Merge branch release/v7.2.0 into master
1
.gitignore
vendored
|
|
@ -3,6 +3,7 @@ Thumbs.db
|
||||||
.DS_Store
|
.DS_Store
|
||||||
/deploy
|
/deploy
|
||||||
build/node_modules
|
build/node_modules
|
||||||
|
build/plugins/**/node_modules/
|
||||||
build/sprites/node_modules/
|
build/sprites/node_modules/
|
||||||
vendor/framework7-react/
|
vendor/framework7-react/
|
||||||
apps/documenteditor/embed/resources/less/node_modules
|
apps/documenteditor/embed/resources/less/node_modules
|
||||||
|
|
|
||||||
|
|
@ -115,6 +115,7 @@
|
||||||
address: 'New-York, 125f-25',
|
address: 'New-York, 125f-25',
|
||||||
mail: 'support@gmail.com',
|
mail: 'support@gmail.com',
|
||||||
www: 'www.superpuper.com',
|
www: 'www.superpuper.com',
|
||||||
|
phone: '1234567890',
|
||||||
info: 'Some info',
|
info: 'Some info',
|
||||||
logo: '',
|
logo: '',
|
||||||
logoDark: '', // logo for dark theme
|
logoDark: '', // logo for dark theme
|
||||||
|
|
@ -219,8 +220,9 @@
|
||||||
uiTheme: 'theme-dark' // set interface theme: id or default-dark/default-light
|
uiTheme: 'theme-dark' // set interface theme: id or default-dark/default-light
|
||||||
},
|
},
|
||||||
coEditing: {
|
coEditing: {
|
||||||
mode: 'fast', // <coauthoring mode>, 'fast' or 'strict'. if 'fast' and 'customization.autosave'=false -> set 'customization.autosave'=true
|
mode: 'fast', // <coauthoring mode>, 'fast' or 'strict'. if 'fast' and 'customization.autosave'=false -> set 'customization.autosave'=true. 'fast' - default for editor
|
||||||
change: true, // can change co-authoring mode
|
// for viewer: 'strict' is default, offline viewer; 'fast' - live viewer, show changes from other users
|
||||||
|
change: true, // can change co-authoring mode. true - default for editor, false - default for viewer
|
||||||
},
|
},
|
||||||
plugins: {
|
plugins: {
|
||||||
autostart: ['asc.{FFE1F462-1EA2-4391-990D-4CC84940B754}'],
|
autostart: ['asc.{FFE1F462-1EA2-4391-990D-4CC84940B754}'],
|
||||||
|
|
@ -913,7 +915,7 @@
|
||||||
if ( typeof(customization) == 'object' && ( customization.toolbarNoTabs ||
|
if ( typeof(customization) == 'object' && ( customization.toolbarNoTabs ||
|
||||||
(config.editorConfig.targetApp!=='desktop') && (customization.loaderName || customization.loaderLogo))) {
|
(config.editorConfig.targetApp!=='desktop') && (customization.loaderName || customization.loaderLogo))) {
|
||||||
index = "/index_loader.html";
|
index = "/index_loader.html";
|
||||||
} else if (config.editorConfig.mode === 'editdiagram' || config.editorConfig.mode === 'editmerge')
|
} else if (config.editorConfig.mode === 'editdiagram' || config.editorConfig.mode === 'editmerge' || config.editorConfig.mode === 'editole')
|
||||||
index = "/index_internal.html";
|
index = "/index_internal.html";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
@ -947,7 +949,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config.editorConfig && (config.editorConfig.mode == 'editdiagram' || config.editorConfig.mode == 'editmerge'))
|
if (config.editorConfig && (config.editorConfig.mode == 'editdiagram' || config.editorConfig.mode == 'editmerge' || config.editorConfig.mode == 'editole'))
|
||||||
params += "&internal=true";
|
params += "&internal=true";
|
||||||
|
|
||||||
if (config.frameEditorId)
|
if (config.frameEditorId)
|
||||||
|
|
@ -972,25 +974,6 @@
|
||||||
return params;
|
return params;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getFrameTitle(config) {
|
|
||||||
var title = 'Powerful online editor for text documents, spreadsheets, and presentations';
|
|
||||||
var appMap = {
|
|
||||||
'text': 'text documents',
|
|
||||||
'spreadsheet': 'spreadsheets',
|
|
||||||
'presentation': 'presentations',
|
|
||||||
'word': 'text documents',
|
|
||||||
'cell': 'spreadsheets',
|
|
||||||
'slide': 'presentations'
|
|
||||||
};
|
|
||||||
|
|
||||||
if (typeof config.documentType === 'string') {
|
|
||||||
var app = appMap[config.documentType.toLowerCase()];
|
|
||||||
if (app)
|
|
||||||
title = 'Powerful online editor for ' + app;
|
|
||||||
}
|
|
||||||
return title;
|
|
||||||
}
|
|
||||||
|
|
||||||
function createIframe(config) {
|
function createIframe(config) {
|
||||||
var iframe = document.createElement("iframe");
|
var iframe = document.createElement("iframe");
|
||||||
|
|
||||||
|
|
@ -1000,11 +983,11 @@
|
||||||
iframe.align = "top";
|
iframe.align = "top";
|
||||||
iframe.frameBorder = 0;
|
iframe.frameBorder = 0;
|
||||||
iframe.name = "frameEditor";
|
iframe.name = "frameEditor";
|
||||||
iframe.title = getFrameTitle(config);
|
config.title && (typeof config.title === 'string') && (iframe.title = config.title);
|
||||||
iframe.allowFullscreen = true;
|
iframe.allowFullscreen = true;
|
||||||
iframe.setAttribute("allowfullscreen",""); // for IE11
|
iframe.setAttribute("allowfullscreen",""); // for IE11
|
||||||
iframe.setAttribute("onmousewheel",""); // for Safari on Mac
|
iframe.setAttribute("onmousewheel",""); // for Safari on Mac
|
||||||
iframe.setAttribute("allow", "autoplay; camera; microphone; display-capture");
|
iframe.setAttribute("allow", "autoplay; camera; microphone; display-capture; clipboard-write;");
|
||||||
|
|
||||||
if (config.type == "mobile")
|
if (config.type == "mobile")
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -262,7 +262,7 @@ div {
|
||||||
var config = {
|
var config = {
|
||||||
"width": "100%",
|
"width": "100%",
|
||||||
"height": "100%",
|
"height": "100%",
|
||||||
"type": "desktop",
|
"type": queryParams.embed==="1" ? "embedded" : "desktop",
|
||||||
"documentType": documentType,
|
"documentType": documentType,
|
||||||
"token": token,
|
"token": token,
|
||||||
"document": {
|
"document": {
|
||||||
|
|
@ -302,7 +302,7 @@ div {
|
||||||
"uiTheme": queryParams.thm==="1" ? "default-light" : (queryParams.thm==="2" ? "default-dark" : undefined)
|
"uiTheme": queryParams.thm==="1" ? "default-light" : (queryParams.thm==="2" ? "default-dark" : undefined)
|
||||||
},
|
},
|
||||||
"coEditing": {
|
"coEditing": {
|
||||||
"mode": "fast",
|
"mode": userAuth.mode !== "view" ? "fast" : "strict",
|
||||||
"change": false
|
"change": false
|
||||||
},
|
},
|
||||||
"wopi": {
|
"wopi": {
|
||||||
|
|
|
||||||
|
|
@ -57,6 +57,16 @@
|
||||||
|
|
||||||
$dlgShare.find('#btn-copyshort').on('click', copytext.bind(this, $dlgShare.find('#id-short-url')));
|
$dlgShare.find('#btn-copyshort').on('click', copytext.bind(this, $dlgShare.find('#id-short-url')));
|
||||||
$dlgShare.find('.share-buttons > span').on('click', function(e){
|
$dlgShare.find('.share-buttons > span').on('click', function(e){
|
||||||
|
if ( window.config ) {
|
||||||
|
const key = $(e.target).attr('data-name');
|
||||||
|
const btn = config.btnsShare[key];
|
||||||
|
if ( btn && btn.getUrl ) {
|
||||||
|
window.open(btn.getUrl(appConfig.shareUrl, appConfig.docTitle), btn.target || '',
|
||||||
|
btn.features || 'menubar=no,toolbar=no,resizable=yes,scrollbars=yes,height=300,width=600');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var _url;
|
var _url;
|
||||||
switch ($(e.target).attr('data-name')) {
|
switch ($(e.target).attr('data-name')) {
|
||||||
case 'facebook':
|
case 'facebook':
|
||||||
|
|
|
||||||
|
|
@ -36,6 +36,11 @@
|
||||||
!common.utils && (common.utils = {});
|
!common.utils && (common.utils = {});
|
||||||
|
|
||||||
common.utils = new(function(){
|
common.utils = new(function(){
|
||||||
|
var userAgent = navigator.userAgent.toLowerCase(),
|
||||||
|
check = function(regex){
|
||||||
|
return regex.test(userAgent);
|
||||||
|
},
|
||||||
|
isMac = check(/macintosh|mac os x/);
|
||||||
return {
|
return {
|
||||||
openLink: function(url) {
|
openLink: function(url) {
|
||||||
if (url) {
|
if (url) {
|
||||||
|
|
@ -100,7 +105,9 @@
|
||||||
return prop;
|
return prop;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
|
|
||||||
|
isMac : isMac
|
||||||
};
|
};
|
||||||
})();
|
})();
|
||||||
}();
|
}();
|
||||||
|
|
|
||||||
77
apps/common/embed/lib/view/SearchBar.js
Normal file
|
|
@ -0,0 +1,77 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2020
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha
|
||||||
|
* street, Riga, Latvia, EU, LV-1050.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SearchBar.js
|
||||||
|
*
|
||||||
|
* Created by Julia Svinareva on 27.04.2022
|
||||||
|
* Copyright (c) 2022 Ascensio System SIA. All rights reserved.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
!window.common && (window.common = {});
|
||||||
|
!common.view && (common.view = {});
|
||||||
|
common.view.SearchBar = new(function() {
|
||||||
|
var tpl = '<div class="asc-window search-window" style="display: none;">' +
|
||||||
|
'<div class="body">{body}</div>' +
|
||||||
|
'</div>';
|
||||||
|
var tplBody = '<input type="text" id="search-bar-text" placeholder="{textFind}" autocomplete="off">' +
|
||||||
|
'<div class="tools">' +
|
||||||
|
'<button id="search-bar-back" class="svg-icon search-arrow-up"></button>' +
|
||||||
|
'<button id="search-bar-next" class="svg-icon search-arrow-down"></button>' +
|
||||||
|
'<button id="search-bar-close" class="svg-icon search-close"></button>' +
|
||||||
|
'</div>';
|
||||||
|
|
||||||
|
return {
|
||||||
|
create: function(parent) {
|
||||||
|
!parent && (parent = 'body');
|
||||||
|
|
||||||
|
var _$dlg = $(tpl
|
||||||
|
.replace(/\{body}/, tplBody)
|
||||||
|
.replace(/\{textFind}/, this.textFind))
|
||||||
|
.appendTo(parent)
|
||||||
|
.attr('id', 'dlg-search');
|
||||||
|
|
||||||
|
return _$dlg;
|
||||||
|
},
|
||||||
|
|
||||||
|
disableNavButtons: function (resultNumber, allResults) {
|
||||||
|
var disable = $('#search-bar-text').val() === '' || !allResults;
|
||||||
|
$('#search-bar-back').attr({disabled: disable});
|
||||||
|
$('#search-bar-next').attr({disabled: disable});
|
||||||
|
},
|
||||||
|
|
||||||
|
textFind: 'Find'
|
||||||
|
|
||||||
|
};
|
||||||
|
})();
|
||||||
|
|
@ -73,6 +73,20 @@ common.view.modals = new(function() {
|
||||||
|
|
||||||
var _$dlg;
|
var _$dlg;
|
||||||
if (name == 'share') {
|
if (name == 'share') {
|
||||||
|
if ( window.config && window.config.btnsShare ) {
|
||||||
|
let _btns = [];
|
||||||
|
for (const key of Object.keys(config.btnsShare))
|
||||||
|
_btns.push(`<span class="svg big-${key}" data-name="${key}"></span>`);
|
||||||
|
|
||||||
|
if ( _btns ) {
|
||||||
|
let $sharebox = $(_tplbody_share);
|
||||||
|
$sharebox.find('.autotest').prevAll().remove();
|
||||||
|
$sharebox.eq(1).prepend(_btns.join(''));
|
||||||
|
|
||||||
|
_tplbody_share = $("<div>").append($sharebox).html();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
_$dlg = $(tplDialog
|
_$dlg = $(tplDialog
|
||||||
.replace(/\{title}/, this.txtShare)
|
.replace(/\{title}/, this.txtShare)
|
||||||
.replace(/\{body}/, _tplbody_share)
|
.replace(/\{body}/, _tplbody_share)
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
<svg width="380" height="40" viewBox="0 0 380 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg width="580" height="40" viewBox="0 0 580 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<g id="icon-menu-sprite Embedded Viewer">
|
<g id="icon-menu-sprite Embedded Viewer">
|
||||||
<g id="view-settings">
|
<g id="view-settings">
|
||||||
<path id="Vector" d="M17 26H3V27H17V26Z" fill="white"/>
|
<path id="Vector" d="M17 26H3V27H17V26Z" fill="white"/>
|
||||||
|
|
@ -148,5 +148,73 @@
|
||||||
<g id="close_2">
|
<g id="close_2">
|
||||||
<path id="Vector 73_2" d="M366 5L375 14M375 5L366 14" stroke="black" stroke-width="1.5"/>
|
<path id="Vector 73_2" d="M366 5L375 14M375 5L366 14" stroke="black" stroke-width="1.5"/>
|
||||||
</g>
|
</g>
|
||||||
|
<g id="сut">
|
||||||
|
<circle id="Ellipse 103" cx="385.5" cy="13.5" r="2" stroke="black"/>
|
||||||
|
<circle id="Ellipse 104" cx="385.5" cy="6.5" r="2" stroke="black"/>
|
||||||
|
<path id="Rectangle 1552" d="M387.188 7.56689L398.446 14.0669V14.0669C398.17 14.5452 397.559 14.7091 397.08 14.4329L386.688 8.43292L387.188 7.56689Z" fill="black"/>
|
||||||
|
<path id="Rectangle 1553" d="M386.688 11.5669L397.08 5.56689C397.558 5.29075 398.17 5.45463 398.446 5.93292V5.93292L387.188 12.4329L386.688 11.5669Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="сut_2">
|
||||||
|
<circle id="Ellipse 103_2" cx="385.5" cy="33.5" r="2" stroke="white"/>
|
||||||
|
<circle id="Ellipse 104_2" cx="385.5" cy="26.5" r="2" stroke="white"/>
|
||||||
|
<path id="Rectangle 1552_2" d="M387.188 27.5669L398.446 34.0669V34.0669C398.17 34.5452 397.559 34.7091 397.08 34.4329L386.688 28.4329L387.188 27.5669Z" fill="white"/>
|
||||||
|
<path id="Rectangle 1553_2" d="M386.688 31.5669L397.08 25.5669C397.558 25.2908 398.17 25.4546 398.446 25.9329V25.9329L387.188 32.4329L386.688 31.5669Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="copy">
|
||||||
|
<path id="Union_27" fill-rule="evenodd" clip-rule="evenodd" d="M404 5H412V7H413V5C413 4.44772 412.552 4 412 4H404C403.448 4 403 4.44772 403 5V12C403 12.5523 403.448 13 404 13H406V12H404V5ZM411 6H405V7H411V6ZM408 9V16H416V9H408ZM408 8C407.448 8 407 8.44772 407 9V16C407 16.5523 407.448 17 408 17H416C416.552 17 417 16.5523 417 16V9C417 8.44772 416.552 8 416 8H408ZM406 8H405V9H406V8ZM405 10H406V11H405V10ZM415 11V10H409V11H415ZM415 12V13H409V12H415ZM415 15V14H409V15H415Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="copy_2">
|
||||||
|
<path id="Union_28" fill-rule="evenodd" clip-rule="evenodd" d="M404 25H412V27H413V25C413 24.4477 412.552 24 412 24H404C403.448 24 403 24.4477 403 25V32C403 32.5523 403.448 33 404 33H406V32H404V25ZM411 26H405V27H411V26ZM408 29V36H416V29H408ZM408 28C407.448 28 407 28.4477 407 29V36C407 36.5523 407.448 37 408 37H416C416.552 37 417 36.5523 417 36V29C417 28.4477 416.552 28 416 28H408ZM406 28H405V29H406V28ZM405 30H406V31H405V30ZM415 31V30H409V31H415ZM415 32V33H409V32H415ZM415 35V34H409V35H415Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="paste">
|
||||||
|
<path id="Union_29" fill-rule="evenodd" clip-rule="evenodd" d="M426 3H432V4H434C434.552 4 435 4.44772 435 5V7H434V5H432V6H426V5H424V12H426V13H424C423.448 13 423 12.5523 423 12V5C423 4.44772 423.448 4 424 4H426V3ZM436 16V9H428V16H436ZM428 8C427.448 8 427 8.44772 427 9V16C427 16.5523 427.448 17 428 17H436C436.552 17 437 16.5523 437 16V9C437 8.44772 436.552 8 436 8H428ZM429 11V10H435V11H429ZM435 12H429V13H435V12ZM429 15V14H435V15H429Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="paste_2">
|
||||||
|
<path id="Union_30" fill-rule="evenodd" clip-rule="evenodd" d="M426 23H432V24H434C434.552 24 435 24.4477 435 25V27H434V25H432V26H426V25H424V32H426V33H424C423.448 33 423 32.5523 423 32V25C423 24.4477 423.448 24 424 24H426V23ZM436 36V29H428V36H436ZM428 28C427.448 28 427 28.4477 427 29V36C427 36.5523 427.448 37 428 37H436C436.552 37 437 36.5523 437 36V29C437 28.4477 436.552 28 436 28H428ZM429 31V30H435V31H429ZM435 32H429V33H435V32ZM429 35V34H435V35H429Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="redo">
|
||||||
|
<path id="Vector" d="M469.1 7C471.1 7 473.2 8.3 474.5 9.5L477 7V14H470L472.5 11.5C471.7 10.2 469.9 9.1 468.2 9.1C465.7 9.1 462.8 10.8 462.5 13.2C462.9 9.7 465.5 7 469.1 7Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="redo_2">
|
||||||
|
<path id="Vector_2" d="M469.1 27C471.1 27 473.2 28.3 474.5 29.5L477 27V34H470L472.5 31.5C471.7 30.2 469.9 29.1 468.2 29.1C465.7 29.1 462.8 30.8 462.5 33.2C462.9 29.7 465.5 27 469.1 27Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="undo">
|
||||||
|
<path id="Vector_3" d="M450.9 7C448.9 7 446.8 8.3 445.5 9.5L443 7V14H450L447.5 11.5C448.3 10.2 450.1 9.1 451.8 9.1C454.3 9.1 457.2 10.8 457.5 13.2C457.1 9.7 454.5 7 450.9 7Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="undo_2">
|
||||||
|
<path id="Vector_4" d="M450.9 27C448.9 27 446.8 28.3 445.5 29.5L443 27V34H450L447.5 31.5C448.3 30.2 450.1 29.1 451.8 29.1C454.3 29.1 457.2 30.8 457.5 33.2C457.1 29.7 454.5 27 450.9 27Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="search">
|
||||||
|
<path id="Union_31" fill-rule="evenodd" clip-rule="evenodd" d="M493 8.5C493 10.9853 490.985 13 488.5 13C486.015 13 484 10.9853 484 8.5C484 6.01472 486.015 4 488.5 4C490.985 4 493 6.01472 493 8.5ZM492.02 12.7266C491.066 13.5217 489.839 14 488.5 14C485.462 14 483 11.5376 483 8.5C483 5.46243 485.462 3 488.5 3C491.538 3 494 5.46243 494 8.5C494 9.83875 493.522 11.0658 492.727 12.0195L496.854 16.1465L496.146 16.8536L492.02 12.7266Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="search_2">
|
||||||
|
<path id="Union_32" fill-rule="evenodd" clip-rule="evenodd" d="M493 28.5C493 30.9853 490.985 33 488.5 33C486.015 33 484 30.9853 484 28.5C484 26.0147 486.015 24 488.5 24C490.985 24 493 26.0147 493 28.5ZM492.02 32.7266C491.066 33.5217 489.839 34 488.5 34C485.462 34 483 31.5376 483 28.5C483 25.4624 485.462 23 488.5 23C491.538 23 494 25.4624 494 28.5C494 29.8387 493.522 31.0658 492.727 32.0195L496.854 36.1465L496.146 36.8536L492.02 32.7266Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="btn-sheet-view">
|
||||||
|
<path id="Union_33" fill-rule="evenodd" clip-rule="evenodd" d="M509.93 13C507.552 13 505.45 11.8151 504.184 10C505.45 8.18485 507.552 7 509.93 7C512.307 7 514.409 8.18486 515.675 10C514.409 11.8151 512.307 13 509.93 13ZM509.93 6C512.891 6 515.476 7.6088 516.859 10C515.476 12.3912 512.891 14 509.93 14C506.969 14 504.383 12.3912 503 10C504.383 7.60879 506.969 6 509.93 6ZM509.93 12C511.034 12 511.93 11.1046 511.93 10C511.93 8.89543 511.034 8 509.93 8C508.825 8 507.93 8.89543 507.93 10C507.93 11.1046 508.825 12 509.93 12Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="btn-sheet-view_2">
|
||||||
|
<path id="Union_34" fill-rule="evenodd" clip-rule="evenodd" d="M509.93 33C507.552 33 505.45 31.8151 504.184 30C505.45 28.1849 507.552 27 509.93 27C512.307 27 514.409 28.1849 515.675 30C514.409 31.8151 512.307 33 509.93 33ZM509.93 26C512.891 26 515.476 27.6088 516.859 30C515.476 32.3912 512.891 34 509.93 34C506.969 34 504.383 32.3912 503 30C504.383 27.6088 506.969 26 509.93 26ZM509.93 32C511.034 32 511.93 31.1046 511.93 30C511.93 28.8954 511.034 28 509.93 28C508.825 28 507.93 28.8954 507.93 30C507.93 31.1046 508.825 32 509.93 32Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="hide-password">
|
||||||
|
<path id="Subtract" fill-rule="evenodd" clip-rule="evenodd" d="M530.948 6.05196C530.638 6.01766 530.321 6 530 6C526.91 6 524.243 7.63505 523 10C523.439 10.8356 524.056 11.5801 524.807 12.1935L525.518 11.4821C524.979 11.055 524.519 10.5539 524.158 10C525.311 8.23092 527.473 7 530 7C530 7 530 7 530 7L530.948 6.05196ZM530 13C532.527 12.9999 534.689 11.769 535.842 10C535.481 9.44626 535.021 8.94525 534.482 8.51821L535.194 7.80682C535.944 8.42019 536.561 9.16455 537 10C535.757 12.3649 533.09 14 530 14C529.679 14 529.363 13.9824 529.052 13.9481L530 13Z" fill="black"/>
|
||||||
|
<path id="Vector 169" d="M525 15L535 5" stroke="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="hide-password_2">
|
||||||
|
<path id="Subtract_2" fill-rule="evenodd" clip-rule="evenodd" d="M530.948 26.052C530.638 26.0177 530.321 26 530 26C526.91 26 524.243 27.6351 523 30C523.439 30.8356 524.056 31.5801 524.807 32.1935L525.518 31.4821C524.979 31.055 524.519 30.5539 524.158 30C525.311 28.2309 527.473 27 530 27C530 27 530 27 530 27L530.948 26.052ZM530 33C532.527 32.9999 534.689 31.769 535.842 30C535.481 29.4463 535.021 28.9453 534.482 28.5182L535.194 27.8068C535.944 28.4202 536.561 29.1646 537 30C535.757 32.3649 533.09 34 530 34C529.679 34 529.363 33.9824 529.052 33.9481L530 33Z" fill="white"/>
|
||||||
|
<path id="Vector 169_2" d="M525 35L535 25" stroke="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="arrow-up">
|
||||||
|
<path id="Union_4" fill-rule="evenodd" clip-rule="evenodd" d="M550 6.29297L550.354 6.64652L555.854 12.1465L555.146 12.8536L550 7.70718L544.854 12.8536L544.146 12.1465L549.646 6.64652L550 6.29297Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="arrow-up_2">
|
||||||
|
<path id="Union_3" fill-rule="evenodd" clip-rule="evenodd" d="M550 26.293L550.354 26.6465L555.854 32.1465L555.146 32.8536L550 27.7072L544.854 32.8536L544.146 32.1465L549.646 26.6465L550 26.293Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="arrow-down">
|
||||||
|
<path id="Union_2" fill-rule="evenodd" clip-rule="evenodd" d="M570 13.7071L570.354 13.3536L575.854 7.85359L575.146 7.14648L570 12.2929L564.854 7.14648L564.146 7.85359L569.646 13.3536L570 13.7071Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="arrow-down_2">
|
||||||
|
<path id="Union" fill-rule="evenodd" clip-rule="evenodd" d="M570 33.7071L570.354 33.3536L575.854 27.8536L575.146 27.1465L570 32.2929L564.854 27.1465L564.146 27.8536L569.646 33.3536L570 33.7071Z" fill="white"/>
|
||||||
|
</g>
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 22 KiB |
|
|
@ -503,7 +503,7 @@
|
||||||
@icon-height: 20px;
|
@icon-height: 20px;
|
||||||
.svg-icon {
|
.svg-icon {
|
||||||
background: data-uri('../../../../common/embed/resources/img/icon-menu-sprite.svg') no-repeat;
|
background: data-uri('../../../../common/embed/resources/img/icon-menu-sprite.svg') no-repeat;
|
||||||
background-size: @icon-width*19 @icon-height*2;
|
background-size: @icon-width*29 @icon-height*2;
|
||||||
|
|
||||||
&.download {
|
&.download {
|
||||||
background-position: -@icon-width 0;
|
background-position: -@icon-width 0;
|
||||||
|
|
@ -557,6 +557,18 @@
|
||||||
&.more-vertical {
|
&.more-vertical {
|
||||||
background-position: -@icon-width*14 0;
|
background-position: -@icon-width*14 0;
|
||||||
}
|
}
|
||||||
|
&.search-close {
|
||||||
|
background-position: -@icon-width*18 0;
|
||||||
|
}
|
||||||
|
&.search {
|
||||||
|
background-position: -@icon-width*24 0;
|
||||||
|
}
|
||||||
|
&.search-arrow-up {
|
||||||
|
background-position: -@icon-width*27 0;
|
||||||
|
}
|
||||||
|
&.search-arrow-down {
|
||||||
|
background-position: -@icon-width*28 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.mi-icon {
|
.mi-icon {
|
||||||
|
|
@ -786,3 +798,72 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#id-search {
|
||||||
|
button.active {
|
||||||
|
background-color: @btnActiveColor !important;
|
||||||
|
background-position: -@icon-width*19 -@icon-height;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.search-window {
|
||||||
|
width: 301px;
|
||||||
|
height: 54px;
|
||||||
|
z-index: 50;
|
||||||
|
position: fixed;
|
||||||
|
|
||||||
|
box-shadow: 0 5px 15px rgba(0,0,0,0.2);
|
||||||
|
border-radius: 5px;
|
||||||
|
border: solid 1px #CBCBCB;
|
||||||
|
|
||||||
|
.body {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
border-radius: 5px;
|
||||||
|
background-color: #FFFFFF;
|
||||||
|
display: flex;
|
||||||
|
padding: 16px;
|
||||||
|
|
||||||
|
input {
|
||||||
|
width: 192px;
|
||||||
|
height: 22px;
|
||||||
|
border-radius: 2px;
|
||||||
|
box-shadow: none;
|
||||||
|
border: solid 1px #CFCFCF;
|
||||||
|
padding: 1px 3px;
|
||||||
|
color: #444444;
|
||||||
|
font-size: 11px;
|
||||||
|
|
||||||
|
&::placeholder {
|
||||||
|
color: #CFCFCF;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:focus {
|
||||||
|
border-color: #848484;
|
||||||
|
outline: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.tools {
|
||||||
|
display: flex;
|
||||||
|
|
||||||
|
button {
|
||||||
|
border: none;
|
||||||
|
margin-left: 7px;
|
||||||
|
cursor: pointer;
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
opacity: 0.8;
|
||||||
|
|
||||||
|
&:hover:not(:disabled) {
|
||||||
|
background-color: #d8dadc;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:disabled {
|
||||||
|
opacity: 0.4;
|
||||||
|
cursor: default;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
<svg width="480" height="40" viewBox="0 0 480 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg width="580" height="40" viewBox="0 0 580 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<g id="icon-menu-sprite Embedded Viewer">
|
<g id="icon-menu-sprite Embedded Viewer">
|
||||||
<g id="view-settings">
|
<g id="view-settings">
|
||||||
<path id="Vector" d="M17 26H3V27H17V26Z" fill="white"/>
|
<path id="Vector" d="M17 26H3V27H17V26Z" fill="white"/>
|
||||||
|
|
@ -184,5 +184,37 @@
|
||||||
<g id="undo_2">
|
<g id="undo_2">
|
||||||
<path id="Vector_4" d="M450.9 27C448.9 27 446.8 28.3 445.5 29.5L443 27V34H450L447.5 31.5C448.3 30.2 450.1 29.1 451.8 29.1C454.3 29.1 457.2 30.8 457.5 33.2C457.1 29.7 454.5 27 450.9 27Z" fill="white"/>
|
<path id="Vector_4" d="M450.9 27C448.9 27 446.8 28.3 445.5 29.5L443 27V34H450L447.5 31.5C448.3 30.2 450.1 29.1 451.8 29.1C454.3 29.1 457.2 30.8 457.5 33.2C457.1 29.7 454.5 27 450.9 27Z" fill="white"/>
|
||||||
</g>
|
</g>
|
||||||
|
<g id="search">
|
||||||
|
<path id="Union_31" fill-rule="evenodd" clip-rule="evenodd" d="M493 8.5C493 10.9853 490.985 13 488.5 13C486.015 13 484 10.9853 484 8.5C484 6.01472 486.015 4 488.5 4C490.985 4 493 6.01472 493 8.5ZM492.02 12.7266C491.066 13.5217 489.839 14 488.5 14C485.462 14 483 11.5376 483 8.5C483 5.46243 485.462 3 488.5 3C491.538 3 494 5.46243 494 8.5C494 9.83875 493.522 11.0658 492.727 12.0195L496.854 16.1465L496.146 16.8536L492.02 12.7266Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="search_2">
|
||||||
|
<path id="Union_32" fill-rule="evenodd" clip-rule="evenodd" d="M493 28.5C493 30.9853 490.985 33 488.5 33C486.015 33 484 30.9853 484 28.5C484 26.0147 486.015 24 488.5 24C490.985 24 493 26.0147 493 28.5ZM492.02 32.7266C491.066 33.5217 489.839 34 488.5 34C485.462 34 483 31.5376 483 28.5C483 25.4624 485.462 23 488.5 23C491.538 23 494 25.4624 494 28.5C494 29.8387 493.522 31.0658 492.727 32.0195L496.854 36.1465L496.146 36.8536L492.02 32.7266Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="btn-sheet-view">
|
||||||
|
<path id="Union_33" fill-rule="evenodd" clip-rule="evenodd" d="M509.93 13C507.552 13 505.45 11.8151 504.184 10C505.45 8.18485 507.552 7 509.93 7C512.307 7 514.409 8.18486 515.675 10C514.409 11.8151 512.307 13 509.93 13ZM509.93 6C512.891 6 515.476 7.6088 516.859 10C515.476 12.3912 512.891 14 509.93 14C506.969 14 504.383 12.3912 503 10C504.383 7.60879 506.969 6 509.93 6ZM509.93 12C511.034 12 511.93 11.1046 511.93 10C511.93 8.89543 511.034 8 509.93 8C508.825 8 507.93 8.89543 507.93 10C507.93 11.1046 508.825 12 509.93 12Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="btn-sheet-view_2">
|
||||||
|
<path id="Union_34" fill-rule="evenodd" clip-rule="evenodd" d="M509.93 33C507.552 33 505.45 31.8151 504.184 30C505.45 28.1849 507.552 27 509.93 27C512.307 27 514.409 28.1849 515.675 30C514.409 31.8151 512.307 33 509.93 33ZM509.93 26C512.891 26 515.476 27.6088 516.859 30C515.476 32.3912 512.891 34 509.93 34C506.969 34 504.383 32.3912 503 30C504.383 27.6088 506.969 26 509.93 26ZM509.93 32C511.034 32 511.93 31.1046 511.93 30C511.93 28.8954 511.034 28 509.93 28C508.825 28 507.93 28.8954 507.93 30C507.93 31.1046 508.825 32 509.93 32Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="hide-password">
|
||||||
|
<path id="Subtract" fill-rule="evenodd" clip-rule="evenodd" d="M530.948 6.05196C530.638 6.01766 530.321 6 530 6C526.91 6 524.243 7.63505 523 10C523.439 10.8356 524.056 11.5801 524.807 12.1935L525.518 11.4821C524.979 11.055 524.519 10.5539 524.158 10C525.311 8.23092 527.473 7 530 7C530 7 530 7 530 7L530.948 6.05196ZM530 13C532.527 12.9999 534.689 11.769 535.842 10C535.481 9.44626 535.021 8.94525 534.482 8.51821L535.194 7.80682C535.944 8.42019 536.561 9.16455 537 10C535.757 12.3649 533.09 14 530 14C529.679 14 529.363 13.9824 529.052 13.9481L530 13Z" fill="black"/>
|
||||||
|
<path id="Vector 169" d="M525 15L535 5" stroke="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="hide-password_2">
|
||||||
|
<path id="Subtract_2" fill-rule="evenodd" clip-rule="evenodd" d="M530.948 26.052C530.638 26.0177 530.321 26 530 26C526.91 26 524.243 27.6351 523 30C523.439 30.8356 524.056 31.5801 524.807 32.1935L525.518 31.4821C524.979 31.055 524.519 30.5539 524.158 30C525.311 28.2309 527.473 27 530 27C530 27 530 27 530 27L530.948 26.052ZM530 33C532.527 32.9999 534.689 31.769 535.842 30C535.481 29.4463 535.021 28.9453 534.482 28.5182L535.194 27.8068C535.944 28.4202 536.561 29.1646 537 30C535.757 32.3649 533.09 34 530 34C529.679 34 529.363 33.9824 529.052 33.9481L530 33Z" fill="white"/>
|
||||||
|
<path id="Vector 169_2" d="M525 35L535 25" stroke="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="arrow-up">
|
||||||
|
<path id="Union_4" fill-rule="evenodd" clip-rule="evenodd" d="M550 6.29297L550.354 6.64652L555.854 12.1465L555.146 12.8536L550 7.70718L544.854 12.8536L544.146 12.1465L549.646 6.64652L550 6.29297Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="arrow-up_2">
|
||||||
|
<path id="Union_3" fill-rule="evenodd" clip-rule="evenodd" d="M550 26.293L550.354 26.6465L555.854 32.1465L555.146 32.8536L550 27.7072L544.854 32.8536L544.146 32.1465L549.646 26.6465L550 26.293Z" fill="white"/>
|
||||||
|
</g>
|
||||||
|
<g id="arrow-down">
|
||||||
|
<path id="Union_2" fill-rule="evenodd" clip-rule="evenodd" d="M570 13.7071L570.354 13.3536L575.854 7.85359L575.146 7.14648L570 12.2929L564.854 7.14648L564.146 7.85359L569.646 13.3536L570 13.7071Z" fill="black"/>
|
||||||
|
</g>
|
||||||
|
<g id="arrow-down_2">
|
||||||
|
<path id="Union" fill-rule="evenodd" clip-rule="evenodd" d="M570 33.7071L570.354 33.3536L575.854 27.8536L575.146 27.1465L570 32.2929L564.854 27.1465L564.146 27.8536L569.646 33.3536L570 33.7071Z" fill="white"/>
|
||||||
|
</g>
|
||||||
</g>
|
</g>
|
||||||
</svg>
|
</svg>
|
||||||
|
|
|
||||||
|
Before Width: | Height: | Size: 16 KiB After Width: | Height: | Size: 20 KiB |
|
|
@ -5,6 +5,7 @@
|
||||||
@import "../../../../common/main/resources/less/colors-table.less";
|
@import "../../../../common/main/resources/less/colors-table.less";
|
||||||
@import "../../../../common/main/resources/less/colors-table-classic.less";
|
@import "../../../../common/main/resources/less/colors-table-classic.less";
|
||||||
@import "../../../../common/main/resources/less/colors-table-dark.less";
|
@import "../../../../common/main/resources/less/colors-table-dark.less";
|
||||||
|
@import "../../../../common/main/resources/less/colors-table-dark-contrast.less";
|
||||||
|
|
||||||
// Core variables and mixins
|
// Core variables and mixins
|
||||||
//@import "../../../../../vendor/bootstrap/less/variables.less";
|
//@import "../../../../../vendor/bootstrap/less/variables.less";
|
||||||
|
|
@ -81,6 +82,7 @@
|
||||||
@import "../../../../common/main/resources/less/checkbox.less";
|
@import "../../../../common/main/resources/less/checkbox.less";
|
||||||
@import "../../../../common/main/resources/less/opendialog.less";
|
@import "../../../../common/main/resources/less/opendialog.less";
|
||||||
@import "../../../../common/main/resources/less/advanced-settings-window.less";
|
@import "../../../../common/main/resources/less/advanced-settings-window.less";
|
||||||
|
@import "../../../../common/main/resources/less/searchdialog.less";
|
||||||
|
|
||||||
@toolbarBorderColor: @border-toolbar-ie;
|
@toolbarBorderColor: @border-toolbar-ie;
|
||||||
@toolbarBorderColor: @border-toolbar;
|
@toolbarBorderColor: @border-toolbar;
|
||||||
|
|
@ -225,7 +227,7 @@
|
||||||
background: data-uri('../../../../common/main/resources/img/header/dark-logo_s.svg') no-repeat;
|
background: data-uri('../../../../common/main/resources/img/header/dark-logo_s.svg') no-repeat;
|
||||||
}
|
}
|
||||||
|
|
||||||
.theme-dark {
|
.theme-type-dark {
|
||||||
.brand-logo {
|
.brand-logo {
|
||||||
background: data-uri('../../../../common/main/resources/img/header/header-logo_s.svg') no-repeat;
|
background: data-uri('../../../../common/main/resources/img/header/header-logo_s.svg') no-repeat;
|
||||||
}
|
}
|
||||||
|
|
@ -431,7 +433,7 @@
|
||||||
@icon-width: 20px;
|
@icon-width: 20px;
|
||||||
@icon-height: 20px;
|
@icon-height: 20px;
|
||||||
|
|
||||||
.theme-dark {
|
.theme-type-dark {
|
||||||
@neg-value: -@icon-height;
|
@neg-value: -@icon-height;
|
||||||
--icon-normal-top: @neg-value;
|
--icon-normal-top: @neg-value;
|
||||||
}
|
}
|
||||||
|
|
@ -439,7 +441,7 @@
|
||||||
|
|
||||||
.svg-icon {
|
.svg-icon {
|
||||||
background: data-uri('../../../../common/forms/resources/img/icon-menu-sprite.svg') no-repeat;
|
background: data-uri('../../../../common/forms/resources/img/icon-menu-sprite.svg') no-repeat;
|
||||||
background-size: @icon-width*24 @icon-height*2;
|
background-size: @icon-width*29 @icon-height*2;
|
||||||
|
|
||||||
&.download {
|
&.download {
|
||||||
background-position: -@icon-width 0;
|
background-position: -@icon-width 0;
|
||||||
|
|
@ -531,6 +533,30 @@
|
||||||
background-position: -@icon-width*23 0;
|
background-position: -@icon-width*23 0;
|
||||||
background-position: -@icon-width*23 @icon-normal-top;
|
background-position: -@icon-width*23 @icon-normal-top;
|
||||||
}
|
}
|
||||||
|
&.search {
|
||||||
|
background-position: -@icon-width*24 0;
|
||||||
|
background-position: -@icon-width*24 @icon-normal-top;
|
||||||
|
}
|
||||||
|
&.btn-sheet-view {
|
||||||
|
background-position: -@icon-width*25 0;
|
||||||
|
background-position: -@icon-width*25 @icon-normal-top;
|
||||||
|
}
|
||||||
|
&.hide-password {
|
||||||
|
background-position: -@icon-width*26 0;
|
||||||
|
background-position: -@icon-width*26 @icon-normal-top;
|
||||||
|
}
|
||||||
|
&.search-close {
|
||||||
|
background-position: -@icon-width*18 0;
|
||||||
|
background-position: -@icon-width*18 @icon-normal-top;
|
||||||
|
}
|
||||||
|
&.search-arrow-up {
|
||||||
|
background-position: -@icon-width*27 0;
|
||||||
|
background-position: -@icon-width*27 @icon-normal-top;
|
||||||
|
}
|
||||||
|
&.search-arrow-down {
|
||||||
|
background-position: -@icon-width*28 0;
|
||||||
|
background-position: -@icon-width*28 @icon-normal-top;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.btn {
|
.btn {
|
||||||
|
|
@ -671,17 +697,6 @@
|
||||||
.fontsize(@font-size-large);
|
.fontsize(@font-size-large);
|
||||||
}
|
}
|
||||||
|
|
||||||
.input-field-btn {
|
.search-bar {
|
||||||
.select-button {
|
z-index: 50;
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.input-error {
|
|
||||||
&:before {
|
|
||||||
right: 3px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
input {
|
|
||||||
padding-right: 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
@ -40,7 +40,8 @@ Common.Locale = new(function() {
|
||||||
var loadcallback,
|
var loadcallback,
|
||||||
apply = false,
|
apply = false,
|
||||||
defLang = '{{DEFAULT_LANG}}',
|
defLang = '{{DEFAULT_LANG}}',
|
||||||
currentLang = defLang;
|
currentLang = defLang,
|
||||||
|
_4letterLangs = ['pt-pt', 'zh-tw'];
|
||||||
|
|
||||||
var _applyLocalization = function(callback) {
|
var _applyLocalization = function(callback) {
|
||||||
try {
|
try {
|
||||||
|
|
@ -87,6 +88,10 @@ Common.Locale = new(function() {
|
||||||
return currentLang;
|
return currentLang;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var _getDefaultLanguage = function() {
|
||||||
|
return defLang;
|
||||||
|
};
|
||||||
|
|
||||||
var _getLoadedLanguage = function() {
|
var _getLoadedLanguage = function() {
|
||||||
return loadedLang;
|
return loadedLang;
|
||||||
};
|
};
|
||||||
|
|
@ -100,11 +105,16 @@ Common.Locale = new(function() {
|
||||||
|
|
||||||
var _requireLang = function (l) {
|
var _requireLang = function (l) {
|
||||||
typeof l != 'string' && (l = null);
|
typeof l != 'string' && (l = null);
|
||||||
var lang = (l || _getUrlParameterByName('lang') || defLang).split(/[\-_]/)[0];
|
var lang = (l || _getUrlParameterByName('lang') || defLang);
|
||||||
|
var idx4Letters = _4letterLangs.indexOf(lang.replace('_', '-').toLowerCase()); // try to load 4 letters language
|
||||||
|
lang = (idx4Letters<0) ? lang.split(/[\-_]/)[0] : _4letterLangs[idx4Letters];
|
||||||
currentLang = lang;
|
currentLang = lang;
|
||||||
fetch('locale/' + lang + '.json')
|
fetch('locale/' + lang + '.json')
|
||||||
.then(function(response) {
|
.then(function(response) {
|
||||||
if (!response.ok) {
|
if (!response.ok) {
|
||||||
|
if (idx4Letters>=0) { // try to load 2-letters language
|
||||||
|
throw new Error('4letters error');
|
||||||
|
}
|
||||||
currentLang = defLang;
|
currentLang = defLang;
|
||||||
if (lang != defLang)
|
if (lang != defLang)
|
||||||
/* load default lang if fetch failed */
|
/* load default lang if fetch failed */
|
||||||
|
|
@ -128,6 +138,12 @@ Common.Locale = new(function() {
|
||||||
l10n = json || {};
|
l10n = json || {};
|
||||||
apply && _applyLocalization();
|
apply && _applyLocalization();
|
||||||
}).catch(function(e) {
|
}).catch(function(e) {
|
||||||
|
if ( /4letters/.test(e) ) {
|
||||||
|
return setTimeout(function(){
|
||||||
|
_requireLang(lang.split(/[\-_]/)[0]);
|
||||||
|
}, 0);
|
||||||
|
}
|
||||||
|
|
||||||
if ( !/loaded/.test(e) && currentLang != defLang && defLang && defLang.length < 3 ) {
|
if ( !/loaded/.test(e) && currentLang != defLang && defLang && defLang.length < 3 ) {
|
||||||
return setTimeout(function(){
|
return setTimeout(function(){
|
||||||
_requireLang(defLang)
|
_requireLang(defLang)
|
||||||
|
|
@ -158,7 +174,8 @@ Common.Locale = new(function() {
|
||||||
return {
|
return {
|
||||||
apply: _applyLocalization,
|
apply: _applyLocalization,
|
||||||
get: _get,
|
get: _get,
|
||||||
getCurrentLanguage: _getCurrentLanguage
|
getCurrentLanguage: _getCurrentLanguage,
|
||||||
|
getDefaultLanguage: _getDefaultLanguage
|
||||||
};
|
};
|
||||||
|
|
||||||
})();
|
})();
|
||||||
|
|
|
||||||
|
|
@ -210,8 +210,10 @@ define([
|
||||||
templateBtnIcon +
|
templateBtnIcon +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'<div class="inner-box-caption">' +
|
'<div class="inner-box-caption">' +
|
||||||
'<span class="caption"><%= caption %></span>' +
|
'<span class="caption"><%= caption %>' +
|
||||||
'<i class="caret"></i>' +
|
'<i class="caret"></i>' +
|
||||||
|
'</span>' +
|
||||||
|
'<i class="caret compact-caret"></i>' +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'</button>' +
|
'</button>' +
|
||||||
'</div>';
|
'</div>';
|
||||||
|
|
@ -225,12 +227,38 @@ define([
|
||||||
'</button>' +
|
'</button>' +
|
||||||
'<button type="button" class="btn <%= cls %> inner-box-caption dropdown-toggle" data-toggle="dropdown" data-hint="<%= dataHint %>" data-hint-direction="<%= dataHintDirection %>" data-hint-offset="<%= dataHintOffset %>" <% if (dataHintTitle) { %> data-hint-title="<%= dataHintTitle %>" <% } %>>' +
|
'<button type="button" class="btn <%= cls %> inner-box-caption dropdown-toggle" data-toggle="dropdown" data-hint="<%= dataHint %>" data-hint-direction="<%= dataHintDirection %>" data-hint-offset="<%= dataHintOffset %>" <% if (dataHintTitle) { %> data-hint-title="<%= dataHintTitle %>" <% } %>>' +
|
||||||
'<span class="btn-fixflex-vcenter">' +
|
'<span class="btn-fixflex-vcenter">' +
|
||||||
'<span class="caption"><%= caption %></span>' +
|
'<span class="caption"><%= caption %>' +
|
||||||
'<i class="caret"></i>' +
|
'<i class="caret"></i>' +
|
||||||
'</span>' +
|
'</span>' +
|
||||||
|
'<i class="caret compact-caret"></i>' +
|
||||||
|
'</span>' +
|
||||||
'</button>' +
|
'</button>' +
|
||||||
'</div>';
|
'</div>';
|
||||||
|
|
||||||
|
var getWidthOfCaption = function (txt) {
|
||||||
|
var el = document.createElement('span');
|
||||||
|
el.style.fontSize = '11px';
|
||||||
|
el.style.fontFamily = 'Arial, Helvetica, "Helvetica Neue", sans-serif';
|
||||||
|
el.style.position = "absolute";
|
||||||
|
el.style.top = '-1000px';
|
||||||
|
el.style.left = '-1000px';
|
||||||
|
el.innerHTML = txt;
|
||||||
|
document.body.appendChild(el);
|
||||||
|
var result = el.offsetWidth;
|
||||||
|
document.body.removeChild(el);
|
||||||
|
return result;
|
||||||
|
};
|
||||||
|
|
||||||
|
var getShortText = function (txt, max) {
|
||||||
|
var lastIndex = txt.length - 1,
|
||||||
|
word = txt;
|
||||||
|
while (getWidthOfCaption(word) > max) {
|
||||||
|
word = txt.slice(0, lastIndex).trim() + '...';
|
||||||
|
lastIndex--;
|
||||||
|
}
|
||||||
|
return word;
|
||||||
|
};
|
||||||
|
|
||||||
Common.UI.Button = Common.UI.BaseView.extend({
|
Common.UI.Button = Common.UI.BaseView.extend({
|
||||||
options : {
|
options : {
|
||||||
id : null,
|
id : null,
|
||||||
|
|
@ -320,6 +348,37 @@ define([
|
||||||
me.render(me.options.parentEl);
|
me.render(me.options.parentEl);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getCaptionWithBreaks: function (caption) {
|
||||||
|
var words = caption.split(' '),
|
||||||
|
newCaption = null,
|
||||||
|
maxWidth = 85 - 4;
|
||||||
|
if (words.length > 1) {
|
||||||
|
maxWidth = !!this.menu || this.split === true ? maxWidth - 10 : maxWidth;
|
||||||
|
if (words.length < 3) {
|
||||||
|
words[1] = getShortText(words[1], maxWidth);
|
||||||
|
newCaption = words[0] + '<br>' + words[1];
|
||||||
|
} else {
|
||||||
|
if (getWidthOfCaption(words[0] + ' ' + words[1]) < maxWidth) { // first and second words in first line
|
||||||
|
words[2] = getShortText(words[2], maxWidth);
|
||||||
|
newCaption = words[0] + ' ' + words[1] + '<br>' + words[2];
|
||||||
|
} else if (getWidthOfCaption(words[1] + ' ' + words[2]) < maxWidth) { // second and third words in second line
|
||||||
|
words[2] = getShortText(words[2], maxWidth);
|
||||||
|
newCaption = words[0] + '<br>' + words[1] + ' ' + words[2];
|
||||||
|
} else {
|
||||||
|
words[1] = getShortText(words[1] + ' ' + words[2], maxWidth);
|
||||||
|
newCaption = words[0] + '<br>' + words[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
var width = getWidthOfCaption(caption);
|
||||||
|
newCaption = width < maxWidth ? caption : getShortText(caption, maxWidth);
|
||||||
|
if (!!this.menu || this.split === true) {
|
||||||
|
newCaption += '<br>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return newCaption;
|
||||||
|
},
|
||||||
|
|
||||||
render: function(parentEl) {
|
render: function(parentEl) {
|
||||||
var me = this;
|
var me = this;
|
||||||
|
|
||||||
|
|
@ -341,6 +400,10 @@ define([
|
||||||
} else {
|
} else {
|
||||||
this.template = _.template(templateHugeCaption);
|
this.template = _.template(templateHugeCaption);
|
||||||
}
|
}
|
||||||
|
var newCaption = this.getCaptionWithBreaks(this.caption);
|
||||||
|
if (newCaption) {
|
||||||
|
me.caption = newCaption;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
me.cmpEl = $(this.template({
|
me.cmpEl = $(this.template({
|
||||||
|
|
@ -748,15 +811,19 @@ define([
|
||||||
|
|
||||||
setCaption: function(caption) {
|
setCaption: function(caption) {
|
||||||
if (this.caption != caption) {
|
if (this.caption != caption) {
|
||||||
|
if ( /icon-top/.test(this.cls) && !!this.caption && /huge/.test(this.cls) ) {
|
||||||
|
var newCaption = this.getCaptionWithBreaks(caption);
|
||||||
|
this.caption = newCaption || caption;
|
||||||
|
} else
|
||||||
this.caption = caption;
|
this.caption = caption;
|
||||||
|
|
||||||
if (this.rendered) {
|
if (this.rendered) {
|
||||||
var captionNode = this.cmpEl.find('.caption');
|
var captionNode = this.cmpEl.find('.caption');
|
||||||
|
|
||||||
if (captionNode.length > 0) {
|
if (captionNode.length > 0) {
|
||||||
captionNode.text(caption);
|
captionNode.html(this.caption);
|
||||||
} else {
|
} else {
|
||||||
this.cmpEl.find('button:first').addBack().filter('button').text(caption);
|
this.cmpEl.find('button:first').addBack().filter('button').html(this.caption);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -456,6 +456,13 @@ define([
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
focus: function () {
|
||||||
|
var me = this;
|
||||||
|
me.enableKeyEvents && me.monthPicker && _.delay(function() {
|
||||||
|
me.monthPicker.focus();
|
||||||
|
}, 10);
|
||||||
|
},
|
||||||
|
|
||||||
textJanuary: 'January',
|
textJanuary: 'January',
|
||||||
textFebruary: 'February',
|
textFebruary: 'February',
|
||||||
textMarch: 'March',
|
textMarch: 'March',
|
||||||
|
|
|
||||||
|
|
@ -55,12 +55,15 @@ define([
|
||||||
|
|
||||||
getPicker: function(color, colors) {
|
getPicker: function(color, colors) {
|
||||||
if (!this.colorPicker) {
|
if (!this.colorPicker) {
|
||||||
this.colorPicker = new Common.UI.ThemeColorPalette({
|
var config = {
|
||||||
el: this.cmpEl.find('#' + this.menu.id + '-color-menu'),
|
el: this.cmpEl.find('#' + this.menu.id + '-color-menu'),
|
||||||
transparent: this.options.transparent,
|
|
||||||
value: color,
|
value: color,
|
||||||
colors: colors
|
colors: colors
|
||||||
});
|
};
|
||||||
|
(this.options.transparent!==undefined) && (config['transparent'] = this.options.transparent);
|
||||||
|
(this.options.hideEmptyColors!==undefined) && (config['hideEmptyColors'] = this.options.hideEmptyColors);
|
||||||
|
|
||||||
|
this.colorPicker = new Common.UI.ThemeColorPalette(config);
|
||||||
this.colorPicker.on('select', _.bind(this.onColorSelect, this));
|
this.colorPicker.on('select', _.bind(this.onColorSelect, this));
|
||||||
this.cmpEl.find('#' + this.menu.id + '-color-new').on('click', _.bind(this.addNewColor, this));
|
this.cmpEl.find('#' + this.menu.id + '-color-new').on('click', _.bind(this.addNewColor, this));
|
||||||
if (this.options.auto) {
|
if (this.options.auto) {
|
||||||
|
|
@ -80,7 +83,7 @@ define([
|
||||||
getMenu: function(options) {
|
getMenu: function(options) {
|
||||||
if (typeof this.menu !== 'object') {
|
if (typeof this.menu !== 'object') {
|
||||||
options = options || this.options;
|
options = options || this.options;
|
||||||
var height = options.paletteHeight || 240,
|
var height = options.paletteHeight ? options.paletteHeight + 'px' : 'auto',
|
||||||
id = Common.UI.getId(),
|
id = Common.UI.getId(),
|
||||||
auto = [];
|
auto = [];
|
||||||
if (options.auto) {
|
if (options.auto) {
|
||||||
|
|
@ -98,7 +101,8 @@ define([
|
||||||
cls: 'shifted-left',
|
cls: 'shifted-left',
|
||||||
additionalAlign: options.additionalAlign,
|
additionalAlign: options.additionalAlign,
|
||||||
items: (options.additionalItems ? options.additionalItems : []).concat(auto).concat([
|
items: (options.additionalItems ? options.additionalItems : []).concat(auto).concat([
|
||||||
{ template: _.template('<div id="' + id + '-color-menu" style="width: 169px; height:' + height + 'px; margin: 10px;"></div>') },
|
{ template: _.template('<div id="' + id + '-color-menu" style="width: 164px; height:' + height + '; display: inline-block;"></div>') },
|
||||||
|
{caption: '--'},
|
||||||
{
|
{
|
||||||
id: id + '-color-new',
|
id: id + '-color-new',
|
||||||
template: _.template('<a tabindex="-1" type="menuitem" style="">' + this.textNewColor + '</a>')
|
template: _.template('<a tabindex="-1" type="menuitem" style="">' + this.textNewColor + '</a>')
|
||||||
|
|
|
||||||
|
|
@ -358,6 +358,9 @@ define([
|
||||||
Common.NotificationCenter.trigger('menu:hide', this, isFromInputControl);
|
Common.NotificationCenter.trigger('menu:hide', this, isFromInputControl);
|
||||||
if (this.options.takeFocusOnClose) {
|
if (this.options.takeFocusOnClose) {
|
||||||
var me = this;
|
var me = this;
|
||||||
|
(me._input && me._input.length>0 && !me.editable) && (me._input[0].selectionStart===me._input[0].selectionEnd) && setTimeout(function() {
|
||||||
|
me._input[0].selectionStart = me._input[0].selectionEnd = 0;
|
||||||
|
},1);
|
||||||
setTimeout(function(){me.focus();}, 1);
|
setTimeout(function(){me.focus();}, 1);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -66,12 +66,12 @@ define([
|
||||||
spriteCols = 1,
|
spriteCols = 1,
|
||||||
applicationPixelRatio = Common.Utils.applicationPixelRatio();
|
applicationPixelRatio = Common.Utils.applicationPixelRatio();
|
||||||
|
|
||||||
if (typeof window['AscDesktopEditor'] === 'object') {
|
if ( Common.Controllers.Desktop.isActive() ) {
|
||||||
thumbs[0].path = window['AscDesktopEditor'].getFontsSprite('');
|
thumbs[0].path = Common.Controllers.Desktop.call('getFontsSprite');
|
||||||
thumbs[1].path = window['AscDesktopEditor'].getFontsSprite('@1.25x');
|
thumbs[1].path = Common.Controllers.Desktop.call('getFontsSprite', '@1.25x');
|
||||||
thumbs[2].path = window['AscDesktopEditor'].getFontsSprite('@1.5x');
|
thumbs[2].path = Common.Controllers.Desktop.call('getFontsSprite', '@1.5x');
|
||||||
thumbs[3].path = window['AscDesktopEditor'].getFontsSprite('@1.75x');
|
thumbs[3].path = Common.Controllers.Desktop.call('getFontsSprite', '@1.75x');
|
||||||
thumbs[4].path = window['AscDesktopEditor'].getFontsSprite('@2x');
|
thumbs[4].path = Common.Controllers.Desktop.call('getFontsSprite', '@2x');
|
||||||
}
|
}
|
||||||
|
|
||||||
var bestDistance = Math.abs(applicationPixelRatio-thumbs[0].ratio);
|
var bestDistance = Math.abs(applicationPixelRatio-thumbs[0].ratio);
|
||||||
|
|
@ -89,7 +89,7 @@ define([
|
||||||
thumbCanvas.width = thumbs[thumbIdx].width;
|
thumbCanvas.width = thumbs[thumbIdx].width;
|
||||||
|
|
||||||
function CThumbnailLoader() {
|
function CThumbnailLoader() {
|
||||||
this.supportBinaryFormat = (window['AscDesktopEditor'] && !window['AscDesktopEditor']['isSupportBinaryFontsSprite']) ? false : true;
|
this.supportBinaryFormat = !(Common.Controllers.Desktop.isActive() && !Common.Controllers.Desktop.isFeatureAvailable('isSupportBinaryFontsSprite'));
|
||||||
// наш формат - альфамаска с сжатием типа rle для полностью прозрачных пикселов
|
// наш формат - альфамаска с сжатием типа rle для полностью прозрачных пикселов
|
||||||
|
|
||||||
this.image = null;
|
this.image = null;
|
||||||
|
|
@ -134,7 +134,6 @@ define([
|
||||||
};
|
};
|
||||||
|
|
||||||
this.openBinary = function(arrayBuffer) {
|
this.openBinary = function(arrayBuffer) {
|
||||||
|
|
||||||
//var t1 = performance.now();
|
//var t1 = performance.now();
|
||||||
|
|
||||||
var binaryAlpha = this.binaryFormat;
|
var binaryAlpha = this.binaryFormat;
|
||||||
|
|
|
||||||
|
|
@ -223,6 +223,7 @@ define([
|
||||||
listenStoreEvents: true,
|
listenStoreEvents: true,
|
||||||
allowScrollbar: true,
|
allowScrollbar: true,
|
||||||
scrollAlwaysVisible: false,
|
scrollAlwaysVisible: false,
|
||||||
|
minScrollbarLength: 40,
|
||||||
showLast: true,
|
showLast: true,
|
||||||
useBSKeydown: false,
|
useBSKeydown: false,
|
||||||
cls: ''
|
cls: ''
|
||||||
|
|
@ -272,6 +273,7 @@ define([
|
||||||
me.listenStoreEvents= (me.options.listenStoreEvents!==undefined) ? me.options.listenStoreEvents : true;
|
me.listenStoreEvents= (me.options.listenStoreEvents!==undefined) ? me.options.listenStoreEvents : true;
|
||||||
me.allowScrollbar = (me.options.allowScrollbar!==undefined) ? me.options.allowScrollbar : true;
|
me.allowScrollbar = (me.options.allowScrollbar!==undefined) ? me.options.allowScrollbar : true;
|
||||||
me.scrollAlwaysVisible = me.options.scrollAlwaysVisible || false;
|
me.scrollAlwaysVisible = me.options.scrollAlwaysVisible || false;
|
||||||
|
me.minScrollbarLength = me.options.minScrollbarLength || 40;
|
||||||
me.tabindex = me.options.tabindex || 0;
|
me.tabindex = me.options.tabindex || 0;
|
||||||
me.delayRenderTips = me.options.delayRenderTips || false;
|
me.delayRenderTips = me.options.delayRenderTips || false;
|
||||||
if (me.parentMenu)
|
if (me.parentMenu)
|
||||||
|
|
@ -355,7 +357,7 @@ define([
|
||||||
this.scroller = new Common.UI.Scroller({
|
this.scroller = new Common.UI.Scroller({
|
||||||
el: $(this.el).find('.inner').addBack().filter('.inner'),
|
el: $(this.el).find('.inner').addBack().filter('.inner'),
|
||||||
useKeyboard: this.enableKeyEvents && !this.handleSelect,
|
useKeyboard: this.enableKeyEvents && !this.handleSelect,
|
||||||
minScrollbarLength : 40,
|
minScrollbarLength : this.minScrollbarLength,
|
||||||
wheelSpeed: 10,
|
wheelSpeed: 10,
|
||||||
alwaysVisibleY: this.scrollAlwaysVisible
|
alwaysVisibleY: this.scrollAlwaysVisible
|
||||||
});
|
});
|
||||||
|
|
@ -474,12 +476,12 @@ define([
|
||||||
var me = this,
|
var me = this,
|
||||||
view_el = $(view.el),
|
view_el = $(view.el),
|
||||||
tip = record.get('tip');
|
tip = record.get('tip');
|
||||||
if (tip) {
|
if (tip!==undefined && tip!==null) {
|
||||||
if (this.delayRenderTips)
|
if (this.delayRenderTips)
|
||||||
view_el.one('mouseenter', function(){ // hide tooltip when mouse is over menu
|
view_el.one('mouseenter', function(){ // hide tooltip when mouse is over menu
|
||||||
view_el.attr('data-toggle', 'tooltip');
|
view_el.attr('data-toggle', 'tooltip');
|
||||||
view_el.tooltip({
|
view_el.tooltip({
|
||||||
title : tip,
|
title : record.get('tip'), // use actual tip, because it can be changed
|
||||||
placement : 'cursor',
|
placement : 'cursor',
|
||||||
zIndex : me.tipZIndex
|
zIndex : me.tipZIndex
|
||||||
});
|
});
|
||||||
|
|
@ -488,7 +490,7 @@ define([
|
||||||
else {
|
else {
|
||||||
view_el.attr('data-toggle', 'tooltip');
|
view_el.attr('data-toggle', 'tooltip');
|
||||||
view_el.tooltip({
|
view_el.tooltip({
|
||||||
title : tip,
|
title : record.get('tip'), // use actual tip, because it can be changed
|
||||||
placement : 'cursor',
|
placement : 'cursor',
|
||||||
zIndex : me.tipZIndex
|
zIndex : me.tipZIndex
|
||||||
});
|
});
|
||||||
|
|
@ -548,7 +550,7 @@ define([
|
||||||
this.scroller = new Common.UI.Scroller({
|
this.scroller = new Common.UI.Scroller({
|
||||||
el: $(this.el).find('.inner').addBack().filter('.inner'),
|
el: $(this.el).find('.inner').addBack().filter('.inner'),
|
||||||
useKeyboard: this.enableKeyEvents && !this.handleSelect,
|
useKeyboard: this.enableKeyEvents && !this.handleSelect,
|
||||||
minScrollbarLength : 40,
|
minScrollbarLength : this.minScrollbarLength,
|
||||||
wheelSpeed: 10,
|
wheelSpeed: 10,
|
||||||
alwaysVisibleY: this.scrollAlwaysVisible
|
alwaysVisibleY: this.scrollAlwaysVisible
|
||||||
});
|
});
|
||||||
|
|
@ -822,7 +824,7 @@ define([
|
||||||
paddings = parseInt(menuRoot.css('padding-top')) + parseInt(menuRoot.css('padding-bottom')),
|
paddings = parseInt(menuRoot.css('padding-top')) + parseInt(menuRoot.css('padding-bottom')),
|
||||||
menuH = menuRoot.outerHeight(),
|
menuH = menuRoot.outerHeight(),
|
||||||
top = parseInt(menuRoot.css('top')),
|
top = parseInt(menuRoot.css('top')),
|
||||||
props = {minScrollbarLength : 40};
|
props = {minScrollbarLength : this.minScrollbarLength};
|
||||||
this.scrollAlwaysVisible && (props.alwaysVisibleY = this.scrollAlwaysVisible);
|
this.scrollAlwaysVisible && (props.alwaysVisibleY = this.scrollAlwaysVisible);
|
||||||
|
|
||||||
if (top + menuH > docH ) {
|
if (top + menuH > docH ) {
|
||||||
|
|
@ -993,7 +995,7 @@ define([
|
||||||
this.scroller = new Common.UI.Scroller({
|
this.scroller = new Common.UI.Scroller({
|
||||||
el: $(this.el).find('.inner').addBack().filter('.inner'),
|
el: $(this.el).find('.inner').addBack().filter('.inner'),
|
||||||
useKeyboard: this.enableKeyEvents && !this.handleSelect,
|
useKeyboard: this.enableKeyEvents && !this.handleSelect,
|
||||||
minScrollbarLength : 40,
|
minScrollbarLength : this.minScrollbarLength,
|
||||||
wheelSpeed: 10,
|
wheelSpeed: 10,
|
||||||
alwaysVisibleY: this.scrollAlwaysVisible
|
alwaysVisibleY: this.scrollAlwaysVisible
|
||||||
});
|
});
|
||||||
|
|
@ -1085,7 +1087,7 @@ define([
|
||||||
this.scroller = new Common.UI.Scroller({
|
this.scroller = new Common.UI.Scroller({
|
||||||
el: $(this.el).find('.inner').addBack().filter('.inner'),
|
el: $(this.el).find('.inner').addBack().filter('.inner'),
|
||||||
useKeyboard: this.enableKeyEvents && !this.handleSelect,
|
useKeyboard: this.enableKeyEvents && !this.handleSelect,
|
||||||
minScrollbarLength : 40,
|
minScrollbarLength : this.minScrollbarLength,
|
||||||
wheelSpeed: 10,
|
wheelSpeed: 10,
|
||||||
alwaysVisibleY: this.scrollAlwaysVisible
|
alwaysVisibleY: this.scrollAlwaysVisible
|
||||||
});
|
});
|
||||||
|
|
@ -1293,7 +1295,7 @@ define([
|
||||||
paddings = parseInt(menuRoot.css('padding-top')) + parseInt(menuRoot.css('padding-bottom')),
|
paddings = parseInt(menuRoot.css('padding-top')) + parseInt(menuRoot.css('padding-bottom')),
|
||||||
menuH = menuRoot.outerHeight(),
|
menuH = menuRoot.outerHeight(),
|
||||||
top = parseInt(menuRoot.css('top')),
|
top = parseInt(menuRoot.css('top')),
|
||||||
props = {minScrollbarLength : 40};
|
props = {minScrollbarLength : this.minScrollbarLength};
|
||||||
this.scrollAlwaysVisible && (props.alwaysVisibleY = this.scrollAlwaysVisible);
|
this.scrollAlwaysVisible && (props.alwaysVisibleY = this.scrollAlwaysVisible);
|
||||||
|
|
||||||
if (top + menuH > docH ) {
|
if (top + menuH > docH ) {
|
||||||
|
|
|
||||||
|
|
@ -49,7 +49,7 @@ define([
|
||||||
Common.UI.DimensionPicker = Common.UI.BaseView.extend((function(){
|
Common.UI.DimensionPicker = Common.UI.BaseView.extend((function(){
|
||||||
return {
|
return {
|
||||||
options: {
|
options: {
|
||||||
itemSize : 18,
|
itemSize : 20,
|
||||||
minRows : 5,
|
minRows : 5,
|
||||||
minColumns : 5,
|
minColumns : 5,
|
||||||
maxRows : 20,
|
maxRows : 20,
|
||||||
|
|
|
||||||
|
|
@ -81,7 +81,7 @@ define([
|
||||||
template: _.template([
|
template: _.template([
|
||||||
'<div class="input-field" style="<%= style %>">',
|
'<div class="input-field" style="<%= style %>">',
|
||||||
'<input ',
|
'<input ',
|
||||||
'type="text" ',
|
'type="<%= type %>" ',
|
||||||
'name="<%= name %>" ',
|
'name="<%= name %>" ',
|
||||||
'spellcheck="<%= spellcheck %>" ',
|
'spellcheck="<%= spellcheck %>" ',
|
||||||
'class="form-control <%= cls %>" ',
|
'class="form-control <%= cls %>" ',
|
||||||
|
|
@ -164,8 +164,6 @@ define([
|
||||||
this._input.on('keydown', _.bind(this.onKeyDown, this));
|
this._input.on('keydown', _.bind(this.onKeyDown, this));
|
||||||
this._input.on('keyup', _.bind(this.onKeyUp, this));
|
this._input.on('keyup', _.bind(this.onKeyUp, this));
|
||||||
if (this.validateOnChange) this._input.on('input', _.bind(this.onInputChanging, this));
|
if (this.validateOnChange) this._input.on('input', _.bind(this.onInputChanging, this));
|
||||||
if (this.type=='password') this._input.on('input', _.bind(this.checkPasswordType, this));
|
|
||||||
|
|
||||||
if (this.maxLength) this._input.attr('maxlength', this.maxLength);
|
if (this.maxLength) this._input.attr('maxlength', this.maxLength);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -190,15 +188,6 @@ define([
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
checkPasswordType: function(){
|
|
||||||
if(this.type == 'text') return;
|
|
||||||
if (this._input.val() !== '') {
|
|
||||||
(this._input.attr('type') !== 'password') && this._input.attr('type', 'password');
|
|
||||||
} else {
|
|
||||||
this._input.attr('type', 'text');
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_doChange: function(e, extra) {
|
_doChange: function(e, extra) {
|
||||||
// skip processing for internally-generated synthetic event
|
// skip processing for internally-generated synthetic event
|
||||||
// to avoid double processing
|
// to avoid double processing
|
||||||
|
|
@ -317,8 +306,6 @@ define([
|
||||||
if (this.rendered){
|
if (this.rendered){
|
||||||
this._input.val(value);
|
this._input.val(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
(this.type=='password') && this.checkPasswordType();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
getValue: function() {
|
getValue: function() {
|
||||||
|
|
@ -431,23 +418,25 @@ define([
|
||||||
validateOnBlur: true,
|
validateOnBlur: true,
|
||||||
disabled: false,
|
disabled: false,
|
||||||
editable: true,
|
editable: true,
|
||||||
iconCls: 'btn-select-range',
|
iconCls: 'toolbar__icon btn-select-range',
|
||||||
btnHint: ''
|
btnHint: ''
|
||||||
},
|
},
|
||||||
|
|
||||||
template: _.template([
|
template: _.template([
|
||||||
'<div class="input-field input-field-btn" style="<%= style %>">',
|
'<div class="input-field input-field-btn" style="<%= style %>">',
|
||||||
'<input ',
|
'<input ',
|
||||||
'type="text" ',
|
'type=<%= type %> ',
|
||||||
'name="<%= name %>" ',
|
'name="<%= name %>" ',
|
||||||
'spellcheck="<%= spellcheck %>" ',
|
'spellcheck="<%= spellcheck %>" ',
|
||||||
'class="form-control <%= cls %>" ',
|
'class="form-control <%= cls %>" ',
|
||||||
'placeholder="<%= placeHolder %>" ',
|
'placeholder="<%= placeHolder %>" ',
|
||||||
'value="<%= value %>"',
|
'value="<%= value %>"',
|
||||||
|
'data-hint="<%= dataHint %>"',
|
||||||
|
'data-hint-offset="<%= dataHintOffset %>"',
|
||||||
|
'data-hint-direction="<%= dataHintDirection %>"',
|
||||||
'>',
|
'>',
|
||||||
'<span class="input-error"></span>',
|
'<span class="input-error"></span>',
|
||||||
'<div class="select-button">' +
|
'<div class="select-button">' +
|
||||||
'<button type="button" class="btn btn-toolbar"><i class="icon toolbar__icon <%= iconCls %>"></i></button>' +
|
|
||||||
'</div>',
|
'</div>',
|
||||||
'</div>'
|
'</div>'
|
||||||
].join('')),
|
].join('')),
|
||||||
|
|
@ -465,8 +454,10 @@ define([
|
||||||
name : this.name,
|
name : this.name,
|
||||||
placeHolder : this.placeHolder,
|
placeHolder : this.placeHolder,
|
||||||
spellcheck : this.spellcheck,
|
spellcheck : this.spellcheck,
|
||||||
iconCls : this.options.iconCls,
|
scope : me,
|
||||||
scope : me
|
dataHint : this.options.dataHint,
|
||||||
|
dataHintOffset: this.options.dataHintOffset,
|
||||||
|
dataHintDirection: this.options.dataHintDirection
|
||||||
}));
|
}));
|
||||||
|
|
||||||
if (parentEl) {
|
if (parentEl) {
|
||||||
|
|
@ -483,10 +474,12 @@ define([
|
||||||
var el = this.cmpEl;
|
var el = this.cmpEl;
|
||||||
|
|
||||||
this._button = new Common.UI.Button({
|
this._button = new Common.UI.Button({
|
||||||
el: this.cmpEl.find('button'),
|
cls: 'btn-toolbar',
|
||||||
iconCls: this.options.iconCls,
|
iconCls: this.options.iconCls,
|
||||||
hint: this.options.btnHint || ''
|
hint: this.options.btnHint || '',
|
||||||
|
menu: this.options.menu
|
||||||
});
|
});
|
||||||
|
this._button.render(this.cmpEl.find('.select-button'));
|
||||||
this._button.on('click', _.bind(this.onButtonClick, this));
|
this._button.on('click', _.bind(this.onButtonClick, this));
|
||||||
|
|
||||||
this._input = this.cmpEl.find('input').addBack().filter('input');
|
this._input = this.cmpEl.find('input').addBack().filter('input');
|
||||||
|
|
@ -556,6 +549,7 @@ define([
|
||||||
style: '',
|
style: '',
|
||||||
value: '',
|
value: '',
|
||||||
name: '',
|
name: '',
|
||||||
|
type: 'password',
|
||||||
validation: null,
|
validation: null,
|
||||||
allowBlank: true,
|
allowBlank: true,
|
||||||
placeHolder: '',
|
placeHolder: '',
|
||||||
|
|
@ -566,7 +560,8 @@ define([
|
||||||
validateOnBlur: true,
|
validateOnBlur: true,
|
||||||
disabled: false,
|
disabled: false,
|
||||||
editable: true,
|
editable: true,
|
||||||
iconCls: 'btn-sheet-view',
|
showCls: 'toolbar__icon btn-sheet-view',
|
||||||
|
hideCls: 'toolbar__icon hide-password',
|
||||||
btnHint: '',
|
btnHint: '',
|
||||||
repeatInput: null,
|
repeatInput: null,
|
||||||
showPwdOnClick: true
|
showPwdOnClick: true
|
||||||
|
|
@ -575,6 +570,7 @@ define([
|
||||||
initialize : function(options) {
|
initialize : function(options) {
|
||||||
options = options || {};
|
options = options || {};
|
||||||
options.btnHint = options.btnHint || this.textHintShowPwd;
|
options.btnHint = options.btnHint || this.textHintShowPwd;
|
||||||
|
options.iconCls = options.showCls || this.options.showCls;
|
||||||
|
|
||||||
Common.UI.InputFieldBtn.prototype.initialize.call(this, options);
|
Common.UI.InputFieldBtn.prototype.initialize.call(this, options);
|
||||||
|
|
||||||
|
|
@ -586,7 +582,6 @@ define([
|
||||||
Common.UI.InputFieldBtn.prototype.render.call(this, parentEl);
|
Common.UI.InputFieldBtn.prototype.render.call(this, parentEl);
|
||||||
|
|
||||||
this._btnElm = this._button.$el;
|
this._btnElm = this._button.$el;
|
||||||
this._input.on('input', _.bind(this.checkPasswordType, this));
|
|
||||||
if(this.options.showPwdOnClick)
|
if(this.options.showPwdOnClick)
|
||||||
this._button.on('click', _.bind(this.passwordClick, this));
|
this._button.on('click', _.bind(this.passwordClick, this));
|
||||||
else
|
else
|
||||||
|
|
@ -617,7 +612,7 @@ define([
|
||||||
|
|
||||||
passwordShow: function (e) {
|
passwordShow: function (e) {
|
||||||
if (this.disabled) return;
|
if (this.disabled) return;
|
||||||
this._button.setIconCls('hide-password');
|
this._button.setIconCls(this.options.hideCls);
|
||||||
this.type = 'text';
|
this.type = 'text';
|
||||||
|
|
||||||
this._input.attr('type', this.type);
|
this._input.attr('type', this.type);
|
||||||
|
|
@ -636,13 +631,13 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
passwordHide: function (e) {
|
passwordHide: function (e) {
|
||||||
this._button.setIconCls('btn-sheet-view');
|
this._button.setIconCls(this.options.showCls);
|
||||||
this.type = 'password';
|
this.type = 'password';
|
||||||
|
|
||||||
(this._input.val() !== '') && this._input.attr('type', this.type);
|
this._input.attr('type', this.type);
|
||||||
if(this.repeatInput) {
|
if(this.repeatInput) {
|
||||||
this.repeatInput.type = this.type;
|
this.repeatInput.type = this.type;
|
||||||
(this.repeatInput._input.val() !== '') && this.repeatInput._input.attr('type', this.type);
|
this.repeatInput._input.attr('type', this.type);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(this.options.showPwdOnClick) {
|
if(this.options.showPwdOnClick) {
|
||||||
|
|
@ -665,4 +660,66 @@ define([
|
||||||
textHintHidePwd: 'Hide password'
|
textHintHidePwd: 'Hide password'
|
||||||
}
|
}
|
||||||
})(), Common.UI.InputFieldBtnPassword || {}));
|
})(), Common.UI.InputFieldBtnPassword || {}));
|
||||||
|
|
||||||
|
Common.UI.InputFieldBtnCalendar = Common.UI.InputFieldBtn.extend((function (){
|
||||||
|
return {
|
||||||
|
options: {
|
||||||
|
id: null,
|
||||||
|
cls: '',
|
||||||
|
style: '',
|
||||||
|
value: '',
|
||||||
|
type: 'date',
|
||||||
|
name: '',
|
||||||
|
validation: null,
|
||||||
|
allowBlank: true,
|
||||||
|
placeHolder: '',
|
||||||
|
blankError: null,
|
||||||
|
spellcheck: false,
|
||||||
|
maskExp: '',
|
||||||
|
validateOnChange: false,
|
||||||
|
validateOnBlur: true,
|
||||||
|
disabled: false,
|
||||||
|
editable: true,
|
||||||
|
iconCls: 'toolbar__icon btn-datetime',
|
||||||
|
btnHint: '',
|
||||||
|
menu: true
|
||||||
|
},
|
||||||
|
|
||||||
|
render: function (parentEl) {
|
||||||
|
var me = this;
|
||||||
|
Common.UI.InputFieldBtn.prototype.render.call(this, parentEl);
|
||||||
|
|
||||||
|
var id = 'id-' + Common.UI.getId() + 'input-field-datetime',
|
||||||
|
menu = new Common.UI.Menu({
|
||||||
|
menuAlign: 'tr-br',
|
||||||
|
style: 'border: none; padding: 0;',
|
||||||
|
items: [
|
||||||
|
{template: _.template('<div id="' + id + '" style=""></div>'), stopPropagation: true}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
$('button', this._button.cmpEl).addClass('no-caret');
|
||||||
|
this._button.setMenu(menu);
|
||||||
|
this._button.menu.on('show:after', function(menu) {
|
||||||
|
if (!me.cmpCalendar) {
|
||||||
|
me.cmpCalendar = new Common.UI.Calendar({
|
||||||
|
el: me.cmpEl.find('#' + id),
|
||||||
|
enableKeyEvents: true,
|
||||||
|
firstday: 1
|
||||||
|
});
|
||||||
|
me.cmpCalendar.on('date:click', function (cmp, date) {
|
||||||
|
me.trigger('date:click', me, date);
|
||||||
|
menu.hide();
|
||||||
|
});
|
||||||
|
menu.alignPosition();
|
||||||
|
}
|
||||||
|
me.cmpCalendar.focus();
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
setDate: function(date) {
|
||||||
|
if (this.cmpCalendar && date && date instanceof Date && !isNaN(date))
|
||||||
|
this.cmpCalendar && this.cmpCalendar.setDate(date);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})());
|
||||||
});
|
});
|
||||||
|
|
@ -301,6 +301,7 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
onItemMouseDown: function(e) {
|
onItemMouseDown: function(e) {
|
||||||
|
Common.UI.HintManager && Common.UI.HintManager.clearHints();
|
||||||
if (e.which != 1) {
|
if (e.which != 1) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
e.stopPropagation();
|
e.stopPropagation();
|
||||||
|
|
|
||||||
|
|
@ -147,8 +147,13 @@ define([
|
||||||
el.on('input', '.form-control', _.bind(this.onInput, this));
|
el.on('input', '.form-control', _.bind(this.onInput, this));
|
||||||
if (!this.options.allowDecimal)
|
if (!this.options.allowDecimal)
|
||||||
el.on('keypress', '.form-control', _.bind(this.onKeyPress, this));
|
el.on('keypress', '.form-control', _.bind(this.onKeyPress, this));
|
||||||
el.on('focus', 'input.form-control', function() {
|
el.on('focus', 'input.form-control', function(e) {
|
||||||
setTimeout(function(){me.$input && me.$input.select();}, 1);
|
setTimeout(function(){
|
||||||
|
if (me.$input) {
|
||||||
|
me.$input[0].selectionStart = 0;
|
||||||
|
me.$input[0].selectionEnd = me.$input.val().length;
|
||||||
|
}
|
||||||
|
}, 1);
|
||||||
});
|
});
|
||||||
Common.Utils.isGecko && el.on('blur', 'input.form-control', function() {
|
Common.Utils.isGecko && el.on('blur', 'input.form-control', function() {
|
||||||
setTimeout(function(){
|
setTimeout(function(){
|
||||||
|
|
|
||||||
|
|
@ -52,6 +52,7 @@ define([
|
||||||
var $scrollL;
|
var $scrollL;
|
||||||
var optsFold = {timeout: 2000};
|
var optsFold = {timeout: 2000};
|
||||||
var config = {};
|
var config = {};
|
||||||
|
var btnsMore = [];
|
||||||
|
|
||||||
var onScrollTabs = function(opts, e) {
|
var onScrollTabs = function(opts, e) {
|
||||||
var sv = $boxTabs.scrollLeft();
|
var sv = $boxTabs.scrollLeft();
|
||||||
|
|
@ -119,6 +120,7 @@ define([
|
||||||
Common.NotificationCenter.on('tab:visible', _.bind(function(action, visible){
|
Common.NotificationCenter.on('tab:visible', _.bind(function(action, visible){
|
||||||
this.setVisible(action, visible);
|
this.setVisible(action, visible);
|
||||||
}, this));
|
}, this));
|
||||||
|
Common.NotificationCenter.on('tab:resize', _.bind(this.onResizeTabs, this));
|
||||||
},
|
},
|
||||||
|
|
||||||
afterRender: function() {
|
afterRender: function() {
|
||||||
|
|
@ -126,7 +128,9 @@ define([
|
||||||
|
|
||||||
$boxTabs = me.$('.tabs > ul');
|
$boxTabs = me.$('.tabs > ul');
|
||||||
me.$tabs = $boxTabs.find('> li');
|
me.$tabs = $boxTabs.find('> li');
|
||||||
me.$panels = me.$('.box-panels > .panel');
|
me.$boxpanels = me.$('.box-panels');
|
||||||
|
me.$panels = me.$boxpanels.find('> .panel');
|
||||||
|
|
||||||
optsFold.$bar = me.$('.toolbar');
|
optsFold.$bar = me.$('.toolbar');
|
||||||
var $scrollR = me.$('.tabs .scroll.right');
|
var $scrollR = me.$('.tabs .scroll.right');
|
||||||
$scrollL = me.$('.tabs .scroll.left');
|
$scrollL = me.$('.tabs .scroll.left');
|
||||||
|
|
@ -226,7 +230,7 @@ define([
|
||||||
// optsFold.timer = setTimeout(this.collapse, optsFold.timeout);
|
// optsFold.timer = setTimeout(this.collapse, optsFold.timeout);
|
||||||
},
|
},
|
||||||
|
|
||||||
onResize: function(e) {
|
onResizeTabs: function(e) {
|
||||||
if ( this.hasTabInvisible() ) {
|
if ( this.hasTabInvisible() ) {
|
||||||
if ( !$boxTabs.parent().hasClass('short') )
|
if ( !$boxTabs.parent().hasClass('short') )
|
||||||
$boxTabs.parent().addClass('short');
|
$boxTabs.parent().addClass('short');
|
||||||
|
|
@ -234,7 +238,11 @@ define([
|
||||||
if ( $boxTabs.parent().hasClass('short') ) {
|
if ( $boxTabs.parent().hasClass('short') ) {
|
||||||
$boxTabs.parent().removeClass('short');
|
$boxTabs.parent().removeClass('short');
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onResize: function(e) {
|
||||||
|
this.onResizeTabs();
|
||||||
|
this.hideMoreBtns();
|
||||||
this.processPanelVisible();
|
this.processPanelVisible();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -261,7 +269,7 @@ define([
|
||||||
me._timerSetTab = false;
|
me._timerSetTab = false;
|
||||||
}, 500);
|
}, 500);
|
||||||
me.setTab(tab);
|
me.setTab(tab);
|
||||||
me.processPanelVisible(null, true);
|
// me.processPanelVisible(null, true);
|
||||||
if ( !me.isFolded ) {
|
if ( !me.isFolded ) {
|
||||||
if ( me.dblclick_timer ) clearTimeout(me.dblclick_timer);
|
if ( me.dblclick_timer ) clearTimeout(me.dblclick_timer);
|
||||||
me.dblclick_timer = setTimeout(function () {
|
me.dblclick_timer = setTimeout(function () {
|
||||||
|
|
@ -286,11 +294,14 @@ define([
|
||||||
if ( tab ) {
|
if ( tab ) {
|
||||||
me.$tabs.removeClass('active');
|
me.$tabs.removeClass('active');
|
||||||
me.$panels.removeClass('active');
|
me.$panels.removeClass('active');
|
||||||
|
me.hideMoreBtns();
|
||||||
|
|
||||||
var panel = this.$panels.filter('[data-tab=' + tab + ']');
|
var panel = this.$panels.filter('[data-tab=' + tab + ']');
|
||||||
if ( panel.length ) {
|
if ( panel.length ) {
|
||||||
this.lastPanel = tab;
|
this.lastPanel = tab;
|
||||||
panel.addClass('active');
|
panel.addClass('active');
|
||||||
|
me.setMoreButton(tab, panel);
|
||||||
|
me.processPanelVisible(null, true, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( panel.length ) {
|
if ( panel.length ) {
|
||||||
|
|
@ -375,7 +386,7 @@ define([
|
||||||
* hide button's caption to decrease panel width
|
* hide button's caption to decrease panel width
|
||||||
* ##adopt-panel-width
|
* ##adopt-panel-width
|
||||||
**/
|
**/
|
||||||
processPanelVisible: function(panel, now) {
|
processPanelVisible: function(panel, now, force) {
|
||||||
var me = this;
|
var me = this;
|
||||||
if ( me._timer_id ) clearTimeout(me._timer_id);
|
if ( me._timer_id ) clearTimeout(me._timer_id);
|
||||||
|
|
||||||
|
|
@ -387,6 +398,7 @@ define([
|
||||||
_rightedge = data.rightedge,
|
_rightedge = data.rightedge,
|
||||||
_btns = data.buttons,
|
_btns = data.buttons,
|
||||||
_flex = data.flex;
|
_flex = data.flex;
|
||||||
|
var more_section = $active.find('.more-box');
|
||||||
|
|
||||||
if ( !_rightedge ) {
|
if ( !_rightedge ) {
|
||||||
_rightedge = $active.get(0).getBoundingClientRect().right;
|
_rightedge = $active.get(0).getBoundingClientRect().right;
|
||||||
|
|
@ -407,19 +419,22 @@ define([
|
||||||
data.flex = _flex;
|
data.flex = _flex;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( _rightedge > _maxright) {
|
if ( (_rightedge > _maxright)) {
|
||||||
|
if (!more_section.is(':visible') ) {
|
||||||
if (_flex.length>0) {
|
if (_flex.length>0) {
|
||||||
for (var i=0; i<_flex.length; i++) {
|
for (var i=0; i<_flex.length; i++) {
|
||||||
var item = _flex[i].el;
|
var item = _flex[i].el;
|
||||||
if (item.outerWidth() > parseInt(item.css('min-width')))
|
_rightedge = $active.get(0).getBoundingClientRect().right;
|
||||||
|
if (item.outerWidth() > parseInt(item.css('min-width'))) {
|
||||||
|
data.rightedge = _rightedge;
|
||||||
return;
|
return;
|
||||||
else
|
} else
|
||||||
item.css('width', item.css('min-width'));
|
item.css('width', item.css('min-width'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (var i=_btns.length-1; i>=0; i--) {
|
for (var i=_btns.length-1; i>=0; i--) {
|
||||||
var btn = _btns[i];
|
var btn = _btns[i];
|
||||||
if ( !btn.hasClass('compactwidth') ) {
|
if ( !btn.hasClass('compactwidth') && !btn.hasClass('slot-btn-more')) {
|
||||||
btn.addClass('compactwidth');
|
btn.addClass('compactwidth');
|
||||||
_rightedge = $active.get(0).getBoundingClientRect().right;
|
_rightedge = $active.get(0).getBoundingClientRect().right;
|
||||||
if (_rightedge <= _maxright)
|
if (_rightedge <= _maxright)
|
||||||
|
|
@ -427,7 +442,11 @@ define([
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
data.rightedge = _rightedge;
|
data.rightedge = _rightedge;
|
||||||
|
}
|
||||||
|
me.resizeToolbar(force);
|
||||||
} else {
|
} else {
|
||||||
|
more_section.is(':visible') && me.resizeToolbar(force);
|
||||||
|
if (!more_section.is(':visible')) {
|
||||||
for (var i=0; i<_btns.length; i++) {
|
for (var i=0; i<_btns.length; i++) {
|
||||||
var btn = _btns[i];
|
var btn = _btns[i];
|
||||||
if ( btn.hasClass('compactwidth') ) {
|
if ( btn.hasClass('compactwidth') ) {
|
||||||
|
|
@ -445,6 +464,8 @@ define([
|
||||||
for (var i=0; i<_flex.length; i++) {
|
for (var i=0; i<_flex.length; i++) {
|
||||||
var item = _flex[i];
|
var item = _flex[i];
|
||||||
item.el.css('width', item.width);
|
item.el.css('width', item.width);
|
||||||
|
data.rightedge = $active.get(0).getBoundingClientRect().right;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -477,6 +498,303 @@ define([
|
||||||
this.$tabs.find('> a[data-tab=' + tab + ']').parent().css('display', visible ? '' : 'none');
|
this.$tabs.find('> a[data-tab=' + tab + ']').parent().css('display', visible ? '' : 'none');
|
||||||
this.onResize();
|
this.onResize();
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
setMoreButton: function(tab, panel) {
|
||||||
|
var me = this;
|
||||||
|
if (!btnsMore[tab]) {
|
||||||
|
var top = panel.position().top;
|
||||||
|
var box = $('<div class="more-box" style="position: absolute;right: 0; top:'+ top +'px; padding-left: 12px;padding-right: 6px;display: none;">' +
|
||||||
|
'<div class="separator long" style="position: relative;display: table-cell;"></div>' +
|
||||||
|
'<div class="group" style=""><span class="btn-slot text x-huge slot-btn-more"></span></div>' +
|
||||||
|
'</div>');
|
||||||
|
panel.append(box);
|
||||||
|
btnsMore[tab] = new Common.UI.Button({
|
||||||
|
cls: 'btn-toolbar x-huge icon-top dropdown-manual',
|
||||||
|
caption: Common.Locale.get("textMoreButton",{name:"Common.Translation", default: "More"}),
|
||||||
|
iconCls: 'toolbar__icon btn-more',
|
||||||
|
enableToggle: true
|
||||||
|
});
|
||||||
|
btnsMore[tab].render(box.find('.slot-btn-more'));
|
||||||
|
btnsMore[tab].on('toggle', function(btn, state, e) {
|
||||||
|
(state) ? me.onMoreShow(btn, e) : me.onMoreHide(btn, e);
|
||||||
|
Common.NotificationCenter.trigger('more:toggle', btn, state);
|
||||||
|
});
|
||||||
|
var moreContainer = $('<div class="dropdown-menu more-container" data-tab="' + tab + '"><div style="display: inline;"></div></div>');
|
||||||
|
optsFold.$bar.append(moreContainer);
|
||||||
|
btnsMore[tab].panel = moreContainer.find('div');
|
||||||
|
}
|
||||||
|
this.$moreBar = btnsMore[tab].panel;
|
||||||
|
},
|
||||||
|
|
||||||
|
resizeToolbar: function(reset) {
|
||||||
|
var $active = this.$panels.filter('.active'),
|
||||||
|
more_section = $active.find('.more-box'),
|
||||||
|
more_section_width = parseInt(more_section.css('width')) || 0,
|
||||||
|
box_controls_width = $active.parents('.box-controls').width(),
|
||||||
|
_maxright = box_controls_width,
|
||||||
|
_rightedge = $active.get(0).getBoundingClientRect().right,
|
||||||
|
delta = (this._prevBoxWidth) ? (_maxright - this._prevBoxWidth) : -1,
|
||||||
|
hideAllMenus = false;
|
||||||
|
this._prevBoxWidth = _maxright;
|
||||||
|
more_section.is(':visible') && (_maxright -= more_section_width);
|
||||||
|
|
||||||
|
if (this.$moreBar && this.$moreBar.parent().is(':visible')) {
|
||||||
|
this.$moreBar.parent().css('max-width', Common.Utils.innerWidth());
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( (reset || delta<0) && (_rightedge > _maxright)) { // from toolbar to more section
|
||||||
|
if (!more_section.is(':visible') ) {
|
||||||
|
more_section.css('display', "");
|
||||||
|
_maxright -= parseInt(more_section.css('width'));
|
||||||
|
}
|
||||||
|
var last_separator = null,
|
||||||
|
last_group = null,
|
||||||
|
prevchild = this.$moreBar.children().filter("[data-hidden-tb-item!=true]");
|
||||||
|
if (prevchild.length>0) {
|
||||||
|
prevchild = $(prevchild[0]);
|
||||||
|
if (prevchild.hasClass('separator'))
|
||||||
|
last_separator = prevchild;
|
||||||
|
if (prevchild.hasClass('group') && prevchild.attr('group-state') == 'open')
|
||||||
|
last_group = prevchild;
|
||||||
|
}
|
||||||
|
var items = $active.find('> div:not(.more-box)');
|
||||||
|
var need_break = false;
|
||||||
|
for (var i=items.length-1; i>=0; i--) {
|
||||||
|
var item = $(items[i]);
|
||||||
|
if (!item.is(':visible') && !item.attr('hidden-on-resize')) { // move invisible items as is and set special attr
|
||||||
|
item.attr('data-hidden-tb-item', true);
|
||||||
|
this.$moreBar.prepend(item);
|
||||||
|
hideAllMenus = true;
|
||||||
|
} else if (item.hasClass('group')) {
|
||||||
|
_rightedge = $active.get(0).getBoundingClientRect().right;
|
||||||
|
if (_rightedge <= _maxright) // stop moving items
|
||||||
|
break;
|
||||||
|
|
||||||
|
var offset = item.offset(),
|
||||||
|
item_width = item.outerWidth(),
|
||||||
|
children = item.children();
|
||||||
|
if (!item.attr('inner-width') && item.attr('group-state') !== 'open') {
|
||||||
|
item.attr('inner-width', item_width);
|
||||||
|
for (var j=children.length-1; j>=0; j--) {
|
||||||
|
var child = $(children[j]);
|
||||||
|
child.attr('inner-width', child.outerWidth());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ((offset.left > _maxright || children.length==1) && item.attr('group-state') != 'open') {
|
||||||
|
// move group
|
||||||
|
this.$moreBar.prepend(item);
|
||||||
|
if (last_separator) {
|
||||||
|
last_separator.css('display', '');
|
||||||
|
last_separator.removeAttr('hidden-on-resize');
|
||||||
|
}
|
||||||
|
hideAllMenus = true;
|
||||||
|
} else if ( offset.left+item_width > _maxright ) {
|
||||||
|
// move buttons from group
|
||||||
|
for (var j=children.length-1; j>=0; j--) {
|
||||||
|
var child = $(children[j]);
|
||||||
|
if (child.hasClass('elset')) {
|
||||||
|
this.$moreBar.prepend(item);
|
||||||
|
if (last_separator) {
|
||||||
|
last_separator.css('display', '');
|
||||||
|
last_separator.removeAttr('hidden-on-resize');
|
||||||
|
}
|
||||||
|
hideAllMenus = true;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
var child_offset = child.offset(),
|
||||||
|
child_width = child.outerWidth();
|
||||||
|
if (child_offset.left+child_width>_maxright) {
|
||||||
|
if (!last_group) {
|
||||||
|
last_group = $('<div></div>');
|
||||||
|
last_group.addClass(items[i].className);
|
||||||
|
var attrs = items[i].attributes;
|
||||||
|
for (var k = 0; k < attrs.length; k++) {
|
||||||
|
last_group.attr(attrs[k].name, attrs[k].value);
|
||||||
|
}
|
||||||
|
this.$moreBar.prepend(last_group);
|
||||||
|
if (last_separator) {
|
||||||
|
last_separator.css('display', '');
|
||||||
|
last_separator.removeAttr('hidden-on-resize');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
last_group.prepend(child);
|
||||||
|
hideAllMenus = true;
|
||||||
|
} else {
|
||||||
|
need_break = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (item.children().length<1) { // all buttons are moved
|
||||||
|
item.remove();
|
||||||
|
last_group && last_group.removeAttr('group-state').attr('inner-width', item.attr('inner-width'));
|
||||||
|
last_group = null;
|
||||||
|
} else {
|
||||||
|
last_group && last_group.attr('group-state', 'open') && item.attr('group-state', 'open');
|
||||||
|
}
|
||||||
|
if (need_break)
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
last_separator = null;
|
||||||
|
} else if (item.hasClass('separator')) {
|
||||||
|
this.$moreBar.prepend(item);
|
||||||
|
item.css('display', 'none');
|
||||||
|
item.attr('hidden-on-resize', true);
|
||||||
|
last_separator = item;
|
||||||
|
hideAllMenus = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if ((reset || delta>0) && more_section.is(':visible')) {
|
||||||
|
var last_separator = null,
|
||||||
|
last_group = null,
|
||||||
|
prevchild = $active.find('> div:not(.more-box)');
|
||||||
|
var last_width = 0;
|
||||||
|
if (prevchild.length>0) {
|
||||||
|
prevchild = $(prevchild[prevchild.length-1]);
|
||||||
|
if (prevchild.hasClass('separator')) {
|
||||||
|
last_separator = prevchild;
|
||||||
|
last_width = parseInt(last_separator.css('margin-left')) + parseInt(last_separator.css('margin-right')) + 1;
|
||||||
|
}
|
||||||
|
if (prevchild.hasClass('group') && prevchild.attr('group-state') == 'open')
|
||||||
|
last_group = prevchild;
|
||||||
|
}
|
||||||
|
|
||||||
|
var items = this.$moreBar.children();
|
||||||
|
if (items.length>0) {
|
||||||
|
// from more panel to toolbar
|
||||||
|
for (var i=0; i<items.length; i++) {
|
||||||
|
var item = $(items[i]);
|
||||||
|
_rightedge = $active.get(0).getBoundingClientRect().right;
|
||||||
|
if (!item.is(':visible') && item.attr('data-hidden-tb-item')) { // move invisible items as is
|
||||||
|
item.removeAttr('data-hidden-tb-item');
|
||||||
|
more_section.before(item);
|
||||||
|
if (this.$moreBar.children().filter('.group').length == 0) {
|
||||||
|
this.hideMoreBtns();
|
||||||
|
more_section.css('display', "none");
|
||||||
|
}
|
||||||
|
} else if (item.hasClass('group')) {
|
||||||
|
var islast = false;
|
||||||
|
if (this.$moreBar.children().filter('.group').length == 1) {
|
||||||
|
_maxright = box_controls_width; // try to move last group
|
||||||
|
islast = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
var item_width = parseInt(item.attr('inner-width') || 0);
|
||||||
|
if (_rightedge + last_width + item_width < _maxright && item.attr('group-state') != 'open') {
|
||||||
|
// move group
|
||||||
|
more_section.before(item);
|
||||||
|
if (last_separator) {
|
||||||
|
last_separator.css('display', '');
|
||||||
|
last_separator.removeAttr('hidden-on-resize');
|
||||||
|
}
|
||||||
|
if (this.$moreBar.children().filter('.group').length == 0) {
|
||||||
|
this.hideMoreBtns();
|
||||||
|
more_section.css('display', "none");
|
||||||
|
}
|
||||||
|
hideAllMenus = true;
|
||||||
|
} else if ( _rightedge + last_width < _maxright) {
|
||||||
|
// move buttons from group
|
||||||
|
var children = item.children();
|
||||||
|
_maxright = box_controls_width - more_section_width;
|
||||||
|
for (var j=0; j<children.length; j++) {
|
||||||
|
if (islast && j==children.length-1)
|
||||||
|
_maxright = box_controls_width; // try to move last item from last group
|
||||||
|
_rightedge = $active.get(0).getBoundingClientRect().right;
|
||||||
|
var child = $(children[j]);
|
||||||
|
if (child.hasClass('elset')) { // don't add group - no enough space
|
||||||
|
need_break = true;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
var child_width = parseInt(child.attr('inner-width') || 0) + (!last_group ? parseInt(item.css('padding-left')) : 0); // if new group is started add left-padding
|
||||||
|
if (_rightedge+last_width+child_width < _maxright) {
|
||||||
|
if (!last_group) {
|
||||||
|
last_group = $('<div></div>');
|
||||||
|
last_group.addClass(items[i].className);
|
||||||
|
var attrs = items[i].attributes;
|
||||||
|
for (var k = 0; k < attrs.length; k++) {
|
||||||
|
last_group.attr(attrs[k].name, attrs[k].value);
|
||||||
|
}
|
||||||
|
if (last_group.hasClass('flex')) { // need to update flex groups list
|
||||||
|
$active.data().flex = null;
|
||||||
|
}
|
||||||
|
more_section.before(last_group);
|
||||||
|
if (last_separator) {
|
||||||
|
last_separator.css('display', '');
|
||||||
|
last_separator.removeAttr('hidden-on-resize');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
last_group.append(child);
|
||||||
|
hideAllMenus = true;
|
||||||
|
} else {
|
||||||
|
need_break = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (item.children().length<1) { // all buttons are moved
|
||||||
|
item.remove();
|
||||||
|
last_group && last_group.removeAttr('group-state').attr('inner-width', item.attr('inner-width'));
|
||||||
|
last_group = null;
|
||||||
|
if (this.$moreBar.children().filter('.group').length == 0) {
|
||||||
|
this.hideMoreBtns();
|
||||||
|
more_section.css('display', "none");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
last_group && last_group.attr('group-state', 'open') && item.attr('group-state', 'open');
|
||||||
|
}
|
||||||
|
if (need_break)
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
last_separator = null; last_width = 0;
|
||||||
|
} else if (item.hasClass('separator')) {
|
||||||
|
more_section.before(item);
|
||||||
|
item.css('display', 'none');
|
||||||
|
item.attr('hidden-on-resize', true);
|
||||||
|
last_separator = item;
|
||||||
|
last_width = parseInt(last_separator.css('margin-left')) + parseInt(last_separator.css('margin-right')) + 1;
|
||||||
|
hideAllMenus = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
this.hideMoreBtns();
|
||||||
|
more_section.css('display', "none");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
hideAllMenus && Common.UI.Menu.Manager.hideAll();
|
||||||
|
},
|
||||||
|
|
||||||
|
onMoreHide: function(btn, e) {
|
||||||
|
var moreContainer = btn.panel.parent();
|
||||||
|
if (btn.pressed) {
|
||||||
|
btn.toggle(false, true);
|
||||||
|
}
|
||||||
|
if (moreContainer.is(':visible')) {
|
||||||
|
moreContainer.hide();
|
||||||
|
Common.NotificationCenter.trigger('edit:complete', this.toolbar, btn);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onMoreShow: function(btn, e) {
|
||||||
|
var moreContainer = btn.panel.parent(),
|
||||||
|
parentxy = moreContainer.parent().offset(),
|
||||||
|
target = btn.$el,
|
||||||
|
showxy = target.offset(),
|
||||||
|
right = Common.Utils.innerWidth() - (showxy.left - parentxy.left + target.width()),
|
||||||
|
top = showxy.top - parentxy.top + target.height() + 10;
|
||||||
|
|
||||||
|
moreContainer.css({right: right, left: 'auto', top : top, 'max-width': Common.Utils.innerWidth() + 'px'});
|
||||||
|
moreContainer.show();
|
||||||
|
},
|
||||||
|
|
||||||
|
hideMoreBtns: function() {
|
||||||
|
for (var btn in btnsMore) {
|
||||||
|
btnsMore[btn] && btnsMore[btn].toggle(false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}()));
|
}()));
|
||||||
|
|
|
||||||
|
|
@ -157,7 +157,7 @@ define([
|
||||||
|
|
||||||
setRawValue: function(value) {
|
setRawValue: function(value) {
|
||||||
var value = (value === true || value === 'true' || value === '1' || value === 1 );
|
var value = (value === true || value === 'true' || value === '1' || value === 1 );
|
||||||
$('input[type=radio][name=' + this.name + ']').removeClass('checked');
|
value && $('input[type=radio][name=' + this.name + ']').removeClass('checked');
|
||||||
this.$radio.toggleClass('checked', value);
|
this.$radio.toggleClass('checked', value);
|
||||||
this.$radio.prop('checked', value);
|
this.$radio.prop('checked', value);
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -513,10 +513,10 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
setTabVisible: function(index, suppress) {
|
setTabVisible: function(index, suppress) {
|
||||||
if (index <= 0 || index == 'first') {
|
if (index <= 0) {
|
||||||
this.$bar.scrollLeft(0);
|
this.$bar.scrollLeft(0);
|
||||||
this.checkInvisible(suppress);
|
this.checkInvisible(suppress);
|
||||||
} else if ( index >= (this.tabs.length - 1) || index == 'last') {
|
} else if ( index >= (this.tabs.length - 1)) {
|
||||||
var tab = this.tabs[this.tabs.length-1].$el;
|
var tab = this.tabs[this.tabs.length-1].$el;
|
||||||
if (this.$bar.find('.separator-item').length === 0) {
|
if (this.$bar.find('.separator-item').length === 0) {
|
||||||
this.$bar.append('<li class="separator-item"><span></span></li>');
|
this.$bar.append('<li class="separator-item"><span></span></li>');
|
||||||
|
|
@ -610,7 +610,7 @@ define([
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
addDataHint: function (index) { //Hint Manager
|
addDataHint: function (index, dataHint) { //Hint Manager
|
||||||
var oldHintTab = this.$bar.find('[data-hint]');
|
var oldHintTab = this.$bar.find('[data-hint]');
|
||||||
if (oldHintTab.length > 0) {
|
if (oldHintTab.length > 0) {
|
||||||
oldHintTab.removeAttr('data-hint');
|
oldHintTab.removeAttr('data-hint');
|
||||||
|
|
@ -619,7 +619,7 @@ define([
|
||||||
oldHintTab.removeAttr('data-hint-title');
|
oldHintTab.removeAttr('data-hint-title');
|
||||||
}
|
}
|
||||||
var newHintTab = this.tabs[index].$el;
|
var newHintTab = this.tabs[index].$el;
|
||||||
newHintTab.attr('data-hint', '0');
|
newHintTab.attr('data-hint', dataHint || '0');
|
||||||
newHintTab.attr('data-hint-direction', 'top');
|
newHintTab.attr('data-hint-direction', 'top');
|
||||||
newHintTab.attr('data-hint-offset', 'medium');
|
newHintTab.attr('data-hint-offset', 'medium');
|
||||||
newHintTab.attr('data-hint-title', 'M');
|
newHintTab.attr('data-hint-title', 'M');
|
||||||
|
|
|
||||||
|
|
@ -52,7 +52,9 @@ define([
|
||||||
dynamiccolors: 10,
|
dynamiccolors: 10,
|
||||||
standardcolors: 10,
|
standardcolors: 10,
|
||||||
themecolors: 10,
|
themecolors: 10,
|
||||||
|
columns: 10,
|
||||||
effects: 5,
|
effects: 5,
|
||||||
|
hideEmptyColors: true,
|
||||||
allowReselect: true,
|
allowReselect: true,
|
||||||
transparent: false,
|
transparent: false,
|
||||||
value: '000000',
|
value: '000000',
|
||||||
|
|
@ -62,7 +64,7 @@ define([
|
||||||
|
|
||||||
template :
|
template :
|
||||||
_.template(
|
_.template(
|
||||||
'<div style="padding: 8px 12px 12px;">' +
|
'<div style="padding: 4px 0 0 12px;">' +
|
||||||
'<% var me = this; var idx = 0; %>' +
|
'<% var me = this; var idx = 0; %>' +
|
||||||
'<% $(colors).each(function(num, item) { %>' +
|
'<% $(colors).each(function(num, item) { %>' +
|
||||||
'<% if (me.isBlankSeparator(item)) { %> <div class="palette-color-spacer" style="width:100%;height:8px;float:left;"></div>' +
|
'<% if (me.isBlankSeparator(item)) { %> <div class="palette-color-spacer" style="width:100%;height:8px;float:left;"></div>' +
|
||||||
|
|
@ -76,6 +78,9 @@ define([
|
||||||
'<em><span unselectable="on"> </span></em>' +
|
'<em><span unselectable="on"> </span></em>' +
|
||||||
'</a>' +
|
'</a>' +
|
||||||
'<% } else if (me.isEffect(item)) { %>' +
|
'<% } else if (me.isEffect(item)) { %>' +
|
||||||
|
'<% if (idx>0 && me.columns>0 && idx%me.columns===0) { %> ' +
|
||||||
|
'<div style="width:100%;height:0;float:left;"></div>' +
|
||||||
|
'<% } %>' +
|
||||||
'<a effectid="<%=item.effectId%>" effectvalue="<%=item.effectValue%>" class="palette-color-effect color-<%=item.color%>" style="background:#<%=item.color%>" idx="<%=idx++%>">' +
|
'<a effectid="<%=item.effectId%>" effectvalue="<%=item.effectValue%>" class="palette-color-effect color-<%=item.color%>" style="background:#<%=item.color%>" idx="<%=idx++%>">' +
|
||||||
'<em><span style="background:#<%=item.color%>;" unselectable="on"> </span></em>' +
|
'<em><span style="background:#<%=item.color%>;" unselectable="on"> </span></em>' +
|
||||||
'</a>' +
|
'</a>' +
|
||||||
|
|
@ -85,9 +90,11 @@ define([
|
||||||
'<% }); %>' +
|
'<% }); %>' +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'<% if (me.options.dynamiccolors!==undefined) { %>' +
|
'<% if (me.options.dynamiccolors!==undefined) { %>' +
|
||||||
'<div class="palette-color-spacer" style="width:100%;height:8px;float:left;"></div><div style="padding: 12px;">' +
|
'<div class="palette-color-dynamiccolors" style="padding: 4px 0 0 12px">' +
|
||||||
|
'<div class="palette-color-spacer" style="width:100%;height:8px;float:left;"></div>' +
|
||||||
|
'<div class="palette-color-caption" style="width:100%;float:left;font-size: 11px;"><%=me.textRecentColors%></div>' +
|
||||||
'<% for (var i=0; i<me.options.dynamiccolors; i++) { %>' +
|
'<% for (var i=0; i<me.options.dynamiccolors; i++) { %>' +
|
||||||
'<a class="color-dynamic-<%=i%> dynamic-empty-color" color="" idx="<%=idx++%>">' +
|
'<a class="color-dynamic-<%=i%> dynamic-empty-color <%= me.emptyColorsClass %>" color="" idx="<%=idx++%>">' +
|
||||||
'<em><span unselectable="on"> </span></em></a>' +
|
'<em><span unselectable="on"> </span></em></a>' +
|
||||||
'<% } %>' +
|
'<% } %>' +
|
||||||
'<% } %>' +
|
'<% } %>' +
|
||||||
|
|
@ -103,10 +110,12 @@ define([
|
||||||
el = me.$el || $(this.el);
|
el = me.$el || $(this.el);
|
||||||
|
|
||||||
this.colors = me.options.colors || this.generateColorData(me.options.themecolors, me.options.effects, me.options.standardcolors, me.options.transparent);
|
this.colors = me.options.colors || this.generateColorData(me.options.themecolors, me.options.effects, me.options.standardcolors, me.options.transparent);
|
||||||
|
this.columns = me.options.columns || 0;
|
||||||
this.enableKeyEvents= me.options.enableKeyEvents;
|
this.enableKeyEvents= me.options.enableKeyEvents;
|
||||||
this.tabindex = me.options.tabindex || 0;
|
this.tabindex = me.options.tabindex || 0;
|
||||||
this.outerMenu = me.options.outerMenu;
|
this.outerMenu = me.options.outerMenu;
|
||||||
this.lastSelectedIdx = -1;
|
this.lastSelectedIdx = -1;
|
||||||
|
this.emptyColorsClass = me.options.hideEmptyColors ? 'hidden' : '';
|
||||||
|
|
||||||
me.colorItems = [];
|
me.colorItems = [];
|
||||||
if (me.options.keyMoveDirection=='vertical')
|
if (me.options.keyMoveDirection=='vertical')
|
||||||
|
|
@ -123,6 +132,15 @@ define([
|
||||||
this.updateColors(this.options.updateColorsArr[0], this.options.updateColorsArr[1]);
|
this.updateColors(this.options.updateColorsArr[0], this.options.updateColorsArr[1]);
|
||||||
if (this.options.value)
|
if (this.options.value)
|
||||||
this.select(this.options.value, true);
|
this.select(this.options.value, true);
|
||||||
|
if (this.options.outerMenu && this.options.outerMenu.focusOnShow && this.options.outerMenu.menu) {
|
||||||
|
el.addClass('focused');
|
||||||
|
this.options.outerMenu.menu.on('show:after', function(menu) {
|
||||||
|
_.delay(function() {
|
||||||
|
me.showLastSelected();
|
||||||
|
me.focus();
|
||||||
|
}, 10);
|
||||||
|
});
|
||||||
|
}
|
||||||
this.updateCustomColors();
|
this.updateCustomColors();
|
||||||
el.closest('.btn-group').on('show.bs.dropdown', _.bind(this.updateCustomColors, this));
|
el.closest('.btn-group').on('show.bs.dropdown', _.bind(this.updateCustomColors, this));
|
||||||
el.closest('.dropdown-submenu').on('show.bs.dropdown', _.bind(this.updateCustomColors, this));
|
el.closest('.dropdown-submenu').on('show.bs.dropdown', _.bind(this.updateCustomColors, this));
|
||||||
|
|
@ -171,15 +189,19 @@ define([
|
||||||
if (color) { // custom color was selected
|
if (color) { // custom color was selected
|
||||||
color = color.toUpperCase();
|
color = color.toUpperCase();
|
||||||
selected.removeClass(this.selectedCls);
|
selected.removeClass(this.selectedCls);
|
||||||
|
this.lastSelectedIdx = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
var colors = Common.localStorage.getItem('asc.'+Common.localStorage.getId()+'.colors.custom');
|
var colors = Common.localStorage.getItem('asc.'+Common.localStorage.getId()+'.colors.custom');
|
||||||
colors = colors ? colors.split(',') : [];
|
colors = colors ? colors.split(',') : [];
|
||||||
|
|
||||||
var i = -1, colorEl, c = colors.length < this.options.dynamiccolors ? colors.length : this.options.dynamiccolors;
|
var i = -1, colorEl, c = colors.length < this.options.dynamiccolors ? colors.length : this.options.dynamiccolors;
|
||||||
|
if (this.options.hideEmptyColors && this._layoutParams && el.find('.dynamic-empty-color').length !== (this.options.dynamiccolors - c)) {// recalc indexed if change custom colors
|
||||||
|
this._layoutParams = undefined;
|
||||||
|
}
|
||||||
while (++i < c) {
|
while (++i < c) {
|
||||||
colorEl = el.find('.color-dynamic-'+ i);
|
colorEl = el.find('.color-dynamic-'+ i);
|
||||||
colorEl.removeClass('dynamic-empty-color').attr('color', colors[i]);
|
colorEl.removeClass('dynamic-empty-color').removeClass(this.emptyColorsClass).attr('color', colors[i]);
|
||||||
colorEl.find('span').css({
|
colorEl.find('span').css({
|
||||||
'background-color': '#'+colors[i]
|
'background-color': '#'+colors[i]
|
||||||
});
|
});
|
||||||
|
|
@ -189,6 +211,16 @@ define([
|
||||||
color = undefined; //select only first found color
|
color = undefined; //select only first found color
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
while (i < this.options.dynamiccolors) {
|
||||||
|
colorEl = el.find('.color-dynamic-'+ i);
|
||||||
|
colorEl.removeAttr('color');
|
||||||
|
colorEl.addClass('dynamic-empty-color').addClass(this.emptyColorsClass);
|
||||||
|
colorEl.find('span').css({
|
||||||
|
'background-color': 'transparent'
|
||||||
|
});
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
el.find('.palette-color-dynamiccolors').toggleClass(this.emptyColorsClass, c===0);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -197,7 +229,7 @@ define([
|
||||||
var target = $(e.target).closest('a');
|
var target = $(e.target).closest('a');
|
||||||
var color, cmp;
|
var color, cmp;
|
||||||
|
|
||||||
if (target.length==0) return;
|
if (target.length==0) return false;
|
||||||
|
|
||||||
if (target.hasClass('color-transparent') ) {
|
if (target.hasClass('color-transparent') ) {
|
||||||
me.clearSelection(true);
|
me.clearSelection(true);
|
||||||
|
|
@ -265,12 +297,16 @@ define([
|
||||||
if (child.length==0) {
|
if (child.length==0) {
|
||||||
this.updateCustomColors();
|
this.updateCustomColors();
|
||||||
child = el.find('.color-dynamic-' + (this.options.dynamiccolors - 1));
|
child = el.find('.color-dynamic-' + (this.options.dynamiccolors - 1));
|
||||||
|
} else {
|
||||||
|
if (this.options.hideEmptyColors && this._layoutParams) // recalc indexed
|
||||||
|
this._layoutParams = undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
child.first().removeClass('dynamic-empty-color').addClass(this.selectedCls).attr('color', color[1]);
|
child.first().removeClass('dynamic-empty-color').removeClass(this.emptyColorsClass).addClass(this.selectedCls).attr('color', color[1]);
|
||||||
child.first().find('span').css({
|
child.first().find('span').css({
|
||||||
'background-color': '#'+color[1]
|
'background-color': '#'+color[1]
|
||||||
});
|
});
|
||||||
|
el.find('.palette-color-dynamiccolors').removeClass(this.emptyColorsClass);
|
||||||
this.select(color[1], true);
|
this.select(color[1], true);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
@ -483,7 +519,7 @@ define([
|
||||||
var arr = [],
|
var arr = [],
|
||||||
len = (themecolors>0 && effects>0) ? themecolors * effects : 0;
|
len = (themecolors>0 && effects>0) ? themecolors * effects : 0;
|
||||||
if (themecolors>0) {
|
if (themecolors>0) {
|
||||||
arr = [this.textThemeColors, '-'];
|
arr = [this.textThemeColors];
|
||||||
for (var i=0; i<themecolors; i++)
|
for (var i=0; i<themecolors; i++)
|
||||||
arr.push({color: 'FFFFFF', effectId: 1});
|
arr.push({color: 'FFFFFF', effectId: 1});
|
||||||
|
|
||||||
|
|
@ -492,10 +528,10 @@ define([
|
||||||
arr.push({color: 'FFFFFF', effectId: 1});
|
arr.push({color: 'FFFFFF', effectId: 1});
|
||||||
|
|
||||||
if (standardcolors)
|
if (standardcolors)
|
||||||
arr.push('-', '--', '-');
|
arr.push('-');
|
||||||
}
|
}
|
||||||
if (standardcolors) {
|
if (standardcolors) {
|
||||||
arr.push(this.textStandartColors, '-');
|
arr.push(this.textStandartColors);
|
||||||
if (transparent) {
|
if (transparent) {
|
||||||
arr.push('transparent');
|
arr.push('transparent');
|
||||||
standardcolors--;
|
standardcolors--;
|
||||||
|
|
@ -503,8 +539,6 @@ define([
|
||||||
for (var i=0; i<standardcolors; i++)
|
for (var i=0; i<standardcolors; i++)
|
||||||
arr.push('FFFFFF');
|
arr.push('FFFFFF');
|
||||||
}
|
}
|
||||||
if (this.options.dynamiccolors && (themecolors || standardcolors))
|
|
||||||
arr.push('-', '--');
|
|
||||||
return arr;
|
return arr;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -640,6 +674,7 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
textThemeColors : 'Theme Colors',
|
textThemeColors : 'Theme Colors',
|
||||||
textStandartColors : 'Standart Colors'
|
textStandartColors : 'Standard Colors',
|
||||||
|
textRecentColors : 'Recent Colors'
|
||||||
}, Common.UI.ThemeColorPalette || {}));
|
}, Common.UI.ThemeColorPalette || {}));
|
||||||
});
|
});
|
||||||
|
|
@ -104,12 +104,17 @@
|
||||||
offset : opts.offset,
|
offset : opts.offset,
|
||||||
cls : opts.cls,
|
cls : opts.cls,
|
||||||
html : opts.html,
|
html : opts.html,
|
||||||
hideonclick : opts.hideonclick
|
hideonclick : opts.hideonclick,
|
||||||
|
keepvisible: opts.keepvisible
|
||||||
});
|
});
|
||||||
|
|
||||||
if (opts.hideonclick) {
|
if (opts.hideonclick) {
|
||||||
|
var me = this;
|
||||||
var tip = this.$element.data('bs.tooltip');
|
var tip = this.$element.data('bs.tooltip');
|
||||||
if (tip) tip.tip().on('click', function() {tip.hide();});
|
if (tip) tip.tip().on('click', function() {
|
||||||
|
tip.hide();
|
||||||
|
me.trigger('tooltip:hideonclick', this);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
this.$element.on('shown.bs.tooltip', _.bind(this.onTipShown, this));
|
this.$element.on('shown.bs.tooltip', _.bind(this.onTipShown, this));
|
||||||
|
|
|
||||||
|
|
@ -235,31 +235,31 @@ define([
|
||||||
var isExpanded = !record.get('isExpanded');
|
var isExpanded = !record.get('isExpanded');
|
||||||
record.set('isExpanded', isExpanded);
|
record.set('isExpanded', isExpanded);
|
||||||
this.store[(isExpanded) ? 'expandSubItems' : 'collapseSubItems'](record);
|
this.store[(isExpanded) ? 'expandSubItems' : 'collapseSubItems'](record);
|
||||||
this.scroller.update({minScrollbarLength: 40, alwaysVisibleY: this.scrollAlwaysVisible});
|
this.scroller.update({minScrollbarLength: this.minScrollbarLength, alwaysVisibleY: this.scrollAlwaysVisible});
|
||||||
} else
|
} else
|
||||||
Common.UI.DataView.prototype.onClickItem.call(this, view, record, e);
|
Common.UI.DataView.prototype.onClickItem.call(this, view, record, e);
|
||||||
},
|
},
|
||||||
|
|
||||||
expandAll: function() {
|
expandAll: function() {
|
||||||
this.store.expandAll();
|
this.store.expandAll();
|
||||||
this.scroller.update({minScrollbarLength: 40, alwaysVisibleY: this.scrollAlwaysVisible});
|
this.scroller.update({minScrollbarLength: this.minScrollbarLength, alwaysVisibleY: this.scrollAlwaysVisible});
|
||||||
},
|
},
|
||||||
|
|
||||||
collapseAll: function() {
|
collapseAll: function() {
|
||||||
this.store.collapseAll();
|
this.store.collapseAll();
|
||||||
this.scroller.update({minScrollbarLength: 40, alwaysVisibleY: this.scrollAlwaysVisible});
|
this.scroller.update({minScrollbarLength: this.minScrollbarLength, alwaysVisibleY: this.scrollAlwaysVisible});
|
||||||
},
|
},
|
||||||
|
|
||||||
expandToLevel: function(expandLevel) {
|
expandToLevel: function(expandLevel) {
|
||||||
this.store.expandToLevel(expandLevel);
|
this.store.expandToLevel(expandLevel);
|
||||||
this.scroller.update({minScrollbarLength: 40, alwaysVisibleY: this.scrollAlwaysVisible});
|
this.scroller.update({minScrollbarLength: this.minScrollbarLength, alwaysVisibleY: this.scrollAlwaysVisible});
|
||||||
},
|
},
|
||||||
|
|
||||||
expandRecord: function(record) {
|
expandRecord: function(record) {
|
||||||
if (record) {
|
if (record) {
|
||||||
record.set('isExpanded', true);
|
record.set('isExpanded', true);
|
||||||
this.store.expandSubItems(record);
|
this.store.expandSubItems(record);
|
||||||
this.scroller.update({minScrollbarLength: 40, alwaysVisibleY: this.scrollAlwaysVisible});
|
this.scroller.update({minScrollbarLength: this.minScrollbarLength, alwaysVisibleY: this.scrollAlwaysVisible});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -267,7 +267,7 @@ define([
|
||||||
if (record) {
|
if (record) {
|
||||||
record.set('isExpanded', false);
|
record.set('isExpanded', false);
|
||||||
this.store.collapseSubItems(record);
|
this.store.collapseSubItems(record);
|
||||||
this.scroller.update({minScrollbarLength: 40, alwaysVisibleY: this.scrollAlwaysVisible});
|
this.scroller.update({minScrollbarLength: this.minScrollbarLength, alwaysVisibleY: this.scrollAlwaysVisible});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -241,7 +241,7 @@ define([
|
||||||
|
|
||||||
function _autoSize() {
|
function _autoSize() {
|
||||||
if (this.initConfig.height == 'auto') {
|
if (this.initConfig.height == 'auto') {
|
||||||
var height = parseInt(this.$window.find('> .body').css('height'));
|
var height = Math.ceil(parseFloat(this.$window.find('> .body').css('height')));
|
||||||
this.initConfig.header && (height += parseInt(this.$window.find('> .header').css('height')));
|
this.initConfig.header && (height += parseInt(this.$window.find('> .header').css('height')));
|
||||||
this.$window.height(height);
|
this.$window.height(height);
|
||||||
}
|
}
|
||||||
|
|
@ -490,7 +490,8 @@ define([
|
||||||
if (options.width=='auto') {
|
if (options.width=='auto') {
|
||||||
text_cnt.height(Math.max(text.height(), icon_height) + ((check.length>0) ? (check.height() + parseInt(check.css('margin-top'))) : 0));
|
text_cnt.height(Math.max(text.height(), icon_height) + ((check.length>0) ? (check.height() + parseInt(check.css('margin-top'))) : 0));
|
||||||
body.height(parseInt(text_cnt.css('height')) + parseInt(footer.css('height')));
|
body.height(parseInt(text_cnt.css('height')) + parseInt(footer.css('height')));
|
||||||
window.setSize(text.position().left + text.width() + parseInt(text_cnt.css('padding-right')),
|
var span_el = check.find('span');
|
||||||
|
window.setSize(Math.max(text.width(), span_el.length>0 ? span_el.position().left + span_el.width() : 0) + text.position().left + parseInt(text_cnt.css('padding-right')),
|
||||||
parseInt(body.css('height')) + parseInt(header.css('height')));
|
parseInt(body.css('height')) + parseInt(header.css('height')));
|
||||||
} else {
|
} else {
|
||||||
text.css('white-space', 'normal');
|
text.css('white-space', 'normal');
|
||||||
|
|
|
||||||
|
|
@ -85,6 +85,14 @@ define([
|
||||||
storeUsers: this.getApplication().getCollection('Common.Collections.Users'),
|
storeUsers: this.getApplication().getCollection('Common.Collections.Users'),
|
||||||
storeMessages: this.getApplication().getCollection('Common.Collections.ChatMessages')
|
storeMessages: this.getApplication().getCollection('Common.Collections.ChatMessages')
|
||||||
});
|
});
|
||||||
|
this.panelChat.on('render:after', _.bind(this.onAfterRender, this));
|
||||||
|
},
|
||||||
|
|
||||||
|
onAfterRender: function(panel) {
|
||||||
|
var viewport = this.getApplication().getController('Viewport').getView('Viewport');
|
||||||
|
viewport.hlayout.on('layout:resizedrag', _.bind(function () {
|
||||||
|
panel && panel.updateScrolls();
|
||||||
|
}, this));
|
||||||
},
|
},
|
||||||
|
|
||||||
setMode: function(mode) {
|
setMode: function(mode) {
|
||||||
|
|
@ -95,7 +103,7 @@ define([
|
||||||
if (this.mode.canCoAuthoring && this.mode.canChat)
|
if (this.mode.canCoAuthoring && this.mode.canChat)
|
||||||
this.api.asc_registerCallback('asc_onCoAuthoringChatReceiveMessage', _.bind(this.onReceiveMessage, this));
|
this.api.asc_registerCallback('asc_onCoAuthoringChatReceiveMessage', _.bind(this.onReceiveMessage, this));
|
||||||
|
|
||||||
if ( !this.mode.isEditDiagram && !this.mode.isEditMailMerge ) {
|
if ( !this.mode.isEditDiagram && !this.mode.isEditMailMerge && !this.mode.isEditOle ) {
|
||||||
this.api.asc_registerCallback('asc_onAuthParticipantsChanged', _.bind(this.onUsersChanged, this));
|
this.api.asc_registerCallback('asc_onAuthParticipantsChanged', _.bind(this.onUsersChanged, this));
|
||||||
this.api.asc_registerCallback('asc_onConnectionStateChanged', _.bind(this.onUserConnection, this));
|
this.api.asc_registerCallback('asc_onConnectionStateChanged', _.bind(this.onUserConnection, this));
|
||||||
this.api.asc_coAuthoringGetUsers();
|
this.api.asc_coAuthoringGetUsers();
|
||||||
|
|
|
||||||
|
|
@ -60,10 +60,12 @@ define([
|
||||||
'btn-save-coauth': 'coauth',
|
'btn-save-coauth': 'coauth',
|
||||||
'btn-synch': 'synch' };
|
'btn-synch': 'synch' };
|
||||||
|
|
||||||
var is_win_xp = window.RendererProcessVariable && window.RendererProcessVariable.os === 'winxp';
|
var nativevars;
|
||||||
|
|
||||||
if ( !!native ) {
|
if ( !!native ) {
|
||||||
native.features = native.features || {};
|
native.features = native.features || {};
|
||||||
|
nativevars = window.RendererProcessVariable;
|
||||||
|
|
||||||
window.on_native_message = function (cmd, param) {
|
window.on_native_message = function (cmd, param) {
|
||||||
if (/^style:change/.test(cmd)) {
|
if (/^style:change/.test(cmd)) {
|
||||||
var obj = JSON.parse(param);
|
var obj = JSON.parse(param);
|
||||||
|
|
@ -137,6 +139,10 @@ define([
|
||||||
if (!!_mr[1]) $('#app-title').show();
|
if (!!_mr[1]) $('#app-title').show();
|
||||||
else if (!!_mr[2]) $('#app-title').hide();
|
else if (!!_mr[2]) $('#app-title').hide();
|
||||||
}
|
}
|
||||||
|
} else
|
||||||
|
if (/althints:show/.test(cmd)) {
|
||||||
|
if ( /false|hide/.test(param) )
|
||||||
|
Common.NotificationCenter.trigger('hints:clear');
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -187,11 +193,36 @@ define([
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var _onHintsShow = function (visible, level) {
|
||||||
|
let info = {
|
||||||
|
visible: visible && !(level > 0),
|
||||||
|
};
|
||||||
|
|
||||||
|
if ( !!titlebuttons ) {
|
||||||
|
info.hints = {};
|
||||||
|
!!titlebuttons['print'] && (info.hints['print'] = titlebuttons['print'].btn.btnEl.attr('data-hint-title'));
|
||||||
|
!!titlebuttons['undo'] && (info.hints['undo'] = titlebuttons['undo'].btn.btnEl.attr('data-hint-title'));
|
||||||
|
!!titlebuttons['redo'] && (info.hints['redo'] = titlebuttons['redo'].btn.btnEl.attr('data-hint-title'));
|
||||||
|
!!titlebuttons['save'] && (info.hints['save'] = titlebuttons['save'].btn.btnEl.attr('data-hint-title'));
|
||||||
|
}
|
||||||
|
|
||||||
|
native.execCommand('althints:show', JSON.stringify(info));
|
||||||
|
}
|
||||||
|
|
||||||
|
var _onKeyDown = function (e) {
|
||||||
|
if ( Common.UI.HintManager.isHintVisible() ) {
|
||||||
|
native.execCommand('althints:keydown', JSON.stringify({code:e.keyCode}));
|
||||||
|
console.log('hint keydown', e.keyCode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
init: function (opts) {
|
init: function (opts) {
|
||||||
_.extend(config, opts);
|
_.extend(config, opts);
|
||||||
|
|
||||||
if ( config.isDesktopApp ) {
|
if ( config.isDesktopApp ) {
|
||||||
|
let is_win_xp = nativevars && nativevars.os === 'winxp';
|
||||||
|
|
||||||
Common.UI.Themes.setAvailable(!is_win_xp);
|
Common.UI.Themes.setAvailable(!is_win_xp);
|
||||||
Common.NotificationCenter.on('app:ready', function (opts) {
|
Common.NotificationCenter.on('app:ready', function (opts) {
|
||||||
_.extend(config, opts);
|
_.extend(config, opts);
|
||||||
|
|
@ -256,12 +287,17 @@ define([
|
||||||
|
|
||||||
Common.NotificationCenter.on({
|
Common.NotificationCenter.on({
|
||||||
'modal:show': _onModalDialog.bind(this, 'open'),
|
'modal:show': _onModalDialog.bind(this, 'open'),
|
||||||
'modal:close': _onModalDialog.bind(this, 'close')
|
'modal:close': _onModalDialog.bind(this, 'close'),
|
||||||
, 'uitheme:changed' : function (name) {
|
'uitheme:changed' : function (name) {
|
||||||
|
if (Common.localStorage.getBool('ui-theme-use-system', false)) {
|
||||||
|
native.execCommand("uitheme:changed", JSON.stringify({name:'theme-system'}));
|
||||||
|
} else {
|
||||||
var theme = Common.UI.Themes.get(name);
|
var theme = Common.UI.Themes.get(name);
|
||||||
if ( theme )
|
if ( theme )
|
||||||
native.execCommand("uitheme:changed", JSON.stringify({name:name, type:theme.type}));
|
native.execCommand("uitheme:changed", JSON.stringify({name:name, type:theme.type}));
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
'hints:show': _onHintsShow.bind(this),
|
||||||
});
|
});
|
||||||
|
|
||||||
webapp.addListeners({
|
webapp.addListeners({
|
||||||
|
|
@ -278,6 +314,8 @@ define([
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}, {id: 'desktop'});
|
}, {id: 'desktop'});
|
||||||
|
|
||||||
|
$(document).on('keydown', _onKeyDown.bind(this));
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
process: function (opts) {
|
process: function (opts) {
|
||||||
|
|
@ -313,6 +351,25 @@ define([
|
||||||
// return webapp.getController('Main').api.asc_isOffline();
|
// return webapp.getController('Main').api.asc_isOffline();
|
||||||
return webapp.getController('Main').appOptions.isOffline;
|
return webapp.getController('Main').appOptions.isOffline;
|
||||||
},
|
},
|
||||||
|
isFeatureAvailable: function (feature) {
|
||||||
|
return !!native && !!native[feature];
|
||||||
|
},
|
||||||
|
call: function (name) {
|
||||||
|
if ( native[name] ) {
|
||||||
|
let args = [].slice.call(arguments, 1);
|
||||||
|
// return native[name](...args);
|
||||||
|
return native[name].apply(this, args);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
helpUrl: function () {
|
||||||
|
if ( !!nativevars && nativevars.helpUrl ) {
|
||||||
|
var webapp = window.SSE ? 'spreadsheeteditor' :
|
||||||
|
window.PE ? 'presentationeditor' : 'documenteditor';
|
||||||
|
return nativevars.helpUrl + '/' + webapp + '/main/resources/help';
|
||||||
|
}
|
||||||
|
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -243,15 +243,6 @@ define([
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
showExternalEditor: function () {
|
|
||||||
if ( externalEditor ) {
|
|
||||||
var value = Common.localStorage.getItem("ui-theme-id", "theme-light");
|
|
||||||
externalEditor.serviceCommand('theme:change', value);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.diagramEditorView.show();
|
|
||||||
},
|
|
||||||
|
|
||||||
warningTitle: 'Warning',
|
warningTitle: 'Warning',
|
||||||
warningText: 'The object is disabled because of editing by another user.',
|
warningText: 'The object is disabled because of editing by another user.',
|
||||||
textClose: 'Close',
|
textClose: 'Close',
|
||||||
|
|
|
||||||
253
apps/common/main/lib/controller/ExternalOleEditor.js
Normal file
|
|
@ -0,0 +1,253 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2022
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha
|
||||||
|
* street, Riga, Latvia, EU, LV-1050.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* ExternalOleEditor.js
|
||||||
|
*
|
||||||
|
* Created by Julia Radzhabova on 3/10/22
|
||||||
|
* Copyright (c) 2022 Ascensio System SIA. All rights reserved.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (Common === undefined)
|
||||||
|
var Common = {};
|
||||||
|
|
||||||
|
Common.Controllers = Common.Controllers || {};
|
||||||
|
|
||||||
|
define([
|
||||||
|
'core',
|
||||||
|
'common/main/lib/view/ExternalOleEditor'
|
||||||
|
], function () { 'use strict';
|
||||||
|
Common.Controllers.ExternalOleEditor = Backbone.Controller.extend(_.extend((function() {
|
||||||
|
var appLang = '{{DEFAULT_LANG}}',
|
||||||
|
customization = undefined,
|
||||||
|
targetApp = '',
|
||||||
|
externalEditor = null,
|
||||||
|
isAppFirstOpened = true;
|
||||||
|
|
||||||
|
|
||||||
|
var createExternalEditor = function() {
|
||||||
|
!!customization && (customization.uiTheme = Common.localStorage.getItem("ui-theme-id", "theme-light"));
|
||||||
|
externalEditor = new DocsAPI.DocEditor('id-ole-editor-placeholder', {
|
||||||
|
width : '100%',
|
||||||
|
height : '100%',
|
||||||
|
documentType: 'cell',
|
||||||
|
document : {
|
||||||
|
url : '_chart_',
|
||||||
|
permissions : {
|
||||||
|
edit : true,
|
||||||
|
download: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
editorConfig: {
|
||||||
|
mode : 'editole',
|
||||||
|
targetApp : targetApp,
|
||||||
|
lang : appLang,
|
||||||
|
canCoAuthoring : false,
|
||||||
|
canBackToFolder : false,
|
||||||
|
canCreateNew : false,
|
||||||
|
customization : customization,
|
||||||
|
user : {id: ('uid-'+Date.now())}
|
||||||
|
},
|
||||||
|
events: {
|
||||||
|
'onAppReady' : function() {},
|
||||||
|
'onDocumentStateChange' : function() {},
|
||||||
|
'onError' : function() {},
|
||||||
|
'onInternalMessage' : _.bind(this.onInternalMessage, this)
|
||||||
|
}
|
||||||
|
});
|
||||||
|
Common.Gateway.on('processmouse', _.bind(this.onProcessMouse, this));
|
||||||
|
};
|
||||||
|
|
||||||
|
return {
|
||||||
|
views: ['Common.Views.ExternalOleEditor'],
|
||||||
|
|
||||||
|
initialize: function() {
|
||||||
|
this.addListeners({
|
||||||
|
'Common.Views.ExternalOleEditor': {
|
||||||
|
'setoledata': _.bind(this.setOleData, this),
|
||||||
|
'drag': _.bind(function(o, state){
|
||||||
|
externalEditor && externalEditor.serviceCommand('window:drag', state == 'start');
|
||||||
|
},this),
|
||||||
|
'show': _.bind(function(cmp){
|
||||||
|
var h = this.oleEditorView.getHeight(),
|
||||||
|
innerHeight = Common.Utils.innerHeight() - Common.Utils.InternalSettings.get('window-inactive-area-top');
|
||||||
|
if (innerHeight>h && h<700 || innerHeight<h) {
|
||||||
|
h = Math.min(innerHeight, 700);
|
||||||
|
this.oleEditorView.setHeight(h);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (externalEditor) {
|
||||||
|
externalEditor.serviceCommand('setAppDisabled',false);
|
||||||
|
if (isAppFirstOpened && this.oleEditorView._isExternalDocReady) {
|
||||||
|
isAppFirstOpened = false;
|
||||||
|
this.oleEditorView._oleData && this.setOleData();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.needDisableEditing && this.oleEditorView._isExternalDocReady) {
|
||||||
|
this.onOleEditingDisabled();
|
||||||
|
}
|
||||||
|
externalEditor.attachMouseEvents();
|
||||||
|
} else {
|
||||||
|
createExternalEditor.apply(this);
|
||||||
|
}
|
||||||
|
this.isExternalEditorVisible = true;
|
||||||
|
this.isHandlerCalled = false;
|
||||||
|
}, this),
|
||||||
|
'hide': _.bind(function(cmp){
|
||||||
|
if (externalEditor) {
|
||||||
|
externalEditor.detachMouseEvents();
|
||||||
|
this.isExternalEditorVisible = false;
|
||||||
|
}
|
||||||
|
}, this)
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
|
onLaunch: function() {
|
||||||
|
this.oleEditorView = this.createView('Common.Views.ExternalOleEditor', {handler: _.bind(this.handler, this)});
|
||||||
|
},
|
||||||
|
|
||||||
|
setApi: function(api) {
|
||||||
|
this.api = api;
|
||||||
|
this.api.asc_registerCallback('asc_onCloseOleEditor', _.bind(this.onOleEditingDisabled, this));
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
handler: function(result, value) {
|
||||||
|
if (this.isHandlerCalled) return;
|
||||||
|
this.isHandlerCalled = true;
|
||||||
|
if (this.oleEditorView._isExternalDocReady)
|
||||||
|
externalEditor && externalEditor.serviceCommand('queryClose',{mr:result});
|
||||||
|
else {
|
||||||
|
this.oleEditorView.hide();
|
||||||
|
this.isHandlerCalled = false;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
setOleData: function() {
|
||||||
|
if (!isAppFirstOpened) {
|
||||||
|
externalEditor && externalEditor.serviceCommand('setOleData', this.oleEditorView._oleData);
|
||||||
|
this.oleEditorView._oleData = null;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
loadConfig: function(data) {
|
||||||
|
if (data && data.config) {
|
||||||
|
if (data.config.lang) appLang = data.config.lang;
|
||||||
|
if (data.config.customization) customization = data.config.customization;
|
||||||
|
if (data.config.targetApp) targetApp = data.config.targetApp;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onOleEditingDisabled: function() {
|
||||||
|
if ( !this.oleEditorView.isVisible() || !this.oleEditorView._isExternalDocReady ) {
|
||||||
|
this.needDisableEditing = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.oleEditorView.setControlsDisabled(true);
|
||||||
|
|
||||||
|
Common.UI.alert({
|
||||||
|
title: this.warningTitle,
|
||||||
|
msg : this.warningText,
|
||||||
|
iconCls: 'warn',
|
||||||
|
buttons: ['ok'],
|
||||||
|
callback: _.bind(function(btn){
|
||||||
|
this.setControlsDisabled(false);
|
||||||
|
this.oleEditorView.hide();
|
||||||
|
}, this)
|
||||||
|
});
|
||||||
|
|
||||||
|
this.needDisableEditing = false;
|
||||||
|
},
|
||||||
|
|
||||||
|
onInternalMessage: function(data) {
|
||||||
|
var eventData = data.data;
|
||||||
|
|
||||||
|
if (this.oleEditorView) {
|
||||||
|
if (eventData.type == 'documentReady') {
|
||||||
|
this.oleEditorView._isExternalDocReady = true;
|
||||||
|
this.isExternalEditorVisible && (isAppFirstOpened = false);
|
||||||
|
this.oleEditorView._oleData && this.setOleData();
|
||||||
|
if (this.needDisableEditing) {
|
||||||
|
this.onOleEditingDisabled();
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
if (eventData.type == 'oleEditorReady') {
|
||||||
|
if (this.needDisableEditing===undefined)
|
||||||
|
this.oleEditorView.setControlsDisabled(false);
|
||||||
|
} else
|
||||||
|
if (eventData.type == "shortcut") {
|
||||||
|
if (eventData.data.key == 'escape')
|
||||||
|
this.oleEditorView.hide();
|
||||||
|
} else
|
||||||
|
if (eventData.type == "canClose") {
|
||||||
|
if (eventData.data.answer === true) {
|
||||||
|
if (externalEditor) {
|
||||||
|
externalEditor.serviceCommand('setAppDisabled',true);
|
||||||
|
if (eventData.data.mr == 'ok')
|
||||||
|
externalEditor.serviceCommand('getOleData');
|
||||||
|
}
|
||||||
|
this.oleEditorView.hide();
|
||||||
|
}
|
||||||
|
this.isHandlerCalled = false;
|
||||||
|
} else
|
||||||
|
if (eventData.type == "processMouse") {
|
||||||
|
if (eventData.data.event == 'mouse:up') {
|
||||||
|
this.oleEditorView.binding.dragStop();
|
||||||
|
} else
|
||||||
|
if (eventData.data.event == 'mouse:move') {
|
||||||
|
var x = parseInt(this.oleEditorView.$window.css('left')) + eventData.data.pagex,
|
||||||
|
y = parseInt(this.oleEditorView.$window.css('top')) + eventData.data.pagey + 34;
|
||||||
|
this.oleEditorView.binding.drag({pageX:x, pageY:y});
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
this.oleEditorView.fireEvent('internalmessage', this.oleEditorView, eventData);
|
||||||
|
}
|
||||||
|
} ,
|
||||||
|
|
||||||
|
onProcessMouse: function(data) {
|
||||||
|
if (data.type == 'mouseup' && this.isExternalEditorVisible) {
|
||||||
|
externalEditor && externalEditor.serviceCommand('processmouse', data);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
warningTitle: 'Warning',
|
||||||
|
warningText: 'The object is disabled because of editing by another user.',
|
||||||
|
textClose: 'Close',
|
||||||
|
textAnonymous: 'Anonymous'
|
||||||
|
}
|
||||||
|
})(), Common.Controllers.ExternalOleEditor || {}));
|
||||||
|
});
|
||||||
|
|
@ -44,6 +44,7 @@
|
||||||
* <button ... data-hint="1" data-hint-direction="right" data-hint-offset="big" data-hint-title="B">...</button>
|
* <button ... data-hint="1" data-hint-direction="right" data-hint-offset="big" data-hint-title="B">...</button>
|
||||||
* <label ... data-hint="1" data-hint-direction="bottom" data-hint-offset="medium" data-hint-title="L">...</label>
|
* <label ... data-hint="1" data-hint-direction="bottom" data-hint-offset="medium" data-hint-title="L">...</label>
|
||||||
*
|
*
|
||||||
|
*
|
||||||
* Example usage with components:
|
* Example usage with components:
|
||||||
*
|
*
|
||||||
* new Common.UI.Button({
|
* new Common.UI.Button({
|
||||||
|
|
@ -117,7 +118,11 @@ Common.UI.HintManager = new(function() {
|
||||||
_inputTimer,
|
_inputTimer,
|
||||||
_isDocReady = false,
|
_isDocReady = false,
|
||||||
_isEditDiagram = false,
|
_isEditDiagram = false,
|
||||||
_usedTitles = [];
|
_usedTitles = [],
|
||||||
|
_appPrefix,
|
||||||
|
_staticHints = { // for desktop buttons
|
||||||
|
"btnhome": 'K'
|
||||||
|
};
|
||||||
|
|
||||||
var _api;
|
var _api;
|
||||||
|
|
||||||
|
|
@ -133,7 +138,7 @@ Common.UI.HintManager = new(function() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (_isEditDiagram) {
|
if (_isEditDiagram) {
|
||||||
_currentSection = [$(window.parent.document).find('.advanced-settings-dlg')[0], window.document];
|
_currentSection = [$(window.parent.document).find('.advanced-settings-dlg:visible')[0], window.document];
|
||||||
} else if ($('#file-menu-panel').is(':visible')) {
|
} else if ($('#file-menu-panel').is(':visible')) {
|
||||||
_currentSection = $('#file-menu-panel');
|
_currentSection = $('#file-menu-panel');
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -170,6 +175,8 @@ Common.UI.HintManager = new(function() {
|
||||||
} else {
|
} else {
|
||||||
_hintVisible = false;
|
_hintVisible = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Common.NotificationCenter.trigger('hints:show', _hintVisible, _currentLevel);
|
||||||
};
|
};
|
||||||
|
|
||||||
var _hideHints = function() {
|
var _hideHints = function() {
|
||||||
|
|
@ -178,6 +185,8 @@ Common.UI.HintManager = new(function() {
|
||||||
item.remove()
|
item.remove()
|
||||||
});
|
});
|
||||||
clearInterval(_inputTimer);
|
clearInterval(_inputTimer);
|
||||||
|
|
||||||
|
Common.NotificationCenter.trigger('hints:show', false);
|
||||||
};
|
};
|
||||||
|
|
||||||
var _nextLevel = function(level) {
|
var _nextLevel = function(level) {
|
||||||
|
|
@ -218,6 +227,15 @@ Common.UI.HintManager = new(function() {
|
||||||
return arr;
|
return arr;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var _getLetterInUILanguage = function (letter) {
|
||||||
|
var l = letter;
|
||||||
|
if (_arrAlphabet.indexOf(l) === -1) {
|
||||||
|
var ind = _arrEnAlphabet.indexOf(l);
|
||||||
|
l = _arrAlphabet[ind];
|
||||||
|
}
|
||||||
|
return l;
|
||||||
|
};
|
||||||
|
|
||||||
var _isItemDisabled = function (item) {
|
var _isItemDisabled = function (item) {
|
||||||
return (item.hasClass('disabled') || item.parent().hasClass('disabled') || item.attr('disabled'));
|
return (item.hasClass('disabled') || item.parent().hasClass('disabled') || item.attr('disabled'));
|
||||||
};
|
};
|
||||||
|
|
@ -263,21 +281,25 @@ Common.UI.HintManager = new(function() {
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var _arrLetters = [];
|
var _arrLetters = [],
|
||||||
|
_usedLetters = [];
|
||||||
|
if (_currentLevel === 0) {
|
||||||
|
for (var key in _staticHints) {
|
||||||
|
var t = _staticHints[key].toLowerCase();
|
||||||
|
_usedTitles.push(t);
|
||||||
|
_usedLetters.push(_arrAlphabet.indexOf(t));
|
||||||
|
}
|
||||||
|
}
|
||||||
if (visibleItems.length > _arrAlphabet.length) {
|
if (visibleItems.length > _arrAlphabet.length) {
|
||||||
visibleItemsWithTitle.forEach(function (item) {
|
visibleItemsWithTitle.forEach(function (item) {
|
||||||
var t = $(item).data('hint-title').toLowerCase();
|
var t = $(item).data('hint-title').toLowerCase();
|
||||||
if (_arrAlphabet.indexOf(t) === -1) {
|
t = _getLetterInUILanguage(t);
|
||||||
var ind = _arrEnAlphabet.indexOf(t);
|
|
||||||
t = _arrAlphabet[ind];
|
|
||||||
}
|
|
||||||
_usedTitles.push(t);
|
_usedTitles.push(t);
|
||||||
});
|
});
|
||||||
_arrLetters = _getLetters(visibleItems.length);
|
_arrLetters = _getLetters(visibleItems.length + (_currentLevel === 0 ? _.size(_staticHints) : 0));
|
||||||
} else {
|
} else {
|
||||||
_arrLetters = _arrAlphabet.slice();
|
_arrLetters = _arrAlphabet.slice();
|
||||||
}
|
}
|
||||||
var usedLetters = [];
|
|
||||||
if (arrItemsWithTitle.length > 0) {
|
if (arrItemsWithTitle.length > 0) {
|
||||||
visibleItems.forEach(function (item) {
|
visibleItems.forEach(function (item) {
|
||||||
var el = $(item);
|
var el = $(item);
|
||||||
|
|
@ -285,9 +307,9 @@ Common.UI.HintManager = new(function() {
|
||||||
if (title) {
|
if (title) {
|
||||||
var ind = _arrEnAlphabet.indexOf(title.toLowerCase());
|
var ind = _arrEnAlphabet.indexOf(title.toLowerCase());
|
||||||
if (ind === -1) { // we have already changed
|
if (ind === -1) { // we have already changed
|
||||||
usedLetters.push(_arrAlphabet.indexOf(title.toLowerCase()));
|
_usedLetters.push(_arrAlphabet.indexOf(title.toLowerCase()));
|
||||||
} else {
|
} else {
|
||||||
usedLetters.push(ind);
|
_usedLetters.push(ind);
|
||||||
if (_lang !== 'en') {
|
if (_lang !== 'en') {
|
||||||
el.attr('data-hint-title', _arrLetters[ind].toUpperCase());
|
el.attr('data-hint-title', _arrLetters[ind].toUpperCase());
|
||||||
}
|
}
|
||||||
|
|
@ -298,7 +320,7 @@ Common.UI.HintManager = new(function() {
|
||||||
var index = 0;
|
var index = 0;
|
||||||
visibleItems.forEach(function (item) {
|
visibleItems.forEach(function (item) {
|
||||||
var el = $(item);
|
var el = $(item);
|
||||||
while (usedLetters.indexOf(index) !== -1) {
|
while (_usedLetters.indexOf(index) !== -1) {
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
var title = el.attr('data-hint-title');
|
var title = el.attr('data-hint-title');
|
||||||
|
|
@ -326,7 +348,7 @@ Common.UI.HintManager = new(function() {
|
||||||
if (!_isItemDisabled(item)) {
|
if (!_isItemDisabled(item)) {
|
||||||
var leftBorder = 0,
|
var leftBorder = 0,
|
||||||
rightBorder = docW;
|
rightBorder = docW;
|
||||||
if (!_isEditDiagram && $(_currentSection).prop('id') === 'toolbar' && ($(_currentSection).find('.toolbar-mask').length > 0 || item.closest('.group').find('.toolbar-group-mask').length > 0)
|
if (!_isEditDiagram && $(_currentSection).prop('id') === 'toolbar' && ($(_currentSection).find('.toolbar-mask').length > 0)
|
||||||
|| ($('#about-menu-panel').is(':visible') && item.closest('.hint-section').prop('id') === 'right-menu')) { // don't show right menu hints when about is visible
|
|| ($('#about-menu-panel').is(':visible') && item.closest('.hint-section').prop('id') === 'right-menu')) { // don't show right menu hints when about is visible
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -436,6 +458,10 @@ Common.UI.HintManager = new(function() {
|
||||||
|
|
||||||
var _init = function(api) {
|
var _init = function(api) {
|
||||||
_api = api;
|
_api = api;
|
||||||
|
|
||||||
|
var filter = Common.localStorage.getKeysFilter();
|
||||||
|
_appPrefix = (filter && filter.length) ? filter.split(',')[0] : '';
|
||||||
|
|
||||||
Common.NotificationCenter.on({
|
Common.NotificationCenter.on({
|
||||||
'app:ready': function (mode) {
|
'app:ready': function (mode) {
|
||||||
var lang = mode.lang ? mode.lang.toLowerCase() : 'en';
|
var lang = mode.lang ? mode.lang.toLowerCase() : 'en';
|
||||||
|
|
@ -537,7 +563,7 @@ Common.UI.HintManager = new(function() {
|
||||||
} else {
|
} else {
|
||||||
_isComplete = false;
|
_isComplete = false;
|
||||||
_hideHints();
|
_hideHints();
|
||||||
if (!_isEditDiagram && $(_currentSection).prop('id') === 'toolbar' && ($(_currentSection).find('.toolbar-mask').length > 0 || curr.closest('.group').find('.toolbar-group-mask').length > 0)) {
|
if (!_isEditDiagram && $(_currentSection).prop('id') === 'toolbar' && ($(_currentSection).find('.toolbar-mask').length > 0)) {
|
||||||
_resetToDefault();
|
_resetToDefault();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -559,7 +585,7 @@ Common.UI.HintManager = new(function() {
|
||||||
if (curr.prop('id') === 'btn-goback' || curr.closest('.btn-slot').prop('id') === 'slot-btn-options' ||
|
if (curr.prop('id') === 'btn-goback' || curr.closest('.btn-slot').prop('id') === 'slot-btn-options' ||
|
||||||
curr.closest('.btn-slot').prop('id') === 'slot-btn-mode' || curr.prop('id') === 'btn-favorite' || curr.parent().prop('id') === 'tlb-box-users' ||
|
curr.closest('.btn-slot').prop('id') === 'slot-btn-mode' || curr.prop('id') === 'btn-favorite' || curr.parent().prop('id') === 'tlb-box-users' ||
|
||||||
curr.prop('id') === 'left-btn-thumbs' || curr.hasClass('scroll') || curr.prop('id') === 'left-btn-about' ||
|
curr.prop('id') === 'left-btn-thumbs' || curr.hasClass('scroll') || curr.prop('id') === 'left-btn-about' ||
|
||||||
curr.prop('id') === 'left-btn-support') {
|
curr.prop('id') === 'left-btn-support' || curr.closest('.btn-slot').prop('id') === 'slot-btn-search') {
|
||||||
_resetToDefault();
|
_resetToDefault();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -594,7 +620,9 @@ Common.UI.HintManager = new(function() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_needShow = (!e.shiftKey && e.keyCode == Common.UI.Keys.ALT && !Common.Utils.ModalWindow.isVisible() && _isDocReady && _arrAlphabet.length > 0);
|
_needShow = (Common.Utils.InternalSettings.get(_appPrefix + "settings-use-alt-key") && !e.shiftKey && e.keyCode == Common.UI.Keys.ALT &&
|
||||||
|
!Common.Utils.ModalWindow.isVisible() && _isDocReady && _arrAlphabet.length > 0 &&
|
||||||
|
!(window.PE && $('#pe-preview').is(':visible')));
|
||||||
if (e.altKey && e.keyCode !== 115) {
|
if (e.altKey && e.keyCode !== 115) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
}
|
}
|
||||||
|
|
@ -609,7 +637,16 @@ Common.UI.HintManager = new(function() {
|
||||||
_arrAlphabet = langsJson[lang];
|
_arrAlphabet = langsJson[lang];
|
||||||
return _arrAlphabet;
|
return _arrAlphabet;
|
||||||
};
|
};
|
||||||
return !_setAlphabet(lng) ? (!_setAlphabet(lng.split(/[\-_]/)[0]) ? _setAlphabet('en') : true) : true;
|
var loaded = !_setAlphabet(lng) ? (!_setAlphabet(lng.split(/[\-_]/)[0]) ? _setAlphabet('en') : true) : true;
|
||||||
|
if (loaded && _lang !== 'en') {
|
||||||
|
for (var key in _staticHints) {
|
||||||
|
var hint = _getLetterInUILanguage(_staticHints[key].toLowerCase());
|
||||||
|
if (hint) {
|
||||||
|
_staticHints[key] = hint.toUpperCase();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return loaded;
|
||||||
});
|
});
|
||||||
Common.Utils.loadConfig('../../common/main/resources/alphabetletters/qwertyletters.json', function (langsJson) {
|
Common.Utils.loadConfig('../../common/main/resources/alphabetletters/qwertyletters.json', function (langsJson) {
|
||||||
_arrQwerty = langsJson[_lang];
|
_arrQwerty = langsJson[_lang];
|
||||||
|
|
@ -638,7 +675,9 @@ Common.UI.HintManager = new(function() {
|
||||||
$('.hint-div').remove();
|
$('.hint-div').remove();
|
||||||
}
|
}
|
||||||
if ($('iframe').length > 0) {
|
if ($('iframe').length > 0) {
|
||||||
|
try {
|
||||||
$('iframe').contents().find('.hint-div').remove();
|
$('iframe').contents().find('.hint-div').remove();
|
||||||
|
} catch (e) {}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -647,7 +686,11 @@ Common.UI.HintManager = new(function() {
|
||||||
};
|
};
|
||||||
|
|
||||||
var _setMode = function (mode) {
|
var _setMode = function (mode) {
|
||||||
_isEditDiagram = mode.isEditDiagram;
|
_isEditDiagram = mode.isEditDiagram || mode.isEditMailMerge || mode.isEditOle;
|
||||||
|
};
|
||||||
|
|
||||||
|
var _getStaticHint = function (key) {
|
||||||
|
return _staticHints[key];
|
||||||
};
|
};
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
|
@ -655,6 +698,7 @@ Common.UI.HintManager = new(function() {
|
||||||
setMode: _setMode,
|
setMode: _setMode,
|
||||||
clearHints: _clearHints,
|
clearHints: _clearHints,
|
||||||
needCloseFileMenu: _needCloseFileMenu,
|
needCloseFileMenu: _needCloseFileMenu,
|
||||||
isHintVisible: _isHintVisible
|
isHintVisible: _isHintVisible,
|
||||||
|
getStaticHint: _getStaticHint
|
||||||
}
|
}
|
||||||
})();
|
})();
|
||||||
|
|
@ -262,7 +262,7 @@ define([
|
||||||
store.where({isRevision: false}).forEach(function(item){
|
store.where({isRevision: false}).forEach(function(item){
|
||||||
item.set('isVisible', needExpand);
|
item.set('isVisible', needExpand);
|
||||||
});
|
});
|
||||||
this.panelHistory.viewHistoryList.scroller.update({minScrollbarLength: 40});
|
this.panelHistory.viewHistoryList.scroller.update({minScrollbarLength: this.panelHistory.viewHistoryList.minScrollbarLength});
|
||||||
this.panelHistory.btnExpand.cmpEl.text(needExpand ? this.panelHistory.textHideAll : this.panelHistory.textShowAll);
|
this.panelHistory.btnExpand.cmpEl.text(needExpand ? this.panelHistory.textHideAll : this.panelHistory.textShowAll);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -63,7 +63,7 @@ define([
|
||||||
'render:before' : function (toolbar) {
|
'render:before' : function (toolbar) {
|
||||||
var appOptions = me.getApplication().getController('Main').appOptions;
|
var appOptions = me.getApplication().getController('Main').appOptions;
|
||||||
|
|
||||||
if ( !appOptions.isEditMailMerge && !appOptions.isEditDiagram ) {
|
if ( !appOptions.isEditMailMerge && !appOptions.isEditDiagram && !appOptions.isEditOle ) {
|
||||||
var tab = {action: 'plugins', caption: me.panelPlugins.groupCaption, dataHintTitle: 'E', layoutname: 'toolbar-plugins'};
|
var tab = {action: 'plugins', caption: me.panelPlugins.groupCaption, dataHintTitle: 'E', layoutname: 'toolbar-plugins'};
|
||||||
me.$toolbarPanelPlugins = me.panelPlugins.getPanel();
|
me.$toolbarPanelPlugins = me.panelPlugins.getPanel();
|
||||||
|
|
||||||
|
|
@ -162,6 +162,8 @@ define([
|
||||||
this.api.asc_registerCallback("asc_onPluginMouseMove", _.bind(this.onPluginMouseMove, this));
|
this.api.asc_registerCallback("asc_onPluginMouseMove", _.bind(this.onPluginMouseMove, this));
|
||||||
this.api.asc_registerCallback('asc_onPluginsReset', _.bind(this.resetPluginsList, this));
|
this.api.asc_registerCallback('asc_onPluginsReset', _.bind(this.resetPluginsList, this));
|
||||||
this.api.asc_registerCallback('asc_onPluginsInit', _.bind(this.onPluginsInit, this));
|
this.api.asc_registerCallback('asc_onPluginsInit', _.bind(this.onPluginsInit, this));
|
||||||
|
this.api.asc_registerCallback('asc_onPluginShowButton', _.bind(this.onPluginShowButton, this));
|
||||||
|
this.api.asc_registerCallback('asc_onPluginHideButton', _.bind(this.onPluginHideButton, this));
|
||||||
|
|
||||||
this.loadPlugins();
|
this.loadPlugins();
|
||||||
}
|
}
|
||||||
|
|
@ -204,17 +206,7 @@ define([
|
||||||
arr = [];
|
arr = [];
|
||||||
storePlugins.each(function(item){
|
storePlugins.each(function(item){
|
||||||
var plugin = new Asc.CPlugin();
|
var plugin = new Asc.CPlugin();
|
||||||
plugin.deserialize(item.attributes);
|
plugin.deserialize(item.get('original'));
|
||||||
|
|
||||||
var variations = item.get('variations'),
|
|
||||||
variationsArr = [];
|
|
||||||
variations.forEach(function(itemVar){
|
|
||||||
var variation = new Asc.CPluginVariation();
|
|
||||||
variation.deserialize(itemVar.attributes);
|
|
||||||
variationsArr.push(variation);
|
|
||||||
});
|
|
||||||
|
|
||||||
plugin.set_Variations(variationsArr);
|
|
||||||
item.set('pluginObj', plugin);
|
item.set('pluginObj', plugin);
|
||||||
arr.push(plugin);
|
arr.push(plugin);
|
||||||
});
|
});
|
||||||
|
|
@ -252,6 +244,10 @@ define([
|
||||||
$('<div class="separator long"></div>').appendTo(me.$toolbarPanelPlugins);
|
$('<div class="separator long"></div>').appendTo(me.$toolbarPanelPlugins);
|
||||||
_group = $('<div class="group"></div>');
|
_group = $('<div class="group"></div>');
|
||||||
rank_plugins = 0;
|
rank_plugins = 0;
|
||||||
|
} else {
|
||||||
|
_group.appendTo(me.$toolbarPanelPlugins);
|
||||||
|
$('<div class="separator long invisible"></div>').appendTo(me.$toolbarPanelPlugins);
|
||||||
|
_group = $('<div class="group" style="padding-left: 0;"></div>');
|
||||||
}
|
}
|
||||||
|
|
||||||
var btn = me.panelPlugins.createPluginButton(model);
|
var btn = me.panelPlugins.createPluginButton(model);
|
||||||
|
|
@ -387,6 +383,7 @@ define([
|
||||||
buttons: isCustomWindow ? undefined : newBtns,
|
buttons: isCustomWindow ? undefined : newBtns,
|
||||||
toolcallback: _.bind(this.onToolClose, this),
|
toolcallback: _.bind(this.onToolClose, this),
|
||||||
help: !!help,
|
help: !!help,
|
||||||
|
loader: plugin.get_Loader(),
|
||||||
modal: isModal!==undefined ? isModal : true
|
modal: isModal!==undefined ? isModal : true
|
||||||
});
|
});
|
||||||
me.pluginDlg.on({
|
me.pluginDlg.on({
|
||||||
|
|
@ -405,6 +402,9 @@ define([
|
||||||
},
|
},
|
||||||
'help': function(){
|
'help': function(){
|
||||||
help && window.open(help, '_blank');
|
help && window.open(help, '_blank');
|
||||||
|
},
|
||||||
|
'header:click': function(type){
|
||||||
|
me.api.asc_pluginButtonClick(type);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
@ -464,6 +464,14 @@ define([
|
||||||
this.parsePlugins(pluginsdata)
|
this.parsePlugins(pluginsdata)
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onPluginShowButton: function(id) {
|
||||||
|
this.pluginDlg && this.pluginDlg.showButton(id);
|
||||||
|
},
|
||||||
|
|
||||||
|
onPluginHideButton: function(id) {
|
||||||
|
this.pluginDlg && this.pluginDlg.hideButton(id);
|
||||||
|
},
|
||||||
|
|
||||||
runAutoStartPlugins: function() {
|
runAutoStartPlugins: function() {
|
||||||
if (this.autostart && this.autostart.length > 0) {
|
if (this.autostart && this.autostart.length > 0) {
|
||||||
this.api.asc_pluginRun(this.autostart.shift(), 0, '');
|
this.api.asc_pluginRun(this.autostart.shift(), 0, '');
|
||||||
|
|
@ -562,7 +570,8 @@ define([
|
||||||
visible: pluginVisible,
|
visible: pluginVisible,
|
||||||
groupName: (item.group) ? item.group.name : '',
|
groupName: (item.group) ? item.group.name : '',
|
||||||
groupRank: (item.group) ? item.group.rank : 0,
|
groupRank: (item.group) ? item.group.rank : 0,
|
||||||
minVersion: item.minVersion
|
minVersion: item.minVersion,
|
||||||
|
original: item
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -100,6 +100,7 @@ define([
|
||||||
onLaunch: function () {
|
onLaunch: function () {
|
||||||
this.collection = this.getApplication().getCollection('Common.Collections.ReviewChanges');
|
this.collection = this.getApplication().getCollection('Common.Collections.ReviewChanges');
|
||||||
this.userCollection = this.getApplication().getCollection('Common.Collections.Users');
|
this.userCollection = this.getApplication().getCollection('Common.Collections.Users');
|
||||||
|
this.viewmode = false;
|
||||||
|
|
||||||
this._state = {posx: -1000, posy: -1000, popoverVisible: false, previewMode: false, compareSettings: null, wsLock: false, wsProps: []};
|
this._state = {posx: -1000, posy: -1000, popoverVisible: false, previewMode: false, compareSettings: null, wsLock: false, wsProps: []};
|
||||||
|
|
||||||
|
|
@ -160,13 +161,23 @@ define([
|
||||||
this.document = data.doc;
|
this.document = data.doc;
|
||||||
},
|
},
|
||||||
|
|
||||||
SetDisabled: function(state) {
|
SetDisabled: function(state, reviewMode, fillFormMode) {
|
||||||
if (this.dlgChanges)
|
if (this.dlgChanges)
|
||||||
this.dlgChanges.close();
|
this.dlgChanges.close();
|
||||||
this.view && this.view.SetDisabled(state, this.langs, {comments: !!this._state.wsProps['Objects']});
|
if (reviewMode)
|
||||||
|
this.lockToolbar(Common.enumLock.previewReviewMode, state);
|
||||||
|
else if (fillFormMode)
|
||||||
|
this.lockToolbar(Common.enumLock.viewFormMode, state);
|
||||||
|
else
|
||||||
|
this.lockToolbar(Common.enumLock.viewMode, state);
|
||||||
|
|
||||||
this.setPreviewMode(state);
|
this.setPreviewMode(state);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
lockToolbar: function (causes, lock, opts) {
|
||||||
|
Common.Utils.lockControls(causes, lock, opts, this.view.getButtons());
|
||||||
|
},
|
||||||
|
|
||||||
setPreviewMode: function(mode) { //disable accept/reject in popover
|
setPreviewMode: function(mode) { //disable accept/reject in popover
|
||||||
if (this.viewmode === mode) return;
|
if (this.viewmode === mode) return;
|
||||||
this.viewmode = mode;
|
this.viewmode = mode;
|
||||||
|
|
@ -202,8 +213,7 @@ define([
|
||||||
btnlock = this.isSelectedChangesLocked(changes, isShow);
|
btnlock = this.isSelectedChangesLocked(changes, isShow);
|
||||||
}
|
}
|
||||||
if (this._state.lock !== btnlock) {
|
if (this._state.lock !== btnlock) {
|
||||||
this.view.btnAccept.setDisabled(btnlock);
|
Common.Utils.lockControls(Common.enumLock.reviewChangelock, btnlock, {array: [this.view.btnAccept, this.view.btnReject]});
|
||||||
this.view.btnReject.setDisabled(btnlock);
|
|
||||||
if (this.dlgChanges) {
|
if (this.dlgChanges) {
|
||||||
this.dlgChanges.btnAccept.setDisabled(btnlock);
|
this.dlgChanges.btnAccept.setDisabled(btnlock);
|
||||||
this.dlgChanges.btnReject.setDisabled(btnlock);
|
this.dlgChanges.btnReject.setDisabled(btnlock);
|
||||||
|
|
@ -540,7 +550,7 @@ define([
|
||||||
if (item.value === 'all') {
|
if (item.value === 'all') {
|
||||||
this.api.asc_AcceptAllChanges();
|
this.api.asc_AcceptAllChanges();
|
||||||
} else {
|
} else {
|
||||||
this.api.asc_AcceptChanges();
|
this.api.asc_AcceptChangesBySelection(true); // accept and move to the next change
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
this.api.asc_AcceptChanges(menu);
|
this.api.asc_AcceptChanges(menu);
|
||||||
|
|
@ -555,7 +565,7 @@ define([
|
||||||
if (item.value === 'all') {
|
if (item.value === 'all') {
|
||||||
this.api.asc_RejectAllChanges();
|
this.api.asc_RejectAllChanges();
|
||||||
} else {
|
} else {
|
||||||
this.api.asc_RejectChanges();
|
this.api.asc_RejectChangesBySelection(true); // reject and move to the next change
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
this.api.asc_RejectChanges(menu);
|
this.api.asc_RejectChanges(menu);
|
||||||
|
|
@ -603,7 +613,8 @@ define([
|
||||||
this.view.turnChanges(state, global);
|
this.view.turnChanges(state, global);
|
||||||
if (userId && this.userCollection) {
|
if (userId && this.userCollection) {
|
||||||
var rec = this.userCollection.findOriginalUser(userId);
|
var rec = this.userCollection.findOriginalUser(userId);
|
||||||
rec && this.showTips(Common.Utils.String.format(globalFlag ? this.textOnGlobal : this.textOffGlobal, AscCommon.UserInfoParser.getParsedName(rec.get('username'))));
|
rec && Common.NotificationCenter.trigger('showmessage', {msg: Common.Utils.String.format(globalFlag ? this.textOnGlobal : this.textOffGlobal, AscCommon.UserInfoParser.getParsedName(rec.get('username')))},
|
||||||
|
{timeout: 5000, hideCloseTip: true});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
@ -787,7 +798,7 @@ define([
|
||||||
Common.NotificationCenter.trigger('editing:disable', disable, {
|
Common.NotificationCenter.trigger('editing:disable', disable, {
|
||||||
viewMode: false,
|
viewMode: false,
|
||||||
reviewMode: true,
|
reviewMode: true,
|
||||||
fillFormwMode: false,
|
fillFormMode: false,
|
||||||
allowMerge: false,
|
allowMerge: false,
|
||||||
allowSignature: false,
|
allowSignature: false,
|
||||||
allowProtect: false,
|
allowProtect: false,
|
||||||
|
|
@ -798,22 +809,13 @@ define([
|
||||||
navigation: {disable: false, previewMode: true},
|
navigation: {disable: false, previewMode: true},
|
||||||
comments: {disable: false, previewMode: true},
|
comments: {disable: false, previewMode: true},
|
||||||
chat: false,
|
chat: false,
|
||||||
review: false,
|
review: true,
|
||||||
viewport: false,
|
viewport: false,
|
||||||
documentHolder: true,
|
documentHolder: true,
|
||||||
toolbar: true,
|
toolbar: true,
|
||||||
plugins: true
|
plugins: true,
|
||||||
|
protect: true
|
||||||
}, 'review');
|
}, 'review');
|
||||||
|
|
||||||
if (this.view) {
|
|
||||||
this.view.$el.find('.no-group-mask.review').css('opacity', 1);
|
|
||||||
|
|
||||||
this.view.btnsDocLang && this.view.btnsDocLang.forEach(function(button) {
|
|
||||||
if ( button ) {
|
|
||||||
button.setDisabled(disable || !this.langs || this.langs.length<1);
|
|
||||||
}
|
|
||||||
}, this);
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
|
||||||
createToolbarPanel: function() {
|
createToolbarPanel: function() {
|
||||||
|
|
@ -889,8 +891,8 @@ define([
|
||||||
}
|
}
|
||||||
me.onChangeProtectSheet();
|
me.onChangeProtectSheet();
|
||||||
if (me.view) {
|
if (me.view) {
|
||||||
me.view.btnCommentRemove && me.view.btnCommentRemove.setDisabled(!Common.localStorage.getBool(me.view.appPrefix + "settings-livecomment", true) || !!this._state.wsProps['Objects']);
|
me.lockToolbar(Common.enumLock.hideComments, !Common.localStorage.getBool(me.view.appPrefix + "settings-livecomment", true), {array: [me.view.btnCommentRemove, me.view.btnCommentResolve]});
|
||||||
me.view.btnCommentResolve && me.view.btnCommentResolve.setDisabled(!Common.localStorage.getBool(me.view.appPrefix + "settings-livecomment", true) || !!this._state.wsProps['Objects']);
|
me.lockToolbar(Common.enumLock['Objects'], !!this._state.wsProps['Objects'], {array: [me.view.btnCommentRemove, me.view.btnCommentResolve]});
|
||||||
}
|
}
|
||||||
|
|
||||||
var val = Common.localStorage.getItem(me.view.appPrefix + "settings-review-hover-mode");
|
var val = Common.localStorage.getItem(me.view.appPrefix + "settings-review-hover-mode");
|
||||||
|
|
@ -902,41 +904,6 @@ define([
|
||||||
me.appConfig.reviewHoverMode = val;
|
me.appConfig.reviewHoverMode = val;
|
||||||
},
|
},
|
||||||
|
|
||||||
showTips: function(strings) {
|
|
||||||
var me = this;
|
|
||||||
if (!strings.length) return;
|
|
||||||
if (typeof(strings)!='object') strings = [strings];
|
|
||||||
|
|
||||||
function showNextTip() {
|
|
||||||
var str_tip = strings.shift();
|
|
||||||
if (str_tip) {
|
|
||||||
me.tooltip.setTitle(str_tip);
|
|
||||||
me.tooltip.show();
|
|
||||||
me.tipTimeout = setTimeout(function () {
|
|
||||||
me.tooltip.hide();
|
|
||||||
}, 5000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!this.tooltip) {
|
|
||||||
this.tooltip = new Common.UI.Tooltip({
|
|
||||||
owner: this.getApplication().getController('Toolbar').getView(),
|
|
||||||
hideonclick: true,
|
|
||||||
placement: 'bottom',
|
|
||||||
cls: 'main-info',
|
|
||||||
offset: 30
|
|
||||||
});
|
|
||||||
this.tooltip.on('tooltip:hide', function(cmp){
|
|
||||||
if (cmp==me.tooltip) {
|
|
||||||
clearTimeout(me.tipTimeout);
|
|
||||||
setTimeout(showNextTip, 300);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
showNextTip();
|
|
||||||
},
|
|
||||||
|
|
||||||
applySettings: function(menu) {
|
applySettings: function(menu) {
|
||||||
this.view && this.view.turnSpelling( Common.localStorage.getBool(this.view.appPrefix + "settings-spellcheck", true) );
|
this.view && this.view.turnSpelling( Common.localStorage.getBool(this.view.appPrefix + "settings-spellcheck", true) );
|
||||||
this.view && this.view.turnCoAuthMode( Common.localStorage.getBool(this.view.appPrefix + "settings-coauthmode", true) );
|
this.view && this.view.turnCoAuthMode( Common.localStorage.getBool(this.view.appPrefix + "settings-coauthmode", true) );
|
||||||
|
|
@ -952,11 +919,7 @@ define([
|
||||||
|
|
||||||
setLanguages: function (array) {
|
setLanguages: function (array) {
|
||||||
this.langs = array;
|
this.langs = array;
|
||||||
this.view && this.view.btnsDocLang && this.view.btnsDocLang.forEach(function(button) {
|
this.lockToolbar(Common.enumLock.noSpellcheckLangs, this.langs.length<1, {array: this.view.btnsDocLang});
|
||||||
if ( button ) {
|
|
||||||
button.setDisabled(this.langs.length<1);
|
|
||||||
}
|
|
||||||
}, this);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
onDocLanguage: function() {
|
onDocLanguage: function() {
|
||||||
|
|
@ -976,6 +939,7 @@ define([
|
||||||
onLostEditRights: function() {
|
onLostEditRights: function() {
|
||||||
this._readonlyRights = true;
|
this._readonlyRights = true;
|
||||||
this.view && this.view.onLostEditRights();
|
this.view && this.view.onLostEditRights();
|
||||||
|
this.view && this.lockToolbar(Common.enumLock.cantShare, true, {array: [this.view.btnSharing]});
|
||||||
},
|
},
|
||||||
|
|
||||||
changeAccessRights: function(btn,event,opts) {
|
changeAccessRights: function(btn,event,opts) {
|
||||||
|
|
@ -1007,7 +971,7 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
onCoAuthoringDisconnect: function() {
|
onCoAuthoringDisconnect: function() {
|
||||||
this.SetDisabled(true);
|
this.lockToolbar(Common.enumLock.lostConnect, true)
|
||||||
},
|
},
|
||||||
|
|
||||||
onUpdateUsers: function() {
|
onUpdateUsers: function() {
|
||||||
|
|
@ -1025,15 +989,14 @@ define([
|
||||||
if (!item.asc_getView())
|
if (!item.asc_getView())
|
||||||
length++;
|
length++;
|
||||||
});
|
});
|
||||||
this.view.btnCompare.setDisabled(length>1 || this.viewmode);
|
Common.Utils.lockControls(Common.enumLock.hasCoeditingUsers, length>1, {array: [this.view.btnCompare]});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
commentsShowHide: function(mode) {
|
commentsShowHide: function(mode) {
|
||||||
if (!this.view) return;
|
if (!this.view) return;
|
||||||
var value = Common.Utils.InternalSettings.get(this.view.appPrefix + "settings-livecomment");
|
var value = Common.Utils.InternalSettings.get(this.view.appPrefix + "settings-livecomment");
|
||||||
(value!==undefined) && this.view.btnCommentRemove && this.view.btnCommentRemove.setDisabled(mode != 'show' && !value || !!this._state.wsProps['Objects']);
|
(value!==undefined) && this.lockToolbar(Common.enumLock.hideComments, mode != 'show' && !value, {array: [this.view.btnCommentRemove, this.view.btnCommentResolve]});
|
||||||
(value!==undefined) && this.view.btnCommentResolve && this.view.btnCommentResolve.setDisabled(mode != 'show' && !value || !!this._state.wsProps['Objects']);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
onChangeProtectSheet: function(props) {
|
onChangeProtectSheet: function(props) {
|
||||||
|
|
@ -1045,11 +1008,7 @@ define([
|
||||||
this._state.wsLock = props ? props.wsLock : false;
|
this._state.wsLock = props ? props.wsLock : false;
|
||||||
|
|
||||||
if (!this.view) return;
|
if (!this.view) return;
|
||||||
var leftmenu = this.getApplication().getController('LeftMenu'),
|
this.lockToolbar(Common.enumLock['Objects'], !!this._state.wsProps['Objects'], {array: [this.view.btnCommentRemove, this.view.btnCommentResolve]});
|
||||||
isCommentsVisible = leftmenu && leftmenu.isCommentsVisible();
|
|
||||||
var value = Common.Utils.InternalSettings.get(this.view.appPrefix + "settings-livecomment");
|
|
||||||
(value!==undefined) && this.view.btnCommentRemove && this.view.btnCommentRemove.setDisabled(!isCommentsVisible && !value || !!this._state.wsProps['Objects']);
|
|
||||||
(value!==undefined) && this.view.btnCommentResolve && this.view.btnCommentResolve.setDisabled(!isCommentsVisible && !value || !!this._state.wsProps['Objects']);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
textInserted: '<b>Inserted:</b>',
|
textInserted: '<b>Inserted:</b>',
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,16 @@ define([
|
||||||
|
|
||||||
Common.UI.Themes = new (function(locale) {
|
Common.UI.Themes = new (function(locale) {
|
||||||
!locale && (locale = {});
|
!locale && (locale = {});
|
||||||
|
|
||||||
|
const THEME_TYPE_LIGHT = 'light';
|
||||||
|
const THEME_TYPE_DARK = 'dark';
|
||||||
|
const THEME_TYPE_SYSTEM = 'system';
|
||||||
var themes_map = {
|
var themes_map = {
|
||||||
|
'theme-system': {
|
||||||
|
text: locale.txtThemeSystem || 'Same as system',
|
||||||
|
type: THEME_TYPE_SYSTEM,
|
||||||
|
source: 'static',
|
||||||
|
},
|
||||||
'theme-light': {
|
'theme-light': {
|
||||||
text: locale.txtThemeLight || 'Light',
|
text: locale.txtThemeLight || 'Light',
|
||||||
type: 'light',
|
type: 'light',
|
||||||
|
|
@ -27,10 +36,16 @@ define([
|
||||||
type: 'dark',
|
type: 'dark',
|
||||||
source: 'static',
|
source: 'static',
|
||||||
},
|
},
|
||||||
|
'theme-contrast-dark': {
|
||||||
|
text: locale.txtThemeContrastDark || 'Dark Contrast',
|
||||||
|
type: 'dark',
|
||||||
|
source: 'static',
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !!window.currentLoaderTheme ) {
|
if ( !!window.currentLoaderTheme ) {
|
||||||
themes_map[currentLoaderTheme.id] = {};
|
if ( !themes_map[currentLoaderTheme.id] )
|
||||||
|
themes_map[currentLoaderTheme.id] = currentLoaderTheme;
|
||||||
window.currentLoaderTheme = undefined;
|
window.currentLoaderTheme = undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -43,6 +58,10 @@ define([
|
||||||
"toolbar-header-spreadsheet",
|
"toolbar-header-spreadsheet",
|
||||||
"toolbar-header-presentation",
|
"toolbar-header-presentation",
|
||||||
|
|
||||||
|
"text-toolbar-header-on-background-document",
|
||||||
|
"text-toolbar-header-on-background-spreadsheet",
|
||||||
|
"text-toolbar-header-on-background-presentation",
|
||||||
|
|
||||||
"background-normal",
|
"background-normal",
|
||||||
"background-toolbar",
|
"background-toolbar",
|
||||||
"background-toolbar-additional",
|
"background-toolbar-additional",
|
||||||
|
|
@ -104,6 +123,7 @@ define([
|
||||||
"canvas-page-border",
|
"canvas-page-border",
|
||||||
|
|
||||||
"canvas-ruler-background",
|
"canvas-ruler-background",
|
||||||
|
"canvas-ruler-border",
|
||||||
"canvas-ruler-margins-background",
|
"canvas-ruler-margins-background",
|
||||||
"canvas-ruler-mark",
|
"canvas-ruler-mark",
|
||||||
"canvas-ruler-handle-border",
|
"canvas-ruler-handle-border",
|
||||||
|
|
@ -195,6 +215,8 @@ define([
|
||||||
themes_map[obj.id] = {text: theme_label, type: obj.type};
|
themes_map[obj.id] = {text: theme_label, type: obj.type};
|
||||||
write_theme_css( create_colors_css(obj.id, obj.colors) );
|
write_theme_css( create_colors_css(obj.id, obj.colors) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Common.NotificationCenter.trigger('uitheme:countchanged');
|
||||||
}
|
}
|
||||||
|
|
||||||
var get_themes_config = function (url) {
|
var get_themes_config = function (url) {
|
||||||
|
|
@ -257,6 +279,21 @@ define([
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const is_theme_type_system = function (id) { return themes_map[id].type == THEME_TYPE_SYSTEM; }
|
||||||
|
const get_system_theme_type = function () { return window.matchMedia('(prefers-color-scheme: dark)').matches ? THEME_TYPE_DARK : THEME_TYPE_LIGHT; }
|
||||||
|
const get_system_default_theme = function () {
|
||||||
|
const id = get_system_theme_type() == THEME_TYPE_DARK ?
|
||||||
|
id_default_dark_theme : id_default_light_theme;
|
||||||
|
|
||||||
|
return {id: id, info: themes_map[id]};
|
||||||
|
};
|
||||||
|
|
||||||
|
const on_system_theme_dark = function (mql) {
|
||||||
|
if (Common.localStorage.getBool('ui-theme-use-system', false)) {
|
||||||
|
this.setTheme('theme-system');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
return {
|
return {
|
||||||
init: function (api) {
|
init: function (api) {
|
||||||
var me = this;
|
var me = this;
|
||||||
|
|
@ -265,7 +302,9 @@ define([
|
||||||
$(window).on('storage', function (e) {
|
$(window).on('storage', function (e) {
|
||||||
if ( e.key == 'ui-theme' || e.key == 'ui-theme-id' ) {
|
if ( e.key == 'ui-theme' || e.key == 'ui-theme-id' ) {
|
||||||
if ( !!e.originalEvent.newValue ) {
|
if ( !!e.originalEvent.newValue ) {
|
||||||
me.setTheme(e.originalEvent.newValue, true);
|
if (Common.localStorage.getBool('ui-theme-use-system', false)) {
|
||||||
|
me.setTheme('theme-system');
|
||||||
|
} else me.setTheme(e.originalEvent.newValue, true);
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
if ( e.key == 'content-theme' ) {
|
if ( e.key == 'content-theme' ) {
|
||||||
|
|
@ -309,6 +348,8 @@ define([
|
||||||
obj.name = theme_name;
|
obj.name = theme_name;
|
||||||
api.asc_setSkin(obj);
|
api.asc_setSkin(obj);
|
||||||
|
|
||||||
|
if ( !(Common.Utils.isIE10 || Common.Utils.isIE11) )
|
||||||
|
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', on_system_theme_dark.bind(this));
|
||||||
Common.NotificationCenter.on('document:ready', on_document_ready.bind(this));
|
Common.NotificationCenter.on('document:ready', on_document_ready.bind(this));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -329,6 +370,9 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
currentThemeId: function () {
|
currentThemeId: function () {
|
||||||
|
if ( Common.localStorage.getBool('ui-theme-use-system', false) )
|
||||||
|
return 'theme-system';
|
||||||
|
|
||||||
var t = Common.localStorage.getItem('ui-theme') || Common.localStorage.getItem('ui-theme-id');
|
var t = Common.localStorage.getItem('ui-theme') || Common.localStorage.getItem('ui-theme-id');
|
||||||
var id = get_ui_theme_name(t);
|
var id = get_ui_theme_name(t);
|
||||||
return !!themes_map[id] ? id : id_default_light_theme;
|
return !!themes_map[id] ? id : id_default_light_theme;
|
||||||
|
|
@ -342,8 +386,9 @@ define([
|
||||||
return themes_map[this.defaultThemeId(type)]
|
return themes_map[this.defaultThemeId(type)]
|
||||||
},
|
},
|
||||||
|
|
||||||
isDarkTheme: function () {
|
isDarkTheme: function (id) {
|
||||||
return themes_map[this.currentThemeId()].type == 'dark';
|
!id && (id = this.currentThemeId());
|
||||||
|
return (is_theme_type_system(id) ? get_system_default_theme().info.type : themes_map[id].type) == THEME_TYPE_DARK;
|
||||||
},
|
},
|
||||||
|
|
||||||
isContentThemeDark: function () {
|
isContentThemeDark: function () {
|
||||||
|
|
@ -376,11 +421,39 @@ define([
|
||||||
Common.NotificationCenter.trigger('contenttheme:dark', !is_current_dark);
|
Common.NotificationCenter.trigger('contenttheme:dark', !is_current_dark);
|
||||||
},
|
},
|
||||||
|
|
||||||
setTheme: function (obj, force) {
|
setTheme: function (obj) {
|
||||||
if ( !obj ) return;
|
if ( !obj ) return;
|
||||||
|
|
||||||
var id = get_ui_theme_name(obj);
|
var id = get_ui_theme_name(obj),
|
||||||
if ( (this.currentThemeId() != id || force) && !!themes_map[id] ) {
|
refresh_only = arguments[1];
|
||||||
|
|
||||||
|
if ( !refresh_only && is_theme_type_system(this.currentThemeId()) ) {
|
||||||
|
// TODO: need refactoring. for bug 58801
|
||||||
|
if ( get_system_default_theme().id == id ) {
|
||||||
|
Common.localStorage.setBool('ui-theme-use-system', false);
|
||||||
|
Common.localStorage.setItem('ui-theme-id', '');
|
||||||
|
Common.localStorage.setItem('ui-theme-id', id);
|
||||||
|
Common.NotificationCenter.trigger('uitheme:changed', id);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( is_theme_type_system(id) ) {
|
||||||
|
if ( get_system_default_theme().id == this.currentThemeId() ) {
|
||||||
|
Common.localStorage.setBool('ui-theme-use-system', true);
|
||||||
|
Common.localStorage.setItem('ui-theme-id', '');
|
||||||
|
Common.localStorage.setItem('ui-theme-id', id);
|
||||||
|
Common.NotificationCenter.trigger('uitheme:changed', id);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Common.localStorage.setBool('ui-theme-use-system', true);
|
||||||
|
id = get_system_default_theme().id;
|
||||||
|
} else {
|
||||||
|
Common.localStorage.setBool('ui-theme-use-system', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( (this.currentThemeId() != id || refresh_only) && !!themes_map[id] ) {
|
||||||
document.body.className = document.body.className.replace(/theme-[\w-]+\s?/gi, '').trim();
|
document.body.className = document.body.className.replace(/theme-[\w-]+\s?/gi, '').trim();
|
||||||
document.body.classList.add(id, 'theme-type-' + themes_map[id].type);
|
document.body.classList.add(id, 'theme-type-' + themes_map[id].type);
|
||||||
|
|
||||||
|
|
@ -404,15 +477,18 @@ define([
|
||||||
var theme_obj = {
|
var theme_obj = {
|
||||||
id: id,
|
id: id,
|
||||||
type: obj.type,
|
type: obj.type,
|
||||||
|
text: themes_map[id].text,
|
||||||
};
|
};
|
||||||
|
|
||||||
if ( themes_map[id].source != 'static' ) {
|
if ( themes_map[id].source != 'static' ) {
|
||||||
theme_obj.colors = obj;
|
theme_obj.colors = obj;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( !refresh_only )
|
||||||
Common.localStorage.setItem('ui-theme', JSON.stringify(theme_obj));
|
Common.localStorage.setItem('ui-theme', JSON.stringify(theme_obj));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( !refresh_only )
|
||||||
Common.localStorage.setItem('ui-theme-id', id);
|
Common.localStorage.setItem('ui-theme-id', id);
|
||||||
Common.NotificationCenter.trigger('uitheme:changed', id);
|
Common.NotificationCenter.trigger('uitheme:changed', id);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -36,7 +36,8 @@
|
||||||
return _MAP[x] || x.toUpperCase().charCodeAt(0);
|
return _MAP[x] || x.toUpperCase().charCodeAt(0);
|
||||||
},
|
},
|
||||||
_downKeys = [];
|
_downKeys = [];
|
||||||
var locked;
|
var locked,
|
||||||
|
propagate;
|
||||||
|
|
||||||
for(k=1;k<20;k++) _MAP['f'+k] = 111+k;
|
for(k=1;k<20;k++) _MAP['f'+k] = 111+k;
|
||||||
|
|
||||||
|
|
@ -116,6 +117,8 @@
|
||||||
// call the handler and stop the event if neccessary
|
// call the handler and stop the event if neccessary
|
||||||
if((handler.mods.length == 0 && !_mods[16] && !_mods[18] && !_mods[17] && !_mods[91]) || modifiersMatch){
|
if((handler.mods.length == 0 && !_mods[16] && !_mods[18] && !_mods[17] && !_mods[91]) || modifiersMatch){
|
||||||
if(locked===true || handler.locked || handler.method(event, handler)===false){
|
if(locked===true || handler.locked || handler.method(event, handler)===false){
|
||||||
|
if (locked===true && propagate || handler.locked && handler.propagate)
|
||||||
|
continue;
|
||||||
if(event.preventDefault) event.preventDefault();
|
if(event.preventDefault) event.preventDefault();
|
||||||
else event.returnValue = false;
|
else event.returnValue = false;
|
||||||
if(event.stopPropagation) event.stopPropagation();
|
if(event.stopPropagation) event.stopPropagation();
|
||||||
|
|
@ -188,8 +191,8 @@
|
||||||
|
|
||||||
if (keys.length > 1) {
|
if (keys.length > 1) {
|
||||||
mods = getMods(keys);
|
mods = getMods(keys);
|
||||||
key = keys[keys.length - 1];
|
|
||||||
}
|
}
|
||||||
|
(keys.length > 0) && (key = keys[keys.length - 1]);
|
||||||
|
|
||||||
key = code(key);
|
key = code(key);
|
||||||
|
|
||||||
|
|
@ -301,8 +304,8 @@
|
||||||
|
|
||||||
if (keys.length > 1) {
|
if (keys.length > 1) {
|
||||||
mods = getMods(keys);
|
mods = getMods(keys);
|
||||||
key = keys[keys.length - 1];
|
|
||||||
}
|
}
|
||||||
|
(keys.length > 0) && (key = keys[keys.length - 1]);
|
||||||
|
|
||||||
key = code(key);
|
key = code(key);
|
||||||
|
|
||||||
|
|
@ -320,12 +323,23 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function suspend(key, scope) {
|
function suspend(key, scope, pass) {
|
||||||
key ? setKeyOptions(key, scope, 'locked', true) : (locked = true);
|
if (key) {
|
||||||
|
setKeyOptions(key, scope, 'locked', true)
|
||||||
|
pass && setKeyOptions(key, scope, 'propagate', true)
|
||||||
|
} else {
|
||||||
|
locked = true;
|
||||||
|
pass && (propagate = true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function resume(key, scope) {
|
function resume(key, scope) {
|
||||||
key ? setKeyOptions(key, scope, 'locked', false) : (locked = false);
|
if (key) {
|
||||||
|
setKeyOptions(key, scope, 'locked', false)
|
||||||
|
setKeyOptions(key, scope, 'propagate', false)
|
||||||
|
} else {
|
||||||
|
locked = propagate = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// set window.key and window.key.set/get/deleteScope, and the default filter
|
// set window.key and window.key.set/get/deleteScope, and the default filter
|
||||||
|
|
|
||||||
|
|
@ -128,8 +128,9 @@ function patchDropDownKeyDown(e) {
|
||||||
var mnu = $('> [role=menu]', li),
|
var mnu = $('> [role=menu]', li),
|
||||||
$subitems = mnu.find('> li:not(.divider):not(.disabled):visible > a'),
|
$subitems = mnu.find('> li:not(.divider):not(.disabled):visible > a'),
|
||||||
$dataviews = mnu.find('> li:not(.divider):not(.disabled):visible .dataview'),
|
$dataviews = mnu.find('> li:not(.divider):not(.disabled):visible .dataview'),
|
||||||
|
$palette = mnu.find('> li:not(.divider):not(.disabled):visible .theme-colorpalette.focused'),
|
||||||
$internal_menu = mnu.find('> li:not(.divider):not(.disabled):visible ul.internal-menu');
|
$internal_menu = mnu.find('> li:not(.divider):not(.disabled):visible ul.internal-menu');
|
||||||
if ($subitems.length>0 && $dataviews.length<1 && $internal_menu.length<1)
|
if ($subitems.length>0 && $dataviews.length<1 && $internal_menu.length<1 && $palette.length<1)
|
||||||
($subitems.index($subitems.filter(':focus'))<0) && $subitems.eq(0).focus();
|
($subitems.index($subitems.filter(':focus'))<0) && $subitems.eq(0).focus();
|
||||||
}, 250);
|
}, 250);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
63
apps/common/main/lib/template/SearchPanel.template
Normal file
|
|
@ -0,0 +1,63 @@
|
||||||
|
<div id="search-box" class="layout-ct vbox search-panel">
|
||||||
|
<div id="search-header">
|
||||||
|
<label id="search-adv-title"></label>
|
||||||
|
<div id="search-btn-close"></div>
|
||||||
|
</div>
|
||||||
|
<div id="search-adv-settings">
|
||||||
|
<table cols="1">
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td class="padding-small"><div id="search-adv-text"></div></td>
|
||||||
|
</tr>
|
||||||
|
<tr class="edit-setting">
|
||||||
|
<td class="padding-large"><div id="search-adv-replace-text"></div></td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td class="padding-large">
|
||||||
|
<label id="search-adv-results-number" style="display: inline-block;">
|
||||||
|
<%= scope.textSearchResults %>
|
||||||
|
</label>
|
||||||
|
<div class="search-nav-btns">
|
||||||
|
<div id="search-adv-back"></div>
|
||||||
|
<div id="search-adv-next"></div>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr class="edit-setting">
|
||||||
|
<td class="padding-large">
|
||||||
|
<button type="button" class="btn btn-text-default" id="search-adv-replace" data-hint="1" data-hint-direction="bottom" data-hint-offset="big"><%= scope.textReplace %></button>
|
||||||
|
<button type="button" class="btn btn-text-default" id="search-adv-replace-all" data-hint="1" data-hint-direction="bottom" data-hint-offset="big"><%= scope.textReplaceAll %></button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr class="search-options-block">
|
||||||
|
<td class="padding-large">
|
||||||
|
<div id="open-search-options" data-hint="1" data-hint-direction="left" data-hint-offset="0, -15">
|
||||||
|
<div class="search-options-caret img-commonctrl"></div>
|
||||||
|
<div class="search-options-txt"><%= scope.textSearchOptions %></div>
|
||||||
|
</div>
|
||||||
|
<div id="search-options">
|
||||||
|
<label class="input-label"><%= scope.textWithin %></label>
|
||||||
|
<div id="search-adv-cmb-within"></div>
|
||||||
|
<div id="search-adv-select-range"></div>
|
||||||
|
<label class="input-label"><%= scope.textSearch %></label>
|
||||||
|
<div id="search-adv-cmb-search"></div>
|
||||||
|
<label class="input-label"><%= scope.textLookIn %></label>
|
||||||
|
<div id="search-adv-cmb-look-in"></div>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td class="padding-small"><div id="search-adv-case-sensitive"></div></td>
|
||||||
|
</tr>
|
||||||
|
<!---<tr>
|
||||||
|
<td class="padding-small"><div id="search-adv-use-regexp"></div></td>
|
||||||
|
</tr>-->
|
||||||
|
<tr>
|
||||||
|
<td class="padding-large"><div id="search-adv-match-word"></div></td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div id="search-results" class="ps-container oo">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
@ -148,8 +148,8 @@ Common.util = Common.util||{};
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
suspendEvents: function(key,scope) {
|
suspendEvents: function(key,scope,propagate) {
|
||||||
window.key.suspend(key,scope);
|
window.key.suspend(key,scope,propagate);
|
||||||
},
|
},
|
||||||
|
|
||||||
resumeEvents: function(key,scope) {
|
resumeEvents: function(key,scope) {
|
||||||
|
|
|
||||||
|
|
@ -109,13 +109,16 @@
|
||||||
|
|
||||||
var me = this;
|
var me = this;
|
||||||
Common.NotificationCenter.on({'layout:changed': function(e){
|
Common.NotificationCenter.on({'layout:changed': function(e){
|
||||||
if (!me.options.hideonclick && me.tip().is(':visible'))
|
if (!me.options.keepvisible && !me.options.hideonclick && me.tip().is(':visible'))
|
||||||
me.hide();
|
me.hide();
|
||||||
}});
|
}});
|
||||||
|
this.isDesktopApp = Common.Controllers.Desktop.isActive();
|
||||||
},
|
},
|
||||||
|
|
||||||
mousemove: function (e) {
|
mousemove: function (e) {
|
||||||
this.targetXY = [e.clientX*Common.Utils.zoom(), e.clientY*Common.Utils.zoom()];
|
var x = e.clientX*Common.Utils.zoom(),
|
||||||
|
y = e.clientY*Common.Utils.zoom();
|
||||||
|
this.targetXY = [x, this.isDesktopApp ? Math.max(y, 14) : y];
|
||||||
},
|
},
|
||||||
|
|
||||||
leave: function(obj) {
|
leave: function(obj) {
|
||||||
|
|
|
||||||
|
|
@ -794,6 +794,9 @@ define(function(){ 'use strict';
|
||||||
textTurns: 'Turns',
|
textTurns: 'Turns',
|
||||||
textShapes: 'Shapes',
|
textShapes: 'Shapes',
|
||||||
textLoops: 'Loops',
|
textLoops: 'Loops',
|
||||||
|
textPathCurve: 'Curve',
|
||||||
|
textPathLine: 'Line',
|
||||||
|
textPathScribble: 'Scribble',
|
||||||
|
|
||||||
getEffectGroupData: function () {
|
getEffectGroupData: function () {
|
||||||
return [
|
return [
|
||||||
|
|
@ -849,8 +852,8 @@ define(function(){ 'use strict';
|
||||||
{group: 'menu-effect-group-path', value: AscFormat.MOTION_ARC_DOWN, iconCls: 'animation-motion-paths-arcs', displayValue: this.textArcs, familyEffect: 'patharcs'},
|
{group: 'menu-effect-group-path', value: AscFormat.MOTION_ARC_DOWN, iconCls: 'animation-motion-paths-arcs', displayValue: this.textArcs, familyEffect: 'patharcs'},
|
||||||
{group: 'menu-effect-group-path', value: AscFormat.MOTION_TURN_DOWN, iconCls: 'animation-motion-paths-turns', displayValue: this.textTurns, familyEffect: 'pathturns'},
|
{group: 'menu-effect-group-path', value: AscFormat.MOTION_TURN_DOWN, iconCls: 'animation-motion-paths-turns', displayValue: this.textTurns, familyEffect: 'pathturns'},
|
||||||
{group: 'menu-effect-group-path', value: AscFormat.MOTION_CIRCLE, iconCls: 'animation-motion-paths-shapes', displayValue: this.textShapes, familyEffect: 'pathshapes'},
|
{group: 'menu-effect-group-path', value: AscFormat.MOTION_CIRCLE, iconCls: 'animation-motion-paths-shapes', displayValue: this.textShapes, familyEffect: 'pathshapes'},
|
||||||
{group: 'menu-effect-group-path', value: AscFormat.MOTION_HORIZONTAL_FIGURE_8_FOUR, iconCls: 'animation-motion-paths-loops', displayValue: this.textLoops, familyEffect: 'pathloops'}//,
|
{group: 'menu-effect-group-path', value: AscFormat.MOTION_HORIZONTAL_FIGURE_8_FOUR, iconCls: 'animation-motion-paths-loops', displayValue: this.textLoops, familyEffect: 'pathloops'},
|
||||||
//{group: 'menu-effect-group-path', value: AscFormat.MOTION_CUSTOM_PATH, iconCls: 'animation-motion-paths-custom-path', displayValue: this.textCustomPath}
|
{group: 'menu-effect-group-path', value: AscFormat.MOTION_CUSTOM_PATH, iconCls: 'animation-motion-paths-custom-path', displayValue: this.textCustomPath}
|
||||||
];
|
];
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -1038,7 +1041,8 @@ define(function(){ 'use strict';
|
||||||
{group: 'menu-effect-group-path', level: 'menu-effect-level-special', value: AscFormat.MOTION_PEANUT, displayValue: this.textPeanut},
|
{group: 'menu-effect-group-path', level: 'menu-effect-level-special', value: AscFormat.MOTION_PEANUT, displayValue: this.textPeanut},
|
||||||
{group: 'menu-effect-group-path', level: 'menu-effect-level-special', value: AscFormat.MOTION_POINTY_STAR, displayValue: this.textPointStar},
|
{group: 'menu-effect-group-path', level: 'menu-effect-level-special', value: AscFormat.MOTION_POINTY_STAR, displayValue: this.textPointStar},
|
||||||
{group: 'menu-effect-group-path', level: 'menu-effect-level-special', value: AscFormat.MOTION_SWOOSH, displayValue: this.textSwoosh},
|
{group: 'menu-effect-group-path', level: 'menu-effect-level-special', value: AscFormat.MOTION_SWOOSH, displayValue: this.textSwoosh},
|
||||||
{group: 'menu-effect-group-path', level: 'menu-effect-level-special', value: AscFormat.MOTION_VERTICAL_FIGURE_8, displayValue: this.textVerticalFigure, familyEffect: 'pathloops'}
|
{group: 'menu-effect-group-path', level: 'menu-effect-level-special', value: AscFormat.MOTION_VERTICAL_FIGURE_8, displayValue: this.textVerticalFigure, familyEffect: 'pathloops'},
|
||||||
|
{group: 'menu-effect-group-path', level: 'menu-effect-level-special', value: AscFormat.MOTION_CUSTOM_PATH, displayValue: this.textCustomPath, notsupported: true}
|
||||||
|
|
||||||
];
|
];
|
||||||
},
|
},
|
||||||
|
|
@ -1277,11 +1281,21 @@ define(function(){ 'use strict';
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 'menu-effect-group-path':
|
||||||
|
switch (type) {
|
||||||
|
case AscFormat.MOTION_CUSTOM_PATH:
|
||||||
|
return [
|
||||||
|
{value: AscFormat.MOTION_CUSTOM_PATH_CURVE, caption: this.textPathCurve, isCustom: true},
|
||||||
|
{value: AscFormat.MOTION_CUSTOM_PATH_LINE, caption: this.textPathLine, isCustom: true},
|
||||||
|
{value: AscFormat.MOTION_CUSTOM_PATH_SCRIBBLE, caption: this.textPathScribble, isCustom: true}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
getSimilarEffectsArray: function (group, familyEffect) {
|
getSimilarEffectsArray: function (familyEffect) {
|
||||||
switch (familyEffect){
|
switch (familyEffect){
|
||||||
case 'shape':
|
case 'shape':
|
||||||
return [
|
return [
|
||||||
|
|
|
||||||
|
|
@ -31,4 +31,10 @@ if ( !window.fetch ) {
|
||||||
return target;
|
return target;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (typeof Object.getOwnPropertySymbols != 'function') {
|
||||||
|
Object.getOwnPropertySymbols = function(target) {
|
||||||
|
return [];
|
||||||
|
};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -62,8 +62,14 @@ if ( window.desktop ) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( theme.id ) {
|
if ( theme.id ) {
|
||||||
// params.uitheme = undefined;
|
if ( theme.id == 'theme-system' ) {
|
||||||
|
localStorage.setItem("ui-theme-use-system", "1");
|
||||||
|
localStorage.removeItem("ui-theme-id");
|
||||||
|
delete params.uitheme;
|
||||||
|
} else {
|
||||||
localStorage.setItem("ui-theme-id", theme.id);
|
localStorage.setItem("ui-theme-id", theme.id);
|
||||||
|
}
|
||||||
|
|
||||||
localStorage.removeItem("ui-theme");
|
localStorage.removeItem("ui-theme");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -93,10 +99,12 @@ if ( !!ui_theme_name ) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( checkLocalStorage ) {
|
if ( checkLocalStorage ) {
|
||||||
var content_theme = localStorage.getItem("content-theme");
|
let current_theme = localStorage.getItem("ui-theme");
|
||||||
if ( content_theme == 'dark' ) {
|
|
||||||
var current_theme = localStorage.getItem("ui-theme");
|
|
||||||
if ( !!current_theme && /type":\s*"dark/.test(current_theme) ) {
|
if ( !!current_theme && /type":\s*"dark/.test(current_theme) ) {
|
||||||
|
document.body.classList.add("theme-type-dark");
|
||||||
|
|
||||||
|
let content_theme = localStorage.getItem("content-theme");
|
||||||
|
if ( content_theme == 'dark' ) {
|
||||||
document.body.classList.add("content-theme-dark");
|
document.body.classList.add("content-theme-dark");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,9 @@
|
||||||
|
|
||||||
+function init_themes() {
|
+function init_themes() {
|
||||||
|
if ( localStorage.getItem("ui-theme-use-system") == '1' ) {
|
||||||
|
localStorage.removeItem("ui-theme-id");
|
||||||
|
}
|
||||||
|
|
||||||
var objtheme = localStorage.getItem("ui-theme");
|
var objtheme = localStorage.getItem("ui-theme");
|
||||||
if ( typeof(objtheme) == 'string' &&
|
if ( typeof(objtheme) == 'string' &&
|
||||||
objtheme.startsWith("{") && objtheme.endsWith("}") )
|
objtheme.startsWith("{") && objtheme.endsWith("}") )
|
||||||
|
|
|
||||||
|
|
@ -193,13 +193,18 @@ var utils = new(function() {
|
||||||
me.innerHeight = window.innerHeight * me.zoom;
|
me.innerHeight = window.innerHeight * me.zoom;
|
||||||
me.applicationPixelRatio = scale.applicationPixelRatio || scale.devicePixelRatio;
|
me.applicationPixelRatio = scale.applicationPixelRatio || scale.devicePixelRatio;
|
||||||
};
|
};
|
||||||
|
checkSizeIE = function() {
|
||||||
|
me.innerWidth = window.innerWidth;
|
||||||
|
me.innerHeight = window.innerHeight;
|
||||||
|
};
|
||||||
me.zoom = 1;
|
me.zoom = 1;
|
||||||
me.applicationPixelRatio = 1;
|
me.applicationPixelRatio = 1;
|
||||||
me.innerWidth = window.innerWidth;
|
me.innerWidth = window.innerWidth;
|
||||||
me.innerHeight = window.innerHeight;
|
me.innerHeight = window.innerHeight;
|
||||||
if ( isIE )
|
if ( isIE ) {
|
||||||
$(document.body).addClass('ie');
|
$(document.body).addClass('ie');
|
||||||
else {
|
$(window).on('resize', checkSizeIE);
|
||||||
|
} else {
|
||||||
checkSize();
|
checkSize();
|
||||||
$(window).on('resize', checkSize);
|
$(window).on('resize', checkSize);
|
||||||
}
|
}
|
||||||
|
|
@ -436,7 +441,7 @@ var metrics = new(function() {
|
||||||
}
|
}
|
||||||
})();
|
})();
|
||||||
|
|
||||||
Common.Utils.Metric = _extend_object(Common.Utils.Metric, metrics);
|
Common.Utils.Metric = _extend_object(metrics, Common.Utils.Metric);
|
||||||
|
|
||||||
Common.Utils.RGBColor = function(colorString) {
|
Common.Utils.RGBColor = function(colorString) {
|
||||||
var r, g, b;
|
var r, g, b;
|
||||||
|
|
@ -603,8 +608,12 @@ Common.Utils.RGBColor = function(colorString) {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
Common.Utils.String = new (function() {
|
var utilsString = new (function() {
|
||||||
return {
|
return {
|
||||||
|
textCtrl: 'Ctrl',
|
||||||
|
textShift: 'Shift',
|
||||||
|
textAlt: 'Alt',
|
||||||
|
|
||||||
format: function(format) {
|
format: function(format) {
|
||||||
var args = _.toArray(arguments).slice(1);
|
var args = _.toArray(arguments).slice(1);
|
||||||
if (args.length && typeof args[0] == 'object')
|
if (args.length && typeof args[0] == 'object')
|
||||||
|
|
@ -648,7 +657,7 @@ Common.Utils.String = new (function() {
|
||||||
return Common.Utils.String.format(template, string.replace(/\+(?=\S)/g, '').replace(/Ctrl|ctrl/g, '⌘').replace(/Alt|alt/g, '⌥').replace(/Shift|shift/g, '⇧'));
|
return Common.Utils.String.format(template, string.replace(/\+(?=\S)/g, '').replace(/Ctrl|ctrl/g, '⌘').replace(/Alt|alt/g, '⌥').replace(/Shift|shift/g, '⇧'));
|
||||||
}
|
}
|
||||||
|
|
||||||
return Common.Utils.String.format(template, string);
|
return Common.Utils.String.format(template, string.replace(/Ctrl|ctrl/g, this.textCtrl).replace(/Alt|alt/g, this.textAlt).replace(/Shift|shift/g, this.textShift));
|
||||||
},
|
},
|
||||||
|
|
||||||
parseFloat: function(string) {
|
parseFloat: function(string) {
|
||||||
|
|
@ -680,6 +689,8 @@ Common.Utils.String = new (function() {
|
||||||
}
|
}
|
||||||
})();
|
})();
|
||||||
|
|
||||||
|
Common.Utils.String = _extend_object(utilsString, Common.Utils.String);
|
||||||
|
|
||||||
Common.Utils.isBrowserSupported = function() {
|
Common.Utils.isBrowserSupported = function() {
|
||||||
return !((Common.Utils.ieVersion != 0 && Common.Utils.ieVersion < 10.0) ||
|
return !((Common.Utils.ieVersion != 0 && Common.Utils.ieVersion < 10.0) ||
|
||||||
(Common.Utils.safariVersion != 0 && Common.Utils.safariVersion < 5.0) ||
|
(Common.Utils.safariVersion != 0 && Common.Utils.safariVersion < 5.0) ||
|
||||||
|
|
@ -881,7 +892,7 @@ Common.Utils.lockControls = function(causes, lock, opts, defControls) {
|
||||||
opts.merge && (controls = _.union(defControls,controls));
|
opts.merge && (controls = _.union(defControls,controls));
|
||||||
|
|
||||||
function doLock(cmp, cause) {
|
function doLock(cmp, cause) {
|
||||||
if ( cmp && _.contains(cmp.options.lock, cause) ) {
|
if ( cmp && cmp.options && _.contains(cmp.options.lock, cause) ) {
|
||||||
var index = cmp.keepState.indexOf(cause);
|
var index = cmp.keepState.indexOf(cause);
|
||||||
if (lock) {
|
if (lock) {
|
||||||
if (index < 0) {
|
if (index < 0) {
|
||||||
|
|
@ -986,8 +997,9 @@ jQuery.fn.extend({
|
||||||
var _el = document.getElementById(id.substring(1));
|
var _el = document.getElementById(id.substring(1));
|
||||||
if ( !_el ) {
|
if ( !_el ) {
|
||||||
parent = parent || this;
|
parent = parent || this;
|
||||||
if ( parent instanceof jQuery ) {
|
if ( parent && parent.length > 0 ) {
|
||||||
parent.each(function (i, node) {
|
parent.each(function (i, node) {
|
||||||
|
if (node.querySelectorAll) {
|
||||||
_el = node.querySelectorAll(id);
|
_el = node.querySelectorAll(id);
|
||||||
if ( _el.length == 0 ) {
|
if ( _el.length == 0 ) {
|
||||||
if ( ('#' + node.id) == id ) {
|
if ( ('#' + node.id) == id ) {
|
||||||
|
|
@ -999,12 +1011,15 @@ jQuery.fn.extend({
|
||||||
_el = _el[0];
|
_el = _el[0];
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
|
if (parent && parent.querySelectorAll) {
|
||||||
_el = parent.querySelectorAll(id);
|
_el = parent.querySelectorAll(id);
|
||||||
if ( _el && _el.length ) return _el[0];
|
if ( _el && _el.length ) return _el[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return _el;
|
return _el;
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -126,6 +126,12 @@ define([
|
||||||
'<a href="mailto:" id="id-about-company-mail"></a>',
|
'<a href="mailto:" id="id-about-company-mail"></a>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'</tr>',
|
'</tr>',
|
||||||
|
'<tr>',
|
||||||
|
'<td align="center" class="padding-small">',
|
||||||
|
'<label class="asc-about-desc-name">' + this.txtTel + '</label>',
|
||||||
|
'<label class="asc-about-desc" id="id-about-company-tel"></label>',
|
||||||
|
'</td>',
|
||||||
|
'</tr>',
|
||||||
'<tr>',
|
'<tr>',
|
||||||
'<td align="center" class="padding-small">',
|
'<td align="center" class="padding-small">',
|
||||||
'<a href="" target="_blank" id="id-about-company-url"></a>',
|
'<a href="" target="_blank" id="id-about-company-url"></a>',
|
||||||
|
|
@ -177,6 +183,7 @@ define([
|
||||||
this.lblCompanyMail = _$l.findById('#id-about-company-mail');
|
this.lblCompanyMail = _$l.findById('#id-about-company-mail');
|
||||||
this.lblCompanyUrl = _$l.findById('#id-about-company-url');
|
this.lblCompanyUrl = _$l.findById('#id-about-company-url');
|
||||||
this.lblCompanyLic = _$l.findById('#id-about-company-lic');
|
this.lblCompanyLic = _$l.findById('#id-about-company-lic');
|
||||||
|
this.lblCompanyTel = _$l.findById('#id-about-company-tel');
|
||||||
|
|
||||||
this.$el.html(_$l);
|
this.$el.html(_$l);
|
||||||
this.$el.addClass('about-dlg');
|
this.$el.addClass('about-dlg');
|
||||||
|
|
@ -224,6 +231,11 @@ define([
|
||||||
this.lblCompanyMail.attr('href', "mailto:"+value).text(value) :
|
this.lblCompanyMail.attr('href', "mailto:"+value).text(value) :
|
||||||
this.lblCompanyMail.parents('tr').addClass('hidden');
|
this.lblCompanyMail.parents('tr').addClass('hidden');
|
||||||
|
|
||||||
|
value = customer.phone;
|
||||||
|
value && value.length ?
|
||||||
|
this.lblCompanyTel.text(value) :
|
||||||
|
this.lblCompanyTel.parents('tr').addClass('hidden');
|
||||||
|
|
||||||
if ((value = customer.www) && value.length) {
|
if ((value = customer.www) && value.length) {
|
||||||
var http = !/^https?:\/{2}/i.test(value) ? "http:\/\/" : '';
|
var http = !/^https?:\/{2}/i.test(value) ? "http:\/\/" : '';
|
||||||
this.lblCompanyUrl.attr('href', http+value).text(value);
|
this.lblCompanyUrl.attr('href', http+value).text(value);
|
||||||
|
|
|
||||||
|
|
@ -136,7 +136,7 @@ define([
|
||||||
this.txtMessage.on('keydown', _.bind(this._onKeyDown, this));
|
this.txtMessage.on('keydown', _.bind(this._onKeyDown, this));
|
||||||
|
|
||||||
this.setupLayout();
|
this.setupLayout();
|
||||||
|
this.trigger('render:after', this);
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -493,7 +493,7 @@ define([
|
||||||
},
|
},
|
||||||
updateScrolls: function () {
|
updateScrolls: function () {
|
||||||
if (this.commentsView && this.commentsView.scroller) {
|
if (this.commentsView && this.commentsView.scroller) {
|
||||||
this.commentsView.scroller.update({minScrollbarLength: 40, alwaysVisibleY: true});
|
this.commentsView.scroller.update({minScrollbarLength: this.commentsView.minScrollbarLength, alwaysVisibleY: true});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -61,8 +61,8 @@ define([
|
||||||
'</div>',
|
'</div>',
|
||||||
'<div class="separator horizontal"></div>',
|
'<div class="separator horizontal"></div>',
|
||||||
'<div class="footer" style="text-align: center;">',
|
'<div class="footer" style="text-align: center;">',
|
||||||
'<button id="id-btn-merge-editor-apply" class="btn normal dlg-btn primary custom" result="ok">' + this.textSave + '</button>',
|
'<button id="id-btn-merge-editor-apply" class="btn normal dlg-btn primary custom" result="ok" data-hint="1" data-hint-direction="bottom" data-hint-offset="big">' + this.textSave + '</button>',
|
||||||
'<button id="id-btn-merge-editor-cancel" class="btn normal dlg-btn disabled" result="cancel">' + this.textClose + '</button>',
|
'<button id="id-btn-merge-editor-cancel" class="btn normal dlg-btn" result="cancel" data-hint="1" data-hint-direction="bottom" data-hint-offset="big">' + this.textClose + '</button>',
|
||||||
'</div>'
|
'</div>'
|
||||||
].join('');
|
].join('');
|
||||||
|
|
||||||
|
|
|
||||||
164
apps/common/main/lib/view/ExternalOleEditor.js
Normal file
|
|
@ -0,0 +1,164 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2022
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha
|
||||||
|
* street, Riga, Latvia, EU, LV-1050.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* ExternalOleEditor.js
|
||||||
|
*
|
||||||
|
* Created by Julia Radzhabova on 3/10/22
|
||||||
|
* Copyright (c) 2022 Ascensio System SIA. All rights reserved.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
define([
|
||||||
|
'common/main/lib/component/Window'
|
||||||
|
], function () { 'use strict';
|
||||||
|
|
||||||
|
Common.Views.ExternalOleEditor = Common.UI.Window.extend(_.extend({
|
||||||
|
initialize : function(options) {
|
||||||
|
var _options = {};
|
||||||
|
var _inner_height = Common.Utils.innerHeight() - Common.Utils.InternalSettings.get('window-inactive-area-top');
|
||||||
|
_.extend(_options, {
|
||||||
|
title: this.textTitle,
|
||||||
|
width: 910,
|
||||||
|
height: (_inner_height - 700)<0 ? _inner_height : 700,
|
||||||
|
cls: 'advanced-settings-dlg',
|
||||||
|
header: true,
|
||||||
|
toolclose: 'hide',
|
||||||
|
toolcallback: _.bind(this.onToolClose, this)
|
||||||
|
}, options);
|
||||||
|
|
||||||
|
this.template = [
|
||||||
|
'<div id="id-ole-editor-container" class="box" style="height:' + (_options.height-85) + 'px;">',
|
||||||
|
'<div id="id-ole-editor-placeholder" style="width: 100%;height: 100%;"></div>',
|
||||||
|
'</div>',
|
||||||
|
'<div class="separator horizontal"></div>',
|
||||||
|
'<div class="footer" style="text-align: center;">',
|
||||||
|
'<button id="id-btn-ole-editor-apply" class="btn normal dlg-btn primary custom" result="ok" data-hint="1" data-hint-direction="bottom" data-hint-offset="big">' + this.textSave + '</button>',
|
||||||
|
'<button id="id-btn-ole-editor-cancel" class="btn normal dlg-btn" result="cancel" data-hint="1" data-hint-direction="bottom" data-hint-offset="big">' + this.textClose + '</button>',
|
||||||
|
'</div>'
|
||||||
|
].join('');
|
||||||
|
|
||||||
|
_options.tpl = _.template(this.template)(_options);
|
||||||
|
|
||||||
|
this.handler = _options.handler;
|
||||||
|
this._oleData = null;
|
||||||
|
this._isNewOle = true;
|
||||||
|
Common.UI.Window.prototype.initialize.call(this, _options);
|
||||||
|
},
|
||||||
|
|
||||||
|
render: function() {
|
||||||
|
Common.UI.Window.prototype.render.call(this);
|
||||||
|
|
||||||
|
this.btnSave = new Common.UI.Button({
|
||||||
|
el: $('#id-btn-ole-editor-apply'),
|
||||||
|
disabled: true
|
||||||
|
});
|
||||||
|
this.btnCancel = new Common.UI.Button({
|
||||||
|
el: $('#id-btn-ole-editor-cancel')
|
||||||
|
});
|
||||||
|
|
||||||
|
this.$window.find('.dlg-btn').on('click', _.bind(this.onDlgBtnClick, this));
|
||||||
|
},
|
||||||
|
|
||||||
|
show: function() {
|
||||||
|
this.setPlaceholder();
|
||||||
|
Common.UI.Window.prototype.show.apply(this, arguments);
|
||||||
|
},
|
||||||
|
|
||||||
|
setOleData: function(data) {
|
||||||
|
this._oleData = data;
|
||||||
|
if (this._isExternalDocReady)
|
||||||
|
this.fireEvent('setoledata', this);
|
||||||
|
},
|
||||||
|
|
||||||
|
setEditMode: function(mode) {
|
||||||
|
this._isNewOle = !mode;
|
||||||
|
},
|
||||||
|
|
||||||
|
isEditMode: function() {
|
||||||
|
return !this._isNewOle;
|
||||||
|
},
|
||||||
|
|
||||||
|
setControlsDisabled: function(disable) {
|
||||||
|
this.btnSave.setDisabled(disable);
|
||||||
|
this.btnCancel.setDisabled(disable);
|
||||||
|
(disable) ? this.$window.find('.tool.close').addClass('disabled') : this.$window.find('.tool.close').removeClass('disabled');
|
||||||
|
},
|
||||||
|
|
||||||
|
onDlgBtnClick: function(event) {
|
||||||
|
if ( this.handler ) {
|
||||||
|
this.handler.call(this, event.currentTarget.attributes['result'].value);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.hide();
|
||||||
|
},
|
||||||
|
|
||||||
|
onToolClose: function() {
|
||||||
|
if ( this.handler ) {
|
||||||
|
this.handler.call(this, 'cancel');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.hide();
|
||||||
|
},
|
||||||
|
|
||||||
|
setHeight: function(height) {
|
||||||
|
if (height >= 0) {
|
||||||
|
var min = parseInt(this.$window.css('min-height'));
|
||||||
|
height < min && (height = min);
|
||||||
|
this.$window.height(height);
|
||||||
|
|
||||||
|
var header_height = (this.initConfig.header) ? parseInt(this.$window.find('> .header').css('height')) : 0;
|
||||||
|
|
||||||
|
this.$window.find('> .body').css('height', height-header_height);
|
||||||
|
this.$window.find('> .body > .box').css('height', height-85);
|
||||||
|
|
||||||
|
var top = (Common.Utils.innerHeight() - Common.Utils.InternalSettings.get('window-inactive-area-top') - parseInt(height)) / 2;
|
||||||
|
var left = (Common.Utils.innerWidth() - parseInt(this.initConfig.width)) / 2;
|
||||||
|
|
||||||
|
this.$window.css('left',left);
|
||||||
|
this.$window.css('top', Common.Utils.InternalSettings.get('window-inactive-area-top') + top);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
setPlaceholder: function(placeholder) {
|
||||||
|
this._placeholder = placeholder;
|
||||||
|
},
|
||||||
|
|
||||||
|
getPlaceholder: function() {
|
||||||
|
return this._placeholder;
|
||||||
|
},
|
||||||
|
|
||||||
|
textSave: 'Save & Exit',
|
||||||
|
textClose: 'Close',
|
||||||
|
textTitle: 'Spreadsheet Editor'
|
||||||
|
}, Common.Views.ExternalOleEditor || {}));
|
||||||
|
});
|
||||||
|
|
@ -52,7 +52,7 @@ define([
|
||||||
|
|
||||||
Common.Views.Header = Backbone.View.extend(_.extend(function(){
|
Common.Views.Header = Backbone.View.extend(_.extend(function(){
|
||||||
var storeUsers, appConfig;
|
var storeUsers, appConfig;
|
||||||
var $userList, $panelUsers, $btnUsers;
|
var $userList, $panelUsers, $btnUsers, $btnUserName, $labelDocName;
|
||||||
var _readonlyRights = false;
|
var _readonlyRights = false;
|
||||||
|
|
||||||
var templateUserItem =
|
var templateUserItem =
|
||||||
|
|
@ -74,7 +74,8 @@ define([
|
||||||
var templateRightBox = '<section>' +
|
var templateRightBox = '<section>' +
|
||||||
'<section id="box-doc-name">' +
|
'<section id="box-doc-name">' +
|
||||||
// '<input type="text" id="rib-doc-name" spellcheck="false" data-can-copy="false" style="pointer-events: none;" disabled="disabled">' +
|
// '<input type="text" id="rib-doc-name" spellcheck="false" data-can-copy="false" style="pointer-events: none;" disabled="disabled">' +
|
||||||
'<label id="rib-doc-name" />' +
|
//'<label id="rib-doc-name" />' +
|
||||||
|
'<input id="rib-doc-name" autofill="off" autocomplete="off"/></input>' +
|
||||||
'</section>' +
|
'</section>' +
|
||||||
'<section style="display: inherit;">' +
|
'<section style="display: inherit;">' +
|
||||||
'<div class="hedset">' +
|
'<div class="hedset">' +
|
||||||
|
|
@ -84,31 +85,36 @@ define([
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'<div class="hedset" data-layout-name="header-users">' +
|
'<div class="hedset" data-layout-name="header-users">' +
|
||||||
// '<span class="btn-slot text" id="slot-btn-users"></span>' +
|
// '<span class="btn-slot text" id="slot-btn-users"></span>' +
|
||||||
'<section id="tlb-box-users" class="box-cousers dropdown"">' +
|
'<section id="tlb-box-users" class="box-cousers dropdown">' +
|
||||||
'<div class="btn-users" data-hint="0" data-hint-direction="bottom" data-hint-offset="big">' +
|
'<div class="btn-users dropdown-toggle" data-toggle="dropdown" data-hint="0" data-hint-direction="bottom" data-hint-offset="big">' +
|
||||||
'<i class="icon toolbar__icon icon--inverse btn-users"></i>' +
|
'<div class="inner-box-icon">' +
|
||||||
'<label class="caption">+</label>' +
|
'<svg class=""><use xlink:href="#svg-icon-users"></use></svg>' +
|
||||||
|
'</div>' +
|
||||||
|
'<label class="caption"></label>' +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'<div class="cousers-menu dropdown-menu">' +
|
'<div class="cousers-menu dropdown-menu">' +
|
||||||
'<label id="tlb-users-menu-descr"><%= tipUsers %></label>' +
|
'<label id="tlb-users-menu-descr"><%= tipUsers %></label>' +
|
||||||
'<div class="cousers-list"></div>' +
|
'<div class="cousers-list"></div>' +
|
||||||
'<label id="tlb-change-rights" class="link"><%= txtAccessRights %></label>' +
|
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'</section>'+
|
'</section>'+
|
||||||
'</div>' +
|
'</div>' +
|
||||||
|
'<div class="hedset">' +
|
||||||
|
'<div class="btn-slot" id="slot-btn-share"></div>' +
|
||||||
|
'</div>' +
|
||||||
'<div class="hedset">' +
|
'<div class="hedset">' +
|
||||||
'<div class="btn-slot" id="slot-btn-mode"></div>' +
|
'<div class="btn-slot" id="slot-btn-mode"></div>' +
|
||||||
'<div class="btn-slot" id="slot-btn-back"></div>' +
|
'<div class="btn-slot" id="slot-btn-back"></div>' +
|
||||||
'<div class="btn-slot" id="slot-btn-favorite"></div>' +
|
'<div class="btn-slot" id="slot-btn-favorite"></div>' +
|
||||||
'<div class="btn-slot" id="slot-btn-options"></div>' +
|
'<div class="btn-slot" id="slot-btn-search"></div>' +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'<div class="hedset">' +
|
'<div class="hedset">' +
|
||||||
'<div class="btn-slot" id="slot-btn-user-name"></div>' +
|
// '<div class="btn-slot slot-btn-user-name"></div>' +
|
||||||
'<div class="btn-slot">' +
|
'<button type="button" class="btn btn-header slot-btn-user-name hidden">' +
|
||||||
'<div class="btn-current-user btn-header hidden">' +
|
'<div class="color-user-name"></div>' +
|
||||||
'<i class="icon toolbar__icon icon--inverse btn-user"></i>' +
|
'</button>' +
|
||||||
|
'<div class="btn-current-user hidden">' +
|
||||||
|
'<div class="color-user-name"></div>' +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'</div>'
|
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'</section>' +
|
'</section>' +
|
||||||
'</section>';
|
'</section>';
|
||||||
|
|
@ -126,15 +132,24 @@ define([
|
||||||
'<div class="btn-slot" id="slot-btn-dt-redo"></div>' +
|
'<div class="btn-slot" id="slot-btn-dt-redo"></div>' +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'<div class="lr-separator" id="id-box-doc-name">' +
|
'<div class="lr-separator" id="id-box-doc-name">' +
|
||||||
'<label id="title-doc-name" />' +
|
// '<label id="title-doc-name" /></label>' +
|
||||||
|
'<input id="title-doc-name" autofill="off" autocomplete="off"/></input>' +
|
||||||
|
'</div>' +
|
||||||
|
'<div class="hedset">' +
|
||||||
|
// '<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">' +
|
||||||
|
'<div class="color-user-name"></div>' +
|
||||||
|
'</div>' +
|
||||||
'</div>' +
|
'</div>' +
|
||||||
'<label id="title-user-name"></label>' +
|
|
||||||
'</section>';
|
'</section>';
|
||||||
|
|
||||||
function onResetUsers(collection, opts) {
|
function onResetUsers(collection, opts) {
|
||||||
var usercount = collection.getVisibleEditingCount();
|
var usercount = collection.getVisibleEditingCount();
|
||||||
if ( $userList ) {
|
if ( $userList ) {
|
||||||
if ( usercount > 1 || usercount > 0 && appConfig && !appConfig.isEdit && !appConfig.isRestrictedEdit) {
|
if (usercount > 1 && appConfig && (appConfig.isEdit || appConfig.isRestrictedEdit)) {
|
||||||
$userList.html(templateUserList({
|
$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(),
|
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),
|
usertpl: _.template(templateUserItem),
|
||||||
|
|
@ -165,46 +180,23 @@ define([
|
||||||
function applyUsers(count, originalCount) {
|
function applyUsers(count, originalCount) {
|
||||||
if (!$btnUsers) return;
|
if (!$btnUsers) return;
|
||||||
|
|
||||||
var has_edit_users = count > 1 || count > 0 && appConfig && !appConfig.isEdit && !appConfig.isRestrictedEdit; // has other user(s) who edit document
|
var has_edit_users = count > 1 && appConfig && (appConfig.isEdit || appConfig.isRestrictedEdit); // has other user(s) who edit document
|
||||||
if ( has_edit_users ) {
|
if ( has_edit_users ) {
|
||||||
$btnUsers
|
|
||||||
.attr('data-toggle', 'dropdown')
|
|
||||||
.addClass('dropdown-toggle')
|
|
||||||
.menu = true;
|
|
||||||
|
|
||||||
$panelUsers['show']();
|
$panelUsers['show']();
|
||||||
|
$btnUsers.find('.caption').html(originalCount);
|
||||||
} else {
|
} else {
|
||||||
$btnUsers
|
$panelUsers['hide']();
|
||||||
.removeAttr('data-toggle')
|
|
||||||
.removeClass('dropdown-toggle')
|
|
||||||
.menu = false;
|
|
||||||
|
|
||||||
$panelUsers[(!_readonlyRights && appConfig && (appConfig.sharingSettingsUrl && appConfig.sharingSettingsUrl.length || appConfig.canRequestSharingSettings)) ? 'show' : 'hide']();
|
|
||||||
}
|
|
||||||
|
|
||||||
$btnUsers.find('.caption')
|
|
||||||
.css({'font-size': ((has_edit_users) ? '12px' : '14px'),
|
|
||||||
'margin-top': ((has_edit_users) ? '0' : '-1px')})
|
|
||||||
.html((has_edit_users) ? originalCount : '+');
|
|
||||||
|
|
||||||
var usertip = $btnUsers.data('bs.tooltip');
|
|
||||||
if ( usertip ) {
|
|
||||||
usertip.options.title = (has_edit_users) ? usertip.options.titleExt : usertip.options.titleNorm;
|
|
||||||
usertip.setContent();
|
|
||||||
}
|
}
|
||||||
|
updateDocNamePosition(appConfig);
|
||||||
}
|
}
|
||||||
|
|
||||||
function onLostEditRights() {
|
function onLostEditRights() {
|
||||||
_readonlyRights = true;
|
_readonlyRights = true;
|
||||||
$panelUsers && $panelUsers.find('#tlb-change-rights').hide();
|
this.btnShare && this.btnShare.setVisible(false);
|
||||||
$btnUsers && !$btnUsers.menu && $panelUsers.hide();
|
updateDocNamePosition(appConfig);
|
||||||
}
|
}
|
||||||
|
|
||||||
function onUsersClick(e) {
|
function onUsersClick(e) {
|
||||||
if ( !$btnUsers.menu ) {
|
|
||||||
$panelUsers.removeClass('open');
|
|
||||||
Common.NotificationCenter.trigger('collaboration:sharing');
|
|
||||||
} else {
|
|
||||||
var usertip = $btnUsers.data('bs.tooltip');
|
var usertip = $btnUsers.data('bs.tooltip');
|
||||||
if ( usertip ) {
|
if ( usertip ) {
|
||||||
if ( usertip.dontShow===undefined)
|
if ( usertip.dontShow===undefined)
|
||||||
|
|
@ -213,26 +205,59 @@ define([
|
||||||
usertip.hide();
|
usertip.hide();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function updateDocNamePosition(config) {
|
||||||
|
if ( $labelDocName && config) {
|
||||||
|
var $parent = $labelDocName.parent();
|
||||||
|
if (!config.isEdit) {
|
||||||
|
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
|
||||||
|
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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function onAppShowed(config) {
|
function onAppShowed(config) {
|
||||||
if ( this.labelDocName ) {
|
// config.isCrypted =true; //delete fore merge!
|
||||||
|
if ( $labelDocName ) {
|
||||||
if ( config.isCrypted ) {
|
if ( config.isCrypted ) {
|
||||||
this.labelDocName.before(
|
$labelDocName.before(
|
||||||
'<div class="inner-box-icon crypted">' +
|
'<div class="inner-box-icon crypted hidden">' +
|
||||||
'<svg class="icon"><use xlink:href="#svg-icon-crypted"></use></svg>' +
|
'<svg class="icon"><use xlink:href="#svg-icon-crypted"></use></svg>' +
|
||||||
'</div>');
|
'</div>');
|
||||||
|
this.imgCrypted = $labelDocName.parent().find('.crypted');
|
||||||
|
this._showImgCrypted = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!config.isEdit || !config.customization || !config.customization.compactHeader) {
|
updateDocNamePosition(config);
|
||||||
var $parent = this.labelDocName.parent();
|
|
||||||
var _left_width = $parent.position().left,
|
|
||||||
_right_width = $parent.next().outerWidth();
|
|
||||||
|
|
||||||
if ( _left_width < _right_width )
|
|
||||||
this.labelDocName.parent().css('padding-left', _right_width - _left_width);
|
|
||||||
else this.labelDocName.parent().css('padding-right', _left_width - _right_width);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -252,6 +277,15 @@ define([
|
||||||
Common.NotificationCenter.trigger('markfavorite', !me.options.favorite);
|
Common.NotificationCenter.trigger('markfavorite', !me.options.favorite);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
if ( me.logo )
|
if ( me.logo )
|
||||||
me.logo.children(0).on('click', function (e) {
|
me.logo.children(0).on('click', function (e) {
|
||||||
var _url = !!me.branding && !!me.branding.logo && (me.branding.logo.url!==undefined) ?
|
var _url = !!me.branding && !!me.branding.logo && (me.branding.logo.url!==undefined) ?
|
||||||
|
|
@ -274,33 +308,17 @@ define([
|
||||||
|
|
||||||
var editingUsers = storeUsers.getVisibleEditingCount();
|
var editingUsers = storeUsers.getVisibleEditingCount();
|
||||||
$btnUsers.tooltip({
|
$btnUsers.tooltip({
|
||||||
title: (editingUsers > 1 || editingUsers>0 && !appConfig.isEdit && !appConfig.isRestrictedEdit) ? me.tipViewUsers : me.tipAccessRights,
|
title: me.tipUsers,
|
||||||
titleNorm: me.tipAccessRights,
|
|
||||||
titleExt: me.tipViewUsers,
|
|
||||||
placement: 'bottom',
|
placement: 'bottom',
|
||||||
html: true
|
html: true
|
||||||
});
|
});
|
||||||
|
|
||||||
$btnUsers.on('click', onUsersClick.bind(me));
|
$btnUsers.on('click', onUsersClick.bind(me));
|
||||||
|
$panelUsers[(editingUsers > 1 && appConfig && (appConfig.isEdit || appConfig.isRestrictedEdit)) ? 'show' : 'hide']();
|
||||||
var $labelChangeRights = $panelUsers.find('#tlb-change-rights');
|
updateDocNamePosition(appConfig);
|
||||||
$labelChangeRights.on('click', function(e) {
|
|
||||||
$panelUsers.removeClass('open');
|
|
||||||
Common.NotificationCenter.trigger('collaboration:sharing');
|
|
||||||
});
|
|
||||||
|
|
||||||
$labelChangeRights[(!mode.isOffline && (mode.sharingSettingsUrl && mode.sharingSettingsUrl.length || mode.canRequestSharingSettings))?'show':'hide']();
|
|
||||||
$panelUsers[(editingUsers > 1 || editingUsers > 0 && !appConfig.isEdit && !appConfig.isRestrictedEdit || !mode.isOffline && (mode.sharingSettingsUrl && mode.sharingSettingsUrl.length || mode.canRequestSharingSettings)) ? 'show' : 'hide']();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (appConfig.user.guest && appConfig.canRenameAnonymous) {
|
if (appConfig.user.guest && appConfig.canRenameAnonymous) {
|
||||||
if (me.labelUserName) {
|
if (me.btnUserName) {
|
||||||
me.labelUserName.addClass('clickable');
|
|
||||||
me.labelUserName.on('click', function (e) {
|
|
||||||
Common.NotificationCenter.trigger('user:rename');
|
|
||||||
});
|
|
||||||
} else if (me.btnUserName) {
|
|
||||||
me.btnUserName.on('click', function (e) {
|
me.btnUserName.on('click', function (e) {
|
||||||
Common.NotificationCenter.trigger('user:rename');
|
Common.NotificationCenter.trigger('user:rename');
|
||||||
});
|
});
|
||||||
|
|
@ -351,47 +369,69 @@ define([
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( me.btnOptions )
|
if (me.btnSearch)
|
||||||
me.btnOptions.updateHint(me.tipViewSettings);
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
|
function onFocusDocName(e){
|
||||||
|
var me = this;
|
||||||
|
me.imgCrypted && me.imgCrypted.toggleClass('hidden', true);
|
||||||
|
me.isSaveDocName =false;
|
||||||
|
if(me.withoutExt) return;
|
||||||
|
var name = me.cutDocName($labelDocName.val());
|
||||||
|
me.withoutExt = true;
|
||||||
|
_.delay(function(){
|
||||||
|
me.setDocTitle(name);
|
||||||
|
$labelDocName.select();
|
||||||
|
},100);
|
||||||
}
|
}
|
||||||
|
|
||||||
function onDocNameKeyDown(e) {
|
function onDocNameKeyDown(e) {
|
||||||
var me = this;
|
var me = this;
|
||||||
|
|
||||||
var name = me.labelDocName.val();
|
var name = $labelDocName.val();
|
||||||
if ( e.keyCode == Common.UI.Keys.RETURN ) {
|
if ( e.keyCode == Common.UI.Keys.RETURN ) {
|
||||||
name = name.trim();
|
name = name.trim();
|
||||||
if ( !_.isEmpty(name) && me.documentCaption !== name ) {
|
if ( !_.isEmpty(name) && me.cutDocName(me.documentCaption) !== name ) {
|
||||||
|
me.isSaveDocName =true;
|
||||||
if ( /[\t*\+:\"<>?|\\\\/]/gim.test(name) ) {
|
if ( /[\t*\+:\"<>?|\\\\/]/gim.test(name) ) {
|
||||||
_.defer(function() {
|
_.defer(function() {
|
||||||
Common.UI.error({
|
Common.UI.error({
|
||||||
msg: (new Common.Views.RenameDialog).txtInvalidName + "*+:\"<>?|\/"
|
msg: (new Common.Views.RenameDialog).txtInvalidName + "*+:\"<>?|\/"
|
||||||
, callback: function() {
|
, callback: function() {
|
||||||
_.delay(function() {
|
_.delay(function() {
|
||||||
me.labelDocName.focus();
|
$labelDocName.focus();
|
||||||
|
me.isSaveDocName =true;
|
||||||
}, 50);
|
}, 50);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
me.labelDocName.blur();
|
|
||||||
})
|
})
|
||||||
} else {
|
} else
|
||||||
Common.Gateway.requestRename(name);
|
if(me.withoutExt) {
|
||||||
|
name = me.cutDocName(name);
|
||||||
|
me.options.wopi ? me.api.asc_wopi_renameFile(name) : Common.Gateway.requestRename(name);
|
||||||
|
name += me.fileExtention;
|
||||||
|
me.withoutExt = false;
|
||||||
|
me.setDocTitle(name);
|
||||||
Common.NotificationCenter.trigger('edit:complete', me);
|
Common.NotificationCenter.trigger('edit:complete', me);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
Common.NotificationCenter.trigger('edit:complete', me);
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
if ( e.keyCode == Common.UI.Keys.ESC ) {
|
if ( e.keyCode == Common.UI.Keys.ESC ) {
|
||||||
me.labelDocName.val(me.documentCaption);
|
|
||||||
Common.NotificationCenter.trigger('edit:complete', this);
|
Common.NotificationCenter.trigger('edit:complete', this);
|
||||||
} else {
|
} else {
|
||||||
me.labelDocName.attr('size', name.length > 10 ? name.length : 10);
|
_.delay(function(){
|
||||||
|
me.setDocTitle();
|
||||||
|
},10);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function onContentThemeChangedToDark(isdark) {
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
options: {
|
options: {
|
||||||
branding: {},
|
branding: {},
|
||||||
|
|
@ -421,7 +461,6 @@ define([
|
||||||
id: 'btn-goback',
|
id: 'btn-goback',
|
||||||
cls: 'btn-header',
|
cls: 'btn-header',
|
||||||
iconCls: 'toolbar__icon icon--inverse btn-goback',
|
iconCls: 'toolbar__icon icon--inverse btn-goback',
|
||||||
split: true,
|
|
||||||
dataHint: '0',
|
dataHint: '0',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'big'
|
dataHintOffset: 'big'
|
||||||
|
|
@ -434,17 +473,15 @@ define([
|
||||||
reset : onResetUsers
|
reset : onResetUsers
|
||||||
});
|
});
|
||||||
|
|
||||||
me.btnOptions = new Common.UI.Button({
|
me.btnSearch = new Common.UI.Button({
|
||||||
cls: 'btn-header no-caret',
|
cls: 'btn-header no-caret',
|
||||||
iconCls: 'toolbar__icon icon--inverse btn-ic-options',
|
iconCls: 'toolbar__icon icon--inverse btn-menu-search',
|
||||||
menu: true,
|
enableToggle: true,
|
||||||
dataHint: '0',
|
dataHint: '0',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'big'
|
dataHintOffset: 'big'
|
||||||
});
|
});
|
||||||
|
|
||||||
me.mnuZoom = {options: {value: 100}};
|
|
||||||
|
|
||||||
me.btnFavorite = new Common.UI.Button({
|
me.btnFavorite = new Common.UI.Button({
|
||||||
id: 'btn-favorite',
|
id: 'btn-favorite',
|
||||||
cls: 'btn-header',
|
cls: 'btn-header',
|
||||||
|
|
@ -456,10 +493,10 @@ define([
|
||||||
|
|
||||||
Common.NotificationCenter.on({
|
Common.NotificationCenter.on({
|
||||||
'app:ready': function(mode) {Common.Utils.asyncCall(onAppReady, me, mode);},
|
'app:ready': function(mode) {Common.Utils.asyncCall(onAppReady, me, mode);},
|
||||||
'app:face': function(mode) {Common.Utils.asyncCall(onAppShowed, me, mode);}
|
'app:face': function(mode) {Common.Utils.asyncCall(onAppShowed, me, mode);},
|
||||||
|
'tab:visible': function() {Common.Utils.asyncCall(updateDocNamePosition, me, appConfig);},
|
||||||
|
'collaboration:sharingdeny': function(mode) {Common.Utils.asyncCall(onLostEditRights, me, mode);}
|
||||||
});
|
});
|
||||||
Common.NotificationCenter.on('collaboration:sharingdeny', onLostEditRights);
|
|
||||||
Common.NotificationCenter.on('contenttheme:dark', onContentThemeChangedToDark.bind(this));
|
|
||||||
Common.NotificationCenter.on('uitheme:changed', this.changeLogo.bind(this));
|
Common.NotificationCenter.on('uitheme:changed', this.changeLogo.bind(this));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -479,7 +516,7 @@ define([
|
||||||
disabled: disabled === true,
|
disabled: disabled === true,
|
||||||
dataHint:'0',
|
dataHint:'0',
|
||||||
dataHintDirection: hintDirection ? hintDirection : (config.isDesktopApp ? 'right' : 'left'),
|
dataHintDirection: hintDirection ? hintDirection : (config.isDesktopApp ? 'right' : 'left'),
|
||||||
dataHintOffset: hintOffset ? hintOffset : (config.isDesktopApp ? '10, -10' : '10, 10'),
|
dataHintOffset: hintOffset ? hintOffset : (config.isDesktopApp ? '10, -18' : '10, 10'),
|
||||||
dataHintTitle: hintTitle
|
dataHintTitle: hintTitle
|
||||||
})).render(slot);
|
})).render(slot);
|
||||||
}
|
}
|
||||||
|
|
@ -500,21 +537,19 @@ define([
|
||||||
if ( role == 'right' ) {
|
if ( role == 'right' ) {
|
||||||
var $html = $(_.template(templateRightBox)({
|
var $html = $(_.template(templateRightBox)({
|
||||||
tipUsers: this.labelCoUsersDescr,
|
tipUsers: this.labelCoUsersDescr,
|
||||||
txtAccessRights: this.txtAccessRights
|
textShare: this.textShare
|
||||||
}));
|
}));
|
||||||
|
|
||||||
if ( !me.labelDocName ) {
|
if ( !$labelDocName ) {
|
||||||
me.labelDocName = $html.find('#rib-doc-name');
|
$labelDocName = $html.find('#rib-doc-name');
|
||||||
if ( me.documentCaption ) {
|
if ( me.documentCaption ) {
|
||||||
me.labelDocName.text(me.documentCaption);
|
setTimeout(function() { me.setDocTitle(me.documentCaption); }, 50);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$html.find('#rib-doc-name').hide();
|
$html.find('#rib-doc-name').hide();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !_.isUndefined(this.options.canRename) ) {
|
this.setCanRename(!!this.options.canRename);
|
||||||
this.setCanRename(this.options.canRename);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( this.options.canBack === true ) {
|
if ( this.options.canBack === true ) {
|
||||||
me.btnGoBack.render($html.find('#slot-btn-back'));
|
me.btnGoBack.render($html.find('#slot-btn-back'));
|
||||||
|
|
@ -540,33 +575,72 @@ define([
|
||||||
if ( config.canEdit && config.canRequestEditRights )
|
if ( config.canEdit && config.canRequestEditRights )
|
||||||
this.btnEdit = createTitleButton('toolbar__icon icon--inverse btn-edit', $html.findById('#slot-hbtn-edit'), undefined, 'bottom', 'big');
|
this.btnEdit = createTitleButton('toolbar__icon icon--inverse btn-edit', $html.findById('#slot-hbtn-edit'), undefined, 'bottom', 'big');
|
||||||
}
|
}
|
||||||
me.btnOptions.render($html.find('#slot-btn-options'));
|
me.btnSearch.render($html.find('#slot-btn-search'));
|
||||||
|
|
||||||
if (!config.isEdit || config.customization && !!config.customization.compactHeader) {
|
if (!config.isEdit || config.customization && !!config.customization.compactHeader) {
|
||||||
if (config.user.guest && config.canRenameAnonymous)
|
if (config.user.guest && config.canRenameAnonymous) {
|
||||||
me.btnUserName = createTitleButton('toolbar__icon icon--inverse btn-user', $html.findById('#slot-btn-user-name'), undefined, 'bottom', 'big' );
|
me.btnUserName = new Common.UI.Button({
|
||||||
else {
|
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 = $html.find('.btn-current-user');
|
||||||
me.elUserName.removeClass('hidden');
|
me.elUserName.removeClass('hidden');
|
||||||
}
|
}
|
||||||
|
$btnUserName = $html.find('.color-user-name');
|
||||||
me.setUserName(me.options.userName);
|
me.setUserName(me.options.userName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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');
|
$userList = $html.find('.cousers-list');
|
||||||
$panelUsers = $html.find('.box-cousers');
|
$panelUsers = $html.find('.box-cousers');
|
||||||
$btnUsers = $html.find('.btn-users');
|
$btnUsers = $panelUsers.find('> .btn-users');
|
||||||
|
|
||||||
$panelUsers.hide();
|
$panelUsers.hide();
|
||||||
return $html;
|
return $html;
|
||||||
} else
|
} else
|
||||||
if ( role == 'title' ) {
|
if ( role == 'title' ) {
|
||||||
var $html = $(_.template(templateTitleBox)());
|
var $html = $(_.template(templateTitleBox)());
|
||||||
|
|
||||||
!!me.labelDocName && me.labelDocName.hide().off(); // hide document title if it was created in right box
|
!!$labelDocName && $labelDocName.hide().off(); // hide document title if it was created in right box
|
||||||
me.labelDocName = $html.find('#title-doc-name');
|
$labelDocName = $html.find('#title-doc-name');
|
||||||
me.labelDocName.text( me.documentCaption );
|
setTimeout(function() { me.setDocTitle(me.documentCaption); }, 50);
|
||||||
|
|
||||||
me.labelUserName = $('> #title-user-name', $html);
|
me.options.wopi && $labelDocName.attr('maxlength', me.options.wopi.FileNameMaxLength);
|
||||||
|
|
||||||
|
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');
|
||||||
|
}
|
||||||
|
$btnUserName = $html.find('.color-user-name');
|
||||||
me.setUserName(me.options.userName);
|
me.setUserName(me.options.userName);
|
||||||
|
|
||||||
if ( config.canPrint && config.isEdit ) {
|
if ( config.canPrint && config.isEdit ) {
|
||||||
|
|
@ -577,19 +651,6 @@ define([
|
||||||
me.btnUndo = createTitleButton('toolbar__icon icon--inverse btn-undo', $html.findById('#slot-btn-dt-undo'), true, undefined, undefined, 'Z');
|
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');
|
me.btnRedo = createTitleButton('toolbar__icon icon--inverse btn-redo', $html.findById('#slot-btn-dt-redo'), true, undefined, undefined, 'Y');
|
||||||
|
|
||||||
if ( me.btnSave.$icon.is('svg') ) {
|
|
||||||
me.btnSave.$icon.addClass('icon-save btn-save');
|
|
||||||
var _create_use = function (extid, intid) {
|
|
||||||
var _use = document.createElementNS('http://www.w3.org/2000/svg', 'use');
|
|
||||||
_use.setAttributeNS('http://www.w3.org/1999/xlink', 'xlink:href', extid);
|
|
||||||
_use.setAttribute('id', intid);
|
|
||||||
|
|
||||||
return $(_use);
|
|
||||||
};
|
|
||||||
|
|
||||||
_create_use('#svg-btn-save-coauth', 'coauth').appendTo(me.btnSave.$icon);
|
|
||||||
_create_use('#svg-btn-save-sync', 'sync').appendTo(me.btnSave.$icon);
|
|
||||||
}
|
|
||||||
return $html;
|
return $html;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
@ -630,14 +691,13 @@ define([
|
||||||
!value && (value = '');
|
!value && (value = '');
|
||||||
|
|
||||||
this.documentCaption = value;
|
this.documentCaption = value;
|
||||||
|
var idx = this.documentCaption.lastIndexOf('.');
|
||||||
|
if (idx>0)
|
||||||
|
this.fileExtention = this.documentCaption.substring(idx);
|
||||||
this.isModified && (value += '*');
|
this.isModified && (value += '*');
|
||||||
if ( this.labelDocName ) {
|
if ( $labelDocName ) {
|
||||||
this.labelDocName.text( value );
|
this.setDocTitle( value );
|
||||||
// this.labelDocName.attr('size', value.length);
|
|
||||||
|
|
||||||
this.setCanRename(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -651,7 +711,7 @@ define([
|
||||||
var _name = this.documentCaption;
|
var _name = this.documentCaption;
|
||||||
changed && (_name += '*');
|
changed && (_name += '*');
|
||||||
|
|
||||||
this.labelDocName.text(_name);
|
this.setDocTitle(_name);
|
||||||
},
|
},
|
||||||
|
|
||||||
setCanBack: function (value, text) {
|
setCanBack: function (value, text) {
|
||||||
|
|
@ -659,7 +719,7 @@ define([
|
||||||
this.btnGoBack[value ? 'show' : 'hide']();
|
this.btnGoBack[value ? 'show' : 'hide']();
|
||||||
if (value)
|
if (value)
|
||||||
this.btnGoBack.updateHint((text && typeof text == 'string') ? text : this.textBack);
|
this.btnGoBack.updateHint((text && typeof text == 'string') ? text : this.textBack);
|
||||||
|
updateDocNamePosition(appConfig);
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -672,7 +732,7 @@ define([
|
||||||
this.btnFavorite[value!==undefined && value!==null ? 'show' : 'hide']();
|
this.btnFavorite[value!==undefined && value!==null ? 'show' : 'hide']();
|
||||||
this.btnFavorite.changeIcon(!!value ? {next: 'btn-in-favorite'} : {curr: 'btn-in-favorite'});
|
this.btnFavorite.changeIcon(!!value ? {next: 'btn-in-favorite'} : {curr: 'btn-in-favorite'});
|
||||||
this.btnFavorite.updateHint(!value ? this.textAddFavorite : this.textRemoveFavorite);
|
this.btnFavorite.updateHint(!value ? this.textAddFavorite : this.textRemoveFavorite);
|
||||||
|
updateDocNamePosition(appConfig);
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -681,12 +741,10 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
setCanRename: function (rename) {
|
setCanRename: function (rename) {
|
||||||
rename = false;
|
|
||||||
|
|
||||||
var me = this;
|
var me = this;
|
||||||
me.options.canRename = rename;
|
me.options.canRename = rename;
|
||||||
if ( me.labelDocName ) {
|
if ( $labelDocName ) {
|
||||||
var label = me.labelDocName;
|
var label = $labelDocName;
|
||||||
if ( rename ) {
|
if ( rename ) {
|
||||||
label.removeAttr('disabled').tooltip({
|
label.removeAttr('disabled').tooltip({
|
||||||
title: me.txtRename,
|
title: me.txtRename,
|
||||||
|
|
@ -695,8 +753,20 @@ define([
|
||||||
|
|
||||||
label.on({
|
label.on({
|
||||||
'keydown': onDocNameKeyDown.bind(this),
|
'keydown': onDocNameKeyDown.bind(this),
|
||||||
|
'focus': onFocusDocName.bind(this),
|
||||||
'blur': function (e) {
|
'blur': function (e) {
|
||||||
|
me.imgCrypted && me.imgCrypted.toggleClass('hidden', false);
|
||||||
|
Common.Utils.isGecko && (label[0].selectionStart = label[0].selectionEnd = 0);
|
||||||
|
if(!me.isSaveDocName) {
|
||||||
|
me.withoutExt = false;
|
||||||
|
me.setDocTitle(me.documentCaption);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
'paste': function (e) {
|
||||||
|
setTimeout(function() {
|
||||||
|
var name = me.cutDocName($labelDocName.val());
|
||||||
|
me.setDocTitle(name);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
@ -713,12 +783,37 @@ define([
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
cutDocName: function(name) {
|
||||||
|
if(name.length <= this.fileExtention.length) return name;
|
||||||
|
var idx =name.length - this.fileExtention.length;
|
||||||
|
|
||||||
|
return (name.substring(idx) == this.fileExtention) ? name.substring(0, idx) : name ;
|
||||||
|
},
|
||||||
|
|
||||||
|
setDocTitle: function(name){
|
||||||
|
var width = this.getTextWidth(name || $labelDocName.val());
|
||||||
|
(width>=0) && $labelDocName.width(width);
|
||||||
|
name && (width>=0) && $labelDocName.val(name);
|
||||||
|
if (this._showImgCrypted && width>=0) {
|
||||||
|
this.imgCrypted.toggleClass('hidden', false);
|
||||||
|
this._showImgCrypted = false;
|
||||||
|
}
|
||||||
|
(width>=0) && onResize();
|
||||||
|
},
|
||||||
|
|
||||||
|
getTextWidth: function(text) {
|
||||||
|
if (!this._testCanvas ) {
|
||||||
|
var font = ($labelDocName.css('font-size') + ' ' + $labelDocName.css('font-family')).trim();
|
||||||
|
if (font) {
|
||||||
|
var canvas = document.createElement("canvas");
|
||||||
|
this._testCanvas = canvas.getContext('2d');
|
||||||
|
this._testCanvas.font = font;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this._testCanvas ? this._testCanvas.measureText(text).width : -1;
|
||||||
|
},
|
||||||
|
|
||||||
setUserName: function(name) {
|
setUserName: function(name) {
|
||||||
if ( !!this.labelUserName ) {
|
|
||||||
if ( !!name ) {
|
|
||||||
this.labelUserName.text(name).show();
|
|
||||||
} else this.labelUserName.hide();
|
|
||||||
} else {
|
|
||||||
this.options.userName = name;
|
this.options.userName = name;
|
||||||
if ( this.btnUserName ) {
|
if ( this.btnUserName ) {
|
||||||
this.btnUserName.updateHint(name);
|
this.btnUserName.updateHint(name);
|
||||||
|
|
@ -729,8 +824,7 @@ define([
|
||||||
html: true
|
html: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
$btnUserName && $btnUserName.text(this.getInitials(name));
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
@ -739,24 +833,23 @@ define([
|
||||||
return this.btnSave;
|
return this.btnSave;
|
||||||
else if (type == 'users')
|
else if (type == 'users')
|
||||||
return $panelUsers;
|
return $panelUsers;
|
||||||
|
else if (type == 'share')
|
||||||
|
return this.btnShare;
|
||||||
},
|
},
|
||||||
|
|
||||||
lockHeaderBtns: function (alias, lock) {
|
lockHeaderBtns: function (alias, lock) {
|
||||||
var me = this;
|
var me = this;
|
||||||
if ( alias == 'users' ) {
|
if ( alias == 'users' ) {
|
||||||
if ( lock )
|
|
||||||
$btnUsers.addClass('disabled').attr('disabled', 'disabled'); else
|
|
||||||
$btnUsers.removeClass('disabled').removeAttr('disabled');
|
|
||||||
} else if ( alias == 'rename-user' ) {
|
|
||||||
if (me.labelUserName) {
|
|
||||||
if ( lock ) {
|
if ( lock ) {
|
||||||
me.labelUserName.removeClass('clickable');
|
$btnUsers.addClass('disabled').attr('disabled', 'disabled');
|
||||||
me.labelUserName.addClass('disabled');
|
|
||||||
} else {
|
} else {
|
||||||
me.labelUserName.addClass('clickable');
|
$btnUsers.removeClass('disabled').removeAttr('disabled');
|
||||||
me.labelUserName.removeClass('disabled');
|
|
||||||
}
|
}
|
||||||
} else if (me.btnUserName) {
|
if (me.btnShare) {
|
||||||
|
me.btnShare.setDisabled(lock);
|
||||||
|
}
|
||||||
|
} else if ( alias == 'rename-user' ) {
|
||||||
|
if (me.btnUserName) {
|
||||||
me.btnUserName.setDisabled(lock);
|
me.btnUserName.setDisabled(lock);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -777,20 +870,21 @@ define([
|
||||||
switch ( alias ) {
|
switch ( alias ) {
|
||||||
case 'undo': _lockButton(me.btnUndo); break;
|
case 'undo': _lockButton(me.btnUndo); break;
|
||||||
case 'redo': _lockButton(me.btnRedo); break;
|
case 'redo': _lockButton(me.btnRedo); break;
|
||||||
case 'opts': _lockButton(me.btnOptions); break;
|
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
fakeMenuItem: function() {
|
getInitials: function(name) {
|
||||||
return {
|
var fio = name.split(' ');
|
||||||
conf: {checked: false, disabled: false},
|
var initials = fio[0].substring(0, 1).toUpperCase();
|
||||||
setChecked: function (val) { this.conf.checked = val; },
|
for (var i = fio.length-1; i>0; i--) {
|
||||||
isChecked: function () { return this.conf.checked; },
|
if (fio[i][0]!=='(' && fio[i][0]!==')') {
|
||||||
setDisabled: function (val) { this.conf.disabled = val; },
|
initials += fio[i].substring(0, 1).toUpperCase();
|
||||||
isDisabled: function () { return this.conf.disabled; }
|
break;
|
||||||
};
|
}
|
||||||
|
}
|
||||||
|
return initials;
|
||||||
},
|
},
|
||||||
|
|
||||||
textBack: 'Go to Documents',
|
textBack: 'Go to Documents',
|
||||||
|
|
@ -799,6 +893,7 @@ define([
|
||||||
tipAccessRights: 'Manage document access rights',
|
tipAccessRights: 'Manage document access rights',
|
||||||
labelCoUsersDescr: 'Document is currently being edited by several users.',
|
labelCoUsersDescr: 'Document is currently being edited by several users.',
|
||||||
tipViewUsers: 'View users and manage document access rights',
|
tipViewUsers: 'View users and manage document access rights',
|
||||||
|
tipUsers: 'View users',
|
||||||
tipDownload: 'Download file',
|
tipDownload: 'Download file',
|
||||||
tipPrint: 'Print file',
|
tipPrint: 'Print file',
|
||||||
tipGoEdit: 'Edit current file',
|
tipGoEdit: 'Edit current file',
|
||||||
|
|
@ -813,7 +908,9 @@ define([
|
||||||
tipViewSettings: 'View Settings',
|
tipViewSettings: 'View Settings',
|
||||||
textRemoveFavorite: 'Remove from Favorites',
|
textRemoveFavorite: 'Remove from Favorites',
|
||||||
textAddFavorite: 'Mark as favorite',
|
textAddFavorite: 'Mark as favorite',
|
||||||
textHideNotes: 'Hide Notes'
|
textHideNotes: 'Hide Notes',
|
||||||
|
tipSearch: 'Search',
|
||||||
|
textShare: 'Share'
|
||||||
}
|
}
|
||||||
}(), Common.Views.Header || {}))
|
}(), Common.Views.Header || {}))
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -68,11 +68,14 @@ define([
|
||||||
initialize: function(options) {
|
initialize: function(options) {
|
||||||
_.extend(this, options);
|
_.extend(this, options);
|
||||||
Common.UI.BaseView.prototype.initialize.call(this, arguments);
|
Common.UI.BaseView.prototype.initialize.call(this, arguments);
|
||||||
|
|
||||||
|
var filter = Common.localStorage.getKeysFilter();
|
||||||
|
this.appPrefix = (filter && filter.length) ? filter.split(',')[0] : '';
|
||||||
},
|
},
|
||||||
|
|
||||||
render: function(el) {
|
render: function(el) {
|
||||||
el = el || this.el;
|
el = el || this.el;
|
||||||
$(el).html(this.template({scope: this})).width( (parseInt(Common.localStorage.getItem('de-mainmenu-width')) || MENU_SCALE_PART) - SCALE_MIN);
|
$(el).html(this.template({scope: this})).width( (parseInt(Common.localStorage.getItem(this.appPrefix + 'mainmenu-width')) || MENU_SCALE_PART) - SCALE_MIN);
|
||||||
|
|
||||||
this.viewHistoryList = new Common.UI.DataView({
|
this.viewHistoryList = new Common.UI.DataView({
|
||||||
el: $('#history-list'),
|
el: $('#history-list'),
|
||||||
|
|
@ -110,7 +113,7 @@ define([
|
||||||
for(var i=1; i<revisions.length; i++)
|
for(var i=1; i<revisions.length; i++)
|
||||||
revisions[i].set('isVisible', isExpanded);
|
revisions[i].set('isVisible', isExpanded);
|
||||||
}
|
}
|
||||||
this.scroller.update({minScrollbarLength: 40});
|
this.scroller.update({minScrollbarLength: this.minScrollbarLength});
|
||||||
} else
|
} else
|
||||||
Common.UI.DataView.prototype.onClickItem.call(this, view, record, e);
|
Common.UI.DataView.prototype.onClickItem.call(this, view, record, e);
|
||||||
me.btnExpand.cmpEl.text(me.storeHistory.hasCollapsed() ? me.textShowAll : me.textHideAll);
|
me.btnExpand.cmpEl.text(me.storeHistory.hasCollapsed() ? me.textShowAll : me.textHideAll);
|
||||||
|
|
|
||||||
|
|
@ -48,7 +48,7 @@ define([
|
||||||
Common.Views.InsertTableDialog = Common.UI.Window.extend(_.extend({
|
Common.Views.InsertTableDialog = Common.UI.Window.extend(_.extend({
|
||||||
options: {
|
options: {
|
||||||
width: 230,
|
width: 230,
|
||||||
height: 156,
|
height: 157,
|
||||||
style: 'min-width: 230px;',
|
style: 'min-width: 230px;',
|
||||||
cls: 'modal-dlg',
|
cls: 'modal-dlg',
|
||||||
split: false,
|
split: false,
|
||||||
|
|
|
||||||
|
|
@ -50,11 +50,18 @@ define([
|
||||||
'common/main/lib/view/SymbolTableDialog'
|
'common/main/lib/view/SymbolTableDialog'
|
||||||
], function () { 'use strict';
|
], function () { 'use strict';
|
||||||
|
|
||||||
|
var _BulletTypes = {};
|
||||||
|
_BulletTypes.none = -1;
|
||||||
|
_BulletTypes.symbol = 0;
|
||||||
|
_BulletTypes.image = 2;
|
||||||
|
_BulletTypes.newSymbol = 1;
|
||||||
|
_BulletTypes.newImage = -2;
|
||||||
|
|
||||||
Common.Views.ListSettingsDialog = Common.UI.Window.extend(_.extend({
|
Common.Views.ListSettingsDialog = Common.UI.Window.extend(_.extend({
|
||||||
options: {
|
options: {
|
||||||
type: 0, // 0 - markers, 1 - numbers
|
type: 0, // 0 - markers, 1 - numbers
|
||||||
width: 280,
|
width: 285,
|
||||||
height: 255,
|
height: 261,
|
||||||
style: 'min-width: 240px;',
|
style: 'min-width: 240px;',
|
||||||
cls: 'modal-dlg',
|
cls: 'modal-dlg',
|
||||||
split: false,
|
split: false,
|
||||||
|
|
@ -80,9 +87,18 @@ define([
|
||||||
'<td style="padding-right: 5px;padding-bottom: 8px;min-width: 50px;">',
|
'<td style="padding-right: 5px;padding-bottom: 8px;min-width: 50px;">',
|
||||||
'<label class="text">' + this.txtType + '</label>',
|
'<label class="text">' + this.txtType + '</label>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'<td style="padding-right: 5px;padding-bottom: 8px;width: 100px;">',
|
'<td style="padding-right: 5px;padding-bottom: 8px;width: 105px;">',
|
||||||
'<div id="id-dlg-list-numbering-format" class="input-group-nr" style="width: 100px;"></div>',
|
'<div id="id-dlg-list-numbering-format" class="input-group-nr" style="width: 105px;"></div>',
|
||||||
'<div id="id-dlg-list-bullet-format" class="input-group-nr" style="width: 100px;"></div>',
|
'<div id="id-dlg-list-bullet-format" class="input-group-nr" style="width: 105px;"></div>',
|
||||||
|
'</td>',
|
||||||
|
'<td style="padding-bottom: 8px;"></td>',
|
||||||
|
'</tr>',
|
||||||
|
'<tr class="image">',
|
||||||
|
'<td style="padding-right: 5px;padding-bottom: 8px;min-width: 50px;">',
|
||||||
|
'<label class="text">' + this.txtImport + '</label>',
|
||||||
|
'</td>',
|
||||||
|
'<td style="padding-right: 5px;padding-bottom: 8px;width: 105px;">',
|
||||||
|
'<div id="id-dlg-list-image" style="width: 105px;"></div>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'<td style="padding-bottom: 8px;"></td>',
|
'<td style="padding-bottom: 8px;"></td>',
|
||||||
'</tr>',
|
'</tr>',
|
||||||
|
|
@ -90,7 +106,7 @@ define([
|
||||||
'<td style="padding-right: 5px;padding-bottom: 8px;min-width: 50px;">',
|
'<td style="padding-right: 5px;padding-bottom: 8px;min-width: 50px;">',
|
||||||
'<label class="text">' + this.txtSize + '</label>',
|
'<label class="text">' + this.txtSize + '</label>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'<td style="padding-right: 5px;padding-bottom: 8px;width: 100px;">',
|
'<td style="padding-right: 5px;padding-bottom: 8px;width: 105px;">',
|
||||||
'<div id="id-dlg-list-size"></div>',
|
'<div id="id-dlg-list-size"></div>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'<td style="padding-bottom: 8px;">',
|
'<td style="padding-bottom: 8px;">',
|
||||||
|
|
@ -101,16 +117,16 @@ define([
|
||||||
'<td style="padding-right: 5px;padding-bottom: 8px;min-width: 50px;">',
|
'<td style="padding-right: 5px;padding-bottom: 8px;min-width: 50px;">',
|
||||||
'<label class="text" style="white-space: nowrap;">' + this.txtStart + '</label>',
|
'<label class="text" style="white-space: nowrap;">' + this.txtStart + '</label>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'<td style="padding-right: 5px;padding-bottom: 8px;width: 100px;">',
|
'<td style="padding-right: 5px;padding-bottom: 8px;width: 105px;">',
|
||||||
'<div id="id-dlg-list-start"></div>',
|
'<div id="id-dlg-list-start"></div>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'<td style="padding-bottom: 8px;"></td>',
|
'<td style="padding-bottom: 8px;"></td>',
|
||||||
'</tr>',
|
'</tr>',
|
||||||
'<tr>',
|
'<tr class="color">',
|
||||||
'<td style="padding-right: 5px;padding-bottom: 8px;min-width: 50px;">',
|
'<td style="padding-right: 5px;padding-bottom: 8px;min-width: 50px;">',
|
||||||
'<label class="text">' + this.txtColor + '</label>',
|
'<label class="text">' + this.txtColor + '</label>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'<td style="padding-right: 5px;padding-bottom: 8px;width: 100px;">',
|
'<td style="padding-right: 5px;padding-bottom: 8px;width: 105px;">',
|
||||||
'<div id="id-dlg-list-color"></div>',
|
'<div id="id-dlg-list-color"></div>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'<td style="padding-bottom: 8px;"></td>',
|
'<td style="padding-bottom: 8px;"></td>',
|
||||||
|
|
@ -123,6 +139,8 @@ define([
|
||||||
this.props = options.props;
|
this.props = options.props;
|
||||||
this.options.tpl = _.template(this.template)(this.options);
|
this.options.tpl = _.template(this.template)(this.options);
|
||||||
this.color = '000000';
|
this.color = '000000';
|
||||||
|
this.storage = !!options.storage;
|
||||||
|
this.api = options.api;
|
||||||
|
|
||||||
Common.UI.Window.prototype.initialize.call(this, this.options);
|
Common.UI.Window.prototype.initialize.call(this, this.options);
|
||||||
},
|
},
|
||||||
|
|
@ -179,7 +197,9 @@ define([
|
||||||
[
|
[
|
||||||
'<% _.each(items, function(item) { %>',
|
'<% _.each(items, function(item) { %>',
|
||||||
'<li id="<%= item.id %>" data-value="<%= item.value %>"><a tabindex="-1" type="menuitem">',
|
'<li id="<%= item.id %>" data-value="<%= item.value %>"><a tabindex="-1" type="menuitem">',
|
||||||
'<%= item.displayValue %><% if (item.value === 0) { %><span style="font-family:<%=item.font%>;"><%=item.symbol%></span><% } %>',
|
'<%= item.displayValue %>',
|
||||||
|
'<% if (item.value === 0) { %><span style="font-family:<%=item.font%>;"><%=item.symbol%></span>',
|
||||||
|
'<% } else if (item.value === 2) { %><span id="id-dlg-list-bullet-image-preview" style="width:12px; height: 12px; margin-left: 4px; margin-bottom: 1px;display: inline-block; vertical-align: middle;"></span><% } %>',
|
||||||
'</a></li>',
|
'</a></li>',
|
||||||
'<% }); %>'
|
'<% }); %>'
|
||||||
];
|
];
|
||||||
|
|
@ -195,28 +215,36 @@ define([
|
||||||
this.cmbBulletFormat = new Common.UI.ComboBoxCustom({
|
this.cmbBulletFormat = new Common.UI.ComboBoxCustom({
|
||||||
el : $('#id-dlg-list-bullet-format'),
|
el : $('#id-dlg-list-bullet-format'),
|
||||||
menuStyle : 'min-width: 100%;max-height: 183px;',
|
menuStyle : 'min-width: 100%;max-height: 183px;',
|
||||||
style : "width: 100px;",
|
style : "width: 105px;",
|
||||||
editable : false,
|
editable : false,
|
||||||
takeFocusOnClose: true,
|
takeFocusOnClose: true,
|
||||||
template : _.template(template.join('')),
|
template : _.template(template.join('')),
|
||||||
itemsTemplate: _.template(itemsTemplate.join('')),
|
itemsTemplate: _.template(itemsTemplate.join('')),
|
||||||
data : [
|
data : [
|
||||||
{ displayValue: this.txtNone, value: -1 },
|
{ displayValue: this.txtNone, value: _BulletTypes.none },
|
||||||
{ displayValue: this.txtSymbol + ': ', value: 0, symbol: "•", font: 'Arial' },
|
{ displayValue: this.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: "•", font: 'Arial' },
|
||||||
{ displayValue: this.txtSymbol + ': ', value: 0, symbol: "o", font: 'Courier New' },
|
{ displayValue: this.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: "o", font: 'Courier New' },
|
||||||
{ displayValue: this.txtSymbol + ': ', value: 0, symbol: "§", font: 'Wingdings' },
|
{ displayValue: this.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: "§", font: 'Wingdings' },
|
||||||
{ displayValue: this.txtSymbol + ': ', value: 0, symbol: "v", font: 'Wingdings' },
|
{ displayValue: this.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: "v", font: 'Wingdings' },
|
||||||
{ displayValue: this.txtSymbol + ': ', value: 0, symbol: "Ø", font: 'Wingdings' },
|
{ displayValue: this.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: "Ø", font: 'Wingdings' },
|
||||||
{ displayValue: this.txtSymbol + ': ', value: 0, symbol: "ü", font: 'Wingdings' },
|
{ displayValue: this.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: "ü", font: 'Wingdings' },
|
||||||
{ displayValue: this.txtSymbol + ': ', value: 0, symbol: "w", font: 'Wingdings' },
|
{ displayValue: this.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: "w", font: 'Wingdings' },
|
||||||
{ displayValue: this.txtSymbol + ': ', value: 0, symbol: "–", font: 'Arial' },
|
{ displayValue: this.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: "–", font: 'Arial' },
|
||||||
{ displayValue: this.txtNewBullet, value: 1 }
|
{ displayValue: this.txtNewBullet, value: _BulletTypes.newSymbol },
|
||||||
|
{ displayValue: this.txtNewImage, value: _BulletTypes.newImage }
|
||||||
],
|
],
|
||||||
updateFormControl: function(record) {
|
updateFormControl: function(record) {
|
||||||
var formcontrol = $(this.el).find('.form-control');
|
var formcontrol = $(this.el).find('.form-control');
|
||||||
if (record) {
|
if (record) {
|
||||||
if (record.get('value')==0)
|
if (record.get('value')===_BulletTypes.symbol)
|
||||||
formcontrol[0].innerHTML = record.get('displayValue') + '<span style="font-family:' + (record.get('font') || 'Arial') + '">' + record.get('symbol') + '</span>';
|
formcontrol[0].innerHTML = record.get('displayValue') + '<span style="font-family:' + (record.get('font') || 'Arial') + '">' + record.get('symbol') + '</span>';
|
||||||
|
else if (record.get('value')===_BulletTypes.image) {
|
||||||
|
formcontrol[0].innerHTML = record.get('displayValue') + '<span id="id-dlg-list-bullet-combo-preview" style="width:12px; height: 12px; margin-left: 2px; margin-bottom: 1px;display: inline-block; vertical-align: middle;"></span>';
|
||||||
|
var bullet = new Asc.asc_CBullet();
|
||||||
|
bullet.asc_fillBulletImage(me.imageProps.id);
|
||||||
|
bullet.drawSquareImage('id-dlg-list-bullet-combo-preview');
|
||||||
|
} else if (record.get('value')===_BulletTypes.newImage)
|
||||||
|
formcontrol[0].innerHTML = me.txtImage;
|
||||||
else
|
else
|
||||||
formcontrol[0].innerHTML = record.get('displayValue');
|
formcontrol[0].innerHTML = record.get('displayValue');
|
||||||
} else
|
} else
|
||||||
|
|
@ -227,7 +255,9 @@ define([
|
||||||
this.cmbBulletFormat.selectRecord(rec);
|
this.cmbBulletFormat.selectRecord(rec);
|
||||||
this.bulletProps = {symbol: rec.get('symbol'), font: rec.get('font')};
|
this.bulletProps = {symbol: rec.get('symbol'), font: rec.get('font')};
|
||||||
this.cmbBulletFormat.on('selected', _.bind(function (combo, record) {
|
this.cmbBulletFormat.on('selected', _.bind(function (combo, record) {
|
||||||
if (record.value === 1) {
|
this.imageControls.toggleClass('hidden', !(record.value === _BulletTypes.image || record.value === _BulletTypes.newImage));
|
||||||
|
this.colorControls.toggleClass('hidden', record.value === _BulletTypes.image || record.value === _BulletTypes.newImage);
|
||||||
|
if (record.value === _BulletTypes.newSymbol) {
|
||||||
var me = this,
|
var me = this,
|
||||||
props = me.bulletProps,
|
props = me.bulletProps,
|
||||||
handler = function(dlg, result, settings) {
|
handler = function(dlg, result, settings) {
|
||||||
|
|
@ -242,10 +272,17 @@ define([
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
var store = combo.store;
|
var store = combo.store;
|
||||||
if (!store.findWhere({value: 0, symbol: props.symbol, font: props.font}))
|
if (!store.findWhere({value: _BulletTypes.symbol, symbol: props.symbol, font: props.font})) {
|
||||||
store.add({ displayValue: me.txtSymbol + ': ', value: 0, symbol: props.symbol, font: props.font }, {at: store.length-1});
|
var idx = store.indexOf(store.findWhere({value: _BulletTypes.image}));
|
||||||
|
if (idx<0)
|
||||||
|
idx = store.indexOf(store.findWhere({value: _BulletTypes.newSymbol}));
|
||||||
|
store.add({ displayValue: me.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: props.symbol, font: props.font }, {at: idx});
|
||||||
|
}
|
||||||
|
if (me.imageProps)
|
||||||
|
me.imageProps.redraw = true;
|
||||||
|
|
||||||
combo.setData(store.models);
|
combo.setData(store.models);
|
||||||
combo.selectRecord(combo.store.findWhere({value: 0, symbol: props.symbol, font: props.font}));
|
combo.selectRecord(combo.store.findWhere({value: _BulletTypes.symbol, symbol: props.symbol, font: props.font}));
|
||||||
},
|
},
|
||||||
win = new Common.Views.SymbolTableDialog({
|
win = new Common.Views.SymbolTableDialog({
|
||||||
api: me.options.api,
|
api: me.options.api,
|
||||||
|
|
@ -258,7 +295,11 @@ define([
|
||||||
});
|
});
|
||||||
win.show();
|
win.show();
|
||||||
win.on('symbol:dblclick', handler);
|
win.on('symbol:dblclick', handler);
|
||||||
} else if (record.value == -1) {
|
} else if (record.value == _BulletTypes.newImage) { // new image
|
||||||
|
} else if (record.value == _BulletTypes.image) { // image
|
||||||
|
if (this._changedProps)
|
||||||
|
this._changedProps.asc_fillBulletImage(this.imageProps.id);
|
||||||
|
} else if (record.value == _BulletTypes.none) {
|
||||||
if (this._changedProps)
|
if (this._changedProps)
|
||||||
this._changedProps.asc_putListType(0, record.value);
|
this._changedProps.asc_putListType(0, record.value);
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -271,12 +312,14 @@ define([
|
||||||
this._changedProps.asc_putSymbol(this.bulletProps.symbol);
|
this._changedProps.asc_putSymbol(this.bulletProps.symbol);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
this.btnOk.setDisabled(record.value === _BulletTypes.newImage);
|
||||||
}, this));
|
}, this));
|
||||||
|
this.cmbBulletFormat.on('show:after', _.bind(this.onBulletFormatOpen, this));
|
||||||
|
|
||||||
this.spnSize = new Common.UI.MetricSpinner({
|
this.spnSize = new Common.UI.MetricSpinner({
|
||||||
el : $window.find('#id-dlg-list-size'),
|
el : $window.find('#id-dlg-list-size'),
|
||||||
step : 1,
|
step : 1,
|
||||||
width : 100,
|
width : 105,
|
||||||
value : 100,
|
value : 100,
|
||||||
defaultUnit : '',
|
defaultUnit : '',
|
||||||
maxValue : 400,
|
maxValue : 400,
|
||||||
|
|
@ -302,7 +345,7 @@ define([
|
||||||
this.spnStart = new Common.UI.MetricSpinner({
|
this.spnStart = new Common.UI.MetricSpinner({
|
||||||
el : $window.find('#id-dlg-list-start'),
|
el : $window.find('#id-dlg-list-start'),
|
||||||
step : 1,
|
step : 1,
|
||||||
width : 100,
|
width : 105,
|
||||||
value : 1,
|
value : 1,
|
||||||
defaultUnit : '',
|
defaultUnit : '',
|
||||||
maxValue : 32767,
|
maxValue : 32767,
|
||||||
|
|
@ -314,7 +357,32 @@ define([
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
me.numberingControls = $window.find('.numbering');
|
this.btnSelectImage = new Common.UI.Button({
|
||||||
|
parentEl: $('#id-dlg-list-image'),
|
||||||
|
cls: 'btn-text-menu-default',
|
||||||
|
caption: this.textSelect,
|
||||||
|
style: 'width: 100%;',
|
||||||
|
menu: new Common.UI.Menu({
|
||||||
|
style: 'min-width: 105px;',
|
||||||
|
maxHeight: 200,
|
||||||
|
additionalAlign: this.menuAddAlign,
|
||||||
|
items: [
|
||||||
|
{caption: this.textFromFile, value: 0},
|
||||||
|
{caption: this.textFromUrl, value: 1},
|
||||||
|
{caption: this.textFromStorage, value: 2}
|
||||||
|
]
|
||||||
|
})
|
||||||
|
});
|
||||||
|
this.btnSelectImage.menu.on('item:click', _.bind(this.onImageSelect, this));
|
||||||
|
this.btnSelectImage.menu.items[2].setVisible(this.storage);
|
||||||
|
|
||||||
|
this.btnOk = new Common.UI.Button({
|
||||||
|
el: $window.find('.primary')
|
||||||
|
});
|
||||||
|
|
||||||
|
me.numberingControls = $window.find('tr.numbering');
|
||||||
|
me.imageControls = $window.find('tr.image');
|
||||||
|
me.colorControls = $window.find('tr.color');
|
||||||
|
|
||||||
var el = $window.find('table tr:first() td:first()');
|
var el = $window.find('table tr:first() td:first()');
|
||||||
el.width(Math.max($window.find('.numbering .text').width(), el.width()));
|
el.width(Math.max($window.find('.numbering .text').width(), el.width()));
|
||||||
|
|
@ -323,12 +391,52 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
getFocusedComponents: function() {
|
getFocusedComponents: function() {
|
||||||
return [this.cmbNumFormat, this.cmbBulletFormat, this.spnSize, this.spnStart, this.btnColor];
|
return [this.cmbNumFormat, this.cmbBulletFormat, this.btnSelectImage, this.spnSize, this.spnStart, this.btnColor];
|
||||||
},
|
},
|
||||||
|
|
||||||
afterRender: function() {
|
afterRender: function() {
|
||||||
this.updateThemeColors();
|
this.updateThemeColors();
|
||||||
this._setDefaults(this.props);
|
this._setDefaults(this.props);
|
||||||
|
|
||||||
|
var me = this;
|
||||||
|
var onApiImageLoaded = function(bullet) {
|
||||||
|
me.imageProps = {id: bullet.asc_getImageId(), redraw: true};
|
||||||
|
if (me._changedProps)
|
||||||
|
me._changedProps.asc_fillBulletImage(me.imageProps.id);
|
||||||
|
// add or update record for image to btnBulletFormat and select it
|
||||||
|
var store = me.cmbBulletFormat.store;
|
||||||
|
if (!store.findWhere({value: _BulletTypes.image})) {
|
||||||
|
var idx = store.indexOf(store.findWhere({value: _BulletTypes.newSymbol}));
|
||||||
|
store.add({ displayValue: me.txtImage + ':', value: _BulletTypes.image }, {at: idx});
|
||||||
|
}
|
||||||
|
me.cmbBulletFormat.setData(store.models);
|
||||||
|
me.cmbBulletFormat.selectRecord(me.cmbBulletFormat.store.findWhere({value: _BulletTypes.image}));
|
||||||
|
me.btnOk.setDisabled(false);
|
||||||
|
};
|
||||||
|
this.api.asc_registerCallback('asc_onBulletImageLoaded', onApiImageLoaded);
|
||||||
|
|
||||||
|
var insertImageFromStorage = function(data) {
|
||||||
|
if (data && data._urls && data.c=='bullet') {
|
||||||
|
(new Asc.asc_CBullet()).asc_putImageUrl(data._urls[0], data.token);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Common.NotificationCenter.on('storage:image-insert', insertImageFromStorage);
|
||||||
|
|
||||||
|
this.on('close', function(obj){
|
||||||
|
me.api.asc_unregisterCallback('asc_onBulletImageLoaded', onApiImageLoaded);
|
||||||
|
Common.NotificationCenter.off('storage:image-insert', insertImageFromStorage);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
onBulletFormatOpen: function(combo) {
|
||||||
|
var store = combo.store,
|
||||||
|
rec = store.findWhere({value: _BulletTypes.image});
|
||||||
|
if (rec && this.imageProps.redraw) {
|
||||||
|
var bullet = new Asc.asc_CBullet();
|
||||||
|
bullet.asc_fillBulletImage(this.imageProps.id);
|
||||||
|
bullet.drawSquareImage('id-dlg-list-bullet-image-preview');
|
||||||
|
this.imageProps.redraw = false;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
updateThemeColors: function() {
|
updateThemeColors: function() {
|
||||||
|
|
@ -347,9 +455,14 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
ShowHideElem: function(value) {
|
ShowHideElem: function(value) {
|
||||||
|
var isImage = value==0 && (this.cmbBulletFormat.getValue()===_BulletTypes.image || this.cmbBulletFormat.getValue()===_BulletTypes.newImage ||
|
||||||
|
(this.cmbBulletFormat.getValue()===undefined || this.cmbBulletFormat.getValue()==='') && this.originalType === AscFormat.BULLET_TYPE_BULLET_BLIP);
|
||||||
this.numberingControls.toggleClass('hidden', value==0);
|
this.numberingControls.toggleClass('hidden', value==0);
|
||||||
|
this.imageControls.toggleClass('hidden', !isImage);
|
||||||
|
this.colorControls.toggleClass('hidden', isImage);
|
||||||
this.cmbNumFormat.setVisible(value==1);
|
this.cmbNumFormat.setVisible(value==1);
|
||||||
this.cmbBulletFormat.setVisible(value==0);
|
this.cmbBulletFormat.setVisible(value==0);
|
||||||
|
this.btnOk.setDisabled(isImage && (this.cmbBulletFormat.getValue()===_BulletTypes.newImage));
|
||||||
var me = this;
|
var me = this;
|
||||||
_.delay(function(){
|
_.delay(function(){
|
||||||
if (value)
|
if (value)
|
||||||
|
|
@ -362,18 +475,28 @@ define([
|
||||||
_handleInput: function(state) {
|
_handleInput: function(state) {
|
||||||
if (this.options.handler)
|
if (this.options.handler)
|
||||||
{
|
{
|
||||||
|
if (state == 'ok' && this.btnOk.isDisabled()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
var type = this.btnBullet.pressed ? 0 : 1;
|
var type = this.btnBullet.pressed ? 0 : 1;
|
||||||
if (this.originalType == AscFormat.BULLET_TYPE_BULLET_NONE) {
|
if (this.originalType == AscFormat.BULLET_TYPE_BULLET_NONE) {
|
||||||
this._changedProps = new Asc.asc_CBullet();
|
this._changedProps = new Asc.asc_CBullet();
|
||||||
this._changedProps.asc_putColor(Common.Utils.ThemeColor.getRgbColor(this.color));
|
|
||||||
this._changedProps.asc_putSize(this.spnSize.getNumberValue());
|
this._changedProps.asc_putSize(this.spnSize.getNumberValue());
|
||||||
|
if (type==0 && this.cmbBulletFormat.getValue()===_BulletTypes.image && this.imageProps) {//image
|
||||||
|
this._changedProps.asc_fillBulletImage(this.imageProps.id);
|
||||||
|
} else {
|
||||||
|
this._changedProps.asc_putColor(Common.Utils.ThemeColor.getRgbColor(this.color));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.originalType == AscFormat.BULLET_TYPE_BULLET_NONE ||
|
if (this.originalType == AscFormat.BULLET_TYPE_BULLET_NONE ||
|
||||||
this.originalType == AscFormat.BULLET_TYPE_BULLET_CHAR && type==1 || this.originalType == AscFormat.BULLET_TYPE_BULLET_AUTONUM && type==0) { // changed list type
|
(this.originalType == AscFormat.BULLET_TYPE_BULLET_CHAR || this.originalType == AscFormat.BULLET_TYPE_BULLET_BLIP) && type==1 ||
|
||||||
|
this.originalType == AscFormat.BULLET_TYPE_BULLET_AUTONUM && type==0) { // changed list type
|
||||||
if (type==0) {//markers
|
if (type==0) {//markers
|
||||||
if (this.cmbBulletFormat.getValue()==-1) {
|
if (this.cmbBulletFormat.getValue()==_BulletTypes.none) {
|
||||||
this._changedProps.asc_putListType(0, -1);
|
this._changedProps.asc_putListType(0, -1);
|
||||||
|
} else if (this.cmbBulletFormat.getValue()==_BulletTypes.image) {
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
this._changedProps.asc_putFont(this.bulletProps.font);
|
this._changedProps.asc_putFont(this.bulletProps.font);
|
||||||
this._changedProps.asc_putSymbol(this.bulletProps.symbol);
|
this._changedProps.asc_putSymbol(this.bulletProps.symbol);
|
||||||
|
|
@ -432,16 +555,28 @@ define([
|
||||||
|
|
||||||
if (this.originalType == AscFormat.BULLET_TYPE_BULLET_NONE) {
|
if (this.originalType == AscFormat.BULLET_TYPE_BULLET_NONE) {
|
||||||
this.cmbNumFormat.setValue(-1);
|
this.cmbNumFormat.setValue(-1);
|
||||||
this.cmbBulletFormat.setValue(-1);
|
this.cmbBulletFormat.setValue(_BulletTypes.none);
|
||||||
type = this.type;
|
type = this.type;
|
||||||
} else if (this.originalType == AscFormat.BULLET_TYPE_BULLET_CHAR) {
|
} else if (this.originalType == AscFormat.BULLET_TYPE_BULLET_CHAR) {
|
||||||
var symbol = bullet.asc_getSymbol();
|
var symbol = bullet.asc_getSymbol();
|
||||||
if (symbol) {
|
if (symbol) {
|
||||||
this.bulletProps = {symbol: symbol, font: bullet.asc_getFont()};
|
this.bulletProps = {symbol: symbol, font: bullet.asc_getFont()};
|
||||||
if (!this.cmbBulletFormat.store.findWhere({value: 0, symbol: this.bulletProps.symbol, font: this.bulletProps.font}))
|
if (!this.cmbBulletFormat.store.findWhere({value: _BulletTypes.symbol, symbol: this.bulletProps.symbol, font: this.bulletProps.font}))
|
||||||
this.cmbBulletFormat.store.add({ displayValue: this.txtSymbol + ': ', value: 0, symbol: this.bulletProps.symbol, font: this.bulletProps.font }, {at: this.cmbBulletFormat.store.length-1});
|
this.cmbBulletFormat.store.add({ displayValue: this.txtSymbol + ': ', value: _BulletTypes.symbol, symbol: this.bulletProps.symbol, font: this.bulletProps.font }, {at: this.cmbBulletFormat.store.length-2});
|
||||||
this.cmbBulletFormat.setData(this.cmbBulletFormat.store.models);
|
this.cmbBulletFormat.setData(this.cmbBulletFormat.store.models);
|
||||||
this.cmbBulletFormat.selectRecord(this.cmbBulletFormat.store.findWhere({value: 0, symbol: this.bulletProps.symbol, font: this.bulletProps.font}));
|
this.cmbBulletFormat.selectRecord(this.cmbBulletFormat.store.findWhere({value: _BulletTypes.symbol, symbol: this.bulletProps.symbol, font: this.bulletProps.font}));
|
||||||
|
} else
|
||||||
|
this.cmbBulletFormat.setValue('');
|
||||||
|
this._changedProps = bullet;
|
||||||
|
type = 0;
|
||||||
|
} else if (this.originalType == AscFormat.BULLET_TYPE_BULLET_BLIP) {
|
||||||
|
var id = bullet.asc_getImageId();
|
||||||
|
if (id) {
|
||||||
|
this.imageProps = {id: id, redraw: true};
|
||||||
|
if (!this.cmbBulletFormat.store.findWhere({value: _BulletTypes.image}))
|
||||||
|
this.cmbBulletFormat.store.add({ displayValue: this.txtImage + ':', value: _BulletTypes.image}, {at: this.cmbBulletFormat.store.length-2});
|
||||||
|
this.cmbBulletFormat.setData(this.cmbBulletFormat.store.models);
|
||||||
|
this.cmbBulletFormat.selectRecord(this.cmbBulletFormat.store.findWhere({value: _BulletTypes.image}));
|
||||||
} else
|
} else
|
||||||
this.cmbBulletFormat.setValue('');
|
this.cmbBulletFormat.setValue('');
|
||||||
this._changedProps = bullet;
|
this._changedProps = bullet;
|
||||||
|
|
@ -458,7 +593,7 @@ define([
|
||||||
}
|
}
|
||||||
} else {// different bullet types
|
} else {// different bullet types
|
||||||
this.cmbNumFormat.setValue(-1);
|
this.cmbNumFormat.setValue(-1);
|
||||||
this.cmbBulletFormat.setValue(-1);
|
this.cmbBulletFormat.setValue(_BulletTypes.none);
|
||||||
this._changedProps = new Asc.asc_CBullet();
|
this._changedProps = new Asc.asc_CBullet();
|
||||||
type = this.type;
|
type = this.type;
|
||||||
}
|
}
|
||||||
|
|
@ -468,6 +603,26 @@ define([
|
||||||
this.ShowHideElem(type);
|
this.ShowHideElem(type);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onImageSelect: function(menu, item) {
|
||||||
|
if (item.value==1) {
|
||||||
|
var me = this;
|
||||||
|
(new Common.Views.ImageFromUrlDialog({
|
||||||
|
handler: function(result, value) {
|
||||||
|
if (result == 'ok') {
|
||||||
|
var checkUrl = value.replace(/ /g, '');
|
||||||
|
if (!_.isEmpty(checkUrl)) {
|
||||||
|
(new Asc.asc_CBullet()).asc_putImageUrl(checkUrl);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})).show();
|
||||||
|
} else if (item.value==2) {
|
||||||
|
Common.NotificationCenter.trigger('storage:image-load', 'bullet');
|
||||||
|
} else {
|
||||||
|
(new Asc.asc_CBullet()).asc_showFileDialog();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
txtTitle: 'List Settings',
|
txtTitle: 'List Settings',
|
||||||
txtSize: 'Size',
|
txtSize: 'Size',
|
||||||
txtColor: 'Color',
|
txtColor: 'Color',
|
||||||
|
|
@ -478,6 +633,13 @@ define([
|
||||||
txtType: 'Type',
|
txtType: 'Type',
|
||||||
txtNone: 'None',
|
txtNone: 'None',
|
||||||
txtNewBullet: 'New bullet',
|
txtNewBullet: 'New bullet',
|
||||||
txtSymbol: 'Symbol'
|
txtSymbol: 'Symbol',
|
||||||
|
txtNewImage: 'New image',
|
||||||
|
txtImage: 'Image',
|
||||||
|
txtImport: 'Import',
|
||||||
|
textSelect: 'Select From',
|
||||||
|
textFromUrl: 'From URL',
|
||||||
|
textFromFile: 'From File',
|
||||||
|
textFromStorage: 'From Storage'
|
||||||
}, Common.Views.ListSettingsDialog || {}))
|
}, Common.Views.ListSettingsDialog || {}))
|
||||||
});
|
});
|
||||||
|
|
@ -205,6 +205,8 @@ define([
|
||||||
this.inputPwd = new Common.UI.InputFieldBtnPassword({
|
this.inputPwd = new Common.UI.InputFieldBtnPassword({
|
||||||
el: $('#id-password-txt'),
|
el: $('#id-password-txt'),
|
||||||
type: 'password',
|
type: 'password',
|
||||||
|
showCls: (this.options.iconType==='svg' ? 'svg-icon' : 'toolbar__icon') + ' btn-sheet-view',
|
||||||
|
hideCls: (this.options.iconType==='svg' ? 'svg-icon' : 'toolbar__icon') + ' hide-password',
|
||||||
validateOnBlur: false,
|
validateOnBlur: false,
|
||||||
showPwdOnClick: true,
|
showPwdOnClick: true,
|
||||||
validation : function(value) {
|
validation : function(value) {
|
||||||
|
|
|
||||||
|
|
@ -77,6 +77,7 @@ define([
|
||||||
_options.tpl = _.template(this.template)(_options);
|
_options.tpl = _.template(this.template)(_options);
|
||||||
|
|
||||||
this.url = options.url || '';
|
this.url = options.url || '';
|
||||||
|
this.loader = (options.loader!==undefined) ? options.loader : true;
|
||||||
this.frameId = options.frameId || 'plugin_iframe';
|
this.frameId = options.frameId || 'plugin_iframe';
|
||||||
Common.UI.Window.prototype.initialize.call(this, _options);
|
Common.UI.Window.prototype.initialize.call(this, _options);
|
||||||
},
|
},
|
||||||
|
|
@ -90,6 +91,8 @@ define([
|
||||||
if (!this.options.header) this._headerFooterHeight -= 34;
|
if (!this.options.header) this._headerFooterHeight -= 34;
|
||||||
this._headerFooterHeight += ((parseInt(this.$window.css('border-top-width')) + parseInt(this.$window.css('border-bottom-width'))));
|
this._headerFooterHeight += ((parseInt(this.$window.css('border-top-width')) + parseInt(this.$window.css('border-bottom-width'))));
|
||||||
|
|
||||||
|
this.$window.find('.header').prepend($('<div class="tools left hidden"></div>'));
|
||||||
|
|
||||||
var iframe = document.createElement("iframe");
|
var iframe = document.createElement("iframe");
|
||||||
iframe.id = this.frameId;
|
iframe.id = this.frameId;
|
||||||
iframe.name = 'pluginFrameEditor';
|
iframe.name = 'pluginFrameEditor';
|
||||||
|
|
@ -102,6 +105,7 @@ define([
|
||||||
iframe.onload = _.bind(this._onLoad,this);
|
iframe.onload = _.bind(this._onLoad,this);
|
||||||
|
|
||||||
var me = this;
|
var me = this;
|
||||||
|
if (this.loader) {
|
||||||
setTimeout(function(){
|
setTimeout(function(){
|
||||||
if (me.isLoaded) return;
|
if (me.isLoaded) return;
|
||||||
me.loadMask = new Common.UI.LoadMask({owner: $('#id-plugin-placeholder')});
|
me.loadMask = new Common.UI.LoadMask({owner: $('#id-plugin-placeholder')});
|
||||||
|
|
@ -109,6 +113,7 @@ define([
|
||||||
me.loadMask.show();
|
me.loadMask.show();
|
||||||
if (me.isLoaded) me.loadMask.hide();
|
if (me.isLoaded) me.loadMask.hide();
|
||||||
}, 500);
|
}, 500);
|
||||||
|
}
|
||||||
|
|
||||||
iframe.src = this.url;
|
iframe.src = this.url;
|
||||||
$('#id-plugin-placeholder').append(iframe);
|
$('#id-plugin-placeholder').append(iframe);
|
||||||
|
|
@ -180,6 +185,32 @@ define([
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
showButton: function(id) {
|
||||||
|
var header = this.$window.find('.header .tools.left');
|
||||||
|
if (id=='back') {
|
||||||
|
var btn = header.find('#id-plugindlg-' + id);
|
||||||
|
if (btn.length<1) {
|
||||||
|
btn = $('<div id="id-plugindlg-' + id + '" class="tool help" style="font-size:20px;">←</div>');
|
||||||
|
btn.on('click', _.bind(function() {
|
||||||
|
this.fireEvent('header:click',id);
|
||||||
|
}, this));
|
||||||
|
header.prepend(btn);
|
||||||
|
}
|
||||||
|
btn.show();
|
||||||
|
header.removeClass('hidden');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
hideButton: function(id) {
|
||||||
|
var header = this.$window.find('.header .tools.left');
|
||||||
|
if (id=='back') {
|
||||||
|
var btn = header.find('#id-plugindlg-' + id);
|
||||||
|
if (btn.length>0) {
|
||||||
|
btn.hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
textLoading : 'Loading'
|
textLoading : 'Loading'
|
||||||
}, Common.Views.PluginDlg || {}));
|
}, Common.Views.PluginDlg || {}));
|
||||||
});
|
});
|
||||||
|
|
@ -60,11 +60,11 @@ define([
|
||||||
'</div>',
|
'</div>',
|
||||||
'</div>',
|
'</div>',
|
||||||
'<div id="current-plugin-box" class="layout-ct vbox hidden">',
|
'<div id="current-plugin-box" class="layout-ct vbox hidden">',
|
||||||
|
'<div id="current-plugin-frame" class="">',
|
||||||
|
'</div>',
|
||||||
'<div id="current-plugin-header">',
|
'<div id="current-plugin-header">',
|
||||||
'<label></label>',
|
'<label></label>',
|
||||||
'<div id="id-plugin-close" class="tool close"></div>',
|
'<div id="id-plugin-close" class="close"></div>',
|
||||||
'</div>',
|
|
||||||
'<div id="current-plugin-frame" class="">',
|
|
||||||
'</div>',
|
'</div>',
|
||||||
'</div>',
|
'</div>',
|
||||||
'<div id="plugins-mask" style="display: none;">'
|
'<div id="plugins-mask" style="display: none;">'
|
||||||
|
|
@ -111,6 +111,13 @@ define([
|
||||||
this.currentPluginPanel = $('#current-plugin-box');
|
this.currentPluginPanel = $('#current-plugin-box');
|
||||||
this.currentPluginFrame = $('#current-plugin-frame');
|
this.currentPluginFrame = $('#current-plugin-frame');
|
||||||
|
|
||||||
|
this.pluginClose = new Common.UI.Button({
|
||||||
|
parentEl: $('#id-plugin-close'),
|
||||||
|
cls: 'btn-toolbar',
|
||||||
|
iconCls: 'toolbar__icon btn-close',
|
||||||
|
hint: this.textClosePanel
|
||||||
|
});
|
||||||
|
|
||||||
this.pluginMenu = new Common.UI.Menu({
|
this.pluginMenu = new Common.UI.Menu({
|
||||||
menuAlign : 'tr-br',
|
menuAlign : 'tr-br',
|
||||||
items: []
|
items: []
|
||||||
|
|
@ -426,7 +433,8 @@ define([
|
||||||
textLoading: 'Loading',
|
textLoading: 'Loading',
|
||||||
textStart: 'Start',
|
textStart: 'Start',
|
||||||
textStop: 'Stop',
|
textStop: 'Stop',
|
||||||
groupCaption: 'Plugins'
|
groupCaption: 'Plugins',
|
||||||
|
textClosePanel: 'Close plugin'
|
||||||
|
|
||||||
}, Common.Views.Plugins || {}));
|
}, Common.Views.Plugins || {}));
|
||||||
});
|
});
|
||||||
|
|
@ -54,6 +54,26 @@ define([
|
||||||
], function () {
|
], function () {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
if (!Common.enumLock)
|
||||||
|
Common.enumLock = {};
|
||||||
|
|
||||||
|
var enumLock = {
|
||||||
|
noSpellcheckLangs: 'no-spellcheck-langs',
|
||||||
|
isReviewOnly: 'review-only',
|
||||||
|
reviewChangelock: 'review-change-lock',
|
||||||
|
hasCoeditingUsers: 'has-coediting-users',
|
||||||
|
previewReviewMode: 'preview-review-mode', // display mode on Collaboration tab
|
||||||
|
viewFormMode: 'view-form-mode', // view form mode on Forms tab
|
||||||
|
viewMode: 'view-mode', // view mode on disconnect, version history etc (used for locking buttons not in toolbar)
|
||||||
|
hideComments: 'hide-comments', // no live comments and left panel is closed
|
||||||
|
cantShare: 'cant-share'
|
||||||
|
};
|
||||||
|
for (var key in enumLock) {
|
||||||
|
if (enumLock.hasOwnProperty(key)) {
|
||||||
|
Common.enumLock[key] = enumLock[key];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Common.Views.ReviewChanges = Common.UI.BaseView.extend(_.extend((function(){
|
Common.Views.ReviewChanges = Common.UI.BaseView.extend(_.extend((function(){
|
||||||
var template =
|
var template =
|
||||||
'<section id="review-changes-panel" class="panel" data-tab="review">' +
|
'<section id="review-changes-panel" class="panel" data-tab="review">' +
|
||||||
|
|
@ -229,44 +249,52 @@ define([
|
||||||
Common.UI.BaseView.prototype.initialize.call(this, options);
|
Common.UI.BaseView.prototype.initialize.call(this, options);
|
||||||
|
|
||||||
this.appConfig = options.mode;
|
this.appConfig = options.mode;
|
||||||
|
this.lockedControls = [];
|
||||||
var filter = Common.localStorage.getKeysFilter();
|
var filter = Common.localStorage.getKeysFilter();
|
||||||
this.appPrefix = (filter && filter.length) ? filter.split(',')[0] : '';
|
this.appPrefix = (filter && filter.length) ? filter.split(',')[0] : '';
|
||||||
|
var _set = Common.enumLock;
|
||||||
if ( this.appConfig.canReview ) {
|
if ( this.appConfig.canReview ) {
|
||||||
this.btnAccept = new Common.UI.Button({
|
this.btnAccept = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
caption: this.txtAccept,
|
caption: this.txtAccept,
|
||||||
split: !this.appConfig.canUseReviewPermissions,
|
split: !this.appConfig.canUseReviewPermissions,
|
||||||
iconCls: 'toolbar__icon btn-review-save',
|
iconCls: 'toolbar__icon btn-review-save',
|
||||||
|
lock: [_set.reviewChangelock, _set.isReviewOnly, _set.previewReviewMode, _set.viewFormMode, _set.lostConnect],
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnAccept);
|
||||||
|
|
||||||
this.btnReject = new Common.UI.Button({
|
this.btnReject = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
caption: this.txtReject,
|
caption: this.txtReject,
|
||||||
split: !this.appConfig.canUseReviewPermissions,
|
split: !this.appConfig.canUseReviewPermissions,
|
||||||
iconCls: 'toolbar__icon btn-review-deny',
|
iconCls: 'toolbar__icon btn-review-deny',
|
||||||
|
lock: [_set.reviewChangelock, _set.isReviewOnly, _set.previewReviewMode, _set.viewFormMode, _set.lostConnect],
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnReject);
|
||||||
|
|
||||||
if (this.appConfig.canFeatureComparison)
|
if (this.appConfig.canFeatureComparison) {
|
||||||
this.btnCompare = new Common.UI.Button({
|
this.btnCompare = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
caption: this.txtCompare,
|
caption: this.txtCompare,
|
||||||
split: true,
|
split: true,
|
||||||
iconCls: 'toolbar__icon btn-compare',
|
iconCls: 'toolbar__icon btn-compare',
|
||||||
|
lock: [_set.hasCoeditingUsers, _set.previewReviewMode, _set.viewFormMode, _set.lostConnect],
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnCompare);
|
||||||
|
}
|
||||||
this.btnTurnOn = new Common.UI.Button({
|
this.btnTurnOn = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
iconCls: 'toolbar__icon btn-ic-review',
|
iconCls: 'toolbar__icon btn-ic-review',
|
||||||
|
lock: [_set.previewReviewMode, _set.viewFormMode, _set.lostConnect],
|
||||||
caption: this.txtTurnon,
|
caption: this.txtTurnon,
|
||||||
split: !this.appConfig.isReviewOnly,
|
split: !this.appConfig.isReviewOnly,
|
||||||
enableToggle: true,
|
enableToggle: true,
|
||||||
|
|
@ -275,25 +303,30 @@ define([
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
this.btnsTurnReview = [this.btnTurnOn];
|
this.btnsTurnReview = [this.btnTurnOn];
|
||||||
|
this.lockedControls.push(this.btnTurnOn);
|
||||||
}
|
}
|
||||||
if (this.appConfig.canViewReview) {
|
if (this.appConfig.canViewReview) {
|
||||||
this.btnPrev = new Common.UI.Button({
|
this.btnPrev = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
iconCls: 'toolbar__icon btn-review-prev',
|
iconCls: 'toolbar__icon btn-review-prev',
|
||||||
|
lock: [_set.previewReviewMode, _set.viewFormMode, _set.lostConnect],
|
||||||
caption: this.txtPrev,
|
caption: this.txtPrev,
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnPrev);
|
||||||
|
|
||||||
this.btnNext = new Common.UI.Button({
|
this.btnNext = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
iconCls: 'toolbar__icon btn-review-next',
|
iconCls: 'toolbar__icon btn-review-next',
|
||||||
|
lock: [_set.previewReviewMode, _set.viewFormMode, _set.lostConnect],
|
||||||
caption: this.txtNext,
|
caption: this.txtNext,
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnNext);
|
||||||
|
|
||||||
if (!this.appConfig.isRestrictedEdit && !(this.appConfig.customization && this.appConfig.customization.review && this.appConfig.customization.review.hideReviewDisplay)) {// hide Display mode option for fillForms and commenting mode
|
if (!this.appConfig.isRestrictedEdit && !(this.appConfig.customization && this.appConfig.customization.review && this.appConfig.customization.review.hideReviewDisplay)) {// hide Display mode option for fillForms and commenting mode
|
||||||
var menuTemplate = _.template('<a id="<%= id %>" tabindex="-1" type="menuitem"><div><%= caption %></div>' +
|
var menuTemplate = _.template('<a id="<%= id %>" tabindex="-1" type="menuitem"><div><%= caption %></div>' +
|
||||||
|
|
@ -303,6 +336,7 @@ define([
|
||||||
this.btnReviewView = new Common.UI.Button({
|
this.btnReviewView = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
iconCls: 'toolbar__icon btn-ic-reviewview',
|
iconCls: 'toolbar__icon btn-ic-reviewview',
|
||||||
|
lock: [_set.viewFormMode, _set.lostConnect],
|
||||||
caption: this.txtView,
|
caption: this.txtView,
|
||||||
menu: new Common.UI.Menu({
|
menu: new Common.UI.Menu({
|
||||||
cls: 'ppm-toolbar',
|
cls: 'ppm-toolbar',
|
||||||
|
|
@ -349,6 +383,7 @@ define([
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnReviewView);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -356,23 +391,27 @@ define([
|
||||||
this.btnSharing = new Common.UI.Button({
|
this.btnSharing = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
iconCls: 'toolbar__icon btn-ic-sharing',
|
iconCls: 'toolbar__icon btn-ic-sharing',
|
||||||
|
lock: [_set.viewFormMode, _set.cantShare, _set.lostConnect],
|
||||||
caption: this.txtSharing,
|
caption: this.txtSharing,
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnSharing);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.appConfig.isEdit && !this.appConfig.isOffline && this.appConfig.canCoAuthoring && this.appConfig.canChangeCoAuthoring) {
|
if (this.appConfig.isEdit && !this.appConfig.isOffline && this.appConfig.canCoAuthoring && this.appConfig.canChangeCoAuthoring) {
|
||||||
this.btnCoAuthMode = new Common.UI.Button({
|
this.btnCoAuthMode = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
iconCls: 'toolbar__icon btn-ic-coedit',
|
iconCls: 'toolbar__icon btn-ic-coedit',
|
||||||
|
lock: [_set.viewFormMode, _set.lostConnect],
|
||||||
caption: this.txtCoAuthMode,
|
caption: this.txtCoAuthMode,
|
||||||
menu: true,
|
menu: true,
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnCoAuthMode);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.btnsSpelling = [];
|
this.btnsSpelling = [];
|
||||||
|
|
@ -382,23 +421,27 @@ define([
|
||||||
this.btnHistory = new Common.UI.Button({
|
this.btnHistory = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
iconCls: 'toolbar__icon btn-ic-history',
|
iconCls: 'toolbar__icon btn-ic-history',
|
||||||
|
lock: [_set.lostConnect],
|
||||||
caption: this.txtHistory,
|
caption: this.txtHistory,
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnHistory);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.appConfig.canCoAuthoring && this.appConfig.canChat) {
|
if (this.appConfig.canCoAuthoring && this.appConfig.canChat) {
|
||||||
this.btnChat = new Common.UI.Button({
|
this.btnChat = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
iconCls: 'toolbar__icon btn-ic-chat',
|
iconCls: 'toolbar__icon btn-ic-chat',
|
||||||
|
lock: [_set.lostConnect],
|
||||||
caption: this.txtChat,
|
caption: this.txtChat,
|
||||||
enableToggle: true,
|
enableToggle: true,
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnChat);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( this.appConfig.canCoAuthoring && this.appConfig.canComments ) {
|
if ( this.appConfig.canCoAuthoring && this.appConfig.canComments ) {
|
||||||
|
|
@ -407,19 +450,23 @@ define([
|
||||||
caption: this.txtCommentRemove,
|
caption: this.txtCommentRemove,
|
||||||
split: true,
|
split: true,
|
||||||
iconCls: 'toolbar__icon btn-rem-comment',
|
iconCls: 'toolbar__icon btn-rem-comment',
|
||||||
|
lock: [_set.previewReviewMode, _set.viewFormMode, _set.hideComments, _set['Objects'], _set.lostConnect],
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnCommentRemove);
|
||||||
this.btnCommentResolve = new Common.UI.Button({
|
this.btnCommentResolve = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar x-huge icon-top',
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
caption: this.txtCommentResolve,
|
caption: this.txtCommentResolve,
|
||||||
split: true,
|
split: true,
|
||||||
iconCls: 'toolbar__icon btn-resolve-all',
|
iconCls: 'toolbar__icon btn-resolve-all',
|
||||||
|
lock: [_set.previewReviewMode, _set.viewFormMode, _set.hideComments, _set['Objects'], _set.lostConnect],
|
||||||
dataHint: '1',
|
dataHint: '1',
|
||||||
dataHintDirection: 'bottom',
|
dataHintDirection: 'bottom',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
|
this.lockedControls.push(this.btnCommentResolve);
|
||||||
}
|
}
|
||||||
|
|
||||||
Common.NotificationCenter.on('app:ready', this.onAppReady.bind(this));
|
Common.NotificationCenter.on('app:ready', this.onAppReady.bind(this));
|
||||||
|
|
@ -524,8 +571,7 @@ define([
|
||||||
me.btnCompare.updateHint(me.tipCompare);
|
me.btnCompare.updateHint(me.tipCompare);
|
||||||
}
|
}
|
||||||
|
|
||||||
config.isReviewOnly && me.btnAccept.setDisabled(true);
|
Common.Utils.lockControls(Common.enumLock.isReviewOnly, config.isReviewOnly, {array: [me.btnAccept, me.btnReject]});
|
||||||
config.isReviewOnly && me.btnReject.setDisabled(true);
|
|
||||||
}
|
}
|
||||||
if (me.appConfig.canViewReview) {
|
if (me.appConfig.canViewReview) {
|
||||||
me.btnPrev.updateHint(me.hintPrev);
|
me.btnPrev.updateHint(me.hintPrev);
|
||||||
|
|
@ -685,6 +731,7 @@ define([
|
||||||
var button = new Common.UI.Button({
|
var button = new Common.UI.Button({
|
||||||
cls : 'btn-toolbar',
|
cls : 'btn-toolbar',
|
||||||
iconCls : 'toolbar__icon btn-ic-review',
|
iconCls : 'toolbar__icon btn-ic-review',
|
||||||
|
lock: [Common.enumLock.viewMode, Common.enumLock.previewReviewMode, Common.enumLock.viewFormMode, Common.enumLock.lostConnect],
|
||||||
hintAnchor : 'top',
|
hintAnchor : 'top',
|
||||||
hint : this.tipReview,
|
hint : this.tipReview,
|
||||||
split : !this.appConfig.isReviewOnly,
|
split : !this.appConfig.isReviewOnly,
|
||||||
|
|
@ -724,13 +771,14 @@ define([
|
||||||
});
|
});
|
||||||
|
|
||||||
this.btnsTurnReview.push(button);
|
this.btnsTurnReview.push(button);
|
||||||
|
this.lockedControls.push(button);
|
||||||
return button;
|
return button;
|
||||||
} else
|
} else
|
||||||
if ( type == 'spelling' ) {
|
if ( type == 'spelling' ) {
|
||||||
button = new Common.UI.Button({
|
button = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar',
|
cls: 'btn-toolbar',
|
||||||
iconCls: 'toolbar__icon btn-ic-docspell',
|
iconCls: 'toolbar__icon btn-ic-docspell',
|
||||||
|
lock: [Common.enumLock.viewMode, Common.enumLock.viewFormMode, Common.enumLock.previewReviewMode],
|
||||||
hintAnchor : 'top',
|
hintAnchor : 'top',
|
||||||
hint: this.tipSetSpelling,
|
hint: this.tipSetSpelling,
|
||||||
enableToggle: true,
|
enableToggle: true,
|
||||||
|
|
@ -740,25 +788,30 @@ define([
|
||||||
visible: Common.UI.FeaturesManager.canChange('spellcheck')
|
visible: Common.UI.FeaturesManager.canChange('spellcheck')
|
||||||
});
|
});
|
||||||
this.btnsSpelling.push(button);
|
this.btnsSpelling.push(button);
|
||||||
|
this.lockedControls.push(button);
|
||||||
return button;
|
return button;
|
||||||
} else if (type == 'doclang' && parent == 'statusbar' ) {
|
} else if (type == 'doclang' && parent == 'statusbar' ) {
|
||||||
button = new Common.UI.Button({
|
button = new Common.UI.Button({
|
||||||
cls: 'btn-toolbar',
|
cls: 'btn-toolbar',
|
||||||
iconCls: 'toolbar__icon btn-ic-doclang',
|
iconCls: 'toolbar__icon btn-ic-doclang',
|
||||||
|
lock: [Common.enumLock.viewMode, Common.enumLock.previewReviewMode, Common.enumLock.viewFormMode, Common.enumLock.noSpellcheckLangs, Common.enumLock.lostConnect],
|
||||||
hintAnchor : 'top',
|
hintAnchor : 'top',
|
||||||
hint: this.tipSetDocLang,
|
hint: this.tipSetDocLang,
|
||||||
disabled: true,
|
|
||||||
dataHint: '0',
|
dataHint: '0',
|
||||||
dataHintDirection: 'top',
|
dataHintDirection: 'top',
|
||||||
dataHintOffset: 'small'
|
dataHintOffset: 'small'
|
||||||
});
|
});
|
||||||
this.btnsDocLang.push(button);
|
this.btnsDocLang.push(button);
|
||||||
|
this.lockedControls.push(button);
|
||||||
|
Common.Utils.lockControls(Common.enumLock.noSpellcheckLangs, true, {array: [button]});
|
||||||
return button;
|
return button;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getButtons: function() {
|
||||||
|
return this.lockedControls;
|
||||||
|
},
|
||||||
|
|
||||||
getUserName: function (username) {
|
getUserName: function (username) {
|
||||||
return Common.Utils.String.htmlEncode(AscCommon.UserInfoParser.getParsedName(username));
|
return Common.Utils.String.htmlEncode(AscCommon.UserInfoParser.getParsedName(username));
|
||||||
},
|
},
|
||||||
|
|
@ -814,34 +867,8 @@ define([
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
SetDisabled: function (state, langs, protectProps) {
|
|
||||||
this.btnsSpelling && this.btnsSpelling.forEach(function(button) {
|
|
||||||
if ( button ) {
|
|
||||||
button.setDisabled(state);
|
|
||||||
}
|
|
||||||
}, this);
|
|
||||||
this.btnsDocLang && this.btnsDocLang.forEach(function(button) {
|
|
||||||
if ( button ) {
|
|
||||||
button.setDisabled(state || langs && langs.length<1);
|
|
||||||
}
|
|
||||||
}, this);
|
|
||||||
this.btnsTurnReview && this.btnsTurnReview.forEach(function(button) {
|
|
||||||
if ( button ) {
|
|
||||||
button.setDisabled(state);
|
|
||||||
}
|
|
||||||
}, this);
|
|
||||||
// this.btnChat && this.btnChat.setDisabled(state);
|
|
||||||
|
|
||||||
this.btnCommentRemove && this.btnCommentRemove.setDisabled(state || !Common.Utils.InternalSettings.get(this.appPrefix + "settings-livecomment") || protectProps && protectProps.comments);
|
|
||||||
this.btnCommentResolve && this.btnCommentResolve.setDisabled(state || !Common.Utils.InternalSettings.get(this.appPrefix + "settings-livecomment") || protectProps && protectProps.comments);
|
|
||||||
},
|
|
||||||
|
|
||||||
onLostEditRights: function() {
|
onLostEditRights: function() {
|
||||||
this._readonlyRights = true;
|
this._readonlyRights = true;
|
||||||
if (!this.rendered)
|
|
||||||
return;
|
|
||||||
|
|
||||||
this.btnSharing && this.btnSharing.setDisabled(true);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
txtAccept: 'Accept',
|
txtAccept: 'Accept',
|
||||||
|
|
|
||||||
201
apps/common/main/lib/view/SearchBar.js
Normal file
|
|
@ -0,0 +1,201 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2019
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha
|
||||||
|
* street, Riga, Latvia, EU, LV-1050.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* SearchBar.js
|
||||||
|
*
|
||||||
|
* Created by Julia Svinareva on 03.02.2022
|
||||||
|
* Copyright (c) 2022 Ascensio System SIA. All rights reserved.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
define([
|
||||||
|
'common/main/lib/component/Window',
|
||||||
|
'common/main/lib/component/Button'
|
||||||
|
], function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
Common.UI.SearchBar = Common.UI.Window.extend(_.extend({
|
||||||
|
options: {
|
||||||
|
modal: false,
|
||||||
|
width: 328,
|
||||||
|
height: 54,
|
||||||
|
header: false,
|
||||||
|
cls: 'search-bar',
|
||||||
|
alias: 'SearchBar',
|
||||||
|
showOpenPanel: true,
|
||||||
|
toolclose: 'hide'
|
||||||
|
},
|
||||||
|
|
||||||
|
initialize : function(options) {
|
||||||
|
_.extend(this.options, options || {});
|
||||||
|
|
||||||
|
this.template = [
|
||||||
|
'<div class="box">',
|
||||||
|
'<input type="text" id="search-bar-text" class="input-field form-control" maxlength="255" placeholder="'+this.textFind+'" autocomplete="off">',
|
||||||
|
'<div class="tools">',
|
||||||
|
'<div id="search-bar-back"></div>',
|
||||||
|
'<div id="search-bar-next"></div>',
|
||||||
|
this.options.showOpenPanel ? '<div id="search-bar-open-panel"></div>' : '',
|
||||||
|
'<div id="search-bar-close"></div>',
|
||||||
|
'</div>',
|
||||||
|
'</div>'
|
||||||
|
].join('');
|
||||||
|
|
||||||
|
this.options.tpl = _.template(this.template)(this.options);
|
||||||
|
this.iconType = this.options.iconType;
|
||||||
|
|
||||||
|
Common.UI.Window.prototype.initialize.call(this, this.options);
|
||||||
|
|
||||||
|
Common.NotificationCenter.on('layout:changed', _.bind(this.onLayoutChanged, this));
|
||||||
|
$(window).on('resize', _.bind(this.onLayoutChanged, this));
|
||||||
|
},
|
||||||
|
|
||||||
|
render: function() {
|
||||||
|
Common.UI.Window.prototype.render.call(this);
|
||||||
|
|
||||||
|
this.inputSearch = this.$window.find('#search-bar-text');
|
||||||
|
this.inputSearch.on('input', _.bind(function () {
|
||||||
|
this.disableNavButtons();
|
||||||
|
this.fireEvent('search:input', [this.inputSearch.val()]);
|
||||||
|
}, this)).on('keydown', _.bind(function (e) {
|
||||||
|
this.fireEvent('search:keydown', [this.inputSearch.val(), e]);
|
||||||
|
}, this));
|
||||||
|
|
||||||
|
this.btnBack = new Common.UI.Button({
|
||||||
|
parentEl: $('#search-bar-back'),
|
||||||
|
cls: 'btn-toolbar',
|
||||||
|
iconCls: this.iconType === 'svg' ? 'svg-icon search-arrow-up' : 'toolbar__icon btn-arrow-up',
|
||||||
|
hint: this.tipPreviousResult
|
||||||
|
});
|
||||||
|
this.btnBack.on('click', _.bind(this.onBtnNextClick, this, 'back'));
|
||||||
|
|
||||||
|
this.btnNext = new Common.UI.Button({
|
||||||
|
parentEl: $('#search-bar-next'),
|
||||||
|
cls: 'btn-toolbar',
|
||||||
|
iconCls: this.iconType === 'svg' ? 'svg-icon search-arrow-down' : 'toolbar__icon btn-arrow-down',
|
||||||
|
hint: this.tipNextResult
|
||||||
|
});
|
||||||
|
this.btnNext.on('click', _.bind(this.onBtnNextClick, this, 'next'));
|
||||||
|
|
||||||
|
if (this.options.showOpenPanel) {
|
||||||
|
this.btnOpenPanel = new Common.UI.Button({
|
||||||
|
parentEl: $('#search-bar-open-panel'),
|
||||||
|
cls: 'btn-toolbar',
|
||||||
|
iconCls: 'toolbar__icon more-vertical',
|
||||||
|
hint: this.tipOpenAdvancedSettings
|
||||||
|
});
|
||||||
|
this.btnOpenPanel.on('click', _.bind(this.onOpenPanel, this));
|
||||||
|
}
|
||||||
|
|
||||||
|
this.btnClose = new Common.UI.Button({
|
||||||
|
parentEl: $('#search-bar-close'),
|
||||||
|
cls: 'btn-toolbar',
|
||||||
|
iconCls: this.iconType === 'svg' ? 'svg-icon search-close' : 'toolbar__icon btn-close',
|
||||||
|
hint: this.tipCloseSearch
|
||||||
|
});
|
||||||
|
this.btnClose.on('click', _.bind(function () {
|
||||||
|
this.hide();
|
||||||
|
}, this))
|
||||||
|
|
||||||
|
this.on('animate:before', _.bind(this.focus, this));
|
||||||
|
|
||||||
|
Common.NotificationCenter.on('search:updateresults', _.bind(this.disableNavButtons, this));
|
||||||
|
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
show: function(text) {
|
||||||
|
var top = ($('#app-title').length > 0 ? $('#app-title').height() : 0) + $('#toolbar').height() + 2,
|
||||||
|
left = Common.Utils.innerWidth() - ($('#right-menu').is(':visible') ? $('#right-menu').width() : 0) - this.options.width - 32;
|
||||||
|
Common.UI.Window.prototype.show.call(this, left, top);
|
||||||
|
|
||||||
|
this.disableNavButtons();
|
||||||
|
if (text) {
|
||||||
|
this.inputSearch.val(text);
|
||||||
|
this.fireEvent('search:input', [text]);
|
||||||
|
} else {
|
||||||
|
this.inputSearch.val('');
|
||||||
|
window.SSE && this.fireEvent('search:input', ['', true]);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.focus();
|
||||||
|
},
|
||||||
|
|
||||||
|
focus: function() {
|
||||||
|
var me = this;
|
||||||
|
setTimeout(function(){
|
||||||
|
me.inputSearch.focus();
|
||||||
|
me.inputSearch.select();
|
||||||
|
}, 10);
|
||||||
|
},
|
||||||
|
|
||||||
|
setText: function (text) {
|
||||||
|
this.inputSearch.val(text);
|
||||||
|
this.fireEvent('search:input', [text]);
|
||||||
|
},
|
||||||
|
|
||||||
|
getSettings: function() {
|
||||||
|
return {
|
||||||
|
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
onLayoutChanged: function () {
|
||||||
|
var top = $('#app-title').height() + $('#toolbar').height() + 2,
|
||||||
|
left = Common.Utils.innerWidth() - ($('#right-menu').is(':visible') ? $('#right-menu').width() : 0) - this.options.width - 32;
|
||||||
|
this.$window.css({left: left, top: top});
|
||||||
|
},
|
||||||
|
|
||||||
|
onBtnNextClick: function(action) {
|
||||||
|
this.fireEvent('search:'+action, [this.inputSearch.val(), false]);
|
||||||
|
},
|
||||||
|
|
||||||
|
onOpenPanel: function () {
|
||||||
|
this.hide();
|
||||||
|
this.fireEvent('search:show', [true, this.inputSearch.val()]);
|
||||||
|
},
|
||||||
|
|
||||||
|
disableNavButtons: function (resultNumber, allResults) {
|
||||||
|
var disable = (this.inputSearch.val() === '' && !window.SSE) || !allResults;
|
||||||
|
this.btnBack.setDisabled(disable);
|
||||||
|
this.btnNext.setDisabled(disable);
|
||||||
|
},
|
||||||
|
|
||||||
|
textFind: 'Find',
|
||||||
|
tipPreviousResult: 'Previous result',
|
||||||
|
tipNextResult: 'Next result',
|
||||||
|
tipOpenAdvancedSettings: 'Open advanced settings',
|
||||||
|
tipCloseSearch: 'Close search'
|
||||||
|
|
||||||
|
}, Common.UI.SearchBar || {}));
|
||||||
|
});
|
||||||
445
apps/common/main/lib/view/SearchPanel.js
Normal file
|
|
@ -0,0 +1,445 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2019
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha
|
||||||
|
* street, Riga, Latvia, EU, LV-1050.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* User: Julia.Svinareva
|
||||||
|
* Date: 11.02.2022
|
||||||
|
*/
|
||||||
|
|
||||||
|
define([
|
||||||
|
'text!common/main/lib/template/SearchPanel.template',
|
||||||
|
'common/main/lib/util/utils',
|
||||||
|
'common/main/lib/component/BaseView',
|
||||||
|
'common/main/lib/component/Layout'
|
||||||
|
], function (template) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
Common.Views.SearchPanel = Common.UI.BaseView.extend(_.extend({
|
||||||
|
el: '#left-panel-search',
|
||||||
|
template: _.template(template),
|
||||||
|
|
||||||
|
initialize: function(options) {
|
||||||
|
_.extend(this, options);
|
||||||
|
Common.UI.BaseView.prototype.initialize.call(this, arguments);
|
||||||
|
|
||||||
|
this.mode = false;
|
||||||
|
|
||||||
|
window.SSE && (this.extendedOptions = Common.localStorage.getBool('sse-search-options-extended', true));
|
||||||
|
},
|
||||||
|
|
||||||
|
render: function(el) {
|
||||||
|
var me = this;
|
||||||
|
if (!this.rendered) {
|
||||||
|
el = el || this.el;
|
||||||
|
$(el).html(this.template({
|
||||||
|
scope: this
|
||||||
|
}));
|
||||||
|
this.$el = $(el);
|
||||||
|
|
||||||
|
this.inputText = new Common.UI.InputField({
|
||||||
|
el: $('#search-adv-text'),
|
||||||
|
placeHolder: this.textFind,
|
||||||
|
allowBlank: true,
|
||||||
|
validateOnBlur: false,
|
||||||
|
style: 'width: 100%;',
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'left',
|
||||||
|
dataHintOffset: 'small'
|
||||||
|
});
|
||||||
|
this.inputText._input.on('input', _.bind(function () {
|
||||||
|
this.fireEvent('search:input', [this.inputText._input.val()]);
|
||||||
|
}, this)).on('keydown', _.bind(function (e) {
|
||||||
|
this.fireEvent('search:keydown', [this.inputText._input.val(), e]);
|
||||||
|
}, this));
|
||||||
|
|
||||||
|
this.inputReplace = new Common.UI.InputField({
|
||||||
|
el: $('#search-adv-replace-text'),
|
||||||
|
placeHolder: this.textReplaceWith,
|
||||||
|
allowBlank: true,
|
||||||
|
validateOnBlur: false,
|
||||||
|
style: 'width: 100%;',
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'left',
|
||||||
|
dataHintOffset: 'small'
|
||||||
|
});
|
||||||
|
this.inputReplace._input.on('keydown', _.bind(function (e) {
|
||||||
|
if (e.keyCode === Common.UI.Keys.RETURN && !this.btnReplace.isDisabled()) {
|
||||||
|
this.onReplaceClick('replace');
|
||||||
|
}
|
||||||
|
}, this));
|
||||||
|
|
||||||
|
this.btnBack = new Common.UI.Button({
|
||||||
|
parentEl: $('#search-adv-back'),
|
||||||
|
cls: 'btn-toolbar',
|
||||||
|
iconCls: 'toolbar__icon btn-arrow-up',
|
||||||
|
hint: this.tipPreviousResult,
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'bottom'
|
||||||
|
});
|
||||||
|
this.btnBack.on('click', _.bind(this.onBtnNextClick, this, 'back'));
|
||||||
|
|
||||||
|
this.btnNext = new Common.UI.Button({
|
||||||
|
parentEl: $('#search-adv-next'),
|
||||||
|
cls: 'btn-toolbar',
|
||||||
|
iconCls: 'toolbar__icon btn-arrow-down',
|
||||||
|
hint: this.tipNextResult,
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'bottom'
|
||||||
|
});
|
||||||
|
this.btnNext.on('click', _.bind(this.onBtnNextClick, this, 'next'));
|
||||||
|
|
||||||
|
this.btnReplace = new Common.UI.Button({
|
||||||
|
el: $('#search-adv-replace')
|
||||||
|
});
|
||||||
|
this.btnReplace.on('click', _.bind(this.onReplaceClick, this, 'replace'));
|
||||||
|
|
||||||
|
this.btnReplaceAll = new Common.UI.Button({
|
||||||
|
el: $('#search-adv-replace-all')
|
||||||
|
});
|
||||||
|
this.btnReplaceAll.on('click', _.bind(this.onReplaceClick, this, 'replaceall'));
|
||||||
|
|
||||||
|
this.$reaultsNumber = $('#search-adv-results-number');
|
||||||
|
this.updateResultsNumber('no-results');
|
||||||
|
|
||||||
|
this.chCaseSensitive = new Common.UI.CheckBox({
|
||||||
|
el: $('#search-adv-case-sensitive'),
|
||||||
|
labelText: this.textCaseSensitive,
|
||||||
|
value: false,
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'left',
|
||||||
|
dataHintOffset: 'small'
|
||||||
|
}).on('change', function(field) {
|
||||||
|
me.fireEvent('search:options', ['case-sensitive', field.getValue() === 'checked']);
|
||||||
|
});
|
||||||
|
|
||||||
|
/*this.chUseRegExp = new Common.UI.CheckBox({
|
||||||
|
el: $('#search-adv-use-regexp'),
|
||||||
|
labelText: this.textMatchUsingRegExp,
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'left',
|
||||||
|
dataHintOffset: 'small'
|
||||||
|
}).on('change', function(field) {
|
||||||
|
me.fireEvent('search:options', ['regexp', field.getValue() === 'checked']);
|
||||||
|
});*/
|
||||||
|
|
||||||
|
this.chMatchWord = new Common.UI.CheckBox({
|
||||||
|
el: $('#search-adv-match-word'),
|
||||||
|
labelText: window.SSE ? this.textItemEntireCell : this.textWholeWords,
|
||||||
|
value: false,
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'left',
|
||||||
|
dataHintOffset: 'small'
|
||||||
|
}).on('change', function(field) {
|
||||||
|
me.fireEvent('search:options', ['match-word', field.getValue() === 'checked']);
|
||||||
|
});
|
||||||
|
|
||||||
|
this.buttonClose = new Common.UI.Button({
|
||||||
|
parentEl: $('#search-btn-close', this.$el),
|
||||||
|
cls: 'btn-toolbar',
|
||||||
|
iconCls: 'toolbar__icon btn-close',
|
||||||
|
hint: this.textCloseSearch,
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'bottom',
|
||||||
|
dataHintOffset: 'medium'
|
||||||
|
});
|
||||||
|
this.buttonClose.on('click', _.bind(this.onClickClosePanel, this));
|
||||||
|
|
||||||
|
this.$resultsContainer = $('#search-results');
|
||||||
|
this.$resultsContainer.hide();
|
||||||
|
|
||||||
|
Common.NotificationCenter.on('search:updateresults', _.bind(this.disableNavButtons, this));
|
||||||
|
if (window.SSE) {
|
||||||
|
this.cmbWithin = new Common.UI.ComboBox({
|
||||||
|
el: $('#search-adv-cmb-within'),
|
||||||
|
menuStyle: 'min-width: 100%;',
|
||||||
|
style: "width: 219px;",
|
||||||
|
editable: false,
|
||||||
|
cls: 'input-group-nr',
|
||||||
|
data: [
|
||||||
|
{ value: 0, displayValue: this.textSheet },
|
||||||
|
{ value: 1, displayValue: this.textWorkbook },
|
||||||
|
{ value: 2, displayValue: this.textSpecificRange}
|
||||||
|
],
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'bottom',
|
||||||
|
dataHintOffset: 'big'
|
||||||
|
}).on('selected', function(combo, record) {
|
||||||
|
me.fireEvent('search:options', ['within', record.value]);
|
||||||
|
});
|
||||||
|
|
||||||
|
this.inputSelectRange = new Common.UI.InputFieldBtn({
|
||||||
|
el: $('#search-adv-select-range'),
|
||||||
|
placeHolder: this.textSelectDataRange,
|
||||||
|
allowBlank: true,
|
||||||
|
validateOnChange: true,
|
||||||
|
validateOnBlur: true,
|
||||||
|
style: "width: 219px; margin-top: 8px",
|
||||||
|
disabled: true,
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'left',
|
||||||
|
dataHintOffset: 'small'
|
||||||
|
}).on('keyup:after', function(input, e) {
|
||||||
|
me.fireEvent('search:options', ['range', input.getValue(), e.keyCode !== Common.UI.Keys.RETURN]);
|
||||||
|
});
|
||||||
|
this.inputSelectRange.$el.hide();
|
||||||
|
|
||||||
|
this.cmbSearch = new Common.UI.ComboBox({
|
||||||
|
el: $('#search-adv-cmb-search'),
|
||||||
|
menuStyle: 'min-width: 100%;',
|
||||||
|
style: "width: 219px;",
|
||||||
|
editable: false,
|
||||||
|
cls: 'input-group-nr',
|
||||||
|
data: [
|
||||||
|
{ value: 0, displayValue: this.textByRows },
|
||||||
|
{ value: 1, displayValue: this.textByColumns }
|
||||||
|
],
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'bottom',
|
||||||
|
dataHintOffset: 'big'
|
||||||
|
}).on('selected', function(combo, record) {
|
||||||
|
me.fireEvent('search:options', ['search', !record.value]);
|
||||||
|
});
|
||||||
|
|
||||||
|
this.cmbLookIn = new Common.UI.ComboBox({
|
||||||
|
el: $('#search-adv-cmb-look-in'),
|
||||||
|
menuStyle: 'min-width: 100%;',
|
||||||
|
style: "width: 219px;",
|
||||||
|
editable: false,
|
||||||
|
cls: 'input-group-nr',
|
||||||
|
data: [
|
||||||
|
{ value: 0, displayValue: this.textFormulas },
|
||||||
|
{ value: 1, displayValue: this.textValues }
|
||||||
|
],
|
||||||
|
dataHint: '1',
|
||||||
|
dataHintDirection: 'bottom',
|
||||||
|
dataHintOffset: 'big'
|
||||||
|
}).on('selected', function(combo, record) {
|
||||||
|
me.fireEvent('search:options', ['lookIn', !record.value]);
|
||||||
|
});
|
||||||
|
|
||||||
|
this.$searchOptionsBlock = $('.search-options-block');
|
||||||
|
this.$searchOptionsBlock.show();
|
||||||
|
$('#open-search-options').on('click', _.bind(this.expandSearchOptions, this));
|
||||||
|
|
||||||
|
if (!this.extendedOptions) {
|
||||||
|
this.$searchOptionsBlock.addClass('no-expand');
|
||||||
|
}
|
||||||
|
|
||||||
|
this.cmbWithin.setValue(0);
|
||||||
|
this.cmbSearch.setValue(0);
|
||||||
|
this.cmbLookIn.setValue(0);
|
||||||
|
|
||||||
|
var tableTemplate = '<div class="search-table">' +
|
||||||
|
'<div class="header-items">' +
|
||||||
|
'<div class="header-item">' + this.textSheet + '</div>' +
|
||||||
|
'<div class="header-item">' + this.textName + '</div>' +
|
||||||
|
'<div class="header-item">' + this.textCell + '</div>' +
|
||||||
|
'<div class="header-item">' + this.textValue + '</div>' +
|
||||||
|
'<div class="header-item">' + this.textFormula + '</div>' +
|
||||||
|
'</div>' +
|
||||||
|
'<div class="ps-container oo search-items"></div>' +
|
||||||
|
'</div>',
|
||||||
|
$resultTable = $(tableTemplate).appendTo(this.$resultsContainer);
|
||||||
|
this.$resultsContainer.scroller = new Common.UI.Scroller({
|
||||||
|
el: $resultTable.find('.search-items'),
|
||||||
|
includePadding: true,
|
||||||
|
useKeyboard: true,
|
||||||
|
minScrollbarLength: 40,
|
||||||
|
alwaysVisibleY: true
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
this.$resultsContainer.scroller = new Common.UI.Scroller({
|
||||||
|
el: this.$resultsContainer,
|
||||||
|
includePadding: true,
|
||||||
|
useKeyboard: true,
|
||||||
|
minScrollbarLength: 40,
|
||||||
|
alwaysVisibleY: true
|
||||||
|
});
|
||||||
|
}
|
||||||
|
Common.NotificationCenter.on('window:resize', function() {
|
||||||
|
me.updateResultsContainerHeight();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.rendered = true;
|
||||||
|
this.trigger('render:after', this);
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
show: function () {
|
||||||
|
Common.UI.BaseView.prototype.show.call(this,arguments);
|
||||||
|
this.fireEvent('show', this );
|
||||||
|
|
||||||
|
this.updateResultsContainerHeight();
|
||||||
|
},
|
||||||
|
|
||||||
|
hide: function () {
|
||||||
|
Common.UI.BaseView.prototype.hide.call(this,arguments);
|
||||||
|
this.fireEvent('hide', this );
|
||||||
|
},
|
||||||
|
|
||||||
|
focus: function(type) {
|
||||||
|
var me = this,
|
||||||
|
el = type === 'replace' ? me.inputReplace.$el : (type === 'range' ? me.inputSelectRange.$el : me.inputText.$el);
|
||||||
|
setTimeout(function(){
|
||||||
|
el.find('input').focus();
|
||||||
|
el.find('input').select();
|
||||||
|
}, 10);
|
||||||
|
},
|
||||||
|
|
||||||
|
setSearchMode: function (mode) {
|
||||||
|
if (this.mode !== mode) {
|
||||||
|
this.$el.find('.edit-setting')[mode !== 'no-replace' ? 'show' : 'hide']();
|
||||||
|
this.$el.find('#search-adv-title').text(mode !== 'no-replace' ? this.textFindAndReplace : this.textFind);
|
||||||
|
this.mode = mode;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
ChangeSettings: function(props) {
|
||||||
|
},
|
||||||
|
|
||||||
|
updateResultsContainerHeight: function () {
|
||||||
|
if (this.$resultsContainer) {
|
||||||
|
this.$resultsContainer.outerHeight($('#search-box').outerHeight() - $('#search-header').outerHeight() - $('#search-adv-settings').outerHeight());
|
||||||
|
this.$resultsContainer.scroller.update({alwaysVisibleY: true});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
updateResultsNumber: function (current, count) {
|
||||||
|
var text;
|
||||||
|
if (count > 300) {
|
||||||
|
text = this.textTooManyResults;
|
||||||
|
} else {
|
||||||
|
text = current === 'no-results' ? this.textNoSearchResults :
|
||||||
|
(current === 'stop' ? this.textSearchHasStopped :
|
||||||
|
(current === 'content-changed' ? (this.textContentChanged + ' ' + Common.Utils.String.format(this.textSearchAgain, '<a class="search-again">','</a>')) :
|
||||||
|
(!count ? this.textNoMatches : Common.Utils.String.format(this.textSearchResults, current + 1, count))));
|
||||||
|
}
|
||||||
|
if (current === 'content-changed') {
|
||||||
|
var me = this;
|
||||||
|
this.$reaultsNumber.html(text);
|
||||||
|
this.$reaultsNumber.find('.search-again').on('click', function () {
|
||||||
|
me.fireEvent('search:next', [me.inputText.getValue(), true]);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
this.$reaultsNumber.text(text);
|
||||||
|
}
|
||||||
|
this.updateResultsContainerHeight();
|
||||||
|
!window.SSE && this.disableReplaceButtons(!count);
|
||||||
|
},
|
||||||
|
|
||||||
|
onClickClosePanel: function() {
|
||||||
|
Common.NotificationCenter.trigger('leftmenu:change', 'hide');
|
||||||
|
this.fireEvent('hide', this );
|
||||||
|
},
|
||||||
|
|
||||||
|
onBtnNextClick: function (action) {
|
||||||
|
this.fireEvent('search:'+action, [this.inputText.getValue(), true]);
|
||||||
|
},
|
||||||
|
|
||||||
|
onReplaceClick: function (action) {
|
||||||
|
this.fireEvent('search:'+action, [this.inputText.getValue(), this.inputReplace.getValue()]);
|
||||||
|
},
|
||||||
|
|
||||||
|
getSettings: function() {
|
||||||
|
return {
|
||||||
|
textsearch: this.inputText.getValue(),
|
||||||
|
matchcase: this.chCaseSensitive.checked,
|
||||||
|
matchword: this.chMatchWord.checked
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
expandSearchOptions: function () {
|
||||||
|
this.extendedOptions = !this.extendedOptions;
|
||||||
|
this.$searchOptionsBlock[this.extendedOptions ? 'removeClass' : 'addClass']('no-expand');
|
||||||
|
Common.localStorage.setBool('sse-search-options-extended', this.extendedOptions);
|
||||||
|
|
||||||
|
this.updateResultsContainerHeight();
|
||||||
|
},
|
||||||
|
|
||||||
|
setFindText: function (val) {
|
||||||
|
this.inputText.setValue(val);
|
||||||
|
},
|
||||||
|
|
||||||
|
clearResultsNumber: function () {
|
||||||
|
this.updateResultsNumber('no-results');
|
||||||
|
},
|
||||||
|
|
||||||
|
disableNavButtons: function (resultNumber, allResults) {
|
||||||
|
var disable = (this.inputText._input.val() === '' && !window.SSE) || !allResults;
|
||||||
|
this.btnBack.setDisabled(disable);
|
||||||
|
this.btnNext.setDisabled(disable);
|
||||||
|
},
|
||||||
|
|
||||||
|
disableReplaceButtons: function (disable) {
|
||||||
|
this.btnReplace.setDisabled(disable);
|
||||||
|
this.btnReplaceAll.setDisabled(disable);
|
||||||
|
},
|
||||||
|
|
||||||
|
textFind: 'Find',
|
||||||
|
textFindAndReplace: 'Find and replace',
|
||||||
|
textCloseSearch: 'Close search',
|
||||||
|
textReplace: 'Replace',
|
||||||
|
textReplaceAll: 'Replace All',
|
||||||
|
textSearchResults: 'Search results: {0}/{1}',
|
||||||
|
textReplaceWith: 'Replace with',
|
||||||
|
textCaseSensitive: 'Case sensitive',
|
||||||
|
textMatchUsingRegExp: 'Match using regular expressions',
|
||||||
|
textWholeWords: 'Whole words only',
|
||||||
|
textWithin: 'Within',
|
||||||
|
textSelectDataRange: 'Select Data range',
|
||||||
|
textSearch: 'Search',
|
||||||
|
textLookIn: 'Look in',
|
||||||
|
textSheet: 'Sheet',
|
||||||
|
textWorkbook: 'Workbook',
|
||||||
|
textSpecificRange: 'Specific range',
|
||||||
|
textByRows: 'By rows',
|
||||||
|
textByColumns: 'By columns',
|
||||||
|
textFormulas: 'Formulas',
|
||||||
|
textValues: 'Values',
|
||||||
|
textSearchOptions: 'Search options',
|
||||||
|
textNoMatches: 'No matches',
|
||||||
|
textNoSearchResults: 'No search results',
|
||||||
|
textItemEntireCell: 'Entire cell contents',
|
||||||
|
textTooManyResults: 'There are too many results to show here',
|
||||||
|
tipPreviousResult: 'Previous result',
|
||||||
|
tipNextResult: 'Next result',
|
||||||
|
textName: 'Name',
|
||||||
|
textCell: 'Cell',
|
||||||
|
textValue: 'Value',
|
||||||
|
textFormula: 'Formula',
|
||||||
|
textSearchHasStopped: 'Search has stopped',
|
||||||
|
textContentChanged: 'Document changed.',
|
||||||
|
textSearchAgain: '{0}Perform new search{1} for accurate results.'
|
||||||
|
|
||||||
|
}, Common.Views.SearchPanel || {}));
|
||||||
|
});
|
||||||
|
|
@ -430,7 +430,7 @@ define([
|
||||||
'<table cols="1" style="width: 100%;">',
|
'<table cols="1" style="width: 100%;">',
|
||||||
'<tr>',
|
'<tr>',
|
||||||
'<td style="padding-bottom: 16px;">',
|
'<td style="padding-bottom: 16px;">',
|
||||||
'<div id="symbol-table-scrollable-div" style="position: relative;height:'+ (this.options.height-302 + 38*(this.special ? 0 : 1)) + 'px;">',
|
'<div id="symbol-table-scrollable-div" style="position: relative;height:'+ (this.options.height-304 + 38*(this.special ? 0 : 1)) + 'px;">',
|
||||||
'<div style="width: 100%;">',
|
'<div style="width: 100%;">',
|
||||||
'<div id="id-preview">',
|
'<div id="id-preview">',
|
||||||
'<div>',
|
'<div>',
|
||||||
|
|
@ -476,7 +476,7 @@ define([
|
||||||
'</tr>',
|
'</tr>',
|
||||||
'<tr>',
|
'<tr>',
|
||||||
'<td>',
|
'<td>',
|
||||||
'<div id="symbol-table-special-list" class="no-borders" style="width:100%; height: '+ (this.options.height-156 + 38*(this.special ? 0 : 1)) + 'px;"></div>',
|
'<div id="symbol-table-special-list" class="no-borders" style="width:100%; height: '+ (this.options.height-157 + 38*(this.special ? 0 : 1)) + 'px;"></div>',
|
||||||
'</td>',
|
'</td>',
|
||||||
'</tr>',
|
'</tr>',
|
||||||
'</table>',
|
'</table>',
|
||||||
|
|
@ -1104,7 +1104,7 @@ define([
|
||||||
},
|
},
|
||||||
|
|
||||||
getMaxHeight: function(){
|
getMaxHeight: function(){
|
||||||
return this.symbolTablePanel.innerHeight();
|
return this.symbolTablePanel.innerHeight()-2;
|
||||||
},
|
},
|
||||||
|
|
||||||
getRowsCount: function() {
|
getRowsCount: function() {
|
||||||
|
|
@ -1436,8 +1436,8 @@ define([
|
||||||
this.curSize = {resize: false, width: size[0], height: size[1]};
|
this.curSize = {resize: false, width: size[0], height: size[1]};
|
||||||
} else if (this.curSize.resize) {
|
} else if (this.curSize.resize) {
|
||||||
this._preventUpdateScroll = false;
|
this._preventUpdateScroll = false;
|
||||||
this.curSize.height = size[1] - 302 + 38*(this.special ? 0 : 1);
|
this.curSize.height = size[1] - 304 + 38*(this.special ? 0 : 1);
|
||||||
var rows = Math.max(1, ((this.curSize.height/CELL_HEIGHT) >> 0)),
|
var rows = Math.max(1, (((this.curSize.height-2)/CELL_HEIGHT) >> 0)),
|
||||||
height = rows*CELL_HEIGHT;
|
height = rows*CELL_HEIGHT;
|
||||||
|
|
||||||
this.symbolTablePanel.css({'height': this.curSize.height + 'px'});
|
this.symbolTablePanel.css({'height': this.curSize.height + 'px'});
|
||||||
|
|
@ -1447,7 +1447,7 @@ define([
|
||||||
|
|
||||||
this.updateView(undefined, undefined, undefined, true);
|
this.updateView(undefined, undefined, undefined, true);
|
||||||
|
|
||||||
this.specialList.cmpEl.height(size[1] - 156 + 38*(this.special ? 0 : 1));
|
this.specialList.cmpEl.height(size[1] - 157 + 38*(this.special ? 0 : 1));
|
||||||
|
|
||||||
!this.special && (size[1] += 38);
|
!this.special && (size[1] += 38);
|
||||||
var valJson = JSON.stringify(size);
|
var valJson = JSON.stringify(size);
|
||||||
|
|
@ -1465,16 +1465,16 @@ define([
|
||||||
this.curSize.resize = true;
|
this.curSize.resize = true;
|
||||||
|
|
||||||
this.curSize.width = size[0];
|
this.curSize.width = size[0];
|
||||||
this.curSize.height = size[1] - 302 + 38*(this.special ? 0 : 1);
|
this.curSize.height = size[1] - 304 + 38*(this.special ? 0 : 1);
|
||||||
|
|
||||||
var rows = Math.max(1, ((this.curSize.height/CELL_HEIGHT) >> 0)),
|
var rows = Math.max(1, (((this.curSize.height-2)/CELL_HEIGHT) >> 0)),
|
||||||
height = rows*CELL_HEIGHT;
|
height = rows*CELL_HEIGHT;
|
||||||
|
|
||||||
this.symbolTablePanel.css({'height': this.curSize.height + 'px'});
|
this.symbolTablePanel.css({'height': this.curSize.height + 'px'});
|
||||||
this.previewPanel.css({'height': height + 'px'});
|
this.previewPanel.css({'height': height + 'px'});
|
||||||
this.previewScrolled.css({'height': height + 'px'});
|
this.previewScrolled.css({'height': height + 'px'});
|
||||||
|
|
||||||
this.specialList.cmpEl.height(size[1] - 156 + 38*(this.special ? 0 : 1));
|
this.specialList.cmpEl.height(size[1] - 157 + 38*(this.special ? 0 : 1));
|
||||||
|
|
||||||
this.updateView(undefined, undefined, undefined, true);
|
this.updateView(undefined, undefined, undefined, true);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
Before Width: | Height: | Size: 8.6 KiB After Width: | Height: | Size: 8.6 KiB |
|
Before Width: | Height: | Size: 6.2 KiB After Width: | Height: | Size: 6.2 KiB |
|
Before Width: | Height: | Size: 49 KiB After Width: | Height: | Size: 49 KiB |
|
Before Width: | Height: | Size: 28 KiB After Width: | Height: | Size: 28 KiB |
|
Before Width: | Height: | Size: 56 KiB After Width: | Height: | Size: 56 KiB |
|
Before Width: | Height: | Size: 42 KiB After Width: | Height: | Size: 42 KiB |
|
Before Width: | Height: | Size: 33 KiB After Width: | Height: | Size: 33 KiB |
|
Before Width: | Height: | Size: 59 KiB After Width: | Height: | Size: 59 KiB |
|
Before Width: | Height: | Size: 36 KiB After Width: | Height: | Size: 36 KiB |
|
Before Width: | Height: | Size: 55 KiB After Width: | Height: | Size: 55 KiB |
|
Before Width: | Height: | Size: 59 KiB After Width: | Height: | Size: 59 KiB |
|
Before Width: | Height: | Size: 55 KiB After Width: | Height: | Size: 55 KiB |
|
Before Width: | Height: | Size: 46 KiB After Width: | Height: | Size: 46 KiB |
|
Before Width: | Height: | Size: 18 KiB After Width: | Height: | Size: 18 KiB |
|
Before Width: | Height: | Size: 3.7 KiB After Width: | Height: | Size: 3.7 KiB |
|
Before Width: | Height: | Size: 5.3 KiB After Width: | Height: | Size: 5.3 KiB |
|
Before Width: | Height: | Size: 4.1 KiB After Width: | Height: | Size: 4.1 KiB |
|
Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 13 KiB |
|
Before Width: | Height: | Size: 9.5 KiB After Width: | Height: | Size: 9.5 KiB |
|
Before Width: | Height: | Size: 305 B After Width: | Height: | Size: 305 B |
|
Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 13 KiB |
|
Before Width: | Height: | Size: 7.5 KiB After Width: | Height: | Size: 7.5 KiB |
|
Before Width: | Height: | Size: 26 KiB After Width: | Height: | Size: 26 KiB |
23
apps/common/main/resources/help/download.html
Normal file
|
|
@ -0,0 +1,23 @@
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
font-family: Arial,Helvetica,"Helvetica Neue",sans-serif;
|
||||||
|
color: #444;
|
||||||
|
}
|
||||||
|
.centered {
|
||||||
|
text-align: center;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: center;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="centered">
|
||||||
|
<h1>There is no help installed</h1>
|
||||||
|
<h2>please, download it from <a href='#'>www.onlyoffice.com</a></h1>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
Before Width: | Height: | Size: 15 KiB After Width: | Height: | Size: 15 KiB |
|
Before Width: | Height: | Size: 5.5 KiB After Width: | Height: | Size: 5.5 KiB |
|
Before Width: | Height: | Size: 16 KiB After Width: | Height: | Size: 16 KiB |
|
Before Width: | Height: | Size: 7.3 KiB After Width: | Height: | Size: 7.3 KiB |
|
Before Width: | Height: | Size: 52 KiB After Width: | Height: | Size: 52 KiB |
|
Before Width: | Height: | Size: 10 KiB After Width: | Height: | Size: 10 KiB |
|
Before Width: | Height: | Size: 8.2 KiB After Width: | Height: | Size: 8.2 KiB |
|
Before Width: | Height: | Size: 14 KiB After Width: | Height: | Size: 14 KiB |
|
Before Width: | Height: | Size: 9.4 KiB After Width: | Height: | Size: 9.4 KiB |
|
Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 13 KiB |
|
Before Width: | Height: | Size: 14 KiB After Width: | Height: | Size: 14 KiB |
|
Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 13 KiB |