Commit f403e1dd authored by Ilya Kirillov's avatar Ilya Kirillov

Fixed several bugs with calculating a footnotes.

parent 1b89a438
...@@ -7641,10 +7641,14 @@ ParaFootnoteReference.prototype.Get_Footnote = function() ...@@ -7641,10 +7641,14 @@ ParaFootnoteReference.prototype.Get_Footnote = function()
{ {
return this.Footnote; return this.Footnote;
}; };
ParaFootnoteReference.prototype.UpdateNumber = function(nPageAbs, nColumnAbs, nAdditional) ParaFootnoteReference.prototype.UpdateNumber = function(PRS)
{ {
if (this.Footnote) if (this.Footnote && true !== PRS.IsFastRecalculate())
{ {
var nPageAbs = PRS.GetPageAbs();
var nColumnAbs = PRS.GetColumnAbs();
var nAdditional = PRS.GetFootnoteReferencesCount()
var oLogicDocument = this.Footnote.Get_LogicDocument(); var oLogicDocument = this.Footnote.Get_LogicDocument();
var oFootnotesController = oLogicDocument.GetFootnotesController(); var oFootnotesController = oLogicDocument.GetFootnotesController();
this.Number = oFootnotesController.GetFootnoteNumberOnPage(nPageAbs, nColumnAbs) + nAdditional; this.Number = oFootnotesController.GetFootnoteNumberOnPage(nPageAbs, nColumnAbs) + nAdditional;
......
...@@ -1875,56 +1875,6 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu ...@@ -1875,56 +1875,6 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu
return true; return true;
var oTopDocument = PRS.TopDocument; var oTopDocument = PRS.TopDocument;
// for (var nIndex = 0, nCount = PRS.Footnotes.length; nIndex < nCount; ++nIndex)
// {
// var oFootnote = PRS.Footnotes[nIndex].FootnoteReference.Get_Footnote();
// var oPos = PRS.Footnotes[nIndex].Pos;
//
// // Проверим позицию
// if (true === this.MoveToLBP && PRS.LineBreakPos.Compare(oPos) >= 0)
// return true;
//
// // TODO: Здесь надо разобраться с параграфами внутри таблицы.
// if (oTopDocument instanceof CDocument)
// {
// var RecalcInfo = oTopDocument.RecalcInfo;
// var nPageAbs = PRS.PageAbs;
// var nColumnAbs = PRS.ColumnAbs;
// if (true === RecalcInfo.Can_RecalcObject())
// {
// RecalcInfo.Set_FootnoteReference(oFootnote, nPageAbs, nColumnAbs);
// oTopDocument.Footnotes.AddFootnoteToPage(nPageAbs, nColumnAbs, oFootnote, this.Pages[CurPage].Y + this.Lines[CurLine].Bottom);
// PRS.RecalcResult = recalcresult_CurPage | recalcresultflags_Column | recalcresultflags_Footnotes;
// return false;
// }
// else if (true === RecalcInfo.Check_FootnoteReference(oFootnote))
// {
// if (true === RecalcInfo.Is_PageBreakBefore())
// {
// //PRS.RecalcResult
// }
//
// if (nPageAbs === RecalcInfo.FootnotePage && nColumnAbs === RecalcInfo.FootnoteColumn)
// {
// // Все нормально пересчиталось
// RecalcInfo.Reset_FootnoteReference();
// }
// else
// {
// // TODO: Реализовать
// RecalcInfo.Set_PageBreakBefore(true);
// oTopDocument.Footnotes.RemoveFootnoteFromPage(nPageAbs, nColumnAbs, oFootnote);
// PRS.RecalcResult = recalcresult_CurPage | recalcresultflags_Column | recalcresultflags_Footnotes;
// return false;
// }
// }
// else
// {
// // Ничего не делаем, просто пропускаем ссылку на данную сноску
// }
// }
// }
var arrFootnotes = []; var arrFootnotes = [];
for (var nIndex = 0, nCount = PRS.Footnotes.length; nIndex < nCount; ++nIndex) for (var nIndex = 0, nCount = PRS.Footnotes.length; nIndex < nCount; ++nIndex)
{ {
...@@ -1932,8 +1882,8 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu ...@@ -1932,8 +1882,8 @@ Paragraph.prototype.private_RecalculateLineCheckFootnotes = function(CurLine, Cu
var oPos = PRS.Footnotes[nIndex].Pos; var oPos = PRS.Footnotes[nIndex].Pos;
// Проверим позицию // Проверим позицию
if (true === this.MoveToLBP && PRS.LineBreakPos.Compare(oPos) >= 0) if (true === PRS.MoveToLBP && PRS.LineBreakPos.Compare(oPos) <= 0)
return true; continue;
arrFootnotes.push(oFootnote); arrFootnotes.push(oFootnote);
} }
...@@ -3007,22 +2957,38 @@ CParagraphRecalculateStateWrap.prototype = ...@@ -3007,22 +2957,38 @@ CParagraphRecalculateStateWrap.prototype =
NumberingItem.LineAscent = LineAscent; NumberingItem.LineAscent = LineAscent;
return X; return X;
}, }
};
Add_FootnoteReference : function(FootnoteReference, Pos) CParagraphRecalculateStateWrap.prototype.AddFootnoteReference = function(FootnoteReference, Pos)
{ {
this.Footnotes.push({FootnoteReference : FootnoteReference, Pos : Pos}); this.Footnotes.push({FootnoteReference : FootnoteReference, Pos : Pos});
}, };
CParagraphRecalculateStateWrap.prototype.GetFootnoteReferencesCount = function()
GetFootnoteReferencesCount : function() {
{
return this.Footnotes.length; return this.Footnotes.length;
}, };
CParagraphRecalculateStateWrap.prototype.SetFast = function(bValue)
SetFast : function(bValue) {
{
this.Fast = bValue; this.Fast = bValue;
} };
CParagraphRecalculateStateWrap.prototype.IsFastRecalculate = function()
{
return this.Fast;
};
CParagraphRecalculateStateWrap.prototype.GetPageAbs = function()
{
return this.PageAbs;
};
CParagraphRecalculateStateWrap.prototype.GetColumnAbs = function()
{
return this.ColumnAbs;
};
CParagraphRecalculateStateWrap.prototype.GetCurrentContentPos = function(nPos)
{
var oContentPos = this.CurPos.Copy();
oContentPos.Set(this.CurPos);
oContentPos.Add(nPos);
return oContentPos;
}; };
function CParagraphRecalculateStateCounter() function CParagraphRecalculateStateCounter()
......
...@@ -2343,8 +2343,8 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth) ...@@ -2343,8 +2343,8 @@ ParaRun.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
if (para_FootnoteReference === ItemType) if (para_FootnoteReference === ItemType)
{ {
Item.UpdateNumber(PRS.PageAbs, PRS.ColumnAbs, PRS.GetFootnoteReferencesCount()); Item.UpdateNumber(PRS);
PRS.Add_FootnoteReference(Item, Pos); PRS.AddFootnoteReference(Item, PRS.GetCurrentContentPos(Pos));
} }
else if (para_FootnoteRef === ItemType) else if (para_FootnoteRef === ItemType)
{ {
......
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