web-apps/apps/spreadsheeteditor/main/app/view/Statusbar.js

1125 lines
51 KiB
JavaScript
Raw Normal View History

2016-04-01 13:17:09 +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
*
* 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
/**
* StatusBar View
*
* Created by Maxim Kadushkin on 27 March 2014
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!spreadsheeteditor/main/app/template/StatusBar.template',
'tip',
'common/main/lib/component/TabBar',
'common/main/lib/component/Menu',
'common/main/lib/component/Window',
'common/main/lib/component/ThemeColorPalette'
],
function(template){
'use strict';
if (SSE.Views.Statusbar) {
var RenameDialog = SSE.Views.Statusbar.RenameDialog;
var CopyDialog = SSE.Views.Statusbar.CopyDialog;
}
SSE.Views.Statusbar = Common.UI.BaseView.extend(_.extend({
el: '#statusbar',
template: _.template(template),
events: function() {
return {
'click #status-btn-tabfirst': _.bind(this.onBtnTabScroll, this, 'first'),
'click #status-btn-tabback': _.bind(this.onBtnTabScroll, this, 'backward'),
'click #status-btn-tabnext': _.bind(this.onBtnTabScroll, this, 'forward'),
'click #status-btn-tablast': _.bind(this.onBtnTabScroll, this, 'last')
};
},
api: undefined,
initialize: function (options) {
_.extend(this, options);
},
render: function () {
var me = this;
$(this.el).html(this.template({
scope: this
}));
this.editMode = false;
2019-10-15 09:36:27 +00:00
this.rangeSelectionMode = Asc.c_oAscSelectionDialogType.None;
2016-03-11 00:48:53 +00:00
this.btnZoomDown = new Common.UI.Button({
el: $('#status-btn-zoomdown',this.el),
hint: this.tipZoomOut+' (Ctrl+-)',
hintAnchor: 'top'
});
this.btnZoomUp = new Common.UI.Button({
el: $('#status-btn-zoomup',this.el),
hint: this.tipZoomIn+' (Ctrl++)',
hintAnchor: 'top-right'
});
this.btnScrollFirst = new Common.UI.Button({
el: $('#status-btn-tabfirst',this.el),
hint: this.tipFirst,
disabled: true,
hintAnchor: 'top'
});
this.btnScrollBack = new Common.UI.Button({
el: $('#status-btn-tabback',this.el),
hint: this.tipPrev,
disabled: true,
hintAnchor: 'top'
});
this.btnScrollNext = new Common.UI.Button({
el: $('#status-btn-tabnext',this.el),
hint: this.tipNext,
disabled: true,
hintAnchor: 'top'
});
this.btnScrollLast = new Common.UI.Button({
el: $('#status-btn-tablast',this.el),
hint: this.tipLast,
disabled: true,
hintAnchor: 'top'
});
this.btnAddWorksheet = new Common.UI.Button({
el: $('#status-btn-addtab',this.el),
hint: this.tipAddTab,
disabled: true,
hintAnchor: 'top'
});
this.cntSheetList = new Common.UI.Button({
2021-06-26 13:16:33 +00:00
el: $('.cnt-tabslist', this.el),
hint: this.tipListOfSheets,
hintAnchor: 'top'
});
this.btnSheetList = $('#status-btn-tabslist',this.$el);
2021-06-26 13:16:33 +00:00
this.sheetListMenu = new Common.UI.Menu({
style: 'margin-top:-3px;',
menuAlign: 'bl-tl',
maxHeight: 300
});
this.sheetListMenu.on('item:click', function(obj,item) {
me.fireEvent('show:tab', [item.value]);
});
this.cntSheetList.cmpEl.on({
2021-06-26 13:16:33 +00:00
'show.bs.dropdown': function () {
_.defer(function(){
me.cntSheetList.cmpEl.find('ul').focus();
2021-06-26 13:16:33 +00:00
}, 100);
},
'hide.bs.dropdown': function () {
_.defer(function(){
me.api.asc_enableKeyEvents(true);
}, 100);
}
});
this.sheetListMenu.render($('.cnt-tabslist',this.el));
this.sheetListMenu.cmpEl.attr({tabindex: -1});
2016-03-11 00:48:53 +00:00
this.cntZoom = new Common.UI.Button({
el: $('.cnt-zoom',this.el),
hint: this.tipZoomFactor,
hintAnchor: 'top'
});
this.cntZoom.cmpEl.on({
'show.bs.dropdown': function () {
_.defer(function(){
me.cntZoom.cmpEl.find('ul').focus();
}, 100);
},
'hide.bs.dropdown': function () {
_.defer(function(){
me.api.asc_enableKeyEvents(true);
}, 100);
}
});
this.zoomMenu = new Common.UI.Menu({
style: 'margin-top:-5px;',
menuAlign: 'bl-tl',
items: [
{ caption: "50%", value: 50 },
{ caption: "75%", value: 75 },
{ caption: "100%", value: 100 },
{ caption: "125%", value: 125 },
{ caption: "150%", value: 150 },
{ caption: "175%", value: 175 },
{ caption: "200%", value: 200 }
]
});
this.zoomMenu.render($('.cnt-zoom',this.el));
this.zoomMenu.cmpEl.attr({tabindex: -1});
this.labelZoom = $('#status-label-zoom',this.$el);
this.tabBarBox = $('#status-sheets-bar-box', this.el);
this.tabbar = new Common.UI.TabBar({
el: '#status-sheets-bar',
placement: 'bottom',
draggable: false
}).render();
this.tabbar.on({
'tab:invisible' : _.bind(this.onTabInvisible, this),
'tab:changed' : _.bind(this.onSheetChanged, this),
//'tab:manual' : _.bind(this.onAddTabClick, this),
'tab:contextmenu' : _.bind(this.onTabMenu, this),
'tab:dblclick' : _.bind(function () {
2021-02-16 11:49:13 +00:00
if (me.editMode && !(me.mode && me.mode.isDisconnected) && (me.rangeSelectionMode !== Asc.c_oAscSelectionDialogType.Chart) &&
(me.rangeSelectionMode !== Asc.c_oAscSelectionDialogType.FormatTable)&&
(me.rangeSelectionMode !== Asc.c_oAscSelectionDialogType.PrintTitles)) {
2016-03-11 00:48:53 +00:00
me.fireEvent('sheet:changename');
}
}, this),
2019-10-01 08:49:43 +00:00
'tab:move' : _.bind(function (selectTabs, index) {
2016-03-11 00:48:53 +00:00
me.tabBarScroll = {scrollLeft: me.tabbar.scrollX};
if (_.isUndefined(selectTabs) || _.isUndefined(index) || (selectTabs && selectTabs.length === 1 && selectTabs[0] === index)) {
2016-03-11 00:48:53 +00:00
return;
}
2019-10-01 08:49:43 +00:00
if (_.isArray(selectTabs)) {
me.fireEvent('sheet:move', [selectTabs, false, true, undefined, index]);
} else {
var tabIndex = selectTabs;
2016-03-11 00:48:53 +00:00
2019-10-01 08:49:43 +00:00
if (tabIndex < index) {
++index;
}
2016-03-11 00:48:53 +00:00
2019-10-01 08:49:43 +00:00
me.fireEvent('sheet:move', [undefined, false, true, tabIndex, index]);
}
2016-03-11 00:48:53 +00:00
2019-12-12 11:35:57 +00:00
}, this),
2020-02-18 11:43:56 +00:00
'tab:dragstart': _.bind(function (dataTransfer, selectTabs) {
Common.Utils.isIE && (this.isDrop = false);
2020-09-03 17:08:47 +00:00
Common.UI.Menu.Manager.hideAll();
2020-02-25 09:05:23 +00:00
this.api.asc_closeCellEditor();
2020-02-13 09:09:05 +00:00
var arrTabs = [],
2020-01-14 08:53:55 +00:00
arrName = [],
me = this;
2020-02-13 09:09:05 +00:00
var wc = me.api.asc_getWorksheetsCount(), items = [], i = -1;
while (++i < wc) {
if (!this.api.asc_isWorksheetHidden(i)) {
items.push({
value: me.api.asc_getWorksheetName(i),
inindex: i
});
}
}
var arrSelectIndex = [];
selectTabs.forEach(function (item) {
arrSelectIndex.push(item.sheetindex);
});
items.forEach(function (item) {
if (arrSelectIndex.indexOf(item.inindex) !== -1) {
arrTabs.push(item.inindex);
arrName.push(item.value);
}
2020-01-13 08:36:22 +00:00
});
2020-02-18 11:43:56 +00:00
var stringSheet, arr = [];
stringSheet = this.api.asc_StartMoveSheet(_.clone(arrTabs));
arr.push({type: 'onlyoffice', value: stringSheet});
arr.push({type: 'indexes', value: arrTabs});
arr.push({type: 'names', value: arrName});
arr.push({type: 'key', value: Common.Utils.InternalSettings.get("sse-doc-info-key")});
var json = JSON.stringify(arr);
if (!Common.Utils.isIE) {
dataTransfer.setData('onlyoffice', json);
} else {
dataTransfer.setData('text', 'sheet');
this.dataTransfer = json;
}
2020-02-18 11:43:56 +00:00
this.dropTabs = selectTabs;
2019-12-12 11:35:57 +00:00
}, this),
2020-02-18 11:43:56 +00:00
'tab:drop': _.bind(function (dataTransfer, index) {
if (this.isEditFormula || (Common.Utils.isIE && this.dataTransfer === undefined)) return;
Common.Utils.isIE && (this.isDrop = true);
var data = !Common.Utils.isIE ? dataTransfer.getData('onlyoffice') : this.dataTransfer;
2020-02-18 11:43:56 +00:00
if (data) {
var arrData = JSON.parse(data);
2020-02-25 09:05:23 +00:00
if (arrData) {
2020-02-18 11:43:56 +00:00
var key = _.findWhere(arrData, {type: 'key'}).value;
if (Common.Utils.InternalSettings.get("sse-doc-info-key") === key) {
2020-08-25 12:04:12 +00:00
this.api.asc_moveWorksheet(_.isNumber(index) ? index : this.api.asc_getWorksheetsCount(), _.findWhere(arrData, {type: 'indexes'}).value);
2020-08-05 18:16:17 +00:00
this.api.asc_enableKeyEvents(true);
Common.NotificationCenter.trigger('tabs:dragend', this);
2020-02-18 11:43:56 +00:00
} else {
var names = [], wc = this.api.asc_getWorksheetsCount();
while (wc--) {
names.push(this.api.asc_getWorksheetName(wc).toLowerCase());
}
var newNames = [];
var arrNames = _.findWhere(arrData, {type: 'names'}).value;
arrNames.forEach(function (name) {
2020-08-06 11:51:59 +00:00
var ind = 1,
2020-02-18 11:43:56 +00:00
name = name;
2020-08-06 11:51:59 +00:00
var re = /^(.*)\((\d)\)$/.exec(name);
var first = re ? re[1] : name + ' ';
var arr = [];
newNames.length > 0 && newNames.forEach(function (item) {
arr.push(item.toLowerCase());
});
while (names.indexOf(name.toLowerCase()) !== -1 || arr.indexOf(name.toLowerCase()) !== -1) {
ind++;
name = first + '(' + ind + ')';
2020-02-18 11:43:56 +00:00
}
2020-08-06 11:51:59 +00:00
newNames.push(name);
2020-02-18 11:43:56 +00:00
});
2020-08-31 11:29:07 +00:00
var index = _.isNumber(index) ? index : this.api.asc_getWorksheetsCount();
2020-02-18 11:43:56 +00:00
this.api.asc_EndMoveSheet(index, newNames, _.findWhere(arrData, {type: 'onlyoffice'}).value);
}
}
}
}, this),
'tab:dragend': _.bind(function (cut) {
if (cut && !(Common.Utils.isIE && this.isDrop === false)) {
2020-02-18 11:43:56 +00:00
if (this.dropTabs.length > 0) {
var arr = [];
this.dropTabs.forEach(function (tab) {
arr.push(tab.sheetindex);
});
me.api.asc_deleteWorksheet(arr);
2020-02-13 09:09:05 +00:00
}
2020-01-24 11:26:16 +00:00
}
2020-02-18 11:43:56 +00:00
this.dropTabs = undefined;
if (Common.Utils.isIE) {
this.isDrop = undefined;
this.dataTransfer = undefined;
}
Common.NotificationCenter.trigger('tabs:dragend', this);
2016-03-11 00:48:53 +00:00
}, this)
});
var menuHiddenItems = new Common.UI.Menu({
2016-11-10 07:19:17 +00:00
maxHeight: 260,
2016-03-11 00:48:53 +00:00
menuAlign: 'tl-tr'
2016-11-10 07:19:17 +00:00
}).on('show:after', function () {
this.scroller.update({alwaysVisibleY: true});
2016-03-11 00:48:53 +00:00
});
menuHiddenItems.on('item:click', function(obj,item,e) {
me.fireEvent('show:hidden', [me, item.value]);
});
var menuColorItems = new Common.UI.Menu({
menuAlign: 'tl-tr',
cls: 'color-tab',
items: [
2020-12-24 08:50:09 +00:00
{ template: _.template('<div id="id-tab-menu-color" style="width: 169px; height: 216px; margin: 10px;"></div>') },
2016-03-11 00:48:53 +00:00
{ template: _.template('<a id="id-tab-menu-new-color" style="padding-left:12px;">' + me.textNewColor + '</a>') }
]
});
function dummyCmp() {
return {
isDummy : true,
on : function() {}
}
}
me.mnuTabColor = dummyCmp();
this.tabMenu = new Common.UI.Menu({
menuAlign: 'bl-tl',
items: [
{caption: this.itemInsert, value: 'ins'},
{caption: this.itemDelete, value: 'del'},
{caption: this.itemRename, value: 'ren'},
{caption: this.itemCopy, value: 'copy'},
{caption: this.itemMove, value: 'move'},
{caption: this.itemHide, value: 'hide'},
{
caption: this.itemHidden,
menu: menuHiddenItems
},
{
caption: this.itemTabColor,
menu: menuColorItems
},
{ caption: '--' },
{caption: this.selectAllSheets, value: 'selectall'},
{caption: this.ungroupSheets, value: 'noselect'}
2016-03-11 00:48:53 +00:00
]
}).on('render:after', function(btn) {
me.mnuTabColor = new Common.UI.ThemeColorPalette({
el: $('#id-tab-menu-color'),
transparent: true
2016-03-11 00:48:53 +00:00
});
me.mnuTabColor.on('select', function(picker, color) {
me.fireEvent('sheet:setcolor', [color]);
});
});
var customizeStatusBarMenuTemplate = _.template('<a id="<%= id %>" tabindex="-1" type="menuitem">'+
'<div style="position: relative;">'+
'<div style="position: absolute; left: 0; width: 100px;"><%= caption %></div>' +
'<label style="width: 100%; overflow: hidden; text-overflow: ellipsis; text-align: right; vertical-align: bottom; padding-left: 100px; color: silver;cursor: pointer;"><%= options.exampleval ? options.exampleval : "" %></label>' +
'</div></a>');
2020-06-17 14:39:13 +00:00
this.customizeStatusBarMenu = new Common.UI.Menu({
style: 'margin-top: -14px; margin-left: -7px;',
menuAlign: 'bl-tl',
items: [
2020-06-17 20:03:34 +00:00
//{template: _.template('<div style="padding-left: 6px; padding-top: 2px;">' + this.textCustomizeStatusBar + '</div>')},
//{caption: '--'},
{
id: 'math-item-average',
caption: this.itemAverage,
value: 'average',
checkable: true,
checked: true,
template: customizeStatusBarMenuTemplate,
exampleval: ''
},
{
id: 'math-item-count',
caption: this.itemCount,
value: 'count',
checkable: true,
checked: true,
template: customizeStatusBarMenuTemplate,
exampleval: ''
},
{
id: 'math-item-min',
caption: this.itemMinimum,
value: 'min',
checkable: true,
checked: true,
template: customizeStatusBarMenuTemplate,
exampleval: ''
},
{
id: 'math-item-max',
caption: this.itemMaximum,
value: 'max',
checkable: true,
checked: true,
template: customizeStatusBarMenuTemplate,
exampleval: ''
},
{
id: 'math-item-sum',
caption: this.itemSum,
value: 'sum',
checkable: true,
checked: true,
template: customizeStatusBarMenuTemplate,
exampleval: ''
}
]
2020-06-17 14:39:13 +00:00
});
2020-06-05 13:10:48 +00:00
this.tabbar.$el.append('<div class="dropdown-toggle" data-toggle="dropdown" style="width:0; height:0;"></div>');
2016-03-11 00:48:53 +00:00
this.tabMenu.render(this.tabbar.$el);
2016-11-18 08:23:29 +00:00
this.tabMenu.cmpEl.attr({tabindex: -1});
2016-03-11 00:48:53 +00:00
this.tabMenu.on('show:after', _.bind(this.onTabMenuAfterShow, this));
this.tabMenu.on('hide:after', _.bind(this.onTabMenuAfterHide, this));
this.tabMenu.on('item:click', _.bind(this.onTabMenuClick, this));
this.boxMath = $('#status-math-box', this.el);
this.labelSum = $('#status-math-sum', this.boxMath);
this.labelCount = $('#status-math-count', this.boxMath);
this.labelAverage = $('#status-math-average', this.boxMath);
2019-02-28 08:31:15 +00:00
this.labelMin = $('#status-math-min', this.boxMath);
this.labelMax = $('#status-math-max', this.boxMath);
2016-03-11 00:48:53 +00:00
this.boxMath.hide();
2017-02-06 11:22:34 +00:00
this.boxFiltered = $('#status-filtered-box', this.el);
this.labelFiltered = $('#status-filtered-records', this.boxFiltered);
this.boxFiltered.hide();
2016-03-11 00:48:53 +00:00
this.boxZoom = $('#status-zoom-box', this.el);
this.boxZoom.find('.separator').css('border-left-color','transparent');
2020-06-17 14:39:13 +00:00
this.$el.append('<div id="statusbar-menu" style="width:0; height:0;"></div>');
this.$customizeStatusBarMenu = this.$el.find('#statusbar-menu');
this.$customizeStatusBarMenu.on({
'show.bs.dropdown': function () {
_.defer(function(){
me.$customizeStatusBarMenu.find('ul').focus();
}, 100);
},
'hide.bs.dropdown': function () {
_.defer(function(){
me.api.asc_enableKeyEvents(true);
}, 100);
}
});
this.$customizeStatusBarMenu.append('<div class="dropdown-toggle" data-toggle="dropdown" style="width:0; height:0;"></div>');
this.customizeStatusBarMenu.render(this.$customizeStatusBarMenu);
this.customizeStatusBarMenu.cmpEl.attr({tabindex: -1});
this.customizeStatusBarMenu.on('show:after', _.bind(this.onCustomizeStatusBarAfterShow, this));
this.customizeStatusBarMenu.on('hide:after', _.bind(this.onCustomizeStatusBarAfterHide, this));
this.customizeStatusBarMenu.on('item:click', _.bind(this.onCustomizeStatusBarClick, this));
2020-06-17 20:03:34 +00:00
this.$el.on('contextmenu', _.bind(this.showCustomizeStatusBar, this));
2020-06-17 14:39:13 +00:00
2016-03-11 00:48:53 +00:00
return this;
},
setApi: function(api) {
this.api = api;
this.api.asc_registerCallback('asc_onSheetsChanged', _.bind(this.update, this));
return this;
},
setMode: function(mode) {
this.mode = _.extend({}, this.mode, mode);
// this.$el.find('.el-edit')[mode.isEdit?'show':'hide']();
this.btnAddWorksheet.setVisible(this.mode.isEdit);
this.btnAddWorksheet.setDisabled(this.mode.isDisconnected);
this.updateTabbarBorders();
},
setVisible: function(visible) {
visible ? this.show(): this.hide();
},
update: function() {
var me = this;
this.tabbar.empty(true);
this.tabMenu.items[6].menu.removeAll();
this.tabMenu.items[6].hide();
this.btnAddWorksheet.setDisabled(true);
2021-06-26 13:16:33 +00:00
this.sheetListMenu.removeAll();
2016-03-11 00:48:53 +00:00
if (this.api) {
var wc = this.api.asc_getWorksheetsCount(), i = -1;
2021-06-26 13:16:33 +00:00
var hidentems = [], items = [], allItems = [], tab, locked, name;
2016-03-11 00:48:53 +00:00
var sindex = this.api.asc_getActiveWorksheetIndex();
while (++i < wc) {
locked = me.api.asc_isWorksheetLockedOrDeleted(i);
name = me.api.asc_getActiveNamedSheetView ? me.api.asc_getActiveNamedSheetView(i) || '' : '';
2016-03-11 00:48:53 +00:00
tab = {
sheetindex : i,
2020-01-13 08:36:22 +00:00
index : items.length,
2016-03-11 00:48:53 +00:00
active : sindex == i,
label : me.api.asc_getWorksheetName(i),
// reorderable : !locked,
cls : locked ? 'coauth-locked':'',
2021-02-16 11:49:13 +00:00
isLockTheDrag : locked || me.mode.isDisconnected,
iconCls : 'btn-sheet-view',
iconTitle : name,
iconVisible : name!==''
2016-03-11 00:48:53 +00:00
};
this.api.asc_isWorksheetHidden(i)? hidentems.push(tab) : items.push(tab);
2021-06-26 13:16:33 +00:00
allItems.push(tab);
2016-03-11 00:48:53 +00:00
}
if (hidentems.length) {
hidentems.forEach(function(item){
me.tabMenu.items[6].menu.addItem(new Common.UI.MenuItem({
style: 'white-space: pre-wrap',
caption: Common.Utils.String.htmlEncode(item.label),
value: item.sheetindex
}));
});
this.tabMenu.items[6].show();
}
this.tabbar.add(items);
2021-06-26 13:16:33 +00:00
allItems.forEach(function(item){
me.sheetListMenu.addItem(new Common.UI.MenuItem({
style: 'white-space: pre-wrap',
caption: Common.Utils.String.htmlEncode(item.label),
value: item.sheetindex,
checkable: true,
checked: item.active,
hidden: me.api.asc_isWorksheetHidden(item.sheetindex),
textHidden: me.itemHidden,
template: _.template([
'<a id="<%= id %>" style="<%= style %>" tabindex="-1" type="menuitem" <% if (options.hidden) { %> data-hidden="true" <% } %>>',
2021-06-26 13:16:33 +00:00
'<div class="color"></div>',
'<span class="name"><%= caption %></span>',
'<% if (options.hidden) { %>',
'<span class="hidden-mark"><%= options.textHidden %></span>',
'<% } %>',
'</a>'
].join(''))
}));
});
2016-03-11 00:48:53 +00:00
if (!_.isUndefined(this.tabBarScroll)) {
this.tabbar.$bar.scrollLeft(this.tabBarScroll.scrollLeft);
this.tabBarScroll = undefined;
}
if (!this.tabbar.isTabVisible(sindex))
this.tabbar.setTabVisible(sindex);
2019-10-14 12:00:15 +00:00
this.btnAddWorksheet.setDisabled(me.mode.isDisconnected || me.api.asc_isWorkbookLocked() || me.api.isCellEdited);
2016-03-11 00:48:53 +00:00
$('#status-label-zoom').text(Common.Utils.String.format(this.zoomText, Math.floor((this.api.asc_getZoom() +.005)*100)));
me.fireEvent('sheet:changed', [me, sindex]);
me.fireEvent('sheet:updateColors', [true]);
Common.NotificationCenter.trigger('comments:updatefilter', ['doc', 'sheet' + me.api.asc_getActiveWorksheetId()], false);
2016-03-11 00:48:53 +00:00
}
},
setMathInfo: function(info) {
if (info.count>1) {
if (!this.boxMath.is(':visible')) this.boxMath.show();
this.labelCount.text(this.textCount + ': ' + info.count);
this.labelMin.text((info.min && info.min.length) ? (this.textMin + ': ' + info.min) : '');
this.labelMax.text((info.max && info.max.length) ? (this.textMax + ': ' + info.max) : '');
this.labelSum.text((info.sum && info.sum.length) ? (this.textSum + ': ' + info.sum) : '');
this.labelAverage.text((info.average && info.average.length) ? (this.textAverage + ': ' + info.average) : '');
this.customizeStatusBarMenu.items.forEach(function (item) {
if (item.options.id === 'math-item-average') {
item.options.exampleval = (info.average && info.average.length) ? info.average : '';
} else if (item.options.id === 'math-item-min') {
item.options.exampleval = (info.min && info.min.length) ? info.min : '';
} else if (item.options.id === 'math-item-max') {
item.options.exampleval = (info.max && info.max.length) ? info.max : '';
} else if (item.options.id === 'math-item-count') {
item.options.exampleval = (info.count) ? String(info.count) : '';
} else if (item.options.id === 'math-item-sum') {
item.options.exampleval = (info.sum && info.sum.length) ? info.sum : '';
} else {
item.options.exampleval = '';
}
$(item.el).find('label').text(item.options.exampleval);
});
2016-03-11 00:48:53 +00:00
} else {
this.customizeStatusBarMenu.items.forEach(function (item) {
item.options.exampleval = '';
$(item.el).find('label').text('');
});
2016-03-11 00:48:53 +00:00
if (this.boxMath.is(':visible')) this.boxMath.hide();
}
var me = this;
_.delay(function(){
me.updateVisibleItemsBoxMath();
me.updateTabbarBorders();
2016-03-11 00:48:53 +00:00
me.onTabInvisible(undefined, me.tabbar.checkInvisible(true));
},30);
},
2017-02-06 11:22:34 +00:00
setFilteredInfo: function(countFilter, countRecords) {
if (countFilter>0 && countRecords>0) {//filter is applied
if (!this.boxFiltered.is(':visible')) this.boxFiltered.show();
this.labelFiltered.text(Common.Utils.String.format(this.filteredRecordsText, countFilter, countRecords));
} else if (countFilter) {// filter mode
if (!this.boxFiltered.is(':visible')) this.boxFiltered.show();
this.labelFiltered.text(this.filteredText);
} else if (countFilter !== undefined && countFilter !== null){
2017-02-06 11:22:34 +00:00
if (this.boxFiltered.is(':visible')) this.boxFiltered.hide();
} else {
var filterInfo = this.api.asc_getCellInfo().asc_getAutoFilterInfo(),
need_disable = !filterInfo || (filterInfo.asc_getIsApplyAutoFilter()!==true);
this.setFilteredInfo(!need_disable);
2017-02-06 11:22:34 +00:00
}
var me = this;
_.delay(function(){
me.onTabInvisible(undefined, me.tabbar.checkInvisible(true));
},30);
},
2016-03-11 00:48:53 +00:00
onSheetChanged: function(o, index, tab) {
this.api.asc_showWorksheet(tab.sheetindex);
if (this.hasTabInvisible && !this.tabbar.isTabVisible(index)) {
this.tabbar.setTabVisible(index);
}
this.fireEvent('sheet:changed', [this, tab.sheetindex]);
this.fireEvent('sheet:updateColors', [true]);
// Common.NotificationCenter.trigger('comments:updatefilter', ['doc', 'sheet' + this.api.asc_getActiveWorksheetId()], false); // hide popover
2016-03-11 00:48:53 +00:00
},
2019-09-03 11:09:22 +00:00
onTabMenu: function (o, index, tab, select) {
2019-10-23 09:43:34 +00:00
var me = this;
if (this.mode.isEdit && !this.isEditFormula && (this.rangeSelectionMode !== Asc.c_oAscSelectionDialogType.Chart) &&
(this.rangeSelectionMode !== Asc.c_oAscSelectionDialogType.FormatTable) &&
(this.rangeSelectionMode !== Asc.c_oAscSelectionDialogType.PrintTitles) &&
!this.mode.isDisconnected ) {
2016-03-11 00:48:53 +00:00
if (tab && tab.sheetindex >= 0) {
var rect = tab.$el.get(0).getBoundingClientRect(),
childPos = tab.$el.offset(),
parentPos = tab.$el.parent().offset();
if (!tab.isActive()) this.tabbar.setActive(tab);
2019-10-23 09:43:34 +00:00
if (!_.isUndefined(select)) {
var issheetlocked = false;
select.forEach(function (item) {
if (me.api.asc_isWorksheetLockedOrDeleted(item.sheetindex)) {
issheetlocked = true;
}
});
} else {
var issheetlocked = me.api.asc_isWorksheetLockedOrDeleted(tab.sheetindex);
}
var isdoclocked = this.api.asc_isWorkbookLocked();
2016-03-11 00:48:53 +00:00
this.tabMenu.items[0].setDisabled(isdoclocked);
this.tabMenu.items[1].setDisabled(issheetlocked);
this.tabMenu.items[2].setDisabled(issheetlocked);
this.tabMenu.items[3].setDisabled(issheetlocked);
this.tabMenu.items[4].setDisabled(issheetlocked);
2016-03-11 00:48:53 +00:00
this.tabMenu.items[5].setDisabled(issheetlocked);
this.tabMenu.items[6].setDisabled(isdoclocked);
this.tabMenu.items[7].setDisabled(issheetlocked);
if (select.length === 1) {
this.tabMenu.items[10].hide();
} else {
this.tabMenu.items[10].show();
}
this.tabMenu.items[9].setDisabled(issheetlocked);
this.tabMenu.items[10].setDisabled(issheetlocked);
2016-03-11 00:48:53 +00:00
this.api.asc_closeCellEditor();
this.api.asc_enableKeyEvents(false);
this.tabMenu.atposition = (function () {
return {
top : rect.top,
left: rect.left - parentPos.left - 2
};
})();
this.tabMenu.hide();
this.tabMenu.show();
var menu = this.tabMenu;
_.defer(function(){
menu.cmpEl.focus();
}, 10);
2016-03-11 00:48:53 +00:00
}
}
},
onTabMenuAfterShow: function (obj) {
if (obj.atposition) {
obj.setOffset(obj.atposition.left);
}
this.enableKeyEvents = true;
},
onTabMenuAfterHide: function () {
if (!_.isUndefined(this.enableKeyEvents)) {
if (this.api) {
this.api.asc_enableKeyEvents(this.enableKeyEvents);
}
this.enableKeyEvents = undefined;
}
},
onTabMenuClick: function (o, item) {
if (item && this.api) {
this.enableKeyEvents = (item.value === 'ins' || item.value === 'hide');
if (item.value === 'selectall') {
this.tabbar.setSelectAll(true);
} else if (item.value === 'noselect') {
this.tabbar.setSelectAll(false);
}
2016-03-11 00:48:53 +00:00
}
},
onTabInvisible: function(obj, opts) {
if (this.btnScrollFirst.isDisabled() !== (!opts.first)) {
this.btnScrollFirst.setDisabled(!opts.first);
this.btnScrollBack.setDisabled(!opts.first);
}
if (this.btnScrollNext.isDisabled() !== (!opts.last)) {
this.btnScrollNext.setDisabled(!opts.last);
this.btnScrollLast.setDisabled(!opts.last);
}
this.hasTabInvisible = opts.first || opts.last;
},
onBtnTabScroll: function(action, e) {
this.tabbar.setTabVisible(action);
},
updateTabbarBorders: function() {
var right = parseInt(this.boxZoom.css('width')), visible = false;
if (this.boxMath.is(':visible')) {
right += parseInt(this.boxMath.css('width'));
visible = true;
}
2017-02-06 11:22:34 +00:00
if (this.boxFiltered.is(':visible')) {
right += parseInt(this.boxFiltered.css('width'));
visible = true;
}
2016-03-11 00:48:53 +00:00
this.boxZoom.find('.separator').css('border-left-color',visible?'':'transparent');
this.tabBarBox.css('right', right + 'px');
},
updateVisibleItemsBoxMath: function () {
var widthStatusbar = parseInt(this.$el.css('width'));
var width = parseInt(this.boxZoom.css('width')) + parseInt($('#status-tabs-scroll').css('width')) + parseInt($('#status-addtabs-box').css('width'));
if (this.boxFiltered.is(':visible')) {
width += parseInt(this.boxFiltered.css('width'));
}
this.$el.find('.over-box').removeClass('over-box');
while (width + parseInt(this.boxMath.css('width')) + 100 > widthStatusbar) {
var items = this.boxMath.find('label:not(.hide, .over-box)');
(items.length>0) && $(items[items.length - 1]).addClass('over-box');
if (items.length<=1)
break;
}
},
2016-03-11 00:48:53 +00:00
changeViewMode: function (edit) {
if (edit) {
2021-06-26 13:16:33 +00:00
this.tabBarBox.css('left', '175px');
2016-03-11 00:48:53 +00:00
} else {
this.tabBarBox.css('left', '');
}
this.tabbar.options.draggable = edit;
this.editMode = edit;
},
2020-06-17 14:39:13 +00:00
showCustomizeStatusBar: function (e) {
2020-06-17 20:03:34 +00:00
var el = $(e.target);
if ($('#status-zoom-box').find(el).length > 0
|| $(e.target).closest('.statusbar .list-item').length>0
2020-06-17 20:03:34 +00:00
|| $('#status-tabs-scroll').find(el).length > 0
|| $('#status-addtabs-box').find(el).length > 0) return;
this.customizeStatusBarMenu.hide();
2020-06-17 14:39:13 +00:00
this.customizeStatusBarMenu.atposition = {
2020-06-17 20:03:34 +00:00
left: e.clientX*Common.Utils.zoom(),
top: e.clientY*Common.Utils.zoom()
2020-06-17 14:39:13 +00:00
};
this.customizeStatusBarMenu.show();
},
onCustomizeStatusBarAfterShow: function (obj) {
if (obj.atposition) {
obj.setOffset(obj.atposition.left);
}
this.enableKeyEvents = true;
},
onCustomizeStatusBarAfterHide: function () {
if (!_.isUndefined(this.enableKeyEvents)) {
if (this.api) {
this.api.asc_enableKeyEvents(this.enableKeyEvents);
}
this.enableKeyEvents = undefined;
}
},
2020-06-17 20:03:34 +00:00
onCustomizeStatusBarClick: function (o, item, event) {
2020-06-17 14:39:13 +00:00
var value = item.value,
checked = item.checked;
this.boxMath.find('#status-math-' + value)[checked ? 'removeClass' : 'addClass']('hide');
2020-06-17 20:03:34 +00:00
if (this.boxMath.find('label').length === this.boxMath.find('label.hide').length) {
this.boxMath.find('.separator').hide();
} else {
if (this.boxMath.find('.separator').is(":hidden")) {
this.boxMath.find('.separator').show();
}
}
this.updateVisibleItemsBoxMath();
this.updateTabbarBorders();
this.onTabInvisible(undefined, this.tabbar.checkInvisible(true));
2020-06-17 20:03:34 +00:00
event.stopPropagation();
item.$el.find('a').blur();
2020-06-17 14:39:13 +00:00
},
2016-03-11 00:48:53 +00:00
tipZoomIn : 'Zoom In',
tipZoomOut : 'Zoom Out',
tipZoomFactor : 'Magnification',
tipFirst : 'First Sheet',
tipLast : 'Last Sheet',
tipPrev : 'Previous Sheet',
tipNext : 'Next Sheet',
tipAddTab : 'Add Worksheet',
2021-06-26 13:16:33 +00:00
tipListOfSheets : 'List of Sheets',
2016-03-11 00:48:53 +00:00
itemInsert : 'Insert',
itemDelete : 'Delete',
itemRename : 'Rename',
itemCopy : 'Copy',
itemMove : 'Move',
itemHide : 'Hide',
itemHidden : 'Hidden',
itemTabColor : 'Tab Color',
textNoColor : 'No Color',
textNewColor : 'Add New Custom Color',
zoomText : 'Zoom {0}%',
2019-11-12 09:50:14 +00:00
textSum : 'Sum',
textCount : 'Count',
textAverage : 'Average',
textMin : 'Min',
textMax : 'Max',
2017-02-06 11:22:34 +00:00
filteredRecordsText : '{0} of {1} records filtered',
filteredText : 'Filter mode',
selectAllSheets : 'Select All Sheets',
2020-06-17 14:39:13 +00:00
ungroupSheets : 'Ungroup Sheets',
2020-06-18 11:16:30 +00:00
//textCustomizeStatusBar: 'Customize status bar',
2020-06-17 14:39:13 +00:00
itemAverage : 'Average',
itemCount : 'Count',
itemMinimum : 'Minimum',
itemMaximum : 'Maximum',
itemSum : 'Sum'
2016-03-11 00:48:53 +00:00
}, SSE.Views.Statusbar || {}));
SSE.Views.Statusbar.RenameDialog = Common.UI.Window.extend(_.extend({
options: {
header: false,
width: 280,
2019-09-11 08:38:08 +00:00
cls: 'modal-dlg',
2019-11-05 10:34:44 +00:00
buttons: ['ok', 'cancel']
2016-03-11 00:48:53 +00:00
},
template: '<div class="box">' +
'<div class="input-row">' +
'<label><%= label %></label>' +
'</div>' +
2020-06-05 13:10:48 +00:00
'<div class="input-row" id="txt-sheet-name"></div>' +
2016-03-11 00:48:53 +00:00
'</div>',
initialize : function(options) {
_.extend(this.options, options || {}, {
2019-09-11 08:38:08 +00:00
label: this.labelSheetName
2016-03-11 00:48:53 +00:00
});
2017-04-21 08:10:07 +00:00
this.options.tpl = _.template(this.template)(this.options);
2016-03-11 00:48:53 +00:00
Common.UI.Window.prototype.initialize.call(this, this.options);
},
render: function() {
Common.UI.Window.prototype.render.call(this);
var $window = this.getChild();
$window.find('.dlg-btn').on('click', _.bind(this.onBtnClick, this));
this.txtName = new Common.UI.InputField({
el: $window.find('#txt-sheet-name'),
style: 'width:100%;',
2019-04-08 14:08:17 +00:00
value: Common.Utils.String.htmlEncode(this.options.current),
2016-03-11 00:48:53 +00:00
allowBlank: false,
maxLength: 31,
validation: _.bind(this.nameValidator, this)
});
},
show: function(x,y) {
Common.UI.Window.prototype.show.apply(this, arguments);
var edit = this.txtName.$el.find('input');
_.delay(function(me){
edit.focus();
edit.select();
}, 100, this);
},
onBtnClick: function(event) {
this.doClose(event.currentTarget.attributes['result'].value);
},
doClose: function(res) {
if (res == 'ok') {
if (this.txtName.checkValidate() !== true) {
_.delay(function(me){
me.txtName.focus();
}, 100, this);
return;
}
}
if (this.options.handler) {
this.options.handler.call(this, res, this.txtName.getValue());
}
this.close();
},
onPrimary: function(e) {
this.doClose('ok');
return false;
2016-03-11 00:48:53 +00:00
},
nameValidator: function(value) {
var items = this.options.names;
if (!items && this.options.api) {
var api = this.options.api,
sindex = api.asc_getActiveWorksheetIndex(),
wc = api.asc_getWorksheetsCount();
items = [];
while (wc--) {
if (sindex !== wc) {
items.push(api.asc_getWorksheetName(wc).toLowerCase());
}
}
}
if (items) {
var testval = value.toLowerCase();
for (var i = items.length - 1; i >= 0; --i) {
if (items[i] === testval) {
return this.errNameExists;
}
}
}
if (value.length > 2 && value[0]=='"' && value[value.length-1]=='"') return true;
if (!/[:\\\/\*\?\[\]\']/.test(value)) return true;
return this.errNameWrongChar;
},
errNameExists : 'Worksheet with such name already exist.',
errNameWrongChar: 'A sheet name cannot contains characters: \\, \/, *, ?, [, ], :',
labelSheetName : 'Sheet Name'
}, RenameDialog||{}));
SSE.Views.Statusbar.CopyDialog = Common.UI.Window.extend(_.extend({
options: {
width: 270,
2019-09-11 08:38:08 +00:00
cls: 'modal-dlg',
2019-11-05 10:34:44 +00:00
buttons: ['ok', 'cancel']
2016-03-11 00:48:53 +00:00
},
template: '<div class="box">' +
'<div class="input-row">' +
'<label><%= label %></label>' +
'</div>' +
2020-06-05 13:10:48 +00:00
'<div id="status-list-names" style="height: 162px;"></div>' +
2016-03-11 00:48:53 +00:00
'</div>',
initialize : function(options) {
_.extend(this.options, options || {}, {
2019-09-11 08:38:08 +00:00
label: options.ismove ? this.textMoveBefore : this.textCopyBefore
2016-03-11 00:48:53 +00:00
});
2017-04-21 08:10:07 +00:00
this.options.tpl = _.template(this.template)(this.options);
2016-03-11 00:48:53 +00:00
Common.UI.Window.prototype.initialize.call(this, this.options);
},
render: function() {
Common.UI.Window.prototype.render.call(this);
var $window = this.getChild();
$window.find('.dlg-btn').on('click', _.bind(this.onBtnClick, this));
var pages = [];
this.options.names.forEach(function(item){
pages.push(new Common.UI.DataViewModel(item));
}, this);
if (pages.length) {
pages.push(new Common.UI.DataViewModel({
value : this.options.ismove ? this.itemMoveToEnd : this.itemCopyToEnd,
inindex : -255
}));
}
this.listNames = new Common.UI.ListView({
el: $('#status-list-names', $window),
store: new Common.UI.DataViewStore(pages),
2021-05-13 17:30:57 +00:00
cls: 'dbl-clickable',
itemTemplate: _.template('<div id="<%= id %>" class="list-item"><%= Common.Utils.String.htmlEncode(value) %></div>')
2016-03-11 00:48:53 +00:00
});
this.listNames.selectByIndex(0);
this.listNames.on('entervalue', _.bind(this.onPrimary, this));
this.listNames.on('item:dblclick', _.bind(this.onPrimary, this));
this.mask = $('.modals-mask');
this.mask.on('mousedown',_.bind(this.onUpdateFocus, this));
},
show: function(x,y) {
Common.UI.Window.prototype.show.apply(this, arguments);
_.delay(function(me){
me.listNames.focus();
2016-03-11 00:48:53 +00:00
}, 100, this);
},
hide: function () {
Common.UI.Window.prototype.hide.apply(this, arguments);
this.mask.off('mousedown',_.bind(this.onUpdateFocus, this));
},
onBtnClick: function(event) {
var active = this.listNames.getSelectedRec();
if (this.options.handler) {
this.options.handler.call(this,
2019-06-27 11:18:01 +00:00
event.currentTarget.attributes['result'].value, active.get('inindex'));
2016-03-11 00:48:53 +00:00
}
this.close();
},
onPrimary: function() {
if (this.options.handler) {
2019-06-27 11:18:01 +00:00
this.options.handler.call(this, 'ok', this.listNames.getSelectedRec().get('inindex'));
2016-03-11 00:48:53 +00:00
}
this.close();
},
onUpdateFocus: function () {
_.delay(function(me){
me.listNames.focus();
2016-03-11 00:48:53 +00:00
}, 100, this);
},
itemCopyToEnd : '(Copy to end)',
itemMoveToEnd : '(Move to end)',
textCopyBefore : 'Copy before sheet',
textMoveBefore : 'Move before sheet'
}, CopyDialog||{}));
}
);