@talxis/base-controls 1.2509.1-alpha.5 → 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 (478) 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/DateTime/translations.d.ts +0 -1
  36. package/dist/components/Duration/durationOptions.d.ts +0 -1
  37. package/dist/components/Grid/Grid.d.ts +3 -0
  38. package/dist/components/Grid/Grid.js +37 -0
  39. package/dist/components/Grid/Grid.js.map +1 -0
  40. package/dist/components/Grid/GridContext.d.ts +3 -0
  41. package/dist/components/Grid/GridContext.js.map +1 -0
  42. package/dist/components/Grid/aggregation/Aggregation.d.ts +18 -0
  43. package/dist/components/Grid/aggregation/Aggregation.js +129 -0
  44. package/dist/components/Grid/aggregation/Aggregation.js.map +1 -0
  45. package/dist/components/Grid/{grid/Grid.d.ts → core/components/AgGrid/AgGrid.d.ts} +2 -2
  46. package/dist/components/Grid/core/components/AgGrid/AgGrid.js +203 -0
  47. package/dist/components/Grid/core/components/AgGrid/AgGrid.js.map +1 -0
  48. package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/EmptyRecords.js +12 -0
  49. package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/EmptyRecords.js.map +1 -0
  50. package/dist/components/Grid/{overlays/empty-records → core/components/AgGrid/components/EmptyRecordsOverlay}/styles.d.ts +1 -1
  51. package/dist/components/Grid/{overlays/empty-records → core/components/AgGrid/components/EmptyRecordsOverlay}/styles.js +1 -1
  52. package/dist/components/Grid/core/components/AgGrid/components/EmptyRecordsOverlay/styles.js.map +1 -0
  53. package/dist/components/Grid/core/components/AgGrid/components/LoadingOverlay/LoadingOverlay.js.map +1 -0
  54. package/dist/components/Grid/{grid/ag-grid/AgGridContext.d.ts → core/components/AgGrid/context.d.ts} +2 -2
  55. package/dist/components/Grid/{grid/ag-grid/AgGridContext.js → core/components/AgGrid/context.js} +1 -1
  56. package/dist/components/Grid/core/components/AgGrid/context.js.map +1 -0
  57. package/dist/components/Grid/core/components/AgGrid/model/AgGrid.d.ts +52 -0
  58. package/dist/components/Grid/core/components/AgGrid/model/AgGrid.js +343 -0
  59. package/dist/components/Grid/core/components/AgGrid/model/AgGrid.js.map +1 -0
  60. package/dist/components/Grid/{grid/ValueComparator.d.ts → core/components/AgGrid/model/Comparator.d.ts} +1 -1
  61. package/dist/components/Grid/{grid/ValueComparator.js → core/components/AgGrid/model/Comparator.js} +1 -7
  62. package/dist/components/Grid/core/components/AgGrid/model/Comparator.js.map +1 -0
  63. package/dist/components/Grid/{grid → core/components/AgGrid}/styles.d.ts +4 -24
  64. package/dist/components/Grid/{grid → core/components/AgGrid}/styles.js +6 -37
  65. package/dist/components/Grid/core/components/AgGrid/styles.js.map +1 -0
  66. package/dist/components/Grid/{cells/cell → core/components/Cell}/Cell.d.ts +3 -3
  67. package/dist/components/Grid/core/components/Cell/Cell.js +158 -0
  68. package/dist/components/Grid/core/components/Cell/Cell.js.map +1 -0
  69. package/dist/components/Grid/{cells/cell/content → core/components/Cell/CellContent}/CellContent.d.ts +2 -2
  70. package/dist/components/Grid/{cells/cell/content → core/components/Cell/CellContent}/CellContent.js +31 -40
  71. package/dist/components/Grid/core/components/Cell/CellContent/CellContent.js.map +1 -0
  72. package/dist/components/Grid/core/components/Cell/CellContent/styles.js.map +1 -0
  73. package/dist/components/Grid/{cells/cell/notifications → core/components/Cell/Notifications}/Notifications.d.ts +1 -1
  74. package/dist/components/Grid/{cells/cell/notifications → core/components/Cell/Notifications}/Notifications.js +5 -5
  75. package/dist/components/Grid/core/components/Cell/Notifications/Notifications.js.map +1 -0
  76. package/dist/components/Grid/{cells/cell/notifications → core/components/Cell/Notifications}/styles.js +1 -1
  77. package/dist/components/Grid/core/components/Cell/Notifications/styles.js.map +1 -0
  78. package/dist/components/Grid/{cells/cell → core/components/Cell}/styles.d.ts +3 -34
  79. package/dist/components/Grid/core/components/Cell/styles.js +59 -0
  80. package/dist/components/Grid/core/components/Cell/styles.js.map +1 -0
  81. package/dist/components/Grid/{column-headers/column-header → core/components/ColumnHeader}/ColumnHeader.d.ts +1 -1
  82. package/dist/components/Grid/core/components/ColumnHeader/ColumnHeader.js +61 -0
  83. package/dist/components/Grid/core/components/ColumnHeader/ColumnHeader.js.map +1 -0
  84. package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/GlobalCheckbox.d.ts +2 -0
  85. package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/GlobalCheckbox.js +50 -0
  86. package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/GlobalCheckbox.js.map +1 -0
  87. package/dist/components/Grid/core/components/ColumnHeader/components/GlobalCheckbox/styles.js.map +1 -0
  88. package/dist/components/Grid/core/components/ColumnHeader/styles.d.ts +42 -0
  89. package/dist/components/Grid/core/components/ColumnHeader/styles.js +48 -0
  90. package/dist/components/Grid/core/components/ColumnHeader/styles.js.map +1 -0
  91. package/dist/components/Grid/core/components/Dialog/Constants.d.ts +2 -0
  92. package/dist/components/Grid/core/components/Dialog/Constants.js +9 -0
  93. package/dist/components/Grid/core/components/Dialog/Constants.js.map +1 -0
  94. package/dist/components/Grid/core/components/Dialog/Styles.d.ts +2 -0
  95. package/dist/components/Grid/core/components/Dialog/Styles.js +61 -0
  96. package/dist/components/Grid/core/components/Dialog/Styles.js.map +1 -0
  97. package/dist/components/Grid/core/components/Dialog/index.d.ts +4 -0
  98. package/dist/components/Grid/core/components/Dialog/index.js +16 -0
  99. package/dist/components/Grid/core/components/Dialog/index.js.map +1 -0
  100. package/dist/components/Grid/core/components/Dialog/interfaces/index.d.ts +6 -0
  101. package/dist/components/Grid/core/components/Dialog/interfaces/index.js +2 -0
  102. package/dist/components/Grid/core/components/Dialog/interfaces/index.js.map +1 -0
  103. package/dist/components/Grid/core/components/Save/Save.d.ts +2 -0
  104. package/dist/components/Grid/core/components/Save/Save.js +59 -0
  105. package/dist/components/Grid/core/components/Save/Save.js.map +1 -0
  106. package/dist/components/Grid/core/components/Save/components/ChangeEditor/ChangeEditor.d.ts +7 -0
  107. package/dist/components/Grid/core/components/Save/components/ChangeEditor/ChangeEditor.js +73 -0
  108. package/dist/components/Grid/core/components/Save/components/ChangeEditor/ChangeEditor.js.map +1 -0
  109. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/ChangeGrid.d.ts +11 -0
  110. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/ChangeGrid.js +231 -0
  111. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/ChangeGrid.js.map +1 -0
  112. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/styles.d.ts +39 -0
  113. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/styles.js +45 -0
  114. package/dist/components/Grid/core/components/Save/components/ChangeEditor/components/ChangeGrid/styles.js.map +1 -0
  115. package/dist/components/Grid/core/components/Save/components/ChangeEditor/styles.d.ts +31 -0
  116. package/dist/components/Grid/core/components/Save/components/ChangeEditor/styles.js +37 -0
  117. package/dist/components/Grid/core/components/Save/components/ChangeEditor/styles.js.map +1 -0
  118. package/dist/components/Grid/core/components/Save/styles.d.ts +35 -0
  119. package/dist/components/Grid/core/components/Save/styles.js +42 -0
  120. package/dist/components/Grid/core/components/Save/styles.js.map +1 -0
  121. package/dist/components/Grid/core/controllers/useGridController.d.ts +7 -0
  122. package/dist/components/Grid/core/controllers/useGridController.js +29 -0
  123. package/dist/components/Grid/core/controllers/useGridController.js.map +1 -0
  124. package/dist/components/Grid/core/enums/ConditionOperator.d.ts +48 -0
  125. package/dist/components/Grid/core/enums/ConditionOperator.js +52 -0
  126. package/dist/components/Grid/core/enums/ConditionOperator.js.map +1 -0
  127. package/dist/components/Grid/core/enums/DataType.d.ts +25 -0
  128. package/dist/components/Grid/core/enums/DataType.js +30 -0
  129. package/dist/components/Grid/core/enums/DataType.js.map +1 -0
  130. package/dist/components/Grid/core/hooks/useGridInstance.d.ts +2 -0
  131. package/dist/components/Grid/{grid → core/hooks}/useGridInstance.js +2 -2
  132. package/dist/components/Grid/core/hooks/useGridInstance.js.map +1 -0
  133. package/dist/components/Grid/core/hooks/useRefreshCallback.d.ts +2 -0
  134. package/dist/components/Grid/core/hooks/useRefreshCallback.js +20 -0
  135. package/dist/components/Grid/core/hooks/useRefreshCallback.js.map +1 -0
  136. package/dist/components/Grid/core/interfaces/IGridColumn.d.ts +13 -0
  137. package/dist/components/Grid/core/interfaces/IGridContext.d.ts +4 -0
  138. package/dist/components/Grid/core/model/Grid.d.ts +83 -0
  139. package/dist/components/Grid/core/model/Grid.js +528 -0
  140. package/dist/components/Grid/core/model/Grid.js.map +1 -0
  141. package/dist/components/Grid/core/model/GridDependency.d.ts +13 -0
  142. package/dist/components/Grid/core/model/GridDependency.js +28 -0
  143. package/dist/components/Grid/core/model/GridDependency.js.map +1 -0
  144. package/dist/components/Grid/core/services/KeyListener.d.ts +12 -0
  145. package/dist/components/Grid/core/services/KeyListener.js +31 -0
  146. package/dist/components/Grid/core/services/KeyListener.js.map +1 -0
  147. package/dist/components/Grid/{column-headers/column-header → filtering/components/FilterCallout}/FilterCallout.d.ts +1 -1
  148. package/dist/components/Grid/filtering/components/FilterCallout/FilterCallout.js +59 -0
  149. package/dist/components/Grid/filtering/components/FilterCallout/FilterCallout.js.map +1 -0
  150. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.d.ts +7 -0
  151. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.js +56 -0
  152. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionOperator/ConditionOperator.js.map +1 -0
  153. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.d.ts +7 -0
  154. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.js +73 -0
  155. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValue.js.map +1 -0
  156. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValueBetween.d.ts +7 -0
  157. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValueBetween.js +90 -0
  158. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/ConditionValueBetween.js.map +1 -0
  159. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.d.ts +48 -0
  160. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.js +146 -0
  161. package/dist/components/Grid/filtering/components/FilterCallout/components/ConditionValue/model/ConditionComponentValue.js.map +1 -0
  162. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/Component.d.ts +11 -0
  163. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/Component.js +53 -0
  164. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/Component.js.map +1 -0
  165. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/controller/useComponentController.d.ts +9 -0
  166. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/controller/useComponentController.js +31 -0
  167. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/controller/useComponentController.js.map +1 -0
  168. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/model/Component.d.ts +10 -0
  169. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/model/Component.js +294 -0
  170. package/dist/components/Grid/filtering/components/FilterCallout/components/LegacyControlRendering/model/Component.js.map +1 -0
  171. package/dist/components/Grid/filtering/components/FilterCallout/styles.d.ts +35 -0
  172. package/dist/components/Grid/{column-headers/column-header → filtering/components/FilterCallout}/styles.js +11 -20
  173. package/dist/components/Grid/filtering/components/FilterCallout/styles.js.map +1 -0
  174. package/dist/components/Grid/filtering/constants.d.ts +5 -0
  175. package/dist/components/Grid/filtering/constants.js +53 -0
  176. package/dist/components/Grid/filtering/constants.js.map +1 -0
  177. package/dist/components/Grid/filtering/controller/useColumnFilterConditionController.d.ts +21 -0
  178. package/dist/components/Grid/filtering/controller/useColumnFilterConditionController.js +44 -0
  179. package/dist/components/Grid/filtering/controller/useColumnFilterConditionController.js.map +1 -0
  180. package/dist/components/Grid/filtering/model/Condition.d.ts +49 -0
  181. package/dist/components/Grid/filtering/model/Condition.js +347 -0
  182. package/dist/components/Grid/filtering/model/Condition.js.map +1 -0
  183. package/dist/components/Grid/filtering/model/Filtering.d.ts +11 -0
  184. package/dist/components/Grid/filtering/model/Filtering.js +78 -0
  185. package/dist/components/Grid/filtering/model/Filtering.js.map +1 -0
  186. package/dist/components/Grid/filtering/utils/FilteringUtilts.d.ts +34 -0
  187. package/dist/components/Grid/filtering/utils/FilteringUtilts.js +195 -0
  188. package/dist/components/Grid/filtering/utils/FilteringUtilts.js.map +1 -0
  189. package/dist/components/Grid/index.d.ts +1 -1
  190. package/dist/components/Grid/index.js +1 -1
  191. package/dist/components/Grid/interfaces.d.ts +0 -10
  192. package/dist/components/Grid/selection/model/Selection.d.ts +12 -0
  193. package/dist/components/Grid/selection/model/Selection.js +55 -0
  194. package/dist/components/Grid/selection/model/Selection.js.map +1 -0
  195. package/dist/components/Grid/sorting/Sorting.d.ts +10 -0
  196. package/dist/components/Grid/sorting/Sorting.js +31 -0
  197. package/dist/components/Grid/sorting/Sorting.js.map +1 -0
  198. package/dist/components/Grid/{column-headers/column-header/ColumnHeaderContextualMenu.d.ts → sorting/components/SortingContextualMenu/SortingContextualMenu.d.ts} +3 -3
  199. package/dist/components/Grid/sorting/components/SortingContextualMenu/SortingContextualMenu.js +157 -0
  200. package/dist/components/Grid/sorting/components/SortingContextualMenu/SortingContextualMenu.js.map +1 -0
  201. package/dist/components/Grid/sorting/components/SortingContextualMenu/styles.d.ts +9 -0
  202. package/dist/components/Grid/sorting/components/SortingContextualMenu/styles.js +15 -0
  203. package/dist/components/Grid/sorting/components/SortingContextualMenu/styles.js.map +1 -0
  204. package/dist/components/Grid/sorting/controllers/useColumnSortingController.d.ts +9 -0
  205. package/dist/components/Grid/sorting/controllers/useColumnSortingController.js +22 -0
  206. package/dist/components/Grid/sorting/controllers/useColumnSortingController.js.map +1 -0
  207. package/dist/components/Grid/translations.d.ts +180 -20
  208. package/dist/components/Grid/translations.js +48 -5
  209. package/dist/components/Grid/translations.js.map +1 -1
  210. package/dist/components/GridCellRenderer/DefaultContentRenderer/DefaultContentRenderer.d.ts +2 -0
  211. package/dist/components/GridCellRenderer/DefaultContentRenderer/DefaultContentRenderer.js +11 -0
  212. package/dist/components/GridCellRenderer/DefaultContentRenderer/DefaultContentRenderer.js.map +1 -0
  213. package/dist/components/GridCellRenderer/DefaultContentRenderer/index.d.ts +1 -0
  214. package/dist/components/GridCellRenderer/DefaultContentRenderer/index.js +2 -0
  215. package/dist/components/GridCellRenderer/DefaultContentRenderer/index.js.map +1 -0
  216. package/dist/components/GridCellRenderer/GridCellRenderer.js +282 -99
  217. package/dist/components/GridCellRenderer/GridCellRenderer.js.map +1 -1
  218. package/dist/components/GridCellRenderer/OptionSet/OptionSet.d.ts +5 -0
  219. package/dist/components/GridCellRenderer/OptionSet/OptionSet.js +75 -0
  220. package/dist/components/GridCellRenderer/OptionSet/OptionSet.js.map +1 -0
  221. package/dist/components/GridCellRenderer/OptionSet/index.d.ts +1 -0
  222. package/dist/components/GridCellRenderer/OptionSet/index.js +2 -0
  223. package/dist/components/GridCellRenderer/OptionSet/index.js.map +1 -0
  224. package/dist/components/GridCellRenderer/OptionSet/styles.d.ts +20 -0
  225. package/dist/components/GridCellRenderer/OptionSet/styles.js +29 -0
  226. package/dist/components/GridCellRenderer/OptionSet/styles.js.map +1 -0
  227. package/dist/components/GridCellRenderer/RecordCommands/Icon.d.ts +7 -0
  228. package/dist/components/GridCellRenderer/RecordCommands/Icon.js +32 -0
  229. package/dist/components/GridCellRenderer/RecordCommands/Icon.js.map +1 -0
  230. package/dist/components/GridCellRenderer/RecordCommands/RecordCommands.d.ts +13 -0
  231. package/dist/components/GridCellRenderer/RecordCommands/RecordCommands.js +103 -0
  232. package/dist/components/GridCellRenderer/RecordCommands/RecordCommands.js.map +1 -0
  233. package/dist/components/GridCellRenderer/RecordCommands/styles.d.ts +13 -0
  234. package/dist/components/GridCellRenderer/RecordCommands/styles.js +32 -0
  235. package/dist/components/GridCellRenderer/RecordCommands/styles.js.map +1 -0
  236. package/dist/components/GridCellRenderer/interfaces.d.ts +42 -54
  237. package/dist/components/GridCellRenderer/styles.d.ts +60 -34
  238. package/dist/components/GridCellRenderer/styles.js +77 -69
  239. package/dist/components/GridCellRenderer/styles.js.map +1 -1
  240. package/dist/components/GridCellRenderer/translations.d.ts +1 -1
  241. package/dist/components/GridCellRenderer/translations.js +32 -30
  242. package/dist/components/GridCellRenderer/translations.js.map +1 -1
  243. package/dist/components/GridCellRenderer/useComponentProps.d.ts +6 -0
  244. package/dist/components/GridCellRenderer/useComponentProps.js +10 -0
  245. package/dist/components/GridCellRenderer/useComponentProps.js.map +1 -0
  246. package/dist/components/Lookup/Lookup.js +1 -1
  247. package/dist/components/Lookup/Lookup.js.map +1 -1
  248. package/dist/components/Lookup/hooks/useFetchXml.d.ts +0 -1
  249. package/dist/components/Lookup/hooks/useLookup.d.ts +0 -1
  250. package/dist/components/Lookup/hooks/useLookup.js +2 -2
  251. package/dist/components/Lookup/hooks/useLookup.js.map +1 -1
  252. package/dist/components/Lookup/interfaces.d.ts +0 -1
  253. package/dist/components/MultiSelectOptionSet/MultiSelectOptionSet.js +2 -2
  254. package/dist/components/MultiSelectOptionSet/MultiSelectOptionSet.js.map +1 -1
  255. package/dist/components/NestedControlRenderer/NestedControl.d.ts +0 -3
  256. package/dist/components/NestedControlRenderer/NestedControl.js +2 -5
  257. package/dist/components/NestedControlRenderer/NestedControl.js.map +1 -1
  258. package/dist/components/NestedControlRenderer/NestedControlRenderer.js +6 -11
  259. package/dist/components/NestedControlRenderer/NestedControlRenderer.js.map +1 -1
  260. package/dist/components/NestedControlRenderer/interfaces.d.ts +0 -4
  261. package/dist/components/NestedControlRenderer/properties/FileProperty.js +1 -1
  262. package/dist/components/NestedControlRenderer/properties/FileProperty.js.map +1 -1
  263. package/dist/components/NestedControlRenderer/properties/Property.d.ts +0 -1
  264. package/dist/components/OptionSet/OptionSet.js +4 -5
  265. package/dist/components/OptionSet/OptionSet.js.map +1 -1
  266. package/dist/components/OptionSet/shared.d.ts +0 -1
  267. package/dist/components/TextField/TextField.js +1 -1
  268. package/dist/components/TextField/TextField.js.map +1 -1
  269. package/dist/components/index.js +3 -1
  270. package/dist/components/index.js.map +1 -1
  271. package/dist/hooks/useControl.d.ts +0 -1
  272. package/dist/hooks/useControl.js +0 -1
  273. package/dist/hooks/useControl.js.map +1 -1
  274. package/dist/hooks/useControlSizing.d.ts +0 -1
  275. package/dist/hooks/useInputBasedControl.js +1 -2
  276. package/dist/hooks/useInputBasedControl.js.map +1 -1
  277. package/dist/index.d.ts +299 -163
  278. package/dist/index.js +3 -1
  279. package/dist/index.js.map +1 -1
  280. package/dist/interfaces/context.d.ts +0 -1
  281. package/dist/interfaces/property.d.ts +1 -2
  282. package/dist/utils/BaseControls.d.ts +1 -2
  283. package/dist/utils/BaseControls.js +1 -5
  284. package/dist/utils/BaseControls.js.map +1 -1
  285. package/dist/utils/dataset/adapters/DatasetAdapter.d.ts +0 -1
  286. package/dist/utils/dataset/adapters/VirtualDatasetAdapter.d.ts +16 -13
  287. package/dist/utils/dataset/adapters/VirtualDatasetAdapter.js +72 -27
  288. package/dist/utils/dataset/adapters/VirtualDatasetAdapter.js.map +1 -1
  289. package/dist/utils/theme/ControlTheme.d.ts +0 -1
  290. package/dist/utils/theme/components/ThemeWrapper.d.ts +1 -2
  291. package/dist/utils/theme/components/ThemeWrapper.js.map +1 -1
  292. package/dist/utils/theme/hooks/useControlTheme.js +1 -2
  293. package/dist/utils/theme/hooks/useControlTheme.js.map +1 -1
  294. package/package.json +5 -9
  295. package/dist/components/DatasetControl/DatasetControlModel.d.ts +0 -37
  296. package/dist/components/DatasetControl/DatasetControlModel.js +0 -110
  297. package/dist/components/DatasetControl/DatasetControlModel.js.map +0 -1
  298. package/dist/components/DatasetControl/Filtering/DatasetColumnFiltering.d.ts +0 -3
  299. package/dist/components/DatasetControl/Filtering/DatasetColumnFiltering.js +0 -166
  300. package/dist/components/DatasetControl/Filtering/DatasetColumnFiltering.js.map +0 -1
  301. package/dist/components/DatasetControl/Filtering/DatasetColumnFilteringModel.d.ts +0 -16
  302. package/dist/components/DatasetControl/Filtering/DatasetColumnFilteringModel.js +0 -59
  303. package/dist/components/DatasetControl/Filtering/DatasetColumnFilteringModel.js.map +0 -1
  304. package/dist/components/DatasetControl/Filtering/interfaces.d.ts +0 -32
  305. package/dist/components/DatasetControl/Filtering/styles.d.ts +0 -16
  306. package/dist/components/DatasetControl/Filtering/styles.js +0 -23
  307. package/dist/components/DatasetControl/Filtering/styles.js.map +0 -1
  308. package/dist/components/DatasetControl/Filtering/translations.d.ts +0 -154
  309. package/dist/components/DatasetControl/Filtering/translations.js +0 -43
  310. package/dist/components/DatasetControl/Filtering/translations.js.map +0 -1
  311. package/dist/components/DatasetControl/Header/Header.d.ts +0 -5
  312. package/dist/components/DatasetControl/Header/Header.js +0 -89
  313. package/dist/components/DatasetControl/Header/Header.js.map +0 -1
  314. package/dist/components/DatasetControl/Header/styles.d.ts +0 -22
  315. package/dist/components/DatasetControl/Header/styles.js +0 -29
  316. package/dist/components/DatasetControl/Header/styles.js.map +0 -1
  317. package/dist/components/DatasetControl/Pagination/Pagination.d.ts +0 -5
  318. package/dist/components/DatasetControl/Pagination/Pagination.js +0 -91
  319. package/dist/components/DatasetControl/Pagination/Pagination.js.map +0 -1
  320. package/dist/components/DatasetControl/Pagination/PaginationModel.d.ts +0 -10
  321. package/dist/components/DatasetControl/Pagination/PaginationModel.js +0 -45
  322. package/dist/components/DatasetControl/Pagination/PaginationModel.js.map +0 -1
  323. package/dist/components/DatasetControl/Pagination/styles.d.ts +0 -23
  324. package/dist/components/DatasetControl/Pagination/styles.js +0 -29
  325. package/dist/components/DatasetControl/Pagination/styles.js.map +0 -1
  326. package/dist/components/DatasetControl/useModel.d.ts +0 -4
  327. package/dist/components/DatasetControl/useModel.js +0 -9
  328. package/dist/components/DatasetControl/useModel.js.map +0 -1
  329. package/dist/components/Grid/cells/cell/Cell.js +0 -302
  330. package/dist/components/Grid/cells/cell/Cell.js.map +0 -1
  331. package/dist/components/Grid/cells/cell/content/CellContent.js.map +0 -1
  332. package/dist/components/Grid/cells/cell/content/styles.js.map +0 -1
  333. package/dist/components/Grid/cells/cell/notifications/Notifications.js.map +0 -1
  334. package/dist/components/Grid/cells/cell/notifications/styles.js.map +0 -1
  335. package/dist/components/Grid/cells/cell/styles.js +0 -78
  336. package/dist/components/Grid/cells/cell/styles.js.map +0 -1
  337. package/dist/components/Grid/column-headers/column-header/ColumnHeader.js +0 -83
  338. package/dist/components/Grid/column-headers/column-header/ColumnHeader.js.map +0 -1
  339. package/dist/components/Grid/column-headers/column-header/ColumnHeaderContextualMenu.js +0 -115
  340. package/dist/components/Grid/column-headers/column-header/ColumnHeaderContextualMenu.js.map +0 -1
  341. package/dist/components/Grid/column-headers/column-header/FilterCallout.js +0 -103
  342. package/dist/components/Grid/column-headers/column-header/FilterCallout.js.map +0 -1
  343. package/dist/components/Grid/column-headers/column-header/styles.d.ts +0 -84
  344. package/dist/components/Grid/column-headers/column-header/styles.js.map +0 -1
  345. package/dist/components/Grid/column-headers/record-selection-checkbox/RecordSelectionCheckbox.d.ts +0 -2
  346. package/dist/components/Grid/column-headers/record-selection-checkbox/RecordSelectionCheckbox.js +0 -50
  347. package/dist/components/Grid/column-headers/record-selection-checkbox/RecordSelectionCheckbox.js.map +0 -1
  348. package/dist/components/Grid/column-headers/record-selection-checkbox/styles.js.map +0 -1
  349. package/dist/components/Grid/errors/FullWidthCellRendererError/FullWidthCellRendererError.d.ts +0 -6
  350. package/dist/components/Grid/errors/FullWidthCellRendererError/FullWidthCellRendererError.js +0 -15
  351. package/dist/components/Grid/errors/FullWidthCellRendererError/FullWidthCellRendererError.js.map +0 -1
  352. package/dist/components/Grid/errors/FullWidthCellRendererError/styles.d.ts +0 -6
  353. package/dist/components/Grid/errors/FullWidthCellRendererError/styles.js +0 -13
  354. package/dist/components/Grid/errors/FullWidthCellRendererError/styles.js.map +0 -1
  355. package/dist/components/Grid/grid/Grid.js +0 -64
  356. package/dist/components/Grid/grid/Grid.js.map +0 -1
  357. package/dist/components/Grid/grid/GridContext.d.ts +0 -3
  358. package/dist/components/Grid/grid/GridContext.js.map +0 -1
  359. package/dist/components/Grid/grid/GridModel.d.ts +0 -118
  360. package/dist/components/Grid/grid/GridModel.js +0 -787
  361. package/dist/components/Grid/grid/GridModel.js.map +0 -1
  362. package/dist/components/Grid/grid/ValueComparator.js.map +0 -1
  363. package/dist/components/Grid/grid/ag-grid/AgGridContext.js.map +0 -1
  364. package/dist/components/Grid/grid/ag-grid/AgGridModel.d.ts +0 -88
  365. package/dist/components/Grid/grid/ag-grid/AgGridModel.js +0 -565
  366. package/dist/components/Grid/grid/ag-grid/AgGridModel.js.map +0 -1
  367. package/dist/components/Grid/grid/ag-grid/ServerSideDatasource.d.ts +0 -7
  368. package/dist/components/Grid/grid/ag-grid/ServerSideDatasource.js +0 -38
  369. package/dist/components/Grid/grid/ag-grid/ServerSideDatasource.js.map +0 -1
  370. package/dist/components/Grid/grid/ag-grid/useAgGridInstance.d.ts +0 -2
  371. package/dist/components/Grid/grid/ag-grid/useAgGridInstance.js +0 -9
  372. package/dist/components/Grid/grid/ag-grid/useAgGridInstance.js.map +0 -1
  373. package/dist/components/Grid/grid/styles.js.map +0 -1
  374. package/dist/components/Grid/grid/useGridInstance.d.ts +0 -2
  375. package/dist/components/Grid/grid/useGridInstance.js.map +0 -1
  376. package/dist/components/Grid/loading/full-row/FullRowLoading.d.ts +0 -3
  377. package/dist/components/Grid/loading/full-row/FullRowLoading.js +0 -33
  378. package/dist/components/Grid/loading/full-row/FullRowLoading.js.map +0 -1
  379. package/dist/components/Grid/loading/full-row/styles.d.ts +0 -9
  380. package/dist/components/Grid/loading/full-row/styles.js +0 -16
  381. package/dist/components/Grid/loading/full-row/styles.js.map +0 -1
  382. package/dist/components/Grid/overlays/empty-records/EmptyRecordsOverlay.js +0 -13
  383. package/dist/components/Grid/overlays/empty-records/EmptyRecordsOverlay.js.map +0 -1
  384. package/dist/components/Grid/overlays/empty-records/styles.js.map +0 -1
  385. package/dist/components/Grid/overlays/loading/LoadingOverlay.js.map +0 -1
  386. package/dist/components/GridCellRenderer/GridCellRendererModel.d.ts +0 -52
  387. package/dist/components/GridCellRenderer/GridCellRendererModel.js +0 -211
  388. package/dist/components/GridCellRenderer/GridCellRendererModel.js.map +0 -1
  389. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/ColorfulOptionSetValueRenderer.d.ts +0 -10
  390. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/ColorfulOptionSetValueRenderer.js +0 -53
  391. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/ColorfulOptionSetValueRenderer.js.map +0 -1
  392. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/styles.d.ts +0 -20
  393. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/styles.js +0 -29
  394. package/dist/components/GridCellRenderer/ValueRenderer/ColorfulOptionSetValueRenderer/styles.js.map +0 -1
  395. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/FileRenderer.d.ts +0 -7
  396. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/FileRenderer.js +0 -76
  397. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/FileRenderer.js.map +0 -1
  398. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/styles.d.ts +0 -18
  399. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/styles.js +0 -25
  400. package/dist/components/GridCellRenderer/ValueRenderer/FileRenderer/styles.js.map +0 -1
  401. package/dist/components/GridCellRenderer/ValueRenderer/ValueRenderer.d.ts +0 -3
  402. package/dist/components/GridCellRenderer/ValueRenderer/ValueRenderer.js +0 -52
  403. package/dist/components/GridCellRenderer/ValueRenderer/ValueRenderer.js.map +0 -1
  404. package/dist/components/GridCellRenderer/ValueRenderer/styles.d.ts +0 -1666
  405. package/dist/components/GridCellRenderer/ValueRenderer/styles.js +0 -31
  406. package/dist/components/GridCellRenderer/ValueRenderer/styles.js.map +0 -1
  407. package/dist/components/GridCellRenderer/properties/Email.d.ts +0 -5
  408. package/dist/components/GridCellRenderer/properties/Email.js +0 -15
  409. package/dist/components/GridCellRenderer/properties/Email.js.map +0 -1
  410. package/dist/components/GridCellRenderer/properties/File.d.ts +0 -20
  411. package/dist/components/GridCellRenderer/properties/File.js +0 -99
  412. package/dist/components/GridCellRenderer/properties/File.js.map +0 -1
  413. package/dist/components/GridCellRenderer/properties/Image.d.ts +0 -4
  414. package/dist/components/GridCellRenderer/properties/Image.js +0 -15
  415. package/dist/components/GridCellRenderer/properties/Image.js.map +0 -1
  416. package/dist/components/GridCellRenderer/properties/Lookup.d.ts +0 -6
  417. package/dist/components/GridCellRenderer/properties/Lookup.js +0 -19
  418. package/dist/components/GridCellRenderer/properties/Lookup.js.map +0 -1
  419. package/dist/components/GridCellRenderer/properties/MultiSelectOptionSet.d.ts +0 -6
  420. package/dist/components/GridCellRenderer/properties/MultiSelectOptionSet.js +0 -11
  421. package/dist/components/GridCellRenderer/properties/MultiSelectOptionSet.js.map +0 -1
  422. package/dist/components/GridCellRenderer/properties/MultilineText.d.ts +0 -4
  423. package/dist/components/GridCellRenderer/properties/MultilineText.js +0 -10
  424. package/dist/components/GridCellRenderer/properties/MultilineText.js.map +0 -1
  425. package/dist/components/GridCellRenderer/properties/OptionSet.d.ts +0 -6
  426. package/dist/components/GridCellRenderer/properties/OptionSet.js +0 -11
  427. package/dist/components/GridCellRenderer/properties/OptionSet.js.map +0 -1
  428. package/dist/components/GridCellRenderer/properties/OptionSetBase.d.ts +0 -8
  429. package/dist/components/GridCellRenderer/properties/OptionSetBase.js +0 -19
  430. package/dist/components/GridCellRenderer/properties/OptionSetBase.js.map +0 -1
  431. package/dist/components/GridCellRenderer/properties/Phone.d.ts +0 -9
  432. package/dist/components/GridCellRenderer/properties/Phone.js +0 -15
  433. package/dist/components/GridCellRenderer/properties/Phone.js.map +0 -1
  434. package/dist/components/GridCellRenderer/properties/Property.d.ts +0 -20
  435. package/dist/components/GridCellRenderer/properties/Property.js +0 -54
  436. package/dist/components/GridCellRenderer/properties/Property.js.map +0 -1
  437. package/dist/components/GridCellRenderer/properties/TwoOptions.d.ts +0 -6
  438. package/dist/components/GridCellRenderer/properties/TwoOptions.js +0 -11
  439. package/dist/components/GridCellRenderer/properties/TwoOptions.js.map +0 -1
  440. package/dist/components/GridCellRenderer/properties/Url.d.ts +0 -5
  441. package/dist/components/GridCellRenderer/properties/Url.js +0 -15
  442. package/dist/components/GridCellRenderer/properties/Url.js.map +0 -1
  443. package/dist/components/GridCellRenderer/useModel.d.ts +0 -4
  444. package/dist/components/GridCellRenderer/useModel.js +0 -9
  445. package/dist/components/GridCellRenderer/useModel.js.map +0 -1
  446. package/dist/components/GridColumnHeader/GridColumnHeader.d.ts +0 -3
  447. package/dist/components/GridColumnHeader/GridColumnHeader.js +0 -134
  448. package/dist/components/GridColumnHeader/GridColumnHeader.js.map +0 -1
  449. package/dist/components/GridColumnHeader/GridColumnHeaderModel.d.ts +0 -26
  450. package/dist/components/GridColumnHeader/GridColumnHeaderModel.js +0 -87
  451. package/dist/components/GridColumnHeader/GridColumnHeaderModel.js.map +0 -1
  452. package/dist/components/GridColumnHeader/interfaces.d.ts +0 -45
  453. package/dist/components/GridColumnHeader/styles.d.ts +0 -37
  454. package/dist/components/GridColumnHeader/styles.js +0 -55
  455. package/dist/components/GridColumnHeader/styles.js.map +0 -1
  456. package/dist/components/GridColumnHeader/translations.d.ts +0 -26
  457. package/dist/components/GridColumnHeader/translations.js +0 -29
  458. package/dist/components/GridColumnHeader/translations.js.map +0 -1
  459. package/dist/components/Ribbon/Ribbon.d.ts +0 -3
  460. package/dist/components/Ribbon/Ribbon.js +0 -97
  461. package/dist/components/Ribbon/Ribbon.js.map +0 -1
  462. package/dist/components/Ribbon/RibbonModel.d.ts +0 -4
  463. package/dist/components/Ribbon/interfaces.d.ts +0 -19
  464. package/dist/components/Ribbon/styles.d.ts +0 -11
  465. package/dist/components/Ribbon/styles.js +0 -18
  466. package/dist/components/Ribbon/styles.js.map +0 -1
  467. package/dist/hooks/useEventEmitter.d.ts +0 -2
  468. package/dist/hooks/useEventEmitter.js +0 -18
  469. package/dist/hooks/useEventEmitter.js.map +0 -1
  470. /package/dist/components/Grid/{grid/GridContext.js → GridContext.js} +0 -0
  471. /package/dist/components/Grid/{overlays/empty-records/EmptyRecordsOverlay.d.ts → core/components/AgGrid/components/EmptyRecordsOverlay/EmptyRecords.d.ts} +0 -0
  472. /package/dist/components/Grid/{overlays/loading → core/components/AgGrid/components/LoadingOverlay}/LoadingOverlay.d.ts +0 -0
  473. /package/dist/components/Grid/{overlays/loading → core/components/AgGrid/components/LoadingOverlay}/LoadingOverlay.js +0 -0
  474. /package/dist/components/Grid/{cells/cell/content → core/components/Cell/CellContent}/styles.d.ts +0 -0
  475. /package/dist/components/Grid/{cells/cell/content → core/components/Cell/CellContent}/styles.js +0 -0
  476. /package/dist/components/Grid/{cells/cell/notifications → core/components/Cell/Notifications}/styles.d.ts +0 -0
  477. /package/dist/components/Grid/{column-headers/record-selection-checkbox → core/components/ColumnHeader/components/GlobalCheckbox}/styles.d.ts +0 -0
  478. /package/dist/components/Grid/{column-headers/record-selection-checkbox → core/components/ColumnHeader/components/GlobalCheckbox}/styles.js +0 -0
@@ -1,109 +1,292 @@
1
1
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
2
- import { useRef, useMemo } from 'react';
3
- import { GridCellRendererModel } from './GridCellRendererModel.js';
4
- import { ThemeProvider, Label, Icon, Text } from '@fluentui/react';
5
- import { getClassNames } from '@talxis/react-components';
6
- import { getGridCellRendererStyles } from './styles.js';
7
- import { ValueRenderer } from './ValueRenderer/ValueRenderer.js';
8
- import { ModelContext } from './useModel.js';
9
- import { gridGroupCellRendererTranslations } from './translations.js';
2
+ import { SpinnerSize, ThemeProvider, Label, Icon, Link, Image } from '@fluentui/react';
3
+ import { useMemo, useState } from 'react';
4
+ import { getGridCellLabelStyles, getDefaultContentRendererStyles } from './styles.js';
5
+ import { Client, Constants, DataTypes, Sanitizer, FetchXmlDataProvider, FileAttribute, Attribute } from '@talxis/client-libraries';
6
+ import { getDefaultGridRendererTranslations } from './translations.js';
7
+ import { ComponentPropsContext } from './useComponentProps.js';
8
+ import { getClassNames, Spinner } from '@talxis/react-components';
9
+ import { RecordCommands } from './RecordCommands/RecordCommands.js';
10
+ import { OptionSet } from './OptionSet/OptionSet.js';
10
11
  import { useControl } from '../../hooks/useControl.js';
12
+ import { DefaultContentRenderer } from './DefaultContentRenderer/DefaultContentRenderer.js';
11
13
 
14
+ const client = new Client();
12
15
  const GridCellRenderer = (props) => {
13
- const { theme, labels, className, sizing } = useControl('GridCellRenderer', props, gridGroupCellRendererTranslations);
14
- const propsRef = useRef(props);
15
- propsRef.current = props;
16
- const model = useMemo(() => {
17
- return new GridCellRendererModel({
18
- getProps: () => propsRef.current,
19
- getControlTheme: () => theme,
20
- labels: labels,
21
- });
22
- }, []);
23
- const styles = getGridCellRendererStyles(model, sizing.height);
16
+ const dataset = props.parameters.Dataset.raw;
17
+ const context = props.context;
18
+ const record = props.parameters.Record.raw;
19
+ const column = props.parameters.Column.raw;
20
+ const columnAlignment = props.parameters.ColumnAlignment.raw;
21
+ const dataType = props.parameters.value.type;
22
+ const { theme, sizing, labels } = useControl('GridCellLabel', props, getDefaultGridRendererTranslations());
23
+ const styles = useMemo(() => getGridCellLabelStyles(columnAlignment ?? 'left', dataType, sizing.height, theme), [columnAlignment, dataType, sizing.height, theme]);
24
+ const defaultContentRendererStyles = useMemo(() => getDefaultContentRendererStyles(theme, dataType, sizing.height), [theme, dataType, sizing.height]);
25
+ const value = props.parameters.value.raw;
26
+ const formattedValue = props.parameters.value.formatted;
27
+ const isNavigationEnabled = props.parameters.EnableNavigation.raw;
28
+ const prefixIcon = props.parameters.PrefixIcon?.raw;
29
+ const suffixIcon = props.parameters.SuffixIcon?.raw;
30
+ const aggregationFunction = props.parameters.AggregationFunction.raw;
24
31
  const onOverrideComponentProps = props.onOverrideComponentProps ?? ((props) => props);
32
+ const [downloadInProgress, setIsDownloadInProgress] = useState(false);
33
+ const getLinkProps = () => {
34
+ const props = {
35
+ title: formattedValue,
36
+ className: styles.link,
37
+ rel: 'noopener noreferrer',
38
+ children: formattedValue,
39
+ disabled: downloadInProgress
40
+ };
41
+ switch (dataType) {
42
+ case DataTypes.SingleLineEmail: {
43
+ props.href = `mailto:${value}`;
44
+ break;
45
+ }
46
+ case DataTypes.SingleLinePhone: {
47
+ props.href = `tel:${value}`;
48
+ break;
49
+ }
50
+ case DataTypes.SingleLineUrl: {
51
+ props.href = value;
52
+ props.target = '_blank';
53
+ break;
54
+ }
55
+ case DataTypes.Image:
56
+ case DataTypes.File: {
57
+ props.href = value.fileUrl;
58
+ props.download = value.fileName;
59
+ if (dataType === 'Image') {
60
+ props.title = value.fileName;
61
+ props.children = value.fileName;
62
+ }
63
+ if (shouldUsePortalDownload()) {
64
+ props.onClick = (e) => downloadPortalFile(e);
65
+ }
66
+ break;
67
+ }
68
+ case DataTypes.LookupCustomer:
69
+ case DataTypes.LookupOwner:
70
+ case DataTypes.LookupSimple:
71
+ case DataTypes.LookupRegarding: {
72
+ props.onClick = () => {
73
+ dataset.openDatasetItem(Sanitizer.Lookup.getEntityReference(value[0]));
74
+ };
75
+ break;
76
+ }
77
+ //primary navigation link
78
+ default: {
79
+ props.onClick = () => {
80
+ dataset.openDatasetItem(record.getNamedReference());
81
+ };
82
+ }
83
+ }
84
+ return props;
85
+ };
86
+ //matching could be improved
87
+ const getIconNameForMimeType = (mimeType) => {
88
+ if (!mimeType) {
89
+ return 'Attach';
90
+ }
91
+ const icon_classes = {
92
+ image: "Photo2",
93
+ audio: "MusicNote",
94
+ video: "Video",
95
+ "application/pdf": "PDF",
96
+ "application/msword": "WordDocument",
97
+ "application/vnd.ms-word": "WordDocument",
98
+ "application/vnd.oasis.opendocument.text": "WordDocument",
99
+ "application/vnd.openxmlformats-officedocument.wordprocessingml": "WordDocument",
100
+ "application/vnd.ms-excel": "ExcelDocument",
101
+ "application/vnd.openxmlformats-officedocument.spreadsheetml": "ExcelDocument",
102
+ "application/vnd.oasis.opendocument.spreadsheet": "ExcelDocument",
103
+ "application/vnd.ms-powerpoint": "PowerPointDocument",
104
+ "application/vnd.openxmlformats-officedocument.presentationml": "PowerPointDocument",
105
+ "application/vnd.oasis.opendocument.presentation": "PowerPointDocument",
106
+ "text/plain": "TextDocument",
107
+ "text/html": "FileCode",
108
+ "application/json": "FileCode",
109
+ // Archives
110
+ "application/gzip": "ZipFolder",
111
+ "application/zip": "ZipFolder"
112
+ };
113
+ if (icon_classes[mimeType]) {
114
+ return icon_classes[mimeType];
115
+ }
116
+ else if (icon_classes[mimeType.split("/")[0]]) {
117
+ return icon_classes[mimeType.split("/")[0]];
118
+ }
119
+ return 'Attach';
120
+ };
121
+ const renderContent = () => {
122
+ if (!formattedValue || aggregationFunction) {
123
+ return jsx(DefaultContentRenderer, {});
124
+ }
125
+ if (column.isPrimary && isNavigationEnabled) {
126
+ const linkProps = componentProps.onGetLinkProps(getLinkProps());
127
+ return jsx(Link, { ...linkProps, children: linkProps.children });
128
+ }
129
+ switch (dataType) {
130
+ case DataTypes.SingleLineEmail:
131
+ case DataTypes.SingleLinePhone:
132
+ case DataTypes.SingleLineUrl:
133
+ case DataTypes.LookupCustomer:
134
+ case DataTypes.LookupOwner:
135
+ case DataTypes.LookupSimple:
136
+ case DataTypes.LookupRegarding: {
137
+ if (isNavigationEnabled) {
138
+ const linkProps = componentProps.onGetLinkProps(getLinkProps());
139
+ return jsx(Link, { ...linkProps, children: linkProps.children });
140
+ }
141
+ return jsx(DefaultContentRenderer, {});
142
+ }
143
+ case DataTypes.OptionSet:
144
+ case DataTypes.MultiSelectOptionSet:
145
+ case DataTypes.TwoOptions: {
146
+ return jsx(OptionSet, { context: props.context, parameters: { ...props.parameters } });
147
+ }
148
+ case DataTypes.File:
149
+ case DataTypes.Image: {
150
+ return renderFileLink(dataType === 'Image');
151
+ }
152
+ }
153
+ return jsx(DefaultContentRenderer, {});
154
+ };
155
+ const shouldUsePortalDownload = () => {
156
+ const isFetchXmlDataProvider = dataset.getDataProvider() instanceof FetchXmlDataProvider;
157
+ //only use portal download if within portal, uses fetch xml provider and is not virtual column
158
+ if (client.isTalxisPortal() && isFetchXmlDataProvider && !column.name.endsWith('__virtual')) {
159
+ return true;
160
+ }
161
+ return false;
162
+ };
163
+ const renderFileLink = (isImage) => {
164
+ const linkProps = componentProps.onGetLinkProps(getLinkProps());
165
+ return (jsxs("div", { ...componentProps.fileProps.containerProps, children: [!downloadInProgress &&
166
+ jsxs(Fragment, { children: [!isImage &&
167
+ jsx(Icon, { ...componentProps.fileProps.iconProps, iconName: componentProps.fileProps.iconProps.onGetIconName(getIconNameForMimeType(value.mimeType)) }), isImage &&
168
+ jsx(Image, { ...componentProps.fileProps.imageProps, src: getThumbnailUrl() })] }), downloadInProgress &&
169
+ jsx(Spinner, { ...componentProps.fileProps.loadingProps.spinnerProps }), jsx(Link, { ...linkProps, children: linkProps.children })] }));
170
+ };
171
+ const getIconProps = (json) => {
172
+ if (!json) {
173
+ return undefined;
174
+ }
175
+ return JSON.parse(json);
176
+ };
177
+ const getThumbnailUrl = () => {
178
+ let src = value.thumbnailUrl;
179
+ if (client.isTalxisPortal()) {
180
+ src = `data:${value.mimeType};base64,${value.fileContent}`;
181
+ }
182
+ return componentProps.fileProps.imageProps.onGetSrc(src);
183
+ };
184
+ const downloadPortalFile = async (e) => {
185
+ e.preventDefault();
186
+ setIsDownloadInProgress(true);
187
+ const storage = new FileAttribute(context.webAPI);
188
+ let entityName = dataset.getTargetEntityType();
189
+ let recordId = record.getRecordId();
190
+ let attributeName = Attribute.GetNameFromAlias(column.name);
191
+ const entityAliasName = Attribute.GetLinkedEntityAlias(column.name);
192
+ if (entityAliasName) {
193
+ entityName = dataset.linking.getLinkedEntities().find(x => x.alias === entityAliasName).name;
194
+ const entityMetadata = await context.utils.getEntityMetadata(entityName, []);
195
+ recordId = record.getRawData()[`${entityAliasName}.${entityMetadata.PrimaryIdAttribute}`];
196
+ }
197
+ await storage.downloadFileFromAttribute({
198
+ entityName: entityName,
199
+ recordId: recordId,
200
+ fileAttribute: attributeName
201
+ }, true, undefined, {
202
+ fileName: value.fileName,
203
+ fileSizeInBytes: value.fileSize
204
+ });
205
+ setIsDownloadInProgress(false);
206
+ };
207
+ const getAggregationLabel = (aggregationFunction) => {
208
+ switch (aggregationFunction) {
209
+ case 'avg': {
210
+ return labels.avg();
211
+ }
212
+ case 'max': {
213
+ return labels.max();
214
+ }
215
+ case 'min': {
216
+ return labels.min();
217
+ }
218
+ case 'sum': {
219
+ return labels.sum();
220
+ }
221
+ case 'count': {
222
+ return labels.count();
223
+ }
224
+ case 'countcolumn': {
225
+ return labels.countcolumn();
226
+ }
227
+ }
228
+ };
25
229
  const componentProps = onOverrideComponentProps({
26
- onRender: (props, defaultRender) => defaultRender(props)
27
- });
28
- return (jsx(ModelContext.Provider, { value: model, children: componentProps.onRender({
29
- container: {
30
- className: getClassNames([className, styles.gridCellRendererRoot]),
31
- title: model.getFormattedValue().value,
32
- theme: theme
230
+ onGetLinkProps: (props) => props,
231
+ onGetOptionSetProps: (props) => props,
232
+ onGetRecordCommandsProps: (props) => props,
233
+ onRenderContent: (defaultRenderer) => defaultRenderer(),
234
+ onRenderAggregationLabel: (props, defaultRenderer) => defaultRenderer(props),
235
+ rootContainerProps: {
236
+ theme: theme,
237
+ className: styles.root
238
+ },
239
+ contentWrapperProps: {
240
+ className: styles.contentWrapper,
241
+ },
242
+ prefixSuffixWrapperProps: {
243
+ className: styles.prefixSuffixContentWrapper
244
+ },
245
+ textProps: {
246
+ className: getClassNames([defaultContentRendererStyles.content, !formattedValue ? defaultContentRendererStyles.placeholder : undefined]),
247
+ title: formattedValue,
248
+ children: formattedValue ?? '---'
249
+ },
250
+ fileProps: {
251
+ containerProps: {
252
+ className: styles.fileWrapper
33
253
  },
34
- onRenderContentContainer: (props, defaultRender) => defaultRender(props),
35
- onRenderAggregationLabel: (props, defaultRender) => defaultRender(props)
36
- }, (props) => {
37
- return (jsxs(ThemeProvider, { ...props.container, children: [props.onRenderAggregationLabel({
38
- children: model.getAggregationLabel(),
39
- className: styles.aggregationLabel
40
- }, (props) => {
41
- if (model.getAggregationLabel()) {
42
- return jsx(Label, { ...props });
43
- }
44
- return jsx(Fragment, {});
45
- }), props.onRenderContentContainer({
46
- container: {
47
- className: styles.contentContainer
48
- },
49
- onRenderPrefixIcon: (props, defaultRender) => defaultRender(props),
50
- onRenderSuffixIcon: (props, defaultRender) => defaultRender(props),
51
- onRenderInnerContainer: (props, defaultRender) => defaultRender(props),
52
- }, (props) => {
53
- return (jsxs("div", { ...props.container, children: [props.onRenderPrefixIcon({
54
- ...model.getPrefixIconProps(),
55
- styles: {
56
- root: styles.affixIconRoot
57
- }
58
- }, (props) => {
59
- if (model.getPrefixIconProps()) {
60
- return jsx(Icon, { ...props });
61
- }
62
- return jsx(Fragment, {});
63
- }), props.onRenderInnerContainer({
64
- container: {
65
- className: styles.innerContentContainer
66
- },
67
- onRenderValueContainer: (props, defaultRender) => defaultRender(props),
68
- onRenderAggregatedValue: (props, defaultRender) => defaultRender(props)
69
- }, (props) => {
70
- return (jsxs("div", { ...props.container, children: [props.onRenderValueContainer({
71
- container: {
72
- className: styles.valueContainer,
73
- },
74
- onRenderValue: (props, defaultRender) => defaultRender(props)
75
- }, (props) => {
76
- return (jsx("div", { ...props.container, children: props.onRenderValue({
77
- onRenderPlaceholder: (props, defaultRender) => defaultRender(props),
78
- onRenderText: (props, defaultRender) => defaultRender(props),
79
- onRenderLink: (props, defaultRender) => defaultRender(props),
80
- onRenderColorfulOptionSet: (props, defaultRender) => defaultRender(props),
81
- onRenderFile: (props, defaultRender) => defaultRender(props)
82
- }, (props) => {
83
- return (jsx(ValueRenderer, { ...props }));
84
- }) }));
85
- }), props.onRenderAggregatedValue({
86
- children: model.getFormattedAggregatedValue(),
87
- className: styles.aggregatedValue,
88
- }, (props) => {
89
- if (model.getFormattedAggregatedValue() !== null) {
90
- return jsx(Text, { ...props });
91
- }
92
- return jsx(Fragment, {});
93
- })] }));
94
- }), props.onRenderSuffixIcon({
95
- ...model.getSuffixIconProps(),
96
- styles: {
97
- root: styles.affixIconRoot
98
- }
99
- }, (props) => {
100
- if (model.getSuffixIconProps()) {
101
- return jsx(Icon, { ...props });
102
- }
103
- return jsx(Fragment, {});
104
- })] }));
105
- })] }));
106
- }) }));
254
+ iconProps: {
255
+ className: styles.fileIcon,
256
+ onGetIconName: (iconName) => iconName
257
+ },
258
+ imageProps: {
259
+ className: styles.fileImage,
260
+ onGetSrc: (src) => src
261
+ },
262
+ loadingProps: {
263
+ spinnerProps: {
264
+ size: SpinnerSize.small,
265
+ styles: {
266
+ circle: styles.loadingSpinnerCircle
267
+ }
268
+ }
269
+ }
270
+ }
271
+ });
272
+ const componentPropsProviderValue = useMemo(() => {
273
+ return {
274
+ current: componentProps
275
+ };
276
+ }, []);
277
+ componentPropsProviderValue.current = componentProps;
278
+ //this allows to add prefix/sufix icon without the need of cell customizer
279
+ //it can cover a lot of cases where otherwise custom PCF would be needed
280
+ const prefixIconProps = getIconProps(prefixIcon);
281
+ const suffixIconProps = getIconProps(suffixIcon);
282
+ return jsx(ComponentPropsContext.Provider, { value: componentPropsProviderValue, children: column.name === Constants.RIBBON_BUTTONS_COLUMN_NAME ?
283
+ jsx(RecordCommands, { applicationTheme: context.fluentDesignLanguage?.applicationTheme ?? theme, theme: theme, themeOverride: context.fluentDesignLanguage?.v8FluentOverrides, commands: props.parameters.RecordCommands?.raw ?? [], alignment: columnAlignment }) :
284
+ jsxs(ThemeProvider, { ...componentProps.rootContainerProps, children: [aggregationFunction &&
285
+ componentProps.onRenderAggregationLabel({
286
+ className: styles.aggregationLabel
287
+ }, (props) => {
288
+ return jsx(Label, { ...props, children: getAggregationLabel(aggregationFunction) });
289
+ }), jsxs("div", { ...componentProps.prefixSuffixWrapperProps, children: [prefixIconProps && jsx(Icon, { ...prefixIconProps, className: getClassNames([prefixIconProps.className, styles.icon]) }), jsx("div", { ...componentProps.contentWrapperProps, children: componentProps.contentWrapperProps.children ?? renderContent() }), suffixIconProps && jsx(Icon, { ...suffixIconProps, className: getClassNames([suffixIconProps.className, styles.icon]) })] })] }) });
107
290
  };
108
291
 
109
292
  export { GridCellRenderer };
@@ -1 +1 @@
1
- {"version":3,"file":"GridCellRenderer.js","sources":["../../../src/components/GridCellRenderer/GridCellRenderer.tsx"],"sourcesContent":["import { useMemo, useRef } from \"react\";\nimport { GridCellRendererModel } from \"./GridCellRendererModel\";\nimport { useControl } from \"../../hooks\";\nimport { Icon, Label, ThemeProvider, Text } from \"@fluentui/react\";\nimport { IGridCellRenderer } from \"./interfaces\";\nimport { getClassNames } from \"@talxis/react-components\";\nimport { getGridCellRendererStyles } from \"./styles\";\nimport { ValueRenderer } from \"./ValueRenderer/ValueRenderer\";\nimport { ModelContext } from \"./useModel\";\nimport { gridGroupCellRendererTranslations } from \"./translations\";\n\nexport const GridCellRenderer = (props: IGridCellRenderer) => {\n const { theme, labels, className, sizing } = useControl('GridCellRenderer', props, gridGroupCellRendererTranslations);\n const propsRef = useRef<IGridCellRenderer>(props);\n propsRef.current = props;\n const model = useMemo(() => {\n return new GridCellRendererModel({\n getProps: () => propsRef.current,\n getControlTheme: () => theme,\n labels: labels,\n });\n }, []);\n const styles = getGridCellRendererStyles(model, sizing.height);\n const onOverrideComponentProps = props.onOverrideComponentProps ?? ((props) => props);\n\n const componentProps = onOverrideComponentProps({\n onRender: (props, defaultRender) => defaultRender(props)\n })\n\n return (\n <ModelContext.Provider value={model}>\n {componentProps.onRender({\n container: {\n className: getClassNames([className, styles.gridCellRendererRoot]),\n title: model.getFormattedValue().value!,\n theme: theme\n },\n onRenderContentContainer: (props, defaultRender) => defaultRender(props),\n onRenderAggregationLabel: (props, defaultRender) => defaultRender(props)\n }, (props) => {\n return (\n <ThemeProvider {...props.container}>\n {props.onRenderAggregationLabel({\n children: model.getAggregationLabel(),\n className: styles.aggregationLabel\n }, (props) => {\n if (model.getAggregationLabel()) {\n return <Label {...props} />;\n }\n return <></>;\n })}\n {props.onRenderContentContainer({\n container: {\n className: styles.contentContainer\n },\n onRenderPrefixIcon: (props, defaultRender) => defaultRender(props),\n onRenderSuffixIcon: (props, defaultRender) => defaultRender(props),\n onRenderInnerContainer: (props, defaultRender) => defaultRender(props),\n }, (props) => {\n return (\n <div {...props.container}>\n {props.onRenderPrefixIcon({\n ...model.getPrefixIconProps(),\n styles: {\n root: styles.affixIconRoot\n }\n }, (props) => {\n if (model.getPrefixIconProps()) {\n return <Icon {...props} />;\n }\n return <></>;\n })}\n {props.onRenderInnerContainer({\n container: {\n className: styles.innerContentContainer\n },\n onRenderValueContainer: (props, defaultRender) => defaultRender(props),\n onRenderAggregatedValue: (props, defaultRender) => defaultRender(props)\n }, (props) => {\n return (\n <div {...props.container}>\n {props.onRenderValueContainer({\n container: {\n className: styles.valueContainer,\n },\n onRenderValue: (props, defaultRender) => defaultRender(props)\n }, (props) => {\n return (\n <div {...props.container}>\n {props.onRenderValue({\n onRenderPlaceholder: (props, defaultRender) => defaultRender(props),\n onRenderText: (props, defaultRender) => defaultRender(props),\n onRenderLink: (props, defaultRender) => defaultRender(props),\n onRenderColorfulOptionSet: (props, defaultRender) => defaultRender(props),\n onRenderFile: (props, defaultRender) => defaultRender(props)\n }, (props) => {\n return (\n <ValueRenderer {...props}\n />\n );\n })}\n </div>\n );\n })}\n {props.onRenderAggregatedValue({\n children: model.getFormattedAggregatedValue(),\n className: styles.aggregatedValue,\n }, (props) => {\n if (model.getFormattedAggregatedValue() !== null) {\n return <Text {...props} />\n }\n return <></>\n })}\n </div>\n );\n })}\n {props.onRenderSuffixIcon({\n ...model.getSuffixIconProps(),\n styles: {\n root: styles.affixIconRoot\n }\n }, (props) => {\n if (model.getSuffixIconProps()) {\n return <Icon {...props} />\n }\n return <></>\n })}\n </div>\n );\n })}\n </ThemeProvider>\n );\n })}\n </ModelContext.Provider>\n );\n};"],"names":["_jsx","_jsxs"],"mappings":"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"}
1
+ {"version":3,"file":"GridCellRenderer.js","sources":["../../../src/components/GridCellRenderer/GridCellRenderer.tsx"],"sourcesContent":["import { Icon, IIconProps, ILinkProps, Image, Label, Link, SpinnerSize, ThemeProvider } from \"@fluentui/react\";\nimport { useControl } from \"../../hooks\";\nimport { useMemo, useState } from \"react\";\nimport { getDefaultContentRendererStyles, getGridCellLabelStyles } from \"./styles\";\nimport { AggregationFunction, Attribute, Client, Constants, DataType, DataTypes, FetchXmlDataProvider, FileAttribute, IRecord, Sanitizer } from \"@talxis/client-libraries\";\nimport { OptionSet } from './OptionSet';\nimport { IGridCellRenderer } from \"./interfaces\";\nimport { getDefaultGridRendererTranslations } from \"./translations\";\nimport { ComponentPropsContext } from \"./useComponentProps\";\nimport { DefaultContentRenderer } from \"./DefaultContentRenderer\";\nimport { getClassNames, Spinner } from \"@talxis/react-components\";\nimport { RecordCommands } from \"./RecordCommands/RecordCommands\";\n\nconst client = new Client();\n\nexport const GridCellRenderer = (props: IGridCellRenderer) => {\n const dataset = props.parameters.Dataset.raw;\n const context = props.context;\n const record: IRecord = props.parameters.Record.raw;\n const column = props.parameters.Column.raw;\n const columnAlignment = props.parameters.ColumnAlignment.raw;\n const dataType: DataType = props.parameters.value.type as DataType;\n const { theme, sizing, labels } = useControl('GridCellLabel', props, getDefaultGridRendererTranslations());\n const styles = useMemo(() => getGridCellLabelStyles(columnAlignment ?? 'left', dataType, sizing.height!, theme), [columnAlignment, dataType, sizing.height, theme]);\n const defaultContentRendererStyles = useMemo(() => getDefaultContentRendererStyles(theme, dataType, sizing.height!), [theme, dataType, sizing.height]);\n const value = props.parameters.value.raw;\n const formattedValue: string = props.parameters.value.formatted;\n const isNavigationEnabled = props.parameters.EnableNavigation.raw;\n const prefixIcon = props.parameters.PrefixIcon?.raw\n const suffixIcon = props.parameters.SuffixIcon?.raw;\n const aggregationFunction = props.parameters.AggregationFunction.raw;\n const onOverrideComponentProps = props.onOverrideComponentProps ?? ((props) => props);\n const [downloadInProgress, setIsDownloadInProgress] = useState(false);\n\n const getLinkProps = (): ILinkProps => {\n const props: ILinkProps = {\n title: formattedValue,\n className: styles.link,\n rel: 'noopener noreferrer',\n children: formattedValue,\n disabled: downloadInProgress\n }\n switch (dataType) {\n case DataTypes.SingleLineEmail: {\n props.href = `mailto:${value}`;\n break;\n }\n case DataTypes.SingleLinePhone: {\n props.href = `tel:${value}`;\n break;\n }\n case DataTypes.SingleLineUrl: {\n props.href = value;\n props.target = '_blank';\n break;\n }\n case DataTypes.Image:\n case DataTypes.File: {\n props.href = value.fileUrl;\n props.download = value.fileName;\n if (dataType === 'Image') {\n props.title = value.fileName;\n props.children = value.fileName;\n }\n if (shouldUsePortalDownload()) {\n props.onClick = (e) => downloadPortalFile(e);\n }\n break;\n }\n case DataTypes.LookupCustomer:\n case DataTypes.LookupOwner:\n case DataTypes.LookupSimple:\n case DataTypes.LookupRegarding: {\n props.onClick = () => {\n dataset.openDatasetItem(Sanitizer.Lookup.getEntityReference(value[0]))\n }\n break;\n }\n //primary navigation link\n default: {\n props.onClick = () => {\n dataset.openDatasetItem(record.getNamedReference());\n }\n }\n }\n return props;\n }\n\n\n //matching could be improved\n const getIconNameForMimeType = (mimeType?: string) => {\n if (!mimeType) {\n return 'Attach';\n }\n const icon_classes: any = {\n image: \"Photo2\",\n audio: \"MusicNote\",\n video: \"Video\",\n \"application/pdf\": \"PDF\",\n \"application/msword\": \"WordDocument\",\n \"application/vnd.ms-word\": \"WordDocument\",\n \"application/vnd.oasis.opendocument.text\": \"WordDocument\",\n \"application/vnd.openxmlformats-officedocument.wordprocessingml\": \"WordDocument\",\n \"application/vnd.ms-excel\": \"ExcelDocument\",\n \"application/vnd.openxmlformats-officedocument.spreadsheetml\": \"ExcelDocument\",\n \"application/vnd.oasis.opendocument.spreadsheet\": \"ExcelDocument\",\n \"application/vnd.ms-powerpoint\": \"PowerPointDocument\",\n \"application/vnd.openxmlformats-officedocument.presentationml\": \"PowerPointDocument\",\n \"application/vnd.oasis.opendocument.presentation\": \"PowerPointDocument\",\n \"text/plain\": \"TextDocument\",\n \"text/html\": \"FileCode\",\n \"application/json\": \"FileCode\",\n // Archives\n \"application/gzip\": \"ZipFolder\",\n \"application/zip\": \"ZipFolder\"\n };\n\n if (icon_classes[mimeType]) {\n return icon_classes[mimeType];\n }\n else if (icon_classes[mimeType.split(\"/\")[0]]) {\n return icon_classes[mimeType.split(\"/\")[0]];\n }\n return 'Attach';\n }\n\n const renderContent = () => {\n if (!formattedValue || aggregationFunction) {\n return <DefaultContentRenderer />\n }\n if (column.isPrimary && isNavigationEnabled) {\n const linkProps = componentProps.onGetLinkProps(getLinkProps());\n return <Link {...linkProps}>{linkProps.children}</Link>\n }\n switch (dataType) {\n case DataTypes.SingleLineEmail:\n case DataTypes.SingleLinePhone:\n case DataTypes.SingleLineUrl:\n case DataTypes.LookupCustomer:\n case DataTypes.LookupOwner:\n case DataTypes.LookupSimple:\n case DataTypes.LookupRegarding: {\n if (isNavigationEnabled) {\n const linkProps = componentProps.onGetLinkProps(getLinkProps());\n return <Link {...linkProps}>{linkProps.children}</Link>\n }\n return <DefaultContentRenderer />\n }\n case DataTypes.OptionSet:\n case DataTypes.MultiSelectOptionSet:\n case DataTypes.TwoOptions: {\n return <OptionSet context={props.context} parameters={{ ...props.parameters }} />\n }\n case DataTypes.File:\n case DataTypes.Image: {\n return renderFileLink(dataType === 'Image');\n }\n }\n return <DefaultContentRenderer />\n }\n\n const shouldUsePortalDownload = () => {\n const isFetchXmlDataProvider = dataset.getDataProvider() instanceof FetchXmlDataProvider;\n //only use portal download if within portal, uses fetch xml provider and is not virtual column\n if (client.isTalxisPortal() && isFetchXmlDataProvider && !column.name.endsWith('__virtual')) {\n return true;\n }\n return false;\n }\n\n const renderFileLink = (isImage?: boolean) => {\n const linkProps = componentProps.onGetLinkProps(getLinkProps());\n return (<div {...componentProps.fileProps.containerProps}>\n {!downloadInProgress &&\n <>\n {!isImage &&\n <Icon {...componentProps.fileProps.iconProps} iconName={componentProps.fileProps.iconProps.onGetIconName(getIconNameForMimeType(value.mimeType))} />\n }\n {isImage &&\n <Image {...componentProps.fileProps.imageProps} src={getThumbnailUrl()} />\n }\n </>\n }\n {downloadInProgress &&\n <Spinner {...componentProps.fileProps.loadingProps.spinnerProps} />\n }\n <Link {...linkProps}>{linkProps.children}</Link>\n </div>);\n }\n\n const getIconProps = (json?: string | null): IIconProps | undefined => {\n if (!json) {\n return undefined;\n }\n return JSON.parse(json);\n }\n\n const getThumbnailUrl = () => {\n let src = value.thumbnailUrl;\n if (client.isTalxisPortal()) {\n src = `data:${value.mimeType};base64,${value.fileContent}`\n }\n return componentProps.fileProps.imageProps.onGetSrc(src);\n }\n\n const downloadPortalFile = async (e: React.MouseEvent<HTMLAnchorElement | HTMLElement | HTMLButtonElement, MouseEvent>) => {\n e.preventDefault();\n setIsDownloadInProgress(true);\n const storage = new FileAttribute(context.webAPI);\n let entityName = dataset.getTargetEntityType();\n let recordId = record.getRecordId();\n let attributeName = Attribute.GetNameFromAlias(column.name);\n const entityAliasName = Attribute.GetLinkedEntityAlias(column.name);\n\n if (entityAliasName) {\n entityName = dataset.linking.getLinkedEntities().find(x => x.alias === entityAliasName)!.name;\n const entityMetadata = await context.utils.getEntityMetadata(entityName, []);\n recordId = record.getRawData()![`${entityAliasName}.${entityMetadata.PrimaryIdAttribute}`];\n }\n await storage.downloadFileFromAttribute({\n entityName: entityName,\n recordId: recordId,\n fileAttribute: attributeName\n }, true, undefined, {\n fileName: value.fileName,\n fileSizeInBytes: value.fileSize\n })\n setIsDownloadInProgress(false);\n }\n\n const getAggregationLabel = (aggregationFunction: AggregationFunction) => {\n switch (aggregationFunction) {\n case 'avg': {\n return labels.avg();\n }\n case 'max': {\n return labels.max();\n }\n case 'min': {\n return labels.min();\n }\n case 'sum': {\n return labels.sum();\n }\n case 'count': {\n return labels.count()\n }\n case 'countcolumn': {\n return labels.countcolumn()\n }\n }\n }\n\n const componentProps = onOverrideComponentProps({\n onGetLinkProps: (props) => props,\n onGetOptionSetProps: (props) => props,\n onGetRecordCommandsProps: (props) => props,\n onRenderContent: (defaultRenderer) => defaultRenderer(),\n onRenderAggregationLabel: (props, defaultRenderer) => defaultRenderer(props),\n rootContainerProps: {\n theme: theme,\n className: styles.root\n },\n contentWrapperProps: {\n className: styles.contentWrapper,\n },\n prefixSuffixWrapperProps: {\n className: styles.prefixSuffixContentWrapper\n },\n textProps: {\n className: getClassNames([defaultContentRendererStyles.content, !formattedValue ? defaultContentRendererStyles.placeholder : undefined]),\n title: formattedValue,\n children: formattedValue ?? '---'\n },\n fileProps: {\n containerProps: {\n className: styles.fileWrapper\n },\n iconProps: {\n className: styles.fileIcon,\n onGetIconName: (iconName) => iconName\n },\n imageProps: {\n className: styles.fileImage,\n onGetSrc: (src) => src\n },\n loadingProps: {\n spinnerProps: {\n size: SpinnerSize.small,\n styles: {\n circle: styles.loadingSpinnerCircle\n }\n }\n }\n }\n });\n\n const componentPropsProviderValue = useMemo(() => {\n return {\n current: componentProps\n }\n }, []);\n componentPropsProviderValue.current = componentProps;\n\n //this allows to add prefix/sufix icon without the need of cell customizer\n //it can cover a lot of cases where otherwise custom PCF would be needed\n const prefixIconProps = getIconProps(prefixIcon);\n const suffixIconProps = getIconProps(suffixIcon)\n\n return <ComponentPropsContext.Provider value={componentPropsProviderValue}>\n {column.name === Constants.RIBBON_BUTTONS_COLUMN_NAME ?\n <RecordCommands\n applicationTheme={context.fluentDesignLanguage?.applicationTheme ?? theme}\n theme={theme}\n themeOverride={context.fluentDesignLanguage?.v8FluentOverrides}\n commands={props.parameters.RecordCommands?.raw ?? []}\n alignment={columnAlignment} /> :\n <ThemeProvider {...componentProps.rootContainerProps}>\n {aggregationFunction &&\n componentProps.onRenderAggregationLabel({\n className: styles.aggregationLabel\n }, (props) => {\n return <Label {...props}>{getAggregationLabel(aggregationFunction)}</Label>\n })\n }\n <div {...componentProps.prefixSuffixWrapperProps}>\n {prefixIconProps && <Icon {...prefixIconProps} className={getClassNames([prefixIconProps.className, styles.icon])} />}\n <div {...componentProps.contentWrapperProps}>\n {componentProps.contentWrapperProps.children ?? renderContent()}\n </div>\n {suffixIconProps && <Icon {...suffixIconProps} className={getClassNames([suffixIconProps.className, styles.icon])} />}\n </div>\n </ThemeProvider>}\n </ComponentPropsContext.Provider>\n}\n\n\n"],"names":["_jsx","_jsxs","_Fragment"],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ import { IOptionSet } from "../../OptionSet";
3
+ import { IMultiSelectOptionSet } from "../../MultiSelectOptionSet";
4
+ import { ITwoOptions } from "../../TwoOptions";
5
+ export declare const OptionSet: (props: IOptionSet | IMultiSelectOptionSet | ITwoOptions) => JSX.Element;
@@ -0,0 +1,75 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useTheme, merge, ThemeProvider, Text } from '@fluentui/react';
3
+ import { Theming, useThemeGenerator } from '@talxis/react-components';
4
+ import { useMemo } from 'react';
5
+ import { getOptionSetStyles, getColorfulOptionStyles } from './styles.js';
6
+ import { useComponentProps } from '../useComponentProps.js';
7
+ import { DefaultContentRenderer } from '../DefaultContentRenderer/DefaultContentRenderer.js';
8
+
9
+ const OptionSet = (props) => {
10
+ const dataType = props.parameters.value.type;
11
+ const options = props.parameters.value.attributes.Options;
12
+ const value = props.parameters.value.raw;
13
+ const styles = useMemo(() => getOptionSetStyles(), []);
14
+ const componentProps = useComponentProps();
15
+ const optionSetProps = componentProps.onGetOptionSetProps({
16
+ containerProps: {
17
+ className: styles.root
18
+ },
19
+ onGetOptionProps: (props) => props
20
+ });
21
+ const shouldRenderDefaultLabel = () => {
22
+ if (!props.parameters.EnableOptionSetColors?.raw || !options.some(option => option.Color)) {
23
+ return true;
24
+ }
25
+ return false;
26
+ };
27
+ const getSelectedOptions = () => {
28
+ let result = value ?? [];
29
+ switch (dataType) {
30
+ case 'OptionSet': {
31
+ result = [value];
32
+ break;
33
+ }
34
+ case 'TwoOptions': {
35
+ result = [+value];
36
+ break;
37
+ }
38
+ }
39
+ return options.filter(option => result?.includes(option.Value)) ?? [];
40
+ };
41
+ if (shouldRenderDefaultLabel()) {
42
+ return jsx(DefaultContentRenderer, {});
43
+ }
44
+ return (jsx("div", { ...optionSetProps.containerProps, children: getSelectedOptions().map(option => {
45
+ return jsx(ColorfulOption, { optionSetProps: optionSetProps, option: option, context: props.context }, option.Value);
46
+ }) }));
47
+ };
48
+ const ColorfulOption = (props) => {
49
+ const theme = useTheme();
50
+ const option = props.option;
51
+ const backgroundColor = option.Color ?? theme.palette.neutralLight;
52
+ const textColor = Theming.GetTextColorForBackground(backgroundColor);
53
+ const styles = useMemo(() => getColorfulOptionStyles(), []);
54
+ const optionTheme = useThemeGenerator(textColor, backgroundColor, textColor, merge({}, {
55
+ fonts: {
56
+ medium: {
57
+ fontWeight: 600
58
+ }
59
+ }
60
+ }, props.context.fluentDesignLanguage?.v8FluentOverrides));
61
+ const optionProps = props.optionSetProps.onGetOptionProps({
62
+ containerProps: {
63
+ className: styles.option,
64
+ theme: optionTheme
65
+ },
66
+ option: option,
67
+ textProps: {
68
+ children: option.Label
69
+ }
70
+ });
71
+ return (jsx(ThemeProvider, { ...optionProps.containerProps, children: jsx(Text, { ...optionProps.textProps, children: optionProps.textProps.children }) }));
72
+ };
73
+
74
+ export { OptionSet };
75
+ //# sourceMappingURL=OptionSet.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OptionSet.js","sources":["../../../../src/components/GridCellRenderer/OptionSet/OptionSet.tsx"],"sourcesContent":["import { DataType } from \"@talxis/client-libraries\";\nimport { IOptionSet } from \"../../OptionSet\"\nimport { IMultiSelectOptionSet } from \"../../MultiSelectOptionSet\";\nimport { ITwoOptions } from \"../../TwoOptions\";\nimport { PartialTheme, ThemeProvider, useTheme, merge } from \"@fluentui/react\";\nimport { Theming, useThemeGenerator } from \"@talxis/react-components\";\nimport { Text } from '@fluentui/react';\nimport { IContext } from \"../../../interfaces\";\nimport { useMemo } from \"react\";\nimport { getColorfulOptionStyles, getOptionSetStyles } from \"./styles\";\nimport { useComponentProps } from \"../useComponentProps\";\nimport { IOptionSetProps } from \"../interfaces\";\nimport { DefaultContentRenderer } from \"../DefaultContentRenderer\";\n\nexport const OptionSet = (props: IOptionSet | IMultiSelectOptionSet | ITwoOptions) => {\n const dataType: DataType = props.parameters.value.type as DataType;\n const options = props.parameters.value.attributes.Options;\n const value: any = props.parameters.value.raw;\n const styles = useMemo(() => getOptionSetStyles(), []);\n const componentProps = useComponentProps();\n\n const optionSetProps = componentProps.onGetOptionSetProps({\n containerProps: {\n className: styles.root\n },\n onGetOptionProps: (props) => props\n })\n\n const shouldRenderDefaultLabel = () => {\n if (!props.parameters.EnableOptionSetColors?.raw || !options.some(option => option.Color)) {\n return true;\n }\n return false;\n }\n\n const getSelectedOptions = () => {\n let result: any = value ?? [];\n switch (dataType) {\n case 'OptionSet': {\n result = [value]\n break;\n }\n case 'TwoOptions': {\n result = [+value];\n break;\n }\n }\n return options.filter(option => result?.includes(option.Value)) ?? [];\n }\n\n if (shouldRenderDefaultLabel()) {\n return <DefaultContentRenderer />\n }\n return (<div {...optionSetProps.containerProps}>\n {getSelectedOptions().map(option => {\n return <ColorfulOption\n key={option.Value}\n optionSetProps={optionSetProps}\n option={option}\n context={props.context} />\n })}\n </div>)\n}\n\nconst ColorfulOption = (props: {\n option: ComponentFramework.PropertyHelper.OptionMetadata,\n context: IContext;\n optionSetProps: IOptionSetProps\n}) => {\n const theme = useTheme();\n const option = props.option;\n const backgroundColor = option.Color ?? theme.palette.neutralLight;\n const textColor = Theming.GetTextColorForBackground(backgroundColor);\n const styles = useMemo(() => getColorfulOptionStyles(), []);\n const optionTheme = useThemeGenerator(textColor, backgroundColor, textColor, merge({}, {\n fonts: {\n medium: {\n fontWeight: 600\n }\n }\n } as PartialTheme, props.context.fluentDesignLanguage?.v8FluentOverrides as PartialTheme));\n\n const optionProps = props.optionSetProps.onGetOptionProps({\n containerProps: {\n className: styles.option,\n theme: optionTheme\n },\n option: option,\n textProps: {\n children: option.Label\n }\n })\n\n return (\n <ThemeProvider {...optionProps.containerProps}>\n <Text {...optionProps.textProps}>{optionProps.textProps.children}</Text>\n </ThemeProvider>\n )\n}"],"names":["_jsx"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export * from './OptionSet';
@@ -0,0 +1,2 @@
1
+ export { OptionSet } from './OptionSet.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,20 @@
1
+ export declare const getColorfulOptionStyles: () => import("@fluentui/react").IProcessedStyleSet<{
2
+ option: {
3
+ borderRadius: number;
4
+ padding: number;
5
+ paddingLeft: number;
6
+ paddingRight: number;
7
+ overflow: string;
8
+ textOverflow: string;
9
+ flexGrow: number;
10
+ };
11
+ }>;
12
+ export declare const getOptionSetStyles: () => import("@fluentui/react").IProcessedStyleSet<{
13
+ root: {
14
+ gap: number;
15
+ display: string;
16
+ overflow: string;
17
+ flexGrow: number;
18
+ textAlign: string;
19
+ };
20
+ }>;