SideNavLayoutView.js 5.5 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
/**
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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
 *
 *     http://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.
 */

define(['require',
20
    'hbs!tmpl/site/SideNavLayoutView_tmpl',
21 22
    'utils/Utils',
    'utils/Globals',
23 24
    'utils/UrlLinks'
], function(require, tmpl, Utils, Globals, UrlLinks) {
25 26 27 28 29 30 31
    'use strict';

    var SideNavLayoutView = Marionette.LayoutView.extend({
        template: tmpl,

        regions: {
            RTagLayoutView: "#r_tagLayoutView",
32 33
            RSearchLayoutView: "#r_searchLayoutView",
            RGlossaryLayoutView: "#r_glossaryLayoutView"
34 35 36 37
        },
        ui: {
            tabs: '.tabs li a',
        },
38 39
        templateHelpers: function() {
            return {
40
                apiBaseUrl: UrlLinks.apiBaseUrl
41 42
            };
        },
43 44 45 46 47
        events: function() {
            var events = {},
                that = this;
            events["click " + this.ui.tabs] = function(e) {
                var urlString = "",
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
                    elementName = $(e.currentTarget).data(),
                    tabStateUrls = Globals.saveApplicationState.tabState,
                    urlStateObj = Utils.getUrlState,
                    hashUrl = Utils.getUrlState.getQueryUrl().hash;

                if (urlStateObj.isTagTab()) {
                    if (hashUrl != tabStateUrls.tagUrl) {
                        Globals.saveApplicationState.tabState.tagUrl = hashUrl;
                    }
                } else if (urlStateObj.isSearchTab()) {
                    if (hashUrl != tabStateUrls.searchUrl) {
                        Globals.saveApplicationState.tabState.searchUrl = hashUrl;
                    }
                }

63
                if (elementName.name == "tab-classification") {
64 65 66
                    urlString = tabStateUrls.tagUrl; //'#!/tag';
                } else if (elementName.name == "tab-search") {
                    urlString = tabStateUrls.searchUrl; // '#!/search';
67 68
                } else if (elementName.name == "tab-glossary") {
                    urlString = tabStateUrls.glossaryUrl; // '#!/glossary';
69
                }
70

71 72 73 74
                Utils.setUrl({
                    url: urlString,
                    mergeBrowserUrl: false,
                    trigger: true,
75
                    updateTabState: true
76 77 78 79 80
                });
            };
            return events;
        },
        initialize: function(options) {
81
            this.options = options;
82 83 84 85
        },
        onRender: function() {
            this.renderTagLayoutView();
            this.renderSearchLayoutView();
86
            this.renderGlossaryLayoutView();
87 88 89 90 91 92
            this.selectTab();

        },
        renderTagLayoutView: function() {
            var that = this;
            require(['views/tag/TagLayoutView'], function(TagLayoutView) {
93 94 95 96 97
                that.RTagLayoutView.show(new TagLayoutView(
                    _.extend(that.options, {
                        "collection": that.options.classificationDefCollection
                    })
                ));
98 99 100 101 102
            });
        },
        renderSearchLayoutView: function() {
            var that = this;
            require(['views/search/SearchLayoutView'], function(SearchLayoutView) {
103 104 105 106 107 108 109
                that.RSearchLayoutView.show(new SearchLayoutView(that.options));
            });
        },
        renderGlossaryLayoutView: function() {
            var that = this;
            require(['views/glossary/GlossaryLayoutView'], function(GlossaryLayoutView) {
                that.RGlossaryLayoutView.show(new GlossaryLayoutView(that.options));
110 111 112
            });
        },
        selectTab: function() {
113 114 115 116 117 118 119 120 121
            var that = this;
            var activeTab = function(options) {
                var view = options.view;
                that.$('.tabs').find('li a[aria-controls="tab-' + view + '"]').parents('li').addClass('active').siblings().removeClass('active');
                that.$('.tab-content').find('div#tab-' + view).addClass('active').siblings().removeClass('active');
            };
            if (Utils.getUrlState.isSearchTab() || Utils.getUrlState.isInitial()) {
                activeTab({ "view": "search" });
            } else if (Utils.getUrlState.isTagTab()) {
122 123 124
                activeTab({ "view": "classification" });
            } else if (Utils.getUrlState.isGlossaryTab()) {
                activeTab({ "view": "glossary" });
125 126 127
            } else if (Utils.getUrlState.isDetailPage()) {
                var queryParams = Utils.getUrlState.getQueryParams(),
                    view = "search";
128 129 130 131 132 133
                if (queryParams && queryParams.from) {
                    if (queryParams.from == "classification") {
                        view = "tag";
                    } else if (queryParams.from == "glossary") {
                        view = "glossary";
                    }
134 135
                }
                activeTab({ "view": view });
136 137 138 139
            }
        },
    });
    return SideNavLayoutView;
140
});