/* * * (c) Copyright Ascensio System Limited 2010-2016 * * 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 * */ /** * ImageSettingsAdvanced.js * * Created by Julia Radzhabova on 3/03/14 * Copyright (c) 2014 Ascensio System SIA. All rights reserved. * */ define([ 'text!documenteditor/main/app/template/ImageSettingsAdvanced.template', 'common/main/lib/view/AdvancedSettingsWindow', 'common/main/lib/component/ComboBox', 'common/main/lib/component/MetricSpinner', 'common/main/lib/component/CheckBox', 'common/main/lib/component/RadioBox' ], function (contentTemplate) { 'use strict'; DE.Views.ImageSettingsAdvanced = Common.Views.AdvancedSettingsWindow.extend(_.extend({ options: { contentWidth: 340, height: 485, toggleGroup: 'image-adv-settings-group', sizeOriginal: {width: 0, height: 0}, sizeMax: {width: 55.88, height: 55.88}, properties: null }, initialize : function(options) { _.extend(this.options, { title: this.textTitle, items: [ {panelId: 'id-adv-image-width', panelCaption: this.textSize}, {panelId: 'id-adv-shape-size', panelCaption: this.textSize}, {panelId: 'id-adv-image-wrap', panelCaption: this.textBtnWrap}, {panelId: 'id-adv-image-position', panelCaption: this.textPosition}, {panelId: 'id-adv-image-shape', panelCaption: this.textShape}, {panelId: 'id-adv-image-margins', panelCaption: this.strMargins} ], contentTemplate: _.template(contentTemplate)({ scope: this }) }, options); Common.Views.AdvancedSettingsWindow.prototype.initialize.call(this, this.options); this.spinners = []; this._state = { HAlignType: Asc.c_oAscAlignH.Left, HAlignFrom: Asc.c_oAscRelativeFromH.Character, HPositionFrom: Asc.c_oAscRelativeFromH.Character, HPositionPcFrom: Asc.c_oAscRelativeFromH.Page, ShapeWidthPcFrom: Asc.c_oAscRelativeFromH.Margin, VAlignType: Asc.c_oAscAlignV.Top, VAlignFrom: Asc.c_oAscRelativeFromV.Line, VPositionFrom: Asc.c_oAscRelativeFromV.Line, VPositionPcFrom: Asc.c_oAscRelativeFromV.Page, ShapeHeightPcFrom: Asc.c_oAscRelativeFromV.Margin, spnXChanged: false, spnYChanged: false, spnXPcChanged: false, spnYPcChanged: false }; this._objectType = Asc.c_oAscTypeSelectElement.Image; this.Margins = undefined; this._nRatio = 1; this._originalProps = this.options.imageProps; this.pageWidth = this.options.sectionProps ? this.options.sectionProps.get_W() : 210; this.pageHeight = this.options.sectionProps ? this.options.sectionProps.get_H() : 297; this._changedProps = null; this._changedShapeProps = null; }, render: function() { Common.Views.AdvancedSettingsWindow.prototype.render.call(this); var me = this; // Image & Chart Size this.spnWidth = new Common.UI.MetricSpinner({ el: $('#image-advanced-spin-width'), step: .1, width: 80, defaultUnit : "cm", value: '3 cm', maxValue: 55.88, minValue: 0 }); this.spnWidth.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this.btnRatio.pressed) { var w = field.getNumberValue(); var h = w/this._nRatio; if (h>this.sizeMax.height) { h = this.sizeMax.height; w = h * this._nRatio; this.spnWidth.setValue(w, true); } this.spnHeight.setValue(h, true); } if (this._changedProps) { this._changedProps.put_Width(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); this._changedProps.put_Height(Common.Utils.Metric.fnRecalcToMM(this.spnHeight.getNumberValue())); } }, this)); this.spinners.push(this.spnWidth); this.spnHeight = new Common.UI.MetricSpinner({ el: $('#image-advanced-spin-height'), step: .1, width: 80, defaultUnit : "cm", value: '3 cm', maxValue: 55.88, minValue: 0 }); this.spnHeight.on('change', _.bind(function(field, newValue, oldValue, eOpts){ var h = field.getNumberValue(), w = null; if (this.btnRatio.pressed) { w = h * this._nRatio; if (w>this.sizeMax.width) { w = this.sizeMax.width; h = w/this._nRatio; this.spnHeight.setValue(h, true); } this.spnWidth.setValue(w, true); } if (this._changedProps) { this._changedProps.put_Height(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); this._changedProps.put_Width(Common.Utils.Metric.fnRecalcToMM(this.spnWidth.getNumberValue())); } }, this)); this.spinners.push(this.spnHeight); this.btnOriginalSize = new Common.UI.Button({ el: $('#image-advanced-button-original-size') }); this.btnOriginalSize.on('click', _.bind(function(btn, e) { this.spnWidth.setValue(this.sizeOriginal.width, true); this.spnHeight.setValue(this.sizeOriginal.height, true); this._nRatio = this.sizeOriginal.width/this.sizeOriginal.height; if (this._changedProps) { this._changedProps.put_Height(Common.Utils.Metric.fnRecalcToMM(this.spnHeight.getNumberValue())); this._changedProps.put_Width(Common.Utils.Metric.fnRecalcToMM(this.spnWidth.getNumberValue())); } }, this)); this.btnRatio = new Common.UI.Button({ cls: 'btn-toolbar', iconCls: 'advanced-btn-ratio', style: 'margin-bottom: 1px;', enableToggle: true, hint: this.textKeepRatio }); this.btnRatio.render($('#image-advanced-button-ratio')) ; this.btnRatio.on('click', _.bind(function(btn, e) { if (btn.pressed && this.spnHeight.getNumberValue()>0) { this._nRatio = this.spnWidth.getNumberValue()/this.spnHeight.getNumberValue(); } }, this)); // Shape Size this.radioHSize = new Common.UI.RadioBox({ el: $('#shape-radio-hsize'), name: 'asc-radio-width', checked: true }); this.radioHSize.on('change', _.bind(this.onRadioHSizeChange, this)); this.radioHSizePc = new Common.UI.RadioBox({ el: $('#shape-radio-hsizepc'), name: 'asc-radio-width' }); this.radioHSizePc.on('change', _.bind(this.onRadioHSizePcChange, this)); this.radioVSize = new Common.UI.RadioBox({ el: $('#shape-radio-vsize'), name: 'asc-radio-height', checked: true }); this.radioVSize.on('change', _.bind(this.onRadioVSizeChange, this)); this.radioVSizePc = new Common.UI.RadioBox({ el: $('#shape-radio-vsizepc'), name: 'asc-radio-height' }); this.radioVSizePc.on('change', _.bind(this.onRadioVSizePcChange, this)); this.chRatio = new Common.UI.CheckBox({ el: $('#shape-checkbox-ratio'), labelText: this.textAspectRatio }); this.chRatio.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if ((field.getValue()=='checked') && this.spnShapeHeight.getNumberValue()>0) { this._nRatio = this.spnShapeWidth.getNumberValue()/this.spnShapeHeight.getNumberValue(); } }, this)); this.spnShapeWidth = new Common.UI.MetricSpinner({ el: $('#shape-advanced-spin-width'), step: .1, width: 80, defaultUnit : "cm", value: '3 cm', maxValue: 55.88, minValue: 0 }); this.spnShapeWidth.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this.chRatio.getValue()=='checked' && !this.chRatio.isDisabled()) { var w = field.getNumberValue(); var h = w/this._nRatio; if (h>this.sizeMax.height) { h = this.sizeMax.height; w = h * this._nRatio; this.spnShapeWidth.setValue(w, true); } this.spnShapeHeight.setValue(h, true); } if (this._changedProps) { this._changedProps.put_Width(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); this._changedProps.put_Height(Common.Utils.Metric.fnRecalcToMM(this.spnShapeHeight.getNumberValue())); } }, this)); this.spinners.push(this.spnShapeWidth); this.spnShapeHeight = new Common.UI.MetricSpinner({ el: $('#shape-advanced-spin-height'), step: .1, width: 80, defaultUnit : "cm", value: '3 cm', maxValue: 55.88, minValue: 0 }); this.spnShapeHeight.on('change', _.bind(function(field, newValue, oldValue, eOpts){ var h = field.getNumberValue(), w = null; if (this.chRatio.getValue()=='checked' && !this.chRatio.isDisabled()) { w = h * this._nRatio; if (w>this.sizeMax.width) { w = this.sizeMax.width; h = w/this._nRatio; this.spnShapeHeight.setValue(h, true); } this.spnShapeWidth.setValue(w, true); } if (this._changedProps) { this._changedProps.put_Height(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); this._changedProps.put_Width(Common.Utils.Metric.fnRecalcToMM(this.spnShapeWidth.getNumberValue())); } }, this)); this.spinners.push(this.spnShapeHeight); this.spnShapeWidthPc = new Common.UI.MetricSpinner({ el: $('#shape-advanced-spin-width-rel'), disabled: true, step: 1, width: 80, defaultUnit : "%", value: '1 %', maxValue: 1000, minValue: 1 }); this.spnShapeWidthPc.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_SizeRelH()===null || this._changedProps.get_SizeRelH()===undefined) this._changedProps.put_SizeRelH(new Asc.CImagePositionH()); this._changedProps.get_SizeRelH().put_Value(field.getNumberValue()); this._changedProps.get_SizeRelH().put_RelativeFrom(this._state.ShapeWidthPcFrom); } }, this)); this.spnShapeHeightPc = new Common.UI.MetricSpinner({ el: $('#shape-advanced-spin-height-rel'), disabled: true, step: 1, width: 80, defaultUnit : "%", value: '1 %', maxValue: 1000, minValue: 1 }); this.spnShapeHeightPc.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_SizeRelV()===null || this._changedProps.get_SizeRelV()===undefined) this._changedProps.put_SizeRelV(new Asc.CImagePositionV()); this._changedProps.get_SizeRelV().put_Value(field.getNumberValue()); this._changedProps.get_SizeRelV().put_RelativeFrom(this._state.ShapeHeightPcFrom); } }, this)); this._arrHRelativePc = [ {displayValue: this.textLeftMargin, value: Asc.c_oAscRelativeFromH.LeftMargin}, {displayValue: this.textMargin, value: Asc.c_oAscRelativeFromH.Margin}, {displayValue: this.textPage, value: Asc.c_oAscRelativeFromH.Page}, {displayValue: this.textRightMargin, value: Asc.c_oAscRelativeFromH.RightMargin} ]; this.cmbWidthPc = new Common.UI.ComboBox({ el: $('#shape-combo-width-rel'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrHRelativePc }); this.cmbWidthPc.setDisabled(true); this.cmbWidthPc.setValue(this._state.ShapeWidthPcFrom); this.cmbWidthPc.on('selected', _.bind(this.onCmbWidthPcSelect, this)); this._arrVRelativePc = [ {displayValue: this.textMargin, value: Asc.c_oAscRelativeFromV.Margin}, {displayValue: this.textBottomMargin, value: Asc.c_oAscRelativeFromV.BottomMargin}, {displayValue: this.textPage, value: Asc.c_oAscRelativeFromV.Page}, {displayValue: this.textTopMargin, value: Asc.c_oAscRelativeFromV.TopMargin} ]; this.cmbHeightPc = new Common.UI.ComboBox({ el: $('#shape-combo-height-rel'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrVRelativePc }); this.cmbHeightPc.setDisabled(true); this.cmbHeightPc.setValue(this._state.ShapeHeightPcFrom); this.cmbHeightPc.on('selected', _.bind(this.onCmbHeightPcSelect, this)); // Wrapping this.btnWrapInline = new Common.UI.Button({ cls: 'btn-options x-huge', iconCls: 'icon-advanced-wrap btn-wrap-inline', posId: Asc.c_oAscWrapStyle2.Inline, hint: this.textWrapInlineTooltip, enableToggle: true, allowDepress: false, toggleGroup : 'imgAdvWrapGroup' }); this.btnWrapInline.render( $('#image-advanced-button-wrap-inline')) ; this.btnWrapInline.on('click', _.bind(this.onBtnWrapClick, this)); this.btnWrapSquare = new Common.UI.Button({ cls: 'btn-options x-huge', iconCls: 'icon-advanced-wrap btn-wrap-square', posId: Asc.c_oAscWrapStyle2.Square, hint: this.textWrapSquareTooltip, enableToggle: true, allowDepress: false, toggleGroup : 'imgAdvWrapGroup' }); this.btnWrapSquare.render( $('#image-advanced-button-wrap-square')) ; this.btnWrapSquare.on('click', _.bind(this.onBtnWrapClick, this)); this.btnWrapTight = new Common.UI.Button({ cls: 'btn-options x-huge', iconCls: 'icon-advanced-wrap btn-wrap-tight', posId: Asc.c_oAscWrapStyle2.Tight, hint: this.textWrapTightTooltip, enableToggle: true, allowDepress: false, toggleGroup : 'imgAdvWrapGroup' }); this.btnWrapTight.render( $('#image-advanced-button-wrap-tight')) ; this.btnWrapTight.on('click', _.bind(this.onBtnWrapClick, this)); this.btnWrapThrough = new Common.UI.Button({ cls: 'btn-options x-huge', iconCls: 'icon-advanced-wrap btn-wrap-through', posId: Asc.c_oAscWrapStyle2.Through, hint: this.textWrapThroughTooltip, enableToggle: true, allowDepress: false, toggleGroup : 'imgAdvWrapGroup' }); this.btnWrapThrough.render( $('#image-advanced-button-wrap-through')) ; this.btnWrapThrough.on('click', _.bind(this.onBtnWrapClick, this)); this.btnWrapTopBottom = new Common.UI.Button({ cls: 'btn-options x-huge', iconCls: 'icon-advanced-wrap btn-wrap-topbottom', posId: Asc.c_oAscWrapStyle2.TopAndBottom, hint: this.textWrapTopbottomTooltip, enableToggle: true, allowDepress: false, toggleGroup : 'imgAdvWrapGroup' }); this.btnWrapTopBottom.render( $('#image-advanced-button-wrap-topbottom')) ; this.btnWrapTopBottom.on('click', _.bind(this.onBtnWrapClick, this)); this.btnWrapBehind = new Common.UI.Button({ cls: 'btn-options x-huge', iconCls: 'icon-advanced-wrap btn-wrap-behind', posId: Asc.c_oAscWrapStyle2.Behind, hint: this.textWrapBehindTooltip, enableToggle: true, allowDepress: false, toggleGroup : 'imgAdvWrapGroup' }); this.btnWrapBehind.render( $('#image-advanced-button-wrap-behind')) ; this.btnWrapBehind.on('click', _.bind(this.onBtnWrapClick, this)); this.btnWrapInFront = new Common.UI.Button({ cls: 'btn-options x-huge', iconCls: 'icon-advanced-wrap btn-wrap-infront', posId: Asc.c_oAscWrapStyle2.InFront, hint: this.textWrapInFrontTooltip, enableToggle: true, allowDepress: false, toggleGroup : 'imgAdvWrapGroup' }); this.btnWrapInFront.render( $('#image-advanced-button-wrap-infront')) ; this.btnWrapInFront.on('click', _.bind(this.onBtnWrapClick, this)); this.spnTop = new Common.UI.MetricSpinner({ el: $('#image-advanced-distance-top'), step: .1, width: 85, defaultUnit : "cm", value: '0 cm', maxValue: 55.87, minValue: 0 }); this.spnTop.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_Paddings()===null || this._changedProps.get_Paddings()===undefined) this._changedProps.put_Paddings(new CPaddings()); this._changedProps.get_Paddings().put_Top(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); } }, this)); this.spinners.push(this.spnTop); this.spnBottom = new Common.UI.MetricSpinner({ el: $('#image-advanced-distance-bottom'), step: .1, width: 85, defaultUnit : "cm", value: '0 cm', maxValue: 55.87, minValue: 0 }); this.spnBottom.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_Paddings()===null || this._changedProps.get_Paddings()===undefined) this._changedProps.put_Paddings(new CPaddings()); this._changedProps.get_Paddings().put_Bottom(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); } }, this)); this.spinners.push(this.spnBottom); this.spnLeft = new Common.UI.MetricSpinner({ el: $('#image-advanced-distance-left'), step: .1, width: 85, defaultUnit : "cm", value: '0.32 cm', maxValue: 55.87, minValue: 0 }); this.spnLeft.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_Paddings()===null || this._changedProps.get_Paddings()===undefined) this._changedProps.put_Paddings(new CPaddings()); this._changedProps.get_Paddings().put_Left(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); } }, this)); this.spinners.push(this.spnLeft); this.spnRight = new Common.UI.MetricSpinner({ el: $('#image-advanced-distance-right'), step: .1, width: 85, defaultUnit : "cm", value: '0.32 cm', maxValue: 55.87, minValue: 0 }); this.spnRight.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_Paddings()===null || this._changedProps.get_Paddings()===undefined) this._changedProps.put_Paddings(new CPaddings()); this._changedProps.get_Paddings().put_Right(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); } }, this)); this.spinners.push(this.spnRight); // Position this.spnX = new Common.UI.MetricSpinner({ el: $('#image-spin-x'), step: .1, width: 115, disabled: true, defaultUnit : "cm", defaultValue : 0, value: '0 cm', maxValue: 55.87, minValue: -55.87 }); this.spnX.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_PositionH()===null || this._changedProps.get_PositionH()===undefined) this._changedProps.put_PositionH(new Asc.CImagePositionH()); this._changedProps.get_PositionH().put_UseAlign(false); this._changedProps.get_PositionH().put_Percent(false); this._changedProps.get_PositionH().put_RelativeFrom(this._state.HPositionFrom); this._changedProps.get_PositionH().put_Value(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); this._state.spnXChanged = true; } }, this)); this.spinners.push(this.spnX); this.spnY = new Common.UI.MetricSpinner({ el: $('#image-spin-y'), step: .1, width: 115, disabled: true, defaultUnit : "cm", defaultValue : 0, value: '0 cm', maxValue: 55.87, minValue: -55.87 }); this.spnY.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_PositionV()===null || this._changedProps.get_PositionV()===undefined) this._changedProps.put_PositionV(new Asc.CImagePositionV()); this._changedProps.get_PositionV().put_UseAlign(false); this._changedProps.get_PositionV().put_Percent(false); this._changedProps.get_PositionV().put_RelativeFrom(this._state.VPositionFrom); this._changedProps.get_PositionV().put_Value(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); this._state.spnYChanged = true; } }, this)); this.spinners.push(this.spnY); // Horizontal this._arrHAlign = [ {displayValue: this.textLeft, value: Asc.c_oAscAlignH.Left}, {displayValue: this.textCenter, value: Asc.c_oAscAlignH.Center}, {displayValue: this.textRight, value: Asc.c_oAscAlignH.Right} ]; this.cmbHAlign = new Common.UI.ComboBox({ el: $('#image-combo-halign'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrHAlign }); this.cmbHAlign.setValue(this._state.HAlignType); this.cmbHAlign.on('selected', _.bind(this.onHAlignSelect, this)); this._arrHRelative = [ {displayValue: this.textCharacter, value: Asc.c_oAscRelativeFromH.Character}, {displayValue: this.textColumn, value: Asc.c_oAscRelativeFromH.Column}, {displayValue: this.textLeftMargin, value: Asc.c_oAscRelativeFromH.LeftMargin}, {displayValue: this.textMargin, value: Asc.c_oAscRelativeFromH.Margin}, {displayValue: this.textPage, value: Asc.c_oAscRelativeFromH.Page}, {displayValue: this.textRightMargin, value: Asc.c_oAscRelativeFromH.RightMargin} ]; this.cmbHRelative = new Common.UI.ComboBox({ el: $('#image-combo-hrelative'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrHRelative }); this.cmbHRelative.setValue(this._state.HAlignFrom); this.cmbHRelative.on('selected', _.bind(this.onHRelativeSelect, this)); this.cmbHPosition = new Common.UI.ComboBox({ el: $('#image-combo-hposition'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrHRelative }); this.cmbHPosition.setDisabled(true); this.cmbHPosition.setValue(this._state.HPositionFrom); this.cmbHPosition.on('selected', _.bind(this.onHPositionSelect, this)); this.spnXPc = new Common.UI.MetricSpinner({ el: $('#image-spin-xpc'), step: 1, width: 115, disabled: true, defaultUnit : "%", defaultValue : 0, value: '0 %', maxValue: 1000, minValue: -1000 }); this.spnXPc.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_PositionH()===null || this._changedProps.get_PositionH()===undefined) this._changedProps.put_PositionH(new Asc.CImagePositionH()); this._changedProps.get_PositionH().put_UseAlign(false); this._changedProps.get_PositionH().put_Percent(true); this._changedProps.get_PositionH().put_RelativeFrom(this._state.HPositionPcFrom); this._changedProps.get_PositionH().put_Value(field.getNumberValue()); this._state.spnXPcChanged = true; } }, this)); this.cmbHPositionPc = new Common.UI.ComboBox({ el: $('#image-combo-hpositionpc'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrHRelativePc }); this.cmbHPositionPc.setDisabled(true); this.cmbHPositionPc.setValue(this._state.HPositionPcFrom); this.cmbHPositionPc.on('selected', _.bind(this.onHPositionPcSelect, this)); // Vertical this._arrVAlign = [ {displayValue: this.textTop, value: Asc.c_oAscAlignV.Top}, {displayValue: this.textCenter, value: Asc.c_oAscAlignV.Center}, {displayValue: this.textBottom, value: Asc.c_oAscAlignV.Bottom} ]; this.cmbVAlign = new Common.UI.ComboBox({ el: $('#image-combo-valign'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrVAlign }); this.cmbVAlign.setValue(this._state.VAlignType); this.cmbVAlign.on('selected', _.bind(this.onVAlignSelect, this)); this._arrVRelative = [ {displayValue: this.textLine, value: Asc.c_oAscRelativeFromV.Line}, {displayValue: this.textMargin, value: Asc.c_oAscRelativeFromV.Margin}, {displayValue: this.textBottomMargin, value: Asc.c_oAscRelativeFromV.BottomMargin}, {displayValue: this.textParagraph, value: Asc.c_oAscRelativeFromV.Paragraph}, {displayValue: this.textPage, value: Asc.c_oAscRelativeFromV.Page}, {displayValue: this.textTopMargin, value: Asc.c_oAscRelativeFromV.TopMargin} ]; this.cmbVRelative = new Common.UI.ComboBox({ el: $('#image-combo-vrelative'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrVRelative }); this.cmbVRelative.setValue(this._state.VAlignFrom); this.cmbVRelative.on('selected', _.bind(this.onVRelativeSelect, this)); this.cmbVPosition = new Common.UI.ComboBox({ el: $('#image-combo-vposition'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrVRelative }); this.cmbVPosition.setDisabled(true); this.cmbVPosition.setValue(this._state.VPositionFrom); this.cmbVPosition.on('selected', _.bind(this.onVPositionSelect, this)); this.spnYPc = new Common.UI.MetricSpinner({ el: $('#image-spin-ypc'), step: 1, width: 115, disabled: true, defaultUnit : "%", defaultValue : 0, value: '0 %', maxValue: 1000, minValue: -1000 }); this.spnYPc.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this._changedProps.get_PositionV()===null || this._changedProps.get_PositionV()===undefined) this._changedProps.put_PositionV(new Asc.CImagePositionV()); this._changedProps.get_PositionV().put_UseAlign(false); this._changedProps.get_PositionV().put_Percent(true); this._changedProps.get_PositionV().put_RelativeFrom(this._state.VPositionPcFrom); this._changedProps.get_PositionV().put_Value(field.getNumberValue()); this._state.spnYPcChanged = true; } }, this)); this.cmbVPositionPc = new Common.UI.ComboBox({ el: $('#image-combo-vpositionpc'), cls: 'input-group-nr', menuStyle: 'min-width: 115px;', editable: false, data: this._arrVRelativePc }); this.cmbVPositionPc.setDisabled(true); this.cmbVPositionPc.setValue(this._state.VPositionPcFrom); this.cmbVPositionPc.on('selected', _.bind(this.onVPositionPcSelect, this)); this.radioHAlign = new Common.UI.RadioBox({ el: $('#image-radio-halign'), name: 'asc-radio-horizontal', checked: true }); this.radioHAlign.on('change', _.bind(this.onRadioHAlignChange, this)); this.radioHPosition = new Common.UI.RadioBox({ el: $('#image-radio-hposition'), name: 'asc-radio-horizontal' }); this.radioHPosition.on('change', _.bind(this.onRadioHPositionChange, this)); this.radioHPositionPc = new Common.UI.RadioBox({ el: $('#image-radio-hpositionpc'), name: 'asc-radio-horizontal' }); this.radioHPositionPc.on('change', _.bind(this.onRadioHPositionPcChange, this)); this.radioVAlign = new Common.UI.RadioBox({ el: $('#image-radio-valign'), name: 'asc-radio-vertical', checked: true }); this.radioVAlign.on('change', _.bind(this.onRadioVAlignChange, this)); this.radioVPosition = new Common.UI.RadioBox({ el: $('#image-radio-vposition'), name: 'asc-radio-vertical' }); this.radioVPosition.on('change', _.bind(this.onRadioVPositionChange, this)); this.radioVPositionPc = new Common.UI.RadioBox({ el: $('#image-radio-vpositionpc'), name: 'asc-radio-vertical' }); this.radioVPositionPc.on('change', _.bind(this.onRadioVPositionPcChange, this)); this.chMove = new Common.UI.CheckBox({ el: $('#image-checkbox-move'), labelText: this.textMove }); this.chMove.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { var value = this._arrVRelative[(field.getValue()=='checked') ? 3 : 4].value; if (this.cmbVRelative.isDisabled()) { this.cmbVPosition.setValue(value); var rec = this.cmbVPosition.getSelectedRecord(); if (rec) this.onVPositionSelect(this.cmbVPosition, rec); } else { this.cmbVRelative.setValue(value); var rec = this.cmbVRelative.getSelectedRecord(); if (rec) this.onVRelativeSelect(this.cmbVRelative, rec); } } }, this)); this.chOverlap = new Common.UI.CheckBox({ el: $('#image-checkbox-overlap'), labelText: this.textOverlap }); this.chOverlap.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { this._changedProps.put_AllowOverlap(field.getValue()=='checked'); } }, this)); // Margins this.spnMarginTop = new Common.UI.MetricSpinner({ el: $('#image-margin-top'), step: .1, width: 100, defaultUnit : "cm", value: '0 cm', maxValue: 55.87, minValue: 0 }); this.spnMarginTop.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this.Margins===undefined) this.Margins= new CPaddings(); this.Margins.put_Top(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); } }, this)); this.spinners.push(this.spnMarginTop); this.spnMarginBottom = new Common.UI.MetricSpinner({ el: $('#image-margin-bottom'), step: .1, width: 100, defaultUnit : "cm", value: '0 cm', maxValue: 55.87, minValue: 0 }); this.spnMarginBottom.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this.Margins===undefined) this.Margins= new CPaddings(); this.Margins.put_Bottom(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); } }, this)); this.spinners.push(this.spnMarginBottom); this.spnMarginLeft = new Common.UI.MetricSpinner({ el: $('#image-margin-left'), step: .1, width: 100, defaultUnit : "cm", value: '0.19 cm', maxValue: 9.34, minValue: 0 }); this.spnMarginLeft.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this.Margins===undefined) this.Margins= new CPaddings(); this.Margins.put_Left(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); } }, this)); this.spinners.push(this.spnMarginLeft); this.spnMarginRight = new Common.UI.MetricSpinner({ el: $('#image-margin-right'), step: .1, width: 100, defaultUnit : "cm", value: '0.19 cm', maxValue: 9.34, minValue: 0 }); this.spnMarginRight.on('change', _.bind(function(field, newValue, oldValue, eOpts){ if (this._changedProps) { if (this.Margins===undefined) this.Margins= new CPaddings(); this.Margins.put_Right(Common.Utils.Metric.fnRecalcToMM(field.getNumberValue())); } }, this)); this.spinners.push(this.spnMarginRight); // Shape this._arrCapType = [ {displayValue: this.textFlat, value: Asc.c_oAscLineCapType.Flat}, {displayValue: this.textRound, value: Asc.c_oAscLineCapType.Round}, {displayValue: this.textSquare, value: Asc.c_oAscLineCapType.Square} ]; this.cmbCapType = new Common.UI.ComboBox({ el: $('#shape-advanced-cap-type'), cls: 'input-group-nr', menuStyle: 'min-width: 100px;', editable: false, data: this._arrCapType }); this.cmbCapType.setValue(Asc.c_oAscLineCapType.Flat); this.cmbCapType.on('selected', _.bind(function(combo, record){ if (this._changedShapeProps) { if (this._changedShapeProps.get_stroke()===null) this._changedShapeProps.put_stroke(new CAscStroke()); this._changedShapeProps.get_stroke().put_linecap(record.value); } }, this)); this._arrJoinType = [ {displayValue: this.textRound, value: Asc.c_oAscLineJoinType.Round}, {displayValue: this.textBevel, value: Asc.c_oAscLineJoinType.Bevel}, {displayValue: this.textMiter, value: Asc.c_oAscLineJoinType.Miter} ]; this.cmbJoinType = new Common.UI.ComboBox({ el: $('#shape-advanced-join-type'), cls: 'input-group-nr', menuStyle: 'min-width: 100px;', editable: false, data: this._arrJoinType }); this.cmbJoinType.setValue(Asc.c_oAscLineJoinType.Round); this.cmbJoinType.on('selected', _.bind(function(combo, record){ if (this._changedShapeProps) { if (this._changedShapeProps.get_stroke()===null) this._changedShapeProps.put_stroke(new CAscStroke()); this._changedShapeProps.get_stroke().put_linejoin(record.value); } }, this)); var _arrStyles = [], _arrSize = []; for ( var i=0; i<6; i++ ) _arrStyles.push({value: i, offsetx: 80*i+10, offsety: 0}); _arrStyles[0].type = Asc.c_oAscLineBeginType.None; _arrStyles[1].type = Asc.c_oAscLineBeginType.Triangle; _arrStyles[2].type = Asc.c_oAscLineBeginType.Arrow; _arrStyles[3].type = Asc.c_oAscLineBeginType.Stealth; _arrStyles[4].type = Asc.c_oAscLineBeginType.Diamond; _arrStyles[5].type = Asc.c_oAscLineBeginType.Oval; for ( i=0; i<9; i++ ) _arrSize.push({value: i, offsetx: 80+10, offsety: 20*(i+1)}); _arrSize[0].type = Asc.c_oAscLineBeginSize.small_small; _arrSize[1].type = Asc.c_oAscLineBeginSize.small_mid; _arrSize[2].type = Asc.c_oAscLineBeginSize.small_large; _arrSize[3].type = Asc.c_oAscLineBeginSize.mid_small; _arrSize[4].type = Asc.c_oAscLineBeginSize.mid_mid; _arrSize[5].type = Asc.c_oAscLineBeginSize.mid_large; _arrSize[6].type = Asc.c_oAscLineBeginSize.large_small; _arrSize[7].type = Asc.c_oAscLineBeginSize.large_mid; _arrSize[8].type = Asc.c_oAscLineBeginSize.large_large; this.btnBeginStyle = new Common.UI.ComboBox({ el: $('#shape-advanced-begin-style'), template: _.template([ '' ].join('')) }); this.btnBeginStyleMenu = (new Common.UI.Menu({ style: 'min-width: 105px;', items: [ { template: _.template('
') } ] })).render($('#shape-advanced-begin-style')); this.mnuBeginStylePicker = new Common.UI.DataView({ el: $('#shape-advanced-menu-begin-style'), parentMenu: this.btnBeginStyleMenu, store: new Common.UI.DataViewStore(_arrStyles), itemTemplate: _.template('
') }); this.mnuBeginStylePicker.on('item:click', _.bind(this.onSelectBeginStyle, this)); this._selectStyleItem(this.btnBeginStyle, null); this.btnBeginSize = new Common.UI.ComboBox({ el: $('#shape-advanced-begin-size'), template: _.template([ '' ].join('')) }); this.btnBeginSizeMenu = (new Common.UI.Menu({ style: 'min-width: 160px;', items: [ { template: _.template('
') } ] })).render($('#shape-advanced-begin-size')); this.mnuBeginSizePicker = new Common.UI.DataView({ el: $('#shape-advanced-menu-begin-size'), parentMenu: this.btnBeginSizeMenu, store: new Common.UI.DataViewStore(_arrSize), itemTemplate: _.template('
') }); this.mnuBeginSizePicker.on('item:click', _.bind(this.onSelectBeginSize, this)); this._selectStyleItem(this.btnBeginSize, null); for ( i=0; i<_arrStyles.length; i++ ) _arrStyles[i].offsety += 200; for ( i=0; i<_arrSize.length; i++ ) _arrSize[i].offsety += 200; this.btnEndStyle = new Common.UI.ComboBox({ el: $('#shape-advanced-end-style'), template: _.template([ '' ].join('')) }); this.btnEndStyleMenu = (new Common.UI.Menu({ style: 'min-width: 105px;', items: [ { template: _.template('
') } ] })).render($('#shape-advanced-end-style')); this.mnuEndStylePicker = new Common.UI.DataView({ el: $('#shape-advanced-menu-end-style'), parentMenu: this.btnEndStyleMenu, store: new Common.UI.DataViewStore(_arrStyles), itemTemplate: _.template('
') }); this.mnuEndStylePicker.on('item:click', _.bind(this.onSelectEndStyle, this)); this._selectStyleItem(this.btnEndStyle, null); this.btnEndSize = new Common.UI.ComboBox({ el: $('#shape-advanced-end-size'), template: _.template([ '' ].join('')) }); this.btnEndSizeMenu = (new Common.UI.Menu({ style: 'min-width: 160px;', items: [ { template: _.template('
') } ] })).render($('#shape-advanced-end-size')); this.mnuEndSizePicker = new Common.UI.DataView({ el: $('#shape-advanced-menu-end-size'), parentMenu: this.btnEndSizeMenu, store: new Common.UI.DataViewStore(_arrSize), itemTemplate: _.template('
') }); this.mnuEndSizePicker.on('item:click', _.bind(this.onSelectEndSize, this)); this._selectStyleItem(this.btnEndSize, null); this.afterRender(); }, afterRender: function() { this.updateMetricUnit(); this._setDefaults(this._originalProps); var btnCategoryShapeSize, btnCategoryImageSize; _.each(this.btnsCategory, function(btn) { if (btn.options.contentTarget == 'id-adv-image-width') btnCategoryImageSize = btn; else if(btn.options.contentTarget == 'id-adv-shape-size') btnCategoryShapeSize = btn; }); this.content_panels.filter('.active').removeClass('active'); if (this._objectType == Asc.c_oAscTypeSelectElement.Shape) { btnCategoryImageSize.hide(); btnCategoryShapeSize.toggle(true, true); $("#" + btnCategoryShapeSize.options.contentTarget).addClass('active'); } else { btnCategoryShapeSize.hide(); btnCategoryImageSize.toggle(true, true); $("#" + btnCategoryImageSize.options.contentTarget).addClass('active'); } }, _setDefaults: function(props) { if (props ){ this._objectType = Asc.c_oAscTypeSelectElement.Image; var value = props.get_WrappingStyle(); if ( props.get_CanBeFlow() ) { switch (value) { case Asc.c_oAscWrapStyle2.Inline: this.btnWrapInline.toggle(true); break; case Asc.c_oAscWrapStyle2.Square: this.btnWrapSquare.toggle(true); break; case Asc.c_oAscWrapStyle2.Tight: this.btnWrapTight.toggle(true); break; case Asc.c_oAscWrapStyle2.Through: this.btnWrapThrough.toggle(true); break; case Asc.c_oAscWrapStyle2.TopAndBottom: this.btnWrapTopBottom.toggle(true); break; case Asc.c_oAscWrapStyle2.Behind: this.btnWrapBehind.toggle(true); break; case Asc.c_oAscWrapStyle2.InFront: this.btnWrapInFront.toggle(true); break; default: this.btnWrapInline.toggle(false); this.btnWrapSquare.toggle(false); this.btnWrapTight.toggle(false); this.btnWrapThrough.toggle(false); this.btnWrapTopBottom.toggle(false); this.btnWrapBehind.toggle(false); this.btnWrapInFront.toggle(false); break; } this._DisableElem(value); } else { this.btnWrapInline.toggle(true); this.btnWrapSquare.setDisabled(true); this.btnWrapTight.setDisabled(true); this.btnWrapThrough.setDisabled(true); this.btnWrapTopBottom.setDisabled(true); this.btnWrapBehind.setDisabled(true); this.btnWrapInFront.setDisabled(true); this._DisableElem(Asc.c_oAscWrapStyle2.Inline); } if (props.get_Paddings()) { var Paddings = { Top: props.get_Paddings().get_Top(), Right: props.get_Paddings().get_Right(), Bottom: props.get_Paddings().get_Bottom(), Left: props.get_Paddings().get_Left() }; if (Paddings.Top !== null && Paddings.Top !== undefined) this.spnTop.setValue(Common.Utils.Metric.fnRecalcFromMM(Paddings.Top), true); if (Paddings.Left !== null && Paddings.Left !== undefined) this.spnLeft.setValue(Common.Utils.Metric.fnRecalcFromMM(Paddings.Left), true); if (Paddings.Bottom !== null && Paddings.Bottom !== undefined) this.spnBottom.setValue(Common.Utils.Metric.fnRecalcFromMM(Paddings.Bottom), true); if (Paddings.Right !== null && Paddings.Right !== undefined) this.spnRight.setValue(Common.Utils.Metric.fnRecalcFromMM(Paddings.Right), true); } var Position = props.get_PositionH(); if (Position) { if (Position.get_UseAlign()) { value = Position.get_Align(); for (var i=0; i0) this._nRatio = props.get_Width()/props.get_Height(); var shapeprops = props.get_ShapeProperties(); var chartprops = props.get_ChartProperties(); this.btnOriginalSize.setVisible(!(shapeprops || chartprops)); this.btnOriginalSize.setDisabled(props.get_ImageUrl()===null || props.get_ImageUrl()===undefined); this.btnsCategory[4].setVisible(shapeprops!==null && !shapeprops.get_FromChart()); // Shapes this.btnsCategory[5].setVisible(shapeprops!==null && !shapeprops.get_FromChart()); // Margins this.btnsCategory[2].setDisabled(props.get_FromGroup()); // Wrapping if (shapeprops) { this._objectType = Asc.c_oAscTypeSelectElement.Shape; this._setShapeDefaults(shapeprops); this.setTitle(this.textTitleShape); value = Common.localStorage.getItem("de-settings-shaperatio"); if (value!==null && parseInt(value) == 1) { this.chRatio.setValue(true); } this.spnShapeWidth.setMaxValue(this.sizeMax.width); this.spnShapeHeight.setMaxValue(this.sizeMax.height); var sizeRelH = props.get_SizeRelH(); if (sizeRelH) { this.radioHSizePc.setValue(true); this.spnShapeWidthPc.setValue(sizeRelH.get_Value()); value = sizeRelH.get_RelativeFrom(); for (i=0; i0) { picker.store.each( function(rec){ rec.set({offsetx: record.get('value')*80 + 10}); }, this); combo.setDisabled(false); if (sizeidx !== null) { picker.selectByIndex(sizeidx, true); this._selectStyleItem(combo, picker.store.at(sizeidx)); } else this._selectStyleItem(combo, null); } else { this._selectStyleItem(combo, null); combo.setDisabled(true); } }, _selectStyleItem: function(combo, record) { var formcontrol = $(combo.el).find('.form-control'); formcontrol.css('background-position', ((record) ? (-record.get('offsetx')+20) + 'px' : '0') + ' ' + ((record) ? '-' + record.get('offsety') + 'px' : '-30px')); }, onSelectBeginStyle: function(picker, view, record, e){ if (this._changedShapeProps) { if (this._changedShapeProps.get_stroke()===null) this._changedShapeProps.put_stroke(new CAscStroke()); this._changedShapeProps.get_stroke().put_linebeginstyle(record.get('type')); } if (this._beginSizeIdx===null || this._beginSizeIdx===undefined) this._beginSizeIdx = 4; this._updateSizeArr(this.btnBeginSize, this.mnuBeginSizePicker, record, this._beginSizeIdx); this._selectStyleItem(this.btnBeginStyle, record); }, onSelectBeginSize: function(picker, view, record, e){ if (this._changedShapeProps) { if (this._changedShapeProps.get_stroke()===null) this._changedShapeProps.put_stroke(new CAscStroke()); this._changedShapeProps.get_stroke().put_linebeginsize(record.get('type')); } this._beginSizeIdx = record.get('value'); this._selectStyleItem(this.btnBeginSize, record); }, onSelectEndStyle: function(picker, view, record, e){ if (this._changedShapeProps) { if (this._changedShapeProps.get_stroke()===null) this._changedShapeProps.put_stroke(new CAscStroke()); this._changedShapeProps.get_stroke().put_lineendstyle(record.get('type')); } if (this._endSizeIdx===null || this._endSizeIdx===undefined) this._endSizeIdx = 4; this._updateSizeArr(this.btnEndSize, this.mnuEndSizePicker, record, this._endSizeIdx); this._selectStyleItem(this.btnEndStyle, record); }, onSelectEndSize: function(picker, view, record, e){ if (this._changedShapeProps) { if (this._changedShapeProps.get_stroke()===null) this._changedShapeProps.put_stroke(new CAscStroke()); this._changedShapeProps.get_stroke().put_lineendsize(record.get('type')); } this._endSizeIdx = record.get('value'); this._selectStyleItem(this.btnEndSize, record); }, textTop: 'Top', textLeft: 'Left', textBottom: 'Bottom', textRight: 'Right', textOriginalSize: 'Default Size', textPosition: 'Position', textDistance: 'Distance From Text', textSize: 'Size', textWrap: 'Wrapping Style', textWidth: 'Width', textHeight: 'Height', textWrapInlineTooltip: 'Inline', textWrapSquareTooltip: 'Square', textWrapTightTooltip: 'Tight', textWrapThroughTooltip: 'Through', textWrapTopbottomTooltip: 'Top and Bottom', textWrapBehindTooltip: 'Behind', textWrapInFrontTooltip: 'In Front', textTitle: 'Image - Advanced Settings', textKeepRatio: 'Constant Proportions', cancelButtonText: 'Cancel', okButtonText: 'Ok', textBtnWrap: 'Text Wrapping', textCenter: 'Center', textCharacter: 'Character', textColumn: 'Column', textLeftMargin: 'Left Margin', textMargin: 'Margin', textPage: 'Page', textRightMargin: 'Right Margin', textLine: 'Line', textBottomMargin: 'Bottom Margin', textParagraph: 'Paragraph', textTopMargin: 'Top Margin', textHorizontal: 'Horizontal', textVertical: 'Vertical', textAlignment: 'Alignment', textRelative: 'relative to', textRightOf: 'to the right Of', textBelow: 'below', textOverlap: 'Allow overlap', textMove: 'Move object with text', textOptions: 'Options', textShape: 'Shape Settings', textTitleShape: 'Shape - Advanced Settings', textTitleChart: 'Chart - Advanced Settings', strMargins: 'Text Padding', textRound: 'Round', textMiter: 'Miter', textSquare: 'Square', textFlat: 'Flat', textBevel: 'Bevel', textArrows: 'Arrows', textLineStyle: 'Line Style', textCapType: 'Cap Type', textJoinType: 'Join Type', textBeginStyle: 'Begin Style', textBeginSize: 'Begin Size', textEndStyle: 'End Style', textEndSize: 'End Size', textPositionPc: 'Relative position', textAspectRatio: 'Lock aspect ratio', textAbsoluteWH: 'Absolute', textRelativeWH: 'Relative' }, DE.Views.ImageSettingsAdvanced || {})); });