/* * * (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 * */ /** * DocumentHolder.js * * DocumentHolder view * * Created by Julia Radzhabova on 3/28/14 * Copyright (c) 2018 Ascensio System SIA. All rights reserved. * */ define([ 'jquery', 'underscore', 'backbone', 'gateway', 'common/main/lib/component/Menu' ], function ($, _, Backbone, gateway) { 'use strict'; SSE.Views.DocumentHolder = Backbone.View.extend(_.extend({ el: '#editor_sdk', // Compile our stats template template: null, // Delegated events for creating new items, and clearing completed ones. events: { }, initialize: function() { var me = this; this.setApi = function(api) { me.api = api; return me; }; }, render: function() { this.fireEvent('render:before', this); this.cmpEl = $(this.el); this.fireEvent('render:after', this); return this; }, focus: function() { var me = this; _.defer(function(){ me.cmpEl && me.cmpEl.focus(); }, 50); }, createDelayedElementsViewer: function() { var me = this; me.menuViewCopy = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-copy', caption: me.txtCopy, value: 'copy' }); me.menuViewUndo = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-undo', caption: me.textUndo }); me.menuViewCopySeparator = new Common.UI.MenuItem({ caption: '--' }); me.menuViewAddComment = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-menu-comments', id: 'id-context-menu-item-view-add-comment', caption: me.txtAddComment }); me.menuSignatureViewSign = new Common.UI.MenuItem({caption: this.strSign, value: 0 }); me.menuSignatureDetails = new Common.UI.MenuItem({caption: this.strDetails, value: 1 }); me.menuSignatureViewSetup = new Common.UI.MenuItem({caption: this.strSetup, value: 2 }); me.menuSignatureRemove = new Common.UI.MenuItem({caption: this.strDelete, value: 3 }); me.menuViewSignSeparator = new Common.UI.MenuItem({caption: '--' }); this.viewModeMenu = new Common.UI.Menu({ cls: 'shifted-right', items: [ me.menuViewCopy, me.menuViewUndo, me.menuViewCopySeparator, me.menuSignatureViewSign, me.menuSignatureDetails, me.menuSignatureViewSetup, me.menuSignatureRemove, me.menuViewSignSeparator, me.menuViewAddComment ] }); me.fireEvent('createdelayedelements', [me]); }, createDelayedElements: function() { var me = this; me.pmiCut = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-cut', caption : me.txtCut, value : 'cut' }); me.pmiCopy = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-copy', caption : me.txtCopy, value : 'copy' }); me.pmiPaste = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-paste', caption : me.txtPaste, value : 'paste' }); me.pmiSelectTable = new Common.UI.MenuItem({ caption : me.txtSelect, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign : 'tl-tr', items: [ { caption: this.selectRowText, value: Asc.c_oAscChangeSelectionFormatTable.row}, { caption: this.selectColumnText, value: Asc.c_oAscChangeSelectionFormatTable.column}, { caption: this.selectDataText, value: Asc.c_oAscChangeSelectionFormatTable.data}, { caption: this.selectTableText, value: Asc.c_oAscChangeSelectionFormatTable.all} ] }) }); me.pmiInsertEntire = new Common.UI.MenuItem({ caption : me.txtInsert }); me.pmiInsertCells = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-addcell', caption : me.txtInsert, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign : 'tl-tr', items: [ { caption : me.txtShiftRight, value : Asc.c_oAscInsertOptions.InsertCellsAndShiftRight },{ caption : me.txtShiftDown, value : Asc.c_oAscInsertOptions.InsertCellsAndShiftDown },{ caption : me.txtRow, value : Asc.c_oAscInsertOptions.InsertRows },{ caption : me.txtColumn, value : Asc.c_oAscInsertOptions.InsertColumns } ] }) }); me.pmiInsertTable = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-addcell', caption : me.txtInsert, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign : 'tl-tr', items: [ { caption: me.insertRowAboveText, value: Asc.c_oAscInsertOptions.InsertTableRowAbove}, { caption: me.insertRowBelowText, value: Asc.c_oAscInsertOptions.InsertTableRowBelow}, { caption: me.insertColumnLeftText, value: Asc.c_oAscInsertOptions.InsertTableColLeft}, { caption: me.insertColumnRightText, value: Asc.c_oAscInsertOptions.InsertTableColRight} ] }) }); me.pmiDeleteEntire = new Common.UI.MenuItem({ caption : me.txtDelete }); me.pmiDeleteCells = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-delcell', caption : me.txtDelete, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign : 'tl-tr', items: [ { caption : me.txtShiftLeft, value : Asc.c_oAscDeleteOptions.DeleteCellsAndShiftLeft },{ caption : me.txtShiftUp, value : Asc.c_oAscDeleteOptions.DeleteCellsAndShiftTop },{ caption : me.txtRow, value : Asc.c_oAscDeleteOptions.DeleteRows },{ caption : me.txtColumn, value : Asc.c_oAscDeleteOptions.DeleteColumns } ] }) }); me.pmiDeleteTable = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-delcell', caption : me.txtDelete, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign : 'tl-tr', items: [ { caption: this.deleteRowText, value: Asc.c_oAscDeleteOptions.DeleteRows}, { caption: this.deleteColumnText, value: Asc.c_oAscDeleteOptions.DeleteColumns}, { caption: this.deleteTableText, value: Asc.c_oAscDeleteOptions.DeleteTable} ] }) }); me.pmiClear = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-clearstyle', caption : me.txtClear, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign : 'tl-tr', items: [ { caption : me.txtClearAll, value : Asc.c_oAscCleanOptions.All }, { caption : me.txtClearText, value : Asc.c_oAscCleanOptions.Text }, { caption : me.txtClearFormat, value : Asc.c_oAscCleanOptions.Format }, { caption : me.txtClearComments, value : Asc.c_oAscCleanOptions.Comments }, { caption : me.txtClearHyper, value : Asc.c_oAscCleanOptions.Hyperlinks } ] }) }); me.pmiSortCells = new Common.UI.MenuItem({ caption : me.txtSort, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign : 'tl-tr', items: [ { iconCls: 'menu__icon btn-sort-down', caption : me.txtAscending, value : Asc.c_oAscSortOptions.Ascending },{ iconCls: 'menu__icon btn-sort-up', caption : me.txtDescending, value : Asc.c_oAscSortOptions.Descending },{ caption : me.txtSortCellColor, value : Asc.c_oAscSortOptions.ByColorFill },{ caption : me.txtSortFontColor, value : Asc.c_oAscSortOptions.ByColorFont },{ caption : me.txtCustomSort, value : 'advanced' } ] }) }); me.pmiFilterCells = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-autofilter', caption : me.txtFilter, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign : 'tl-tr', items: [ { caption : me.txtFilterValue, value : 0 },{ caption : me.txtFilterCellColor, value : 1 },{ caption : me.txtFilterFontColor, value : 2 } ] }) }); me.pmiReapply = new Common.UI.MenuItem({ caption : me.txtReapply }); me.mnuRefreshPivot = new Common.UI.MenuItem({ caption : me.txtRefresh }); me.mnuGroupPivot = new Common.UI.MenuItem({ caption : this.txtGroup, value : 'grouping' }); me.mnuUnGroupPivot = new Common.UI.MenuItem({ caption : this.txtUngroup, value : 'ungrouping' }); me.pmiInsFunction = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-function', caption : me.txtFormula }); me.menuAddHyperlink = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-inserthyperlink', caption : me.txtInsHyperlink, inCell : true }); me.menuEditHyperlink = new Common.UI.MenuItem({ caption : me.editHyperlinkText, inCell : true }); me.menuRemoveHyperlink = new Common.UI.MenuItem({ caption : me.removeHyperlinkText }); me.menuHyperlink = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-inserthyperlink', caption : me.txtInsHyperlink, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items : [ me.menuEditHyperlink, me.menuRemoveHyperlink ] }) }); me.pmiRowHeight = new Common.UI.MenuItem({ caption : me.txtRowHeight, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items : [ { caption: me.txtAutoRowHeight, value: 'auto-row-height' }, { caption: me.txtCustomRowHeight, value: 'row-height' } ] }) }); me.pmiColumnWidth = new Common.UI.MenuItem({ caption : me.txtColumnWidth, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items : [ { caption: me.txtAutoColumnWidth, value: 'auto-column-width' }, { caption: me.txtCustomColumnWidth, value: 'column-width' } ] }) }); me.pmiEntireHide = new Common.UI.MenuItem({ caption : me.txtHide }); me.pmiEntireShow = new Common.UI.MenuItem({ caption : me.txtShow }); me.pmiAddComment = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-menu-comments', id : 'id-context-menu-item-add-comment', caption : me.txtAddComment }); me.pmiCellMenuSeparator = new Common.UI.MenuItem({ caption : '--' }) me.pmiFunctionSeparator = new Common.UI.MenuItem({ caption : '--' }); me.pmiFreezeSeparator = new Common.UI.MenuItem({ caption : '--' }); me.pmiAddNamedRange = new Common.UI.MenuItem({ id : 'id-context-menu-item-add-named-range', caption : me.txtAddNamedRange }); me.pmiFreezePanes = new Common.UI.MenuItem({ caption : me.textFreezePanes }); me.pmiEntriesList = new Common.UI.MenuItem({ caption : me.textEntriesList }); me.pmiSparklines = new Common.UI.MenuItem({ caption : me.txtSparklines, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items : [ { caption: me.txtClearSparklines, value: Asc.c_oAscCleanOptions.Sparklines }, { caption: me.txtClearSparklineGroups, value: Asc.c_oAscCleanOptions.SparklineGroups } ] }) }); var numFormatTemplate = _.template(''+ '
'+ '
<%= caption %>
' + '' + '
'); me.pmiNumFormat = new Common.UI.MenuItem({ caption: me.txtNumFormat, menu: new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items: [ { caption: this.txtGeneral, template: numFormatTemplate, checkable: true, format: 'General', exampleval: '100', value: Asc.c_oAscNumFormatType.General }, { caption: this.txtNumber, template: numFormatTemplate, checkable: true, format: '0.00', exampleval: '100,00', value: Asc.c_oAscNumFormatType.Number }, { caption: this.txtScientific, template: numFormatTemplate, checkable: true, format: '0.00E+00', exampleval: '1,00E+02', value: Asc.c_oAscNumFormatType.Scientific }, { caption: this.txtAccounting, template: numFormatTemplate, checkable: true, format: '_($* #,##0.00_);_($* (#,##0.00);_($* "-"??_);_(@_)', exampleval: '100,00 $', value: Asc.c_oAscNumFormatType.Accounting }, { caption: this.txtCurrency, template: numFormatTemplate, checkable: true, format: '$#,##0.00', exampleval: '100,00 $', value: Asc.c_oAscNumFormatType.Currency }, { caption: this.txtDate, template: numFormatTemplate, checkable: true, format: 'MM-dd-yyyy', exampleval: '04-09-1900', value: Asc.c_oAscNumFormatType.Date }, { caption: this.txtTime, template: numFormatTemplate, checkable: true, format: 'HH:MM:ss', exampleval: '00:00:00', value: Asc.c_oAscNumFormatType.Time }, { caption: this.txtPercentage, template: numFormatTemplate, checkable: true, format: '0.00%', exampleval: '100,00%', value: Asc.c_oAscNumFormatType.Percent }, { caption: this.txtFraction, template: numFormatTemplate, checkable: true, format: '# ?/?', exampleval: '100', value: Asc.c_oAscNumFormatType.Fraction }, { caption: this.txtText, template: numFormatTemplate, checkable: true, format: '@', exampleval: '100', value: Asc.c_oAscNumFormatType.Text }, {caption: '--'}, me.pmiAdvancedNumFormat = new Common.UI.MenuItem({ caption: me.textMoreFormats, value: 'advanced' }) ] }) }); me.pmiCondFormat = new Common.UI.MenuItem({ caption : me.txtCondFormat }); me.pmiGetRangeList = new Common.UI.MenuItem({ caption : me.txtGetLink }); me.ssMenu = new Common.UI.Menu({ cls: 'shifted-right', restoreHeightAndTop: true, id : 'id-context-menu-cell', items : [ me.pmiCut, me.pmiCopy, me.pmiPaste, {caption: '--'}, me.pmiSelectTable, me.pmiInsertEntire, me.pmiInsertCells, me.pmiInsertTable, me.pmiDeleteEntire, me.pmiDeleteCells, me.pmiDeleteTable, me.pmiClear, {caption: '--'}, me.pmiSparklines, me.pmiSortCells, me.pmiFilterCells, me.pmiReapply, me.mnuRefreshPivot, me.mnuGroupPivot, me.mnuUnGroupPivot, {caption: '--'}, me.pmiAddComment, me.pmiCellMenuSeparator, me.pmiNumFormat, me.pmiCondFormat, me.pmiEntriesList, me.pmiGetRangeList, me.pmiAddNamedRange, me.pmiFunctionSeparator, me.pmiInsFunction, me.menuAddHyperlink, me.menuHyperlink, me.pmiRowHeight, me.pmiColumnWidth, me.pmiEntireHide, me.pmiEntireShow, me.pmiFreezeSeparator, me.pmiFreezePanes ] }); me.mnuGroupImg = new Common.UI.MenuItem({ caption : this.txtGroup, iconCls : 'menu__icon shape-group', type : 'group', value : 'grouping' }); me.mnuUnGroupImg = new Common.UI.MenuItem({ caption : this.txtUngroup, iconCls : 'menu__icon shape-ungroup', type : 'group', value : 'ungrouping' }); me.mnuShapeSeparator = new Common.UI.MenuItem({ caption : '--' }); me.mnuShapeAdvanced = new Common.UI.MenuItem({ iconCls : 'menu__icon btn-menu-shape', caption : me.advancedShapeText }); me.mnuImgAdvanced = new Common.UI.MenuItem({ iconCls : 'menu__icon btn-menu-image', caption : me.advancedImgText }); me.mnuSlicerSeparator = new Common.UI.MenuItem({ caption : '--' }); me.mnuSlicerAdvanced = new Common.UI.MenuItem({ iconCls : 'menu__icon btn-slicer', caption : me.advancedSlicerText }); me.mnuChartEdit = new Common.UI.MenuItem({ iconCls : 'menu__icon btn-menu-chart', caption : me.chartText }); me.mnuChartData = new Common.UI.MenuItem({ iconCls : 'menu__icon btn-select-range', caption : me.chartDataText }); me.mnuChartType = new Common.UI.MenuItem({ caption : me.chartTypeText }); me.pmiImgCut = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-cut', caption : me.txtCut, value : 'cut' }); me.pmiImgCopy = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-copy', caption : me.txtCopy, value : 'copy' }); me.pmiImgPaste = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-paste', caption : me.txtPaste, value : 'paste' }); me.menuSignatureEditSign = new Common.UI.MenuItem({caption: this.strSign, value: 0 }); me.menuSignatureEditSetup = new Common.UI.MenuItem({caption: this.strSetup, value: 2 }); me.menuEditSignSeparator = new Common.UI.MenuItem({ caption: '--' }); me.menuImgOriginalSize = new Common.UI.MenuItem({ caption : me.originalSizeText }); me.menuImgReplace = new Common.UI.MenuItem({ caption : me.textReplace, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items: [ new Common.UI.MenuItem({caption : this.textFromFile, value: 'file'}), new Common.UI.MenuItem({caption : this.textFromUrl, value: 'url'}), new Common.UI.MenuItem({caption : this.textFromStorage, value: 'storage'}) ] }) }); me.menuImgCrop = new Common.UI.MenuItem({ caption : me.textCrop, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items: [ new Common.UI.MenuItem({ caption: me.textCrop, checkable: true, allowDepress: true, value : 0 }), new Common.UI.MenuItem({ caption: me.textCropFill, value : 1 }), new Common.UI.MenuItem({ caption: me.textCropFit, value : 2 }) ] }) }); me.mnuBringToFront = new Common.UI.MenuItem({ caption : this.textArrangeFront, iconCls : 'menu__icon arrange-front', type : 'arrange', value : Asc.c_oAscDrawingLayerType.BringToFront }); me.mnuSendToBack = new Common.UI.MenuItem({ caption : this.textArrangeBack, iconCls : 'menu__icon arrange-back', type : 'arrange', value : Asc.c_oAscDrawingLayerType.SendToBack }); me.mnuBringForward = new Common.UI.MenuItem({ caption : this.textArrangeForward, iconCls : 'menu__icon arrange-forward', type : 'arrange', value : Asc.c_oAscDrawingLayerType.BringForward }); me.mnuSendBackward = new Common.UI.MenuItem({ caption: this.textArrangeBackward, iconCls : 'menu__icon arrange-backward', type : 'arrange', value : Asc.c_oAscDrawingLayerType.SendBackward }); me.menuImageArrange = new Common.UI.MenuItem({ caption : me.textArrange, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items: [ me.mnuBringToFront, me.mnuSendToBack, me.mnuBringForward, me.mnuSendBackward, { caption: '--' }, me.mnuGroupImg, me.mnuUnGroupImg ] }) }); me.menuImageAlign = new Common.UI.MenuItem({ caption : me.textAlign, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items: [{ caption : me.textShapeAlignLeft, iconCls : 'menu__icon shape-align-left', value : 0 }, { caption : me.textShapeAlignCenter, iconCls : 'menu__icon shape-align-center', value : 4 }, { caption : me.textShapeAlignRight, iconCls : 'menu__icon shape-align-right', value : 1 }, { caption : me.textShapeAlignTop, iconCls : 'menu__icon shape-align-top', value : 3 }, { caption : me.textShapeAlignMiddle, iconCls : 'menu__icon shape-align-middle', value : 5 }, { caption : me.textShapeAlignBottom, iconCls : 'menu__icon shape-align-bottom', value : 2 }, {caption: '--'}, { caption: me.txtDistribHor, iconCls: 'menu__icon shape-distribute-hor', value: 6 }, { caption: me.txtDistribVert, iconCls: 'menu__icon shape-distribute-vert', value: 7 }] }) }); me.menuImgRotate = new Common.UI.MenuItem({ caption : me.textRotate, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items: [ new Common.UI.MenuItem({ iconCls: 'menu__icon btn-rotate-90', caption: me.textRotate90, type : 'rotate', value : 1 }), new Common.UI.MenuItem({ iconCls: 'menu__icon btn-rotate-270', caption: me.textRotate270, type : 'rotate', value : 0 }), { caption: '--' }, new Common.UI.MenuItem({ iconCls: 'menu__icon btn-flip-hor', caption: me.textFlipH, type : 'flip', value : 1 }), new Common.UI.MenuItem({ iconCls: 'menu__icon btn-flip-vert', caption: me.textFlipV, type : 'flip', value : 0 }) ] }) }); me.menuImgMacro = new Common.UI.MenuItem({ caption: me.textMacro }); me.menuImgEditPoints = new Common.UI.MenuItem({ caption: me.textEditPoints }); me.menuImgEditPointsSeparator = new Common.UI.MenuItem({ caption : '--' }); this.imgMenu = new Common.UI.Menu({ cls: 'shifted-right', restoreHeightAndTop: true, items: [ me.pmiImgCut, me.pmiImgCopy, me.pmiImgPaste, {caption: '--'}, me.menuSignatureEditSign, me.menuSignatureEditSetup, me.menuEditSignSeparator, me.menuImgEditPoints, me.menuImgEditPointsSeparator, me.menuImageArrange, me.menuImageAlign, me.menuImgRotate, me.menuImgMacro, me.mnuShapeSeparator, me.menuImgCrop, me.mnuChartData, me.mnuChartType, me.mnuChartEdit, me.mnuShapeAdvanced, me.menuImgOriginalSize, me.menuImgReplace, me.mnuImgAdvanced, me.mnuSlicerSeparator, me.mnuSlicerAdvanced ] }); this.menuParagraphVAlign = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-align-top', caption : this.vertAlignText, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign : 'tl-tr', items: [ me.menuParagraphTop = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-align-top', caption : me.topCellText, checkable : true, checkmark : false, toggleGroup : 'popupparagraphvalign', value : Asc.c_oAscVAlign.Top }), me.menuParagraphCenter = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-align-middle', caption : me.centerCellText, checkable : true, checkmark : false, toggleGroup : 'popupparagraphvalign', value : Asc.c_oAscVAlign.Center }), this.menuParagraphBottom = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-align-bottom', caption : me.bottomCellText, checkable : true, checkmark : false, toggleGroup : 'popupparagraphvalign', value : Asc.c_oAscVAlign.Bottom }) ] }) }); me.menuParagraphDirection = new Common.UI.MenuItem({ iconCls: 'menu__icon text-orient-hor', caption : me.directionText, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items : [ me.menuParagraphDirectH = new Common.UI.MenuItem({ caption : me.directHText, iconCls : 'menu__icon text-orient-hor', checkable : true, checkmark : false, checked : false, toggleGroup : 'popupparagraphdirect', direction : Asc.c_oAscVertDrawingText.normal }), me.menuParagraphDirect90 = new Common.UI.MenuItem({ caption : me.direct90Text, iconCls : 'menu__icon text-orient-rdown', checkable : true, checkmark : false, checked : false, toggleGroup : 'popupparagraphdirect', direction : Asc.c_oAscVertDrawingText.vert }), me.menuParagraphDirect270 = new Common.UI.MenuItem({ caption : me.direct270Text, iconCls : 'menu__icon text-orient-rup', checkable : true, checkmark : false, checked : false, toggleGroup : 'popupparagraphdirect', direction : Asc.c_oAscVertDrawingText.vert270 }) ] }) }); me.menuParagraphBullets = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-setmarkers', caption : me.bulletsText, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items : [ { template: _.template('') }, {caption: '--'}, me.menuParagraphBulletNone = new Common.UI.MenuItem({ caption : me.textNone, checkable : true, checked : false, value : -1 }), me.mnuListSettings = new Common.UI.MenuItem({ caption: me.textListSettings, value: 'settings' }) ] }) }); me._markersArr = [ {type: Asc.asc_PreviewBulletType.char, char: String.fromCharCode(0x00B7), specialFont: 'Symbol'}, {type: Asc.asc_PreviewBulletType.char, char: 'o', specialFont: 'Courier New'}, {type: Asc.asc_PreviewBulletType.char, char: String.fromCharCode(0x00A7), specialFont: 'Wingdings'}, {type: Asc.asc_PreviewBulletType.char, char: String.fromCharCode(0x0076), specialFont: 'Wingdings'}, {type: Asc.asc_PreviewBulletType.char, char: String.fromCharCode(0x00D8), specialFont: 'Wingdings'}, {type: Asc.asc_PreviewBulletType.char, char: String.fromCharCode(0x00FC), specialFont: 'Wingdings'}, {type: Asc.asc_PreviewBulletType.char, char: String.fromCharCode(0x00A8), specialFont: 'Symbol'}, {type: Asc.asc_PreviewBulletType.char, char: String.fromCharCode(0x2013), specialFont: 'Arial'} ]; me.paraBulletsPicker = { conf: {rec: null}, delayRenderTips: true, store : new Common.UI.DataViewStore([ {group: 'menu-list-bullet-group', id: 'id-markers-' + Common.UI.getId(), type: 0, subtype: 1, drawdata: me._markersArr[0], skipRenderOnChange: true, tip: this.tipMarkersFRound}, {group: 'menu-list-bullet-group', id: 'id-markers-' + Common.UI.getId(), type: 0, subtype: 2, drawdata: me._markersArr[1], skipRenderOnChange: true, tip: this.tipMarkersHRound}, {group: 'menu-list-bullet-group', id: 'id-markers-' + Common.UI.getId(), type: 0, subtype: 3, drawdata: me._markersArr[2], skipRenderOnChange: true, tip: this.tipMarkersFSquare}, {group: 'menu-list-bullet-group', id: 'id-markers-' + Common.UI.getId(), type: 0, subtype: 4, drawdata: me._markersArr[3], skipRenderOnChange: true, tip: this.tipMarkersStar}, {group: 'menu-list-bullet-group', id: 'id-markers-' + Common.UI.getId(), type: 0, subtype: 5, drawdata: me._markersArr[4], skipRenderOnChange: true, tip: this.tipMarkersArrow}, {group: 'menu-list-bullet-group', id: 'id-markers-' + Common.UI.getId(), type: 0, subtype: 6, drawdata: me._markersArr[5], skipRenderOnChange: true, tip: this.tipMarkersCheckmark}, {group: 'menu-list-bullet-group', id: 'id-markers-' + Common.UI.getId(), type: 0, subtype: 7, drawdata: me._markersArr[6], skipRenderOnChange: true, tip: this.tipMarkersFRhombus}, {group: 'menu-list-bullet-group', id: 'id-markers-' + Common.UI.getId(), type: 0, subtype: 8, drawdata: me._markersArr[7], skipRenderOnChange: true, tip: this.tipMarkersDash}, {group: 'menu-list-number-group', id: 'id-numbers-' + Common.UI.getId(), type: 1, subtype: 4, drawdata: {type: Asc.asc_PreviewBulletType.number, numberingType: Asc.asc_oAscNumberingLevel.UpperLetterDot_Left}, skipRenderOnChange: true, tip: this.tipNumCapitalLetters}, {group: 'menu-list-number-group', id: 'id-numbers-' + Common.UI.getId(), type: 1, subtype: 5, drawdata: {type: Asc.asc_PreviewBulletType.number, numberingType: Asc.asc_oAscNumberingLevel.LowerLetterBracket_Left}, skipRenderOnChange: true, tip: this.tipNumLettersParentheses}, {group: 'menu-list-number-group', id: 'id-numbers-' + Common.UI.getId(), type: 1, subtype: 6, drawdata: {type: Asc.asc_PreviewBulletType.number, numberingType: Asc.asc_oAscNumberingLevel.LowerLetterDot_Left}, skipRenderOnChange: true, tip: this.tipNumLettersPoints}, {group: 'menu-list-number-group', id: 'id-numbers-' + Common.UI.getId(), type: 1, subtype: 1, drawdata: {type: Asc.asc_PreviewBulletType.number, numberingType: Asc.asc_oAscNumberingLevel.DecimalDot_Right}, skipRenderOnChange: true, tip: this.tipNumNumbersPoint}, {group: 'menu-list-number-group', id: 'id-numbers-' + Common.UI.getId(), type: 1, subtype: 2, drawdata: {type: Asc.asc_PreviewBulletType.number, numberingType: Asc.asc_oAscNumberingLevel.DecimalBracket_Right}, skipRenderOnChange: true, tip: this.tipNumNumbersParentheses}, {group: 'menu-list-number-group', id: 'id-numbers-' + Common.UI.getId(), type: 1, subtype: 3, drawdata: {type: Asc.asc_PreviewBulletType.number, numberingType: Asc.asc_oAscNumberingLevel.UpperRomanDot_Right}, skipRenderOnChange: true, tip: this.tipNumRoman}, {group: 'menu-list-number-group', id: 'id-numbers-' + Common.UI.getId(), type: 1, subtype: 7, drawdata: {type: Asc.asc_PreviewBulletType.number, numberingType: Asc.asc_oAscNumberingLevel.LowerRomanDot_Right}, skipRenderOnChange: true, tip: this.tipNumRomanSmall} ]), groups: new Common.UI.DataViewGroupStore([ {id: 'menu-list-bullet-group', caption: this.textBullets}, {id: 'menu-list-number-group', caption: this.textNumbering} ]), selectRecord: function (rec) { this.conf.rec = rec; } }; me.menuAddHyperlinkShape = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-inserthyperlink', caption : me.txtInsHyperlink }); me.menuEditHyperlinkShape = new Common.UI.MenuItem({ caption : me.editHyperlinkText }); me.menuRemoveHyperlinkShape = new Common.UI.MenuItem({ caption : me.removeHyperlinkText }); me.menuHyperlinkShape = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-inserthyperlink', caption : me.txtInsHyperlink, menu : new Common.UI.Menu({ cls: 'shifted-right', menuAlign: 'tl-tr', items : [ me.menuEditHyperlinkShape, me.menuRemoveHyperlinkShape ] }) }); this.pmiTextAdvanced = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-paragraph', caption : me.txtTextAdvanced }); me.pmiTextCut = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-cut', caption : me.txtCut, value : 'cut' }); me.pmiTextCopy = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-copy', caption : me.txtCopy, value : 'copy' }); me.pmiTextPaste = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-paste', caption : me.txtPaste, value : 'paste' }); this.textInShapeMenu = new Common.UI.Menu({ cls: 'shifted-right', items: [ me.pmiTextCut, me.pmiTextCopy, me.pmiTextPaste, {caption: '--'}, me.menuParagraphVAlign, me.menuParagraphDirection, me.menuParagraphBullets, me.menuAddHyperlinkShape, me.menuHyperlinkShape, {caption: '--'}, me.pmiTextAdvanced ] }); me.pmiCommonCut = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-cut', caption : me.txtCut, value : 'cut' }); me.pmiCommonCopy = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-copy', caption : me.txtCopy, value : 'copy' }); me.pmiCommonPaste = new Common.UI.MenuItem({ iconCls: 'menu__icon btn-paste', caption : me.txtPaste, value : 'paste' }); this.copyPasteMenu = new Common.UI.Menu({ cls: 'shifted-right', items: [ me.pmiCommonCut, me.pmiCommonCopy, me.pmiCommonPaste ] }); this.entriesMenu = new Common.UI.Menu({ maxHeight: 200, cyclic: false, items: [] }).on('show:after', function () { this.scroller.update({alwaysVisibleY: true}); }).on('keydown:before', function (menu, e) { if (e.altKey && e.keyCode == Common.UI.Keys.DOWN) { var li = $(e.target).closest('li'); if (li.length>0) li.click(); else menu.hide(); } }); this.funcMenu = new Common.UI.Menu({ maxHeight: 200, cyclic: false, items: [] }).on('render:after', function(mnu) { mnu.cmpEl.removeAttr('oo_editor_input').attr('oo_editor_keyboard', true); }); this.tableTotalMenu = new Common.UI.Menu({ maxHeight: 160, menuAlign: 'tr-br', cyclic: false, cls: 'lang-menu', items: [ {caption: this.textNone, value: Asc.ETotalsRowFunction.totalrowfunctionNone, checkable: true}, {caption: this.textAverage, value: Asc.ETotalsRowFunction.totalrowfunctionAverage, checkable: true }, {caption: this.textCount, value: Asc.ETotalsRowFunction.totalrowfunctionCount, checkable: true }, {caption: this.textMax, value: Asc.ETotalsRowFunction.totalrowfunctionMax, checkable: true }, {caption: this.textMin, value: Asc.ETotalsRowFunction.totalrowfunctionMin, checkable: true }, {caption: this.textSum, value: Asc.ETotalsRowFunction.totalrowfunctionSum, checkable: true }, {caption: this.textStdDev, value: Asc.ETotalsRowFunction.totalrowfunctionStdDev, checkable: true }, {caption: this.textVar, value: Asc.ETotalsRowFunction.totalrowfunctionVar, checkable: true }, {caption: this.textMore, value: Asc.ETotalsRowFunction.totalrowfunctionCustom, checkable: true } ] }); me.fireEvent('createdelayedelements', [me]); }, setMenuItemCommentCaptionMode: function (item, add, editable) { item.setCaption(add ? this.txtAddComment : (editable ? this.txtEditComment : this.txtShowComment), true); }, txtSort: 'Sort', txtAscending: 'Ascending', txtDescending: 'Descending', txtFormula: 'Insert Function', txtInsHyperlink: 'Hyperlink', txtCut: 'Cut', txtCopy: 'Copy', txtPaste: 'Paste', txtInsert: 'Insert', txtDelete: 'Delete', txtClear: 'Clear', txtClearAll: 'All', txtClearText: 'Text', txtClearFormat: 'Format', txtClearHyper: 'Hyperlink', txtClearComments: 'Comments', txtShiftRight: 'Shift cells right', txtShiftLeft: 'Shift cells left', txtShiftUp: 'Shift cells up', txtShiftDown: 'Shift cells down', txtRow: 'Entire Row', txtColumn: 'Entire Column', txtColumnWidth: 'Set Column Width', txtRowHeight: 'Set Row Height', txtWidth: 'Width', txtHide: 'Hide', txtShow: 'Show', textArrangeFront: 'Bring To Front', textArrangeBack: 'Send To Back', textArrangeForward: 'Bring Forward', textArrangeBackward: 'Send Backward', txtArrange: 'Arrange', txtAddComment: 'Add Comment', txtEditComment: 'Edit Comment', txtUngroup: 'Ungroup', txtGroup: 'Group', topCellText: 'Align Top', centerCellText: 'Align Middle', bottomCellText: 'Align Bottom', vertAlignText: 'Vertical Alignment', txtTextAdvanced: 'Text Advanced Settings', editHyperlinkText: 'Edit Hyperlink', removeHyperlinkText: 'Remove Hyperlink', editChartText: 'Edit Data', advancedShapeText: 'Shape Advanced Settings', chartText: 'Chart Advanced Settings', directionText: 'Text Direction', directHText: 'Horizontal', direct90Text: 'Rotate Text Down', direct270Text: 'Rotate Text Up', txtAddNamedRange: 'Define Name', textFreezePanes: 'Freeze Panes', textUnFreezePanes: 'Unfreeze Panes', txtSelect: 'Select', selectRowText : 'Row', selectColumnText : 'Entire Column', selectDataText : 'Column Data', selectTableText : 'Table', insertRowAboveText : 'Row Above', insertRowBelowText : 'Row Below', insertColumnLeftText : 'Column Left', insertColumnRightText : 'Column Right', deleteRowText : 'Row', deleteColumnText : 'Column', deleteTableText : 'Table', txtFilter: 'Filter', txtFilterValue: 'Filter by Selected cell\'s value', txtFilterCellColor: 'Filter by cell\'s color', txtFilterFontColor: 'Filter by font color', txtReapply: 'Reapply', txtSortCellColor: 'Selected Cell Color on top', txtSortFontColor: 'Selected Font Color on top', txtAutoColumnWidth: 'Auto Fit Column Width', txtAutoRowHeight: 'Auto Fit Row Height', txtCustomColumnWidth: 'Custom Column Width', txtCustomRowHeight: 'Custom Row Height', textEntriesList: 'Select from drop-down list', txtSparklines: 'Sparklines', txtClearSparklines: 'Clear Selected Sparklines', txtClearSparklineGroups: 'Clear Selected Sparkline Groups', txtShowComment: 'Show Comment', advancedImgText: 'Image Advanced Settings', textNone: 'None', bulletsText: 'Bullets and Numbering', textUndo: 'Undo', strSign: 'Sign', strDetails: 'Signature Details', strSetup: 'Signature Setup', strDelete: 'Remove Signature', originalSizeText: 'Actual Size', textReplace: 'Replace image', textFromUrl: 'From URL', textFromFile: 'From File', txtNumFormat: 'Number Format', txtGeneral: 'General', txtNumber: 'Number', txtScientific: 'Scientific', txtAccounting: 'Accounting', txtCurrency: 'Currency', txtDate: 'Date', txtTime: 'Time', txtPercentage: 'Percentage', txtFraction: 'Fraction', txtText: 'Text', textMoreFormats: 'More formats', textShapeAlignLeft : 'Align Left', textShapeAlignRight : 'Align Right', textShapeAlignCenter : 'Align Center', textShapeAlignTop : 'Align Top', textShapeAlignBottom : 'Align Bottom', textShapeAlignMiddle : 'Align Middle', txtDistribHor: 'Distribute Horizontally', txtDistribVert: 'Distribute Vertically', textRotate270: 'Rotate 90° Counterclockwise', textRotate90: 'Rotate 90° Clockwise', textFlipV: 'Flip Vertically', textFlipH: 'Flip Horizontally', textRotate: 'Rotate', textArrange: 'Arrange', textAlign: 'Align', textCrop: 'Crop', textCropFill: 'Fill', textCropFit: 'Fit', textListSettings: 'List Settings', textFromStorage: 'From Storage', advancedSlicerText: 'Slicer Advanced Settings', textAverage: 'Average', textMax: 'Max', textMin: 'Min', textCount: 'Count', textSum: 'Sum', textStdDev: 'StdDev', textVar: 'Var', textMore: 'More functions', txtCustomSort: 'Custom sort', txtCondFormat: 'Conditional Formatting', textBullets: 'Bullets', textNumbering: 'Numbering', textMacro: 'Assign Macro', textEditPoints: 'Edit Points', tipNumCapitalLetters: 'A. B. C.', tipNumLettersParentheses: 'a) b) c)', tipNumLettersPoints: 'a. b. c.', tipNumNumbersPoint: '1. 2. 3.', tipNumNumbersParentheses: '1) 2) 3)', tipNumRoman: 'I. II. III.', tipNumRomanSmall: 'i. ii. iii.', tipMarkersFRound: 'Filled round bullets', tipMarkersHRound: 'Hollow round bullets', tipMarkersFSquare: 'Filled square bullets', tipMarkersStar: 'Star bullets', tipMarkersArrow: 'Arrow bullets', tipMarkersCheckmark: 'Checkmark bullets', tipMarkersFRhombus: 'Filled rhombus bullets', tipMarkersDash: 'Dash bullets', chartDataText: 'Select Chart Data', chartTypeText: 'Change Chart Type', txtGetLink: 'Get link to this range', txtRefresh: 'Refresh' }, SSE.Views.DocumentHolder || {})); });