/* * * (c) Copyright Ascensio System SIA 2010-2022 * * 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-12 Ernesta Birznieka-Upisha * 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 * */ /** * ProtectDialog.js * * Created by Julia Radzhabova on 21.09.2022 * Copyright (c) 2022 Ascensio System SIA. All rights reserved. * */ define([ 'common/main/lib/component/Window' ], function () { 'use strict'; DE.Views.ProtectDialog = Common.UI.Window.extend(_.extend({ initialize : function (options) { var t = this, _options = {}; _.extend(_options, { title: options.title ? options.title : this.txtTitle, cls: 'modal-dlg', width: 350, height: 'auto', buttons: options.buttons ? options.buttons : [{ value: 'ok', caption: this.txtProtect }, 'cancel'] }, options); this.handler = options.handler; this.props = options.props; this.template = options.template || [ '
', '
', '', '
', '
', '
', '', '
', '
', '
', '', '
', '
', '
', '
', '
', '', '
' ].join(''); _options.tpl = _.template(this.template)(_options); Common.UI.Window.prototype.initialize.call(this, _options); }, render: function () { Common.UI.Window.prototype.render.call(this); var me = this; this.$window.find('.dlg-btn').on('click', _.bind(this.onBtnClick, this)); this.repeatPwd = new Common.UI.InputField({ el: this.$window.find('#id-protect-repeat-txt'), type: 'password', allowBlank : true, style : 'width: 100%;', maxLength: 15, validateOnBlur: false, validation : function(value) { return me.txtIncorrectPwd; } }); this.inputPwd = new Common.UI.InputFieldBtnPassword({ el: this.$window.find('#id-protect-password-txt'), type: 'password', allowBlank : true, style : 'width: 100%;', maxLength: 15, validateOnBlur: false, repeatInput: this.repeatPwd, showPwdOnClick: true, validation : function(value) { return (value.length>15) ? me.txtLimit : true; } }); this.rbView = new Common.UI.RadioBox({ el: this.$window.find('#id-protect-radio-view'), labelText: this.textView, name: 'asc-radio-protect-mode', value: Asc.c_oAscEDocProtect.ReadOnly, checked: true }); this.rbForms = new Common.UI.RadioBox({ el: this.$window.find('#id-protect-radio-forms'), labelText: this.textForms, name: 'asc-radio-protect-mode', value: Asc.c_oAscEDocProtect.Forms }); this.rbReview = new Common.UI.RadioBox({ el: this.$window.find('#id-protect-radio-review'), labelText: this.textReview, name: 'asc-radio-protect-mode', value: Asc.c_oAscEDocProtect.TrackedChanges }); this.rbComments = new Common.UI.RadioBox({ el: this.$window.find('#id-protect-radio-comment'), labelText: this.textComments, name: 'asc-radio-protect-mode', value: Asc.c_oAscEDocProtect.Comments }); this.btnOk = new Common.UI.Button({ el: this.$window.find('.primary') }); this.afterRender(); }, getFocusedComponents: function() { return [this.inputPwd, this.repeatPwd, this.rbView, this.rbForms, this.rbReview, this.rbComments]; }, getDefaultFocusableComponent: function () { return this.inputPwd; }, afterRender: function() { this._setDefaults(this.props); }, onPrimary: function(event) { this._handleInput('ok'); return false; }, onBtnClick: function(event) { this._handleInput(event.currentTarget.attributes['result'].value); }, _handleInput: function(state) { if (state === 'ok' && this.btnOk.isDisabled()) return; if (this.handler) { if (state === 'ok') { if (this.inputPwd.checkValidate() !== true) { this.inputPwd.focus(); return; } if (this.inputPwd.getValue() !== this.repeatPwd.getValue()) { this.repeatPwd.checkValidate(); this.repeatPwd.focus(); return; } } this.handler.call(this, state, this.inputPwd.getValue(), (state == 'ok') ? this.getSettings() : undefined); } this.close(); }, _setDefaults: function (props) { if (props) { } }, getSettings: function() { if (this.rbView.getValue()) return Asc.c_oAscEDocProtect.ReadOnly; if (this.rbForms.getValue()) return Asc.c_oAscEDocProtect.Forms; if (this.rbReview.getValue()) return Asc.c_oAscEDocProtect.TrackedChanges; if (this.rbComments.getValue()) return Asc.c_oAscEDocProtect.Comments; }, SetDisabled: function(disabled) { this.btnOk.setDisabled(disabled); }, txtPassword : "Password", txtRepeat: 'Repeat password', txtOptional: 'optional', txtIncorrectPwd: 'Confirmation password is not identical', txtWarning: 'Warning: If you lose or forget the password, it cannot be recovered. Please keep it in a safe place.', txtProtect: 'Protect', txtTitle: 'Protect', txtAllow: 'Allow only this type of editing in the document', textView: 'No changes (Read only)', textForms: 'Filling forms', textReview: 'Tracked changes', textComments: 'Comments', txtLimit: 'Password is limited to 15 characters' }, DE.Views.ProtectDialog || {})); });