/** * Viewport.js * * View for viewport * * Created by Maxim Kadushkin on 24 March 2014 * Copyright (c) 2014 Ascensio System SIA. All rights reserved. * */ define([ 'text!spreadsheeteditor/main/app/template/Viewport.template', 'jquery', 'underscore', 'backbone', 'common/main/lib/component/BaseView', 'common/main/lib/component/Layout' ], function (viewportTemplate, $, _, Backbone) { 'use strict'; SSE.Views.Viewport = Backbone.View.extend({ el: '#viewport', // Compile our stats template template: _.template(viewportTemplate), // Delegated events for creating new items, and clearing completed ones. events: { }, // Set innerHTML and get the references to the DOM elements initialize: function() { // }, // Render layout render: function() { var el = $(this.el); el.html(this.template({})); // Workaround Safari's scrolling problem if (Common.Utils.isSafari) { $('body').addClass('safari'); $('body').mousewheel(function(e){ e.preventDefault(); e.stopPropagation(); }); } else if (Common.Utils.isChrome) { $('body').addClass('chrome'); } var $container = $('#viewport-vbox-layout', el); var items = $container.find(' > .layout-item'); this.vlayout = new Common.UI.VBoxLayout({ box: $container, items: [{ el: items[0], rely: true }, { el: items[1], rely: true }, { el: items[2], stretch: true }, { el: items[3], height: 25 }] }); $container = $('#viewport-hbox-layout', el); items = $container.find(' > .layout-item'); this.hlayout = new Common.UI.HBoxLayout({ box: $container, items: [{ el: items[0], rely: true, resize: { hidden: true, autohide: false, min: 300, max: 600 } }, { el: items[1], stretch: true }, { el: $(items[2]).hide(), rely: true }] }); $container = $container.find('.layout-ct.vbox'); items = $container.find(' > .layout-item'); this.celayout = new Common.UI.VBoxLayout({ box: $container, items: [{ el: items[0], rely: true, resize: { min: 19, max: -100 } }, { el: items[1], stretch: true }] }); return this; }, applyEditorMode: function() { var me = this, toolbarView = SSE.getController('Toolbar').getView('Toolbar'), rightMenuView = SSE.getController('RightMenu').getView('RightMenu'); // statusBarView = SSE.getController('Statusbar').getView('Statusbar'); // me._toolbar = toolbarView.render(this.mode.isEditDiagram, this.mode.isEditMailMerge); me._rightMenu = rightMenuView.render(); // // var value = Common.localStorage.getItem('de-hidden-status'); // if (value !== null && parseInt(value) == 1) // statusBarView.setVisible(false); }, setMode: function(mode, delay) { if (mode.isDisconnected) { /** coauthoring begin **/ if (_.isUndefined(this.mode)) this.mode = {}; this.mode.canCoAuthoring = false; /** coauthoring end **/ } else { this.mode = mode; } } }); });