/*
 *
 * (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
 *
 */

/**
 *  Editor.js
 *  Document Editor
 *
 *  Created by Alexander Yuzhin on 9/22/16
 *  Copyright (c) 2018 Ascensio System SIA. All rights reserved.
 *
 */

define([
    'core',
    'documenteditor/mobile/app/view/Editor'
], function (core) {
    'use strict';

    DE.Controllers.Editor = Backbone.Controller.extend((function() {
        // private

        function isPhone() {
            var ua = navigator.userAgent,
                isMobile = /Mobile(\/|\s)/.test(ua);

            return /(iPhone|iPod)/.test(ua) ||
                (!/(Silk)/.test(ua) && (/(Android)/.test(ua) && (/(Android 2)/.test(ua) || isMobile))) ||
                (/(BlackBerry|BB)/.test(ua) && isMobile) ||
                /(Windows Phone)/.test(ua);
        }

        function isTablet() {
            var ua = navigator.userAgent;

            return !isPhone(ua) && (/iPad/.test(ua) || /Android/.test(ua) || /(RIM Tablet OS)/.test(ua) ||
                (/MSIE 10/.test(ua) && /; Touch/.test(ua)));
        }

        function isSailfish() {
            var ua = navigator.userAgent;
            return /Sailfish/.test(ua) || /Jolla/.test(ua);
        }

        return {
            // Specifying a EditorController model
            models: [],

            // Specifying a collection of out EditorView
            collections: [],

            // Specifying application views
            views: [
                'Editor'   // is main application layout
            ],

            // When controller is created let's setup view event listeners
            initialize: function() {
                // This most important part when we will tell our controller what events should be handled
            },

            setApi: function(api) {
                this.api = api;
            },

            // When our application is ready, lets get started
            onLaunch: function() {
                // Device detection
                var phone = isPhone();
                // console.debug('Layout profile:', phone ? 'Phone' : 'Tablet');

                if ( isSailfish() ) {
                    Common.SharedSettings.set('sailfish', true);
                    $('html').addClass('sailfish');
                }

                Common.SharedSettings.set('android', Framework7.prototype.device.android);
                Common.SharedSettings.set('phone', phone);

                $('html').addClass(phone ? 'phone' : 'tablet');

                // Create and render main view
                this.editorView = this.createView('Editor').render();

                $$(window).on('resize', _.bind(this.onWindowResize, this));
            },

            onWindowResize: function(e) {
                this.api && this.api.Resize();
            }
        }
    })());
});