Merge branch 'feature/transitions' into develop
|
@ -214,6 +214,9 @@ define([
|
||||||
|
|
||||||
me.trigger('render:after', me);
|
me.trigger('render:after', me);
|
||||||
}
|
}
|
||||||
|
if (this.disabled) {
|
||||||
|
this.setDisabled(!!this.disabled);
|
||||||
|
}
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
},
|
},
|
||||||
|
|
|
@ -239,6 +239,10 @@
|
||||||
&:not(:first-child) {
|
&:not(:first-child) {
|
||||||
margin-top: 6px;
|
margin-top: 6px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&.font-normal {
|
||||||
|
.font-size-normal();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.separator {
|
.separator {
|
||||||
|
|
|
@ -162,6 +162,7 @@ require([
|
||||||
,'Common.Controllers.ExternalDiagramEditor'
|
,'Common.Controllers.ExternalDiagramEditor'
|
||||||
,'Common.Controllers.ReviewChanges'
|
,'Common.Controllers.ReviewChanges'
|
||||||
,'Common.Controllers.Protection'
|
,'Common.Controllers.Protection'
|
||||||
|
,'Transitions'
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -197,6 +198,7 @@ require([
|
||||||
,'common/main/lib/controller/Protection'
|
,'common/main/lib/controller/Protection'
|
||||||
,'common/main/lib/controller/Themes'
|
,'common/main/lib/controller/Themes'
|
||||||
,'common/main/lib/controller/Desktop'
|
,'common/main/lib/controller/Desktop'
|
||||||
|
,'presentationeditor/main/app/controller/Transitions'
|
||||||
], function() {
|
], function() {
|
||||||
app.start();
|
app.start();
|
||||||
});
|
});
|
||||||
|
|
|
@ -137,8 +137,8 @@ define([
|
||||||
if (settingsType==Common.Utils.documentSettingsType.Slide) {
|
if (settingsType==Common.Utils.documentSettingsType.Slide) {
|
||||||
this._settings[settingsType].locked = value.get_LockDelete();
|
this._settings[settingsType].locked = value.get_LockDelete();
|
||||||
this._settings[settingsType].lockedBackground = value.get_LockBackground();
|
this._settings[settingsType].lockedBackground = value.get_LockBackground();
|
||||||
this._settings[settingsType].lockedEffects = value.get_LockTransition();
|
/*this._settings[settingsType].lockedEffects = value.get_LockTransition();
|
||||||
this._settings[settingsType].lockedTransition = value.get_LockTransition();
|
this._settings[settingsType].lockedTransition = value.get_LockTransition();*/
|
||||||
this._settings[settingsType].lockedHeader = !!value.get_LockHeader && value.get_LockHeader();
|
this._settings[settingsType].lockedHeader = !!value.get_LockHeader && value.get_LockHeader();
|
||||||
} else {
|
} else {
|
||||||
this._settings[settingsType].locked = value.get_Locked();
|
this._settings[settingsType].locked = value.get_Locked();
|
||||||
|
@ -182,8 +182,6 @@ define([
|
||||||
if (i == Common.Utils.documentSettingsType.Slide) {
|
if (i == Common.Utils.documentSettingsType.Slide) {
|
||||||
if (pnl.locked!==undefined)
|
if (pnl.locked!==undefined)
|
||||||
this.rightmenu.slideSettings.setLocked(this._state.no_slides || pnl.lockedBackground || pnl.locked,
|
this.rightmenu.slideSettings.setLocked(this._state.no_slides || pnl.lockedBackground || pnl.locked,
|
||||||
this._state.no_slides || pnl.lockedEffects || pnl.locked,
|
|
||||||
this._state.no_slides || pnl.lockedTransition || pnl.locked,
|
|
||||||
this._state.no_slides || pnl.lockedHeader || pnl.locked);
|
this._state.no_slides || pnl.lockedHeader || pnl.locked);
|
||||||
} else
|
} else
|
||||||
pnl.panel.setLocked(pnl.locked);
|
pnl.panel.setLocked(pnl.locked);
|
||||||
|
@ -220,7 +218,7 @@ define([
|
||||||
SetDisabled: function(disabled, allowSignature) {
|
SetDisabled: function(disabled, allowSignature) {
|
||||||
this.setMode({isEdit: !disabled});
|
this.setMode({isEdit: !disabled});
|
||||||
if (this.rightmenu && this.rightmenu.paragraphSettings) {
|
if (this.rightmenu && this.rightmenu.paragraphSettings) {
|
||||||
this.rightmenu.slideSettings.SetSlideDisabled(disabled, disabled, disabled, disabled);
|
this.rightmenu.slideSettings.SetSlideDisabled(disabled, disabled);
|
||||||
this.rightmenu.paragraphSettings.disableControls(disabled);
|
this.rightmenu.paragraphSettings.disableControls(disabled);
|
||||||
this.rightmenu.shapeSettings.disableControls(disabled);
|
this.rightmenu.shapeSettings.disableControls(disabled);
|
||||||
this.rightmenu.textartSettings.disableControls(disabled);
|
this.rightmenu.textartSettings.disableControls(disabled);
|
||||||
|
|
|
@ -106,6 +106,7 @@ define([
|
||||||
me.btnSpelling.render( me.statusbar.$el.find('#btn-doc-spell') );
|
me.btnSpelling.render( me.statusbar.$el.find('#btn-doc-spell') );
|
||||||
me.btnDocLang = review.getButton('doclang', 'statusbar');
|
me.btnDocLang = review.getButton('doclang', 'statusbar');
|
||||||
me.btnDocLang.render( me.statusbar.$el.find('#btn-doc-lang') );
|
me.btnDocLang.render( me.statusbar.$el.find('#btn-doc-lang') );
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
me.statusbar.$el.find('.el-edit, .el-review').hide();
|
me.statusbar.$el.find('.el-edit, .el-review').hide();
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,6 +52,7 @@ define([
|
||||||
'common/main/lib/view/SymbolTableDialog',
|
'common/main/lib/view/SymbolTableDialog',
|
||||||
'common/main/lib/util/define',
|
'common/main/lib/util/define',
|
||||||
'presentationeditor/main/app/collection/SlideThemes',
|
'presentationeditor/main/app/collection/SlideThemes',
|
||||||
|
'presentationeditor/main/app/controller/Transitions',
|
||||||
'presentationeditor/main/app/view/Toolbar',
|
'presentationeditor/main/app/view/Toolbar',
|
||||||
'presentationeditor/main/app/view/DateTimeDialog',
|
'presentationeditor/main/app/view/DateTimeDialog',
|
||||||
'presentationeditor/main/app/view/HeaderFooterDialog',
|
'presentationeditor/main/app/view/HeaderFooterDialog',
|
||||||
|
@ -2399,20 +2400,25 @@ define([
|
||||||
} else
|
} else
|
||||||
if ( config.customization && config.customization.compactToolbar )
|
if ( config.customization && config.customization.compactToolbar )
|
||||||
compactview = true;
|
compactview = true;
|
||||||
}
|
|
||||||
|
|
||||||
|
}
|
||||||
me.toolbar.render(_.extend({compactview: compactview}, config));
|
me.toolbar.render(_.extend({compactview: compactview}, config));
|
||||||
|
|
||||||
var tab = {action: 'review', caption: me.toolbar.textTabCollaboration};
|
var tab = {action: 'review', caption: me.toolbar.textTabCollaboration};
|
||||||
var $panel = me.getApplication().getController('Common.Controllers.ReviewChanges').createToolbarPanel();
|
var $panel = me.getApplication().getController('Common.Controllers.ReviewChanges').createToolbarPanel();
|
||||||
if ( $panel ) {
|
if ( $panel ) {
|
||||||
me.toolbar.addTab(tab, $panel, 3);
|
me.toolbar.addTab(tab, $panel, 4);
|
||||||
me.toolbar.setVisible('review', config.isEdit || config.canViewReview || config.canCoAuthoring && config.canComments);
|
me.toolbar.setVisible('review', config.isEdit || config.canViewReview || config.canCoAuthoring && config.canComments);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( config.isEdit ) {
|
if ( config.isEdit ) {
|
||||||
me.toolbar.setMode(config);
|
me.toolbar.setMode(config);
|
||||||
|
|
||||||
|
var transitController = me.getApplication().getController('Transitions');
|
||||||
|
transitController.setApi(me.api).setConfig({toolbar: me,mode:config}).createToolbarPanel();
|
||||||
|
Array.prototype.push.apply(me.toolbar.lockControls,transitController.getView().getButtons());
|
||||||
|
Array.prototype.push.apply(me.toolbar.slideOnlyControls,transitController.getView().getButtons());
|
||||||
|
|
||||||
me.toolbar.btnSave.on('disabled', _.bind(me.onBtnChangeState, me, 'save:disabled'));
|
me.toolbar.btnSave.on('disabled', _.bind(me.onBtnChangeState, me, 'save:disabled'));
|
||||||
|
|
||||||
if (!(config.customization && config.customization.compactHeader)) {
|
if (!(config.customization && config.customization.compactHeader)) {
|
||||||
|
@ -2458,6 +2464,7 @@ define([
|
||||||
if (btn.cmpEl.closest('#review-changes-panel').length>0)
|
if (btn.cmpEl.closest('#review-changes-panel').length>0)
|
||||||
btn.setCaption(me.toolbar.capBtnAddComment);
|
btn.setCaption(me.toolbar.capBtnAddComment);
|
||||||
}, this);
|
}, this);
|
||||||
|
|
||||||
this.toolbar.lockToolbar(PE.enumLock.noSlides, this._state.no_slides, { array: this.btnsComment });
|
this.toolbar.lockToolbar(PE.enumLock.noSlides, this._state.no_slides, { array: this.btnsComment });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
294
apps/presentationeditor/main/app/controller/Transitions.js
Normal file
|
@ -0,0 +1,294 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2019
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha
|
||||||
|
* street, Riga, Latvia, EU, LV-1050.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* Transitions.js
|
||||||
|
*
|
||||||
|
* Created by Olga.Transitions on 15.07.21
|
||||||
|
* Copyright (c) 2021 Ascensio System SIA. All rights reserved.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
define([
|
||||||
|
'core',
|
||||||
|
'jquery',
|
||||||
|
'underscore',
|
||||||
|
'backbone',
|
||||||
|
'presentationeditor/main/app/view/Transitions'
|
||||||
|
], function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
PE.Controllers.Transitions = Backbone.Controller.extend(_.extend({
|
||||||
|
models : [],
|
||||||
|
collections : [],
|
||||||
|
views : [
|
||||||
|
'PE.Views.Transitions'
|
||||||
|
],
|
||||||
|
options: {
|
||||||
|
alias: 'Transitions'
|
||||||
|
},
|
||||||
|
sdkViewName : '#id_main',
|
||||||
|
|
||||||
|
initialize: function () {
|
||||||
|
|
||||||
|
this.addListeners({
|
||||||
|
'PE.Views.Transitions': {
|
||||||
|
'transit:preview': _.bind(this.onPreviewClick, this),
|
||||||
|
'transit:parameters': _.bind(this.onParameterClick, this),
|
||||||
|
'transit:duration': _.bind(this.onDurationChange, this),
|
||||||
|
'transit:applytoall': _.bind(this.onApplyToAllClick, this),
|
||||||
|
'transit:selecteffect': _.bind(this.onEffectSelect, this),
|
||||||
|
'transit:startonclick': _.bind(this.onStartOnClickChange, this),
|
||||||
|
'transit:delay': _.bind(this.onDelayChange, this),
|
||||||
|
'transit:checkdelay': _.bind(this.onCheckDelayChange, this)
|
||||||
|
},
|
||||||
|
'Toolbar': {
|
||||||
|
'tab:active': _.bind(this.onActiveTab, this)
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
|
onLaunch: function () {
|
||||||
|
this._state = {};
|
||||||
|
},
|
||||||
|
|
||||||
|
setConfig: function (config) {
|
||||||
|
this.appConfig = config.mode;
|
||||||
|
|
||||||
|
this.view = this.createView('PE.Views.Transitions', {
|
||||||
|
toolbar: config.toolbar,
|
||||||
|
mode: config.mode
|
||||||
|
});
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
setApi: function (api) {
|
||||||
|
this.api = api;
|
||||||
|
this.api.asc_registerCallback('asc_onFocusObject', _.bind(this.onFocusObject, this));
|
||||||
|
this.api.asc_registerCallback('asc_onCountPages', _.bind(this.onApiCountPages, this));
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
onApiCountPages: function (count) {
|
||||||
|
if (this._state.no_slides !== (count<=0)) {
|
||||||
|
this._state.no_slides = (count<=0);
|
||||||
|
this.lockToolbar(PE.enumLock.noSlides, this._state.no_slides);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
createToolbarPanel: function() {
|
||||||
|
return this.view.getPanel();
|
||||||
|
},
|
||||||
|
|
||||||
|
getView: function(name) {
|
||||||
|
return !name && this.view ?
|
||||||
|
this.view : Backbone.Controller.prototype.getView.call(this, name);
|
||||||
|
},
|
||||||
|
|
||||||
|
onPreviewClick: function() {
|
||||||
|
if (this.api) {
|
||||||
|
this.api.SlideTransitionPlay();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onParameterClick: function (item) {
|
||||||
|
this.EffectType = item.value;
|
||||||
|
if (this.api && !this._noApply) {
|
||||||
|
var props = new Asc.CAscSlideProps();
|
||||||
|
var transition = new Asc.CAscSlideTransition();
|
||||||
|
transition.put_TransitionType(this.Effect);
|
||||||
|
transition.put_TransitionOption(this.EffectType);
|
||||||
|
props.put_transition(transition);
|
||||||
|
this.api.SetSlideProps(props);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onDurationChange: function(field, newValue, oldValue, eOpts) {
|
||||||
|
if (this.api && !this._noApply) {
|
||||||
|
var props = new Asc.CAscSlideProps();
|
||||||
|
var transition = new Asc.CAscSlideTransition();
|
||||||
|
transition.put_TransitionDuration(field.getNumberValue()*1000);
|
||||||
|
props.put_transition(transition);
|
||||||
|
this.api.SetSlideProps(props);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onStartOnClickChange: function(field, newValue, oldValue, eOpts) {
|
||||||
|
if (this.api && !this._noApply) {
|
||||||
|
var props = new Asc.CAscSlideProps();
|
||||||
|
var transition = new Asc.CAscSlideTransition();
|
||||||
|
transition.put_SlideAdvanceOnMouseClick(field.getValue() == 'checked');
|
||||||
|
props.put_transition(transition);
|
||||||
|
this.api.SetSlideProps(props);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onDelayChange: function(field, newValue, oldValue, eOpts) {
|
||||||
|
if (this.api && !this._noApply) {
|
||||||
|
var props = new Asc.CAscSlideProps();
|
||||||
|
var transition = new Asc.CAscSlideTransition();
|
||||||
|
transition.put_SlideAdvanceDuration(field.getNumberValue()*1000);
|
||||||
|
props.put_transition(transition);
|
||||||
|
this.api.SetSlideProps(props);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onCheckDelayChange: function(field, newValue, oldValue, eOpts) {
|
||||||
|
this.view.numDelay.setDisabled(field.getValue() !== 'checked');
|
||||||
|
if (this.api && !this._noApply) {
|
||||||
|
var props = new Asc.CAscSlideProps();
|
||||||
|
var transition = new Asc.CAscSlideTransition();
|
||||||
|
transition.put_SlideAdvanceAfter(field.getValue() == 'checked');
|
||||||
|
props.put_transition(transition);
|
||||||
|
this.api.SetSlideProps(props);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onApplyToAllClick: function () {
|
||||||
|
if (this.api) this.api.SlideTransitionApplyToAll();
|
||||||
|
},
|
||||||
|
|
||||||
|
onEffectSelect: function (combo, record) {
|
||||||
|
var type = record.get('value');
|
||||||
|
|
||||||
|
if (this.Effect !== type &&
|
||||||
|
!((this.Effect === Asc.c_oAscSlideTransitionTypes.Wipe || this.Effect === Asc.c_oAscSlideTransitionTypes.UnCover || this.Effect === Asc.c_oAscSlideTransitionTypes.Cover)&&
|
||||||
|
(type === Asc.c_oAscSlideTransitionTypes.Wipe || type === Asc.c_oAscSlideTransitionTypes.UnCover || type === Asc.c_oAscSlideTransitionTypes.Cover))) {
|
||||||
|
var parameter = this.view.setMenuParameters(type);
|
||||||
|
if (parameter)
|
||||||
|
this.onParameterClick(parameter);
|
||||||
|
}
|
||||||
|
this.Effect = type;
|
||||||
|
|
||||||
|
if (this.api && !this._noApply) {
|
||||||
|
var props = new Asc.CAscSlideProps();
|
||||||
|
var transition = new Asc.CAscSlideTransition();
|
||||||
|
transition.put_TransitionType(type);
|
||||||
|
transition.put_TransitionOption(this.EffectType);
|
||||||
|
props.put_transition(transition);
|
||||||
|
this.api.SetSlideProps(props);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onFocusObject: function(selectedObjects) {
|
||||||
|
var me = this;
|
||||||
|
|
||||||
|
for (var i = 0; i<selectedObjects.length; i++) {
|
||||||
|
var eltype = selectedObjects[i].get_ObjectType();
|
||||||
|
|
||||||
|
if (eltype === undefined)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (eltype == Asc.c_oAscTypeSelectElement.Slide) {
|
||||||
|
var locked_transition = undefined,
|
||||||
|
pr = selectedObjects[i].get_ObjectValue();
|
||||||
|
locked_transition = pr.get_LockTransition();
|
||||||
|
|
||||||
|
if (locked_transition !== undefined && me._state.lockedtransition !== locked_transition)
|
||||||
|
if (me.view.toolbar._state.activated) me._state.lockedtransition = locked_transition;
|
||||||
|
|
||||||
|
this.loadSettings(pr);
|
||||||
|
|
||||||
|
if (this._state.onactivetab) {
|
||||||
|
this.setLocked();
|
||||||
|
this.setSettings();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
loadSettings: function (props) {
|
||||||
|
var transition = props.get_transition();
|
||||||
|
|
||||||
|
if (transition) {
|
||||||
|
this._state.Effect = transition.get_TransitionType();
|
||||||
|
this._state.EffectType = transition.get_TransitionOption();
|
||||||
|
|
||||||
|
var value = transition.get_TransitionDuration();
|
||||||
|
if (Math.abs(this._state.Duration - value) > 0.001 ||
|
||||||
|
(this._state.Duration === null || value === null) && (this._state.Duration !== value) ||
|
||||||
|
(this._state.Duration === undefined || value === undefined) && (this._state.Duration !== value)) {
|
||||||
|
this._state.Duration = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
value = transition.get_SlideAdvanceDuration();
|
||||||
|
if (Math.abs(this._state.Delay - value) > 0.001 ||
|
||||||
|
(this._state.Delay === null || value === null) && (this._state.Delay !== value) ||
|
||||||
|
(this._state.Delay === undefined || value === undefined) && (this._state.Delay !== value)) {
|
||||||
|
this._state.Delay = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
this._state.OnMouseClick = transition.get_SlideAdvanceOnMouseClick();
|
||||||
|
this._state.AdvanceAfter = transition.get_SlideAdvanceAfter();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
onActiveTab: function(tab) {
|
||||||
|
if (tab == 'transit') {
|
||||||
|
this._state.onactivetab = true;
|
||||||
|
this.setLocked();
|
||||||
|
this.setSettings();
|
||||||
|
}
|
||||||
|
else this._state.onactivetab = false;
|
||||||
|
},
|
||||||
|
|
||||||
|
lockToolbar: function (causes, lock, opts) {
|
||||||
|
Common.Utils.lockControls(causes, lock, opts, this.view.lockedControls);
|
||||||
|
},
|
||||||
|
|
||||||
|
setLocked: function() {
|
||||||
|
if (this._state.lockedtransition != undefined)
|
||||||
|
this.lockToolbar(PE.enumLock.transitLock, this._state.lockedtransition);
|
||||||
|
},
|
||||||
|
|
||||||
|
setSettings: function () {
|
||||||
|
var me = this.view;
|
||||||
|
|
||||||
|
if (this._state.Effect !== undefined) {
|
||||||
|
var item = me.listEffects.store.findWhere({value: this._state.Effect});
|
||||||
|
me.listEffects.menuPicker.selectRecord(item ? item : me.listEffects.menuPicker.items[0]);
|
||||||
|
this.view.btnParameters.setIconCls('toolbar__icon icon ' + item.get('imageUrl'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (me.btnParameters.menu.items.length > 0 && this._state.EffectType !== undefined)
|
||||||
|
me.setMenuParameters(this._state.Effect, this._state.EffectType);
|
||||||
|
|
||||||
|
me.numDuration.setValue((this._state.Duration !== null && this._state.Duration !== undefined) ? this._state.Duration / 1000. : '', true);
|
||||||
|
me.numDelay.setValue((this._state.Delay !== null && this._state.Delay !== undefined) ? this._state.Delay / 1000. : '', true);
|
||||||
|
me.chStartOnClick.setValue((this._state.OnMouseClick !== null && this._state.OnMouseClick !== undefined) ? this._state.OnMouseClick : 'indeterminate', true);
|
||||||
|
me.chDelay.setValue((this._state.AdvanceAfter !== null && this._state.AdvanceAfter !== undefined) ? this._state.AdvanceAfter : 'indeterminate', true);
|
||||||
|
me.numDelay.setDisabled(me.chDelay.getValue() !== 'checked' || me.chDelay.disabled);
|
||||||
|
}
|
||||||
|
|
||||||
|
}, PE.Controllers.Transitions || {}));
|
||||||
|
});
|
|
@ -117,57 +117,6 @@
|
||||||
<div class="separator horizontal"></div>
|
<div class="separator horizontal"></div>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
|
||||||
<td>
|
|
||||||
<label class="header"><%= scope.strEffect %></label>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td class="padding-small">
|
|
||||||
<div id="slide-combo-effect-name" style="width: 100%;"></div>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td class="padding-small">
|
|
||||||
<div id="slide-combo-effect-type" style="width: 100%;"></div>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td class="padding-small">
|
|
||||||
<div>
|
|
||||||
<label class="input-label" style="margin-top:4px;"><%= scope.strDuration %></label>
|
|
||||||
<div id="slide-spin-duration" style="display: inline-block; float:right;"></div>
|
|
||||||
</div>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td class="padding-large">
|
|
||||||
<button type="button" class="btn btn-text-default" id="slide-button-preview" style="width:100%;" data-hint="1" data-hint-direction="bottom" data-hint-offset="big"><%= scope.textPreview %></button>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td class="padding-small">
|
|
||||||
<div id="slide-checkbox-start-click"></div>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td class="padding-large">
|
|
||||||
<div>
|
|
||||||
<div id="slide-checkbox-delay" style="display: inline-block; width: 100px; margin-top:4px;"></div>
|
|
||||||
<div id="slide-spin-delay" style="display: inline-block; float:right;"></div>
|
|
||||||
</div>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td class="padding-small">
|
|
||||||
<button type="button" class="btn btn-text-default" id="slide-button-apply-all" style="width:100%;" data-hint="1" data-hint-direction="bottom" data-hint-offset="big"><%= scope.textApplyAll %></button>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td class="padding-small">
|
|
||||||
<div class="separator horizontal"></div>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
<tr>
|
||||||
<td class="padding-small">
|
<td class="padding-small">
|
||||||
<div id="slide-checkbox-slidenum"></div>
|
<div id="slide-checkbox-slidenum"></div>
|
||||||
|
|
|
@ -142,6 +142,42 @@
|
||||||
<span class="btn-slot text x-huge" id="slot-btn-insvideo"></span>
|
<span class="btn-slot text x-huge" id="slot-btn-insvideo"></span>
|
||||||
</div>
|
</div>
|
||||||
</section>
|
</section>
|
||||||
|
<section id="transitions-panel" class="panel" data-tab="transit">
|
||||||
|
<div class="group flex small" id="transit-field-effects" style="width: 700px; max-width: 700px; min-width: 140px;" data-group-width="700px"></div>
|
||||||
|
|
||||||
|
<div class="group small">
|
||||||
|
<span class="btn-slot text x-huge" id="transit-button-parameters"></span>
|
||||||
|
</div>
|
||||||
|
<div class="separator long"></div>
|
||||||
|
<div class="group small">
|
||||||
|
<div class="elset font-normal">
|
||||||
|
<label id="transit-duration"></label>
|
||||||
|
<span id="transit-spin-duration" class="btn-slot text spinner"></span>
|
||||||
|
</div>
|
||||||
|
<div class="elset">
|
||||||
|
<span class="btn-slot text" id="transit-button-preview"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="separator long"></div>
|
||||||
|
<div class="group small">
|
||||||
|
<div class="elset">
|
||||||
|
<span class="btn-slot text" id="transit-checkbox-startonclick"></span>
|
||||||
|
</div>
|
||||||
|
<div class="elset font-normal">
|
||||||
|
<span class="btn-slot text" id="transit-checkbox-delay"></span>
|
||||||
|
<div id="transit-spin-delay" class="btn-slot text spinner"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="separator long"></div>
|
||||||
|
<div class="group small">
|
||||||
|
<div class="elset">
|
||||||
|
<span class="btn-slot text " id="transit-button-apply"></span>
|
||||||
|
</div>
|
||||||
|
<div class="elset">
|
||||||
|
<span class="btn-slot text x-huge"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
</section>
|
</section>
|
||||||
</section>
|
</section>
|
||||||
</div>
|
</div>
|
|
@ -79,8 +79,6 @@ define([
|
||||||
|
|
||||||
this._locked = {
|
this._locked = {
|
||||||
background: false,
|
background: false,
|
||||||
effects: false,
|
|
||||||
transition: false,
|
|
||||||
header: false
|
header: false
|
||||||
};
|
};
|
||||||
this._stateDisabled = {};
|
this._stateDisabled = {};
|
||||||
|
@ -188,141 +186,6 @@ define([
|
||||||
this.FillGradientContainer = $('#slide-panel-gradient-fill');
|
this.FillGradientContainer = $('#slide-panel-gradient-fill');
|
||||||
this.TransparencyContainer = $('#slide-panel-transparent-fill');
|
this.TransparencyContainer = $('#slide-panel-transparent-fill');
|
||||||
|
|
||||||
this._arrEffectName = [
|
|
||||||
{displayValue: this.textNone, value: Asc.c_oAscSlideTransitionTypes.None},
|
|
||||||
{displayValue: this.textFade, value: Asc.c_oAscSlideTransitionTypes.Fade},
|
|
||||||
{displayValue: this.textPush, value: Asc.c_oAscSlideTransitionTypes.Push},
|
|
||||||
{displayValue: this.textWipe, value: Asc.c_oAscSlideTransitionTypes.Wipe},
|
|
||||||
{displayValue: this.textSplit, value: Asc.c_oAscSlideTransitionTypes.Split},
|
|
||||||
{displayValue: this.textUnCover, value: Asc.c_oAscSlideTransitionTypes.UnCover},
|
|
||||||
{displayValue: this.textCover, value: Asc.c_oAscSlideTransitionTypes.Cover},
|
|
||||||
{displayValue: this.textClock, value: Asc.c_oAscSlideTransitionTypes.Clock},
|
|
||||||
{displayValue: this.textZoom, value: Asc.c_oAscSlideTransitionTypes.Zoom}
|
|
||||||
];
|
|
||||||
|
|
||||||
this.cmbEffectName = new Common.UI.ComboBox({
|
|
||||||
el: $('#slide-combo-effect-name'),
|
|
||||||
cls: 'input-group-nr',
|
|
||||||
style: 'width: 100%;',
|
|
||||||
menuStyle: 'min-width: 100%;',
|
|
||||||
editable: false,
|
|
||||||
data: this._arrEffectName,
|
|
||||||
disabled: true,
|
|
||||||
dataHint: '1',
|
|
||||||
dataHintDirection: 'bottom',
|
|
||||||
dataHintOffset: 'big'
|
|
||||||
});
|
|
||||||
this.cmbEffectName.setValue('');
|
|
||||||
this.cmbEffectName.on('selected', _.bind(this.onEffectNameSelect, this));
|
|
||||||
|
|
||||||
this._arrEffectType = [
|
|
||||||
{displayValue: this.textSmoothly, value: Asc.c_oAscSlideTransitionParams.Fade_Smoothly},
|
|
||||||
{displayValue: this.textBlack, value: Asc.c_oAscSlideTransitionParams.Fade_Through_Black},
|
|
||||||
{displayValue: this.textLeft, value: Asc.c_oAscSlideTransitionParams.Param_Left},
|
|
||||||
{displayValue: this.textTop, value: Asc.c_oAscSlideTransitionParams.Param_Top},
|
|
||||||
{displayValue: this.textRight, value: Asc.c_oAscSlideTransitionParams.Param_Right},
|
|
||||||
{displayValue: this.textBottom, value: Asc.c_oAscSlideTransitionParams.Param_Bottom},
|
|
||||||
{displayValue: this.textTopLeft, value: Asc.c_oAscSlideTransitionParams.Param_TopLeft},
|
|
||||||
{displayValue: this.textTopRight, value: Asc.c_oAscSlideTransitionParams.Param_TopRight},
|
|
||||||
{displayValue: this.textBottomLeft, value: Asc.c_oAscSlideTransitionParams.Param_BottomLeft},
|
|
||||||
{displayValue: this.textBottomRight, value: Asc.c_oAscSlideTransitionParams.Param_BottomRight},
|
|
||||||
{displayValue: this.textVerticalIn, value: Asc.c_oAscSlideTransitionParams.Split_VerticalIn},
|
|
||||||
{displayValue: this.textVerticalOut, value: Asc.c_oAscSlideTransitionParams.Split_VerticalOut},
|
|
||||||
{displayValue: this.textHorizontalIn, value: Asc.c_oAscSlideTransitionParams.Split_HorizontalIn},
|
|
||||||
{displayValue: this.textHorizontalOut, value: Asc.c_oAscSlideTransitionParams.Split_HorizontalOut},
|
|
||||||
{displayValue: this.textClockwise, value: Asc.c_oAscSlideTransitionParams.Clock_Clockwise},
|
|
||||||
{displayValue: this.textCounterclockwise, value: Asc.c_oAscSlideTransitionParams.Clock_Counterclockwise},
|
|
||||||
{displayValue: this.textWedge, value: Asc.c_oAscSlideTransitionParams.Clock_Wedge},
|
|
||||||
{displayValue: this.textZoomIn, value: Asc.c_oAscSlideTransitionParams.Zoom_In},
|
|
||||||
{displayValue: this.textZoomOut, value: Asc.c_oAscSlideTransitionParams.Zoom_Out},
|
|
||||||
{displayValue: this.textZoomRotate, value: Asc.c_oAscSlideTransitionParams.Zoom_AndRotate}
|
|
||||||
];
|
|
||||||
|
|
||||||
this.cmbEffectType = new Common.UI.ComboBox({
|
|
||||||
el: $('#slide-combo-effect-type'),
|
|
||||||
cls: 'input-group-nr',
|
|
||||||
style: 'width: 100%;',
|
|
||||||
menuStyle: 'min-width: 100%;',
|
|
||||||
editable: false,
|
|
||||||
data: this._arrEffectType,
|
|
||||||
disabled: true,
|
|
||||||
dataHint: '1',
|
|
||||||
dataHintDirection: 'bottom',
|
|
||||||
dataHintOffset: 'big'
|
|
||||||
});
|
|
||||||
this.cmbEffectType.setValue('');
|
|
||||||
this.cmbEffectType.on('selected', _.bind(this.onEffectTypeSelect, this));
|
|
||||||
|
|
||||||
this.numDuration = new Common.UI.MetricSpinner({
|
|
||||||
el: $('#slide-spin-duration'),
|
|
||||||
step: 1,
|
|
||||||
width: 70,
|
|
||||||
value: '',
|
|
||||||
defaultUnit : this.textSec,
|
|
||||||
maxValue: 300,
|
|
||||||
minValue: 0,
|
|
||||||
disabled: true,
|
|
||||||
dataHint: '1',
|
|
||||||
dataHintDirection: 'bottom',
|
|
||||||
dataHintOffset: 'big'
|
|
||||||
});
|
|
||||||
this.numDuration.on('change', _.bind(this.onDurationChange, this));
|
|
||||||
this.numDuration.on('inputleave', function(){ me.fireEvent('editcomplete', me);});
|
|
||||||
|
|
||||||
this.numDelay = new Common.UI.MetricSpinner({
|
|
||||||
el: $('#slide-spin-delay'),
|
|
||||||
step: 1,
|
|
||||||
width: 70,
|
|
||||||
value: '',
|
|
||||||
defaultUnit : this.textSec,
|
|
||||||
maxValue: 300,
|
|
||||||
minValue: 0,
|
|
||||||
disabled: true,
|
|
||||||
dataHint: '1',
|
|
||||||
dataHintDirection: 'bottom',
|
|
||||||
dataHintOffset: 'big'
|
|
||||||
});
|
|
||||||
this.numDelay.on('change', _.bind(this.onDelayChange, this));
|
|
||||||
this.numDelay.on('inputleave', function(){ me.fireEvent('editcomplete', me);});
|
|
||||||
|
|
||||||
this.chStartOnClick = new Common.UI.CheckBox({
|
|
||||||
el: $('#slide-checkbox-start-click'),
|
|
||||||
labelText: this.strStartOnClick,
|
|
||||||
disabled: true,
|
|
||||||
dataHint: '1',
|
|
||||||
dataHintDirection: 'left',
|
|
||||||
dataHintOffset: 'small'
|
|
||||||
});
|
|
||||||
this.chStartOnClick.on('change', _.bind(this.onStartOnClickChange, this));
|
|
||||||
|
|
||||||
this.chDelay = new Common.UI.CheckBox({
|
|
||||||
el: $('#slide-checkbox-delay'),
|
|
||||||
labelText: this.strDelay,
|
|
||||||
disabled: true,
|
|
||||||
dataHint: '1',
|
|
||||||
dataHintDirection: 'left',
|
|
||||||
dataHintOffset: 'small'
|
|
||||||
});
|
|
||||||
this.chDelay.on('change', _.bind(this.onCheckDelayChange, this));
|
|
||||||
|
|
||||||
this.btnPreview = new Common.UI.Button({
|
|
||||||
el: $('#slide-button-preview'),
|
|
||||||
disabled: true
|
|
||||||
});
|
|
||||||
this.btnPreview.on('click', _.bind(function(btn){
|
|
||||||
if (this.api) this.api.SlideTransitionPlay();
|
|
||||||
this.fireEvent('editcomplete', this);
|
|
||||||
}, this));
|
|
||||||
|
|
||||||
this.btnApplyToAll = new Common.UI.Button({
|
|
||||||
el: $('#slide-button-apply-all'),
|
|
||||||
disabled: true
|
|
||||||
});
|
|
||||||
this.btnApplyToAll.on('click', _.bind(function(btn){
|
|
||||||
if (this.api) this.api.SlideTransitionApplyToAll();
|
|
||||||
this.fireEvent('editcomplete', this);
|
|
||||||
}, this));
|
|
||||||
|
|
||||||
this.chSlideNum = new Common.UI.CheckBox({
|
this.chSlideNum = new Common.UI.CheckBox({
|
||||||
el: $('#slide-checkbox-slidenum'),
|
el: $('#slide-checkbox-slidenum'),
|
||||||
labelText: this.strSlideNum,
|
labelText: this.strSlideNum,
|
||||||
|
@ -1158,122 +1021,6 @@ define([
|
||||||
this.fireEvent('editcomplete', this);
|
this.fireEvent('editcomplete', this);
|
||||||
},
|
},
|
||||||
|
|
||||||
fillEffectTypeCombo: function (type) {
|
|
||||||
var arr = [];
|
|
||||||
switch (type) {
|
|
||||||
case Asc.c_oAscSlideTransitionTypes.Fade:
|
|
||||||
arr.push(this._arrEffectType[0], this._arrEffectType[1]);
|
|
||||||
break;
|
|
||||||
case Asc.c_oAscSlideTransitionTypes.Push:
|
|
||||||
arr = this._arrEffectType.slice(2, 6);
|
|
||||||
break;
|
|
||||||
case Asc.c_oAscSlideTransitionTypes.Wipe:
|
|
||||||
arr = this._arrEffectType.slice(2, 10);
|
|
||||||
break;
|
|
||||||
case Asc.c_oAscSlideTransitionTypes.Split:
|
|
||||||
arr = this._arrEffectType.slice(10, 14);
|
|
||||||
break;
|
|
||||||
case Asc.c_oAscSlideTransitionTypes.UnCover:
|
|
||||||
arr = this._arrEffectType.slice(2, 10);
|
|
||||||
break;
|
|
||||||
case Asc.c_oAscSlideTransitionTypes.Cover:
|
|
||||||
arr = this._arrEffectType.slice(2, 10);
|
|
||||||
break;
|
|
||||||
case Asc.c_oAscSlideTransitionTypes.Clock:
|
|
||||||
arr = this._arrEffectType.slice(14, 17);
|
|
||||||
break;
|
|
||||||
case Asc.c_oAscSlideTransitionTypes.Zoom:
|
|
||||||
arr = this._arrEffectType.slice(17);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (arr.length>0) {
|
|
||||||
this.cmbEffectType.store.reset(arr);
|
|
||||||
this.cmbEffectType.setValue(arr[0].value);
|
|
||||||
this.EffectType = arr[0].value;
|
|
||||||
} else {
|
|
||||||
this.cmbEffectType.store.reset();
|
|
||||||
this.EffectType = undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.cmbEffectType.setDisabled(arr.length<1 || this._locked.effects);
|
|
||||||
this.numDuration.setDisabled(arr.length<1 || this._locked.effects);
|
|
||||||
this.btnPreview.setDisabled(arr.length<1 || this._locked.effects);
|
|
||||||
},
|
|
||||||
|
|
||||||
onEffectNameSelect: function(combo, record) {
|
|
||||||
var type = record.value;
|
|
||||||
if (this.Effect !== type &&
|
|
||||||
!((this.Effect===Asc.c_oAscSlideTransitionTypes.Wipe || this.Effect===Asc.c_oAscSlideTransitionTypes.UnCover || this.Effect===Asc.c_oAscSlideTransitionTypes.Cover)&&
|
|
||||||
(type===Asc.c_oAscSlideTransitionTypes.Wipe || type===Asc.c_oAscSlideTransitionTypes.UnCover || type===Asc.c_oAscSlideTransitionTypes.Cover)) )
|
|
||||||
this.fillEffectTypeCombo(type);
|
|
||||||
this.Effect = type;
|
|
||||||
if (this.api && !this._noApply) {
|
|
||||||
var props = new Asc.CAscSlideProps();
|
|
||||||
var transition = new Asc.CAscSlideTransition();
|
|
||||||
transition.put_TransitionType(type);
|
|
||||||
transition.put_TransitionOption(this.EffectType);
|
|
||||||
props.put_transition(transition);
|
|
||||||
this.api.SetSlideProps(props);
|
|
||||||
}
|
|
||||||
this.fireEvent('editcomplete', this);
|
|
||||||
},
|
|
||||||
|
|
||||||
onEffectTypeSelect: function(combo, record) {
|
|
||||||
this.EffectType = record.value;
|
|
||||||
if (this.api && !this._noApply) {
|
|
||||||
var props = new Asc.CAscSlideProps();
|
|
||||||
var transition = new Asc.CAscSlideTransition();
|
|
||||||
transition.put_TransitionType(this.Effect);
|
|
||||||
transition.put_TransitionOption(this.EffectType);
|
|
||||||
props.put_transition(transition);
|
|
||||||
this.api.SetSlideProps(props);
|
|
||||||
}
|
|
||||||
this.fireEvent('editcomplete', this);
|
|
||||||
},
|
|
||||||
|
|
||||||
onDurationChange: function(field, newValue, oldValue, eOpts){
|
|
||||||
if (this.api && !this._noApply) {
|
|
||||||
var props = new Asc.CAscSlideProps();
|
|
||||||
var transition = new Asc.CAscSlideTransition();
|
|
||||||
transition.put_TransitionDuration(field.getNumberValue()*1000);
|
|
||||||
props.put_transition(transition);
|
|
||||||
this.api.SetSlideProps(props);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
onDelayChange: function(field, newValue, oldValue, eOpts){
|
|
||||||
if (this.api && !this._noApply) {
|
|
||||||
var props = new Asc.CAscSlideProps();
|
|
||||||
var transition = new Asc.CAscSlideTransition();
|
|
||||||
transition.put_SlideAdvanceDuration(field.getNumberValue()*1000);
|
|
||||||
props.put_transition(transition);
|
|
||||||
this.api.SetSlideProps(props);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
onStartOnClickChange: function(field, newValue, oldValue, eOpts){
|
|
||||||
if (this.api && !this._noApply) {
|
|
||||||
var props = new Asc.CAscSlideProps();
|
|
||||||
var transition = new Asc.CAscSlideTransition();
|
|
||||||
transition.put_SlideAdvanceOnMouseClick(field.getValue()=='checked');
|
|
||||||
props.put_transition(transition);
|
|
||||||
this.api.SetSlideProps(props);
|
|
||||||
}
|
|
||||||
this.fireEvent('editcomplete', this);
|
|
||||||
},
|
|
||||||
|
|
||||||
onCheckDelayChange: function(field, newValue, oldValue, eOpts){
|
|
||||||
this.numDelay.setDisabled(field.getValue()!=='checked');
|
|
||||||
if (this.api && !this._noApply) {
|
|
||||||
var props = new Asc.CAscSlideProps();
|
|
||||||
var transition = new Asc.CAscSlideTransition();
|
|
||||||
transition.put_SlideAdvanceAfter(field.getValue()=='checked');
|
|
||||||
props.put_transition(transition);
|
|
||||||
this.api.SetSlideProps(props);
|
|
||||||
}
|
|
||||||
this.fireEvent('editcomplete', this);
|
|
||||||
},
|
|
||||||
|
|
||||||
onHeaderChange: function(type, field, newValue, oldValue, eOpts){
|
onHeaderChange: function(type, field, newValue, oldValue, eOpts){
|
||||||
if (this.api && !this._noApply) {
|
if (this.api && !this._noApply) {
|
||||||
var props = this.api.asc_getHeaderFooterProperties();
|
var props = this.api.asc_getHeaderFooterProperties();
|
||||||
|
@ -1341,7 +1088,7 @@ define([
|
||||||
ChangeSettings: function(props) {
|
ChangeSettings: function(props) {
|
||||||
if (this._initSettings)
|
if (this._initSettings)
|
||||||
this.createDelayedElements();
|
this.createDelayedElements();
|
||||||
this.SetSlideDisabled(this._locked.background, this._locked.effects, this._locked.transition, this._locked.header);
|
this.SetSlideDisabled(this._locked.background, this._locked.header);
|
||||||
|
|
||||||
if (props)
|
if (props)
|
||||||
{
|
{
|
||||||
|
@ -1538,65 +1285,6 @@ define([
|
||||||
this._state.SlideColor = this.SlideColor.Color;
|
this._state.SlideColor = this.SlideColor.Color;
|
||||||
}
|
}
|
||||||
|
|
||||||
var transition = props.get_transition();
|
|
||||||
if (transition) {
|
|
||||||
var value = transition.get_TransitionType();
|
|
||||||
var found = false;
|
|
||||||
if (this._state.Effect !== value) {
|
|
||||||
var item = this.cmbEffectName.store.findWhere({value: value});
|
|
||||||
if (item) {
|
|
||||||
found = true;
|
|
||||||
this.cmbEffectName.setValue(item.get('value'));
|
|
||||||
} else
|
|
||||||
this.cmbEffectName.setValue('');
|
|
||||||
|
|
||||||
this.fillEffectTypeCombo((found) ? value : undefined);
|
|
||||||
this.Effect = value;
|
|
||||||
this._state.Effect = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
value = transition.get_TransitionOption();
|
|
||||||
if (this._state.EffectType !== value || found) {
|
|
||||||
found = false;
|
|
||||||
item = this.cmbEffectType.store.findWhere({value: value});
|
|
||||||
if (item) {
|
|
||||||
found = true;
|
|
||||||
this.cmbEffectType.setValue(item.get('value'));
|
|
||||||
} else
|
|
||||||
this.cmbEffectType.setValue('');
|
|
||||||
|
|
||||||
this._state.EffectType = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
value = transition.get_TransitionDuration();
|
|
||||||
if ( Math.abs(this._state.Duration-value)>0.001 ||
|
|
||||||
(this._state.Duration===null || value===null)&&(this._state.Duration!==value) ||
|
|
||||||
(this._state.Duration===undefined || value===undefined)&&(this._state.Duration!==value) ) {
|
|
||||||
this.numDuration.setValue((value !== null && value !== undefined) ? value/1000. : '', true);
|
|
||||||
this._state.Duration=value;
|
|
||||||
}
|
|
||||||
|
|
||||||
value = transition.get_SlideAdvanceDuration();
|
|
||||||
if ( Math.abs(this._state.Delay-value)>0.001 ||
|
|
||||||
(this._state.Delay===null || value===null)&&(this._state.Delay!==value) ||
|
|
||||||
(this._state.Delay===undefined || value===undefined)&&(this._state.Delay!==value) ) {
|
|
||||||
this.numDelay.setValue((value !== null && value !== undefined) ? value/1000. : '', true);
|
|
||||||
this._state.Delay=value;
|
|
||||||
}
|
|
||||||
|
|
||||||
value = transition.get_SlideAdvanceOnMouseClick();
|
|
||||||
if ( this._state.OnMouseClick!==value ) {
|
|
||||||
this.chStartOnClick.setValue((value !== null && value !== undefined) ? value : 'indeterminate', true);
|
|
||||||
this._state.OnMouseClick=value;
|
|
||||||
}
|
|
||||||
value = transition.get_SlideAdvanceAfter();
|
|
||||||
if ( this._state.AdvanceAfter!==value ) {
|
|
||||||
this.chDelay.setValue((value !== null && value !== undefined) ? value : 'indeterminate', true);
|
|
||||||
this.numDelay.setDisabled(this.chDelay.getValue()!=='checked');
|
|
||||||
this._state.AdvanceAfter=value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// pattern colors
|
// pattern colors
|
||||||
type1 = typeof(this.FGColor.Color);
|
type1 = typeof(this.FGColor.Color);
|
||||||
type2 = typeof(this._state.FGColor);
|
type2 = typeof(this._state.FGColor);
|
||||||
|
@ -1683,15 +1371,15 @@ define([
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
setLocked: function (background, effects, transition, header) {
|
setLocked: function (background, header) {
|
||||||
this._locked = {
|
this._locked = {
|
||||||
background: background, effects: effects, transition: transition, header: header
|
background: background, header: header
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
SetSlideDisabled: function(background, effects, transition, header) {
|
SetSlideDisabled: function(background, header) {
|
||||||
this._locked = {
|
this._locked = {
|
||||||
background: background, effects: effects, transition: transition, header: header
|
background: background, header: header
|
||||||
};
|
};
|
||||||
if (this._initSettings) return;
|
if (this._initSettings) return;
|
||||||
|
|
||||||
|
@ -1705,21 +1393,6 @@ define([
|
||||||
this.numGradientAngle.setDisabled(background || this.GradFillType !== Asc.c_oAscFillGradType.GRAD_LINEAR);
|
this.numGradientAngle.setDisabled(background || this.GradFillType !== Asc.c_oAscFillGradType.GRAD_LINEAR);
|
||||||
this._stateDisabled.background = background;
|
this._stateDisabled.background = background;
|
||||||
}
|
}
|
||||||
if (effects !== this._stateDisabled.effects) {
|
|
||||||
var length = this.cmbEffectType.store.length;
|
|
||||||
this.cmbEffectName.setDisabled(effects);
|
|
||||||
this.cmbEffectType.setDisabled(length<1 || effects);
|
|
||||||
this.numDuration.setDisabled(length<1 || effects);
|
|
||||||
this.btnPreview.setDisabled(length<1 || effects);
|
|
||||||
this._stateDisabled.effects = effects;
|
|
||||||
}
|
|
||||||
if (transition !== this._stateDisabled.transition) {
|
|
||||||
this.chStartOnClick.setDisabled(transition);
|
|
||||||
this.chDelay.setDisabled(transition);
|
|
||||||
this.numDelay.setDisabled(transition || this.chDelay.getValue()!=='checked');
|
|
||||||
this.btnApplyToAll.setDisabled(transition);
|
|
||||||
this._stateDisabled.transition = transition;
|
|
||||||
}
|
|
||||||
if (header !== this._stateDisabled.header) {
|
if (header !== this._stateDisabled.header) {
|
||||||
this.chSlideNum.setDisabled(header);
|
this.chSlideNum.setDisabled(header);
|
||||||
this.chDateTime.setDisabled(header);
|
this.chDateTime.setDisabled(header);
|
||||||
|
@ -1821,41 +1494,6 @@ define([
|
||||||
textAdvanced : 'Show advanced settings',
|
textAdvanced : 'Show advanced settings',
|
||||||
textNoFill : 'No Fill',
|
textNoFill : 'No Fill',
|
||||||
textSelectTexture : 'Select',
|
textSelectTexture : 'Select',
|
||||||
textNone: 'None',
|
|
||||||
textFade: 'Fade',
|
|
||||||
textPush: 'Push',
|
|
||||||
textWipe: 'Wipe',
|
|
||||||
textSplit: 'Split',
|
|
||||||
textUnCover: 'UnCover',
|
|
||||||
textCover: 'Cover',
|
|
||||||
textClock: 'Clock',
|
|
||||||
textZoom: 'Zoom',
|
|
||||||
textSmoothly: 'Smoothly',
|
|
||||||
textBlack: 'Through Black',
|
|
||||||
textLeft: 'Left',
|
|
||||||
textTop: 'Top',
|
|
||||||
textRight: 'Right',
|
|
||||||
textBottom: 'Bottom',
|
|
||||||
textTopLeft: 'Top-Left',
|
|
||||||
textTopRight: 'Top-Right',
|
|
||||||
textBottomLeft: 'Bottom-Left',
|
|
||||||
textBottomRight: 'Bottom-Right',
|
|
||||||
textVerticalIn: 'Vertical In',
|
|
||||||
textVerticalOut: 'Vertical Out',
|
|
||||||
textHorizontalIn: 'Horizontal In',
|
|
||||||
textHorizontalOut: 'Horizontal Out',
|
|
||||||
textClockwise: 'Clockwise',
|
|
||||||
textCounterclockwise: 'Counterclockwise',
|
|
||||||
textWedge: 'Wedge',
|
|
||||||
textZoomIn: 'Zoom In',
|
|
||||||
textZoomOut: 'Zoom Out',
|
|
||||||
textZoomRotate: 'Zoom and Rotate',
|
|
||||||
strStartOnClick: 'Start On Click',
|
|
||||||
strDelay: 'Delay',
|
|
||||||
textApplyAll: 'Apply to All Slides',
|
|
||||||
textPreview: 'Preview',
|
|
||||||
strEffect: 'Effect',
|
|
||||||
strDuration: 'Duration',
|
|
||||||
textGradientFill: 'Gradient Fill',
|
textGradientFill: 'Gradient Fill',
|
||||||
textPatternFill: 'Pattern',
|
textPatternFill: 'Pattern',
|
||||||
strBackground: 'Background color',
|
strBackground: 'Background color',
|
||||||
|
@ -1867,7 +1505,6 @@ define([
|
||||||
textDirection: 'Direction',
|
textDirection: 'Direction',
|
||||||
textStyle: 'Style',
|
textStyle: 'Style',
|
||||||
textGradient: 'Gradient Points',
|
textGradient: 'Gradient Points',
|
||||||
textSec: 's',
|
|
||||||
strSlideNum: 'Show Slide Number',
|
strSlideNum: 'Show Slide Number',
|
||||||
strDateTime: 'Show Date and Time',
|
strDateTime: 'Show Date and Time',
|
||||||
textFromStorage: 'From Storage',
|
textFromStorage: 'From Storage',
|
||||||
|
|
|
@ -82,7 +82,8 @@ define([
|
||||||
noTextSelected: 'no-text',
|
noTextSelected: 'no-text',
|
||||||
inEquation: 'in-equation',
|
inEquation: 'in-equation',
|
||||||
commentLock: 'can-comment',
|
commentLock: 'can-comment',
|
||||||
noColumns: 'no-columns'
|
noColumns: 'no-columns',
|
||||||
|
transitLock: 'transit-lock'
|
||||||
};
|
};
|
||||||
|
|
||||||
PE.Views.Toolbar = Common.UI.Mixtbar.extend(_.extend((function(){
|
PE.Views.Toolbar = Common.UI.Mixtbar.extend(_.extend((function(){
|
||||||
|
@ -129,7 +130,8 @@ define([
|
||||||
tabs: [
|
tabs: [
|
||||||
{caption: me.textTabFile, action: 'file', extcls: 'canedit', haspanel:false},
|
{caption: me.textTabFile, action: 'file', extcls: 'canedit', haspanel:false},
|
||||||
{caption: me.textTabHome, action: 'home', extcls: 'canedit'},
|
{caption: me.textTabHome, action: 'home', extcls: 'canedit'},
|
||||||
{caption: me.textTabInsert, action: 'ins', extcls: 'canedit'}
|
{caption: me.textTabInsert, action: 'ins', extcls: 'canedit'},
|
||||||
|
{caption: me.textTabTransitions, action: 'transit', extcls: 'canedit'}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
@ -1096,6 +1098,7 @@ define([
|
||||||
me.isCompactView = mode.compactview;
|
me.isCompactView = mode.compactview;
|
||||||
if ( mode.isEdit ) {
|
if ( mode.isEdit ) {
|
||||||
me.$el.html(me.rendererComponents(me.$layout));
|
me.$el.html(me.rendererComponents(me.$layout));
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
me.$layout.find('.canedit').hide();
|
me.$layout.find('.canedit').hide();
|
||||||
me.$layout.addClass('folded');
|
me.$layout.addClass('folded');
|
||||||
|
@ -1110,10 +1113,12 @@ define([
|
||||||
Common.UI.Mixtbar.prototype.onResize.apply(me, arguments);
|
Common.UI.Mixtbar.prototype.onResize.apply(me, arguments);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
//_.bind(function (element){
|
||||||
|
//},me);
|
||||||
if ( mode.isEdit ) {
|
if ( mode.isEdit ) {
|
||||||
me.setTab('home');
|
me.setTab('home');
|
||||||
me.processPanelVisible();
|
me.processPanelVisible();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( me.isCompactView )
|
if ( me.isCompactView )
|
||||||
|
@ -1143,7 +1148,6 @@ define([
|
||||||
var _injectComponent = function (id, cmp) {
|
var _injectComponent = function (id, cmp) {
|
||||||
Common.Utils.injectComponent($host.find(id), cmp);
|
Common.Utils.injectComponent($host.find(id), cmp);
|
||||||
};
|
};
|
||||||
|
|
||||||
_injectComponent('#slot-field-fontname', this.cmbFontName);
|
_injectComponent('#slot-field-fontname', this.cmbFontName);
|
||||||
_injectComponent('#slot-field-fontsize', this.cmbFontSize);
|
_injectComponent('#slot-field-fontsize', this.cmbFontSize);
|
||||||
_injectComponent('#slot-btn-changeslide', this.btnChangeSlide);
|
_injectComponent('#slot-btn-changeslide', this.btnChangeSlide);
|
||||||
|
@ -1921,7 +1925,8 @@ define([
|
||||||
mniToggleCase: 'tOGGLE cASE',
|
mniToggleCase: 'tOGGLE cASE',
|
||||||
strMenuNoFill: 'No Fill',
|
strMenuNoFill: 'No Fill',
|
||||||
tipHighlightColor: 'Highlight color',
|
tipHighlightColor: 'Highlight color',
|
||||||
txtScheme22: 'New Office'
|
txtScheme22: 'New Office',
|
||||||
|
textTabTransitions: 'Transitions'
|
||||||
}
|
}
|
||||||
}()), PE.Views.Toolbar || {}));
|
}()), PE.Views.Toolbar || {}));
|
||||||
});
|
});
|
441
apps/presentationeditor/main/app/view/Transitions.js
Normal file
|
@ -0,0 +1,441 @@
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2019
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at 20A-12 Ernesta Birznieka-Upisha
|
||||||
|
* street, Riga, Latvia, EU, LV-1050.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* Transitions.js
|
||||||
|
*
|
||||||
|
* View
|
||||||
|
*
|
||||||
|
* Created by Olga.Sharova on 15.07.21
|
||||||
|
* Copyright (c) 2021 Ascensio System SIA. All rights reserved.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
define([
|
||||||
|
'common/main/lib/util/utils',
|
||||||
|
'common/main/lib/component/Button',
|
||||||
|
'common/main/lib/component/DataView',
|
||||||
|
'common/main/lib/component/ComboDataView',
|
||||||
|
'common/main/lib/component/Layout',
|
||||||
|
'presentationeditor/main/app/view/SlideSettings',
|
||||||
|
'common/main/lib/component/MetricSpinner',
|
||||||
|
'common/main/lib/component/Window'
|
||||||
|
], function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
PE.Views.Transitions = Common.UI.BaseView.extend(_.extend((function() {
|
||||||
|
function setEvents() {
|
||||||
|
var me = this;
|
||||||
|
if (me.listEffects) {
|
||||||
|
me.listEffects.on('click', _.bind(function (combo, record) {
|
||||||
|
me.fireEvent('transit:selecteffect', [combo, record]);
|
||||||
|
}, me));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (me.btnPreview) {
|
||||||
|
me.btnPreview.on('click', _.bind(function(btn) {
|
||||||
|
me.fireEvent('transit:preview', [me.btnPreview]);
|
||||||
|
}, me));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (me.btnParameters) {
|
||||||
|
me.btnParameters.on('click', function (e) {
|
||||||
|
me.fireEvent('transit:parameters', ['current']);
|
||||||
|
});
|
||||||
|
|
||||||
|
me.btnParameters.menu.on('item:click', function (menu, item, e) {
|
||||||
|
me.fireEvent('transit:parameters', [item]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (me.btnApplyToAll) {
|
||||||
|
me.btnApplyToAll.on('click', _.bind(function(btn) {
|
||||||
|
me.fireEvent('transit:applytoall', [me.btnApplyToAll]);
|
||||||
|
}, me));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (me.numDuration) {
|
||||||
|
me.numDuration.on('change', function(bth) {
|
||||||
|
me.fireEvent('transit:duration', [me.numDuration]);
|
||||||
|
}, me);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (me.numDelay) {
|
||||||
|
me.numDelay.on('change', function(bth) {
|
||||||
|
me.fireEvent('transit:delay', [me.numDelay]);
|
||||||
|
}, me);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (me.chStartOnClick) {
|
||||||
|
me.chStartOnClick.on('change', _.bind(function (e) {
|
||||||
|
me.fireEvent('transit:startonclick', [me.chStartOnClick, me.chStartOnClick.value, me.chStartOnClick.lastValue]);
|
||||||
|
}, me));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (me.chDelay) {
|
||||||
|
me.chDelay.on('change', _.bind(function (e) {
|
||||||
|
me.fireEvent('transit:checkdelay', [me.chDelay, me.chDelay.value, me.chDelay.lastValue]);
|
||||||
|
}, me));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
// el: '#transitions-panel',
|
||||||
|
|
||||||
|
options: {},
|
||||||
|
|
||||||
|
initialize: function (options) {
|
||||||
|
|
||||||
|
Common.UI.BaseView.prototype.initialize.call(this, options);
|
||||||
|
this.toolbar = options.toolbar;
|
||||||
|
this.appConfig = options.mode;
|
||||||
|
this.$el = this.toolbar.toolbar.$el.find('#transitions-panel');
|
||||||
|
var _set = PE.enumLock;
|
||||||
|
this.lockedControls = [];
|
||||||
|
|
||||||
|
this._arrEffectName = [
|
||||||
|
{title: this.textNone, imageUrl: "transition-none", value: Asc.c_oAscSlideTransitionTypes.None, id: Common.UI.getId()},
|
||||||
|
{title: this.textFade, imageUrl: "transition-fade", value: Asc.c_oAscSlideTransitionTypes.Fade, id: Common.UI.getId()},
|
||||||
|
{title: this.textPush, imageUrl: "transition-push", value: Asc.c_oAscSlideTransitionTypes.Push, id: Common.UI.getId()},
|
||||||
|
{title: this.textWipe, imageUrl: "transition-wipe", value: Asc.c_oAscSlideTransitionTypes.Wipe, id: Common.UI.getId()},
|
||||||
|
{title: this.textSplit, imageUrl: "transition-split", value: Asc.c_oAscSlideTransitionTypes.Split, id: Common.UI.getId()},
|
||||||
|
{title: this.textUnCover, imageUrl: "transition-uncover", value: Asc.c_oAscSlideTransitionTypes.UnCover, id: Common.UI.getId()},
|
||||||
|
{title: this.textCover, imageUrl: "transition-cover", value: Asc.c_oAscSlideTransitionTypes.Cover, id: Common.UI.getId()},
|
||||||
|
{title: this.textClock, imageUrl: "transition-clock", value: Asc.c_oAscSlideTransitionTypes.Clock, id: Common.UI.getId()},
|
||||||
|
{title: this.textZoom, imageUrl: "transition-zoom", value: Asc.c_oAscSlideTransitionTypes.Zoom, id: Common.UI.getId()}
|
||||||
|
];
|
||||||
|
|
||||||
|
this.listEffects = new Common.UI.ComboDataView({
|
||||||
|
cls: 'combo-styles',
|
||||||
|
itemWidth: 87,
|
||||||
|
itemHeight: 40,
|
||||||
|
enableKeyEvents: true,
|
||||||
|
lock:[_set.slideDeleted, _set.noSlides, _set.disableOnStart, _set.transitLock],
|
||||||
|
beforeOpenHandler: function (e) {
|
||||||
|
var cmp = this,
|
||||||
|
menu = cmp.openButton.menu;
|
||||||
|
|
||||||
|
if (menu.cmpEl) {
|
||||||
|
|
||||||
|
menu.menuAlignEl = cmp.cmpEl;
|
||||||
|
menu.menuAlign = 'tl-tl';
|
||||||
|
menu.cmpEl.css({
|
||||||
|
'width': cmp.cmpEl.width() - cmp.openButton.$el.width(),
|
||||||
|
'min-height': cmp.cmpEl.height()
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cmp.menuPicker.scroller) {
|
||||||
|
cmp.menuPicker.scroller.update({
|
||||||
|
includePadding: true,
|
||||||
|
suppressScrollX: true
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
cmp.removeTips();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
this.lockedControls.push(this.listEffects);
|
||||||
|
this.listEffects.menuPicker.store.add(this._arrEffectName);
|
||||||
|
|
||||||
|
this.listEffects.fieldPicker.itemTemplate = _.template([
|
||||||
|
'<div class = "btn_item x-huge" id = "<%= id %>" style = "width: ' + (this.listEffects.itemWidth) + 'px;height: ' + (this.listEffects.itemHeight) + 'px;">',
|
||||||
|
'<div class = "icon toolbar__icon <%= imageUrl %>"></div>',
|
||||||
|
'<div class = "caption"><%= title %></div>',
|
||||||
|
'</div>'
|
||||||
|
].join(''));
|
||||||
|
this.listEffects.menuPicker.itemTemplate = this.listEffects.fieldPicker.itemTemplate;
|
||||||
|
|
||||||
|
this.btnPreview = new Common.UI.Button({
|
||||||
|
cls: 'btn-toolbar', // x-huge icon-top',
|
||||||
|
caption: this.txtPreview,
|
||||||
|
split: false,
|
||||||
|
iconCls: 'toolbar__icon preview-transitions',
|
||||||
|
lock:[_set.slideDeleted, _set.noSlides, _set.disableOnStart, _set.transitLock]
|
||||||
|
});
|
||||||
|
this.lockedControls.push(this.btnPreview);
|
||||||
|
|
||||||
|
this.btnParameters = new Common.UI.Button({
|
||||||
|
cls: 'btn-toolbar x-huge icon-top',
|
||||||
|
caption: this.txtParameters,
|
||||||
|
iconCls: 'toolbar__icon icon transition-none',
|
||||||
|
menu: new Common.UI.Menu({
|
||||||
|
items: this.createParametersMenuItems()}),
|
||||||
|
lock:[_set.slideDeleted, _set.noSlides, _set.disableOnStart, _set.transitLock]
|
||||||
|
});
|
||||||
|
this.lockedControls.push(this.btnParameters);
|
||||||
|
|
||||||
|
this.btnApplyToAll = new Common.UI.Button({
|
||||||
|
cls: 'btn-toolbar',
|
||||||
|
caption: this.txtApplyToAll,
|
||||||
|
split: true,
|
||||||
|
iconCls: 'toolbar__icon transition-apply-all',
|
||||||
|
lock:[_set.slideDeleted, _set.noSlides, _set.disableOnStart, _set.transitLock]
|
||||||
|
});
|
||||||
|
this.lockedControls.push(this.btnApplyToAll);
|
||||||
|
|
||||||
|
this.numDuration = new Common.UI.MetricSpinner({
|
||||||
|
el: this.$el.find('#transit-spin-duration'),
|
||||||
|
step: 1,
|
||||||
|
width: 50,
|
||||||
|
value: '',
|
||||||
|
defaultUnit: this.txtSec,
|
||||||
|
maxValue: 300,
|
||||||
|
minValue: 0,
|
||||||
|
lock:[_set.slideDeleted, _set.noSlides, _set.disableOnStart, _set.transitLock]
|
||||||
|
});
|
||||||
|
this.lockedControls.push(this.numDuration);
|
||||||
|
|
||||||
|
this.numDelay = new Common.UI.MetricSpinner({
|
||||||
|
el: this.$el.find('#transit-spin-delay'),
|
||||||
|
step: 1,
|
||||||
|
width: 60,
|
||||||
|
value: '',
|
||||||
|
defaultUnit: this.txtSec,
|
||||||
|
maxValue: 300,
|
||||||
|
minValue: 0,
|
||||||
|
lock:[_set.slideDeleted, _set.noSlides, _set.disableOnStart, _set.transitLock]
|
||||||
|
});
|
||||||
|
this.lockedControls.push(this.numDelay);
|
||||||
|
|
||||||
|
this.chStartOnClick = new Common.UI.CheckBox({
|
||||||
|
el: this.$el.find('#transit-checkbox-startonclick'),
|
||||||
|
labelText: this.strStartOnClick,
|
||||||
|
lock:[_set.slideDeleted, _set.noSlides, _set.disableOnStart, _set.transitLock]
|
||||||
|
});
|
||||||
|
this.lockedControls.push(this.chStartOnClick);
|
||||||
|
|
||||||
|
this.chDelay = new Common.UI.CheckBox({
|
||||||
|
el: this.$el.find('#transit-checkbox-delay'),
|
||||||
|
labelText: this.strDelay,
|
||||||
|
lock:[_set.slideDeleted, _set.noSlides, _set.disableOnStart, _set.transitLock]
|
||||||
|
});
|
||||||
|
this.lockedControls.push(this.chDelay);
|
||||||
|
|
||||||
|
Common.Utils.lockControls(PE.enumLock.disableOnStart, true, {array: this.lockedControls});
|
||||||
|
|
||||||
|
this.$el.find('#transit-duration').text(this.strDuration);
|
||||||
|
Common.NotificationCenter.on('app:ready', this.onAppReady.bind(this));
|
||||||
|
},
|
||||||
|
|
||||||
|
render: function (el) {
|
||||||
|
this.boxSdk = $('#editor_sdk');
|
||||||
|
if (el) el.html(this.getPanel());
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
createParametersMenuItems: function()
|
||||||
|
{
|
||||||
|
var arrEffectType = [
|
||||||
|
{caption: this.textSmoothly, value: Asc.c_oAscSlideTransitionParams.Fade_Smoothly},
|
||||||
|
{caption: this.textBlack, value: Asc.c_oAscSlideTransitionParams.Fade_Through_Black},
|
||||||
|
{caption: this.textLeft, value: Asc.c_oAscSlideTransitionParams.Param_Left},
|
||||||
|
{caption: this.textTop, value: Asc.c_oAscSlideTransitionParams.Param_Top},
|
||||||
|
{caption: this.textRight, value: Asc.c_oAscSlideTransitionParams.Param_Right},
|
||||||
|
{caption: this.textBottom, value: Asc.c_oAscSlideTransitionParams.Param_Bottom},
|
||||||
|
{caption: this.textTopLeft, value: Asc.c_oAscSlideTransitionParams.Param_TopLeft},
|
||||||
|
{caption: this.textTopRight, value: Asc.c_oAscSlideTransitionParams.Param_TopRight},
|
||||||
|
{caption: this.textBottomLeft, value: Asc.c_oAscSlideTransitionParams.Param_BottomLeft},
|
||||||
|
{caption: this.textBottomRight, value: Asc.c_oAscSlideTransitionParams.Param_BottomRight},
|
||||||
|
{caption: this.textVerticalIn, value: Asc.c_oAscSlideTransitionParams.Split_VerticalIn},
|
||||||
|
{caption: this.textVerticalOut, value: Asc.c_oAscSlideTransitionParams.Split_VerticalOut},
|
||||||
|
{caption: this.textHorizontalIn, value: Asc.c_oAscSlideTransitionParams.Split_HorizontalIn},
|
||||||
|
{caption: this.textHorizontalOut, value: Asc.c_oAscSlideTransitionParams.Split_HorizontalOut},
|
||||||
|
{caption: this.textClockwise, value: Asc.c_oAscSlideTransitionParams.Clock_Clockwise},
|
||||||
|
{caption: this.textCounterclockwise, value: Asc.c_oAscSlideTransitionParams.Clock_Counterclockwise},
|
||||||
|
{caption: this.textWedge, value: Asc.c_oAscSlideTransitionParams.Clock_Wedge},
|
||||||
|
{caption: this.textZoomIn, value: Asc.c_oAscSlideTransitionParams.Zoom_In},
|
||||||
|
{caption: this.textZoomOut, value: Asc.c_oAscSlideTransitionParams.Zoom_Out},
|
||||||
|
{caption: this.textZoomRotate, value: Asc.c_oAscSlideTransitionParams.Zoom_AndRotate}
|
||||||
|
];
|
||||||
|
|
||||||
|
var itemsMenu = [];
|
||||||
|
_.each(arrEffectType, function (item) {
|
||||||
|
itemsMenu.push({
|
||||||
|
caption: item.caption,
|
||||||
|
value: item.value,
|
||||||
|
checkable: true,
|
||||||
|
toggleGroup: 'effects'
|
||||||
|
});
|
||||||
|
});
|
||||||
|
return itemsMenu;
|
||||||
|
},
|
||||||
|
|
||||||
|
onAppReady: function (config) {
|
||||||
|
var me = this;
|
||||||
|
(new Promise(function (accept, reject) {
|
||||||
|
accept();
|
||||||
|
})).then(function() {
|
||||||
|
|
||||||
|
setEvents.call(me);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
getPanel: function () {
|
||||||
|
this.listEffects && this.listEffects.render(this.$el.find('#transit-field-effects'));
|
||||||
|
this.btnPreview && this.btnPreview.render(this.$el.find('#transit-button-preview'));
|
||||||
|
this.btnParameters && this.btnParameters.render(this.$el.find('#transit-button-parameters'));
|
||||||
|
this.btnApplyToAll && this.btnApplyToAll.render(this.$el.find('#transit-button-apply'));
|
||||||
|
this.renderComponent('#transit-spin-duration', this.numDuration);
|
||||||
|
this.renderComponent('#transit-spin-delay', this.numDelay);
|
||||||
|
this.renderComponent('#transit-checkbox-startonclick', this.chStartOnClick);
|
||||||
|
this.$el.find("#label-duration").innerText = this.strDuration;
|
||||||
|
this.$el.find("#label-delay").innerText = this.strDelay;
|
||||||
|
return this.$el;
|
||||||
|
},
|
||||||
|
|
||||||
|
renderComponent: function (compid, obj)
|
||||||
|
{
|
||||||
|
var element = this.$el.find(compid);
|
||||||
|
element.parent().append(obj.el);
|
||||||
|
},
|
||||||
|
|
||||||
|
show: function () {
|
||||||
|
Common.UI.BaseView.prototype.show.call(this);
|
||||||
|
this.fireEvent('show', this);
|
||||||
|
},
|
||||||
|
|
||||||
|
getButtons: function (type) {
|
||||||
|
if (type === undefined)
|
||||||
|
return this.lockedControls;
|
||||||
|
return [];
|
||||||
|
},
|
||||||
|
|
||||||
|
setDisabled: function (state) {
|
||||||
|
this.lockedControls && this.lockedControls.forEach(function (button) {
|
||||||
|
button.setDisabled(state);
|
||||||
|
}, this);
|
||||||
|
},
|
||||||
|
|
||||||
|
setMenuParameters: function (effect, value)
|
||||||
|
{
|
||||||
|
var minMax = [-1, -1];
|
||||||
|
switch (effect) {
|
||||||
|
case Asc.c_oAscSlideTransitionTypes.Fade:
|
||||||
|
minMax = [0, 1];
|
||||||
|
break;
|
||||||
|
case Asc.c_oAscSlideTransitionTypes.Push:
|
||||||
|
minMax = [2, 5];
|
||||||
|
break;
|
||||||
|
case Asc.c_oAscSlideTransitionTypes.Wipe:
|
||||||
|
minMax = [2, 9];
|
||||||
|
break;
|
||||||
|
case Asc.c_oAscSlideTransitionTypes.Split:
|
||||||
|
minMax = [10, 13];
|
||||||
|
break;
|
||||||
|
case Asc.c_oAscSlideTransitionTypes.UnCover:
|
||||||
|
minMax = [2, 9];
|
||||||
|
break;
|
||||||
|
case Asc.c_oAscSlideTransitionTypes.Cover:
|
||||||
|
minMax = [2, 9];
|
||||||
|
break;
|
||||||
|
case Asc.c_oAscSlideTransitionTypes.Clock:
|
||||||
|
minMax = [14, 16];
|
||||||
|
break;
|
||||||
|
case Asc.c_oAscSlideTransitionTypes.Zoom:
|
||||||
|
minMax = [17, 19];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
var selectedElement;
|
||||||
|
_.each(this.btnParameters.menu.items, function (element, index) {
|
||||||
|
if (((index < minMax[0])||(index > minMax[1])))
|
||||||
|
element.$el.css('display', 'none');
|
||||||
|
else {
|
||||||
|
element.$el.css('display', '');
|
||||||
|
|
||||||
|
if (value != undefined) {
|
||||||
|
if (value == element.value) selectedElement = element;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (selectedElement == undefined)
|
||||||
|
selectedElement = this.btnParameters.menu.items[minMax[0]];
|
||||||
|
|
||||||
|
if (effect != Asc.c_oAscSlideTransitionTypes.None)
|
||||||
|
selectedElement.setChecked(true);
|
||||||
|
|
||||||
|
if (!this.listEffects.isDisabled()) {
|
||||||
|
this.numDelay.setDisabled(this.chDelay.getValue() !== 'checked');
|
||||||
|
this.btnParameters.setDisabled(effect === Asc.c_oAscSlideTransitionTypes.None);
|
||||||
|
this.btnPreview.setDisabled(effect === Asc.c_oAscSlideTransitionTypes.None);
|
||||||
|
this.numDuration.setDisabled(effect === Asc.c_oAscSlideTransitionTypes.None);
|
||||||
|
}
|
||||||
|
return selectedElement;
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
|
txtSec: 's',
|
||||||
|
txtPreview: 'Preview',
|
||||||
|
txtParameters: 'Parameters',
|
||||||
|
txtApplyToAll: 'Apply to All Slides',
|
||||||
|
strDuration: 'Duration',
|
||||||
|
strDelay: 'Delay',
|
||||||
|
strStartOnClick: 'Start On Click',
|
||||||
|
|
||||||
|
textNone: 'None',
|
||||||
|
textFade: 'Fade',
|
||||||
|
textPush: 'Push',
|
||||||
|
textWipe: 'Wipe',
|
||||||
|
textSplit: 'Split',
|
||||||
|
textUnCover: 'UnCover',
|
||||||
|
textCover: 'Cover',
|
||||||
|
textClock: 'Clock',
|
||||||
|
textZoom: 'Zoom',
|
||||||
|
|
||||||
|
textSmoothly: 'Smoothly',
|
||||||
|
textBlack: 'Through Black',
|
||||||
|
textLeft: 'Left',
|
||||||
|
textTop: 'Top',
|
||||||
|
textRight: 'Right',
|
||||||
|
textBottom: 'Bottom',
|
||||||
|
textTopLeft: 'Top-Left',
|
||||||
|
textTopRight: 'Top-Right',
|
||||||
|
textBottomLeft: 'Bottom-Left',
|
||||||
|
textBottomRight: 'Bottom-Right',
|
||||||
|
textVerticalIn: 'Vertical In',
|
||||||
|
textVerticalOut: 'Vertical Out',
|
||||||
|
textHorizontalIn: 'Horizontal In',
|
||||||
|
textHorizontalOut: 'Horizontal Out',
|
||||||
|
textClockwise: 'Clockwise',
|
||||||
|
textCounterclockwise: 'Counterclockwise',
|
||||||
|
textWedge: 'Wedge',
|
||||||
|
textZoomIn: 'Zoom In',
|
||||||
|
textZoomOut: 'Zoom Out',
|
||||||
|
textZoomRotate: 'Zoom and Rotate'
|
||||||
|
}
|
||||||
|
}()), PE.Views.Transitions || {}));
|
||||||
|
|
||||||
|
});
|
|
@ -153,6 +153,7 @@ require([
|
||||||
,'Common.Controllers.ExternalDiagramEditor'
|
,'Common.Controllers.ExternalDiagramEditor'
|
||||||
,'Common.Controllers.ReviewChanges'
|
,'Common.Controllers.ReviewChanges'
|
||||||
,'Common.Controllers.Protection'
|
,'Common.Controllers.Protection'
|
||||||
|
,'Transitions'
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -188,6 +189,7 @@ require([
|
||||||
,'common/main/lib/controller/Protection'
|
,'common/main/lib/controller/Protection'
|
||||||
,'common/main/lib/controller/Themes'
|
,'common/main/lib/controller/Themes'
|
||||||
,'common/main/lib/controller/Desktop'
|
,'common/main/lib/controller/Desktop'
|
||||||
|
,'presentationeditor/main/app/controller/Transitions'
|
||||||
], function() {
|
], function() {
|
||||||
window.compareVersions = true;
|
window.compareVersions = true;
|
||||||
app.start();
|
app.start();
|
||||||
|
|
|
@ -1648,70 +1648,70 @@
|
||||||
"PE.Views.SlideSettings.strBackground": "Background color",
|
"PE.Views.SlideSettings.strBackground": "Background color",
|
||||||
"PE.Views.SlideSettings.strColor": "Color",
|
"PE.Views.SlideSettings.strColor": "Color",
|
||||||
"PE.Views.SlideSettings.strDateTime": "Show Date and Time",
|
"PE.Views.SlideSettings.strDateTime": "Show Date and Time",
|
||||||
"PE.Views.SlideSettings.strDelay": "Delay",
|
"del_PE.Views.SlideSettings.strDelay": "Delay",
|
||||||
"PE.Views.SlideSettings.strDuration": "Duration",
|
"del_PE.Views.SlideSettings.strDuration": "Duration",
|
||||||
"PE.Views.SlideSettings.strEffect": "Effect",
|
"del_PE.Views.SlideSettings.strEffect": "Effect",
|
||||||
"PE.Views.SlideSettings.strFill": "Background",
|
"PE.Views.SlideSettings.strFill": "Background",
|
||||||
"PE.Views.SlideSettings.strForeground": "Foreground color",
|
"PE.Views.SlideSettings.strForeground": "Foreground color",
|
||||||
"PE.Views.SlideSettings.strPattern": "Pattern",
|
"PE.Views.SlideSettings.strPattern": "Pattern",
|
||||||
"PE.Views.SlideSettings.strSlideNum": "Show Slide Number",
|
"PE.Views.SlideSettings.strSlideNum": "Show Slide Number",
|
||||||
"PE.Views.SlideSettings.strStartOnClick": "Start On Click",
|
"del_PE.Views.SlideSettings.strStartOnClick": "Start On Click",
|
||||||
"PE.Views.SlideSettings.strTransparency": "Opacity",
|
"PE.Views.SlideSettings.strTransparency": "Opacity",
|
||||||
"PE.Views.SlideSettings.textAdvanced": "Show advanced settings",
|
"PE.Views.SlideSettings.textAdvanced": "Show advanced settings",
|
||||||
"PE.Views.SlideSettings.textAngle": "Angle",
|
"PE.Views.SlideSettings.textAngle": "Angle",
|
||||||
"PE.Views.SlideSettings.textApplyAll": "Apply to All Slides",
|
"del_PE.Views.SlideSettings.textApplyAll": "Apply to All Slides",
|
||||||
"PE.Views.SlideSettings.textBlack": "Through Black",
|
"del_PE.Views.SlideSettings.textBlack": "Through Black",
|
||||||
"PE.Views.SlideSettings.textBottom": "Bottom",
|
"del_PE.Views.SlideSettings.textBottom": "Bottom",
|
||||||
"PE.Views.SlideSettings.textBottomLeft": "Bottom Left",
|
"del_PE.Views.SlideSettings.textBottomLeft": "Bottom Left",
|
||||||
"PE.Views.SlideSettings.textBottomRight": "Bottom Right",
|
"del_PE.Views.SlideSettings.textBottomRight": "Bottom Right",
|
||||||
"PE.Views.SlideSettings.textClock": "Clock",
|
"del_PE.Views.SlideSettings.textClock": "Clock",
|
||||||
"PE.Views.SlideSettings.textClockwise": "Clockwise",
|
"del_PE.Views.SlideSettings.textClockwise": "Clockwise",
|
||||||
"PE.Views.SlideSettings.textColor": "Color Fill",
|
"PE.Views.SlideSettings.textColor": "Color Fill",
|
||||||
"PE.Views.SlideSettings.textCounterclockwise": "Counterclockwise",
|
"del_PE.Views.SlideSettings.textCounterclockwise": "Counterclockwise",
|
||||||
"PE.Views.SlideSettings.textCover": "Cover",
|
"del_PE.Views.SlideSettings.textCover": "Cover",
|
||||||
"PE.Views.SlideSettings.textDirection": "Direction",
|
"PE.Views.SlideSettings.textDirection": "Direction",
|
||||||
"PE.Views.SlideSettings.textEmptyPattern": "No Pattern",
|
"PE.Views.SlideSettings.textEmptyPattern": "No Pattern",
|
||||||
"PE.Views.SlideSettings.textFade": "Fade",
|
"del_PE.Views.SlideSettings.textFade": "Fade",
|
||||||
"PE.Views.SlideSettings.textFromFile": "From File",
|
"PE.Views.SlideSettings.textFromFile": "From File",
|
||||||
"PE.Views.SlideSettings.textFromStorage": "From Storage",
|
"PE.Views.SlideSettings.textFromStorage": "From Storage",
|
||||||
"PE.Views.SlideSettings.textFromUrl": "From URL",
|
"PE.Views.SlideSettings.textFromUrl": "From URL",
|
||||||
"PE.Views.SlideSettings.textGradient": "Gradient points",
|
"PE.Views.SlideSettings.textGradient": "Gradient points",
|
||||||
"PE.Views.SlideSettings.textGradientFill": "Gradient Fill",
|
"PE.Views.SlideSettings.textGradientFill": "Gradient Fill",
|
||||||
"PE.Views.SlideSettings.textHorizontalIn": "Horizontal In",
|
"del_PE.Views.SlideSettings.textHorizontalIn": "Horizontal In",
|
||||||
"PE.Views.SlideSettings.textHorizontalOut": "Horizontal Out",
|
"del_PE.Views.SlideSettings.textHorizontalOut": "Horizontal Out",
|
||||||
"PE.Views.SlideSettings.textImageTexture": "Picture or Texture",
|
"PE.Views.SlideSettings.textImageTexture": "Picture or Texture",
|
||||||
"PE.Views.SlideSettings.textLeft": "Left",
|
"del_PE.Views.SlideSettings.textLeft": "Left",
|
||||||
"PE.Views.SlideSettings.textLinear": "Linear",
|
"PE.Views.SlideSettings.textLinear": "Linear",
|
||||||
"PE.Views.SlideSettings.textNoFill": "No Fill",
|
"PE.Views.SlideSettings.textNoFill": "No Fill",
|
||||||
"PE.Views.SlideSettings.textNone": "None",
|
"del_PE.Views.SlideSettings.textNone": "None",
|
||||||
"PE.Views.SlideSettings.textPatternFill": "Pattern",
|
"PE.Views.SlideSettings.textPatternFill": "Pattern",
|
||||||
"PE.Views.SlideSettings.textPosition": "Position",
|
"PE.Views.SlideSettings.textPosition": "Position",
|
||||||
"PE.Views.SlideSettings.textPreview": "Preview",
|
"del_PE.Views.SlideSettings.textPreview": "Preview",
|
||||||
"PE.Views.SlideSettings.textPush": "Push",
|
"del_PE.Views.SlideSettings.textPush": "Push",
|
||||||
"PE.Views.SlideSettings.textRadial": "Radial",
|
"PE.Views.SlideSettings.textRadial": "Radial",
|
||||||
"PE.Views.SlideSettings.textReset": "Reset Changes",
|
"PE.Views.SlideSettings.textReset": "Reset Changes",
|
||||||
"PE.Views.SlideSettings.textRight": "Right",
|
"del_PE.Views.SlideSettings.textRight": "Right",
|
||||||
"PE.Views.SlideSettings.textSec": "s",
|
"del_PE.Views.SlideSettings.textSec": "s",
|
||||||
"PE.Views.SlideSettings.textSelectImage": "Select Picture",
|
"PE.Views.SlideSettings.textSelectImage": "Select Picture",
|
||||||
"PE.Views.SlideSettings.textSelectTexture": "Select",
|
"PE.Views.SlideSettings.textSelectTexture": "Select",
|
||||||
"PE.Views.SlideSettings.textSmoothly": "Smoothly",
|
"del_PE.Views.SlideSettings.textSmoothly": "Smoothly",
|
||||||
"PE.Views.SlideSettings.textSplit": "Split",
|
"del_PE.Views.SlideSettings.textSplit": "Split",
|
||||||
"PE.Views.SlideSettings.textStretch": "Stretch",
|
"PE.Views.SlideSettings.textStretch": "Stretch",
|
||||||
"PE.Views.SlideSettings.textStyle": "Style",
|
"PE.Views.SlideSettings.textStyle": "Style",
|
||||||
"PE.Views.SlideSettings.textTexture": "From Texture",
|
"PE.Views.SlideSettings.textTexture": "From Texture",
|
||||||
"PE.Views.SlideSettings.textTile": "Tile",
|
"PE.Views.SlideSettings.textTile": "Tile",
|
||||||
"PE.Views.SlideSettings.textTop": "Top",
|
"del_PE.Views.SlideSettings.textTop": "Top",
|
||||||
"PE.Views.SlideSettings.textTopLeft": "Top Left",
|
"del_PE.Views.SlideSettings.textTopLeft": "Top Left",
|
||||||
"PE.Views.SlideSettings.textTopRight": "Top Right",
|
"del_PE.Views.SlideSettings.textTopRight": "Top Right",
|
||||||
"PE.Views.SlideSettings.textUnCover": "Uncover",
|
"del_PE.Views.SlideSettings.textUnCover": "Uncover",
|
||||||
"PE.Views.SlideSettings.textVerticalIn": "Vertical In",
|
"del_PE.Views.SlideSettings.textVerticalIn": "Vertical In",
|
||||||
"PE.Views.SlideSettings.textVerticalOut": "Vertical Out",
|
"del_PE.Views.SlideSettings.textVerticalOut": "Vertical Out",
|
||||||
"PE.Views.SlideSettings.textWedge": "Wedge",
|
"del_PE.Views.SlideSettings.textWedge": "Wedge",
|
||||||
"PE.Views.SlideSettings.textWipe": "Wipe",
|
"del_PE.Views.SlideSettings.textWipe": "Wipe",
|
||||||
"PE.Views.SlideSettings.textZoom": "Zoom",
|
"del_PE.Views.SlideSettings.textZoom": "Zoom",
|
||||||
"PE.Views.SlideSettings.textZoomIn": "Zoom In",
|
"del_PE.Views.SlideSettings.textZoomIn": "Zoom In",
|
||||||
"PE.Views.SlideSettings.textZoomOut": "Zoom Out",
|
"del_PE.Views.SlideSettings.textZoomOut": "Zoom Out",
|
||||||
"PE.Views.SlideSettings.textZoomRotate": "Zoom and Rotate",
|
"del_PE.Views.SlideSettings.textZoomRotate": "Zoom and Rotate",
|
||||||
"PE.Views.SlideSettings.tipAddGradientPoint": "Add gradient point",
|
"PE.Views.SlideSettings.tipAddGradientPoint": "Add gradient point",
|
||||||
"PE.Views.SlideSettings.tipRemoveGradientPoint": "Remove gradient point",
|
"PE.Views.SlideSettings.tipRemoveGradientPoint": "Remove gradient point",
|
||||||
"PE.Views.SlideSettings.txtBrownPaper": "Brown Paper",
|
"PE.Views.SlideSettings.txtBrownPaper": "Brown Paper",
|
||||||
|
@ -2018,5 +2018,42 @@
|
||||||
"PE.Views.Toolbar.txtScheme8": "Flow",
|
"PE.Views.Toolbar.txtScheme8": "Flow",
|
||||||
"PE.Views.Toolbar.txtScheme9": "Foundry",
|
"PE.Views.Toolbar.txtScheme9": "Foundry",
|
||||||
"PE.Views.Toolbar.txtSlideAlign": "Align to Slide",
|
"PE.Views.Toolbar.txtSlideAlign": "Align to Slide",
|
||||||
"PE.Views.Toolbar.txtUngroup": "Ungroup"
|
"PE.Views.Toolbar.txtUngroup": "Ungroup",
|
||||||
|
"PE.Views.Transitions.txtSec": "s",
|
||||||
|
"PE.Views.Transitions.txtPreview": "Preview",
|
||||||
|
"PE.Views.Transitions.txtParameters": "Parameters",
|
||||||
|
"PE.Views.Transitions.txtApplyToAll": "Apply to All Slides",
|
||||||
|
"PE.Views.Transitions.strDuration": "Duration",
|
||||||
|
"PE.Views.Transitions.strDelay": "Delay",
|
||||||
|
"PE.Views.Transitions.strStartOnClick": "Start On Click",
|
||||||
|
"PE.Views.Transitions.textNone": "None",
|
||||||
|
"PE.Views.Transitions.textFade": "Fade",
|
||||||
|
"PE.Views.Transitions.textPush": "Push",
|
||||||
|
"PE.Views.Transitions.textWipe": "Wipe",
|
||||||
|
"PE.Views.Transitions.textSplit": "Split",
|
||||||
|
"PE.Views.Transitions.textUnCover": "UnCover",
|
||||||
|
"PE.Views.Transitions.textCover": "Cover",
|
||||||
|
"PE.Views.Transitions.textClock": "Clock",
|
||||||
|
"PE.Views.Transitions.textZoom": "Zoom",
|
||||||
|
"PE.Views.Transitions.textSmoothly": "Smoothly",
|
||||||
|
"PE.Views.Transitions.textBlack": "Through Black",
|
||||||
|
"PE.Views.Transitions.textLeft": "Left",
|
||||||
|
"PE.Views.Transitions.textTop": "Top",
|
||||||
|
"PE.Views.Transitions.textRight": "Right",
|
||||||
|
"PE.Views.Transitions.textBottom": "Bottom",
|
||||||
|
"PE.Views.Transitions.textTopLeft": "Top-Left",
|
||||||
|
"PE.Views.Transitions.textTopRight": "Top-Right",
|
||||||
|
"PE.Views.Transitions.textBottomLeft": "Bottom-Left",
|
||||||
|
"PE.Views.Transitions.textBottomRight": "Bottom-Right",
|
||||||
|
"PE.Views.Transitions.textVerticalIn": "Vertical In",
|
||||||
|
"PE.Views.Transitions.textVerticalOut": "Vertical Out",
|
||||||
|
"PE.Views.Transitions.textHorizontalIn": "Horizontal In",
|
||||||
|
"PE.Views.Transitions.textHorizontalOut": "Horizontal Out",
|
||||||
|
"PE.Views.Transitions.textClockwise": "Clockwise",
|
||||||
|
"PE.Views.Transitions.textCounterclockwise": "Counterclockwise",
|
||||||
|
"PE.Views.Transitions.textWedge": "Wedge",
|
||||||
|
"PE.Views.Transitions.textZoomIn": "Zoom In",
|
||||||
|
"PE.Views.Transitions.textZoomOut": "Zoom Out",
|
||||||
|
"PE.Views.Transitions.textZoomRotate": "Zoom and Rotate",
|
||||||
|
"PE.Views.Toolbar.textTabTransitions": "Transitions"
|
||||||
}
|
}
|
After Width: | Height: | Size: 372 B |
After Width: | Height: | Size: 357 B |
After Width: | Height: | Size: 277 B |
After Width: | Height: | Size: 197 B |
After Width: | Height: | Size: 587 B |
After Width: | Height: | Size: 733 B |
After Width: | Height: | Size: 283 B |
After Width: | Height: | Size: 332 B |
After Width: | Height: | Size: 249 B |
After Width: | Height: | Size: 278 B |
After Width: | Height: | Size: 232 B |
After Width: | Height: | Size: 410 B |
After Width: | Height: | Size: 369 B |
After Width: | Height: | Size: 279 B |
After Width: | Height: | Size: 199 B |
After Width: | Height: | Size: 645 B |
After Width: | Height: | Size: 774 B |
After Width: | Height: | Size: 290 B |
After Width: | Height: | Size: 338 B |
After Width: | Height: | Size: 255 B |
After Width: | Height: | Size: 306 B |
After Width: | Height: | Size: 257 B |
After Width: | Height: | Size: 454 B |
After Width: | Height: | Size: 398 B |
After Width: | Height: | Size: 286 B |
After Width: | Height: | Size: 205 B |
After Width: | Height: | Size: 702 B |
After Width: | Height: | Size: 796 B |
After Width: | Height: | Size: 373 B |
After Width: | Height: | Size: 359 B |
After Width: | Height: | Size: 257 B |
After Width: | Height: | Size: 295 B |
After Width: | Height: | Size: 257 B |
After Width: | Height: | Size: 330 B |
After Width: | Height: | Size: 353 B |
After Width: | Height: | Size: 257 B |
After Width: | Height: | Size: 193 B |
After Width: | Height: | Size: 542 B |
After Width: | Height: | Size: 589 B |
After Width: | Height: | Size: 283 B |
After Width: | Height: | Size: 360 B |
After Width: | Height: | Size: 244 B |
After Width: | Height: | Size: 261 B |
After Width: | Height: | Size: 235 B |
After Width: | Height: | Size: 512 B |
After Width: | Height: | Size: 353 B |
After Width: | Height: | Size: 334 B |
After Width: | Height: | Size: 253 B |
After Width: | Height: | Size: 1 KiB |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 398 B |
After Width: | Height: | Size: 497 B |
After Width: | Height: | Size: 313 B |
After Width: | Height: | Size: 359 B |
After Width: | Height: | Size: 321 B |
|
@ -132,6 +132,7 @@
|
||||||
@import "rightmenu.less";
|
@import "rightmenu.less";
|
||||||
@import "advanced-settings.less";
|
@import "advanced-settings.less";
|
||||||
@import "document-preview.less";
|
@import "document-preview.less";
|
||||||
|
@import "transitions";
|
||||||
|
|
||||||
@import "sprites/iconssmall@1x";
|
@import "sprites/iconssmall@1x";
|
||||||
@import "sprites/iconsbig@1x";
|
@import "sprites/iconsbig@1x";
|
||||||
|
|
63
apps/presentationeditor/main/resources/less/transitions.less
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
#transitions-panel {
|
||||||
|
.item {
|
||||||
|
background: transparent;
|
||||||
|
border-color: transparent;
|
||||||
|
|
||||||
|
.box-shadow(none);
|
||||||
|
border-radius: @scaled-one-px-value-ie;
|
||||||
|
border-radius: @scaled-one-px-value;
|
||||||
|
border-width: calc(2*@scaled-one-px-value-ie) ;
|
||||||
|
border-width: calc(@scaled-two-px-value);
|
||||||
|
|
||||||
|
&:hover{
|
||||||
|
border-color: @border-preview-hover-ie;
|
||||||
|
border-color: @border-preview-hover;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.selected
|
||||||
|
{
|
||||||
|
border-color: @border-preview-select-ie;
|
||||||
|
border-color: @border-preview-select;
|
||||||
|
}
|
||||||
|
|
||||||
|
.style{
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.combo-dataview
|
||||||
|
{
|
||||||
|
&.disabled {
|
||||||
|
.item {
|
||||||
|
&:hover:not(.selected) {
|
||||||
|
border-color: transparent;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.spinner
|
||||||
|
{
|
||||||
|
margin-left: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
.btn_item {
|
||||||
|
color: @text-normal-ie;
|
||||||
|
color: @text-normal;
|
||||||
|
display: inline-flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: center;
|
||||||
|
|
||||||
|
.icon:not(svg) {
|
||||||
|
width: @x-huge-btn-icon-size;
|
||||||
|
height: @x-huge-btn-icon-size;
|
||||||
|
min-width: 0;
|
||||||
|
margin-top: -2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.caption{
|
||||||
|
line-height: 18px;
|
||||||
|
font-size: 11px;
|
||||||
|
}
|
||||||
|
}
|