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
Jérome Perrin
gitlab-ce
Commits
4dce23c0
Commit
4dce23c0
authored
Jul 14, 2017
by
Fatih Acet
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
IssueNotesRefactor: Implement showing placeholder note while creating note.
parent
b3da0ab5
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
108 additions
and
47 deletions
+108
-47
app/assets/javascripts/notes/components/issue_comment_form.vue
...ssets/javascripts/notes/components/issue_comment_form.vue
+45
-27
app/assets/javascripts/notes/components/issue_note_body.vue
app/assets/javascripts/notes/components/issue_note_body.vue
+2
-2
app/assets/javascripts/notes/components/issue_notes.vue
app/assets/javascripts/notes/components/issue_notes.vue
+5
-3
app/assets/javascripts/notes/components/issue_placeholder_note.vue
...s/javascripts/notes/components/issue_placeholder_note.vue
+46
-0
app/assets/javascripts/notes/components/issue_placeholder_system_note.vue
...cripts/notes/components/issue_placeholder_system_note.vue
+1
-1
app/assets/javascripts/notes/stores/issue_notes_store.js
app/assets/javascripts/notes/stores/issue_notes_store.js
+9
-14
No files found.
app/assets/javascripts/notes/components/issue_comment_form.vue
View file @
4dce23c0
...
@@ -6,8 +6,8 @@ import UserAvatarLink from '../../vue_shared/components/user_avatar/user_avatar_
...
@@ -6,8 +6,8 @@ import UserAvatarLink from '../../vue_shared/components/user_avatar/user_avatar_
import
MarkdownField
from
'
../../vue_shared/components/markdown/field.vue
'
;
import
MarkdownField
from
'
../../vue_shared/components/markdown/field.vue
'
;
import
IssueNoteSignedOutWidget
from
'
./issue_note_signed_out_widget.vue
'
;
import
IssueNoteSignedOutWidget
from
'
./issue_note_signed_out_widget.vue
'
;
import
eventHub
from
'
../event_hub
'
;
import
eventHub
from
'
../event_hub
'
;
const
REGEX_QUICK_ACTIONS
=
/^
\/\w
+.*$/gm
;
const
REGEX_QUICK_ACTIONS
=
/^
\/\w
+.*$/gm
;
export
default
{
export
default
{
data
()
{
data
()
{
const
{
create_note_path
,
state
}
=
window
.
gl
.
issueData
;
const
{
create_note_path
,
state
}
=
window
.
gl
.
issueData
;
...
@@ -67,15 +67,50 @@ export default {
...
@@ -67,15 +67,50 @@ export default {
data
.
noteData
.
note
.
type
=
'
DiscussionNote
'
;
data
.
noteData
.
note
.
type
=
'
DiscussionNote
'
;
}
}
this
.
$store
.
dispatch
(
'
createNewNote
'
,
data
)
let
placeholderText
=
this
.
note
;
.
then
(
this
.
handleNewNoteCreated
)
const
hasQuickActions
=
this
.
hasQuickActions
();
.
catch
(
this
.
handleError
);
if
(
hasQuickActions
)
{
placeholderText
=
this
.
stripQuickActions
();
}
if
(
this
.
hasQuickActions
())
{
if
(
placeholderText
.
length
)
{
this
.
$store
.
commit
(
'
showPlaceholderSystemNote
'
,
{
this
.
$store
.
commit
(
'
showPlaceholderNote
'
,
{
noteBody
:
placeholderText
,
});
}
if
(
hasQuickActions
)
{
this
.
$store
.
commit
(
'
showPlaceholderNote
'
,
{
isSystemNote
:
true
,
noteBody
:
this
.
getQuickActionText
(),
noteBody
:
this
.
getQuickActionText
(),
});
});
}
}
this
.
$store
.
dispatch
(
'
createNewNote
'
,
data
)
.
then
((
res
)
=>
{
const
{
errors
}
=
res
;
if
(
hasQuickActions
)
{
this
.
$store
.
dispatch
(
'
poll
'
);
$
(
this
.
$refs
.
textarea
).
trigger
(
'
clear-commands-cache.atwho
'
);
new
Flash
(
'
Commands applied
'
,
'
notice
'
,
$
(
this
.
$el
));
// eslint-disable-line
}
if
(
errors
)
{
if
(
errors
.
commands_only
)
{
new
Flash
(
errors
.
commands_only
,
'
notice
'
,
$
(
this
.
$el
));
// eslint-disable-line
this
.
discard
();
}
else
{
this
.
handleError
();
}
}
else
{
this
.
discard
();
}
this
.
$store
.
commit
(
'
removePlaceholderNotes
'
);
})
.
catch
(
this
.
handleError
);
}
}
if
(
withIssueAction
)
{
if
(
withIssueAction
)
{
...
@@ -94,26 +129,6 @@ export default {
...
@@ -94,26 +129,6 @@ export default {
$
(
`.js-btn-issue-action.
${
btnClass
}
:visible`
).
trigger
(
'
click
'
);
$
(
`.js-btn-issue-action.
${
btnClass
}
:visible`
).
trigger
(
'
click
'
);
}
}
},
},
handleNewNoteCreated
(
res
)
{
const
{
commands_changes
,
errors
,
valid
}
=
res
;
if
(
!
valid
&&
errors
)
{
const
{
commands_only
}
=
errors
;
if
(
commands_only
)
{
new
Flash
(
commands_only
,
'
notice
'
,
$
(
this
.
$el
));
// eslint-disable-line
$
(
this
.
$refs
.
textarea
).
trigger
(
'
clear-commands-cache.atwho
'
);
this
.
$store
.
dispatch
(
'
poll
'
);
this
.
discard
();
}
else
{
this
.
handleError
();
}
}
else
{
this
.
discard
();
}
this
.
$store
.
commit
(
'
removePlaceholderSystemNote
'
);
},
discard
()
{
discard
()
{
// `blur` is needed to clear slash commands autocomplete cache if event fired.
// `blur` is needed to clear slash commands autocomplete cache if event fired.
// `focus` is needed to remain cursor in the textarea.
// `focus` is needed to remain cursor in the textarea.
...
@@ -143,7 +158,7 @@ export default {
...
@@ -143,7 +158,7 @@ export default {
const
quickActions
=
AjaxCache
.
get
(
gl
.
GfmAutoComplete
.
dataSources
.
commands
);
const
quickActions
=
AjaxCache
.
get
(
gl
.
GfmAutoComplete
.
dataSources
.
commands
);
const
{
note
}
=
this
;
const
{
note
}
=
this
;
const
executedCommands
=
quickActions
.
filter
((
command
,
index
)
=>
{
const
executedCommands
=
quickActions
.
filter
((
command
)
=>
{
const
commandRegex
=
new
RegExp
(
`/
${
command
.
name
}
`
);
const
commandRegex
=
new
RegExp
(
`/
${
command
.
name
}
`
);
return
commandRegex
.
test
(
note
);
return
commandRegex
.
test
(
note
);
});
});
...
@@ -162,6 +177,9 @@ export default {
...
@@ -162,6 +177,9 @@ export default {
hasQuickActions
()
{
hasQuickActions
()
{
return
REGEX_QUICK_ACTIONS
.
test
(
this
.
note
);
return
REGEX_QUICK_ACTIONS
.
test
(
this
.
note
);
},
},
stripQuickActions
()
{
return
this
.
note
.
replace
(
REGEX_QUICK_ACTIONS
,
''
).
trim
();
},
},
},
mounted
()
{
mounted
()
{
const
issuableDataEl
=
document
.
getElementById
(
'
js-issuable-app-initial-data
'
);
const
issuableDataEl
=
document
.
getElementById
(
'
js-issuable-app-initial-data
'
);
...
...
app/assets/javascripts/notes/components/issue_note_body.vue
View file @
4dce23c0
...
@@ -39,10 +39,10 @@ export default {
...
@@ -39,10 +39,10 @@ export default {
},
},
initTaskList
()
{
initTaskList
()
{
if
(
this
.
canEdit
)
{
if
(
this
.
canEdit
)
{
new
TaskList
({
this
.
taskList
=
new
TaskList
({
dataType
:
'
note
'
,
dataType
:
'
note
'
,
fieldName
:
'
note
'
,
fieldName
:
'
note
'
,
selector
:
'
.notes
'
selector
:
'
.notes
'
,
});
});
}
}
},
},
...
...
app/assets/javascripts/notes/components/issue_notes.vue
View file @
4dce23c0
...
@@ -9,6 +9,7 @@ import IssueNote from './issue_note.vue';
...
@@ -9,6 +9,7 @@ import IssueNote from './issue_note.vue';
import
IssueDiscussion
from
'
./issue_discussion.vue
'
;
import
IssueDiscussion
from
'
./issue_discussion.vue
'
;
import
IssueSystemNote
from
'
./issue_system_note.vue
'
;
import
IssueSystemNote
from
'
./issue_system_note.vue
'
;
import
IssueCommentForm
from
'
./issue_comment_form.vue
'
;
import
IssueCommentForm
from
'
./issue_comment_form.vue
'
;
import
PlaceholderNote
from
'
./issue_placeholder_note.vue
'
;
import
PlaceholderSystemNote
from
'
./issue_placeholder_system_note.vue
'
;
import
PlaceholderSystemNote
from
'
./issue_placeholder_system_note.vue
'
;
Vue
.
use
(
Vuex
);
Vue
.
use
(
Vuex
);
...
@@ -27,6 +28,7 @@ export default {
...
@@ -27,6 +28,7 @@ export default {
IssueDiscussion
,
IssueDiscussion
,
IssueSystemNote
,
IssueSystemNote
,
IssueCommentForm
,
IssueCommentForm
,
PlaceholderNote
,
PlaceholderSystemNote
,
PlaceholderSystemNote
,
},
},
computed
:
{
computed
:
{
...
@@ -37,12 +39,12 @@ export default {
...
@@ -37,12 +39,12 @@ export default {
},
},
methods
:
{
methods
:
{
component
(
note
)
{
component
(
note
)
{
if
(
note
.
p
laceholderNote
)
{
if
(
note
.
isP
laceholderNote
)
{
if
(
note
.
placeholderType
===
'
systemNote
'
)
{
if
(
note
.
placeholderType
===
'
systemNote
'
)
{
return
PlaceholderSystemNote
;
return
PlaceholderSystemNote
;
}
}
}
return
PlaceholderNote
;
else
if
(
note
.
individual_note
)
{
}
else
if
(
note
.
individual_note
)
{
return
note
.
notes
[
0
].
system
?
IssueSystemNote
:
IssueNote
;
return
note
.
notes
[
0
].
system
?
IssueSystemNote
:
IssueNote
;
}
}
...
...
app/assets/javascripts/notes/components/issue_placeholder_note.vue
0 → 100644
View file @
4dce23c0
<
script
>
export
default
{
props
:
{
note
:
{
type
:
Object
,
required
:
true
,
},
},
data
()
{
return
{
currentUser
:
window
.
gl
.
currentUserData
,
};
},
};
</
script
>
<
template
>
<li
class=
"note being-posted fade-in-half timeline-entry"
>
<div
class=
"timeline-entry-inner"
>
<div
class=
"timeline-icon"
>
<a
:href=
"currentUser.path"
>
<img
:src=
"currentUser.avatar_url"
class=
"avatar s40"
/>
</a>
</div>
<div
:class=
"
{ discussion: !note.individual_note }"
class="timeline-content">
<div
class=
"note-header"
>
<div
class=
"note-header-info"
>
<a
:href=
"currentUser.path"
>
<span
class=
"hidden-xs"
>
{{
currentUser
.
name
}}
</span>
<span
class=
"note-headline-light"
>
@
{{
currentUser
.
username
}}
</span>
</a>
</div>
</div>
<div
class=
"note-body"
>
<div
class=
"note-text"
>
<p>
{{
note
.
body
}}
</p>
</div>
</div>
</div>
</div>
</li>
</
template
>
app/assets/javascripts/notes/components/issue_placeholder_system_note.vue
View file @
4dce23c0
...
@@ -4,7 +4,7 @@ export default {
...
@@ -4,7 +4,7 @@ export default {
note
:
{
note
:
{
type
:
Object
,
type
:
Object
,
required
:
true
,
required
:
true
,
}
}
,
},
},
};
};
</
script
>
</
script
>
...
...
app/assets/javascripts/notes/stores/issue_notes_store.js
View file @
4dce23c0
...
@@ -108,30 +108,25 @@ const mutations = {
...
@@ -108,30 +108,25 @@ const mutations = {
setLastFetchedAt
(
storeState
,
fetchedAt
)
{
setLastFetchedAt
(
storeState
,
fetchedAt
)
{
storeState
.
lastFetchedAt
=
fetchedAt
;
storeState
.
lastFetchedAt
=
fetchedAt
;
},
},
showPlaceholder
System
Note
(
storeState
,
data
)
{
showPlaceholderNote
(
storeState
,
data
)
{
storeState
.
notes
.
push
({
storeState
.
notes
.
push
({
placeholderNote
:
true
,
individual_note
:
true
,
individual_note
:
true
,
placeholderType
:
'
systemNote
'
,
isPlaceholderNote
:
true
,
placeholderType
:
data
.
isSystemNote
?
'
systemNote
'
:
'
note
'
,
notes
:
[
notes
:
[
{
{
id
:
'
placeholderSystemNote
'
,
body
:
data
.
noteBody
,
body
:
data
.
noteBody
,
},
},
],
],
});
});
},
},
removePlaceholder
SystemNote
(
storeState
)
{
removePlaceholder
Notes
(
storeState
)
{
let
index
=
-
1
;
const
{
notes
}
=
storeState
;
storeState
.
notes
.
forEach
((
n
,
i
)
=>
{
for
(
let
i
=
notes
.
length
-
1
;
i
>=
0
;
i
-=
1
)
{
if
(
n
.
placeholderNote
&&
n
.
placeholderType
===
'
systemNote
'
)
{
if
(
n
otes
[
i
].
isPlaceholderNote
)
{
index
=
i
;
notes
.
splice
(
i
,
1
)
;
}
}
});
if
(
index
>
-
1
)
{
storeState
.
notes
.
splice
(
index
,
1
);
}
}
},
},
};
};
...
@@ -185,7 +180,7 @@ const actions = {
...
@@ -185,7 +180,7 @@ const actions = {
return
res
;
return
res
;
});
});
},
},
poll
(
context
,
data
)
{
poll
(
context
)
{
const
{
notesPath
}
=
$
(
'
.js-notes-wrapper
'
)[
0
].
dataset
;
const
{
notesPath
}
=
$
(
'
.js-notes-wrapper
'
)[
0
].
dataset
;
return
service
return
service
...
...
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