mirror of
https://github.com/yldio/copilot.git
synced 2025-01-03 23:50:13 +02:00
collapsed state for service items
This commit is contained in:
parent
c9ea9117f0
commit
08a3a0291d
@ -160,6 +160,7 @@
|
|||||||
},
|
},
|
||||||
"services": {
|
"services": {
|
||||||
"ui": {
|
"ui": {
|
||||||
|
"collapsed": [],
|
||||||
"sections": [
|
"sections": [
|
||||||
"summary",
|
"summary",
|
||||||
"instances",
|
"instances",
|
||||||
|
@ -10,5 +10,6 @@ const APP = constantCase(process.env['APP_NAME']);
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
...require('@state/thunks'),
|
...require('@state/thunks'),
|
||||||
updateRouter: createAction(`${APP}/APP/UPDATE_ROUTER`),
|
updateRouter: createAction(`${APP}/APP/UPDATE_ROUTER`),
|
||||||
toggleHeaderTooltip: createAction(`${APP}/APP/TOGGLE_HEADER_TOOLTIP`)
|
toggleHeaderTooltip: createAction(`${APP}/APP/TOGGLE_HEADER_TOOLTIP`),
|
||||||
|
toggleServiceCollapsed: createAction(`${APP}/APP/TOGGLE_SERVICE_COLLAPSED`)
|
||||||
};
|
};
|
||||||
|
@ -1,9 +1,23 @@
|
|||||||
const ReduxActions = require('redux-actions');
|
const ReduxActions = require('redux-actions');
|
||||||
|
|
||||||
|
const actions = require('@state/actions');
|
||||||
|
|
||||||
const {
|
const {
|
||||||
handleActions
|
handleActions
|
||||||
} = ReduxActions;
|
} = ReduxActions;
|
||||||
|
|
||||||
|
const {
|
||||||
|
toggleServiceCollapsed
|
||||||
|
} = actions;
|
||||||
|
|
||||||
module.exports = handleActions({
|
module.exports = handleActions({
|
||||||
'x': (state) => state // somehow handleActions needs at least one reducer
|
[toggleServiceCollapsed.toString()]: (state, action) => ({
|
||||||
|
...state,
|
||||||
|
ui: {
|
||||||
|
...state.ui,
|
||||||
|
collapsed: state.ui.collapsed.indexOf(action.payload) >= 0
|
||||||
|
? state.ui.collapsed.filter((uuid) => uuid !== action.payload)
|
||||||
|
: [...state.ui.collapsed, action.payload]
|
||||||
|
}
|
||||||
|
})
|
||||||
}, {});
|
}, {});
|
||||||
|
@ -15,6 +15,7 @@ const serviceUiSections = (state) => get(state, 'services.ui.sections', []);
|
|||||||
const orgs = (state) => get(state, 'orgs.data', []);
|
const orgs = (state) => get(state, 'orgs.data', []);
|
||||||
const projects = (state) => get(state, 'projects.data', []);
|
const projects = (state) => get(state, 'projects.data', []);
|
||||||
const services = (state) => get(state, 'services.data', []);
|
const services = (state) => get(state, 'services.data', []);
|
||||||
|
const collapsedServices = (state) => get(state, 'services.ui.collapsed', []);
|
||||||
const instances = (state) => get(state, 'instances.data', []);
|
const instances = (state) => get(state, 'instances.data', []);
|
||||||
|
|
||||||
const projectById = (projectId) => createSelector(
|
const projectById = (projectId) => createSelector(
|
||||||
@ -45,19 +46,28 @@ const orgSections = (orgId) => createSelector(
|
|||||||
);
|
);
|
||||||
|
|
||||||
const servicesByProjectId = (projectId) => createSelector(
|
const servicesByProjectId = (projectId) => createSelector(
|
||||||
[services, projectById(projectId)],
|
[services, projectById(projectId), collapsedServices],
|
||||||
(services, project) =>
|
(services, project, collapsed) =>
|
||||||
services.filter((s) => s.project === project.uuid)
|
services.filter((s) => s.project === project.uuid)
|
||||||
.map((service) => ({
|
.map((service) => ({
|
||||||
...service,
|
...service,
|
||||||
services: services.filter((s) => s.parent === service.uuid)
|
services: services.filter((s) => s.parent === service.uuid)
|
||||||
}))
|
}))
|
||||||
.filter((s) => !s.parent)
|
.filter((s) => !s.parent)
|
||||||
|
.map((service) => ({
|
||||||
|
...service,
|
||||||
|
collapsed: collapsed.indexOf(service.uuid) >= 0,
|
||||||
|
services: service.services.map((service) => ({
|
||||||
|
...service,
|
||||||
|
collapsed: collapsed.indexOf(service.uuid) >= 0
|
||||||
|
}))
|
||||||
|
}))
|
||||||
);
|
);
|
||||||
|
|
||||||
const instancesByServiceId = (serviceId) => createSelector(
|
const instancesByServiceId = (serviceId) => createSelector(
|
||||||
[instances, serviceById(serviceId)],
|
[instances, serviceById(serviceId)],
|
||||||
(instances, service) => instances.filter((i) => i.service === service.uuid)
|
(instances, service) =>
|
||||||
|
instances.filter((i) => i.service === service.uuid)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user