@sap-ux/ui-components 1.0.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 (450) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +20 -0
  3. package/dist/components/Icons.d.ts +105 -0
  4. package/dist/components/Icons.d.ts.map +1 -0
  5. package/dist/components/Icons.js +401 -0
  6. package/dist/components/Icons.js.map +1 -0
  7. package/dist/components/UIBreadcrumb/UIBreadcrumb.d.ts +23 -0
  8. package/dist/components/UIBreadcrumb/UIBreadcrumb.d.ts.map +1 -0
  9. package/dist/components/UIBreadcrumb/UIBreadcrumb.js +38 -0
  10. package/dist/components/UIBreadcrumb/UIBreadcrumb.js.map +1 -0
  11. package/dist/components/UIBreadcrumb/index.d.ts +2 -0
  12. package/dist/components/UIBreadcrumb/index.d.ts.map +1 -0
  13. package/dist/components/UIBreadcrumb/index.js +14 -0
  14. package/dist/components/UIBreadcrumb/index.js.map +1 -0
  15. package/dist/components/UIButton/UIActionButton.d.ts +23 -0
  16. package/dist/components/UIButton/UIActionButton.d.ts.map +1 -0
  17. package/dist/components/UIButton/UIActionButton.js +97 -0
  18. package/dist/components/UIButton/UIActionButton.js.map +1 -0
  19. package/dist/components/UIButton/UIDefaultButton.d.ts +23 -0
  20. package/dist/components/UIButton/UIDefaultButton.d.ts.map +1 -0
  21. package/dist/components/UIButton/UIDefaultButton.js +227 -0
  22. package/dist/components/UIButton/UIDefaultButton.js.map +1 -0
  23. package/dist/components/UIButton/UIIconButton.d.ts +37 -0
  24. package/dist/components/UIButton/UIIconButton.d.ts.map +1 -0
  25. package/dist/components/UIButton/UIIconButton.js +106 -0
  26. package/dist/components/UIButton/UIIconButton.js.map +1 -0
  27. package/dist/components/UIButton/UISplitButton.d.ts +36 -0
  28. package/dist/components/UIButton/UISplitButton.d.ts.map +1 -0
  29. package/dist/components/UIButton/UISplitButton.js +67 -0
  30. package/dist/components/UIButton/UISplitButton.js.map +1 -0
  31. package/dist/components/UIButton/index.d.ts +7 -0
  32. package/dist/components/UIButton/index.d.ts.map +1 -0
  33. package/dist/components/UIButton/index.js +17 -0
  34. package/dist/components/UIButton/index.js.map +1 -0
  35. package/dist/components/UICallout/UICallout.d.ts +37 -0
  36. package/dist/components/UICallout/UICallout.d.ts.map +1 -0
  37. package/dist/components/UICallout/UICallout.js +90 -0
  38. package/dist/components/UICallout/UICallout.js.map +1 -0
  39. package/dist/components/UICallout/index.d.ts +2 -0
  40. package/dist/components/UICallout/index.d.ts.map +1 -0
  41. package/dist/components/UICallout/index.js +14 -0
  42. package/dist/components/UICallout/index.js.map +1 -0
  43. package/dist/components/UICheckbox/UICheckbox.d.ts +34 -0
  44. package/dist/components/UICheckbox/UICheckbox.d.ts.map +1 -0
  45. package/dist/components/UICheckbox/UICheckbox.js +135 -0
  46. package/dist/components/UICheckbox/UICheckbox.js.map +1 -0
  47. package/dist/components/UICheckbox/index.d.ts +2 -0
  48. package/dist/components/UICheckbox/index.d.ts.map +1 -0
  49. package/dist/components/UICheckbox/index.js +14 -0
  50. package/dist/components/UICheckbox/index.js.map +1 -0
  51. package/dist/components/UIChoiceGroup/UIChoiceGroup.d.ts +28 -0
  52. package/dist/components/UIChoiceGroup/UIChoiceGroup.d.ts.map +1 -0
  53. package/dist/components/UIChoiceGroup/UIChoiceGroup.js +182 -0
  54. package/dist/components/UIChoiceGroup/UIChoiceGroup.js.map +1 -0
  55. package/dist/components/UIChoiceGroup/index.d.ts +2 -0
  56. package/dist/components/UIChoiceGroup/index.d.ts.map +1 -0
  57. package/dist/components/UIChoiceGroup/index.js +14 -0
  58. package/dist/components/UIChoiceGroup/index.js.map +1 -0
  59. package/dist/components/UIComboBox/Callout.scss +7 -0
  60. package/dist/components/UIComboBox/UIComboBox.d.ts +190 -0
  61. package/dist/components/UIComboBox/UIComboBox.d.ts.map +1 -0
  62. package/dist/components/UIComboBox/UIComboBox.js +468 -0
  63. package/dist/components/UIComboBox/UIComboBox.js.map +1 -0
  64. package/dist/components/UIComboBox/UIComboBox.scss +245 -0
  65. package/dist/components/UIComboBox/_mixins.scss +24 -0
  66. package/dist/components/UIComboBox/index.d.ts +2 -0
  67. package/dist/components/UIComboBox/index.d.ts.map +1 -0
  68. package/dist/components/UIComboBox/index.js +14 -0
  69. package/dist/components/UIComboBox/index.js.map +1 -0
  70. package/dist/components/UIContextualMenu/UIContextualMenu.d.ts +32 -0
  71. package/dist/components/UIContextualMenu/UIContextualMenu.d.ts.map +1 -0
  72. package/dist/components/UIContextualMenu/UIContextualMenu.js +124 -0
  73. package/dist/components/UIContextualMenu/UIContextualMenu.js.map +1 -0
  74. package/dist/components/UIContextualMenu/UIContextualMenu.scss +211 -0
  75. package/dist/components/UIContextualMenu/UIHighlightMenuOption.d.ts +20 -0
  76. package/dist/components/UIContextualMenu/UIHighlightMenuOption.d.ts.map +1 -0
  77. package/dist/components/UIContextualMenu/UIHighlightMenuOption.js +51 -0
  78. package/dist/components/UIContextualMenu/UIHighlightMenuOption.js.map +1 -0
  79. package/dist/components/UIContextualMenu/UIHighlightMenuOption.scss +23 -0
  80. package/dist/components/UIContextualMenu/_variables.scss +30 -0
  81. package/dist/components/UIContextualMenu/index.d.ts +3 -0
  82. package/dist/components/UIContextualMenu/index.d.ts.map +1 -0
  83. package/dist/components/UIContextualMenu/index.js +15 -0
  84. package/dist/components/UIContextualMenu/index.js.map +1 -0
  85. package/dist/components/UIDatePicker/UIDatePicker.d.ts +49 -0
  86. package/dist/components/UIDatePicker/UIDatePicker.d.ts.map +1 -0
  87. package/dist/components/UIDatePicker/UIDatePicker.js +72 -0
  88. package/dist/components/UIDatePicker/UIDatePicker.js.map +1 -0
  89. package/dist/components/UIDatePicker/UIDatePicker.scss +38 -0
  90. package/dist/components/UIDatePicker/index.d.ts +2 -0
  91. package/dist/components/UIDatePicker/index.d.ts.map +1 -0
  92. package/dist/components/UIDatePicker/index.js +14 -0
  93. package/dist/components/UIDatePicker/index.js.map +1 -0
  94. package/dist/components/UIDialog/UIDialog.d.ts +102 -0
  95. package/dist/components/UIDialog/UIDialog.d.ts.map +1 -0
  96. package/dist/components/UIDialog/UIDialog.js +250 -0
  97. package/dist/components/UIDialog/UIDialog.js.map +1 -0
  98. package/dist/components/UIDialog/index.d.ts +2 -0
  99. package/dist/components/UIDialog/index.d.ts.map +1 -0
  100. package/dist/components/UIDialog/index.js +14 -0
  101. package/dist/components/UIDialog/index.js.map +1 -0
  102. package/dist/components/UIDropdown/UIDropdown.d.ts +76 -0
  103. package/dist/components/UIDropdown/UIDropdown.d.ts.map +1 -0
  104. package/dist/components/UIDropdown/UIDropdown.js +166 -0
  105. package/dist/components/UIDropdown/UIDropdown.js.map +1 -0
  106. package/dist/components/UIDropdown/UIDropdown.scss +80 -0
  107. package/dist/components/UIDropdown/index.d.ts +2 -0
  108. package/dist/components/UIDropdown/index.d.ts.map +1 -0
  109. package/dist/components/UIDropdown/index.js +14 -0
  110. package/dist/components/UIDropdown/index.js.map +1 -0
  111. package/dist/components/UIFlexibleTable/RowActions.d.ts +17 -0
  112. package/dist/components/UIFlexibleTable/RowActions.d.ts.map +1 -0
  113. package/dist/components/UIFlexibleTable/RowActions.js +68 -0
  114. package/dist/components/UIFlexibleTable/RowActions.js.map +1 -0
  115. package/dist/components/UIFlexibleTable/RowData.d.ts +16 -0
  116. package/dist/components/UIFlexibleTable/RowData.d.ts.map +1 -0
  117. package/dist/components/UIFlexibleTable/RowData.js +109 -0
  118. package/dist/components/UIFlexibleTable/RowData.js.map +1 -0
  119. package/dist/components/UIFlexibleTable/UIFlexibleTable.d.ts +12 -0
  120. package/dist/components/UIFlexibleTable/UIFlexibleTable.d.ts.map +1 -0
  121. package/dist/components/UIFlexibleTable/UIFlexibleTable.js +256 -0
  122. package/dist/components/UIFlexibleTable/UIFlexibleTable.js.map +1 -0
  123. package/dist/components/UIFlexibleTable/UIFlexibleTable.scss +408 -0
  124. package/dist/components/UIFlexibleTable/UIFlexibleTableActionButton.d.ts +20 -0
  125. package/dist/components/UIFlexibleTable/UIFlexibleTableActionButton.d.ts.map +1 -0
  126. package/dist/components/UIFlexibleTable/UIFlexibleTableActionButton.js +20 -0
  127. package/dist/components/UIFlexibleTable/UIFlexibleTableActionButton.js.map +1 -0
  128. package/dist/components/UIFlexibleTable/UIFlexibleTableRow.d.ts +28 -0
  129. package/dist/components/UIFlexibleTable/UIFlexibleTableRow.d.ts.map +1 -0
  130. package/dist/components/UIFlexibleTable/UIFlexibleTableRow.js +165 -0
  131. package/dist/components/UIFlexibleTable/UIFlexibleTableRow.js.map +1 -0
  132. package/dist/components/UIFlexibleTable/UIFlexibleTableRowActionButton.d.ts +21 -0
  133. package/dist/components/UIFlexibleTable/UIFlexibleTableRowActionButton.d.ts.map +1 -0
  134. package/dist/components/UIFlexibleTable/UIFlexibleTableRowActionButton.js +20 -0
  135. package/dist/components/UIFlexibleTable/UIFlexibleTableRowActionButton.js.map +1 -0
  136. package/dist/components/UIFlexibleTable/index.d.ts +6 -0
  137. package/dist/components/UIFlexibleTable/index.d.ts.map +1 -0
  138. package/dist/components/UIFlexibleTable/index.js +18 -0
  139. package/dist/components/UIFlexibleTable/index.js.map +1 -0
  140. package/dist/components/UIFlexibleTable/types.d.ts +103 -0
  141. package/dist/components/UIFlexibleTable/types.d.ts.map +1 -0
  142. package/dist/components/UIFlexibleTable/types.js +9 -0
  143. package/dist/components/UIFlexibleTable/types.js.map +1 -0
  144. package/dist/components/UIFlexibleTable/utils.d.ts +29 -0
  145. package/dist/components/UIFlexibleTable/utils.d.ts.map +1 -0
  146. package/dist/components/UIFlexibleTable/utils.js +53 -0
  147. package/dist/components/UIFlexibleTable/utils.js.map +1 -0
  148. package/dist/components/UIFocusZone/UIFocusTrapZone.d.ts +22 -0
  149. package/dist/components/UIFocusZone/UIFocusTrapZone.d.ts.map +1 -0
  150. package/dist/components/UIFocusZone/UIFocusTrapZone.js +33 -0
  151. package/dist/components/UIFocusZone/UIFocusTrapZone.js.map +1 -0
  152. package/dist/components/UIFocusZone/UIFocusZone.d.ts +23 -0
  153. package/dist/components/UIFocusZone/UIFocusZone.d.ts.map +1 -0
  154. package/dist/components/UIFocusZone/UIFocusZone.js +35 -0
  155. package/dist/components/UIFocusZone/UIFocusZone.js.map +1 -0
  156. package/dist/components/UIFocusZone/index.d.ts +3 -0
  157. package/dist/components/UIFocusZone/index.d.ts.map +1 -0
  158. package/dist/components/UIFocusZone/index.js +15 -0
  159. package/dist/components/UIFocusZone/index.js.map +1 -0
  160. package/dist/components/UIIcon/UIIcon.d.ts +24 -0
  161. package/dist/components/UIIcon/UIIcon.d.ts.map +1 -0
  162. package/dist/components/UIIcon/UIIcon.js +37 -0
  163. package/dist/components/UIIcon/UIIcon.js.map +1 -0
  164. package/dist/components/UIIcon/UIIcon.scss +3 -0
  165. package/dist/components/UIIcon/index.d.ts +2 -0
  166. package/dist/components/UIIcon/index.d.ts.map +1 -0
  167. package/dist/components/UIIcon/index.js +14 -0
  168. package/dist/components/UIIcon/index.js.map +1 -0
  169. package/dist/components/UIInput/UITextInput.d.ts +25 -0
  170. package/dist/components/UIInput/UITextInput.d.ts.map +1 -0
  171. package/dist/components/UIInput/UITextInput.js +180 -0
  172. package/dist/components/UIInput/UITextInput.js.map +1 -0
  173. package/dist/components/UIInput/index.d.ts +2 -0
  174. package/dist/components/UIInput/index.d.ts.map +1 -0
  175. package/dist/components/UIInput/index.js +14 -0
  176. package/dist/components/UIInput/index.js.map +1 -0
  177. package/dist/components/UILabel/UILabel.d.ts +30 -0
  178. package/dist/components/UILabel/UILabel.d.ts.map +1 -0
  179. package/dist/components/UILabel/UILabel.js +64 -0
  180. package/dist/components/UILabel/UILabel.js.map +1 -0
  181. package/dist/components/UILabel/index.d.ts +2 -0
  182. package/dist/components/UILabel/index.d.ts.map +1 -0
  183. package/dist/components/UILabel/index.js +14 -0
  184. package/dist/components/UILabel/index.js.map +1 -0
  185. package/dist/components/UILink/UILink.d.ts +22 -0
  186. package/dist/components/UILink/UILink.d.ts.map +1 -0
  187. package/dist/components/UILink/UILink.js +58 -0
  188. package/dist/components/UILink/UILink.js.map +1 -0
  189. package/dist/components/UILink/index.d.ts +2 -0
  190. package/dist/components/UILink/index.d.ts.map +1 -0
  191. package/dist/components/UILink/index.js +14 -0
  192. package/dist/components/UILink/index.js.map +1 -0
  193. package/dist/components/UIList/UIList.d.ts +31 -0
  194. package/dist/components/UIList/UIList.d.ts.map +1 -0
  195. package/dist/components/UIList/UIList.js +120 -0
  196. package/dist/components/UIList/UIList.js.map +1 -0
  197. package/dist/components/UIList/UIList.scss +16 -0
  198. package/dist/components/UIList/index.d.ts +2 -0
  199. package/dist/components/UIList/index.d.ts.map +1 -0
  200. package/dist/components/UIList/index.js +14 -0
  201. package/dist/components/UIList/index.js.map +1 -0
  202. package/dist/components/UILoader/UILoader.d.ts +27 -0
  203. package/dist/components/UILoader/UILoader.d.ts.map +1 -0
  204. package/dist/components/UILoader/UILoader.js +78 -0
  205. package/dist/components/UILoader/UILoader.js.map +1 -0
  206. package/dist/components/UILoader/UILoader.scss +32 -0
  207. package/dist/components/UILoader/index.d.ts +2 -0
  208. package/dist/components/UILoader/index.d.ts.map +1 -0
  209. package/dist/components/UILoader/index.js +14 -0
  210. package/dist/components/UILoader/index.js.map +1 -0
  211. package/dist/components/UIMessageBar/UIMessageBar.d.ts +25 -0
  212. package/dist/components/UIMessageBar/UIMessageBar.d.ts.map +1 -0
  213. package/dist/components/UIMessageBar/UIMessageBar.js +59 -0
  214. package/dist/components/UIMessageBar/UIMessageBar.js.map +1 -0
  215. package/dist/components/UIMessageBar/index.d.ts +2 -0
  216. package/dist/components/UIMessageBar/index.d.ts.map +1 -0
  217. package/dist/components/UIMessageBar/index.js +14 -0
  218. package/dist/components/UIMessageBar/index.js.map +1 -0
  219. package/dist/components/UIModal/UIModal.d.ts +23 -0
  220. package/dist/components/UIModal/UIModal.d.ts.map +1 -0
  221. package/dist/components/UIModal/UIModal.js +43 -0
  222. package/dist/components/UIModal/UIModal.js.map +1 -0
  223. package/dist/components/UIModal/index.d.ts +2 -0
  224. package/dist/components/UIModal/index.d.ts.map +1 -0
  225. package/dist/components/UIModal/index.js +14 -0
  226. package/dist/components/UIModal/index.js.map +1 -0
  227. package/dist/components/UIOverlay/UIOverlay.d.ts +22 -0
  228. package/dist/components/UIOverlay/UIOverlay.d.ts.map +1 -0
  229. package/dist/components/UIOverlay/UIOverlay.js +38 -0
  230. package/dist/components/UIOverlay/UIOverlay.js.map +1 -0
  231. package/dist/components/UIOverlay/index.d.ts +2 -0
  232. package/dist/components/UIOverlay/index.d.ts.map +1 -0
  233. package/dist/components/UIOverlay/index.js +14 -0
  234. package/dist/components/UIOverlay/index.js.map +1 -0
  235. package/dist/components/UISearchBox/UISearchBox.d.ts +22 -0
  236. package/dist/components/UISearchBox/UISearchBox.d.ts.map +1 -0
  237. package/dist/components/UISearchBox/UISearchBox.js +155 -0
  238. package/dist/components/UISearchBox/UISearchBox.js.map +1 -0
  239. package/dist/components/UISearchBox/index.d.ts +4 -0
  240. package/dist/components/UISearchBox/index.d.ts.map +1 -0
  241. package/dist/components/UISearchBox/index.js +14 -0
  242. package/dist/components/UISearchBox/index.js.map +1 -0
  243. package/dist/components/UISection/UISection.d.ts +33 -0
  244. package/dist/components/UISection/UISection.d.ts.map +1 -0
  245. package/dist/components/UISection/UISection.js +47 -0
  246. package/dist/components/UISection/UISection.js.map +1 -0
  247. package/dist/components/UISection/UISection.scss +76 -0
  248. package/dist/components/UISection/UISections.d.ts +251 -0
  249. package/dist/components/UISection/UISections.d.ts.map +1 -0
  250. package/dist/components/UISection/UISections.js +709 -0
  251. package/dist/components/UISection/UISections.js.map +1 -0
  252. package/dist/components/UISection/UISections.scss +62 -0
  253. package/dist/components/UISection/UISplitter.d.ts +97 -0
  254. package/dist/components/UISection/UISplitter.d.ts.map +1 -0
  255. package/dist/components/UISection/UISplitter.js +221 -0
  256. package/dist/components/UISection/UISplitter.js.map +1 -0
  257. package/dist/components/UISection/UISplitter.scss +212 -0
  258. package/dist/components/UISection/_mixins.scss +14 -0
  259. package/dist/components/UISection/_variables.scss +1 -0
  260. package/dist/components/UISection/index.d.ts +4 -0
  261. package/dist/components/UISection/index.d.ts.map +1 -0
  262. package/dist/components/UISection/index.js +16 -0
  263. package/dist/components/UISection/index.js.map +1 -0
  264. package/dist/components/UITable/UITable-helper.d.ts +85 -0
  265. package/dist/components/UITable/UITable-helper.d.ts.map +1 -0
  266. package/dist/components/UITable/UITable-helper.js +267 -0
  267. package/dist/components/UITable/UITable-helper.js.map +1 -0
  268. package/dist/components/UITable/UITable.d.ts +212 -0
  269. package/dist/components/UITable/UITable.d.ts.map +1 -0
  270. package/dist/components/UITable/UITable.js +762 -0
  271. package/dist/components/UITable/UITable.js.map +1 -0
  272. package/dist/components/UITable/UITable.scss +194 -0
  273. package/dist/components/UITable/index.d.ts +3 -0
  274. package/dist/components/UITable/index.d.ts.map +1 -0
  275. package/dist/components/UITable/index.js +15 -0
  276. package/dist/components/UITable/index.js.map +1 -0
  277. package/dist/components/UITable/types.d.ts +76 -0
  278. package/dist/components/UITable/types.d.ts.map +1 -0
  279. package/dist/components/UITable/types.js +27 -0
  280. package/dist/components/UITable/types.js.map +1 -0
  281. package/dist/components/UITabs/UITabs.d.ts +28 -0
  282. package/dist/components/UITabs/UITabs.d.ts.map +1 -0
  283. package/dist/components/UITabs/UITabs.js +70 -0
  284. package/dist/components/UITabs/UITabs.js.map +1 -0
  285. package/dist/components/UITabs/index.d.ts +2 -0
  286. package/dist/components/UITabs/index.d.ts.map +1 -0
  287. package/dist/components/UITabs/index.js +14 -0
  288. package/dist/components/UITabs/index.js.map +1 -0
  289. package/dist/components/UIToggle/UIToggle.d.ts +39 -0
  290. package/dist/components/UIToggle/UIToggle.d.ts.map +1 -0
  291. package/dist/components/UIToggle/UIToggle.js +181 -0
  292. package/dist/components/UIToggle/UIToggle.js.map +1 -0
  293. package/dist/components/UIToggle/index.d.ts +2 -0
  294. package/dist/components/UIToggle/index.d.ts.map +1 -0
  295. package/dist/components/UIToggle/index.js +14 -0
  296. package/dist/components/UIToggle/index.js.map +1 -0
  297. package/dist/components/UIToggleGroup/UIToggleGroup.d.ts +31 -0
  298. package/dist/components/UIToggleGroup/UIToggleGroup.d.ts.map +1 -0
  299. package/dist/components/UIToggleGroup/UIToggleGroup.js +132 -0
  300. package/dist/components/UIToggleGroup/UIToggleGroup.js.map +1 -0
  301. package/dist/components/UIToggleGroup/UIToggleGroup.scss +13 -0
  302. package/dist/components/UIToggleGroup/UIToggleGroup.types.d.ts +23 -0
  303. package/dist/components/UIToggleGroup/UIToggleGroup.types.d.ts.map +1 -0
  304. package/dist/components/UIToggleGroup/UIToggleGroup.types.js +3 -0
  305. package/dist/components/UIToggleGroup/UIToggleGroup.types.js.map +1 -0
  306. package/dist/components/UIToggleGroup/UIToggleGroupOption/UIToggleGroupOption.d.ts +26 -0
  307. package/dist/components/UIToggleGroup/UIToggleGroupOption/UIToggleGroupOption.d.ts.map +1 -0
  308. package/dist/components/UIToggleGroup/UIToggleGroupOption/UIToggleGroupOption.js +74 -0
  309. package/dist/components/UIToggleGroup/UIToggleGroupOption/UIToggleGroupOption.js.map +1 -0
  310. package/dist/components/UIToggleGroup/UIToggleGroupOption/UIToggleGroupOption.scss +74 -0
  311. package/dist/components/UIToggleGroup/UIToggleGroupOption/UIToggleGroupOption.types.d.ts +11 -0
  312. package/dist/components/UIToggleGroup/UIToggleGroupOption/UIToggleGroupOption.types.d.ts.map +1 -0
  313. package/dist/components/UIToggleGroup/UIToggleGroupOption/UIToggleGroupOption.types.js +3 -0
  314. package/dist/components/UIToggleGroup/UIToggleGroupOption/UIToggleGroupOption.types.js.map +1 -0
  315. package/dist/components/UIToggleGroup/UIToggleGroupOption/index.d.ts +3 -0
  316. package/dist/components/UIToggleGroup/UIToggleGroupOption/index.d.ts.map +1 -0
  317. package/dist/components/UIToggleGroup/UIToggleGroupOption/index.js +15 -0
  318. package/dist/components/UIToggleGroup/UIToggleGroupOption/index.js.map +1 -0
  319. package/dist/components/UIToggleGroup/index.d.ts +3 -0
  320. package/dist/components/UIToggleGroup/index.d.ts.map +1 -0
  321. package/dist/components/UIToggleGroup/index.js +15 -0
  322. package/dist/components/UIToggleGroup/index.js.map +1 -0
  323. package/dist/components/UIToolbar/UIToolbar.d.ts +37 -0
  324. package/dist/components/UIToolbar/UIToolbar.d.ts.map +1 -0
  325. package/dist/components/UIToolbar/UIToolbar.js +101 -0
  326. package/dist/components/UIToolbar/UIToolbar.js.map +1 -0
  327. package/dist/components/UIToolbar/UIToolbar.scss +48 -0
  328. package/dist/components/UIToolbar/UIToolbarColumn.d.ts +8 -0
  329. package/dist/components/UIToolbar/UIToolbarColumn.d.ts.map +1 -0
  330. package/dist/components/UIToolbar/UIToolbarColumn.js +30 -0
  331. package/dist/components/UIToolbar/UIToolbarColumn.js.map +1 -0
  332. package/dist/components/UIToolbar/UIToolbarDivider.d.ts +26 -0
  333. package/dist/components/UIToolbar/UIToolbarDivider.d.ts.map +1 -0
  334. package/dist/components/UIToolbar/UIToolbarDivider.js +51 -0
  335. package/dist/components/UIToolbar/UIToolbarDivider.js.map +1 -0
  336. package/dist/components/UIToolbar/index.d.ts +4 -0
  337. package/dist/components/UIToolbar/index.d.ts.map +1 -0
  338. package/dist/components/UIToolbar/index.js +16 -0
  339. package/dist/components/UIToolbar/index.js.map +1 -0
  340. package/dist/components/UITooltip/UITooltip.d.ts +29 -0
  341. package/dist/components/UITooltip/UITooltip.d.ts.map +1 -0
  342. package/dist/components/UITooltip/UITooltip.js +79 -0
  343. package/dist/components/UITooltip/UITooltip.js.map +1 -0
  344. package/dist/components/UITooltip/UITooltipUtils.d.ts +17 -0
  345. package/dist/components/UITooltip/UITooltipUtils.d.ts.map +1 -0
  346. package/dist/components/UITooltip/UITooltipUtils.js +47 -0
  347. package/dist/components/UITooltip/UITooltipUtils.js.map +1 -0
  348. package/dist/components/UITooltip/index.d.ts +3 -0
  349. package/dist/components/UITooltip/index.d.ts.map +1 -0
  350. package/dist/components/UITooltip/index.js +15 -0
  351. package/dist/components/UITooltip/index.js.map +1 -0
  352. package/dist/components/UITreeDropdown/UITreeDropdown.d.ts +255 -0
  353. package/dist/components/UITreeDropdown/UITreeDropdown.d.ts.map +1 -0
  354. package/dist/components/UITreeDropdown/UITreeDropdown.js +638 -0
  355. package/dist/components/UITreeDropdown/UITreeDropdown.js.map +1 -0
  356. package/dist/components/UITreeDropdown/UITreeDropdown.scss +82 -0
  357. package/dist/components/UITreeDropdown/index.d.ts +2 -0
  358. package/dist/components/UITreeDropdown/index.d.ts.map +1 -0
  359. package/dist/components/UITreeDropdown/index.js +14 -0
  360. package/dist/components/UITreeDropdown/index.js.map +1 -0
  361. package/dist/components/UIVerticalDivider/UIVerticalDivider.d.ts +24 -0
  362. package/dist/components/UIVerticalDivider/UIVerticalDivider.d.ts.map +1 -0
  363. package/dist/components/UIVerticalDivider/UIVerticalDivider.js +42 -0
  364. package/dist/components/UIVerticalDivider/UIVerticalDivider.js.map +1 -0
  365. package/dist/components/UIVerticalDivider/index.d.ts +2 -0
  366. package/dist/components/UIVerticalDivider/index.d.ts.map +1 -0
  367. package/dist/components/UIVerticalDivider/index.js +14 -0
  368. package/dist/components/UIVerticalDivider/index.js.map +1 -0
  369. package/dist/components/UIVirtualList/UIAutoSizer.d.ts +22 -0
  370. package/dist/components/UIVirtualList/UIAutoSizer.d.ts.map +1 -0
  371. package/dist/components/UIVirtualList/UIAutoSizer.js +33 -0
  372. package/dist/components/UIVirtualList/UIAutoSizer.js.map +1 -0
  373. package/dist/components/UIVirtualList/UICellMeasurer.d.ts +23 -0
  374. package/dist/components/UIVirtualList/UICellMeasurer.d.ts.map +1 -0
  375. package/dist/components/UIVirtualList/UICellMeasurer.js +33 -0
  376. package/dist/components/UIVirtualList/UICellMeasurer.js.map +1 -0
  377. package/dist/components/UIVirtualList/UIVirtualList.d.ts +43 -0
  378. package/dist/components/UIVirtualList/UIVirtualList.d.ts.map +1 -0
  379. package/dist/components/UIVirtualList/UIVirtualList.js +70 -0
  380. package/dist/components/UIVirtualList/UIVirtualList.js.map +1 -0
  381. package/dist/components/UIVirtualList/index.d.ts +4 -0
  382. package/dist/components/UIVirtualList/index.d.ts.map +1 -0
  383. package/dist/components/UIVirtualList/index.js +16 -0
  384. package/dist/components/UIVirtualList/index.js.map +1 -0
  385. package/dist/components/index.d.ts +34 -0
  386. package/dist/components/index.d.ts.map +1 -0
  387. package/dist/components/index.js +46 -0
  388. package/dist/components/index.js.map +1 -0
  389. package/dist/helper/ValidationMessage/MessageWrapper.d.ts +18 -0
  390. package/dist/helper/ValidationMessage/MessageWrapper.d.ts.map +1 -0
  391. package/dist/helper/ValidationMessage/MessageWrapper.js +35 -0
  392. package/dist/helper/ValidationMessage/MessageWrapper.js.map +1 -0
  393. package/dist/helper/ValidationMessage/MessageWrapper.scss +44 -0
  394. package/dist/helper/ValidationMessage/index.d.ts +3 -0
  395. package/dist/helper/ValidationMessage/index.d.ts.map +1 -0
  396. package/dist/helper/ValidationMessage/index.js +15 -0
  397. package/dist/helper/ValidationMessage/index.js.map +1 -0
  398. package/dist/helper/ValidationMessage/utils.d.ts +32 -0
  399. package/dist/helper/ValidationMessage/utils.d.ts.map +1 -0
  400. package/dist/helper/ValidationMessage/utils.js +124 -0
  401. package/dist/helper/ValidationMessage/utils.js.map +1 -0
  402. package/dist/index.d.ts +3 -0
  403. package/dist/index.d.ts.map +1 -0
  404. package/dist/index.js +15 -0
  405. package/dist/index.js.map +1 -0
  406. package/dist/styles/_color.scss +435 -0
  407. package/dist/styles/_mixins.scss +15 -0
  408. package/dist/styles/_theia_materialcolors.scss +279 -0
  409. package/dist/styles/_typography.scss +72 -0
  410. package/dist/styles/_variables.scss +24 -0
  411. package/dist/styles/ui-components.scss +5 -0
  412. package/dist/utilities/DeepMerge.d.ts +10 -0
  413. package/dist/utilities/DeepMerge.d.ts.map +1 -0
  414. package/dist/utilities/DeepMerge.js +43 -0
  415. package/dist/utilities/DeepMerge.js.map +1 -0
  416. package/dist/utilities/Focus.d.ts +5 -0
  417. package/dist/utilities/Focus.d.ts.map +1 -0
  418. package/dist/utilities/Focus.js +8 -0
  419. package/dist/utilities/Focus.js.map +1 -0
  420. package/dist/utilities/Id.d.ts +3 -0
  421. package/dist/utilities/Id.d.ts.map +1 -0
  422. package/dist/utilities/Id.js +6 -0
  423. package/dist/utilities/Id.js.map +1 -0
  424. package/dist/utilities/Keys.d.ts +3 -0
  425. package/dist/utilities/Keys.d.ts.map +1 -0
  426. package/dist/utilities/Keys.js +6 -0
  427. package/dist/utilities/Keys.js.map +1 -0
  428. package/dist/utilities/index.d.ts +4 -0
  429. package/dist/utilities/index.d.ts.map +1 -0
  430. package/dist/utilities/index.js +16 -0
  431. package/dist/utilities/index.js.map +1 -0
  432. package/package.json +78 -0
  433. package/storybook/509.1060f8f464e74d7e89e3.manager.bundle.js +17 -0
  434. package/storybook/685.6d7c03ae84f4f4910fd8.manager.bundle.js +10 -0
  435. package/storybook/720.3f79f56f8617ba9b098b.manager.bundle.js +1 -0
  436. package/storybook/730.e07ff5529508942d85d4.manager.bundle.js +15 -0
  437. package/storybook/759.8ae5af3b1b3b446a9919.manager.bundle.js +296 -0
  438. package/storybook/906.cf93a831.iframe.bundle.js +1 -0
  439. package/storybook/93.4e7a890e.iframe.bundle.js +301 -0
  440. package/storybook/975.15c711f75c0452ae9e9f.manager.bundle.js +2 -0
  441. package/storybook/978.a517622963996a3b8256.manager.bundle.js +894 -0
  442. package/storybook/983.515d3eedbfaed61e9ae7.manager.bundle.js +1 -0
  443. package/storybook/favicon.ico +0 -0
  444. package/storybook/iframe.html +380 -0
  445. package/storybook/index.html +177 -0
  446. package/storybook/main.e843f431b2692c06059a.manager.bundle.js +1 -0
  447. package/storybook/main.fd2077c6.iframe.bundle.js +98 -0
  448. package/storybook/project.json +1 -0
  449. package/storybook/runtime~main.1118f177d5097a42d314.manager.bundle.js +2 -0
  450. package/storybook/runtime~main.e0688c57.iframe.bundle.js +2 -0
@@ -0,0 +1,762 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.UITable = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const react_2 = require("@fluentui/react");
9
+ const UICheckbox_1 = require("../UICheckbox");
10
+ const UIInput_1 = require("../UIInput");
11
+ const UIDropdown_1 = require("../UIDropdown");
12
+ const UIComboBox_1 = require("../UIComboBox");
13
+ const UIDatePicker_1 = require("../UIDatePicker");
14
+ const UITable_helper_1 = require("./UITable-helper");
15
+ const types_1 = require("./types");
16
+ require("./UITable.scss");
17
+ /**
18
+ * UITable component
19
+ * based on: https://developer.microsoft.com/en-us/fluentui#/controls/web/detailslist
20
+ *
21
+ * @exports
22
+ * @class {UITable}
23
+ * @extends {React.Component<UITableProps, UITableState>}
24
+ */
25
+ class UITable extends react_1.default.Component {
26
+ /**
27
+ * Initializes component properties.
28
+ *
29
+ * @param props
30
+ */
31
+ constructor(props) {
32
+ super(props);
33
+ this.inputRefs = {};
34
+ this.activeElement = {};
35
+ this._onRenderRow = (props) => {
36
+ if (!props) {
37
+ return null;
38
+ }
39
+ const toggle = !!this.props.renderInputs;
40
+ return react_1.default.createElement(react_2.DetailsRow, { "data-selection-toggle": toggle, rowFieldsAs: this.renderRowFields.bind(this), ...props });
41
+ };
42
+ this.onComboBoxChange = (option) => {
43
+ const editedCell = this.state.editedCell || this.activeElement;
44
+ if (editedCell && option) {
45
+ editedCell.newValue = option.text;
46
+ }
47
+ this.setState({ editedCell });
48
+ };
49
+ this.onDropdownCellValueChange = (selectedOption, item, rowIndex, column) => {
50
+ const newValue = selectedOption.key;
51
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
52
+ // @ts-ignore
53
+ if (typeof this.props.onSave === 'function' && Number.isInteger(rowIndex) && column) {
54
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
55
+ // @ts-ignore
56
+ const currentValue = this.props.items[rowIndex][column.key];
57
+ const editedCell = { rowIndex, item, column, errorMessage: undefined };
58
+ if (currentValue !== newValue) {
59
+ this.props.onSave(editedCell, newValue);
60
+ }
61
+ const field = column?.fieldName;
62
+ if (field && item) {
63
+ item[field] = newValue;
64
+ }
65
+ }
66
+ this.cancelEdit();
67
+ };
68
+ this.state = {
69
+ columns: props.columns || [],
70
+ items: props.items || []
71
+ };
72
+ this.tableRef = react_1.default.createRef();
73
+ this.selection = new react_2.Selection({
74
+ onSelectionChanged: () => {
75
+ if (typeof this.props.onSelectionChange !== 'function') {
76
+ return;
77
+ }
78
+ this.props.onSelectionChange(this.selection.getSelectedIndices());
79
+ }
80
+ });
81
+ if (this.props.selectionRef) {
82
+ this.props.selectionRef.current = this.selection;
83
+ }
84
+ this.onTextInputChange = this.onTextInputChange.bind(this);
85
+ this.onComboBoxChange = this.onComboBoxChange.bind(this);
86
+ this.onDocumentMousedown = this.onDocumentMousedown.bind(this);
87
+ this.onKeyDown = this.onKeyDown.bind(this);
88
+ this.onComboBoxKeyDownCapture = this.onComboBoxKeyDownCapture.bind(this);
89
+ this.validateCell = this.validateCell.bind(this);
90
+ this.editNextCell = this.editNextCell.bind(this);
91
+ this._onColumnClick = this._onColumnClick.bind(this);
92
+ this._onCellRender = this._onCellRender.bind(this);
93
+ this._onRenderCheckbox = this._onRenderCheckbox.bind(this);
94
+ this._onRenderField = this._onRenderField?.bind(this);
95
+ this._onRenderRow = this._onRenderRow?.bind(this);
96
+ this._onRenderItemColumn = this._onRenderItemColumn?.bind(this);
97
+ this._onCellActivation = this._onCellActivation?.bind(this);
98
+ }
99
+ componentDidMount() {
100
+ this.onDocMousedown = this.onDocumentMousedown;
101
+ document.addEventListener('mousedown', this.onDocMousedown, true);
102
+ window.dispatchEvent(new Event('resize'));
103
+ this._setTextRefs();
104
+ }
105
+ componentWillUnmount() {
106
+ document.removeEventListener('mousedown', this.onDocMousedown);
107
+ }
108
+ /**
109
+ * On component update.
110
+ *
111
+ * @param prevProps
112
+ * @param prevState
113
+ */
114
+ componentDidUpdate(prevProps, prevState) {
115
+ const scrollContainer = document.querySelector('.ms-ScrollablePane--contentContainer');
116
+ if (scrollContainer) {
117
+ const left = scrollContainer.scrollLeft || 0;
118
+ requestAnimationFrame(() => (scrollContainer.scrollLeft = left));
119
+ }
120
+ if (prevProps.items !== this.props.items) {
121
+ this.setState({ items: this.props.items });
122
+ this._setTextRefs();
123
+ }
124
+ if (prevProps.columns !== this.props.columns) {
125
+ this.setState({ columns: this.props.columns });
126
+ }
127
+ if (prevProps.dataSetKey !== this.props.dataSetKey) {
128
+ this.setState({ editedCell: undefined });
129
+ }
130
+ if (typeof this.props.selectedRow !== 'undefined' && prevProps.selectedRow !== this.props.selectedRow) {
131
+ UITable_helper_1.scrollToRow(this.props.selectedRow, this.tableRef?.current);
132
+ }
133
+ if (this.props.scrollToAddedRow) {
134
+ const dataSetChanged = this.props.dataSetKey !== prevProps.dataSetKey;
135
+ const { items } = this.state;
136
+ const { items: prevItems } = prevState;
137
+ const itemsDelta = items.length - prevItems.length;
138
+ const shouldScrollToNewRow = !dataSetChanged && itemsDelta === 1;
139
+ if (shouldScrollToNewRow && this.tableRef && this.tableRef.current) {
140
+ const newRowIndex = items.length - 1;
141
+ this.tableRef.current.scrollToIndex(newRowIndex);
142
+ }
143
+ }
144
+ const { selectedColumnId } = this.props;
145
+ const { selectedColumnId: prevSelectedColumnId } = prevProps;
146
+ // Due to table rendering using columns data from state, instead of props,
147
+ // to sync selected column change callback with rendered dataset change
148
+ // selected column id/key needs to be stored on a state level along with columns data
149
+ if (selectedColumnId !== prevSelectedColumnId) {
150
+ this.setState({ selectedColumnId });
151
+ }
152
+ const columnIsSelected = typeof this.state.selectedColumnId !== 'undefined';
153
+ const selectedColumnDidChange = prevState.selectedColumnId !== this.state.selectedColumnId;
154
+ if (columnIsSelected && selectedColumnDidChange) {
155
+ UITable_helper_1.scrollToColumn(this.state.selectedColumnId || '', this.state.columns, this.props.selectedRow || 0, this.props.showRowNumbers);
156
+ }
157
+ }
158
+ _setTextRefs() {
159
+ if (this.props.columns && this.props.items) {
160
+ for (const rowIndexTmp in this.props.items) {
161
+ for (const col of this.props.columns) {
162
+ if (col.editable === true && this.inputRefs) {
163
+ this.inputRefs[rowIndexTmp] = this.inputRefs[rowIndexTmp] || {};
164
+ this.inputRefs[rowIndexTmp][col.key] = react_1.default.createRef();
165
+ }
166
+ }
167
+ }
168
+ }
169
+ }
170
+ /**
171
+ * On render row fields event.
172
+ *
173
+ * @param props
174
+ * @returns {JSX.Element}
175
+ */
176
+ renderRowFields(props) {
177
+ // disabled is set to false when selectionMode === undefined || selectionMode === SelectionMode.single
178
+ let disabled = false;
179
+ const selectionMode = this.props.selectionMode;
180
+ if (selectionMode === react_2.SelectionMode.multiple || selectionMode === react_2.SelectionMode.none) {
181
+ disabled = true;
182
+ }
183
+ return (react_1.default.createElement("div", { "data-selection-disabled": disabled },
184
+ react_1.default.createElement(react_2.DetailsRowFields, { ...props })));
185
+ }
186
+ /**
187
+ * On render field event.
188
+ *
189
+ * @param props
190
+ * @param defaultRender
191
+ *
192
+ * @returns {null | JSX.Element}
193
+ */
194
+ _onRenderField(props, defaultRender) {
195
+ if (!props || !defaultRender) {
196
+ return null;
197
+ }
198
+ const cell = defaultRender(props);
199
+ const onClick = (e) => {
200
+ const target = e?.target;
201
+ const targetTag = target?.tagName;
202
+ if (['INPUT', 'TEXTAREA', 'SELECT'].includes(targetTag)) {
203
+ return;
204
+ }
205
+ const { item, rowIndex, column } = this.activeElement;
206
+ this._onCellClick(e, item, rowIndex || 0, column);
207
+ };
208
+ // in app-migrator, show a warning message for library projects on main migration view
209
+ if (props.item.hideCells && props.column.fieldName === 'moduleName' && !props.item.status) {
210
+ return (react_1.default.createElement("div", { ...(cell?.props || {}), "data-is-focusable": true, onClick: onClick, tabIndex: "0" },
211
+ cell?.props?.children || null,
212
+ react_1.default.createElement("div", { className: "table-item-warning" }, "This is a reuse library and does not require input during migration")));
213
+ }
214
+ else {
215
+ return (react_1.default.createElement("div", { ...(cell?.props || {}), "data-is-focusable": true, onClick: onClick, tabIndex: "0" }, cell?.props?.children || null));
216
+ }
217
+ }
218
+ // just sets the active element property on the table, to track it later
219
+ /**
220
+ * On cell activation event.
221
+ *
222
+ * @param item
223
+ * @param rowIndex
224
+ * @param ev
225
+ */
226
+ _onCellActivation(item, rowIndex, ev) {
227
+ const rowEl = ev?.target?.closest('.ms-DetailsRow');
228
+ let column = {};
229
+ const cells = rowEl?.querySelectorAll('.ms-DetailsRow-fields .ms-DetailsRow-cell');
230
+ if (!cells || !cells.length) {
231
+ return;
232
+ }
233
+ // focusing cell, not the row
234
+ const cellEl = ev?.target?.closest('.ms-DetailsRow-cell');
235
+ if (cellEl) {
236
+ const cellIdx = Array.from(cells).indexOf(cellEl);
237
+ if (cellIdx === -1) {
238
+ return;
239
+ }
240
+ column = this.props.columns[cellIdx];
241
+ if (!column) {
242
+ return;
243
+ }
244
+ }
245
+ this.activeElement = { item, rowIndex: rowIndex || 0, column };
246
+ if (this.props.renderInputs && column?.editable) {
247
+ const isDropdown = this.activeElement?.column?.columnControlType === types_1.ColumnControlType?.UIDropdown;
248
+ if (!isDropdown && this.state.editedCell?.column?.key !== this.activeElement?.column?.key) {
249
+ this.setState({ editedCell: this.activeElement });
250
+ }
251
+ }
252
+ }
253
+ /**
254
+ * On render item column event.
255
+ *
256
+ * @param {UIDocument} item
257
+ * @param {number} index
258
+ * @param {UIColumn} column
259
+ *
260
+ * @returns {React.ReactNode}
261
+ */
262
+ _onRenderItemColumn(item, index, column) {
263
+ if (column?.key === '__row_number__') {
264
+ return react_1.default.createElement("div", { className: "ms-DetailsList-row-number" }, (index || 0) + 1);
265
+ }
266
+ return item[column?.fieldName || ''] || '';
267
+ }
268
+ // Replace weird radio-button-checkboxes with proper checkboxes
269
+ /**
270
+ * On render checkbox event.
271
+ *
272
+ * @param {IDetailsListCheckboxProps | undefined} props
273
+ * @returns {React.ReactElement}
274
+ */
275
+ _onRenderCheckbox(props) {
276
+ return react_1.default.createElement(UICheckbox_1.UICheckbox, { ...props });
277
+ }
278
+ // COLUMN HEADER SORT
279
+ /**
280
+ * On column click event.
281
+ *
282
+ * @param ev
283
+ * @param column
284
+ */
285
+ _onColumnClick(ev, column) {
286
+ const { columns, items } = this.state;
287
+ const newColumns = columns.slice();
288
+ const currColumn = newColumns.filter((currCol) => column.key === currCol.key)[0];
289
+ newColumns.forEach((newCol) => {
290
+ if (newCol === currColumn) {
291
+ currColumn.isSortedDescending = !currColumn.isSortedDescending;
292
+ currColumn.isSorted = true;
293
+ }
294
+ else {
295
+ newCol.isSorted = false;
296
+ newCol.isSortedDescending = false;
297
+ }
298
+ });
299
+ const field = currColumn.fieldName || currColumn.name || '';
300
+ const newItems = UITable_helper_1._copyAndSort(items, field, currColumn.isSortedDescending);
301
+ this.setState({ columns: newColumns, items: newItems });
302
+ }
303
+ // CELL EDITING
304
+ /**
305
+ * On start edit event call.
306
+ *
307
+ * @param rowIndex
308
+ * @param item
309
+ * @param column
310
+ * @param errorMessage
311
+ */
312
+ startEdit(rowIndex, item, column, errorMessage) {
313
+ const { editedCell } = this.state;
314
+ const isAlreadyInEdit = editedCell?.rowIndex === rowIndex && column?.key && editedCell?.column?.key === column?.key;
315
+ if (!isAlreadyInEdit) {
316
+ this.setState({ editedCell: { rowIndex, item, column, errorMessage } });
317
+ if (!this.props.renderInputs) {
318
+ this.rerenderTable();
319
+ }
320
+ }
321
+ requestAnimationFrame(() => {
322
+ if (column?.columnControlType === types_1.ColumnControlType.UITextInput) {
323
+ this.inputRefs?.[rowIndex][column?.key]?.current?.select();
324
+ }
325
+ else if (column?.columnControlType === types_1.ColumnControlType.UIBooleanSelect) {
326
+ const combo = this.inputRefs?.[rowIndex][column?.key];
327
+ UITable_helper_1.getComboBoxInput(combo)?.focus();
328
+ }
329
+ else if (column?.columnControlType === types_1.ColumnControlType.UIDatePicker) {
330
+ this.inputRefs?.[rowIndex][column?.key]?.current?.select();
331
+ }
332
+ else if (column?.key) {
333
+ const otherElement = this.inputRefs?.[rowIndex][column.key]?.current;
334
+ otherElement.focus();
335
+ }
336
+ });
337
+ }
338
+ rerenderTable() {
339
+ if (this.tableRef.current) {
340
+ this.tableRef.current.forceUpdate();
341
+ }
342
+ }
343
+ cancelEdit() {
344
+ this.setState({ editedCell: undefined });
345
+ this.rerenderTable();
346
+ }
347
+ /**
348
+ * On save cell event.
349
+ *
350
+ * @param cancelEdit
351
+ * @param value
352
+ */
353
+ saveCell(cancelEdit = false, value) {
354
+ if (typeof this.props.onSave === 'function' && this.state.editedCell) {
355
+ const { rowIndex, column } = this.state.editedCell;
356
+ if (column?.columnControlType !== types_1.ColumnControlType.UIDropdown && !this.state.editedCell.errorMessage) {
357
+ let compRef;
358
+ if (column && this?.inputRefs?.[rowIndex]?.[column.key]) {
359
+ compRef = this?.inputRefs[rowIndex][column.key];
360
+ }
361
+ const currentValue = column && this.props.items[rowIndex][column.key];
362
+ let refValue = '';
363
+ if (column?.columnControlType === types_1.ColumnControlType.UITextInput) {
364
+ refValue = compRef?.current?.value || '';
365
+ }
366
+ else if (column?.columnControlType === types_1.ColumnControlType.UIDatePicker) {
367
+ refValue = compRef?.current?.value || '';
368
+ }
369
+ else if (column?.columnControlType === types_1.ColumnControlType.UIBooleanSelect) {
370
+ const combo = compRef;
371
+ refValue = UITable_helper_1.getComboBoxInput(combo)?.value || '';
372
+ }
373
+ const newValue = value ?? refValue;
374
+ if (currentValue !== newValue) {
375
+ this.props.onSave(this.state.editedCell, newValue);
376
+ }
377
+ const item = this.state.editedCell?.item;
378
+ const field = column?.fieldName;
379
+ if (field && item) {
380
+ item[field] = newValue;
381
+ }
382
+ }
383
+ }
384
+ if (cancelEdit) {
385
+ this.cancelEdit();
386
+ }
387
+ }
388
+ /**
389
+ * On mouse down event.
390
+ *
391
+ * @param e
392
+ */
393
+ onDocumentMousedown(e) {
394
+ const target = e.target; // needed for TSC
395
+ if (target.closest('.ms-TextField') ||
396
+ target.closest('.ms-ComboBox') ||
397
+ target.closest('.ms-ComboBox-option') ||
398
+ target.closest('.ui-DatePicker')) {
399
+ return;
400
+ }
401
+ if (this.state.editedCell) {
402
+ if (this.state.editedCell.errorMessage) {
403
+ e.preventDefault();
404
+ }
405
+ else {
406
+ this.saveCell(true);
407
+ }
408
+ }
409
+ }
410
+ /**
411
+ * On key down event.
412
+ *
413
+ * @param {React.KeyboardEvent<Element | IDropdown>} e
414
+ * @returns {void}
415
+ */
416
+ onKeyDown(e) {
417
+ if (!['Enter', 'Tab', 'Escape', 'ArrowDown', 'ArrowUp', 'ArrowLeft', 'ArrowRight'].includes(e.key)) {
418
+ return;
419
+ }
420
+ const isArrow = ['ArrowDown', 'ArrowUp', 'ArrowLeft', 'ArrowRight'].includes(e.key);
421
+ const isInput = e.target.tagName === 'INPUT';
422
+ if (isArrow && isInput) {
423
+ e.stopPropagation();
424
+ return;
425
+ }
426
+ e.preventDefault();
427
+ if (e.key === 'Escape') {
428
+ this.cancelEdit();
429
+ UITable_helper_1.focusEditedCell(this.state.editedCell, this.props);
430
+ return UITable_helper_1.showFocus();
431
+ }
432
+ if (this.state.editedCell?.errorMessage) {
433
+ return;
434
+ }
435
+ e.stopPropagation();
436
+ if (e.key === 'Enter' || e.key === 'Tab') {
437
+ this.editNextCell(e.key, e.shiftKey);
438
+ }
439
+ }
440
+ /**
441
+ * On ComboBox keydown event call.
442
+ *
443
+ * @param e
444
+ */
445
+ onComboBoxKeyDownCapture(e) {
446
+ if (e.key === 'Enter' || e.key === 'Tab') {
447
+ // stop Enter from opening combobox
448
+ e.stopPropagation();
449
+ e.preventDefault();
450
+ this.editNextCell(e.key, e.shiftKey);
451
+ }
452
+ }
453
+ /**
454
+ * On Edit next cell.
455
+ *
456
+ * @param key
457
+ * @param shiftKey
458
+ */
459
+ editNextCell(key, shiftKey) {
460
+ this.saveCell();
461
+ let direction = '';
462
+ if (key === 'Enter') {
463
+ direction = shiftKey ? 'up' : 'down';
464
+ }
465
+ else if (key === 'Tab') {
466
+ direction = shiftKey ? 'left' : 'right';
467
+ }
468
+ if (direction) {
469
+ UITable_helper_1.hideFocus();
470
+ }
471
+ setTimeout(() => {
472
+ UITable_helper_1.focusEditedCell(this.state.editedCell, this.props, direction)
473
+ .then(() => {
474
+ if (!direction) {
475
+ return UITable_helper_1.showFocus();
476
+ }
477
+ UITable_helper_1.hideFocus();
478
+ const { rowIndex, item, column } = this.activeElement;
479
+ this.startEdit(rowIndex, item, column);
480
+ })
481
+ .catch((e) => {
482
+ throw e;
483
+ });
484
+ }, 100);
485
+ }
486
+ /**
487
+ * On Cell click.
488
+ *
489
+ * @param e
490
+ * @param item
491
+ * @param rowIndex
492
+ * @param column
493
+ */
494
+ _onCellClick(e, item, rowIndex, column) {
495
+ const previousCellHasErrors = this.state.editedCell?.errorMessage;
496
+ if (previousCellHasErrors) {
497
+ return;
498
+ }
499
+ if (this.props.renderInputs) {
500
+ return;
501
+ }
502
+ const el = e?.target;
503
+ requestAnimationFrame(() => {
504
+ // check the checkbox & focus the clicked cell
505
+ if (el) {
506
+ // the eslint comments below are necessary.
507
+ // If removed - eslint will show another error, that click/focus don't exist...
508
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion
509
+ const fz = el.closest('.ms-FocusZone');
510
+ if (fz && fz.click) {
511
+ fz.click();
512
+ }
513
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion
514
+ const cell = el.closest('.ms-DetailsRow-cell');
515
+ if (cell && cell.focus) {
516
+ cell.focus();
517
+ }
518
+ }
519
+ if (column?.editable !== true) {
520
+ UITable_helper_1.showFocus();
521
+ }
522
+ });
523
+ if (rowIndex !== undefined && item && column && column.editable === true) {
524
+ e?.stopPropagation();
525
+ requestAnimationFrame(() => this.startEdit(rowIndex, item, column));
526
+ }
527
+ }
528
+ /**
529
+ * Validates cell.
530
+ * @param value
531
+ */
532
+ validateCell(value) {
533
+ const editedCell = this.state.editedCell;
534
+ const column = editedCell?.column;
535
+ let errorMessage = '';
536
+ if (column && typeof column.validate === 'function') {
537
+ errorMessage = column.validate(value);
538
+ }
539
+ if (editedCell && editedCell.errorMessage !== errorMessage) {
540
+ editedCell.errorMessage = errorMessage || undefined;
541
+ this.setState({ editedCell });
542
+ this.rerenderTable();
543
+ }
544
+ }
545
+ /**
546
+ * On Text input change.
547
+ *
548
+ * @param e
549
+ * @param newValue
550
+ */
551
+ onTextInputChange(e, newValue = '') {
552
+ const editedCell = this.state.editedCell || this.activeElement;
553
+ if (editedCell) {
554
+ editedCell.newValue = newValue;
555
+ }
556
+ this.setState({ editedCell });
557
+ const column = editedCell?.column;
558
+ if (column && typeof column.validate === 'function') {
559
+ this.validateCell(newValue);
560
+ }
561
+ if (this.props.renderInputs) {
562
+ this.saveCell(false, newValue);
563
+ }
564
+ }
565
+ /**
566
+ * Gets input ref.
567
+ *
568
+ * @param rowIndex
569
+ * @param column
570
+ * @returns { React.RefObject<ITextField | IDropdown | UIComboBox> | undefined}
571
+ */
572
+ _getInputRef(rowIndex, column) {
573
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
574
+ // @ts-ignore
575
+ return this?.inputRefs?.[rowIndex]?.[column.key];
576
+ }
577
+ /**
578
+ * Renders dropdown.
579
+ *
580
+ * @param item
581
+ * @param rowIndex
582
+ * @param column
583
+ * @returns {any}
584
+ */
585
+ _renderDropdown(item, rowIndex, column) {
586
+ const compRef = this._getInputRef(rowIndex, column);
587
+ return (react_1.default.createElement(UIDropdown_1.UIDropdown, { hidden: item.hideCells ?? false, placeholder: "Select an option", componentRef: compRef, options: column?.data.dropdownOptions,
588
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
589
+ // @ts-ignore
590
+ defaultSelectedKey: item[column?.key] || column?.data.defaultSelectedKey, onChange: (ev, text) => this.onDropdownCellValueChange(text, item, rowIndex, column), onKeyDown: this.onKeyDown }));
591
+ }
592
+ /**
593
+ * Renders boolean select.
594
+ *
595
+ * @param item
596
+ * @param rowIndex
597
+ * @param column
598
+ *
599
+ * @returns {any}
600
+ */
601
+ _renderBooleanSelect(item, rowIndex, column) {
602
+ const compRef = this._getInputRef(rowIndex, column);
603
+ const newValue = this.state.editedCell?.newValue;
604
+ let value;
605
+ if (column?.fieldName) {
606
+ value = item[column?.fieldName];
607
+ }
608
+ if (typeof newValue !== 'undefined') {
609
+ value = newValue;
610
+ }
611
+ return (react_1.default.createElement(UIComboBox_1.UIComboBox, { defaultSelectedKey: value, allowFreeform: false, autoComplete: "on", shouldRestoreFocus: false, componentRef: compRef, errorMessage: this.state.editedCell?.errorMessage, openMenuOnClick: false, onPendingValueChanged: this.onComboBoxChange, onKeyDown: this.onKeyDown, onKeyDownCapture: this.onComboBoxKeyDownCapture, onClick: (e) => {
612
+ e.stopPropagation();
613
+ }, options: [
614
+ { key: 'true', text: 'true' },
615
+ { key: 'false', text: 'false' }
616
+ ] }));
617
+ }
618
+ /**
619
+ * Renders date picker.
620
+ *
621
+ * @param item
622
+ * @param rowIndex
623
+ * @param column
624
+ * @param dateOnly
625
+ *
626
+ * @returns {any}
627
+ */
628
+ _renderDatePicker(item, rowIndex, column, dateOnly = true) {
629
+ const compRef = this._getInputRef(rowIndex, column);
630
+ const newValue = this.state.editedCell?.newValue;
631
+ let value;
632
+ if (column?.fieldName) {
633
+ value = item[column?.fieldName];
634
+ }
635
+ if (typeof newValue !== 'undefined') {
636
+ value = newValue;
637
+ }
638
+ return (react_1.default.createElement(UIDatePicker_1.UIDatePicker, { defaultValue: value, componentRef: compRef, dateOnly: dateOnly, errorMessage: this.state.editedCell?.errorMessage, onChange: this.onTextInputChange, onKeyDown: this.onKeyDown, onClick: (e) => {
639
+ e.stopPropagation();
640
+ } }));
641
+ }
642
+ /**
643
+ * Renders text input.
644
+ *
645
+ * @param item
646
+ * @param rowIndex
647
+ * @param column
648
+ *
649
+ * @returns {any}
650
+ */
651
+ _renderTextInput(item, rowIndex, column) {
652
+ const compRef = this._getInputRef(rowIndex, column);
653
+ const newValue = this.state.editedCell?.newValue;
654
+ let value;
655
+ if (column?.fieldName) {
656
+ value = item[column?.fieldName];
657
+ }
658
+ if (typeof newValue !== 'undefined') {
659
+ value = newValue;
660
+ }
661
+ if (!item.hideCells) {
662
+ return (react_1.default.createElement(UIInput_1.UITextInput
663
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
664
+ // @ts-ignore
665
+ , {
666
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
667
+ // @ts-ignore
668
+ defaultValue: value, componentRef: compRef, errorMessage: this.state.editedCell?.errorMessage, onChange: this.onTextInputChange, onKeyDown: this.onKeyDown, onClick: (e) => {
669
+ e.stopPropagation();
670
+ } }));
671
+ }
672
+ }
673
+ /**
674
+ * On cell render.
675
+ *
676
+ * @param item
677
+ * @param rowIndex
678
+ * @param column
679
+ * @returns {any}
680
+ */
681
+ _onCellRender(item, rowIndex, column) {
682
+ // inputs & dropdowns always visible
683
+ if (this.props.renderInputs && rowIndex !== undefined) {
684
+ if (column?.columnControlType === types_1.ColumnControlType.UIDropdown) {
685
+ return this._renderDropdown(item, rowIndex, column);
686
+ }
687
+ return this._renderTextInput(item, rowIndex, column);
688
+ }
689
+ // inputs visible only in "edit mode" (after cell click)
690
+ const editedCell = this.state.editedCell;
691
+ const itsThisRow = editedCell && editedCell.rowIndex === rowIndex;
692
+ const itsThisCol = editedCell && editedCell.column?.key === column?.key;
693
+ const isCellInEditMode = itsThisRow && itsThisCol;
694
+ if (isCellInEditMode && rowIndex !== undefined) {
695
+ if (column?.columnControlType === types_1.ColumnControlType.UIBooleanSelect) {
696
+ return this._renderBooleanSelect(item, rowIndex, column);
697
+ }
698
+ else if (column?.columnControlType === types_1.ColumnControlType.UIDatePicker) {
699
+ return this._renderDatePicker(item, rowIndex, column, column?.type === 'Date');
700
+ }
701
+ else {
702
+ return this._renderTextInput(item, rowIndex, column);
703
+ }
704
+ }
705
+ const onClick = (e) => {
706
+ e.stopPropagation();
707
+ this._onCellClick(e, item, rowIndex || 0, column);
708
+ };
709
+ return (react_1.default.createElement("span", { style: { cursor: 'text', padding: 5 }, onClick: onClick }, item[column?.fieldName || 0]));
710
+ }
711
+ /**
712
+ * @returns {JSX.Element}
713
+ */
714
+ render() {
715
+ // get columns & items from props, so that detailsListProps does not contain them
716
+ // because we want them to come from state, and be passed to component only once
717
+ let { columns, items, checkboxVisibility, headerRenderer, selectionMode } = this.props;
718
+ const { scrollablePaneProps, showRowNumbers, ...detailsListProps } = this.props;
719
+ // get them from state if they exist
720
+ if (this.state.columns) {
721
+ columns = this.state.columns;
722
+ }
723
+ if (this.state.items) {
724
+ items = this.state.items;
725
+ }
726
+ if (columns) {
727
+ columns.forEach((col) => {
728
+ col.onColumnClick = this._onColumnClick;
729
+ if (col.editable === true) {
730
+ col.onRender = this._onCellRender;
731
+ }
732
+ else {
733
+ col.className = 'uneditable';
734
+ }
735
+ if (col.key === this.props.selectedColumnId) {
736
+ col.headerClassName = 'selected';
737
+ }
738
+ });
739
+ columns = UITable_helper_1.addRowNumbers(columns, showRowNumbers);
740
+ }
741
+ const styles = UITable_helper_1.getStylesForSelectedCell(this.state);
742
+ if (typeof checkboxVisibility === 'undefined') {
743
+ checkboxVisibility = react_2.CheckboxVisibility.hidden;
744
+ }
745
+ if (typeof selectionMode === 'undefined') {
746
+ selectionMode = react_2.SelectionMode.single;
747
+ }
748
+ if (typeof headerRenderer === 'undefined') {
749
+ headerRenderer = UITable_helper_1._onHeaderRender;
750
+ }
751
+ const focusZoneProps = {
752
+ direction: react_2.FocusZoneDirection.vertical,
753
+ shouldEnterInnerZone: (ev) => {
754
+ return ev.key === 'ArrowRight';
755
+ }
756
+ };
757
+ return (react_1.default.createElement(react_2.ScrollablePane, { ...scrollablePaneProps, styles: { stickyAbove: { zIndex: 2 } } },
758
+ react_1.default.createElement(react_2.DetailsList, { checkboxVisibility: checkboxVisibility, componentRef: this.tableRef, selection: this.selection, selectionMode: selectionMode, onRenderCheckbox: this._onRenderCheckbox, onRenderDetailsHeader: headerRenderer, onRenderField: this._onRenderField, onRenderRow: this._onRenderRow, onRenderItemColumn: this._onRenderItemColumn, layoutMode: react_2.DetailsListLayoutMode.fixedColumns, constrainMode: react_2.ConstrainMode.unconstrained, focusZoneProps: focusZoneProps, onActiveItemChanged: this._onCellActivation, ...detailsListProps, items: items, columns: columns, styles: styles })));
759
+ }
760
+ }
761
+ exports.UITable = UITable;
762
+ //# sourceMappingURL=UITable.js.map