1
0
Fork 0
mirror of synced 2024-07-07 15:25:52 +12:00
budibase/packages/standard-components/dist/generators.js
Michael Shanks b7d9e05641
Work on Components API & bugfixes (#102)
* typo - screens not being sent to page save

* removed children arg from hydrateChildren (n/a)

* initialiseChildren does not rerender unless forced

* removed derivatives of initialiseChildren

* renamed initialiseChildren > attachChildren

* standard-components - refactoring

div now container
H1, h2... etc now Heading with type
Select now takes option as _children

* loads of bug fixing

* safe props creation
anytime props are loaded,
we make sure they conform to the components props definition
2020-02-14 11:51:45 +00:00

202 lines
17 KiB
JavaScript

const headers = () => [
{
name: "common/H1",
description: "Header 1",
inherits: "@budibase/standard-components/text",
props: {
font: "20pt",
},
},
{
name: "common/H2",
description: "Header 2",
inherits: "@budibase/standard-components/text",
props: {
font: "15pt",
},
},
{
name: "common/H3",
description: "Header 3",
inherits: "@budibase/standard-components/text",
props: {
font: "12pt bold",
},
},
{
name: "common/H4",
description: "Header 4",
inherits: "@budibase/standard-components/text",
props: {
font: "10pt bold",
},
},
];
const forms = ({ records, indexes }) => [
...headers(),
...records.map(root),
];
const root = record => ({
name: `${record.name} Form`,
description: `All fields on record '${record.nodeKey()}' `,
inherits: "@budibase/standard-components/stackpanel",
props: {
direction: "vertical",
children: [
{
control: {
_component: "common/H1",
value: `Edit ${record.name}`,
},
},
form(record),
saveCancelButtons(record),
],
},
});
const form = record => ({
control: {
_component: "@budibase/standard-components/form",
formControls: record.fields.map(f => ({
label: f.label,
control: {
_component: "@budibase/standard-components/textbox",
value: {
"##bbstate": `current${record.name}.${f.name}`,
"##bbsource": "store",
},
},
})),
},
});
const saveCancelButtons = record => ({
control: {
_component: "@budibase/standard-components/stackpanel",
direction: "horizontal",
children: [
paddedPanelForButton({
_component: "common/Primary Button",
contentText: `Save ${record.name}`,
onClick: [
{
"##eventHandlerType": "Save Record",
parameters: {
statePath: `current${record.name}`,
},
},
],
}),
paddedPanelForButton({
_component: "common/Secondary Button",
contentText: `Cancel`,
onClick: [
{
"##eventHandlerType": "Save Record",
parameters: {
statePath: `current${record.name}`,
},
},
],
}),
],
},
});
const paddedPanelForButton = button => ({
control: {
_component: "@budibase/standard-components/panel",
padding: "20px",
component: button,
},
});
const indexTables = ({ indexes, helpers }) =>
indexes
.filter(i => i.parent().type === "root")
.map(i => indexTable(i, helpers));
const indexTableProps = (index, helpers) => ({
data: {
"##bbstate": index.nodeKey(),
"##bbsource": "store",
},
columns: helpers.indexSchema(index).map(column),
});
const indexTable = (index, helpers) => ({
name: `tables/${index.name} Table`,
inherits: "@budibase/standard-components/table",
props: indexTableProps(index, helpers),
});
const column = col => ({
title: col.name,
value: {
"##bbstate": col.name,
"##bbsource": "context",
},
});
const nav = ({ records, indexes, helpers }) => [
{
name: "Application Root",
inherits: "@budibase/standard-components/nav",
props: {
items: indexes.filter(i => i.parent().type === "root").map(navItem),
selectedItem: {
"##bbstate": "selectedNav",
"##bbstatefallback": records[0].collectionName,
"##bbsource": "store",
},
},
},
...indexTables({ records, indexes, helpers }),
];
const navItem = index => ({
title: index.name,
component: {
_component: `tables/${index.name} Table`,
},
});
const app = params => {
return [...nav(params), ...forms(params)]
};
const buttons = () => [
{
name: "common/Primary Button",
description: "a styled button",
inherits: "@budibase/standard-components/button",
props: {
padding: "5px 7px",
border: "1px solid #EEE",
color: "#5F6368",
background: "##f2f2f2",
hoverColor: "black",
hoverBackground: "#cccccc",
},
},
{
name: "common/Secondary Button",
description: "a styled button",
inherits: "@budibase/standard-components/button",
props: {
padding: "5px 7px",
border: "1px solid #EEE",
color: "#5F6368",
background: "##f2f2f2",
hoverColor: "black",
hoverBackground: "#cccccc",
},
},
];
export { app, buttons, forms, headers, indexTables, nav };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"generators.js","sources":["../src/generators/headersGenerator.js","../src/generators/formsGenerator.js","../src/generators/indexTablesGenerator.js","../src/generators/navGenerator.js","../src/generators/appGenerator.js","../src/generators/buttonsGenerator.js"],"sourcesContent":["export const headers = () => [\r\n  {\r\n    name: \"common/H1\",\r\n    description: \"Header 1\",\r\n    inherits: \"@budibase/standard-components/text\",\r\n    props: {\r\n      font: \"20pt\",\r\n    },\r\n  },\r\n  {\r\n    name: \"common/H2\",\r\n    description: \"Header 2\",\r\n    inherits: \"@budibase/standard-components/text\",\r\n    props: {\r\n      font: \"15pt\",\r\n    },\r\n  },\r\n  {\r\n    name: \"common/H3\",\r\n    description: \"Header 3\",\r\n    inherits: \"@budibase/standard-components/text\",\r\n    props: {\r\n      font: \"12pt bold\",\r\n    },\r\n  },\r\n  {\r\n    name: \"common/H4\",\r\n    description: \"Header 4\",\r\n    inherits: \"@budibase/standard-components/text\",\r\n    props: {\r\n      font: \"10pt bold\",\r\n    },\r\n  },\r\n]\r\n","import { headers } from \"./headersGenerator\"\r\n\r\nexport const forms = ({ records, indexes }) => [\r\n  ...headers({ records, indexes }),\r\n  ...records.map(root),\r\n]\r\n\r\nconst root = record => ({\r\n  name: `${record.name} Form`,\r\n  description: `All fields on record '${record.nodeKey()}' `,\r\n  inherits: \"@budibase/standard-components/stackpanel\",\r\n  props: {\r\n    direction: \"vertical\",\r\n    children: [\r\n      {\r\n        control: {\r\n          _component: \"common/H1\",\r\n          value: `Edit ${record.name}`,\r\n        },\r\n      },\r\n      form(record),\r\n      saveCancelButtons(record),\r\n    ],\r\n  },\r\n})\r\n\r\nconst form = record => ({\r\n  control: {\r\n    _component: \"@budibase/standard-components/form\",\r\n    formControls: record.fields.map(f => ({\r\n      label: f.label,\r\n      control: {\r\n        _component: \"@budibase/standard-components/textbox\",\r\n        value: {\r\n          \"##bbstate\": `current${record.name}.${f.name}`,\r\n          \"##bbsource\": \"store\",\r\n        },\r\n      },\r\n    })),\r\n  },\r\n})\r\n\r\nconst saveCancelButtons = record => ({\r\n  control: {\r\n    _component: \"@budibase/standard-components/stackpanel\",\r\n    direction: \"horizontal\",\r\n    children: [\r\n      paddedPanelForButton({\r\n        _component: \"common/Primary Button\",\r\n        contentText: `Save ${record.name}`,\r\n        onClick: [\r\n          {\r\n            \"##eventHandlerType\": \"Save Record\",\r\n            parameters: {\r\n              statePath: `current${record.name}`,\r\n            },\r\n          },\r\n        ],\r\n      }),\r\n      paddedPanelForButton({\r\n        _component: \"common/Secondary Button\",\r\n        contentText: `Cancel`,\r\n        onClick: [\r\n          {\r\n            \"##eventHandlerType\": \"Save Record\",\r\n            parameters: {\r\n              statePath: `current${record.name}`,\r\n            },\r\n          },\r\n        ],\r\n      }),\r\n    ],\r\n  },\r\n})\r\n\r\nconst paddedPanelForButton = button => ({\r\n  control: {\r\n    _component: \"@budibase/standard-components/panel\",\r\n    padding: \"20px\",\r\n    component: button,\r\n  },\r\n})\r\n","export const indexTables = ({ indexes, helpers }) =>\r\n  indexes\r\n    .filter(i => i.parent().type === \"root\")\r\n    .map(i => indexTable(i, helpers))\r\n\r\nexport const indexTableProps = (index, helpers) => ({\r\n  data: {\r\n    \"##bbstate\": index.nodeKey(),\r\n    \"##bbsource\": \"store\",\r\n  },\r\n  columns: helpers.indexSchema(index).map(column),\r\n})\r\n\r\nconst indexTable = (index, helpers) => ({\r\n  name: `tables/${index.name} Table`,\r\n  inherits: \"@budibase/standard-components/table\",\r\n  props: indexTableProps(index, helpers),\r\n})\r\n\r\nconst column = col => ({\r\n  title: col.name,\r\n  value: {\r\n    \"##bbstate\": col.name,\r\n    \"##bbsource\": \"context\",\r\n  },\r\n})\r\n","import { indexTables } from \"./indexTablesGenerator\"\r\n\r\nexport const nav = ({ records, indexes, helpers }) => [\r\n  {\r\n    name: \"Application Root\",\r\n    inherits: \"@budibase/standard-components/nav\",\r\n    props: {\r\n      items: indexes.filter(i => i.parent().type === \"root\").map(navItem),\r\n      selectedItem: {\r\n        \"##bbstate\": \"selectedNav\",\r\n        \"##bbstatefallback\": records[0].collectionName,\r\n        \"##bbsource\": \"store\",\r\n      },\r\n    },\r\n  },\r\n  ...indexTables({ records, indexes, helpers }),\r\n]\r\n\r\nexport const navItem = index => ({\r\n  title: index.name,\r\n  component: {\r\n    _component: `tables/${index.name} Table`,\r\n  },\r\n})\r\n","import { forms } from \"./formsGenerator\"\r\nimport { nav } from \"./navGenerator\"\r\n\r\nexport const app = params => {\r\n  return [...nav(params), ...forms(params)]\r\n}\r\n","export const buttons = () => [\r\n  {\r\n    name: \"common/Primary Button\",\r\n    description: \"a styled button\",\r\n    inherits: \"@budibase/standard-components/button\",\r\n    props: {\r\n      padding: \"5px 7px\",\r\n      border: \"1px solid #EEE\",\r\n      color: \"#5F6368\",\r\n      background: \"##f2f2f2\",\r\n      hoverColor: \"black\",\r\n      hoverBackground: \"#cccccc\",\r\n    },\r\n  },\r\n  {\r\n    name: \"common/Secondary Button\",\r\n    description: \"a styled button\",\r\n    inherits: \"@budibase/standard-components/button\",\r\n    props: {\r\n      padding: \"5px 7px\",\r\n      border: \"1px solid #EEE\",\r\n      color: \"#5F6368\",\r\n      background: \"##f2f2f2\",\r\n      hoverColor: \"black\",\r\n      hoverBackground: \"#cccccc\",\r\n    },\r\n  },\r\n]\r\n"],"names":[],"mappings":"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"}