Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
gitlab-ce
Commits
d6d2ca03
Commit
d6d2ca03
authored
Dec 01, 2016
by
Regis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
get commit component to render needed info - work on SVG loading next
parent
3acee982
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
13 additions
and
57 deletions
+13
-57
app/assets/javascripts/vue_pipelines_index/pipelines.js.es6
app/assets/javascripts/vue_pipelines_index/pipelines.js.es6
+12
-4
app/assets/javascripts/vue_pipelines_index/store.js.es6
app/assets/javascripts/vue_pipelines_index/store.js.es6
+1
-53
No files found.
app/assets/javascripts/vue_pipelines_index/pipelines.js.es6
View file @
d6d2ca03
...
@@ -62,9 +62,17 @@
...
@@ -62,9 +62,17 @@
this.store.fetchDataLoop.call(this, Vue, this.pagenum, this.scope);
this.store.fetchDataLoop.call(this, Vue, this.pagenum, this.scope);
},
},
author(pipeline) {
author(pipeline) {
const author = pipeline.commit.author;
const { commit } = pipeline;
const author = commit.author;
if (author) return author;
if (author) return author;
return ({});
const nonUser = {
avatar_url: commit.author_gravatar_url,
web_url: `mailto:${commit.author_email}`,
username: commit.author_name,
};
return nonUser;
},
},
addTimeInterval(id, that) {
addTimeInterval(id, that) {
this.allTimeIntervals.push({ id, component: that });
this.allTimeIntervals.push({ id, component: that });
...
@@ -85,7 +93,7 @@
...
@@ -85,7 +93,7 @@
<td>
<td>
<commit
<commit
:tag="pipeline.ref['tag?']"
:tag="pipeline.ref['tag?']"
:author='
pipeline.commit.author
'
:author='
author(pipeline)
'
:title='pipeline.commit.title'
:title='pipeline.commit.title'
:ref='pipeline.ref'
:ref='pipeline.ref'
:short_sha='pipeline.commit.short_id'
:short_sha='pipeline.commit.short_id'
...
@@ -108,7 +116,7 @@
...
@@ -108,7 +116,7 @@
<i class="fa fa-spinner fa-spin"></i>
<i class="fa fa-spinner fa-spin"></i>
</div>
</div>
<gl-pagination
<gl-pagination
v-if='count.all > 0'
v-if='count.all >
3
0'
:pagenum='pagenum'
:pagenum='pagenum'
:changepage='changepage'
:changepage='changepage'
:count='count.all'
:count='count.all'
...
...
app/assets/javascripts/vue_pipelines_index/store.js.es6
View file @
d6d2ca03
...
@@ -2,30 +2,6 @@
...
@@ -2,30 +2,6 @@
/* eslint-disable no-param-reassign */
/* eslint-disable no-param-reassign */
((gl) => {
((gl) => {
const REALTIME = false;
const PAGINATION_LIMIT = 31;
const SLICE_LIMIT = 29;
class RealtimePaginationUpdater {
constructor(pageData) {
this.pageData = pageData;
}
updatePageDiff(apiResponse) {
const diffData = this.pageData.slice(0);
apiResponse.pipelines.forEach((newPipe, i) => {
if (newPipe.commit) {
diffData.unshift(newPipe);
} else {
const newMerge = Object.assign({}, diffData[i], newPipe);
diffData[i] = newMerge;
}
});
if (diffData.length < PAGINATION_LIMIT) return diffData;
return diffData.slice(0, SLICE_LIMIT);
}
}
gl.PipelineStore = class {
gl.PipelineStore = class {
fetchDataLoop(Vue, pageNum, url) {
fetchDataLoop(Vue, pageNum, url) {
const setVueResources = () => { Vue.activeResources = 1; };
const setVueResources = () => { Vue.activeResources = 1; };
...
@@ -61,46 +37,18 @@
...
@@ -61,46 +37,18 @@
this.pageRequest = false;
this.pageRequest = false;
subtractFromVueResources();
subtractFromVueResources();
}, () => new Flash(
}, () => new Flash(
'Something went wrong on our end.'
'Something went wrong on our end.',
));
const goUpdate = () =>
this.$http.get(`${url}?page=${pageNum}&updated_at=${this.updatedAt}`)
.then((response) => {
const res = JSON.parse(response.body);
const p = new RealtimePaginationUpdater(this.pipelines);
Vue.set(this, 'updatedAt', res.updated_at);
Vue.set(this, 'pipelines', p.updatePageDiff(res));
Vue.set(this, 'count', res.count);
updatePipelineNums(this.count);
subtractFromVueResources();
}, () => new Flash(
'Something went wrong on our end.'
));
));
resourceChecker();
resourceChecker();
goFetch();
goFetch();
const poller = () => {
this.intervalId = setInterval(() => {
if (this.updatedAt) {
resourceChecker();
if (Vue.activeResources > 1) return;
goUpdate();
}
}, 3000);
};
if (REALTIME) poller();
const removePipelineInterval = () => {
const removePipelineInterval = () => {
this.allTimeIntervals.forEach(e => clearInterval(e.id));
this.allTimeIntervals.forEach(e => clearInterval(e.id));
if (REALTIME) clearInterval(this.intervalId);
};
};
const startIntervalLoops = () => {
const startIntervalLoops = () => {
this.allTimeIntervals.forEach(e => e.component.startInterval());
this.allTimeIntervals.forEach(e => e.component.startInterval());
if (REALTIME) poller();
};
};
window.onbeforeunload = function onClose() {
window.onbeforeunload = function onClose() {
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment