From 819fa9db875879311f911749f15c19d2f6e29d41 Mon Sep 17 00:00:00 2001 From: Brad Rydzewski Date: Sun, 9 Aug 2015 20:18:21 -0700 Subject: [PATCH] status icons, animated running icon --- .../static/scripts/filters/filter.js | 22 +++++++ .../scripts/views/builds/index/content.html | 4 +- .../scripts/views/builds/show/content.html | 4 +- cmd/drone-server/static/styles/list.css | 10 ++- cmd/drone-server/static/styles/main.css | 63 ++++++++++++------- doc/setup/sqlite.md | 24 +++++-- pkg/types/build.go | 18 +++--- 7 files changed, 102 insertions(+), 43 deletions(-) diff --git a/cmd/drone-server/static/scripts/filters/filter.js b/cmd/drone-server/static/scripts/filters/filter.js index 76eb4ee4..da6517f7 100644 --- a/cmd/drone-server/static/scripts/filters/filter.js +++ b/cmd/drone-server/static/scripts/filters/filter.js @@ -60,12 +60,34 @@ } } + /** + * message is a helper function that return the build icon. + */ + function icon() { + return function(status) { + switch(status) { + case "pending": + case "running": + return "refresh"; + case "failure": + return "clear"; + case "success": + return "check"; + case "killed": + case "error": + return "remove"; + } + return ""; + } + } + angular .module('drone') .filter('trunc', trunc) .filter('author', author) .filter('message', message) .filter('sha', sha) + .filter('icon', icon) .filter('ref', ref); })(); diff --git a/cmd/drone-server/static/scripts/views/builds/index/content.html b/cmd/drone-server/static/scripts/views/builds/index/content.html index 46fdc33e..72c493a9 100644 --- a/cmd/drone-server/static/scripts/views/builds/index/content.html +++ b/cmd/drone-server/static/scripts/views/builds/index/content.html @@ -30,7 +30,9 @@
-
+
+ {{ build.status | icon }} +

{{ build.head_commit.message }}

diff --git a/cmd/drone-server/static/scripts/views/builds/show/content.html b/cmd/drone-server/static/scripts/views/builds/show/content.html index 479191bf..9653496c 100644 --- a/cmd/drone-server/static/scripts/views/builds/show/content.html +++ b/cmd/drone-server/static/scripts/views/builds/show/content.html @@ -15,8 +15,8 @@
-
- check +
+ {{ job.status | icon }}
{{ job.number }}
diff --git a/cmd/drone-server/static/styles/list.css b/cmd/drone-server/static/styles/list.css index 4b6eef9f..0a12fc15 100644 --- a/cmd/drone-server/static/styles/list.css +++ b/cmd/drone-server/static/styles/list.css @@ -17,8 +17,8 @@ min-width: 60px; } .list .column-status { - width: 45px; - min-width: 45px; + width: 60px; + min-width: 60px; } .list .column-fill { flex: 1 1 auto; @@ -51,6 +51,12 @@ border-radius:4px; margin-left:5px; } +.user-list .column-avatar img { + width:32px; + height:32px; + border-radius:50%; + margin-left:5px; +} .list h2 { line-height:32px; font-size:18px; diff --git a/cmd/drone-server/static/styles/main.css b/cmd/drone-server/static/styles/main.css index 1d89eec1..cfd278ae 100644 --- a/cmd/drone-server/static/styles/main.css +++ b/cmd/drone-server/static/styles/main.css @@ -133,8 +133,8 @@ main article { margin-bottom:20px; } main aside { - min-width:500px; - width:500px; + min-width:450px; + width:450px; box-sizing: border-box; padding:40px 50px; } @@ -306,10 +306,10 @@ main aside > div { box-sizing: border-box; } .build-summary h2 { - line-height:25px; + line-height:21px; } .build-summary p { - margin-top:15px; + margin-top:10px; } /* @@ -326,8 +326,8 @@ main aside > div { .job-list > a > div:first-child, .job-list > li > div:first-child { - width:40px; - min-width:40px; + width:50px; + min-width:50px; } .job-list > a > div:nth-child(2), .job-list > li > div:nth-child(2) { /** TEMPORARILY HIDDEN. MAY DECIDE TO REMOVE */ @@ -507,18 +507,17 @@ menu .button span { width: 36px; vertical-align: middle; text-align: center; - font-size:32px; + font-size:24px; + color:rgba(255,255,255,0.7); } .status-small { - + width: 32px; + height: 32px; } -.status.error, -.status.killed, -.status.failure { - color: #bf616a; -} -.status.success { - color:#a3be8c; +.status-small i { + line-height: 32px; + width: 32px; + height: 32px; } /* Search Form */ @@ -607,13 +606,7 @@ pre.snippet { /* ROUND INDICATORS */ .status { - width:12px; - height:12px; - border-radius:50px; - margin-top:10px; -} -.status i { - font-size:0px; + border-radius:50%; } .status.error, .status.killed, @@ -623,10 +616,32 @@ pre.snippet { .status.success { background:#a3be8c; } +.status.running, +.status.pending { + background:#ebcb8b; +} + +.status.running i, +.status.pending i { + -webkit-animation-name: delayed-rotate; + -webkit-animation-duration: 1s; + -webkit-animation-iteration-count: infinite; + -webkit-animation-timing-function: ease-in-out; + + -moz-animation-name: delayed-rotate; + -moz-animation-duration: 1s; + -moz-animation-iteration-count: infinite; + -moz-animation-timing-function: ease-in-out; + + animation-name: delayed-rotate; + animation-duration: 1s; + animation-iteration-count: infinite; + animation-timing-function: ease-in-out; +} .build-list li > div:first-child, .job-list li > div:first-child { - width: 45px; - min-width: 45px; + width: 55px; + min-width: 55px; } diff --git a/doc/setup/sqlite.md b/doc/setup/sqlite.md index 5b0f6b47..f275f71a 100644 --- a/doc/setup/sqlite.md +++ b/doc/setup/sqlite.md @@ -9,12 +9,26 @@ DATABASE_CONFIG="/var/lib/drone/drone.sqlite" ## Sqlite3 configuration +The following is the standard URI connection scheme: + +``` +file:path[?options] +``` + The components of the datasource connection string are: -* `path` local path to sqlite database. The default value is `/var/lib/drone/drone.sqlite`. +* `file:` URI prefix to identify database files. +* `path` local path to the database file. The default value is `/var/lib/drone/drone.sqlite`. +* `?options` connection specific options. **not recommended** -This is an example connection string: +## Sqlite3 options -```bash -DATABASE_CONFIG="/var/lib/drone/drone.sqlite" -``` +This section lists all connection options used in the connection string format. Connection options are pairs in the following form: `name=value`. The value is always case sensitive. Separate options with the ampersand (i.e. &) character: + +* `vfs` opens the database connection using the VFS value. +* `mode` opens the database as `ro`, `rw`, `rwc` or `memory`. +* `cache` opens the database with `shared` or `private` cache. +* `psow` overrides the powersafe overwrite property of the database file being opened. +* `_loc` sets the location of the time format. Use `auto` to auto-detect. +* `_busy_timeout` sets the value of the `sqlite3_busy_timeout` +* `_txlock` sets the locking behavior to `immediate`, `deferred`, or `exclusive` diff --git a/pkg/types/build.go b/pkg/types/build.go index e831a701..e82336a0 100644 --- a/pkg/types/build.go +++ b/pkg/types/build.go @@ -18,15 +18,15 @@ type Build struct { Finished int64 `json:"finished_at"` Commit *Commit `json:"head_commit"` - PullRequest *PullRequest `json:"pull_request"` + PullRequest *PullRequest `json:"pull_request,omitempty"` Jobs []*Job `json:"jobs,omitempty" sql:"-"` } type PullRequest struct { - Number int `json:"number"` - Title string `json:"title"` - Base *Commit `json:"base_commit"` + Number int `json:"number,omitempty"` + Title string `json:"title,omitempty"` + Base *Commit `json:"base_commit,omitempty"` } type Commit struct { @@ -34,12 +34,12 @@ type Commit struct { Ref string `json:"ref"` Branch string `json:"branch" sql:"index:ix_commit_branch"` Message string `json:"message"` - Timestamp string `json:"timestamp"` - Remote string `json:"remote"` - Author *Author `json:"author"` + Timestamp string `json:"timestamp,omitempty"` + Remote string `json:"remote,omitempty"` + Author *Author `json:"author,omitempty"` } type Author struct { - Login string `json:"login"` - Email string `json:"email"` + Login string `json:"login,omitempty"` + Email string `json:"email,omitempty"` }