Add screen patch store method and reduce state updates when deleting screens
This commit is contained in:
parent
55fb91a1ae
commit
3e4cf89765
|
@ -228,6 +228,14 @@ export const getFrontendStore = () => {
|
||||||
})
|
})
|
||||||
return savedScreen
|
return savedScreen
|
||||||
},
|
},
|
||||||
|
patch: async (screenId, patch) => {
|
||||||
|
const state = get(store)
|
||||||
|
const screen = state.screens.find(screen => screen._id === screenId)
|
||||||
|
if (!screen) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
return store.actions.screens.save({ ...screen, ...patch })
|
||||||
|
},
|
||||||
delete: async screens => {
|
delete: async screens => {
|
||||||
const screensToDelete = Array.isArray(screens) ? screens : [screens]
|
const screensToDelete = Array.isArray(screens) ? screens : [screens]
|
||||||
|
|
||||||
|
@ -249,20 +257,24 @@ export const getFrontendStore = () => {
|
||||||
promises.push(store.actions.links.delete(deleteUrls))
|
promises.push(store.actions.links.delete(deleteUrls))
|
||||||
await Promise.all(promises)
|
await Promise.all(promises)
|
||||||
const deletedIds = screensToDelete.map(screen => screen._id)
|
const deletedIds = screensToDelete.map(screen => screen._id)
|
||||||
|
const routesResponse = await API.fetchAppRoutes()
|
||||||
store.update(state => {
|
store.update(state => {
|
||||||
// Remove deleted screens from state
|
// Remove deleted screens from state
|
||||||
state.screens = state.screens.filter(screen => {
|
state.screens = state.screens.filter(screen => {
|
||||||
return !deletedIds.includes(screen._id)
|
return !deletedIds.includes(screen._id)
|
||||||
})
|
})
|
||||||
|
|
||||||
// Deselect the current screen if it was deleted
|
// Deselect the current screen if it was deleted
|
||||||
if (deletedIds.includes(state.selectedScreenId)) {
|
if (deletedIds.includes(state.selectedScreenId)) {
|
||||||
state.selectedScreenId = null
|
state.selectedScreenId = null
|
||||||
|
state.selectedComponentId = null
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Update routing
|
||||||
|
state.routes = routesResponse.routes
|
||||||
|
|
||||||
return state
|
return state
|
||||||
})
|
})
|
||||||
|
|
||||||
// Refresh routes
|
|
||||||
await store.actions.routing.fetch()
|
|
||||||
},
|
},
|
||||||
updateHomeScreen: async (screen, makeHomeScreen = true) => {
|
updateHomeScreen: async (screen, makeHomeScreen = true) => {
|
||||||
let promises = []
|
let promises = []
|
||||||
|
|
Loading…
Reference in New Issue