/* * * (c) Copyright Ascensio System SIA 2010-2020 * * 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 * */ /** * FormsTab.js * * Created by Julia Radzhabova on 06.10.2020 * Copyright (c) 2020 Ascensio System SIA. All rights reserved. * */ define([ 'common/main/lib/util/utils', 'common/main/lib/component/BaseView', 'common/main/lib/component/Layout' ], function () { 'use strict'; DE.Views.FormsTab = Common.UI.BaseView.extend(_.extend((function(){ function setEvents() { var me = this; this.btnTextField.on('click', function (b, e) { me.fireEvent('forms:insert', ['text']); }); this.btnComboBox.on('click', function (b, e) { me.fireEvent('forms:insert', ['combobox']); }); this.btnDropDown.on('click', function (b, e) { me.fireEvent('forms:insert', ['dropdown']); }); this.btnCheckBox.on('click', function (b, e) { me.fireEvent('forms:insert', ['checkbox']); }); this.btnRadioBox.on('click', function (b, e) { me.fireEvent('forms:insert', ['radiobox']); }); this.btnImageField.on('click', function (b, e) { me.fireEvent('forms:insert', ['picture']); }); this.btnViewForm.on('click', function (b, e) { me.fireEvent('forms:mode', [b.pressed]); }); if (this.mnuFormsColorPicker) { this.btnClearFields.on('click', function (b, e) { me.fireEvent('forms:clear'); }); $('#id-toolbar-menu-new-form-color').on('click', function (b, e) { me.fireEvent('forms:new-color'); }); this.mnuNoFormsColor.on('click', function (item) { me.fireEvent('forms:no-color', [item]); }); this.mnuFormsColorPicker.on('select', function(picker, color) { me.fireEvent('forms:select-color', [color]); }); this.btnHighlight.menu.on('show:after', function(picker, color) { me.fireEvent('forms:open-color', [color]); }); } } return { options: {}, initialize: function (options) { Common.UI.BaseView.prototype.initialize.call(this); this.toolbar = options.toolbar; this.paragraphControls = []; var me = this, $host = me.toolbar.$el; this.btnTextField = new Common.UI.Button({ parentEl: $host.find('#slot-btn-form-field'), cls: 'btn-toolbar x-huge icon-top', iconCls: 'toolbar__icon btn-text-field', caption: this.capBtnText, disabled: true }); this.paragraphControls.push(this.btnTextField); this.btnComboBox = new Common.UI.Button({ parentEl: $host.find('#slot-btn-form-combobox'), cls: 'btn-toolbar x-huge icon-top', iconCls: 'toolbar__icon btn-combo-box', caption: this.capBtnComboBox, disabled: true }); this.paragraphControls.push(this.btnComboBox); this.btnDropDown = new Common.UI.Button({ parentEl: $host.find('#slot-btn-form-dropdown'), cls: 'btn-toolbar x-huge icon-top', iconCls: 'toolbar__icon btn-dropdown', caption: this.capBtnDropDown, disabled: true }); this.paragraphControls.push(this.btnDropDown); this.btnCheckBox = new Common.UI.Button({ parentEl: $host.find('#slot-btn-form-checkbox'), cls: 'btn-toolbar x-huge icon-top', iconCls: 'toolbar__icon btn-checkbox', caption: this.capBtnCheckBox, disabled: true }); this.paragraphControls.push(this.btnCheckBox); this.btnRadioBox = new Common.UI.Button({ parentEl: $host.find('#slot-btn-form-radiobox'), cls: 'btn-toolbar x-huge icon-top', iconCls: 'toolbar__icon btn-radio-button', caption: this.capBtnRadioBox, disabled: true }); this.paragraphControls.push(this.btnRadioBox); this.btnImageField = new Common.UI.Button({ parentEl: $host.find('#slot-btn-form-image'), cls: 'btn-toolbar x-huge icon-top', iconCls: 'toolbar__icon btn-insertimage', caption: this.capBtnImage, disabled: true }); this.paragraphControls.push(this.btnImageField); this.btnViewForm = new Common.UI.Button({ parentEl: $host.find('#slot-btn-form-view'), cls: 'btn-toolbar x-huge icon-top', iconCls: 'toolbar__icon btn-sheet-view', caption: this.capBtnView, enableToggle: true, disabled: true }); this.paragraphControls.push(this.btnViewForm); this.btnClearFields = new Common.UI.Button({ parentEl : $host.find('#slot-form-clear-fields'), cls : 'btn-toolbar', iconCls : 'toolbar__icon btn-clearstyle', caption : this.textClearFields, disabled: true }); this.paragraphControls.push(this.btnClearFields); this.btnHighlight = new Common.UI.Button({ parentEl : $host.find('#slot-form-highlight'), cls : 'btn-toolbar', iconCls : 'toolbar__icon btn-highlight', caption : this.textHighlight, menu : true, disabled: true }); this.paragraphControls.push(this.btnHighlight); this._state = {disabled: false}; Common.NotificationCenter.on('app:ready', this.onAppReady.bind(this)); }, render: function (el) { return this; }, onAppReady: function (config) { var me = this; (new Promise(function (accept, reject) { accept(); })).then(function(){ if (config.canEditContentControl) { me.btnHighlight.setMenu(new Common.UI.Menu({ items: [ me.mnuNoFormsColor = new Common.UI.MenuItem({ id: 'id-toolbar-menu-no-highlight-form', caption: me.textNoHighlight, checkable: true }), {caption: '--'}, {template: _.template('
')}, {template: _.template('' + me.textNewColor + '')} ] })); me.mnuFormsColorPicker = new Common.UI.ThemeColorPalette({ el: $('#id-toolbar-menu-form-color') }); } else { me.btnHighlight.cmpEl.parents('.group').hide().prev('.separator').hide(); } me.btnTextField.updateHint(me.tipTextField); me.btnComboBox.updateHint(me.tipComboBox); me.btnDropDown.updateHint(me.tipDropDown); me.btnCheckBox.updateHint(me.tipCheckBox); me.btnRadioBox.updateHint(me.tipRadioBox); me.btnImageField.updateHint(me.tipImageField); me.btnViewForm.updateHint(me.tipViewForm); setEvents.call(me); }); }, show: function () { Common.UI.BaseView.prototype.show.call(this); this.fireEvent('show', this); }, getButtons: function() { return this.paragraphControls; }, SetDisabled: function (state) { this._state.disabled = state; this.paragraphControls.forEach(function(button) { if ( button ) { button.setDisabled(state); } }, this); }, capBtnText: 'Text Field', capBtnComboBox: 'Combo Box', capBtnDropDown: 'Dropdown', capBtnCheckBox: 'Checkbox', capBtnRadioBox: 'Radio Button', capBtnImage: 'Image', capBtnView: 'View Form', textClearFields: 'Clear All Fields', textHighlight: 'Highlight Settings', tipTextField: 'Insert text field', tipComboBox: 'Insert combo box', tipDropDown: 'Insert dropdown list', tipCheckBox: 'Insert checkbox', tipRadioBox: 'Insert radio button', tipImageField: 'Insert image', tipViewForm: 'Fill form mode', textNoHighlight: 'No highlighting', textNewColor: 'Add New Custom Color' } }()), DE.Views.FormsTab || {})); });