2021-10-28 13:43:31 +02:00
|
|
|
import { writable, derived, get } from "svelte/store"
|
2021-09-01 12:41:48 +02:00
|
|
|
import Manifest from "manifest.json"
|
2021-08-20 10:27:38 +02:00
|
|
|
import { findComponentById, findComponentPathById } from "../utils/components"
|
2021-09-30 17:52:21 +02:00
|
|
|
import { pingEndUser } from "../api"
|
2021-06-08 09:00:54 +02:00
|
|
|
|
2021-06-30 20:37:03 +02:00
|
|
|
const dispatchEvent = (type, data = {}) => {
|
2021-10-28 19:40:46 +02:00
|
|
|
window.parent.postMessage({ type, data })
|
2021-06-08 09:00:54 +02:00
|
|
|
}
|
|
|
|
|
2020-11-24 10:31:54 +01:00
|
|
|
const createBuilderStore = () => {
|
|
|
|
const initialState = {
|
|
|
|
inBuilder: false,
|
2020-11-27 17:36:31 +01:00
|
|
|
layout: null,
|
2020-11-24 10:31:54 +01:00
|
|
|
screen: null,
|
2020-11-30 13:11:50 +01:00
|
|
|
selectedComponentId: null,
|
2021-10-28 13:43:31 +02:00
|
|
|
editMode: false,
|
2020-11-30 13:11:50 +01:00
|
|
|
previewId: null,
|
2021-01-06 11:11:56 +01:00
|
|
|
previewType: null,
|
2021-08-19 15:53:13 +02:00
|
|
|
selectedPath: [],
|
2021-09-08 10:40:25 +02:00
|
|
|
theme: null,
|
|
|
|
customTheme: null,
|
|
|
|
previewDevice: "desktop",
|
2021-09-17 15:17:50 +02:00
|
|
|
isDragging: false,
|
2021-01-06 11:11:56 +01:00
|
|
|
}
|
2021-06-08 09:00:54 +02:00
|
|
|
const writableStore = writable(initialState)
|
|
|
|
const derivedStore = derived(writableStore, $state => {
|
2021-08-19 17:04:15 +02:00
|
|
|
// Avoid any of this logic if we aren't in the builder preview
|
2021-08-19 17:06:33 +02:00
|
|
|
if (!$state.inBuilder) {
|
2021-08-19 17:04:15 +02:00
|
|
|
return $state
|
|
|
|
}
|
|
|
|
|
2021-06-08 09:00:54 +02:00
|
|
|
// Derive the selected component instance and definition
|
|
|
|
const { layout, screen, previewType, selectedComponentId } = $state
|
|
|
|
const asset = previewType === "layout" ? layout : screen
|
|
|
|
const component = findComponentById(asset?.props, selectedComponentId)
|
|
|
|
const prefix = "@budibase/standard-components/"
|
|
|
|
const type = component?._component?.replace(prefix, "")
|
2021-06-11 09:05:49 +02:00
|
|
|
const definition = type ? Manifest[type] : null
|
2021-08-19 15:53:13 +02:00
|
|
|
|
|
|
|
// Derive the selected component path
|
2021-08-20 10:27:38 +02:00
|
|
|
const path = findComponentPathById(asset.props, selectedComponentId) || []
|
2021-08-19 15:53:13 +02:00
|
|
|
|
2021-06-08 09:00:54 +02:00
|
|
|
return {
|
|
|
|
...$state,
|
|
|
|
selectedComponent: component,
|
|
|
|
selectedComponentDefinition: definition,
|
2021-08-20 10:27:38 +02:00
|
|
|
selectedComponentPath: path?.map(component => component._id),
|
2021-06-08 09:00:54 +02:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2021-01-06 11:11:56 +01:00
|
|
|
const actions = {
|
2021-05-04 12:32:22 +02:00
|
|
|
selectComponent: id => {
|
2021-10-28 13:43:31 +02:00
|
|
|
if (id === get(writableStore).selectedComponentId) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
writableStore.update(state => ({ ...state, editMode: false }))
|
2021-06-23 15:21:37 +02:00
|
|
|
dispatchEvent("select-component", { id })
|
2021-01-06 11:11:56 +01:00
|
|
|
},
|
2021-06-08 09:00:54 +02:00
|
|
|
updateProp: (prop, value) => {
|
|
|
|
dispatchEvent("update-prop", { prop, value })
|
|
|
|
},
|
2021-06-23 15:21:37 +02:00
|
|
|
deleteComponent: id => {
|
|
|
|
dispatchEvent("delete-component", { id })
|
|
|
|
},
|
2021-06-30 20:37:03 +02:00
|
|
|
notifyLoaded: () => {
|
|
|
|
dispatchEvent("preview-loaded")
|
|
|
|
},
|
2021-09-30 16:03:57 +02:00
|
|
|
pingEndUser: () => {
|
2021-09-30 17:52:21 +02:00
|
|
|
pingEndUser()
|
2021-09-30 16:03:57 +02:00
|
|
|
},
|
2021-08-19 15:53:13 +02:00
|
|
|
setSelectedPath: path => {
|
2021-10-28 13:43:31 +02:00
|
|
|
writableStore.update(state => ({ ...state, selectedPath: path }))
|
2021-08-19 15:53:13 +02:00
|
|
|
},
|
2021-09-16 08:28:59 +02:00
|
|
|
moveComponent: (componentId, destinationComponentId, mode) => {
|
|
|
|
dispatchEvent("move-component", {
|
|
|
|
componentId,
|
|
|
|
destinationComponentId,
|
|
|
|
mode,
|
|
|
|
})
|
|
|
|
},
|
2021-09-17 15:17:50 +02:00
|
|
|
setDragging: dragging => {
|
2021-11-16 14:35:20 +01:00
|
|
|
if (dragging === get(writableStore).isDragging) {
|
|
|
|
return
|
|
|
|
}
|
2021-10-28 13:43:31 +02:00
|
|
|
writableStore.update(state => ({ ...state, isDragging: dragging }))
|
|
|
|
},
|
|
|
|
setEditMode: enabled => {
|
2021-11-16 14:35:20 +01:00
|
|
|
if (enabled === get(writableStore).editMode) {
|
|
|
|
return
|
|
|
|
}
|
2021-10-28 13:43:31 +02:00
|
|
|
writableStore.update(state => ({ ...state, editMode: enabled }))
|
2021-09-16 15:28:44 +02:00
|
|
|
},
|
2021-01-06 11:11:56 +01:00
|
|
|
}
|
|
|
|
return {
|
2021-06-08 09:00:54 +02:00
|
|
|
...writableStore,
|
2021-11-18 21:31:25 +01:00
|
|
|
set: state => writableStore.set({ ...initialState, ...state }),
|
2021-06-08 09:00:54 +02:00
|
|
|
subscribe: derivedStore.subscribe,
|
2021-01-06 11:11:56 +01:00
|
|
|
actions,
|
2020-11-24 10:31:54 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export const builderStore = createBuilderStore()
|