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
82d6d6be
Commit
82d6d6be
authored
Sep 03, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
80122ef2
2f01437f
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
51 additions
and
61 deletions
+51
-61
app/assets/javascripts/sidebar/components/assignees/sidebar_assignees.vue
...cripts/sidebar/components/assignees/sidebar_assignees.vue
+2
-6
app/assets/javascripts/sidebar/services/sidebar_service.js
app/assets/javascripts/sidebar/services/sidebar_service.js
+6
-17
app/assets/javascripts/sidebar/sidebar_mediator.js
app/assets/javascripts/sidebar/sidebar_mediator.js
+14
-18
app/views/shared/issuable/_sidebar_assignees.html.haml
app/views/shared/issuable/_sidebar_assignees.html.haml
+1
-1
changelogs/unreleased/remove-vue-resource-from-sidebar-service.yml
...s/unreleased/remove-vue-resource-from-sidebar-service.yml
+5
-0
spec/javascripts/sidebar/mock_data.js
spec/javascripts/sidebar/mock_data.js
+0
-10
spec/javascripts/sidebar/sidebar_mediator_spec.js
spec/javascripts/sidebar/sidebar_mediator_spec.js
+15
-4
spec/javascripts/sidebar/sidebar_move_issue_spec.js
spec/javascripts/sidebar/sidebar_move_issue_spec.js
+8
-5
No files found.
app/assets/javascripts/sidebar/components/assignees/sidebar_assignees.vue
View file @
82d6d6be
...
@@ -67,18 +67,14 @@ export default {
...
@@ -67,18 +67,14 @@ export default {
saveAssignees
()
{
saveAssignees
()
{
this
.
loading
=
true
;
this
.
loading
=
true
;
function
setLoadingFalse
()
{
this
.
loading
=
false
;
}
this
.
mediator
this
.
mediator
.
saveAssignees
(
this
.
field
)
.
saveAssignees
(
this
.
field
)
.
then
(
setLoadingFalse
.
bind
(
this
))
.
then
(()
=>
{
.
then
(()
=>
{
this
.
loading
=
false
;
refreshUserMergeRequestCounts
();
refreshUserMergeRequestCounts
();
})
})
.
catch
(()
=>
{
.
catch
(()
=>
{
setLoadingFalse
()
;
this
.
loading
=
false
;
return
new
Flash
(
__
(
'
Error occurred when saving assignees
'
));
return
new
Flash
(
__
(
'
Error occurred when saving assignees
'
));
});
});
},
},
...
...
app/assets/javascripts/sidebar/services/sidebar_service.js
View file @
82d6d6be
import
Vue
from
'
vue
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
import
VueResource
from
'
vue-resource
'
;
Vue
.
use
(
VueResource
);
export
default
class
SidebarService
{
export
default
class
SidebarService
{
constructor
(
endpointMap
)
{
constructor
(
endpointMap
)
{
...
@@ -18,23 +15,15 @@ export default class SidebarService {
...
@@ -18,23 +15,15 @@ export default class SidebarService {
}
}
get
()
{
get
()
{
return
Vue
.
http
.
get
(
this
.
endpoint
);
return
axios
.
get
(
this
.
endpoint
);
}
}
update
(
key
,
data
)
{
update
(
key
,
data
)
{
return
Vue
.
http
.
put
(
return
axios
.
put
(
this
.
endpoint
,
{
[
key
]:
data
});
this
.
endpoint
,
{
[
key
]:
data
,
},
{
emulateJSON
:
true
,
},
);
}
}
getProjectsAutocomplete
(
searchTerm
)
{
getProjectsAutocomplete
(
searchTerm
)
{
return
Vue
.
http
.
get
(
this
.
projectsAutocompleteEndpoint
,
{
return
axios
.
get
(
this
.
projectsAutocompleteEndpoint
,
{
params
:
{
params
:
{
search
:
searchTerm
,
search
:
searchTerm
,
},
},
...
@@ -42,11 +31,11 @@ export default class SidebarService {
...
@@ -42,11 +31,11 @@ export default class SidebarService {
}
}
toggleSubscription
()
{
toggleSubscription
()
{
return
Vue
.
http
.
post
(
this
.
toggleSubscriptionEndpoint
);
return
axios
.
post
(
this
.
toggleSubscriptionEndpoint
);
}
}
moveIssue
(
moveToProjectId
)
{
moveIssue
(
moveToProjectId
)
{
return
Vue
.
http
.
post
(
this
.
moveIssueEndpoint
,
{
return
axios
.
post
(
this
.
moveIssueEndpoint
,
{
move_to_project_id
:
moveToProjectId
,
move_to_project_id
:
moveToProjectId
,
});
});
}
}
...
...
app/assets/javascripts/sidebar/sidebar_mediator.js
View file @
82d6d6be
...
@@ -32,7 +32,10 @@ export default class SidebarMediator {
...
@@ -32,7 +32,10 @@ export default class SidebarMediator {
// If there are no ids, that means we have to unassign (which is id = 0)
// If there are no ids, that means we have to unassign (which is id = 0)
// And it only accepts an array, hence [0]
// And it only accepts an array, hence [0]
return
this
.
service
.
update
(
field
,
selected
.
length
===
0
?
[
0
]
:
selected
);
const
assignees
=
selected
.
length
===
0
?
[
0
]
:
selected
;
const
data
=
{
assignee_ids
:
assignees
};
return
this
.
service
.
update
(
field
,
data
);
}
}
setMoveToProjectId
(
projectId
)
{
setMoveToProjectId
(
projectId
)
{
...
@@ -42,8 +45,7 @@ export default class SidebarMediator {
...
@@ -42,8 +45,7 @@ export default class SidebarMediator {
fetch
()
{
fetch
()
{
return
this
.
service
return
this
.
service
.
get
()
.
get
()
.
then
(
response
=>
response
.
json
())
.
then
(({
data
})
=>
{
.
then
(
data
=>
{
this
.
processFetchedData
(
data
);
this
.
processFetchedData
(
data
);
})
})
.
catch
(()
=>
new
Flash
(
__
(
'
Error occurred when fetching sidebar data
'
)));
.
catch
(()
=>
new
Flash
(
__
(
'
Error occurred when fetching sidebar data
'
)));
...
@@ -71,20 +73,14 @@ export default class SidebarMediator {
...
@@ -71,20 +73,14 @@ export default class SidebarMediator {
}
}
fetchAutocompleteProjects
(
searchTerm
)
{
fetchAutocompleteProjects
(
searchTerm
)
{
return
this
.
service
return
this
.
service
.
getProjectsAutocomplete
(
searchTerm
).
then
(({
data
})
=>
{
.
getProjectsAutocomplete
(
searchTerm
)
.
then
(
response
=>
response
.
json
())
.
then
(
data
=>
{
this
.
store
.
setAutocompleteProjects
(
data
);
this
.
store
.
setAutocompleteProjects
(
data
);
return
this
.
store
.
autocompleteProjects
;
return
this
.
store
.
autocompleteProjects
;
});
});
}
}
moveIssue
()
{
moveIssue
()
{
return
this
.
service
return
this
.
service
.
moveIssue
(
this
.
store
.
moveToProjectId
).
then
(({
data
})
=>
{
.
moveIssue
(
this
.
store
.
moveToProjectId
)
.
then
(
response
=>
response
.
json
())
.
then
(
data
=>
{
if
(
window
.
location
.
pathname
!==
data
.
web_url
)
{
if
(
window
.
location
.
pathname
!==
data
.
web_url
)
{
visitUrl
(
data
.
web_url
);
visitUrl
(
data
.
web_url
);
}
}
...
...
app/views/shared/issuable/_sidebar_assignees.html.haml
View file @
82d6d6be
-
issuable_type
=
issuable_sidebar
[
:type
]
-
issuable_type
=
issuable_sidebar
[
:type
]
-
signed_in
=
!!
issuable_sidebar
.
dig
(
:current_user
,
:id
)
-
signed_in
=
!!
issuable_sidebar
.
dig
(
:current_user
,
:id
)
#js-vue-sidebar-assignees
{
data:
{
field:
"#{issuable_type}
[assignee_ids]
"
,
signed_in:
signed_in
}
}
#js-vue-sidebar-assignees
{
data:
{
field:
"#{issuable_type}"
,
signed_in:
signed_in
}
}
.title.hide-collapsed
.title.hide-collapsed
=
_
(
'Assignee'
)
=
_
(
'Assignee'
)
=
icon
(
'spinner spin'
)
=
icon
(
'spinner spin'
)
...
...
changelogs/unreleased/remove-vue-resource-from-sidebar-service.yml
0 → 100644
View file @
82d6d6be
---
title
:
Remove vue resource from sidebar service
merge_request
:
32400
author
:
Lee Tickett
type
:
other
spec/javascripts/sidebar/mock_data.js
View file @
82d6d6be
...
@@ -210,14 +210,4 @@ const mockData = {
...
@@ -210,14 +210,4 @@ const mockData = {
},
},
};
};
mockData
.
sidebarMockInterceptor
=
function
(
request
,
next
)
{
const
body
=
this
.
responseMap
[
request
.
method
.
toUpperCase
()][
request
.
url
];
next
(
request
.
respondWith
(
JSON
.
stringify
(
body
),
{
status
:
200
,
}),
);
}.
bind
(
mockData
);
export
default
mockData
;
export
default
mockData
;
spec/javascripts/sidebar/sidebar_mediator_spec.js
View file @
82d6d6be
import
_
from
'
underscore
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
Vue
from
'
vue
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
import
SidebarMediator
from
'
~/sidebar/sidebar_mediator
'
;
import
SidebarMediator
from
'
~/sidebar/sidebar_mediator
'
;
import
SidebarStore
from
'
~/sidebar/stores/sidebar_store
'
;
import
SidebarStore
from
'
~/sidebar/stores/sidebar_store
'
;
import
SidebarService
from
'
~/sidebar/services/sidebar_service
'
;
import
SidebarService
from
'
~/sidebar/services/sidebar_service
'
;
import
Mock
from
'
./mock_data
'
;
import
Mock
from
'
./mock_data
'
;
describe
(
'
Sidebar mediator
'
,
function
()
{
describe
(
'
Sidebar mediator
'
,
function
()
{
let
mock
;
beforeEach
(()
=>
{
beforeEach
(()
=>
{
Vue
.
http
.
interceptors
.
push
(
Mock
.
sidebarMockInterceptor
);
mock
=
new
MockAdapter
(
axios
);
this
.
mediator
=
new
SidebarMediator
(
Mock
.
mediator
);
this
.
mediator
=
new
SidebarMediator
(
Mock
.
mediator
);
});
});
...
@@ -15,7 +18,7 @@ describe('Sidebar mediator', function() {
...
@@ -15,7 +18,7 @@ describe('Sidebar mediator', function() {
SidebarService
.
singleton
=
null
;
SidebarService
.
singleton
=
null
;
SidebarStore
.
singleton
=
null
;
SidebarStore
.
singleton
=
null
;
SidebarMediator
.
singleton
=
null
;
SidebarMediator
.
singleton
=
null
;
Vue
.
http
.
interceptors
=
_
.
without
(
Vue
.
http
.
interceptors
,
Mock
.
sidebarMockInterceptor
);
mock
.
restore
(
);
});
});
it
(
'
assigns yourself
'
,
()
=>
{
it
(
'
assigns yourself
'
,
()
=>
{
...
@@ -26,6 +29,7 @@ describe('Sidebar mediator', function() {
...
@@ -26,6 +29,7 @@ describe('Sidebar mediator', function() {
});
});
it
(
'
saves assignees
'
,
done
=>
{
it
(
'
saves assignees
'
,
done
=>
{
mock
.
onPut
(
'
/gitlab-org/gitlab-shell/issues/5.json?serializer=sidebar_extras
'
).
reply
(
200
,
{});
this
.
mediator
this
.
mediator
.
saveAssignees
(
'
issue[assignee_ids]
'
)
.
saveAssignees
(
'
issue[assignee_ids]
'
)
.
then
(
resp
=>
{
.
then
(
resp
=>
{
...
@@ -38,6 +42,9 @@ describe('Sidebar mediator', function() {
...
@@ -38,6 +42,9 @@ describe('Sidebar mediator', function() {
it
(
'
fetches the data
'
,
done
=>
{
it
(
'
fetches the data
'
,
done
=>
{
const
mockData
=
const
mockData
=
Mock
.
responseMap
.
GET
[
'
/gitlab-org/gitlab-shell/issues/5.json?serializer=sidebar_extras
'
];
Mock
.
responseMap
.
GET
[
'
/gitlab-org/gitlab-shell/issues/5.json?serializer=sidebar_extras
'
];
mock
.
onGet
(
'
/gitlab-org/gitlab-shell/issues/5.json?serializer=sidebar_extras
'
)
.
reply
(
200
,
mockData
);
spyOn
(
this
.
mediator
,
'
processFetchedData
'
).
and
.
callThrough
();
spyOn
(
this
.
mediator
,
'
processFetchedData
'
).
and
.
callThrough
();
this
.
mediator
this
.
mediator
...
@@ -74,6 +81,7 @@ describe('Sidebar mediator', function() {
...
@@ -74,6 +81,7 @@ describe('Sidebar mediator', function() {
it
(
'
fetches autocomplete projects
'
,
done
=>
{
it
(
'
fetches autocomplete projects
'
,
done
=>
{
const
searchTerm
=
'
foo
'
;
const
searchTerm
=
'
foo
'
;
mock
.
onGet
(
'
/autocomplete/projects?project_id=15
'
).
reply
(
200
,
{});
spyOn
(
this
.
mediator
.
service
,
'
getProjectsAutocomplete
'
).
and
.
callThrough
();
spyOn
(
this
.
mediator
.
service
,
'
getProjectsAutocomplete
'
).
and
.
callThrough
();
spyOn
(
this
.
mediator
.
store
,
'
setAutocompleteProjects
'
).
and
.
callThrough
();
spyOn
(
this
.
mediator
.
store
,
'
setAutocompleteProjects
'
).
and
.
callThrough
();
...
@@ -88,7 +96,9 @@ describe('Sidebar mediator', function() {
...
@@ -88,7 +96,9 @@ describe('Sidebar mediator', function() {
});
});
it
(
'
moves issue
'
,
done
=>
{
it
(
'
moves issue
'
,
done
=>
{
const
mockData
=
Mock
.
responseMap
.
POST
[
'
/gitlab-org/gitlab-shell/issues/5/move
'
];
const
moveToProjectId
=
7
;
const
moveToProjectId
=
7
;
mock
.
onPost
(
'
/gitlab-org/gitlab-shell/issues/5/move
'
).
reply
(
200
,
mockData
);
this
.
mediator
.
store
.
setMoveToProjectId
(
moveToProjectId
);
this
.
mediator
.
store
.
setMoveToProjectId
(
moveToProjectId
);
spyOn
(
this
.
mediator
.
service
,
'
moveIssue
'
).
and
.
callThrough
();
spyOn
(
this
.
mediator
.
service
,
'
moveIssue
'
).
and
.
callThrough
();
const
visitUrl
=
spyOnDependency
(
SidebarMediator
,
'
visitUrl
'
);
const
visitUrl
=
spyOnDependency
(
SidebarMediator
,
'
visitUrl
'
);
...
@@ -105,6 +115,7 @@ describe('Sidebar mediator', function() {
...
@@ -105,6 +115,7 @@ describe('Sidebar mediator', function() {
it
(
'
toggle subscription
'
,
done
=>
{
it
(
'
toggle subscription
'
,
done
=>
{
this
.
mediator
.
store
.
setSubscribedState
(
false
);
this
.
mediator
.
store
.
setSubscribedState
(
false
);
mock
.
onPost
(
'
/gitlab-org/gitlab-shell/issues/5/toggle_subscription
'
).
reply
(
200
,
{});
spyOn
(
this
.
mediator
.
service
,
'
toggleSubscription
'
).
and
.
callThrough
();
spyOn
(
this
.
mediator
.
service
,
'
toggleSubscription
'
).
and
.
callThrough
();
this
.
mediator
this
.
mediator
...
...
spec/javascripts/sidebar/sidebar_move_issue_spec.js
View file @
82d6d6be
import
$
from
'
jquery
'
;
import
$
from
'
jquery
'
;
import
_
from
'
underscore
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
Vue
from
'
vue
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
import
SidebarMediator
from
'
~/sidebar/sidebar_mediator
'
;
import
SidebarMediator
from
'
~/sidebar/sidebar_mediator
'
;
import
SidebarStore
from
'
~/sidebar/stores/sidebar_store
'
;
import
SidebarStore
from
'
~/sidebar/stores/sidebar_store
'
;
import
SidebarService
from
'
~/sidebar/services/sidebar_service
'
;
import
SidebarService
from
'
~/sidebar/services/sidebar_service
'
;
...
@@ -8,8 +8,12 @@ import SidebarMoveIssue from '~/sidebar/lib/sidebar_move_issue';
...
@@ -8,8 +8,12 @@ import SidebarMoveIssue from '~/sidebar/lib/sidebar_move_issue';
import
Mock
from
'
./mock_data
'
;
import
Mock
from
'
./mock_data
'
;
describe
(
'
SidebarMoveIssue
'
,
function
()
{
describe
(
'
SidebarMoveIssue
'
,
function
()
{
let
mock
;
beforeEach
(()
=>
{
beforeEach
(()
=>
{
Vue
.
http
.
interceptors
.
push
(
Mock
.
sidebarMockInterceptor
);
mock
=
new
MockAdapter
(
axios
);
const
mockData
=
Mock
.
responseMap
.
GET
[
'
/autocomplete/projects?project_id=15
'
];
mock
.
onGet
(
'
/autocomplete/projects?project_id=15
'
).
reply
(
200
,
mockData
);
this
.
mediator
=
new
SidebarMediator
(
Mock
.
mediator
);
this
.
mediator
=
new
SidebarMediator
(
Mock
.
mediator
);
this
.
$content
=
$
(
`
this
.
$content
=
$
(
`
<div class="dropdown">
<div class="dropdown">
...
@@ -37,8 +41,7 @@ describe('SidebarMoveIssue', function() {
...
@@ -37,8 +41,7 @@ describe('SidebarMoveIssue', function() {
SidebarMediator
.
singleton
=
null
;
SidebarMediator
.
singleton
=
null
;
this
.
sidebarMoveIssue
.
destroy
();
this
.
sidebarMoveIssue
.
destroy
();
mock
.
restore
();
Vue
.
http
.
interceptors
=
_
.
without
(
Vue
.
http
.
interceptors
,
Mock
.
sidebarMockInterceptor
);
});
});
describe
(
'
init
'
,
()
=>
{
describe
(
'
init
'
,
()
=>
{
...
...
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