286 lines
10 KiB
JavaScript
286 lines
10 KiB
JavaScript
/*
|
|
*
|
|
* (c) Copyright Ascensio System Limited 2010-2016
|
|
*
|
|
* 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 Lubanas st. 125a-25, Riga, Latvia,
|
|
* EU, LV-1021.
|
|
*
|
|
* 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
|
|
*
|
|
*/
|
|
|
|
/**
|
|
* EditSlide.js
|
|
* Presentation Editor
|
|
*
|
|
* Created by Julia Radzhabova on 12/07/16
|
|
* Copyright (c) 2016 Ascensio System SIA. All rights reserved.
|
|
*
|
|
*/
|
|
|
|
define([
|
|
'core',
|
|
'presentationeditor/mobile/app/view/edit/EditSlide'
|
|
], function (core) {
|
|
'use strict';
|
|
|
|
PE.Controllers.EditSlide = Backbone.Controller.extend(_.extend((function() {
|
|
// Private
|
|
var _stack = [],
|
|
_slideObject = undefined,
|
|
_themes = [],
|
|
_themeId = -1;
|
|
|
|
return {
|
|
models: [],
|
|
collections: [],
|
|
views: [
|
|
'EditSlide'
|
|
],
|
|
|
|
initialize: function () {
|
|
Common.NotificationCenter.on('editcontainer:show', _.bind(this.initEvents, this));
|
|
Common.NotificationCenter.on('slidelayouts:load', _.bind(this.updateLayouts, this));
|
|
|
|
this.addListeners({
|
|
'EditSlide': {
|
|
'page:show': this.onPageShow
|
|
}
|
|
});
|
|
},
|
|
|
|
setApi: function (api) {
|
|
var me = this;
|
|
me.api = api;
|
|
|
|
me.api.asc_registerCallback('asc_onFocusObject', _.bind(me.onApiFocusObject, me));
|
|
me.api.asc_registerCallback('asc_onInitEditorStyles', _.bind(me.onApiInitEditorStyles, me));
|
|
me.api.asc_registerCallback('asc_onUpdateThemeIndex', _.bind(me.onApiUpdateThemeIndex, me));
|
|
},
|
|
|
|
onLaunch: function () {
|
|
this.createView('EditSlide').render();
|
|
},
|
|
|
|
initEvents: function () {
|
|
var me = this;
|
|
|
|
$('#slide-remove').single('click', _.bind(me.onRemoveSlide, me));
|
|
$('#slide-duplicate').single('click', _.bind(me.onDuplicateSlide, me));
|
|
|
|
me.initSettings();
|
|
},
|
|
|
|
onPageShow: function (view, pageId) {
|
|
var me = this;
|
|
me.initSettings(pageId);
|
|
},
|
|
|
|
initSettings: function (pageId) {
|
|
var me = this;
|
|
|
|
if (_slideObject) {
|
|
if (pageId == '#edit-slide-style') {
|
|
me._initStyleView();
|
|
|
|
var paletteFillColor = me.getView('EditSlide').paletteFillColor;
|
|
paletteFillColor && paletteFillColor.on('select', _.bind(me.onFillColor, me));
|
|
|
|
} else if (pageId == '#edit-slide-layout') {
|
|
$('.container-edit .slide-layout li').single('click', _.buffered(me.onLayoutClick, 100, me));
|
|
} else if (pageId == '#edit-slide-theme') {
|
|
this.getView('EditSlide').renderThemes();
|
|
|
|
$('.container-edit .slide-theme .row div').removeClass('active').single('click', _.buffered(me.onThemeClick, 100, me));
|
|
$('.container-edit .slide-theme div[data-type=' + _themeId + ']').addClass('active');
|
|
}
|
|
}
|
|
},
|
|
|
|
_initStyleView: function () {
|
|
var me = this,
|
|
paletteFillColor = me.getView('EditSlide').paletteFillColor;
|
|
|
|
var sdkColor, color;
|
|
|
|
// Init fill color
|
|
var fill = _slideObject.get_background(),
|
|
fillType = fill.get_type();
|
|
|
|
color = 'transparent';
|
|
|
|
if (fillType == Asc.c_oAscFill.FILL_TYPE_SOLID) {
|
|
fill = fill.get_fill();
|
|
sdkColor = fill.get_color();
|
|
|
|
if (sdkColor) {
|
|
if (sdkColor.get_type() == Asc.c_oAscColor.COLOR_TYPE_SCHEME) {
|
|
color = {color: Common.Utils.ThemeColor.getHexColor(sdkColor.get_r(), sdkColor.get_g(), sdkColor.get_b()), effectValue: sdkColor.get_value()};
|
|
} else {
|
|
color = Common.Utils.ThemeColor.getHexColor(sdkColor.get_r(), sdkColor.get_g(), sdkColor.get_b());
|
|
}
|
|
}
|
|
}
|
|
|
|
paletteFillColor && paletteFillColor.select(color);
|
|
},
|
|
|
|
// Public
|
|
|
|
getSlide: function () {
|
|
return _slideObject;
|
|
},
|
|
|
|
getThemes: function () {
|
|
return _themes || [];
|
|
},
|
|
|
|
// Handlers
|
|
|
|
onLayoutClick: function (e) {
|
|
var me = this,
|
|
$target = $(e.currentTarget),
|
|
type = $target.data('type');
|
|
|
|
me.api.ChangeLayout(type);
|
|
},
|
|
|
|
onThemeClick: function (e) {
|
|
var me = this,
|
|
$target = $(e.currentTarget),
|
|
type = $target.data('type');
|
|
|
|
$('.container-edit .slide-theme div').removeClass('active');
|
|
$target.addClass('active');
|
|
|
|
me.api.ChangeTheme(type);
|
|
},
|
|
|
|
onRemoveSlide: function () {
|
|
this.api.DeleteSlide();
|
|
PE.getController('EditContainer').hideModal();
|
|
},
|
|
|
|
onDuplicateSlide: function () {
|
|
this.api.DublicateSlide();
|
|
PE.getController('EditContainer').hideModal();
|
|
},
|
|
|
|
onFillColor: function(palette, color) {
|
|
var me = this;
|
|
|
|
if (me.api) {
|
|
var props = new Asc.CAscSlideProps();
|
|
var fill = new Asc.asc_CShapeFill();
|
|
|
|
if (color == 'transparent') {
|
|
fill.put_type(Asc.c_oAscFill.FILL_TYPE_NOFILL);
|
|
fill.put_fill(null);
|
|
} else {
|
|
fill.put_type(Asc.c_oAscFill.FILL_TYPE_SOLID);
|
|
fill.put_fill(new Asc.asc_CFillSolid());
|
|
fill.get_fill().put_color(Common.Utils.ThemeColor.getRgbColor(color));
|
|
}
|
|
props.put_background(fill);
|
|
me.api.SetSlideProps(props);
|
|
}
|
|
},
|
|
|
|
updateLayouts: function(layouts){
|
|
this.getView('EditSlide').updateLayouts();
|
|
$('.container-edit .slide-layout li').single('click', _.buffered(this.onLayoutClick, 100, this));
|
|
},
|
|
|
|
// API handlers
|
|
|
|
onApiFocusObject: function (objects) {
|
|
_stack = objects;
|
|
|
|
var slides = [];
|
|
|
|
_.each(_stack, function (object) {
|
|
if (object.get_ObjectType() == Asc.c_oAscTypeSelectElement.Slide) {
|
|
slides.push(object);
|
|
}
|
|
});
|
|
|
|
if (slides.length > 0) {
|
|
var object = slides[slides.length - 1]; // get top slide
|
|
_slideObject = object.get_ObjectValue();
|
|
} else {
|
|
_slideObject = undefined;
|
|
}
|
|
},
|
|
|
|
onApiInitEditorStyles: function(themes) {
|
|
if (themes) {
|
|
window.styles_loaded = false;
|
|
|
|
var me = this,
|
|
defaultThemes = themes[0] || [],
|
|
docThemes = themes[1] || [];
|
|
|
|
_themes = [];
|
|
|
|
_.each(defaultThemes.concat(docThemes), function(theme) {
|
|
_themes.push({
|
|
imageUrl: theme.get_Image(),
|
|
themeId : theme.get_Index()
|
|
});
|
|
});
|
|
|
|
window.styles_loaded = true;
|
|
}
|
|
},
|
|
|
|
onApiUpdateThemeIndex: function(themeId) {
|
|
_themeId = themeId;
|
|
$('.container-edit .slide-theme .row div').removeClass('active');
|
|
$('.container-edit .slide-theme div[data-type=' + _themeId + ']').addClass('active');
|
|
},
|
|
|
|
// Helpers
|
|
|
|
_closeIfNeed: function () {
|
|
if (!this._isSlideInStack()) {
|
|
PE.getController('EditContainer').hideModal();
|
|
}
|
|
},
|
|
|
|
_isSlideInStack: function () {
|
|
var slideExist = false;
|
|
|
|
_.some(_stack, function(object) {
|
|
if (object.get_ObjectType() == Asc.c_oAscTypeSelectElement.Slide) {
|
|
slideExist = true;
|
|
return true;
|
|
}
|
|
});
|
|
|
|
return slideExist;
|
|
}
|
|
};
|
|
})(), PE.Controllers.EditSlide || {}))
|
|
}); |