@kalisio/kdk 1.3.6 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (577) hide show
  1. package/.nyc_output/{0d403586-0c7c-4336-94d1-a49e9f02a905.json → 058fc679-d60a-4501-ac04-71171e5200b8.json} +0 -0
  2. package/.nyc_output/2226bcce-9d22-4dad-b9fa-46564b5565c7.json +1 -0
  3. package/.nyc_output/6dc4b140-1a8a-4d69-b91c-89c557883d6e.json +1 -0
  4. package/.nyc_output/{21dd57bd-48c5-41c8-8800-252db32a9366.json → 8b1830fa-932e-4a61-9837-4a5b18f83ea9.json} +0 -0
  5. package/.nyc_output/{3eb3a2ca-53c2-4551-ba6b-adf70f9a53cd.json → afd2d144-3570-4858-b94a-b523dbd023dd.json} +0 -0
  6. package/.nyc_output/processinfo/058fc679-d60a-4501-ac04-71171e5200b8.json +1 -0
  7. package/.nyc_output/processinfo/2226bcce-9d22-4dad-b9fa-46564b5565c7.json +1 -0
  8. package/.nyc_output/processinfo/6dc4b140-1a8a-4d69-b91c-89c557883d6e.json +1 -0
  9. package/.nyc_output/processinfo/8b1830fa-932e-4a61-9837-4a5b18f83ea9.json +1 -0
  10. package/.nyc_output/processinfo/afd2d144-3570-4858-b94a-b523dbd023dd.json +1 -0
  11. package/.nyc_output/processinfo/index.json +1 -1
  12. package/CHANGELOG.md +167 -79
  13. package/README.md +1 -1
  14. package/coverage/core/api/application.js.html +436 -436
  15. package/coverage/core/api/authentication.js.html +119 -119
  16. package/coverage/core/api/db.js.html +201 -201
  17. package/coverage/core/api/hooks/hooks.account.js.html +48 -48
  18. package/coverage/core/api/hooks/hooks.authentication.js.html +64 -64
  19. package/coverage/core/api/hooks/hooks.authorisations.js.html +369 -378
  20. package/coverage/core/api/hooks/hooks.devices.js.html +49 -49
  21. package/coverage/core/api/hooks/hooks.groups.js.html +37 -37
  22. package/coverage/core/api/hooks/hooks.logger.js.html +27 -27
  23. package/coverage/core/api/hooks/hooks.model.js.html +269 -269
  24. package/coverage/core/api/hooks/hooks.organisations.js.html +183 -231
  25. package/coverage/core/api/hooks/hooks.pusher.js.html +114 -114
  26. package/coverage/core/api/hooks/hooks.query.js.html +234 -198
  27. package/coverage/core/api/hooks/hooks.service.js.html +82 -82
  28. package/coverage/core/api/hooks/hooks.storage.js.html +121 -121
  29. package/coverage/core/api/hooks/hooks.tags.js.html +232 -232
  30. package/coverage/core/api/hooks/hooks.users.js.html +304 -256
  31. package/coverage/core/api/hooks/index.html +172 -172
  32. package/coverage/core/api/hooks/index.js.html +24 -24
  33. package/coverage/core/api/index.html +75 -75
  34. package/coverage/core/api/index.js.html +26 -26
  35. package/coverage/core/api/marshall.js.html +57 -57
  36. package/coverage/core/api/models/groups.model.mongodb.js.html +20 -20
  37. package/coverage/core/api/models/index.html +50 -50
  38. package/coverage/core/api/models/organisations.model.mongodb.js.html +12 -12
  39. package/coverage/core/api/models/tags.model.mongodb.js.html +22 -22
  40. package/coverage/core/api/models/users.model.mongodb.js.html +20 -20
  41. package/coverage/core/api/oauth2-handler.js.html +18 -18
  42. package/coverage/core/api/oauth2-verifier.js.html +38 -38
  43. package/coverage/core/api/services/account/account.hooks.js.html +16 -16
  44. package/coverage/core/api/services/account/account.service.js.html +108 -108
  45. package/coverage/core/api/services/account/index.html +32 -32
  46. package/coverage/core/api/services/authorisations/authorisations.hooks.js.html +9 -9
  47. package/coverage/core/api/services/authorisations/authorisations.service.js.html +132 -129
  48. package/coverage/core/api/services/authorisations/index.html +28 -28
  49. package/coverage/core/api/services/databases/databases.hooks.js.html +9 -9
  50. package/coverage/core/api/services/databases/databases.service.js.html +12 -12
  51. package/coverage/core/api/services/databases/index.html +24 -24
  52. package/coverage/core/api/services/devices/devices.hooks.js.html +9 -9
  53. package/coverage/core/api/services/devices/devices.service.js.html +121 -121
  54. package/coverage/core/api/services/devices/index.html +28 -28
  55. package/coverage/core/api/services/groups/groups.hooks.js.html +9 -9
  56. package/coverage/core/api/services/groups/index.html +13 -13
  57. package/coverage/core/api/services/index.html +21 -21
  58. package/coverage/core/api/services/index.js.html +137 -137
  59. package/coverage/core/api/services/mailer/index.html +24 -24
  60. package/coverage/core/api/services/mailer/mailer.hooks.js.html +9 -9
  61. package/coverage/core/api/services/mailer/mailer.service.js.html +19 -19
  62. package/coverage/core/api/services/organisations/index.html +24 -24
  63. package/coverage/core/api/services/organisations/organisations.hooks.js.html +8 -8
  64. package/coverage/core/api/services/organisations/organisations.service.js.html +67 -67
  65. package/coverage/core/api/services/pusher/index.html +34 -34
  66. package/coverage/core/api/services/pusher/pusher.channels.js.html +8 -8
  67. package/coverage/core/api/services/pusher/pusher.hooks.js.html +10 -10
  68. package/coverage/core/api/services/pusher/pusher.service.js.html +414 -414
  69. package/coverage/core/api/services/storage/index.html +21 -21
  70. package/coverage/core/api/services/storage/storage.hooks.js.html +35 -35
  71. package/coverage/core/api/services/tags/index.html +21 -21
  72. package/coverage/core/api/services/tags/tags.hooks.js.html +25 -25
  73. package/coverage/core/api/services/users/index.html +21 -21
  74. package/coverage/core/api/services/users/users.hooks.js.html +33 -33
  75. package/coverage/core/common/errors.js.html +1 -1
  76. package/coverage/core/common/index.html +42 -27
  77. package/coverage/core/common/index.js.html +16 -16
  78. package/coverage/core/common/permissions.js.html +325 -265
  79. package/coverage/index.html +182 -182
  80. package/coverage/lcov-report/core/api/application.js.html +436 -436
  81. package/coverage/lcov-report/core/api/authentication.js.html +119 -119
  82. package/coverage/lcov-report/core/api/db.js.html +201 -201
  83. package/coverage/lcov-report/core/api/hooks/hooks.account.js.html +48 -48
  84. package/coverage/lcov-report/core/api/hooks/hooks.authentication.js.html +64 -64
  85. package/coverage/lcov-report/core/api/hooks/hooks.authorisations.js.html +369 -378
  86. package/coverage/lcov-report/core/api/hooks/hooks.devices.js.html +49 -49
  87. package/coverage/lcov-report/core/api/hooks/hooks.groups.js.html +37 -37
  88. package/coverage/lcov-report/core/api/hooks/hooks.logger.js.html +27 -27
  89. package/coverage/lcov-report/core/api/hooks/hooks.model.js.html +269 -269
  90. package/coverage/lcov-report/core/api/hooks/hooks.organisations.js.html +183 -231
  91. package/coverage/lcov-report/core/api/hooks/hooks.pusher.js.html +114 -114
  92. package/coverage/lcov-report/core/api/hooks/hooks.query.js.html +234 -198
  93. package/coverage/lcov-report/core/api/hooks/hooks.service.js.html +82 -82
  94. package/coverage/lcov-report/core/api/hooks/hooks.storage.js.html +121 -121
  95. package/coverage/lcov-report/core/api/hooks/hooks.tags.js.html +232 -232
  96. package/coverage/lcov-report/core/api/hooks/hooks.users.js.html +304 -256
  97. package/coverage/lcov-report/core/api/hooks/index.html +172 -172
  98. package/coverage/lcov-report/core/api/hooks/index.js.html +24 -24
  99. package/coverage/lcov-report/core/api/index.html +75 -75
  100. package/coverage/lcov-report/core/api/index.js.html +26 -26
  101. package/coverage/lcov-report/core/api/marshall.js.html +57 -57
  102. package/coverage/lcov-report/core/api/models/groups.model.mongodb.js.html +20 -20
  103. package/coverage/lcov-report/core/api/models/index.html +50 -50
  104. package/coverage/lcov-report/core/api/models/organisations.model.mongodb.js.html +12 -12
  105. package/coverage/lcov-report/core/api/models/tags.model.mongodb.js.html +22 -22
  106. package/coverage/lcov-report/core/api/models/users.model.mongodb.js.html +20 -20
  107. package/coverage/lcov-report/core/api/oauth2-handler.js.html +18 -18
  108. package/coverage/lcov-report/core/api/oauth2-verifier.js.html +38 -38
  109. package/coverage/lcov-report/core/api/services/account/account.hooks.js.html +16 -16
  110. package/coverage/lcov-report/core/api/services/account/account.service.js.html +108 -108
  111. package/coverage/lcov-report/core/api/services/account/index.html +32 -32
  112. package/coverage/lcov-report/core/api/services/authorisations/authorisations.hooks.js.html +9 -9
  113. package/coverage/lcov-report/core/api/services/authorisations/authorisations.service.js.html +132 -129
  114. package/coverage/lcov-report/core/api/services/authorisations/index.html +28 -28
  115. package/coverage/lcov-report/core/api/services/databases/databases.hooks.js.html +9 -9
  116. package/coverage/lcov-report/core/api/services/databases/databases.service.js.html +12 -12
  117. package/coverage/lcov-report/core/api/services/databases/index.html +24 -24
  118. package/coverage/lcov-report/core/api/services/devices/devices.hooks.js.html +9 -9
  119. package/coverage/lcov-report/core/api/services/devices/devices.service.js.html +121 -121
  120. package/coverage/lcov-report/core/api/services/devices/index.html +28 -28
  121. package/coverage/lcov-report/core/api/services/groups/groups.hooks.js.html +9 -9
  122. package/coverage/lcov-report/core/api/services/groups/index.html +13 -13
  123. package/coverage/lcov-report/core/api/services/index.html +21 -21
  124. package/coverage/lcov-report/core/api/services/index.js.html +137 -137
  125. package/coverage/lcov-report/core/api/services/mailer/index.html +24 -24
  126. package/coverage/lcov-report/core/api/services/mailer/mailer.hooks.js.html +9 -9
  127. package/coverage/lcov-report/core/api/services/mailer/mailer.service.js.html +19 -19
  128. package/coverage/lcov-report/core/api/services/organisations/index.html +24 -24
  129. package/coverage/lcov-report/core/api/services/organisations/organisations.hooks.js.html +8 -8
  130. package/coverage/lcov-report/core/api/services/organisations/organisations.service.js.html +67 -67
  131. package/coverage/lcov-report/core/api/services/pusher/index.html +34 -34
  132. package/coverage/lcov-report/core/api/services/pusher/pusher.channels.js.html +8 -8
  133. package/coverage/lcov-report/core/api/services/pusher/pusher.hooks.js.html +10 -10
  134. package/coverage/lcov-report/core/api/services/pusher/pusher.service.js.html +414 -414
  135. package/coverage/lcov-report/core/api/services/storage/index.html +21 -21
  136. package/coverage/lcov-report/core/api/services/storage/storage.hooks.js.html +35 -35
  137. package/coverage/lcov-report/core/api/services/tags/index.html +21 -21
  138. package/coverage/lcov-report/core/api/services/tags/tags.hooks.js.html +25 -25
  139. package/coverage/lcov-report/core/api/services/users/index.html +21 -21
  140. package/coverage/lcov-report/core/api/services/users/users.hooks.js.html +33 -33
  141. package/coverage/lcov-report/core/common/errors.js.html +1 -1
  142. package/coverage/lcov-report/core/common/index.html +42 -27
  143. package/coverage/lcov-report/core/common/index.js.html +16 -16
  144. package/coverage/lcov-report/core/common/permissions.js.html +325 -265
  145. package/coverage/lcov-report/index.html +182 -182
  146. package/coverage/lcov-report/map/api/hooks/hooks.catalog.js.html +1 -1
  147. package/coverage/lcov-report/map/api/hooks/hooks.query.js.html +118 -37
  148. package/coverage/lcov-report/map/api/hooks/index.html +7 -7
  149. package/coverage/lcov-report/map/api/hooks/index.js.html +1 -1
  150. package/coverage/lcov-report/map/api/index.html +1 -1
  151. package/coverage/lcov-report/map/api/index.js.html +1 -1
  152. package/coverage/lcov-report/map/api/marshall.js.html +1 -1
  153. package/coverage/lcov-report/map/api/models/alerts.model.mongodb.js.html +1 -1
  154. package/coverage/lcov-report/map/api/models/catalog.model.mongodb.js.html +1 -1
  155. package/coverage/lcov-report/map/api/models/features.model.mongodb.js.html +1 -1
  156. package/coverage/lcov-report/map/api/models/index.html +1 -1
  157. package/coverage/lcov-report/map/api/services/alerts/alerts.hooks.js.html +1 -1
  158. package/coverage/lcov-report/map/api/services/alerts/alerts.service.js.html +1 -1
  159. package/coverage/lcov-report/map/api/services/alerts/index.html +1 -1
  160. package/coverage/lcov-report/map/api/services/catalog/catalog.hooks.js.html +1 -1
  161. package/coverage/lcov-report/map/api/services/catalog/index.html +1 -1
  162. package/coverage/lcov-report/map/api/services/daptiles/daptiles.service.js.html +1 -1
  163. package/coverage/lcov-report/map/api/services/daptiles/index.html +1 -1
  164. package/coverage/lcov-report/map/api/services/features/features.hooks.js.html +2 -2
  165. package/coverage/lcov-report/map/api/services/features/index.html +1 -1
  166. package/coverage/lcov-report/map/api/services/geocoder/geocoder.hooks.js.html +1 -1
  167. package/coverage/lcov-report/map/api/services/geocoder/geocoder.service.js.html +1 -1
  168. package/coverage/lcov-report/map/api/services/geocoder/index.html +1 -1
  169. package/coverage/lcov-report/map/api/services/index.html +1 -1
  170. package/coverage/lcov-report/map/api/services/index.js.html +1 -1
  171. package/coverage/lcov-report/map/common/dynamic-grid-source.js.html +1 -1
  172. package/coverage/lcov-report/map/common/errors.js.html +1 -1
  173. package/coverage/lcov-report/map/common/geotiff-grid-source.js.html +1 -1
  174. package/coverage/lcov-report/map/common/grid.js.html +1 -1
  175. package/coverage/lcov-report/map/common/index.html +12 -12
  176. package/coverage/lcov-report/map/common/index.js.html +1 -1
  177. package/coverage/lcov-report/map/common/meteo-model-grid-source.js.html +1 -1
  178. package/coverage/lcov-report/map/common/moment-utils.js.html +1 -1
  179. package/coverage/lcov-report/map/common/opendap-grid-source.js.html +1 -1
  180. package/coverage/lcov-report/map/common/opendap-utils.js.html +1 -1
  181. package/coverage/lcov-report/map/common/permissions.js.html +1 -1
  182. package/coverage/lcov-report/map/common/time-based-grid-source.js.html +1 -1
  183. package/coverage/lcov-report/map/common/tms-utils.js.html +1 -1
  184. package/coverage/lcov-report/map/common/wcs-grid-source.js.html +1 -1
  185. package/coverage/lcov-report/map/common/wcs-utils.js.html +1 -1
  186. package/coverage/lcov-report/map/common/weacast-grid-source.js.html +1 -1
  187. package/coverage/lcov-report/map/common/wfs-utils.js.html +8 -5
  188. package/coverage/lcov-report/map/common/wms-utils.js.html +1 -1
  189. package/coverage/lcov-report/map/common/wmts-utils.js.html +71 -11
  190. package/coverage/lcov.info +3742 -3949
  191. package/coverage/map/api/hooks/hooks.catalog.js.html +1 -1
  192. package/coverage/map/api/hooks/hooks.query.js.html +118 -37
  193. package/coverage/map/api/hooks/index.html +7 -7
  194. package/coverage/map/api/hooks/index.js.html +1 -1
  195. package/coverage/map/api/index.html +1 -1
  196. package/coverage/map/api/index.js.html +1 -1
  197. package/coverage/map/api/marshall.js.html +1 -1
  198. package/coverage/map/api/models/alerts.model.mongodb.js.html +1 -1
  199. package/coverage/map/api/models/catalog.model.mongodb.js.html +1 -1
  200. package/coverage/map/api/models/features.model.mongodb.js.html +1 -1
  201. package/coverage/map/api/models/index.html +1 -1
  202. package/coverage/map/api/services/alerts/alerts.hooks.js.html +1 -1
  203. package/coverage/map/api/services/alerts/alerts.service.js.html +1 -1
  204. package/coverage/map/api/services/alerts/index.html +1 -1
  205. package/coverage/map/api/services/catalog/catalog.hooks.js.html +1 -1
  206. package/coverage/map/api/services/catalog/index.html +1 -1
  207. package/coverage/map/api/services/daptiles/daptiles.service.js.html +1 -1
  208. package/coverage/map/api/services/daptiles/index.html +1 -1
  209. package/coverage/map/api/services/features/features.hooks.js.html +2 -2
  210. package/coverage/map/api/services/features/index.html +1 -1
  211. package/coverage/map/api/services/geocoder/geocoder.hooks.js.html +1 -1
  212. package/coverage/map/api/services/geocoder/geocoder.service.js.html +1 -1
  213. package/coverage/map/api/services/geocoder/index.html +1 -1
  214. package/coverage/map/api/services/index.html +1 -1
  215. package/coverage/map/api/services/index.js.html +1 -1
  216. package/coverage/map/common/dynamic-grid-source.js.html +1 -1
  217. package/coverage/map/common/errors.js.html +1 -1
  218. package/coverage/map/common/geotiff-grid-source.js.html +1 -1
  219. package/coverage/map/common/grid.js.html +1 -1
  220. package/coverage/map/common/index.html +12 -12
  221. package/coverage/map/common/index.js.html +1 -1
  222. package/coverage/map/common/meteo-model-grid-source.js.html +1 -1
  223. package/coverage/map/common/moment-utils.js.html +1 -1
  224. package/coverage/map/common/opendap-grid-source.js.html +1 -1
  225. package/coverage/map/common/opendap-utils.js.html +1 -1
  226. package/coverage/map/common/permissions.js.html +1 -1
  227. package/coverage/map/common/time-based-grid-source.js.html +1 -1
  228. package/coverage/map/common/tms-utils.js.html +1 -1
  229. package/coverage/map/common/wcs-grid-source.js.html +1 -1
  230. package/coverage/map/common/wcs-utils.js.html +1 -1
  231. package/coverage/map/common/weacast-grid-source.js.html +1 -1
  232. package/coverage/map/common/wfs-utils.js.html +8 -5
  233. package/coverage/map/common/wms-utils.js.html +1 -1
  234. package/coverage/map/common/wmts-utils.js.html +71 -11
  235. package/extras/icons/kanban.png +0 -0
  236. package/extras/tours/core/add-member.js +10 -1
  237. package/extras/tours/core/{tag-member.js → edit-member-tags.js} +4 -3
  238. package/extras/tours/core/groups.js +8 -2
  239. package/extras/tours/core/members.js +11 -21
  240. package/extras/tours/core/tags.js +7 -1
  241. package/extras/tours/map/catalog-categories.js +4 -4
  242. package/extras/tours/map/catalog-panel.js +16 -16
  243. package/extras/tours/map/favorite-views.js +3 -3
  244. package/lib/core/api/hooks/hooks.authorisations.js +149 -140
  245. package/lib/core/api/hooks/hooks.authorisations.js.map +1 -1
  246. package/lib/core/api/hooks/hooks.organisations.js +1 -23
  247. package/lib/core/api/hooks/hooks.organisations.js.map +1 -1
  248. package/lib/core/api/hooks/hooks.query.js +22 -0
  249. package/lib/core/api/hooks/hooks.query.js.map +1 -1
  250. package/lib/core/api/hooks/hooks.users.js +34 -18
  251. package/lib/core/api/hooks/hooks.users.js.map +1 -1
  252. package/lib/core/api/services/authorisations/authorisations.service.js +34 -25
  253. package/lib/core/api/services/authorisations/authorisations.service.js.map +1 -1
  254. package/lib/core/client/api.js +1 -0
  255. package/lib/core/client/api.js.map +1 -1
  256. package/lib/core/client/components/account/KAccountDZ.vue +3 -4
  257. package/lib/core/client/components/account/KAccountDevices.vue +5 -6
  258. package/lib/core/client/components/account/KDeviceCard.vue +2 -1
  259. package/lib/core/client/components/account/KIdentityPanel.vue +1 -7
  260. package/lib/core/client/components/collection/KBoard.vue +26 -155
  261. package/lib/core/client/components/collection/KCard.vue +144 -42
  262. package/lib/core/client/components/collection/KCardSection.vue +52 -0
  263. package/lib/core/client/components/collection/KColumn.vue +181 -0
  264. package/lib/core/client/components/collection/KGrid.vue +13 -18
  265. package/lib/core/client/components/collection/KHistory.vue +61 -89
  266. package/lib/core/client/components/collection/KHistoryEntry.vue +90 -66
  267. package/lib/core/client/components/collection/KItem.vue +21 -2
  268. package/lib/core/client/components/collection/KList.vue +9 -12
  269. package/lib/core/client/components/collection/KTable.vue +33 -39
  270. package/lib/core/client/components/collection/index.js +6 -1
  271. package/lib/core/client/components/collection/index.js.map +1 -1
  272. package/lib/core/client/components/editor/KEditor.vue +0 -6
  273. package/lib/core/client/components/editor/KModalEditor.vue +4 -4
  274. package/lib/core/client/components/editor/KSettingsEditor.vue +49 -0
  275. package/lib/core/client/components/form/KAttachmentField.vue +10 -10
  276. package/lib/core/client/components/form/KChipsField.vue +28 -23
  277. package/lib/core/client/components/form/KColorField.vue +30 -25
  278. package/lib/core/client/components/form/KFileField.vue +11 -40
  279. package/lib/core/client/components/form/KForm.vue +0 -12
  280. package/lib/core/client/components/form/KIconField.vue +1 -0
  281. package/lib/core/client/components/form/KItemField.vue +6 -2
  282. package/lib/core/client/components/form/KRoleField.vue +56 -0
  283. package/lib/core/client/components/form/KSelectField.vue +16 -1
  284. package/lib/core/client/components/form/KView.vue +5 -14
  285. package/lib/core/client/components/frame/KAction.vue +18 -12
  286. package/lib/core/client/components/frame/KAvatar.vue +3 -3
  287. package/lib/core/client/components/frame/KChart.vue +60 -0
  288. package/lib/core/client/components/frame/KChipsPane.vue +80 -0
  289. package/lib/core/client/components/frame/KContent.vue +1 -1
  290. package/lib/core/client/components/frame/KModal.vue +30 -44
  291. package/lib/core/client/components/frame/KPanel.vue +1 -1
  292. package/lib/core/client/components/frame/{KMenu.vue → KPopupAction.vue} +6 -7
  293. package/lib/core/client/components/frame/KSpot.vue +31 -0
  294. package/lib/core/client/components/frame/KStamp.vue +62 -0
  295. package/lib/core/client/components/frame/index.js +56 -1
  296. package/lib/core/client/components/frame/index.js.map +1 -1
  297. package/lib/core/client/components/input/KColorChooser.vue +16 -8
  298. package/lib/core/client/components/input/KIconChooser.vue +2 -1
  299. package/lib/core/client/components/input/KOptionsChooser.vue +2 -2
  300. package/lib/core/client/components/input/KUploader.vue +14 -5
  301. package/lib/core/client/components/layout/KAbout.vue +9 -3
  302. package/lib/core/client/components/layout/KFab.vue +1 -1
  303. package/lib/core/client/components/layout/KPage.vue +44 -19
  304. package/lib/core/client/components/layout/KTour.vue +2 -2
  305. package/lib/core/client/components/layout/KWelcome.vue +13 -12
  306. package/lib/core/client/components/layout/KWindow.vue +1 -1
  307. package/lib/core/client/components/media/KImageViewer.vue +9 -7
  308. package/lib/core/client/components/media/KMediaBrowser.vue +12 -8
  309. package/lib/core/client/components/menu/KMenu.vue +103 -0
  310. package/lib/core/client/components/team/KAddMember.vue +17 -9
  311. package/lib/core/client/components/team/KChangeRole.vue +5 -7
  312. package/lib/core/client/components/team/KGroupCard.vue +34 -51
  313. package/lib/core/client/components/team/KGroupsActivity.vue +9 -2
  314. package/lib/core/client/components/team/KJoinGroup.vue +5 -7
  315. package/lib/core/client/components/team/KMemberCard.vue +104 -63
  316. package/lib/core/client/components/team/KMembersActivity.vue +9 -2
  317. package/lib/core/client/components/team/KOrganisationsActivity.vue +8 -1
  318. package/lib/core/client/components/team/KTagCard.vue +26 -26
  319. package/lib/core/client/components/team/KTagsActivity.vue +9 -2
  320. package/lib/core/client/components/time/KTimeRange.vue +144 -0
  321. package/lib/core/client/components/viewer/KModalViewer.vue +6 -0
  322. package/lib/core/client/components/viewer/KViewer.vue +0 -6
  323. package/lib/core/client/i18n/core_en.json +138 -94
  324. package/lib/core/client/i18n/core_fr.json +61 -17
  325. package/lib/core/client/index.js +46 -14
  326. package/lib/core/client/index.js.map +1 -1
  327. package/lib/core/client/layout.js +8 -1
  328. package/lib/core/client/layout.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/reader.js +54 -0
  350. package/lib/core/client/reader.js.map +1 -0
  351. package/lib/core/client/readers/index.js +30 -0
  352. package/lib/core/client/readers/index.js.map +1 -0
  353. package/lib/core/client/readers/reader.csv.js +43 -0
  354. package/lib/core/client/readers/reader.csv.js.map +1 -0
  355. package/lib/core/client/readers/reader.json.js +38 -0
  356. package/lib/core/client/readers/reader.json.js.map +1 -0
  357. package/lib/core/client/services/index.js +23 -0
  358. package/lib/core/client/services/index.js.map +1 -1
  359. package/lib/core/client/services/local-settings.service.js +4 -0
  360. package/lib/core/client/services/local-settings.service.js.map +1 -1
  361. package/lib/core/client/time.js +131 -0
  362. package/lib/core/client/time.js.map +1 -0
  363. package/lib/core/common/permissions.js +65 -23
  364. package/lib/core/common/permissions.js.map +1 -1
  365. package/lib/core/common/schemas/groups.create.json +1 -1
  366. package/lib/core/common/schemas/groups.update.json +1 -1
  367. package/lib/core/common/schemas/organisations.create.json +1 -1
  368. package/lib/core/common/schemas/organisations.update.json +2 -2
  369. package/lib/core/common/schemas/settings.update.json +139 -0
  370. package/lib/core/common/schemas/tags.update.json +9 -1
  371. package/lib/map/api/hooks/hooks.query.js +55 -29
  372. package/lib/map/api/hooks/hooks.query.js.map +1 -1
  373. package/lib/map/api/services/features/features.hooks.js +1 -1
  374. package/lib/map/api/services/features/features.hooks.js.map +1 -1
  375. package/lib/map/client/components/KCaptureToolbar.vue +156 -0
  376. package/lib/map/client/components/KColorLegend.vue +25 -23
  377. package/lib/map/client/components/KFavoriteViews.vue +71 -35
  378. package/lib/map/client/components/KFeaturesChart.vue +11 -9
  379. package/lib/map/client/components/KFeaturesFilter.vue +18 -8
  380. package/lib/map/client/components/KFeaturesTable.vue +27 -2
  381. package/lib/map/client/components/KLayerEditionToolbar.vue +51 -0
  382. package/lib/map/client/components/KLayerStyleEditor.vue +12 -5
  383. package/lib/map/client/components/KLayerStyleForm.vue +44 -33
  384. package/lib/map/client/components/KLocationInput.vue +126 -65
  385. package/lib/map/client/components/KLocationMap.vue +199 -84
  386. package/lib/map/client/components/KMeasureTool.vue +340 -0
  387. package/lib/map/client/components/KPositionIndicator.vue +1 -0
  388. package/lib/map/client/components/KTimeline.vue +41 -37
  389. package/lib/map/client/components/KUrlLegend.vue +21 -19
  390. package/lib/map/client/components/catalog/KBaseLayersSelector.vue +105 -0
  391. package/lib/map/client/components/catalog/KCatalog.vue +14 -2
  392. package/lib/map/client/components/catalog/KConnectLayer.vue +31 -11
  393. package/lib/map/client/components/catalog/KCreateLayer.vue +37 -14
  394. package/lib/map/client/components/catalog/KImportLayer.vue +33 -40
  395. package/lib/map/client/components/catalog/KLayerCategories.vue +86 -62
  396. package/lib/map/client/components/catalog/KLayersSelector.vue +44 -42
  397. package/lib/map/client/components/catalog/KWeatherLayersSelector.vue +3 -3
  398. package/lib/map/client/components/form/KLocationField.vue +1 -1
  399. package/lib/map/client/components/form/KOwsLayerField.vue +7 -0
  400. package/lib/map/client/components/form/KOwsServiceField.vue +1 -0
  401. package/lib/map/client/components/widget/KInformationBox.vue +10 -16
  402. package/lib/map/client/components/widget/KMapillaryViewer.vue +59 -49
  403. package/lib/map/client/components/widget/KTimeSeries.vue +119 -31
  404. package/lib/map/client/i18n/map_en.json +105 -20
  405. package/lib/map/client/i18n/map_fr.json +107 -23
  406. package/lib/map/client/init.js +24 -7
  407. package/lib/map/client/init.js.map +1 -1
  408. package/lib/map/client/leaflet/GSMaPLayer.js +4 -9
  409. package/lib/map/client/leaflet/GSMaPLayer.js.map +1 -1
  410. package/lib/map/client/leaflet/MaskLayer.js +73 -0
  411. package/lib/map/client/leaflet/MaskLayer.js.map +1 -0
  412. package/lib/map/client/mixins/globe/mixin.base-globe.js +7 -6
  413. package/lib/map/client/mixins/globe/mixin.base-globe.js.map +1 -1
  414. package/lib/map/client/mixins/globe/mixin.geojson-layers.js +7 -9
  415. package/lib/map/client/mixins/globe/mixin.geojson-layers.js.map +1 -1
  416. package/lib/map/client/mixins/globe/mixin.popup.js +4 -0
  417. package/lib/map/client/mixins/globe/mixin.popup.js.map +1 -1
  418. package/lib/map/client/mixins/globe/mixin.tooltip.js +4 -0
  419. package/lib/map/client/mixins/globe/mixin.tooltip.js.map +1 -1
  420. package/lib/map/client/mixins/index.js +8 -13
  421. package/lib/map/client/mixins/index.js.map +1 -1
  422. package/lib/map/client/mixins/map/mixin.base-map.js +71 -8
  423. package/lib/map/client/mixins/map/mixin.base-map.js.map +1 -1
  424. package/lib/map/client/mixins/map/mixin.canvas-layers.js +276 -51
  425. package/lib/map/client/mixins/map/mixin.canvas-layers.js.map +1 -1
  426. package/lib/map/client/mixins/map/mixin.edit-layers.js +218 -121
  427. package/lib/map/client/mixins/map/mixin.edit-layers.js.map +1 -1
  428. package/lib/map/client/mixins/map/mixin.file-layers.js +46 -93
  429. package/lib/map/client/mixins/map/mixin.file-layers.js.map +1 -1
  430. package/lib/map/client/mixins/map/mixin.geojson-layers.js +22 -11
  431. package/lib/map/client/mixins/map/mixin.geojson-layers.js.map +1 -1
  432. package/lib/map/client/mixins/map/mixin.georaster-layers.js +7 -4
  433. package/lib/map/client/mixins/map/mixin.georaster-layers.js.map +1 -1
  434. package/lib/map/client/mixins/map/mixin.gsmap-layers.js +3 -3
  435. package/lib/map/client/mixins/map/mixin.gsmap-layers.js.map +1 -1
  436. package/lib/map/client/mixins/map/mixin.heatmap-layers.js +8 -10
  437. package/lib/map/client/mixins/map/mixin.heatmap-layers.js.map +1 -1
  438. package/lib/map/client/mixins/map/mixin.mapillary-layers.js +25 -40
  439. package/lib/map/client/mixins/map/mixin.mapillary-layers.js.map +1 -1
  440. package/lib/map/client/mixins/map/mixin.popup.js +4 -0
  441. package/lib/map/client/mixins/map/mixin.popup.js.map +1 -1
  442. package/lib/map/client/mixins/map/mixin.tiled-mesh-layers.js +5 -3
  443. package/lib/map/client/mixins/map/mixin.tiled-mesh-layers.js.map +1 -1
  444. package/lib/map/client/mixins/map/mixin.tiled-wind-layers.js +5 -3
  445. package/lib/map/client/mixins/map/mixin.tiled-wind-layers.js.map +1 -1
  446. package/lib/map/client/mixins/map/mixin.tooltip.js +4 -0
  447. package/lib/map/client/mixins/map/mixin.tooltip.js.map +1 -1
  448. package/lib/map/client/mixins/mixin.activity.js +62 -68
  449. package/lib/map/client/mixins/mixin.activity.js.map +1 -1
  450. package/lib/map/client/mixins/mixin.context.js +26 -3
  451. package/lib/map/client/mixins/mixin.context.js.map +1 -1
  452. package/lib/map/client/mixins/mixin.feature-selection.js +8 -10
  453. package/lib/map/client/mixins/mixin.feature-selection.js.map +1 -1
  454. package/lib/map/client/mixins/mixin.feature-service.js +9 -7
  455. package/lib/map/client/mixins/mixin.feature-service.js.map +1 -1
  456. package/lib/map/client/mixins/mixin.infobox.js +4 -0
  457. package/lib/map/client/mixins/mixin.infobox.js.map +1 -1
  458. package/lib/map/client/mixins/mixin.weacast.js +6 -4
  459. package/lib/map/client/mixins/mixin.weacast.js.map +1 -1
  460. package/lib/map/client/pixi-utils.js +9 -0
  461. package/lib/map/client/pixi-utils.js.map +1 -1
  462. package/lib/map/client/readers/index.js +42 -0
  463. package/lib/map/client/readers/index.js.map +1 -0
  464. package/lib/map/client/readers/reader.geojson.js +59 -0
  465. package/lib/map/client/readers/reader.geojson.js.map +1 -0
  466. package/lib/map/client/readers/reader.gpx.js +41 -0
  467. package/lib/map/client/readers/reader.gpx.js.map +1 -0
  468. package/lib/map/client/readers/reader.kml.js +41 -0
  469. package/lib/map/client/readers/reader.kml.js.map +1 -0
  470. package/lib/map/client/utils.js +52 -1
  471. package/lib/map/client/utils.js.map +1 -1
  472. package/lib/map/common/wfs-utils.js +1 -1
  473. package/lib/map/common/wfs-utils.js.map +1 -1
  474. package/lib/map/common/wmts-utils.js +31 -7
  475. package/lib/map/common/wmts-utils.js.map +1 -1
  476. package/lib/test/client/core/account.js +100 -0
  477. package/lib/test/client/core/account.js.map +1 -0
  478. package/lib/test/client/core/api.js +400 -0
  479. package/lib/test/client/core/api.js.map +1 -0
  480. package/lib/test/client/core/collection.js +109 -0
  481. package/lib/test/client/core/collection.js.map +1 -0
  482. package/lib/test/client/core/index.js +90 -0
  483. package/lib/test/client/core/index.js.map +1 -0
  484. package/lib/test/client/core/layout.js +221 -0
  485. package/lib/test/client/core/layout.js.map +1 -0
  486. package/lib/test/client/core/runner.js +203 -0
  487. package/lib/test/client/core/runner.js.map +1 -0
  488. package/lib/test/client/core/screens.js +68 -0
  489. package/lib/test/client/core/screens.js.map +1 -0
  490. package/lib/test/client/core/utils.js +304 -0
  491. package/lib/test/client/core/utils.js.map +1 -0
  492. package/lib/test/client/index.js +20 -0
  493. package/lib/test/client/index.js.map +1 -0
  494. package/lib/test/client/map/catalog.js +192 -0
  495. package/lib/test/client/map/catalog.js.map +1 -0
  496. package/lib/test/client/map/controls.js +54 -0
  497. package/lib/test/client/map/controls.js.map +1 -0
  498. package/lib/test/client/map/index.js +30 -0
  499. package/lib/test/client/map/index.js.map +1 -0
  500. package/package.json +18 -9
  501. package/test.client.js +1 -0
  502. package/tests/core/test-log-2021-09-02.log +47 -0
  503. package/tests/map/test-log-%DATE%.logYYYY-09-DD +6 -0
  504. package/tests/map/test-log-2021-09-02.log +3 -0
  505. package/.nyc_output/5baea3f8-cf8e-4c76-8ccf-0e48b6f16fa4.json +0 -1
  506. package/.nyc_output/dddde6b5-9024-4b0e-8d8b-4502d437b8a4.json +0 -1
  507. package/.nyc_output/ef5e94ba-9a99-4fb6-ab1d-1a974112bb83.json +0 -1
  508. package/.nyc_output/fd4681f8-5f41-4f17-b393-9f399b24c128.json +0 -1
  509. package/.nyc_output/processinfo/0d403586-0c7c-4336-94d1-a49e9f02a905.json +0 -1
  510. package/.nyc_output/processinfo/21dd57bd-48c5-41c8-8800-252db32a9366.json +0 -1
  511. package/.nyc_output/processinfo/3eb3a2ca-53c2-4551-ba6b-adf70f9a53cd.json +0 -1
  512. package/.nyc_output/processinfo/5baea3f8-cf8e-4c76-8ccf-0e48b6f16fa4.json +0 -1
  513. package/.nyc_output/processinfo/dddde6b5-9024-4b0e-8d8b-4502d437b8a4.json +0 -1
  514. package/.nyc_output/processinfo/ef5e94ba-9a99-4fb6-ab1d-1a974112bb83.json +0 -1
  515. package/.nyc_output/processinfo/fd4681f8-5f41-4f17-b393-9f399b24c128.json +0 -1
  516. package/extras/testcafe/Dockerfile +0 -48
  517. package/extras/testcafe/docker-entrypoint.sh +0 -27
  518. package/extras/testcafe/page-models/core/account.js +0 -75
  519. package/extras/testcafe/page-models/core/base-collection.js +0 -41
  520. package/extras/testcafe/page-models/core/base-page.js +0 -25
  521. package/extras/testcafe/page-models/core/groups.js +0 -36
  522. package/extras/testcafe/page-models/core/index.js +0 -140
  523. package/extras/testcafe/page-models/core/layout.js +0 -145
  524. package/extras/testcafe/page-models/core/members.js +0 -98
  525. package/extras/testcafe/page-models/core/organisations.js +0 -76
  526. package/extras/testcafe/page-models/core/screens.js +0 -99
  527. package/extras/testcafe/page-models/core/tags.js +0 -21
  528. package/extras/testcafe/page-models/map/add-layer.js +0 -51
  529. package/extras/testcafe/page-models/map/catalog.js +0 -132
  530. package/extras/testcafe/page-models/map/index.js +0 -36
  531. package/extras/testcafe/page-models/map/map-activity.js +0 -42
  532. package/extras/testcafe/page-models/map/timeline.js +0 -67
  533. package/lib/core/client/components/frame/KLabel.vue +0 -56
  534. package/lib/core/client/components/team/KTagsPane.vue +0 -35
  535. package/lib/map/client/leaflet/TiledMapillaryLayer.js +0 -137
  536. package/lib/map/client/leaflet/TiledMapillaryLayer.js.map +0 -1
  537. package/lib/map/client/mixins/mixin.time.js +0 -73
  538. package/lib/map/client/mixins/mixin.time.js.map +0 -1
  539. package/tests/core/account.test.js +0 -423
  540. package/tests/core/client.test.js.skip +0 -37
  541. package/tests/core/config/default.js +0 -96
  542. package/tests/core/config/email-templates/confirmInvitation/html.ejs +0 -18
  543. package/tests/core/config/email-templates/identityChange/html.ejs +0 -12
  544. package/tests/core/config/email-templates/newDevice/html.ejs +0 -7
  545. package/tests/core/config/email-templates/passwordChange/html.ejs +0 -5
  546. package/tests/core/config/email-templates/resendVerifySignup/html.ejs +0 -10
  547. package/tests/core/config/email-templates/resetPwd/html.ejs +0 -5
  548. package/tests/core/config/email-templates/sendResetPwd/html.ejs +0 -8
  549. package/tests/core/config/email-templates/verifySignup/html.ejs +0 -3
  550. package/tests/core/data/10k_most_common_passwords.txt +0 -10000
  551. package/tests/core/data/logo.png +0 -0
  552. package/tests/core/hooks.test.js +0 -175
  553. package/tests/core/index.test.js +0 -432
  554. package/tests/core/notifications.test.js +0 -465
  555. package/tests/core/storage.test.js +0 -134
  556. package/tests/core/team.test.js +0 -610
  557. package/tests/core/utils.js +0 -62
  558. package/tests/map/alerts.test.js +0 -554
  559. package/tests/map/config/default.js +0 -112
  560. package/tests/map/config/layers.json +0 -37
  561. package/tests/map/daptiles.test.js +0 -41
  562. package/tests/map/data/DescribeCoverage.xml +0 -55
  563. package/tests/map/data/GetCoverage.tif +0 -0
  564. package/tests/map/data/adsb.observations.json +0 -132
  565. package/tests/map/data/dataset.grb.das +0 -55
  566. package/tests/map/data/dataset.grb.dds +0 -17
  567. package/tests/map/data/dataset.grb.dods +0 -0
  568. package/tests/map/data/lat_lon_bounds.grb.dods +0 -0
  569. package/tests/map/data/subdataset.grb.dods +0 -0
  570. package/tests/map/data/vigicrues.observations.json +0 -47042
  571. package/tests/map/data/vigicrues.stations.json +0 -15422
  572. package/tests/map/data/zones.json +0 -1228
  573. package/tests/map/forecast-data/gfs-world/u-wind/2021-07-15_12-00-00_2021-07-15_12-00-00.grib +0 -0
  574. package/tests/map/forecast-data/gfs-world/v-wind/2021-07-15_12-00-00_2021-07-15_12-00-00.grib +0 -0
  575. package/tests/map/grid-sources.test.js +0 -304
  576. package/tests/map/hooks.test.js +0 -96
  577. package/tests/map/index.test.js +0 -333
@@ -28,10 +28,6 @@ const baseFieldMixin = {
28
28
  type: Boolean,
29
29
  default: false
30
30
  },
31
- display: {
32
- type: Object,
33
- required: true
34
- },
35
31
  readOnly: {
36
32
  type: Boolean,
37
33
  default: false
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../core/client/mixins/mixin.base-field.js"],"names":["baseFieldMixin","props","values","type","Object","default","properties","required","Boolean","display","readOnly","computed","label","_","get","field","$i18n","i18next","exists","$t","helper","hasError","isEmpty","error","errorLabel","disabled","data","model","emptyModel","watch","updateValue","name","clear","methods","value","isNil","fill","isEqual","validate","invalidate","onChanged","$nextTick","$emit","apply","object","set","submitted","created"],"mappings":"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","file":"mixin.base-field.js","sourcesContent":["import _ from 'lodash'\r\n\r\nconst baseFieldMixin = {\r\n props: {\r\n values: {\r\n type: Object,\r\n default: () => { return null }\r\n },\r\n properties: {\r\n type: Object,\r\n required: true\r\n },\r\n required: {\r\n type: Boolean,\r\n default: false\r\n },\r\n display: {\r\n type: Object,\r\n required: true\r\n },\r\n readOnly: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n computed: {\r\n label () {\r\n // Check if we have a translation key or directly the label content\r\n const label = _.get(this.properties.field, 'label', '')\r\n return (this.$i18n.i18next.exists(label) ? this.$t(label) : label)\r\n },\r\n helper () {\r\n // Check if we have a translation key or directly the helper content\r\n const helper = _.get(this.properties.field, 'helper', '')\r\n return (this.$i18n.i18next.exists(helper) ? this.$t(helper) : helper)\r\n },\r\n hasError () {\r\n return !_.isEmpty(this.error)\r\n },\r\n errorLabel () {\r\n // Check for overriden error label\r\n let error = _.get(this.properties.field, 'errorLabel', '')\r\n // If not use default validator error messages\r\n if (!error) error = this.error\r\n // Else check if we have a translation key or directly the error content\r\n return (this.$i18n.i18next.exists(error) ? this.$t(error) : error)\r\n },\r\n disabled () {\r\n return _.get(this.properties.field, 'disabled', false)\r\n }\r\n },\r\n data () {\r\n return {\r\n // The model to used for data binding with the field\r\n model: this.emptyModel(),\r\n // The error message\r\n error: ''\r\n }\r\n },\r\n watch: {\r\n values: function () {\r\n if (this.values) this.updateValue(_.get(this.values, this.properties.name))\r\n else this.clear()\r\n }\r\n },\r\n methods: {\r\n updateValue (value) {\r\n if (_.isNil(value)) this.clear()\r\n else this.fill(value)\r\n },\r\n emptyModel () {\r\n return ''\r\n },\r\n isEmpty () {\r\n return _.isEqual(this.model, this.emptyModel())\r\n },\r\n value () {\r\n return this.model\r\n },\r\n fill (value) {\r\n this.model = value\r\n this.error = ''\r\n },\r\n clear () {\r\n this.fill(_.get(this.properties, 'default', this.emptyModel()))\r\n },\r\n validate () {\r\n this.error = ''\r\n },\r\n invalidate (error) {\r\n this.error = error\r\n },\r\n async onChanged () {\r\n // Tell the form that this field has a new value.\r\n // Consequently the form will validate or invalidate the field\r\n // Warning: This method must be called once the form is mounted\r\n // We need to force a refresh so that the model is correctly updated by Vuejs\r\n await this.$nextTick()\r\n this.$emit('field-changed', this.properties.name, this.model)\r\n },\r\n apply (object, field) {\r\n // To be overloaded if you need to perform specific operations before the form has been submitted\r\n // By default simply set the current value on the given object field to apply the form\r\n _.set(object, field, this.value())\r\n },\r\n submitted (object, field) {\r\n // To be overloaded if you need to perform specific operations after the form has been submitted\r\n }\r\n },\r\n created () {\r\n if (this.values) this.updateValue(_.get(this.values, this.properties.name))\r\n }\r\n}\r\n\r\nexport default baseFieldMixin\r\n"]}
1
+ {"version":3,"sources":["../../../../core/client/mixins/mixin.base-field.js"],"names":["baseFieldMixin","props","values","type","Object","default","properties","required","Boolean","readOnly","computed","label","_","get","field","$i18n","i18next","exists","$t","helper","hasError","isEmpty","error","errorLabel","disabled","data","model","emptyModel","watch","updateValue","name","clear","methods","value","isNil","fill","isEqual","validate","invalidate","onChanged","$nextTick","$emit","apply","object","set","submitted","created"],"mappings":"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","file":"mixin.base-field.js","sourcesContent":["import _ from 'lodash'\r\n\r\nconst baseFieldMixin = {\r\n props: {\r\n values: {\r\n type: Object,\r\n default: () => { return null }\r\n },\r\n properties: {\r\n type: Object,\r\n required: true\r\n },\r\n required: {\r\n type: Boolean,\r\n default: false\r\n },\r\n readOnly: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n computed: {\r\n label () {\r\n // Check if we have a translation key or directly the label content\r\n const label = _.get(this.properties.field, 'label', '')\r\n return (this.$i18n.i18next.exists(label) ? this.$t(label) : label)\r\n },\r\n helper () {\r\n // Check if we have a translation key or directly the helper content\r\n const helper = _.get(this.properties.field, 'helper', '')\r\n return (this.$i18n.i18next.exists(helper) ? this.$t(helper) : helper)\r\n },\r\n hasError () {\r\n return !_.isEmpty(this.error)\r\n },\r\n errorLabel () {\r\n // Check for overriden error label\r\n let error = _.get(this.properties.field, 'errorLabel', '')\r\n // If not use default validator error messages\r\n if (!error) error = this.error\r\n // Else check if we have a translation key or directly the error content\r\n return (this.$i18n.i18next.exists(error) ? this.$t(error) : error)\r\n },\r\n disabled () {\r\n return _.get(this.properties.field, 'disabled', false)\r\n }\r\n },\r\n data () {\r\n return {\r\n // The model to used for data binding with the field\r\n model: this.emptyModel(),\r\n // The error message\r\n error: ''\r\n }\r\n },\r\n watch: {\r\n values: function () {\r\n if (this.values) this.updateValue(_.get(this.values, this.properties.name))\r\n else this.clear()\r\n }\r\n },\r\n methods: {\r\n updateValue (value) {\r\n if (_.isNil(value)) this.clear()\r\n else this.fill(value)\r\n },\r\n emptyModel () {\r\n return ''\r\n },\r\n isEmpty () {\r\n return _.isEqual(this.model, this.emptyModel())\r\n },\r\n value () {\r\n return this.model\r\n },\r\n fill (value) {\r\n this.model = value\r\n this.error = ''\r\n },\r\n clear () {\r\n this.fill(_.get(this.properties, 'default', this.emptyModel()))\r\n },\r\n validate () {\r\n this.error = ''\r\n },\r\n invalidate (error) {\r\n this.error = error\r\n },\r\n async onChanged () {\r\n // Tell the form that this field has a new value.\r\n // Consequently the form will validate or invalidate the field\r\n // Warning: This method must be called once the form is mounted\r\n // We need to force a refresh so that the model is correctly updated by Vuejs\r\n await this.$nextTick()\r\n this.$emit('field-changed', this.properties.name, this.model)\r\n },\r\n apply (object, field) {\r\n // To be overloaded if you need to perform specific operations before the form has been submitted\r\n // By default simply set the current value on the given object field to apply the form\r\n _.set(object, field, this.value())\r\n },\r\n submitted (object, field) {\r\n // To be overloaded if you need to perform specific operations after the form has been submitted\r\n }\r\n },\r\n created () {\r\n if (this.values) this.updateValue(_.get(this.values, this.properties.name))\r\n }\r\n}\r\n\r\nexport default baseFieldMixin\r\n"]}
@@ -60,19 +60,13 @@ exports.default = {
60
60
  },
61
61
  computed: {
62
62
  name() {
63
- return this.getName();
63
+ return _lodash2.default.get(this.item, this.options.nameField || 'name', '');
64
64
  },
65
65
  description() {
66
- return this.getDescription();
66
+ return _lodash2.default.get(this.item, this.options.descriptionField || 'description', '');
67
67
  }
68
68
  },
69
69
  methods: {
70
- getName() {
71
- return _lodash2.default.get(this.item, this.options.nameField || 'name', '');
72
- },
73
- getDescription() {
74
- return _lodash2.default.get(this.item, this.options.descriptionField || 'description', '');
75
- },
76
70
  setActions(actions) {
77
71
  // As context is different for each item we need to clone the global action configuration
78
72
  // otheriwse context will always reference the last processed item
@@ -90,21 +84,42 @@ exports.default = {
90
84
  const actions = this.filteredActions();
91
85
  if (actions && actions.length > 0) this.setActions(actions);else this.clearActions();
92
86
  },
87
+ onItemToggled(toggled) {
88
+ this.$emit('item-toggled', this.item, toggled);
89
+ },
93
90
  onItemSelected(section) {
94
91
  this.$emit('item-selected', this.item, section);
95
92
  },
93
+ canViewItem() {
94
+ return this.$can('read', this.service, this.contextId, this.item);
95
+ },
96
96
  viewItem() {
97
97
  const path = this.$route.fullPath + `/view/${this.item._id}`;
98
98
  this.$router.push(path);
99
99
  },
100
- editItem() {
101
- const path = this.$route.fullPath + `/edit/${this.item._id}`;
102
- this.$router.push(path);
100
+ canEditItem() {
101
+ return this.$can('update', this.service, this.contextId, this.item);
102
+ },
103
+ editItem(scope = undefined, properties = undefined) {
104
+ const route = this.$route;
105
+ let subPath = 'edit/' + this.item._id;
106
+ // Add trailing / if required (as sometimes it might be already present)
107
+ if (!route.path.endsWith('/')) subPath = `/${subPath}`;
108
+ if (scope) {
109
+ if (properties) subPath += `/${properties}`;else subPath += `/${scope}`;
110
+ }
111
+ this.$router.push({
112
+ path: route.path + subPath,
113
+ params: route.params,
114
+ query: route.query
115
+ });
116
+ },
117
+ canRemoveItem() {
118
+ return this.$can('remove', this.service, this.contextId, this.item);
103
119
  },
104
120
  removeItem(prompt) {
105
- if (!['none', 'confirm', 'input'].includes(prompt)) return;
106
121
  if (prompt === 'confirm' || prompt === 'input') {
107
- const name = this.getName();
122
+ const name = this.name;
108
123
  const input = {
109
124
  type: 'text',
110
125
  model: '',
@@ -132,7 +147,7 @@ exports.default = {
132
147
  }
133
148
  },
134
149
  exportItem() {
135
- const name = this.getName();
150
+ const name = this.name;
136
151
  const file = name + '.json';
137
152
  if ((0, _quasar.exportFile)(file, JSON.stringify(this.item))) {
138
153
  this.$toast({ type: 'error', message: this.$t('mixins.baseItem.ITEM_EXPORTED', { name, file }) });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../core/client/mixins/mixin.base-item.js"],"names":["props","contextId","type","String","default","service","required","item","Object","actions","Array","filter","options","bindActions","Boolean","watch","configureActions","data","itemActions","computed","name","getName","description","getDescription","methods","_","get","nameField","descriptionField","setActions","Layout","bindContent","cloneDeep","clearActions","filteredActions","filterContent","length","onItemSelected","section","$emit","viewItem","path","$route","fullPath","_id","$router","push","editItem","removeItem","prompt","includes","input","model","isValid","val","Dialog","create","title","$t","message","html","undefined","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 this.getName()\r\n },\r\n description () {\r\n return this.getDescription()\r\n }\r\n },\r\n methods: {\r\n getName () {\r\n return _.get(this.item, this.options.nameField || 'name', '')\r\n },\r\n getDescription () {\r\n return _.get(this.item, this.options.descriptionField || 'description', '')\r\n },\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 onItemSelected (section) {\r\n this.$emit('item-selected', this.item, section)\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 editItem () {\r\n const path = this.$route.fullPath + `/edit/${this.item._id}`\r\n this.$router.push(path)\r\n },\r\n removeItem (prompt) {\r\n if (!['none', 'confirm', 'input'].includes(prompt)) return\r\n if (prompt === 'confirm' || prompt === 'input') {\r\n const name = this.getName()\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.getName()\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"]}
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","loadService","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,cAAM,MAAKC,WAAL,EAAN;AACA;AACA,cAAMC,QAAQC,GAAR,CAAY,CAChB,MAAKC,UAAL,CAAgB,MAAKR,aAAL,EAAhB,CADgB,EAEhB,MAAKS,UAAL,EAFgB,CAAZ,CAAN;AAJe;AAQhB;AAjBM;AAXa,CAAxB;;kBAgCenB,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 // When the service is available\r\n await this.loadService()\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"]}
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[perspective] : false;
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.loadService().get(this.objectId, params).then(object => {
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","loadService","get","then","catch","error"],"mappings":";;;;;;AAAA;;AAEA,MAAMA,mBAAmB;AACvBC,SAAO;AACLC,cAAU;AACRC,YAAMC,MADE;AAERC,eAAS;AAFD,KADL;AAKLC,iBAAa;AACXH,YAAMC,MADK;AAEXC,eAAS;AAFE;AALR,GADgB;AAWvBE,SAAQ;AACN,WAAO;AACLC,cAAQ;AADH,KAAP;AAGD,GAfsB;AAgBvBC,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,mBAAgBP,WAAhB,EAA6B;AAC3B,aAAO,KAAKE,MAAL,GAAc,KAAKA,MAAL,CAAYF,WAAZ,CAAd,GAAyC,KAAhD;AACD,KATM;AAUPQ,iBAAc;AACZ,UAAI,CAAC,KAAKZ,QAAV,EAAoB;AAClB,aAAKM,MAAL,GAAc,IAAd;AACA,eAAOO,QAAQC,OAAR,CAAgB,IAAhB,CAAP;AACD;AACD;AACA,YAAMC,gBAAiB,KAAKN,WAAL,OAAuB,KAAKT,QAA7B,IAA0C,CAAC,KAAKW,cAAL,CAAoB,KAAKP,WAAzB,CAAjE;AACA,UAAI,CAAC,KAAKY,aAAN,IAAuBD,aAA3B,EAA0C;AACxC,aAAKC,aAAL,GAAqB,kCAAsB,CAACF,OAAD,EAAUG,MAAV,KAAqB;AAC9D,cAAIC,SAAS,EAAb;AACA,cAAI,KAAKd,WAAT,EAAsB;AACpBc,qBAAS,EAAEC,OAAO,EAAEC,SAAS,CAAC,KAAD,EAAQ,KAAKhB,WAAb,CAAX,EAAT,EAAT;AACD;AACD,eAAKiB,WAAL,GACGC,GADH,CACO,KAAKtB,QADZ,EACsBkB,MADtB,EAEGK,IAFH,CAEQjB,UAAU;AACd,iBAAKA,MAAL,GAAcA,MAAd;AACAQ,oBAAQR,MAAR;AACD,WALH,EAMGkB,KANH,CAMSC,SAAS;AACdR,mBAAOQ,KAAP;AACD,WARH;AASD,SAdoB,CAArB;AAeD;AACD,aAAO,KAAKT,aAAZ;AACD;AAnCM;AAhBc,CAAzB;;kBAuDelB,gB","file":"mixin.object-proxy.js","sourcesContent":["import { 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 },\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 ? 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) {\r\n params = { query: { $select: ['_id', this.perspective] } }\r\n }\r\n this.loadService()\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"]}
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","includes","schemaPromise"],"mappings":";;;;;;AAAA;;AACA;;;;AAEA,MAAMA,mBAAmB;AACvBC,SAAO;AACLC,gBAAY;AACVC,YAAMC,MADI;AAEVC,eAAS;AAFC;AADP,GADgB;AAOvBC,SAAQ;AACN,WAAO;AACLC,cAAQ;AADH,KAAP;AAGD,GAXsB;AAYvBC,WAAS;AACPC,gBAAa;AACX,aAAO,KAAKF,MAAZ;AACD,KAHM;AAIPG,kBAAe;AACb,aAAO,KAAKH,MAAL,GAAc,KAAKA,MAAL,CAAYI,GAA1B,GAAgC,EAAvC;AACD,KANM;AAODC,0BAAN,CAA8BC,UAA9B,EAA0C;AAAA;;AAAA;AACxC,YAAI;AACF,gBAAKN,MAAL,GAAc,MAAM,MAAKO,KAAL,CAAWD,UAAX,EAAuB,QAAvB,CAApB;AACA;AACA;AACA,cAAI,MAAKN,MAAL,CAAYF,OAAhB,EAAyB,MAAKE,MAAL,GAAc,MAAKA,MAAL,CAAYF,OAA1B;AACzB,iBAAO,MAAKE,MAAZ;AACD,SAND,CAME,OAAOQ,KAAP,EAAc;AACdC,yBAAOC,KAAP,CAAa,OAAb,EAAsBF,KAAtB;AACA,gBAAMA,KAAN;AACD;AAVuC;AAWzC,KAlBM;AAmBDG,sBAAN,CAA0BC,IAA1B,EAAgC;AAAA;;AAAA;AAC9B,YAAI;AACF,iBAAKZ,MAAL,GAAca,KAAKC,KAAL,CAAWF,IAAX,CAAd;AACA,iBAAO,OAAKZ,MAAZ;AACD,SAHD,CAGE,OAAOQ,KAAP,EAAc;AACdC,yBAAOC,KAAP,CAAa,OAAb,EAAsBF,KAAtB;AACA,gBAAMA,KAAN;AACD;AAP6B;AAQ/B,KA3BM;AA4BPO,eAAYT,UAAZ,EAAwB;AACtB;AACA;AACA,YAAMU,gBAAgBV,cAAc,CAAC,KAAKH,WAAL,GAAmBc,QAAnB,CAA4BX,aAAa,OAAzC,CAArC;AACA,UAAI,CAAC,KAAKY,aAAN,IAAuBF,aAA3B,EAA0C;AACxC;AACA,aAAKE,aAAL,GAAqB,kCAAsB,KAAKvB,UAAL,GACvC,KAAKgB,kBAAL,CAAwB,KAAKhB,UAA7B,CADuC,GAEvC,KAAKU,sBAAL,CAA4BC,UAA5B,CAFiB,CAArB;AAGD;AACD,aAAO,KAAKY,aAAZ;AACD;AAvCM;AAZc,CAAzB;;kBAuDezB,gB","file":"mixin.schema-proxy.js","sourcesContent":["import { 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 },\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 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 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 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"]}
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
- return this._service;
20
- },
21
- getServicePath() {
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 this.getService();
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","_service","getServicePath","path","loadService","$api","serviceChanged","Error","serviceFind","params","find","serviceGet","id","get","serviceCreate","data","create","serviceUpdate","update","servicePatch","patch","serviceRemove","remove"],"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;AAWnBG,WAAS;AACPC,iBAAc;AACZ,aAAO,KAAKC,QAAZ;AACD,KAHM;AAIPC,qBAAkB;AAChB,aAAO,KAAKD,QAAL,GAAgB,KAAKA,QAAL,CAAcE,IAA9B,GAAqC,EAA5C;AACD,KANM;AAOPC,kBAAe;AACb;AACA,YAAMD,OAAO,KAAKE,IAAL,CAAUH,cAAV,CAAyB,KAAKJ,OAA9B,EAAuC,KAAKL,SAA5C,CAAb;AACA,YAAMa,iBAAiB,KAAKJ,cAAL,OAA0BC,IAAjD;AACA,UAAIG,cAAJ,EAAoB;AAClB,aAAKL,QAAL,GAAgB,KAAKI,IAAL,CAAUP,OAAV,CAAkBK,IAAlB,CAAhB;AACA,YAAI,CAAC,KAAKF,QAAV,EAAoB;AAClB,gBAAM,IAAIM,KAAJ,CAAU,oCAAoC,KAAKT,OAAnD,CAAN;AACD;AACF;AACD,aAAO,KAAKE,UAAL,EAAP;AACD,KAlBM;AAmBPQ,gBAAaC,MAAb,EAAqB;AACnB,aAAO,KAAKR,QAAL,CAAcS,IAAd,CAAmBD,MAAnB,CAAP;AACD,KArBM;AAsBPE,eAAYC,EAAZ,EAAgBH,MAAhB,EAAwB;AACtB,aAAO,KAAKR,QAAL,CAAcY,GAAd,CAAkBD,EAAlB,EAAsBH,MAAtB,CAAP;AACD,KAxBM;AAyBPK,kBAAeC,IAAf,EAAqBN,MAArB,EAA6B;AAC3B,aAAO,KAAKR,QAAL,CAAce,MAAd,CAAqBD,IAArB,EAA2BN,MAA3B,CAAP;AACD,KA3BM;AA4BPQ,kBAAeL,EAAf,EAAmBG,IAAnB,EAAyBN,MAAzB,EAAiC;AAC/B,aAAO,KAAKR,QAAL,CAAciB,MAAd,CAAqBN,EAArB,EAAyBG,IAAzB,EAA+BN,MAA/B,CAAP;AACD,KA9BM;AA+BPU,iBAAcP,EAAd,EAAkBG,IAAlB,EAAwBN,MAAxB,EAAgC;AAC9B,aAAO,KAAKR,QAAL,CAAcmB,KAAd,CAAoBR,EAApB,EAAwBG,IAAxB,EAA8BN,MAA9B,CAAP;AACD,KAjCM;AAkCPY,kBAAeT,EAAf,EAAmBH,MAAnB,EAA2B;AACzB,aAAO,KAAKR,QAAL,CAAcqB,MAAd,CAAqBV,EAArB,EAAyBH,MAAzB,CAAP;AACD;AApCM;AAXU,CAArB;;kBAmDelB,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 methods: {\r\n getService () {\r\n return this._service\r\n },\r\n getServicePath () {\r\n return this._service ? this._service.path : ''\r\n },\r\n loadService () {\r\n // Create a new mixin promise if required\r\n const path = this.$api.getServicePath(this.service, this.contextId)\r\n const serviceChanged = this.getServicePath() !== path\r\n if (serviceChanged) {\r\n this._service = this.$api.service(path)\r\n if (!this._service) {\r\n throw new Error('Cannot retrieve target service ' + this.service)\r\n }\r\n }\r\n return this.getService()\r\n },\r\n serviceFind (params) {\r\n return this._service.find(params)\r\n },\r\n serviceGet (id, params) {\r\n return this._service.get(id, params)\r\n },\r\n serviceCreate (data, params) {\r\n return this._service.create(data, params)\r\n },\r\n serviceUpdate (id, data, params) {\r\n return this._service.update(id, data, params)\r\n },\r\n servicePatch (id, data, params) {\r\n return this._service.patch(id, data, params)\r\n },\r\n serviceRemove (id, params) {\r\n return this._service.remove(id, params)\r\n }\r\n }\r\n}\r\n\r\nexport default serviceMixin\r\n"]}
1
+ {"version":3,"sources":["../../../../core/client/mixins/mixin.service.js"],"names":["serviceMixin","props","contextId","type","String","default","undefined","service","methods","getService","$api","Error"],"mappings":";;;;;AAAA,MAAMA,eAAe;AACnBC,SAAO;AACLC,eAAW;AACTC,YAAMC,MADG;AAETC,eAASC;AAFA,KADN;AAKLC,aAAS;AACPJ,YAAMC,MADC;AAEPC,eAAS;AAFF;AALJ,GADY;;AAYnBG,WAAS;AACPC,iBAAc;AACZ,YAAMF,UAAU,KAAKG,IAAL,CAAUD,UAAV,CAAqB,KAAKF,OAA1B,EAAmC,KAAKL,SAAxC,CAAhB;AACA,UAAI,CAACK,OAAL,EAAc;AACZ,cAAM,IAAII,KAAJ,CAAU,oCAAoC,KAAKJ,OAAnD,CAAN;AACD;AACD,aAAOA,OAAP;AACD;AAPM;AAZU,CAArB;;kBAuBeP,Y","file":"mixin.service.js","sourcesContent":["const serviceMixin = {\r\n props: {\r\n contextId: {\r\n type: String,\r\n default: undefined\r\n },\r\n service: {\r\n type: String,\r\n default: ''\r\n }\r\n },\r\n\r\n methods: {\r\n getService () {\r\n const service = this.$api.getService(this.service, this.contextId)\r\n if (!service) {\r\n throw new Error('Cannot retrieve target service ' + this.service)\r\n }\r\n return service\r\n }\r\n }\r\n}\r\n\r\nexport default serviceMixin\r\n"]}
@@ -0,0 +1,54 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Reader = undefined;
7
+
8
+ var _path = require('path');
9
+
10
+ var _path2 = _interopRequireDefault(_path);
11
+
12
+ var _i18next = require('i18next');
13
+
14
+ var _i18next2 = _interopRequireDefault(_i18next);
15
+
16
+ var _events = require('./events');
17
+
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+
20
+ function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
21
+
22
+ // Export singleton
23
+ const Reader = exports.Reader = {
24
+ readers: {},
25
+ register(mimeType, reader) {
26
+ this.readers[mimeType] = reader;
27
+ },
28
+ read(file, options) {
29
+ var _this = this;
30
+
31
+ return _asyncToGenerator(function* () {
32
+ const fileExtension = _path2.default.extname(file.name);
33
+ const reader = _this.readers[fileExtension];
34
+ if (reader) {
35
+ try {
36
+ const content = yield reader(file, options);
37
+ return content;
38
+ } catch (error) {
39
+ _events.Events.$emit('error', error);
40
+ throw error;
41
+ }
42
+ }
43
+ const error = {
44
+ message: _i18next2.default.t('errors.UNSUPPORTED_FILE_FORMAT', { file: file.name })
45
+ };
46
+ _events.Events.$emit('error', error);
47
+ throw new Error(error);
48
+ })();
49
+ },
50
+ getSupportedFormats() {
51
+ return Object.keys(this.readers);
52
+ }
53
+ };
54
+ //# sourceMappingURL=reader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../core/client/reader.js"],"names":["Reader","readers","register","mimeType","reader","read","file","options","fileExtension","path","extname","name","content","error","Events","$emit","message","i18next","t","Error","getSupportedFormats","Object","keys"],"mappings":";;;;;;;AAAA;;;;AACA;;;;AACA;;;;;;AAEA;AACO,MAAMA,0BAAS;AACpBC,WAAS,EADW;AAEpBC,WAAUC,QAAV,EAAoBC,MAApB,EAA4B;AAC1B,SAAKH,OAAL,CAAaE,QAAb,IAAyBC,MAAzB;AACD,GAJmB;AAKdC,MAAN,CAAYC,IAAZ,EAAkBC,OAAlB,EAA2B;AAAA;;AAAA;AACzB,YAAMC,gBAAgBC,eAAKC,OAAL,CAAaJ,KAAKK,IAAlB,CAAtB;AACA,YAAMP,SAAS,MAAKH,OAAL,CAAaO,aAAb,CAAf;AACA,UAAIJ,MAAJ,EAAY;AACV,YAAI;AACF,gBAAMQ,UAAU,MAAMR,OAAOE,IAAP,EAAaC,OAAb,CAAtB;AACA,iBAAOK,OAAP;AACD,SAHD,CAGE,OAAOC,KAAP,EAAc;AACdC,yBAAOC,KAAP,CAAa,OAAb,EAAsBF,KAAtB;AACA,gBAAMA,KAAN;AACD;AACF;AACD,YAAMA,QAAQ;AACZG,iBAASC,kBAAQC,CAAR,CAAU,gCAAV,EAA4C,EAAEZ,MAAMA,KAAKK,IAAb,EAA5C;AADG,OAAd;AAGAG,qBAAOC,KAAP,CAAa,OAAb,EAAsBF,KAAtB;AACA,YAAM,IAAIM,KAAJ,CAAUN,KAAV,CAAN;AAhByB;AAiB1B,GAtBmB;AAuBpBO,wBAAuB;AACrB,WAAOC,OAAOC,IAAP,CAAY,KAAKrB,OAAjB,CAAP;AACD;AAzBmB,CAAf","file":"reader.js","sourcesContent":["import path from 'path'\r\nimport i18next from 'i18next'\r\nimport { Events } from './events'\r\n\r\n// Export singleton\r\nexport const Reader = {\r\n readers: {},\r\n register (mimeType, reader) {\r\n this.readers[mimeType] = reader\r\n },\r\n async read (file, options) {\r\n const fileExtension = path.extname(file.name)\r\n const reader = this.readers[fileExtension]\r\n if (reader) {\r\n try {\r\n const content = await reader(file, options)\r\n return content\r\n } catch (error) {\r\n Events.$emit('error', error)\r\n throw error\r\n }\r\n }\r\n const error = {\r\n message: i18next.t('errors.UNSUPPORTED_FILE_FORMAT', { file: file.name })\r\n }\r\n Events.$emit('error', error)\r\n throw new Error(error)\r\n },\r\n getSupportedFormats () {\r\n return Object.keys(this.readers)\r\n }\r\n}\n"]}
@@ -0,0 +1,30 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+
7
+ var _reader = require('./reader.json');
8
+
9
+ Object.keys(_reader).forEach(function (key) {
10
+ if (key === "default" || key === "__esModule") return;
11
+ Object.defineProperty(exports, key, {
12
+ enumerable: true,
13
+ get: function () {
14
+ return _reader[key];
15
+ }
16
+ });
17
+ });
18
+
19
+ var _reader2 = require('./reader.csv');
20
+
21
+ Object.keys(_reader2).forEach(function (key) {
22
+ if (key === "default" || key === "__esModule") return;
23
+ Object.defineProperty(exports, key, {
24
+ enumerable: true,
25
+ get: function () {
26
+ return _reader2[key];
27
+ }
28
+ });
29
+ });
30
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../core/client/readers/index.js"],"names":[],"mappings":";;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","file":"index.js","sourcesContent":["export * from './reader.json'\r\nexport * from './reader.csv'\r\n"]}
@@ -0,0 +1,43 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.readCSV = readCSV;
7
+
8
+ var _loglevel = require('loglevel');
9
+
10
+ var _loglevel2 = _interopRequireDefault(_loglevel);
11
+
12
+ var _i18next = require('i18next');
13
+
14
+ var _i18next2 = _interopRequireDefault(_i18next);
15
+
16
+ var _papaparse = require('papaparse');
17
+
18
+ var _papaparse2 = _interopRequireDefault(_papaparse);
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
+
22
+ function readCSV(file, options) {
23
+ return new Promise((resolve, reject) => {
24
+ const reader = new FileReader();
25
+ reader.onloadend = () => {
26
+ let content = reader.result;
27
+ const papaParseOptions = Object.assign({ skipEmptyLines: true }, options);
28
+ content = _papaparse2.default.parse(content, papaParseOptions);
29
+ if (content.errors.length > 0) {
30
+ _loglevel2.default.debug(content.errors);
31
+ reject(new Error(_i18next2.default.t('errors.INVALID_CSV_FILE', { file: file.name }), { errors: content.errors }));
32
+ return;
33
+ }
34
+ resolve(content);
35
+ };
36
+ reader.onerror = error => {
37
+ _loglevel2.default.debug(error);
38
+ reject(new Error(_i18next2.default.t('errors.CANNOT_READ_FILE', { file: file.name }), { errors: error }));
39
+ };
40
+ reader.readAsText(file);
41
+ });
42
+ }
43
+ //# sourceMappingURL=reader.csv.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../core/client/readers/reader.csv.js"],"names":["readCSV","file","options","Promise","resolve","reject","reader","FileReader","onloadend","content","result","papaParseOptions","Object","assign","skipEmptyLines","Papa","parse","errors","length","logger","debug","Error","i18next","t","name","onerror","error","readAsText"],"mappings":";;;;;QAIgBA,O,GAAAA,O;;AAJhB;;;;AACA;;;;AACA;;;;;;AAEO,SAASA,OAAT,CAAkBC,IAAlB,EAAwBC,OAAxB,EAAiC;AACtC,SAAO,IAAIC,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;AACtC,UAAMC,SAAS,IAAIC,UAAJ,EAAf;AACAD,WAAOE,SAAP,GAAmB,MAAM;AACvB,UAAIC,UAAUH,OAAOI,MAArB;AACA,YAAMC,mBAAmBC,OAAOC,MAAP,CAAc,EAAEC,gBAAgB,IAAlB,EAAd,EAAwCZ,OAAxC,CAAzB;AACAO,gBAAUM,oBAAKC,KAAL,CAAWP,OAAX,EAAoBE,gBAApB,CAAV;AACA,UAAIF,QAAQQ,MAAR,CAAeC,MAAf,GAAwB,CAA5B,EAA+B;AAC7BC,2BAAOC,KAAP,CAAaX,QAAQQ,MAArB;AACAZ,eAAO,IAAIgB,KAAJ,CAAUC,kBAAQC,CAAR,CAAU,yBAAV,EAAqC,EAAEtB,MAAMA,KAAKuB,IAAb,EAArC,CAAV,EAAqE,EAAEP,QAAQR,QAAQQ,MAAlB,EAArE,CAAP;AACA;AACD;AACDb,cAAQK,OAAR;AACD,KAVD;AAWAH,WAAOmB,OAAP,GAAkBC,KAAD,IAAW;AAC1BP,yBAAOC,KAAP,CAAaM,KAAb;AACArB,aAAO,IAAIgB,KAAJ,CAAUC,kBAAQC,CAAR,CAAU,yBAAV,EAAqC,EAAEtB,MAAMA,KAAKuB,IAAb,EAArC,CAAV,EAAqE,EAAEP,QAAQS,KAAV,EAArE,CAAP;AACD,KAHD;AAIApB,WAAOqB,UAAP,CAAkB1B,IAAlB;AACD,GAlBM,CAAP;AAmBD","file":"reader.csv.js","sourcesContent":["import logger from 'loglevel'\r\nimport i18next from 'i18next'\r\nimport Papa from 'papaparse'\r\n\r\nexport function readCSV (file, options) {\r\n return new Promise((resolve, reject) => {\r\n const reader = new FileReader()\r\n reader.onloadend = () => {\r\n let content = reader.result\r\n const papaParseOptions = Object.assign({ skipEmptyLines: true }, options)\r\n content = Papa.parse(content, papaParseOptions)\r\n if (content.errors.length > 0) {\r\n logger.debug(content.errors)\r\n reject(new Error(i18next.t('errors.INVALID_CSV_FILE', { file: file.name }), { errors: content.errors }))\r\n return\r\n }\r\n resolve(content)\r\n }\r\n reader.onerror = (error) => {\r\n logger.debug(error)\r\n reject(new Error(i18next.t('errors.CANNOT_READ_FILE', { file: file.name }), { errors: error }))\n }\r\n reader.readAsText(file)\r\n })\r\n}\r\n"]}