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
0a782fcf
Commit
0a782fcf
authored
Jun 30, 2020
by
David O'Regan
Committed by
Natalia Tepluhina
Jun 30, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Leverage Apollo Cache
Swap base side bar toggle data property for apllo cache driven resolver.
parent
5f64156e
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
112 additions
and
71 deletions
+112
-71
app/assets/javascripts/alert_management/components/alert_details.vue
...javascripts/alert_management/components/alert_details.vue
+21
-20
app/assets/javascripts/alert_management/components/alert_sidebar.vue
...javascripts/alert_management/components/alert_sidebar.vue
+22
-13
app/assets/javascripts/alert_management/details.js
app/assets/javascripts/alert_management/details.js
+33
-20
app/assets/javascripts/alert_management/graphql/mutations/alert_set_assignees.graphql
..._management/graphql/mutations/alert_set_assignees.graphql
+1
-1
app/assets/javascripts/alert_management/graphql/mutations/create_issue_from_alert.graphql
...agement/graphql/mutations/create_issue_from_alert.graphql
+1
-1
app/assets/javascripts/alert_management/graphql/mutations/toggle_sidebar_status.mutation.graphql
.../graphql/mutations/toggle_sidebar_status.mutation.graphql
+3
-0
app/assets/javascripts/alert_management/graphql/mutations/update_alert_status.graphql
..._management/graphql/mutations/update_alert_status.graphql
+1
-1
app/assets/javascripts/alert_management/graphql/queries/sidebar_status.query.graphql
...t_management/graphql/queries/sidebar_status.query.graphql
+3
-0
spec/frontend/alert_management/components/alert_management_detail_spec.js
...ert_management/components/alert_management_detail_spec.js
+11
-7
spec/frontend/alert_management/components/alert_sidebar_spec.js
...rontend/alert_management/components/alert_sidebar_spec.js
+16
-8
No files found.
app/assets/javascripts/alert_management/components/alert_details.vue
View file @
0a782fcf
...
...
@@ -12,13 +12,15 @@ import {
GlTable
,
}
from
'
@gitlab/ui
'
;
import
{
s__
}
from
'
~/locale
'
;
import
query
from
'
../graphql/queries/details.query.graphql
'
;
import
alertQuery
from
'
../graphql/queries/details.query.graphql
'
;
import
sidebarStatusQuery
from
'
../graphql/queries/sidebar_status.query.graphql
'
;
import
{
fetchPolicies
}
from
'
~/lib/graphql
'
;
import
TimeAgoTooltip
from
'
~/vue_shared/components/time_ago_tooltip.vue
'
;
import
highlightCurrentUser
from
'
~/behaviors/markdown/highlight_current_user
'
;
import
initUserPopovers
from
'
~/user_popovers
'
;
import
{
ALERTS_SEVERITY_LABELS
,
trackAlertsDetailsViewsOptions
}
from
'
../constants
'
;
import
createIssueQuery
from
'
../graphql/mutations/create_issue_from_alert.graphql
'
;
import
createIssueMutation
from
'
../graphql/mutations/create_issue_from_alert.graphql
'
;
import
toggleSidebarStatusMutation
from
'
../graphql/mutations/toggle_sidebar_status.mutation.graphql
'
;
import
{
visitUrl
,
joinPaths
}
from
'
~/lib/utils/url_utility
'
;
import
Tracking
from
'
~/tracking
'
;
import
{
toggleContainerClasses
}
from
'
~/lib/utils/dom_utils
'
;
...
...
@@ -52,28 +54,27 @@ export default {
AlertSidebar
,
SystemNote
,
},
props
:
{
inject
:
{
projectPath
:
{
default
:
''
,
},
alertId
:
{
type
:
String
,
required
:
true
,
default
:
''
,
},
projectId
:
{
type
:
String
,
required
:
true
,
},
projectPath
:
{
type
:
String
,
required
:
true
,
default
:
''
,
},
projectIssuesPath
:
{
type
:
String
,
required
:
true
,
default
:
''
,
},
},
apollo
:
{
alert
:
{
fetchPolicy
:
fetchPolicies
.
CACHE_AND_NETWORK
,
query
,
query
:
alertQuery
,
variables
()
{
return
{
fullPath
:
this
.
projectPath
,
...
...
@@ -88,15 +89,18 @@ export default {
Sentry
.
captureException
(
error
);
},
},
sidebarStatus
:
{
query
:
sidebarStatusQuery
,
},
},
data
()
{
return
{
alert
:
null
,
errored
:
false
,
sidebarStatus
:
false
,
isErrorDismissed
:
false
,
createIssueError
:
''
,
issueCreationInProgress
:
false
,
sidebarCollapsed
:
false
,
sidebarErrorMessage
:
''
,
};
},
...
...
@@ -132,10 +136,10 @@ export default {
this
.
sidebarErrorMessage
=
''
;
},
toggleSidebar
()
{
this
.
sidebarCollapsed
=
!
this
.
sidebarCollapsed
;
this
.
$apollo
.
mutate
({
mutation
:
toggleSidebarStatusMutation
})
;
toggleContainerClasses
(
containerEl
,
{
'
right-sidebar-collapsed
'
:
this
.
sidebarCollapsed
,
'
right-sidebar-expanded
'
:
!
this
.
sidebarCollapsed
,
'
right-sidebar-collapsed
'
:
!
this
.
sidebarStatus
,
'
right-sidebar-expanded
'
:
this
.
sidebarStatus
,
});
},
handleAlertSidebarError
(
errorMessage
)
{
...
...
@@ -147,7 +151,7 @@ export default {
this
.
$apollo
.
mutate
({
mutation
:
createIssue
Query
,
mutation
:
createIssue
Mutation
,
variables
:
{
iid
:
this
.
alert
.
iid
,
projectPath
:
this
.
projectPath
,
...
...
@@ -197,7 +201,7 @@ export default {
<div
v-if=
"alert"
class=
"alert-management-details gl-relative"
:class=
"
{ 'pr-sm-8': sidebar
Collapsed
}"
:class=
"
{ 'pr-sm-8': sidebar
Status
}"
>
<div
class=
"gl-display-flex gl-justify-content-space-between gl-align-items-baseline gl-px-1 py-3 py-md-4 gl-border-b-1 gl-border-b-gray-200 gl-border-b-solid flex-column flex-sm-row"
...
...
@@ -330,10 +334,7 @@ export default {
</gl-tab>
</gl-tabs>
<alert-sidebar
:project-path=
"projectPath"
:project-id=
"projectId"
:alert=
"alert"
:sidebar-collapsed=
"sidebarCollapsed"
@
alert-refresh=
"alertRefresh"
@
toggle-sidebar=
"toggleSidebar"
@
alert-error=
"handleAlertSidebarError"
...
...
app/assets/javascripts/alert_management/components/alert_sidebar.vue
View file @
0a782fcf
...
...
@@ -4,6 +4,8 @@ import SidebarTodo from './sidebar/sidebar_todo.vue';
import
SidebarStatus
from
'
./sidebar/sidebar_status.vue
'
;
import
SidebarAssignees
from
'
./sidebar/sidebar_assignees.vue
'
;
import
sidebarStatusQuery
from
'
../graphql/queries/sidebar_status.query.graphql
'
;
export
default
{
components
:
{
SidebarAssignees
,
...
...
@@ -11,27 +13,34 @@ export default {
SidebarTodo
,
SidebarStatus
,
},
props
:
{
sidebarCollapsed
:
{
type
:
Boolean
,
required
:
true
,
inject
:
{
projectPath
:
{
default
:
''
,
},
projectId
:
{
type
:
String
,
required
:
true
,
default
:
''
,
},
projectPath
:
{
type
:
String
,
required
:
true
,
},
props
:
{
alert
:
{
type
:
Object
,
required
:
true
,
},
},
apollo
:
{
sidebarStatus
:
{
query
:
sidebarStatusQuery
,
},
},
data
()
{
return
{
sidebarStatus
:
false
,
};
},
computed
:
{
sidebarCollapsedClass
()
{
return
this
.
sidebar
Collapsed
?
'
right-sidebar-collapsed
'
:
'
right-sidebar-expanded
'
;
return
this
.
sidebar
Status
?
'
right-sidebar-collapsed
'
:
'
right-sidebar-expanded
'
;
},
},
};
...
...
@@ -41,10 +50,10 @@ export default {
<aside
:class=
"sidebarCollapsedClass"
class=
"right-sidebar alert-sidebar"
>
<div
class=
"issuable-sidebar js-issuable-update"
>
<sidebar-header
:sidebar-collapsed=
"sidebar
Collapsed
"
:sidebar-collapsed=
"sidebar
Status
"
@
toggle-sidebar=
"$emit('toggle-sidebar')"
/>
<sidebar-todo
v-if=
"sidebar
Collapsed"
:sidebar-collapsed=
"sidebarCollapsed
"
/>
<sidebar-todo
v-if=
"sidebar
Status"
:sidebar-collapsed=
"sidebarStatus
"
/>
<sidebar-status
:project-path=
"projectPath"
:alert=
"alert"
...
...
@@ -55,7 +64,7 @@ export default {
:project-path=
"projectPath"
:project-id=
"projectId"
:alert=
"alert"
:sidebar-collapsed=
"sidebar
Collapsed
"
:sidebar-collapsed=
"sidebar
Status
"
@
alert-refresh=
"$emit('alert-refresh')"
@
toggle-sidebar=
"$emit('toggle-sidebar')"
@
alert-error=
"$emit('alert-error', $event)"
...
...
app/assets/javascripts/alert_management/details.js
View file @
0a782fcf
...
...
@@ -3,6 +3,7 @@ import VueApollo from 'vue-apollo';
import
createDefaultClient
from
'
~/lib/graphql
'
;
import
{
defaultDataIdFromObject
}
from
'
apollo-cache-inmemory
'
;
import
AlertDetails
from
'
./components/alert_details.vue
'
;
import
sidebarStatusQuery
from
'
./graphql/queries/sidebar_status.query.graphql
'
;
Vue
.
use
(
VueApollo
);
...
...
@@ -10,10 +11,18 @@ export default selector => {
const
domEl
=
document
.
querySelector
(
selector
);
const
{
alertId
,
projectPath
,
projectIssuesPath
,
projectId
}
=
domEl
.
dataset
;
const
resolvers
=
{
Mutation
:
{
toggleSidebarStatus
:
(
_
,
__
,
{
cache
})
=>
{
const
data
=
cache
.
readQuery
({
query
:
sidebarStatusQuery
});
data
.
sidebarStatus
=
!
data
.
sidebarStatus
;
cache
.
writeQuery
({
query
:
sidebarStatusQuery
,
data
});
},
},
};
const
apolloProvider
=
new
VueApollo
({
defaultClient
:
createDefaultClient
(
{},
{
defaultClient
:
createDefaultClient
(
resolvers
,
{
cacheConfig
:
{
dataIdFromObject
:
object
=>
{
// eslint-disable-next-line no-underscore-dangle
...
...
@@ -23,26 +32,30 @@ export default selector => {
return
defaultDataIdFromObject
(
object
);
},
},
}),
});
apolloProvider
.
clients
.
defaultClient
.
cache
.
writeData
({
data
:
{
sidebarStatus
:
false
,
},
),
});
// eslint-disable-next-line no-new
new
Vue
({
el
:
selector
,
provide
:
{
projectPath
,
alertId
,
projectIssuesPath
,
projectId
,
},
apolloProvider
,
components
:
{
AlertDetails
,
},
render
(
createElement
)
{
return
createElement
(
'
alert-details
'
,
{
props
:
{
alertId
,
projectPath
,
projectId
,
projectIssuesPath
,
},
});
return
createElement
(
'
alert-details
'
,
{});
},
});
};
app/assets/javascripts/alert_management/graphql/mutations/alert_set_assignees.graphql
View file @
0a782fcf
mutation
(
$projectPath
:
ID
!,
$assigneeUsernames
:
[
String
!]!,
$iid
:
String
!)
{
mutation
alertSetAssignees
(
$projectPath
:
ID
!,
$assigneeUsernames
:
[
String
!]!,
$iid
:
String
!)
{
alertSetAssignees
(
input
:
{
iid
:
$iid
,
assigneeUsernames
:
$assigneeUsernames
,
projectPath
:
$projectPath
}
)
{
...
...
app/assets/javascripts/alert_management/graphql/mutations/create_issue_from_alert.graphql
View file @
0a782fcf
mutation
(
$projectPath
:
ID
!,
$iid
:
String
!)
{
mutation
createAlertIssue
(
$projectPath
:
ID
!,
$iid
:
String
!)
{
createAlertIssue
(
input
:
{
iid
:
$iid
,
projectPath
:
$projectPath
})
{
errors
issue
{
...
...
app/assets/javascripts/alert_management/graphql/mutations/toggle_sidebar_status.mutation.graphql
0 → 100644
View file @
0a782fcf
mutation
toggleSidebarStatus
{
toggleSidebarStatus
@client
}
app/assets/javascripts/alert_management/graphql/mutations/update_alert_status.graphql
View file @
0a782fcf
mutation
(
$projectPath
:
ID
!,
$status
:
AlertManagementStatus
!,
$iid
:
String
!)
{
mutation
updateAlertStatus
(
$projectPath
:
ID
!,
$status
:
AlertManagementStatus
!,
$iid
:
String
!)
{
updateAlertStatus
(
input
:
{
iid
:
$iid
,
status
:
$status
,
projectPath
:
$projectPath
})
{
errors
alert
{
...
...
app/assets/javascripts/alert_management/graphql/queries/sidebar_status.query.graphql
0 → 100644
View file @
0a782fcf
query
sidebarStatus
{
sidebarStatus
@client
}
spec/frontend/alert_management/components/alert_management_detail_spec.js
View file @
0a782fcf
...
...
@@ -3,7 +3,7 @@ import { GlAlert, GlLoadingIcon, GlTable } from '@gitlab/ui';
import
axios
from
'
axios
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
AlertDetails
from
'
~/alert_management/components/alert_details.vue
'
;
import
createIssue
Query
from
'
~/alert_management/graphql/mutations/create_issue_from_alert.graphql
'
;
import
createIssue
Mutation
from
'
~/alert_management/graphql/mutations/create_issue_from_alert.graphql
'
;
import
{
joinPaths
}
from
'
~/lib/utils/url_utility
'
;
import
{
trackAlertsDetailsViewsOptions
,
...
...
@@ -25,14 +25,14 @@ describe('AlertDetails', () => {
function
mountComponent
({
data
,
loading
=
false
,
mountMethod
=
shallowMount
,
stubs
=
{}
}
=
{})
{
wrapper
=
mountMethod
(
AlertDetails
,
{
pro
psData
:
{
pro
vide
:
{
alertId
:
'
alertId
'
,
projectPath
,
projectIssuesPath
,
projectId
,
},
data
()
{
return
{
alert
:
{
...
mockAlert
},
...
data
};
return
{
alert
:
{
...
mockAlert
},
sidebarStatus
:
false
,
...
data
};
},
mocks
:
{
$apollo
:
{
...
...
@@ -41,6 +41,7 @@ describe('AlertDetails', () => {
alert
:
{
loading
,
},
sidebarStatus
:
{},
},
},
},
...
...
@@ -135,7 +136,7 @@ describe('AlertDetails', () => {
it
(
'
should display "View issue" button that links the issue page when issue exists
'
,
()
=>
{
const
issueIid
=
'
3
'
;
mountComponent
({
data
:
{
alert
:
{
...
mockAlert
,
issueIid
}
},
data
:
{
alert
:
{
...
mockAlert
,
issueIid
}
,
sidebarStatus
:
false
},
});
expect
(
findViewIssueBtn
().
exists
()).
toBe
(
true
);
expect
(
findViewIssueBtn
().
attributes
(
'
href
'
)).
toBe
(
joinPaths
(
projectIssuesPath
,
issueIid
));
...
...
@@ -148,9 +149,12 @@ describe('AlertDetails', () => {
mountMethod
:
mount
,
data
:
{
alert
:
{
...
mockAlert
,
issueIid
}
},
});
return
wrapper
.
vm
.
$nextTick
().
then
(()
=>
{
expect
(
findViewIssueBtn
().
exists
()).
toBe
(
false
);
expect
(
findCreateIssueBtn
().
exists
()).
toBe
(
true
);
});
});
it
(
'
calls `$apollo.mutate` with `createIssueQuery`
'
,
()
=>
{
const
issueIid
=
'
10
'
;
...
...
@@ -160,7 +164,7 @@ describe('AlertDetails', () => {
findCreateIssueBtn
().
trigger
(
'
click
'
);
expect
(
wrapper
.
vm
.
$apollo
.
mutate
).
toHaveBeenCalledWith
({
mutation
:
createIssue
Query
,
mutation
:
createIssue
Mutation
,
variables
:
{
iid
:
mockAlert
.
iid
,
projectPath
,
...
...
spec/frontend/alert_management/components/alert_sidebar_spec.js
View file @
0a782fcf
...
...
@@ -11,20 +11,28 @@ describe('Alert Details Sidebar', () => {
let
wrapper
;
let
mock
;
function
mountComponent
({
sidebarCollapsed
=
true
,
mountMethod
=
shallowMount
,
stubs
=
{},
alert
=
{},
}
=
{})
{
function
mountComponent
({
mountMethod
=
shallowMount
,
stubs
=
{},
alert
=
{}
}
=
{})
{
wrapper
=
mountMethod
(
AlertSidebar
,
{
data
()
{
return
{
sidebarStatus
:
false
,
};
},
propsData
:
{
alert
,
sidebarCollapsed
,
},
provide
:
{
projectPath
:
'
projectPath
'
,
projectId
:
'
1
'
,
},
stubs
,
mocks
:
{
$apollo
:
{
queries
:
{
sidebarStatus
:
{},
},
},
},
});
}
...
...
@@ -42,7 +50,7 @@ describe('Alert Details Sidebar', () => {
});
it
(
'
open as default
'
,
()
=>
{
expect
(
wrapper
.
props
(
'
sidebarCollaps
ed
'
)).
toBe
(
true
);
expect
(
wrapper
.
classes
(
'
right-sidebar-expand
ed
'
)).
toBe
(
true
);
});
it
(
'
should render side bar assignee dropdown
'
,
()
=>
{
...
...
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