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

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 (373) hide show
  1. package/docs/assets/js/search.json +1 -1
  2. package/docs/classes/combinatorproperties.html +2 -5
  3. package/docs/classes/materialanyofstringorenumcontrol.html +6 -9
  4. package/docs/classes/materialtablecontrol.html +4 -7
  5. package/docs/globals.html +878 -423
  6. package/docs/index.html +68 -59
  7. package/docs/interfaces/ajvprops.html +1 -4
  8. package/docs/interfaces/arraylayouttoolbarprops.html +5 -8
  9. package/docs/interfaces/categorizationstate.html +1 -4
  10. package/docs/interfaces/categorizationstepperstate.html +0 -3
  11. package/docs/interfaces/combinatorpropertiesprops.html +0 -3
  12. package/docs/interfaces/deletedialogprops.html +0 -3
  13. package/docs/interfaces/dispatchpropsofexpandpanel.html +3 -6
  14. package/docs/interfaces/emptytableprops.html +0 -3
  15. package/docs/interfaces/expandpanelprops.html +19 -22
  16. package/docs/interfaces/jsonformstheme.html +39 -49
  17. package/docs/interfaces/materialcategorizationlayoutrendererprops.html +5 -8
  18. package/docs/interfaces/materialcategorizationstepperlayoutrendererprops.html +1 -4
  19. package/docs/interfaces/materiallayoutrendererprops.html +0 -3
  20. package/docs/interfaces/materialtabletoolbarprops.html +9 -12
  21. package/docs/interfaces/muitextinputprops.html +2 -5
  22. package/docs/interfaces/nonemptycellcomponentprops.html +266 -0
  23. package/docs/interfaces/nonemptycellprops.html +0 -3
  24. package/docs/interfaces/nonemptyrowprops.html +80 -27
  25. package/docs/interfaces/ownoneofprops.html +0 -3
  26. package/docs/interfaces/ownpropsofexpandpanel.html +14 -17
  27. package/docs/interfaces/ownpropsofnonemptycell.html +0 -3
  28. package/docs/interfaces/statepropsofexpandpanel.html +16 -19
  29. package/docs/interfaces/tableheadercellprops.html +0 -3
  30. package/docs/interfaces/tablerowsprop.html +9 -12
  31. package/docs/interfaces/validationprops.html +2 -5
  32. package/docs/interfaces/withdeletedialogsupport.html +0 -3
  33. package/docs/interfaces/withinput.html +1 -4
  34. package/docs/interfaces/withoptionlabel.html +7 -7
  35. package/example/index.ts +7 -23
  36. package/lib/additional/ListWithDetailMasterItem.d.ts +3 -3
  37. package/lib/additional/MaterialLabelRenderer.d.ts +13 -13
  38. package/lib/additional/MaterialListWithDetailRenderer.d.ts +6 -6
  39. package/lib/additional/index.d.ts +4 -4
  40. package/lib/cells/CustomizableCells.d.ts +9 -9
  41. package/lib/cells/MaterialBooleanCell.d.ts +6 -6
  42. package/lib/cells/MaterialBooleanToggleCell.d.ts +6 -6
  43. package/lib/cells/MaterialDateCell.d.ts +6 -6
  44. package/lib/cells/MaterialEnumCell.d.ts +10 -10
  45. package/lib/cells/MaterialIntegerCell.d.ts +6 -6
  46. package/lib/cells/MaterialNumberCell.d.ts +10 -10
  47. package/lib/cells/MaterialNumberFormatCell.d.ts +10 -10
  48. package/lib/cells/MaterialOneOfEnumCell.d.ts +10 -10
  49. package/lib/cells/MaterialTextCell.d.ts +10 -10
  50. package/lib/cells/MaterialTimeCell.d.ts +6 -6
  51. package/lib/cells/index.d.ts +13 -13
  52. package/lib/complex/CombinatorProperties.d.ts +12 -12
  53. package/lib/complex/DeleteDialog.d.ts +11 -11
  54. package/lib/complex/MaterialAllOfRenderer.d.ts +6 -5
  55. package/lib/complex/MaterialAnyOfRenderer.d.ts +6 -5
  56. package/lib/complex/MaterialArrayControlRenderer.d.ts +5 -5
  57. package/lib/complex/MaterialEnumArrayRenderer.d.ts +6 -6
  58. package/lib/complex/MaterialObjectRenderer.d.ts +6 -5
  59. package/lib/complex/MaterialOneOfRenderer.d.ts +9 -8
  60. package/lib/complex/MaterialTableControl.d.ts +25 -10
  61. package/lib/complex/NoBorderTableCell.d.ts +3 -3
  62. package/lib/complex/TableToolbar.d.ts +15 -15
  63. package/lib/complex/ValidationIcon.d.ts +7 -11
  64. package/lib/complex/index.d.ts +19 -19
  65. package/lib/controls/MaterialAnyOfStringOrEnumControl.d.ts +9 -9
  66. package/lib/controls/MaterialBooleanControl.d.ts +6 -6
  67. package/lib/controls/MaterialBooleanToggleControl.d.ts +6 -6
  68. package/lib/controls/MaterialDateControl.d.ts +6 -9
  69. package/lib/controls/MaterialDateTimeControl.d.ts +6 -9
  70. package/lib/controls/MaterialEnumControl.d.ts +7 -6
  71. package/lib/controls/MaterialInputControl.d.ts +6 -9
  72. package/lib/controls/MaterialIntegerControl.d.ts +6 -6
  73. package/lib/controls/MaterialNativeControl.d.ts +6 -9
  74. package/lib/controls/MaterialNumberControl.d.ts +6 -6
  75. package/lib/controls/MaterialOneOfEnumControl.d.ts +7 -6
  76. package/lib/controls/MaterialOneOfRadioGroupControl.d.ts +6 -6
  77. package/lib/controls/MaterialRadioGroup.d.ts +3 -6
  78. package/lib/controls/MaterialRadioGroupControl.d.ts +6 -6
  79. package/lib/controls/MaterialSliderControl.d.ts +6 -9
  80. package/lib/controls/MaterialTextControl.d.ts +6 -6
  81. package/lib/controls/MaterialTimeControl.d.ts +6 -9
  82. package/lib/controls/index.d.ts +35 -35
  83. package/lib/index.d.ts +9 -9
  84. package/lib/jsonforms-react-material.cjs.js +1489 -0
  85. package/lib/jsonforms-react-material.cjs.js.map +1 -0
  86. package/lib/jsonforms-react-material.esm.js +1221 -0
  87. package/lib/jsonforms-react-material.esm.js.map +1 -0
  88. package/lib/layouts/ArrayToolbar.d.ts +9 -9
  89. package/lib/layouts/ExpandPanelRenderer.d.ts +51 -51
  90. package/lib/layouts/MaterialArrayLayout.d.ts +3 -13
  91. package/lib/layouts/MaterialArrayLayoutRenderer.d.ts +6 -6
  92. package/lib/layouts/MaterialCategorizationLayout.d.ts +17 -25
  93. package/lib/layouts/MaterialCategorizationStepperLayout.d.ts +13 -20
  94. package/lib/layouts/MaterialGroupLayout.d.ts +7 -7
  95. package/lib/layouts/MaterialHorizontalLayout.d.ts +10 -10
  96. package/lib/layouts/MaterialVerticalLayout.d.ts +10 -10
  97. package/lib/layouts/index.d.ts +6 -6
  98. package/lib/mui-controls/MuiAutocomplete.d.ts +9 -0
  99. package/lib/mui-controls/MuiCheckbox.d.ts +3 -3
  100. package/lib/mui-controls/MuiInputInteger.d.ts +3 -3
  101. package/lib/mui-controls/MuiInputNumber.d.ts +3 -3
  102. package/lib/mui-controls/MuiInputNumberFormat.d.ts +3 -3
  103. package/lib/mui-controls/MuiInputText.d.ts +9 -9
  104. package/lib/mui-controls/MuiInputTime.d.ts +3 -3
  105. package/lib/mui-controls/MuiSelect.d.ts +3 -3
  106. package/lib/mui-controls/MuiToggle.d.ts +3 -3
  107. package/lib/mui-controls/index.d.ts +7 -7
  108. package/lib/util/datejs.d.ts +3 -3
  109. package/lib/util/debounce.d.ts +1 -0
  110. package/lib/util/focus.d.ts +1 -0
  111. package/lib/util/index.d.ts +5 -3
  112. package/lib/util/layout.d.ts +15 -13
  113. package/lib/util/theme.d.ts +10 -10
  114. package/package.json +34 -28
  115. package/rollup.config.js +51 -0
  116. package/src/additional/ListWithDetailMasterItem.tsx +3 -6
  117. package/src/additional/MaterialLabelRenderer.tsx +1 -1
  118. package/src/additional/MaterialListWithDetailRenderer.tsx +1 -1
  119. package/src/cells/MaterialDateCell.tsx +1 -1
  120. package/src/cells/MaterialTimeCell.tsx +1 -0
  121. package/src/complex/CombinatorProperties.tsx +2 -2
  122. package/src/complex/DeleteDialog.tsx +2 -2
  123. package/src/complex/MaterialAllOfRenderer.tsx +3 -2
  124. package/src/complex/MaterialAnyOfRenderer.tsx +3 -2
  125. package/src/complex/MaterialArrayControlRenderer.tsx +1 -1
  126. package/src/complex/MaterialEnumArrayRenderer.tsx +4 -3
  127. package/src/complex/MaterialObjectRenderer.tsx +3 -2
  128. package/src/complex/MaterialOneOfRenderer.tsx +7 -7
  129. package/src/complex/MaterialTableControl.tsx +45 -37
  130. package/src/complex/NoBorderTableCell.tsx +10 -12
  131. package/src/complex/TableToolbar.tsx +9 -7
  132. package/src/complex/ValidationIcon.tsx +12 -19
  133. package/src/controls/MaterialAnyOfStringOrEnumControl.tsx +17 -14
  134. package/src/controls/MaterialBooleanControl.tsx +1 -1
  135. package/src/controls/MaterialBooleanToggleControl.tsx +1 -1
  136. package/src/controls/MaterialDateControl.tsx +87 -93
  137. package/src/controls/MaterialDateTimeControl.tsx +88 -96
  138. package/src/controls/MaterialEnumControl.tsx +12 -3
  139. package/src/controls/MaterialInputControl.tsx +65 -71
  140. package/src/controls/MaterialNativeControl.tsx +55 -59
  141. package/src/controls/MaterialOneOfEnumControl.tsx +13 -4
  142. package/src/controls/MaterialOneOfRadioGroupControl.tsx +4 -4
  143. package/src/controls/MaterialRadioGroup.tsx +73 -73
  144. package/src/controls/MaterialRadioGroupControl.tsx +1 -1
  145. package/src/controls/MaterialSliderControl.tsx +93 -88
  146. package/src/controls/MaterialTimeControl.tsx +87 -85
  147. package/src/layouts/ArrayToolbar.tsx +11 -7
  148. package/src/layouts/ExpandPanelRenderer.tsx +28 -32
  149. package/src/layouts/MaterialArrayLayout.tsx +73 -82
  150. package/src/layouts/MaterialArrayLayoutRenderer.tsx +1 -1
  151. package/src/layouts/MaterialCategorizationLayout.tsx +50 -67
  152. package/src/layouts/MaterialCategorizationStepperLayout.tsx +80 -88
  153. package/src/layouts/MaterialGroupLayout.tsx +1 -1
  154. package/src/{extended → mui-controls}/MuiAutocomplete.tsx +11 -9
  155. package/src/mui-controls/MuiCheckbox.tsx +2 -3
  156. package/src/mui-controls/MuiInputInteger.tsx +13 -10
  157. package/src/mui-controls/MuiInputNumber.tsx +10 -7
  158. package/src/mui-controls/MuiInputNumberFormat.tsx +9 -12
  159. package/src/mui-controls/MuiInputText.tsx +30 -21
  160. package/src/mui-controls/MuiInputTime.tsx +7 -5
  161. package/src/mui-controls/MuiSelect.tsx +4 -5
  162. package/src/mui-controls/MuiToggle.tsx +2 -3
  163. package/{lib/cells/MaterialNumberCell.js → src/util/debounce.ts} +20 -16
  164. package/{lib/util/index.js → src/util/focus.ts} +9 -7
  165. package/src/util/index.ts +2 -0
  166. package/src/util/layout.tsx +7 -8
  167. package/src/util/theme.ts +1 -1
  168. package/stats.html +3279 -0
  169. package/test/renderers/MaterialAllOfRenderer.test.tsx +1 -1
  170. package/test/renderers/MaterialAnyOfRenderer.test.tsx +15 -9
  171. package/test/renderers/MaterialAnyOfStringOrEnumControl.test.tsx +1 -1
  172. package/test/renderers/MaterialArrayControl.test.tsx +1 -1
  173. package/test/renderers/MaterialArrayLayout.test.tsx +39 -32
  174. package/test/renderers/MaterialBooleanCell.test.tsx +1 -1
  175. package/test/renderers/MaterialBooleanToggleCell.test.tsx +3 -2
  176. package/test/renderers/MaterialBooleanToggleControl.test.tsx +3 -2
  177. package/test/renderers/MaterialCategorizationLayout.test.tsx +76 -3
  178. package/test/renderers/MaterialCategorizationStepperLayout.test.tsx +79 -6
  179. package/test/renderers/MaterialDateCell.test.tsx +1 -1
  180. package/test/renderers/MaterialDateControl.test.tsx +5 -3
  181. package/test/renderers/MaterialDateTimeControl.test.tsx +5 -3
  182. package/test/renderers/MaterialEnumArrayRenderer.test.tsx +15 -7
  183. package/test/renderers/MaterialEnumCell.test.tsx +1 -1
  184. package/test/renderers/MaterialGroupLayout.test.tsx +1 -1
  185. package/test/renderers/MaterialInputControl.test.tsx +4 -4
  186. package/test/renderers/MaterialIntegerCell.test.tsx +42 -21
  187. package/test/renderers/MaterialLabelRenderer.test.tsx +1 -1
  188. package/test/renderers/MaterialLayouts.test.tsx +1 -1
  189. package/test/renderers/MaterialListWithDetailRenderer.test.tsx +2 -2
  190. package/test/renderers/MaterialNativeControl.test.tsx +2 -2
  191. package/test/renderers/MaterialNumberCell.test.tsx +46 -25
  192. package/test/renderers/MaterialObjectControl.test.tsx +1 -1
  193. package/test/renderers/MaterialOneOfEnumCell.test.tsx +1 -1
  194. package/test/renderers/MaterialOneOfRadioGroupControl.test.tsx +1 -1
  195. package/test/renderers/MaterialOneOfRenderer.test.tsx +17 -11
  196. package/test/renderers/MaterialRadioGroupControl.test.tsx +1 -1
  197. package/test/renderers/MaterialSliderControl.test.tsx +2 -2
  198. package/test/renderers/MaterialTextCell.test.tsx +47 -33
  199. package/test/renderers/MaterialTextControl.test.tsx +8 -4
  200. package/test/renderers/MaterialTimeCell.test.tsx +42 -21
  201. package/test/renderers/MaterialTimeControl.test.tsx +8 -6
  202. package/tsconfig.json +1 -2
  203. package/tsconfig.test.json +7 -0
  204. package/docs/classes/materialarraylayout.html +0 -777
  205. package/docs/classes/materialcategorizationlayoutrenderer.html +0 -786
  206. package/docs/classes/materialcategorizationstepperlayoutrenderer.html +0 -762
  207. package/docs/classes/materialdatecontrol.html +0 -825
  208. package/docs/classes/materialdatetimecontrol.html +0 -825
  209. package/docs/classes/materialinputcontrol.html +0 -825
  210. package/docs/classes/materialnativecontrol.html +0 -825
  211. package/docs/classes/materialradiogroup.html +0 -825
  212. package/docs/classes/materialslidercontrol.html +0 -825
  213. package/docs/classes/materialtimecontrol.html +0 -825
  214. package/docs/interfaces/materialarraylayoutstate.html +0 -157
  215. package/example/CustomAutocomplete.tsx +0 -54
  216. package/lib/additional/ListWithDetailMasterItem.js +0 -19
  217. package/lib/additional/ListWithDetailMasterItem.js.map +0 -1
  218. package/lib/additional/MaterialLabelRenderer.js +0 -47
  219. package/lib/additional/MaterialLabelRenderer.js.map +0 -1
  220. package/lib/additional/MaterialListWithDetailRenderer.js +0 -64
  221. package/lib/additional/MaterialListWithDetailRenderer.js.map +0 -1
  222. package/lib/additional/index.js +0 -34
  223. package/lib/additional/index.js.map +0 -1
  224. package/lib/cells/CustomizableCells.js +0 -45
  225. package/lib/cells/CustomizableCells.js.map +0 -1
  226. package/lib/cells/MaterialBooleanCell.js +0 -37
  227. package/lib/cells/MaterialBooleanCell.js.map +0 -1
  228. package/lib/cells/MaterialBooleanToggleCell.js +0 -38
  229. package/lib/cells/MaterialBooleanToggleCell.js.map +0 -1
  230. package/lib/cells/MaterialDateCell.js +0 -40
  231. package/lib/cells/MaterialDateCell.js.map +0 -1
  232. package/lib/cells/MaterialEnumCell.js +0 -39
  233. package/lib/cells/MaterialEnumCell.js.map +0 -1
  234. package/lib/cells/MaterialIntegerCell.js +0 -35
  235. package/lib/cells/MaterialIntegerCell.js.map +0 -1
  236. package/lib/cells/MaterialNumberCell.js.map +0 -1
  237. package/lib/cells/MaterialNumberFormatCell.js +0 -39
  238. package/lib/cells/MaterialNumberFormatCell.js.map +0 -1
  239. package/lib/cells/MaterialOneOfEnumCell.js +0 -39
  240. package/lib/cells/MaterialOneOfEnumCell.js.map +0 -1
  241. package/lib/cells/MaterialTextCell.js +0 -39
  242. package/lib/cells/MaterialTextCell.js.map +0 -1
  243. package/lib/cells/MaterialTimeCell.js +0 -35
  244. package/lib/cells/MaterialTimeCell.js.map +0 -1
  245. package/lib/cells/index.js +0 -60
  246. package/lib/cells/index.js.map +0 -1
  247. package/lib/complex/CombinatorProperties.js +0 -57
  248. package/lib/complex/CombinatorProperties.js.map +0 -1
  249. package/lib/complex/DeleteDialog.js +0 -41
  250. package/lib/complex/DeleteDialog.js.map +0 -1
  251. package/lib/complex/MaterialAllOfRenderer.js +0 -45
  252. package/lib/complex/MaterialAllOfRenderer.js.map +0 -1
  253. package/lib/complex/MaterialAnyOfRenderer.js +0 -49
  254. package/lib/complex/MaterialAnyOfRenderer.js.map +0 -1
  255. package/lib/complex/MaterialArrayControlRenderer.js +0 -55
  256. package/lib/complex/MaterialArrayControlRenderer.js.map +0 -1
  257. package/lib/complex/MaterialEnumArrayRenderer.js +0 -45
  258. package/lib/complex/MaterialEnumArrayRenderer.js.map +0 -1
  259. package/lib/complex/MaterialObjectRenderer.js +0 -49
  260. package/lib/complex/MaterialObjectRenderer.js.map +0 -1
  261. package/lib/complex/MaterialOneOfRenderer.js +0 -77
  262. package/lib/complex/MaterialOneOfRenderer.js.map +0 -1
  263. package/lib/complex/MaterialTableControl.js +0 -190
  264. package/lib/complex/MaterialTableControl.js.map +0 -1
  265. package/lib/complex/NoBorderTableCell.js +0 -41
  266. package/lib/complex/NoBorderTableCell.js.map +0 -1
  267. package/lib/complex/TableToolbar.js +0 -58
  268. package/lib/complex/TableToolbar.js.map +0 -1
  269. package/lib/complex/ValidationIcon.js +0 -48
  270. package/lib/complex/ValidationIcon.js.map +0 -1
  271. package/lib/complex/index.js +0 -47
  272. package/lib/complex/index.js.map +0 -1
  273. package/lib/controls/MaterialAnyOfStringOrEnumControl.js +0 -80
  274. package/lib/controls/MaterialAnyOfStringOrEnumControl.js.map +0 -1
  275. package/lib/controls/MaterialBooleanControl.js +0 -41
  276. package/lib/controls/MaterialBooleanControl.js.map +0 -1
  277. package/lib/controls/MaterialBooleanToggleControl.js +0 -41
  278. package/lib/controls/MaterialBooleanToggleControl.js.map +0 -1
  279. package/lib/controls/MaterialDateControl.js +0 -69
  280. package/lib/controls/MaterialDateControl.js.map +0 -1
  281. package/lib/controls/MaterialDateTimeControl.js +0 -71
  282. package/lib/controls/MaterialDateTimeControl.js.map +0 -1
  283. package/lib/controls/MaterialEnumControl.js +0 -36
  284. package/lib/controls/MaterialEnumControl.js.map +0 -1
  285. package/lib/controls/MaterialInputControl.js +0 -61
  286. package/lib/controls/MaterialInputControl.js.map +0 -1
  287. package/lib/controls/MaterialIntegerControl.js +0 -36
  288. package/lib/controls/MaterialIntegerControl.js.map +0 -1
  289. package/lib/controls/MaterialNativeControl.js +0 -55
  290. package/lib/controls/MaterialNativeControl.js.map +0 -1
  291. package/lib/controls/MaterialNumberControl.js +0 -36
  292. package/lib/controls/MaterialNumberControl.js.map +0 -1
  293. package/lib/controls/MaterialOneOfEnumControl.js +0 -36
  294. package/lib/controls/MaterialOneOfEnumControl.js.map +0 -1
  295. package/lib/controls/MaterialOneOfRadioGroupControl.js +0 -37
  296. package/lib/controls/MaterialOneOfRadioGroupControl.js.map +0 -1
  297. package/lib/controls/MaterialRadioGroup.js +0 -55
  298. package/lib/controls/MaterialRadioGroup.js.map +0 -1
  299. package/lib/controls/MaterialRadioGroupControl.js +0 -37
  300. package/lib/controls/MaterialRadioGroupControl.js.map +0 -1
  301. package/lib/controls/MaterialSliderControl.js +0 -74
  302. package/lib/controls/MaterialSliderControl.js.map +0 -1
  303. package/lib/controls/MaterialTextControl.js +0 -36
  304. package/lib/controls/MaterialTextControl.js.map +0 -1
  305. package/lib/controls/MaterialTimeControl.js +0 -66
  306. package/lib/controls/MaterialTimeControl.js.map +0 -1
  307. package/lib/controls/index.js +0 -91
  308. package/lib/controls/index.js.map +0 -1
  309. package/lib/extended/MaterialAutocompleteEnumControl.d.ts +0 -7
  310. package/lib/extended/MaterialAutocompleteEnumControl.js +0 -42
  311. package/lib/extended/MaterialAutocompleteEnumControl.js.map +0 -1
  312. package/lib/extended/MaterialAutocompleteOneOfEnumControl.d.ts +0 -7
  313. package/lib/extended/MaterialAutocompleteOneOfEnumControl.js +0 -42
  314. package/lib/extended/MaterialAutocompleteOneOfEnumControl.js.map +0 -1
  315. package/lib/extended/MuiAutocomplete.d.ts +0 -10
  316. package/lib/extended/MuiAutocomplete.js +0 -45
  317. package/lib/extended/MuiAutocomplete.js.map +0 -1
  318. package/lib/extended/index.d.ts +0 -10
  319. package/lib/extended/index.js +0 -48
  320. package/lib/extended/index.js.map +0 -1
  321. package/lib/index.js +0 -89
  322. package/lib/index.js.map +0 -1
  323. package/lib/jsonforms-material.js +0 -86
  324. package/lib/jsonforms-material.js.map +0 -1
  325. package/lib/layouts/ArrayToolbar.js +0 -27
  326. package/lib/layouts/ArrayToolbar.js.map +0 -1
  327. package/lib/layouts/ExpandPanelRenderer.js +0 -113
  328. package/lib/layouts/ExpandPanelRenderer.js.map +0 -1
  329. package/lib/layouts/MaterialArrayLayout.js +0 -66
  330. package/lib/layouts/MaterialArrayLayout.js.map +0 -1
  331. package/lib/layouts/MaterialArrayLayoutRenderer.js +0 -43
  332. package/lib/layouts/MaterialArrayLayoutRenderer.js.map +0 -1
  333. package/lib/layouts/MaterialCategorizationLayout.js +0 -88
  334. package/lib/layouts/MaterialCategorizationLayout.js.map +0 -1
  335. package/lib/layouts/MaterialCategorizationStepperLayout.js +0 -89
  336. package/lib/layouts/MaterialCategorizationStepperLayout.js.map +0 -1
  337. package/lib/layouts/MaterialGroupLayout.js +0 -52
  338. package/lib/layouts/MaterialGroupLayout.js.map +0 -1
  339. package/lib/layouts/MaterialHorizontalLayout.js +0 -51
  340. package/lib/layouts/MaterialHorizontalLayout.js.map +0 -1
  341. package/lib/layouts/MaterialVerticalLayout.js +0 -51
  342. package/lib/layouts/MaterialVerticalLayout.js.map +0 -1
  343. package/lib/layouts/index.js +0 -43
  344. package/lib/layouts/index.js.map +0 -1
  345. package/lib/mui-controls/MuiCheckbox.js +0 -40
  346. package/lib/mui-controls/MuiCheckbox.js.map +0 -1
  347. package/lib/mui-controls/MuiInputInteger.js +0 -41
  348. package/lib/mui-controls/MuiInputInteger.js.map +0 -1
  349. package/lib/mui-controls/MuiInputNumber.js +0 -41
  350. package/lib/mui-controls/MuiInputNumber.js.map +0 -1
  351. package/lib/mui-controls/MuiInputNumberFormat.js +0 -50
  352. package/lib/mui-controls/MuiInputNumberFormat.js.map +0 -1
  353. package/lib/mui-controls/MuiInputText.js +0 -64
  354. package/lib/mui-controls/MuiInputText.js.map +0 -1
  355. package/lib/mui-controls/MuiInputTime.js +0 -37
  356. package/lib/mui-controls/MuiInputTime.js.map +0 -1
  357. package/lib/mui-controls/MuiSelect.js +0 -38
  358. package/lib/mui-controls/MuiSelect.js.map +0 -1
  359. package/lib/mui-controls/MuiToggle.js +0 -39
  360. package/lib/mui-controls/MuiToggle.js.map +0 -1
  361. package/lib/mui-controls/index.js +0 -35
  362. package/lib/mui-controls/index.js.map +0 -1
  363. package/lib/util/datejs.js +0 -26
  364. package/lib/util/datejs.js.map +0 -1
  365. package/lib/util/index.js.map +0 -1
  366. package/lib/util/layout.js +0 -54
  367. package/lib/util/layout.js.map +0 -1
  368. package/lib/util/theme.js +0 -3
  369. package/lib/util/theme.js.map +0 -1
  370. package/src/extended/MaterialAutocompleteEnumControl.tsx +0 -55
  371. package/src/extended/MaterialAutocompleteOneOfEnumControl.tsx +0 -55
  372. package/src/extended/index.ts +0 -56
  373. package/webpack/webpack.build.js +0 -21
@@ -24,9 +24,8 @@
24
24
  */
25
25
  import React from 'react';
26
26
  import {
27
- computeLabel,
28
27
  ControlProps,
29
- ControlState,
28
+ showAsRequired,
30
29
  isDateControl,
31
30
  isDescriptionHidden,
32
31
  isTimeControl,
@@ -34,66 +33,63 @@ import {
34
33
  RankedTester,
35
34
  rankWith
36
35
  } from '@jsonforms/core';
37
- import { Hidden } from '@material-ui/core';
38
- import { Control, withJsonFormsControlProps } from '@jsonforms/react';
39
- import TextField from '@material-ui/core/TextField';
36
+ import { Hidden, TextField } from '@mui/material';
37
+ import { withJsonFormsControlProps } from '@jsonforms/react';
40
38
  import merge from 'lodash/merge';
39
+ import { useDebouncedChange, useFocus } from '../util';
41
40
 
42
- export class MaterialNativeControl extends Control<ControlProps, ControlState> {
43
- render() {
44
- const {
45
- id,
46
- errors,
47
- label,
48
- schema,
49
- description,
50
- enabled,
51
- visible,
52
- required,
53
- path,
54
- handleChange,
55
- data,
56
- config
57
- } = this.props;
58
- const isValid = errors.length === 0;
59
- const appliedUiSchemaOptions = merge(
60
- {},
61
- config,
62
- this.props.uischema.options
63
- );
64
- const onChange = (ev: any) => handleChange(path, ev.target.value);
65
- const fieldType = appliedUiSchemaOptions.format ?? schema.format;
66
- const showDescription = !isDescriptionHidden(
67
- visible,
68
- description,
69
- this.state.isFocused,
70
- appliedUiSchemaOptions.showUnfocusedDescription
71
- );
41
+ export const MaterialNativeControl = (props: ControlProps) => {
42
+ const [focused, onFocus, onBlur] = useFocus();
43
+ const {
44
+ id,
45
+ errors,
46
+ label,
47
+ schema,
48
+ description,
49
+ enabled,
50
+ visible,
51
+ required,
52
+ path,
53
+ handleChange,
54
+ data,
55
+ config
56
+ } = props;
57
+ const isValid = errors.length === 0;
58
+ const appliedUiSchemaOptions = merge(
59
+ {},
60
+ config,
61
+ props.uischema.options
62
+ );
63
+ const [inputValue, onChange] = useDebouncedChange(handleChange, '', data, path);
64
+ const fieldType = appliedUiSchemaOptions.format ?? schema.format;
65
+ const showDescription = !isDescriptionHidden(
66
+ visible,
67
+ description,
68
+ focused,
69
+ appliedUiSchemaOptions.showUnfocusedDescription
70
+ );
72
71
 
73
- return (
74
- <Hidden xsUp={!visible}>
75
- <TextField
76
- id={id + '-input'}
77
- label={computeLabel(
78
- label,
79
- required,
80
- appliedUiSchemaOptions.hideRequiredAsterisk
81
- )}
82
- type={fieldType}
83
- error={!isValid}
84
- disabled={!enabled}
85
- fullWidth={!appliedUiSchemaOptions.trim}
86
- onFocus={this.onFocus}
87
- onBlur={this.onBlur}
88
- helperText={!isValid ? errors : showDescription ? description : null}
89
- InputLabelProps={{ shrink: true }}
90
- value={data}
91
- onChange={onChange}
92
- />
93
- </Hidden>
94
- );
95
- }
96
- }
72
+ return (
73
+ <Hidden xsUp={!visible}>
74
+ <TextField
75
+ required={showAsRequired(required,
76
+ appliedUiSchemaOptions.hideRequiredAsterisk)}
77
+ id={id + '-input'}
78
+ label={label}
79
+ type={fieldType}
80
+ error={!isValid}
81
+ disabled={!enabled}
82
+ fullWidth={!appliedUiSchemaOptions.trim}
83
+ onFocus={onFocus}
84
+ onBlur={onBlur}
85
+ helperText={!isValid ? errors : showDescription ? description : null}
86
+ InputLabelProps={{ shrink: true }}
87
+ value={inputValue}
88
+ onChange={onChange}
89
+ />
90
+ </Hidden>
91
+ );
92
+ };
97
93
 
98
94
  export const materialNativeControlTester: RankedTester = rankWith(
99
95
  2,
@@ -31,12 +31,21 @@ import {
31
31
  rankWith,
32
32
  } from '@jsonforms/core';
33
33
  import { withJsonFormsOneOfEnumProps } from '@jsonforms/react';
34
+ import { MuiAutocomplete, WithOptionLabel } from '../mui-controls/MuiAutocomplete';
34
35
  import { MuiSelect } from '../mui-controls/MuiSelect';
35
- import { MaterialInputControl } from './MaterialInputControl';
36
+ import { MaterialInputControl } from '../controls/MaterialInputControl';
37
+ import merge from 'lodash/merge';
36
38
 
37
- export const MaterialOneOfEnumControl = (props: ControlProps & OwnPropsOfEnum) => (
38
- <MaterialInputControl {...props} input={MuiSelect} />
39
- );
39
+ export const MaterialOneOfEnumControl = (props: ControlProps & OwnPropsOfEnum & WithOptionLabel) => {
40
+ const {config, uischema} = props;
41
+ const appliedUiSchemaOptions = merge({}, config, uischema.options);
42
+ return (
43
+ <MaterialInputControl
44
+ {...props}
45
+ input={appliedUiSchemaOptions.autocomplete === false ? MuiSelect : MuiAutocomplete}
46
+ />
47
+ );
48
+ };
40
49
 
41
50
  export const materialOneOfEnumControlTester: RankedTester = rankWith(
42
51
  5,
@@ -36,12 +36,12 @@ import { withJsonFormsOneOfEnumProps } from '@jsonforms/react';
36
36
  import { MaterialRadioGroup } from './MaterialRadioGroup';
37
37
 
38
38
  export const MaterialOneOfRadioGroupControl = (props: ControlProps & OwnPropsOfEnum) => {
39
- return <MaterialRadioGroup {...props}/>;
39
+ return <MaterialRadioGroup {...props}/>;
40
40
  };
41
41
 
42
42
  export const materialOneOfRadioGroupControlTester: RankedTester = rankWith(
43
- 20,
44
- and(isOneOfEnumControl, optionIs('format', 'radio'))
45
- );
43
+ 20,
44
+ and(isOneOfEnumControl, optionIs('format', 'radio'))
45
+ );
46
46
 
47
47
  export default withJsonFormsOneOfEnumProps(MaterialOneOfRadioGroupControl);
@@ -25,89 +25,89 @@
25
25
  import merge from 'lodash/merge';
26
26
  import React from 'react';
27
27
  import {
28
- computeLabel,
29
28
  ControlProps,
30
- ControlState,
29
+ showAsRequired,
31
30
  isDescriptionHidden,
32
31
  OwnPropsOfEnum
33
32
  } from '@jsonforms/core';
34
- import { Control } from '@jsonforms/react';
35
- import Radio from '@material-ui/core/Radio';
36
- import RadioGroup from '@material-ui/core/RadioGroup';
37
33
  import {
38
34
  FormControl,
39
35
  FormControlLabel,
40
36
  FormHelperText,
41
37
  FormLabel,
42
- Hidden
43
- } from '@material-ui/core';
38
+ Hidden,
39
+ Radio,
40
+ RadioGroup
41
+ } from '@mui/material';
42
+ import { useFocus } from '../util';
44
43
 
45
- export class MaterialRadioGroup extends Control<
46
- ControlProps & OwnPropsOfEnum,
47
- ControlState
48
- > {
49
- render() {
50
- const {
51
- config,
52
- id,
53
- label,
54
- required,
55
- description,
56
- errors,
57
- data,
58
- visible,
59
- options
60
- } = this.props;
61
- const isValid = errors.length === 0;
62
- const appliedUiSchemaOptions = merge(
63
- {},
64
- config,
65
- this.props.uischema.options
66
- );
67
- const showDescription = !isDescriptionHidden(
68
- visible,
69
- description,
70
- this.state.isFocused,
71
- appliedUiSchemaOptions.showUnfocusedDescription
72
- );
44
+ export const MaterialRadioGroup = (props: ControlProps & OwnPropsOfEnum) => {
45
+ const [focused, onFocus, onBlur] = useFocus();
46
+ const {
47
+ config,
48
+ id,
49
+ label,
50
+ required,
51
+ description,
52
+ errors,
53
+ data,
54
+ visible,
55
+ options,
56
+ handleChange,
57
+ path,
58
+ enabled
59
+ } = props;
60
+ const isValid = errors.length === 0;
61
+ const appliedUiSchemaOptions = merge(
62
+ {},
63
+ config,
64
+ props.uischema.options
65
+ );
66
+ const showDescription = !isDescriptionHidden(
67
+ visible,
68
+ description,
69
+ focused,
70
+ appliedUiSchemaOptions.showUnfocusedDescription
71
+ );
72
+ const onChange = (_ev:any, value:any) => handleChange(path, value);
73
73
 
74
- return (
75
- <Hidden xsUp={!visible}>
76
- <FormControl
77
- component={'fieldset' as 'div'}
78
- fullWidth={!appliedUiSchemaOptions.trim}
74
+ return (
75
+ <Hidden xsUp={!visible}>
76
+ <FormControl
77
+ component={'fieldset' as 'div'}
78
+ fullWidth={!appliedUiSchemaOptions.trim}
79
+ onFocus={onFocus}
80
+ onBlur={onBlur}
81
+ >
82
+ <FormLabel
83
+ htmlFor={id}
84
+ error={!isValid}
85
+ component={'legend' as 'label'}
86
+ required={showAsRequired(required,
87
+ appliedUiSchemaOptions.hideRequiredAsterisk)}
79
88
  >
80
- <FormLabel
81
- htmlFor={id}
82
- error={!isValid}
83
- component={'legend' as 'label'}
84
- >
85
- {computeLabel(
86
- label,
87
- required,
88
- appliedUiSchemaOptions.hideRequiredAsterisk
89
- )}
90
- </FormLabel>
89
+ {label}
90
+ </FormLabel>
91
91
 
92
- <RadioGroup
93
- value={this.state.value}
94
- onChange={(_ev, value) => this.handleChange(value)}
95
- row={true}
96
- >
97
- {options.map(option => (
98
- <FormControlLabel
99
- value={option.value}
100
- key={option.label}
101
- control={<Radio checked={data === option.value} />}
102
- label={option.label}
103
- />
104
- ))}
105
- </RadioGroup>
106
- <FormHelperText error={!isValid}>
107
- {!isValid ? errors : showDescription ? description : null}
108
- </FormHelperText>
109
- </FormControl>
110
- </Hidden>
111
- );
112
- }
113
- }
92
+ <RadioGroup
93
+ value={props.data}
94
+ onChange={onChange}
95
+ row={true}
96
+ >
97
+ {options.map(option => (
98
+ <FormControlLabel
99
+ value={option.value}
100
+ key={option.label}
101
+ control={<Radio checked={data === option.value} />}
102
+ label={option.label}
103
+ disabled={!enabled}
104
+ />
105
+ ))}
106
+ </RadioGroup>
107
+ <FormHelperText error={!isValid}>
108
+ {!isValid ? errors : showDescription ? description : null}
109
+ </FormHelperText>
110
+ </FormControl>
111
+ </Hidden>
112
+ );
113
+ };
@@ -32,7 +32,7 @@ import {
32
32
  import { withJsonFormsEnumProps } from '@jsonforms/react';
33
33
  import { MaterialRadioGroup } from './MaterialRadioGroup';
34
34
  export const MaterialRadioGroupControl = (props: ControlProps & OwnPropsOfEnum) => {
35
- return <MaterialRadioGroup {...props} />;
35
+ return <MaterialRadioGroup {...props} />;
36
36
  };
37
37
 
38
38
  export const materialRadioGroupControlTester: RankedTester = rankWith(
@@ -22,114 +22,119 @@
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, {useCallback} from 'react';
26
26
  import {
27
- computeLabel,
28
27
  ControlProps,
29
- ControlState,
28
+ showAsRequired,
30
29
  isDescriptionHidden,
31
30
  isRangeControl,
32
31
  RankedTester,
33
32
  rankWith
34
33
  } from '@jsonforms/core';
35
- import { Control, withJsonFormsControlProps } from '@jsonforms/react';
34
+ import { withJsonFormsControlProps } from '@jsonforms/react';
36
35
 
37
36
  import {
38
37
  FormControl,
39
38
  FormHelperText,
39
+ FormLabel,
40
40
  Hidden,
41
41
  Slider,
42
42
  Typography
43
- } from '@material-ui/core';
43
+ } from '@mui/material';
44
44
  import merge from 'lodash/merge';
45
+ import { useFocus } from '../util';
45
46
 
46
- export class MaterialSliderControl extends Control<ControlProps, ControlState> {
47
- render() {
48
- const {
49
- id,
50
- data,
51
- description,
52
- enabled,
53
- errors,
54
- label,
55
- schema,
56
- handleChange,
57
- visible,
58
- path,
59
- required,
60
- config
61
- } = this.props;
62
- const isValid = errors.length === 0;
63
- const appliedUiSchemaOptions = merge(
64
- {},
65
- config,
66
- this.props.uischema.options
67
- );
68
- const labelStyle: { [x: string]: any } = {
69
- whiteSpace: 'nowrap',
70
- overflow: 'hidden',
71
- textOverflow: 'ellipsis',
72
- width: '100%'
73
- };
74
- const rangeContainerStyle: { [x: string]: any } = {
75
- display: 'flex'
76
- };
77
- const rangeItemStyle: { [x: string]: any } = {
78
- flexGrow: '1'
79
- };
80
- const sliderStyle: { [x: string]: any } = {
81
- marginTop: '7px'
82
- };
47
+ export const MaterialSliderControl = (props: ControlProps) => {
48
+ const [focused, onFocus, onBlur] = useFocus();
49
+ const {
50
+ id,
51
+ data,
52
+ description,
53
+ enabled,
54
+ errors,
55
+ label,
56
+ schema,
57
+ handleChange,
58
+ visible,
59
+ path,
60
+ required,
61
+ config
62
+ } = props;
63
+ const isValid = errors.length === 0;
64
+ const appliedUiSchemaOptions = merge(
65
+ {},
66
+ config,
67
+ props.uischema.options
68
+ );
69
+ const labelStyle: { [x: string]: any } = {
70
+ whiteSpace: 'nowrap',
71
+ overflow: 'hidden',
72
+ textOverflow: 'ellipsis',
73
+ width: '100%'
74
+ };
75
+ const rangeContainerStyle: { [x: string]: any } = {
76
+ display: 'flex'
77
+ };
78
+ const rangeItemStyle: { [x: string]: any } = {
79
+ flexGrow: '1'
80
+ };
81
+ const sliderStyle: { [x: string]: any } = {
82
+ marginTop: '7px'
83
+ };
83
84
 
84
- const showDescription = !isDescriptionHidden(
85
- visible,
86
- description,
87
- this.state.isFocused,
88
- appliedUiSchemaOptions.showUnfocusedDescription
89
- );
90
- return (
91
- <Hidden xsUp={!visible}>
92
- <FormControl
93
- fullWidth={!appliedUiSchemaOptions.trim}
94
- onFocus={this.onFocus}
95
- onBlur={this.onBlur}
96
- id={id}
85
+ const showDescription = !isDescriptionHidden(
86
+ visible,
87
+ description,
88
+ focused,
89
+ appliedUiSchemaOptions.showUnfocusedDescription
90
+ );
91
+
92
+ const onChange = useCallback((_ev: any, value: any) => handleChange(path, Number(value)), [path, handleChange]);
93
+
94
+ return (
95
+ <Hidden xsUp={!visible}>
96
+ <FormControl
97
+ fullWidth={!appliedUiSchemaOptions.trim}
98
+ onFocus={onFocus}
99
+ onBlur={onBlur}
100
+ id={id}
101
+ >
102
+ <FormLabel
103
+ htmlFor={id}
104
+ error={!isValid}
105
+ component={'legend' as 'label'}
106
+ required={showAsRequired(required,
107
+ appliedUiSchemaOptions.hideRequiredAsterisk)}
97
108
  >
98
109
  <Typography id={id + '-typo'} style={labelStyle} variant='caption'>
99
- {computeLabel(
100
- label,
101
- required,
102
- appliedUiSchemaOptions.hideRequiredAsterisk
103
- )}
110
+ {label}
111
+ </Typography>
112
+ </FormLabel>
113
+ <div style={rangeContainerStyle}>
114
+ <Typography style={rangeItemStyle} variant='caption' align='left'>
115
+ {schema.minimum}
116
+ </Typography>
117
+ <Typography style={rangeItemStyle} variant='caption' align='right'>
118
+ {schema.maximum}
104
119
  </Typography>
105
- <div style={rangeContainerStyle}>
106
- <Typography style={rangeItemStyle} variant='caption' align='left'>
107
- {schema.minimum}
108
- </Typography>
109
- <Typography style={rangeItemStyle} variant='caption' align='right'>
110
- {schema.maximum}
111
- </Typography>
112
- </div>
113
- <Slider
114
- style={sliderStyle}
115
- min={schema.minimum}
116
- max={schema.maximum}
117
- value={Number(data || schema.default)}
118
- onChange={(_ev: any, value: any) => {
119
- handleChange(path, Number(value));
120
- }}
121
- id={id + '-input'}
122
- disabled={!enabled}
123
- step={schema.multipleOf || 1}
124
- />
125
- <FormHelperText error={!isValid}>
126
- {!isValid ? errors : showDescription ? description : null}
127
- </FormHelperText>
128
- </FormControl>
129
- </Hidden>
130
- );
131
- }
132
- }
120
+ </div>
121
+ <Slider
122
+ style={sliderStyle}
123
+ min={schema.minimum}
124
+ max={schema.maximum}
125
+ value={Number(data || schema.default)}
126
+ onChange={onChange}
127
+ id={id + '-input'}
128
+ disabled={!enabled}
129
+ step={schema.multipleOf || 1}
130
+ />
131
+ <FormHelperText error={!isValid}>
132
+ {!isValid ? errors : showDescription ? description : null}
133
+ </FormHelperText>
134
+ </FormControl>
135
+ </Hidden>
136
+ );
137
+ };
133
138
  export const materialSliderControlTester: RankedTester = rankWith(
134
139
  4,
135
140
  isRangeControl