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
/ * *
* FileMenuPanels . js
*
* Contains views for menu 'File'
*
* Created by Maxim Kadushkin on 20 February 2014
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 ( [
'common/main/lib/view/DocumentAccessDialog'
] , function ( ) {
'use strict' ;
! DE . Views . FileMenuPanels && ( DE . Views . FileMenuPanels = { } ) ;
DE . Views . FileMenuPanels . ViewSaveAs = Common . UI . BaseView . extend ( {
el : '#panel-saveas' ,
menu : undefined ,
formats : [ [
2018-01-25 07:33:59 +00:00
{ name : 'DOCX' , imgCls : 'docx' , type : Asc . c _oAscFileType . DOCX } ,
2016-04-05 11:52:34 +00:00
{ name : 'PDF' , imgCls : 'pdf' , type : Asc . c _oAscFileType . PDF } ,
2019-02-21 13:40:18 +00:00
{ name : 'ODT' , imgCls : 'odt' , type : Asc . c _oAscFileType . ODT } ,
{ name : 'TXT' , imgCls : 'txt' , type : Asc . c _oAscFileType . TXT }
2016-03-11 00:48:53 +00:00
] , [
2019-02-21 13:10:37 +00:00
{ name : 'DOTX' , imgCls : 'dotx' , type : Asc . c _oAscFileType . DOTX } ,
{ name : 'PDFA' , imgCls : 'pdfa' , type : Asc . c _oAscFileType . PDFA } ,
2019-02-21 13:40:18 +00:00
{ name : 'OTT' , imgCls : 'ott' , type : Asc . c _oAscFileType . OTT } ,
{ name : 'RTF' , imgCls : 'rtf' , type : Asc . c _oAscFileType . RTF }
2019-02-21 13:10:37 +00:00
] , [
2016-04-05 11:52:34 +00:00
{ name : 'HTML (Zipped)' , imgCls : 'html' , type : Asc . c _oAscFileType . HTML }
2016-03-11 00:48:53 +00:00
] ] ,
template : _ . template ( [
'<table><tbody>' ,
'<% _.each(rows, function(row) { %>' ,
'<tr>' ,
'<% _.each(row, function(item) { %>' ,
2018-04-17 12:07:30 +00:00
'<td><div><svg class="btn-doc-format" format="<%= item.type %>">' ,
'<use xlink:href="#svg-format-<%= item.imgCls %>"></use>' ,
'</svg></div></td>' ,
2016-03-11 00:48:53 +00:00
'<% }) %>' ,
'</tr>' ,
'<% }) %>' ,
'</tbody></table>'
] . join ( '' ) ) ,
initialize : function ( options ) {
Common . UI . BaseView . prototype . initialize . call ( this , arguments ) ;
this . menu = options . menu ;
} ,
render : function ( ) {
2019-08-01 08:13:08 +00:00
this . $el . html ( this . template ( { rows : this . formats } ) ) ;
2016-03-11 00:48:53 +00:00
$ ( '.btn-doc-format' , this . el ) . on ( 'click' , _ . bind ( this . onFormatClick , this ) ) ;
if ( _ . isUndefined ( this . scroller ) ) {
this . scroller = new Common . UI . Scroller ( {
2019-08-01 08:50:22 +00:00
el : this . $el ,
2016-03-11 00:48:53 +00:00
suppressScrollX : true
} ) ;
}
return this ;
} ,
onFormatClick : function ( e ) {
var type = e . currentTarget . attributes [ 'format' ] ;
if ( ! _ . isUndefined ( type ) && this . menu ) {
this . menu . fireEvent ( 'saveas:format' , [ this . menu , parseInt ( type . value ) ] ) ;
}
}
} ) ;
2018-08-22 08:13:37 +00:00
DE . Views . FileMenuPanels . ViewSaveCopy = Common . UI . BaseView . extend ( {
el : '#panel-savecopy' ,
menu : undefined ,
formats : [ [
{ name : 'DOCX' , imgCls : 'docx' , type : Asc . c _oAscFileType . DOCX , ext : '.docx' } ,
{ name : 'PDF' , imgCls : 'pdf' , type : Asc . c _oAscFileType . PDF , ext : '.pdf' } ,
2019-02-21 13:40:18 +00:00
{ name : 'ODT' , imgCls : 'odt' , type : Asc . c _oAscFileType . ODT , ext : '.odt' } ,
{ name : 'TXT' , imgCls : 'txt' , type : Asc . c _oAscFileType . TXT , ext : '.txt' }
2018-08-22 08:13:37 +00:00
] , [
2019-02-21 13:10:37 +00:00
{ name : 'DOTX' , imgCls : 'dotx' , type : Asc . c _oAscFileType . DOTX , ext : '.dotx' } ,
{ name : 'PDFA' , imgCls : 'pdfa' , type : Asc . c _oAscFileType . PDFA , ext : '.pdf' } ,
2019-02-21 13:40:18 +00:00
{ name : 'OTT' , imgCls : 'ott' , type : Asc . c _oAscFileType . OTT , ext : '.ott' } ,
{ name : 'RTF' , imgCls : 'rtf' , type : Asc . c _oAscFileType . RTF , ext : '.rtf' }
2019-02-21 13:10:37 +00:00
] , [
2018-08-22 08:13:37 +00:00
{ name : 'HTML (Zipped)' , imgCls : 'html' , type : Asc . c _oAscFileType . HTML , ext : '.html' }
] ] ,
template : _ . template ( [
'<table><tbody>' ,
'<% _.each(rows, function(row) { %>' ,
'<tr>' ,
'<% _.each(row, function(item) { %>' ,
'<td><div><svg class="btn-doc-format" format="<%= item.type %>", format-ext="<%= item.ext %>">' ,
'<use xlink:href="#svg-format-<%= item.imgCls %>"></use>' ,
'</svg></div></td>' ,
'<% }) %>' ,
'</tr>' ,
'<% }) %>' ,
'</tbody></table>'
] . join ( '' ) ) ,
initialize : function ( options ) {
Common . UI . BaseView . prototype . initialize . call ( this , arguments ) ;
this . menu = options . menu ;
} ,
render : function ( ) {
2019-08-22 14:41:41 +00:00
this . $el . html ( this . template ( { rows : this . formats } ) ) ;
2018-08-22 08:13:37 +00:00
$ ( '.btn-doc-format' , this . el ) . on ( 'click' , _ . bind ( this . onFormatClick , this ) ) ;
if ( _ . isUndefined ( this . scroller ) ) {
this . scroller = new Common . UI . Scroller ( {
2019-08-01 08:50:22 +00:00
el : this . $el ,
2018-08-22 08:13:37 +00:00
suppressScrollX : true
} ) ;
}
return this ;
} ,
onFormatClick : function ( e ) {
var type = e . currentTarget . attributes [ 'format' ] ,
ext = e . currentTarget . attributes [ 'format-ext' ] ;
if ( ! _ . isUndefined ( type ) && ! _ . isUndefined ( ext ) && this . menu ) {
this . menu . fireEvent ( 'savecopy:format' , [ this . menu , parseInt ( type . value ) , ext . value ] ) ;
}
}
} ) ;
2016-03-11 00:48:53 +00:00
DE . Views . FileMenuPanels . Settings = Common . UI . BaseView . extend ( _ . extend ( {
el : '#panel-settings' ,
menu : undefined ,
template : _ . template ( [
'<table><tbody>' ,
/** coauthoring begin **/
2017-06-14 11:53:29 +00:00
'<tr class="comments">' ,
2016-03-11 00:48:53 +00:00
'<td class="left"><label><%= scope.txtLiveComment %></label></td>' ,
'<td class="right"><div id="fms-chb-live-comment"/></td>' ,
2017-06-14 11:53:29 +00:00
'</tr>' , '<tr class="divider comments"></tr>' ,
'<tr class="comments">' ,
2017-06-05 14:51:26 +00:00
'<td class="left"></td>' ,
'<td class="right"><div id="fms-chb-resolved-comment"/></td>' ,
2017-06-14 11:53:29 +00:00
'</tr>' , '<tr class="divider comments"></tr>' ,
2016-03-11 00:48:53 +00:00
/** coauthoring end **/
'<tr class="edit">' ,
'<td class="left"><label><%= scope.txtSpellCheck %></label></td>' ,
'<td class="right"><div id="fms-chb-spell-check"/></td>' ,
'</tr>' , '<tr class="divider edit"></tr>' ,
2016-08-16 10:20:46 +00:00
'<tr class="edit">' ,
'<td class="left"><label><%= scope.txtInput %></label></td>' ,
'<td class="right"><div id="fms-chb-input-mode"/></td>' ,
'</tr>' , '<tr class="divider edit"></tr>' ,
2017-04-11 13:54:05 +00:00
'<tr class="edit">' ,
2016-03-11 00:48:53 +00:00
'<td class="left"><label><%= scope.textAlignGuides %></label></td>' ,
'<td class="right"><span id="fms-chb-align-guides" /></td>' ,
2017-04-11 13:54:05 +00:00
'</tr>' , '<tr class="divider edit"></tr>' ,
2019-07-24 09:27:14 +00:00
'<tr class="edit">' ,
'<td class="left"><label><%= scope.textCompatible %></label></td>' ,
'<td class="right"><span id="fms-chb-compatible" /></td>' ,
'</tr>' , '<tr class="divider edit"></tr>' ,
2016-03-11 00:48:53 +00:00
'<tr class="autosave">' ,
'<td class="left"><label id="fms-lbl-autosave"><%= scope.textAutoSave %></label></td>' ,
'<td class="right"><span id="fms-chb-autosave" /></td>' ,
'</tr>' , '<tr class="divider autosave"></tr>' ,
2017-04-11 13:40:01 +00:00
'<tr class="forcesave">' ,
'<td class="left"><label id="fms-lbl-forcesave"><%= scope.textForceSave %></label></td>' ,
'<td class="right"><span id="fms-chb-forcesave" /></td>' ,
'</tr>' , '<tr class="divider forcesave"></tr>' ,
2016-03-11 00:48:53 +00:00
/** coauthoring begin **/
'<tr class="coauth changes">' ,
'<td class="left"><label><%= scope.strCoAuthMode %></label></td>' ,
'<td class="right">' ,
2018-10-31 08:57:22 +00:00
'<div><div id="fms-cmb-coauth-mode" style="display: inline-block; margin-right: 15px;vertical-align: middle;"/>' ,
2016-03-11 00:48:53 +00:00
'<label id="fms-lbl-coauth-mode" style="vertical-align: middle;"><%= scope.strCoAuthModeDescFast %></label></div></td>' ,
'</tr>' , '<tr class="divider coauth changes"></tr>' ,
'<tr class="coauth changes">' ,
'<td class="left"><label><%= scope.strShowChanges %></label></td>' ,
'<td class="right"><span id="fms-cmb-show-changes" /></td>' ,
'</tr>' , '<tr class="divider coauth changes"></tr>' ,
/** coauthoring end **/
'<tr>' ,
'<td class="left"><label><%= scope.strZoom %></label></td>' ,
'<td class="right"><div id="fms-cmb-zoom" class="input-group-nr" /></td>' ,
'</tr>' , '<tr class="divider"></tr>' ,
'<tr>' ,
'<td class="left"><label><%= scope.strFontRender %></label></td>' ,
'<td class="right"><span id="fms-cmb-font-render" /></td>' ,
'</tr>' , '<tr class="divider"></tr>' ,
'<tr class="edit">' ,
'<td class="left"><label><%= scope.strUnit %></label></td>' ,
'<td class="right"><span id="fms-cmb-unit" /></td>' ,
'</tr>' , '<tr class="divider edit"></tr>' ,
'<tr>' ,
'<td class="left"></td>' ,
'<td class="right"><button id="fms-btn-apply" class="btn normal dlg-btn primary"><%= scope.okButtonText %></button></td>' ,
'</tr>' ,
'</tbody></table>'
] . join ( '' ) ) ,
initialize : function ( options ) {
Common . UI . BaseView . prototype . initialize . call ( this , arguments ) ;
this . menu = options . menu ;
} ,
2019-08-01 08:13:08 +00:00
render : function ( node ) {
2019-08-01 08:50:22 +00:00
var me = this ;
var $markup = $ ( this . template ( { scope : this } ) ) ;
2016-03-11 00:48:53 +00:00
this . chInputMode = new Common . UI . CheckBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-chb-input-mode' ) ,
2016-03-11 00:48:53 +00:00
labelText : this . strInputMode
} ) ;
/** coauthoring begin **/
this . chLiveComment = new Common . UI . CheckBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-chb-live-comment' ) ,
2016-03-11 00:48:53 +00:00
labelText : this . strLiveComment
2019-08-01 08:13:08 +00:00
} ) . on ( 'change' , function ( field , newValue , oldValue , eOpts ) {
me . chResolvedComment . setDisabled ( field . getValue ( ) !== 'checked' ) ;
} ) ;
2017-06-05 14:51:26 +00:00
this . chResolvedComment = new Common . UI . CheckBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-chb-resolved-comment' ) ,
2017-06-05 14:51:26 +00:00
labelText : this . strResolvedComment
2016-03-11 00:48:53 +00:00
} ) ;
/** coauthoring end **/
this . chSpell = new Common . UI . CheckBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-chb-spell-check' ) ,
2016-03-11 00:48:53 +00:00
labelText : this . strSpellCheckMode
} ) ;
2019-07-24 09:27:14 +00:00
this . chCompatible = new Common . UI . CheckBox ( {
2019-09-19 13:31:05 +00:00
el : $markup . findById ( '#fms-chb-compatible' ) ,
2019-07-24 09:27:14 +00:00
labelText : this . textOldVersions
} ) ;
2016-03-11 00:48:53 +00:00
this . chAutosave = new Common . UI . CheckBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-chb-autosave' ) ,
2016-03-11 00:48:53 +00:00
labelText : this . strAutosave
2019-08-01 08:13:08 +00:00
} ) . on ( 'change' , function ( field , newValue , oldValue , eOpts ) {
if ( field . getValue ( ) !== 'checked' && me . cmbCoAuthMode . getValue ( ) ) {
me . cmbCoAuthMode . setValue ( 0 ) ;
me . onSelectCoAuthMode ( me . cmbCoAuthMode . getSelectedRecord ( ) ) ;
2016-03-25 07:48:19 +00:00
}
2019-08-01 08:13:08 +00:00
} ) ;
this . lblAutosave = $markup . findById ( '#fms-lbl-autosave' ) ;
2017-04-11 13:40:01 +00:00
this . chForcesave = new Common . UI . CheckBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-chb-forcesave' ) ,
2017-04-11 13:40:01 +00:00
labelText : this . strForcesave
} ) ;
2016-03-11 00:48:53 +00:00
this . chAlignGuides = new Common . UI . CheckBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-chb-align-guides' ) ,
2016-03-11 00:48:53 +00:00
labelText : this . strAlignGuides
} ) ;
this . cmbZoom = new Common . UI . ComboBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-cmb-zoom' ) ,
2016-03-11 00:48:53 +00:00
style : 'width: 160px;' ,
editable : false ,
cls : 'input-group-nr' ,
2016-09-13 08:28:21 +00:00
menuStyle : 'max-height: 210px;' ,
2016-03-11 00:48:53 +00:00
data : [
2016-09-13 08:28:21 +00:00
{ value : - 1 , displayValue : this . txtFitPage } ,
{ value : - 2 , displayValue : this . txtFitWidth } ,
2016-03-11 00:48:53 +00:00
{ value : 50 , displayValue : "50%" } ,
{ value : 60 , displayValue : "60%" } ,
{ value : 70 , displayValue : "70%" } ,
{ value : 80 , displayValue : "80%" } ,
{ value : 90 , displayValue : "90%" } ,
{ value : 100 , displayValue : "100%" } ,
{ value : 110 , displayValue : "110%" } ,
{ value : 120 , displayValue : "120%" } ,
{ value : 150 , displayValue : "150%" } ,
{ value : 175 , displayValue : "175%" } ,
{ value : 200 , displayValue : "200%" }
]
} ) ;
/** coauthoring begin **/
this . cmbShowChanges = new Common . UI . ComboBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-cmb-show-changes' ) ,
2016-03-11 00:48:53 +00:00
style : 'width: 160px;' ,
editable : false ,
cls : 'input-group-nr' ,
data : [
{ value : 'none' , displayValue : this . txtNone } ,
{ value : 'all' , displayValue : this . txtAll } ,
{ value : 'last' , displayValue : this . txtLast }
]
} ) ;
this . cmbCoAuthMode = new Common . UI . ComboBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-cmb-coauth-mode' ) ,
2016-03-11 00:48:53 +00:00
style : 'width: 160px;' ,
editable : false ,
cls : 'input-group-nr' ,
data : [
{ value : 1 , displayValue : this . strFast , descValue : this . strCoAuthModeDescFast } ,
{ value : 0 , displayValue : this . strStrict , descValue : this . strCoAuthModeDescStrict }
]
2019-08-01 08:13:08 +00:00
} ) . on ( 'selected' , function ( combo , record ) {
if ( record . value == 1 && ( me . chAutosave . getValue ( ) !== 'checked' ) )
me . chAutosave . setValue ( 1 ) ;
me . onSelectCoAuthMode ( record ) ;
} ) ;
2016-03-11 00:48:53 +00:00
2019-08-01 08:13:08 +00:00
this . lblCoAuthMode = $markup . findById ( '#fms-lbl-coauth-mode' ) ;
2016-03-11 00:48:53 +00:00
/** coauthoring end **/
this . cmbFontRender = new Common . UI . ComboBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . find ( '#fms-cmb-font-render' ) ,
2016-03-11 00:48:53 +00:00
style : 'width: 160px;' ,
editable : false ,
cls : 'input-group-nr' ,
data : [
{ value : 0 , displayValue : this . txtWin } ,
{ value : 1 , displayValue : this . txtMac } ,
{ value : 2 , displayValue : this . txtNative }
]
} ) ;
this . cmbUnit = new Common . UI . ComboBox ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-cmb-unit' ) ,
2016-03-11 00:48:53 +00:00
style : 'width: 160px;' ,
editable : false ,
cls : 'input-group-nr' ,
data : [
{ value : Common . Utils . Metric . c _MetricUnits [ 'cm' ] , displayValue : this . txtCm } ,
2016-04-06 15:17:40 +00:00
{ value : Common . Utils . Metric . c _MetricUnits [ 'pt' ] , displayValue : this . txtPt } ,
{ value : Common . Utils . Metric . c _MetricUnits [ 'inch' ] , displayValue : this . txtInch }
2016-03-11 00:48:53 +00:00
]
} ) ;
this . btnApply = new Common . UI . Button ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#fms-btn-apply' )
2016-03-11 00:48:53 +00:00
} ) ;
2019-08-01 08:13:08 +00:00
this . btnApply . on ( 'click' , this . applySettings . bind ( this ) ) ;
2016-03-11 00:48:53 +00:00
2019-08-01 08:50:22 +00:00
this . $el = $ ( node ) . html ( $markup ) ;
2016-03-11 00:48:53 +00:00
if ( _ . isUndefined ( this . scroller ) ) {
this . scroller = new Common . UI . Scroller ( {
2019-08-01 08:50:22 +00:00
el : this . $el ,
2016-03-11 00:48:53 +00:00
suppressScrollX : true
} ) ;
}
return this ;
} ,
show : function ( ) {
Common . UI . BaseView . prototype . show . call ( this , arguments ) ;
this . updateSettings ( ) ;
} ,
setMode : function ( mode ) {
this . mode = mode ;
$ ( 'tr.edit' , this . el ) [ mode . isEdit ? 'show' : 'hide' ] ( ) ;
2016-03-25 07:48:19 +00:00
$ ( 'tr.autosave' , this . el ) [ mode . isEdit ? 'show' : 'hide' ] ( ) ;
2017-04-11 13:40:01 +00:00
$ ( 'tr.forcesave' , this . el ) [ mode . canForcesave ? 'show' : 'hide' ] ( ) ;
2016-03-18 13:48:33 +00:00
if ( this . mode . isDesktopApp && this . mode . isOffline ) {
2016-03-11 00:48:53 +00:00
this . chAutosave . setCaption ( this . strAutoRecover ) ;
this . lblAutosave . text ( this . textAutoRecover ) ;
}
/** coauthoring begin **/
$ ( 'tr.coauth' , this . el ) [ mode . isEdit && mode . canCoAuthoring ? 'show' : 'hide' ] ( ) ;
2016-12-20 14:29:37 +00:00
$ ( 'tr.coauth.changes' , this . el ) [ mode . isEdit && ! mode . isOffline && mode . canCoAuthoring ? 'show' : 'hide' ] ( ) ;
2018-12-17 08:37:43 +00:00
$ ( 'tr.comments' , this . el ) [ mode . canCoAuthoring ? 'show' : 'hide' ] ( ) ;
2016-03-11 00:48:53 +00:00
/** coauthoring end **/
} ,
updateSettings : function ( ) {
2017-10-03 11:22:33 +00:00
this . chInputMode . setValue ( Common . Utils . InternalSettings . get ( "de-settings-inputmode" ) ) ;
2016-03-11 00:48:53 +00:00
2017-10-03 11:22:33 +00:00
var value = Common . Utils . InternalSettings . get ( "de-settings-zoom" ) ;
2016-09-13 08:28:21 +00:00
value = ( value !== null ) ? parseInt ( value ) : ( this . mode . customization && this . mode . customization . zoom ? parseInt ( this . mode . customization . zoom ) : 100 ) ;
var item = this . cmbZoom . store . findWhere ( { value : value } ) ;
this . cmbZoom . setValue ( item ? parseInt ( item . get ( 'value' ) ) : ( value > 0 ? value + '%' : 100 ) ) ;
2016-03-11 00:48:53 +00:00
/** coauthoring begin **/
2017-10-03 11:22:33 +00:00
this . chLiveComment . setValue ( Common . Utils . InternalSettings . get ( "de-settings-livecomment" ) ) ;
this . chResolvedComment . setValue ( Common . Utils . InternalSettings . get ( "de-settings-resolvedcomment" ) ) ;
2017-06-05 14:51:26 +00:00
2017-10-03 11:22:33 +00:00
var fast _coauth = Common . Utils . InternalSettings . get ( "de-settings-coauthmode" ) ;
item = this . cmbCoAuthMode . store . findWhere ( { value : fast _coauth ? 1 : 0 } ) ;
2016-03-11 00:48:53 +00:00
this . cmbCoAuthMode . setValue ( item ? item . get ( 'value' ) : 1 ) ;
this . lblCoAuthMode . text ( item ? item . get ( 'descValue' ) : this . strCoAuthModeDescFast ) ;
this . fillShowChanges ( fast _coauth ) ;
2017-10-03 11:22:33 +00:00
value = Common . Utils . InternalSettings . get ( ( fast _coauth ) ? "de-settings-showchanges-fast" : "de-settings-showchanges-strict" ) ;
2016-03-11 00:48:53 +00:00
item = this . cmbShowChanges . store . findWhere ( { value : value } ) ;
this . cmbShowChanges . setValue ( item ? item . get ( 'value' ) : ( fast _coauth ) ? 'none' : 'last' ) ;
/** coauthoring end **/
2017-10-03 11:22:33 +00:00
value = Common . Utils . InternalSettings . get ( "de-settings-fontrender" ) ;
2017-10-04 15:44:01 +00:00
item = this . cmbFontRender . store . findWhere ( { value : parseInt ( value ) } ) ;
2016-03-11 00:48:53 +00:00
this . cmbFontRender . setValue ( item ? item . get ( 'value' ) : ( window . devicePixelRatio > 1 ? 1 : 0 ) ) ;
2017-10-03 11:22:33 +00:00
value = Common . Utils . InternalSettings . get ( "de-settings-unit" ) ;
item = this . cmbUnit . store . findWhere ( { value : value } ) ;
2016-04-08 08:55:15 +00:00
this . cmbUnit . setValue ( item ? parseInt ( item . get ( 'value' ) ) : Common . Utils . Metric . getDefaultMetric ( ) ) ;
2016-03-11 00:48:53 +00:00
this . _oldUnits = this . cmbUnit . getValue ( ) ;
2017-10-03 11:22:33 +00:00
value = Common . Utils . InternalSettings . get ( "de-settings-autosave" ) ;
this . chAutosave . setValue ( value == 1 ) ;
2016-03-11 00:48:53 +00:00
2017-06-16 11:53:29 +00:00
if ( this . mode . canForcesave )
2017-10-03 11:22:33 +00:00
this . chForcesave . setValue ( Common . Utils . InternalSettings . get ( "de-settings-forcesave" ) ) ;
2017-04-11 13:40:01 +00:00
2017-10-03 11:22:33 +00:00
this . chSpell . setValue ( Common . Utils . InternalSettings . get ( "de-settings-spellcheck" ) ) ;
this . chAlignGuides . setValue ( Common . Utils . InternalSettings . get ( "de-settings-showsnaplines" ) ) ;
2019-07-24 09:27:14 +00:00
this . chCompatible . setValue ( Common . Utils . InternalSettings . get ( "de-settings-compatible" ) ) ;
2016-03-11 00:48:53 +00:00
} ,
applySettings : function ( ) {
Common . localStorage . setItem ( "de-settings-inputmode" , this . chInputMode . isChecked ( ) ? 1 : 0 ) ;
Common . localStorage . setItem ( "de-settings-zoom" , this . cmbZoom . getValue ( ) ) ;
2017-10-03 11:22:33 +00:00
Common . Utils . InternalSettings . set ( "de-settings-zoom" , Common . localStorage . getItem ( "de-settings-zoom" ) ) ;
2016-03-11 00:48:53 +00:00
/** coauthoring begin **/
Common . localStorage . setItem ( "de-settings-livecomment" , this . chLiveComment . isChecked ( ) ? 1 : 0 ) ;
2017-06-05 14:51:26 +00:00
Common . localStorage . setItem ( "de-settings-resolvedcomment" , this . chResolvedComment . isChecked ( ) ? 1 : 0 ) ;
2016-12-20 14:29:37 +00:00
if ( this . mode . isEdit && ! this . mode . isOffline && this . mode . canCoAuthoring ) {
2016-03-11 00:48:53 +00:00
Common . localStorage . setItem ( "de-settings-coauthmode" , this . cmbCoAuthMode . getValue ( ) ) ;
Common . localStorage . setItem ( this . cmbCoAuthMode . getValue ( ) ? "de-settings-showchanges-fast" : "de-settings-showchanges-strict" , this . cmbShowChanges . getValue ( ) ) ;
}
/** coauthoring end **/
Common . localStorage . setItem ( "de-settings-fontrender" , this . cmbFontRender . getValue ( ) ) ;
Common . localStorage . setItem ( "de-settings-unit" , this . cmbUnit . getValue ( ) ) ;
Common . localStorage . setItem ( "de-settings-autosave" , this . chAutosave . isChecked ( ) ? 1 : 0 ) ;
2017-04-11 13:40:01 +00:00
if ( this . mode . canForcesave )
Common . localStorage . setItem ( "de-settings-forcesave" , this . chForcesave . isChecked ( ) ? 1 : 0 ) ;
2016-03-11 00:48:53 +00:00
Common . localStorage . setItem ( "de-settings-spellcheck" , this . chSpell . isChecked ( ) ? 1 : 0 ) ;
2019-07-24 09:27:14 +00:00
Common . localStorage . setItem ( "de-settings-compatible" , this . chCompatible . isChecked ( ) ? 1 : 0 ) ;
Common . Utils . InternalSettings . set ( "de-settings-compatible" , this . chCompatible . isChecked ( ) ? 1 : 0 ) ;
2017-10-04 15:44:01 +00:00
Common . Utils . InternalSettings . set ( "de-settings-showsnaplines" , this . chAlignGuides . isChecked ( ) ) ;
2016-03-11 00:48:53 +00:00
Common . localStorage . save ( ) ;
if ( this . menu ) {
this . menu . fireEvent ( 'settings:apply' , [ this . menu ] ) ;
if ( this . _oldUnits !== this . cmbUnit . getValue ( ) )
Common . NotificationCenter . trigger ( 'settings:unitschanged' , this ) ;
}
} ,
fillShowChanges : function ( fastmode ) {
if ( fastmode && this . cmbShowChanges . store . length == 3 || ! fastmode && this . cmbShowChanges . store . length == 2 ) {
var arr = [ { value : 'none' , displayValue : this . txtNone } , { value : 'all' , displayValue : this . txtAll } ] ;
if ( ! fastmode ) arr . push ( { value : 'last' , displayValue : this . txtLast } ) ;
this . cmbShowChanges . store . reset ( arr ) ;
}
} ,
2016-03-25 07:48:19 +00:00
onSelectCoAuthMode : function ( record ) {
this . lblCoAuthMode . text ( record . descValue ) ;
this . fillShowChanges ( record . value == 1 ) ;
this . cmbShowChanges . setValue ( ( record . value == 1 ) ? 'none' : 'last' ) ;
} ,
2016-03-11 00:48:53 +00:00
strLiveComment : 'Turn on option' ,
strInputMode : 'Turn on hieroglyphs' ,
strZoom : 'Default Zoom Value' ,
/** coauthoring begin **/
strShowChanges : 'Realtime Collaboration Changes' ,
txtAll : 'View All' ,
txtNone : 'View Nothing' ,
txtLast : 'View Last' ,
txtLiveComment : 'Live Commenting' ,
/** coauthoring end **/
okButtonText : 'Apply' ,
txtInput : 'Alternate Input' ,
txtWin : 'as Windows' ,
txtMac : 'as OS X' ,
txtNative : 'Native' ,
strFontRender : 'Font Hinting' ,
strUnit : 'Unit of Measurement' ,
txtCm : 'Centimeter' ,
txtPt : 'Point' ,
textAutoSave : 'Autosave' ,
strAutosave : 'Turn on autosave' ,
txtSpellCheck : 'Spell Checking' ,
strSpellCheckMode : 'Turn on spell checking option' ,
textAlignGuides : 'Alignment Guides' ,
strAlignGuides : 'Turn on alignment guides' ,
strCoAuthMode : 'Co-editing mode' ,
strCoAuthModeDescFast : 'Other users will see your changes at once' ,
strCoAuthModeDescStrict : 'You will need to accept changes before you can see them' ,
strFast : 'Fast' ,
strStrict : 'Strict' ,
textAutoRecover : 'Autorecover' ,
2016-04-06 15:17:40 +00:00
strAutoRecover : 'Turn on autorecover' ,
2016-09-13 08:28:21 +00:00
txtInch : 'Inch' ,
2016-09-26 12:07:51 +00:00
txtFitPage : 'Fit to Page' ,
2017-04-11 13:40:01 +00:00
txtFitWidth : 'Fit to Width' ,
textForceSave : 'Save to Server' ,
2017-06-05 14:51:26 +00:00
strForcesave : 'Always save to server (otherwise save to server on document close)' ,
2019-07-24 09:27:14 +00:00
strResolvedComment : 'Turn on display of the resolved comments' ,
textCompatible : 'Compatibility' ,
2019-07-25 13:01:40 +00:00
textOldVersions : 'Make the files compatible with older MS Word versions when saved as DOCX'
2016-03-11 00:48:53 +00:00
} , DE . Views . FileMenuPanels . Settings || { } ) ) ;
DE . Views . FileMenuPanels . RecentFiles = Common . UI . BaseView . extend ( {
el : '#panel-recentfiles' ,
menu : undefined ,
template : _ . template ( [
'<div id="id-recent-view" style="margin: 20px 0;"></div>'
] . join ( '' ) ) ,
initialize : function ( options ) {
Common . UI . BaseView . prototype . initialize . call ( this , arguments ) ;
this . menu = options . menu ;
this . recent = options . recent ;
} ,
render : function ( ) {
2019-08-22 14:41:41 +00:00
this . $el . html ( this . template ( ) ) ;
2016-03-11 00:48:53 +00:00
this . viewRecentPicker = new Common . UI . DataView ( {
el : $ ( '#id-recent-view' ) ,
store : new Common . UI . DataViewStore ( this . recent ) ,
itemTemplate : _ . template ( [
'<div class="recent-wrap">' ,
'<div class="recent-icon"></div>' ,
'<div class="file-name"><%= Common.Utils.String.htmlEncode(title) %></div>' ,
'<div class="file-info"><%= Common.Utils.String.htmlEncode(folder) %></div>' ,
'</div>'
] . join ( '' ) )
} ) ;
this . viewRecentPicker . on ( 'item:click' , _ . bind ( this . onRecentFileClick , this ) ) ;
if ( _ . isUndefined ( this . scroller ) ) {
this . scroller = new Common . UI . Scroller ( {
2019-08-22 14:41:41 +00:00
el : this . $el ,
2016-03-11 00:48:53 +00:00
suppressScrollX : true
} ) ;
}
return this ;
} ,
onRecentFileClick : function ( view , itemview , record ) {
if ( this . menu )
this . menu . fireEvent ( 'recent:open' , [ this . menu , record . get ( 'url' ) ] ) ;
}
} ) ;
DE . Views . FileMenuPanels . CreateNew = Common . UI . BaseView . extend ( _ . extend ( {
el : '#panel-createnew' ,
menu : undefined ,
events : function ( ) {
return {
'click .blank-document-btn' : _ . bind ( this . _onBlankDocument , this ) ,
'click .thumb-list .thumb-wrap' : _ . bind ( this . _onDocumentTemplate , this )
} ;
} ,
template : _ . template ( [
'<h3 style="margin-top: 20px;"><%= scope.fromBlankText %></h3><hr noshade />' ,
'<div class="blank-document">' ,
2018-04-17 12:07:30 +00:00
'<div class="blank-document-btn">' ,
'<svg class="btn-doc-format">' ,
'<use xlink:href="#svg-format-docx"></use>' ,
'</svg>' ,
'</div>' ,
2016-03-11 00:48:53 +00:00
'<div class="blank-document-info">' ,
'<h3><%= scope.newDocumentText %></h3>' ,
'<%= scope.newDescriptionText %>' ,
'</div>' ,
'</div>' ,
'<h3><%= scope.fromTemplateText %></h3><hr noshade />' ,
'<div class="thumb-list">' ,
'<% _.each(docs, function(item) { %>' ,
'<div class="thumb-wrap" template="<%= item.url %>">' ,
2018-04-17 12:07:30 +00:00
'<div class="thumb"' ,
'<% if (!_.isEmpty(item.icon)) { ' +
'print(\" style=\'background-image: url(item.icon);\'>\")' +
' } else { ' +
'print(\"><svg class=\'btn-doc-format\'><use xlink:href=\'#svg-format-blank\'></use></svg>\")' +
' } %>' ,
'</div>' ,
2016-03-11 00:48:53 +00:00
'<div class="title"><%= item.name %></div>' ,
'</div>' ,
'<% }) %>' ,
'</div>'
] . join ( '' ) ) ,
initialize : function ( options ) {
Common . UI . BaseView . prototype . initialize . call ( this , arguments ) ;
this . menu = options . menu ;
} ,
render : function ( ) {
2019-08-22 14:41:41 +00:00
this . $el . html ( this . template ( {
2016-03-11 00:48:53 +00:00
scope : this ,
docs : this . options [ 0 ] . docs
} ) ) ;
if ( _ . isUndefined ( this . scroller ) ) {
this . scroller = new Common . UI . Scroller ( {
2019-08-22 14:41:41 +00:00
el : this . $el ,
2016-03-11 00:48:53 +00:00
suppressScrollX : true
} ) ;
}
return this ;
} ,
_onBlankDocument : function ( ) {
if ( this . menu )
this . menu . fireEvent ( 'create:new' , [ this . menu , 'blank' ] ) ;
} ,
_onDocumentTemplate : function ( e ) {
if ( this . menu )
this . menu . fireEvent ( 'create:new' , [ this . menu , e . currentTarget . attributes [ 'template' ] . value ] ) ;
} ,
fromBlankText : 'From Blank' ,
newDocumentText : 'New Text Document' ,
newDescriptionText : 'Create a new blank text document which you will be able to style and format after it is created during the editing. Or choose one of the templates to start a document of a certain type or purpose where some styles have already been pre-applied.' ,
fromTemplateText : 'From Template' ,
noTemplatesText : 'There are no templates'
} , DE . Views . FileMenuPanels . CreateNew || { } ) ) ;
DE . Views . FileMenuPanels . DocumentInfo = Common . UI . BaseView . extend ( _ . extend ( {
el : '#panel-info' ,
menu : undefined ,
initialize : function ( options ) {
Common . UI . BaseView . prototype . initialize . call ( this , arguments ) ;
this . rendered = false ;
this . template = _ . template ( [
'<table class="main">' ,
2019-04-02 10:17:26 +00:00
'<tr>' ,
'<td class="left"><label>' + this . txtPlacement + '</label></td>' ,
'<td class="right"><label id="id-info-placement">-</label></td>' ,
'</tr>' ,
'<tr>' ,
'<td class="left"><label>' + this . txtOwner + '</label></td>' ,
'<td class="right"><label id="id-info-owner">-</label></td>' ,
'</tr>' ,
'<tr>' ,
'<td class="left"><label>' + this . txtUploaded + '</label></td>' ,
'<td class="right"><label id="id-info-uploaded">-</label></td>' ,
'</tr>' ,
'<tr class="divider general"></tr>' ,
'<tr class="divider general"></tr>' ,
'<tr>' ,
'<td class="left"><label>' + this . txtPages + '</label></td>' ,
'<td class="right"><label id="id-info-pages"></label></td>' ,
'</tr>' ,
'<tr>' ,
'<td class="left"><label>' + this . txtParagraphs + '</label></td>' ,
'<td class="right"><label id="id-info-paragraphs"></label></td>' ,
'</tr>' ,
'<tr>' ,
'<td class="left"><label>' + this . txtWords + '</label></td>' ,
'<td class="right"><label id="id-info-words"></label></td>' ,
'</tr>' ,
'<tr>' ,
'<td class="left"><label>' + this . txtSymbols + '</label></td>' ,
'<td class="right"><label id="id-info-symbols"></label></td>' ,
'</tr>' ,
'<tr>' ,
'<td class="left"><label>' + this . txtSpaces + '</label></td>' ,
'<td class="right"><label id="id-info-spaces"></label></td>' ,
'</tr>' ,
2019-05-15 11:17:29 +00:00
'<tr class="divider"></tr>' ,
'<tr class="divider"></tr>' ,
2019-05-15 13:49:11 +00:00
// '<tr>',
// '<td class="left"><label>' + this.txtEditTime + '</label></td>',
// '<td class="right"><label id="id-info-edittime"></label></td>',
// '</tr>',
2016-03-11 00:48:53 +00:00
'<tr>' ,
'<td class="left"><label>' + this . txtTitle + '</label></td>' ,
2019-04-02 10:17:26 +00:00
'<td class="right"><div id="id-info-title"></div></td>' ,
2016-03-11 00:48:53 +00:00
'</tr>' ,
2019-08-09 07:04:43 +00:00
'<tr>' ,
'<td class="left"><label>' + this . txtSubject + '</label></td>' ,
'<td class="right"><div id="id-info-subject"></div></td>' ,
'</tr>' ,
2019-04-02 10:17:26 +00:00
'<tr>' ,
'<td class="left"><label>' + this . txtComment + '</label></td>' ,
'<td class="right"><div id="id-info-comment"></div></td>' ,
2016-03-11 00:48:53 +00:00
'</tr>' ,
2019-04-02 10:17:26 +00:00
'<tr class="divider"></tr>' ,
'<tr class="divider"></tr>' ,
'<tr>' ,
'<td class="left"><label>' + this . txtModifyDate + '</label></td>' ,
'<td class="right"><label id="id-info-modify-date"></label></td>' ,
2016-03-11 00:48:53 +00:00
'</tr>' ,
2019-04-02 10:17:26 +00:00
'<tr>' ,
'<td class="left"><label>' + this . txtModifyBy + '</label></td>' ,
'<td class="right"><label id="id-info-modify-by"></label></td>' ,
2018-11-06 09:58:02 +00:00
'</tr>' ,
2019-04-02 10:17:26 +00:00
'<tr class="divider modify">' ,
'<tr class="divider modify">' ,
'<tr>' ,
2019-05-16 08:49:13 +00:00
'<td class="left"><label>' + this . txtCreated + '</label></td>' ,
2019-04-02 10:17:26 +00:00
'<td class="right"><label id="id-info-date"></label></td>' ,
2016-03-11 00:48:53 +00:00
'</tr>' ,
'<tr>' ,
2019-04-02 10:17:26 +00:00
'<td class="left"><label>' + this . txtAppName + '</label></td>' ,
'<td class="right"><label id="id-info-appname"></label></td>' ,
'</tr>' ,
'<tr>' ,
'<td class="left" style="vertical-align: top;"><label style="margin-top: 3px;">' + this . txtAuthor + '</label></td>' ,
'<td class="right" style="vertical-align: top;"><div id="id-info-author">' ,
2016-03-11 00:48:53 +00:00
'<table>' ,
2019-04-02 10:17:26 +00:00
'<tr>' ,
'<td><div id="id-info-add-author"><input type="text" spellcheck="false" class="form-control" placeholder="' + this . txtAddAuthor + '"></div></td>' ,
'</tr>' ,
2016-03-11 00:48:53 +00:00
'</table>' ,
'</div></td>' ,
'</tr>' ,
2019-09-06 14:38:29 +00:00
'<tr class="divider"></tr>' ,
'<tr>' ,
'<td class="left"></td>' ,
'<td class="right"><button id="fminfo-btn-apply" class="btn normal dlg-btn primary"><%= scope.okButtonText %></button></td>' ,
'</tr>' ,
2016-03-11 00:48:53 +00:00
'</table>'
] . join ( '' ) ) ;
this . infoObj = { PageCount : 0 , WordsCount : 0 , ParagraphCount : 0 , SymbolsCount : 0 , SymbolsWSCount : 0 } ;
this . inProgress = false ;
this . menu = options . menu ;
2019-06-21 11:34:40 +00:00
this . coreProps = null ;
this . authors = [ ] ;
2019-08-28 08:46:56 +00:00
this . _locked = false ;
2016-03-11 00:48:53 +00:00
} ,
2019-08-01 08:13:08 +00:00
render : function ( node ) {
2019-04-02 10:17:26 +00:00
var me = this ;
2019-09-18 14:54:16 +00:00
var $markup = $ ( me . template ( { scope : me } ) ) ;
2019-04-02 10:17:26 +00:00
// server info
2019-08-01 08:13:08 +00:00
this . lblPlacement = $markup . findById ( '#id-info-placement' ) ;
this . lblOwner = $markup . findById ( '#id-info-owner' ) ;
this . lblUploaded = $markup . findById ( '#id-info-uploaded' ) ;
2019-04-02 10:17:26 +00:00
// statistic info
2019-08-01 08:13:08 +00:00
this . lblStatPages = $markup . findById ( '#id-info-pages' ) ;
this . lblStatWords = $markup . findById ( '#id-info-words' ) ;
this . lblStatParagraphs = $markup . findById ( '#id-info-paragraphs' ) ;
this . lblStatSymbols = $markup . findById ( '#id-info-symbols' ) ;
this . lblStatSpaces = $markup . findById ( '#id-info-spaces' ) ;
// this.lblEditTime = $markup.find('#id-info-edittime');
2019-04-02 10:17:26 +00:00
// edited info
2019-06-21 13:35:23 +00:00
var keyDownBefore = function ( input , e ) {
if ( e . keyCode === Common . UI . Keys . ESC ) {
var newVal = input . _input . val ( ) ,
oldVal = input . getValue ( ) ;
if ( newVal !== oldVal ) {
input . setValue ( oldVal ) ;
e . stopPropagation ( ) ;
}
}
} ;
2019-04-02 10:17:26 +00:00
this . inputTitle = new Common . UI . InputField ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#id-info-title' ) ,
2019-04-02 10:17:26 +00:00
style : 'width: 200px;' ,
2019-05-15 11:17:29 +00:00
placeHolder : this . txtAddText ,
2019-04-02 10:17:26 +00:00
validateOnBlur : false
2019-06-21 13:35:23 +00:00
} ) . on ( 'keydown:before' , keyDownBefore ) ;
2019-04-02 10:17:26 +00:00
this . inputSubject = new Common . UI . InputField ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#id-info-subject' ) ,
2019-04-02 10:17:26 +00:00
style : 'width: 200px;' ,
2019-05-15 11:17:29 +00:00
placeHolder : this . txtAddText ,
2019-04-02 10:17:26 +00:00
validateOnBlur : false
2019-06-21 13:35:23 +00:00
} ) . on ( 'keydown:before' , keyDownBefore ) ;
2019-04-02 10:17:26 +00:00
this . inputComment = new Common . UI . InputField ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#id-info-comment' ) ,
2019-04-02 10:17:26 +00:00
style : 'width: 200px;' ,
2019-05-15 11:17:29 +00:00
placeHolder : this . txtAddText ,
2019-04-02 10:17:26 +00:00
validateOnBlur : false
2019-06-21 13:35:23 +00:00
} ) . on ( 'keydown:before' , keyDownBefore ) ;
2019-04-02 10:17:26 +00:00
// modify info
2019-08-01 08:13:08 +00:00
this . lblModifyDate = $markup . findById ( '#id-info-modify-date' ) ;
this . lblModifyBy = $markup . findById ( '#id-info-modify-by' ) ;
2019-04-02 10:17:26 +00:00
// creation info
2019-08-01 08:13:08 +00:00
this . lblDate = $markup . findById ( '#id-info-date' ) ;
this . lblApplication = $markup . findById ( '#id-info-appname' ) ;
this . tblAuthor = $markup . findById ( '#id-info-author table' ) ;
this . trAuthor = $markup . findById ( '#id-info-add-author' ) . closest ( 'tr' ) ;
2019-04-02 10:17:26 +00:00
this . authorTpl = '<tr><td><div style="display: inline-block;width: 200px;"><input type="text" spellcheck="false" class="form-control" readonly="true" value="{0}" ></div><div class="close img-commonctrl"></div></td></tr>' ;
this . tblAuthor . on ( 'click' , function ( e ) {
2019-08-01 08:13:08 +00:00
var btn = $markup . find ( e . target ) ;
2019-06-21 12:14:24 +00:00
if ( btn . hasClass ( 'close' ) && ! btn . hasClass ( 'disabled' ) ) {
2019-04-02 10:17:26 +00:00
var el = btn . closest ( 'tr' ) ,
idx = me . tblAuthor . find ( 'tr' ) . index ( el ) ;
el . remove ( ) ;
2019-06-21 11:34:40 +00:00
me . authors . splice ( idx , 1 ) ;
2019-04-02 10:17:26 +00:00
}
} ) ;
this . inputAuthor = new Common . UI . InputField ( {
2019-08-01 08:13:08 +00:00
el : $markup . findById ( '#id-info-add-author' ) ,
2019-04-02 10:17:26 +00:00
style : 'width: 200px;' ,
validateOnBlur : false ,
placeHolder : this . txtAddAuthor
2019-09-06 14:38:29 +00:00
} ) . on ( 'changed:after' , function ( input , newValue , oldValue , e ) {
2019-06-21 12:37:11 +00:00
if ( newValue == oldValue ) return ;
2019-04-02 10:17:26 +00:00
var val = newValue . trim ( ) ;
if ( ! ! val && val !== oldValue . trim ( ) ) {
2019-09-06 14:38:29 +00:00
var isFromApply = e && e . relatedTarget && ( e . relatedTarget . id == 'fminfo-btn-apply' ) ;
2019-04-02 10:17:26 +00:00
val . split ( /\s*[,;]\s*/ ) . forEach ( function ( item ) {
var str = item . trim ( ) ;
if ( str ) {
2019-06-21 11:34:40 +00:00
me . authors . push ( item ) ;
2019-09-06 14:38:29 +00:00
if ( ! isFromApply ) {
var div = $ ( Common . Utils . String . format ( me . authorTpl , Common . Utils . String . htmlEncode ( str ) ) ) ;
me . trAuthor . before ( div ) ;
}
2019-04-02 10:17:26 +00:00
}
} ) ;
2019-09-06 14:38:29 +00:00
! isFromApply && me . inputAuthor . setValue ( '' ) ;
2019-04-02 10:17:26 +00:00
}
2019-06-21 13:35:23 +00:00
} ) . on ( 'keydown:before' , keyDownBefore ) ;
2016-03-11 00:48:53 +00:00
2019-09-06 14:38:29 +00:00
this . btnApply = new Common . UI . Button ( {
el : '#fminfo-btn-apply'
} ) ;
this . btnApply . on ( 'click' , _ . bind ( this . applySettings , this ) ) ;
2016-03-11 00:48:53 +00:00
this . rendered = true ;
this . updateInfo ( this . doc ) ;
2019-08-01 08:50:22 +00:00
this . $el = $ ( node ) . html ( $markup ) ;
2016-03-11 00:48:53 +00:00
if ( _ . isUndefined ( this . scroller ) ) {
this . scroller = new Common . UI . Scroller ( {
2019-08-01 08:50:22 +00:00
el : this . $el ,
2016-03-11 00:48:53 +00:00
suppressScrollX : true
} ) ;
}
return this ;
} ,
show : function ( ) {
Common . UI . BaseView . prototype . show . call ( this , arguments ) ;
this . updateStatisticInfo ( ) ;
2019-04-02 10:17:26 +00:00
this . updateFileInfo ( ) ;
2016-03-11 00:48:53 +00:00
} ,
hide : function ( ) {
Common . UI . BaseView . prototype . hide . call ( this , arguments ) ;
this . stopUpdatingStatisticInfo ( ) ;
} ,
updateInfo : function ( doc ) {
2019-07-30 09:05:48 +00:00
if ( ! this . doc && doc && doc . info ) {
doc . info . author && console . log ( "Obsolete: The 'author' parameter of the document 'info' section is deprecated. Please use 'owner' instead." ) ;
doc . info . created && console . log ( "Obsolete: The 'created' parameter of the document 'info' section is deprecated. Please use 'uploaded' instead." ) ;
}
2016-03-11 00:48:53 +00:00
this . doc = doc ;
if ( ! this . rendered )
return ;
2019-04-02 10:17:26 +00:00
var visible = false ;
2016-03-11 00:48:53 +00:00
doc = doc || { } ;
if ( doc . info ) {
2019-04-02 10:17:26 +00:00
// server info
2016-03-11 00:48:53 +00:00
if ( doc . info . folder )
this . lblPlacement . text ( doc . info . folder ) ;
2019-05-16 08:49:13 +00:00
visible = this . _ShowHideInfoItem ( this . lblPlacement , doc . info . folder !== undefined && doc . info . folder !== null ) || visible ;
2019-07-30 09:05:48 +00:00
var value = doc . info . owner || doc . info . author ;
if ( value )
this . lblOwner . text ( value ) ;
visible = this . _ShowHideInfoItem ( this . lblOwner , ! ! value ) || visible ;
value = doc . info . uploaded || doc . info . created ;
if ( value )
this . lblUploaded . text ( value ) ;
visible = this . _ShowHideInfoItem ( this . lblUploaded , ! ! value ) || visible ;
2016-03-11 00:48:53 +00:00
} else
this . _ShowHideDocInfo ( false ) ;
2019-04-02 10:17:26 +00:00
$ ( 'tr.divider.general' , this . el ) [ visible ? 'show' : 'hide' ] ( ) ;
2018-11-06 09:58:02 +00:00
var appname = ( this . api ) ? this . api . asc _getAppProps ( ) : null ;
if ( appname ) {
appname = ( appname . asc _getApplication ( ) || '' ) + ' ' + ( appname . asc _getAppVersion ( ) || '' ) ;
this . lblApplication . text ( appname ) ;
2019-04-02 10:17:26 +00:00
}
2019-05-16 08:52:49 +00:00
this . _ShowHideInfoItem ( this . lblApplication , ! ! appname ) ;
2019-06-21 11:34:40 +00:00
this . coreProps = ( this . api ) ? this . api . asc _getCoreProps ( ) : null ;
if ( this . coreProps ) {
var value = this . coreProps . asc _getCreated ( ) ;
2019-04-02 10:17:26 +00:00
if ( value )
this . lblDate . text ( value . toLocaleString ( ) ) ;
this . _ShowHideInfoItem ( this . lblDate , ! ! value ) ;
2018-11-06 09:58:02 +00:00
}
2016-03-11 00:48:53 +00:00
} ,
2019-04-02 10:17:26 +00:00
updateFileInfo : function ( ) {
if ( ! this . rendered )
return ;
var me = this ,
2019-05-15 13:28:18 +00:00
props = ( this . api ) ? this . api . asc _getCoreProps ( ) : null ,
value ;
2019-06-21 11:34:40 +00:00
this . coreProps = props ;
2019-05-15 13:49:11 +00:00
// var app = (this.api) ? this.api.asc_getAppProps() : null;
// if (app) {
// value = app.asc_getTotalTime();
// if (value)
// this.lblEditTime.text(value + ' ' + this.txtMinutes);
// }
// this._ShowHideInfoItem(this.lblEditTime, !!value);
2019-05-15 13:28:18 +00:00
2019-04-02 10:17:26 +00:00
if ( props ) {
var visible = false ;
2019-05-15 13:28:18 +00:00
value = props . asc _getModified ( ) ;
2019-04-02 10:17:26 +00:00
if ( value )
this . lblModifyDate . text ( value . toLocaleString ( ) ) ;
2019-05-16 08:49:13 +00:00
visible = this . _ShowHideInfoItem ( this . lblModifyDate , ! ! value ) || visible ;
2019-04-02 10:17:26 +00:00
value = props . asc _getLastModifiedBy ( ) ;
if ( value )
this . lblModifyBy . text ( value ) ;
2019-05-16 08:49:13 +00:00
visible = this . _ShowHideInfoItem ( this . lblModifyBy , ! ! value ) || visible ;
2019-04-02 10:17:26 +00:00
$ ( 'tr.divider.modify' , this . el ) [ visible ? 'show' : 'hide' ] ( ) ;
value = props . asc _getTitle ( ) ;
this . inputTitle . setValue ( value || '' ) ;
value = props . asc _getSubject ( ) ;
this . inputSubject . setValue ( value || '' ) ;
value = props . asc _getDescription ( ) ;
this . inputComment . setValue ( value || '' ) ;
2019-09-06 14:38:29 +00:00
this . inputAuthor . setValue ( '' ) ;
2019-04-02 10:17:26 +00:00
this . tblAuthor . find ( 'tr:not(:last-of-type)' ) . remove ( ) ;
2019-06-21 11:34:40 +00:00
this . authors = [ ] ;
2019-05-15 13:28:18 +00:00
value = props . asc _getCreator ( ) ; //"123\"\"\"\<\>,456";
value && value . split ( /\s*[,;]\s*/ ) . forEach ( function ( item ) {
2019-04-02 10:17:26 +00:00
var div = $ ( Common . Utils . String . format ( me . authorTpl , Common . Utils . String . htmlEncode ( item ) ) ) ;
me . trAuthor . before ( div ) ;
2019-06-21 11:34:40 +00:00
me . authors . push ( item ) ;
2019-04-02 10:17:26 +00:00
} ) ;
2019-08-28 08:46:56 +00:00
this . tblAuthor . find ( '.close' ) . toggleClass ( 'hidden' , ! this . mode . isEdit ) ;
2019-04-02 10:17:26 +00:00
}
2019-08-28 08:46:56 +00:00
this . SetDisabled ( ) ;
2019-04-02 10:17:26 +00:00
} ,
_ShowHideInfoItem : function ( el , visible ) {
el . closest ( 'tr' ) [ visible ? 'show' : 'hide' ] ( ) ;
return visible ;
2016-03-11 00:48:53 +00:00
} ,
_ShowHideDocInfo : function ( visible ) {
2019-04-02 10:17:26 +00:00
this . _ShowHideInfoItem ( this . lblPlacement , visible ) ;
this . _ShowHideInfoItem ( this . lblOwner , visible ) ;
this . _ShowHideInfoItem ( this . lblUploaded , visible ) ;
2016-03-11 00:48:53 +00:00
} ,
updateStatisticInfo : function ( ) {
if ( this . api && this . doc ) {
this . api . startGetDocInfo ( ) ;
}
} ,
stopUpdatingStatisticInfo : function ( ) {
if ( this . api ) {
this . api . stopGetDocInfo ( ) ;
}
} ,
setApi : function ( o ) {
this . api = o ;
this . api . asc _registerCallback ( 'asc_onGetDocInfoStart' , _ . bind ( this . _onGetDocInfoStart , this ) ) ;
this . api . asc _registerCallback ( 'asc_onGetDocInfoStop' , _ . bind ( this . _onGetDocInfoEnd , this ) ) ;
this . api . asc _registerCallback ( 'asc_onDocInfo' , _ . bind ( this . _onDocInfo , this ) ) ;
this . api . asc _registerCallback ( 'asc_onGetDocInfoEnd' , _ . bind ( this . _onGetDocInfoEnd , this ) ) ;
2019-04-02 10:17:26 +00:00
// this.api.asc_registerCallback('asc_onDocumentName', _.bind(this.onDocumentName, this));
2019-06-21 12:14:24 +00:00
this . api . asc _registerCallback ( 'asc_onLockCore' , _ . bind ( this . onLockCore , this ) ) ;
2018-11-06 09:58:02 +00:00
this . updateInfo ( this . doc ) ;
2016-03-11 00:48:53 +00:00
return this ;
} ,
setMode : function ( mode ) {
2019-08-28 08:46:56 +00:00
this . mode = mode ;
this . inputAuthor . setVisible ( mode . isEdit ) ;
2019-09-06 14:38:29 +00:00
this . btnApply . setVisible ( mode . isEdit ) ;
2019-08-28 08:46:56 +00:00
this . tblAuthor . find ( '.close' ) . toggleClass ( 'hidden' , ! mode . isEdit ) ;
this . SetDisabled ( ) ;
2016-03-11 00:48:53 +00:00
return this ;
} ,
_onGetDocInfoStart : function ( ) {
var me = this ;
this . inProgress = true ;
this . infoObj = { PageCount : 0 , WordsCount : 0 , ParagraphCount : 0 , SymbolsCount : 0 , SymbolsWSCount : 0 } ;
_ . defer ( function ( ) {
if ( ! me . inProgress ) return ;
me . lblStatPages . text ( me . txtLoading ) ;
me . lblStatWords . text ( me . txtLoading ) ;
me . lblStatParagraphs . text ( me . txtLoading ) ;
me . lblStatSymbols . text ( me . txtLoading ) ;
me . lblStatSpaces . text ( me . txtLoading ) ;
} , 2000 ) ;
} ,
_onDocInfo : function ( obj ) {
if ( obj ) {
if ( obj . get _PageCount ( ) > - 1 )
this . infoObj . PageCount = obj . get _PageCount ( ) ;
if ( obj . get _WordsCount ( ) > - 1 )
this . infoObj . WordsCount = obj . get _WordsCount ( ) ;
if ( obj . get _ParagraphCount ( ) > - 1 )
this . infoObj . ParagraphCount = obj . get _ParagraphCount ( ) ;
if ( obj . get _SymbolsCount ( ) > - 1 )
this . infoObj . SymbolsCount = obj . get _SymbolsCount ( ) ;
if ( obj . get _SymbolsWSCount ( ) > - 1 )
this . infoObj . SymbolsWSCount = obj . get _SymbolsWSCount ( ) ;
}
} ,
_onGetDocInfoEnd : function ( ) {
this . inProgress = false ;
this . lblStatPages . text ( this . infoObj . PageCount ) ;
this . lblStatWords . text ( this . infoObj . WordsCount ) ;
this . lblStatParagraphs . text ( this . infoObj . ParagraphCount ) ;
this . lblStatSymbols . text ( this . infoObj . SymbolsCount ) ;
this . lblStatSpaces . text ( this . infoObj . SymbolsWSCount ) ;
} ,
onDocumentName : function ( name ) {
2019-05-16 12:59:39 +00:00
// this.lblTitle.text((name) ? name : '-');
2016-03-11 00:48:53 +00:00
} ,
2019-06-21 12:14:24 +00:00
onLockCore : function ( lock ) {
2019-08-28 08:46:56 +00:00
this . _locked = lock ;
this . updateFileInfo ( ) ;
} ,
SetDisabled : function ( ) {
var disable = ! this . mode . isEdit || this . _locked ;
this . inputTitle . setDisabled ( disable ) ;
this . inputSubject . setDisabled ( disable ) ;
this . inputComment . setDisabled ( disable ) ;
this . inputAuthor . setDisabled ( disable ) ;
this . tblAuthor . find ( '.close' ) . toggleClass ( 'disabled' , this . _locked ) ;
this . tblAuthor . toggleClass ( 'disabled' , disable ) ;
2019-09-06 14:38:29 +00:00
this . btnApply . setDisabled ( this . _locked ) ;
} ,
applySettings : function ( ) {
if ( this . coreProps && this . api ) {
this . coreProps . asc _putTitle ( this . inputTitle . getValue ( ) ) ;
this . coreProps . asc _putSubject ( this . inputSubject . getValue ( ) ) ;
this . coreProps . asc _putDescription ( this . inputComment . getValue ( ) ) ;
this . coreProps . asc _putCreator ( this . authors . join ( ';' ) ) ;
this . api . asc _setCoreProps ( this . coreProps ) ;
}
this . menu . hide ( ) ;
2019-06-21 12:14:24 +00:00
} ,
2019-05-15 11:17:29 +00:00
txtPlacement : 'Location' ,
txtOwner : 'Owner' ,
2019-04-02 10:17:26 +00:00
txtUploaded : 'Uploaded' ,
2016-03-11 00:48:53 +00:00
txtPages : 'Pages' ,
txtWords : 'Words' ,
txtParagraphs : 'Paragraphs' ,
txtSymbols : 'Symbols' ,
txtSpaces : 'Symbols with spaces' ,
2018-11-06 09:58:02 +00:00
txtLoading : 'Loading...' ,
2019-04-02 10:17:26 +00:00
txtAppName : 'Application' ,
txtEditTime : 'Total Editing time' ,
txtTitle : 'Title' ,
txtSubject : 'Subject' ,
txtComment : 'Comment' ,
txtModifyDate : 'Last Modified' ,
txtModifyBy : 'Last Modified By' ,
2019-05-16 08:49:13 +00:00
txtCreated : 'Created' ,
2019-04-02 10:17:26 +00:00
txtAuthor : 'Author' ,
2019-05-15 11:17:29 +00:00
txtAddAuthor : 'Add Author' ,
2019-05-15 13:28:18 +00:00
txtAddText : 'Add Text' ,
2019-09-06 14:38:29 +00:00
txtMinutes : 'min' ,
okButtonText : 'Apply'
2016-03-11 00:48:53 +00:00
} , DE . Views . FileMenuPanels . DocumentInfo || { } ) ) ;
DE . Views . FileMenuPanels . DocumentRights = Common . UI . BaseView . extend ( _ . extend ( {
el : '#panel-rights' ,
menu : undefined ,
initialize : function ( options ) {
Common . UI . BaseView . prototype . initialize . call ( this , arguments ) ;
this . rendered = false ;
this . template = _ . template ( [
'<table class="main">' ,
'<tr class="rights">' ,
'<td class="left" style="vertical-align: top;"><label>' + this . txtRights + '</label></td>' ,
'<td class="right"><div id="id-info-rights"></div></td>' ,
'</tr>' ,
'<tr class="edit-rights">' ,
'<td class="left"></td><td class="right"><button id="id-info-btn-edit" class="btn normal dlg-btn primary custom" style="margin-right: 10px;">' + this . txtBtnAccessRights + '</button></td>' ,
'</tr>' ,
'</table>'
] . join ( '' ) ) ;
this . templateRights = _ . template ( [
'<table>' ,
'<% _.each(users, function(item) { %>' ,
'<tr>' ,
'<td><span class="userLink img-commonctrl <% if (item.isLink) { %>sharedLink<% } %>"></span><span><%= Common.Utils.String.htmlEncode(item.user) %></span></td>' ,
'<td><%= Common.Utils.String.htmlEncode(item.permissions) %></td>' ,
'</tr>' ,
'<% }); %>' ,
'</table>'
] . join ( '' ) ) ;
this . menu = options . menu ;
} ,
2019-08-01 08:13:08 +00:00
render : function ( node ) {
var $markup = $ ( this . template ( ) ) ;
2016-03-11 00:48:53 +00:00
2019-08-01 08:13:08 +00:00
this . cntRights = $markup . findById ( '#id-info-rights' ) ;
2016-03-11 00:48:53 +00:00
this . btnEditRights = new Common . UI . Button ( {
2019-08-01 08:13:08 +00:00
el : $markup . elementById ( '#id-info-btn-edit' )
2016-03-11 00:48:53 +00:00
} ) ;
this . btnEditRights . on ( 'click' , _ . bind ( this . changeAccessRights , this ) ) ;
this . rendered = true ;
this . updateInfo ( this . doc ) ;
2019-08-01 08:50:22 +00:00
Common . NotificationCenter . on ( 'collaboration:sharing' , this . changeAccessRights . bind ( this ) ) ;
Common . NotificationCenter . on ( 'collaboration:sharingdeny' , this . onLostEditRights . bind ( this ) ) ;
this . $el = $ ( node ) . html ( $markup ) ;
2016-03-11 00:48:53 +00:00
if ( _ . isUndefined ( this . scroller ) ) {
this . scroller = new Common . UI . Scroller ( {
2019-08-01 08:50:22 +00:00
el : this . $el ,
2016-03-11 00:48:53 +00:00
suppressScrollX : true
} ) ;
}
return this ;
} ,
show : function ( ) {
Common . UI . BaseView . prototype . show . call ( this , arguments ) ;
} ,
hide : function ( ) {
Common . UI . BaseView . prototype . hide . call ( this , arguments ) ;
} ,
updateInfo : function ( doc ) {
this . doc = doc ;
if ( ! this . rendered )
return ;
doc = doc || { } ;
if ( doc . info ) {
if ( doc . info . sharingSettings )
this . cntRights . html ( this . templateRights ( { users : doc . info . sharingSettings } ) ) ;
this . _ShowHideInfoItem ( 'rights' , doc . info . sharingSettings !== undefined && doc . info . sharingSettings !== null && doc . info . sharingSettings . length > 0 ) ;
this . _ShowHideInfoItem ( 'edit-rights' , ! ! this . sharingSettingsUrl && this . sharingSettingsUrl . length && this . _readonlyRights !== true ) ;
} else
this . _ShowHideDocInfo ( false ) ;
} ,
_ShowHideInfoItem : function ( cls , visible ) {
$ ( 'tr.' + cls , this . el ) [ visible ? 'show' : 'hide' ] ( ) ;
} ,
_ShowHideDocInfo : function ( visible ) {
this . _ShowHideInfoItem ( 'rights' , visible ) ;
this . _ShowHideInfoItem ( 'edit-rights' , visible ) ;
} ,
setApi : function ( o ) {
this . api = o ;
return this ;
} ,
setMode : function ( mode ) {
this . sharingSettingsUrl = mode . sharingSettingsUrl ;
2019-04-23 12:02:42 +00:00
! ! this . sharingSettingsUrl && this . sharingSettingsUrl . length && Common . Gateway . on ( 'showsharingsettings' , _ . bind ( this . changeAccessRights , this ) ) ;
2019-07-11 15:00:11 +00:00
! ! this . sharingSettingsUrl && this . sharingSettingsUrl . length && Common . Gateway . on ( 'setsharingsettings' , _ . bind ( this . setSharingSettings , this ) ) ;
2016-03-11 00:48:53 +00:00
return this ;
} ,
changeAccessRights : function ( btn , event , opts ) {
2019-04-23 12:02:42 +00:00
if ( this . _docAccessDlg || this . _readonlyRights ) return ;
2016-03-11 00:48:53 +00:00
var me = this ;
me . _docAccessDlg = new Common . Views . DocumentAccessDialog ( {
settingsurl : this . sharingSettingsUrl
} ) ;
me . _docAccessDlg . on ( 'accessrights' , function ( obj , rights ) {
2019-07-11 15:00:11 +00:00
me . updateSharingSettings ( rights ) ;
2016-03-11 00:48:53 +00:00
} ) . on ( 'close' , function ( obj ) {
me . _docAccessDlg = undefined ;
} ) ;
me . _docAccessDlg . show ( ) ;
} ,
2019-07-11 15:00:11 +00:00
setSharingSettings : function ( data ) {
2019-07-12 07:43:02 +00:00
data && this . updateSharingSettings ( data . sharingSettings ) ;
2019-07-11 15:00:11 +00:00
} ,
updateSharingSettings : function ( rights ) {
this . doc . info . sharingSettings = rights ;
this . _ShowHideInfoItem ( 'rights' , this . doc . info . sharingSettings !== undefined && this . doc . info . sharingSettings !== null && this . doc . info . sharingSettings . length > 0 ) ;
this . cntRights . html ( this . templateRights ( { users : this . doc . info . sharingSettings } ) ) ;
Common . NotificationCenter . trigger ( 'mentions:clearusers' , this ) ;
} ,
2016-03-11 00:48:53 +00:00
onLostEditRights : function ( ) {
this . _readonlyRights = true ;
if ( ! this . rendered )
return ;
this . _ShowHideInfoItem ( 'edit-rights' , false ) ;
} ,
txtRights : 'Persons who have rights' ,
txtBtnAccessRights : 'Change access rights'
} , DE . Views . FileMenuPanels . DocumentRights || { } ) ) ;
DE . Views . FileMenuPanels . Help = Common . UI . BaseView . extend ( {
el : '#panel-help' ,
menu : undefined ,
template : _ . template ( [
'<div style="width:100%; height:100%; position: relative;">' ,
2018-01-15 14:08:35 +00:00
'<div id="id-help-contents" style="position: absolute; width:220px; top: 0; bottom: 0;" class="no-padding"></div>' ,
'<div id="id-help-frame" style="position: absolute; left: 220px; top: 0; right: 0; bottom: 0;" class="no-padding"></div>' ,
2016-03-11 00:48:53 +00:00
'</div>'
] . join ( '' ) ) ,
initialize : function ( options ) {
Common . UI . BaseView . prototype . initialize . call ( this , arguments ) ;
this . menu = options . menu ;
this . urlPref = 'resources/help/en/' ;
this . en _data = [
2018-01-15 14:32:17 +00:00
{ "src" : "ProgramInterface/ProgramInterface.htm" , "name" : "Introducing Document Editor user interface" , "headername" : "Program Interface" } ,
{ "src" : "ProgramInterface/FileTab.htm" , "name" : "File tab" } ,
{ "src" : "ProgramInterface/HomeTab.htm" , "name" : "Home Tab" } ,
{ "src" : "ProgramInterface/InsertTab.htm" , "name" : "Insert tab" } ,
{ "src" : "ProgramInterface/LayoutTab.htm" , "name" : "Layout tab" } ,
{ "src" : "ProgramInterface/ReviewTab.htm" , "name" : "Review tab" } ,
{ "src" : "ProgramInterface/PluginsTab.htm" , "name" : "Plugins tab" } ,
{ "src" : "UsageInstructions/ChangeColorScheme.htm" , "name" : "Change color scheme" , "headername" : "Basic operations" } ,
{ "src" : "UsageInstructions/CopyPasteUndoRedo.htm" , "name" : "Copy/paste text passages, undo/redo your actions" } ,
{ "src" : "UsageInstructions/OpenCreateNew.htm" , "name" : "Create a new document or open an existing one" } ,
{ "src" : "UsageInstructions/SetPageParameters.htm" , "name" : "Set page parameters" , "headername" : "Page formatting" } ,
{ "src" : "UsageInstructions/NonprintingCharacters.htm" , "name" : "Show/hide nonprinting characters" } ,
{ "src" : "UsageInstructions/SectionBreaks.htm" , "name" : "Insert section breaks" } ,
{ "src" : "UsageInstructions/InsertHeadersFooters.htm" , "name" : "Insert headers and footers" } ,
{ "src" : "UsageInstructions/InsertPageNumbers.htm" , "name" : "Insert page numbers" } ,
{ "src" : "UsageInstructions/InsertFootnotes.htm" , "name" : "Insert footnotes" } ,
{ "src" : "UsageInstructions/AlignText.htm" , "name" : "Align your text in a paragraph" , "headername" : "Paragraph formatting" } ,
{ "src" : "UsageInstructions/BackgroundColor.htm" , "name" : "Select background color for a paragraph" } ,
{ "src" : "UsageInstructions/ParagraphIndents.htm" , "name" : "Change paragraph indents" } ,
{ "src" : "UsageInstructions/LineSpacing.htm" , "name" : "Set paragraph line spacing" } ,
{ "src" : "UsageInstructions/PageBreaks.htm" , "name" : "Insert page breaks" } ,
{ "src" : "UsageInstructions/AddBorders.htm" , "name" : "Add borders" } ,
{ "src" : "UsageInstructions/SetTabStops.htm" , "name" : "Set tab stops" } ,
{ "src" : "UsageInstructions/CreateLists.htm" , "name" : "Create lists" } ,
{ "src" : "UsageInstructions/FormattingPresets.htm" , "name" : "Apply formatting styles" , "headername" : "Text formatting" } ,
{ "src" : "UsageInstructions/FontTypeSizeColor.htm" , "name" : "Set font type, size, and color" } ,
{ "src" : "UsageInstructions/DecorationStyles.htm" , "name" : "Apply font decoration styles" } ,
{ "src" : "UsageInstructions/CopyClearFormatting.htm" , "name" : "Copy/clear text formatting" } ,
{ "src" : "UsageInstructions/AddHyperlinks.htm" , "name" : "Add hyperlinks" } ,
{ "src" : "UsageInstructions/InsertDropCap.htm" , "name" : "Insert a drop cap" } ,
{ "src" : "UsageInstructions/InsertTables.htm" , "name" : "Insert tables" , "headername" : "Operations on objects" } ,
{ "src" : "UsageInstructions/InsertImages.htm" , "name" : "Insert images" } ,
{ "src" : "UsageInstructions/InsertAutoshapes.htm" , "name" : "Insert autoshapes" } ,
{ "src" : "UsageInstructions/InsertCharts.htm" , "name" : "Insert charts" } ,
{ "src" : "UsageInstructions/InsertTextObjects.htm" , "name" : "Insert text objects" } ,
{ "src" : "UsageInstructions/AlignArrangeObjects.htm" , "name" : "Align and arrange objects on a page" } ,
{ "src" : "UsageInstructions/ChangeWrappingStyle.htm" , "name" : "Change wrapping style" } ,
{ "src" : "UsageInstructions/UseMailMerge.htm" , "name" : "Use mail merge" , "headername" : "Mail Merge" } ,
{ "src" : "UsageInstructions/InsertEquation.htm" , "name" : "Insert equations" , "headername" : "Math equations" } ,
{ "src" : "HelpfulHints/CollaborativeEditing.htm" , "name" : "Collaborative document editing" , "headername" : "Document co-editing" } ,
{ "src" : "HelpfulHints/Review.htm" , "name" : "Document Review" } ,
{ "src" : "UsageInstructions/ViewDocInfo.htm" , "name" : "View document information" , "headername" : "Tools and settings" } ,
{ "src" : "UsageInstructions/SavePrintDownload.htm" , "name" : "Save/download/print your document" } ,
{ "src" : "HelpfulHints/AdvancedSettings.htm" , "name" : "Advanced settings of Document Editor" } ,
{ "src" : "HelpfulHints/Navigation.htm" , "name" : "View settings and navigation tools" } ,
{ "src" : "HelpfulHints/Search.htm" , "name" : "Search and replace function" } ,
{ "src" : "HelpfulHints/SpellChecking.htm" , "name" : "Spell-checking" } ,
{ "src" : "HelpfulHints/About.htm" , "name" : "About Document Editor" , "headername" : "Helpful hints" } ,
{ "src" : "HelpfulHints/SupportedFormats.htm" , "name" : "Supported formats of electronic documents" } ,
{ "src" : "HelpfulHints/KeyboardShortcuts.htm" , "name" : "Keyboard shortcuts" }
2016-03-11 00:48:53 +00:00
] ;
if ( Common . Utils . isIE ) {
window . onhelp = function ( ) { return false ; }
}
} ,
render : function ( ) {
var me = this ;
2019-08-22 14:41:41 +00:00
this . $el . html ( this . template ( ) ) ;
2016-03-11 00:48:53 +00:00
this . viewHelpPicker = new Common . UI . DataView ( {
el : $ ( '#id-help-contents' ) ,
store : new Common . UI . DataViewStore ( [ ] ) ,
keyMoveDirection : 'vertical' ,
itemTemplate : _ . template ( [
'<div id="<%= id %>" class="help-item-wrap">' ,
'<div class="caption"><%= name %></div>' ,
'</div>'
] . join ( '' ) )
} ) ;
this . viewHelpPicker . on ( 'item:add' , function ( dataview , itemview , record ) {
if ( record . has ( 'headername' ) ) {
$ ( itemview . el ) . before ( '<div class="header-name">' + record . get ( 'headername' ) + '</div>' ) ;
}
} ) ;
this . viewHelpPicker . on ( 'item:select' , function ( dataview , itemview , record ) {
me . iFrame . src = me . urlPref + record . get ( 'src' ) ;
} ) ;
this . iFrame = document . createElement ( 'iframe' ) ;
this . iFrame . src = "" ;
this . iFrame . align = "top" ;
this . iFrame . frameBorder = "0" ;
this . iFrame . width = "100%" ;
this . iFrame . height = "100%" ;
Common . Gateway . on ( 'internalcommand' , function ( data ) {
if ( data . type == 'help:hyperlink' ) {
var src = data . data ;
var rec = me . viewHelpPicker . store . find ( function ( record ) {
return ( src . indexOf ( record . get ( 'src' ) ) > 0 ) ;
} ) ;
if ( rec ) {
me . viewHelpPicker . selectRecord ( rec , true ) ;
me . viewHelpPicker . scrollToRecord ( rec ) ;
}
}
} ) ;
$ ( '#id-help-frame' ) . append ( this . iFrame ) ;
return this ;
} ,
setLangConfig : function ( lang ) {
var me = this ;
var store = this . viewHelpPicker . store ;
if ( lang ) {
2018-01-24 11:40:59 +00:00
lang = lang . split ( /[\-\_]/ ) [ 0 ] ;
2016-03-11 00:48:53 +00:00
var config = {
dataType : 'json' ,
error : function ( ) {
if ( me . urlPref . indexOf ( 'resources/help/en/' ) < 0 ) {
me . urlPref = 'resources/help/en/' ;
store . url = 'resources/help/en/Contents.json' ;
store . fetch ( config ) ;
} else {
me . urlPref = 'resources/help/en/' ;
store . reset ( me . en _data ) ;
}
} ,
success : function ( ) {
var rec = store . at ( 0 ) ;
me . viewHelpPicker . selectRecord ( rec ) ;
me . iFrame . src = me . urlPref + rec . get ( 'src' ) ;
}
} ;
store . url = 'resources/help/' + lang + '/Contents.json' ;
store . fetch ( config ) ;
this . urlPref = 'resources/help/' + lang + '/' ;
}
} ,
show : function ( url ) {
Common . UI . BaseView . prototype . show . call ( this ) ;
if ( ! this . _scrollerInited ) {
this . viewHelpPicker . scroller . update ( ) ;
this . _scrollerInited = true ;
}
if ( url ) {
var rec = this . viewHelpPicker . store . findWhere ( {
src : url
} ) ;
if ( rec ) {
this . viewHelpPicker . selectRecord ( rec ) ;
this . viewHelpPicker . scrollToRecord ( rec ) ;
}
}
}
} ) ;
2017-09-13 08:01:30 +00:00
DE . Views . FileMenuPanels . ProtectDoc = Common . UI . BaseView . extend ( _ . extend ( {
el : '#panel-protect' ,
menu : undefined ,
template : _ . template ( [
2017-11-15 12:52:37 +00:00
'<label id="id-fms-lbl-protect-header" style="font-size: 18px;"><%= scope.strProtect %></label>' ,
2017-11-16 09:43:21 +00:00
'<div id="id-fms-password">' ,
'<label class="header"><%= scope.strEncrypt %></label>' ,
'<div id="fms-btn-add-pwd" style="width:190px;"></div>' ,
'<table id="id-fms-view-pwd" cols="2" width="300">' ,
'<tr>' ,
2018-04-27 13:14:18 +00:00
'<td colspan="2"><label style="cursor: default;"><%= scope.txtEncrypted %></label></td>' ,
2017-11-16 09:43:21 +00:00
'</tr>' ,
'<tr>' ,
'<td><div id="fms-btn-change-pwd" style="width:190px;"></div></td>' ,
'<td align="right"><div id="fms-btn-delete-pwd" style="width:190px; margin-left:20px;"></div></td>' ,
'</tr>' ,
'</table>' ,
'</div>' ,
2017-11-15 12:52:37 +00:00
'<div id="id-fms-signature">' ,
'<label class="header"><%= scope.strSignature %></label>' ,
2017-11-16 09:43:21 +00:00
'<div id="fms-btn-invisible-sign" style="width:190px; margin-bottom: 20px;"></div>' ,
2017-11-15 12:52:37 +00:00
'<div id="id-fms-signature-view"></div>' ,
'</div>'
2017-09-13 08:01:30 +00:00
] . join ( '' ) ) ,
initialize : function ( options ) {
Common . UI . BaseView . prototype . initialize . call ( this , arguments ) ;
this . menu = options . menu ;
2017-09-13 08:14:25 +00:00
2017-11-15 12:52:37 +00:00
var me = this ;
this . templateSignature = _ . template ( [
'<table cols="2" width="300" class="<% if (!hasRequested && !hasSigned) { %>hidden<% } %>"">' ,
2017-05-24 11:55:18 +00:00
'<tr>' ,
2018-04-27 13:14:18 +00:00
'<td colspan="2"><label style="cursor: default;"><%= tipText %></label></td>' ,
2017-05-24 11:55:18 +00:00
'</tr>' ,
'<tr>' ,
2017-11-15 12:52:37 +00:00
'<td><label class="link signature-view-link">' + me . txtView + '</label></td>' ,
'<td align="right"><label class="link signature-edit-link <% if (!hasSigned) { %>hidden<% } %>">' + me . txtEdit + '</label></td>' ,
2017-05-24 11:55:18 +00:00
'</tr>' ,
2017-09-13 08:14:25 +00:00
'</table>'
] . join ( '' ) ) ;
2017-09-13 08:01:30 +00:00
} ,
render : function ( ) {
2019-08-22 14:41:41 +00:00
this . $el . html ( this . template ( { scope : this } ) ) ;
2017-09-13 08:01:30 +00:00
2017-11-15 12:52:37 +00:00
var protection = DE . getController ( 'Common.Controllers.Protection' ) . getView ( ) ;
2017-11-16 09:43:21 +00:00
this . btnAddPwd = protection . getButton ( 'add-password' ) ;
this . btnAddPwd . render ( this . $el . find ( '#fms-btn-add-pwd' ) ) ;
this . btnAddPwd . on ( 'click' , _ . bind ( this . closeMenu , this ) ) ;
this . btnChangePwd = protection . getButton ( 'change-password' ) ;
this . btnChangePwd . render ( this . $el . find ( '#fms-btn-change-pwd' ) ) ;
this . btnChangePwd . on ( 'click' , _ . bind ( this . closeMenu , this ) ) ;
this . btnDeletePwd = protection . getButton ( 'del-password' ) ;
this . btnDeletePwd . render ( this . $el . find ( '#fms-btn-delete-pwd' ) ) ;
this . btnDeletePwd . on ( 'click' , _ . bind ( this . closeMenu , this ) ) ;
2018-08-01 16:08:24 +00:00
this . cntPassword = $ ( '#id-fms-password' ) ;
this . cntPasswordView = $ ( '#id-fms-view-pwd' ) ;
2017-11-16 09:43:21 +00:00
2017-11-15 12:52:37 +00:00
this . btnAddInvisibleSign = protection . getButton ( 'signature' ) ;
this . btnAddInvisibleSign . render ( this . $el . find ( '#fms-btn-invisible-sign' ) ) ;
this . btnAddInvisibleSign . on ( 'click' , _ . bind ( this . closeMenu , this ) ) ;
2017-09-13 08:14:25 +00:00
2017-11-15 12:52:37 +00:00
this . cntSignature = $ ( '#id-fms-signature' ) ;
this . cntSignatureView = $ ( '#id-fms-signature-view' ) ;
2017-09-13 08:01:30 +00:00
if ( _ . isUndefined ( this . scroller ) ) {
this . scroller = new Common . UI . Scroller ( {
2019-08-01 08:50:22 +00:00
el : this . $el ,
2017-09-13 08:01:30 +00:00
suppressScrollX : true
} ) ;
}
2017-11-15 12:52:37 +00:00
this . $el . on ( 'click' , '.signature-edit-link' , _ . bind ( this . onEdit , this ) ) ;
this . $el . on ( 'click' , '.signature-view-link' , _ . bind ( this . onView , this ) ) ;
2017-09-13 08:01:30 +00:00
return this ;
} ,
show : function ( ) {
Common . UI . BaseView . prototype . show . call ( this , arguments ) ;
2017-09-13 08:14:25 +00:00
this . updateSignatures ( ) ;
2017-11-16 09:43:21 +00:00
this . updateEncrypt ( ) ;
2017-09-13 08:01:30 +00:00
} ,
setMode : function ( mode ) {
this . mode = mode ;
2018-08-01 16:08:24 +00:00
this . cntSignature . toggleClass ( 'hidden' , ! this . mode . isSignatureSupport ) ;
this . cntPassword . toggleClass ( 'hidden' , ! this . mode . isPasswordSupport ) ;
2017-09-13 08:01:30 +00:00
} ,
2017-09-13 08:14:25 +00:00
setApi : function ( o ) {
this . api = o ;
return this ;
} ,
2017-11-15 12:52:37 +00:00
closeMenu : function ( ) {
this . menu && this . menu . hide ( ) ;
} ,
onEdit : function ( ) {
this . menu && this . menu . hide ( ) ;
var me = this ;
Common . UI . warning ( {
title : this . notcriticalErrorTitle ,
msg : this . txtEditWarning ,
buttons : [ 'ok' , 'cancel' ] ,
primary : 'ok' ,
callback : function ( btn ) {
if ( btn == 'ok' ) {
2017-11-16 09:43:21 +00:00
me . api . asc _RemoveAllSignatures ( ) ;
2017-11-15 12:52:37 +00:00
}
}
} ) ;
2017-09-13 08:01:30 +00:00
} ,
2017-11-15 12:52:37 +00:00
onView : function ( ) {
this . menu && this . menu . hide ( ) ;
2017-11-16 14:03:05 +00:00
DE . getController ( 'RightMenu' ) . rightmenu . SetActivePane ( Common . Utils . documentSettingsType . Signature , true ) ;
2017-09-13 08:01:30 +00:00
} ,
2017-09-13 08:14:25 +00:00
updateSignatures : function ( ) {
2017-05-22 10:33:13 +00:00
var requested = this . api . asc _getRequestSignatures ( ) ,
2017-05-23 08:55:06 +00:00
valid = this . api . asc _getSignatures ( ) ,
2017-11-15 12:52:37 +00:00
hasRequested = requested && requested . length > 0 ,
hasValid = false ,
hasInvalid = false ;
2017-05-23 08:55:06 +00:00
_ . each ( valid , function ( item , index ) {
2017-11-15 12:52:37 +00:00
if ( item . asc _getValid ( ) == 0 )
hasValid = true ;
else
hasInvalid = true ;
2017-05-23 08:55:06 +00:00
} ) ;
2017-11-08 14:52:03 +00:00
2017-11-15 12:52:37 +00:00
// hasRequested = true;
// hasValid = true;
// hasInvalid = true;
2017-11-08 14:52:03 +00:00
2017-11-15 12:52:37 +00:00
var tipText = ( hasInvalid ) ? this . txtSignedInvalid : ( hasValid ? this . txtSigned : "" ) ;
if ( hasRequested )
tipText = this . txtRequestedSignatures + ( tipText != "" ? "<br><br>" : "" ) + tipText ;
2017-11-08 14:52:03 +00:00
2017-11-15 12:52:37 +00:00
this . cntSignatureView . html ( this . templateSignature ( { tipText : tipText , hasSigned : ( hasValid || hasInvalid ) , hasRequested : hasRequested } ) ) ;
2017-09-13 08:14:25 +00:00
} ,
2017-11-16 09:43:21 +00:00
updateEncrypt : function ( ) {
2018-08-01 16:08:24 +00:00
this . cntPasswordView . toggleClass ( 'hidden' , this . btnAddPwd . isVisible ( ) ) ;
2017-11-16 09:43:21 +00:00
} ,
2017-09-13 08:01:30 +00:00
strProtect : 'Protect Document' ,
2017-12-06 11:37:06 +00:00
strSignature : 'With Signature' ,
2017-11-15 12:52:37 +00:00
txtView : 'View signatures' ,
txtEdit : 'Edit document' ,
txtSigned : 'Valid signatures has been added to the document. The document is protected from editing.' ,
txtSignedInvalid : 'Some of the digital signatures in document are invalid or could not be verified. The document is protected from editing.' ,
txtRequestedSignatures : 'This document needs to be signed.' ,
notcriticalErrorTitle : 'Warning' ,
2017-11-16 09:43:21 +00:00
txtEditWarning : 'Editing will remove the signatures from the document.<br>Are you sure you want to continue?' ,
2017-12-06 11:37:06 +00:00
strEncrypt : 'With Password' ,
2017-11-16 09:43:21 +00:00
txtEncrypted : 'This document has been protected by password'
2017-09-13 08:01:30 +00:00
} , DE . Views . FileMenuPanels . ProtectDoc || { } ) ) ;
2016-03-11 00:48:53 +00:00
} ) ;