@kalisio/kdk 1.3.5 → 1.4.2
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/2c5b7c8e-81db-4d2c-a7a4-02dc640d301f.json +1 -0
- package/.nyc_output/{0b8aa700-8daa-49ce-85e7-a8f8965d55f0.json → 2e74ca23-8cf0-4161-9536-f71c2a1a74bb.json} +0 -0
- package/.nyc_output/{20df4355-911a-4b16-a8ab-d3392e9f0a7f.json → 81d21e46-766a-46bc-b1b7-143ca577347a.json} +0 -0
- package/.nyc_output/a762cb58-70dc-4d39-ab69-928635affa98.json +1 -0
- package/.nyc_output/{257af0bb-96c3-465a-b5ef-a1df60078d5f.json → aaf3ebbb-f895-4d7b-9255-bc5dee832570.json} +0 -0
- package/.nyc_output/{284aebfa-23fd-425f-9d72-e4b8904dc224.json → dbeb2602-0ac2-4e66-978b-0d29548359ca.json} +0 -0
- package/.nyc_output/{5cbee06e-be6e-468a-bd78-4793ee785fe4.json → e47d1e4c-2fff-4dcb-908f-d3081162547c.json} +0 -0
- package/.nyc_output/processinfo/{2bece194-92f7-4971-a688-10604044a7fa.json → 2c5b7c8e-81db-4d2c-a7a4-02dc640d301f.json} +1 -1
- package/.nyc_output/processinfo/2e74ca23-8cf0-4161-9536-f71c2a1a74bb.json +1 -0
- package/.nyc_output/processinfo/81d21e46-766a-46bc-b1b7-143ca577347a.json +1 -0
- package/.nyc_output/processinfo/a762cb58-70dc-4d39-ab69-928635affa98.json +1 -0
- package/.nyc_output/processinfo/aaf3ebbb-f895-4d7b-9255-bc5dee832570.json +1 -0
- package/.nyc_output/processinfo/dbeb2602-0ac2-4e66-978b-0d29548359ca.json +1 -0
- package/.nyc_output/processinfo/e47d1e4c-2fff-4dcb-908f-d3081162547c.json +1 -0
- package/.nyc_output/processinfo/index.json +1 -1
- package/CHANGELOG.md +189 -67
- package/README.md +1 -1
- package/coverage/core/api/application.js.html +145 -145
- package/coverage/core/api/authentication.js.html +37 -37
- package/coverage/core/api/db.js.html +74 -74
- package/coverage/core/api/hooks/hooks.account.js.html +15 -15
- package/coverage/core/api/hooks/hooks.authentication.js.html +16 -16
- package/coverage/core/api/hooks/hooks.authorisations.js.html +112 -121
- package/coverage/core/api/hooks/hooks.devices.js.html +5 -5
- package/coverage/core/api/hooks/hooks.groups.js.html +3 -3
- package/coverage/core/api/hooks/hooks.logger.js.html +7 -7
- package/coverage/core/api/hooks/hooks.model.js.html +149 -149
- package/coverage/core/api/hooks/hooks.organisations.js.html +13 -61
- package/coverage/core/api/hooks/hooks.pusher.js.html +7 -7
- package/coverage/core/api/hooks/hooks.query.js.html +68 -32
- package/coverage/core/api/hooks/hooks.service.js.html +15 -15
- package/coverage/core/api/hooks/hooks.storage.js.html +5 -5
- package/coverage/core/api/hooks/hooks.tags.js.html +7 -7
- package/coverage/core/api/hooks/hooks.users.js.html +111 -63
- package/coverage/core/api/hooks/index.html +72 -72
- package/coverage/core/api/hooks/index.js.html +15 -15
- package/coverage/core/api/index.html +35 -35
- package/coverage/core/api/index.js.html +13 -13
- package/coverage/core/api/marshall.js.html +81 -81
- package/coverage/core/api/models/groups.model.mongodb.js.html +1 -1
- package/coverage/core/api/models/index.html +1 -1
- package/coverage/core/api/models/organisations.model.mongodb.js.html +1 -1
- package/coverage/core/api/models/tags.model.mongodb.js.html +1 -1
- package/coverage/core/api/models/users.model.mongodb.js.html +7 -7
- package/coverage/core/api/oauth2-handler.js.html +3 -3
- package/coverage/core/api/oauth2-verifier.js.html +5 -5
- package/coverage/core/api/services/account/account.hooks.js.html +1 -1
- package/coverage/core/api/services/account/account.service.js.html +34 -34
- package/coverage/core/api/services/account/index.html +17 -17
- package/coverage/core/api/services/authorisations/authorisations.hooks.js.html +3 -3
- package/coverage/core/api/services/authorisations/authorisations.service.js.html +40 -37
- package/coverage/core/api/services/authorisations/index.html +17 -17
- package/coverage/core/api/services/databases/databases.hooks.js.html +1 -1
- package/coverage/core/api/services/databases/databases.service.js.html +1 -1
- package/coverage/core/api/services/databases/index.html +1 -1
- package/coverage/core/api/services/devices/devices.hooks.js.html +1 -1
- package/coverage/core/api/services/devices/devices.service.js.html +1 -1
- package/coverage/core/api/services/devices/index.html +1 -1
- package/coverage/core/api/services/groups/groups.hooks.js.html +1 -1
- package/coverage/core/api/services/groups/index.html +1 -1
- package/coverage/core/api/services/index.html +5 -5
- package/coverage/core/api/services/index.js.html +40 -40
- package/coverage/core/api/services/mailer/index.html +1 -1
- package/coverage/core/api/services/mailer/mailer.hooks.js.html +1 -1
- package/coverage/core/api/services/mailer/mailer.service.js.html +1 -1
- package/coverage/core/api/services/organisations/index.html +1 -1
- package/coverage/core/api/services/organisations/organisations.hooks.js.html +1 -1
- package/coverage/core/api/services/organisations/organisations.service.js.html +1 -1
- package/coverage/core/api/services/pusher/index.html +1 -1
- package/coverage/core/api/services/pusher/pusher.channels.js.html +1 -1
- package/coverage/core/api/services/pusher/pusher.hooks.js.html +1 -1
- package/coverage/core/api/services/pusher/pusher.service.js.html +1 -1
- package/coverage/core/api/services/storage/index.html +1 -1
- package/coverage/core/api/services/storage/storage.hooks.js.html +4 -4
- package/coverage/core/api/services/tags/index.html +1 -1
- package/coverage/core/api/services/tags/tags.hooks.js.html +1 -1
- package/coverage/core/api/services/users/index.html +1 -1
- package/coverage/core/api/services/users/users.hooks.js.html +12 -12
- package/coverage/core/common/index.html +32 -32
- package/coverage/core/common/index.js.html +27 -27
- package/coverage/core/common/permissions.js.html +135 -75
- package/coverage/index.html +157 -157
- package/coverage/lcov-report/core/api/application.js.html +145 -145
- package/coverage/lcov-report/core/api/authentication.js.html +37 -37
- package/coverage/lcov-report/core/api/db.js.html +74 -74
- package/coverage/lcov-report/core/api/hooks/hooks.account.js.html +15 -15
- package/coverage/lcov-report/core/api/hooks/hooks.authentication.js.html +16 -16
- package/coverage/lcov-report/core/api/hooks/hooks.authorisations.js.html +112 -121
- package/coverage/lcov-report/core/api/hooks/hooks.devices.js.html +5 -5
- package/coverage/lcov-report/core/api/hooks/hooks.groups.js.html +3 -3
- package/coverage/lcov-report/core/api/hooks/hooks.logger.js.html +7 -7
- package/coverage/lcov-report/core/api/hooks/hooks.model.js.html +149 -149
- package/coverage/lcov-report/core/api/hooks/hooks.organisations.js.html +13 -61
- package/coverage/lcov-report/core/api/hooks/hooks.pusher.js.html +7 -7
- package/coverage/lcov-report/core/api/hooks/hooks.query.js.html +68 -32
- package/coverage/lcov-report/core/api/hooks/hooks.service.js.html +15 -15
- package/coverage/lcov-report/core/api/hooks/hooks.storage.js.html +5 -5
- package/coverage/lcov-report/core/api/hooks/hooks.tags.js.html +7 -7
- package/coverage/lcov-report/core/api/hooks/hooks.users.js.html +111 -63
- package/coverage/lcov-report/core/api/hooks/index.html +72 -72
- package/coverage/lcov-report/core/api/hooks/index.js.html +15 -15
- package/coverage/lcov-report/core/api/index.html +35 -35
- package/coverage/lcov-report/core/api/index.js.html +13 -13
- package/coverage/lcov-report/core/api/marshall.js.html +81 -81
- package/coverage/lcov-report/core/api/models/groups.model.mongodb.js.html +1 -1
- package/coverage/lcov-report/core/api/models/index.html +1 -1
- package/coverage/lcov-report/core/api/models/organisations.model.mongodb.js.html +1 -1
- package/coverage/lcov-report/core/api/models/tags.model.mongodb.js.html +1 -1
- package/coverage/lcov-report/core/api/models/users.model.mongodb.js.html +7 -7
- package/coverage/lcov-report/core/api/oauth2-handler.js.html +3 -3
- package/coverage/lcov-report/core/api/oauth2-verifier.js.html +5 -5
- package/coverage/lcov-report/core/api/services/account/account.hooks.js.html +1 -1
- package/coverage/lcov-report/core/api/services/account/account.service.js.html +34 -34
- package/coverage/lcov-report/core/api/services/account/index.html +17 -17
- package/coverage/lcov-report/core/api/services/authorisations/authorisations.hooks.js.html +3 -3
- package/coverage/lcov-report/core/api/services/authorisations/authorisations.service.js.html +40 -37
- package/coverage/lcov-report/core/api/services/authorisations/index.html +17 -17
- package/coverage/lcov-report/core/api/services/databases/databases.hooks.js.html +1 -1
- package/coverage/lcov-report/core/api/services/databases/databases.service.js.html +1 -1
- package/coverage/lcov-report/core/api/services/databases/index.html +1 -1
- package/coverage/lcov-report/core/api/services/devices/devices.hooks.js.html +1 -1
- package/coverage/lcov-report/core/api/services/devices/devices.service.js.html +1 -1
- package/coverage/lcov-report/core/api/services/devices/index.html +1 -1
- package/coverage/lcov-report/core/api/services/groups/groups.hooks.js.html +1 -1
- package/coverage/lcov-report/core/api/services/groups/index.html +1 -1
- package/coverage/lcov-report/core/api/services/index.html +5 -5
- package/coverage/lcov-report/core/api/services/index.js.html +40 -40
- package/coverage/lcov-report/core/api/services/mailer/index.html +1 -1
- package/coverage/lcov-report/core/api/services/mailer/mailer.hooks.js.html +1 -1
- package/coverage/lcov-report/core/api/services/mailer/mailer.service.js.html +1 -1
- package/coverage/lcov-report/core/api/services/organisations/index.html +1 -1
- package/coverage/lcov-report/core/api/services/organisations/organisations.hooks.js.html +1 -1
- package/coverage/lcov-report/core/api/services/organisations/organisations.service.js.html +1 -1
- package/coverage/lcov-report/core/api/services/pusher/index.html +1 -1
- package/coverage/lcov-report/core/api/services/pusher/pusher.channels.js.html +1 -1
- package/coverage/lcov-report/core/api/services/pusher/pusher.hooks.js.html +1 -1
- package/coverage/lcov-report/core/api/services/pusher/pusher.service.js.html +1 -1
- package/coverage/lcov-report/core/api/services/storage/index.html +1 -1
- package/coverage/lcov-report/core/api/services/storage/storage.hooks.js.html +4 -4
- package/coverage/lcov-report/core/api/services/tags/index.html +1 -1
- package/coverage/lcov-report/core/api/services/tags/tags.hooks.js.html +1 -1
- package/coverage/lcov-report/core/api/services/users/index.html +1 -1
- package/coverage/lcov-report/core/api/services/users/users.hooks.js.html +12 -12
- package/coverage/lcov-report/core/common/index.html +32 -32
- package/coverage/lcov-report/core/common/index.js.html +27 -27
- package/coverage/lcov-report/core/common/permissions.js.html +135 -75
- package/coverage/lcov-report/index.html +157 -157
- package/coverage/lcov-report/map/api/hooks/hooks.catalog.js.html +55 -55
- package/coverage/lcov-report/map/api/hooks/hooks.query.js.html +337 -274
- package/coverage/lcov-report/map/api/hooks/index.html +43 -43
- package/coverage/lcov-report/map/api/hooks/index.js.html +12 -12
- package/coverage/lcov-report/map/api/index.html +31 -31
- package/coverage/lcov-report/map/api/index.js.html +24 -24
- package/coverage/lcov-report/map/api/marshall.js.html +39 -39
- package/coverage/lcov-report/map/api/models/alerts.model.mongodb.js.html +20 -20
- package/coverage/lcov-report/map/api/models/catalog.model.mongodb.js.html +22 -22
- package/coverage/lcov-report/map/api/models/features.model.mongodb.js.html +24 -24
- package/coverage/lcov-report/map/api/models/index.html +43 -43
- package/coverage/lcov-report/map/api/services/alerts/alerts.hooks.js.html +21 -21
- package/coverage/lcov-report/map/api/services/alerts/alerts.service.js.html +156 -156
- package/coverage/lcov-report/map/api/services/alerts/index.html +30 -30
- package/coverage/lcov-report/map/api/services/catalog/catalog.hooks.js.html +19 -19
- package/coverage/lcov-report/map/api/services/catalog/index.html +17 -17
- 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 +20 -20
- package/coverage/lcov-report/map/api/services/features/index.html +21 -21
- package/coverage/lcov-report/map/api/services/geocoder/geocoder.hooks.js.html +8 -8
- package/coverage/lcov-report/map/api/services/geocoder/geocoder.service.js.html +99 -99
- package/coverage/lcov-report/map/api/services/geocoder/index.html +28 -28
- package/coverage/lcov-report/map/api/services/index.html +21 -21
- package/coverage/lcov-report/map/api/services/index.js.html +71 -71
- package/coverage/lcov-report/map/common/dynamic-grid-source.js.html +68 -68
- package/coverage/lcov-report/map/common/errors.js.html +9 -9
- package/coverage/lcov-report/map/common/geotiff-grid-source.js.html +120 -120
- package/coverage/lcov-report/map/common/grid.js.html +268 -268
- package/coverage/lcov-report/map/common/index.html +149 -149
- package/coverage/lcov-report/map/common/index.js.html +31 -31
- package/coverage/lcov-report/map/common/meteo-model-grid-source.js.html +71 -71
- package/coverage/lcov-report/map/common/moment-utils.js.html +14 -14
- package/coverage/lcov-report/map/common/opendap-grid-source.js.html +280 -280
- package/coverage/lcov-report/map/common/opendap-utils.js.html +220 -220
- package/coverage/lcov-report/map/common/permissions.js.html +21 -21
- package/coverage/lcov-report/map/common/time-based-grid-source.js.html +51 -51
- package/coverage/lcov-report/map/common/tms-utils.js.html +1 -1
- package/coverage/lcov-report/map/common/wcs-grid-source.js.html +99 -99
- package/coverage/lcov-report/map/common/wcs-utils.js.html +66 -66
- package/coverage/lcov-report/map/common/weacast-grid-source.js.html +196 -196
- 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 +3588 -3659
- package/coverage/map/api/hooks/hooks.catalog.js.html +55 -55
- package/coverage/map/api/hooks/hooks.query.js.html +337 -274
- package/coverage/map/api/hooks/index.html +43 -43
- package/coverage/map/api/hooks/index.js.html +12 -12
- package/coverage/map/api/index.html +31 -31
- package/coverage/map/api/index.js.html +24 -24
- package/coverage/map/api/marshall.js.html +39 -39
- package/coverage/map/api/models/alerts.model.mongodb.js.html +20 -20
- package/coverage/map/api/models/catalog.model.mongodb.js.html +22 -22
- package/coverage/map/api/models/features.model.mongodb.js.html +24 -24
- package/coverage/map/api/models/index.html +43 -43
- package/coverage/map/api/services/alerts/alerts.hooks.js.html +21 -21
- package/coverage/map/api/services/alerts/alerts.service.js.html +156 -156
- package/coverage/map/api/services/alerts/index.html +30 -30
- package/coverage/map/api/services/catalog/catalog.hooks.js.html +19 -19
- package/coverage/map/api/services/catalog/index.html +17 -17
- 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 +20 -20
- package/coverage/map/api/services/features/index.html +21 -21
- package/coverage/map/api/services/geocoder/geocoder.hooks.js.html +8 -8
- package/coverage/map/api/services/geocoder/geocoder.service.js.html +99 -99
- package/coverage/map/api/services/geocoder/index.html +28 -28
- package/coverage/map/api/services/index.html +21 -21
- package/coverage/map/api/services/index.js.html +71 -71
- package/coverage/map/common/dynamic-grid-source.js.html +68 -68
- package/coverage/map/common/errors.js.html +9 -9
- package/coverage/map/common/geotiff-grid-source.js.html +120 -120
- package/coverage/map/common/grid.js.html +268 -268
- package/coverage/map/common/index.html +149 -149
- package/coverage/map/common/index.js.html +31 -31
- package/coverage/map/common/meteo-model-grid-source.js.html +71 -71
- package/coverage/map/common/moment-utils.js.html +14 -14
- package/coverage/map/common/opendap-grid-source.js.html +280 -280
- package/coverage/map/common/opendap-utils.js.html +220 -220
- package/coverage/map/common/permissions.js.html +21 -21
- package/coverage/map/common/time-based-grid-source.js.html +51 -51
- package/coverage/map/common/tms-utils.js.html +1 -1
- package/coverage/map/common/wcs-grid-source.js.html +99 -99
- package/coverage/map/common/wcs-utils.js.html +66 -66
- package/coverage/map/common/weacast-grid-source.js.html +196 -196
- 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/testcafe/page-models/map/catalog.js +2 -2
- 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/KForm.vue +0 -12
- package/lib/core/client/components/form/KIconField.vue +1 -0
- package/lib/core/client/components/form/KItemField.vue +8 -4
- 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/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 +133 -93
- package/lib/core/client/i18n/core_fr.json +56 -16
- package/lib/core/client/index.js +28 -14
- package/lib/core/client/index.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/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 +48 -27
- 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/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 +15 -7
- package/lib/map/client/components/KFeaturesTable.vue +27 -2
- package/lib/map/client/components/KLayerEditionToolbar.vue +43 -0
- package/lib/map/client/components/KLayerStyleEditor.vue +10 -4
- package/lib/map/client/components/KLayerStyleForm.vue +14 -11
- package/lib/map/client/components/KLocationInput.vue +126 -65
- package/lib/map/client/components/KLocationMap.vue +199 -84
- package/lib/map/client/components/KPositionIndicator.vue +1 -0
- package/lib/map/client/components/KTimeline.vue +41 -36
- 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 +28 -8
- package/lib/map/client/components/catalog/KLayerCategories.vue +86 -62
- package/lib/map/client/components/catalog/KLayersSelector.vue +42 -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 +21 -2
- 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 +39 -29
- package/lib/map/client/i18n/map_en.json +65 -17
- package/lib/map/client/i18n/map_fr.json +67 -20
- package/lib/map/client/init.js +18 -6
- 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/GradientPath.js.map +1 -1
- package/lib/map/client/leaflet/MaskLayer.js +64 -0
- package/lib/map/client/leaflet/MaskLayer.js.map +1 -0
- package/lib/map/client/mixins/globe/mixin.base-globe.js +4 -1
- 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/index.js +8 -13
- package/lib/map/client/mixins/index.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.base-map.js +30 -6
- package/lib/map/client/mixins/map/mixin.base-map.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.canvas-layers.js +274 -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 +25 -18
- package/lib/map/client/mixins/map/mixin.file-layers.js.map +1 -1
- package/lib/map/client/mixins/map/mixin.geojson-layers.js +18 -10
- 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.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/mixin.activity.js +60 -68
- package/lib/map/client/mixins/mixin.activity.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 +7 -5
- package/lib/map/client/mixins/mixin.feature-service.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/utils.js +50 -0
- 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 +204 -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 +191 -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 +17 -9
- package/test.client.js +1 -0
- package/tests/core/test-log-2021-07-15.log +71 -0
- package/tests/core/test-log-2021-09-02.log +47 -0
- package/tests/map/test-log-%DATE%.logYYYY-07-DD +12 -0
- package/tests/map/test-log-%DATE%.logYYYY-09-DD +6 -0
- package/tests/map/test-log-2021-07-12.log +12 -0
- package/tests/map/test-log-2021-07-15.log +5 -0
- package/tests/map/test-log-2021-09-02.log +3 -0
- package/.nyc_output/11cd93d8-69cb-405c-98a3-d249ea35b6da.json +0 -1
- package/.nyc_output/2bece194-92f7-4971-a688-10604044a7fa.json +0 -1
- package/.nyc_output/5ddee33e-b658-4c8e-a247-54f575ac67e8.json +0 -1
- package/.nyc_output/78760ae4-555f-4d9c-a6a1-acf5e2f0fe45.json +0 -1
- package/.nyc_output/d0bb2559-084e-4c92-b9e6-29a9abd41f7c.json +0 -1
- package/.nyc_output/processinfo/0b8aa700-8daa-49ce-85e7-a8f8965d55f0.json +0 -1
- package/.nyc_output/processinfo/11cd93d8-69cb-405c-98a3-d249ea35b6da.json +0 -1
- package/.nyc_output/processinfo/20df4355-911a-4b16-a8ab-d3392e9f0a7f.json +0 -1
- package/.nyc_output/processinfo/257af0bb-96c3-465a-b5ef-a1df60078d5f.json +0 -1
- package/.nyc_output/processinfo/284aebfa-23fd-425f-9d72-e4b8904dc224.json +0 -1
- package/.nyc_output/processinfo/5cbee06e-be6e-468a-bd78-4793ee785fe4.json +0 -1
- package/.nyc_output/processinfo/5ddee33e-b658-4c8e-a247-54f575ac67e8.json +0 -1
- package/.nyc_output/processinfo/78760ae4-555f-4d9c-a6a1-acf5e2f0fe45.json +0 -1
- package/.nyc_output/processinfo/d0bb2559-084e-4c92-b9e6-29a9abd41f7c.json +0 -1
- 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 -415
- package/tests/core/client.test.js.skip +0 -37
- package/tests/core/config/default.js +0 -97
- 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 -418
- 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 -59
- 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/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-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"]}
|
|
@@ -10,6 +10,10 @@ var _localSettings = require('./local-settings.service');
|
|
|
10
10
|
|
|
11
11
|
var _localSettings2 = _interopRequireDefault(_localSettings);
|
|
12
12
|
|
|
13
|
+
var _config = require('config');
|
|
14
|
+
|
|
15
|
+
var _config2 = _interopRequireDefault(_config);
|
|
16
|
+
|
|
13
17
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
14
18
|
|
|
15
19
|
exports.LocalSettingsService = _localSettings2.default;
|
|
@@ -26,5 +30,24 @@ function init() {
|
|
|
26
30
|
api.declareService('storage', { context: true });
|
|
27
31
|
api.declareService('account');
|
|
28
32
|
api.declareService('devices');
|
|
33
|
+
|
|
34
|
+
// Setup service for settings edition
|
|
35
|
+
api.createService('settings', Object.assign({
|
|
36
|
+
service: _localSettings2.default,
|
|
37
|
+
propertyMapping: {
|
|
38
|
+
shortTime: 'time.format.time.short',
|
|
39
|
+
longTime: 'time.format.time.long',
|
|
40
|
+
shortDate: 'time.format.date.short',
|
|
41
|
+
longDate: 'time.format.date.long',
|
|
42
|
+
shortYear: 'time.format.year.short',
|
|
43
|
+
longYear: 'time.format.year.long',
|
|
44
|
+
utc: 'time.format.utc',
|
|
45
|
+
timelineStep: 'time.step',
|
|
46
|
+
timeseriesSpan: 'timeseries.span',
|
|
47
|
+
location: 'locationFormat',
|
|
48
|
+
restoreView: 'restore.view',
|
|
49
|
+
restoreLayers: 'restore.layers'
|
|
50
|
+
}
|
|
51
|
+
}, _config2.default.settings || {})); // Default options can be overriden from app config
|
|
29
52
|
}
|
|
30
53
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../core/client/services/index.js"],"names":["init","LocalSettingsService","api","declareService","context"],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/services/index.js"],"names":["init","LocalSettingsService","api","declareService","context","createService","Object","assign","service","propertyMapping","shortTime","longTime","shortDate","longDate","shortYear","longYear","utc","timelineStep","timeseriesSpan","location","restoreView","restoreLayers","config","settings"],"mappings":";;;;;;kBAKwBA,I;;AALxB;;;;AACA;;;;;;QAESC,oB,GAAAA,uB;AAEM,SAASD,IAAT,GAAiB;AAC9B,QAAME,MAAM,IAAZ;;AAEA;AACAA,MAAIC,cAAJ,CAAmB,OAAnB;AACAD,MAAIC,cAAJ,CAAmB,gBAAnB;AACAD,MAAIC,cAAJ,CAAmB,MAAnB,EAA2B,EAAEC,SAAS,IAAX,EAA3B;AACAF,MAAIC,cAAJ,CAAmB,eAAnB;AACAD,MAAIC,cAAJ,CAAmB,SAAnB,EAA8B,EAAEC,SAAS,IAAX,EAA9B;AACAF,MAAIC,cAAJ,CAAmB,QAAnB,EAA6B,EAAEC,SAAS,IAAX,EAA7B;AACAF,MAAIC,cAAJ,CAAmB,SAAnB,EAA8B,EAAEC,SAAS,IAAX,EAA9B;AACAF,MAAIC,cAAJ,CAAmB,SAAnB;AACAD,MAAIC,cAAJ,CAAmB,SAAnB;;AAEA;AACAD,MAAIG,aAAJ,CAAkB,UAAlB,EAA8BC,OAAOC,MAAP,CAAc;AAC1CC,aAASP,uBADiC;AAE1CQ,qBAAiB;AACfC,iBAAW,wBADI;AAEfC,gBAAU,uBAFK;AAGfC,iBAAW,wBAHI;AAIfC,gBAAU,uBAJK;AAKfC,iBAAW,wBALI;AAMfC,gBAAU,uBANK;AAOfC,WAAK,iBAPU;AAQfC,oBAAc,WARC;AASfC,sBAAgB,iBATD;AAUfC,gBAAU,gBAVK;AAWfC,mBAAa,cAXE;AAYfC,qBAAe;AAZA;AAFyB,GAAd,EAgB3BC,iBAAOC,QAAP,IAAmB,EAhBQ,CAA9B,EAf8B,CA+BH;AAC5B","file":"index.js","sourcesContent":["import LocalSettingsService from './local-settings.service'\r\nimport config from 'config'\r\n\r\nexport { LocalSettingsService }\r\n\r\nexport default function init () {\r\n const api = this\r\n\r\n // Declare the built-in services, others are optional\r\n api.declareService('users')\r\n api.declareService('authorisations')\r\n api.declareService('tags', { context: true })\r\n api.declareService('organisations')\r\n api.declareService('members', { context: true })\r\n api.declareService('groups', { context: true })\r\n api.declareService('storage', { context: true })\r\n api.declareService('account')\r\n api.declareService('devices')\r\n\r\n // Setup service for settings edition\r\n api.createService('settings', Object.assign({\r\n service: LocalSettingsService,\r\n propertyMapping: {\r\n shortTime: 'time.format.time.short',\r\n longTime: 'time.format.time.long',\r\n shortDate: 'time.format.date.short',\r\n longDate: 'time.format.date.long',\r\n shortYear: 'time.format.year.short',\r\n longYear: 'time.format.year.long',\r\n utc: 'time.format.utc',\r\n timelineStep: 'time.step',\r\n timeseriesSpan: 'timeseries.span',\r\n location: 'locationFormat',\r\n restoreView: 'restore.view',\r\n restoreLayers: 'restore.layers'\r\n }\r\n }, config.settings || {})) // Default options can be overriden from app config\r\n}\r\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../core/client/services/local-settings.service.js"],"names":["name","api","options","mapping","propertyMapping","rootPaths","_","uniq","values","map","path","split","settingsKey","config","appName","toLowerCase","get","id","data","forOwn","value","key","set","Store","patch","previousRootValues","rootPath","has","forEach","index","eventName","kebabCase","Events","$emit","saveSettings","window","localStorage","setItem","JSON","stringify","restoreSettings","settings","getItem","parse"],"mappings":";;;;;;kBAKe,UAAUA,IAAV,EAAgBC,GAAhB,EAAqBC,OAArB,EAA8B;AAC3C,QAAMC,UAAUD,QAAQE,eAAxB;AACA;AACA;AACA,QAAMC,YAAYC,iBAAEC,IAAF,CAAOD,iBAAEE,MAAF,CAASL,OAAT,EAAkBM,GAAlB,CAAsBC,QAAQA,KAAKC,KAAL,CAAW,GAAX,EAAgB,CAAhB,CAA9B,CAAP,CAAlB;AACA,QAAMC,cAAcC,iBAAOC,OAAP,CAAeC,WAAf,KAA+B,GAA/B,IAAsCb,QAAQU,WAAR,IAAuB,UAA7D,CAApB;AACA,SAAO;;AAECI,OAAN,CAAWC,EAAX,EAAe;AAAA;AACb,cAAMC,OAAO,EAAb;AACAZ,yBAAEa,MAAF,CAAShB,OAAT,EAAkB,UAACiB,KAAD,EAAQC,GAAR,EAAgB;AAChCf,2BAAEgB,GAAF,CAAMJ,IAAN,EAAYG,GAAZ,EAAiBE,aAAMP,GAAN,CAAUI,KAAV,CAAjB;AACD,SAFD;AAGA,eAAOF,IAAP;AALa;AAMd,KARI;;AAUCM,SAAN,CAAaP,EAAb,EAAiBC,IAAjB,EAAuB;AAAA;;AAAA;AACrB,cAAMO,qBAAqBpB,UAAUI,GAAV,CAAc;AAAA,iBAAYc,aAAMP,GAAN,CAAUU,QAAV,CAAZ;AAAA,SAAd,CAA3B;AACApB,yBAAEa,MAAF,CAASD,IAAT,EAAe,UAACE,KAAD,EAAQC,GAAR,EAAgB;AAC7B,cAAIf,iBAAEqB,GAAF,CAAMxB,OAAN,EAAekB,GAAf,CAAJ,EAAyB;AACvBE,yBAAMD,GAAN,CAAUnB,QAAQkB,GAAR,CAAV,EAAwBD,KAAxB;AACD;AACF,SAJD;AAKAf,kBAAUuB,OAAV,CAAkB,UAACF,QAAD,EAAWG,KAAX,EAAqB;AACrC,gBAAMC,YAAYxB,iBAAEyB,SAAF,CAAa,GAAEL,QAAS,UAAxB,CAAlB;AACAM,yBAAOC,KAAP,CAAaH,SAAb,EAAwBP,aAAMP,GAAN,CAAUU,QAAV,CAAxB,EAA6CD,mBAAmBI,KAAnB,CAA7C;AACD,SAHD;AAIA,cAAKK,YAAL;AAXqB;AAYtB,KAtBI;;AAwBLA,mBAAgB;AACd,YAAMhB,OAAO,EAAb;AACAZ,uBAAEa,MAAF,CAAShB,OAAT,EAAkB,CAACiB,KAAD,EAAQC,GAAR,KAAgB;AAChC,YAAIE,aAAMI,GAAN,CAAUP,KAAV,CAAJ,EAAsB;AACpBd,2BAAEgB,GAAF,CAAMJ,IAAN,EAAYG,GAAZ,EAAiBE,aAAMP,GAAN,CAAUI,KAAV,CAAjB;AACD;AACF,OAJD;AAKAe,aAAOC,YAAP,CAAoBC,OAApB,CAA4BzB,WAA5B,EAAyC0B,KAAKC,SAAL,CAAerB,IAAf,CAAzC;AACD,KAhCI;;AAkCLsB,sBAAmB;AACjB,UAAIC,WAAWN,OAAOC,YAAP,CAAoBM,OAApB,CAA4B9B,WAA5B,CAAf;AACA,UAAI,CAAC6B,QAAL,EAAe;AACfA,iBAAWH,KAAKK,KAAL,CAAWF,QAAX,CAAX;AACAnC,uBAAEa,MAAF,CAAShB,OAAT,EAAkB,CAACiB,KAAD,EAAQC,GAAR,KAAgB;AAChC,YAAIf,iBAAEqB,GAAF,CAAMc,QAAN,EAAgBpB,GAAhB,CAAJ,EAA0B;AACxBE,uBAAMD,GAAN,CAAUF,KAAV,EAAiBd,iBAAEU,GAAF,CAAMyB,QAAN,EAAgBpB,GAAhB,CAAjB;AACD;AACF,OAJD;AAKD;
|
|
1
|
+
{"version":3,"sources":["../../../../core/client/services/local-settings.service.js"],"names":["name","api","options","mapping","propertyMapping","rootPaths","_","uniq","values","map","path","split","settingsKey","config","appName","toLowerCase","get","id","data","forOwn","value","key","set","Store","patch","previousRootValues","rootPath","has","forEach","index","eventName","kebabCase","Events","$emit","saveSettings","window","localStorage","setItem","JSON","stringify","restoreSettings","settings","getItem","parse","getSettingsMapping"],"mappings":";;;;;;kBAKe,UAAUA,IAAV,EAAgBC,GAAhB,EAAqBC,OAArB,EAA8B;AAC3C,QAAMC,UAAUD,QAAQE,eAAxB;AACA;AACA;AACA,QAAMC,YAAYC,iBAAEC,IAAF,CAAOD,iBAAEE,MAAF,CAASL,OAAT,EAAkBM,GAAlB,CAAsBC,QAAQA,KAAKC,KAAL,CAAW,GAAX,EAAgB,CAAhB,CAA9B,CAAP,CAAlB;AACA,QAAMC,cAAcC,iBAAOC,OAAP,CAAeC,WAAf,KAA+B,GAA/B,IAAsCb,QAAQU,WAAR,IAAuB,UAA7D,CAApB;AACA,SAAO;;AAECI,OAAN,CAAWC,EAAX,EAAe;AAAA;AACb,cAAMC,OAAO,EAAb;AACAZ,yBAAEa,MAAF,CAAShB,OAAT,EAAkB,UAACiB,KAAD,EAAQC,GAAR,EAAgB;AAChCf,2BAAEgB,GAAF,CAAMJ,IAAN,EAAYG,GAAZ,EAAiBE,aAAMP,GAAN,CAAUI,KAAV,CAAjB;AACD,SAFD;AAGA,eAAOF,IAAP;AALa;AAMd,KARI;;AAUCM,SAAN,CAAaP,EAAb,EAAiBC,IAAjB,EAAuB;AAAA;;AAAA;AACrB,cAAMO,qBAAqBpB,UAAUI,GAAV,CAAc;AAAA,iBAAYc,aAAMP,GAAN,CAAUU,QAAV,CAAZ;AAAA,SAAd,CAA3B;AACApB,yBAAEa,MAAF,CAASD,IAAT,EAAe,UAACE,KAAD,EAAQC,GAAR,EAAgB;AAC7B,cAAIf,iBAAEqB,GAAF,CAAMxB,OAAN,EAAekB,GAAf,CAAJ,EAAyB;AACvBE,yBAAMD,GAAN,CAAUnB,QAAQkB,GAAR,CAAV,EAAwBD,KAAxB;AACD;AACF,SAJD;AAKAf,kBAAUuB,OAAV,CAAkB,UAACF,QAAD,EAAWG,KAAX,EAAqB;AACrC,gBAAMC,YAAYxB,iBAAEyB,SAAF,CAAa,GAAEL,QAAS,UAAxB,CAAlB;AACAM,yBAAOC,KAAP,CAAaH,SAAb,EAAwBP,aAAMP,GAAN,CAAUU,QAAV,CAAxB,EAA6CD,mBAAmBI,KAAnB,CAA7C;AACD,SAHD;AAIA,cAAKK,YAAL;AAXqB;AAYtB,KAtBI;;AAwBLA,mBAAgB;AACd,YAAMhB,OAAO,EAAb;AACAZ,uBAAEa,MAAF,CAAShB,OAAT,EAAkB,CAACiB,KAAD,EAAQC,GAAR,KAAgB;AAChC,YAAIE,aAAMI,GAAN,CAAUP,KAAV,CAAJ,EAAsB;AACpBd,2BAAEgB,GAAF,CAAMJ,IAAN,EAAYG,GAAZ,EAAiBE,aAAMP,GAAN,CAAUI,KAAV,CAAjB;AACD;AACF,OAJD;AAKAe,aAAOC,YAAP,CAAoBC,OAApB,CAA4BzB,WAA5B,EAAyC0B,KAAKC,SAAL,CAAerB,IAAf,CAAzC;AACD,KAhCI;;AAkCLsB,sBAAmB;AACjB,UAAIC,WAAWN,OAAOC,YAAP,CAAoBM,OAApB,CAA4B9B,WAA5B,CAAf;AACA,UAAI,CAAC6B,QAAL,EAAe;AACfA,iBAAWH,KAAKK,KAAL,CAAWF,QAAX,CAAX;AACAnC,uBAAEa,MAAF,CAAShB,OAAT,EAAkB,CAACiB,KAAD,EAAQC,GAAR,KAAgB;AAChC,YAAIf,iBAAEqB,GAAF,CAAMc,QAAN,EAAgBpB,GAAhB,CAAJ,EAA0B;AACxBE,uBAAMD,GAAN,CAAUF,KAAV,EAAiBd,iBAAEU,GAAF,CAAMyB,QAAN,EAAgBpB,GAAhB,CAAjB;AACD;AACF,OAJD;AAKD,KA3CI;;AA6CLuB,yBAAsB;AACpB,aAAOzC,OAAP;AACD;AA/CI,GAAP;AAiDD,C;;AA5DD;;;;AACA;;;;AACA;;AACA","file":"local-settings.service.js","sourcesContent":["import _ from 'lodash'\r\nimport config from 'config'\r\nimport { Store } from '../store'\r\nimport { Events } from '../events'\r\n\r\nexport default function (name, api, options) {\r\n const mapping = options.propertyMapping\r\n // We will emit also an event for all top level properties in case of nested ones\r\n // This simplifies event management for some listeners instead of listening to all nested properties\r\n const rootPaths = _.uniq(_.values(mapping).map(path => path.split('.')[0]))\r\n const settingsKey = config.appName.toLowerCase() + '-' + (options.settingsKey || 'settings')\r\n return {\r\n\r\n async get (id) {\r\n const data = {}\r\n _.forOwn(mapping, (value, key) => {\r\n _.set(data, key, Store.get(value))\r\n })\r\n return data\r\n },\r\n\r\n async patch (id, data) {\r\n const previousRootValues = rootPaths.map(rootPath => Store.get(rootPath))\r\n _.forOwn(data, (value, key) => {\r\n if (_.has(mapping, key)) {\r\n Store.set(mapping[key], value)\r\n }\r\n })\r\n rootPaths.forEach((rootPath, index) => {\r\n const eventName = _.kebabCase(`${rootPath}-changed`)\r\n Events.$emit(eventName, Store.get(rootPath), previousRootValues[index])\r\n })\r\n this.saveSettings()\r\n },\r\n\r\n saveSettings () {\r\n const data = {}\r\n _.forOwn(mapping, (value, key) => {\r\n if (Store.has(value)) {\r\n _.set(data, key, Store.get(value))\r\n }\r\n })\r\n window.localStorage.setItem(settingsKey, JSON.stringify(data))\r\n },\r\n\r\n restoreSettings () {\r\n let settings = window.localStorage.getItem(settingsKey)\r\n if (!settings) return\r\n settings = JSON.parse(settings)\r\n _.forOwn(mapping, (value, key) => {\r\n if (_.has(settings, key)) {\r\n Store.set(value, _.get(settings, key))\r\n }\r\n })\r\n },\r\n\r\n getSettingsMapping () {\r\n return mapping\r\n }\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Time = undefined;
|
|
7
|
+
|
|
8
|
+
var _lodash = require('lodash');
|
|
9
|
+
|
|
10
|
+
var _lodash2 = _interopRequireDefault(_lodash);
|
|
11
|
+
|
|
12
|
+
var _moment = require('moment');
|
|
13
|
+
|
|
14
|
+
var _moment2 = _interopRequireDefault(_moment);
|
|
15
|
+
|
|
16
|
+
var _events = require('./events');
|
|
17
|
+
|
|
18
|
+
var _store = require('./store');
|
|
19
|
+
|
|
20
|
+
var _utils = require('./utils');
|
|
21
|
+
|
|
22
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
23
|
+
|
|
24
|
+
// Export singleton
|
|
25
|
+
const Time = exports.Time = {
|
|
26
|
+
initialize() {
|
|
27
|
+
// Set locale globally
|
|
28
|
+
_moment2.default.locale((0, _utils.getLocale)());
|
|
29
|
+
// Set the time object within the store
|
|
30
|
+
const now = _moment2.default.utc();
|
|
31
|
+
_store.Store.set('time', {
|
|
32
|
+
range: {
|
|
33
|
+
start: now.clone().subtract(1, 'months').startOf('day'),
|
|
34
|
+
end: now.clone().endOf('day'),
|
|
35
|
+
field: 'createdAt',
|
|
36
|
+
query: {}
|
|
37
|
+
},
|
|
38
|
+
format: {
|
|
39
|
+
time: {
|
|
40
|
+
short: 'H[h]',
|
|
41
|
+
long: 'HH:mm'
|
|
42
|
+
},
|
|
43
|
+
date: {
|
|
44
|
+
short: 'DD/MM',
|
|
45
|
+
long: 'dddd D'
|
|
46
|
+
},
|
|
47
|
+
year: {
|
|
48
|
+
short: 'YY',
|
|
49
|
+
long: 'YYYY'
|
|
50
|
+
},
|
|
51
|
+
utc: false
|
|
52
|
+
},
|
|
53
|
+
currentTime: now,
|
|
54
|
+
step: 60 // 1H
|
|
55
|
+
});
|
|
56
|
+
this.updateTimeRangeQuery();
|
|
57
|
+
// Make filter react to external changes to update the query
|
|
58
|
+
_events.Events.$on('time-range-changed', () => this.updateTimeRangeQuery());
|
|
59
|
+
},
|
|
60
|
+
convertToMoment(datetime) {
|
|
61
|
+
if (_moment2.default.isMoment(datetime)) {
|
|
62
|
+
// Clone to avoid mutating and force UTC mode
|
|
63
|
+
return _moment2.default.utc(datetime.valueOf());
|
|
64
|
+
} else {
|
|
65
|
+
// Convert from Date, string or milliseconds (ie EPOCH)
|
|
66
|
+
return _moment2.default.utc(datetime);
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
get() {
|
|
70
|
+
return _store.Store.get('time');
|
|
71
|
+
},
|
|
72
|
+
getRange() {
|
|
73
|
+
return this.get().range;
|
|
74
|
+
},
|
|
75
|
+
patchRange(range) {
|
|
76
|
+
_store.Store.patch('time.range', range);
|
|
77
|
+
},
|
|
78
|
+
getRangeQuery() {
|
|
79
|
+
return _store.Store.get('time.range.query');
|
|
80
|
+
},
|
|
81
|
+
// Build sort query
|
|
82
|
+
updateTimeRangeQuery() {
|
|
83
|
+
const query = {};
|
|
84
|
+
query[this.getRange().field] = { $gte: this.getRange().start.format(), $lte: this.getRange().end.format()
|
|
85
|
+
// Avoid reentrance as we listen to other filter property changes
|
|
86
|
+
};if (!_lodash2.default.isEqual(query, this.getRangeQuery())) _store.Store.patch('time.range', { query });
|
|
87
|
+
},
|
|
88
|
+
getFormat() {
|
|
89
|
+
return this.get().format;
|
|
90
|
+
},
|
|
91
|
+
format(datetime, format) {
|
|
92
|
+
let currentTime = this.convertToMoment(datetime);
|
|
93
|
+
if (!this.getFormat().utc) {
|
|
94
|
+
// Convert to local time
|
|
95
|
+
currentTime = (0, _moment2.default)(currentTime.valueOf());
|
|
96
|
+
}
|
|
97
|
+
if (format === 'iso') return currentTime.format();
|
|
98
|
+
// Defaults to long mode if not given
|
|
99
|
+
else return currentTime.format(_lodash2.default.get(this.getFormat(), format, _lodash2.default.get(this.getFormat(), format + '.long')));
|
|
100
|
+
},
|
|
101
|
+
getCurrentTime() {
|
|
102
|
+
return this.get().currentTime;
|
|
103
|
+
},
|
|
104
|
+
setCurrentTime(datetime) {
|
|
105
|
+
const now = this.convertToMoment(datetime);
|
|
106
|
+
if (this.getCurrentTime().isSame(now)) return;
|
|
107
|
+
_store.Store.patch('time.currentTime', now);
|
|
108
|
+
},
|
|
109
|
+
getCurrentFormattedTime() {
|
|
110
|
+
const currentTime = this.getCurrentTime();
|
|
111
|
+
return {
|
|
112
|
+
time: {
|
|
113
|
+
short: this.format(currentTime, 'time.short'),
|
|
114
|
+
long: this.format(currentTime, 'time.long')
|
|
115
|
+
},
|
|
116
|
+
date: {
|
|
117
|
+
short: this.format(currentTime, 'date.short'),
|
|
118
|
+
long: this.format(currentTime, 'date.long')
|
|
119
|
+
},
|
|
120
|
+
year: {
|
|
121
|
+
short: this.format(currentTime, 'year.short'),
|
|
122
|
+
long: this.format(currentTime, 'year.long')
|
|
123
|
+
},
|
|
124
|
+
iso: this.format(currentTime, 'iso')
|
|
125
|
+
};
|
|
126
|
+
},
|
|
127
|
+
getStep() {
|
|
128
|
+
return this.get().step;
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
//# sourceMappingURL=time.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../core/client/time.js"],"names":["Time","initialize","moment","locale","now","utc","Store","set","range","start","clone","subtract","startOf","end","endOf","field","query","format","time","short","long","date","year","currentTime","step","updateTimeRangeQuery","Events","$on","convertToMoment","datetime","isMoment","valueOf","get","getRange","patchRange","patch","getRangeQuery","$gte","$lte","_","isEqual","getFormat","getCurrentTime","setCurrentTime","isSame","getCurrentFormattedTime","iso","getStep"],"mappings":"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","file":"time.js","sourcesContent":["import _ from 'lodash'\r\nimport moment from 'moment'\r\nimport { Events } from './events'\r\nimport { Store } from './store'\r\nimport { getLocale } from './utils'\r\n\r\n// Export singleton\r\nexport const Time = {\r\n initialize () {\r\n // Set locale globally\r\n moment.locale(getLocale())\r\n // Set the time object within the store\r\n const now = moment.utc()\r\n Store.set('time', {\r\n range: {\r\n start: now.clone().subtract(1, 'months').startOf('day'),\r\n end: now.clone().endOf('day'),\r\n field: 'createdAt',\r\n query: {}\r\n },\r\n format: {\r\n time: {\r\n short: 'H[h]',\r\n long: 'HH:mm'\r\n },\r\n date: {\r\n short: 'DD/MM',\r\n long: 'dddd D'\r\n },\r\n year: {\r\n short: 'YY',\r\n long: 'YYYY'\r\n },\r\n utc: false\r\n },\r\n currentTime: now,\r\n step: 60 // 1H\r\n })\r\n this.updateTimeRangeQuery()\r\n // Make filter react to external changes to update the query\r\n Events.$on('time-range-changed', () => this.updateTimeRangeQuery())\r\n },\r\n convertToMoment (datetime) {\r\n if (moment.isMoment(datetime)) {\r\n // Clone to avoid mutating and force UTC mode\r\n return moment.utc(datetime.valueOf())\r\n } else { // Convert from Date, string or milliseconds (ie EPOCH)\r\n return moment.utc(datetime)\r\n }\r\n },\r\n get () {\r\n return Store.get('time')\r\n },\r\n getRange () {\r\n return this.get().range\r\n },\r\n patchRange (range) {\r\n Store.patch('time.range', range)\r\n },\r\n getRangeQuery () {\r\n return Store.get('time.range.query')\r\n },\r\n // Build sort query\r\n updateTimeRangeQuery () {\r\n const query = {}\r\n query[this.getRange().field] = { $gte: this.getRange().start.format(), $lte: this.getRange().end.format() }\r\n // Avoid reentrance as we listen to other filter property changes\r\n if (!_.isEqual(query, this.getRangeQuery())) Store.patch('time.range', { query })\r\n },\r\n getFormat () {\r\n return this.get().format\r\n },\r\n format (datetime, format) {\r\n let currentTime = this.convertToMoment(datetime)\r\n if (!this.getFormat().utc) {\r\n // Convert to local time\r\n currentTime = moment(currentTime.valueOf())\r\n }\r\n if (format === 'iso') return currentTime.format()\r\n // Defaults to long mode if not given\r\n else return currentTime.format(_.get(this.getFormat(), format, _.get(this.getFormat(), format + '.long')))\r\n },\r\n getCurrentTime () {\r\n return this.get().currentTime\r\n },\r\n setCurrentTime (datetime) {\r\n const now = this.convertToMoment(datetime)\r\n if (this.getCurrentTime().isSame(now)) return\r\n Store.patch('time.currentTime', now)\r\n },\r\n getCurrentFormattedTime () {\r\n const currentTime = this.getCurrentTime()\r\n return {\r\n time: {\r\n short: this.format(currentTime, 'time.short'),\r\n long: this.format(currentTime, 'time.long')\r\n },\r\n date: {\r\n short: this.format(currentTime, 'date.short'),\r\n long: this.format(currentTime, 'date.long')\r\n },\r\n year: {\r\n short: this.format(currentTime, 'year.short'),\r\n long: this.format(currentTime, 'year.long')\r\n },\r\n iso: this.format(currentTime, 'iso')\r\n }\r\n },\r\n getStep () {\r\n return this.get().step\r\n }\r\n}\r\n"]}
|