/* * * (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!presentationeditor/main/app/template/SignatureSettings.template', 'jquery', 'underscore', 'backbone', 'common/main/lib/component/Button', 'common/main/lib/view/SignDialog' ], function (menuTemplate, $, _, Backbone) { 'use strict'; PE.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, validSignatures: undefined, invalidSignatures: undefined, DisabledEditing: false, ready: false }; this._locked = false; this.lockedControls = []; this._noApply = false; this._originalProps = null; 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.cntValidSign = $('#signature-valid-sign'); this.cntInvalidSign = $('#signature-invalid-sign'); 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.onApiUpdateSignatures, this)); } Common.NotificationCenter.on('document:ready', _.bind(this.onDocumentReady, this)); return this; }, ChangeSettings: function(props) { if (!this._state.validSignatures || !this._state.invalidSignatures) this.updateSignatures(this.api.asc_getSignatures()); this.disableControls(this._locked); }, setLocked: function (locked) { this._locked = locked; }, disableControls: function(disable) { if (this._state.DisabledControls!==disable) { this._state.DisabledControls = 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; }, onApiUpdateSignatures: function(valid){ if (!this._state.ready) return; this.updateSignatures(valid); this.showSignatureTooltip(this._state.validSignatures.length>0 || this._state.invalidSignatures.length>0); }, updateSignatures: function(valid){ var me = this; me._state.validSignatures = []; me._state.invalidSignatures = []; _.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.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.cntValidSign.html(this.templateValid({signatures: me._state.validSignatures, header: this.strValid})); this.cntInvalidSign.html(this.templateValid({signatures: me._state.invalidSignatures, header: this.strInvalid})); this.$linksView = $('.signature-view-link', this.$el); var width = this.$linksView.width(); $('.signature-sign-name', this.cntValidSign).css('max-width', 170-width); $('.signature-sign-name', this.cntInvalidSign).css('max-width', 170-width); me.disableEditing(me._state.validSignatures.length>0 || me._state.invalidSignatures.length>0); }, 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(); }, onViewSignature: function(event) { var target = $(event.currentTarget); if (target.hasClass('disabled')) return; this.api.asc_ViewCertificate(target.attr('data-value')); }, onDocumentReady: function() { this._state.ready = true; this.updateSignatures(this.api.asc_getSignatures()); this.showSignatureTooltip(this._state.validSignatures.length>0 || this._state.invalidSignatures.length>0); }, showSignatureTooltip: function(hasSigned) { if (!hasSigned) return; var me = this, tip = new Common.UI.SynchronizeTip({ target : PE.getController('RightMenu').getView('RightMenu').btnSignature.btnEl, text : this.txtSignedDocument, showLink: hasSigned, textLink: this.txtContinueEditing, placement: 'left' }); tip.on({ 'dontshowclick': function() { tip.close(); // me.api.editSingedDoc(); me.disableEditing(false); }, 'closeclick': function() { tip.close(); } }); tip.show(); }, disableEditing: function(disable) { if (this._state.DisabledEditing != disable) { this._state.DisabledEditing = disable; disable && PE.getController('RightMenu').getView('RightMenu').clearSelection(); PE.getController('RightMenu').SetDisabled(disable, true); PE.getController('Toolbar').DisableToolbar(disable, disable); PE.getController('Statusbar').getView('Statusbar').SetDisabled(disable); PE.getController('Common.Controllers.ReviewChanges').SetDisabled(disable); PE.getController('DocumentHolder').getView('DocumentHolder').SetDisabled(disable); var leftMenu = PE.getController('LeftMenu').leftMenu; leftMenu.btnComments.setDisabled(disable); var comments = PE.getController('Common.Controllers.Comments'); if (comments) comments.setPreviewMode(disable); this.disableInsertControls(disable); } }, strSignature: 'Signature', strInvisibleSign: 'Add invisible digital signature', strValid: 'Valid signatures', strInvalid: 'Invalid signatures', strView: 'View', txtSignedDocument: 'This document has been signed. It should not be edited.', txtContinueEditing: 'Edit anyway' }, PE.Views.SignatureSettings || {})); });