2024-08-19 12:44:09 +02:00
|
|
|
import { Screen } from "../Screen"
|
|
|
|
import { Component } from "../../Component"
|
|
|
|
import { capitalise } from "helpers"
|
|
|
|
import { makePropSafe as safe } from "@budibase/string-templates"
|
|
|
|
import getValidRoute from "../getValidRoute"
|
|
|
|
import { Helpers } from "@budibase/bbui"
|
2024-09-09 13:15:25 +02:00
|
|
|
import { getRowActionButtonTemplates } from "templates/rowActions"
|
2024-08-19 12:44:09 +02:00
|
|
|
|
|
|
|
const getTableScreenTemplate = ({
|
|
|
|
route,
|
|
|
|
updateScreenRoute,
|
|
|
|
createScreenRoute,
|
|
|
|
tableOrView,
|
|
|
|
permissions,
|
2024-08-20 15:58:07 +02:00
|
|
|
gridLayout,
|
2024-08-19 12:44:09 +02:00
|
|
|
}) => {
|
2024-08-20 15:58:07 +02:00
|
|
|
const buttonGroup = new Component("@budibase/standard-components/buttongroup")
|
|
|
|
const createButton = new Component("@budibase/standard-components/button")
|
|
|
|
|
|
|
|
createButton.customProps({
|
|
|
|
onClick: [
|
|
|
|
{
|
|
|
|
"##eventHandlerType": "Navigate To",
|
|
|
|
parameters: {
|
|
|
|
type: "url",
|
|
|
|
url: createScreenRoute,
|
2024-08-19 12:44:09 +02:00
|
|
|
},
|
2024-08-20 15:58:07 +02:00
|
|
|
},
|
|
|
|
],
|
|
|
|
text: "Create row",
|
|
|
|
type: "cta",
|
|
|
|
})
|
|
|
|
|
|
|
|
buttonGroup
|
|
|
|
.instanceName(`${tableOrView.name} - Create`)
|
|
|
|
.customProps({
|
|
|
|
hAlign: "right",
|
|
|
|
buttons: [createButton.json()],
|
2024-08-19 12:44:09 +02:00
|
|
|
})
|
2024-08-20 15:58:07 +02:00
|
|
|
.gridDesktopColSpan(7, 13)
|
|
|
|
.gridDesktopRowSpan(1, 3)
|
2024-08-19 12:44:09 +02:00
|
|
|
|
|
|
|
const heading = new Component("@budibase/standard-components/heading")
|
|
|
|
.instanceName("Table heading")
|
|
|
|
.customProps({
|
|
|
|
text: tableOrView.name,
|
|
|
|
})
|
2024-08-20 15:58:07 +02:00
|
|
|
.gridDesktopColSpan(1, 7)
|
|
|
|
.gridDesktopRowSpan(1, 3)
|
2024-08-19 12:44:09 +02:00
|
|
|
|
|
|
|
const updateScreenRouteSegments = updateScreenRoute.split(":id")
|
|
|
|
if (updateScreenRouteSegments.length !== 2) {
|
|
|
|
throw new Error("Provided edit screen route is invalid")
|
|
|
|
}
|
|
|
|
|
|
|
|
const tableBlock = new Component("@budibase/standard-components/gridblock")
|
|
|
|
.instanceName(`${tableOrView.name} - Table`)
|
|
|
|
.customProps({
|
|
|
|
table: tableOrView.datasourceSelectFormat,
|
|
|
|
allowAddRows: false,
|
|
|
|
allowEditRows: false,
|
|
|
|
allowDeleteRows: false,
|
|
|
|
onRowClick: [
|
|
|
|
{
|
|
|
|
id: 0,
|
|
|
|
"##eventHandlerType": "Navigate To",
|
|
|
|
parameters: {
|
|
|
|
type: "url",
|
|
|
|
url: `${updateScreenRouteSegments[0]}{{ ${safe(
|
|
|
|
"eventContext"
|
|
|
|
)}.${safe("row")}._id }}${updateScreenRouteSegments[1]}`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
})
|
2024-08-20 15:58:07 +02:00
|
|
|
.gridDesktopColSpan(1, 13)
|
|
|
|
.gridDesktopRowSpan(3, 21)
|
2024-08-19 12:44:09 +02:00
|
|
|
|
|
|
|
const template = new Screen()
|
|
|
|
.route(route)
|
|
|
|
.instanceName(`${tableOrView.name} - List`)
|
2024-08-20 15:58:07 +02:00
|
|
|
.customProps({ layout: gridLayout ? "grid" : "flex" })
|
2024-08-19 12:44:09 +02:00
|
|
|
.role(permissions.write)
|
|
|
|
.autoTableId(tableOrView.id)
|
2024-08-20 15:58:07 +02:00
|
|
|
.addChild(heading)
|
|
|
|
.addChild(buttonGroup)
|
2024-08-21 17:39:54 +02:00
|
|
|
.addChild(tableBlock)
|
2024-08-19 12:44:09 +02:00
|
|
|
.json()
|
|
|
|
|
|
|
|
return {
|
|
|
|
data: template,
|
|
|
|
navigationLinkLabel: capitalise(tableOrView.name),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-09-09 13:15:25 +02:00
|
|
|
const getUpdateScreenTemplate = async ({
|
2024-08-19 12:44:09 +02:00
|
|
|
route,
|
|
|
|
tableScreenRoute,
|
|
|
|
tableOrView,
|
|
|
|
permissions,
|
|
|
|
}) => {
|
|
|
|
const formBlockId = Helpers.uuid()
|
|
|
|
const formId = `${formBlockId}-form`
|
|
|
|
const repeaterId = `${formBlockId}-repeater`
|
|
|
|
|
|
|
|
const deleteButton = new Component("@budibase/standard-components/button")
|
|
|
|
.instanceName("Delete button")
|
|
|
|
.customProps({
|
2024-09-09 13:15:25 +02:00
|
|
|
type: "warning",
|
|
|
|
quiet: true,
|
2024-08-19 12:44:09 +02:00
|
|
|
text: "Delete",
|
|
|
|
onClick: [
|
|
|
|
{
|
|
|
|
"##eventHandlerType": "Delete Row",
|
|
|
|
parameters: {
|
|
|
|
confirm: true,
|
|
|
|
tableId: tableOrView.id,
|
|
|
|
rowId: `{{ ${safe(repeaterId)}.${safe("_id")} }}`,
|
|
|
|
revId: `{{ ${safe(repeaterId)}.${safe("_rev")} }}`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"##eventHandlerType": "Navigate To",
|
|
|
|
parameters: {
|
|
|
|
type: "url",
|
|
|
|
url: tableScreenRoute,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
})
|
|
|
|
|
|
|
|
const saveButton = new Component("@budibase/standard-components/button")
|
|
|
|
.instanceName("Save button")
|
|
|
|
.customProps({
|
|
|
|
type: "cta",
|
|
|
|
text: "Save",
|
|
|
|
onClick: [
|
|
|
|
{
|
|
|
|
"##eventHandlerType": "Validate Form",
|
|
|
|
parameters: {
|
|
|
|
componentId: formId,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"##eventHandlerType": "Save Row",
|
|
|
|
parameters: {
|
|
|
|
providerId: formId,
|
|
|
|
tableId: tableOrView.id,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"##eventHandlerType": "Navigate To",
|
|
|
|
parameters: {
|
|
|
|
type: "url",
|
|
|
|
url: tableScreenRoute,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
})
|
|
|
|
|
2024-09-09 13:15:25 +02:00
|
|
|
let updateFormBlock = new Component(
|
2024-08-19 12:44:09 +02:00
|
|
|
"@budibase/standard-components/formblock",
|
|
|
|
formBlockId
|
|
|
|
)
|
|
|
|
.instanceName("Update row form block")
|
|
|
|
.customProps({
|
|
|
|
dataSource: tableOrView.tableSelectFormat,
|
|
|
|
labelPosition: "left",
|
2024-09-09 13:15:25 +02:00
|
|
|
buttonPosition: "bottom",
|
2024-08-19 12:44:09 +02:00
|
|
|
actionType: "Update",
|
|
|
|
title: `Update ${tableOrView.name} row`,
|
|
|
|
})
|
|
|
|
|
2024-09-09 13:15:25 +02:00
|
|
|
// Generate button config including row actions
|
|
|
|
let buttons = [saveButton.json(), deleteButton.json()]
|
|
|
|
const rowActionButtons = await getRowActionButtonTemplates({
|
|
|
|
instance: updateFormBlock.json(),
|
|
|
|
})
|
|
|
|
buttons = [...(buttons || []), ...rowActionButtons]
|
|
|
|
updateFormBlock = updateFormBlock.customProps({
|
|
|
|
buttons,
|
|
|
|
buttonsCollapsed: buttons.length > 5,
|
|
|
|
})
|
|
|
|
|
2024-08-19 12:44:09 +02:00
|
|
|
const template = new Screen()
|
|
|
|
.route(route)
|
|
|
|
.instanceName(`Update row`)
|
|
|
|
.role(permissions.write)
|
|
|
|
.autoTableId(tableOrView.id)
|
|
|
|
.addChild(updateFormBlock)
|
|
|
|
.json()
|
|
|
|
|
|
|
|
return {
|
|
|
|
data: template,
|
|
|
|
navigationLinkLabel: null,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const getCreateScreenTemplate = ({
|
|
|
|
route,
|
|
|
|
tableScreenRoute,
|
|
|
|
tableOrView,
|
|
|
|
permissions,
|
|
|
|
}) => {
|
|
|
|
const formBlockId = Helpers.uuid()
|
|
|
|
const formId = `${formBlockId}-form`
|
|
|
|
|
|
|
|
const saveButton = new Component("@budibase/standard-components/button")
|
|
|
|
.instanceName("Save button")
|
|
|
|
.customProps({
|
|
|
|
type: "cta",
|
|
|
|
text: "Save",
|
|
|
|
onClick: [
|
|
|
|
{
|
|
|
|
"##eventHandlerType": "Validate Form",
|
|
|
|
parameters: {
|
|
|
|
componentId: formId,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"##eventHandlerType": "Save Row",
|
|
|
|
parameters: {
|
|
|
|
providerId: formId,
|
|
|
|
tableId: tableOrView.id,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"##eventHandlerType": "Navigate To",
|
|
|
|
parameters: {
|
|
|
|
type: "url",
|
|
|
|
url: tableScreenRoute,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
})
|
|
|
|
|
|
|
|
const createFormBlock = new Component(
|
|
|
|
"@budibase/standard-components/formblock",
|
|
|
|
formBlockId
|
|
|
|
)
|
|
|
|
.instanceName("Create row form block")
|
|
|
|
.customProps({
|
|
|
|
dataSource: tableOrView.tableSelectFormat,
|
|
|
|
labelPosition: "left",
|
2024-09-09 13:15:25 +02:00
|
|
|
buttonPosition: "bottom",
|
2024-08-19 12:44:09 +02:00
|
|
|
actionType: "Create",
|
|
|
|
title: `Create ${tableOrView.name} row`,
|
2024-09-09 13:15:25 +02:00
|
|
|
buttons: [saveButton.json()],
|
2024-08-19 12:44:09 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
const template = new Screen()
|
|
|
|
.route(route)
|
|
|
|
.instanceName("Create row")
|
|
|
|
.role(permissions.write)
|
|
|
|
.autoTableId(tableOrView.id)
|
|
|
|
.addChild(createFormBlock)
|
|
|
|
.json()
|
|
|
|
|
|
|
|
return {
|
|
|
|
data: template,
|
|
|
|
navigationLinkLabel: null,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-09-09 13:15:25 +02:00
|
|
|
const newScreen = async ({ tableOrView, permissions, screens }) => {
|
2024-08-19 12:44:09 +02:00
|
|
|
const tableScreenRoute = getValidRoute(
|
|
|
|
screens,
|
|
|
|
tableOrView.name,
|
|
|
|
permissions.write
|
|
|
|
)
|
|
|
|
|
|
|
|
const updateScreenRoute = getValidRoute(
|
|
|
|
screens,
|
|
|
|
`/${tableOrView.name}/edit/:id`,
|
|
|
|
permissions.write
|
|
|
|
)
|
|
|
|
|
|
|
|
const createScreenRoute = getValidRoute(
|
|
|
|
screens,
|
|
|
|
`/${tableOrView.name}/new`,
|
|
|
|
permissions.write
|
|
|
|
)
|
|
|
|
|
|
|
|
const tableScreenTemplate = getTableScreenTemplate({
|
|
|
|
route: tableScreenRoute,
|
|
|
|
updateScreenRoute,
|
|
|
|
createScreenRoute,
|
|
|
|
permissions,
|
|
|
|
tableOrView,
|
2024-08-20 15:58:07 +02:00
|
|
|
gridLayout: true,
|
2024-08-19 12:44:09 +02:00
|
|
|
})
|
|
|
|
|
2024-09-09 13:15:25 +02:00
|
|
|
const updateScreenTemplate = await getUpdateScreenTemplate({
|
2024-08-19 12:44:09 +02:00
|
|
|
route: updateScreenRoute,
|
|
|
|
tableScreenRoute,
|
|
|
|
tableOrView,
|
|
|
|
permissions,
|
2024-08-20 15:58:07 +02:00
|
|
|
gridLayout: false,
|
2024-08-19 12:44:09 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
const createScreenTemplate = getCreateScreenTemplate({
|
|
|
|
route: createScreenRoute,
|
|
|
|
tableScreenRoute,
|
|
|
|
tableOrView,
|
|
|
|
permissions,
|
2024-08-20 15:58:07 +02:00
|
|
|
gridLayout: false,
|
2024-08-19 12:44:09 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
return [tableScreenTemplate, updateScreenTemplate, createScreenTemplate]
|
|
|
|
}
|
|
|
|
|
|
|
|
export default newScreen
|