@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
@@ -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
 
@@ -10,10 +10,10 @@ require("./HorizontalTile.scss");
10
10
  const classnames_1 = __importDefault(require("classnames"));
11
11
  const HorizontalTile = (props) => {
12
12
  const { title, titleTooltip, subText, subtextToolTip, actionGroup, selected, className, onClickTitle, ...rest } = props;
13
- return (react_1.default.createElement("div", { className: classnames_1.default("rcw-horizontal-tile-container", { "rcw-horizontal-tile-selected": selected }, className), onClick: rest.onClick, "data-testid": "horizontal-tile" },
13
+ return (react_1.default.createElement("div", { className: (0, classnames_1.default)("rcw-horizontal-tile-container", { "rcw-horizontal-tile-selected": selected }, className), onClick: rest.onClick, "data-testid": "horizontal-tile" },
14
14
  react_1.default.createElement("div", { className: "rcw-body-container" },
15
15
  react_1.default.createElement("div", { className: "rcw-body" },
16
- react_1.default.createElement(itwinui_react_1.Text, { className: classnames_1.default("rcw-body-text", { "iui-anchor": !!onClickTitle }), onClick: onClickTitle, variant: "body", title: titleTooltip }, title),
16
+ react_1.default.createElement(itwinui_react_1.Text, { className: (0, classnames_1.default)("rcw-body-text", { "iui-anchor": !!onClickTitle }), onClick: onClickTitle, variant: "body", title: titleTooltip }, title),
17
17
  subText &&
18
18
  react_1.default.createElement(itwinui_react_1.Text, { className: "rcw-body-text", isMuted: true, title: subtextToolTip, variant: "small" }, subText))),
19
19
  react_1.default.createElement("div", { className: "rcw-action-button", "data-testid": "tile-action-button" }, actionGroup)));
@@ -1 +1 @@
1
- {"version":3,"file":"HorizontalTile.js","sourceRoot":"","sources":["../../../../src/widget/components/HorizontalTile.tsx"],"names":[],"mappings":";;;;;;AAKA,kDAA0B;AAC1B,wDAA4C;AAC5C,iCAA+B;AAC/B,4DAAoC;AAY7B,MAAM,cAAc,GAAG,CAAC,KAA0B,EAAE,EAAE;IAC3D,MAAM,EACJ,KAAK,EACL,YAAY,EACZ,OAAO,EACP,cAAc,EACd,WAAW,EACX,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,GAAG,IAAI,EACR,GAAG,KAAK,CAAC;IAEV,OAAO,CACL,uCACE,SAAS,EAAE,oBAAU,CACnB,+BAA+B,EAC/B,EAAE,8BAA8B,EAAE,QAAQ,EAAE,EAC5C,SAAS,CACV,EACD,OAAO,EAAE,IAAI,CAAC,OAAO,iBACT,iBAAiB;QAE7B,uCAAK,SAAS,EAAC,oBAAoB;YACjC,uCAAK,SAAS,EAAC,UAAU;gBACvB,8BAAC,oBAAI,IAAC,SAAS,EAAE,oBAAU,CAAC,eAAe,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC,YAAY,EAAE,CAAC,EAC5E,OAAO,EAAE,YAAY,EACrB,OAAO,EAAC,MAAM,EACd,KAAK,EAAE,YAAY,IAAG,KAAK,CACtB;gBAEL,OAAO;oBACP,8BAAC,oBAAI,IAAC,SAAS,EAAC,eAAe,EAC7B,OAAO,EAAE,IAAI,EACb,KAAK,EAAE,cAAc,EACrB,OAAO,EAAC,OAAO,IAAE,OAAO,CACnB,CAEL,CACF;QACN,uCACE,SAAS,EAAC,mBAAmB,iBACjB,oBAAoB,IAC/B,WAAW,CACR,CACF,CACP,CAAC;AACJ,CAAC,CAAC;AA/CW,QAAA,cAAc,kBA+CzB","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 { ReactNode } from \"react\";\nimport React from \"react\";\nimport { Text } from \"@itwin/itwinui-react\";\nimport \"./HorizontalTile.scss\";\nimport classNames from \"classnames\";\n\nexport interface HorizontalTileProps extends React.ComponentPropsWithoutRef<\"div\"> {\n title: string;\n actionGroup: ReactNode;\n subText: string;\n onClickTitle?: React.MouseEventHandler;\n titleTooltip: string;\n subtextToolTip?: string;\n selected?: boolean;\n}\n\nexport const HorizontalTile = (props: HorizontalTileProps) => {\n const {\n title,\n titleTooltip,\n subText,\n subtextToolTip,\n actionGroup,\n selected,\n className,\n onClickTitle,\n ...rest\n } = props;\n\n return (\n <div\n className={classNames(\n \"rcw-horizontal-tile-container\",\n { \"rcw-horizontal-tile-selected\": selected },\n className\n )}\n onClick={rest.onClick}\n data-testid=\"horizontal-tile\"\n >\n <div className=\"rcw-body-container\">\n <div className=\"rcw-body\">\n <Text className={classNames(\"rcw-body-text\", { \"iui-anchor\": !!onClickTitle })}\n onClick={onClickTitle}\n variant=\"body\"\n title={titleTooltip}>{title}\n </Text>\n {\n subText &&\n <Text className=\"rcw-body-text\"\n isMuted={true}\n title={subtextToolTip}\n variant=\"small\">{subText}\n </Text>\n }\n </div>\n </div>\n <div\n className=\"rcw-action-button\"\n data-testid=\"tile-action-button\">\n {actionGroup}\n </div>\n </div>\n );\n};\n"]}
1
+ {"version":3,"file":"HorizontalTile.js","sourceRoot":"","sources":["../../../../src/widget/components/HorizontalTile.tsx"],"names":[],"mappings":";;;;;;AAKA,kDAA0B;AAC1B,wDAA4C;AAC5C,iCAA+B;AAC/B,4DAAoC;AAY7B,MAAM,cAAc,GAAG,CAAC,KAA0B,EAAE,EAAE;IAC3D,MAAM,EACJ,KAAK,EACL,YAAY,EACZ,OAAO,EACP,cAAc,EACd,WAAW,EACX,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,GAAG,IAAI,EACR,GAAG,KAAK,CAAC;IAEV,OAAO,CACL,uCACE,SAAS,EAAE,IAAA,oBAAU,EACnB,+BAA+B,EAC/B,EAAE,8BAA8B,EAAE,QAAQ,EAAE,EAC5C,SAAS,CACV,EACD,OAAO,EAAE,IAAI,CAAC,OAAO,iBACT,iBAAiB;QAE7B,uCAAK,SAAS,EAAC,oBAAoB;YACjC,uCAAK,SAAS,EAAC,UAAU;gBACvB,8BAAC,oBAAI,IAAC,SAAS,EAAE,IAAA,oBAAU,EAAC,eAAe,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC,YAAY,EAAE,CAAC,EAC5E,OAAO,EAAE,YAAY,EACrB,OAAO,EAAC,MAAM,EACd,KAAK,EAAE,YAAY,IAAG,KAAK,CACtB;gBAEL,OAAO;oBACP,8BAAC,oBAAI,IAAC,SAAS,EAAC,eAAe,EAC7B,OAAO,EAAE,IAAI,EACb,KAAK,EAAE,cAAc,EACrB,OAAO,EAAC,OAAO,IAAE,OAAO,CACnB,CAEL,CACF;QACN,uCACE,SAAS,EAAC,mBAAmB,iBACjB,oBAAoB,IAC/B,WAAW,CACR,CACF,CACP,CAAC;AACJ,CAAC,CAAC;AA/CW,QAAA,cAAc,kBA+CzB","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 { ReactNode } from \"react\";\nimport React from \"react\";\nimport { Text } from \"@itwin/itwinui-react\";\nimport \"./HorizontalTile.scss\";\nimport classNames from \"classnames\";\n\nexport interface HorizontalTileProps extends React.ComponentPropsWithoutRef<\"div\"> {\n title: string;\n actionGroup: ReactNode;\n subText: string;\n onClickTitle?: React.MouseEventHandler;\n titleTooltip: string;\n subtextToolTip?: string;\n selected?: boolean;\n}\n\nexport const HorizontalTile = (props: HorizontalTileProps) => {\n const {\n title,\n titleTooltip,\n subText,\n subtextToolTip,\n actionGroup,\n selected,\n className,\n onClickTitle,\n ...rest\n } = props;\n\n return (\n <div\n className={classNames(\n \"rcw-horizontal-tile-container\",\n { \"rcw-horizontal-tile-selected\": selected },\n className\n )}\n onClick={rest.onClick}\n data-testid=\"horizontal-tile\"\n >\n <div className=\"rcw-body-container\">\n <div className=\"rcw-body\">\n <Text className={classNames(\"rcw-body-text\", { \"iui-anchor\": !!onClickTitle })}\n onClick={onClickTitle}\n variant=\"body\"\n title={titleTooltip}>{title}\n </Text>\n {\n subText &&\n <Text className=\"rcw-body-text\"\n isMuted={true}\n title={subtextToolTip}\n variant=\"small\">{subText}\n </Text>\n }\n </div>\n </div>\n <div\n className=\"rcw-action-button\"\n data-testid=\"tile-action-button\">\n {actionGroup}\n </div>\n </div>\n );\n};\n"]}
@@ -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
  }
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -24,8 +28,8 @@ const itwinui_react_1 = require("@itwin/itwinui-react");
24
28
  const react_1 = __importStar(require("react"));
25
29
  const ReportsConfigWidget_1 = require("../../ReportsConfigWidget");
26
30
  const LocalizedTablePaginator = (props) => {
27
- const pageSizeList = react_1.useMemo(() => [10, 25, 50], []);
28
- const paginationLocalization = react_1.useMemo(() => ({
31
+ const pageSizeList = (0, react_1.useMemo)(() => [10, 25, 50], []);
32
+ const paginationLocalization = (0, react_1.useMemo)(() => ({
29
33
  pageSizeLabel: (size) => ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Table.SizePerPage", { size }),
30
34
  rangeLabel: (startIndex, endIndex, totalRows, isLoading) => isLoading
31
35
  ? ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Table.StartIndexEndIndex", { startIndex, endIndex })
@@ -1 +1 @@
1
- {"version":3,"file":"LocalizedTablePaginator.js","sourceRoot":"","sources":["../../../../src/widget/components/LocalizedTablePaginator.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAKA,wDAAsD;AACtD,+CAAuC;AACvC,mEAAgE;AAEzD,MAAM,uBAAuB,GAAG,CAAC,KAAkC,EAAE,EAAE;IAC5E,MAAM,YAAY,GAAG,eAAO,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IACrD,MAAM,sBAAsB,GAAG,eAAO,CACpC,GAAG,EAAE,CAAC,CAAC;QACL,aAAa,EAAE,CAAC,IAAY,EAAE,EAAE,CAC9B,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACjD,uCAAuC,EACvC,EAAE,IAAI,EAAE,CACT;QACH,UAAU,EAAE,CACV,UAAkB,EAClB,QAAgB,EAChB,SAAiB,EACjB,SAAkB,EAClB,EAAE,CACF,SAAS;YACP,CAAC,CAAC,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACnD,8CAA8C,EAC9C,EAAE,UAAU,EAAE,QAAQ,EAAE,CACzB;YACD,CAAC,CAAC,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACnD,gDAAgD,EAChD,EAAE,UAAU,EAAE,QAAQ,EAAE,SAAS,EAAE,CACpC;QACL,YAAY,EAAE,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CAC/D,wCAAwC,CACzC;QACD,QAAQ,EAAE,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CAC3D,oCAAoC,CACrC;QACD,aAAa,EAAE,CAAC,IAAY,EAAE,EAAE,CAC9B,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACjD,oCAAoC,EACpC,EAAE,IAAI,EAAE,CACT;QACH,gBAAgB,EAAE,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACnE,uCAAuC,CACxC;KACF,CAAC,EACF,EAAE,CACH,CAAC;IAEF,OAAO,CACL,8BAAC,8BAAc,OACT,KAAK,EACT,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,sBAAsB,GACpC,CACH,CAAC;AACJ,CAAC,CAAC;AAjDW,QAAA,uBAAuB,2BAiDlC","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 { TablePaginatorRendererProps } from \"@itwin/itwinui-react\";\nimport { TablePaginator } from \"@itwin/itwinui-react\";\nimport React, { useMemo } from \"react\";\nimport { ReportsConfigWidget } from \"../../ReportsConfigWidget\";\n\nexport const LocalizedTablePaginator = (props: TablePaginatorRendererProps) => {\n const pageSizeList = useMemo(() => [10, 25, 50], []);\n const paginationLocalization = useMemo(\n () => ({\n pageSizeLabel: (size: number) =>\n ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.SizePerPage\",\n { size }\n ),\n rangeLabel: (\n startIndex: number,\n endIndex: number,\n totalRows: number,\n isLoading: boolean\n ) =>\n isLoading\n ? ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.StartIndexEndIndex\",\n { startIndex, endIndex }\n )\n : ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.StartIndexEndIndexOf\",\n { startIndex, endIndex, totalRows }\n ),\n previousPage: ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.PreviousPage\"\n ),\n nextPage: ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.NextPage\"\n ),\n goToPageLabel: (page: number) =>\n ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.GoToPage\",\n { page }\n ),\n rowsPerPageLabel: ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.RowsPerPage\"\n ),\n }),\n []\n );\n\n return (\n <TablePaginator\n {...props}\n pageSizeList={pageSizeList}\n localization={paginationLocalization}\n />\n );\n};\n"]}
1
+ {"version":3,"file":"LocalizedTablePaginator.js","sourceRoot":"","sources":["../../../../src/widget/components/LocalizedTablePaginator.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,wDAAsD;AACtD,+CAAuC;AACvC,mEAAgE;AAEzD,MAAM,uBAAuB,GAAG,CAAC,KAAkC,EAAE,EAAE;IAC5E,MAAM,YAAY,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IACrD,MAAM,sBAAsB,GAAG,IAAA,eAAO,EACpC,GAAG,EAAE,CAAC,CAAC;QACL,aAAa,EAAE,CAAC,IAAY,EAAE,EAAE,CAC9B,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACjD,uCAAuC,EACvC,EAAE,IAAI,EAAE,CACT;QACH,UAAU,EAAE,CACV,UAAkB,EAClB,QAAgB,EAChB,SAAiB,EACjB,SAAkB,EAClB,EAAE,CACF,SAAS;YACP,CAAC,CAAC,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACnD,8CAA8C,EAC9C,EAAE,UAAU,EAAE,QAAQ,EAAE,CACzB;YACD,CAAC,CAAC,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACnD,gDAAgD,EAChD,EAAE,UAAU,EAAE,QAAQ,EAAE,SAAS,EAAE,CACpC;QACL,YAAY,EAAE,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CAC/D,wCAAwC,CACzC;QACD,QAAQ,EAAE,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CAC3D,oCAAoC,CACrC;QACD,aAAa,EAAE,CAAC,IAAY,EAAE,EAAE,CAC9B,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACjD,oCAAoC,EACpC,EAAE,IAAI,EAAE,CACT;QACH,gBAAgB,EAAE,yCAAmB,CAAC,YAAY,CAAC,kBAAkB,CACnE,uCAAuC,CACxC;KACF,CAAC,EACF,EAAE,CACH,CAAC;IAEF,OAAO,CACL,8BAAC,8BAAc,OACT,KAAK,EACT,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,sBAAsB,GACpC,CACH,CAAC;AACJ,CAAC,CAAC;AAjDW,QAAA,uBAAuB,2BAiDlC","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 { TablePaginatorRendererProps } from \"@itwin/itwinui-react\";\nimport { TablePaginator } from \"@itwin/itwinui-react\";\nimport React, { useMemo } from \"react\";\nimport { ReportsConfigWidget } from \"../../ReportsConfigWidget\";\n\nexport const LocalizedTablePaginator = (props: TablePaginatorRendererProps) => {\n const pageSizeList = useMemo(() => [10, 25, 50], []);\n const paginationLocalization = useMemo(\n () => ({\n pageSizeLabel: (size: number) =>\n ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.SizePerPage\",\n { size }\n ),\n rangeLabel: (\n startIndex: number,\n endIndex: number,\n totalRows: number,\n isLoading: boolean\n ) =>\n isLoading\n ? ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.StartIndexEndIndex\",\n { startIndex, endIndex }\n )\n : ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.StartIndexEndIndexOf\",\n { startIndex, endIndex, totalRows }\n ),\n previousPage: ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.PreviousPage\"\n ),\n nextPage: ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.NextPage\"\n ),\n goToPageLabel: (page: number) =>\n ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.GoToPage\",\n { page }\n ),\n rowsPerPageLabel: ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Table.RowsPerPage\"\n ),\n }),\n []\n );\n\n return (\n <TablePaginator\n {...props}\n pageSizeList={pageSizeList}\n localization={paginationLocalization}\n />\n );\n};\n"]}
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -36,16 +40,14 @@ require("./ReportAction.scss");
36
40
  const ReportsConfigApiContext_1 = require("../context/ReportsConfigApiContext");
37
41
  const ReportsConfigWidget_1 = require("../../ReportsConfigWidget");
38
42
  const ReportAction = ({ report, onSaveSuccess, onClickCancel }) => {
39
- var _a, _b;
40
- const { iTwinId, getAccessToken, reportsClient } = ReportsConfigApiContext_1.useReportsConfigApi();
41
- const [values, setValues] = react_1.useState({
42
- name: (_a = report === null || report === void 0 ? void 0 : report.displayName) !== null && _a !== void 0 ? _a : "",
43
- description: (_b = report === null || report === void 0 ? void 0 : report.description) !== null && _b !== void 0 ? _b : "",
43
+ const { iTwinId, getAccessToken, reportsClient } = (0, ReportsConfigApiContext_1.useReportsConfigApi)();
44
+ const [values, setValues] = (0, react_1.useState)({
45
+ name: report?.displayName ?? "",
46
+ description: report?.description ?? "",
44
47
  });
45
- const [validator, showValidationMessage] = useValidator_1.default();
46
- const [isLoading, setIsLoading] = react_1.useState(false);
48
+ const [validator, showValidationMessage] = (0, useValidator_1.default)();
49
+ const [isLoading, setIsLoading] = (0, react_1.useState)(false);
47
50
  const onSave = async () => {
48
- var _a, _b, _c;
49
51
  try {
50
52
  if (!validator.allValid()) {
51
53
  showValidationMessage(true);
@@ -54,7 +56,7 @@ const ReportAction = ({ report, onSaveSuccess, onClickCancel }) => {
54
56
  setIsLoading(true);
55
57
  const accessToken = await getAccessToken();
56
58
  report
57
- ? await reportsClient.updateReport(accessToken, (_a = report.id) !== null && _a !== void 0 ? _a : "", {
59
+ ? await reportsClient.updateReport(accessToken, report.id ?? "", {
58
60
  displayName: values.name,
59
61
  description: values.description,
60
62
  })
@@ -65,12 +67,12 @@ const ReportAction = ({ report, onSaveSuccess, onClickCancel }) => {
65
67
  });
66
68
  onSaveSuccess();
67
69
  setValues({
68
- name: (_b = report === null || report === void 0 ? void 0 : report.displayName) !== null && _b !== void 0 ? _b : "",
69
- description: (_c = report === null || report === void 0 ? void 0 : report.description) !== null && _c !== void 0 ? _c : "",
70
+ name: report?.displayName ?? "",
71
+ description: report?.description ?? "",
70
72
  });
71
73
  }
72
74
  catch (error) {
73
- utils_1.handleError(error.status);
75
+ (0, utils_1.handleError)(error.status);
74
76
  setIsLoading(false);
75
77
  }
76
78
  finally {
@@ -80,20 +82,20 @@ const ReportAction = ({ report, onSaveSuccess, onClickCancel }) => {
80
82
  return (react_1.default.createElement(react_1.default.Fragment, null,
81
83
  react_1.default.createElement("div", { className: "rcw-details-form-container" },
82
84
  react_1.default.createElement(itwinui_react_1.Fieldset, { legend: ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:ReportDetails"), className: "rcw-details-form" },
83
- react_1.default.createElement(itwinui_react_1.Small, { className: "field-legend" }, ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:MandatoryFields")),
85
+ react_1.default.createElement(itwinui_react_1.Text, { variant: 'small', className: "field-legend" }, ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:MandatoryFields")),
84
86
  react_1.default.createElement(itwinui_react_1.LabeledInput, { name: "name", label: ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Name"), value: values.name, required: true, disabled: isLoading, onChange: (event) => {
85
- utils_1.handleInputChange(event, values, setValues);
87
+ (0, utils_1.handleInputChange)(event, values, setValues);
86
88
  validator.showMessageFor("name");
87
89
  }, message: validator.message("name", values.name, useValidator_1.NAME_REQUIREMENTS), status: validator.message("name", values.name, useValidator_1.NAME_REQUIREMENTS)
88
90
  ? "negative"
89
91
  : undefined, onBlur: () => {
90
92
  validator.showMessageFor("name");
91
93
  }, onBlurCapture: (event) => {
92
- utils_1.handleInputChange(event, values, setValues);
94
+ (0, utils_1.handleInputChange)(event, values, setValues);
93
95
  validator.showMessageFor("name");
94
96
  } }),
95
97
  react_1.default.createElement(itwinui_react_1.LabeledInput, { name: "description", label: ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Description"), value: values.description, onChange: (event) => {
96
- utils_1.handleInputChange(event, values, setValues);
98
+ (0, utils_1.handleInputChange)(event, values, setValues);
97
99
  }, disabled: isLoading }))),
98
100
  react_1.default.createElement(ActionPanel_1.default, { actionLabel: ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Add"), onAction: onSave, onCancel: onClickCancel, isSavingDisabled: !values.name, isLoading: isLoading })));
99
101
  };
@@ -1 +1 @@
1
- {"version":3,"file":"ReportAction.js","sourceRoot":"","sources":["../../../../src/widget/components/ReportAction.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 { Fieldset, LabeledInput, Small } from \"@itwin/itwinui-react\";\nimport React, { useState } from \"react\";\nimport ActionPanel from \"./ActionPanel\";\nimport useValidator, { NAME_REQUIREMENTS } from \"../hooks/useValidator\";\nimport {\n handleError,\n handleInputChange,\n} from \"./utils\";\nimport \"./ReportAction.scss\";\nimport type { Report } from \"@itwin/insights-client\";\nimport { useReportsConfigApi } from \"../context/ReportsConfigApiContext\";\nimport { ReportsConfigWidget } from \"../../ReportsConfigWidget\";\n\nexport interface ReportActionProps {\n report?: Report;\n onSaveSuccess: () => void;\n onClickCancel?: () => void;\n}\n\nexport const ReportAction = ({ report, onSaveSuccess, onClickCancel }: ReportActionProps) => {\n const { iTwinId, getAccessToken, reportsClient } = useReportsConfigApi();\n const [values, setValues] = useState({\n name: report?.displayName ?? \"\",\n description: report?.description ?? \"\",\n });\n const [validator, showValidationMessage] = useValidator();\n const [isLoading, setIsLoading] = useState<boolean>(false);\n\n const onSave = async () => {\n try {\n if (!validator.allValid()) {\n showValidationMessage(true);\n return;\n }\n setIsLoading(true);\n const accessToken = await getAccessToken();\n report\n ? await reportsClient.updateReport(accessToken, report.id ?? \"\", {\n displayName: values.name,\n description: values.description,\n })\n : await reportsClient.createReport(accessToken, {\n displayName: values.name,\n description: values.description,\n projectId: iTwinId,\n });\n onSaveSuccess();\n setValues({\n name: report?.displayName ?? \"\",\n description: report?.description ?? \"\",\n });\n } catch (error: any) {\n handleError(error.status);\n setIsLoading(false);\n } finally {\n setIsLoading(false);\n }\n };\n\n return (\n <>\n <div className=\"rcw-details-form-container\">\n <Fieldset\n legend={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:ReportDetails\"\n )}\n className=\"rcw-details-form\"\n >\n <Small className=\"field-legend\">\n {ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:MandatoryFields\"\n )}\n </Small>\n <LabeledInput\n name=\"name\"\n label={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Name\"\n )}\n value={values.name}\n required\n disabled={isLoading}\n onChange={(event) => {\n handleInputChange(event, values, setValues);\n validator.showMessageFor(\"name\");\n }}\n message={validator.message(\"name\", values.name, NAME_REQUIREMENTS)}\n status={\n validator.message(\"name\", values.name, NAME_REQUIREMENTS)\n ? \"negative\"\n : undefined\n }\n onBlur={() => {\n validator.showMessageFor(\"name\");\n }}\n onBlurCapture={(event) => {\n handleInputChange(event, values, setValues);\n validator.showMessageFor(\"name\");\n }}\n />\n <LabeledInput\n name=\"description\"\n label={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Description\"\n )}\n value={values.description}\n onChange={(event) => {\n handleInputChange(event, values, setValues);\n }}\n disabled={isLoading}\n />\n </Fieldset>\n </div>\n <ActionPanel\n actionLabel={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Add\"\n )}\n onAction={onSave}\n onCancel={onClickCancel}\n isSavingDisabled={!values.name}\n isLoading={isLoading}\n />\n </>\n );\n};\n\n"]}
1
+ {"version":3,"file":"ReportAction.js","sourceRoot":"","sources":["../../../../src/widget/components/ReportAction.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 { Fieldset, LabeledInput, Text } from \"@itwin/itwinui-react\";\nimport React, { useState } from \"react\";\nimport ActionPanel from \"./ActionPanel\";\nimport useValidator, { NAME_REQUIREMENTS } from \"../hooks/useValidator\";\nimport {\n handleError,\n handleInputChange,\n} from \"./utils\";\nimport \"./ReportAction.scss\";\nimport type { Report } from \"@itwin/insights-client\";\nimport { useReportsConfigApi } from \"../context/ReportsConfigApiContext\";\nimport { ReportsConfigWidget } from \"../../ReportsConfigWidget\";\n\nexport interface ReportActionProps {\n report?: Report;\n onSaveSuccess: () => void;\n onClickCancel?: () => void;\n}\n\nexport const ReportAction = ({ report, onSaveSuccess, onClickCancel }: ReportActionProps) => {\n const { iTwinId, getAccessToken, reportsClient } = useReportsConfigApi();\n const [values, setValues] = useState({\n name: report?.displayName ?? \"\",\n description: report?.description ?? \"\",\n });\n const [validator, showValidationMessage] = useValidator();\n const [isLoading, setIsLoading] = useState<boolean>(false);\n\n const onSave = async () => {\n try {\n if (!validator.allValid()) {\n showValidationMessage(true);\n return;\n }\n setIsLoading(true);\n const accessToken = await getAccessToken();\n report\n ? await reportsClient.updateReport(accessToken, report.id ?? \"\", {\n displayName: values.name,\n description: values.description,\n })\n : await reportsClient.createReport(accessToken, {\n displayName: values.name,\n description: values.description,\n projectId: iTwinId,\n });\n onSaveSuccess();\n setValues({\n name: report?.displayName ?? \"\",\n description: report?.description ?? \"\",\n });\n } catch (error: any) {\n handleError(error.status);\n setIsLoading(false);\n } finally {\n setIsLoading(false);\n }\n };\n\n return (\n <>\n <div className=\"rcw-details-form-container\">\n <Fieldset\n legend={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:ReportDetails\"\n )}\n className=\"rcw-details-form\"\n >\n <Text variant='small' className=\"field-legend\">\n {ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:MandatoryFields\"\n )}\n </Text>\n <LabeledInput\n name=\"name\"\n label={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Name\"\n )}\n value={values.name}\n required\n disabled={isLoading}\n onChange={(event) => {\n handleInputChange(event, values, setValues);\n validator.showMessageFor(\"name\");\n }}\n message={validator.message(\"name\", values.name, NAME_REQUIREMENTS)}\n status={\n validator.message(\"name\", values.name, NAME_REQUIREMENTS)\n ? \"negative\"\n : undefined\n }\n onBlur={() => {\n validator.showMessageFor(\"name\");\n }}\n onBlurCapture={(event) => {\n handleInputChange(event, values, setValues);\n validator.showMessageFor(\"name\");\n }}\n />\n <LabeledInput\n name=\"description\"\n label={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Description\"\n )}\n value={values.description}\n onChange={(event) => {\n handleInputChange(event, values, setValues);\n }}\n disabled={isLoading}\n />\n </Fieldset>\n </div>\n <ActionPanel\n actionLabel={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Add\"\n )}\n onAction={onSave}\n onCancel={onClickCancel}\n isSavingDisabled={!values.name}\n isLoading={isLoading}\n />\n </>\n );\n};\n\n"]}
@@ -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
  }
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -32,11 +36,10 @@ const itwinui_react_1 = require("@itwin/itwinui-react");
32
36
  const itwinui_icons_react_1 = require("@itwin/itwinui-icons-react");
33
37
  const HorizontalTile_1 = require("./HorizontalTile");
34
38
  const ReportHorizontalTile = (props) => {
35
- var _a, _b;
36
- const [jobStarted, setJobStarted] = react_1.useState(false);
37
- const [extractionState, setExtractionState] = react_1.useState(ExtractionStatus_1.ExtractionStates.None);
38
- const interval = react_1.useRef();
39
- react_1.useEffect(() => {
39
+ const [jobStarted, setJobStarted] = (0, react_1.useState)(false);
40
+ const [extractionState, setExtractionState] = (0, react_1.useState)(ExtractionStatus_1.ExtractionStates.None);
41
+ const interval = (0, react_1.useRef)();
42
+ (0, react_1.useEffect)(() => {
40
43
  const listener = (startedReportId) => {
41
44
  if (startedReportId === props.report.id) {
42
45
  setExtractionState(ExtractionStatus_1.ExtractionStates.Starting);
@@ -48,7 +51,7 @@ const ReportHorizontalTile = (props) => {
48
51
  props.jobStartEvent.removeListener(listener);
49
52
  };
50
53
  }, [props.jobStartEvent, props.report.id]);
51
- react_1.useEffect(() => {
54
+ (0, react_1.useEffect)(() => {
52
55
  if (jobStarted) {
53
56
  window.clearInterval(interval.current);
54
57
  interval.current = window.setInterval(async () => {
@@ -64,20 +67,19 @@ const ReportHorizontalTile = (props) => {
64
67
  return () => window.clearInterval(interval.current);
65
68
  }, [props.report.id, props.bulkExtractor, jobStarted]);
66
69
  const onClickTile = (e) => {
67
- var _a;
68
- if ((_a = e === null || e === void 0 ? void 0 : e.currentTarget.className) === null || _a === void 0 ? void 0 : _a.toString().split(" ").includes("rcw-horizontal-tile-container")) {
70
+ if (e?.currentTarget.className?.toString().split(" ").includes("rcw-horizontal-tile-container")) {
69
71
  props.onSelectionChange(props.report.id, e.ctrlKey);
70
72
  }
71
73
  };
72
- return (react_1.default.createElement(HorizontalTile_1.HorizontalTile, { title: props.report.displayName, subText: (_a = props.report.description) !== null && _a !== void 0 ? _a : "", subtextToolTip: (_b = props.report.description) !== null && _b !== void 0 ? _b : "", titleTooltip: props.report.displayName, onClick: onClickTile, onClickTitle: () => { var _a; return (_a = props.onClickTitle) === null || _a === void 0 ? void 0 : _a.call(props, props.report); }, selected: props.selected, actionGroup: extractionState === ExtractionStatus_1.ExtractionStates.None ? (react_1.default.createElement("div", { className: "rcw-action-button", "data-testid": "tile-action-button" },
74
+ return (react_1.default.createElement(HorizontalTile_1.HorizontalTile, { title: props.report.displayName, subText: props.report.description ?? "", subtextToolTip: props.report.description ?? "", titleTooltip: props.report.displayName, onClick: onClickTile, onClickTitle: () => props.onClickTitle?.(props.report), selected: props.selected, actionGroup: extractionState === ExtractionStatus_1.ExtractionStates.None ? (react_1.default.createElement("div", { className: "rcw-action-button", "data-testid": "tile-action-button" },
73
75
  react_1.default.createElement(itwinui_react_1.DropdownMenu, { menuItems: (close) => [
74
- props.onClickModify ? react_1.default.createElement(itwinui_react_1.MenuItem, { key: 0, onClick: () => { var _a; return (_a = props.onClickModify) === null || _a === void 0 ? void 0 : _a.call(props, props.report); }, icon: react_1.default.createElement(itwinui_icons_react_1.SvgEdit, null) }, ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Modify")) : [],
76
+ props.onClickModify ? react_1.default.createElement(itwinui_react_1.MenuItem, { key: 0, onClick: () => props.onClickModify?.(props.report), icon: react_1.default.createElement(itwinui_icons_react_1.SvgEdit, null) }, ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Modify")) : [],
75
77
  react_1.default.createElement(itwinui_react_1.MenuItem, { key: 1, onClick: () => {
76
78
  props.onClickDelete();
77
79
  close();
78
80
  }, icon: react_1.default.createElement(itwinui_icons_react_1.SvgDelete, null) }, ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Remove")),
79
81
  ].flat() },
80
- react_1.default.createElement(itwinui_react_1.IconButton, { styleType: "borderless" },
82
+ react_1.default.createElement(itwinui_react_1.IconButton, { styleType: "borderless", title: ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:ReportOptions") },
81
83
  react_1.default.createElement(itwinui_icons_react_1.SvgMore, null))))) : (react_1.default.createElement(ExtractionStatus_1.ExtractionStatus, { state: extractionState, clearExtractionState: () => {
82
84
  setExtractionState(ExtractionStatus_1.ExtractionStates.None);
83
85
  } })) }));
@@ -1 +1 @@
1
- {"version":3,"file":"ReportHorizontalTile.js","sourceRoot":"","sources":["../../../../src/widget/components/ReportHorizontalTile.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 React, { useEffect, useRef, useState } from \"react\";\nimport type { BulkExtractor } from \"./BulkExtractor\";\nimport { ExtractionStates, ExtractionStatus } from \"./ExtractionStatus\";\nimport type { BeEvent } from \"@itwin/core-bentley\";\nimport { STATUS_CHECK_INTERVAL } from \"./Constants\";\nimport type { Report } from \"@itwin/insights-client\";\nimport { ReportsConfigWidget } from \"../../ReportsConfigWidget\";\nimport {\n DropdownMenu,\n IconButton,\n MenuItem,\n} from \"@itwin/itwinui-react\";\nimport {\n SvgDelete,\n SvgEdit,\n SvgMore,\n} from \"@itwin/itwinui-icons-react\";\nimport { HorizontalTile } from \"./HorizontalTile\";\n\nexport interface ReportHorizontalTileProps {\n selected: boolean;\n onSelectionChange: (reportId: string, controlPressed: boolean) => void;\n bulkExtractor: BulkExtractor;\n jobStartEvent: BeEvent<(reportId: string) => void>;\n report: Report;\n onClickDelete: () => void;\n onClickModify?: (report: Report) => void;\n onClickTitle?: (report: Report) => void;\n}\n\nexport const ReportHorizontalTile = (props: ReportHorizontalTileProps) => {\n const [jobStarted, setJobStarted] = useState<boolean>(false);\n const [extractionState, setExtractionState] = useState<ExtractionStates>(ExtractionStates.None);\n const interval = useRef<number>();\n\n useEffect(() => {\n const listener = (startedReportId: string) => {\n if (startedReportId === props.report.id) {\n setExtractionState(ExtractionStates.Starting);\n setJobStarted(true);\n }\n };\n props.jobStartEvent.addListener(listener);\n\n return () => {\n props.jobStartEvent.removeListener(listener);\n };\n }, [props.jobStartEvent, props.report.id]);\n\n useEffect(() => {\n if (jobStarted) {\n window.clearInterval(interval.current);\n interval.current = window.setInterval(async () => {\n const state = await props.bulkExtractor.getReportState(props.report.id);\n if (state) {\n setExtractionState(state);\n if (state === ExtractionStates.Failed || state === ExtractionStates.Succeeded) {\n setJobStarted(false);\n }\n }\n }, STATUS_CHECK_INTERVAL);\n }\n return () => window.clearInterval(interval.current);\n }, [props.report.id, props.bulkExtractor, jobStarted]);\n\n const onClickTile = (e: React.MouseEvent) => {\n if (e?.currentTarget.className?.toString().split(\" \").includes(\"rcw-horizontal-tile-container\")) {\n props.onSelectionChange(props.report.id, e.ctrlKey);\n }\n };\n\n return (\n <HorizontalTile\n title={props.report.displayName}\n subText={props.report.description ?? \"\"}\n subtextToolTip={props.report.description ?? \"\"}\n titleTooltip={props.report.displayName}\n onClick={onClickTile}\n onClickTitle={() => props.onClickTitle?.(props.report)}\n selected={props.selected}\n actionGroup={extractionState === ExtractionStates.None ? (\n <div\n className=\"rcw-action-button\"\n data-testid=\"tile-action-button\">\n <DropdownMenu\n menuItems={(close: () => void) => [\n props.onClickModify ? <MenuItem\n key={0}\n onClick={() => props.onClickModify?.(props.report)}\n icon={<SvgEdit />}\n >\n {ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Modify\"\n )}\n </MenuItem> : [],\n <MenuItem\n key={1}\n onClick={() => {\n props.onClickDelete();\n close();\n }}\n icon={<SvgDelete />}\n >\n {ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Remove\"\n )}\n </MenuItem>,\n ].flat()}\n >\n <IconButton styleType=\"borderless\">\n <SvgMore />\n </IconButton>\n </DropdownMenu>\n </div>\n ) : (\n <ExtractionStatus\n state={extractionState}\n clearExtractionState={() => {\n setExtractionState(ExtractionStates.None);\n }}\n ></ExtractionStatus>\n )}\n ></HorizontalTile>\n );\n};\n"]}
1
+ {"version":3,"file":"ReportHorizontalTile.js","sourceRoot":"","sources":["../../../../src/widget/components/ReportHorizontalTile.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 React, { useEffect, useRef, useState } from \"react\";\nimport type { BulkExtractor } from \"./BulkExtractor\";\nimport { ExtractionStates, ExtractionStatus } from \"./ExtractionStatus\";\nimport type { BeEvent } from \"@itwin/core-bentley\";\nimport { STATUS_CHECK_INTERVAL } from \"./Constants\";\nimport type { Report } from \"@itwin/insights-client\";\nimport { ReportsConfigWidget } from \"../../ReportsConfigWidget\";\nimport {\n DropdownMenu,\n IconButton,\n MenuItem,\n} from \"@itwin/itwinui-react\";\nimport {\n SvgDelete,\n SvgEdit,\n SvgMore,\n} from \"@itwin/itwinui-icons-react\";\nimport { HorizontalTile } from \"./HorizontalTile\";\n\nexport interface ReportHorizontalTileProps {\n selected: boolean;\n onSelectionChange: (reportId: string, controlPressed: boolean) => void;\n bulkExtractor: BulkExtractor;\n jobStartEvent: BeEvent<(reportId: string) => void>;\n report: Report;\n onClickDelete: () => void;\n onClickModify?: (report: Report) => void;\n onClickTitle?: (report: Report) => void;\n}\n\nexport const ReportHorizontalTile = (props: ReportHorizontalTileProps) => {\n const [jobStarted, setJobStarted] = useState<boolean>(false);\n const [extractionState, setExtractionState] = useState<ExtractionStates>(ExtractionStates.None);\n const interval = useRef<number>();\n\n useEffect(() => {\n const listener = (startedReportId: string) => {\n if (startedReportId === props.report.id) {\n setExtractionState(ExtractionStates.Starting);\n setJobStarted(true);\n }\n };\n props.jobStartEvent.addListener(listener);\n\n return () => {\n props.jobStartEvent.removeListener(listener);\n };\n }, [props.jobStartEvent, props.report.id]);\n\n useEffect(() => {\n if (jobStarted) {\n window.clearInterval(interval.current);\n interval.current = window.setInterval(async () => {\n const state = await props.bulkExtractor.getReportState(props.report.id);\n if (state) {\n setExtractionState(state);\n if (state === ExtractionStates.Failed || state === ExtractionStates.Succeeded) {\n setJobStarted(false);\n }\n }\n }, STATUS_CHECK_INTERVAL);\n }\n return () => window.clearInterval(interval.current);\n }, [props.report.id, props.bulkExtractor, jobStarted]);\n\n const onClickTile = (e: React.MouseEvent) => {\n if (e?.currentTarget.className?.toString().split(\" \").includes(\"rcw-horizontal-tile-container\")) {\n props.onSelectionChange(props.report.id, e.ctrlKey);\n }\n };\n\n return (\n <HorizontalTile\n title={props.report.displayName}\n subText={props.report.description ?? \"\"}\n subtextToolTip={props.report.description ?? \"\"}\n titleTooltip={props.report.displayName}\n onClick={onClickTile}\n onClickTitle={() => props.onClickTitle?.(props.report)}\n selected={props.selected}\n actionGroup={extractionState === ExtractionStates.None ? (\n <div\n className=\"rcw-action-button\"\n data-testid=\"tile-action-button\">\n <DropdownMenu\n menuItems={(close: () => void) => [\n props.onClickModify ? <MenuItem\n key={0}\n onClick={() => props.onClickModify?.(props.report)}\n icon={<SvgEdit />}\n >\n {ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Modify\"\n )}\n </MenuItem> : [],\n <MenuItem\n key={1}\n onClick={() => {\n props.onClickDelete();\n close();\n }}\n icon={<SvgDelete />}\n >\n {ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Remove\"\n )}\n </MenuItem>,\n ].flat()}\n >\n <IconButton styleType=\"borderless\" title={ReportsConfigWidget.localization.getLocalizedString(\"ReportsConfigWidget:ReportOptions\")}>\n <SvgMore />\n </IconButton>\n </DropdownMenu>\n </div>\n ) : (\n <ExtractionStatus\n state={extractionState}\n clearExtractionState={() => {\n setExtractionState(ExtractionStates.None);\n }}\n ></ExtractionStatus>\n )}\n ></HorizontalTile>\n );\n};\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"ReportMappingHorizontalTile.d.ts","sourceRoot":"","sources":["../../../../src/widget/components/ReportMappingHorizontalTile.tsx"],"names":[],"mappings":";AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAErD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AASnD,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAC;AAEhE,MAAM,WAAW,gCAAgC;IAC/C,aAAa,EAAE,OAAO,CAAC,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC,CAAC;IACnD,OAAO,EAAE,uBAAuB,CAAC;IACjC,aAAa,EAAE,MAAM,IAAI,CAAC;IAC1B,aAAa,EAAE,aAAa,CAAC;IAC7B,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,2BAA2B,UAAW,gCAAgC,gBAoGlF,CAAC"}
1
+ {"version":3,"file":"ReportMappingHorizontalTile.d.ts","sourceRoot":"","sources":["../../../../src/widget/components/ReportMappingHorizontalTile.tsx"],"names":[],"mappings":";AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAErD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AASnD,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAC;AAEhE,MAAM,WAAW,gCAAgC;IAC/C,aAAa,EAAE,OAAO,CAAC,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC,CAAC;IACnD,OAAO,EAAE,uBAAuB,CAAC;IACjC,aAAa,EAAE,MAAM,IAAI,CAAC;IAC1B,aAAa,EAAE,aAAa,CAAC;IAC7B,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,2BAA2B,UAAW,gCAAgC,gBAqGlF,CAAC"}
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -32,11 +36,11 @@ const itwinui_react_1 = require("@itwin/itwinui-react");
32
36
  const itwinui_icons_react_1 = require("@itwin/itwinui-icons-react");
33
37
  const HorizontalTile_1 = require("./HorizontalTile");
34
38
  const ReportMappingHorizontalTile = (props) => {
35
- const [extractionState, setExtractionState] = react_1.useState(ExtractionStatus_1.ExtractionStates.None);
36
- const [jobStarted, setJobStarted] = react_1.useState(true);
37
- const interval = react_1.useRef();
38
- const initialLoad = react_1.useRef(true);
39
- react_1.useEffect(() => {
39
+ const [extractionState, setExtractionState] = (0, react_1.useState)(ExtractionStatus_1.ExtractionStates.None);
40
+ const [jobStarted, setJobStarted] = (0, react_1.useState)(true);
41
+ const interval = (0, react_1.useRef)();
42
+ const initialLoad = (0, react_1.useRef)(true);
43
+ (0, react_1.useEffect)(() => {
40
44
  const listener = (startedIModelId) => {
41
45
  if (startedIModelId === props.mapping.imodelId) {
42
46
  setExtractionState(ExtractionStatus_1.ExtractionStates.Starting);
@@ -48,7 +52,7 @@ const ReportMappingHorizontalTile = (props) => {
48
52
  props.jobStartEvent.removeListener(listener);
49
53
  };
50
54
  }, [props.jobStartEvent, props.mapping]);
51
- const getExtractionState = react_1.useCallback(async () => {
55
+ const getExtractionState = (0, react_1.useCallback)(async () => {
52
56
  const state = await props.bulkExtractor.getIModelState(props.mapping.imodelId, props.mapping.iModelName, props.odataFeedUrl);
53
57
  if (state === ExtractionStatus_1.ExtractionStates.Failed || state === ExtractionStatus_1.ExtractionStates.Succeeded || state === ExtractionStatus_1.ExtractionStates.None) {
54
58
  setJobStarted(false);
@@ -63,7 +67,7 @@ const ReportMappingHorizontalTile = (props) => {
63
67
  }
64
68
  setExtractionState(state);
65
69
  }, [props.mapping, props.bulkExtractor, props.odataFeedUrl]);
66
- react_1.useEffect(() => {
70
+ (0, react_1.useEffect)(() => {
67
71
  if (jobStarted) {
68
72
  getExtractionState().catch((error) => {
69
73
  setExtractionState(ExtractionStatus_1.ExtractionStates.Failed);
@@ -78,20 +82,20 @@ const ReportMappingHorizontalTile = (props) => {
78
82
  }
79
83
  return () => window.clearInterval(interval.current);
80
84
  }, [jobStarted, getExtractionState]);
81
- return (react_1.default.createElement(HorizontalTile_1.HorizontalTile, { title: props.mapping.mappingName, subText: props.mapping.iModelName, titleTooltip: props.mapping.mappingDescription, actionGroup: (react_1.default.createElement("div", { className: "rcw-action-button", "data-testid": "tile-action-button" },
82
- extractionState === ExtractionStatus_1.ExtractionStates.None ?
83
- (react_1.default.createElement(itwinui_react_1.IconButton, { styleType: "borderless", title: ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:UpdateDataset"), onClick: async () => {
85
+ return (react_1.default.createElement(HorizontalTile_1.HorizontalTile, { title: props.mapping.mappingName, subText: props.mapping.iModelName, titleTooltip: props.mapping.mappingDescription, actionGroup: (react_1.default.createElement("div", { className: "rcw-action-button", "data-testid": "tile-action-button" }, extractionState === ExtractionStatus_1.ExtractionStates.None ?
86
+ (react_1.default.createElement(react_1.default.Fragment, null,
87
+ react_1.default.createElement(itwinui_react_1.IconButton, { styleType: "borderless", title: ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:UpdateDataset"), onClick: async () => {
84
88
  setExtractionState(ExtractionStatus_1.ExtractionStates.Starting);
85
89
  await props.bulkExtractor.runIModelExtraction(props.mapping.imodelId);
86
90
  props.jobStartEvent.raiseEvent(props.mapping.imodelId);
87
91
  }, disabled: jobStarted },
88
- react_1.default.createElement(itwinui_icons_react_1.SvgRefresh, null))) : (react_1.default.createElement(ExtractionStatus_1.ExtractionStatus, { state: extractionState, clearExtractionState: () => {
89
- setExtractionState(ExtractionStatus_1.ExtractionStates.None);
90
- } })),
91
- react_1.default.createElement(itwinui_react_1.IconButton, { styleType: "borderless", title: ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Remove"), onClick: () => {
92
- props.onClickDelete();
93
- }, disabled: jobStarted },
94
- react_1.default.createElement(itwinui_icons_react_1.SvgDelete, null)))) }));
92
+ react_1.default.createElement(itwinui_icons_react_1.SvgPlay, null)),
93
+ react_1.default.createElement(itwinui_react_1.IconButton, { styleType: "borderless", title: ReportsConfigWidget_1.ReportsConfigWidget.localization.getLocalizedString("ReportsConfigWidget:Remove"), onClick: () => {
94
+ props.onClickDelete();
95
+ } },
96
+ react_1.default.createElement(itwinui_icons_react_1.SvgDelete, null)))) : (react_1.default.createElement(ExtractionStatus_1.ExtractionStatus, { state: extractionState, clearExtractionState: () => {
97
+ setExtractionState(ExtractionStatus_1.ExtractionStates.None);
98
+ } })))) }));
95
99
  };
96
100
  exports.ReportMappingHorizontalTile = ReportMappingHorizontalTile;
97
101
  //# sourceMappingURL=ReportMappingHorizontalTile.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ReportMappingHorizontalTile.js","sourceRoot":"","sources":["../../../../src/widget/components/ReportMappingHorizontalTile.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 React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport type { BulkExtractor } from \"./BulkExtractor\";\nimport { ExtractionStates, ExtractionStatus } from \"./ExtractionStatus\";\nimport type { BeEvent } from \"@itwin/core-bentley\";\nimport { STATUS_CHECK_INTERVAL } from \"./Constants\";\nimport { ReportsConfigWidget } from \"../../ReportsConfigWidget\";\nimport { IconButton } from \"@itwin/itwinui-react\";\nimport {\n SvgDelete,\n SvgRefresh,\n} from \"@itwin/itwinui-icons-react\";\nimport { HorizontalTile } from \"./HorizontalTile\";\nimport type { ReportMappingAndMapping } from \"./ReportMappings\";\n\nexport interface ReportMappingHorizontalTileProps {\n jobStartEvent: BeEvent<(iModelId: string) => void>;\n mapping: ReportMappingAndMapping;\n onClickDelete: () => void;\n bulkExtractor: BulkExtractor;\n odataFeedUrl: string;\n}\n\nexport const ReportMappingHorizontalTile = (props: ReportMappingHorizontalTileProps) => {\n const [extractionState, setExtractionState] = useState<ExtractionStates>(ExtractionStates.None);\n const [jobStarted, setJobStarted] = useState<boolean>(true);\n const interval = useRef<number>();\n const initialLoad = useRef<boolean>(true);\n\n useEffect(() => {\n const listener = (startedIModelId: string) => {\n if (startedIModelId === props.mapping.imodelId) {\n setExtractionState(ExtractionStates.Starting);\n setJobStarted(true);\n }\n };\n props.jobStartEvent.addListener(listener);\n\n return () => {\n props.jobStartEvent.removeListener(listener);\n };\n }, [props.jobStartEvent, props.mapping]);\n\n const getExtractionState = useCallback(async () => {\n const state = await props.bulkExtractor.getIModelState(props.mapping.imodelId, props.mapping.iModelName, props.odataFeedUrl);\n if (state === ExtractionStates.Failed || state === ExtractionStates.Succeeded || state === ExtractionStates.None) {\n setJobStarted(false);\n if (initialLoad.current) {\n initialLoad.current = false;\n setExtractionState(ExtractionStates.None);\n return;\n }\n } else {\n initialLoad.current = false;\n }\n setExtractionState(state);\n }, [props.mapping, props.bulkExtractor, props.odataFeedUrl]);\n\n useEffect(() => {\n if (jobStarted) {\n getExtractionState().catch((error) => {\n setExtractionState(ExtractionStates.Failed);\n setJobStarted(false);\n /* eslint-disable no-console */\n console.error(error);\n });\n window.clearInterval(interval.current);\n interval.current = window.setInterval(async () => {\n await getExtractionState();\n }, STATUS_CHECK_INTERVAL);\n }\n return () => window.clearInterval(interval.current);\n }, [jobStarted, getExtractionState]);\n\n return (\n <HorizontalTile\n title={props.mapping.mappingName}\n subText={props.mapping.iModelName}\n titleTooltip={props.mapping.mappingDescription}\n actionGroup={(\n <div\n className=\"rcw-action-button\"\n data-testid=\"tile-action-button\">\n {extractionState === ExtractionStates.None ?\n (\n <IconButton\n styleType=\"borderless\"\n title={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:UpdateDataset\"\n )}\n onClick={async () => {\n setExtractionState(ExtractionStates.Starting);\n await props.bulkExtractor.runIModelExtraction(props.mapping.imodelId);\n props.jobStartEvent.raiseEvent(props.mapping.imodelId);\n }}\n disabled={jobStarted}\n >\n <SvgRefresh />\n </IconButton>\n ) : (\n <ExtractionStatus\n state={extractionState}\n clearExtractionState={() => {\n setExtractionState(ExtractionStates.None);\n }}\n ></ExtractionStatus>\n )}\n <IconButton\n styleType=\"borderless\"\n title={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Remove\"\n )}\n onClick={() => {\n props.onClickDelete();\n }}\n disabled={jobStarted}\n >\n <SvgDelete />\n </IconButton>\n </div >\n )}\n />\n );\n};\n"]}
1
+ {"version":3,"file":"ReportMappingHorizontalTile.js","sourceRoot":"","sources":["../../../../src/widget/components/ReportMappingHorizontalTile.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 React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport type { BulkExtractor } from \"./BulkExtractor\";\nimport { ExtractionStates, ExtractionStatus } from \"./ExtractionStatus\";\nimport type { BeEvent } from \"@itwin/core-bentley\";\nimport { STATUS_CHECK_INTERVAL } from \"./Constants\";\nimport { ReportsConfigWidget } from \"../../ReportsConfigWidget\";\nimport { IconButton } from \"@itwin/itwinui-react\";\nimport {\n SvgDelete,\n SvgPlay,\n} from \"@itwin/itwinui-icons-react\";\nimport { HorizontalTile } from \"./HorizontalTile\";\nimport type { ReportMappingAndMapping } from \"./ReportMappings\";\n\nexport interface ReportMappingHorizontalTileProps {\n jobStartEvent: BeEvent<(iModelId: string) => void>;\n mapping: ReportMappingAndMapping;\n onClickDelete: () => void;\n bulkExtractor: BulkExtractor;\n odataFeedUrl: string;\n}\n\nexport const ReportMappingHorizontalTile = (props: ReportMappingHorizontalTileProps) => {\n const [extractionState, setExtractionState] = useState<ExtractionStates>(ExtractionStates.None);\n const [jobStarted, setJobStarted] = useState<boolean>(true);\n const interval = useRef<number>();\n const initialLoad = useRef<boolean>(true);\n\n useEffect(() => {\n const listener = (startedIModelId: string) => {\n if (startedIModelId === props.mapping.imodelId) {\n setExtractionState(ExtractionStates.Starting);\n setJobStarted(true);\n }\n };\n props.jobStartEvent.addListener(listener);\n\n return () => {\n props.jobStartEvent.removeListener(listener);\n };\n }, [props.jobStartEvent, props.mapping]);\n\n const getExtractionState = useCallback(async () => {\n const state = await props.bulkExtractor.getIModelState(props.mapping.imodelId, props.mapping.iModelName, props.odataFeedUrl);\n if (state === ExtractionStates.Failed || state === ExtractionStates.Succeeded || state === ExtractionStates.None) {\n setJobStarted(false);\n if (initialLoad.current) {\n initialLoad.current = false;\n setExtractionState(ExtractionStates.None);\n return;\n }\n } else {\n initialLoad.current = false;\n }\n setExtractionState(state);\n }, [props.mapping, props.bulkExtractor, props.odataFeedUrl]);\n\n useEffect(() => {\n if (jobStarted) {\n getExtractionState().catch((error) => {\n setExtractionState(ExtractionStates.Failed);\n setJobStarted(false);\n /* eslint-disable no-console */\n console.error(error);\n });\n window.clearInterval(interval.current);\n interval.current = window.setInterval(async () => {\n await getExtractionState();\n }, STATUS_CHECK_INTERVAL);\n }\n return () => window.clearInterval(interval.current);\n }, [jobStarted, getExtractionState]);\n\n return (\n <HorizontalTile\n title={props.mapping.mappingName}\n subText={props.mapping.iModelName}\n titleTooltip={props.mapping.mappingDescription}\n actionGroup={(\n <div\n className=\"rcw-action-button\"\n data-testid=\"tile-action-button\">\n {extractionState === ExtractionStates.None ?\n (\n <>\n <IconButton\n styleType=\"borderless\"\n title={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:UpdateDataset\"\n )}\n onClick={async () => {\n setExtractionState(ExtractionStates.Starting);\n await props.bulkExtractor.runIModelExtraction(props.mapping.imodelId);\n props.jobStartEvent.raiseEvent(props.mapping.imodelId);\n }}\n disabled={jobStarted}\n >\n <SvgPlay />\n </IconButton>\n <IconButton\n styleType=\"borderless\"\n title={ReportsConfigWidget.localization.getLocalizedString(\n \"ReportsConfigWidget:Remove\"\n )}\n onClick={() => {\n props.onClickDelete();\n }}\n >\n <SvgDelete />\n </IconButton>\n </>\n ) : (\n <ExtractionStatus\n state={extractionState}\n clearExtractionState={() => {\n setExtractionState(ExtractionStates.None);\n }}\n ></ExtractionStatus>\n )}\n </div >\n )}\n />\n );\n};\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"ReportMappings.d.ts","sourceRoot":"","sources":["../../../../src/widget/components/ReportMappings.tsx"],"names":[],"mappings":";AAkBA,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAC;AAQvD,OAAO,uBAAuB,CAAC;AAE/B,OAAO,KAAK,EAAkB,MAAM,EAAE,aAAa,EAAiB,MAAM,wBAAwB,CAAC;AAgBnG,oBAAY,iBAAiB,GAAG,uBAAuB,CAAC,aAAa,CAAC,CAAC;AAEvE,oBAAY,uBAAuB,GAAG,iBAAiB,GAAG;IACxD,WAAW,EAAE,MAAM,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AA2DF,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,IAAI,CAAC;IACzB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,eAAO,MAAM,cAAc,8CAA+C,mBAAmB,uBAoN5F,CAAC"}
1
+ {"version":3,"file":"ReportMappings.d.ts","sourceRoot":"","sources":["../../../../src/widget/components/ReportMappings.tsx"],"names":[],"mappings":";AAiBA,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAC;AAQvD,OAAO,uBAAuB,CAAC;AAE/B,OAAO,KAAK,EAAkB,MAAM,EAAE,aAAa,EAAiB,MAAM,wBAAwB,CAAC;AAgBnG,oBAAY,iBAAiB,GAAG,uBAAuB,CAAC,aAAa,CAAC,CAAC;AAEvE,oBAAY,uBAAuB,GAAG,iBAAiB,GAAG;IACxD,WAAW,EAAE,MAAM,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AA2DF,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,IAAI,CAAC;IACzB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,eAAO,MAAM,cAAc,8CAA+C,mBAAmB,uBAmN5F,CAAC"}