@luomus/laji-form-builder 1.0.28

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (92) hide show
  1. package/CHANGELOG.md +3 -0
  2. package/LICENSE +21 -0
  3. package/README.md +114 -0
  4. package/dist/laji-form-builder.js +2 -0
  5. package/dist/laji-form-builder.js.LICENSE.txt +82 -0
  6. package/dist/main.js +2 -0
  7. package/dist/main.js.LICENSE.txt +86 -0
  8. package/dist/styles.css +4 -0
  9. package/lib/api-client.d.ts +20 -0
  10. package/lib/api-client.js +60 -0
  11. package/lib/api-client.js.map +1 -0
  12. package/lib/client/LajiFormInterface.d.ts +44 -0
  13. package/lib/client/LajiFormInterface.js +39 -0
  14. package/lib/client/LajiFormInterface.js.map +1 -0
  15. package/lib/client/app.d.ts +9 -0
  16. package/lib/client/app.js +39 -0
  17. package/lib/client/app.js.map +1 -0
  18. package/lib/client/components/Builder.d.ts +101 -0
  19. package/lib/client/components/Builder.js +357 -0
  20. package/lib/client/components/Builder.js.map +1 -0
  21. package/lib/client/components/Context.d.ts +18 -0
  22. package/lib/client/components/Context.js +25 -0
  23. package/lib/client/components/Context.js.map +1 -0
  24. package/lib/client/components/Editor/BasicEditor.d.ts +29 -0
  25. package/lib/client/components/Editor/BasicEditor.js +185 -0
  26. package/lib/client/components/Editor/BasicEditor.js.map +1 -0
  27. package/lib/client/components/Editor/DiffViewer.d.ts +17 -0
  28. package/lib/client/components/Editor/DiffViewer.js +134 -0
  29. package/lib/client/components/Editor/DiffViewer.js.map +1 -0
  30. package/lib/client/components/Editor/Editor.d.ts +111 -0
  31. package/lib/client/components/Editor/Editor.js +344 -0
  32. package/lib/client/components/Editor/Editor.js.map +1 -0
  33. package/lib/client/components/Editor/ElemPicker.d.ts +13 -0
  34. package/lib/client/components/Editor/ElemPicker.js +170 -0
  35. package/lib/client/components/Editor/ElemPicker.js.map +1 -0
  36. package/lib/client/components/Editor/FieldEditor.d.ts +41 -0
  37. package/lib/client/components/Editor/FieldEditor.js +125 -0
  38. package/lib/client/components/Editor/FieldEditor.js.map +1 -0
  39. package/lib/client/components/Editor/Fields.d.ts +27 -0
  40. package/lib/client/components/Editor/Fields.js +185 -0
  41. package/lib/client/components/Editor/Fields.js.map +1 -0
  42. package/lib/client/components/Editor/OptionsEditor.d.ts +20 -0
  43. package/lib/client/components/Editor/OptionsEditor.js +207 -0
  44. package/lib/client/components/Editor/OptionsEditor.js.map +1 -0
  45. package/lib/client/components/Editor/UiSchemaEditor.d.ts +22 -0
  46. package/lib/client/components/Editor/UiSchemaEditor.js +368 -0
  47. package/lib/client/components/Editor/UiSchemaEditor.js.map +1 -0
  48. package/lib/client/components/LajiForm.d.ts +4 -0
  49. package/lib/client/components/LajiForm.js +32 -0
  50. package/lib/client/components/LajiForm.js.map +1 -0
  51. package/lib/client/components/Wizard.d.ts +11 -0
  52. package/lib/client/components/Wizard.js +364 -0
  53. package/lib/client/components/Wizard.js.map +1 -0
  54. package/lib/client/components/components.d.ts +103 -0
  55. package/lib/client/components/components.js +321 -0
  56. package/lib/client/components/components.js.map +1 -0
  57. package/lib/client/services/change-handler-service.d.ts +57 -0
  58. package/lib/client/services/change-handler-service.js +150 -0
  59. package/lib/client/services/change-handler-service.js.map +1 -0
  60. package/lib/client/services/form-service.d.ts +21 -0
  61. package/lib/client/services/form-service.js +77 -0
  62. package/lib/client/services/form-service.js.map +1 -0
  63. package/lib/client/styles.css +227 -0
  64. package/lib/client/styles.d.ts +2 -0
  65. package/lib/client/styles.js +5 -0
  66. package/lib/client/styles.js.map +1 -0
  67. package/lib/client/themes/bs3.d.ts +3 -0
  68. package/lib/client/themes/bs3.js +49 -0
  69. package/lib/client/themes/bs3.js.map +1 -0
  70. package/lib/client/themes/theme.d.ts +28 -0
  71. package/lib/client/themes/theme.js +14 -0
  72. package/lib/client/themes/theme.js.map +1 -0
  73. package/lib/client/translations.json +272 -0
  74. package/lib/client/utils.d.ts +63 -0
  75. package/lib/client/utils.js +370 -0
  76. package/lib/client/utils.js.map +1 -0
  77. package/lib/model.d.ts +205 -0
  78. package/lib/model.js +43 -0
  79. package/lib/model.js.map +1 -0
  80. package/lib/services/form-expander-service.d.ts +15 -0
  81. package/lib/services/form-expander-service.js +77 -0
  82. package/lib/services/form-expander-service.js.map +1 -0
  83. package/lib/services/has-cache.d.ts +8 -0
  84. package/lib/services/has-cache.js +22 -0
  85. package/lib/services/has-cache.js.map +1 -0
  86. package/lib/services/metadata-service.d.ts +23 -0
  87. package/lib/services/metadata-service.js +138 -0
  88. package/lib/services/metadata-service.js.map +1 -0
  89. package/lib/utils.d.ts +79 -0
  90. package/lib/utils.js +117 -0
  91. package/lib/utils.js.map +1 -0
  92. package/package.json +114 -0
@@ -0,0 +1,125 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __importDefault = (this && this.__importDefault) || function (mod) {
22
+ return (mod && mod.__esModule) ? mod : { "default": mod };
23
+ };
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ const React = __importStar(require("react"));
26
+ const utils_1 = require("../../../utils");
27
+ const utils_2 = require("../../utils");
28
+ const Builder_1 = require("../Builder");
29
+ const components_1 = require("../components");
30
+ const Context_1 = require("../Context");
31
+ const Editor_1 = require("./Editor");
32
+ const memoizee_1 = __importDefault(require("memoizee"));
33
+ const Fields_1 = __importDefault(require("./Fields"));
34
+ const UiSchemaEditor_1 = __importDefault(require("./UiSchemaEditor"));
35
+ const BasicEditor_1 = __importDefault(require("./BasicEditor"));
36
+ const tabs = { basic: "editor.tab.fields.basic", uiSchema: "editor.tab.fields.uiSchema" };
37
+ class FieldEditor extends React.PureComponent {
38
+ constructor() {
39
+ super(...arguments);
40
+ this.state = {
41
+ tab: "basic"
42
+ };
43
+ this.fieldsRef = React.createRef();
44
+ this.nmspc = utils_2.nmspc("field-editor");
45
+ this.onTabChange = (tab) => {
46
+ this.setState({ tab });
47
+ };
48
+ this.getSelected = () => this.getFieldPath(this.props.selectedField || "");
49
+ this.getFields = memoizee_1.default((master) => ([{
50
+ name: utils_1.getPropertyContextName(master.context),
51
+ fields: master.fields
52
+ }]));
53
+ this.getFieldPath = (path) => {
54
+ const globalSlashRegexp = /\//g;
55
+ const firstSlashSeparatedPathPart = /\/[^/]*/;
56
+ const slashMatch = path.match(globalSlashRegexp);
57
+ const isRootField = slashMatch && slashMatch.length === 1;
58
+ return isRootField ? "/" : path.replace(firstSlashSeparatedPathPart, "");
59
+ };
60
+ this.onFieldDeleted = (field) => {
61
+ this.props.onChange([{ type: "field", op: "delete", selected: this.getFieldPath(field) }]);
62
+ };
63
+ this.onFieldAdded = (field, property) => {
64
+ this.props.onChange([{ type: "field", op: "add", selected: this.getFieldPath(field), value: property }]);
65
+ };
66
+ this.onEditorChange = (events) => {
67
+ events = (events instanceof Array ? events : [events]).map(event => {
68
+ return Object.assign(Object.assign({}, event), { selected: this.getSelected() });
69
+ });
70
+ this.props.onChange(events);
71
+ };
72
+ }
73
+ render() {
74
+ const { expandedMaster, schemaFormat } = this.props;
75
+ const active = this.state.tab;
76
+ const fieldEditorContentStyle = {
77
+ width: "100%",
78
+ height: "100%"
79
+ };
80
+ const fieldsStyle = {
81
+ display: "flex",
82
+ flexDirection: "column",
83
+ height: utils_2.fullHeightWithOffset(25 + (this.props.topOffset || 0)),
84
+ overflowY: "auto"
85
+ };
86
+ const editorProps = Object.assign(Object.assign({ selected: this.props.selectedField, contentValid: Builder_1.isValid(schemaFormat), active }, this.getFieldEditorChildProps(expandedMaster, schemaFormat)), { className: Editor_1.editorContentNmspc("ui"), topOffset: this.props.topOffset });
87
+ return React.createElement(React.Fragment, null,
88
+ React.createElement(components_1.ErrorBoundary, null,
89
+ React.createElement(components_1.DraggableWidth, { style: fieldsStyle, className: utils_2.gnmspc("editor-nav-bar"), ref: this.fieldsRef },
90
+ React.createElement(Fields_1.default, { className: utils_2.gnmspc("field-chooser"), fields: this.getFields(expandedMaster), onSelected: this.props.onSelectedField, onDeleted: this.onFieldDeleted, onAdded: this.onFieldAdded, selected: this.props.selectedField, pointer: "", expanded: true, fieldsContainerElem: this.fieldsRef.current, context: expandedMaster.context })),
91
+ this.props.selectedField
92
+ && editorProps.field
93
+ && React.createElement("div", { style: { display: "flex", flexDirection: "column", width: "100%" } },
94
+ React.createElement(Editor_1.TabChooser, { tabs: tabs, active: this.state.tab, onChange: this.onTabChange, className: this.nmspc("toolbar") }),
95
+ React.createElement("div", { style: fieldEditorContentStyle, className: this.nmspc("content") }, active === "uiSchema" && React.createElement(UiSchemaEditor_1.default, Object.assign({}, editorProps))
96
+ || active === "basic" && React.createElement(BasicEditor_1.default, Object.assign({}, editorProps))
97
+ || null))));
98
+ }
99
+ getFieldEditorChildProps(expandedMaster, schemaFormat) {
100
+ var _a;
101
+ const { editorLang } = this.context;
102
+ const selected = this.getSelected();
103
+ const findField = (_field, path) => {
104
+ const [next, ...rest] = path.split("/").filter(s => s);
105
+ if (next === undefined) {
106
+ return _field;
107
+ }
108
+ const child = _field.fields
109
+ .find(_child => _child.name === next);
110
+ return findField(child, rest.join("/"));
111
+ };
112
+ return {
113
+ schema: utils_1.parseJSONPointer(schemaFormat.schema, utils_2.fieldPointerToSchemaPointer(schemaFormat.schema, selected)),
114
+ uiSchema: utils_1.parseJSONPointer(expandedMaster.uiSchema, utils_2.fieldPointerToUiSchemaPointer(schemaFormat.schema, selected), !!"safely"),
115
+ field: findField(this.getFields(expandedMaster)[0], selected),
116
+ translations: ((_a = expandedMaster.translations) === null || _a === void 0 ? void 0 : _a[editorLang]) || {},
117
+ path: selected,
118
+ onChange: this.onEditorChange,
119
+ context: expandedMaster.context,
120
+ };
121
+ }
122
+ }
123
+ exports.default = FieldEditor;
124
+ FieldEditor.contextType = Context_1.Context;
125
+ //# sourceMappingURL=FieldEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FieldEditor.js","sourceRoot":"","sources":["../../../../src/client/components/Editor/FieldEditor.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ import * as React from "react";
2
+ import { Property, Field as FieldOptions } from "../../../model";
3
+ import { Stylable, Classable } from "../components";
4
+ declare type OnSelectedCB = (field: string) => void;
5
+ declare const Fields: React.NamedExoticComponent<{
6
+ fields: FieldProps[];
7
+ onSelected: OnSelectedCB;
8
+ onDeleted: OnSelectedCB;
9
+ onAdded: (field: string, property: Property) => void;
10
+ selected?: string | undefined;
11
+ pointer: string;
12
+ expanded?: boolean | undefined;
13
+ fieldsContainerElem: HTMLDivElement | null;
14
+ context?: string | undefined;
15
+ } & Stylable & Classable>;
16
+ export default Fields;
17
+ interface FieldProps extends FieldOptions {
18
+ pointer: string;
19
+ selected?: string;
20
+ onSelected: OnSelectedCB;
21
+ onDeleted: OnSelectedCB;
22
+ onAdded: (field: string, property: Property) => void;
23
+ fields?: FieldProps[];
24
+ expanded?: boolean;
25
+ fieldsContainerElem: HTMLDivElement | null;
26
+ context?: string;
27
+ }
@@ -0,0 +1,185 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
22
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
23
+ return new (P || (P = Promise))(function (resolve, reject) {
24
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
25
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
26
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
27
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
28
+ });
29
+ };
30
+ var __importDefault = (this && this.__importDefault) || function (mod) {
31
+ return (mod && mod.__esModule) ? mod : { "default": mod };
32
+ };
33
+ Object.defineProperty(exports, "__esModule", { value: true });
34
+ const React = __importStar(require("react"));
35
+ const utils_1 = require("../../../utils");
36
+ const utils_2 = require("../../utils");
37
+ const components_1 = require("../components");
38
+ const Context_1 = require("../Context");
39
+ const LajiForm_1 = __importDefault(require("../LajiForm"));
40
+ const Fields = React.memo(function Fields({ fields = [], onSelected, onDeleted, onAdded, selected, pointer, style = {}, className, expanded, fieldsContainerElem, context }) {
41
+ return (React.createElement("div", { style: Object.assign(Object.assign({}, style), { display: "flex", flexDirection: "column" }), className: className }, fields.map((f) => (React.createElement(Field, Object.assign({ key: f.name }, f, { onSelected: onSelected, onDeleted: onDeleted, onAdded: onAdded, selected: selected, pointer: `${pointer}/${f.name}`, expanded: expanded, fieldsContainerElem: fieldsContainerElem, context: context }))))));
42
+ });
43
+ exports.default = Fields;
44
+ class Field extends React.PureComponent {
45
+ constructor() {
46
+ super(...arguments);
47
+ this.state = {
48
+ expanded: this.props.expanded || Field.isSelected(this.props.selected, this.props.pointer) || false,
49
+ addOpen: false
50
+ };
51
+ this.fieldRef = React.createRef();
52
+ this.nmspc = utils_2.nmspc("field");
53
+ this.toggleExpand = (e) => {
54
+ e.stopPropagation();
55
+ this.setState({ expanded: !this.state.expanded });
56
+ };
57
+ this.onThisSelected = () => {
58
+ this.props.onSelected(this.props.pointer);
59
+ };
60
+ this.onChildSelected = (pointer) => {
61
+ this.props.onSelected(pointer);
62
+ };
63
+ this.onThisDeleted = () => {
64
+ this.props.onDeleted(this.props.pointer);
65
+ };
66
+ this.onChildDeleted = (pointer) => {
67
+ this.props.onDeleted(pointer);
68
+ };
69
+ this.onOpenAdd = () => {
70
+ this.setState({ addOpen: true });
71
+ };
72
+ this.onCloseAdd = () => {
73
+ this.setState({ addOpen: false });
74
+ };
75
+ this.renderAdder = () => {
76
+ if (!this.state.properties) {
77
+ return null;
78
+ }
79
+ const existing = utils_1.dictionarify(this.props.fields || [], (field) => field.name);
80
+ const [enums, enumNames] = this.state.properties
81
+ .filter(p => !existing[utils_1.unprefixProp(p.property)])
82
+ .reduce(([_enums, _enumNames], prop) => {
83
+ _enums.push(prop.property);
84
+ _enumNames.push(`${prop.property} (${prop.label[this.context.lang]})`);
85
+ return [_enums, _enumNames];
86
+ }, [[], []]);
87
+ if (enums.length === 0) {
88
+ return null;
89
+ }
90
+ const schema = utils_1.JSONSchemaBuilder.enu({ enum: enums, enumNames }, { title: this.context.translations["addProperty"] });
91
+ return (React.createElement(LajiForm_1.default, { schema: schema, onChange: this.onAddProperty, autoFocus: true }));
92
+ };
93
+ this.onAddProperty = (property) => {
94
+ if (!property) {
95
+ return;
96
+ }
97
+ const propertyModel = this.state.properties
98
+ .find(childProp => childProp.property === property);
99
+ if (propertyModel) {
100
+ this.props.onAdded(this.props.pointer, propertyModel);
101
+ this.onCloseAdd();
102
+ }
103
+ };
104
+ }
105
+ static getDerivedStateFromProps(nextProps, prevState) {
106
+ if (nextProps.selected !== prevState.prevSelected
107
+ && !Field.isChildSelected(prevState.prevSelected, nextProps.pointer)
108
+ && Field.isChildSelected(nextProps.selected, nextProps.pointer)) {
109
+ return { expanded: true };
110
+ }
111
+ return {};
112
+ }
113
+ componentDidUpdate(prevProps) {
114
+ this.scrollToIfNeeded(prevProps);
115
+ }
116
+ componentDidMount() {
117
+ this.scrollToIfNeeded();
118
+ this.propertyContextAbortController = new AbortController();
119
+ this.getProperties(this.props.pointer, this.propertyContextAbortController.signal).then(properties => this.setState({ properties: properties.length ? properties : false }));
120
+ }
121
+ scrollToIfNeeded(prevProps) {
122
+ if ((!prevProps || !Field.isSelected(prevProps.selected, prevProps.pointer))
123
+ && Field.isSelected(this.props.selected, this.props.pointer)
124
+ && this.fieldRef.current && this.props.fieldsContainerElem) {
125
+ utils_2.scrollIntoViewIfNeeded(this.fieldRef.current, 0, 0, this.props.fieldsContainerElem);
126
+ }
127
+ }
128
+ static isSelected(selected, pointer) {
129
+ return selected === pointer;
130
+ }
131
+ static isChildSelected(selected = "", pointer) {
132
+ return selected.startsWith(pointer);
133
+ }
134
+ getProperties(path, signal) {
135
+ return __awaiter(this, void 0, void 0, function* () {
136
+ const getPropertyFromSubPathAndProp = (path, property) => __awaiter(this, void 0, void 0, function* () {
137
+ const splitted = path.substr(1).split("/");
138
+ const [cur, ...rest] = splitted;
139
+ if (splitted.length === 1) {
140
+ return property;
141
+ }
142
+ const properties = property.isEmbeddable
143
+ ? yield this.context.metadataService.getPropertiesForEmbeddedProperty(property.range[0], undefined, signal)
144
+ : [];
145
+ const nextProperty = properties === null || properties === void 0 ? void 0 : properties.find(p => utils_1.unprefixProp(p.property) === rest[0]);
146
+ if (!nextProperty) {
147
+ throw new Error("Couldn't find property " + cur);
148
+ }
149
+ return getPropertyFromSubPathAndProp("/" + rest.join("/"), nextProperty);
150
+ });
151
+ const property = yield getPropertyFromSubPathAndProp(`${path.length === 1 ? "" : path}`, utils_1.getRootProperty(utils_1.getRootField({ context: this.props.context })));
152
+ if (property.isEmbeddable) {
153
+ return yield this.context.metadataService.getPropertiesForEmbeddedProperty(property.range[0]);
154
+ }
155
+ else {
156
+ return [];
157
+ }
158
+ });
159
+ }
160
+ render() {
161
+ var _a;
162
+ const { name, fields = [], selected, pointer } = this.props;
163
+ const expandClassName = this.nmspc(fields.length
164
+ ? this.state.expanded
165
+ ? "expanded"
166
+ : "contracted"
167
+ : "nonexpandable");
168
+ const isSelected = Field.isSelected(this.props.selected, this.props.pointer);
169
+ const containerClassName = utils_2.classNames(this.nmspc("item"), this.nmspc(pointer.substr(1).replace(/\//g, "-")), isSelected && this.nmspc("item-selected"));
170
+ return (React.createElement("div", { className: utils_2.classNames(this.nmspc(), isSelected && this.nmspc("selected")), ref: this.fieldRef },
171
+ React.createElement(components_1.Clickable, { className: containerClassName, onClick: this.onThisSelected },
172
+ React.createElement(components_1.Clickable, { className: expandClassName, onClick: fields.length ? this.toggleExpand : undefined, key: "expand" }),
173
+ React.createElement(components_1.Clickable, { className: this.nmspc("label") }, name),
174
+ this.state.properties === false
175
+ ? null
176
+ : ((_a = this.state.properties) === null || _a === void 0 ? void 0 : _a.length)
177
+ ? React.createElement(components_1.Clickable, { className: this.nmspc("add"), onClick: this.onOpenAdd })
178
+ : React.createElement(components_1.Spinner, { color: "white", size: 15 }),
179
+ React.createElement(components_1.Clickable, { className: this.nmspc("delete"), onClick: this.onThisDeleted })),
180
+ this.state.expanded && (React.createElement(Fields, { fields: fields, onSelected: this.onChildSelected, onDeleted: this.onChildDeleted, onAdded: this.props.onAdded, selected: selected, pointer: pointer, fieldsContainerElem: this.props.fieldsContainerElem, context: this.props.context })),
181
+ this.state.addOpen && (React.createElement(components_1.GenericModal, { onHide: this.onCloseAdd }, this.renderAdder()))));
182
+ }
183
+ }
184
+ Field.contextType = Context_1.Context;
185
+ //# sourceMappingURL=Fields.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Fields.js","sourceRoot":"","sources":["../../../../src/client/components/Editor/Fields.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ import * as React from "react";
2
+ import { Stylable } from "../components";
3
+ import { OptionChangeEvent, TranslationsChangeEvent } from "../../services/change-handler-service";
4
+ import { Property, Master, Lang, JSONObject } from "../../../model";
5
+ import MetadataService from "../../../services/metadata-service";
6
+ export declare const mapRangeToUiSchema: (property: Property, metadataService: MetadataService, lang: Lang) => Promise<JSONObject>;
7
+ export declare const mapPropertyToUiSchema: (property: Property, metadataService: MetadataService, lang: Lang) => Promise<JSONObject>;
8
+ declare type FormOptionEvent = OptionChangeEvent | TranslationsChangeEvent;
9
+ declare const _default: React.MemoExoticComponent<React.ForwardRefExoticComponent<Stylable & {
10
+ master: Master;
11
+ translations: {
12
+ [key: string]: string;
13
+ };
14
+ onChange: (events: FormOptionEvent | FormOptionEvent[]) => void;
15
+ onLoaded?: (() => void) | undefined;
16
+ filter?: string[] | undefined;
17
+ clearFilters: () => void;
18
+ topOffset?: number | undefined;
19
+ } & React.RefAttributes<HTMLDivElement>>>;
20
+ export default _default;
@@ -0,0 +1,207 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
22
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
23
+ return new (P || (P = Promise))(function (resolve, reject) {
24
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
25
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
26
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
27
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
28
+ });
29
+ };
30
+ var __rest = (this && this.__rest) || function (s, e) {
31
+ var t = {};
32
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
33
+ t[p] = s[p];
34
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
35
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
36
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
37
+ t[p[i]] = s[p[i]];
38
+ }
39
+ return t;
40
+ };
41
+ var __importDefault = (this && this.__importDefault) || function (mod) {
42
+ return (mod && mod.__esModule) ? mod : { "default": mod };
43
+ };
44
+ Object.defineProperty(exports, "__esModule", { value: true });
45
+ exports.mapPropertyToUiSchema = exports.mapRangeToUiSchema = void 0;
46
+ const React = __importStar(require("react"));
47
+ const LajiForm_1 = __importDefault(require("../LajiForm"));
48
+ const Context_1 = require("../Context");
49
+ const components_1 = require("../components");
50
+ const model_1 = require("../../../model");
51
+ const utils_1 = require("../../../utils");
52
+ const utils_2 = require("../../utils");
53
+ const utils_3 = require("@luomus/laji-form/lib/utils");
54
+ const UiSchemaEditor_1 = require("./UiSchemaEditor");
55
+ const Editor_1 = require("./Editor");
56
+ const mapRangeToUiSchema = (property, metadataService, lang) => __awaiter(void 0, void 0, void 0, function* () {
57
+ const range = property.range[0];
58
+ if (range === "MY.document" || range === model_1.PropertyRange.keyValue) {
59
+ return { "ui:field": "TextareaEditorField" };
60
+ }
61
+ if (property.isEmbeddable) {
62
+ const properties = yield metadataService.getPropertiesForEmbeddedProperty(range);
63
+ const propertiesUiSchemas = yield Promise.all(properties.map(p => exports.mapPropertyToUiSchema(p, metadataService, lang)));
64
+ return propertiesUiSchemas.reduce((ps, p, i) => (Object.assign(Object.assign({}, ps), { [utils_1.unprefixProp(properties[i].property)]: p })), {});
65
+ }
66
+ return {};
67
+ });
68
+ exports.mapRangeToUiSchema = mapRangeToUiSchema;
69
+ const mapComment = (comment, uiSchema) => (Object.assign(Object.assign({}, uiSchema), { "ui:help": comment }));
70
+ const mapPropertyToUiSchema = (property, metadataService, lang) => __awaiter(void 0, void 0, void 0, function* () { return mapComment(utils_1.multiLang(property.comment, lang), yield exports.mapRangeToUiSchema(property, metadataService, lang)); });
71
+ exports.mapPropertyToUiSchema = mapPropertyToUiSchema;
72
+ const formProperty = {
73
+ range: ["MHL.form"],
74
+ property: "MHL.form",
75
+ isEmbeddable: true,
76
+ label: {},
77
+ maxOccurs: "1",
78
+ minOccurs: "1",
79
+ multiLanguage: false,
80
+ shortName: "form",
81
+ required: false,
82
+ domain: []
83
+ };
84
+ const prepareSchema = (schema) => {
85
+ delete schema.properties.fields;
86
+ delete schema.properties.uiSchema;
87
+ delete schema.properties.translations;
88
+ return schema;
89
+ };
90
+ const prepareUiSchema = (schema, uiSchema, formData, filter, displayOnlyUsed = false) => {
91
+ uiSchema["ui:order"] = [
92
+ "name",
93
+ "title",
94
+ "description",
95
+ "shortDescription",
96
+ "baseFormID",
97
+ "fieldsFormID",
98
+ "collectionID",
99
+ "category",
100
+ "logo",
101
+ "options",
102
+ "*"
103
+ ];
104
+ const doFilter = (schema, uiSchema, formData, filter) => {
105
+ if (!filter && !displayOnlyUsed) {
106
+ return;
107
+ }
108
+ const properties = model_1.isJSONSchemaObject(schema) ? schema.properties : undefined;
109
+ properties && Object.keys(properties).forEach((prop) => {
110
+ if ((filter && !filter[prop]) || (displayOnlyUsed && utils_3.isDefaultData(formData === null || formData === void 0 ? void 0 : formData[prop], properties[prop]))) {
111
+ uiSchema[prop] = { "ui:field": "HiddenField" };
112
+ }
113
+ if (!uiSchema[prop]) {
114
+ uiSchema[prop] = {};
115
+ }
116
+ doFilter(properties[prop], uiSchema[prop], formData === null || formData === void 0 ? void 0 : formData[prop], filter === null || filter === void 0 ? void 0 : filter[prop]);
117
+ });
118
+ };
119
+ const filterTree = filter === null || filter === void 0 ? void 0 : filter.reduce((tree, f) => {
120
+ const splits = f.split("/").filter(s => s);
121
+ let treePointer = tree;
122
+ splits.forEach((s, i) => {
123
+ if (i === splits.length - 1) {
124
+ treePointer[s] = true;
125
+ }
126
+ else {
127
+ if (!treePointer[s]) {
128
+ treePointer[s] = {};
129
+ }
130
+ treePointer = treePointer[s];
131
+ }
132
+ });
133
+ return tree;
134
+ }, {});
135
+ doFilter(schema, uiSchema, formData, filterTree);
136
+ return uiSchema;
137
+ };
138
+ const prepareMaster = (master) => {
139
+ const { fields, uiSchema, translations, id, "@context": storeContext, "@type": storeType } = master, _master = __rest(master, ["fields", "uiSchema", "translations", "id", "@context", "@type"]);
140
+ return _master;
141
+ };
142
+ exports.default = React.memo(React.forwardRef(function OptionsEditor({ master, onChange, translations, onLoaded, filter, clearFilters, topOffset = 0 }, ref) {
143
+ const context = React.useContext(Context_1.Context);
144
+ const { metadataService, translations: appTranslations, editorLang } = context;
145
+ const [schema, setModelSchema] = React.useState();
146
+ const [uiSchema, setModelUiSchema] = React.useState();
147
+ const [displayOnlyUsed, setDisplayOnlyUsed] = React.useState(false);
148
+ const toggleSetDisplayOnlyUsed = React.useCallback(() => setDisplayOnlyUsed(!displayOnlyUsed), [displayOnlyUsed, setDisplayOnlyUsed]);
149
+ const _master = React.useMemo(() => prepareMaster(master), [master]);
150
+ const formData = React.useMemo(() => utils_1.translate(_master, translations), [_master, translations]);
151
+ React.useEffect(() => {
152
+ (() => __awaiter(this, void 0, void 0, function* () {
153
+ const schema = yield metadataService.getJSONSchemaFromProperty(formProperty);
154
+ setModelSchema(prepareSchema(schema));
155
+ setModelUiSchema(prepareUiSchema(schema, yield exports.mapPropertyToUiSchema(formProperty, metadataService, editorLang), formData, filter, displayOnlyUsed));
156
+ }))();
157
+ }, [metadataService, filter, editorLang, displayOnlyUsed, formData]);
158
+ const onLajiFormChange = React.useCallback((viewFormData) => {
159
+ const changedPaths = utils_2.detectChangePaths(viewFormData, formData);
160
+ let newFormData = _master;
161
+ const events = [];
162
+ changedPaths.forEach(changedPath => {
163
+ const currentValue = utils_1.parseJSONPointer(newFormData, changedPath);
164
+ const newValue = utils_1.parseJSONPointer(viewFormData, changedPath);
165
+ if (typeof currentValue === "string" || typeof newValue === "string") {
166
+ newFormData = utils_2.handleTranslationChange(newFormData, events, "", changedPath, context, currentValue, newValue);
167
+ events.push({ type: "options", value: utils_1.parseJSONPointer(newFormData, changedPath), path: changedPath });
168
+ }
169
+ else {
170
+ newFormData = utils_3.updateSafelyWithJSONPointer(newFormData, newValue, changedPath);
171
+ events.push({ type: "options", value: newValue, path: changedPath });
172
+ }
173
+ });
174
+ onChange(events);
175
+ }, [formData, onChange, _master, context]);
176
+ let props = React.useMemo(() => ({
177
+ schema,
178
+ uiSchema,
179
+ formData,
180
+ onChange: onLajiFormChange,
181
+ fields: { TextareaEditorField: UiSchemaEditor_1.TextareaEditorField },
182
+ }), [schema, uiSchema, formData, onLajiFormChange]);
183
+ React.useEffect(() => {
184
+ if (schema && onLoaded) {
185
+ onLoaded();
186
+ }
187
+ }, [schema, onLoaded]);
188
+ const content = React.useCallback(() => {
189
+ const _content = !schema
190
+ ? React.createElement(components_1.Spinner, null)
191
+ : (React.createElement("div", { style: { height: "100%", overflow: "auto" }, className: Editor_1.editorContentNmspc("ui") },
192
+ React.createElement(LajiForm_1.default, Object.assign({}, props))));
193
+ return React.createElement(React.Fragment, null,
194
+ React.createElement(Editor_1.EditorToolbar, null,
195
+ React.createElement(components_1.Button, { onClick: toggleSetDisplayOnlyUsed, active: displayOnlyUsed, small: true }, appTranslations["editor.options.displayOnlyUsed"]),
196
+ (filter === null || filter === void 0 ? void 0 : filter.length) && React.createElement(components_1.Button, { small: true, variant: "danger", onClick: clearFilters }, appTranslations["editor.options.clear"])),
197
+ _content);
198
+ }, [schema, props, toggleSetDisplayOnlyUsed, displayOnlyUsed, appTranslations, filter === null || filter === void 0 ? void 0 : filter.length, clearFilters]);
199
+ const getJSON = React.useCallback(() => formData, [formData]);
200
+ const [activeTab, setActiveTab] = React.useState("JSON");
201
+ React.useEffect(() => {
202
+ (filter === null || filter === void 0 ? void 0 : filter.length) && setActiveTab("UI");
203
+ }, [filter]);
204
+ return (React.createElement("div", { className: utils_2.gnmspc("options-editor"), ref: ref, style: { width: "100%" } },
205
+ React.createElement(Editor_1.GenericEditorContent, { json: getJSON(), onJSONChange: onLajiFormChange, validator: model_1.isJSONObject, renderUI: content, activeTab: activeTab, onTabChange: setActiveTab, overflowUIContent: false, topOffset: (activeTab === "JSON" ? 46 : 73) + topOffset })));
206
+ }));
207
+ //# sourceMappingURL=OptionsEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OptionsEditor.js","sourceRoot":"","sources":["../../../../src/client/components/Editor/OptionsEditor.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ import * as React from "react";
2
+ import memoize from "memoizee";
3
+ import { Context } from "../Context";
4
+ import { FieldProps } from "@luomus/laji-form/lib/components/LajiForm";
5
+ import { JSONObject, JSONSchema } from "../../../model";
6
+ import { GenericFieldEditorProps } from "./FieldEditor";
7
+ export default class UiSchemaEditor extends React.PureComponent<GenericFieldEditorProps> {
8
+ static contextType: React.Context<import("../Context").ContextProps>;
9
+ context: React.ContextType<typeof Context>;
10
+ constructor(props: GenericFieldEditorProps);
11
+ getEditorSchema: ((uiSchema: JSONObject | undefined, schema: JSONSchema<import("../../../model").JSONSchemaEnumOneOf>, prefix?: string | undefined) => any) & memoize.Memoized<(uiSchema: JSONObject | undefined, schema: JSONSchema<import("../../../model").JSONSchemaEnumOneOf>, prefix?: string | undefined) => any>;
12
+ getEditorUiSchema: ((uiSchema: JSONObject | undefined, schemaForUiSchema: JSONSchema) => any) & memoize.Memoized<(uiSchema: JSONObject | undefined, schemaForUiSchema: JSONSchema) => any>;
13
+ normalizeUiSchema<T extends JSONObject | undefined>(uiSchema: T, prefix?: string): T;
14
+ render(): JSX.Element;
15
+ renderUI(): JSX.Element | null;
16
+ getJSONEditorFormData(): JSONObject | undefined;
17
+ onUiSchemaChange(eventUiSchema: JSONObject | undefined, oldUiSchema: JSONObject | undefined): void;
18
+ onEditorLajiFormChange: (eventUiSchema: JSONObject) => void;
19
+ onJSONEditorChange(uiSchema: JSONObject | undefined): void;
20
+ }
21
+ export declare const TextareaEditorField: (props: FieldProps) => JSX.Element;
22
+ export declare const EditorLajiForm: (props: any) => JSX.Element;