@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
@@ -35,10 +35,10 @@ import {
35
35
  WithClassname
36
36
  } from '@jsonforms/core';
37
37
  import { Control, withJsonFormsControlProps } from '@jsonforms/react';
38
- import { Input } from '@material-ui/core';
39
- import { InputBaseComponentProps } from '@material-ui/core/InputBase';
38
+ import { Input, InputBaseComponentProps } from '@mui/material';
40
39
  import merge from 'lodash/merge';
41
- import React from 'react';
40
+ import React, { useMemo } from 'react';
41
+ import { useDebouncedChange } from '../util';
42
42
  import { MaterialInputControl } from './MaterialInputControl';
43
43
 
44
44
  const findEnumSchema = (schemas: JsonSchema[]) =>
@@ -64,17 +64,20 @@ const MuiAutocompleteInputText = (props: EnumCellProps & WithClassname) => {
64
64
  const enumSchema = findEnumSchema(schema.anyOf);
65
65
  const stringSchema = findTextSchema(schema.anyOf);
66
66
  const maxLength = stringSchema.maxLength;
67
- const appliedUiSchemaOptions = merge({}, config, uischema.options);
68
- let inputProps: InputBaseComponentProps = {};
69
- if (appliedUiSchemaOptions.restrict) {
70
- inputProps = { maxLength: maxLength };
71
- }
72
- if (appliedUiSchemaOptions.trim && maxLength !== undefined) {
73
- inputProps.size = maxLength;
74
- }
75
- const onChange = (ev: any) => handleChange(path, ev.target.value);
67
+ const appliedUiSchemaOptions = useMemo(() => merge({}, config, uischema.options),[config, uischema.options]);
68
+ const inputProps: InputBaseComponentProps = useMemo(() => {
69
+ let propMemo: InputBaseComponentProps = {};
70
+ if (appliedUiSchemaOptions.restrict) {
71
+ propMemo = { maxLength: maxLength };
72
+ }
73
+ if (appliedUiSchemaOptions.trim && maxLength !== undefined) {
74
+ propMemo.size = maxLength;
75
+ }
76
+ propMemo.list = props.id + 'datalist';
77
+ return propMemo;
78
+ },[appliedUiSchemaOptions,props.id]);
79
+ const [inputText, onChange] = useDebouncedChange(handleChange, '', data, path);
76
80
 
77
- inputProps.list = props.id + 'datalist';
78
81
  const dataList = (
79
82
  <datalist id={props.id + 'datalist'}>
80
83
  {enumSchema.enum.map(optionValue => (
@@ -85,7 +88,7 @@ const MuiAutocompleteInputText = (props: EnumCellProps & WithClassname) => {
85
88
  return (
86
89
  <Input
87
90
  type='text'
88
- value={data || ''}
91
+ value={inputText}
89
92
  onChange={onChange}
90
93
  className={className}
91
94
  id={id}
@@ -31,7 +31,7 @@ import {
31
31
  ControlProps
32
32
  } from '@jsonforms/core';
33
33
  import { withJsonFormsControlProps } from '@jsonforms/react';
34
- import { FormControlLabel, Hidden } from '@material-ui/core';
34
+ import { FormControlLabel, Hidden } from '@mui/material';
35
35
  import { MuiCheckbox } from '../mui-controls/MuiCheckbox';
36
36
 
37
37
  export const MaterialBooleanControl = ({
@@ -33,7 +33,7 @@ import {
33
33
  and
34
34
  } from '@jsonforms/core';
35
35
  import { withJsonFormsControlProps } from '@jsonforms/react';
36
- import { FormControlLabel, Hidden } from '@material-ui/core';
36
+ import { FormControlLabel, Hidden } from '@mui/material';
37
37
  import { MuiToggle } from '../mui-controls/MuiToggle';
38
38
 
39
39
  export const MaterialBooleanToggleControl = ({
@@ -22,137 +22,105 @@
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 startsWith from 'lodash/startsWith';
26
25
  import merge from 'lodash/merge';
27
- import React from 'react';
26
+ import React, { useMemo } from 'react';
28
27
  import {
29
- computeLabel,
30
- ControlState,
31
- DispatchPropsOfControl,
28
+ ControlProps,
32
29
  isDateControl,
33
30
  isDescriptionHidden,
34
- isPlainLabel,
35
31
  RankedTester,
36
32
  rankWith,
37
- StatePropsOfControl
38
33
  } from '@jsonforms/core';
39
- import { Control, withJsonFormsControlProps } from '@jsonforms/react';
40
- import { Hidden } from '@material-ui/core';
41
- import KeyboardArrowLeftIcon from '@material-ui/icons/KeyboardArrowLeft';
42
- import KeyboardArrowRightIcon from '@material-ui/icons/KeyboardArrowRight';
43
- import EventIcon from '@material-ui/icons/Event';
44
- import moment from 'moment';
45
- import { Moment } from 'moment';
34
+ import { withJsonFormsControlProps } from '@jsonforms/react';
35
+ import { FormHelperText, Hidden, TextField } from '@mui/material';
46
36
  import {
47
- KeyboardDatePicker,
48
- MuiPickersUtilsProvider
49
- } from '@material-ui/pickers';
50
- import MomentUtils from '@date-io/moment';
37
+ DatePicker,
38
+ LocalizationProvider
39
+ } from '@mui/lab';
40
+ import AdapterDayjs from '@mui/lab/AdapterDayjs';
41
+ import { createOnChangeHandler, getData, useFocus } from '../util';
51
42
 
52
- export interface DateControl {
53
- momentLocale?: Moment;
54
- }
43
+ export const MaterialDateControl = (props: ControlProps)=> {
44
+ const [focused, onFocus, onBlur] = useFocus();
45
+ const {
46
+ description,
47
+ id,
48
+ errors,
49
+ label,
50
+ uischema,
51
+ visible,
52
+ enabled,
53
+ required,
54
+ path,
55
+ handleChange,
56
+ data,
57
+ config
58
+ } = props;
59
+ const isValid = errors.length === 0;
60
+ const appliedUiSchemaOptions = merge({}, config, uischema.options);
61
+ const showDescription = !isDescriptionHidden(
62
+ visible,
63
+ description,
64
+ focused,
65
+ appliedUiSchemaOptions.showUnfocusedDescription
66
+ );
55
67
 
56
- // Workaround typing problems in @material-ui/pickers@3.2.3
57
- const AnyPropsKeyboardDatePicker: React.FunctionComponent<
58
- any
59
- > = KeyboardDatePicker;
68
+ const format = appliedUiSchemaOptions.dateFormat ?? 'YYYY-MM-DD';
69
+ const saveFormat = appliedUiSchemaOptions.dateSaveFormat ?? 'YYYY-MM-DD';
60
70
 
61
- export class MaterialDateControl extends Control<
62
- StatePropsOfDateControl & DispatchPropsOfControl & DateControl,
63
- ControlState
64
- > {
65
- render() {
66
- const {
67
- description,
68
- id,
69
- errors,
70
- label,
71
- uischema,
72
- visible,
73
- enabled,
74
- required,
75
- path,
76
- handleChange,
77
- data,
78
- momentLocale,
79
- config
80
- } = this.props;
81
- const defaultLabel = label as string;
82
- const cancelLabel = '%cancel';
83
- const clearLabel = '%clear';
84
- const isValid = errors.length === 0;
85
- const appliedUiSchemaOptions = merge({}, config, uischema.options);
86
- const showDescription = !isDescriptionHidden(
87
- visible,
88
- description,
89
- this.state.isFocused,
90
- appliedUiSchemaOptions.showUnfocusedDescription
91
- );
92
- const inputProps = {};
93
- const localeDateTimeFormat = momentLocale
94
- ? `${momentLocale.localeData().longDateFormat('L')}`
95
- : 'YYYY-MM-DD';
71
+ const firstFormHelperText = showDescription
72
+ ? description
73
+ : !isValid
74
+ ? errors
75
+ : null;
76
+ const secondFormHelperText = showDescription && !isValid ? errors : null;
77
+ const onChange = useMemo(() => createOnChangeHandler(
78
+ path,
79
+ handleChange,
80
+ saveFormat
81
+ ),[path, handleChange, saveFormat]);
96
82
 
97
- let labelText;
98
- let labelCancel;
99
- let labelClear;
100
-
101
- if (isPlainLabel(label)) {
102
- labelText = label;
103
- labelCancel = 'Cancel';
104
- labelClear = 'Clear';
105
- } else {
106
- labelText = defaultLabel;
107
- labelCancel = startsWith(cancelLabel, '%') ? 'Cancel' : cancelLabel;
108
- labelClear = startsWith(clearLabel, '%') ? 'Clear' : clearLabel;
109
- }
110
-
111
- return (
112
- <Hidden xsUp={!visible}>
113
- <MuiPickersUtilsProvider utils={MomentUtils}>
114
- <AnyPropsKeyboardDatePicker
115
- id={id + '-input'}
116
- label={computeLabel(
117
- labelText,
118
- required,
119
- appliedUiSchemaOptions.hideRequiredAsterisk
120
- )}
121
- error={!isValid}
122
- fullWidth={!appliedUiSchemaOptions.trim}
123
- helperText={!isValid ? errors : showDescription ? description : ' '}
124
- InputLabelProps={{ shrink: true }}
125
- value={data || null}
126
- onChange={(datetime: any) =>
127
- handleChange(
128
- path,
129
- datetime ? moment(datetime).format('YYYY-MM-DD') : ''
130
- )
131
- }
132
- format={localeDateTimeFormat}
133
- clearable={true}
134
- disabled={!enabled}
135
- autoFocus={appliedUiSchemaOptions.focus}
136
- onFocus={this.onFocus}
137
- onBlur={this.onBlur}
138
- cancelLabel={labelCancel}
139
- clearLabel={labelClear}
140
- leftArrowIcon={<KeyboardArrowLeftIcon />}
141
- rightArrowIcon={<KeyboardArrowRightIcon />}
142
- keyboardIcon={<EventIcon />}
143
- InputProps={inputProps}
144
- />
145
- </MuiPickersUtilsProvider>
146
- </Hidden>
147
- );
148
- }
149
- }
150
-
151
- export interface StatePropsOfDateControl extends StatePropsOfControl {
152
- defaultLabel: string;
153
- cancelLabel: string;
154
- clearLabel: string;
155
- }
83
+ return (
84
+ <Hidden xsUp={!visible}>
85
+ <LocalizationProvider dateAdapter={AdapterDayjs}>
86
+ <DatePicker
87
+ label={label}
88
+ value={getData(data, saveFormat)}
89
+ clearable
90
+ onChange={onChange}
91
+ inputFormat={format}
92
+ disableMaskedInput
93
+ views={appliedUiSchemaOptions.views}
94
+ disabled={!enabled}
95
+ cancelText={appliedUiSchemaOptions.cancelLabel}
96
+ clearText={appliedUiSchemaOptions.clearLabel}
97
+ okText={appliedUiSchemaOptions.okLabel}
98
+ renderInput={params => (
99
+ <TextField
100
+ {...params}
101
+ id={id + '-input'}
102
+ required={required && !appliedUiSchemaOptions.hideRequiredAsterisk}
103
+ autoFocus={appliedUiSchemaOptions.focus}
104
+ error={!isValid}
105
+ fullWidth={!appliedUiSchemaOptions.trim}
106
+ inputProps={{ ...params.inputProps, type: 'text' }}
107
+ InputLabelProps={data ? { shrink: true } : undefined}
108
+ onFocus={onFocus}
109
+ onBlur={onBlur}
110
+ variant={'standard'}
111
+ />
112
+ )}
113
+ />
114
+ <FormHelperText error={!isValid && !showDescription}>
115
+ {firstFormHelperText}
116
+ </FormHelperText>
117
+ <FormHelperText error={!isValid}>
118
+ {secondFormHelperText}
119
+ </FormHelperText>
120
+ </LocalizationProvider>
121
+ </Hidden>
122
+ );
123
+ };
156
124
 
157
125
  export const materialDateControlTester: RankedTester = rankWith(
158
126
  4,
@@ -22,95 +22,108 @@
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, { useMemo } from 'react';
26
26
  import merge from 'lodash/merge';
27
27
  import {
28
- computeLabel,
29
28
  ControlProps,
30
- ControlState,
31
29
  isDateTimeControl,
32
- isPlainLabel,
30
+ isDescriptionHidden,
33
31
  RankedTester,
34
32
  rankWith
35
33
  } from '@jsonforms/core';
36
- import { Control, withJsonFormsControlProps } from '@jsonforms/react';
37
- import moment from 'moment';
38
- import { Hidden } from '@material-ui/core';
39
- import KeyboardArrowLeftIcon from '@material-ui/icons/KeyboardArrowLeft';
40
- import KeyboardArrowRightIcon from '@material-ui/icons/KeyboardArrowRight';
41
- import DateRangeIcon from '@material-ui/icons/DateRange';
42
- import EventIcon from '@material-ui/icons/Event';
43
- import AccessTimeIcon from '@material-ui/icons/AccessTime';
34
+ import { withJsonFormsControlProps } from '@jsonforms/react';
35
+ import { FormHelperText, Hidden, TextField } from '@mui/material';
44
36
  import {
45
- KeyboardDateTimePicker,
46
- MuiPickersUtilsProvider
47
- } from '@material-ui/pickers';
48
- import MomentUtils from '@date-io/moment';
37
+ DateTimePicker,
38
+ LocalizationProvider
39
+ } from '@mui/lab';
40
+ import AdapterDayjs from '@mui/lab/AdapterDayjs';
41
+ import { createOnChangeHandler, getData, useFocus } from '../util';
49
42
 
50
- // Workaround typing problems in @material-ui/pickers@3.2.3
51
- const AnyPropsKeyboardDateTimepicker: React.FunctionComponent<
52
- any
53
- > = KeyboardDateTimePicker;
43
+ export const MaterialDateTimeControl = (props: ControlProps) => {
44
+ const [focused, onFocus, onBlur] = useFocus();
45
+ const {
46
+ id,
47
+ description,
48
+ errors,
49
+ label,
50
+ uischema,
51
+ visible,
52
+ enabled,
53
+ required,
54
+ path,
55
+ handleChange,
56
+ data,
57
+ config
58
+ } = props;
59
+ const appliedUiSchemaOptions = merge({}, config, uischema.options);
60
+ const isValid = errors.length === 0;
54
61
 
55
- export class MaterialDateTimeControl extends Control<
56
- ControlProps,
57
- ControlState
58
- > {
59
- render() {
60
- const {
61
- id,
62
- description,
63
- errors,
64
- label,
65
- uischema,
66
- visible,
67
- enabled,
68
- required,
69
- path,
70
- handleChange,
71
- data,
72
- config
73
- } = this.props;
74
- const appliedUiSchemaOptions = merge({}, config, uischema.options);
75
- const isValid = errors.length === 0;
76
- const inputProps = {};
62
+ const showDescription = !isDescriptionHidden(
63
+ visible,
64
+ description,
65
+ focused,
66
+ appliedUiSchemaOptions.showUnfocusedDescription
67
+ );
68
+
69
+ const format = appliedUiSchemaOptions.dateTimeFormat ?? 'YYYY-MM-DD HH:mm';
70
+ const saveFormat = appliedUiSchemaOptions.dateTimeSaveFormat ?? undefined;
71
+
72
+ const firstFormHelperText = showDescription
73
+ ? description
74
+ : !isValid
75
+ ? errors
76
+ : null;
77
+ const secondFormHelperText = showDescription && !isValid ? errors : null;
78
+
79
+ const onChange = useMemo(() => createOnChangeHandler(
80
+ path,
81
+ handleChange,
82
+ saveFormat
83
+ ),[path, handleChange, saveFormat]);
77
84
 
78
- return (
79
- <Hidden xsUp={!visible}>
80
- <MuiPickersUtilsProvider utils={MomentUtils}>
81
- <AnyPropsKeyboardDateTimepicker
82
- id={id + '-input'}
83
- label={computeLabel(
84
- isPlainLabel(label) ? label : label.default,
85
- required,
86
- appliedUiSchemaOptions.hideRequiredAsterisk
87
- )}
88
- error={!isValid}
89
- fullWidth={!appliedUiSchemaOptions.trim}
90
- onFocus={this.onFocus}
91
- onBlur={this.onBlur}
92
- helperText={!isValid ? errors : description}
93
- InputLabelProps={{ shrink: true }}
94
- value={data || null}
95
- onChange={(datetime: any) =>
96
- handleChange(path, datetime ? moment(datetime).format() : '')
97
- }
98
- format='MM/DD/YYYY h:mm a'
99
- clearable={true}
100
- disabled={!enabled}
101
- autoFocus={appliedUiSchemaOptions.focus}
102
- leftArrowIcon={<KeyboardArrowLeftIcon />}
103
- rightArrowIcon={<KeyboardArrowRightIcon />}
104
- dateRangeIcon={<DateRangeIcon />}
105
- keyboardIcon={<EventIcon />}
106
- timeIcon={<AccessTimeIcon />}
107
- InputProps={inputProps}
108
- />
109
- </MuiPickersUtilsProvider>
110
- </Hidden>
111
- );
112
- }
113
- }
85
+ return (
86
+ <Hidden xsUp={!visible}>
87
+ <LocalizationProvider dateAdapter={AdapterDayjs}>
88
+ <DateTimePicker
89
+ label={label}
90
+ value={getData(data, saveFormat)}
91
+ clearable
92
+ onChange={onChange}
93
+ inputFormat={format}
94
+ disableMaskedInput
95
+ ampm={!!appliedUiSchemaOptions.ampm}
96
+ views={appliedUiSchemaOptions.views}
97
+ disabled={!enabled}
98
+ cancelText={appliedUiSchemaOptions.cancelLabel}
99
+ clearText={appliedUiSchemaOptions.clearLabel}
100
+ okText={appliedUiSchemaOptions.okLabel}
101
+ renderInput={params => (
102
+ <TextField
103
+ {...params}
104
+ id={id + '-input'}
105
+ required={required && !appliedUiSchemaOptions.hideRequiredAsterisk}
106
+ autoFocus={appliedUiSchemaOptions.focus}
107
+ error={!isValid}
108
+ fullWidth={!appliedUiSchemaOptions.trim}
109
+ inputProps={{ ...params.inputProps, type: 'text' }}
110
+ InputLabelProps={data ? { shrink: true } : undefined}
111
+ onFocus={onFocus}
112
+ onBlur={onBlur}
113
+ variant={'standard'}
114
+ />
115
+ )}
116
+ />
117
+ <FormHelperText error={!isValid && !showDescription}>
118
+ {firstFormHelperText}
119
+ </FormHelperText>
120
+ <FormHelperText error={!isValid}>
121
+ {secondFormHelperText}
122
+ </FormHelperText>
123
+ </LocalizationProvider>
124
+ </Hidden>
125
+ );
126
+ };
114
127
 
115
128
  export const materialDateTimeControlTester: RankedTester = rankWith(
116
129
  2,
@@ -32,11 +32,20 @@ import {
32
32
  } from '@jsonforms/core';
33
33
  import { withJsonFormsEnumProps } from '@jsonforms/react';
34
34
  import { MuiSelect } from '../mui-controls/MuiSelect';
35
+ import merge from 'lodash/merge';
35
36
  import { MaterialInputControl } from './MaterialInputControl';
37
+ import { MuiAutocomplete, WithOptionLabel } from '../mui-controls/MuiAutocomplete';
36
38
 
37
- export const MaterialEnumControl = (props: ControlProps & OwnPropsOfEnum) => (
38
- <MaterialInputControl {...props} input={MuiSelect} />
39
- );
39
+ export const MaterialEnumControl = (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 materialEnumControlTester: RankedTester = rankWith(
42
51
  2,