@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
@@ -1,7 +1,7 @@
1
1
  /*
2
2
  The MIT License
3
3
 
4
- Copyright (c) 2017-2019 EclipseSource Munich
4
+ Copyright (c) 2017-2021 EclipseSource Munich
5
5
  https://github.com/eclipsesource/jsonforms
6
6
 
7
7
  Permission is hereby granted, free of charge, to any person obtaining a copy
@@ -24,88 +24,81 @@
24
24
  */
25
25
  import React from 'react';
26
26
  import {
27
- computeLabel,
27
+ showAsRequired,
28
28
  ControlProps,
29
- ControlState,
30
29
  isDescriptionHidden,
31
- isPlainLabel
32
30
  } from '@jsonforms/core';
33
- import { Control } from '@jsonforms/react';
34
31
 
35
- import { Hidden, InputLabel } from '@material-ui/core';
36
- import { FormControl, FormHelperText } from '@material-ui/core';
32
+ import { Hidden, InputLabel } from '@mui/material';
33
+ import { FormControl, FormHelperText } from '@mui/material';
37
34
  import merge from 'lodash/merge';
35
+ import { useFocus } from '../util';
38
36
 
39
37
  export interface WithInput {
40
38
  input: any;
41
39
  }
42
40
 
43
- export abstract class MaterialInputControl extends Control<
44
- ControlProps & WithInput,
45
- ControlState
46
- > {
47
- render() {
48
- const {
49
- id,
50
- description,
51
- errors,
52
- label,
53
- uischema,
54
- visible,
55
- required,
56
- config,
57
- input
58
- } = this.props;
59
- const isValid = errors.length === 0;
60
- const appliedUiSchemaOptions = merge({}, config, uischema.options);
41
+ export const MaterialInputControl = (props: ControlProps & WithInput) => {
42
+ const [focused, onFocus, onBlur] = useFocus();
43
+ const {
44
+ id,
45
+ description,
46
+ errors,
47
+ label,
48
+ uischema,
49
+ visible,
50
+ required,
51
+ config,
52
+ input
53
+ } = props;
54
+ const isValid = errors.length === 0;
55
+ const appliedUiSchemaOptions = merge({}, config, uischema.options);
61
56
 
62
- const showDescription = !isDescriptionHidden(
63
- visible,
64
- description,
65
- this.state.isFocused,
66
- appliedUiSchemaOptions.showUnfocusedDescription
67
- );
57
+ const showDescription = !isDescriptionHidden(
58
+ visible,
59
+ description,
60
+ focused,
61
+ appliedUiSchemaOptions.showUnfocusedDescription
62
+ );
68
63
 
69
- const firstFormHelperText = showDescription
70
- ? description
71
- : !isValid
72
- ? errors
73
- : null;
74
- const secondFormHelperText = showDescription && !isValid ? errors : null;
75
- const InnerComponent = input;
64
+ const firstFormHelperText = showDescription
65
+ ? description
66
+ : !isValid
67
+ ? errors
68
+ : null;
69
+ const secondFormHelperText = showDescription && !isValid ? errors : null;
70
+ const InnerComponent = input;
76
71
 
77
- return (
78
- <Hidden xsUp={!visible}>
79
- <FormControl
80
- fullWidth={!appliedUiSchemaOptions.trim}
81
- onFocus={this.onFocus}
82
- onBlur={this.onBlur}
83
- id={id}
72
+ return (
73
+ <Hidden xsUp={!visible}>
74
+ <FormControl
75
+ fullWidth={!appliedUiSchemaOptions.trim}
76
+ onFocus={onFocus}
77
+ onBlur={onBlur}
78
+ id={id}
79
+ variant={'standard'}
80
+ >
81
+ <InputLabel
82
+ htmlFor={id + '-input'}
83
+ error={!isValid}
84
+ required={showAsRequired(required,
85
+ appliedUiSchemaOptions.hideRequiredAsterisk)}
84
86
  >
85
- <InputLabel
86
- htmlFor={id + '-input'}
87
- error={!isValid}
88
- >
89
- {computeLabel(
90
- isPlainLabel(label) ? label : label.default,
91
- required,
92
- appliedUiSchemaOptions.hideRequiredAsterisk
93
- )}
94
- </InputLabel>
95
- <InnerComponent
96
- {...this.props}
97
- id={id + '-input'}
98
- isValid={isValid}
99
- visible={visible}
100
- />
101
- <FormHelperText error={!isValid && !showDescription}>
102
- {firstFormHelperText}
103
- </FormHelperText>
104
- <FormHelperText error={!isValid}>
105
- {secondFormHelperText}
106
- </FormHelperText>
107
- </FormControl>
108
- </Hidden>
109
- );
110
- }
111
- }
87
+ {label}
88
+ </InputLabel>
89
+ <InnerComponent
90
+ {...props}
91
+ id={id + '-input'}
92
+ isValid={isValid}
93
+ visible={visible}
94
+ />
95
+ <FormHelperText error={!isValid && !showDescription}>
96
+ {firstFormHelperText}
97
+ </FormHelperText>
98
+ <FormHelperText error={!isValid}>
99
+ {secondFormHelperText}
100
+ </FormHelperText>
101
+ </FormControl>
102
+ </Hidden>
103
+ );
104
+ };
@@ -24,77 +24,72 @@
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
- isPlainLabel,
33
31
  isTimeControl,
34
32
  or,
35
33
  RankedTester,
36
34
  rankWith
37
35
  } from '@jsonforms/core';
38
- import { Hidden } from '@material-ui/core';
39
- import { Control, withJsonFormsControlProps } from '@jsonforms/react';
40
- import TextField from '@material-ui/core/TextField';
36
+ import { Hidden, TextField } from '@mui/material';
37
+ import { withJsonFormsControlProps } from '@jsonforms/react';
41
38
  import merge from 'lodash/merge';
39
+ import { useDebouncedChange, useFocus } from '../util';
42
40
 
43
- export class MaterialNativeControl extends Control<ControlProps, ControlState> {
44
- render() {
45
- const {
46
- id,
47
- errors,
48
- label,
49
- schema,
50
- description,
51
- enabled,
52
- visible,
53
- required,
54
- path,
55
- handleChange,
56
- data,
57
- config
58
- } = this.props;
59
- const isValid = errors.length === 0;
60
- const appliedUiSchemaOptions = merge(
61
- {},
62
- config,
63
- this.props.uischema.options
64
- );
65
- const onChange = (ev: any) => handleChange(path, ev.target.value);
66
- const fieldType = schema.format;
67
- const showDescription = !isDescriptionHidden(
68
- visible,
69
- description,
70
- this.state.isFocused,
71
- appliedUiSchemaOptions.showUnfocusedDescription
72
- );
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
+ );
73
71
 
74
- return (
75
- <Hidden xsUp={!visible}>
76
- <TextField
77
- id={id + '-input'}
78
- label={computeLabel(
79
- isPlainLabel(label) ? label : label.default,
80
- required,
81
- appliedUiSchemaOptions.hideRequiredAsterisk
82
- )}
83
- type={fieldType}
84
- error={!isValid}
85
- disabled={!enabled}
86
- fullWidth={!appliedUiSchemaOptions.trim}
87
- onFocus={this.onFocus}
88
- onBlur={this.onBlur}
89
- helperText={!isValid ? errors : showDescription ? description : null}
90
- InputLabelProps={{ shrink: true }}
91
- value={data}
92
- onChange={onChange}
93
- />
94
- </Hidden>
95
- );
96
- }
97
- }
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
+ };
98
93
 
99
94
  export const materialNativeControlTester: RankedTester = rankWith(
100
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,90 +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
- isPlainLabel,
33
31
  OwnPropsOfEnum
34
32
  } from '@jsonforms/core';
35
- import { Control } from '@jsonforms/react';
36
- import Radio from '@material-ui/core/Radio';
37
- import RadioGroup from '@material-ui/core/RadioGroup';
38
33
  import {
39
34
  FormControl,
40
35
  FormControlLabel,
41
36
  FormHelperText,
42
37
  FormLabel,
43
- Hidden
44
- } from '@material-ui/core';
38
+ Hidden,
39
+ Radio,
40
+ RadioGroup
41
+ } from '@mui/material';
42
+ import { useFocus } from '../util';
45
43
 
46
- export class MaterialRadioGroup extends Control<
47
- ControlProps & OwnPropsOfEnum,
48
- ControlState
49
- > {
50
- render() {
51
- const {
52
- config,
53
- id,
54
- label,
55
- required,
56
- description,
57
- errors,
58
- data,
59
- visible,
60
- options
61
- } = this.props;
62
- const isValid = errors.length === 0;
63
- const appliedUiSchemaOptions = merge(
64
- {},
65
- config,
66
- this.props.uischema.options
67
- );
68
- const showDescription = !isDescriptionHidden(
69
- visible,
70
- description,
71
- this.state.isFocused,
72
- appliedUiSchemaOptions.showUnfocusedDescription
73
- );
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);
74
73
 
75
- return (
76
- <Hidden xsUp={!visible}>
77
- <FormControl
78
- component={'fieldset' as 'div'}
79
- 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)}
80
88
  >
81
- <FormLabel
82
- htmlFor={id}
83
- error={!isValid}
84
- component={'legend' as 'label'}
85
- >
86
- {computeLabel(
87
- isPlainLabel(label) ? label : label.default,
88
- required,
89
- appliedUiSchemaOptions.hideRequiredAsterisk
90
- )}
91
- </FormLabel>
89
+ {label}
90
+ </FormLabel>
92
91
 
93
- <RadioGroup
94
- value={this.state.value}
95
- onChange={(_ev, value) => this.handleChange(value)}
96
- row={true}
97
- >
98
- {options.map(option => (
99
- <FormControlLabel
100
- value={option.value}
101
- key={option.label}
102
- control={<Radio checked={data === option.value} />}
103
- label={option.label}
104
- />
105
- ))}
106
- </RadioGroup>
107
- <FormHelperText error={!isValid}>
108
- {!isValid ? errors : showDescription ? description : null}
109
- </FormHelperText>
110
- </FormControl>
111
- </Hidden>
112
- );
113
- }
114
- }
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(