/* * (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 * */ /** * GoalSeekDlg.js * * Created on 21.07.2023 * */ define([ 'common/main/lib/view/AdvancedSettingsWindow', ], function () { 'use strict'; SSE.Views.GoalSeekDlg = Common.Views.AdvancedSettingsWindow.extend(_.extend({ options: { contentWidth: 250, separator: false, id: 'window-goal-seek' }, initialize : function(options) { var me = this; _.extend(this.options, { title: this.textTitle, contentStyle: 'padding: 5px 5px 0;', contentTemplate: _.template([ '
', '
', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '
', '', '
', '
', '
', '', '
', '
', '
', '', '
', '
', '
', '
' ].join(''))({scope: this}) }, options); this.api = options.api; this.props = options.props; this.options.handler = function(result, value) { if ( result != 'ok' || this.isRangeValid() ) { if (options.handler) options.handler.call(this, result, value); return; } return true; }; this.dataFormulaCellValid = ''; this.dataChangeCellValid = ''; Common.Views.AdvancedSettingsWindow.prototype.initialize.call(this, this.options); }, render: function() { Common.Views.AdvancedSettingsWindow.prototype.render.call(this); this.txtFormulaCell= new Common.UI.InputFieldBtn({ el : $('#goal-seek-formula-cell'), name : 'range', style : 'width: 100%;', btnHint : this.textSelectData, validateOnBlur: false, hideErrorOnInput: true }); this.txtFormulaCell.on('button:click', _.bind(this.onSelectData, this, 'formula')); this.txtChangeCell = new Common.UI.InputFieldBtn({ el : $('#goal-seek-change-cell'), name : 'range', style : 'width: 100%;', btnHint : this.textSelectData, validateOnBlur: false, hideErrorOnInput: true }); this.txtChangeCell.on('button:click', _.bind(this.onSelectData, this, 'change')); this.txtExpectVal = new Common.UI.InputField({ el : $('#goal-seek-expect-val'), style : 'width: 100%;', maskExp : /[0-9,\.\-]/, validateOnBlur: false, hideErrorOnInput: true }); this.afterRender(); }, getFocusedComponents: function() { return [this.txtFormulaCell, this.txtExpectVal, this.txtChangeCell].concat(this.getFooterButtons()); }, getDefaultFocusableComponent: function () { if (this._alreadyRendered) return; // focus only at first show this._alreadyRendered = true; return this.txtFormulaCell; }, afterRender: function() { this._setDefaults(this.props); }, _setDefaults: function (props) { this.txtFormulaCell.setValue(this.api.asc_getActiveRangeStr(Asc.referenceType.A)); }, getSettings: function () { return {formulaCell: this.txtFormulaCell.getValue(), changingCell: this.txtChangeCell.getValue(), expectedValue: this.txtExpectVal.getValue()}; }, isRangeValid: function() { var isvalid = true, txtError = '', value; if (_.isEmpty(this.txtFormulaCell.getValue())) { isvalid = false; txtError = this.txtEmpty; } else { value = this.api.asc_checkDataRange(Asc.c_oAscSelectionDialogType.GoalSeek_Cell, this.txtFormulaCell.getValue(), true); if (value != Asc.c_oAscError.ID.No) { if (value == Asc.c_oAscError.ID.DataRangeError) { txtError = this.textDataRangeError; } else if (value == Asc.c_oAscError.ID.MustSingleCell) { txtError = this.textMustSingleCell; } else if (value == Asc.c_oAscError.ID.MustContainFormula) { txtError = this.textMustContainFormula; } else if (value == Asc.c_oAscError.ID.MustFormulaResultNumber) { txtError = this.textMustFormulaResultNumber; } isvalid = false; } } if (!isvalid) { this.txtFormulaCell.showError([txtError]); this.txtFormulaCell.cmpEl.find('input').focus(); return isvalid; } if (_.isEmpty(this.txtExpectVal.getValue())) { isvalid = false; txtError = this.txtEmpty; } else if (!Common.UI.isValidNumber(this.txtExpectVal.getValue())) { isvalid = false; txtError = this.txtErrorNumber; } if (!isvalid) { this.txtExpectVal.showError([txtError]); this.txtExpectVal.cmpEl.find('input').focus(); return isvalid; } if (_.isEmpty(this.txtChangeCell.getValue())) { isvalid = false; txtError = this.txtEmpty; } else { value = this.api.asc_checkDataRange(Asc.c_oAscSelectionDialogType.GoalSeek_ChangingCell, this.txtChangeCell.getValue(), true); if (value != Asc.c_oAscError.ID.No) { if (value == Asc.c_oAscError.ID.DataRangeError) { txtError = this.textDataRangeError; } else if (value == Asc.c_oAscError.ID.MustSingleCell) { txtError = this.textMustSingleCell; } else if (value == Asc.c_oAscError.ID.MustContainValue) { txtError = this.textMustContainValue; } isvalid = false; } } if (!isvalid) { this.txtChangeCell.showError([txtError]); this.txtChangeCell.cmpEl.find('input').focus(); return isvalid; } return isvalid; }, onSelectData: function(type) { var me = this, txtRange = (type=='formula') ? me.txtFormulaCell : me.txtChangeCell; if (me.api) { var handlerDlg = function(dlg, result) { if (result == 'ok') { var txt = dlg.getSettings(); (type=='formula') ? (me.dataFormulaCellValid = txt) : (me.dataChangeCellValid = txt); txtRange.setValue(txt); txtRange.checkValidate(); } }; var win = new SSE.Views.CellRangeDialog({ handler: handlerDlg }).on('close', function() { me.show(); _.delay(function(){ txtRange.focus(); },1); }); var xy = Common.Utils.getOffset(me.$window); me.hide(); win.show(me.$window, xy); win.setSettings({ api : me.api, range : (!_.isEmpty(txtRange.getValue()) && (txtRange.checkValidate()==true)) ? txtRange.getValue() : ((type=='formula') ? me.dataFormulaCellValid : me.dataChangeCellValid) }); } }, textTitle: 'Goal Seek', textSetCell: 'Set cell', textToValue: 'To value', textChangingCell: 'By changing cell', txtEmpty: 'This field is required', textSelectData: 'Select data', textDataRangeError: 'The formula is missing a range', textMustSingleCell: 'Reference must be to a single cell', textMustContainFormula: 'The cell must contain a formula', textMustFormulaResultNumber: 'Formula in cell must result in a number', textMustContainValue: 'Cell must contain a value', txtErrorNumber: 'Your entry cannot be used. An integer or decimal number may be required.' }, SSE.Views.GoalSeekDlg || {})) });