2016-04-01 13:17:09 +00:00
/ *
*
2019-01-17 13:05:03 +00:00
* ( c ) Copyright Ascensio System SIA 2010 - 2019
2016-04-01 13:17:09 +00:00
*
* 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
*
2019-01-17 13:00:34 +00:00
* You can contact Ascensio System SIA at 20 A - 12 Ernesta Birznieka - Upisha
* street , Riga , Latvia , EU , LV - 1050.
2016-04-01 13:17:09 +00:00
*
* 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
*
* /
2016-03-11 00:48:53 +00:00
/ * *
* TextArtSettings . js
*
* Created by Julia Radzhabova on 7 / 10 / 15
2018-03-01 12:16:38 +00:00
* Copyright ( c ) 2018 Ascensio System SIA . All rights reserved .
2016-03-11 00:48:53 +00:00
*
* /
define ( [
'text!documenteditor/main/app/template/TextArtSettings.template' ,
'jquery' ,
'underscore' ,
'backbone' ,
'common/main/lib/component/ComboBox' ,
'common/main/lib/component/ComboBorderSize' ,
'common/main/lib/component/MetricSpinner' ,
'common/main/lib/component/ThemeColorPalette' ,
'common/main/lib/component/ColorButton' ,
'common/main/lib/component/ComboDataView' ,
'common/main/lib/component/Slider' ,
'common/main/lib/component/MultiSliderGradient'
] , function ( menuTemplate , $ , _ , Backbone ) {
'use strict' ;
DE . Views . TextArtSettings = Backbone . View . extend ( _ . extend ( {
el : '#id-textart-settings' ,
// Compile our stats template
template : _ . template ( menuTemplate ) ,
// Delegated events for creating new items, and clearing completed ones.
events : {
} ,
options : {
alias : 'TextArtSettings'
} ,
initialize : function ( ) {
this . _initSettings = true ;
this . _noApply = true ;
this . imgprops = null ;
this . shapeprops = null ;
this . _sendUndoPoint = true ;
this . _sliderChanged = false ;
2016-04-06 13:38:54 +00:00
this . txtPt = Common . Utils . Metric . getMetricName ( Common . Utils . Metric . c _MetricUnits . pt ) ;
2016-03-11 00:48:53 +00:00
this . _state = {
Transparency : null ,
2016-04-05 11:52:34 +00:00
FillType : Asc . c _oAscFill . FILL _TYPE _SOLID ,
2016-03-11 00:48:53 +00:00
ShapeColor : 'transparent' ,
2016-04-05 11:52:34 +00:00
StrokeType : Asc . c _oAscStrokeType . STROKE _COLOR ,
2016-03-11 00:48:53 +00:00
StrokeWidth : this . _pt2mm ( 1 ) ,
StrokeColor : '000000' ,
2016-06-29 12:47:08 +00:00
StrokeBorderType : Asc . c _oDashType . solid ,
2016-03-11 00:48:53 +00:00
GradColor : '000000' ,
2016-04-05 11:52:34 +00:00
GradFillType : Asc . c _oAscFillGradType . GRAD _LINEAR ,
2016-03-11 00:48:53 +00:00
FormId : null ,
DisabledControls : false
} ;
this . lockedControls = [ ] ;
this . _locked = false ;
2016-04-05 11:52:34 +00:00
this . OriginalFillType = Asc . c _oAscFill . FILL _TYPE _SOLID ;
2016-03-11 00:48:53 +00:00
this . ShapeColor = { Value : 1 , Color : 'transparent' } ; // value=1 - цвет определен - прозрачный или другой, value=0 - цвет не определен, рисуем прозрачным
2016-04-05 11:52:34 +00:00
this . GradFillType = Asc . c _oAscFillGradType . GRAD _LINEAR ;
2016-03-11 00:48:53 +00:00
this . GradColor = { values : [ 0 , 100 ] , colors : [ '000000' , 'ffffff' ] , currentIdx : 0 } ;
this . GradRadialDirectionIdx = 0 ;
this . GradLinearDirectionType = 0 ;
this . BorderColor = { Value : 1 , Color : 'transparent' } ; // value=1 - цвет определен - прозрачный или другой, value=0 - цвет не определен, рисуем прозрачным
this . BorderSize = 0 ;
2016-06-29 12:47:08 +00:00
this . BorderType = Asc . c _oDashType . solid ;
2016-03-11 00:48:53 +00:00
2019-09-03 10:32:06 +00:00
DE . getCollection ( 'Common.Collections.TextArt' ) . bind ( {
reset : this . fillTextArt . bind ( this )
} ) ;
2016-03-11 00:48:53 +00:00
this . render ( ) ;
} ,
render : function ( ) {
2019-08-23 10:09:39 +00:00
var el = this . $el || $ ( this . el ) ;
2016-03-11 00:48:53 +00:00
el . html ( this . template ( {
scope : this
} ) ) ;
2019-08-23 10:09:39 +00:00
this . FillColorContainer = $ ( '#textart-panel-color-fill' ) ;
this . FillGradientContainer = $ ( '#textart-panel-gradient-fill' ) ;
this . TransparencyContainer = $ ( '#textart-panel-transparent-fill' ) ;
2016-03-11 00:48:53 +00:00
} ,
setApi : function ( api ) {
this . api = api ;
return this ;
} ,
onFillSrcSelect : function ( combo , record ) {
this . ShowHideElem ( record . value ) ;
switch ( record . value ) {
2016-04-05 11:52:34 +00:00
case Asc . c _oAscFill . FILL _TYPE _SOLID :
this . _state . FillType = Asc . c _oAscFill . FILL _TYPE _SOLID ;
2016-03-11 00:48:53 +00:00
if ( ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-04-05 11:52:34 +00:00
fill . put _type ( Asc . c _oAscFill . FILL _TYPE _SOLID ) ;
2016-04-18 12:21:15 +00:00
fill . put _fill ( new Asc . asc _CFillSolid ( ) ) ;
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _color ( Common . Utils . ThemeColor . getRgbColor ( ( this . ShapeColor . Color == 'transparent' ) ? { color : '4f81bd' , effectId : 24 } : this . ShapeColor . Color ) ) ;
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
break ;
2016-04-05 11:52:34 +00:00
case Asc . c _oAscFill . FILL _TYPE _GRAD :
this . _state . FillType = Asc . c _oAscFill . FILL _TYPE _GRAD ;
2016-03-11 00:48:53 +00:00
if ( ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-04-05 11:52:34 +00:00
fill . put _type ( Asc . c _oAscFill . FILL _TYPE _GRAD ) ;
2016-04-18 12:21:15 +00:00
fill . put _fill ( new Asc . asc _CFillGrad ( ) ) ;
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _grad _type ( this . GradFillType ) ;
2016-04-05 11:52:34 +00:00
if ( this . GradFillType == Asc . c _oAscFillGradType . GRAD _LINEAR ) {
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _linear _angle ( this . GradLinearDirectionType * 60000 ) ;
fill . get _fill ( ) . put _linear _scale ( true ) ;
}
2016-04-05 11:52:34 +00:00
if ( this . OriginalFillType !== Asc . c _oAscFill . FILL _TYPE _GRAD ) {
2019-06-06 14:20:05 +00:00
this . GradColor . values = [ 0 , 100 ] ;
this . GradColor . colors = [ this . GradColor . colors [ 0 ] , this . GradColor . colors [ this . GradColor . colors . length - 1 ] ] ;
2019-06-07 11:15:15 +00:00
this . GradColor . currentIdx = 0 ;
2016-03-11 00:48:53 +00:00
var HexColor0 = Common . Utils . ThemeColor . getRgbColor ( this . GradColor . colors [ 0 ] ) . get _color ( ) . get _hex ( ) ,
HexColor1 = Common . Utils . ThemeColor . getRgbColor ( this . GradColor . colors [ 1 ] ) . get _color ( ) . get _hex ( ) ;
if ( HexColor0 === 'ffffff' && HexColor1 === 'ffffff' ) {
HexColor0 = { color : '4f81bd' , effectId : 24 } ; // color accent1
} else {
HexColor0 = this . GradColor . colors [ 0 ] ;
}
fill . get _fill ( ) . put _positions ( [ this . GradColor . values [ 0 ] * 1000 , this . GradColor . values [ 1 ] * 1000 ] ) ;
fill . get _fill ( ) . put _colors ( [ Common . Utils . ThemeColor . getRgbColor ( HexColor0 ) , Common . Utils . ThemeColor . getRgbColor ( this . GradColor . colors [ 1 ] ) ] ) ;
}
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
break ;
2016-04-05 11:52:34 +00:00
case Asc . c _oAscFill . FILL _TYPE _NOFILL :
this . _state . FillType = Asc . c _oAscFill . FILL _TYPE _NOFILL ;
2016-03-11 00:48:53 +00:00
if ( ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-04-05 11:52:34 +00:00
fill . put _type ( Asc . c _oAscFill . FILL _TYPE _NOFILL ) ;
2016-03-11 00:48:53 +00:00
fill . put _fill ( null ) ;
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
break ;
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
2020-04-29 14:37:59 +00:00
onColorsBackSelect : function ( btn , color ) {
2016-03-11 00:48:53 +00:00
this . ShapeColor = { Value : 1 , Color : color } ;
if ( this . api && ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-03-11 00:48:53 +00:00
if ( this . ShapeColor . Color == 'transparent' ) {
2016-04-05 11:52:34 +00:00
fill . put _type ( Asc . c _oAscFill . FILL _TYPE _NOFILL ) ;
2016-03-11 00:48:53 +00:00
fill . put _fill ( null ) ;
} else {
2016-04-05 11:52:34 +00:00
fill . put _type ( Asc . c _oAscFill . FILL _TYPE _SOLID ) ;
2016-04-18 12:21:15 +00:00
fill . put _fill ( new Asc . asc _CFillSolid ( ) ) ;
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _color ( Common . Utils . ThemeColor . getRgbColor ( this . ShapeColor . Color ) ) ;
}
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
onNumTransparencyChange : function ( field , newValue , oldValue , eOpts ) {
this . sldrTransparency . setValue ( field . getNumberValue ( ) , true ) ;
if ( this . api ) {
var num = field . getNumberValue ( ) ;
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-03-11 00:48:53 +00:00
fill . put _transparent ( num * 2.55 ) ;
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
} ,
onTransparencyChange : function ( field , newValue , oldValue ) {
this . _sliderChanged = newValue ;
this . numTransparency . setValue ( newValue , true ) ;
if ( this . _sendUndoPoint ) {
this . api . setStartPointHistory ( ) ;
this . _sendUndoPoint = false ;
this . updateslider = setInterval ( _ . bind ( this . _transparencyApplyFunc , this ) , 100 ) ;
}
} ,
onTransparencyChangeComplete : function ( field , newValue , oldValue ) {
clearInterval ( this . updateslider ) ;
this . _sliderChanged = newValue ;
2018-11-08 07:58:53 +00:00
if ( ! this . _sendUndoPoint ) { // start point was added
this . api . setEndPointHistory ( ) ;
this . _transparencyApplyFunc ( ) ;
}
2016-03-11 00:48:53 +00:00
this . _sendUndoPoint = true ;
} ,
_transparencyApplyFunc : function ( ) {
if ( this . _sliderChanged !== undefined ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-03-11 00:48:53 +00:00
fill . put _transparent ( this . _sliderChanged * 2.55 ) ;
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
this . _sliderChanged = undefined ;
}
} ,
onGradTypeSelect : function ( combo , record ) {
this . GradFillType = record . value ;
2016-04-05 11:52:34 +00:00
if ( this . GradFillType == Asc . c _oAscFillGradType . GRAD _LINEAR ) {
2016-03-11 00:48:53 +00:00
this . mnuDirectionPicker . store . reset ( this . _viewDataLinear ) ;
this . mnuDirectionPicker . cmpEl . width ( 175 ) ;
this . mnuDirectionPicker . restoreHeight = 174 ;
var record = this . mnuDirectionPicker . store . findWhere ( { type : this . GradLinearDirectionType } ) ;
this . mnuDirectionPicker . selectRecord ( record , true ) ;
if ( record )
this . btnDirection . setIconCls ( 'item-gradient ' + record . get ( 'iconcls' ) ) ;
else
this . btnDirection . setIconCls ( '' ) ;
2016-04-05 11:52:34 +00:00
} else if ( this . GradFillType == Asc . c _oAscFillGradType . GRAD _PATH ) {
2016-03-11 00:48:53 +00:00
this . mnuDirectionPicker . store . reset ( this . _viewDataRadial ) ;
this . mnuDirectionPicker . cmpEl . width ( 60 ) ;
this . mnuDirectionPicker . restoreHeight = 58 ;
this . mnuDirectionPicker . selectByIndex ( this . GradRadialDirectionIdx , true ) ;
if ( this . GradRadialDirectionIdx >= 0 )
this . btnDirection . setIconCls ( 'item-gradient ' + this . _viewDataRadial [ this . GradRadialDirectionIdx ] . iconcls ) ;
else
this . btnDirection . setIconCls ( '' ) ;
}
if ( this . api && ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-04-05 11:52:34 +00:00
fill . put _type ( Asc . c _oAscFill . FILL _TYPE _GRAD ) ;
2016-04-18 12:21:15 +00:00
fill . put _fill ( new Asc . asc _CFillGrad ( ) ) ;
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _grad _type ( this . GradFillType ) ;
2016-04-05 11:52:34 +00:00
if ( this . GradFillType == Asc . c _oAscFillGradType . GRAD _LINEAR ) {
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _linear _angle ( this . GradLinearDirectionType * 60000 ) ;
fill . get _fill ( ) . put _linear _scale ( true ) ;
}
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
onSelectGradient : function ( btn , picker , itemView , record ) {
if ( this . _noApply ) return ;
var rawData = { } ,
isPickerSelect = _ . isFunction ( record . toJSON ) ;
if ( isPickerSelect ) {
if ( record . get ( 'selected' ) ) {
rawData = record . toJSON ( ) ;
} else {
// record deselected
return ;
}
} else {
rawData = record ;
}
this . btnDirection . setIconCls ( 'item-gradient ' + rawData . iconcls ) ;
2016-04-05 11:52:34 +00:00
( this . GradFillType == Asc . c _oAscFillGradType . GRAD _LINEAR ) ? this . GradLinearDirectionType = rawData . type : this . GradRadialDirectionIdx = 0 ;
2016-03-11 00:48:53 +00:00
if ( this . api ) {
2016-04-05 11:52:34 +00:00
if ( this . GradFillType == Asc . c _oAscFillGradType . GRAD _LINEAR ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-04-05 11:52:34 +00:00
fill . put _type ( Asc . c _oAscFill . FILL _TYPE _GRAD ) ;
2016-04-18 12:21:15 +00:00
fill . put _fill ( new Asc . asc _CFillGrad ( ) ) ;
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _grad _type ( this . GradFillType ) ;
fill . get _fill ( ) . put _linear _angle ( rawData . type * 60000 ) ;
fill . get _fill ( ) . put _linear _scale ( true ) ;
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
2020-04-29 14:37:59 +00:00
onColorsGradientSelect : function ( btn , color ) {
2016-03-11 00:48:53 +00:00
this . GradColor . colors [ this . GradColor . currentIdx ] = color ;
this . sldrGradient . setColorValue ( Common . Utils . String . format ( '#{0}' , ( typeof ( color ) == 'object' ) ? color . color : color ) ) ;
if ( this . api && ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-04-05 11:52:34 +00:00
fill . put _type ( Asc . c _oAscFill . FILL _TYPE _GRAD ) ;
2016-04-18 12:21:15 +00:00
fill . put _fill ( new Asc . asc _CFillGrad ( ) ) ;
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _grad _type ( this . GradFillType ) ;
2019-06-06 14:20:05 +00:00
var arr = [ ] ;
this . GradColor . colors . forEach ( function ( item ) {
arr . push ( Common . Utils . ThemeColor . getRgbColor ( item ) ) ;
} ) ;
fill . get _fill ( ) . put _colors ( arr ) ;
2016-03-11 00:48:53 +00:00
2016-04-05 11:52:34 +00:00
if ( this . OriginalFillType !== Asc . c _oAscFill . FILL _TYPE _GRAD ) {
if ( this . GradFillType == Asc . c _oAscFillGradType . GRAD _LINEAR ) {
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _linear _angle ( this . GradLinearDirectionType * 60000 ) ;
fill . get _fill ( ) . put _linear _scale ( true ) ;
}
2019-06-06 14:20:05 +00:00
arr = [ ] ;
this . GradColor . values . forEach ( function ( item ) {
arr . push ( item * 1000 ) ;
} ) ;
fill . get _fill ( ) . put _positions ( arr ) ;
2016-03-11 00:48:53 +00:00
}
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
onGradientChange : function ( slider , newValue , oldValue ) {
this . GradColor . values = slider . getValues ( ) ;
2020-07-10 15:21:45 +00:00
this . spnGradPosition . setValue ( this . GradColor . values [ this . GradColor . currentIdx ] , true ) ;
2016-03-11 00:48:53 +00:00
this . _sliderChanged = true ;
if ( this . api && ! this . _noApply ) {
if ( this . _sendUndoPoint ) {
this . api . setStartPointHistory ( ) ;
this . _sendUndoPoint = false ;
this . updateslider = setInterval ( _ . bind ( this . _gradientApplyFunc , this ) , 100 ) ;
}
}
} ,
onGradientChangeComplete : function ( slider , newValue , oldValue ) {
clearInterval ( this . updateslider ) ;
this . _sliderChanged = true ;
2018-11-08 07:58:53 +00:00
if ( ! this . _sendUndoPoint ) { // start point was added
this . api . setEndPointHistory ( ) ;
this . _gradientApplyFunc ( ) ;
}
2016-03-11 00:48:53 +00:00
this . _sendUndoPoint = true ;
} ,
_gradientApplyFunc : function ( ) {
if ( this . _sliderChanged ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
2016-04-05 11:52:34 +00:00
fill . put _type ( Asc . c _oAscFill . FILL _TYPE _GRAD ) ;
2016-04-18 12:21:15 +00:00
fill . put _fill ( new Asc . asc _CFillGrad ( ) ) ;
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _grad _type ( this . GradFillType ) ;
2019-06-06 14:20:05 +00:00
var arr = [ ] ;
this . GradColor . values . forEach ( function ( item ) {
arr . push ( item * 1000 ) ;
} ) ;
fill . get _fill ( ) . put _positions ( arr ) ;
2016-03-11 00:48:53 +00:00
2016-04-05 11:52:34 +00:00
if ( this . OriginalFillType !== Asc . c _oAscFill . FILL _TYPE _GRAD ) {
if ( this . GradFillType == Asc . c _oAscFillGradType . GRAD _LINEAR ) {
2016-03-11 00:48:53 +00:00
fill . get _fill ( ) . put _linear _angle ( this . GradLinearDirectionType * 60000 ) ;
fill . get _fill ( ) . put _linear _scale ( true ) ;
}
2019-06-06 14:20:05 +00:00
arr = [ ] ;
this . GradColor . colors . forEach ( function ( item ) {
arr . push ( Common . Utils . ThemeColor . getRgbColor ( item ) ) ;
} ) ;
fill . get _fill ( ) . put _colors ( arr ) ;
2016-03-11 00:48:53 +00:00
}
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
this . _sliderChanged = false ;
}
} ,
applyBorderSize : function ( value ) {
2020-03-31 13:49:33 +00:00
value = Common . Utils . String . parseFloat ( value ) ;
2016-03-11 00:48:53 +00:00
value = isNaN ( value ) ? 0 : Math . max ( 0 , Math . min ( 1584 , value ) ) ;
this . BorderSize = value ;
if ( this . api && ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var stroke = new Asc . asc _CStroke ( ) ;
2017-08-02 12:40:49 +00:00
if ( this . BorderSize < 0.00001 ) {
2016-04-05 11:52:34 +00:00
stroke . put _type ( Asc . c _oAscStrokeType . STROKE _NONE ) ;
2016-03-11 00:48:53 +00:00
this . _state . StrokeType = this . _state . StrokeWidth = - 1 ;
} else {
2016-04-05 11:52:34 +00:00
stroke . put _type ( Asc . c _oAscStrokeType . STROKE _COLOR ) ;
2016-03-11 00:48:53 +00:00
if ( this . BorderColor . Color == 'transparent' || this . BorderColor . Color . color == 'transparent' )
stroke . put _color ( Common . Utils . ThemeColor . getRgbColor ( { color : '000000' , effectId : 29 } ) ) ;
2016-04-05 11:52:34 +00:00
else if ( this . _state . StrokeType == Asc . c _oAscStrokeType . STROKE _NONE || this . _state . StrokeType === null )
2016-03-11 00:48:53 +00:00
stroke . put _color ( Common . Utils . ThemeColor . getRgbColor ( Common . Utils . ThemeColor . colorValue2EffectId ( this . BorderColor . Color ) ) ) ;
2016-06-29 12:47:08 +00:00
stroke . asc _putPrstDash ( this . BorderType ) ;
2016-03-11 00:48:53 +00:00
stroke . put _width ( this . _pt2mm ( this . BorderSize ) ) ;
}
props . asc _putLine ( stroke ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
onComboBlur : function ( ) {
this . fireEvent ( 'editcomplete' , this ) ;
} ,
onBorderSizeChanged : function ( before , combo , record , e ) {
var me = this ;
if ( before ) {
2016-04-06 13:38:54 +00:00
var value = parseFloat ( record . value ) ,
expr = new RegExp ( '^\\s*(\\d*(\\.|,)?\\d+)\\s*(' + me . txtPt + ')?\\s*$' ) ;
if ( ! ( expr . exec ( record . value ) ) || value < 0 || value > 1584 ) {
2016-03-11 00:48:53 +00:00
this . _state . StrokeType = this . _state . StrokeWidth = - 1 ;
Common . UI . error ( {
msg : this . textBorderSizeErr ,
callback : function ( ) {
_ . defer ( function ( btn ) {
me . fireEvent ( 'editcomplete' , me ) ;
} )
}
} ) ;
}
} else
this . applyBorderSize ( record . value ) ;
} ,
onBorderSizeSelect : function ( combo , record ) {
this . applyBorderSize ( record . value ) ;
} ,
2016-06-29 12:47:08 +00:00
onBorderTypeSelect : function ( combo , record ) {
this . BorderType = record . value ;
if ( this . api && ! this . _noApply ) {
var props = new Asc . asc _TextArtProperties ( ) ;
var stroke = new Asc . asc _CStroke ( ) ;
2017-08-02 12:40:49 +00:00
if ( this . BorderSize < 0.00001 ) {
2016-06-29 12:47:08 +00:00
stroke . put _type ( Asc . c _oAscStrokeType . STROKE _NONE ) ;
} else {
stroke . put _type ( Asc . c _oAscStrokeType . STROKE _COLOR ) ;
stroke . put _color ( Common . Utils . ThemeColor . getRgbColor ( this . BorderColor . Color ) ) ;
stroke . put _width ( this . _pt2mm ( this . BorderSize ) ) ;
stroke . asc _putPrstDash ( this . BorderType ) ;
}
props . asc _putLine ( stroke ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
2020-04-29 14:37:59 +00:00
onColorsBorderSelect : function ( btn , color ) {
2016-03-11 00:48:53 +00:00
this . BorderColor = { Value : 1 , Color : color } ;
if ( this . api && this . BorderSize > 0 && ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
var stroke = new Asc . asc _CStroke ( ) ;
2017-08-02 12:40:49 +00:00
if ( this . BorderSize < 0.00001 ) {
2016-04-05 11:52:34 +00:00
stroke . put _type ( Asc . c _oAscStrokeType . STROKE _NONE ) ;
2016-03-11 00:48:53 +00:00
} else {
2016-04-05 11:52:34 +00:00
stroke . put _type ( Asc . c _oAscStrokeType . STROKE _COLOR ) ;
2016-03-11 00:48:53 +00:00
stroke . put _color ( Common . Utils . ThemeColor . getRgbColor ( this . BorderColor . Color ) ) ;
stroke . put _width ( this . _pt2mm ( this . BorderSize ) ) ;
2016-06-29 12:47:08 +00:00
stroke . asc _putPrstDash ( this . BorderType ) ;
2016-03-11 00:48:53 +00:00
}
props . asc _putLine ( stroke ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
ChangeSettings : function ( props ) {
if ( this . imgprops == null ) {
2016-04-18 12:21:15 +00:00
this . imgprops = new Asc . asc _CImgProperty ( ) ;
this . imgprops . put _ShapeProperties ( new Asc . asc _CShapeProperty ( ) ) ;
2016-03-11 00:48:53 +00:00
this . shapeprops = this . imgprops . get _ShapeProperties ( ) ;
} else
this . imgprops . put _ImageUrl ( null ) ;
if ( this . _initSettings )
this . createDelayedElements ( ) ;
if ( props && props . get _ShapeProperties ( ) && props . get _ShapeProperties ( ) . get _TextArtProperties ( ) )
{
var shapeprops = props . get _ShapeProperties ( ) . get _TextArtProperties ( ) ;
this . _noApply = true ;
this . disableControls ( this . _locked ) ;
// background colors
var rec = null ,
fill = shapeprops . asc _getFill ( ) ,
fill _type = ( fill ) ? fill . get _type ( ) : null ,
color = null ;
if ( fill ) {
var transparency = fill . get _transparent ( ) ;
if ( Math . abs ( this . _state . Transparency - transparency ) > 0.001 || Math . abs ( this . numTransparency . getNumberValue ( ) - transparency ) > 0.001 ||
( this . _state . Transparency === null || transparency === null ) && ( this . _state . Transparency !== transparency || this . numTransparency . getNumberValue ( ) !== transparency ) ) {
if ( transparency !== undefined ) {
this . sldrTransparency . setValue ( ( transparency === null ) ? 100 : transparency / 255 * 100 , true ) ;
this . numTransparency . setValue ( this . sldrTransparency . getValue ( ) , true ) ;
}
this . _state . Transparency = transparency ;
}
}
if ( fill === null || fill === undefined || fill _type === null ) { // заливка не совпадает у неск. фигур
this . OriginalFillType = null ;
2016-04-05 11:52:34 +00:00
} else if ( fill _type == Asc . c _oAscFill . FILL _TYPE _NOFILL ) { // заливки нет
this . OriginalFillType = Asc . c _oAscFill . FILL _TYPE _NOFILL ;
} else if ( fill _type == Asc . c _oAscFill . FILL _TYPE _SOLID ) {
2016-03-11 00:48:53 +00:00
fill = fill . get _fill ( ) ;
color = fill . get _color ( ) ;
if ( color ) {
2016-04-05 11:52:34 +00:00
if ( color . get _type ( ) == Asc . c _oAscColor . COLOR _TYPE _SCHEME ) {
2016-03-11 00:48:53 +00:00
this . ShapeColor = { Value : 1 , Color : { color : Common . Utils . ThemeColor . getHexColor ( color . get _r ( ) , color . get _g ( ) , color . get _b ( ) ) , effectValue : color . get _value ( ) } } ;
} else {
this . ShapeColor = { Value : 1 , Color : Common . Utils . ThemeColor . getHexColor ( color . get _r ( ) , color . get _g ( ) , color . get _b ( ) ) } ;
}
} else
this . ShapeColor = { Value : 0 , Color : 'transparent' } ;
2016-04-05 11:52:34 +00:00
this . OriginalFillType = Asc . c _oAscFill . FILL _TYPE _SOLID ;
2016-03-11 00:48:53 +00:00
this . GradColor . colors [ 0 ] = ( this . ShapeColor . Color !== 'transparent' ) ? Common . Utils . ThemeColor . colorValue2EffectId ( this . ShapeColor . Color ) : '000000' ;
2019-06-06 14:20:05 +00:00
this . GradColor . colors [ this . GradColor . colors . length - 1 ] = 'ffffff' ;
2016-04-05 11:52:34 +00:00
} else if ( fill _type == Asc . c _oAscFill . FILL _TYPE _GRAD ) {
2016-03-11 00:48:53 +00:00
fill = fill . get _fill ( ) ;
var gradfilltype = fill . get _grad _type ( ) ; // null - не совпадают у нескольких фигур
if ( this . _state . GradFillType !== gradfilltype || this . GradFillType !== gradfilltype ) {
this . GradFillType = gradfilltype ;
rec = undefined ;
2016-04-05 11:52:34 +00:00
if ( this . GradFillType == Asc . c _oAscFillGradType . GRAD _LINEAR || this . GradFillType == Asc . c _oAscFillGradType . GRAD _PATH ) {
2016-03-11 00:48:53 +00:00
this . cmbGradType . setValue ( this . GradFillType ) ;
rec = this . cmbGradType . store . findWhere ( { value : this . GradFillType } ) ;
this . onGradTypeSelect ( this . cmbGradType , rec . attributes ) ;
} else {
this . cmbGradType . setValue ( '' ) ;
this . btnDirection . setIconCls ( '' ) ;
}
this . _state . GradFillType = this . GradFillType ;
}
2016-04-05 11:52:34 +00:00
if ( this . GradFillType == Asc . c _oAscFillGradType . GRAD _LINEAR ) {
2016-03-11 00:48:53 +00:00
var value = Math . floor ( fill . get _linear _angle ( ) / 60000 ) ;
if ( Math . abs ( this . GradLinearDirectionType - value ) > 0.001 ) {
this . GradLinearDirectionType = value ;
var record = this . mnuDirectionPicker . store . findWhere ( { type : value } ) ;
this . mnuDirectionPicker . selectRecord ( record , true ) ;
if ( record )
this . btnDirection . setIconCls ( 'item-gradient ' + record . get ( 'iconcls' ) ) ;
else
this . btnDirection . setIconCls ( '' ) ;
}
}
2019-06-06 14:20:05 +00:00
var me = this ;
var colors = fill . get _colors ( ) ,
positions = fill . get _positions ( ) ,
2019-12-05 08:16:19 +00:00
length = colors ? colors . length : this . GradColor . colors . length ;
2019-06-06 14:20:05 +00:00
this . sldrGradient . setThumbs ( length ) ;
if ( this . GradColor . colors . length > length ) {
this . GradColor . colors . splice ( length , this . GradColor . colors . length - length ) ;
this . GradColor . values . splice ( length , this . GradColor . colors . length - length ) ;
this . GradColor . currentIdx = 0 ;
}
colors && colors . forEach ( function ( color , index ) {
2016-03-11 00:48:53 +00:00
if ( color ) {
2016-04-05 11:52:34 +00:00
if ( color . get _type ( ) == Asc . c _oAscColor . COLOR _TYPE _SCHEME ) {
2019-06-06 14:20:05 +00:00
me . GradColor . colors [ index ] = { color : Common . Utils . ThemeColor . getHexColor ( color . get _r ( ) , color . get _g ( ) , color . get _b ( ) ) , effectValue : color . get _value ( ) } ;
Common . Utils . ThemeColor . colorValue2EffectId ( me . GradColor . colors [ index ] ) ;
2016-03-11 00:48:53 +00:00
} else {
2019-06-06 14:20:05 +00:00
me . GradColor . colors [ index ] = Common . Utils . ThemeColor . getHexColor ( color . get _r ( ) , color . get _g ( ) , color . get _b ( ) ) ;
2016-03-11 00:48:53 +00:00
}
} else
2019-06-06 14:20:05 +00:00
me . GradColor . colors [ index ] = '000000' ;
2016-03-11 00:48:53 +00:00
2019-06-06 14:20:05 +00:00
var position = positions [ index ] ;
2016-03-11 00:48:53 +00:00
if ( position !== null ) {
position = position / 1000 ;
2019-06-06 14:20:05 +00:00
me . GradColor . values [ index ] = position ;
2016-03-11 00:48:53 +00:00
}
2019-06-06 14:20:05 +00:00
} ) ;
for ( var index = 0 ; index < length ; index ++ ) {
me . sldrGradient . setColorValue ( Common . Utils . String . format ( '#{0}' , ( typeof ( me . GradColor . colors [ index ] ) == 'object' ) ? me . GradColor . colors [ index ] . color : me . GradColor . colors [ index ] ) , index ) ;
me . sldrGradient . setValue ( index , me . GradColor . values [ index ] ) ;
2016-03-11 00:48:53 +00:00
}
2019-11-15 11:05:50 +00:00
if ( _ . isUndefined ( me . GradColor . currentIdx ) || me . GradColor . currentIdx >= this . GradColor . colors . length ) {
me . GradColor . currentIdx = 0 ;
}
me . sldrGradient . setActiveThumb ( me . GradColor . currentIdx ) ;
2020-07-09 12:44:30 +00:00
this . spnGradPosition . setValue ( this . GradColor . values [ this . GradColor . currentIdx ] ) ;
2016-04-05 11:52:34 +00:00
this . OriginalFillType = Asc . c _oAscFill . FILL _TYPE _GRAD ;
2016-03-11 00:48:53 +00:00
this . ShapeColor = { Value : 1 , Color : this . GradColor . colors [ 0 ] } ;
}
if ( this . _state . FillType !== this . OriginalFillType ) {
this . cmbFillSrc . setValue ( ( this . OriginalFillType === null ) ? '' : this . OriginalFillType ) ;
this . _state . FillType = this . OriginalFillType ;
this . ShowHideElem ( this . OriginalFillType ) ;
}
var type1 = typeof ( this . ShapeColor . Color ) ,
type2 = typeof ( this . _state . ShapeColor ) ;
if ( ( type1 !== type2 ) || ( type1 == 'object' &&
( this . ShapeColor . Color . effectValue !== this . _state . ShapeColor . effectValue || this . _state . ShapeColor . color . indexOf ( this . ShapeColor . Color . color ) < 0 ) ) ||
( type1 != 'object' && this . _state . ShapeColor . indexOf ( this . ShapeColor . Color ) < 0 ) ) {
this . btnBackColor . setColor ( this . ShapeColor . Color ) ;
if ( typeof ( this . ShapeColor . Color ) == 'object' ) {
var isselected = false ;
for ( var i = 0 ; i < 10 ; i ++ ) {
if ( Common . Utils . ThemeColor . ThemeValues [ i ] == this . ShapeColor . Color . effectValue ) {
this . colorsBack . select ( this . ShapeColor . Color , true ) ;
isselected = true ;
break ;
}
}
if ( ! isselected ) this . colorsBack . clearSelection ( ) ;
} else
this . colorsBack . select ( this . ShapeColor . Color , true ) ;
this . _state . ShapeColor = this . ShapeColor . Color ;
}
// border colors
var stroke = shapeprops . asc _getLine ( ) ,
2016-06-29 12:47:08 +00:00
strokeType = ( stroke ) ? stroke . get _type ( ) : null ,
2017-10-31 12:36:28 +00:00
borderType ,
update = ( this . _state . StrokeColor == 'transparent' && this . BorderColor . Color !== 'transparent' ) ; // border color was changed for shape without line and then shape was reselected (or apply other settings)
2016-03-11 00:48:53 +00:00
if ( stroke ) {
2016-04-05 11:52:34 +00:00
if ( strokeType == Asc . c _oAscStrokeType . STROKE _COLOR ) {
2016-03-11 00:48:53 +00:00
color = stroke . get _color ( ) ;
if ( color ) {
2016-04-05 11:52:34 +00:00
if ( color . get _type ( ) == Asc . c _oAscColor . COLOR _TYPE _SCHEME ) {
2016-03-11 00:48:53 +00:00
this . BorderColor = { Value : 1 , Color : { color : Common . Utils . ThemeColor . getHexColor ( color . get _r ( ) , color . get _g ( ) , color . get _b ( ) ) , effectValue : color . get _value ( ) } } ;
}
else
this . BorderColor = { Value : 1 , Color : Common . Utils . ThemeColor . getHexColor ( color . get _r ( ) , color . get _g ( ) , color . get _b ( ) ) } ;
}
else
this . BorderColor = { Value : 1 , Color : 'transparent' } ;
} else {
this . BorderColor = { Value : 1 , Color : 'transparent' } ;
}
2016-06-29 12:47:08 +00:00
borderType = stroke . asc _getPrstDash ( ) ;
2016-03-11 00:48:53 +00:00
} else { // no stroke
this . BorderColor = { Value : 0 , Color : 'transparent' } ;
}
type1 = typeof ( this . BorderColor . Color ) ;
type2 = typeof ( this . _state . StrokeColor ) ;
2017-10-31 12:36:28 +00:00
if ( update || ( type1 !== type2 ) || ( type1 == 'object' &&
2016-03-11 00:48:53 +00:00
( this . BorderColor . Color . effectValue !== this . _state . StrokeColor . effectValue || this . _state . StrokeColor . color . indexOf ( this . BorderColor . Color . color ) < 0 ) ) ||
( type1 != 'object' && ( this . _state . StrokeColor . indexOf ( this . BorderColor . Color ) < 0 || typeof ( this . btnBorderColor . color ) == 'object' ) ) ) {
this . btnBorderColor . setColor ( this . BorderColor . Color ) ;
if ( typeof ( this . BorderColor . Color ) == 'object' ) {
var isselected = false ;
for ( var i = 0 ; i < 10 ; i ++ ) {
if ( Common . Utils . ThemeColor . ThemeValues [ i ] == this . BorderColor . Color . effectValue ) {
this . colorsBorder . select ( this . BorderColor . Color , true ) ;
isselected = true ;
break ;
}
}
if ( ! isselected ) this . colorsBorder . clearSelection ( ) ;
} else
this . colorsBorder . select ( this . BorderColor . Color , true ) ;
this . _state . StrokeColor = this . BorderColor . Color ;
}
2016-04-05 11:52:34 +00:00
if ( this . _state . StrokeType !== strokeType || strokeType == Asc . c _oAscStrokeType . STROKE _COLOR ) {
if ( strokeType == Asc . c _oAscStrokeType . STROKE _COLOR ) {
2016-03-11 00:48:53 +00:00
var w = stroke . get _width ( ) ;
2017-08-02 12:40:49 +00:00
var check _value = ( Math . abs ( this . _state . StrokeWidth - w ) < 0.00001 ) && ! ( ( new RegExp ( this . txtPt + '\\s*$' ) ) . test ( this . cmbBorderSize . getRawValue ( ) ) ) ;
if ( Math . abs ( this . _state . StrokeWidth - w ) > 0.00001 || check _value ||
2016-03-11 00:48:53 +00:00
( this . _state . StrokeWidth === null || w === null ) && ( this . _state . StrokeWidth !== w ) ) {
this . _state . StrokeWidth = w ;
if ( w !== null ) w = this . _mm2pt ( w ) ;
var _selectedItem = ( w === null ) ? w : _ . find ( this . cmbBorderSize . store . models , function ( item ) {
2017-08-02 12:40:49 +00:00
if ( w < item . attributes . value + 0.00001 && w > item . attributes . value - 0.00001 ) {
2016-03-11 00:48:53 +00:00
return true ;
}
} ) ;
if ( _selectedItem )
this . cmbBorderSize . selectRecord ( _selectedItem ) ;
else {
2016-04-06 13:38:54 +00:00
this . cmbBorderSize . setValue ( ( w !== null ) ? parseFloat ( w . toFixed ( 2 ) ) + ' ' + this . txtPt : '' ) ;
2016-03-11 00:48:53 +00:00
}
this . BorderSize = w ;
}
2016-04-05 11:52:34 +00:00
} else if ( strokeType == Asc . c _oAscStrokeType . STROKE _NONE ) {
2016-03-11 00:48:53 +00:00
this . _state . StrokeWidth = 0 ;
this . BorderSize = this . cmbBorderSize . store . at ( 0 ) . get ( 'value' ) ;
this . cmbBorderSize . setValue ( this . BorderSize ) ;
} else {
this . _state . StrokeWidth = null ;
this . BorderSize = - 1 ;
this . cmbBorderSize . setValue ( null ) ;
}
this . _state . StrokeType = strokeType ;
}
2016-06-29 12:47:08 +00:00
if ( this . _state . StrokeBorderType !== borderType ) {
this . BorderType = this . _state . StrokeBorderType = borderType ;
this . cmbBorderType . setValue ( borderType ) ;
}
2016-03-11 00:48:53 +00:00
color = this . GradColor . colors [ this . GradColor . currentIdx ] ;
type1 = typeof ( color ) ;
type2 = typeof ( this . _state . GradColor ) ;
if ( ( type1 !== type2 ) || ( type1 == 'object' &&
( color . effectValue !== this . _state . GradColor . effectValue || this . _state . GradColor . color . indexOf ( color . color ) < 0 ) ) ||
( type1 != 'object' && this . _state . GradColor . indexOf ( color ) < 0 ) ) {
this . btnGradColor . setColor ( color ) ;
if ( typeof ( color ) == 'object' ) {
var isselected = false ;
for ( var i = 0 ; i < 10 ; i ++ ) {
if ( Common . Utils . ThemeColor . ThemeValues [ i ] == color . effectValue ) {
this . colorsGrad . select ( color , true ) ;
isselected = true ;
break ;
}
}
if ( ! isselected ) this . colorsGrad . clearSelection ( ) ;
} else
this . colorsGrad . select ( color , true ) ;
this . _state . GradColor = color ;
}
var form = shapeprops . asc _getForm ( ) ;
if ( this . _state . FormId !== form ) {
this . cmbTransform . suspendEvents ( ) ;
var rec = this . cmbTransform . menuPicker . store . findWhere ( {
type : form
} ) ;
this . cmbTransform . menuPicker . selectRecord ( rec ) ;
this . cmbTransform . resumeEvents ( ) ;
this . _state . FormId = form ;
}
this . _noApply = false ;
}
} ,
2016-08-16 13:55:14 +00:00
createDelayedControls : function ( ) {
var me = this ;
this . _arrFillSrc = [
{ displayValue : this . textColor , value : Asc . c _oAscFill . FILL _TYPE _SOLID } ,
{ displayValue : this . textGradientFill , value : Asc . c _oAscFill . FILL _TYPE _GRAD } ,
{ displayValue : this . textNoFill , value : Asc . c _oAscFill . FILL _TYPE _NOFILL }
] ;
this . cmbFillSrc = new Common . UI . ComboBox ( {
el : $ ( '#textart-combo-fill-src' ) ,
cls : 'input-group-nr' ,
style : 'width: 100%;' ,
2018-08-15 12:12:05 +00:00
menuStyle : 'min-width: 100%;' ,
2016-08-16 13:55:14 +00:00
editable : false ,
data : this . _arrFillSrc
} ) ;
this . cmbFillSrc . setValue ( this . _arrFillSrc [ 0 ] . value ) ;
this . cmbFillSrc . on ( 'selected' , _ . bind ( this . onFillSrcSelect , this ) ) ;
this . lockedControls . push ( this . cmbFillSrc ) ;
this . numTransparency = new Common . UI . MetricSpinner ( {
el : $ ( '#textart-spin-transparency' ) ,
step : 1 ,
width : 62 ,
value : '100 %' ,
defaultUnit : "%" ,
maxValue : 100 ,
minValue : 0
} ) ;
this . numTransparency . on ( 'change' , _ . bind ( this . onNumTransparencyChange , this ) ) ;
2019-12-06 08:35:17 +00:00
this . numTransparency . on ( 'inputleave' , function ( ) { me . fireEvent ( 'editcomplete' , me ) ; } ) ;
2016-08-16 13:55:14 +00:00
this . lockedControls . push ( this . numTransparency ) ;
this . sldrTransparency = new Common . UI . SingleSlider ( {
el : $ ( '#textart-slider-transparency' ) ,
width : 75 ,
minValue : 0 ,
maxValue : 100 ,
value : 100
} ) ;
this . sldrTransparency . on ( 'change' , _ . bind ( this . onTransparencyChange , this ) ) ;
this . sldrTransparency . on ( 'changecomplete' , _ . bind ( this . onTransparencyChangeComplete , this ) ) ;
this . lockedControls . push ( this . sldrTransparency ) ;
this . lblTransparencyStart = $ ( this . el ) . find ( '#textart-lbl-transparency-start' ) ;
this . lblTransparencyEnd = $ ( this . el ) . find ( '#textart-lbl-transparency-end' ) ;
this . _arrGradType = [
{ displayValue : this . textLinear , value : Asc . c _oAscFillGradType . GRAD _LINEAR } ,
{ displayValue : this . textRadial , value : Asc . c _oAscFillGradType . GRAD _PATH }
] ;
this . cmbGradType = new Common . UI . ComboBox ( {
el : $ ( '#textart-combo-grad-type' ) ,
cls : 'input-group-nr' ,
menuStyle : 'min-width: 90px;' ,
editable : false ,
data : this . _arrGradType
} ) ;
this . cmbGradType . setValue ( this . _arrGradType [ 0 ] . value ) ;
this . cmbGradType . on ( 'selected' , _ . bind ( this . onGradTypeSelect , this ) ) ;
this . lockedControls . push ( this . cmbGradType ) ;
this . _viewDataLinear = [
{ offsetx : 0 , offsety : 0 , type : 45 , subtype : - 1 , iconcls : 'gradient-left-top' } ,
{ offsetx : 50 , offsety : 0 , type : 90 , subtype : 4 , iconcls : 'gradient-top' } ,
{ offsetx : 100 , offsety : 0 , type : 135 , subtype : 5 , iconcls : 'gradient-right-top' } ,
{ offsetx : 0 , offsety : 50 , type : 0 , subtype : 6 , iconcls : 'gradient-left' , cls : 'item-gradient-separator' , selected : true } ,
{ offsetx : 100 , offsety : 50 , type : 180 , subtype : 1 , iconcls : 'gradient-right' } ,
{ offsetx : 0 , offsety : 100 , type : 315 , subtype : 2 , iconcls : 'gradient-left-bottom' } ,
{ offsetx : 50 , offsety : 100 , type : 270 , subtype : 3 , iconcls : 'gradient-bottom' } ,
{ offsetx : 100 , offsety : 100 , type : 225 , subtype : 7 , iconcls : 'gradient-right-bottom' }
] ;
this . _viewDataRadial = [
{ offsetx : 100 , offsety : 150 , type : 2 , subtype : 5 , iconcls : 'gradient-radial-center' }
] ;
this . btnDirection = new Common . UI . Button ( {
cls : 'btn-large-dataview' ,
iconCls : 'item-gradient gradient-left' ,
menu : new Common . UI . Menu ( {
style : 'min-width: 60px;' ,
menuAlign : 'tr-br' ,
items : [
{ template : _ . template ( '<div id="id-textart-menu-direction" style="width: 175px; margin: 0 5px;"></div>' ) }
]
} )
} ) ;
this . btnDirection . on ( 'render:after' , function ( btn ) {
me . mnuDirectionPicker = new Common . UI . DataView ( {
el : $ ( '#id-textart-menu-direction' ) ,
parentMenu : btn . menu ,
restoreHeight : 174 ,
store : new Common . UI . DataViewStore ( me . _viewDataLinear ) ,
itemTemplate : _ . template ( '<div id="<%= id %>" class="item-gradient" style="background-position: -<%= offsetx %>px -<%= offsety %>px;"></div>' )
} ) ;
} ) ;
this . btnDirection . render ( $ ( '#textart-button-direction' ) ) ;
this . mnuDirectionPicker . on ( 'item:click' , _ . bind ( this . onSelectGradient , this , this . btnDirection ) ) ;
this . lockedControls . push ( this . btnDirection ) ;
this . sldrGradient = new Common . UI . MultiSliderGradient ( {
el : $ ( '#textart-slider-gradient' ) ,
2020-07-09 12:44:30 +00:00
width : 192 ,
2016-08-16 13:55:14 +00:00
minValue : 0 ,
maxValue : 100 ,
values : [ 0 , 100 ]
} ) ;
this . sldrGradient . on ( 'change' , _ . bind ( this . onGradientChange , this ) ) ;
this . sldrGradient . on ( 'changecomplete' , _ . bind ( this . onGradientChangeComplete , this ) ) ;
this . sldrGradient . on ( 'thumbclick' , function ( cmp , index ) {
me . GradColor . currentIdx = index ;
var color = me . GradColor . colors [ me . GradColor . currentIdx ] ;
me . btnGradColor . setColor ( color ) ;
me . colorsGrad . select ( color , false ) ;
2020-07-09 12:44:30 +00:00
var pos = me . GradColor . values [ me . GradColor . currentIdx ] ;
me . spnGradPosition . setValue ( pos , true ) ;
2016-08-16 13:55:14 +00:00
} ) ;
this . sldrGradient . on ( 'thumbdblclick' , function ( cmp ) {
me . btnGradColor . cmpEl . find ( 'button' ) . dropdown ( 'toggle' ) ;
} ) ;
2017-04-12 09:57:15 +00:00
this . sldrGradient . on ( 'sortthumbs' , function ( cmp , recalc _indexes ) {
var colors = [ ] ,
currentIdx ;
_ . each ( recalc _indexes , function ( recalc _index , index ) {
colors . push ( me . GradColor . colors [ recalc _index ] ) ;
if ( me . GradColor . currentIdx == recalc _index )
currentIdx = index ;
} ) ;
me . OriginalFillType = null ;
me . GradColor . colors = colors ;
me . GradColor . currentIdx = currentIdx ;
} ) ;
2020-07-13 19:14:51 +00:00
this . sldrGradient . on ( 'addthumb' , function ( cmp , index , pos ) {
me . GradColor . colors [ index ] = me . GradColor . colors [ me . GradColor . currentIdx ] ;
2019-11-15 12:10:03 +00:00
me . GradColor . currentIdx = index ;
2020-07-13 19:14:51 +00:00
var color = me . sldrGradient . addNewThumb ( index , pos ) ;
me . GradColor . colors [ me . GradColor . currentIdx ] = color ;
2019-11-15 11:05:50 +00:00
} ) ;
this . sldrGradient . on ( 'removethumb' , function ( cmp , index ) {
me . sldrGradient . removeThumb ( index ) ;
me . GradColor . values . splice ( index , 1 ) ;
me . sldrGradient . changeGradientStyle ( ) ;
} ) ;
2016-08-16 13:55:14 +00:00
this . lockedControls . push ( this . sldrGradient ) ;
2020-07-09 12:44:30 +00:00
this . spnGradPosition = new Common . UI . MetricSpinner ( {
el : $ ( '#textart-gradient-position' ) ,
step : 1 ,
width : 60 ,
defaultUnit : "%" ,
value : '50 %' ,
allowDecimal : false ,
maxValue : 100 ,
minValue : 0 ,
disabled : this . _locked
} ) ;
this . lockedControls . push ( this . spnGradPosition ) ;
this . spnGradPosition . on ( 'change' , _ . bind ( this . onPositionChange , this ) ) ;
this . spnGradPosition . on ( 'inputleave' , function ( ) { Common . NotificationCenter . trigger ( 'edit:complete' , me ) ; } ) ;
this . btnAddGradientStep = new Common . UI . Button ( {
parentEl : $ ( '#textart-gradient-add-step' ) ,
cls : 'btn-toolbar' ,
iconCls : 'toolbar__icon btn-add-breakpoint' ,
disabled : this . _locked ,
hint : this . tipAddGradientPoint ,
} ) ;
this . btnAddGradientStep . on ( 'click' , _ . bind ( this . onAddGradientStep , this ) ) ;
this . lockedControls . push ( this . btnAddGradientStep ) ;
this . btnRemoveGradientStep = new Common . UI . Button ( {
parentEl : $ ( '#textart-gradient-remove-step' ) ,
cls : 'btn-toolbar' ,
iconCls : 'toolbar__icon btn-remove-breakpoint' ,
disabled : this . _locked ,
hint : this . tipRemoveGradientPoint
} ) ;
this . btnRemoveGradientStep . on ( 'click' , _ . bind ( this . onRemoveGradientStep , this ) ) ;
this . lockedControls . push ( this . btnRemoveGradientStep ) ;
2016-08-16 13:55:14 +00:00
this . cmbBorderSize = new Common . UI . ComboBorderSizeEditable ( {
el : $ ( '#textart-combo-border-size' ) ,
style : "width: 93px;" ,
txtNoBorders : this . txtNoBorders
} )
. on ( 'selected' , _ . bind ( this . onBorderSizeSelect , this ) )
. on ( 'changed:before' , _ . bind ( this . onBorderSizeChanged , this , true ) )
. on ( 'changed:after' , _ . bind ( this . onBorderSizeChanged , this , false ) )
. on ( 'combo:blur' , _ . bind ( this . onComboBlur , this , false ) ) ;
this . BorderSize = this . cmbBorderSize . store . at ( 2 ) . get ( 'value' ) ;
this . cmbBorderSize . setValue ( this . BorderSize ) ;
this . lockedControls . push ( this . cmbBorderSize ) ;
this . cmbBorderType = new Common . UI . ComboBorderType ( {
el : $ ( '#textart-combo-border-type' ) ,
style : "width: 93px;" ,
menuStyle : 'min-width: 93px;'
} ) . on ( 'selected' , _ . bind ( this . onBorderTypeSelect , this ) )
. on ( 'combo:blur' , _ . bind ( this . onComboBlur , this , false ) ) ;
this . BorderType = Asc . c _oDashType . solid ;
this . cmbBorderType . setValue ( this . BorderType ) ;
this . lockedControls . push ( this . cmbBorderType ) ;
this . cmbTransform = new Common . UI . ComboDataView ( {
itemWidth : 50 ,
itemHeight : 50 ,
menuMaxHeight : 300 ,
enableKeyEvents : true ,
cls : 'combo-textart'
} ) ;
this . cmbTransform . render ( $ ( '#textart-combo-transform' ) ) ;
this . cmbTransform . openButton . menu . cmpEl . css ( {
'min-width' : 178 ,
'max-width' : 178
} ) ;
this . cmbTransform . on ( 'click' , _ . bind ( this . onTransformSelect , this ) ) ;
this . cmbTransform . openButton . menu . on ( 'show:after' , function ( ) {
me . cmbTransform . menuPicker . scroller . update ( { alwaysVisibleY : true } ) ;
} ) ;
this . lockedControls . push ( this . cmbTransform ) ;
} ,
2016-03-11 00:48:53 +00:00
createDelayedElements : function ( ) {
2019-08-21 14:08:21 +00:00
this . _initSettings = false ;
2016-08-16 13:55:14 +00:00
this . createDelayedControls ( ) ;
2016-03-11 00:48:53 +00:00
this . UpdateThemeColors ( ) ;
2016-05-10 11:44:17 +00:00
this . fillTransform ( this . api . asc _getPropertyEditorTextArts ( ) ) ;
2019-08-21 14:08:21 +00:00
this . fillTextArt ( ) ;
2016-03-11 00:48:53 +00:00
} ,
fillTextArt : function ( ) {
2019-08-21 14:08:21 +00:00
if ( this . _initSettings ) return ;
2016-08-16 13:55:14 +00:00
var me = this ;
if ( ! this . cmbTextArt ) {
this . cmbTextArt = new Common . UI . ComboDataView ( {
itemWidth : 50 ,
itemHeight : 50 ,
menuMaxHeight : 300 ,
enableKeyEvents : true ,
showLast : false ,
cls : 'combo-textart'
} ) ;
this . cmbTextArt . render ( $ ( '#textart-combo-template' ) ) ;
this . cmbTextArt . openButton . menu . cmpEl . css ( {
'min-width' : 178 ,
'max-width' : 178
} ) ;
this . cmbTextArt . on ( 'click' , _ . bind ( this . onTextArtSelect , this ) ) ;
this . cmbTextArt . openButton . menu . on ( 'show:after' , function ( ) {
me . cmbTextArt . menuPicker . scroller . update ( { alwaysVisibleY : true } ) ;
} ) ;
this . lockedControls . push ( this . cmbTextArt ) ;
}
var models = this . application . getCollection ( 'Common.Collections.TextArt' ) . models ,
2016-03-11 00:48:53 +00:00
count = this . cmbTextArt . menuPicker . store . length ;
2019-09-03 10:32:06 +00:00
if ( models . length < 1 ) {
DE . getController ( 'Main' ) . fillTextArt ( this . api . asc _getTextArtPreviews ( ) ) ;
return ;
}
2016-03-11 00:48:53 +00:00
if ( count > 0 && count == models . length ) {
var data = this . cmbTextArt . menuPicker . store . models ;
_ . each ( models , function ( template , index ) {
data [ index ] . set ( 'imageUrl' , template . get ( 'imageUrl' ) ) ;
} ) ;
} else {
this . cmbTextArt . menuPicker . store . reset ( models ) ;
if ( this . cmbTextArt . menuPicker . store . length > 0 )
this . cmbTextArt . fillComboView ( this . cmbTextArt . menuPicker . store . at ( 0 ) ) ;
}
} ,
onTextArtSelect : function ( combo , record ) {
if ( this . api && ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
2016-03-11 00:48:53 +00:00
props . asc _putStyle ( record . get ( 'data' ) ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
fillTransform : function ( transforms ) {
if ( transforms && transforms . length > 1 && transforms [ 1 ] ) {
var me = this ,
artStore = [ ] ,
arrTransforms = transforms [ 1 ] ;
for ( var i = 0 ; i < arrTransforms . length ; i ++ ) {
var arr = arrTransforms [ i ] ;
if ( arr && arr . length > 0 )
_ . each ( arr , function ( item ) {
artStore . push ( {
imageUrl : item . Image ,
type : item . Type ,
selected : false
} ) ;
} ) ;
}
this . cmbTransform . menuPicker . store . add ( artStore ) ;
if ( this . cmbTransform . menuPicker . store . length > 0 ) {
this . cmbTransform . fillComboView ( this . cmbTransform . menuPicker . store . at ( 0 ) , true ) ;
}
}
} ,
onTransformSelect : function ( combo , record ) {
if ( this . api && ! this . _noApply ) {
2016-04-18 12:21:15 +00:00
var props = new Asc . asc _TextArtProperties ( ) ;
2016-03-11 00:48:53 +00:00
props . asc _putForm ( record . get ( 'type' ) ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
}
this . fireEvent ( 'editcomplete' , this ) ;
} ,
UpdateThemeColors : function ( ) {
2019-08-22 08:57:33 +00:00
if ( this . _initSettings ) return ;
2016-08-16 13:55:14 +00:00
if ( ! this . btnBackColor ) {
this . btnBorderColor = new Common . UI . ColorButton ( {
2020-04-30 12:11:03 +00:00
parentEl : $ ( '#textart-border-color-btn' ) ,
color : '000000'
2016-08-16 13:55:14 +00:00
} ) ;
this . lockedControls . push ( this . btnBorderColor ) ;
2020-04-29 14:37:59 +00:00
this . colorsBorder = this . btnBorderColor . getPicker ( ) ;
this . btnBorderColor . on ( 'color:select' , _ . bind ( this . onColorsBorderSelect , this ) ) ;
2016-08-16 13:55:14 +00:00
this . btnGradColor = new Common . UI . ColorButton ( {
2020-04-30 12:11:03 +00:00
parentEl : $ ( '#textart-gradient-color-btn' ) ,
color : '000000'
2016-08-16 13:55:14 +00:00
} ) ;
this . lockedControls . push ( this . btnGradColor ) ;
2020-04-29 14:37:59 +00:00
this . colorsGrad = this . btnGradColor . getPicker ( ) ;
this . btnGradColor . on ( 'color:select' , _ . bind ( this . onColorsGradientSelect , this ) ) ;
2016-08-16 13:55:14 +00:00
this . btnBackColor = new Common . UI . ColorButton ( {
2020-04-29 14:37:59 +00:00
parentEl : $ ( '#textart-back-color-btn' ) ,
2020-04-30 12:11:03 +00:00
transparent : true ,
color : 'transparent'
2016-08-16 13:55:14 +00:00
} ) ;
this . lockedControls . push ( this . btnBackColor ) ;
2020-04-29 14:37:59 +00:00
this . colorsBack = this . btnBackColor . getPicker ( ) ;
this . btnBackColor . on ( 'color:select' , _ . bind ( this . onColorsBackSelect , this ) ) ;
2016-08-16 13:55:14 +00:00
}
2016-03-11 00:48:53 +00:00
this . colorsBorder . updateColors ( Common . Utils . ThemeColor . getEffectColors ( ) , Common . Utils . ThemeColor . getStandartColors ( ) ) ;
this . colorsBack . updateColors ( Common . Utils . ThemeColor . getEffectColors ( ) , Common . Utils . ThemeColor . getStandartColors ( ) ) ;
this . colorsGrad . updateColors ( Common . Utils . ThemeColor . getEffectColors ( ) , Common . Utils . ThemeColor . getStandartColors ( ) ) ;
} ,
_pt2mm : function ( value ) {
return ( value * 25.4 / 72.0 ) ;
} ,
_mm2pt : function ( value ) {
return ( value * 72.0 / 25.4 ) ;
} ,
ShowHideElem : function ( value ) {
2016-04-05 11:52:34 +00:00
this . FillColorContainer . toggleClass ( 'settings-hidden' , value !== Asc . c _oAscFill . FILL _TYPE _SOLID ) ;
this . FillGradientContainer . toggleClass ( 'settings-hidden' , value !== Asc . c _oAscFill . FILL _TYPE _GRAD ) ;
this . TransparencyContainer . toggleClass ( 'settings-hidden' , ( value === Asc . c _oAscFill . FILL _TYPE _NOFILL || value === null ) ) ;
2016-03-11 00:48:53 +00:00
} ,
setLocked : function ( locked ) {
this . _locked = locked ;
} ,
disableControls : function ( disable ) {
2016-08-16 13:55:14 +00:00
if ( this . _initSettings ) return ;
2016-03-11 00:48:53 +00:00
if ( this . _state . DisabledControls !== disable ) {
this . _state . DisabledControls = disable ;
_ . each ( this . lockedControls , function ( item ) {
item . setDisabled ( disable ) ;
} ) ;
}
} ,
2020-07-09 12:44:30 +00:00
onPositionChange : function ( btn ) {
2020-07-10 15:21:45 +00:00
var pos = btn . getNumberValue ( ) ,
minValue = ( this . GradColor . currentIdx - 1 < 0 ) ? 0 : this . GradColor . values [ this . GradColor . currentIdx - 1 ] ,
maxValue = ( this . GradColor . currentIdx + 1 < this . GradColor . values . length ) ? this . GradColor . values [ this . GradColor . currentIdx + 1 ] : 100 ,
needSort = pos < minValue || pos > maxValue ;
2020-07-09 12:44:30 +00:00
if ( this . api ) {
this . GradColor . values [ this . GradColor . currentIdx ] = pos ;
var props = new Asc . asc _TextArtProperties ( ) ;
var fill = new Asc . asc _CShapeFill ( ) ;
fill . asc _putType ( Asc . c _oAscFill . FILL _TYPE _GRAD ) ;
fill . asc _putFill ( new Asc . asc _CFillGrad ( ) ) ;
fill . asc _getFill ( ) . asc _putGradType ( this . GradFillType ) ;
var arr = [ ] ;
this . GradColor . values . forEach ( function ( item ) {
arr . push ( item * 1000 ) ;
} ) ;
fill . asc _getFill ( ) . asc _putPositions ( arr ) ;
props . asc _putFill ( fill ) ;
this . shapeprops . put _TextArtProperties ( props ) ;
this . api . ImgApply ( this . imgprops ) ;
2020-07-10 15:21:45 +00:00
if ( needSort ) {
this . sldrGradient . sortThumbs ( ) ;
this . sldrGradient . trigger ( 'change' , this . sldrGradient ) ;
this . sldrGradient . trigger ( 'changecomplete' , this . sldrGradient ) ;
}
2020-07-09 12:44:30 +00:00
}
} ,
onAddGradientStep : function ( ) {
2020-07-09 18:49:35 +00:00
if ( this . GradColor . colors . length > 9 ) return ;
2020-07-09 12:44:30 +00:00
var curIndex = this . GradColor . currentIdx ;
var pos = ( this . GradColor . values [ curIndex ] + this . GradColor . values [ curIndex < this . GradColor . colors . length - 1 ? curIndex + 1 : curIndex - 1 ] ) / 2 ;
this . GradColor . colors [ this . GradColor . colors . length ] = this . GradColor . colors [ curIndex ] ;
this . GradColor . currentIdx = this . GradColor . colors . length - 1 ;
2020-07-13 19:14:51 +00:00
var color = this . sldrGradient . addNewThumb ( undefined , pos , curIndex ) ;
this . GradColor . colors [ this . GradColor . currentIdx ] = color ;
2020-07-09 12:44:30 +00:00
this . sldrGradient . trigger ( 'change' , this . sldrGradient ) ;
this . sldrGradient . trigger ( 'changecomplete' , this . sldrGradient ) ;
} ,
onRemoveGradientStep : function ( ) {
if ( this . GradColor . values . length < 3 ) return ;
this . GradColor . values . splice ( this . GradColor . currentIdx , 1 ) ;
this . sldrGradient . removeThumb ( this . GradColor . currentIdx ) ;
if ( _ . isUndefined ( this . GradColor . currentIdx ) || this . GradColor . currentIdx >= this . GradColor . colors . length ) {
this . GradColor . currentIdx = 0 ;
}
this . sldrGradient . setActiveThumb ( this . GradColor . currentIdx ) ;
this . sldrGradient . trigger ( 'change' , this . sldrGradient ) ;
this . sldrGradient . trigger ( 'changecomplete' , this . sldrGradient ) ;
} ,
2016-03-11 00:48:53 +00:00
txtNoBorders : 'No Line' ,
strStroke : 'Stroke' ,
strColor : 'Color' ,
strSize : 'Size' ,
strFill : 'Fill' ,
textColor : 'Color Fill' ,
strTransparency : 'Opacity' ,
textNoFill : 'No Fill' ,
textSelectTexture : 'Select' ,
textGradientFill : 'Gradient Fill' ,
textLinear : 'Linear' ,
textRadial : 'Radial' ,
textDirection : 'Direction' ,
textStyle : 'Style' ,
textGradient : 'Gradient' ,
textBorderSizeErr : 'The entered value is incorrect.<br>Please enter a value between 0 pt and 1584 pt.' ,
textTransform : 'Transform' ,
2016-06-29 12:47:08 +00:00
textTemplate : 'Template' ,
2020-07-09 12:44:30 +00:00
strType : 'Type' ,
textPosition : 'Position' ,
tipAddGradientPoint : 'Add gradient point' ,
tipRemoveGradientPoint : 'Remove gradient point'
2016-03-11 00:48:53 +00:00
} , DE . Views . TextArtSettings || { } ) ) ;
} ) ;