/*
 * Copyright (c) 2014-present, b3log.org
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/*
 * @file tabs.js
 *
 * @author <a href="http://vanessa.b3log.org">Liyuan Li</a>
 * @version 1.0.0.1, Dec 8, 2015
 */
var Tabs = function (obj) {
    obj._$tabsPanel = $(obj.id + " > .tabs-panel");
    obj._$tabs = $(obj.id + " > .tabs");
    obj._stack = [];

    this.obj = obj;
    this.obj.STACKSIZE = 64;

    this._init(obj);

    // DOM 元素存在时,应顺序入栈
    var _it = this;
    $(obj.id + " > .tabs > div").each(function () {
        var id = $(this).data("index");
        if (obj._stack.length === _it.obj.STACKSIZE) {
            obj._stack.splice(0, 1);
        }
        if (obj._stack[obj._stack.length - 1] !== id) {
            _it.obj._stack.push(id);
        }
    });

};

$.extend(Tabs.prototype, {
    _init: function (obj) {
        var _that = this;

        obj._$tabs.on("click", "div", function (event) {
            if ($(this).hasClass('current')) {
                return false;
            }

            var id = $(this).data("index");
            _that.setCurrent(id);
            if (typeof (obj.clickAfter) === "function") {
                obj.clickAfter(id);
            }
        });

        obj._$tabs.on("click", ".ico-close", function (event) {
            var id = $(this).parent().data("index"),
                    isRemove = true;

            if (typeof obj.removeBefore === 'function') {
                isRemove = obj.removeBefore(id);
            }

            if (isRemove) {
                _that.del(id);
            }
            event.stopPropagation();
        });
    },
    _hasId: function (id) {
        var $tabs = this.obj._$tabs;
        if ($tabs.find('div[data-index="' + id + '"]').length === 0) {
            return false;
        }
        return true;
    },
    add: function (data) {
        // 添加当前 tab
        if (this.getCurrentId() === data.id) {
            return false;
        }

        // 当前 tab 已经存在
        if (this._hasId(data.id)) {
            this.setCurrent(data.id);
            return false;
        }

        var $tabsPanel = this.obj._$tabsPanel,
                $tabs = this.obj._$tabs;

        $tabs.append('<div data-index="' + data.id + '">'
                + data.title + ' <span class="ico-close font-ico"></span></div>');
        $tabsPanel.append('<div data-index="' + data.id + '">' + data.content
                + '</div>');

        this.setCurrent(data.id);

        if (typeof data.after === 'function') {
            data.after();
        }
    },
    del: function (id) {
        var $tabsPanel = this.obj._$tabsPanel,
                $tabs = this.obj._$tabs,
                stack = this.obj._stack,
                prevId = null;

        $tabs.children("div[data-index='" + id + "']").remove();
        $tabsPanel.children("div[data-index='" + id + "']").remove();

        // 移除堆栈中该 id
        for (var i = 0; i < stack.length; i++) {
            if (id === stack[i]) {
                stack.splice(i, 1);
                i--;
            }
        }

        prevId = stack[stack.length - 1];

        if (typeof this.obj.removeAfter === 'function') {
            this.obj.removeAfter(id, prevId);
        }

        this.setCurrent(prevId);
    },
    getCurrentId: function () {
        var $tabs = this.obj._$tabs;
        return $tabs.children(".current").data("index");
    },
    setCurrent: function (path) {
        if (!path) {
            return false;
        }

        var $tabsPanel = this.obj._$tabsPanel,
                $tabs = this.obj._$tabs;

        var $currentTab = $tabs.children(".current");
        if ($currentTab.data("index") === path) {
            return false;
        }

        // tab 顺序入栈,如栈满则清除
        var stack = this.obj._stack;
        if (stack.length === this.obj.STACKSIZE) {
            stack.splice(0, 1);
        }
        if (stack[stack.length - 1] !== path) {
            this.obj._stack.push(path);
        }

        $tabs.children("div").removeClass("current");
        $tabsPanel.children("div").hide();

        $tabs.children('div[data-index="' + path + '"]').addClass("current");
        $tabsPanel.children('div[data-index="' + path + '"]').show();

        if (typeof this.obj.setAfter === 'function') {
            this.obj.setAfter();
        }

        var id = this.getCurrentId();
        if ("startPage" === id) {
            return;
        }

        // set tree node selected
        var tId = tree.getTIdByPath(id);
        var node = tree.fileTree.getNodeByTId(tId);
        tree.fileTree.selectNode(node);
        wide.curNode = node;

        for (var i = 0, ii = editors.data.length; i < ii; i++) {
            if (editors.data[i].id === id) {
                wide.curEditor = editors.data[i].editor;
                break;
            }
        }

        if (wide.curEditor) {
            var cursor = wide.curEditor.getCursor();
            wide.curEditor.setCursor(cursor);
            wide.curEditor.focus();
            wide.refreshOutline();

            $(".footer .cursor").text('|   ' + (cursor.line + 1) + ':' + (cursor.ch + 1) + '   |');
        }
    }
});