@kalisio/kdk 2.5.3 → 2.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.github/workflows/main.yaml +35 -6
- package/client.globe.js +8 -0
- package/client.js +8 -0
- package/client.map.js +8 -0
- package/core/api/hooks/hooks.push.js +3 -2
- package/core/api/hooks/hooks.tags.js +56 -0
- package/core/api/models/tags.model.mongodb.js +8 -0
- package/core/api/services/index.js +33 -2
- package/core/api/services/tags/tags.hooks.js +47 -0
- package/core/client/api.js +5 -5
- package/core/client/components/KActivity.vue +3 -2
- package/core/client/components/KChip.vue +2 -2
- package/core/client/components/KEditor.vue +3 -1
- package/core/client/components/KFollower.vue +4 -4
- package/core/client/components/KStore.vue +1 -1
- package/core/client/components/KTab.vue +20 -7
- package/core/client/components/account/KProfile.vue +9 -25
- package/core/client/components/action/KAction.vue +10 -10
- package/core/client/components/action/KToggleFullscreenAction.vue +2 -11
- package/core/client/components/app/KHome.vue +3 -2
- package/core/client/components/collection/KFilter.vue +5 -4
- package/core/client/components/collection/KGrid.vue +5 -1
- package/core/client/components/collection/KItemsFilter.vue +47 -0
- package/core/client/components/collection/KItemsSorter.vue +42 -0
- package/core/client/components/collection/KScrollDown.vue +2 -2
- package/core/client/components/collection/KSearchFilterControl.vue +3 -2
- package/core/client/components/collection/KSorter.vue +33 -37
- package/core/client/components/collection/KTagsFilterControl.vue +14 -40
- package/core/client/components/collection/KTagsFilterView.vue +10 -45
- package/core/client/components/collection/KTimeFilterControl.vue +6 -7
- package/core/client/components/collection/KTimeFilterView.vue +13 -22
- package/core/client/components/collection/KTimeLine.vue +18 -9
- package/core/client/components/form/KColorField.vue +13 -6
- package/core/client/components/form/KColorScaleField.vue +7 -12
- package/core/client/components/form/KFileField.vue +118 -89
- package/core/client/components/form/KForm.vue +30 -18
- package/core/client/components/form/KIconField.vue +4 -1
- package/core/client/components/form/KNumberField.vue +9 -2
- package/core/client/components/form/KSelectField.vue +1 -4
- package/core/client/components/form/KTagField.vue +229 -0
- package/core/client/components/form/KTextField.vue +4 -0
- package/core/client/components/form/KTextareaField.vue +3 -1
- package/core/client/components/input/KShapePicker.vue +3 -3
- package/core/client/components/layout/KFab.vue +32 -20
- package/core/client/components/layout/KPage.vue +11 -6
- package/core/client/components/layout/KWindow.vue +5 -0
- package/core/client/components/media/index.js +2 -6
- package/core/client/components/menu/KMenu.vue +12 -10
- package/core/client/components/menu/KSubMenu.vue +12 -12
- package/core/client/components/messages/KMessageCard.vue +13 -12
- package/core/client/components/messages/KMessageComposer.vue +13 -9
- package/core/client/components/messages/KMessagesTimeLine.vue +16 -8
- package/core/client/components/tags/KTagFilter.vue +99 -0
- package/core/client/components/tags/KTagItem.vue +65 -0
- package/core/client/components/tags/KTagManager.vue +198 -0
- package/core/client/components/tags/KTagSelection.vue +82 -0
- package/core/client/components/time/KDate.vue +3 -17
- package/core/client/components/time/KDateTime.vue +1 -1
- package/core/client/components/time/KTime.vue +0 -4
- package/core/client/composables/collection-filter.js +41 -2
- package/core/client/composables/collection.js +3 -3
- package/core/client/composables/index.js +1 -0
- package/core/client/composables/pwa.js +13 -0
- package/core/client/composables/session.js +7 -8
- package/core/client/composables/user.js +36 -0
- package/core/client/directives/index.js +1 -0
- package/core/client/directives/v-drop-file.js +174 -0
- package/core/client/document.js +2 -1
- package/core/client/exporter.js +17 -3
- package/core/client/i18n/core_en.json +34 -7
- package/core/client/i18n/core_fr.json +36 -9
- package/core/client/i18n.js +26 -11
- package/core/client/layout.js +5 -5
- package/core/client/mixins/mixin.base-activity.js +8 -5
- package/core/client/mixins/mixin.base-editor.js +2 -1
- package/core/client/mixins/mixin.base-field.js +3 -2
- package/core/client/mixins/mixin.base-item.js +12 -10
- package/core/client/mixins/mixin.service.js +3 -1
- package/core/client/platform.js +0 -3
- package/core/client/readers/reader.json.js +2 -2
- package/core/client/utils/index.js +2 -0
- package/core/client/utils/utils.collection.js +6 -6
- package/core/client/utils/utils.colors.js +46 -19
- package/core/client/utils/utils.files.js +19 -0
- package/core/client/utils/utils.locale.js +13 -17
- package/core/client/utils/utils.services.js +27 -0
- package/core/client/utils/utils.shapes.js +2 -2
- package/core/client/utils/utils.tags.js +17 -0
- package/core/client/utils/utils.tours.js +31 -0
- package/core/common/permissions.js +3 -0
- package/core/common/schemas/tags.update.json +35 -0
- package/core/common/schemas/users.update-profile.json +1 -1
- package/core/common/utils.js +5 -5
- package/extras/configs/panes.top.js +11 -0
- package/extras/configs/stickies.js +1 -1
- package/extras/configs/widgets.left.js +13 -1
- package/extras/libs/jsts.min.js +8 -0
- package/{test/client/core/account.js → extras/tests/core/account.mjs} +4 -4
- package/extras/tests/core/api.mjs +114 -0
- package/{test/client/core/collection.js → extras/tests/core/collection.mjs} +8 -8
- package/{test/client/core/dialogs.js → extras/tests/core/dialogs.mjs} +1 -1
- package/extras/tests/core/index.mjs +9 -0
- package/{test/client/core/layout.js → extras/tests/core/layout.mjs} +7 -3
- package/{test/client/core/runner.js → extras/tests/core/runner.mjs} +3 -3
- package/{test/client/core/screens.js → extras/tests/core/screens.mjs} +1 -1
- package/{test/client/core/utils.js → extras/tests/core/utils.mjs} +79 -26
- package/extras/tests/index.mjs +4 -0
- package/{test/client/map/api.js → extras/tests/map/api.mjs} +1 -1
- package/{test/client/map/catalog.js → extras/tests/map/catalog.mjs} +18 -18
- package/{test/client/map/controls.js → extras/tests/map/controls.mjs} +3 -3
- package/extras/tests/map/index.mjs +5 -0
- package/{test/client/map/time.js → extras/tests/map/time.mjs} +3 -3
- package/{test/client/map/utils.js → extras/tests/map/utils.mjs} +6 -5
- package/extras/tours/fab.js +36 -0
- package/extras/tours/layout.js +49 -0
- package/extras/tours/pane.left.js +78 -0
- package/extras/tours/pane.right.js +145 -0
- package/extras/tours/pane.top.js +239 -0
- package/map/api/config/layers.cjs +28 -13
- package/map/api/hooks/hooks.query.js +12 -7
- package/map/api/models/catalog.model.mongodb.js +17 -6
- package/map/api/services/catalog/catalog.hooks.js +1 -1
- package/map/api/services/index.js +18 -1
- package/map/client/cesium/utils/utils.cesium.js +25 -65
- package/map/client/cesium/utils/utils.features.js +1 -0
- package/map/client/cesium/utils/utils.geojson.js +1 -0
- package/map/client/cesium/utils/utils.style.js +7 -6
- package/map/client/components/KFeatureEditor.vue +3 -3
- package/map/client/components/KFeaturesChart.vue +4 -4
- package/map/client/components/KFeaturesFilterEditor.vue +19 -13
- package/map/client/components/KFeaturesFilterManager.vue +7 -4
- package/map/client/components/KFeaturesTable.vue +2 -2
- package/map/client/components/KLayerEditor.vue +6 -6
- package/map/client/components/KMeasureTool.vue +2 -1
- package/map/client/components/catalog/KBaseLayersSelector.vue +1 -1
- package/map/client/components/catalog/KCategoryItem.vue +15 -1
- package/map/client/components/catalog/KConnectLayer.vue +2 -2
- package/map/client/components/catalog/KCreateView.vue +3 -2
- package/map/client/components/catalog/KFilteredLayerItem.vue +26 -6
- package/map/client/components/catalog/KImportLayer.vue +6 -3
- package/map/client/components/catalog/KLayerCategories.vue +6 -6
- package/map/client/components/catalog/KLayerItem.vue +12 -2
- package/map/client/components/catalog/KLayersList.vue +180 -0
- package/map/client/components/catalog/KLayersPanel.vue +146 -36
- package/map/client/components/catalog/KLayersSelector.vue +96 -48
- package/map/client/components/catalog/KProjectEditor.vue +0 -9
- package/map/client/components/catalog/KProjectSelector.vue +3 -2
- package/map/client/components/catalog/KProjectsPanel.vue +23 -8
- package/map/client/components/catalog/KViewsPanel.vue +18 -8
- package/map/client/components/catalog/KWeatherLayersSelector.vue +3 -3
- package/map/client/components/form/KDirectionField.vue +3 -6
- package/map/client/components/form/KLayerCategoryField.vue +2 -2
- package/map/client/components/form/KOwsServiceField.vue +25 -24
- package/map/client/components/form/KSelectLayersField.vue +4 -4
- package/map/client/components/form/KSelectViewsField.vue +4 -4
- package/map/client/components/legend/KLayerLegend.vue +11 -2
- package/map/client/components/legend/KLegend.vue +44 -51
- package/map/client/components/location/KLocationCardSection.vue +6 -7
- package/map/client/components/location/KLocationMap.vue +23 -13
- package/map/client/components/stickies/KPosition.vue +5 -0
- package/map/client/components/styles/KLayerStyleAction.vue +59 -12
- package/map/client/components/styles/KStyleEditor.vue +71 -8
- package/map/client/components/styles/KStyleEditorSection.vue +82 -33
- package/map/client/components/styles/KStyleManager.vue +119 -59
- package/map/client/components/styles/KStylePreview.vue +9 -25
- package/map/client/components/styles/KStylePreviewItem.vue +22 -1
- package/map/client/components/tools/KSearchTool.vue +1 -1
- package/map/client/components/widget/KElevationProfile.vue +20 -17
- package/map/client/components/widget/KInformationBox.vue +5 -5
- package/map/client/components/widget/KMapillaryViewer.vue +2 -1
- package/map/client/components/widget/KTimeSeries.vue +11 -9
- package/map/client/globe.js +2 -0
- package/map/client/i18n/map_en.json +29 -7
- package/map/client/i18n/map_fr.json +29 -7
- package/map/client/leaflet/GradientPath.js +61 -24
- package/map/client/leaflet/ShapeMarker.js +12 -5
- package/map/client/leaflet/TiledMeshLayer.js +3 -3
- package/map/client/leaflet/utils/utils.geojson.js +66 -8
- package/map/client/leaflet/utils/utils.style.js +14 -15
- package/map/client/mixins/globe/mixin.base-globe.js +181 -34
- package/map/client/mixins/globe/mixin.file-layers.js +3 -0
- package/map/client/mixins/globe/mixin.geojson-layers.js +179 -31
- package/map/client/mixins/globe/mixin.opendap-layers.js +2 -1
- package/map/client/mixins/globe/mixin.style.js +23 -1
- package/map/client/mixins/globe/mixin.tooltip.js +14 -2
- package/map/client/mixins/map/mixin.base-map.js +146 -58
- package/map/client/mixins/map/mixin.edit-layers.js +18 -15
- package/map/client/mixins/map/mixin.geojson-layers.js +181 -106
- package/map/client/mixins/map/mixin.heatmap-layers.js +3 -2
- package/map/client/mixins/map/mixin.map-activity.js +6 -1
- package/map/client/mixins/map/mixin.mapillary-layers.js +2 -1
- package/map/client/mixins/map/mixin.pmtiles-layers.js +3 -3
- package/map/client/mixins/map/mixin.tiled-mesh-layers.js +3 -2
- package/map/client/mixins/map/mixin.tiled-wind-layers.js +3 -2
- package/map/client/mixins/mixin.activity.js +197 -51
- package/map/client/mixins/mixin.context.js +11 -11
- package/map/client/mixins/mixin.feature-service.js +11 -9
- package/map/client/mixins/mixin.weacast.js +5 -3
- package/map/client/readers/reader.geojson.js +3 -1
- package/map/client/utils/utils.capture.js +3 -3
- package/map/client/utils/utils.catalog.js +9 -5
- package/map/client/utils/utils.features.js +120 -54
- package/map/client/utils/utils.js +25 -10
- package/map/client/utils/utils.layers.js +148 -24
- package/map/client/utils/utils.location.js +26 -9
- package/map/client/utils/utils.schema.js +2 -1
- package/map/client/utils/utils.style.js +53 -9
- package/map/common/geotiff-grid-source.js +1 -3
- package/map/common/opendap-utils.js +0 -1
- package/map/common/tms-utils.js +0 -1
- package/map/common/wcs-utils.js +0 -1
- package/map/common/wfs-utils.js +0 -1
- package/map/common/wms-utils.js +7 -1
- package/map/common/wmts-utils.js +0 -1
- package/package.json +12 -12
- package/scripts/init_runner.sh +3 -3
- package/scripts/kash/CHANGELOG.md +27 -0
- package/scripts/kash/kash.sh +556 -237
- package/scripts/kash/scripts/run_tests.sh +44 -5
- package/scripts/setup_workspace.sh +23 -13
- package/test/api/core/config/default.cjs +2 -1
- package/test/api/core/tags.test.js +62 -0
- package/test/api/map/config/default.cjs +2 -1
- package/test/api/map/config/layers.json +9 -0
- package/test/api/map/data/openradiation.json +13811 -0
- package/test/api/map/grid-sources.test.js +1 -3
- package/test/api/map/index.test.js +60 -1
- package/test/api/map/style.test.js +30 -1
- package/test.api.js +1 -1
- package/vite/App.vue +18 -0
- package/vite/AppWithGlobe.vue +84 -0
- package/vite/GlobeActivity.vue +58 -0
- package/vite/MapActivity.vue +63 -0
- package/vite/MapActivityWithGlobe.vue +63 -0
- package/vite/README.md +169 -0
- package/vite/config.js +221 -0
- package/vite/index_with_globe.html +50 -0
- package/vite/index_with_map.html +50 -0
- package/vite/package.json +173 -0
- package/vite/quasar.variables.scss +17 -0
- package/vite/vite.config.js +166 -0
- package/vite/yarn.lock +11641 -0
- package/core/client/components/media/KImageViewer.vue +0 -68
- package/core/client/components/media/KMarkdownViewer.vue +0 -55
- package/core/client/components/media/KMediaBrowser.vue +0 -301
- package/coverage/base.css +0 -224
- package/coverage/block-navigation.js +0 -87
- package/coverage/core/api/application.js.html +0 -1870
- package/coverage/core/api/authentication.js.html +0 -874
- package/coverage/core/api/db.js.html +0 -793
- package/coverage/core/api/hooks/hooks.authentication.js.html +0 -139
- package/coverage/core/api/hooks/hooks.authorisations.js.html +0 -958
- package/coverage/core/api/hooks/hooks.groups.js.html +0 -229
- package/coverage/core/api/hooks/hooks.logger.js.html +0 -163
- package/coverage/core/api/hooks/hooks.model.js.html +0 -967
- package/coverage/core/api/hooks/hooks.organisations.js.html +0 -541
- package/coverage/core/api/hooks/hooks.push.js.html +0 -265
- package/coverage/core/api/hooks/hooks.query.js.html +0 -862
- package/coverage/core/api/hooks/hooks.schemas.js.html +0 -298
- package/coverage/core/api/hooks/hooks.service.js.html +0 -319
- package/coverage/core/api/hooks/hooks.storage.js.html +0 -193
- package/coverage/core/api/hooks/hooks.users.js.html +0 -595
- package/coverage/core/api/hooks/index.html +0 -266
- package/coverage/core/api/hooks/index.js.html +0 -115
- package/coverage/core/api/index.html +0 -176
- package/coverage/core/api/index.js.html +0 -148
- package/coverage/core/api/marshall.js.html +0 -448
- package/coverage/core/api/models/groups.model.mongodb.js.html +0 -109
- package/coverage/core/api/models/index.html +0 -131
- package/coverage/core/api/models/messages.model.mongodb.js.html +0 -121
- package/coverage/core/api/models/organisations.model.mongodb.js.html +0 -94
- package/coverage/core/api/models/tags.model.mongodb.js.html +0 -115
- package/coverage/core/api/models/users.model.mongodb.js.html +0 -115
- package/coverage/core/api/services/account/account.hooks.js.html +0 -208
- package/coverage/core/api/services/account/account.service.js.html +0 -436
- package/coverage/core/api/services/account/index.html +0 -131
- package/coverage/core/api/services/authorisations/authorisations.hooks.js.html +0 -184
- package/coverage/core/api/services/authorisations/authorisations.service.js.html +0 -520
- package/coverage/core/api/services/authorisations/index.html +0 -131
- package/coverage/core/api/services/databases/databases.hooks.js.html +0 -193
- package/coverage/core/api/services/databases/databases.service.js.html +0 -100
- package/coverage/core/api/services/databases/index.html +0 -131
- package/coverage/core/api/services/groups/groups.hooks.js.html +0 -178
- package/coverage/core/api/services/groups/index.html +0 -116
- package/coverage/core/api/services/import-export/import-export.hooks.js.html +0 -184
- package/coverage/core/api/services/import-export/import-export.service.js.html +0 -118
- package/coverage/core/api/services/import-export/index.html +0 -131
- package/coverage/core/api/services/index.html +0 -116
- package/coverage/core/api/services/index.js.html +0 -532
- package/coverage/core/api/services/mailer/index.html +0 -131
- package/coverage/core/api/services/mailer/mailer.hooks.js.html +0 -190
- package/coverage/core/api/services/mailer/mailer.service.js.html +0 -118
- package/coverage/core/api/services/messages/index.html +0 -116
- package/coverage/core/api/services/messages/messages.hooks.js.html +0 -202
- package/coverage/core/api/services/organisations/index.html +0 -131
- package/coverage/core/api/services/organisations/organisations.hooks.js.html +0 -178
- package/coverage/core/api/services/organisations/organisations.service.js.html +0 -343
- package/coverage/core/api/services/push/index.html +0 -131
- package/coverage/core/api/services/push/push.hooks.js.html +0 -190
- package/coverage/core/api/services/push/push.service.js.html +0 -121
- package/coverage/core/api/services/storage/index.html +0 -131
- package/coverage/core/api/services/storage/storage.hooks.js.html +0 -190
- package/coverage/core/api/services/storage/storage.service.js.html +0 -172
- package/coverage/core/api/services/tags/index.html +0 -116
- package/coverage/core/api/services/tags/tags.hooks.js.html +0 -178
- package/coverage/core/api/services/users/index.html +0 -131
- package/coverage/core/api/services/users/users.hooks.js.html +0 -310
- package/coverage/core/api/services/users/users.service.js.html +0 -100
- package/coverage/core/api/utils.js.html +0 -118
- package/coverage/core/common/errors.js.html +0 -88
- package/coverage/core/common/index.html +0 -191
- package/coverage/core/common/index.js.html +0 -115
- package/coverage/core/common/permissions.js.html +0 -733
- package/coverage/core/common/schema.js.html +0 -190
- package/coverage/core/common/utils.js.html +0 -226
- package/coverage/core/common/utils.offline.js.html +0 -199
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +0 -476
- package/coverage/lcov-report/base.css +0 -224
- package/coverage/lcov-report/block-navigation.js +0 -87
- package/coverage/lcov-report/core/api/application.js.html +0 -1870
- package/coverage/lcov-report/core/api/authentication.js.html +0 -874
- package/coverage/lcov-report/core/api/db.js.html +0 -793
- package/coverage/lcov-report/core/api/hooks/hooks.authentication.js.html +0 -139
- package/coverage/lcov-report/core/api/hooks/hooks.authorisations.js.html +0 -958
- package/coverage/lcov-report/core/api/hooks/hooks.groups.js.html +0 -229
- package/coverage/lcov-report/core/api/hooks/hooks.logger.js.html +0 -163
- package/coverage/lcov-report/core/api/hooks/hooks.model.js.html +0 -967
- package/coverage/lcov-report/core/api/hooks/hooks.organisations.js.html +0 -541
- package/coverage/lcov-report/core/api/hooks/hooks.push.js.html +0 -265
- package/coverage/lcov-report/core/api/hooks/hooks.query.js.html +0 -862
- package/coverage/lcov-report/core/api/hooks/hooks.schemas.js.html +0 -298
- package/coverage/lcov-report/core/api/hooks/hooks.service.js.html +0 -319
- package/coverage/lcov-report/core/api/hooks/hooks.storage.js.html +0 -193
- package/coverage/lcov-report/core/api/hooks/hooks.users.js.html +0 -595
- package/coverage/lcov-report/core/api/hooks/index.html +0 -266
- package/coverage/lcov-report/core/api/hooks/index.js.html +0 -115
- package/coverage/lcov-report/core/api/index.html +0 -176
- package/coverage/lcov-report/core/api/index.js.html +0 -148
- package/coverage/lcov-report/core/api/marshall.js.html +0 -448
- package/coverage/lcov-report/core/api/models/groups.model.mongodb.js.html +0 -109
- package/coverage/lcov-report/core/api/models/index.html +0 -131
- package/coverage/lcov-report/core/api/models/messages.model.mongodb.js.html +0 -121
- package/coverage/lcov-report/core/api/models/organisations.model.mongodb.js.html +0 -94
- package/coverage/lcov-report/core/api/models/tags.model.mongodb.js.html +0 -115
- package/coverage/lcov-report/core/api/models/users.model.mongodb.js.html +0 -115
- package/coverage/lcov-report/core/api/services/account/account.hooks.js.html +0 -208
- package/coverage/lcov-report/core/api/services/account/account.service.js.html +0 -436
- package/coverage/lcov-report/core/api/services/account/index.html +0 -131
- package/coverage/lcov-report/core/api/services/authorisations/authorisations.hooks.js.html +0 -184
- package/coverage/lcov-report/core/api/services/authorisations/authorisations.service.js.html +0 -520
- package/coverage/lcov-report/core/api/services/authorisations/index.html +0 -131
- package/coverage/lcov-report/core/api/services/databases/databases.hooks.js.html +0 -193
- package/coverage/lcov-report/core/api/services/databases/databases.service.js.html +0 -100
- package/coverage/lcov-report/core/api/services/databases/index.html +0 -131
- package/coverage/lcov-report/core/api/services/groups/groups.hooks.js.html +0 -178
- package/coverage/lcov-report/core/api/services/groups/index.html +0 -116
- package/coverage/lcov-report/core/api/services/import-export/import-export.hooks.js.html +0 -184
- package/coverage/lcov-report/core/api/services/import-export/import-export.service.js.html +0 -118
- package/coverage/lcov-report/core/api/services/import-export/index.html +0 -131
- package/coverage/lcov-report/core/api/services/index.html +0 -116
- package/coverage/lcov-report/core/api/services/index.js.html +0 -532
- package/coverage/lcov-report/core/api/services/mailer/index.html +0 -131
- package/coverage/lcov-report/core/api/services/mailer/mailer.hooks.js.html +0 -190
- package/coverage/lcov-report/core/api/services/mailer/mailer.service.js.html +0 -118
- package/coverage/lcov-report/core/api/services/messages/index.html +0 -116
- package/coverage/lcov-report/core/api/services/messages/messages.hooks.js.html +0 -202
- package/coverage/lcov-report/core/api/services/organisations/index.html +0 -131
- package/coverage/lcov-report/core/api/services/organisations/organisations.hooks.js.html +0 -178
- package/coverage/lcov-report/core/api/services/organisations/organisations.service.js.html +0 -343
- package/coverage/lcov-report/core/api/services/push/index.html +0 -131
- package/coverage/lcov-report/core/api/services/push/push.hooks.js.html +0 -190
- package/coverage/lcov-report/core/api/services/push/push.service.js.html +0 -121
- package/coverage/lcov-report/core/api/services/storage/index.html +0 -131
- package/coverage/lcov-report/core/api/services/storage/storage.hooks.js.html +0 -190
- package/coverage/lcov-report/core/api/services/storage/storage.service.js.html +0 -172
- package/coverage/lcov-report/core/api/services/tags/index.html +0 -116
- package/coverage/lcov-report/core/api/services/tags/tags.hooks.js.html +0 -178
- package/coverage/lcov-report/core/api/services/users/index.html +0 -131
- package/coverage/lcov-report/core/api/services/users/users.hooks.js.html +0 -310
- package/coverage/lcov-report/core/api/services/users/users.service.js.html +0 -100
- package/coverage/lcov-report/core/api/utils.js.html +0 -118
- package/coverage/lcov-report/core/common/errors.js.html +0 -88
- package/coverage/lcov-report/core/common/index.html +0 -191
- package/coverage/lcov-report/core/common/index.js.html +0 -115
- package/coverage/lcov-report/core/common/permissions.js.html +0 -733
- package/coverage/lcov-report/core/common/schema.js.html +0 -190
- package/coverage/lcov-report/core/common/utils.js.html +0 -226
- package/coverage/lcov-report/core/common/utils.offline.js.html +0 -199
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +0 -476
- package/coverage/lcov-report/map/api/hooks/hooks.catalog.js.html +0 -553
- package/coverage/lcov-report/map/api/hooks/hooks.features.js.html +0 -397
- package/coverage/lcov-report/map/api/hooks/hooks.query.js.html +0 -1294
- package/coverage/lcov-report/map/api/hooks/index.html +0 -161
- package/coverage/lcov-report/map/api/hooks/index.js.html +0 -94
- package/coverage/lcov-report/map/api/index.html +0 -131
- package/coverage/lcov-report/map/api/index.js.html +0 -139
- package/coverage/lcov-report/map/api/marshall.js.html +0 -178
- package/coverage/lcov-report/map/api/models/alerts.model.mongodb.js.html +0 -106
- package/coverage/lcov-report/map/api/models/catalog.model.mongodb.js.html +0 -169
- package/coverage/lcov-report/map/api/models/features.model.mongodb.js.html +0 -196
- package/coverage/lcov-report/map/api/models/index.html +0 -176
- package/coverage/lcov-report/map/api/models/projects.model.mongodb.js.html +0 -109
- package/coverage/lcov-report/map/api/models/styles.model.mongodb.js.html +0 -112
- package/coverage/lcov-report/map/api/services/alerts/alerts.hooks.js.html +0 -274
- package/coverage/lcov-report/map/api/services/alerts/alerts.service.js.html +0 -610
- package/coverage/lcov-report/map/api/services/alerts/index.html +0 -131
- package/coverage/lcov-report/map/api/services/catalog/catalog.hooks.js.html +0 -328
- package/coverage/lcov-report/map/api/services/catalog/index.html +0 -116
- package/coverage/lcov-report/map/api/services/daptiles/daptiles.service.js.html +0 -1510
- package/coverage/lcov-report/map/api/services/daptiles/index.html +0 -116
- package/coverage/lcov-report/map/api/services/features/features.hooks.js.html +0 -310
- package/coverage/lcov-report/map/api/services/features/features.service.js.html +0 -544
- package/coverage/lcov-report/map/api/services/features/index.html +0 -131
- package/coverage/lcov-report/map/api/services/index.html +0 -116
- package/coverage/lcov-report/map/api/services/index.js.html +0 -1054
- package/coverage/lcov-report/map/api/services/projects/index.html +0 -116
- package/coverage/lcov-report/map/api/services/projects/projects.hooks.js.html +0 -439
- package/coverage/lcov-report/map/api/services/styles/index.html +0 -116
- package/coverage/lcov-report/map/api/services/styles/styles.hooks.js.html +0 -196
- package/coverage/lcov-report/map/common/dynamic-grid-source.js.html +0 -466
- package/coverage/lcov-report/map/common/errors.js.html +0 -94
- package/coverage/lcov-report/map/common/geotiff-grid-source.js.html +0 -544
- package/coverage/lcov-report/map/common/grid.js.html +0 -1612
- package/coverage/lcov-report/map/common/index.html +0 -371
- package/coverage/lcov-report/map/common/index.js.html +0 -172
- package/coverage/lcov-report/map/common/meteo-model-grid-source.js.html +0 -556
- package/coverage/lcov-report/map/common/moment-utils.js.html +0 -157
- package/coverage/lcov-report/map/common/opendap-grid-source.js.html +0 -868
- package/coverage/lcov-report/map/common/opendap-utils.js.html +0 -826
- package/coverage/lcov-report/map/common/permissions.js.html +0 -130
- package/coverage/lcov-report/map/common/time-based-grid-source.js.html +0 -418
- package/coverage/lcov-report/map/common/tms-utils.js.html +0 -274
- package/coverage/lcov-report/map/common/wcs-grid-source.js.html +0 -364
- package/coverage/lcov-report/map/common/wcs-utils.js.html +0 -586
- package/coverage/lcov-report/map/common/weacast-grid-source.js.html +0 -1033
- package/coverage/lcov-report/map/common/wfs-utils.js.html +0 -574
- package/coverage/lcov-report/map/common/wms-utils.js.html +0 -451
- package/coverage/lcov-report/map/common/wmts-utils.js.html +0 -547
- package/coverage/lcov-report/prettify.css +0 -1
- package/coverage/lcov-report/prettify.js +0 -2
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +0 -196
- package/coverage/lcov.info +0 -11520
- package/coverage/map/api/hooks/hooks.catalog.js.html +0 -553
- package/coverage/map/api/hooks/hooks.features.js.html +0 -397
- package/coverage/map/api/hooks/hooks.query.js.html +0 -1294
- package/coverage/map/api/hooks/index.html +0 -161
- package/coverage/map/api/hooks/index.js.html +0 -94
- package/coverage/map/api/index.html +0 -131
- package/coverage/map/api/index.js.html +0 -139
- package/coverage/map/api/marshall.js.html +0 -178
- package/coverage/map/api/models/alerts.model.mongodb.js.html +0 -106
- package/coverage/map/api/models/catalog.model.mongodb.js.html +0 -169
- package/coverage/map/api/models/features.model.mongodb.js.html +0 -196
- package/coverage/map/api/models/index.html +0 -176
- package/coverage/map/api/models/projects.model.mongodb.js.html +0 -109
- package/coverage/map/api/models/styles.model.mongodb.js.html +0 -112
- package/coverage/map/api/services/alerts/alerts.hooks.js.html +0 -274
- package/coverage/map/api/services/alerts/alerts.service.js.html +0 -610
- package/coverage/map/api/services/alerts/index.html +0 -131
- package/coverage/map/api/services/catalog/catalog.hooks.js.html +0 -328
- package/coverage/map/api/services/catalog/index.html +0 -116
- package/coverage/map/api/services/daptiles/daptiles.service.js.html +0 -1510
- package/coverage/map/api/services/daptiles/index.html +0 -116
- package/coverage/map/api/services/features/features.hooks.js.html +0 -310
- package/coverage/map/api/services/features/features.service.js.html +0 -544
- package/coverage/map/api/services/features/index.html +0 -131
- package/coverage/map/api/services/index.html +0 -116
- package/coverage/map/api/services/index.js.html +0 -1054
- package/coverage/map/api/services/projects/index.html +0 -116
- package/coverage/map/api/services/projects/projects.hooks.js.html +0 -439
- package/coverage/map/api/services/styles/index.html +0 -116
- package/coverage/map/api/services/styles/styles.hooks.js.html +0 -196
- package/coverage/map/common/dynamic-grid-source.js.html +0 -466
- package/coverage/map/common/errors.js.html +0 -94
- package/coverage/map/common/geotiff-grid-source.js.html +0 -544
- package/coverage/map/common/grid.js.html +0 -1612
- package/coverage/map/common/index.html +0 -371
- package/coverage/map/common/index.js.html +0 -172
- package/coverage/map/common/meteo-model-grid-source.js.html +0 -556
- package/coverage/map/common/moment-utils.js.html +0 -157
- package/coverage/map/common/opendap-grid-source.js.html +0 -868
- package/coverage/map/common/opendap-utils.js.html +0 -826
- package/coverage/map/common/permissions.js.html +0 -130
- package/coverage/map/common/time-based-grid-source.js.html +0 -418
- package/coverage/map/common/tms-utils.js.html +0 -274
- package/coverage/map/common/wcs-grid-source.js.html +0 -364
- package/coverage/map/common/wcs-utils.js.html +0 -586
- package/coverage/map/common/weacast-grid-source.js.html +0 -1033
- package/coverage/map/common/wfs-utils.js.html +0 -574
- package/coverage/map/common/wms-utils.js.html +0 -451
- package/coverage/map/common/wmts-utils.js.html +0 -547
- package/coverage/prettify.css +0 -1
- package/coverage/prettify.js +0 -2
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +0 -196
- package/coverage/tmp/coverage-151198-1753351220086-0.json +0 -1
- package/coverage/tmp/coverage-151210-1753351220070-0.json +0 -1
- package/coverage/tmp/coverage-151221-1753351129816-0.json +0 -1
- package/coverage/tmp/coverage-151233-1753351129803-0.json +0 -1
- package/coverage/tmp/coverage-151240-1753351129770-0.json +0 -1
- package/coverage/tmp/coverage-151307-1753351220058-0.json +0 -1
- package/coverage/tmp/coverage-151319-1753351220044-0.json +0 -1
- package/coverage/tmp/coverage-151326-1753351220010-0.json +0 -1
- package/extras/tours/core/account-profile.js +0 -32
- package/extras/tours/core/account.js +0 -143
- package/extras/tours/core/add-member.js +0 -75
- package/extras/tours/core/add-tag.js +0 -13
- package/extras/tours/core/create-group.js +0 -19
- package/extras/tours/core/create-organisation.js +0 -19
- package/extras/tours/core/create-tag.js +0 -26
- package/extras/tours/core/edit-member-role.js +0 -13
- package/extras/tours/core/groups.js +0 -65
- package/extras/tours/core/join-group.js +0 -13
- package/extras/tours/core/login.js +0 -41
- package/extras/tours/core/members.js +0 -108
- package/extras/tours/core/register.js +0 -61
- package/extras/tours/core/send-reset-password.js +0 -14
- package/extras/tours/core/tags.js +0 -65
- package/extras/tours/map/catalog-panel.js +0 -112
- package/extras/tours/map/fab.js +0 -26
- package/extras/tours/map/navigation-bar.js +0 -187
- package/extras/tours/map/side-nav.js +0 -36
- package/test/api/core/test-log-2025-02-05.log +0 -23
- package/test/api/core/test-log-2025-05-21.log +0 -15
- package/test/api/core/test-log-2025-06-25.log +0 -9
- package/test/api/core/test-log-2025-07-24.log +0 -44
- package/test/api/map/test-log-2025-05-27.log +0 -13
- package/test/api/map/test-log-2025-06-23.log +0 -7
- package/test/api/map/test-log-2025-07-24.log +0 -11
- package/test/client/core/api.js +0 -361
- package/test/client/core/index.js +0 -9
- package/test/client/index.js +0 -4
- package/test/client/map/index.js +0 -5
- package/test.client.js +0 -1
- /package/{test/client/core/time.js → extras/tests/core/time.mjs} +0 -0
- /package/extras/tours/{map/add-layer.js → add-layer.js} +0 -0
- /package/extras/tours/{map/catalog-categories.js → catalog-categories.js} +0 -0
- /package/extras/tours/{map/connect-layer.js → connect-layer.js} +0 -0
- /package/extras/tours/{map/create-layer.js → create-layer.js} +0 -0
- /package/extras/tours/{map/create-view.js → create-view.js} +0 -0
- /package/extras/tours/{map/import-layer.js → import-layer.js} +0 -0
- /package/extras/tours/{map/timeline.js → pane.bottom.js} +0 -0
|
@@ -1,34 +1,70 @@
|
|
|
1
1
|
<template>
|
|
2
|
-
<div>
|
|
3
|
-
<
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
2
|
+
<div v-if="props.layers.length > 0">
|
|
3
|
+
<k-layers-list :layers="filteredLayers" :options="options">
|
|
4
|
+
<template v-slot:header>
|
|
5
|
+
<div class="q-ma-sm">
|
|
6
|
+
<q-select
|
|
7
|
+
for="layer-model"
|
|
8
|
+
id="layer-model"
|
|
9
|
+
:placeholder="$t('KLayersSelector.SELECT_LAYERS')"
|
|
10
|
+
autocomplete="off"
|
|
11
|
+
v-model="model"
|
|
12
|
+
:options="selectOptions"
|
|
13
|
+
filled
|
|
14
|
+
use-input
|
|
15
|
+
use-chips
|
|
16
|
+
map-options
|
|
17
|
+
emit-value
|
|
18
|
+
multiple
|
|
19
|
+
clearable
|
|
20
|
+
@filter="filter"
|
|
21
|
+
@add="toggleLayer"
|
|
22
|
+
@remove="toggleLayer"
|
|
23
|
+
@clear="clear"
|
|
24
|
+
>
|
|
25
|
+
<template v-slot:prepend>
|
|
26
|
+
<q-icon name="las la-map-marker" />
|
|
27
|
+
</template>
|
|
28
|
+
<template v-slot:option="scope">
|
|
29
|
+
<q-item v-bind="scope.itemProps" :id="scope.opt.name">
|
|
30
|
+
<q-item-section avatar>
|
|
31
|
+
<q-icon
|
|
32
|
+
v-if="!scope.opt.iconUrl"
|
|
33
|
+
:name="scope.opt.icon || 'las la-map-marker'"
|
|
34
|
+
/>
|
|
35
|
+
</q-item-section>
|
|
36
|
+
<q-item-section>
|
|
37
|
+
<q-item-label lines="1">
|
|
38
|
+
{{ scope.opt.label }}
|
|
39
|
+
</q-item-label>
|
|
40
|
+
<q-item-label caption lines="2">
|
|
41
|
+
{{ scope.opt.description }}
|
|
42
|
+
</q-item-label>
|
|
43
|
+
</q-item-section>
|
|
44
|
+
</q-item>
|
|
45
|
+
</template>
|
|
46
|
+
</q-select>
|
|
47
|
+
</div>
|
|
13
48
|
</template>
|
|
14
|
-
</
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
49
|
+
</k-layers-list>
|
|
50
|
+
</div>
|
|
51
|
+
<div v-else class="row justify-center q-pa-sm">
|
|
52
|
+
<KStamp
|
|
53
|
+
icon="las la-exclamation-circle"
|
|
54
|
+
icon-size="sm"
|
|
55
|
+
:text="$t('KWeatherLayersSelector.NO_MODEL_AVAILABLE')"
|
|
56
|
+
text-size="0.9rem"
|
|
57
|
+
direction="horizontal"
|
|
58
|
+
/>
|
|
24
59
|
</div>
|
|
25
60
|
</template>
|
|
26
61
|
|
|
27
62
|
<script setup>
|
|
28
63
|
import _ from 'lodash'
|
|
29
|
-
import { computed } from 'vue'
|
|
30
|
-
import {
|
|
31
|
-
import
|
|
64
|
+
import { computed, ref } from 'vue'
|
|
65
|
+
import { KStamp } from '../../../../core/client/components'
|
|
66
|
+
import KLayersList from './KLayersList.vue'
|
|
67
|
+
import { useCurrentActivity } from '../../composables'
|
|
32
68
|
|
|
33
69
|
// Props
|
|
34
70
|
const props = defineProps({
|
|
@@ -42,38 +78,50 @@ const props = defineProps({
|
|
|
42
78
|
}
|
|
43
79
|
})
|
|
44
80
|
|
|
81
|
+
// Data
|
|
82
|
+
const model = ref([])
|
|
83
|
+
const selectOptions = ref(
|
|
84
|
+
props.layers.map((layer) => ({ label: layer.label, value: layer._id }))
|
|
85
|
+
)
|
|
86
|
+
const { CurrentActivity } = useCurrentActivity()
|
|
87
|
+
const { layers } = CurrentActivity.value
|
|
88
|
+
|
|
45
89
|
// Computed
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
})
|
|
90
|
+
const filteredLayers = computed(() =>
|
|
91
|
+
model.value
|
|
92
|
+
? props.layers.filter((layer) => model.value.includes(layer._id))
|
|
93
|
+
: []
|
|
94
|
+
)
|
|
52
95
|
|
|
53
96
|
// Functions
|
|
54
|
-
function toggleLayer (
|
|
97
|
+
function toggleLayer (layerId) {
|
|
98
|
+
const layer = props.layers.find((l) => l._id === layerId.value)
|
|
55
99
|
const toggleAction = _.find(layer.actions, { id: 'toggle' })
|
|
56
100
|
if (toggleAction) toggleAction.handler()
|
|
57
101
|
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
// Due to v-model the visible flag has already been changed on the layer
|
|
62
|
-
// Simply reset others layers before activating the new one to avoid any problem
|
|
63
|
-
const visibleLayers = _.filter(props.layers, { isVisible: true })
|
|
64
|
-
for (let i = 0; i < visibleLayers.length; i++) {
|
|
65
|
-
const visibleLayer = visibleLayers[i]
|
|
66
|
-
if (visibleLayer !== layer) await toggleLayer(visibleLayers[i])
|
|
67
|
-
}
|
|
102
|
+
function clear () {
|
|
103
|
+
for (const layer of props.layers) {
|
|
104
|
+
if (layer?.isVisible) toggleLayer({ value: layer._id })
|
|
68
105
|
}
|
|
69
|
-
|
|
106
|
+
model.value = []
|
|
70
107
|
}
|
|
71
|
-
function
|
|
72
|
-
|
|
73
|
-
|
|
108
|
+
function filter (val, update, abort) {
|
|
109
|
+
update(() => {
|
|
110
|
+
const needle = val.toLowerCase()
|
|
111
|
+
selectOptions.value = props.layers
|
|
112
|
+
.filter((layer) => layer.label.toLowerCase().indexOf(needle) > -1)
|
|
113
|
+
.map((layer) => ({ label: layer.label, value: layer._id }))
|
|
114
|
+
})
|
|
74
115
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
116
|
+
|
|
117
|
+
// set default layers from layer.leaflet.isVisible property
|
|
118
|
+
if (props.layers.length > 0) {
|
|
119
|
+
for (const layer of props.layers) {
|
|
120
|
+
const layerObject = layers[layer.name]
|
|
121
|
+
if (layerObject) {
|
|
122
|
+
const isLayerVisible = _.get(layerObject, 'isVisible')
|
|
123
|
+
if (isLayerVisible && !model.value.includes(layer._id)) model.value.push(layer._id)
|
|
124
|
+
}
|
|
125
|
+
}
|
|
78
126
|
}
|
|
79
127
|
</script>
|
|
@@ -66,15 +66,6 @@ export default {
|
|
|
66
66
|
},
|
|
67
67
|
methods: {
|
|
68
68
|
async apply () {
|
|
69
|
-
// We at least needs a background layer
|
|
70
|
-
// FIXME: how to do this as we only have IDs here
|
|
71
|
-
/*
|
|
72
|
-
const layers = this.form.values().layers
|
|
73
|
-
if (!_.find(layers, { type: 'BaseLayer'})) {
|
|
74
|
-
this.$notify({ type: 'negative', message: this.$t('KProjectEditor.BACKGROUND_LAYER_REQUIRED') })
|
|
75
|
-
return
|
|
76
|
-
}
|
|
77
|
-
*/
|
|
78
69
|
this.processing = true
|
|
79
70
|
if (await baseEditor.methods.apply.call(this)) {
|
|
80
71
|
this.processing = false
|
|
@@ -28,6 +28,7 @@
|
|
|
28
28
|
<script>
|
|
29
29
|
import { KPanel, KAction } from '../../../../core/client/components'
|
|
30
30
|
import { baseItem } from '../../../../core/client/mixins'
|
|
31
|
+
import { api } from '../../../../core/client/api.js'
|
|
31
32
|
|
|
32
33
|
export default {
|
|
33
34
|
name: 'k-project-selector',
|
|
@@ -39,14 +40,14 @@ export default {
|
|
|
39
40
|
computed: {
|
|
40
41
|
projectActions () {
|
|
41
42
|
const projectActions = []
|
|
42
|
-
if (
|
|
43
|
+
if (api.can('update', 'projects', this.item)) {
|
|
43
44
|
const content = [{
|
|
44
45
|
id: 'edit-project',
|
|
45
46
|
icon: 'las la-file-alt',
|
|
46
47
|
label: 'KProjectSelector.EDIT_PROJECT',
|
|
47
48
|
handler: (item) => this.$emit('item-selected', item, 'edit-project')
|
|
48
49
|
}]
|
|
49
|
-
if (
|
|
50
|
+
if (api.can('remove', 'projects', this.item)) {
|
|
50
51
|
content.push({
|
|
51
52
|
id: 'remove-project',
|
|
52
53
|
icon: 'las la-trash',
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
:nb-items-per-page="20"
|
|
7
7
|
:append-items="true"
|
|
8
8
|
:base-query="baseQuery"
|
|
9
|
-
:filter-query="
|
|
9
|
+
:filter-query="filterQuery"
|
|
10
10
|
:dense="true"
|
|
11
11
|
:scrollToTop="false"
|
|
12
12
|
:header="toolbar"
|
|
@@ -17,11 +17,12 @@
|
|
|
17
17
|
</template>
|
|
18
18
|
|
|
19
19
|
<script setup>
|
|
20
|
+
import _ from 'lodash'
|
|
20
21
|
import logger from 'loglevel'
|
|
21
22
|
import { ref, computed } from 'vue'
|
|
22
23
|
import { useRouter, useRoute } from 'vue-router'
|
|
23
24
|
import { useCurrentActivity } from '../../composables'
|
|
24
|
-
import {
|
|
25
|
+
import { utils, i18n, api } from '../../../../core/client'
|
|
25
26
|
import { KGrid } from '../../../../core/client/components'
|
|
26
27
|
import { uncacheView } from '../../utils'
|
|
27
28
|
|
|
@@ -29,23 +30,34 @@ import { uncacheView } from '../../utils'
|
|
|
29
30
|
const router = useRouter()
|
|
30
31
|
const route = useRoute()
|
|
31
32
|
const { CurrentActivity } = useCurrentActivity()
|
|
32
|
-
const filter = ref(Filter.get())
|
|
33
|
-
const sorter = Sorter.get()
|
|
34
33
|
const projectRenderer = ref({
|
|
35
34
|
component: 'catalog/KProjectSelector',
|
|
36
35
|
class: 'col-12'
|
|
37
36
|
})
|
|
37
|
+
const baseQuery = ref({ $sort: { name: 1 } })
|
|
38
|
+
const searchString = ref('')
|
|
38
39
|
|
|
39
40
|
// Computed
|
|
40
|
-
const
|
|
41
|
+
const filterQuery = computed(() => {
|
|
42
|
+
const query = {}
|
|
43
|
+
if (!_.isEmpty(searchString.value)) {
|
|
44
|
+
query.name = { $regex: searchString.value }
|
|
45
|
+
}
|
|
46
|
+
return query
|
|
47
|
+
})
|
|
41
48
|
const toolbar = computed(() => {
|
|
42
49
|
return [
|
|
43
50
|
{
|
|
44
51
|
id: 'projects-filter',
|
|
45
|
-
component: 'collection/
|
|
52
|
+
component: 'collection/KItemsFilter',
|
|
53
|
+
class: 'col',
|
|
54
|
+
value: searchString.value,
|
|
55
|
+
onSearch: (value) => {
|
|
56
|
+
searchString.value = value
|
|
57
|
+
}
|
|
46
58
|
},
|
|
47
59
|
{
|
|
48
|
-
component: 'collection/
|
|
60
|
+
component: 'collection/KItemsSorter',
|
|
49
61
|
id: 'projects-sorter',
|
|
50
62
|
tooltip: 'KProjectsPanel.SORT_PROJECTS',
|
|
51
63
|
options: [
|
|
@@ -53,7 +65,10 @@ const toolbar = computed(() => {
|
|
|
53
65
|
{ icon: 'las la-sort-alpha-up', value: { field: 'name', order: -1 } },
|
|
54
66
|
{ icon: 'kdk:clockwise.png', value: { field: 'updatedAt', order: 1 } },
|
|
55
67
|
{ icon: 'kdk:anticlockwise.png', value: { field: 'updatedAt', order: -1 } }
|
|
56
|
-
]
|
|
68
|
+
],
|
|
69
|
+
onOptionChanged: (option) => {
|
|
70
|
+
baseQuery.value = { $sort: { [option.field]: option.order } }
|
|
71
|
+
}
|
|
57
72
|
}
|
|
58
73
|
]
|
|
59
74
|
})
|
|
@@ -21,38 +21,45 @@
|
|
|
21
21
|
import _ from 'lodash'
|
|
22
22
|
import logger from 'loglevel'
|
|
23
23
|
import { ref, computed } from 'vue'
|
|
24
|
-
import {
|
|
24
|
+
import { utils, i18n, api, LocalCache, Store } from '../../../../core/client'
|
|
25
25
|
import { KGrid } from '../../../../core/client/components'
|
|
26
26
|
import { useCurrentActivity, useProject } from '../../composables'
|
|
27
27
|
import { cacheView, uncacheView } from '../../utils/utils.offline.js'
|
|
28
28
|
import { Dialog, Notify } from 'quasar'
|
|
29
29
|
|
|
30
30
|
// Data
|
|
31
|
-
const filter = Filter.get()
|
|
32
|
-
const sorter = Sorter.get()
|
|
33
31
|
const { CurrentActivity } = useCurrentActivity()
|
|
34
32
|
const { project: loadedProject } = await getProject()
|
|
35
33
|
const project = ref(loadedProject)
|
|
36
34
|
const viewRenderer = ref(getViewRenderer())
|
|
35
|
+
const searchString = ref('')
|
|
36
|
+
const sortQuery = ref({ $sort: { name: 1 } })
|
|
37
37
|
|
|
38
38
|
// Computed
|
|
39
39
|
const baseQuery = computed(() => {
|
|
40
|
-
return Object.assign({ type: 'Context' },
|
|
40
|
+
return Object.assign({ type: 'Context' }, sortQuery.value)
|
|
41
41
|
})
|
|
42
42
|
const filterQuery = computed(() => {
|
|
43
43
|
const query = {}
|
|
44
44
|
if (project.value) Object.assign(query, { _id: { $in: _.map(project.value.views, '_id') } })
|
|
45
|
-
|
|
45
|
+
if (!_.isEmpty(searchString.value)) {
|
|
46
|
+
Object.assign(query, { name: { $regex: searchString.value } })
|
|
47
|
+
}
|
|
46
48
|
return query
|
|
47
49
|
})
|
|
48
50
|
const toolbar = computed(() => {
|
|
49
51
|
return [
|
|
50
52
|
{
|
|
51
53
|
id: 'views-filter',
|
|
52
|
-
component: 'collection/
|
|
54
|
+
component: 'collection/KItemsFilter',
|
|
55
|
+
class: 'col',
|
|
56
|
+
value: searchString.value,
|
|
57
|
+
onSearch: (value) => {
|
|
58
|
+
searchString.value = value
|
|
59
|
+
}
|
|
53
60
|
},
|
|
54
61
|
{
|
|
55
|
-
component: 'collection/
|
|
62
|
+
component: 'collection/KItemsSorter',
|
|
56
63
|
id: 'views-sorter',
|
|
57
64
|
tooltip: 'KViewsPanel.SORT_VIEWS',
|
|
58
65
|
options: [
|
|
@@ -60,7 +67,10 @@ const toolbar = computed(() => {
|
|
|
60
67
|
{ icon: 'las la-sort-alpha-up', value: { field: 'name', order: -1 } },
|
|
61
68
|
{ icon: 'kdk:clockwise.png', value: { field: 'updatedAt', order: 1 } },
|
|
62
69
|
{ icon: 'kdk:anticlockwise.png', value: { field: 'updatedAt', order: -1 } }
|
|
63
|
-
]
|
|
70
|
+
],
|
|
71
|
+
onOptionChanged: (option) => {
|
|
72
|
+
sortQuery.value = { $sort: { [option.field]: option.order } }
|
|
73
|
+
}
|
|
64
74
|
}
|
|
65
75
|
]
|
|
66
76
|
})
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div v-if="forecastModels.length > 0">
|
|
3
|
-
<k-layers-
|
|
3
|
+
<k-layers-list :layers="filteredLayers" :options="options">
|
|
4
4
|
<template v-slot:header>
|
|
5
5
|
<div class="q-ma-sm">
|
|
6
6
|
<q-select for="forecast-model" id="forecast-model" v-model="model" :options="models" filled map-options emit-value @update:model-value="onModelChanged">
|
|
@@ -25,7 +25,7 @@
|
|
|
25
25
|
</q-select>
|
|
26
26
|
</div>
|
|
27
27
|
</template>
|
|
28
|
-
</k-layers-
|
|
28
|
+
</k-layers-list>
|
|
29
29
|
</div>
|
|
30
30
|
<div v-else class="row justify-center q-pa-sm">
|
|
31
31
|
<KStamp icon="las la-exclamation-circle" icon-size="sm" :text="$t('KWeatherLayersSelector.NO_MODEL_AVAILABLE')" text-size="0.9rem" direction="horizontal" />
|
|
@@ -36,7 +36,7 @@
|
|
|
36
36
|
import _ from 'lodash'
|
|
37
37
|
import { computed, ref } from 'vue'
|
|
38
38
|
import { KStamp } from '../../../../core/client/components'
|
|
39
|
-
import
|
|
39
|
+
import KLayersList from './KLayersList.vue'
|
|
40
40
|
|
|
41
41
|
// Props
|
|
42
42
|
const props = defineProps({
|
|
@@ -64,7 +64,7 @@
|
|
|
64
64
|
:error-message="errorLabel"
|
|
65
65
|
:error="hasError"
|
|
66
66
|
:disable="disabled"
|
|
67
|
-
:clearable="
|
|
67
|
+
:clearable="isClearable()"
|
|
68
68
|
bottom-slots
|
|
69
69
|
borderless
|
|
70
70
|
@clear="onCleared">
|
|
@@ -111,14 +111,11 @@ export default {
|
|
|
111
111
|
},
|
|
112
112
|
labelMode () {
|
|
113
113
|
return _.get(this.properties.field, 'labelMode', 'from')
|
|
114
|
-
},
|
|
115
|
-
clearable () {
|
|
116
|
-
return _.get(this.properties.field, 'clearable', false)
|
|
117
114
|
}
|
|
118
115
|
},
|
|
119
116
|
methods: {
|
|
120
|
-
|
|
121
|
-
return
|
|
117
|
+
isClearable () {
|
|
118
|
+
return _.get(this.properties.field, 'clearable', false)
|
|
122
119
|
},
|
|
123
120
|
onCleared () {
|
|
124
121
|
this.model = null
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
</template>
|
|
33
33
|
|
|
34
34
|
<script>
|
|
35
|
-
import { mixins as kCoreMixins } from '../../../../core/client'
|
|
35
|
+
import { api, mixins as kCoreMixins } from '../../../../core/client'
|
|
36
36
|
|
|
37
37
|
export default {
|
|
38
38
|
name: 'k-category-field',
|
|
@@ -49,7 +49,7 @@ export default {
|
|
|
49
49
|
},
|
|
50
50
|
async created () {
|
|
51
51
|
// Build the list of available categories
|
|
52
|
-
const response = await
|
|
52
|
+
const response = await api.getService('catalog').find({ query: { type: 'Category' } })
|
|
53
53
|
this.availableCategories = response.data
|
|
54
54
|
}
|
|
55
55
|
}
|
|
@@ -55,7 +55,7 @@
|
|
|
55
55
|
</template>
|
|
56
56
|
</q-select>
|
|
57
57
|
<!-- Header -->
|
|
58
|
-
<div class="row" v-if="
|
|
58
|
+
<div class="row" v-if="unhautorized">
|
|
59
59
|
<q-input class="col"
|
|
60
60
|
:for="properties.name + '-header-key-field'"
|
|
61
61
|
:id="properties.name + '-header-key-field'"
|
|
@@ -80,9 +80,8 @@
|
|
|
80
80
|
|
|
81
81
|
<script>
|
|
82
82
|
import _ from 'lodash'
|
|
83
|
-
import fetch from 'node-fetch'
|
|
84
83
|
import xml2js from 'xml2js'
|
|
85
|
-
import { mixins as kCoreMixins } from '../../../../core/client'
|
|
84
|
+
import { api, mixins as kCoreMixins } from '../../../../core/client'
|
|
86
85
|
import { KAction } from '../../../../core/client/components'
|
|
87
86
|
import * as wms from '../../../common/wms-utils'
|
|
88
87
|
import * as wfs from '../../../common/wfs-utils'
|
|
@@ -99,7 +98,7 @@ export default {
|
|
|
99
98
|
return {
|
|
100
99
|
request: '',
|
|
101
100
|
availableServices: [],
|
|
102
|
-
|
|
101
|
+
unhautorized: false,
|
|
103
102
|
headerKey: '',
|
|
104
103
|
headerValue: '',
|
|
105
104
|
loading: false
|
|
@@ -127,38 +126,37 @@ export default {
|
|
|
127
126
|
let response = null
|
|
128
127
|
this.loading = true
|
|
129
128
|
if (request) {
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
this.error = ''
|
|
142
|
-
}
|
|
129
|
+
// Check if related to registered service in case we need headers
|
|
130
|
+
const service = _.find(this.availableServices, { request })
|
|
131
|
+
const url = new URL(request)
|
|
132
|
+
response = await this.probeEndpoint(url, _.get(service, 'headers', {}))
|
|
133
|
+
if (response) {
|
|
134
|
+
// make sure WFS server supports GeoJSON output
|
|
135
|
+
if (response.protocol === 'WFS' && !response.geoJsonOutputFormat) {
|
|
136
|
+
this.error = 'KOwsServiceField.WFS_MISSING_GEOJSON_SUPPORT'
|
|
137
|
+
} else {
|
|
138
|
+
this.model = response
|
|
139
|
+
this.error = ''
|
|
143
140
|
}
|
|
144
|
-
}
|
|
145
|
-
|
|
141
|
+
} else if (this.unhautorized) {
|
|
142
|
+
// Remove any previous headers as token might have expired or so
|
|
143
|
+
_.unset(service, 'headers')
|
|
146
144
|
}
|
|
147
145
|
}
|
|
148
146
|
this.loading = false
|
|
149
|
-
if (this.model) this.onChanged()
|
|
147
|
+
if (this.model && !this.error) this.onChanged()
|
|
150
148
|
},
|
|
151
149
|
async onAddService () {
|
|
152
150
|
// Delete the available layers before saving the service
|
|
153
151
|
const service = _.cloneDeep(this.model)
|
|
154
152
|
delete service.availableLayers
|
|
155
153
|
// Save the service
|
|
156
|
-
await
|
|
154
|
+
await api.getService('catalog').create(service)
|
|
157
155
|
// Refresh the list of available services
|
|
158
156
|
this.refreshAvailableServices()
|
|
159
157
|
},
|
|
160
158
|
async onDeleteService (service) {
|
|
161
|
-
await
|
|
159
|
+
await api.getService('catalog').remove(service._id)
|
|
162
160
|
// Refresh the list of available services
|
|
163
161
|
this.refreshAvailableServices()
|
|
164
162
|
// Clear
|
|
@@ -197,9 +195,11 @@ export default {
|
|
|
197
195
|
}
|
|
198
196
|
const resp = await fetch(query, { redirect: 'follow', headers: result.headers })
|
|
199
197
|
if ((resp.status === 401) || (resp.status === 403)) {
|
|
200
|
-
this.
|
|
198
|
+
this.unhautorized = true
|
|
201
199
|
this.error = 'KOwsServiceField.UNAUTHORIZED_MESSAGE'
|
|
202
200
|
return null
|
|
201
|
+
} else {
|
|
202
|
+
this.unhautorized = false
|
|
203
203
|
}
|
|
204
204
|
const txt = await resp.text()
|
|
205
205
|
caps = await xml2js.parseStringPromise(txt, { tagNameProcessors: [xml2js.processors.stripPrefix] })
|
|
@@ -241,6 +241,7 @@ export default {
|
|
|
241
241
|
result.availableLayers = decoded.availableLayers
|
|
242
242
|
result.version = this.findQueryParameter(url.searchParams, 'VERSION')
|
|
243
243
|
if (!result.version) result.version = decoded.version
|
|
244
|
+
if (decoded.getMapUrl) result.getMapUrl = decoded.getMapUrl
|
|
244
245
|
} else if (result.protocol === 'WFS') {
|
|
245
246
|
const decoded = await wfs.discover(result.baseUrl, result.searchParams, result.headers, caps)
|
|
246
247
|
result.availableLayers = decoded.availableLayers
|
|
@@ -275,7 +276,7 @@ export default {
|
|
|
275
276
|
},
|
|
276
277
|
async refreshAvailableServices () {
|
|
277
278
|
// Retrieve the list of the available services
|
|
278
|
-
const response = await
|
|
279
|
+
const response = await api.getService('catalog').find({ query: { type: 'Service' } })
|
|
279
280
|
this.availableServices = response.data
|
|
280
281
|
}
|
|
281
282
|
},
|
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
:error-message="errorLabel"
|
|
8
8
|
:error="hasError"
|
|
9
9
|
:disable="disabled"
|
|
10
|
-
:clearable="
|
|
10
|
+
:clearable="isClearable()"
|
|
11
11
|
hide-bottom-space
|
|
12
12
|
bottom-slots
|
|
13
13
|
borderless
|
|
@@ -54,9 +54,6 @@ export default {
|
|
|
54
54
|
},
|
|
55
55
|
inheritAttrs: false,
|
|
56
56
|
computed: {
|
|
57
|
-
clearable () {
|
|
58
|
-
return _.get(this.properties.field, 'clearable', false)
|
|
59
|
-
},
|
|
60
57
|
layerTree () {
|
|
61
58
|
const tree = []
|
|
62
59
|
const userLayers = { id: 'userLayers', label: this.$t('LAYERS_LABEL'), layers: [] }
|
|
@@ -102,6 +99,9 @@ export default {
|
|
|
102
99
|
emptyModel () {
|
|
103
100
|
return []
|
|
104
101
|
},
|
|
102
|
+
isClearable () {
|
|
103
|
+
return _.get(this.properties.field, 'clearable', false)
|
|
104
|
+
},
|
|
105
105
|
fill (value) {
|
|
106
106
|
kCoreMixins.baseField.methods.fill.call(this, value)
|
|
107
107
|
// As we keep track of ID/name depending on if a layer comes from local/global catalog we need to process both
|
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
:error-message="errorLabel"
|
|
8
8
|
:error="hasError"
|
|
9
9
|
:disable="disabled"
|
|
10
|
-
:clearable="
|
|
10
|
+
:clearable="isClearable()"
|
|
11
11
|
hide-bottom-space
|
|
12
12
|
bottom-slots
|
|
13
13
|
borderless
|
|
@@ -63,9 +63,6 @@ export default {
|
|
|
63
63
|
},
|
|
64
64
|
inheritAttrs: false,
|
|
65
65
|
computed: {
|
|
66
|
-
clearable () {
|
|
67
|
-
return _.get(this.properties.field, 'clearable', false)
|
|
68
|
-
},
|
|
69
66
|
viewTree () {
|
|
70
67
|
const tree = []
|
|
71
68
|
if (this.views.length > 0) {
|
|
@@ -86,6 +83,9 @@ export default {
|
|
|
86
83
|
emptyModel () {
|
|
87
84
|
return []
|
|
88
85
|
},
|
|
86
|
+
isClearable () {
|
|
87
|
+
return _.get(this.properties.field, 'clearable', false)
|
|
88
|
+
},
|
|
89
89
|
fill (value) {
|
|
90
90
|
kCoreMixins.baseField.methods.fill.call(this, value)
|
|
91
91
|
this.selectedViews = _.map(this.model, '_id')
|
|
@@ -42,6 +42,15 @@ const legends = computed(() => {
|
|
|
42
42
|
const result = []
|
|
43
43
|
let layerLegends = props.layer.legend || []
|
|
44
44
|
if (!Array.isArray(layerLegends)) layerLegends = [layerLegends]
|
|
45
|
+
// Check if layer has filters with own legend
|
|
46
|
+
if (Array.isArray(props.layer.filters)) {
|
|
47
|
+
props.layer.filters.forEach((filter) => {
|
|
48
|
+
// Include when filter is active and has a legend
|
|
49
|
+
if (!filter.isActive || !filter.legend) { return }
|
|
50
|
+
const filterLegends = Array.isArray(filter.legend) ? filter.legend : [filter.legend]
|
|
51
|
+
layerLegends.push(...filterLegends)
|
|
52
|
+
})
|
|
53
|
+
}
|
|
45
54
|
layerLegends.forEach(legend => {
|
|
46
55
|
const minZoom = _.get(legend, 'minZoom', _.get(props.layer, `${props.engine}.minZoom`, 0))
|
|
47
56
|
const maxZoom = _.get(legend, 'maxZoom', _.get(props.layer, `${props.engine}.maxZoom`, 99))
|
|
@@ -50,9 +59,9 @@ const legends = computed(() => {
|
|
|
50
59
|
const hasMinZoom = _.isNumber(minZoom)
|
|
51
60
|
const hasMaxZoom = _.isNumber(maxZoom)
|
|
52
61
|
const inMinZoomRange = (hasMinZoom ? props.zoom >= minZoom : true)
|
|
53
|
-
const inMaxZoomRange = (hasMaxZoom ? props.zoom
|
|
62
|
+
const inMaxZoomRange = (hasMaxZoom ? props.zoom < maxZoom : true)
|
|
54
63
|
if (inMinZoomRange && inMaxZoomRange) {
|
|
55
|
-
logger.debug(`[KDK]
|
|
64
|
+
logger.debug(`[KDK] Rendering '${props.layer.name}' legend`)
|
|
56
65
|
const renderer = props.renderers[legend.type]
|
|
57
66
|
if (!renderer) {
|
|
58
67
|
logger.warn(`[KDK] Cannot find any renderer for the layer's legend of type of ${legend.type}`)
|