mirror of
https://github.com/ohwgiles/laminar.git
synced 2024-10-27 20:34:20 +00:00
report running state, only show spinner when actually running
This commit is contained in:
parent
87ebf91f1e
commit
f181c87d3b
@ -156,6 +156,7 @@ void Laminar::sendStatus(LaminarClient* client) {
|
|||||||
j.set("queued", run->startedAt - run->queuedAt);
|
j.set("queued", run->startedAt - run->queuedAt);
|
||||||
j.set("started", run->startedAt);
|
j.set("started", run->startedAt);
|
||||||
j.set("reason", run->reason());
|
j.set("reason", run->reason());
|
||||||
|
j.set("result", to_string(RunState::RUNNING));
|
||||||
db->stmt("SELECT completedAt - startedAt FROM builds WHERE name = ? ORDER BY completedAt DESC LIMIT 1")
|
db->stmt("SELECT completedAt - startedAt FROM builds WHERE name = ? ORDER BY completedAt DESC LIMIT 1")
|
||||||
.bind(run->name)
|
.bind(run->name)
|
||||||
.fetch<int>([&](int etc){
|
.fetch<int>([&](int etc){
|
||||||
@ -188,6 +189,7 @@ void Laminar::sendStatus(LaminarClient* client) {
|
|||||||
j.set("number", run->build);
|
j.set("number", run->build);
|
||||||
j.set("node", run->node->name);
|
j.set("node", run->node->name);
|
||||||
j.set("started", run->startedAt);
|
j.set("started", run->startedAt);
|
||||||
|
j.set("result", to_string(RunState::RUNNING));
|
||||||
j.set("reason", run->reason());
|
j.set("reason", run->reason());
|
||||||
j.EndObject();
|
j.EndObject();
|
||||||
}
|
}
|
||||||
|
@ -306,7 +306,10 @@ angular.module('laminar',['ngRoute','ngSanitize'])
|
|||||||
.run(function($rootScope) {
|
.run(function($rootScope) {
|
||||||
angular.extend($rootScope, {
|
angular.extend($rootScope, {
|
||||||
runIcon: function(result) {
|
runIcon: function(result) {
|
||||||
return result === "success" ? '<span style="color:forestgreen;font-family:\'Zapf Dingbats\';">✔</span>' : result === "failed" ? '<span style="color:crimson;">✘</span>' : '';
|
return result === "success" ? '<span style="color:forestgreen;font-family:\'Zapf Dingbats\';">✔</span>' : result === "failed" || result === "aborted" ? '<span style="color:crimson;">✘</span>' : '';
|
||||||
|
},
|
||||||
|
runComplete: function(run) {
|
||||||
|
return !!run && (run.result === 'aborted' || run.result === 'failed' || run.result === 'success');
|
||||||
},
|
},
|
||||||
formatDate: function(unix) {
|
formatDate: function(unix) {
|
||||||
// TODO reimplement when toLocaleDateString() accepts formatting
|
// TODO reimplement when toLocaleDateString() accepts formatting
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
<div class="container-fluid">
|
<div class="container-fluid">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-sm-5 col-md-6 col-lg-7">
|
<div class="col-sm-5 col-md-6 col-lg-7">
|
||||||
<h3 style="float:left"><img class="spin" src="/progress.png" ng-hide="job.result"><span ng-bind-html="runIcon(job.result)"></span> {{name}} #{{num}}</h3>
|
<h3 style="float:left"><img class="spin" src="/progress.png" ng-show="job.result === 'running'"><span ng-bind-html="runIcon(job.result)"></span> {{name}} #{{num}}</h3>
|
||||||
<nav class="pull-left">
|
<nav class="pull-left">
|
||||||
<ul class="pagination" style="margin:15px 20px">
|
<ul class="pagination" style="margin:15px 20px">
|
||||||
<li ng-show="num > 1"><a href="jobs/{{name}}/{{num-1}}">«</a></li>
|
<li ng-show="num > 1"><a href="jobs/{{name}}/{{num-1}}">«</a></li>
|
||||||
@ -13,12 +13,12 @@
|
|||||||
<dt>Reason</dt><dd>{{job.reason}}</dd>
|
<dt>Reason</dt><dd>{{job.reason}}</dd>
|
||||||
<dt>Queued for</dt><dd>{{job.queued}}s</dd>
|
<dt>Queued for</dt><dd>{{job.queued}}s</dd>
|
||||||
<dt>Started</dt><dd>{{formatDate(job.started)}}</dd>
|
<dt>Started</dt><dd>{{formatDate(job.started)}}</dd>
|
||||||
<dt ng-show="job.result">Completed</dt><dd ng-show="job.result">{{formatDate(job.completed)}}</dd>
|
<dt ng-show="runComplete(job)">Completed</dt><dd ng-show="runComplete(job)">{{formatDate(job.completed)}}</dd>
|
||||||
<dt ng-show="job.result">Duration</dt><dd ng-show="job.result">{{job.duration}}s</dd>
|
<dt ng-show="runComplete(job)">Duration</dt><dd ng-show="runComplete(job)">{{job.duration}}s</dd>
|
||||||
</dl>
|
</dl>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-sm-7 col-md-6 col-lg-5">
|
<div class="col-sm-7 col-md-6 col-lg-5">
|
||||||
<div class="progress" ng-hide="job.result">
|
<div class="progress" ng-show="job.result == 'running'">
|
||||||
<div class="progress-bar progress-bar-{{job.overtime?'warning':'info'}} progress-bar-striped {{job.etc?'':'active'}}" style="width:{{!job.etc?'100':job.progress}}%;"></div>
|
<div class="progress-bar progress-bar-{{job.overtime?'warning':'info'}} progress-bar-striped {{job.etc?'':'active'}}" style="width:{{!job.etc?'100':job.progress}}%;"></div>
|
||||||
</div>
|
</div>
|
||||||
<div class="panel panel-default" ng-show="job.artifacts.length">
|
<div class="panel panel-default" ng-show="job.artifacts.length">
|
||||||
|
@ -30,6 +30,7 @@ namespace fs = boost::filesystem;
|
|||||||
std::string to_string(const RunState& rs) {
|
std::string to_string(const RunState& rs) {
|
||||||
switch(rs) {
|
switch(rs) {
|
||||||
case RunState::PENDING: return "pending";
|
case RunState::PENDING: return "pending";
|
||||||
|
case RunState::RUNNING: return "running";
|
||||||
case RunState::ABORTED: return "aborted";
|
case RunState::ABORTED: return "aborted";
|
||||||
case RunState::FAILED: return "failed";
|
case RunState::FAILED: return "failed";
|
||||||
case RunState::SUCCESS: return "success";
|
case RunState::SUCCESS: return "success";
|
||||||
|
Loading…
Reference in New Issue
Block a user