2016-04-01 13:17:09 +00:00
|
|
|
/*
|
|
|
|
*
|
2019-01-17 13:05:03 +00:00
|
|
|
* (c) Copyright Ascensio System SIA 2010-2019
|
2016-04-01 13:17:09 +00:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*
|
2019-01-17 13:00:34 +00:00
|
|
|
* You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha
|
|
|
|
* street, Riga, Latvia, EU, LV-1050.
|
2016-04-01 13:17:09 +00:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*
|
|
|
|
*/
|
2016-03-11 00:48:53 +00:00
|
|
|
/**
|
|
|
|
* TableSettings.js
|
|
|
|
*
|
|
|
|
* Created by Julia Radzhabova on 4/11/14
|
2018-03-01 12:16:38 +00:00
|
|
|
* Copyright (c) 2018 Ascensio System SIA. All rights reserved.
|
2016-03-11 00:48:53 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
define([
|
|
|
|
'text!presentationeditor/main/app/template/TableSettings.template',
|
|
|
|
'jquery',
|
|
|
|
'underscore',
|
|
|
|
'backbone',
|
|
|
|
'common/main/lib/component/Button',
|
|
|
|
'common/main/lib/component/CheckBox',
|
|
|
|
'common/main/lib/component/ThemeColorPalette',
|
|
|
|
'common/main/lib/component/ColorButton',
|
|
|
|
'common/main/lib/component/ComboBorderSize',
|
|
|
|
'common/main/lib/component/ComboDataView',
|
|
|
|
'common/main/lib/view/InsertTableDialog',
|
|
|
|
'presentationeditor/main/app/view/TableSettingsAdvanced'
|
|
|
|
], function (menuTemplate, $, _, Backbone) {
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
PE.Views.TableSettings = Backbone.View.extend(_.extend({
|
|
|
|
el: '#id-table-settings',
|
|
|
|
|
|
|
|
// Compile our stats template
|
|
|
|
template: _.template(menuTemplate),
|
|
|
|
|
|
|
|
// Delegated events for creating new items, and clearing completed ones.
|
|
|
|
events: {
|
|
|
|
},
|
|
|
|
|
|
|
|
options: {
|
|
|
|
alias: 'TableSettings'
|
|
|
|
},
|
|
|
|
|
|
|
|
initialize: function () {
|
2016-10-11 10:29:21 +00:00
|
|
|
this._initSettings = true;
|
2016-03-11 00:48:53 +00:00
|
|
|
|
|
|
|
this._state = {
|
2022-02-15 10:30:50 +00:00
|
|
|
TemplateId: undefined,
|
2016-03-11 00:48:53 +00:00
|
|
|
CheckHeader: false,
|
|
|
|
CheckTotal: false,
|
|
|
|
CheckBanded: false,
|
|
|
|
CheckFirst: false,
|
|
|
|
CheckLast: false,
|
|
|
|
CheckColBanded: false,
|
|
|
|
BackColor: '#000000',
|
2018-02-06 12:06:01 +00:00
|
|
|
DisabledControls: false,
|
|
|
|
Width: null,
|
2022-02-15 10:30:50 +00:00
|
|
|
Height: null,
|
|
|
|
beginPreviewStyles: true,
|
|
|
|
previewStylesCount: -1,
|
|
|
|
currentStyleFound: false
|
2016-03-11 00:48:53 +00:00
|
|
|
};
|
2018-02-06 12:06:01 +00:00
|
|
|
this.spinners = [];
|
2016-03-11 00:48:53 +00:00
|
|
|
this.lockedControls = [];
|
|
|
|
this._locked = false;
|
2016-04-05 12:57:51 +00:00
|
|
|
this._originalLook = new Asc.CTablePropLook();
|
2016-03-11 00:48:53 +00:00
|
|
|
|
|
|
|
this._originalProps = null;
|
|
|
|
this.CellBorders = {};
|
|
|
|
this.CellColor = {Value: 1, Color: 'transparent'}; // value=1 - цвет определен - прозрачный или другой, value=0 - цвет не определен, рисуем прозрачным
|
|
|
|
this.BorderSize = 1;
|
|
|
|
this._noApply = false;
|
|
|
|
|
|
|
|
this.render();
|
|
|
|
},
|
|
|
|
|
|
|
|
onCheckTemplateChange: function(type, field, newValue, oldValue, eOpts) {
|
|
|
|
if (this.api) {
|
2016-04-05 12:57:51 +00:00
|
|
|
var properties = new Asc.CTableProp();
|
|
|
|
var look = (this._originalLook) ? this._originalLook : new Asc.CTablePropLook();
|
2016-03-11 00:48:53 +00:00
|
|
|
switch (type) {
|
|
|
|
case 0:
|
|
|
|
look.put_FirstRow(field.getValue()=='checked');
|
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
look.put_LastRow(field.getValue()=='checked');
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
look.put_BandHor(field.getValue()=='checked');
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
look.put_FirstCol(field.getValue()=='checked');
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
look.put_LastCol(field.getValue()=='checked');
|
|
|
|
break;
|
|
|
|
case 5:
|
|
|
|
look.put_BandVer(field.getValue()=='checked');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
properties.put_TableLook(look);
|
|
|
|
this.api.tblApply(properties);
|
|
|
|
}
|
|
|
|
this.fireEvent('editcomplete', this);
|
|
|
|
},
|
|
|
|
|
2019-12-13 14:18:11 +00:00
|
|
|
onTableTemplateSelect: function(btn, picker, itemView, record){
|
2016-03-11 00:48:53 +00:00
|
|
|
if (this.api && !this._noApply) {
|
2016-04-05 12:57:51 +00:00
|
|
|
var properties = new Asc.CTableProp();
|
2016-03-11 00:48:53 +00:00
|
|
|
properties.put_TableStyle(record.get('templateId'));
|
|
|
|
this.api.tblApply(properties);
|
|
|
|
}
|
|
|
|
this.fireEvent('editcomplete', this);
|
|
|
|
},
|
|
|
|
|
2020-04-29 17:32:18 +00:00
|
|
|
onColorsBackSelect: function(btn, color) {
|
2016-03-11 00:48:53 +00:00
|
|
|
this.CellColor = {Value: 1, Color: color};
|
|
|
|
|
|
|
|
if (this.api) {
|
2016-04-05 12:57:51 +00:00
|
|
|
var properties = new Asc.CTableProp();
|
|
|
|
var background = new Asc.CBackground();
|
2016-03-11 00:48:53 +00:00
|
|
|
properties.put_CellsBackground(background);
|
|
|
|
|
|
|
|
if (this.CellColor.Color=='transparent') {
|
|
|
|
background.put_Value(1);
|
|
|
|
} else {
|
|
|
|
background.put_Value(0);
|
|
|
|
background.put_Color(Common.Utils.ThemeColor.getRgbColor(this.CellColor.Color));
|
|
|
|
}
|
|
|
|
properties.put_CellSelect(true);
|
|
|
|
this.api.tblApply(properties);
|
|
|
|
}
|
|
|
|
|
|
|
|
this.fireEvent('editcomplete', this);
|
|
|
|
},
|
|
|
|
|
|
|
|
onBtnBordersClick: function(btn, eOpts){
|
|
|
|
this._UpdateBordersStyle(btn.options.strId, true);
|
|
|
|
if (this.api) {
|
2016-04-05 12:57:51 +00:00
|
|
|
var properties = new Asc.CTableProp();
|
2016-03-11 00:48:53 +00:00
|
|
|
properties.put_CellBorders(this.CellBorders);
|
|
|
|
properties.put_CellSelect(true);
|
|
|
|
this.api.tblApply(properties);
|
|
|
|
}
|
|
|
|
this.fireEvent('editcomplete', this);
|
|
|
|
},
|
|
|
|
|
|
|
|
onBorderSizeSelect: function(combo, record) {
|
|
|
|
this.BorderSize = record.value;
|
|
|
|
},
|
|
|
|
|
|
|
|
onEditClick: function(menu, item, e) {
|
|
|
|
if (this.api) {
|
|
|
|
switch (item.value) {
|
|
|
|
case 0: this.api.selectRow(); break;
|
|
|
|
case 1: this.api.selectColumn(); break;
|
|
|
|
case 2: this.api.selectCell(); break;
|
|
|
|
case 3: this.api.selectTable(); break;
|
|
|
|
case 4: this.api.addRowAbove(); break;
|
|
|
|
case 5: this.api.addRowBelow(); break;
|
|
|
|
case 6: this.api.addColumnLeft(); break;
|
|
|
|
case 7: this.api.addColumnRight(); break;
|
|
|
|
case 8: this.api.remRow(); break;
|
|
|
|
case 9: this.api.remColumn(); break;
|
|
|
|
case 10: this.api.remTable(); break;
|
|
|
|
case 11: this.api.MergeCells(); break;
|
|
|
|
case 12: this.splitCells(menu, item, e); break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
this.fireEvent('editcomplete', this);
|
|
|
|
},
|
|
|
|
|
|
|
|
splitCells: function(menu, item, e) {
|
|
|
|
var me = this;
|
|
|
|
(new Common.Views.InsertTableDialog({
|
2017-08-07 09:23:03 +00:00
|
|
|
split: true,
|
2016-03-11 00:48:53 +00:00
|
|
|
handler: function(result, value) {
|
|
|
|
if (result == 'ok') {
|
|
|
|
if (me.api) {
|
|
|
|
me.api.SplitCell(value.columns, value.rows);
|
|
|
|
}
|
|
|
|
}
|
2017-08-23 08:02:04 +00:00
|
|
|
me.fireEvent('editcomplete', me);
|
2016-03-11 00:48:53 +00:00
|
|
|
}
|
|
|
|
})).show();
|
|
|
|
},
|
|
|
|
|
|
|
|
render: function () {
|
|
|
|
var el = $(this.el);
|
|
|
|
el.html(this.template({
|
|
|
|
scope: this
|
|
|
|
}));
|
|
|
|
},
|
|
|
|
|
|
|
|
setApi: function(o) {
|
|
|
|
this.api = o;
|
|
|
|
if (o) {
|
2021-09-24 15:25:11 +00:00
|
|
|
this.api.asc_registerCallback('asc_onInitTableTemplates', _.bind(this.onInitTableTemplates, this));
|
2022-02-15 10:30:50 +00:00
|
|
|
this.api.asc_registerCallback('asc_onBeginTableStylesPreview', _.bind(this.onBeginTableStylesPreview, this));
|
|
|
|
this.api.asc_registerCallback('asc_onAddTableStylesPreview', _.bind(this.onAddTableStylesPreview, this));
|
|
|
|
this.api.asc_registerCallback('asc_onEndTableStylesPreview', _.bind(this.onEndTableStylesPreview, this));
|
2016-03-11 00:48:53 +00:00
|
|
|
}
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2016-10-11 10:29:21 +00:00
|
|
|
createDelayedControls: function() {
|
|
|
|
var me = this;
|
|
|
|
|
2021-09-24 15:25:11 +00:00
|
|
|
this._tableTemplates && this._onInitTemplates();
|
2021-09-08 16:26:02 +00:00
|
|
|
|
2016-10-11 10:29:21 +00:00
|
|
|
this.chHeader = new Common.UI.CheckBox({
|
|
|
|
el: $('#table-checkbox-header'),
|
2021-06-16 13:43:51 +00:00
|
|
|
labelText: this.textHeader,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'left',
|
|
|
|
dataHintOffset: 'small'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
this.lockedControls.push(this.chHeader);
|
|
|
|
|
|
|
|
this.chTotal = new Common.UI.CheckBox({
|
|
|
|
el: $('#table-checkbox-total'),
|
2021-06-16 13:43:51 +00:00
|
|
|
labelText: this.textTotal,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'left',
|
|
|
|
dataHintOffset: 'small'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
this.lockedControls.push(this.chTotal);
|
|
|
|
|
|
|
|
this.chBanded = new Common.UI.CheckBox({
|
|
|
|
el: $('#table-checkbox-banded'),
|
2021-06-16 13:43:51 +00:00
|
|
|
labelText: this.textBanded,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'left',
|
|
|
|
dataHintOffset: 'small'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
this.lockedControls.push(this.chBanded);
|
|
|
|
|
|
|
|
this.chFirst = new Common.UI.CheckBox({
|
|
|
|
el: $('#table-checkbox-first'),
|
2021-06-16 13:43:51 +00:00
|
|
|
labelText: this.textFirst,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'left',
|
|
|
|
dataHintOffset: 'small'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
this.lockedControls.push(this.chFirst);
|
|
|
|
|
|
|
|
this.chLast = new Common.UI.CheckBox({
|
|
|
|
el: $('#table-checkbox-last'),
|
2021-06-16 13:43:51 +00:00
|
|
|
labelText: this.textLast,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'left',
|
|
|
|
dataHintOffset: 'small'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
this.lockedControls.push(this.chLast);
|
|
|
|
|
|
|
|
this.chColBanded = new Common.UI.CheckBox({
|
|
|
|
el: $('#table-checkbox-col-banded'),
|
2021-06-16 13:43:51 +00:00
|
|
|
labelText: this.textBanded,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'left',
|
|
|
|
dataHintOffset: 'small'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
this.lockedControls.push(this.chColBanded);
|
|
|
|
|
|
|
|
this.chHeader.on('change', _.bind(this.onCheckTemplateChange, this, 0));
|
|
|
|
this.chTotal.on('change', _.bind(this.onCheckTemplateChange, this, 1));
|
|
|
|
this.chBanded.on('change', _.bind(this.onCheckTemplateChange, this, 2));
|
|
|
|
this.chFirst.on('change', _.bind(this.onCheckTemplateChange, this, 3));
|
|
|
|
this.chLast.on('change', _.bind(this.onCheckTemplateChange, this, 4));
|
|
|
|
this.chColBanded.on('change', _.bind(this.onCheckTemplateChange, this, 5));
|
|
|
|
|
|
|
|
var _arrBorderPosition = [
|
2021-06-16 13:43:51 +00:00
|
|
|
['l', 'toolbar__icon btn-border-left', 'table-button-border-left', this.tipLeft, 'bottom'],
|
|
|
|
['c', 'toolbar__icon btn-border-insidevert', 'table-button-border-inner-vert', this.tipInnerVert, 'bottom'],
|
|
|
|
['r', 'toolbar__icon btn-border-right', 'table-button-border-right', this.tipRight, 'bottom'],
|
|
|
|
['t', 'toolbar__icon btn-border-top', 'table-button-border-top', this.tipTop, 'bottom'],
|
|
|
|
['m', 'toolbar__icon btn-border-insidehor', 'table-button-border-inner-hor', this.tipInnerHor, 'bottom'],
|
|
|
|
['b', 'toolbar__icon btn-border-bottom', 'table-button-border-bottom', this.tipBottom, 'bottom'],
|
|
|
|
['cm', 'toolbar__icon btn-border-inside', 'table-button-border-inner', this.tipInner, 'top'],
|
|
|
|
['lrtb', 'toolbar__icon btn-border-out', 'table-button-border-outer', this.tipOuter, 'top'],
|
|
|
|
['lrtbcm', 'toolbar__icon btn-border-all', 'table-button-border-all', this.tipAll, 'top'],
|
|
|
|
['', 'toolbar__icon btn-border-no', 'table-button-border-none', this.tipNone, 'top']
|
2016-10-11 10:29:21 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
this._btnsBorderPosition = [];
|
|
|
|
_.each(_arrBorderPosition, function(item, index, list){
|
|
|
|
var _btn = new Common.UI.Button({
|
2020-04-29 07:36:53 +00:00
|
|
|
parentEl: $('#'+item[2]),
|
2019-11-21 16:10:02 +00:00
|
|
|
cls: 'btn-toolbar borders--small',
|
2016-10-11 10:29:21 +00:00
|
|
|
iconCls: item[1],
|
|
|
|
strId :item[0],
|
2021-06-16 13:43:51 +00:00
|
|
|
hint: item[3],
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: item[4],
|
|
|
|
dataHintOffset: 'small'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
_btn.on('click', _.bind(this.onBtnBordersClick, this));
|
|
|
|
this._btnsBorderPosition.push( _btn );
|
|
|
|
this.lockedControls.push(_btn);
|
|
|
|
}, this);
|
|
|
|
|
|
|
|
this.cmbBorderSize = new Common.UI.ComboBorderSize({
|
|
|
|
el: $('#table-combo-border-size'),
|
2021-06-16 13:43:51 +00:00
|
|
|
style: "width: 93px;",
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'bottom',
|
|
|
|
dataHintOffset: 'big'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
this.BorderSize = this.cmbBorderSize.store.at(2).get('value');
|
|
|
|
this.cmbBorderSize.setValue(this.BorderSize);
|
|
|
|
this.cmbBorderSize.on('selected', _.bind(this.onBorderSizeSelect, this));
|
|
|
|
this.lockedControls.push(this.cmbBorderSize);
|
|
|
|
|
|
|
|
this.btnEdit = new Common.UI.Button({
|
2020-04-29 07:36:53 +00:00
|
|
|
parentEl: $('#table-btn-edit'),
|
2021-12-04 19:59:28 +00:00
|
|
|
cls : 'btn-toolbar align-left',
|
|
|
|
iconCls : 'toolbar__icon rows-and-columns',
|
|
|
|
caption : this.textEdit,
|
|
|
|
style : 'width: 100%;',
|
|
|
|
menu: new Common.UI.Menu({
|
2016-10-11 10:29:21 +00:00
|
|
|
menuAlign: 'tr-br',
|
|
|
|
items: [
|
|
|
|
{ caption: this.selectRowText, value: 0 },
|
|
|
|
{ caption: this.selectColumnText, value: 1 },
|
|
|
|
{ caption: this.selectCellText, value: 2 },
|
|
|
|
{ caption: this.selectTableText, value: 3 },
|
|
|
|
{ caption: '--' },
|
|
|
|
{ caption: this.insertRowAboveText, value: 4 },
|
|
|
|
{ caption: this.insertRowBelowText, value: 5 },
|
|
|
|
{ caption: this.insertColumnLeftText, value: 6 },
|
|
|
|
{ caption: this.insertColumnRightText, value: 7 },
|
|
|
|
{ caption: '--' },
|
|
|
|
{ caption: this.deleteRowText, value: 8 },
|
|
|
|
{ caption: this.deleteColumnText, value: 9 },
|
|
|
|
{ caption: this.deleteTableText, value: 10 },
|
|
|
|
{ caption: '--' },
|
|
|
|
{ caption: this.mergeCellsText, value: 11 },
|
|
|
|
{ caption: this.splitCellsText, value: 12 }
|
|
|
|
]
|
2021-06-16 13:43:51 +00:00
|
|
|
}),
|
2021-12-04 19:59:28 +00:00
|
|
|
dataHint : '1',
|
|
|
|
dataHintDirection: 'left',
|
|
|
|
dataHintOffset: 'small'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
this.mnuMerge = this.btnEdit.menu.items[this.btnEdit.menu.items.length-2];
|
|
|
|
this.mnuSplit = this.btnEdit.menu.items[this.btnEdit.menu.items.length-1];
|
|
|
|
|
|
|
|
this.btnEdit.menu.on('show:after', _.bind( function(){
|
|
|
|
if (this.api) {
|
|
|
|
this.mnuMerge.setDisabled(!this.api.CheckBeforeMergeCells());
|
|
|
|
this.mnuSplit.setDisabled(!this.api.CheckBeforeSplitCells());
|
|
|
|
}
|
|
|
|
}, this));
|
|
|
|
this.btnEdit.menu.on('item:click', _.bind(this.onEditClick, this));
|
|
|
|
this.lockedControls.push(this.btnEdit);
|
|
|
|
|
2018-02-06 12:06:01 +00:00
|
|
|
this.numHeight = new Common.UI.MetricSpinner({
|
|
|
|
el: $('#table-spin-cell-height'),
|
|
|
|
step: .1,
|
|
|
|
width: 115,
|
|
|
|
defaultUnit : "cm",
|
|
|
|
value: '1 cm',
|
|
|
|
maxValue: 55.88,
|
2021-06-16 13:43:51 +00:00
|
|
|
minValue: 0,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'bottom',
|
|
|
|
dataHintOffset: 'big'
|
2018-02-06 12:06:01 +00:00
|
|
|
});
|
|
|
|
this.numHeight.on('change', _.bind(function(field, newValue, oldValue, eOpts){
|
|
|
|
var _props = new Asc.CTableProp();
|
|
|
|
_props.put_RowHeight(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue()));
|
|
|
|
this.api.tblApply(_props);
|
|
|
|
}, this));
|
2019-12-06 08:35:17 +00:00
|
|
|
this.numHeight.on('inputleave', function(){ me.fireEvent('editcomplete', me);});
|
2018-02-06 12:06:01 +00:00
|
|
|
this.lockedControls.push(this.numHeight);
|
|
|
|
this.spinners.push(this.numHeight);
|
|
|
|
|
|
|
|
this.numWidth = new Common.UI.MetricSpinner({
|
|
|
|
el: $('#table-spin-cell-width'),
|
|
|
|
step: .1,
|
|
|
|
width: 115,
|
|
|
|
defaultUnit : "cm",
|
|
|
|
value: '1 cm',
|
|
|
|
maxValue: 55.88,
|
2021-06-16 13:43:51 +00:00
|
|
|
minValue: 0,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'bottom',
|
|
|
|
dataHintOffset: 'big'
|
2018-02-06 12:06:01 +00:00
|
|
|
});
|
|
|
|
this.numWidth.on('change', _.bind(function(field, newValue, oldValue, eOpts){
|
|
|
|
var _props = new Asc.CTableProp();
|
|
|
|
_props.put_ColumnWidth(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue()));
|
|
|
|
this.api.tblApply(_props);
|
|
|
|
}, this));
|
2019-12-06 08:35:17 +00:00
|
|
|
this.numWidth.on('inputleave', function(){ me.fireEvent('editcomplete', me);});
|
2018-02-06 12:06:01 +00:00
|
|
|
this.lockedControls.push(this.numWidth);
|
|
|
|
this.spinners.push(this.numWidth);
|
|
|
|
|
|
|
|
this.btnDistributeRows = new Common.UI.Button({
|
|
|
|
el: $('#table-btn-distrub-rows')
|
|
|
|
});
|
|
|
|
this.lockedControls.push(this.btnDistributeRows);
|
|
|
|
this.btnDistributeRows.on('click', _.bind(function(btn){
|
|
|
|
this.api.asc_DistributeTableCells(false);
|
|
|
|
}, this));
|
|
|
|
|
|
|
|
this.btnDistributeCols = new Common.UI.Button({
|
|
|
|
el: $('#table-btn-distrub-cols')
|
|
|
|
});
|
|
|
|
this.lockedControls.push(this.btnDistributeCols);
|
|
|
|
this.btnDistributeCols.on('click', _.bind(function(btn){
|
|
|
|
this.api.asc_DistributeTableCells(true);
|
|
|
|
}, this));
|
|
|
|
|
2016-10-11 10:29:21 +00:00
|
|
|
this.linkAdvanced = $('#table-advanced-link');
|
|
|
|
$(this.el).on('click', '#table-advanced-link', _.bind(this.openAdvancedSettings, this));
|
|
|
|
},
|
|
|
|
|
2016-03-11 00:48:53 +00:00
|
|
|
ChangeSettings: function(props) {
|
2016-10-11 10:29:21 +00:00
|
|
|
if (this._initSettings)
|
|
|
|
this.createDelayedElements();
|
2016-10-14 10:48:04 +00:00
|
|
|
|
2017-04-11 11:05:56 +00:00
|
|
|
this.disableControls(this._locked); // need to update combodataview after disabled state
|
2016-03-11 00:48:53 +00:00
|
|
|
|
|
|
|
if (props )
|
|
|
|
{
|
2016-04-05 12:57:51 +00:00
|
|
|
this._originalProps = new Asc.CTableProp(props);
|
2016-03-11 00:48:53 +00:00
|
|
|
this._originalProps.put_CellSelect(true);
|
|
|
|
|
2018-02-06 12:06:01 +00:00
|
|
|
var value = props.get_ColumnWidth();
|
|
|
|
if ((this._state.Width === undefined || value === undefined)&&(this._state.Width!==value) ||
|
|
|
|
Math.abs(this._state.Width-value)>0.001) {
|
|
|
|
this.numWidth.setValue((value !== null && value !== undefined) ? Common.Utils.Metric.fnRecalcFromMM(value) : '', true);
|
|
|
|
this._state.Width=value;
|
|
|
|
}
|
|
|
|
value = props.get_RowHeight();
|
|
|
|
if ((this._state.Height === undefined || value === undefined)&&(this._state.Height!==value) ||
|
|
|
|
Math.abs(this._state.Height-value)>0.001) {
|
|
|
|
this.numHeight.setValue((value !== null && value !== undefined) ? Common.Utils.Metric.fnRecalcFromMM(value) : '', true);
|
|
|
|
this._state.Height=value;
|
|
|
|
}
|
|
|
|
|
2016-03-11 00:48:53 +00:00
|
|
|
//for table-template
|
2018-02-06 12:06:01 +00:00
|
|
|
value = props.get_TableStyle();
|
2016-03-11 00:48:53 +00:00
|
|
|
if (this._state.TemplateId!==value || this._isTemplatesChanged) {
|
2019-12-13 14:18:11 +00:00
|
|
|
this._state.TemplateId = value;
|
2022-02-15 10:30:50 +00:00
|
|
|
var template = this.api.asc_getTableStylesPreviews(false, [this._state.TemplateId]);
|
|
|
|
if (template && template.length>0)
|
|
|
|
this.$el.find('.icon-template-table').css({'background-image': 'url(' + template[0].asc_getImage() + ')', 'height': '52px', 'width': '72px', 'background-position': 'center', 'background-size': 'auto 52px'});
|
|
|
|
this._state.currentStyleFound = false;
|
|
|
|
this.selectCurrentTableStyle();
|
2016-03-11 00:48:53 +00:00
|
|
|
}
|
|
|
|
this._isTemplatesChanged = false;
|
|
|
|
|
|
|
|
var look = props.get_TableLook();
|
|
|
|
if (look) {
|
|
|
|
value = look.get_FirstRow();
|
|
|
|
if (this._state.CheckHeader!==value) {
|
|
|
|
this.chHeader.setValue(value, true);
|
|
|
|
this._state.CheckHeader=value;
|
|
|
|
this._originalLook.put_FirstRow(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
value = look.get_LastRow();
|
|
|
|
if (this._state.CheckTotal!==value) {
|
|
|
|
this.chTotal.setValue(value, true);
|
|
|
|
this._state.CheckTotal=value;
|
|
|
|
this._originalLook.put_LastRow(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
value = look.get_BandHor();
|
|
|
|
if (this._state.CheckBanded!==value) {
|
|
|
|
this.chBanded.setValue(value, true);
|
|
|
|
this._state.CheckBanded=value;
|
|
|
|
this._originalLook.put_BandHor(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
value = look.get_FirstCol();
|
|
|
|
if (this._state.CheckFirst!==value) {
|
|
|
|
this.chFirst.setValue(value, true);
|
|
|
|
this._state.CheckFirst=value;
|
|
|
|
this._originalLook.put_FirstCol(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
value = look.get_LastCol();
|
|
|
|
if (this._state.CheckLast!==value) {
|
|
|
|
this.chLast.setValue(value, true);
|
|
|
|
this._state.CheckLast=value;
|
|
|
|
this._originalLook.put_LastCol(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
value = look.get_BandVer();
|
|
|
|
if (this._state.CheckColBanded!==value) {
|
|
|
|
this.chColBanded.setValue(value, true);
|
|
|
|
this._state.CheckColBanded=value;
|
|
|
|
this._originalLook.put_BandVer(value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// background colors
|
|
|
|
var background = props.get_CellsBackground();
|
|
|
|
if (background) {
|
|
|
|
if (background.get_Value()==0) {
|
|
|
|
var color = background.get_Color();
|
|
|
|
if (color) {
|
2016-04-05 11:52:34 +00:00
|
|
|
if (color.get_type() == Asc.c_oAscColor.COLOR_TYPE_SCHEME) {
|
2016-03-11 00:48:53 +00:00
|
|
|
this.CellColor = {Value: 1, Color: {color: Common.Utils.ThemeColor.getHexColor(color.get_r(), color.get_g(), color.get_b()), effectValue: color.get_value() }};
|
|
|
|
} else {
|
|
|
|
this.CellColor = {Value: 1, Color: Common.Utils.ThemeColor.getHexColor(color.get_r(), color.get_g(), color.get_b())};
|
|
|
|
}
|
|
|
|
} else
|
|
|
|
this.CellColor = {Value: 1, Color: 'transparent'};
|
|
|
|
} else
|
|
|
|
this.CellColor = {Value: 1, Color: 'transparent'};
|
|
|
|
} else
|
|
|
|
this.CellColor = {Value: 0, Color: 'transparent'};
|
|
|
|
|
|
|
|
var type1 = typeof(this.CellColor.Color),
|
|
|
|
type2 = typeof(this._state.BackColor);
|
|
|
|
if ( (type1 !== type2) || (type1=='object' &&
|
|
|
|
(this.CellColor.Color.effectValue!==this._state.BackColor.effectValue || this._state.BackColor.color.indexOf(this.CellColor.Color.color)<0)) ||
|
|
|
|
(type1!='object' && this._state.BackColor.indexOf(this.CellColor.Color)<0 )) {
|
|
|
|
|
|
|
|
this.btnBackColor.setColor(this.CellColor.Color);
|
|
|
|
if ( typeof(this.CellColor.Color) == 'object' ) {
|
|
|
|
var isselected = false;
|
|
|
|
for (var i=0; i<10; i++) {
|
|
|
|
if ( Common.Utils.ThemeColor.ThemeValues[i] == this.CellColor.Color.effectValue ) {
|
|
|
|
this.colorsBack.select(this.CellColor.Color,true);
|
|
|
|
isselected = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!isselected) this.colorsBack.clearSelection();
|
|
|
|
} else
|
|
|
|
this.colorsBack.select(this.CellColor.Color,true);
|
|
|
|
|
|
|
|
this._state.BackColor = this.CellColor.Color;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-02-06 12:06:01 +00:00
|
|
|
updateMetricUnit: function() {
|
|
|
|
if (this.spinners) {
|
|
|
|
for (var i=0; i<this.spinners.length; i++) {
|
|
|
|
var spinner = this.spinners[i];
|
|
|
|
spinner.setDefaultUnit(Common.Utils.Metric.getCurrentMetricName());
|
|
|
|
spinner.setStep(Common.Utils.Metric.getCurrentMetric()==Common.Utils.Metric.c_MetricUnits.pt ? 1 : 0.1);
|
|
|
|
}
|
2021-01-11 15:06:12 +00:00
|
|
|
var val = this._state.Width;
|
|
|
|
this.numWidth && this.numWidth.setValue((val !== null && val !== undefined) ? Common.Utils.Metric.fnRecalcFromMM(val) : '', true);
|
|
|
|
val = this._state.Height;
|
|
|
|
this.numHeight && this.numHeight.setValue((val !== null && val !== undefined) ? Common.Utils.Metric.fnRecalcFromMM(val) : '', true);
|
2018-02-06 12:06:01 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2016-03-11 00:48:53 +00:00
|
|
|
_UpdateBordersStyle: function(border) {
|
2016-04-05 12:57:51 +00:00
|
|
|
this.CellBorders = new Asc.CBorders();
|
2016-03-11 00:48:53 +00:00
|
|
|
var updateBorders = this.CellBorders;
|
|
|
|
|
|
|
|
var visible = (border != '');
|
|
|
|
|
|
|
|
if (border.indexOf('l') > -1 || !visible) {
|
|
|
|
if (updateBorders.get_Left()===null || updateBorders.get_Left()===undefined)
|
2016-04-18 12:21:15 +00:00
|
|
|
updateBorders.put_Left(new Asc.asc_CTextBorder());
|
2016-03-11 00:48:53 +00:00
|
|
|
this._UpdateBorderStyle (updateBorders.get_Left(), visible);
|
|
|
|
}
|
|
|
|
if (border.indexOf('t') > -1 || !visible) {
|
|
|
|
if (updateBorders.get_Top()===null || updateBorders.get_Top()===undefined)
|
2016-04-18 12:21:15 +00:00
|
|
|
updateBorders.put_Top(new Asc.asc_CTextBorder());
|
2016-03-11 00:48:53 +00:00
|
|
|
this._UpdateBorderStyle (updateBorders.get_Top(), visible);
|
|
|
|
}
|
|
|
|
if (border.indexOf('r') > -1 || !visible) {
|
|
|
|
if (updateBorders.get_Right()===null || updateBorders.get_Right()===undefined)
|
2016-04-18 12:21:15 +00:00
|
|
|
updateBorders.put_Right(new Asc.asc_CTextBorder());
|
2016-03-11 00:48:53 +00:00
|
|
|
this._UpdateBorderStyle (updateBorders.get_Right(), visible);
|
|
|
|
}
|
|
|
|
if (border.indexOf('b') > -1 || !visible) {
|
|
|
|
if (updateBorders.get_Bottom()===null || updateBorders.get_Bottom()===undefined)
|
2016-04-18 12:21:15 +00:00
|
|
|
updateBorders.put_Bottom(new Asc.asc_CTextBorder());
|
2016-03-11 00:48:53 +00:00
|
|
|
this._UpdateBorderStyle (updateBorders.get_Bottom(), visible);
|
|
|
|
}
|
|
|
|
if (border.indexOf('c') > -1 || !visible) {
|
|
|
|
if (updateBorders.get_InsideV()===null || updateBorders.get_InsideV()===undefined)
|
2016-04-18 12:21:15 +00:00
|
|
|
updateBorders.put_InsideV(new Asc.asc_CTextBorder());
|
2016-03-11 00:48:53 +00:00
|
|
|
this._UpdateBorderStyle (updateBorders.get_InsideV(), visible);
|
|
|
|
}
|
|
|
|
if (border.indexOf('m') > -1 || !visible) {
|
|
|
|
if (updateBorders.get_InsideH()===null || updateBorders.get_InsideH()===undefined)
|
2016-04-18 12:21:15 +00:00
|
|
|
updateBorders.put_InsideH(new Asc.asc_CTextBorder());
|
2016-03-11 00:48:53 +00:00
|
|
|
this._UpdateBorderStyle (updateBorders.get_InsideH(), visible);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
_UpdateBorderStyle: function(border, visible) {
|
|
|
|
if (null == border)
|
2016-04-18 12:21:15 +00:00
|
|
|
border = new Asc.asc_CTextBorder();
|
2016-03-11 00:48:53 +00:00
|
|
|
|
|
|
|
if (visible && this.BorderSize > 0){
|
|
|
|
var size = parseFloat(this.BorderSize);
|
|
|
|
border.put_Value(1);
|
|
|
|
border.put_Size(size * 25.4 / 72.0);
|
|
|
|
var color = Common.Utils.ThemeColor.getRgbColor(this.btnBorderColor.color);
|
|
|
|
border.put_Color(color);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
border.put_Value(0);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2016-10-11 10:29:21 +00:00
|
|
|
createDelayedElements: function() {
|
2019-08-22 10:38:13 +00:00
|
|
|
this._initSettings = false;
|
2016-10-11 10:29:21 +00:00
|
|
|
this.createDelayedControls();
|
|
|
|
this.UpdateThemeColors();
|
2018-02-06 12:06:01 +00:00
|
|
|
this.updateMetricUnit();
|
2016-10-11 10:29:21 +00:00
|
|
|
},
|
|
|
|
|
2016-03-11 00:48:53 +00:00
|
|
|
UpdateThemeColors: function() {
|
2019-08-22 10:38:13 +00:00
|
|
|
if (this._initSettings) return;
|
2016-10-11 10:29:21 +00:00
|
|
|
if (!this.btnBackColor) {
|
|
|
|
this.btnBorderColor = new Common.UI.ColorButton({
|
2020-04-30 12:11:03 +00:00
|
|
|
parentEl: $('#table-border-color-btn'),
|
2021-01-20 13:42:48 +00:00
|
|
|
color: 'auto',
|
2021-06-16 13:43:51 +00:00
|
|
|
auto: true,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'bottom',
|
|
|
|
dataHintOffset: 'big'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
|
|
|
this.lockedControls.push(this.btnBorderColor);
|
2020-04-29 17:32:18 +00:00
|
|
|
this.borderColor = this.btnBorderColor.getPicker();
|
2016-10-11 10:29:21 +00:00
|
|
|
|
|
|
|
this.btnBackColor = new Common.UI.ColorButton({
|
2020-04-29 17:32:18 +00:00
|
|
|
parentEl: $('#table-back-color-btn'),
|
2021-06-16 13:43:51 +00:00
|
|
|
transparent: true,
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'bottom',
|
|
|
|
dataHintOffset: 'big'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
2020-04-29 17:32:18 +00:00
|
|
|
this.lockedControls.push(this.btnBackColor);
|
|
|
|
this.colorsBack = this.btnBackColor.getPicker();
|
|
|
|
this.btnBackColor.on('color:select', _.bind(this.onColorsBackSelect, this));
|
2016-08-18 07:58:30 +00:00
|
|
|
}
|
2016-10-11 10:29:21 +00:00
|
|
|
this.colorsBack.updateColors(Common.Utils.ThemeColor.getEffectColors(), Common.Utils.ThemeColor.getStandartColors());
|
|
|
|
this.borderColor.updateColors(Common.Utils.ThemeColor.getEffectColors(), Common.Utils.ThemeColor.getStandartColors());
|
2021-01-20 13:42:48 +00:00
|
|
|
!this.btnBorderColor.isAutoColor() && this.btnBorderColor.setColor(this.borderColor.getColor());
|
2016-03-11 00:48:53 +00:00
|
|
|
},
|
|
|
|
|
2022-02-15 10:30:50 +00:00
|
|
|
selectCurrentTableStyle: function() {
|
|
|
|
if (!this.mnuTableTemplatePicker || this._state.beginPreviewStyles) return;
|
|
|
|
|
|
|
|
var rec = this.mnuTableTemplatePicker.store.findWhere({
|
|
|
|
templateId: this._state.TemplateId
|
|
|
|
});
|
|
|
|
if (!rec && this._state.previewStylesCount===this.mnuTableTemplatePicker.store.length) {
|
|
|
|
rec = this.mnuTableTemplatePicker.store.at(0);
|
|
|
|
}
|
|
|
|
if (rec) {
|
|
|
|
this._state.currentStyleFound = true;
|
|
|
|
this.btnTableTemplate.suspendEvents();
|
|
|
|
this.mnuTableTemplatePicker.selectRecord(rec, true);
|
|
|
|
this.btnTableTemplate.resumeEvents();
|
|
|
|
this.$el.find('.icon-template-table').css({'background-image': 'url(' + rec.get("imageUrl") + ')', 'height': '52px', 'width': '72px', 'background-position': 'center', 'background-size': 'auto 52px'});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
onBeginTableStylesPreview: function(count){
|
|
|
|
this._state.beginPreviewStyles = true;
|
|
|
|
this._state.currentStyleFound = false;
|
|
|
|
this._state.previewStylesCount = count;
|
|
|
|
},
|
|
|
|
|
|
|
|
onEndTableStylesPreview: function(){
|
|
|
|
!this._state.currentStyleFound && this.selectCurrentTableStyle();
|
|
|
|
if (this.mnuTableTemplatePicker) {
|
|
|
|
this.mnuTableTemplatePicker.scroller.update({alwaysVisibleY: true});
|
|
|
|
if (this.mnuTableTemplatePicker.isVisible())
|
|
|
|
this.mnuTableTemplatePicker.scrollToRecord(this.mnuTableTemplatePicker.getSelectedRec());
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
onAddTableStylesPreview: function(Templates){
|
|
|
|
var self = this;
|
2022-07-31 00:08:52 +00:00
|
|
|
var templates = [];
|
|
|
|
var groups = [
|
|
|
|
{id: 'menu-table-group-custom', caption: self.txtGroupTable_Custom, templates: []},
|
|
|
|
{id: 'menu-table-group-optimal', caption: self.txtGroupTable_Optimal, templates: []},
|
|
|
|
{id: 'menu-table-group-light', caption: self.txtGroupTable_Light, templates: []},
|
|
|
|
{id: 'menu-table-group-medium', caption: self.txtGroupTable_Medium, templates: []},
|
|
|
|
{id: 'menu-table-group-dark', caption: self.txtGroupTable_Dark, templates: []},
|
|
|
|
{id: 'menu-table-group-no-name', caption: ' ', templates: []},
|
|
|
|
];
|
|
|
|
|
|
|
|
self.mnuTableTemplatePicker.store.models.forEach(function(template) {
|
|
|
|
groups.filter(function(item){ return item.id == template.attributes.group; })[0].templates.push(template);
|
|
|
|
});
|
2022-02-15 10:30:50 +00:00
|
|
|
_.each(Templates, function(template){
|
|
|
|
var tip = template.asc_getDisplayName();
|
2022-07-31 00:08:52 +00:00
|
|
|
var groupItem = '';
|
|
|
|
|
2022-02-15 10:30:50 +00:00
|
|
|
if (template.asc_getType()==0) {
|
2022-07-31 00:08:52 +00:00
|
|
|
var arr = tip.split(' ');
|
|
|
|
|
|
|
|
if(new RegExp('No Style|Themed Style', 'i').test(tip)){
|
|
|
|
groupItem = 'menu-table-group-optimal';
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
if(arr[0]){
|
|
|
|
groupItem = 'menu-table-group-' + arr[0].toLowerCase();
|
|
|
|
}
|
|
|
|
if(groups.some(function(item) {return item.id === groupItem;}) == false) {
|
|
|
|
groupItem = 'menu-table-group-no-name';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-15 10:30:50 +00:00
|
|
|
['No Style', 'No Grid', 'Table Grid', 'Themed Style', 'Light Style', 'Medium Style', 'Dark Style', 'Accent'].forEach(function(item){
|
|
|
|
var str = 'txtTable_' + item.replace(' ', '');
|
|
|
|
if (self[str])
|
|
|
|
tip = tip.replace(new RegExp(item, 'g'), self[str]);
|
|
|
|
});
|
|
|
|
}
|
2022-07-31 00:08:52 +00:00
|
|
|
else {
|
|
|
|
groupItem = 'menu-table-group-custom'
|
|
|
|
}
|
|
|
|
|
|
|
|
groups.filter(function(item){ return item.id == groupItem; })[0].templates.push({
|
2022-02-15 10:30:50 +00:00
|
|
|
imageUrl: template.asc_getImage(),
|
|
|
|
id : Common.UI.getId(),
|
|
|
|
templateId: template.asc_getId(),
|
2022-07-31 00:08:52 +00:00
|
|
|
group : groupItem,
|
2022-02-15 10:30:50 +00:00
|
|
|
tip : tip
|
|
|
|
});
|
|
|
|
});
|
2022-07-31 00:08:52 +00:00
|
|
|
|
|
|
|
groups = groups.filter(function(item, index){
|
|
|
|
return item.templates.length > 0
|
|
|
|
});
|
|
|
|
|
|
|
|
groups.forEach(function(item){
|
|
|
|
templates = templates.concat(item.templates);
|
|
|
|
delete item.templates;
|
|
|
|
});
|
|
|
|
|
2022-02-15 10:30:50 +00:00
|
|
|
if (this._state.beginPreviewStyles) {
|
|
|
|
this._state.beginPreviewStyles = false;
|
2022-07-31 00:08:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
self.mnuTableTemplatePicker && self.mnuTableTemplatePicker.groups.reset(groups);
|
|
|
|
self.mnuTableTemplatePicker && self.mnuTableTemplatePicker.store.reset(templates);
|
2022-02-15 10:30:50 +00:00
|
|
|
!this._state.currentStyleFound && this.selectCurrentTableStyle();
|
|
|
|
},
|
|
|
|
|
2021-09-24 15:25:11 +00:00
|
|
|
onInitTableTemplates: function(){
|
2021-09-08 16:26:02 +00:00
|
|
|
if (this._initSettings) {
|
2021-09-24 15:25:11 +00:00
|
|
|
this._tableTemplates = true;
|
2021-09-08 16:26:02 +00:00
|
|
|
return;
|
|
|
|
}
|
2021-09-24 15:25:11 +00:00
|
|
|
this._onInitTemplates();
|
|
|
|
},
|
2021-09-08 16:26:02 +00:00
|
|
|
|
2021-09-24 15:25:11 +00:00
|
|
|
_onInitTemplates: function(){
|
2016-03-11 00:48:53 +00:00
|
|
|
var self = this;
|
|
|
|
this._isTemplatesChanged = true;
|
|
|
|
|
2019-12-13 14:18:11 +00:00
|
|
|
if (!this.btnTableTemplate) {
|
|
|
|
this.btnTableTemplate = new Common.UI.Button({
|
|
|
|
cls : 'btn-large-dataview template-table',
|
|
|
|
iconCls : 'icon-template-table',
|
|
|
|
menu : new Common.UI.Menu({
|
2021-08-13 20:46:06 +00:00
|
|
|
style: 'width: 588px;',
|
2019-12-13 14:18:11 +00:00
|
|
|
items: [
|
|
|
|
{ template: _.template('<div id="id-table-menu-template" class="menu-table-template" style="margin: 5px 5px 5px 10px;"></div>') }
|
|
|
|
]
|
2021-06-16 13:43:51 +00:00
|
|
|
}),
|
|
|
|
dataHint: '1',
|
|
|
|
dataHintDirection: 'bottom',
|
|
|
|
dataHintOffset: 'big'
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
2019-12-13 14:18:11 +00:00
|
|
|
this.btnTableTemplate.on('render:after', function(btn) {
|
|
|
|
self.mnuTableTemplatePicker = new Common.UI.DataView({
|
|
|
|
el: $('#id-table-menu-template'),
|
|
|
|
parentMenu: btn.menu,
|
|
|
|
restoreHeight: 350,
|
|
|
|
groups: new Common.UI.DataViewGroupStore(),
|
|
|
|
store: new Common.UI.DataViewStore(),
|
2021-08-13 20:46:06 +00:00
|
|
|
itemTemplate: _.template('<div id="<%= id %>" class="item"><img src="<%= imageUrl %>" height="52" width="72"></div>'),
|
2021-09-08 15:42:05 +00:00
|
|
|
style: 'max-height: 350px;',
|
|
|
|
delayRenderTips: true
|
2019-12-13 14:18:11 +00:00
|
|
|
});
|
2016-10-11 10:29:21 +00:00
|
|
|
});
|
2019-12-13 14:18:11 +00:00
|
|
|
this.btnTableTemplate.render($('#table-btn-template'));
|
2022-02-15 10:30:50 +00:00
|
|
|
this.btnTableTemplate.cmpEl.find('.icon-template-table').css({'height': '52px', 'width': '72px', 'background-position': 'center', 'background-size': 'auto 52px'});
|
2019-12-13 14:18:11 +00:00
|
|
|
this.lockedControls.push(this.btnTableTemplate);
|
|
|
|
this.mnuTableTemplatePicker.on('item:click', _.bind(this.onTableTemplateSelect, this, this.btnTableTemplate));
|
2016-10-11 10:29:21 +00:00
|
|
|
}
|
2022-02-15 10:30:50 +00:00
|
|
|
this.api.asc_generateTableStylesPreviews();
|
2016-03-11 00:48:53 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
openAdvancedSettings: function(e) {
|
|
|
|
if (this.linkAdvanced.hasClass('disabled')) return;
|
|
|
|
|
|
|
|
var me = this;
|
|
|
|
if (me.api && !this._locked){
|
|
|
|
var selectedElements = me.api.getSelectedElements();
|
|
|
|
if (selectedElements && selectedElements.length>0){
|
|
|
|
var elType, elValue;
|
|
|
|
for (var i = selectedElements.length - 1; i >= 0; i--) {
|
|
|
|
elType = selectedElements[i].get_ObjectType();
|
|
|
|
elValue = selectedElements[i].get_ObjectValue();
|
2016-04-05 11:52:34 +00:00
|
|
|
if (Asc.c_oAscTypeSelectElement.Table == elType) {
|
2016-03-11 00:48:53 +00:00
|
|
|
(new PE.Views.TableSettingsAdvanced(
|
|
|
|
{
|
|
|
|
tableProps: elValue,
|
2022-01-28 14:01:31 +00:00
|
|
|
slideSize: PE.getController('Toolbar').currentPageSize,
|
2016-03-11 00:48:53 +00:00
|
|
|
handler: function(result, value) {
|
|
|
|
if (result == 'ok') {
|
|
|
|
if (me.api) {
|
|
|
|
me.api.tblApply(value.tableProps);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
me.fireEvent('editcomplete', me);
|
|
|
|
}
|
|
|
|
})).show();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
setLocked: function (locked) {
|
|
|
|
this._locked = locked;
|
|
|
|
},
|
|
|
|
|
|
|
|
disableControls: function(disable) {
|
2016-10-11 10:29:21 +00:00
|
|
|
if (this._initSettings) return;
|
|
|
|
|
2016-03-11 00:48:53 +00:00
|
|
|
if (this._state.DisabledControls!==disable) {
|
|
|
|
this._state.DisabledControls = disable;
|
|
|
|
_.each(this.lockedControls, function(item) {
|
|
|
|
item.setDisabled(disable);
|
|
|
|
});
|
2022-02-15 10:30:50 +00:00
|
|
|
this.linkAdvanced && this.linkAdvanced.toggleClass('disabled', disable);
|
2016-03-11 00:48:53 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
textBorders: 'Border\'s Style',
|
|
|
|
textBorderColor: 'Color',
|
|
|
|
textBackColor: 'Background color',
|
|
|
|
textEdit: 'Rows & Columns',
|
|
|
|
selectRowText : 'Select Row',
|
|
|
|
selectColumnText : 'Select Column',
|
|
|
|
selectCellText : 'Select Cell',
|
|
|
|
selectTableText : 'Select Table',
|
|
|
|
insertRowAboveText : 'Insert Row Above',
|
|
|
|
insertRowBelowText : 'Insert Row Below',
|
|
|
|
insertColumnLeftText : 'Insert Column Left',
|
|
|
|
insertColumnRightText : 'Insert Column Right',
|
|
|
|
deleteRowText : 'Delete Row',
|
|
|
|
deleteColumnText : 'Delete Column',
|
|
|
|
deleteTableText : 'Delete Table',
|
|
|
|
mergeCellsText : 'Merge Cells',
|
|
|
|
splitCellsText : 'Split Cell...',
|
|
|
|
splitCellTitleText : 'Split Cell',
|
|
|
|
textSelectBorders : 'Select borders that you want to change',
|
|
|
|
textAdvanced : 'Show advanced settings',
|
|
|
|
txtNoBorders : 'No borders',
|
|
|
|
textTemplate : 'Select From Template',
|
|
|
|
textRows : 'Rows',
|
|
|
|
textColumns : 'Columns',
|
|
|
|
textHeader : 'Header',
|
|
|
|
textTotal : 'Total',
|
|
|
|
textBanded : 'Banded',
|
|
|
|
textFirst : 'First',
|
|
|
|
textLast : 'Last',
|
|
|
|
textEmptyTemplate : 'No templates',
|
|
|
|
tipTop: 'Set Outer Top Border Only',
|
|
|
|
tipLeft: 'Set Outer Left Border Only',
|
|
|
|
tipBottom: 'Set Outer Bottom Border Only',
|
|
|
|
tipRight: 'Set Outer Right Border Only',
|
|
|
|
tipAll: 'Set Outer Border and All Inner Lines',
|
|
|
|
tipNone: 'Set No Borders',
|
|
|
|
tipInner: 'Set Inner Lines Only',
|
|
|
|
tipInnerVert: 'Set Vertical Inner Lines Only',
|
|
|
|
tipInnerHor: 'Set Horizontal Inner Lines Only',
|
2018-02-06 12:06:01 +00:00
|
|
|
tipOuter: 'Set Outer Border Only',
|
|
|
|
textCellSize: 'Cell Size',
|
|
|
|
textHeight: 'Height',
|
|
|
|
textWidth: 'Width',
|
|
|
|
textDistributeRows: 'Distribute rows',
|
2019-09-20 08:12:02 +00:00
|
|
|
textDistributeCols: 'Distribute columns',
|
|
|
|
txtTable_NoStyle: 'No Style',
|
|
|
|
txtTable_NoGrid: 'No Grid',
|
|
|
|
txtTable_TableGrid: 'Table Grid',
|
|
|
|
txtTable_ThemedStyle: 'Themed Style',
|
|
|
|
txtTable_LightStyle: 'Light Style',
|
|
|
|
txtTable_MediumStyle: 'Medium Style',
|
|
|
|
txtTable_DarkStyle: 'Dark Style',
|
2022-07-31 00:08:52 +00:00
|
|
|
txtTable_Accent: 'Accent',
|
|
|
|
txtGroupTable_Custom: 'Custom',
|
|
|
|
txtGroupTable_Optimal: 'Best Match for Document',
|
|
|
|
txtGroupTable_Light: 'Light',
|
|
|
|
txtGroupTable_Medium: 'Medium',
|
|
|
|
txtGroupTable_Dark: 'Dark',
|
2019-09-20 08:12:02 +00:00
|
|
|
|
|
|
|
}, PE.Views.TableSettings || {}));
|
2016-03-11 00:48:53 +00:00
|
|
|
});
|