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
a5b97897
Commit
a5b97897
authored
Feb 01, 2021
by
Coung Ngo
Committed by
Ezekiel Kigbo
Feb 01, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Migrate subscription component toggle to GitLab UI component
Migrate use of the vue_shared toggle to GlToggle
parent
1d73ba55
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
51 additions
and
47 deletions
+51
-47
app/assets/javascripts/sidebar/components/subscriptions/subscriptions.vue
...cripts/sidebar/components/subscriptions/subscriptions.vue
+7
-8
changelogs/unreleased/cngo-migrate-subscription-toggle-to-gitlab-ui.yml
...eleased/cngo-migrate-subscription-toggle-to-gitlab-ui.yml
+5
-0
ee/spec/frontend/epic/components/sidebar_items/sidebar_subscription_spec.js
...pic/components/sidebar_items/sidebar_subscription_spec.js
+16
-21
spec/features/boards/sidebar_spec.rb
spec/features/boards/sidebar_spec.rb
+4
-4
spec/features/issues/user_toggles_subscription_spec.rb
spec/features/issues/user_toggles_subscription_spec.rb
+3
-3
spec/features/merge_request/user_manages_subscription_spec.rb
.../features/merge_request/user_manages_subscription_spec.rb
+1
-1
spec/frontend/sidebar/subscriptions_spec.js
spec/frontend/sidebar/subscriptions_spec.js
+15
-10
No files found.
app/assets/javascripts/sidebar/components/subscriptions/subscriptions.vue
View file @
a5b97897
<
script
>
<
script
>
import
{
GlIcon
,
GlTooltipDirective
}
from
'
@gitlab/ui
'
;
import
{
GlIcon
,
GlTo
ggle
,
GlTo
oltipDirective
}
from
'
@gitlab/ui
'
;
import
{
__
}
from
'
~/locale
'
;
import
{
__
}
from
'
~/locale
'
;
import
Tracking
from
'
~/tracking
'
;
import
Tracking
from
'
~/tracking
'
;
import
toggleButton
from
'
~/vue_shared/components/toggle_button.vue
'
;
import
eventHub
from
'
../../event_hub
'
;
import
eventHub
from
'
../../event_hub
'
;
const
ICON_ON
=
'
notifications
'
;
const
ICON_ON
=
'
notifications
'
;
...
@@ -16,7 +15,7 @@ export default {
...
@@ -16,7 +15,7 @@ export default {
},
},
components
:
{
components
:
{
GlIcon
,
GlIcon
,
toggleButton
,
GlToggle
,
},
},
mixins
:
[
Tracking
.
mixin
({
label
:
'
right_sidebar
'
})],
mixins
:
[
Tracking
.
mixin
({
label
:
'
right_sidebar
'
})],
props
:
{
props
:
{
...
@@ -106,7 +105,7 @@ export default {
...
@@ -106,7 +105,7 @@ export default {
</
script
>
</
script
>
<
template
>
<
template
>
<div>
<div
class=
"gl-display-flex gl-justify-content-space-between"
>
<span
<span
ref=
"tooltip"
ref=
"tooltip"
v-gl-tooltip
.
viewport
.
left
v-gl-tooltip
.
viewport
.
left
...
@@ -116,13 +115,13 @@ export default {
...
@@ -116,13 +115,13 @@ export default {
>
>
<gl-icon
:name=
"notificationIcon"
:size=
"16"
class=
"sidebar-item-icon is-active"
/>
<gl-icon
:name=
"notificationIcon"
:size=
"16"
class=
"sidebar-item-icon is-active"
/>
</span>
</span>
<span
class=
"
issuable-header-text hide-collapsed float-left
"
>
{{
notificationText
}}
</span>
<span
class=
"
hide-collapsed"
data-testid=
"subscription-title
"
>
{{
notificationText
}}
</span>
<
toggle-button
<
gl-toggle
v-if=
"!projectEmailsDisabled"
v-if=
"!projectEmailsDisabled"
ref=
"toggleButton"
:is-loading=
"showLoadingState"
:is-loading=
"showLoadingState"
:value=
"subscribed"
:value=
"subscribed"
class=
"float-right hide-collapsed js-issuable-subscribe-button"
class=
"hide-collapsed"
data-testid=
"subscription-toggle"
@
change=
"toggleSubscription"
@
change=
"toggleSubscription"
/>
/>
</div>
</div>
...
...
changelogs/unreleased/cngo-migrate-subscription-toggle-to-gitlab-ui.yml
0 → 100644
View file @
a5b97897
---
title
:
Migrate toggle button in subscription to GitLab UI component
merge_request
:
52717
author
:
type
:
changed
ee/spec/frontend/epic/components/sidebar_items/sidebar_subscription_spec.js
View file @
a5b97897
import
Vue
from
'
vue
'
;
import
{
GlToggle
}
from
'
@gitlab/ui
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
SidebarSubscription
from
'
ee/epic/components/sidebar_items/sidebar_subscription.vue
'
;
import
SidebarSubscription
from
'
ee/epic/components/sidebar_items/sidebar_subscription.vue
'
;
import
createStore
from
'
ee/epic/store
'
;
import
createStore
from
'
ee/epic/store
'
;
import
{
extendedWrapper
}
from
'
helpers/vue_test_utils_helper
'
;
import
{
mountComponentWithStore
}
from
'
helpers/vue_mount_component_helper
'
;
import
{
mockEpicMeta
,
mockEpicData
}
from
'
../../mock_data
'
;
describe
(
'
SidebarSubscriptionComponent
'
,
()
=>
{
describe
(
'
SidebarSubscriptionComponent
'
,
()
=>
{
let
vm
;
let
wrapper
;
let
store
;
beforeEach
(()
=>
{
beforeEach
(()
=>
{
const
Component
=
Vue
.
extend
(
SidebarSubscription
);
wrapper
=
extendedWrapper
(
store
=
createStore
();
mount
(
SidebarSubscription
,
{
store
.
dispatch
(
'
setEpicMeta
'
,
mockEpicMeta
);
store
:
createStore
(),
store
.
dispatch
(
'
setEpicData
'
,
mockEpicData
);
propsData
:
{
sidebarCollapsed
:
false
},
}),
vm
=
mountComponentWithStore
(
Component
,
{
);
store
,
props
:
{
sidebarCollapsed
:
false
},
});
});
});
afterEach
(()
=>
{
afterEach
(()
=>
{
vm
.
$destroy
();
wrapper
.
destroy
();
wrapper
=
null
;
});
});
describe
(
'
template
'
,
()
=>
{
describe
(
'
template
'
,
()
=>
{
it
(
'
renders subscription toggle element container
'
,
()
=>
{
it
(
'
renders subscription toggle element container
'
,
()
=>
{
expect
(
vm
.
$el
.
classList
.
contain
s
(
'
block
'
)).
toBe
(
true
);
expect
(
wrapper
.
classe
s
(
'
block
'
)).
toBe
(
true
);
expect
(
vm
.
$el
.
classList
.
contain
s
(
'
subscription
'
)).
toBe
(
true
);
expect
(
wrapper
.
classe
s
(
'
subscription
'
)).
toBe
(
true
);
});
});
it
(
'
renders toggle title text
'
,
()
=>
{
it
(
'
renders toggle title text
'
,
()
=>
{
expect
(
vm
.
$el
.
querySelector
(
'
.issuable-header-text
'
).
innerText
.
trim
()).
toBe
(
'
Notifications
'
);
expect
(
wrapper
.
findByTestId
(
'
subscription-title
'
).
text
()).
toBe
(
'
Notifications
'
);
});
});
it
(
'
renders toggle button element
'
,
()
=>
{
it
(
'
renders toggle button element
'
,
()
=>
{
expect
(
vm
.
$el
.
querySelector
(
'
.js-issuable-subscribe-button button
'
)).
not
.
toBeNull
(
);
expect
(
wrapper
.
findComponent
(
GlToggle
).
exists
()).
toBe
(
true
);
});
});
});
});
});
});
spec/features/boards/sidebar_spec.rb
View file @
a5b97897
...
@@ -411,10 +411,10 @@ RSpec.describe 'Issue Boards', :js do
...
@@ -411,10 +411,10 @@ RSpec.describe 'Issue Boards', :js do
wait_for_requests
wait_for_requests
page
.
within
(
'.subscriptions'
)
do
page
.
within
(
'.subscriptions'
)
do
find
(
'
.js-issuable-subscribe-button
button:not(.is-checked)'
).
click
find
(
'
[data-testid="subscription-toggle"]
button:not(.is-checked)'
).
click
wait_for_requests
wait_for_requests
expect
(
page
).
to
have_css
(
'
.js-issuable-subscribe-button
button.is-checked'
)
expect
(
page
).
to
have_css
(
'
[data-testid="subscription-toggle"]
button.is-checked'
)
end
end
end
end
...
@@ -427,10 +427,10 @@ RSpec.describe 'Issue Boards', :js do
...
@@ -427,10 +427,10 @@ RSpec.describe 'Issue Boards', :js do
wait_for_requests
wait_for_requests
page
.
within
(
'.subscriptions'
)
do
page
.
within
(
'.subscriptions'
)
do
find
(
'
.js-issuable-subscribe-button
button.is-checked'
).
click
find
(
'
[data-testid="subscription-toggle"]
button.is-checked'
).
click
wait_for_requests
wait_for_requests
expect
(
page
).
to
have_css
(
'
.js-issuable-subscribe-button
button:not(.is-checked)'
)
expect
(
page
).
to
have_css
(
'
[data-testid="subscription-toggle"]
button:not(.is-checked)'
)
end
end
end
end
end
end
...
...
spec/features/issues/user_toggles_subscription_spec.rb
View file @
a5b97897
...
@@ -15,13 +15,13 @@ RSpec.describe "User toggles subscription", :js do
...
@@ -15,13 +15,13 @@ RSpec.describe "User toggles subscription", :js do
end
end
it
"unsubscribes from issue"
do
it
"unsubscribes from issue"
do
subscription_button
=
find
(
".js-issuable-subscribe-button"
)
subscription_button
=
find
(
'[data-testid="subscription-toggle"]'
)
# Check we're subscribed.
# Check we're subscribed.
expect
(
subscription_button
).
to
have_css
(
"button.is-checked"
)
expect
(
subscription_button
).
to
have_css
(
"button.is-checked"
)
# Toggle subscription.
# Toggle subscription.
find
(
".js-issuable-subscribe-button button"
).
click
find
(
'[data-testid="subscription-toggle"]'
).
click
wait_for_requests
wait_for_requests
# Check we're unsubscribed.
# Check we're unsubscribed.
...
@@ -33,7 +33,7 @@ RSpec.describe "User toggles subscription", :js do
...
@@ -33,7 +33,7 @@ RSpec.describe "User toggles subscription", :js do
it
'is disabled'
do
it
'is disabled'
do
expect
(
page
).
to
have_content
(
'Notifications have been disabled by the project or group owner'
)
expect
(
page
).
to
have_content
(
'Notifications have been disabled by the project or group owner'
)
expect
(
page
).
not_to
have_selector
(
'
.js-issuable-subscribe-button
'
)
expect
(
page
).
not_to
have_selector
(
'
[data-testid="subscription-toggle"]
'
)
end
end
end
end
end
end
spec/features/merge_request/user_manages_subscription_spec.rb
View file @
a5b97897
...
@@ -15,7 +15,7 @@ RSpec.describe 'User manages subscription', :js do
...
@@ -15,7 +15,7 @@ RSpec.describe 'User manages subscription', :js do
end
end
it
'toggles subscription'
do
it
'toggles subscription'
do
page
.
within
(
'
.js-issuable-subscribe-button
'
)
do
page
.
within
(
'
[data-testid="subscription-toggle"]
'
)
do
wait_for_requests
wait_for_requests
expect
(
page
).
to
have_css
'button:not(.is-checked)'
expect
(
page
).
to
have_css
'button:not(.is-checked)'
...
...
spec/frontend/sidebar/subscriptions_spec.js
View file @
a5b97897
import
{
GlToggle
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
extendedWrapper
}
from
'
helpers/vue_test_utils_helper
'
;
import
Subscriptions
from
'
~/sidebar/components/subscriptions/subscriptions.vue
'
;
import
Subscriptions
from
'
~/sidebar/components/subscriptions/subscriptions.vue
'
;
import
eventHub
from
'
~/sidebar/event_hub
'
;
import
eventHub
from
'
~/sidebar/event_hub
'
;
import
ToggleButton
from
'
~/vue_shared/components/toggle_button.vue
'
;
describe
(
'
Subscriptions
'
,
()
=>
{
describe
(
'
Subscriptions
'
,
()
=>
{
let
wrapper
;
let
wrapper
;
const
findToggleButton
=
()
=>
wrapper
.
find
(
ToggleButton
);
const
findToggleButton
=
()
=>
wrapper
.
find
Component
(
GlToggle
);
const
mountComponent
=
(
propsData
)
=>
const
mountComponent
=
(
propsData
)
=>
extendedWrapper
(
shallowMount
(
Subscriptions
,
{
shallowMount
(
Subscriptions
,
{
propsData
,
propsData
,
});
}),
);
afterEach
(()
=>
{
afterEach
(()
=>
{
wrapper
.
destroy
();
wrapper
.
destroy
();
...
@@ -24,7 +27,7 @@ describe('Subscriptions', () => {
...
@@ -24,7 +27,7 @@ describe('Subscriptions', () => {
subscribed
:
undefined
,
subscribed
:
undefined
,
});
});
expect
(
findToggleButton
().
attributes
(
'
isloading
'
)).
toBe
(
'
true
'
);
expect
(
findToggleButton
().
props
(
'
isLoading
'
)).
toBe
(
true
);
});
});
it
(
'
is toggled "off" when currently not subscribed
'
,
()
=>
{
it
(
'
is toggled "off" when currently not subscribed
'
,
()
=>
{
...
@@ -32,7 +35,7 @@ describe('Subscriptions', () => {
...
@@ -32,7 +35,7 @@ describe('Subscriptions', () => {
subscribed
:
false
,
subscribed
:
false
,
});
});
expect
(
findToggleButton
().
attributes
(
'
value
'
)).
toBeFalsy
(
);
expect
(
findToggleButton
().
props
(
'
value
'
)).
toBe
(
false
);
});
});
it
(
'
is toggled "on" when currently subscribed
'
,
()
=>
{
it
(
'
is toggled "on" when currently subscribed
'
,
()
=>
{
...
@@ -40,7 +43,7 @@ describe('Subscriptions', () => {
...
@@ -40,7 +43,7 @@ describe('Subscriptions', () => {
subscribed
:
true
,
subscribed
:
true
,
});
});
expect
(
findToggleButton
().
attributes
(
'
value
'
)).
toBe
(
'
true
'
);
expect
(
findToggleButton
().
props
(
'
value
'
)).
toBe
(
true
);
});
});
it
(
'
toggleSubscription method emits `toggleSubscription` event on eventHub and Component
'
,
()
=>
{
it
(
'
toggleSubscription method emits `toggleSubscription` event on eventHub and Component
'
,
()
=>
{
...
@@ -93,14 +96,16 @@ describe('Subscriptions', () => {
...
@@ -93,14 +96,16 @@ describe('Subscriptions', () => {
});
});
it
(
'
sets the correct display text
'
,
()
=>
{
it
(
'
sets the correct display text
'
,
()
=>
{
expect
(
wrapper
.
find
(
'
.issuable-header-text
'
).
text
()).
toContain
(
subscribeDisabledDescription
);
expect
(
wrapper
.
findByTestId
(
'
subscription-title
'
).
text
()).
toContain
(
subscribeDisabledDescription
,
);
expect
(
wrapper
.
find
({
ref
:
'
tooltip
'
}).
attributes
(
'
title
'
)).
toBe
(
expect
(
wrapper
.
find
({
ref
:
'
tooltip
'
}).
attributes
(
'
title
'
)).
toBe
(
subscribeDisabledDescription
,
subscribeDisabledDescription
,
);
);
});
});
it
(
'
does not render the toggle button
'
,
()
=>
{
it
(
'
does not render the toggle button
'
,
()
=>
{
expect
(
wrapper
.
find
(
'
.js-issuable-subscribe-button
'
).
exists
()).
toBe
(
false
);
expect
(
findToggleButton
(
).
exists
()).
toBe
(
false
);
});
});
});
});
});
});
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