/* * * (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 * */ /** * Settings.js * Document Editor * * Created by Alexander Yuzhin on 10/7/16 * Copyright (c) 2016 Ascensio System SIA. All rights reserved. * */ define([ 'text!documenteditor/mobile/app/template/Settings.template', 'jquery', 'underscore', 'backbone' ], function (settingsTemplate, $, _, Backbone) { 'use strict'; DE.Views.Settings = Backbone.View.extend(_.extend((function() { // private var _isEdit = false; return { // el: '.view-main', template: _.template(settingsTemplate), events: { // }, initialize: function() { Common.NotificationCenter.on('settingscontainer:show', _.bind(this.initEvents, this)); Common.Gateway.on('opendocument', _.bind(this.loadDocument, this)); this.on('page:show', _.bind(this.updateItemHandlers, this)); }, initEvents: function () { var me = this; me.updateItemHandlers(); me.initControls(); }, // Render layout render: function() { this.layout = $('
').append(this.template({ android : Common.SharedSettings.get('android'), phone : Common.SharedSettings.get('phone'), scope : this })); return this; }, setMode: function (mode) { _isEdit = (mode === 'edit') }, rootLayout: function () { if (this.layout) { var $layour = this.layout.find('#settings-root-view'), isPhone = Common.SharedSettings.get('phone'); if (_isEdit) { $layour.find('#settings-edit-document').hide(); $layour.find('#settings-readermode').hide(); $layour.find('#settings-search .item-title').text(this.textFindAndReplace) } else { $layour.find('#settings-document').hide(); $layour.find('#settings-readermode input:checkbox') .prop('checked', Common.SharedSettings.get('readerMode')); } return $layour.html(); } return ''; }, initControls: function() { // }, updateItemHandlers: function () { var selectorsDynamicPage = [ '.page[data-page=settings-root-view]', '.page[data-page=settings-document-view]' ].map(function (selector) { return selector + ' a.item-link[data-page]'; }).join(', '); $(selectorsDynamicPage).single('click', _.bind(this.onItemClick, this)); }, showPage: function(templateId, suspendEvent) { var rootView = DE.getController('Settings').rootView(); if (rootView && this.layout) { var $content = this.layout.find(templateId); // Android fix for navigation if (Framework7.prototype.device.android) { $content.find('.page').append($content.find('.navbar')); } rootView.router.load({ content: $content.html() }); if (suspendEvent !== true) { this.fireEvent('page:show', [this, templateId]); } } }, onItemClick: function (e) { var $target = $(e.currentTarget), page = $target.data('page'); if (page && page.length > 0 ) { this.showPage(page); } }, renderPageSizes: function(sizes, selectIndex) { var $pageFormats = $('.page[data-page=settings-document-formats-view]'), $list = $pageFormats.find('ul'), items = []; _.each(sizes, function (size, index) { items.push(_.template([ '