@itwin/reports-config-widget-react 0.2.0 → 0.3.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.
- package/.rush/temp/operation/rebuild/all.log +9 -0
- package/.rush/temp/operation/rebuild/state.json +3 -0
- package/.rush/temp/package-deps_rebuild.json +36 -32
- package/.rush/temp/shrinkwrap-deps.json +90 -36
- package/CHANGELOG.json +33 -0
- package/CHANGELOG.md +18 -1
- package/lib/cjs/reports-config-widget-react.d.ts +5 -0
- package/lib/cjs/reports-config-widget-react.d.ts.map +1 -1
- package/lib/cjs/reports-config-widget-react.js +11 -0
- package/lib/cjs/reports-config-widget-react.js.map +1 -1
- package/lib/cjs/test/AddMappingModal.test.js +15 -28
- package/lib/cjs/test/AddMappingModal.test.js.map +1 -1
- package/lib/cjs/test/BulkExtractor.test.js +13 -19
- package/lib/cjs/test/BulkExtractor.test.js.map +1 -1
- package/lib/cjs/test/DeleteModal.test.d.ts.map +1 -1
- package/lib/cjs/test/DeleteModal.test.js +4 -62
- package/lib/cjs/test/DeleteModal.test.js.map +1 -1
- package/lib/cjs/test/ReportAction.test.js +13 -78
- package/lib/cjs/test/ReportAction.test.js.map +1 -1
- package/lib/cjs/test/ReportMappingHorizontalTile.test.js +2 -35
- package/lib/cjs/test/ReportMappingHorizontalTile.test.js.map +1 -1
- package/lib/cjs/test/ReportMappings.test.d.ts.map +1 -1
- package/lib/cjs/test/ReportMappings.test.js +38 -91
- package/lib/cjs/test/ReportMappings.test.js.map +1 -1
- package/lib/cjs/test/Reports.test.js +19 -72
- package/lib/cjs/test/Reports.test.js.map +1 -1
- package/lib/cjs/test/test-utils.d.ts +3 -8
- package/lib/cjs/test/test-utils.d.ts.map +1 -1
- package/lib/cjs/test/test-utils.js +8 -33
- package/lib/cjs/test/test-utils.js.map +1 -1
- package/lib/cjs/tsconfig.tsbuildinfo +1 -1
- package/lib/cjs/widget/components/ActionPanel.d.ts +1 -1
- package/lib/cjs/widget/components/ActionPanel.d.ts.map +1 -1
- package/lib/cjs/widget/components/ActionPanel.js +4 -4
- package/lib/cjs/widget/components/ActionPanel.js.map +1 -1
- package/lib/cjs/widget/components/AddMappingsModal.d.ts +4 -4
- package/lib/cjs/widget/components/AddMappingsModal.d.ts.map +1 -1
- package/lib/cjs/widget/components/AddMappingsModal.js +23 -22
- package/lib/cjs/widget/components/AddMappingsModal.js.map +1 -1
- package/lib/cjs/widget/components/BulkExtractor.d.ts +4 -4
- package/lib/cjs/widget/components/BulkExtractor.d.ts.map +1 -1
- package/lib/cjs/widget/components/BulkExtractor.js +6 -6
- package/lib/cjs/widget/components/BulkExtractor.js.map +1 -1
- package/lib/cjs/widget/components/DeleteModal.d.ts +4 -5
- package/lib/cjs/widget/components/DeleteModal.d.ts.map +1 -1
- package/lib/cjs/widget/components/DeleteModal.js +9 -13
- package/lib/cjs/widget/components/DeleteModal.js.map +1 -1
- package/lib/cjs/widget/components/HorizontalTile.scss +6 -3
- package/lib/cjs/widget/components/ReportAction.d.ts +4 -5
- package/lib/cjs/widget/components/ReportAction.d.ts.map +1 -1
- package/lib/cjs/widget/components/ReportAction.js +15 -15
- package/lib/cjs/widget/components/ReportAction.js.map +1 -1
- package/lib/cjs/widget/components/ReportHorizontalTile.d.ts +4 -4
- package/lib/cjs/widget/components/ReportHorizontalTile.d.ts.map +1 -1
- package/lib/cjs/widget/components/ReportHorizontalTile.js +27 -12
- package/lib/cjs/widget/components/ReportHorizontalTile.js.map +1 -1
- package/lib/cjs/widget/components/ReportMappingHorizontalTile.d.ts +1 -1
- package/lib/cjs/widget/components/ReportMappingHorizontalTile.d.ts.map +1 -1
- package/lib/cjs/widget/components/ReportMappingHorizontalTile.js +24 -9
- package/lib/cjs/widget/components/ReportMappingHorizontalTile.js.map +1 -1
- package/lib/cjs/widget/components/ReportMappings.d.ts +4 -6
- package/lib/cjs/widget/components/ReportMappings.d.ts.map +1 -1
- package/lib/cjs/widget/components/ReportMappings.js +37 -47
- package/lib/cjs/widget/components/ReportMappings.js.map +1 -1
- package/lib/cjs/widget/components/ReportMappings.scss +3 -3
- package/lib/cjs/widget/components/Reports.d.ts +6 -1
- package/lib/cjs/widget/components/Reports.d.ts.map +1 -1
- package/lib/cjs/widget/components/Reports.js +42 -83
- package/lib/cjs/widget/components/Reports.js.map +1 -1
- package/lib/cjs/widget/components/ReportsConfigContext.d.ts +18 -0
- package/lib/cjs/widget/components/ReportsConfigContext.d.ts.map +1 -0
- package/lib/cjs/widget/components/ReportsConfigContext.js +87 -0
- package/lib/cjs/widget/components/ReportsConfigContext.js.map +1 -0
- package/lib/cjs/widget/components/ReportsContainer.d.ts +14 -0
- package/lib/cjs/widget/components/ReportsContainer.d.ts.map +1 -1
- package/lib/cjs/widget/components/ReportsContainer.js +28 -16
- package/lib/cjs/widget/components/ReportsContainer.js.map +1 -1
- package/lib/cjs/widget/components/ReportsHeader.d.ts +7 -0
- package/lib/cjs/widget/components/ReportsHeader.d.ts.map +1 -0
- package/lib/cjs/widget/components/ReportsHeader.js +20 -0
- package/lib/cjs/widget/components/ReportsHeader.js.map +1 -0
- package/lib/cjs/widget/components/ReportsRouter.d.ts +8 -0
- package/lib/cjs/widget/components/ReportsRouter.d.ts.map +1 -0
- package/lib/cjs/widget/components/ReportsRouter.js +52 -0
- package/lib/cjs/widget/components/ReportsRouter.js.map +1 -0
- package/lib/cjs/widget/components/SearchBar.js +1 -2
- package/lib/cjs/widget/components/SearchBar.js.map +1 -1
- package/lib/cjs/widget/components/SearchBar.scss +1 -1
- package/lib/cjs/widget/components/SelectIModel.d.ts +3 -3
- package/lib/cjs/widget/components/SelectIModel.d.ts.map +1 -1
- package/lib/cjs/widget/components/SelectIModel.js +6 -26
- package/lib/cjs/widget/components/SelectIModel.js.map +1 -1
- package/lib/cjs/widget/components/utils.d.ts +1 -1
- package/lib/cjs/widget/components/utils.d.ts.map +1 -1
- package/lib/cjs/widget/components/utils.js.map +1 -1
- package/lib/cjs/widget/context/BulkExtractorContext.d.ts +10 -0
- package/lib/cjs/widget/context/BulkExtractorContext.d.ts.map +1 -0
- package/lib/cjs/widget/context/{ReportsApiConfigContext.js → BulkExtractorContext.js} +7 -10
- package/lib/cjs/widget/context/BulkExtractorContext.js.map +1 -0
- package/lib/cjs/widget/context/ReportsConfigApiContext.d.ts +16 -0
- package/lib/cjs/widget/context/ReportsConfigApiContext.d.ts.map +1 -0
- package/lib/cjs/widget/context/ReportsConfigApiContext.js +43 -0
- package/lib/cjs/widget/context/ReportsConfigApiContext.js.map +1 -0
- package/lib/esm/reports-config-widget-react.d.ts +5 -0
- package/lib/esm/reports-config-widget-react.d.ts.map +1 -1
- package/lib/esm/reports-config-widget-react.js +5 -0
- package/lib/esm/reports-config-widget-react.js.map +1 -1
- package/lib/esm/test/AddMappingModal.test.js +16 -29
- package/lib/esm/test/AddMappingModal.test.js.map +1 -1
- package/lib/esm/test/BulkExtractor.test.js +14 -17
- package/lib/esm/test/BulkExtractor.test.js.map +1 -1
- package/lib/esm/test/DeleteModal.test.d.ts.map +1 -1
- package/lib/esm/test/DeleteModal.test.js +5 -44
- package/lib/esm/test/DeleteModal.test.js.map +1 -1
- package/lib/esm/test/ReportAction.test.js +14 -60
- package/lib/esm/test/ReportAction.test.js.map +1 -1
- package/lib/esm/test/ReportMappingHorizontalTile.test.js +3 -36
- package/lib/esm/test/ReportMappingHorizontalTile.test.js.map +1 -1
- package/lib/esm/test/ReportMappings.test.d.ts.map +1 -1
- package/lib/esm/test/ReportMappings.test.js +37 -90
- package/lib/esm/test/ReportMappings.test.js.map +1 -1
- package/lib/esm/test/Reports.test.js +20 -54
- package/lib/esm/test/Reports.test.js.map +1 -1
- package/lib/esm/test/test-utils.d.ts +3 -8
- package/lib/esm/test/test-utils.d.ts.map +1 -1
- package/lib/esm/test/test-utils.js +7 -31
- package/lib/esm/test/test-utils.js.map +1 -1
- package/lib/esm/tsconfig.tsbuildinfo +1 -1
- package/lib/esm/widget/components/ActionPanel.d.ts +1 -1
- package/lib/esm/widget/components/ActionPanel.d.ts.map +1 -1
- package/lib/esm/widget/components/ActionPanel.js +4 -4
- package/lib/esm/widget/components/ActionPanel.js.map +1 -1
- package/lib/esm/widget/components/AddMappingsModal.d.ts +4 -4
- package/lib/esm/widget/components/AddMappingsModal.d.ts.map +1 -1
- package/lib/esm/widget/components/AddMappingsModal.js +25 -24
- package/lib/esm/widget/components/AddMappingsModal.js.map +1 -1
- package/lib/esm/widget/components/BulkExtractor.d.ts +4 -4
- package/lib/esm/widget/components/BulkExtractor.d.ts.map +1 -1
- package/lib/esm/widget/components/BulkExtractor.js +7 -8
- package/lib/esm/widget/components/BulkExtractor.js.map +1 -1
- package/lib/esm/widget/components/DeleteModal.d.ts +4 -5
- package/lib/esm/widget/components/DeleteModal.d.ts.map +1 -1
- package/lib/esm/widget/components/DeleteModal.js +9 -13
- package/lib/esm/widget/components/DeleteModal.js.map +1 -1
- package/lib/esm/widget/components/HorizontalTile.scss +6 -3
- package/lib/esm/widget/components/ReportAction.d.ts +4 -5
- package/lib/esm/widget/components/ReportAction.d.ts.map +1 -1
- package/lib/esm/widget/components/ReportAction.js +14 -16
- package/lib/esm/widget/components/ReportAction.js.map +1 -1
- package/lib/esm/widget/components/ReportHorizontalTile.d.ts +4 -4
- package/lib/esm/widget/components/ReportHorizontalTile.d.ts.map +1 -1
- package/lib/esm/widget/components/ReportHorizontalTile.js +4 -5
- package/lib/esm/widget/components/ReportHorizontalTile.js.map +1 -1
- package/lib/esm/widget/components/ReportMappingHorizontalTile.d.ts +1 -1
- package/lib/esm/widget/components/ReportMappingHorizontalTile.d.ts.map +1 -1
- package/lib/esm/widget/components/ReportMappingHorizontalTile.js +1 -2
- package/lib/esm/widget/components/ReportMappingHorizontalTile.js.map +1 -1
- package/lib/esm/widget/components/ReportMappings.d.ts +4 -6
- package/lib/esm/widget/components/ReportMappings.d.ts.map +1 -1
- package/lib/esm/widget/components/ReportMappings.js +39 -49
- package/lib/esm/widget/components/ReportMappings.js.map +1 -1
- package/lib/esm/widget/components/ReportMappings.scss +3 -3
- package/lib/esm/widget/components/Reports.d.ts +6 -1
- package/lib/esm/widget/components/Reports.d.ts.map +1 -1
- package/lib/esm/widget/components/Reports.js +45 -86
- package/lib/esm/widget/components/Reports.js.map +1 -1
- package/lib/esm/widget/components/ReportsConfigContext.d.ts +18 -0
- package/lib/esm/widget/components/ReportsConfigContext.d.ts.map +1 -0
- package/lib/esm/widget/components/ReportsConfigContext.js +64 -0
- package/lib/esm/widget/components/ReportsConfigContext.js.map +1 -0
- package/lib/esm/widget/components/ReportsContainer.d.ts +14 -0
- package/lib/esm/widget/components/ReportsContainer.d.ts.map +1 -1
- package/lib/esm/widget/components/ReportsContainer.js +28 -17
- package/lib/esm/widget/components/ReportsContainer.js.map +1 -1
- package/lib/esm/widget/components/ReportsHeader.d.ts +7 -0
- package/lib/esm/widget/components/ReportsHeader.d.ts.map +1 -0
- package/lib/esm/widget/components/ReportsHeader.js +13 -0
- package/lib/esm/widget/components/ReportsHeader.js.map +1 -0
- package/lib/esm/widget/components/ReportsRouter.d.ts +8 -0
- package/lib/esm/widget/components/ReportsRouter.d.ts.map +1 -0
- package/lib/esm/widget/components/ReportsRouter.js +45 -0
- package/lib/esm/widget/components/ReportsRouter.js.map +1 -0
- package/lib/esm/widget/components/SearchBar.js +1 -2
- package/lib/esm/widget/components/SearchBar.js.map +1 -1
- package/lib/esm/widget/components/SearchBar.scss +1 -1
- package/lib/esm/widget/components/SelectIModel.d.ts +3 -3
- package/lib/esm/widget/components/SelectIModel.d.ts.map +1 -1
- package/lib/esm/widget/components/SelectIModel.js +7 -27
- package/lib/esm/widget/components/SelectIModel.js.map +1 -1
- package/lib/esm/widget/components/utils.d.ts +1 -1
- package/lib/esm/widget/components/utils.d.ts.map +1 -1
- package/lib/esm/widget/components/utils.js.map +1 -1
- package/lib/esm/widget/context/BulkExtractorContext.d.ts +10 -0
- package/lib/esm/widget/context/BulkExtractorContext.d.ts.map +1 -0
- package/lib/esm/widget/context/BulkExtractorContext.js +11 -0
- package/lib/esm/widget/context/BulkExtractorContext.js.map +1 -0
- package/lib/esm/widget/context/ReportsConfigApiContext.d.ts +16 -0
- package/lib/esm/widget/context/ReportsConfigApiContext.d.ts.map +1 -0
- package/lib/esm/widget/context/ReportsConfigApiContext.js +20 -0
- package/lib/esm/widget/context/ReportsConfigApiContext.js.map +1 -0
- package/lib/public/locales/en/ReportsConfigWidget.json +2 -1
- package/package.json +4 -4
- package/public/locales/en/ReportsConfigWidget.json +2 -1
- package/reports-config-widget-react.build.error.log +1 -14
- package/reports-config-widget-react.build.log +2 -60
- package/src/reports-config-widget-react.ts +6 -0
- package/src/test/AddMappingModal.test.tsx +20 -37
- package/src/test/BulkExtractor.test.ts +15 -17
- package/src/test/DeleteModal.test.tsx +4 -73
- package/src/test/ReportAction.test.tsx +17 -90
- package/src/test/ReportMappingHorizontalTile.test.tsx +3 -54
- package/src/test/ReportMappings.test.tsx +50 -135
- package/src/test/Reports.test.tsx +21 -80
- package/src/test/test-utils.tsx +9 -49
- package/src/widget/components/ActionPanel.tsx +16 -14
- package/src/widget/components/AddMappingsModal.tsx +39 -39
- package/src/widget/components/BulkExtractor.ts +11 -10
- package/src/widget/components/DeleteModal.tsx +14 -20
- package/src/widget/components/HorizontalTile.scss +6 -3
- package/src/widget/components/ReportAction.tsx +15 -30
- package/src/widget/components/ReportHorizontalTile.tsx +10 -11
- package/src/widget/components/ReportMappingHorizontalTile.tsx +2 -3
- package/src/widget/components/ReportMappings.scss +3 -3
- package/src/widget/components/ReportMappings.tsx +66 -69
- package/src/widget/components/Reports.tsx +143 -187
- package/src/widget/components/ReportsConfigContext.tsx +95 -0
- package/src/widget/components/ReportsContainer.tsx +47 -21
- package/src/widget/components/ReportsHeader.tsx +27 -0
- package/src/widget/components/ReportsRouter.tsx +63 -0
- package/src/widget/components/SearchBar.scss +1 -1
- package/src/widget/components/SearchBar.tsx +2 -2
- package/src/widget/components/SelectIModel.tsx +11 -29
- package/src/widget/components/utils.tsx +1 -1
- package/src/widget/context/{ReportsApiConfigContext.tsx → BulkExtractorContext.tsx} +9 -10
- package/src/widget/context/ReportsConfigApiContext.tsx +39 -0
- package/coverage/clover.xml +0 -838
- package/coverage/coverage-final.json +0 -29
- package/coverage/lcov-report/base.css +0 -224
- package/coverage/lcov-report/block-navigation.js +0 -87
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +0 -206
- package/coverage/lcov-report/prettify.css +0 -1
- package/coverage/lcov-report/prettify.js +0 -2
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +0 -196
- package/coverage/lcov-report/src/ReportsConfigWidget.ts.html +0 -193
- package/coverage/lcov-report/src/index.html +0 -116
- package/coverage/lcov-report/src/test/index.html +0 -116
- package/coverage/lcov-report/src/test/test-utils.tsx.html +0 -316
- package/coverage/lcov-report/src/widget/ReportsConfigUiProvider.tsx.html +0 -286
- package/coverage/lcov-report/src/widget/components/ActionPanel.tsx.html +0 -241
- package/coverage/lcov-report/src/widget/components/AddMappingsModal.tsx.html +0 -604
- package/coverage/lcov-report/src/widget/components/BulkExtractor.ts.html +0 -661
- package/coverage/lcov-report/src/widget/components/Constants.ts.html +0 -106
- package/coverage/lcov-report/src/widget/components/DeleteModal.tsx.html +0 -385
- package/coverage/lcov-report/src/widget/components/ExtractionStates/FailedExtractionState.tsx.html +0 -187
- package/coverage/lcov-report/src/widget/components/ExtractionStates/QueuedExtractionState.tsx.html +0 -145
- package/coverage/lcov-report/src/widget/components/ExtractionStates/RunningExtractionState.tsx.html +0 -139
- package/coverage/lcov-report/src/widget/components/ExtractionStates/StartingExtractionState.tsx.html +0 -151
- package/coverage/lcov-report/src/widget/components/ExtractionStates/SucceededExtractionState.tsx.html +0 -190
- package/coverage/lcov-report/src/widget/components/ExtractionStates/index.html +0 -176
- package/coverage/lcov-report/src/widget/components/ExtractionStatus.tsx.html +0 -295
- package/coverage/lcov-report/src/widget/components/ExtractionToast.tsx.html +0 -208
- package/coverage/lcov-report/src/widget/components/HorizontalTile.tsx.html +0 -289
- package/coverage/lcov-report/src/widget/components/LocalizedTablePaginator.tsx.html +0 -262
- package/coverage/lcov-report/src/widget/components/ReportAction.tsx.html +0 -517
- package/coverage/lcov-report/src/widget/components/ReportHorizontalTile.tsx.html +0 -475
- package/coverage/lcov-report/src/widget/components/ReportMappingHorizontalTile.tsx.html +0 -469
- package/coverage/lcov-report/src/widget/components/ReportMappings.tsx.html +0 -1078
- package/coverage/lcov-report/src/widget/components/Reports.tsx.html +0 -877
- package/coverage/lcov-report/src/widget/components/ReportsContainer.tsx.html +0 -223
- package/coverage/lcov-report/src/widget/components/SearchBar.tsx.html +0 -271
- package/coverage/lcov-report/src/widget/components/SelectIModel.tsx.html +0 -391
- package/coverage/lcov-report/src/widget/components/index.html +0 -371
- package/coverage/lcov-report/src/widget/components/utils.tsx.html +0 -562
- package/coverage/lcov-report/src/widget/context/ReportsApiConfigContext.tsx.html +0 -166
- package/coverage/lcov-report/src/widget/context/index.html +0 -116
- package/coverage/lcov-report/src/widget/hooks/index.html +0 -116
- package/coverage/lcov-report/src/widget/hooks/useValidator.ts.html +0 -295
- package/coverage/lcov-report/src/widget/index.html +0 -116
- package/coverage/lcov.info +0 -1594
- package/lib/cjs/widget/context/ReportsApiConfigContext.d.ts +0 -9
- package/lib/cjs/widget/context/ReportsApiConfigContext.d.ts.map +0 -1
- package/lib/cjs/widget/context/ReportsApiConfigContext.js.map +0 -1
- package/lib/esm/widget/context/ReportsApiConfigContext.d.ts +0 -9
- package/lib/esm/widget/context/ReportsApiConfigContext.d.ts.map +0 -1
- package/lib/esm/widget/context/ReportsApiConfigContext.js +0 -14
- package/lib/esm/widget/context/ReportsApiConfigContext.js.map +0 -1
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
/*---------------------------------------------------------------------------------------------
|
|
2
|
+
* Copyright (c) Bentley Systems, Incorporated. All rights reserved.
|
|
3
|
+
* See LICENSE.md in the project root for license terms and full copyright notice.
|
|
4
|
+
*--------------------------------------------------------------------------------------------*/
|
|
5
|
+
import { useActiveIModelConnection } from "@itwin/appui-react";
|
|
6
|
+
import React from "react";
|
|
7
|
+
import { ReportsConfigWidget } from "../../ReportsConfigWidget";
|
|
8
|
+
import { ReportAction } from "./ReportAction";
|
|
9
|
+
import { ReportMappings } from "./ReportMappings";
|
|
10
|
+
import { Reports } from "./Reports";
|
|
11
|
+
import type { Route } from "./ReportsContainer";
|
|
12
|
+
import { RouteStep } from "./ReportsContainer";
|
|
13
|
+
|
|
14
|
+
export const ReportsRouter = ({
|
|
15
|
+
currentRoute,
|
|
16
|
+
navigateTo,
|
|
17
|
+
goBack,
|
|
18
|
+
}: {
|
|
19
|
+
currentRoute: Route;
|
|
20
|
+
navigateTo: (toRoute: (prev: Route | undefined) => Route) => void;
|
|
21
|
+
goBack: () => void;
|
|
22
|
+
}) => {
|
|
23
|
+
const { report } = currentRoute.reportsRoutingFields;
|
|
24
|
+
const iModelId = useActiveIModelConnection()?.iModelId ?? "";
|
|
25
|
+
switch (currentRoute.step) {
|
|
26
|
+
case RouteStep.ReportsList:
|
|
27
|
+
return (
|
|
28
|
+
<Reports
|
|
29
|
+
onClickAddReport={() =>
|
|
30
|
+
navigateTo(() => ({
|
|
31
|
+
step: RouteStep.ReportAction,
|
|
32
|
+
title: ReportsConfigWidget.localization.getLocalizedString(
|
|
33
|
+
"ReportsConfigWidget:ITwinReports"
|
|
34
|
+
),
|
|
35
|
+
reportsRoutingFields: {},
|
|
36
|
+
}))
|
|
37
|
+
}
|
|
38
|
+
onClickReportTitle={(r) => {
|
|
39
|
+
navigateTo(() => ({
|
|
40
|
+
step: RouteStep.ReportMappings,
|
|
41
|
+
reportsRoutingFields: { report: r },
|
|
42
|
+
title: r.displayName,
|
|
43
|
+
}));
|
|
44
|
+
}}
|
|
45
|
+
onClickReportModify={(r) => {
|
|
46
|
+
navigateTo(() => ({
|
|
47
|
+
step: RouteStep.ReportAction,
|
|
48
|
+
reportsRoutingFields: { report: r },
|
|
49
|
+
title: r.displayName,
|
|
50
|
+
}));
|
|
51
|
+
}}
|
|
52
|
+
/>
|
|
53
|
+
);
|
|
54
|
+
|
|
55
|
+
case RouteStep.ReportAction:
|
|
56
|
+
return <ReportAction report={report} onClickCancel={goBack} onSaveSuccess={goBack} />;
|
|
57
|
+
case RouteStep.ReportMappings:
|
|
58
|
+
if (!report) return null;
|
|
59
|
+
return <ReportMappings report={report} onClickClose={goBack} defaultIModelId={iModelId} />;
|
|
60
|
+
default:
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
@@ -52,10 +52,10 @@ export const SearchBar = ({
|
|
|
52
52
|
value={searchValue}
|
|
53
53
|
onChange={(e) => setSearchValue(e.target.value)}
|
|
54
54
|
disabled={disabled}
|
|
55
|
-
/>
|
|
55
|
+
/>
|
|
56
56
|
</div>
|
|
57
57
|
) : (
|
|
58
|
-
<IconButton styleType="borderless" onClick={() => setSearchBarOpened(true)}>
|
|
58
|
+
<IconButton styleType="borderless" data-testid="rcw-search-button" onClick={() => setSearchBarOpened(true)}>
|
|
59
59
|
<SvgSearch />
|
|
60
60
|
</IconButton>
|
|
61
61
|
);
|
|
@@ -2,37 +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 {
|
|
5
|
+
import type { AccessToken } from "@itwin/core-bentley";
|
|
6
6
|
import { AccessTokenAdapter } from "@itwin/imodels-access-frontend";
|
|
7
7
|
import type {
|
|
8
8
|
GetIModelListParams,
|
|
9
|
-
|
|
9
|
+
IModelsClient,
|
|
10
10
|
MinimalIModel,
|
|
11
11
|
} from "@itwin/imodels-client-management";
|
|
12
12
|
import {
|
|
13
|
-
Constants,
|
|
14
|
-
IModelsClient,
|
|
15
13
|
toArray,
|
|
16
14
|
} from "@itwin/imodels-client-management";
|
|
17
15
|
import { ComboBox, Label } from "@itwin/itwinui-react";
|
|
18
16
|
import React, { useEffect, useMemo, useState } from "react";
|
|
19
17
|
import { ReportsConfigWidget } from "../../ReportsConfigWidget";
|
|
20
|
-
import
|
|
21
|
-
import { useReportsApiConfig } from "../context/ReportsApiConfigContext";
|
|
18
|
+
import { useReportsConfigApi } from "../context/ReportsConfigApiContext";
|
|
22
19
|
import "./SelectIModel.scss";
|
|
23
|
-
import { generateUrl } from "./utils";
|
|
24
20
|
|
|
25
21
|
const fetchIModels = async (
|
|
26
22
|
setiModels: React.Dispatch<React.SetStateAction<MinimalIModel[]>>,
|
|
27
23
|
iTwinId: string,
|
|
28
|
-
|
|
24
|
+
iModelsClient: IModelsClient,
|
|
25
|
+
getAccessToken: () => Promise<AccessToken>
|
|
29
26
|
) => {
|
|
30
|
-
const
|
|
31
|
-
api: { baseUrl: generateUrl(Constants.api.baseUrl, apiContext.baseUrl) },
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
const iModelsClient: IModelsClient = new IModelsClient(iModelClientOptions);
|
|
35
|
-
const accessToken = await apiContext.getAccessToken();
|
|
27
|
+
const accessToken = await getAccessToken();
|
|
36
28
|
const authorization = AccessTokenAdapter.toAuthorizationCallback(accessToken);
|
|
37
29
|
const getiModelListParams: GetIModelListParams = {
|
|
38
30
|
urlParams: { projectId: iTwinId },
|
|
@@ -45,30 +37,20 @@ const fetchIModels = async (
|
|
|
45
37
|
};
|
|
46
38
|
|
|
47
39
|
interface SelectedIModelProps {
|
|
48
|
-
selectedIModelId
|
|
49
|
-
setSelectedIModelId:
|
|
40
|
+
selectedIModelId?: string;
|
|
41
|
+
setSelectedIModelId: (iModelId: string) => void;
|
|
50
42
|
}
|
|
51
43
|
|
|
52
44
|
export const SelectIModel = ({
|
|
53
45
|
selectedIModelId,
|
|
54
46
|
setSelectedIModelId,
|
|
55
47
|
}: SelectedIModelProps) => {
|
|
56
|
-
const
|
|
57
|
-
const iModelId = useActiveIModelConnection()?.iModelId ?? "";
|
|
58
|
-
const iTwinId = useActiveIModelConnection()?.iTwinId ?? "";
|
|
48
|
+
const { iTwinId, getAccessToken, iModelsClient } = useReportsConfigApi();
|
|
59
49
|
const [iModels, setIModels] = useState<MinimalIModel[]>([]);
|
|
60
50
|
|
|
61
51
|
useEffect(() => {
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
}
|
|
65
|
-
}, [apiConfig, setIModels, iModelId, iTwinId]);
|
|
66
|
-
|
|
67
|
-
useEffect(() => {
|
|
68
|
-
if (iModelId && iModels.length > 0) {
|
|
69
|
-
setSelectedIModelId(iModelId);
|
|
70
|
-
}
|
|
71
|
-
}, [iModelId, iModels, setSelectedIModelId]);
|
|
52
|
+
void fetchIModels(setIModels, iTwinId, iModelsClient, getAccessToken);
|
|
53
|
+
}, [getAccessToken, iModelsClient, iTwinId, setIModels]);
|
|
72
54
|
|
|
73
55
|
const iModelOptions = useMemo(() => {
|
|
74
56
|
return iModels.map((iModel) => ({
|
|
@@ -5,22 +5,21 @@
|
|
|
5
5
|
import type { AccessToken } from "@itwin/core-bentley";
|
|
6
6
|
import * as React from "react";
|
|
7
7
|
import { createContext } from "react";
|
|
8
|
+
import type { BulkExtractor } from "../components/BulkExtractor";
|
|
8
9
|
|
|
9
|
-
export
|
|
10
|
-
|
|
11
|
-
|
|
10
|
+
export type GetAccessTokenFn = () => Promise<AccessToken>;
|
|
11
|
+
|
|
12
|
+
export interface BulkExtractorContextProps {
|
|
13
|
+
bulkExtractor?: BulkExtractor;
|
|
12
14
|
}
|
|
13
15
|
|
|
14
|
-
export const
|
|
15
|
-
getAccessToken: async () => "",
|
|
16
|
-
baseUrl: "",
|
|
17
|
-
});
|
|
16
|
+
export const BulkExtractorContext = createContext<BulkExtractorContextProps>({});
|
|
18
17
|
|
|
19
|
-
export const
|
|
20
|
-
const context = React.useContext(
|
|
18
|
+
export const useBulkExtractor = () => {
|
|
19
|
+
const context = React.useContext(BulkExtractorContext);
|
|
21
20
|
if (!context) {
|
|
22
21
|
throw new Error(
|
|
23
|
-
"
|
|
22
|
+
"useBulkExtractor should be used within a BulkExtractorContext provider"
|
|
24
23
|
);
|
|
25
24
|
}
|
|
26
25
|
return context;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/*---------------------------------------------------------------------------------------------
|
|
2
|
+
* Copyright (c) Bentley Systems, Incorporated. All rights reserved.
|
|
3
|
+
* See LICENSE.md in the project root for license terms and full copyright notice.
|
|
4
|
+
*--------------------------------------------------------------------------------------------*/
|
|
5
|
+
import type { AccessToken } from "@itwin/core-bentley";
|
|
6
|
+
import { IModelsClient } from "@itwin/imodels-client-management";
|
|
7
|
+
import { MappingsClient, ReportsClient } from "@itwin/insights-client";
|
|
8
|
+
import * as React from "react";
|
|
9
|
+
import { createContext } from "react";
|
|
10
|
+
|
|
11
|
+
export type GetAccessTokenFn = () => Promise<AccessToken>;
|
|
12
|
+
|
|
13
|
+
export interface ReportsConfigApiProps {
|
|
14
|
+
getAccessToken: GetAccessTokenFn;
|
|
15
|
+
iTwinId: string;
|
|
16
|
+
baseUrl: string;
|
|
17
|
+
reportsClient: ReportsClient;
|
|
18
|
+
mappingsClient: MappingsClient;
|
|
19
|
+
iModelsClient: IModelsClient;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export const ReportsConfigApiContext = createContext<ReportsConfigApiProps>({
|
|
23
|
+
getAccessToken: async () => "",
|
|
24
|
+
iTwinId: "",
|
|
25
|
+
baseUrl: "",
|
|
26
|
+
reportsClient: new ReportsClient(),
|
|
27
|
+
mappingsClient: new MappingsClient(),
|
|
28
|
+
iModelsClient: new IModelsClient(),
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
export const useReportsConfigApi = () => {
|
|
32
|
+
const context = React.useContext(ReportsConfigApiContext);
|
|
33
|
+
if (!context) {
|
|
34
|
+
throw new Error(
|
|
35
|
+
"useReportsConfigApi should be used within a ReportsConfigApiContext provider"
|
|
36
|
+
);
|
|
37
|
+
}
|
|
38
|
+
return context;
|
|
39
|
+
};
|