/* * * (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 * */ /** * AddOther.js * Document Editor * * Created by Alexander Yuzhin on 10/17/16 * Copyright (c) 2018 Ascensio System SIA. All rights reserved. * */ define([ 'text!documenteditor/mobile/app/template/AddOther.template', 'jquery', 'underscore', 'backbone' ], function (addTemplate, $, _, Backbone) { 'use strict'; DE.Views.AddOther = Backbone.View.extend(_.extend((function() { // private return { // el: '.view-main', template: _.template(addTemplate), events: { }, initialize: function () { Common.NotificationCenter.on('addcontainer:show', _.bind(this.initEvents, this)); }, initEvents: function () { var me = this; $('#add-other-link').single('click', _.bind(me.showLink, me)); $('#add-other-pagenumber').single('click', _.bind(me.showPagePosition, me)); if (this.isDisableComment) { $('#item-comment').addClass('disabled'); } else { $('#item-comment').removeClass('disabled'); $('#add-other-comment').single('click', _.bind(me.showPageComment, me)); } if (this.isDisableBreak) { $('#item-break').addClass('disabled'); } else { $('#item-break').removeClass('disabled'); $('#add-other-break').single('click', _.bind(me.showPageBreak, me)); } if (this.isDisableFootnote) { $('#item-footnote').addClass('disabled'); } else { $('#item-footnote').removeClass('disabled'); $('#add-other-footnote').single('click', _.bind(me.showPageFootnote, me)); } 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; }, rootLayout: function () { if (this.layout) { if (!this.canViewComments) { this.layout.find('#addother-root-view #item-comment').remove(); } return this.layout .find('#addother-root-view') .html(); } return ''; }, initControls: function () { // }, showPage: function (templateId, animate) { var rootView = DE.getController('AddContainer').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(), animatePages: animate !== false }); this.fireEvent('page:show', [this, templateId]); } }, showPageBreak: function() { this.showPage('#addother-insert-break'); $('#add-other-section').single('click', _.bind(this.showSectionBreak, this)); }, showSectionBreak: function () { this.showPage('#addother-sectionbreak'); }, showLink: function (animate) { this.showPage('#addother-link', animate); $('.page[data-page=addother-link] input[type=url]').single('input', _.bind(function(e) { $('#add-link-insert').toggleClass('disabled', _.isEmpty($('#add-link-url input').val())); }, this)); _.delay(function () { $('.page[data-page=addother-link] input[type=url]').focus(); }, 1000); }, showPagePosition: function () { this.showPage('#addother-pagenumber'); }, showPageFootnote: function () { this.showPage('#addother-insert-footnote'); }, showPageComment: function(animate) { this.showPage('#addother-insert-comment', animate); }, renderComment: function(comment) { var me = this; _.delay(function () { var $commentInfo = $('#comment-info'); var template = [ '<% if (android) { %>
<%= comment.userInitials %>
<% } %>', '
<%= scope.getUserName(comment.username) %>
', '
<%= comment.date %>
', '<% if (android) { %>
<% } %>', '
' ].join(''); var insert = _.template(template)({ android: Framework7.prototype.device.android, comment: comment, textAddComment: me.textAddComment, scope: me }); $commentInfo.html(insert); _.defer(function () { var $textarea = $('.comment-textarea')[0]; var $btnAddComment = $('#done-comment'); $btnAddComment.addClass('disabled'); $textarea.focus(); $textarea.oninput = function () { if ($textarea.value.length < 1) { if (!$btnAddComment.hasClass('disabled')) $btnAddComment.addClass('disabled'); } else { if ($btnAddComment.hasClass('disabled')) { $btnAddComment.removeClass('disabled'); } } }; }); }, 100); }, getUserName: function (username) { return Common.Utils.String.htmlEncode(Common.Utils.UserInfoParser.getParsedName(username)); }, renderNumFormat: function (dataFormat, selectFormat) { var $listFormat = $('#list-format-footnote ul'), items = []; _.each(dataFormat, function (formatItem) { var itemTemplate = [ '
  • ', '', '
  • ' ].join(''); items.push(_.template(itemTemplate)({ android: Framework7.prototype.device.android, item: formatItem, select: selectFormat })); }); $listFormat.html(items); }, renderFootnotePos: function (dataPosition, selectPosition) { var $listPos = $('#position-footnote ul'), items = []; _.each(dataPosition, function (posItem) { var itemTemplate = [ '
  • ', '', '
  • ' ].join(''); items.push(_.template(itemTemplate)({ android: Framework7.prototype.device.android, item: posItem, select: selectPosition })); }); $listPos.html(items); }, textPageBreak: 'Page Break', textSectionBreak: 'Section Break', textColumnBreak: 'Column Break', textLink: 'Link', textPageNumber: 'Page Number', textBack: 'Back', textAddLink: 'Add Link', textDisplay: 'Display', textTip: 'Screen Tip', textInsert: 'Insert', textPosition: 'Position', textLeftTop: 'Left Top', textCenterTop: 'Center Top', textRightTop: 'Right Top', textLeftBottom: 'Left Bottom', textCenterBottom: 'Center Bottom', textRightBottom: 'Right Bottom', textCurrentPos: 'Current Position', textNextPage: 'Next Page', textContPage: 'Continuous Page', textEvenPage: 'Even Page', textOddPage: 'Odd Page', textFootnote: 'Footnote', textInsertFootnote: 'Insert Footnote', textFormat: 'Format', textStartFrom: 'Start At', textLocation: 'Location', textComment: 'Comment', textAddComment: 'Add Comment', textDone: 'Done', textBreak: 'Break' } })(), DE.Views.AddOther || {})) });