[SSE] Apply settings for conditional formatting

This commit is contained in:
Julia Radzhabova 2021-01-26 11:38:05 +03:00
parent 4a246ef70f
commit 729b8a8b10
3 changed files with 129 additions and 5 deletions

View file

@ -1487,6 +1487,7 @@ define([
langId: value,
handler: function (result, settings) {
if (me && me.api) {
me.api.asc_setCF(settings);
}
}
})).show();

View file

@ -1181,6 +1181,120 @@ define([
}
},
getSettings: function() {
var props;
var rec = this.ruleStore.findWhere({index: this.cmbCategory.getValue()});
if (rec) {
props = new AscCommonExcel.CConditionalFormattingRule();
var type = rec.get('type');
props.asc_setType(type);
if (type == Asc.c_oAscCFType.containsText || type == Asc.c_oAscCFType.notContainsText || type == Asc.c_oAscCFType.beginsWith ||
type == Asc.c_oAscCFType.endsWith || type == Asc.c_oAscCFType.timePeriod || type == Asc.c_oAscCFType.aboveAverage ||
type == Asc.c_oAscCFType.top10 || type == Asc.c_oAscCFType.cellIs || type == Asc.c_oAscCFType.expression) {
var xfs = new AscCommonExcel.CellXfs();
xfs.asc_setFontBold(this.btnBold.isActive());
xfs.asc_setFontItalic(this.btnItalic.isActive());
xfs.asc_setFontUnderline(this.btnUnderline.isActive());
xfs.asc_setFontStrikeout(this.btnStrikeout.isActive());
this.mnuTextColorPicker.currentColor && xfs.asc_setFontColor(Common.Utils.ThemeColor.getRgbColor(this.mnuTextColorPicker.currentColor));
this.mnuFillColorPicker.currentColor && xfs.asc_setFillColor(Common.Utils.ThemeColor.getRgbColor(this.mnuFillColorPicker.currentColor));
this.cmbNumberFormat.getSelectedRecord() && xfs.asc_setNumFormatInfo(this.cmbNumberFormat.getValue());
props.asc_setDxf(xfs);
}
switch (type) {
case Asc.c_oAscCFType.containsText:
case Asc.c_oAscCFType.notContainsText:
case Asc.c_oAscCFType.beginsWith:
case Asc.c_oAscCFType.endsWith:
var value = this.txtRange1.setValue();
value && props.asc_setContainsText(value);
break;
case Asc.c_oAscCFType.timePeriod:
props.asc_setTimePeriod(this.cmbRule.getValue());
break;
case Asc.c_oAscCFType.aboveAverage:
var val = this.cmbRule.getValue();
var above = !(val%2);
props.asc_setAboveAverage(above);
props.asc_setEqualAverage(val==2 || val==3);
props.asc_setStdDev(val>3 ? (val/2 - 1) : 0);
break;
case Asc.c_oAscCFType.top10:
props.asc_setBottom(!!this.cmbRule.getValue());
props.asc_setPercent(!!this.cmbPercent.getValue());
(this.numRank.getValue()!=='') && props.asc_setRank(this.numRank.getNumberValue());
break;
case Asc.c_oAscCFType.cellIs:
props.asc_setOperator(this.cmbRule.getValue());
props.asc_setValue1(this.txtRange1.getValue());
props.asc_setValue2(this.txtRange2.getValue());
break;
case Asc.c_oAscCFType.expression:
props.asc_getValue1(this.txtRange1.getValue());
break;
case Asc.c_oAscCFType.colorScale:
var scaleProps = new AscCommonExcel.CColorScale();
var scalesCount = rec.get('num');
var arr = (scalesCount) ? [this.scaleControls[0], this.scaleControls[2]] : this.scaleControls;
var colors = [], scales = [];
for (var i=0; i<scalesCount; i++) {
var scale = new AscCommonExcel.CConditionalFormatValueObject();
var controls = arr[i];
scale.asc_setType(controls.combo.getValue());
scale.asc_setVal(controls.range.getValue());
scales.push(scale);
colors.push(Common.Utils.ThemeColor.getRgbColor(Common.Utils.ThemeColor.getRgbColor(controls.color.currentColor)));
}
scaleProps.asc_setColors();
scaleProps.asc_setCFVOs();
props.asc_setColorScaleOrDataBarOrIconSetRule(scaleProps);
break;
case Asc.c_oAscCFType.dataBar:
// value = props.asc_getColorScaleOrDataBarOrIconSetRule();
// var bars = value.asc_getCFVOs();
// var arr = this.barControls;
// for (var i=0; i<bars.length; i++) {
// var bartype = bars[i].asc_getType(),
// val = bars[i].asc_getVal(),
// controls = arr[i];
// controls.combo.setValue(bartype);
// controls.range.setDisabled(bartype == Asc.c_oAscCfvoType.Minimum || bartype == Asc.c_oAscCfvoType.Maximum || bartype == Asc.c_oAscCfvoType.AutoMin || bartype == Asc.c_oAscCfvoType.AutoMax);
// controls.range.setValue((bartype !== Asc.c_oAscCfvoType.Minimum && bartype !== Asc.c_oAscCfvoType.Maximum && bartype !== Asc.c_oAscCfvoType.AutoMin && bartype !== Asc.c_oAscCfvoType.AutoMax &&
// val!==null && val!==undefined) ? val : '');
// }
// this.cmbFill.setValue(value.asc_getGradient());
// setColor(value.asc_getColor(), this.btnPosFill);
// setColor(value.asc_getNegativeColor() || value.asc_getColor(), this.btnNegFill);
// this.chFill.setValue(value.asc_getNegativeBarColorSameAsPositive());
//
// var color = value.asc_getBorderColor();
// this.cmbBorder.setValue(color===null);
// this.btnPosBorder.setDisabled(color===null);
// if (color) {
// setColor(value.asc_getBorderColor(), this.btnPosBorder);
// setColor(value.asc_getNegativeBorderColor() || value.asc_getBorderColor(), this.btnNegBorder);
// }
// this.chBorder.setValue(value.asc_getNegativeBarBorderColorSameAsPositive());
// this.chBorder.setDisabled(color===null);
// this.btnNegBorder.setDisabled(color===null || value.asc_getNegativeBarBorderColorSameAsPositive());
//
// this.cmbBarDirection.setValue(value.asc_getDirection());
// this.chShowBar.setValue(!value.asc_getShowValue());
// this.cmbAxisPos.setValue(value.asc_getAxisPosition());
// value.asc_getAxisColor() && setColor(value.asc_getAxisColor(), this.btnAxisColor);
// this.btnAxisColor.setDisabled(value.asc_getAxisPosition() == Asc.c_oAscDataBarAxisPosition.none);
break;
case Asc.c_oAscCFType.iconSet:
// value = props.asc_getColorScaleOrDataBarOrIconSetRule();
break;
}
}
return props;
},
refreshRules: function(index, ruleType) {
var rec = this.ruleStore.findWhere({index: index});
if (rec) {
@ -1305,10 +1419,6 @@ define([
this.mnuBorderColorPicker.updateColors(Common.Utils.ThemeColor.getEffectColors(), Common.Utils.ThemeColor.getStandartColors());
},
getSettings: function() {
return {};
},
onPrimary: function() {
this.onDlgBtnClick('ok');
return false;

View file

@ -446,8 +446,21 @@ define([ 'text!spreadsheeteditor/main/app/template/FormatRulesManagerDlg.templa
langId : me.langId,
handler : function(result, settings) {
if (result == 'ok' && settings) {
var name = me.getRuleName(settings);
if (isEdit) {
rec.set('name', name);
rec.set('tip', name);
rec.set('props', settings);
} else {
var store = me.rulesList.store,
index = rec ? store.indexOf(rec)+1 : store.length;
store.add({
levelIndex: index,
name: name,
tip: name,
range: '',
props: settings
}, {at: index});
}
}
}