Commit d9860e44 authored by alexey.musinov's avatar alexey.musinov

Merge branch 'develop' of https://github.com/ONLYOFFICE/sdkjs into develop

parents 0acb1bf1 e5aa82ac
...@@ -438,12 +438,12 @@ DependencyGraph.prototype = { ...@@ -438,12 +438,12 @@ DependencyGraph.prototype = {
if(cwf) if(cwf)
{ {
if(!toAdd) if(!toAdd)
delete cwf.cells[sOldCellId]; delete cwf[sOldCellId];
if(!toDelete) if(!toDelete)
{ {
var cell = node.returnCell(); var cell = node.returnCell();
if ( cell && cell.formulaParsed ) if ( cell && cell.formulaParsed )
cwf.cells[node.cellId] = node.cellId; cwf[node.cellId] = node.cellId;
} }
} }
} }
...@@ -2098,16 +2098,16 @@ Workbook.prototype.copyWorksheet=function(index, insertBefore, sName, sId, bFrom ...@@ -2098,16 +2098,16 @@ Workbook.prototype.copyWorksheet=function(index, insertBefore, sName, sId, bFrom
//для формул. создаем копию this.cwf[this.Id] для нового листа. //для формул. создаем копию this.cwf[this.Id] для нового листа.
if ( this.cwf[wsFrom.getId()] ){ if ( this.cwf[wsFrom.getId()] ){
var cwf = { cells:{} }; var cwf = {};
var newSheetId = newSheet.getId(); var newSheetId = newSheet.getId();
var cwfFrom = this.cwf[wsFrom.getId()]; var cwfFrom = this.cwf[wsFrom.getId()];
this.cwf[newSheetId] = cwf; this.cwf[newSheetId] = cwf;
for( var id in cwfFrom.cells ){ for( var id in cwfFrom ){
cwf.cells[id] = cwfFrom.cells[id]; cwf[id] = cwfFrom[id];
this.needRecalc.nodes[getVertexId(newSheetId, id)] = [newSheetId, id]; this.needRecalc.nodes[getVertexId(newSheetId, id)] = [newSheetId, id];
this.needRecalc.length++; this.needRecalc.length++;
} }
newSheet._BuildDependencies(cwf.cells); newSheet._BuildDependencies(cwf);
} }
if(!tableNames && newSheet.TableParts && newSheet.TableParts.length) if(!tableNames && newSheet.TableParts && newSheet.TableParts.length)
...@@ -2145,7 +2145,7 @@ Workbook.prototype.insertWorksheet = function (index, sheet, cwf) { ...@@ -2145,7 +2145,7 @@ Workbook.prototype.insertWorksheet = function (index, sheet, cwf) {
this._insertTablePartsName(sheet); this._insertTablePartsName(sheet);
//восстанавливаем список ячеек с формулами для sheet //восстанавливаем список ячеек с формулами для sheet
this.cwf[sheet.getId()] = cwf; this.cwf[sheet.getId()] = cwf;
sheet._BuildDependencies(cwf.cells); sheet._BuildDependencies(cwf);
this.sortDependency(); this.sortDependency();
}; };
Workbook.prototype._insertTablePartsName = function (sheet) { Workbook.prototype._insertTablePartsName = function (sheet) {
...@@ -2737,7 +2737,7 @@ Workbook.prototype.buildDependency = function(){ ...@@ -2737,7 +2737,7 @@ Workbook.prototype.buildDependency = function(){
// this.dependencyFormulas = null; // this.dependencyFormulas = null;
// this.dependencyFormulas = new DependencyGraph(this); // this.dependencyFormulas = new DependencyGraph(this);
for(var i in this.cwf){ for(var i in this.cwf){
this.getWorksheetById(i)._BuildDependencies(this.cwf[i].cells); this.getWorksheetById(i)._BuildDependencies(this.cwf[i]);
} }
}; };
Workbook.prototype.recalcDependency = function(f,bad,notRecalc){ Workbook.prototype.recalcDependency = function(f,bad,notRecalc){
...@@ -3057,20 +3057,20 @@ Workbook.prototype.getTableNameColumnByIndex = function(tableName, columnIndex){ ...@@ -3057,20 +3057,20 @@ Workbook.prototype.getTableNameColumnByIndex = function(tableName, columnIndex){
} }
return res; return res;
}; };
Workbook.prototype.updateSparklineCache = function(sheet, ranges) { Workbook.prototype.updateSparklineCache = function (sheet, ranges) {
for (var i = 0; i < this.aWorksheets.length; ++i) { for (var i = 0; i < this.aWorksheets.length; ++i) {
this.aWorksheets[i].updateSparklineCache(sheet, ranges); this.aWorksheets[i].updateSparklineCache(sheet, ranges);
} }
}; };
Workbook.prototype.lockDraw = function() { Workbook.prototype.lockDraw = function () {
++this.lockCounter; ++this.lockCounter;
}; };
Workbook.prototype.unLockDraw = function() { Workbook.prototype.unLockDraw = function () {
if (0 < this.lockCounter) { if (0 < this.lockCounter) {
--this.lockCounter; --this.lockCounter;
} }
}; };
Workbook.prototype.buildRecalc = function(notrec, bForce) { Workbook.prototype.buildRecalc = function (notrec, bForce) {
var ws; var ws;
if (this.lockCounter > 0 && !bForce) { if (this.lockCounter > 0 && !bForce) {
return; return;
...@@ -3100,8 +3100,8 @@ Workbook.prototype.buildRecalc = function(notrec, bForce) { ...@@ -3100,8 +3100,8 @@ Workbook.prototype.buildRecalc = function(notrec, bForce) {
if (!notrec) { if (!notrec) {
this.sortDependency(); this.sortDependency();
} }
}; };
Workbook.prototype.sortDependency = function(setCellFormat) { Workbook.prototype.sortDependency = function (setCellFormat) {
this.buildRecalc(true); this.buildRecalc(true);
var i; var i;
...@@ -3109,9 +3109,10 @@ Workbook.prototype.sortDependency = function(setCellFormat) { ...@@ -3109,9 +3109,10 @@ Workbook.prototype.sortDependency = function(setCellFormat) {
if (nR && (nR.length > 0)) { if (nR && (nR.length > 0)) {
var oCleanCellCacheArea = {}; var oCleanCellCacheArea = {};
var oNodeDependence = this.dependencyFormulas.getNodeDependence(nR.nodes); var oNodeDependence = this.dependencyFormulas.getNodeDependence(nR.nodes);
for (i in oNodeDependence.oMasterNodes) for (i in oNodeDependence.oMasterNodes) {
this._sortDependency(oNodeDependence.oMasterNodes[i], oNodeDependence, oNodeDependence.oMasterAreaNodes, false, this._sortDependency(oNodeDependence.oMasterNodes[i], oNodeDependence, oNodeDependence.oMasterAreaNodes, false,
oCleanCellCacheArea, setCellFormat); oCleanCellCacheArea, setCellFormat);
}
//те AreaNodes //те AreaNodes
var oCurMasterAreaNodes = oNodeDependence.oMasterAreaNodes; var oCurMasterAreaNodes = oNodeDependence.oMasterAreaNodes;
while (true) { while (true) {
...@@ -3133,15 +3134,17 @@ Workbook.prototype.sortDependency = function(setCellFormat) { ...@@ -3133,15 +3134,17 @@ Workbook.prototype.sortDependency = function(setCellFormat) {
break; break;
} }
} }
for (i in oCleanCellCacheArea) for (i in oCleanCellCacheArea) {
this.handlers.trigger("cleanCellCache", i, oCleanCellCacheArea[i], AscCommonExcel.c_oAscCanChangeColWidth.none); this.handlers.trigger("cleanCellCache", i, oCleanCellCacheArea[i], AscCommonExcel.c_oAscCanChangeColWidth.none);
}
AscCommonExcel.g_oVLOOKUPCache.clean(); AscCommonExcel.g_oVLOOKUPCache.clean();
AscCommonExcel.g_oHLOOKUPCache.clean(); AscCommonExcel.g_oHLOOKUPCache.clean();
} }
this.needRecalc = {nodes: {}, length: 0}; this.needRecalc = {nodes: {}, length: 0};
}; };
Workbook.prototype._sortDependency = function(node, oNodeDependence, oNewMasterAreaNodes, bBad, oCleanCellCacheArea, setCellFormat) { Workbook.prototype._sortDependency =
function (node, oNodeDependence, oNewMasterAreaNodes, bBad, oCleanCellCacheArea, setCellFormat) {
if (node) { if (node) {
var oWeightMapElem = oNodeDependence.oWeightMap[node.nodeId]; var oWeightMapElem = oNodeDependence.oWeightMap[node.nodeId];
if (oWeightMapElem) { if (oWeightMapElem) {
...@@ -3187,14 +3190,15 @@ Workbook.prototype._sortDependency = function(node, oNodeDependence, oNewMasterA ...@@ -3187,14 +3190,15 @@ Workbook.prototype._sortDependency = function(node, oNodeDependence, oNewMasterA
oWeightMapElem.gray = true; oWeightMapElem.gray = true;
var oSlaveNodes = node.getSlaveEdges(); var oSlaveNodes = node.getSlaveEdges();
if (oSlaveNodes) { if (oSlaveNodes) {
for (var i in oSlaveNodes) for (var i in oSlaveNodes) {
this._sortDependency(oSlaveNodes[i], oNodeDependence, oNewMasterAreaNodes, bBad, oCleanCellCacheArea); this._sortDependency(oSlaveNodes[i], oNodeDependence, oNewMasterAreaNodes, bBad, oCleanCellCacheArea);
} }
}
oWeightMapElem.gray = false; oWeightMapElem.gray = false;
} }
} }
} }
}; };
//------------------------------------------------------------------------------------------------- //-------------------------------------------------------------------------------------------------
/** /**
* @constructor * @constructor
...@@ -3439,7 +3443,7 @@ Woorksheet.prototype.copyDrawingObjects=function(oNewWs, wsFrom) ...@@ -3439,7 +3443,7 @@ Woorksheet.prototype.copyDrawingObjects=function(oNewWs, wsFrom)
} }
}; };
Woorksheet.prototype.initPostOpen = function(handlers){ Woorksheet.prototype.initPostOpen = function(handlers){
this.workbook.cwf[this.Id]={ cells:{} }; var cwf = this.workbook.cwf[this.Id]={};
if(this.aFormulaExt){ if(this.aFormulaExt){
var formulaShared = {}; var formulaShared = {};
for(var i = 0; i < this.aFormulaExt.length; ++i){ for(var i = 0; i < this.aFormulaExt.length; ++i){
...@@ -3474,7 +3478,7 @@ Woorksheet.prototype.initPostOpen = function(handlers){ ...@@ -3474,7 +3478,7 @@ Woorksheet.prototype.initPostOpen = function(handlers){
off.offsetRow *=-1; off.offsetRow *=-1;
formulaShared[oFormulaExt.si].fVal.changeOffset(off); formulaShared[oFormulaExt.si].fVal.changeOffset(off);
} }
this.workbook.cwf[this.Id].cells[sCellId] = sCellId; cwf[sCellId] = sCellId;
} }
} }
} }
...@@ -3495,7 +3499,7 @@ Woorksheet.prototype.initPostOpen = function(handlers){ ...@@ -3495,7 +3499,7 @@ Woorksheet.prototype.initPostOpen = function(handlers){
Если ячейка содержит в себе формулу, то добавляем ее в список ячеек с формулами. Если ячейка содержит в себе формулу, то добавляем ее в список ячеек с формулами.
*/ */
if(oCell.sFormula){ if(oCell.sFormula){
this.workbook.cwf[this.Id].cells[sCellId] = sCellId; cwf[sCellId] = sCellId;
} }
/* /*
Строится список ячеек, которые необходимо пересчитать при открытии. Это ячейки имеющие атрибут f.ca или значение в которых неопределено. Строится список ячеек, которые необходимо пересчитать при открытии. Это ячейки имеющие атрибут f.ca или значение в которых неопределено.
...@@ -3800,7 +3804,7 @@ Woorksheet.prototype.setName=function(name, bFromUndoRedo){ ...@@ -3800,7 +3804,7 @@ Woorksheet.prototype.setName=function(name, bFromUndoRedo){
//перестраиваем формулы, если у них были ссылки на лист со старым именем. //перестраиваем формулы, если у них были ссылки на лист со старым именем.
for(var id in this.workbook.cwf) { for(var id in this.workbook.cwf) {
this.workbook.getWorksheetById(id)._ReBuildFormulas(this.workbook.cwf[id].cells,lastName,this.sName); this.workbook.getWorksheetById(id)._ReBuildFormulas(this.workbook.cwf[id],lastName,this.sName);
} }
this.workbook.dependencyFormulas.relinkDefNameByWorksheet(lastName, name); this.workbook.dependencyFormulas.relinkDefNameByWorksheet(lastName, name);
......
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