@itwin/reports-config-widget-react 0.3.0 → 0.5.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 (263) hide show
  1. package/CHANGELOG.json +41 -0
  2. package/CHANGELOG.md +25 -2
  3. package/coverage/clover.xml +867 -0
  4. package/coverage/coverage-final.json +33 -0
  5. package/coverage/lcov-report/base.css +224 -0
  6. package/coverage/lcov-report/block-navigation.js +87 -0
  7. package/coverage/lcov-report/favicon.png +0 -0
  8. package/coverage/lcov-report/index.html +206 -0
  9. package/coverage/lcov-report/prettify.css +1 -0
  10. package/coverage/lcov-report/prettify.js +2 -0
  11. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  12. package/coverage/lcov-report/sorter.js +196 -0
  13. package/coverage/lcov-report/src/ReportsConfigWidget.ts.html +193 -0
  14. package/coverage/lcov-report/src/index.html +116 -0
  15. package/coverage/lcov-report/src/test/index.html +116 -0
  16. package/coverage/lcov-report/src/test/test-utils.tsx.html +379 -0
  17. package/coverage/lcov-report/src/widget/ReportsConfigUiProvider.tsx.html +265 -0
  18. package/coverage/lcov-report/src/widget/components/ActionPanel.tsx.html +247 -0
  19. package/coverage/lcov-report/src/widget/components/AddMappingsModal.tsx.html +589 -0
  20. package/coverage/lcov-report/src/widget/components/BulkExtractor.ts.html +664 -0
  21. package/coverage/lcov-report/src/widget/components/Constants.ts.html +112 -0
  22. package/coverage/lcov-report/src/widget/components/DeleteModal.tsx.html +367 -0
  23. package/coverage/lcov-report/src/widget/components/ExtractionStates/FailedExtractionState.tsx.html +187 -0
  24. package/coverage/lcov-report/src/widget/components/ExtractionStates/QueuedExtractionState.tsx.html +145 -0
  25. package/coverage/lcov-report/src/widget/components/ExtractionStates/RunningExtractionState.tsx.html +139 -0
  26. package/coverage/lcov-report/src/widget/components/ExtractionStates/StartingExtractionState.tsx.html +151 -0
  27. package/coverage/lcov-report/src/widget/components/ExtractionStates/SucceededExtractionState.tsx.html +190 -0
  28. package/coverage/lcov-report/src/widget/components/ExtractionStates/index.html +176 -0
  29. package/coverage/lcov-report/src/widget/components/ExtractionStatus.tsx.html +295 -0
  30. package/coverage/lcov-report/src/widget/components/ExtractionToast.tsx.html +208 -0
  31. package/coverage/lcov-report/src/widget/components/HorizontalTile.tsx.html +289 -0
  32. package/coverage/lcov-report/src/widget/components/LocalizedTablePaginator.tsx.html +262 -0
  33. package/coverage/lcov-report/src/widget/components/ReportAction.tsx.html +472 -0
  34. package/coverage/lcov-report/src/widget/components/ReportHorizontalTile.tsx.html +472 -0
  35. package/coverage/lcov-report/src/widget/components/ReportMappingHorizontalTile.tsx.html +469 -0
  36. package/coverage/lcov-report/src/widget/components/ReportMappings.tsx.html +1063 -0
  37. package/coverage/lcov-report/src/widget/components/Reports.tsx.html +754 -0
  38. package/coverage/lcov-report/src/widget/components/ReportsConfigContext.tsx.html +373 -0
  39. package/coverage/lcov-report/src/widget/components/ReportsContainer.tsx.html +301 -0
  40. package/coverage/lcov-report/src/widget/components/ReportsHeader.tsx.html +166 -0
  41. package/coverage/lcov-report/src/widget/components/ReportsRouter.tsx.html +274 -0
  42. package/coverage/lcov-report/src/widget/components/SearchBar.tsx.html +286 -0
  43. package/coverage/lcov-report/src/widget/components/SelectIModel.tsx.html +337 -0
  44. package/coverage/lcov-report/src/widget/components/index.html +416 -0
  45. package/coverage/lcov-report/src/widget/components/utils.tsx.html +565 -0
  46. package/coverage/lcov-report/src/widget/context/BulkExtractorContext.tsx.html +163 -0
  47. package/coverage/lcov-report/src/widget/context/ReportsConfigApiContext.tsx.html +202 -0
  48. package/coverage/lcov-report/src/widget/context/index.html +131 -0
  49. package/coverage/lcov-report/src/widget/hooks/index.html +116 -0
  50. package/coverage/lcov-report/src/widget/hooks/useValidator.ts.html +295 -0
  51. package/coverage/lcov-report/src/widget/index.html +116 -0
  52. package/coverage/lcov.info +1609 -0
  53. package/jest.config.js +1 -0
  54. package/lib/cjs/ReportsConfigWidget.js +1 -1
  55. package/lib/cjs/ReportsConfigWidget.js.map +1 -1
  56. package/lib/cjs/reports-config-widget-react.js +5 -1
  57. package/lib/cjs/reports-config-widget-react.js.map +1 -1
  58. package/lib/cjs/test/AddMappingModal.test.js +20 -70
  59. package/lib/cjs/test/AddMappingModal.test.js.map +1 -1
  60. package/lib/cjs/test/BulkExtractor.test.js +5 -1
  61. package/lib/cjs/test/BulkExtractor.test.js.map +1 -1
  62. package/lib/cjs/test/DeleteModal.test.js +2 -2
  63. package/lib/cjs/test/DeleteModal.test.js.map +1 -1
  64. package/lib/cjs/test/ReportAction.test.js +7 -7
  65. package/lib/cjs/test/ReportAction.test.js.map +1 -1
  66. package/lib/cjs/test/ReportMappingHorizontalTile.test.js +31 -81
  67. package/lib/cjs/test/ReportMappingHorizontalTile.test.js.map +1 -1
  68. package/lib/cjs/test/ReportMappings.test.js +38 -88
  69. package/lib/cjs/test/ReportMappings.test.js.map +1 -1
  70. package/lib/cjs/test/Reports.test.js +68 -66
  71. package/lib/cjs/test/Reports.test.js.map +1 -1
  72. package/lib/cjs/test/WidgetHeader.test.js +9 -3
  73. package/lib/cjs/test/WidgetHeader.test.js.map +1 -1
  74. package/lib/cjs/test/test-utils.d.ts +30 -0
  75. package/lib/cjs/test/test-utils.d.ts.map +1 -1
  76. package/lib/cjs/test/test-utils.js +66 -7
  77. package/lib/cjs/test/test-utils.js.map +1 -1
  78. package/lib/cjs/tsconfig.tsbuildinfo +1 -1
  79. package/lib/cjs/widget/ReportsConfigUiProvider.d.ts +3 -3
  80. package/lib/cjs/widget/ReportsConfigUiProvider.d.ts.map +1 -1
  81. package/lib/cjs/widget/ReportsConfigUiProvider.js +10 -8
  82. package/lib/cjs/widget/ReportsConfigUiProvider.js.map +1 -1
  83. package/lib/cjs/widget/components/ActionPanel.d.ts +2 -2
  84. package/lib/cjs/widget/components/ActionPanel.d.ts.map +1 -1
  85. package/lib/cjs/widget/components/ActionPanel.js +5 -1
  86. package/lib/cjs/widget/components/ActionPanel.js.map +1 -1
  87. package/lib/cjs/widget/components/ActionPanel.scss +2 -3
  88. package/lib/cjs/widget/components/AddMappingsModal.d.ts.map +1 -1
  89. package/lib/cjs/widget/components/AddMappingsModal.js +27 -28
  90. package/lib/cjs/widget/components/AddMappingsModal.js.map +1 -1
  91. package/lib/cjs/widget/components/AddMappingsModal.scss +1 -2
  92. package/lib/cjs/widget/components/BulkExtractor.js +2 -2
  93. package/lib/cjs/widget/components/BulkExtractor.js.map +1 -1
  94. package/lib/cjs/widget/components/Constants.d.ts +1 -0
  95. package/lib/cjs/widget/components/Constants.d.ts.map +1 -1
  96. package/lib/cjs/widget/components/Constants.js +2 -1
  97. package/lib/cjs/widget/components/Constants.js.map +1 -1
  98. package/lib/cjs/widget/components/DeleteModal.js +8 -4
  99. package/lib/cjs/widget/components/DeleteModal.js.map +1 -1
  100. package/lib/cjs/widget/components/DeleteModal.scss +2 -3
  101. package/lib/cjs/widget/components/ExtractionStatus.js +7 -3
  102. package/lib/cjs/widget/components/ExtractionStatus.js.map +1 -1
  103. package/lib/cjs/widget/components/ExtractionStatus.scss +6 -7
  104. package/lib/cjs/widget/components/HorizontalTile.js +2 -2
  105. package/lib/cjs/widget/components/HorizontalTile.js.map +1 -1
  106. package/lib/cjs/widget/components/HorizontalTile.scss +10 -16
  107. package/lib/cjs/widget/components/LocalizedTablePaginator.js +7 -3
  108. package/lib/cjs/widget/components/LocalizedTablePaginator.js.map +1 -1
  109. package/lib/cjs/widget/components/ReportAction.js +19 -17
  110. package/lib/cjs/widget/components/ReportAction.js.map +1 -1
  111. package/lib/cjs/widget/components/ReportAction.scss +1 -2
  112. package/lib/cjs/widget/components/ReportHorizontalTile.js +14 -12
  113. package/lib/cjs/widget/components/ReportHorizontalTile.js.map +1 -1
  114. package/lib/cjs/widget/components/ReportMappingHorizontalTile.d.ts.map +1 -1
  115. package/lib/cjs/widget/components/ReportMappingHorizontalTile.js +22 -18
  116. package/lib/cjs/widget/components/ReportMappingHorizontalTile.js.map +1 -1
  117. package/lib/cjs/widget/components/ReportMappings.d.ts.map +1 -1
  118. package/lib/cjs/widget/components/ReportMappings.js +28 -27
  119. package/lib/cjs/widget/components/ReportMappings.js.map +1 -1
  120. package/lib/cjs/widget/components/ReportMappings.scss +9 -10
  121. package/lib/cjs/widget/components/Reports.d.ts.map +1 -1
  122. package/lib/cjs/widget/components/Reports.js +26 -22
  123. package/lib/cjs/widget/components/Reports.js.map +1 -1
  124. package/lib/cjs/widget/components/Reports.scss +15 -15
  125. package/lib/cjs/widget/components/ReportsConfigContext.d.ts.map +1 -1
  126. package/lib/cjs/widget/components/ReportsConfigContext.js +29 -32
  127. package/lib/cjs/widget/components/ReportsConfigContext.js.map +1 -1
  128. package/lib/cjs/widget/components/ReportsContainer.js +9 -6
  129. package/lib/cjs/widget/components/ReportsContainer.js.map +1 -1
  130. package/lib/cjs/widget/components/ReportsContainer.scss +1 -3
  131. package/lib/cjs/widget/components/ReportsRouter.js +1 -2
  132. package/lib/cjs/widget/components/ReportsRouter.js.map +1 -1
  133. package/lib/cjs/widget/components/SearchBar.d.ts.map +1 -1
  134. package/lib/cjs/widget/components/SearchBar.js +9 -5
  135. package/lib/cjs/widget/components/SearchBar.js.map +1 -1
  136. package/lib/cjs/widget/components/SearchBar.scss +0 -1
  137. package/lib/cjs/widget/components/SelectIModel.js +11 -7
  138. package/lib/cjs/widget/components/SelectIModel.js.map +1 -1
  139. package/lib/cjs/widget/components/SelectIModel.scss +2 -3
  140. package/lib/cjs/widget/components/utils.d.ts.map +1 -1
  141. package/lib/cjs/widget/components/utils.js +1 -1
  142. package/lib/cjs/widget/components/utils.js.map +1 -1
  143. package/lib/cjs/widget/components/utils.scss +16 -8
  144. package/lib/cjs/widget/context/BulkExtractorContext.js +6 -2
  145. package/lib/cjs/widget/context/BulkExtractorContext.js.map +1 -1
  146. package/lib/cjs/widget/context/ReportsConfigApiContext.js +6 -2
  147. package/lib/cjs/widget/context/ReportsConfigApiContext.js.map +1 -1
  148. package/lib/cjs/widget/hooks/useValidator.js +1 -1
  149. package/lib/cjs/widget/hooks/useValidator.js.map +1 -1
  150. package/lib/esm/ReportsConfigWidget.js +1 -1
  151. package/lib/esm/ReportsConfigWidget.js.map +1 -1
  152. package/lib/esm/test/AddMappingModal.test.js +2 -56
  153. package/lib/esm/test/AddMappingModal.test.js.map +1 -1
  154. package/lib/esm/test/ReportMappingHorizontalTile.test.js +3 -57
  155. package/lib/esm/test/ReportMappingHorizontalTile.test.js.map +1 -1
  156. package/lib/esm/test/ReportMappings.test.js +8 -62
  157. package/lib/esm/test/ReportMappings.test.js.map +1 -1
  158. package/lib/esm/test/Reports.test.js +32 -53
  159. package/lib/esm/test/Reports.test.js.map +1 -1
  160. package/lib/esm/test/WidgetHeader.test.js +8 -2
  161. package/lib/esm/test/WidgetHeader.test.js.map +1 -1
  162. package/lib/esm/test/test-utils.d.ts +30 -0
  163. package/lib/esm/test/test-utils.d.ts.map +1 -1
  164. package/lib/esm/test/test-utils.js +59 -4
  165. package/lib/esm/test/test-utils.js.map +1 -1
  166. package/lib/esm/tsconfig.tsbuildinfo +1 -1
  167. package/lib/esm/widget/ReportsConfigUiProvider.d.ts +3 -3
  168. package/lib/esm/widget/ReportsConfigUiProvider.d.ts.map +1 -1
  169. package/lib/esm/widget/ReportsConfigUiProvider.js +2 -4
  170. package/lib/esm/widget/ReportsConfigUiProvider.js.map +1 -1
  171. package/lib/esm/widget/components/ActionPanel.d.ts +2 -2
  172. package/lib/esm/widget/components/ActionPanel.d.ts.map +1 -1
  173. package/lib/esm/widget/components/ActionPanel.js.map +1 -1
  174. package/lib/esm/widget/components/ActionPanel.scss +2 -3
  175. package/lib/esm/widget/components/AddMappingsModal.d.ts.map +1 -1
  176. package/lib/esm/widget/components/AddMappingsModal.js +10 -15
  177. package/lib/esm/widget/components/AddMappingsModal.js.map +1 -1
  178. package/lib/esm/widget/components/AddMappingsModal.scss +1 -2
  179. package/lib/esm/widget/components/Constants.d.ts +1 -0
  180. package/lib/esm/widget/components/Constants.d.ts.map +1 -1
  181. package/lib/esm/widget/components/Constants.js +1 -0
  182. package/lib/esm/widget/components/Constants.js.map +1 -1
  183. package/lib/esm/widget/components/DeleteModal.js +2 -2
  184. package/lib/esm/widget/components/DeleteModal.js.map +1 -1
  185. package/lib/esm/widget/components/DeleteModal.scss +2 -3
  186. package/lib/esm/widget/components/ExtractionStatus.scss +6 -7
  187. package/lib/esm/widget/components/HorizontalTile.scss +10 -16
  188. package/lib/esm/widget/components/ReportAction.js +7 -9
  189. package/lib/esm/widget/components/ReportAction.js.map +1 -1
  190. package/lib/esm/widget/components/ReportAction.scss +1 -2
  191. package/lib/esm/widget/components/ReportHorizontalTile.js +4 -6
  192. package/lib/esm/widget/components/ReportHorizontalTile.js.map +1 -1
  193. package/lib/esm/widget/components/ReportMappingHorizontalTile.d.ts.map +1 -1
  194. package/lib/esm/widget/components/ReportMappingHorizontalTile.js +11 -11
  195. package/lib/esm/widget/components/ReportMappingHorizontalTile.js.map +1 -1
  196. package/lib/esm/widget/components/ReportMappings.d.ts.map +1 -1
  197. package/lib/esm/widget/components/ReportMappings.js +7 -10
  198. package/lib/esm/widget/components/ReportMappings.js.map +1 -1
  199. package/lib/esm/widget/components/ReportMappings.scss +9 -10
  200. package/lib/esm/widget/components/Reports.d.ts.map +1 -1
  201. package/lib/esm/widget/components/Reports.js +9 -9
  202. package/lib/esm/widget/components/Reports.js.map +1 -1
  203. package/lib/esm/widget/components/Reports.scss +15 -15
  204. package/lib/esm/widget/components/ReportsConfigContext.d.ts.map +1 -1
  205. package/lib/esm/widget/components/ReportsConfigContext.js +21 -28
  206. package/lib/esm/widget/components/ReportsConfigContext.js.map +1 -1
  207. package/lib/esm/widget/components/ReportsContainer.js +1 -2
  208. package/lib/esm/widget/components/ReportsContainer.js.map +1 -1
  209. package/lib/esm/widget/components/ReportsContainer.scss +1 -3
  210. package/lib/esm/widget/components/ReportsRouter.js +1 -2
  211. package/lib/esm/widget/components/ReportsRouter.js.map +1 -1
  212. package/lib/esm/widget/components/SearchBar.d.ts.map +1 -1
  213. package/lib/esm/widget/components/SearchBar.js +2 -2
  214. package/lib/esm/widget/components/SearchBar.js.map +1 -1
  215. package/lib/esm/widget/components/SearchBar.scss +0 -1
  216. package/lib/esm/widget/components/SelectIModel.js +1 -1
  217. package/lib/esm/widget/components/SelectIModel.js.map +1 -1
  218. package/lib/esm/widget/components/SelectIModel.scss +2 -3
  219. package/lib/esm/widget/components/utils.d.ts.map +1 -1
  220. package/lib/esm/widget/components/utils.js +2 -2
  221. package/lib/esm/widget/components/utils.js.map +1 -1
  222. package/lib/esm/widget/components/utils.scss +16 -8
  223. package/lib/public/locales/en/ReportsConfigWidget.json +4 -0
  224. package/package.json +56 -55
  225. package/public/locales/en/ReportsConfigWidget.json +4 -0
  226. package/src/test/AddMappingModal.test.tsx +7 -57
  227. package/src/test/ReportMappingHorizontalTile.test.tsx +6 -58
  228. package/src/test/ReportMappings.test.tsx +7 -58
  229. package/src/test/Reports.test.tsx +32 -110
  230. package/src/test/WidgetHeader.test.tsx +9 -2
  231. package/src/test/test-utils.tsx +62 -1
  232. package/src/widget/ReportsConfigUiProvider.tsx +7 -14
  233. package/src/widget/components/ActionPanel.scss +2 -3
  234. package/src/widget/components/ActionPanel.tsx +1 -1
  235. package/src/widget/components/AddMappingsModal.scss +1 -2
  236. package/src/widget/components/AddMappingsModal.tsx +16 -21
  237. package/src/widget/components/Constants.ts +2 -0
  238. package/src/widget/components/DeleteModal.scss +2 -3
  239. package/src/widget/components/DeleteModal.tsx +3 -3
  240. package/src/widget/components/ExtractionStatus.scss +6 -7
  241. package/src/widget/components/HorizontalTile.scss +10 -16
  242. package/src/widget/components/ReportAction.scss +1 -2
  243. package/src/widget/components/ReportAction.tsx +3 -3
  244. package/src/widget/components/ReportHorizontalTile.tsx +1 -1
  245. package/src/widget/components/ReportMappingHorizontalTile.tsx +28 -27
  246. package/src/widget/components/ReportMappings.scss +9 -10
  247. package/src/widget/components/ReportMappings.tsx +2 -4
  248. package/src/widget/components/Reports.scss +15 -15
  249. package/src/widget/components/Reports.tsx +25 -22
  250. package/src/widget/components/ReportsConfigContext.tsx +3 -2
  251. package/src/widget/components/ReportsContainer.scss +1 -3
  252. package/src/widget/components/SearchBar.scss +0 -1
  253. package/src/widget/components/SearchBar.tsx +6 -1
  254. package/src/widget/components/SelectIModel.scss +2 -3
  255. package/src/widget/components/SelectIModel.tsx +1 -1
  256. package/src/widget/components/utils.scss +16 -8
  257. package/src/widget/components/utils.tsx +7 -6
  258. package/.rush/temp/operation/rebuild/all.log +0 -9
  259. package/.rush/temp/operation/rebuild/state.json +0 -3
  260. package/.rush/temp/package-deps_rebuild.json +0 -68
  261. package/.rush/temp/shrinkwrap-deps.json +0 -931
  262. package/reports-config-widget-react.build.error.log +0 -1
  263. package/reports-config-widget-react.build.log +0 -2
@@ -15,6 +15,7 @@ import type { CreateTypeFromInterface } from "./utils";
15
15
  import { handleError } from "./utils";
16
16
  import { ReportsConfigWidget } from "../../ReportsConfigWidget";
17
17
  import type { AccessToken } from "@itwin/core-bentley";
18
+ import type { Column } from "react-table";
18
19
 
19
20
  export type MappingType = CreateTypeFromInterface<Mapping>;
20
21
 
@@ -74,29 +75,23 @@ export const AddMappingsModal = ({
74
75
  }, [getAccessToken, mappingsClient, selectedIModelId, setIsLoading]);
75
76
 
76
77
  const mappingsColumns = useMemo(
77
- () => [
78
+ (): Column<CreateTypeFromInterface<Mapping>>[] => [
78
79
  {
79
- Header: "Table",
80
- columns: [
81
- {
82
- id: "mappingName",
83
- Header: ReportsConfigWidget.localization.getLocalizedString(
84
- "ReportsConfigWidget:MappingName"
85
- ),
86
- accessor: "mappingName",
87
- Filter: tableFilters.TextFilter(),
88
- },
89
- {
90
- id: "description",
91
- Header: ReportsConfigWidget.localization.getLocalizedString(
92
- "ReportsConfigWidget:Description"
93
- ),
94
- accessor: "description",
95
- Filter: tableFilters.TextFilter(),
96
- },
97
- ],
80
+ id: "mappingName",
81
+ Header: ReportsConfigWidget.localization.getLocalizedString(
82
+ "ReportsConfigWidget:MappingName"
83
+ ),
84
+ accessor: "mappingName",
85
+ Filter: tableFilters.TextFilter(),
98
86
  },
99
- ],
87
+ {
88
+ id: "description",
89
+ Header: ReportsConfigWidget.localization.getLocalizedString(
90
+ "ReportsConfigWidget:Description"
91
+ ),
92
+ accessor: "description",
93
+ Filter: tableFilters.TextFilter(),
94
+ }],
100
95
  []
101
96
  );
102
97
 
@@ -5,3 +5,5 @@
5
5
  export const STATUS_CHECK_INTERVAL = 5000;
6
6
  export const ANIMATION_DELAY = "5s";
7
7
  export const ANIMATION_DURATION = "1s";
8
+
9
+ export const IMODELS_BASE_URL= "https://api.bentley.com/imodels";
@@ -2,11 +2,10 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- @import "~@itwin/itwinui-css/scss/variables";
6
5
 
7
6
  .rcw-delete-modal-body-text {
8
7
  display: flex;
9
- gap: $iui-xs;
8
+ gap: var(--iui-size-2xs);
10
9
  flex-wrap: wrap;
11
10
 
12
11
  >strong {
@@ -15,5 +14,5 @@
15
14
  }
16
15
 
17
16
  .rcw-loading-delete {
18
- margin-right: $iui-s;
17
+ margin-right: var(--iui-size-xs);
19
18
  }
@@ -4,11 +4,11 @@
4
4
  *--------------------------------------------------------------------------------------------*/
5
5
  import {
6
6
  Button,
7
- Leading,
8
7
  MiddleTextTruncation,
9
8
  Modal,
10
9
  ModalButtonBar,
11
10
  ModalContent,
11
+ Text,
12
12
  } from "@itwin/itwinui-react";
13
13
  import React, { useState } from "react";
14
14
  import { ReportsConfigWidget } from "../../ReportsConfigWidget";
@@ -54,11 +54,11 @@ export const DeleteModal = ({
54
54
  >
55
55
  <ModalContent>
56
56
  <div className="rcw-delete-modal-body-text">
57
- <Leading>
57
+ <Text variant='leading'>
58
58
  {ReportsConfigWidget.localization.getLocalizedString(
59
59
  "ReportsConfigWidget:AreYouSureYouWantToDelete"
60
60
  )}
61
- </Leading>
61
+ </Text>
62
62
  <strong>{<MiddleTextTruncation text={`${entityName}?`} />}</strong>
63
63
  </div>
64
64
  </ModalContent>
@@ -2,7 +2,6 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- @import "~@itwin/itwinui-css/scss/variables";
6
5
 
7
6
  .rcw-extraction-status {
8
7
  align-items: center;
@@ -10,10 +9,10 @@
10
9
  display: flex;
11
10
 
12
11
  .rcw-status-icon {
13
- width: $iui-icons-default;
14
- height: $iui-icons-default;
12
+ width: var(--iui-size-m);
13
+ height: var(--iui-size-m);
15
14
  align-items: center;
16
- margin: auto $iui-xs * 3;
15
+ margin: auto calc(var(--iui-size-2xs) * 3);
17
16
  display: flex;
18
17
  }
19
18
  }
@@ -22,11 +21,11 @@
22
21
  align-items: center;
23
22
  height: 38px;
24
23
  display: flex;
25
- margin: auto $iui-xs * 3;
24
+ margin: auto calc(var(--iui-size-2xs) * 3);
26
25
 
27
26
  .rcw-status-icon {
28
- width: $iui-icons-default;
29
- height: $iui-icons-default;
27
+ width: var(--iui-size-m);
28
+ height: var(--iui-size-m);
30
29
  }
31
30
  }
32
31
 
@@ -2,18 +2,14 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- @import "~@itwin/itwinui-css/scss/variables";
6
- @import "~@itwin/itwinui-css/scss/icon/index";
7
-
8
5
  .rcw-horizontal-tile {
9
6
  &-container {
10
7
  display: flex;
11
8
  justify-content: space-between;
12
9
  border-radius: 5px;
13
- background-color: var(--iui-color-background-2);
14
- height: $iui-baseline * 4;
15
- min-height: 44px;
16
- padding: 5.5px $iui-s;
10
+ background-color: var(--iui-color-background-backdrop);
11
+ min-height: calc(var(--iui-size-s) * 5);
12
+ padding: 5.5px var(--iui-size-xs);
17
13
 
18
14
  .rcw-body-container {
19
15
  display: flex;
@@ -38,18 +34,16 @@
38
34
  align-self: center;
39
35
  min-width: 36px;
40
36
  flex-shrink: 0;
41
- display: flex;
37
+ margin-right: var(--iui-size-2xs);
42
38
  }
43
39
  }
44
40
 
45
41
  &-selected {
46
- @include themed {
47
- border: 1px solid t(iui-color-foreground-primary);
48
- background: linear-gradient(
49
- rgba(t(iui-color-foreground-primary-rgb), t(iui-opacity-6)),
50
- rgba(t(iui-color-foreground-primary-rgb), t(iui-opacity-6))
51
- ),
52
- linear-gradient(t(iui-color-background-1), t(iui-color-background-1));
53
- }
42
+ border: 1px solid var(--iui-color-border-accent);
43
+ background: linear-gradient(
44
+ rgba(var(--iui-color-accent-hsl), var(--iui-opacity-6)),
45
+ rgba(var(--iui-color-accent-hsl), var(--iui-opacity-6))
46
+ ),
47
+ linear-gradient(var(--iui-color-background), var(--iui-color-background));
54
48
  }
55
49
  }
@@ -2,7 +2,6 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- @import "~@itwin/itwinui-css/scss/variables";
6
5
 
7
6
  .rcw-details-form-container {
8
7
  overflow-x: auto;
@@ -11,6 +10,6 @@
11
10
  .rcw-details-form {
12
11
  display: flex;
13
12
  flex-direction: column;
14
- gap: $iui-baseline;
13
+ gap: var(--iui-size-);
15
14
  }
16
15
  }
@@ -2,7 +2,7 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- import { Fieldset, LabeledInput, Small } from "@itwin/itwinui-react";
5
+ import { Fieldset, LabeledInput, Text } from "@itwin/itwinui-react";
6
6
  import React, { useState } from "react";
7
7
  import ActionPanel from "./ActionPanel";
8
8
  import useValidator, { NAME_REQUIREMENTS } from "../hooks/useValidator";
@@ -70,11 +70,11 @@ export const ReportAction = ({ report, onSaveSuccess, onClickCancel }: ReportAct
70
70
  )}
71
71
  className="rcw-details-form"
72
72
  >
73
- <Small className="field-legend">
73
+ <Text variant='small' className="field-legend">
74
74
  {ReportsConfigWidget.localization.getLocalizedString(
75
75
  "ReportsConfigWidget:MandatoryFields"
76
76
  )}
77
- </Small>
77
+ </Text>
78
78
  <LabeledInput
79
79
  name="name"
80
80
  label={ReportsConfigWidget.localization.getLocalizedString(
@@ -111,7 +111,7 @@ export const ReportHorizontalTile = (props: ReportHorizontalTileProps) => {
111
111
  </MenuItem>,
112
112
  ].flat()}
113
113
  >
114
- <IconButton styleType="borderless">
114
+ <IconButton styleType="borderless" title={ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:ReportOptions")}>
115
115
  <SvgMore />
116
116
  </IconButton>
117
117
  </DropdownMenu>
@@ -11,7 +11,7 @@ import { ReportsConfigWidget } from "../../ReportsConfigWidget";
11
11
  import { IconButton } from "@itwin/itwinui-react";
12
12
  import {
13
13
  SvgDelete,
14
- SvgRefresh,
14
+ SvgPlay,
15
15
  } from "@itwin/itwinui-icons-react";
16
16
  import { HorizontalTile } from "./HorizontalTile";
17
17
  import type { ReportMappingAndMapping } from "./ReportMappings";
@@ -86,20 +86,33 @@ export const ReportMappingHorizontalTile = (props: ReportMappingHorizontalTilePr
86
86
  data-testid="tile-action-button">
87
87
  {extractionState === ExtractionStates.None ?
88
88
  (
89
- <IconButton
90
- styleType="borderless"
91
- title={ReportsConfigWidget.localization.getLocalizedString(
92
- "ReportsConfigWidget:UpdateDataset"
93
- )}
94
- onClick={async () => {
95
- setExtractionState(ExtractionStates.Starting);
96
- await props.bulkExtractor.runIModelExtraction(props.mapping.imodelId);
97
- props.jobStartEvent.raiseEvent(props.mapping.imodelId);
98
- }}
99
- disabled={jobStarted}
100
- >
101
- <SvgRefresh />
102
- </IconButton>
89
+ <>
90
+ <IconButton
91
+ styleType="borderless"
92
+ title={ReportsConfigWidget.localization.getLocalizedString(
93
+ "ReportsConfigWidget:UpdateDataset"
94
+ )}
95
+ onClick={async () => {
96
+ setExtractionState(ExtractionStates.Starting);
97
+ await props.bulkExtractor.runIModelExtraction(props.mapping.imodelId);
98
+ props.jobStartEvent.raiseEvent(props.mapping.imodelId);
99
+ }}
100
+ disabled={jobStarted}
101
+ >
102
+ <SvgPlay />
103
+ </IconButton>
104
+ <IconButton
105
+ styleType="borderless"
106
+ title={ReportsConfigWidget.localization.getLocalizedString(
107
+ "ReportsConfigWidget:Remove"
108
+ )}
109
+ onClick={() => {
110
+ props.onClickDelete();
111
+ }}
112
+ >
113
+ <SvgDelete />
114
+ </IconButton>
115
+ </>
103
116
  ) : (
104
117
  <ExtractionStatus
105
118
  state={extractionState}
@@ -108,18 +121,6 @@ export const ReportMappingHorizontalTile = (props: ReportMappingHorizontalTilePr
108
121
  }}
109
122
  ></ExtractionStatus>
110
123
  )}
111
- <IconButton
112
- styleType="borderless"
113
- title={ReportsConfigWidget.localization.getLocalizedString(
114
- "ReportsConfigWidget:Remove"
115
- )}
116
- onClick={() => {
117
- props.onClickDelete();
118
- }}
119
- disabled={jobStarted}
120
- >
121
- <SvgDelete />
122
- </IconButton>
123
124
  </div >
124
125
  )}
125
126
  />
@@ -2,31 +2,29 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- @import "~@itwin/itwinui-css/scss/variables";
6
5
 
7
6
  .rcw-report-mapping-misc {
8
7
  display: flex;
9
8
  flex-direction: column;
10
- gap: $iui-baseline;
9
+ gap: var(--iui-size-s);
11
10
  }
12
11
 
13
12
  .rcw-report-mappings-container {
14
13
  display: flex;
15
14
  flex-direction: column;
16
15
  flex-grow: 1;
17
- padding: $iui-baseline $iui-m;
18
16
  min-height: 0;
19
17
 
20
18
  .rcw-odata-url-input {
21
- margin-bottom: $iui-baseline * 2;
19
+ margin-bottom: calc(var(--iui-size-s) * 2);
22
20
  }
23
21
 
24
22
  .rcw-toolbar {
25
23
  display: flex;
26
24
  justify-content: space-between;
27
- gap: $iui-s;
28
- border-bottom: 1px solid var(--iui-color-background-4);
29
- padding-bottom: $iui-baseline;
25
+ gap: var(--iui-size-xs);
26
+ border-bottom: 1px solid var(--iui-color-border-subtle);
27
+ padding-bottom: var(--iui-size-s);
30
28
  flex-wrap: wrap;
31
29
  }
32
30
 
@@ -34,13 +32,14 @@
34
32
  display: flex;
35
33
  flex-direction: column;
36
34
  overflow-y: overlay;
37
- gap: 8px;
38
- margin-top: 8px;
35
+ gap: var(--iui-size-xs);
36
+ margin-top: var(--iui-size-xs);
39
37
  }
40
38
 
41
39
  .rcw-search-bar-container {
42
- flex-basis: $iui-3xl;
40
+ flex-basis: var(--iui-size-3xl);
43
41
  flex-shrink: 1;
44
42
  flex-grow: 1;
43
+ display: flex;
45
44
  }
46
45
  }
@@ -11,7 +11,6 @@ import {
11
11
  Button,
12
12
  IconButton,
13
13
  LabeledInput,
14
- Surface,
15
14
  Text,
16
15
  toaster,
17
16
  } from "@itwin/itwinui-react";
@@ -182,7 +181,7 @@ export const ReportMappings = ({ report, onClickClose, defaultIModelId }: Report
182
181
 
183
182
  return (
184
183
  <>
185
- <Surface className="rcw-report-mappings-container">
184
+ <div className="rcw-report-mappings-container">
186
185
  <LabeledInput
187
186
  label={ReportsConfigWidget.localization.getLocalizedString(
188
187
  "ReportsConfigWidget:ODataFeedURL"
@@ -195,7 +194,6 @@ export const ReportMappings = ({ report, onClickClose, defaultIModelId }: Report
195
194
  title={ReportsConfigWidget.localization.getLocalizedString(
196
195
  "ReportsConfigWidget:Copy"
197
196
  )}
198
- styleType="borderless"
199
197
  onClick={async (_) => {
200
198
  await navigator.clipboard.writeText(odataFeedUrl);
201
199
  toaster.positive(
@@ -273,7 +271,7 @@ export const ReportMappings = ({ report, onClickClose, defaultIModelId }: Report
273
271
  ))}
274
272
  </div>
275
273
  )}
276
- </Surface>
274
+ </div>
277
275
  <AddMappingsModal
278
276
  show={showAddMapping}
279
277
  reportId={report.id}
@@ -2,39 +2,39 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- @import "~@itwin/itwinui-css/scss/variables";
6
5
 
7
6
  .rcw-reports-list-container {
8
7
  display: flex;
9
8
  flex-direction: column;
10
9
  flex-grow: 1;
11
- padding: $iui-baseline $iui-m;
12
10
  min-height: 0;
13
11
 
14
12
  .rcw-toolbar {
15
13
  display: flex;
16
14
  justify-content: space-between;
17
- gap: $iui-s;
18
- border-bottom: 1px solid var(--iui-color-background-4);
19
- padding-bottom: $iui-baseline;
15
+ gap: var(--iui-size-xs);
16
+ border-bottom: 1px solid var(--iui-color-border-subtle);
17
+ padding-bottom: var(--iui-size-s);
20
18
  flex-wrap: wrap;
21
- }
22
19
 
23
- .rcw-search-bar-container {
24
- flex-basis: $iui-3xl;
25
- flex-shrink: 1;
26
- flex-grow: 1;
20
+ .rcw-search-bar-container {
21
+ flex-shrink: 1;
22
+ flex-grow: 0;
23
+ display: flex;
24
+ }
25
+
26
+ .rcw-button-spacing {
27
+ display: flex;
28
+ gap: var(--iui-size-xs);
29
+ }
27
30
  }
28
31
 
29
32
  .rcw-reports-list {
30
33
  display: flex;
31
34
  flex-direction: column;
32
35
  overflow-y: overlay;
33
- gap: 7.5px;
34
- margin-top: 7.5px;
36
+ gap: var(--iui-size-xs);
37
+ margin-top: var(--iui-size-xs);
35
38
  }
36
39
  }
37
40
 
38
- .rcw-button-container {
39
- display: flex;
40
- }
@@ -3,7 +3,7 @@
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
5
  import { SvgAdd, SvgPlay, SvgRefresh } from "@itwin/itwinui-icons-react";
6
- import { Button, IconButton, Surface } from "@itwin/itwinui-react";
6
+ import { Button, IconButton } from "@itwin/itwinui-react";
7
7
  import React, { useCallback, useEffect, useMemo, useState } from "react";
8
8
  import type { CreateTypeFromInterface } from "./utils";
9
9
  import {
@@ -121,28 +121,31 @@ export const Reports = ({
121
121
 
122
122
  return (
123
123
  <>
124
- <Surface className="rcw-reports-list-container">
124
+ <div className="rcw-reports-list-container">
125
125
  <div className="rcw-toolbar">
126
- {onClickAddReport && (
127
- <Button
128
- startIcon={<SvgAdd />}
129
- onClick={onClickAddReport}
130
- styleType="high-visibility"
131
- >
132
- {ReportsConfigWidget.localization.getLocalizedString(
133
- "ReportsConfigWidget:New"
134
- )}
135
- </Button>
136
- )}
137
- <IconButton
138
- title={ReportsConfigWidget.localization.getLocalizedString(
139
- "ReportsConfigWidget:UpdateDatasets"
126
+ <div className="rcw-button-spacing">
127
+ {onClickAddReport && (
128
+ <Button
129
+ startIcon={<SvgAdd />}
130
+ onClick={onClickAddReport}
131
+ styleType="high-visibility"
132
+ title="New Report"
133
+ >
134
+ {ReportsConfigWidget.localization.getLocalizedString(
135
+ "ReportsConfigWidget:New"
136
+ )}
137
+ </Button>
140
138
  )}
141
- onClick={updateDatasets}
142
- disabled={selectedReportIds.length === 0}
143
- >
144
- <SvgPlay />
145
- </IconButton>
139
+ <IconButton
140
+ title={ReportsConfigWidget.localization.getLocalizedString(
141
+ "ReportsConfigWidget:UpdateDatasets"
142
+ )}
143
+ onClick={updateDatasets}
144
+ disabled={selectedReportIds.length === 0}
145
+ >
146
+ <SvgPlay />
147
+ </IconButton>
148
+ </div>
146
149
  <div
147
150
  className="rcw-search-bar-container"
148
151
  data-testid="rcw-search-bar"
@@ -202,7 +205,7 @@ export const Reports = ({
202
205
  ))}
203
206
  </div>
204
207
  )}
205
- </Surface>
208
+ </div>
206
209
  <DeleteModal
207
210
  entityName={showDeleteModal?.displayName}
208
211
  onClose={() => setShowDeleteModal(undefined)}
@@ -4,7 +4,7 @@
4
4
  *--------------------------------------------------------------------------------------------*/
5
5
  import { IModelApp } from "@itwin/core-frontend";
6
6
  import type { IModelsClientOptions } from "@itwin/imodels-client-management";
7
- import { Constants, IModelsClient } from "@itwin/imodels-client-management";
7
+ import { IModelsClient } from "@itwin/imodels-client-management";
8
8
  import { ExtractionClient, MappingsClient, REPORTING_BASE_PATH, ReportsClient } from "@itwin/insights-client";
9
9
  import { toaster } from "@itwin/itwinui-react";
10
10
  import React, { useCallback, useEffect, useMemo, useState } from "react";
@@ -16,6 +16,7 @@ import type {
16
16
  import { ReportsConfigApiContext } from "../context/ReportsConfigApiContext";
17
17
  import { REPORTS_CONFIG_BASE_URL } from "../ReportsConfigUiProvider";
18
18
  import { BulkExtractor } from "./BulkExtractor";
19
+ import { IMODELS_BASE_URL } from "./Constants";
19
20
  import { FailedExtractionToast, SuccessfulExtractionToast } from "./ExtractionToast";
20
21
  import { generateUrl } from "./utils";
21
22
 
@@ -40,7 +41,7 @@ export const ReportsConfigContext = (props: ReportsConfigContextProps) => {
40
41
  props.baseUrl || REPORTS_CONFIG_BASE_URL
41
42
  ), [props.baseUrl]);
42
43
  const iModelClientOptions: IModelsClientOptions = useMemo(() => ({
43
- api: { baseUrl: generateUrl(Constants.api.baseUrl, props.baseUrl ?? REPORTS_CONFIG_BASE_URL) },
44
+ api: { baseUrl: generateUrl(IMODELS_BASE_URL, props.baseUrl ?? REPORTS_CONFIG_BASE_URL) },
44
45
  }), [props.baseUrl]);
45
46
  const [extractionClient, setExtractionClient] = useState<ExtractionClient>(
46
47
  props.extractionClient ?? new ExtractionClient(reportsBaseUrl())
@@ -2,7 +2,6 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- @import "~@itwin/itwinui-css/scss/variables";
6
5
 
7
6
  .rcw-reports-container {
8
7
  position: absolute;
@@ -10,9 +9,8 @@
10
9
  left: 0;
11
10
  display: flex;
12
11
  flex-direction: column;
13
- padding: $iui-baseline $iui-m;
12
+ padding: var(--iui-size-s) var(--iui-size-m);
14
13
  box-sizing: border-box;
15
14
  height: 100%;
16
15
  overflow: auto;
17
- gap: $iui-baseline;
18
16
  }
@@ -2,7 +2,6 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- @import "~@itwin/itwinui-css/scss/variables";
6
5
 
7
6
  @keyframes rcw-expand {
8
7
  0% {
@@ -44,6 +44,7 @@ export const SearchBar = ({
44
44
  <IconButton
45
45
  onClick={() => setSearchBarClosing(true)}
46
46
  styleType="borderless"
47
+ title={ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:ClearSearch")}
47
48
  >
48
49
  <SvgCloseSmall />
49
50
  </IconButton>
@@ -55,7 +56,11 @@ export const SearchBar = ({
55
56
  />
56
57
  </div>
57
58
  ) : (
58
- <IconButton styleType="borderless" data-testid="rcw-search-button" onClick={() => setSearchBarOpened(true)}>
59
+ <IconButton
60
+ styleType="borderless"
61
+ data-testid="rcw-search-button"
62
+ title={ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:SearchReport")}
63
+ onClick={() => setSearchBarOpened(true)}>
59
64
  <SvgSearch />
60
65
  </IconButton>
61
66
  );
@@ -2,15 +2,14 @@
2
2
  * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
- @import "~@itwin/itwinui-css/scss/variables";
6
5
 
7
6
  .rcw-select-imodel {
8
7
  position: relative;
9
- margin-bottom: $iui-baseline * 2;
8
+ margin-bottom: calc(var(--iui-size-s) * 2);
10
9
 
11
10
  .rcw-combobox {
12
11
  display: flex;
13
- gap: $iui-s;
12
+ gap: var(--iui-size-xs);
14
13
  width: 100%;
15
14
  }
16
15
  }
@@ -27,7 +27,7 @@ const fetchIModels = async (
27
27
  const accessToken = await getAccessToken();
28
28
  const authorization = AccessTokenAdapter.toAuthorizationCallback(accessToken);
29
29
  const getiModelListParams: GetIModelListParams = {
30
- urlParams: { projectId: iTwinId },
30
+ urlParams: { iTwinId },
31
31
  authorization,
32
32
  };
33
33
  const iModels = await toArray(