12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- /**
- * 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.MainServiceMenuView = Em.CollectionView.extend({
- content: function () {
- return App.router.get('mainServiceController.content');
- }.property('App.router.mainServiceController.content'),
- didInsertElement: function () {
- App.router.location.addObserver('lastSetURL', this, 'renderOnRoute');
- this.renderOnRoute();
- },
- activeServiceId : null,
- /**
- * Syncs navigation menu with requested URL
- */
- renderOnRoute: function () {
- var last_url = App.router.location.lastSetURL || location.href.replace(/^[^#]*#/, '');
- if (last_url.substr(1, 4) !== 'main' || !this._childViews) {
- return;
- }
- var reg = /^\/main\/services\/(\S+)\//g;
- var sub_url = reg.exec(last_url);
- var service_id = (null != sub_url) ? sub_url[1] : 1;
- this.set('activeServiceId', service_id);
- },
- tagName: 'ul',
- classNames: ["nav", "nav-list", "nav-services"],
- itemViewClass: Em.View.extend({
- classNameBindings: ["active"],
- active: function(){
- return this.get('content.id') == this.get('parentView.activeServiceId') ? 'active' : '';
- }.property('parentView.activeServiceId'),
- alertsCount: function () {
- var allAlerts = App.router.get('clusterController.alerts');
- var serviceId = this.get('content.serviceName');
- if (serviceId) {
- return allAlerts.filterProperty('serviceType', serviceId).length;
- }
- return 0;
- }.property('App.router.clusterController.alerts'),
- templateName: require('templates/main/service/menu_item')
- })
- });
|