UNPKG

@tomino/dynamic-form-semantic-ui

Version:

Semantic UI form renderer based on dynamic form generation

166 lines 20.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const tslib_1 = require("tslib"); const react_1 = tslib_1.__importDefault(require("react")); const semantic_ui_react_1 = require("semantic-ui-react"); const mobx_react_1 = require("mobx-react"); const react_router_1 = require("react-router"); const dynamic_form_1 = require("@tomino/dynamic-form"); const react_router_view_1 = require("./react_router_view"); const common_1 = require("../common"); const editor_common_1 = require("../editor/editor_common"); const wrapper_1 = require("../wrapper"); const layouts_common_editor_1 = require("../editor/layouts_common_editor"); const helpers_1 = require("../helpers"); const editor_context_1 = require("../editor/editor_context"); exports.thumbnails = { dark: '', light: '' }; const DisabledRouter = props => (react_1.default.createElement(react_router_1.MemoryRouter, { initialEntries: [props.formElement.props.testRoute] }, common_1.createComponents(props))); DisabledRouter.displayName = 'DisabledRouter'; exports.ReactRouterProviderEditorComponent = props => { const context = react_1.default.useContext(editor_context_1.EditorContext); let route = helpers_1.getValue(props, context, 'testRoute'); return (react_1.default.createElement(wrapper_1.DynamicComponent, Object.assign({}, props, { preserveProps: true, label: dynamic_form_1.config.i18n `Router Provider`, control: !props.formElement.elements || props.formElement.elements.length == 0 ? layouts_common_editor_1.EditorDropCell : route ? DisabledRouter : react_router_view_1.ReactRouterProvider }))); }; exports.ReactRouterProviderEditor = { Component: mobx_react_1.observer(exports.ReactRouterProviderEditorComponent), title: 'React Router Provider', control: 'ReactRouterProvider', thumbnail: exports.thumbnails, provider: true, group: 'React Router', props: editor_common_1.propGroup('Editor', { testRoute: editor_common_1.boundProp({ documentation: 'This is useful during testing when a mocked provider can be used instead.' }) }) }; exports.routeProps = editor_common_1.propGroup('Router', { exact: editor_common_1.prop({ group: 'Route', control: 'Checkbox', documentation: 'Allows to match the path "exactly". For example route "/" without "exact" would match also "/home"', label: 'Exact', type: 'boolean' }), path: editor_common_1.prop({ group: 'Route', label: 'Path', documentation: 'Path / Route to match', type: 'string' }), page: editor_common_1.prop({ control: 'Select', group: 'Route', label: 'Page', documentation: 'Page to display', props: { options: { handler: 'optionsProjectPages' } }, type: 'string' }) }); exports.ReactRouterRouteEditor = { Component: mobx_react_1.observer(react_router_view_1.ReactRouterRoute), title: 'Route', control: 'ReactRouterRoute', thumbnail: exports.thumbnails, group: 'React Router', props: exports.routeProps, handlers: { optionsProjectPages: ({ owner }) => { const form = common_1.root(owner); return form.pages ? form.pages.map(p => ({ text: p.props.label, value: p.uid })) : []; } } }; exports.ReactRouterSwitchEditor = { Component: mobx_react_1.observer(react_router_view_1.ReactRouterSwitch), title: 'Switch', control: 'ReactRouterSwitch', thumbnail: exports.thumbnails, group: 'React Router', props: { config: editor_common_1.prop({ control: 'Table', props: { text: 'Routes' }, elements: [ { control: 'Input', props: { placeholder: 'path', label: 'Path', value: { source: 'path' } } }, { control: 'Select', props: { label: 'Page', value: { source: 'page' }, options: { handler: 'optionsProjectPages' } }, documentation: 'Page to display' }, { control: 'Checkbox', props: { label: 'Exact', width: '20px', value: { source: 'exact' } } } ], type: 'array', items: { type: 'object', properties: { exact: { type: 'boolean' }, path: { type: 'string' }, page: { type: 'string' } } } }) } }; exports.ReactRouterLinkEditor = { Component: mobx_react_1.observer(react_router_view_1.ReactRouterLinkView.Component), title: 'Link', control: 'ReactRouterLink', thumbnail: exports.thumbnails, group: 'React Router', props: editor_common_1.propGroup('Router', { url: editor_common_1.prop({ label: 'Url', documentation: 'You can interpolate values using "${}" notation. For example "This is my ${name}", where <i>name</i> is a value from the dataset.', type: 'string' }), text: editor_common_1.prop({ label: 'Text', documentation: 'You can interpolate values using "${}" notation. For example "This is my ${name}", where <i>name</i> is a value from the dataset.', type: 'string' }) }) }; exports.ReactRouterRedirectEditorComponent = mobx_react_1.observer(props => react_1.default.createElement(semantic_ui_react_1.Label, { content: `Redirect to: ${props.formElement.props.url}` })); exports.ReactRouterRedirectEditor = { Component: mobx_react_1.observer(exports.ReactRouterRedirectEditorComponent), title: 'Redirect', control: 'ReactRouterRedirect', icon: 'anchor', props: editor_common_1.propGroup('Router', { url: editor_common_1.prop({ label: 'Url', documentation: 'You can interpolate values using "${}" notation. For example "This is my ${name}", where <i>name</i> is a value from the dataset.', type: 'string' }) }) }; //# sourceMappingURL=react_router_editor.js.map