/* * (c) Copyright Ascensio System SIA 2010-2024 * * This program is a free software product. You can redistribute it and/or * modify it under the terms of the GNU Affero General Public License (AGPL) * version 3 as published by the Free Software Foundation. In accordance with * Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect * that Ascensio System SIA expressly excludes the warranty of non-infringement * of any third-party rights. * * This program is distributed WITHOUT ANY WARRANTY; without even the implied * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For * details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html * * You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish * street, Riga, Latvia, EU, LV-1050. * * The interactive user interfaces in modified source and object code versions * of the Program must display Appropriate Legal Notices, as required under * Section 5 of the GNU AGPL version 3. * * Pursuant to Section 7(b) of the License you must retain the original Product * logo when distributing the program. Pursuant to Section 7(e) we decline to * grant you any rights under trademark law for use of our trademarks. * * All the Product's GUI elements, including illustrations and icon sets, as * well as technical writing content are licensed under the terms of the * Creative Commons Attribution-ShareAlike 4.0 International. See the License * terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode * */ "use strict"; (function (window, undefined) { /* * Import * ----------------------------------------------------------------------------- */ var FT_Common = AscFonts.FT_Common; var CellValueType = AscCommon.CellValueType; var EIconSetType = Asc.EIconSetType; var asc_error = Asc.c_oAscError.ID; /** * Отвечает за условное форматирование * ----------------------------------------------------------------------------- * * @constructor * @memberOf Asc */ function CConditionalFormatting() { this.pivot = false; this.ranges = null; this.aRules = []; return this; } CConditionalFormatting.prototype.setSqRef = function (sqRef) { this.ranges = AscCommonExcel.g_oRangeCache.getRangesFromSqRef(sqRef); }; CConditionalFormatting.prototype.isValid = function () { //todo more checks return this.ranges && this.ranges.length > 0; }; CConditionalFormatting.prototype.initRules = function () { for (var i = 0; i < this.aRules.length; ++i) { this.aRules[i].updateConditionalFormatting(this); } }; //todo need another approach function CConditionalFormattingFormulaParent(ws, rule, isDefName) { this.ws = ws; this.rule = rule; this.isDefName = isDefName; } CConditionalFormattingFormulaParent.prototype.onFormulaEvent = function (type, eventData) { if (AscCommon.c_oNotifyParentType.IsDefName === type && this.isDefName) { return {bbox: this.rule.getBBox(), ranges: this.rule.ranges}; } else if (AscCommon.c_oNotifyParentType.Change === type) { this.ws.setDirtyConditionalFormatting(new AscCommonExcel.MultiplyRange(this.rule.ranges)); } }; CConditionalFormattingFormulaParent.prototype.clone = function () { return new CConditionalFormattingFormulaParent(this.ws, this.rule, this.isDefName); }; function CConditionalFormattingRule() { this.aboveAverage = true; this.activePresent = false; this.bottom = false; this.dxf = null; this.equalAverage = false; this.id = AscCommon.g_oIdCounter.Get_NewId(); this.operator = null; this.percent = false; this.priority = null; this.rank = null; this.stdDev = null; this.stopIfTrue = false; this.text = null; this.timePeriod = null; this.type = null; this.aRuleElements = []; // from CConditionalFormatting // Combined all the rules into one array to sort the priorities, // so they transferred these properties to the rule this.pivot = false; this.ranges = null; this.isLock = null; return this; } CConditionalFormattingRule.prototype.Get_Id = function () { return this.id; }; CConditionalFormattingRule.prototype.getType = function () { return AscCommonExcel.UndoRedoDataTypes.CFDataInner; }; CConditionalFormattingRule.prototype.clone = function () { var i, res = new CConditionalFormattingRule(); res.aboveAverage = this.aboveAverage; res.bottom = this.bottom; if (this.dxf) { res.dxf = this.dxf.clone(); } res.equalAverage = this.equalAverage; res.operator = this.operator; res.percent = this.percent; res.priority = this.priority; res.rank = this.rank; res.stdDev = this.stdDev; res.stopIfTrue = this.stopIfTrue; res.text = this.text; res.timePeriod = this.timePeriod; res.type = this.type; res.updateConditionalFormatting(this); for (i = 0; i < this.aRuleElements.length; ++i) { res.aRuleElements.push(this.aRuleElements[i].clone()); } return res; }; CConditionalFormattingRule.prototype.combineRangesToSingle = function () { let ranges = this.ranges; if (!ranges || !ranges.length) { return null; } if (ranges.length === 1) { return ranges[0]; } // Sort ranges by position let sortedRanges = ranges.slice().sort(function(a, b) { // First compare by rows if (a.r1 !== b.r1) { return a.r1 - b.r1; } // Then by columns if rows are equal return a.c1 - b.c1; }); let result = sortedRanges[0].clone(); let canCombine = true; for (let i = 1; i < sortedRanges.length; i++) { let current = sortedRanges[i]; // Check if ranges can be combined horizontally (same rows) if (current.r1 === result.r1 && current.r2 === result.r2 && current.c1 <= result.c2 + 1) { // Extend range horizontally result.c2 = Math.max(result.c2, current.c2); continue; } // Check if ranges can be combined vertically (same columns) if (current.c1 === result.c1 && current.c2 === result.c2 && current.r1 <= result.r2 + 1) { // Extend range vertically result.r2 = Math.max(result.r2, current.r2); continue; } // Cannot combine - ranges are not continuous canCombine = false; break; } if (canCombine) { this.ranges = [result]; } }; CConditionalFormattingRule.prototype.merge = function (oRule) { if (this.aboveAverage === true) { this.aboveAverage = oRule.aboveAverage; } if (this.activePresent === false) { this.activePresent = oRule.activePresent; } if (this.bottom === false) { this.bottom = oRule.bottom; } //TODO merge if (this.dxf === null) { this.dxf = oRule.dxf; } if (this.equalAverage === false) { this.equalAverage = oRule.equalAverage; } if (this.operator === null) { this.operator = oRule.operator; } if (this.percent === false) { this.percent = oRule.percent; } if (this.priority === null) { this.priority = oRule.priority; } if (this.rank === null) { this.rank = oRule.rank; } if (this.stdDev === null) { this.stdDev = oRule.stdDev; } if (this.stopIfTrue === false) { this.stopIfTrue = oRule.stopIfTrue; } if (this.text === null) { this.text = oRule.text; } if (this.timePeriod === null) { this.timePeriod = oRule.timePeriod; } if (this.type === null) { this.type = oRule.type; } if (this.aRuleElements && this.aRuleElements.length === 0) { this.aRuleElements = oRule.aRuleElements; } else if (this.aRuleElements && oRule.aRuleElements && this.aRuleElements.length === oRule.aRuleElements.length) { for (var i = 0; i < this.aRuleElements.length; i++) { this.aRuleElements[i].merge(oRule.aRuleElements[i]); } } //this.aRuleElements = []; if (this.pivot === false) { this.pivot = oRule.pivot; } if (this.ranges === null) { this.ranges = oRule.ranges; } if (this.isLock === null) { this.isLock = oRule.isLock; } }; CConditionalFormattingRule.prototype.recalcInterfaceFormula = function (ws, toInterface) { for (var i = 0; i < this.aRuleElements.length; i++) { this.aRuleElements[i].recalcFormula && this.aRuleElements[i].recalcFormula(ws, toInterface); } }; CConditionalFormattingRule.prototype.Write_ToBinary2 = function (writer) { //for wrapper //writer.WriteLong(this.getObjectType()); writer.WriteBool(this.aboveAverage); writer.WriteBool(this.activePresent); writer.WriteBool(this.bottom); if (null != this.dxf) { var dxf = this.dxf; writer.WriteBool(true); var oBinaryStylesTableWriter = new AscCommonExcel.BinaryStylesTableWriter(writer); oBinaryStylesTableWriter.bs.WriteItem(0, function () { oBinaryStylesTableWriter.WriteDxf(dxf); }); } else { writer.WriteBool(false); } writer.WriteBool(this.equalAverage); if (null != this.operator) { writer.WriteBool(true); writer.WriteLong(this.operator); } else { writer.WriteBool(false); } writer.WriteBool(this.percent); if (null != this.priority) { writer.WriteBool(true); writer.WriteLong(this.priority); } else { writer.WriteBool(false); } if (null != this.rank) { writer.WriteBool(true); writer.WriteLong(this.rank); } else { writer.WriteBool(false); } if (null != this.stdDev) { writer.WriteBool(true); writer.WriteLong(this.stdDev); } else { writer.WriteBool(false); } writer.WriteBool(this.stopIfTrue); if (null != this.text) { writer.WriteBool(true); writer.WriteString2(this.text); } else { writer.WriteBool(false); } if (null != this.timePeriod) { writer.WriteBool(true); writer.WriteString2(this.timePeriod); } else { writer.WriteBool(false); } if (null != this.type) { writer.WriteBool(true); writer.WriteLong(this.type); } else { writer.WriteBool(false); } var i; if (null != this.aRuleElements) { writer.WriteBool(true); writer.WriteLong(this.aRuleElements.length); for (i = 0; i < this.aRuleElements.length; i++) { writer.WriteLong(this.aRuleElements[i].type); this.aRuleElements[i].Write_ToBinary2(writer); } } else { writer.WriteBool(false); } writer.WriteBool(this.pivot); if (null != this.ranges) { writer.WriteBool(true); writer.WriteLong(this.ranges.length); for (i = 0; i < this.ranges.length; i++) { writer.WriteLong(this.ranges[i].r1); writer.WriteLong(this.ranges[i].c1); writer.WriteLong(this.ranges[i].r2); writer.WriteLong(this.ranges[i].c2); } } else { writer.WriteBool(false); } }; CConditionalFormattingRule.prototype.Read_FromBinary2 = function (reader) { this.aboveAverage = reader.GetBool(); this.activePresent = reader.GetBool(); this.bottom = reader.GetBool(); var length, i; if (reader.GetBool()) { var api_sheet = Asc['editor']; var wb = api_sheet.wbModel; var bsr = new AscCommonExcel.Binary_StylesTableReader(reader, wb); var bcr = new AscCommon.Binary_CommonReader(reader); var oDxf = new AscCommonExcel.CellXfs(); reader.GetUChar(); length = reader.GetULongLE(); bcr.Read1(length, function (t, l) { return bsr.ReadDxf(t, l, oDxf); }); this.dxf = oDxf; } this.equalAverage = reader.GetBool(); if (reader.GetBool()) { this.operator = reader.GetLong(); } this.percent = reader.GetBool(); if (reader.GetBool()) { this.priority = reader.GetLong(); } if (reader.GetBool()) { this.rank = reader.GetLong(); } if (reader.GetBool()) { this.stdDev = reader.GetLong(); } this.stopIfTrue = reader.GetBool(); if (reader.GetBool()) { this.text = reader.GetString2(); } if (reader.GetBool()) { this.timePeriod = reader.GetString2(); } if (reader.GetBool()) { this.type = reader.GetLong(); } if (reader.GetBool()) { length = reader.GetULong(); for (i = 0; i < length; ++i) { if (!this.aRuleElements) { this.aRuleElements = []; } var type = reader.GetLong(); var elem; switch (type) { case Asc.ECfType.colorScale: elem = new CColorScale(); break; case Asc.ECfType.dataBar: elem = new CDataBar(); break; case Asc.ECfType.iconSet: elem = new CIconSet(); break; default: elem = new CFormulaCF(); break; //TODO ?CFormulaCF } elem.Read_FromBinary2(reader); this.aRuleElements.push(elem); } } this.pivot = reader.GetBool(); if (reader.GetBool()) { length = reader.GetULong(); for (i = 0; i < length; ++i) { if (!this.ranges) { this.ranges = []; } var r1 = reader.GetLong(); var c1 = reader.GetLong(); var r2 = reader.GetLong(); var c2 = reader.GetLong(); this.ranges.push(new Asc.Range(c1, r1, c2, r2)); } } }; CConditionalFormattingRule.prototype.set = function (val, addToHistory, ws) { this.aboveAverage = this.checkProperty(this.aboveAverage, val.aboveAverage, AscCH.historyitem_CFRule_SetAboveAverage, ws, addToHistory); this.activePresent = this.checkProperty(this.activePresent, val.activePresent, AscCH.historyitem_CFRule_SetActivePresent, ws, addToHistory); this.bottom = this.checkProperty(this.bottom, val.bottom, AscCH.historyitem_CFRule_SetBottom, ws, addToHistory); this.equalAverage = this.checkProperty(this.equalAverage, val.equalAverage, AscCH.historyitem_CFRule_SetEqualAverage, ws, addToHistory); this.operator = this.checkProperty(this.operator, val.operator, AscCH.historyitem_CFRule_SetOperator, ws, addToHistory); this.percent = this.checkProperty(this.percent, val.percent, AscCH.historyitem_CFRule_SetPercent, ws, addToHistory); this.priority = this.checkProperty(this.priority, val.priority, AscCH.historyitem_CFRule_SetPriority, ws, addToHistory); this.rank = this.checkProperty(this.rank, val.rank, AscCH.historyitem_CFRule_SetRank, ws, addToHistory); this.stdDev = this.checkProperty(this.stdDev, val.stdDev, AscCH.historyitem_CFRule_SetStdDev, ws, addToHistory); this.stopIfTrue = this.checkProperty(this.stopIfTrue, val.stopIfTrue, AscCH.historyitem_CFRule_SetStopIfTrue, ws, addToHistory); this.text = this.checkProperty(this.text, val.text, AscCH.historyitem_CFRule_SetText, ws, addToHistory); this.timePeriod = this.checkProperty(this.timePeriod, val.timePeriod, AscCH.historyitem_CFRule_SetTimePeriod, ws, addToHistory); this.type = this.checkProperty(this.type, val.type, AscCH.historyitem_CFRule_SetType, ws, addToHistory); this.pivot = this.checkProperty(this.pivot, val.pivot, AscCH.historyitem_CFRule_SetPivot, ws, addToHistory); var compareElements = function (_elem1, _elem2) { if (_elem1.length === _elem2.length) { for (var i = 0; i < _elem1.length; i++) { if (!_elem1[i].isEqual(_elem2[i])) { return false; } } return true; } return false; }; if (!compareElements(this.aRuleElements, val.aRuleElements)) { if (addToHistory) { History.Add(AscCommonExcel.g_oUndoRedoCF, AscCH.historyitem_CFRule_SetRuleElements, ws.getId(), this.getUnionRange(), new AscCommonExcel.UndoRedoData_CF(this.id, this.aRuleElements, val.aRuleElements)); } this.aRuleElements = val.aRuleElements; } if ((this.dxf && val.dxf && !this.dxf.isEqual(val.dxf)) || (this.dxf && !val.dxf) || (!this.dxf && val.dxf)) { var elem = val.dxf ? val.dxf.clone() : null; if (addToHistory) { History.Add(AscCommonExcel.g_oUndoRedoCF, AscCH.historyitem_CFRule_SetDxf, ws.getId(), this.getUnionRange(), new AscCommonExcel.UndoRedoData_CF(this.id, this.dxf, elem)); } this.dxf = elem; } if (this.ranges && val.ranges && !compareElements(this.ranges, val.ranges)) { this.setLocation(val.ranges, ws, true); } }; CConditionalFormattingRule.prototype.setLocation = function (location, ws, addToHistory) { if (addToHistory && !History.TurnOffHistory) { var getUndoRedoRange = function (_ranges) { var needRanges = []; for (var i = 0; i < _ranges.length; i++) { needRanges.push(new AscCommonExcel.UndoRedoData_BBox(_ranges[i])); } return needRanges; }; History.Add(AscCommonExcel.g_oUndoRedoCF, AscCH.historyitem_CFRule_SetRanges, ws.getId(), this.getUnionRange(location), new AscCommonExcel.UndoRedoData_CF(this.id, getUndoRedoRange(this.ranges), getUndoRedoRange(location))); } this.ranges = location; if (ws) { ws.cleanConditionalFormattingRangeIterator(); } }; CConditionalFormattingRule.prototype.checkProperty = function (propOld, propNew, type, ws, addToHistory) { if (propOld !== propNew) { if (addToHistory) { History.Add(AscCommonExcel.g_oUndoRedoCF, type, ws.getId(), this.getUnionRange(), new AscCommonExcel.UndoRedoData_CF(this.id, propOld, propNew)); } return propNew; } return propOld; }; CConditionalFormattingRule.prototype.setOffset = function (offset, range, ws, addToHistory) { var newRanges = []; var isChange = false; var _setDiff = function (_range) { //TODO объединть в одну функцию с dataValidation(.shift) var _newRanges, _offset, tempRange, intersection, otherPart, diff; if (range && range.getType() === Asc.c_oAscSelectionType.RangeCells) { if (offset.row !== 0) { //c_oAscInsertOptions.InsertCellsAndShiftDown tempRange = new Asc.Range(range.c1, range.r1, range.c2, AscCommon.gc_nMaxRow0); intersection = tempRange.intersection(_range); if (intersection) { diff = range.r2 - range.r1 + 1; _newRanges = []; //добавляем сдвинутую часть диапазона _newRanges.push(intersection); _offset = new AscCommon.CellBase(offset.row > 0 ? diff : -diff, 0); otherPart = _newRanges[0].difference(_range); _newRanges[0].setOffset(_offset); //исключаем сдвинутую часть из диапазона _newRanges = _newRanges.concat(otherPart); } } else if (offset.col !== 0) { //c_oAscInsertOptions.InsertCellsAndShiftRight tempRange = new Asc.Range(range.c1, range.r1, AscCommon.gc_nMaxCol0, range.r2); intersection = tempRange.intersection(_range); if (intersection) { diff = range.c2 - range.c1 + 1; _newRanges = []; //добавляем сдвинутую часть диапазона _newRanges.push(intersection); _offset = new AscCommon.CellBase(0, offset.col > 0 ? diff : -diff, 0); otherPart = _newRanges[0].difference(_range); _newRanges[0].setOffset(_offset); //исключаем сдвинутую часть из диапазона _newRanges = _newRanges.concat(otherPart); } } } return _newRanges; }; for (var i = 0; i < this.ranges.length; i++) { var newRange = this.ranges[i].clone(); if (range.isIntersectForShift(newRange, offset)) { if (newRange.forShift(range, offset)) { if (ws.autoFilters.isAddTotalRow && newRange.containsRange(this.ranges[i])) { newRange = this.ranges[i].clone(); } else { isChange = true; } } newRanges.push(newRange); } else { if (ws.autoFilters.isAddTotalRow && newRange.containsRange(this.ranges[i])) { newRange = this.ranges[i].clone(); } else { var changedRanges = _setDiff(this.ranges[i]); if (changedRanges) { newRanges = newRanges.concat(changedRanges); isChange = true; } else { newRanges = newRanges.concat(this.ranges[i].clone()); } } } } if (isChange) { this.setLocation(newRanges, ws, addToHistory); if (ws) { ws.setDirtyConditionalFormatting(new AscCommonExcel.MultiplyRange(newRanges)) } } }; CConditionalFormattingRule.prototype.updateFormulas = function (ws) { if (this.aRuleElements && this.aRuleElements.length) { for (let i = 0; i < this.aRuleElements.length; i++) { let _formula = this.aRuleElements[i] && this.aRuleElements[i]._f && this.aRuleElements[i].getFormula && this.aRuleElements[i].getFormula(ws); if (_formula && _formula.Formula && this.aRuleElements[i] && this.aRuleElements[i].Text && this.aRuleElements[i].Text !== _formula.Formula) { this.aRuleElements[i].Text = this.aRuleElements[i].getFormulaStr(); } } } }; CConditionalFormattingRule.prototype.getUnionRange = function (opt_ranges) { var res = null; var _getUnionRanges = function (_ranges) { if (!_ranges) { return null; } var _res = null; for (var i = 0; i < _ranges.length; i++) { if (!_res) { _res = _ranges[i].clone(); } else { _res.union2(_ranges[i]); } } return _res; }; if (opt_ranges) { res = _getUnionRanges(opt_ranges); } if (this.ranges) { var tempRange = _getUnionRanges(this.ranges); if (tempRange) { if (res) { res.union2(tempRange) } else { res = tempRange; } } } return res; }; CConditionalFormattingRule.prototype.getTimePeriod = function () { var start, end; var now = new Asc.cDate(); now.setUTCHours(0, 0, 0, 0); switch (this.timePeriod) { case AscCommonExcel.ST_TimePeriod.last7Days: now.setUTCDate(now.getUTCDate() + 1); end = now.getExcelDate(); now.setUTCDate(now.getUTCDate() - 7); start = now.getExcelDate(); break; case AscCommonExcel.ST_TimePeriod.lastMonth: now.setUTCDate(1); end = now.getExcelDate(); now.setUTCMonth(now.getUTCMonth() - 1); start = now.getExcelDate(); break; case AscCommonExcel.ST_TimePeriod.thisMonth: now.setUTCDate(1); start = now.getExcelDate(); now.setUTCMonth(now.getUTCMonth() + 1); end = now.getExcelDate(); break; case AscCommonExcel.ST_TimePeriod.nextMonth: now.setUTCDate(1); now.setUTCMonth(now.getUTCMonth() + 1); start = now.getExcelDate(); now.setUTCMonth(now.getUTCMonth() + 1); end = now.getExcelDate(); break; case AscCommonExcel.ST_TimePeriod.lastWeek: now.setUTCDate(now.getUTCDate() - now.getUTCDay()); end = now.getExcelDate(); now.setUTCDate(now.getUTCDate() - 7); start = now.getExcelDate(); break; case AscCommonExcel.ST_TimePeriod.thisWeek: now.setUTCDate(now.getUTCDate() - now.getUTCDay()); start = now.getExcelDate(); now.setUTCDate(now.getUTCDate() + 7); end = now.getExcelDate(); break; case AscCommonExcel.ST_TimePeriod.nextWeek: now.setUTCDate(now.getUTCDate() - now.getUTCDay() + 7); start = now.getExcelDate(); now.setUTCDate(now.getUTCDate() + 7); end = now.getExcelDate(); break; case AscCommonExcel.ST_TimePeriod.yesterday: end = now.getExcelDate(); now.setUTCDate(now.getUTCDate() - 1); start = now.getExcelDate(); break; case AscCommonExcel.ST_TimePeriod.today: start = now.getExcelDate(); now.setUTCDate(now.getUTCDate() + 1); end = now.getExcelDate(); break; case AscCommonExcel.ST_TimePeriod.tomorrow: now.setUTCDate(now.getUTCDate() + 1); start = now.getExcelDate(); now.setUTCDate(now.getUTCDate() + 1); end = now.getExcelDate(); break; } return {start: start, end: end}; }; CConditionalFormattingRule.prototype.getValueCellIs = function (ws, opt_parent, opt_bbox, opt_offset, opt_returnRaw) { var res; if (null !== this.text) { res = new AscCommonExcel.cString(this.text); } else if (this.aRuleElements[0] && (this.type === Asc.ECfType.notContainsText || this.type === Asc.ECfType.containsText)) { //ms see on bool result of first formula //formula1/formula2: true/false -> true, false/true -> false, false/false -> false res = this.aRuleElements[0].getValue(ws, opt_parent, opt_bbox, opt_offset, opt_returnRaw); } else if (this.aRuleElements[1]) { res = this.aRuleElements[1].getValue(ws, opt_parent, opt_bbox, opt_offset, opt_returnRaw); } return res; }; CConditionalFormattingRule.prototype.getFormulaCellIs = function (opt_getFirstRule) { return null === this.text && this.aRuleElements[opt_getFirstRule ? 0 : 1]; }; CConditionalFormattingRule.prototype.cellIs = function (operator, cell, v1, v2) { if (operator === AscCommonExcel.ECfOperator.Operator_beginsWith || operator === AscCommonExcel.ECfOperator.Operator_endsWith || operator === AscCommonExcel.ECfOperator.Operator_containsText || operator === AscCommonExcel.ECfOperator.Operator_notContains) { //ms see on bool result of first formula //formula1/formula2: true/false -> true, false/true -> false, false/false -> false if (v1 && v1.tocBool) { let boolVal = v1.tocBool(); if (boolVal && (boolVal.value === false || boolVal.value === true)){ return boolVal.value; } } return this._cellIsText(operator, cell, v1); } else { return this._cellIsNumber(operator, cell, v1, v2); } }; CConditionalFormattingRule.prototype._cellIsText = function (operator, cell, v1) { if (!v1 || AscCommonExcel.cElementType.empty === v1.type) { v1 = new AscCommonExcel.cString(""); } if (AscCommonExcel.ECfOperator.Operator_notContains === operator) { return !this._cellIsText(AscCommonExcel.ECfOperator.Operator_containsText, cell, v1); } var cellType = cell ? cell.type : null; if (cellType === CellValueType.Error || AscCommonExcel.cElementType.error === v1.type) { return false; } var res = false; var cellVal = cell ? cell.getValueWithoutFormat().toLowerCase() : ""; var v1Val = v1.toLocaleString().toLowerCase(); switch (operator) { case AscCommonExcel.ECfOperator.Operator_beginsWith: case AscCommonExcel.ECfOperator.Operator_endsWith: if (AscCommonExcel.cElementType.string === v1.type && (cellType === CellValueType.String || "" === v1Val)) { if (AscCommonExcel.ECfOperator.Operator_beginsWith === operator) { res = cellVal.startsWith(v1Val); } else { res = cellVal.endsWith(v1Val); } } else { res = false; } break; case AscCommonExcel.ECfOperator.Operator_containsText: if ("" === cellVal) { res = false; } else { res = -1 !== cellVal.indexOf(v1Val); } break; } return res; }; CConditionalFormattingRule.prototype._cellIsNumber = function (operator, cell, v1, v2) { if (!v1 || AscCommonExcel.cElementType.empty === v1.type) { v1 = new AscCommonExcel.cNumber(0); } if ((cell && cell.type === CellValueType.Error) || AscCommonExcel.cElementType.error === v1.type) { return false; } var cellVal; var res = false; switch (operator) { case AscCommonExcel.ECfOperator.Operator_equal: if (AscCommonExcel.cElementType.number === v1.type) { if (!cell || cell.isNullTextString()) { res = 0 === v1.getValue(); } else if (cell.type === CellValueType.Number) { res = cell.getNumberValue() === v1.getValue(); } else { res = false; } } else if (AscCommonExcel.cElementType.string === v1.type) { if (!cell || cell.isNullTextString()) { res = "" === v1.getValue().toLowerCase(); } else if (cell.type === CellValueType.String) { cellVal = cell.getValueWithoutFormat().toLowerCase(); res = cellVal === v1.getValue().toLowerCase(); } else { res = false; } } else if (AscCommonExcel.cElementType.bool === v1.type) { if (cell && cell.type === CellValueType.Bool) { res = cell.getBoolValue() === v1.toBool(); } else { res = false; } } break; case AscCommonExcel.ECfOperator.Operator_notEqual: res = !this._cellIsNumber(AscCommonExcel.ECfOperator.Operator_equal, cell, v1); break; case AscCommonExcel.ECfOperator.Operator_greaterThan: if (AscCommonExcel.cElementType.number === v1.type) { if (!cell || cell.isNullTextString()) { res = 0 > v1.getValue(); } else if (cell.type === CellValueType.Number) { res = cell.getNumberValue() > v1.getValue(); } else { res = true; } } else if (AscCommonExcel.cElementType.string === v1.type) { if (!cell || cell.isNullTextString()) { res = "" > v1.getValue().toLowerCase(); } else if (cell.type === CellValueType.Number) { res = false; } else if (cell.type === CellValueType.String) { cellVal = cell.getValueWithoutFormat().toLowerCase(); //todo Excel uses different string compare function res = cellVal > v1.getValue().toLowerCase(); } else if (cell.type === CellValueType.Bool) { res = true; } } else if (AscCommonExcel.cElementType.bool === v1.type) { if (cell && cell.type === CellValueType.Bool) { res = cell.getBoolValue() > v1.toBool(); } else { res = false; } } break; case AscCommonExcel.ECfOperator.Operator_greaterThanOrEqual: res = this._cellIsNumber(AscCommonExcel.ECfOperator.Operator_greaterThan, cell, v1) || this._cellIsNumber(AscCommonExcel.ECfOperator.Operator_equal, cell, v1); break; case AscCommonExcel.ECfOperator.Operator_lessThan: res = !this._cellIsNumber(AscCommonExcel.ECfOperator.Operator_greaterThanOrEqual, cell, v1); break; case AscCommonExcel.ECfOperator.Operator_lessThanOrEqual: res = !this._cellIsNumber(AscCommonExcel.ECfOperator.Operator_greaterThan, cell, v1); break; case AscCommonExcel.ECfOperator.Operator_between: res = this._cellIsNumber(AscCommonExcel.ECfOperator.Operator_greaterThanOrEqual, cell, v1) && this._cellIsNumber(AscCommonExcel.ECfOperator.Operator_lessThanOrEqual, cell, v2); break; case AscCommonExcel.ECfOperator.Operator_notBetween: res = !this._cellIsNumber(AscCommonExcel.ECfOperator.Operator_between, cell, v1, v2); break; } return res; }; CConditionalFormattingRule.prototype.getAverage = function (val, average, stdDev) { var res = false; if (this.stdDev && stdDev) { average += ((this.aboveAverage ? 1 : -1) * this.stdDev) * stdDev; } if (this.aboveAverage) { res = val > average; } else { res = val < average; } res = res || (this.equalAverage && val == average); return res; }; CConditionalFormattingRule.prototype.hasStdDev = function () { return null !== this.stdDev; }; CConditionalFormattingRule.prototype.updateConditionalFormatting = function (cf) { var i; this.pivot = cf.pivot; if (cf.ranges) { this.ranges = []; for (i = 0; i < cf.ranges.length; ++i) { this.ranges.push(cf.ranges[i].clone()); } } }; CConditionalFormattingRule.prototype.getBBox = function () { var bbox = null; if (this.ranges && this.ranges.length > 0) { bbox = this.ranges[0].clone(); for (var i = 1; i < this.ranges.length; ++i) { bbox.union2(this.ranges[i]); } } return bbox; }; CConditionalFormattingRule.prototype.containsIntoRange = function (range) { var res = null; if (this.ranges && this.ranges.length > 0) { res = true; for (var i = 0; i < this.ranges.length; ++i) { if (!range.containsRange(this.ranges[i])) { res = false; break; } } } return res; }; CConditionalFormattingRule.prototype.containsIntoRange = function (range) { var res = null; if (this.ranges && this.ranges.length > 0) { res = true; for (var i = 0; i < this.ranges.length; ++i) { if (!range.containsRange(this.ranges[i])) { res = false; break; } } } return res; }; CConditionalFormattingRule.prototype.getIntersections = function (range) { var res = []; if (this.ranges) { for (var i = 0; i < this.ranges.length; ++i) { var intersection = this.ranges[i].intersection(range); if (intersection) { res.push(intersection); } } } return res.length ? res : null; }; CConditionalFormattingRule.prototype.getIndexRule = function (values, ws, value) { var valueCFVO; var aCFVOs = this._getCFVOs(); var bReverse = this.aRuleElements && this.aRuleElements[0] && this.aRuleElements[0].Reverse; for (var i = aCFVOs.length - 1; i >= 0; --i) { valueCFVO = this._getValue(values, aCFVOs[i], ws); if (value > valueCFVO || (aCFVOs[i].Gte && value === valueCFVO)) { return bReverse ? aCFVOs.length - 1 - i : i; } } return 0; }; CConditionalFormattingRule.prototype.getMin = function (values, ws) { var aCFVOs = this._getCFVOs(); var oCFVO = (aCFVOs && 0 < aCFVOs.length) ? aCFVOs[0] : null; return this._getValue(values, oCFVO, ws); }; CConditionalFormattingRule.prototype.getMid = function (values, ws) { var aCFVOs = this._getCFVOs(); var oCFVO = (aCFVOs && 2 < aCFVOs.length) ? aCFVOs[1] : null; return this._getValue(values, oCFVO, ws); }; CConditionalFormattingRule.prototype.getMax = function (values, ws) { var aCFVOs = this._getCFVOs(); var oCFVO = (aCFVOs && 2 === aCFVOs.length) ? aCFVOs[1] : ((aCFVOs && 2 < aCFVOs.length) ? aCFVOs[2] : null); return this._getValue(values, oCFVO, ws); }; CConditionalFormattingRule.prototype._getCFVOs = function () { var oRuleElement = this.aRuleElements[0]; return oRuleElement && oRuleElement.aCFVOs; }; CConditionalFormattingRule.prototype._getValue = function (values, oCFVO, ws) { var res, min; if (oCFVO) { if (oCFVO.Val) { res = 0; if (null === oCFVO.formula) { oCFVO.formulaParent = new CConditionalFormattingFormulaParent(ws, this, false); oCFVO.formula = new CFormulaCF(); oCFVO.formula.Text = oCFVO.Val; } var calcRes = oCFVO.formula.getValue(ws, oCFVO.formulaParent, null, null, true); if (calcRes && calcRes.tocNumber) { calcRes = calcRes.tocNumber(); if (calcRes && calcRes.toNumber) { res = calcRes.toNumber(); } } } switch (oCFVO.Type) { case AscCommonExcel.ECfvoType.Minimum: res = AscCommonExcel.getArrayMin(values); break; case AscCommonExcel.ECfvoType.Maximum: res = AscCommonExcel.getArrayMax(values); break; case AscCommonExcel.ECfvoType.Number: break; case AscCommonExcel.ECfvoType.Percent: min = AscCommonExcel.getArrayMin(values); res = min + (AscCommonExcel.getArrayMax(values) - min) * res / 100; break; case AscCommonExcel.ECfvoType.Percentile: res = AscCommonExcel.getPercentile(values, res / 100.0); if (AscCommonExcel.cElementType.number === res.type) { res = res.getValue(); } else { res = AscCommonExcel.getArrayMin(values); } break; case AscCommonExcel.ECfvoType.Formula: break; case AscCommonExcel.ECfvoType.AutoMin: res = Math.min(0, AscCommonExcel.getArrayMin(values)); break; case AscCommonExcel.ECfvoType.AutoMax: res = Math.max(0, AscCommonExcel.getArrayMax(values)); break; default: res = -Number.MAX_VALUE; break; } } return res; }; CConditionalFormattingRule.prototype.applyPreset = function (presetId) { var presetType = presetId[0]; var styleIndex = presetId[1]; var elem; switch (presetType) { case Asc.c_oAscCFRuleTypeSettings.dataBar: elem = new CDataBar(); elem.applyPreset(styleIndex); this.type = Asc.ECfType.dataBar; break; case Asc.c_oAscCFRuleTypeSettings.colorScale: elem = new CColorScale(); elem.applyPreset(styleIndex); this.type = Asc.ECfType.colorScale; break; case Asc.c_oAscCFRuleTypeSettings.icons: elem = new CIconSet(); elem.applyPreset(styleIndex); this.type = Asc.ECfType.iconSet; break; } if (elem) { this.aRuleElements.push(elem); } }; CConditionalFormattingRule.prototype.asc_getType = function () { return this.type; }; CConditionalFormattingRule.prototype.asc_getDxf = function () { return this.dxf; }; CConditionalFormattingRule.prototype.asc_getLocation = function () { var arrResult = []; var t = this; if (this.ranges) { var wb = Asc['editor'].wbModel; var isActive = true, sheet; for (var i = 0; i < wb.aWorksheets.length; i++) { if (i !== wb.nActive) { if (wb.aWorksheets[i].getCFRuleById(t.id)) { isActive = false; } if (!isActive) { sheet = wb.aWorksheets[i]; return true; } } } this.ranges.forEach(function (item) { arrResult.push((sheet ? sheet.sName + "!" : "") + item.getAbsName()); }); } return [isActive, "=" + arrResult.join(AscCommon.FormulaSeparators.functionArgumentSeparator)]; }; CConditionalFormattingRule.prototype.asc_getContainsText = function () { if (null !== this.text) { return this.text; } var ruleElement = this.aRuleElements[1]; return ruleElement && ruleElement.getFormula ? "=" + ruleElement.Text : null; }; CConditionalFormattingRule.prototype.asc_getTimePeriod = function () { return this.timePeriod; }; CConditionalFormattingRule.prototype.asc_getOperator = function () { return this.operator; }; CConditionalFormattingRule.prototype.asc_getPriority = function () { return this.priority; }; CConditionalFormattingRule.prototype.asc_getRank = function () { return this.rank; }; CConditionalFormattingRule.prototype.asc_getBottom = function () { return this.bottom; }; CConditionalFormattingRule.prototype.asc_getPercent = function () { return this.percent; }; CConditionalFormattingRule.prototype.asc_getAboveAverage = function () { return this.aboveAverage; }; CConditionalFormattingRule.prototype.asc_getEqualAverage = function () { return this.equalAverage; }; CConditionalFormattingRule.prototype.asc_getStdDev = function () { return this.stdDev; }; CConditionalFormattingRule.prototype.asc_getStopIfTrue = function () { return this.stopIfTrue; }; CConditionalFormattingRule.prototype.asc_getText = function () { return this.text; }; CConditionalFormattingRule.prototype.asc_getValue1 = function () { var ruleElement = this.aRuleElements[0]; return ruleElement && ruleElement.getFormula ? "=" + ruleElement.getFormulaStr(true) : null; }; CConditionalFormattingRule.prototype.asc_getValue2 = function () { var ruleElement = this.aRuleElements[1]; return ruleElement && ruleElement.getFormula ? "=" + ruleElement.getFormulaStr(true) : null; }; CConditionalFormattingRule.prototype.asc_getColorScaleOrDataBarOrIconSetRule = function () { if ((Asc.ECfType.dataBar === this.type || Asc.ECfType.iconSet === this.type || Asc.ECfType.colorScale === this.type) && 1 === this.aRuleElements.length) { var res = this.aRuleElements[0]; if (res && this.type === res.type) { return res; } } return null; }; CConditionalFormattingRule.prototype.asc_getId = function () { return this.id; }; CConditionalFormattingRule.prototype.asc_getIsLock = function () { return this.isLock; }; CConditionalFormattingRule.prototype.asc_getPreview = function (id, text) { var api_sheet = Asc['editor']; var res; if (Asc.ECfType.colorScale === this.type && 1 === this.aRuleElements.length) { res = this.aRuleElements[0].asc_getPreview(api_sheet, id, text); } else if (Asc.ECfType.dataBar === this.type && 1 === this.aRuleElements.length) { res = this.aRuleElements[0].asc_getPreview(api_sheet, id); } else if (Asc.ECfType.iconSet === this.type && 1 === this.aRuleElements.length) { res = this.aRuleElements[0].asc_getPreview(api_sheet, id); } else { if (this.dxf) { res = this.dxf.asc_getPreview2(api_sheet, id, text); } else { var tempXfs = new AscCommonExcel.CellXfs(); res = tempXfs.asc_getPreview2(api_sheet, id, text); } } return res; }; CConditionalFormattingRule.prototype.asc_setType = function (val) { this.type = val; this._cleanAfterChangeType(); var formula = this.getFormulaByType(this.text); if (formula) { this.aRuleElements = []; this.aRuleElements[0] = new CFormulaCF(); this.aRuleElements[0].Text = formula; } }; CConditionalFormattingRule.prototype._cleanAfterChangeType = function () { switch (this.type) { case Asc.ECfType.notContainsErrors: case Asc.ECfType.containsErrors: case Asc.ECfType.notContainsBlanks: case Asc.ECfType.containsBlanks: case Asc.ECfType.timePeriod: this.aRuleElements = []; this.percent = null; this.text = null; this.rank = null; break; case Asc.ECfType.colorScale: this.dxf = null; break; } if (this.type !== Asc.ECfType.top10) { this.rank = null; } }; CConditionalFormattingRule.prototype.asc_setDxf = function (val) { this.dxf = val; }; CConditionalFormattingRule.prototype.asc_setLocation = function (val) { let t = this; if (val) { if (val[0] === "=") { val = val.slice(1); } this.ranges = []; let wb = Asc.editor && Asc.editor.wbModel; let _ranges; if (wb) { let ws = wb.getActiveWs(); _ranges = AscCommonExcel.getRangeByRef(val, ws, true); } if (_ranges) { for (let i = 0; i < _ranges.length; i++) { if (_ranges[i].bbox) { t.ranges.push(_ranges[i].bbox); } } } } }; CConditionalFormattingRule.prototype.asc_setContainsText = function (val) { if (val[0] === "=") { val = val.slice(1); //генерируем массив this.aRuleElements = []; this.aRuleElements[0] = new CFormulaCF(); this.aRuleElements[0].Text = this.getFormulaByType(val, true); this.aRuleElements[1] = new CFormulaCF(); this.aRuleElements[1].Text = val; this.text = null; } else { this.aRuleElements = []; this.aRuleElements[0] = new CFormulaCF(); this.aRuleElements[0].Text = this.getFormulaByType(val); this.text = val; } }; CConditionalFormattingRule.prototype.getFormulaByType = function (val, isFormulaVal) { var t = this; var _generateTimePeriodFunction = function () { switch (t.timePeriod) { case AscCommonExcel.ST_TimePeriod.yesterday: res = "FLOOR(" + firstCellInRange + ",1)" + "=TODAY()-1"; break; case AscCommonExcel.ST_TimePeriod.today: res = "FLOOR(" + firstCellInRange + ",1)" + "=TODAY()"; break; case AscCommonExcel.ST_TimePeriod.tomorrow: res = "FLOOR(" + firstCellInRange + ",1)" + "=TODAY()+1"; break; case AscCommonExcel.ST_TimePeriod.last7Days: res = "AND(TODAY()-FLOOR(" + firstCellInRange + ",1)<=6,FLOOR(" + firstCellInRange + ",1)<=TODAY())"; break; case AscCommonExcel.ST_TimePeriod.lastWeek: res = "AND(TODAY()-ROUNDDOWN(" + firstCellInRange + ",0)>=(WEEKDAY(TODAY())),TODAY()-ROUNDDOWN(" + firstCellInRange + ",0)<(WEEKDAY(TODAY())+7))"; break; case AscCommonExcel.ST_TimePeriod.thisWeek: res = "AND(TODAY()-ROUNDDOWN(" + firstCellInRange + ",0)<=WEEKDAY(TODAY())-1,ROUNDDOWN(" + firstCellInRange + ",0)-TODAY()<=7-WEEKDAY(TODAY()))"; break; case AscCommonExcel.ST_TimePeriod.nextWeek: res = "AND(ROUNDDOWN(" + firstCellInRange + ",0)-TODAY()>(7-WEEKDAY(TODAY())),ROUNDDOWN(" + firstCellInRange + ",0)-TODAY()<(15-WEEKDAY(TODAY())))"; break; case AscCommonExcel.ST_TimePeriod.lastMonth: res = "AND(MONTH(" + firstCellInRange + ")=MONTH(EDATE(TODAY(),0-1)),YEAR(" + firstCellInRange + ")=YEAR(EDATE(TODAY(),0-1)))"; break; case AscCommonExcel.ST_TimePeriod.thisMonth: res = "AND(MONTH(" + firstCellInRange + ")=MONTH(TODAY()),YEAR(" + firstCellInRange + ")=YEAR(TODAY()))"; break; case AscCommonExcel.ST_TimePeriod.nextMonth: res = "AND(MONTH(" + firstCellInRange + ")=MONTH(EDATE(TODAY(),0+1)),YEAR(" + firstCellInRange + ")=YEAR(EDATE(TODAY(),0+1)))"; break; } }; var res = null; var range; if (val !== null && val !== undefined && !isFormulaVal) { val = addQuotes(val); } if (this.ranges && this.ranges[0]) { range = this.ranges[0]; } else { var api_sheet = Asc['editor']; var wb = api_sheet.wbModel; var sheet = wb.getActiveWs(); range = sheet && sheet.selectionRange && sheet.selectionRange.ranges && sheet.selectionRange.ranges[0]; } if (range) { var firstCellInRange = new Asc.Range(range.c1, range.r1, range.c1, range.r1); AscCommonExcel.executeInR1C1Mode(false, function () { firstCellInRange = firstCellInRange.getName(); }); switch (this.type) { case Asc.ECfType.notContainsText: if (val !== null && val !== undefined) { res = "ISERROR(SEARCH(" + val + "," + firstCellInRange + "))"; } break; case Asc.ECfType.containsText: if (val !== null && val !== undefined) { res = "NOT(ISERROR(SEARCH(" + val + "," + firstCellInRange + ")))"; } break; case Asc.ECfType.endsWith: if (val !== null && val !== undefined) { res = "RIGHT(" + firstCellInRange + ",LEN(" + val + "))" + "=" + val; } break; case Asc.ECfType.beginsWith: if (val !== null && val !== undefined) { res = "LEFT(" + firstCellInRange + ",LEN(" + val + "))" + "=" + val; } break; case Asc.ECfType.notContainsErrors: res = "NOT(ISERROR(" + firstCellInRange + "))"; break; case Asc.ECfType.containsErrors: res = "ISERROR(" + firstCellInRange + ")"; break; case Asc.ECfType.notContainsBlanks: res = "LEN(TRIM(" + firstCellInRange + "))>0"; break; case Asc.ECfType.containsBlanks: res = "LEN(TRIM(" + firstCellInRange + "))=0"; break; case Asc.ECfType.timePeriod: res = _generateTimePeriodFunction(); break; } } return res; }; CConditionalFormattingRule.prototype.asc_setTimePeriod = function (val) { this.timePeriod = val; var formula = this.getFormulaByType(); if (formula) { this.aRuleElements = []; this.aRuleElements[0] = new CFormulaCF(); this.aRuleElements[0].Text = formula; } }; CConditionalFormattingRule.prototype.asc_setOperator = function (val) { this.operator = val; }; CConditionalFormattingRule.prototype.asc_setPriority = function (val) { this.priority = val; }; CConditionalFormattingRule.prototype.asc_setRank = function (val) { this.rank = val; }; CConditionalFormattingRule.prototype.asc_setBottom = function (val) { this.bottom = val; }; CConditionalFormattingRule.prototype.asc_setPercent = function (val) { this.percent = val; }; CConditionalFormattingRule.prototype.asc_setAboveAverage = function (val) { this.aboveAverage = val; }; CConditionalFormattingRule.prototype.asc_setEqualAverage = function (val) { this.equalAverage = val; }; CConditionalFormattingRule.prototype.asc_setStdDev = function (val) { this.stdDev = val; }; CConditionalFormattingRule.prototype.asc_setStopIfTrue = function (val) { this.stopIfTrue = val; }; CConditionalFormattingRule.prototype.asc_setText = function (val) { this.text = val; }; CConditionalFormattingRule.prototype.asc_setValue1 = function (val) { //чищу всегда, поскольку от интерфейса всегда заново выставляются оба значения this.aRuleElements = []; val = correctFromInterface(val); this.aRuleElements[0] = new CFormulaCF(); this.aRuleElements[0].Text = val; }; CConditionalFormattingRule.prototype.asc_setValue2 = function (val) { if (!this.aRuleElements) { this.aRuleElements = []; } val = correctFromInterface(val); this.aRuleElements[1] = new CFormulaCF(); this.aRuleElements[1].Text = val; }; CConditionalFormattingRule.prototype.asc_setColorScaleOrDataBarOrIconSetRule = function (val) { this.aRuleElements = []; this.aRuleElements.push(val); }; CConditionalFormattingRule.prototype.asc_checkScope = function (type, tableId) { var sheet, range; var api_sheet = Asc['editor']; var wb = api_sheet.wbModel; switch (type) { case Asc.c_oAscSelectionForCFType.selection: sheet = wb.getActiveWs(); // ToDo multiselect range = sheet.selectionRange.getLast(); break; case Asc.c_oAscSelectionForCFType.worksheet: break; case Asc.c_oAscSelectionForCFType.table: var oTable; if (tableId) { oTable = wb.getTableByName(tableId, true); if (oTable) { sheet = wb.aWorksheets[oTable.index]; range = oTable.table.Ref; } } else { //this table sheet = wb.getActiveWs(); var thisTableIndex = sheet.autoFilters.searchRangeInTableParts(sheet.selectionRange.getLast()); if (thisTableIndex >= 0) { range = sheet.TableParts[thisTableIndex].Ref; } else { sheet = null; } } break; case Asc.c_oAscSelectionForCFType.pivot: sheet = wb.getActiveWs(); var _activeCell = sheet.selectionRange.activeCell; var _pivot = sheet.getPivotTable(_activeCell.col, _activeCell.row); if (_pivot) { range = _pivot.location && _pivot.location.ref; } if (!range) { sheet = null; } break; } if (range) { var multiplyRange = new AscCommonExcel.MultiplyRange(this.ranges); if (multiplyRange.isIntersect(range)) { return true; } } return false; }; CConditionalFormattingRule.sStartLockCFId = 'cfrule_'; function CColorScale() { this.aCFVOs = []; this.aColors = []; return this; } CColorScale.prototype.type = Asc.ECfType.colorScale; CColorScale.prototype.clone = function () { var i, res = new CColorScale(); for (i = 0; i < this.aCFVOs.length; ++i) { res.aCFVOs.push(this.aCFVOs[i].clone()); } for (i = 0; i < this.aColors.length; ++i) { res.aColors.push(this.aColors[i].clone()); } return res; }; CColorScale.prototype.merge = function (obj) { if (this.aCFVOs.length === 0) { this.aCFVOs = obj.aCFVOs; } else if (this.aCFVOs.length === obj.aCFVOs.length) { for (var i = 0; i < this.aCFVOs.length; i++) { this.aCFVOs[i].merge(obj.aCFVOs[i]); } } if (this.aColors && this.aColors.length === 0) { this.aColors = obj.aColors; } else if (this.aColors && obj.aColors && this.aColors.length === obj.aColors.length) { for (var i = 0; i < this.aColors.length; i++) { //TODO //this.aCFVOs[i].merge(obj.aCFVOs[i]); } } }; CColorScale.prototype.applyPreset = function (styleIndex) { var presetStyles = conditionalFormattingPresets[Asc.c_oAscCFRuleTypeSettings.colorScale][styleIndex]; for (var i = 0; i < presetStyles.length; i++) { var formatValueObject = new CConditionalFormatValueObject(); formatValueObject.Type = presetStyles[i][0] ? presetStyles[i][0] : null; formatValueObject.Val = presetStyles[i][1] ? presetStyles[i][1] + "" : null; var colorObject = new AscCommonExcel.RgbColor(presetStyles[i][2] ? presetStyles[i][2] : 0); this.aCFVOs.push(formatValueObject); this.aColors.push(colorObject); } }; CColorScale.prototype.Write_ToBinary2 = function (writer) { //CConditionalFormatValueObject var i; if (null != this.aCFVOs) { writer.WriteBool(true); writer.WriteLong(this.aCFVOs.length); for (i = 0; i < this.aCFVOs.length; i++) { this.aCFVOs[i].Write_ToBinary2(writer); } } else { writer.WriteBool(false); } //rgbcolor,... if (null != this.aColors) { writer.WriteBool(true); writer.WriteLong(this.aColors.length); for (i = 0; i < this.aColors.length; i++) { writer.WriteLong(this.aColors[i].getType()); this.aColors[i].Write_ToBinary2(writer); } } else { writer.WriteBool(false); } }; CColorScale.prototype.Read_FromBinary2 = function (reader) { var i, length, elem; if (reader.GetBool()) { length = reader.GetULong(); for (i = 0; i < length; ++i) { if (!this.aCFVOs) { this.aCFVOs = []; } elem = new CConditionalFormatValueObject(); elem.Read_FromBinary2(reader); this.aCFVOs.push(elem); } } if (reader.GetBool()) { length = reader.GetULong(); for (i = 0; i < length; ++i) { if (!this.aColors) { this.aColors = []; } //TODO colors!!! var type = reader.GetLong(); switch (type) { case AscCommonExcel.UndoRedoDataTypes.RgbColor: elem = new AscCommonExcel.RgbColor(); break; case AscCommonExcel.UndoRedoDataTypes.ThemeColor: elem = new AscCommonExcel.ThemeColor(); break; } if (null != elem.Read_FromBinary2) { elem.Read_FromBinary2(reader); } else if (null != elem.Read_FromBinary2AndReplace) { elem = elem.Read_FromBinary2AndReplace(reader); } this.aColors.push(elem); } } }; CColorScale.prototype.asc_getCFVOs = function () { return this.aCFVOs; }; CColorScale.prototype.asc_getColors = function () { var res = []; for (var i = 0; i < this.aColors.length; ++i) { res.push(Asc.colorObjToAscColor(this.aColors[i])); } return res; }; CColorScale.prototype.asc_getPreview = function (api, id) { return AscCommonExcel.drawGradientPreview(id, api.wb, this.aColors); }; CColorScale.prototype.asc_setCFVOs = function (val) { this.aCFVOs = val; }; CColorScale.prototype.asc_setColors = function (val) { var newArr = []; for (var i = 0; i < val.length; ++i) { if (this.aColors[i] && this.aColors[i].getR() === val[i].asc_getR() && this.aColors[i].getG() === val[i].asc_getG() && this.aColors[i].getB() === val[i].asc_getB()) { newArr.push(this.aColors[i]); } else { newArr.push(AscCommonExcel.CorrectAscColor(val[i])); } } this.aColors = newArr; }; CColorScale.prototype.isEqual = function (elem) { if ((elem.aCFVOs && elem.aCFVOs.length === this.aCFVOs.length) || (!elem.aCFVOs && !this.aCFVOs)) { var i; if (elem.aCFVOs) { for (i = 0; i < elem.aCFVOs.length; i++) { if (!elem.aCFVOs[i].isEqual(this.aCFVOs[i])) { return false; } } } if ((elem.aColors && elem.aColors.length === this.aColors.length) || (!elem.aColors && !this.aColors)) { if (elem.aColors) { for (i = 0; i < elem.aColors.length; i++) { if (!elem.aColors[i].isEqual(this.aColors[i])) { return false; } } } return true; } } return false; }; CColorScale.prototype.getType = function () { return window['AscCommonExcel'].UndoRedoDataTypes.ColorScale; }; function CDataBar() { this.MaxLength = 90; this.MinLength = 10; this.ShowValue = true; this.AxisPosition = AscCommonExcel.EDataBarAxisPosition.automatic; this.Gradient = true; this.Direction = AscCommonExcel.EDataBarDirection.context; this.NegativeBarColorSameAsPositive = false; this.NegativeBarBorderColorSameAsPositive = true; this.aCFVOs = []; this.Color = null; this.NegativeColor = null; this.BorderColor = null; this.NegativeBorderColor = null; this.AxisColor = null; return this; } CDataBar.prototype.type = Asc.ECfType.dataBar; CDataBar.prototype.clone = function () { var i, res = new CDataBar(); res.MaxLength = this.MaxLength; res.MinLength = this.MinLength; res.ShowValue = this.ShowValue; res.AxisPosition = this.AxisPosition; res.Gradient = this.Gradient; res.Direction = this.Direction; res.NegativeBarColorSameAsPositive = this.NegativeBarColorSameAsPositive; res.NegativeBarBorderColorSameAsPositive = this.NegativeBarBorderColorSameAsPositive; for (i = 0; i < this.aCFVOs.length; ++i) { res.aCFVOs.push(this.aCFVOs[i].clone()); } if (this.Color) { res.Color = this.Color.clone(); } if (this.NegativeColor) { res.NegativeColor = this.NegativeColor.clone(); } if (this.BorderColor) { res.BorderColor = this.BorderColor.clone(); } if (this.NegativeBorderColor) { res.NegativeBorderColor = this.NegativeBorderColor.clone(); } if (this.AxisColor) { res.AxisColor = this.AxisColor.clone(); } return res; }; CDataBar.prototype.merge = function (obj) { //сравниваю по дефолтовым величинам if (this.MaxLength === 90) { this.MaxLength = obj.MaxLength; } if (this.MinLength === 10) { this.MinLength = obj.MinLength; } if (this.ShowValue === true) { this.ShowValue = obj.ShowValue; } if (this.AxisPosition === AscCommonExcel.EDataBarAxisPosition.automatic) { this.AxisPosition = obj.AxisPosition; } if (this.Gradient === true) { this.Gradient = obj.Gradient; } if (this.Direction === AscCommonExcel.EDataBarDirection.context) { this.Direction = obj.Direction; } if (this.NegativeBarColorSameAsPositive === false) { this.NegativeBarColorSameAsPositive = obj.NegativeBarColorSameAsPositive; } if (this.NegativeBarBorderColorSameAsPositive === true) { this.NegativeBarBorderColorSameAsPositive = obj.NegativeBarBorderColorSameAsPositive; } if (this.aCFVOs.length === 0) { this.aCFVOs = obj.aCFVOs; } else if (this.aCFVOs.length === obj.aCFVOs.length) { for (var i = 0; i < this.aCFVOs.length; i++) { this.aCFVOs[i].merge(obj.aCFVOs[i]); } } if (this.Color === null) { this.Color = obj.Color; } if (this.NegativeColor === null) { this.NegativeColor = obj.NegativeColor; } if (this.BorderColor === null) { this.BorderColor = obj.BorderColor; } if (this.NegativeBorderColor === null) { this.NegativeBorderColor = obj.NegativeBorderColor; } if (this.AxisColor === null) { this.AxisColor = obj.AxisColor; } }; CDataBar.prototype.isEqual = function (elem) { var _compareColors = function (_color1, _color2) { if (!_color1 && !_color2) { return true; } if (_color1 && _color2 && _color1.isEqual(_color2)) { return true; } return false; }; if (this.MaxLength === elem.MaxLength && this.MinLength === elem.MinLength && this.ShowValue === elem.ShowValue && this.AxisPosition === elem.AxisPosition && this.Gradient === elem.Gradient && this.Direction === elem.Direction && this.NegativeBarColorSameAsPositive === elem.NegativeBarColorSameAsPositive && this.NegativeBarBorderColorSameAsPositive === elem.NegativeBarBorderColorSameAsPositive) { if (elem.aCFVOs && elem.aCFVOs.length === this.aCFVOs.length) { var i; for (i = 0; i < elem.aCFVOs.length; i++) { if (!elem.aCFVOs[i].isEqual(this.aCFVOs[i])) { return false; } } if (_compareColors(this.Color, elem.Color) && _compareColors(this.NegativeColor, elem.NegativeColor) && _compareColors(this.BorderColor, elem.BorderColor) && _compareColors(this.NegativeBorderColor, elem.NegativeBorderColor) && _compareColors(this.AxisColor, elem.AxisColor)) { return true; } } } return false; }; CDataBar.prototype.applyPreset = function (styleIndex) { var _generateRgbColor = function (_color) { if (_color === undefined || _color === null) { return null; } return new AscCommonExcel.RgbColor(_color); }; var presetStyles = conditionalFormattingPresets[Asc.c_oAscCFRuleTypeSettings.dataBar][styleIndex]; this.AxisColor = _generateRgbColor(presetStyles[0]); this.AxisPosition = 0; this.BorderColor = _generateRgbColor(presetStyles[1]); this.Color = _generateRgbColor(presetStyles[2]); this.Direction = 0; this.Gradient = presetStyles[3]; this.MaxLength = 100; this.MinLength = 0; this.NegativeBarBorderColorSameAsPositive = false; this.NegativeBarColorSameAsPositive = false; this.NegativeBorderColor = _generateRgbColor(presetStyles[4]); this.NegativeColor = _generateRgbColor(presetStyles[5]); this.ShowValue = true; var formatValueObject1 = new CConditionalFormatValueObject(); formatValueObject1.Type = AscCommonExcel.ECfvoType.AutoMin; this.aCFVOs.push(formatValueObject1); var formatValueObject2 = new CConditionalFormatValueObject(); formatValueObject2.Type = AscCommonExcel.ECfvoType.AutoMax; this.aCFVOs.push(formatValueObject2); }; CDataBar.prototype.Write_ToBinary2 = function (writer) { if (null != this.MaxLength) { writer.WriteBool(true); writer.WriteLong(this.MaxLength); } else { writer.WriteBool(false); } if (null != this.MinLength) { writer.WriteBool(true); writer.WriteLong(this.MinLength); } else { writer.WriteBool(false); } if (null != this.ShowValue) { writer.WriteBool(true); writer.WriteBool(this.ShowValue); } else { writer.WriteBool(false); } if (null != this.AxisPosition) { writer.WriteBool(true); writer.WriteLong(this.AxisPosition); } else { writer.WriteBool(false); } if (null != this.Gradient) { writer.WriteBool(true); writer.WriteBool(this.Gradient); } else { writer.WriteBool(false); } if (null != this.Direction) { writer.WriteBool(true); writer.WriteLong(this.Direction); } else { writer.WriteBool(false); } if (null != this.NegativeBarColorSameAsPositive) { writer.WriteBool(true); writer.WriteBool(this.NegativeBarColorSameAsPositive); } else { writer.WriteBool(false); } if (null != this.NegativeBarBorderColorSameAsPositive) { writer.WriteBool(true); writer.WriteBool(this.NegativeBarBorderColorSameAsPositive); } else { writer.WriteBool(false); } //CConditionalFormatValueObject if (null != this.aCFVOs) { writer.WriteBool(true); writer.WriteLong(this.aCFVOs.length); for (var i = 0; i < this.aCFVOs.length; i++) { this.aCFVOs[i].Write_ToBinary2(writer); } } else { writer.WriteBool(false); } if (null != this.Color) { writer.WriteBool(true); writer.WriteLong(this.Color.getType()); this.Color.Write_ToBinary2(writer); } else { writer.WriteBool(false); } if (null != this.NegativeColor) { writer.WriteBool(true); writer.WriteLong(this.NegativeColor.getType()); this.NegativeColor.Write_ToBinary2(writer); } else { writer.WriteBool(false); } if (null != this.BorderColor) { writer.WriteBool(true); writer.WriteLong(this.BorderColor.getType()); this.BorderColor.Write_ToBinary2(writer); } else { writer.WriteBool(false); } if (null != this.NegativeBorderColor) { writer.WriteBool(true); writer.WriteLong(this.NegativeBorderColor.getType()); this.NegativeBorderColor.Write_ToBinary2(writer); } else { writer.WriteBool(false); } if (null != this.AxisColor) { writer.WriteBool(true); writer.WriteLong(this.AxisColor.getType()); this.AxisColor.Write_ToBinary2(writer); } else { writer.WriteBool(false); } }; CDataBar.prototype.Read_FromBinary2 = function (reader) { if (reader.GetBool()) { this.MaxLength = reader.GetLong(); } if (reader.GetBool()) { this.MinLength = reader.GetLong(); } if (reader.GetBool()) { this.ShowValue = reader.GetBool(); } if (reader.GetBool()) { this.AxisPosition = reader.GetLong(); } if (reader.GetBool()) { this.Gradient = reader.GetBool(); } if (reader.GetBool()) { this.Direction = reader.GetLong(); } if (reader.GetBool()) { this.NegativeBarColorSameAsPositive = reader.GetBool(); } if (reader.GetBool()) { this.NegativeBarBorderColorSameAsPositive = reader.GetBool(); } var i, length, type, elem; if (reader.GetBool()) { length = reader.GetULong(); for (i = 0; i < length; ++i) { if (!this.aCFVOs) { this.aCFVOs = []; } elem = new CConditionalFormatValueObject(); elem.Read_FromBinary2(reader); this.aCFVOs.push(elem); } } var readColor = function () { var type = reader.GetLong(); var _color; switch (type) { case AscCommonExcel.UndoRedoDataTypes.RgbColor: _color = new AscCommonExcel.RgbColor(); break; case AscCommonExcel.UndoRedoDataTypes.ThemeColor: _color = new AscCommonExcel.ThemeColor(); break; } if (null != _color.Read_FromBinary2) { _color.Read_FromBinary2(reader); } else if (null != _color.Read_FromBinary2AndReplace) { _color = _color.Read_FromBinary2AndReplace(reader); } return _color; }; if (reader.GetBool()) { this.Color = readColor(); } if (reader.GetBool()) { this.NegativeColor = readColor(); } if (reader.GetBool()) { this.BorderColor = readColor(); } if (reader.GetBool()) { this.NegativeBorderColor = readColor(); } if (reader.GetBool()) { this.AxisColor = readColor(); } }; CDataBar.prototype.asc_setInterfaceDefault = function () { //ms всегда создаёт правило с такими настройками, хотя в документации други дефолтовые значения //дёргаем этот метод при создании нового правила из интерфейса this.MinLength = 0; this.MaxLength = 100; }; CDataBar.prototype.asc_getPreview = function (api, id) { var color = this.Color; var aColors = []; var isReverse = this.Direction === AscCommonExcel.EDataBarDirection.rightToLeft; if (color) { if (this.Gradient) { var endColor = getDataBarGradientColor(color); if (isReverse) { aColors = [endColor, color]; } else { aColors = [color, endColor]; } } else { aColors = [color]; } } AscCommonExcel.drawGradientPreview(id, api.wb, aColors, new AscCommon.CColor(202, 202, 202)/*this.settings.cells.defaultState.border*/, this.BorderColor, isReverse ? -0.75 : 0.75, 2); }; CDataBar.prototype.asc_getShowValue = function () { return this.ShowValue; }; CDataBar.prototype.asc_getAxisPosition = function () { //TODO после открытия менять значения для условного формтирования без ext if (this.AxisPosition === AscCommonExcel.EDataBarAxisPosition.automatic && !this.AxisColor) { this.AxisPosition = AscCommonExcel.EDataBarAxisPosition.none; } return this.AxisPosition; }; CDataBar.prototype.asc_getGradient = function () { return this.Gradient; }; CDataBar.prototype.asc_getDirection = function () { return this.Direction; }; CDataBar.prototype.asc_getNegativeBarColorSameAsPositive = function () { //TODO после открытия менять значения для условного формтирования без ext //в старом формате эта опция не используется //буду ориентироваться что если не задан NegativeColor, то эта опция выставляется в true if (!this.NegativeColor) { this.NegativeBarColorSameAsPositive = true; } return this.NegativeBarColorSameAsPositive; }; CDataBar.prototype.asc_getNegativeBarBorderColorSameAsPositive = function () { return this.NegativeBarBorderColorSameAsPositive; }; CDataBar.prototype.asc_getCFVOs = function () { return this.aCFVOs; }; CDataBar.prototype.asc_getColor = function () { return this.Color ? Asc.colorObjToAscColor(this.Color) : null; }; CDataBar.prototype.asc_getNegativeColor = function () { return this.NegativeColor ? Asc.colorObjToAscColor(this.NegativeColor) : null; }; CDataBar.prototype.asc_getBorderColor = function () { return this.BorderColor ? Asc.colorObjToAscColor(this.BorderColor) : null; }; CDataBar.prototype.asc_getNegativeBorderColor = function () { return this.NegativeBorderColor ? Asc.colorObjToAscColor(this.NegativeBorderColor) : null; }; CDataBar.prototype.asc_getAxisColor = function () { return this.AxisColor ? Asc.colorObjToAscColor(this.AxisColor) : null; }; CDataBar.prototype.asc_setShowValue = function (val) { this.ShowValue = val; }; CDataBar.prototype.asc_setAxisPosition = function (val) { this.AxisPosition = val; }; CDataBar.prototype.asc_setGradient = function (val) { this.Gradient = val; }; CDataBar.prototype.asc_setDirection = function (val) { this.Direction = val; }; CDataBar.prototype.asc_setNegativeBarColorSameAsPositive = function (val) { this.NegativeBarColorSameAsPositive = val; }; CDataBar.prototype.asc_setNegativeBarBorderColorSameAsPositive = function (val) { this.NegativeBarBorderColorSameAsPositive = val; }; CDataBar.prototype.asc_setCFVOs = function (val) { this.aCFVOs = val; }; CDataBar.prototype.asc_setColor = function (val) { this.Color = AscCommonExcel.CorrectAscColor(val); }; CDataBar.prototype.asc_setNegativeColor = function (val) { this.NegativeColor = AscCommonExcel.CorrectAscColor(val); }; CDataBar.prototype.asc_setBorderColor = function (val) { this.BorderColor = AscCommonExcel.CorrectAscColor(val); if (val === null) { this.asc_setNegativeBorderColor(val); } }; CDataBar.prototype.asc_setNegativeBorderColor = function (val) { this.NegativeBorderColor = AscCommonExcel.CorrectAscColor(val); }; CDataBar.prototype.asc_setAxisColor = function (val) { this.AxisColor = AscCommonExcel.CorrectAscColor(val); }; CDataBar.prototype.getType = function () { return window['AscCommonExcel'].UndoRedoDataTypes.DataBar; }; function CFormulaCF() { this.Text = null; this._f = null; return this; } CFormulaCF.prototype.getType = function () { return AscCommonExcel.UndoRedoDataTypes.CFormulaCF; }; CFormulaCF.prototype.clone = function () { var res = new CFormulaCF(); res.Text = this.Text; return res; }; CFormulaCF.prototype.Write_ToBinary2 = function (writer) { if (null != this.Text) { writer.WriteBool(true); writer.WriteString2(this.Text); } else { writer.WriteBool(false); } }; CFormulaCF.prototype.Read_FromBinary2 = function (reader) { if (reader.GetBool()) { this.Text = reader.GetString2(); } }; CFormulaCF.prototype.isEqual = function (val) { return val.Text === this.Text; }; CFormulaCF.prototype.init = function (ws, opt_parent) { if (!this._f) { this._f = new AscCommonExcel.parserFormula(this.Text, opt_parent, ws); this._f.parse(); if (opt_parent) { //todo realize removeDependencies this._f.buildDependencies(); } } }; CFormulaCF.prototype.recalcFormula = function (ws, toInterface) { var f = new AscCommonExcel.parserFormula(this.Text, null, ws); if (f.parse(!toInterface)) { this.Text = toInterface ? f.assembleLocale(AscCommonExcel.cFormulaFunctionToLocale, true) : f.assemble(); } }; CFormulaCF.prototype.getFormula = function (ws, opt_parent) { this.init(ws, opt_parent); return this._f; }; CFormulaCF.prototype.getValue = function (ws, opt_parent, opt_bbox, opt_offset, opt_returnRaw) { this.init(ws, opt_parent); var res = this._f.calculate(null, opt_bbox, opt_offset); if (!opt_returnRaw) { res = this._f.simplifyRefType(res); } return res; }; CFormulaCF.prototype.asc_getText = function () { return this.Text; }; CFormulaCF.prototype.asc_setText = function (val) { this.Text = val; }; CFormulaCF.prototype.isExtended = function () { //if ((m_arrFormula[i].IsInit()) && m_arrFormula[i]->isExtended()) //TODO в x2t условие, которое в нашем случае не получится использовать, мы не храним этот флаг //m_arrFormula[i]->isExtended() -> return (m_sNodeName == L"xm:f"); return true; }; CFormulaCF.prototype.getFormulaStr = function (needBuild) { var res = null; if (this._f) { res = this._f.assembleLocale(AscCommonExcel.cFormulaFunctionToLocale, true); } else if (needBuild) { var oWB = Asc.editor && Asc.editor.wbModel; if (oWB) { var ws = oWB.getActiveWs(); if (ws) { var _f = new AscCommonExcel.parserFormula(this.Text, null, ws); _f.parse(true, true); res = _f.assembleLocale(AscCommonExcel.cFormulaFunctionToLocale, true); } } } return res ? res : this.Text; }; function CIconSet() { this.IconSet = EIconSetType.Traffic3Lights1; this.Percent = true; this.Reverse = false; this.ShowValue = true; this.aCFVOs = []; this.aIconSets = []; return this; } CIconSet.prototype.type = Asc.ECfType.iconSet; CIconSet.prototype.clone = function () { var i, res = new CIconSet(); res.IconSet = this.IconSet; res.Percent = this.Percent; res.Reverse = this.Reverse; res.ShowValue = this.ShowValue; if (this.aCFVOs) { for (i = 0; i < this.aCFVOs.length; ++i) { res.aCFVOs.push(this.aCFVOs[i].clone()); } } if (this.aIconSets) { for (i = 0; i < this.aIconSets.length; ++i) { res.aIconSets.push(this.aIconSets[i].clone()); } } return res; }; CIconSet.prototype.merge = function (obj) { //сравниваю по дефолтовым величинам if (this.IconSet === EIconSetType.Traffic3Lights1) { this.IconSet = obj.IconSet; } if (this.Percent === true) { this.Percent = obj.Percent; } if (this.Reverse === false) { this.Reverse = obj.Reverse; } if (this.ShowValue === true) { this.ShowValue = obj.ShowValue; } if (this.aCFVOs && this.aCFVOs.length === 0) { this.aCFVOs = obj.aCFVOs; } else if (this.aCFVOs && obj.aCFVOs && this.aCFVOs.length === obj.aCFVOs.length) { for (var i = 0; i < this.aCFVOs.length; i++) { this.aCFVOs[i].merge(obj.aCFVOs[i]); } } if (this.aIconSets.length === 0) { this.aIconSets = obj.aIconSets; } else if (this.aIconSets.length === obj.aIconSets.length) { for (var i = 0; i < this.aIconSets.length; i++) { this.aIconSets[i].merge(obj.aIconSets[i]); } } }; CIconSet.prototype.isEqual = function (elem) { if (this.IconSet === elem.IconSet && this.Percent === elem.Percent && this.Reverse === elem.Reverse && this.ShowValue === elem.ShowValue) { if ((elem.aCFVOs && elem.aCFVOs.length === this.aCFVOs.length) || (!elem.aCFVOs && !this.aCFVOs)) { var i; if (elem.aCFVOs) { for (i = 0; i < elem.aCFVOs.length; i++) { if (!elem.aCFVOs[i].isEqual(this.aCFVOs[i])) { return false; } } } if (elem.aIconSets && elem.aIconSets.length === this.aIconSets.length) { for (i = 0; i < elem.aIconSets.length; i++) { if (!elem.aIconSets[i].isEqual(this.aIconSets[i])) { return false; } } return true; } else if (!elem.aIconSets && !this.aIconSets) { return true; } } } return false; }; CIconSet.prototype.applyPreset = function (styleIndex) { var presetStyles = conditionalFormattingPresets[Asc.c_oAscCFRuleTypeSettings.icons][styleIndex]; this.IconSet = styleIndex; for (var i = 0; i < presetStyles.length; i++) { var formatValueObject = new CConditionalFormatValueObject(); formatValueObject.Type = presetStyles[i][0]; formatValueObject.Val = presetStyles[i][1]; if (presetStyles[i][2]) { formatValueObject.formula = new CFormulaCF(); formatValueObject.formula.Text = presetStyles[i][2]; } this.aCFVOs.push(formatValueObject); } }; CIconSet.prototype.Write_ToBinary2 = function (writer) { if (null != this.IconSet) { writer.WriteBool(true); writer.WriteLong(this.IconSet); } else { writer.WriteBool(false); } if (null != this.Percent) { writer.WriteBool(true); writer.WriteBool(this.Percent); } else { writer.WriteBool(false); } if (null != this.Reverse) { writer.WriteBool(true); writer.WriteBool(this.Reverse); } else { writer.WriteBool(false); } if (null != this.ShowValue) { writer.WriteBool(true); writer.WriteBool(this.ShowValue); } else { writer.WriteBool(false); } //CConditionalFormatValueObject var i; if (null != this.aCFVOs) { writer.WriteBool(true); writer.WriteLong(this.aCFVOs.length); for (i = 0; i < this.aCFVOs.length; i++) { this.aCFVOs[i].Write_ToBinary2(writer); } } else { writer.WriteBool(false); } //new AscCommonExcel.CConditionalFormatIconSet() if (null != this.aIconSets) { writer.WriteBool(true); writer.WriteLong(this.aIconSets.length); for (i = 0; i < this.aIconSets.length; i++) { this.aIconSets[i].Write_ToBinary2(writer); } } else { writer.WriteBool(false); } }; CIconSet.prototype.Read_FromBinary2 = function (reader) { if (reader.GetBool()) { this.IconSet = reader.GetLong(); } if (reader.GetBool()) { this.Percent = reader.GetBool(); } if (reader.GetBool()) { this.Reverse = reader.GetBool(); } if (reader.GetBool()) { this.ShowValue = reader.GetBool(); } var i, length, elem; if (reader.GetBool()) { length = reader.GetULong(); for (i = 0; i < length; ++i) { if (!this.aCFVOs) { this.aCFVOs = []; } elem = new CConditionalFormatValueObject(); elem.Read_FromBinary2(reader); this.aCFVOs.push(elem); } } if (reader.GetBool()) { length = reader.GetULong(); for (i = 0; i < length; ++i) { if (!this.aIconSets) { this.aIconSets = []; } elem = new CConditionalFormatIconSet(); elem.Read_FromBinary2(reader); this.aIconSets.push(elem); } } }; CIconSet.prototype.asc_getPreview = function (api, id) { var i, aIconImgs = []; if (!this.Reverse) { for (i = this.aCFVOs.length - 1; i >= 0; i--) { aIconImgs.push(getCFIcon(this, i)); } } else { for (i = 0; i < this.aCFVOs.length; i++) { aIconImgs.push(getCFIcon(this, i)); } } AscCommonExcel.drawIconSetPreview(id, api.wb, aIconImgs); }; CIconSet.prototype.asc_getIconSet = function () { return this.IconSet; }; CIconSet.prototype.asc_getReverse = function () { return this.Reverse; }; CIconSet.prototype.asc_getShowValue = function () { return this.ShowValue; }; CIconSet.prototype.asc_getCFVOs = function () { return this.aCFVOs; }; CIconSet.prototype.asc_getIconSets = function () { return this.aIconSets; }; CIconSet.prototype.asc_setIconSet = function (val) { this.IconSet = val; }; CIconSet.prototype.asc_setReverse = function (val) { this.Reverse = val; }; CIconSet.prototype.asc_setShowValue = function (val) { this.ShowValue = val; }; CIconSet.prototype.asc_setCFVOs = function (val) { this.aCFVOs = val; }; CIconSet.prototype.asc_setIconSets = function (val) { this.aIconSets = val == null ? [] : val; }; CIconSet.prototype.getType = function () { return window['AscCommonExcel'].UndoRedoDataTypes.IconSet; }; function CConditionalFormatValueObject() { this.Gte = true; this.Type = null; this.Val = null; this.formulaParent = null; this.formula = null; return this; } CConditionalFormatValueObject.prototype.clone = function () { var res = new CConditionalFormatValueObject(); res.Gte = this.Gte; res.Type = this.Type; res.Val = this.Val; res.formulaParent = this.formulaParent ? this.formulaParent.clone() : null; res.formula = this.formula ? this.formula.clone() : null; return res; }; CConditionalFormatValueObject.prototype.merge = function (obj) { //сравниваю по дефолтовым величинам if (this.Gte === true) { this.Gte = obj.Gte; } if (obj.Type !== null) { this.Type = obj.Type; } if (this.Val === null) { this.Val = obj.Val; } if (this.formulaParent === null) { this.formulaParent = obj.formulaParent; } if (this.formula === null) { this.formula = obj.formula; } }; CConditionalFormatValueObject.prototype.Write_ToBinary2 = function (writer) { if (null != this.Gte) { writer.WriteBool(true); writer.WriteBool(this.Gte); } else { writer.WriteBool(false); } if (null != this.Type) { writer.WriteBool(true); writer.WriteLong(this.Type); } else { writer.WriteBool(false); } if (null != this.Val) { writer.WriteBool(true); writer.WriteString2(this.Val); } else { writer.WriteBool(false); } }; CConditionalFormatValueObject.prototype.Read_FromBinary2 = function (reader) { if (reader.GetBool()) { this.Gte = reader.GetBool(); } if (reader.GetBool()) { this.Type = reader.GetLong(); } if (reader.GetBool()) { this.Val = reader.GetString2(); } }; CConditionalFormatValueObject.prototype.asc_getGte = function () { return this.Gte; }; CConditionalFormatValueObject.prototype.asc_getType = function () { return this.Type; }; CConditionalFormatValueObject.prototype.asc_getVal = function () { return !isNumeric(this.Val) ? "=" + this.Val : this.Val; }; CConditionalFormatValueObject.prototype.asc_setGte = function (val) { this.Gte = val; }; CConditionalFormatValueObject.prototype.asc_setType = function (val) { this.Type = val; }; CConditionalFormatValueObject.prototype.asc_setVal = function (val) { val = correctFromInterface(val); this.Val = (val !== undefined && val !== null) ? val + "" : val; }; CConditionalFormatValueObject.prototype.isEqual = function (elem) { if (this.Gte === elem.Gte && this.Type === elem.Type && this.Val === elem.Val && this.Type === elem.Type) { return true; } return false; }; function CConditionalFormatIconSet() { this.IconSet = null; this.IconId = null; return this; } CConditionalFormatIconSet.prototype.clone = function () { var res = new CConditionalFormatIconSet(); res.IconSet = this.IconSet; res.IconId = this.IconId; return res; }; CConditionalFormatIconSet.prototype.merge = function (obj) { //сравниваю по дефолтовым величинам if (this.IconSet === null) { this.IconSet = obj.IconSet; } if (this.IconId === null) { this.IconId = obj.IconId; } }; CConditionalFormatIconSet.prototype.isEqual = function (val) { return this.IconSet === val.IconSet && this.IconId === val.IconId; }; CConditionalFormatIconSet.prototype.Write_ToBinary2 = function (writer) { if (null != this.IconSet) { writer.WriteBool(true); writer.WriteLong(this.IconSet); } else { writer.WriteBool(false); } if (null != this.IconId) { writer.WriteBool(true); writer.WriteLong(this.IconId); } else { writer.WriteBool(false); } }; CConditionalFormatIconSet.prototype.Read_FromBinary2 = function (reader) { if (reader.GetBool()) { this.IconSet = reader.GetLong(); } if (reader.GetBool()) { this.IconId = reader.GetLong(); } }; CConditionalFormatIconSet.prototype.asc_getIconSet = function () { return this.IconSet; }; CConditionalFormatIconSet.prototype.asc_getIconId = function () { return this.IconId; }; CConditionalFormatIconSet.prototype.asc_getIndex = function () { return this.IconId; }; CConditionalFormatIconSet.prototype.asc_setIconSet = function (val) { this.IconSet = val; }; CConditionalFormatIconSet.prototype.asc_setIconId = function (val) { this.IconId = val; }; CConditionalFormatIconSet.prototype.asc_setIndex = function (val) { this.IconId = val; }; function CGradient(c1, c2) { this.MaxColorIndex = 512; this.base_shift = 8; this.c1 = c1; this.c2 = c2; this.min = this.max = 0; this.koef = null; this.r1 = this.r2 = 0; this.g1 = this.g2 = 0; this.b1 = this.b2 = 0; return this; } CGradient.prototype.init = function (min, max) { var distance = max - min; this.min = min; this.max = max; this.koef = distance ? this.MaxColorIndex / (2.0 * distance) : 0; this.r1 = this.c1.getR(); this.g1 = this.c1.getG(); this.b1 = this.c1.getB(); this.r2 = this.c2.getR(); this.g2 = this.c2.getG(); this.b2 = this.c2.getB(); }; CGradient.prototype.calculateColor = function (indexColor) { indexColor = ((indexColor - this.min) * this.koef) >> 0; var r = (this.r1 + ((FT_Common.IntToUInt(this.r2 - this.r1) * indexColor) >> this.base_shift)) & 0xFF; var g = (this.g1 + ((FT_Common.IntToUInt(this.g2 - this.g1) * indexColor) >> this.base_shift)) & 0xFF; var b = (this.b1 + ((FT_Common.IntToUInt(this.b2 - this.b1) * indexColor) >> this.base_shift)) & 0xFF; //console.log("index=" + indexColor + ": r=" + r + " g=" + g + " b=" + b); return new AscCommonExcel.RgbColor((r << 16) + (g << 8) + b); }; CGradient.prototype.getMinColor = function () { return new AscCommonExcel.RgbColor((this.r1 << 16) + (this.g1 << 8) + this.b1); }; CGradient.prototype.getMaxColor = function () { return new AscCommonExcel.RgbColor((this.r2 << 16) + (this.g2 << 8) + this.b2); }; function isValidDataRefCf(type, props) { var i; var ws; var checkFormulaStack = function (_f) { if (!_f) { return null; } var stack = _f.outStack; if (stack && stack.length) { //если идут фрифметические операции, использования диапазонов внутри формул - ошибки на это нет //поэтому я проверяю на одиночный диапазон if (stack.length === 1 && (stack[0].type === AscCommonExcel.cElementType.cellsRange || stack[0].type === AscCommonExcel.cElementType.cellsRange3D)) { return asc_error.NotSingleReferenceCannotUsed; } if (type === Asc.ECfType.colorScale || type === Asc.ECfType.dataBar || type === Asc.ECfType.iconSet) { for (var i = 0; i < stack.length; i++) { if (stack[i]) { //допускаются только абсолютные ссылки if (stack[i].type === AscCommonExcel.cElementType.cellsRange || stack[i].type === AscCommonExcel.cElementType.cellsRange3D || stack[i].type === AscCommonExcel.cElementType.cell || stack[i].type === AscCommonExcel.cElementType.cell3D) { //ссылки должны быть только абсолютные var _range = stack[i].getRange(); if (_range.bbox) { _range = _range.bbox; } var isAbsRow1 = _range.isAbsRow(_range.refType1); var isAbsCol1 = _range.isAbsCol(_range.refType1); var isAbsRow2 = _range.isAbsRow(_range.refType2); var isAbsCol2 = _range.isAbsCol(_range.refType2); if (!isAbsRow1 || !isAbsCol1 || !isAbsRow2 || !isAbsCol2) { return asc_error.CannotUseRelativeReference; } } } } } } return null; }; var _parseResultArg; var _doParseFormula = function (sFormula) { _parseResultArg = null; if (!(typeof sFormula === "string" && sFormula.length > 0)) { return; } if (!ws) { var oWB = Asc.editor && Asc.editor.wbModel; if (!oWB) { return; } ws = oWB.getWorksheet(0); } if (sFormula.charAt(0) === '=') { sFormula = sFormula.slice(1); } var _formulaParsed = new AscCommonExcel.parserFormula(sFormula, null, ws); _parseResultArg = new AscCommonExcel.ParseResult([], []); _formulaParsed.parse(true, true, _parseResultArg, true); return _formulaParsed; }; var _checkValue = function (_val, _type, _isNumeric) { var fParser, _error; switch (_type) { case AscCommonExcel.ECfvoType.Formula: if (_isNumeric) { } else if (_val && _val[0] !== "=") { _val = '"' + _val + '"'; } else { fParser = _doParseFormula(_val); if (_parseResultArg && _parseResultArg.error) { return _parseResultArg.error; } //если внутри диапазон - проверяем его _error = fParser && checkFormulaStack(fParser); if (_error !== null) { return _error; } } break; case AscCommonExcel.ECfvoType.Number: if (_isNumeric) { } else if (_val && _val[0] !== "=") { _val = '"' + _val + '"'; } else { fParser = _doParseFormula(_val); if (_parseResultArg && _parseResultArg.error) { return _parseResultArg.error; } //если внутри диапазон - проверяем его _error = fParser && checkFormulaStack(fParser); if (_error !== null) { return _error; } } break; case AscCommonExcel.ECfvoType.Percent: if (_isNumeric) { if (_val < 0 && _val > 100) { //is not valid precentile return asc_error.NotValidPercentage; } } else if (_val && _val[0] !== "=") { _val = '"' + _val + '"'; } else { fParser = _doParseFormula(_val); if (_parseResultArg && _parseResultArg.error) { return _parseResultArg.error; } //если внутри диапазон - проверяем его _error = fParser && checkFormulaStack(fParser); if (_error !== null) { return _error; } } break; case AscCommonExcel.ECfvoType.Percentile: //в случае с индивидуальное проверкой Percentile - выдаём только 2 ошибки if (_isNumeric) { if (_val < 0 && _val > 100) { //is not valid precentile return asc_error.NotValidPercentile; } } else { return asc_error.CannotAddConditionalFormatting; } break; } return null; }; var compareRefs = function (_prevVal, _prevType, _prevNum, _val, _type, _isNum) { //далее сравниваем ближайшие значения с одним типом, предыдущее должно быть меньше следующего //в databar ошибка для подобного сравнения не возникает //для iconSet сравниваем числа для типов Number/Percent/Percentile - должны идти по убыванию, сраниваем только соседние if (_prevNum && _isNum) { if (_isNum && _prevNum) { _val = parseFloat(_val); _prevVal = parseFloat(_prevVal); } if (type === Asc.ECfType.colorScale) { if (_prevType === _type && type !== AscCommonExcel.ECfvoType.Formula && _prevVal > _val) { return asc_error.ValueMustBeGreaterThen; } } else if (type === Asc.ECfType.iconSet) { if (_prevType !== AscCommonExcel.ECfvoType.Formula && type !== AscCommonExcel.ECfvoType.Formula && _val < _prevVal) { return asc_error.IconDataRangesOverlap; } } } return null; }; //value, type var prevType, prevVal, prevNum; var nError; var _isNumeric; for (i = 0; i < props.length; i++) { if (undefined !== props[i][1] && type !== Asc.ECfType.top10) { _isNumeric = isNumeric(props[i][0]); nError = _checkValue(props[i][0], props[i][1], _isNumeric); if (nError !== null) { return [nError, i]; } if (prevType === undefined) { prevType = props[i][1]; prevVal = props[i][0]; prevNum = _isNumeric; } else { if (!(i === 1 && type === Asc.ECfType.iconSet)) { nError = compareRefs(prevVal, prevType, prevNum, props[i][0], props[i][1], _isNumeric); } if (nError !== null) { return [nError, i]; } prevType = props[i][1]; prevVal = props[i][0]; prevNum = _isNumeric; } } else { //в этом случае должны быть следующие типы if (type === Asc.ECfType.expression) { nError = _checkValue(props[i][0], AscCommonExcel.ECfvoType.Formula); if (nError !== null) { return [nError, i]; } } else if (type === Asc.ECfType.cellIs) { nError = _checkValue(props[i][0], AscCommonExcel.ECfvoType.Formula); if (nError !== null) { return [nError, i]; } } else if (type === Asc.ECfType.containsText) { nError = _checkValue(props[i][0], AscCommonExcel.ECfvoType.Formula); if (nError !== null) { return [nError, i]; } } else if (type === Asc.ECfType.top10) { _isNumeric = isNumeric(props[i][0]); var isPrecent = props[i][1]; if (!_isNumeric) { return [asc_error.ErrorTop10Between, i]; } else if (!isPrecent && (props[i][0] < 0 || props[i][0] > 1000)) { return [asc_error.ErrorTop10Between, i]; } else if (isPrecent && (props[i][0] < 0 || props[i][0] > 100)) { return [asc_error.ErrorTop10Between, i]; } } } } } function correctFromInterface(val) { let _isNumeric = isNumeric(val); if (!_isNumeric) { let isDate; let isFormula; if (val[0] === "=") { val = val.slice(1); isFormula = true; } else { isDate = AscCommon.g_oFormatParser.parseDate(val, AscCommon.g_oDefaultCultureInfo); } //храним число if (isDate) { val = isDate.value; return val; } if (!isFormula) { val = addQuotes(val); } else { let oWB = Asc.editor && Asc.editor.wbModel; if (oWB) { let ws = oWB.getActiveWs(); if (ws) { let _f = new AscCommonExcel.parserFormula(val, null, ws); _f.parse(true, true); val = _f.assembleLocale(AscCommonExcel.cFormulaFunctionToLocale, true); } } } } return val; } function addQuotes(val) { var _res; if (val[0] === '"') { _res = val.replace(/\"/g, "\"\""); _res = "\"" + _res + "\""; } else { _res = "\"" + val + "\""; } return _res; } var isNumeric = function (_val) { return !isNaN(parseFloat(_val)) && isFinite(_val); }; var cDefIconSize = 16; var cDefIconFont = 11; var fullIconArray = ["", "", "", '', "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", ""]; var iDown = 1, iSide = 2, iUp = 3; var iDownGray = 4, iSideGray = 5, iUpGray = 6; var iFlagRed = 7, iFlagYellow = 8, iFlagGreen = 9; var iDiamondRed = 10, iTriangleYellow = 11, iCircleGreen = 12; var iCrossRed = 13, iExclamationYellow = 14, iCheckGreen = 15; var iCrossSymbolRed = 16, iExclamationSymbolYellow = 17, iCheckSymbolGreen = 18; var iCircleRed = 19, iCircleYellow = 20; var iTrafficLightRed = 21, iTrafficLightYellow = 22, iTrafficLightGreen = 23; var iDownIncline = 24, iUpIncline = 25; var iDownInclineGray = 26, iUpInclineGray = 27; var iOneFilledBars = 28, iTwoFilledBars = 29, iThreeFilledBars = 30, iFourFilledBars = 31; var iCircleBlack = 32, iCircleGray = 33, iCircleLightRed = 34; var iCircleWhite = 35, iCircleThreeWhiteQuarters = 36, iCircleTwoWhiteQuarters = 37, iCircleOneWhiteQuarter = 38; var iZeroFilledBars = 39; var iTriangleRed = 40, iDashYellow = 41, iTriangleGreen = 42; var iStarSilver = 43, iStarHalf = 44, iStarGold = 45; var iZeroFilledBoxes = 46, iOneFilledBoxes = 47, iTwoFilledBoxes = 48, iThreeFilledBoxes = 49, iFourFilledBoxes = 50; var c_arrIcons = [20]; c_arrIcons[EIconSetType.Arrows3] = [iDown, iSide, iUp]; c_arrIcons[EIconSetType.Arrows3Gray] = [iDownGray, iSideGray, iUpGray]; c_arrIcons[EIconSetType.Flags3] = [iFlagRed, iFlagYellow, iFlagGreen]; c_arrIcons[EIconSetType.Signs3] = [iDiamondRed, iTriangleYellow, iCircleGreen]; c_arrIcons[EIconSetType.Symbols3] = [iCrossRed, iExclamationYellow, iCheckGreen]; c_arrIcons[EIconSetType.Symbols3_2] = [iCrossSymbolRed, iExclamationSymbolYellow, iCheckSymbolGreen]; c_arrIcons[EIconSetType.Traffic3Lights1] = [iCircleRed, iCircleYellow, iCircleGreen]; c_arrIcons[EIconSetType.Traffic3Lights2] = [iTrafficLightRed, iTrafficLightYellow, iTrafficLightGreen]; c_arrIcons[EIconSetType.Arrows4] = [iDown, iDownIncline, iUpIncline, iUp]; c_arrIcons[EIconSetType.Arrows4Gray] = [iDownGray, iDownInclineGray, iUpInclineGray, iUpGray]; c_arrIcons[EIconSetType.Rating4] = [iOneFilledBars, iTwoFilledBars, iThreeFilledBars, iFourFilledBars]; c_arrIcons[EIconSetType.RedToBlack4] = [iCircleBlack, iCircleGray, iCircleLightRed, iCircleRed]; c_arrIcons[EIconSetType.Traffic4Lights] = [iCircleBlack, iCircleRed, iCircleYellow, iCircleGreen]; c_arrIcons[EIconSetType.Arrows5] = [iDown, iDownIncline, iSide, iUpIncline, iUp]; c_arrIcons[EIconSetType.Arrows5Gray] = [iDownGray, iDownInclineGray, iSideGray, iUpInclineGray, iUpGray]; c_arrIcons[EIconSetType.Quarters5] = [iCircleWhite, iCircleThreeWhiteQuarters, iCircleTwoWhiteQuarters, iCircleOneWhiteQuarter, iCircleBlack]; c_arrIcons[EIconSetType.Rating5] = [iZeroFilledBars, iOneFilledBars, iTwoFilledBars, iThreeFilledBars, iFourFilledBars]; c_arrIcons[EIconSetType.Triangles3] = [iTriangleRed, iDashYellow, iTriangleGreen]; c_arrIcons[EIconSetType.Stars3] = [iStarSilver, iStarHalf, iStarGold]; c_arrIcons[EIconSetType.Boxes5] = [iZeroFilledBoxes, iOneFilledBoxes, iTwoFilledBoxes, iThreeFilledBoxes, iFourFilledBoxes]; function getCFIconsForLoad() { return fullIconArray; } function getCFIcon(oRuleElement, index) { var oIconSet = oRuleElement.aIconSets && oRuleElement.aIconSets[index]; var iconSetType = (oIconSet && null !== oIconSet.IconSet) ? oIconSet.IconSet : oRuleElement.IconSet; if (EIconSetType.NoIcons === iconSetType) { return null; } var icons = c_arrIcons[iconSetType] || c_arrIcons[EIconSetType.Traffic3Lights1]; return fullIconArray[(icons[(oIconSet && null !== oIconSet.IconId) ? oIconSet.IconId : index] || icons[icons.length - 1]) - 1]; } function getDataBarGradientColor(color) { if (!color) { return null; } var RGB = {R: 0xFF, G: 0xFF, B: 0xFF}; var bCoeff = 0.828; RGB.R = Math.min(255, (color.getR() + bCoeff * (0xFF - color.getR()) + 0.5) >> 0); RGB.G = Math.min(255, (color.getG() + bCoeff * (0xFF - color.getG()) + 0.5) >> 0); RGB.B = Math.min(255, (color.getB() + bCoeff * (0xFF - color.getB()) + 0.5) >> 0); return AscCommonExcel.createRgbColor(RGB.R, RGB.G, RGB.B); } function getFullCFIcons() { return fullIconArray; } function getCFIconsByType() { return c_arrIcons; } function getFullCFPresets() { return conditionalFormattingPresets; } //[AxisColor, BorderColor, Color, Gradient, NegativeBorderColor, NegativeColor] var aDataBarStyles = [[0, 6524614, 6524614, true, 16711680, 16711680], [0, 6538116, 6538116, true, 16711680, 16711680], [0, 16733530, 16733530, true, 16711680, 16711680], [0, 16758312, 16758312, true, 16711680, 16711680], [0, 35567, 35567, true, 16711680, 16711680], [0, 14024827, 14024827, true, 16711680, 16711680], [0, , 6524614, false, , 16711680], [0, , 6538116, false, , 16711680], [0, , 16733530, false, , 16711680], [0, , 16758312, false, , 16711680], [0, , 35567, false, , 16711680], [0, , 14024827, false, , 16711680]]; //[[Type, Val, Rgb], [Type, Val, Rgb], ...] var aColorScaleStyles = [[[2, null, 16279915], [5, 50, 16771972], [1, null, 6536827]], [[2, null, 6536827], [5, 50, 16771972], [1, null, 16279915]], [[2, null, 16279915], [5, 50, 16579839], [1, null, 6536827]], [[2, null, 6536827], [5, 50, 16579839], [1, null, 16279915]], [[2, null, 16279915], [5, 50, 16579839], [1, null, 5933766]], [[2, null, 5933766], [5, 50, 16579839], [1, null, 16279915]], [[2, null, 16279915], [1, null, 16579839]], [[2, null, 16579839], [1, null, 16279915]], [[2, null, 16579839], [1, null, 6536827]], [[2, null, 6536827], [1, null, 16579839]], [[2, null, 16773020], [1, null, 6536827]], [[2, null, 6536827], [1, null, 16773020]]]; //[[[Type, Val, Formula], [Type, Val, Formula], ...], [[Type, Val, Formula], [Type, Val, Formula], ...]] var aIconsStyles = [[[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '25', null], [4, '50', null], [4, '75', '75']], [[4, '0', null], [4, '25', null], [4, '50', null], [4, '75', '75']], [[4, '0', null], [4, '25', null], [4, '50', null], [4, '75', '75']], [[4, '0', null], [4, '25', null], [4, '50', null], [4, '75', '75']], [[4, '0', null], [4, '25', null], [4, '50', null], [4, '75', '75']], [[4, '0', null], [4, '20', null], [4, '40', null], [4, '60', null], [4, '80', '80']], [[4, '0', null], [4, '20', null], [4, '40', null], [4, '60', null], [4, '80', '80']], [[4, '0', null], [4, '20', null], [4, '40', null], [4, '60', null], [4, '80', '80']], [[4, '0', null], [4, '20', null], [4, '40', null], [4, '60', null], [4, '80', '80']], [[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '33', null], [4, '67', '67']], [[4, '0', null], [4, '20', null], [4, '40', null], [4, '60', null], [4, '80', '80']]]; //[[fontColor, fillColor, borderColor]] var aFormatStyles = [["9C0006", "FFC7CE"], ["9C5700", "FFEB9C"], ["006100", "C6EFCE"], [, "FFC7CE"], ["9C0006"], [, , "9C0006"]]; var conditionalFormattingPresets = {}; conditionalFormattingPresets[Asc.c_oAscCFRuleTypeSettings.dataBar] = aDataBarStyles; conditionalFormattingPresets[Asc.c_oAscCFRuleTypeSettings.colorScale] = aColorScaleStyles; conditionalFormattingPresets[Asc.c_oAscCFRuleTypeSettings.icons] = aIconsStyles; conditionalFormattingPresets[Asc.c_oAscCFRuleTypeSettings.format] = aFormatStyles; /* * Export * ----------------------------------------------------------------------------- */ var prot; window['AscCommonExcel'] = window['AscCommonExcel'] || {}; window['AscCommonExcel'].CConditionalFormatting = CConditionalFormatting; window['AscCommonExcel'].CConditionalFormattingFormulaParent = CConditionalFormattingFormulaParent; window['Asc']["asc_CConditionalFormattingRule"] = window['AscCommonExcel'].CConditionalFormattingRule = CConditionalFormattingRule; window['Asc']["asc_CColorScale"] = window['AscCommonExcel'].CColorScale = CColorScale; window['Asc']["asc_CDataBar"] = window['AscCommonExcel'].CDataBar = CDataBar; window['AscCommonExcel'].CFormulaCF = CFormulaCF; window['Asc']["asc_CIconSet"] = window['AscCommonExcel'].CIconSet = CIconSet; window['Asc']["asc_CConditionalFormatValueObject"] = window['AscCommonExcel'].CConditionalFormatValueObject = CConditionalFormatValueObject; window['Asc']["asc_CConditionalFormatIconSet"] = window['AscCommonExcel'].CConditionalFormatIconSet = CConditionalFormatIconSet; window['AscCommonExcel'].CGradient = CGradient; window['AscCommonExcel'].cDefIconSize = cDefIconSize; window['AscCommonExcel'].cDefIconFont = cDefIconFont; window['AscCommonExcel'].getCFIconsForLoad = getCFIconsForLoad; window['AscCommonExcel'].getCFIcon = getCFIcon; window['AscCommonExcel'].getDataBarGradientColor = getDataBarGradientColor; window['AscCommonExcel'].getFullCFIcons = getFullCFIcons; window['AscCommonExcel'].getFullCFPresets = getFullCFPresets; window['AscCommonExcel'].getCFIconsByType = getCFIconsByType; window['AscCommonExcel'].isValidDataRefCf = isValidDataRefCf; prot = CConditionalFormattingRule.prototype; prot['asc_getDxf'] = prot.asc_getDxf; prot['asc_getType'] = prot.asc_getType; prot['asc_getLocation'] = prot.asc_getLocation; prot['asc_getContainsText'] = prot.asc_getContainsText; prot['asc_getTimePeriod'] = prot.asc_getTimePeriod; prot['asc_getOperator'] = prot.asc_getOperator; prot['asc_getPriority'] = prot.asc_getPriority; prot['asc_getRank'] = prot.asc_getRank; prot['asc_getBottom'] = prot.asc_getBottom; prot['asc_getPercent'] = prot.asc_getPercent; prot['asc_getAboveAverage'] = prot.asc_getAboveAverage; prot['asc_getEqualAverage'] = prot.asc_getEqualAverage; prot['asc_getStdDev'] = prot.asc_getStdDev; prot['asc_getValue1'] = prot.asc_getValue1; prot['asc_getValue2'] = prot.asc_getValue2; prot['asc_getColorScaleOrDataBarOrIconSetRule'] = prot.asc_getColorScaleOrDataBarOrIconSetRule; prot['asc_getId'] = prot.asc_getId; prot['asc_getIsLock'] = prot.asc_getIsLock; prot['asc_getPreview'] = prot.asc_getPreview; prot['asc_setDxf'] = prot.asc_setDxf; prot['asc_setType'] = prot.asc_setType; prot['asc_setLocation'] = prot.asc_setLocation; prot['asc_setContainsText'] = prot.asc_setContainsText; prot['asc_setTimePeriod'] = prot.asc_setTimePeriod; prot['asc_setOperator'] = prot.asc_setOperator; prot['asc_setPriority'] = prot.asc_setPriority; prot['asc_setRank'] = prot.asc_setRank; prot['asc_setBottom'] = prot.asc_setBottom; prot['asc_setPercent'] = prot.asc_setPercent; prot['asc_setAboveAverage'] = prot.asc_setAboveAverage; prot['asc_setEqualAverage'] = prot.asc_setEqualAverage; prot['asc_setStdDev'] = prot.asc_setStdDev; prot['asc_setValue1'] = prot.asc_setValue1; prot['asc_setValue2'] = prot.asc_setValue2; prot['asc_checkScope'] = prot.asc_checkScope; prot['asc_setColorScaleOrDataBarOrIconSetRule'] = prot.asc_setColorScaleOrDataBarOrIconSetRule; prot = CColorScale.prototype; prot['asc_getCFVOs'] = prot.asc_getCFVOs; prot['asc_getColors'] = prot.asc_getColors; prot['asc_getPreview'] = prot.asc_getPreview; prot['asc_setCFVOs'] = prot.asc_setCFVOs; prot['asc_setColors'] = prot.asc_setColors; prot = CDataBar.prototype; prot['asc_setInterfaceDefault'] = prot.asc_setInterfaceDefault; prot['asc_getShowValue'] = prot.asc_getShowValue; prot['asc_getAxisPosition'] = prot.asc_getAxisPosition; prot['asc_getGradient'] = prot.asc_getGradient; prot['asc_getDirection'] = prot.asc_getDirection; prot['asc_getNegativeBarColorSameAsPositive'] = prot.asc_getNegativeBarColorSameAsPositive; prot['asc_getNegativeBarBorderColorSameAsPositive'] = prot.asc_getNegativeBarBorderColorSameAsPositive; prot['asc_getCFVOs'] = prot.asc_getCFVOs; prot['asc_getColor'] = prot.asc_getColor; prot['asc_getNegativeColor'] = prot.asc_getNegativeColor; prot['asc_getBorderColor'] = prot.asc_getBorderColor; prot['asc_getNegativeBorderColor'] = prot.asc_getNegativeBorderColor; prot['asc_getAxisColor'] = prot.asc_getAxisColor; prot['asc_setShowValue'] = prot.asc_setShowValue; prot['asc_setAxisPosition'] = prot.asc_setAxisPosition; prot['asc_setGradient'] = prot.asc_setGradient; prot['asc_setDirection'] = prot.asc_setDirection; prot['asc_setNegativeBarColorSameAsPositive'] = prot.asc_setNegativeBarColorSameAsPositive; prot['asc_setNegativeBarBorderColorSameAsPositive'] = prot.asc_setNegativeBarBorderColorSameAsPositive; prot['asc_setCFVOs'] = prot.asc_setCFVOs; prot['asc_setColor'] = prot.asc_setColor; prot['asc_setNegativeColor'] = prot.asc_setNegativeColor; prot['asc_setBorderColor'] = prot.asc_setBorderColor; prot['asc_setNegativeBorderColor'] = prot.asc_setNegativeBorderColor; prot['asc_setAxisColor'] = prot.asc_setAxisColor; prot = CIconSet.prototype; prot['asc_getIconSet'] = prot.asc_getIconSet; prot['asc_getReverse'] = prot.asc_getReverse; prot['asc_getShowValue'] = prot.asc_getShowValue; prot['asc_getCFVOs'] = prot.asc_getCFVOs; prot['asc_getIconSets'] = prot.asc_getIconSets; prot['asc_setIconSet'] = prot.asc_setIconSet; prot['asc_setReverse'] = prot.asc_setReverse; prot['asc_setShowValue'] = prot.asc_setShowValue; prot['asc_setCFVOs'] = prot.asc_setCFVOs; prot['asc_setIconSets'] = prot.asc_setIconSets; prot = CConditionalFormatValueObject.prototype; prot['asc_getGte'] = prot.asc_getGte; prot['asc_getType'] = prot.asc_getType; prot['asc_getVal'] = prot.asc_getVal; prot['asc_setGte'] = prot.asc_setGte; prot['asc_setType'] = prot.asc_setType; prot['asc_setVal'] = prot.asc_setVal; prot = CFormulaCF.prototype; prot['asc_getText'] = prot.asc_getText; prot['asc_setText'] = prot.asc_setText; prot = CConditionalFormatIconSet.prototype; prot['asc_getIconSet'] = prot.asc_getIconSet; prot['asc_getIconId'] = prot.asc_getIconId; prot['asc_setIconSet'] = prot.asc_setIconSet; prot['asc_setIconId'] = prot.asc_setIconId; })(window);