@wavemaker-ai/react-codegen 1.0.0-rc.647469

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 (360) hide show
  1. package/build-react-web.js +149 -0
  2. package/build-react-web.js.map +1 -0
  3. package/command.js +101 -0
  4. package/command.js.map +1 -0
  5. package/index.js +122 -0
  6. package/index.js.map +1 -0
  7. package/package-lock.json +4353 -0
  8. package/package.json +86 -0
  9. package/src/app.generator.js +1272 -0
  10. package/src/app.generator.js.map +1 -0
  11. package/src/download-packages.js +193 -0
  12. package/src/download-packages.js.map +1 -0
  13. package/src/fomatter.js +20 -0
  14. package/src/fomatter.js.map +1 -0
  15. package/src/gen-app-override-css.js +379 -0
  16. package/src/gen-app-override-css.js.map +1 -0
  17. package/src/genappoverridecssold-file.js +311 -0
  18. package/src/genappoverridecssold-file.js.map +1 -0
  19. package/src/handlebar-helpers.js +399 -0
  20. package/src/handlebar-helpers.js.map +1 -0
  21. package/src/increment-builder.js +85 -0
  22. package/src/increment-builder.js.map +1 -0
  23. package/src/profiles/profile.js +24 -0
  24. package/src/profiles/profile.js.map +1 -0
  25. package/src/profiles/web-preview.profile.js +15 -0
  26. package/src/profiles/web-preview.profile.js.map +1 -0
  27. package/src/project.service.js +314 -0
  28. package/src/project.service.js.map +1 -0
  29. package/src/transpile/bind.ex.transformer.js +226 -0
  30. package/src/transpile/bind.ex.transformer.js.map +1 -0
  31. package/src/transpile/components/advanced/carousel-template.transformer.js +16 -0
  32. package/src/transpile/components/advanced/carousel-template.transformer.js.map +1 -0
  33. package/src/transpile/components/advanced/carousel.transformer.js +55 -0
  34. package/src/transpile/components/advanced/carousel.transformer.js.map +1 -0
  35. package/src/transpile/components/advanced/login.transformer.js +26 -0
  36. package/src/transpile/components/advanced/login.transformer.js.map +1 -0
  37. package/src/transpile/components/advanced/marquee.transformer.js +16 -0
  38. package/src/transpile/components/advanced/marquee.transformer.js.map +1 -0
  39. package/src/transpile/components/basic/anchor.transformer.js +13 -0
  40. package/src/transpile/components/basic/anchor.transformer.js.map +1 -0
  41. package/src/transpile/components/basic/audio.transformer.js +16 -0
  42. package/src/transpile/components/basic/audio.transformer.js.map +1 -0
  43. package/src/transpile/components/basic/html.transformer.js +15 -0
  44. package/src/transpile/components/basic/html.transformer.js.map +1 -0
  45. package/src/transpile/components/basic/icon.transformer.js +16 -0
  46. package/src/transpile/components/basic/icon.transformer.js.map +1 -0
  47. package/src/transpile/components/basic/iframe.transformer.js +16 -0
  48. package/src/transpile/components/basic/iframe.transformer.js.map +1 -0
  49. package/src/transpile/components/basic/label.transformer.js +16 -0
  50. package/src/transpile/components/basic/label.transformer.js.map +1 -0
  51. package/src/transpile/components/basic/message.transformer.js +16 -0
  52. package/src/transpile/components/basic/message.transformer.js.map +1 -0
  53. package/src/transpile/components/basic/picture.transformer.js +22 -0
  54. package/src/transpile/components/basic/picture.transformer.js.map +1 -0
  55. package/src/transpile/components/basic/progress-bar.transformer.js +18 -0
  56. package/src/transpile/components/basic/progress-bar.transformer.js.map +1 -0
  57. package/src/transpile/components/basic/progress-circle.transformer.js +16 -0
  58. package/src/transpile/components/basic/progress-circle.transformer.js.map +1 -0
  59. package/src/transpile/components/basic/richtexteditor.transformer.js +21 -0
  60. package/src/transpile/components/basic/richtexteditor.transformer.js.map +1 -0
  61. package/src/transpile/components/basic/search.transformer.js +68 -0
  62. package/src/transpile/components/basic/search.transformer.js.map +1 -0
  63. package/src/transpile/components/basic/spinner.transformer.js +16 -0
  64. package/src/transpile/components/basic/spinner.transformer.js.map +1 -0
  65. package/src/transpile/components/basic/tree.transformer.js +16 -0
  66. package/src/transpile/components/basic/tree.transformer.js.map +1 -0
  67. package/src/transpile/components/basic/video.transformer.js +16 -0
  68. package/src/transpile/components/basic/video.transformer.js.map +1 -0
  69. package/src/transpile/components/chart/chart.transformer.js +13 -0
  70. package/src/transpile/components/chart/chart.transformer.js.map +1 -0
  71. package/src/transpile/components/container/accordion-pane.transformer.js +34 -0
  72. package/src/transpile/components/container/accordion-pane.transformer.js.map +1 -0
  73. package/src/transpile/components/container/accordion.transformer.js +49 -0
  74. package/src/transpile/components/container/accordion.transformer.js.map +1 -0
  75. package/src/transpile/components/container/container.transformer.js +27 -0
  76. package/src/transpile/components/container/container.transformer.js.map +1 -0
  77. package/src/transpile/components/container/layout-grid/grid-column.transformer.js +16 -0
  78. package/src/transpile/components/container/layout-grid/grid-column.transformer.js.map +1 -0
  79. package/src/transpile/components/container/layout-grid/grid-row.transformer.js +16 -0
  80. package/src/transpile/components/container/layout-grid/grid-row.transformer.js.map +1 -0
  81. package/src/transpile/components/container/layout-grid/grid.transformer.js +16 -0
  82. package/src/transpile/components/container/layout-grid/grid.transformer.js.map +1 -0
  83. package/src/transpile/components/container/linear-layout/linear-layout-item.js +16 -0
  84. package/src/transpile/components/container/linear-layout/linear-layout-item.js.map +1 -0
  85. package/src/transpile/components/container/linear-layout/linear-layout.js +16 -0
  86. package/src/transpile/components/container/linear-layout/linear-layout.js.map +1 -0
  87. package/src/transpile/components/container/panel-content.transformer.js +16 -0
  88. package/src/transpile/components/container/panel-content.transformer.js.map +1 -0
  89. package/src/transpile/components/container/panel-footer.transformer.js +11 -0
  90. package/src/transpile/components/container/panel-footer.transformer.js.map +1 -0
  91. package/src/transpile/components/container/panel.transformer.js +26 -0
  92. package/src/transpile/components/container/panel.transformer.js.map +1 -0
  93. package/src/transpile/components/container/repeat-template.transformer.js +16 -0
  94. package/src/transpile/components/container/repeat-template.transformer.js.map +1 -0
  95. package/src/transpile/components/container/tabheader.transformer.js +13 -0
  96. package/src/transpile/components/container/tabheader.transformer.js.map +1 -0
  97. package/src/transpile/components/container/tabpane.transformer.js +38 -0
  98. package/src/transpile/components/container/tabpane.transformer.js.map +1 -0
  99. package/src/transpile/components/container/tabs.transformer.js +105 -0
  100. package/src/transpile/components/container/tabs.transformer.js.map +1 -0
  101. package/src/transpile/components/container/tile.transformer.js +16 -0
  102. package/src/transpile/components/container/tile.transformer.js.map +1 -0
  103. package/src/transpile/components/container/wizard.transformer.js +81 -0
  104. package/src/transpile/components/container/wizard.transformer.js.map +1 -0
  105. package/src/transpile/components/container/wizardaction.transformer.js +120 -0
  106. package/src/transpile/components/container/wizardaction.transformer.js.map +1 -0
  107. package/src/transpile/components/container/wizardstep.transformer.js +74 -0
  108. package/src/transpile/components/container/wizardstep.transformer.js.map +1 -0
  109. package/src/transpile/components/data/card/card-actions.transformer.js +13 -0
  110. package/src/transpile/components/data/card/card-actions.transformer.js.map +1 -0
  111. package/src/transpile/components/data/card/card-content.transformer.js +23 -0
  112. package/src/transpile/components/data/card/card-content.transformer.js.map +1 -0
  113. package/src/transpile/components/data/card/card-footer.transformer.js +13 -0
  114. package/src/transpile/components/data/card/card-footer.transformer.js.map +1 -0
  115. package/src/transpile/components/data/card/card.transformer.js +13 -0
  116. package/src/transpile/components/data/card/card.transformer.js.map +1 -0
  117. package/src/transpile/components/data/form/dynamic-fields.transformer.js +24 -0
  118. package/src/transpile/components/data/form/dynamic-fields.transformer.js.map +1 -0
  119. package/src/transpile/components/data/form/form-action.transformer.js +145 -0
  120. package/src/transpile/components/data/form/form-action.transformer.js.map +1 -0
  121. package/src/transpile/components/data/form/form-body.transformer.js +16 -0
  122. package/src/transpile/components/data/form/form-body.transformer.js.map +1 -0
  123. package/src/transpile/components/data/form/form-field.transformer.js +443 -0
  124. package/src/transpile/components/data/form/form-field.transformer.js.map +1 -0
  125. package/src/transpile/components/data/form/form-footer.transformer.js +16 -0
  126. package/src/transpile/components/data/form/form-footer.transformer.js.map +1 -0
  127. package/src/transpile/components/data/form/form.transformer.js +167 -0
  128. package/src/transpile/components/data/form/form.transformer.js.map +1 -0
  129. package/src/transpile/components/data/form/util.js +70 -0
  130. package/src/transpile/components/data/form/util.js.map +1 -0
  131. package/src/transpile/components/data/list/list-content.transformer.js +35 -0
  132. package/src/transpile/components/data/list/list-content.transformer.js.map +1 -0
  133. package/src/transpile/components/data/list/list-template-transformer.js +13 -0
  134. package/src/transpile/components/data/list/list-template-transformer.js.map +1 -0
  135. package/src/transpile/components/data/list/list-transformer.js +308 -0
  136. package/src/transpile/components/data/list/list-transformer.js.map +1 -0
  137. package/src/transpile/components/data/live-filter-field.transformer.js +437 -0
  138. package/src/transpile/components/data/live-filter-field.transformer.js.map +1 -0
  139. package/src/transpile/components/data/livefilter.transformer.js +141 -0
  140. package/src/transpile/components/data/livefilter.transformer.js.map +1 -0
  141. package/src/transpile/components/data/liveform.transformer.js +160 -0
  142. package/src/transpile/components/data/liveform.transformer.js.map +1 -0
  143. package/src/transpile/components/data/table/live-table.transformer.js +15 -0
  144. package/src/transpile/components/data/table/live-table.transformer.js.map +1 -0
  145. package/src/transpile/components/data/table/table-action.transformer.js +29 -0
  146. package/src/transpile/components/data/table/table-action.transformer.js.map +1 -0
  147. package/src/transpile/components/data/table/table-column.transformer.js +121 -0
  148. package/src/transpile/components/data/table/table-column.transformer.js.map +1 -0
  149. package/src/transpile/components/data/table/table-group.transformer.js +16 -0
  150. package/src/transpile/components/data/table/table-group.transformer.js.map +1 -0
  151. package/src/transpile/components/data/table/table-row-action.transformer.js +34 -0
  152. package/src/transpile/components/data/table/table-row-action.transformer.js.map +1 -0
  153. package/src/transpile/components/data/table/table-row.transformer.js +33 -0
  154. package/src/transpile/components/data/table/table-row.transformer.js.map +1 -0
  155. package/src/transpile/components/data/table/table.transformer.js +64 -0
  156. package/src/transpile/components/data/table/table.transformer.js.map +1 -0
  157. package/src/transpile/components/data/table/utils.js +89 -0
  158. package/src/transpile/components/data/table/utils.js.map +1 -0
  159. package/src/transpile/components/dialogs/alert-dialog.transformer.js +16 -0
  160. package/src/transpile/components/dialogs/alert-dialog.transformer.js.map +1 -0
  161. package/src/transpile/components/dialogs/confirm-dialog.transformer.js +16 -0
  162. package/src/transpile/components/dialogs/confirm-dialog.transformer.js.map +1 -0
  163. package/src/transpile/components/dialogs/dialog-actions.transformer.js +57 -0
  164. package/src/transpile/components/dialogs/dialog-actions.transformer.js.map +1 -0
  165. package/src/transpile/components/dialogs/dialog-body.transformer.js +13 -0
  166. package/src/transpile/components/dialogs/dialog-body.transformer.js.map +1 -0
  167. package/src/transpile/components/dialogs/dialog.transformer.js +26 -0
  168. package/src/transpile/components/dialogs/dialog.transformer.js.map +1 -0
  169. package/src/transpile/components/dialogs/iframe-dialog.transformer.js +16 -0
  170. package/src/transpile/components/dialogs/iframe-dialog.transformer.js.map +1 -0
  171. package/src/transpile/components/dialogs/login-dialog.transformer.js +45 -0
  172. package/src/transpile/components/dialogs/login-dialog.transformer.js.map +1 -0
  173. package/src/transpile/components/dialogs/page-dialog.transformer.js +16 -0
  174. package/src/transpile/components/dialogs/page-dialog.transformer.js.map +1 -0
  175. package/src/transpile/components/element/html-transformer.js +9 -0
  176. package/src/transpile/components/element/html-transformer.js.map +1 -0
  177. package/src/transpile/components/form/button-group.transformer.js +16 -0
  178. package/src/transpile/components/form/button-group.transformer.js.map +1 -0
  179. package/src/transpile/components/form/button.transformer.js +27 -0
  180. package/src/transpile/components/form/button.transformer.js.map +1 -0
  181. package/src/transpile/components/form/rating.transformer.js +19 -0
  182. package/src/transpile/components/form/rating.transformer.js.map +1 -0
  183. package/src/transpile/components/input/calendar.transformer.js +13 -0
  184. package/src/transpile/components/input/calendar.transformer.js.map +1 -0
  185. package/src/transpile/components/input/checkbox-set.transformer.js +29 -0
  186. package/src/transpile/components/input/checkbox-set.transformer.js.map +1 -0
  187. package/src/transpile/components/input/checkbox.transformer.js +47 -0
  188. package/src/transpile/components/input/checkbox.transformer.js.map +1 -0
  189. package/src/transpile/components/input/chips.transformer.js +22 -0
  190. package/src/transpile/components/input/chips.transformer.js.map +1 -0
  191. package/src/transpile/components/input/color-picker.transformer.js +19 -0
  192. package/src/transpile/components/input/color-picker.transformer.js.map +1 -0
  193. package/src/transpile/components/input/composite.transformer.js +16 -0
  194. package/src/transpile/components/input/composite.transformer.js.map +1 -0
  195. package/src/transpile/components/input/currency.transformer.js +21 -0
  196. package/src/transpile/components/input/currency.transformer.js.map +1 -0
  197. package/src/transpile/components/input/epoch/date.transformer.js +16 -0
  198. package/src/transpile/components/input/epoch/date.transformer.js.map +1 -0
  199. package/src/transpile/components/input/epoch/datetime.transformer.js +16 -0
  200. package/src/transpile/components/input/epoch/datetime.transformer.js.map +1 -0
  201. package/src/transpile/components/input/epoch/time.transformer.js +16 -0
  202. package/src/transpile/components/input/epoch/time.transformer.js.map +1 -0
  203. package/src/transpile/components/input/file-upload.transformer.js +32 -0
  204. package/src/transpile/components/input/file-upload.transformer.js.map +1 -0
  205. package/src/transpile/components/input/number.transformer.js +20 -0
  206. package/src/transpile/components/input/number.transformer.js.map +1 -0
  207. package/src/transpile/components/input/radio-set.transformer.js +25 -0
  208. package/src/transpile/components/input/radio-set.transformer.js.map +1 -0
  209. package/src/transpile/components/input/rating.transformer.js +20 -0
  210. package/src/transpile/components/input/rating.transformer.js.map +1 -0
  211. package/src/transpile/components/input/select.transformer.js +57 -0
  212. package/src/transpile/components/input/select.transformer.js.map +1 -0
  213. package/src/transpile/components/input/slider.transformer.js +28 -0
  214. package/src/transpile/components/input/slider.transformer.js.map +1 -0
  215. package/src/transpile/components/input/switch.transformer.js +21 -0
  216. package/src/transpile/components/input/switch.transformer.js.map +1 -0
  217. package/src/transpile/components/input/text.transformer.js +21 -0
  218. package/src/transpile/components/input/text.transformer.js.map +1 -0
  219. package/src/transpile/components/input/textarea.transformer.js +19 -0
  220. package/src/transpile/components/input/textarea.transformer.js.map +1 -0
  221. package/src/transpile/components/input/upload.transformer.js +19 -0
  222. package/src/transpile/components/input/upload.transformer.js.map +1 -0
  223. package/src/transpile/components/layout/footer.transformer.js +31 -0
  224. package/src/transpile/components/layout/footer.transformer.js.map +1 -0
  225. package/src/transpile/components/layout/header.transformer.js +31 -0
  226. package/src/transpile/components/layout/header.transformer.js.map +1 -0
  227. package/src/transpile/components/layout/leftnav.transformer.js +31 -0
  228. package/src/transpile/components/layout/leftnav.transformer.js.map +1 -0
  229. package/src/transpile/components/layout/rightnav.transformer.js +31 -0
  230. package/src/transpile/components/layout/rightnav.transformer.js.map +1 -0
  231. package/src/transpile/components/layout/topnav.transformer.js +35 -0
  232. package/src/transpile/components/layout/topnav.transformer.js.map +1 -0
  233. package/src/transpile/components/nav/nav-item.transformer.js +25 -0
  234. package/src/transpile/components/nav/nav-item.transformer.js.map +1 -0
  235. package/src/transpile/components/nav/nav.transformer.js +69 -0
  236. package/src/transpile/components/nav/nav.transformer.js.map +1 -0
  237. package/src/transpile/components/nav/navbar.transformer.js +121 -0
  238. package/src/transpile/components/nav/navbar.transformer.js.map +1 -0
  239. package/src/transpile/components/navigation/breadcrumb.transformer.js +16 -0
  240. package/src/transpile/components/navigation/breadcrumb.transformer.js.map +1 -0
  241. package/src/transpile/components/navigation/menu.transformer.js +36 -0
  242. package/src/transpile/components/navigation/menu.transformer.js.map +1 -0
  243. package/src/transpile/components/navigation/popover.transformer.js +29 -0
  244. package/src/transpile/components/navigation/popover.transformer.js.map +1 -0
  245. package/src/transpile/components/page/content.transformer.js +17 -0
  246. package/src/transpile/components/page/content.transformer.js.map +1 -0
  247. package/src/transpile/components/page/page-content.transformer.js +17 -0
  248. package/src/transpile/components/page/page-content.transformer.js.map +1 -0
  249. package/src/transpile/components/page/page.transformer.js +50 -0
  250. package/src/transpile/components/page/page.transformer.js.map +1 -0
  251. package/src/transpile/components/page/partial-container.transformer.js +95 -0
  252. package/src/transpile/components/page/partial-container.transformer.js.map +1 -0
  253. package/src/transpile/components/page/partial.transformer.js +19 -0
  254. package/src/transpile/components/page/partial.transformer.js.map +1 -0
  255. package/src/transpile/components/prefab/prefab-container.transformer.js +32 -0
  256. package/src/transpile/components/prefab/prefab-container.transformer.js.map +1 -0
  257. package/src/transpile/components/prefab/prefab.transformer.js +85 -0
  258. package/src/transpile/components/prefab/prefab.transformer.js.map +1 -0
  259. package/src/transpile/components/transform-register.js +247 -0
  260. package/src/transpile/components/transform-register.js.map +1 -0
  261. package/src/transpile/components/utils.js +371 -0
  262. package/src/transpile/components/utils.js.map +1 -0
  263. package/src/transpile/components/wmx-component/wmx-component.transformer.js +35 -0
  264. package/src/transpile/components/wmx-component/wmx-component.transformer.js.map +1 -0
  265. package/src/transpile/id-generator.js +87 -0
  266. package/src/transpile/id-generator.js.map +1 -0
  267. package/src/transpile/property/base-parser.js +13 -0
  268. package/src/transpile/property/base-parser.js.map +1 -0
  269. package/src/transpile/property/property-parser.js +276 -0
  270. package/src/transpile/property/property-parser.js.map +1 -0
  271. package/src/transpile/property/show-in-device.parser.js +17 -0
  272. package/src/transpile/property/show-in-device.parser.js.map +1 -0
  273. package/src/transpile/style/background-image.parser.js +20 -0
  274. package/src/transpile/style/background-image.parser.js.map +1 -0
  275. package/src/transpile/style/border-width.parser.js +20 -0
  276. package/src/transpile/style/border-width.parser.js.map +1 -0
  277. package/src/transpile/style/dimension-style.parser.js +70 -0
  278. package/src/transpile/style/dimension-style.parser.js.map +1 -0
  279. package/src/transpile/style/horizontal-align.parser.js +24 -0
  280. package/src/transpile/style/horizontal-align.parser.js.map +1 -0
  281. package/src/transpile/style/margin.parser.js +20 -0
  282. package/src/transpile/style/margin.parser.js.map +1 -0
  283. package/src/transpile/style/multi-dimension-style.parser.js +29 -0
  284. package/src/transpile/style/multi-dimension-style.parser.js.map +1 -0
  285. package/src/transpile/style/numeric-style.parser.js +18 -0
  286. package/src/transpile/style/numeric-style.parser.js.map +1 -0
  287. package/src/transpile/style/padding.parser.js +20 -0
  288. package/src/transpile/style/padding.parser.js.map +1 -0
  289. package/src/transpile/style/style.parser.js +15 -0
  290. package/src/transpile/style/style.parser.js.map +1 -0
  291. package/src/transpile/style.transformer.js +124 -0
  292. package/src/transpile/style.transformer.js.map +1 -0
  293. package/src/transpile/transpile.js +1057 -0
  294. package/src/transpile/transpile.js.map +1 -0
  295. package/src/transpile/widget-inline-style-constants.js +200 -0
  296. package/src/transpile/widget-inline-style-constants.js.map +1 -0
  297. package/src/transpile/widget-inline-style-processor.js +714 -0
  298. package/src/transpile/widget-inline-style-processor.js.map +1 -0
  299. package/src/types/index.js +6 -0
  300. package/src/types/index.js.map +1 -0
  301. package/src/utils/grouping-util.js +500 -0
  302. package/src/utils/grouping-util.js.map +1 -0
  303. package/src/utils.js +934 -0
  304. package/src/utils.js.map +1 -0
  305. package/src/variables/variable.transformer.js +675 -0
  306. package/src/variables/variable.transformer.js.map +1 -0
  307. package/src/wmx.generator.js +216 -0
  308. package/src/wmx.generator.js.map +1 -0
  309. package/templates/.DS_Store +0 -0
  310. package/templates/app.style.template +3 -0
  311. package/templates/app.variables.template +1 -0
  312. package/templates/component/app.libs.hbs +38 -0
  313. package/templates/component/app.script.hbs +8 -0
  314. package/templates/component/app.template.hbs +47 -0
  315. package/templates/component/component.hbs +92 -0
  316. package/templates/component/component.props.template +1 -0
  317. package/templates/component/formatter.hbs +8 -0
  318. package/templates/component/layout.hbs +32 -0
  319. package/templates/component/page.hbs +16 -0
  320. package/templates/component/partial.hbs +78 -0
  321. package/templates/component/script.template +6 -0
  322. package/templates/component/style-def.template +18 -0
  323. package/templates/component/style.template +1 -0
  324. package/templates/entity-provider.template +21 -0
  325. package/templates/foundation/layout.tsx +30 -0
  326. package/templates/pages-config.template +12 -0
  327. package/templates/partial-config.template +58 -0
  328. package/templates/project/.DS_Store +0 -0
  329. package/templates/project/.env +1 -0
  330. package/templates/project/.gitignore +2 -0
  331. package/templates/project/.prettierrc +8 -0
  332. package/templates/project/README.md +60 -0
  333. package/templates/project/app/autoLayout.css +133 -0
  334. package/templates/project/app/client.layout.tsx +193 -0
  335. package/templates/project/app/components.css +186 -0
  336. package/templates/project/app/error.tsx +27 -0
  337. package/templates/project/app/globals.css +157 -0
  338. package/templates/project/app/layout.tsx +40 -0
  339. package/templates/project/app/loading.tsx +6 -0
  340. package/templates/project/app/page.tsx +3 -0
  341. package/templates/project/app/widgetInlineStylesOverride.css +676 -0
  342. package/templates/project/hooks/usePageEvents.tsx +45 -0
  343. package/templates/project/libs/appConfig.ts +14 -0
  344. package/templates/project/next-env.d.ts +5 -0
  345. package/templates/project/next.config.ts +17 -0
  346. package/templates/project/package-lock.json +5397 -0
  347. package/templates/project/package.json +38 -0
  348. package/templates/project/public/error-fallback.svg +89 -0
  349. package/templates/project/public/file.svg +1 -0
  350. package/templates/project/public/globe.svg +1 -0
  351. package/templates/project/public/next.svg +1 -0
  352. package/templates/project/public/vercel.svg +1 -0
  353. package/templates/project/public/window.svg +1 -0
  354. package/templates/project/scripts/app-custom-server.js +44 -0
  355. package/templates/project/scripts/getlibs.js +53 -0
  356. package/templates/project/tsconfig.json +36 -0
  357. package/templates/project/types/runtime-config.d.ts +9 -0
  358. package/templates/resource.resolver.template +20 -0
  359. package/templates/service.defs.template +3 -0
  360. package/templates/variables.template +252 -0
@@ -0,0 +1,676 @@
1
+ /* ==========================================================================
2
+ WaveMaker React Runtime — Aggregate Stylesheet
3
+ ==========================================================================
4
+
5
+
6
+ /* --------------------------------------------------------------------------
7
+ Utility classes
8
+ -------------------------------------------------------------------------- */
9
+
10
+ .wm-app .wm-hidden {
11
+ display: none;
12
+ }
13
+
14
+ .wm-app .wm-position-relative {
15
+ position: relative;
16
+ }
17
+
18
+ .wm-app .wm-overflow-inherit {
19
+ overflow: inherit;
20
+ }
21
+
22
+ .wm-app .wm-overflow-x-hidden {
23
+ overflow-x: hidden;
24
+ }
25
+
26
+ .wm-app .wm-touch-action-none {
27
+ touch-action: none;
28
+ }
29
+
30
+ .wm-app .wm-user-select-none {
31
+ user-select: none;
32
+ }
33
+
34
+ .wm-app .wm-will-change-transform {
35
+ will-change: transform;
36
+ }
37
+
38
+ .wm-app .wm-w-full {
39
+ width: 100%;
40
+ }
41
+
42
+ .wm-app .wm-text-center {
43
+ text-align: center;
44
+ }
45
+
46
+ .wm-app .wm-all-unset {
47
+ all: unset;
48
+ }
49
+
50
+ /* Image helpers */
51
+ .wm-app .wm-img-circle {
52
+ border-radius: 50%;
53
+ }
54
+
55
+ .wm-app .wm-w-32 {
56
+ width: 32px;
57
+ }
58
+
59
+ .wm-app .wm-h-32 {
60
+ height: 32px;
61
+ }
62
+
63
+ /* --------------------------------------------------------------------------
64
+ List component — inner container structure
65
+ -------------------------------------------------------------------------- */
66
+
67
+ .wm-app .app-livelist.app-panel .list-group .app-horizontal-list {
68
+ display: flex;
69
+ flex-direction: row;
70
+ flex-wrap: nowrap;
71
+ }
72
+
73
+ .wm-app
74
+ .app-livelist.app-panel
75
+ .list-group
76
+ .app-horizontal-list
77
+ > .app-list-item {
78
+ min-width: fit-content;
79
+ flex-shrink: 0;
80
+ }
81
+
82
+ /* --------------------------------------------------------------------------
83
+ List component — Load More footer
84
+ -------------------------------------------------------------------------- */
85
+
86
+ .wm-app .app-livelist.app-panel .app-livelist-container .wm-load-more-footer {
87
+ padding: 16px;
88
+ }
89
+
90
+ /* --------------------------------------------------------------------------
91
+ DnD sortable item
92
+ --wm-dnd-transform and --wm-dnd-transition are per-frame values from
93
+ @dnd-kit, set as inline style variables. All other DnD states use classes.
94
+ -------------------------------------------------------------------------- */
95
+
96
+ .wm-app .app-livelist.app-panel .app-livelist-container .wm-sortable-item {
97
+ transform: var(--wm-dnd-transform);
98
+ transition: var(--wm-dnd-transition);
99
+ }
100
+
101
+ .wm-app
102
+ .app-livelist.app-panel
103
+ .app-livelist-container
104
+ .wm-sortable-item.wm-dragging {
105
+ opacity: 0.5;
106
+ }
107
+
108
+ .wm-app
109
+ .app-livelist.app-panel
110
+ .app-livelist-container
111
+ .wm-sortable-item.wm-cursor-grab {
112
+ cursor: grab;
113
+ }
114
+
115
+ /* --------------------------------------------------------------------------
116
+ Wm-anchor component — inline styles for legacy support
117
+ -------------------------------------------------------------------------- */
118
+
119
+ /* Former sx={{ padding: 0 }} only — do not add other properties here. */
120
+ .wm-app .app-anchor.wm-anchor-link {
121
+ padding: 0;
122
+ }
123
+
124
+ /* Former inline icon layout (iconposition). */
125
+ .wm-app .app-anchor.wm-anchor-link.wm-anchor-icon-top {
126
+ flex-direction: column;
127
+ align-items: center;
128
+ }
129
+
130
+ .wm-app .app-anchor.wm-anchor-link.wm-anchor-icon-right {
131
+ direction: rtl;
132
+ }
133
+
134
+ .wm-app .app-anchor.wm-anchor-link.wm-anchor-icon-left {
135
+ direction: ltr;
136
+ }
137
+
138
+ .wm-app .app-anchor.wm-anchor-link .wm-anchor-icon-media {
139
+ margin: var(--wm-anchor-icon-margin, 0 4px);
140
+ width: var(--wm-anchor-icon-width, var(--wm-anchor-icon-size));
141
+ height: var(--wm-anchor-icon-height, var(--wm-anchor-icon-size));
142
+ }
143
+
144
+ /* Former Badge sx (font-size + badge transform). */
145
+ .wm-app .app-anchor.wm-anchor-link .wm-anchor-badge {
146
+ font-size: inherit;
147
+ }
148
+
149
+ .wm-app .app-anchor.wm-anchor-link .wm-anchor-badge .wm-anchor-badge-mark {
150
+ transform: none;
151
+ }
152
+
153
+ /* --------------------------------------------------------------------------
154
+ WmHtml component — inline styles for legacy support
155
+ -------------------------------------------------------------------------- */
156
+
157
+ .wm-app .app-html-container.wm-html-root.wm-html-align-left {
158
+ text-align: left !important;
159
+ }
160
+
161
+ .wm-app .app-html-container.wm-html-root.wm-html-align-center {
162
+ text-align: center !important;
163
+ }
164
+
165
+ .wm-app .app-html-container.wm-html-root.wm-html-align-right {
166
+ text-align: right !important;
167
+ }
168
+
169
+ .wm-app .app-html-container.wm-html-root {
170
+ width: var(--wm-html-width);
171
+ height: var(--wm-html-height);
172
+ overflow: var(--wm-html-overflow);
173
+ }
174
+
175
+ /* --------------------------------------------------------------------------
176
+ WmIcon — layout + size via CSS vars on .wm-icon-root for legacy support
177
+ Runtime sets --icon-size, --icon-width, --icon-height (no --wm- prefix; see rules/rulz.txt).
178
+ -------------------------------------------------------------------------- */
179
+
180
+ .wm-app .app-icon-wrapper.wm-icon-root {
181
+ flex-direction: row;
182
+ font-size: var(--icon-size);
183
+ }
184
+
185
+ .wm-app .app-icon-wrapper.wm-icon-root.wm-icon-pos-right {
186
+ flex-direction: row-reverse;
187
+ }
188
+
189
+ .wm-app .app-icon-wrapper.wm-icon-root .wm-icon-media {
190
+ width: var(--icon-width, auto);
191
+ height: var(--icon-height, auto);
192
+ }
193
+
194
+ /* --------------------------------------------------------------------------
195
+ WmIframe — former inner sx: border/margin; dimensions via vars from runtime.
196
+ -------------------------------------------------------------------------- */
197
+
198
+ .wm-app .embed-responsive.app-iframe.wm-iframe-root {
199
+ width: var(--wm-iframe-width);
200
+ height: var(--wm-iframe-height);
201
+ }
202
+
203
+ .wm-app .embed-responsive.app-iframe.wm-iframe-root .wm-iframe-frame {
204
+ border: 0;
205
+ margin: 0;
206
+ width: var(--wm-iframe-inner-width);
207
+ height: var(--wm-iframe-inner-height);
208
+ }
209
+
210
+ /* --------------------------------------------------------------------------
211
+ WmLabel — former styled(Box) display; former inline styles on caption links.
212
+ -------------------------------------------------------------------------- */
213
+
214
+ .wm-label-root {
215
+ display: inline-block;
216
+ }
217
+
218
+ .wm-app .app-label.wm-label-root a {
219
+ color: blue;
220
+ text-decoration: underline;
221
+ }
222
+
223
+ /* WmPicture: former sx {{ objectFit: resizemode || "cover" }} — .app-picture + wm-picture-object-fit-* (Rule 5) */
224
+ .wm-app .app-picture.wm-picture-object-fit-fill {
225
+ object-fit: fill;
226
+ }
227
+
228
+ .wm-app .app-picture.wm-picture-object-fit-cover {
229
+ object-fit: cover;
230
+ }
231
+
232
+ .wm-app .app-picture.wm-picture-object-fit-contain {
233
+ object-fit: contain;
234
+ }
235
+
236
+ /* WmProgressBar: dynamic segment width via inline CSS var only */
237
+ .wm-app .app-progress .wm-progress-segment {
238
+ width: var(--wm-progress-segment-width);
239
+ }
240
+
241
+ /* WmVideo: former styled(video) { width: 100%; height: auto; } — .app-video .wm-video-media */
242
+ .wm-app .wm-video-media {
243
+ width: 100%;
244
+ height: auto;
245
+ }
246
+
247
+ /* WmProgressCircle — former default Box 150×150, SVG overflow, arc transform/transition, caption font sizes */
248
+ .wm-app .app-progress.circle.wm-progress-circle-root {
249
+ width: 150px;
250
+ height: 150px;
251
+ }
252
+
253
+ .wm-app .app-progress.circle.wm-progress-circle-root .wm-progress-circle-svg {
254
+ overflow: visible;
255
+ }
256
+
257
+ .wm-app .app-progress.circle.wm-progress-circle-root .wm-progress-circle-arc {
258
+ transform: rotate(-90deg);
259
+ transform-origin: 50% 50%;
260
+ transition: stroke-dashoffset 0.5s ease;
261
+ }
262
+
263
+ /* Shared 0.7em caption text (value, title, subtitle) */
264
+ .wm-app
265
+ .app-progress.circle.wm-progress-circle-root
266
+ .wm-progress-circle-caption-primary {
267
+ font-size: 0.7em;
268
+ }
269
+
270
+ .wm-app
271
+ .app-progress.circle.wm-progress-circle-root
272
+ .wm-progress-circle-caption-suffix {
273
+ font-size: 0.45em;
274
+ }
275
+
276
+ /* --------------------------------------------------------------------------
277
+ WmSearch — former inline static styles (dropdown may portal outside .app-search)
278
+ -------------------------------------------------------------------------- */
279
+
280
+ .wm-app .wm-search-popper,
281
+ .wm-search-popper {
282
+ z-index: 1300;
283
+ }
284
+
285
+ .wm-app .wm-search-group-title,
286
+ .wm-search-group-title {
287
+ padding: 10px 16px;
288
+ }
289
+
290
+ .wm-app .wm-search-match-highlight,
291
+ .wm-search-match-highlight {
292
+ color: var(--wm-search-dropdown-menu-item-color-matched);
293
+ }
294
+
295
+ .wm-app .wm-search-dropdown-item,
296
+ .wm-search-dropdown-item {
297
+ padding: 10px 16px;
298
+ }
299
+
300
+ .wm-app .wm-search-item-link,
301
+ .wm-search-item-link {
302
+ text-decoration: none;
303
+ color: inherit;
304
+ }
305
+
306
+ .wm-app .wm-search-item-image,
307
+ .wm-search-item-image {
308
+ margin-right: 8px;
309
+ border-radius: 100%;
310
+ }
311
+
312
+ .wm-app .wm-search-loading-spinner,
313
+ .wm-search-loading-spinner {
314
+ display: inline-flex;
315
+ vertical-align: middle;
316
+ margin-right: 8px;
317
+ }
318
+
319
+ .wm-app .wm-search-dropdown-message,
320
+ .wm-search-dropdown-message {
321
+ padding: 8px 16px;
322
+ }
323
+
324
+ .wm-app .wm-search-dropdown-completion,
325
+ .wm-search-dropdown-completion {
326
+ padding: 8px 16px;
327
+ text-align: center;
328
+ }
329
+
330
+ .wm-app .wm-search-dropdown-scroll,
331
+ .wm-search-dropdown-scroll {
332
+ max-height: 300px;
333
+ overflow: auto;
334
+ box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
335
+ }
336
+
337
+ /* WmTree: former empty-state inline styles */
338
+ .wm-app .app-tree .wm-tree-empty-message {
339
+ padding: 16px;
340
+ color: inherit;
341
+ }
342
+
343
+ .wm-app .app-tree .wm-tree-children-list {
344
+ margin-left: 20px;
345
+ list-style: none;
346
+ padding: 0;
347
+ }
348
+
349
+ .wm-app .app-tree .wm-tree-children-open {
350
+ display: block;
351
+ }
352
+
353
+ .wm-app .app-tree .wm-tree-children-closed {
354
+ display: none;
355
+ }
356
+
357
+ /* WmSpinner: former styled(Box) image static styles */
358
+ .wm-app .app-spinner .wm-spinner-image {
359
+ width: var(--wm-spinner-image-width, 20px);
360
+ height: var(--wm-spinner-image-height, auto);
361
+ background-image: var(--wm-spinner-image-bg-image);
362
+ background-size: var(--wm-spinner-image-bg-size, 20px);
363
+ background-repeat: no-repeat;
364
+ display: inline-block;
365
+ }
366
+
367
+ .wm-app .app-spinner .wm-spinner-icon {
368
+ font-size: var(--wm-spinner-icon-size);
369
+ }
370
+
371
+ /* WmRichTextEditor: static placeholder textarea styles */
372
+ .wm-app .wm-richtexteditor-placeholder {
373
+ border: 1px solid;
374
+ border-radius: 4px;
375
+ padding: 8px;
376
+ font: inherit;
377
+ resize: vertical;
378
+ box-sizing: border-box;
379
+ }
380
+
381
+ /* EditorContainer */
382
+ .wm-app .wm-richtexteditor-root .jodit-workplace {
383
+ height: var(--richtexteditor-height, auto) !important;
384
+ }
385
+
386
+ .wm-richtexteditor-root .jodit-container {
387
+ border: 1px solid var(--wm-richtexteditor-divider);
388
+ }
389
+
390
+ .wm-app .wm-richtexteditor-root .jodit-react-container {
391
+ min-height: unset !important;
392
+ min-width: unset !important;
393
+ max-width: unset !important;
394
+ }
395
+
396
+ .wm-app .wm-richtexteditor-root .jodit-status-bar {
397
+ border: 1px solid var(--richtexteditor-divider);
398
+ border-top: none;
399
+ }
400
+
401
+ .wm-app .wm-richtexteditor-root .jodit-toolbar {
402
+ background: var(--richtexteditor-paper-bg);
403
+ border: 1px solid var(--richtexteditor-divider);
404
+ border-bottom: none;
405
+ }
406
+
407
+ .wm-app .wm-richtexteditor-root .jodit-toolbar__box {
408
+ background: var(--richtexteditor-paper-bg);
409
+ }
410
+
411
+ .wm-app .wm-richtexteditor-root .jodit-toolbar-button {
412
+ margin: 2px;
413
+ }
414
+
415
+ .wm-app .wm-richtexteditor-root div[contenteditable='true'] {
416
+ background: var(--wm-note-editable-background);
417
+ color: var(--wm-note-editable-color);
418
+ }
419
+
420
+ .wm-app .wm-richtexteditor-root .jodit-wysiwyg {
421
+ padding: unset !important;
422
+ margin: unset !important;
423
+ min-height: 100px !important;
424
+ }
425
+
426
+ .wm-app .wm-richtexteditor-root .jodit-wysiwyg ul,
427
+ .wm-app .wm-richtexteditor-root .jodit-wysiwyg li {
428
+ padding-left: 2em !important;
429
+ margin: 1em 0 !important;
430
+ list-style-type: unset;
431
+ }
432
+
433
+ .wm-app .wm-richtexteditor-root .jodit-container * {
434
+ box-sizing: border-box;
435
+ }
436
+
437
+ .wm-app .wm-richtexteditor-root .jodit-wysiwyg ol {
438
+ list-style-type: decimal;
439
+ padding-left: 2em !important;
440
+ margin: 1em 0 !important;
441
+ }
442
+
443
+ /* Hidden Input */
444
+ .wm-app .wm-richtexteditor-hidden-input {
445
+ display: none;
446
+ }
447
+
448
+ /* PreviewContainer */
449
+ .wm-app .wm-richtexteditor-preview {
450
+ margin-top: var(--richtexteditor-preview-margin-top);
451
+ padding: var(--richtexteditor-preview-padding);
452
+ border-radius: var(--richtexteditor-preview-radius);
453
+ background-color: var(--richtexteditor-paper-bg);
454
+ color: var(--richtexteditor-text-primary);
455
+ min-height: 100px !important;
456
+ overflow-y: auto;
457
+ }
458
+
459
+ .wm-app .wm-richtexteditor-preview img {
460
+ max-width: 100%;
461
+ }
462
+
463
+ .wm-app .wm-richtexteditor-preview table {
464
+ border-collapse: collapse;
465
+ width: 100%;
466
+ margin: var(--richtexteditor-preview-table-margin);
467
+ }
468
+
469
+ .wm-app .wm-richtexteditor-preview th,
470
+ .wm-app .wm-richtexteditor-preview td {
471
+ border: 1px solid var(--richtexteditor-divider);
472
+ padding: var(--richtexteditor-preview-cell-padding);
473
+ }
474
+
475
+ /* WmCalendar: former root inline width */
476
+ .wm-app .app-calendar.wm-calendar-root {
477
+ width: 100%;
478
+ }
479
+
480
+ /* WmChips: former MUI Box flex layout on chip list (display/flexWrap/gap) */
481
+ .wm-chips-list {
482
+ display: flex;
483
+ flex-wrap: wrap;
484
+ gap: 8px;
485
+ }
486
+
487
+ /* WmChips SortableChip: former static margin + cursor/opacity from inline style */
488
+ .wm-app .wm-chips-chip-item,
489
+ .wm-chips-chip-item {
490
+ margin: 2px;
491
+ }
492
+
493
+ .wm-app .wm-chips-chip-item.wm-chips-chip-grab,
494
+ .wm-chips-chip-item.wm-chips-chip-grab {
495
+ cursor: grab;
496
+ }
497
+
498
+ .wm-app .wm-chips-chip-item:not(.wm-chips-chip-grab),
499
+ .wm-chips-chip-item:not(.wm-chips-chip-grab) {
500
+ cursor: default;
501
+ }
502
+
503
+ .wm-app .wm-chips-chip-item.wm-chips-chip-dragging,
504
+ .wm-chips-chip-item.wm-chips-chip-dragging {
505
+ opacity: 0.5;
506
+ }
507
+
508
+ /* WmColorPicker: former root sx position:relative */
509
+ .wm-app .input-group.app-colorpicker.wm-colorpicker-root,
510
+ .input-group.app-colorpicker.wm-colorpicker-root {
511
+ position: relative;
512
+ }
513
+
514
+ /* Addon cursor: one of enabled | disabled (matches former pointer / not-allowed) */
515
+ .wm-app .wm-colorpicker-addon-enabled,
516
+ .wm-colorpicker-addon-enabled {
517
+ cursor: pointer;
518
+ }
519
+
520
+ .wm-app .wm-colorpicker-addon-disabled,
521
+ .wm-colorpicker-addon-disabled {
522
+ cursor: not-allowed;
523
+ }
524
+
525
+ /* Portal popup: former styled(Box) ChromePicker wrapper (fixed + arrow + .chrome-picker chrome) */
526
+ .wm-app .wm-colorpicker-popup,
527
+ .wm-colorpicker-popup {
528
+ position: fixed;
529
+ z-index: 1300;
530
+ top: var(--colorpicker-popup-top, 0);
531
+ left: var(--colorpicker-popup-left, 0);
532
+ margin-top: var(--colorpicker-popup-margin-top, 8px);
533
+ }
534
+
535
+ .wm-app .wm-colorpicker-popup.wm-colorpicker-popup-direction-down::before,
536
+ .wm-colorpicker-popup.wm-colorpicker-popup-direction-down::before {
537
+ content: '';
538
+ position: absolute;
539
+ left: 8px;
540
+ width: 0;
541
+ height: 0;
542
+ border-style: solid;
543
+ z-index: 999999;
544
+ top: -10px;
545
+ border-width: 0 5px 10px 5px;
546
+ border-color: transparent transparent #777 transparent;
547
+ }
548
+
549
+ .wm-app .wm-colorpicker-popup.wm-colorpicker-popup-direction-up::before,
550
+ .wm-colorpicker-popup.wm-colorpicker-popup-direction-up::before {
551
+ content: '';
552
+ position: absolute;
553
+ left: 8px;
554
+ width: 0;
555
+ height: 0;
556
+ border-style: solid;
557
+ z-index: 999999;
558
+ bottom: -10px;
559
+ border-width: 10px 5px 0 5px;
560
+ border-color: #777 transparent transparent transparent;
561
+ }
562
+
563
+ .wm-app .wm-colorpicker-popup .chrome-picker,
564
+ .wm-colorpicker-popup .chrome-picker {
565
+ box-shadow:
566
+ 0 2px 15px rgba(0, 0, 0, 0.12),
567
+ 0 2px 10px rgba(0, 0, 0, 0.16) !important;
568
+ height: auto;
569
+ border: #777 solid 1px;
570
+ cursor: default;
571
+ user-select: none;
572
+ background-color: #fff !important;
573
+ border-radius: 4px;
574
+ padding: 8px;
575
+ width: 226px !important;
576
+ box-sizing: border-box !important;
577
+ }
578
+
579
+ .wm-app .wm-colorpicker-swatch,
580
+ .wm-colorpicker-swatch {
581
+ background-color: var(--colorpicker-swatch-bg, transparent);
582
+ }
583
+
584
+ /* WmCheckboxset: former inline/sx styles */
585
+ .wm-checkboxset-item-reset {
586
+ all: unset;
587
+ }
588
+
589
+ .wm-app .wm-checkboxset-input-readonly,
590
+ .wm-checkboxset-input-readonly {
591
+ background: transparent !important;
592
+ }
593
+
594
+ .wm-app .wm-checkboxset-label-row {
595
+ margin-bottom: 1px;
596
+ }
597
+
598
+ .wm-app .wm-checkboxset-required-mark,
599
+ .wm-checkboxset-required-mark {
600
+ color: red;
601
+ }
602
+
603
+ .wm-app .wm-checkboxset-group-list {
604
+ padding-left: 2px;
605
+ }
606
+
607
+ /* WmRadioset: former styled(List) static + collapsible/disabled + list width */
608
+ .wm-radioset-styled-list {
609
+ list-style-type: none;
610
+ padding: 0;
611
+ margin: 0;
612
+ width: var(--radioset-list-width, 100%);
613
+ }
614
+
615
+ .wm-radioset-styled-list.wm-radioset-list-collapsible
616
+ li.app-list-item-group
617
+ ul.item-group {
618
+ padding: 0;
619
+ display: none;
620
+ }
621
+
622
+ .wm-radioset-styled-list.wm-radioset-list-collapsible
623
+ li.app-list-item-group
624
+ ul.collapse-open {
625
+ display: block;
626
+ }
627
+
628
+ .wm-radioset-styled-list.wm-radioset-list-disabled {
629
+ opacity: 0.5;
630
+ user-select: none;
631
+ }
632
+
633
+ /* WmSwitch: former root / btn-group inline layout */
634
+ .wm-app .app-switch.wm-switch-root {
635
+ overflow: auto;
636
+ }
637
+
638
+ .wm-app .app-switch .wm-switch-inner {
639
+ overflow: visible;
640
+ position: relative;
641
+ }
642
+
643
+ /* WmFileUpload */
644
+ .wm-app .app-fileupload.wm-fileupload-root {
645
+ width: 100%;
646
+ }
647
+
648
+ .wm-app input.file-input.wm-fileupload-file-input {
649
+ display: none;
650
+ }
651
+
652
+ .wm-app .file-list-container.wm-fileupload-file-list-container {
653
+ overflow: auto;
654
+ max-height: var(--fileupload-list-max-height) px;
655
+ }
656
+
657
+ .wm-fileupload-media-full-width {
658
+ width: 100%;
659
+ }
660
+
661
+ /* WmNumber: former TextField static sx; dynamic props.styles on sx + htmlInput (type=text) */
662
+ .wm-number-textfield {
663
+ width: 100%;
664
+ }
665
+
666
+ .wm-number-textfield.wm-number-textfield-disabled .wm-number-slot-input {
667
+ -webkit-text-fill-color: inherit;
668
+ }
669
+
670
+ .wm-number-helper-text {
671
+ margin-left: 0;
672
+ }
673
+
674
+ .wm-number-helper-text.wm-number-helper-text-error {
675
+ color: #ee5f5b;
676
+ }
@@ -0,0 +1,45 @@
1
+ 'use client';
2
+ import { useEffect, useRef } from 'react';
3
+
4
+ export interface PageEventHandlers {
5
+ attach?: () => void;
6
+ detach?: () => void;
7
+ destroy?: () => void;
8
+ orientationchange?: () => void;
9
+ resize?: () => void;
10
+ }
11
+
12
+ export const usePageEvent = (handlers: PageEventHandlers) => {
13
+ const handlersRef = useRef(handlers);
14
+ handlersRef.current = handlers;
15
+
16
+ useEffect(() => {
17
+ // this will be called when the page is mounted/attached
18
+ if (handlersRef.current.attach) {
19
+ handlersRef.current.attach();
20
+ }
21
+
22
+ const handleOrientationChange = () => {
23
+ handlersRef.current.orientationchange?.();
24
+ };
25
+
26
+ const handleResize = () => {
27
+ handlersRef.current.resize?.();
28
+ };
29
+
30
+ window.addEventListener('orientationchange', handleOrientationChange);
31
+ window.addEventListener('resize', handleResize);
32
+
33
+ return () => {
34
+ window.removeEventListener('orientationchange', handleOrientationChange); // called when page orientation changes
35
+ window.removeEventListener('resize', handleResize); // called when page is resized
36
+
37
+ // this will be called when the page is destroyed/unmounted
38
+ if (handlersRef.current.destroy) {
39
+ handlersRef.current.destroy();
40
+ }
41
+ };
42
+ }, []);
43
+
44
+ return null;
45
+ };