Files
DocumentServer-v-9.2.0/sdkjs/cell/model/ConditionalFormatting.js
Yajbir Singh f1b860b25c
Some checks failed
check / markdownlint (push) Has been cancelled
check / spellchecker (push) Has been cancelled
updated
2025-12-11 19:03:17 +05:30

3271 lines
141 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
* (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);