@kalisio/kdk 1.3.4 → 1.4.1

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.
Files changed (536) hide show
  1. package/.nyc_output/{0b8aa700-8daa-49ce-85e7-a8f8965d55f0.json → 03fad5e1-0985-48cc-bcbf-b53b3567b484.json} +0 -0
  2. package/.nyc_output/{20df4355-911a-4b16-a8ab-d3392e9f0a7f.json → 0a387479-430c-4f37-afd0-7cb413b43f71.json} +0 -0
  3. package/.nyc_output/3def2322-4b64-4d43-886a-2f1d1ac42e7f.json +1 -0
  4. package/.nyc_output/{257af0bb-96c3-465a-b5ef-a1df60078d5f.json → 48c4e1d1-6dc8-4531-9519-3715b705900e.json} +0 -0
  5. package/.nyc_output/{284aebfa-23fd-425f-9d72-e4b8904dc224.json → 5942dc79-7596-496b-aca5-0a4fbea84813.json} +0 -0
  6. package/.nyc_output/dcf9446b-252f-41f8-96f9-0119b21bc294.json +1 -0
  7. package/.nyc_output/{5cbee06e-be6e-468a-bd78-4793ee785fe4.json → e4dcc112-f0f4-42fe-a481-fb65d8cb1b7d.json} +0 -0
  8. package/.nyc_output/processinfo/03fad5e1-0985-48cc-bcbf-b53b3567b484.json +1 -0
  9. package/.nyc_output/processinfo/0a387479-430c-4f37-afd0-7cb413b43f71.json +1 -0
  10. package/.nyc_output/processinfo/3def2322-4b64-4d43-886a-2f1d1ac42e7f.json +1 -0
  11. package/.nyc_output/processinfo/48c4e1d1-6dc8-4531-9519-3715b705900e.json +1 -0
  12. package/.nyc_output/processinfo/5942dc79-7596-496b-aca5-0a4fbea84813.json +1 -0
  13. package/.nyc_output/processinfo/{2bece194-92f7-4971-a688-10604044a7fa.json → dcf9446b-252f-41f8-96f9-0119b21bc294.json} +1 -1
  14. package/.nyc_output/processinfo/e4dcc112-f0f4-42fe-a481-fb65d8cb1b7d.json +1 -0
  15. package/.nyc_output/processinfo/index.json +1 -1
  16. package/CHANGELOG.md +251 -94
  17. package/README.md +1 -1
  18. package/coverage/core/api/application.js.html +145 -145
  19. package/coverage/core/api/authentication.js.html +36 -36
  20. package/coverage/core/api/db.js.html +74 -74
  21. package/coverage/core/api/hooks/hooks.account.js.html +4 -4
  22. package/coverage/core/api/hooks/hooks.authentication.js.html +4 -4
  23. package/coverage/core/api/hooks/hooks.authorisations.js.html +112 -121
  24. package/coverage/core/api/hooks/hooks.devices.js.html +5 -5
  25. package/coverage/core/api/hooks/hooks.groups.js.html +3 -3
  26. package/coverage/core/api/hooks/hooks.logger.js.html +7 -7
  27. package/coverage/core/api/hooks/hooks.model.js.html +149 -149
  28. package/coverage/core/api/hooks/hooks.organisations.js.html +13 -61
  29. package/coverage/core/api/hooks/hooks.pusher.js.html +7 -7
  30. package/coverage/core/api/hooks/hooks.query.js.html +68 -32
  31. package/coverage/core/api/hooks/hooks.service.js.html +15 -15
  32. package/coverage/core/api/hooks/hooks.storage.js.html +5 -5
  33. package/coverage/core/api/hooks/hooks.tags.js.html +7 -7
  34. package/coverage/core/api/hooks/hooks.users.js.html +93 -45
  35. package/coverage/core/api/hooks/index.html +66 -66
  36. package/coverage/core/api/hooks/index.js.html +15 -15
  37. package/coverage/core/api/index.html +35 -35
  38. package/coverage/core/api/index.js.html +13 -13
  39. package/coverage/core/api/marshall.js.html +81 -81
  40. package/coverage/core/api/models/groups.model.mongodb.js.html +1 -1
  41. package/coverage/core/api/models/index.html +1 -1
  42. package/coverage/core/api/models/organisations.model.mongodb.js.html +1 -1
  43. package/coverage/core/api/models/tags.model.mongodb.js.html +1 -1
  44. package/coverage/core/api/models/users.model.mongodb.js.html +7 -7
  45. package/coverage/core/api/oauth2-handler.js.html +3 -3
  46. package/coverage/core/api/oauth2-verifier.js.html +5 -5
  47. package/coverage/core/api/services/account/account.hooks.js.html +1 -1
  48. package/coverage/core/api/services/account/account.service.js.html +1 -1
  49. package/coverage/core/api/services/account/index.html +1 -1
  50. package/coverage/core/api/services/authorisations/authorisations.hooks.js.html +3 -3
  51. package/coverage/core/api/services/authorisations/authorisations.service.js.html +40 -37
  52. package/coverage/core/api/services/authorisations/index.html +17 -17
  53. package/coverage/core/api/services/databases/databases.hooks.js.html +1 -1
  54. package/coverage/core/api/services/databases/databases.service.js.html +1 -1
  55. package/coverage/core/api/services/databases/index.html +1 -1
  56. package/coverage/core/api/services/devices/devices.hooks.js.html +1 -1
  57. package/coverage/core/api/services/devices/devices.service.js.html +1 -1
  58. package/coverage/core/api/services/devices/index.html +1 -1
  59. package/coverage/core/api/services/groups/groups.hooks.js.html +1 -1
  60. package/coverage/core/api/services/groups/index.html +1 -1
  61. package/coverage/core/api/services/index.html +5 -5
  62. package/coverage/core/api/services/index.js.html +40 -40
  63. package/coverage/core/api/services/mailer/index.html +1 -1
  64. package/coverage/core/api/services/mailer/mailer.hooks.js.html +1 -1
  65. package/coverage/core/api/services/mailer/mailer.service.js.html +1 -1
  66. package/coverage/core/api/services/organisations/index.html +1 -1
  67. package/coverage/core/api/services/organisations/organisations.hooks.js.html +1 -1
  68. package/coverage/core/api/services/organisations/organisations.service.js.html +1 -1
  69. package/coverage/core/api/services/pusher/index.html +19 -19
  70. package/coverage/core/api/services/pusher/pusher.channels.js.html +1 -1
  71. package/coverage/core/api/services/pusher/pusher.hooks.js.html +1 -1
  72. package/coverage/core/api/services/pusher/pusher.service.js.html +32 -32
  73. package/coverage/core/api/services/storage/index.html +1 -1
  74. package/coverage/core/api/services/storage/storage.hooks.js.html +4 -4
  75. package/coverage/core/api/services/tags/index.html +1 -1
  76. package/coverage/core/api/services/tags/tags.hooks.js.html +1 -1
  77. package/coverage/core/api/services/users/index.html +1 -1
  78. package/coverage/core/api/services/users/users.hooks.js.html +12 -12
  79. package/coverage/core/common/index.html +32 -32
  80. package/coverage/core/common/index.js.html +27 -27
  81. package/coverage/core/common/permissions.js.html +135 -75
  82. package/coverage/index.html +158 -158
  83. package/coverage/lcov-report/core/api/application.js.html +145 -145
  84. package/coverage/lcov-report/core/api/authentication.js.html +36 -36
  85. package/coverage/lcov-report/core/api/db.js.html +74 -74
  86. package/coverage/lcov-report/core/api/hooks/hooks.account.js.html +4 -4
  87. package/coverage/lcov-report/core/api/hooks/hooks.authentication.js.html +4 -4
  88. package/coverage/lcov-report/core/api/hooks/hooks.authorisations.js.html +112 -121
  89. package/coverage/lcov-report/core/api/hooks/hooks.devices.js.html +5 -5
  90. package/coverage/lcov-report/core/api/hooks/hooks.groups.js.html +3 -3
  91. package/coverage/lcov-report/core/api/hooks/hooks.logger.js.html +7 -7
  92. package/coverage/lcov-report/core/api/hooks/hooks.model.js.html +149 -149
  93. package/coverage/lcov-report/core/api/hooks/hooks.organisations.js.html +13 -61
  94. package/coverage/lcov-report/core/api/hooks/hooks.pusher.js.html +7 -7
  95. package/coverage/lcov-report/core/api/hooks/hooks.query.js.html +68 -32
  96. package/coverage/lcov-report/core/api/hooks/hooks.service.js.html +15 -15
  97. package/coverage/lcov-report/core/api/hooks/hooks.storage.js.html +5 -5
  98. package/coverage/lcov-report/core/api/hooks/hooks.tags.js.html +7 -7
  99. package/coverage/lcov-report/core/api/hooks/hooks.users.js.html +93 -45
  100. package/coverage/lcov-report/core/api/hooks/index.html +66 -66
  101. package/coverage/lcov-report/core/api/hooks/index.js.html +15 -15
  102. package/coverage/lcov-report/core/api/index.html +35 -35
  103. package/coverage/lcov-report/core/api/index.js.html +13 -13
  104. package/coverage/lcov-report/core/api/marshall.js.html +81 -81
  105. package/coverage/lcov-report/core/api/models/groups.model.mongodb.js.html +1 -1
  106. package/coverage/lcov-report/core/api/models/index.html +1 -1
  107. package/coverage/lcov-report/core/api/models/organisations.model.mongodb.js.html +1 -1
  108. package/coverage/lcov-report/core/api/models/tags.model.mongodb.js.html +1 -1
  109. package/coverage/lcov-report/core/api/models/users.model.mongodb.js.html +7 -7
  110. package/coverage/lcov-report/core/api/oauth2-handler.js.html +3 -3
  111. package/coverage/lcov-report/core/api/oauth2-verifier.js.html +5 -5
  112. package/coverage/lcov-report/core/api/services/account/account.hooks.js.html +1 -1
  113. package/coverage/lcov-report/core/api/services/account/account.service.js.html +1 -1
  114. package/coverage/lcov-report/core/api/services/account/index.html +1 -1
  115. package/coverage/lcov-report/core/api/services/authorisations/authorisations.hooks.js.html +3 -3
  116. package/coverage/lcov-report/core/api/services/authorisations/authorisations.service.js.html +40 -37
  117. package/coverage/lcov-report/core/api/services/authorisations/index.html +17 -17
  118. package/coverage/lcov-report/core/api/services/databases/databases.hooks.js.html +1 -1
  119. package/coverage/lcov-report/core/api/services/databases/databases.service.js.html +1 -1
  120. package/coverage/lcov-report/core/api/services/databases/index.html +1 -1
  121. package/coverage/lcov-report/core/api/services/devices/devices.hooks.js.html +1 -1
  122. package/coverage/lcov-report/core/api/services/devices/devices.service.js.html +1 -1
  123. package/coverage/lcov-report/core/api/services/devices/index.html +1 -1
  124. package/coverage/lcov-report/core/api/services/groups/groups.hooks.js.html +1 -1
  125. package/coverage/lcov-report/core/api/services/groups/index.html +1 -1
  126. package/coverage/lcov-report/core/api/services/index.html +5 -5
  127. package/coverage/lcov-report/core/api/services/index.js.html +40 -40
  128. package/coverage/lcov-report/core/api/services/mailer/index.html +1 -1
  129. package/coverage/lcov-report/core/api/services/mailer/mailer.hooks.js.html +1 -1
  130. package/coverage/lcov-report/core/api/services/mailer/mailer.service.js.html +1 -1
  131. package/coverage/lcov-report/core/api/services/organisations/index.html +1 -1
  132. package/coverage/lcov-report/core/api/services/organisations/organisations.hooks.js.html +1 -1
  133. package/coverage/lcov-report/core/api/services/organisations/organisations.service.js.html +1 -1
  134. package/coverage/lcov-report/core/api/services/pusher/index.html +19 -19
  135. package/coverage/lcov-report/core/api/services/pusher/pusher.channels.js.html +1 -1
  136. package/coverage/lcov-report/core/api/services/pusher/pusher.hooks.js.html +1 -1
  137. package/coverage/lcov-report/core/api/services/pusher/pusher.service.js.html +32 -32
  138. package/coverage/lcov-report/core/api/services/storage/index.html +1 -1
  139. package/coverage/lcov-report/core/api/services/storage/storage.hooks.js.html +4 -4
  140. package/coverage/lcov-report/core/api/services/tags/index.html +1 -1
  141. package/coverage/lcov-report/core/api/services/tags/tags.hooks.js.html +1 -1
  142. package/coverage/lcov-report/core/api/services/users/index.html +1 -1
  143. package/coverage/lcov-report/core/api/services/users/users.hooks.js.html +12 -12
  144. package/coverage/lcov-report/core/common/index.html +32 -32
  145. package/coverage/lcov-report/core/common/index.js.html +27 -27
  146. package/coverage/lcov-report/core/common/permissions.js.html +135 -75
  147. package/coverage/lcov-report/index.html +158 -158
  148. package/coverage/lcov-report/map/api/hooks/hooks.catalog.js.html +55 -55
  149. package/coverage/lcov-report/map/api/hooks/hooks.query.js.html +302 -275
  150. package/coverage/lcov-report/map/api/hooks/index.html +43 -43
  151. package/coverage/lcov-report/map/api/hooks/index.js.html +12 -12
  152. package/coverage/lcov-report/map/api/index.html +31 -31
  153. package/coverage/lcov-report/map/api/index.js.html +24 -24
  154. package/coverage/lcov-report/map/api/marshall.js.html +39 -39
  155. package/coverage/lcov-report/map/api/models/alerts.model.mongodb.js.html +20 -20
  156. package/coverage/lcov-report/map/api/models/catalog.model.mongodb.js.html +22 -22
  157. package/coverage/lcov-report/map/api/models/features.model.mongodb.js.html +24 -24
  158. package/coverage/lcov-report/map/api/models/index.html +43 -43
  159. package/coverage/lcov-report/map/api/services/alerts/alerts.hooks.js.html +21 -21
  160. package/coverage/lcov-report/map/api/services/alerts/alerts.service.js.html +156 -156
  161. package/coverage/lcov-report/map/api/services/alerts/index.html +30 -30
  162. package/coverage/lcov-report/map/api/services/catalog/catalog.hooks.js.html +19 -19
  163. package/coverage/lcov-report/map/api/services/catalog/index.html +17 -17
  164. package/coverage/lcov-report/map/api/services/daptiles/daptiles.service.js.html +1 -1
  165. package/coverage/lcov-report/map/api/services/daptiles/index.html +1 -1
  166. package/coverage/lcov-report/map/api/services/features/features.hooks.js.html +20 -20
  167. package/coverage/lcov-report/map/api/services/features/index.html +21 -21
  168. package/coverage/lcov-report/map/api/services/geocoder/geocoder.hooks.js.html +8 -8
  169. package/coverage/lcov-report/map/api/services/geocoder/geocoder.service.js.html +99 -99
  170. package/coverage/lcov-report/map/api/services/geocoder/index.html +28 -28
  171. package/coverage/lcov-report/map/api/services/index.html +21 -21
  172. package/coverage/lcov-report/map/api/services/index.js.html +71 -71
  173. package/coverage/lcov-report/map/common/dynamic-grid-source.js.html +68 -68
  174. package/coverage/lcov-report/map/common/errors.js.html +9 -9
  175. package/coverage/lcov-report/map/common/geotiff-grid-source.js.html +120 -120
  176. package/coverage/lcov-report/map/common/grid.js.html +268 -268
  177. package/coverage/lcov-report/map/common/index.html +149 -149
  178. package/coverage/lcov-report/map/common/index.js.html +31 -31
  179. package/coverage/lcov-report/map/common/meteo-model-grid-source.js.html +71 -71
  180. package/coverage/lcov-report/map/common/moment-utils.js.html +14 -14
  181. package/coverage/lcov-report/map/common/opendap-grid-source.js.html +280 -280
  182. package/coverage/lcov-report/map/common/opendap-utils.js.html +220 -220
  183. package/coverage/lcov-report/map/common/permissions.js.html +21 -21
  184. package/coverage/lcov-report/map/common/time-based-grid-source.js.html +51 -51
  185. package/coverage/lcov-report/map/common/tms-utils.js.html +1 -1
  186. package/coverage/lcov-report/map/common/wcs-grid-source.js.html +99 -99
  187. package/coverage/lcov-report/map/common/wcs-utils.js.html +66 -66
  188. package/coverage/lcov-report/map/common/weacast-grid-source.js.html +196 -196
  189. package/coverage/lcov-report/map/common/wfs-utils.js.html +8 -5
  190. package/coverage/lcov-report/map/common/wms-utils.js.html +1 -1
  191. package/coverage/lcov-report/map/common/wmts-utils.js.html +71 -11
  192. package/coverage/lcov.info +3530 -3606
  193. package/coverage/map/api/hooks/hooks.catalog.js.html +55 -55
  194. package/coverage/map/api/hooks/hooks.query.js.html +302 -275
  195. package/coverage/map/api/hooks/index.html +43 -43
  196. package/coverage/map/api/hooks/index.js.html +12 -12
  197. package/coverage/map/api/index.html +31 -31
  198. package/coverage/map/api/index.js.html +24 -24
  199. package/coverage/map/api/marshall.js.html +39 -39
  200. package/coverage/map/api/models/alerts.model.mongodb.js.html +20 -20
  201. package/coverage/map/api/models/catalog.model.mongodb.js.html +22 -22
  202. package/coverage/map/api/models/features.model.mongodb.js.html +24 -24
  203. package/coverage/map/api/models/index.html +43 -43
  204. package/coverage/map/api/services/alerts/alerts.hooks.js.html +21 -21
  205. package/coverage/map/api/services/alerts/alerts.service.js.html +156 -156
  206. package/coverage/map/api/services/alerts/index.html +30 -30
  207. package/coverage/map/api/services/catalog/catalog.hooks.js.html +19 -19
  208. package/coverage/map/api/services/catalog/index.html +17 -17
  209. package/coverage/map/api/services/daptiles/daptiles.service.js.html +1 -1
  210. package/coverage/map/api/services/daptiles/index.html +1 -1
  211. package/coverage/map/api/services/features/features.hooks.js.html +20 -20
  212. package/coverage/map/api/services/features/index.html +21 -21
  213. package/coverage/map/api/services/geocoder/geocoder.hooks.js.html +8 -8
  214. package/coverage/map/api/services/geocoder/geocoder.service.js.html +99 -99
  215. package/coverage/map/api/services/geocoder/index.html +28 -28
  216. package/coverage/map/api/services/index.html +21 -21
  217. package/coverage/map/api/services/index.js.html +71 -71
  218. package/coverage/map/common/dynamic-grid-source.js.html +68 -68
  219. package/coverage/map/common/errors.js.html +9 -9
  220. package/coverage/map/common/geotiff-grid-source.js.html +120 -120
  221. package/coverage/map/common/grid.js.html +268 -268
  222. package/coverage/map/common/index.html +149 -149
  223. package/coverage/map/common/index.js.html +31 -31
  224. package/coverage/map/common/meteo-model-grid-source.js.html +71 -71
  225. package/coverage/map/common/moment-utils.js.html +14 -14
  226. package/coverage/map/common/opendap-grid-source.js.html +280 -280
  227. package/coverage/map/common/opendap-utils.js.html +220 -220
  228. package/coverage/map/common/permissions.js.html +21 -21
  229. package/coverage/map/common/time-based-grid-source.js.html +51 -51
  230. package/coverage/map/common/tms-utils.js.html +1 -1
  231. package/coverage/map/common/wcs-grid-source.js.html +99 -99
  232. package/coverage/map/common/wcs-utils.js.html +66 -66
  233. package/coverage/map/common/weacast-grid-source.js.html +196 -196
  234. package/coverage/map/common/wfs-utils.js.html +8 -5
  235. package/coverage/map/common/wms-utils.js.html +1 -1
  236. package/coverage/map/common/wmts-utils.js.html +71 -11
  237. package/extras/icons/kanban.png +0 -0
  238. package/extras/testcafe/page-models/map/catalog.js +2 -2
  239. package/extras/tours/core/add-member.js +10 -1
  240. package/extras/tours/core/{tag-member.js → edit-member-tags.js} +4 -3
  241. package/extras/tours/core/groups.js +8 -2
  242. package/extras/tours/core/members.js +11 -21
  243. package/extras/tours/core/tags.js +7 -1
  244. package/extras/tours/map/catalog-categories.js +4 -4
  245. package/extras/tours/map/catalog-panel.js +16 -16
  246. package/extras/tours/map/favorite-views.js +3 -3
  247. package/lib/core/api/hooks/hooks.authorisations.js +149 -140
  248. package/lib/core/api/hooks/hooks.authorisations.js.map +1 -1
  249. package/lib/core/api/hooks/hooks.organisations.js +1 -23
  250. package/lib/core/api/hooks/hooks.organisations.js.map +1 -1
  251. package/lib/core/api/hooks/hooks.query.js +22 -0
  252. package/lib/core/api/hooks/hooks.query.js.map +1 -1
  253. package/lib/core/api/hooks/hooks.users.js +34 -18
  254. package/lib/core/api/hooks/hooks.users.js.map +1 -1
  255. package/lib/core/api/services/authorisations/authorisations.service.js +34 -25
  256. package/lib/core/api/services/authorisations/authorisations.service.js.map +1 -1
  257. package/lib/core/client/api.js +1 -0
  258. package/lib/core/client/api.js.map +1 -1
  259. package/lib/core/client/components/account/KAccountDZ.vue +3 -4
  260. package/lib/core/client/components/account/KAccountDevices.vue +5 -6
  261. package/lib/core/client/components/account/KDeviceCard.vue +2 -1
  262. package/lib/core/client/components/account/KIdentityPanel.vue +1 -7
  263. package/lib/core/client/components/collection/KBoard.vue +23 -158
  264. package/lib/core/client/components/collection/KCard.vue +144 -42
  265. package/lib/core/client/components/collection/KCardSection.vue +52 -0
  266. package/lib/core/client/components/collection/KColumn.vue +181 -0
  267. package/lib/core/client/components/collection/KFilter.vue +3 -2
  268. package/lib/core/client/components/collection/KGrid.vue +13 -18
  269. package/lib/core/client/components/collection/KHistory.vue +61 -89
  270. package/lib/core/client/components/collection/KHistoryEntry.vue +90 -66
  271. package/lib/core/client/components/collection/KItem.vue +21 -2
  272. package/lib/core/client/components/collection/KList.vue +9 -12
  273. package/lib/core/client/components/collection/KTable.vue +33 -39
  274. package/lib/core/client/components/collection/index.js +6 -1
  275. package/lib/core/client/components/collection/index.js.map +1 -1
  276. package/lib/core/client/components/editor/KEditor.vue +0 -6
  277. package/lib/core/client/components/editor/KModalEditor.vue +4 -4
  278. package/lib/core/client/components/editor/KSettingsEditor.vue +49 -0
  279. package/lib/core/client/components/form/KAttachmentField.vue +10 -10
  280. package/lib/core/client/components/form/KChipsField.vue +28 -23
  281. package/lib/core/client/components/form/KColorField.vue +30 -25
  282. package/lib/core/client/components/form/KForm.vue +0 -12
  283. package/lib/core/client/components/form/KIconField.vue +1 -0
  284. package/lib/core/client/components/form/KItemField.vue +8 -3
  285. package/lib/core/client/components/form/KRoleField.vue +56 -0
  286. package/lib/core/client/components/form/KSelectField.vue +16 -1
  287. package/lib/core/client/components/form/KView.vue +5 -14
  288. package/lib/core/client/components/frame/KAction.vue +18 -12
  289. package/lib/core/client/components/frame/KAvatar.vue +3 -3
  290. package/lib/core/client/components/frame/KChart.vue +60 -0
  291. package/lib/core/client/components/frame/KChipsPane.vue +80 -0
  292. package/lib/core/client/components/frame/KContent.vue +1 -1
  293. package/lib/core/client/components/frame/KModal.vue +30 -44
  294. package/lib/core/client/components/frame/KPanel.vue +1 -1
  295. package/lib/core/client/components/frame/{KMenu.vue → KPopupAction.vue} +6 -7
  296. package/lib/core/client/components/frame/KSpot.vue +31 -0
  297. package/lib/core/client/components/frame/KStamp.vue +62 -0
  298. package/lib/core/client/components/frame/index.js +56 -1
  299. package/lib/core/client/components/frame/index.js.map +1 -1
  300. package/lib/core/client/components/input/KColorChooser.vue +16 -8
  301. package/lib/core/client/components/input/KIconChooser.vue +2 -1
  302. package/lib/core/client/components/input/KUploader.vue +14 -5
  303. package/lib/core/client/components/layout/KAbout.vue +9 -3
  304. package/lib/core/client/components/layout/KFab.vue +1 -1
  305. package/lib/core/client/components/layout/KPage.vue +44 -19
  306. package/lib/core/client/components/layout/KTour.vue +2 -2
  307. package/lib/core/client/components/layout/KWelcome.vue +13 -12
  308. package/lib/core/client/components/layout/KWindow.vue +1 -1
  309. package/lib/core/client/components/media/KImageViewer.vue +9 -7
  310. package/lib/core/client/components/media/KMediaBrowser.vue +12 -8
  311. package/lib/core/client/components/menu/KMenu.vue +103 -0
  312. package/lib/core/client/components/team/KAddMember.vue +17 -9
  313. package/lib/core/client/components/team/KChangeRole.vue +5 -7
  314. package/lib/core/client/components/team/KGroupCard.vue +34 -51
  315. package/lib/core/client/components/team/KGroupsActivity.vue +9 -2
  316. package/lib/core/client/components/team/KJoinGroup.vue +5 -7
  317. package/lib/core/client/components/team/KMemberCard.vue +104 -63
  318. package/lib/core/client/components/team/KMembersActivity.vue +9 -2
  319. package/lib/core/client/components/team/KOrganisationsActivity.vue +8 -1
  320. package/lib/core/client/components/team/KTagCard.vue +26 -26
  321. package/lib/core/client/components/team/KTagsActivity.vue +9 -2
  322. package/lib/core/client/components/time/KTimeRange.vue +144 -0
  323. package/lib/core/client/components/viewer/KModalViewer.vue +6 -0
  324. package/lib/core/client/components/viewer/KViewer.vue +0 -6
  325. package/lib/core/client/i18n/core_en.json +132 -93
  326. package/lib/core/client/i18n/core_fr.json +55 -16
  327. package/lib/core/client/index.js +28 -14
  328. package/lib/core/client/index.js.map +1 -1
  329. package/lib/core/client/mixins/mixin.authorisation.js +28 -18
  330. package/lib/core/client/mixins/mixin.authorisation.js.map +1 -1
  331. package/lib/core/client/mixins/mixin.base-collection.js +57 -9
  332. package/lib/core/client/mixins/mixin.base-collection.js.map +1 -1
  333. package/lib/core/client/mixins/mixin.base-context.js +1 -1
  334. package/lib/core/client/mixins/mixin.base-context.js.map +1 -1
  335. package/lib/core/client/mixins/mixin.base-editor.js +26 -16
  336. package/lib/core/client/mixins/mixin.base-editor.js.map +1 -1
  337. package/lib/core/client/mixins/mixin.base-field.js +0 -4
  338. package/lib/core/client/mixins/mixin.base-field.js.map +1 -1
  339. package/lib/core/client/mixins/mixin.base-item.js +29 -14
  340. package/lib/core/client/mixins/mixin.base-item.js.map +1 -1
  341. package/lib/core/client/mixins/mixin.base-viewer.js +0 -2
  342. package/lib/core/client/mixins/mixin.base-viewer.js.map +1 -1
  343. package/lib/core/client/mixins/mixin.object-proxy.js +17 -3
  344. package/lib/core/client/mixins/mixin.object-proxy.js.map +1 -1
  345. package/lib/core/client/mixins/mixin.schema-proxy.js +31 -0
  346. package/lib/core/client/mixins/mixin.schema-proxy.js.map +1 -1
  347. package/lib/core/client/mixins/mixin.service.js +5 -33
  348. package/lib/core/client/mixins/mixin.service.js.map +1 -1
  349. package/lib/core/client/services/index.js +23 -0
  350. package/lib/core/client/services/index.js.map +1 -1
  351. package/lib/core/client/services/local-settings.service.js +4 -0
  352. package/lib/core/client/services/local-settings.service.js.map +1 -1
  353. package/lib/core/client/time.js +131 -0
  354. package/lib/core/client/time.js.map +1 -0
  355. package/lib/core/common/permissions.js +65 -23
  356. package/lib/core/common/permissions.js.map +1 -1
  357. package/lib/core/common/schemas/groups.create.json +1 -1
  358. package/lib/core/common/schemas/groups.update.json +1 -1
  359. package/lib/core/common/schemas/organisations.create.json +1 -1
  360. package/lib/core/common/schemas/organisations.update.json +2 -2
  361. package/lib/core/common/schemas/settings.update.json +139 -0
  362. package/lib/core/common/schemas/tags.update.json +9 -1
  363. package/lib/map/api/hooks/hooks.query.js +48 -27
  364. package/lib/map/api/hooks/hooks.query.js.map +1 -1
  365. package/lib/map/api/services/features/features.hooks.js +1 -1
  366. package/lib/map/api/services/features/features.hooks.js.map +1 -1
  367. package/lib/map/client/components/KColorLegend.vue +25 -23
  368. package/lib/map/client/components/KFavoriteViews.vue +71 -35
  369. package/lib/map/client/components/KFeaturesChart.vue +11 -9
  370. package/lib/map/client/components/KFeaturesFilter.vue +15 -7
  371. package/lib/map/client/components/KFeaturesTable.vue +27 -2
  372. package/lib/map/client/components/KLayerEditionToolbar.vue +43 -0
  373. package/lib/map/client/components/KLayerStyleEditor.vue +10 -4
  374. package/lib/map/client/components/KLayerStyleForm.vue +14 -11
  375. package/lib/map/client/components/KLocationInput.vue +126 -65
  376. package/lib/map/client/components/KLocationMap.vue +199 -84
  377. package/lib/map/client/components/KTimeline.vue +41 -36
  378. package/lib/map/client/components/KUrlLegend.vue +21 -19
  379. package/lib/map/client/components/catalog/KBaseLayersSelector.vue +105 -0
  380. package/lib/map/client/components/catalog/KCatalog.vue +15 -3
  381. package/lib/map/client/components/catalog/KConnectLayer.vue +31 -11
  382. package/lib/map/client/components/catalog/KCreateLayer.vue +37 -14
  383. package/lib/map/client/components/catalog/KImportLayer.vue +28 -8
  384. package/lib/map/client/components/catalog/KLayerCategories.vue +86 -62
  385. package/lib/map/client/components/catalog/KLayersSelector.vue +42 -42
  386. package/lib/map/client/components/catalog/KWeatherLayersSelector.vue +3 -3
  387. package/lib/map/client/components/form/KLocationField.vue +1 -1
  388. package/lib/map/client/components/form/KOwsLayerField.vue +14 -2
  389. package/lib/map/client/components/form/KOwsServiceField.vue +1 -0
  390. package/lib/map/client/components/widget/KInformationBox.vue +10 -16
  391. package/lib/map/client/components/widget/KMapillaryViewer.vue +59 -49
  392. package/lib/map/client/components/widget/KTimeSeries.vue +39 -29
  393. package/lib/map/client/i18n/map_en.json +63 -16
  394. package/lib/map/client/i18n/map_fr.json +66 -20
  395. package/lib/map/client/init.js +18 -6
  396. package/lib/map/client/init.js.map +1 -1
  397. package/lib/map/client/leaflet/GSMaPLayer.js +4 -9
  398. package/lib/map/client/leaflet/GSMaPLayer.js.map +1 -1
  399. package/lib/map/client/leaflet/GradientPath.js +6 -1
  400. package/lib/map/client/leaflet/GradientPath.js.map +1 -1
  401. package/lib/map/client/leaflet/MaskLayer.js +64 -0
  402. package/lib/map/client/leaflet/MaskLayer.js.map +1 -0
  403. package/lib/map/client/mixins/globe/mixin.base-globe.js +4 -1
  404. package/lib/map/client/mixins/globe/mixin.base-globe.js.map +1 -1
  405. package/lib/map/client/mixins/globe/mixin.geojson-layers.js +7 -9
  406. package/lib/map/client/mixins/globe/mixin.geojson-layers.js.map +1 -1
  407. package/lib/map/client/mixins/index.js +8 -13
  408. package/lib/map/client/mixins/index.js.map +1 -1
  409. package/lib/map/client/mixins/map/mixin.base-map.js +30 -6
  410. package/lib/map/client/mixins/map/mixin.base-map.js.map +1 -1
  411. package/lib/map/client/mixins/map/mixin.canvas-layers.js +275 -52
  412. package/lib/map/client/mixins/map/mixin.canvas-layers.js.map +1 -1
  413. package/lib/map/client/mixins/map/mixin.edit-layers.js +218 -121
  414. package/lib/map/client/mixins/map/mixin.edit-layers.js.map +1 -1
  415. package/lib/map/client/mixins/map/mixin.file-layers.js +25 -18
  416. package/lib/map/client/mixins/map/mixin.file-layers.js.map +1 -1
  417. package/lib/map/client/mixins/map/mixin.geojson-layers.js +18 -10
  418. package/lib/map/client/mixins/map/mixin.geojson-layers.js.map +1 -1
  419. package/lib/map/client/mixins/map/mixin.georaster-layers.js +7 -4
  420. package/lib/map/client/mixins/map/mixin.georaster-layers.js.map +1 -1
  421. package/lib/map/client/mixins/map/mixin.gsmap-layers.js +3 -3
  422. package/lib/map/client/mixins/map/mixin.gsmap-layers.js.map +1 -1
  423. package/lib/map/client/mixins/map/mixin.heatmap-layers.js +8 -10
  424. package/lib/map/client/mixins/map/mixin.heatmap-layers.js.map +1 -1
  425. package/lib/map/client/mixins/map/mixin.mapillary-layers.js +25 -40
  426. package/lib/map/client/mixins/map/mixin.mapillary-layers.js.map +1 -1
  427. package/lib/map/client/mixins/map/mixin.tiled-mesh-layers.js +5 -3
  428. package/lib/map/client/mixins/map/mixin.tiled-mesh-layers.js.map +1 -1
  429. package/lib/map/client/mixins/map/mixin.tiled-wind-layers.js +5 -3
  430. package/lib/map/client/mixins/map/mixin.tiled-wind-layers.js.map +1 -1
  431. package/lib/map/client/mixins/mixin.activity.js +60 -68
  432. package/lib/map/client/mixins/mixin.activity.js.map +1 -1
  433. package/lib/map/client/mixins/mixin.feature-selection.js +8 -10
  434. package/lib/map/client/mixins/mixin.feature-selection.js.map +1 -1
  435. package/lib/map/client/mixins/mixin.feature-service.js +7 -5
  436. package/lib/map/client/mixins/mixin.feature-service.js.map +1 -1
  437. package/lib/map/client/mixins/mixin.weacast.js +6 -4
  438. package/lib/map/client/mixins/mixin.weacast.js.map +1 -1
  439. package/lib/map/client/pixi-utils.js +9 -0
  440. package/lib/map/client/pixi-utils.js.map +1 -1
  441. package/lib/map/client/utils.js +50 -0
  442. package/lib/map/client/utils.js.map +1 -1
  443. package/lib/map/common/wfs-utils.js +1 -1
  444. package/lib/map/common/wfs-utils.js.map +1 -1
  445. package/lib/map/common/wmts-utils.js +31 -7
  446. package/lib/map/common/wmts-utils.js.map +1 -1
  447. package/lib/test/client/core/account.js +100 -0
  448. package/lib/test/client/core/account.js.map +1 -0
  449. package/lib/test/client/core/api.js +400 -0
  450. package/lib/test/client/core/api.js.map +1 -0
  451. package/lib/test/client/core/collection.js +109 -0
  452. package/lib/test/client/core/collection.js.map +1 -0
  453. package/lib/test/client/core/index.js +90 -0
  454. package/lib/test/client/core/index.js.map +1 -0
  455. package/lib/test/client/core/layout.js +221 -0
  456. package/lib/test/client/core/layout.js.map +1 -0
  457. package/lib/test/client/core/runner.js +204 -0
  458. package/lib/test/client/core/runner.js.map +1 -0
  459. package/lib/test/client/core/screens.js +68 -0
  460. package/lib/test/client/core/screens.js.map +1 -0
  461. package/lib/test/client/core/utils.js +304 -0
  462. package/lib/test/client/core/utils.js.map +1 -0
  463. package/lib/test/client/index.js +20 -0
  464. package/lib/test/client/index.js.map +1 -0
  465. package/lib/test/client/map/catalog.js +191 -0
  466. package/lib/test/client/map/catalog.js.map +1 -0
  467. package/lib/test/client/map/controls.js +54 -0
  468. package/lib/test/client/map/controls.js.map +1 -0
  469. package/lib/test/client/map/index.js +30 -0
  470. package/lib/test/client/map/index.js.map +1 -0
  471. package/package.json +17 -9
  472. package/test.client.js +1 -0
  473. package/tests/core/test-log-2021-07-15.log +71 -0
  474. package/tests/core/test-log-2021-09-02.log +47 -0
  475. package/tests/map/test-log-%DATE%.logYYYY-07-DD +12 -0
  476. package/tests/map/test-log-%DATE%.logYYYY-09-DD +6 -0
  477. package/tests/map/test-log-2021-07-12.log +12 -0
  478. package/tests/map/test-log-2021-07-15.log +5 -0
  479. package/tests/map/test-log-2021-09-02.log +3 -0
  480. package/.nyc_output/11cd93d8-69cb-405c-98a3-d249ea35b6da.json +0 -1
  481. package/.nyc_output/2bece194-92f7-4971-a688-10604044a7fa.json +0 -1
  482. package/.nyc_output/5ddee33e-b658-4c8e-a247-54f575ac67e8.json +0 -1
  483. package/.nyc_output/78760ae4-555f-4d9c-a6a1-acf5e2f0fe45.json +0 -1
  484. package/.nyc_output/d0bb2559-084e-4c92-b9e6-29a9abd41f7c.json +0 -1
  485. package/.nyc_output/processinfo/0b8aa700-8daa-49ce-85e7-a8f8965d55f0.json +0 -1
  486. package/.nyc_output/processinfo/11cd93d8-69cb-405c-98a3-d249ea35b6da.json +0 -1
  487. package/.nyc_output/processinfo/20df4355-911a-4b16-a8ab-d3392e9f0a7f.json +0 -1
  488. package/.nyc_output/processinfo/257af0bb-96c3-465a-b5ef-a1df60078d5f.json +0 -1
  489. package/.nyc_output/processinfo/284aebfa-23fd-425f-9d72-e4b8904dc224.json +0 -1
  490. package/.nyc_output/processinfo/5cbee06e-be6e-468a-bd78-4793ee785fe4.json +0 -1
  491. package/.nyc_output/processinfo/5ddee33e-b658-4c8e-a247-54f575ac67e8.json +0 -1
  492. package/.nyc_output/processinfo/78760ae4-555f-4d9c-a6a1-acf5e2f0fe45.json +0 -1
  493. package/.nyc_output/processinfo/d0bb2559-084e-4c92-b9e6-29a9abd41f7c.json +0 -1
  494. package/lib/core/client/components/frame/KLabel.vue +0 -56
  495. package/lib/core/client/components/team/KTagsPane.vue +0 -35
  496. package/lib/map/client/leaflet/TiledMapillaryLayer.js +0 -137
  497. package/lib/map/client/leaflet/TiledMapillaryLayer.js.map +0 -1
  498. package/lib/map/client/mixins/mixin.time.js +0 -73
  499. package/lib/map/client/mixins/mixin.time.js.map +0 -1
  500. package/tests/core/account.test.js +0 -415
  501. package/tests/core/client.test.js.skip +0 -37
  502. package/tests/core/config/default.js +0 -97
  503. package/tests/core/config/email-templates/confirmInvitation/html.ejs +0 -18
  504. package/tests/core/config/email-templates/identityChange/html.ejs +0 -12
  505. package/tests/core/config/email-templates/newDevice/html.ejs +0 -7
  506. package/tests/core/config/email-templates/passwordChange/html.ejs +0 -5
  507. package/tests/core/config/email-templates/resendVerifySignup/html.ejs +0 -10
  508. package/tests/core/config/email-templates/resetPwd/html.ejs +0 -5
  509. package/tests/core/config/email-templates/sendResetPwd/html.ejs +0 -8
  510. package/tests/core/config/email-templates/verifySignup/html.ejs +0 -3
  511. package/tests/core/data/10k_most_common_passwords.txt +0 -10000
  512. package/tests/core/data/logo.png +0 -0
  513. package/tests/core/hooks.test.js +0 -175
  514. package/tests/core/index.test.js +0 -418
  515. package/tests/core/notifications.test.js +0 -465
  516. package/tests/core/storage.test.js +0 -134
  517. package/tests/core/team.test.js +0 -610
  518. package/tests/core/utils.js +0 -59
  519. package/tests/map/alerts.test.js +0 -554
  520. package/tests/map/config/default.js +0 -112
  521. package/tests/map/config/layers.json +0 -37
  522. package/tests/map/daptiles.test.js +0 -41
  523. package/tests/map/data/DescribeCoverage.xml +0 -55
  524. package/tests/map/data/GetCoverage.tif +0 -0
  525. package/tests/map/data/adsb.observations.json +0 -132
  526. package/tests/map/data/dataset.grb.das +0 -55
  527. package/tests/map/data/dataset.grb.dds +0 -17
  528. package/tests/map/data/dataset.grb.dods +0 -0
  529. package/tests/map/data/lat_lon_bounds.grb.dods +0 -0
  530. package/tests/map/data/subdataset.grb.dods +0 -0
  531. package/tests/map/data/vigicrues.observations.json +0 -47042
  532. package/tests/map/data/vigicrues.stations.json +0 -15422
  533. package/tests/map/data/zones.json +0 -1228
  534. package/tests/map/grid-sources.test.js +0 -304
  535. package/tests/map/hooks.test.js +0 -96
  536. package/tests/map/index.test.js +0 -333
@@ -23,9 +23,9 @@
23
23
  <div class='clearfix'>
24
24
 
25
25
  <div class='fl pad1y space-right2'>
26
- <span class="strong">8.54% </span>
26
+ <span class="strong">0% </span>
27
27
  <span class="quiet">Statements</span>
28
- <span class='fraction'>7/82</span>
28
+ <span class='fraction'>0/75</span>
29
29
  </div>
30
30
 
31
31
 
@@ -37,16 +37,16 @@
37
37
 
38
38
 
39
39
  <div class='fl pad1y space-right2'>
40
- <span class="strong">8.33% </span>
40
+ <span class="strong">0% </span>
41
41
  <span class="quiet">Functions</span>
42
- <span class='fraction'>1/12</span>
42
+ <span class='fraction'>0/11</span>
43
43
  </div>
44
44
 
45
45
 
46
46
  <div class='fl pad1y space-right2'>
47
- <span class="strong">9.59% </span>
47
+ <span class="strong">0% </span>
48
48
  <span class="quiet">Lines</span>
49
- <span class='fraction'>7/73</span>
49
+ <span class='fraction'>0/66</span>
50
50
  </div>
51
51
 
52
52
 
@@ -211,16 +211,16 @@
211
211
  <a name='L152'></a><a href='#L152'>152</a>
212
212
  <a name='L153'></a><a href='#L153'>153</a>
213
213
  <a name='L154'></a><a href='#L154'>154</a>
214
- <a name='L155'></a><a href='#L155'>155</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
215
- <span class="cline-any cline-yes">1x</span>
216
- <span class="cline-any cline-yes">1x</span>
217
- <span class="cline-any cline-yes">1x</span>
218
- <span class="cline-any cline-yes">1x</span>
219
- <span class="cline-any cline-yes">1x</span>
214
+ <a name='L155'></a><a href='#L155'>155</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span>
215
+ <span class="cline-any cline-neutral">&nbsp;</span>
216
+ <span class="cline-any cline-neutral">&nbsp;</span>
220
217
  <span class="cline-any cline-neutral">&nbsp;</span>
221
218
  <span class="cline-any cline-neutral">&nbsp;</span>
222
219
  <span class="cline-any cline-neutral">&nbsp;</span>
223
- <span class="cline-any cline-yes">1x</span>
220
+ <span class="cline-any cline-neutral">&nbsp;</span>
221
+ <span class="cline-any cline-neutral">&nbsp;</span>
222
+ <span class="cline-any cline-neutral">&nbsp;</span>
223
+ <span class="cline-any cline-no">&nbsp;</span>
224
224
  <span class="cline-any cline-neutral">&nbsp;</span>
225
225
  <span class="cline-any cline-neutral">&nbsp;</span>
226
226
  <span class="cline-any cline-neutral">&nbsp;</span>
@@ -252,7 +252,7 @@
252
252
  <span class="cline-any cline-no">&nbsp;</span>
253
253
  <span class="cline-any cline-neutral">&nbsp;</span>
254
254
  <span class="cline-any cline-neutral">&nbsp;</span>
255
- <span class="cline-any cline-no">&nbsp;</span>
255
+ <span class="cline-any cline-neutral">&nbsp;</span>
256
256
  <span class="cline-any cline-no">&nbsp;</span>
257
257
  <span class="cline-any cline-neutral">&nbsp;</span>
258
258
  <span class="cline-any cline-no">&nbsp;</span>
@@ -373,47 +373,47 @@ import { DynamicGridSource } from './dynamic-grid-source'
373
373
  import { readAsTimeOrDuration, makeTime } from './moment-utils'
374
374
  &nbsp;
375
375
  export class MeteoModelGridSource extends DynamicGridSource {
376
- static getKey () {
377
- return 'meteo_model'
376
+ <span class="fstat-no" title="function not covered" > st</span>atic getKey () {
377
+ <span class="cstat-no" title="statement not covered" > return 'meteo_model'</span>
378
378
  }
379
379
  &nbsp;
380
- <span class="fstat-no" title="function not covered" > constructor (o</span>ptions) {
381
- <span class="cstat-no" title="statement not covered" > super(o</span>ptions)
380
+ <span class="fstat-no" title="function not covered" > co</span>nstructor (options) {
381
+ <span class="cstat-no" title="statement not covered" > super(options)</span>
382
382
  &nbsp;
383
- <span class="cstat-no" title="statement not covered" > this.o</span>ptions = options
383
+ <span class="cstat-no" title="statement not covered" > this.options = options</span>
384
384
  // these members are not mandatory, but still defined in the context
385
- <span class="cstat-no" title="statement not covered" > this.u</span>pdateCtx.level = undefined
385
+ <span class="cstat-no" title="statement not covered" > this.updateCtx.level = undefined</span>
386
386
  }
387
387
  &nbsp;
388
- <span class="fstat-no" title="function not covered" > setModel (m</span>odel) {
389
- <span class="cstat-no" title="statement not covered" > this.u</span>pdateCtx.model = model
390
- <span class="cstat-no" title="statement not covered" > this.q</span>ueueUpdate()
388
+ <span class="fstat-no" title="function not covered" > se</span>tModel (model) {
389
+ <span class="cstat-no" title="statement not covered" > this.updateCtx.model = model</span>
390
+ <span class="cstat-no" title="statement not covered" > this.queueUpdate()</span>
391
391
  }
392
392
  &nbsp;
393
- <span class="fstat-no" title="function not covered" > setTime (t</span>ime) {
394
- <span class="cstat-no" title="statement not covered" > this.u</span>pdateCtx.time = time.clone()
395
- <span class="cstat-no" title="statement not covered" > this.u</span>pdateCtx.time.utc()
393
+ <span class="fstat-no" title="function not covered" > se</span>tTime (time) {
394
+ <span class="cstat-no" title="statement not covered" > this.updateCtx.time = time.clone()</span>
395
+ <span class="cstat-no" title="statement not covered" > this.updateCtx.time.utc()</span>
396
396
  // reset runOffset to fetch nearest run time
397
397
  // when there's no data in the nearest run, we may try to fetch
398
398
  // data in the run before the nearest (cf. dataChanged())
399
- <span class="cstat-no" title="statement not covered" > this.u</span>pdateCtx.runOffset = 0
400
- <span class="cstat-no" title="statement not covered" > this.q</span>ueueUpdate()
399
+ <span class="cstat-no" title="statement not covered" > this.updateCtx.runOffset = 0</span>
400
+ <span class="cstat-no" title="statement not covered" > this.queueUpdate()</span>
401
401
  }
402
402
  &nbsp;
403
- <span class="fstat-no" title="function not covered" > setLevel (l</span>evel) {
404
- <span class="cstat-no" title="statement not covered" > if (level !== null) <span class="cstat-no" title="statement not covered" >this.u</span>pdateCtx.level = level</span>
405
- else <span class="cstat-no" title="statement not covered" >if (this.updateCtx.level) <span class="cstat-no" title="statement not covered" >delete t</span></span>his.updateCtx.level
406
- <span class="cstat-no" title="statement not covered" > this.q</span>ueueUpdate()
403
+ <span class="fstat-no" title="function not covered" > se</span>tLevel (level) {
404
+ <span class="cstat-no" title="statement not covered" > if (level !== null) <span class="cstat-no" title="statement not covered" >this.updateCtx.level = level</span></span>
405
+ else <span class="cstat-no" title="statement not covered" >if (this.updateCtx.level) <span class="cstat-no" title="statement not covered" >delete this.updateCtx.level</span></span>
406
+ <span class="cstat-no" title="statement not covered" > this.queueUpdate()</span>
407
407
  }
408
408
  &nbsp;
409
- async <span class="fstat-no" title="function not covered" >setup (c</span>onfig) <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >{</span></span>
410
- <span class="cstat-no" title="statement not covered" > this.c</span>andidates = []
409
+ <span class="fstat-no" title="function not covered" > as</span>ync setup (config) {
410
+ <span class="cstat-no" title="statement not covered" > this.candidates = []</span>
411
411
  &nbsp;
412
412
  <span class="cstat-no" title="statement not covered" > for (const source of config.sources) {</span>
413
413
  // use default props and override with current source
414
- const item = <span class="cstat-no" title="statement not covered" >Object.a</span>ssign(Object.assign({}, config.default), source)
414
+ const item = <span class="cstat-no" title="statement not covered" >Object.assign(Object.assign({}, config.default), source)</span>
415
415
  &nbsp;
416
- const [key, conf] = <span class="cstat-no" title="statement not covered" >extractGridSourceConfig(i</span>tem)
416
+ const [key, conf] = <span class="cstat-no" title="statement not covered" >extractGridSourceConfig(item)</span>
417
417
  const candidate = <span class="cstat-no" title="statement not covered" >{</span>
418
418
  key: key,
419
419
  staticProps: conf,
@@ -425,59 +425,59 @@ export class MeteoModelGridSource extends DynamicGridSource {
425
425
  &nbsp;
426
426
  // handle dynamic properties
427
427
  <span class="cstat-no" title="statement not covered" > for (const prop of _.keys(item.dynprops)) {</span>
428
- const value = <span class="cstat-no" title="statement not covered" >item.d</span>ynprops[prop]
429
- const generator = <span class="cstat-no" title="statement not covered" >this.d</span>ynpropGenerator(value)
430
- <span class="cstat-no" title="statement not covered" > if (generator) <span class="cstat-no" title="statement not covered" >candidate.d</span></span>ynamicProps[prop] = generator
428
+ const value = <span class="cstat-no" title="statement not covered" >item.dynprops[prop]</span>
429
+ const generator = <span class="cstat-no" title="statement not covered" >this.dynpropGenerator(value)</span>
430
+ <span class="cstat-no" title="statement not covered" > if (generator) <span class="cstat-no" title="statement not covered" >candidate.dynamicProps[prop] = generator</span></span>
431
431
  }
432
432
  &nbsp;
433
- <span class="cstat-no" title="statement not covered" > this.c</span>andidates.push(candidate)
433
+ <span class="cstat-no" title="statement not covered" > this.candidates.push(candidate)</span>
434
434
  }
435
435
  }
436
436
  &nbsp;
437
- <span class="fstat-no" title="function not covered" > makeBuildContext (u</span>pdateCtx) {
438
- const ctx = <span class="cstat-no" title="statement not covered" >Object.a</span>ssign({}, updateCtx)
437
+ <span class="fstat-no" title="function not covered" > ma</span>keBuildContext (updateCtx) {
438
+ const ctx = <span class="cstat-no" title="statement not covered" >Object.assign({}, updateCtx)</span>
439
439
  &nbsp;
440
- <span class="cstat-no" title="statement not covered" > ctx.c</span>andidate = this.selectCandidate(updateCtx.time, updateCtx.model.name)
440
+ <span class="cstat-no" title="statement not covered" > ctx.candidate = this.selectCandidate(updateCtx.time, updateCtx.model.name)</span>
441
441
  <span class="cstat-no" title="statement not covered" > if (ctx.candidate) {</span>
442
442
  // update context
443
- <span class="cstat-no" title="statement not covered" > ctx.r</span>unTime = getNearestRunTime(updateCtx.time, updateCtx.model.runInterval)
443
+ <span class="cstat-no" title="statement not covered" > ctx.runTime = getNearestRunTime(updateCtx.time, updateCtx.model.runInterval)</span>
444
444
  // take runOffset into account
445
- <span class="cstat-no" title="statement not covered" > ctx.r</span>unTime.subtract(ctx.runOffset * updateCtx.model.runInterval, 'seconds')
446
- <span class="cstat-no" title="statement not covered" > ctx.f</span>orecastTime = getNearestForecastTime(updateCtx.time, updateCtx.model.interval)
447
- <span class="cstat-no" title="statement not covered" > ctx.f</span>orecastOffset = moment.duration(ctx.forecastTime.diff(ctx.runTime))
445
+ <span class="cstat-no" title="statement not covered" > ctx.runTime.subtract(ctx.runOffset * updateCtx.model.runInterval, 'seconds')</span>
446
+ <span class="cstat-no" title="statement not covered" > ctx.forecastTime = getNearestForecastTime(updateCtx.time, updateCtx.model.interval)</span>
447
+ <span class="cstat-no" title="statement not covered" > ctx.forecastOffset = moment.duration(ctx.forecastTime.diff(ctx.runTime))</span>
448
448
  &nbsp;
449
449
  // switch to utc mode, all display methods will display in UTC
450
- <span class="cstat-no" title="statement not covered" > ctx.t</span>ime.utc()
451
- <span class="cstat-no" title="statement not covered" > ctx.r</span>unTime.utc()
452
- <span class="cstat-no" title="statement not covered" > ctx.f</span>orecastTime.utc()
450
+ <span class="cstat-no" title="statement not covered" > ctx.time.utc()</span>
451
+ <span class="cstat-no" title="statement not covered" > ctx.runTime.utc()</span>
452
+ <span class="cstat-no" title="statement not covered" > ctx.forecastTime.utc()</span>
453
453
  }
454
454
  &nbsp;
455
- <span class="cstat-no" title="statement not covered" > return c</span>tx
455
+ <span class="cstat-no" title="statement not covered" > return ctx</span>
456
456
  }
457
457
  &nbsp;
458
- <span class="fstat-no" title="function not covered" > shouldSkipUpdate (n</span>ewContext, oldContext) {
459
- <span class="cstat-no" title="statement not covered" > if (oldContext.candidate !== newContext.candidate) <span class="cstat-no" title="statement not covered" >return f</span></span>alse
460
- <span class="cstat-no" title="statement not covered" > if (oldContext.runTime &amp;&amp; newContext.runTime &amp;&amp; !oldContext.runTime.isSame(newContext.runTime)) <span class="cstat-no" title="statement not covered" >return f</span></span>alse
461
- <span class="cstat-no" title="statement not covered" > if (oldContext.forecastTime &amp;&amp; newContext.forecastTime &amp;&amp; !oldContext.forecastTime.isSame(newContext.forecastTime)) <span class="cstat-no" title="statement not covered" >return f</span></span>alse
462
- <span class="cstat-no" title="statement not covered" > if (oldContext.level !== newContext.level) <span class="cstat-no" title="statement not covered" >return f</span></span>alse
463
- <span class="cstat-no" title="statement not covered" > return t</span>rue
458
+ <span class="fstat-no" title="function not covered" > sh</span>ouldSkipUpdate (newContext, oldContext) {
459
+ <span class="cstat-no" title="statement not covered" > if (oldContext.candidate !== newContext.candidate) <span class="cstat-no" title="statement not covered" >return false</span></span>
460
+ <span class="cstat-no" title="statement not covered" > if (oldContext.runTime &amp;&amp; newContext.runTime &amp;&amp; !oldContext.runTime.isSame(newContext.runTime)) <span class="cstat-no" title="statement not covered" >return false</span></span>
461
+ <span class="cstat-no" title="statement not covered" > if (oldContext.forecastTime &amp;&amp; newContext.forecastTime &amp;&amp; !oldContext.forecastTime.isSame(newContext.forecastTime)) <span class="cstat-no" title="statement not covered" >return false</span></span>
462
+ <span class="cstat-no" title="statement not covered" > if (oldContext.level !== newContext.level) <span class="cstat-no" title="statement not covered" >return false</span></span>
463
+ <span class="cstat-no" title="statement not covered" > return true</span>
464
464
  }
465
465
  &nbsp;
466
- <span class="fstat-no" title="function not covered" > buildSourceAndConfig (c</span>tx) {
466
+ <span class="fstat-no" title="function not covered" > bu</span>ildSourceAndConfig (ctx) {
467
467
  let source = <span class="cstat-no" title="statement not covered" >null</span>
468
468
  let config = <span class="cstat-no" title="statement not covered" >null</span>
469
469
  &nbsp;
470
470
  <span class="cstat-no" title="statement not covered" > if (ctx.candidate) {</span>
471
- <span class="cstat-no" title="statement not covered" > config = t</span>his.deriveConfig(ctx, ctx.candidate.staticProps, ctx.candidate.dynamicProps)
471
+ <span class="cstat-no" title="statement not covered" > config = this.deriveConfig(ctx, ctx.candidate.staticProps, ctx.candidate.dynamicProps)</span>
472
472
  <span class="cstat-no" title="statement not covered" > if (config) {</span>
473
- <span class="cstat-no" title="statement not covered" > source = m</span>akeGridSource(ctx.candidate.key, this.options)
473
+ <span class="cstat-no" title="statement not covered" > source = makeGridSource(ctx.candidate.key, this.options)</span>
474
474
  }
475
475
  }
476
476
  &nbsp;
477
- <span class="cstat-no" title="statement not covered" > return [</span>source, config]
477
+ <span class="cstat-no" title="statement not covered" > return [source, config]</span>
478
478
  }
479
479
  &nbsp;
480
- <span class="fstat-no" title="function not covered" > selectCandidate (t</span>ime, model) {
480
+ <span class="fstat-no" title="function not covered" > se</span>lectCandidate (time, model) {
481
481
  const now = <span class="cstat-no" title="statement not covered" >moment()</span>
482
482
  &nbsp;
483
483
  let candidate = <span class="cstat-no" title="statement not covered" >null</span>
@@ -488,20 +488,20 @@ export class MeteoModelGridSource extends DynamicGridSource {
488
488
  const from = <span class="cstat-no" title="statement not covered" >source.from ? makeTime(source.from, now) : null</span>
489
489
  const to = <span class="cstat-no" title="statement not covered" >source.to ? makeTime(source.to, now) : null</span>
490
490
  <span class="cstat-no" title="statement not covered" > if (from &amp;&amp; to) {</span>
491
- <span class="cstat-no" title="statement not covered" > candidate = t</span>ime.isBetween(from, to) ? source : null
491
+ <span class="cstat-no" title="statement not covered" > candidate = time.isBetween(from, to) ? source : null</span>
492
492
  } else <span class="cstat-no" title="statement not covered" >if (from) {</span>
493
- <span class="cstat-no" title="statement not covered" > candidate = t</span>ime.isSameOrAfter(from) ? source : null
493
+ <span class="cstat-no" title="statement not covered" > candidate = time.isSameOrAfter(from) ? source : null</span>
494
494
  } else <span class="cstat-no" title="statement not covered" >if (to) {</span>
495
- <span class="cstat-no" title="statement not covered" > candidate = t</span>ime.isSameOrBefore(to) ? source : null
495
+ <span class="cstat-no" title="statement not covered" > candidate = time.isSameOrBefore(to) ? source : null</span>
496
496
  }
497
497
  &nbsp;
498
498
  <span class="cstat-no" title="statement not covered" > if (candidate) <span class="cstat-no" title="statement not covered" >break</span></span>
499
499
  }
500
500
  &nbsp;
501
- <span class="cstat-no" title="statement not covered" > return c</span>andidate
501
+ <span class="cstat-no" title="statement not covered" > return candidate</span>
502
502
  }
503
503
  &nbsp;
504
- <span class="fstat-no" title="function not covered" > dataChanged () {</span>
504
+ <span class="fstat-no" title="function not covered" > da</span>taChanged () {
505
505
  // check if we need to try to fetch data from a previous run
506
506
  // in case the nearest run doesn't exists or fails to provide
507
507
  // required data
@@ -510,13 +510,13 @@ export class MeteoModelGridSource extends DynamicGridSource {
510
510
  // if we have a selected source but it's not usable
511
511
  <span class="cstat-no" title="statement not covered" > if (this.updateCtx.runOffset === 0) {</span>
512
512
  // queue updaty with an offseted run
513
- <span class="cstat-no" title="statement not covered" > this.u</span>pdateCtx.runOffset = 1
514
- <span class="cstat-no" title="statement not covered" > this.q</span>ueueUpdate()
513
+ <span class="cstat-no" title="statement not covered" > this.updateCtx.runOffset = 1</span>
514
+ <span class="cstat-no" title="statement not covered" > this.queueUpdate()</span>
515
515
  <span class="cstat-no" title="statement not covered" > return</span>
516
516
  }
517
517
  }
518
518
  &nbsp;
519
- <span class="cstat-no" title="statement not covered" > super.d</span>ataChanged()
519
+ <span class="cstat-no" title="statement not covered" > super.dataChanged()</span>
520
520
  }
521
521
  }
522
522
  &nbsp;</pre></td></tr></table></pre>
@@ -526,7 +526,7 @@ export class MeteoModelGridSource extends DynamicGridSource {
526
526
  <div class='footer quiet pad2 space-top1 center small'>
527
527
  Code coverage generated by
528
528
  <a href="https://istanbul.js.org/" target="_blank">istanbul</a>
529
- at Tue Jun 08 2021 18:08:53 GMT+0200 (GMT+02:00)
529
+ at Tue Nov 23 2021 19:39:25 GMT+0100 (GMT+01:00)
530
530
  </div>
531
531
  </div>
532
532
  <script src="../../prettify.js"></script>
@@ -23,9 +23,9 @@
23
23
  <div class='clearfix'>
24
24
 
25
25
  <div class='fl pad1y space-right2'>
26
- <span class="strong">9.09% </span>
26
+ <span class="strong">0% </span>
27
27
  <span class="quiet">Statements</span>
28
- <span class='fraction'>1/11</span>
28
+ <span class='fraction'>0/10</span>
29
29
  </div>
30
30
 
31
31
 
@@ -44,9 +44,9 @@
44
44
 
45
45
 
46
46
  <div class='fl pad1y space-right2'>
47
- <span class="strong">9.09% </span>
47
+ <span class="strong">0% </span>
48
48
  <span class="quiet">Lines</span>
49
- <span class='fraction'>1/11</span>
49
+ <span class='fraction'>0/10</span>
50
50
  </div>
51
51
 
52
52
 
@@ -81,7 +81,7 @@
81
81
  <a name='L22'></a><a href='#L22'>22</a>
82
82
  <a name='L23'></a><a href='#L23'>23</a>
83
83
  <a name='L24'></a><a href='#L24'>24</a>
84
- <a name='L25'></a><a href='#L25'>25</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
84
+ <a name='L25'></a><a href='#L25'>25</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span>
85
85
  <span class="cline-any cline-neutral">&nbsp;</span>
86
86
  <span class="cline-any cline-neutral">&nbsp;</span>
87
87
  <span class="cline-any cline-no">&nbsp;</span>
@@ -107,27 +107,27 @@
107
107
  <span class="cline-any cline-neutral">&nbsp;</span>
108
108
  <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import moment from 'moment'
109
109
  &nbsp;
110
- export function <span class="fstat-no" title="function not covered" >readAsTimeOrDuration (c</span>onf) {
110
+ export function <span class="fstat-no" title="function not covered" >readAsTimeOrDuration </span>(conf) {
111
111
  let ret = <span class="cstat-no" title="statement not covered" >null</span>
112
112
  <span class="cstat-no" title="statement not covered" > if (typeof conf === 'string') {</span>
113
113
  <span class="cstat-no" title="statement not covered" > if (conf.charAt(0) === 'P') {</span>
114
114
  // treat as a duration
115
- <span class="cstat-no" title="statement not covered" > ret = m</span>oment.duration(conf)
115
+ <span class="cstat-no" title="statement not covered" > ret = moment.duration(conf)</span>
116
116
  } else {
117
117
  // treat as time
118
- <span class="cstat-no" title="statement not covered" > ret = m</span>oment.utc(conf)
118
+ <span class="cstat-no" title="statement not covered" > ret = moment.utc(conf)</span>
119
119
  }
120
120
  &nbsp;
121
- <span class="cstat-no" title="statement not covered" > ret = r</span>et.isValid() ? ret : null
121
+ <span class="cstat-no" title="statement not covered" > ret = ret.isValid() ? ret : null</span>
122
122
  } else <span class="cstat-no" title="statement not covered" >if (!conf) {</span>
123
- <span class="cstat-no" title="statement not covered" > ret = m</span>oment.duration(0)
123
+ <span class="cstat-no" title="statement not covered" > ret = moment.duration(0)</span>
124
124
  }
125
125
  &nbsp;
126
- <span class="cstat-no" title="statement not covered" > return r</span>et
126
+ <span class="cstat-no" title="statement not covered" > return ret</span>
127
127
  }
128
128
  &nbsp;
129
- export function <span class="fstat-no" title="function not covered" >makeTime (t</span>imeOrDuration, referenceTime) {
130
- <span class="cstat-no" title="statement not covered" > return m</span>oment.isDuration(timeOrDuration) ? referenceTime.clone().add(timeOrDuration) : timeOrDuration
129
+ export function <span class="fstat-no" title="function not covered" >makeTime </span>(timeOrDuration, referenceTime) {
130
+ <span class="cstat-no" title="statement not covered" > return moment.isDuration(timeOrDuration) ? referenceTime.clone().add(timeOrDuration) : timeOrDuration</span>
131
131
  }
132
132
  &nbsp;</pre></td></tr></table></pre>
133
133
 
@@ -136,7 +136,7 @@ export function <span class="fstat-no" title="function not covered" >makeTime (t
136
136
  <div class='footer quiet pad2 space-top1 center small'>
137
137
  Code coverage generated by
138
138
  <a href="https://istanbul.js.org/" target="_blank">istanbul</a>
139
- at Tue Jun 08 2021 18:08:53 GMT+0200 (GMT+02:00)
139
+ at Tue Nov 23 2021 19:39:25 GMT+0100 (GMT+01:00)
140
140
  </div>
141
141
  </div>
142
142
  <script src="../../prettify.js"></script>