2020-07-07 08:45:45 +00:00
/ *
*
* ( c ) Copyright Ascensio System SIA 2010 - 2020
*
* 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 20 A - 12 Ernesta Birznieka - Upisha
* street , Riga , Latvia , EU , LV - 1050.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices , as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7 ( b ) of the License you must retain the original Product
* logo when distributing the program . Pursuant to Section 7 ( e ) we decline to
* grant you any rights under trademark law for use of our trademarks .
*
* All the Product ' s GUI elements , including illustrations and icon sets , as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution - ShareAlike 4.0 International . See the License
* terms at http : //creativecommons.org/licenses/by-sa/4.0/legalcode
*
* /
/ * *
* ChartDataDialog . js
*
* Created by Julia Radzhabova on 06.07 . 2020
* Copyright ( c ) 2020 Ascensio System SIA . All rights reserved .
*
* /
define ( [
'common/main/lib/util/utils' ,
'common/main/lib/component/MetricSpinner' ,
'common/main/lib/component/ComboBox' ,
'common/main/lib/component/ListView' ,
'common/main/lib/view/AdvancedSettingsWindow'
] , function ( ) { 'use strict' ;
SSE . Views . ChartDataDialog = Common . Views . AdvancedSettingsWindow . extend ( _ . extend ( {
options : {
contentWidth : 370 ,
2020-07-07 12:10:48 +00:00
height : 490
2020-07-07 08:45:45 +00:00
} ,
initialize : function ( options ) {
var me = this ;
_ . extend ( this . options , {
title : this . textTitle ,
template : [
'<div class="box" style="height:' + ( me . options . height - 85 ) + 'px;">' ,
'<div class="content-panel" style="padding: 0 10px;"><div class="inner-content">' ,
'<div class="settings-panel active">' ,
'<table cols="1" style="width: 100%;">' ,
'<tr>' ,
'<td>' ,
'<label class="input-label">' , me . textDataRange , '</label>' ,
'</td>' ,
'</tr>' ,
'<tr>' ,
'<td class="padding-small" width="200">' ,
'<div id="chart-dlg-txt-range" class="input-row" style=""></div>' ,
'</td>' ,
'</tr>' ,
'<tr>' ,
'<td class="padding-small">' ,
'<label class="input-label">' , me . textSeries , '</label>' ,
'<div id="chart-dlg-series-list" class="" style="width:100%; height: 93px;"></div>' ,
'</td>' ,
'</tr>' ,
'<tr>' ,
'<td class="padding-large">' ,
'<button type="button" class="btn btn-text-default auto" id="chart-dlg-btn-add" style="min-width: 70px;margin-right:5px;">' , me . textAdd , '</button>' ,
'<button type="button" class="btn btn-text-default auto" id="chart-dlg-btn-edit" style="min-width: 70px;margin-right:5px;">' , me . textEdit , '</button>' ,
'<button type="button" class="btn btn-text-default auto" id="chart-dlg-btn-delete" style="min-width: 70px;margin-right:5px;">' , me . textDelete , '</button>' ,
'<div style="display: inline-block; float: right;">' ,
2020-07-07 12:07:15 +00:00
'<div id="chart-dlg-btn-up" style="display: inline-block;border: 1px solid #cfcfcf;border-radius: 1px;margin-right: 2px;"></div>' ,
2020-07-07 08:45:45 +00:00
'<div id="chart-dlg-btn-down" style="display: inline-block;border: 1px solid #cfcfcf;border-radius: 1px;"></div>' ,
'</div>' ,
'</td>' ,
'</tr>' ,
'<tr>' ,
'<td class="padding-large">' ,
'<button type="button" class="btn btn-text-default auto" id="chart-dlg-btn-switch" style="min-width: 70px;margin-right:5px;">' , me . textSwitch , '</button>' ,
'</td>' ,
'</tr>' ,
'<tr>' ,
'<td class="padding-small">' ,
'<label class="input-label">' , me . textCategory , '</label>' ,
'<div id="chart-dlg-category-list" class="" style="width:100%; height: 93px;"></div>' ,
'</td>' ,
'</tr>' ,
'<tr>' ,
'<td class="padding-small">' ,
'<button type="button" class="btn btn-text-default auto" id="chart-dlg-btn-category-edit" style="min-width: 70px;margin-right:5px;">' , me . textEdit , '</button>' ,
'</td>' ,
'</tr>' ,
'</table>' ,
'</div></div>' ,
'</div>' ,
'</div>' ,
2020-07-07 12:10:48 +00:00
'<div class="separator horizontal"></div>'
2020-07-07 08:45:45 +00:00
] . join ( '' )
} , options ) ;
this . handler = options . handler ;
Common . Views . AdvancedSettingsWindow . prototype . initialize . call ( this , this . options ) ;
this . _noApply = true ;
this . _changedProps = null ;
this . api = this . options . api ;
this . chartSettings = this . options . chartSettings ;
this . dataRangeValid = '' ;
this . dataDirect = 0 ;
this . currentChartType = Asc . c _oAscChartTypeSettings . barNormal ;
} ,
render : function ( ) {
Common . Views . AdvancedSettingsWindow . prototype . render . call ( this ) ;
var me = this ;
this . txtDataRange = new Common . UI . InputFieldBtn ( {
el : $ ( '#chart-dlg-txt-range' ) ,
name : 'range' ,
style : 'width: 100%;' ,
btnHint : this . textSelectData ,
allowBlank : true ,
validateOnChange : true
} ) ;
this . txtDataRange . on ( 'button:click' , _ . bind ( this . onSelectData _simple , this ) ) ;
this . txtDataRange . on ( 'changed:after' , function ( input , newValue , oldValue , e ) {
if ( newValue !== me . dataRangeValid ) {
if ( me . isRangeValid ( ) ) {
me . dataRangeValid = newValue ;
me . txtDataRange . checkValidate ( ) ;
me . chartSettings . putRange ( me . dataRangeValid ) ;
me . api . asc _editChartDrawingObject ( me . chartSettings ) ;
} else {
me . txtDataRange . setValue ( me . dataRangeValid ) ;
me . txtDataRange . checkValidate ( ) ;
}
}
} ) ;
// Chart data
this . seriesList = new Common . UI . ListView ( {
el : $ ( '#chart-dlg-series-list' , this . $window ) ,
store : new Common . UI . DataViewStore ( ) ,
emptyText : '' ,
2020-07-07 09:32:59 +00:00
scrollAlwaysVisible : true
2020-07-07 08:45:45 +00:00
} ) ;
this . seriesList . onKeyDown = _ . bind ( this . onListKeyDown , this , 'series' ) ;
this . seriesList . on ( 'item:select' , _ . bind ( this . onSelectSeries , this ) ) ;
2020-07-07 12:07:15 +00:00
this . seriesList . store . comparator = function ( rec ) {
return rec . get ( "order" ) ;
} ;
2020-07-07 08:45:45 +00:00
this . btnAdd = new Common . UI . Button ( {
el : $ ( '#chart-dlg-btn-add' )
} ) ;
this . btnAdd . on ( 'click' , _ . bind ( this . onAddSeries , this , false ) ) ;
this . btnDelete = new Common . UI . Button ( {
el : $ ( '#chart-dlg-btn-delete' )
} ) ;
2020-07-07 12:07:15 +00:00
this . btnDelete . on ( 'click' , _ . bind ( this . onDeleteSeries , this ) ) ;
2020-07-07 08:45:45 +00:00
this . btnEdit = new Common . UI . Button ( {
el : $ ( '#chart-dlg-btn-edit' )
} ) ;
this . btnEdit . on ( 'click' , _ . bind ( this . onEditSeries , this , false ) ) ;
this . btnUp = new Common . UI . Button ( {
parentEl : $ ( '#chart-dlg-btn-up' ) ,
cls : 'btn-toolbar' ,
iconCls : 'caret-up' ,
hint : this . textUp
} ) ;
2020-07-07 12:07:15 +00:00
this . btnUp . on ( 'click' , _ . bind ( this . onMoveClick , this , true ) ) ;
2020-07-07 08:45:45 +00:00
this . btnDown = new Common . UI . Button ( {
parentEl : $ ( '#chart-dlg-btn-down' ) ,
cls : 'btn-toolbar' ,
iconCls : 'caret-down' ,
hint : this . textDown
} ) ;
2020-07-07 12:07:15 +00:00
this . btnDown . on ( 'click' , _ . bind ( this . onMoveClick , this , false ) ) ;
2020-07-07 08:45:45 +00:00
this . btnSwitch = new Common . UI . Button ( {
el : $ ( '#chart-dlg-btn-switch' )
} ) ;
// this.btnSwitch.on('click', _.bind(this.onSwitch, this));
this . categoryList = new Common . UI . ListView ( {
el : $ ( '#chart-dlg-category-list' , this . $window ) ,
store : new Common . UI . DataViewStore ( ) ,
emptyText : '' ,
2020-07-07 09:32:59 +00:00
scrollAlwaysVisible : true
2020-07-07 08:45:45 +00:00
} ) ;
this . categoryList . onKeyDown = _ . bind ( this . onListKeyDown , this , 'category' ) ;
this . btnEditCategory = new Common . UI . Button ( {
el : $ ( '#chart-dlg-btn-category-edit' )
} ) ;
this . btnEditCategory . on ( 'click' , _ . bind ( this . onEditCategory , this , false ) ) ;
this . afterRender ( ) ;
} ,
afterRender : function ( ) {
this . _setDefaults ( this . chartSettings ) ;
} ,
show : function ( ) {
Common . Views . AdvancedSettingsWindow . prototype . show . apply ( this , arguments ) ;
var me = this ;
_ . delay ( function ( ) {
me . txtDataRange . cmpEl . find ( 'input' ) . focus ( ) ;
} , 50 ) ;
} ,
close : function ( ) {
this . api . asc _onCloseChartFrame ( ) ;
Common . Views . AdvancedSettingsWindow . prototype . close . apply ( this , arguments ) ;
} ,
_setDefaults : function ( props ) {
var me = this ;
if ( props ) {
this . chartSettings = props ;
this . currentChartType = props . getType ( ) ;
var value = props . getRange ( ) ;
this . txtDataRange . setValue ( ( value ) ? value : '' ) ;
this . dataRangeValid = value ;
this . txtDataRange . validation = function ( value ) {
if ( _ . isEmpty ( value ) ) {
return true ;
}
var isvalid = me . api . asc _checkDataRange ( Asc . c _oAscSelectionDialogType . Chart , value , false ) ;
return ( isvalid == Asc . c _oAscError . ID . DataRangeError ) ? me . textInvalidRange : true ;
} ;
this . dataDirect = props . getInColumns ( ) ? 1 : 0 ;
2020-07-07 12:07:15 +00:00
this . updateSeriesList ( props . getSeries ( ) , 0 ) ;
var categories = props . getCatValues ( ) ,
arr = [ ] ;
var store = this . categoryList . store ;
for ( var i = 0 , len = categories . length ; i < len ; i ++ )
{
var item = categories [ i ] ,
rec = new Common . UI . DataViewModel ( ) ;
rec . set ( {
value : item
} ) ;
arr . push ( rec ) ;
}
store . reset ( arr ) ;
( len > 0 ) && this . categoryList . selectByIndex ( 0 ) ;
2020-07-07 08:45:45 +00:00
}
2020-07-07 12:07:15 +00:00
this . updateButtons ( ) ;
2020-07-07 13:19:30 +00:00
this . updateCatButtons ( ) ;
2020-07-07 08:45:45 +00:00
} ,
getSettings : function ( ) {
this . chartSettings . putRange ( this . txtDataRange . getValue ( ) ) ;
return { chartSettings : this . chartSettings } ;
} ,
onDlgBtnClick : function ( event ) {
var me = this ;
var state = ( typeof ( event ) == 'object' ) ? event . currentTarget . attributes [ 'result' ] . value : event ;
if ( state == 'ok' ) {
this . handler && this . handler . call ( this , state , ( state == 'ok' ) ? this . getSettings ( ) : undefined ) ;
}
this . close ( ) ;
} ,
onPrimary : function ( ) {
this . onDlgBtnClick ( 'ok' ) ;
return false ;
} ,
isRangeValid : function ( ) {
var isvalid ;
if ( ! _ . isEmpty ( this . txtDataRange . getValue ( ) ) ) {
isvalid = this . api . asc _checkDataRange ( Asc . c _oAscSelectionDialogType . Chart , this . txtDataRange . getValue ( ) , true , this . dataDirect === 0 , this . currentChartType ) ;
if ( isvalid == Asc . c _oAscError . ID . No )
return true ;
} else
return true ;
if ( isvalid == Asc . c _oAscError . ID . StockChartError ) {
Common . UI . warning ( { msg : this . errorStockChart } ) ;
} else if ( isvalid == Asc . c _oAscError . ID . MaxDataSeriesError ) {
Common . UI . warning ( { msg : this . errorMaxRows } ) ;
} else if ( isvalid == Asc . c _oAscError . ID . MaxDataPointsError )
Common . UI . warning ( { msg : this . errorMaxPoints } ) ;
else
this . txtDataRange . cmpEl . find ( 'input' ) . focus ( ) ;
return false ;
} ,
onSelectData _simple : function ( ) {
var me = this ;
if ( me . api ) {
var props = me . chartSettings ;
var handlerDlg = function ( dlg , result ) {
if ( result == 'ok' && me . isRangeValid ( ) ) {
me . dataRangeValid = dlg . getSettings ( ) ;
me . txtDataRange . setValue ( me . dataRangeValid ) ;
me . txtDataRange . checkValidate ( ) ;
props . putRange ( me . dataRangeValid ) ;
me . api . asc _setSelectionDialogMode ( Asc . c _oAscSelectionDialogType . None ) ;
me . api . asc _editChartDrawingObject ( props ) ;
}
} ;
var win = new SSE . Views . CellRangeDialog ( {
handler : handlerDlg
} ) . on ( 'close' , function ( ) {
me . show ( ) ;
} ) ;
var xy = me . $window . offset ( ) ;
me . hide ( ) ;
win . show ( xy . left + 160 , xy . top + 125 ) ;
win . setSettings ( {
api : me . api ,
range : ( ! _ . isEmpty ( me . txtDataRange . getValue ( ) ) && ( me . txtDataRange . checkValidate ( ) == true ) ) ? me . txtDataRange . getValue ( ) : me . dataRangeValid ,
type : Asc . c _oAscSelectionDialogType . Chart
} ) ;
}
} ,
onSelectData : function ( ) {
var me = this ;
if ( me . api ) {
var props = me . chartSettings ,
handlerDlg = function ( dlg , result ) {
if ( result == 'ok' && me . isRangeValid ( ) ) {
props . putRange ( dlg . getSettings ( ) ) ;
me . api . asc _setSelectionDialogMode ( Asc . c _oAscSelectionDialogType . None ) ;
me . api . asc _editChartDrawingObject ( props ) ;
}
} ,
validation = function ( value ) {
var isvalid ;
if ( ! _ . isEmpty ( value ) ) {
isvalid = me . api . asc _checkDataRange ( Asc . c _oAscSelectionDialogType . Chart , value , true , ! props . getInColumns ( ) , me . currentChartType ) ;
if ( isvalid == Asc . c _oAscError . ID . No )
return true ;
} else return '' ;
if ( isvalid == Asc . c _oAscError . ID . StockChartError ) {
return this . errorStockChart ;
} else if ( isvalid == Asc . c _oAscError . ID . MaxDataSeriesError ) {
return this . errorMaxRows ;
}
return this . txtInvalidRange ;
} ;
var win = new SSE . Views . CellRangeDialog ( {
handler : handlerDlg
} ) . on ( 'close' , function ( ) {
me . show ( ) ;
// me.api.asc_onCloseChartFrame();
} ) ;
var xy = me . $window . offset ( ) ;
me . hide ( ) ;
win . show ( xy . left + 160 , xy . top + 125 ) ;
win . setSettings ( {
api : me . api ,
range : props . getRange ( ) ,
validation : validation ,
type : Asc . c _oAscSelectionDialogType . Chart
} ) ;
}
} ,
onListKeyDown : function ( type , e , data ) {
var record = null , listView = ( type == 'series' ) ? this . seriesList : this . categoryList ;
if ( listView . disabled ) return ;
if ( _ . isUndefined ( undefined ) ) data = e ;
2020-07-07 09:32:59 +00:00
if ( type == 'series' && data . keyCode == Common . UI . Keys . DELETE && ! this . btnDelete . isDisabled ( ) ) {
2020-07-07 08:45:45 +00:00
// this.onDeleteSeries();
} else {
Common . UI . DataView . prototype . onKeyDown . call ( listView , e , data ) ;
}
} ,
onSelectSeries : function ( lisvView , itemView , record ) {
2020-07-07 13:19:30 +00:00
this . updateCatButtons ( record . get ( 'series' ) . asc _IsScatter ( ) ) ;
2020-07-07 08:45:45 +00:00
this . updateMoveButtons ( ) ;
} ,
2020-07-07 12:07:15 +00:00
updateButtons : function ( ) {
// this.btnAdd.setDisabled(this.seriesList.store.length>63);
this . btnEdit . setDisabled ( this . seriesList . store . length < 1 ) ;
this . btnDelete . setDisabled ( this . seriesList . store . length < 1 ) ;
this . updateMoveButtons ( ) ;
} ,
2020-07-07 13:19:30 +00:00
updateCatButtons : function ( isScatter ) {
if ( isScatter === undefined ) {
var rec = this . seriesList . getSelectedRec ( ) ;
rec && ( isScatter = rec . get ( 'series' ) . asc _IsScatter ( ) ) ;
}
this . btnEditCategory . setDisabled ( this . categoryList . store . length < 1 || ! ! isScatter ) ;
2020-07-07 12:07:15 +00:00
} ,
2020-07-07 08:45:45 +00:00
updateMoveButtons : function ( ) {
var rec = this . seriesList . getSelectedRec ( ) ,
index = rec ? this . seriesList . store . indexOf ( rec ) : - 1 ;
this . btnUp . setDisabled ( index < 1 ) ;
this . btnDown . setDisabled ( index < 0 || index == this . seriesList . store . length - 1 ) ;
} ,
onAddSeries : function ( ) {
2020-07-07 12:07:15 +00:00
var rec = ( this . seriesList . store . length > 0 ) ? this . seriesList . store . at ( this . seriesList . store . length - 1 ) : null ,
isScatter = false ;
rec && ( isScatter = rec . get ( 'series' ) . asc _IsScatter ( ) ) ;
2020-07-07 08:45:45 +00:00
var handlerDlg = function ( dlg , result ) {
if ( result == 'ok' ) {
var changedValue = dlg . getSettings ( ) ;
2020-07-07 12:07:15 +00:00
if ( isScatter ) {
this . chartSettings . addScatterSeries ( changedValue . name , changedValue . valuesX , changedValue . valuesY ) ;
} else {
this . chartSettings . addSeries ( changedValue . name , changedValue . values ) ;
}
this . updateSeriesList ( this . chartSettings . getSeries ( ) , this . seriesList . store . length - 1 ) ;
this . updateButtons ( ) ;
2020-07-07 08:45:45 +00:00
}
} ;
2020-07-07 12:07:15 +00:00
this . changeDataRange ( 1 , { isScatter : isScatter } , true , handlerDlg ) ;
} ,
onDeleteSeries : function ( ) {
var rec = this . seriesList . getSelectedRec ( ) ;
if ( rec ) {
var order = rec . get ( 'order' ) ;
// this.chartSettings.deleteSeries(rec.get('index'));
this . updateSeriesList ( this . chartSettings . getSeries ( ) , order ) ;
}
this . updateButtons ( ) ;
2020-07-07 08:45:45 +00:00
} ,
onEditSeries : function ( ) {
2020-07-07 12:07:15 +00:00
var rec = this . seriesList . getSelectedRec ( ) ;
if ( rec ) {
var series = rec . get ( 'series' ) ,
isScatter = series . asc _IsScatter ( ) ;
var handlerDlg = function ( dlg , result ) {
if ( result == 'ok' ) {
var changedValue = dlg . getSettings ( ) ;
}
} ;
this . changeDataRange ( 1 , { series : series , name : series . asc _getName ( ) , isScatter : isScatter , values : isScatter ? null : series . asc _getValues ( ) ,
valuesX : ! isScatter ? null : series . asc _getXValues ( ) , valuesY : ! isScatter ? null : series . asc _getYValues ( ) } , false , handlerDlg ) ;
}
2020-07-07 08:45:45 +00:00
} ,
onEditCategory : function ( ) {
var handlerDlg = function ( dlg , result ) {
if ( result == 'ok' ) {
var changedValue = dlg . getSettings ( ) ;
}
} ;
2020-07-07 13:19:30 +00:00
this . changeDataRange ( 0 , { category : '' , values : this . chartSettings . getCatValues ( ) } , false , handlerDlg ) ;
2020-07-07 08:45:45 +00:00
} ,
2020-07-07 12:07:15 +00:00
changeDataRange : function ( type , props , add , handlerDlg ) {
2020-07-07 08:45:45 +00:00
var me = this ;
var win = new SSE . Views . ChartDataRangeDialog ( {
type : type , //series
2020-07-07 12:07:15 +00:00
isScatter : ! ! props . isScatter ,
2020-07-07 08:45:45 +00:00
handler : handlerDlg
} ) . on ( 'close' , function ( ) {
me . show ( ) ;
} ) ;
var xy = me . $window . offset ( ) ;
me . hide ( ) ;
win . show ( xy . left + 160 , xy . top + 125 ) ;
win . setSettings ( {
2020-07-07 12:07:15 +00:00
api : me . api ,
props : props
2020-07-07 08:45:45 +00:00
} ) ;
} ,
2020-07-07 12:07:15 +00:00
onMoveClick : function ( up ) {
var store = this . seriesList . store ,
length = store . length ,
rec = this . seriesList . getSelectedRec ( ) ;
if ( rec ) {
var index = store . indexOf ( rec ) ,
order = rec . get ( 'order' ) ,
newindex = up ? Math . max ( 0 , index - 1 ) : Math . min ( length - 1 , index + 1 ) ,
newrec = store . at ( newindex ) ,
neworder = newrec . get ( 'order' ) ;
store . add ( store . remove ( rec ) , { at : newindex } ) ;
rec . set ( 'order' , neworder ) ;
newrec . set ( 'order' , order ) ;
// this.chartSettings.changeSeriesOrder(rec.get('index'), neworder, newrec.get('index'), order);
this . seriesList . selectRecord ( rec ) ;
this . seriesList . scrollToRecord ( rec ) ;
}
this . updateMoveButtons ( ) ;
} ,
updateSeriesList : function ( series , index ) {
var arr = [ ] ;
var store = this . seriesList . store ;
for ( var i = 0 , len = series . length ; i < len ; i ++ )
{
var item = series [ i ] ,
rec = new Common . UI . DataViewModel ( ) ;
rec . set ( {
value : item . getSeriesName ( ) ,
index : item . asc _getIdx ( ) ,
order : item . asc _getOrder ( ) ,
series : item
} ) ;
arr . push ( rec ) ;
}
store . reset ( arr ) ;
( len > 0 ) && this . seriesList . selectByIndex ( Math . min ( index || 0 , store . length - 1 ) ) ;
} ,
2020-07-07 08:45:45 +00:00
textTitle : 'Chart Data' ,
txtEmpty : 'This field is required' ,
textInvalidRange : 'ERROR! Invalid cells range' ,
textSelectData : 'Select data' ,
errorMaxRows : 'ERROR! The maximum number of data series per chart is 255.' ,
errorStockChart : 'Incorrect row order. To build a stock chart place the data on the sheet in the following order:<br> opening price, max price, min price, closing price.' ,
errorMaxPoints : 'ERROR! The maximum number of points in series per chart is 4096.' ,
textSeries : 'Legend Entries (Series)' ,
textAdd : 'Add' ,
textEdit : 'Edit' ,
textDelete : 'Remove' ,
textSwitch : 'Switch Row/Column' ,
textCategory : 'Horizontal (Category) Axis Labels' ,
textUp : 'Up' ,
textDown : 'Down' ,
textData : 'Data'
} , SSE . Views . ChartDataDialog || { } ) )
} ) ;