2227 lines
95 KiB
JavaScript
2227 lines
95 KiB
JavaScript
|
/*
|
|||
|
* (c) Copyright Ascensio System SIA 2010-2014
|
|||
|
*
|
|||
|
* This program is a free software product. You can redistribute it and/or
|
|||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
|||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
|||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
|||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
|||
|
* of any third-party rights.
|
|||
|
*
|
|||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
|||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
|||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
|||
|
*
|
|||
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
|||
|
* EU, LV-1021.
|
|||
|
*
|
|||
|
* The interactive user interfaces in modified source and object code versions
|
|||
|
* of the Program must display Appropriate Legal Notices, as required under
|
|||
|
* Section 5 of the GNU AGPL version 3.
|
|||
|
*
|
|||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
|||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
|||
|
* grant you any rights under trademark law for use of our trademarks.
|
|||
|
*
|
|||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
|||
|
* well as technical writing content are licensed under the terms of the
|
|||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
|||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
|||
|
*
|
|||
|
*/
|
|||
|
Ext.define("DE.view.Toolbar", {
|
|||
|
extend: "Ext.toolbar.Toolbar",
|
|||
|
alias: "widget.detoolbar",
|
|||
|
cls: "de-toolbar",
|
|||
|
height: 68,
|
|||
|
minWidth: 1175,
|
|||
|
_state: {
|
|||
|
clrhighlight: undefined,
|
|||
|
clrtext: undefined
|
|||
|
},
|
|||
|
layout: {
|
|||
|
type: "hbox",
|
|||
|
align: "middle"
|
|||
|
},
|
|||
|
requires: ["Ext.data.Store", "Ext.data.Model", "Common.component.MenuDataViewPicker", "Common.component.SplitColorButton", "Common.component.ComboDataView", "DE.component.DimensionPicker", "Common.plugin.ComboBoxScrollPane", "Ext.form.field.ComboBox", "Common.view.ComboFonts", "Ext.Array", "Ext.util.Cookies", "Common.component.SynchronizeTip", "Common.component.ThemeColorPalette", "Common.plugin.MenuExpand", "Ext.util.Cookies"],
|
|||
|
constructor: function (config) {
|
|||
|
this.initConfig(config);
|
|||
|
this.callParent(arguments);
|
|||
|
return this;
|
|||
|
},
|
|||
|
initComponent: function () {
|
|||
|
var me = this;
|
|||
|
this.addEvents("editcomplete");
|
|||
|
this.addEvents("inserttable", "insertimage", "insertshape");
|
|||
|
this.paragraphControls = [];
|
|||
|
this.synchTooltip = undefined;
|
|||
|
this.ThemeValues = [6, 15, 7, 16, 0, 1, 2, 3, 4, 5];
|
|||
|
this.SchemeNames = [this.txtScheme1, this.txtScheme2, this.txtScheme3, this.txtScheme4, this.txtScheme5, this.txtScheme6, this.txtScheme7, this.txtScheme8, this.txtScheme9, this.txtScheme10, this.txtScheme11, this.txtScheme12, this.txtScheme13, this.txtScheme14, this.txtScheme15, this.txtScheme16, this.txtScheme17, this.txtScheme18, this.txtScheme19, this.txtScheme20, this.txtScheme21];
|
|||
|
var hidetip = window.localStorage.getItem("de-hide-synch");
|
|||
|
this.showSynchTip = !(hidetip && parseInt(hidetip) == 1);
|
|||
|
this.needShowSynchTip = false;
|
|||
|
this.cmbFont = Ext.create("Common.view.ComboFonts", {
|
|||
|
id: "toolbar-combo-fonts",
|
|||
|
margin: "0 4 0 0",
|
|||
|
width: 128,
|
|||
|
cls: "asc-toolbar-combo",
|
|||
|
editable: true,
|
|||
|
selectOnFocus: true,
|
|||
|
tooltip: this.tipFontName,
|
|||
|
showlastused: true,
|
|||
|
enableKeyEvents: true,
|
|||
|
preventMark: true,
|
|||
|
validateOnBlur: false,
|
|||
|
validateOnChange: false,
|
|||
|
plugins: [{
|
|||
|
ptype: "comboboxscrollpane",
|
|||
|
pluginId: "scrollpane",
|
|||
|
settings: {
|
|||
|
enableKeyboardNavigation: true
|
|||
|
}
|
|||
|
}]
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.cmbFont);
|
|||
|
Ext.define("DE.view.FontSize", {
|
|||
|
extend: "Ext.data.Model",
|
|||
|
fields: [{
|
|||
|
type: "int",
|
|||
|
name: "sizevalue"
|
|||
|
},
|
|||
|
{
|
|||
|
type: "string",
|
|||
|
name: "sizestring"
|
|||
|
}]
|
|||
|
});
|
|||
|
var storesize = Ext.create("Ext.data.Store", {
|
|||
|
model: "DE.view.FontSize",
|
|||
|
data: []
|
|||
|
});
|
|||
|
this.cmbFontSize = Ext.create("Ext.form.field.ComboBox", {
|
|||
|
id: "toolbar-combo-font-size",
|
|||
|
store: storesize,
|
|||
|
displayField: "sizestring",
|
|||
|
queryMode: "local",
|
|||
|
typeAhead: false,
|
|||
|
selectOnFocus: true,
|
|||
|
margin: "0 4 0 0",
|
|||
|
width: 60,
|
|||
|
cls: "asc-toolbar-combo",
|
|||
|
listConfig: {
|
|||
|
maxHeight: 400
|
|||
|
},
|
|||
|
preventMark: true,
|
|||
|
validateOnBlur: false,
|
|||
|
validateOnChange: false,
|
|||
|
listeners: {
|
|||
|
render: {
|
|||
|
fn: function (cmp) {
|
|||
|
cmp.el.set({
|
|||
|
"data-qtip": me.tipFontSize
|
|||
|
});
|
|||
|
cmp.validate();
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.cmbFontSize);
|
|||
|
this.btnBold = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-bold",
|
|||
|
tooltip: this.textBold + " (Ctrl+B)",
|
|||
|
iconCls: "asc-toolbar-btn btn-bold",
|
|||
|
enableToggle: true
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnBold);
|
|||
|
this.btnItalic = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-italic",
|
|||
|
tooltip: this.textItalic + " (Ctrl+I)",
|
|||
|
iconCls: "asc-toolbar-btn btn-italic",
|
|||
|
enableToggle: true
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnItalic);
|
|||
|
this.btnUnderline = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-underline",
|
|||
|
tooltip: this.textUnderline + " (Ctrl+U)",
|
|||
|
iconCls: "asc-toolbar-btn btn-underline",
|
|||
|
enableToggle: true
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnUnderline);
|
|||
|
this.btnStrikeout = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-strikeout",
|
|||
|
tooltip: this.textStrikeout,
|
|||
|
iconCls: "asc-toolbar-btn btn-strike",
|
|||
|
enableToggle: true
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnStrikeout);
|
|||
|
this.btnSuperscript = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-superscript",
|
|||
|
tooltip: this.textSuperscript,
|
|||
|
iconCls: "asc-toolbar-btn btn-superscript",
|
|||
|
enableToggle: true,
|
|||
|
toggleGroup: "subscriptGroup"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnSuperscript);
|
|||
|
this.btnSubscript = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-subscript",
|
|||
|
tooltip: this.textSubscript,
|
|||
|
iconCls: "asc-toolbar-btn btn-subscript",
|
|||
|
enableToggle: true,
|
|||
|
toggleGroup: "subscriptGroup"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnSubscript);
|
|||
|
this.btnPrint = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-print",
|
|||
|
tooltip: this.tipPrint + " (Ctrl+P)",
|
|||
|
iconCls: "asc-toolbar-btn btn-print"
|
|||
|
});
|
|||
|
this.btnSave = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-save",
|
|||
|
tooltip: this.tipSave + " (Ctrl+S)",
|
|||
|
iconCls: "asc-toolbar-btn btn-save"
|
|||
|
});
|
|||
|
this.btnCopy = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-copy",
|
|||
|
tooltip: this.tipCopy + " (Ctrl+C)",
|
|||
|
iconCls: "asc-toolbar-btn btn-copy"
|
|||
|
});
|
|||
|
this.btnPaste = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-paste",
|
|||
|
tooltip: this.tipPaste + " (Ctrl+V)",
|
|||
|
iconCls: "asc-toolbar-btn btn-paste"
|
|||
|
});
|
|||
|
this.btnUndo = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-undo",
|
|||
|
tooltip: this.tipUndo + " (Ctrl+Z)",
|
|||
|
iconCls: "asc-toolbar-btn btn-undo"
|
|||
|
});
|
|||
|
this.btnRedo = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-redo",
|
|||
|
tooltip: this.tipRedo + " (Ctrl+Y)",
|
|||
|
iconCls: "asc-toolbar-btn btn-redo"
|
|||
|
});
|
|||
|
this.btnIncFontSize = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-increase-font",
|
|||
|
tooltip: this.tipIncFont + " (Ctrl+])",
|
|||
|
iconCls: "asc-toolbar-btn btn-incfont"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnIncFontSize);
|
|||
|
this.btnDecFontSize = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-decrease-font",
|
|||
|
tooltip: this.tipDecFont + " (Ctrl+[)",
|
|||
|
iconCls: "asc-toolbar-btn btn-decfont"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnDecFontSize);
|
|||
|
function _setMarkerColor(strcolor, h) {
|
|||
|
if (h === "menu") {
|
|||
|
me.mnuHighlightTransparent.setChecked(false);
|
|||
|
me.btnHighlightColor.setColor(strcolor);
|
|||
|
me.btnHighlightColor.toggle(true, true);
|
|||
|
Ext.menu.Manager.hideAll();
|
|||
|
}
|
|||
|
if (strcolor == "transparent") {
|
|||
|
me.api.SetMarkerFormat(true, false);
|
|||
|
} else {
|
|||
|
var r = strcolor[0] + strcolor[1],
|
|||
|
g = strcolor[2] + strcolor[3],
|
|||
|
b = strcolor[4] + strcolor[5];
|
|||
|
me.api.SetMarkerFormat(true, true, parseInt(r, 16), parseInt(g, 16), parseInt(b, 16));
|
|||
|
}
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
Common.component.Analytics.trackEvent("ToolBar", "Highlight Color");
|
|||
|
}
|
|||
|
this._clearColorPalette = function (picker) {
|
|||
|
if (picker && picker.getEl()) {
|
|||
|
picker.getEl().down("a.color-" + picker.getValue()).removeCls(picker.selectedCls);
|
|||
|
}
|
|||
|
};
|
|||
|
this.btnHighlightColor = Ext.widget("cmdsplitcolorbutton", {
|
|||
|
id: "toolbar-button-highlight-color",
|
|||
|
tooltip: this.tipHighlightColor,
|
|||
|
color: "FFFF00",
|
|||
|
horizontalOffset: 4,
|
|||
|
verticalOffset: 2,
|
|||
|
enableToggle: true,
|
|||
|
iconCls: "asc-toolbar-btn btn-selectcolor",
|
|||
|
menu: {
|
|||
|
showSeparator: false,
|
|||
|
items: [this.colorsHighlight = Ext.create("Ext.ColorPalette", {
|
|||
|
id: "menu-palette-highlight-color",
|
|||
|
cls: "color-palette-highlight",
|
|||
|
height: 126,
|
|||
|
width: 132,
|
|||
|
value: "FFFF00",
|
|||
|
allowReselect: true,
|
|||
|
style: "padding: 6px;",
|
|||
|
colors: ["FFFF00", "00FF00", "00FFFF", "FF00FF", "0000FF", "FF0000", "00008B", "008B8B", "006400", "800080", "8B0000", "808000", "FFFFFF", "D3D3D3", "A9A9A9", "000000"],
|
|||
|
listeners: {
|
|||
|
select: function (picker, color, eOpts) {
|
|||
|
_setMarkerColor(color, "menu");
|
|||
|
},
|
|||
|
afterrender: function (ct) {
|
|||
|
if (me.mnuHighlightTransparent.checked) {
|
|||
|
me._clearColorPalette(ct);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}), "-", this.mnuHighlightTransparent = Ext.widget("menucheckitem", {
|
|||
|
cls: "menu-item-highlightcolor-nocolor",
|
|||
|
text: this.strMenuNoFill,
|
|||
|
checked: false,
|
|||
|
iconCls: "menu-item-nocolor",
|
|||
|
handler: function onItemClick(item) {
|
|||
|
_setMarkerColor("transparent", "menu");
|
|||
|
item.setChecked(true);
|
|||
|
me._clearColorPalette(me.colorsHighlight);
|
|||
|
}
|
|||
|
})],
|
|||
|
listeners: {
|
|||
|
hide: {
|
|||
|
fn: function () {
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
listeners: {
|
|||
|
click: function (btn) {
|
|||
|
if (btn.pressed) {
|
|||
|
_setMarkerColor(btn.getColor());
|
|||
|
Common.component.Analytics.trackEvent("ToolBar", "Highlight Color");
|
|||
|
} else {
|
|||
|
me.api.SetMarkerFormat(false);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnHighlightColor);
|
|||
|
this.hotKeys = new Ext.util.KeyMap(document, [{
|
|||
|
key: Ext.EventObject.ESC,
|
|||
|
ctrl: false,
|
|||
|
shift: false,
|
|||
|
fn: function () {
|
|||
|
if (me.btnHighlightColor.pressed) {
|
|||
|
me.btnHighlightColor.toggle(false, true);
|
|||
|
me.api.SetMarkerFormat(false);
|
|||
|
}
|
|||
|
}
|
|||
|
}]);
|
|||
|
this.btnFontColor = Ext.widget("cmdsplitcolorbutton", {
|
|||
|
id: "toolbar-button-font-color",
|
|||
|
tooltip: this.tipFontColor,
|
|||
|
color: "000000",
|
|||
|
horizontalOffset: 3,
|
|||
|
verticalOffset: 2,
|
|||
|
split: true,
|
|||
|
listeners: {
|
|||
|
changecolor: function (btn, color) {
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
},
|
|||
|
click: function (btn) {
|
|||
|
me.colorsText.fireEvent("select", me.colorsText, me.colorsText.currentColor);
|
|||
|
}
|
|||
|
},
|
|||
|
iconCls: "asc-toolbar-btn btn-fontcolor"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnFontColor);
|
|||
|
this.btnMarkers = Ext.create("Ext.button.Split", {
|
|||
|
id: "toolbar-btn-markers",
|
|||
|
tooltip: this.tipMarkers,
|
|||
|
enableToggle: true,
|
|||
|
toggleGroup: "markersGroup",
|
|||
|
iconCls: "asc-toolbar-btn btn-setmarkers",
|
|||
|
split: true
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnMarkers);
|
|||
|
this.btnNumbers = Ext.create("Ext.button.Split", {
|
|||
|
id: "toolbar-btn-numbering",
|
|||
|
tooltip: this.tipNumbers,
|
|||
|
enableToggle: true,
|
|||
|
toggleGroup: "markersGroup",
|
|||
|
iconCls: "asc-toolbar-btn btn-numbering",
|
|||
|
split: true
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnNumbers);
|
|||
|
this.btnMultilevels = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-btn-multilevels",
|
|||
|
tooltip: this.tipMultilevels,
|
|||
|
iconCls: "asc-toolbar-btn btn-multilevels",
|
|||
|
split: true
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnMultilevels);
|
|||
|
this.btnAlignLeft = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-align-left",
|
|||
|
tooltip: this.tipAlignLeft + " (Ctrl+L)",
|
|||
|
enableToggle: true,
|
|||
|
toggleGroup: "alignGroup",
|
|||
|
allowDepress: false,
|
|||
|
iconCls: "asc-toolbar-btn btn-align-left"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnAlignLeft);
|
|||
|
this.btnAlignCenter = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-align-center",
|
|||
|
tooltip: this.tipAlignCenter + " (Ctrl+E)",
|
|||
|
enableToggle: true,
|
|||
|
toggleGroup: "alignGroup",
|
|||
|
allowDepress: false,
|
|||
|
iconCls: "asc-toolbar-btn btn-align-center"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnAlignCenter);
|
|||
|
this.btnAlignRight = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-align-right",
|
|||
|
tooltip: this.tipAlignRight + " (Ctrl+R)",
|
|||
|
enableToggle: true,
|
|||
|
toggleGroup: "alignGroup",
|
|||
|
allowDepress: false,
|
|||
|
iconCls: "asc-toolbar-btn btn-align-right"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnAlignRight);
|
|||
|
this.btnAlignJust = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-align-just",
|
|||
|
tooltip: this.tipAlignJust + " (Ctrl+J)",
|
|||
|
enableToggle: true,
|
|||
|
toggleGroup: "alignGroup",
|
|||
|
allowDepress: false,
|
|||
|
iconCls: "asc-toolbar-btn btn-align-just"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnAlignJust);
|
|||
|
this.btnHorizontalAlign = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-halign",
|
|||
|
tooltip: this.tipHAligh,
|
|||
|
iconCls: "asc-toolbar-btn btn-halign",
|
|||
|
cls: "halign-left",
|
|||
|
icls: "halign-left",
|
|||
|
menu: {
|
|||
|
showSeparator: false,
|
|||
|
id: "toolbar-menu-horalign",
|
|||
|
defaults: {
|
|||
|
cls: "toolbar-menu-icon-item",
|
|||
|
group: "halignGroup",
|
|||
|
checked: false
|
|||
|
},
|
|||
|
items: [{
|
|||
|
iconCls: "mnu-icon-item mnu-align-left",
|
|||
|
text: this.tipAlignLeft + " (Ctrl+L)",
|
|||
|
icls: "halign-left",
|
|||
|
halign: 1,
|
|||
|
checked: true
|
|||
|
},
|
|||
|
{
|
|||
|
iconCls: "mnu-icon-item mnu-align-center",
|
|||
|
text: this.tipAlignCenter + " (Ctrl+E)",
|
|||
|
icls: "halign-center",
|
|||
|
halign: 2
|
|||
|
},
|
|||
|
{
|
|||
|
iconCls: "mnu-icon-item mnu-align-right",
|
|||
|
text: this.tipAlignRight + " (Ctrl+R)",
|
|||
|
icls: "halign-right",
|
|||
|
halign: 0
|
|||
|
},
|
|||
|
{
|
|||
|
iconCls: "mnu-icon-item mnu-align-just",
|
|||
|
text: this.tipAlignJust + " (Ctrl+J)",
|
|||
|
icls: "halign-just",
|
|||
|
halign: 3
|
|||
|
}]
|
|||
|
}
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnHorizontalAlign);
|
|||
|
this.btnDecLeftOffset = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-dec-left-offset",
|
|||
|
tooltip: this.tipDecPrLeft + " (Ctrl+Shift+M)",
|
|||
|
iconCls: "asc-toolbar-btn btn-decoffset"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnDecLeftOffset);
|
|||
|
this.btnIncLeftOffset = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-inc-left-offset",
|
|||
|
tooltip: this.tipIncPrLeft + " (Ctrl+M)",
|
|||
|
iconCls: "asc-toolbar-btn btn-incoffset"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnIncLeftOffset);
|
|||
|
this.btnShowHidenChars = Ext.create("Ext.button.Split", {
|
|||
|
id: "toolbar-button-show-hidden",
|
|||
|
tooltip: this.tipShowHiddenChars,
|
|||
|
enableToggle: true,
|
|||
|
pressed: false,
|
|||
|
iconCls: "asc-toolbar-btn btn-hidenchars",
|
|||
|
menu: {
|
|||
|
listeners: {
|
|||
|
hide: function () {
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
}
|
|||
|
},
|
|||
|
items: [this.mniShowHiddenChars = Ext.widget("menucheckitem", {
|
|||
|
text: this.mniHiddenChars,
|
|||
|
hideOnClick: true,
|
|||
|
listeners: {
|
|||
|
checkchange: function (item, checked) {
|
|||
|
var pressed = checked;
|
|||
|
me.btnShowHidenChars.toggle(pressed, true);
|
|||
|
if (me.api) {
|
|||
|
me.api.put_ShowParaMarks(checked);
|
|||
|
}
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
Common.component.Analytics.trackEvent("ToolBar", "Hidden Characters");
|
|||
|
}
|
|||
|
}
|
|||
|
}), this.mniShowHiddenBorders = Ext.widget("menucheckitem", {
|
|||
|
text: this.mniHiddenBorders,
|
|||
|
hideOnClick: true,
|
|||
|
listeners: {
|
|||
|
checkchange: function (item, checked) {
|
|||
|
if (me.api) {
|
|||
|
me.api.put_ShowTableEmptyLine(checked);
|
|||
|
}
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
}
|
|||
|
}
|
|||
|
})]
|
|||
|
},
|
|||
|
listeners: {
|
|||
|
toggle: function (btn, pressed) {
|
|||
|
if (pressed) {
|
|||
|
me.mniShowHiddenChars.setChecked(true, true);
|
|||
|
Common.component.Analytics.trackEvent("ToolBar", "Hidden Characters");
|
|||
|
} else {
|
|||
|
me.mniShowHiddenChars.setChecked(false, true);
|
|||
|
}
|
|||
|
if (me.api) {
|
|||
|
me.api.put_ShowParaMarks(pressed);
|
|||
|
}
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
this.btnLineSpace = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-line-space",
|
|||
|
tooltip: this.tipLineSpace,
|
|||
|
iconCls: "asc-toolbar-btn btn-linespace",
|
|||
|
menu: {
|
|||
|
id: "toolbar-menu-line-space",
|
|||
|
width: 76,
|
|||
|
defaults: {
|
|||
|
group: "linespace",
|
|||
|
checked: false
|
|||
|
},
|
|||
|
items: [{
|
|||
|
text: "1.0",
|
|||
|
linespace: 1,
|
|||
|
checked: true
|
|||
|
},
|
|||
|
{
|
|||
|
text: "1.15",
|
|||
|
linespace: 1.15
|
|||
|
},
|
|||
|
{
|
|||
|
text: "1.5",
|
|||
|
linespace: 1.5
|
|||
|
},
|
|||
|
{
|
|||
|
text: "2.0",
|
|||
|
linespace: 2
|
|||
|
},
|
|||
|
{
|
|||
|
text: "2.5",
|
|||
|
linespace: 2.5
|
|||
|
},
|
|||
|
{
|
|||
|
text: "3.0",
|
|||
|
linespace: 3
|
|||
|
}]
|
|||
|
}
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnLineSpace);
|
|||
|
this.btnInsertTable = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-insert-table",
|
|||
|
tooltip: this.tipInsertTable,
|
|||
|
iconCls: "asc-toolbar-btn btn-inserttable",
|
|||
|
menu: {
|
|||
|
showSeparator: false,
|
|||
|
id: "toolbar-menu-insert-table",
|
|||
|
items: [{
|
|||
|
xtype: "container",
|
|||
|
width: 200,
|
|||
|
items: [{
|
|||
|
xtype: "dedimensionpicker",
|
|||
|
minRows: 8,
|
|||
|
minColumns: 10,
|
|||
|
maxRows: 8,
|
|||
|
maxColumns: 10,
|
|||
|
stalign: "top",
|
|||
|
padding: "10px"
|
|||
|
}]
|
|||
|
},
|
|||
|
{
|
|||
|
text: this.mniCustomTable,
|
|||
|
id: "toolbar-insert-custom-table",
|
|||
|
cls: "menu-item-noicon"
|
|||
|
}]
|
|||
|
}
|
|||
|
});
|
|||
|
this.btnInsertImage = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-insert-image",
|
|||
|
tooltip: this.tipInsertImage,
|
|||
|
iconCls: "asc-toolbar-btn btn-insertimage",
|
|||
|
menu: {
|
|||
|
showSeparator: false,
|
|||
|
id: "toolbar-menu-insertimage",
|
|||
|
items: [{
|
|||
|
text: this.mniImageFromFile,
|
|||
|
cls: "menu-item-noicon",
|
|||
|
from: "file"
|
|||
|
},
|
|||
|
{
|
|||
|
text: this.mniImageFromUrl,
|
|||
|
cls: "menu-item-noicon",
|
|||
|
from: "url"
|
|||
|
}]
|
|||
|
}
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnInsertImage);
|
|||
|
this.btnPageBreak = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-page-break",
|
|||
|
tooltip: this.tipPageBreak,
|
|||
|
iconCls: "asc-toolbar-btn btn-pagebreak"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnPageBreak);
|
|||
|
this.btnEditHeader = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-edit-header",
|
|||
|
tooltip: this.tipEditHeader,
|
|||
|
iconCls: "asc-toolbar-btn btn-editheader",
|
|||
|
menu: {
|
|||
|
showSeparator: false,
|
|||
|
id: "toolbar-menu-edit-header",
|
|||
|
items: [{
|
|||
|
text: this.mniEditHeader,
|
|||
|
cls: "menu-item-noicon",
|
|||
|
place: "Header"
|
|||
|
},
|
|||
|
{
|
|||
|
text: this.mniEditFooter,
|
|||
|
cls: "menu-item-noicon",
|
|||
|
place: "Footer"
|
|||
|
},
|
|||
|
{
|
|||
|
xtype: "menuseparator"
|
|||
|
}]
|
|||
|
}
|
|||
|
});
|
|||
|
this.btnInsertHyperlink = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-insert-hyperlink",
|
|||
|
tooltip: this.tipInsertHyperlink + " (Ctrl+K)",
|
|||
|
iconCls: "asc-toolbar-btn btn-inserthyperlink"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnInsertHyperlink);
|
|||
|
this.btnClearStyle = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-clear-style",
|
|||
|
tooltip: this.tipClearStyle,
|
|||
|
iconCls: "asc-toolbar-btn btn-clearstyle"
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnClearStyle);
|
|||
|
this.btnCopyStyle = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-copy-style",
|
|||
|
tooltip: this.tipCopyStyle + " (Ctrl+Shift+C)",
|
|||
|
iconCls: "asc-toolbar-btn btn-copystyle",
|
|||
|
enableToggle: true
|
|||
|
});
|
|||
|
this.btnPageSize = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-pagesize",
|
|||
|
tooltip: this.tipPageSize,
|
|||
|
iconCls: "asc-toolbar-btn btn-pagesize",
|
|||
|
pagesize: [210, 297],
|
|||
|
split: true
|
|||
|
});
|
|||
|
this.btnPageOrient = Ext.create("Ext.button.Button", {
|
|||
|
enableToggle: true,
|
|||
|
tooltip: this.tipPageOrient,
|
|||
|
id: "toolbar-button-pageorient",
|
|||
|
iconCls: "asc-toolbar-btn btn-pageorient"
|
|||
|
});
|
|||
|
me.btnNewDocument = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-newdocument",
|
|||
|
tooltip: this.tipNewDocument,
|
|||
|
iconCls: "asc-toolbar-btn btn-newdocument"
|
|||
|
});
|
|||
|
me.btnOpenDocument = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-opendocument",
|
|||
|
tooltip: this.tipOpenDocument,
|
|||
|
iconCls: "asc-toolbar-btn btn-opendocument"
|
|||
|
});
|
|||
|
this.btnInsertShape = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-insert-shape",
|
|||
|
tooltip: this.tipInsertShape,
|
|||
|
iconCls: "asc-toolbar-btn btn-insertshape",
|
|||
|
enableToggle: true,
|
|||
|
menu: {
|
|||
|
showSeparator: false,
|
|||
|
id: "toolbar-menu-insert-shape",
|
|||
|
items: [],
|
|||
|
plugins: [{
|
|||
|
ptype: "menuexpand"
|
|||
|
}]
|
|||
|
}
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnInsertShape);
|
|||
|
this.btnInsertText = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-insert-text",
|
|||
|
tooltip: this.tipInsertText,
|
|||
|
iconCls: "asc-toolbar-btn btn-text",
|
|||
|
enableToggle: true
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnInsertText);
|
|||
|
this.btnColorSchemas = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-color-schemas",
|
|||
|
tooltip: this.tipColorSchemas,
|
|||
|
iconCls: "asc-toolbar-btn btn-colorschemas",
|
|||
|
split: true
|
|||
|
});
|
|||
|
this.btnFitPage = Ext.widget("menucheckitem", {
|
|||
|
id: "toolbar-menu-fit-page",
|
|||
|
text: this.textFitPage,
|
|||
|
checked: false,
|
|||
|
hideOnClick: true
|
|||
|
});
|
|||
|
this.btnFitWidth = Ext.widget("menucheckitem", {
|
|||
|
id: "toolbar-menu-fit-width",
|
|||
|
text: this.textFitWidth,
|
|||
|
checked: false,
|
|||
|
hideOnClick: true
|
|||
|
});
|
|||
|
this.btnZoomIn = Ext.widget("button", {
|
|||
|
id: "toolbar-menu-zoomin",
|
|||
|
cls: "asc-toolbar-btn-zoom",
|
|||
|
iconCls: "asc-statusbar-btn btn-zoomin"
|
|||
|
});
|
|||
|
this.btnZoomOut = Ext.widget("button", {
|
|||
|
id: "toolbar-menu-zoomout",
|
|||
|
cls: "asc-toolbar-btn-zoom",
|
|||
|
iconCls: "asc-statusbar-btn btn-zoomout"
|
|||
|
});
|
|||
|
this.txtZoom = Ext.widget("label", {
|
|||
|
id: "toolbar-menu-zoom-text",
|
|||
|
text: "100%",
|
|||
|
style: "white-space:nowrap; text-align: center;"
|
|||
|
});
|
|||
|
this.btnHide = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-hide",
|
|||
|
tooltip: this.tipViewSettings,
|
|||
|
iconCls: "asc-toolbar-btn btn-hidebars",
|
|||
|
split: true
|
|||
|
});
|
|||
|
this.btnAdvSettings = Ext.create("Ext.button.Button", {
|
|||
|
id: "toolbar-button-settings",
|
|||
|
tooltip: this.tipAdvSettings,
|
|||
|
iconCls: "asc-toolbar-btn btn-settings"
|
|||
|
});
|
|||
|
this.btnDropCap = Ext.create("Ext.Button", {
|
|||
|
id: "toolbar-button-dropcap",
|
|||
|
tooltip: this.tipDropCap,
|
|||
|
iconCls: "asc-toolbar-btn btn-dropcap",
|
|||
|
cls: "dropcap-text",
|
|||
|
icls: "dropcap-text",
|
|||
|
menu: {
|
|||
|
showSeparator: false,
|
|||
|
id: "toolbar-menu-dropcap",
|
|||
|
items: [{
|
|||
|
cls: "toolbar-menu-icon-item",
|
|||
|
group: "dropcapGroup",
|
|||
|
iconCls: "mnu-icon-item mnu-dropcap-none",
|
|||
|
text: this.textNone,
|
|||
|
icls: "dropcap-none",
|
|||
|
dropcap: c_oAscDropCap.None,
|
|||
|
checked: true
|
|||
|
},
|
|||
|
{
|
|||
|
cls: "toolbar-menu-icon-item",
|
|||
|
group: "dropcapGroup",
|
|||
|
iconCls: "mnu-icon-item mnu-dropcap-text",
|
|||
|
text: this.textInText,
|
|||
|
icls: "dropcap-text",
|
|||
|
dropcap: c_oAscDropCap.Drop,
|
|||
|
checked: false
|
|||
|
},
|
|||
|
{
|
|||
|
cls: "toolbar-menu-icon-item",
|
|||
|
group: "dropcapGroup",
|
|||
|
iconCls: "mnu-icon-item mnu-dropcap-margin",
|
|||
|
text: this.textInMargin,
|
|||
|
icls: "dropcap-margin",
|
|||
|
dropcap: c_oAscDropCap.Margin,
|
|||
|
checked: false
|
|||
|
},
|
|||
|
{
|
|||
|
xtype: "menuseparator"
|
|||
|
},
|
|||
|
{
|
|||
|
id: "mnu-dropcap-advanced",
|
|||
|
text: this.mniEditDropCap,
|
|||
|
cls: "menu-item-noicon"
|
|||
|
}]
|
|||
|
}
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.btnDropCap);
|
|||
|
var btnPlaceholderHtml = function (id, iconCls, style) {
|
|||
|
return Ext.String.format('<div class="toolbar-btn-placeholder x-btn-default-toolbar-small-icon x-btn-default-toolbar-small document-loading" id="{0}" style="{2}"><span class="replaceme x-btn-icon asc-toolbar-btn {1}"> </span></div>', id, iconCls, style || "");
|
|||
|
};
|
|||
|
var btnSplitPlaceholderHtml = function (id, iconCls, style, extraCls) {
|
|||
|
return Ext.String.format('<div class="toolbar-btn-placeholder x-btn-default-toolbar-small-icon x-btn-default-toolbar-small document-loading x-btn-split x-btn-split-right{3}" id="{0}" style="width: 34px; {2}"><span class="replaceme x-btn-icon asc-toolbar-btn {1}"> </span></div>', id, iconCls, style || "", extraCls ? " " + extraCls : "");
|
|||
|
};
|
|||
|
var separatorHtml = function (size, style) {
|
|||
|
return Ext.String.format('<div class="x-toolbar-separator x-toolbar-item x-toolbar-separator-horizontal manual {0}" style="{1}" role="presentation" tabindex="-1"></div>', size, style || "");
|
|||
|
};
|
|||
|
var comboBoxHtml = function (id, text, style) {
|
|||
|
return Ext.String.format('<div id="{0}" class="x-container storage-combodataview x-container-default x-box-layout-ct toolbar-combo-placeholder x-item-disabled" role="presentation" tabindex="-1" style="{2}"><div class="x-trigger-index-0 x-form-trigger x-form-arrow-trigger x-form-trigger-last x-unselectable" role="button"></div>{1}</div>', id, text || "", style || "");
|
|||
|
};
|
|||
|
var comboDataViewHtml = function (id, text, style) {
|
|||
|
return Ext.String.format('<div id="{0}" class="x-container storage-combodataview x-container-default x-box-layout-ct toolbar-dataview-placeholder x-item-disabled" role="presentation" tabindex="-1" style="{1}"><div class="x-btn x-btn-combodataview x-box-item x-btn-default-small" style="height: 44px; margin: 0; top: 4px;"></div></div>', id, style || "");
|
|||
|
};
|
|||
|
var isCompactView = (window.localStorage.getItem("de-compact-toolbar") && parseInt(window.localStorage.getItem("de-compact-toolbar")) == 1) || false;
|
|||
|
this.setHeight(isCompactView ? 38 : 68);
|
|||
|
this.html = ['<div id="id-toolbar-short" style="' + (isCompactView ? "display: table;": "display: none;") + 'width: 100%; height: 22px; margin-top: 3px;" >', '<div class="toolbar-group">', '<div class="toolbar-row">', btnPlaceholderHtml("id-toolbar-short-btn-print", "btn-print", "margin: 0 4px 0 0;"), btnPlaceholderHtml("id-toolbar-short-btn-save", "btn-save"), "</div>", "</div>", '<div class="toolbar-group separator">', separatorHtml("short"), "</div>", '<div class="toolbar-group">', '<div class="toolbar-row">', btnPlaceholderHtml("id-toolbar-short-btn-undo", "btn-undo", "margin: 0 4px 0 0;"), btnPlaceholderHtml("id-toolbar-short-btn-redo", "btn-redo", "margin: 0 1px 0 3px;"), "</div>", "</div>", '<div class="toolbar-group separator">', separatorHtml("short"), "</div>", '<div class="toolbar-group">', '<div class="toolbar-row" style="width: 200px; margin-top: 2px;">', comboBoxHtml("id-toolbar-short-field-fontname", "Arial", "display: inline; float: left; line-height: 20px; padding: 0; width: 127px; height: 22px; margin-right: 4px;"), comboBoxHtml("id-toolbar-short-field-fontsize", "11", "display: inline; float: left; padding: 0; line-height: 20px; width: 59px; height: 22px; margin-right: 2px;"), "</div>", "</div>", '<div class="toolbar-group" style="padding-left: 0">', '<div class="toolbar-row" style="margin-top: 2px;">', btnPlaceholderHtml("id-toolbar-short-btn-bold", "btn-bold", "margin: 0 2px 0 0;"), btnPlaceholderHtml("id-toolbar-short-btn-italic", "btn-italic", "margin: 0 2px 0 0;"), btnPlaceholderHtml("id-toolbar-short-btn-underline", "btn-underline", "margin: 0 4px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-highlight", "btn-selectcolor", "margin: 0 4px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-fontcolor", "btn-fontcolor", "margin: 0 0 0 0;"), "</div>", "</div>", '<div class="toolbar-group separator">', separatorHtml("short"), "</div>", '<div class="toolbar-group">', '<div class="toolbar-row" style="margin-top: 2px;">', btnSplitPlaceholderHtml("id-toolbar-short-btn-halign", "btn-align-left", "margin: 0 4px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-setmarkers", "btn-setmarkers", "margin: 0 4px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-numbering", "btn-numbering", "margin: 0 4px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-multilevels", "btn-multilevels", "margin: 0;"), "</div>", "</div>", '<div class="toolbar-group separator">', separatorHtml("short"), "</div>", '<div class="toolbar-group">', '<div class="toolbar-row" style="margin-top: 2px;">', btnPlaceholderHtml("id-toolbar-short-btn-decoffset", "btn-decoffset", "margin: 0 4px 0 0;"), btnPlaceholderHtml("id-toolbar-short-btn-incoffset", "btn-incoffset", "margin: 0 4px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-linespace", "btn-linespace", "margin: 0 2px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-hidenchars", "btn-hidenchars", "margin: 0;"), "</div>", "</div>", '<div class="toolbar-group separator">', separatorHtml("short"), "</div>", '<div class="toolbar-group">', '<div class="toolbar-row" style="margin-top: 2px;">', btnSplitPlaceholderHtml("id-toolbar-short-btn-inserttable", "btn-inserttable", "margin: 0 2px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-insertimage", "btn-insertimage", "margin: 0 2px 0 0;"), btnPlaceholderHtml("id-toolbar-short-btn-text", "btn-text", "margin: 0 4px 0 0;"), btnPlaceholderHtml("id-toolbar-short-btn-pagebreak", "btn-pagebreak", "margin: 0 4px 0 0;"), btnPlaceholderHtml("id-toolbar-short-btn-inserthyperlink", "btn-inserthyperlink", "margin: 0 4px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-editheader", "btn-editheader", "margin: 0 2px 0 0;"), btnSplitPlaceholderHtml("id-toolbar-short-btn-insertshape", "btn-insertshape", "margin: 0;"), "</div>", "</div>", '<div class="toolbar-group separator">', separatorHtml("short"), "</div>", '<div class="toolbar-group">', '<div class="toolbar-row" style="margin-top: 2px;">', btnPlaceholderHtml("id-toolbar-short-btn-pageorient", "btn-pageorient", "margin: 0 4px 0 0;"), btnSplitPlaceholderHtml("i
|
|||
|
this.items = [];
|
|||
|
this.listStyles = Ext.create("Common.component.ComboDataView", {
|
|||
|
id: "toolbar-combo-view-styles",
|
|||
|
flex: 1,
|
|||
|
height: 54,
|
|||
|
itemWidth: 80,
|
|||
|
itemHeight: 40,
|
|||
|
menuMaxHeight: 500,
|
|||
|
minWidth: 125,
|
|||
|
repeatedselect: true,
|
|||
|
handleGlobalResize: true,
|
|||
|
viewData: []
|
|||
|
});
|
|||
|
this.paragraphControls.push(this.listStyles);
|
|||
|
this.callParent(arguments);
|
|||
|
},
|
|||
|
setApi: function (o) {
|
|||
|
this.api = o;
|
|||
|
if (this.api) {
|
|||
|
this.api.asc_registerCallback("asc_onMarkerFormatChanged", Ext.bind(this._onStartHighlight, this));
|
|||
|
this.api.asc_registerCallback("asc_onTextHighLight", Ext.bind(this._onHighlightColor, this));
|
|||
|
this.api.asc_registerCallback("asc_onCollaborativeChanges", Ext.bind(this._onCollaborativeChanges, this));
|
|||
|
return this;
|
|||
|
}
|
|||
|
},
|
|||
|
_onStartHighlight: function (pressed) {
|
|||
|
this.btnHighlightColor.toggle(pressed, true);
|
|||
|
},
|
|||
|
_onHighlightColor: function (c) {
|
|||
|
this.colorsHighlight.suspendEvents(false);
|
|||
|
var textpr = this.api.get_TextProps().get_TextPr();
|
|||
|
if (textpr) {
|
|||
|
c = textpr.get_HighLight();
|
|||
|
if (c == -1) {
|
|||
|
if (this._state.clrhighlight != -1) {
|
|||
|
this.mnuHighlightTransparent.setChecked(true);
|
|||
|
if (this.colorsHighlight.getEl()) {
|
|||
|
this._state.clrhighlight = -1;
|
|||
|
this._clearColorPalette(this.colorsHighlight);
|
|||
|
}
|
|||
|
}
|
|||
|
} else {
|
|||
|
if (c !== null) {
|
|||
|
if (this._state.clrhighlight != c.get_hex()) {
|
|||
|
this.mnuHighlightTransparent.setChecked(false);
|
|||
|
this._state.clrhighlight = c.get_hex().toUpperCase();
|
|||
|
if (Ext.Array.contains(this.colorsHighlight.colors, this._state.clrhighlight)) {
|
|||
|
this.colorsHighlight.select(this._state.clrhighlight, false);
|
|||
|
}
|
|||
|
}
|
|||
|
} else {
|
|||
|
if (this._state.clrhighlight !== c) {
|
|||
|
this.mnuHighlightTransparent.setChecked(false);
|
|||
|
this._clearColorPalette(this.colorsHighlight);
|
|||
|
this._state.clrhighlight = c;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
this.colorsHighlight.resumeEvents();
|
|||
|
},
|
|||
|
_onTextColor: function (color) {
|
|||
|
var clr;
|
|||
|
if (color) {
|
|||
|
if (color.get_type() == c_oAscColor.COLOR_TYPE_SCHEME) {
|
|||
|
clr = {
|
|||
|
color: this.getHexColor(color.get_r(), color.get_g(), color.get_b()),
|
|||
|
effectValue: color.get_value()
|
|||
|
};
|
|||
|
} else {
|
|||
|
clr = this.getHexColor(color.get_r(), color.get_g(), color.get_b());
|
|||
|
}
|
|||
|
}
|
|||
|
var type1 = typeof(clr),
|
|||
|
type2 = typeof(this._state.clrtext);
|
|||
|
if ((type1 !== type2) || (type1 == "object" && (clr.effectValue !== this._state.clrtext.effectValue || this._state.clrtext.color.indexOf(clr.color) < 0)) || (type1 != "object" && this._state.clrtext.indexOf(clr) < 0)) {
|
|||
|
this.colorsText.suspendEvents(false);
|
|||
|
if (typeof(clr) == "object") {
|
|||
|
for (var i = 0; i < 10; i++) {
|
|||
|
if (this.ThemeValues[i] == clr.effectValue) {
|
|||
|
this.colorsText.select(clr, false);
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
} else {
|
|||
|
this.colorsText.select(clr, false);
|
|||
|
}
|
|||
|
this.colorsText.resumeEvents();
|
|||
|
this._state.clrtext = clr;
|
|||
|
}
|
|||
|
},
|
|||
|
getHexColor: function (r, g, b) {
|
|||
|
r = r.toString(16);
|
|||
|
g = g.toString(16);
|
|||
|
b = b.toString(16);
|
|||
|
if (r.length == 1) {
|
|||
|
r = "0" + r;
|
|||
|
}
|
|||
|
if (g.length == 1) {
|
|||
|
g = "0" + g;
|
|||
|
}
|
|||
|
if (b.length == 1) {
|
|||
|
b = "0" + b;
|
|||
|
}
|
|||
|
return r + g + b;
|
|||
|
},
|
|||
|
getRgbColor: function (clr) {
|
|||
|
var color = (typeof(clr) == "object") ? clr.color : clr;
|
|||
|
color = color.replace(/#/, "");
|
|||
|
if (color.length == 3) {
|
|||
|
color = color.replace(/(.)/g, "$1$1");
|
|||
|
}
|
|||
|
color = parseInt(color, 16);
|
|||
|
var c = new CAscColor();
|
|||
|
c.put_type((typeof(clr) == "object") ? c_oAscColor.COLOR_TYPE_SCHEME : c_oAscColor.COLOR_TYPE_SRGB);
|
|||
|
c.put_r(color >> 16);
|
|||
|
c.put_g((color & 65280) >> 8);
|
|||
|
c.put_b(color & 255);
|
|||
|
c.put_a(255);
|
|||
|
if (clr.effectId !== undefined) {
|
|||
|
c.put_value(clr.effectId);
|
|||
|
}
|
|||
|
return c;
|
|||
|
},
|
|||
|
_onSendThemeColorSchemes: function (schemas) {
|
|||
|
var me = this;
|
|||
|
me.btnColorSchemas.menu.removeAll();
|
|||
|
var schemeTpl = Ext.create("Ext.XTemplate", '<a class="x-menu-item-link">', '<span class="colors">', '<tpl for="colors">', '<span class="color" style="background: {color};"></span>', "</tpl>", "</span>", '<span class="text">{text}</span>', "</a>");
|
|||
|
for (var i = 0; i < schemas.length; i++) {
|
|||
|
var schema = schemas[i];
|
|||
|
var colors = schema.get_colors();
|
|||
|
var schemecolors = [];
|
|||
|
for (var j = 2; j < 7; j++) {
|
|||
|
var clr = "#" + this.getHexColor(colors[j].get_r(), colors[j].get_g(), colors[j].get_b());
|
|||
|
schemecolors.push({
|
|||
|
color: clr
|
|||
|
});
|
|||
|
}
|
|||
|
var mnu = Ext.create("Ext.menu.Item", {
|
|||
|
cls: "menu-item-noicon asc-color-schemas-menu",
|
|||
|
data: {
|
|||
|
text: (i < 21) ? me.SchemeNames[i] : schema.get_name(),
|
|||
|
colors: schemecolors
|
|||
|
},
|
|||
|
tpl: schemeTpl,
|
|||
|
schemaType: i
|
|||
|
});
|
|||
|
if (i == 21) {
|
|||
|
me.btnColorSchemas.menu.add(Ext.create("Ext.menu.Separator", {}));
|
|||
|
}
|
|||
|
me.btnColorSchemas.menu.add(mnu);
|
|||
|
}
|
|||
|
},
|
|||
|
_onSendThemeColors: function (colors, standart_colors) {
|
|||
|
var standartcolors = [];
|
|||
|
if (standart_colors) {
|
|||
|
for (var i = 0; i < standart_colors.length; i++) {
|
|||
|
var item = this.getHexColor(standart_colors[i].get_r(), standart_colors[i].get_g(), standart_colors[i].get_b());
|
|||
|
standartcolors.push(item);
|
|||
|
}
|
|||
|
}
|
|||
|
var effectcolors = [];
|
|||
|
var clr, clrPara;
|
|||
|
for (i = 0; i < 6; i++) {
|
|||
|
for (var j = 0; j < 10; j++) {
|
|||
|
var idx = i + j * 6;
|
|||
|
var item = {
|
|||
|
color: this.getHexColor(colors[idx].get_r(), colors[idx].get_g(), colors[idx].get_b()),
|
|||
|
effectId: idx,
|
|||
|
effectValue: this.ThemeValues[j]
|
|||
|
};
|
|||
|
effectcolors.push(item);
|
|||
|
if (typeof(this.colorsText.currentColor) == "object" && clr === undefined && this.colorsText.currentColor.effectId == idx) {
|
|||
|
clr = item;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
this.colorsText.updateColors(effectcolors, standartcolors);
|
|||
|
if (this.colorsText.currentColor === undefined) {
|
|||
|
this.btnFontColor.setColor(effectcolors[1].color, false);
|
|||
|
this.colorsText.currentColor = effectcolors[1];
|
|||
|
} else {
|
|||
|
if (clr !== undefined) {
|
|||
|
this.btnFontColor.setColor(clr.color, false);
|
|||
|
this.colorsText.currentColor = clr;
|
|||
|
}
|
|||
|
}
|
|||
|
this.effectcolors = effectcolors;
|
|||
|
if (standartcolors && standartcolors.length > 0) {
|
|||
|
this.standartcolors = standartcolors;
|
|||
|
}
|
|||
|
},
|
|||
|
_onInsertPageNumber: function (picker, record) {
|
|||
|
if (this.api) {
|
|||
|
this.api.put_PageNum(record.data.data.type, record.data.data.subtype);
|
|||
|
}
|
|||
|
setTimeout(function () {
|
|||
|
picker.selectByIndex(-1);
|
|||
|
},
|
|||
|
100);
|
|||
|
this.fireEvent("editcomplete", this);
|
|||
|
Ext.menu.Manager.hideAll();
|
|||
|
Common.component.Analytics.trackEvent("ToolBar", "Page Number");
|
|||
|
},
|
|||
|
_onCollaborativeChanges: function () {
|
|||
|
if (!this.btnSave.rendered) {
|
|||
|
this.needShowSynchTip = true;
|
|||
|
return;
|
|||
|
}
|
|||
|
var span = this.btnSave.getEl().down(".asc-toolbar-btn");
|
|||
|
span.removeCls("btn-save");
|
|||
|
span.addCls("btn-synch");
|
|||
|
if (this.showSynchTip && this.isVisible()) {
|
|||
|
this.btnSave.setTooltip("");
|
|||
|
if (this.synchTooltip === undefined) {
|
|||
|
this._createSynchTip();
|
|||
|
}
|
|||
|
this.synchTooltip.show();
|
|||
|
} else {
|
|||
|
this.btnSave.setTooltip(this.tipSynchronize + " (Ctrl+S)");
|
|||
|
}
|
|||
|
},
|
|||
|
_onLockHeaderFooters: function () {
|
|||
|
this.pageNumHeaderFooter.setDisabled(true);
|
|||
|
this.mnuInsertPageNum.setDisabled(this.pageNumCurrentPos.isDisabled());
|
|||
|
},
|
|||
|
_onUnLockHeaderFooters: function () {
|
|||
|
this.pageNumHeaderFooter.setDisabled(false);
|
|||
|
this.mnuInsertPageNum.setDisabled(false);
|
|||
|
},
|
|||
|
_createSynchTip: function () {
|
|||
|
var showxy = this.btnSave.getPosition();
|
|||
|
showxy[0] += this.btnSave.getWidth();
|
|||
|
showxy[1] += this.btnSave.getHeight() / 2;
|
|||
|
this.synchTooltip = Ext.getBody().createChild({
|
|||
|
tag: "div",
|
|||
|
cls: "synch-tip-root",
|
|||
|
style: "top: " + showxy[1] + "px; left: " + showxy[0] + "px; width: 250px;"
|
|||
|
});
|
|||
|
if (this.synchTooltip) {
|
|||
|
var newsynch = Ext.widget("commonsynchronizetip", {
|
|||
|
renderTo: this.synchTooltip
|
|||
|
});
|
|||
|
newsynch.getEl().alignTo(this.synchTooltip, "tl");
|
|||
|
newsynch.addListener("dontshowclick", function () {
|
|||
|
this.showSynchTip = false;
|
|||
|
this.synchTooltip.hide();
|
|||
|
this.btnSave.setTooltip(this.tipSynchronize + " (Ctrl+S)");
|
|||
|
window.localStorage.setItem("de-hide-synch", 1);
|
|||
|
},
|
|||
|
this);
|
|||
|
newsynch.addListener("closeclick", function () {
|
|||
|
this.synchTooltip.hide();
|
|||
|
this.btnSave.setTooltip(this.tipSynchronize + " (Ctrl+S)");
|
|||
|
},
|
|||
|
this);
|
|||
|
}
|
|||
|
},
|
|||
|
setMode: function (mode) {
|
|||
|
if (mode.isDisconnected) {
|
|||
|
this.btnNewDocument.setDisabled(true);
|
|||
|
this.btnOpenDocument.setDisabled(true);
|
|||
|
this.btnSave.setDisabled(true);
|
|||
|
this.btnCopy.setDisabled(true);
|
|||
|
this.btnPaste.setDisabled(true);
|
|||
|
this.btnUndo.setDisabled(true);
|
|||
|
this.btnRedo.setDisabled(true);
|
|||
|
this.btnIncFontSize.setDisabled(true);
|
|||
|
this.btnDecFontSize.setDisabled(true);
|
|||
|
this.btnBold.setDisabled(true);
|
|||
|
this.btnItalic.setDisabled(true);
|
|||
|
this.btnUnderline.setDisabled(true);
|
|||
|
this.btnStrikeout.setDisabled(true);
|
|||
|
this.btnSuperscript.setDisabled(true);
|
|||
|
this.btnSubscript.setDisabled(true);
|
|||
|
this.btnHighlightColor.setDisabled(true);
|
|||
|
this.btnFontColor.setDisabled(true);
|
|||
|
this.btnMarkers.setDisabled(true);
|
|||
|
this.btnNumbers.setDisabled(true);
|
|||
|
this.btnMultilevels.setDisabled(true);
|
|||
|
this.btnAlignLeft.setDisabled(true);
|
|||
|
this.btnAlignCenter.setDisabled(true);
|
|||
|
this.btnAlignRight.setDisabled(true);
|
|||
|
this.btnAlignJust.setDisabled(true);
|
|||
|
this.btnDecLeftOffset.setDisabled(true);
|
|||
|
this.btnIncLeftOffset.setDisabled(true);
|
|||
|
this.btnLineSpace.setDisabled(true);
|
|||
|
this.btnShowHidenChars.setDisabled(true);
|
|||
|
this.btnInsertTable.setDisabled(true);
|
|||
|
this.btnInsertImage.setDisabled(true);
|
|||
|
this.btnInsertText.setDisabled(true);
|
|||
|
this.btnDropCap.setDisabled(true);
|
|||
|
this.btnPageBreak.setDisabled(true);
|
|||
|
this.btnInsertHyperlink.setDisabled(true);
|
|||
|
this.btnEditHeader.setDisabled(true);
|
|||
|
this.btnInsertShape.setDisabled(true);
|
|||
|
this.btnPageOrient.setDisabled(true);
|
|||
|
this.btnPageSize.setDisabled(true);
|
|||
|
this.btnClearStyle.setDisabled(true);
|
|||
|
this.btnCopyStyle.setDisabled(true);
|
|||
|
this.btnColorSchemas.setDisabled(true);
|
|||
|
this.btnHorizontalAlign.setDisabled(true);
|
|||
|
this.cmbFont.setDisabled(true);
|
|||
|
this.cmbFontSize.setDisabled(true);
|
|||
|
this.listStyles.setDisabled(true);
|
|||
|
} else {
|
|||
|
if (this.api) {
|
|||
|
this.mniShowHiddenChars.setChecked(this.api.get_ShowParaMarks(), true);
|
|||
|
this.mniShowHiddenBorders.setChecked(this.api.get_ShowTableEmptyLine(), true);
|
|||
|
this.btnShowHidenChars.toggle(this.mniShowHiddenChars.checked, true);
|
|||
|
}
|
|||
|
}
|
|||
|
if (!mode.nativeApp) {
|
|||
|
var nativeBtnGroup = Ext.get("id-toolbar-full-group-native");
|
|||
|
if (nativeBtnGroup) {
|
|||
|
nativeBtnGroup.setVisibilityMode(Ext.Element.DISPLAY);
|
|||
|
nativeBtnGroup.hide();
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
synchronizeChanges: function () {
|
|||
|
var span = this.btnSave.getEl().down(".asc-toolbar-btn");
|
|||
|
if (span.hasCls("btn-synch")) {
|
|||
|
span.removeCls("btn-synch");
|
|||
|
span.addCls("btn-save");
|
|||
|
if (this.synchTooltip) {
|
|||
|
this.synchTooltip.hide();
|
|||
|
}
|
|||
|
this.btnSave.setTooltip(this.tipSave + " (Ctrl+S)");
|
|||
|
}
|
|||
|
},
|
|||
|
_arrangeSlideItems: function () {
|
|||
|
if (!this.needArrangeSlideItems) {
|
|||
|
return;
|
|||
|
}
|
|||
|
var me = this;
|
|||
|
if (this.getEl()) {
|
|||
|
var jspElem = this.getEl().down(".jspPane");
|
|||
|
if (jspElem && jspElem.getHeight() > 0 && this.getEl().getHeight() > 0) {
|
|||
|
var i = 0;
|
|||
|
var updatescroll = setInterval(function () {
|
|||
|
if (me.needArrangeSlideItems) {
|
|||
|
me.resizeSlideItems();
|
|||
|
}
|
|||
|
if (!me.needArrangeSlideItems) {
|
|||
|
clearInterval(updatescroll);
|
|||
|
me.doLayout();
|
|||
|
return;
|
|||
|
}
|
|||
|
if (i++>5) {
|
|||
|
clearInterval(updatescroll);
|
|||
|
}
|
|||
|
},
|
|||
|
100);
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
_resizeSlideItems: function () {
|
|||
|
var cols = 3;
|
|||
|
var selector = "div.group-item";
|
|||
|
var el = this.getEl();
|
|||
|
var thumbs = el.query(selector);
|
|||
|
var i = 0;
|
|||
|
while (i < thumbs.length) {
|
|||
|
var height = 0;
|
|||
|
for (var j = i; j < i + cols; j++) {
|
|||
|
if (j >= thumbs.length) {
|
|||
|
break;
|
|||
|
}
|
|||
|
var thEl = Ext.get(thumbs[j]);
|
|||
|
var h = thEl.getHeight();
|
|||
|
if (h < 50) {
|
|||
|
return;
|
|||
|
}
|
|||
|
if (h < height) {
|
|||
|
thEl.setHeight(height);
|
|||
|
} else {
|
|||
|
height = h;
|
|||
|
}
|
|||
|
}
|
|||
|
i += cols;
|
|||
|
}
|
|||
|
if (thumbs.length > 0) {
|
|||
|
this.needArrangeSlideItems = false;
|
|||
|
}
|
|||
|
},
|
|||
|
changeViewMode: function (compact) {
|
|||
|
var me = this,
|
|||
|
toolbarFull = Ext.get("id-toolbar-full"),
|
|||
|
toolbarShort = Ext.get("id-toolbar-short");
|
|||
|
if (toolbarFull && toolbarShort) {
|
|||
|
if (compact) {
|
|||
|
toolbarShort.setStyle({
|
|||
|
display: "table"
|
|||
|
});
|
|||
|
toolbarFull.setStyle({
|
|||
|
display: "none"
|
|||
|
});
|
|||
|
this.setHeight(38);
|
|||
|
this.rendererComponents("short");
|
|||
|
} else {
|
|||
|
toolbarShort.setStyle({
|
|||
|
display: "none"
|
|||
|
});
|
|||
|
toolbarFull.setStyle({
|
|||
|
display: "table"
|
|||
|
});
|
|||
|
this.setHeight(68);
|
|||
|
this.rendererComponents("full");
|
|||
|
Ext.defer(function () {
|
|||
|
var listStylesVisible = (me.listStyles.rendered && me.listStyles.getEl() && me.listStyles.getEl().up("#id-toolbar-full-group-styles") && me.listStyles.getEl().up("#id-toolbar-full-group-styles").isVisible());
|
|||
|
if (me.listStyles.dataMenu.picker.store.getCount() > 0 && listStylesVisible) {
|
|||
|
me.listStyles.doComponentLayout();
|
|||
|
me.listStyles.fillComboView(me.listStyles.dataMenu.picker.getSelectedRec(), true);
|
|||
|
}
|
|||
|
},
|
|||
|
100);
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
rendererComponents: function (mode) {
|
|||
|
var me = this;
|
|||
|
var replaceBtn = function (id, btn) {
|
|||
|
var placeholderEl = Ext.get(id);
|
|||
|
if (placeholderEl) {
|
|||
|
if (!placeholderEl.down("button")) {
|
|||
|
placeholderEl.removeCls(["x-btn-default-toolbar-small-icon", "x-btn-default-toolbar-small", "x-btn-disabled", "x-btn-split", "x-btn-split-right", "document-loading"]);
|
|||
|
var icon = placeholderEl.down("span");
|
|||
|
icon && icon.remove();
|
|||
|
btn.addCls("x-btn-default-toolbar-small x-btn-default-toolbar-small-icon ");
|
|||
|
if (btn.rendered) {
|
|||
|
placeholderEl.dom.appendChild(document.getElementById(btn.getId()));
|
|||
|
} else {
|
|||
|
btn.render(placeholderEl);
|
|||
|
}
|
|||
|
btn.removeCls(["x-btn-default-small", "x-btn-default-small-icon"]);
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
var replaceField = function (id, field) {
|
|||
|
var placeholderEl = Ext.get(id);
|
|||
|
if (placeholderEl) {
|
|||
|
if (!placeholderEl.down("input")) {
|
|||
|
if (/toolbar-combo-placeholder|toolbar-dataview-placeholder/.test(placeholderEl.dom.className)) {
|
|||
|
for (var i = placeholderEl.dom.childNodes.length, node; i--;) {
|
|||
|
node = placeholderEl.dom.childNodes[i];
|
|||
|
node.parentNode.removeChild(node);
|
|||
|
}
|
|||
|
}
|
|||
|
placeholderEl.removeCls(["x-container", "storage-combodataview", "x-container-default", "x-box-layout-ct", "toolbar-combo-placeholder", "toolbar-dataview-placeholder", "x-item-disabled"]);
|
|||
|
if (field.rendered) {
|
|||
|
placeholderEl.dom.appendChild(document.getElementById(field.getId()));
|
|||
|
} else {
|
|||
|
field.render(placeholderEl);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
var prefix = (mode === "short") ? "short" : "full";
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-newdocument", me.btnNewDocument);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-opendocument", me.btnOpenDocument);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-print", me.btnPrint);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-save", me.btnSave);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-copy", me.btnCopy);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-paste", me.btnPaste);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-undo", me.btnUndo);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-redo", me.btnRedo);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-incfont", me.btnIncFontSize);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-decfont", me.btnDecFontSize);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-bold", me.btnBold);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-italic", me.btnItalic);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-underline", me.btnUnderline);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-strikeout", me.btnStrikeout);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-superscript", me.btnSuperscript);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-subscript", me.btnSubscript);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-highlight", me.btnHighlightColor);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-fontcolor", me.btnFontColor);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-setmarkers", me.btnMarkers);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-numbering", me.btnNumbers);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-multilevels", me.btnMultilevels);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-align-left", me.btnAlignLeft);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-align-center", me.btnAlignCenter);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-align-right", me.btnAlignRight);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-align-just", me.btnAlignJust);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-decoffset", me.btnDecLeftOffset);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-incoffset", me.btnIncLeftOffset);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-linespace", me.btnLineSpace);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-hidenchars", me.btnShowHidenChars);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-inserttable", me.btnInsertTable);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-insertimage", me.btnInsertImage);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-text", me.btnInsertText);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-dropcap", me.btnDropCap);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-pagebreak", me.btnPageBreak);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-inserthyperlink", me.btnInsertHyperlink);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-editheader", me.btnEditHeader);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-insertshape", me.btnInsertShape);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-pageorient", me.btnPageOrient);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-pagesize", me.btnPageSize);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-clearstyle", me.btnClearStyle);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-copystyle", me.btnCopyStyle);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-colorschemas", me.btnColorSchemas);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-hidebars", me.btnHide);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-settings", me.btnAdvSettings);
|
|||
|
replaceBtn("id-toolbar-" + prefix + "-btn-halign", me.btnHorizontalAlign);
|
|||
|
replaceField("id-toolbar-" + prefix + "-field-fontname", me.cmbFont);
|
|||
|
replaceField("id-toolbar-" + prefix + "-field-fontsize", me.cmbFontSize);
|
|||
|
replaceField("id-toolbar-" + prefix + "-field-styles", me.listStyles);
|
|||
|
},
|
|||
|
createDelayedElements: function () {
|
|||
|
var btns_arr = [],
|
|||
|
me = this;
|
|||
|
var isCompactView = (window.localStorage.getItem("de-compact-toolbar") && parseInt(window.localStorage.getItem("de-compact-toolbar")) == 1) || false;
|
|||
|
me.rendererComponents(isCompactView ? "short" : "full");
|
|||
|
var dataTpl = Ext.create("Ext.XTemplate", '<tpl for=".">', '<div class="thumb-wrap">', '<img src="" style="{imgstyle}" class="{imgcls}"/>', "</div>", "</tpl>");
|
|||
|
var viewData = [{
|
|||
|
offsety: 0,
|
|||
|
data: {
|
|||
|
type: 0,
|
|||
|
subtype: -1
|
|||
|
},
|
|||
|
imgcls: "item-markerlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 38,
|
|||
|
data: {
|
|||
|
type: 0,
|
|||
|
subtype: 1
|
|||
|
},
|
|||
|
imgcls: "item-markerlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 76,
|
|||
|
data: {
|
|||
|
type: 0,
|
|||
|
subtype: 2
|
|||
|
},
|
|||
|
imgcls: "item-markerlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 114,
|
|||
|
data: {
|
|||
|
type: 0,
|
|||
|
subtype: 3
|
|||
|
},
|
|||
|
imgcls: "item-markerlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 152,
|
|||
|
data: {
|
|||
|
type: 0,
|
|||
|
subtype: 4
|
|||
|
},
|
|||
|
imgcls: "item-markerlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 190,
|
|||
|
data: {
|
|||
|
type: 0,
|
|||
|
subtype: 5
|
|||
|
},
|
|||
|
imgcls: "item-markerlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 228,
|
|||
|
data: {
|
|||
|
type: 0,
|
|||
|
subtype: 6
|
|||
|
},
|
|||
|
imgcls: "item-markerlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 266,
|
|||
|
data: {
|
|||
|
type: 0,
|
|||
|
subtype: 7
|
|||
|
},
|
|||
|
imgcls: "item-markerlist"
|
|||
|
}];
|
|||
|
for (var i = 0; i < viewData.length; i++) {
|
|||
|
viewData[i].imgstyle = Ext.String.format("background-position: 0 {0}px;", -viewData[i].offsety);
|
|||
|
}
|
|||
|
this.btnMarkers.menu = Ext.create("Common.component.MenuDataViewPicker", {
|
|||
|
width: 194,
|
|||
|
height: 108,
|
|||
|
contentWidth: 174,
|
|||
|
dataTpl: dataTpl,
|
|||
|
viewData: viewData
|
|||
|
});
|
|||
|
btns_arr.push(this.btnMarkers);
|
|||
|
viewData = [{
|
|||
|
offsety: 0,
|
|||
|
data: {
|
|||
|
type: 1,
|
|||
|
subtype: -1
|
|||
|
},
|
|||
|
imgcls: "item-numberlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 518,
|
|||
|
data: {
|
|||
|
type: 1,
|
|||
|
subtype: 4
|
|||
|
},
|
|||
|
imgcls: "item-numberlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 592,
|
|||
|
data: {
|
|||
|
type: 1,
|
|||
|
subtype: 5
|
|||
|
},
|
|||
|
imgcls: "item-numberlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 666,
|
|||
|
data: {
|
|||
|
type: 1,
|
|||
|
subtype: 6
|
|||
|
},
|
|||
|
imgcls: "item-numberlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 296,
|
|||
|
data: {
|
|||
|
type: 1,
|
|||
|
subtype: 1
|
|||
|
},
|
|||
|
imgcls: "item-numberlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 370,
|
|||
|
data: {
|
|||
|
type: 1,
|
|||
|
subtype: 2
|
|||
|
},
|
|||
|
imgcls: "item-numberlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 444,
|
|||
|
data: {
|
|||
|
type: 1,
|
|||
|
subtype: 3
|
|||
|
},
|
|||
|
imgcls: "item-numberlist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 740,
|
|||
|
data: {
|
|||
|
type: 1,
|
|||
|
subtype: 7
|
|||
|
},
|
|||
|
imgcls: "item-numberlist"
|
|||
|
}];
|
|||
|
for (var i = 0; i < viewData.length; i++) {
|
|||
|
viewData[i].imgstyle = Ext.String.format("background-position:0 {0}px;", -viewData[i].offsety);
|
|||
|
}
|
|||
|
this.btnNumbers.menu = Ext.create("Common.component.MenuDataViewPicker", {
|
|||
|
width: 336,
|
|||
|
height: 180,
|
|||
|
contentWidth: 316,
|
|||
|
dataTpl: dataTpl,
|
|||
|
viewData: viewData
|
|||
|
});
|
|||
|
btns_arr.push(this.btnNumbers);
|
|||
|
viewData = [{
|
|||
|
offsety: 0,
|
|||
|
data: {
|
|||
|
type: 2,
|
|||
|
subtype: -1
|
|||
|
},
|
|||
|
imgcls: "item-multilevellist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 74,
|
|||
|
data: {
|
|||
|
type: 2,
|
|||
|
subtype: 1
|
|||
|
},
|
|||
|
imgcls: "item-multilevellist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 148,
|
|||
|
data: {
|
|||
|
type: 2,
|
|||
|
subtype: 2
|
|||
|
},
|
|||
|
imgcls: "item-multilevellist"
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 222,
|
|||
|
data: {
|
|||
|
type: 2,
|
|||
|
subtype: 3
|
|||
|
},
|
|||
|
imgcls: "item-multilevellist"
|
|||
|
}];
|
|||
|
for (var i = 0; i < viewData.length; i++) {
|
|||
|
viewData[i].imgstyle = Ext.String.format("background-position:0 {0}px;", -viewData[i].offsety);
|
|||
|
}
|
|||
|
this.btnMultilevels.menu = Ext.create("Common.component.MenuDataViewPicker", {
|
|||
|
width: 173,
|
|||
|
height: 180,
|
|||
|
contentWidth: 153,
|
|||
|
dataTpl: dataTpl,
|
|||
|
viewData: viewData
|
|||
|
});
|
|||
|
btns_arr.push(this.btnMultilevels);
|
|||
|
this.btnFontColor.menu = Ext.create("Ext.menu.Menu", {
|
|||
|
showSeparator: false,
|
|||
|
items: [this.colorsText = Ext.create("Common.component.ThemeColorPalette", {
|
|||
|
id: "menu-palette-font-color",
|
|||
|
value: "000000",
|
|||
|
width: 165,
|
|||
|
height: 214,
|
|||
|
dynamiccolors: true,
|
|||
|
dyncolorscount: 10,
|
|||
|
currentColor: undefined,
|
|||
|
colors: [me.textThemeColors, "-", {
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 3
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 4
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 5
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 3
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 4
|
|||
|
},
|
|||
|
"-", {
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 3
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 4
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 5
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
{
|
|||
|
color: "FFFFFF",
|
|||
|
effectId: 2
|
|||
|
},
|
|||
|
{
|
|||
|
color: "000000",
|
|||
|
effectId: 1
|
|||
|
},
|
|||
|
"-", "--", "-", me.textStandartColors, "-", "3D55FE", "5301B3", "980ABD", "B2275F", "F83D26", "F86A1D", "F7AC16", "F7CA12", "FAFF44", "D6EF39", "-", "--"],
|
|||
|
listeners: {
|
|||
|
select: {
|
|||
|
fn: function (picker, color, eOpts) {
|
|||
|
if (typeof(color) == "object") {
|
|||
|
me.btnFontColor.setColor(color.color);
|
|||
|
} else {
|
|||
|
me.btnFontColor.setColor(color);
|
|||
|
}
|
|||
|
Ext.menu.Manager.hideAll();
|
|||
|
me.colorsText.currentColor = color;
|
|||
|
me.api.put_TextColor(me.getRgbColor(color));
|
|||
|
Common.component.Analytics.trackEvent("ToolBar", "Text Color");
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}), {
|
|||
|
cls: "menu-item-noicon menu-item-color-palette-theme",
|
|||
|
text: this.textNewColor,
|
|||
|
listeners: {
|
|||
|
click: function (item, event) {
|
|||
|
me.colorsText.addNewColor();
|
|||
|
}
|
|||
|
}
|
|||
|
}],
|
|||
|
listeners: {
|
|||
|
hide: function () {
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
btns_arr.push(this.btnFontColor);
|
|||
|
viewData = [{
|
|||
|
offsety: 132,
|
|||
|
data: {
|
|||
|
type: c_pageNumPosition.PAGE_NUM_POSITION_TOP,
|
|||
|
subtype: c_pageNumPosition.PAGE_NUM_POSITION_LEFT
|
|||
|
}
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 99,
|
|||
|
data: {
|
|||
|
type: c_pageNumPosition.PAGE_NUM_POSITION_TOP,
|
|||
|
subtype: c_pageNumPosition.PAGE_NUM_POSITION_CENTER
|
|||
|
}
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 66,
|
|||
|
data: {
|
|||
|
type: c_pageNumPosition.PAGE_NUM_POSITION_TOP,
|
|||
|
subtype: c_pageNumPosition.PAGE_NUM_POSITION_RIGHT
|
|||
|
}
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 33,
|
|||
|
data: {
|
|||
|
type: c_pageNumPosition.PAGE_NUM_POSITION_BOTTOM,
|
|||
|
subtype: c_pageNumPosition.PAGE_NUM_POSITION_LEFT
|
|||
|
}
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 0,
|
|||
|
data: {
|
|||
|
type: c_pageNumPosition.PAGE_NUM_POSITION_BOTTOM,
|
|||
|
subtype: c_pageNumPosition.PAGE_NUM_POSITION_CENTER
|
|||
|
}
|
|||
|
},
|
|||
|
{
|
|||
|
offsety: 165,
|
|||
|
data: {
|
|||
|
type: c_pageNumPosition.PAGE_NUM_POSITION_BOTTOM,
|
|||
|
subtype: c_pageNumPosition.PAGE_NUM_POSITION_RIGHT
|
|||
|
}
|
|||
|
}];
|
|||
|
for (var i = 0; i < viewData.length; i++) {
|
|||
|
viewData[i].imgstyle = Ext.String.format("background-image:url({0});", "resources/img/toolbar/colontitules.png");
|
|||
|
viewData[i].imgstyle += Ext.String.format("background-image:-webkit-image-set(url({0}) 1x, url({1}) 2x);", "resources/img/toolbar/colontitules.png", "resources/img/toolbar/colontitules@2x.png");
|
|||
|
viewData[i].imgstyle += Ext.String.format("background-position:0 {0}px; width:33px; height:33px;", -viewData[i].offsety);
|
|||
|
}
|
|||
|
this.mnuInsertPageNum = Ext.widget("menuitem", {
|
|||
|
text: this.textInsertPageNumber,
|
|||
|
cls: "menu-item-noicon",
|
|||
|
hideOnClick: false,
|
|||
|
menu: {
|
|||
|
showSeparator: false,
|
|||
|
items: [me.pageNumHeaderFooter = Ext.widget("container", {
|
|||
|
style: "text-align:center;padding: 8px 0 0 0;",
|
|||
|
cls: "pagenum-container",
|
|||
|
items: [{
|
|||
|
xtype: "cmddataviewpicker",
|
|||
|
padding: "4px 4px 1px 12px",
|
|||
|
cls: "menu-insertpagenum",
|
|||
|
width: 175,
|
|||
|
height: 110,
|
|||
|
contentWidth: 155,
|
|||
|
dataTpl: dataTpl,
|
|||
|
viewData: viewData,
|
|||
|
listeners: {
|
|||
|
select: me._onInsertPageNumber,
|
|||
|
scope: me
|
|||
|
}
|
|||
|
}]
|
|||
|
}), me.pageNumCurrentPos = Ext.widget("menuitem", {
|
|||
|
text: this.textToCurrent,
|
|||
|
cls: "menu-item-noicon",
|
|||
|
listeners: {
|
|||
|
click: {
|
|||
|
fn: function () {
|
|||
|
if (me.api) {
|
|||
|
me.api.put_PageNum(-1);
|
|||
|
}
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
Common.component.Analytics.trackEvent("ToolBar", "Page Number");
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
})],
|
|||
|
listeners: {
|
|||
|
hide: {
|
|||
|
fn: function () {
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
this.btnEditHeader.menu.add(this.mnuInsertPageNum);
|
|||
|
this.paragraphControls.push(this.pageNumCurrentPos);
|
|||
|
var pagesizeTemplate = Ext.create("Ext.XTemplate", '<tpl if="plain">{text}</tpl>' + '<tpl if="!plain">' + '<a id="{id}-itemEl" class="' + Ext.baseCSSPrefix + 'menu-item-link menu-item-usetitle" href="{href}" hidefocus="true" unselectable="on">' + '<img id="{id}-iconEl" src="{icon}" class="' + Ext.baseCSSPrefix + 'menu-item-icon {iconCls}" />' + '<div class="menu-item-title"><span class="' + Ext.baseCSSPrefix + 'menu-item-text" style="font-weight:bold;">{[this.getTText(values.text)]}</span></div>' + '<div class="menu-item-decript"><span class="' + Ext.baseCSSPrefix + 'menu-item-text">{[this.getDText(values.text)]}</span></div>' + "</a>" + "</tpl>", {
|
|||
|
getTText: function (t) {
|
|||
|
return (/^.*(?=\|)/).exec(t) || t;
|
|||
|
},
|
|||
|
getDText: function (t) {
|
|||
|
var out = (/\|(.*)$/).exec(t);
|
|||
|
return out ? out[1] : "";
|
|||
|
}
|
|||
|
});
|
|||
|
this.btnPageSize.menu = Ext.create("Ext.menu.Menu", {
|
|||
|
showSeparator: false,
|
|||
|
id: "menu-page-size",
|
|||
|
defaults: {
|
|||
|
group: "pagesize",
|
|||
|
checked: false,
|
|||
|
renderTpl: pagesizeTemplate,
|
|||
|
checkHandler: function (item, checked) {
|
|||
|
if (me.api && checked) {
|
|||
|
me.btnPageSize.pagesize[0] = item.pagesize[0];
|
|||
|
me.btnPageSize.pagesize[1] = item.pagesize[1];
|
|||
|
me.api.change_DocSize(item.pagesize[0], item.pagesize[1]);
|
|||
|
Common.component.Analytics.trackEvent("ToolBar", "Page Size");
|
|||
|
}
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
}
|
|||
|
},
|
|||
|
items: [{
|
|||
|
text: "US Letter|21,59cm x 27,94cm",
|
|||
|
pagesize: [215.9, 279.4]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "US Legal|21,59cm x 35,56cm",
|
|||
|
pagesize: [215.9, 355.6]
|
|||
|
},
|
|||
|
{
|
|||
|
checked: true,
|
|||
|
text: "A4|21cm x 29,7cm",
|
|||
|
pagesize: [210, 297]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "A5|14,81cm x 20,99cm",
|
|||
|
pagesize: [148.1, 209.9]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "B5|17,6cm x 25,01cm",
|
|||
|
pagesize: [176, 250.1]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "Envelope #10|10,48cm x 24,13cm",
|
|||
|
pagesize: [104.8, 241.3]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "Envelope DL|11,01cm x 22,01cm",
|
|||
|
pagesize: [110.1, 220.1]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "Tabloid|27,94cm x 43,17cm",
|
|||
|
pagesize: [279.4, 431.7]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "A3|29,7cm x 42,01cm",
|
|||
|
pagesize: [297, 420.1]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "Tabloid Oversize|30,48cm x 45,71cm",
|
|||
|
pagesize: [304.8, 457.1]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "ROC 16K|19,68cm x 27,3cm",
|
|||
|
pagesize: [196.8, 273]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "Envelope Choukei 3|11,99cm x 23,49cm",
|
|||
|
pagesize: [119.9, 234.9]
|
|||
|
},
|
|||
|
{
|
|||
|
text: "Super B/A3|33,02cm x 48,25cm",
|
|||
|
pagesize: [330.2, 482.5]
|
|||
|
}]
|
|||
|
});
|
|||
|
btns_arr.push(this.btnPageSize);
|
|||
|
this.btnColorSchemas.menu = Ext.create("Ext.menu.Menu", {
|
|||
|
showSeparator: false,
|
|||
|
id: "toolbar-menu-color-schemas",
|
|||
|
items: []
|
|||
|
});
|
|||
|
btns_arr.push(this.btnColorSchemas);
|
|||
|
var value = window.localStorage.getItem("de-compact-toolbar");
|
|||
|
var valueCompact = (value !== null && parseInt(value) == 1);
|
|||
|
value = window.localStorage.getItem("de-hidden-title");
|
|||
|
var valueTitle = (value !== null && parseInt(value) == 1);
|
|||
|
value = window.localStorage.getItem("de-hidden-status");
|
|||
|
var valueStatus = (value !== null && parseInt(value) == 1);
|
|||
|
this.btnHide.menu = Ext.create("Ext.menu.Menu", {
|
|||
|
id: "menu-hide-bars",
|
|||
|
showSeparator: false,
|
|||
|
defaults: {
|
|||
|
checked: false,
|
|||
|
targetbar: undefined,
|
|||
|
hideOnClick: true
|
|||
|
},
|
|||
|
items: [{
|
|||
|
id: "mnu-hide-bars-toolbar",
|
|||
|
text: this.textCompactView,
|
|||
|
checked: valueCompact
|
|||
|
},
|
|||
|
{
|
|||
|
text: this.textHideTitleBar,
|
|||
|
checked: valueTitle,
|
|||
|
checkHandler: function (item, checked) {
|
|||
|
if (item.targetbar === undefined) {
|
|||
|
item.targetbar = Ext.ComponentQuery.query("commonheader")[0];
|
|||
|
}
|
|||
|
if (item.targetbar) {
|
|||
|
(checked) ? item.targetbar.hide() : item.targetbar.show();
|
|||
|
}
|
|||
|
window.localStorage.setItem("de-hidden-title", checked ? 1 : 0);
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
}
|
|||
|
},
|
|||
|
{
|
|||
|
text: this.textHideStatusBar,
|
|||
|
checked: valueStatus,
|
|||
|
checkHandler: function (item, checked) {
|
|||
|
if (item.targetbar === undefined) {
|
|||
|
item.targetbar = Ext.ComponentQuery.query("documentstatusinfo")[0];
|
|||
|
}
|
|||
|
if (item.targetbar) {
|
|||
|
(checked) ? item.targetbar.hide() : item.targetbar.show();
|
|||
|
}
|
|||
|
window.localStorage.setItem("de-hidden-status", checked ? 1 : 0);
|
|||
|
me.fireEvent("editcomplete", me);
|
|||
|
}
|
|||
|
},
|
|||
|
{
|
|||
|
xtype: "menuseparator"
|
|||
|
},
|
|||
|
this.btnFitPage, this.btnFitWidth, {
|
|||
|
xtype: "container",
|
|||
|
layout: {
|
|||
|
type: "hbox",
|
|||
|
align: "middle"
|
|||
|
},
|
|||
|
width: 165,
|
|||
|
style: "font-size:11px; padding:6px 2px 3px 32px;",
|
|||
|
items: [{
|
|||
|
xtype: "label",
|
|||
|
text: me.textZoom
|
|||
|
},
|
|||
|
{
|
|||
|
xtype: "tbspacer",
|
|||
|
flex: 1
|
|||
|
},
|
|||
|
this.btnZoomOut, {
|
|||
|
xtype: "tbspacer",
|
|||
|
width: 1
|
|||
|
},
|
|||
|
this.txtZoom, this.btnZoomIn, {
|
|||
|
xtype: "tbspacer",
|
|||
|
width: 5
|
|||
|
}]
|
|||
|
}]
|
|||
|
});
|
|||
|
btns_arr.push(this.btnHide);
|
|||
|
for (i = 0; i < btns_arr.length; i++) {
|
|||
|
var btn = btns_arr[i];
|
|||
|
btn.menu.ownerCt = btn;
|
|||
|
btn.mon(btns_arr[i].menu, {
|
|||
|
scope: btn,
|
|||
|
show: btn.onMenuShow,
|
|||
|
hide: btn.onMenuHide
|
|||
|
});
|
|||
|
if (btn.rendered) {
|
|||
|
btn.initAria();
|
|||
|
}
|
|||
|
}
|
|||
|
var fontSize = [{
|
|||
|
"sizevalue": 8,
|
|||
|
"sizestring": "8"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 9,
|
|||
|
"sizestring": "9"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 10,
|
|||
|
"sizestring": "10"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 11,
|
|||
|
"sizestring": "11"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 12,
|
|||
|
"sizestring": "12"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 14,
|
|||
|
"sizestring": "14"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 16,
|
|||
|
"sizestring": "16"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 18,
|
|||
|
"sizestring": "18"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 20,
|
|||
|
"sizestring": "20"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 22,
|
|||
|
"sizestring": "22"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 24,
|
|||
|
"sizestring": "24"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 26,
|
|||
|
"sizestring": "26"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 28,
|
|||
|
"sizestring": "28"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 36,
|
|||
|
"sizestring": "36"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 48,
|
|||
|
"sizestring": "48"
|
|||
|
},
|
|||
|
{
|
|||
|
"sizevalue": 72,
|
|||
|
"sizestring": "72"
|
|||
|
}];
|
|||
|
this.cmbFontSize.store.loadData(fontSize);
|
|||
|
this.cmbFontSize.select(this.cmbFontSize.store.getAt(3));
|
|||
|
if (this.api) {
|
|||
|
this.api.asc_registerCallback("asc_onTextColor", Ext.bind(this._onTextColor, this));
|
|||
|
this.api.asc_registerCallback("asc_onLockHeaderFooters", Ext.bind(this._onLockHeaderFooters, this));
|
|||
|
this.api.asc_registerCallback("asc_onUnLockHeaderFooters", Ext.bind(this._onUnLockHeaderFooters, this));
|
|||
|
var schemes = this.api.get_PropertyThemeColorSchemes();
|
|||
|
if (schemes) {
|
|||
|
this._onSendThemeColorSchemes(schemes);
|
|||
|
}
|
|||
|
}
|
|||
|
if (this.needShowSynchTip) {
|
|||
|
this.needShowSynchTip = false;
|
|||
|
this._onCollaborativeChanges();
|
|||
|
}
|
|||
|
},
|
|||
|
textBold: "Bold",
|
|||
|
textItalic: "Italic",
|
|||
|
textUnderline: "Underline",
|
|||
|
textStrikeout: "Strikeout",
|
|||
|
textSuperscript: "Superscript",
|
|||
|
textSubscript: "Subscript",
|
|||
|
strMenuNoFill: "No Fill",
|
|||
|
tipFontName: "Font Name",
|
|||
|
tipFontSize: "Font Size",
|
|||
|
tipCopy: "Copy",
|
|||
|
tipPaste: "Paste",
|
|||
|
tipUndo: "Undo",
|
|||
|
tipRedo: "Redo",
|
|||
|
tipPrint: "Print",
|
|||
|
tipSave: "Save",
|
|||
|
tipIncFont: "Increment font size",
|
|||
|
tipDecFont: "Decrement font size",
|
|||
|
tipHighlightColor: "Highlight color",
|
|||
|
tipFontColor: "Font color",
|
|||
|
tipMarkers: "Bullets",
|
|||
|
tipNumbers: "Numbering",
|
|||
|
tipMultilevels: "Outline",
|
|||
|
tipAlignLeft: "Align Left",
|
|||
|
tipAlignRight: "Align Right",
|
|||
|
tipAlignCenter: "Align Center",
|
|||
|
tipAlignJust: "Justified",
|
|||
|
tipDecPrLeft: "Decrease Indent",
|
|||
|
tipIncPrLeft: "Increase Indent",
|
|||
|
tipShowHiddenChars: "Nonprinting Characters",
|
|||
|
tipLineSpace: "Paragraph Line Spacing",
|
|||
|
tipPrColor: "Background color",
|
|||
|
tipInsertTable: "Insert Table",
|
|||
|
tipInsertImage: "Insert Picture",
|
|||
|
tipPageBreak: "Insert Page Break",
|
|||
|
tipInsertNum: "Insert Page Number",
|
|||
|
tipClearStyle: "Clear Style",
|
|||
|
tipCopyStyle: "Copy Style",
|
|||
|
tipPageSize: "Page Size",
|
|||
|
tipPageOrient: "Page Orientation",
|
|||
|
tipBack: "Back",
|
|||
|
tipInsertShape: "Insert Autoshape",
|
|||
|
mniImageFromFile: "Picture from file",
|
|||
|
mniImageFromUrl: "Picture from url",
|
|||
|
mniCustomTable: "Insert Custom Table",
|
|||
|
textTitleError: "Error",
|
|||
|
textInsertPageNumber: "Insert page number",
|
|||
|
textToCurrent: "To Current Position",
|
|||
|
tipEditHeader: "Edit Document Header or Footer",
|
|||
|
mniEditHeader: "Edit Document Header",
|
|||
|
mniEditFooter: "Edit Document Footer",
|
|||
|
tipInsertHyperlink: "Add Hyperlink",
|
|||
|
mniHiddenChars: "Nonprinting Characters",
|
|||
|
mniHiddenBorders: "Hidden Table Borders",
|
|||
|
tipNewDocument: "New Document",
|
|||
|
tipOpenDocument: "Open Document",
|
|||
|
tipSynchronize: "The document has been changed by another user. Please click to save your changes and reload the updates.",
|
|||
|
textNewColor: "Add New Custom Color",
|
|||
|
tipInsertChart: "Insert Chart",
|
|||
|
textLine: "Line Chart",
|
|||
|
textColumn: "Column Chart",
|
|||
|
textBar: "Bar Chart",
|
|||
|
textArea: "Area Chart",
|
|||
|
textPie: "Pie Chart",
|
|||
|
textPoint: "Point Chart",
|
|||
|
textStock: "Stock Chart",
|
|||
|
textThemeColors: "Theme Colors",
|
|||
|
textStandartColors: "Standart Colors",
|
|||
|
tipColorSchemas: "Change Color Scheme",
|
|||
|
tipInsertText: "Insert Text",
|
|||
|
tipHAligh: "Horizontal Align",
|
|||
|
tipViewSettings: "View Settings",
|
|||
|
tipAdvSettings: "Advanced Settings",
|
|||
|
textCompactView: "View Compact Toolbar",
|
|||
|
textHideTitleBar: "Hide Title Bar",
|
|||
|
textHideStatusBar: "Hide Status Bar",
|
|||
|
textHideLines: "Hide Lines",
|
|||
|
textFitPage: "Fit Page",
|
|||
|
textFitWidth: "Fit Width",
|
|||
|
textZoom: "Zoom",
|
|||
|
mniEditDropCap: "Drop Cap Settings",
|
|||
|
textNone: "None",
|
|||
|
textInText: "In Text",
|
|||
|
textInMargin: "In Margin",
|
|||
|
tipDropCap: "Insert drop cap",
|
|||
|
txtScheme1: "Office",
|
|||
|
txtScheme2: "Grayscale",
|
|||
|
txtScheme3: "Apex",
|
|||
|
txtScheme4: "Aspect",
|
|||
|
txtScheme5: "Civic",
|
|||
|
txtScheme6: "Concourse",
|
|||
|
txtScheme7: "Equity",
|
|||
|
txtScheme8: "Flow",
|
|||
|
txtScheme9: "Foundry",
|
|||
|
txtScheme10: "Median",
|
|||
|
txtScheme11: "Metro",
|
|||
|
txtScheme12: "Module",
|
|||
|
txtScheme13: "Opulent",
|
|||
|
txtScheme14: "Oriel",
|
|||
|
txtScheme15: "Origin",
|
|||
|
txtScheme16: "Paper",
|
|||
|
txtScheme17: "Solstice",
|
|||
|
txtScheme18: "Technic",
|
|||
|
txtScheme19: "Trek",
|
|||
|
txtScheme20: "Urban",
|
|||
|
txtScheme21: "Verve"
|
|||
|
});
|