DocumentServer/OfficeWeb/apps/documenteditor/main/app/view/ParagraphSettingsAdvanced.js

2563 lines
99 KiB
JavaScript
Raw Normal View History

2014-07-05 18:22:49 +00:00
/*
* (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.ParagraphSettingsAdvanced", {
extend: "Ext.window.Window",
alias: "widget.deparagraphsettingsadvanced",
requires: ["Ext.Array", "Ext.form.field.ComboBox", "Ext.window.Window", "Common.component.ThemeColorPalette", "Common.component.MetricSpinner", "DE.component.TableStyler", "Common.component.IndeterminateCheckBox", "Common.plugin.GridScrollPane", "Ext.grid.Panel", "Common.plugin.ComboBoxScrollPane"],
cls: "asc-advanced-settings-window",
modal: true,
resizable: false,
plain: true,
constrain: true,
height: 390,
width: 516,
layout: {
type: "vbox",
align: "stretch"
},
initComponent: function () {
var me = this;
this.addEvents("onmodalresult");
this.Borders = {};
this.BorderSize = {
ptValue: 0,
pxValue: 0
};
this.paragraphShade = "transparent";
this._changedProps = null;
this.ChangedBorders = undefined;
this.checkGroup = 0;
this._noApply = true;
this._tabListChanged = false;
this.Margins = undefined;
this.ThemeValues = [6, 15, 7, 16, 0, 1, 2, 3, 4, 5];
this.numFirstLine = Ext.create("Common.component.MetricSpinner", {
id: "paragraphadv-spin-first-line",
readOnly: false,
step: 0.1,
width: 85,
defaultUnit: "cm",
value: "0 cm",
maxValue: 55.87,
minValue: -55.87,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
if (this._changedProps.get_Ind() === null || this._changedProps.get_Ind() === undefined) {
this._changedProps.put_Ind(new CParagraphInd());
}
this._changedProps.get_Ind().put_FirstLine(Common.MetricSettings.fnRecalcToMM(field.getNumberValue()));
}
},
this)
}
});
this.numIndentsLeft = Ext.widget("commonmetricspinner", {
id: "paragraphadv-spin-indent-left",
readOnly: false,
step: 0.1,
width: 85,
defaultUnit: "cm",
value: "0 cm",
maxValue: 55.87,
minValue: -55.87,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
if (this._changedProps.get_Ind() === null || this._changedProps.get_Ind() === undefined) {
this._changedProps.put_Ind(new CParagraphInd());
}
this._changedProps.get_Ind().put_Left(Common.MetricSettings.fnRecalcToMM(field.getNumberValue()));
}
},
this)
}
});
this.numIndentsRight = Ext.widget("commonmetricspinner", {
id: "paragraphadv-spin-indent-right",
readOnly: false,
step: 0.1,
width: 85,
defaultUnit: "cm",
value: "0 cm",
maxValue: 55.87,
minValue: -55.87,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
if (this._changedProps.get_Ind() === null || this._changedProps.get_Ind() === undefined) {
this._changedProps.put_Ind(new CParagraphInd());
}
this._changedProps.get_Ind().put_Right(Common.MetricSettings.fnRecalcToMM(field.getNumberValue()));
}
},
this)
}
});
this._spacer = Ext.create("Ext.toolbar.Spacer", {
width: "100%",
height: 10,
html: '<div style="width: 100%; height: 40%; border-bottom: 1px solid #C7C7C7"></div>'
});
this.chBreakBefore = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-break-before",
boxLabel: this.strBreakBefore,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
this._changedProps.put_PageBreakBefore(field.getValue() == "checked");
}
},
this)
}
});
this.chKeepLines = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-keep-lines",
boxLabel: this.strKeepLines,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
this._changedProps.put_KeepLines(field.getValue() == "checked");
}
},
this)
}
});
this.chOrphan = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-orphan",
boxLabel: this.strOrphan,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
this._changedProps.put_WidowControl(field.getValue() == "checked");
}
},
this)
}
});
this.chKeepNext = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-keep-next",
boxLabel: this.strKeepNext,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
this._changedProps.put_KeepNext(field.getValue() == "checked");
}
},
this)
}
});
var _arrBorderPresets = [[c_tableBorder.BORDER_OUTER, "lrtb", "asc-advanced-settings-position-btn btn-adv-paragraph-outer", "paragraphadv-button-border-outer", this.tipOuter], [c_tableBorder.BORDER_ALL, "lrtbm", "asc-advanced-settings-position-btn btn-adv-paragraph-all", "paragraphadv-button-border-all", this.tipAll], [c_tableBorder.BORDER_NONE, "", "asc-advanced-settings-position-btn btn-adv-paragraph-none", "paragraphadv-button-border-none", this.tipNone], [c_tableBorder.BORDER_VERTICAL_LEFT, "l", "asc-advanced-settings-position-btn btn-adv-paragraph-left", "paragraphadv-button-border-left", this.tipLeft], [c_tableBorder.BORDER_VERTICAL_RIGHT, "r", "asc-advanced-settings-position-btn btn-adv-paragraph-right", "paragraphadv-button-border-right", this.tipRight], [c_tableBorder.BORDER_HORIZONTAL_TOP, "t", "asc-advanced-settings-position-btn btn-adv-paragraph-top", "paragraphadv-button-border-top", this.tipTop], [c_tableBorder.BORDER_HORIZONTAL_CENTER, "m", "asc-advanced-settings-position-btn btn-adv-paragraph-inner-hor", "paragraphadv-button-border-inner-hor", this.tipInner], [c_tableBorder.BORDER_HORIZONTAL_BOTTOM, "b", "asc-advanced-settings-position-btn btn-adv-paragraph-bottom", "paragraphadv-button-border-bottom", this.tipBottom]];
this._btnsBorderPosition = [];
Ext.Array.forEach(_arrBorderPresets, function (item, index) {
var _btn = Ext.create("Ext.Button", {
id: item[3],
cls: item[2],
posId: item[0],
strId: item[1],
text: "",
tooltip: item[4],
listeners: {
click: Ext.bind(function (btn, eOpts) {
this._ApplyBorderPreset(btn.strId);
},
this)
}
});
this._btnsBorderPosition.push(_btn);
},
this);
this._BordersImage = Ext.widget("detablestyler", {
id: "id-deparagraphstyler",
width: 200,
height: 170,
rows: this.tableStylerRows,
columns: this.tableStylerColumns,
spacingMode: false
});
var dataBorders = [{
borderstyle: "",
text: this.txtNoBorders,
value: 0,
offsety: 0
},
{
text: "0.5 pt",
value: 0.5,
pxValue: 0.5,
offsety: 0
},
{
text: "1 pt",
value: 1,
pxValue: 1,
offsety: 20
},
{
text: "1.5 pt",
value: 1.5,
pxValue: 2,
offsety: 40
},
{
text: "2.25 pt",
value: 2.25,
pxValue: 3,
offsety: 60
},
{
text: "3 pt",
value: 3,
pxValue: 4,
offsety: 80
},
{
text: "4.5 pt",
value: 4.5,
pxValue: 5,
offsety: 100
},
{
text: "6 pt",
value: 6,
pxValue: 6,
offsety: 120
}];
for (var i = 1; i < dataBorders.length; i++) {
dataBorders[i].borderstyle = Ext.String.format("background:url({0}) 0 {1}px; width:69px; height:20px; margin-right:5px;", "resources/img/right-panels/BorderSize.png", -dataBorders[i].offsety);
}
var fieldStore = Ext.create("Ext.data.Store", {
model: "DE.model.ModelBorders",
data: dataBorders
});
var item_tpl = Ext.create("Ext.XTemplate", '<tpl for=".">' + '<span style="display: inline-block; margin-top: 3px; font-size: 11px; height: 17px;">{text}</span>' + '<img src="" align="right" style="{borderstyle}">' + "</tpl>");
this.cmbBorderSize = Ext.create("Ext.form.field.ComboBox", {
width: 93,
height: 21,
editable: false,
queryMode: "local",
matchFieldWidth: false,
displayField: "text",
store: fieldStore,
listConfig: {
mode: "local",
width: 145,
itemTpl: item_tpl
},
listeners: {
select: Ext.bind(function (combo, records, eOpts) {
this.BorderSize = {
ptValue: records[0].data.value,
pxValue: records[0].data.pxValue
};
this._BordersImage.setVirtualBorderSize(this.BorderSize.pxValue);
if (combo.inputEl) {
if (records[0].data.value > 0) {
combo.inputEl.set({
type: "image"
});
combo.inputEl.set({
src: ""
});
var style = Ext.String.format("background:url({0}) no-repeat scroll 0 {1}px, url({2}) repeat scroll 0 0 white", "resources/img/right-panels/BorderSize.png", -records[0].data.offsety, "resources/img/controls/text-bg.gif");
Ext.DomHelper.applyStyles(combo.inputEl, style);
} else {
var style = Ext.String.format("background: url({0}) repeat scroll 0 0 white", "resources/img/controls/text-bg.gif");
Ext.DomHelper.applyStyles(combo.inputEl, style);
combo.inputEl.set({
type: "text"
});
combo.inputEl.set({
value: me.txtNoBorders
});
combo.onItemClick(combo.picker, records[0]);
}
}
},
this),
afterRender: function () {
if (this.inputEl) {
Ext.DomHelper.applyStyles(this.inputEl, "padding-left:7px");
this.inputEl.set({
type: "image"
});
this.inputEl.set({
src: ""
});
var style = Ext.String.format("background:url({0}) repeat scroll 0 {1}px, url({2}) repeat scroll 0 0 white", "resources/img/right-panels/BorderSize.png", -20, "resources/img/controls/text-bg.gif");
Ext.DomHelper.applyStyles(this.inputEl, style);
}
}
},
plugins: [{
ptype: "comboboxscrollpane",
pluginId: "scrollpane",
settings: {
enableKeyboardNavigation: true
}
}]
});
var rec = this.cmbBorderSize.getStore().getAt(2);
this.cmbBorderSize.select(rec);
this.BorderSize = {
ptValue: rec.data.value,
pxValue: rec.data.pxValue
};
this._btnBorderColor = Ext.create("Ext.button.Button", {
id: "paragraphadv-button-border-color",
arrowCls: "",
width: 45,
height: 22,
color: "000000",
menu: {
showSeparator: false,
items: [this.colorsBorder = Ext.create("Common.component.ThemeColorPalette", {
value: "000000",
width: 165,
height: 214,
dynamiccolors: true,
dyncolorscount: 10,
colors: [this.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: "3D55FE",
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
},
"-", "--", "-", this.textStandartColors, "-", "3D55FE", "5301B3", "980ABD", "B2275F", "F83D26", "F86A1D", "F7AC16", "F7CA12", "FAFF44", "D6EF39", "-", "--"],
listeners: {
select: {
fn: function (picker, color, eOpts, id) {
Ext.menu.Manager.hideAll();
var colorstr = Ext.String.format("#{0}", (typeof(color) == "object") ? color.color : color);
me._btnBorderColor.color = color;
me._BordersImage.setVirtualBorderColor(colorstr);
if (me._btnBorderColor.btnEl) {
Ext.DomHelper.applyStyles(me._btnBorderColor.btnEl, {
"background-color": colorstr
});
}
}
}
}
}), {
cls: "menu-item-noicon menu-item-color-palette-theme",
text: this.textNewColor,
listeners: {
click: function (item, event) {
me.colorsBorder.addNewColor();
}
}
}]
},
listeners: {
render: function (c) {
var colorStyle = Ext.String.format("background-color:#{0}", (typeof(c.color) == "object") ? c.color.color : c.color);
Ext.DomHelper.applyStyles(c.btnEl, colorStyle);
}
},
setColor: function (newcolor) {
var border, clr;
this.color = newcolor;
if (newcolor == "transparent" || newcolor.color == "transparent") {
border = "1px solid #BEBEBE";
clr = newcolor;
} else {
border = "none";
clr = Ext.String.format("#{0}", (typeof(newcolor) == "object") ? newcolor.color : newcolor);
}
if (this.btnEl !== undefined) {
Ext.DomHelper.applyStyles(this.btnEl, {
"background-color": clr,
"border": border
});
}
}
});
this._btnBackColor = Ext.create("Ext.button.Button", {
id: "paragraphadv-button-back-color",
arrowCls: "",
width: 50,
height: 22,
color: "transparent",
menu: {
showSeparator: false,
items: [this.colorsBack = Ext.create("Common.component.ThemeColorPalette", {
value: "000000",
width: 165,
height: 214,
dynamiccolors: true,
dyncolorscount: 10,
colors: [this.textThemeColors, "-", {
color: "3366FF",
effectId: 1
},
{
color: "0000FF",
effectId: 2
},
{
color: "000090",
effectId: 3
},
{
color: "660066",
effectId: 4
},
{
color: "800000",
effectId: 5
},
{
color: "FF0000",
effectId: 1
},
{
color: "FF6600",
effectId: 1
},
{
color: "FFFF00",
effectId: 2
},
{
color: "CCFFCC",
effectId: 3
},
{
color: "008000",
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
},
"-", "--", "-", this.textStandartColors, "-", "transparent", "5301B3", "980ABD", "B2275F", "F83D26", "F86A1D", "F7AC16", "F7CA12", "FAFF44", "D6EF39", "-", "--"],
listeners: {
select: {
fn: function (picker, color, eOpts, id) {
Ext.menu.Manager.hideAll();
var clr, border;
me._btnBackColor.color = color;
if (color == "transparent") {
clr = "transparent";
border = "1px solid #BEBEBE";
} else {
clr = Ext.String.format("#{0}", (typeof(color) == "object") ? color.color : color);
border = "none";
}
if (me._btnBackColor.btnEl) {
Ext.DomHelper.applyStyles(me._btnBackColor.btnEl, {
"background-color": clr,
"border": border
});
}
me.paragraphShade = me._btnBackColor.color;
if (me._changedProps) {
if (me._changedProps.get_Shade() === undefined || me._changedProps.get_Shade() === null) {
me._changedProps.put_Shade(new CParagraphShd());
}
if (me._btnBackColor.color == "transparent") {
me._changedProps.get_Shade().put_Value(shd_Nil);
} else {
me._changedProps.get_Shade().put_Value(shd_Clear);
me._changedProps.get_Shade().put_Color(me.getRgbColor(me._btnBackColor.color));
}
}
}
}
}
}), {
cls: "menu-item-noicon menu-item-color-palette-theme",
text: me.textNewColor,
listeners: {
click: function (item, event) {
me.colorsBack.addNewColor();
}
}
}]
},
listeners: {
render: function (c) {
var border, clr;
if (c.color == "transparent") {
border = "1px solid #BEBEBE";
clr = c.color;
} else {
border = "none";
clr = Ext.String.format("#{0}", (typeof(c.color) == "object") ? c.color.color : c.color);
}
Ext.DomHelper.applyStyles(c.btnEl, {
"background-color": clr,
"border": border
});
}
},
setColor: function (newcolor) {
var border, clr;
this.color = newcolor;
if (newcolor == "transparent") {
border = "1px solid #BEBEBE";
clr = newcolor;
} else {
border = "none";
clr = Ext.String.format("#{0}", (typeof(newcolor) == "object") ? newcolor.color : newcolor);
}
if (this.btnEl !== undefined) {
Ext.DomHelper.applyStyles(this.btnEl, {
"background-color": clr,
"border": border
});
}
}
});
this.chStrike = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-strike",
width: 140,
boxLabel: this.strStrike,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps && this.checkGroup != 1) {
this._changedProps.put_Strikeout(field.getValue() == "checked");
}
this.checkGroup = 0;
if (field.getValue() == "checked") {
this.checkGroup = 1;
this.chDoubleStrike.setValue(0);
if (this._changedProps) {
this._changedProps.put_DStrikeout(false);
}
this.checkGroup = 0;
}
if (this.api && !this._noApply) {
var properties = (this._originalProps) ? this._originalProps : new CParagraphProp();
properties.put_Strikeout(field.getValue() == "checked");
properties.put_DStrikeout(this.chDoubleStrike.getValue() == "checked");
this.api.SetDrawImagePlaceParagraph("paragraphadv-font-img", properties);
}
},
this)
}
});
this.chDoubleStrike = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-double-strike",
width: 140,
boxLabel: this.strDoubleStrike,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps && this.checkGroup != 1) {
this._changedProps.put_DStrikeout(field.getValue() == "checked");
}
this.checkGroup = 0;
if (field.getValue() == "checked") {
this.checkGroup = 1;
this.chStrike.setValue(0);
if (this._changedProps) {
this._changedProps.put_Strikeout(false);
}
this.checkGroup = 0;
}
if (this.api && !this._noApply) {
var properties = (this._originalProps) ? this._originalProps : new CParagraphProp();
properties.put_DStrikeout(field.getValue() == "checked");
properties.put_Strikeout(this.chStrike.getValue() == "checked");
this.api.SetDrawImagePlaceParagraph("paragraphadv-font-img", properties);
}
},
this)
}
});
this.chSuperscript = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-superscript",
width: 140,
boxLabel: this.strSuperscript,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps && this.checkGroup != 2) {
this._changedProps.put_Superscript(field.getValue() == "checked");
}
this.checkGroup = 0;
if (field.getValue() == "checked") {
this.checkGroup = 2;
this.chSubscript.setValue(0);
if (this._changedProps) {
this._changedProps.put_Subscript(false);
}
this.checkGroup = 0;
}
if (this.api && !this._noApply) {
var properties = (this._originalProps) ? this._originalProps : new CParagraphProp();
properties.put_Superscript(field.getValue() == "checked");
properties.put_Subscript(this.chSubscript.getValue() == "checked");
this.api.SetDrawImagePlaceParagraph("paragraphadv-font-img", properties);
}
},
this)
}
});
this.chSubscript = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-subscript",
width: 140,
boxLabel: this.strSubscript,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps && this.checkGroup != 2) {
this._changedProps.put_Subscript(field.getValue() == "checked");
}
this.checkGroup = 0;
if (field.getValue() == "checked") {
this.checkGroup = 2;
this.chSuperscript.setValue(0);
if (this._changedProps) {
this._changedProps.put_Superscript(false);
}
this.checkGroup = 0;
}
if (this.api && !this._noApply) {
var properties = (this._originalProps) ? this._originalProps : new CParagraphProp();
properties.put_Subscript(field.getValue() == "checked");
properties.put_Superscript(this.chSuperscript.getValue() == "checked");
this.api.SetDrawImagePlaceParagraph("paragraphadv-font-img", properties);
}
},
this)
}
});
this.chSmallCaps = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-small-caps",
width: 140,
boxLabel: this.strSmallCaps,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps && this.checkGroup != 3) {
this._changedProps.put_SmallCaps(field.getValue() == "checked");
}
this.checkGroup = 0;
if (field.getValue() == "checked") {
this.checkGroup = 3;
this.chAllCaps.setValue(0);
if (this._changedProps) {
this._changedProps.put_AllCaps(false);
}
this.checkGroup = 0;
}
if (this.api && !this._noApply) {
var properties = (this._originalProps) ? this._originalProps : new CParagraphProp();
properties.put_SmallCaps(field.getValue() == "checked");
properties.put_AllCaps(this.chAllCaps.getValue() == "checked");
this.api.SetDrawImagePlaceParagraph("paragraphadv-font-img", properties);
}
},
this)
}
});
this.chAllCaps = Ext.create("Common.component.IndeterminateCheckBox", {
id: "paragraphadv-checkbox-all-caps",
width: 140,
boxLabel: this.strAllCaps,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps && this.checkGroup != 3) {
this._changedProps.put_AllCaps(field.getValue() == "checked");
}
this.checkGroup = 0;
if (field.getValue() == "checked") {
this.checkGroup = 3;
this.chSmallCaps.setValue(0);
if (this._changedProps) {
this._changedProps.put_SmallCaps(false);
}
this.checkGroup = 0;
}
if (this.api && !this._noApply) {
var properties = (this._originalProps) ? this._originalProps : new CParagraphProp();
properties.put_AllCaps(field.getValue() == "checked");
properties.put_SmallCaps(this.chSmallCaps.getValue() == "checked");
this.api.SetDrawImagePlaceParagraph("paragraphadv-font-img", properties);
}
},
this)
}
});
this.numSpacing = Ext.create("Common.component.MetricSpinner", {
id: "paragraphadv-spin-spacing",
readOnly: false,
step: 0.01,
width: 100,
defaultUnit: "cm",
value: "0 cm",
maxValue: 55.87,
minValue: -55.87,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
this._changedProps.put_TextSpacing(Common.MetricSettings.fnRecalcToMM(field.getNumberValue()));
}
if (this.api && !this._noApply) {
var properties = (this._originalProps) ? this._originalProps : new CParagraphProp();
properties.put_TextSpacing(Common.MetricSettings.fnRecalcToMM(field.getNumberValue()));
this.api.SetDrawImagePlaceParagraph("paragraphadv-font-img", properties);
}
},
this)
}
});
this.numPosition = Ext.widget("commonmetricspinner", {
id: "paragraphadv-spin-position",
readOnly: false,
step: 0.01,
width: 100,
defaultUnit: "cm",
value: "0 cm",
maxValue: 55.87,
minValue: -55.87,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
this._changedProps.put_Position(Common.MetricSettings.fnRecalcToMM(field.getNumberValue()));
}
if (this.api && !this._noApply) {
var properties = (this._originalProps) ? this._originalProps : new CParagraphProp();
properties.put_Position(Common.MetricSettings.fnRecalcToMM(field.getNumberValue()));
this.api.SetDrawImagePlaceParagraph("paragraphadv-font-img", properties);
}
},
this)
}
});
this.fontImage = Ext.create("Ext.container.Container", {
id: "paragraphadv-font-img",
width: "100%",
height: 80,
style: "background-color:#ffffff; border:1px solid #CDCDCD;"
});
this.numTab = Ext.widget("commonmetricspinner", {
id: "paragraphadv-spin-tab",
readOnly: false,
step: 0.1,
width: 180,
defaultUnit: "cm",
value: "1.25 cm",
maxValue: 55.87,
minValue: 0
});
this.numDefaultTab = Ext.widget("commonmetricspinner", {
id: "paragraphadv-spin-default-tab",
readOnly: false,
step: 0.1,
width: 107,
defaultUnit: "cm",
value: "1.25 cm",
maxValue: 55.87,
minValue: 0,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (this._changedProps) {
this._changedProps.put_DefaultTab(parseFloat(Common.MetricSettings.fnRecalcToMM(field.getNumberValue()).toFixed(1)));
}
},
this)
}
});
this.btnAddTab = Ext.create("Ext.Button", {
width: 90,
text: this.textSet,
enableToggle: false,
listeners: {
click: Ext.bind(function (btn, eOpts) {
var val = this.numTab.getNumberValue();
var align = this.radioLeft.getValue() ? 1 : (this.radioCenter.getValue() ? 3 : 2);
var idx = fieldStore.findBy(function (record, id) {
return (Math.abs(record.data.tabPos - val) < 0.001);
},
this);
if (idx < 0) {
var rec = fieldStore.add({
tabPos: val,
tabStr: val + " " + Common.MetricSettings.metricName[Common.MetricSettings.getCurrentMetric()],
tabAlign: align
});
fieldStore.sort();
this.tabList.getSelectionModel().select(rec);
} else {
var rec = fieldStore.getAt(idx);
rec.set("tabAlign", align);
}
},
this)
}
});
this.btnRemoveTab = Ext.create("Ext.Button", {
width: 90,
text: this.textRemove,
enableToggle: false,
listeners: {
click: Ext.bind(function (btn, eOpts) {
var rec = this.tabList.getSelectionModel().getSelection();
if (rec.length > 0) {
var idx = rec[0].index;
fieldStore.remove(rec);
if (idx > fieldStore.count() - 1) {
idx = fieldStore.count() - 1;
}
if (idx > -1) {
this.tabList.getSelectionModel().select(idx);
}
}
},
this)
}
});
this.btnRemoveAll = Ext.create("Ext.Button", {
width: 90,
text: this.textRemoveAll,
enableToggle: false,
listeners: {
click: Ext.bind(function (btn, eOpts) {
fieldStore.removeAll();
},
this)
}
});
this.radioLeft = Ext.create("Ext.form.field.Radio", {
boxLabel: this.textTabLeft,
name: "asc-radio-tab",
checked: true
});
this.radioCenter = Ext.create("Ext.form.field.Radio", {
boxLabel: this.textTabCenter,
name: "asc-radio-tab",
checked: false
});
this.radioRight = Ext.create("Ext.form.field.Radio", {
boxLabel: this.textTabRight,
name: "asc-radio-tab",
checked: false
});
Ext.define("DE.model.TabDataModel", {
extend: "Ext.data.Model",
fields: [{
name: "tabPos",
name: "tabStr",
name: "tabAlign"
}]
});
var fieldStore = Ext.create("Ext.data.Store", {
model: "DE.model.TabDataModel",
data: [],
sorters: ["tabPos"],
listeners: {
datachanged: Ext.bind(function (btn, eOpts) {
if (!this._noApply) {
this._tabListChanged = true;
}
},
this),
update: Ext.bind(function (btn, eOpts) {
if (!this._noApply) {
this._tabListChanged = true;
}
},
this),
clear: Ext.bind(function (btn, eOpts) {
if (!this._noApply) {
this._tabListChanged = true;
}
},
this)
}
});
this.tabList = Ext.create("Ext.grid.Panel", {
activeItem: 0,
id: "paragraphadv-tab-list",
store: fieldStore,
mode: "local",
scroll: false,
columns: [{
flex: 1,
dataIndex: "tabStr"
}],
height: 80,
width: 180,
hideHeaders: true,
viewConfig: {
stripeRows: false
},
plugins: [{
pluginId: "scrollpane",
ptype: "gridscrollpane"
}],
listeners: {
select: function (o, record, index, eOpts) {
this.numTab.setValue(record.data.tabPos);
(record.data.tabAlign == 1) ? this.radioLeft.setValue(true) : ((record.data.tabAlign == 3) ? this.radioCenter.setValue(true) : this.radioRight.setValue(true));
},
scope: this
}
});
this._spnMarginTop = Ext.create("Common.component.MetricSpinner", {
id: "paraadv-number-margin-top",
readOnly: false,
maxValue: 55.87,
minValue: 0,
step: 0.1,
defaultUnit: "cm",
value: "0 cm",
width: 100,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (!this._noApply) {
if (this.Margins === undefined) {
this.Margins = {};
}
this.Margins.Top = Common.MetricSettings.fnRecalcToMM(field.getNumberValue());
}
},
this)
}
});
this._spnMarginBottom = Ext.create("Common.component.MetricSpinner", {
id: "paraadv-number-margin-bottom",
readOnly: false,
maxValue: 55.87,
minValue: 0,
step: 0.1,
defaultUnit: "cm",
value: "0 cm",
width: 100,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (!this._noApply) {
if (this.Margins === undefined) {
this.Margins = {};
}
this.Margins.Bottom = Common.MetricSettings.fnRecalcToMM(field.getNumberValue());
}
},
this)
}
});
this._spnMarginLeft = Ext.create("Common.component.MetricSpinner", {
id: "paraadv-number-margin-left",
readOnly: false,
maxValue: 9.34,
minValue: 0,
step: 0.1,
defaultUnit: "cm",
value: "0.19 cm",
width: 100,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (!this._noApply) {
if (this.Margins === undefined) {
this.Margins = {};
}
this.Margins.Left = Common.MetricSettings.fnRecalcToMM(field.getNumberValue());
}
},
this)
}
});
this._spnMarginRight = Ext.create("Common.component.MetricSpinner", {
id: "paraadv-number-margin-right",
readOnly: false,
maxValue: 9.34,
minValue: 0,
step: 0.1,
defaultUnit: "cm",
value: "0.19 cm",
width: 100,
listeners: {
change: Ext.bind(function (field, newValue, oldValue, eOpts) {
if (!this._noApply) {
if (this.Margins === undefined) {
this.Margins = {};
}
this.Margins.Right = Common.MetricSettings.fnRecalcToMM(field.getNumberValue());
}
},
this)
}
});
this.btnIndents = Ext.widget("button", {
width: 160,
height: 27,
cls: "asc-dialogmenu-btn",
text: this.strParagraphIndents,
textAlign: "right",
enableToggle: true,
allowDepress: false,
toggleGroup: "advtablecardGroup",
pressed: true,
listeners: {
click: function (btn) {
if (btn.pressed) {
this.mainCard.getLayout().setActiveItem("card-indents");
}
},
scope: this
}
});
this.btnFont = Ext.widget("button", {
width: 160,
height: 27,
cls: "asc-dialogmenu-btn",
text: this.strParagraphFont,
textAlign: "right",
enableToggle: true,
allowDepress: false,
toggleGroup: "advtablecardGroup",
listeners: {
click: function (btn) {
if (btn.pressed) {
this.mainCard.getLayout().setActiveItem("card-font");
}
},
scope: this
}
});
this.btnBorders = Ext.widget("button", {
width: 160,
height: 27,
cls: "asc-dialogmenu-btn",
textAlign: "right",
text: this.strBorders,
enableToggle: true,
allowDepress: false,
toggleGroup: "advtablecardGroup",
listeners: {
click: function (btn) {
if (btn.pressed) {
this.mainCard.getLayout().setActiveItem("card-borders");
}
},
scope: this
}
});
this.btnTabs = Ext.widget("button", {
width: 160,
height: 27,
cls: "asc-dialogmenu-btn",
textAlign: "right",
text: this.strTabs,
enableToggle: true,
allowDepress: false,
toggleGroup: "advtablecardGroup",
listeners: {
click: function (btn) {
if (btn.pressed) {
this.mainCard.getLayout().setActiveItem("card-tabs");
this.tabList.getPlugin("scrollpane").updateScrollPane();
}
},
scope: this
}
});
this.btnMargins = Ext.widget("button", {
width: 160,
height: 27,
cls: "asc-dialogmenu-btn",
textAlign: "right",
text: this.strMargins,
enableToggle: true,
allowDepress: false,
toggleGroup: "advtablecardGroup",
listeners: {
click: function (btn) {
if (btn.pressed) {
this.mainCard.getLayout().setActiveItem("card-margins");
}
},
scope: this
}
});
this._BordersContainer = {
xtype: "container",
itemId: "card-borders",
layout: {
type: "vbox",
align: "stretch"
},
height: 285,
items: [{
xtype: "container",
layout: {
type: "hbox",
align: "middle"
},
height: 28,
padding: "2px 10px 0 10px",
style: "vertical-align: middle;",
items: [{
xtype: "label",
text: this.textBorderWidth
},
{
xtype: "tbspacer",
width: 4
},
this.cmbBorderSize, {
xtype: "tbspacer",
flex: 1
},
{
xtype: "label",
text: this.textBorderColor
},
{
xtype: "tbspacer",
width: 4
},
this._btnBorderColor]
},
{
xtype: "tbspacer",
height: 10
},
{
xtype: "label",
text: this.textBorderDesc,
style: "padding-left:10px;height:13px;"
},
{
xtype: "tbspacer",
height: 20
},
{
xtype: "container",
layout: {
type: "hbox",
align: "top"
},
height: 180,
width: 200,
padding: "0 10",
style: "vertical-align: top;",
items: [this.bordersImagePanel = Ext.create("Ext.container.Container", {
layout: "card",
activeItem: 0,
width: 200,
height: 180,
style: "padding-bottom:10px;",
items: [this._BordersImage]
}), {
xtype: "tbspacer",
width: 25
},
{
xtype: "container",
layout: "hbox",
height: 180,
width: 100,
items: [this._PresetsContainer = Ext.create("Ext.container.Container", {
height: 180,
width: 100,
layout: {
type: "table",
columns: 2,
tdAttrs: {
style: "padding-right: 10px; padding-bottom: 4px; vertical-align: middle;"
}
},
items: [{
xtype: "tbspacer",
height: 5
},
{
xtype: "tbspacer",
height: 5
},
this._btnsBorderPosition[5], this._btnsBorderPosition[6], this._btnsBorderPosition[7], this._btnsBorderPosition[0], this._btnsBorderPosition[3], this._btnsBorderPosition[1], this._btnsBorderPosition[4], this._btnsBorderPosition[2]]
})]
}]
},
{
xtype: "tbspacer",
height: 5
},
{
xtype: "container",
height: 23,
padding: "0 10",
layout: "hbox",
items: [this._BackContainer = Ext.create("Ext.container.Container", {
height: 23,
width: 150,
layout: "hbox",
margin: "0 4px 0 0",
items: [{
xtype: "label",
text: this.textBackColor,
margin: "2px 4px 0 0"
},
this._btnBackColor]
})]
}]
};
this._IndentsContainer = {
xtype: "container",
itemId: "card-indents",
width: 340,
layout: {
type: "vbox",
align: "stretch"
},
items: [{
xtype: "container",
padding: "0 10",
layout: {
type: "table",
columns: 5
},
defaults: {
xtype: "container",
layout: "vbox",
layoutConfig: {
align: "stretch"
},
height: 40,
style: "float:left;"
},
items: [{
items: [{
xtype: "label",
text: this.strIndentsFirstLine,
width: 85
},
{
xtype: "tbspacer",
height: 3
},
this.numFirstLine]
},
{
xtype: "tbspacer",
width: 23,
height: 3
},
{
items: [{
xtype: "label",
text: this.strIndentsLeftText,
width: 85
},
{
xtype: "tbspacer",
height: 3
},
this.numIndentsLeft]
},
{
xtype: "tbspacer",
width: 23,
height: 3
},
{
items: [{
xtype: "label",
text: this.strIndentsRightText,
width: 85
},
{
xtype: "tbspacer",
height: 3
},
this.numIndentsRight]
}]
},
this._spacer.cloneConfig({
style: "margin: 16px 0 11px 0;",
height: 6
}), {
xtype: "container",
height: 25,
padding: "0 10",
layout: {
type: "table",
columns: 3,
tdAttrs: {
style: "vertical-align: middle;"
}
},
items: [this.chBreakBefore, {
xtype: "tbspacer",
width: 10,
height: 3
},
this.chKeepLines, this.chOrphan, {
xtype: "tbspacer",
width: 10,
height: 3
},
this.chKeepNext]
}]
};
this._FontContainer = {
xtype: "container",
itemId: "card-font",
width: 340,
layout: {
type: "vbox",
align: "stretch"
},
items: [{
xtype: "label",
style: "font-weight: bold;margin-top: 1px; padding-left:10px;height:13px;",
text: this.textEffects
},
{
xtype: "tbspacer",
height: 8
},
{
xtype: "container",
height: 85,
width: "100%",
padding: "0 10",
layout: {
type: "table",
columns: 3,
tdAttrs: {
style: "vertical-align: middle;"
}
},
items: [this.chStrike, {
xtype: "tbspacer",
width: 20,
height: 2
},
this.chSubscript, this.chDoubleStrike, {
xtype: "tbspacer",
width: 20,
height: 2
},
this.chSmallCaps, this.chSuperscript, {
xtype: "tbspacer",
width: 20,
height: 2
},
this.chAllCaps]
},
{
xtype: "label",
style: "font-weight: bold;margin-top: 1px; padding-left:10px;height:13px;",
text: this.textCharacterSpacing
},
{
xtype: "tbspacer",
height: 8
},
{
xtype: "container",
height: 46,
padding: "0 10",
layout: {
type: "table",
columns: 3,
tdAttrs: {
style: "vertical-align: middle;"
}
},
items: [{
xtype: "label",
text: this.textSpacing,
width: 85
},
{
xtype: "tbspacer",
width: 60,
height: 2
},
{
xtype: "label",
text: this.textPosition,
width: 85
},
{
xtype: "tbspacer",
height: 2
},
{
xtype: "tbspacer",
height: 2
},
{
xtype: "tbspacer",
height: 2
},
this.numSpacing, {
xtype: "tbspacer",
width: 60,
height: 2
},
this.numPosition]
},
{
xtype: "tbspacer",
height: 10
},
{
xtype: "container",
height: 85,
padding: "0 10",
items: [this.fontImage]
}]
};
this._TabsContainer = {
xtype: "container",
itemId: "card-tabs",
width: 340,
layout: {
type: "vbox",
align: "stretch"
},
items: [{
xtype: "container",
padding: "0 0 0 10",
layout: {
type: "table",
columns: 3,
tdAttrs: {
style: "padding-right: 7px;"
}
},
defaults: {
xtype: "container",
layout: "vbox",
layoutConfig: {
align: "stretch"
},
style: "float:left;"
},
items: [{
height: 50,
colspan: 2,
items: [{
xtype: "label",
text: this.textTabPosition,
width: 85
},
{
xtype: "tbspacer",
height: 3
},
this.numTab]
},
{
height: 50,
items: [{
xtype: "label",
text: this.textDefault,
width: 107
},
{
xtype: "tbspacer",
height: 3
},
this.numDefaultTab]
},
{
height: 95,
colspan: 3,
items: [this.tabList]
},
{
height: 100,
colspan: 3,
items: [{
xtype: "label",
text: this.textAlign,
width: 85
},
{
xtype: "tbspacer",
height: 3
},
this.radioLeft, this.radioCenter, this.radioRight]
},
this.btnAddTab, this.btnRemoveTab, this.btnRemoveAll]
}]
};
this._MarginsContainer = {
xtype: "container",
itemId: "card-margins",
width: 340,
layout: {
type: "vbox",
align: "stretch"
},
items: [{
xtype: "container",
padding: "0 10",
layout: {
type: "table",
columns: 2,
tdAttrs: {
style: "padding-right: 40px;vertical-align: middle;"
}
},
items: [{
xtype: "label",
text: this.textTop,
width: 85
},
{
xtype: "label",
text: this.textLeft,
width: 85
},
{
xtype: "tbspacer",
height: 2
},
{
xtype: "tbspacer",
height: 2
},
this._spnMarginTop, this._spnMarginLeft, {
xtype: "tbspacer",
height: 5
},
{
xtype: "tbspacer",
height: 5
},
{
xtype: "label",
text: this.textBottom,
width: 85
},
{
xtype: "label",
text: this.textRight,
width: 85
},
{
xtype: "tbspacer",
height: 2
},
{
xtype: "tbspacer",
height: 2
},
this._spnMarginBottom, this._spnMarginRight]
}]
};
this.items = [{
xtype: "container",
height: 300,
layout: {
type: "hbox",
align: "stretch"
},
items: [{
xtype: "container",
width: 160,
padding: "5px 0 0 0",
layout: {
type: "vbox",
align: "stretch"
},
defaults: {
xtype: "container",
layout: {
type: "hbox",
align: "middle",
pack: "end"
}
},
items: [{
height: 30,
items: [this.btnIndents]
},
{
height: 30,
items: [this.btnBorders]
},
{
height: 30,
items: [this.btnFont]
},
{
height: 30,
items: [this.btnTabs]
},
{
height: 30,
items: [this.btnMargins]
}]
},
{
xtype: "box",
cls: "advanced-settings-separator",
height: "100%",
width: 8
},
this.mainCard = Ext.create("Ext.container.Container", {
height: 300,
flex: 1,
padding: "12px 18px 0 10px",
layout: "card",
items: [this._IndentsContainer, this._BordersContainer, this._FontContainer, this._TabsContainer, this._MarginsContainer]
})]
},
this._spacer.cloneConfig({
style: "margin: 0 18px"
}), {
xtype: "container",
height: 40,
layout: {
type: "vbox",
align: "center",
pack: "center"
},
items: [{
xtype: "container",
width: 182,
height: 24,
layout: {
type: "hbox",
align: "middle"
},
items: [this.btnOk = Ext.widget("button", {
cls: "asc-blue-button",
width: 86,
height: 22,
margin: "0 5px 0 0",
text: this.okButtonText,
listeners: {
click: function (btn) {
this.fireEvent("onmodalresult", this, 1, this.getSettings());
this.close();
},
scope: this
}
}), this.btnCancel = Ext.widget("button", {
cls: "asc-darkgray-button",
width: 86,
height: 22,
text: this.cancelButtonText,
listeners: {
click: function (btn) {
this.fireEvent("onmodalresult", this, 0);
this.close();
},
scope: this
}
})]
}]
}];
this.callParent(arguments);
},
afterRender: function () {
this.callParent(arguments);
this._setDefaults(this._originalProps);
if (this.borderProps !== undefined) {
this._btnBorderColor.setColor(this.borderProps.borderColor);
var colorstr = Ext.String.format("#{0}", (typeof(this.borderProps.borderColor) == "object") ? this.borderProps.borderColor.color : this.borderProps.borderColor);
this._BordersImage.setVirtualBorderColor(colorstr);
var rec = this.cmbBorderSize.getStore().findRecord("value", this.borderProps.borderSize.ptValue);
if (rec) {
this.cmbBorderSize.select(rec);
this.cmbBorderSize.fireEvent("select", this.cmbBorderSize, [rec]);
}
this.colorsBorder.select(this.borderProps.borderColor);
}
this.setTitle(this.textTitle);
if (this.colorProps !== undefined) {
this.sendThemeColors(this.colorProps[0], this.colorProps[1]);
}
for (var i = 0; i < this._BordersImage.rows; i++) {
for (var j = 0; j < this._BordersImage.columns; j++) {
this._BordersImage.getCell(j, i).addListener("borderclick", function (ct, border, size, color) {
if (this.ChangedBorders === undefined) {
this.ChangedBorders = new CParagraphBorders();
}
this._UpdateCellBordersStyle(ct, border, size, color, this.Borders);
},
this);
}
}
this._BordersImage.addListener("borderclick", function (ct, border, size, color) {
if (this.ChangedBorders === undefined) {
this.ChangedBorders = new CParagraphBorders();
}
this._UpdateTableBordersStyle(ct, border, size, color, this.Borders);
},
this);
},
setSettings: function (props) {
this._originalProps = new CParagraphProp(props.paragraphProps);
this.borderProps = props.borderProps;
this.colorProps = props.colorProps;
this._changedProps = null;
this.api = props.api;
},
_setDefaults: function (props) {
if (props) {
this._originalProps = new CParagraphProp(props);
this.numFirstLine.setValue((props.get_Ind() !== null && props.get_Ind().get_FirstLine() !== null) ? Common.MetricSettings.fnRecalcFromMM(props.get_Ind().get_FirstLine()) : "");
this.numIndentsLeft.setValue((props.get_Ind() !== null && props.get_Ind().get_Left() !== null) ? Common.MetricSettings.fnRecalcFromMM(props.get_Ind().get_Left()) : "");
this.numIndentsRight.setValue((props.get_Ind() !== null && props.get_Ind().get_Right() !== null) ? Common.MetricSettings.fnRecalcFromMM(props.get_Ind().get_Right()) : "");
this.chKeepLines.setValue((props.get_KeepLines() !== null && props.get_KeepLines() !== undefined) ? props.get_KeepLines() : "indeterminate");
this.chBreakBefore.setValue((props.get_PageBreakBefore() !== null && props.get_PageBreakBefore() !== undefined) ? props.get_PageBreakBefore() : "indeterminate");
this.chKeepNext.setValue((props.get_KeepNext() !== null && props.get_KeepNext() !== undefined) ? props.get_KeepNext() : "indeterminate");
this.chOrphan.setValue((props.get_WidowControl() !== null && props.get_WidowControl() !== undefined) ? props.get_WidowControl() : "indeterminate");
this.Borders = new CParagraphBorders(props.get_Borders());
if (this.Borders) {
var brd = this.Borders.get_Left();
var val = (null !== brd && undefined !== brd && null !== brd.get_Space() && undefined !== brd.get_Space()) ? Common.MetricSettings.fnRecalcFromMM(brd.get_Space()) : "";
this._spnMarginLeft.setValue(val);
brd = this.Borders.get_Top();
val = (null !== brd && undefined !== brd && null !== brd.get_Space() && undefined !== brd.get_Space()) ? Common.MetricSettings.fnRecalcFromMM(brd.get_Space()) : "";
this._spnMarginTop.setValue(val);
brd = this.Borders.get_Right();
val = (null !== brd && undefined !== brd && null !== brd.get_Space() && undefined !== brd.get_Space()) ? Common.MetricSettings.fnRecalcFromMM(brd.get_Space()) : "";
this._spnMarginRight.setValue(val);
brd = this.Borders.get_Bottom();
val = (null !== brd && undefined !== brd && null !== brd.get_Space() && undefined !== brd.get_Space()) ? Common.MetricSettings.fnRecalcFromMM(brd.get_Space()) : "";
this._spnMarginBottom.setValue(val);
}
var shd = props.get_Shade();
if (shd !== null && shd !== undefined && shd.get_Value() === shd_Clear) {
var color = shd.get_Color();
if (color) {
if (color.get_type() == c_oAscColor.COLOR_TYPE_SCHEME) {
this.paragraphShade = {
color: this.getHexColor(color.get_r(), color.get_g(), color.get_b()),
effectValue: color.get_value()
};
} else {
this.paragraphShade = this.getHexColor(color.get_r(), color.get_g(), color.get_b());
}
} else {
this.paragraphShade = "transparent";
}
} else {
this.paragraphShade = "transparent";
}
this._btnBackColor.setColor(this.paragraphShade);
if (typeof(this.paragraphShade) == "object") {
for (var i = 0; i < 10; i++) {
if (this.ThemeValues[i] == this.paragraphShade.effectValue) {
this.colorsBack.select(this.paragraphShade, true);
break;
}
}
} else {
this.colorsBack.select(this.paragraphShade, true);
}
this._UpdateBorders();
this._noApply = true;
this.chStrike.setValue((props.get_Strikeout() !== null && props.get_Strikeout() !== undefined) ? props.get_Strikeout() : "indeterminate");
this.chDoubleStrike.setValue((props.get_DStrikeout() !== null && props.get_DStrikeout() !== undefined) ? props.get_DStrikeout() : "indeterminate");
this.chSubscript.setValue((props.get_Subscript() !== null && props.get_Subscript() !== undefined) ? props.get_Subscript() : "indeterminate");
this.chSuperscript.setValue((props.get_Superscript() !== null && props.get_Superscript() !== undefined) ? props.get_Superscript() : "indeterminate");
this.chSmallCaps.setValue((props.get_SmallCaps() !== null && props.get_SmallCaps() !== undefined) ? props.get_SmallCaps() : "indeterminate");
this.chAllCaps.setValue((props.get_AllCaps() !== null && props.get_AllCaps() !== undefined) ? props.get_AllCaps() : "indeterminate");
this.numSpacing.setValue((props.get_TextSpacing() !== null && props.get_TextSpacing() !== undefined) ? Common.MetricSettings.fnRecalcFromMM(props.get_TextSpacing()) : "");
this.numPosition.setValue((props.get_Position() !== null && props.get_Position() !== undefined) ? Common.MetricSettings.fnRecalcFromMM(props.get_Position()) : "");
this.api.SetDrawImagePlaceParagraph("paragraphadv-font-img", this._originalProps);
this.numDefaultTab.setValue((props.get_DefaultTab() !== null && props.get_DefaultTab() !== undefined) ? Common.MetricSettings.fnRecalcFromMM(parseFloat(props.get_DefaultTab().toFixed(1))) : "");
var tabs = props.get_Tabs();
if (tabs) {
var arr = [];
var count = tabs.get_Count();
for (var i = 0; i < count; i++) {
var tab = tabs.get_Tab(i);
var rec = {
tabPos: Common.MetricSettings.fnRecalcFromMM(parseFloat(tab.get_Pos().toFixed(1))),
tabAlign: tab.get_Value()
};
rec.tabStr = parseFloat(Ext.Number.toFixed(rec.tabPos, 3)) + " " + Common.MetricSettings.metricName[Common.MetricSettings.getCurrentMetric()];
arr.push(rec);
}
this.tabList.getStore().loadData(arr);
this.tabList.getStore().sort();
if (this.tabList.getStore().count() > 0) {
this.tabList.getSelectionModel().select(0);
}
}
this._noApply = false;
this._changedProps = new CParagraphProp();
this.ChangedBorders = undefined;
}
},
getSettings: function () {
if (this.ChangedBorders === null) {
this._changedProps.put_Borders(this.Borders);
} else {
if (this.ChangedBorders !== undefined) {
this._changedProps.put_Borders(this.ChangedBorders);
}
}
if (this.Margins) {
var borders = this._changedProps.get_Borders();
if (borders === undefined || borders === null) {
this._changedProps.put_Borders(new CParagraphBorders());
borders = this._changedProps.get_Borders();
}
if (this.Margins.Left !== undefined) {
if (borders.get_Left() === undefined || borders.get_Left() === null) {
borders.put_Left(new CBorder(this.Borders.get_Left()));
}
borders.get_Left().put_Space(this.Margins.Left);
}
if (this.Margins.Top !== undefined) {
if (borders.get_Top() === undefined || borders.get_Top() === null) {
borders.put_Top(new CBorder(this.Borders.get_Top()));
}
borders.get_Top().put_Space(this.Margins.Top);
}
if (this.Margins.Right !== undefined) {
if (borders.get_Right() === undefined || borders.get_Right() === null) {
borders.put_Right(new CBorder(this.Borders.get_Right()));
}
borders.get_Right().put_Space(this.Margins.Right);
}
if (this.Margins.Bottom !== undefined) {
if (borders.get_Bottom() === undefined || borders.get_Bottom() === null) {
borders.put_Bottom(new CBorder(this.Borders.get_Bottom()));
}
borders.get_Bottom().put_Space(this.Margins.Bottom);
if (borders.get_Between() === undefined || borders.get_Between() === null) {
borders.put_Between(new CBorder(this.Borders.get_Between()));
}
borders.get_Between().put_Space(this.Margins.Bottom);
}
}
if (this._tabListChanged) {
if (this._changedProps.get_Tabs() === null || this._changedProps.get_Tabs() === undefined) {
this._changedProps.put_Tabs(new CParagraphTabs());
}
this.tabList.getStore().each(function (item, index) {
var tab = new CParagraphTab(Common.MetricSettings.fnRecalcToMM(item.data.tabPos), item.data.tabAlign);
this._changedProps.get_Tabs().add_Tab(tab);
},
this);
}
return {
paragraphProps: this._changedProps,
borderProps: {
borderSize: this.BorderSize,
borderColor: this._btnBorderColor.color
}
};
},
_UpdateBorders: function () {
var oldSize = this.BorderSize;
var oldColor = this._btnBorderColor.color;
this._UpdateBorder(this.Borders.get_Left(), "l");
this._UpdateBorder(this.Borders.get_Top(), "t");
this._UpdateBorder(this.Borders.get_Right(), "r");
this._UpdateBorder(this.Borders.get_Bottom(), "b");
if (this.Borders.get_Between() !== null) {
for (var i = 0; i < this._BordersImage.columns; i++) {
this._UpdateCellBorder(this.Borders.get_Between(), "b", this._BordersImage.getCell(i, 0));
this._UpdateCellBorder(this.Borders.get_Between(), "t", this._BordersImage.getCell(i, 1));
}
}
this._BordersImage.setVirtualBorderSize(oldSize.pxValue);
var colorstr = Ext.String.format("#{0}", (typeof(oldColor) == "object") ? oldColor.color : oldColor);
this._BordersImage.setVirtualBorderColor(colorstr);
},
_UpdateCellBorder: function (BorderParam, borderName, cell) {
if (null !== BorderParam && undefined !== BorderParam) {
if (null !== BorderParam.get_Value() && null !== BorderParam.get_Size() && null !== BorderParam.get_Color() && 1 == BorderParam.get_Value()) {
cell.setBordersSize(borderName, this._BorderPt2Px(BorderParam.get_Size() * 72 / 25.4));
cell.setBordersColor(borderName, "rgb(" + BorderParam.get_Color().get_r() + "," + BorderParam.get_Color().get_g() + "," + BorderParam.get_Color().get_b() + ")");
} else {
cell.setBordersSize(borderName, 0);
}
} else {
cell.setBordersSize(borderName, 0);
}
},
_UpdateBorder: function (BorderParam, borderName) {
if (null !== BorderParam && undefined !== BorderParam) {
if (null !== BorderParam.get_Value() && null !== BorderParam.get_Size() && null !== BorderParam.get_Color() && 1 == BorderParam.get_Value()) {
this._BordersImage.setBordersSize(borderName, this._BorderPt2Px(BorderParam.get_Size() * 72 / 25.4));
this._BordersImage.setBordersColor(borderName, "rgb(" + BorderParam.get_Color().get_r() + "," + BorderParam.get_Color().get_g() + "," + BorderParam.get_Color().get_b() + ")");
} else {
this._BordersImage.setBordersSize(borderName, 0);
}
} else {
this._BordersImage.setBordersSize(borderName, 0);
}
},
_BorderPt2Px: function (value) {
if (value == 0) {
return 0;
}
if (value < 0.6) {
return 0.5;
}
if (value <= 1) {
return 1;
}
if (value <= 1.5) {
return 2;
}
if (value <= 2.25) {
return 3;
}
if (value <= 3) {
return 4;
}
if (value <= 4.5) {
return 5;
}
return 6;
},
_ApplyBorderPreset: function (border) {
this.ChangedBorders = null;
this.Borders.put_Left(this._UpdateBorderStyle(this.Borders.get_Left(), (border.indexOf("l") > -1)));
this.Borders.put_Top(this._UpdateBorderStyle(this.Borders.get_Top(), (border.indexOf("t") > -1)));
this.Borders.put_Right(this._UpdateBorderStyle(this.Borders.get_Right(), (border.indexOf("r") > -1)));
this.Borders.put_Bottom(this._UpdateBorderStyle(this.Borders.get_Bottom(), (border.indexOf("b") > -1)));
this.Borders.put_Between(this._UpdateBorderStyle(this.Borders.get_Between(), (border.indexOf("m") > -1)));
this._UpdateBorders();
},
_UpdateBorderStyle: function (border, visible) {
if (null == border) {
border = new CBorder();
}
if (visible && this.BorderSize.ptValue > 0) {
var size = parseFloat(this.BorderSize.ptValue);
border.put_Value(1);
border.put_Size(size * 25.4 / 72);
var color = this.getRgbColor(this._btnBorderColor.color);
border.put_Color(color);
} else {
border.put_Color(new CColor());
border.put_Value(0);
}
return border;
},
_UpdateCellBordersStyle: function (ct, border, size, color, destination) {
var updateBorders = destination;
if (ct.col == 0 && border.indexOf("l") > -1) {
updateBorders.put_Left(this._UpdateBorderStyle(updateBorders.get_Left(), (size > 0)));
if (this.ChangedBorders) {
this.ChangedBorders.put_Left(new CBorder(updateBorders.get_Left()));
}
}
if (ct.col == this.tableStylerColumns - 1 && border.indexOf("r") > -1) {
updateBorders.put_Right(this._UpdateBorderStyle(updateBorders.get_Right(), (size > 0)));
if (this.ChangedBorders) {
this.ChangedBorders.put_Right(new CBorder(updateBorders.get_Right()));
}
}
if (ct.row == 0 && border.indexOf("t") > -1) {
updateBorders.put_Top(this._UpdateBorderStyle(updateBorders.get_Top(), (size > 0)));
if (this.ChangedBorders) {
this.ChangedBorders.put_Top(new CBorder(updateBorders.get_Top()));
}
}
if (ct.row == this.tableStylerRows - 1 && border.indexOf("b") > -1) {
updateBorders.put_Bottom(this._UpdateBorderStyle(updateBorders.get_Bottom(), (size > 0)));
if (this.ChangedBorders) {
this.ChangedBorders.put_Bottom(new CBorder(updateBorders.get_Bottom()));
}
}
if (ct.row == 0 && border.indexOf("b") > -1 || ct.row == this.tableStylerRows - 1 && border.indexOf("t") > -1) {
updateBorders.put_Between(this._UpdateBorderStyle(updateBorders.get_Between(), (size > 0)));
if (this.ChangedBorders) {
this.ChangedBorders.put_Between(new CBorder(updateBorders.get_Between()));
}
}
},
_UpdateTableBordersStyle: function (ct, border, size, color, destination) {
var updateBorders = destination;
if (border.indexOf("l") > -1) {
updateBorders.put_Left(this._UpdateBorderStyle(updateBorders.get_Left(), (size > 0)));
if (this.ChangedBorders) {
this.ChangedBorders.put_Left(new CBorder(updateBorders.get_Left()));
}
}
if (border.indexOf("t") > -1) {
updateBorders.put_Top(this._UpdateBorderStyle(updateBorders.get_Top(), (size > 0)));
if (this.ChangedBorders) {
this.ChangedBorders.put_Top(new CBorder(updateBorders.get_Top()));
}
}
if (border.indexOf("r") > -1) {
updateBorders.put_Right(this._UpdateBorderStyle(updateBorders.get_Right(), (size > 0)));
if (this.ChangedBorders) {
this.ChangedBorders.put_Right(new CBorder(updateBorders.get_Right()));
}
}
if (border.indexOf("b") > -1) {
updateBorders.put_Bottom(this._UpdateBorderStyle(updateBorders.get_Bottom(), (size > 0)));
if (this.ChangedBorders) {
this.ChangedBorders.put_Bottom(new CBorder(updateBorders.get_Bottom()));
}
}
},
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;
},
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;
},
sendThemeColors: function (effectcolors, standartcolors) {
if (standartcolors && effectcolors) {
this.colorsBorder.updateColors(effectcolors, standartcolors);
this.colorsBack.updateColors(effectcolors, standartcolors);
}
},
updateMetricUnit: function () {
var spinners = this.query("commonmetricspinner");
if (spinners) {
for (var i = 0; i < spinners.length; i++) {
var spinner = spinners[i];
spinner.setDefaultUnit(Common.MetricSettings.metricName[Common.MetricSettings.getCurrentMetric()]);
if (spinner.id == "paragraphadv-spin-spacing" || spinner.id == "paragraphadv-spin-position") {
spinner.setStep(Common.MetricSettings.getCurrentMetric() == Common.MetricSettings.c_MetricUnits.cm ? 0.01 : 1);
} else {
spinner.setStep(Common.MetricSettings.getCurrentMetric() == Common.MetricSettings.c_MetricUnits.cm ? 0.1 : 1);
}
}
}
},
textTitle: "Paragraph - Advanced Settings",
strIndentsFirstLine: "First line",
strIndentsLeftText: "Left",
strIndentsRightText: "Right",
strParagraphIndents: "Indents & Placement",
strParagraphPosition: "Placement",
strParagraphFont: "Font",
strBreakBefore: "Page break before",
strKeepLines: "Keep lines together",
strBorders: "Borders & Fill",
textBorderWidth: "Border Size",
textBorderColor: "Border Color",
textBackColor: "Background Color",
textBorderDesc: "Click on diagramm or use buttons to select borders",
cancelButtonText: "Cancel",
okButtonText: "Ok",
txtNoBorders: "No borders",
textNewColor: "Add New Custom Color",
textEffects: "Effects",
textCharacterSpacing: "Character Spacing",
textSpacing: "Spacing",
textPosition: "Position",
strDoubleStrike: "Double strikethrough",
strStrike: "Strikethrough",
strSuperscript: "Superscript",
strSubscript: "Subscript",
strSmallCaps: "Small caps",
strAllCaps: "All caps",
textThemeColors: "Theme Colors",
textStandartColors: "Standart Colors",
strOrphan: "Orphan control",
strKeepNext: "Keep with next",
strTabs: "Tab",
textSet: "Specify",
textRemove: "Remove",
textRemoveAll: "Remove All",
textTabLeft: "Left",
textTabRight: "Right",
textTabCenter: "Center",
textAlign: "Alignment",
textTabPosition: "Tab Position",
textDefault: "Default Tab",
textTop: "Top",
textLeft: "Left",
textBottom: "Bottom",
textRight: "Right",
strMargins: "Margins",
tipTop: "Set Top Border Only",
tipLeft: "Set Left Border Only",
tipBottom: "Set Bottom Border Only",
tipRight: "Set Right Border Only",
tipAll: "Set Outer Border and All Inner Lines",
tipNone: "Set No Borders",
tipInner: "Set Horizontal Inner Lines Only",
tipOuter: "Set Outer Border Only"
});