@wavemaker-ai/react-codegen 1.0.0-rc.309
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.
- package/build-react-web.js +149 -0
- package/build-react-web.js.map +1 -0
- package/command.js +106 -0
- package/command.js.map +1 -0
- package/dist/transpiler/index.d.mts +62 -0
- package/dist/transpiler/index.mjs +47857 -0
- package/dist/transpiler/index.mjs.map +1 -0
- package/dist/transpiler/wm-styles.css +1502 -0
- package/index.js +122 -0
- package/index.js.map +1 -0
- package/package-lock.json +5243 -0
- package/package.json +104 -0
- package/src/app.generator.js +1274 -0
- package/src/app.generator.js.map +1 -0
- package/src/download-packages.js +193 -0
- package/src/download-packages.js.map +1 -0
- package/src/fomatter.js +20 -0
- package/src/fomatter.js.map +1 -0
- package/src/gen-app-override-css.js +379 -0
- package/src/gen-app-override-css.js.map +1 -0
- package/src/genappoverridecssold-file.js +311 -0
- package/src/genappoverridecssold-file.js.map +1 -0
- package/src/handlebar-helpers.js +51 -0
- package/src/handlebar-helpers.js.map +1 -0
- package/src/increment-builder.js +85 -0
- package/src/increment-builder.js.map +1 -0
- package/src/profiles/profile.js +24 -0
- package/src/profiles/profile.js.map +1 -0
- package/src/profiles/web-preview.profile.js +15 -0
- package/src/profiles/web-preview.profile.js.map +1 -0
- package/src/project.service.js +314 -0
- package/src/project.service.js.map +1 -0
- package/src/transpile/bind.ex.transformer.js +232 -0
- package/src/transpile/bind.ex.transformer.js.map +1 -0
- package/src/transpile/components/advanced/carousel-template.transformer.js +16 -0
- package/src/transpile/components/advanced/carousel-template.transformer.js.map +1 -0
- package/src/transpile/components/advanced/carousel.transformer.js +54 -0
- package/src/transpile/components/advanced/carousel.transformer.js.map +1 -0
- package/src/transpile/components/advanced/login.transformer.js +25 -0
- package/src/transpile/components/advanced/login.transformer.js.map +1 -0
- package/src/transpile/components/advanced/marquee.transformer.js +16 -0
- package/src/transpile/components/advanced/marquee.transformer.js.map +1 -0
- package/src/transpile/components/basic/anchor.transformer.js +13 -0
- package/src/transpile/components/basic/anchor.transformer.js.map +1 -0
- package/src/transpile/components/basic/audio.transformer.js +16 -0
- package/src/transpile/components/basic/audio.transformer.js.map +1 -0
- package/src/transpile/components/basic/html.transformer.js +15 -0
- package/src/transpile/components/basic/html.transformer.js.map +1 -0
- package/src/transpile/components/basic/icon.transformer.js +16 -0
- package/src/transpile/components/basic/icon.transformer.js.map +1 -0
- package/src/transpile/components/basic/iframe.transformer.js +16 -0
- package/src/transpile/components/basic/iframe.transformer.js.map +1 -0
- package/src/transpile/components/basic/label.transformer.js +16 -0
- package/src/transpile/components/basic/label.transformer.js.map +1 -0
- package/src/transpile/components/basic/message.transformer.js +16 -0
- package/src/transpile/components/basic/message.transformer.js.map +1 -0
- package/src/transpile/components/basic/picture.transformer.js +22 -0
- package/src/transpile/components/basic/picture.transformer.js.map +1 -0
- package/src/transpile/components/basic/progress-bar.transformer.js +18 -0
- package/src/transpile/components/basic/progress-bar.transformer.js.map +1 -0
- package/src/transpile/components/basic/progress-circle.transformer.js +16 -0
- package/src/transpile/components/basic/progress-circle.transformer.js.map +1 -0
- package/src/transpile/components/basic/richtexteditor.transformer.js +21 -0
- package/src/transpile/components/basic/richtexteditor.transformer.js.map +1 -0
- package/src/transpile/components/basic/search.transformer.js +68 -0
- package/src/transpile/components/basic/search.transformer.js.map +1 -0
- package/src/transpile/components/basic/spinner.transformer.js +16 -0
- package/src/transpile/components/basic/spinner.transformer.js.map +1 -0
- package/src/transpile/components/basic/tree.transformer.js +16 -0
- package/src/transpile/components/basic/tree.transformer.js.map +1 -0
- package/src/transpile/components/basic/video.transformer.js +16 -0
- package/src/transpile/components/basic/video.transformer.js.map +1 -0
- package/src/transpile/components/chart/chart.transformer.js +13 -0
- package/src/transpile/components/chart/chart.transformer.js.map +1 -0
- package/src/transpile/components/container/accordion-pane.transformer.js +44 -0
- package/src/transpile/components/container/accordion-pane.transformer.js.map +1 -0
- package/src/transpile/components/container/accordion.transformer.js +48 -0
- package/src/transpile/components/container/accordion.transformer.js.map +1 -0
- package/src/transpile/components/container/container.transformer.js +39 -0
- package/src/transpile/components/container/container.transformer.js.map +1 -0
- package/src/transpile/components/container/layout-grid/grid-column.transformer.js +16 -0
- package/src/transpile/components/container/layout-grid/grid-column.transformer.js.map +1 -0
- package/src/transpile/components/container/layout-grid/grid-row.transformer.js +16 -0
- package/src/transpile/components/container/layout-grid/grid-row.transformer.js.map +1 -0
- package/src/transpile/components/container/layout-grid/grid.transformer.js +16 -0
- package/src/transpile/components/container/layout-grid/grid.transformer.js.map +1 -0
- package/src/transpile/components/container/linear-layout/linear-layout-item.js +16 -0
- package/src/transpile/components/container/linear-layout/linear-layout-item.js.map +1 -0
- package/src/transpile/components/container/linear-layout/linear-layout.js +16 -0
- package/src/transpile/components/container/linear-layout/linear-layout.js.map +1 -0
- package/src/transpile/components/container/panel-content.transformer.js +16 -0
- package/src/transpile/components/container/panel-content.transformer.js.map +1 -0
- package/src/transpile/components/container/panel-footer.transformer.js +11 -0
- package/src/transpile/components/container/panel-footer.transformer.js.map +1 -0
- package/src/transpile/components/container/panel.transformer.js +36 -0
- package/src/transpile/components/container/panel.transformer.js.map +1 -0
- package/src/transpile/components/container/repeat-template.transformer.js +16 -0
- package/src/transpile/components/container/repeat-template.transformer.js.map +1 -0
- package/src/transpile/components/container/tabheader.transformer.js +13 -0
- package/src/transpile/components/container/tabheader.transformer.js.map +1 -0
- package/src/transpile/components/container/tabpane.transformer.js +48 -0
- package/src/transpile/components/container/tabpane.transformer.js.map +1 -0
- package/src/transpile/components/container/tabs.transformer.js +71 -0
- package/src/transpile/components/container/tabs.transformer.js.map +1 -0
- package/src/transpile/components/container/tile.transformer.js +16 -0
- package/src/transpile/components/container/tile.transformer.js.map +1 -0
- package/src/transpile/components/container/wizard.transformer.js +80 -0
- package/src/transpile/components/container/wizard.transformer.js.map +1 -0
- package/src/transpile/components/container/wizardaction.transformer.js +120 -0
- package/src/transpile/components/container/wizardaction.transformer.js.map +1 -0
- package/src/transpile/components/container/wizardstep.transformer.js +99 -0
- package/src/transpile/components/container/wizardstep.transformer.js.map +1 -0
- package/src/transpile/components/data/card/card-actions.transformer.js +13 -0
- package/src/transpile/components/data/card/card-actions.transformer.js.map +1 -0
- package/src/transpile/components/data/card/card-content.transformer.js +33 -0
- package/src/transpile/components/data/card/card-content.transformer.js.map +1 -0
- package/src/transpile/components/data/card/card-footer.transformer.js +13 -0
- package/src/transpile/components/data/card/card-footer.transformer.js.map +1 -0
- package/src/transpile/components/data/card/card.transformer.js +13 -0
- package/src/transpile/components/data/card/card.transformer.js.map +1 -0
- package/src/transpile/components/data/form/dynamic-fields.transformer.js +24 -0
- package/src/transpile/components/data/form/dynamic-fields.transformer.js.map +1 -0
- package/src/transpile/components/data/form/form-action.transformer.js +145 -0
- package/src/transpile/components/data/form/form-action.transformer.js.map +1 -0
- package/src/transpile/components/data/form/form-body.transformer.js +16 -0
- package/src/transpile/components/data/form/form-body.transformer.js.map +1 -0
- package/src/transpile/components/data/form/form-field.transformer.js +442 -0
- package/src/transpile/components/data/form/form-field.transformer.js.map +1 -0
- package/src/transpile/components/data/form/form-footer.transformer.js +16 -0
- package/src/transpile/components/data/form/form-footer.transformer.js.map +1 -0
- package/src/transpile/components/data/form/form.transformer.js +166 -0
- package/src/transpile/components/data/form/form.transformer.js.map +1 -0
- package/src/transpile/components/data/form/util.js +70 -0
- package/src/transpile/components/data/form/util.js.map +1 -0
- package/src/transpile/components/data/list/list-content.transformer.js +35 -0
- package/src/transpile/components/data/list/list-content.transformer.js.map +1 -0
- package/src/transpile/components/data/list/list-template-transformer.js +22 -0
- package/src/transpile/components/data/list/list-template-transformer.js.map +1 -0
- package/src/transpile/components/data/list/list-transformer.js +287 -0
- package/src/transpile/components/data/list/list-transformer.js.map +1 -0
- package/src/transpile/components/data/live-filter-field.transformer.js +436 -0
- package/src/transpile/components/data/live-filter-field.transformer.js.map +1 -0
- package/src/transpile/components/data/livefilter.transformer.js +140 -0
- package/src/transpile/components/data/livefilter.transformer.js.map +1 -0
- package/src/transpile/components/data/liveform.transformer.js +159 -0
- package/src/transpile/components/data/liveform.transformer.js.map +1 -0
- package/src/transpile/components/data/table/live-table.transformer.js +15 -0
- package/src/transpile/components/data/table/live-table.transformer.js.map +1 -0
- package/src/transpile/components/data/table/table-action.transformer.js +29 -0
- package/src/transpile/components/data/table/table-action.transformer.js.map +1 -0
- package/src/transpile/components/data/table/table-column.transformer.js +121 -0
- package/src/transpile/components/data/table/table-column.transformer.js.map +1 -0
- package/src/transpile/components/data/table/table-group.transformer.js +16 -0
- package/src/transpile/components/data/table/table-group.transformer.js.map +1 -0
- package/src/transpile/components/data/table/table-row-action.transformer.js +34 -0
- package/src/transpile/components/data/table/table-row-action.transformer.js.map +1 -0
- package/src/transpile/components/data/table/table-row.transformer.js +46 -0
- package/src/transpile/components/data/table/table-row.transformer.js.map +1 -0
- package/src/transpile/components/data/table/table.transformer.js +64 -0
- package/src/transpile/components/data/table/table.transformer.js.map +1 -0
- package/src/transpile/components/data/table/utils.js +89 -0
- package/src/transpile/components/data/table/utils.js.map +1 -0
- package/src/transpile/components/dialogs/alert-dialog.transformer.js +16 -0
- package/src/transpile/components/dialogs/alert-dialog.transformer.js.map +1 -0
- package/src/transpile/components/dialogs/confirm-dialog.transformer.js +16 -0
- package/src/transpile/components/dialogs/confirm-dialog.transformer.js.map +1 -0
- package/src/transpile/components/dialogs/dialog-actions.transformer.js +56 -0
- package/src/transpile/components/dialogs/dialog-actions.transformer.js.map +1 -0
- package/src/transpile/components/dialogs/dialog-body.transformer.js +13 -0
- package/src/transpile/components/dialogs/dialog-body.transformer.js.map +1 -0
- package/src/transpile/components/dialogs/dialog.transformer.js +26 -0
- package/src/transpile/components/dialogs/dialog.transformer.js.map +1 -0
- package/src/transpile/components/dialogs/iframe-dialog.transformer.js +16 -0
- package/src/transpile/components/dialogs/iframe-dialog.transformer.js.map +1 -0
- package/src/transpile/components/dialogs/login-dialog.transformer.js +44 -0
- package/src/transpile/components/dialogs/login-dialog.transformer.js.map +1 -0
- package/src/transpile/components/dialogs/page-dialog.transformer.js +16 -0
- package/src/transpile/components/dialogs/page-dialog.transformer.js.map +1 -0
- package/src/transpile/components/element/html-transformer.js +9 -0
- package/src/transpile/components/element/html-transformer.js.map +1 -0
- package/src/transpile/components/form/button-group.transformer.js +16 -0
- package/src/transpile/components/form/button-group.transformer.js.map +1 -0
- package/src/transpile/components/form/button.transformer.js +27 -0
- package/src/transpile/components/form/button.transformer.js.map +1 -0
- package/src/transpile/components/form/rating.transformer.js +19 -0
- package/src/transpile/components/form/rating.transformer.js.map +1 -0
- package/src/transpile/components/input/calendar.transformer.js +13 -0
- package/src/transpile/components/input/calendar.transformer.js.map +1 -0
- package/src/transpile/components/input/checkbox-set.transformer.js +29 -0
- package/src/transpile/components/input/checkbox-set.transformer.js.map +1 -0
- package/src/transpile/components/input/checkbox.transformer.js +47 -0
- package/src/transpile/components/input/checkbox.transformer.js.map +1 -0
- package/src/transpile/components/input/chips.transformer.js +22 -0
- package/src/transpile/components/input/chips.transformer.js.map +1 -0
- package/src/transpile/components/input/color-picker.transformer.js +19 -0
- package/src/transpile/components/input/color-picker.transformer.js.map +1 -0
- package/src/transpile/components/input/composite.transformer.js +16 -0
- package/src/transpile/components/input/composite.transformer.js.map +1 -0
- package/src/transpile/components/input/currency.transformer.js +21 -0
- package/src/transpile/components/input/currency.transformer.js.map +1 -0
- package/src/transpile/components/input/epoch/date.transformer.js +16 -0
- package/src/transpile/components/input/epoch/date.transformer.js.map +1 -0
- package/src/transpile/components/input/epoch/datetime.transformer.js +16 -0
- package/src/transpile/components/input/epoch/datetime.transformer.js.map +1 -0
- package/src/transpile/components/input/epoch/time.transformer.js +16 -0
- package/src/transpile/components/input/epoch/time.transformer.js.map +1 -0
- package/src/transpile/components/input/file-upload.transformer.js +32 -0
- package/src/transpile/components/input/file-upload.transformer.js.map +1 -0
- package/src/transpile/components/input/number.transformer.js +20 -0
- package/src/transpile/components/input/number.transformer.js.map +1 -0
- package/src/transpile/components/input/radio-set.transformer.js +25 -0
- package/src/transpile/components/input/radio-set.transformer.js.map +1 -0
- package/src/transpile/components/input/rating.transformer.js +20 -0
- package/src/transpile/components/input/rating.transformer.js.map +1 -0
- package/src/transpile/components/input/select.transformer.js +57 -0
- package/src/transpile/components/input/select.transformer.js.map +1 -0
- package/src/transpile/components/input/slider.transformer.js +28 -0
- package/src/transpile/components/input/slider.transformer.js.map +1 -0
- package/src/transpile/components/input/switch.transformer.js +21 -0
- package/src/transpile/components/input/switch.transformer.js.map +1 -0
- package/src/transpile/components/input/text.transformer.js +21 -0
- package/src/transpile/components/input/text.transformer.js.map +1 -0
- package/src/transpile/components/input/textarea.transformer.js +19 -0
- package/src/transpile/components/input/textarea.transformer.js.map +1 -0
- package/src/transpile/components/input/upload.transformer.js +19 -0
- package/src/transpile/components/input/upload.transformer.js.map +1 -0
- package/src/transpile/components/layout/footer.transformer.js +48 -0
- package/src/transpile/components/layout/footer.transformer.js.map +1 -0
- package/src/transpile/components/layout/header.transformer.js +48 -0
- package/src/transpile/components/layout/header.transformer.js.map +1 -0
- package/src/transpile/components/layout/leftnav.transformer.js +48 -0
- package/src/transpile/components/layout/leftnav.transformer.js.map +1 -0
- package/src/transpile/components/layout/rightnav.transformer.js +48 -0
- package/src/transpile/components/layout/rightnav.transformer.js.map +1 -0
- package/src/transpile/components/layout/topnav.transformer.js +48 -0
- package/src/transpile/components/layout/topnav.transformer.js.map +1 -0
- package/src/transpile/components/nav/nav-item.transformer.js +24 -0
- package/src/transpile/components/nav/nav-item.transformer.js.map +1 -0
- package/src/transpile/components/nav/nav.transformer.js +68 -0
- package/src/transpile/components/nav/nav.transformer.js.map +1 -0
- package/src/transpile/components/nav/navbar.transformer.js +120 -0
- package/src/transpile/components/nav/navbar.transformer.js.map +1 -0
- package/src/transpile/components/navigation/breadcrumb.transformer.js +16 -0
- package/src/transpile/components/navigation/breadcrumb.transformer.js.map +1 -0
- package/src/transpile/components/navigation/menu.transformer.js +36 -0
- package/src/transpile/components/navigation/menu.transformer.js.map +1 -0
- package/src/transpile/components/navigation/popover.transformer.js +39 -0
- package/src/transpile/components/navigation/popover.transformer.js.map +1 -0
- package/src/transpile/components/page/content.transformer.js +17 -0
- package/src/transpile/components/page/content.transformer.js.map +1 -0
- package/src/transpile/components/page/page-content.transformer.js +17 -0
- package/src/transpile/components/page/page-content.transformer.js.map +1 -0
- package/src/transpile/components/page/page.transformer.js +50 -0
- package/src/transpile/components/page/page.transformer.js.map +1 -0
- package/src/transpile/components/page/partial-container.transformer.js +61 -0
- package/src/transpile/components/page/partial-container.transformer.js.map +1 -0
- package/src/transpile/components/page/partial.transformer.js +19 -0
- package/src/transpile/components/page/partial.transformer.js.map +1 -0
- package/src/transpile/components/partial/partial-content.transformer.js +56 -0
- package/src/transpile/components/partial/partial-content.transformer.js.map +1 -0
- package/src/transpile/components/prefab/prefab-container.transformer.js +32 -0
- package/src/transpile/components/prefab/prefab-container.transformer.js.map +1 -0
- package/src/transpile/components/prefab/prefab.transformer.js +91 -0
- package/src/transpile/components/prefab/prefab.transformer.js.map +1 -0
- package/src/transpile/components/transform-register.js +247 -0
- package/src/transpile/components/transform-register.js.map +1 -0
- package/src/transpile/components/utils.js +371 -0
- package/src/transpile/components/utils.js.map +1 -0
- package/src/transpile/components/wmx-component/wmx-component.transformer.js +35 -0
- package/src/transpile/components/wmx-component/wmx-component.transformer.js.map +1 -0
- package/src/transpile/id-generator.js +87 -0
- package/src/transpile/id-generator.js.map +1 -0
- package/src/transpile/index.js +65 -0
- package/src/transpile/index.js.map +1 -0
- package/src/transpile/property/base-parser.js +13 -0
- package/src/transpile/property/base-parser.js.map +1 -0
- package/src/transpile/property/property-parser.js +277 -0
- package/src/transpile/property/property-parser.js.map +1 -0
- package/src/transpile/property/show-in-device.parser.js +17 -0
- package/src/transpile/property/show-in-device.parser.js.map +1 -0
- package/src/transpile/serialize-variables.js +322 -0
- package/src/transpile/serialize-variables.js.map +1 -0
- package/src/transpile/style/background-image.parser.js +20 -0
- package/src/transpile/style/background-image.parser.js.map +1 -0
- package/src/transpile/style/border-width.parser.js +20 -0
- package/src/transpile/style/border-width.parser.js.map +1 -0
- package/src/transpile/style/dimension-style.parser.js +70 -0
- package/src/transpile/style/dimension-style.parser.js.map +1 -0
- package/src/transpile/style/horizontal-align.parser.js +24 -0
- package/src/transpile/style/horizontal-align.parser.js.map +1 -0
- package/src/transpile/style/margin.parser.js +20 -0
- package/src/transpile/style/margin.parser.js.map +1 -0
- package/src/transpile/style/multi-dimension-style.parser.js +29 -0
- package/src/transpile/style/multi-dimension-style.parser.js.map +1 -0
- package/src/transpile/style/numeric-style.parser.js +18 -0
- package/src/transpile/style/numeric-style.parser.js.map +1 -0
- package/src/transpile/style/padding.parser.js +20 -0
- package/src/transpile/style/padding.parser.js.map +1 -0
- package/src/transpile/style/split-css-shorthand.js +60 -0
- package/src/transpile/style/split-css-shorthand.js.map +1 -0
- package/src/transpile/style/style.parser.js +15 -0
- package/src/transpile/style/style.parser.js.map +1 -0
- package/src/transpile/style.transformer.js +124 -0
- package/src/transpile/style.transformer.js.map +1 -0
- package/src/transpile/transform-markup.js +283 -0
- package/src/transpile/transform-markup.js.map +1 -0
- package/src/transpile/transpile-variables.js +35 -0
- package/src/transpile/transpile-variables.js.map +1 -0
- package/src/transpile/transpile.js +1098 -0
- package/src/transpile/transpile.js.map +1 -0
- package/src/transpile/transpiler.js +26 -0
- package/src/transpile/transpiler.js.map +1 -0
- package/src/transpile/variables-template-source.js +6 -0
- package/src/transpile/variables-template-source.js.map +1 -0
- package/src/transpile/variables-template.js +15 -0
- package/src/transpile/variables-template.js.map +1 -0
- package/src/transpile/widget-inline-style-constants.js +200 -0
- package/src/transpile/widget-inline-style-constants.js.map +1 -0
- package/src/transpile/widget-inline-style-processor.js +684 -0
- package/src/transpile/widget-inline-style-processor.js.map +1 -0
- package/src/types/index.js +6 -0
- package/src/types/index.js.map +1 -0
- package/src/utils/grouping-util.js +500 -0
- package/src/utils/grouping-util.js.map +1 -0
- package/src/utils.browser.js +853 -0
- package/src/utils.browser.js.map +1 -0
- package/src/utils.js +988 -0
- package/src/utils.js.map +1 -0
- package/src/variables/variable.transformer.js +690 -0
- package/src/variables/variable.transformer.js.map +1 -0
- package/src/wmx.generator.js +216 -0
- package/src/wmx.generator.js.map +1 -0
- package/templates/.DS_Store +0 -0
- package/templates/app.style.template +3 -0
- package/templates/app.variables.template +1 -0
- package/templates/component/app.libs.hbs +38 -0
- package/templates/component/app.script.hbs +8 -0
- package/templates/component/app.template.hbs +47 -0
- package/templates/component/component.hbs +79 -0
- package/templates/component/component.props.template +1 -0
- package/templates/component/formatter.hbs +8 -0
- package/templates/component/layout.hbs +32 -0
- package/templates/component/page.hbs +16 -0
- package/templates/component/partial.hbs +69 -0
- package/templates/component/script.template +6 -0
- package/templates/component/style-def.template +18 -0
- package/templates/component/style.template +1 -0
- package/templates/entity-provider.template +21 -0
- package/templates/foundation/layout.tsx +30 -0
- package/templates/pages-config.template +12 -0
- package/templates/partial-config.template +58 -0
- package/templates/project/.DS_Store +0 -0
- package/templates/project/.env +1 -0
- package/templates/project/.gitignore +2 -0
- package/templates/project/.prettierrc +8 -0
- package/templates/project/README.md +60 -0
- package/templates/project/app/autoLayout.css +133 -0
- package/templates/project/app/client.layout.tsx +193 -0
- package/templates/project/app/components.css +182 -0
- package/templates/project/app/error.tsx +27 -0
- package/templates/project/app/globals.css +5 -0
- package/templates/project/app/layout.tsx +40 -0
- package/templates/project/app/loading.tsx +6 -0
- package/templates/project/app/page.tsx +3 -0
- package/templates/project/app/widgetInlineStylesOverride.css +1027 -0
- package/templates/project/app/wm-globals.css +152 -0
- package/templates/project/app/wm-styles.css +4 -0
- package/templates/project/hooks/usePageEvents.tsx +45 -0
- package/templates/project/libs/appConfig.ts +14 -0
- package/templates/project/next-env.d.ts +5 -0
- package/templates/project/next.config.ts +17 -0
- package/templates/project/package-lock.json +5397 -0
- package/templates/project/package.json +41 -0
- package/templates/project/public/error-fallback.svg +89 -0
- package/templates/project/public/file.svg +1 -0
- package/templates/project/public/globe.svg +1 -0
- package/templates/project/public/next.svg +1 -0
- package/templates/project/public/vercel.svg +1 -0
- package/templates/project/public/window.svg +1 -0
- package/templates/project/scripts/app-custom-server.js +44 -0
- package/templates/project/scripts/getlibs.js +53 -0
- package/templates/project/tsconfig.json +36 -0
- package/templates/project/types/runtime-config.d.ts +9 -0
- package/templates/resource.resolver.template +20 -0
- package/templates/service.defs.template +3 -0
- package/templates/variables.template +252 -0
|
@@ -0,0 +1,442 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.imports = void 0;
|
|
4
|
+
const transpile_1 = require("../../../transpile");
|
|
5
|
+
const util_1 = require("./util");
|
|
6
|
+
const utils_1 = require("../../utils");
|
|
7
|
+
exports.imports = [
|
|
8
|
+
{
|
|
9
|
+
name: "WmFormField",
|
|
10
|
+
from: "@wavemaker-ai/react-runtime/components/data/form/form-field",
|
|
11
|
+
},
|
|
12
|
+
];
|
|
13
|
+
const getAttribute = (element, attrName) => {
|
|
14
|
+
const value = element.getAttribute(attrName);
|
|
15
|
+
return value === null || value === void 0 ? void 0 : value.replace(/"/g, """);
|
|
16
|
+
};
|
|
17
|
+
const extractField = (element, context, formElement) => {
|
|
18
|
+
const widgetType = getAttribute(element, "widget") || "text";
|
|
19
|
+
const widgetName = getAttribute(element, "key") || getAttribute(element, "name") || "text" + "_formWidget";
|
|
20
|
+
return getFormWidgetTemplate(widgetType, widgetName, element, formElement ? getAttribute(formElement, "formdata") : undefined);
|
|
21
|
+
};
|
|
22
|
+
const getFormWidgetTemplate = (widgetType, widgetName, element, formDataVariable) => {
|
|
23
|
+
var _a, _b;
|
|
24
|
+
widgetName = widgetName.replace(".", "_");
|
|
25
|
+
const inputName = (_b = (_a = getAttribute(element, "key")) === null || _a === void 0 ? void 0 : _a.split(".")) === null || _b === void 0 ? void 0 : _b.at(-1);
|
|
26
|
+
const formfieldName = getAttribute(element, "name");
|
|
27
|
+
var labelMarkup = getAttribute(element, "displayname")
|
|
28
|
+
? `<wm-label
|
|
29
|
+
required="bind:$formField.required"
|
|
30
|
+
htmlFor="${formfieldName}_formWidget"
|
|
31
|
+
caption="bind:$formField.displayname"
|
|
32
|
+
class="app-label control-label formfield-label"
|
|
33
|
+
conditionalclass="bind:$formField.captionCls + ' ' + $formField.invalidCls"
|
|
34
|
+
name="${widgetName}_formLabel"></wm-label>`
|
|
35
|
+
: "";
|
|
36
|
+
const onFocus = getAttribute(element, "on-focus");
|
|
37
|
+
if (onFocus) {
|
|
38
|
+
element.removeAttribute("on-focus");
|
|
39
|
+
}
|
|
40
|
+
const onBlur = getAttribute(element, "on-blur");
|
|
41
|
+
if (onBlur) {
|
|
42
|
+
element.removeAttribute("on-blur");
|
|
43
|
+
}
|
|
44
|
+
const onTap = getAttribute(element, "on-tap");
|
|
45
|
+
if (onTap) {
|
|
46
|
+
element.removeAttribute("on-tap");
|
|
47
|
+
}
|
|
48
|
+
const placeholder = getAttribute(element, "placeholder");
|
|
49
|
+
if (placeholder) {
|
|
50
|
+
element.removeAttribute("placeholder");
|
|
51
|
+
}
|
|
52
|
+
var commonFields = `name="${formfieldName}_formWidget"
|
|
53
|
+
formfield="true"
|
|
54
|
+
datavalue="bind:$formField.datavalue || $formField.defaultvalue"
|
|
55
|
+
conditionalclass=""
|
|
56
|
+
${placeholder ? 'placeholder="' + placeholder + '"' : ""}
|
|
57
|
+
${onFocus ? "on-focus=" + onFocus : ""}
|
|
58
|
+
${onBlur ? "on-blur=" + onBlur : ""}`;
|
|
59
|
+
var widgetMarkup = getWidgetMarkup(widgetType, widgetName, commonFields, element);
|
|
60
|
+
let currentNode = element.parentNode;
|
|
61
|
+
while (currentNode) {
|
|
62
|
+
if (currentNode.rawTagName === "wm-form" ||
|
|
63
|
+
currentNode.rawTagName === "wm-liveform" ||
|
|
64
|
+
currentNode.getAttribute("type") === "dynamic") {
|
|
65
|
+
break;
|
|
66
|
+
}
|
|
67
|
+
currentNode = currentNode.parentNode;
|
|
68
|
+
}
|
|
69
|
+
return {
|
|
70
|
+
label: labelMarkup ? (0, transpile_1.parse)(labelMarkup).firstChild : null,
|
|
71
|
+
field: (0, transpile_1.parse)(widgetMarkup).firstChild,
|
|
72
|
+
};
|
|
73
|
+
};
|
|
74
|
+
const getDisplayExpression = (displayExpr) => {
|
|
75
|
+
//if the expression is "Label ' location' sample" then it should be as it is. but failing
|
|
76
|
+
//that is why if there is bind display expression should be with single quote else double quote
|
|
77
|
+
if (displayExpr.includes("bind:")) {
|
|
78
|
+
// Replace single quotes with ' to prevent breaking the attribute
|
|
79
|
+
const escapedExpr = displayExpr.replace(/'/g, "'");
|
|
80
|
+
return `displayexpression='${escapedExpr}'`;
|
|
81
|
+
}
|
|
82
|
+
return `displayexpression="${displayExpr}"`;
|
|
83
|
+
};
|
|
84
|
+
const getWidgetMarkup = (widgetType, widgetName, commonFields, element) => {
|
|
85
|
+
let tmpl = "";
|
|
86
|
+
const getDisplayExpr = element.getAttribute("displayexpression") || element.getAttribute("displaylabel");
|
|
87
|
+
const displayExp = getDisplayExpr ? getDisplayExpression(getDisplayExpr) : "";
|
|
88
|
+
const formFieldTags = ["text", "password", "number", "currency", "textarea"];
|
|
89
|
+
let currentNode = element.parentNode;
|
|
90
|
+
while (currentNode) {
|
|
91
|
+
if (currentNode.rawTagName === "wm-form" ||
|
|
92
|
+
currentNode.rawTagName === "wm-liveform" ||
|
|
93
|
+
currentNode.getAttribute("type") === "dynamic") {
|
|
94
|
+
break;
|
|
95
|
+
}
|
|
96
|
+
currentNode = currentNode.parentNode;
|
|
97
|
+
}
|
|
98
|
+
const isFloatingForm = (currentNode === null || currentNode === void 0 ? void 0 : currentNode.getAttribute("captionposition")) === "floating";
|
|
99
|
+
const floatinglabel = formFieldTags.includes(widgetType) && isFloatingForm
|
|
100
|
+
? `floatinglabel='${element.getAttribute("displayname")}'`
|
|
101
|
+
: "";
|
|
102
|
+
const dateTimeDialogTags = ["date", "time", "datetime"];
|
|
103
|
+
const isDateTimeTag = dateTimeDialogTags.includes(widgetType);
|
|
104
|
+
// * date picker modal customization
|
|
105
|
+
const dateheadertitle = isDateTimeTag && element.getAttribute("dateheadertitle")
|
|
106
|
+
? `dateheadertitle='${element.getAttribute("dateheadertitle")}'`
|
|
107
|
+
: "";
|
|
108
|
+
const dateconfirmationtitle = isDateTimeTag && element.getAttribute("dateconfirmationtitle")
|
|
109
|
+
? `dateconfirmationtitle='${element.getAttribute("dateconfirmationtitle")}'`
|
|
110
|
+
: "";
|
|
111
|
+
const datecanceltitle = isDateTimeTag && element.getAttribute("datecanceltitle")
|
|
112
|
+
? `datecanceltitle='${element.getAttribute("datecanceltitle")}'`
|
|
113
|
+
: "";
|
|
114
|
+
// * time picker modal customization
|
|
115
|
+
const timeheadertitle = isDateTimeTag && element.getAttribute("timeheadertitle")
|
|
116
|
+
? `timeheadertitle='${element.getAttribute("timeheadertitle")}'`
|
|
117
|
+
: "";
|
|
118
|
+
const timeconfirmationtitle = isDateTimeTag && element.getAttribute("timeconfirmationtitle")
|
|
119
|
+
? `timeconfirmationtitle='${element.getAttribute("timeconfirmationtitle")}'`
|
|
120
|
+
: "";
|
|
121
|
+
const timecanceltitle = isDateTimeTag && element.getAttribute("timecanceltitle")
|
|
122
|
+
? `timecanceltitle='${element.getAttribute("timecanceltitle")}'`
|
|
123
|
+
: "";
|
|
124
|
+
const outputformat = element.getAttribute("outputformat")
|
|
125
|
+
? `outputformat='${element.getAttribute("outputformat")}'`
|
|
126
|
+
: ``;
|
|
127
|
+
switch (widgetType) {
|
|
128
|
+
case "text":
|
|
129
|
+
case "password":
|
|
130
|
+
let inputtype = widgetType === "password" ? "password" : getAttribute(element, "inputtype");
|
|
131
|
+
inputtype = inputtype ? `type=${inputtype}` : "";
|
|
132
|
+
tmpl = `<wm-text ${inputtype} ${commonFields}
|
|
133
|
+
updateon="bind:$formField.updateon"
|
|
134
|
+
maxchars="bind:$formField.maxchars"
|
|
135
|
+
></wm-text>`;
|
|
136
|
+
break;
|
|
137
|
+
case "textarea":
|
|
138
|
+
tmpl = `<wm-textarea ${commonFields}
|
|
139
|
+
updateon="bind:$formField.updateon || 'blur'"
|
|
140
|
+
maxchars="bind:$formField.maxchars"
|
|
141
|
+
${floatinglabel}>
|
|
142
|
+
</wm-textarea>`;
|
|
143
|
+
break;
|
|
144
|
+
case "number":
|
|
145
|
+
tmpl = `<wm-number ${commonFields}
|
|
146
|
+
updateon="bind:$formField.updateon || 'blur'"
|
|
147
|
+
minvalue="bind:$formField.minvalue"
|
|
148
|
+
maxvalue="bind:$formField.maxvalue"
|
|
149
|
+
displayValue="bind:$formField.displayValue"
|
|
150
|
+
${floatinglabel}>
|
|
151
|
+
</wm-number>`;
|
|
152
|
+
break;
|
|
153
|
+
case "currency":
|
|
154
|
+
tmpl = `<wm-currency ${commonFields}
|
|
155
|
+
updateon="bind:$formField.updateon || 'blur'"
|
|
156
|
+
minvalue="bind:$formField.minvalue"
|
|
157
|
+
maxvalue="bind:$formField.maxvalue"
|
|
158
|
+
${floatinglabel}>
|
|
159
|
+
</wm-currency>`;
|
|
160
|
+
break;
|
|
161
|
+
case "select":
|
|
162
|
+
tmpl = `<wm-select ${commonFields} ${displayExp}
|
|
163
|
+
dataset="bind:$formField.dataset"
|
|
164
|
+
displayfield="bind:$formField.displayfield"
|
|
165
|
+
datafield="bind:$formField.datafield"
|
|
166
|
+
></wm-select>`;
|
|
167
|
+
break;
|
|
168
|
+
case "autocomplete":
|
|
169
|
+
const datasource = (0, utils_1.getDatasourceExpr)(element);
|
|
170
|
+
// Set searchkey to the value of key attribute before removing it
|
|
171
|
+
const searchkeyAttribute = element.getAttribute("key");
|
|
172
|
+
if (searchkeyAttribute) {
|
|
173
|
+
element.setAttribute("searchkey", searchkeyAttribute);
|
|
174
|
+
}
|
|
175
|
+
element.removeAttribute("key");
|
|
176
|
+
tmpl = `<wm-search ${commonFields} ${displayExp}
|
|
177
|
+
type="autocomplete"
|
|
178
|
+
limit="bind:$formField.limit"
|
|
179
|
+
displayimagesrc="bind:$formField.displayimagesrc"
|
|
180
|
+
searchkey="bind:$formField.searchkey"
|
|
181
|
+
showclear="bind:$formField.showclear || false"
|
|
182
|
+
dataset="bind:$formField.dataset"
|
|
183
|
+
displayfield="bind:$formField.displaylabel"
|
|
184
|
+
datafield="bind:$formField.datafield"
|
|
185
|
+
${datasource ? `datasource="${datasource}"` : ""}
|
|
186
|
+
></wm-search>`;
|
|
187
|
+
break;
|
|
188
|
+
case "chips":
|
|
189
|
+
// Set searchkey to the value of key attribute before removing it
|
|
190
|
+
const chipsKeyAttribute = element.getAttribute("key");
|
|
191
|
+
if (chipsKeyAttribute) {
|
|
192
|
+
element.setAttribute("searchkey", chipsKeyAttribute);
|
|
193
|
+
}
|
|
194
|
+
element.removeAttribute("key");
|
|
195
|
+
tmpl = `<wm-chips ${commonFields} ${displayExp}
|
|
196
|
+
minchars="bind:$formField.minchars || 1"
|
|
197
|
+
maxsize="bind:$formField.maxsize"
|
|
198
|
+
displayimagesrc="bind:$formField.displayimagesrc"
|
|
199
|
+
searchkey="bind:$formField.searchkey"
|
|
200
|
+
dataset="bind:$formField.dataset || 'Option 1, Option 2, Option 3'"
|
|
201
|
+
displayfield="bind:$formField.displayfield"
|
|
202
|
+
datafield="bind:$formField.datafield"
|
|
203
|
+
></wm-chips>`;
|
|
204
|
+
break;
|
|
205
|
+
case "checkbox":
|
|
206
|
+
tmpl = `<wm-checkbox ${commonFields}
|
|
207
|
+
caption="bind:$formField.caption"
|
|
208
|
+
checkedvalue="bind:$formField.checkedvalue || true"
|
|
209
|
+
uncheckedvalue="bind:$formField.uncheckedvalue || false">
|
|
210
|
+
</wm-checkbox>`;
|
|
211
|
+
break;
|
|
212
|
+
case "checkboxset":
|
|
213
|
+
tmpl = `<wm-checkboxset ${commonFields} ${displayExp}
|
|
214
|
+
dataset="bind:$formField.dataset || 'Option 1, Option 2, Option 3'"
|
|
215
|
+
displayfield="bind:$formField.displayfield"
|
|
216
|
+
datafield="bind:$formField.datafield"
|
|
217
|
+
></wm-checkboxset>`;
|
|
218
|
+
break;
|
|
219
|
+
case "toggle":
|
|
220
|
+
tmpl = `<wm-checkbox ${commonFields}
|
|
221
|
+
type="toggle"
|
|
222
|
+
checkedvalue="bind:$formField.checkedvalue || true"
|
|
223
|
+
uncheckedvalue="bind:$formField.uncheckedvalue || false">
|
|
224
|
+
</wm-checkbox>`;
|
|
225
|
+
break;
|
|
226
|
+
case "richtext":
|
|
227
|
+
tmpl = `<wm-richtexteditor ${commonFields} disabled="bind:$formField.disabled || false" readonly="bind:$formField.readonly || false" ${displayExp}
|
|
228
|
+
></wm-richtexteditor>`;
|
|
229
|
+
break;
|
|
230
|
+
case "switch":
|
|
231
|
+
tmpl = `<wm-switch ${commonFields} ${displayExp}
|
|
232
|
+
dataset="bind:$formField.dataset || 'yes, no, maybe'"
|
|
233
|
+
displayfield="bind:$formField.displayfield"
|
|
234
|
+
datafield="bind:$formField.datafield"
|
|
235
|
+
></wm-switch>`;
|
|
236
|
+
break;
|
|
237
|
+
case "radioset":
|
|
238
|
+
tmpl = `<wm-radioset ${commonFields} ${displayExp}
|
|
239
|
+
dataset="bind:$formField.dataset || 'Option 1, Option 2, Option 3'"
|
|
240
|
+
displayfield="bind:$formField.displayfield"
|
|
241
|
+
datafield="bind:$formField.datafield"
|
|
242
|
+
></wm-radioset>`;
|
|
243
|
+
break;
|
|
244
|
+
case "date":
|
|
245
|
+
tmpl += `<wm-date ${commonFields}
|
|
246
|
+
mindate="bind:$formField.mindate"
|
|
247
|
+
maxdate="bind:$formField.maxdate"
|
|
248
|
+
datepattern="bind:$formField.datepattern"
|
|
249
|
+
${outputformat}
|
|
250
|
+
${dateheadertitle}
|
|
251
|
+
${dateconfirmationtitle}
|
|
252
|
+
${datecanceltitle}
|
|
253
|
+
></wm-date>`;
|
|
254
|
+
break;
|
|
255
|
+
case "datetime":
|
|
256
|
+
case "timestamp":
|
|
257
|
+
tmpl = `<wm-datetime ${commonFields}
|
|
258
|
+
mindate="bind:$formField.mindate"
|
|
259
|
+
maxdate="bind:$formField.maxdate"
|
|
260
|
+
datepattern="bind:$formField.datepattern"
|
|
261
|
+
${outputformat}
|
|
262
|
+
${dateheadertitle}
|
|
263
|
+
${dateconfirmationtitle}
|
|
264
|
+
${datecanceltitle}
|
|
265
|
+
${timeheadertitle}
|
|
266
|
+
${timeconfirmationtitle}
|
|
267
|
+
${timecanceltitle}
|
|
268
|
+
></wm-datetime>`;
|
|
269
|
+
break;
|
|
270
|
+
case "time":
|
|
271
|
+
tmpl += `<wm-time ${commonFields}
|
|
272
|
+
timepattern="bind:$formField.timepattern"
|
|
273
|
+
${outputformat}
|
|
274
|
+
${timeheadertitle}
|
|
275
|
+
${timeconfirmationtitle}
|
|
276
|
+
${timecanceltitle}
|
|
277
|
+
></wm-time>`;
|
|
278
|
+
break;
|
|
279
|
+
case "slider":
|
|
280
|
+
tmpl += `<wm-slider ${commonFields}
|
|
281
|
+
minvalue="bind:$formField.minvalue || 0"
|
|
282
|
+
maxvalue="bind:$formField.maxvalue || 100"
|
|
283
|
+
step="bind:$formField.step || 1"
|
|
284
|
+
></wm-slider>`;
|
|
285
|
+
break;
|
|
286
|
+
case "rating":
|
|
287
|
+
let showcaptions = getAttribute(element, "showcaptions");
|
|
288
|
+
showcaptions = showcaptions ? `showcaptions="bind:$formField.showcaptions"` : "";
|
|
289
|
+
tmpl += `<wm-rating ${commonFields} ${displayExp}
|
|
290
|
+
${getAttribute(element, "dataset") ? 'dataset="bind:$formField.dataset"' : ""}
|
|
291
|
+
displayfield="bind:$formField.displayfield || 'value'"
|
|
292
|
+
datafield="bind:$formField.datafield || 'key'"
|
|
293
|
+
${showcaptions}
|
|
294
|
+
maxvalue="bind:$formField.maxvalue || 5"
|
|
295
|
+
></wm-rating>`;
|
|
296
|
+
break;
|
|
297
|
+
case "fileupload":
|
|
298
|
+
case "file":
|
|
299
|
+
case "upload":
|
|
300
|
+
tmpl = `<wm-upload ${commonFields}
|
|
301
|
+
type="${element.getAttribute("type") || "file"}"
|
|
302
|
+
updateon="bind:$formField.updateon || 'blur'"
|
|
303
|
+
></wm-upload>`;
|
|
304
|
+
break;
|
|
305
|
+
case "colorpicker":
|
|
306
|
+
tmpl = `<wm-colorpicker ${commonFields}
|
|
307
|
+
updateon="bind:$formField.updateon || 'blur'"
|
|
308
|
+
${floatinglabel}>
|
|
309
|
+
</wm-colorpicker>`;
|
|
310
|
+
break;
|
|
311
|
+
}
|
|
312
|
+
return tmpl;
|
|
313
|
+
};
|
|
314
|
+
exports.default = {
|
|
315
|
+
pre: (element, context) => {
|
|
316
|
+
const widgetType = getAttribute(element, "widget") || util_1.FormWidgetType.TEXT;
|
|
317
|
+
const listName = context.data.listname;
|
|
318
|
+
let currentNode = element.parentNode;
|
|
319
|
+
while (currentNode) {
|
|
320
|
+
if (currentNode.rawTagName === "wm-form" ||
|
|
321
|
+
currentNode.rawTagName === "wm-liveform" ||
|
|
322
|
+
(currentNode === null || currentNode === void 0 ? void 0 : currentNode.getAttribute("type")) === "dynamic") {
|
|
323
|
+
break;
|
|
324
|
+
}
|
|
325
|
+
currentNode = currentNode.parentNode;
|
|
326
|
+
}
|
|
327
|
+
let formName, formScope, control;
|
|
328
|
+
if ((currentNode === null || currentNode === void 0 ? void 0 : currentNode.getAttribute("type")) === "dynamic") {
|
|
329
|
+
formName = currentNode.getAttribute("dynamicForm");
|
|
330
|
+
formScope = `formScope={() => fragment?.Widgets?.${formName}}`;
|
|
331
|
+
}
|
|
332
|
+
else {
|
|
333
|
+
formName = currentNode === null || currentNode === void 0 ? void 0 : currentNode.getAttribute("name");
|
|
334
|
+
}
|
|
335
|
+
// Strip formdata prefix from name and key attributes if parent form has formdataprefix
|
|
336
|
+
const formdataPrefix = currentNode === null || currentNode === void 0 ? void 0 : currentNode.getAttribute("formdataprefix");
|
|
337
|
+
if (formdataPrefix) {
|
|
338
|
+
const currentName = element.getAttribute("name");
|
|
339
|
+
// Name uses dot notation: Formdata.booleancol
|
|
340
|
+
if (currentName && currentName.startsWith(formdataPrefix + ".")) {
|
|
341
|
+
const strippedName = currentName.substring(formdataPrefix.length + 1);
|
|
342
|
+
element.setAttribute("name", strippedName);
|
|
343
|
+
}
|
|
344
|
+
const currentKey = element.getAttribute("key");
|
|
345
|
+
if (currentKey && currentKey.startsWith(formdataPrefix + ".")) {
|
|
346
|
+
const strippedKey = currentKey.substring(formdataPrefix.length + 1);
|
|
347
|
+
element.setAttribute("key", strippedKey);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
if (util_1.DATASET_WIDGETS.includes(widgetType)) {
|
|
351
|
+
// @ts-ignore
|
|
352
|
+
// element.setAttribute("formRef", formName);
|
|
353
|
+
if (element.attrs["primary-key"]) {
|
|
354
|
+
element.setAttribute("primaryKey", element.attrs["primary-key"]);
|
|
355
|
+
}
|
|
356
|
+
element.removeAttribute("primary-key");
|
|
357
|
+
if (element.attrs["is-related"]) {
|
|
358
|
+
element.setAttribute("isRelated", element.attrs["is-related"]);
|
|
359
|
+
}
|
|
360
|
+
element.removeAttribute("is-related");
|
|
361
|
+
// If dataset is not present, inherit from parent wm-liveform suggested by @bhadhavya_vakiti
|
|
362
|
+
if (!element.getAttribute("dataset") && (currentNode === null || currentNode === void 0 ? void 0 : currentNode.rawTagName) === "wm-liveform") {
|
|
363
|
+
const parentDataset = currentNode.getAttribute("dataset");
|
|
364
|
+
if (parentDataset) {
|
|
365
|
+
element.setAttribute("dataset", parentDataset);
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
if (element.getAttribute("dataset")) {
|
|
369
|
+
element.setAttribute("isDataSetBound", "true");
|
|
370
|
+
}
|
|
371
|
+
// Set default displayfield and datafield to name attribute if not provided
|
|
372
|
+
const nameAttribute = element.getAttribute("name");
|
|
373
|
+
if (nameAttribute) {
|
|
374
|
+
if (!element.hasAttribute("displayfield")) {
|
|
375
|
+
element.setAttribute("displayfield", nameAttribute);
|
|
376
|
+
}
|
|
377
|
+
if (!element.hasAttribute("datafield")) {
|
|
378
|
+
element.setAttribute("datafield", nameAttribute);
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
// const validate = `widget.validateFormField.call(widget);`;
|
|
383
|
+
// let onChange = element.getAttribute("on-change") || "";
|
|
384
|
+
// onChange = listName
|
|
385
|
+
// ? `list.itemWidgets[$index].${currentNode.getAttribute("name")} && list.itemWidgets[$index].${currentNode.getAttribute("name")}.props.onChange && list.itemWidgets[$index].${currentNode.getAttribute("name")}.props.onChange($event, widget, newVal, oldVal);` +
|
|
386
|
+
// onChange
|
|
387
|
+
// : `fragment.Widgets.${currentNode.getAttribute("name")} && fragment.Widgets.${currentNode.getAttribute("name")}.props.onChange && fragment.Widgets.${currentNode.getAttribute("name")}.props.onChange($event, widget, newVal, oldVal);` +
|
|
388
|
+
// onChange;
|
|
389
|
+
// element.setAttribute("on-change", onChange);
|
|
390
|
+
const formField = extractField(element, context, currentNode);
|
|
391
|
+
if (formField.label) {
|
|
392
|
+
element.childNodes.push(formField.label);
|
|
393
|
+
}
|
|
394
|
+
element.childNodes.push(formField.field);
|
|
395
|
+
// Remove displayexpression/displaylabel from form field - they're already on the child widget
|
|
396
|
+
element.removeAttribute("displayexpression");
|
|
397
|
+
element.removeAttribute("displaylabel");
|
|
398
|
+
element.removeAttribute("datavalue");
|
|
399
|
+
element.removeAttribute("height");
|
|
400
|
+
// element.setAttribute("on-validate", validate);
|
|
401
|
+
const childDatasetNode = currentNode === null || currentNode === void 0 ? void 0 : currentNode.getAttribute("childdatasetnode");
|
|
402
|
+
let formKey = "";
|
|
403
|
+
if (childDatasetNode) {
|
|
404
|
+
formKey = childDatasetNode + "." + element.attrs["name"];
|
|
405
|
+
}
|
|
406
|
+
else {
|
|
407
|
+
formKey = element.attrs["key"] || element.attrs["name"];
|
|
408
|
+
}
|
|
409
|
+
element.setAttribute("formKey", formKey);
|
|
410
|
+
if (element.getAttribute("is-range") === "true") {
|
|
411
|
+
(0, util_1.setDefaultPlaceholder)(element, widgetType, 0);
|
|
412
|
+
(0, util_1.setDefaultPlaceholder)(element, widgetType, 1);
|
|
413
|
+
}
|
|
414
|
+
else {
|
|
415
|
+
(0, util_1.setDefaultPlaceholder)(element, widgetType, 2);
|
|
416
|
+
}
|
|
417
|
+
const fieldcolumn = element.getAttribute("field");
|
|
418
|
+
element.removeAttribute("field");
|
|
419
|
+
if (formName) {
|
|
420
|
+
element.setAttribute("formName", formName);
|
|
421
|
+
}
|
|
422
|
+
(() => {
|
|
423
|
+
const attrs = ["primary-key", "is-related"];
|
|
424
|
+
attrs.forEach(attr => {
|
|
425
|
+
if (element.hasAttribute(attr)) {
|
|
426
|
+
element.removeAttribute(attr);
|
|
427
|
+
}
|
|
428
|
+
});
|
|
429
|
+
})();
|
|
430
|
+
// Rename key to dataKey for React (key is a reserved prop and cannot be passed)
|
|
431
|
+
const keyValue = element.getAttribute("key");
|
|
432
|
+
if (keyValue) {
|
|
433
|
+
element.setAttribute("dataKey", keyValue);
|
|
434
|
+
element.removeAttribute("key");
|
|
435
|
+
}
|
|
436
|
+
return `<WmFormField ${formScope || ""} field="true" ${fieldcolumn ? `fieldcol="${fieldcolumn}"` : ""} role="form-field" ${(0, utils_1.extractDatasetInfo)(element)} ${(0, transpile_1.transformAttrs)(element, context)} renderFormFields={($formField) => (<>`;
|
|
437
|
+
},
|
|
438
|
+
post: (element, context) => " </>)}></WmFormField>",
|
|
439
|
+
imports: (element, context) => exports.imports,
|
|
440
|
+
createComponent: (element, context) => (0, transpile_1.createComponent)(element, context),
|
|
441
|
+
};
|
|
442
|
+
//# sourceMappingURL=form-field.transformer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"form-field.transformer.js","sourceRoot":"","sources":["../../../../../../src/transpile/components/data/form/form-field.transformer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.imports = void 0;
|
|
4
|
+
const transpile_1 = require("../../../transpile");
|
|
5
|
+
exports.imports = [
|
|
6
|
+
{
|
|
7
|
+
name: "WmFormFooter",
|
|
8
|
+
from: "@wavemaker-ai/react-runtime/components/data/form/form-footer",
|
|
9
|
+
},
|
|
10
|
+
];
|
|
11
|
+
exports.default = {
|
|
12
|
+
pre: (element, context) => `<WmFormFooter ${(0, transpile_1.transformAttrs)(element, context)}>`,
|
|
13
|
+
post: (element, context) => "</WmFormFooter>",
|
|
14
|
+
imports: (element, context) => exports.imports,
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=form-footer.transformer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"form-footer.transformer.js","sourceRoot":"","sources":["../../../../../../src/transpile/components/data/form/form-footer.transformer.ts"],"names":[],"mappings":";;;AAEA,kDAA+F;AAElF,QAAA,OAAO,GAAa;IAC/B;QACE,IAAI,EAAE,cAAc;QACpB,IAAI,EAAE,8DAA8D;KACrE;CACF,CAAC;AAEF,kBAAe;IACb,GAAG,EAAE,CAAC,OAAoB,EAAE,OAA6B,EAAE,EAAE,CAC3D,iBAAiB,IAAA,0BAAc,EAAC,OAAO,EAAE,OAAO,CAAC,GAAG;IACtD,IAAI,EAAE,CAAC,OAAoB,EAAE,OAA6B,EAAE,EAAE,CAAC,iBAAiB;IAChF,OAAO,EAAE,CAAC,OAAoB,EAAE,OAA6B,EAAE,EAAE,CAAC,eAAO;CAC3D,CAAC"}
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.imports = void 0;
|
|
4
|
+
const lodash_1 = require("lodash");
|
|
5
|
+
const transpile_1 = require("../../../transpile");
|
|
6
|
+
const utils_1 = require("../../utils");
|
|
7
|
+
exports.imports = [
|
|
8
|
+
{ name: "WmForm", from: "@wavemaker-ai/react-runtime/components/data/form" },
|
|
9
|
+
];
|
|
10
|
+
const getDataSetExpr = (element, bindExpr) => {
|
|
11
|
+
return element.getAttribute("isLogin") ? "" : `${bindExpr}[widget.props.name] = newVal;`;
|
|
12
|
+
};
|
|
13
|
+
const getOnChangeExpr = (element) => {
|
|
14
|
+
let currentNode = element.parentNode, exp;
|
|
15
|
+
while (currentNode) {
|
|
16
|
+
if (currentNode.rawTagName === "wm-form") {
|
|
17
|
+
element.setAttribute("parentForm", currentNode.getAttribute("name") || "");
|
|
18
|
+
// assigning child form name.
|
|
19
|
+
element.setAttribute("childdatasetnode", element.getAttribute("name") || "");
|
|
20
|
+
break;
|
|
21
|
+
}
|
|
22
|
+
else if (currentNode.rawTagName === "wm-prefab" ||
|
|
23
|
+
currentNode.rawTagName === "wm-prefab-container") {
|
|
24
|
+
// Check if the prefab has a parentForm attribute and propagate it
|
|
25
|
+
const prefabParentForm = currentNode.getAttribute("parentForm");
|
|
26
|
+
if (prefabParentForm) {
|
|
27
|
+
element.setAttribute("parentForm", prefabParentForm);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
currentNode = currentNode.parentNode;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
const getFormSubmitExpr = (element) => {
|
|
34
|
+
const dataset = element.getAttribute("dataset");
|
|
35
|
+
if (dataset) {
|
|
36
|
+
const variableArr = dataset.match(/(fragment)+\.Variables\.[^\.]+/g);
|
|
37
|
+
if (variableArr && variableArr.length) {
|
|
38
|
+
let variable = variableArr[0];
|
|
39
|
+
return `
|
|
40
|
+
(formData, success, error) => {
|
|
41
|
+
${variable} &&
|
|
42
|
+
${variable}.invoke(formData, success, error);
|
|
43
|
+
}
|
|
44
|
+
`;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
const pluckFormActionNodes = (element, actions = []) => {
|
|
49
|
+
if (element.childNodes.length) {
|
|
50
|
+
(0, lodash_1.forEach)(element.childNodes, n => {
|
|
51
|
+
if ((0, transpile_1.isHTMLElement)(n) && n.rawTagName === "wm-form") {
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
else if ((0, transpile_1.isHTMLElement)(n) && n.rawTagName === "wm-form-action") {
|
|
55
|
+
actions.push(n);
|
|
56
|
+
n.remove();
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
pluckFormActionNodes(n, actions);
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
return actions;
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
const setFormActions = (element, context) => {
|
|
66
|
+
const formActions = pluckFormActionNodes(element);
|
|
67
|
+
const formFooter = (0, transpile_1.parse)(`<wm-form-footer></wm-form-footer>`).firstChild;
|
|
68
|
+
var btnMarkup;
|
|
69
|
+
formActions &&
|
|
70
|
+
formActions.forEach((formAction) => {
|
|
71
|
+
formAction.setAttribute("formKey", element.attrs["name"]);
|
|
72
|
+
formFooter.appendChild(formAction);
|
|
73
|
+
});
|
|
74
|
+
const container = (0, transpile_1.parse)(`<wm-container class="form-elements"></wm-container>`)
|
|
75
|
+
.firstChild;
|
|
76
|
+
const formBody = (0, transpile_1.parse)(`<wm-form-body></wm-form-body>`).firstChild;
|
|
77
|
+
formBody.childNodes.push(container);
|
|
78
|
+
container.childNodes = element.childNodes;
|
|
79
|
+
// Add dynamic form if metadata attribute exists
|
|
80
|
+
if (element.getAttribute("metadata")) {
|
|
81
|
+
const dynamicForm = (0, transpile_1.parse)(`<wm-dynamic-fields></wm-dynamic-fields>`).firstChild;
|
|
82
|
+
dynamicForm.setAttribute("metadata", element.getAttribute("metadata") || "");
|
|
83
|
+
dynamicForm.setAttribute("formRef", `bind:fragment?.Widgets?.${element.getAttribute("name")}?.ref`);
|
|
84
|
+
const beforeRender = element.getAttribute("on-beforerender");
|
|
85
|
+
if (beforeRender) {
|
|
86
|
+
dynamicForm.setAttribute("on-beforerender", beforeRender);
|
|
87
|
+
}
|
|
88
|
+
container.appendChild(dynamicForm);
|
|
89
|
+
element.removeAttribute("metadata");
|
|
90
|
+
element.removeAttribute("on-beforerender");
|
|
91
|
+
}
|
|
92
|
+
element.childNodes = [formBody];
|
|
93
|
+
if (formActions && formActions.length) {
|
|
94
|
+
formBody.childNodes.push(formFooter);
|
|
95
|
+
}
|
|
96
|
+
};
|
|
97
|
+
exports.default = {
|
|
98
|
+
pre: (element, context) => {
|
|
99
|
+
// Check if form is inside a list and set parent list attributes
|
|
100
|
+
const directParentListName = (0, utils_1.getDirectParentList)(element);
|
|
101
|
+
getOnChangeExpr(element);
|
|
102
|
+
if (directParentListName) {
|
|
103
|
+
element.setAttribute("parentListName", directParentListName);
|
|
104
|
+
element.setAttribute("isParentList", "true");
|
|
105
|
+
}
|
|
106
|
+
const datasourceAttr = element.getAttribute("datasource");
|
|
107
|
+
const datasetAttr = element.getAttribute("dataset");
|
|
108
|
+
if (!datasourceAttr &&
|
|
109
|
+
datasetAttr &&
|
|
110
|
+
datasetAttr.startsWith("bind:fragment.Variables.") &&
|
|
111
|
+
datasetAttr.endsWith(".dataSet")) {
|
|
112
|
+
const match = datasetAttr.match(/^bind:fragment\.Variables\.([^.]+)\.dataSet$/);
|
|
113
|
+
if (match) {
|
|
114
|
+
const variableName = match[1];
|
|
115
|
+
element.setAttribute("datasource", `{fragment?.Variables?.${variableName}}`);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
// Process formdata attribute - extract single-key object wrapper
|
|
119
|
+
// Only apply this transformation if the key is exactly "Formdata"
|
|
120
|
+
let formdataAttr = element.getAttribute("formdata");
|
|
121
|
+
let formdataPrefix = "";
|
|
122
|
+
if (formdataAttr) {
|
|
123
|
+
// Handle both "bind:{ 'Formdata': ... }" and "{ 'Formdata': ... }" formats
|
|
124
|
+
let valueToMatch = formdataAttr;
|
|
125
|
+
const hasBindPrefix = formdataAttr.startsWith("bind:");
|
|
126
|
+
if (hasBindPrefix) {
|
|
127
|
+
valueToMatch = formdataAttr.substring(5); // Remove "bind:" prefix
|
|
128
|
+
}
|
|
129
|
+
// Check if formdata is an object with single key like { 'Formdata': ... }
|
|
130
|
+
const objectMatch = valueToMatch.match(/^\{\s*['"]([^'"]+)['"]\s*:\s*(.+)\s*\}$/);
|
|
131
|
+
if (objectMatch && objectMatch[1] === "Formdata") {
|
|
132
|
+
formdataPrefix = objectMatch[1]; // Extract the key ("Formdata")
|
|
133
|
+
const extractedValue = objectMatch[2].trim(); // Extract the value
|
|
134
|
+
// Set formdata to the extracted value (with bind: prefix if it was there)
|
|
135
|
+
element.setAttribute("formdata", hasBindPrefix ? "bind:" + extractedValue : extractedValue);
|
|
136
|
+
// Store the prefix so child form fields can strip it from formKey
|
|
137
|
+
element.setAttribute("formdataprefix", formdataPrefix);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
const beforeSubmit = element.getAttribute("on-beforesubmit") || element.getAttribute("on-BeforeSubmit");
|
|
141
|
+
let returnBeforeSubmit = "";
|
|
142
|
+
if (beforeSubmit) {
|
|
143
|
+
// Remove both possible variations of the attribute
|
|
144
|
+
element.removeAttribute("on-beforesubmit");
|
|
145
|
+
element.removeAttribute("on-BeforeSubmit");
|
|
146
|
+
// Split and trim each statement
|
|
147
|
+
const fnCalls = beforeSubmit
|
|
148
|
+
.split(";")
|
|
149
|
+
.map(fn => fn.trim())
|
|
150
|
+
.filter(Boolean); // remove empty entries
|
|
151
|
+
// Join using `||`
|
|
152
|
+
returnBeforeSubmit = `($event,widget,$data) => {return (\n ${fnCalls.join(" ||\n ")}\n);}`;
|
|
153
|
+
}
|
|
154
|
+
const formSubmit = getFormSubmitExpr(element);
|
|
155
|
+
setFormActions(element, context);
|
|
156
|
+
return `<WmForm listener={fragment} ${(0, transpile_1.transformAttrs)(element, context)}
|
|
157
|
+
${formSubmit ? `formSubmit={${formSubmit}}` : ""}
|
|
158
|
+
${returnBeforeSubmit ? `onBeforeSubmit={${returnBeforeSubmit}}` : ""}
|
|
159
|
+
${datasourceAttr ? `datasource={${datasourceAttr}}` : ""}
|
|
160
|
+
${directParentListName ? `formArrayIndex={$index}` : ""}
|
|
161
|
+
>`;
|
|
162
|
+
},
|
|
163
|
+
post: (element, context) => `</WmForm>`,
|
|
164
|
+
imports: (element, context) => exports.imports,
|
|
165
|
+
};
|
|
166
|
+
//# sourceMappingURL=form.transformer.js.map
|