web-apps/apps/common/main/lib/view/Header.js

932 lines
43 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
/**
* Header.js
*
* Created by Alexander Yuzhin on 2/14/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
*
*/
if (Common === undefined)
var Common = {};
Common.Views = Common.Views || {};
define([
'backbone',
'text!common/main/lib/template/Header.template',
2016-09-26 10:54:25 +00:00
'core',
'common/main/lib/view/RenameDialog'
2016-03-11 00:48:53 +00:00
], function (Backbone, headerTemplate) { 'use strict';
2017-03-01 13:33:12 +00:00
Common.Views.Header = Backbone.View.extend(_.extend(function(){
2017-03-16 10:20:07 +00:00
var storeUsers, appConfig;
var $userList, $panelUsers, $btnUsers, $btnUserName, $labelDocName;
2019-04-08 15:40:08 +00:00
var _readonlyRights = false;
var templateUserItem =
'<li id="<%= user.get("iid") %>" class="<% if (!user.get("online")) { %> offline <% } if (user.get("view")) {%> viewmode <% } %>">' +
'<div class="user-name">' +
'<div class="color" style="background-color: <%= user.get("color") %>;"></div>'+
'<label><%= fnEncode(user.get("username")) %></label>' +
'<% if (len>1) { %><label style="margin-left:3px;">(<%=len%>)</label><% } %>' +
'</div>'+
'</li>';
var templateUserList = _.template(
'<ul>' +
'<% for (originalId in users) { %>' +
'<%= usertpl({user: users[originalId][0], fnEncode: fnEncode, len: users[originalId].length}) %>' +
'<% } %>' +
'</ul>');
var templateRightBox = '<section>' +
2017-08-15 11:44:59 +00:00
'<section id="box-doc-name">' +
// '<input type="text" id="rib-doc-name" spellcheck="false" data-can-copy="false" style="pointer-events: none;" disabled="disabled">' +
2022-02-03 12:06:09 +00:00
//'<label id="rib-doc-name" />' +
'<input id="rib-doc-name" autofill="off" autocomplete="off"/></input>' +
2017-08-15 11:44:59 +00:00
'</section>' +
2020-07-29 19:50:07 +00:00
'<section style="display: inherit;">' +
'<div class="hedset">' +
'<div class="btn-slot" id="slot-hbtn-edit"></div>' +
2022-11-15 18:45:25 +00:00
'<div class="btn-slot" id="slot-hbtn-print-quick"></div>' +
2020-07-29 19:50:07 +00:00
'<div class="btn-slot" id="slot-hbtn-print"></div>' +
'<div class="btn-slot" id="slot-hbtn-download"></div>' +
'</div>' +
'<div class="hedset" data-layout-name="header-users">' +
2020-07-29 19:50:07 +00:00
// '<span class="btn-slot text" id="slot-btn-users"></span>' +
'<section id="tlb-box-users" class="box-cousers dropdown">' +
'<div class="btn-users dropdown-toggle" data-toggle="dropdown" data-hint="0" data-hint-direction="bottom" data-hint-offset="big">' +
'<div class="inner-box-icon">' +
'<svg class=""><use xlink:href="#svg-icon-users"></use></svg>' +
'</div>' +
'<label class="caption"></label>' +
2020-07-29 19:50:07 +00:00
'</div>' +
'<div class="cousers-menu dropdown-menu">' +
'<label id="tlb-users-menu-descr"><%= tipUsers %></label>' +
'<div class="cousers-list"></div>' +
'</div>' +
'</section>'+
'</div>' +
2022-02-03 10:51:38 +00:00
'<div class="hedset">' +
2022-02-04 11:51:13 +00:00
'<div class="btn-slot" id="slot-btn-share"></div>' +
2020-07-29 19:50:07 +00:00
'</div>' +
'<div class="hedset">' +
2021-07-02 13:15:54 +00:00
'<div class="btn-slot" id="slot-btn-mode"></div>' +
2020-07-29 19:50:07 +00:00
'<div class="btn-slot" id="slot-btn-back"></div>' +
2020-12-14 19:45:30 +00:00
'<div class="btn-slot" id="slot-btn-favorite"></div>' +
2022-02-08 16:03:44 +00:00
'<div class="btn-slot" id="slot-btn-search"></div>' +
2020-07-29 19:50:07 +00:00
'</div>' +
'<div class="hedset">' +
2022-02-04 09:13:13 +00:00
// '<div class="btn-slot slot-btn-user-name"></div>' +
'<button type="button" class="btn btn-header slot-btn-user-name hidden">' +
'<div class="color-user-name"></div>' +
'</button>' +
'<div class="btn-current-user hidden">' +
2022-02-04 09:13:13 +00:00
'<div class="color-user-name"></div>' +
'</div>' +
'</div>' +
2017-08-15 11:44:59 +00:00
'</section>' +
2017-03-01 13:33:12 +00:00
'</section>';
2017-04-22 14:51:12 +00:00
var templateLeftBox = '<section class="logo">' +
2020-06-05 13:10:48 +00:00
'<div id="header-logo"><i></i></div>' +
'</section>';
2018-02-03 13:10:38 +00:00
var templateTitleBox = '<section id="box-document-title">' +
'<div class="extra"></div>' +
2020-07-29 19:50:07 +00:00
'<div class="hedset">' +
2021-11-18 14:46:14 +00:00
'<div class="btn-slot" id="slot-btn-dt-save" data-layout-name="header-save"></div>' +
2022-11-15 18:45:25 +00:00
'<div class="btn-slot" id="slot-btn-dt-print-quick"></div>' +
2018-02-03 13:10:38 +00:00
'<div class="btn-slot" id="slot-btn-dt-print"></div>' +
'<div class="btn-slot" id="slot-btn-dt-undo"></div>' +
'<div class="btn-slot" id="slot-btn-dt-redo"></div>' +
'</div>' +
'<div class="lr-separator" id="id-box-doc-name">' +
2022-01-11 00:35:54 +00:00
// '<label id="title-doc-name" /></label>' +
2022-01-13 23:25:47 +00:00
'<input id="title-doc-name" autofill="off" autocomplete="off"/></input>' +
2020-04-24 21:58:40 +00:00
'</div>' +
2022-02-03 20:14:59 +00:00
'<div class="hedset">' +
2022-02-04 09:13:13 +00:00
// '<div class="btn-slot slot-btn-user-name"></div>' +
'<button type="button" class="btn btn-header slot-btn-user-name hidden">' +
'<div class="color-user-name"></div>' +
'</button>' +
'<div class="btn-current-user hidden">' +
2022-02-04 09:13:13 +00:00
'<div class="color-user-name"></div>' +
2022-02-03 20:14:59 +00:00
'</div>' +
'</div>' +
2018-02-03 13:10:38 +00:00
'</section>';
function onResetUsers(collection, opts) {
var usercount = collection.getVisibleEditingCount();
if ( $userList ) {
if (usercount > 1 && appConfig && (appConfig.isEdit || appConfig.isRestrictedEdit)) {
$userList.html(templateUserList({
users: collection.chain().filter(function(item){return item.get('online') && !item.get('view') && !item.get('hidden')}).groupBy(function(item) {return item.get('idOriginal');}).value(),
usertpl: _.template(templateUserItem),
fnEncode: function(username) {
2021-03-26 11:29:16 +00:00
return Common.Utils.String.htmlEncode(AscCommon.UserInfoParser.getParsedName(username));
}
}));
2019-04-23 10:20:39 +00:00
$userList.scroller = new Common.UI.Scroller({
el: $userList.find('ul'),
useKeyboard: true,
minScrollbarLength: 40,
alwaysVisibleY: true
});
$userList.scroller.update({minScrollbarLength : 40, alwaysVisibleY: true});
} else {
$userList.empty();
}
}
applyUsers( usercount, collection.getVisibleEditingOriginalCount() );
};
function onUsersChanged(model) {
onResetUsers(model.collection);
};
function applyUsers(count, originalCount) {
2019-01-11 11:02:28 +00:00
if (!$btnUsers) return;
var has_edit_users = count > 1 && appConfig && (appConfig.isEdit || appConfig.isRestrictedEdit); // has other user(s) who edit document
2018-04-20 08:23:58 +00:00
if ( has_edit_users ) {
$panelUsers['show']();
2022-02-03 10:30:01 +00:00
$btnUsers.find('.caption').html(originalCount);
} else {
$panelUsers['hide']();
}
updateDocNamePosition(appConfig);
}
2019-04-08 15:40:08 +00:00
function onLostEditRights() {
_readonlyRights = true;
2022-02-04 11:51:13 +00:00
this.btnShare && this.btnShare.setVisible(false);
updateDocNamePosition(appConfig);
2019-04-08 15:40:08 +00:00
}
function onUsersClick(e) {
var usertip = $btnUsers.data('bs.tooltip');
if ( usertip ) {
if ( usertip.dontShow===undefined)
usertip.dontShow = true;
usertip.hide();
}
}
function updateDocNamePosition(config) {
if ( $labelDocName && config) {
var $parent = $labelDocName.parent();
if (!config.isEdit) {
2021-04-12 16:13:31 +00:00
var _left_width = $parent.position().left,
_right_width = $parent.next().outerWidth();
$parent.css('padding-left', _left_width < _right_width ? Math.max(2, _right_width - _left_width) : 2);
$parent.css('padding-right', _left_width < _right_width ? 2 : Math.max(2, _left_width - _right_width));
} else if (!(config.customization && config.customization.compactHeader)) {
var _left_width = $parent.position().left,
_right_width = $parent.next().outerWidth(),
outerWidth = $labelDocName.outerWidth(),
cssWidth = $labelDocName[0].style.width;
cssWidth = cssWidth ? parseFloat(cssWidth) : outerWidth;
if (cssWidth - outerWidth > 0.1) {
$parent.css('padding-left', _left_width < _right_width ? Math.max(2, $parent.outerWidth() - 2 - cssWidth) : 2);
$parent.css('padding-right', _left_width < _right_width ? 2 : Math.max(2, $parent.outerWidth() - 2 - cssWidth));
} else {
$parent.css('padding-left', _left_width < _right_width ? Math.max(2, Math.min(_right_width - _left_width + 2, $parent.outerWidth() - 2 - cssWidth)) : 2);
$parent.css('padding-right', _left_width < _right_width ? 2 : Math.max(2, Math.min(_left_width - _right_width + 2, $parent.outerWidth() - 2 - cssWidth)));
}
}
if (!(config.customization && config.customization.toolbarHideFileName) && (!config.isEdit || config.customization && config.customization.compactHeader)) {
var basis = parseFloat($parent.css('padding-left') || 0) + parseFloat($parent.css('padding-right') || 0) + parseInt($labelDocName.css('min-width') || 50); // 2px - box-shadow
2022-05-11 13:08:19 +00:00
config.isCrypted && (basis += 20);
$parent.css('flex-basis', Math.ceil(basis) + 'px');
$parent.closest('.extra.right').css('flex-basis', Math.ceil(basis) + $parent.next().outerWidth() + 'px');
Common.NotificationCenter.trigger('tab:resize');
}
}
}
function onResize() {
if (appConfig && appConfig.isEdit && !(appConfig.customization && appConfig.customization.compactHeader)) {
updateDocNamePosition(appConfig);
}
}
2020-04-24 21:58:40 +00:00
function onAppShowed(config) {
// config.isCrypted =true; //delete fore merge!
if ( $labelDocName ) {
if ( config.isCrypted ) {
$labelDocName.before(
'<div class="inner-box-icon crypted hidden">' +
'<svg class="icon"><use xlink:href="#svg-icon-crypted"></use></svg>' +
'</div>');
this.imgCrypted = $labelDocName.parent().find('.crypted');
this._showImgCrypted = true;
}
updateDocNamePosition(config);
2020-04-24 21:58:40 +00:00
}
}
2018-03-21 11:11:03 +00:00
function onAppReady(mode) {
appConfig = mode;
var me = this;
me.btnGoBack.on('click', function (e) {
2018-02-14 14:11:28 +00:00
Common.NotificationCenter.trigger('goback');
});
2020-12-14 19:45:30 +00:00
me.btnFavorite.on('click', function (e) {
// wait for setFavorite method
// me.options.favorite = !me.options.favorite;
// me.btnFavorite.changeIcon(me.options.favorite ? {next: 'btn-in-favorite'} : {curr: 'btn-in-favorite'});
// me.btnFavorite.updateHint(!me.options.favorite ? me.textAddFavorite : me.textRemoveFavorite);
Common.NotificationCenter.trigger('markfavorite', !me.options.favorite);
2020-12-14 19:45:30 +00:00
});
2022-02-04 11:51:13 +00:00
if (me.btnShare) {
me.btnShare.on('click', function (e) {
Common.NotificationCenter.trigger('collaboration:sharing');
});
me.btnShare.updateHint(me.tipAccessRights);
me.btnShare.setVisible(!_readonlyRights && appConfig && (appConfig.sharingSettingsUrl && appConfig.sharingSettingsUrl.length || appConfig.canRequestSharingSettings));
updateDocNamePosition(appConfig);
2022-02-04 11:51:13 +00:00
}
2017-05-04 12:36:42 +00:00
if ( me.logo )
me.logo.children(0).on('click', function (e) {
2018-11-13 08:40:35 +00:00
var _url = !!me.branding && !!me.branding.logo && (me.branding.logo.url!==undefined) ?
me.branding.logo.url : '{{PUBLISHER_URL}}';
2018-11-13 08:40:35 +00:00
if (_url) {
var newDocumentPage = window.open(_url);
newDocumentPage && newDocumentPage.focus();
}
2017-05-04 12:36:42 +00:00
});
2020-07-29 19:50:07 +00:00
if ( $panelUsers ) {
onResetUsers(storeUsers);
2020-07-29 19:50:07 +00:00
$panelUsers.on('shown.bs.dropdown', function () {
$userList.scroller && $userList.scroller.update({minScrollbarLength: 40, alwaysVisibleY: true});
});
2020-07-29 19:50:07 +00:00
$panelUsers.find('.cousers-menu')
.on('click', function(e) { return false; });
var editingUsers = storeUsers.getVisibleEditingCount();
2020-07-29 19:50:07 +00:00
$btnUsers.tooltip({
title: me.tipUsers,
2020-07-29 19:50:07 +00:00
placement: 'bottom',
html: true
});
$btnUsers.on('click', onUsersClick.bind(me));
$panelUsers[(editingUsers > 1 && appConfig && (appConfig.isEdit || appConfig.isRestrictedEdit)) ? 'show' : 'hide']();
updateDocNamePosition(appConfig);
}
2017-07-13 09:43:40 +00:00
if (appConfig.user.guest && appConfig.canRenameAnonymous) {
2022-02-03 20:14:59 +00:00
if (me.btnUserName) {
me.btnUserName.on('click', function (e) {
Common.NotificationCenter.trigger('user:rename');
});
}
2020-12-11 10:08:13 +00:00
}
if ( me.btnPrint ) {
me.btnPrint.updateHint(me.tipPrint + Common.Utils.String.platformKey('Ctrl+P'));
me.btnPrint.on('click', function (e) {
me.fireEvent('print', me);
});
}
2022-11-15 18:45:25 +00:00
if ( me.btnPrintQuick ) {
me.btnPrintQuick.updateHint(me.tipPrintQuick);
me.btnPrintQuick.on('click', function (e) {
me.fireEvent('print-quick', me);
});
}
if ( me.btnSave ) {
me.btnSave.updateHint(me.tipSave + Common.Utils.String.platformKey('Ctrl+S'));
me.btnSave.on('click', function (e) {
me.fireEvent('save', me);
});
}
if ( me.btnUndo ) {
me.btnUndo.updateHint(me.tipUndo + Common.Utils.String.platformKey('Ctrl+Z'));
me.btnUndo.on('click', function (e) {
me.fireEvent('undo', me);
});
}
if ( me.btnRedo ) {
me.btnRedo.updateHint(me.tipRedo + Common.Utils.String.platformKey('Ctrl+Y'));
me.btnRedo.on('click', function (e) {
me.fireEvent('redo', me);
});
}
2017-07-13 09:43:40 +00:00
if ( !mode.isEdit ) {
if ( me.btnDownload ) {
2017-08-07 14:10:03 +00:00
me.btnDownload.updateHint(me.tipDownload);
2017-07-13 09:43:40 +00:00
me.btnDownload.on('click', function (e) {
me.fireEvent('downloadas', ['original']);
});
}
if ( me.btnEdit ) {
2017-07-21 10:44:07 +00:00
me.btnEdit.updateHint(me.tipGoEdit);
me.btnEdit.on('click', function (e) {
me.fireEvent('go:editor', me);
});
}
2017-07-13 09:43:40 +00:00
}
2018-03-21 11:11:03 +00:00
2022-04-12 14:08:08 +00:00
if (me.btnSearch)
me.btnSearch.updateHint(me.tipSearch + Common.Utils.String.platformKey('Ctrl+F'));
if (appConfig.isEdit && !(appConfig.customization && appConfig.customization.compactHeader))
Common.NotificationCenter.on('window:resize', onResize);
}
2022-01-11 00:35:54 +00:00
function onFocusDocName(e){
var me = this;
2022-05-11 13:08:19 +00:00
me.imgCrypted && me.imgCrypted.toggleClass('hidden', true);
2022-01-13 00:29:02 +00:00
me.isSaveDocName =false;
if(me.withoutExt) return;
var name = me.cutDocName($labelDocName.val());
2022-04-12 06:49:23 +00:00
me.withoutExt = true;
2022-01-11 00:35:54 +00:00
_.delay(function(){
2022-05-11 13:08:38 +00:00
me.setDocTitle(name);
$labelDocName.select();
2022-01-11 00:35:54 +00:00
},100);
}
2017-08-01 12:14:19 +00:00
function onDocNameKeyDown(e) {
var me = this;
var name = $labelDocName.val();
2017-08-01 12:14:19 +00:00
if ( e.keyCode == Common.UI.Keys.RETURN ) {
name = name.trim();
2022-01-13 00:29:02 +00:00
if ( !_.isEmpty(name) && me.cutDocName(me.documentCaption) !== name ) {
2022-04-28 22:33:39 +00:00
me.isSaveDocName =true;
2017-08-01 12:14:19 +00:00
if ( /[\t*\+:\"<>?|\\\\/]/gim.test(name) ) {
_.defer(function() {
Common.UI.error({
msg: (new Common.Views.RenameDialog).txtInvalidName + "*+:\"<>?|\/"
, callback: function() {
_.delay(function() {
$labelDocName.focus();
2022-01-13 00:29:02 +00:00
me.isSaveDocName =true;
2017-08-01 12:14:19 +00:00
}, 50);
}
});
})
2022-01-13 00:29:02 +00:00
} else
if(me.withoutExt) {
2022-01-13 16:44:46 +00:00
name = me.cutDocName(name);
2022-01-11 23:10:08 +00:00
me.options.wopi ? me.api.asc_wopi_renameFile(name) : Common.Gateway.requestRename(name);
2022-01-13 00:29:02 +00:00
name += me.fileExtention;
me.withoutExt = false;
2022-05-11 13:08:38 +00:00
me.setDocTitle(name);
2017-08-01 12:14:19 +00:00
Common.NotificationCenter.trigger('edit:complete', me);
}
2022-01-13 00:29:02 +00:00
2022-01-11 23:10:08 +00:00
} else {
Common.NotificationCenter.trigger('edit:complete', me);
2017-08-01 12:14:19 +00:00
}
} else
if ( e.keyCode == Common.UI.Keys.ESC ) {
Common.NotificationCenter.trigger('edit:complete', this);
} else {
2022-04-28 03:46:03 +00:00
_.delay(function(){
2022-05-11 13:08:38 +00:00
me.setDocTitle();
2022-04-28 03:46:03 +00:00
},10);
2017-08-01 12:14:19 +00:00
}
}
2017-03-01 13:33:12 +00:00
return {
options: {
branding: {},
documentCaption: '',
canBack: false
},
el: '#header',
// Compile our stats template
template: _.template(headerTemplate),
// Delegated events for creating new items, and clearing completed ones.
events: {
// 'click #header-logo': function (e) {}
},
initialize: function (options) {
var me = this;
2018-03-28 10:37:41 +00:00
this.options = this.options ? _.extend(this.options, options) : options;
2017-03-01 13:33:12 +00:00
this.documentCaption = this.options.documentCaption;
this.branding = this.options.customization;
this.isModified = false;
2017-03-01 13:33:12 +00:00
me.btnGoBack = new Common.UI.Button({
id: 'btn-goback',
cls: 'btn-header',
2019-11-27 16:43:44 +00:00
iconCls: 'toolbar__icon icon--inverse btn-goback',
dataHint: '0',
dataHintDirection: 'bottom',
dataHintOffset: 'big'
2017-03-01 13:33:12 +00:00
});
2016-03-11 00:48:53 +00:00
2017-03-29 09:01:34 +00:00
storeUsers = this.options.storeUsers;
storeUsers.bind({
add : onUsersChanged,
change : onUsersChanged,
reset : onResetUsers
2017-03-01 13:33:12 +00:00
});
2022-02-08 16:03:44 +00:00
me.btnSearch = new Common.UI.Button({
cls: 'btn-header no-caret',
iconCls: 'toolbar__icon icon--inverse btn-menu-search',
2022-02-09 18:15:36 +00:00
enableToggle: true,
2022-02-08 16:03:44 +00:00
dataHint: '0',
dataHintDirection: 'bottom',
dataHintOffset: 'big'
});
2020-12-14 19:45:30 +00:00
me.btnFavorite = new Common.UI.Button({
id: 'btn-favorite',
cls: 'btn-header',
2021-07-06 15:42:13 +00:00
iconCls: 'toolbar__icon icon--inverse btn-favorite',
dataHint: '0',
dataHintDirection: 'bottom',
dataHintOffset: 'big'
2020-12-14 19:45:30 +00:00
});
2019-05-13 11:45:17 +00:00
Common.NotificationCenter.on({
'app:ready': function(mode) {Common.Utils.asyncCall(onAppReady, me, mode);},
2022-02-04 11:51:13 +00:00
'app:face': function(mode) {Common.Utils.asyncCall(onAppShowed, me, mode);},
'tab:visible': function() {Common.Utils.asyncCall(updateDocNamePosition, me, appConfig);},
2022-02-04 11:51:13 +00:00
'collaboration:sharingdeny': function(mode) {Common.Utils.asyncCall(onLostEditRights, me, mode);}
2018-03-21 11:11:03 +00:00
});
Common.NotificationCenter.on('uitheme:changed', this.changeLogo.bind(this));
2017-03-01 13:33:12 +00:00
},
render: function (el, role) {
$(el).html(this.getPanel(role));
return this;
},
2017-05-04 12:36:42 +00:00
getPanel: function (role, config) {
2018-02-03 13:10:38 +00:00
var me = this;
function createTitleButton(iconid, slot, disabled, hintDirection, hintOffset, hintTitle) {
2018-02-03 13:10:38 +00:00
return (new Common.UI.Button({
cls: 'btn-header',
2019-11-27 16:43:44 +00:00
iconCls: iconid,
disabled: disabled === true,
dataHint:'0',
dataHintDirection: hintDirection ? hintDirection : (config.isDesktopApp ? 'right' : 'left'),
dataHintOffset: hintOffset ? hintOffset : (config.isDesktopApp ? '10, -18' : '10, 10'),
dataHintTitle: hintTitle
2018-02-03 13:10:38 +00:00
})).render(slot);
}
2017-05-04 12:36:42 +00:00
if ( role == 'left' && (!config || !config.isDesktopApp)) {
$html = $(templateLeftBox);
2017-03-01 13:33:12 +00:00
this.logo = $html.find('#header-logo');
2017-09-18 11:38:24 +00:00
if (this.branding && this.branding.logo && (this.branding.logo.image || this.branding.logo.imageDark) && this.logo) {
var image = Common.UI.Themes.isDarkTheme() ? (this.branding.logo.imageDark || this.branding.logo.image) : (this.branding.logo.image || this.branding.logo.imageDark);
this.logo.html('<img src="' + image + '" style="max-width:100px; max-height:20px; margin: 0;"/>');
2017-09-18 11:38:24 +00:00
this.logo.css({'background-image': 'none', width: 'auto'});
2018-11-13 08:40:35 +00:00
(this.branding.logo.url || this.branding.logo.url===undefined) && this.logo.addClass('link');
2017-09-18 11:38:24 +00:00
}
2017-03-01 13:33:12 +00:00
return $html;
} else
if ( role == 'right' ) {
2017-04-21 08:15:04 +00:00
var $html = $(_.template(templateRightBox)({
tipUsers: this.labelCoUsersDescr,
textShare: this.textShare
}));
2017-03-01 13:33:12 +00:00
if ( !$labelDocName ) {
$labelDocName = $html.find('#rib-doc-name');
2018-02-03 13:10:38 +00:00
if ( me.documentCaption ) {
setTimeout(function() { me.setDocTitle(me.documentCaption); }, 50);
2018-02-03 13:10:38 +00:00
}
2020-04-22 16:46:53 +00:00
} else {
$html.find('#rib-doc-name').hide();
}
2022-05-09 19:21:21 +00:00
this.setCanRename(!!this.options.canRename);
2018-02-03 13:10:38 +00:00
if ( this.options.canBack === true ) {
me.btnGoBack.render($html.find('#slot-btn-back'));
} else {
$html.find('#slot-btn-back').hide();
}
2017-03-01 13:33:12 +00:00
2020-12-15 14:28:12 +00:00
if ( this.options.favorite !== undefined && this.options.favorite!==null) {
2020-12-14 19:45:30 +00:00
me.btnFavorite.render($html.find('#slot-btn-favorite'));
me.btnFavorite.changeIcon(!!me.options.favorite ? {next: 'btn-in-favorite'} : {curr: 'btn-in-favorite'});
me.btnFavorite.updateHint(!me.options.favorite ? me.textAddFavorite : me.textRemoveFavorite);
} else {
$html.find('#slot-btn-favorite').hide();
}
2017-07-13 09:43:40 +00:00
if ( !config.isEdit ) {
2018-02-03 13:10:38 +00:00
if ( (config.canDownload || config.canDownloadOrigin) && !config.isOffline )
2021-10-08 17:00:17 +00:00
this.btnDownload = createTitleButton('toolbar__icon icon--inverse btn-download', $html.findById('#slot-hbtn-download'), undefined, 'bottom', 'big');
2017-07-13 09:43:40 +00:00
2018-02-03 13:10:38 +00:00
if ( config.canPrint )
this.btnPrint = createTitleButton('toolbar__icon icon--inverse btn-print', $html.findById('#slot-hbtn-print'), undefined, 'bottom', 'big', 'P');
2022-11-15 18:45:25 +00:00
if ( config.canQuickPrint )
this.btnPrintQuick = createTitleButton('toolbar__icon icon--inverse btn-print-quick', $html.findById('#slot-hbtn-print-quick'), undefined, 'bottom', 'big', 'Q');
2018-02-03 13:10:38 +00:00
if ( config.canEdit && config.canRequestEditRights )
2021-10-08 17:00:17 +00:00
this.btnEdit = createTitleButton('toolbar__icon icon--inverse btn-edit', $html.findById('#slot-hbtn-edit'), undefined, 'bottom', 'big');
2017-07-13 09:43:40 +00:00
}
2022-02-08 16:03:44 +00:00
me.btnSearch.render($html.find('#slot-btn-search'));
2017-07-13 09:43:40 +00:00
if (!config.isEdit || config.customization && !!config.customization.compactHeader) {
2022-02-04 09:13:13 +00:00
if (config.user.guest && config.canRenameAnonymous) {
me.btnUserName = new Common.UI.Button({
el: $html.findById('.slot-btn-user-name'),
cls: 'btn-header',
dataHint:'0',
dataHintDirection: 'bottom',
dataHintOffset: 'big',
visible: true
});
me.btnUserName.cmpEl.removeClass('hidden');
} else {
me.elUserName = $html.find('.btn-current-user');
me.elUserName.removeClass('hidden');
}
2022-02-04 09:13:13 +00:00
$btnUserName = $html.find('.color-user-name');
me.setUserName(me.options.userName);
}
2022-02-04 11:51:13 +00:00
if (!_readonlyRights && config && (config.sharingSettingsUrl && config.sharingSettingsUrl.length || config.canRequestSharingSettings)) {
me.btnShare = new Common.UI.Button({
cls: 'btn-header btn-header-share',
iconCls: 'toolbar__icon icon--inverse btn-users-share',
caption: me.textShare,
dataHint: '0',
dataHintDirection: 'bottom',
dataHintOffset: 'big'
});
me.btnShare.render($html.find('#slot-btn-share'));
} else {
$html.find('#slot-btn-share').hide();
}
$userList = $html.find('.cousers-list');
$panelUsers = $html.find('.box-cousers');
$btnUsers = $panelUsers.find('> .btn-users');
$panelUsers.hide();
2018-02-03 13:10:38 +00:00
return $html;
} else
if ( role == 'title' ) {
var $html = $(_.template(templateTitleBox)());
!!$labelDocName && $labelDocName.hide().off(); // hide document title if it was created in right box
$labelDocName = $html.find('#title-doc-name');
setTimeout(function() { me.setDocTitle(me.documentCaption); }, 50);
2022-04-12 06:49:23 +00:00
me.options.wopi && $labelDocName.attr('maxlength', me.options.wopi.FileNameMaxLength);
2018-02-03 13:10:38 +00:00
2022-02-04 09:13:13 +00:00
if (config.user.guest && config.canRenameAnonymous) {
me.btnUserName = new Common.UI.Button({
el: $html.findById('.slot-btn-user-name'),
cls: 'btn-header',
dataHint:'0',
dataHintDirection: 'bottom',
dataHintOffset: 'big',
visible: true
});
me.btnUserName.cmpEl.removeClass('hidden');
}
2022-02-03 20:14:59 +00:00
else {
me.elUserName = $html.find('.btn-current-user');
me.elUserName.removeClass('hidden');
}
2022-02-04 09:13:13 +00:00
$btnUserName = $html.find('.color-user-name');
2018-02-03 13:10:38 +00:00
me.setUserName(me.options.userName);
if ( config.canPrint && config.isEdit ) {
me.btnPrint = createTitleButton('toolbar__icon icon--inverse btn-print', $html.findById('#slot-btn-dt-print'), true, undefined, undefined, 'P');
2018-02-03 13:10:38 +00:00
}
2022-11-15 18:45:25 +00:00
if ( config.canQuickPrint && config.isEdit )
me.btnPrintQuick = createTitleButton('toolbar__icon icon--inverse btn-print-quick', $html.findById('#slot-btn-dt-print-quick'), true, undefined, undefined, 'Q');
2018-02-03 13:10:38 +00:00
me.btnSave = createTitleButton('toolbar__icon icon--inverse btn-save', $html.findById('#slot-btn-dt-save'), true, undefined, undefined, 'S');
me.btnUndo = createTitleButton('toolbar__icon icon--inverse btn-undo', $html.findById('#slot-btn-dt-undo'), true, undefined, undefined, 'Z');
me.btnRedo = createTitleButton('toolbar__icon icon--inverse btn-redo', $html.findById('#slot-btn-dt-redo'), true, undefined, undefined, 'Y');
2018-02-03 13:10:38 +00:00
2017-03-01 13:33:12 +00:00
return $html;
}
},
setVisible: function (visible) {
// visible
// ? this.show()
// : this.hide();
},
setBranding: function (value) {
var element;
this.branding = value;
2018-02-07 08:11:58 +00:00
if ( value ) {
if ( value.logo &&(value.logo.image || value.logo.imageDark)) {
var image = Common.UI.Themes.isDarkTheme() ? (value.logo.imageDark || value.logo.image) : (value.logo.image || value.logo.imageDark);
2018-02-07 08:11:58 +00:00
element = $('#header-logo');
if (element) {
element.html('<img src="' + image + '" style="max-width:100px; max-height:20px; margin: 0;"/>');
2018-02-07 08:11:58 +00:00
element.css({'background-image': 'none', width: 'auto'});
2018-11-13 08:40:35 +00:00
(value.logo.url || value.logo.url===undefined) && element.addClass('link');
2018-02-07 08:11:58 +00:00
}
}
2016-09-26 10:54:25 +00:00
}
2017-03-01 13:33:12 +00:00
},
changeLogo: function () {
var value = this.branding;
if ( value && value.logo && value.logo.image && value.logo.imageDark && (value.logo.image !== value.logo.imageDark)) { // change logo when image and imageDark are different
var image = Common.UI.Themes.isDarkTheme() ? (value.logo.imageDark || value.logo.image) : (value.logo.image || value.logo.imageDark);
$('#header-logo img').attr('src', image);
}
},
setDocumentCaption: function(value) {
2017-03-01 13:33:12 +00:00
!value && (value = '');
this.documentCaption = value;
2022-01-13 00:29:02 +00:00
var idx = this.documentCaption.lastIndexOf('.');
if (idx>0)
this.fileExtention = this.documentCaption.substring(idx);
this.isModified && (value += '*');
if ( $labelDocName ) {
2022-05-11 13:08:38 +00:00
this.setDocTitle( value );
2017-08-01 12:14:19 +00:00
}
2017-03-01 13:33:12 +00:00
return value;
},
getDocumentCaption: function () {
return this.documentCaption;
},
setDocumentChanged: function (changed) {
this.isModified = changed;
var _name = this.documentCaption;
2017-03-01 13:33:12 +00:00
changed && (_name += '*');
2022-05-11 13:08:38 +00:00
this.setDocTitle(_name);
2017-03-01 13:33:12 +00:00
},
setCanBack: function (value, text) {
2018-02-03 13:10:38 +00:00
this.options.canBack = value;
2017-03-01 13:33:12 +00:00
this.btnGoBack[value ? 'show' : 'hide']();
if (value)
this.btnGoBack.updateHint((text && typeof text == 'string') ? text : this.textBack);
updateDocNamePosition(appConfig);
2018-02-03 13:10:38 +00:00
return this;
2017-03-01 13:33:12 +00:00
},
getCanBack: function () {
2018-02-03 13:10:38 +00:00
return this.options.canBack;
2017-03-01 13:33:12 +00:00
},
2020-12-14 19:45:30 +00:00
setFavorite: function (value) {
this.options.favorite = value;
2020-12-15 14:28:12 +00:00
this.btnFavorite[value!==undefined && value!==null ? 'show' : 'hide']();
2020-12-14 19:45:30 +00:00
this.btnFavorite.changeIcon(!!value ? {next: 'btn-in-favorite'} : {curr: 'btn-in-favorite'});
this.btnFavorite.updateHint(!value ? this.textAddFavorite : this.textRemoveFavorite);
updateDocNamePosition(appConfig);
2020-12-14 19:45:30 +00:00
return this;
},
getFavorite: function () {
return this.options.favorite;
},
2017-03-01 13:33:12 +00:00
setCanRename: function (rename) {
var me = this;
me.options.canRename = rename;
if ( $labelDocName ) {
var label = $labelDocName;
if ( rename ) {
label.removeAttr('disabled').tooltip({
title: me.txtRename,
placement: 'cursor'}
);
2017-08-15 11:44:59 +00:00
label.on({
'keydown': onDocNameKeyDown.bind(this),
2022-01-11 00:35:54 +00:00
'focus': onFocusDocName.bind(this),
2017-08-15 11:44:59 +00:00
'blur': function (e) {
2022-05-11 13:08:19 +00:00
me.imgCrypted && me.imgCrypted.toggleClass('hidden', false);
Common.Utils.isGecko && (label[0].selectionStart = label[0].selectionEnd = 0);
2022-01-13 00:29:02 +00:00
if(!me.isSaveDocName) {
me.withoutExt = false;
2022-05-11 13:08:38 +00:00
me.setDocTitle(me.documentCaption);
2022-01-13 00:29:02 +00:00
}
2022-01-13 16:13:44 +00:00
},
'paste': function (e) {
setTimeout(function() {
var name = me.cutDocName($labelDocName.val());
2022-05-11 13:08:38 +00:00
me.setDocTitle(name);
2022-01-13 16:13:44 +00:00
});
2017-08-15 11:44:59 +00:00
}
});
} else {
2017-08-15 11:44:59 +00:00
label.off();
label.attr('disabled', true);
var tip = label.data('bs.tooltip');
if ( tip ) {
tip.options.title = '';
tip.setContent();
}
2017-08-01 12:14:19 +00:00
}
label.attr('data-can-copy', rename);
2017-08-01 12:14:19 +00:00
}
2017-03-01 13:33:12 +00:00
},
2022-01-13 00:29:02 +00:00
cutDocName: function(name) {
2022-04-21 23:25:44 +00:00
if(name.length <= this.fileExtention.length) return name;
2022-01-13 00:29:02 +00:00
var idx =name.length - this.fileExtention.length;
return (name.substring(idx) == this.fileExtention) ? name.substring(0, idx) : name ;
},
2022-05-11 13:08:38 +00:00
setDocTitle: function(name){
var width = this.getTextWidth(name || $labelDocName.val());
(width>=0) && $labelDocName.width(width);
name && (width>=0) && $labelDocName.val(name);
2022-05-11 13:08:19 +00:00
if (this._showImgCrypted && width>=0) {
this.imgCrypted.toggleClass('hidden', false);
this._showImgCrypted = false;
}
(width>=0) && onResize();
2022-04-28 03:46:03 +00:00
},
2022-04-12 06:49:23 +00:00
2022-04-28 18:36:08 +00:00
getTextWidth: function(text) {
if (!this._testCanvas ) {
var font = ($labelDocName.css('font-size') + ' ' + $labelDocName.css('font-family')).trim();
2022-04-28 18:36:08 +00:00
if (font) {
var canvas = document.createElement("canvas");
this._testCanvas = canvas.getContext('2d');
this._testCanvas.font = font;
}
2018-02-03 13:10:38 +00:00
}
2022-04-28 18:36:08 +00:00
return this._testCanvas ? this._testCanvas.measureText(text).width : -1;
2022-04-12 06:49:23 +00:00
},
2018-02-03 13:10:38 +00:00
setUserName: function(name) {
2022-02-03 20:14:59 +00:00
this.options.userName = name;
if ( this.btnUserName ) {
this.btnUserName.updateHint(name);
} else if (this.elUserName) {
this.elUserName.tooltip({
title: Common.Utils.String.htmlEncode(name),
placement: 'cursor',
html: true
});
2018-02-03 13:10:38 +00:00
}
2022-02-04 09:13:13 +00:00
$btnUserName && $btnUserName.text(this.getInitials(name));
2018-02-03 13:10:38 +00:00
return this;
},
getButton: function(type) {
if (type == 'save')
return this.btnSave;
2020-10-15 14:14:06 +00:00
else if (type == 'users')
return $panelUsers;
else if (type == 'share')
2022-02-04 11:51:13 +00:00
return this.btnShare;
},
lockHeaderBtns: function (alias, lock) {
var me = this;
if ( alias == 'users' ) {
if ( lock ) {
$btnUsers.addClass('disabled').attr('disabled', 'disabled');
} else {
2021-10-08 17:00:17 +00:00
$btnUsers.removeClass('disabled').removeAttr('disabled');
2022-02-04 11:51:13 +00:00
}
if (me.btnShare) {
me.btnShare.setDisabled(lock);
}
2021-03-26 22:21:17 +00:00
} else if ( alias == 'rename-user' ) {
2022-02-03 20:14:59 +00:00
if (me.btnUserName) {
2021-03-26 22:21:17 +00:00
me.btnUserName.setDisabled(lock);
}
} else {
2018-07-30 14:08:33 +00:00
var _lockButton = function (btn) {
if ( btn ) {
if ( lock ) {
btn.keepState = {
disabled: btn.isDisabled()
};
2018-03-21 11:11:03 +00:00
btn.setDisabled( true );
} else {
btn.setDisabled( btn.keepState && btn.keepState.disabled || lock);
2018-03-21 11:11:03 +00:00
delete btn.keepState;
}
}
2018-07-30 14:08:33 +00:00
};
2018-03-21 11:11:03 +00:00
switch ( alias ) {
case 'undo': _lockButton(me.btnUndo); break;
case 'redo': _lockButton(me.btnRedo); break;
default: break;
}
}
},
2022-02-04 09:13:13 +00:00
getInitials: function(name) {
var fio = name.split(' ');
var initials = fio[0].substring(0, 1).toUpperCase();
for (var i = fio.length-1; i>0; i--) {
if (fio[i][0]!=='(' && fio[i][0]!==')') {
initials += fio[i].substring(0, 1).toUpperCase();
break;
}
}
return initials;
2018-03-21 11:28:28 +00:00
},
2017-03-01 13:33:12 +00:00
textBack: 'Go to Documents',
2017-04-19 12:09:44 +00:00
txtRename: 'Rename',
txtAccessRights: 'Change access rights',
tipAccessRights: 'Manage document access rights',
labelCoUsersDescr: 'Document is currently being edited by several users.',
2017-07-21 10:44:07 +00:00
tipViewUsers: 'View users and manage document access rights',
tipUsers: 'View users',
2017-07-21 10:44:07 +00:00
tipDownload: 'Download file',
tipPrint: 'Print file',
tipGoEdit: 'Edit current file',
tipSave: 'Save',
tipUndo: 'Undo',
2018-03-21 11:28:28 +00:00
tipRedo: 'Redo',
textCompactView: 'Hide Toolbar',
textHideStatusBar: 'Combine sheet and status bars',
2018-03-21 11:28:28 +00:00
textHideLines: 'Hide Rulers',
textZoom: 'Zoom',
textAdvSettings: 'Advanced Settings',
2020-12-14 19:45:30 +00:00
tipViewSettings: 'View Settings',
textRemoveFavorite: 'Remove from Favorites',
2021-04-26 16:49:10 +00:00
textAddFavorite: 'Mark as favorite',
2022-04-12 14:08:08 +00:00
textHideNotes: 'Hide Notes',
tipSearch: 'Search',
2022-11-15 18:45:25 +00:00
textShare: 'Share',
tipPrintQuick: 'Quick print'
2017-03-01 13:33:12 +00:00
}
}(), Common.Views.Header || {}))
2016-03-11 00:48:53 +00:00
});