/* * * (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 * */ /** * Animation.js * * Created by Olga.Animation on 13.10.21 * Copyright (c) 2021 Ascensio System SIA. All rights reserved. * */ define([ 'core', 'jquery', 'underscore', 'backbone', 'presentationeditor/main/app/view/Animation', 'presentationeditor/main/app/view/AnimationDialog' ], function () { 'use strict'; PE.Controllers.Animation = Backbone.Controller.extend(_.extend({ models : [], collections : [], views : [ 'PE.Views.Animation' ], options: { alias: 'Animation' }, sdkViewName : '#id_main', initialize: function () { this.addListeners({ 'PE.Views.Animation': { 'animation:preview': _.bind(this.onPreviewClick, this), 'animation:parameters': _.bind(this.onParameterClick, this), 'animation:duration': _.bind(this.onDurationChange, this), 'animation:selecteffect': _.bind(this.onEffectSelect, this), 'animation:delay': _.bind(this.onDelayChange, this), 'animation:animationpane':_.bind(this.onAnimationPane, this), 'animation:addanimation': _.bind(this.onAddAnimation, this), 'animation:startselect': _.bind(this.onStartSelect, this), 'animation:checkrewind': _.bind(this.onCheckRewindChange,this), }, 'Toolbar': { 'tab:active': _.bind(this.onActiveTab, this) } }); this.EffectGroups = Common.define.effectData.getEffectGroupData(); }, onLaunch: function () { this._state = {}; }, setConfig: function (config) { this.appConfig = config.mode; this.view = this.createView('PE.Views.Animation', { 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() { this.api.asc_StartAnimationPreview(); }, onParameterClick: function (value) { this._state.EffectOption = value; if(this.api && this.AnimationProperties) { this.AnimationProperties.asc_putSubtype(value); this.api.asc_SetAnimationProperties(this.AnimationProperties); // this.getAnimationProperties(); console.log(this.AnimationProperties.asc_getSubtype()); } }, onAnimationPane: function() { (new PE.Views.AnimationDialog({ api: this.api, activEffect: this.Effect })).show(); }, onAddAnimation: function(combo, record) { var type = record.get('value'); var group = Common.define.effectData.getEffectGroupData().findWhere({id: record.group}).value; this.addNewEffect(type, group); this._state.EffectGroups = group; this._state.Effect = type; }, addNewEffect: function (type, group, replace) { if (this._state.Effect == type) return; var parameter= this.view.setMenuParameters(type, undefined, group == this._state.EffectGroups); this.api.asc_AddAnimation(this._state.EffectGroups, type, parameter!==undefined ? parameter : 0, !!replace); if (parameter!= undefined) this.onParameterClick(parameter); }, onDurationChange: function(field, newValue, oldValue, eOpts) { if (this.api) { this._state.Duration = field.getNumberValue() * 1000; this.AnimationProperties.asc_putDuration(this._state.Duration); this.api.asc_SetAnimationProperties(this.AnimationProperties); } }, onDelayChange: function(field, newValue, oldValue, eOpts) { if (this.api) { this._state.Delay = field.getNumberValue() * 1000; this.AnimationProperties.asc_putDelay(this._state.Delay); this.api.asc_SetAnimationProperties(this.AnimationProperties); } }, onEffectSelect: function (combo, record) { var type = record.get('value'); var group = _.findWhere(Common.define.effectData.getEffectGroupData(),{id: record.get('group')}).value; this.addNewEffect(type, group, true); this._state.EffectGroups = group; this._state.Effect = type; }, onStartSelect: function (combo, record) { if (this.api) { this._state.StartEffect =record.value; this.AnimationProperties.asc_putStartType(this._state.StartEffect); this.api.asc_SetAnimationProperties(this.AnimationProperties); } }, onCheckRewindChange: function (field, newValue, oldValue, eOpts) { if (this.api && this.AnimationProperties) { this.AnimationProperties.asc_putRewind(field.getValue() == 'checked'); this.api.asc_SetAnimationProperties(this.AnimationProperties); } }, onFocusObject: function(selectedObjects) { for (var i = 0; i 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 = this.AnimationProperties.asc_getDelay(); 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.StartSelect = this.AnimationProperties.asc_getStartType(); this._state.RepeatCount = this.AnimationProperties.asc_getRepeatCount(); this._state.Rewind = this.AnimationProperties.asc_getRewind(); }, onActiveTab: function(tab) { if (tab == 'animate') { 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; var item; if (this._state.Effect !== undefined) { 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.EffectOption !== undefined) me.setMenuParameters(this._state.Effect, this._state.EffectOption, true); 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); (this._state.StartSelect==undefined)&&(this._state.StartSelect = AscFormat.NODE_TYPE_CLICKEFFECT); item = me.cmbStart.store.findWhere({value: this._state.StartSelect}); me.cmbStart.selectRecord(item); me.chRewind.setValue(this._state.Rewind, true); } }, PE.Controllers.Animation || {})); });