@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.
Files changed (386) hide show
  1. package/build-react-web.js +149 -0
  2. package/build-react-web.js.map +1 -0
  3. package/command.js +106 -0
  4. package/command.js.map +1 -0
  5. package/dist/transpiler/index.d.mts +62 -0
  6. package/dist/transpiler/index.mjs +47857 -0
  7. package/dist/transpiler/index.mjs.map +1 -0
  8. package/dist/transpiler/wm-styles.css +1502 -0
  9. package/index.js +122 -0
  10. package/index.js.map +1 -0
  11. package/package-lock.json +5243 -0
  12. package/package.json +104 -0
  13. package/src/app.generator.js +1274 -0
  14. package/src/app.generator.js.map +1 -0
  15. package/src/download-packages.js +193 -0
  16. package/src/download-packages.js.map +1 -0
  17. package/src/fomatter.js +20 -0
  18. package/src/fomatter.js.map +1 -0
  19. package/src/gen-app-override-css.js +379 -0
  20. package/src/gen-app-override-css.js.map +1 -0
  21. package/src/genappoverridecssold-file.js +311 -0
  22. package/src/genappoverridecssold-file.js.map +1 -0
  23. package/src/handlebar-helpers.js +51 -0
  24. package/src/handlebar-helpers.js.map +1 -0
  25. package/src/increment-builder.js +85 -0
  26. package/src/increment-builder.js.map +1 -0
  27. package/src/profiles/profile.js +24 -0
  28. package/src/profiles/profile.js.map +1 -0
  29. package/src/profiles/web-preview.profile.js +15 -0
  30. package/src/profiles/web-preview.profile.js.map +1 -0
  31. package/src/project.service.js +314 -0
  32. package/src/project.service.js.map +1 -0
  33. package/src/transpile/bind.ex.transformer.js +232 -0
  34. package/src/transpile/bind.ex.transformer.js.map +1 -0
  35. package/src/transpile/components/advanced/carousel-template.transformer.js +16 -0
  36. package/src/transpile/components/advanced/carousel-template.transformer.js.map +1 -0
  37. package/src/transpile/components/advanced/carousel.transformer.js +54 -0
  38. package/src/transpile/components/advanced/carousel.transformer.js.map +1 -0
  39. package/src/transpile/components/advanced/login.transformer.js +25 -0
  40. package/src/transpile/components/advanced/login.transformer.js.map +1 -0
  41. package/src/transpile/components/advanced/marquee.transformer.js +16 -0
  42. package/src/transpile/components/advanced/marquee.transformer.js.map +1 -0
  43. package/src/transpile/components/basic/anchor.transformer.js +13 -0
  44. package/src/transpile/components/basic/anchor.transformer.js.map +1 -0
  45. package/src/transpile/components/basic/audio.transformer.js +16 -0
  46. package/src/transpile/components/basic/audio.transformer.js.map +1 -0
  47. package/src/transpile/components/basic/html.transformer.js +15 -0
  48. package/src/transpile/components/basic/html.transformer.js.map +1 -0
  49. package/src/transpile/components/basic/icon.transformer.js +16 -0
  50. package/src/transpile/components/basic/icon.transformer.js.map +1 -0
  51. package/src/transpile/components/basic/iframe.transformer.js +16 -0
  52. package/src/transpile/components/basic/iframe.transformer.js.map +1 -0
  53. package/src/transpile/components/basic/label.transformer.js +16 -0
  54. package/src/transpile/components/basic/label.transformer.js.map +1 -0
  55. package/src/transpile/components/basic/message.transformer.js +16 -0
  56. package/src/transpile/components/basic/message.transformer.js.map +1 -0
  57. package/src/transpile/components/basic/picture.transformer.js +22 -0
  58. package/src/transpile/components/basic/picture.transformer.js.map +1 -0
  59. package/src/transpile/components/basic/progress-bar.transformer.js +18 -0
  60. package/src/transpile/components/basic/progress-bar.transformer.js.map +1 -0
  61. package/src/transpile/components/basic/progress-circle.transformer.js +16 -0
  62. package/src/transpile/components/basic/progress-circle.transformer.js.map +1 -0
  63. package/src/transpile/components/basic/richtexteditor.transformer.js +21 -0
  64. package/src/transpile/components/basic/richtexteditor.transformer.js.map +1 -0
  65. package/src/transpile/components/basic/search.transformer.js +68 -0
  66. package/src/transpile/components/basic/search.transformer.js.map +1 -0
  67. package/src/transpile/components/basic/spinner.transformer.js +16 -0
  68. package/src/transpile/components/basic/spinner.transformer.js.map +1 -0
  69. package/src/transpile/components/basic/tree.transformer.js +16 -0
  70. package/src/transpile/components/basic/tree.transformer.js.map +1 -0
  71. package/src/transpile/components/basic/video.transformer.js +16 -0
  72. package/src/transpile/components/basic/video.transformer.js.map +1 -0
  73. package/src/transpile/components/chart/chart.transformer.js +13 -0
  74. package/src/transpile/components/chart/chart.transformer.js.map +1 -0
  75. package/src/transpile/components/container/accordion-pane.transformer.js +44 -0
  76. package/src/transpile/components/container/accordion-pane.transformer.js.map +1 -0
  77. package/src/transpile/components/container/accordion.transformer.js +48 -0
  78. package/src/transpile/components/container/accordion.transformer.js.map +1 -0
  79. package/src/transpile/components/container/container.transformer.js +39 -0
  80. package/src/transpile/components/container/container.transformer.js.map +1 -0
  81. package/src/transpile/components/container/layout-grid/grid-column.transformer.js +16 -0
  82. package/src/transpile/components/container/layout-grid/grid-column.transformer.js.map +1 -0
  83. package/src/transpile/components/container/layout-grid/grid-row.transformer.js +16 -0
  84. package/src/transpile/components/container/layout-grid/grid-row.transformer.js.map +1 -0
  85. package/src/transpile/components/container/layout-grid/grid.transformer.js +16 -0
  86. package/src/transpile/components/container/layout-grid/grid.transformer.js.map +1 -0
  87. package/src/transpile/components/container/linear-layout/linear-layout-item.js +16 -0
  88. package/src/transpile/components/container/linear-layout/linear-layout-item.js.map +1 -0
  89. package/src/transpile/components/container/linear-layout/linear-layout.js +16 -0
  90. package/src/transpile/components/container/linear-layout/linear-layout.js.map +1 -0
  91. package/src/transpile/components/container/panel-content.transformer.js +16 -0
  92. package/src/transpile/components/container/panel-content.transformer.js.map +1 -0
  93. package/src/transpile/components/container/panel-footer.transformer.js +11 -0
  94. package/src/transpile/components/container/panel-footer.transformer.js.map +1 -0
  95. package/src/transpile/components/container/panel.transformer.js +36 -0
  96. package/src/transpile/components/container/panel.transformer.js.map +1 -0
  97. package/src/transpile/components/container/repeat-template.transformer.js +16 -0
  98. package/src/transpile/components/container/repeat-template.transformer.js.map +1 -0
  99. package/src/transpile/components/container/tabheader.transformer.js +13 -0
  100. package/src/transpile/components/container/tabheader.transformer.js.map +1 -0
  101. package/src/transpile/components/container/tabpane.transformer.js +48 -0
  102. package/src/transpile/components/container/tabpane.transformer.js.map +1 -0
  103. package/src/transpile/components/container/tabs.transformer.js +71 -0
  104. package/src/transpile/components/container/tabs.transformer.js.map +1 -0
  105. package/src/transpile/components/container/tile.transformer.js +16 -0
  106. package/src/transpile/components/container/tile.transformer.js.map +1 -0
  107. package/src/transpile/components/container/wizard.transformer.js +80 -0
  108. package/src/transpile/components/container/wizard.transformer.js.map +1 -0
  109. package/src/transpile/components/container/wizardaction.transformer.js +120 -0
  110. package/src/transpile/components/container/wizardaction.transformer.js.map +1 -0
  111. package/src/transpile/components/container/wizardstep.transformer.js +99 -0
  112. package/src/transpile/components/container/wizardstep.transformer.js.map +1 -0
  113. package/src/transpile/components/data/card/card-actions.transformer.js +13 -0
  114. package/src/transpile/components/data/card/card-actions.transformer.js.map +1 -0
  115. package/src/transpile/components/data/card/card-content.transformer.js +33 -0
  116. package/src/transpile/components/data/card/card-content.transformer.js.map +1 -0
  117. package/src/transpile/components/data/card/card-footer.transformer.js +13 -0
  118. package/src/transpile/components/data/card/card-footer.transformer.js.map +1 -0
  119. package/src/transpile/components/data/card/card.transformer.js +13 -0
  120. package/src/transpile/components/data/card/card.transformer.js.map +1 -0
  121. package/src/transpile/components/data/form/dynamic-fields.transformer.js +24 -0
  122. package/src/transpile/components/data/form/dynamic-fields.transformer.js.map +1 -0
  123. package/src/transpile/components/data/form/form-action.transformer.js +145 -0
  124. package/src/transpile/components/data/form/form-action.transformer.js.map +1 -0
  125. package/src/transpile/components/data/form/form-body.transformer.js +16 -0
  126. package/src/transpile/components/data/form/form-body.transformer.js.map +1 -0
  127. package/src/transpile/components/data/form/form-field.transformer.js +442 -0
  128. package/src/transpile/components/data/form/form-field.transformer.js.map +1 -0
  129. package/src/transpile/components/data/form/form-footer.transformer.js +16 -0
  130. package/src/transpile/components/data/form/form-footer.transformer.js.map +1 -0
  131. package/src/transpile/components/data/form/form.transformer.js +166 -0
  132. package/src/transpile/components/data/form/form.transformer.js.map +1 -0
  133. package/src/transpile/components/data/form/util.js +70 -0
  134. package/src/transpile/components/data/form/util.js.map +1 -0
  135. package/src/transpile/components/data/list/list-content.transformer.js +35 -0
  136. package/src/transpile/components/data/list/list-content.transformer.js.map +1 -0
  137. package/src/transpile/components/data/list/list-template-transformer.js +22 -0
  138. package/src/transpile/components/data/list/list-template-transformer.js.map +1 -0
  139. package/src/transpile/components/data/list/list-transformer.js +287 -0
  140. package/src/transpile/components/data/list/list-transformer.js.map +1 -0
  141. package/src/transpile/components/data/live-filter-field.transformer.js +436 -0
  142. package/src/transpile/components/data/live-filter-field.transformer.js.map +1 -0
  143. package/src/transpile/components/data/livefilter.transformer.js +140 -0
  144. package/src/transpile/components/data/livefilter.transformer.js.map +1 -0
  145. package/src/transpile/components/data/liveform.transformer.js +159 -0
  146. package/src/transpile/components/data/liveform.transformer.js.map +1 -0
  147. package/src/transpile/components/data/table/live-table.transformer.js +15 -0
  148. package/src/transpile/components/data/table/live-table.transformer.js.map +1 -0
  149. package/src/transpile/components/data/table/table-action.transformer.js +29 -0
  150. package/src/transpile/components/data/table/table-action.transformer.js.map +1 -0
  151. package/src/transpile/components/data/table/table-column.transformer.js +121 -0
  152. package/src/transpile/components/data/table/table-column.transformer.js.map +1 -0
  153. package/src/transpile/components/data/table/table-group.transformer.js +16 -0
  154. package/src/transpile/components/data/table/table-group.transformer.js.map +1 -0
  155. package/src/transpile/components/data/table/table-row-action.transformer.js +34 -0
  156. package/src/transpile/components/data/table/table-row-action.transformer.js.map +1 -0
  157. package/src/transpile/components/data/table/table-row.transformer.js +46 -0
  158. package/src/transpile/components/data/table/table-row.transformer.js.map +1 -0
  159. package/src/transpile/components/data/table/table.transformer.js +64 -0
  160. package/src/transpile/components/data/table/table.transformer.js.map +1 -0
  161. package/src/transpile/components/data/table/utils.js +89 -0
  162. package/src/transpile/components/data/table/utils.js.map +1 -0
  163. package/src/transpile/components/dialogs/alert-dialog.transformer.js +16 -0
  164. package/src/transpile/components/dialogs/alert-dialog.transformer.js.map +1 -0
  165. package/src/transpile/components/dialogs/confirm-dialog.transformer.js +16 -0
  166. package/src/transpile/components/dialogs/confirm-dialog.transformer.js.map +1 -0
  167. package/src/transpile/components/dialogs/dialog-actions.transformer.js +56 -0
  168. package/src/transpile/components/dialogs/dialog-actions.transformer.js.map +1 -0
  169. package/src/transpile/components/dialogs/dialog-body.transformer.js +13 -0
  170. package/src/transpile/components/dialogs/dialog-body.transformer.js.map +1 -0
  171. package/src/transpile/components/dialogs/dialog.transformer.js +26 -0
  172. package/src/transpile/components/dialogs/dialog.transformer.js.map +1 -0
  173. package/src/transpile/components/dialogs/iframe-dialog.transformer.js +16 -0
  174. package/src/transpile/components/dialogs/iframe-dialog.transformer.js.map +1 -0
  175. package/src/transpile/components/dialogs/login-dialog.transformer.js +44 -0
  176. package/src/transpile/components/dialogs/login-dialog.transformer.js.map +1 -0
  177. package/src/transpile/components/dialogs/page-dialog.transformer.js +16 -0
  178. package/src/transpile/components/dialogs/page-dialog.transformer.js.map +1 -0
  179. package/src/transpile/components/element/html-transformer.js +9 -0
  180. package/src/transpile/components/element/html-transformer.js.map +1 -0
  181. package/src/transpile/components/form/button-group.transformer.js +16 -0
  182. package/src/transpile/components/form/button-group.transformer.js.map +1 -0
  183. package/src/transpile/components/form/button.transformer.js +27 -0
  184. package/src/transpile/components/form/button.transformer.js.map +1 -0
  185. package/src/transpile/components/form/rating.transformer.js +19 -0
  186. package/src/transpile/components/form/rating.transformer.js.map +1 -0
  187. package/src/transpile/components/input/calendar.transformer.js +13 -0
  188. package/src/transpile/components/input/calendar.transformer.js.map +1 -0
  189. package/src/transpile/components/input/checkbox-set.transformer.js +29 -0
  190. package/src/transpile/components/input/checkbox-set.transformer.js.map +1 -0
  191. package/src/transpile/components/input/checkbox.transformer.js +47 -0
  192. package/src/transpile/components/input/checkbox.transformer.js.map +1 -0
  193. package/src/transpile/components/input/chips.transformer.js +22 -0
  194. package/src/transpile/components/input/chips.transformer.js.map +1 -0
  195. package/src/transpile/components/input/color-picker.transformer.js +19 -0
  196. package/src/transpile/components/input/color-picker.transformer.js.map +1 -0
  197. package/src/transpile/components/input/composite.transformer.js +16 -0
  198. package/src/transpile/components/input/composite.transformer.js.map +1 -0
  199. package/src/transpile/components/input/currency.transformer.js +21 -0
  200. package/src/transpile/components/input/currency.transformer.js.map +1 -0
  201. package/src/transpile/components/input/epoch/date.transformer.js +16 -0
  202. package/src/transpile/components/input/epoch/date.transformer.js.map +1 -0
  203. package/src/transpile/components/input/epoch/datetime.transformer.js +16 -0
  204. package/src/transpile/components/input/epoch/datetime.transformer.js.map +1 -0
  205. package/src/transpile/components/input/epoch/time.transformer.js +16 -0
  206. package/src/transpile/components/input/epoch/time.transformer.js.map +1 -0
  207. package/src/transpile/components/input/file-upload.transformer.js +32 -0
  208. package/src/transpile/components/input/file-upload.transformer.js.map +1 -0
  209. package/src/transpile/components/input/number.transformer.js +20 -0
  210. package/src/transpile/components/input/number.transformer.js.map +1 -0
  211. package/src/transpile/components/input/radio-set.transformer.js +25 -0
  212. package/src/transpile/components/input/radio-set.transformer.js.map +1 -0
  213. package/src/transpile/components/input/rating.transformer.js +20 -0
  214. package/src/transpile/components/input/rating.transformer.js.map +1 -0
  215. package/src/transpile/components/input/select.transformer.js +57 -0
  216. package/src/transpile/components/input/select.transformer.js.map +1 -0
  217. package/src/transpile/components/input/slider.transformer.js +28 -0
  218. package/src/transpile/components/input/slider.transformer.js.map +1 -0
  219. package/src/transpile/components/input/switch.transformer.js +21 -0
  220. package/src/transpile/components/input/switch.transformer.js.map +1 -0
  221. package/src/transpile/components/input/text.transformer.js +21 -0
  222. package/src/transpile/components/input/text.transformer.js.map +1 -0
  223. package/src/transpile/components/input/textarea.transformer.js +19 -0
  224. package/src/transpile/components/input/textarea.transformer.js.map +1 -0
  225. package/src/transpile/components/input/upload.transformer.js +19 -0
  226. package/src/transpile/components/input/upload.transformer.js.map +1 -0
  227. package/src/transpile/components/layout/footer.transformer.js +48 -0
  228. package/src/transpile/components/layout/footer.transformer.js.map +1 -0
  229. package/src/transpile/components/layout/header.transformer.js +48 -0
  230. package/src/transpile/components/layout/header.transformer.js.map +1 -0
  231. package/src/transpile/components/layout/leftnav.transformer.js +48 -0
  232. package/src/transpile/components/layout/leftnav.transformer.js.map +1 -0
  233. package/src/transpile/components/layout/rightnav.transformer.js +48 -0
  234. package/src/transpile/components/layout/rightnav.transformer.js.map +1 -0
  235. package/src/transpile/components/layout/topnav.transformer.js +48 -0
  236. package/src/transpile/components/layout/topnav.transformer.js.map +1 -0
  237. package/src/transpile/components/nav/nav-item.transformer.js +24 -0
  238. package/src/transpile/components/nav/nav-item.transformer.js.map +1 -0
  239. package/src/transpile/components/nav/nav.transformer.js +68 -0
  240. package/src/transpile/components/nav/nav.transformer.js.map +1 -0
  241. package/src/transpile/components/nav/navbar.transformer.js +120 -0
  242. package/src/transpile/components/nav/navbar.transformer.js.map +1 -0
  243. package/src/transpile/components/navigation/breadcrumb.transformer.js +16 -0
  244. package/src/transpile/components/navigation/breadcrumb.transformer.js.map +1 -0
  245. package/src/transpile/components/navigation/menu.transformer.js +36 -0
  246. package/src/transpile/components/navigation/menu.transformer.js.map +1 -0
  247. package/src/transpile/components/navigation/popover.transformer.js +39 -0
  248. package/src/transpile/components/navigation/popover.transformer.js.map +1 -0
  249. package/src/transpile/components/page/content.transformer.js +17 -0
  250. package/src/transpile/components/page/content.transformer.js.map +1 -0
  251. package/src/transpile/components/page/page-content.transformer.js +17 -0
  252. package/src/transpile/components/page/page-content.transformer.js.map +1 -0
  253. package/src/transpile/components/page/page.transformer.js +50 -0
  254. package/src/transpile/components/page/page.transformer.js.map +1 -0
  255. package/src/transpile/components/page/partial-container.transformer.js +61 -0
  256. package/src/transpile/components/page/partial-container.transformer.js.map +1 -0
  257. package/src/transpile/components/page/partial.transformer.js +19 -0
  258. package/src/transpile/components/page/partial.transformer.js.map +1 -0
  259. package/src/transpile/components/partial/partial-content.transformer.js +56 -0
  260. package/src/transpile/components/partial/partial-content.transformer.js.map +1 -0
  261. package/src/transpile/components/prefab/prefab-container.transformer.js +32 -0
  262. package/src/transpile/components/prefab/prefab-container.transformer.js.map +1 -0
  263. package/src/transpile/components/prefab/prefab.transformer.js +91 -0
  264. package/src/transpile/components/prefab/prefab.transformer.js.map +1 -0
  265. package/src/transpile/components/transform-register.js +247 -0
  266. package/src/transpile/components/transform-register.js.map +1 -0
  267. package/src/transpile/components/utils.js +371 -0
  268. package/src/transpile/components/utils.js.map +1 -0
  269. package/src/transpile/components/wmx-component/wmx-component.transformer.js +35 -0
  270. package/src/transpile/components/wmx-component/wmx-component.transformer.js.map +1 -0
  271. package/src/transpile/id-generator.js +87 -0
  272. package/src/transpile/id-generator.js.map +1 -0
  273. package/src/transpile/index.js +65 -0
  274. package/src/transpile/index.js.map +1 -0
  275. package/src/transpile/property/base-parser.js +13 -0
  276. package/src/transpile/property/base-parser.js.map +1 -0
  277. package/src/transpile/property/property-parser.js +277 -0
  278. package/src/transpile/property/property-parser.js.map +1 -0
  279. package/src/transpile/property/show-in-device.parser.js +17 -0
  280. package/src/transpile/property/show-in-device.parser.js.map +1 -0
  281. package/src/transpile/serialize-variables.js +322 -0
  282. package/src/transpile/serialize-variables.js.map +1 -0
  283. package/src/transpile/style/background-image.parser.js +20 -0
  284. package/src/transpile/style/background-image.parser.js.map +1 -0
  285. package/src/transpile/style/border-width.parser.js +20 -0
  286. package/src/transpile/style/border-width.parser.js.map +1 -0
  287. package/src/transpile/style/dimension-style.parser.js +70 -0
  288. package/src/transpile/style/dimension-style.parser.js.map +1 -0
  289. package/src/transpile/style/horizontal-align.parser.js +24 -0
  290. package/src/transpile/style/horizontal-align.parser.js.map +1 -0
  291. package/src/transpile/style/margin.parser.js +20 -0
  292. package/src/transpile/style/margin.parser.js.map +1 -0
  293. package/src/transpile/style/multi-dimension-style.parser.js +29 -0
  294. package/src/transpile/style/multi-dimension-style.parser.js.map +1 -0
  295. package/src/transpile/style/numeric-style.parser.js +18 -0
  296. package/src/transpile/style/numeric-style.parser.js.map +1 -0
  297. package/src/transpile/style/padding.parser.js +20 -0
  298. package/src/transpile/style/padding.parser.js.map +1 -0
  299. package/src/transpile/style/split-css-shorthand.js +60 -0
  300. package/src/transpile/style/split-css-shorthand.js.map +1 -0
  301. package/src/transpile/style/style.parser.js +15 -0
  302. package/src/transpile/style/style.parser.js.map +1 -0
  303. package/src/transpile/style.transformer.js +124 -0
  304. package/src/transpile/style.transformer.js.map +1 -0
  305. package/src/transpile/transform-markup.js +283 -0
  306. package/src/transpile/transform-markup.js.map +1 -0
  307. package/src/transpile/transpile-variables.js +35 -0
  308. package/src/transpile/transpile-variables.js.map +1 -0
  309. package/src/transpile/transpile.js +1098 -0
  310. package/src/transpile/transpile.js.map +1 -0
  311. package/src/transpile/transpiler.js +26 -0
  312. package/src/transpile/transpiler.js.map +1 -0
  313. package/src/transpile/variables-template-source.js +6 -0
  314. package/src/transpile/variables-template-source.js.map +1 -0
  315. package/src/transpile/variables-template.js +15 -0
  316. package/src/transpile/variables-template.js.map +1 -0
  317. package/src/transpile/widget-inline-style-constants.js +200 -0
  318. package/src/transpile/widget-inline-style-constants.js.map +1 -0
  319. package/src/transpile/widget-inline-style-processor.js +684 -0
  320. package/src/transpile/widget-inline-style-processor.js.map +1 -0
  321. package/src/types/index.js +6 -0
  322. package/src/types/index.js.map +1 -0
  323. package/src/utils/grouping-util.js +500 -0
  324. package/src/utils/grouping-util.js.map +1 -0
  325. package/src/utils.browser.js +853 -0
  326. package/src/utils.browser.js.map +1 -0
  327. package/src/utils.js +988 -0
  328. package/src/utils.js.map +1 -0
  329. package/src/variables/variable.transformer.js +690 -0
  330. package/src/variables/variable.transformer.js.map +1 -0
  331. package/src/wmx.generator.js +216 -0
  332. package/src/wmx.generator.js.map +1 -0
  333. package/templates/.DS_Store +0 -0
  334. package/templates/app.style.template +3 -0
  335. package/templates/app.variables.template +1 -0
  336. package/templates/component/app.libs.hbs +38 -0
  337. package/templates/component/app.script.hbs +8 -0
  338. package/templates/component/app.template.hbs +47 -0
  339. package/templates/component/component.hbs +79 -0
  340. package/templates/component/component.props.template +1 -0
  341. package/templates/component/formatter.hbs +8 -0
  342. package/templates/component/layout.hbs +32 -0
  343. package/templates/component/page.hbs +16 -0
  344. package/templates/component/partial.hbs +69 -0
  345. package/templates/component/script.template +6 -0
  346. package/templates/component/style-def.template +18 -0
  347. package/templates/component/style.template +1 -0
  348. package/templates/entity-provider.template +21 -0
  349. package/templates/foundation/layout.tsx +30 -0
  350. package/templates/pages-config.template +12 -0
  351. package/templates/partial-config.template +58 -0
  352. package/templates/project/.DS_Store +0 -0
  353. package/templates/project/.env +1 -0
  354. package/templates/project/.gitignore +2 -0
  355. package/templates/project/.prettierrc +8 -0
  356. package/templates/project/README.md +60 -0
  357. package/templates/project/app/autoLayout.css +133 -0
  358. package/templates/project/app/client.layout.tsx +193 -0
  359. package/templates/project/app/components.css +182 -0
  360. package/templates/project/app/error.tsx +27 -0
  361. package/templates/project/app/globals.css +5 -0
  362. package/templates/project/app/layout.tsx +40 -0
  363. package/templates/project/app/loading.tsx +6 -0
  364. package/templates/project/app/page.tsx +3 -0
  365. package/templates/project/app/widgetInlineStylesOverride.css +1027 -0
  366. package/templates/project/app/wm-globals.css +152 -0
  367. package/templates/project/app/wm-styles.css +4 -0
  368. package/templates/project/hooks/usePageEvents.tsx +45 -0
  369. package/templates/project/libs/appConfig.ts +14 -0
  370. package/templates/project/next-env.d.ts +5 -0
  371. package/templates/project/next.config.ts +17 -0
  372. package/templates/project/package-lock.json +5397 -0
  373. package/templates/project/package.json +41 -0
  374. package/templates/project/public/error-fallback.svg +89 -0
  375. package/templates/project/public/file.svg +1 -0
  376. package/templates/project/public/globe.svg +1 -0
  377. package/templates/project/public/next.svg +1 -0
  378. package/templates/project/public/vercel.svg +1 -0
  379. package/templates/project/public/window.svg +1 -0
  380. package/templates/project/scripts/app-custom-server.js +44 -0
  381. package/templates/project/scripts/getlibs.js +53 -0
  382. package/templates/project/tsconfig.json +36 -0
  383. package/templates/project/types/runtime-config.d.ts +9 -0
  384. package/templates/resource.resolver.template +20 -0
  385. package/templates/service.defs.template +3 -0
  386. package/templates/variables.template +252 -0
@@ -0,0 +1,1027 @@
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
+ .wm-app .app-livelist .app-livelist-container.clearfix {
115
+ width: 100%;
116
+ height: 100%;
117
+ box-sizing: border-box;
118
+ }
119
+
120
+ /* --------------------------------------------------------------------------
121
+ Wm-anchor component — inline styles for legacy support
122
+ -------------------------------------------------------------------------- */
123
+
124
+ /* Former sx={{ padding: 0 }} only — do not add other properties here. */
125
+ .wm-app .app-anchor.wm-anchor-link {
126
+ padding: 0;
127
+ }
128
+
129
+ /* Former inline icon layout (iconposition). */
130
+ .wm-app .app-anchor.wm-anchor-link.wm-anchor-icon-top {
131
+ flex-direction: column;
132
+ align-items: center;
133
+ }
134
+
135
+ .wm-app .app-anchor.wm-anchor-link.wm-anchor-icon-right {
136
+ direction: rtl;
137
+ }
138
+
139
+ .wm-app .app-anchor.wm-anchor-link.wm-anchor-icon-left {
140
+ direction: ltr;
141
+ }
142
+
143
+ .wm-app .app-anchor.wm-anchor-link .wm-anchor-icon-media {
144
+ margin: var(--wm-anchor-icon-margin, 0 4px);
145
+ width: var(--wm-anchor-icon-width, var(--wm-anchor-icon-size));
146
+ height: var(--wm-anchor-icon-height, var(--wm-anchor-icon-size));
147
+ }
148
+
149
+ /* Former Badge sx (font-size + badge transform). */
150
+ .wm-app .app-anchor.wm-anchor-link .wm-anchor-badge {
151
+ font-size: inherit;
152
+ }
153
+
154
+ .wm-app .app-anchor.wm-anchor-link .wm-anchor-badge .wm-anchor-badge-mark {
155
+ transform: none;
156
+ }
157
+
158
+ /* --------------------------------------------------------------------------
159
+ WmHtml component — inline styles for legacy support
160
+ -------------------------------------------------------------------------- */
161
+
162
+ .wm-app .app-html-container.wm-html-root.wm-html-align-left {
163
+ text-align: left !important;
164
+ }
165
+
166
+ .wm-app .app-html-container.wm-html-root.wm-html-align-center {
167
+ text-align: center !important;
168
+ }
169
+
170
+ .wm-app .app-html-container.wm-html-root.wm-html-align-right {
171
+ text-align: right !important;
172
+ }
173
+
174
+ .wm-app .app-html-container.wm-html-root {
175
+ width: var(--wm-html-width);
176
+ height: var(--wm-html-height);
177
+ overflow: var(--wm-html-overflow);
178
+ }
179
+
180
+ /* --------------------------------------------------------------------------
181
+ WmIcon — layout + size via CSS vars on .wm-icon-root for legacy support
182
+ Runtime sets --icon-size, --icon-width, --icon-height (no --wm- prefix; see rules/rulz.txt).
183
+ -------------------------------------------------------------------------- */
184
+
185
+ .wm-app .app-icon-wrapper.wm-icon-root {
186
+ flex-direction: row;
187
+ font-size: var(--icon-size);
188
+ }
189
+
190
+ .wm-app .app-icon-wrapper.wm-icon-root.wm-icon-pos-right {
191
+ flex-direction: row-reverse;
192
+ }
193
+
194
+ .wm-app .app-icon-wrapper.wm-icon-root .wm-icon-media {
195
+ width: var(--icon-width, auto);
196
+ height: var(--icon-height, auto);
197
+ }
198
+
199
+ /* --------------------------------------------------------------------------
200
+ WmIframe — former inner sx: border/margin; dimensions via vars from runtime.
201
+ -------------------------------------------------------------------------- */
202
+
203
+ .wm-app .embed-responsive.app-iframe.wm-iframe-root {
204
+ width: var(--wm-iframe-width);
205
+ height: var(--wm-iframe-height);
206
+ }
207
+
208
+ .wm-app .embed-responsive.app-iframe.wm-iframe-root .wm-iframe-frame {
209
+ border: 0;
210
+ margin: 0;
211
+ width: var(--wm-iframe-inner-width);
212
+ height: var(--wm-iframe-inner-height);
213
+ }
214
+
215
+ /* --------------------------------------------------------------------------
216
+ WmLabel — former styled(Box) display; former inline styles on caption links.
217
+ -------------------------------------------------------------------------- */
218
+
219
+ .wm-label-root {
220
+ display: inline-block;
221
+ }
222
+
223
+ .wm-app .app-label.wm-label-root a {
224
+ color: blue;
225
+ text-decoration: underline;
226
+ }
227
+
228
+ /* WmPicture: former sx {{ objectFit: resizemode || "cover" }} — .app-picture + wm-picture-object-fit-* (Rule 5) */
229
+ .wm-app .app-picture.wm-picture-object-fit-fill {
230
+ object-fit: fill;
231
+ }
232
+
233
+ .wm-app .app-picture.wm-picture-object-fit-cover {
234
+ object-fit: cover;
235
+ }
236
+
237
+ .wm-app .app-picture.wm-picture-object-fit-contain {
238
+ object-fit: contain;
239
+ }
240
+
241
+ /* WmProgressBar: dynamic segment width via inline CSS var only */
242
+ .wm-app .app-progress .wm-progress-segment {
243
+ width: var(--wm-progress-segment-width);
244
+ }
245
+
246
+ /* WmVideo: former styled(video) { width: 100%; height: auto; } — .app-video .wm-video-media */
247
+ .wm-app .wm-video-media {
248
+ width: 100%;
249
+ height: auto;
250
+ }
251
+
252
+ /* WmProgressCircle — former default Box 150×150, SVG overflow, arc transform/transition, caption font sizes */
253
+ .wm-app .app-progress.circle.wm-progress-circle-root {
254
+ width: 150px;
255
+ height: 150px;
256
+ }
257
+
258
+ .wm-app .app-progress.circle.wm-progress-circle-root .wm-progress-circle-svg {
259
+ overflow: visible;
260
+ }
261
+
262
+ .wm-app .app-progress.circle.wm-progress-circle-root .wm-progress-circle-arc {
263
+ transform: rotate(-90deg);
264
+ transform-origin: 50% 50%;
265
+ transition: stroke-dashoffset 0.5s ease;
266
+ }
267
+
268
+ /* Shared 0.7em caption text (value, title, subtitle) */
269
+ .wm-app
270
+ .app-progress.circle.wm-progress-circle-root
271
+ .wm-progress-circle-caption-primary {
272
+ font-size: 0.7em;
273
+ }
274
+
275
+ .wm-app
276
+ .app-progress.circle.wm-progress-circle-root
277
+ .wm-progress-circle-caption-suffix {
278
+ font-size: 0.45em;
279
+ }
280
+
281
+ /* --------------------------------------------------------------------------
282
+ WmSearch — former inline static styles (dropdown may portal outside .app-search)
283
+ -------------------------------------------------------------------------- */
284
+
285
+ .wm-app .wm-search-popper,
286
+ .wm-search-popper {
287
+ z-index: 1300;
288
+ }
289
+
290
+ .wm-app .wm-search-group-title,
291
+ .wm-search-group-title {
292
+ padding: 10px 16px;
293
+ }
294
+
295
+ .wm-app .wm-search-match-highlight,
296
+ .wm-search-match-highlight {
297
+ color: var(--wm-search-dropdown-menu-item-color-matched);
298
+ }
299
+
300
+ .wm-app .wm-search-dropdown-item,
301
+ .wm-search-dropdown-item {
302
+ padding: 10px 16px;
303
+ }
304
+
305
+ .wm-app .wm-search-item-link,
306
+ .wm-search-item-link {
307
+ text-decoration: none;
308
+ color: inherit;
309
+ }
310
+
311
+ .wm-app .wm-search-item-image,
312
+ .wm-search-item-image {
313
+ margin-right: 8px;
314
+ border-radius: 100%;
315
+ }
316
+
317
+ .wm-app .wm-search-loading-spinner,
318
+ .wm-search-loading-spinner {
319
+ display: inline-flex;
320
+ vertical-align: middle;
321
+ margin-right: 8px;
322
+ }
323
+
324
+ .wm-app .wm-search-dropdown-message,
325
+ .wm-search-dropdown-message {
326
+ padding: 8px 16px;
327
+ }
328
+
329
+ .wm-app .wm-search-dropdown-completion,
330
+ .wm-search-dropdown-completion {
331
+ padding: 8px 16px;
332
+ text-align: center;
333
+ }
334
+
335
+ .wm-app .wm-search-dropdown-scroll,
336
+ .wm-search-dropdown-scroll {
337
+ max-height: 300px;
338
+ overflow: auto;
339
+ box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
340
+ }
341
+
342
+ /* WmTree: former empty-state inline styles */
343
+ .wm-app .app-tree .wm-tree-empty-message {
344
+ padding: 16px;
345
+ color: inherit;
346
+ }
347
+
348
+ .wm-app .app-tree .wm-tree-children-list {
349
+ margin-left: 20px;
350
+ list-style: none;
351
+ padding: 0;
352
+ }
353
+
354
+ .wm-app .app-tree .wm-tree-children-open {
355
+ display: block;
356
+ }
357
+
358
+ .wm-app .app-tree .wm-tree-children-closed {
359
+ display: none;
360
+ }
361
+
362
+ /* WmSpinner: former styled(Box) image static styles */
363
+ .wm-app .app-spinner .wm-spinner-image {
364
+ width: var(--wm-spinner-image-width, 20px);
365
+ height: var(--wm-spinner-image-height, auto);
366
+ background-image: var(--wm-spinner-image-bg-image);
367
+ background-size: var(--wm-spinner-image-bg-size, 20px);
368
+ background-repeat: no-repeat;
369
+ display: inline-block;
370
+ }
371
+
372
+ .wm-app .app-spinner .wm-spinner-icon {
373
+ font-size: var(--wm-spinner-icon-size);
374
+ }
375
+
376
+ /* WmRichTextEditor: static placeholder textarea styles */
377
+ .wm-app .wm-richtexteditor-placeholder {
378
+ border: 1px solid;
379
+ border-radius: 4px;
380
+ padding: 8px;
381
+ font: inherit;
382
+ resize: vertical;
383
+ box-sizing: border-box;
384
+ }
385
+
386
+ /* EditorContainer */
387
+ .wm-app .wm-richtexteditor-root .jodit-workplace {
388
+ height: var(--richtexteditor-height, auto) !important;
389
+ }
390
+
391
+ .wm-richtexteditor-root .jodit-container {
392
+ border: 1px solid var(--wm-richtexteditor-divider);
393
+ }
394
+
395
+ .wm-app .wm-richtexteditor-root .jodit-react-container {
396
+ min-height: unset !important;
397
+ min-width: unset !important;
398
+ max-width: unset !important;
399
+ }
400
+
401
+ .wm-app .wm-richtexteditor-root .jodit-status-bar {
402
+ border: 1px solid var(--richtexteditor-divider);
403
+ border-top: none;
404
+ }
405
+
406
+ .wm-app .wm-richtexteditor-root .jodit-toolbar {
407
+ background: var(--richtexteditor-paper-bg);
408
+ border: 1px solid var(--richtexteditor-divider);
409
+ border-bottom: none;
410
+ }
411
+
412
+ .wm-app .wm-richtexteditor-root .jodit-toolbar__box {
413
+ background: var(--richtexteditor-paper-bg);
414
+ }
415
+
416
+ .wm-app .wm-richtexteditor-root .jodit-toolbar-button {
417
+ margin: 2px;
418
+ }
419
+
420
+ .wm-app .wm-richtexteditor-root div[contenteditable='true'] {
421
+ background: var(--wm-note-editable-background);
422
+ color: var(--wm-note-editable-color);
423
+ }
424
+
425
+ .wm-app .wm-richtexteditor-root .jodit-wysiwyg {
426
+ padding: unset !important;
427
+ margin: unset !important;
428
+ min-height: 100px !important;
429
+ }
430
+
431
+ .wm-app .wm-richtexteditor-root .jodit-wysiwyg ul,
432
+ .wm-app .wm-richtexteditor-root .jodit-wysiwyg li {
433
+ padding-left: 2em !important;
434
+ margin: 1em 0 !important;
435
+ list-style-type: unset;
436
+ }
437
+
438
+ .wm-app .wm-richtexteditor-root .jodit-container * {
439
+ box-sizing: border-box;
440
+ }
441
+
442
+ .wm-app .wm-richtexteditor-root .jodit-wysiwyg ol {
443
+ list-style-type: decimal;
444
+ padding-left: 2em !important;
445
+ margin: 1em 0 !important;
446
+ }
447
+
448
+ /* Hidden Input */
449
+ .wm-app .wm-richtexteditor-hidden-input {
450
+ display: none;
451
+ }
452
+
453
+ /* PreviewContainer */
454
+ .wm-app .wm-richtexteditor-preview {
455
+ margin-top: var(--richtexteditor-preview-margin-top);
456
+ padding: var(--richtexteditor-preview-padding);
457
+ border-radius: var(--richtexteditor-preview-radius);
458
+ background-color: var(--richtexteditor-paper-bg);
459
+ color: var(--richtexteditor-text-primary);
460
+ min-height: 100px !important;
461
+ overflow-y: auto;
462
+ }
463
+
464
+ .wm-app .wm-richtexteditor-preview img {
465
+ max-width: 100%;
466
+ }
467
+
468
+ .wm-app .wm-richtexteditor-preview table {
469
+ border-collapse: collapse;
470
+ width: 100%;
471
+ margin: var(--richtexteditor-preview-table-margin);
472
+ }
473
+
474
+ .wm-app .wm-richtexteditor-preview th,
475
+ .wm-app .wm-richtexteditor-preview td {
476
+ border: 1px solid var(--richtexteditor-divider);
477
+ padding: var(--richtexteditor-preview-cell-padding);
478
+ }
479
+
480
+ /* WmCalendar: former root inline width */
481
+ .wm-app .app-calendar.wm-calendar-root {
482
+ width: 100%;
483
+ }
484
+
485
+ /* WmChips: former MUI Box flex layout on chip list (display/flexWrap/gap) */
486
+ .wm-chips-list {
487
+ display: flex;
488
+ flex-wrap: wrap;
489
+ gap: 8px;
490
+ }
491
+
492
+ /* WmChips SortableChip: former static margin + cursor/opacity from inline style */
493
+ .wm-app .wm-chips-chip-item,
494
+ .wm-chips-chip-item {
495
+ margin: 2px;
496
+ }
497
+
498
+ .wm-app .wm-chips-chip-item.wm-chips-chip-grab,
499
+ .wm-chips-chip-item.wm-chips-chip-grab {
500
+ cursor: grab;
501
+ }
502
+
503
+ .wm-app .wm-chips-chip-item:not(.wm-chips-chip-grab),
504
+ .wm-chips-chip-item:not(.wm-chips-chip-grab) {
505
+ cursor: default;
506
+ }
507
+
508
+ .wm-app .wm-chips-chip-item.wm-chips-chip-dragging,
509
+ .wm-chips-chip-item.wm-chips-chip-dragging {
510
+ opacity: 0.5;
511
+ }
512
+
513
+ /* WmColorPicker: former root sx position:relative */
514
+ .wm-app .input-group.app-colorpicker.wm-colorpicker-root,
515
+ .input-group.app-colorpicker.wm-colorpicker-root {
516
+ position: relative;
517
+ }
518
+
519
+ /* Addon cursor: one of enabled | disabled (matches former pointer / not-allowed) */
520
+ .wm-app .wm-colorpicker-addon-enabled,
521
+ .wm-colorpicker-addon-enabled {
522
+ cursor: pointer;
523
+ }
524
+
525
+ .wm-app .wm-colorpicker-addon-disabled,
526
+ .wm-colorpicker-addon-disabled {
527
+ cursor: not-allowed;
528
+ }
529
+
530
+ /* Portal popup: former styled(Box) ChromePicker wrapper (fixed + arrow + .chrome-picker chrome) */
531
+ .wm-app .wm-colorpicker-popup,
532
+ .wm-colorpicker-popup {
533
+ position: fixed;
534
+ z-index: 1300;
535
+ top: var(--colorpicker-popup-top, 0);
536
+ left: var(--colorpicker-popup-left, 0);
537
+ margin-top: var(--colorpicker-popup-margin-top, 8px);
538
+ }
539
+
540
+ .wm-app .wm-colorpicker-popup.wm-colorpicker-popup-direction-down::before,
541
+ .wm-colorpicker-popup.wm-colorpicker-popup-direction-down::before {
542
+ content: '';
543
+ position: absolute;
544
+ left: 8px;
545
+ width: 0;
546
+ height: 0;
547
+ border-style: solid;
548
+ z-index: 999999;
549
+ top: -10px;
550
+ border-width: 0 5px 10px 5px;
551
+ border-color: transparent transparent #777 transparent;
552
+ }
553
+
554
+ .wm-app .wm-colorpicker-popup.wm-colorpicker-popup-direction-up::before,
555
+ .wm-colorpicker-popup.wm-colorpicker-popup-direction-up::before {
556
+ content: '';
557
+ position: absolute;
558
+ left: 8px;
559
+ width: 0;
560
+ height: 0;
561
+ border-style: solid;
562
+ z-index: 999999;
563
+ bottom: -10px;
564
+ border-width: 10px 5px 0 5px;
565
+ border-color: #777 transparent transparent transparent;
566
+ }
567
+
568
+ .wm-app .wm-colorpicker-popup .chrome-picker,
569
+ .wm-colorpicker-popup .chrome-picker {
570
+ box-shadow:
571
+ 0 2px 15px rgba(0, 0, 0, 0.12),
572
+ 0 2px 10px rgba(0, 0, 0, 0.16) !important;
573
+ height: auto;
574
+ border: #777 solid 1px;
575
+ cursor: default;
576
+ user-select: none;
577
+ background-color: #fff !important;
578
+ border-radius: 4px;
579
+ padding: 8px;
580
+ width: 226px !important;
581
+ box-sizing: border-box !important;
582
+ }
583
+
584
+ .wm-app .wm-colorpicker-swatch,
585
+ .wm-colorpicker-swatch {
586
+ background-color: var(--colorpicker-swatch-bg, transparent);
587
+ }
588
+
589
+ /* WmCheckboxset: former inline/sx styles */
590
+ .wm-checkboxset-item-reset {
591
+ all: unset;
592
+ }
593
+
594
+ .wm-app .wm-checkboxset-input-readonly,
595
+ .wm-checkboxset-input-readonly {
596
+ background: transparent !important;
597
+ }
598
+
599
+ .wm-app .wm-checkboxset-label-row {
600
+ margin-bottom: 1px;
601
+ }
602
+
603
+ .wm-app .wm-checkboxset-required-mark,
604
+ .wm-checkboxset-required-mark {
605
+ color: red;
606
+ }
607
+
608
+ .wm-app .wm-checkboxset-group-list {
609
+ padding-left: 2px;
610
+ }
611
+
612
+ /* WmRadioset: former styled(List) static + collapsible/disabled + list width */
613
+ .wm-radioset-styled-list {
614
+ list-style-type: none;
615
+ padding: 0;
616
+ margin: 0;
617
+ width: var(--radioset-list-width, 100%);
618
+ }
619
+
620
+ .wm-radioset-styled-list.wm-radioset-list-collapsible
621
+ li.app-list-item-group
622
+ ul.item-group {
623
+ padding: 0;
624
+ display: none;
625
+ }
626
+
627
+ .wm-radioset-styled-list.wm-radioset-list-collapsible
628
+ li.app-list-item-group
629
+ ul.collapse-open {
630
+ display: block;
631
+ }
632
+
633
+ .wm-radioset-styled-list.wm-radioset-list-disabled {
634
+ opacity: 0.5;
635
+ user-select: none;
636
+ }
637
+
638
+ /* WmSwitch: former root / btn-group inline layout */
639
+ .wm-app .app-switch.wm-switch-root {
640
+ overflow: auto;
641
+ }
642
+
643
+ .wm-app .app-switch .wm-switch-inner {
644
+ overflow: visible;
645
+ position: relative;
646
+ }
647
+
648
+ /* WmFileUpload */
649
+ .wm-app .app-fileupload.wm-fileupload-root {
650
+ width: 100%;
651
+ }
652
+
653
+ .wm-app input.file-input.wm-fileupload-file-input {
654
+ display: none;
655
+ }
656
+
657
+ .wm-app .file-list-container.wm-fileupload-file-list-container {
658
+ overflow: auto;
659
+ max-height: var(--fileupload-list-max-height) px;
660
+ }
661
+
662
+ .wm-fileupload-media-full-width {
663
+ width: 100%;
664
+ }
665
+
666
+ /* WmNumber: former TextField static sx; dynamic props.styles on sx + htmlInput (type=text) */
667
+ .wm-number-textfield {
668
+ width: 100%;
669
+ }
670
+
671
+ .wm-number-textfield.wm-number-textfield-disabled .wm-number-slot-input {
672
+ -webkit-text-fill-color: inherit;
673
+ }
674
+
675
+ .wm-number-helper-text {
676
+ margin-left: 0;
677
+ }
678
+
679
+ .wm-number-helper-text.wm-number-helper-text-error {
680
+ color: #ee5f5b;
681
+ }
682
+
683
+ /* WmRating only: single-class hooks (not the default pattern for other widgets — see wm-csp-widget-styles Rule 6) */
684
+ .wm-rating-star {
685
+ transition: all 0.2s ease-in-out;
686
+ font-size: var(--wm-rating-star-font-size, inherit);
687
+ color: var(--wm-rating-star-color, #ccc);
688
+ border: 1px solid var(--wm-rating-star-border-color, transparent);
689
+ }
690
+
691
+ .wm-rating-star-icon {
692
+ color: inherit;
693
+ }
694
+
695
+ .wm-rating-star.wm-rating-star-readonly {
696
+ opacity: 0.5;
697
+ pointer-events: none;
698
+ }
699
+
700
+ /* WmSelect inline styles */
701
+ .wm-app .app-select optgroup {
702
+ background-color: rgba(0, 0, 0, 0.1);
703
+ }
704
+
705
+ /* WmSlider inline styles */
706
+ .wm-app .app-slider.slider .slider-container .slider-control.wm-slider-control {
707
+ --end: var(--wm-slider-end);
708
+ }
709
+
710
+ .wm-app
711
+ .app-slider.slider
712
+ .marker-container
713
+ .marker-wrapper.wm-slider-marker-wrapper {
714
+ left: var(--wm-slider-marker-left);
715
+ }
716
+
717
+ /* WmText: former TextField static sx (kept low-specificity like sx output) */
718
+ .wm-text-input:disabled {
719
+ -webkit-text-fill-color: inherit;
720
+ }
721
+
722
+ .wm-text-helper-text {
723
+ margin-left: 0;
724
+ }
725
+
726
+ .wm-text-helper-text.wm-text-helper-text-error {
727
+ color: #ee5f5b;
728
+ }
729
+
730
+ /* WmTextarea: former TextField static sx */
731
+ .wm-textarea-root {
732
+ width: 100%;
733
+ }
734
+
735
+ .wm-textarea-input {
736
+ height: var(--wm-textarea-height, auto) !important;
737
+ }
738
+
739
+ /* WmUpload inline styles */
740
+ .wm-upload-existing-image {
741
+ height: 2em;
742
+ }
743
+
744
+ /* WmTime: former TimePicker popper sx */
745
+ .wm-timepicker-popper .MuiPaper-root {
746
+ background: var(--wm-timepicker-background);
747
+ padding: var(--wm-timepicker-padding);
748
+ border-radius: var(--wm-timepicker-border-radius);
749
+ width: auto;
750
+ box-shadow: none;
751
+ }
752
+
753
+ .wm-timepicker-popper .Mui-selected,
754
+ .wm-timepicker-popper .Mui-selected:hover {
755
+ background-color: var(--wm-btn-secondary-background) !important;
756
+ color: var(--wm-btn-secondary-color) !important;
757
+ }
758
+
759
+ /* WmDate DatePickerPopover — chained hooks for popover/calendar (dynamic width via --wm-datepicker-calendar-width on root) */
760
+ .wm-datepicker-popover .MuiPopover-paper {
761
+ box-shadow:
762
+ 0px 3px 3px -2px rgba(0, 0, 0, 0.2),
763
+ 0px 3px 4px 0px rgba(0, 0, 0, 0.14),
764
+ 0px 1px 8px 0px rgba(0, 0, 0, 0.12);
765
+ border-radius: 4px;
766
+ }
767
+
768
+ .wm-app .app-date.wm-datepicker-popover .MuiDateCalendar-root {
769
+ width: var(--wm-datepicker-calendar-width);
770
+ }
771
+
772
+ .wm-app .app-date.wm-datepicker-popover .wm-datepicker-popover-paper {
773
+ width: auto;
774
+ padding-bottom: 2px;
775
+ background: var(--wm-datepicker-background);
776
+ }
777
+
778
+ .wm-app .app-date.wm-datepicker-popover .wm-datepicker-button-bar {
779
+ display: flex;
780
+ justify-content: space-between;
781
+ padding-left: 2px;
782
+ padding-right: 2px;
783
+ margin-top: 1px;
784
+ }
785
+
786
+ .wm-app .app-date.wm-datepicker-popover .wm-datepicker-bar-btn {
787
+ --wm-btn-color: var(--wm-color-primary);
788
+ --wm-btn-state-layer-color: var(--wm-color-primary);
789
+ background: none;
790
+ border: none;
791
+ }
792
+
793
+ /* WmDateTime — former styled.ts (single-class roots; calendar width stays sx on popper) */
794
+ .wm-datetime-html-input {
795
+ box-sizing: inherit !important;
796
+ }
797
+
798
+ .wm-datetime-picker-textfield-hidden {
799
+ display: none !important;
800
+ }
801
+
802
+ .wm-datetime-input-label {
803
+ background-color: white;
804
+ }
805
+
806
+ .wm-datetime-input-label.MuiInputLabel-shrink {
807
+ transform: translate(14px, -9px) scale(0.75);
808
+ transition: transform 200ms cubic-bezier(0, 0, 0.2, 1) 0ms;
809
+ }
810
+
811
+ .wm-datetime-input-label:not(.MuiInputLabel-shrink) {
812
+ transform: translate(14px, 16px) scale(1);
813
+ transition: transform 200ms cubic-bezier(0, 0, 0.2, 1) 0ms;
814
+ }
815
+
816
+ .wm-datetime-date-picker-popper .MuiPaper-root {
817
+ background: var(--wm-datepicker-background);
818
+ padding: var(--wm-datepicker-padding);
819
+ border-radius: var(--wm-datepicker-border-radius);
820
+ }
821
+
822
+ .wm-datetime-date-picker-popper .MuiDateCalendar-root {
823
+ width: var(--wm-datetime-calendar-width, 370px);
824
+ }
825
+
826
+ .wm-datetime-date-picker-popper .MuiDayCalendar-header {
827
+ justify-content: space-evenly;
828
+ }
829
+
830
+ .wm-datetime-date-picker-popper .MuiDayCalendar-weekNumber {
831
+ margin-top: 10px;
832
+ text-align: center;
833
+ }
834
+
835
+ .wm-datetime-date-picker-popper .MuiDayCalendar-slideTransition {
836
+ min-height: 260px;
837
+ }
838
+
839
+ .wm-datetime-date-picker-popper .MuiDayCalendar-weekNumberLabel {
840
+ width: 32px !important;
841
+ padding: 0 !important;
842
+ }
843
+
844
+ .wm-datetime-date-picker-popper .MuiTypography-caption {
845
+ padding: 0 24px;
846
+ }
847
+
848
+ .wm-datetime-date-picker-popper .MuiYearCalendar-root {
849
+ width: auto;
850
+ }
851
+
852
+ .wm-datetime-date-picker-popper .MuiPickersDay-root.Mui-selected {
853
+ background-color: var(--wm-btn-secondary-background) !important;
854
+ color: var(--wm-btn-secondary-color);
855
+ font-weight: bold;
856
+ }
857
+
858
+ .wm-datetime-date-picker-popper .MuiMonthCalendar-button.Mui-selected {
859
+ background-color: var(--wm-btn-secondary-background) !important;
860
+ color: var(--wm-btn-secondary-color);
861
+ font-weight: bold;
862
+ }
863
+
864
+ .wm-datetime-date-picker-popper .MuiPickersDay-root.Mui-selected:hover {
865
+ background-color: var(--wm-btn-secondary-background);
866
+ color: var(--wm-btn-secondary-color);
867
+ }
868
+
869
+ .wm-datetime-date-picker-popper .MuiYearCalendar-button.Mui-selected {
870
+ background-color: var(--wm-btn-secondary-background) !important;
871
+ color: var(--wm-btn-secondary-color);
872
+ font-weight: bold;
873
+ }
874
+
875
+ .wm-datetime-date-picker-popper .MuiPickersDay-today {
876
+ background-color: transparent !important;
877
+ }
878
+
879
+ .wm-datetime-time-picker-popper .MuiPickersLayout-root {
880
+ display: inline-block;
881
+ }
882
+
883
+ .wm-datetime-time-picker-popper .MuiPaper-root {
884
+ background: var(--wm-timepicker-background);
885
+ padding: var(--wm-timepicker-padding);
886
+ border-radius: var(--wm-timepicker-border-radius);
887
+ }
888
+
889
+ .wm-datetime-time-picker-popper .Mui-selected,
890
+ .wm-datetime-time-picker-popper .Mui-selected:hover {
891
+ background-color: var(--wm-btn-secondary-background) !important;
892
+ color: var(--wm-btn-secondary-color) !important;
893
+ }
894
+
895
+ .wm-datetime-datepicker-action-bar .MuiButton-root {
896
+ --wm-btn-color: var(--wm-color-primary);
897
+ --wm-btn-state-layer-color: var(--wm-color-primary);
898
+ background: none;
899
+ border: none;
900
+ }
901
+
902
+ /* WmAccordionPane — former inline flex on title row (styles/static extraction → scoped chain; not sx) */
903
+ .wm-app .app-accordion-panel.panel .wm-accordion-pane-title-main {
904
+ flex: 1;
905
+ }
906
+
907
+ /* --------------------------------------------------------------------------
908
+ Layout grid — root min-width (static; designer styles still merge via inline)
909
+ -------------------------------------------------------------------------- */
910
+
911
+ .wm-app .app-grid-layout.clearfix.wm-layout-grid-root {
912
+ min-width: 100%;
913
+ }
914
+
915
+ /* --------------------------------------------------------------------------
916
+ Panel — header image icon (defaults; optional --wm-panel-icon-* from runtime)
917
+ -------------------------------------------------------------------------- */
918
+
919
+ .wm-app .app-panel.panel .wm-panel-header-icon-img {
920
+ width: var(--wm-panel-icon-width);
921
+ height: var(--wm-panel-icon-height);
922
+ margin: var(--wm-panel-icon-margin);
923
+ }
924
+
925
+ /* --------------------------------------------------------------------------
926
+ Tabs + TabPane — extracted from inline styles (static + state classes)
927
+ -------------------------------------------------------------------------- */
928
+
929
+ .wm-app .app-tabs.clearfix .wm-tabs-heading {
930
+ cursor: pointer;
931
+ gap: var(--wm-anchor-gap);
932
+ }
933
+
934
+ .wm-app .app-tabs.clearfix .wm-tabs-heading.wm-tabs-heading-disabled {
935
+ cursor: not-allowed;
936
+ }
937
+
938
+ .wm-app
939
+ .app-tabs.clearfix
940
+ .tab-content.wm-tabs-content.wm-tabs-content-vertical {
941
+ flex: 1;
942
+ min-width: 0;
943
+ }
944
+
945
+ .wm-app .app-tabs.clearfix .tab-pane.wm-tab-pane-root {
946
+ width: 100%;
947
+ }
948
+
949
+ .wm-app .app-tabs.clearfix .tab-pane.wm-tab-pane-root.wm-tab-pane-active {
950
+ display: block;
951
+ }
952
+
953
+ .wm-app .app-tabs.clearfix .tab-pane.wm-tab-pane-root.wm-tab-pane-inactive {
954
+ display: none;
955
+ }
956
+
957
+ /* --------------------------------------------------------------------------
958
+ App-Spinner — root for list (defaults; optional --wm-spinner-* from runtime)
959
+ -------------------------------------------------------------------------- */
960
+
961
+ .wm-app .app-spinner.wm-spinner-root {
962
+ z-index: 100;
963
+ }
964
+
965
+ /* --------------------------------------------------------------------------
966
+ WmCard — static presentation (dynamic: Card width/height; CardMedia maxHeight)
967
+ -------------------------------------------------------------------------- */
968
+
969
+ .wm-app .app-card.card .app-card-avatar .wm-card-avatar-img {
970
+ border-radius: 50%;
971
+ }
972
+
973
+ .wm-app .app-card.card .app-card-image.wm-card-media-root {
974
+ padding: 0;
975
+ margin: 0;
976
+ background-color: transparent;
977
+ }
978
+
979
+ .wm-app
980
+ .app-card.card
981
+ .app-card-image.wm-card-media-root
982
+ .card-image.wm-card-media-img {
983
+ width: 100%;
984
+ height: 100%;
985
+ }
986
+
987
+ .wm-app .app-card-content.wm-card-content-root {
988
+ padding: 0;
989
+ margin: 0;
990
+ background-color: transparent;
991
+ }
992
+
993
+ .wm-app .app-card-content.wm-card-content-root:last-child {
994
+ padding-bottom: 0;
995
+ }
996
+
997
+ /* * --------------------------------------------------------------------------
998
+ WmCard — static presentation (dynamic: Card width/height; CardMedia maxHeight)
999
+ -------------------------------------------------------------------------- */
1000
+
1001
+ .wm-app .app-card.card .app-card-avatar .wm-card-avatar-img {
1002
+ border-radius: 50%;
1003
+ }
1004
+
1005
+ .wm-app .app-card.card .app-card-image.wm-card-media-root {
1006
+ padding: 0;
1007
+ margin: 0;
1008
+ background-color: transparent;
1009
+ }
1010
+
1011
+ .wm-app
1012
+ .app-card.card
1013
+ .app-card-image.wm-card-media-root
1014
+ .card-image.wm-card-media-img {
1015
+ width: 100%;
1016
+ height: 100%;
1017
+ }
1018
+
1019
+ .wm-app .app-card-content.wm-card-content-root {
1020
+ padding: 0;
1021
+ margin: 0;
1022
+ background-color: transparent;
1023
+ }
1024
+
1025
+ .wm-app .app-card-content.wm-card-content-root:last-child {
1026
+ padding-bottom: 0;
1027
+ }