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
12b3a203
Commit
12b3a203
authored
Dec 21, 2018
by
Heinrich Lee Yu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
CE backport for `reference` in gfm_autocomplete
Currently not used by any CE code
parent
b83be503
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
51 additions
and
9 deletions
+51
-9
app/assets/javascripts/gfm_auto_complete.js
app/assets/javascripts/gfm_auto_complete.js
+15
-9
spec/javascripts/gfm_auto_complete_spec.js
spec/javascripts/gfm_auto_complete_spec.js
+36
-0
No files found.
app/assets/javascripts/gfm_auto_complete.js
View file @
12b3a203
...
...
@@ -221,13 +221,13 @@ class GfmAutoComplete {
displayTpl
(
value
)
{
let
tmpl
=
GfmAutoComplete
.
Loading
.
template
;
if
(
value
.
title
!=
null
)
{
tmpl
=
GfmAutoComplete
.
Issues
.
templateFunction
(
value
.
id
,
value
.
title
);
tmpl
=
GfmAutoComplete
.
Issues
.
templateFunction
(
value
);
}
return
tmpl
;
},
data
:
GfmAutoComplete
.
defaultLoadingData
,
// eslint-disable-next-line no-template-curly-in-string
insertTpl
:
'
${atwho-at}${id}
'
,
insertTpl
:
GfmAutoComplete
.
Issues
.
insertTemplateFunction
,
skipSpecialCharacterTest
:
true
,
callbacks
:
{
...
this
.
getDefaultCallbacks
(),
beforeSave
(
issues
)
{
...
...
@@ -238,6 +238,7 @@ class GfmAutoComplete {
return
{
id
:
i
.
iid
,
title
:
sanitize
(
i
.
title
),
reference
:
i
.
reference
,
search
:
`
${
i
.
iid
}
${
i
.
title
}
`
,
};
});
...
...
@@ -287,13 +288,13 @@ class GfmAutoComplete {
displayTpl
(
value
)
{
let
tmpl
=
GfmAutoComplete
.
Loading
.
template
;
if
(
value
.
title
!=
null
)
{
tmpl
=
GfmAutoComplete
.
Issues
.
templateFunction
(
value
.
id
,
value
.
title
);
tmpl
=
GfmAutoComplete
.
Issues
.
templateFunction
(
value
);
}
return
tmpl
;
},
data
:
GfmAutoComplete
.
defaultLoadingData
,
// eslint-disable-next-line no-template-curly-in-string
insertTpl
:
'
${atwho-at}${id}
'
,
insertTpl
:
GfmAutoComplete
.
Issues
.
insertTemplateFunction
,
skipSpecialCharacterTest
:
true
,
callbacks
:
{
...
this
.
getDefaultCallbacks
(),
beforeSave
(
merges
)
{
...
...
@@ -304,6 +305,7 @@ class GfmAutoComplete {
return
{
id
:
m
.
iid
,
title
:
sanitize
(
m
.
title
),
reference
:
m
.
reference
,
search
:
`
${
m
.
iid
}
${
m
.
title
}
`
,
};
});
...
...
@@ -397,7 +399,7 @@ class GfmAutoComplete {
displayTpl
(
value
)
{
let
tmpl
=
GfmAutoComplete
.
Loading
.
template
;
if
(
value
.
title
!=
null
)
{
tmpl
=
GfmAutoComplete
.
Issues
.
templateFunction
(
value
.
id
,
value
.
title
);
tmpl
=
GfmAutoComplete
.
Issues
.
templateFunction
(
value
);
}
return
tmpl
;
},
...
...
@@ -596,8 +598,12 @@ GfmAutoComplete.Labels = {
};
// Issues, MergeRequests and Snippets
GfmAutoComplete
.
Issues
=
{
templateFunction
(
id
,
title
)
{
return
`<li><small>
${
id
}
</small>
${
_
.
escape
(
title
)}
</li>`
;
insertTemplateFunction
(
value
)
{
// eslint-disable-next-line no-template-curly-in-string
return
value
.
reference
||
'
${atwho-at}${id}
'
;
},
templateFunction
({
id
,
title
,
reference
})
{
return
`<li><small>
${
reference
||
id
}
</small>
${
_
.
escape
(
title
)}
</li>`
;
},
};
// Milestones
...
...
spec/javascripts/gfm_auto_complete_spec.js
View file @
12b3a203
...
...
@@ -205,4 +205,40 @@ describe('GfmAutoComplete', function() {
expect
(
GfmAutoComplete
.
isLoading
({
title
:
'
Foo
'
})).
toBe
(
false
);
});
});
describe
(
'
Issues.insertTemplateFunction
'
,
function
()
{
it
(
'
should return default template
'
,
function
()
{
expect
(
GfmAutoComplete
.
Issues
.
insertTemplateFunction
({
id
:
5
,
title
:
'
Some Issue
'
})).
toBe
(
'
${atwho-at}${id}
'
,
// eslint-disable-line no-template-curly-in-string
);
});
it
(
'
should return reference when reference is set
'
,
function
()
{
expect
(
GfmAutoComplete
.
Issues
.
insertTemplateFunction
({
id
:
5
,
title
:
'
Some Issue
'
,
reference
:
'
grp/proj#5
'
,
}),
).
toBe
(
'
grp/proj#5
'
);
});
});
describe
(
'
Issues.templateFunction
'
,
function
()
{
it
(
'
should return html with id and title
'
,
function
()
{
expect
(
GfmAutoComplete
.
Issues
.
templateFunction
({
id
:
5
,
title
:
'
Some Issue
'
})).
toBe
(
'
<li><small>5</small> Some Issue</li>
'
,
);
});
it
(
'
should replace id with reference if reference is set
'
,
function
()
{
expect
(
GfmAutoComplete
.
Issues
.
templateFunction
({
id
:
5
,
title
:
'
Some Issue
'
,
reference
:
'
grp/proj#5
'
,
}),
).
toBe
(
'
<li><small>grp/proj#5</small> Some Issue</li>
'
);
});
});
});
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