@jsonforms/material-renderers 3.0.0-alpha.0 → 3.0.0-beta.0

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 (514) hide show
  1. package/README.md +1 -1
  2. package/docs/assets/js/search.json +1 -1
  3. package/docs/classes/combinatorproperties.html +2 -5
  4. package/docs/classes/materialanyofstringorenumcontrol.html +6 -9
  5. package/docs/classes/materialtablecontrol.html +4 -7
  6. package/docs/globals.html +1014 -483
  7. package/docs/index.html +77 -68
  8. package/docs/interfaces/ajvprops.html +1 -4
  9. package/docs/interfaces/arraylayouttoolbarprops.html +5 -8
  10. package/docs/interfaces/categorizationstate.html +1 -4
  11. package/docs/interfaces/categorizationstepperstate.html +0 -3
  12. package/docs/interfaces/combinatorpropertiesprops.html +0 -3
  13. package/docs/interfaces/deletedialogprops.html +0 -3
  14. package/docs/interfaces/dispatchpropsofexpandpanel.html +3 -6
  15. package/docs/interfaces/emptytableprops.html +0 -3
  16. package/docs/interfaces/expandpanelprops.html +19 -22
  17. package/docs/interfaces/jsonformstheme.html +39 -49
  18. package/docs/interfaces/materialcategorizationlayoutrendererprops.html +11 -14
  19. package/docs/interfaces/materialcategorizationstepperlayoutrendererprops.html +7 -10
  20. package/docs/interfaces/materiallayoutrendererprops.html +0 -3
  21. package/docs/interfaces/materialtabletoolbarprops.html +10 -13
  22. package/docs/interfaces/muitextinputprops.html +2 -5
  23. package/docs/interfaces/nonemptycellcomponentprops.html +266 -0
  24. package/docs/interfaces/nonemptycellprops.html +0 -3
  25. package/docs/interfaces/nonemptyrowprops.html +80 -27
  26. package/docs/interfaces/ownoneofprops.html +0 -3
  27. package/docs/interfaces/ownpropsofexpandpanel.html +14 -17
  28. package/docs/interfaces/ownpropsofnonemptycell.html +0 -3
  29. package/docs/interfaces/statepropsofexpandpanel.html +16 -19
  30. package/docs/interfaces/tableheadercellprops.html +0 -3
  31. package/docs/interfaces/tablerowsprop.html +9 -12
  32. package/docs/interfaces/validationprops.html +2 -5
  33. package/docs/interfaces/withdeletedialogsupport.html +0 -3
  34. package/docs/interfaces/withinput.html +1 -4
  35. package/docs/interfaces/withoptionlabel.html +7 -7
  36. package/example/index.ts +7 -23
  37. package/lib/additional/ListWithDetailMasterItem.d.ts +3 -3
  38. package/lib/additional/MaterialLabelRenderer.d.ts +13 -13
  39. package/lib/additional/MaterialListWithDetailRenderer.d.ts +6 -6
  40. package/lib/additional/index.d.ts +4 -4
  41. package/lib/cells/CustomizableCells.d.ts +9 -9
  42. package/lib/cells/MaterialBooleanCell.d.ts +6 -6
  43. package/lib/cells/MaterialBooleanToggleCell.d.ts +6 -6
  44. package/lib/cells/MaterialDateCell.d.ts +6 -6
  45. package/lib/cells/MaterialEnumCell.d.ts +10 -10
  46. package/lib/cells/MaterialIntegerCell.d.ts +6 -6
  47. package/lib/cells/MaterialNumberCell.d.ts +10 -10
  48. package/lib/cells/MaterialNumberFormatCell.d.ts +10 -10
  49. package/lib/cells/MaterialOneOfEnumCell.d.ts +10 -10
  50. package/lib/cells/MaterialTextCell.d.ts +10 -10
  51. package/lib/cells/MaterialTimeCell.d.ts +6 -6
  52. package/lib/cells/index.d.ts +13 -13
  53. package/lib/complex/CombinatorProperties.d.ts +12 -12
  54. package/lib/complex/DeleteDialog.d.ts +11 -11
  55. package/lib/complex/MaterialAllOfRenderer.d.ts +6 -5
  56. package/lib/complex/MaterialAnyOfRenderer.d.ts +6 -5
  57. package/lib/complex/MaterialArrayControlRenderer.d.ts +5 -5
  58. package/lib/complex/MaterialEnumArrayRenderer.d.ts +6 -6
  59. package/lib/complex/MaterialObjectRenderer.d.ts +6 -5
  60. package/lib/complex/MaterialOneOfRenderer.d.ts +9 -8
  61. package/lib/complex/MaterialTableControl.d.ts +25 -10
  62. package/lib/complex/NoBorderTableCell.d.ts +3 -3
  63. package/lib/complex/TableToolbar.d.ts +15 -15
  64. package/lib/complex/ValidationIcon.d.ts +7 -11
  65. package/lib/complex/index.d.ts +19 -19
  66. package/lib/controls/MaterialAnyOfStringOrEnumControl.d.ts +9 -9
  67. package/lib/controls/MaterialBooleanControl.d.ts +6 -6
  68. package/lib/controls/MaterialBooleanToggleControl.d.ts +6 -6
  69. package/lib/controls/MaterialDateControl.d.ts +6 -18
  70. package/lib/controls/MaterialDateTimeControl.d.ts +6 -9
  71. package/lib/controls/MaterialEnumControl.d.ts +7 -6
  72. package/lib/controls/MaterialInputControl.d.ts +6 -9
  73. package/lib/controls/MaterialIntegerControl.d.ts +6 -6
  74. package/lib/controls/MaterialNativeControl.d.ts +6 -9
  75. package/lib/controls/MaterialNumberControl.d.ts +6 -6
  76. package/lib/controls/MaterialOneOfEnumControl.d.ts +7 -6
  77. package/lib/controls/MaterialOneOfRadioGroupControl.d.ts +6 -6
  78. package/lib/controls/MaterialRadioGroup.d.ts +3 -6
  79. package/lib/controls/MaterialRadioGroupControl.d.ts +6 -6
  80. package/lib/controls/MaterialSliderControl.d.ts +6 -9
  81. package/lib/controls/MaterialTextControl.d.ts +6 -6
  82. package/lib/controls/MaterialTimeControl.d.ts +6 -0
  83. package/lib/controls/index.d.ts +35 -33
  84. package/lib/index.d.ts +9 -9
  85. package/lib/jsonforms-react-material.cjs.js +1489 -0
  86. package/lib/jsonforms-react-material.cjs.js.map +1 -0
  87. package/lib/jsonforms-react-material.esm.js +1221 -0
  88. package/lib/jsonforms-react-material.esm.js.map +1 -0
  89. package/lib/layouts/ArrayToolbar.d.ts +9 -9
  90. package/lib/layouts/ExpandPanelRenderer.d.ts +51 -52
  91. package/lib/layouts/MaterialArrayLayout.d.ts +3 -13
  92. package/lib/layouts/MaterialArrayLayoutRenderer.d.ts +6 -6
  93. package/lib/layouts/MaterialCategorizationLayout.d.ts +17 -25
  94. package/lib/layouts/MaterialCategorizationStepperLayout.d.ts +13 -20
  95. package/lib/layouts/MaterialGroupLayout.d.ts +7 -7
  96. package/lib/layouts/MaterialHorizontalLayout.d.ts +10 -10
  97. package/lib/layouts/MaterialVerticalLayout.d.ts +10 -10
  98. package/lib/layouts/index.d.ts +6 -6
  99. package/lib/mui-controls/MuiAutocomplete.d.ts +9 -0
  100. package/lib/mui-controls/MuiCheckbox.d.ts +3 -3
  101. package/lib/mui-controls/MuiInputInteger.d.ts +3 -3
  102. package/lib/mui-controls/MuiInputNumber.d.ts +3 -3
  103. package/lib/mui-controls/MuiInputNumberFormat.d.ts +3 -3
  104. package/lib/mui-controls/MuiInputText.d.ts +9 -9
  105. package/lib/mui-controls/MuiInputTime.d.ts +3 -3
  106. package/lib/mui-controls/MuiSelect.d.ts +3 -3
  107. package/lib/mui-controls/MuiToggle.d.ts +3 -3
  108. package/lib/mui-controls/index.d.ts +7 -7
  109. package/lib/util/datejs.d.ts +3 -0
  110. package/lib/util/debounce.d.ts +1 -0
  111. package/lib/util/focus.d.ts +1 -0
  112. package/lib/util/index.d.ts +5 -2
  113. package/lib/util/layout.d.ts +15 -13
  114. package/lib/util/theme.d.ts +10 -10
  115. package/package.json +36 -31
  116. package/rollup.config.js +51 -0
  117. package/src/additional/ListWithDetailMasterItem.tsx +3 -6
  118. package/src/additional/MaterialLabelRenderer.tsx +1 -1
  119. package/src/additional/MaterialListWithDetailRenderer.tsx +2 -3
  120. package/src/cells/MaterialDateCell.tsx +1 -1
  121. package/src/cells/MaterialTimeCell.tsx +1 -0
  122. package/src/complex/CombinatorProperties.tsx +2 -2
  123. package/src/complex/DeleteDialog.tsx +2 -2
  124. package/src/complex/MaterialAllOfRenderer.tsx +3 -2
  125. package/src/complex/MaterialAnyOfRenderer.tsx +3 -2
  126. package/src/complex/MaterialArrayControlRenderer.tsx +1 -1
  127. package/src/complex/MaterialEnumArrayRenderer.tsx +4 -3
  128. package/src/complex/MaterialObjectRenderer.tsx +4 -4
  129. package/src/complex/MaterialOneOfRenderer.tsx +7 -7
  130. package/src/complex/MaterialTableControl.tsx +45 -37
  131. package/src/complex/NoBorderTableCell.tsx +10 -12
  132. package/src/complex/TableToolbar.tsx +10 -9
  133. package/src/complex/ValidationIcon.tsx +12 -19
  134. package/src/controls/MaterialAnyOfStringOrEnumControl.tsx +17 -14
  135. package/src/controls/MaterialBooleanControl.tsx +1 -1
  136. package/src/controls/MaterialBooleanToggleControl.tsx +1 -1
  137. package/src/controls/MaterialDateControl.tsx +87 -119
  138. package/src/controls/MaterialDateTimeControl.tsx +91 -78
  139. package/src/controls/MaterialEnumControl.tsx +12 -3
  140. package/src/controls/MaterialInputControl.tsx +65 -72
  141. package/src/controls/MaterialNativeControl.tsx +55 -60
  142. package/src/controls/MaterialOneOfEnumControl.tsx +13 -4
  143. package/src/controls/MaterialOneOfRadioGroupControl.tsx +4 -4
  144. package/src/controls/MaterialRadioGroup.tsx +73 -74
  145. package/src/controls/MaterialRadioGroupControl.tsx +1 -1
  146. package/src/controls/MaterialSliderControl.tsx +93 -89
  147. package/src/controls/MaterialTimeControl.tsx +133 -0
  148. package/src/controls/index.ts +7 -0
  149. package/src/index.ts +3 -0
  150. package/src/layouts/ArrayToolbar.tsx +11 -7
  151. package/src/layouts/ExpandPanelRenderer.tsx +44 -42
  152. package/src/layouts/MaterialArrayLayout.tsx +73 -83
  153. package/src/layouts/MaterialArrayLayoutRenderer.tsx +1 -1
  154. package/src/layouts/MaterialCategorizationLayout.tsx +50 -67
  155. package/src/layouts/MaterialCategorizationStepperLayout.tsx +80 -88
  156. package/src/layouts/MaterialGroupLayout.tsx +1 -1
  157. package/src/{extended → mui-controls}/MuiAutocomplete.tsx +11 -9
  158. package/src/mui-controls/MuiCheckbox.tsx +2 -3
  159. package/src/mui-controls/MuiInputInteger.tsx +13 -10
  160. package/src/mui-controls/MuiInputNumber.tsx +10 -7
  161. package/src/mui-controls/MuiInputNumberFormat.tsx +9 -12
  162. package/src/mui-controls/MuiInputText.tsx +30 -21
  163. package/src/mui-controls/MuiInputTime.tsx +7 -5
  164. package/src/mui-controls/MuiSelect.tsx +4 -5
  165. package/src/mui-controls/MuiToggle.tsx +2 -3
  166. package/src/util/datejs.ts +32 -0
  167. package/{lib/cells/MaterialNumberCell.js → src/util/debounce.ts} +20 -16
  168. package/{lib/util/index.js → src/util/focus.ts} +9 -6
  169. package/src/util/index.ts +3 -0
  170. package/src/util/layout.tsx +7 -8
  171. package/src/util/theme.ts +1 -1
  172. package/stats.html +3279 -0
  173. package/test/renderers/MaterialAllOfRenderer.test.tsx +1 -1
  174. package/test/renderers/MaterialAnyOfRenderer.test.tsx +15 -9
  175. package/test/renderers/MaterialAnyOfStringOrEnumControl.test.tsx +1 -1
  176. package/test/renderers/MaterialArrayControl.test.tsx +1 -1
  177. package/test/renderers/MaterialArrayLayout.test.tsx +9 -9
  178. package/test/renderers/MaterialBooleanCell.test.tsx +1 -1
  179. package/test/renderers/MaterialBooleanToggleCell.test.tsx +3 -2
  180. package/test/renderers/MaterialBooleanToggleControl.test.tsx +3 -2
  181. package/test/renderers/MaterialCategorizationLayout.test.tsx +76 -3
  182. package/test/renderers/MaterialCategorizationStepperLayout.test.tsx +79 -6
  183. package/test/renderers/MaterialDateCell.test.tsx +1 -1
  184. package/test/renderers/MaterialDateControl.test.tsx +46 -2
  185. package/test/renderers/MaterialDateTimeControl.test.tsx +57 -12
  186. package/test/renderers/MaterialEnumArrayRenderer.test.tsx +1 -1
  187. package/test/renderers/MaterialEnumCell.test.tsx +1 -1
  188. package/test/renderers/MaterialGroupLayout.test.tsx +1 -1
  189. package/test/renderers/MaterialInputControl.test.tsx +4 -4
  190. package/test/renderers/MaterialIntegerCell.test.tsx +42 -21
  191. package/test/renderers/MaterialLabelRenderer.test.tsx +1 -1
  192. package/test/renderers/MaterialLayouts.test.tsx +1 -1
  193. package/test/renderers/MaterialListWithDetailRenderer.test.tsx +2 -2
  194. package/test/renderers/MaterialNativeControl.test.tsx +2 -2
  195. package/test/renderers/MaterialNumberCell.test.tsx +46 -25
  196. package/test/renderers/MaterialObjectControl.test.tsx +1 -1
  197. package/test/renderers/MaterialOneOfEnumCell.test.tsx +1 -1
  198. package/test/renderers/MaterialOneOfRadioGroupControl.test.tsx +1 -1
  199. package/test/renderers/MaterialOneOfRenderer.test.tsx +17 -11
  200. package/test/renderers/MaterialRadioGroupControl.test.tsx +1 -1
  201. package/test/renderers/MaterialSliderControl.test.tsx +2 -2
  202. package/test/renderers/MaterialTextCell.test.tsx +47 -33
  203. package/test/renderers/MaterialTextControl.test.tsx +8 -4
  204. package/test/renderers/MaterialTimeCell.test.tsx +42 -21
  205. package/test/renderers/MaterialTimeControl.test.tsx +380 -0
  206. package/tsconfig.json +1 -2
  207. package/tsconfig.test.json +7 -0
  208. package/docs/classes/materialarraylayout.html +0 -777
  209. package/docs/classes/materialcategorizationlayoutrenderer.html +0 -786
  210. package/docs/classes/materialcategorizationstepperlayoutrenderer.html +0 -762
  211. package/docs/classes/materialdatecontrol.html +0 -825
  212. package/docs/classes/materialdatetimecontrol.html +0 -825
  213. package/docs/classes/materialinputcontrol.html +0 -825
  214. package/docs/classes/materialnativecontrol.html +0 -825
  215. package/docs/classes/materialradiogroup.html +0 -825
  216. package/docs/classes/materialslidercontrol.html +0 -825
  217. package/docs/interfaces/datecontrol.html +0 -157
  218. package/docs/interfaces/materialarraylayoutstate.html +0 -157
  219. package/docs/interfaces/statepropsofdatecontrol.html +0 -468
  220. package/example/CustomAutocomplete.tsx +0 -54
  221. package/lib/additional/ListWithDetailMasterItem.js +0 -19
  222. package/lib/additional/ListWithDetailMasterItem.js.map +0 -1
  223. package/lib/additional/MaterialLabelRenderer.js +0 -47
  224. package/lib/additional/MaterialLabelRenderer.js.map +0 -1
  225. package/lib/additional/MaterialListWithDetailRenderer.js +0 -64
  226. package/lib/additional/MaterialListWithDetailRenderer.js.map +0 -1
  227. package/lib/additional/index.js +0 -34
  228. package/lib/additional/index.js.map +0 -1
  229. package/lib/bundle.js +0 -191792
  230. package/lib/bundle.js.map +0 -1
  231. package/lib/cells/CustomizableCells.js +0 -45
  232. package/lib/cells/CustomizableCells.js.map +0 -1
  233. package/lib/cells/MaterialBooleanCell.js +0 -37
  234. package/lib/cells/MaterialBooleanCell.js.map +0 -1
  235. package/lib/cells/MaterialBooleanToggleCell.js +0 -38
  236. package/lib/cells/MaterialBooleanToggleCell.js.map +0 -1
  237. package/lib/cells/MaterialDateCell.js +0 -40
  238. package/lib/cells/MaterialDateCell.js.map +0 -1
  239. package/lib/cells/MaterialEnumCell.js +0 -39
  240. package/lib/cells/MaterialEnumCell.js.map +0 -1
  241. package/lib/cells/MaterialIntegerCell.js +0 -35
  242. package/lib/cells/MaterialIntegerCell.js.map +0 -1
  243. package/lib/cells/MaterialNumberCell.js.map +0 -1
  244. package/lib/cells/MaterialNumberFormatCell.js +0 -39
  245. package/lib/cells/MaterialNumberFormatCell.js.map +0 -1
  246. package/lib/cells/MaterialOneOfEnumCell.js +0 -39
  247. package/lib/cells/MaterialOneOfEnumCell.js.map +0 -1
  248. package/lib/cells/MaterialTextCell.js +0 -39
  249. package/lib/cells/MaterialTextCell.js.map +0 -1
  250. package/lib/cells/MaterialTimeCell.js +0 -35
  251. package/lib/cells/MaterialTimeCell.js.map +0 -1
  252. package/lib/cells/index.js +0 -60
  253. package/lib/cells/index.js.map +0 -1
  254. package/lib/complex/CombinatorProperties.js +0 -57
  255. package/lib/complex/CombinatorProperties.js.map +0 -1
  256. package/lib/complex/DeleteDialog.js +0 -41
  257. package/lib/complex/DeleteDialog.js.map +0 -1
  258. package/lib/complex/MaterialAllOfRenderer.js +0 -45
  259. package/lib/complex/MaterialAllOfRenderer.js.map +0 -1
  260. package/lib/complex/MaterialAnyOfRenderer.js +0 -49
  261. package/lib/complex/MaterialAnyOfRenderer.js.map +0 -1
  262. package/lib/complex/MaterialArrayControlRenderer.js +0 -55
  263. package/lib/complex/MaterialArrayControlRenderer.js.map +0 -1
  264. package/lib/complex/MaterialEnumArrayRenderer.js +0 -45
  265. package/lib/complex/MaterialEnumArrayRenderer.js.map +0 -1
  266. package/lib/complex/MaterialObjectRenderer.js +0 -49
  267. package/lib/complex/MaterialObjectRenderer.js.map +0 -1
  268. package/lib/complex/MaterialOneOfRenderer.js +0 -77
  269. package/lib/complex/MaterialOneOfRenderer.js.map +0 -1
  270. package/lib/complex/MaterialTableControl.js +0 -190
  271. package/lib/complex/MaterialTableControl.js.map +0 -1
  272. package/lib/complex/NoBorderTableCell.js +0 -41
  273. package/lib/complex/NoBorderTableCell.js.map +0 -1
  274. package/lib/complex/TableToolbar.js +0 -58
  275. package/lib/complex/TableToolbar.js.map +0 -1
  276. package/lib/complex/ValidationIcon.js +0 -48
  277. package/lib/complex/ValidationIcon.js.map +0 -1
  278. package/lib/complex/index.js +0 -47
  279. package/lib/complex/index.js.map +0 -1
  280. package/lib/controls/MaterialAnyOfStringOrEnumControl.js +0 -80
  281. package/lib/controls/MaterialAnyOfStringOrEnumControl.js.map +0 -1
  282. package/lib/controls/MaterialBooleanControl.js +0 -41
  283. package/lib/controls/MaterialBooleanControl.js.map +0 -1
  284. package/lib/controls/MaterialBooleanToggleControl.js +0 -41
  285. package/lib/controls/MaterialBooleanToggleControl.js.map +0 -1
  286. package/lib/controls/MaterialDateControl.js +0 -83
  287. package/lib/controls/MaterialDateControl.js.map +0 -1
  288. package/lib/controls/MaterialDateTimeControl.js +0 -64
  289. package/lib/controls/MaterialDateTimeControl.js.map +0 -1
  290. package/lib/controls/MaterialEnumControl.js +0 -36
  291. package/lib/controls/MaterialEnumControl.js.map +0 -1
  292. package/lib/controls/MaterialInputControl.js +0 -61
  293. package/lib/controls/MaterialInputControl.js.map +0 -1
  294. package/lib/controls/MaterialIntegerControl.js +0 -36
  295. package/lib/controls/MaterialIntegerControl.js.map +0 -1
  296. package/lib/controls/MaterialNativeControl.js +0 -54
  297. package/lib/controls/MaterialNativeControl.js.map +0 -1
  298. package/lib/controls/MaterialNumberControl.js +0 -36
  299. package/lib/controls/MaterialNumberControl.js.map +0 -1
  300. package/lib/controls/MaterialOneOfEnumControl.js +0 -36
  301. package/lib/controls/MaterialOneOfEnumControl.js.map +0 -1
  302. package/lib/controls/MaterialOneOfRadioGroupControl.js +0 -37
  303. package/lib/controls/MaterialOneOfRadioGroupControl.js.map +0 -1
  304. package/lib/controls/MaterialRadioGroup.js +0 -55
  305. package/lib/controls/MaterialRadioGroup.js.map +0 -1
  306. package/lib/controls/MaterialRadioGroupControl.js +0 -37
  307. package/lib/controls/MaterialRadioGroupControl.js.map +0 -1
  308. package/lib/controls/MaterialSliderControl.js +0 -74
  309. package/lib/controls/MaterialSliderControl.js.map +0 -1
  310. package/lib/controls/MaterialTextControl.js +0 -36
  311. package/lib/controls/MaterialTextControl.js.map +0 -1
  312. package/lib/controls/index.js +0 -87
  313. package/lib/controls/index.js.map +0 -1
  314. package/lib/example/src/App.d.ts +0 -8
  315. package/lib/example/src/Rating.d.ts +0 -18
  316. package/lib/example/src/RatingControl.d.ts +0 -16
  317. package/lib/example/src/index.d.ts +0 -11
  318. package/lib/example/src/reduxUtil.d.ts +0 -38
  319. package/lib/example/src/util.d.ts +0 -20
  320. package/lib/examples/src/1169.d.ts +0 -24
  321. package/lib/examples/src/1220.d.ts +0 -3
  322. package/lib/examples/src/1253.d.ts +0 -16
  323. package/lib/examples/src/1254.d.ts +0 -21
  324. package/lib/examples/src/allOf.d.ts +0 -56
  325. package/lib/examples/src/anyOf-oneOf-allOf-resolve.d.ts +0 -44
  326. package/lib/examples/src/anyOf.d.ts +0 -64
  327. package/lib/examples/src/arrays-with-custom-element-label.d.ts +0 -43
  328. package/lib/examples/src/arrays-with-detail-and-rule.d.ts +0 -91
  329. package/lib/examples/src/arrays-with-detail.d.ts +0 -65
  330. package/lib/examples/src/arrays.d.ts +0 -38
  331. package/lib/examples/src/booleanToggle.d.ts +0 -62
  332. package/lib/examples/src/categorization.d.ts +0 -135
  333. package/lib/examples/src/config.d.ts +0 -29
  334. package/lib/examples/src/control-options.d.ts +0 -190
  335. package/lib/examples/src/dates.d.ts +0 -1
  336. package/lib/examples/src/day1.d.ts +0 -23
  337. package/lib/examples/src/day2.d.ts +0 -42
  338. package/lib/examples/src/day3.d.ts +0 -51
  339. package/lib/examples/src/day4.d.ts +0 -72
  340. package/lib/examples/src/day5.d.ts +0 -133
  341. package/lib/examples/src/day6.d.ts +0 -85
  342. package/lib/examples/src/default.d.ts +0 -64
  343. package/lib/examples/src/dynamic.d.ts +0 -1
  344. package/lib/examples/src/enum.d.ts +0 -49
  345. package/lib/examples/src/enumInArray.d.ts +0 -27
  346. package/lib/examples/src/example.d.ts +0 -15
  347. package/lib/examples/src/generate.d.ts +0 -12
  348. package/lib/examples/src/generateUI.d.ts +0 -33
  349. package/lib/examples/src/huge.d.ts +0 -1
  350. package/lib/examples/src/i18n.d.ts +0 -25
  351. package/lib/examples/src/if_then_else.d.ts +0 -25
  352. package/lib/examples/src/index.d.ts +0 -56
  353. package/lib/examples/src/layout.d.ts +0 -97
  354. package/lib/examples/src/list-with-detail-registered.d.ts +0 -1
  355. package/lib/examples/src/list-with-detail.d.ts +0 -1
  356. package/lib/examples/src/multi-enum.d.ts +0 -34
  357. package/lib/examples/src/nestedArrays.d.ts +0 -4
  358. package/lib/examples/src/numbers.d.ts +0 -46
  359. package/lib/examples/src/object.d.ts +0 -56
  360. package/lib/examples/src/onChange.d.ts +0 -18
  361. package/lib/examples/src/oneOf-recursive.d.ts +0 -48
  362. package/lib/examples/src/oneOf.d.ts +0 -53
  363. package/lib/examples/src/oneOfArray.d.ts +0 -53
  364. package/lib/examples/src/person.d.ts +0 -99
  365. package/lib/examples/src/radioGroup.d.ts +0 -1
  366. package/lib/examples/src/readonly.d.ts +0 -36
  367. package/lib/examples/src/register.d.ts +0 -3
  368. package/lib/examples/src/resolve.d.ts +0 -45
  369. package/lib/examples/src/rule.d.ts +0 -59
  370. package/lib/examples/src/ruleInheritance.d.ts +0 -26
  371. package/lib/examples/src/scope.d.ts +0 -50
  372. package/lib/examples/src/stepper.d.ts +0 -138
  373. package/lib/examples/src/steppershownav.d.ts +0 -139
  374. package/lib/examples/src/stringArray.d.ts +0 -22
  375. package/lib/examples/src/text.d.ts +0 -37
  376. package/lib/extended/MaterialAutocompleteEnumControl.d.ts +0 -7
  377. package/lib/extended/MaterialAutocompleteEnumControl.js +0 -42
  378. package/lib/extended/MaterialAutocompleteEnumControl.js.map +0 -1
  379. package/lib/extended/MaterialAutocompleteOneOfEnumControl.d.ts +0 -7
  380. package/lib/extended/MaterialAutocompleteOneOfEnumControl.js +0 -42
  381. package/lib/extended/MaterialAutocompleteOneOfEnumControl.js.map +0 -1
  382. package/lib/extended/MuiAutocomplete.d.ts +0 -10
  383. package/lib/extended/MuiAutocomplete.js +0 -45
  384. package/lib/extended/MuiAutocomplete.js.map +0 -1
  385. package/lib/extended/index.d.ts +0 -10
  386. package/lib/extended/index.js +0 -48
  387. package/lib/extended/index.js.map +0 -1
  388. package/lib/index.js +0 -88
  389. package/lib/index.js.map +0 -1
  390. package/lib/jsonforms-material.js +0 -358
  391. package/lib/jsonforms-material.js.map +0 -1
  392. package/lib/layouts/ArrayToolbar.js +0 -27
  393. package/lib/layouts/ArrayToolbar.js.map +0 -1
  394. package/lib/layouts/ExpandPanelRenderer.js +0 -109
  395. package/lib/layouts/ExpandPanelRenderer.js.map +0 -1
  396. package/lib/layouts/MaterialArrayLayout.js +0 -66
  397. package/lib/layouts/MaterialArrayLayout.js.map +0 -1
  398. package/lib/layouts/MaterialArrayLayoutRenderer.js +0 -43
  399. package/lib/layouts/MaterialArrayLayoutRenderer.js.map +0 -1
  400. package/lib/layouts/MaterialCategorizationLayout.js +0 -88
  401. package/lib/layouts/MaterialCategorizationLayout.js.map +0 -1
  402. package/lib/layouts/MaterialCategorizationStepperLayout.js +0 -89
  403. package/lib/layouts/MaterialCategorizationStepperLayout.js.map +0 -1
  404. package/lib/layouts/MaterialGroupLayout.js +0 -52
  405. package/lib/layouts/MaterialGroupLayout.js.map +0 -1
  406. package/lib/layouts/MaterialHorizontalLayout.js +0 -51
  407. package/lib/layouts/MaterialHorizontalLayout.js.map +0 -1
  408. package/lib/layouts/MaterialVerticalLayout.js +0 -51
  409. package/lib/layouts/MaterialVerticalLayout.js.map +0 -1
  410. package/lib/layouts/index.js +0 -43
  411. package/lib/layouts/index.js.map +0 -1
  412. package/lib/logo.svg +0 -7
  413. package/lib/material/example/CustomAutocomplete.d.ts +0 -3
  414. package/lib/material/example/index.d.ts +0 -1
  415. package/lib/material/src/additional/ListWithDetailMasterItem.d.ts +0 -3
  416. package/lib/material/src/additional/MaterialLabelRenderer.d.ts +0 -13
  417. package/lib/material/src/additional/MaterialListWithDetailRenderer.d.ts +0 -6
  418. package/lib/material/src/additional/index.d.ts +0 -4
  419. package/lib/material/src/cells/CustomizableCells.d.ts +0 -9
  420. package/lib/material/src/cells/MaterialBooleanCell.d.ts +0 -6
  421. package/lib/material/src/cells/MaterialBooleanToggleCell.d.ts +0 -6
  422. package/lib/material/src/cells/MaterialDateCell.d.ts +0 -6
  423. package/lib/material/src/cells/MaterialEnumCell.d.ts +0 -10
  424. package/lib/material/src/cells/MaterialIntegerCell.d.ts +0 -6
  425. package/lib/material/src/cells/MaterialNumberCell.d.ts +0 -10
  426. package/lib/material/src/cells/MaterialNumberFormatCell.d.ts +0 -10
  427. package/lib/material/src/cells/MaterialOneOfEnumCell.d.ts +0 -10
  428. package/lib/material/src/cells/MaterialTextCell.d.ts +0 -10
  429. package/lib/material/src/cells/MaterialTimeCell.d.ts +0 -6
  430. package/lib/material/src/cells/index.d.ts +0 -13
  431. package/lib/material/src/complex/CombinatorProperties.d.ts +0 -12
  432. package/lib/material/src/complex/DeleteDialog.d.ts +0 -11
  433. package/lib/material/src/complex/MaterialAllOfRenderer.d.ts +0 -5
  434. package/lib/material/src/complex/MaterialAnyOfRenderer.d.ts +0 -5
  435. package/lib/material/src/complex/MaterialArrayControlRenderer.d.ts +0 -5
  436. package/lib/material/src/complex/MaterialEnumArrayRenderer.d.ts +0 -6
  437. package/lib/material/src/complex/MaterialObjectRenderer.d.ts +0 -5
  438. package/lib/material/src/complex/MaterialOneOfRenderer.d.ts +0 -8
  439. package/lib/material/src/complex/MaterialTableControl.d.ts +0 -10
  440. package/lib/material/src/complex/NoBorderTableCell.d.ts +0 -3
  441. package/lib/material/src/complex/TableToolbar.d.ts +0 -15
  442. package/lib/material/src/complex/ValidationIcon.d.ts +0 -11
  443. package/lib/material/src/complex/index.d.ts +0 -19
  444. package/lib/material/src/controls/MaterialAnyOfStringOrEnumControl.d.ts +0 -9
  445. package/lib/material/src/controls/MaterialBooleanControl.d.ts +0 -6
  446. package/lib/material/src/controls/MaterialBooleanToggleControl.d.ts +0 -6
  447. package/lib/material/src/controls/MaterialDateControl.d.ts +0 -18
  448. package/lib/material/src/controls/MaterialDateTimeControl.d.ts +0 -9
  449. package/lib/material/src/controls/MaterialEnumControl.d.ts +0 -6
  450. package/lib/material/src/controls/MaterialInputControl.d.ts +0 -9
  451. package/lib/material/src/controls/MaterialIntegerControl.d.ts +0 -6
  452. package/lib/material/src/controls/MaterialNativeControl.d.ts +0 -9
  453. package/lib/material/src/controls/MaterialNumberControl.d.ts +0 -6
  454. package/lib/material/src/controls/MaterialOneOfEnumControl.d.ts +0 -6
  455. package/lib/material/src/controls/MaterialOneOfRadioGroupControl.d.ts +0 -6
  456. package/lib/material/src/controls/MaterialRadioGroup.d.ts +0 -6
  457. package/lib/material/src/controls/MaterialRadioGroupControl.d.ts +0 -6
  458. package/lib/material/src/controls/MaterialSliderControl.d.ts +0 -9
  459. package/lib/material/src/controls/MaterialTextControl.d.ts +0 -6
  460. package/lib/material/src/controls/index.d.ts +0 -33
  461. package/lib/material/src/extended/MaterialAutocompleteEnumControl.d.ts +0 -7
  462. package/lib/material/src/extended/MaterialAutocompleteOneOfEnumControl.d.ts +0 -7
  463. package/lib/material/src/extended/MuiAutocomplete.d.ts +0 -10
  464. package/lib/material/src/extended/index.d.ts +0 -10
  465. package/lib/material/src/index.d.ts +0 -9
  466. package/lib/material/src/layouts/ArrayToolbar.d.ts +0 -9
  467. package/lib/material/src/layouts/ExpandPanelRenderer.d.ts +0 -52
  468. package/lib/material/src/layouts/MaterialArrayLayout.d.ts +0 -13
  469. package/lib/material/src/layouts/MaterialArrayLayoutRenderer.d.ts +0 -6
  470. package/lib/material/src/layouts/MaterialCategorizationLayout.d.ts +0 -25
  471. package/lib/material/src/layouts/MaterialCategorizationStepperLayout.d.ts +0 -20
  472. package/lib/material/src/layouts/MaterialGroupLayout.d.ts +0 -7
  473. package/lib/material/src/layouts/MaterialHorizontalLayout.d.ts +0 -10
  474. package/lib/material/src/layouts/MaterialVerticalLayout.d.ts +0 -10
  475. package/lib/material/src/layouts/index.d.ts +0 -6
  476. package/lib/material/src/mui-controls/MuiCheckbox.d.ts +0 -3
  477. package/lib/material/src/mui-controls/MuiInputInteger.d.ts +0 -3
  478. package/lib/material/src/mui-controls/MuiInputNumber.d.ts +0 -3
  479. package/lib/material/src/mui-controls/MuiInputNumberFormat.d.ts +0 -3
  480. package/lib/material/src/mui-controls/MuiInputText.d.ts +0 -9
  481. package/lib/material/src/mui-controls/MuiInputTime.d.ts +0 -3
  482. package/lib/material/src/mui-controls/MuiSelect.d.ts +0 -3
  483. package/lib/material/src/mui-controls/MuiToggle.d.ts +0 -3
  484. package/lib/material/src/mui-controls/index.d.ts +0 -7
  485. package/lib/material/src/util/index.d.ts +0 -2
  486. package/lib/material/src/util/layout.d.ts +0 -13
  487. package/lib/material/src/util/theme.d.ts +0 -10
  488. package/lib/mui-controls/MuiCheckbox.js +0 -40
  489. package/lib/mui-controls/MuiCheckbox.js.map +0 -1
  490. package/lib/mui-controls/MuiInputInteger.js +0 -41
  491. package/lib/mui-controls/MuiInputInteger.js.map +0 -1
  492. package/lib/mui-controls/MuiInputNumber.js +0 -41
  493. package/lib/mui-controls/MuiInputNumber.js.map +0 -1
  494. package/lib/mui-controls/MuiInputNumberFormat.js +0 -50
  495. package/lib/mui-controls/MuiInputNumberFormat.js.map +0 -1
  496. package/lib/mui-controls/MuiInputText.js +0 -64
  497. package/lib/mui-controls/MuiInputText.js.map +0 -1
  498. package/lib/mui-controls/MuiInputTime.js +0 -37
  499. package/lib/mui-controls/MuiInputTime.js.map +0 -1
  500. package/lib/mui-controls/MuiSelect.js +0 -38
  501. package/lib/mui-controls/MuiSelect.js.map +0 -1
  502. package/lib/mui-controls/MuiToggle.js +0 -39
  503. package/lib/mui-controls/MuiToggle.js.map +0 -1
  504. package/lib/mui-controls/index.js +0 -35
  505. package/lib/mui-controls/index.js.map +0 -1
  506. package/lib/util/index.js.map +0 -1
  507. package/lib/util/layout.js +0 -54
  508. package/lib/util/layout.js.map +0 -1
  509. package/lib/util/theme.js +0 -3
  510. package/lib/util/theme.js.map +0 -1
  511. package/src/extended/MaterialAutocompleteEnumControl.tsx +0 -55
  512. package/src/extended/MaterialAutocompleteOneOfEnumControl.tsx +0 -55
  513. package/src/extended/index.ts +0 -56
  514. package/webpack/webpack.build.js +0 -21
@@ -23,100 +23,90 @@
23
23
  THE SOFTWARE.
24
24
  */
25
25
  import range from 'lodash/range';
26
- import React from 'react';
26
+ import React, {useState, useCallback} from 'react';
27
27
  import {
28
28
  ArrayLayoutProps,
29
29
  composePaths,
30
30
  computeLabel,
31
31
  createDefaultValue,
32
- isPlainLabel
33
32
  } from '@jsonforms/core';
34
33
  import map from 'lodash/map';
35
34
  import { ArrayLayoutToolbar } from './ArrayToolbar';
36
35
  import ExpandPanelRenderer from './ExpandPanelRenderer';
37
36
  import merge from 'lodash/merge';
38
37
 
39
- interface MaterialArrayLayoutState {
40
- expanded: string | boolean;
41
- }
42
- export class MaterialArrayLayout extends React.PureComponent<
43
- ArrayLayoutProps,
44
- MaterialArrayLayoutState
45
- > {
46
- state: MaterialArrayLayoutState = {
47
- expanded: null
48
- };
49
- innerCreateDefaultValue = () => createDefaultValue(this.props.schema);
50
- handleChange = (panel: string) => (_event: any, expanded: boolean) => {
51
- this.setState({
52
- expanded: expanded ? panel : false
53
- });
54
- };
55
- isExpanded = (index: number) =>
56
- this.state.expanded === composePaths(this.props.path, `${index}`);
57
- render() {
58
- const {
59
- data,
60
- path,
61
- schema,
62
- uischema,
63
- errors,
64
- addItem,
65
- renderers,
66
- cells,
67
- label,
68
- required,
69
- rootSchema,
70
- config,
71
- uischemas
72
- } = this.props;
73
- const appliedUiSchemaOptions = merge(
74
- {},
75
- config,
76
- this.props.uischema.options
77
- );
38
+ const MaterialArrayLayoutComponent = (props: ArrayLayoutProps)=> {
39
+ const [expanded, setExpanded] = useState<string|boolean>(false);
40
+ const innerCreateDefaultValue = useCallback(() => createDefaultValue(props.schema), [props.schema]);
41
+ const handleChange = useCallback((panel: string) => (_event: any, expandedPanel: boolean) => {
42
+ setExpanded(expandedPanel ? panel : false)
43
+ }, []);
44
+ const isExpanded = (index: number) =>
45
+ expanded === composePaths(props.path, `${index}`);
46
+
47
+ const {
48
+ data,
49
+ path,
50
+ schema,
51
+ uischema,
52
+ errors,
53
+ addItem,
54
+ renderers,
55
+ cells,
56
+ label,
57
+ required,
58
+ rootSchema,
59
+ config,
60
+ uischemas
61
+ } = props;
62
+ const appliedUiSchemaOptions = merge(
63
+ {},
64
+ config,
65
+ props.uischema.options
66
+ );
78
67
 
79
- return (
68
+ return (
69
+ <div>
70
+ <ArrayLayoutToolbar
71
+ label={computeLabel(
72
+ label,
73
+ required,
74
+ appliedUiSchemaOptions.hideRequiredAsterisk
75
+ )}
76
+ errors={errors}
77
+ path={path}
78
+ addItem={addItem}
79
+ createDefault={innerCreateDefaultValue}
80
+ />
80
81
  <div>
81
- <ArrayLayoutToolbar
82
- label={computeLabel(
83
- isPlainLabel(label) ? label : label.default,
84
- required,
85
- appliedUiSchemaOptions.hideRequiredAsterisk
86
- )}
87
- errors={errors}
88
- path={path}
89
- addItem={addItem}
90
- createDefault={this.innerCreateDefaultValue}
91
- />
92
- <div>
93
- {data > 0 ? (
94
- map(range(data), index => {
95
- return (
96
- <ExpandPanelRenderer
97
- index={index}
98
- expanded={this.isExpanded(index)}
99
- schema={schema}
100
- path={path}
101
- handleExpansion={this.handleChange}
102
- uischema={uischema}
103
- renderers={renderers}
104
- cells={cells}
105
- key={index}
106
- rootSchema={rootSchema}
107
- enableMoveUp={index != 0}
108
- enableMoveDown={index < data - 1}
109
- config={config}
110
- childLabelProp={appliedUiSchemaOptions.elementLabelProp}
111
- uischemas={uischemas}
112
- />
113
- );
114
- })
115
- ) : (
116
- <p>No data</p>
117
- )}
118
- </div>
82
+ {data > 0 ? (
83
+ map(range(data), index => {
84
+ return (
85
+ <ExpandPanelRenderer
86
+ index={index}
87
+ expanded={isExpanded(index)}
88
+ schema={schema}
89
+ path={path}
90
+ handleExpansion={handleChange}
91
+ uischema={uischema}
92
+ renderers={renderers}
93
+ cells={cells}
94
+ key={index}
95
+ rootSchema={rootSchema}
96
+ enableMoveUp={index != 0}
97
+ enableMoveDown={index < data - 1}
98
+ config={config}
99
+ childLabelProp={appliedUiSchemaOptions.elementLabelProp}
100
+ uischemas={uischemas}
101
+ />
102
+ );
103
+ })
104
+ ) : (
105
+ <p>No data</p>
106
+ )}
119
107
  </div>
120
- );
121
- }
122
- }
108
+ </div>
109
+ );
110
+ };
111
+
112
+ export const MaterialArrayLayout = React.memo(MaterialArrayLayoutComponent);
@@ -30,7 +30,7 @@ import {
30
30
  RankedTester,
31
31
  rankWith
32
32
  } from '@jsonforms/core';
33
- import { Hidden } from '@material-ui/core';
33
+ import { Hidden } from '@mui/material';
34
34
  import { MaterialArrayLayout } from './MaterialArrayLayout';
35
35
  import { withJsonFormsArrayLayoutProps } from '@jsonforms/react';
36
36
 
@@ -22,9 +22,8 @@
22
22
  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
23
  THE SOFTWARE.
24
24
  */
25
- import React from 'react';
26
- import { Hidden, Tab, Tabs } from '@material-ui/core';
27
- import AppBar from '@material-ui/core/AppBar';
25
+ import React, {useState} from 'react';
26
+ import { AppBar, Hidden, Tab, Tabs } from '@mui/material';
28
27
  import {
29
28
  and,
30
29
  Categorization,
@@ -37,7 +36,7 @@ import {
37
36
  UISchemaElement,
38
37
  uiTypeIs
39
38
  } from '@jsonforms/core';
40
- import { RendererComponent, withJsonFormsLayoutProps } from '@jsonforms/react';
39
+ import { withJsonFormsLayoutProps } from '@jsonforms/react';
41
40
  import {
42
41
  AjvProps,
43
42
  MaterialLayoutRenderer,
@@ -76,71 +75,55 @@ export interface MaterialCategorizationLayoutRendererProps
76
75
  onChange?(selected: number, prevSelected: number): void;
77
76
  }
78
77
 
79
- export class MaterialCategorizationLayoutRenderer extends RendererComponent<
80
- MaterialCategorizationLayoutRendererProps,
81
- CategorizationState
82
- > {
83
- state = {
84
- activeCategory: 0
78
+ export const MaterialCategorizationLayoutRenderer = (props: MaterialCategorizationLayoutRendererProps) => {
79
+ const {
80
+ data,
81
+ path,
82
+ renderers,
83
+ cells,
84
+ schema,
85
+ uischema,
86
+ visible,
87
+ enabled,
88
+ selected,
89
+ onChange,
90
+ ajv
91
+ } = props;
92
+ const categorization = uischema as Categorization;
93
+ const [activeCategory, setActiveCategory]= useState<number|undefined>(selected??0);
94
+ const categories = categorization.elements.filter((category: Category) =>
95
+ isVisible(category, data, undefined, ajv)
96
+ );
97
+ const childProps: MaterialLayoutRendererProps = {
98
+ elements: categories[activeCategory].elements,
99
+ schema,
100
+ path,
101
+ direction: 'column',
102
+ enabled,
103
+ visible,
104
+ renderers,
105
+ cells
85
106
  };
86
-
87
- render() {
88
- const {
89
- data,
90
- path,
91
- renderers,
92
- cells,
93
- schema,
94
- uischema,
95
- visible,
96
- enabled,
97
- selected,
98
- ajv
99
- } = this.props;
100
- const categorization = uischema as Categorization;
101
- const value = this.hasOwnState() ? this.state.activeCategory : selected;
102
- const childProps: MaterialLayoutRendererProps = {
103
- elements: categorization.elements[value].elements,
104
- schema,
105
- path,
106
- direction: 'column',
107
- enabled,
108
- visible,
109
- renderers,
110
- cells
111
- };
112
- const categories = categorization.elements.filter((category: Category) =>
113
- isVisible(category, data, undefined, ajv)
114
- );
115
- return (
116
- <Hidden xsUp={!visible}>
117
- <AppBar position='static'>
118
- <Tabs value={value} onChange={this.handleChange} variant='scrollable'>
119
- {categories.map((e: Category, idx: number) => (
120
- <Tab key={idx} label={e.label} />
121
- ))}
122
- </Tabs>
123
- </AppBar>
124
- <div style={{ marginTop: '0.5em' }}>
125
- <MaterialLayoutRenderer {...childProps} />
126
- </div>
127
- </Hidden>
128
- );
129
- }
130
-
131
- hasOwnState = () => {
132
- return this.props.ownState !== undefined ? this.props.ownState : true;
133
- };
134
-
135
- private handleChange = (_event: any, value: any) => {
136
- if (this.props.onChange) {
137
- this.props.onChange(value, this.state.activeCategory);
138
- }
139
- const hasOwnState = this.hasOwnState();
140
- if (hasOwnState) {
141
- this.setState({ activeCategory: value });
107
+ const onTabChange = (_event: any, value: any) => {
108
+ if (onChange) {
109
+ onChange(value, activeCategory);
142
110
  }
111
+ setActiveCategory(value);
143
112
  };
144
- }
113
+ return (
114
+ <Hidden xsUp={!visible}>
115
+ <AppBar position='static'>
116
+ <Tabs value={activeCategory} onChange={onTabChange} textColor='inherit' indicatorColor='secondary' variant='scrollable'>
117
+ {categories.map((e: Category, idx: number) => (
118
+ <Tab key={idx} label={e.label} />
119
+ ))}
120
+ </Tabs>
121
+ </AppBar>
122
+ <div style={{ marginTop: '0.5em' }}>
123
+ <MaterialLayoutRenderer {...childProps} />
124
+ </div>
125
+ </Hidden>
126
+ );
127
+ };
145
128
 
146
129
  export default withJsonFormsLayoutProps(withAjvProps(MaterialCategorizationLayoutRenderer));
@@ -22,9 +22,9 @@
22
22
  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
23
  THE SOFTWARE.
24
24
  */
25
- import React from 'react';
25
+ import React, {useState} from 'react';
26
26
  import merge from 'lodash/merge';
27
- import { Button, Hidden, Step, StepButton, Stepper } from '@material-ui/core';
27
+ import { Button, Hidden, Step, StepButton, Stepper } from '@mui/material';
28
28
  import {
29
29
  and,
30
30
  Categorization,
@@ -37,7 +37,7 @@ import {
37
37
  StatePropsOfLayout,
38
38
  uiTypeIs
39
39
  } from '@jsonforms/core';
40
- import { RendererComponent, withJsonFormsLayoutProps } from '@jsonforms/react';
40
+ import { withJsonFormsLayoutProps } from '@jsonforms/react';
41
41
  import {
42
42
  AjvProps,
43
43
  MaterialLayoutRenderer,
@@ -63,94 +63,86 @@ export interface MaterialCategorizationStepperLayoutRendererProps
63
63
  data: any;
64
64
  }
65
65
 
66
- export class MaterialCategorizationStepperLayoutRenderer extends RendererComponent<
67
- MaterialCategorizationStepperLayoutRendererProps,
68
- CategorizationStepperState
69
- > {
70
- state = {
71
- activeCategory: 0
72
- };
66
+ export const MaterialCategorizationStepperLayoutRenderer = (props: MaterialCategorizationStepperLayoutRendererProps)=> {
67
+ const [activeCategory, setActiveCategory] = useState<number>(0);
73
68
 
74
- handleStep = (step: number) => {
75
- this.setState({ activeCategory: step });
69
+ const handleStep = (step: number) => {
70
+ setActiveCategory( step);
76
71
  };
77
72
 
78
- render() {
79
- const {
80
- data,
81
- path,
82
- renderers,
83
- schema,
84
- uischema,
85
- visible,
86
- cells,
87
- config,
88
- ajv
89
- } = this.props;
90
- const categorization = uischema as Categorization;
91
- const activeCategory = this.state.activeCategory;
92
- const appliedUiSchemaOptions = merge({}, config, uischema.options);
93
- const buttonWrapperStyle = {
94
- textAlign: 'right' as 'right',
95
- width: '100%',
96
- margin: '1em auto'
97
- };
98
- const buttonNextStyle = {
99
- float: 'right' as 'right'
100
- };
101
- const buttonStyle = {
102
- marginRight: '1em'
103
- };
104
- const childProps: MaterialLayoutRendererProps = {
105
- elements: categorization.elements[activeCategory].elements,
106
- schema,
107
- path,
108
- direction: 'column',
109
- visible,
110
- renderers,
111
- cells
112
- };
113
- const categories = categorization.elements.filter((category: Category) =>
114
- isVisible(category, data, undefined, ajv)
115
- );
116
- return (
117
- <Hidden xsUp={!visible}>
118
- <Stepper activeStep={activeCategory} nonLinear>
119
- {categories.map((e: Category, idx: number) => (
120
- <Step key={e.label}>
121
- <StepButton onClick={() => this.handleStep(idx)}>
122
- {e.label}
123
- </StepButton>
124
- </Step>
125
- ))}
126
- </Stepper>
127
- <div>
128
- <MaterialLayoutRenderer {...childProps} />
129
- </div>
130
- { !!appliedUiSchemaOptions.showNavButtons ? (<div style={buttonWrapperStyle}>
131
- <Button
132
- style={buttonNextStyle}
133
- variant="contained"
134
- color="primary"
135
- disabled={activeCategory >= categories.length - 1}
136
- onClick={() => this.handleStep(activeCategory + 1)}
137
- >
138
- Next
139
- </Button>
140
- <Button
141
- style={buttonStyle}
142
- color="secondary"
143
- variant="contained"
144
- disabled={activeCategory <= 0}
145
- onClick={() => this.handleStep(activeCategory - 1)}
146
- >
147
- Previous
148
- </Button>
149
- </div>) : (<></>)}
150
- </Hidden>
151
- );
152
- }
153
- }
73
+ const {
74
+ data,
75
+ path,
76
+ renderers,
77
+ schema,
78
+ uischema,
79
+ visible,
80
+ cells,
81
+ config,
82
+ ajv
83
+ } = props;
84
+ const categorization = uischema as Categorization;
85
+ const appliedUiSchemaOptions = merge({}, config, uischema.options);
86
+ const buttonWrapperStyle = {
87
+ textAlign: 'right' as 'right',
88
+ width: '100%',
89
+ margin: '1em auto'
90
+ };
91
+ const buttonNextStyle = {
92
+ float: 'right' as 'right'
93
+ };
94
+ const buttonStyle = {
95
+ marginRight: '1em'
96
+ };
97
+ const categories = categorization.elements.filter((category: Category) =>
98
+ isVisible(category, data, undefined, ajv)
99
+ );
100
+ const childProps: MaterialLayoutRendererProps = {
101
+ elements: categories[activeCategory].elements,
102
+ schema,
103
+ path,
104
+ direction: 'column',
105
+ visible,
106
+ renderers,
107
+ cells
108
+ };
109
+ return (
110
+ <Hidden xsUp={!visible}>
111
+ <Stepper activeStep={activeCategory} nonLinear>
112
+ {categories.map((e: Category, idx: number) => (
113
+ <Step key={e.label}>
114
+ <StepButton onClick={() => handleStep(idx)}>
115
+ {e.label}
116
+ </StepButton>
117
+ </Step>
118
+ ))}
119
+ </Stepper>
120
+ <div>
121
+ <MaterialLayoutRenderer {...childProps} />
122
+ </div>
123
+ { !!appliedUiSchemaOptions.showNavButtons ? (<div style={buttonWrapperStyle}>
124
+ <Button
125
+ style={buttonNextStyle}
126
+ variant="contained"
127
+ color="primary"
128
+ disabled={activeCategory >= categories.length - 1}
129
+ onClick={() => handleStep(activeCategory + 1)}
130
+ >
131
+ Next
132
+ </Button>
133
+ <Button
134
+ style={buttonStyle}
135
+ color="secondary"
136
+ variant="contained"
137
+ disabled={activeCategory <= 0}
138
+ onClick={() => handleStep(activeCategory - 1)}
139
+ >
140
+ Previous
141
+ </Button>
142
+ </div>) : (<></>)}
143
+ </Hidden>
144
+ );
145
+ };
154
146
 
155
147
  export default withJsonFormsLayoutProps(withAjvProps(
156
148
  MaterialCategorizationStepperLayoutRenderer
@@ -24,7 +24,7 @@
24
24
  */
25
25
  import isEmpty from 'lodash/isEmpty';
26
26
  import React from 'react';
27
- import { Card, CardContent, CardHeader, Hidden } from '@material-ui/core';
27
+ import { Card, CardContent, CardHeader, Hidden } from '@mui/material';
28
28
  import {
29
29
  GroupLayout,
30
30
  LayoutProps,
@@ -25,19 +25,21 @@
25
25
  import React, { ReactNode } from 'react';
26
26
  import { EnumCellProps, EnumOption, WithClassname } from '@jsonforms/core';
27
27
 
28
- import Input from '@material-ui/core/Input';
29
- import Autocomplete, { AutocompleteRenderOptionState } from '@material-ui/lab/Autocomplete';
30
- import { areEqual } from '@jsonforms/react';
28
+ import {
29
+ Autocomplete,
30
+ AutocompleteRenderOptionState,
31
+ Input,
32
+ FilterOptionsState
33
+ } from '@mui/material';
31
34
  import merge from 'lodash/merge';
32
- import { FilterOptionsState } from '@material-ui/lab/useAutocomplete';
33
35
 
34
36
  export interface WithOptionLabel {
35
- getOptionLabel?(option: EnumOption) : string;
36
- renderOption?(option: EnumOption, state: AutocompleteRenderOptionState): ReactNode;
37
- filterOptions?(options: EnumOption[], state: FilterOptionsState<EnumOption>) : EnumOption[];
37
+ getOptionLabel?(option: EnumOption) : string;
38
+ renderOption?(props: React.HTMLAttributes<HTMLLIElement>, option: EnumOption, state: AutocompleteRenderOptionState): ReactNode;
39
+ filterOptions?(options: EnumOption[], state: FilterOptionsState<EnumOption>) : EnumOption[];
38
40
  }
39
41
 
40
- export const MuiAutocomplete = React.memo((props: EnumCellProps & WithClassname & WithOptionLabel) => {
42
+ export const MuiAutocomplete = (props: EnumCellProps & WithClassname & WithOptionLabel) => {
41
43
  const {
42
44
  data,
43
45
  className,
@@ -90,4 +92,4 @@ export const MuiAutocomplete = React.memo((props: EnumCellProps & WithClassname
90
92
  filterOptions={filterOptions}
91
93
  />
92
94
  );
93
- }, areEqual);
95
+ };
@@ -24,8 +24,7 @@
24
24
  */
25
25
  import React from 'react';
26
26
  import { CellProps, WithClassname } from '@jsonforms/core';
27
- import Checkbox from '@material-ui/core/Checkbox';
28
- import { areEqual } from '@jsonforms/react';
27
+ import { Checkbox } from '@mui/material';
29
28
  import merge from 'lodash/merge';
30
29
 
31
30
  export const MuiCheckbox = React.memo((props: CellProps & WithClassname) => {
@@ -54,4 +53,4 @@ export const MuiCheckbox = React.memo((props: CellProps & WithClassname) => {
54
53
  inputProps={inputProps}
55
54
  />
56
55
  );
57
- }, areEqual);
56
+ });
@@ -24,11 +24,15 @@
24
24
  */
25
25
  import React from 'react';
26
26
  import { CellProps, WithClassname } from '@jsonforms/core';
27
- import Input from '@material-ui/core/Input';
28
- import { areEqual } from '@jsonforms/react';
27
+ import { Input } from '@mui/material';
29
28
  import merge from 'lodash/merge';
29
+ import { useDebouncedChange } from '../util';
30
30
 
31
- export const MuiInputInteger = React.memo(
31
+ const toNumber = (value: string) =>
32
+ value === '' ? undefined : parseInt(value, 10);
33
+ const eventToValue = (ev:any) => toNumber(ev.target.value);
34
+
35
+ export const MuiInputInteger = React.memo(
32
36
  (props: CellProps & WithClassname) => {
33
37
  const {
34
38
  data,
@@ -41,15 +45,16 @@ export const MuiInputInteger = React.memo(
41
45
  config
42
46
  } = props;
43
47
  const inputProps = { step: '1' };
44
- const toNumber = (value: string) =>
45
- value === '' ? undefined : parseInt(value, 10);
48
+
46
49
  const appliedUiSchemaOptions = merge({}, config, uischema.options);
47
50
 
51
+ const [inputValue, onChange] = useDebouncedChange(handleChange, '', data, path, eventToValue);
52
+
48
53
  return (
49
54
  <Input
50
55
  type='number'
51
- value={data !== undefined && data !== null ? data : ''}
52
- onChange={ev => handleChange(path, toNumber(ev.target.value))}
56
+ value={inputValue}
57
+ onChange={onChange}
53
58
  className={className}
54
59
  id={id}
55
60
  disabled={!enabled}
@@ -58,6 +63,4 @@ export const MuiInputInteger = React.memo(
58
63
  fullWidth={true}
59
64
  />
60
65
  );
61
- },
62
- areEqual
63
- );
66
+ });
@@ -24,10 +24,13 @@
24
24
  */
25
25
  import React from 'react';
26
26
  import { CellProps, WithClassname } from '@jsonforms/core';
27
- import Input from '@material-ui/core/Input';
28
- import { areEqual } from '@jsonforms/react';
27
+ import { Input } from '@mui/material';
29
28
  import merge from 'lodash/merge';
29
+ import {useDebouncedChange} from '../util';
30
30
 
31
+ const toNumber = (value: string) =>
32
+ value === '' ? undefined : parseFloat(value);
33
+ const eventToValue = (ev:any) => toNumber(ev.target.value);
31
34
  export const MuiInputNumber = React.memo((props: CellProps & WithClassname) => {
32
35
  const {
33
36
  data,
@@ -40,15 +43,15 @@ export const MuiInputNumber = React.memo((props: CellProps & WithClassname) => {
40
43
  config
41
44
  } = props;
42
45
  const inputProps = { step: '0.1' };
43
- const toNumber = (value: string) =>
44
- value === '' ? undefined : parseFloat(value);
46
+
45
47
  const appliedUiSchemaOptions = merge({}, config, uischema.options);
48
+ const [inputValue, onChange] = useDebouncedChange(handleChange, '', data, path, eventToValue);
46
49
 
47
50
  return (
48
51
  <Input
49
52
  type='number'
50
- value={data === undefined || data === null ? '' : data}
51
- onChange={ev => handleChange(path, toNumber(ev.target.value))}
53
+ value={inputValue}
54
+ onChange={onChange}
52
55
  className={className}
53
56
  id={id}
54
57
  disabled={!enabled}
@@ -57,4 +60,4 @@ export const MuiInputNumber = React.memo((props: CellProps & WithClassname) => {
57
60
  fullWidth={true}
58
61
  />
59
62
  );
60
- }, areEqual);
63
+ });