Fix click on navigation not selecting it

This commit is contained in:
Andrew Kingston 2023-08-23 15:37:13 +01:00
parent 80e622d2e0
commit 0ef0e58e5e
4 changed files with 16 additions and 12 deletions

View File

@ -999,14 +999,18 @@ export const getFrontendStore = () => {
const parent = findComponentParent(screen.props, componentId)
const index = parent?._children.findIndex(x => x._id === componentId)
if (componentId === "screen") {
// Check for screen and navigation component edge cases
const screenComponentId = `${screen._id}-screen`
const navComponentId = `${screen._id}-navigation`
console.log(componentId, screenComponentId, navComponentId)
if (componentId === screenComponentId) {
return null
}
if (componentId === "navigation") {
return "screen"
if (componentId === navComponentId) {
return screenComponentId
}
if (parent._id === screen.props._id && index === 0) {
return "navigation"
return navComponentId
}
// If we have siblings above us, choose the sibling or a descendant
@ -1036,8 +1040,11 @@ export const getFrontendStore = () => {
const parent = findComponentParent(screen.props, componentId)
const index = parent?._children.findIndex(x => x._id === componentId)
if (state.selectedComponentId === "screen") {
return "navigation"
// Check for screen and navigation component edge cases
const screenComponentId = `${screen._id}-screen`
const navComponentId = `${screen._id}-navigation`
if (state.selectedComponentId === screenComponentId) {
return navComponentId
}
// If we have children, select first child
@ -1076,6 +1083,7 @@ export const getFrontendStore = () => {
}
},
selectPrevious: () => {
console.log("prev")
const previousId = store.actions.components.getPrevious()
if (previousId) {
store.update(state => {
@ -1085,6 +1093,7 @@ export const getFrontendStore = () => {
}
},
selectNext: () => {
console.log("next")
const nextId = store.actions.components.getNext()
if (nextId) {
store.update(state => {

View File

@ -156,8 +156,6 @@
store.actions.components.copy(source, true, false)
await store.actions.components.paste(destination, data.mode)
}
} else if (type === "click-nav") {
$store.selectedComponentId = "navigation"
} else if (type === "request-add-component") {
toggleAddComponent()
} else if (type === "highlight-setting") {

View File

@ -176,7 +176,7 @@
class:hidden={$routeStore.queryParams?.peek}
class:clickable={$builderStore.inBuilder}
on:click={$builderStore.inBuilder
? builderStore.actions.clickNav
? builderStore.actions.selectComponent(navigationId)
: null}
style={navStyle}
>

View File

@ -80,9 +80,6 @@ const createBuilderStore = () => {
}
store.update(state => ({ ...state, editMode: enabled }))
},
clickNav: () => {
eventStore.actions.dispatchEvent("click-nav")
},
requestAddComponent: () => {
eventStore.actions.dispatchEvent("request-add-component")
},