@jsonforms/material-renderers 2.5.2 → 3.0.0-alpha.3

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 (357) 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 +1040 -328
  7. package/docs/index.html +84 -51
  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 +5 -20
  37. package/lib/additional/ListWithDetailMasterItem.d.ts +1 -1
  38. package/lib/additional/ListWithDetailMasterItem.js +8 -8
  39. package/lib/additional/ListWithDetailMasterItem.js.map +1 -1
  40. package/lib/additional/MaterialLabelRenderer.d.ts +1 -1
  41. package/lib/additional/MaterialLabelRenderer.js +6 -4
  42. package/lib/additional/MaterialLabelRenderer.js.map +1 -1
  43. package/lib/additional/MaterialListWithDetailRenderer.d.ts +1 -1
  44. package/lib/additional/MaterialListWithDetailRenderer.js +10 -8
  45. package/lib/additional/MaterialListWithDetailRenderer.js.map +1 -1
  46. package/lib/additional/index.js +3 -2
  47. package/lib/additional/index.js.map +1 -1
  48. package/lib/cells/CustomizableCells.d.ts +1 -0
  49. package/lib/cells/CustomizableCells.js +11 -8
  50. package/lib/cells/CustomizableCells.js.map +1 -1
  51. package/lib/cells/MaterialBooleanCell.d.ts +1 -1
  52. package/lib/cells/MaterialBooleanCell.js +3 -1
  53. package/lib/cells/MaterialBooleanCell.js.map +1 -1
  54. package/lib/cells/MaterialBooleanToggleCell.d.ts +1 -1
  55. package/lib/cells/MaterialBooleanToggleCell.js +3 -1
  56. package/lib/cells/MaterialBooleanToggleCell.js.map +1 -1
  57. package/lib/cells/MaterialDateCell.d.ts +1 -1
  58. package/lib/cells/MaterialDateCell.js +4 -2
  59. package/lib/cells/MaterialDateCell.js.map +1 -1
  60. package/lib/cells/MaterialEnumCell.d.ts +1 -1
  61. package/lib/cells/MaterialEnumCell.js +3 -1
  62. package/lib/cells/MaterialEnumCell.js.map +1 -1
  63. package/lib/cells/MaterialIntegerCell.d.ts +1 -1
  64. package/lib/cells/MaterialIntegerCell.js +3 -1
  65. package/lib/cells/MaterialIntegerCell.js.map +1 -1
  66. package/lib/cells/MaterialNumberCell.d.ts +1 -1
  67. package/lib/cells/MaterialNumberCell.js +3 -1
  68. package/lib/cells/MaterialNumberCell.js.map +1 -1
  69. package/lib/cells/MaterialNumberFormatCell.d.ts +1 -1
  70. package/lib/cells/MaterialNumberFormatCell.js +3 -1
  71. package/lib/cells/MaterialNumberFormatCell.js.map +1 -1
  72. package/lib/cells/MaterialOneOfEnumCell.d.ts +10 -0
  73. package/lib/cells/MaterialOneOfEnumCell.js +41 -0
  74. package/lib/cells/MaterialOneOfEnumCell.js.map +1 -0
  75. package/lib/cells/MaterialTextCell.d.ts +1 -1
  76. package/lib/cells/MaterialTextCell.js +3 -1
  77. package/lib/cells/MaterialTextCell.js.map +1 -1
  78. package/lib/cells/MaterialTimeCell.d.ts +1 -1
  79. package/lib/cells/MaterialTimeCell.js +3 -1
  80. package/lib/cells/MaterialTimeCell.js.map +1 -1
  81. package/lib/cells/index.d.ts +2 -1
  82. package/lib/cells/index.js +13 -9
  83. package/lib/cells/index.js.map +1 -1
  84. package/lib/complex/CombinatorProperties.js +4 -2
  85. package/lib/complex/CombinatorProperties.js.map +1 -1
  86. package/lib/complex/DeleteDialog.js +9 -9
  87. package/lib/complex/DeleteDialog.js.map +1 -1
  88. package/lib/complex/MaterialAllOfRenderer.d.ts +3 -2
  89. package/lib/complex/MaterialAllOfRenderer.js +12 -10
  90. package/lib/complex/MaterialAllOfRenderer.js.map +1 -1
  91. package/lib/complex/MaterialAnyOfRenderer.d.ts +3 -2
  92. package/lib/complex/MaterialAnyOfRenderer.js +7 -5
  93. package/lib/complex/MaterialAnyOfRenderer.js.map +1 -1
  94. package/lib/complex/MaterialArrayControlRenderer.d.ts +1 -1
  95. package/lib/complex/MaterialArrayControlRenderer.js +5 -3
  96. package/lib/complex/MaterialArrayControlRenderer.js.map +1 -1
  97. package/lib/complex/MaterialEnumArrayRenderer.d.ts +2 -2
  98. package/lib/complex/MaterialEnumArrayRenderer.js +12 -9
  99. package/lib/complex/MaterialEnumArrayRenderer.js.map +1 -1
  100. package/lib/complex/MaterialObjectRenderer.d.ts +3 -2
  101. package/lib/complex/MaterialObjectRenderer.js +7 -5
  102. package/lib/complex/MaterialObjectRenderer.js.map +1 -1
  103. package/lib/complex/MaterialOneOfRenderer.d.ts +2 -1
  104. package/lib/complex/MaterialOneOfRenderer.js +16 -15
  105. package/lib/complex/MaterialOneOfRenderer.js.map +1 -1
  106. package/lib/complex/MaterialTableControl.d.ts +16 -1
  107. package/lib/complex/MaterialTableControl.js +42 -35
  108. package/lib/complex/MaterialTableControl.js.map +1 -1
  109. package/lib/complex/NoBorderTableCell.d.ts +2 -2
  110. package/lib/complex/NoBorderTableCell.js +8 -10
  111. package/lib/complex/NoBorderTableCell.js.map +1 -1
  112. package/lib/complex/TableToolbar.d.ts +2 -2
  113. package/lib/complex/TableToolbar.js +12 -14
  114. package/lib/complex/TableToolbar.js.map +1 -1
  115. package/lib/complex/ValidationIcon.d.ts +2 -6
  116. package/lib/complex/ValidationIcon.js +9 -13
  117. package/lib/complex/ValidationIcon.js.map +1 -1
  118. package/lib/complex/index.js +6 -5
  119. package/lib/complex/index.js.map +1 -1
  120. package/lib/controls/MaterialAnyOfStringOrEnumControl.d.ts +1 -1
  121. package/lib/controls/MaterialAnyOfStringOrEnumControl.js +18 -13
  122. package/lib/controls/MaterialAnyOfStringOrEnumControl.js.map +1 -1
  123. package/lib/controls/MaterialBooleanControl.d.ts +1 -1
  124. package/lib/controls/MaterialBooleanControl.js +6 -4
  125. package/lib/controls/MaterialBooleanControl.js.map +1 -1
  126. package/lib/controls/MaterialBooleanToggleControl.d.ts +1 -1
  127. package/lib/controls/MaterialBooleanToggleControl.js +6 -4
  128. package/lib/controls/MaterialBooleanToggleControl.js.map +1 -1
  129. package/lib/controls/MaterialDateControl.d.ts +3 -15
  130. package/lib/controls/MaterialDateControl.js +29 -50
  131. package/lib/controls/MaterialDateControl.js.map +1 -1
  132. package/lib/controls/MaterialDateTimeControl.d.ts +3 -6
  133. package/lib/controls/MaterialDateTimeControl.js +29 -31
  134. package/lib/controls/MaterialDateTimeControl.js.map +1 -1
  135. package/lib/controls/MaterialEnumControl.d.ts +1 -1
  136. package/lib/controls/MaterialEnumControl.js +3 -1
  137. package/lib/controls/MaterialEnumControl.js.map +1 -1
  138. package/lib/controls/MaterialInputControl.d.ts +2 -5
  139. package/lib/controls/MaterialInputControl.js +25 -30
  140. package/lib/controls/MaterialInputControl.js.map +1 -1
  141. package/lib/controls/MaterialIntegerControl.d.ts +1 -1
  142. package/lib/controls/MaterialIntegerControl.js +3 -1
  143. package/lib/controls/MaterialIntegerControl.js.map +1 -1
  144. package/lib/controls/MaterialNativeControl.d.ts +3 -6
  145. package/lib/controls/MaterialNativeControl.js +16 -20
  146. package/lib/controls/MaterialNativeControl.js.map +1 -1
  147. package/lib/controls/MaterialNumberControl.d.ts +1 -1
  148. package/lib/controls/MaterialNumberControl.js +3 -1
  149. package/lib/controls/MaterialNumberControl.js.map +1 -1
  150. package/lib/controls/MaterialOneOfEnumControl.d.ts +1 -1
  151. package/lib/controls/MaterialOneOfEnumControl.js +3 -1
  152. package/lib/controls/MaterialOneOfEnumControl.js.map +1 -1
  153. package/lib/controls/MaterialOneOfRadioGroupControl.d.ts +1 -1
  154. package/lib/controls/MaterialOneOfRadioGroupControl.js +3 -1
  155. package/lib/controls/MaterialOneOfRadioGroupControl.js.map +1 -1
  156. package/lib/controls/MaterialRadioGroup.d.ts +2 -5
  157. package/lib/controls/MaterialRadioGroup.js +16 -23
  158. package/lib/controls/MaterialRadioGroup.js.map +1 -1
  159. package/lib/controls/MaterialRadioGroupControl.d.ts +1 -1
  160. package/lib/controls/MaterialRadioGroupControl.js +3 -1
  161. package/lib/controls/MaterialRadioGroupControl.js.map +1 -1
  162. package/lib/controls/MaterialSliderControl.d.ts +3 -6
  163. package/lib/controls/MaterialSliderControl.js +36 -40
  164. package/lib/controls/MaterialSliderControl.js.map +1 -1
  165. package/lib/controls/MaterialTextControl.d.ts +1 -1
  166. package/lib/controls/MaterialTextControl.js +3 -1
  167. package/lib/controls/MaterialTextControl.js.map +1 -1
  168. package/lib/controls/MaterialTimeControl.d.ts +6 -0
  169. package/lib/controls/MaterialTimeControl.js +62 -0
  170. package/lib/controls/MaterialTimeControl.js.map +1 -0
  171. package/lib/controls/index.d.ts +11 -9
  172. package/lib/controls/index.js +19 -14
  173. package/lib/controls/index.js.map +1 -1
  174. package/lib/extended/MaterialAutocompleteEnumControl.d.ts +1 -1
  175. package/lib/extended/MaterialAutocompleteEnumControl.js +3 -1
  176. package/lib/extended/MaterialAutocompleteEnumControl.js.map +1 -1
  177. package/lib/extended/MaterialAutocompleteOneOfEnumControl.d.ts +1 -1
  178. package/lib/extended/MaterialAutocompleteOneOfEnumControl.js +3 -1
  179. package/lib/extended/MaterialAutocompleteOneOfEnumControl.js.map +1 -1
  180. package/lib/extended/MuiAutocomplete.d.ts +3 -4
  181. package/lib/extended/MuiAutocomplete.js +7 -7
  182. package/lib/extended/MuiAutocomplete.js.map +1 -1
  183. package/lib/extended/index.d.ts +3 -3
  184. package/lib/extended/index.js +3 -2
  185. package/lib/extended/index.js.map +1 -1
  186. package/lib/index.js +3 -0
  187. package/lib/index.js.map +1 -1
  188. package/lib/jsonforms-material.js +248 -315
  189. package/lib/jsonforms-material.js.map +1 -1
  190. package/lib/layouts/ArrayToolbar.js +14 -16
  191. package/lib/layouts/ArrayToolbar.js.map +1 -1
  192. package/lib/layouts/ExpandPanelRenderer.d.ts +2 -3
  193. package/lib/layouts/ExpandPanelRenderer.js +47 -45
  194. package/lib/layouts/ExpandPanelRenderer.js.map +1 -1
  195. package/lib/layouts/MaterialArrayLayout.d.ts +1 -11
  196. package/lib/layouts/MaterialArrayLayout.js +19 -31
  197. package/lib/layouts/MaterialArrayLayout.js.map +1 -1
  198. package/lib/layouts/MaterialArrayLayoutRenderer.d.ts +1 -1
  199. package/lib/layouts/MaterialArrayLayoutRenderer.js +5 -3
  200. package/lib/layouts/MaterialArrayLayoutRenderer.js.map +1 -1
  201. package/lib/layouts/MaterialCategorizationLayout.d.ts +2 -10
  202. package/lib/layouts/MaterialCategorizationLayout.js +35 -52
  203. package/lib/layouts/MaterialCategorizationLayout.js.map +1 -1
  204. package/lib/layouts/MaterialCategorizationStepperLayout.d.ts +2 -9
  205. package/lib/layouts/MaterialCategorizationStepperLayout.js +45 -56
  206. package/lib/layouts/MaterialCategorizationStepperLayout.js.map +1 -1
  207. package/lib/layouts/MaterialGroupLayout.d.ts +1 -1
  208. package/lib/layouts/MaterialGroupLayout.js +11 -9
  209. package/lib/layouts/MaterialGroupLayout.js.map +1 -1
  210. package/lib/layouts/MaterialHorizontalLayout.d.ts +1 -1
  211. package/lib/layouts/MaterialHorizontalLayout.js +3 -1
  212. package/lib/layouts/MaterialHorizontalLayout.js.map +1 -1
  213. package/lib/layouts/MaterialVerticalLayout.d.ts +1 -1
  214. package/lib/layouts/MaterialVerticalLayout.js +3 -1
  215. package/lib/layouts/MaterialVerticalLayout.js.map +1 -1
  216. package/lib/layouts/index.js +6 -5
  217. package/lib/layouts/index.js.map +1 -1
  218. package/lib/mui-controls/MuiCheckbox.js +4 -4
  219. package/lib/mui-controls/MuiCheckbox.js.map +1 -1
  220. package/lib/mui-controls/MuiInputInteger.js +10 -7
  221. package/lib/mui-controls/MuiInputInteger.js.map +1 -1
  222. package/lib/mui-controls/MuiInputNumber.js +10 -7
  223. package/lib/mui-controls/MuiInputNumber.js.map +1 -1
  224. package/lib/mui-controls/MuiInputNumberFormat.js +8 -9
  225. package/lib/mui-controls/MuiInputNumberFormat.js.map +1 -1
  226. package/lib/mui-controls/MuiInputText.d.ts +1 -1
  227. package/lib/mui-controls/MuiInputText.js +17 -13
  228. package/lib/mui-controls/MuiInputText.js.map +1 -1
  229. package/lib/mui-controls/MuiInputTime.js +6 -4
  230. package/lib/mui-controls/MuiInputTime.js.map +1 -1
  231. package/lib/mui-controls/MuiSelect.js +4 -5
  232. package/lib/mui-controls/MuiSelect.js.map +1 -1
  233. package/lib/mui-controls/MuiToggle.js +4 -4
  234. package/lib/mui-controls/MuiToggle.js.map +1 -1
  235. package/lib/util/datejs.d.ts +3 -0
  236. package/lib/util/datejs.js +29 -0
  237. package/lib/util/datejs.js.map +1 -0
  238. package/lib/util/debounce.d.ts +1 -0
  239. package/lib/util/debounce.js +48 -0
  240. package/lib/util/debounce.js.map +1 -0
  241. package/lib/util/focus.d.ts +1 -0
  242. package/lib/util/focus.js +36 -0
  243. package/lib/util/focus.js.map +1 -0
  244. package/lib/util/index.d.ts +3 -0
  245. package/lib/util/index.js +4 -0
  246. package/lib/util/index.js.map +1 -1
  247. package/lib/util/layout.d.ts +2 -1
  248. package/lib/util/layout.js +13 -9
  249. package/lib/util/layout.js.map +1 -1
  250. package/lib/util/theme.d.ts +1 -1
  251. package/package.json +22 -26
  252. package/src/additional/ListWithDetailMasterItem.tsx +3 -6
  253. package/src/additional/MaterialLabelRenderer.tsx +1 -1
  254. package/src/additional/MaterialListWithDetailRenderer.tsx +4 -5
  255. package/src/cells/CustomizableCells.ts +1 -0
  256. package/src/cells/MaterialDateCell.tsx +1 -1
  257. package/src/cells/MaterialOneOfEnumCell.tsx +46 -0
  258. package/src/cells/MaterialTimeCell.tsx +1 -0
  259. package/src/cells/index.ts +5 -0
  260. package/src/complex/CombinatorProperties.tsx +2 -2
  261. package/src/complex/DeleteDialog.tsx +2 -2
  262. package/src/complex/MaterialAllOfRenderer.tsx +6 -5
  263. package/src/complex/MaterialAnyOfRenderer.tsx +5 -4
  264. package/src/complex/MaterialArrayControlRenderer.tsx +1 -1
  265. package/src/complex/MaterialEnumArrayRenderer.tsx +2 -1
  266. package/src/complex/MaterialObjectRenderer.tsx +6 -6
  267. package/src/complex/MaterialOneOfRenderer.tsx +9 -9
  268. package/src/complex/MaterialTableControl.tsx +45 -37
  269. package/src/complex/NoBorderTableCell.tsx +10 -12
  270. package/src/complex/TableToolbar.tsx +10 -9
  271. package/src/complex/ValidationIcon.tsx +12 -19
  272. package/src/controls/MaterialAnyOfStringOrEnumControl.tsx +17 -14
  273. package/src/controls/MaterialBooleanControl.tsx +1 -1
  274. package/src/controls/MaterialBooleanToggleControl.tsx +1 -1
  275. package/src/controls/MaterialDateControl.tsx +87 -119
  276. package/src/controls/MaterialDateTimeControl.tsx +91 -78
  277. package/src/controls/MaterialEnumControl.tsx +1 -1
  278. package/src/controls/MaterialInputControl.tsx +65 -72
  279. package/src/controls/MaterialNativeControl.tsx +55 -60
  280. package/src/controls/MaterialOneOfEnumControl.tsx +1 -1
  281. package/src/controls/MaterialOneOfRadioGroupControl.tsx +4 -4
  282. package/src/controls/MaterialRadioGroup.tsx +73 -74
  283. package/src/controls/MaterialRadioGroupControl.tsx +1 -1
  284. package/src/controls/MaterialSliderControl.tsx +93 -89
  285. package/src/controls/MaterialTimeControl.tsx +133 -0
  286. package/src/controls/index.ts +7 -0
  287. package/src/extended/MuiAutocomplete.tsx +11 -9
  288. package/src/extended/index.ts +1 -1
  289. package/src/index.ts +6 -0
  290. package/src/layouts/ArrayToolbar.tsx +11 -7
  291. package/src/layouts/ExpandPanelRenderer.tsx +46 -44
  292. package/src/layouts/MaterialArrayLayout.tsx +73 -83
  293. package/src/layouts/MaterialArrayLayoutRenderer.tsx +1 -1
  294. package/src/layouts/MaterialCategorizationLayout.tsx +50 -67
  295. package/src/layouts/MaterialCategorizationStepperLayout.tsx +80 -88
  296. package/src/layouts/MaterialGroupLayout.tsx +1 -1
  297. package/src/mui-controls/MuiCheckbox.tsx +2 -3
  298. package/src/mui-controls/MuiInputInteger.tsx +13 -10
  299. package/src/mui-controls/MuiInputNumber.tsx +10 -7
  300. package/src/mui-controls/MuiInputNumberFormat.tsx +9 -12
  301. package/src/mui-controls/MuiInputText.tsx +30 -21
  302. package/src/mui-controls/MuiInputTime.tsx +7 -5
  303. package/src/mui-controls/MuiSelect.tsx +4 -5
  304. package/src/mui-controls/MuiToggle.tsx +2 -3
  305. package/src/util/datejs.ts +32 -0
  306. package/src/util/debounce.ts +43 -0
  307. package/src/util/focus.ts +32 -0
  308. package/src/util/index.ts +3 -0
  309. package/src/util/layout.tsx +7 -8
  310. package/src/util/theme.ts +1 -1
  311. package/test/renderers/MaterialAllOfRenderer.test.tsx +1 -1
  312. package/test/renderers/MaterialAnyOfRenderer.test.tsx +15 -9
  313. package/test/renderers/MaterialAnyOfStringOrEnumControl.test.tsx +1 -1
  314. package/test/renderers/MaterialArrayControl.test.tsx +1 -1
  315. package/test/renderers/MaterialArrayLayout.test.tsx +9 -9
  316. package/test/renderers/MaterialBooleanCell.test.tsx +1 -1
  317. package/test/renderers/MaterialBooleanToggleCell.test.tsx +3 -2
  318. package/test/renderers/MaterialBooleanToggleControl.test.tsx +3 -3
  319. package/test/renderers/MaterialCategorizationLayout.test.tsx +75 -2
  320. package/test/renderers/MaterialCategorizationStepperLayout.test.tsx +75 -2
  321. package/test/renderers/MaterialDateCell.test.tsx +1 -1
  322. package/test/renderers/MaterialDateControl.test.tsx +46 -2
  323. package/test/renderers/MaterialDateTimeControl.test.tsx +57 -12
  324. package/test/renderers/MaterialEnumArrayRenderer.test.tsx +1 -1
  325. package/test/renderers/MaterialEnumCell.test.tsx +1 -1
  326. package/test/renderers/MaterialGroupLayout.test.tsx +1 -1
  327. package/test/renderers/MaterialInputControl.test.tsx +4 -4
  328. package/test/renderers/MaterialIntegerCell.test.tsx +42 -21
  329. package/test/renderers/MaterialLabelRenderer.test.tsx +1 -1
  330. package/test/renderers/MaterialLayouts.test.tsx +1 -1
  331. package/test/renderers/MaterialListWithDetailRenderer.test.tsx +2 -2
  332. package/test/renderers/MaterialNativeControl.test.tsx +2 -2
  333. package/test/renderers/MaterialNumberCell.test.tsx +46 -25
  334. package/test/renderers/MaterialObjectControl.test.tsx +1 -1
  335. package/test/renderers/MaterialOneOfEnumCell.test.tsx +93 -0
  336. package/test/renderers/MaterialOneOfRadioGroupControl.test.tsx +1 -1
  337. package/test/renderers/MaterialOneOfRenderer.test.tsx +20 -14
  338. package/test/renderers/MaterialRadioGroupControl.test.tsx +1 -1
  339. package/test/renderers/MaterialSliderControl.test.tsx +2 -2
  340. package/test/renderers/MaterialTextCell.test.tsx +47 -33
  341. package/test/renderers/MaterialTextControl.test.tsx +8 -4
  342. package/test/renderers/MaterialTimeCell.test.tsx +42 -21
  343. package/test/renderers/MaterialTimeControl.test.tsx +380 -0
  344. package/webpack/webpack.build.js +3 -3
  345. package/docs/classes/materialarraylayout.html +0 -777
  346. package/docs/classes/materialcategorizationlayoutrenderer.html +0 -786
  347. package/docs/classes/materialcategorizationstepperlayoutrenderer.html +0 -762
  348. package/docs/classes/materialdatecontrol.html +0 -825
  349. package/docs/classes/materialdatetimecontrol.html +0 -825
  350. package/docs/classes/materialinputcontrol.html +0 -825
  351. package/docs/classes/materialnativecontrol.html +0 -825
  352. package/docs/classes/materialradiogroup.html +0 -825
  353. package/docs/classes/materialslidercontrol.html +0 -825
  354. package/docs/interfaces/datecontrol.html +0 -157
  355. package/docs/interfaces/materialarraylayoutstate.html +0 -157
  356. package/docs/interfaces/statepropsofdatecontrol.html +0 -468
  357. package/example/CustomAutocomplete.tsx +0 -54
@@ -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,
@@ -35,7 +35,7 @@ import { MuiSelect } from '../mui-controls/MuiSelect';
35
35
  import { MaterialInputControl } from './MaterialInputControl';
36
36
 
37
37
  export const MaterialOneOfEnumControl = (props: ControlProps & OwnPropsOfEnum) => (
38
- <MaterialInputControl {...props} input={MuiSelect} />
38
+ <MaterialInputControl {...props} input={MuiSelect} />
39
39
  );
40
40
 
41
41
  export const materialOneOfEnumControlTester: RankedTester = rankWith(
@@ -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(
@@ -22,115 +22,119 @@
22
22
  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
23
  THE SOFTWARE.
24
24
  */
25
- import React from 'react';
25
+ import React, {useCallback} from 'react';
26
26
  import {
27
- computeLabel,
28
27
  ControlProps,
29
- ControlState,
28
+ showAsRequired,
30
29
  isDescriptionHidden,
31
- isPlainLabel,
32
30
  isRangeControl,
33
31
  RankedTester,
34
32
  rankWith
35
33
  } from '@jsonforms/core';
36
- import { Control, withJsonFormsControlProps } from '@jsonforms/react';
34
+ import { withJsonFormsControlProps } from '@jsonforms/react';
37
35
 
38
36
  import {
39
37
  FormControl,
40
38
  FormHelperText,
39
+ FormLabel,
41
40
  Hidden,
42
41
  Slider,
43
42
  Typography
44
- } from '@material-ui/core';
43
+ } from '@mui/material';
45
44
  import merge from 'lodash/merge';
45
+ import { useFocus } from '../util';
46
46
 
47
- export class MaterialSliderControl extends Control<ControlProps, ControlState> {
48
- render() {
49
- const {
50
- id,
51
- data,
52
- description,
53
- enabled,
54
- errors,
55
- label,
56
- schema,
57
- handleChange,
58
- visible,
59
- path,
60
- required,
61
- config
62
- } = this.props;
63
- const isValid = errors.length === 0;
64
- const appliedUiSchemaOptions = merge(
65
- {},
66
- config,
67
- this.props.uischema.options
68
- );
69
- const labelStyle: { [x: string]: any } = {
70
- whiteSpace: 'nowrap',
71
- overflow: 'hidden',
72
- textOverflow: 'ellipsis',
73
- width: '100%'
74
- };
75
- const rangeContainerStyle: { [x: string]: any } = {
76
- display: 'flex'
77
- };
78
- const rangeItemStyle: { [x: string]: any } = {
79
- flexGrow: '1'
80
- };
81
- const sliderStyle: { [x: string]: any } = {
82
- marginTop: '7px'
83
- };
47
+ export const MaterialSliderControl = (props: ControlProps) => {
48
+ const [focused, onFocus, onBlur] = useFocus();
49
+ const {
50
+ id,
51
+ data,
52
+ description,
53
+ enabled,
54
+ errors,
55
+ label,
56
+ schema,
57
+ handleChange,
58
+ visible,
59
+ path,
60
+ required,
61
+ config
62
+ } = props;
63
+ const isValid = errors.length === 0;
64
+ const appliedUiSchemaOptions = merge(
65
+ {},
66
+ config,
67
+ props.uischema.options
68
+ );
69
+ const labelStyle: { [x: string]: any } = {
70
+ whiteSpace: 'nowrap',
71
+ overflow: 'hidden',
72
+ textOverflow: 'ellipsis',
73
+ width: '100%'
74
+ };
75
+ const rangeContainerStyle: { [x: string]: any } = {
76
+ display: 'flex'
77
+ };
78
+ const rangeItemStyle: { [x: string]: any } = {
79
+ flexGrow: '1'
80
+ };
81
+ const sliderStyle: { [x: string]: any } = {
82
+ marginTop: '7px'
83
+ };
84
84
 
85
- const showDescription = !isDescriptionHidden(
86
- visible,
87
- description,
88
- this.state.isFocused,
89
- appliedUiSchemaOptions.showUnfocusedDescription
90
- );
91
- return (
92
- <Hidden xsUp={!visible}>
93
- <FormControl
94
- fullWidth={!appliedUiSchemaOptions.trim}
95
- onFocus={this.onFocus}
96
- onBlur={this.onBlur}
97
- id={id}
85
+ const showDescription = !isDescriptionHidden(
86
+ visible,
87
+ description,
88
+ focused,
89
+ appliedUiSchemaOptions.showUnfocusedDescription
90
+ );
91
+
92
+ const onChange = useCallback((_ev: any, value: any) => handleChange(path, Number(value)), [path, handleChange]);
93
+
94
+ return (
95
+ <Hidden xsUp={!visible}>
96
+ <FormControl
97
+ fullWidth={!appliedUiSchemaOptions.trim}
98
+ onFocus={onFocus}
99
+ onBlur={onBlur}
100
+ id={id}
101
+ >
102
+ <FormLabel
103
+ htmlFor={id}
104
+ error={!isValid}
105
+ component={'legend' as 'label'}
106
+ required={showAsRequired(required,
107
+ appliedUiSchemaOptions.hideRequiredAsterisk)}
98
108
  >
99
109
  <Typography id={id + '-typo'} style={labelStyle} variant='caption'>
100
- {computeLabel(
101
- isPlainLabel(label) ? label : label.default,
102
- required,
103
- appliedUiSchemaOptions.hideRequiredAsterisk
104
- )}
110
+ {label}
111
+ </Typography>
112
+ </FormLabel>
113
+ <div style={rangeContainerStyle}>
114
+ <Typography style={rangeItemStyle} variant='caption' align='left'>
115
+ {schema.minimum}
116
+ </Typography>
117
+ <Typography style={rangeItemStyle} variant='caption' align='right'>
118
+ {schema.maximum}
105
119
  </Typography>
106
- <div style={rangeContainerStyle}>
107
- <Typography style={rangeItemStyle} variant='caption' align='left'>
108
- {schema.minimum}
109
- </Typography>
110
- <Typography style={rangeItemStyle} variant='caption' align='right'>
111
- {schema.maximum}
112
- </Typography>
113
- </div>
114
- <Slider
115
- style={sliderStyle}
116
- min={schema.minimum}
117
- max={schema.maximum}
118
- value={Number(data || schema.default)}
119
- onChange={(_ev: any, value: any) => {
120
- handleChange(path, Number(value));
121
- }}
122
- id={id + '-input'}
123
- disabled={!enabled}
124
- step={schema.multipleOf || 1}
125
- />
126
- <FormHelperText error={!isValid}>
127
- {!isValid ? errors : showDescription ? description : null}
128
- </FormHelperText>
129
- </FormControl>
130
- </Hidden>
131
- );
132
- }
133
- }
120
+ </div>
121
+ <Slider
122
+ style={sliderStyle}
123
+ min={schema.minimum}
124
+ max={schema.maximum}
125
+ value={Number(data || schema.default)}
126
+ onChange={onChange}
127
+ id={id + '-input'}
128
+ disabled={!enabled}
129
+ step={schema.multipleOf || 1}
130
+ />
131
+ <FormHelperText error={!isValid}>
132
+ {!isValid ? errors : showDescription ? description : null}
133
+ </FormHelperText>
134
+ </FormControl>
135
+ </Hidden>
136
+ );
137
+ };
134
138
  export const materialSliderControlTester: RankedTester = rankWith(
135
139
  4,
136
140
  isRangeControl
@@ -0,0 +1,133 @@
1
+ /*
2
+ The MIT License
3
+
4
+ Copyright (c) 2017-2019 EclipseSource Munich
5
+ https://github.com/eclipsesource/jsonforms
6
+
7
+ Permission is hereby granted, free of charge, to any person obtaining a copy
8
+ of this software and associated documentation files (the "Software"), to deal
9
+ in the Software without restriction, including without limitation the rights
10
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
+ copies of the Software, and to permit persons to whom the Software is
12
+ furnished to do so, subject to the following conditions:
13
+
14
+ The above copyright notice and this permission notice shall be included in
15
+ all copies or substantial portions of the Software.
16
+
17
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
+ THE SOFTWARE.
24
+ */
25
+ import React, { useMemo } from 'react';
26
+ import merge from 'lodash/merge';
27
+ import {
28
+ ControlProps,
29
+ isTimeControl,
30
+ isDescriptionHidden,
31
+ RankedTester,
32
+ rankWith
33
+ } from '@jsonforms/core';
34
+ import { withJsonFormsControlProps } from '@jsonforms/react';
35
+ import { FormHelperText, Hidden, TextField } from '@mui/material';
36
+ import {
37
+ TimePicker,
38
+ LocalizationProvider
39
+ } from '@mui/lab';
40
+ import AdapterDayjs from '@mui/lab/AdapterDayjs';
41
+ import { createOnChangeHandler, getData, useFocus } from '../util';
42
+
43
+ export const MaterialTimeControl = (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;
61
+
62
+ const showDescription = !isDescriptionHidden(
63
+ visible,
64
+ description,
65
+ focused,
66
+ appliedUiSchemaOptions.showUnfocusedDescription
67
+ );
68
+
69
+ const format = appliedUiSchemaOptions.timeFormat ?? 'HH:mm';
70
+ const saveFormat = appliedUiSchemaOptions.timeSaveFormat ?? 'HH:mm:ss';
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]);
84
+
85
+ return (
86
+ <Hidden xsUp={!visible}>
87
+ <LocalizationProvider dateAdapter={AdapterDayjs}>
88
+ <TimePicker
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
+ };
127
+
128
+ export const materialTimeControlTester: RankedTester = rankWith(
129
+ 4,
130
+ isTimeControl
131
+ );
132
+
133
+ export default withJsonFormsControlProps(MaterialTimeControl);