@ministryofjustice/hmpps-digital-prison-reporting-frontend 4.17.3 → 4.17.5
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/dpr/assets/app.js.map +1 -1
- package/dpr/components/_async/async-filters-form/sortByTemplate.js +1 -1
- package/dpr/components/_async/async-filters-form/sortByTemplate.js.map +1 -1
- package/dpr/components/_async/async-filters-form/types.d.js +1 -1
- package/dpr/components/_async/async-filters-form/types.d.js.map +1 -1
- package/dpr/components/_async/async-filters-form/utils.js +1 -1
- package/dpr/components/_async/async-filters-form/utils.js.map +2 -2
- package/dpr/components/_async/async-filters-form/utils.test.ts +9 -9
- package/dpr/components/_async/async-filters-form/utils.ts +1 -1
- package/dpr/components/_async/async-filters-form/view.njk +6 -3
- package/dpr/components/_catalogue/catalogue/types.js +1 -1
- package/dpr/components/_catalogue/catalogue/types.js.map +1 -1
- package/dpr/components/_catalogue/catalogue/utils.js +1 -1
- package/dpr/components/_catalogue/catalogue/utils.js.map +2 -2
- package/dpr/components/_catalogue/catalogue/utils.test.ts +6 -3
- package/dpr/components/_catalogue/catalogue/utils.ts +2 -2
- package/dpr/components/_catalogue/catalogue-list/utils.js +1 -1
- package/dpr/components/_catalogue/catalogue-list/utils.js.map +2 -2
- package/dpr/components/_catalogue/catalogue-list/utils.test.ts +1 -0
- package/dpr/components/_catalogue/catalogue-list/utils.ts +5 -5
- package/dpr/components/_charts/chart/Buckets.js +1 -1
- package/dpr/components/_charts/chart/Buckets.js.map +3 -3
- package/dpr/components/_charts/chart/Buckets.ts +3 -3
- package/dpr/components/_charts/chart/heatmap/HeatmapChart.js +1 -1
- package/dpr/components/_charts/chart/heatmap/HeatmapChart.js.map +3 -3
- package/dpr/components/_charts/chart/heatmap/HeatmapChart.ts +1 -13
- package/dpr/components/_charts/chart/heatmap/types.js +1 -1
- package/dpr/components/_charts/chart/heatmap/types.js.map +2 -2
- package/dpr/components/_charts/chart/heatmap/types.ts +1 -1
- package/dpr/components/_charts/utils.js +1 -1
- package/dpr/components/_charts/utils.js.map +3 -3
- package/dpr/components/_charts/utils.test.ts +1 -0
- package/dpr/components/_charts/utils.ts +84 -43
- package/dpr/components/_dashboards/dashboard-list/utils.js +1 -1
- package/dpr/components/_dashboards/dashboard-list/utils.js.map +2 -2
- package/dpr/components/_dashboards/dashboard-list/utils.test.ts +1 -0
- package/dpr/components/_dashboards/dashboard-list/utils.ts +16 -11
- package/dpr/components/_dashboards/dashboard-visualisation/DashboardVisualisation.js +1 -1
- package/dpr/components/_dashboards/dashboard-visualisation/DashboardVisualisation.js.map +2 -2
- package/dpr/components/_dashboards/dashboard-visualisation/DashboardVisualisation.ts +1 -1
- package/dpr/components/_dashboards/dashboard-visualisation/types.js +1 -1
- package/dpr/components/_dashboards/dashboard-visualisation/types.js.map +2 -2
- package/dpr/components/_dashboards/dashboard-visualisation/types.ts +8 -8
- package/dpr/components/_dashboards/scorecard/Scorecard.js +1 -1
- package/dpr/components/_dashboards/scorecard/Scorecard.js.map +2 -2
- package/dpr/components/_dashboards/scorecard/Scorecard.ts +8 -8
- package/dpr/components/_dashboards/scorecard/types.js +1 -1
- package/dpr/components/_dashboards/scorecard/types.js.map +2 -2
- package/dpr/components/_dashboards/scorecard/types.ts +12 -10
- package/dpr/components/_dashboards/scorecard/utils.js +1 -1
- package/dpr/components/_dashboards/scorecard/utils.js.map +1 -1
- package/dpr/components/_dashboards/scorecard/utils.test.ts +1 -0
- package/dpr/components/_filters/filter-input/enum.js +1 -1
- package/dpr/components/_filters/filter-input/enum.js.map +1 -1
- package/dpr/components/_filters/filter-input/filters.js +1 -1
- package/dpr/components/_filters/filter-input/filters.js.map +1 -1
- package/dpr/components/_filters/filter-input/filters.test.ts +1 -0
- package/dpr/components/_filters/filter-input/types.d.js +1 -1
- package/dpr/components/_filters/filter-input/types.d.js.map +1 -1
- package/dpr/components/_filters/filters-selected/utils.js +1 -1
- package/dpr/components/_filters/filters-selected/utils.js.map +3 -3
- package/dpr/components/_filters/filters-selected/utils.test.ts +7 -4
- package/dpr/components/_filters/filters-selected/utils.ts +1 -1
- package/dpr/components/_filters/filtersTypeEnum.js +1 -1
- package/dpr/components/_filters/filtersTypeEnum.js.map +1 -1
- package/dpr/components/_filters/types.d.js +1 -1
- package/dpr/components/_filters/types.d.js.map +2 -2
- package/dpr/components/_filters/types.d.ts +5 -5
- package/dpr/components/_filters/utils.js +1 -1
- package/dpr/components/_filters/utils.js.map +2 -2
- package/dpr/components/_filters/utils.test.ts +54 -49
- package/dpr/components/_filters/utils.ts +16 -20
- package/dpr/components/_inputs/date-input/utils.js +1 -1
- package/dpr/components/_inputs/date-input/utils.js.map +1 -1
- package/dpr/components/_inputs/date-input/utils.test.ts +1 -0
- package/dpr/components/_inputs/date-range/clientClass.mjs +2 -2
- package/dpr/components/_inputs/date-range/types.js +1 -1
- package/dpr/components/_inputs/date-range/types.js.map +2 -2
- package/dpr/components/_inputs/date-range/types.ts +2 -2
- package/dpr/components/_inputs/date-range/utils.js +1 -1
- package/dpr/components/_inputs/date-range/utils.js.map +2 -2
- package/dpr/components/_inputs/date-range/utils.test.ts +5 -7
- package/dpr/components/_inputs/date-range/utils.ts +4 -4
- package/dpr/components/_inputs/date-range/view.njk +1 -0
- package/dpr/components/_inputs/granular-date-range/types.js +1 -1
- package/dpr/components/_inputs/granular-date-range/types.js.map +1 -1
- package/dpr/components/_inputs/granular-date-range/utils.js +1 -1
- package/dpr/components/_inputs/granular-date-range/utils.js.map +1 -1
- package/dpr/components/_inputs/granular-date-range/utils.test.ts +1 -0
- package/dpr/components/_inputs/multi-select/utils.js +1 -1
- package/dpr/components/_inputs/multi-select/utils.js.map +3 -3
- package/dpr/components/_inputs/multi-select/utils.ts +1 -1
- package/dpr/components/_inputs/multi-select/utilt.test.ts +29 -14
- package/dpr/components/_inputs/start-end-date/utils.js +1 -1
- package/dpr/components/_inputs/start-end-date/utils.js.map +1 -1
- package/dpr/components/_inputs/start-end-date/utils.test.ts +1 -0
- package/dpr/components/_reports/report-actions/actionsTemplate.js +1 -1
- package/dpr/components/_reports/report-actions/actionsTemplate.js.map +1 -1
- package/dpr/components/_reports/report-actions/types.d.js +1 -1
- package/dpr/components/_reports/report-actions/types.d.js.map +2 -2
- package/dpr/components/_reports/report-actions/types.d.ts +1 -1
- package/dpr/components/_reports/report-actions/utils.js +1 -1
- package/dpr/components/_reports/report-actions/utils.js.map +1 -1
- package/dpr/components/_reports/report-actions/utils.test.ts +8 -4
- package/dpr/components/_reports/report-columns-form/types.d.js +1 -1
- package/dpr/components/_reports/report-columns-form/types.d.js.map +1 -1
- package/dpr/components/_reports/report-columns-form/utils.js +1 -1
- package/dpr/components/_reports/report-columns-form/utils.js.map +2 -2
- package/dpr/components/_reports/report-columns-form/utils.ts +1 -1
- package/dpr/components/_reports/report-data-table/types.d.js +1 -1
- package/dpr/components/_reports/report-data-table/types.d.js.map +1 -1
- package/dpr/components/_reports/report-data-table/utils.js +1 -1
- package/dpr/components/_reports/report-data-table/utils.js.map +3 -3
- package/dpr/components/_reports/report-data-table/utils.test.ts +15 -8
- package/dpr/components/_reports/report-data-table/utils.ts +20 -8
- package/dpr/components/_reports/report-pagination/types.d.js +1 -1
- package/dpr/components/_reports/report-pagination/types.d.js.map +2 -2
- package/dpr/components/_reports/report-pagination/types.d.ts +2 -2
- package/dpr/components/_reports/report-pagination/utils.js +1 -1
- package/dpr/components/_reports/report-pagination/utils.js.map +1 -1
- package/dpr/components/_reports/report-pagination/utils.test.ts +1 -0
- package/dpr/components/_reports/report-totals/utils.js +1 -1
- package/dpr/components/_reports/report-totals/utils.js.map +1 -1
- package/dpr/components/card-group/utils.js +1 -1
- package/dpr/components/card-group/utils.js.map +1 -1
- package/dpr/components/card-group/utils.test.ts +7 -0
- package/dpr/components/report-list/defaultTokenProvider.js +1 -1
- package/dpr/components/report-list/defaultTokenProvider.js.map +3 -3
- package/dpr/components/report-list/defaultTokenProvider.ts +3 -3
- package/dpr/components/report-list/types.d.js +1 -1
- package/dpr/components/report-list/types.d.js.map +1 -1
- package/dpr/components/report-list/utils.js +1 -1
- package/dpr/components/report-list/utils.js.map +2 -2
- package/dpr/components/report-list/utils.test.ts +6 -4
- package/dpr/components/report-list/utils.ts +5 -5
- package/dpr/components/show-more/utils.js +1 -1
- package/dpr/components/show-more/utils.js.map +1 -1
- package/dpr/components/user-reports/bookmarks/utils.js +1 -1
- package/dpr/components/user-reports/bookmarks/utils.js.map +3 -3
- package/dpr/components/user-reports/bookmarks/utils.test.ts +14 -11
- package/dpr/components/user-reports/bookmarks/utils.ts +26 -31
- package/dpr/components/user-reports/requested/utils.js +1 -1
- package/dpr/components/user-reports/requested/utils.js.map +3 -3
- package/dpr/components/user-reports/requested/utils.test.ts +4 -3
- package/dpr/components/user-reports/requested/utils.ts +4 -3
- package/dpr/components/user-reports/types.d.js +1 -1
- package/dpr/components/user-reports/types.d.js.map +2 -2
- package/dpr/components/user-reports/types.d.ts +1 -1
- package/dpr/components/user-reports/utils.js +1 -1
- package/dpr/components/user-reports/utils.js.map +3 -3
- package/dpr/components/user-reports/utils.test.ts +48 -47
- package/dpr/components/user-reports/utils.ts +51 -57
- package/dpr/components/user-reports/viewed/utils.js +1 -1
- package/dpr/components/user-reports/viewed/utils.js.map +2 -2
- package/dpr/components/user-reports/viewed/utils.ts +5 -4
- package/dpr/data/agentConfig.js +1 -1
- package/dpr/data/agentConfig.js.map +1 -1
- package/dpr/data/dashboardClient.js +1 -1
- package/dpr/data/dashboardClient.js.map +2 -2
- package/dpr/data/dashboardClient.ts +2 -2
- package/dpr/data/dprReportingClient.js +1 -1
- package/dpr/data/dprReportingClient.js.map +3 -3
- package/dpr/data/dprReportingClient.ts +3 -3
- package/dpr/data/missingReportClient.js +2 -0
- package/dpr/data/missingReportClient.js.map +7 -0
- package/dpr/{services/missingReport → data}/missingReportClient.ts +4 -4
- package/dpr/data/productCollectionClient.js +2 -0
- package/dpr/data/productCollectionClient.js.map +7 -0
- package/dpr/data/productCollectionClient.ts +28 -0
- package/dpr/data/reportDataStore.js +1 -1
- package/dpr/data/reportDataStore.js.map +1 -1
- package/dpr/data/reportingClient.js +1 -1
- package/dpr/data/reportingClient.js.map +3 -3
- package/dpr/data/reportingClient.ts +7 -9
- package/dpr/data/restClient.js +1 -1
- package/dpr/data/restClient.js.map +2 -2
- package/dpr/data/restClient.ts +5 -5
- package/dpr/data/types.d.js +1 -1
- package/dpr/data/types.d.js.map +2 -2
- package/dpr/data/types.d.ts +1 -1
- package/dpr/middleware/reportAuthoriser.js +1 -1
- package/dpr/middleware/reportAuthoriser.js.map +2 -2
- package/dpr/middleware/reportAuthoriser.ts +2 -2
- package/dpr/middleware/setUpDprResources.js +1 -1
- package/dpr/middleware/setUpDprResources.js.map +2 -2
- package/dpr/middleware/setUpDprResources.test.ts +59 -20
- package/dpr/middleware/setUpDprResources.ts +30 -29
- package/dpr/middleware/setUpNestedRoute.js +1 -1
- package/dpr/middleware/setUpNestedRoute.js.map +2 -2
- package/dpr/middleware/setUpNestedRoute.ts +1 -1
- package/dpr/routes/index.js +1 -1
- package/dpr/routes/index.js.map +2 -2
- package/dpr/routes/index.ts +1 -2
- package/dpr/routes/journeys/download-report/controller.js +1 -1
- package/dpr/routes/journeys/download-report/controller.js.map +3 -3
- package/dpr/routes/journeys/download-report/controller.ts +7 -6
- package/dpr/routes/journeys/download-report/request-download/form/controller.js +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/controller.js.map +3 -3
- package/dpr/routes/journeys/download-report/request-download/form/controller.ts +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/routes.js +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/routes.js.map +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/submitted/controller.js +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/submitted/controller.js.map +3 -3
- package/dpr/routes/journeys/download-report/request-download/form/submitted/controller.ts +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/submitted/routes.js +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/submitted/routes.js.map +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/submitted/tests.cy.js +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/submitted/tests.cy.js.map +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/tests.cy.js +1 -1
- package/dpr/routes/journeys/download-report/request-download/form/tests.cy.js.map +1 -1
- package/dpr/routes/journeys/download-report/request-download/routes.js +1 -1
- package/dpr/routes/journeys/download-report/request-download/routes.js.map +1 -1
- package/dpr/routes/journeys/download-report/request-download/service.js +1 -1
- package/dpr/routes/journeys/download-report/request-download/service.js.map +3 -3
- package/dpr/routes/journeys/download-report/request-download/service.ts +20 -8
- package/dpr/routes/journeys/download-report/routes.js +1 -1
- package/dpr/routes/journeys/download-report/routes.js.map +3 -3
- package/dpr/routes/journeys/download-report/routes.ts +1 -4
- package/dpr/routes/journeys/download-report/tests.cy.js +1 -1
- package/dpr/routes/journeys/download-report/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/download-report/tests.cy.ts +4 -1
- package/dpr/routes/journeys/download-report/utils.js +1 -1
- package/dpr/routes/journeys/download-report/utils.js.map +2 -2
- package/dpr/routes/journeys/download-report/utils.ts +2 -4
- package/dpr/routes/journeys/my-reports/bookmarks/controller.js +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/controller.js.map +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/list/controller.js +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/list/controller.js.map +3 -3
- package/dpr/routes/journeys/my-reports/bookmarks/list/controller.ts +2 -2
- package/dpr/routes/journeys/my-reports/bookmarks/list/routes.js +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/list/routes.js.map +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/list/tests.cy.js +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/list/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/my-reports/bookmarks/list/tests.cy.ts +1 -2
- package/dpr/routes/journeys/my-reports/bookmarks/routes.js +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/routes.js.map +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/service.js +3 -3
- package/dpr/routes/journeys/my-reports/bookmarks/service.js.map +3 -3
- package/dpr/routes/journeys/my-reports/bookmarks/service.ts +31 -18
- package/dpr/routes/journeys/my-reports/bookmarks/tests.cy.js +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/my-reports/bookmarks/tests.cy.ts +26 -26
- package/dpr/routes/journeys/my-reports/bookmarks/utils.js +1 -1
- package/dpr/routes/journeys/my-reports/bookmarks/utils.js.map +3 -3
- package/dpr/routes/journeys/my-reports/bookmarks/utils.ts +10 -11
- package/dpr/routes/journeys/my-reports/recently-viewed/controller.js +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/controller.js.map +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/list/controller.js +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/list/controller.js.map +3 -3
- package/dpr/routes/journeys/my-reports/recently-viewed/list/controller.ts +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/list/routes.js +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/list/routes.js.map +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/list/tests.cy.js +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/list/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/my-reports/recently-viewed/list/tests.cy.ts +7 -4
- package/dpr/routes/journeys/my-reports/recently-viewed/routes.js +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/routes.js.map +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/service.js +1 -1
- package/dpr/routes/journeys/my-reports/recently-viewed/service.js.map +3 -3
- package/dpr/routes/journeys/my-reports/recently-viewed/service.ts +0 -2
- package/dpr/routes/journeys/my-reports/requested-reports/controller.js +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/controller.js.map +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/list/controller.js +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/list/controller.js.map +3 -3
- package/dpr/routes/journeys/my-reports/requested-reports/list/controller.ts +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/list/routes.js +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/list/routes.js.map +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/list/tests.cy.js +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/list/tests.cy.js.map +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/routes.js +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/routes.js.map +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/service.js +1 -1
- package/dpr/routes/journeys/my-reports/requested-reports/service.js.map +3 -3
- package/dpr/routes/journeys/my-reports/requested-reports/service.ts +25 -17
- package/dpr/routes/journeys/my-reports/routes.js +1 -1
- package/dpr/routes/journeys/my-reports/routes.js.map +3 -3
- package/dpr/routes/journeys/my-reports/routes.ts +0 -3
- package/dpr/routes/journeys/product-collection/routes.js +1 -1
- package/dpr/routes/journeys/product-collection/routes.js.map +1 -1
- package/dpr/routes/journeys/product-collection/selected/controller.js +1 -1
- package/dpr/routes/journeys/product-collection/selected/controller.js.map +1 -1
- package/dpr/routes/journeys/product-collection/selected/routes.js +1 -1
- package/dpr/routes/journeys/product-collection/selected/routes.js.map +1 -1
- package/dpr/routes/journeys/product-collection/selected/tests.cy.js +1 -1
- package/dpr/routes/journeys/product-collection/selected/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/product-collection/selected/tests.cy.ts +6 -4
- package/dpr/routes/journeys/product-collection/selected/validation.js +1 -1
- package/dpr/routes/journeys/product-collection/selected/validation.js.map +1 -1
- package/dpr/routes/journeys/request-missing-report/form/controller.js +1 -1
- package/dpr/routes/journeys/request-missing-report/form/controller.js.map +3 -3
- package/dpr/routes/journeys/request-missing-report/form/controller.ts +21 -19
- package/dpr/routes/journeys/request-missing-report/form/routes.js +1 -1
- package/dpr/routes/journeys/request-missing-report/form/routes.js.map +1 -1
- package/dpr/routes/journeys/request-missing-report/form/tests.cy.js +1 -1
- package/dpr/routes/journeys/request-missing-report/form/tests.cy.js.map +1 -1
- package/dpr/routes/journeys/request-missing-report/form/validation.js +1 -1
- package/dpr/routes/journeys/request-missing-report/form/validation.js.map +1 -1
- package/dpr/routes/journeys/request-missing-report/routes.js +1 -1
- package/dpr/routes/journeys/request-missing-report/routes.js.map +1 -1
- package/dpr/routes/journeys/request-missing-report/submitted/controller.js +1 -1
- package/dpr/routes/journeys/request-missing-report/submitted/controller.js.map +1 -1
- package/dpr/routes/journeys/request-missing-report/submitted/routes.js +1 -1
- package/dpr/routes/journeys/request-missing-report/submitted/routes.js.map +1 -1
- package/dpr/routes/journeys/request-missing-report/submitted/tests.cy.js +1 -1
- package/dpr/routes/journeys/request-missing-report/submitted/tests.cy.js.map +1 -1
- package/dpr/routes/journeys/request-missing-report/tests.cy.js +1 -1
- package/dpr/routes/journeys/request-missing-report/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/request-missing-report/tests.cy.ts +1 -1
- package/dpr/routes/journeys/request-report/controller.js +1 -1
- package/dpr/routes/journeys/request-report/controller.js.map +3 -3
- package/dpr/routes/journeys/request-report/controller.ts +1 -1
- package/dpr/routes/journeys/request-report/filters/controller.js +1 -1
- package/dpr/routes/journeys/request-report/filters/controller.js.map +3 -3
- package/dpr/routes/journeys/request-report/filters/controller.ts +7 -8
- package/dpr/routes/journeys/request-report/filters/routes.js +1 -1
- package/dpr/routes/journeys/request-report/filters/routes.js.map +1 -1
- package/dpr/routes/journeys/request-report/filters/tests.cy.js +1 -1
- package/dpr/routes/journeys/request-report/filters/tests.cy.js.map +1 -1
- package/dpr/routes/journeys/request-report/filters/utils.js +1 -1
- package/dpr/routes/journeys/request-report/filters/utils.js.map +3 -3
- package/dpr/routes/journeys/request-report/filters/utils.ts +38 -23
- package/dpr/routes/journeys/request-report/filters/view.njk +2 -1
- package/dpr/routes/journeys/request-report/routes.js +1 -1
- package/dpr/routes/journeys/request-report/routes.js.map +2 -2
- package/dpr/routes/journeys/request-report/routes.ts +2 -2
- package/dpr/routes/journeys/request-report/status/controller.js +1 -1
- package/dpr/routes/journeys/request-report/status/controller.js.map +3 -3
- package/dpr/routes/journeys/request-report/status/controller.ts +4 -4
- package/dpr/routes/journeys/request-report/status/routes.js +1 -1
- package/dpr/routes/journeys/request-report/status/routes.js.map +1 -1
- package/dpr/routes/journeys/request-report/status/tests.cy.js +1 -1
- package/dpr/routes/journeys/request-report/status/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/request-report/status/tests.cy.ts +9 -4
- package/dpr/routes/journeys/request-report/status/utils.js +1 -1
- package/dpr/routes/journeys/request-report/status/utils.js.map +3 -3
- package/dpr/routes/journeys/request-report/status/utils.ts +10 -13
- package/dpr/routes/journeys/request-report/tests.cy.js +1 -1
- package/dpr/routes/journeys/request-report/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/request-report/tests.cy.ts +14 -11
- package/dpr/routes/journeys/routes.js +1 -1
- package/dpr/routes/journeys/routes.js.map +1 -1
- package/dpr/routes/journeys/view-report/async/controller.js +1 -1
- package/dpr/routes/journeys/view-report/async/controller.js.map +3 -3
- package/dpr/routes/journeys/view-report/async/controller.ts +4 -4
- package/dpr/routes/journeys/view-report/async/dashboard/controller.js +1 -1
- package/dpr/routes/journeys/view-report/async/dashboard/controller.js.map +3 -3
- package/dpr/routes/journeys/view-report/async/dashboard/controller.ts +4 -4
- package/dpr/routes/journeys/view-report/async/dashboard/routes.js +1 -1
- package/dpr/routes/journeys/view-report/async/dashboard/routes.js.map +1 -1
- package/dpr/routes/journeys/view-report/async/dashboard/tests.cy.js +1 -1
- package/dpr/routes/journeys/view-report/async/dashboard/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/view-report/async/dashboard/tests.cy.ts +2 -2
- package/dpr/routes/journeys/view-report/async/dashboard/utils.js +1 -1
- package/dpr/routes/journeys/view-report/async/dashboard/utils.js.map +3 -3
- package/dpr/routes/journeys/view-report/async/dashboard/utils.ts +6 -8
- package/dpr/routes/journeys/view-report/async/report/controller.js +1 -1
- package/dpr/routes/journeys/view-report/async/report/controller.js.map +3 -3
- package/dpr/routes/journeys/view-report/async/report/controller.ts +5 -5
- package/dpr/routes/journeys/view-report/async/report/routes.js +1 -1
- package/dpr/routes/journeys/view-report/async/report/routes.js.map +1 -1
- package/dpr/routes/journeys/view-report/async/report/tests.cy.js +1 -1
- package/dpr/routes/journeys/view-report/async/report/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/view-report/async/report/tests.cy.ts +9 -7
- package/dpr/routes/journeys/view-report/async/report/types.js +1 -1
- package/dpr/routes/journeys/view-report/async/report/types.js.map +2 -2
- package/dpr/routes/journeys/view-report/async/report/types.ts +8 -8
- package/dpr/routes/journeys/view-report/async/report/utils.js +1 -1
- package/dpr/routes/journeys/view-report/async/report/utils.js.map +2 -2
- package/dpr/routes/journeys/view-report/async/report/utils.ts +16 -18
- package/dpr/routes/journeys/view-report/async/routes.js +1 -1
- package/dpr/routes/journeys/view-report/async/routes.js.map +1 -1
- package/dpr/routes/journeys/view-report/controller.js +1 -1
- package/dpr/routes/journeys/view-report/controller.js.map +3 -3
- package/dpr/routes/journeys/view-report/controller.ts +1 -1
- package/dpr/routes/journeys/view-report/routes.js +1 -1
- package/dpr/routes/journeys/view-report/routes.js.map +2 -2
- package/dpr/routes/journeys/view-report/routes.ts +6 -3
- package/dpr/routes/journeys/view-report/sync/load-report/controller.js +1 -1
- package/dpr/routes/journeys/view-report/sync/load-report/controller.js.map +2 -2
- package/dpr/routes/journeys/view-report/sync/load-report/controller.ts +1 -1
- package/dpr/routes/journeys/view-report/sync/load-report/routes.js +1 -1
- package/dpr/routes/journeys/view-report/sync/load-report/routes.js.map +1 -1
- package/dpr/routes/journeys/view-report/sync/report/controller.js +1 -1
- package/dpr/routes/journeys/view-report/sync/report/controller.js.map +3 -3
- package/dpr/routes/journeys/view-report/sync/report/controller.ts +6 -6
- package/dpr/routes/journeys/view-report/sync/report/routes.js +1 -1
- package/dpr/routes/journeys/view-report/sync/report/routes.js.map +1 -1
- package/dpr/routes/journeys/view-report/sync/report/utils.js +1 -1
- package/dpr/routes/journeys/view-report/sync/report/utils.js.map +3 -3
- package/dpr/routes/journeys/view-report/sync/report/utils.ts +29 -19
- package/dpr/routes/journeys/view-report/sync/routes.js +1 -1
- package/dpr/routes/journeys/view-report/sync/routes.js.map +1 -1
- package/dpr/routes/journeys/view-report/sync/tests.cy.js +1 -1
- package/dpr/routes/journeys/view-report/sync/tests.cy.js.map +2 -2
- package/dpr/routes/journeys/view-report/sync/tests.cy.ts +1 -1
- package/dpr/routes/journeys/view-report/utils.js +1 -1
- package/dpr/routes/journeys/view-report/utils.js.map +3 -3
- package/dpr/routes/journeys/view-report/utils.ts +22 -12
- package/dpr/services/dashboardService.js +1 -1
- package/dpr/services/dashboardService.js.map +3 -3
- package/dpr/services/dashboardService.ts +1 -3
- package/dpr/services/defaultFilterValuesService.js +1 -1
- package/dpr/services/defaultFilterValuesService.js.map +3 -3
- package/dpr/services/defaultFilterValuesService.ts +34 -15
- package/dpr/services/index.js +1 -1
- package/dpr/services/index.js.map +1 -1
- package/dpr/services/missingReport/missingReportService.js +2 -0
- package/dpr/services/missingReport/missingReportService.js.map +7 -0
- package/dpr/services/missingReport/missingReportService.ts +26 -0
- package/dpr/services/productCollection/productCollectionService.js +1 -1
- package/dpr/services/productCollection/productCollectionService.js.map +3 -3
- package/dpr/services/productCollection/productCollectionService.ts +19 -14
- package/dpr/services/productCollection/productCollectionStoreService.js +1 -1
- package/dpr/services/productCollection/productCollectionStoreService.js.map +3 -3
- package/dpr/services/productCollection/productCollectionStoreService.ts +9 -3
- package/dpr/services/reportStoreService.js +1 -1
- package/dpr/services/reportStoreService.js.map +2 -2
- package/dpr/services/reportStoreService.ts +1 -1
- package/dpr/services/reportingService.js +1 -1
- package/dpr/services/reportingService.js.map +3 -3
- package/dpr/services/reportingService.ts +1 -3
- package/dpr/setUpNunjucksFilters.js +1 -1
- package/dpr/setUpNunjucksFilters.js.map +1 -1
- package/dpr/types/AsyncReportUtils.js +1 -1
- package/dpr/types/AsyncReportUtils.js.map +2 -2
- package/dpr/types/AsyncReportUtils.ts +2 -1
- package/dpr/types/Bookmark.js +1 -1
- package/dpr/types/Bookmark.js.map +2 -2
- package/dpr/types/Bookmark.ts +9 -3
- package/dpr/types/Charts.js +1 -1
- package/dpr/types/Charts.js.map +1 -1
- package/dpr/types/Download.js +1 -1
- package/dpr/types/Download.js.map +1 -1
- package/dpr/types/DprConfig.js +1 -1
- package/dpr/types/DprConfig.js.map +2 -2
- package/dpr/types/DprConfig.ts +8 -0
- package/dpr/types/DprUser.js +1 -1
- package/dpr/types/DprUser.js.map +2 -2
- package/dpr/types/DprUser.ts +2 -2
- package/dpr/types/EmbeddedReportUtils.js +1 -1
- package/dpr/types/EmbeddedReportUtils.js.map +1 -1
- package/dpr/types/ExecutionData.d.js +1 -1
- package/dpr/types/ExecutionData.d.js.map +2 -2
- package/dpr/types/ExecutionData.d.ts +2 -2
- package/dpr/types/Metrics.js +1 -1
- package/dpr/types/Metrics.js.map +2 -2
- package/dpr/types/Metrics.ts +1 -1
- package/dpr/types/ReportQuery.js +1 -1
- package/dpr/types/ReportQuery.js.map +2 -2
- package/dpr/types/ReportQuery.ts +15 -11
- package/dpr/types/ReportStore.js +1 -1
- package/dpr/types/ReportStore.js.map +1 -1
- package/dpr/types/Services.d.js +1 -1
- package/dpr/types/Services.d.js.map +2 -2
- package/dpr/types/Services.d.ts +8 -8
- package/dpr/types/Templates.d.js +1 -1
- package/dpr/types/Templates.d.js.map +1 -1
- package/dpr/types/UserReports.js +1 -1
- package/dpr/types/UserReports.js.map +2 -2
- package/dpr/types/UserReports.ts +29 -15
- package/dpr/types/api.d.js +1 -1
- package/dpr/types/api.d.js.map +1 -1
- package/dpr/types/index.d.js +1 -1
- package/dpr/types/index.d.js.map +2 -2
- package/dpr/types/index.d.ts +1 -1
- package/dpr/utils/CollatedSummaryBuilder/CollatedSummaryBuilder.js +1 -1
- package/dpr/utils/CollatedSummaryBuilder/CollatedSummaryBuilder.js.map +1 -1
- package/dpr/utils/CollatedSummaryBuilder/CollatedSummaryBuilder.test.ts +2 -0
- package/dpr/utils/CreateDprServices.js +2 -0
- package/dpr/utils/CreateDprServices.js.map +7 -0
- package/dpr/utils/CreateDprServices.ts +73 -0
- package/dpr/utils/DataTableBuilder/DataTableBuilder.js +1 -1
- package/dpr/utils/DataTableBuilder/DataTableBuilder.js.map +1 -1
- package/dpr/utils/DataTableBuilder/DataTableBuilder.test.ts +10 -0
- package/dpr/utils/DataTableBuilder/types.d.js +1 -1
- package/dpr/utils/DataTableBuilder/types.d.js.map +2 -2
- package/dpr/utils/DataTableBuilder/types.d.ts +3 -3
- package/dpr/utils/DateMapper/DateMapper.js +1 -1
- package/dpr/utils/DateMapper/DateMapper.js.map +2 -2
- package/dpr/utils/DateMapper/DateMapper.test.ts +22 -9
- package/dpr/utils/DateMapper/DateMapper.ts +9 -11
- package/dpr/utils/DateMapper/types.d.js +1 -1
- package/dpr/utils/DateMapper/types.d.js.map +1 -1
- package/dpr/utils/ErrorHandler.js +2 -0
- package/dpr/utils/ErrorHandler.js.map +7 -0
- package/dpr/utils/ErrorHandler.ts +85 -0
- package/dpr/utils/ParentChildDataTableBuilder/ParentChildDataTableBuilder.js +1 -1
- package/dpr/utils/ParentChildDataTableBuilder/ParentChildDataTableBuilder.js.map +2 -2
- package/dpr/utils/ParentChildDataTableBuilder/ParentChildDataTableBuilder.test.ts +13 -2
- package/dpr/utils/ParentChildDataTableBuilder/ParentChildDataTableBuilder.ts +3 -3
- package/dpr/utils/ParentChildDataTableBuilder/types.d.js +1 -1
- package/dpr/utils/ParentChildDataTableBuilder/types.d.js.map +1 -1
- package/dpr/utils/Personalisation/personalisationUtils.js +1 -1
- package/dpr/utils/Personalisation/personalisationUtils.js.map +3 -3
- package/dpr/utils/Personalisation/personalisationUtils.ts +6 -2
- package/dpr/utils/Personalisation/types.d.js +1 -1
- package/dpr/utils/Personalisation/types.d.js.map +1 -1
- package/dpr/utils/SectionedDataTableBuilder/SectionedDataTableBuilder.js +1 -1
- package/dpr/utils/SectionedDataTableBuilder/SectionedDataTableBuilder.js.map +2 -2
- package/dpr/utils/SectionedDataTableBuilder/SectionedDataTableBuilder.test.ts +5 -0
- package/dpr/utils/SectionedDataTableBuilder/SectionedDataTableBuilder.ts +1 -1
- package/dpr/utils/SectionedDataTableBuilder/types.d.js +1 -1
- package/dpr/utils/SectionedDataTableBuilder/types.d.js.map +1 -1
- package/dpr/utils/SectionedFieldsTableBuilder/SectionedFieldsTableBuilder.js +1 -1
- package/dpr/utils/SectionedFieldsTableBuilder/SectionedFieldsTableBuilder.js.map +2 -2
- package/dpr/utils/SectionedFieldsTableBuilder/SectionedFieldsTableBuilder.test.ts +7 -4
- package/dpr/utils/SectionedFieldsTableBuilder/SectionedFieldsTableBuilder.ts +3 -3
- package/dpr/utils/SummaryDataTableBuilder/SummaryDataTableBuilder.js +1 -1
- package/dpr/utils/SummaryDataTableBuilder/SummaryDataTableBuilder.js.map +1 -1
- package/dpr/utils/SummaryDataTableBuilder/SummaryDataTableBuilder.test.ts +1 -0
- package/dpr/utils/UserStoreItemBuilder.js +1 -1
- package/dpr/utils/UserStoreItemBuilder.js.map +2 -2
- package/dpr/utils/UserStoreItemBuilder.ts +19 -32
- package/dpr/utils/arrayUtils.js +1 -1
- package/dpr/utils/arrayUtils.js.map +1 -1
- package/dpr/utils/datasetHelper.js +1 -1
- package/dpr/utils/datasetHelper.js.map +2 -2
- package/dpr/utils/datasetHelper.test.ts +21 -33
- package/dpr/utils/datasetHelper.ts +12 -17
- package/dpr/utils/definitionUtils.js +1 -1
- package/dpr/utils/definitionUtils.js.map +3 -3
- package/dpr/utils/definitionUtils.ts +14 -3
- package/dpr/utils/index.js +1 -1
- package/dpr/utils/index.js.map +1 -1
- package/dpr/utils/indexedAccesHelper.js +2 -0
- package/dpr/utils/indexedAccesHelper.js.map +7 -0
- package/dpr/utils/indexedAccesHelper.ts +24 -0
- package/dpr/utils/localsHelper.js +1 -1
- package/dpr/utils/localsHelper.js.map +2 -2
- package/dpr/utils/localsHelper.ts +8 -8
- package/dpr/utils/logger.js +1 -1
- package/dpr/utils/logger.js.map +2 -2
- package/dpr/utils/logger.ts +1 -1
- package/dpr/utils/reportListsHelper.js +1 -1
- package/dpr/utils/reportListsHelper.js.map +1 -1
- package/dpr/utils/reportStoreHelper.js +1 -1
- package/dpr/utils/reportStoreHelper.js.map +1 -1
- package/dpr/utils/reportStoreHelper.test.ts +3 -2
- package/dpr/utils/requestStatusHelper.js +1 -1
- package/dpr/utils/requestStatusHelper.js.map +3 -3
- package/dpr/utils/requestStatusHelper.ts +29 -42
- package/dpr/utils/sanitisedError.js +1 -1
- package/dpr/utils/sanitisedError.js.map +2 -2
- package/dpr/utils/sanitisedError.ts +1 -1
- package/dpr/utils/urlHelper.js +1 -1
- package/dpr/utils/urlHelper.js.map +2 -2
- package/dpr/utils/urlHelper.ts +4 -4
- package/dpr/validation/validate.js +1 -1
- package/dpr/validation/validate.js.map +2 -2
- package/dpr/validation/validate.ts +2 -2
- package/package.json +4 -2
- package/dpr/components/error-summary/utils.js +0 -2
- package/dpr/components/error-summary/utils.js.map +0 -7
- package/dpr/components/error-summary/utils.test.ts +0 -54
- package/dpr/components/error-summary/utils.ts +0 -65
- package/dpr/services/missingReport/missingReportClient.js +0 -2
- package/dpr/services/missingReport/missingReportClient.js.map +0 -7
- package/dpr/utils/ReportStoreServiceUtils.js +0 -2
- package/dpr/utils/ReportStoreServiceUtils.js.map +0 -7
- package/dpr/utils/ReportStoreServiceUtils.ts +0 -140
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var O=Object.create;var w=Object.defineProperty;var Y=Object.getOwnPropertyDescriptor;var H=Object.getOwnPropertyNames;var _=Object.getPrototypeOf,j=Object.prototype.hasOwnProperty;var z=(t,r)=>{for(var e in r)w(t,e,{get:r[e],enumerable:!0})},P=(t,r,e,
|
|
1
|
+
"use strict";var O=Object.create;var w=Object.defineProperty;var Y=Object.getOwnPropertyDescriptor;var H=Object.getOwnPropertyNames;var _=Object.getPrototypeOf,j=Object.prototype.hasOwnProperty;var z=(t,r)=>{for(var e in r)w(t,e,{get:r[e],enumerable:!0})},P=(t,r,e,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let o of H(r))!j.call(t,o)&&o!==e&&w(t,o,{get:()=>r[o],enumerable:!(n=Y(r,o))||n.enumerable});return t};var g=(t,r,e)=>(e=t!=null?O(_(t)):{},P(r||!t||!t.__esModule?w(e,"default",{value:t,enumerable:!0}):e,t)),J=t=>P(w({},"__esModule",{value:!0}),t);var M={};z(M,{default:()=>K,getRenderData:()=>U,getReport:()=>W,getReportData:()=>b,getReportRenderData:()=>v,setActions:()=>T});module.exports=J(M);var N=g(require("parseurl")),y=require("../../../../../types/UserReports"),C=g(require("../../../../../types/ReportQuery")),I=g(require("../../../../../components/_reports/report-pagination/utils")),V=g(require("../../../../../components/_reports/report-totals/utils")),k=g(require("../../../../../components/_reports/report-columns-form/utils")),Q=g(require("../../../../../components/_reports/report-actions/utils")),A=g(require("../../../../../components/_filters/utils")),B=g(require("../../../../../components/_filters/filters-selected/utils")),h=g(require("../../../../../utils/localsHelper")),F=g(require("../../../../../utils/UserStoreItemBuilder")),x=g(require("../../../../../utils/DataTableBuilder/DataTableBuilder")),E=require("../../../../../components/_filters/filtersTypeEnum");const T=(t,r,e,n,o,s,a,p,i,l)=>{const{name:c,variant:d,id:u}=r,{name:f,id:D,printable:m}=d,S={enabled:s>0,name:f,reportName:c,csrfToken:t,reportId:u,id:D,columns:e.value,loadType:y.LoadType.SYNC,definitionPath:a,canDownload:o,currentUrl:p,currentQueryParams:i,nestedBaseUrl:l};return Q.default.getActions({download:S,print:{enabled:!!m},share:{reportName:c,name:f,url:n},copy:{url:n}})},G=async({req:t,services:r,reportName:e,name:n,description:o,reportId:s,id:a,userId:p,filters:i})=>{const l={type:y.ReportType.REPORT,reportId:s,id:a,reportName:e,description:o,name:n},c={query:t.query,querySummary:B.default.getQuerySummary(t.query,i)},d=new F.default(l).addInteractiveQuery(c).addStatus(y.RequestStatus.READY).addTimestamp().addReportUrls(t).build();await r.recentlyViewedService?.setRecentlyViewed(d,p)},b=async({services:t,req:r,token:e,reportId:n,id:o,dataProductDefinitionsPath:s})=>{const a=await t.reportingService.getDefinition(e,n,o,s),{variant:p}=a,{resourceName:i,specification:l}=p,c=new C.default({fields:l?.fields||[],template:l?.template||"list",queryParams:r.query,definitionsPath:s});return{reportData:await t.reportingService.getListWithWarnings(i,e,c),reportDefinition:a,reportQuery:c}},W=async({req:t,res:r,services:e})=>{const{token:n,csrfToken:o,dprUser:s}=h.default.getValues(r),{reportId:a,id:p}=t.params,i=t.query.dataProductDefinitionsPath,{reportData:l,reportDefinition:c,reportQuery:d}=await b({services:e,req:t,token:n,reportId:a,id:p,dataProductDefinitionsPath:i}),u=await e.reportingService.getCount(c.variant.resourceName,n,d),f=!!await e.downloadPermissionService?.downloadEnabledForReport(s.id,a,p),D=!!await e.bookmarkService?.isBookmarked(p,a,s.id),m=await U({req:t,res:r,services:e,reportDefinition:c,reportQuery:d,reportData:l,count:u,csrfToken:o,canDownload:f});return Object.keys(m).length&&await G({req:t,services:e,reportName:m.reportName,name:m.name,description:m.description||"",reportId:a,id:p,userId:s.id,filters:m.filterData.filters}),{renderData:{...m,csrfToken:o,loadType:y.LoadType.SYNC,reportId:a,id:p,bookmarked:D,dataProductDefinitionsPath:i}}},v=async({req:t,res:r,services:e,count:n,specification:o,reportQuery:s,data:a,filtersType:p})=>{const i=(0,N.default)(t),l=`${t.protocol}://${t.get("host")}${t.originalUrl}`,c=i?.search?t.originalUrl.split(i.search)[0]:t.originalUrl,d=new x.default(o.fields).withHeaderSortOptions(s).buildTable(a);let u,f;i&&(u=I.default.getPaginationData(i,n,t),f=V.default.getTotals(u.pageSize,u.currentPage,u.totalRows,d.rowCount));const D=await A.default.getFilters({fields:o.fields,req:t,res:r,services:e,filtersType:p||E.FiltersType.INTERACTIVE}),m=k.default.getColumns(o,t);return{dataTable:[d],totals:f,filterData:D,columns:m,pagination:u,reportUrl:c.replace("/download-disabled","").replace("/download-disabled?",""),reportSearch:i?.search,encodedSearch:i?.search?encodeURIComponent(i.search):void 0,fullUrl:l}},U=async({req:t,res:r,services:e,reportDefinition:n,reportQuery:o,reportData:s,count:a,csrfToken:p,canDownload:i})=>{const{dataProductDefinitionsPath:l}=t.query,{nestedBaseUrl:c}=h.default.getValues(r),{name:d,description:u}=n,{specification:f,name:D,description:m,classification:S,printable:$}=n.variant,{data:L}=s;if(!f)throw new Error("No specicication found in definition");const R=await v({req:t,res:r,services:e,count:a,specification:f,reportQuery:o,data:L}),q=T(p,n,R.columns,`${t.protocol}://${t.get("host")}${t.originalUrl}`,i,a,l,R.reportUrl,R.reportSearch||"",c);return{...R,reportName:d,name:D,description:m||u,count:a,type:y.ReportType.REPORT,classification:S,printable:$,actions:q,warnings:s.warnings,canDownload:i,nestedBaseUrl:c}};var K={getRenderData:U,getReport:W,getReportData:b,getReportRenderData:v,setActions:T};0&&(module.exports={getRenderData,getReport,getReportData,getReportRenderData,setActions});
|
|
2
2
|
//# sourceMappingURL=utils.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../../src/dpr/routes/journeys/view-report/sync/report/utils.ts"],
|
|
4
|
-
"sourcesContent": ["import parseUrl from 'parseurl'\nimport type { Request, Response } from 'express'\nimport Dict = NodeJS.Dict\nimport type { components } from '../../../../../types/api'\nimport type { DataTable } from '../../../../../utils/DataTableBuilder/types'\nimport type { ListWithWarnings } from '../../../../../data/types'\nimport type { Columns } from '../../../../../components/_reports/report-columns-form/types'\nimport type { Services } from '../../../../../types/Services'\nimport type { DownloadActionParams } from '../../../../../components/_reports/report-actions/types'\nimport { LoadType, ReportType, RequestStatus } from '../../../../../types/UserReports'\nimport ReportQuery from '../../../../../types/ReportQuery'\nimport { Template } from '../../../../../types/Templates'\nimport { FilterValue } from '../../../../../components/_filters/types'\n\nimport PaginationUtils from '../../../../../components/_reports/report-pagination/utils'\nimport TotalsUtils from '../../../../../components/_reports/report-totals/utils'\nimport ColumnUtils from '../../../../../components/_reports/report-columns-form/utils'\nimport ReportActionsUtils from '../../../../../components/_reports/report-actions/utils'\nimport FiltersUtils from '../../../../../components/_filters/utils'\nimport SelectedFiltersUtils from '../../../../../components/_filters/filters-selected/utils'\nimport LocalsHelper from '../../../../../utils/localsHelper'\nimport UserStoreItemBuilder from '../../../../../utils/UserStoreItemBuilder'\n\nimport DataTableBuilder from '../../../../../utils/DataTableBuilder/DataTableBuilder'\nimport { FiltersType } from '../../../../../components/_filters/filtersTypeEnum'\n\nexport const setActions = (\n csrfToken: string,\n reportDefinition: components['schemas']['SingleVariantReportDefinition'],\n columns: Columns,\n url: string,\n canDownload: boolean,\n count: number,\n dataProductDefinitionsPath: string,\n currentUrl: string,\n currentQueryParams: string,\n nestedBaseUrl: string,\n) => {\n const { name: reportName, variant, id: reportId } = reportDefinition\n const { name, id, printable } = variant\n\n const downloadConfig: DownloadActionParams = {\n enabled: count > 0,\n name,\n reportName,\n csrfToken,\n reportId,\n id,\n columns: columns.value,\n loadType: LoadType.SYNC,\n definitionPath: dataProductDefinitionsPath,\n canDownload,\n currentUrl,\n currentQueryParams,\n nestedBaseUrl,\n }\n\n return ReportActionsUtils.getActions({\n download: downloadConfig,\n print: {\n enabled: printable,\n },\n share: {\n reportName,\n name,\n url,\n },\n copy: {\n url,\n },\n })\n}\n\nconst setAsRecentlyViewed = async ({\n req,\n services,\n reportName,\n name,\n description,\n reportId,\n id,\n userId,\n filters,\n}: {\n req: Request\n services: Services\n reportName: string\n name: string\n description: string\n reportId: string\n id: string\n userId: string\n filters: FilterValue[]\n}) => {\n const stateData = {\n type: ReportType.REPORT,\n reportId,\n id,\n reportName,\n description,\n name,\n }\n\n const interactiveQueryData: { query: Dict<string>; querySummary: Array<Dict<string>> } = {\n query: <Dict<string>>req.query,\n querySummary: SelectedFiltersUtils.getQuerySummary(<Dict<string>>req.query, filters),\n }\n\n const recentlyViewedData = new UserStoreItemBuilder(stateData)\n .addInteractiveQuery(interactiveQueryData)\n .addStatus(RequestStatus.READY)\n .addTimestamp()\n .addReportUrls(req)\n .build()\n\n await services.recentlyViewedService
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": ["utils_exports", "__export", "utils_default", "getRenderData", "getReport", "getReportData", "getReportRenderData", "setActions", "__toCommonJS", "import_parseurl", "import_UserReports", "import_ReportQuery", "import_utils", "import_localsHelper", "import_UserStoreItemBuilder", "import_DataTableBuilder", "import_filtersTypeEnum", "csrfToken", "reportDefinition", "columns", "url", "canDownload", "count", "dataProductDefinitionsPath", "currentUrl", "currentQueryParams", "nestedBaseUrl", "reportName", "variant", "reportId", "name", "id", "printable", "downloadConfig", "ReportActionsUtils", "setAsRecentlyViewed", "req", "services", "description", "userId", "filters", "stateData", "interactiveQueryData", "SelectedFiltersUtils", "recentlyViewedData", "UserStoreItemBuilder", "token", "resourceName", "specification", "reportQuery", "ReportQuery", "res", "dprUser", "LocalsHelper", "reportData", "bookmarked", "renderData", "data", "filtersType", "parseUrl", "fullUrl", "pathname", "
|
|
4
|
+
"sourcesContent": ["import parseUrl from 'parseurl'\nimport type { Request, Response } from 'express'\nimport Dict = NodeJS.Dict\nimport type { components } from '../../../../../types/api'\nimport type { DataTable } from '../../../../../utils/DataTableBuilder/types'\nimport type { ListWithWarnings } from '../../../../../data/types'\nimport type { Columns } from '../../../../../components/_reports/report-columns-form/types'\nimport type { Services } from '../../../../../types/Services'\nimport type { DownloadActionParams } from '../../../../../components/_reports/report-actions/types'\nimport { LoadType, ReportType, RequestStatus } from '../../../../../types/UserReports'\nimport ReportQuery from '../../../../../types/ReportQuery'\nimport { Template } from '../../../../../types/Templates'\nimport { FilterValue } from '../../../../../components/_filters/types'\n\nimport PaginationUtils from '../../../../../components/_reports/report-pagination/utils'\nimport TotalsUtils from '../../../../../components/_reports/report-totals/utils'\nimport ColumnUtils from '../../../../../components/_reports/report-columns-form/utils'\nimport ReportActionsUtils from '../../../../../components/_reports/report-actions/utils'\nimport FiltersUtils from '../../../../../components/_filters/utils'\nimport SelectedFiltersUtils from '../../../../../components/_filters/filters-selected/utils'\nimport LocalsHelper from '../../../../../utils/localsHelper'\nimport UserStoreItemBuilder from '../../../../../utils/UserStoreItemBuilder'\n\nimport DataTableBuilder from '../../../../../utils/DataTableBuilder/DataTableBuilder'\nimport { FiltersType } from '../../../../../components/_filters/filtersTypeEnum'\n\nexport const setActions = (\n csrfToken: string,\n reportDefinition: components['schemas']['SingleVariantReportDefinition'],\n columns: Columns,\n url: string,\n canDownload: boolean,\n count: number,\n dataProductDefinitionsPath: string,\n currentUrl: string,\n currentQueryParams: string,\n nestedBaseUrl: string,\n) => {\n const { name: reportName, variant, id: reportId } = reportDefinition\n const { name, id, printable } = variant\n\n const downloadConfig: DownloadActionParams = {\n enabled: count > 0,\n name,\n reportName,\n csrfToken,\n reportId,\n id,\n columns: columns.value,\n loadType: LoadType.SYNC,\n definitionPath: dataProductDefinitionsPath,\n canDownload,\n currentUrl,\n currentQueryParams,\n nestedBaseUrl,\n }\n\n return ReportActionsUtils.getActions({\n download: downloadConfig,\n print: {\n enabled: Boolean(printable),\n },\n share: {\n reportName,\n name,\n url,\n },\n copy: {\n url,\n },\n })\n}\n\nconst setAsRecentlyViewed = async ({\n req,\n services,\n reportName,\n name,\n description,\n reportId,\n id,\n userId,\n filters,\n}: {\n req: Request\n services: Services\n reportName: string\n name: string\n description: string\n reportId: string\n id: string\n userId: string\n filters: FilterValue[]\n}) => {\n const stateData = {\n type: ReportType.REPORT,\n reportId,\n id,\n reportName,\n description,\n name,\n }\n\n const interactiveQueryData: { query: Dict<string>; querySummary: Array<Dict<string>> } = {\n query: <Dict<string>>req.query,\n querySummary: SelectedFiltersUtils.getQuerySummary(<Dict<string>>req.query, filters),\n }\n\n const recentlyViewedData = new UserStoreItemBuilder(stateData)\n .addInteractiveQuery(interactiveQueryData)\n .addStatus(RequestStatus.READY)\n .addTimestamp()\n .addReportUrls(req)\n .build()\n\n await services.recentlyViewedService?.setRecentlyViewed(recentlyViewedData, userId)\n}\n\nexport const getReportData = async ({\n services,\n req,\n token,\n reportId,\n id,\n dataProductDefinitionsPath,\n}: {\n services: Services\n req: Request\n token: string\n reportId: string\n id: string\n dataProductDefinitionsPath?: string\n}) => {\n const reportDefinition = await services.reportingService.getDefinition(\n token,\n reportId,\n id,\n dataProductDefinitionsPath,\n )\n const { variant } = reportDefinition\n const { resourceName, specification } = variant\n\n const reportQuery = new ReportQuery({\n fields: specification?.fields || [],\n template: (specification?.template as Template) || 'list',\n queryParams: req.query,\n definitionsPath: <string>dataProductDefinitionsPath,\n })\n\n return {\n reportData: await services.reportingService.getListWithWarnings(resourceName, token, reportQuery),\n reportDefinition,\n reportQuery,\n }\n}\n\nexport const getReport = async ({ req, res, services }: { req: Request; res: Response; services: Services }) => {\n const { token, csrfToken, dprUser } = LocalsHelper.getValues(res)\n const { reportId, id } = req.params\n const dataProductDefinitionsPath = <string>req.query['dataProductDefinitionsPath']\n\n const { reportData, reportDefinition, reportQuery } = await getReportData({\n services,\n req,\n token,\n reportId,\n id,\n dataProductDefinitionsPath,\n })\n const count = await services.reportingService.getCount(reportDefinition.variant.resourceName, token, reportQuery)\n const canDownload = Boolean(\n await services.downloadPermissionService?.downloadEnabledForReport(dprUser.id, reportId, id),\n )\n const bookmarked = Boolean(await services.bookmarkService?.isBookmarked(id, reportId, dprUser.id))\n\n const renderData = await getRenderData({\n req,\n res,\n services,\n reportDefinition,\n reportQuery,\n reportData,\n count,\n csrfToken,\n canDownload,\n })\n\n if (Object.keys(renderData).length) {\n await setAsRecentlyViewed({\n req,\n services,\n reportName: renderData.reportName,\n name: renderData.name,\n description: renderData.description || '',\n reportId,\n id,\n userId: dprUser.id,\n filters: renderData.filterData.filters,\n })\n }\n\n return {\n renderData: {\n ...renderData,\n csrfToken,\n loadType: LoadType.SYNC,\n reportId,\n id,\n bookmarked,\n dataProductDefinitionsPath,\n },\n }\n}\n\nexport const getReportRenderData = async ({\n req,\n res,\n services,\n count,\n specification,\n reportQuery,\n data,\n filtersType,\n}: {\n req: Request\n res?: Response\n services?: Services\n count: number\n specification: components['schemas']['Specification']\n reportQuery: ReportQuery\n data: Dict<string>[]\n filtersType?: FiltersType\n}) => {\n const url = parseUrl(req)\n const fullUrl = `${req.protocol}://${req.get('host')}${req.originalUrl}`\n const pathname = url?.search ? req.originalUrl.split(url.search)[0] : req.originalUrl\n\n const dataTable: DataTable = new DataTableBuilder(specification.fields)\n .withHeaderSortOptions(reportQuery)\n .buildTable(data)\n\n let pagination\n let totals\n if (url) {\n pagination = PaginationUtils.getPaginationData(url, count, req)\n totals = TotalsUtils.getTotals(\n pagination.pageSize,\n pagination.currentPage,\n pagination.totalRows,\n dataTable.rowCount,\n )\n }\n\n const filterData = await FiltersUtils.getFilters({\n fields: specification.fields,\n req,\n res,\n services,\n filtersType: filtersType || FiltersType.INTERACTIVE,\n })\n\n const columns = ColumnUtils.getColumns(specification, req)\n\n return {\n dataTable: [dataTable],\n totals,\n filterData,\n columns,\n pagination,\n reportUrl: pathname.replace('/download-disabled', '').replace('/download-disabled?', ''),\n reportSearch: url?.search,\n encodedSearch: url?.search ? encodeURIComponent(url.search) : undefined,\n fullUrl,\n }\n}\n\nexport const getRenderData = async ({\n req,\n res,\n services,\n reportDefinition,\n reportQuery,\n reportData,\n count,\n csrfToken,\n canDownload,\n}: {\n req: Request\n res: Response\n services: Services\n reportDefinition: components['schemas']['SingleVariantReportDefinition']\n reportQuery: ReportQuery\n reportData: ListWithWarnings\n csrfToken: string\n count: number\n canDownload: boolean\n}) => {\n const { dataProductDefinitionsPath } = req.query\n const { nestedBaseUrl } = LocalsHelper.getValues(res)\n const { name: reportName, description: reportDescription } = reportDefinition\n const { specification, name, description, classification, printable } = reportDefinition.variant\n const { data } = reportData\n\n if (!specification) {\n throw new Error('No specicication found in definition')\n }\n\n const reportRenderData = await getReportRenderData({ req, res, services, count, specification, reportQuery, data })\n\n const actions = setActions(\n csrfToken,\n reportDefinition,\n reportRenderData.columns,\n `${req.protocol}://${req.get('host')}${req.originalUrl}`,\n canDownload,\n count,\n <string>dataProductDefinitionsPath,\n reportRenderData.reportUrl,\n reportRenderData.reportSearch || '',\n nestedBaseUrl,\n )\n\n return {\n ...reportRenderData,\n reportName,\n name,\n description: description || reportDescription,\n count,\n type: ReportType.REPORT,\n classification,\n printable,\n actions,\n warnings: reportData.warnings,\n canDownload,\n nestedBaseUrl,\n }\n}\n\nexport default {\n getRenderData,\n getReport,\n getReportData,\n getReportRenderData,\n setActions,\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["utils_exports", "__export", "utils_default", "getRenderData", "getReport", "getReportData", "getReportRenderData", "setActions", "__toCommonJS", "import_parseurl", "import_UserReports", "import_ReportQuery", "import_utils", "import_localsHelper", "import_UserStoreItemBuilder", "import_DataTableBuilder", "import_filtersTypeEnum", "csrfToken", "reportDefinition", "columns", "url", "canDownload", "count", "dataProductDefinitionsPath", "currentUrl", "currentQueryParams", "nestedBaseUrl", "reportName", "variant", "reportId", "name", "id", "printable", "downloadConfig", "ReportActionsUtils", "setAsRecentlyViewed", "req", "services", "description", "userId", "filters", "stateData", "interactiveQueryData", "SelectedFiltersUtils", "recentlyViewedData", "UserStoreItemBuilder", "token", "resourceName", "specification", "reportQuery", "ReportQuery", "res", "dprUser", "LocalsHelper", "reportData", "bookmarked", "renderData", "data", "filtersType", "parseUrl", "fullUrl", "pathname", "dataTable", "DataTableBuilder", "pagination", "totals", "PaginationUtils", "TotalsUtils", "filterData", "FiltersUtils", "ColumnUtils", "reportDescription", "classification", "reportRenderData", "actions"]
|
|
7
7
|
}
|
|
@@ -58,7 +58,7 @@ export const setActions = (
|
|
|
58
58
|
return ReportActionsUtils.getActions({
|
|
59
59
|
download: downloadConfig,
|
|
60
60
|
print: {
|
|
61
|
-
enabled: printable,
|
|
61
|
+
enabled: Boolean(printable),
|
|
62
62
|
},
|
|
63
63
|
share: {
|
|
64
64
|
reportName,
|
|
@@ -113,7 +113,7 @@ const setAsRecentlyViewed = async ({
|
|
|
113
113
|
.addReportUrls(req)
|
|
114
114
|
.build()
|
|
115
115
|
|
|
116
|
-
await services.recentlyViewedService
|
|
116
|
+
await services.recentlyViewedService?.setRecentlyViewed(recentlyViewedData, userId)
|
|
117
117
|
}
|
|
118
118
|
|
|
119
119
|
export const getReportData = async ({
|
|
@@ -141,8 +141,8 @@ export const getReportData = async ({
|
|
|
141
141
|
const { resourceName, specification } = variant
|
|
142
142
|
|
|
143
143
|
const reportQuery = new ReportQuery({
|
|
144
|
-
fields: specification
|
|
145
|
-
template: specification
|
|
144
|
+
fields: specification?.fields || [],
|
|
145
|
+
template: (specification?.template as Template) || 'list',
|
|
146
146
|
queryParams: req.query,
|
|
147
147
|
definitionsPath: <string>dataProductDefinitionsPath,
|
|
148
148
|
})
|
|
@@ -157,7 +157,7 @@ export const getReportData = async ({
|
|
|
157
157
|
export const getReport = async ({ req, res, services }: { req: Request; res: Response; services: Services }) => {
|
|
158
158
|
const { token, csrfToken, dprUser } = LocalsHelper.getValues(res)
|
|
159
159
|
const { reportId, id } = req.params
|
|
160
|
-
const dataProductDefinitionsPath = <string>req.query
|
|
160
|
+
const dataProductDefinitionsPath = <string>req.query['dataProductDefinitionsPath']
|
|
161
161
|
|
|
162
162
|
const { reportData, reportDefinition, reportQuery } = await getReportData({
|
|
163
163
|
services,
|
|
@@ -168,8 +168,10 @@ export const getReport = async ({ req, res, services }: { req: Request; res: Res
|
|
|
168
168
|
dataProductDefinitionsPath,
|
|
169
169
|
})
|
|
170
170
|
const count = await services.reportingService.getCount(reportDefinition.variant.resourceName, token, reportQuery)
|
|
171
|
-
const canDownload =
|
|
172
|
-
|
|
171
|
+
const canDownload = Boolean(
|
|
172
|
+
await services.downloadPermissionService?.downloadEnabledForReport(dprUser.id, reportId, id),
|
|
173
|
+
)
|
|
174
|
+
const bookmarked = Boolean(await services.bookmarkService?.isBookmarked(id, reportId, dprUser.id))
|
|
173
175
|
|
|
174
176
|
const renderData = await getRenderData({
|
|
175
177
|
req,
|
|
@@ -189,7 +191,7 @@ export const getReport = async ({ req, res, services }: { req: Request; res: Res
|
|
|
189
191
|
services,
|
|
190
192
|
reportName: renderData.reportName,
|
|
191
193
|
name: renderData.name,
|
|
192
|
-
description: renderData.description,
|
|
194
|
+
description: renderData.description || '',
|
|
193
195
|
reportId,
|
|
194
196
|
id,
|
|
195
197
|
userId: dprUser.id,
|
|
@@ -231,19 +233,23 @@ export const getReportRenderData = async ({
|
|
|
231
233
|
}) => {
|
|
232
234
|
const url = parseUrl(req)
|
|
233
235
|
const fullUrl = `${req.protocol}://${req.get('host')}${req.originalUrl}`
|
|
234
|
-
const pathname = url
|
|
235
|
-
const pagination = PaginationUtils.getPaginationData(url, count, req)
|
|
236
|
+
const pathname = url?.search ? req.originalUrl.split(url.search)[0] : req.originalUrl
|
|
236
237
|
|
|
237
238
|
const dataTable: DataTable = new DataTableBuilder(specification.fields)
|
|
238
239
|
.withHeaderSortOptions(reportQuery)
|
|
239
240
|
.buildTable(data)
|
|
240
241
|
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
pagination.
|
|
245
|
-
|
|
246
|
-
|
|
242
|
+
let pagination
|
|
243
|
+
let totals
|
|
244
|
+
if (url) {
|
|
245
|
+
pagination = PaginationUtils.getPaginationData(url, count, req)
|
|
246
|
+
totals = TotalsUtils.getTotals(
|
|
247
|
+
pagination.pageSize,
|
|
248
|
+
pagination.currentPage,
|
|
249
|
+
pagination.totalRows,
|
|
250
|
+
dataTable.rowCount,
|
|
251
|
+
)
|
|
252
|
+
}
|
|
247
253
|
|
|
248
254
|
const filterData = await FiltersUtils.getFilters({
|
|
249
255
|
fields: specification.fields,
|
|
@@ -262,8 +268,8 @@ export const getReportRenderData = async ({
|
|
|
262
268
|
columns,
|
|
263
269
|
pagination,
|
|
264
270
|
reportUrl: pathname.replace('/download-disabled', '').replace('/download-disabled?', ''),
|
|
265
|
-
reportSearch: url
|
|
266
|
-
encodedSearch: url
|
|
271
|
+
reportSearch: url?.search,
|
|
272
|
+
encodedSearch: url?.search ? encodeURIComponent(url.search) : undefined,
|
|
267
273
|
fullUrl,
|
|
268
274
|
}
|
|
269
275
|
}
|
|
@@ -295,6 +301,10 @@ export const getRenderData = async ({
|
|
|
295
301
|
const { specification, name, description, classification, printable } = reportDefinition.variant
|
|
296
302
|
const { data } = reportData
|
|
297
303
|
|
|
304
|
+
if (!specification) {
|
|
305
|
+
throw new Error('No specicication found in definition')
|
|
306
|
+
}
|
|
307
|
+
|
|
298
308
|
const reportRenderData = await getReportRenderData({ req, res, services, count, specification, reportQuery, data })
|
|
299
309
|
|
|
300
310
|
const actions = setActions(
|
|
@@ -306,7 +316,7 @@ export const getRenderData = async ({
|
|
|
306
316
|
count,
|
|
307
317
|
<string>dataProductDefinitionsPath,
|
|
308
318
|
reportRenderData.reportUrl,
|
|
309
|
-
reportRenderData.reportSearch,
|
|
319
|
+
reportRenderData.reportSearch || '',
|
|
310
320
|
nestedBaseUrl,
|
|
311
321
|
)
|
|
312
322
|
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var c=Object.create;var m=Object.defineProperty;var d=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var l=Object.getPrototypeOf,v=Object.prototype.hasOwnProperty;var x=(r,o)=>{for(var e in o)m(r,e,{get:o[e],enumerable:!0})},i=(r,o,e,u)=>{if(o&&typeof o=="object"||typeof o=="function")for(let t of g(o))!v.call(r,t)&&t!==e&&m(r,t,{get:()=>o[t],enumerable:!(u=d(o,t))||u.enumerable});return r};var p=(r,o,e)=>(e=r!=null?c(l(r)):{},i(o||!r||!r.__esModule?m(e,"default",{value:r,enumerable:!0}):e,r)),S=r=>i(m({},"__esModule",{value:!0}),r);var A={};x(A,{default:()=>w,routes:()=>a});module.exports=S(A);var s=require("express"),f=p(require("./load-report/routes")),n=p(require("./report/routes")),R=p(require("../../../../middleware/reportAuthoriser"));function a({layoutPath:r,services:o}){const e=(0,s.Router)({mergeParams:!0});return e.use("/report",(0,R.default)(o,r),(0,n.default)({layoutPath:r,services:o})),e.use("/load-report",(0,f.default)({layoutPath:r,services:o})),e}var w=a;0&&(module.exports={routes});
|
|
1
|
+
"use strict";var c=Object.create;var m=Object.defineProperty;var d=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var l=Object.getPrototypeOf,v=Object.prototype.hasOwnProperty;var x=(r,o)=>{for(var e in o)m(r,e,{get:o[e],enumerable:!0})},i=(r,o,e,u)=>{if(o&&typeof o=="object"||typeof o=="function")for(let t of g(o))!v.call(r,t)&&t!==e&&m(r,t,{get:()=>o[t],enumerable:!(u=d(o,t))||u.enumerable});return r};var p=(r,o,e)=>(e=r!=null?c(l(r)):{},i(o||!r||!r.__esModule?m(e,"default",{value:r,enumerable:!0}):e,r)),S=r=>i(m({},"__esModule",{value:!0}),r);var A={};x(A,{default:()=>w,routes:()=>a});module.exports=S(A);var s=require("express"),f=p(require("./load-report/routes")),n=p(require("./report/routes")),R=p(require("../../../../middleware/reportAuthoriser"));function a({layoutPath:r,services:o}){const e=(0,s.Router)({mergeParams:!0});return e.use("/report",(0,R.default)(o,r),(0,n.default)({layoutPath:r,services:o})),e.use("/load-report",(0,f.default)({layoutPath:r,services:o})),e}var w=a;0&&(module.exports={routes});
|
|
2
2
|
//# sourceMappingURL=routes.js.map
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/dpr/routes/journeys/view-report/sync/routes.ts"],
|
|
4
4
|
"sourcesContent": ["/* eslint-disable no-param-reassign */\nimport { Router } from 'express'\nimport { Services } from '../../../../types/Services'\n\n// Routes\nimport loadReportRoutes from './load-report/routes'\nimport viewReportRoutes from './report/routes'\n\n// middleware\nimport reportAuthoriser from '../../../../middleware/reportAuthoriser'\n\nexport function routes({ layoutPath, services }: { layoutPath: string; services: Services }) {\n const router = Router({ mergeParams: true })\n\n router.use('/report', reportAuthoriser(services, layoutPath), viewReportRoutes({ layoutPath, services }))\n router.use(`/load-report`, loadReportRoutes({ layoutPath, services }))\n\n return router\n}\n\nexport default routes\n"],
|
|
5
|
-
"mappings": "
|
|
5
|
+
"mappings": "0jBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,aAAAE,EAAA,WAAAC,IAAA,eAAAC,EAAAJ,GACA,IAAAK,EAAuB,mBAIvBC,EAA6B,mCAC7BA,EAA6B,8BAG7BC,EAA6B,sDAEtB,SAASJ,EAAO,CAAE,WAAAK,EAAY,SAAAC,CAAS,EAA+C,CAC3F,MAAMC,KAAS,UAAO,CAAE,YAAa,EAAK,CAAC,EAE3C,OAAAA,EAAO,IAAI,aAAW,EAAAC,SAAiBF,EAAUD,CAAU,KAAG,EAAAI,SAAiB,CAAE,WAAAJ,EAAY,SAAAC,CAAS,CAAC,CAAC,EACxGC,EAAO,IAAI,kBAAgB,EAAAG,SAAiB,CAAE,WAAAL,EAAY,SAAAC,CAAS,CAAC,CAAC,EAE9DC,CACT,CAEA,IAAOR,EAAQC",
|
|
6
6
|
"names": ["routes_exports", "__export", "routes_default", "routes", "__toCommonJS", "import_express", "import_routes", "import_reportAuthoriser", "layoutPath", "services", "router", "reportAuthoriser", "viewReportRoutes", "loadReportRoutes"]
|
|
7
7
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var e=require("../../../../../../cypress-tests/cypressUtils");context("Platform sync tests",()=>{const t="/embedded/platform/";describe("Sync tests from the platform",()=>{before(()=>{(0,e.executeReportStubs)(),cy.task("stubDefinitionSyncReport"),cy.task("stubRequestSuccessResult20"),cy.task("stubSyncRequestDataSuccess"),cy.task("stubSyncRequestDataSuccessCount")}),it("should load a sync report",()=>{cy.visit(t),cy.findByLabelText(/Reports catalogue.*/i).within(()=>{cy.findByRole("row",{name:(c,s)
|
|
1
|
+
"use strict";var e=require("../../../../../../cypress-tests/cypressUtils");context("Platform sync tests",()=>{const t="/embedded/platform/";describe("Sync tests from the platform",()=>{before(()=>{(0,e.executeReportStubs)(),cy.task("stubDefinitionSyncReport"),cy.task("stubRequestSuccessResult20"),cy.task("stubSyncRequestDataSuccess"),cy.task("stubSyncRequestDataSuccessCount")}),it("should load a sync report",()=>{cy.visit(t),cy.findByLabelText(/Reports catalogue.*/i).within(()=>{cy.findByRole("row",{name:(c,s)=>!!s.textContent?.includes("This is an sync report")}).within(()=>{cy.findByRole("link",{name:/Load report/}).click()})}),cy.findByRole("heading",{name:/Sync report/,level:1}).should("be.visible")})})});
|
|
2
2
|
//# sourceMappingURL=tests.cy.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../../src/dpr/routes/journeys/view-report/sync/tests.cy.ts"],
|
|
4
|
-
"sourcesContent": ["import { executeReportStubs } from '../../../../../../cypress-tests/cypressUtils'\n\ncontext('Platform sync tests', () => {\n const path = '/embedded/platform/'\n\n describe('Sync tests from the platform', () => {\n before(() => {\n executeReportStubs()\n cy.task('stubDefinitionSyncReport')\n cy.task('stubRequestSuccessResult20')\n cy.task('stubSyncRequestDataSuccess')\n cy.task('stubSyncRequestDataSuccessCount')\n })\n it('should load a sync report', () => {\n cy.visit(path)\n\n cy.findByLabelText(/Reports catalogue.*/i).within(() => {\n cy.findByRole('row', {\n name: (_, element) => {\n return element.textContent
|
|
5
|
-
"mappings": "
|
|
4
|
+
"sourcesContent": ["import { executeReportStubs } from '../../../../../../cypress-tests/cypressUtils'\n\ncontext('Platform sync tests', () => {\n const path = '/embedded/platform/'\n\n describe('Sync tests from the platform', () => {\n before(() => {\n executeReportStubs()\n cy.task('stubDefinitionSyncReport')\n cy.task('stubRequestSuccessResult20')\n cy.task('stubSyncRequestDataSuccess')\n cy.task('stubSyncRequestDataSuccessCount')\n })\n it('should load a sync report', () => {\n cy.visit(path)\n\n cy.findByLabelText(/Reports catalogue.*/i).within(() => {\n cy.findByRole('row', {\n name: (_, element) => {\n return Boolean(element.textContent?.includes('This is an sync report'))\n },\n }).within(() => {\n cy.findByRole('link', { name: /Load report/ }).click()\n })\n })\n\n cy.findByRole('heading', { name: /Sync report/, level: 1 }).should('be.visible')\n })\n })\n})\n"],
|
|
5
|
+
"mappings": "aAAA,IAAAA,EAAmC,wDAEnC,QAAQ,sBAAuB,IAAM,CACnC,MAAMC,EAAO,sBAEb,SAAS,+BAAgC,IAAM,CAC7C,OAAO,IAAM,IACX,sBAAmB,EACnB,GAAG,KAAK,0BAA0B,EAClC,GAAG,KAAK,4BAA4B,EACpC,GAAG,KAAK,4BAA4B,EACpC,GAAG,KAAK,iCAAiC,CAC3C,CAAC,EACD,GAAG,4BAA6B,IAAM,CACpC,GAAG,MAAMA,CAAI,EAEb,GAAG,gBAAgB,sBAAsB,EAAE,OAAO,IAAM,CACtD,GAAG,WAAW,MAAO,CACnB,KAAM,CAACC,EAAGC,IACD,EAAQA,EAAQ,aAAa,SAAS,wBAAwB,CAEzE,CAAC,EAAE,OAAO,IAAM,CACd,GAAG,WAAW,OAAQ,CAAE,KAAM,aAAc,CAAC,EAAE,MAAM,CACvD,CAAC,CACH,CAAC,EAED,GAAG,WAAW,UAAW,CAAE,KAAM,cAAe,MAAO,CAAE,CAAC,EAAE,OAAO,YAAY,CACjF,CAAC,CACH,CAAC,CACH,CAAC",
|
|
6
6
|
"names": ["import_cypressUtils", "path", "_", "element"]
|
|
7
7
|
}
|
|
@@ -17,7 +17,7 @@ context('Platform sync tests', () => {
|
|
|
17
17
|
cy.findByLabelText(/Reports catalogue.*/i).within(() => {
|
|
18
18
|
cy.findByRole('row', {
|
|
19
19
|
name: (_, element) => {
|
|
20
|
-
return element.textContent
|
|
20
|
+
return Boolean(element.textContent?.includes('This is an sync report'))
|
|
21
21
|
},
|
|
22
22
|
}).within(() => {
|
|
23
23
|
cy.findByRole('link', { name: /Load report/ }).click()
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var T=Object.create;var g=Object.defineProperty;var x=Object.getOwnPropertyDescriptor;var E=Object.getOwnPropertyNames;var j=Object.getPrototypeOf,
|
|
1
|
+
"use strict";var T=Object.create;var g=Object.defineProperty;var x=Object.getOwnPropertyDescriptor;var E=Object.getOwnPropertyNames;var j=Object.getPrototypeOf,z=Object.prototype.hasOwnProperty;var B=(e,o)=>{for(var t in o)g(e,t,{get:o[t],enumerable:!0})},C=(e,o,t,a)=>{if(o&&typeof o=="object"||typeof o=="function")for(let n of E(o))!z.call(e,n)&&n!==t&&g(e,n,{get:()=>o[n],enumerable:!(a=x(o,n))||a.enumerable});return e};var y=(e,o,t)=>(t=e!=null?T(j(e)):{},C(o||!e||!e.__esModule?g(t,"default",{value:e,enumerable:!0}):t,e)),M=e=>C(g({},"__esModule",{value:!0}),e);var H={};B(H,{applyDashboardInteractiveQuery:()=>P,applyReportInteractiveQuery:()=>A,default:()=>$});module.exports=M(H);var m=require("../../../components/_filters/filter-input/enum"),D=y(require("../../../utils/localsHelper")),F=y(require("../../../utils/definitionUtils")),I=y(require("../../../utils/DateMapper/DateMapper")),V=y(require("../../../components/_reports/report-columns-form/utils"));const A=async(e,o,t,a)=>{const{reportId:n,id:s}=e.params,{token:l,definitionsPath:i}=D.default.getValues(o),r=(await t.reportingService.getDefinition(l,n,s,i)).variant.specification?.fields||[];return L(e,o,t,a,r)},P=async(e,o,t,a)=>{const{reportId:n,id:s}=e.params,{token:l,definitionsPath:i}=D.default.getValues(o),r=(await t.dashboardService.getDefinition(l,n,s,i)).filterFields||[];return L(e,o,t,a,r)},L=async(e,o,t,a,n)=>{const{tableId:s,id:l}=e.params,{dprUser:i}=D.default.getValues(o);let p;s?p=await t.recentlyViewedService?.getReportByTableId(s,i.id):p=await t.recentlyViewedService?.getReportById(l,i.id);const r=p?.interactiveQuery?.data,d=r?.preventDefault,R=r?.pageSize,S=r?.selectedPage,b=r?.sortColumn,h=r?.sortedAsc;let v={};r&&(v=Object.keys(r).filter(c=>c.includes("filters.")).reduce((c,u)=>({...c,[u]:r[u]}),{}));let f={...d&&{preventDefault:d},...S&&{selectedPage:S},...R&&{pageSize:R},...b&&{sortColumn:b},...h&&{sortedAsc:h},...e.body};if(a==="columns"){const{columns:c}=e.body,u=V.default.mandatoryColumns(n);let w=[];c&&(w=Array.isArray(c)?c:[c]);const U=[...u,...w];f={...f,columns:U,...v}}else{const c=r?.columns||[];f={...f,columns:c}}const Q=O({formData:f,fields:n});o.redirect(`${e.baseUrl}?${Q}`)},O=({formData:e,fields:o})=>{const t=new URLSearchParams;Object.keys(e).forEach(n=>{const s=e[n];if(s&&n!=="_csrf"){const l=n.split(".")[1];if(l){const i=F.default.getFilter(o,l);if(i){const{type:p}=i;switch(p.toLocaleLowerCase()){case m.FilterType.date.toLocaleLowerCase():case m.FilterType.dateRange.toLocaleLowerCase():case m.FilterType.granularDateRange.toLocaleLowerCase():{let r=s;const d=new I.default;d.getDateType(r)!=="none"&&(r=d.toDateString(r,"iso")||""),r&&t.append(n,r)}break;case m.FilterType.multiselect.toLocaleLowerCase():Array.isArray(s)?s.forEach(d=>{t.append(n,d)}):t.append(n,s);break;default:t.append(n,s);break}}}else Array.isArray(s)?s.forEach(i=>{t.append(n,i)}):t.append(n,s)}});const a=t.toString();return decodeURIComponent(a)};var $={applyDashboardInteractiveQuery:P,applyReportInteractiveQuery:A};0&&(module.exports={applyDashboardInteractiveQuery,applyReportInteractiveQuery});
|
|
2
2
|
//# sourceMappingURL=utils.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../../src/dpr/routes/journeys/view-report/utils.ts"],
|
|
4
|
-
"sourcesContent": ["import { Request, Response } from 'express'\nimport { FilterType } from '../../../components/_filters/filter-input/enum'\nimport { components } from '../../../types/api'\nimport { StoredReportData } from '../../../types/UserReports'\nimport { Services } from '../../../types/Services'\nimport LocalsHelper from '../../../utils/localsHelper'\nimport definitionUtils from '../../../utils/definitionUtils'\nimport DateMapper from '../../../utils/DateMapper/DateMapper'\nimport ColumnsUtils from '../../../components/_reports/report-columns-form/utils'\n\nexport const applyReportInteractiveQuery = async (\n req: Request,\n res: Response,\n services: Services,\n applyType: 'columns' | 'filters',\n) => {\n const { reportId, id } = req.params\n const { token, definitionsPath } = LocalsHelper.getValues(res)\n\n // Get the definition\n const definition: components['schemas']['SingleVariantReportDefinition'] =\n await services.reportingService.getDefinition(token, reportId, id, definitionsPath)\n const fields = definition.variant.specification
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": ["utils_exports", "__export", "applyDashboardInteractiveQuery", "applyReportInteractiveQuery", "utils_default", "__toCommonJS", "import_enum", "import_localsHelper", "import_definitionUtils", "import_DateMapper", "import_utils", "req", "res", "services", "applyType", "reportId", "id", "token", "definitionsPath", "LocalsHelper", "fields", "applyInteractiveQuery", "tableId", "dprUser", "reportStateData", "interactiveQueryData", "preventDefault", "
|
|
4
|
+
"sourcesContent": ["import { Request, Response } from 'express'\nimport { FilterType } from '../../../components/_filters/filter-input/enum'\nimport { components } from '../../../types/api'\nimport { StoredReportData } from '../../../types/UserReports'\nimport { Services } from '../../../types/Services'\nimport LocalsHelper from '../../../utils/localsHelper'\nimport definitionUtils from '../../../utils/definitionUtils'\nimport DateMapper from '../../../utils/DateMapper/DateMapper'\nimport ColumnsUtils from '../../../components/_reports/report-columns-form/utils'\n\nexport const applyReportInteractiveQuery = async (\n req: Request,\n res: Response,\n services: Services,\n applyType: 'columns' | 'filters',\n) => {\n const { reportId, id } = req.params\n const { token, definitionsPath } = LocalsHelper.getValues(res)\n\n // Get the definition\n const definition: components['schemas']['SingleVariantReportDefinition'] =\n await services.reportingService.getDefinition(token, reportId, id, definitionsPath)\n const fields = definition.variant.specification?.fields || []\n\n return applyInteractiveQuery(req, res, services, applyType, fields)\n}\n\nexport const applyDashboardInteractiveQuery = async (\n req: Request,\n res: Response,\n services: Services,\n applyType: 'columns' | 'filters',\n) => {\n const { reportId, id } = req.params\n const { token, definitionsPath } = LocalsHelper.getValues(res)\n\n // Get the definition\n const definition: components['schemas']['DashboardDefinition'] = await services.dashboardService.getDefinition(\n token,\n reportId,\n id,\n definitionsPath,\n )\n const fields = definition.filterFields || []\n\n return applyInteractiveQuery(req, res, services, applyType, fields)\n}\n\nconst applyInteractiveQuery = async (\n req: Request,\n res: Response,\n services: Services,\n applyType: 'columns' | 'filters',\n fields: components['schemas']['FieldDefinition'][],\n) => {\n const { tableId, id } = req.params\n const { dprUser } = LocalsHelper.getValues(res)\n\n // get the report state\n let reportStateData: StoredReportData | undefined\n if (tableId) {\n // means its an async report\n reportStateData = await services.recentlyViewedService?.getReportByTableId(tableId, dprUser.id)\n } else {\n // its a sync report and can be indentified by ID as will always only be 1\n reportStateData = await services.recentlyViewedService?.getReportById(id, dprUser.id)\n }\n\n // Get the stored interactive query data\n const interactiveQueryData = reportStateData?.interactiveQuery?.data\n\n const preventDefault = interactiveQueryData?.['preventDefault']\n const pageSize = interactiveQueryData?.['pageSize']\n const selectedPage = interactiveQueryData?.['selectedPage']\n const sortColumn = interactiveQueryData?.['sortColumn']\n const sortedAsc = interactiveQueryData?.['sortedAsc']\n\n let filters = {}\n if (interactiveQueryData) {\n filters = Object.keys(interactiveQueryData)\n .filter((key) => key.includes('filters.'))\n .reduce((acc, key) => ({ ...acc, [key]: interactiveQueryData[key] }), {})\n }\n\n // Create merged form data\n let formData: Record<string, string | string[]> = {\n ...(preventDefault && { preventDefault }),\n ...(selectedPage && { selectedPage }),\n ...(pageSize && { pageSize }),\n ...(sortColumn && { sortColumn }),\n ...(sortedAsc && { sortedAsc }),\n ...req.body,\n }\n\n if (applyType === 'columns') {\n const { columns } = req.body\n const mandatoryCols = ColumnsUtils.mandatoryColumns(fields)\n\n let bodyColumns = []\n if (columns) {\n bodyColumns = Array.isArray(columns) ? columns : [columns]\n }\n const columnsData = [...mandatoryCols, ...bodyColumns]\n formData = { ...formData, columns: columnsData, ...filters }\n } else {\n const columns = interactiveQueryData?.['columns'] || []\n formData = { ...formData, columns }\n }\n\n // Create query string\n const filtersString = createQueryParamsFromFormData({\n formData,\n fields,\n })\n\n // Redirect back to report\n res.redirect(`${req.baseUrl}?${filtersString}`)\n}\n\nconst createQueryParamsFromFormData = ({\n formData,\n fields,\n}: {\n fields: components['schemas']['FieldDefinition'][]\n formData: Record<string, string | string[]>\n}) => {\n // create the query string\n const params = new URLSearchParams()\n Object.keys(formData).forEach((key) => {\n const value = formData[key]\n\n if (value && key !== '_csrf') {\n const fieldId = key.split('.')[1] // filters are prefixed with 'filters.'\n if (fieldId) {\n const filter = definitionUtils.getFilter(fields, fieldId)\n if (filter) {\n const { type: filterType } = filter\n switch (filterType.toLocaleLowerCase()) {\n // DATE RANGE TYPES\n case FilterType.date.toLocaleLowerCase():\n case FilterType.dateRange.toLocaleLowerCase():\n case FilterType.granularDateRange.toLocaleLowerCase():\n {\n let dateValue: string = <string>value\n const dateMapper = new DateMapper()\n const currentDateFormat = dateMapper.getDateType(dateValue)\n if (currentDateFormat !== 'none') {\n dateValue = dateMapper.toDateString(dateValue, 'iso') || ''\n }\n if (dateValue) {\n params.append(key, dateValue)\n }\n }\n break\n\n // MULTIVALUE TYPES: string[] || string if only one value selected\n case FilterType.multiselect.toLocaleLowerCase():\n if (Array.isArray(value)) {\n const multiselectValue = <string[]>value\n multiselectValue.forEach((v: string) => {\n params.append(key, v)\n })\n } else {\n params.append(key, <string>value)\n }\n break\n\n // OTHER TYPES - always a string\n default:\n params.append(key, <string>value)\n break\n }\n }\n } else if (Array.isArray(value)) {\n value.forEach((v: string) => {\n params.append(key, v)\n })\n } else {\n params.append(key, value)\n }\n }\n })\n\n const encodedFilters = params.toString()\n return decodeURIComponent(encodedFilters)\n}\n\nexport default {\n applyDashboardInteractiveQuery,\n applyReportInteractiveQuery,\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["utils_exports", "__export", "applyDashboardInteractiveQuery", "applyReportInteractiveQuery", "utils_default", "__toCommonJS", "import_enum", "import_localsHelper", "import_definitionUtils", "import_DateMapper", "import_utils", "req", "res", "services", "applyType", "reportId", "id", "token", "definitionsPath", "LocalsHelper", "fields", "applyInteractiveQuery", "tableId", "dprUser", "reportStateData", "interactiveQueryData", "preventDefault", "pageSize", "selectedPage", "sortColumn", "sortedAsc", "filters", "key", "acc", "formData", "columns", "mandatoryCols", "ColumnsUtils", "bodyColumns", "columnsData", "filtersString", "createQueryParamsFromFormData", "params", "value", "fieldId", "filter", "definitionUtils", "filterType", "dateValue", "dateMapper", "DateMapper", "v", "encodedFilters"]
|
|
7
7
|
}
|
|
@@ -20,7 +20,7 @@ export const applyReportInteractiveQuery = async (
|
|
|
20
20
|
// Get the definition
|
|
21
21
|
const definition: components['schemas']['SingleVariantReportDefinition'] =
|
|
22
22
|
await services.reportingService.getDefinition(token, reportId, id, definitionsPath)
|
|
23
|
-
const fields = definition.variant.specification
|
|
23
|
+
const fields = definition.variant.specification?.fields || []
|
|
24
24
|
|
|
25
25
|
return applyInteractiveQuery(req, res, services, applyType, fields)
|
|
26
26
|
}
|
|
@@ -57,22 +57,30 @@ const applyInteractiveQuery = async (
|
|
|
57
57
|
const { dprUser } = LocalsHelper.getValues(res)
|
|
58
58
|
|
|
59
59
|
// get the report state
|
|
60
|
-
let reportStateData: StoredReportData
|
|
60
|
+
let reportStateData: StoredReportData | undefined
|
|
61
61
|
if (tableId) {
|
|
62
62
|
// means its an async report
|
|
63
|
-
reportStateData = await services.recentlyViewedService
|
|
63
|
+
reportStateData = await services.recentlyViewedService?.getReportByTableId(tableId, dprUser.id)
|
|
64
64
|
} else {
|
|
65
65
|
// its a sync report and can be indentified by ID as will always only be 1
|
|
66
|
-
reportStateData = await services.recentlyViewedService
|
|
66
|
+
reportStateData = await services.recentlyViewedService?.getReportById(id, dprUser.id)
|
|
67
67
|
}
|
|
68
68
|
|
|
69
69
|
// Get the stored interactive query data
|
|
70
70
|
const interactiveQueryData = reportStateData?.interactiveQuery?.data
|
|
71
71
|
|
|
72
|
-
const
|
|
73
|
-
const
|
|
74
|
-
|
|
75
|
-
|
|
72
|
+
const preventDefault = interactiveQueryData?.['preventDefault']
|
|
73
|
+
const pageSize = interactiveQueryData?.['pageSize']
|
|
74
|
+
const selectedPage = interactiveQueryData?.['selectedPage']
|
|
75
|
+
const sortColumn = interactiveQueryData?.['sortColumn']
|
|
76
|
+
const sortedAsc = interactiveQueryData?.['sortedAsc']
|
|
77
|
+
|
|
78
|
+
let filters = {}
|
|
79
|
+
if (interactiveQueryData) {
|
|
80
|
+
filters = Object.keys(interactiveQueryData)
|
|
81
|
+
.filter((key) => key.includes('filters.'))
|
|
82
|
+
.reduce((acc, key) => ({ ...acc, [key]: interactiveQueryData[key] }), {})
|
|
83
|
+
}
|
|
76
84
|
|
|
77
85
|
// Create merged form data
|
|
78
86
|
let formData: Record<string, string | string[]> = {
|
|
@@ -95,7 +103,7 @@ const applyInteractiveQuery = async (
|
|
|
95
103
|
const columnsData = [...mandatoryCols, ...bodyColumns]
|
|
96
104
|
formData = { ...formData, columns: columnsData, ...filters }
|
|
97
105
|
} else {
|
|
98
|
-
const
|
|
106
|
+
const columns = interactiveQueryData?.['columns'] || []
|
|
99
107
|
formData = { ...formData, columns }
|
|
100
108
|
}
|
|
101
109
|
|
|
@@ -133,13 +141,15 @@ const createQueryParamsFromFormData = ({
|
|
|
133
141
|
case FilterType.dateRange.toLocaleLowerCase():
|
|
134
142
|
case FilterType.granularDateRange.toLocaleLowerCase():
|
|
135
143
|
{
|
|
136
|
-
let dateValue = <string>value
|
|
144
|
+
let dateValue: string = <string>value
|
|
137
145
|
const dateMapper = new DateMapper()
|
|
138
146
|
const currentDateFormat = dateMapper.getDateType(dateValue)
|
|
139
147
|
if (currentDateFormat !== 'none') {
|
|
140
|
-
dateValue = dateMapper.toDateString(dateValue, 'iso')
|
|
148
|
+
dateValue = dateMapper.toDateString(dateValue, 'iso') || ''
|
|
149
|
+
}
|
|
150
|
+
if (dateValue) {
|
|
151
|
+
params.append(key, dateValue)
|
|
141
152
|
}
|
|
142
|
-
params.append(key, dateValue)
|
|
143
153
|
}
|
|
144
154
|
break
|
|
145
155
|
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";var a=Object.defineProperty;var c=Object.getOwnPropertyDescriptor;var d=Object.getOwnPropertyNames;var h=Object.prototype.hasOwnProperty;var m=(i,s)=>{for(var r in s)a(i,r,{get:s[r],enumerable:!0})},D=(i,s,r,n)=>{if(s&&typeof s=="object"||typeof s=="function")for(let t of d(s))!h.call(i,t)&&t!==r&&a(i,t,{get:()=>s[t],enumerable:!(n=c(s,t))||n.enumerable});return i};var b=i=>D(a({},"__esModule",{value:!0}),i);var l={};m(l,{DashboardService:()=>o,default:()=>u});module.exports=b(l);class o{constructor(s){this.dashboardClient=s;this.dashboardClient=s}async getDefinition(s,r,n,t){return this.dashboardClient.getDefinition(s,n,r,t)}async requestAsyncDashboard(s,r,n,t){return this.dashboardClient.requestAsyncDashboard(s,r,n,t)}async cancelAsyncRequest(s,r,n,t,e){return this.dashboardClient.cancelAsyncRequest(s,r,n,t,e)}async getAsyncStatus(s,r,n,t,e,g){return this.dashboardClient.getAsyncStatus(s,r,n,t,e,g)}async getAsyncDashboard(s,r,n,t,e){return this.dashboardClient.getAsyncDashboard(s,n,r,t,e)}}var u=o;0&&(module.exports={DashboardService});
|
|
2
2
|
//# sourceMappingURL=dashboardService.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/dpr/services/dashboardService.ts"],
|
|
4
|
-
"sourcesContent": ["import Dict = NodeJS.Dict\nimport
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": ["dashboardService_exports", "__export", "DashboardService", "dashboardService_default", "__toCommonJS", "
|
|
4
|
+
"sourcesContent": ["import Dict = NodeJS.Dict\nimport DashboardClient from '../data/dashboardClient'\nimport { components } from '../types/api'\nimport { DashboardDataResponse } from '../types/Metrics'\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nclass DashboardService {\n constructor(private readonly dashboardClient: DashboardClient) {\n this.dashboardClient = dashboardClient\n }\n\n async getDefinition(\n token: string,\n dpdId: string,\n id: string,\n dataProductDefinitionsPath?: string,\n ): Promise<components['schemas']['DashboardDefinition']> {\n return this.dashboardClient.getDefinition(token, id, dpdId, dataProductDefinitionsPath)\n }\n\n async requestAsyncDashboard(\n token: string,\n reportId: string,\n dashboardId: string,\n query: Record<string, string | boolean | number>,\n ): Promise<Dict<string>> {\n return this.dashboardClient.requestAsyncDashboard(token, reportId, dashboardId, query)\n }\n\n async cancelAsyncRequest(\n token: string,\n reportId: string,\n dashboardId: string,\n executionId: string,\n dataProductDefinitionsPath?: string,\n ): Promise<Dict<string>> {\n return this.dashboardClient.cancelAsyncRequest(\n token,\n reportId,\n dashboardId,\n executionId,\n dataProductDefinitionsPath,\n )\n }\n\n async getAsyncStatus(\n token: string,\n reportId: string,\n dashboardId: string,\n executionId: string,\n tableId?: string,\n dataProductDefinitionsPath?: string,\n ): Promise<components['schemas']['StatementExecutionStatus']> {\n return this.dashboardClient.getAsyncStatus(\n token,\n reportId,\n dashboardId,\n executionId,\n tableId,\n dataProductDefinitionsPath,\n )\n }\n\n async getAsyncDashboard(\n token: string,\n dashboardId: string,\n reportId: string,\n tableId: string,\n query: Record<string, string | string[]>,\n ): Promise<DashboardDataResponse[][]> {\n return this.dashboardClient.getAsyncDashboard(token, reportId, dashboardId, tableId, query)\n }\n}\n\nexport { DashboardService }\nexport default DashboardService\n"],
|
|
5
|
+
"mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,sBAAAE,EAAA,YAAAC,IAAA,eAAAC,EAAAJ,GAMA,MAAME,CAAiB,CACrB,YAA6BG,EAAkC,CAAlC,qBAAAA,EAC3B,KAAK,gBAAkBA,CACzB,CAEA,MAAM,cACJC,EACAC,EACAC,EACAC,EACuD,CACvD,OAAO,KAAK,gBAAgB,cAAcH,EAAOE,EAAID,EAAOE,CAA0B,CACxF,CAEA,MAAM,sBACJH,EACAI,EACAC,EACAC,EACuB,CACvB,OAAO,KAAK,gBAAgB,sBAAsBN,EAAOI,EAAUC,EAAaC,CAAK,CACvF,CAEA,MAAM,mBACJN,EACAI,EACAC,EACAE,EACAJ,EACuB,CACvB,OAAO,KAAK,gBAAgB,mBAC1BH,EACAI,EACAC,EACAE,EACAJ,CACF,CACF,CAEA,MAAM,eACJH,EACAI,EACAC,EACAE,EACAC,EACAL,EAC4D,CAC5D,OAAO,KAAK,gBAAgB,eAC1BH,EACAI,EACAC,EACAE,EACAC,EACAL,CACF,CACF,CAEA,MAAM,kBACJH,EACAK,EACAD,EACAI,EACAF,EACoC,CACpC,OAAO,KAAK,gBAAgB,kBAAkBN,EAAOI,EAAUC,EAAaG,EAASF,CAAK,CAC5F,CACF,CAGA,IAAOT,EAAQD",
|
|
6
|
+
"names": ["dashboardService_exports", "__export", "DashboardService", "dashboardService_default", "__toCommonJS", "dashboardClient", "token", "dpdId", "id", "dataProductDefinitionsPath", "reportId", "dashboardId", "query", "executionId", "tableId"]
|
|
7
7
|
}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import Dict = NodeJS.Dict
|
|
2
|
-
import logger from '../utils/logger'
|
|
3
2
|
import DashboardClient from '../data/dashboardClient'
|
|
4
3
|
import { components } from '../types/api'
|
|
5
4
|
import { DashboardDataResponse } from '../types/Metrics'
|
|
@@ -8,7 +7,6 @@ import { DashboardDataResponse } from '../types/Metrics'
|
|
|
8
7
|
class DashboardService {
|
|
9
8
|
constructor(private readonly dashboardClient: DashboardClient) {
|
|
10
9
|
this.dashboardClient = dashboardClient
|
|
11
|
-
logger.info('Service created: DashboardService')
|
|
12
10
|
}
|
|
13
11
|
|
|
14
12
|
async getDefinition(
|
|
@@ -52,7 +50,7 @@ class DashboardService {
|
|
|
52
50
|
executionId: string,
|
|
53
51
|
tableId?: string,
|
|
54
52
|
dataProductDefinitionsPath?: string,
|
|
55
|
-
): Promise<
|
|
53
|
+
): Promise<components['schemas']['StatementExecutionStatus']> {
|
|
56
54
|
return this.dashboardClient.getAsyncStatus(
|
|
57
55
|
token,
|
|
58
56
|
reportId,
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var
|
|
1
|
+
"use strict";var h=Object.create;var o=Object.defineProperty;var S=Object.getOwnPropertyDescriptor;var v=Object.getOwnPropertyNames;var y=Object.getPrototypeOf,b=Object.prototype.hasOwnProperty;var w=(i,e)=>{for(var t in e)o(i,t,{get:e[t],enumerable:!0})},p=(i,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of v(e))!b.call(i,s)&&s!==t&&o(i,s,{get:()=>e[s],enumerable:!(n=S(e,s))||n.enumerable});return i};var c=(i,e,t)=>(t=i!=null?h(y(i)):{},p(e||!i||!i.__esModule?o(t,"default",{value:i,enumerable:!0}):t,i)),x=i=>p(o({},"__esModule",{value:!0}),i);var R={};w(R,{DefaultFilterValuesService:()=>d,default:()=>C});module.exports=x(R);var m=c(require("./reportStoreService")),u=require("../components/_filters/filtersTypeEnum"),F=c(require("../utils/logger"));class d extends m.default{constructor(e,t){super(e),this.enabled=!!t.saveDefaults,this.enabled||F.default.info("saveDefaultsFilters: disabled")}async init(e,t){this.enabled&&(e.defaultFilters||(e.defaultFilters=[],await this.saveState(t,e)))}async save(e,t,n,s){if(!this.enabled)return;const r=await this.getState(e);await this.init(r,e);const l={reportId:t,id:n,values:s},a=await this.getIndex(e,t,n);r.defaultFilters!==void 0&&(a===-1?r.defaultFilters.push(l):typeof a=="number"&&(r.defaultFilters[a]=l),await this.saveState(e,r))}async get(e,t,n,s){if(!this.enabled)return[];const l=(await this.getState(e)).defaultFilters?.find(a=>a.id===n&&a.reportId===t);if(l)return l.values.filter(a=>{const f=a.type?a.type:u.FiltersType.REQUEST;return s===f})}async getIndex(e,t,n){return(await this.getState(e)).defaultFilters?.findIndex(r=>r.id===n&&r.reportId===t)}async delete(e,t,n,s){if(!this.enabled)return;const r=await this.getState(e),l=await this.getIndex(e,t,n);if(l!==void 0&&l!==-1&&r.defaultFilters){const a=r.defaultFilters[l];if(a.values.length>0){const f=a.values.filter(g=>(g.type?g.type:u.FiltersType.REQUEST)!==s);r.defaultFilters[l].values=f}else r.defaultFilters.splice(l,1);await this.saveState(e,r)}}}var C=d;0&&(module.exports={DefaultFilterValuesService});
|
|
2
2
|
//# sourceMappingURL=defaultFilterValuesService.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/dpr/services/defaultFilterValuesService.ts"],
|
|
4
|
-
"sourcesContent": ["/* eslint-disable no-param-reassign */\nimport ReportStoreService from './reportStoreService'\nimport ReportDataStore from '../data/reportDataStore'\nimport { ReportStoreConfig } from '../types/ReportStore'\nimport { defaultFilterValue } from '../utils/Personalisation/types'\nimport { FiltersType } from '../components/_filters/filtersTypeEnum'\n\nclass DefaultFilterValuesService extends ReportStoreService {\n constructor(reportDataStore: ReportDataStore) {\n super(reportDataStore)\n }\n\n async init(userConfig: ReportStoreConfig, userId: string) {\n if (!userConfig.defaultFilters) {\n userConfig.defaultFilters = []\n await this.saveState(userId, userConfig)\n }\n }\n\n async save(userId: string, reportId: string, id: string, values: defaultFilterValue[]) {\n const userConfig = await this.getState(userId)\n await this.init(userConfig, userId)\n\n const defaults = {\n reportId,\n id,\n values,\n }\n\n const defaultValuesIndex = await this.getIndex(userId, reportId, id)\n\n
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": ["defaultFilterValuesService_exports", "__export", "DefaultFilterValuesService", "defaultFilterValuesService_default", "__toCommonJS", "import_reportStoreService", "import_filtersTypeEnum", "ReportStoreService", "reportDataStore", "userConfig", "userId", "reportId", "id", "values", "defaults", "defaultValuesIndex", "filtersType", "defaultConfig", "defaultFilter", "v", "type", "index", "updatedValues", "value"]
|
|
4
|
+
"sourcesContent": ["/* eslint-disable no-param-reassign */\nimport ReportStoreService from './reportStoreService'\nimport ReportDataStore from '../data/reportDataStore'\nimport { ReportStoreConfig } from '../types/ReportStore'\nimport { defaultFilterValue } from '../utils/Personalisation/types'\nimport { FiltersType } from '../components/_filters/filtersTypeEnum'\nimport { ServiceFeatureConfig } from '../types/DprConfig'\nimport logger from '../utils/logger'\n\nclass DefaultFilterValuesService extends ReportStoreService {\n enabled: boolean\n\n constructor(reportDataStore: ReportDataStore, serviceFeatureConfig: ServiceFeatureConfig) {\n super(reportDataStore)\n this.enabled = Boolean(serviceFeatureConfig.saveDefaults)\n if (!this.enabled) logger.info(`saveDefaultsFilters: disabled`)\n }\n\n async init(userConfig: ReportStoreConfig, userId: string): Promise<void> {\n if (!this.enabled) return\n\n if (!userConfig.defaultFilters) {\n userConfig.defaultFilters = []\n await this.saveState(userId, userConfig)\n }\n }\n\n async save(userId: string, reportId: string, id: string, values: defaultFilterValue[]): Promise<void> {\n if (!this.enabled) return\n\n const userConfig = await this.getState(userId)\n await this.init(userConfig, userId)\n\n const defaults = {\n reportId,\n id,\n values,\n }\n\n const defaultValuesIndex = await this.getIndex(userId, reportId, id)\n if (userConfig.defaultFilters !== undefined) {\n if (defaultValuesIndex === -1) {\n userConfig.defaultFilters.push(defaults)\n } else if (typeof defaultValuesIndex === 'number') {\n userConfig.defaultFilters[defaultValuesIndex] = defaults\n }\n await this.saveState(userId, userConfig)\n }\n }\n\n async get(\n userId: string,\n reportId: string,\n id: string,\n filtersType: FiltersType,\n ): Promise<defaultFilterValue[] | undefined> {\n if (!this.enabled) return []\n\n const userConfig = await this.getState(userId)\n const defaultConfig = userConfig.defaultFilters?.find((defaultFilter) => {\n return defaultFilter.id === id && defaultFilter.reportId === reportId\n })\n if (!defaultConfig) {\n return undefined\n }\n return defaultConfig.values.filter((v) => {\n const type = !v.type ? FiltersType.REQUEST : v.type\n return filtersType === type\n })\n }\n\n private async getIndex(userId: string, reportId: string, id: string) {\n const userConfig = await this.getState(userId)\n return userConfig.defaultFilters?.findIndex((defaultFilter) => {\n return defaultFilter.id === id && defaultFilter.reportId === reportId\n })\n }\n\n async delete(userId: string, reportId: string, id: string, type: FiltersType): Promise<void> {\n if (!this.enabled) return\n\n const userConfig = await this.getState(userId)\n const index = await this.getIndex(userId, reportId, id)\n if (index !== undefined && index !== -1 && userConfig.defaultFilters) {\n const defaults = userConfig.defaultFilters[index]\n if (defaults.values.length > 0) {\n const updatedValues = defaults.values.filter((value) => {\n const filtersType = !value.type ? FiltersType.REQUEST : value.type\n return filtersType !== type\n })\n userConfig.defaultFilters[index].values = updatedValues\n } else {\n userConfig.defaultFilters.splice(index, 1)\n }\n await this.saveState(userId, userConfig)\n }\n }\n}\n\nexport { DefaultFilterValuesService }\nexport default DefaultFilterValuesService\n"],
|
|
5
|
+
"mappings": "0jBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,gCAAAE,EAAA,YAAAC,IAAA,eAAAC,EAAAJ,GACA,IAAAK,EAA+B,mCAI/BC,EAA4B,kDAE5BC,EAAmB,8BAEnB,MAAML,UAAmC,EAAAM,OAAmB,CAG1D,YAAYC,EAAkCC,EAA4C,CACxF,MAAMD,CAAe,EACrB,KAAK,QAAU,EAAQC,EAAqB,aACvC,KAAK,SAAS,EAAAC,QAAO,KAAK,+BAA+B,CAChE,CAEA,MAAM,KAAKC,EAA+BC,EAA+B,CAClE,KAAK,UAELD,EAAW,iBACdA,EAAW,eAAiB,CAAC,EAC7B,MAAM,KAAK,UAAUC,EAAQD,CAAU,GAE3C,CAEA,MAAM,KAAKC,EAAgBC,EAAkBC,EAAYC,EAA6C,CACpG,GAAI,CAAC,KAAK,QAAS,OAEnB,MAAMJ,EAAa,MAAM,KAAK,SAASC,CAAM,EAC7C,MAAM,KAAK,KAAKD,EAAYC,CAAM,EAElC,MAAMI,EAAW,CACf,SAAAH,EACA,GAAAC,EACA,OAAAC,CACF,EAEME,EAAqB,MAAM,KAAK,SAASL,EAAQC,EAAUC,CAAE,EAC/DH,EAAW,iBAAmB,SAC5BM,IAAuB,GACzBN,EAAW,eAAe,KAAKK,CAAQ,EAC9B,OAAOC,GAAuB,WACvCN,EAAW,eAAeM,CAAkB,EAAID,GAElD,MAAM,KAAK,UAAUJ,EAAQD,CAAU,EAE3C,CAEA,MAAM,IACJC,EACAC,EACAC,EACAI,EAC2C,CAC3C,GAAI,CAAC,KAAK,QAAS,MAAO,CAAC,EAG3B,MAAMC,GADa,MAAM,KAAK,SAASP,CAAM,GACZ,gBAAgB,KAAMQ,GAC9CA,EAAc,KAAON,GAAMM,EAAc,WAAaP,CAC9D,EACD,GAAKM,EAGL,OAAOA,EAAc,OAAO,OAAQE,GAAM,CACxC,MAAMC,EAAQD,EAAE,KAA6BA,EAAE,KAAxB,cAAY,QACnC,OAAOH,IAAgBI,CACzB,CAAC,CACH,CAEA,MAAc,SAASV,EAAgBC,EAAkBC,EAAY,CAEnE,OADmB,MAAM,KAAK,SAASF,CAAM,GAC3B,gBAAgB,UAAWQ,GACpCA,EAAc,KAAON,GAAMM,EAAc,WAAaP,CAC9D,CACH,CAEA,MAAM,OAAOD,EAAgBC,EAAkBC,EAAYQ,EAAkC,CAC3F,GAAI,CAAC,KAAK,QAAS,OAEnB,MAAMX,EAAa,MAAM,KAAK,SAASC,CAAM,EACvCW,EAAQ,MAAM,KAAK,SAASX,EAAQC,EAAUC,CAAE,EACtD,GAAIS,IAAU,QAAaA,IAAU,IAAMZ,EAAW,eAAgB,CACpE,MAAMK,EAAWL,EAAW,eAAeY,CAAK,EAChD,GAAIP,EAAS,OAAO,OAAS,EAAG,CAC9B,MAAMQ,EAAgBR,EAAS,OAAO,OAAQS,IACvBA,EAAM,KAA6BA,EAAM,KAA5B,cAAY,WACvBH,CACxB,EACDX,EAAW,eAAeY,CAAK,EAAE,OAASC,CAC5C,MACEb,EAAW,eAAe,OAAOY,EAAO,CAAC,EAE3C,MAAM,KAAK,UAAUX,EAAQD,CAAU,CACzC,CACF,CACF,CAGA,IAAOT,EAAQD",
|
|
6
|
+
"names": ["defaultFilterValuesService_exports", "__export", "DefaultFilterValuesService", "defaultFilterValuesService_default", "__toCommonJS", "import_reportStoreService", "import_filtersTypeEnum", "import_logger", "ReportStoreService", "reportDataStore", "serviceFeatureConfig", "logger", "userConfig", "userId", "reportId", "id", "values", "defaults", "defaultValuesIndex", "filtersType", "defaultConfig", "defaultFilter", "v", "type", "index", "updatedValues", "value"]
|
|
7
7
|
}
|