Code coverage report for app/views/main/service/info/menu.js

Statements: 93.75% (15 / 16)      Branches: 87.5% (7 / 8)      Functions: 100% (6 / 6)      Lines: 93.75% (15 / 16)      Ignored: none     

All files » app/views/main/service/info/ » menu.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80    1                                     1   1       10             10 2           10 2           10             10       6 6       7 7         1                  
'use strict';
 
;require.register("views/main/service/info/menu", function (exports, require, module) {
  /**
   * 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.
   */
 
  var App = require('app');
 
  App.MainServiceInfoMenuView = Em.CollectionView.extend({
    tagName: 'ul',
    classNames: ["nav", "nav-tabs", "background-text"],
    content: function () {
      var menuItems = [{
        label: Em.I18n.t('services.service.info.menu.summary'),
        id: 'summary-service-tab',
        routing: 'summary',
        active: "active"
      }];
 
      if (this.get('heatmapTab')) {
        menuItems.push({
          label: Em.I18n.t('services.service.info.menu.heatmaps'),
          id: 'heatmap-service-tab',
          routing: 'heatmaps'
        });
      }
      if (this.get('configTab')) {
        menuItems.push({
          label: Em.I18n.t('services.service.info.menu.configs'),
          id: 'configs-service-tab',
          routing: 'configs'
        });
      }
      Iif (this.get('metricTab')) {
        menuItems.push({
          label: Em.I18n.t('services.service.info.menu.metrics'),
          id: 'metrics-service-tab',
          routing: 'metrics'
        });
      }
      return menuItems;
    }.property(),
 
    init: function init() {
      this._super();
      this.activateView();
    },
 
    activateView: function () {
      this.get('_childViews').forEach(function (view) {
        view.set('active', document.URL.endsWith(view.get('content.routing')) ? "active" : "");
      }, this);
    }.observes('App.router.location.lastSetURL'),
 
    deactivateChildViews: function deactivateChildViews() {
      this.get('_childViews').setEach('active', '');
    },
 
    itemViewClass: Em.View.extend({
      classNameBindings: ["active"],
      active: "",
      template: Ember.Handlebars.compile('<a {{action showInfo view.content.routing}} {{bindAttr id="view.content.id"}} href="#"> {{unbound view.content.label}}</a>')
    })
  });
});