@talxis/base-controls 1.2509.1-alpha.6 → 1.2509.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (467) hide show
  1. package/dist/components/DatasetControl/DatasetControl.js +55 -59
  2. package/dist/components/DatasetControl/DatasetControl.js.map +1 -1
  3. package/dist/components/DatasetControl/Paging/DatasetPaging.d.ts +3 -0
  4. package/dist/components/DatasetControl/Paging/DatasetPaging.js +69 -0
  5. package/dist/components/DatasetControl/Paging/DatasetPaging.js.map +1 -0
  6. package/dist/components/DatasetControl/Paging/Paging.d.ts +26 -0
  7. package/dist/components/DatasetControl/Paging/Paging.js +80 -0
  8. package/dist/components/DatasetControl/Paging/Paging.js.map +1 -0
  9. package/dist/components/DatasetControl/Paging/index.d.ts +3 -0
  10. package/dist/components/DatasetControl/Paging/index.js +3 -0
  11. package/dist/components/DatasetControl/Paging/index.js.map +1 -0
  12. package/dist/components/DatasetControl/Paging/interfaces.d.ts +16 -0
  13. package/dist/components/DatasetControl/Paging/styles.d.ts +35 -0
  14. package/dist/components/DatasetControl/Paging/styles.js +41 -0
  15. package/dist/components/DatasetControl/Paging/styles.js.map +1 -0
  16. package/dist/components/DatasetControl/Paging/translations.d.ts +38 -0
  17. package/dist/components/DatasetControl/Paging/translations.js +14 -0
  18. package/dist/components/DatasetControl/Paging/translations.js.map +1 -0
  19. package/dist/components/DatasetControl/QuickFind/QuickFind.d.ts +12 -4
  20. package/dist/components/DatasetControl/QuickFind/QuickFind.js +32 -36
  21. package/dist/components/DatasetControl/QuickFind/QuickFind.js.map +1 -1
  22. package/dist/components/DatasetControl/QuickFind/styles.d.ts +1 -1
  23. package/dist/components/DatasetControl/QuickFind/styles.js +2 -2
  24. package/dist/components/DatasetControl/QuickFind/styles.js.map +1 -1
  25. package/dist/components/DatasetControl/index.d.ts +1 -0
  26. package/dist/components/DatasetControl/index.js +2 -0
  27. package/dist/components/DatasetControl/index.js.map +1 -1
  28. package/dist/components/DatasetControl/interfaces.d.ts +20 -54
  29. package/dist/components/DatasetControl/styles.d.ts +11 -4
  30. package/dist/components/DatasetControl/styles.js +11 -5
  31. package/dist/components/DatasetControl/styles.js.map +1 -1
  32. package/dist/components/DatasetControl/translations.d.ts +0 -44
  33. package/dist/components/DatasetControl/translations.js +1 -15
  34. package/dist/components/DatasetControl/translations.js.map +1 -1
  35. package/dist/components/Grid/Grid.d.ts +3 -0
  36. package/dist/components/Grid/Grid.js +37 -0
  37. package/dist/components/Grid/Grid.js.map +1 -0
  38. package/dist/components/Grid/GridContext.d.ts +3 -0
  39. package/dist/components/Grid/GridContext.js.map +1 -0
  40. package/dist/components/Grid/aggregation/Aggregation.d.ts +18 -0
  41. package/dist/components/Grid/aggregation/Aggregation.js +129 -0
  42. package/dist/components/Grid/aggregation/Aggregation.js.map +1 -0
  43. package/dist/components/Grid/{grid/Grid.d.ts → core/components/AgGrid/AgGrid.d.ts} +2 -2
  44. package/dist/components/Grid/core/components/AgGrid/AgGrid.js +203 -0
  45. package/dist/components/Grid/core/components/AgGrid/AgGrid.js.map +1 -0
  46. package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/EmptyRecords.js +12 -0
  47. package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/EmptyRecords.js.map +1 -0
  48. package/dist/components/Grid/{overlays/empty-records → core/components/AgGrid/components/EmptyRecordsOverlay}/styles.d.ts +1 -1
  49. package/dist/components/Grid/{overlays/empty-records → core/components/AgGrid/components/EmptyRecordsOverlay}/styles.js +1 -1
  50. package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/styles.js.map +1 -0
  51. package/dist/components/Grid/core/components/AgGrid/components/LoadingOverlay/LoadingOverlay.js.map +1 -0
  52. package/dist/components/Grid/{grid/ag-grid/AgGridContext.d.ts → core/components/AgGrid/context.d.ts} +2 -2
  53. package/dist/components/Grid/{grid/ag-grid/AgGridContext.js → core/components/AgGrid/context.js} +1 -1
  54. package/dist/components/Grid/core/components/AgGrid/context.js.map +1 -0
  55. package/dist/components/Grid/core/components/AgGrid/model/AgGrid.d.ts +52 -0
  56. package/dist/components/Grid/core/components/AgGrid/model/AgGrid.js +343 -0
  57. package/dist/components/Grid/core/components/AgGrid/model/AgGrid.js.map +1 -0
  58. package/dist/components/Grid/{grid/ValueComparator.d.ts → core/components/AgGrid/model/Comparator.d.ts} +1 -1
  59. package/dist/components/Grid/{grid/ValueComparator.js → core/components/AgGrid/model/Comparator.js} +1 -7
  60. package/dist/components/Grid/core/components/AgGrid/model/Comparator.js.map +1 -0
  61. package/dist/components/Grid/{grid → core/components/AgGrid}/styles.d.ts +4 -24
  62. package/dist/components/Grid/{grid → core/components/AgGrid}/styles.js +6 -37
  63. package/dist/components/Grid/core/components/AgGrid/styles.js.map +1 -0
  64. package/dist/components/Grid/{cells/cell → core/components/Cell}/Cell.d.ts +3 -3
  65. package/dist/components/Grid/core/components/Cell/Cell.js +158 -0
  66. package/dist/components/Grid/core/components/Cell/Cell.js.map +1 -0
  67. package/dist/components/Grid/{cells/cell/content → core/components/Cell/CellContent}/CellContent.d.ts +2 -2
  68. package/dist/components/Grid/{cells/cell/content → core/components/Cell/CellContent}/CellContent.js +31 -40
  69. package/dist/components/Grid/core/components/Cell/CellContent/CellContent.js.map +1 -0
  70. package/dist/components/Grid/core/components/Cell/CellContent/styles.js.map +1 -0
  71. package/dist/components/Grid/{cells/cell/notifications → core/components/Cell/Notifications}/Notifications.d.ts +1 -1
  72. package/dist/components/Grid/{cells/cell/notifications → core/components/Cell/Notifications}/Notifications.js +5 -5
  73. package/dist/components/Grid/core/components/Cell/Notifications/Notifications.js.map +1 -0
  74. package/dist/components/Grid/{cells/cell/notifications → core/components/Cell/Notifications}/styles.js +1 -1
  75. package/dist/components/Grid/core/components/Cell/Notifications/styles.js.map +1 -0
  76. package/dist/components/Grid/{cells/cell → core/components/Cell}/styles.d.ts +3 -34
  77. package/dist/components/Grid/core/components/Cell/styles.js +59 -0
  78. package/dist/components/Grid/core/components/Cell/styles.js.map +1 -0
  79. package/dist/components/Grid/{column-headers/column-header → core/components/ColumnHeader}/ColumnHeader.d.ts +1 -1
  80. package/dist/components/Grid/core/components/ColumnHeader/ColumnHeader.js +61 -0
  81. package/dist/components/Grid/core/components/ColumnHeader/ColumnHeader.js.map +1 -0
  82. package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/GlobalCheckbox.d.ts +2 -0
  83. package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/GlobalCheckbox.js +50 -0
  84. package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/GlobalCheckbox.js.map +1 -0
  85. package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/styles.js.map +1 -0
  86. package/dist/components/Grid/core/components/ColumnHeader/styles.d.ts +42 -0
  87. package/dist/components/Grid/core/components/ColumnHeader/styles.js +48 -0
  88. package/dist/components/Grid/core/components/ColumnHeader/styles.js.map +1 -0
  89. package/dist/components/Grid/core/components/Dialog/Constants.d.ts +2 -0
  90. package/dist/components/Grid/core/components/Dialog/Constants.js +9 -0
  91. package/dist/components/Grid/core/components/Dialog/Constants.js.map +1 -0
  92. package/dist/components/Grid/core/components/Dialog/Styles.d.ts +2 -0
  93. package/dist/components/Grid/core/components/Dialog/Styles.js +61 -0
  94. package/dist/components/Grid/core/components/Dialog/Styles.js.map +1 -0
  95. package/dist/components/Grid/core/components/Dialog/index.d.ts +4 -0
  96. package/dist/components/Grid/core/components/Dialog/index.js +16 -0
  97. package/dist/components/Grid/core/components/Dialog/index.js.map +1 -0
  98. package/dist/components/Grid/core/components/Dialog/interfaces/index.d.ts +6 -0
  99. package/dist/components/Grid/core/components/Dialog/interfaces/index.js +2 -0
  100. package/dist/components/Grid/core/components/Dialog/interfaces/index.js.map +1 -0
  101. package/dist/components/Grid/core/components/Save/Save.d.ts +2 -0
  102. package/dist/components/Grid/core/components/Save/Save.js +59 -0
  103. package/dist/components/Grid/core/components/Save/Save.js.map +1 -0
  104. package/dist/components/Grid/core/components/Save/components/ChangeEditor/ChangeEditor.d.ts +7 -0
  105. package/dist/components/Grid/core/components/Save/components/ChangeEditor/ChangeEditor.js +73 -0
  106. package/dist/components/Grid/core/components/Save/components/ChangeEditor/ChangeEditor.js.map +1 -0
  107. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/ChangeGrid.d.ts +11 -0
  108. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/ChangeGrid.js +231 -0
  109. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/ChangeGrid.js.map +1 -0
  110. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/styles.d.ts +39 -0
  111. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/styles.js +45 -0
  112. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/styles.js.map +1 -0
  113. package/dist/components/Grid/core/components/Save/components/ChangeEditor/styles.d.ts +31 -0
  114. package/dist/components/Grid/core/components/Save/components/ChangeEditor/styles.js +37 -0
  115. package/dist/components/Grid/core/components/Save/components/ChangeEditor/styles.js.map +1 -0
  116. package/dist/components/Grid/core/components/Save/styles.d.ts +35 -0
  117. package/dist/components/Grid/core/components/Save/styles.js +42 -0
  118. package/dist/components/Grid/core/components/Save/styles.js.map +1 -0
  119. package/dist/components/Grid/core/controllers/useGridController.d.ts +7 -0
  120. package/dist/components/Grid/core/controllers/useGridController.js +29 -0
  121. package/dist/components/Grid/core/controllers/useGridController.js.map +1 -0
  122. package/dist/components/Grid/core/enums/ConditionOperator.d.ts +48 -0
  123. package/dist/components/Grid/core/enums/ConditionOperator.js +52 -0
  124. package/dist/components/Grid/core/enums/ConditionOperator.js.map +1 -0
  125. package/dist/components/Grid/core/enums/DataType.d.ts +25 -0
  126. package/dist/components/Grid/core/enums/DataType.js +30 -0
  127. package/dist/components/Grid/core/enums/DataType.js.map +1 -0
  128. package/dist/components/Grid/core/hooks/useGridInstance.d.ts +2 -0
  129. package/dist/components/Grid/{grid → core/hooks}/useGridInstance.js +2 -2
  130. package/dist/components/Grid/core/hooks/useGridInstance.js.map +1 -0
  131. package/dist/components/Grid/core/hooks/useRefreshCallback.d.ts +2 -0
  132. package/dist/components/Grid/core/hooks/useRefreshCallback.js +20 -0
  133. package/dist/components/Grid/core/hooks/useRefreshCallback.js.map +1 -0
  134. package/dist/components/Grid/core/interfaces/IGridColumn.d.ts +13 -0
  135. package/dist/components/Grid/core/interfaces/IGridContext.d.ts +4 -0
  136. package/dist/components/Grid/core/model/Grid.d.ts +83 -0
  137. package/dist/components/Grid/core/model/Grid.js +528 -0
  138. package/dist/components/Grid/core/model/Grid.js.map +1 -0
  139. package/dist/components/Grid/core/model/GridDependency.d.ts +13 -0
  140. package/dist/components/Grid/core/model/GridDependency.js +28 -0
  141. package/dist/components/Grid/core/model/GridDependency.js.map +1 -0
  142. package/dist/components/Grid/core/services/KeyListener.d.ts +12 -0
  143. package/dist/components/Grid/core/services/KeyListener.js +31 -0
  144. package/dist/components/Grid/core/services/KeyListener.js.map +1 -0
  145. package/dist/components/Grid/{column-headers/column-header → filtering/components/FilterCallout}/FilterCallout.d.ts +1 -1
  146. package/dist/components/Grid/filtering/components/FilterCallout/FilterCallout.js +59 -0
  147. package/dist/components/Grid/filtering/components/FilterCallout/FilterCallout.js.map +1 -0
  148. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.d.ts +7 -0
  149. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.js +56 -0
  150. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.js.map +1 -0
  151. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.d.ts +7 -0
  152. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.js +73 -0
  153. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.js.map +1 -0
  154. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValueBetween.d.ts +7 -0
  155. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValueBetween.js +90 -0
  156. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValueBetween.js.map +1 -0
  157. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.d.ts +48 -0
  158. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.js +146 -0
  159. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.js.map +1 -0
  160. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/Component.d.ts +11 -0
  161. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/Component.js +53 -0
  162. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/Component.js.map +1 -0
  163. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/controller/useComponentController.d.ts +9 -0
  164. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/controller/useComponentController.js +31 -0
  165. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/controller/useComponentController.js.map +1 -0
  166. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/model/Component.d.ts +10 -0
  167. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/model/Component.js +294 -0
  168. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/model/Component.js.map +1 -0
  169. package/dist/components/Grid/filtering/components/FilterCallout/styles.d.ts +35 -0
  170. package/dist/components/Grid/{column-headers/column-header → filtering/components/FilterCallout}/styles.js +11 -20
  171. package/dist/components/Grid/filtering/components/FilterCallout/styles.js.map +1 -0
  172. package/dist/components/Grid/filtering/constants.d.ts +5 -0
  173. package/dist/components/Grid/filtering/constants.js +53 -0
  174. package/dist/components/Grid/filtering/constants.js.map +1 -0
  175. package/dist/components/Grid/filtering/controller/useColumnFilterConditionController.d.ts +21 -0
  176. package/dist/components/Grid/filtering/controller/useColumnFilterConditionController.js +44 -0
  177. package/dist/components/Grid/filtering/controller/useColumnFilterConditionController.js.map +1 -0
  178. package/dist/components/Grid/filtering/model/Condition.d.ts +49 -0
  179. package/dist/components/Grid/filtering/model/Condition.js +347 -0
  180. package/dist/components/Grid/filtering/model/Condition.js.map +1 -0
  181. package/dist/components/Grid/filtering/model/Filtering.d.ts +11 -0
  182. package/dist/components/Grid/filtering/model/Filtering.js +78 -0
  183. package/dist/components/Grid/filtering/model/Filtering.js.map +1 -0
  184. package/dist/components/Grid/filtering/utils/FilteringUtilts.d.ts +34 -0
  185. package/dist/components/Grid/filtering/utils/FilteringUtilts.js +195 -0
  186. package/dist/components/Grid/filtering/utils/FilteringUtilts.js.map +1 -0
  187. package/dist/components/Grid/index.d.ts +1 -1
  188. package/dist/components/Grid/index.js +1 -1
  189. package/dist/components/Grid/interfaces.d.ts +0 -9
  190. package/dist/components/Grid/selection/model/Selection.d.ts +12 -0
  191. package/dist/components/Grid/selection/model/Selection.js +55 -0
  192. package/dist/components/Grid/selection/model/Selection.js.map +1 -0
  193. package/dist/components/Grid/sorting/Sorting.d.ts +10 -0
  194. package/dist/components/Grid/sorting/Sorting.js +31 -0
  195. package/dist/components/Grid/sorting/Sorting.js.map +1 -0
  196. package/dist/components/Grid/{column-headers/column-header/ColumnHeaderContextualMenu.d.ts → sorting/components/SortingContextualMenu/SortingContextualMenu.d.ts} +3 -3
  197. package/dist/components/Grid/sorting/components/SortingContextualMenu/SortingContextualMenu.js +157 -0
  198. package/dist/components/Grid/sorting/components/SortingContextualMenu/SortingContextualMenu.js.map +1 -0
  199. package/dist/components/Grid/sorting/components/SortingContextualMenu/styles.d.ts +9 -0
  200. package/dist/components/Grid/sorting/components/SortingContextualMenu/styles.js +15 -0
  201. package/dist/components/Grid/sorting/components/SortingContextualMenu/styles.js.map +1 -0
  202. package/dist/components/Grid/sorting/controllers/useColumnSortingController.d.ts +9 -0
  203. package/dist/components/Grid/sorting/controllers/useColumnSortingController.js +22 -0
  204. package/dist/components/Grid/sorting/controllers/useColumnSortingController.js.map +1 -0
  205. package/dist/components/Grid/translations.d.ts +180 -20
  206. package/dist/components/Grid/translations.js +48 -5
  207. package/dist/components/Grid/translations.js.map +1 -1
  208. package/dist/components/GridCellRenderer/DefaultContentRenderer/DefaultContentRenderer.d.ts +2 -0
  209. package/dist/components/GridCellRenderer/DefaultContentRenderer/DefaultContentRenderer.js +11 -0
  210. package/dist/components/GridCellRenderer/DefaultContentRenderer/DefaultContentRenderer.js.map +1 -0
  211. package/dist/components/GridCellRenderer/DefaultContentRenderer/index.d.ts +1 -0
  212. package/dist/components/GridCellRenderer/DefaultContentRenderer/index.js +2 -0
  213. package/dist/components/GridCellRenderer/DefaultContentRenderer/index.js.map +1 -0
  214. package/dist/components/GridCellRenderer/GridCellRenderer.js +282 -99
  215. package/dist/components/GridCellRenderer/GridCellRenderer.js.map +1 -1
  216. package/dist/components/GridCellRenderer/OptionSet/OptionSet.d.ts +5 -0
  217. package/dist/components/GridCellRenderer/OptionSet/OptionSet.js +75 -0
  218. package/dist/components/GridCellRenderer/OptionSet/OptionSet.js.map +1 -0
  219. package/dist/components/GridCellRenderer/OptionSet/index.d.ts +1 -0
  220. package/dist/components/GridCellRenderer/OptionSet/index.js +2 -0
  221. package/dist/components/GridCellRenderer/OptionSet/index.js.map +1 -0
  222. package/dist/components/GridCellRenderer/OptionSet/styles.d.ts +20 -0
  223. package/dist/components/GridCellRenderer/OptionSet/styles.js +29 -0
  224. package/dist/components/GridCellRenderer/OptionSet/styles.js.map +1 -0
  225. package/dist/components/GridCellRenderer/RecordCommands/Icon.d.ts +7 -0
  226. package/dist/components/GridCellRenderer/RecordCommands/Icon.js +32 -0
  227. package/dist/components/GridCellRenderer/RecordCommands/Icon.js.map +1 -0
  228. package/dist/components/GridCellRenderer/RecordCommands/RecordCommands.d.ts +13 -0
  229. package/dist/components/GridCellRenderer/RecordCommands/RecordCommands.js +103 -0
  230. package/dist/components/GridCellRenderer/RecordCommands/RecordCommands.js.map +1 -0
  231. package/dist/components/GridCellRenderer/RecordCommands/styles.d.ts +13 -0
  232. package/dist/components/GridCellRenderer/RecordCommands/styles.js +32 -0
  233. package/dist/components/GridCellRenderer/RecordCommands/styles.js.map +1 -0
  234. package/dist/components/GridCellRenderer/interfaces.d.ts +42 -53
  235. package/dist/components/GridCellRenderer/styles.d.ts +60 -34
  236. package/dist/components/GridCellRenderer/styles.js +77 -69
  237. package/dist/components/GridCellRenderer/styles.js.map +1 -1
  238. package/dist/components/GridCellRenderer/translations.d.ts +1 -1
  239. package/dist/components/GridCellRenderer/translations.js +32 -30
  240. package/dist/components/GridCellRenderer/translations.js.map +1 -1
  241. package/dist/components/GridCellRenderer/useComponentProps.d.ts +6 -0
  242. package/dist/components/GridCellRenderer/useComponentProps.js +10 -0
  243. package/dist/components/GridCellRenderer/useComponentProps.js.map +1 -0
  244. package/dist/components/Lookup/Lookup.js +1 -1
  245. package/dist/components/Lookup/Lookup.js.map +1 -1
  246. package/dist/components/Lookup/hooks/useLookup.js +2 -2
  247. package/dist/components/Lookup/hooks/useLookup.js.map +1 -1
  248. package/dist/components/MultiSelectOptionSet/MultiSelectOptionSet.js +2 -2
  249. package/dist/components/MultiSelectOptionSet/MultiSelectOptionSet.js.map +1 -1
  250. package/dist/components/NestedControlRenderer/NestedControl.d.ts +0 -2
  251. package/dist/components/NestedControlRenderer/NestedControl.js +2 -5
  252. package/dist/components/NestedControlRenderer/NestedControl.js.map +1 -1
  253. package/dist/components/NestedControlRenderer/NestedControlRenderer.js +6 -11
  254. package/dist/components/NestedControlRenderer/NestedControlRenderer.js.map +1 -1
  255. package/dist/components/NestedControlRenderer/interfaces.d.ts +0 -4
  256. package/dist/components/NestedControlRenderer/properties/FileProperty.js +1 -1
  257. package/dist/components/NestedControlRenderer/properties/FileProperty.js.map +1 -1
  258. package/dist/components/OptionSet/OptionSet.js +4 -5
  259. package/dist/components/OptionSet/OptionSet.js.map +1 -1
  260. package/dist/components/TextField/TextField.js +1 -1
  261. package/dist/components/TextField/TextField.js.map +1 -1
  262. package/dist/components/index.js +3 -1
  263. package/dist/components/index.js.map +1 -1
  264. package/dist/hooks/useControl.d.ts +0 -1
  265. package/dist/hooks/useControl.js +0 -1
  266. package/dist/hooks/useControl.js.map +1 -1
  267. package/dist/hooks/useInputBasedControl.js +1 -2
  268. package/dist/hooks/useInputBasedControl.js.map +1 -1
  269. package/dist/index.d.ts +299 -162
  270. package/dist/index.js +3 -1
  271. package/dist/index.js.map +1 -1
  272. package/dist/interfaces/property.d.ts +1 -1
  273. package/dist/utils/BaseControls.d.ts +1 -2
  274. package/dist/utils/BaseControls.js +1 -5
  275. package/dist/utils/BaseControls.js.map +1 -1
  276. package/dist/utils/dataset/adapters/VirtualDatasetAdapter.d.ts +16 -12
  277. package/dist/utils/dataset/adapters/VirtualDatasetAdapter.js +72 -27
  278. package/dist/utils/dataset/adapters/VirtualDatasetAdapter.js.map +1 -1
  279. package/dist/utils/theme/components/ThemeWrapper.d.ts +1 -1
  280. package/dist/utils/theme/components/ThemeWrapper.js.map +1 -1
  281. package/dist/utils/theme/hooks/useControlTheme.js +1 -2
  282. package/dist/utils/theme/hooks/useControlTheme.js.map +1 -1
  283. package/package.json +5 -9
  284. package/dist/components/DatasetControl/DatasetControlModel.d.ts +0 -37
  285. package/dist/components/DatasetControl/DatasetControlModel.js +0 -110
  286. package/dist/components/DatasetControl/DatasetControlModel.js.map +0 -1
  287. package/dist/components/DatasetControl/Filtering/DatasetColumnFiltering.d.ts +0 -3
  288. package/dist/components/DatasetControl/Filtering/DatasetColumnFiltering.js +0 -166
  289. package/dist/components/DatasetControl/Filtering/DatasetColumnFiltering.js.map +0 -1
  290. package/dist/components/DatasetControl/Filtering/DatasetColumnFilteringModel.d.ts +0 -15
  291. package/dist/components/DatasetControl/Filtering/DatasetColumnFilteringModel.js +0 -59
  292. package/dist/components/DatasetControl/Filtering/DatasetColumnFilteringModel.js.map +0 -1
  293. package/dist/components/DatasetControl/Filtering/interfaces.d.ts +0 -31
  294. package/dist/components/DatasetControl/Filtering/styles.d.ts +0 -16
  295. package/dist/components/DatasetControl/Filtering/styles.js +0 -23
  296. package/dist/components/DatasetControl/Filtering/styles.js.map +0 -1
  297. package/dist/components/DatasetControl/Filtering/translations.d.ts +0 -154
  298. package/dist/components/DatasetControl/Filtering/translations.js +0 -43
  299. package/dist/components/DatasetControl/Filtering/translations.js.map +0 -1
  300. package/dist/components/DatasetControl/Header/Header.d.ts +0 -5
  301. package/dist/components/DatasetControl/Header/Header.js +0 -89
  302. package/dist/components/DatasetControl/Header/Header.js.map +0 -1
  303. package/dist/components/DatasetControl/Header/styles.d.ts +0 -22
  304. package/dist/components/DatasetControl/Header/styles.js +0 -29
  305. package/dist/components/DatasetControl/Header/styles.js.map +0 -1
  306. package/dist/components/DatasetControl/Pagination/Pagination.d.ts +0 -5
  307. package/dist/components/DatasetControl/Pagination/Pagination.js +0 -91
  308. package/dist/components/DatasetControl/Pagination/Pagination.js.map +0 -1
  309. package/dist/components/DatasetControl/Pagination/PaginationModel.d.ts +0 -10
  310. package/dist/components/DatasetControl/Pagination/PaginationModel.js +0 -45
  311. package/dist/components/DatasetControl/Pagination/PaginationModel.js.map +0 -1
  312. package/dist/components/DatasetControl/Pagination/styles.d.ts +0 -23
  313. package/dist/components/DatasetControl/Pagination/styles.js +0 -29
  314. package/dist/components/DatasetControl/Pagination/styles.js.map +0 -1
  315. package/dist/components/DatasetControl/useModel.d.ts +0 -4
  316. package/dist/components/DatasetControl/useModel.js +0 -9
  317. package/dist/components/DatasetControl/useModel.js.map +0 -1
  318. package/dist/components/Grid/cells/cell/Cell.js +0 -302
  319. package/dist/components/Grid/cells/cell/Cell.js.map +0 -1
  320. package/dist/components/Grid/cells/cell/content/CellContent.js.map +0 -1
  321. package/dist/components/Grid/cells/cell/content/styles.js.map +0 -1
  322. package/dist/components/Grid/cells/cell/notifications/Notifications.js.map +0 -1
  323. package/dist/components/Grid/cells/cell/notifications/styles.js.map +0 -1
  324. package/dist/components/Grid/cells/cell/styles.js +0 -78
  325. package/dist/components/Grid/cells/cell/styles.js.map +0 -1
  326. package/dist/components/Grid/column-headers/column-header/ColumnHeader.js +0 -83
  327. package/dist/components/Grid/column-headers/column-header/ColumnHeader.js.map +0 -1
  328. package/dist/components/Grid/column-headers/column-header/ColumnHeaderContextualMenu.js +0 -115
  329. package/dist/components/Grid/column-headers/column-header/ColumnHeaderContextualMenu.js.map +0 -1
  330. package/dist/components/Grid/column-headers/column-header/FilterCallout.js +0 -103
  331. package/dist/components/Grid/column-headers/column-header/FilterCallout.js.map +0 -1
  332. package/dist/components/Grid/column-headers/column-header/styles.d.ts +0 -84
  333. package/dist/components/Grid/column-headers/column-header/styles.js.map +0 -1
  334. package/dist/components/Grid/column-headers/record-selection-checkbox/RecordSelectionCheckbox.d.ts +0 -2
  335. package/dist/components/Grid/column-headers/record-selection-checkbox/RecordSelectionCheckbox.js +0 -50
  336. package/dist/components/Grid/column-headers/record-selection-checkbox/RecordSelectionCheckbox.js.map +0 -1
  337. package/dist/components/Grid/column-headers/record-selection-checkbox/styles.js.map +0 -1
  338. package/dist/components/Grid/errors/FullWidthCellRendererError/FullWidthCellRendererError.d.ts +0 -6
  339. package/dist/components/Grid/errors/FullWidthCellRendererError/FullWidthCellRendererError.js +0 -15
  340. package/dist/components/Grid/errors/FullWidthCellRendererError/FullWidthCellRendererError.js.map +0 -1
  341. package/dist/components/Grid/errors/FullWidthCellRendererError/styles.d.ts +0 -6
  342. package/dist/components/Grid/errors/FullWidthCellRendererError/styles.js +0 -13
  343. package/dist/components/Grid/errors/FullWidthCellRendererError/styles.js.map +0 -1
  344. package/dist/components/Grid/grid/Grid.js +0 -64
  345. package/dist/components/Grid/grid/Grid.js.map +0 -1
  346. package/dist/components/Grid/grid/GridContext.d.ts +0 -3
  347. package/dist/components/Grid/grid/GridContext.js.map +0 -1
  348. package/dist/components/Grid/grid/GridModel.d.ts +0 -117
  349. package/dist/components/Grid/grid/GridModel.js +0 -787
  350. package/dist/components/Grid/grid/GridModel.js.map +0 -1
  351. package/dist/components/Grid/grid/ValueComparator.js.map +0 -1
  352. package/dist/components/Grid/grid/ag-grid/AgGridContext.js.map +0 -1
  353. package/dist/components/Grid/grid/ag-grid/AgGridModel.d.ts +0 -88
  354. package/dist/components/Grid/grid/ag-grid/AgGridModel.js +0 -565
  355. package/dist/components/Grid/grid/ag-grid/AgGridModel.js.map +0 -1
  356. package/dist/components/Grid/grid/ag-grid/ServerSideDatasource.d.ts +0 -7
  357. package/dist/components/Grid/grid/ag-grid/ServerSideDatasource.js +0 -38
  358. package/dist/components/Grid/grid/ag-grid/ServerSideDatasource.js.map +0 -1
  359. package/dist/components/Grid/grid/ag-grid/useAgGridInstance.d.ts +0 -2
  360. package/dist/components/Grid/grid/ag-grid/useAgGridInstance.js +0 -9
  361. package/dist/components/Grid/grid/ag-grid/useAgGridInstance.js.map +0 -1
  362. package/dist/components/Grid/grid/styles.js.map +0 -1
  363. package/dist/components/Grid/grid/useGridInstance.d.ts +0 -2
  364. package/dist/components/Grid/grid/useGridInstance.js.map +0 -1
  365. package/dist/components/Grid/loading/full-row/FullRowLoading.d.ts +0 -3
  366. package/dist/components/Grid/loading/full-row/FullRowLoading.js +0 -33
  367. package/dist/components/Grid/loading/full-row/FullRowLoading.js.map +0 -1
  368. package/dist/components/Grid/loading/full-row/styles.d.ts +0 -9
  369. package/dist/components/Grid/loading/full-row/styles.js +0 -16
  370. package/dist/components/Grid/loading/full-row/styles.js.map +0 -1
  371. package/dist/components/Grid/overlays/empty-records/EmptyRecordsOverlay.js +0 -13
  372. package/dist/components/Grid/overlays/empty-records/EmptyRecordsOverlay.js.map +0 -1
  373. package/dist/components/Grid/overlays/empty-records/styles.js.map +0 -1
  374. package/dist/components/Grid/overlays/loading/LoadingOverlay.js.map +0 -1
  375. package/dist/components/GridCellRenderer/GridCellRendererModel.d.ts +0 -51
  376. package/dist/components/GridCellRenderer/GridCellRendererModel.js +0 -211
  377. package/dist/components/GridCellRenderer/GridCellRendererModel.js.map +0 -1
  378. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/ColorfulOptionSetValueRenderer.d.ts +0 -9
  379. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/ColorfulOptionSetValueRenderer.js +0 -53
  380. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/ColorfulOptionSetValueRenderer.js.map +0 -1
  381. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/styles.d.ts +0 -20
  382. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/styles.js +0 -29
  383. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/styles.js.map +0 -1
  384. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/FileRenderer.d.ts +0 -7
  385. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/FileRenderer.js +0 -76
  386. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/FileRenderer.js.map +0 -1
  387. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/styles.d.ts +0 -18
  388. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/styles.js +0 -25
  389. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/styles.js.map +0 -1
  390. package/dist/components/GridCellRenderer/ValueRenderer/ValueRenderer.d.ts +0 -3
  391. package/dist/components/GridCellRenderer/ValueRenderer/ValueRenderer.js +0 -52
  392. package/dist/components/GridCellRenderer/ValueRenderer/ValueRenderer.js.map +0 -1
  393. package/dist/components/GridCellRenderer/ValueRenderer/styles.d.ts +0 -1666
  394. package/dist/components/GridCellRenderer/ValueRenderer/styles.js +0 -31
  395. package/dist/components/GridCellRenderer/ValueRenderer/styles.js.map +0 -1
  396. package/dist/components/GridCellRenderer/properties/Email.d.ts +0 -5
  397. package/dist/components/GridCellRenderer/properties/Email.js +0 -15
  398. package/dist/components/GridCellRenderer/properties/Email.js.map +0 -1
  399. package/dist/components/GridCellRenderer/properties/File.d.ts +0 -19
  400. package/dist/components/GridCellRenderer/properties/File.js +0 -99
  401. package/dist/components/GridCellRenderer/properties/File.js.map +0 -1
  402. package/dist/components/GridCellRenderer/properties/Image.d.ts +0 -4
  403. package/dist/components/GridCellRenderer/properties/Image.js +0 -15
  404. package/dist/components/GridCellRenderer/properties/Image.js.map +0 -1
  405. package/dist/components/GridCellRenderer/properties/Lookup.d.ts +0 -6
  406. package/dist/components/GridCellRenderer/properties/Lookup.js +0 -19
  407. package/dist/components/GridCellRenderer/properties/Lookup.js.map +0 -1
  408. package/dist/components/GridCellRenderer/properties/MultiSelectOptionSet.d.ts +0 -5
  409. package/dist/components/GridCellRenderer/properties/MultiSelectOptionSet.js +0 -11
  410. package/dist/components/GridCellRenderer/properties/MultiSelectOptionSet.js.map +0 -1
  411. package/dist/components/GridCellRenderer/properties/MultilineText.d.ts +0 -4
  412. package/dist/components/GridCellRenderer/properties/MultilineText.js +0 -10
  413. package/dist/components/GridCellRenderer/properties/MultilineText.js.map +0 -1
  414. package/dist/components/GridCellRenderer/properties/OptionSet.d.ts +0 -5
  415. package/dist/components/GridCellRenderer/properties/OptionSet.js +0 -11
  416. package/dist/components/GridCellRenderer/properties/OptionSet.js.map +0 -1
  417. package/dist/components/GridCellRenderer/properties/OptionSetBase.d.ts +0 -7
  418. package/dist/components/GridCellRenderer/properties/OptionSetBase.js +0 -19
  419. package/dist/components/GridCellRenderer/properties/OptionSetBase.js.map +0 -1
  420. package/dist/components/GridCellRenderer/properties/Phone.d.ts +0 -9
  421. package/dist/components/GridCellRenderer/properties/Phone.js +0 -15
  422. package/dist/components/GridCellRenderer/properties/Phone.js.map +0 -1
  423. package/dist/components/GridCellRenderer/properties/Property.d.ts +0 -19
  424. package/dist/components/GridCellRenderer/properties/Property.js +0 -54
  425. package/dist/components/GridCellRenderer/properties/Property.js.map +0 -1
  426. package/dist/components/GridCellRenderer/properties/TwoOptions.d.ts +0 -5
  427. package/dist/components/GridCellRenderer/properties/TwoOptions.js +0 -11
  428. package/dist/components/GridCellRenderer/properties/TwoOptions.js.map +0 -1
  429. package/dist/components/GridCellRenderer/properties/Url.d.ts +0 -5
  430. package/dist/components/GridCellRenderer/properties/Url.js +0 -15
  431. package/dist/components/GridCellRenderer/properties/Url.js.map +0 -1
  432. package/dist/components/GridCellRenderer/useModel.d.ts +0 -4
  433. package/dist/components/GridCellRenderer/useModel.js +0 -9
  434. package/dist/components/GridCellRenderer/useModel.js.map +0 -1
  435. package/dist/components/GridColumnHeader/GridColumnHeader.d.ts +0 -3
  436. package/dist/components/GridColumnHeader/GridColumnHeader.js +0 -134
  437. package/dist/components/GridColumnHeader/GridColumnHeader.js.map +0 -1
  438. package/dist/components/GridColumnHeader/GridColumnHeaderModel.d.ts +0 -26
  439. package/dist/components/GridColumnHeader/GridColumnHeaderModel.js +0 -87
  440. package/dist/components/GridColumnHeader/GridColumnHeaderModel.js.map +0 -1
  441. package/dist/components/GridColumnHeader/interfaces.d.ts +0 -45
  442. package/dist/components/GridColumnHeader/styles.d.ts +0 -37
  443. package/dist/components/GridColumnHeader/styles.js +0 -55
  444. package/dist/components/GridColumnHeader/styles.js.map +0 -1
  445. package/dist/components/GridColumnHeader/translations.d.ts +0 -26
  446. package/dist/components/GridColumnHeader/translations.js +0 -29
  447. package/dist/components/GridColumnHeader/translations.js.map +0 -1
  448. package/dist/components/Ribbon/Ribbon.d.ts +0 -3
  449. package/dist/components/Ribbon/Ribbon.js +0 -97
  450. package/dist/components/Ribbon/Ribbon.js.map +0 -1
  451. package/dist/components/Ribbon/RibbonModel.d.ts +0 -4
  452. package/dist/components/Ribbon/interfaces.d.ts +0 -19
  453. package/dist/components/Ribbon/styles.d.ts +0 -11
  454. package/dist/components/Ribbon/styles.js +0 -18
  455. package/dist/components/Ribbon/styles.js.map +0 -1
  456. package/dist/hooks/useEventEmitter.d.ts +0 -2
  457. package/dist/hooks/useEventEmitter.js +0 -18
  458. package/dist/hooks/useEventEmitter.js.map +0 -1
  459. /package/dist/components/Grid/{grid/GridContext.js → GridContext.js} +0 -0
  460. /package/dist/components/Grid/{overlays/empty-records/EmptyRecordsOverlay.d.ts → core/components/AgGrid/components/EmptyRecordsOverlay/EmptyRecords.d.ts} +0 -0
  461. /package/dist/components/Grid/{overlays/loading → core/components/AgGrid/components/LoadingOverlay}/LoadingOverlay.d.ts +0 -0
  462. /package/dist/components/Grid/{overlays/loading → core/components/AgGrid/components/LoadingOverlay}/LoadingOverlay.js +0 -0
  463. /package/dist/components/Grid/{cells/cell/content → core/components/Cell/CellContent}/styles.d.ts +0 -0
  464. /package/dist/components/Grid/{cells/cell/content → core/components/Cell/CellContent}/styles.js +0 -0
  465. /package/dist/components/Grid/{cells/cell/notifications → core/components/Cell/Notifications}/styles.d.ts +0 -0
  466. /package/dist/components/Grid/{column-headers/record-selection-checkbox → core/components/ColumnHeader/components/GlobalCheckbox}/styles.d.ts +0 -0
  467. /package/dist/components/Grid/{column-headers/record-selection-checkbox → core/components/ColumnHeader/components/GlobalCheckbox}/styles.js +0 -0
@@ -0,0 +1,31 @@
1
+ class KeyHoldListener {
2
+ constructor() {
3
+ this._currentlyHeldKey = null;
4
+ this._keyDownHandlers = new Set();
5
+ this._onKeyDownRef = (e) => this._onKeyDown(e);
6
+ this._onKeyUpRef = (e) => this._onKeyUp(e);
7
+ window.addEventListener('keydown', this._onKeyDownRef);
8
+ window.addEventListener('keyup', this._onKeyUpRef);
9
+ }
10
+ getHeldKey() {
11
+ return this._currentlyHeldKey;
12
+ }
13
+ addOnKeyDownHandler(handler) {
14
+ this._keyDownHandlers.add(handler);
15
+ }
16
+ _onKeyDown(e) {
17
+ this._currentlyHeldKey = e.key;
18
+ [...this._keyDownHandlers.values()].map(handler => handler(e));
19
+ }
20
+ _onKeyUp(e) {
21
+ this._currentlyHeldKey = null;
22
+ }
23
+ destroy() {
24
+ this._keyDownHandlers.clear();
25
+ window.removeEventListener('keydown', this._onKeyDownRef);
26
+ window.removeEventListener('keyup', this._onKeyUpRef);
27
+ }
28
+ }
29
+
30
+ export { KeyHoldListener };
31
+ //# sourceMappingURL=KeyListener.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"KeyListener.js","sources":["../../../../../src/components/Grid/core/services/KeyListener.ts"],"sourcesContent":["export class KeyHoldListener {\n private _currentlyHeldKey: string | null = null;\n private _keyDownHandlers: Set<(e: KeyboardEvent) => void> = new Set();\n private _onKeyDownRef: (e: KeyboardEvent) => void;\n private _onKeyUpRef: (e: KeyboardEvent) => void;\n\n constructor() {\n this._onKeyDownRef = (e) => this._onKeyDown(e);\n this._onKeyUpRef = (e) => this._onKeyUp(e);\n window.addEventListener('keydown', this._onKeyDownRef);\n window.addEventListener('keyup', this._onKeyUpRef);\n }\n public getHeldKey(): string | null {\n return this._currentlyHeldKey;\n }\n public addOnKeyDownHandler(handler: (e: KeyboardEvent) => void) {\n this._keyDownHandlers.add(handler);\n }\n private _onKeyDown(e: KeyboardEvent) {\n this._currentlyHeldKey = e.key;\n [...this._keyDownHandlers.values()].map(handler => handler(e));\n }\n private _onKeyUp(e: KeyboardEvent) {\n this._currentlyHeldKey = null;\n }\n destroy() {\n this._keyDownHandlers.clear();\n window.removeEventListener('keydown', this._onKeyDownRef);\n window.removeEventListener('keyup', this._onKeyUpRef);\n }\n}"],"names":[],"mappings":"MAAa,eAAe,CAAA;AAMxB,IAAA,WAAA,GAAA;QALQ,IAAiB,CAAA,iBAAA,GAAkB,IAAI,CAAC;AACxC,QAAA,IAAA,CAAA,gBAAgB,GAAoC,IAAI,GAAG,EAAE,CAAC;AAKlE,QAAA,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;AAC/C,QAAA,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAC3C,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACvD,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;KACtD;IACM,UAAU,GAAA;QACb,OAAO,IAAI,CAAC,iBAAiB,CAAC;KACjC;AACM,IAAA,mBAAmB,CAAC,OAAmC,EAAA;AAC1D,QAAA,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;KACtC;AACO,IAAA,UAAU,CAAC,CAAgB,EAAA;AAC/B,QAAA,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC,GAAG,CAAC;QAC/B,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;KAClE;AACO,IAAA,QAAQ,CAAC,CAAgB,EAAA;AAC7B,QAAA,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;KACjC;IACD,OAAO,GAAA;AACH,QAAA,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAC1D,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;KACzD;AACJ;;;;"}
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
2
  import { ICalloutProps } from '@fluentui/react';
3
- import { IGridColumn } from '../../grid/GridModel';
3
+ import { IGridColumn } from '../../../core/interfaces/IGridColumn';
4
4
  export interface IFilterCallout extends ICalloutProps {
5
5
  column: IGridColumn;
6
6
  onDismiss: () => void;
@@ -0,0 +1,59 @@
1
+ import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
2
+ import * as React from 'react';
3
+ import { Callout, Text, IconButton, PrimaryButton, Button } from '@fluentui/react';
4
+ import { filterCalloutStyles } from './styles.js';
5
+ import { useColumnFilterConditionController } from '../../controller/useColumnFilterConditionController.js';
6
+ import { FilteringUtils } from '../../utils/FilteringUtilts.js';
7
+ import { ConditionOperator } from './components/ConditionOperator/ConditionOperator.js';
8
+ import { ConditionValue } from './components/ConditionValue/ConditionValue.js';
9
+ import { useGridInstance } from '../../../core/hooks/useGridInstance.js';
10
+ import { ConditionValueBetween } from './components/ConditionValue/ConditionValueBetween.js';
11
+
12
+ const FilterCallout = (props) => {
13
+ const { column, onDismiss } = { ...props };
14
+ const condition = useColumnFilterConditionController(column);
15
+ const grid = useGridInstance();
16
+ const conditionRef = React.useRef();
17
+ conditionRef.current = condition;
18
+ const conditionOperator = condition?.operator.get();
19
+ const conditionValue = condition?.value.get();
20
+ const conditionUtils = FilteringUtils.condition();
21
+ const isDeleteButtonDisabled = () => {
22
+ switch (conditionValue) {
23
+ case null:
24
+ case undefined:
25
+ case "": {
26
+ return true;
27
+ }
28
+ }
29
+ return false;
30
+ };
31
+ const isBetweenCondition = () => {
32
+ if (conditionOperator === 10 || conditionOperator === 11) {
33
+ return true;
34
+ }
35
+ return false;
36
+ };
37
+ React.useEffect(() => {
38
+ return () => {
39
+ conditionRef.current?.clear();
40
+ };
41
+ }, []);
42
+ return (jsxs(Callout, { ...props, calloutWidth: 230, className: filterCalloutStyles.root, children: [jsxs("div", { className: filterCalloutStyles.header, children: [jsx(Text, { className: filterCalloutStyles.title, variant: "mediumPlus", children: grid.labels['filtermenu-filterby']() }), jsx(IconButton, { onClick: () => onDismiss(), iconProps: {
43
+ iconName: 'ChromeClose',
44
+ } })] }), condition &&
45
+ jsxs(Fragment, { children: [jsxs("div", { className: filterCalloutStyles.controls, children: [jsx(ConditionOperator, { column: column }), conditionUtils.value(conditionOperator).isEditable && !isBetweenCondition() &&
46
+ jsx(ConditionValue, { column: column }), isBetweenCondition() &&
47
+ jsx(ConditionValueBetween, { column: column })] }), jsxs("div", { className: filterCalloutStyles.footer, children: [jsx(PrimaryButton, { text: grid.labels['filtermenu-applybutton'](), onClick: async () => {
48
+ if (await condition.save()) {
49
+ props.onDismiss();
50
+ }
51
+ } }), conditionUtils.value(conditionOperator).isEditable &&
52
+ jsx(Button, { text: grid.labels['filtermenu-clearbutton'](), disabled: isDeleteButtonDisabled(), onClick: () => {
53
+ condition.setShouldShowError(false);
54
+ condition.value.set(null);
55
+ } })] })] })] }));
56
+ };
57
+
58
+ export { FilterCallout };
59
+ //# sourceMappingURL=FilterCallout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FilterCallout.js","sources":["../../../../../../src/components/Grid/filtering/components/FilterCallout/FilterCallout.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Callout, IconButton, PrimaryButton, Button, ICalloutProps } from '@fluentui/react';\nimport { Text } from '@fluentui/react';\nimport { filterCalloutStyles } from './styles';\nimport { IColumnFilterConditionController, useColumnFilterConditionController } from '../../controller/useColumnFilterConditionController';\nimport { IGridColumn } from '../../../core/interfaces/IGridColumn';\nimport { FilteringUtils } from '../../utils/FilteringUtilts';\nimport { ConditionOperator } from './components/ConditionOperator/ConditionOperator';\nimport { ConditionValue } from './components/ConditionValue/ConditionValue';\nimport { useGridInstance } from '../../../core/hooks/useGridInstance';\nimport { ConditionValueBetween } from './components/ConditionValue/ConditionValueBetween';\n\nexport interface IFilterCallout extends ICalloutProps {\n column: IGridColumn;\n onDismiss: () => void;\n}\n\nexport const FilterCallout = (props: IFilterCallout) => {\n const { column, onDismiss } = { ...props };\n const condition = useColumnFilterConditionController(column);\n const grid = useGridInstance();\n const conditionRef = React.useRef<IColumnFilterConditionController | null>();\n conditionRef.current = condition;\n const conditionOperator = condition?.operator.get();\n const conditionValue = condition?.value.get();\n const conditionUtils = FilteringUtils.condition();\n\n const isDeleteButtonDisabled = () => {\n switch (conditionValue) {\n case null:\n case undefined:\n case \"\": {\n return true;\n }\n }\n return false;\n }\n\n const isBetweenCondition = () => {\n if (conditionOperator === 10 || conditionOperator === 11) {\n return true;\n }\n return false;\n }\n\n React.useEffect(() => {\n return () => {\n conditionRef.current?.clear();\n }\n }, []);\n\n\n return (\n <Callout\n {...props}\n calloutWidth={230}\n className={filterCalloutStyles.root}>\n <div className={filterCalloutStyles.header}>\n <Text className={filterCalloutStyles.title} variant=\"mediumPlus\">{grid.labels['filtermenu-filterby']()}</Text>\n <IconButton onClick={() => onDismiss()} iconProps={{\n iconName: 'ChromeClose',\n }} />\n </div>\n {condition &&\n <>\n <div className={filterCalloutStyles.controls}>\n <ConditionOperator column={column} />\n {conditionUtils.value(conditionOperator!).isEditable && !isBetweenCondition() &&\n <ConditionValue\n column={column} />\n }\n {isBetweenCondition() &&\n <ConditionValueBetween\n column={column} />\n }\n </div>\n <div className={filterCalloutStyles.footer}>\n <PrimaryButton text={grid.labels['filtermenu-applybutton']()}\n onClick={async () => {\n if (await condition.save()) {\n props.onDismiss();\n }\n }} />\n {conditionUtils.value(conditionOperator!).isEditable &&\n <Button text={grid.labels['filtermenu-clearbutton']()}\n disabled={isDeleteButtonDisabled()}\n onClick={() => {\n condition.setShouldShowError(false);\n condition.value.set(null);\n }} />\n }\n </div>\n </>\n }\n </Callout>\n );\n};"],"names":["_jsxs","_jsx","_Fragment"],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import { IGridColumn } from '../../../../../core/interfaces/IGridColumn';
3
+ interface IConditionOperator {
4
+ column: IGridColumn;
5
+ }
6
+ export declare const ConditionOperator: (props: IConditionOperator) => JSX.Element;
7
+ export {};
@@ -0,0 +1,56 @@
1
+ import { jsx, Fragment } from 'react/jsx-runtime';
2
+ import { ComboBox } from '@talxis/react-components';
3
+ import { DataType } from '../../../../../core/enums/DataType.js';
4
+ import { FilteringUtils } from '../../../../utils/FilteringUtilts.js';
5
+ import { useGridInstance } from '../../../../../core/hooks/useGridInstance.js';
6
+ import { useColumnFilterConditionController } from '../../../../controller/useColumnFilterConditionController.js';
7
+
8
+ const ConditionOperator = (props) => {
9
+ const { column } = { ...props };
10
+ const operatorUtils = FilteringUtils.condition().operator();
11
+ const grid = useGridInstance();
12
+ const condition = useColumnFilterConditionController(column);
13
+ //TODO: add missing text operator (begins with, ends with)
14
+ const getOptions = () => {
15
+ let operators = operatorUtils.textFieldOperators;
16
+ switch (column.dataType) {
17
+ case DataType.WHOLE_NONE:
18
+ case DataType.DECIMAL:
19
+ case DataType.FP:
20
+ case DataType.WHOLE_DURATION:
21
+ case DataType.CURRENCY:
22
+ operators = operatorUtils.numberOperators;
23
+ break;
24
+ case DataType.DATE_AND_TIME_DATE_AND_TIME:
25
+ case DataType.DATE_AND_TIME_DATE_ONLY:
26
+ operators = operatorUtils.dateOperators;
27
+ break;
28
+ case DataType.MULTI_SELECT_OPTIONSET:
29
+ operators = operatorUtils.multipleOptionSetOperators;
30
+ break;
31
+ case DataType.FILE:
32
+ case DataType.IMAGE: {
33
+ operators = operatorUtils.fileOperators;
34
+ }
35
+ }
36
+ return operators.map(operator => {
37
+ return {
38
+ key: operator.type,
39
+ text: grid.labels[operator.key]()
40
+ };
41
+ });
42
+ };
43
+ if (!condition) {
44
+ return jsx(Fragment, {});
45
+ }
46
+ return jsx(ComboBox, { ...props, selectedKey: condition.operator.get(), shouldRestoreFocus: false, options: getOptions(), useComboBoxAsMenuWidth: true, styles: {
47
+ callout: {
48
+ maxHeight: '300px !important'
49
+ }
50
+ }, onChange: (e, option) => {
51
+ condition.operator.set(option.key);
52
+ } });
53
+ };
54
+
55
+ export { ConditionOperator };
56
+ //# sourceMappingURL=ConditionOperator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConditionOperator.js","sources":["../../../../../../../../src/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.tsx"],"sourcesContent":["import { ComboBox } from \"@talxis/react-components\";\nimport { DataType } from '../../../../../core/enums/DataType';\nimport { IComboBoxOption, useTheme } from '@fluentui/react';\nimport { FilteringUtils } from '../../../../utils/FilteringUtilts';\nimport { useGridInstance } from '../../../../../core/hooks/useGridInstance';\nimport { useColumnFilterConditionController } from '../../../../controller/useColumnFilterConditionController';\nimport { IGridColumn } from '../../../../../core/interfaces/IGridColumn';\nimport { DatasetConditionOperator } from '../../../../../core/enums/ConditionOperator';\nimport React from 'react';\n\ninterface IConditionOperator {\n column: IGridColumn;\n}\nexport const ConditionOperator = (props: IConditionOperator) => {\n const { column } = { ...props };\n const operatorUtils = FilteringUtils.condition().operator();\n const grid = useGridInstance();\n const condition = useColumnFilterConditionController(column);\n\n //TODO: add missing text operator (begins with, ends with)\n const getOptions = (): IComboBoxOption[] => {\n let operators = operatorUtils.textFieldOperators;\n switch (column.dataType) {\n case DataType.WHOLE_NONE:\n case DataType.DECIMAL:\n case DataType.FP:\n case DataType.WHOLE_DURATION:\n case DataType.CURRENCY:\n operators = operatorUtils.numberOperators;\n break;\n case DataType.DATE_AND_TIME_DATE_AND_TIME:\n case DataType.DATE_AND_TIME_DATE_ONLY:\n operators = operatorUtils.dateOperators;\n break;\n case DataType.MULTI_SELECT_OPTIONSET:\n operators = operatorUtils.multipleOptionSetOperators;\n break;\n case DataType.FILE:\n case DataType.IMAGE: {\n operators = operatorUtils.fileOperators;\n }\n }\n return operators.map(operator => {\n return {\n key: operator.type,\n text: grid.labels[operator.key]()\n };\n });\n };\n if(!condition) {\n return <></>\n }\n return <ComboBox\n {...props}\n selectedKey={condition.operator.get()}\n shouldRestoreFocus={false}\n options={getOptions()}\n useComboBoxAsMenuWidth\n styles={{\n callout: {\n maxHeight: '300px !important'\n }\n }}\n onChange={(e, option) => {\n condition.operator.set(option!.key as DatasetConditionOperator)\n }} />;\n}"],"names":["_jsx"],"mappings":";;;;;;;AAaa,MAAA,iBAAiB,GAAG,CAAC,KAAyB,KAAI;IAC3D,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC;IAChC,MAAM,aAAa,GAAG,cAAc,CAAC,SAAS,EAAE,CAAC,QAAQ,EAAE,CAAC;AAC5D,IAAA,MAAM,IAAI,GAAG,eAAe,EAAE,CAAC;AAC/B,IAAA,MAAM,SAAS,GAAG,kCAAkC,CAAC,MAAM,CAAC,CAAC;;IAG7D,MAAM,UAAU,GAAG,MAAwB;AACvC,QAAA,IAAI,SAAS,GAAG,aAAa,CAAC,kBAAkB,CAAC;QACjD,QAAQ,MAAM,CAAC,QAAQ;YACnB,KAAK,QAAQ,CAAC,UAAU,CAAC;YACzB,KAAK,QAAQ,CAAC,OAAO,CAAC;YACtB,KAAK,QAAQ,CAAC,EAAE,CAAC;YACjB,KAAK,QAAQ,CAAC,cAAc,CAAC;YAC7B,KAAK,QAAQ,CAAC,QAAQ;AAClB,gBAAA,SAAS,GAAG,aAAa,CAAC,eAAe,CAAC;gBAC1C,MAAM;YACV,KAAK,QAAQ,CAAC,2BAA2B,CAAC;YAC1C,KAAK,QAAQ,CAAC,uBAAuB;AACjC,gBAAA,SAAS,GAAG,aAAa,CAAC,aAAa,CAAC;gBACxC,MAAM;YACV,KAAK,QAAQ,CAAC,sBAAsB;AAChC,gBAAA,SAAS,GAAG,aAAa,CAAC,0BAA0B,CAAC;gBACrD,MAAM;YACV,KAAK,QAAQ,CAAC,IAAI,CAAC;AACnB,YAAA,KAAK,QAAQ,CAAC,KAAK,EAAE;AACjB,gBAAA,SAAS,GAAG,aAAa,CAAC,aAAa,CAAC;AAC3C,aAAA;AACJ,SAAA;AACD,QAAA,OAAO,SAAS,CAAC,GAAG,CAAC,QAAQ,IAAG;YAC5B,OAAO;gBACH,GAAG,EAAE,QAAQ,CAAC,IAAI;gBAClB,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;aACpC,CAAC;AACN,SAAC,CAAC,CAAC;AACP,KAAC,CAAC;IACF,IAAG,CAAC,SAAS,EAAE;AACX,QAAA,OAAOA,iBAAK,CAAA;AACf,KAAA;IACD,OAAOA,GAAA,CAAC,QAAQ,EAAA,EAAA,GACR,KAAK,EACT,WAAW,EAAE,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAE,EACrC,kBAAkB,EAAE,KAAK,EACzB,OAAO,EAAE,UAAU,EAAE,EACrB,sBAAsB,EACtB,IAAA,EAAA,MAAM,EAAE;AACJ,YAAA,OAAO,EAAE;AACL,gBAAA,SAAS,EAAE,kBAAkB;AAChC,aAAA;AACJ,SAAA,EACD,QAAQ,EAAE,CAAC,CAAC,EAAE,MAAM,KAAI;YACpB,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAO,CAAC,GAA+B,CAAC,CAAA;AACnE,SAAC,GAAI,CAAC;AACd;;;;"}
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import { IGridColumn } from "../../../../../core/interfaces/IGridColumn";
3
+ interface IConditionValue {
4
+ column: IGridColumn;
5
+ }
6
+ export declare const ConditionValue: (props: IConditionValue) => JSX.Element;
7
+ export {};
@@ -0,0 +1,73 @@
1
+ import { jsx, Fragment } from 'react/jsx-runtime';
2
+ import { useRef, useMemo, useEffect } from 'react';
3
+ import { useColumnFilterConditionController } from '../../../../controller/useColumnFilterConditionController.js';
4
+ import { ConditionComponentValue } from './model/ConditionComponentValue.js';
5
+ import { MemoryDataProvider, DataTypes } from '@talxis/client-libraries';
6
+ import { Component } from '../LegacyControlRendering/Component.js';
7
+ import { useRerender } from '@talxis/react-components';
8
+
9
+ const ConditionValue = (props) => {
10
+ const condition = useColumnFilterConditionController(props.column);
11
+ if (!condition) {
12
+ return jsx(Fragment, {});
13
+ }
14
+ return jsx(InternalConditionValue, { ...condition });
15
+ };
16
+ const InternalConditionValue = (controller) => {
17
+ const componentContainerRef = useRef(null);
18
+ const controllerRef = useRef(controller);
19
+ const firstRenderRef = useRef(true);
20
+ controllerRef.current = controller;
21
+ const conditionComponentValue = useMemo(() => new ConditionComponentValue(controllerRef), []);
22
+ const column = conditionComponentValue.column;
23
+ const rerender = useRerender();
24
+ const record = useMemo(() => {
25
+ const memoryProvider = new MemoryDataProvider([
26
+ {
27
+ [column.name]: conditionComponentValue.get() ?? undefined,
28
+ id: "id",
29
+ },
30
+ ], {
31
+ PrimaryIdAttribute: "id"
32
+ });
33
+ memoryProvider.setColumns([
34
+ {
35
+ ...column,
36
+ metadata: { ...column.metadata, RequiredLevel: 0 },
37
+ },
38
+ {
39
+ name: "id",
40
+ displayName: "",
41
+ dataType: DataTypes.SingleLineText,
42
+ alias: "id",
43
+ order: 0,
44
+ visualSizeFactor: 0,
45
+ },
46
+ ]);
47
+ const record = memoryProvider.refreshSync()[0];
48
+ return record;
49
+ }, []);
50
+ record.setValue(column.name, conditionComponentValue.get());
51
+ useEffect(() => {
52
+ if (conditionComponentValue.get() === null) {
53
+ const input = componentContainerRef.current?.querySelector('input');
54
+ input?.focus();
55
+ }
56
+ if (!firstRenderRef.current) {
57
+ record.expressions?.setRequiredLevelExpression(column.name, () => 'required');
58
+ }
59
+ if (firstRenderRef.current) {
60
+ firstRenderRef.current = false;
61
+ }
62
+ }, [conditionComponentValue.get()]);
63
+ useEffect(() => {
64
+ if (!controller.value.valid) {
65
+ record?.expressions?.setRequiredLevelExpression(column.name, () => 'required');
66
+ rerender();
67
+ }
68
+ }, [controller.value.valid]);
69
+ return (jsx("div", { ref: componentContainerRef, children: jsx(Component, { column: column, record: record, onNotifyOutputChanged: (value) => conditionComponentValue.set(value) }) }));
70
+ };
71
+
72
+ export { ConditionValue };
73
+ //# sourceMappingURL=ConditionValue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConditionValue.js","sources":["../../../../../../../../src/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.tsx"],"sourcesContent":["import { useEffect, useMemo, useRef } from \"react\";\nimport { IGridColumn } from \"../../../../../core/interfaces/IGridColumn\";\nimport { IColumnFilterConditionController, useColumnFilterConditionController } from \"../../../../controller/useColumnFilterConditionController\";\nimport { ConditionComponentValue } from \"./model/ConditionComponentValue\";\nimport { DataTypes, MemoryDataProvider } from \"@talxis/client-libraries\";\nimport { Component } from \"../LegacyControlRendering/Component\";\nimport { useRerender } from \"@talxis/react-components\";\n\ninterface IConditionValue {\n column: IGridColumn;\n}\n\nexport const ConditionValue = (props: IConditionValue) => {\n const condition = useColumnFilterConditionController(props.column);\n if (!condition) {\n return <></>\n }\n return <InternalConditionValue {...condition} />\n}\n\nconst InternalConditionValue = (controller: IColumnFilterConditionController) => {\n const componentContainerRef = useRef<HTMLDivElement>(null);\n const controllerRef = useRef<IColumnFilterConditionController>(controller);\n const firstRenderRef = useRef(true);\n controllerRef.current = controller;\n const conditionComponentValue = useMemo(() => new ConditionComponentValue(controllerRef), []);\n const column = conditionComponentValue.column;\n const rerender = useRerender();\n\n const record = useMemo(() => {\n const memoryProvider = new MemoryDataProvider(\n [\n {\n [column.name]: conditionComponentValue.get() ?? undefined,\n id: \"id\",\n },\n ], {\n PrimaryIdAttribute: \"id\"\n }\n );\n memoryProvider.setColumns([\n {\n ...column,\n metadata: { ...(column.metadata as any), RequiredLevel: 0 },\n },\n {\n name: \"id\",\n displayName: \"\",\n dataType: DataTypes.SingleLineText,\n alias: \"id\",\n order: 0,\n visualSizeFactor: 0,\n },\n ]);\n const record = memoryProvider.refreshSync()[0];\n return record;\n }, []);\n\n record.setValue(column.name, conditionComponentValue.get())\n\n useEffect(() => {\n if (conditionComponentValue.get() === null) {\n const input = componentContainerRef.current?.querySelector('input')\n input?.focus()\n }\n if (!firstRenderRef.current) {\n record.expressions?.setRequiredLevelExpression(column.name, () => 'required');\n }\n if (firstRenderRef.current) {\n firstRenderRef.current = false;\n }\n }, [conditionComponentValue.get()])\n\n useEffect(() => {\n if (!controller.value.valid) {\n record?.expressions?.setRequiredLevelExpression(column.name, () => 'required');\n rerender();\n }\n }, [controller.value.valid])\n\n\n return (\n <div ref={componentContainerRef}>\n <Component\n column={column}\n record={record}\n onNotifyOutputChanged={(value) => conditionComponentValue.set(value)}\n />\n </div>\n )\n}\n"],"names":["_jsx"],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import { IGridColumn } from "../../../../../core/interfaces/IGridColumn";
3
+ interface IConditionValue {
4
+ column: IGridColumn;
5
+ }
6
+ export declare const ConditionValueBetween: (props: IConditionValue) => JSX.Element;
7
+ export {};
@@ -0,0 +1,90 @@
1
+ import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
2
+ import { useRef, useMemo } from 'react';
3
+ import { useColumnFilterConditionController } from '../../../../controller/useColumnFilterConditionController.js';
4
+ import { ConditionComponentValue } from './model/ConditionComponentValue.js';
5
+ import { FieldValue } from '@talxis/client-libraries';
6
+ import { useGridInstance } from '../../../../../core/hooks/useGridInstance.js';
7
+ import dayjs from 'dayjs';
8
+ import { mergeStyles } from '@fluentui/react';
9
+ import { DateTime } from '../../../../../../DateTime/DateTime.js';
10
+
11
+ //copied over the original so it wont get messed up, we need to create a new solution for filtering that is independent of the legacy control rendering
12
+ const ConditionValueBetween = (props) => {
13
+ const condition = useColumnFilterConditionController(props.column);
14
+ if (!condition) {
15
+ return jsx(Fragment, {});
16
+ }
17
+ return jsx(InternalConditionValue, { ...condition });
18
+ };
19
+ const InternalConditionValue = (controller) => {
20
+ const grid = useGridInstance();
21
+ const componentContainerRef = useRef(null);
22
+ const controllerRef = useRef(controller);
23
+ controllerRef.current = controller;
24
+ const conditionComponentValue = useMemo(() => new ConditionComponentValue(controllerRef), []);
25
+ const column = conditionComponentValue.column;
26
+ const getDateBetweenError = (value) => {
27
+ if (controller.shouldShowError() && !controller.value.valid) {
28
+ const fieldValue = new FieldValue(value, column.dataType, {
29
+ ...column.metadata,
30
+ RequiredLevel: 1
31
+ });
32
+ if (fieldValue.isValid().error) {
33
+ return fieldValue.isValid().errorMessage;
34
+ }
35
+ }
36
+ return undefined;
37
+ };
38
+ const getDateBetweenValue = (value) => {
39
+ if (!value) {
40
+ return null;
41
+ }
42
+ const fieldValue = new FieldValue(value, column.dataType, column.metadata);
43
+ if (fieldValue.isValid().error) {
44
+ return value;
45
+ }
46
+ return dayjs(fieldValue.getValue()).startOf('day').toDate();
47
+ };
48
+ return (jsxs("div", { className: mergeStyles({
49
+ display: 'flex',
50
+ flexDirection: 'column',
51
+ gap: 5
52
+ }), ref: componentContainerRef, children: [jsx(DateTime, { context: grid.pcfContext, parameters: {
53
+ EnableDeleteButton: {
54
+ raw: true
55
+ },
56
+ ShowErrorMessage: {
57
+ raw: true
58
+ },
59
+ value: {
60
+ error: !!getDateBetweenError(conditionComponentValue.get()?.[0]),
61
+ errorMessage: getDateBetweenError(conditionComponentValue.get()?.[0]),
62
+ raw: getDateBetweenValue(conditionComponentValue.get()?.[0]),
63
+ //@ts-ignore - typings
64
+ attributes: {
65
+ Format: "DateOnly",
66
+ Behavior: 1,
67
+ }
68
+ }
69
+ }, onNotifyOutputChanged: (outputs) => conditionComponentValue.set([outputs.value, conditionComponentValue.get()?.[1]]) }), jsx(DateTime, { context: grid.pcfContext, parameters: {
70
+ EnableDeleteButton: {
71
+ raw: true
72
+ },
73
+ ShowErrorMessage: {
74
+ raw: true
75
+ },
76
+ value: {
77
+ error: !!getDateBetweenError(conditionComponentValue.get()?.[1]),
78
+ errorMessage: getDateBetweenError(conditionComponentValue.get()?.[1]),
79
+ raw: getDateBetweenValue(conditionComponentValue.get()?.[1]),
80
+ //@ts-ignore - typings
81
+ attributes: {
82
+ Format: "DateOnly",
83
+ Behavior: 1,
84
+ }
85
+ }
86
+ }, onNotifyOutputChanged: (outputs) => conditionComponentValue.set([conditionComponentValue.get()?.[0], outputs.value]) })] }));
87
+ };
88
+
89
+ export { ConditionValueBetween };
90
+ //# sourceMappingURL=ConditionValueBetween.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConditionValueBetween.js","sources":["../../../../../../../../src/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValueBetween.tsx"],"sourcesContent":["import { useMemo, useRef } from \"react\";\nimport { IGridColumn } from \"../../../../../core/interfaces/IGridColumn\";\nimport { IColumnFilterConditionController, useColumnFilterConditionController } from \"../../../../controller/useColumnFilterConditionController\";\nimport { ConditionComponentValue } from \"./model/ConditionComponentValue\";\nimport { DataType, FieldValue } from \"@talxis/client-libraries\";\nimport { DateTime } from \"../../../../../../DateTime\";\nimport { useGridInstance } from \"../../../../../core/hooks/useGridInstance\";\nimport dayjs from \"dayjs\";\nimport { mergeStyles } from \"@fluentui/react\";\n\ninterface IConditionValue {\n column: IGridColumn;\n}\n\n\n//copied over the original so it wont get messed up, we need to create a new solution for filtering that is independent of the legacy control rendering\nexport const ConditionValueBetween = (props: IConditionValue) => {\n const condition = useColumnFilterConditionController(props.column);\n if (!condition) {\n return <></>\n }\n return <InternalConditionValue {...condition} />\n}\n\nconst InternalConditionValue = (controller: IColumnFilterConditionController) => {\n const grid = useGridInstance();\n const componentContainerRef = useRef<HTMLDivElement>(null);\n const controllerRef = useRef<IColumnFilterConditionController>(controller);\n controllerRef.current = controller;\n const conditionComponentValue = useMemo(() => new ConditionComponentValue(controllerRef), []);\n const column = conditionComponentValue.column;\n\n const getDateBetweenError = (value: any): string | undefined => {\n if (controller.shouldShowError() && !controller.value.valid) {\n const fieldValue = new FieldValue(value, column.dataType as DataType, {\n ...column.metadata,\n RequiredLevel: 1\n });\n if (fieldValue.isValid().error) {\n return fieldValue.isValid().errorMessage;\n }\n }\n return undefined;\n }\n\n const getDateBetweenValue = (value: any) => {\n if (!value) {\n return null;\n }\n const fieldValue = new FieldValue(value, column.dataType as DataType, column.metadata);\n if (fieldValue.isValid().error) {\n return value;\n }\n return dayjs(fieldValue.getValue()).startOf('day').toDate();\n }\n\n return (\n <div className={mergeStyles({\n display: 'flex',\n flexDirection: 'column',\n gap: 5\n })} ref={componentContainerRef}>\n <DateTime\n context={grid.pcfContext}\n parameters={{\n EnableDeleteButton: {\n raw: true\n },\n ShowErrorMessage: {\n raw: true\n },\n value: {\n error: !!getDateBetweenError(conditionComponentValue.get()?.[0]),\n errorMessage: getDateBetweenError(conditionComponentValue.get()?.[0]),\n raw: getDateBetweenValue(conditionComponentValue.get()?.[0]),\n //@ts-ignore - typings\n attributes: {\n Format: \"DateOnly\",\n Behavior: 1,\n }\n }\n }}\n onNotifyOutputChanged={(outputs) => conditionComponentValue.set([outputs.value, conditionComponentValue.get()?.[1]])}\n />\n <DateTime\n context={grid.pcfContext}\n parameters={{\n EnableDeleteButton: {\n raw: true\n },\n ShowErrorMessage: {\n raw: true\n },\n value: {\n error: !!getDateBetweenError(conditionComponentValue.get()?.[1]),\n errorMessage: getDateBetweenError(conditionComponentValue.get()?.[1]),\n raw: getDateBetweenValue(conditionComponentValue.get()?.[1]),\n //@ts-ignore - typings\n attributes: {\n Format: \"DateOnly\",\n Behavior: 1,\n }\n }\n }}\n onNotifyOutputChanged={(outputs) => conditionComponentValue.set([conditionComponentValue.get()?.[0], outputs.value])}\n />\n </div >\n )\n}\n"],"names":["_jsx","_jsxs"],"mappings":"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"}
@@ -0,0 +1,48 @@
1
+ /// <reference types="react" />
2
+ /// <reference types="@types/xrm" />
3
+ import { IColumnFilterConditionController } from "../../../../../controller/useColumnFilterConditionController";
4
+ export declare class ConditionComponentValue {
5
+ private _columnFilterConditionControllerRef;
6
+ private _conditionUtils;
7
+ constructor(columnFilterConditionControllerRef: React.MutableRefObject<IColumnFilterConditionController>);
8
+ get column(): {
9
+ isRequired: boolean;
10
+ isEditable: boolean;
11
+ isFilterable: boolean;
12
+ isSorted: boolean;
13
+ isFiltered: boolean;
14
+ canBeAggregated: boolean;
15
+ isSortedDescending: boolean;
16
+ isResizable: boolean;
17
+ alignment: "left" | "right" | "center" | undefined;
18
+ getEntityName: () => string;
19
+ name: string;
20
+ metadata?: Partial<Omit<Xrm.Metadata.AttributeMetadata, "OptionSet"> & {
21
+ [key: string]: any;
22
+ OptionSet: {
23
+ Color: string;
24
+ Label: string;
25
+ Value: number;
26
+ }[];
27
+ SupportedAggregations?: import("@talxis/client-libraries").AggregationFunction[] | undefined;
28
+ }> | undefined;
29
+ type?: "data" | "action" | undefined;
30
+ isDraggable?: boolean | undefined;
31
+ aggregationFunction?: import("@talxis/client-libraries").AggregationFunction | undefined;
32
+ oneClickEdit?: boolean | undefined;
33
+ controls?: import("@talxis/client-libraries").ICustomColumnControl[] | undefined;
34
+ displayName?: string | undefined;
35
+ dataType?: string | undefined;
36
+ alias?: string | undefined;
37
+ order?: number | undefined;
38
+ visualSizeFactor?: number | undefined;
39
+ isHidden?: boolean | undefined;
40
+ isPrimary?: boolean | undefined;
41
+ disableSorting?: boolean | undefined;
42
+ };
43
+ get(): any;
44
+ set(value: any): void;
45
+ private get _columnFilterConditionController();
46
+ private get _value();
47
+ private get _operator();
48
+ }
@@ -0,0 +1,146 @@
1
+ import dayjs from 'dayjs';
2
+ import { DatasetConditionOperator } from '../../../../../../core/enums/ConditionOperator.js';
3
+ import { DataType } from '../../../../../../core/enums/DataType.js';
4
+ import { FilteringUtils } from '../../../../../utils/FilteringUtilts.js';
5
+
6
+ class ConditionComponentValue {
7
+ constructor(columnFilterConditionControllerRef) {
8
+ this._conditionUtils = FilteringUtils.condition();
9
+ this._columnFilterConditionControllerRef = columnFilterConditionControllerRef;
10
+ }
11
+ get column() {
12
+ const _column = { ...this._columnFilterConditionController.column };
13
+ _column.isRequired = false;
14
+ //always needs to be required for filter values if non valid value is present
15
+ if (!this._columnFilterConditionController.value.valid) {
16
+ _column.isRequired = true;
17
+ }
18
+ switch (this._columnFilterConditionController.column.dataType) {
19
+ case DataType.OPTIONSET:
20
+ case DataType.TWO_OPTIONS: {
21
+ _column.dataType = DataType.MULTI_SELECT_OPTIONSET;
22
+ break;
23
+ }
24
+ //skip this validation because operators like contains should not fail on regexes
25
+ case DataType.SINGLE_LINE_EMAIL:
26
+ case DataType.SINGLE_LINE_URL:
27
+ //use single line text field for filters on multiple
28
+ case DataType.MULTIPLE:
29
+ case DataType.SINGLE_LINE_TEXT_AREA: {
30
+ _column.dataType = DataType.SINGLE_LINE_TEXT;
31
+ break;
32
+ }
33
+ //In Power Apps, DateTime fields filters do not allow setting filters for time, only for the date
34
+ case DataType.DATE_AND_TIME_DATE_AND_TIME: {
35
+ _column.dataType = DataType.DATE_AND_TIME_DATE_ONLY;
36
+ break;
37
+ }
38
+ }
39
+ this._conditionUtils.operator(this._operator.get()).allowsOnlyNumber;
40
+ if (this._conditionUtils.operator(this._operator.get()).allowsOnlyNumber) {
41
+ _column.dataType = DataType.WHOLE_NONE;
42
+ }
43
+ if (this._conditionUtils.operator(this._operator.get()).allowsOnlyFreeText) {
44
+ _column.dataType = DataType.SINGLE_LINE_TEXT;
45
+ }
46
+ return _column;
47
+ }
48
+ get() {
49
+ let value = this._value.get();
50
+ if (value == null) {
51
+ return null;
52
+ }
53
+ switch (this.column.dataType) {
54
+ case DataType.MULTI_SELECT_OPTIONSET: {
55
+ if (!value) {
56
+ return [];
57
+ }
58
+ if (typeof value === 'string') {
59
+ value = [value];
60
+ }
61
+ return value.map((x) => parseInt(x));
62
+ }
63
+ case DataType.LOOKUP_OWNER:
64
+ case DataType.LOOKUP_SIMPLE:
65
+ case DataType.LOOKUP_CUSTOMER: {
66
+ if (!value) {
67
+ return [];
68
+ }
69
+ if (typeof value === 'string') {
70
+ value = [value];
71
+ }
72
+ return value.map((x) => {
73
+ return {
74
+ entityType: "",
75
+ name: "",
76
+ id: x
77
+ };
78
+ });
79
+ }
80
+ }
81
+ return value;
82
+ }
83
+ set(value) {
84
+ switch (this.column.dataType) {
85
+ case DataType.DATE_AND_TIME_DATE_AND_TIME:
86
+ case DataType.DATE_AND_TIME_DATE_ONLY: {
87
+ if (Array.isArray(value)) {
88
+ value = value.map((x) => {
89
+ if (x) {
90
+ const date = dayjs(x);
91
+ if (date.isValid()) {
92
+ return date.format('YYYY-MM-DD');
93
+ }
94
+ return x;
95
+ }
96
+ return null;
97
+ });
98
+ }
99
+ if (value instanceof Date) {
100
+ //the column of date time is always converted to Date column in Power Apps
101
+ value = dayjs(value).format('YYYY-MM-DD');
102
+ }
103
+ break;
104
+ }
105
+ case DataType.MULTI_SELECT_OPTIONSET: {
106
+ switch (this._operator.get()) {
107
+ case DatasetConditionOperator.Equal:
108
+ case DatasetConditionOperator.NotEqual: {
109
+ if (value?.length === 1) {
110
+ value = value[0].toString();
111
+ this._value.set(value);
112
+ return;
113
+ }
114
+ }
115
+ }
116
+ for (let i = 0; i < value?.length; i++) {
117
+ value[i] = value[i].toString();
118
+ }
119
+ this._value.set(value);
120
+ return;
121
+ }
122
+ case DataType.LOOKUP_OWNER:
123
+ case DataType.LOOKUP_SIMPLE:
124
+ case DataType.LOOKUP_CUSTOMER: {
125
+ if (value?.length > 1) {
126
+ value = value.map((x) => x.id);
127
+ break;
128
+ }
129
+ value = value[0]?.id;
130
+ }
131
+ }
132
+ this._value.set(value);
133
+ }
134
+ get _columnFilterConditionController() {
135
+ return this._columnFilterConditionControllerRef.current;
136
+ }
137
+ get _value() {
138
+ return this._columnFilterConditionController.value;
139
+ }
140
+ get _operator() {
141
+ return this._columnFilterConditionController.operator;
142
+ }
143
+ }
144
+
145
+ export { ConditionComponentValue };
146
+ //# sourceMappingURL=ConditionComponentValue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConditionComponentValue.js","sources":["../../../../../../../../../src/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.ts"],"sourcesContent":["import dayjs from \"dayjs\";\nimport { DatasetConditionOperator } from \"../../../../../../core/enums/ConditionOperator\";\nimport { DataType } from \"../../../../../../core/enums/DataType\";\nimport { IColumnFilterConditionController } from \"../../../../../controller/useColumnFilterConditionController\";\nimport { FilteringUtils } from \"../../../../../utils/FilteringUtilts\";\n\nexport class ConditionComponentValue {\n //needs to be ref to keep the current reference\n private _columnFilterConditionControllerRef: React.MutableRefObject<IColumnFilterConditionController>;\n private _conditionUtils = FilteringUtils.condition();\n\n constructor(columnFilterConditionControllerRef: React.MutableRefObject<IColumnFilterConditionController>) {\n this._columnFilterConditionControllerRef = columnFilterConditionControllerRef;\n }\n\n public get column() {\n const _column = {...this._columnFilterConditionController.column};\n _column.isRequired = false;\n //always needs to be required for filter values if non valid value is present\n if(!this._columnFilterConditionController.value.valid) {\n _column.isRequired = true;\n }\n switch (this._columnFilterConditionController.column.dataType) {\n case DataType.OPTIONSET:\n case DataType.TWO_OPTIONS: {\n _column.dataType = DataType.MULTI_SELECT_OPTIONSET;\n break;\n }\n //skip this validation because operators like contains should not fail on regexes\n case DataType.SINGLE_LINE_EMAIL:\n case DataType.SINGLE_LINE_URL:\n //use single line text field for filters on multiple\n case DataType.MULTIPLE:\n case DataType.SINGLE_LINE_TEXT_AREA: {\n _column.dataType = DataType.SINGLE_LINE_TEXT;\n break;\n }\n //In Power Apps, DateTime fields filters do not allow setting filters for time, only for the date\n case DataType.DATE_AND_TIME_DATE_AND_TIME: {\n _column.dataType = DataType.DATE_AND_TIME_DATE_ONLY;\n break;\n }\n }\n this._conditionUtils.operator(this._operator.get()).allowsOnlyNumber\n if (this._conditionUtils.operator(this._operator.get()).allowsOnlyNumber) {\n _column.dataType = DataType.WHOLE_NONE;\n }\n if (this._conditionUtils.operator(this._operator.get()).allowsOnlyFreeText) {\n _column.dataType = DataType.SINGLE_LINE_TEXT;\n }\n return _column;\n }\n public get() {\n let value = this._value.get();\n if (value == null) {\n return null;\n }\n switch (this.column.dataType) {\n case DataType.MULTI_SELECT_OPTIONSET: {\n if(!value) {\n return [];\n }\n if (typeof value === 'string') {\n value = [value];\n }\n return value.map((x: string) => parseInt(x))\n }\n case DataType.LOOKUP_OWNER:\n case DataType.LOOKUP_SIMPLE:\n case DataType.LOOKUP_CUSTOMER: {\n if(!value) {\n return [];\n }\n if (typeof value === 'string') {\n value = [value];\n }\n return value.map((x: string) => {\n return {\n entityType: \"\",\n name: \"\",\n id: x\n } as ComponentFramework.LookupValue;\n })\n }\n }\n return value;\n }\n public set(value: any) {\n switch (this.column.dataType) {\n case DataType.DATE_AND_TIME_DATE_AND_TIME:\n case DataType.DATE_AND_TIME_DATE_ONLY: {\n if(Array.isArray(value)) {\n value = value.map((x: Date) => {\n if(x) {\n const date = dayjs(x);\n if(date.isValid()) {\n return date.format('YYYY-MM-DD');\n }\n return x;\n }\n return null;\n })\n }\n if(value instanceof Date) {\n //the column of date time is always converted to Date column in Power Apps\n value = dayjs(value).format('YYYY-MM-DD');\n }\n break;\n }\n case DataType.MULTI_SELECT_OPTIONSET: {\n switch (this._operator.get()) {\n case DatasetConditionOperator.Equal:\n case DatasetConditionOperator.NotEqual: {\n if (value?.length === 1) {\n value = value[0].toString();\n this._value.set(value);\n return;\n }\n }\n }\n for (let i = 0; i < value?.length; i++) {\n value[i] = value[i].toString()\n }\n this._value.set(value);\n return;\n }\n case DataType.LOOKUP_OWNER:\n case DataType.LOOKUP_SIMPLE:\n case DataType.LOOKUP_CUSTOMER: {\n if(value?.length > 1) {\n value = value.map((x: ComponentFramework.LookupValue) => x.id);\n break;\n }\n value = value[0]?.id;\n }\n\n }\n this._value.set(value);\n }\n private get _columnFilterConditionController() {\n return this._columnFilterConditionControllerRef.current;\n }\n private get _value() {\n return this._columnFilterConditionController.value;\n }\n private get _operator() {\n return this._columnFilterConditionController.operator;\n }\n}"],"names":[],"mappings":"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"}