@kalisio/kdk 1.3.6 → 1.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.nyc_output/{0d403586-0c7c-4336-94d1-a49e9f02a905.json → 058fc679-d60a-4501-ac04-71171e5200b8.json} +0 -0
- package/.nyc_output/2226bcce-9d22-4dad-b9fa-46564b5565c7.json +1 -0
- package/.nyc_output/6dc4b140-1a8a-4d69-b91c-89c557883d6e.json +1 -0
- package/.nyc_output/{21dd57bd-48c5-41c8-8800-252db32a9366.json → 8b1830fa-932e-4a61-9837-4a5b18f83ea9.json} +0 -0
- package/.nyc_output/{3eb3a2ca-53c2-4551-ba6b-adf70f9a53cd.json → afd2d144-3570-4858-b94a-b523dbd023dd.json} +0 -0
- package/.nyc_output/processinfo/058fc679-d60a-4501-ac04-71171e5200b8.json +1 -0
- package/.nyc_output/processinfo/2226bcce-9d22-4dad-b9fa-46564b5565c7.json +1 -0
- package/.nyc_output/processinfo/6dc4b140-1a8a-4d69-b91c-89c557883d6e.json +1 -0
- package/.nyc_output/processinfo/8b1830fa-932e-4a61-9837-4a5b18f83ea9.json +1 -0
- package/.nyc_output/processinfo/afd2d144-3570-4858-b94a-b523dbd023dd.json +1 -0
- package/.nyc_output/processinfo/index.json +1 -1
- package/CHANGELOG.md +167 -79
- package/README.md +1 -1
- package/coverage/core/api/application.js.html +436 -436
- package/coverage/core/api/authentication.js.html +119 -119
- package/coverage/core/api/db.js.html +201 -201
- package/coverage/core/api/hooks/hooks.account.js.html +48 -48
- package/coverage/core/api/hooks/hooks.authentication.js.html +64 -64
- package/coverage/core/api/hooks/hooks.authorisations.js.html +369 -378
- package/coverage/core/api/hooks/hooks.devices.js.html +49 -49
- package/coverage/core/api/hooks/hooks.groups.js.html +37 -37
- package/coverage/core/api/hooks/hooks.logger.js.html +27 -27
- package/coverage/core/api/hooks/hooks.model.js.html +269 -269
- package/coverage/core/api/hooks/hooks.organisations.js.html +183 -231
- package/coverage/core/api/hooks/hooks.pusher.js.html +114 -114
- package/coverage/core/api/hooks/hooks.query.js.html +234 -198
- package/coverage/core/api/hooks/hooks.service.js.html +82 -82
- package/coverage/core/api/hooks/hooks.storage.js.html +121 -121
- package/coverage/core/api/hooks/hooks.tags.js.html +232 -232
- package/coverage/core/api/hooks/hooks.users.js.html +304 -256
- package/coverage/core/api/hooks/index.html +172 -172
- package/coverage/core/api/hooks/index.js.html +24 -24
- package/coverage/core/api/index.html +75 -75
- package/coverage/core/api/index.js.html +26 -26
- package/coverage/core/api/marshall.js.html +57 -57
- package/coverage/core/api/models/groups.model.mongodb.js.html +20 -20
- package/coverage/core/api/models/index.html +50 -50
- package/coverage/core/api/models/organisations.model.mongodb.js.html +12 -12
- package/coverage/core/api/models/tags.model.mongodb.js.html +22 -22
- package/coverage/core/api/models/users.model.mongodb.js.html +20 -20
- package/coverage/core/api/oauth2-handler.js.html +18 -18
- package/coverage/core/api/oauth2-verifier.js.html +38 -38
- package/coverage/core/api/services/account/account.hooks.js.html +16 -16
- package/coverage/core/api/services/account/account.service.js.html +108 -108
- package/coverage/core/api/services/account/index.html +32 -32
- package/coverage/core/api/services/authorisations/authorisations.hooks.js.html +9 -9
- package/coverage/core/api/services/authorisations/authorisations.service.js.html +132 -129
- package/coverage/core/api/services/authorisations/index.html +28 -28
- package/coverage/core/api/services/databases/databases.hooks.js.html +9 -9
- package/coverage/core/api/services/databases/databases.service.js.html +12 -12
- package/coverage/core/api/services/databases/index.html +24 -24
- package/coverage/core/api/services/devices/devices.hooks.js.html +9 -9
- package/coverage/core/api/services/devices/devices.service.js.html +121 -121
- package/coverage/core/api/services/devices/index.html +28 -28
- package/coverage/core/api/services/groups/groups.hooks.js.html +9 -9
- package/coverage/core/api/services/groups/index.html +13 -13
- package/coverage/core/api/services/index.html +21 -21
- package/coverage/core/api/services/index.js.html +137 -137
- package/coverage/core/api/services/mailer/index.html +24 -24
- package/coverage/core/api/services/mailer/mailer.hooks.js.html +9 -9
- package/coverage/core/api/services/mailer/mailer.service.js.html +19 -19
- package/coverage/core/api/services/organisations/index.html +24 -24
- package/coverage/core/api/services/organisations/organisations.hooks.js.html +8 -8
- package/coverage/core/api/services/organisations/organisations.service.js.html +67 -67
- package/coverage/core/api/services/pusher/index.html +34 -34
- package/coverage/core/api/services/pusher/pusher.channels.js.html +8 -8
- package/coverage/core/api/services/pusher/pusher.hooks.js.html +10 -10
- package/coverage/core/api/services/pusher/pusher.service.js.html +414 -414
- package/coverage/core/api/services/storage/index.html +21 -21
- package/coverage/core/api/services/storage/storage.hooks.js.html +35 -35
- package/coverage/core/api/services/tags/index.html +21 -21
- package/coverage/core/api/services/tags/tags.hooks.js.html +25 -25
- package/coverage/core/api/services/users/index.html +21 -21
- package/coverage/core/api/services/users/users.hooks.js.html +33 -33
- package/coverage/core/common/errors.js.html +1 -1
- package/coverage/core/common/index.html +42 -27
- package/coverage/core/common/index.js.html +16 -16
- package/coverage/core/common/permissions.js.html +325 -265
- package/coverage/index.html +182 -182
- package/coverage/lcov-report/core/api/application.js.html +436 -436
- package/coverage/lcov-report/core/api/authentication.js.html +119 -119
- package/coverage/lcov-report/core/api/db.js.html +201 -201
- package/coverage/lcov-report/core/api/hooks/hooks.account.js.html +48 -48
- package/coverage/lcov-report/core/api/hooks/hooks.authentication.js.html +64 -64
- package/coverage/lcov-report/core/api/hooks/hooks.authorisations.js.html +369 -378
- package/coverage/lcov-report/core/api/hooks/hooks.devices.js.html +49 -49
- package/coverage/lcov-report/core/api/hooks/hooks.groups.js.html +37 -37
- package/coverage/lcov-report/core/api/hooks/hooks.logger.js.html +27 -27
- package/coverage/lcov-report/core/api/hooks/hooks.model.js.html +269 -269
- package/coverage/lcov-report/core/api/hooks/hooks.organisations.js.html +183 -231
- package/coverage/lcov-report/core/api/hooks/hooks.pusher.js.html +114 -114
- package/coverage/lcov-report/core/api/hooks/hooks.query.js.html +234 -198
- package/coverage/lcov-report/core/api/hooks/hooks.service.js.html +82 -82
- package/coverage/lcov-report/core/api/hooks/hooks.storage.js.html +121 -121
- package/coverage/lcov-report/core/api/hooks/hooks.tags.js.html +232 -232
- package/coverage/lcov-report/core/api/hooks/hooks.users.js.html +304 -256
- package/coverage/lcov-report/core/api/hooks/index.html +172 -172
- package/coverage/lcov-report/core/api/hooks/index.js.html +24 -24
- package/coverage/lcov-report/core/api/index.html +75 -75
- package/coverage/lcov-report/core/api/index.js.html +26 -26
- package/coverage/lcov-report/core/api/marshall.js.html +57 -57
- package/coverage/lcov-report/core/api/models/groups.model.mongodb.js.html +20 -20
- package/coverage/lcov-report/core/api/models/index.html +50 -50
- package/coverage/lcov-report/core/api/models/organisations.model.mongodb.js.html +12 -12
- package/coverage/lcov-report/core/api/models/tags.model.mongodb.js.html +22 -22
- package/coverage/lcov-report/core/api/models/users.model.mongodb.js.html +20 -20
- package/coverage/lcov-report/core/api/oauth2-handler.js.html +18 -18
- package/coverage/lcov-report/core/api/oauth2-verifier.js.html +38 -38
- package/coverage/lcov-report/core/api/services/account/account.hooks.js.html +16 -16
- package/coverage/lcov-report/core/api/services/account/account.service.js.html +108 -108
- package/coverage/lcov-report/core/api/services/account/index.html +32 -32
- package/coverage/lcov-report/core/api/services/authorisations/authorisations.hooks.js.html +9 -9
- package/coverage/lcov-report/core/api/services/authorisations/authorisations.service.js.html +132 -129
- package/coverage/lcov-report/core/api/services/authorisations/index.html +28 -28
- package/coverage/lcov-report/core/api/services/databases/databases.hooks.js.html +9 -9
- package/coverage/lcov-report/core/api/services/databases/databases.service.js.html +12 -12
- package/coverage/lcov-report/core/api/services/databases/index.html +24 -24
- package/coverage/lcov-report/core/api/services/devices/devices.hooks.js.html +9 -9
- package/coverage/lcov-report/core/api/services/devices/devices.service.js.html +121 -121
- package/coverage/lcov-report/core/api/services/devices/index.html +28 -28
- package/coverage/lcov-report/core/api/services/groups/groups.hooks.js.html +9 -9
- package/coverage/lcov-report/core/api/services/groups/index.html +13 -13
- package/coverage/lcov-report/core/api/services/index.html +21 -21
- package/coverage/lcov-report/core/api/services/index.js.html +137 -137
- package/coverage/lcov-report/core/api/services/mailer/index.html +24 -24
- package/coverage/lcov-report/core/api/services/mailer/mailer.hooks.js.html +9 -9
- package/coverage/lcov-report/core/api/services/mailer/mailer.service.js.html +19 -19
- package/coverage/lcov-report/core/api/services/organisations/index.html +24 -24
- package/coverage/lcov-report/core/api/services/organisations/organisations.hooks.js.html +8 -8
- package/coverage/lcov-report/core/api/services/organisations/organisations.service.js.html +67 -67
- package/coverage/lcov-report/core/api/services/pusher/index.html +34 -34
- package/coverage/lcov-report/core/api/services/pusher/pusher.channels.js.html +8 -8
- package/coverage/lcov-report/core/api/services/pusher/pusher.hooks.js.html +10 -10
- package/coverage/lcov-report/core/api/services/pusher/pusher.service.js.html +414 -414
- package/coverage/lcov-report/core/api/services/storage/index.html +21 -21
- package/coverage/lcov-report/core/api/services/storage/storage.hooks.js.html +35 -35
- package/coverage/lcov-report/core/api/services/tags/index.html +21 -21
- package/coverage/lcov-report/core/api/services/tags/tags.hooks.js.html +25 -25
- package/coverage/lcov-report/core/api/services/users/index.html +21 -21
- package/coverage/lcov-report/core/api/services/users/users.hooks.js.html +33 -33
- package/coverage/lcov-report/core/common/errors.js.html +1 -1
- package/coverage/lcov-report/core/common/index.html +42 -27
- package/coverage/lcov-report/core/common/index.js.html +16 -16
- package/coverage/lcov-report/core/common/permissions.js.html +325 -265
- package/coverage/lcov-report/index.html +182 -182
- package/coverage/lcov-report/map/api/hooks/hooks.catalog.js.html +1 -1
- package/coverage/lcov-report/map/api/hooks/hooks.query.js.html +118 -37
- package/coverage/lcov-report/map/api/hooks/index.html +7 -7
- package/coverage/lcov-report/map/api/hooks/index.js.html +1 -1
- package/coverage/lcov-report/map/api/index.html +1 -1
- package/coverage/lcov-report/map/api/index.js.html +1 -1
- package/coverage/lcov-report/map/api/marshall.js.html +1 -1
- package/coverage/lcov-report/map/api/models/alerts.model.mongodb.js.html +1 -1
- package/coverage/lcov-report/map/api/models/catalog.model.mongodb.js.html +1 -1
- package/coverage/lcov-report/map/api/models/features.model.mongodb.js.html +1 -1
- package/coverage/lcov-report/map/api/models/index.html +1 -1
- package/coverage/lcov-report/map/api/services/alerts/alerts.hooks.js.html +1 -1
- package/coverage/lcov-report/map/api/services/alerts/alerts.service.js.html +1 -1
- package/coverage/lcov-report/map/api/services/alerts/index.html +1 -1
- package/coverage/lcov-report/map/api/services/catalog/catalog.hooks.js.html +1 -1
- package/coverage/lcov-report/map/api/services/catalog/index.html +1 -1
- package/coverage/lcov-report/map/api/services/daptiles/daptiles.service.js.html +1 -1
- package/coverage/lcov-report/map/api/services/daptiles/index.html +1 -1
- package/coverage/lcov-report/map/api/services/features/features.hooks.js.html +2 -2
- package/coverage/lcov-report/map/api/services/features/index.html +1 -1
- package/coverage/lcov-report/map/api/services/geocoder/geocoder.hooks.js.html +1 -1
- package/coverage/lcov-report/map/api/services/geocoder/geocoder.service.js.html +1 -1
- package/coverage/lcov-report/map/api/services/geocoder/index.html +1 -1
- package/coverage/lcov-report/map/api/services/index.html +1 -1
- package/coverage/lcov-report/map/api/services/index.js.html +1 -1
- package/coverage/lcov-report/map/common/dynamic-grid-source.js.html +1 -1
- package/coverage/lcov-report/map/common/errors.js.html +1 -1
- package/coverage/lcov-report/map/common/geotiff-grid-source.js.html +1 -1
- package/coverage/lcov-report/map/common/grid.js.html +1 -1
- package/coverage/lcov-report/map/common/index.html +12 -12
- package/coverage/lcov-report/map/common/index.js.html +1 -1
- package/coverage/lcov-report/map/common/meteo-model-grid-source.js.html +1 -1
- package/coverage/lcov-report/map/common/moment-utils.js.html +1 -1
- package/coverage/lcov-report/map/common/opendap-grid-source.js.html +1 -1
- package/coverage/lcov-report/map/common/opendap-utils.js.html +1 -1
- package/coverage/lcov-report/map/common/permissions.js.html +1 -1
- package/coverage/lcov-report/map/common/time-based-grid-source.js.html +1 -1
- package/coverage/lcov-report/map/common/tms-utils.js.html +1 -1
- package/coverage/lcov-report/map/common/wcs-grid-source.js.html +1 -1
- package/coverage/lcov-report/map/common/wcs-utils.js.html +1 -1
- package/coverage/lcov-report/map/common/weacast-grid-source.js.html +1 -1
- package/coverage/lcov-report/map/common/wfs-utils.js.html +8 -5
- package/coverage/lcov-report/map/common/wms-utils.js.html +1 -1
- package/coverage/lcov-report/map/common/wmts-utils.js.html +71 -11
- package/coverage/lcov.info +3742 -3949
- package/coverage/map/api/hooks/hooks.catalog.js.html +1 -1
- package/coverage/map/api/hooks/hooks.query.js.html +118 -37
- package/coverage/map/api/hooks/index.html +7 -7
- package/coverage/map/api/hooks/index.js.html +1 -1
- package/coverage/map/api/index.html +1 -1
- package/coverage/map/api/index.js.html +1 -1
- package/coverage/map/api/marshall.js.html +1 -1
- package/coverage/map/api/models/alerts.model.mongodb.js.html +1 -1
- package/coverage/map/api/models/catalog.model.mongodb.js.html +1 -1
- package/coverage/map/api/models/features.model.mongodb.js.html +1 -1
- package/coverage/map/api/models/index.html +1 -1
- package/coverage/map/api/services/alerts/alerts.hooks.js.html +1 -1
- package/coverage/map/api/services/alerts/alerts.service.js.html +1 -1
- package/coverage/map/api/services/alerts/index.html +1 -1
- package/coverage/map/api/services/catalog/catalog.hooks.js.html +1 -1
- package/coverage/map/api/services/catalog/index.html +1 -1
- package/coverage/map/api/services/daptiles/daptiles.service.js.html +1 -1
- package/coverage/map/api/services/daptiles/index.html +1 -1
- package/coverage/map/api/services/features/features.hooks.js.html +2 -2
- package/coverage/map/api/services/features/index.html +1 -1
- package/coverage/map/api/services/geocoder/geocoder.hooks.js.html +1 -1
- package/coverage/map/api/services/geocoder/geocoder.service.js.html +1 -1
- package/coverage/map/api/services/geocoder/index.html +1 -1
- package/coverage/map/api/services/index.html +1 -1
- package/coverage/map/api/services/index.js.html +1 -1
- package/coverage/map/common/dynamic-grid-source.js.html +1 -1
- package/coverage/map/common/errors.js.html +1 -1
- package/coverage/map/common/geotiff-grid-source.js.html +1 -1
- package/coverage/map/common/grid.js.html +1 -1
- package/coverage/map/common/index.html +12 -12
- package/coverage/map/common/index.js.html +1 -1
- package/coverage/map/common/meteo-model-grid-source.js.html +1 -1
- package/coverage/map/common/moment-utils.js.html +1 -1
- package/coverage/map/common/opendap-grid-source.js.html +1 -1
- package/coverage/map/common/opendap-utils.js.html +1 -1
- package/coverage/map/common/permissions.js.html +1 -1
- package/coverage/map/common/time-based-grid-source.js.html +1 -1
- package/coverage/map/common/tms-utils.js.html +1 -1
- package/coverage/map/common/wcs-grid-source.js.html +1 -1
- package/coverage/map/common/wcs-utils.js.html +1 -1
- package/coverage/map/common/weacast-grid-source.js.html +1 -1
- package/coverage/map/common/wfs-utils.js.html +8 -5
- package/coverage/map/common/wms-utils.js.html +1 -1
- package/coverage/map/common/wmts-utils.js.html +71 -11
- package/extras/icons/kanban.png +0 -0
- package/extras/tours/core/add-member.js +10 -1
- package/extras/tours/core/{tag-member.js → edit-member-tags.js} +4 -3
- package/extras/tours/core/groups.js +8 -2
- package/extras/tours/core/members.js +11 -21
- package/extras/tours/core/tags.js +7 -1
- package/extras/tours/map/catalog-categories.js +4 -4
- package/extras/tours/map/catalog-panel.js +16 -16
- package/extras/tours/map/favorite-views.js +3 -3
- package/lib/core/api/hooks/hooks.authorisations.js +149 -140
- package/lib/core/api/hooks/hooks.authorisations.js.map +1 -1
- package/lib/core/api/hooks/hooks.organisations.js +1 -23
- package/lib/core/api/hooks/hooks.organisations.js.map +1 -1
- package/lib/core/api/hooks/hooks.query.js +22 -0
- package/lib/core/api/hooks/hooks.query.js.map +1 -1
- package/lib/core/api/hooks/hooks.users.js +34 -18
- package/lib/core/api/hooks/hooks.users.js.map +1 -1
- package/lib/core/api/services/authorisations/authorisations.service.js +34 -25
- package/lib/core/api/services/authorisations/authorisations.service.js.map +1 -1
- package/lib/core/client/api.js +1 -0
- package/lib/core/client/api.js.map +1 -1
- package/lib/core/client/components/account/KAccountDZ.vue +3 -4
- package/lib/core/client/components/account/KAccountDevices.vue +5 -6
- package/lib/core/client/components/account/KDeviceCard.vue +2 -1
- package/lib/core/client/components/account/KIdentityPanel.vue +1 -7
- package/lib/core/client/components/collection/KBoard.vue +26 -155
- package/lib/core/client/components/collection/KCard.vue +144 -42
- package/lib/core/client/components/collection/KCardSection.vue +52 -0
- package/lib/core/client/components/collection/KColumn.vue +181 -0
- package/lib/core/client/components/collection/KGrid.vue +13 -18
- package/lib/core/client/components/collection/KHistory.vue +61 -89
- package/lib/core/client/components/collection/KHistoryEntry.vue +90 -66
- package/lib/core/client/components/collection/KItem.vue +21 -2
- package/lib/core/client/components/collection/KList.vue +9 -12
- package/lib/core/client/components/collection/KTable.vue +33 -39
- package/lib/core/client/components/collection/index.js +6 -1
- package/lib/core/client/components/collection/index.js.map +1 -1
- package/lib/core/client/components/editor/KEditor.vue +0 -6
- package/lib/core/client/components/editor/KModalEditor.vue +4 -4
- package/lib/core/client/components/editor/KSettingsEditor.vue +49 -0
- package/lib/core/client/components/form/KAttachmentField.vue +10 -10
- package/lib/core/client/components/form/KChipsField.vue +28 -23
- package/lib/core/client/components/form/KColorField.vue +30 -25
- package/lib/core/client/components/form/KFileField.vue +11 -40
- package/lib/core/client/components/form/KForm.vue +0 -12
- package/lib/core/client/components/form/KIconField.vue +1 -0
- package/lib/core/client/components/form/KItemField.vue +6 -2
- package/lib/core/client/components/form/KRoleField.vue +56 -0
- package/lib/core/client/components/form/KSelectField.vue +16 -1
- package/lib/core/client/components/form/KView.vue +5 -14
- package/lib/core/client/components/frame/KAction.vue +18 -12
- package/lib/core/client/components/frame/KAvatar.vue +3 -3
- package/lib/core/client/components/frame/KChart.vue +60 -0
- package/lib/core/client/components/frame/KChipsPane.vue +80 -0
- package/lib/core/client/components/frame/KContent.vue +1 -1
- package/lib/core/client/components/frame/KModal.vue +30 -44
- package/lib/core/client/components/frame/KPanel.vue +1 -1
- package/lib/core/client/components/frame/{KMenu.vue → KPopupAction.vue} +6 -7
- package/lib/core/client/components/frame/KSpot.vue +31 -0
- package/lib/core/client/components/frame/KStamp.vue +62 -0
- package/lib/core/client/components/frame/index.js +56 -1
- package/lib/core/client/components/frame/index.js.map +1 -1
- package/lib/core/client/components/input/KColorChooser.vue +16 -8
- package/lib/core/client/components/input/KIconChooser.vue +2 -1
- package/lib/core/client/components/input/KOptionsChooser.vue +2 -2
- package/lib/core/client/components/input/KUploader.vue +14 -5
- package/lib/core/client/components/layout/KAbout.vue +9 -3
- package/lib/core/client/components/layout/KFab.vue +1 -1
- package/lib/core/client/components/layout/KPage.vue +44 -19
- package/lib/core/client/components/layout/KTour.vue +2 -2
- package/lib/core/client/components/layout/KWelcome.vue +13 -12
- package/lib/core/client/components/layout/KWindow.vue +1 -1
- package/lib/core/client/components/media/KImageViewer.vue +9 -7
- package/lib/core/client/components/media/KMediaBrowser.vue +12 -8
- package/lib/core/client/components/menu/KMenu.vue +103 -0
- package/lib/core/client/components/team/KAddMember.vue +17 -9
- package/lib/core/client/components/team/KChangeRole.vue +5 -7
- package/lib/core/client/components/team/KGroupCard.vue +34 -51
- package/lib/core/client/components/team/KGroupsActivity.vue +9 -2
- package/lib/core/client/components/team/KJoinGroup.vue +5 -7
- package/lib/core/client/components/team/KMemberCard.vue +104 -63
- package/lib/core/client/components/team/KMembersActivity.vue +9 -2
- package/lib/core/client/components/team/KOrganisationsActivity.vue +8 -1
- package/lib/core/client/components/team/KTagCard.vue +26 -26
- package/lib/core/client/components/team/KTagsActivity.vue +9 -2
- package/lib/core/client/components/time/KTimeRange.vue +144 -0
- package/lib/core/client/components/viewer/KModalViewer.vue +6 -0
- package/lib/core/client/components/viewer/KViewer.vue +0 -6
- package/lib/core/client/i18n/core_en.json +138 -94
- package/lib/core/client/i18n/core_fr.json +61 -17
- package/lib/core/client/index.js +46 -14
- package/lib/core/client/index.js.map +1 -1
- package/lib/core/client/layout.js +8 -1
- package/lib/core/client/layout.js.map +1 -1
- package/lib/core/client/mixins/mixin.authorisation.js +28 -18
- package/lib/core/client/mixins/mixin.authorisation.js.map +1 -1
- package/lib/core/client/mixins/mixin.base-collection.js +57 -9
- package/lib/core/client/mixins/mixin.base-collection.js.map +1 -1
- package/lib/core/client/mixins/mixin.base-context.js +1 -1
- package/lib/core/client/mixins/mixin.base-context.js.map +1 -1
- package/lib/core/client/mixins/mixin.base-editor.js +26 -16
- package/lib/core/client/mixins/mixin.base-editor.js.map +1 -1
- package/lib/core/client/mixins/mixin.base-field.js +0 -4
- package/lib/core/client/mixins/mixin.base-field.js.map +1 -1
- package/lib/core/client/mixins/mixin.base-item.js +29 -14
- package/lib/core/client/mixins/mixin.base-item.js.map +1 -1
- package/lib/core/client/mixins/mixin.base-viewer.js +0 -2
- package/lib/core/client/mixins/mixin.base-viewer.js.map +1 -1
- package/lib/core/client/mixins/mixin.object-proxy.js +17 -3
- package/lib/core/client/mixins/mixin.object-proxy.js.map +1 -1
- package/lib/core/client/mixins/mixin.schema-proxy.js +31 -0
- package/lib/core/client/mixins/mixin.schema-proxy.js.map +1 -1
- package/lib/core/client/mixins/mixin.service.js +5 -33
- package/lib/core/client/mixins/mixin.service.js.map +1 -1
- package/lib/core/client/reader.js +54 -0
- package/lib/core/client/reader.js.map +1 -0
- package/lib/core/client/readers/index.js +30 -0
- package/lib/core/client/readers/index.js.map +1 -0
- package/lib/core/client/readers/reader.csv.js +43 -0
- package/lib/core/client/readers/reader.csv.js.map +1 -0
- package/lib/core/client/readers/reader.json.js +38 -0
- package/lib/core/client/readers/reader.json.js.map +1 -0
- package/lib/core/client/services/index.js +23 -0
- package/lib/core/client/services/index.js.map +1 -1
- package/lib/core/client/services/local-settings.service.js +4 -0
- package/lib/core/client/services/local-settings.service.js.map +1 -1
- package/lib/core/client/time.js +131 -0
- package/lib/core/client/time.js.map +1 -0
- package/lib/core/common/permissions.js +65 -23
- package/lib/core/common/permissions.js.map +1 -1
- package/lib/core/common/schemas/groups.create.json +1 -1
- package/lib/core/common/schemas/groups.update.json +1 -1
- package/lib/core/common/schemas/organisations.create.json +1 -1
- package/lib/core/common/schemas/organisations.update.json +2 -2
- package/lib/core/common/schemas/settings.update.json +139 -0
- package/lib/core/common/schemas/tags.update.json +9 -1
- package/lib/map/api/hooks/hooks.query.js +55 -29
- package/lib/map/api/hooks/hooks.query.js.map +1 -1
- package/lib/map/api/services/features/features.hooks.js +1 -1
- package/lib/map/api/services/features/features.hooks.js.map +1 -1
- package/lib/map/client/components/KCaptureToolbar.vue +156 -0
- package/lib/map/client/components/KColorLegend.vue +25 -23
- package/lib/map/client/components/KFavoriteViews.vue +71 -35
- package/lib/map/client/components/KFeaturesChart.vue +11 -9
- package/lib/map/client/components/KFeaturesFilter.vue +18 -8
- package/lib/map/client/components/KFeaturesTable.vue +27 -2
- package/lib/map/client/components/KLayerEditionToolbar.vue +51 -0
- package/lib/map/client/components/KLayerStyleEditor.vue +12 -5
- package/lib/map/client/components/KLayerStyleForm.vue +44 -33
- package/lib/map/client/components/KLocationInput.vue +126 -65
- package/lib/map/client/components/KLocationMap.vue +199 -84
- package/lib/map/client/components/KMeasureTool.vue +340 -0
- package/lib/map/client/components/KPositionIndicator.vue +1 -0
- package/lib/map/client/components/KTimeline.vue +41 -37
- package/lib/map/client/components/KUrlLegend.vue +21 -19
- package/lib/map/client/components/catalog/KBaseLayersSelector.vue +105 -0
- package/lib/map/client/components/catalog/KCatalog.vue +14 -2
- package/lib/map/client/components/catalog/KConnectLayer.vue +31 -11
- package/lib/map/client/components/catalog/KCreateLayer.vue +37 -14
- package/lib/map/client/components/catalog/KImportLayer.vue +33 -40
- package/lib/map/client/components/catalog/KLayerCategories.vue +86 -62
- package/lib/map/client/components/catalog/KLayersSelector.vue +44 -42
- package/lib/map/client/components/catalog/KWeatherLayersSelector.vue +3 -3
- package/lib/map/client/components/form/KLocationField.vue +1 -1
- package/lib/map/client/components/form/KOwsLayerField.vue +7 -0
- package/lib/map/client/components/form/KOwsServiceField.vue +1 -0
- package/lib/map/client/components/widget/KInformationBox.vue +10 -16
- package/lib/map/client/components/widget/KMapillaryViewer.vue +59 -49
- package/lib/map/client/components/widget/KTimeSeries.vue +119 -31
- package/lib/map/client/i18n/map_en.json +105 -20
- package/lib/map/client/i18n/map_fr.json +107 -23
- package/lib/map/client/init.js +24 -7
- package/lib/map/client/init.js.map +1 -1
- package/lib/map/client/leaflet/GSMaPLayer.js +4 -9
- package/lib/map/client/leaflet/GSMaPLayer.js.map +1 -1
- package/lib/map/client/leaflet/MaskLayer.js +73 -0
- package/lib/map/client/leaflet/MaskLayer.js.map +1 -0
- package/lib/map/client/mixins/globe/mixin.base-globe.js +7 -6
- package/lib/map/client/mixins/globe/mixin.base-globe.js.map +1 -1
- package/lib/map/client/mixins/globe/mixin.geojson-layers.js +7 -9
- package/lib/map/client/mixins/globe/mixin.geojson-layers.js.map +1 -1
- package/lib/map/client/mixins/globe/mixin.popup.js +4 -0
- package/lib/map/client/mixins/globe/mixin.popup.js.map +1 -1
- package/lib/map/client/mixins/globe/mixin.tooltip.js +4 -0
- package/lib/map/client/mixins/globe/mixin.tooltip.js.map +1 -1
- package/lib/map/client/mixins/index.js +8 -13
- package/lib/map/client/mixins/index.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.base-map.js +71 -8
- package/lib/map/client/mixins/map/mixin.base-map.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.canvas-layers.js +276 -51
- package/lib/map/client/mixins/map/mixin.canvas-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.edit-layers.js +218 -121
- package/lib/map/client/mixins/map/mixin.edit-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.file-layers.js +46 -93
- package/lib/map/client/mixins/map/mixin.file-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.geojson-layers.js +22 -11
- package/lib/map/client/mixins/map/mixin.geojson-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.georaster-layers.js +7 -4
- package/lib/map/client/mixins/map/mixin.georaster-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.gsmap-layers.js +3 -3
- package/lib/map/client/mixins/map/mixin.gsmap-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.heatmap-layers.js +8 -10
- package/lib/map/client/mixins/map/mixin.heatmap-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.mapillary-layers.js +25 -40
- package/lib/map/client/mixins/map/mixin.mapillary-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.popup.js +4 -0
- package/lib/map/client/mixins/map/mixin.popup.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.tiled-mesh-layers.js +5 -3
- package/lib/map/client/mixins/map/mixin.tiled-mesh-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.tiled-wind-layers.js +5 -3
- package/lib/map/client/mixins/map/mixin.tiled-wind-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.tooltip.js +4 -0
- package/lib/map/client/mixins/map/mixin.tooltip.js.map +1 -1
- package/lib/map/client/mixins/mixin.activity.js +62 -68
- package/lib/map/client/mixins/mixin.activity.js.map +1 -1
- package/lib/map/client/mixins/mixin.context.js +26 -3
- package/lib/map/client/mixins/mixin.context.js.map +1 -1
- package/lib/map/client/mixins/mixin.feature-selection.js +8 -10
- package/lib/map/client/mixins/mixin.feature-selection.js.map +1 -1
- package/lib/map/client/mixins/mixin.feature-service.js +9 -7
- package/lib/map/client/mixins/mixin.feature-service.js.map +1 -1
- package/lib/map/client/mixins/mixin.infobox.js +4 -0
- package/lib/map/client/mixins/mixin.infobox.js.map +1 -1
- package/lib/map/client/mixins/mixin.weacast.js +6 -4
- package/lib/map/client/mixins/mixin.weacast.js.map +1 -1
- package/lib/map/client/pixi-utils.js +9 -0
- package/lib/map/client/pixi-utils.js.map +1 -1
- package/lib/map/client/readers/index.js +42 -0
- package/lib/map/client/readers/index.js.map +1 -0
- package/lib/map/client/readers/reader.geojson.js +59 -0
- package/lib/map/client/readers/reader.geojson.js.map +1 -0
- package/lib/map/client/readers/reader.gpx.js +41 -0
- package/lib/map/client/readers/reader.gpx.js.map +1 -0
- package/lib/map/client/readers/reader.kml.js +41 -0
- package/lib/map/client/readers/reader.kml.js.map +1 -0
- package/lib/map/client/utils.js +52 -1
- package/lib/map/client/utils.js.map +1 -1
- package/lib/map/common/wfs-utils.js +1 -1
- package/lib/map/common/wfs-utils.js.map +1 -1
- package/lib/map/common/wmts-utils.js +31 -7
- package/lib/map/common/wmts-utils.js.map +1 -1
- package/lib/test/client/core/account.js +100 -0
- package/lib/test/client/core/account.js.map +1 -0
- package/lib/test/client/core/api.js +400 -0
- package/lib/test/client/core/api.js.map +1 -0
- package/lib/test/client/core/collection.js +109 -0
- package/lib/test/client/core/collection.js.map +1 -0
- package/lib/test/client/core/index.js +90 -0
- package/lib/test/client/core/index.js.map +1 -0
- package/lib/test/client/core/layout.js +221 -0
- package/lib/test/client/core/layout.js.map +1 -0
- package/lib/test/client/core/runner.js +203 -0
- package/lib/test/client/core/runner.js.map +1 -0
- package/lib/test/client/core/screens.js +68 -0
- package/lib/test/client/core/screens.js.map +1 -0
- package/lib/test/client/core/utils.js +304 -0
- package/lib/test/client/core/utils.js.map +1 -0
- package/lib/test/client/index.js +20 -0
- package/lib/test/client/index.js.map +1 -0
- package/lib/test/client/map/catalog.js +192 -0
- package/lib/test/client/map/catalog.js.map +1 -0
- package/lib/test/client/map/controls.js +54 -0
- package/lib/test/client/map/controls.js.map +1 -0
- package/lib/test/client/map/index.js +30 -0
- package/lib/test/client/map/index.js.map +1 -0
- package/package.json +18 -9
- package/test.client.js +1 -0
- package/tests/core/test-log-2021-09-02.log +47 -0
- package/tests/map/test-log-%DATE%.logYYYY-09-DD +6 -0
- package/tests/map/test-log-2021-09-02.log +3 -0
- package/.nyc_output/5baea3f8-cf8e-4c76-8ccf-0e48b6f16fa4.json +0 -1
- package/.nyc_output/dddde6b5-9024-4b0e-8d8b-4502d437b8a4.json +0 -1
- package/.nyc_output/ef5e94ba-9a99-4fb6-ab1d-1a974112bb83.json +0 -1
- package/.nyc_output/fd4681f8-5f41-4f17-b393-9f399b24c128.json +0 -1
- package/.nyc_output/processinfo/0d403586-0c7c-4336-94d1-a49e9f02a905.json +0 -1
- package/.nyc_output/processinfo/21dd57bd-48c5-41c8-8800-252db32a9366.json +0 -1
- package/.nyc_output/processinfo/3eb3a2ca-53c2-4551-ba6b-adf70f9a53cd.json +0 -1
- package/.nyc_output/processinfo/5baea3f8-cf8e-4c76-8ccf-0e48b6f16fa4.json +0 -1
- package/.nyc_output/processinfo/dddde6b5-9024-4b0e-8d8b-4502d437b8a4.json +0 -1
- package/.nyc_output/processinfo/ef5e94ba-9a99-4fb6-ab1d-1a974112bb83.json +0 -1
- package/.nyc_output/processinfo/fd4681f8-5f41-4f17-b393-9f399b24c128.json +0 -1
- package/extras/testcafe/Dockerfile +0 -48
- package/extras/testcafe/docker-entrypoint.sh +0 -27
- package/extras/testcafe/page-models/core/account.js +0 -75
- package/extras/testcafe/page-models/core/base-collection.js +0 -41
- package/extras/testcafe/page-models/core/base-page.js +0 -25
- package/extras/testcafe/page-models/core/groups.js +0 -36
- package/extras/testcafe/page-models/core/index.js +0 -140
- package/extras/testcafe/page-models/core/layout.js +0 -145
- package/extras/testcafe/page-models/core/members.js +0 -98
- package/extras/testcafe/page-models/core/organisations.js +0 -76
- package/extras/testcafe/page-models/core/screens.js +0 -99
- package/extras/testcafe/page-models/core/tags.js +0 -21
- package/extras/testcafe/page-models/map/add-layer.js +0 -51
- package/extras/testcafe/page-models/map/catalog.js +0 -132
- package/extras/testcafe/page-models/map/index.js +0 -36
- package/extras/testcafe/page-models/map/map-activity.js +0 -42
- package/extras/testcafe/page-models/map/timeline.js +0 -67
- package/lib/core/client/components/frame/KLabel.vue +0 -56
- package/lib/core/client/components/team/KTagsPane.vue +0 -35
- package/lib/map/client/leaflet/TiledMapillaryLayer.js +0 -137
- package/lib/map/client/leaflet/TiledMapillaryLayer.js.map +0 -1
- package/lib/map/client/mixins/mixin.time.js +0 -73
- package/lib/map/client/mixins/mixin.time.js.map +0 -1
- package/tests/core/account.test.js +0 -423
- package/tests/core/client.test.js.skip +0 -37
- package/tests/core/config/default.js +0 -96
- package/tests/core/config/email-templates/confirmInvitation/html.ejs +0 -18
- package/tests/core/config/email-templates/identityChange/html.ejs +0 -12
- package/tests/core/config/email-templates/newDevice/html.ejs +0 -7
- package/tests/core/config/email-templates/passwordChange/html.ejs +0 -5
- package/tests/core/config/email-templates/resendVerifySignup/html.ejs +0 -10
- package/tests/core/config/email-templates/resetPwd/html.ejs +0 -5
- package/tests/core/config/email-templates/sendResetPwd/html.ejs +0 -8
- package/tests/core/config/email-templates/verifySignup/html.ejs +0 -3
- package/tests/core/data/10k_most_common_passwords.txt +0 -10000
- package/tests/core/data/logo.png +0 -0
- package/tests/core/hooks.test.js +0 -175
- package/tests/core/index.test.js +0 -432
- package/tests/core/notifications.test.js +0 -465
- package/tests/core/storage.test.js +0 -134
- package/tests/core/team.test.js +0 -610
- package/tests/core/utils.js +0 -62
- package/tests/map/alerts.test.js +0 -554
- package/tests/map/config/default.js +0 -112
- package/tests/map/config/layers.json +0 -37
- package/tests/map/daptiles.test.js +0 -41
- package/tests/map/data/DescribeCoverage.xml +0 -55
- package/tests/map/data/GetCoverage.tif +0 -0
- package/tests/map/data/adsb.observations.json +0 -132
- package/tests/map/data/dataset.grb.das +0 -55
- package/tests/map/data/dataset.grb.dds +0 -17
- package/tests/map/data/dataset.grb.dods +0 -0
- package/tests/map/data/lat_lon_bounds.grb.dods +0 -0
- package/tests/map/data/subdataset.grb.dods +0 -0
- package/tests/map/data/vigicrues.observations.json +0 -47042
- package/tests/map/data/vigicrues.stations.json +0 -15422
- package/tests/map/data/zones.json +0 -1228
- package/tests/map/forecast-data/gfs-world/u-wind/2021-07-15_12-00-00_2021-07-15_12-00-00.grib +0 -0
- package/tests/map/forecast-data/gfs-world/v-wind/2021-07-15_12-00-00_2021-07-15_12-00-00.grib +0 -0
- package/tests/map/grid-sources.test.js +0 -304
- package/tests/map/hooks.test.js +0 -96
- package/tests/map/index.test.js +0 -333
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../core/client/mixins/mixin.base-field.js"],"names":["baseFieldMixin","props","values","type","Object","default","properties","required","Boolean","
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/mixins/mixin.base-field.js"],"names":["baseFieldMixin","props","values","type","Object","default","properties","required","Boolean","readOnly","computed","label","_","get","field","$i18n","i18next","exists","$t","helper","hasError","isEmpty","error","errorLabel","disabled","data","model","emptyModel","watch","updateValue","name","clear","methods","value","isNil","fill","isEqual","validate","invalidate","onChanged","$nextTick","$emit","apply","object","set","submitted","created"],"mappings":"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","file":"mixin.base-field.js","sourcesContent":["import _ from 'lodash'\r\n\r\nconst baseFieldMixin = {\r\n props: {\r\n values: {\r\n type: Object,\r\n default: () => { return null }\r\n },\r\n properties: {\r\n type: Object,\r\n required: true\r\n },\r\n required: {\r\n type: Boolean,\r\n default: false\r\n },\r\n readOnly: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n computed: {\r\n label () {\r\n // Check if we have a translation key or directly the label content\r\n const label = _.get(this.properties.field, 'label', '')\r\n return (this.$i18n.i18next.exists(label) ? this.$t(label) : label)\r\n },\r\n helper () {\r\n // Check if we have a translation key or directly the helper content\r\n const helper = _.get(this.properties.field, 'helper', '')\r\n return (this.$i18n.i18next.exists(helper) ? this.$t(helper) : helper)\r\n },\r\n hasError () {\r\n return !_.isEmpty(this.error)\r\n },\r\n errorLabel () {\r\n // Check for overriden error label\r\n let error = _.get(this.properties.field, 'errorLabel', '')\r\n // If not use default validator error messages\r\n if (!error) error = this.error\r\n // Else check if we have a translation key or directly the error content\r\n return (this.$i18n.i18next.exists(error) ? this.$t(error) : error)\r\n },\r\n disabled () {\r\n return _.get(this.properties.field, 'disabled', false)\r\n }\r\n },\r\n data () {\r\n return {\r\n // The model to used for data binding with the field\r\n model: this.emptyModel(),\r\n // The error message\r\n error: ''\r\n }\r\n },\r\n watch: {\r\n values: function () {\r\n if (this.values) this.updateValue(_.get(this.values, this.properties.name))\r\n else this.clear()\r\n }\r\n },\r\n methods: {\r\n updateValue (value) {\r\n if (_.isNil(value)) this.clear()\r\n else this.fill(value)\r\n },\r\n emptyModel () {\r\n return ''\r\n },\r\n isEmpty () {\r\n return _.isEqual(this.model, this.emptyModel())\r\n },\r\n value () {\r\n return this.model\r\n },\r\n fill (value) {\r\n this.model = value\r\n this.error = ''\r\n },\r\n clear () {\r\n this.fill(_.get(this.properties, 'default', this.emptyModel()))\r\n },\r\n validate () {\r\n this.error = ''\r\n },\r\n invalidate (error) {\r\n this.error = error\r\n },\r\n async onChanged () {\r\n // Tell the form that this field has a new value.\r\n // Consequently the form will validate or invalidate the field\r\n // Warning: This method must be called once the form is mounted\r\n // We need to force a refresh so that the model is correctly updated by Vuejs\r\n await this.$nextTick()\r\n this.$emit('field-changed', this.properties.name, this.model)\r\n },\r\n apply (object, field) {\r\n // To be overloaded if you need to perform specific operations before the form has been submitted\r\n // By default simply set the current value on the given object field to apply the form\r\n _.set(object, field, this.value())\r\n },\r\n submitted (object, field) {\r\n // To be overloaded if you need to perform specific operations after the form has been submitted\r\n }\r\n },\r\n created () {\r\n if (this.values) this.updateValue(_.get(this.values, this.properties.name))\r\n }\r\n}\r\n\r\nexport default baseFieldMixin\r\n"]}
|
|
@@ -60,19 +60,13 @@ exports.default = {
|
|
|
60
60
|
},
|
|
61
61
|
computed: {
|
|
62
62
|
name() {
|
|
63
|
-
return this.
|
|
63
|
+
return _lodash2.default.get(this.item, this.options.nameField || 'name', '');
|
|
64
64
|
},
|
|
65
65
|
description() {
|
|
66
|
-
return this.
|
|
66
|
+
return _lodash2.default.get(this.item, this.options.descriptionField || 'description', '');
|
|
67
67
|
}
|
|
68
68
|
},
|
|
69
69
|
methods: {
|
|
70
|
-
getName() {
|
|
71
|
-
return _lodash2.default.get(this.item, this.options.nameField || 'name', '');
|
|
72
|
-
},
|
|
73
|
-
getDescription() {
|
|
74
|
-
return _lodash2.default.get(this.item, this.options.descriptionField || 'description', '');
|
|
75
|
-
},
|
|
76
70
|
setActions(actions) {
|
|
77
71
|
// As context is different for each item we need to clone the global action configuration
|
|
78
72
|
// otheriwse context will always reference the last processed item
|
|
@@ -90,21 +84,42 @@ exports.default = {
|
|
|
90
84
|
const actions = this.filteredActions();
|
|
91
85
|
if (actions && actions.length > 0) this.setActions(actions);else this.clearActions();
|
|
92
86
|
},
|
|
87
|
+
onItemToggled(toggled) {
|
|
88
|
+
this.$emit('item-toggled', this.item, toggled);
|
|
89
|
+
},
|
|
93
90
|
onItemSelected(section) {
|
|
94
91
|
this.$emit('item-selected', this.item, section);
|
|
95
92
|
},
|
|
93
|
+
canViewItem() {
|
|
94
|
+
return this.$can('read', this.service, this.contextId, this.item);
|
|
95
|
+
},
|
|
96
96
|
viewItem() {
|
|
97
97
|
const path = this.$route.fullPath + `/view/${this.item._id}`;
|
|
98
98
|
this.$router.push(path);
|
|
99
99
|
},
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
100
|
+
canEditItem() {
|
|
101
|
+
return this.$can('update', this.service, this.contextId, this.item);
|
|
102
|
+
},
|
|
103
|
+
editItem(scope = undefined, properties = undefined) {
|
|
104
|
+
const route = this.$route;
|
|
105
|
+
let subPath = 'edit/' + this.item._id;
|
|
106
|
+
// Add trailing / if required (as sometimes it might be already present)
|
|
107
|
+
if (!route.path.endsWith('/')) subPath = `/${subPath}`;
|
|
108
|
+
if (scope) {
|
|
109
|
+
if (properties) subPath += `/${properties}`;else subPath += `/${scope}`;
|
|
110
|
+
}
|
|
111
|
+
this.$router.push({
|
|
112
|
+
path: route.path + subPath,
|
|
113
|
+
params: route.params,
|
|
114
|
+
query: route.query
|
|
115
|
+
});
|
|
116
|
+
},
|
|
117
|
+
canRemoveItem() {
|
|
118
|
+
return this.$can('remove', this.service, this.contextId, this.item);
|
|
103
119
|
},
|
|
104
120
|
removeItem(prompt) {
|
|
105
|
-
if (!['none', 'confirm', 'input'].includes(prompt)) return;
|
|
106
121
|
if (prompt === 'confirm' || prompt === 'input') {
|
|
107
|
-
const name = this.
|
|
122
|
+
const name = this.name;
|
|
108
123
|
const input = {
|
|
109
124
|
type: 'text',
|
|
110
125
|
model: '',
|
|
@@ -132,7 +147,7 @@ exports.default = {
|
|
|
132
147
|
}
|
|
133
148
|
},
|
|
134
149
|
exportItem() {
|
|
135
|
-
const name = this.
|
|
150
|
+
const name = this.name;
|
|
136
151
|
const file = name + '.json';
|
|
137
152
|
if ((0, _quasar.exportFile)(file, JSON.stringify(this.item))) {
|
|
138
153
|
this.$toast({ type: 'error', message: this.$t('mixins.baseItem.ITEM_EXPORTED', { name, file }) });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../core/client/mixins/mixin.base-item.js"],"names":["props","contextId","type","String","default","service","required","item","Object","actions","Array","filter","options","bindActions","Boolean","watch","configureActions","data","itemActions","computed","name","
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/mixins/mixin.base-item.js"],"names":["props","contextId","type","String","default","service","required","item","Object","actions","Array","filter","options","bindActions","Boolean","watch","configureActions","data","itemActions","computed","name","_","get","nameField","description","descriptionField","methods","setActions","Layout","bindContent","cloneDeep","clearActions","filteredActions","filterContent","length","onItemToggled","toggled","$emit","onItemSelected","section","canViewItem","$can","viewItem","path","$route","fullPath","_id","$router","push","canEditItem","editItem","scope","undefined","properties","route","subPath","endsWith","params","query","canRemoveItem","removeItem","prompt","input","model","isValid","val","Dialog","create","title","$t","message","html","persistent","ok","label","flat","cancel","onOk","$api","getService","remove","exportItem","file","JSON","stringify","$toast","created","$events","$on","beforeDestroy","$off"],"mappings":"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","file":"mixin.base-item.js","sourcesContent":["import _ from 'lodash'\r\nimport { Dialog, exportFile } from 'quasar'\r\nimport { Layout } from '../layout'\r\n\r\nexport default {\r\n props: {\r\n contextId: {\r\n type: String,\r\n default: ''\r\n },\r\n service: {\r\n type: String,\r\n required: true\r\n },\r\n item: {\r\n type: Object,\r\n required: true\r\n },\r\n actions: {\r\n type: [Object, Array],\r\n default: () => null\r\n },\r\n filter: {\r\n type: Object,\r\n default: () => {}\r\n },\r\n options: {\r\n type: Object,\r\n default: function () {\r\n return {}\r\n }\r\n },\r\n bindActions: {\r\n type: Boolean,\r\n default: true\r\n }\r\n },\r\n watch: {\r\n actions: function () {\r\n // Make configured actions reactive as item actions are built from\r\n this.configureActions()\r\n }\r\n },\r\n data () {\r\n return {\r\n itemActions: null\r\n }\r\n },\r\n computed: {\r\n name () {\r\n return _.get(this.item, this.options.nameField || 'name', '')\r\n },\r\n description () {\r\n return _.get(this.item, this.options.descriptionField || 'description', '')\r\n }\r\n },\r\n methods: {\r\n setActions (actions) {\r\n // As context is different for each item we need to clone the global action configuration\r\n // otheriwse context will always reference the last processed item\r\n this.itemActions = (this.bindActions ? Layout.bindContent(_.cloneDeep(actions), this) : actions)\r\n },\r\n clearActions () {\r\n this.itemActions = null\r\n },\r\n filteredActions () {\r\n return (this.actions ? Layout.filterContent(this.actions, this.filter || {}) : [])\r\n },\r\n // This method should be overriden in items\r\n configureActions () {\r\n // Apply filtering\r\n const actions = this.filteredActions()\r\n if (actions && actions.length > 0) this.setActions(actions)\r\n else this.clearActions()\r\n },\r\n onItemToggled (toggled) {\r\n this.$emit('item-toggled', this.item, toggled)\r\n },\r\n onItemSelected (section) {\r\n this.$emit('item-selected', this.item, section)\r\n },\r\n canViewItem () {\r\n return this.$can('read', this.service, this.contextId, this.item)\r\n },\r\n viewItem () {\r\n const path = this.$route.fullPath + `/view/${this.item._id}`\r\n this.$router.push(path)\r\n },\r\n canEditItem () {\r\n return this.$can('update', this.service, this.contextId, this.item)\r\n },\r\n editItem (scope = undefined, properties = undefined) {\r\n const route = this.$route\r\n let subPath = 'edit/' + this.item._id\r\n // Add trailing / if required (as sometimes it might be already present)\r\n if (!route.path.endsWith('/')) subPath = `/${subPath}`\r\n if (scope) {\r\n if (properties) subPath += `/${properties}`\r\n else subPath += `/${scope}`\r\n }\r\n this.$router.push({\r\n path: route.path + subPath,\r\n params: route.params,\r\n query: route.query\r\n })\r\n },\r\n canRemoveItem () {\r\n return this.$can('remove', this.service, this.contextId, this.item)\r\n },\r\n removeItem (prompt) {\r\n if (prompt === 'confirm' || prompt === 'input') {\r\n const name = this.name\r\n const input = {\r\n type: 'text',\r\n model: '',\r\n isValid: val => val === name\r\n }\r\n Dialog.create({\r\n title: this.$t('mixins.baseItem.REMOVE_ITEM_TITLE', { name }),\r\n message: prompt === 'input' ? this.$t('mixins.baseItem.REMOVE_ITEM_MESSAGE') : '',\r\n html: true,\r\n prompt: prompt === 'input' ? input : undefined,\r\n persistent: true,\r\n ok: {\r\n label: this.$t('OK'),\r\n flat: true\r\n },\r\n cancel: {\r\n label: this.$t('CANCEL'),\r\n flat: true\r\n }\r\n }).onOk(() => {\r\n this.$api.getService(this.service).remove(this.item._id)\r\n })\r\n } else {\r\n this.$api.getService(this.service).remove(this.item._id)\r\n }\r\n },\r\n exportItem () {\r\n const name = this.name\r\n const file = name + '.json'\r\n if (exportFile(file, JSON.stringify(this.item))) {\r\n this.$toast({ type: 'error', message: this.$t('mixins.baseItem.ITEM_EXPORTED', { name, file }) })\r\n } else {\r\n this.$toast({ type: 'error', message: this.$t('mixins.baseItme.CANNOT_EXPORT_ITEM') })\r\n }\r\n }\r\n },\r\n created () {\r\n // Register the actions\r\n this.configureActions()\r\n // Whenever the user abilities are updated, update actions as well\r\n this.$events.$on('user-abilities-changed', this.configureActions)\r\n },\r\n beforeDestroy () {\r\n this.$events.$off('user-abilities-changed', this.configureActions)\r\n }\r\n}\r\n"]}
|
|
@@ -30,8 +30,6 @@ const baseViewerMixin = {
|
|
|
30
30
|
var _this = this;
|
|
31
31
|
|
|
32
32
|
return _asyncToGenerator(function* () {
|
|
33
|
-
// When the service is available
|
|
34
|
-
yield _this.loadService();
|
|
35
33
|
// We can then load the schema/object and local refs in parallel
|
|
36
34
|
yield Promise.all([_this.loadSchema(_this.getSchemaName()), _this.loadObject()]);
|
|
37
35
|
})();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../core/client/mixins/mixin.base-viewer.js"],"names":["baseViewerMixin","computed","viewerTitle","getSchema","schemaTitle","title","$t","object","getObject","methods","getSchemaName","schemaName","service","perspective","refresh","
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/mixins/mixin.base-viewer.js"],"names":["baseViewerMixin","computed","viewerTitle","getSchema","schemaTitle","title","$t","object","getObject","methods","getSchemaName","schemaName","service","perspective","refresh","Promise","all","loadSchema","loadObject"],"mappings":";;;;;;;;AAAA,MAAMA,kBAAkB;AACtBC,YAAU;AACRC,kBAAe;AACb;AACA,UAAI,KAAKC,SAAL,EAAJ,EAAsB;AACpB,cAAMC,cAAc,KAAKD,SAAL,GAAiBE,KAArC;AACA,eAAO,KAAKC,EAAL,CAAQF,WAAR,EAAqB,EAAEG,QAAQ,KAAKC,SAAL,EAAV,EAArB,CAAP;AACD;AACD,aAAO,EAAP;AACD;AARO,GADY;AAWtBC,WAAS;AACPC,oBAAiB;AACf;AACA,UAAIC,aAAa,KAAKC,OAAL,GAAe,MAAhC;AACA,UAAI,KAAKC,WAAT,EAAsB;AACpBF,sBAAe,MAAM,KAAKE,WAA1B;AACD;AACD,aAAOF,UAAP;AACD,KARM;AASDG,WAAN,GAAiB;AAAA;;AAAA;AACf;AACA,cAAMC,QAAQC,GAAR,CAAY,CAChB,MAAKC,UAAL,CAAgB,MAAKP,aAAL,EAAhB,CADgB,EAEhB,MAAKQ,UAAL,EAFgB,CAAZ,CAAN;AAFe;AAMhB;AAfM;AAXa,CAAxB;;kBA8BelB,e","file":"mixin.base-viewer.js","sourcesContent":["const baseViewerMixin = {\r\n computed: {\r\n viewerTitle () {\r\n // Retuns the schema title\r\n if (this.getSchema()) {\r\n const schemaTitle = this.getSchema().title\r\n return this.$t(schemaTitle, { object: this.getObject() })\r\n }\r\n return ''\r\n }\r\n },\r\n methods: {\r\n getSchemaName () {\r\n // When used with a service by default use the same name for schema as for service\r\n let schemaName = this.service + '.get'\r\n if (this.perspective) {\r\n schemaName += ('-' + this.perspective)\r\n }\r\n return schemaName\r\n },\r\n async refresh () {\r\n // We can then load the schema/object and local refs in parallel\r\n await Promise.all([\r\n this.loadSchema(this.getSchemaName()),\r\n this.loadObject()\r\n ])\r\n }\r\n }\r\n}\r\n\r\nexport default baseViewerMixin\r\n"]}
|
|
@@ -4,8 +4,14 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
|
|
7
|
+
var _lodash = require('lodash');
|
|
8
|
+
|
|
9
|
+
var _lodash2 = _interopRequireDefault(_lodash);
|
|
10
|
+
|
|
7
11
|
var _utils = require('../utils');
|
|
8
12
|
|
|
13
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
14
|
+
|
|
9
15
|
const objectProxyMixin = {
|
|
10
16
|
props: {
|
|
11
17
|
objectId: {
|
|
@@ -15,6 +21,14 @@ const objectProxyMixin = {
|
|
|
15
21
|
perspective: {
|
|
16
22
|
type: String,
|
|
17
23
|
default: ''
|
|
24
|
+
},
|
|
25
|
+
// Indicates if the stored object in-memory is only the perspective part (default)
|
|
26
|
+
// or the full structure, ie { perspective: { xxx = } }
|
|
27
|
+
// Note: the full structure is always retrieved/sent from/to the service anyway but sometimes
|
|
28
|
+
// it is easier to manipulate a full-object and edit a nested property seen as a perspective on the front side
|
|
29
|
+
perspectiveAsObject: {
|
|
30
|
+
type: Boolean,
|
|
31
|
+
default: true
|
|
18
32
|
}
|
|
19
33
|
},
|
|
20
34
|
data() {
|
|
@@ -30,7 +44,7 @@ const objectProxyMixin = {
|
|
|
30
44
|
return this.object ? this.object._id : '';
|
|
31
45
|
},
|
|
32
46
|
hasPerspective(perspective) {
|
|
33
|
-
return this.object ? this.object
|
|
47
|
+
return this.object ? _lodash2.default.has(this.object, perspective) : false;
|
|
34
48
|
},
|
|
35
49
|
loadObject() {
|
|
36
50
|
if (!this.objectId) {
|
|
@@ -42,10 +56,10 @@ const objectProxyMixin = {
|
|
|
42
56
|
if (!this.objectPromise || objectChanged) {
|
|
43
57
|
this.objectPromise = (0, _utils.createQuerablePromise)((resolve, reject) => {
|
|
44
58
|
let params = {};
|
|
45
|
-
if (this.perspective) {
|
|
59
|
+
if (this.perspective && this.perspectiveAsObject) {
|
|
46
60
|
params = { query: { $select: ['_id', this.perspective] } };
|
|
47
61
|
}
|
|
48
|
-
this.
|
|
62
|
+
this.getService().get(this.objectId, params).then(object => {
|
|
49
63
|
this.object = object;
|
|
50
64
|
resolve(object);
|
|
51
65
|
}).catch(error => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../core/client/mixins/mixin.object-proxy.js"],"names":["objectProxyMixin","props","objectId","type","String","default","perspective","data","object","methods","getObject","getObjectId","_id","hasPerspective","loadObject","Promise","resolve","objectChanged","objectPromise","reject","params","query","$select","
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/mixins/mixin.object-proxy.js"],"names":["objectProxyMixin","props","objectId","type","String","default","perspective","perspectiveAsObject","Boolean","data","object","methods","getObject","getObjectId","_id","hasPerspective","_","has","loadObject","Promise","resolve","objectChanged","objectPromise","reject","params","query","$select","getService","get","then","catch","error"],"mappings":";;;;;;AAAA;;;;AACA;;;;AAEA,MAAMA,mBAAmB;AACvBC,SAAO;AACLC,cAAU;AACRC,YAAMC,MADE;AAERC,eAAS;AAFD,KADL;AAKLC,iBAAa;AACXH,YAAMC,MADK;AAEXC,eAAS;AAFE,KALR;AASL;AACA;AACA;AACA;AACAE,yBAAqB;AACnBJ,YAAMK,OADa;AAEnBH,eAAS;AAFU;AAbhB,GADgB;AAmBvBI,SAAQ;AACN,WAAO;AACLC,cAAQ;AADH,KAAP;AAGD,GAvBsB;AAwBvBC,WAAS;AACPC,gBAAa;AACX,aAAO,KAAKF,MAAZ;AACD,KAHM;AAIPG,kBAAe;AACb,aAAO,KAAKH,MAAL,GAAc,KAAKA,MAAL,CAAYI,GAA1B,GAAgC,EAAvC;AACD,KANM;AAOPC,mBAAgBT,WAAhB,EAA6B;AAC3B,aAAO,KAAKI,MAAL,GAAcM,iBAAEC,GAAF,CAAM,KAAKP,MAAX,EAAmBJ,WAAnB,CAAd,GAAgD,KAAvD;AACD,KATM;AAUPY,iBAAc;AACZ,UAAI,CAAC,KAAKhB,QAAV,EAAoB;AAClB,aAAKQ,MAAL,GAAc,IAAd;AACA,eAAOS,QAAQC,OAAR,CAAgB,IAAhB,CAAP;AACD;AACD;AACA,YAAMC,gBAAiB,KAAKR,WAAL,OAAuB,KAAKX,QAA7B,IAA0C,CAAC,KAAKa,cAAL,CAAoB,KAAKT,WAAzB,CAAjE;AACA,UAAI,CAAC,KAAKgB,aAAN,IAAuBD,aAA3B,EAA0C;AACxC,aAAKC,aAAL,GAAqB,kCAAsB,CAACF,OAAD,EAAUG,MAAV,KAAqB;AAC9D,cAAIC,SAAS,EAAb;AACA,cAAI,KAAKlB,WAAL,IAAoB,KAAKC,mBAA7B,EAAkD;AAChDiB,qBAAS,EAAEC,OAAO,EAAEC,SAAS,CAAC,KAAD,EAAQ,KAAKpB,WAAb,CAAX,EAAT,EAAT;AACD;AACD,eAAKqB,UAAL,GACGC,GADH,CACO,KAAK1B,QADZ,EACsBsB,MADtB,EAEGK,IAFH,CAEQnB,UAAU;AACd,iBAAKA,MAAL,GAAcA,MAAd;AACAU,oBAAQV,MAAR;AACD,WALH,EAMGoB,KANH,CAMSC,SAAS;AACdR,mBAAOQ,KAAP;AACD,WARH;AASD,SAdoB,CAArB;AAeD;AACD,aAAO,KAAKT,aAAZ;AACD;AAnCM;AAxBc,CAAzB;;kBA+DetB,gB","file":"mixin.object-proxy.js","sourcesContent":["import _ from 'lodash'\r\nimport { createQuerablePromise } from '../utils'\r\n\r\nconst objectProxyMixin = {\r\n props: {\r\n objectId: {\r\n type: String,\r\n default: ''\r\n },\r\n perspective: {\r\n type: String,\r\n default: ''\r\n },\r\n // Indicates if the stored object in-memory is only the perspective part (default)\r\n // or the full structure, ie { perspective: { xxx = } }\r\n // Note: the full structure is always retrieved/sent from/to the service anyway but sometimes\r\n // it is easier to manipulate a full-object and edit a nested property seen as a perspective on the front side\r\n perspectiveAsObject: {\r\n type: Boolean,\r\n default: true\r\n }\r\n },\r\n data () {\r\n return {\r\n object: null\r\n }\r\n },\r\n methods: {\r\n getObject () {\r\n return this.object\r\n },\r\n getObjectId () {\r\n return this.object ? this.object._id : ''\r\n },\r\n hasPerspective (perspective) {\r\n return this.object ? _.has(this.object, perspective) : false\r\n },\r\n loadObject () {\r\n if (!this.objectId) {\r\n this.object = null\r\n return Promise.resolve(null)\r\n }\r\n // Create a new mixin promise if required\r\n const objectChanged = (this.getObjectId() !== this.objectId) || !this.hasPerspective(this.perspective)\r\n if (!this.objectPromise || objectChanged) {\r\n this.objectPromise = createQuerablePromise((resolve, reject) => {\r\n let params = {}\r\n if (this.perspective && this.perspectiveAsObject) {\r\n params = { query: { $select: ['_id', this.perspective] } }\r\n }\r\n this.getService()\r\n .get(this.objectId, params)\r\n .then(object => {\r\n this.object = object\r\n resolve(object)\r\n })\r\n .catch(error => {\r\n reject(error)\r\n })\r\n })\r\n }\r\n return this.objectPromise\r\n }\r\n }\r\n}\r\n\r\nexport default objectProxyMixin\r\n"]}
|
|
@@ -4,10 +4,16 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
|
|
7
|
+
var _lodash = require('lodash');
|
|
8
|
+
|
|
9
|
+
var _lodash2 = _interopRequireDefault(_lodash);
|
|
10
|
+
|
|
7
11
|
var _utils = require('../utils');
|
|
8
12
|
|
|
9
13
|
var _events = require('../events');
|
|
10
14
|
|
|
15
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
16
|
+
|
|
11
17
|
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
|
|
12
18
|
|
|
13
19
|
const schemaProxyMixin = {
|
|
@@ -15,6 +21,10 @@ const schemaProxyMixin = {
|
|
|
15
21
|
schemaJson: {
|
|
16
22
|
type: String,
|
|
17
23
|
default: ''
|
|
24
|
+
},
|
|
25
|
+
schemaProperties: {
|
|
26
|
+
type: [String, Array],
|
|
27
|
+
default: () => []
|
|
18
28
|
}
|
|
19
29
|
},
|
|
20
30
|
data() {
|
|
@@ -29,6 +39,22 @@ const schemaProxyMixin = {
|
|
|
29
39
|
getSchemaId() {
|
|
30
40
|
return this.schema ? this.schema.$id : '';
|
|
31
41
|
},
|
|
42
|
+
filterSchema() {
|
|
43
|
+
// We can filter properties in schema
|
|
44
|
+
const properties = this.schema.properties;
|
|
45
|
+
// Define the properties filter, could be either a joined list (eg query string) or an array
|
|
46
|
+
let propertiesFilter = typeof this.schemaProperties === 'string' ? _lodash2.default.split(this.schemaProperties, ',') : this.schemaProperties;
|
|
47
|
+
if (typeof propertiesFilter === 'string') propertiesFilter = [propertiesFilter];
|
|
48
|
+
if (propertiesFilter.length > 0) {
|
|
49
|
+
Object.keys(properties).forEach(property => {
|
|
50
|
+
if (!propertiesFilter.includes(property)) delete properties[property];
|
|
51
|
+
});
|
|
52
|
+
// Update schema ID so that a filtered schema is not similar to a complete one
|
|
53
|
+
this.schema.$id += propertiesFilter.join();
|
|
54
|
+
// Filter as well required properties
|
|
55
|
+
this.schema.required = _lodash2.default.intersection(this.schema.required, propertiesFilter);
|
|
56
|
+
}
|
|
57
|
+
},
|
|
32
58
|
loadSchemaFromResource(schemaName) {
|
|
33
59
|
var _this = this;
|
|
34
60
|
|
|
@@ -38,6 +64,9 @@ const schemaProxyMixin = {
|
|
|
38
64
|
// FIXME: not yet sure why this is now required, might be related to
|
|
39
65
|
// https://forum.vuejs.org/t/solved-using-standalone-version-but-getting-failed-to-mount-component-template-or-render-function-not-defined/19569/2
|
|
40
66
|
if (_this.schema.default) _this.schema = _this.schema.default;
|
|
67
|
+
_this.schema = _lodash2.default.cloneDeep(_this.schema);
|
|
68
|
+
// Apply filtering
|
|
69
|
+
_this.filterSchema();
|
|
41
70
|
return _this.schema;
|
|
42
71
|
} catch (error) {
|
|
43
72
|
_events.Events.$emit('error', error);
|
|
@@ -51,6 +80,8 @@ const schemaProxyMixin = {
|
|
|
51
80
|
return _asyncToGenerator(function* () {
|
|
52
81
|
try {
|
|
53
82
|
_this2.schema = JSON.parse(json);
|
|
83
|
+
// Apply filtering
|
|
84
|
+
_this2.filterSchema();
|
|
54
85
|
return _this2.schema;
|
|
55
86
|
} catch (error) {
|
|
56
87
|
_events.Events.$emit('error', error);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../core/client/mixins/mixin.schema-proxy.js"],"names":["schemaProxyMixin","props","schemaJson","type","String","default","data","schema","methods","getSchema","getSchemaId","$id","loadSchemaFromResource","schemaName","$load","error","Events","$emit","loadSchemaFromJson","json","JSON","parse","loadSchema","schemaChanged","
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/mixins/mixin.schema-proxy.js"],"names":["schemaProxyMixin","props","schemaJson","type","String","default","schemaProperties","Array","data","schema","methods","getSchema","getSchemaId","$id","filterSchema","properties","propertiesFilter","_","split","length","Object","keys","forEach","property","includes","join","required","intersection","loadSchemaFromResource","schemaName","$load","cloneDeep","error","Events","$emit","loadSchemaFromJson","json","JSON","parse","loadSchema","schemaChanged","schemaPromise"],"mappings":"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","file":"mixin.schema-proxy.js","sourcesContent":["import _ from 'lodash'\r\nimport { createQuerablePromise } from '../utils'\r\nimport { Events } from '../events'\r\n\r\nconst schemaProxyMixin = {\r\n props: {\r\n schemaJson: {\r\n type: String,\r\n default: ''\r\n },\r\n schemaProperties: {\r\n type: [String, Array],\r\n default: () => []\r\n }\r\n },\r\n data () {\r\n return {\r\n schema: null\r\n }\r\n },\r\n methods: {\r\n getSchema () {\r\n return this.schema\r\n },\r\n getSchemaId () {\r\n return this.schema ? this.schema.$id : ''\r\n },\r\n filterSchema () {\r\n // We can filter properties in schema\r\n const properties = this.schema.properties\r\n // Define the properties filter, could be either a joined list (eg query string) or an array\r\n let propertiesFilter = (typeof this.schemaProperties === 'string' ? _.split(this.schemaProperties, ',') : this.schemaProperties)\r\n if (typeof propertiesFilter === 'string') propertiesFilter = [propertiesFilter]\r\n if (propertiesFilter.length > 0) {\r\n Object.keys(properties).forEach(property => {\r\n if (!propertiesFilter.includes(property)) delete properties[property]\r\n })\r\n // Update schema ID so that a filtered schema is not similar to a complete one\r\n this.schema.$id += propertiesFilter.join()\r\n // Filter as well required properties\r\n this.schema.required = _.intersection(this.schema.required, propertiesFilter)\r\n }\r\n },\r\n async loadSchemaFromResource (schemaName) {\r\n try {\r\n this.schema = await this.$load(schemaName, 'schema')\r\n // FIXME: not yet sure why this is now required, might be related to\r\n // https://forum.vuejs.org/t/solved-using-standalone-version-but-getting-failed-to-mount-component-template-or-render-function-not-defined/19569/2\r\n if (this.schema.default) this.schema = this.schema.default\r\n this.schema = _.cloneDeep(this.schema)\r\n // Apply filtering\r\n this.filterSchema()\r\n return this.schema\r\n } catch (error) {\r\n Events.$emit('error', error)\r\n throw error\r\n }\r\n },\r\n async loadSchemaFromJson (json) {\r\n try {\r\n this.schema = JSON.parse(json)\r\n // Apply filtering\r\n this.filterSchema()\r\n return this.schema\r\n } catch (error) {\r\n Events.$emit('error', error)\r\n throw error\r\n }\r\n },\r\n loadSchema (schemaName) {\r\n // Create a new mixin promise if required\r\n // In the JSON schema file we use a $id like 'http:/www.kalisio.xyz/schemas/service.operation-perspective.json#'\r\n const schemaChanged = schemaName && !this.getSchemaId().includes(schemaName + '.json')\r\n if (!this.schemaPromise || schemaChanged) {\r\n // We need to load the schema now\r\n this.schemaPromise = createQuerablePromise(this.schemaJson\r\n ? this.loadSchemaFromJson(this.schemaJson)\r\n : this.loadSchemaFromResource(schemaName))\r\n }\r\n return this.schemaPromise\r\n }\r\n }\r\n}\r\n\r\nexport default schemaProxyMixin\r\n"]}
|
|
@@ -14,42 +14,14 @@ const serviceMixin = {
|
|
|
14
14
|
default: ''
|
|
15
15
|
}
|
|
16
16
|
},
|
|
17
|
+
|
|
17
18
|
methods: {
|
|
18
19
|
getService() {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
return this._service ? this._service.path : '';
|
|
23
|
-
},
|
|
24
|
-
loadService() {
|
|
25
|
-
// Create a new mixin promise if required
|
|
26
|
-
const path = this.$api.getServicePath(this.service, this.contextId);
|
|
27
|
-
const serviceChanged = this.getServicePath() !== path;
|
|
28
|
-
if (serviceChanged) {
|
|
29
|
-
this._service = this.$api.service(path);
|
|
30
|
-
if (!this._service) {
|
|
31
|
-
throw new Error('Cannot retrieve target service ' + this.service);
|
|
32
|
-
}
|
|
20
|
+
const service = this.$api.getService(this.service, this.contextId);
|
|
21
|
+
if (!service) {
|
|
22
|
+
throw new Error('Cannot retrieve target service ' + this.service);
|
|
33
23
|
}
|
|
34
|
-
return
|
|
35
|
-
},
|
|
36
|
-
serviceFind(params) {
|
|
37
|
-
return this._service.find(params);
|
|
38
|
-
},
|
|
39
|
-
serviceGet(id, params) {
|
|
40
|
-
return this._service.get(id, params);
|
|
41
|
-
},
|
|
42
|
-
serviceCreate(data, params) {
|
|
43
|
-
return this._service.create(data, params);
|
|
44
|
-
},
|
|
45
|
-
serviceUpdate(id, data, params) {
|
|
46
|
-
return this._service.update(id, data, params);
|
|
47
|
-
},
|
|
48
|
-
servicePatch(id, data, params) {
|
|
49
|
-
return this._service.patch(id, data, params);
|
|
50
|
-
},
|
|
51
|
-
serviceRemove(id, params) {
|
|
52
|
-
return this._service.remove(id, params);
|
|
24
|
+
return service;
|
|
53
25
|
}
|
|
54
26
|
}
|
|
55
27
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../core/client/mixins/mixin.service.js"],"names":["serviceMixin","props","contextId","type","String","default","undefined","service","methods","getService","
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/mixins/mixin.service.js"],"names":["serviceMixin","props","contextId","type","String","default","undefined","service","methods","getService","$api","Error"],"mappings":";;;;;AAAA,MAAMA,eAAe;AACnBC,SAAO;AACLC,eAAW;AACTC,YAAMC,MADG;AAETC,eAASC;AAFA,KADN;AAKLC,aAAS;AACPJ,YAAMC,MADC;AAEPC,eAAS;AAFF;AALJ,GADY;;AAYnBG,WAAS;AACPC,iBAAc;AACZ,YAAMF,UAAU,KAAKG,IAAL,CAAUD,UAAV,CAAqB,KAAKF,OAA1B,EAAmC,KAAKL,SAAxC,CAAhB;AACA,UAAI,CAACK,OAAL,EAAc;AACZ,cAAM,IAAII,KAAJ,CAAU,oCAAoC,KAAKJ,OAAnD,CAAN;AACD;AACD,aAAOA,OAAP;AACD;AAPM;AAZU,CAArB;;kBAuBeP,Y","file":"mixin.service.js","sourcesContent":["const serviceMixin = {\r\n props: {\r\n contextId: {\r\n type: String,\r\n default: undefined\r\n },\r\n service: {\r\n type: String,\r\n default: ''\r\n }\r\n },\r\n\r\n methods: {\r\n getService () {\r\n const service = this.$api.getService(this.service, this.contextId)\r\n if (!service) {\r\n throw new Error('Cannot retrieve target service ' + this.service)\r\n }\r\n return service\r\n }\r\n }\r\n}\r\n\r\nexport default serviceMixin\r\n"]}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Reader = undefined;
|
|
7
|
+
|
|
8
|
+
var _path = require('path');
|
|
9
|
+
|
|
10
|
+
var _path2 = _interopRequireDefault(_path);
|
|
11
|
+
|
|
12
|
+
var _i18next = require('i18next');
|
|
13
|
+
|
|
14
|
+
var _i18next2 = _interopRequireDefault(_i18next);
|
|
15
|
+
|
|
16
|
+
var _events = require('./events');
|
|
17
|
+
|
|
18
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
19
|
+
|
|
20
|
+
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
|
|
21
|
+
|
|
22
|
+
// Export singleton
|
|
23
|
+
const Reader = exports.Reader = {
|
|
24
|
+
readers: {},
|
|
25
|
+
register(mimeType, reader) {
|
|
26
|
+
this.readers[mimeType] = reader;
|
|
27
|
+
},
|
|
28
|
+
read(file, options) {
|
|
29
|
+
var _this = this;
|
|
30
|
+
|
|
31
|
+
return _asyncToGenerator(function* () {
|
|
32
|
+
const fileExtension = _path2.default.extname(file.name);
|
|
33
|
+
const reader = _this.readers[fileExtension];
|
|
34
|
+
if (reader) {
|
|
35
|
+
try {
|
|
36
|
+
const content = yield reader(file, options);
|
|
37
|
+
return content;
|
|
38
|
+
} catch (error) {
|
|
39
|
+
_events.Events.$emit('error', error);
|
|
40
|
+
throw error;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
const error = {
|
|
44
|
+
message: _i18next2.default.t('errors.UNSUPPORTED_FILE_FORMAT', { file: file.name })
|
|
45
|
+
};
|
|
46
|
+
_events.Events.$emit('error', error);
|
|
47
|
+
throw new Error(error);
|
|
48
|
+
})();
|
|
49
|
+
},
|
|
50
|
+
getSupportedFormats() {
|
|
51
|
+
return Object.keys(this.readers);
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
//# sourceMappingURL=reader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../core/client/reader.js"],"names":["Reader","readers","register","mimeType","reader","read","file","options","fileExtension","path","extname","name","content","error","Events","$emit","message","i18next","t","Error","getSupportedFormats","Object","keys"],"mappings":";;;;;;;AAAA;;;;AACA;;;;AACA;;;;;;AAEA;AACO,MAAMA,0BAAS;AACpBC,WAAS,EADW;AAEpBC,WAAUC,QAAV,EAAoBC,MAApB,EAA4B;AAC1B,SAAKH,OAAL,CAAaE,QAAb,IAAyBC,MAAzB;AACD,GAJmB;AAKdC,MAAN,CAAYC,IAAZ,EAAkBC,OAAlB,EAA2B;AAAA;;AAAA;AACzB,YAAMC,gBAAgBC,eAAKC,OAAL,CAAaJ,KAAKK,IAAlB,CAAtB;AACA,YAAMP,SAAS,MAAKH,OAAL,CAAaO,aAAb,CAAf;AACA,UAAIJ,MAAJ,EAAY;AACV,YAAI;AACF,gBAAMQ,UAAU,MAAMR,OAAOE,IAAP,EAAaC,OAAb,CAAtB;AACA,iBAAOK,OAAP;AACD,SAHD,CAGE,OAAOC,KAAP,EAAc;AACdC,yBAAOC,KAAP,CAAa,OAAb,EAAsBF,KAAtB;AACA,gBAAMA,KAAN;AACD;AACF;AACD,YAAMA,QAAQ;AACZG,iBAASC,kBAAQC,CAAR,CAAU,gCAAV,EAA4C,EAAEZ,MAAMA,KAAKK,IAAb,EAA5C;AADG,OAAd;AAGAG,qBAAOC,KAAP,CAAa,OAAb,EAAsBF,KAAtB;AACA,YAAM,IAAIM,KAAJ,CAAUN,KAAV,CAAN;AAhByB;AAiB1B,GAtBmB;AAuBpBO,wBAAuB;AACrB,WAAOC,OAAOC,IAAP,CAAY,KAAKrB,OAAjB,CAAP;AACD;AAzBmB,CAAf","file":"reader.js","sourcesContent":["import path from 'path'\r\nimport i18next from 'i18next'\r\nimport { Events } from './events'\r\n\r\n// Export singleton\r\nexport const Reader = {\r\n readers: {},\r\n register (mimeType, reader) {\r\n this.readers[mimeType] = reader\r\n },\r\n async read (file, options) {\r\n const fileExtension = path.extname(file.name)\r\n const reader = this.readers[fileExtension]\r\n if (reader) {\r\n try {\r\n const content = await reader(file, options)\r\n return content\r\n } catch (error) {\r\n Events.$emit('error', error)\r\n throw error\r\n }\r\n }\r\n const error = {\r\n message: i18next.t('errors.UNSUPPORTED_FILE_FORMAT', { file: file.name })\r\n }\r\n Events.$emit('error', error)\r\n throw new Error(error)\r\n },\r\n getSupportedFormats () {\r\n return Object.keys(this.readers)\r\n }\r\n}\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
|
|
7
|
+
var _reader = require('./reader.json');
|
|
8
|
+
|
|
9
|
+
Object.keys(_reader).forEach(function (key) {
|
|
10
|
+
if (key === "default" || key === "__esModule") return;
|
|
11
|
+
Object.defineProperty(exports, key, {
|
|
12
|
+
enumerable: true,
|
|
13
|
+
get: function () {
|
|
14
|
+
return _reader[key];
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
var _reader2 = require('./reader.csv');
|
|
20
|
+
|
|
21
|
+
Object.keys(_reader2).forEach(function (key) {
|
|
22
|
+
if (key === "default" || key === "__esModule") return;
|
|
23
|
+
Object.defineProperty(exports, key, {
|
|
24
|
+
enumerable: true,
|
|
25
|
+
get: function () {
|
|
26
|
+
return _reader2[key];
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/readers/index.js"],"names":[],"mappings":";;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","file":"index.js","sourcesContent":["export * from './reader.json'\r\nexport * from './reader.csv'\r\n"]}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.readCSV = readCSV;
|
|
7
|
+
|
|
8
|
+
var _loglevel = require('loglevel');
|
|
9
|
+
|
|
10
|
+
var _loglevel2 = _interopRequireDefault(_loglevel);
|
|
11
|
+
|
|
12
|
+
var _i18next = require('i18next');
|
|
13
|
+
|
|
14
|
+
var _i18next2 = _interopRequireDefault(_i18next);
|
|
15
|
+
|
|
16
|
+
var _papaparse = require('papaparse');
|
|
17
|
+
|
|
18
|
+
var _papaparse2 = _interopRequireDefault(_papaparse);
|
|
19
|
+
|
|
20
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
21
|
+
|
|
22
|
+
function readCSV(file, options) {
|
|
23
|
+
return new Promise((resolve, reject) => {
|
|
24
|
+
const reader = new FileReader();
|
|
25
|
+
reader.onloadend = () => {
|
|
26
|
+
let content = reader.result;
|
|
27
|
+
const papaParseOptions = Object.assign({ skipEmptyLines: true }, options);
|
|
28
|
+
content = _papaparse2.default.parse(content, papaParseOptions);
|
|
29
|
+
if (content.errors.length > 0) {
|
|
30
|
+
_loglevel2.default.debug(content.errors);
|
|
31
|
+
reject(new Error(_i18next2.default.t('errors.INVALID_CSV_FILE', { file: file.name }), { errors: content.errors }));
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
resolve(content);
|
|
35
|
+
};
|
|
36
|
+
reader.onerror = error => {
|
|
37
|
+
_loglevel2.default.debug(error);
|
|
38
|
+
reject(new Error(_i18next2.default.t('errors.CANNOT_READ_FILE', { file: file.name }), { errors: error }));
|
|
39
|
+
};
|
|
40
|
+
reader.readAsText(file);
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=reader.csv.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/readers/reader.csv.js"],"names":["readCSV","file","options","Promise","resolve","reject","reader","FileReader","onloadend","content","result","papaParseOptions","Object","assign","skipEmptyLines","Papa","parse","errors","length","logger","debug","Error","i18next","t","name","onerror","error","readAsText"],"mappings":";;;;;QAIgBA,O,GAAAA,O;;AAJhB;;;;AACA;;;;AACA;;;;;;AAEO,SAASA,OAAT,CAAkBC,IAAlB,EAAwBC,OAAxB,EAAiC;AACtC,SAAO,IAAIC,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;AACtC,UAAMC,SAAS,IAAIC,UAAJ,EAAf;AACAD,WAAOE,SAAP,GAAmB,MAAM;AACvB,UAAIC,UAAUH,OAAOI,MAArB;AACA,YAAMC,mBAAmBC,OAAOC,MAAP,CAAc,EAAEC,gBAAgB,IAAlB,EAAd,EAAwCZ,OAAxC,CAAzB;AACAO,gBAAUM,oBAAKC,KAAL,CAAWP,OAAX,EAAoBE,gBAApB,CAAV;AACA,UAAIF,QAAQQ,MAAR,CAAeC,MAAf,GAAwB,CAA5B,EAA+B;AAC7BC,2BAAOC,KAAP,CAAaX,QAAQQ,MAArB;AACAZ,eAAO,IAAIgB,KAAJ,CAAUC,kBAAQC,CAAR,CAAU,yBAAV,EAAqC,EAAEtB,MAAMA,KAAKuB,IAAb,EAArC,CAAV,EAAqE,EAAEP,QAAQR,QAAQQ,MAAlB,EAArE,CAAP;AACA;AACD;AACDb,cAAQK,OAAR;AACD,KAVD;AAWAH,WAAOmB,OAAP,GAAkBC,KAAD,IAAW;AAC1BP,yBAAOC,KAAP,CAAaM,KAAb;AACArB,aAAO,IAAIgB,KAAJ,CAAUC,kBAAQC,CAAR,CAAU,yBAAV,EAAqC,EAAEtB,MAAMA,KAAKuB,IAAb,EAArC,CAAV,EAAqE,EAAEP,QAAQS,KAAV,EAArE,CAAP;AACD,KAHD;AAIApB,WAAOqB,UAAP,CAAkB1B,IAAlB;AACD,GAlBM,CAAP;AAmBD","file":"reader.csv.js","sourcesContent":["import logger from 'loglevel'\r\nimport i18next from 'i18next'\r\nimport Papa from 'papaparse'\r\n\r\nexport function readCSV (file, options) {\r\n return new Promise((resolve, reject) => {\r\n const reader = new FileReader()\r\n reader.onloadend = () => {\r\n let content = reader.result\r\n const papaParseOptions = Object.assign({ skipEmptyLines: true }, options)\r\n content = Papa.parse(content, papaParseOptions)\r\n if (content.errors.length > 0) {\r\n logger.debug(content.errors)\r\n reject(new Error(i18next.t('errors.INVALID_CSV_FILE', { file: file.name }), { errors: content.errors }))\r\n return\r\n }\r\n resolve(content)\r\n }\r\n reader.onerror = (error) => {\r\n logger.debug(error)\r\n reject(new Error(i18next.t('errors.CANNOT_READ_FILE', { file: file.name }), { errors: error }))\n }\r\n reader.readAsText(file)\r\n })\r\n}\r\n"]}
|