ui: light up the nav, aggregate checks

This commit is contained in:
Jack Pearkes 2014-04-25 16:24:36 -04:00
parent 23f29dc3be
commit 4ac11b219d
6 changed files with 94 additions and 9 deletions

View File

@ -41,14 +41,20 @@
</div>
<div class="col-md-2 col-md-offset-1 col-sm-3 col-sm-offset-0">
<a class="btn btn-warning" href="#">5 checks failing</a>
{{#link-to 'services'}}<button {{bind-attr class=":btn hasFailingChecks:btn-warning:btn-success"}}>{{ checkMessage }}</button>{{/link-to}}
</div>
<div class="col-md-2 col-sm-3">
<a class="btn btn-dropdown btn-default" href="#">
{{model}}
<span class="caret"></span>
</a>
<button type="button" {{bind-attr class=":btn isDropDownVisible:btn-primary:btn-default"}} {{action "toggle"}}> {{model}} <span class="caret"></span> </button>
{{#if isDropdownVisible}}
<ul class="dropdown-menu" style="display:block;">
{{#each dc in dcs}}
<li {{action "toggle"}}>{{#link-to 'services' dc}}{{dc}}{{/link-to}}</li>
{{/each}}
</ul>
{{/if}}
</div>
</div>
</div>
@ -209,9 +215,9 @@
<script type="text/x-handlebars" id="index">
<div class="col-md-8 col-md-offset-2 vertical-center">
{{#each item in model}}
{{#link-to 'dc' item }}
<div class="panel panel-success panel-link panel-short">
<div class="panel-bar"></div>
{{#link-to 'services' item }}
<div class="panel panel-link panel-short">
<div class="panel-bar bg-green"></div>
<div class="panel-heading">
<h3 class="panel-title">
{{item}}

View File

@ -10,6 +10,47 @@ App.IndexController = Ember.Controller.extend({
// path: /:dc
//
App.DcController = Ember.Controller.extend({
isDropdownVisible: false,
checks: function() {
var services = this.get('services');
var checks = Ember.A()
// loop over all of the services we have,
// merge their checks into one.
services.forEach(function(item) {
checks = checks.concat(item.Checks)
});
// return the checks
return checks
}.property('checks'),
checkMessage: function() {
var checks = this.get('checks')
// return the message for display
if (this.get('hasFailingChecks') == true) {
return checks.filterBy('Status', 'critical').get('length') + ' checks failing';
} else {
return checks.filterBy('Status', 'passing').get('length') + ' checks passing';
}
}.property('checkMessage'),
hasFailingChecks: function() {
var checks = this.get('checks')
// Return a boolean if checks are failing.
return (checks.filterBy('Status', 'critical').get('length') > 0);
}.property('hasFailingChecks'),
actions: {
toggle: function(item){
this.toggleProperty('isDropdownVisible');
}
}
})

View File

@ -43,6 +43,18 @@ App.DcRoute = App.BaseRoute.extend({
//
model: function(params) {
return params.dc;
},
setupController: function(controller, model) {
controller.set('content', model);
controller.set('services', [App.Service.create(window.fixtures.services[0]), App.Service.create(window.fixtures.services[1])]);
controller.set('dcs', window.fixtures.dcs);
},
afterModel: function(dcs, transition) {
this.transitionTo('services');
}
});

View File

@ -5,6 +5,13 @@
App.DcView = Ember.View.extend({
templateName: 'dc',
classNames: 'dropdowns',
click: function(e){
if ($(e.target).is('.dropdowns')){
$('ul.dropdown-menu').hide();
}
}
})
//
@ -40,4 +47,3 @@ App.NodesShowView = Ember.View.extend({
//
templateName: 'node'
})

View File

@ -5,6 +5,7 @@
border-width: 2px;
color: $gray;
@include transition(background-color .1s ease-in-out);
outline: none;
&:hover {
color: darken($gray, 10%);

View File

@ -23,4 +23,23 @@
width: auto;
}
ul.dropdown-menu {
li {
a {
text-transform: uppercase;
font-weight: 600;
font-size: 12px;
color: $gray;
@include transition(background-color .1s ease-in-out);
&:hover {
color: darken($gray, 10%);
background-color: lighten($gray-background, 5%);
}
}
}
}
}