/* * * (c) Copyright Ascensio System Limited 2010-2017 * * 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 Lubanas st. 125a-25, Riga, Latvia, * EU, LV-1021. * * 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 * */ /** * SignatureSettings.js * * Created by Julia Radzhabova on 5/24/17 * Copyright (c) 2017 Ascensio System SIA. All rights reserved. * */ define([ 'text!documenteditor/main/app/template/SignatureSettings.template', 'jquery', 'underscore', 'backbone', 'common/main/lib/component/Button', 'common/main/lib/view/SignDialog', 'common/main/lib/view/SignSettingsDialog' ], function (menuTemplate, $, _, Backbone) { 'use strict'; DE.Views.SignatureSettings = Backbone.View.extend(_.extend({ el: '#id-signature-settings', // Compile our stats template template: _.template(menuTemplate), // Delegated events for creating new items, and clearing completed ones. events: { }, options: { alias: 'SignatureSettings' }, initialize: function () { var me = this; this._state = { DisabledControls: false, DisabledInsertControls: false, requestedSignatures: undefined, validSignatures: undefined, invalidSignatures: undefined }; this._locked = false; this.lockedControls = []; this._noApply = false; this._originalProps = null; this.templateRequested = _.template([ '', '', '', '<% _.each(signatures, function(item) { %>', '', '', '', '', '<% }); %>', '
', '' ].join('')); this.templateValid = _.template([ '', '', '', '<% _.each(signatures, function(item) { %>', '', '', '', '', '', '<% }); %>', '
<%= Common.Utils.String.htmlEncode(item.name) %>
', '' ].join('')); this.render(); }, render: function () { this.$el.html(this.template({ scope: this })); this.btnAddInvisibleSign = new Common.UI.Button({ el: this.$el.find('#signature-invisible-sign') }); this.btnAddInvisibleSign.on('click', _.bind(this.addInvisibleSign, this)); this.lockedControls.push(this.btnAddInvisibleSign); this.btnAddVisibleSign = new Common.UI.Button({ el: this.$el.find('#signature-visible-sign') }); this.btnAddVisibleSign.on('click', _.bind(this.addVisibleSign, this)); this.lockedControls.push(this.btnAddVisibleSign); this.cntRequestedSign = $('#signature-requested-sign'); this.cntValidSign = $('#signature-valid-sign'); this.cntInvalidSign = $('#signature-invalid-sign'); this.$el.on('click', '.signature-sign-link', _.bind(this.onSign, this)); this.$el.on('click', '.signature-view-link', _.bind(this.onViewSignature, this)); }, setApi: function(api) { this.api = api; if (this.api) { this.api.asc_registerCallback('asc_onUpdateSignatures', _.bind(this.onUpdateSignatures, this)); } Common.NotificationCenter.on('document:ready', _.bind(this.onDocumentReady, this)); return this; }, ChangeSettings: function(props) { if (!this._state.requestedSignatures || !this._state.validSignatures || !this._state.invalidSignatures) { this.onUpdateSignatures(this.api.asc_getSignatures(), this.api.asc_getRequestSignatures()); } this.disableControls(this._locked); }, setLocked: function (locked) { this._locked = locked; }, disableControls: function(disable) { if (this._state.DisabledControls!==disable) { this._state.DisabledControls = disable; this.$linksSign && this.$linksSign.toggleClass('disabled', disable); this.$linksView && this.$linksView.toggleClass('disabled', disable); } this.disableInsertControls(disable); }, disableInsertControls: function(disable) { if (this._state.DisabledInsertControls!==disable) { this._state.DisabledInsertControls = disable; _.each(this.lockedControls, function(item) { item.setDisabled(disable); }); } }, setMode: function(mode) { this.mode = mode; }, onUpdateSignatures: function(valid, requested){ var me = this; me._state.requestedSignatures = []; me._state.validSignatures = []; me._state.invalidSignatures = []; _.each(requested, function(item, index){ me._state.requestedSignatures.push({name: item.asc_getSigner1(), guid: item.asc_getGuid()}); }); _.each(valid, function(item, index){ var sign = {name: item.asc_getSigner1(), guid: item.asc_getId(), date: '18/05/2017'}; (item.asc_getValid()==0) ? me._state.validSignatures.push(sign) : me._state.invalidSignatures.push(sign); }); // me._state.requestedSignatures = [{name: 'Hammish Mitchell', guid: '123'}, {name: 'Someone Somewhere', guid: '123'}, {name: 'Mary White', guid: '123'}, {name: 'John Black', guid: '123'}]; // me._state.validSignatures = [{name: 'Hammish Mitchell', guid: '123', date: '18/05/2017'}, {name: 'Someone Somewhere', guid: '345', date: '18/05/2017'}]; // me._state.invalidSignatures = [{name: 'Mary White', guid: '111', date: '18/05/2017'}, {name: 'John Black', guid: '456', date: '18/05/2017'}]; this.cntRequestedSign.html(this.templateRequested({signatures: me._state.requestedSignatures, header: this.strRequested})); this.cntValidSign.html(this.templateValid({signatures: me._state.validSignatures, header: this.strValid})); this.cntInvalidSign.html(this.templateValid({signatures: me._state.invalidSignatures, header: this.strInvalid})); this.$linksSign = $('.signature-sign-link', this.$el); var width = this.$linksSign.width(); $('.signature-sign-name', this.cntRequestedSign).css('max-width', 170-width); this.$linksView = $('.signature-view-link', this.$el); width = this.$linksView.width(); $('.signature-sign-name', this.cntValidSign).css('max-width', 170-width); $('.signature-sign-name', this.cntInvalidSign).css('max-width', 170-width); }, addVisibleSign: function(btn) { var me = this, win = new Common.Views.SignSettingsDialog({ handler: function(dlg, result) { if (result == 'ok') { me.api.asc_AddSignatureLine2(dlg.getSettings()); } me.fireEvent('editcomplete', me); } }); win.show(); }, addInvisibleSign: function(btn) { var me = this, win = new Common.Views.SignDialog({ api: me.api, signType: 'invisible', handler: function(dlg, result) { if (result == 'ok') { var props = dlg.getSettings(); me.api.asc_Sign(props.certificateId); } me.fireEvent('editcomplete', me); } }); win.show(); }, onSign: function(event) { var me = this, target = $(event.currentTarget); if (target.hasClass('disabled')) return; if (_.isUndefined(me.fontStore)) { me.fontStore = new Common.Collections.Fonts(); var fonts = DE.getController('Toolbar').getView('Toolbar').cmbFontName.store.toJSON(); var arr = []; _.each(fonts, function(font, index){ if (!font.cloneid) { arr.push(_.clone(font)); } }); me.fontStore.add(arr); } var win = new Common.Views.SignDialog({ api: me.api, signType: 'visible', fontStore: me.fontStore, handler: function(dlg, result) { if (result == 'ok') { var props = dlg.getSettings(); me.api.asc_Sign(props.certificateId, target.attr('data-value'), props.images[0], props.images[1]); } me.fireEvent('editcomplete', me); } }); win.show(); }, onViewSignature: function(event) { var target = $(event.currentTarget); if (target.hasClass('disabled')) return; this.api.asc_ViewCertificate(target.attr('data-value')); }, onDocumentReady: function() { this.ChangeSettings(); var me = this, hasSigned = (me._state.validSignatures.length>0 || me._state.invalidSignatures.length>0), hasRequested = (me._state.requestedSignatures.length>0); hasSigned && this.disableEditing(hasSigned); if (!this._state.tip && (hasSigned || hasRequested)) { this._state.tip = new Common.UI.SynchronizeTip({ target : DE.getController('RightMenu').getView('RightMenu').btnSignature.btnEl, text : (hasSigned) ? this.txtSignedDocument : this.txtRequestedSignatures, showLink: hasSigned, textLink: this.txtContinueEditing, placement: 'left' }); this._state.tip.on({ 'dontshowclick': function() { me._state.tip.hide(); // me.api.editSingedDoc(); me.disableEditing(false); }, 'closeclick': function() { me._state.tip.hide(); } }); this._state.tip.show(); } }, disableEditing: function(disable) { disable && DE.getController('RightMenu').getView('RightMenu').clearSelection(); DE.getController('Toolbar').DisableToolbar(disable, disable); DE.getController('RightMenu').SetDisabled(disable, false, true); DE.getController('Statusbar').getView('Statusbar').SetDisabled(disable); DE.getController('Common.Controllers.ReviewChanges').SetDisabled(disable); DE.getController('LeftMenu').SetDisabled(disable, true); this.disableInsertControls(disable); }, strSignature: 'Signature', strInvisibleSign: 'Add invisible digital signature', strVisibleSign: 'Add visible signature', strRequested: 'Requested signatures', strValid: 'Valid signatures', strInvalid: 'Invalid signatures', strSign: 'Sign', strView: 'View', txtSignedDocument: 'This document has been signed. It should not be edited.', txtRequestedSignatures: 'This document has requested signatures.', txtContinueEditing: 'Edit anyway' }, DE.Views.SignatureSettings || {})); });