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
1
Merge Requests
1
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
nexedi
gitlab-ce
Commits
da7176e4
Commit
da7176e4
authored
Feb 09, 2017
by
Filipa Lacerda
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'diff-notes-refactor-ee' into 'master'
Refactored diff notes Vue app See merge request !1199
parents
9f182d2c
4f6843ca
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
37 additions
and
56 deletions
+37
-56
app/assets/javascripts/diff_notes/components/comment_resolve_btn.js.es6
...ascripts/diff_notes/components/comment_resolve_btn.js.es6
+5
-5
app/assets/javascripts/diff_notes/components/jump_to_discussion.js.es6
...vascripts/diff_notes/components/jump_to_discussion.js.es6
+5
-5
app/assets/javascripts/diff_notes/components/resolve_btn.js.es6
...sets/javascripts/diff_notes/components/resolve_btn.js.es6
+4
-6
app/assets/javascripts/diff_notes/components/resolve_count.js.es6
...ts/javascripts/diff_notes/components/resolve_count.js.es6
+0
-1
app/assets/javascripts/diff_notes/components/resolve_discussion_btn.js.es6
...ripts/diff_notes/components/resolve_discussion_btn.js.es6
+2
-5
app/assets/javascripts/diff_notes/diff_notes_bundle.js.es6
app/assets/javascripts/diff_notes/diff_notes_bundle.js.es6
+1
-1
app/assets/javascripts/diff_notes/services/resolve.js.es6
app/assets/javascripts/diff_notes/services/resolve.js.es6
+17
-28
app/assets/javascripts/notes.js
app/assets/javascripts/notes.js
+1
-1
app/views/discussions/_resolve_all.html.haml
app/views/discussions/_resolve_all.html.haml
+1
-2
app/views/projects/notes/_note.html.haml
app/views/projects/notes/_note.html.haml
+1
-2
No files found.
app/assets/javascripts/diff_notes/components/comment_resolve_btn.js.es6
View file @
da7176e4
/* eslint-disable comma-dangle, object-shorthand, func-names, no-else-return, quotes, no-lonely-if, max-len */
/* eslint-disable comma-dangle, object-shorthand, func-names, no-else-return, quotes, no-lonely-if, max-len */
/* global Vue */
/* global CommentsStore */
/* global CommentsStore */
const Vue = require('vue');
const Vue = require('vue');
...
@@ -10,13 +9,11 @@ const Vue = require('vue');
...
@@ -10,13 +9,11 @@ const Vue = require('vue');
},
},
data() {
data() {
return {
return {
textareaIsEmpty: true
textareaIsEmpty: true,
discussion: {},
};
};
},
},
computed: {
computed: {
discussion: function () {
return CommentsStore.state[this.discussionId];
},
showButton: function () {
showButton: function () {
if (this.discussion) {
if (this.discussion) {
return this.discussion.isResolvable();
return this.discussion.isResolvable();
...
@@ -43,6 +40,9 @@ const Vue = require('vue');
...
@@ -43,6 +40,9 @@ const Vue = require('vue');
}
}
}
}
},
},
created() {
this.discussion = CommentsStore.state[this.discussionId];
},
mounted: function () {
mounted: function () {
const $textarea = $(`#new-discussion-note-form-${this.discussionId} .note-textarea`);
const $textarea = $(`#new-discussion-note-form-${this.discussionId} .note-textarea`);
this.textareaIsEmpty = $textarea.val() === '';
this.textareaIsEmpty = $textarea.val() === '';
...
...
app/assets/javascripts/diff_notes/components/jump_to_discussion.js.es6
View file @
da7176e4
/* eslint-disable comma-dangle, object-shorthand, func-names, no-else-return, guard-for-in, no-restricted-syntax, one-var, space-before-function-paren, no-lonely-if, no-continue, brace-style, max-len, quotes */
/* eslint-disable comma-dangle, object-shorthand, func-names, no-else-return, guard-for-in, no-restricted-syntax, one-var, space-before-function-paren, no-lonely-if, no-continue, brace-style, max-len, quotes */
/* global Vue */
/* global DiscussionMixins */
/* global DiscussionMixins */
/* global CommentsStore */
/* global CommentsStore */
const Vue = require('vue');
const Vue = require('vue');
...
@@ -13,12 +12,10 @@ const Vue = require('vue');
...
@@ -13,12 +12,10 @@ const Vue = require('vue');
data: function () {
data: function () {
return {
return {
discussions: CommentsStore.state,
discussions: CommentsStore.state,
discussion: {},
};
};
},
},
computed: {
computed: {
discussion: function () {
return this.discussions[this.discussionId];
},
allResolved: function () {
allResolved: function () {
return this.unresolvedDiscussionCount === 0;
return this.unresolvedDiscussionCount === 0;
},
},
...
@@ -187,7 +184,10 @@ const Vue = require('vue');
...
@@ -187,7 +184,10 @@ const Vue = require('vue');
offset: -($('.navbar-gitlab').outerHeight() + $('.layout-nav').outerHeight())
offset: -($('.navbar-gitlab').outerHeight() + $('.layout-nav').outerHeight())
});
});
}
}
}
},
created() {
this.discussion = this.discussions[this.discussionId];
},
});
});
Vue.component('jump-to-discussion', JumpToDiscussion);
Vue.component('jump-to-discussion', JumpToDiscussion);
...
...
app/assets/javascripts/diff_notes/components/resolve_btn.js.es6
View file @
da7176e4
/* eslint-disable comma-dangle, object-shorthand, func-names, quote-props, no-else-return, camelcase, no-new, max-len */
/* eslint-disable comma-dangle, object-shorthand, func-names, quote-props, no-else-return, camelcase, no-new, max-len */
/* global Vue */
/* global CommentsStore */
/* global CommentsStore */
/* global ResolveService */
/* global ResolveService */
/* global Flash */
/* global Flash */
...
@@ -11,15 +10,14 @@ const Vue = require('vue');
...
@@ -11,15 +10,14 @@ const Vue = require('vue');
noteId: Number,
noteId: Number,
discussionId: String,
discussionId: String,
resolved: Boolean,
resolved: Boolean,
projectPath: String,
canResolve: Boolean,
canResolve: Boolean,
resolvedBy: String
resolvedBy: String
},
},
data: function () {
data: function () {
return {
return {
note: {},
discussions: CommentsStore.state,
discussions: CommentsStore.state,
loading: false
loading: false,
note: {},
};
};
},
},
watch: {
watch: {
...
@@ -68,10 +66,10 @@ const Vue = require('vue');
...
@@ -68,10 +66,10 @@ const Vue = require('vue');
if (this.isResolved) {
if (this.isResolved) {
promise = ResolveService
promise = ResolveService
.unresolve(this.
projectPath, this.
noteId);
.unresolve(this.noteId);
} else {
} else {
promise = ResolveService
promise = ResolveService
.resolve(this.
projectPath, this.
noteId);
.resolve(this.noteId);
}
}
promise.then((response) => {
promise.then((response) => {
...
...
app/assets/javascripts/diff_notes/components/resolve_count.js.es6
View file @
da7176e4
/* eslint-disable comma-dangle, object-shorthand, func-names, no-param-reassign */
/* eslint-disable comma-dangle, object-shorthand, func-names, no-param-reassign */
/* global Vue */
/* global DiscussionMixins */
/* global DiscussionMixins */
/* global CommentsStore */
/* global CommentsStore */
const Vue = require('vue');
const Vue = require('vue');
...
...
app/assets/javascripts/diff_notes/components/resolve_discussion_btn.js.es6
View file @
da7176e4
/* eslint-disable object-shorthand, func-names, space-before-function-paren, comma-dangle, no-else-return, quotes, max-len */
/* eslint-disable object-shorthand, func-names, space-before-function-paren, comma-dangle, no-else-return, quotes, max-len */
/* global Vue */
/* global CommentsStore */
/* global CommentsStore */
/* global ResolveService */
/* global ResolveService */
const Vue = require('vue');
const Vue = require('vue');
...
@@ -9,12 +8,10 @@ const Vue = require('vue');
...
@@ -9,12 +8,10 @@ const Vue = require('vue');
props: {
props: {
discussionId: String,
discussionId: String,
mergeRequestId: Number,
mergeRequestId: Number,
projectPath: String,
canResolve: Boolean,
canResolve: Boolean,
},
},
data: function() {
data: function() {
return {
return {
discussions: CommentsStore.state,
discussion: {},
discussion: {},
};
};
},
},
...
@@ -50,13 +47,13 @@ const Vue = require('vue');
...
@@ -50,13 +47,13 @@ const Vue = require('vue');
},
},
methods: {
methods: {
resolve: function () {
resolve: function () {
ResolveService.toggleResolveForDiscussion(this.
projectPath, this.
mergeRequestId, this.discussionId);
ResolveService.toggleResolveForDiscussion(this.mergeRequestId, this.discussionId);
}
}
},
},
created: function () {
created: function () {
CommentsStore.createDiscussion(this.discussionId, this.canResolve);
CommentsStore.createDiscussion(this.discussionId, this.canResolve);
this.discussion =
this.discussions
[this.discussionId];
this.discussion =
CommentsStore.state
[this.discussionId];
}
}
});
});
...
...
app/assets/javascripts/diff_notes/diff_notes_bundle.js.es6
View file @
da7176e4
...
@@ -18,7 +18,7 @@ $(() => {
...
@@ -18,7 +18,7 @@ $(() => {
window.gl = window.gl || {};
window.gl = window.gl || {};
window.gl.diffNoteApps = {};
window.gl.diffNoteApps = {};
window.ResolveService = new ResolveServiceClass(projectPath);
window.ResolveService = new
gl.DiffNotes
ResolveServiceClass(projectPath);
gl.diffNotesCompileComponents = () => {
gl.diffNotesCompileComponents = () => {
const $components = $(COMPONENT_SELECTOR).filter(function () {
const $components = $(COMPONENT_SELECTOR).filter(function () {
...
...
app/assets/javascripts/diff_notes/services/resolve.js.es6
View file @
da7176e4
/* eslint-disable class-methods-use-this, one-var, camelcase, no-new, comma-dangle, no-param-reassign, max-len */
/* eslint-disable class-methods-use-this, one-var, camelcase, no-new, comma-dangle, no-param-reassign, max-len */
/* global Vue */
/* global Flash */
/* global Flash */
/* global CommentsStore */
/* global CommentsStore */
const Vue = window.Vue = require('vue');
window.Vue.use(require('vue-resource'));
window.Vue.use(require('vue-resource'));
require('../../vue_shared/vue_resource_interceptor');
(() => {
(() => {
window.ResolveServiceClass = class ResolveServiceClass {
window.gl = window.gl || {};
constructor(rootPath) {
this.noteResource = Vue.resource(`${rootPath}/notes{/noteId}/resolve`);
this.discussionResource = Vue.resource(`${rootPath}/merge_requests{/mergeRequestId}/discussions{/discussionId}/resolve`);
}
setCSRF() {
Vue.http.headers.common['X-CSRF-Token'] = $.rails.csrfToken();
}
prepareRequest() {
class ResolveServiceClass {
this.setCSRF();
constructor(root) {
this.noteResource = Vue.resource(`${root}/notes{/noteId}/resolve`);
this.discussionResource = Vue.resource(`${root}/merge_requests{/mergeRequestId}/discussions{/discussionId}/resolve`);
}
}
resolve(projectPath, noteId) {
resolve(noteId) {
this.prepareRequest(projectPath);
return this.noteResource.save({ noteId }, {});
return this.noteResource.save({ noteId }, {});
}
}
unresolve(projectPath, noteId) {
unresolve(noteId) {
this.prepareRequest(projectPath);
return this.noteResource.delete({ noteId }, {});
return this.noteResource.delete({ noteId }, {});
}
}
toggleResolveForDiscussion(
projectPath,
mergeRequestId, discussionId) {
toggleResolveForDiscussion(mergeRequestId, discussionId) {
const discussion = CommentsStore.state[discussionId];
const discussion = CommentsStore.state[discussionId];
const isResolved = discussion.isResolved();
const isResolved = discussion.isResolved();
let promise;
let promise;
if (isResolved) {
if (isResolved) {
promise = this.unResolveAll(
projectPath,
mergeRequestId, discussionId);
promise = this.unResolveAll(mergeRequestId, discussionId);
} else {
} else {
promise = this.resolveAll(
projectPath,
mergeRequestId, discussionId);
promise = this.resolveAll(mergeRequestId, discussionId);
}
}
promise.then((response) => {
promise.then((response) => {
...
@@ -63,11 +54,9 @@ window.Vue.use(require('vue-resource'));
...
@@ -63,11 +54,9 @@ window.Vue.use(require('vue-resource'));
});
});
}
}
resolveAll(
projectPath,
mergeRequestId, discussionId) {
resolveAll(mergeRequestId, discussionId) {
const discussion = CommentsStore.state[discussionId];
const discussion = CommentsStore.state[discussionId];
this.prepareRequest(projectPath);
discussion.loading = true;
discussion.loading = true;
return this.discussionResource.save({
return this.discussionResource.save({
...
@@ -76,11 +65,9 @@ window.Vue.use(require('vue-resource'));
...
@@ -76,11 +65,9 @@ window.Vue.use(require('vue-resource'));
}, {});
}, {});
}
}
unResolveAll(
projectPath,
mergeRequestId, discussionId) {
unResolveAll(mergeRequestId, discussionId) {
const discussion = CommentsStore.state[discussionId];
const discussion = CommentsStore.state[discussionId];
this.prepareRequest(projectPath);
discussion.loading = true;
discussion.loading = true;
return this.discussionResource.delete({
return this.discussionResource.delete({
...
@@ -88,5 +75,7 @@ window.Vue.use(require('vue-resource'));
...
@@ -88,5 +75,7 @@ window.Vue.use(require('vue-resource'));
discussionId
discussionId
}, {});
}, {});
}
}
};
}
gl.DiffNotesResolveServiceClass = ResolveServiceClass;
})();
})();
app/assets/javascripts/notes.js
View file @
da7176e4
...
@@ -455,7 +455,7 @@ require('vendor/task_list');
...
@@ -455,7 +455,7 @@ require('vendor/task_list');
var
mergeRequestId
=
$form
.
data
(
'
noteable-iid
'
);
var
mergeRequestId
=
$form
.
data
(
'
noteable-iid
'
);
if
(
ResolveService
!=
null
)
{
if
(
ResolveService
!=
null
)
{
ResolveService
.
toggleResolveForDiscussion
(
projectPath
,
mergeRequestId
,
discussionId
);
ResolveService
.
toggleResolveForDiscussion
(
mergeRequestId
,
discussionId
);
}
}
}
}
...
...
app/views/discussions/_resolve_all.html.haml
View file @
da7176e4
-
if
discussion
.
for_merge_request?
-
if
discussion
.
for_merge_request?
%resolve-discussion-btn
{
":project-path"
=>
"'#{project_path(discussion.project)}'"
,
%resolve-discussion-btn
{
":discussion-id"
=>
"'#{discussion.id}'"
,
":discussion-id"
=>
"'#{discussion.id}'"
,
":merge-request-id"
=>
discussion
.
noteable
.
iid
,
":merge-request-id"
=>
discussion
.
noteable
.
iid
,
":can-resolve"
=>
discussion
.
can_resolve?
(
current_user
),
":can-resolve"
=>
discussion
.
can_resolve?
(
current_user
),
"inline-template"
=>
true
}
"inline-template"
=>
true
}
...
...
app/views/projects/notes/_note.html.haml
View file @
da7176e4
...
@@ -30,8 +30,7 @@
...
@@ -30,8 +30,7 @@
-
if
note
.
resolvable?
-
if
note
.
resolvable?
-
can_resolve
=
can?
(
current_user
,
:resolve_note
,
note
)
-
can_resolve
=
can?
(
current_user
,
:resolve_note
,
note
)
%resolve-btn
{
"project-path"
=>
"#{project_path(note.project)}"
,
%resolve-btn
{
"discussion-id"
=>
"#{note.discussion_id}"
,
"discussion-id"
=>
"#{note.discussion_id}"
,
":note-id"
=>
note
.
id
,
":note-id"
=>
note
.
id
,
":resolved"
=>
note
.
resolved?
,
":resolved"
=>
note
.
resolved?
,
":can-resolve"
=>
can_resolve
,
":can-resolve"
=>
can_resolve
,
...
...
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