Commit d2be7577c12766618fd8f57c8328fd847cfa8264
Exists in
master
and in
4 other branches
Merge pull request #2243 from jouve/fix_gfm_username_autocomplete
fix gfm autocomplete for usernames
Showing
9 changed files
with
80 additions
and
48 deletions
Show diff stats
app/assets/javascripts/gfm_auto_complete.js.coffee
1 | 1 | # Creates the variables for setting up GFM auto-completion |
2 | 2 | |
3 | 3 | window.GitLab ?= {} |
4 | -GitLab.GfmAutoComplete ?= {} | |
5 | - | |
6 | -# Emoji | |
7 | -data = [] | |
8 | -template = "<li data-value='${insert}'>${name} <img alt='${name}' height='20' src='${image}' width='20' /></li>" | |
9 | -GitLab.GfmAutoComplete.Emoji = {data, template} | |
10 | - | |
11 | -# Team Members | |
12 | -data = [] | |
13 | -url = ''; | |
14 | -params = {private_token: '', page: 1} | |
15 | -GitLab.GfmAutoComplete.Members = {data, url, params} | |
16 | - | |
17 | -# Add GFM auto-completion to all input fields, that accept GFM input. | |
18 | -GitLab.GfmAutoComplete.setup = -> | |
19 | - input = $('.js-gfm-input') | |
20 | - | |
4 | +GitLab.GfmAutoComplete = | |
21 | 5 | # Emoji |
22 | - input.atWho ':', | |
23 | - data: GitLab.GfmAutoComplete.Emoji.data, | |
24 | - tpl: GitLab.GfmAutoComplete.Emoji.template | |
6 | + Emoji: | |
7 | + data: [] | |
8 | + template: '<li data-value="${insert}">${name} <img alt="${name}" height="20" src="${image}" width="20" /></li>' | |
25 | 9 | |
26 | 10 | # Team Members |
27 | - input.atWho '@', (query, callback) -> | |
28 | - (getMoreMembers = -> | |
29 | - $.getJSON(GitLab.GfmAutoComplete.Members.url, GitLab.GfmAutoComplete.Members.params) | |
30 | - .success (members) -> | |
31 | - # pick the data we need | |
32 | - newMembersData = $.map(members, (m) -> m.name ) | |
33 | - | |
34 | - # add the new page of data to the rest | |
35 | - $.merge(GitLab.GfmAutoComplete.Members.data, newMembersData) | |
36 | - | |
37 | - # show the pop-up with a copy of the current data | |
38 | - callback(GitLab.GfmAutoComplete.Members.data[..]) | |
39 | - | |
40 | - # are we past the last page? | |
41 | - if newMembersData.length is 0 | |
42 | - # set static data and stop callbacks | |
43 | - input.atWho '@', | |
44 | - data: GitLab.GfmAutoComplete.Members.data | |
45 | - callback: null | |
46 | - else | |
47 | - # get next page | |
48 | - getMoreMembers() | |
49 | - | |
50 | - # so the next request gets the next page | |
51 | - GitLab.GfmAutoComplete.Members.params.page += 1 | |
52 | - ).call() | |
11 | + Members: | |
12 | + data: [] | |
13 | + url: '' | |
14 | + params: | |
15 | + private_token: '' | |
16 | + page: 1 | |
17 | + template: '<li data-value="${username}">${username} <small>${name}</small></li>' | |
18 | + | |
19 | + # Add GFM auto-completion to all input fields, that accept GFM input. | |
20 | + setup: -> | |
21 | + input = $('.js-gfm-input') | |
22 | + | |
23 | + # Emoji | |
24 | + input.atWho ':', | |
25 | + data: @Emoji.data | |
26 | + tpl: @Emoji.template | |
27 | + | |
28 | + # Team Members | |
29 | + input.atWho '@', | |
30 | + tpl: @Members.template | |
31 | + callback: (query, callback) => | |
32 | + (getMoreMembers = => | |
33 | + $.getJSON(@Members.url, @Members.params).done (members) => | |
34 | + # pick the data we need | |
35 | + newMembersData = $.map(members, (m) -> | |
36 | + username: m.username | |
37 | + name: m.name | |
38 | + ) | |
39 | + | |
40 | + # add the new page of data to the rest | |
41 | + $.merge(@Members.data, newMembersData) | |
42 | + | |
43 | + # show the pop-up with a copy of the current data | |
44 | + callback(@Members.data[..]) | |
45 | + | |
46 | + # are we past the last page? | |
47 | + if newMembersData.length is 0 | |
48 | + # set static data and stop callbacks | |
49 | + input.atWho '@', | |
50 | + data: @Members.data | |
51 | + callback: null | |
52 | + else | |
53 | + # get next page | |
54 | + getMoreMembers() | |
55 | + | |
56 | + # so the next callback requests the next page | |
57 | + @Members.params.page += 1 | |
58 | + ).call() | ... | ... |
doc/api/issues.md
... | ... | @@ -18,6 +18,7 @@ GET /issues |
18 | 18 | "assignee": null, |
19 | 19 | "author": { |
20 | 20 | "id": 1, |
21 | + "username": "john_smith", | |
21 | 22 | "email": "john@example.com", |
22 | 23 | "name": "John Smith", |
23 | 24 | "blocked": false, |
... | ... | @@ -46,6 +47,7 @@ GET /issues |
46 | 47 | }, |
47 | 48 | "assignee": { |
48 | 49 | "id": 2, |
50 | + "username": "jack_smith", | |
49 | 51 | "email": "jack@example.com", |
50 | 52 | "name": "Jack Smith", |
51 | 53 | "blocked": false, |
... | ... | @@ -53,6 +55,7 @@ GET /issues |
53 | 55 | }, |
54 | 56 | "author": { |
55 | 57 | "id": 1, |
58 | + "username": "john_smith", | |
56 | 59 | "email": "john@example.com", |
57 | 60 | "name": "John Smith", |
58 | 61 | "blocked": false, |
... | ... | @@ -110,6 +113,7 @@ Parameters: |
110 | 113 | }, |
111 | 114 | "assignee": { |
112 | 115 | "id": 2, |
116 | + "username": "jack_smith", | |
113 | 117 | "email": "jack@example.com", |
114 | 118 | "name": "Jack Smith", |
115 | 119 | "blocked": false, |
... | ... | @@ -117,6 +121,7 @@ Parameters: |
117 | 121 | }, |
118 | 122 | "author": { |
119 | 123 | "id": 1, |
124 | + "username": "john_smith", | |
120 | 125 | "email": "john@example.com", |
121 | 126 | "name": "John Smith", |
122 | 127 | "blocked": false, | ... | ... |
doc/api/merge_requests.md
... | ... | @@ -22,6 +22,7 @@ Parameters: |
22 | 22 | "merged":false, |
23 | 23 | "author":{ |
24 | 24 | "id":1, |
25 | + "username": "admin", | |
25 | 26 | "email":"admin@local.host", |
26 | 27 | "name":"Administrator", |
27 | 28 | "blocked":false, |
... | ... | @@ -29,6 +30,7 @@ Parameters: |
29 | 30 | }, |
30 | 31 | "assignee":{ |
31 | 32 | "id":1, |
33 | + "username": "admin", | |
32 | 34 | "email":"admin@local.host", |
33 | 35 | "name":"Administrator", |
34 | 36 | "blocked":false, |
... | ... | @@ -62,6 +64,7 @@ Parameters: |
62 | 64 | "merged":false, |
63 | 65 | "author":{ |
64 | 66 | "id":1, |
67 | + "username": "admin", | |
65 | 68 | "email":"admin@local.host", |
66 | 69 | "name":"Administrator", |
67 | 70 | "blocked":false, |
... | ... | @@ -69,6 +72,7 @@ Parameters: |
69 | 72 | }, |
70 | 73 | "assignee":{ |
71 | 74 | "id":1, |
75 | + "username": "admin", | |
72 | 76 | "email":"admin@local.host", |
73 | 77 | "name":"Administrator", |
74 | 78 | "blocked":false, |
... | ... | @@ -105,6 +109,7 @@ Parameters: |
105 | 109 | "merged":false, |
106 | 110 | "author":{ |
107 | 111 | "id":1, |
112 | + "username": "admin", | |
108 | 113 | "email":"admin@local.host", |
109 | 114 | "name":"Administrator", |
110 | 115 | "blocked":false, |
... | ... | @@ -112,6 +117,7 @@ Parameters: |
112 | 117 | }, |
113 | 118 | "assignee":{ |
114 | 119 | "id":1, |
120 | + "username": "admin", | |
115 | 121 | "email":"admin@local.host", |
116 | 122 | "name":"Administrator", |
117 | 123 | "blocked":false, |
... | ... | @@ -150,6 +156,7 @@ Parameters: |
150 | 156 | "merged":false, |
151 | 157 | "author":{ |
152 | 158 | "id":1, |
159 | + "username": "admin", | |
153 | 160 | "email":"admin@local.host", |
154 | 161 | "name":"Administrator", |
155 | 162 | "blocked":false, |
... | ... | @@ -157,6 +164,7 @@ Parameters: |
157 | 164 | }, |
158 | 165 | "assignee":{ |
159 | 166 | "id":1, |
167 | + "username": "admin", | |
160 | 168 | "email":"admin@local.host", |
161 | 169 | "name":"Administrator", |
162 | 170 | "blocked":false, |
... | ... | @@ -184,6 +192,7 @@ Will return created note with status `201 Created` on success, or `404 Not found |
184 | 192 | { |
185 | 193 | "author":{ |
186 | 194 | "id":1, |
195 | + "username": "admin", | |
187 | 196 | "email":"admin@local.host", |
188 | 197 | "name":"Administrator", |
189 | 198 | "blocked":false, | ... | ... |
doc/api/notes.md
doc/api/projects.md
... | ... | @@ -17,6 +17,7 @@ GET /projects |
17 | 17 | "default_branch": "master", |
18 | 18 | "owner": { |
19 | 19 | "id": 1, |
20 | + "username": "john_smith", | |
20 | 21 | "email": "john@example.com", |
21 | 22 | "name": "John Smith", |
22 | 23 | "blocked": false, |
... | ... | @@ -38,6 +39,7 @@ GET /projects |
38 | 39 | "default_branch": "api", |
39 | 40 | "owner": { |
40 | 41 | "id": 1, |
42 | + "username": "john_smith", | |
41 | 43 | "email": "john@example.com", |
42 | 44 | "name": "John Smith", |
43 | 45 | "blocked": false, |
... | ... | @@ -75,6 +77,7 @@ Parameters: |
75 | 77 | "default_branch": "api", |
76 | 78 | "owner": { |
77 | 79 | "id": 1, |
80 | + "username": "john_smith", | |
78 | 81 | "email": "john@example.com", |
79 | 82 | "name": "John Smith", |
80 | 83 | "blocked": false, |
... | ... | @@ -141,6 +144,7 @@ Parameters: |
141 | 144 | { |
142 | 145 | |
143 | 146 | "id": 1, |
147 | + "username": "john_smith", | |
144 | 148 | "email": "john@example.com", |
145 | 149 | "name": "John Smith", |
146 | 150 | "blocked": false, | ... | ... |
doc/api/session.md
doc/api/snippets.md
doc/api/users.md
... | ... | @@ -10,6 +10,7 @@ GET /users |
10 | 10 | [ |
11 | 11 | { |
12 | 12 | "id": 1, |
13 | + "username": "john_smith", | |
13 | 14 | "email": "john@example.com", |
14 | 15 | "name": "John Smith", |
15 | 16 | "blocked": false, |
... | ... | @@ -23,6 +24,7 @@ GET /users |
23 | 24 | }, |
24 | 25 | { |
25 | 26 | "id": 2, |
27 | + "username": "jack_smith", | |
26 | 28 | "email": "jack@example.com", |
27 | 29 | "name": "Jack Smith", |
28 | 30 | "blocked": false, |
... | ... | @@ -52,6 +54,7 @@ Parameters: |
52 | 54 | ```json |
53 | 55 | { |
54 | 56 | "id": 1, |
57 | + "username": "john_smith", | |
55 | 58 | "email": "john@example.com", |
56 | 59 | "name": "John Smith", |
57 | 60 | "blocked": false, |
... | ... | @@ -75,6 +78,7 @@ POST /users |
75 | 78 | Parameters: |
76 | 79 | + `email` (required) - Email |
77 | 80 | + `password` (required) - Password |
81 | ++ `username` (required) - Username | |
78 | 82 | + `name` (required) - Name |
79 | 83 | + `skype` - Skype ID |
80 | 84 | + `linkedin` - Linkedin |
... | ... | @@ -95,6 +99,7 @@ GET /user |
95 | 99 | ```json |
96 | 100 | { |
97 | 101 | "id": 1, |
102 | + "username": "john_smith", | |
98 | 103 | "email": "john@example.com", |
99 | 104 | "name": "John Smith", |
100 | 105 | "blocked": false, | ... | ... |
lib/api/entities.rb
1 | 1 | module Gitlab |
2 | 2 | module Entities |
3 | 3 | class User < Grape::Entity |
4 | - expose :id, :email, :name, :bio, :skype, :linkedin, :twitter, | |
4 | + expose :id, :username, :email, :name, :bio, :skype, :linkedin, :twitter, | |
5 | 5 | :dark_scheme, :theme_id, :blocked, :created_at |
6 | 6 | end |
7 | 7 | |
8 | 8 | class UserBasic < Grape::Entity |
9 | - expose :id, :email, :name, :blocked, :created_at | |
9 | + expose :id, :username, :email, :name, :blocked, :created_at | |
10 | 10 | end |
11 | 11 | |
12 | 12 | class UserLogin < UserBasic | ... | ... |