/* * * (c) Copyright Ascensio System Limited 2010-2017 * * 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 * */ /** * User: Julia.Radzhabova * Date: 14.12.17 */ define([ 'core', 'documenteditor/main/app/collection/Navigation', 'documenteditor/main/app/view/Navigation' ], function () { 'use strict'; DE.Controllers.Navigation = Backbone.Controller.extend(_.extend({ models: [], collections: [ 'Navigation' ], views: [ 'Navigation' ], initialize: function() { var me = this; this.addListeners({ 'Navigation': { 'show': function() { var obj = me.api.asc_ShowDocumentOutline(); if (!me._navigationObject) me._navigationObject = obj; me.updateNavigation(); }, 'hide': function() { me.api.asc_HideDocumentOutline(); } } }); }, events: function() { }, onLaunch: function() { this.panelNavigation= this.createView('Navigation', { storeNavigation: this.getApplication().getCollection('Navigation') }); this.panelNavigation.on('render:after', _.bind(this.onAfterRender, this)); this._navigationObject = null; }, setApi: function(api) { this.api = api; this.api.asc_registerCallback('asc_onDocumentOutlineUpdate', _.bind(this.updateNavigation, this)); this.api.asc_registerCallback('asc_onDocumentOutlineCurrentPosition', _.bind(this.onChangeOutlinePosition, this)); this.api.asc_registerCallback('asc_onDocumentOutlineUpdateAdd', _.bind(this.updateNavigation, this)); this.api.asc_registerCallback('asc_onDocumentOutlineUpdateChange', _.bind(this.updateChangeNavigation, this)); this.api.asc_registerCallback('asc_onDocumentOutlineUpdateRemove', _.bind(this.updateNavigation, this)); return this; }, setMode: function(mode) { }, onAfterRender: function(panelNavigation) { panelNavigation.viewNavigationList.on('item:click', _.bind(this.onSelectItem, this)); panelNavigation.viewNavigationList.on('item:contextmenu', _.bind(this.onItemContextMenu, this)); panelNavigation.navigationMenu.on('item:click', _.bind(this.onMenuItemClick, this)); panelNavigation.navigationMenu.items[11].menu.on('item:click', _.bind(this.onMenuLevelsItemClick, this)); }, updateNavigation: function() { if (!this._navigationObject) return; var count = this._navigationObject.get_ElementsCount(), prev_level = -1, header_level = -1, first_header = !this._navigationObject.isFirstItemNotHeader(), arr = []; for (var i=0; i<count; i++) { var level = this._navigationObject.get_Level(i), hasParent = true; if (level>prev_level && i>0) arr[i-1].set('hasSubItems', true); if (header_level<0 || level<=header_level) { if (i>0 || first_header) header_level = level; hasParent = false; } arr.push(new Common.UI.TreeViewModel({ name : this._navigationObject.get_Text(i), level: level, index: i, hasParent: hasParent, isEmptyItem: this._navigationObject.isEmptyItem(i) })); prev_level = level; } if (count>0 && !first_header) { arr[0].set('hasSubItems', false); arr[0].set('isNotHeader', true); arr[0].set('name', this.txtBeginning); arr[0].set('tip', this.txtGotoBeginning); } this.getApplication().getCollection('Navigation').reset(arr); }, updateChangeNavigation: function(index) { if (!this._navigationObject) return; var item = this.getApplication().getCollection('Navigation').at(index); if (item.get('level') !== this._navigationObject.get_Level(index) || index==0 && item.get('isNotHeader') !== this._navigationObject.isFirstItemNotHeader()) { this.updateNavigation(); } else { item.set('name', this._navigationObject.get_Text(index)); item.set('isEmptyItem', this._navigationObject.isEmptyItem(index)); } }, onChangeOutlinePosition: function(index) { this.panelNavigation.viewNavigationList.selectByIndex(index); }, onItemContextMenu: function(picker, item, record, e){ var showPoint; var menu = this.panelNavigation.navigationMenu; if (menu.isVisible()) { menu.hide(); } var parentOffset = this.panelNavigation.$el.offset(), top = e.clientY*Common.Utils.zoom(); showPoint = [e.clientX*Common.Utils.zoom() + 5, top - parentOffset.top + 5]; var isNotHeader = record.get('isNotHeader'); menu.items[0].setDisabled(isNotHeader); menu.items[1].setDisabled(isNotHeader); menu.items[3].setDisabled(isNotHeader); menu.items[7].setDisabled(isNotHeader); if (showPoint != undefined) { var menuContainer = this.panelNavigation.$el.find('#menu-navigation-container'); if (!menu.rendered) { if (menuContainer.length < 1) { menuContainer = $('<div id="menu-navigation-container" style="position: absolute; z-index: 10000;"><div class="dropdown-toggle" data-toggle="dropdown"></div></div>', menu.id); $(this.panelNavigation.$el).append(menuContainer); } menu.render(menuContainer); menu.cmpEl.attr({tabindex: "-1"}); } menu.cmpEl.attr('data-value', record.get('index')); menuContainer.css({ left: showPoint[0], top: showPoint[1] }); menu.show(); _.delay(function() { menu.cmpEl.focus(); }, 10); } }, onSelectItem: function(picker, item, record, e){ if (!this._navigationObject) return; this._navigationObject.goto(record.get('index')); }, onMenuItemClick: function (menu, item) { if (!this._navigationObject) return; var index = parseInt(menu.cmpEl.attr('data-value')); if (item.value == 'promote') { this._navigationObject.promote(index); } else if (item.value == 'demote') { this._navigationObject.demote(index); } else if (item.value == 'before') { this._navigationObject.insertHeader(index, true); } else if (item.value == 'after') { this._navigationObject.insertHeader(index, false); } else if (item.value == 'new') { this._navigationObject.insertSubHeader(index); } else if (item.value == 'select') { this._navigationObject.selectContent(index); } else if (item.value == 'expand') { this.panelNavigation.viewNavigationList.expandAll(); } else if (item.value == 'collapse') { this.panelNavigation.viewNavigationList.collapseAll(); } }, onMenuLevelsItemClick: function (menu, item) { this.panelNavigation.viewNavigationList.expandToLevel(item.value-1); }, txtBeginning: 'Beginning of document', txtGotoBeginning: 'Go to the beginning of the document' }, DE.Controllers.Navigation || {})); });