budibase/packages/builder/src/builderStore/storeUtils.js

133 lines
3.6 KiB
JavaScript
Raw Normal View History

import {
makePropsSafe,
getBuiltin,
} from "components/userInterface/pagesParsing/createProps"
import api from "./api"
import { store } from "builderStore"
import { generate_screen_css } from "./generate_css"
2020-08-12 17:28:19 +02:00
import { uuid } from "./uuid"
2020-08-13 12:50:12 +02:00
import getNewComponentName from "./getNewComponentName"
export const selectComponent = (state, component) => {
const componentDef = component._component.startsWith("##")
? component
: state.components[component._component]
state.currentComponentInfo = makePropsSafe(componentDef, component)
state.currentView = "component"
return state
}
export const getParent = (rootProps, child) => {
let parent
walkProps(rootProps, (p, breakWalk) => {
if (
p._children &&
(p._children.includes(child) || p._children.some(c => c._id === child))
) {
parent = p
breakWalk()
}
})
return parent
}
export const saveCurrentPreviewItem = s =>
s.currentFrontEndType === "page"
? savePage(s)
: store.saveScreen(s.currentPreviewItem)
export const savePage = async state => {
const pageName = state.currentPageName || "main"
const page = state.pages[pageName]
const response = await api
.post(`/api/pages/${page._id}`, {
page: { componentLibraries: state.pages.componentLibraries, ...page },
screens: page._screens,
})
.then(response => response.json())
store.update(innerState => {
innerState.pages[pageName]._rev = response.rev
return innerState
})
return state
}
// export const saveScreenApi = async (screen, state) => {
// const currentPage = state.pages[state.currentPageName]
// const response = await api.post(`/api/screens/${currentPage._id}`, screen)
// const json = await response.json()
// store.update(innerState => {
// // TODO: need to update pages in here
// // innerState.pages[pageName]._rev = response.rev
// return innerState
// })
// await savePage(state)
// }
export const walkProps = (props, action, cancelToken = null) => {
cancelToken = cancelToken || { cancelled: false }
action(props, () => {
cancelToken.cancelled = true
})
if (props._children) {
for (let child of props._children) {
if (cancelToken.cancelled) return
walkProps(child, action, cancelToken)
}
}
2020-06-01 13:15:44 +02:00
}
export const regenerateCssForScreen = screen => {
screen._css = generate_screen_css([screen.props])
}
2020-06-02 12:16:30 +02:00
export const regenerateCssForCurrentScreen = state => {
2020-10-17 19:20:06 +02:00
if (state.currentPreviewItem) {
regenerateCssForScreen(state.currentPreviewItem)
}
return state
}
2020-08-12 17:28:19 +02:00
2020-10-09 12:58:46 +02:00
export const generateNewIdsForComponent = (c, state, changeName = true) =>
2020-08-12 17:28:19 +02:00
walkProps(c, p => {
p._id = uuid()
2020-10-09 12:58:46 +02:00
if (changeName) p._instanceName = getNewComponentName(p._component, state)
2020-08-12 17:28:19 +02:00
})
export const getComponentDefinition = (state, name) =>
name.startsWith("##") ? getBuiltin(name) : state.components[name]
2020-10-17 19:20:06 +02:00
export const findChildComponentType = (node, typeToFind) => {
// Stop recursion if invalid props
if (!node || !typeToFind) {
return null
}
// Stop recursion if this element matches
if (node._component === typeToFind) {
return node
}
// Otherwise check if any children match
// Stop recursion if no valid children to process
const children = node._children || (node.props && node.props._children)
if (!children || !children.length) {
return null
}
// Recurse and check each child component
for (let child of children) {
const childResult = findChildComponentType(child, typeToFind)
if (childResult) {
return childResult
}
}
// If we reach here then no children were valid
return null
}