Commit ce2750e0 authored by Regis's avatar Regis

refactor - rename - simple behavior for time_ago

parent d15a0b68
......@@ -78,7 +78,7 @@
<status-scope :pipeline='pipeline'></status-scope>
<pipeline-url :pipeline='pipeline'></pipeline-url>
<commit
:tag='pipeline.ref.tag'
:tag="pipeline.ref['tag?']"
:author='pipeline.commit.author'
:title='pipeline.commit.title'
:ref='pipeline.ref'
......
......@@ -5,23 +5,23 @@
const PAGINATION_LIMIT = 31;
const SLICE_LIMIT = 29;
class PipelineUpdater {
constructor(pipelines) {
this.pipelines = pipelines;
class RealtimePaginationUpdater {
constructor(pageData) {
this.pageData = pageData;
}
updatePipelines(apiResponse) {
const update = this.pipelines.slice(0);
updatePageDiff(apiResponse) {
const diffData = this.pageData.slice(0);
apiResponse.pipelines.forEach((newPipe, i) => {
if (newPipe.commit) {
update.unshift(newPipe);
diffData.unshift(newPipe);
} else {
const newMerge = Object.assign({}, update[i], newPipe);
update[i] = newMerge;
const newMerge = Object.assign({}, diffData[i], newPipe);
diffData[i] = newMerge;
}
});
if (update.length < PAGINATION_LIMIT) return update;
return update.slice(0, SLICE_LIMIT);
if (diffData.length < PAGINATION_LIMIT) return diffData;
return diffData.slice(0, SLICE_LIMIT);
}
}
......@@ -36,6 +36,7 @@
const updatePipelineNums = (count) => {
const { all } = count;
// cannot define non camel case, so not using destructuring for running
const running = count.running_or_pending;
document.querySelector('.js-totalbuilds-count').innerHTML = all;
document.querySelector('.js-running-count').innerHTML = running;
......@@ -67,9 +68,9 @@
this.$http.get(`${url}?page=${pageNum}&updated_at=${this.updatedAt}`)
.then((response) => {
const res = JSON.parse(response.body);
const p = new PipelineUpdater(this.pipelines);
const p = new RealtimePaginationUpdater(this.pipelines);
Vue.set(this, 'updatedAt', res.updated_at);
Vue.set(this, 'pipelines', p.updatePipelines(res));
Vue.set(this, 'pipelines', p.updatePageDiff(res));
Vue.set(this, 'count', res.count);
updatePipelineNums(this.count);
subtractFromVueResources();
......
......@@ -5,6 +5,11 @@
props: [
'pipeline',
],
computed: {
localTimeFinished() {
return gl.utils.formatDate(this.pipeline.details.finished_at);
},
},
methods: {
formatSection(section) {
if (`${section}`.split('').length <= 1) return `0${section}`;
......@@ -58,13 +63,17 @@
};
},
duration() {
if (this.timeStopped()) return this.finishdate();
return this.runningdate();
// if (this.timeStopped()) return this.finishdate();
// return this.runningdate();
const { duration } = this.pipeline.details;
if (duration === 0) return '00:00:00';
if (duration !== null) return duration;
return false;
},
},
template: `
<td>
<p class="duration">
<p class="duration" v-if='duration()'>
<svg
xmlns="http://www.w3.org/2000/svg"
width="40"
......@@ -83,7 +92,7 @@
data-toggle="tooltip"
data-placement="top"
data-container="body"
:data-original-title='9 + 9'
:data-original-title='localTimeFinished'
>
{{timeStopped().words}}
</time>
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment