2016-04-01 13:17:09 +00:00
|
|
|
/*
|
|
|
|
*
|
2017-01-17 14:58:08 +00:00
|
|
|
* (c) Copyright Ascensio System Limited 2010-2017
|
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 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
|
|
|
|
*
|
|
|
|
*/
|
2016-03-11 00:48:53 +00:00
|
|
|
define([
|
|
|
|
'text!spreadsheeteditor/main/app/template/LeftMenu.template',
|
|
|
|
'jquery',
|
|
|
|
'underscore',
|
|
|
|
'backbone',
|
|
|
|
'common/main/lib/component/Button',
|
|
|
|
'common/main/lib/view/About',
|
|
|
|
/** coauthoring begin **/
|
|
|
|
'common/main/lib/view/Comments',
|
|
|
|
'common/main/lib/view/Chat',
|
|
|
|
/** coauthoring end **/
|
|
|
|
'common/main/lib/view/SearchDialog',
|
2016-07-05 12:21:26 +00:00
|
|
|
'common/main/lib/view/Plugins',
|
2016-03-11 00:48:53 +00:00
|
|
|
'spreadsheeteditor/main/app/view/FileMenu'
|
|
|
|
], function (menuTemplate, $, _, Backbone) {
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var SCALE_MIN = 40;
|
|
|
|
var MENU_SCALE_PART = 300;
|
|
|
|
|
|
|
|
SSE.Views.LeftMenu = Backbone.View.extend(_.extend({
|
|
|
|
el: '#left-menu',
|
|
|
|
|
|
|
|
template: _.template(menuTemplate),
|
|
|
|
|
|
|
|
// Delegated events for creating new items, and clearing completed ones.
|
|
|
|
events: function() {
|
|
|
|
return {
|
|
|
|
/** coauthoring begin **/
|
|
|
|
'click #left-btn-comments': _.bind(this.onCoauthOptions, this),
|
|
|
|
'click #left-btn-chat': _.bind(this.onCoauthOptions, this),
|
|
|
|
/** coauthoring end **/
|
2016-07-05 12:21:26 +00:00
|
|
|
'click #left-btn-plugins': _.bind(this.onCoauthOptions, this),
|
2016-03-11 00:48:53 +00:00
|
|
|
'click #left-btn-support': function() {
|
|
|
|
var config = this.mode.customization;
|
|
|
|
config && !!config.feedback && !!config.feedback.url ?
|
|
|
|
window.open(config.feedback.url) :
|
|
|
|
window.open('http://support.onlyoffice.com');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
initialize: function () {
|
|
|
|
this.minimizedMode = true;
|
2017-08-18 14:08:45 +00:00
|
|
|
this._state = {};
|
2016-03-11 00:48:53 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
render: function () {
|
|
|
|
var el = $(this.el);
|
|
|
|
el.html(this.template({
|
|
|
|
}));
|
|
|
|
|
|
|
|
this.btnSearch = new Common.UI.Button({
|
|
|
|
action: 'search',
|
|
|
|
el: $('#left-btn-search', this.el),
|
|
|
|
hint: this.tipSearch + Common.Utils.String.platformKey('Ctrl+F'),
|
|
|
|
disabled: true,
|
|
|
|
enableToggle: true
|
|
|
|
});
|
|
|
|
|
|
|
|
this.btnAbout = new Common.UI.Button({
|
|
|
|
action: 'about',
|
|
|
|
el: $('#left-btn-about', this.el),
|
|
|
|
hint: this.tipAbout,
|
|
|
|
enableToggle: true,
|
|
|
|
disabled: true,
|
|
|
|
toggleGroup: 'leftMenuGroup'
|
|
|
|
});
|
|
|
|
|
|
|
|
this.btnSupport = new Common.UI.Button({
|
|
|
|
action: 'support',
|
|
|
|
el: $('#left-btn-support', this.el),
|
|
|
|
hint: this.tipSupport,
|
|
|
|
disabled: true
|
|
|
|
});
|
|
|
|
|
|
|
|
/** coauthoring begin **/
|
|
|
|
this.btnComments = new Common.UI.Button({
|
|
|
|
el: $('#left-btn-comments', this.el),
|
|
|
|
hint: this.tipComments + Common.Utils.String.platformKey('Ctrl+Shift+H'),
|
|
|
|
enableToggle: true,
|
|
|
|
disabled: true,
|
|
|
|
toggleGroup: 'leftMenuGroup'
|
|
|
|
});
|
|
|
|
|
|
|
|
this.btnChat = new Common.UI.Button({
|
|
|
|
el: $('#left-btn-chat', this.el),
|
|
|
|
hint: this.tipChat + Common.Utils.String.platformKey('Alt+Q'),
|
|
|
|
enableToggle: true,
|
|
|
|
disabled: true,
|
|
|
|
toggleGroup: 'leftMenuGroup'
|
|
|
|
});
|
|
|
|
|
|
|
|
this.btnComments.hide();
|
|
|
|
this.btnChat.hide();
|
|
|
|
|
|
|
|
this.btnComments.on('click', _.bind(this.onBtnMenuClick, this));
|
2017-06-20 09:54:01 +00:00
|
|
|
this.btnComments.on('toggle', _.bind(this.onBtnCommentsToggle, this));
|
2016-03-11 00:48:53 +00:00
|
|
|
this.btnChat.on('click', _.bind(this.onBtnMenuClick, this));
|
|
|
|
/** coauthoring end **/
|
|
|
|
|
2016-07-05 12:21:26 +00:00
|
|
|
this.btnPlugins = new Common.UI.Button({
|
|
|
|
el: $('#left-btn-plugins'),
|
|
|
|
hint: this.tipPlugins,
|
|
|
|
enableToggle: true,
|
|
|
|
disabled: true,
|
|
|
|
toggleGroup: 'leftMenuGroup'
|
|
|
|
});
|
|
|
|
this.btnPlugins.hide();
|
|
|
|
this.btnPlugins.on('click', _.bind(this.onBtnMenuClick, this));
|
|
|
|
|
2016-03-11 00:48:53 +00:00
|
|
|
this.btnSearch.on('click', _.bind(this.onBtnMenuClick, this));
|
|
|
|
this.btnAbout.on('toggle', _.bind(this.onBtnMenuToggle, this));
|
|
|
|
|
2017-04-27 15:34:19 +00:00
|
|
|
this.menuFile = new SSE.Views.FileMenu({});
|
|
|
|
this.menuFile.render();
|
2016-03-11 00:48:53 +00:00
|
|
|
this.btnAbout.panel = (new Common.Views.About({el: $('#about-menu-panel'), appName: 'Spreadsheet Editor'})).render();
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
onBtnMenuToggle: function(btn, state) {
|
|
|
|
if (state) {
|
|
|
|
btn.panel['show']();
|
2017-08-18 14:08:45 +00:00
|
|
|
if (!this._state.pluginIsRunning)
|
|
|
|
this.$el.width(SCALE_MIN);
|
2016-03-11 00:48:53 +00:00
|
|
|
|
|
|
|
if (this.btnSearch.isActive())
|
|
|
|
this.btnSearch.toggle(false);
|
|
|
|
} else {
|
|
|
|
btn.panel['hide']();
|
|
|
|
}
|
|
|
|
if (this.mode.isEdit) SSE.getController('Toolbar').DisableToolbar(state==true);
|
|
|
|
Common.NotificationCenter.trigger('layout:changed', 'leftmenu');
|
|
|
|
},
|
|
|
|
|
2017-06-20 09:54:01 +00:00
|
|
|
onBtnCommentsToggle: function(btn, state) {
|
|
|
|
if (!state)
|
|
|
|
this.fireEvent('comments:hide', this);
|
|
|
|
},
|
|
|
|
|
2016-03-11 00:48:53 +00:00
|
|
|
onBtnMenuClick: function(btn, e) {
|
|
|
|
this.btnAbout.toggle(false);
|
|
|
|
|
|
|
|
if (btn.options.action == 'search') {
|
|
|
|
} else {
|
|
|
|
if (btn.pressed) {
|
|
|
|
if (!(this.$el.width() > SCALE_MIN)) {
|
|
|
|
this.$el.width(Common.localStorage.getItem('sse-mainmenu-width') || MENU_SCALE_PART);
|
|
|
|
}
|
2017-08-18 14:08:45 +00:00
|
|
|
} else if (!this._state.pluginIsRunning){
|
2016-03-11 00:48:53 +00:00
|
|
|
Common.localStorage.setItem('sse-mainmenu-width',this.$el.width());
|
|
|
|
this.$el.width(SCALE_MIN);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// this.btnChat.id == btn.id && !this.btnChat.pressed && this.fireEvent('chat:hide', this);
|
|
|
|
Common.NotificationCenter.trigger('layout:changed', 'leftmenu');
|
|
|
|
},
|
|
|
|
|
|
|
|
/** coauthoring begin **/
|
|
|
|
onCoauthOptions: function(e) {
|
|
|
|
if (this.mode.canCoAuthoring) {
|
|
|
|
if (this.mode.canComments) {
|
|
|
|
if (this.btnComments.pressed && this.btnComments.$el.hasClass('notify'))
|
|
|
|
this.btnComments.$el.removeClass('notify');
|
|
|
|
this.panelComments[this.btnComments.pressed?'show':'hide']();
|
|
|
|
this.fireEvent((this.btnComments.pressed) ? 'comments:show' : 'comments:hide', this);
|
|
|
|
}
|
|
|
|
if (this.mode.canChat) {
|
|
|
|
if (this.btnChat.pressed) {
|
|
|
|
if (this.btnChat.$el.hasClass('notify'))
|
|
|
|
this.btnChat.$el.removeClass('notify');
|
|
|
|
|
|
|
|
this.panelChat.show();
|
|
|
|
this.panelChat.focus();
|
|
|
|
} else
|
|
|
|
this.panelChat['hide']();
|
|
|
|
}
|
|
|
|
}
|
2017-08-18 14:08:45 +00:00
|
|
|
// if (this.mode.canPlugins && this.panelPlugins) {
|
|
|
|
// if (this.btnPlugins.pressed) {
|
|
|
|
// this.panelPlugins.show();
|
|
|
|
// } else
|
|
|
|
// this.panelPlugins['hide']();
|
|
|
|
// }
|
2016-03-11 00:48:53 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
setOptionsPanel: function(name, panel) {
|
|
|
|
if (name == 'chat') {
|
|
|
|
this.panelChat = panel.render('#left-panel-chat');
|
|
|
|
} else if (name == 'comment') {
|
|
|
|
this.panelComments = panel;
|
2016-07-05 12:21:26 +00:00
|
|
|
} else
|
|
|
|
if (name == 'plugins' && !this.panelPlugins) {
|
|
|
|
this.panelPlugins = panel.render('#left-panel-plugins');
|
2016-03-11 00:48:53 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
markCoauthOptions: function(opt, ignoreDisabled) {
|
|
|
|
if (opt=='chat' && this.btnChat.isVisible() &&
|
|
|
|
!this.btnChat.isDisabled() && !this.btnChat.pressed) {
|
|
|
|
this.btnChat.$el.addClass('notify');
|
|
|
|
}
|
|
|
|
if (opt=='comments' && this.btnComments.isVisible() && !this.btnComments.pressed &&
|
|
|
|
(!this.btnComments.isDisabled() || ignoreDisabled) ) {
|
|
|
|
this.btnComments.$el.addClass('notify');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
/** coauthoring end **/
|
|
|
|
|
|
|
|
close: function(menu) {
|
|
|
|
this.btnAbout.toggle(false);
|
2017-08-18 14:08:45 +00:00
|
|
|
if (!this._state.pluginIsRunning)
|
|
|
|
this.$el.width(SCALE_MIN);
|
2016-03-11 00:48:53 +00:00
|
|
|
/** coauthoring begin **/
|
|
|
|
if (this.mode.canCoAuthoring) {
|
|
|
|
if (this.mode.canComments) {
|
|
|
|
this.panelComments['hide']();
|
|
|
|
if (this.btnComments.pressed)
|
|
|
|
this.fireEvent('comments:hide', this);
|
|
|
|
this.btnComments.toggle(false, true);
|
|
|
|
}
|
|
|
|
if (this.mode.canChat) {
|
|
|
|
this.panelChat['hide']();
|
2017-10-12 10:43:23 +00:00
|
|
|
this.btnChat.toggle(false);
|
2016-03-11 00:48:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
/** coauthoring end **/
|
2017-08-18 14:08:45 +00:00
|
|
|
if (this.mode.canPlugins && this.panelPlugins && !this._state.pluginIsRunning) {
|
2016-07-05 12:21:26 +00:00
|
|
|
this.panelPlugins['hide']();
|
|
|
|
this.btnPlugins.toggle(false, true);
|
|
|
|
}
|
2016-03-11 00:48:53 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
isOpened: function() {
|
2017-04-27 15:34:19 +00:00
|
|
|
var isopened = this.btnSearch.pressed;
|
2016-03-11 00:48:53 +00:00
|
|
|
/** coauthoring begin **/
|
|
|
|
!isopened && (isopened = this.btnComments.pressed || this.btnChat.pressed);
|
|
|
|
/** coauthoring end **/
|
|
|
|
return isopened;
|
|
|
|
},
|
|
|
|
|
|
|
|
disableMenu: function(menu, disable) {
|
|
|
|
this.btnAbout.setDisabled(false);
|
|
|
|
this.btnSupport.setDisabled(false);
|
|
|
|
this.btnSearch.setDisabled(false);
|
|
|
|
/** coauthoring begin **/
|
|
|
|
this.btnComments.setDisabled(false);
|
|
|
|
this.btnChat.setDisabled(false);
|
|
|
|
/** coauthoring end **/
|
2016-07-05 12:21:26 +00:00
|
|
|
this.btnPlugins.setDisabled(false);
|
2016-03-11 00:48:53 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
showMenu: function(menu) {
|
|
|
|
var re = /^(\w+):?(\w*)$/.exec(menu);
|
2017-04-27 15:34:19 +00:00
|
|
|
if ( re[1] == 'file' ) {
|
|
|
|
this.menuFile.show(re[2].length ? re[2] : undefined);
|
2016-03-11 00:48:53 +00:00
|
|
|
} else {
|
|
|
|
/** coauthoring begin **/
|
|
|
|
if (menu == 'chat') {
|
|
|
|
if (this.btnChat.isVisible() &&
|
|
|
|
!this.btnChat.isDisabled() && !this.btnChat.pressed) {
|
|
|
|
this.btnChat.toggle(true);
|
|
|
|
this.onBtnMenuClick(this.btnChat);
|
|
|
|
this.onCoauthOptions();
|
|
|
|
this.panelChat.focus();
|
|
|
|
}
|
|
|
|
} else
|
|
|
|
if (menu == 'comments') {
|
|
|
|
if (this.btnComments.isVisible() &&
|
|
|
|
!this.btnComments.isDisabled() && !this.btnComments.pressed) {
|
|
|
|
this.btnComments.toggle(true);
|
|
|
|
this.onBtnMenuClick(this.btnComments);
|
|
|
|
this.onCoauthOptions();
|
|
|
|
this.btnComments.$el.focus();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/** coauthoring end **/
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
getMenu: function(type) {
|
|
|
|
switch (type) {
|
2017-04-27 15:34:19 +00:00
|
|
|
case 'file': return this.menuFile;
|
2016-03-11 00:48:53 +00:00
|
|
|
case 'about': return this.btnAbout.panel;
|
|
|
|
default: return null;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
setMode: function(mode) {
|
|
|
|
this.mode = mode;
|
2016-07-08 12:53:41 +00:00
|
|
|
this.btnAbout.panel.setMode(mode);
|
2016-03-11 00:48:53 +00:00
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2017-04-11 11:05:56 +00:00
|
|
|
setDeveloperMode: function(mode) {
|
|
|
|
if ( !this.$el.is(':visible') ) return;
|
|
|
|
|
|
|
|
if (!this.developerHint) {
|
|
|
|
this.developerHint = $('<div id="developer-hint">' + this.txtDeveloper + '</div>').appendTo(this.$el);
|
|
|
|
this.devHeight = this.developerHint.outerHeight();
|
|
|
|
$(window).on('resize', _.bind(this.onWindowResize, this));
|
|
|
|
}
|
|
|
|
this.developerHint.toggleClass('hidden', !mode);
|
|
|
|
|
|
|
|
var lastbtn = this.$el.find('button.btn-category:visible:last-of-type');
|
|
|
|
this.minDevPosition = lastbtn.offset().top - lastbtn.offsetParent().offset().top + lastbtn.height() + 20;
|
|
|
|
this.onWindowResize();
|
|
|
|
},
|
|
|
|
|
|
|
|
onWindowResize: function() {
|
|
|
|
this.developerHint.css('top', Math.max((this.$el.height()-this.devHeight)/2, this.minDevPosition));
|
|
|
|
},
|
|
|
|
|
2016-03-11 00:48:53 +00:00
|
|
|
/** coauthoring begin **/
|
|
|
|
tipComments : 'Comments',
|
|
|
|
tipChat : 'Chat',
|
|
|
|
/** coauthoring end **/
|
|
|
|
tipAbout : 'About',
|
|
|
|
tipSupport : 'Feedback & Support',
|
|
|
|
tipFile : 'File',
|
2016-07-05 12:21:26 +00:00
|
|
|
tipSearch : 'Search',
|
2017-04-11 11:05:56 +00:00
|
|
|
tipPlugins : 'Plugins',
|
|
|
|
txtDeveloper: 'DEVELOPER MODE'
|
2016-03-11 00:48:53 +00:00
|
|
|
}, SSE.Views.LeftMenu || {}));
|
|
|
|
});
|