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
define ( [
'core' ,
'spreadsheeteditor/main/app/view/FileMenuPanels' ,
'spreadsheeteditor/main/app/view/PrintSettings'
] , function ( ) {
'use strict' ;
SSE . Controllers . Print = Backbone . Controller . extend ( _ . extend ( {
views : [
'MainSettingsPrint'
] ,
initialize : function ( ) {
2016-03-31 11:13:16 +00:00
var value = Common . localStorage . getItem ( "sse-print-settings-range" ) ;
2016-04-05 11:52:34 +00:00
value = ( value !== null ) ? parseInt ( value ) : Asc . c _oAscPrintType . ActiveSheets ;
2016-04-01 13:01:12 +00:00
this . adjPrintParams = new Asc . asc _CAdjustPrint ( ) ;
2016-03-31 11:13:16 +00:00
this . adjPrintParams . asc _setPrintType ( value ) ;
2016-04-01 13:01:12 +00:00
this . _changedProps = null ;
2019-01-18 14:03:28 +00:00
this . _originalPageSettings = null ;
2016-03-11 00:48:53 +00:00
this . addListeners ( {
'MainSettingsPrint' : {
'show' : _ . bind ( this . onShowMainSettingsPrint , this ) ,
'render:after' : _ . bind ( this . onAfterRender , this )
} ,
'PrintSettings' : {
'changerange' : _ . bind ( this . onChangeRange , this )
}
} ) ;
2019-10-02 14:52:54 +00:00
Common . NotificationCenter . on ( 'print' , _ . bind ( this . openPrintSettings , this , 'print' ) ) ;
Common . NotificationCenter . on ( 'download:settings' , _ . bind ( this . openPrintSettings , this , 'download' ) ) ;
2016-03-11 00:48:53 +00:00
} ,
onLaunch : function ( ) {
this . printSettings = this . createView ( 'MainSettingsPrint' ) ;
} ,
onAfterRender : function ( view ) {
2016-04-01 13:01:12 +00:00
this . printSettings . cmbSheet . on ( 'selected' , _ . bind ( this . comboSheetsChange , this , this . printSettings ) ) ;
2016-03-11 00:48:53 +00:00
this . printSettings . btnOk . on ( 'click' , _ . bind ( this . querySavePrintSettings , this ) ) ;
2020-03-17 14:55:37 +00:00
this . fillComponents ( this . printSettings ) ;
2016-04-01 13:01:12 +00:00
this . registerControlEvents ( this . printSettings ) ;
2016-03-11 00:48:53 +00:00
} ,
setApi : function ( o ) {
this . api = o ;
this . api . asc _registerCallback ( 'asc_onSheetsChanged' , _ . bind ( this . updateSheetsInfo , this ) ) ;
} ,
updateSheetsInfo : function ( ) {
if ( this . printSettings . isVisible ( ) ) {
2016-04-01 13:01:12 +00:00
this . updateSettings ( this . printSettings ) ;
2016-03-11 00:48:53 +00:00
} else {
this . isFillSheets = false ;
}
} ,
2016-04-01 13:01:12 +00:00
updateSettings : function ( panel ) {
2016-03-11 00:48:53 +00:00
var wc = this . api . asc _getWorksheetsCount ( ) , i = - 1 ;
2016-04-01 13:01:12 +00:00
var items = [ ] ;
2016-03-11 00:48:53 +00:00
while ( ++ i < wc ) {
if ( ! this . api . asc _isWorksheetHidden ( i ) ) {
items . push ( {
displayValue : this . api . asc _getWorksheetName ( i ) ,
value : i
} ) ;
}
}
2016-04-01 13:01:12 +00:00
panel . cmbSheet . store . reset ( items ) ;
var item = panel . cmbSheet . store . findWhere ( { value : panel . cmbSheet . getValue ( ) } ) ||
panel . cmbSheet . store . findWhere ( { value : this . api . asc _getActiveWorksheetIndex ( ) } ) ;
2016-03-11 00:48:53 +00:00
if ( item ) {
2016-04-01 13:01:12 +00:00
panel . cmbSheet . setValue ( item . get ( 'value' ) ) ;
2016-03-11 00:48:53 +00:00
}
} ,
2016-04-01 13:01:12 +00:00
comboSheetsChange : function ( panel , combo , record ) {
2020-03-18 10:06:18 +00:00
this . fillPageOptions ( panel , this . _changedProps [ record . value ] ? this . _changedProps [ record . value ] : this . api . asc _getPageOptions ( record . value ) , record . value ) ;
2016-03-11 00:48:53 +00:00
} ,
2020-03-18 10:06:18 +00:00
fillPageOptions : function ( panel , props , sheet ) {
2016-03-11 00:48:53 +00:00
var opt = props . asc _getPageSetup ( ) ;
2019-01-18 14:03:28 +00:00
this . _originalPageSettings = opt ;
2016-03-11 00:48:53 +00:00
var item = panel . cmbPaperOrientation . store . findWhere ( { value : opt . asc _getOrientation ( ) } ) ;
if ( item ) panel . cmbPaperOrientation . setValue ( item . get ( 'value' ) ) ;
var w = opt . asc _getWidth ( ) ;
var h = opt . asc _getHeight ( ) ;
2018-09-13 13:47:38 +00:00
var store = panel . cmbPaperSize . store ;
item = null ;
for ( var i = 0 ; i < store . length ; i ++ ) {
var rec = store . at ( i ) ,
value = rec . get ( 'value' ) ,
pagewidth = parseFloat ( /^\d{3}\.?\d*/ . exec ( value ) ) ,
pageheight = parseFloat ( /\d{3}\.?\d*$/ . exec ( value ) ) ;
if ( Math . abs ( pagewidth - w ) < 0.1 && Math . abs ( pageheight - h ) < 0.1 ) {
item = rec ;
break ;
}
}
2016-03-11 00:48:53 +00:00
if ( item )
panel . cmbPaperSize . setValue ( item . get ( 'value' ) ) ;
else
2019-09-04 09:58:34 +00:00
panel . cmbPaperSize . setValue ( this . txtCustom + ' (' + parseFloat ( Common . Utils . Metric . fnRecalcFromMM ( w ) . toFixed ( 2 ) ) + Common . Utils . Metric . getCurrentMetricName ( ) + ' x ' +
2019-01-18 14:03:28 +00:00
parseFloat ( Common . Utils . Metric . fnRecalcFromMM ( h ) . toFixed ( 2 ) ) + Common . Utils . Metric . getCurrentMetricName ( ) + ')' ) ;
2016-03-11 00:48:53 +00:00
2019-10-11 07:45:56 +00:00
this . fitWidth = opt . asc _getFitToWidth ( ) ;
this . fitHeight = opt . asc _getFitToHeight ( ) ;
this . fitScale = opt . asc _getScale ( ) ;
this . setScaling ( panel , this . fitWidth , this . fitHeight , this . fitScale ) ;
2016-04-01 13:01:12 +00:00
item = panel . cmbPaperOrientation . store . findWhere ( { value : opt . asc _getOrientation ( ) } ) ;
if ( item ) panel . cmbPaperOrientation . setValue ( item . get ( 'value' ) ) ;
2016-03-11 00:48:53 +00:00
opt = props . asc _getPageMargins ( ) ;
2016-04-01 14:06:16 +00:00
panel . spnMarginLeft . setValue ( Common . Utils . Metric . fnRecalcFromMM ( opt . asc _getLeft ( ) ) , true ) ;
panel . spnMarginTop . setValue ( Common . Utils . Metric . fnRecalcFromMM ( opt . asc _getTop ( ) ) , true ) ;
panel . spnMarginRight . setValue ( Common . Utils . Metric . fnRecalcFromMM ( opt . asc _getRight ( ) ) , true ) ;
panel . spnMarginBottom . setValue ( Common . Utils . Metric . fnRecalcFromMM ( opt . asc _getBottom ( ) ) , true ) ;
2016-03-11 00:48:53 +00:00
2016-04-01 14:06:16 +00:00
panel . chPrintGrid . setValue ( props . asc _getGridLines ( ) , true ) ;
panel . chPrintRows . setValue ( props . asc _getHeadings ( ) , true ) ;
2020-03-17 14:55:37 +00:00
2020-03-18 10:06:18 +00:00
var value = props . asc _getPrintTitlesWidth ( ) ;
panel . txtRangeTop . setValue ( ( value ) ? value : '' ) ;
panel . txtRangeTop . checkValidate ( ) ;
panel . dataRangeTop = value ;
value = props . asc _getPrintTitlesHeight ( ) ;
panel . txtRangeLeft . setValue ( ( value ) ? value : '' ) ;
panel . txtRangeLeft . checkValidate ( ) ;
panel . dataRangeLeft = value ;
panel . btnPresetsTop . menu . items [ panel . btnPresetsTop . menu . items [ 0 ] . value == 'frozen' ? 0 : 1 ] . setDisabled ( ! this . api . asc _getPrintTitlesRange ( Asc . c _oAscPrintTitlesRangeType . frozen , false , sheet ) ) ;
panel . btnPresetsLeft . menu . items [ panel . btnPresetsLeft . menu . items [ 0 ] . value == 'frozen' ? 0 : 1 ] . setDisabled ( ! this . api . asc _getPrintTitlesRange ( Asc . c _oAscPrintTitlesRangeType . frozen , true , sheet ) ) ;
2016-03-11 00:48:53 +00:00
} ,
2016-04-01 13:01:12 +00:00
fillPrintOptions : function ( props ) {
this . printSettingsDlg . setRange ( props . asc _getPrintType ( ) ) ;
2019-03-19 14:33:09 +00:00
this . printSettingsDlg . setIgnorePrintArea ( ! ! props . asc _getIgnorePrintArea ( ) ) ;
2016-04-01 13:01:12 +00:00
this . onChangeRange ( ) ;
2016-03-11 00:48:53 +00:00
} ,
2016-04-01 13:01:12 +00:00
onChangeRange : function ( ) {
var printtype = this . printSettingsDlg . getRange ( ) ,
store = this . printSettingsDlg . cmbSheet . store ,
2016-04-05 11:52:34 +00:00
item = ( printtype !== Asc . c _oAscPrintType . EntireWorkbook ) ? store . findWhere ( { value : this . api . asc _getActiveWorksheetIndex ( ) } ) : store . at ( 0 ) ;
2016-04-01 13:01:12 +00:00
if ( item ) {
this . printSettingsDlg . cmbSheet . setValue ( item . get ( 'value' ) ) ;
this . comboSheetsChange ( this . printSettingsDlg , this . printSettingsDlg . cmbSheet , item . toJSON ( ) ) ;
}
2016-04-05 11:52:34 +00:00
this . printSettingsDlg . cmbSheet . setDisabled ( printtype !== Asc . c _oAscPrintType . EntireWorkbook ) ;
2019-03-19 14:33:09 +00:00
this . printSettingsDlg . chIgnorePrintArea . setDisabled ( printtype == Asc . c _oAscPrintType . Selection ) ;
2016-03-11 00:48:53 +00:00
} ,
getPageOptions : function ( panel ) {
var props = new Asc . asc _CPageOptions ( ) ;
props . asc _setGridLines ( panel . chPrintGrid . getValue ( ) == 'indeterminate' ? undefined : panel . chPrintGrid . getValue ( ) == 'checked' ? 1 : 0 ) ;
props . asc _setHeadings ( panel . chPrintRows . getValue ( ) == 'indeterminate' ? undefined : panel . chPrintRows . getValue ( ) == 'checked' ? 1 : 0 ) ;
var opt = new Asc . asc _CPageSetup ( ) ;
opt . asc _setOrientation ( panel . cmbPaperOrientation . getValue ( ) == '-' ? undefined : panel . cmbPaperOrientation . getValue ( ) ) ;
var pagew = /^\d{3}\.?\d*/ . exec ( panel . cmbPaperSize . getValue ( ) ) ;
var pageh = /\d{3}\.?\d*$/ . exec ( panel . cmbPaperSize . getValue ( ) ) ;
2019-01-18 14:03:28 +00:00
opt . asc _setWidth ( pagew ? parseFloat ( pagew [ 0 ] ) : ( this . _originalPageSettings ? this . _originalPageSettings . asc _getWidth ( ) : undefined ) ) ;
opt . asc _setHeight ( pageh ? parseFloat ( pageh [ 0 ] ) : ( this . _originalPageSettings ? this . _originalPageSettings . asc _getHeight ( ) : undefined ) ) ;
2016-04-01 13:01:12 +00:00
var value = panel . cmbLayout . getValue ( ) ;
2019-09-04 07:53:56 +00:00
if ( value !== 4 ) {
2019-09-05 07:52:49 +00:00
var fitToWidth = ( value == 1 || value == 2 ) ? 1 : 0 ,
fitToHeight = ( value == 1 || value == 3 ) ? 1 : 0 ;
opt . asc _setFitToWidth ( fitToWidth ) ;
opt . asc _setFitToHeight ( fitToHeight ) ;
! fitToWidth && ! fitToHeight && opt . asc _setScale ( 100 ) ;
2019-10-15 12:07:03 +00:00
this . setScaling ( panel , fitToWidth , fitToHeight , 100 ) ;
2019-09-04 07:53:56 +00:00
} else {
opt . asc _setFitToWidth ( this . fitWidth ) ;
opt . asc _setFitToHeight ( this . fitHeight ) ;
opt . asc _setScale ( this . fitScale ) ;
}
2016-03-11 00:48:53 +00:00
props . asc _setPageSetup ( opt ) ;
opt = new Asc . asc _CPageMargins ( ) ;
opt . asc _setLeft ( panel . spnMarginLeft . getValue ( ) == '-' ? undefined : Common . Utils . Metric . fnRecalcToMM ( panel . spnMarginLeft . getNumberValue ( ) ) ) ; // because 1.91*10=19.0999999...
opt . asc _setTop ( panel . spnMarginTop . getValue ( ) == '-' ? undefined : Common . Utils . Metric . fnRecalcToMM ( panel . spnMarginTop . getNumberValue ( ) ) ) ;
opt . asc _setRight ( panel . spnMarginRight . getValue ( ) == '-' ? undefined : Common . Utils . Metric . fnRecalcToMM ( panel . spnMarginRight . getNumberValue ( ) ) ) ;
opt . asc _setBottom ( panel . spnMarginBottom . getValue ( ) == '-' ? undefined : Common . Utils . Metric . fnRecalcToMM ( panel . spnMarginBottom . getNumberValue ( ) ) ) ;
props . asc _setPageMargins ( opt ) ;
2020-03-18 10:06:18 +00:00
var check = this . api . asc _checkDataRange ( Asc . c _oAscSelectionDialogType . None , panel . txtRangeTop . getValue ( ) , false ) !== Asc . c _oAscError . ID . DataRangeError ;
props . asc _setPrintTitlesWidth ( check ? panel . txtRangeTop . getValue ( ) : panel . dataRangeTop ) ;
check = this . api . asc _checkDataRange ( Asc . c _oAscSelectionDialogType . None , panel . txtRangeLeft . getValue ( ) , false ) !== Asc . c _oAscError . ID . DataRangeError ;
props . asc _setPrintTitlesHeight ( check ? panel . txtRangeLeft . getValue ( ) : panel . dataRangeLeft ) ;
2020-03-17 14:55:37 +00:00
2016-03-11 00:48:53 +00:00
return props ;
} ,
2016-04-01 13:01:12 +00:00
savePageOptions : function ( panel ) {
2018-07-30 14:51:28 +00:00
this . api . asc _savePagePrintOptions ( this . _changedProps ) ;
2018-06-28 09:27:11 +00:00
Common . NotificationCenter . trigger ( 'page:settings' ) ;
2016-03-11 00:48:53 +00:00
} ,
onShowMainSettingsPrint : function ( ) {
2016-04-01 13:01:12 +00:00
this . _changedProps = [ ] ;
2016-03-11 00:48:53 +00:00
if ( ! this . isFillSheets ) {
this . isFillSheets = true ;
2016-04-01 13:01:12 +00:00
this . updateSettings ( this . printSettings ) ;
2016-03-11 00:48:53 +00:00
}
2016-04-01 13:01:12 +00:00
var item = this . printSettings . cmbSheet . store . findWhere ( { value : this . api . asc _getActiveWorksheetIndex ( ) } ) ;
if ( item ) {
this . printSettings . cmbSheet . setValue ( item . get ( 'value' ) ) ;
this . comboSheetsChange ( this . printSettings , this . printSettings . cmbSheet , item . toJSON ( ) ) ;
2016-03-11 00:48:53 +00:00
}
} ,
2018-07-18 11:07:24 +00:00
openPrintSettings : function ( type , cmp , format , asUrl ) {
2019-01-10 11:00:30 +00:00
if ( this . printSettingsDlg && this . printSettingsDlg . isVisible ( ) ) {
asUrl && Common . NotificationCenter . trigger ( 'download:cancel' ) ;
return ;
}
2016-04-04 08:17:21 +00:00
if ( this . api ) {
2018-04-05 11:29:37 +00:00
this . asUrl = asUrl ;
2018-07-18 11:07:24 +00:00
this . downloadFormat = format ;
2016-03-11 00:48:53 +00:00
this . printSettingsDlg = ( new SSE . Views . PrintSettings ( {
2018-04-05 11:29:37 +00:00
type : type ,
2016-03-11 00:48:53 +00:00
handler : _ . bind ( this . resultPrintSettings , this ) ,
afterrender : _ . bind ( function ( ) {
2016-04-01 13:01:12 +00:00
this . _changedProps = [ ] ;
this . updateSettings ( this . printSettingsDlg ) ;
this . printSettingsDlg . cmbSheet . on ( 'selected' , _ . bind ( this . comboSheetsChange , this , this . printSettingsDlg ) ) ;
2020-03-17 14:55:37 +00:00
this . fillComponents ( this . printSettingsDlg , true ) ;
2016-04-01 13:01:12 +00:00
this . fillPrintOptions ( this . adjPrintParams ) ;
this . registerControlEvents ( this . printSettingsDlg ) ;
2016-03-11 00:48:53 +00:00
} , this )
} ) ) ;
this . printSettingsDlg . show ( ) ;
}
} ,
resultPrintSettings : function ( result , value ) {
var view = SSE . getController ( 'Toolbar' ) . getView ( 'Toolbar' ) ;
if ( result == 'ok' ) {
if ( this . checkMargins ( this . printSettingsDlg ) ) {
2016-04-01 13:01:12 +00:00
this . savePageOptions ( this . printSettingsDlg ) ;
2016-03-11 00:48:53 +00:00
2016-03-31 11:13:16 +00:00
var printtype = this . printSettingsDlg . getRange ( ) ;
this . adjPrintParams . asc _setPrintType ( printtype ) ;
2018-07-30 14:51:28 +00:00
this . adjPrintParams . asc _setPageOptionsMap ( this . _changedProps ) ;
2019-03-19 14:33:09 +00:00
this . adjPrintParams . asc _setIgnorePrintArea ( this . printSettingsDlg . getIgnorePrintArea ( ) ) ;
2016-03-31 11:13:16 +00:00
Common . localStorage . setItem ( "sse-print-settings-range" , printtype ) ;
2019-07-24 13:07:16 +00:00
if ( this . printSettingsDlg . type == 'print' ) {
var opts = new Asc . asc _CDownloadOptions ( null , Common . Utils . isChrome || Common . Utils . isSafari || Common . Utils . isOpera ) ;
2019-07-25 10:17:33 +00:00
opts . asc _setAdvancedOptions ( this . adjPrintParams ) ;
2019-07-24 13:07:16 +00:00
this . api . asc _Print ( opts ) ;
} else {
2019-07-24 08:36:13 +00:00
var opts = new Asc . asc _CDownloadOptions ( this . downloadFormat , this . asUrl ) ;
2019-07-25 10:17:33 +00:00
opts . asc _setAdvancedOptions ( this . adjPrintParams ) ;
2019-07-24 08:36:13 +00:00
this . api . asc _DownloadAs ( opts ) ;
}
2018-04-05 11:29:37 +00:00
Common . component . Analytics . trackEvent ( ( this . printSettingsDlg . type == 'print' ) ? 'Print' : 'DownloadAs' ) ;
Common . component . Analytics . trackEvent ( 'ToolBar' , ( this . printSettingsDlg . type == 'print' ) ? 'Print' : 'DownloadAs' ) ;
2016-04-01 13:01:12 +00:00
Common . NotificationCenter . trigger ( 'edit:complete' , view ) ;
2016-03-11 00:48:53 +00:00
} else
return true ;
2019-01-10 11:00:30 +00:00
} else {
this . asUrl && Common . NotificationCenter . trigger ( 'download:cancel' ) ;
2016-04-01 13:01:12 +00:00
Common . NotificationCenter . trigger ( 'edit:complete' , view ) ;
2019-01-10 11:00:30 +00:00
}
2018-07-25 11:24:45 +00:00
this . printSettingsDlg = null ;
2016-03-11 00:48:53 +00:00
} ,
querySavePrintSettings : function ( ) {
if ( this . checkMargins ( this . printSettings ) ) {
2016-04-01 13:01:12 +00:00
this . savePageOptions ( this . printSettings ) ;
2016-03-11 00:48:53 +00:00
this . printSettings . applySettings ( ) ;
}
} ,
checkMargins : function ( panel ) {
2016-04-05 11:52:34 +00:00
if ( panel . cmbPaperOrientation . getValue ( ) == Asc . c _oAscPageOrientation . PagePortrait ) {
2016-03-11 00:48:53 +00:00
var pagewidth = /^\d{3}\.?\d*/ . exec ( panel . cmbPaperSize . getValue ( ) ) ;
var pageheight = /\d{3}\.?\d*$/ . exec ( panel . cmbPaperSize . getValue ( ) ) ;
} else {
pageheight = /^\d{3}\.?\d*/ . exec ( panel . cmbPaperSize . getValue ( ) ) ;
pagewidth = /\d{3}\.?\d*$/ . exec ( panel . cmbPaperSize . getValue ( ) ) ;
}
2019-01-18 14:03:28 +00:00
pagewidth = pagewidth ? parseFloat ( pagewidth [ 0 ] ) : ( this . _originalPageSettings ? this . _originalPageSettings . asc _getWidth ( ) : 0 ) ;
pageheight = pageheight ? parseFloat ( pageheight [ 0 ] ) : ( this . _originalPageSettings ? this . _originalPageSettings . asc _getHeight ( ) : 0 ) ;
2016-03-11 00:48:53 +00:00
var ml = Common . Utils . Metric . fnRecalcToMM ( panel . spnMarginLeft . getNumberValue ( ) ) ;
var mr = Common . Utils . Metric . fnRecalcToMM ( panel . spnMarginRight . getNumberValue ( ) ) ;
var mt = Common . Utils . Metric . fnRecalcToMM ( panel . spnMarginTop . getNumberValue ( ) ) ;
var mb = Common . Utils . Metric . fnRecalcToMM ( panel . spnMarginBottom . getNumberValue ( ) ) ;
var result = false ;
if ( ml > pagewidth ) result = 'left' ; else
if ( mr > pagewidth - ml ) result = 'right' ; else
if ( mt > pageheight ) result = 'top' ; else
if ( mb > pageheight - mt ) result = 'bottom' ;
if ( result ) {
Common . UI . warning ( {
title : this . textWarning ,
msg : this . warnCheckMargings ,
callback : function ( btn , text ) {
switch ( result ) {
case 'left' : panel . spnMarginLeft . $el . focus ( ) ; return ;
case 'right' : panel . spnMarginRight . $el . focus ( ) ; return ;
case 'top' : panel . spnMarginTop . $el . focus ( ) ; return ;
case 'bottom' : panel . spnMarginBottom . $el . focus ( ) ; return ;
}
}
} ) ;
return false ;
}
return true ;
} ,
2016-04-01 13:01:12 +00:00
registerControlEvents : function ( panel ) {
panel . cmbPaperSize . on ( 'selected' , _ . bind ( this . propertyChange , this , panel ) ) ;
panel . cmbPaperOrientation . on ( 'selected' , _ . bind ( this . propertyChange , this , panel ) ) ;
2019-09-04 12:09:04 +00:00
panel . cmbLayout . on ( 'selected' , _ . bind ( this . propertyChange , this , panel , 'scale' ) ) ;
2016-04-01 13:01:12 +00:00
panel . spnMarginTop . on ( 'change' , _ . bind ( this . propertyChange , this , panel ) ) ;
panel . spnMarginBottom . on ( 'change' , _ . bind ( this . propertyChange , this , panel ) ) ;
panel . spnMarginLeft . on ( 'change' , _ . bind ( this . propertyChange , this , panel ) ) ;
panel . spnMarginRight . on ( 'change' , _ . bind ( this . propertyChange , this , panel ) ) ;
panel . chPrintGrid . on ( 'change' , _ . bind ( this . propertyChange , this , panel ) ) ;
panel . chPrintRows . on ( 'change' , _ . bind ( this . propertyChange , this , panel ) ) ;
2020-03-18 10:06:18 +00:00
panel . txtRangeTop . on ( 'changing' , _ . bind ( this . propertyChange , this , panel ) ) ;
panel . txtRangeLeft . on ( 'changing' , _ . bind ( this . propertyChange , this , panel ) ) ;
2020-03-17 14:55:37 +00:00
panel . btnPresetsTop . menu . on ( 'item:click' , _ . bind ( this . onPresetSelect , this , panel , 'top' ) ) ;
panel . btnPresetsLeft . menu . on ( 'item:click' , _ . bind ( this . onPresetSelect , this , panel , 'left' ) ) ;
2016-04-01 13:01:12 +00:00
} ,
2019-09-04 12:09:04 +00:00
propertyChange : function ( panel , scale , combo , record ) {
2019-10-15 12:07:03 +00:00
if ( scale === 'scale' && record . value === 'customoptions' ) {
2019-09-05 07:52:49 +00:00
var me = this ,
props = ( me . _changedProps . length > 0 && me . _changedProps [ panel . cmbSheet . getValue ( ) ] ) ? me . _changedProps [ panel . cmbSheet . getValue ( ) ] : me . api . asc _getPageOptions ( panel . cmbSheet . getValue ( ) ) ;
2019-09-04 12:09:04 +00:00
var win = new SSE . Views . ScaleDialog ( {
api : me . api ,
2019-09-05 07:52:49 +00:00
props : props ,
2019-09-04 12:09:04 +00:00
handler : function ( dlg , result ) {
if ( dlg == 'ok' ) {
if ( me . api && result ) {
me . fitWidth = result . width ;
me . fitHeight = result . height ;
me . fitScale = result . scale ;
me . setScaling ( panel , me . fitWidth , me . fitHeight , me . fitScale ) ;
if ( me . _changedProps ) {
me . _changedProps [ panel . cmbSheet . getValue ( ) ] = me . getPageOptions ( panel ) ;
}
}
} else {
var opt = props . asc _getPageSetup ( ) ,
fitwidth = opt . asc _getFitToWidth ( ) ,
fitheight = opt . asc _getFitToHeight ( ) ,
fitscale = opt . asc _getScale ( ) ;
me . setScaling ( panel , fitwidth , fitheight , fitscale ) ;
}
Common . NotificationCenter . trigger ( 'edit:complete' ) ;
}
} ) ;
win . show ( ) ;
Common . NotificationCenter . trigger ( 'edit:complete' , this . toolbar ) ;
} else {
if ( this . _changedProps ) {
this . _changedProps [ panel . cmbSheet . getValue ( ) ] = this . getPageOptions ( panel ) ;
}
2016-04-01 13:01:12 +00:00
}
} ,
2019-07-23 12:07:51 +00:00
getPrintParams : function ( ) {
return this . adjPrintParams ;
} ,
2019-09-04 07:53:56 +00:00
setScaling : function ( panel , width , height , scale ) {
2019-10-15 12:07:03 +00:00
var value ;
if ( ! width && ! height && scale === 100 ) value = 0 ;
else if ( width === 1 && height === 1 ) value = 1 ;
else if ( width === 1 && ! height ) value = 2 ;
else if ( ! width && height === 1 ) value = 3 ;
else value = 4 ;
panel . addCustomScale ( value === 4 ) ;
panel . cmbLayout . setValue ( value , true ) ;
2019-09-04 07:53:56 +00:00
} ,
2020-03-17 14:55:37 +00:00
fillComponents : function ( panel , selectdata ) {
var me = this ;
panel . txtRangeTop . validation = function ( value ) {
2020-03-18 10:06:18 +00:00
me . propertyChange ( panel ) ;
2020-03-17 14:55:37 +00:00
if ( _ . isEmpty ( value ) ) {
return true ;
}
2020-03-18 07:08:47 +00:00
var isvalid = me . api . asc _checkDataRange ( Asc . c _oAscSelectionDialogType . None , value , false ) ;
2020-03-17 14:55:37 +00:00
return ( isvalid == Asc . c _oAscError . ID . DataRangeError ) ? me . textInvalidRange : true ;
} ;
panel . txtRangeLeft . validation = function ( value ) {
2020-03-18 10:06:18 +00:00
me . propertyChange ( panel ) ;
2020-03-17 14:55:37 +00:00
if ( _ . isEmpty ( value ) ) {
return true ;
}
2020-03-18 07:08:47 +00:00
var isvalid = me . api . asc _checkDataRange ( Asc . c _oAscSelectionDialogType . None , value , false ) ;
2020-03-17 14:55:37 +00:00
return ( isvalid == Asc . c _oAscError . ID . DataRangeError ) ? me . textInvalidRange : true ;
} ;
var data = ( ( selectdata ) ? [ { caption : this . textSelectRange , value : 'select' } ] : [ ] ) . concat ( [
{ caption : this . textFrozenRows , value : 'frozen' } ,
{ caption : this . textFirstRow , value : 'first' } ,
{ caption : '--' } ,
{ caption : this . textNoRepeat , value : 'empty' }
] ) ;
panel . btnPresetsTop . setMenu ( new Common . UI . Menu ( {
style : 'min-width: 100px;' ,
maxHeight : 200 ,
items : data
} ) ) ;
data = ( ( selectdata ) ? [ { caption : this . textSelectRange , value : 'select' } ] : [ ] ) . concat ( [
{ caption : this . textFrozenCols , value : 'frozen' } ,
{ caption : this . textFirstCol , value : 'first' } ,
{ caption : '--' } ,
{ caption : this . textNoRepeat , value : 'empty' }
] ) ;
panel . btnPresetsLeft . setMenu ( new Common . UI . Menu ( {
style : 'min-width: 100px;' ,
maxHeight : 200 ,
items : data
} ) ) ;
} ,
onPresetSelect : function ( panel , type , menu , item ) {
var txtRange = ( type == 'top' ) ? panel . txtRangeTop : panel . txtRangeLeft ;
if ( item . value == 'select' ) {
var me = this ;
if ( me . api ) {
var handlerDlg = function ( dlg , result ) {
if ( result == 'ok' ) {
var valid = dlg . getSettings ( ) ;
if ( type == 'top' )
panel . dataRangeTop = valid ;
else
panel . dataRangeLeft = valid ;
txtRange . setValue ( valid ) ;
txtRange . checkValidate ( ) ;
}
} ;
var win = new SSE . Views . CellRangeDialog ( {
handler : handlerDlg
} ) . on ( 'close' , function ( ) {
panel . show ( ) ;
} ) ;
var xy = panel . $window . offset ( ) ;
panel . hide ( ) ;
win . show ( xy . left + 160 , xy . top + 125 ) ;
win . setSettings ( {
api : me . api ,
range : ( ! _ . isEmpty ( txtRange . getValue ( ) ) && ( txtRange . checkValidate ( ) == true ) ) ? txtRange . getValue ( ) : ( ( type == 'top' ) ? panel . dataRangeTop : panel . dataRangeLeft ) ,
2020-03-18 10:06:18 +00:00
type : Asc . c _oAscSelectionDialogType . Chart
2020-03-17 14:55:37 +00:00
} ) ;
}
} else {
var value = '' ;
if ( item . value == 'frozen' )
2020-03-17 15:03:42 +00:00
value = this . api . asc _getPrintTitlesRange ( Asc . c _oAscPrintTitlesRangeType . frozen , type == 'left' , panel . cmbSheet . getValue ( ) ) ;
2020-03-17 14:55:37 +00:00
else if ( item . value == 'first' )
2020-03-17 15:03:42 +00:00
value = this . api . asc _getPrintTitlesRange ( Asc . c _oAscPrintTitlesRangeType . first , type == 'left' , panel . cmbSheet . getValue ( ) ) ;
2020-03-17 14:55:37 +00:00
txtRange . setValue ( value ) ;
txtRange . checkValidate ( ) ;
if ( type == 'top' )
panel . dataRangeTop = value ;
else
panel . dataRangeLeft = value ;
}
} ,
2016-03-11 00:48:53 +00:00
warnCheckMargings : 'Margins are incorrect' ,
strAllSheets : 'All Sheets' ,
2019-01-18 14:25:13 +00:00
textWarning : 'Warning' ,
2020-03-17 14:55:37 +00:00
txtCustom : 'Custom' ,
textInvalidRange : 'ERROR! Invalid cells range' ,
textRepeat : 'Repeat...' ,
textNoRepeat : 'Not repeat' ,
textSelectRange : 'Select range...' ,
textFrozenRows : 'Frozen rows' ,
textFrozenCols : 'Frozen columns' ,
textFirstRow : 'First row' ,
textFirstCol : 'First column'
2016-03-11 00:48:53 +00:00
} , SSE . Controllers . Print || { } ) ) ;
} ) ;