@itwin/grouping-mapping-widget 0.35.3 → 0.36.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (302) hide show
  1. package/lib/cjs/GroupingMappingWidget.d.ts +28 -0
  2. package/lib/cjs/GroupingMappingWidget.js +71 -0
  3. package/lib/cjs/GroupingMappingWidget.js.map +1 -0
  4. package/lib/cjs/WidgetShell/GroupingMapping.js +4 -3
  5. package/lib/cjs/WidgetShell/GroupingMapping.js.map +1 -1
  6. package/lib/cjs/WidgetShell/GroupingMappingWidget.js +2 -1
  7. package/lib/cjs/WidgetShell/GroupingMappingWidget.js.map +1 -1
  8. package/lib/cjs/WidgetShell/Router/GroupingMappingRouter.js +6 -5
  9. package/lib/cjs/WidgetShell/Router/GroupingMappingRouter.js.map +1 -1
  10. package/lib/cjs/WidgetShell/WidgetHeader/WidgetHeader.js +3 -2
  11. package/lib/cjs/WidgetShell/WidgetHeader/WidgetHeader.js.map +1 -1
  12. package/lib/cjs/common/utils.js +12 -11
  13. package/lib/cjs/common/utils.js.map +1 -1
  14. package/lib/cjs/components/GroupingMappingContext.js +3 -2
  15. package/lib/cjs/components/GroupingMappingContext.js.map +1 -1
  16. package/lib/cjs/components/Groups/Editing/GroupAction.d.ts +2 -2
  17. package/lib/cjs/components/Groups/Editing/GroupAction.js +8 -7
  18. package/lib/cjs/components/Groups/Editing/GroupAction.js.map +1 -1
  19. package/lib/cjs/components/Groups/Editing/GroupDetails.js +4 -3
  20. package/lib/cjs/components/Groups/Editing/GroupDetails.js.map +1 -1
  21. package/lib/cjs/components/Groups/Editing/GroupDetailsActionPanel.js +3 -2
  22. package/lib/cjs/components/Groups/Editing/GroupDetailsActionPanel.js.map +1 -1
  23. package/lib/cjs/components/Groups/Editing/GroupDetailsStep.d.ts +2 -2
  24. package/lib/cjs/components/Groups/Editing/GroupDetailsStep.js +5 -4
  25. package/lib/cjs/components/Groups/Editing/GroupDetailsStep.js.map +1 -1
  26. package/lib/cjs/components/Groups/GroupMenuActions.js +5 -4
  27. package/lib/cjs/components/Groups/GroupMenuActions.js.map +1 -1
  28. package/lib/cjs/components/Groups/GroupOverlapProgressBar.js +2 -1
  29. package/lib/cjs/components/Groups/GroupOverlapProgressBar.js.map +1 -1
  30. package/lib/cjs/components/Groups/GroupsAddButton.js +2 -1
  31. package/lib/cjs/components/Groups/GroupsAddButton.js.map +1 -1
  32. package/lib/cjs/components/Groups/GroupsShowHideButtons.js +2 -1
  33. package/lib/cjs/components/Groups/GroupsShowHideButtons.js.map +1 -1
  34. package/lib/cjs/components/Groups/GroupsView.js +4 -3
  35. package/lib/cjs/components/Groups/GroupsView.js.map +1 -1
  36. package/lib/cjs/components/Groups/GroupsVisualization.js +9 -6
  37. package/lib/cjs/components/Groups/GroupsVisualization.js.map +1 -1
  38. package/lib/cjs/components/Groups/GroupsVisualizationActions.js +3 -2
  39. package/lib/cjs/components/Groups/GroupsVisualizationActions.js.map +1 -1
  40. package/lib/cjs/components/Groups/OverlappedElementsInformationPanel.js +6 -5
  41. package/lib/cjs/components/Groups/OverlappedElementsInformationPanel.js.map +1 -1
  42. package/lib/cjs/components/Groups/QueryBuilder/QueryBuilder.js +4 -3
  43. package/lib/cjs/components/Groups/QueryBuilder/QueryBuilder.js.map +1 -1
  44. package/lib/cjs/components/Groups/QueryBuilder/QueryBuilderActionPanel.js +2 -1
  45. package/lib/cjs/components/Groups/QueryBuilder/QueryBuilderActionPanel.js.map +1 -1
  46. package/lib/cjs/components/Groups/QueryBuilder/QueryBuilderCustomUI.js +2 -1
  47. package/lib/cjs/components/Groups/QueryBuilder/QueryBuilderCustomUI.js.map +1 -1
  48. package/lib/cjs/components/Groups/QueryBuilder/QueryBuilderStep.d.ts +2 -2
  49. package/lib/cjs/components/Groups/QueryBuilder/QueryBuilderStep.js +7 -6
  50. package/lib/cjs/components/Groups/QueryBuilder/QueryBuilderStep.js.map +1 -1
  51. package/lib/cjs/components/Groups/ToggleGroupVisibility.js +3 -2
  52. package/lib/cjs/components/Groups/ToggleGroupVisibility.js.map +1 -1
  53. package/lib/cjs/components/Groups/hooks/useVisualization.js +2 -1
  54. package/lib/cjs/components/Groups/hooks/useVisualization.js.map +1 -1
  55. package/lib/cjs/components/Mappings/Editing/MappingAction.d.ts +2 -2
  56. package/lib/cjs/components/Mappings/Editing/MappingAction.js +9 -8
  57. package/lib/cjs/components/Mappings/Editing/MappingAction.js.map +1 -1
  58. package/lib/cjs/components/Mappings/Extraction/ExtractionLogCustomFilter.js +17 -6
  59. package/lib/cjs/components/Mappings/Extraction/ExtractionLogCustomFilter.js.map +1 -1
  60. package/lib/cjs/components/Mappings/Extraction/ExtractionMessageModal.js +12 -11
  61. package/lib/cjs/components/Mappings/Extraction/ExtractionMessageModal.js.map +1 -1
  62. package/lib/cjs/components/Mappings/Extraction/ExtractionStates/QueuedExtractionState.js +2 -1
  63. package/lib/cjs/components/Mappings/Extraction/ExtractionStates/QueuedExtractionState.js.map +1 -1
  64. package/lib/cjs/components/Mappings/Extraction/ExtractionStates/RunningExtractionState.js +2 -1
  65. package/lib/cjs/components/Mappings/Extraction/ExtractionStates/RunningExtractionState.js.map +1 -1
  66. package/lib/cjs/components/Mappings/Extraction/ExtractionStates/StartingExtractionState.js +2 -1
  67. package/lib/cjs/components/Mappings/Extraction/ExtractionStates/StartingExtractionState.js.map +1 -1
  68. package/lib/cjs/components/Mappings/Extraction/ExtractionStates/TerminalExtractionState.js +2 -1
  69. package/lib/cjs/components/Mappings/Extraction/ExtractionStates/TerminalExtractionState.js.map +1 -1
  70. package/lib/cjs/components/Mappings/Import/ConfirmMappingsImport.d.ts +2 -2
  71. package/lib/cjs/components/Mappings/Import/ConfirmMappingsImport.js +20 -19
  72. package/lib/cjs/components/Mappings/Import/ConfirmMappingsImport.js.map +1 -1
  73. package/lib/cjs/components/Mappings/Import/MappingImportWizardModal.d.ts +2 -2
  74. package/lib/cjs/components/Mappings/Import/MappingImportWizardModal.js +19 -18
  75. package/lib/cjs/components/Mappings/Import/MappingImportWizardModal.js.map +1 -1
  76. package/lib/cjs/components/Mappings/Import/SelectIModel.d.ts +2 -2
  77. package/lib/cjs/components/Mappings/Import/SelectIModel.js +9 -8
  78. package/lib/cjs/components/Mappings/Import/SelectIModel.js.map +1 -1
  79. package/lib/cjs/components/Mappings/Import/SelectITwin.d.ts +2 -2
  80. package/lib/cjs/components/Mappings/Import/SelectITwin.js +14 -13
  81. package/lib/cjs/components/Mappings/Import/SelectITwin.js.map +1 -1
  82. package/lib/cjs/components/Mappings/Import/SelectMappings.d.ts +2 -2
  83. package/lib/cjs/components/Mappings/Import/SelectMappings.js +10 -9
  84. package/lib/cjs/components/Mappings/Import/SelectMappings.js.map +1 -1
  85. package/lib/cjs/components/Mappings/MappingViewActionGroup.js +5 -4
  86. package/lib/cjs/components/Mappings/MappingViewActionGroup.js.map +1 -1
  87. package/lib/cjs/components/Mappings/Mappings.d.ts +2 -2
  88. package/lib/cjs/components/Mappings/Mappings.js.map +1 -1
  89. package/lib/cjs/components/Mappings/MappingsView.d.ts +2 -2
  90. package/lib/cjs/components/Mappings/MappingsView.js +17 -15
  91. package/lib/cjs/components/Mappings/MappingsView.js.map +1 -1
  92. package/lib/cjs/components/Mappings/hooks/useFetchExtractionStatus.js +4 -3
  93. package/lib/cjs/components/Mappings/hooks/useFetchExtractionStatus.js.map +1 -1
  94. package/lib/cjs/components/Mappings/hooks/useMappingsOperations.js +2 -1
  95. package/lib/cjs/components/Mappings/hooks/useMappingsOperations.js.map +1 -1
  96. package/lib/cjs/components/Properties/CalculatedProperties/CalculatedPropertyAction.js +3 -2
  97. package/lib/cjs/components/Properties/CalculatedProperties/CalculatedPropertyAction.js.map +1 -1
  98. package/lib/cjs/components/Properties/CalculatedProperties/CalculatedPropertyActionWithVisuals.js +2 -1
  99. package/lib/cjs/components/Properties/CalculatedProperties/CalculatedPropertyActionWithVisuals.js.map +1 -1
  100. package/lib/cjs/components/Properties/CalculatedProperties/SharedCalculatedPropertyForms.js +3 -2
  101. package/lib/cjs/components/Properties/CalculatedProperties/SharedCalculatedPropertyForms.js.map +1 -1
  102. package/lib/cjs/components/Properties/CustomCalculations/CustomCalculationAction.js +4 -3
  103. package/lib/cjs/components/Properties/CustomCalculations/CustomCalculationAction.js.map +1 -1
  104. package/lib/cjs/components/Properties/GroupColorToggle.js +3 -2
  105. package/lib/cjs/components/Properties/GroupColorToggle.js.map +1 -1
  106. package/lib/cjs/components/Properties/GroupInformationPanel.js +3 -2
  107. package/lib/cjs/components/Properties/GroupInformationPanel.js.map +1 -1
  108. package/lib/cjs/components/Properties/GroupProperties/GroupPropertyAction.d.ts +1 -1
  109. package/lib/cjs/components/Properties/GroupProperties/GroupPropertyAction.js +28 -26
  110. package/lib/cjs/components/Properties/GroupProperties/GroupPropertyAction.js.map +1 -1
  111. package/lib/cjs/components/Properties/GroupProperties/GroupPropertyTable.js +5 -4
  112. package/lib/cjs/components/Properties/GroupProperties/GroupPropertyTable.js.map +1 -1
  113. package/lib/cjs/components/Properties/GroupProperties/GroupsPropertiesSelectionModal.js +12 -11
  114. package/lib/cjs/components/Properties/GroupProperties/GroupsPropertiesSelectionModal.js.map +1 -1
  115. package/lib/cjs/components/Properties/GroupProperties/SaveModal.js +5 -4
  116. package/lib/cjs/components/Properties/GroupProperties/SaveModal.js.map +1 -1
  117. package/lib/cjs/components/Properties/GroupProperties/SortableHorizontalTile.js +2 -1
  118. package/lib/cjs/components/Properties/GroupProperties/SortableHorizontalTile.js.map +1 -1
  119. package/lib/cjs/components/Properties/PropertyMenuWithVisualization.js +2 -1
  120. package/lib/cjs/components/Properties/PropertyMenuWithVisualization.js.map +1 -1
  121. package/lib/cjs/components/Properties/PropertyTable.js +2 -1
  122. package/lib/cjs/components/Properties/PropertyTable.js.map +1 -1
  123. package/lib/cjs/components/Properties/PropertyTableToolbar.js +3 -5
  124. package/lib/cjs/components/Properties/PropertyTableToolbar.js.map +1 -1
  125. package/lib/cjs/components/Properties/hooks/useValidator.d.ts +2 -2
  126. package/lib/cjs/components/Properties/hooks/useValidator.js +12 -9
  127. package/lib/cjs/components/Properties/hooks/useValidator.js.map +1 -1
  128. package/lib/cjs/components/SharedComponents/ActionPanel.js +3 -2
  129. package/lib/cjs/components/SharedComponents/ActionPanel.js.map +1 -1
  130. package/lib/cjs/components/SharedComponents/DeleteModal.js +5 -4
  131. package/lib/cjs/components/SharedComponents/DeleteModal.js.map +1 -1
  132. package/lib/cjs/components/SharedComponents/LoadingOverlay.js +3 -2
  133. package/lib/cjs/components/SharedComponents/LoadingOverlay.js.map +1 -1
  134. package/lib/cjs/components/customUI/DefaultGroupingUI.d.ts +1 -1
  135. package/lib/cjs/components/customUI/DefaultGroupingUI.js +7 -5
  136. package/lib/cjs/components/customUI/DefaultGroupingUI.js.map +1 -1
  137. package/lib/cjs/components/customUI/GroupQueryBuilderCustomUI.js +3 -2
  138. package/lib/cjs/components/customUI/GroupQueryBuilderCustomUI.js.map +1 -1
  139. package/lib/cjs/components/customUI/ManualGroupingCustomUI.js +5 -4
  140. package/lib/cjs/components/customUI/ManualGroupingCustomUI.js.map +1 -1
  141. package/lib/cjs/components/customUI/SearchGroupingCustomUI.js +5 -4
  142. package/lib/cjs/components/customUI/SearchGroupingCustomUI.js.map +1 -1
  143. package/lib/cjs/grouping-mapping-widget.d.ts +3 -0
  144. package/lib/cjs/grouping-mapping-widget.js +4 -1
  145. package/lib/cjs/grouping-mapping-widget.js.map +1 -1
  146. package/lib/cjs/test/GroupingMappingCustomUI.test.js +5 -5
  147. package/lib/cjs/test/GroupingMappingCustomUI.test.js.map +1 -1
  148. package/lib/cjs/test/setup.d.ts +2 -0
  149. package/lib/cjs/test/setup.js +10 -0
  150. package/lib/cjs/test/setup.js.map +1 -0
  151. package/lib/esm/GroupingMappingWidget.d.ts +28 -0
  152. package/lib/esm/GroupingMappingWidget.js +67 -0
  153. package/lib/esm/GroupingMappingWidget.js.map +1 -0
  154. package/lib/esm/WidgetShell/GroupingMapping.js +5 -4
  155. package/lib/esm/WidgetShell/GroupingMapping.js.map +1 -1
  156. package/lib/esm/WidgetShell/GroupingMappingWidget.js +2 -1
  157. package/lib/esm/WidgetShell/GroupingMappingWidget.js.map +1 -1
  158. package/lib/esm/WidgetShell/Router/GroupingMappingRouter.js +6 -5
  159. package/lib/esm/WidgetShell/Router/GroupingMappingRouter.js.map +1 -1
  160. package/lib/esm/WidgetShell/WidgetHeader/WidgetHeader.js +3 -2
  161. package/lib/esm/WidgetShell/WidgetHeader/WidgetHeader.js.map +1 -1
  162. package/lib/esm/common/utils.js +12 -11
  163. package/lib/esm/common/utils.js.map +1 -1
  164. package/lib/esm/components/GroupingMappingContext.js +3 -2
  165. package/lib/esm/components/GroupingMappingContext.js.map +1 -1
  166. package/lib/esm/components/Groups/Editing/GroupAction.d.ts +2 -2
  167. package/lib/esm/components/Groups/Editing/GroupAction.js +8 -7
  168. package/lib/esm/components/Groups/Editing/GroupAction.js.map +1 -1
  169. package/lib/esm/components/Groups/Editing/GroupDetails.js +4 -3
  170. package/lib/esm/components/Groups/Editing/GroupDetails.js.map +1 -1
  171. package/lib/esm/components/Groups/Editing/GroupDetailsActionPanel.js +3 -2
  172. package/lib/esm/components/Groups/Editing/GroupDetailsActionPanel.js.map +1 -1
  173. package/lib/esm/components/Groups/Editing/GroupDetailsStep.d.ts +2 -2
  174. package/lib/esm/components/Groups/Editing/GroupDetailsStep.js +5 -4
  175. package/lib/esm/components/Groups/Editing/GroupDetailsStep.js.map +1 -1
  176. package/lib/esm/components/Groups/GroupMenuActions.js +5 -4
  177. package/lib/esm/components/Groups/GroupMenuActions.js.map +1 -1
  178. package/lib/esm/components/Groups/GroupOverlapProgressBar.js +2 -1
  179. package/lib/esm/components/Groups/GroupOverlapProgressBar.js.map +1 -1
  180. package/lib/esm/components/Groups/GroupsAddButton.js +2 -1
  181. package/lib/esm/components/Groups/GroupsAddButton.js.map +1 -1
  182. package/lib/esm/components/Groups/GroupsShowHideButtons.js +2 -1
  183. package/lib/esm/components/Groups/GroupsShowHideButtons.js.map +1 -1
  184. package/lib/esm/components/Groups/GroupsView.js +4 -3
  185. package/lib/esm/components/Groups/GroupsView.js.map +1 -1
  186. package/lib/esm/components/Groups/GroupsVisualization.js +9 -6
  187. package/lib/esm/components/Groups/GroupsVisualization.js.map +1 -1
  188. package/lib/esm/components/Groups/GroupsVisualizationActions.js +3 -2
  189. package/lib/esm/components/Groups/GroupsVisualizationActions.js.map +1 -1
  190. package/lib/esm/components/Groups/OverlappedElementsInformationPanel.js +6 -5
  191. package/lib/esm/components/Groups/OverlappedElementsInformationPanel.js.map +1 -1
  192. package/lib/esm/components/Groups/QueryBuilder/QueryBuilder.js +4 -3
  193. package/lib/esm/components/Groups/QueryBuilder/QueryBuilder.js.map +1 -1
  194. package/lib/esm/components/Groups/QueryBuilder/QueryBuilderActionPanel.js +2 -1
  195. package/lib/esm/components/Groups/QueryBuilder/QueryBuilderActionPanel.js.map +1 -1
  196. package/lib/esm/components/Groups/QueryBuilder/QueryBuilderCustomUI.js +2 -1
  197. package/lib/esm/components/Groups/QueryBuilder/QueryBuilderCustomUI.js.map +1 -1
  198. package/lib/esm/components/Groups/QueryBuilder/QueryBuilderStep.d.ts +2 -2
  199. package/lib/esm/components/Groups/QueryBuilder/QueryBuilderStep.js +7 -6
  200. package/lib/esm/components/Groups/QueryBuilder/QueryBuilderStep.js.map +1 -1
  201. package/lib/esm/components/Groups/ToggleGroupVisibility.js +3 -2
  202. package/lib/esm/components/Groups/ToggleGroupVisibility.js.map +1 -1
  203. package/lib/esm/components/Groups/hooks/useVisualization.js +2 -1
  204. package/lib/esm/components/Groups/hooks/useVisualization.js.map +1 -1
  205. package/lib/esm/components/Mappings/Editing/MappingAction.d.ts +2 -2
  206. package/lib/esm/components/Mappings/Editing/MappingAction.js +9 -8
  207. package/lib/esm/components/Mappings/Editing/MappingAction.js.map +1 -1
  208. package/lib/esm/components/Mappings/Extraction/ExtractionLogCustomFilter.js +17 -6
  209. package/lib/esm/components/Mappings/Extraction/ExtractionLogCustomFilter.js.map +1 -1
  210. package/lib/esm/components/Mappings/Extraction/ExtractionMessageModal.js +12 -11
  211. package/lib/esm/components/Mappings/Extraction/ExtractionMessageModal.js.map +1 -1
  212. package/lib/esm/components/Mappings/Extraction/ExtractionStates/QueuedExtractionState.js +2 -1
  213. package/lib/esm/components/Mappings/Extraction/ExtractionStates/QueuedExtractionState.js.map +1 -1
  214. package/lib/esm/components/Mappings/Extraction/ExtractionStates/RunningExtractionState.js +2 -1
  215. package/lib/esm/components/Mappings/Extraction/ExtractionStates/RunningExtractionState.js.map +1 -1
  216. package/lib/esm/components/Mappings/Extraction/ExtractionStates/StartingExtractionState.js +2 -1
  217. package/lib/esm/components/Mappings/Extraction/ExtractionStates/StartingExtractionState.js.map +1 -1
  218. package/lib/esm/components/Mappings/Extraction/ExtractionStates/TerminalExtractionState.js +2 -1
  219. package/lib/esm/components/Mappings/Extraction/ExtractionStates/TerminalExtractionState.js.map +1 -1
  220. package/lib/esm/components/Mappings/Import/ConfirmMappingsImport.d.ts +2 -2
  221. package/lib/esm/components/Mappings/Import/ConfirmMappingsImport.js +20 -19
  222. package/lib/esm/components/Mappings/Import/ConfirmMappingsImport.js.map +1 -1
  223. package/lib/esm/components/Mappings/Import/MappingImportWizardModal.d.ts +2 -2
  224. package/lib/esm/components/Mappings/Import/MappingImportWizardModal.js +19 -18
  225. package/lib/esm/components/Mappings/Import/MappingImportWizardModal.js.map +1 -1
  226. package/lib/esm/components/Mappings/Import/SelectIModel.d.ts +2 -2
  227. package/lib/esm/components/Mappings/Import/SelectIModel.js +9 -8
  228. package/lib/esm/components/Mappings/Import/SelectIModel.js.map +1 -1
  229. package/lib/esm/components/Mappings/Import/SelectITwin.d.ts +2 -2
  230. package/lib/esm/components/Mappings/Import/SelectITwin.js +14 -13
  231. package/lib/esm/components/Mappings/Import/SelectITwin.js.map +1 -1
  232. package/lib/esm/components/Mappings/Import/SelectMappings.d.ts +2 -2
  233. package/lib/esm/components/Mappings/Import/SelectMappings.js +10 -9
  234. package/lib/esm/components/Mappings/Import/SelectMappings.js.map +1 -1
  235. package/lib/esm/components/Mappings/MappingViewActionGroup.js +5 -4
  236. package/lib/esm/components/Mappings/MappingViewActionGroup.js.map +1 -1
  237. package/lib/esm/components/Mappings/Mappings.d.ts +2 -2
  238. package/lib/esm/components/Mappings/Mappings.js.map +1 -1
  239. package/lib/esm/components/Mappings/MappingsView.d.ts +2 -2
  240. package/lib/esm/components/Mappings/MappingsView.js +15 -14
  241. package/lib/esm/components/Mappings/MappingsView.js.map +1 -1
  242. package/lib/esm/components/Mappings/hooks/useFetchExtractionStatus.js +4 -3
  243. package/lib/esm/components/Mappings/hooks/useFetchExtractionStatus.js.map +1 -1
  244. package/lib/esm/components/Mappings/hooks/useMappingsOperations.js +2 -1
  245. package/lib/esm/components/Mappings/hooks/useMappingsOperations.js.map +1 -1
  246. package/lib/esm/components/Properties/CalculatedProperties/CalculatedPropertyAction.js +3 -2
  247. package/lib/esm/components/Properties/CalculatedProperties/CalculatedPropertyAction.js.map +1 -1
  248. package/lib/esm/components/Properties/CalculatedProperties/CalculatedPropertyActionWithVisuals.js +2 -1
  249. package/lib/esm/components/Properties/CalculatedProperties/CalculatedPropertyActionWithVisuals.js.map +1 -1
  250. package/lib/esm/components/Properties/CalculatedProperties/SharedCalculatedPropertyForms.js +3 -2
  251. package/lib/esm/components/Properties/CalculatedProperties/SharedCalculatedPropertyForms.js.map +1 -1
  252. package/lib/esm/components/Properties/CustomCalculations/CustomCalculationAction.js +4 -3
  253. package/lib/esm/components/Properties/CustomCalculations/CustomCalculationAction.js.map +1 -1
  254. package/lib/esm/components/Properties/GroupColorToggle.js +3 -2
  255. package/lib/esm/components/Properties/GroupColorToggle.js.map +1 -1
  256. package/lib/esm/components/Properties/GroupInformationPanel.js +3 -2
  257. package/lib/esm/components/Properties/GroupInformationPanel.js.map +1 -1
  258. package/lib/esm/components/Properties/GroupProperties/GroupPropertyAction.d.ts +1 -1
  259. package/lib/esm/components/Properties/GroupProperties/GroupPropertyAction.js +26 -25
  260. package/lib/esm/components/Properties/GroupProperties/GroupPropertyAction.js.map +1 -1
  261. package/lib/esm/components/Properties/GroupProperties/GroupPropertyTable.js +5 -4
  262. package/lib/esm/components/Properties/GroupProperties/GroupPropertyTable.js.map +1 -1
  263. package/lib/esm/components/Properties/GroupProperties/GroupsPropertiesSelectionModal.js +12 -11
  264. package/lib/esm/components/Properties/GroupProperties/GroupsPropertiesSelectionModal.js.map +1 -1
  265. package/lib/esm/components/Properties/GroupProperties/SaveModal.js +5 -4
  266. package/lib/esm/components/Properties/GroupProperties/SaveModal.js.map +1 -1
  267. package/lib/esm/components/Properties/GroupProperties/SortableHorizontalTile.js +2 -1
  268. package/lib/esm/components/Properties/GroupProperties/SortableHorizontalTile.js.map +1 -1
  269. package/lib/esm/components/Properties/PropertyMenuWithVisualization.js +2 -1
  270. package/lib/esm/components/Properties/PropertyMenuWithVisualization.js.map +1 -1
  271. package/lib/esm/components/Properties/PropertyTable.js +2 -1
  272. package/lib/esm/components/Properties/PropertyTable.js.map +1 -1
  273. package/lib/esm/components/Properties/PropertyTableToolbar.js +3 -5
  274. package/lib/esm/components/Properties/PropertyTableToolbar.js.map +1 -1
  275. package/lib/esm/components/Properties/hooks/useValidator.d.ts +2 -2
  276. package/lib/esm/components/Properties/hooks/useValidator.js +9 -8
  277. package/lib/esm/components/Properties/hooks/useValidator.js.map +1 -1
  278. package/lib/esm/components/SharedComponents/ActionPanel.js +3 -2
  279. package/lib/esm/components/SharedComponents/ActionPanel.js.map +1 -1
  280. package/lib/esm/components/SharedComponents/DeleteModal.js +5 -4
  281. package/lib/esm/components/SharedComponents/DeleteModal.js.map +1 -1
  282. package/lib/esm/components/SharedComponents/LoadingOverlay.js +3 -2
  283. package/lib/esm/components/SharedComponents/LoadingOverlay.js.map +1 -1
  284. package/lib/esm/components/customUI/DefaultGroupingUI.d.ts +1 -1
  285. package/lib/esm/components/customUI/DefaultGroupingUI.js +5 -4
  286. package/lib/esm/components/customUI/DefaultGroupingUI.js.map +1 -1
  287. package/lib/esm/components/customUI/GroupQueryBuilderCustomUI.js +3 -2
  288. package/lib/esm/components/customUI/GroupQueryBuilderCustomUI.js.map +1 -1
  289. package/lib/esm/components/customUI/ManualGroupingCustomUI.js +5 -4
  290. package/lib/esm/components/customUI/ManualGroupingCustomUI.js.map +1 -1
  291. package/lib/esm/components/customUI/SearchGroupingCustomUI.js +5 -4
  292. package/lib/esm/components/customUI/SearchGroupingCustomUI.js.map +1 -1
  293. package/lib/esm/grouping-mapping-widget.d.ts +3 -0
  294. package/lib/esm/grouping-mapping-widget.js +2 -0
  295. package/lib/esm/grouping-mapping-widget.js.map +1 -1
  296. package/lib/esm/test/GroupingMappingCustomUI.test.js +5 -5
  297. package/lib/esm/test/GroupingMappingCustomUI.test.js.map +1 -1
  298. package/lib/esm/test/setup.d.ts +2 -0
  299. package/lib/esm/test/setup.js +8 -0
  300. package/lib/esm/test/setup.js.map +1 -0
  301. package/lib/public/locales/en/GroupingMappingWidget.json +220 -0
  302. package/package.json +4 -4
@@ -4,15 +4,16 @@
4
4
  *--------------------------------------------------------------------------------------------*/
5
5
  import { Button, LabeledInput, MiddleTextTruncation, ProgressLinear, Text } from "@itwin/itwinui-react";
6
6
  import React, { useEffect, useState } from "react";
7
+ import { GroupingMappingWidget } from "../../../GroupingMappingWidget";
7
8
  import "./ConfirmMappingsImport.scss";
8
9
  import { SvgStatusSuccessHollow } from "@itwin/itwinui-icons-react";
9
10
  import useValidator, { NAME_REQUIREMENTS } from "../../Properties/hooks/useValidator";
10
11
  import { useMappingClient } from "../../context/MappingClientContext";
11
12
  import { useGroupingMappingApiConfig } from "../../context/GroupingApiConfigContext";
12
13
  import { useMutation } from "@tanstack/react-query";
13
- const defaultDisplayStrings = {
14
- mappings: "Mappings",
15
- };
14
+ const getDefaultDisplayStrings = () => ({
15
+ mappings: GroupingMappingWidget.translate("mappings.mappings"),
16
+ });
16
17
  const ConfirmMappingImport = ({ selectedMappings, importing, setImporting, setSelectedMappings, backFn, onCancel, onFinish, displayStrings: userDisplayStrings, }) => {
17
18
  const { getAccessToken, iModelId } = useGroupingMappingApiConfig();
18
19
  const mappingClient = useMappingClient();
@@ -20,11 +21,11 @@ const ConfirmMappingImport = ({ selectedMappings, importing, setImporting, setSe
20
21
  const [currentlyImporting, setCurrentlyImporting] = useState("");
21
22
  const [validator, showValidationMessage] = useValidator();
22
23
  const [errored, setErrored] = useState(false);
23
- const displayStrings = React.useMemo(() => ({ ...defaultDisplayStrings, ...userDisplayStrings }), [userDisplayStrings]);
24
+ const displayStrings = React.useMemo(() => ({ ...getDefaultDisplayStrings(), ...userDisplayStrings }), [userDisplayStrings]);
24
25
  useEffect(() => {
25
26
  setSelectedMappings((selectedMappings) => selectedMappings.map((mapping) => ({
26
27
  ...mapping,
27
- mappingName: `${mapping.mappingName}_Copy`,
28
+ mappingName: GroupingMappingWidget.translate("import.copySuffix", { name: mapping.mappingName }),
28
29
  })));
29
30
  }, [setSelectedMappings]);
30
31
  const handleChange = (e, index) => {
@@ -68,17 +69,17 @@ const ConfirmMappingImport = ({ selectedMappings, importing, setImporting, setSe
68
69
  return (React.createElement(React.Fragment, null, importing ? (React.createElement("div", { className: "gmw-import-progress-container" },
69
70
  React.createElement("div", { className: "gmw-import-progress-bar" },
70
71
  React.createElement("div", { className: "gmw-import-progress-bar-description" }, !errored ? (importCount !== selectedMappings.length ? (React.createElement(React.Fragment, null,
71
- React.createElement(Text, { variant: "title" }, "Importing"),
72
- React.createElement(Text, null, `We are currently importing the ${displayStrings.mappings.toLocaleLowerCase()}.`))) : (React.createElement(React.Fragment, null,
73
- React.createElement(Text, { variant: "title" }, "Done!"),
74
- React.createElement(Text, null, `Your imported ${displayStrings.mappings.toLocaleLowerCase()} are ready.`)))) : (React.createElement(React.Fragment, null,
75
- React.createElement(Text, { variant: "title" }, "Error!"),
76
- React.createElement(Text, null, `Sorry, there was an error importing some or all ${displayStrings.mappings}.`)))),
72
+ React.createElement(Text, { variant: "title" }, GroupingMappingWidget.translate("import.importing")),
73
+ React.createElement(Text, null, GroupingMappingWidget.translate("import.currentlyImporting", { mappings: displayStrings.mappings.toLocaleLowerCase() })))) : (React.createElement(React.Fragment, null,
74
+ React.createElement(Text, { variant: "title" }, GroupingMappingWidget.translate("import.done")),
75
+ React.createElement(Text, null, GroupingMappingWidget.translate("import.importedReady", { mappings: displayStrings.mappings.toLocaleLowerCase() }))))) : (React.createElement(React.Fragment, null,
76
+ React.createElement(Text, { variant: "title" }, GroupingMappingWidget.translate("import.error")),
77
+ React.createElement(Text, null, GroupingMappingWidget.translate("import.importError", { mappings: displayStrings.mappings }))))),
77
78
  React.createElement(ProgressLinear, { value: (importCount / selectedMappings.length) * 100, labels: importCount === selectedMappings.length
78
- ? ["Import done!", React.createElement(SvgStatusSuccessHollow, { key: "0" })]
79
+ ? [GroupingMappingWidget.translate("import.importDone"), React.createElement(SvgStatusSuccessHollow, { key: "0" })]
79
80
  : [
80
81
  React.createElement(React.Fragment, null,
81
- React.createElement(Text, null, "Copying"),
82
+ React.createElement(Text, null, GroupingMappingWidget.translate("import.copying")),
82
83
  React.createElement(MiddleTextTruncation, { text: currentlyImporting })),
83
84
  `${importCount}/${selectedMappings.length}`,
84
85
  ], status: !errored ? (importCount === selectedMappings.length ? "positive" : undefined) : "negative" })),
@@ -88,13 +89,13 @@ const ConfirmMappingImport = ({ selectedMappings, importing, setImporting, setSe
88
89
  setImportCount(0);
89
90
  setCurrentlyImporting("");
90
91
  setErrored(false);
91
- } }, "Back"),
92
- React.createElement(Button, { styleType: "high-visibility", disabled: !errored && importCount !== selectedMappings.length, onClick: onFinish }, "Close")))) : (React.createElement("div", { className: "gmw-rename-confirm-container " },
92
+ } }, GroupingMappingWidget.translate("common.back")),
93
+ React.createElement(Button, { styleType: "high-visibility", disabled: !errored && importCount !== selectedMappings.length, onClick: onFinish }, GroupingMappingWidget.translate("common.close"))))) : (React.createElement("div", { className: "gmw-rename-confirm-container " },
93
94
  React.createElement("div", { className: "gmw-mapping-rename-container" },
94
95
  React.createElement("div", { className: "gmw-mapping-row-header-container" },
95
96
  React.createElement("div", { className: "gmw-mapping-row" },
96
97
  React.createElement(Text, { variant: "leading" }, displayStrings.mappings),
97
- React.createElement(Text, { variant: "leading" }, "Description"))),
98
+ React.createElement(Text, { variant: "leading" }, GroupingMappingWidget.translate("common.description")))),
98
99
  React.createElement("div", { className: "gmw-mapping-row-body" }, selectedMappings.map((mapping, index) => (React.createElement("div", { className: "gmw-mapping-row-container", key: mapping.id },
99
100
  React.createElement("div", { className: "gmw-mapping-row" },
100
101
  React.createElement(LabeledInput, { value: mapping.mappingName, name: `mapping_${mapping.id}`, required: true, onChange: (event) => {
@@ -109,9 +110,9 @@ const ConfirmMappingImport = ({ selectedMappings, importing, setImporting, setSe
109
110
  React.createElement("div", null, mapping.description)),
110
111
  React.createElement("div", { className: "gmw-border-div" })))))),
111
112
  React.createElement("div", { className: "gmw-import-action-panel" },
112
- React.createElement(Button, { onClick: backFn }, "Back"),
113
- React.createElement(Button, { styleType: "high-visibility", onClick: async () => onImport() }, "Import"),
114
- React.createElement(Button, { onClick: onCancel }, "Cancel"))))));
113
+ React.createElement(Button, { onClick: backFn }, GroupingMappingWidget.translate("common.back")),
114
+ React.createElement(Button, { styleType: "high-visibility", onClick: async () => onImport() }, GroupingMappingWidget.translate("common.import")),
115
+ React.createElement(Button, { onClick: onCancel }, GroupingMappingWidget.translate("common.cancel")))))));
115
116
  };
116
117
  export default ConfirmMappingImport;
117
118
  //# sourceMappingURL=ConfirmMappingsImport.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ConfirmMappingsImport.js","sourceRoot":"","sources":["../../../../../src/components/Mappings/Import/ConfirmMappingsImport.tsx"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\nimport { Button, LabeledInput, MiddleTextTruncation, ProgressLinear, Text } from \"@itwin/itwinui-react\";\nimport React, { useEffect, useState } from \"react\";\nimport type { IMappingTyped } from \"../Mappings\";\nimport \"./ConfirmMappingsImport.scss\";\nimport { SvgStatusSuccessHollow } from \"@itwin/itwinui-icons-react\";\nimport useValidator, { NAME_REQUIREMENTS } from \"../../Properties/hooks/useValidator\";\nimport { useMappingClient } from \"../../context/MappingClientContext\";\nimport { useGroupingMappingApiConfig } from \"../../context/GroupingApiConfigContext\";\nimport { useMutation } from \"@tanstack/react-query\";\n\nconst defaultDisplayStrings = {\n mappings: \"Mappings\",\n};\n\ninterface ConfirmMappingImportProps {\n selectedMappings: IMappingTyped[];\n importing: boolean;\n setImporting: React.Dispatch<React.SetStateAction<boolean>>;\n setSelectedMappings: React.Dispatch<React.SetStateAction<IMappingTyped[]>>;\n backFn: () => void;\n onCancel: () => void;\n onFinish: () => void;\n displayStrings?: Partial<typeof defaultDisplayStrings>;\n}\n\nconst ConfirmMappingImport = ({\n selectedMappings,\n importing,\n setImporting,\n setSelectedMappings,\n backFn,\n onCancel,\n onFinish,\n displayStrings: userDisplayStrings,\n}: ConfirmMappingImportProps) => {\n const { getAccessToken, iModelId } = useGroupingMappingApiConfig();\n const mappingClient = useMappingClient();\n const [importCount, setImportCount] = useState<number>(0);\n const [currentlyImporting, setCurrentlyImporting] = useState<string>(\"\");\n const [validator, showValidationMessage] = useValidator();\n const [errored, setErrored] = useState<boolean>(false);\n\n const displayStrings = React.useMemo(() => ({ ...defaultDisplayStrings, ...userDisplayStrings }), [userDisplayStrings]);\n\n useEffect(() => {\n setSelectedMappings((selectedMappings) =>\n selectedMappings.map((mapping) => ({\n ...mapping,\n mappingName: `${mapping.mappingName}_Copy`,\n })),\n );\n }, [setSelectedMappings]);\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>, index: number) => {\n const newState = [...selectedMappings];\n newState[index] = {\n ...newState[index],\n mappingName: e.target.value,\n };\n setSelectedMappings(newState);\n };\n\n const importMutation = useMutation({\n mutationFn: async (selectedMapping: IMappingTyped) => {\n const accessToken = await getAccessToken();\n await mappingClient.createMapping(accessToken, {\n iModelId,\n mappingName: selectedMapping.mappingName,\n sourceMappingId: selectedMapping.id,\n });\n },\n onMutate: async (selectedMapping: IMappingTyped) => {\n setCurrentlyImporting(selectedMapping.mappingName);\n },\n onSuccess: () => {\n setImportCount((count) => count + 1);\n },\n onError: () => {\n setErrored(true);\n },\n });\n\n const onImport = async () => {\n if (!validator.allValid()) {\n showValidationMessage(true);\n return;\n }\n setImporting(true);\n setImportCount(0);\n for (const mapping of selectedMappings) {\n await importMutation.mutateAsync(mapping);\n }\n };\n\n return (\n <>\n {importing ? (\n <div className=\"gmw-import-progress-container\">\n <div className=\"gmw-import-progress-bar\">\n <div className=\"gmw-import-progress-bar-description\">\n {!errored ? (\n importCount !== selectedMappings.length ? (\n <>\n <Text variant=\"title\">Importing</Text>\n <Text>{`We are currently importing the ${displayStrings.mappings.toLocaleLowerCase()}.`}</Text>\n </>\n ) : (\n <>\n <Text variant=\"title\">Done!</Text>\n <Text>{`Your imported ${displayStrings.mappings.toLocaleLowerCase()} are ready.`}</Text>\n </>\n )\n ) : (\n <>\n <Text variant=\"title\">Error!</Text>\n <Text>{`Sorry, there was an error importing some or all ${displayStrings.mappings}.`}</Text>\n </>\n )}\n </div>\n <ProgressLinear\n value={(importCount / selectedMappings.length) * 100}\n labels={\n importCount === selectedMappings.length\n ? [\"Import done!\", <SvgStatusSuccessHollow key=\"0\" />]\n : [\n <>\n <Text>Copying</Text>\n <MiddleTextTruncation text={currentlyImporting} />\n </>,\n `${importCount}/${selectedMappings.length}`,\n ]\n }\n status={!errored ? (importCount === selectedMappings.length ? \"positive\" : undefined) : \"negative\"}\n />\n </div>\n <div className=\"gmw-import-action-panel\">\n <Button\n disabled={!errored && importCount === selectedMappings.length}\n onClick={() => {\n setImporting(false);\n setImportCount(0);\n setCurrentlyImporting(\"\");\n setErrored(false);\n }}\n >\n Back\n </Button>\n <Button styleType=\"high-visibility\" disabled={!errored && importCount !== selectedMappings.length} onClick={onFinish}>\n Close\n </Button>\n </div>\n </div>\n ) : (\n <div className=\"gmw-rename-confirm-container \">\n <div className=\"gmw-mapping-rename-container\">\n <div className=\"gmw-mapping-row-header-container\">\n <div className=\"gmw-mapping-row\">\n <Text variant=\"leading\">{displayStrings.mappings}</Text>\n <Text variant=\"leading\">Description</Text>\n </div>\n </div>\n <div className=\"gmw-mapping-row-body\">\n {selectedMappings.map((mapping, index) => (\n <div className=\"gmw-mapping-row-container\" key={mapping.id}>\n <div className=\"gmw-mapping-row\">\n <LabeledInput\n value={mapping.mappingName}\n name={`mapping_${mapping.id}`}\n required\n onChange={(event) => {\n handleChange(event, index);\n validator.showMessageFor(`mapping_${mapping.id}`);\n }}\n message={validator.message(`mapping_${mapping.id}`, mapping.mappingName, NAME_REQUIREMENTS)}\n status={validator.message(`mapping_${mapping.id}`, mapping.mappingName, NAME_REQUIREMENTS) ? \"negative\" : undefined}\n onBlur={() => {\n validator.showMessageFor(`mapping_${mapping.id}`);\n }}\n onBlurCapture={(event) => {\n handleChange(event, index);\n validator.showMessageFor(`mapping_${mapping.id}`);\n }}\n />\n <div>{mapping.description}</div>\n </div>\n <div className=\"gmw-border-div\" />\n </div>\n ))}\n </div>\n </div>\n <div className=\"gmw-import-action-panel\">\n <Button onClick={backFn}>Back</Button>\n <Button styleType=\"high-visibility\" onClick={async () => onImport()}>\n Import\n </Button>\n <Button onClick={onCancel}>Cancel</Button>\n </div>\n </div>\n )}\n </>\n );\n};\n\nexport default ConfirmMappingImport;\n"]}
1
+ {"version":3,"file":"ConfirmMappingsImport.js","sourceRoot":"","sources":["../../../../../src/components/Mappings/Import/ConfirmMappingsImport.tsx"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\nimport { Button, LabeledInput, MiddleTextTruncation, ProgressLinear, Text } from \"@itwin/itwinui-react\";\nimport React, { useEffect, useState } from \"react\";\nimport { GroupingMappingWidget } from \"../../../GroupingMappingWidget\";\nimport type { IMappingTyped } from \"../Mappings\";\nimport \"./ConfirmMappingsImport.scss\";\nimport { SvgStatusSuccessHollow } from \"@itwin/itwinui-icons-react\";\nimport useValidator, { NAME_REQUIREMENTS } from \"../../Properties/hooks/useValidator\";\nimport { useMappingClient } from \"../../context/MappingClientContext\";\nimport { useGroupingMappingApiConfig } from \"../../context/GroupingApiConfigContext\";\nimport { useMutation } from \"@tanstack/react-query\";\n\nconst getDefaultDisplayStrings = () => ({\n mappings: GroupingMappingWidget.translate(\"mappings.mappings\"),\n});\n\ninterface ConfirmMappingImportProps {\n selectedMappings: IMappingTyped[];\n importing: boolean;\n setImporting: React.Dispatch<React.SetStateAction<boolean>>;\n setSelectedMappings: React.Dispatch<React.SetStateAction<IMappingTyped[]>>;\n backFn: () => void;\n onCancel: () => void;\n onFinish: () => void;\n displayStrings?: Partial<ReturnType<typeof getDefaultDisplayStrings>>;\n}\n\nconst ConfirmMappingImport = ({\n selectedMappings,\n importing,\n setImporting,\n setSelectedMappings,\n backFn,\n onCancel,\n onFinish,\n displayStrings: userDisplayStrings,\n}: ConfirmMappingImportProps) => {\n const { getAccessToken, iModelId } = useGroupingMappingApiConfig();\n const mappingClient = useMappingClient();\n const [importCount, setImportCount] = useState<number>(0);\n const [currentlyImporting, setCurrentlyImporting] = useState<string>(\"\");\n const [validator, showValidationMessage] = useValidator();\n const [errored, setErrored] = useState<boolean>(false);\n\n const displayStrings = React.useMemo(() => ({ ...getDefaultDisplayStrings(), ...userDisplayStrings }), [userDisplayStrings]);\n\n useEffect(() => {\n setSelectedMappings((selectedMappings) =>\n selectedMappings.map((mapping) => ({\n ...mapping,\n mappingName: GroupingMappingWidget.translate(\"import.copySuffix\", { name: mapping.mappingName }),\n })),\n );\n }, [setSelectedMappings]);\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>, index: number) => {\n const newState = [...selectedMappings];\n newState[index] = {\n ...newState[index],\n mappingName: e.target.value,\n };\n setSelectedMappings(newState);\n };\n\n const importMutation = useMutation({\n mutationFn: async (selectedMapping: IMappingTyped) => {\n const accessToken = await getAccessToken();\n await mappingClient.createMapping(accessToken, {\n iModelId,\n mappingName: selectedMapping.mappingName,\n sourceMappingId: selectedMapping.id,\n });\n },\n onMutate: async (selectedMapping: IMappingTyped) => {\n setCurrentlyImporting(selectedMapping.mappingName);\n },\n onSuccess: () => {\n setImportCount((count) => count + 1);\n },\n onError: () => {\n setErrored(true);\n },\n });\n\n const onImport = async () => {\n if (!validator.allValid()) {\n showValidationMessage(true);\n return;\n }\n setImporting(true);\n setImportCount(0);\n for (const mapping of selectedMappings) {\n await importMutation.mutateAsync(mapping);\n }\n };\n\n return (\n <>\n {importing ? (\n <div className=\"gmw-import-progress-container\">\n <div className=\"gmw-import-progress-bar\">\n <div className=\"gmw-import-progress-bar-description\">\n {!errored ? (\n importCount !== selectedMappings.length ? (\n <>\n <Text variant=\"title\">{GroupingMappingWidget.translate(\"import.importing\")}</Text>\n <Text>{GroupingMappingWidget.translate(\"import.currentlyImporting\", { mappings: displayStrings.mappings.toLocaleLowerCase() })}</Text>\n </>\n ) : (\n <>\n <Text variant=\"title\">{GroupingMappingWidget.translate(\"import.done\")}</Text>\n <Text>{GroupingMappingWidget.translate(\"import.importedReady\", { mappings: displayStrings.mappings.toLocaleLowerCase() })}</Text>\n </>\n )\n ) : (\n <>\n <Text variant=\"title\">{GroupingMappingWidget.translate(\"import.error\")}</Text>\n <Text>{GroupingMappingWidget.translate(\"import.importError\", { mappings: displayStrings.mappings })}</Text>\n </>\n )}\n </div>\n <ProgressLinear\n value={(importCount / selectedMappings.length) * 100}\n labels={\n importCount === selectedMappings.length\n ? [GroupingMappingWidget.translate(\"import.importDone\"), <SvgStatusSuccessHollow key=\"0\" />]\n : [\n <>\n <Text>{GroupingMappingWidget.translate(\"import.copying\")}</Text>\n <MiddleTextTruncation text={currentlyImporting} />\n </>,\n `${importCount}/${selectedMappings.length}`,\n ]\n }\n status={!errored ? (importCount === selectedMappings.length ? \"positive\" : undefined) : \"negative\"}\n />\n </div>\n <div className=\"gmw-import-action-panel\">\n <Button\n disabled={!errored && importCount === selectedMappings.length}\n onClick={() => {\n setImporting(false);\n setImportCount(0);\n setCurrentlyImporting(\"\");\n setErrored(false);\n }}\n >\n {GroupingMappingWidget.translate(\"common.back\")}\n </Button>\n <Button styleType=\"high-visibility\" disabled={!errored && importCount !== selectedMappings.length} onClick={onFinish}>\n {GroupingMappingWidget.translate(\"common.close\")}\n </Button>\n </div>\n </div>\n ) : (\n <div className=\"gmw-rename-confirm-container \">\n <div className=\"gmw-mapping-rename-container\">\n <div className=\"gmw-mapping-row-header-container\">\n <div className=\"gmw-mapping-row\">\n <Text variant=\"leading\">{displayStrings.mappings}</Text>\n <Text variant=\"leading\">{GroupingMappingWidget.translate(\"common.description\")}</Text>\n </div>\n </div>\n <div className=\"gmw-mapping-row-body\">\n {selectedMappings.map((mapping, index) => (\n <div className=\"gmw-mapping-row-container\" key={mapping.id}>\n <div className=\"gmw-mapping-row\">\n <LabeledInput\n value={mapping.mappingName}\n name={`mapping_${mapping.id}`}\n required\n onChange={(event) => {\n handleChange(event, index);\n validator.showMessageFor(`mapping_${mapping.id}`);\n }}\n message={validator.message(`mapping_${mapping.id}`, mapping.mappingName, NAME_REQUIREMENTS)}\n status={validator.message(`mapping_${mapping.id}`, mapping.mappingName, NAME_REQUIREMENTS) ? \"negative\" : undefined}\n onBlur={() => {\n validator.showMessageFor(`mapping_${mapping.id}`);\n }}\n onBlurCapture={(event) => {\n handleChange(event, index);\n validator.showMessageFor(`mapping_${mapping.id}`);\n }}\n />\n <div>{mapping.description}</div>\n </div>\n <div className=\"gmw-border-div\" />\n </div>\n ))}\n </div>\n </div>\n <div className=\"gmw-import-action-panel\">\n <Button onClick={backFn}>{GroupingMappingWidget.translate(\"common.back\")}</Button>\n <Button styleType=\"high-visibility\" onClick={async () => onImport()}>\n {GroupingMappingWidget.translate(\"common.import\")}\n </Button>\n <Button onClick={onCancel}>{GroupingMappingWidget.translate(\"common.cancel\")}</Button>\n </div>\n </div>\n )}\n </>\n );\n};\n\nexport default ConfirmMappingImport;\n"]}
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
2
  import "./MappingImportWizardModal.scss";
3
- declare const defaultDisplayStrings: {
3
+ declare const getDefaultDisplayStrings: () => {
4
4
  mappings: string;
5
5
  iTwins: string;
6
6
  iTwinNumber: string;
@@ -14,7 +14,7 @@ interface MappingImportWizardModalProps {
14
14
  show: boolean;
15
15
  setShow: (show: boolean) => void;
16
16
  onFinish: () => Promise<void>;
17
- displayStrings?: Partial<typeof defaultDisplayStrings>;
17
+ displayStrings?: Partial<ReturnType<typeof getDefaultDisplayStrings>>;
18
18
  }
19
19
  export declare const MappingImportWizardModal: ({ show, setShow, onFinish, displayStrings: userDisplayStrings }: MappingImportWizardModalProps) => JSX.Element;
20
20
  export {};
@@ -1,6 +1,7 @@
1
1
  import { Stepper } from "@itwin/itwinui-react";
2
2
  import { Modal } from "@itwin/itwinui-react";
3
3
  import React, { useEffect, useRef, useState } from "react";
4
+ import { GroupingMappingWidget } from "../../../GroupingMappingWidget";
4
5
  import ConfirmMappingImport from "./ConfirmMappingsImport";
5
6
  import "./MappingImportWizardModal.scss";
6
7
  import SelectIModel from "./SelectIModel";
@@ -9,16 +10,16 @@ import SelectMappings from "./SelectMappings";
9
10
  import { useGroupingMappingApiConfig } from "../../context/GroupingApiConfigContext";
10
11
  import { createIModelsClient, IModelsClientContext } from "../../context/IModelsClientContext";
11
12
  import { createITwinsClient, ITwinsClientContext } from "../../context/ITwinsClientContext";
12
- const defaultDisplayStrings = {
13
- mappings: "Mappings",
13
+ const getDefaultDisplayStrings = () => ({
14
+ mappings: GroupingMappingWidget.translate("mappings.mappings"),
14
15
  iTwins: "iTwins",
15
- iTwinNumber: "Number",
16
- iTwinName: "Name",
17
- iTwinStatus: "Status",
16
+ iTwinNumber: GroupingMappingWidget.translate("common.number"),
17
+ iTwinName: GroupingMappingWidget.translate("common.name"),
18
+ iTwinStatus: GroupingMappingWidget.translate("common.status"),
18
19
  iModels: "iModels",
19
- iModelName: "Name",
20
- iModelDescription: "Description",
21
- };
20
+ iModelName: GroupingMappingWidget.translate("common.name"),
21
+ iModelDescription: GroupingMappingWidget.translate("common.description"),
22
+ });
22
23
  export const MappingImportWizardModal = ({ show, setShow, onFinish, displayStrings: userDisplayStrings }) => {
23
24
  const { prefix } = useGroupingMappingApiConfig();
24
25
  const [currentStep, setCurrentStep] = useState(0);
@@ -33,23 +34,23 @@ export const MappingImportWizardModal = ({ show, setShow, onFinish, displayStrin
33
34
  setITwinsClient(createITwinsClient(prefix));
34
35
  setIModelsClient(createIModelsClient(prefix));
35
36
  }, [prefix]);
36
- const displayStrings = React.useMemo(() => ({ ...defaultDisplayStrings, ...userDisplayStrings }), [userDisplayStrings]);
37
+ const displayStrings = React.useMemo(() => ({ ...getDefaultDisplayStrings(), ...userDisplayStrings }), [userDisplayStrings]);
37
38
  const steps = useRef([
38
39
  {
39
- name: "Select iTwin",
40
- description: `Select the source iTwin to bring your ${displayStrings.mappings} from.`,
40
+ name: GroupingMappingWidget.translate("import.selectITwin"),
41
+ description: GroupingMappingWidget.translate("import.selectITwinDescription", { mappings: displayStrings.mappings }),
41
42
  },
42
43
  {
43
- name: "Select iModel",
44
- description: "Select an iModel within the iTwin you have selected.",
44
+ name: GroupingMappingWidget.translate("import.selectIModel"),
45
+ description: GroupingMappingWidget.translate("import.selectIModelDescription"),
45
46
  },
46
47
  {
47
- name: `Select ${displayStrings.mappings}`,
48
- description: `Select one or more ${displayStrings.mappings} to import.`,
48
+ name: GroupingMappingWidget.translate("import.selectMappings", { mappings: displayStrings.mappings }),
49
+ description: GroupingMappingWidget.translate("import.selectMappingsDescription", { mappings: displayStrings.mappings }),
49
50
  },
50
51
  {
51
- name: "Rename & Confirm",
52
- description: "Rename and confirm your selections. Click import when finished.",
52
+ name: GroupingMappingWidget.translate("import.renameAndConfirm"),
53
+ description: GroupingMappingWidget.translate("import.renameAndConfirmDescription"),
53
54
  },
54
55
  ]);
55
56
  const onClose = async () => {
@@ -57,7 +58,7 @@ export const MappingImportWizardModal = ({ show, setShow, onFinish, displayStrin
57
58
  setCurrentStep(0);
58
59
  await onFinish();
59
60
  };
60
- return (React.createElement(Modal, { title: `Import ${displayStrings.mappings}`, modalRootId: "grouping-mapping-widget", isOpen: show, closeOnEsc: false, closeOnExternalClick: false, isDismissible: !importing, styleType: "fullPage", onClose: async () => {
61
+ return (React.createElement(Modal, { title: GroupingMappingWidget.translate("mappings.importMappings", { mappings: displayStrings.mappings }), modalRootId: "grouping-mapping-widget", isOpen: show, closeOnEsc: false, closeOnExternalClick: false, isDismissible: !importing, styleType: "fullPage", onClose: async () => {
61
62
  await onClose();
62
63
  } },
63
64
  React.createElement("div", { className: "gmw-import-wizard-body-container" },
@@ -1 +1 @@
1
- {"version":3,"file":"MappingImportWizardModal.js","sourceRoot":"","sources":["../../../../../src/components/Mappings/Import/MappingImportWizardModal.tsx"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\nimport type { IModelsClient } from \"@itwin/imodels-client-management\";\nimport type { ITwinsAccessClient } from \"@itwin/itwins-client\";\nimport type { StepProperties } from \"@itwin/itwinui-react\";\nimport { Stepper } from \"@itwin/itwinui-react\";\nimport { Modal } from \"@itwin/itwinui-react\";\nimport React, { useEffect, useRef, useState } from \"react\";\nimport ConfirmMappingImport from \"./ConfirmMappingsImport\";\nimport type { IMappingTyped } from \"../Mappings\";\nimport \"./MappingImportWizardModal.scss\";\nimport SelectIModel from \"./SelectIModel\";\nimport SelectITwin, { ITwinType } from \"./SelectITwin\";\nimport SelectMappings from \"./SelectMappings\";\nimport { useGroupingMappingApiConfig } from \"../../context/GroupingApiConfigContext\";\nimport { createIModelsClient, IModelsClientContext } from \"../../context/IModelsClientContext\";\nimport { createITwinsClient, ITwinsClientContext } from \"../../context/ITwinsClientContext\";\n\nconst defaultDisplayStrings = {\n mappings: \"Mappings\",\n iTwins: \"iTwins\",\n iTwinNumber: \"Number\",\n iTwinName: \"Name\",\n iTwinStatus: \"Status\",\n iModels: \"iModels\",\n iModelName: \"Name\",\n iModelDescription: \"Description\",\n};\ninterface MappingImportWizardModalProps {\n show: boolean;\n setShow: (show: boolean) => void;\n onFinish: () => Promise<void>;\n displayStrings?: Partial<typeof defaultDisplayStrings>;\n}\n\nexport const MappingImportWizardModal = ({ show, setShow, onFinish, displayStrings: userDisplayStrings }: MappingImportWizardModalProps) => {\n const { prefix } = useGroupingMappingApiConfig();\n const [currentStep, setCurrentStep] = useState<number>(0);\n const [iTwinType, setITwinType] = useState<ITwinType>(ITwinType.Favorite);\n const [selectedITwinId, setSelectedITwinId] = useState<string>(\"\");\n const [selectedIModelId, setSelectedIModelId] = useState<string>(\"\");\n const [selectedMappings, setSelectedMappings] = useState<IMappingTyped[]>([]);\n const [importing, setImporting] = useState<boolean>(false);\n const [iTwinsClient, setITwinsClient] = useState<ITwinsAccessClient>(createITwinsClient(prefix));\n const [iModelsClient, setIModelsClient] = useState<IModelsClient>(createIModelsClient(prefix));\n\n useEffect(() => {\n setITwinsClient(createITwinsClient(prefix));\n setIModelsClient(createIModelsClient(prefix));\n }, [prefix]);\n\n const displayStrings = React.useMemo(() => ({ ...defaultDisplayStrings, ...userDisplayStrings }), [userDisplayStrings]);\n\n const steps = useRef<StepProperties[]>([\n {\n name: \"Select iTwin\",\n description: `Select the source iTwin to bring your ${displayStrings.mappings} from.`,\n },\n {\n name: \"Select iModel\",\n description: \"Select an iModel within the iTwin you have selected.\",\n },\n {\n name: `Select ${displayStrings.mappings}`,\n description: `Select one or more ${displayStrings.mappings} to import.`,\n },\n {\n name: \"Rename & Confirm\",\n description: \"Rename and confirm your selections. Click import when finished.\",\n },\n ]);\n\n const onClose = async () => {\n setShow(false);\n setCurrentStep(0);\n await onFinish();\n };\n\n return (\n <Modal\n title={`Import ${displayStrings.mappings}`}\n modalRootId=\"grouping-mapping-widget\"\n isOpen={show}\n closeOnEsc={false}\n closeOnExternalClick={false}\n isDismissible={!importing}\n styleType=\"fullPage\"\n onClose={async () => {\n await onClose();\n }}\n >\n <div className=\"gmw-import-wizard-body-container\">\n <Stepper currentStep={currentStep} steps={steps.current} onStepClick={importing ? undefined : (index: number) => setCurrentStep(index)} />\n\n {(() => {\n switch (currentStep) {\n case 0:\n return (\n <ITwinsClientContext.Provider value={iTwinsClient}>\n <div className=\"gmw-table-container\">\n <SelectITwin\n onSelect={(iTwinId) => {\n setSelectedITwinId(iTwinId);\n setCurrentStep(1);\n }}\n onCancel={onClose}\n onChangeITwinType={setITwinType}\n displayStrings={displayStrings}\n defaultITwinType={iTwinType}\n />\n </div>\n </ITwinsClientContext.Provider>\n );\n case 1:\n return (\n <IModelsClientContext.Provider value={iModelsClient}>\n <div className=\"gmw-table-container\">\n <SelectIModel\n iTwinId={selectedITwinId}\n onSelect={(iModelId) => {\n setSelectedIModelId(iModelId);\n setCurrentStep(2);\n }}\n backFn={() => setCurrentStep(currentStep - 1)}\n onCancel={onClose}\n />\n </div>\n </IModelsClientContext.Provider>\n );\n case 2:\n case 3:\n // Preserve table state within Select Mappings\n return (\n <>\n <div style={{ display: currentStep === 2 ? \"flex\" : \"none\" }} className=\"gmw-mapping-container\">\n <SelectMappings\n iModelId={selectedIModelId}\n onSelect={(selectedMappings) => {\n setSelectedMappings(selectedMappings);\n setCurrentStep(3);\n }}\n onCancel={onClose}\n backFn={() => setCurrentStep(currentStep - 1)}\n displayStrings={displayStrings}\n />\n </div>\n {currentStep === 3 && (\n <ConfirmMappingImport\n selectedMappings={selectedMappings}\n importing={importing}\n setImporting={setImporting}\n setSelectedMappings={setSelectedMappings}\n backFn={() => setCurrentStep(currentStep - 1)}\n onCancel={onClose}\n onFinish={onClose}\n displayStrings={displayStrings}\n />\n )}\n </>\n );\n default:\n return null;\n }\n })()}\n </div>\n </Modal>\n );\n};\n"]}
1
+ {"version":3,"file":"MappingImportWizardModal.js","sourceRoot":"","sources":["../../../../../src/components/Mappings/Import/MappingImportWizardModal.tsx"],"names":[],"mappings":"AAOA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAC7C,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,oBAAoB,MAAM,yBAAyB,CAAC;AAE3D,OAAO,iCAAiC,CAAC;AACzC,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,WAAW,EAAE,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,2BAA2B,EAAE,MAAM,wCAAwC,CAAC;AACrF,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAC/F,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AAE5F,MAAM,wBAAwB,GAAG,GAAG,EAAE,CAAC,CAAC;IACtC,QAAQ,EAAE,qBAAqB,CAAC,SAAS,CAAC,mBAAmB,CAAC;IAC9D,MAAM,EAAE,QAAQ;IAChB,WAAW,EAAE,qBAAqB,CAAC,SAAS,CAAC,eAAe,CAAC;IAC7D,SAAS,EAAE,qBAAqB,CAAC,SAAS,CAAC,aAAa,CAAC;IACzD,WAAW,EAAE,qBAAqB,CAAC,SAAS,CAAC,eAAe,CAAC;IAC7D,OAAO,EAAE,SAAS;IAClB,UAAU,EAAE,qBAAqB,CAAC,SAAS,CAAC,aAAa,CAAC;IAC1D,iBAAiB,EAAE,qBAAqB,CAAC,SAAS,CAAC,oBAAoB,CAAC;CACzE,CAAC,CAAC;AAQH,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,kBAAkB,EAAiC,EAAE,EAAE;IACzI,MAAM,EAAE,MAAM,EAAE,GAAG,2BAA2B,EAAE,CAAC;IACjD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAS,CAAC,CAAC,CAAC;IAC1D,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAY,SAAS,CAAC,QAAQ,CAAC,CAAC;IAC1E,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,QAAQ,CAAS,EAAE,CAAC,CAAC;IACnE,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,QAAQ,CAAS,EAAE,CAAC,CAAC;IACrE,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,QAAQ,CAAkB,EAAE,CAAC,CAAC;IAC9E,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IAC3D,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAqB,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC;IACjG,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAgB,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC;IAE/F,SAAS,CAAC,GAAG,EAAE;QACb,eAAe,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC;QAC5C,gBAAgB,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC;IAChD,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAEb,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,wBAAwB,EAAE,EAAE,GAAG,kBAAkB,EAAE,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC,CAAC;IAE7H,MAAM,KAAK,GAAG,MAAM,CAAmB;QACrC;YACE,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAC,oBAAoB,CAAC;YAC3D,WAAW,EAAE,qBAAqB,CAAC,SAAS,CAAC,+BAA+B,EAAE,EAAE,QAAQ,EAAE,cAAc,CAAC,QAAQ,EAAE,CAAC;SACrH;QACD;YACE,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAC,qBAAqB,CAAC;YAC5D,WAAW,EAAE,qBAAqB,CAAC,SAAS,CAAC,gCAAgC,CAAC;SAC/E;QACD;YACE,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAC,uBAAuB,EAAE,EAAE,QAAQ,EAAE,cAAc,CAAC,QAAQ,EAAE,CAAC;YACrG,WAAW,EAAE,qBAAqB,CAAC,SAAS,CAAC,kCAAkC,EAAE,EAAE,QAAQ,EAAE,cAAc,CAAC,QAAQ,EAAE,CAAC;SACxH;QACD;YACE,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAC,yBAAyB,CAAC;YAChE,WAAW,EAAE,qBAAqB,CAAC,SAAS,CAAC,oCAAoC,CAAC;SACnF;KACF,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,KAAK,IAAI,EAAE;QACzB,OAAO,CAAC,KAAK,CAAC,CAAC;QACf,cAAc,CAAC,CAAC,CAAC,CAAC;QAClB,MAAM,QAAQ,EAAE,CAAC;IACnB,CAAC,CAAC;IAEF,OAAO,CACL,oBAAC,KAAK,IACJ,KAAK,EAAE,qBAAqB,CAAC,SAAS,CAAC,yBAAyB,EAAE,EAAE,QAAQ,EAAE,cAAc,CAAC,QAAQ,EAAE,CAAC,EACxG,WAAW,EAAC,yBAAyB,EACrC,MAAM,EAAE,IAAI,EACZ,UAAU,EAAE,KAAK,EACjB,oBAAoB,EAAE,KAAK,EAC3B,aAAa,EAAE,CAAC,SAAS,EACzB,SAAS,EAAC,UAAU,EACpB,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,MAAM,OAAO,EAAE,CAAC;QAClB,CAAC;QAED,6BAAK,SAAS,EAAC,kCAAkC;YAC/C,oBAAC,OAAO,IAAC,WAAW,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAa,EAAE,EAAE,CAAC,cAAc,CAAC,KAAK,CAAC,GAAI;YAEzI,CAAC,GAAG,EAAE;gBACL,QAAQ,WAAW,EAAE;oBACnB,KAAK,CAAC;wBACJ,OAAO,CACL,oBAAC,mBAAmB,CAAC,QAAQ,IAAC,KAAK,EAAE,YAAY;4BAC/C,6BAAK,SAAS,EAAC,qBAAqB;gCAClC,oBAAC,WAAW,IACV,QAAQ,EAAE,CAAC,OAAO,EAAE,EAAE;wCACpB,kBAAkB,CAAC,OAAO,CAAC,CAAC;wCAC5B,cAAc,CAAC,CAAC,CAAC,CAAC;oCACpB,CAAC,EACD,QAAQ,EAAE,OAAO,EACjB,iBAAiB,EAAE,YAAY,EAC/B,cAAc,EAAE,cAAc,EAC9B,gBAAgB,EAAE,SAAS,GAC3B,CACE,CACuB,CAChC,CAAC;oBACJ,KAAK,CAAC;wBACJ,OAAO,CACL,oBAAC,oBAAoB,CAAC,QAAQ,IAAC,KAAK,EAAE,aAAa;4BACjD,6BAAK,SAAS,EAAC,qBAAqB;gCAClC,oBAAC,YAAY,IACX,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,CAAC,QAAQ,EAAE,EAAE;wCACrB,mBAAmB,CAAC,QAAQ,CAAC,CAAC;wCAC9B,cAAc,CAAC,CAAC,CAAC,CAAC;oCACpB,CAAC,EACD,MAAM,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,WAAW,GAAG,CAAC,CAAC,EAC7C,QAAQ,EAAE,OAAO,GACjB,CACE,CACwB,CACjC,CAAC;oBACJ,KAAK,CAAC,CAAC;oBACP,KAAK,CAAC;wBACJ,8CAA8C;wBAC9C,OAAO,CACL;4BACE,6BAAK,KAAK,EAAE,EAAE,OAAO,EAAE,WAAW,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,SAAS,EAAC,uBAAuB;gCAC7F,oBAAC,cAAc,IACb,QAAQ,EAAE,gBAAgB,EAC1B,QAAQ,EAAE,CAAC,gBAAgB,EAAE,EAAE;wCAC7B,mBAAmB,CAAC,gBAAgB,CAAC,CAAC;wCACtC,cAAc,CAAC,CAAC,CAAC,CAAC;oCACpB,CAAC,EACD,QAAQ,EAAE,OAAO,EACjB,MAAM,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,WAAW,GAAG,CAAC,CAAC,EAC7C,cAAc,EAAE,cAAc,GAC9B,CACE;4BACL,WAAW,KAAK,CAAC,IAAI,CACpB,oBAAC,oBAAoB,IACnB,gBAAgB,EAAE,gBAAgB,EAClC,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,YAAY,EAC1B,mBAAmB,EAAE,mBAAmB,EACxC,MAAM,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,WAAW,GAAG,CAAC,CAAC,EAC7C,QAAQ,EAAE,OAAO,EACjB,QAAQ,EAAE,OAAO,EACjB,cAAc,EAAE,cAAc,GAC9B,CACH,CACA,CACJ,CAAC;oBACJ;wBACE,OAAO,IAAI,CAAC;iBACf;YACH,CAAC,CAAC,EAAE,CACA,CACA,CACT,CAAC;AACJ,CAAC,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\nimport type { IModelsClient } from \"@itwin/imodels-client-management\";\nimport type { ITwinsAccessClient } from \"@itwin/itwins-client\";\nimport type { StepProperties } from \"@itwin/itwinui-react\";\nimport { Stepper } from \"@itwin/itwinui-react\";\nimport { Modal } from \"@itwin/itwinui-react\";\nimport React, { useEffect, useRef, useState } from \"react\";\nimport { GroupingMappingWidget } from \"../../../GroupingMappingWidget\";\nimport ConfirmMappingImport from \"./ConfirmMappingsImport\";\nimport type { IMappingTyped } from \"../Mappings\";\nimport \"./MappingImportWizardModal.scss\";\nimport SelectIModel from \"./SelectIModel\";\nimport SelectITwin, { ITwinType } from \"./SelectITwin\";\nimport SelectMappings from \"./SelectMappings\";\nimport { useGroupingMappingApiConfig } from \"../../context/GroupingApiConfigContext\";\nimport { createIModelsClient, IModelsClientContext } from \"../../context/IModelsClientContext\";\nimport { createITwinsClient, ITwinsClientContext } from \"../../context/ITwinsClientContext\";\n\nconst getDefaultDisplayStrings = () => ({\n mappings: GroupingMappingWidget.translate(\"mappings.mappings\"),\n iTwins: \"iTwins\",\n iTwinNumber: GroupingMappingWidget.translate(\"common.number\"),\n iTwinName: GroupingMappingWidget.translate(\"common.name\"),\n iTwinStatus: GroupingMappingWidget.translate(\"common.status\"),\n iModels: \"iModels\",\n iModelName: GroupingMappingWidget.translate(\"common.name\"),\n iModelDescription: GroupingMappingWidget.translate(\"common.description\"),\n});\ninterface MappingImportWizardModalProps {\n show: boolean;\n setShow: (show: boolean) => void;\n onFinish: () => Promise<void>;\n displayStrings?: Partial<ReturnType<typeof getDefaultDisplayStrings>>;\n}\n\nexport const MappingImportWizardModal = ({ show, setShow, onFinish, displayStrings: userDisplayStrings }: MappingImportWizardModalProps) => {\n const { prefix } = useGroupingMappingApiConfig();\n const [currentStep, setCurrentStep] = useState<number>(0);\n const [iTwinType, setITwinType] = useState<ITwinType>(ITwinType.Favorite);\n const [selectedITwinId, setSelectedITwinId] = useState<string>(\"\");\n const [selectedIModelId, setSelectedIModelId] = useState<string>(\"\");\n const [selectedMappings, setSelectedMappings] = useState<IMappingTyped[]>([]);\n const [importing, setImporting] = useState<boolean>(false);\n const [iTwinsClient, setITwinsClient] = useState<ITwinsAccessClient>(createITwinsClient(prefix));\n const [iModelsClient, setIModelsClient] = useState<IModelsClient>(createIModelsClient(prefix));\n\n useEffect(() => {\n setITwinsClient(createITwinsClient(prefix));\n setIModelsClient(createIModelsClient(prefix));\n }, [prefix]);\n\n const displayStrings = React.useMemo(() => ({ ...getDefaultDisplayStrings(), ...userDisplayStrings }), [userDisplayStrings]);\n\n const steps = useRef<StepProperties[]>([\n {\n name: GroupingMappingWidget.translate(\"import.selectITwin\"),\n description: GroupingMappingWidget.translate(\"import.selectITwinDescription\", { mappings: displayStrings.mappings }),\n },\n {\n name: GroupingMappingWidget.translate(\"import.selectIModel\"),\n description: GroupingMappingWidget.translate(\"import.selectIModelDescription\"),\n },\n {\n name: GroupingMappingWidget.translate(\"import.selectMappings\", { mappings: displayStrings.mappings }),\n description: GroupingMappingWidget.translate(\"import.selectMappingsDescription\", { mappings: displayStrings.mappings }),\n },\n {\n name: GroupingMappingWidget.translate(\"import.renameAndConfirm\"),\n description: GroupingMappingWidget.translate(\"import.renameAndConfirmDescription\"),\n },\n ]);\n\n const onClose = async () => {\n setShow(false);\n setCurrentStep(0);\n await onFinish();\n };\n\n return (\n <Modal\n title={GroupingMappingWidget.translate(\"mappings.importMappings\", { mappings: displayStrings.mappings })}\n modalRootId=\"grouping-mapping-widget\"\n isOpen={show}\n closeOnEsc={false}\n closeOnExternalClick={false}\n isDismissible={!importing}\n styleType=\"fullPage\"\n onClose={async () => {\n await onClose();\n }}\n >\n <div className=\"gmw-import-wizard-body-container\">\n <Stepper currentStep={currentStep} steps={steps.current} onStepClick={importing ? undefined : (index: number) => setCurrentStep(index)} />\n\n {(() => {\n switch (currentStep) {\n case 0:\n return (\n <ITwinsClientContext.Provider value={iTwinsClient}>\n <div className=\"gmw-table-container\">\n <SelectITwin\n onSelect={(iTwinId) => {\n setSelectedITwinId(iTwinId);\n setCurrentStep(1);\n }}\n onCancel={onClose}\n onChangeITwinType={setITwinType}\n displayStrings={displayStrings}\n defaultITwinType={iTwinType}\n />\n </div>\n </ITwinsClientContext.Provider>\n );\n case 1:\n return (\n <IModelsClientContext.Provider value={iModelsClient}>\n <div className=\"gmw-table-container\">\n <SelectIModel\n iTwinId={selectedITwinId}\n onSelect={(iModelId) => {\n setSelectedIModelId(iModelId);\n setCurrentStep(2);\n }}\n backFn={() => setCurrentStep(currentStep - 1)}\n onCancel={onClose}\n />\n </div>\n </IModelsClientContext.Provider>\n );\n case 2:\n case 3:\n // Preserve table state within Select Mappings\n return (\n <>\n <div style={{ display: currentStep === 2 ? \"flex\" : \"none\" }} className=\"gmw-mapping-container\">\n <SelectMappings\n iModelId={selectedIModelId}\n onSelect={(selectedMappings) => {\n setSelectedMappings(selectedMappings);\n setCurrentStep(3);\n }}\n onCancel={onClose}\n backFn={() => setCurrentStep(currentStep - 1)}\n displayStrings={displayStrings}\n />\n </div>\n {currentStep === 3 && (\n <ConfirmMappingImport\n selectedMappings={selectedMappings}\n importing={importing}\n setImporting={setImporting}\n setSelectedMappings={setSelectedMappings}\n backFn={() => setCurrentStep(currentStep - 1)}\n onCancel={onClose}\n onFinish={onClose}\n displayStrings={displayStrings}\n />\n )}\n </>\n );\n default:\n return null;\n }\n })()}\n </div>\n </Modal>\n );\n};\n"]}
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
2
  import "./SelectIModel.scss";
3
- declare const defaultDisplayStrings: {
3
+ declare const getDefaultDisplayStrings: () => {
4
4
  iModels: string;
5
5
  iModelName: string;
6
6
  iModelDescription: string;
@@ -10,7 +10,7 @@ interface SelectIModelProps {
10
10
  onSelect: (iModelId: string) => void;
11
11
  onCancel: () => void;
12
12
  backFn: () => void;
13
- displayStrings?: Partial<typeof defaultDisplayStrings>;
13
+ displayStrings?: Partial<ReturnType<typeof getDefaultDisplayStrings>>;
14
14
  }
15
15
  declare const SelectIModel: ({ iTwinId: iTwinId, onSelect, onCancel, backFn, displayStrings: userDisplayStrings }: SelectIModelProps) => JSX.Element;
16
16
  export default SelectIModel;
@@ -1,15 +1,16 @@
1
1
  import { Button, Table, tableFilters, TablePaginator } from "@itwin/itwinui-react";
2
2
  import React, { useCallback, useMemo } from "react";
3
+ import { GroupingMappingWidget } from "../../../GroupingMappingWidget";
3
4
  import "./SelectIModel.scss";
4
5
  import { useGroupingMappingApiConfig } from "../../context/GroupingApiConfigContext";
5
6
  import { useIModelsClient } from "../../context/IModelsClientContext";
6
7
  import { useQuery } from "@tanstack/react-query";
7
8
  import { AccessTokenAdapter } from "@itwin/imodels-access-frontend";
8
- const defaultDisplayStrings = {
9
+ const getDefaultDisplayStrings = () => ({
9
10
  iModels: "iModels",
10
- iModelName: "Name",
11
- iModelDescription: "Description",
12
- };
11
+ iModelName: GroupingMappingWidget.translate("common.name"),
12
+ iModelDescription: GroupingMappingWidget.translate("common.description"),
13
+ });
13
14
  const fetchIModels = async (getAccessToken, iTwinId, iModelsClient) => {
14
15
  const accessToken = await getAccessToken();
15
16
  const authorization = AccessTokenAdapter.toAuthorizationCallback(accessToken);
@@ -32,7 +33,7 @@ const SelectIModel = ({ iTwinId: iTwinId, onSelect, onCancel, backFn, displayStr
32
33
  queryKey: ["iModels", iTwinId],
33
34
  queryFn: async () => fetchIModels(getAccessToken, iTwinId, iModelsClient),
34
35
  });
35
- const displayStrings = React.useMemo(() => ({ ...defaultDisplayStrings, ...userDisplayStrings }), [userDisplayStrings]);
36
+ const displayStrings = React.useMemo(() => ({ ...getDefaultDisplayStrings(), ...userDisplayStrings }), [userDisplayStrings]);
36
37
  const iModelsColumns = useMemo(() => [
37
38
  {
38
39
  id: "iModelName",
@@ -50,12 +51,12 @@ const SelectIModel = ({ iTwinId: iTwinId, onSelect, onCancel, backFn, displayStr
50
51
  const pageSizeList = useMemo(() => [10, 25, 50], []);
51
52
  const paginator = useCallback((props) => React.createElement(TablePaginator, { ...props, pageSizeList: pageSizeList }), [pageSizeList]);
52
53
  return (React.createElement("div", { className: "gmw-select-imodel-table-container" },
53
- React.createElement(Table, { data: iModels ?? [], columns: iModelsColumns, className: "gmw-select-imodel-table", emptyTableContent: `No ${displayStrings.iModels} available.`, isSortable: true, isLoading: isLoading, onRowClick: (_, row) => {
54
+ React.createElement(Table, { data: iModels ?? [], columns: iModelsColumns, className: "gmw-select-imodel-table", emptyTableContent: GroupingMappingWidget.translate("import.noIModels", { iModels: displayStrings.iModels }), isSortable: true, isLoading: isLoading, onRowClick: (_, row) => {
54
55
  onSelect(row.original.id);
55
56
  }, paginatorRenderer: paginator }),
56
57
  React.createElement("div", { className: "gmw-import-action-panel" },
57
- React.createElement(Button, { onClick: backFn }, "Back"),
58
- React.createElement(Button, { onClick: onCancel }, "Cancel"))));
58
+ React.createElement(Button, { onClick: backFn }, GroupingMappingWidget.translate("common.back")),
59
+ React.createElement(Button, { onClick: onCancel }, GroupingMappingWidget.translate("common.cancel")))));
59
60
  };
60
61
  export default SelectIModel;
61
62
  //# sourceMappingURL=SelectIModel.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SelectIModel.js","sourceRoot":"","sources":["../../../../../src/components/Mappings/Import/SelectIModel.tsx"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\nimport type { IModel, IModelsClient } from \"@itwin/imodels-client-management\";\nimport type { TablePaginatorRendererProps } from \"@itwin/itwinui-react\";\nimport { Button, Table, tableFilters, TablePaginator } from \"@itwin/itwinui-react\";\nimport React, { useCallback, useMemo } from \"react\";\nimport type { CreateTypeFromInterface } from \"../../../common/utils\";\nimport \"./SelectIModel.scss\";\nimport type { GetAccessTokenFn } from \"../../context/GroupingApiConfigContext\";\nimport { useGroupingMappingApiConfig } from \"../../context/GroupingApiConfigContext\";\nimport { useIModelsClient } from \"../../context/IModelsClientContext\";\nimport { useQuery } from \"@tanstack/react-query\";\nimport type { Column } from \"react-table\";\nimport { AccessTokenAdapter } from \"@itwin/imodels-access-frontend\";\n\ntype IIModelTyped = CreateTypeFromInterface<IModel>;\n\nconst defaultDisplayStrings = {\n iModels: \"iModels\",\n iModelName: \"Name\",\n iModelDescription: \"Description\",\n};\n\nconst fetchIModels = async (getAccessToken: GetAccessTokenFn, iTwinId: string, iModelsClient: IModelsClient) => {\n const accessToken = await getAccessToken();\n const authorization = AccessTokenAdapter.toAuthorizationCallback(accessToken);\n const iModelIterator = iModelsClient.iModels.getRepresentationList({\n authorization,\n urlParams: {\n iTwinId,\n },\n });\n\n const iModels = [];\n for await (const iModel of iModelIterator) {\n iModels.push(iModel);\n }\n return iModels;\n};\n\ninterface SelectIModelProps {\n iTwinId: string;\n onSelect: (iModelId: string) => void;\n onCancel: () => void;\n backFn: () => void;\n displayStrings?: Partial<typeof defaultDisplayStrings>;\n}\nconst SelectIModel = ({ iTwinId: iTwinId, onSelect, onCancel, backFn, displayStrings: userDisplayStrings }: SelectIModelProps) => {\n const { getAccessToken } = useGroupingMappingApiConfig();\n const iModelsClient = useIModelsClient();\n\n const { data: iModels, isFetching: isLoading } = useQuery({\n queryKey: [\"iModels\", iTwinId],\n queryFn: async () => fetchIModels(getAccessToken, iTwinId, iModelsClient),\n });\n\n const displayStrings = React.useMemo(() => ({ ...defaultDisplayStrings, ...userDisplayStrings }), [userDisplayStrings]);\n\n const iModelsColumns = useMemo<Column<IIModelTyped>[]>(\n () => [\n {\n id: \"iModelName\",\n Header: `${displayStrings.iModelName}`,\n accessor: \"name\",\n Filter: tableFilters.TextFilter(),\n },\n {\n id: \"iModelDescription\",\n Header: `${displayStrings.iModelDescription}`,\n accessor: \"description\",\n Filter: tableFilters.TextFilter(),\n },\n ],\n [displayStrings.iModelName, displayStrings.iModelDescription],\n );\n\n const pageSizeList = useMemo(() => [10, 25, 50], []);\n const paginator = useCallback((props: TablePaginatorRendererProps) => <TablePaginator {...props} pageSizeList={pageSizeList} />, [pageSizeList]);\n\n return (\n <div className=\"gmw-select-imodel-table-container\">\n <Table<IIModelTyped>\n data={iModels ?? []}\n columns={iModelsColumns}\n className=\"gmw-select-imodel-table\"\n emptyTableContent={`No ${displayStrings.iModels} available.`}\n isSortable\n isLoading={isLoading}\n onRowClick={(_, row) => {\n onSelect(row.original.id);\n }}\n paginatorRenderer={paginator}\n />\n <div className=\"gmw-import-action-panel\">\n <Button onClick={backFn}>Back</Button>\n <Button onClick={onCancel}>Cancel</Button>\n </div>\n </div>\n );\n};\n\nexport default SelectIModel;\n"]}
1
+ {"version":3,"file":"SelectIModel.js","sourceRoot":"","sources":["../../../../../src/components/Mappings/Import/SelectIModel.tsx"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\nimport type { IModel, IModelsClient } from \"@itwin/imodels-client-management\";\nimport type { TablePaginatorRendererProps } from \"@itwin/itwinui-react\";\nimport { Button, Table, tableFilters, TablePaginator } from \"@itwin/itwinui-react\";\nimport React, { useCallback, useMemo } from \"react\";\nimport { GroupingMappingWidget } from \"../../../GroupingMappingWidget\";\nimport type { CreateTypeFromInterface } from \"../../../common/utils\";\nimport \"./SelectIModel.scss\";\nimport type { GetAccessTokenFn } from \"../../context/GroupingApiConfigContext\";\nimport { useGroupingMappingApiConfig } from \"../../context/GroupingApiConfigContext\";\nimport { useIModelsClient } from \"../../context/IModelsClientContext\";\nimport { useQuery } from \"@tanstack/react-query\";\nimport type { Column } from \"react-table\";\nimport { AccessTokenAdapter } from \"@itwin/imodels-access-frontend\";\n\ntype IIModelTyped = CreateTypeFromInterface<IModel>;\n\nconst getDefaultDisplayStrings = () => ({\n iModels: \"iModels\",\n iModelName: GroupingMappingWidget.translate(\"common.name\"),\n iModelDescription: GroupingMappingWidget.translate(\"common.description\"),\n});\n\nconst fetchIModels = async (getAccessToken: GetAccessTokenFn, iTwinId: string, iModelsClient: IModelsClient) => {\n const accessToken = await getAccessToken();\n const authorization = AccessTokenAdapter.toAuthorizationCallback(accessToken);\n const iModelIterator = iModelsClient.iModels.getRepresentationList({\n authorization,\n urlParams: {\n iTwinId,\n },\n });\n\n const iModels = [];\n for await (const iModel of iModelIterator) {\n iModels.push(iModel);\n }\n return iModels;\n};\n\ninterface SelectIModelProps {\n iTwinId: string;\n onSelect: (iModelId: string) => void;\n onCancel: () => void;\n backFn: () => void;\n displayStrings?: Partial<ReturnType<typeof getDefaultDisplayStrings>>;\n}\nconst SelectIModel = ({ iTwinId: iTwinId, onSelect, onCancel, backFn, displayStrings: userDisplayStrings }: SelectIModelProps) => {\n const { getAccessToken } = useGroupingMappingApiConfig();\n const iModelsClient = useIModelsClient();\n\n const { data: iModels, isFetching: isLoading } = useQuery({\n queryKey: [\"iModels\", iTwinId],\n queryFn: async () => fetchIModels(getAccessToken, iTwinId, iModelsClient),\n });\n\n const displayStrings = React.useMemo(() => ({ ...getDefaultDisplayStrings(), ...userDisplayStrings }), [userDisplayStrings]);\n\n const iModelsColumns = useMemo<Column<IIModelTyped>[]>(\n () => [\n {\n id: \"iModelName\",\n Header: `${displayStrings.iModelName}`,\n accessor: \"name\",\n Filter: tableFilters.TextFilter(),\n },\n {\n id: \"iModelDescription\",\n Header: `${displayStrings.iModelDescription}`,\n accessor: \"description\",\n Filter: tableFilters.TextFilter(),\n },\n ],\n [displayStrings.iModelName, displayStrings.iModelDescription],\n );\n\n const pageSizeList = useMemo(() => [10, 25, 50], []);\n const paginator = useCallback((props: TablePaginatorRendererProps) => <TablePaginator {...props} pageSizeList={pageSizeList} />, [pageSizeList]);\n\n return (\n <div className=\"gmw-select-imodel-table-container\">\n <Table<IIModelTyped>\n data={iModels ?? []}\n columns={iModelsColumns}\n className=\"gmw-select-imodel-table\"\n emptyTableContent={GroupingMappingWidget.translate(\"import.noIModels\", { iModels: displayStrings.iModels })}\n isSortable\n isLoading={isLoading}\n onRowClick={(_, row) => {\n onSelect(row.original.id);\n }}\n paginatorRenderer={paginator}\n />\n <div className=\"gmw-import-action-panel\">\n <Button onClick={backFn}>{GroupingMappingWidget.translate(\"common.back\")}</Button>\n <Button onClick={onCancel}>{GroupingMappingWidget.translate(\"common.cancel\")}</Button>\n </div>\n </div>\n );\n};\n\nexport default SelectIModel;\n"]}
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
2
  import "./SelectITwin.scss";
3
- declare const defaultDisplayStrings: {
3
+ declare const getDefaultDisplayStrings: () => {
4
4
  iTwins: string;
5
5
  iTwinNumber: string;
6
6
  iTwinName: string;
@@ -15,7 +15,7 @@ interface SelectITwinProps {
15
15
  onSelect: (iTwinId: string) => void;
16
16
  onCancel: () => void;
17
17
  onChangeITwinType: (iTwinType: number) => void;
18
- displayStrings?: Partial<typeof defaultDisplayStrings>;
18
+ displayStrings?: Partial<ReturnType<typeof getDefaultDisplayStrings>>;
19
19
  defaultITwinType?: ITwinType;
20
20
  }
21
21
  declare const SelectITwin: ({ onSelect, onCancel, onChangeITwinType, displayStrings: userDisplayStrings, defaultITwinType, }: SelectITwinProps) => JSX.Element;
@@ -2,26 +2,27 @@ import { ITwinSubClass } from "@itwin/itwins-client";
2
2
  import { SvgCalendar, SvgList, SvgStarHollow } from "@itwin/itwinui-icons-react";
3
3
  import { Button, Tab, Table, tableFilters, TablePaginator, Tabs } from "@itwin/itwinui-react";
4
4
  import React, { useCallback, useMemo, useState } from "react";
5
+ import { GroupingMappingWidget } from "../../../GroupingMappingWidget";
5
6
  import "./SelectITwin.scss";
6
7
  import { useGroupingMappingApiConfig } from "../../context/GroupingApiConfigContext";
7
8
  import { useITwinsClient } from "../../context/ITwinsClientContext";
8
9
  import { useQuery } from "@tanstack/react-query";
9
- const defaultDisplayStrings = {
10
+ const getDefaultDisplayStrings = () => ({
10
11
  iTwins: "iTwins",
11
- iTwinNumber: "Number",
12
- iTwinName: "Name",
13
- iTwinStatus: "Status",
14
- };
12
+ iTwinNumber: GroupingMappingWidget.translate("common.number"),
13
+ iTwinName: GroupingMappingWidget.translate("common.name"),
14
+ iTwinStatus: GroupingMappingWidget.translate("common.status"),
15
+ });
15
16
  export var ITwinType;
16
17
  (function (ITwinType) {
17
18
  ITwinType[ITwinType["Favorite"] = 0] = "Favorite";
18
19
  ITwinType[ITwinType["Recent"] = 1] = "Recent";
19
20
  ITwinType[ITwinType["All"] = 2] = "All";
20
21
  })(ITwinType || (ITwinType = {}));
21
- const tabsWithIcons = [
22
- React.createElement(Tab, { key: "favorite", label: "Favorite iTwins", startIcon: React.createElement(SvgStarHollow, null) }),
23
- React.createElement(Tab, { key: "recents", label: "Recent iTwins", startIcon: React.createElement(SvgCalendar, null) }),
24
- React.createElement(Tab, { key: "all", label: "My iTwins", startIcon: React.createElement(SvgList, null) }),
22
+ const getTabsWithIcons = () => [
23
+ React.createElement(Tab, { key: "favorite", label: GroupingMappingWidget.translate("import.favoriteITwins"), startIcon: React.createElement(SvgStarHollow, null) }),
24
+ React.createElement(Tab, { key: "recents", label: GroupingMappingWidget.translate("import.recentITwins"), startIcon: React.createElement(SvgCalendar, null) }),
25
+ React.createElement(Tab, { key: "all", label: GroupingMappingWidget.translate("import.myITwins"), startIcon: React.createElement(SvgList, null) }),
25
26
  ];
26
27
  const fetchITwins = async (getAccessToken, iTwinsClient, iTwinType) => {
27
28
  const accessToken = await getAccessToken();
@@ -42,7 +43,7 @@ const SelectITwin = ({ onSelect, onCancel, onChangeITwinType, displayStrings: us
42
43
  queryKey: ["iTwinsByType", iTwinType],
43
44
  queryFn: async () => (await fetchITwins(getAccessToken, iTwinsClient, iTwinType)).data,
44
45
  });
45
- const displayStrings = React.useMemo(() => ({ ...defaultDisplayStrings, ...userDisplayStrings }), [userDisplayStrings]);
46
+ const displayStrings = React.useMemo(() => ({ ...getDefaultDisplayStrings(), ...userDisplayStrings }), [userDisplayStrings]);
46
47
  const iTwinsColumns = useMemo(() => [
47
48
  {
48
49
  id: "iTwinNumber",
@@ -66,15 +67,15 @@ const SelectITwin = ({ onSelect, onCancel, onChangeITwinType, displayStrings: us
66
67
  const pageSizeList = useMemo(() => [10, 25, 50], []);
67
68
  const paginator = useCallback((props) => React.createElement(TablePaginator, { ...props, pageSizeList: pageSizeList }), [pageSizeList]);
68
69
  return (React.createElement("div", { className: "gmw-select-itwin-table-container" },
69
- React.createElement(Tabs, { orientation: "horizontal", labels: tabsWithIcons, onTabSelected: (type) => {
70
+ React.createElement(Tabs, { orientation: "horizontal", labels: getTabsWithIcons(), onTabSelected: (type) => {
70
71
  onChangeITwinType(type);
71
72
  setITwinType(type);
72
73
  }, activeIndex: iTwinType, type: "borderless", contentClassName: "gmw-table-holding-tab" }),
73
- React.createElement(Table, { data: iTwins ?? [], columns: iTwinsColumns, className: "gmw-select-itwin-table", emptyTableContent: `No ${displayStrings.iTwins} available.`, isSortable: true, isLoading: isLoading, onRowClick: (_, row) => {
74
+ React.createElement(Table, { data: iTwins ?? [], columns: iTwinsColumns, className: "gmw-select-itwin-table", emptyTableContent: GroupingMappingWidget.translate("import.noITwins", { iTwins: displayStrings.iTwins }), isSortable: true, isLoading: isLoading, onRowClick: (_, row) => {
74
75
  onSelect(row.original.id);
75
76
  }, paginatorRenderer: paginator }),
76
77
  React.createElement("div", { className: "gmw-import-action-panel" },
77
- React.createElement(Button, { onClick: onCancel }, "Cancel"))));
78
+ React.createElement(Button, { onClick: onCancel }, GroupingMappingWidget.translate("common.cancel")))));
78
79
  };
79
80
  export default SelectITwin;
80
81
  //# sourceMappingURL=SelectITwin.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SelectITwin.js","sourceRoot":"","sources":["../../../../../src/components/Mappings/Import/SelectITwin.tsx"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\nimport type { ITwin, ITwinsAccessClient } from \"@itwin/itwins-client\";\nimport { ITwinSubClass } from \"@itwin/itwins-client\";\nimport { SvgCalendar, SvgList, SvgStarHollow } from \"@itwin/itwinui-icons-react\";\nimport type { TablePaginatorRendererProps } from \"@itwin/itwinui-react\";\nimport { Button, Tab, Table, tableFilters, TablePaginator, Tabs } from \"@itwin/itwinui-react\";\nimport React, { useCallback, useMemo, useState } from \"react\";\nimport type { CreateTypeFromInterface } from \"../../../common/utils\";\nimport \"./SelectITwin.scss\";\nimport type { GetAccessTokenFn } from \"../../context/GroupingApiConfigContext\";\nimport { useGroupingMappingApiConfig } from \"../../context/GroupingApiConfigContext\";\nimport { useITwinsClient } from \"../../context/ITwinsClientContext\";\nimport { useQuery } from \"@tanstack/react-query\";\nimport type { Column } from \"react-table\";\n\ntype IITwinTyped = CreateTypeFromInterface<ITwin>;\n\nconst defaultDisplayStrings = {\n iTwins: \"iTwins\",\n iTwinNumber: \"Number\",\n iTwinName: \"Name\",\n iTwinStatus: \"Status\",\n};\n\nexport enum ITwinType {\n Favorite = 0,\n Recent = 1,\n All = 2,\n}\n\nconst tabsWithIcons = [\n <Tab key=\"favorite\" label=\"Favorite iTwins\" startIcon={<SvgStarHollow />} />,\n <Tab key=\"recents\" label=\"Recent iTwins\" startIcon={<SvgCalendar />} />,\n <Tab key=\"all\" label=\"My iTwins\" startIcon={<SvgList />} />,\n];\n\nconst fetchITwins = async (getAccessToken: GetAccessTokenFn, iTwinsClient: ITwinsAccessClient, iTwinType: ITwinType) => {\n const accessToken = await getAccessToken();\n switch (iTwinType) {\n case ITwinType.Favorite:\n return iTwinsClient.queryFavoritesAsync(accessToken, ITwinSubClass.Project);\n case ITwinType.Recent:\n return iTwinsClient.queryRecentsAsync(accessToken, ITwinSubClass.Project);\n default:\n return iTwinsClient.queryAsync(accessToken, ITwinSubClass.Project);\n }\n};\n\ninterface SelectITwinProps {\n onSelect: (iTwinId: string) => void;\n onCancel: () => void;\n onChangeITwinType: (iTwinType: number) => void;\n displayStrings?: Partial<typeof defaultDisplayStrings>;\n defaultITwinType?: ITwinType;\n}\n\nconst SelectITwin = ({\n onSelect,\n onCancel,\n onChangeITwinType,\n displayStrings: userDisplayStrings,\n defaultITwinType = ITwinType.Favorite,\n}: SelectITwinProps) => {\n const { getAccessToken } = useGroupingMappingApiConfig();\n const iTwinsClient = useITwinsClient();\n const [iTwinType, setITwinType] = useState<number>(defaultITwinType);\n\n const { data: iTwins, isFetching: isLoading } = useQuery({\n queryKey: [\"iTwinsByType\", iTwinType],\n queryFn: async () => (await fetchITwins(getAccessToken, iTwinsClient, iTwinType)).data!,\n });\n\n const displayStrings = React.useMemo(() => ({ ...defaultDisplayStrings, ...userDisplayStrings }), [userDisplayStrings]);\n\n const iTwinsColumns = useMemo<Column<IITwinTyped>[]>(\n () => [\n {\n id: \"iTwinNumber\",\n Header: `${displayStrings.iTwinNumber}`,\n accessor: \"number\",\n Filter: tableFilters.TextFilter(),\n },\n {\n id: \"iTwinName\",\n Header: `${displayStrings.iTwinName}`,\n accessor: \"displayName\",\n Filter: tableFilters.TextFilter(),\n },\n {\n id: \"iTwinStatus\",\n Header: `${displayStrings.iTwinStatus}`,\n accessor: \"status\",\n Filter: tableFilters.TextFilter(),\n },\n ],\n [displayStrings.iTwinNumber, displayStrings.iTwinName, displayStrings.iTwinStatus],\n );\n\n const pageSizeList = useMemo(() => [10, 25, 50], []);\n const paginator = useCallback((props: TablePaginatorRendererProps) => <TablePaginator {...props} pageSizeList={pageSizeList} />, [pageSizeList]);\n\n return (\n <div className=\"gmw-select-itwin-table-container\">\n <Tabs\n orientation=\"horizontal\"\n labels={tabsWithIcons}\n onTabSelected={(type) => {\n onChangeITwinType(type);\n setITwinType(type);\n }}\n activeIndex={iTwinType}\n type={\"borderless\"}\n contentClassName=\"gmw-table-holding-tab\"\n ></Tabs>\n <Table<IITwinTyped>\n data={iTwins ?? []}\n columns={iTwinsColumns}\n className=\"gmw-select-itwin-table\"\n emptyTableContent={`No ${displayStrings.iTwins} available.`}\n isSortable\n isLoading={isLoading}\n onRowClick={(_, row) => {\n onSelect(row.original.id!);\n }}\n paginatorRenderer={paginator}\n />\n <div className=\"gmw-import-action-panel\">\n <Button onClick={onCancel}>Cancel</Button>\n </div>\n </div>\n );\n};\n\nexport default SelectITwin;\n"]}
1
+ {"version":3,"file":"SelectITwin.js","sourceRoot":"","sources":["../../../../../src/components/Mappings/Import/SelectITwin.tsx"],"names":[],"mappings":"AAKA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAEjF,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,YAAY,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAC9F,OAAO,KAAK,EAAE,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AAEvE,OAAO,oBAAoB,CAAC;AAE5B,OAAO,EAAE,2BAA2B,EAAE,MAAM,wCAAwC,CAAC;AACrF,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAKjD,MAAM,wBAAwB,GAAG,GAAG,EAAE,CAAC,CAAC;IACtC,MAAM,EAAE,QAAQ;IAChB,WAAW,EAAE,qBAAqB,CAAC,SAAS,CAAC,eAAe,CAAC;IAC7D,SAAS,EAAE,qBAAqB,CAAC,SAAS,CAAC,aAAa,CAAC;IACzD,WAAW,EAAE,qBAAqB,CAAC,SAAS,CAAC,eAAe,CAAC;CAC9D,CAAC,CAAC;AAEH,MAAM,CAAN,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,iDAAY,CAAA;IACZ,6CAAU,CAAA;IACV,uCAAO,CAAA;AACT,CAAC,EAJW,SAAS,KAAT,SAAS,QAIpB;AAED,MAAM,gBAAgB,GAAG,GAAG,EAAE,CAAC;IAC7B,oBAAC,GAAG,IAAC,GAAG,EAAC,UAAU,EAAC,KAAK,EAAE,qBAAqB,CAAC,SAAS,CAAC,uBAAuB,CAAC,EAAE,SAAS,EAAE,oBAAC,aAAa,OAAG,GAAI;IACrH,oBAAC,GAAG,IAAC,GAAG,EAAC,SAAS,EAAC,KAAK,EAAE,qBAAqB,CAAC,SAAS,CAAC,qBAAqB,CAAC,EAAE,SAAS,EAAE,oBAAC,WAAW,OAAG,GAAI;IAChH,oBAAC,GAAG,IAAC,GAAG,EAAC,KAAK,EAAC,KAAK,EAAE,qBAAqB,CAAC,SAAS,CAAC,iBAAiB,CAAC,EAAE,SAAS,EAAE,oBAAC,OAAO,OAAG,GAAI;CACrG,CAAC;AAEF,MAAM,WAAW,GAAG,KAAK,EAAE,cAAgC,EAAE,YAAgC,EAAE,SAAoB,EAAE,EAAE;IACrH,MAAM,WAAW,GAAG,MAAM,cAAc,EAAE,CAAC;IAC3C,QAAQ,SAAS,EAAE;QACjB,KAAK,SAAS,CAAC,QAAQ;YACrB,OAAO,YAAY,CAAC,mBAAmB,CAAC,WAAW,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;QAC9E,KAAK,SAAS,CAAC,MAAM;YACnB,OAAO,YAAY,CAAC,iBAAiB,CAAC,WAAW,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;QAC5E;YACE,OAAO,YAAY,CAAC,UAAU,CAAC,WAAW,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;KACtE;AACH,CAAC,CAAC;AAUF,MAAM,WAAW,GAAG,CAAC,EACnB,QAAQ,EACR,QAAQ,EACR,iBAAiB,EACjB,cAAc,EAAE,kBAAkB,EAClC,gBAAgB,GAAG,SAAS,CAAC,QAAQ,GACpB,EAAE,EAAE;IACrB,MAAM,EAAE,cAAc,EAAE,GAAG,2BAA2B,EAAE,CAAC;IACzD,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;IACvC,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAS,gBAAgB,CAAC,CAAC;IAErE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,QAAQ,CAAC;QACvD,QAAQ,EAAE,CAAC,cAAc,EAAE,SAAS,CAAC;QACrC,OAAO,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,MAAM,WAAW,CAAC,cAAc,EAAE,YAAY,EAAE,SAAS,CAAC,CAAC,CAAC,IAAK;KACxF,CAAC,CAAC;IAEH,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,wBAAwB,EAAE,EAAE,GAAG,kBAAkB,EAAE,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC,CAAC;IAE7H,MAAM,aAAa,GAAG,OAAO,CAC3B,GAAG,EAAE,CAAC;QACJ;YACE,EAAE,EAAE,aAAa;YACjB,MAAM,EAAE,GAAG,cAAc,CAAC,WAAW,EAAE;YACvC,QAAQ,EAAE,QAAQ;YAClB,MAAM,EAAE,YAAY,CAAC,UAAU,EAAE;SAClC;QACD;YACE,EAAE,EAAE,WAAW;YACf,MAAM,EAAE,GAAG,cAAc,CAAC,SAAS,EAAE;YACrC,QAAQ,EAAE,aAAa;YACvB,MAAM,EAAE,YAAY,CAAC,UAAU,EAAE;SAClC;QACD;YACE,EAAE,EAAE,aAAa;YACjB,MAAM,EAAE,GAAG,cAAc,CAAC,WAAW,EAAE;YACvC,QAAQ,EAAE,QAAQ;YAClB,MAAM,EAAE,YAAY,CAAC,UAAU,EAAE;SAClC;KACF,EACD,CAAC,cAAc,CAAC,WAAW,EAAE,cAAc,CAAC,SAAS,EAAE,cAAc,CAAC,WAAW,CAAC,CACnF,CAAC;IAEF,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IACrD,MAAM,SAAS,GAAG,WAAW,CAAC,CAAC,KAAkC,EAAE,EAAE,CAAC,oBAAC,cAAc,OAAK,KAAK,EAAE,YAAY,EAAE,YAAY,GAAI,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAEjJ,OAAO,CACL,6BAAK,SAAS,EAAC,kCAAkC;QAC/C,oBAAC,IAAI,IACH,WAAW,EAAC,YAAY,EACxB,MAAM,EAAE,gBAAgB,EAAE,EAC1B,aAAa,EAAE,CAAC,IAAI,EAAE,EAAE;gBACtB,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBACxB,YAAY,CAAC,IAAI,CAAC,CAAC;YACrB,CAAC,EACD,WAAW,EAAE,SAAS,EACtB,IAAI,EAAE,YAAY,EAClB,gBAAgB,EAAC,uBAAuB,GAClC;QACR,oBAAC,KAAK,IACJ,IAAI,EAAE,MAAM,IAAI,EAAE,EAClB,OAAO,EAAE,aAAa,EACtB,SAAS,EAAC,wBAAwB,EAClC,iBAAiB,EAAE,qBAAqB,CAAC,SAAS,CAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,cAAc,CAAC,MAAM,EAAE,CAAC,EACxG,UAAU,QACV,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;gBACrB,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAG,CAAC,CAAC;YAC7B,CAAC,EACD,iBAAiB,EAAE,SAAS,GAC5B;QACF,6BAAK,SAAS,EAAC,yBAAyB;YACtC,oBAAC,MAAM,IAAC,OAAO,EAAE,QAAQ,IAAG,qBAAqB,CAAC,SAAS,CAAC,eAAe,CAAC,CAAU,CAClF,CACF,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,WAAW,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\nimport type { ITwin, ITwinsAccessClient } from \"@itwin/itwins-client\";\nimport { ITwinSubClass } from \"@itwin/itwins-client\";\nimport { SvgCalendar, SvgList, SvgStarHollow } from \"@itwin/itwinui-icons-react\";\nimport type { TablePaginatorRendererProps } from \"@itwin/itwinui-react\";\nimport { Button, Tab, Table, tableFilters, TablePaginator, Tabs } from \"@itwin/itwinui-react\";\nimport React, { useCallback, useMemo, useState } from \"react\";\nimport { GroupingMappingWidget } from \"../../../GroupingMappingWidget\";\nimport type { CreateTypeFromInterface } from \"../../../common/utils\";\nimport \"./SelectITwin.scss\";\nimport type { GetAccessTokenFn } from \"../../context/GroupingApiConfigContext\";\nimport { useGroupingMappingApiConfig } from \"../../context/GroupingApiConfigContext\";\nimport { useITwinsClient } from \"../../context/ITwinsClientContext\";\nimport { useQuery } from \"@tanstack/react-query\";\nimport type { Column } from \"react-table\";\n\ntype IITwinTyped = CreateTypeFromInterface<ITwin>;\n\nconst getDefaultDisplayStrings = () => ({\n iTwins: \"iTwins\",\n iTwinNumber: GroupingMappingWidget.translate(\"common.number\"),\n iTwinName: GroupingMappingWidget.translate(\"common.name\"),\n iTwinStatus: GroupingMappingWidget.translate(\"common.status\"),\n});\n\nexport enum ITwinType {\n Favorite = 0,\n Recent = 1,\n All = 2,\n}\n\nconst getTabsWithIcons = () => [\n <Tab key=\"favorite\" label={GroupingMappingWidget.translate(\"import.favoriteITwins\")} startIcon={<SvgStarHollow />} />,\n <Tab key=\"recents\" label={GroupingMappingWidget.translate(\"import.recentITwins\")} startIcon={<SvgCalendar />} />,\n <Tab key=\"all\" label={GroupingMappingWidget.translate(\"import.myITwins\")} startIcon={<SvgList />} />,\n];\n\nconst fetchITwins = async (getAccessToken: GetAccessTokenFn, iTwinsClient: ITwinsAccessClient, iTwinType: ITwinType) => {\n const accessToken = await getAccessToken();\n switch (iTwinType) {\n case ITwinType.Favorite:\n return iTwinsClient.queryFavoritesAsync(accessToken, ITwinSubClass.Project);\n case ITwinType.Recent:\n return iTwinsClient.queryRecentsAsync(accessToken, ITwinSubClass.Project);\n default:\n return iTwinsClient.queryAsync(accessToken, ITwinSubClass.Project);\n }\n};\n\ninterface SelectITwinProps {\n onSelect: (iTwinId: string) => void;\n onCancel: () => void;\n onChangeITwinType: (iTwinType: number) => void;\n displayStrings?: Partial<ReturnType<typeof getDefaultDisplayStrings>>;\n defaultITwinType?: ITwinType;\n}\n\nconst SelectITwin = ({\n onSelect,\n onCancel,\n onChangeITwinType,\n displayStrings: userDisplayStrings,\n defaultITwinType = ITwinType.Favorite,\n}: SelectITwinProps) => {\n const { getAccessToken } = useGroupingMappingApiConfig();\n const iTwinsClient = useITwinsClient();\n const [iTwinType, setITwinType] = useState<number>(defaultITwinType);\n\n const { data: iTwins, isFetching: isLoading } = useQuery({\n queryKey: [\"iTwinsByType\", iTwinType],\n queryFn: async () => (await fetchITwins(getAccessToken, iTwinsClient, iTwinType)).data!,\n });\n\n const displayStrings = React.useMemo(() => ({ ...getDefaultDisplayStrings(), ...userDisplayStrings }), [userDisplayStrings]);\n\n const iTwinsColumns = useMemo<Column<IITwinTyped>[]>(\n () => [\n {\n id: \"iTwinNumber\",\n Header: `${displayStrings.iTwinNumber}`,\n accessor: \"number\",\n Filter: tableFilters.TextFilter(),\n },\n {\n id: \"iTwinName\",\n Header: `${displayStrings.iTwinName}`,\n accessor: \"displayName\",\n Filter: tableFilters.TextFilter(),\n },\n {\n id: \"iTwinStatus\",\n Header: `${displayStrings.iTwinStatus}`,\n accessor: \"status\",\n Filter: tableFilters.TextFilter(),\n },\n ],\n [displayStrings.iTwinNumber, displayStrings.iTwinName, displayStrings.iTwinStatus],\n );\n\n const pageSizeList = useMemo(() => [10, 25, 50], []);\n const paginator = useCallback((props: TablePaginatorRendererProps) => <TablePaginator {...props} pageSizeList={pageSizeList} />, [pageSizeList]);\n\n return (\n <div className=\"gmw-select-itwin-table-container\">\n <Tabs\n orientation=\"horizontal\"\n labels={getTabsWithIcons()}\n onTabSelected={(type) => {\n onChangeITwinType(type);\n setITwinType(type);\n }}\n activeIndex={iTwinType}\n type={\"borderless\"}\n contentClassName=\"gmw-table-holding-tab\"\n ></Tabs>\n <Table<IITwinTyped>\n data={iTwins ?? []}\n columns={iTwinsColumns}\n className=\"gmw-select-itwin-table\"\n emptyTableContent={GroupingMappingWidget.translate(\"import.noITwins\", { iTwins: displayStrings.iTwins })}\n isSortable\n isLoading={isLoading}\n onRowClick={(_, row) => {\n onSelect(row.original.id!);\n }}\n paginatorRenderer={paginator}\n />\n <div className=\"gmw-import-action-panel\">\n <Button onClick={onCancel}>{GroupingMappingWidget.translate(\"common.cancel\")}</Button>\n </div>\n </div>\n );\n};\n\nexport default SelectITwin;\n"]}
@@ -1,7 +1,7 @@
1
1
  /// <reference types="react" />
2
2
  import type { IMappingTyped } from "../Mappings";
3
3
  import "./SelectMapping.scss";
4
- declare const defaultDisplayStrings: {
4
+ declare const getDefaultDisplayStrings: () => {
5
5
  mappings: string;
6
6
  };
7
7
  interface SelectMappingsProps {
@@ -9,7 +9,7 @@ interface SelectMappingsProps {
9
9
  onSelect: (selectedMappings: IMappingTyped[]) => void;
10
10
  onCancel: () => void;
11
11
  backFn: () => void;
12
- displayStrings?: Partial<typeof defaultDisplayStrings>;
12
+ displayStrings?: Partial<ReturnType<typeof getDefaultDisplayStrings>>;
13
13
  }
14
14
  declare const SelectMappings: ({ iModelId, onSelect, onCancel, backFn, displayStrings: userDisplayStrings }: SelectMappingsProps) => JSX.Element;
15
15
  export default SelectMappings;