Commit 3edb6b4e authored by Ilya Kirillov's avatar Ilya Kirillov

Implemented a recalculation of a simple situation with a footnote with in a table.

parent 63f3f49f
...@@ -104,6 +104,7 @@ var recalcresultflags_Footnotes = 0x010000; // Сообщаем, что ...@@ -104,6 +104,7 @@ var recalcresultflags_Footnotes = 0x010000; // Сообщаем, что
// Типы которые возвращают классы CDocument и CDocumentContent после пересчета страницы // Типы которые возвращают классы CDocument и CDocumentContent после пересчета страницы
var recalcresult2_End = 0x00; // Документ рассчитан до конца var recalcresult2_End = 0x00; // Документ рассчитан до конца
var recalcresult2_NextPage = 0x01; // Рассчет нужно продолжить var recalcresult2_NextPage = 0x01; // Рассчет нужно продолжить
var recalcresult2_CurPage = 0x02; // Нужно заново пересчитать данную страницу
var document_EditingType_Common = 0x00; // Обычный режим редактирования var document_EditingType_Common = 0x00; // Обычный режим редактирования
var document_EditingType_Review = 0x01; // Режим рецензирования var document_EditingType_Review = 0x01; // Режим рецензирования
...@@ -11402,29 +11403,6 @@ CDocument.prototype.Goto_FootnotesOnPage = function(nPageIndex) ...@@ -11402,29 +11403,6 @@ CDocument.prototype.Goto_FootnotesOnPage = function(nPageIndex)
return true; return true;
}; };
/**
* Находим отрезок сносок, заданный между сносками.
* @param {?CFootEndnote} oFirstFootnote - если null, то иещм с начала документа
* @param {?CFootEndnote} oLastFootnote - если null, то ищем до конца документа
*/
CDocument.prototype.Get_FootnotesList = function(oFirstFootnote, oLastFootnote)
{
var oEngine = new CDocumentFootnotesRangeEngine();
oEngine.Init(oFirstFootnote, oLastFootnote);
var arrFootnotes = [];
var arrParagraphs = this.Get_AllParagraphs({OnlyMainDocument : true, All : true});
for (var nIndex = 0, nCount = arrParagraphs.length; nIndex < nCount; ++nIndex)
{
var oParagraph = arrParagraphs[nIndex];
if (true === oParagraph.Get_FootnotesList(oEngine))
return arrFootnotes;
}
return oEngine.GetRange();
};
CDocument.prototype.AddFootnote = function() CDocument.prototype.AddFootnote = function()
{ {
var nDocPosType = this.Get_DocPosType(); var nDocPosType = this.Get_DocPosType();
......
...@@ -1074,6 +1074,10 @@ CDocumentContent.prototype.Recalculate_Page = function(PageIndex, ...@@ -1074,6 +1074,10 @@ CDocumentContent.prototype.Recalculate_Page = function(PageIndex,
if (RecalcResult & recalcresult_CurPage) if (RecalcResult & recalcresult_CurPage)
{ {
// Такое не должно приходить в автофигурах, только в таблицах основного документа. Проверка на это находится в параграфе.
if (RecalcResult & recalcresultflags_Footnotes)
return recalcresult2_CurPage | recalcresultflags_Column | recalcresultflags_Footnotes;
return this.Recalculate_Page(PageIndex, false); return this.Recalculate_Page(PageIndex, false);
} }
else if (RecalcResult & recalcresult_NextElement) else if (RecalcResult & recalcresult_NextElement)
...@@ -1432,12 +1436,16 @@ CDocumentContent.prototype.Get_FirstParagraph = function() ...@@ -1432,12 +1436,16 @@ CDocumentContent.prototype.Get_FirstParagraph = function()
}; };
CDocumentContent.prototype.Get_AllParagraphs = function(Props, ParaArray) CDocumentContent.prototype.Get_AllParagraphs = function(Props, ParaArray)
{ {
var arrParagraphs = (ParaArray ? ParaArray : []);
var Count = this.Content.length; var Count = this.Content.length;
for (var Index = 0; Index < Count; Index++) for (var Index = 0; Index < Count; Index++)
{ {
var Element = this.Content[Index]; var Element = this.Content[Index];
Element.Get_AllParagraphs(Props, ParaArray); Element.Get_AllParagraphs(Props, arrParagraphs);
} }
return arrParagraphs;
}; };
// Специальная функция, используемая в колонтитулах для добавления номера страницы // Специальная функция, используемая в колонтитулах для добавления номера страницы
// При этом удаляются все параграфы. Добавляются два новых // При этом удаляются все параграфы. Добавляются два новых
......
...@@ -151,7 +151,29 @@ CDocumentContentBase.prototype.Reassign_ImageUrls = function(mapUrls) ...@@ -151,7 +151,29 @@ CDocumentContentBase.prototype.Reassign_ImageUrls = function(mapUrls)
oDrawing.Reassign_ImageUrls(mapUrls); oDrawing.Reassign_ImageUrls(mapUrls);
} }
}; };
/**
* Находим отрезок сносок, заданный между сносками.
* @param {?CFootEndnote} oFirstFootnote - если null, то иещм с начала документа
* @param {?CFootEndnote} oLastFootnote - если null, то ищем до конца документа
*/
CDocumentContentBase.prototype.Get_FootnotesList = function(oFirstFootnote, oLastFootnote)
{
var oEngine = new CDocumentFootnotesRangeEngine();
oEngine.Init(oFirstFootnote, oLastFootnote);
var arrFootnotes = [];
var arrParagraphs = this.Get_AllParagraphs({OnlyMainDocument : true, All : true});
for (var nIndex = 0, nCount = arrParagraphs.length; nIndex < nCount; ++nIndex)
{
var oParagraph = arrParagraphs[nIndex];
if (true === oParagraph.Get_FootnotesList(oEngine))
return arrFootnotes;
}
return oEngine.GetRange();
};
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Private area // Private area
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
......
...@@ -348,7 +348,7 @@ Paragraph.prototype.Recalculate_FastRange = function(SimpleChanges) ...@@ -348,7 +348,7 @@ Paragraph.prototype.Recalculate_FastRange = function(SimpleChanges)
* Предыдущая страница ДОЛЖНА быть пересчитана, если задано не нулевое значение. * Предыдущая страница ДОЛЖНА быть пересчитана, если задано не нулевое значение.
* @returns {*} Возвращается результат пересчета * @returns {*} Возвращается результат пересчета
*/ */
Paragraph.prototype.Recalculate_Page = function(PageIndex) Paragraph.prototype.Recalculate_Page = function(CurPage)
{ {
this.Clear_NearestPosArray(); this.Clear_NearestPosArray();
...@@ -360,7 +360,6 @@ Paragraph.prototype.Recalculate_Page = function(PageIndex) ...@@ -360,7 +360,6 @@ Paragraph.prototype.Recalculate_Page = function(PageIndex)
this.Internal_CheckSpelling(); this.Internal_CheckSpelling();
var CurPage = PageIndex;
var RecalcResult = this.private_RecalculatePage( CurPage ); var RecalcResult = this.private_RecalculatePage( CurPage );
this.private_CheckColumnBreak(CurPage); this.private_CheckColumnBreak(CurPage);
...@@ -560,11 +559,7 @@ Paragraph.prototype.private_RecalculateFastRange = function(CurRange, CurL ...@@ -560,11 +559,7 @@ Paragraph.prototype.private_RecalculateFastRange = function(CurRange, CurL
Paragraph.prototype.private_RecalculatePage = function(CurPage, bFirstRecalculate) Paragraph.prototype.private_RecalculatePage = function(CurPage, bFirstRecalculate)
{ {
var PRS = this.m_oPRSW; var PRS = this.m_oPRSW;
PRS.Reset_Page(this, CurPage);
PRS.Page = CurPage;
PRS.RunRecalcInfoLast = (0 === CurPage ? null : this.Pages[CurPage - 1].EndInfo.RunRecalcInfo);
PRS.RunRecalcInfoBreak = PRS.RunRecalcInfoLast;
var Pr = this.Get_CompiledPr(); var Pr = this.Get_CompiledPr();
var ParaPr = Pr.ParaPr; var ParaPr = Pr.ParaPr;
...@@ -1348,11 +1343,9 @@ Paragraph.prototype.private_RecalculateLineBottomBound = function(CurLine, CurPa ...@@ -1348,11 +1343,9 @@ Paragraph.prototype.private_RecalculateLineBottomBound = function(CurLine, CurPa
var RealCurPage = this.private_GetRelativePageIndex(CurPage) - this.Get_StartPage_Relative(); var RealCurPage = this.private_GetRelativePageIndex(CurPage) - this.Get_StartPage_Relative();
// TODO: Здесь надо бы ускорить эту проверку var oTopDocument = PRS.TopDocument;
var oTopDocument = this.Parent.Get_TopDocumentContent();
var bNoFootnotes = true; var bNoFootnotes = true;
if (oTopDocument instanceof CDocument && oTopDocument.Footnotes.GetHeight(this.Get_AbsolutePage(CurPage), this.Get_AbsoluteColumn(CurPage)) > 0.001) if (oTopDocument instanceof CDocument && oTopDocument.Footnotes.GetHeight(PRS.PageAbs, PRS.ColumnAbs) > 0.001)
bNoFootnotes = false; bNoFootnotes = false;
// Сначала проверяем не нужно ли сделать перенос страницы в данном месте // Сначала проверяем не нужно ли сделать перенос страницы в данном месте
...@@ -1842,6 +1835,7 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu ...@@ -1842,6 +1835,7 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu
if (!((PRS.RecalcResult & recalcresult_NextElement) || (PRS.RecalcResult & recalcresult_NextLine))) if (!((PRS.RecalcResult & recalcresult_NextElement) || (PRS.RecalcResult & recalcresult_NextLine)))
return false; return false;
var oTopDocument = PRS.TopDocument;
for (var nIndex = 0, nCount = PRS.Footnotes.length; nIndex < nCount; ++nIndex) for (var nIndex = 0, nCount = PRS.Footnotes.length; nIndex < nCount; ++nIndex)
{ {
var oFootnote = PRS.Footnotes[nIndex].FootnoteReference.Get_Footnote(); var oFootnote = PRS.Footnotes[nIndex].FootnoteReference.Get_Footnote();
...@@ -1852,15 +1846,15 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu ...@@ -1852,15 +1846,15 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu
return true; return true;
// TODO: Здесь надо разобраться с параграфами внутри таблицы. // TODO: Здесь надо разобраться с параграфами внутри таблицы.
if (this.Parent instanceof CDocument) if (oTopDocument instanceof CDocument)
{ {
var RecalcInfo = this.Parent.RecalcInfo; var RecalcInfo = oTopDocument.RecalcInfo;
var nPageAbs = this.Get_AbsolutePage(CurPage); var nPageAbs = PRS.PageAbs;
var nColumnAbs = this.Get_AbsoluteColumn(CurPage); var nColumnAbs = PRS.ColumnAbs;
if (true === RecalcInfo.Can_RecalcObject()) if (true === RecalcInfo.Can_RecalcObject())
{ {
RecalcInfo.Set_FootnoteReference(oFootnote, nPageAbs, nColumnAbs); RecalcInfo.Set_FootnoteReference(oFootnote, nPageAbs, nColumnAbs);
this.Parent.Footnotes.AddFootnoteToPage(nPageAbs, nColumnAbs, oFootnote, this.Pages[CurPage].Y + this.Lines[CurLine].Bottom); oTopDocument.Footnotes.AddFootnoteToPage(nPageAbs, nColumnAbs, oFootnote, this.Pages[CurPage].Y + this.Lines[CurLine].Bottom);
PRS.RecalcResult = recalcresult_CurPage | recalcresultflags_Column | recalcresultflags_Footnotes; PRS.RecalcResult = recalcresult_CurPage | recalcresultflags_Column | recalcresultflags_Footnotes;
return false; return false;
} }
...@@ -1880,7 +1874,7 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu ...@@ -1880,7 +1874,7 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu
{ {
// TODO: Реализовать // TODO: Реализовать
RecalcInfo.Set_PageBreakBefore(true); RecalcInfo.Set_PageBreakBefore(true);
this.Parent.Footnotes.RemoveFootnoteFromPage(nPageAbs, nColumnAbs, oFootnote); oTopDocument.Footnotes.RemoveFootnoteFromPage(nPageAbs, nColumnAbs, oFootnote);
PRS.RecalcResult = recalcresult_CurPage | recalcresultflags_Column | recalcresultflags_Footnotes; PRS.RecalcResult = recalcresult_CurPage | recalcresultflags_Column | recalcresultflags_Footnotes;
return false; return false;
} }
...@@ -2526,8 +2520,14 @@ CParagraphRecalculateTabInfo.prototype = ...@@ -2526,8 +2520,14 @@ CParagraphRecalculateTabInfo.prototype =
function CParagraphRecalculateStateWrap(Para) function CParagraphRecalculateStateWrap(Para)
{ {
// Общие параметры, которые заполняются 1 раз на пересчет всей страницы
this.Paragraph = Para; this.Paragraph = Para;
this.Parent = null;
this.TopDocument = null;
this.PageAbs = 0;
this.ColumnAbs = 0;
//
this.Page = 0; this.Page = 0;
this.Line = 0; this.Line = 0;
this.Range = 0; this.Range = 0;
...@@ -2636,6 +2636,18 @@ function CParagraphRecalculateStateWrap(Para) ...@@ -2636,6 +2636,18 @@ function CParagraphRecalculateStateWrap(Para)
CParagraphRecalculateStateWrap.prototype = CParagraphRecalculateStateWrap.prototype =
{ {
Reset_Page : function(Paragraph, CurPage)
{
this.Paragraph = Paragraph;
this.Parent = Paragraph.Parent;
this.TopDocument = Paragraph.Parent.Get_TopDocumentContent();
this.PageAbs = Paragraph.Get_AbsolutePage(CurPage);
this.ColumnAbs = Paragraph.Get_AbsoluteColumn(CurPage);
this.RunRecalcInfoLast = (0 === CurPage ? null : Paragraph.Pages[CurPage - 1].EndInfo.RunRecalcInfo);
this.RunRecalcInfoBreak = this.RunRecalcInfoLast;
},
// Обнуляем некоторые параметры перед новой строкой // Обнуляем некоторые параметры перед новой строкой
Reset_Line : function() Reset_Line : function()
{ {
......
...@@ -51,6 +51,8 @@ CTable.prototype.Recalculate_Page = function(PageIndex) ...@@ -51,6 +51,8 @@ CTable.prototype.Recalculate_Page = function(PageIndex)
this.private_RecalculatePositionX(PageIndex); this.private_RecalculatePositionX(PageIndex);
var Result = this.private_RecalculatePage(PageIndex); var Result = this.private_RecalculatePage(PageIndex);
if (Result & recalcresult_CurPage)
return Result;
this.private_RecalculatePositionY(PageIndex); this.private_RecalculatePositionY(PageIndex);
...@@ -2366,6 +2368,11 @@ CTable.prototype.private_RecalculatePage = function(CurPage) ...@@ -2366,6 +2368,11 @@ CTable.prototype.private_RecalculatePage = function(CurPage)
{ {
bCanShift = true; bCanShift = true;
ShiftDy = -Cell.Content.Pages[0].Y + Y_content_start; ShiftDy = -Cell.Content.Pages[0].Y + Y_content_start;
// Если в ячейке есть ссылки на сноски, тогда такую ячейку нужно пересчитывать
var arrFootnotes = Cell.Content.Get_FootnotesList(null, null);
if (arrFootnotes && arrFootnotes.length > 0)
bCanShift = false;
} }
} }
...@@ -2385,11 +2392,32 @@ CTable.prototype.private_RecalculatePage = function(CurPage) ...@@ -2385,11 +2392,32 @@ CTable.prototype.private_RecalculatePage = function(CurPage)
Cell.Content.Shift( 0, ShiftDx, ShiftDy ); Cell.Content.Shift( 0, ShiftDx, ShiftDy );
Cell.Content.Update_EndInfo(); Cell.Content.Update_EndInfo();
} }
else if ( recalcresult2_NextPage === Cell.Content.Recalculate_Page( CellPageIndex, true ) ) else
{
var RecalcResult = Cell.Content.Recalculate_Page(CellPageIndex, true);
if (recalcresult2_CurPage & RecalcResult)
{
var _RecalcResult = recalcresult_CurPage;
if (RecalcResult & recalcresultflags_Column)
_RecalcResult |= recalcresultflags_Column;
if (RecalcResult & recalcresultflags_Footnotes)
_RecalcResult |= recalcresultflags_Footnotes;
this.TurnOffRecalc = false;
return _RecalcResult;
}
else if (recalcresult2_NextPage & RecalcResult)
{ {
Cell.PagesCount = Cell.Content.Pages.length + 1; Cell.PagesCount = Cell.Content.Pages.length + 1;
bNextPage = true; bNextPage = true;
} }
else if (recalcresult2_End & RecalcResult)
{
// Ничего не делаем
}
}
var CellContentBounds = Cell.Content.Get_PageBounds( CellPageIndex, undefined, true ); var CellContentBounds = Cell.Content.Get_PageBounds( CellPageIndex, undefined, true );
var CellContentBounds_Bottom = CellContentBounds.Bottom + BottomMargin; var CellContentBounds_Bottom = CellContentBounds.Bottom + BottomMargin;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment