@sumaris-net/ngx-components 18.11.0 → 18.12.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 (1383) hide show
  1. package/.editorconfig +24 -0
  2. package/.eslintrc.json +95 -0
  3. package/.gitattribute +1 -0
  4. package/.github/CONTRIBUTING.md +10 -0
  5. package/.github/ISSUE_TEMPLATE.md +6 -0
  6. package/.github/PULL_REQUEST_TEMPLATE.md +10 -0
  7. package/.github/github_disclaimer.md +14 -0
  8. package/.gitlab-ci.yml +46 -0
  9. package/.graphqlconfig +15 -0
  10. package/.prettierignore +9 -0
  11. package/.prettierrc.json +17 -0
  12. package/angular.json +236 -0
  13. package/capacitor.config.ts +49 -0
  14. package/doc/changelog.md +4 -0
  15. package/graphql.config.yml +13 -0
  16. package/ionic.config.json +7 -0
  17. package/karma.conf.js +38 -0
  18. package/ng-package.json +21 -0
  19. package/ngcc.config.js +9 -0
  20. package/package.json +132 -19
  21. package/public_api.ts +426 -0
  22. package/resources/README.md +7 -0
  23. package/resources/icon/TODO.md +11 -0
  24. package/resources/icon.png +0 -0
  25. package/resources/icon.png.md5 +1 -0
  26. package/resources/icon.xcf +0 -0
  27. package/resources/ios/icon/icon-1024.png +0 -0
  28. package/resources/ios/icon/icon-108@2x.png +0 -0
  29. package/resources/ios/icon/icon-20.png +0 -0
  30. package/resources/ios/icon/icon-20@2x.png +0 -0
  31. package/resources/ios/icon/icon-20@3x.png +0 -0
  32. package/resources/ios/icon/icon-24@2x.png +0 -0
  33. package/resources/ios/icon/icon-27.5@2x.png +0 -0
  34. package/resources/ios/icon/icon-29.png +0 -0
  35. package/resources/ios/icon/icon-29@2x.png +0 -0
  36. package/resources/ios/icon/icon-29@3x.png +0 -0
  37. package/resources/ios/icon/icon-40.png +0 -0
  38. package/resources/ios/icon/icon-40@2x.png +0 -0
  39. package/resources/ios/icon/icon-40@3x.png +0 -0
  40. package/resources/ios/icon/icon-44@2x.png +0 -0
  41. package/resources/ios/icon/icon-50.png +0 -0
  42. package/resources/ios/icon/icon-50@2x.png +0 -0
  43. package/resources/ios/icon/icon-60.png +0 -0
  44. package/resources/ios/icon/icon-60@2x.png +0 -0
  45. package/resources/ios/icon/icon-60@3x.png +0 -0
  46. package/resources/ios/icon/icon-72.png +0 -0
  47. package/resources/ios/icon/icon-72@2x.png +0 -0
  48. package/resources/ios/icon/icon-76.png +0 -0
  49. package/resources/ios/icon/icon-76@2x.png +0 -0
  50. package/resources/ios/icon/icon-83.5@2x.png +0 -0
  51. package/resources/ios/icon/icon-86@2x.png +0 -0
  52. package/resources/ios/icon/icon-98@2x.png +0 -0
  53. package/resources/ios/icon/icon-small.png +0 -0
  54. package/resources/ios/icon/icon-small@2x.png +0 -0
  55. package/resources/ios/icon/icon-small@3x.png +0 -0
  56. package/resources/ios/icon/icon.png +0 -0
  57. package/resources/ios/icon/icon@2x.png +0 -0
  58. package/resources/ios/splash/Default-1792h~iphone.png +0 -0
  59. package/resources/ios/splash/Default-2436h.png +0 -0
  60. package/resources/ios/splash/Default-2688h~iphone.png +0 -0
  61. package/resources/ios/splash/Default-568h@2x~iphone.png +0 -0
  62. package/resources/ios/splash/Default-667h.png +0 -0
  63. package/resources/ios/splash/Default-736h.png +0 -0
  64. package/resources/ios/splash/Default-Landscape-1792h~iphone.png +0 -0
  65. package/resources/ios/splash/Default-Landscape-2436h.png +0 -0
  66. package/resources/ios/splash/Default-Landscape-2688h~iphone.png +0 -0
  67. package/resources/ios/splash/Default-Landscape-736h.png +0 -0
  68. package/resources/ios/splash/Default-Landscape@2x~ipad.png +0 -0
  69. package/resources/ios/splash/Default-Landscape@~ipadpro.png +0 -0
  70. package/resources/ios/splash/Default-Landscape~ipad.png +0 -0
  71. package/resources/ios/splash/Default-Portrait@2x~ipad.png +0 -0
  72. package/resources/ios/splash/Default-Portrait@~ipadpro.png +0 -0
  73. package/resources/ios/splash/Default-Portrait~ipad.png +0 -0
  74. package/resources/ios/splash/Default@2x~iphone.png +0 -0
  75. package/resources/ios/splash/Default@2x~universal~anyany.png +0 -0
  76. package/resources/ios/splash/Default~iphone.png +0 -0
  77. package/resources/splash.png +0 -0
  78. package/resources/splash.png.md5 +1 -0
  79. package/scripts/build-android.sh +18 -0
  80. package/scripts/docker-start.sh +6 -0
  81. package/scripts/emulate-android.sh +17 -0
  82. package/scripts/env-android.sh +83 -0
  83. package/scripts/env-clean.sh +23 -0
  84. package/scripts/env-global.sh +154 -0
  85. package/scripts/install-android-sdk-tools.sh +73 -0
  86. package/scripts/ionic-update.sh +24 -0
  87. package/scripts/node/build-i18n.js +37 -0
  88. package/scripts/node/playground.ts +9 -0
  89. package/scripts/node/resources.js +108 -0
  90. package/scripts/release.sh +162 -0
  91. package/scripts/run-android.sh +59 -0
  92. package/scripts/test.sh +19 -0
  93. package/src/app/admin/admin-routing.module.ts +26 -0
  94. package/src/app/admin/admin.module.ts +20 -0
  95. package/src/app/admin/services/filter/person.filter.ts +86 -0
  96. package/src/app/admin/services/person.service.ts +244 -0
  97. package/src/app/admin/services/validator/person.validator.ts +86 -0
  98. package/src/app/admin/users/users.html +613 -0
  99. package/src/app/admin/users/users.module.ts +32 -0
  100. package/src/app/admin/users/users.scss +80 -0
  101. package/src/app/admin/users/users.ts +387 -0
  102. package/src/app/app-routing.module.ts +165 -0
  103. package/src/app/app.component.html +14 -0
  104. package/src/app/app.component.scss +4 -0
  105. package/src/app/app.component.ts +252 -0
  106. package/src/app/app.module.ts +355 -0
  107. package/src/app/core/about/about.modal.html +145 -0
  108. package/src/app/core/about/about.modal.scss +22 -0
  109. package/src/app/core/about/about.modal.ts +69 -0
  110. package/src/app/core/about/about.module.ts +14 -0
  111. package/src/app/core/account/account.module.ts +43 -0
  112. package/src/app/core/account/account.page.html +329 -0
  113. package/src/app/core/account/account.page.scss +20 -0
  114. package/src/app/core/account/account.page.ts +389 -0
  115. package/src/app/core/account/new-token.form.html +90 -0
  116. package/src/app/core/account/new-token.form.ts +99 -0
  117. package/src/app/core/account/new-token.modal.html +52 -0
  118. package/src/app/core/account/new-token.modal.ts +68 -0
  119. package/src/app/core/account/password/change-password.form.html +62 -0
  120. package/src/app/core/account/password/change-password.form.scss +0 -0
  121. package/src/app/core/account/password/change-password.form.ts +58 -0
  122. package/src/app/core/account/password/change-password.module.ts +14 -0
  123. package/src/app/core/account/password/change-password.page.html +41 -0
  124. package/src/app/core/account/password/change-password.page.scss +49 -0
  125. package/src/app/core/account/password/change-password.page.ts +158 -0
  126. package/src/app/core/account/token.table.html +160 -0
  127. package/src/app/core/account/token.table.scss +7 -0
  128. package/src/app/core/account/token.table.ts +160 -0
  129. package/src/app/core/auth/auth.form.html +108 -0
  130. package/src/app/core/auth/auth.form.scss +0 -0
  131. package/src/app/core/auth/auth.form.ts +165 -0
  132. package/src/app/core/auth/auth.modal.html +50 -0
  133. package/src/app/core/auth/auth.modal.scss +0 -0
  134. package/src/app/core/auth/auth.modal.ts +78 -0
  135. package/src/app/core/auth/auth.module.ts +35 -0
  136. package/src/app/core/auth/reset-password.modal.html +59 -0
  137. package/src/app/core/auth/reset-password.modal.ts +83 -0
  138. package/src/app/core/core.module.ts +72 -0
  139. package/src/app/core/core.testing.module.ts +80 -0
  140. package/src/app/core/form/array/form-array.ts +409 -0
  141. package/src/app/core/form/array/testing/form-array-test.module.ts +15 -0
  142. package/src/app/core/form/array/testing/form-array.test.html +196 -0
  143. package/src/app/core/form/array/testing/form-array.test.ts +119 -0
  144. package/src/app/core/form/buttons/form-buttons-bar.component.html +82 -0
  145. package/src/app/core/form/buttons/form-buttons-bar.component.scss +19 -0
  146. package/src/app/core/form/buttons/form-buttons-bar.component.ts +89 -0
  147. package/src/app/core/form/buttons/form-buttons-bar.module.ts +20 -0
  148. package/src/app/core/form/entity/editor.class.ts +295 -0
  149. package/src/app/core/form/entity/entity-editor-modal.class.ts +494 -0
  150. package/src/app/core/form/entity/entity-editor.class.ts +894 -0
  151. package/src/app/core/form/entity/entity-metadata.component.html +57 -0
  152. package/src/app/core/form/entity/entity-metadata.component.scss +40 -0
  153. package/src/app/core/form/entity/entity-metadata.component.ts +18 -0
  154. package/src/app/core/form/entity/entity.module.ts +20 -0
  155. package/src/app/core/form/entity/tab-editor.class.ts +224 -0
  156. package/src/app/core/form/form-container.class.ts +380 -0
  157. package/src/app/core/form/form.class.ts +377 -0
  158. package/src/app/core/form/form.module.ts +38 -0
  159. package/src/app/core/form/form.utils.ts +305 -0
  160. package/src/app/core/form/list/list.form.html +68 -0
  161. package/src/app/core/form/list/list.form.scss +40 -0
  162. package/src/app/core/form/list/list.form.ts +266 -0
  163. package/src/app/core/form/list/list.module.ts +20 -0
  164. package/src/app/core/form/properties/properties.form.html +160 -0
  165. package/src/app/core/form/properties/properties.form.scss +21 -0
  166. package/src/app/core/form/properties/properties.form.ts +331 -0
  167. package/src/app/core/form/properties/properties.module.ts +24 -0
  168. package/src/app/core/form/properties/properties.table.html +228 -0
  169. package/src/app/core/form/properties/properties.table.scss +0 -0
  170. package/src/app/core/form/properties/properties.table.ts +275 -0
  171. package/src/app/core/form/properties/properties.utils.ts +391 -0
  172. package/src/app/core/form/properties/property.validator.ts +82 -0
  173. package/src/app/core/form/properties/testing/properties-form.test.html +23 -0
  174. package/src/app/core/form/properties/testing/properties-form.test.ts +109 -0
  175. package/src/app/core/form/properties/testing/properties-form.testing.module.ts +14 -0
  176. package/src/app/core/form/text-popover/testing/text-popover.testing.html +50 -0
  177. package/src/app/core/form/text-popover/testing/text-popover.testing.module.ts +21 -0
  178. package/src/app/core/form/text-popover/testing/text-popover.testing.ts +76 -0
  179. package/src/app/core/form/text-popover/text-popover.component.html +89 -0
  180. package/src/app/core/form/text-popover/text-popover.component.scss +7 -0
  181. package/src/app/core/form/text-popover/text-popover.component.ts +176 -0
  182. package/src/app/core/form/text-popover/text-popover.module.ts +19 -0
  183. package/src/app/core/form/username/username.form.html +27 -0
  184. package/src/app/core/form/username/username.form.ts +44 -0
  185. package/src/app/core/form/username/username.module.ts +12 -0
  186. package/src/app/core/graphql/graphql.module.ts +7 -0
  187. package/src/app/core/graphql/graphql.service.ts +962 -0
  188. package/src/app/core/graphql/graphql.utils.ts +166 -0
  189. package/src/app/core/home/home.html +295 -0
  190. package/src/app/core/home/home.module.ts +27 -0
  191. package/src/app/core/home/home.scss +279 -0
  192. package/src/app/core/home/home.ts +422 -0
  193. package/src/app/core/icon/icon.component.html +19 -0
  194. package/src/app/core/icon/icon.component.ts +22 -0
  195. package/src/app/core/icon/icon.module.ts +13 -0
  196. package/src/app/core/install/install-upgrade-card.component.html +144 -0
  197. package/src/app/core/install/install-upgrade-card.component.scss +3 -0
  198. package/src/app/core/install/install-upgrade-card.component.ts +445 -0
  199. package/src/app/core/install/install-upgrade-card.module.ts +18 -0
  200. package/src/app/core/menu/menu.component.html +219 -0
  201. package/src/app/core/menu/menu.component.scss +304 -0
  202. package/src/app/core/menu/menu.component.ts +251 -0
  203. package/src/app/core/menu/menu.filter.ts +28 -0
  204. package/src/app/core/menu/menu.model.ts +356 -0
  205. package/src/app/core/menu/menu.module.ts +27 -0
  206. package/src/app/core/menu/menu.service.ts +727 -0
  207. package/src/app/core/menu/sub-menu-tab.directive.ts +99 -0
  208. package/src/app/core/menu/testing/menu-other.testing.ts +57 -0
  209. package/src/app/core/menu/testing/menu.testing.html +143 -0
  210. package/src/app/core/menu/testing/menu.testing.module.ts +52 -0
  211. package/src/app/core/menu/testing/menu.testing.scss +5 -0
  212. package/src/app/core/menu/testing/menu.testing.ts +175 -0
  213. package/src/app/core/offline/update-offline-mode-card.component.html +39 -0
  214. package/src/app/core/offline/update-offline-mode-card.component.scss +3 -0
  215. package/src/app/core/offline/update-offline-mode-card.component.ts +23 -0
  216. package/src/app/core/offline/update-offline-mode-card.module.ts +20 -0
  217. package/src/app/core/peer/select-peer.modal.html +317 -0
  218. package/src/app/core/peer/select-peer.modal.scss +41 -0
  219. package/src/app/core/peer/select-peer.modal.ts +366 -0
  220. package/src/app/core/peer/select-peer.module.ts +23 -0
  221. package/src/app/core/register/register-confirm.page.html +51 -0
  222. package/src/app/core/register/register-confirm.page.scss +56 -0
  223. package/src/app/core/register/register-confirm.page.ts +90 -0
  224. package/src/app/core/register/register.form.html +143 -0
  225. package/src/app/core/register/register.form.scss +10 -0
  226. package/src/app/core/register/register.form.ts +218 -0
  227. package/src/app/core/register/register.modal.html +66 -0
  228. package/src/app/core/register/register.modal.ts +50 -0
  229. package/src/app/core/register/register.module.ts +15 -0
  230. package/src/app/core/services/account.service.ts +1567 -0
  231. package/src/app/core/services/auth-guard.service.ts +70 -0
  232. package/src/app/core/services/base-entity-service.class.ts +659 -0
  233. package/src/app/core/services/base-graphql-service.class.ts +319 -0
  234. package/src/app/core/services/base58.ts +90 -0
  235. package/src/app/core/services/config/core.config.ts +263 -0
  236. package/src/app/core/services/config.service.ts +425 -0
  237. package/src/app/core/services/crypto.service.ts +126 -0
  238. package/src/app/core/services/errors.ts +80 -0
  239. package/src/app/core/services/local-settings.service.spec.ts +39 -0
  240. package/src/app/core/services/local-settings.service.ts +605 -0
  241. package/src/app/core/services/model/account.model.ts +188 -0
  242. package/src/app/core/services/model/config.model.ts +116 -0
  243. package/src/app/core/services/model/department.model.ts +34 -0
  244. package/src/app/core/services/model/entity.decorators.ts +110 -0
  245. package/src/app/core/services/model/entity.model.ts +409 -0
  246. package/src/app/core/services/model/filter.model.ts +127 -0
  247. package/src/app/core/services/model/history.model.ts +25 -0
  248. package/src/app/core/services/model/model.enum.ts +10 -0
  249. package/src/app/core/services/model/node-feature.model.ts +31 -0
  250. package/src/app/core/services/model/peer.model.ts +119 -0
  251. package/src/app/core/services/model/person.model.ts +122 -0
  252. package/src/app/core/services/model/referential.model.ts +253 -0
  253. package/src/app/core/services/model/settings.model.ts +37 -0
  254. package/src/app/core/services/model/token.model.ts +60 -0
  255. package/src/app/core/services/model/tree-item-entity.model.ts +230 -0
  256. package/src/app/core/services/network.service.spec.ts +47 -0
  257. package/src/app/core/services/network.service.ts +761 -0
  258. package/src/app/core/services/network.types.ts +7 -0
  259. package/src/app/core/services/network.utils.ts +83 -0
  260. package/src/app/core/services/pipes/account.pipes.ts +22 -0
  261. package/src/app/core/services/pipes/department-to-string.pipe.ts +13 -0
  262. package/src/app/core/services/pipes/person-to-string.pipe.ts +13 -0
  263. package/src/app/core/services/pipes/pipes.module.ts +30 -0
  264. package/src/app/core/services/pipes/referential-to-string.pipe.ts +18 -0
  265. package/src/app/core/services/pipes/usage-mode.pipes.ts +23 -0
  266. package/src/app/core/services/platform.service.spec.ts +50 -0
  267. package/src/app/core/services/platform.service.ts +694 -0
  268. package/src/app/core/services/storage/entities-storage.service.ts +557 -0
  269. package/src/app/core/services/storage/entity-store.class.ts +589 -0
  270. package/src/app/core/services/testing/local-settings.config.ts +35 -0
  271. package/src/app/core/services/testing/referential-filter.model.ts +28 -0
  272. package/src/app/core/services/testing/referential.validator.ts +58 -0
  273. package/src/app/core/services/testing/user-settings.config.ts +77 -0
  274. package/src/app/core/services/validator/account.validator.ts +50 -0
  275. package/src/app/core/services/validator/base.validator.class.ts +51 -0
  276. package/src/app/core/services/validator/local-settings.validator.ts +59 -0
  277. package/src/app/core/services/validator/user-settings.validator.ts +22 -0
  278. package/src/app/core/services/validator/user-token.validator.ts +54 -0
  279. package/src/app/core/settings/settings.module.ts +15 -0
  280. package/src/app/core/settings/settings.page.html +300 -0
  281. package/src/app/core/settings/settings.page.ts +455 -0
  282. package/src/app/core/table/async-table.class.ts +2019 -0
  283. package/src/app/core/table/column/actions-column.component.html +219 -0
  284. package/src/app/core/table/column/actions-column.component.scss +17 -0
  285. package/src/app/core/table/column/actions-column.component.ts +83 -0
  286. package/src/app/core/table/column/nav-actions-column.component.html +119 -0
  287. package/src/app/core/table/column/nav-actions-column.component.ts +108 -0
  288. package/src/app/core/table/column/row-field.component.html +43 -0
  289. package/src/app/core/table/column/row-field.component.scss +0 -0
  290. package/src/app/core/table/column/row-field.component.ts +63 -0
  291. package/src/app/core/table/entities-async-table-datasource.class.ts +501 -0
  292. package/src/app/core/table/entities-table-datasource.class.ts +499 -0
  293. package/src/app/core/table/memory-table.class.ts +56 -0
  294. package/src/app/core/table/table-select-columns.component.html +56 -0
  295. package/src/app/core/table/table-select-columns.component.ts +49 -0
  296. package/src/app/core/table/table.class.ts +2080 -0
  297. package/src/app/core/table/table.model.ts +39 -0
  298. package/src/app/core/table/table.module.ts +28 -0
  299. package/src/app/core/table/table.pipes.ts +87 -0
  300. package/src/app/core/table/table.utils.ts +42 -0
  301. package/src/app/core/table/testing/multi-table.testing.html +456 -0
  302. package/src/app/core/table/testing/multi-table.testing.ts +263 -0
  303. package/src/app/core/table/testing/table-validator.service.ts +29 -0
  304. package/src/app/core/table/testing/table.testing.html +556 -0
  305. package/src/app/core/table/testing/table.testing.module.ts +16 -0
  306. package/src/app/core/table/testing/table.testing.scss +32 -0
  307. package/src/app/core/table/testing/table.testing.ts +329 -0
  308. package/src/app/core/table/testing/table2-validator.service.ts +19 -0
  309. package/src/app/core/table/testing/table2.testing.html +470 -0
  310. package/src/app/core/table/testing/table2.testing.scss +25 -0
  311. package/src/app/core/table/testing/table2.testing.ts +274 -0
  312. package/src/app/shared/alerts.ts +296 -0
  313. package/src/app/shared/audio/audio.testing.html +29 -0
  314. package/src/app/shared/audio/audio.testing.module.ts +21 -0
  315. package/src/app/shared/audio/audio.testing.ts +27 -0
  316. package/src/app/shared/audio/audio.ts +273 -0
  317. package/src/app/shared/base64.utils.ts +66 -0
  318. package/src/app/shared/capacitor/keyboard.ts +38 -0
  319. package/src/app/shared/capacitor/plugins.ts +12 -0
  320. package/src/app/shared/constants.ts +19 -0
  321. package/src/app/shared/dates.ts +206 -0
  322. package/src/app/shared/debug/debug-service.class.ts +7 -0
  323. package/src/app/shared/debug/debug.component.html +13 -0
  324. package/src/app/shared/debug/debug.component.scss +21 -0
  325. package/src/app/shared/debug/debug.component.spec.ts +24 -0
  326. package/src/app/shared/debug/debug.component.ts +25 -0
  327. package/src/app/shared/debug/debug.module.ts +14 -0
  328. package/src/app/shared/directives/autofocus.directive.ts +93 -0
  329. package/src/app/shared/directives/autoresize.directive.ts +67 -0
  330. package/src/app/shared/directives/autotitle.directive.ts +17 -0
  331. package/src/app/shared/directives/directives.module.ts +16 -0
  332. package/src/app/shared/directives/drag-and-drop.directive.ts +46 -0
  333. package/src/app/shared/directives/ng-var.directive.ts +31 -0
  334. package/src/app/shared/directives/resizable/resizable.component.ts +48 -0
  335. package/src/app/shared/directives/resizable/resizable.directive.ts +43 -0
  336. package/src/app/shared/directives/resizable/resizable.module.ts +9 -0
  337. package/src/app/shared/directives/resizable/resizable.style.scss +37 -0
  338. package/src/app/shared/directives/resizable/resizable.template.html +6 -0
  339. package/src/app/shared/directives/throttled-click.directive.ts +36 -0
  340. package/src/app/shared/events.ts +93 -0
  341. package/src/app/shared/file/csv.utils.ts +123 -0
  342. package/src/app/shared/file/file.service.ts +129 -0
  343. package/src/app/shared/file/file.utils.ts +142 -0
  344. package/src/app/shared/file/images.utils.ts +214 -0
  345. package/src/app/shared/file/json.utils.ts +82 -0
  346. package/src/app/shared/file/uri.utils.ts +31 -0
  347. package/src/app/shared/file/url.utils.ts +163 -0
  348. package/src/app/shared/focusable.ts +8 -0
  349. package/src/app/shared/form/field.component.html +380 -0
  350. package/src/app/shared/form/field.component.scss +7 -0
  351. package/src/app/shared/form/field.component.ts +344 -0
  352. package/src/app/shared/form/field.model.ts +158 -0
  353. package/src/app/shared/form/loading-spinner.ts +16 -0
  354. package/src/app/shared/forms.ts +577 -0
  355. package/src/app/shared/functions.spec.ts +197 -0
  356. package/src/app/shared/functions.ts +694 -0
  357. package/src/app/shared/geolocation/geolocation.utils.ts +105 -0
  358. package/src/app/shared/gesture/gesture-config.ts +43 -0
  359. package/src/app/shared/gesture/hammer.utils.ts +14 -0
  360. package/src/app/shared/graph/colors.utils.ts +69 -0
  361. package/src/app/shared/graph/graph-colors.ts +270 -0
  362. package/src/app/shared/guard/component-dirty.guard.ts +67 -0
  363. package/src/app/shared/hotkeys/dialog/hotkeys-dialog.component.html +11 -0
  364. package/src/app/shared/hotkeys/dialog/hotkeys-dialog.component.scss +37 -0
  365. package/src/app/shared/hotkeys/dialog/hotkeys-dialog.component.ts +14 -0
  366. package/src/app/shared/hotkeys/hotkeys.service.ts +165 -0
  367. package/src/app/shared/hotkeys/shared-hotkeys.module.ts +15 -0
  368. package/src/app/shared/http/http.utils.ts +95 -0
  369. package/src/app/shared/image/gallery/image-gallery.component.html +282 -0
  370. package/src/app/shared/image/gallery/image-gallery.component.scss +218 -0
  371. package/src/app/shared/image/gallery/image-gallery.component.ts +434 -0
  372. package/src/app/shared/image/gallery/image-gallery.module.ts +35 -0
  373. package/src/app/shared/image/gallery/testing/gallegry.model.testing.ts +23 -0
  374. package/src/app/shared/image/gallery/testing/gallery.service.testing.ts +99 -0
  375. package/src/app/shared/image/gallery/testing/gallery.testing.html +27 -0
  376. package/src/app/shared/image/gallery/testing/gallery.testing.module.ts +39 -0
  377. package/src/app/shared/image/gallery/testing/gallery.testing.ts +34 -0
  378. package/src/app/shared/image/image.model.ts +8 -0
  379. package/src/app/shared/image/image.module.ts +12 -0
  380. package/src/app/shared/image/image.service.ts +111 -0
  381. package/src/app/shared/image/image.testing.module.ts +16 -0
  382. package/src/app/shared/inputs.ts +330 -0
  383. package/src/app/shared/interceptors/progess.interceptor.ts +24 -0
  384. package/src/app/shared/logging/log-level.model.ts +53 -0
  385. package/src/app/shared/logging/logger.model.ts +117 -0
  386. package/src/app/shared/logging/logging-service.class.ts +131 -0
  387. package/src/app/shared/logging/logging-service.config.ts +29 -0
  388. package/src/app/shared/logging/logging-service.module.ts +19 -0
  389. package/src/app/shared/markdown/markdown.component.html +55 -0
  390. package/src/app/shared/markdown/markdown.component.scss +75 -0
  391. package/src/app/shared/markdown/markdown.component.ts +350 -0
  392. package/src/app/shared/markdown/markdown.directive.ts +28 -0
  393. package/src/app/shared/markdown/markdown.modal.html +42 -0
  394. package/src/app/shared/markdown/markdown.modal.ts +91 -0
  395. package/src/app/shared/markdown/markdown.module.ts +65 -0
  396. package/src/app/shared/markdown/markdown.service.ts +234 -0
  397. package/src/app/shared/markdown/markdown.utils.ts +90 -0
  398. package/src/app/shared/markdown/testing/markdown.test.html +50 -0
  399. package/src/app/shared/markdown/testing/markdown.test.ts +49 -0
  400. package/src/app/shared/markdown/testing/markdown.testing.module.ts +22 -0
  401. package/src/app/shared/material/autocomplete/material.autocomplete.config.ts +127 -0
  402. package/src/app/shared/material/autocomplete/material.autocomplete.html +400 -0
  403. package/src/app/shared/material/autocomplete/material.autocomplete.module.ts +41 -0
  404. package/src/app/shared/material/autocomplete/material.autocomplete.scss +54 -0
  405. package/src/app/shared/material/autocomplete/material.autocomplete.ts +1375 -0
  406. package/src/app/shared/material/autocomplete/material.autocomplete.utils.ts +21 -0
  407. package/src/app/shared/material/autocomplete/testing/autocomplete.test.html +1164 -0
  408. package/src/app/shared/material/autocomplete/testing/autocomplete.test.spec.ts +33 -0
  409. package/src/app/shared/material/autocomplete/testing/autocomplete.test.ts +272 -0
  410. package/src/app/shared/material/badge/badge.directive.ts +217 -0
  411. package/src/app/shared/material/badge/badge.module.ts +12 -0
  412. package/src/app/shared/material/badge/badge.test.html +275 -0
  413. package/src/app/shared/material/badge/badge.test.ts +34 -0
  414. package/src/app/shared/material/boolean/boolean.module.ts +36 -0
  415. package/src/app/shared/material/boolean/material.boolean.html +271 -0
  416. package/src/app/shared/material/boolean/material.boolean.scss +27 -0
  417. package/src/app/shared/material/boolean/material.boolean.ts +343 -0
  418. package/src/app/shared/material/boolean/testing/boolean.test.page.html +469 -0
  419. package/src/app/shared/material/boolean/testing/boolean.test.page.ts +66 -0
  420. package/src/app/shared/material/chips/chips.module.ts +38 -0
  421. package/src/app/shared/material/chips/material.chips.html +233 -0
  422. package/src/app/shared/material/chips/material.chips.scss +67 -0
  423. package/src/app/shared/material/chips/material.chips.ts +834 -0
  424. package/src/app/shared/material/chips/testing/chips.test.html +207 -0
  425. package/src/app/shared/material/chips/testing/chips.test.ts +169 -0
  426. package/src/app/shared/material/datetime/datetime.module.ts +42 -0
  427. package/src/app/shared/material/datetime/material.date.html +186 -0
  428. package/src/app/shared/material/datetime/material.date.scss +17 -0
  429. package/src/app/shared/material/datetime/material.date.ts +512 -0
  430. package/src/app/shared/material/datetime/material.dateshort.html +194 -0
  431. package/src/app/shared/material/datetime/material.dateshort.scss +23 -0
  432. package/src/app/shared/material/datetime/material.dateshort.ts +497 -0
  433. package/src/app/shared/material/datetime/material.datetime.html +325 -0
  434. package/src/app/shared/material/datetime/material.datetime.scss +87 -0
  435. package/src/app/shared/material/datetime/material.datetime.ts +758 -0
  436. package/src/app/shared/material/datetime/testing/mat-date-time.test.html +794 -0
  437. package/src/app/shared/material/datetime/testing/mat-date-time.test.ts +155 -0
  438. package/src/app/shared/material/datetime/testing/mat-date.test.html +564 -0
  439. package/src/app/shared/material/datetime/testing/mat-date.test.ts +145 -0
  440. package/src/app/shared/material/datetime/testing/mat-dateshort.test.html +530 -0
  441. package/src/app/shared/material/datetime/testing/mat-dateshort.test.ts +133 -0
  442. package/src/app/shared/material/duration/duration.module.ts +33 -0
  443. package/src/app/shared/material/duration/duration.utils.ts +18 -0
  444. package/src/app/shared/material/duration/material.duration.html +116 -0
  445. package/src/app/shared/material/duration/material.duration.scss +28 -0
  446. package/src/app/shared/material/duration/material.duration.ts +308 -0
  447. package/src/app/shared/material/duration/testing/mat-duration.test.html +170 -0
  448. package/src/app/shared/material/duration/testing/mat-duration.test.ts +88 -0
  449. package/src/app/shared/material/latlong/latlong.utils.ts +376 -0
  450. package/src/app/shared/material/latlong/material.latlong-input.html +95 -0
  451. package/src/app/shared/material/latlong/material.latlong-input.scss +66 -0
  452. package/src/app/shared/material/latlong/material.latlong-input.ts +445 -0
  453. package/src/app/shared/material/latlong/material.latlong.html +90 -0
  454. package/src/app/shared/material/latlong/material.latlong.module.ts +37 -0
  455. package/src/app/shared/material/latlong/material.latlong.scss +0 -0
  456. package/src/app/shared/material/latlong/material.latlong.ts +203 -0
  457. package/src/app/shared/material/latlong/testing/latlong.test.html +1008 -0
  458. package/src/app/shared/material/latlong/testing/latlong.test.ts +144 -0
  459. package/src/app/shared/material/material.animations.ts +269 -0
  460. package/src/app/shared/material/material.config.ts +5 -0
  461. package/src/app/shared/material/material.module.ts +94 -0
  462. package/src/app/shared/material/material.testing.module.ts +192 -0
  463. package/src/app/shared/material/memory/memory.utils.ts +57 -0
  464. package/src/app/shared/material/numpad/numpad.animation.ts +1 -0
  465. package/src/app/shared/material/numpad/numpad.append-to-input.directive.ts +110 -0
  466. package/src/app/shared/material/numpad/numpad.component.ts +73 -0
  467. package/src/app/shared/material/numpad/numpad.container.html +37 -0
  468. package/src/app/shared/material/numpad/numpad.container.scss +55 -0
  469. package/src/app/shared/material/numpad/numpad.container.ts +152 -0
  470. package/src/app/shared/material/numpad/numpad.content.html +13 -0
  471. package/src/app/shared/material/numpad/numpad.content.ts +10 -0
  472. package/src/app/shared/material/numpad/numpad.directive.ts +159 -0
  473. package/src/app/shared/material/numpad/numpad.dom-service.ts +35 -0
  474. package/src/app/shared/material/numpad/numpad.model.ts +53 -0
  475. package/src/app/shared/material/numpad/numpad.module.ts +18 -0
  476. package/src/app/shared/material/numpad/testing/numpad.test.html +146 -0
  477. package/src/app/shared/material/numpad/testing/numpad.test.ts +44 -0
  478. package/src/app/shared/material/paginator/material.paginator-i18n.ts +47 -0
  479. package/src/app/shared/material/stepper/material.stepper-i18n.ts +17 -0
  480. package/src/app/shared/material/swipe/material.swipe.html +85 -0
  481. package/src/app/shared/material/swipe/material.swipe.scss +55 -0
  482. package/src/app/shared/material/swipe/material.swipe.ts +366 -0
  483. package/src/app/shared/material/swipe/swipe.module.ts +29 -0
  484. package/src/app/shared/material/swipe/testing/swipe.test.html +112 -0
  485. package/src/app/shared/material/swipe/testing/swipe.test.ts +74 -0
  486. package/src/app/shared/material/test/test-component.css +22 -0
  487. package/src/app/shared/material/test/test-component.html +40 -0
  488. package/src/app/shared/material/test/test-component.ts +295 -0
  489. package/src/app/shared/material/testing/common.test.html +227 -0
  490. package/src/app/shared/material/testing/common.test.ts +126 -0
  491. package/src/app/shared/material/text/testing/text-form.testing.html +213 -0
  492. package/src/app/shared/material/text/testing/text-form.testing.ts +30 -0
  493. package/src/app/shared/material/text/text-form.component.html +63 -0
  494. package/src/app/shared/material/text/text-form.component.scss +8 -0
  495. package/src/app/shared/material/text/text-form.component.ts +177 -0
  496. package/src/app/shared/material/text/text-form.module.ts +36 -0
  497. package/src/app/shared/modules.ts +12 -0
  498. package/src/app/shared/named-filter/named-filter-selector.component.html +77 -0
  499. package/src/app/shared/named-filter/named-filter-selector.component.scss +3 -0
  500. package/src/app/shared/named-filter/named-filter-selector.component.ts +287 -0
  501. package/src/app/shared/named-filter/named-filter.model.ts +64 -0
  502. package/src/app/shared/named-filter/named-filter.module.ts +15 -0
  503. package/src/app/shared/named-filter/named-filter.service.ts +100 -0
  504. package/src/app/shared/named-filter/testing/named-filter-selector.testing.html +61 -0
  505. package/src/app/shared/named-filter/testing/named-filter-selector.testing.ts +80 -0
  506. package/src/app/shared/named-filter/testing/named-filter.testing.module.ts +20 -0
  507. package/src/app/shared/named-filter/testing/named-filter.testing.service.ts +83 -0
  508. package/src/app/shared/observables.ts +139 -0
  509. package/src/app/shared/pipes/arrays.pipe.ts +153 -0
  510. package/src/app/shared/pipes/badge.pipes.ts +17 -0
  511. package/src/app/shared/pipes/colors.pipe.ts +24 -0
  512. package/src/app/shared/pipes/date-diff-duration.pipe.ts +53 -0
  513. package/src/app/shared/pipes/date-format.pipe.ts +73 -0
  514. package/src/app/shared/pipes/date-from-now.pipe.ts +17 -0
  515. package/src/app/shared/pipes/dates.pipe.ts +13 -0
  516. package/src/app/shared/pipes/display-with.pipe.ts +13 -0
  517. package/src/app/shared/pipes/duration.pipe.spec.ts +41 -0
  518. package/src/app/shared/pipes/duration.pipe.ts +28 -0
  519. package/src/app/shared/pipes/file-size.pipe.ts +50 -0
  520. package/src/app/shared/pipes/form.pipes.ts +209 -0
  521. package/src/app/shared/pipes/highlight.pipe.ts +41 -0
  522. package/src/app/shared/pipes/html.pipes.ts +49 -0
  523. package/src/app/shared/pipes/latlong-format.pipe.ts +28 -0
  524. package/src/app/shared/pipes/maps.pipe.ts +41 -0
  525. package/src/app/shared/pipes/maskito.pipe.ts +68 -0
  526. package/src/app/shared/pipes/math.pipes.ts +46 -0
  527. package/src/app/shared/pipes/ng-init.pipe.ts +13 -0
  528. package/src/app/shared/pipes/number-format.pipe.ts +11 -0
  529. package/src/app/shared/pipes/observable.pipes.ts +45 -0
  530. package/src/app/shared/pipes/pipes.module.ts +162 -0
  531. package/src/app/shared/pipes/property.pipes.ts +115 -0
  532. package/src/app/shared/pipes/selection.pipes.ts +165 -0
  533. package/src/app/shared/pipes/string.pipes.ts +128 -0
  534. package/src/app/shared/pipes/translate-context.pipe.ts +27 -0
  535. package/src/app/shared/pipes/types.pipes.ts +52 -0
  536. package/src/app/shared/pipes/url.pipes.ts +36 -0
  537. package/src/app/shared/platforms.ts +99 -0
  538. package/src/app/shared/print/print.service.ts +337 -0
  539. package/src/app/shared/regexps.ts +112 -0
  540. package/src/app/shared/rx-state/rx-state.decorators.ts +281 -0
  541. package/src/app/shared/rx-state/rx-state.module.ts +11 -0
  542. package/src/app/shared/rx-state/rx-state.types.ts +5 -0
  543. package/src/app/shared/services/entity-service.class.ts +120 -0
  544. package/src/app/shared/services/job.utils.ts +124 -0
  545. package/src/app/shared/services/memory-entity-service.class.ts +435 -0
  546. package/src/app/shared/services/progress-bar.service.ts +40 -0
  547. package/src/app/shared/services/startable-observable-service.class.ts +129 -0
  548. package/src/app/shared/services/startable-service.class.ts +120 -0
  549. package/src/app/shared/services/storage.utils.ts +53 -0
  550. package/src/app/shared/services/translate-context.service.ts +112 -0
  551. package/src/app/shared/services/validator-service.class.ts +13 -0
  552. package/src/app/shared/services.ts +134 -0
  553. package/src/app/shared/shared-routing.module.ts +69 -0
  554. package/src/app/shared/shared.module.spec.ts +13 -0
  555. package/src/app/shared/shared.module.ts +168 -0
  556. package/src/app/shared/shared.testing.module.ts +61 -0
  557. package/src/app/shared/storage/storage-explorer.component.html +160 -0
  558. package/src/app/shared/storage/storage-explorer.component.scss +37 -0
  559. package/src/app/shared/storage/storage-explorer.component.spec.ts +24 -0
  560. package/src/app/shared/storage/storage-explorer.component.ts +268 -0
  561. package/src/app/shared/storage/storage-explorer.module.ts +24 -0
  562. package/src/app/shared/storage/storage-explorer.testing-routing.module.ts +19 -0
  563. package/src/app/shared/storage/storage-explorer.testing.module.ts +19 -0
  564. package/src/app/shared/storage/storage.service.ts +131 -0
  565. package/src/app/shared/storage/storage.utils.ts +25 -0
  566. package/src/app/shared/testing/maskito.test.html +40 -0
  567. package/src/app/shared/testing/maskito.test.ts +33 -0
  568. package/src/app/shared/testing/observable.test.html +53 -0
  569. package/src/app/shared/testing/observable.test.scss +3 -0
  570. package/src/app/shared/testing/observable.test.ts +101 -0
  571. package/src/app/shared/testing/tests.page.html +22 -0
  572. package/src/app/shared/testing/tests.page.ts +32 -0
  573. package/src/app/shared/toast/toast.testing.html +50 -0
  574. package/src/app/shared/toast/toast.testing.module.ts +22 -0
  575. package/src/app/shared/toast/toast.testing.ts +52 -0
  576. package/src/app/shared/toast/toasts.ts +161 -0
  577. package/src/app/shared/toolbar/modal-toolbar.html +30 -0
  578. package/src/app/shared/toolbar/modal-toolbar.scss +0 -0
  579. package/src/app/shared/toolbar/modal-toolbar.ts +64 -0
  580. package/src/app/shared/toolbar/toolbar.html +68 -0
  581. package/src/app/shared/toolbar/toolbar.module.ts +18 -0
  582. package/src/app/shared/toolbar/toolbar.scss +0 -0
  583. package/src/app/shared/toolbar/toolbar.ts +262 -0
  584. package/src/app/shared/types.ts +44 -0
  585. package/src/app/shared/upload-file/testing/upload-file.testing.html +30 -0
  586. package/src/app/shared/upload-file/testing/upload-file.testing.module.ts +21 -0
  587. package/src/app/shared/upload-file/testing/upload-file.testing.ts +65 -0
  588. package/src/app/shared/upload-file/upload-file-popover.component.html +46 -0
  589. package/src/app/shared/upload-file/upload-file-popover.component.scss +6 -0
  590. package/src/app/shared/upload-file/upload-file-popover.component.ts +115 -0
  591. package/src/app/shared/upload-file/upload-file.component.html +57 -0
  592. package/src/app/shared/upload-file/upload-file.component.scss +60 -0
  593. package/src/app/shared/upload-file/upload-file.component.ts +222 -0
  594. package/src/app/shared/upload-file/upload-file.model.ts +40 -0
  595. package/src/app/shared/validator/form-error-adapter.class.ts +136 -0
  596. package/src/app/shared/validator/validators.ts +725 -0
  597. package/src/app/shared/version/versions.ts +89 -0
  598. package/src/app/social/job/job.module.ts +14 -0
  599. package/src/app/social/job/progression/job-progression.component.html +19 -0
  600. package/src/app/social/job/progression/job-progression.component.scss +15 -0
  601. package/src/app/social/job/progression/job-progression.component.ts +39 -0
  602. package/src/app/social/job/progression/job-progression.icon.html +30 -0
  603. package/src/app/social/job/progression/job-progression.icon.scss +7 -0
  604. package/src/app/social/job/progression/job-progression.icon.ts +276 -0
  605. package/src/app/social/job/progression/job-progression.list.html +25 -0
  606. package/src/app/social/job/progression/job-progression.list.scss +17 -0
  607. package/src/app/social/job/progression/job-progression.list.ts +40 -0
  608. package/src/app/social/job/progression/job-progression.model.ts +26 -0
  609. package/src/app/social/job/progression/job-progression.service.ts +97 -0
  610. package/src/app/social/job/testing/job-progression.testing.html +11 -0
  611. package/src/app/social/job/testing/job-progression.testing.service.ts +33 -0
  612. package/src/app/social/job/testing/job-progression.testing.ts +28 -0
  613. package/src/app/social/job/testing/job.testing.module.ts +13 -0
  614. package/src/app/social/message/message.form.html +71 -0
  615. package/src/app/social/message/message.form.scss +6 -0
  616. package/src/app/social/message/message.form.ts +128 -0
  617. package/src/app/social/message/message.modal.html +68 -0
  618. package/src/app/social/message/message.modal.ts +117 -0
  619. package/src/app/social/message/message.model.ts +78 -0
  620. package/src/app/social/message/message.module.ts +14 -0
  621. package/src/app/social/message/message.service.ts +104 -0
  622. package/src/app/social/social.errors.ts +10 -0
  623. package/src/app/social/social.module.ts +23 -0
  624. package/src/app/social/social.testing.module.ts +33 -0
  625. package/src/app/social/user-event/notification/user-event-notification.icon.html +17 -0
  626. package/src/app/social/user-event/notification/user-event-notification.icon.ts +112 -0
  627. package/src/app/social/user-event/notification/user-event-notification.list.html +142 -0
  628. package/src/app/social/user-event/notification/user-event-notification.list.scss +73 -0
  629. package/src/app/social/user-event/notification/user-event-notification.list.ts +270 -0
  630. package/src/app/social/user-event/testing/user-event.testing.html +26 -0
  631. package/src/app/social/user-event/testing/user-event.testing.model.ts +142 -0
  632. package/src/app/social/user-event/testing/user-event.testing.module.ts +13 -0
  633. package/src/app/social/user-event/testing/user-event.testing.service.ts +161 -0
  634. package/src/app/social/user-event/testing/user-event.testing.ts +282 -0
  635. package/src/app/social/user-event/user-event.model.ts +55 -0
  636. package/src/app/social/user-event/user-event.module.ts +15 -0
  637. package/src/app/social/user-event/user-event.service.ts +686 -0
  638. package/src/assets/manifest.json +1 -1
  639. package/src/browserslist +9 -0
  640. package/src/environments/environment.class.ts +106 -0
  641. package/src/environments/environment.loader.ts +90 -0
  642. package/src/environments/environment.prod.ts +49 -0
  643. package/src/environments/environment.test.ts +92 -0
  644. package/src/environments/environment.ts +126 -0
  645. package/src/favicon.ico +0 -0
  646. package/src/global.scss +13 -0
  647. package/src/index.html +76 -0
  648. package/src/main.ts +18 -0
  649. package/src/polyfills.ts +34 -0
  650. package/src/schema.graphql +4381 -0
  651. package/src/service-worker.js +31 -0
  652. package/src/test.ts +30 -0
  653. package/tsconfig.app.json +15 -0
  654. package/tsconfig.json +47 -0
  655. package/tsconfig.spec.json +18 -0
  656. package/esm2022/public_api.mjs +0 -380
  657. package/esm2022/src/app/admin/admin-routing.module.mjs +0 -34
  658. package/esm2022/src/app/admin/admin.module.mjs +0 -32
  659. package/esm2022/src/app/admin/services/filter/person.filter.mjs +0 -76
  660. package/esm2022/src/app/admin/services/person.service.mjs +0 -184
  661. package/esm2022/src/app/admin/services/validator/person.validator.mjs +0 -72
  662. package/esm2022/src/app/admin/users/users.mjs +0 -379
  663. package/esm2022/src/app/admin/users/users.module.mjs +0 -56
  664. package/esm2022/src/app/core/about/about.modal.mjs +0 -86
  665. package/esm2022/src/app/core/about/about.module.mjs +0 -22
  666. package/esm2022/src/app/core/account/account.module.mjs +0 -75
  667. package/esm2022/src/app/core/account/account.page.mjs +0 -364
  668. package/esm2022/src/app/core/account/new-token.form.mjs +0 -106
  669. package/esm2022/src/app/core/account/new-token.modal.mjs +0 -66
  670. package/esm2022/src/app/core/account/password/change-password.form.mjs +0 -63
  671. package/esm2022/src/app/core/account/password/change-password.module.mjs +0 -22
  672. package/esm2022/src/app/core/account/password/change-password.page.mjs +0 -150
  673. package/esm2022/src/app/core/account/token.table.mjs +0 -157
  674. package/esm2022/src/app/core/auth/auth.form.mjs +0 -159
  675. package/esm2022/src/app/core/auth/auth.modal.mjs +0 -76
  676. package/esm2022/src/app/core/auth/auth.module.mjs +0 -56
  677. package/esm2022/src/app/core/auth/reset-password.modal.mjs +0 -89
  678. package/esm2022/src/app/core/core.module.mjs +0 -151
  679. package/esm2022/src/app/core/core.testing.module.mjs +0 -107
  680. package/esm2022/src/app/core/form/array/form-array.mjs +0 -328
  681. package/esm2022/src/app/core/form/array/testing/form-array-test.module.mjs +0 -23
  682. package/esm2022/src/app/core/form/array/testing/form-array.test.mjs +0 -94
  683. package/esm2022/src/app/core/form/buttons/form-buttons-bar.component.mjs +0 -108
  684. package/esm2022/src/app/core/form/buttons/form-buttons-bar.module.mjs +0 -31
  685. package/esm2022/src/app/core/form/entity/editor.class.mjs +0 -268
  686. package/esm2022/src/app/core/form/entity/entity-editor-modal.class.mjs +0 -420
  687. package/esm2022/src/app/core/form/entity/entity-editor.class.mjs +0 -741
  688. package/esm2022/src/app/core/form/entity/entity-metadata.component.mjs +0 -24
  689. package/esm2022/src/app/core/form/entity/entity.module.mjs +0 -32
  690. package/esm2022/src/app/core/form/entity/tab-editor.class.mjs +0 -190
  691. package/esm2022/src/app/core/form/form-container.class.mjs +0 -340
  692. package/esm2022/src/app/core/form/form.class.mjs +0 -337
  693. package/esm2022/src/app/core/form/form.module.mjs +0 -70
  694. package/esm2022/src/app/core/form/form.utils.mjs +0 -205
  695. package/esm2022/src/app/core/form/list/list.form.mjs +0 -235
  696. package/esm2022/src/app/core/form/list/list.module.mjs +0 -31
  697. package/esm2022/src/app/core/form/properties/properties.form.mjs +0 -317
  698. package/esm2022/src/app/core/form/properties/properties.module.mjs +0 -37
  699. package/esm2022/src/app/core/form/properties/properties.table.mjs +0 -264
  700. package/esm2022/src/app/core/form/properties/properties.utils.mjs +0 -304
  701. package/esm2022/src/app/core/form/properties/property.validator.mjs +0 -70
  702. package/esm2022/src/app/core/form/properties/testing/properties-form.test.mjs +0 -104
  703. package/esm2022/src/app/core/form/properties/testing/properties-form.testing.module.mjs +0 -23
  704. package/esm2022/src/app/core/form/text-popover/testing/text-popover.testing.mjs +0 -73
  705. package/esm2022/src/app/core/form/text-popover/testing/text-popover.testing.module.mjs +0 -30
  706. package/esm2022/src/app/core/form/text-popover/text-popover.component.mjs +0 -161
  707. package/esm2022/src/app/core/form/text-popover/text-popover.module.mjs +0 -31
  708. package/esm2022/src/app/core/form/username/username.form.mjs +0 -55
  709. package/esm2022/src/app/core/form/username/username.module.mjs +0 -20
  710. package/esm2022/src/app/core/graphql/graphql.module.mjs +0 -14
  711. package/esm2022/src/app/core/graphql/graphql.service.mjs +0 -781
  712. package/esm2022/src/app/core/graphql/graphql.utils.mjs +0 -119
  713. package/esm2022/src/app/core/home/home.mjs +0 -382
  714. package/esm2022/src/app/core/home/home.module.mjs +0 -46
  715. package/esm2022/src/app/core/icon/icon.component.mjs +0 -40
  716. package/esm2022/src/app/core/icon/icon.module.mjs +0 -20
  717. package/esm2022/src/app/core/install/install-upgrade-card.component.mjs +0 -394
  718. package/esm2022/src/app/core/install/install-upgrade-card.module.mjs +0 -31
  719. package/esm2022/src/app/core/menu/menu.component.mjs +0 -258
  720. package/esm2022/src/app/core/menu/menu.model.mjs +0 -272
  721. package/esm2022/src/app/core/menu/menu.module.mjs +0 -47
  722. package/esm2022/src/app/core/menu/menu.service.mjs +0 -666
  723. package/esm2022/src/app/core/menu/sub-menu-tab.directive.mjs +0 -109
  724. package/esm2022/src/app/core/menu/testing/menu-other.testing.mjs +0 -50
  725. package/esm2022/src/app/core/menu/testing/menu.testing.mjs +0 -158
  726. package/esm2022/src/app/core/menu/testing/menu.testing.module.mjs +0 -60
  727. package/esm2022/src/app/core/offline/update-offline-mode-card.component.mjs +0 -28
  728. package/esm2022/src/app/core/offline/update-offline-mode-card.module.mjs +0 -31
  729. package/esm2022/src/app/core/peer/select-peer.modal.mjs +0 -344
  730. package/esm2022/src/app/core/peer/select-peer.module.mjs +0 -36
  731. package/esm2022/src/app/core/register/register-confirm.page.mjs +0 -90
  732. package/esm2022/src/app/core/register/register.form.mjs +0 -194
  733. package/esm2022/src/app/core/register/register.modal.mjs +0 -55
  734. package/esm2022/src/app/core/register/register.module.mjs +0 -23
  735. package/esm2022/src/app/core/services/account.service.mjs +0 -1358
  736. package/esm2022/src/app/core/services/auth-guard.service.mjs +0 -74
  737. package/esm2022/src/app/core/services/base-entity-service.class.mjs +0 -485
  738. package/esm2022/src/app/core/services/base-graphql-service.class.mjs +0 -230
  739. package/esm2022/src/app/core/services/base58.mjs +0 -83
  740. package/esm2022/src/app/core/services/config/core.config.mjs +0 -258
  741. package/esm2022/src/app/core/services/config.service.mjs +0 -384
  742. package/esm2022/src/app/core/services/crypto.service.mjs +0 -107
  743. package/esm2022/src/app/core/services/errors.mjs +0 -54
  744. package/esm2022/src/app/core/services/local-settings.service.mjs +0 -516
  745. package/esm2022/src/app/core/services/model/account.model.mjs +0 -178
  746. package/esm2022/src/app/core/services/model/config.model.mjs +0 -107
  747. package/esm2022/src/app/core/services/model/department.model.mjs +0 -35
  748. package/esm2022/src/app/core/services/model/entity.decorators.mjs +0 -97
  749. package/esm2022/src/app/core/services/model/entity.model.mjs +0 -338
  750. package/esm2022/src/app/core/services/model/filter.model.mjs +0 -93
  751. package/esm2022/src/app/core/services/model/history.model.mjs +0 -2
  752. package/esm2022/src/app/core/services/model/model.enum.mjs +0 -11
  753. package/esm2022/src/app/core/services/model/node-feature.model.mjs +0 -31
  754. package/esm2022/src/app/core/services/model/peer.model.mjs +0 -113
  755. package/esm2022/src/app/core/services/model/person.model.mjs +0 -114
  756. package/esm2022/src/app/core/services/model/referential.model.mjs +0 -205
  757. package/esm2022/src/app/core/services/model/settings.model.mjs +0 -6
  758. package/esm2022/src/app/core/services/model/token.model.mjs +0 -57
  759. package/esm2022/src/app/core/services/model/tree-item-entity.model.mjs +0 -195
  760. package/esm2022/src/app/core/services/network.service.mjs +0 -638
  761. package/esm2022/src/app/core/services/network.types.mjs +0 -2
  762. package/esm2022/src/app/core/services/network.utils.mjs +0 -35
  763. package/esm2022/src/app/core/services/pipes/account.pipes.mjs +0 -38
  764. package/esm2022/src/app/core/services/pipes/department-to-string.pipe.mjs +0 -23
  765. package/esm2022/src/app/core/services/pipes/person-to-string.pipe.mjs +0 -23
  766. package/esm2022/src/app/core/services/pipes/pipes.module.mjs +0 -54
  767. package/esm2022/src/app/core/services/pipes/referential-to-string.pipe.mjs +0 -21
  768. package/esm2022/src/app/core/services/pipes/usage-mode.pipes.mjs +0 -37
  769. package/esm2022/src/app/core/services/platform.service.mjs +0 -627
  770. package/esm2022/src/app/core/services/storage/entities-storage.service.mjs +0 -427
  771. package/esm2022/src/app/core/services/storage/entity-store.class.mjs +0 -450
  772. package/esm2022/src/app/core/services/testing/referential-filter.model.mjs +0 -25
  773. package/esm2022/src/app/core/services/testing/referential.validator.mjs +0 -46
  774. package/esm2022/src/app/core/services/validator/account.validator.mjs +0 -45
  775. package/esm2022/src/app/core/services/validator/base.validator.class.mjs +0 -49
  776. package/esm2022/src/app/core/services/validator/local-settings.validator.mjs +0 -57
  777. package/esm2022/src/app/core/services/validator/user-settings.validator.mjs +0 -27
  778. package/esm2022/src/app/core/services/validator/user-token.validator.mjs +0 -55
  779. package/esm2022/src/app/core/settings/settings.module.mjs +0 -23
  780. package/esm2022/src/app/core/settings/settings.page.mjs +0 -403
  781. package/esm2022/src/app/core/table/async-table.class.mjs +0 -1811
  782. package/esm2022/src/app/core/table/column/actions-column.component.mjs +0 -130
  783. package/esm2022/src/app/core/table/column/nav-actions-column.component.mjs +0 -117
  784. package/esm2022/src/app/core/table/column/row-field.component.mjs +0 -116
  785. package/esm2022/src/app/core/table/entities-async-table-datasource.class.mjs +0 -404
  786. package/esm2022/src/app/core/table/entities-table-datasource.class.mjs +0 -405
  787. package/esm2022/src/app/core/table/memory-table.class.mjs +0 -57
  788. package/esm2022/src/app/core/table/table-select-columns.component.mjs +0 -46
  789. package/esm2022/src/app/core/table/table.class.mjs +0 -1867
  790. package/esm2022/src/app/core/table/table.model.mjs +0 -21
  791. package/esm2022/src/app/core/table/table.module.mjs +0 -51
  792. package/esm2022/src/app/core/table/table.pipes.mjs +0 -77
  793. package/esm2022/src/app/core/table/table.utils.mjs +0 -34
  794. package/esm2022/src/app/core/table/testing/table-validator.service.mjs +0 -32
  795. package/esm2022/src/app/core/table/testing/table.testing.mjs +0 -329
  796. package/esm2022/src/app/core/table/testing/table.testing.module.mjs +0 -25
  797. package/esm2022/src/app/core/table/testing/table2-validator.service.mjs +0 -25
  798. package/esm2022/src/app/core/table/testing/table2.testing.mjs +0 -273
  799. package/esm2022/src/app/shared/alerts.mjs +0 -243
  800. package/esm2022/src/app/shared/audio/audio.mjs +0 -255
  801. package/esm2022/src/app/shared/audio/audio.testing.mjs +0 -32
  802. package/esm2022/src/app/shared/audio/audio.testing.module.mjs +0 -30
  803. package/esm2022/src/app/shared/capacitor/keyboard.mjs +0 -42
  804. package/esm2022/src/app/shared/capacitor/plugins.mjs +0 -9
  805. package/esm2022/src/app/shared/constants.mjs +0 -16
  806. package/esm2022/src/app/shared/dates.mjs +0 -180
  807. package/esm2022/src/app/shared/debug/debug-service.class.mjs +0 -3
  808. package/esm2022/src/app/shared/debug/debug.component.mjs +0 -44
  809. package/esm2022/src/app/shared/debug/debug.module.mjs +0 -23
  810. package/esm2022/src/app/shared/directives/autofocus.directive.mjs +0 -91
  811. package/esm2022/src/app/shared/directives/autoresize.directive.mjs +0 -75
  812. package/esm2022/src/app/shared/directives/autotitle.directive.mjs +0 -30
  813. package/esm2022/src/app/shared/directives/directives.module.mjs +0 -24
  814. package/esm2022/src/app/shared/directives/drag-and-drop.directive.mjs +0 -52
  815. package/esm2022/src/app/shared/directives/ng-var.directive.mjs +0 -33
  816. package/esm2022/src/app/shared/directives/resizable/resizable.component.mjs +0 -62
  817. package/esm2022/src/app/shared/directives/resizable/resizable.directive.mjs +0 -45
  818. package/esm2022/src/app/shared/directives/resizable/resizable.module.mjs +0 -17
  819. package/esm2022/src/app/shared/directives/throttled-click.directive.mjs +0 -43
  820. package/esm2022/src/app/shared/events.mjs +0 -64
  821. package/esm2022/src/app/shared/file/csv.utils.mjs +0 -97
  822. package/esm2022/src/app/shared/file/file.service.mjs +0 -118
  823. package/esm2022/src/app/shared/file/file.utils.mjs +0 -117
  824. package/esm2022/src/app/shared/file/images.utils.mjs +0 -186
  825. package/esm2022/src/app/shared/file/json.utils.mjs +0 -58
  826. package/esm2022/src/app/shared/file/uri.utils.mjs +0 -29
  827. package/esm2022/src/app/shared/file/url.utils.mjs +0 -164
  828. package/esm2022/src/app/shared/focusable.mjs +0 -6
  829. package/esm2022/src/app/shared/form/field.component.mjs +0 -393
  830. package/esm2022/src/app/shared/form/field.model.mjs +0 -82
  831. package/esm2022/src/app/shared/form/loading-spinner.mjs +0 -35
  832. package/esm2022/src/app/shared/forms.mjs +0 -510
  833. package/esm2022/src/app/shared/functions.mjs +0 -672
  834. package/esm2022/src/app/shared/geolocation/geolocation.utils.mjs +0 -86
  835. package/esm2022/src/app/shared/gesture/gesture-config.mjs +0 -46
  836. package/esm2022/src/app/shared/gesture/hammer.utils.mjs +0 -2
  837. package/esm2022/src/app/shared/graph/colors.utils.mjs +0 -60
  838. package/esm2022/src/app/shared/graph/graph-colors.mjs +0 -214
  839. package/esm2022/src/app/shared/guard/component-dirty.guard.mjs +0 -65
  840. package/esm2022/src/app/shared/hotkeys/dialog/hotkeys-dialog.component.mjs +0 -23
  841. package/esm2022/src/app/shared/hotkeys/hotkeys.service.mjs +0 -147
  842. package/esm2022/src/app/shared/hotkeys/shared-hotkeys.module.mjs +0 -24
  843. package/esm2022/src/app/shared/http/http.utils.mjs +0 -56
  844. package/esm2022/src/app/shared/image/gallery/image-gallery.component.mjs +0 -443
  845. package/esm2022/src/app/shared/image/gallery/image-gallery.module.mjs +0 -62
  846. package/esm2022/src/app/shared/image/gallery/testing/gallegry.model.testing.mjs +0 -26
  847. package/esm2022/src/app/shared/image/gallery/testing/gallery.service.testing.mjs +0 -87
  848. package/esm2022/src/app/shared/image/gallery/testing/gallery.testing.mjs +0 -37
  849. package/esm2022/src/app/shared/image/gallery/testing/gallery.testing.module.mjs +0 -59
  850. package/esm2022/src/app/shared/image/image.model.mjs +0 -2
  851. package/esm2022/src/app/shared/image/image.module.mjs +0 -24
  852. package/esm2022/src/app/shared/image/image.service.mjs +0 -109
  853. package/esm2022/src/app/shared/inputs.mjs +0 -279
  854. package/esm2022/src/app/shared/interceptors/progess.interceptor.mjs +0 -27
  855. package/esm2022/src/app/shared/logging/log-level.model.mjs +0 -48
  856. package/esm2022/src/app/shared/logging/logger.model.mjs +0 -47
  857. package/esm2022/src/app/shared/logging/logging-service.class.mjs +0 -125
  858. package/esm2022/src/app/shared/logging/logging-service.config.mjs +0 -2
  859. package/esm2022/src/app/shared/logging/logging-service.module.mjs +0 -30
  860. package/esm2022/src/app/shared/markdown/markdown.component.mjs +0 -321
  861. package/esm2022/src/app/shared/markdown/markdown.directive.mjs +0 -34
  862. package/esm2022/src/app/shared/markdown/markdown.modal.mjs +0 -99
  863. package/esm2022/src/app/shared/markdown/markdown.module.mjs +0 -87
  864. package/esm2022/src/app/shared/markdown/markdown.service.mjs +0 -204
  865. package/esm2022/src/app/shared/markdown/markdown.utils.mjs +0 -87
  866. package/esm2022/src/app/shared/markdown/testing/markdown.test.mjs +0 -55
  867. package/esm2022/src/app/shared/markdown/testing/markdown.testing.module.mjs +0 -30
  868. package/esm2022/src/app/shared/material/autocomplete/material.autocomplete.config.mjs +0 -46
  869. package/esm2022/src/app/shared/material/autocomplete/material.autocomplete.mjs +0 -1313
  870. package/esm2022/src/app/shared/material/autocomplete/material.autocomplete.module.mjs +0 -79
  871. package/esm2022/src/app/shared/material/autocomplete/material.autocomplete.utils.mjs +0 -18
  872. package/esm2022/src/app/shared/material/autocomplete/testing/autocomplete.test.mjs +0 -242
  873. package/esm2022/src/app/shared/material/badge/badge.directive.mjs +0 -251
  874. package/esm2022/src/app/shared/material/badge/badge.module.mjs +0 -20
  875. package/esm2022/src/app/shared/material/badge/badge.test.mjs +0 -42
  876. package/esm2022/src/app/shared/material/boolean/boolean.module.mjs +0 -67
  877. package/esm2022/src/app/shared/material/boolean/material.boolean.mjs +0 -371
  878. package/esm2022/src/app/shared/material/boolean/testing/boolean.test.page.mjs +0 -72
  879. package/esm2022/src/app/shared/material/chips/chips.module.mjs +0 -71
  880. package/esm2022/src/app/shared/material/chips/material.chips.mjs +0 -836
  881. package/esm2022/src/app/shared/material/chips/testing/chips.test.mjs +0 -151
  882. package/esm2022/src/app/shared/material/datetime/datetime.module.mjs +0 -76
  883. package/esm2022/src/app/shared/material/datetime/material.date.mjs +0 -471
  884. package/esm2022/src/app/shared/material/datetime/material.dateshort.mjs +0 -457
  885. package/esm2022/src/app/shared/material/datetime/material.datetime.mjs +0 -693
  886. package/esm2022/src/app/shared/material/datetime/testing/mat-date-time.test.mjs +0 -136
  887. package/esm2022/src/app/shared/material/datetime/testing/mat-date.test.mjs +0 -127
  888. package/esm2022/src/app/shared/material/datetime/testing/mat-dateshort.test.mjs +0 -118
  889. package/esm2022/src/app/shared/material/duration/duration.module.mjs +0 -61
  890. package/esm2022/src/app/shared/material/duration/duration.utils.mjs +0 -16
  891. package/esm2022/src/app/shared/material/duration/material.duration.mjs +0 -283
  892. package/esm2022/src/app/shared/material/duration/testing/mat-duration.test.mjs +0 -85
  893. package/esm2022/src/app/shared/material/latlong/latlong.utils.mjs +0 -319
  894. package/esm2022/src/app/shared/material/latlong/material.latlong-input.mjs +0 -432
  895. package/esm2022/src/app/shared/material/latlong/material.latlong.mjs +0 -231
  896. package/esm2022/src/app/shared/material/latlong/material.latlong.module.mjs +0 -68
  897. package/esm2022/src/app/shared/material/latlong/testing/latlong.test.mjs +0 -137
  898. package/esm2022/src/app/shared/material/material.animations.mjs +0 -200
  899. package/esm2022/src/app/shared/material/material.config.mjs +0 -3
  900. package/esm2022/src/app/shared/material/material.module.mjs +0 -229
  901. package/esm2022/src/app/shared/material/material.testing.module.mjs +0 -245
  902. package/esm2022/src/app/shared/material/paginator/material.paginator-i18n.mjs +0 -51
  903. package/esm2022/src/app/shared/material/stepper/material.stepper-i18n.mjs +0 -23
  904. package/esm2022/src/app/shared/material/swipe/material.swipe.mjs +0 -379
  905. package/esm2022/src/app/shared/material/swipe/swipe.module.mjs +0 -52
  906. package/esm2022/src/app/shared/material/swipe/testing/swipe.test.mjs +0 -67
  907. package/esm2022/src/app/shared/material/test/test-component.mjs +0 -264
  908. package/esm2022/src/app/shared/material/testing/common.test.mjs +0 -111
  909. package/esm2022/src/app/shared/material/text/testing/text-form.testing.mjs +0 -42
  910. package/esm2022/src/app/shared/material/text/text-form.component.mjs +0 -205
  911. package/esm2022/src/app/shared/material/text/text-form.module.mjs +0 -63
  912. package/esm2022/src/app/shared/modules.mjs +0 -12
  913. package/esm2022/src/app/shared/named-filter/named-filter-selector.component.mjs +0 -303
  914. package/esm2022/src/app/shared/named-filter/named-filter.model.mjs +0 -49
  915. package/esm2022/src/app/shared/named-filter/named-filter.module.mjs +0 -24
  916. package/esm2022/src/app/shared/named-filter/named-filter.service.mjs +0 -69
  917. package/esm2022/src/app/shared/named-filter/testing/named-filter-selector.testing.mjs +0 -74
  918. package/esm2022/src/app/shared/named-filter/testing/named-filter.testing.module.mjs +0 -28
  919. package/esm2022/src/app/shared/observables.mjs +0 -100
  920. package/esm2022/src/app/shared/pipes/arrays.pipe.mjs +0 -217
  921. package/esm2022/src/app/shared/pipes/badge.pipes.mjs +0 -24
  922. package/esm2022/src/app/shared/pipes/colors.pipe.mjs +0 -29
  923. package/esm2022/src/app/shared/pipes/date-diff-duration.pipe.mjs +0 -50
  924. package/esm2022/src/app/shared/pipes/date-format.pipe.mjs +0 -72
  925. package/esm2022/src/app/shared/pipes/date-from-now.pipe.mjs +0 -28
  926. package/esm2022/src/app/shared/pipes/dates.pipe.mjs +0 -18
  927. package/esm2022/src/app/shared/pipes/display-with.pipe.mjs +0 -23
  928. package/esm2022/src/app/shared/pipes/duration.pipe.mjs +0 -34
  929. package/esm2022/src/app/shared/pipes/file-size.pipe.mjs +0 -53
  930. package/esm2022/src/app/shared/pipes/form.pipes.mjs +0 -219
  931. package/esm2022/src/app/shared/pipes/highlight.pipe.mjs +0 -50
  932. package/esm2022/src/app/shared/pipes/html.pipes.mjs +0 -69
  933. package/esm2022/src/app/shared/pipes/latlong-format.pipe.mjs +0 -42
  934. package/esm2022/src/app/shared/pipes/maps.pipe.mjs +0 -65
  935. package/esm2022/src/app/shared/pipes/maskito.pipe.mjs +0 -67
  936. package/esm2022/src/app/shared/pipes/math.pipes.mjs +0 -77
  937. package/esm2022/src/app/shared/pipes/ng-init.pipe.mjs +0 -19
  938. package/esm2022/src/app/shared/pipes/number-format.pipe.mjs +0 -17
  939. package/esm2022/src/app/shared/pipes/observable.pipes.mjs +0 -61
  940. package/esm2022/src/app/shared/pipes/pipes.module.mjs +0 -285
  941. package/esm2022/src/app/shared/pipes/property.pipes.mjs +0 -135
  942. package/esm2022/src/app/shared/pipes/selection.pipes.mjs +0 -179
  943. package/esm2022/src/app/shared/pipes/string.pipes.mjs +0 -183
  944. package/esm2022/src/app/shared/pipes/translate-context.pipe.mjs +0 -44
  945. package/esm2022/src/app/shared/pipes/types.pipes.mjs +0 -74
  946. package/esm2022/src/app/shared/pipes/url.pipes.mjs +0 -43
  947. package/esm2022/src/app/shared/platforms.mjs +0 -81
  948. package/esm2022/src/app/shared/print/print.service.mjs +0 -305
  949. package/esm2022/src/app/shared/regexps.mjs +0 -96
  950. package/esm2022/src/app/shared/rx-state/rx-state.decorators.mjs +0 -71
  951. package/esm2022/src/app/shared/rx-state/rx-state.module.mjs +0 -19
  952. package/esm2022/src/app/shared/rx-state/rx-state.types.mjs +0 -2
  953. package/esm2022/src/app/shared/services/entity-service.class.mjs +0 -10
  954. package/esm2022/src/app/shared/services/job.utils.mjs +0 -92
  955. package/esm2022/src/app/shared/services/memory-entity-service.class.mjs +0 -353
  956. package/esm2022/src/app/shared/services/progress-bar.service.mjs +0 -31
  957. package/esm2022/src/app/shared/services/startable-observable-service.class.mjs +0 -118
  958. package/esm2022/src/app/shared/services/startable-service.class.mjs +0 -107
  959. package/esm2022/src/app/shared/services/translate-context.service.mjs +0 -107
  960. package/esm2022/src/app/shared/services/validator-service.class.mjs +0 -2
  961. package/esm2022/src/app/shared/services.mjs +0 -85
  962. package/esm2022/src/app/shared/shared-routing.module.mjs +0 -72
  963. package/esm2022/src/app/shared/shared.module.mjs +0 -229
  964. package/esm2022/src/app/shared/shared.testing.module.mjs +0 -108
  965. package/esm2022/src/app/shared/storage/storage-explorer.component.mjs +0 -279
  966. package/esm2022/src/app/shared/storage/storage-explorer.module.mjs +0 -42
  967. package/esm2022/src/app/shared/storage/storage-explorer.testing-routing.module.mjs +0 -27
  968. package/esm2022/src/app/shared/storage/storage-explorer.testing.module.mjs +0 -25
  969. package/esm2022/src/app/shared/storage/storage.service.mjs +0 -134
  970. package/esm2022/src/app/shared/storage/storage.utils.mjs +0 -13
  971. package/esm2022/src/app/shared/testing/maskito.test.mjs +0 -41
  972. package/esm2022/src/app/shared/testing/observable.test.mjs +0 -94
  973. package/esm2022/src/app/shared/testing/tests.page.mjs +0 -37
  974. package/esm2022/src/app/shared/toast/toast.testing.mjs +0 -54
  975. package/esm2022/src/app/shared/toast/toast.testing.module.mjs +0 -31
  976. package/esm2022/src/app/shared/toast/toasts.mjs +0 -134
  977. package/esm2022/src/app/shared/toolbar/modal-toolbar.mjs +0 -62
  978. package/esm2022/src/app/shared/toolbar/toolbar.mjs +0 -267
  979. package/esm2022/src/app/shared/toolbar/toolbar.module.mjs +0 -26
  980. package/esm2022/src/app/shared/types.mjs +0 -2
  981. package/esm2022/src/app/shared/upload-file/testing/upload-file.testing.mjs +0 -59
  982. package/esm2022/src/app/shared/upload-file/testing/upload-file.testing.module.mjs +0 -30
  983. package/esm2022/src/app/shared/upload-file/upload-file-popover.component.mjs +0 -109
  984. package/esm2022/src/app/shared/upload-file/upload-file.component.mjs +0 -216
  985. package/esm2022/src/app/shared/upload-file/upload-file.model.mjs +0 -26
  986. package/esm2022/src/app/shared/validator/form-error-adapter.class.mjs +0 -114
  987. package/esm2022/src/app/shared/validator/validators.mjs +0 -621
  988. package/esm2022/src/app/shared/version/versions.mjs +0 -81
  989. package/esm2022/src/app/social/job/job.module.mjs +0 -23
  990. package/esm2022/src/app/social/job/progression/job-progression.component.mjs +0 -35
  991. package/esm2022/src/app/social/job/progression/job-progression.icon.mjs +0 -235
  992. package/esm2022/src/app/social/job/progression/job-progression.list.mjs +0 -47
  993. package/esm2022/src/app/social/job/progression/job-progression.model.mjs +0 -29
  994. package/esm2022/src/app/social/job/progression/job-progression.service.mjs +0 -91
  995. package/esm2022/src/app/social/job/testing/job-progression.testing.mjs +0 -38
  996. package/esm2022/src/app/social/job/testing/job-progression.testing.service.mjs +0 -34
  997. package/esm2022/src/app/social/job/testing/job.testing.module.mjs +0 -22
  998. package/esm2022/src/app/social/message/message.form.mjs +0 -141
  999. package/esm2022/src/app/social/message/message.modal.mjs +0 -110
  1000. package/esm2022/src/app/social/message/message.model.mjs +0 -75
  1001. package/esm2022/src/app/social/message/message.module.mjs +0 -22
  1002. package/esm2022/src/app/social/message/message.service.mjs +0 -110
  1003. package/esm2022/src/app/social/social.errors.mjs +0 -10
  1004. package/esm2022/src/app/social/social.module.mjs +0 -22
  1005. package/esm2022/src/app/social/social.testing.module.mjs +0 -40
  1006. package/esm2022/src/app/social/user-event/notification/user-event-notification.icon.mjs +0 -127
  1007. package/esm2022/src/app/social/user-event/notification/user-event-notification.list.mjs +0 -260
  1008. package/esm2022/src/app/social/user-event/testing/user-event.testing.mjs +0 -257
  1009. package/esm2022/src/app/social/user-event/testing/user-event.testing.model.mjs +0 -129
  1010. package/esm2022/src/app/social/user-event/testing/user-event.testing.module.mjs +0 -22
  1011. package/esm2022/src/app/social/user-event/testing/user-event.testing.service.mjs +0 -128
  1012. package/esm2022/src/app/social/user-event/user-event.model.mjs +0 -2
  1013. package/esm2022/src/app/social/user-event/user-event.module.mjs +0 -23
  1014. package/esm2022/src/app/social/user-event/user-event.service.mjs +0 -512
  1015. package/esm2022/src/environments/environment.class.mjs +0 -65
  1016. package/esm2022/src/environments/environment.loader.mjs +0 -77
  1017. package/esm2022/src/environments/environment.mjs +0 -109
  1018. package/esm2022/sumaris-net.ngx-components.mjs +0 -5
  1019. package/fesm2022/sumaris-net.ngx-components.mjs +0 -48596
  1020. package/fesm2022/sumaris-net.ngx-components.mjs.map +0 -1
  1021. package/index.d.ts +0 -5
  1022. package/public_api.d.ts +0 -344
  1023. package/src/app/admin/admin-routing.module.d.ts +0 -9
  1024. package/src/app/admin/admin.module.d.ts +0 -10
  1025. package/src/app/admin/services/filter/person.filter.d.ts +0 -22
  1026. package/src/app/admin/services/person.service.d.ts +0 -37
  1027. package/src/app/admin/services/validator/person.validator.d.ts +0 -23
  1028. package/src/app/admin/users/users.d.ts +0 -61
  1029. package/src/app/admin/users/users.module.d.ts +0 -14
  1030. package/src/app/core/about/about.modal.d.ts +0 -32
  1031. package/src/app/core/about/about.module.d.ts +0 -11
  1032. package/src/app/core/account/account.module.d.ts +0 -18
  1033. package/src/app/core/account/account.page.d.ts +0 -83
  1034. package/src/app/core/account/new-token.form.d.ts +0 -29
  1035. package/src/app/core/account/new-token.modal.d.ts +0 -29
  1036. package/src/app/core/account/password/change-password.form.d.ts +0 -19
  1037. package/src/app/core/account/password/change-password.module.d.ts +0 -11
  1038. package/src/app/core/account/password/change-password.page.d.ts +0 -36
  1039. package/src/app/core/account/token.table.d.ts +0 -27
  1040. package/src/app/core/auth/auth.form.d.ts +0 -38
  1041. package/src/app/core/auth/auth.modal.d.ts +0 -24
  1042. package/src/app/core/auth/auth.module.d.ts +0 -13
  1043. package/src/app/core/auth/reset-password.modal.d.ts +0 -29
  1044. package/src/app/core/core.module.d.ts +0 -28
  1045. package/src/app/core/core.testing.module.d.ts +0 -15
  1046. package/src/app/core/form/array/form-array.d.ts +0 -137
  1047. package/src/app/core/form/array/testing/form-array-test.module.d.ts +0 -12
  1048. package/src/app/core/form/array/testing/form-array.test.d.ts +0 -26
  1049. package/src/app/core/form/buttons/form-buttons-bar.component.d.ts +0 -37
  1050. package/src/app/core/form/buttons/form-buttons-bar.module.d.ts +0 -9
  1051. package/src/app/core/form/entity/editor.class.d.ts +0 -84
  1052. package/src/app/core/form/entity/entity-editor-modal.class.d.ts +0 -126
  1053. package/src/app/core/form/entity/entity-editor.class.d.ts +0 -204
  1054. package/src/app/core/form/entity/entity-metadata.component.d.ts +0 -13
  1055. package/src/app/core/form/entity/entity.module.d.ts +0 -10
  1056. package/src/app/core/form/entity/tab-editor.class.d.ts +0 -66
  1057. package/src/app/core/form/form-container.class.d.ts +0 -127
  1058. package/src/app/core/form/form.class.d.ts +0 -144
  1059. package/src/app/core/form/form.module.d.ts +0 -14
  1060. package/src/app/core/form/form.utils.d.ts +0 -260
  1061. package/src/app/core/form/list/list.form.d.ts +0 -81
  1062. package/src/app/core/form/list/list.module.d.ts +0 -9
  1063. package/src/app/core/form/properties/properties.form.d.ts +0 -92
  1064. package/src/app/core/form/properties/properties.module.d.ts +0 -11
  1065. package/src/app/core/form/properties/properties.table.d.ts +0 -72
  1066. package/src/app/core/form/properties/properties.utils.d.ts +0 -59
  1067. package/src/app/core/form/properties/property.validator.d.ts +0 -27
  1068. package/src/app/core/form/properties/testing/properties-form.test.d.ts +0 -22
  1069. package/src/app/core/form/properties/testing/properties-form.testing.module.d.ts +0 -12
  1070. package/src/app/core/form/text-popover/testing/text-popover.testing.d.ts +0 -16
  1071. package/src/app/core/form/text-popover/testing/text-popover.testing.module.d.ts +0 -11
  1072. package/src/app/core/form/text-popover/text-popover.component.d.ts +0 -80
  1073. package/src/app/core/form/text-popover/text-popover.module.d.ts +0 -9
  1074. package/src/app/core/form/username/username.form.d.ts +0 -19
  1075. package/src/app/core/form/username/username.module.d.ts +0 -9
  1076. package/src/app/core/graphql/graphql.module.d.ts +0 -7
  1077. package/src/app/core/graphql/graphql.service.d.ts +0 -142
  1078. package/src/app/core/graphql/graphql.utils.d.ts +0 -47
  1079. package/src/app/core/home/home.d.ts +0 -109
  1080. package/src/app/core/home/home.module.d.ts +0 -14
  1081. package/src/app/core/icon/icon.component.d.ts +0 -13
  1082. package/src/app/core/icon/icon.module.d.ts +0 -9
  1083. package/src/app/core/install/install-upgrade-card.component.d.ts +0 -63
  1084. package/src/app/core/install/install-upgrade-card.module.d.ts +0 -9
  1085. package/src/app/core/menu/menu.component.d.ts +0 -66
  1086. package/src/app/core/menu/menu.model.d.ts +0 -144
  1087. package/src/app/core/menu/menu.module.d.ts +0 -12
  1088. package/src/app/core/menu/menu.service.d.ts +0 -93
  1089. package/src/app/core/menu/sub-menu-tab.directive.d.ts +0 -29
  1090. package/src/app/core/menu/testing/menu-other.testing.d.ts +0 -15
  1091. package/src/app/core/menu/testing/menu.testing.d.ts +0 -51
  1092. package/src/app/core/menu/testing/menu.testing.module.d.ts +0 -12
  1093. package/src/app/core/offline/update-offline-mode-card.component.d.ts +0 -11
  1094. package/src/app/core/offline/update-offline-mode-card.module.d.ts +0 -9
  1095. package/src/app/core/peer/select-peer.modal.d.ts +0 -101
  1096. package/src/app/core/peer/select-peer.module.d.ts +0 -12
  1097. package/src/app/core/register/register-confirm.page.d.ts +0 -24
  1098. package/src/app/core/register/register.form.d.ts +0 -49
  1099. package/src/app/core/register/register.modal.d.ts +0 -14
  1100. package/src/app/core/register/register.module.d.ts +0 -12
  1101. package/src/app/core/services/account.service.d.ts +0 -207
  1102. package/src/app/core/services/auth-guard.service.d.ts +0 -17
  1103. package/src/app/core/services/base-entity-service.class.d.ts +0 -135
  1104. package/src/app/core/services/base-graphql-service.class.d.ts +0 -77
  1105. package/src/app/core/services/base58.d.ts +0 -7
  1106. package/src/app/core/services/config/core.config.d.ts +0 -46
  1107. package/src/app/core/services/config.service.d.ts +0 -63
  1108. package/src/app/core/services/crypto.service.d.ts +0 -44
  1109. package/src/app/core/services/errors.d.ts +0 -65
  1110. package/src/app/core/services/local-settings.service.d.ts +0 -99
  1111. package/src/app/core/services/model/account.model.d.ts +0 -56
  1112. package/src/app/core/services/model/config.model.d.ts +0 -36
  1113. package/src/app/core/services/model/department.model.d.ts +0 -11
  1114. package/src/app/core/services/model/entity.decorators.d.ts +0 -17
  1115. package/src/app/core/services/model/entity.model.d.ts +0 -133
  1116. package/src/app/core/services/model/filter.model.d.ts +0 -37
  1117. package/src/app/core/services/model/history.model.d.ts +0 -20
  1118. package/src/app/core/services/model/model.enum.d.ts +0 -7
  1119. package/src/app/core/services/model/node-feature.model.d.ts +0 -14
  1120. package/src/app/core/services/model/peer.model.d.ts +0 -35
  1121. package/src/app/core/services/model/person.model.d.ts +0 -37
  1122. package/src/app/core/services/model/referential.model.d.ts +0 -84
  1123. package/src/app/core/services/model/settings.model.d.ts +0 -29
  1124. package/src/app/core/services/model/token.model.d.ts +0 -22
  1125. package/src/app/core/services/model/tree-item-entity.model.d.ts +0 -53
  1126. package/src/app/core/services/network.service.d.ts +0 -159
  1127. package/src/app/core/services/network.types.d.ts +0 -4
  1128. package/src/app/core/services/network.utils.d.ts +0 -38
  1129. package/src/app/core/services/pipes/account.pipes.d.ts +0 -15
  1130. package/src/app/core/services/pipes/department-to-string.pipe.d.ts +0 -9
  1131. package/src/app/core/services/pipes/person-to-string.pipe.d.ts +0 -11
  1132. package/src/app/core/services/pipes/pipes.module.d.ts +0 -11
  1133. package/src/app/core/services/pipes/referential-to-string.pipe.d.ts +0 -13
  1134. package/src/app/core/services/pipes/usage-mode.pipes.d.ts +0 -15
  1135. package/src/app/core/services/platform.service.d.ts +0 -110
  1136. package/src/app/core/services/storage/entities-storage.service.d.ts +0 -108
  1137. package/src/app/core/services/storage/entity-store.class.d.ts +0 -113
  1138. package/src/app/core/services/testing/referential-filter.model.d.ts +0 -9
  1139. package/src/app/core/services/testing/referential.validator.d.ts +0 -22
  1140. package/src/app/core/services/validator/account.validator.d.ts +0 -24
  1141. package/src/app/core/services/validator/base.validator.class.d.ts +0 -21
  1142. package/src/app/core/services/validator/local-settings.validator.d.ts +0 -18
  1143. package/src/app/core/services/validator/user-settings.validator.d.ts +0 -10
  1144. package/src/app/core/services/validator/user-token.validator.d.ts +0 -13
  1145. package/src/app/core/settings/settings.module.d.ts +0 -12
  1146. package/src/app/core/settings/settings.page.d.ts +0 -88
  1147. package/src/app/core/table/async-table.class.d.ts +0 -395
  1148. package/src/app/core/table/column/actions-column.component.d.ts +0 -62
  1149. package/src/app/core/table/column/nav-actions-column.component.d.ts +0 -46
  1150. package/src/app/core/table/column/row-field.component.d.ts +0 -40
  1151. package/src/app/core/table/entities-async-table-datasource.class.d.ts +0 -100
  1152. package/src/app/core/table/entities-table-datasource.class.d.ts +0 -103
  1153. package/src/app/core/table/memory-table.class.d.ts +0 -25
  1154. package/src/app/core/table/table-select-columns.component.d.ts +0 -22
  1155. package/src/app/core/table/table.class.d.ts +0 -400
  1156. package/src/app/core/table/table.model.d.ts +0 -31
  1157. package/src/app/core/table/table.module.d.ts +0 -14
  1158. package/src/app/core/table/table.pipes.d.ts +0 -29
  1159. package/src/app/core/table/table.utils.d.ts +0 -13
  1160. package/src/app/core/table/testing/table-validator.service.d.ts +0 -17
  1161. package/src/app/core/table/testing/table.testing.d.ts +0 -54
  1162. package/src/app/core/table/testing/table.testing.module.d.ts +0 -14
  1163. package/src/app/core/table/testing/table2-validator.service.d.ts +0 -15
  1164. package/src/app/core/table/testing/table2.testing.d.ts +0 -48
  1165. package/src/app/shared/alerts.d.ts +0 -55
  1166. package/src/app/shared/audio/audio.d.ts +0 -45
  1167. package/src/app/shared/audio/audio.testing.d.ts +0 -13
  1168. package/src/app/shared/audio/audio.testing.module.d.ts +0 -11
  1169. package/src/app/shared/capacitor/keyboard.d.ts +0 -16
  1170. package/src/app/shared/capacitor/plugins.d.ts +0 -7
  1171. package/src/app/shared/constants.d.ts +0 -13
  1172. package/src/app/shared/dates.d.ts +0 -61
  1173. package/src/app/shared/debug/debug-service.class.d.ts +0 -5
  1174. package/src/app/shared/debug/debug.component.d.ts +0 -14
  1175. package/src/app/shared/debug/debug.module.d.ts +0 -12
  1176. package/src/app/shared/directives/autofocus.directive.d.ts +0 -18
  1177. package/src/app/shared/directives/autoresize.directive.d.ts +0 -20
  1178. package/src/app/shared/directives/autotitle.directive.d.ts +0 -11
  1179. package/src/app/shared/directives/directives.module.d.ts +0 -14
  1180. package/src/app/shared/directives/drag-and-drop.directive.d.ts +0 -17
  1181. package/src/app/shared/directives/ng-var.directive.d.ts +0 -12
  1182. package/src/app/shared/directives/resizable/resizable.component.d.ts +0 -21
  1183. package/src/app/shared/directives/resizable/resizable.directive.d.ts +0 -12
  1184. package/src/app/shared/directives/resizable/resizable.module.d.ts +0 -8
  1185. package/src/app/shared/directives/throttled-click.directive.d.ts +0 -16
  1186. package/src/app/shared/events.d.ts +0 -29
  1187. package/src/app/shared/file/csv.utils.d.ts +0 -30
  1188. package/src/app/shared/file/file.service.d.ts +0 -23
  1189. package/src/app/shared/file/file.utils.d.ts +0 -20
  1190. package/src/app/shared/file/images.utils.d.ts +0 -36
  1191. package/src/app/shared/file/json.utils.d.ts +0 -19
  1192. package/src/app/shared/file/uri.utils.d.ts +0 -8
  1193. package/src/app/shared/file/url.utils.d.ts +0 -77
  1194. package/src/app/shared/focusable.d.ts +0 -4
  1195. package/src/app/shared/form/field.component.d.ts +0 -85
  1196. package/src/app/shared/form/field.model.d.ts +0 -82
  1197. package/src/app/shared/form/loading-spinner.d.ts +0 -8
  1198. package/src/app/shared/forms.d.ts +0 -135
  1199. package/src/app/shared/functions.d.ts +0 -206
  1200. package/src/app/shared/geolocation/geolocation.utils.d.ts +0 -19
  1201. package/src/app/shared/gesture/gesture-config.d.ts +0 -15
  1202. package/src/app/shared/gesture/hammer.utils.d.ts +0 -16
  1203. package/src/app/shared/graph/colors.utils.d.ts +0 -17
  1204. package/src/app/shared/graph/graph-colors.d.ts +0 -63
  1205. package/src/app/shared/guard/component-dirty.guard.d.ts +0 -14
  1206. package/src/app/shared/hotkeys/dialog/hotkeys-dialog.component.d.ts +0 -8
  1207. package/src/app/shared/hotkeys/hotkeys.service.d.ts +0 -48
  1208. package/src/app/shared/hotkeys/shared-hotkeys.module.d.ts +0 -11
  1209. package/src/app/shared/http/http.utils.d.ts +0 -28
  1210. package/src/app/shared/image/gallery/image-gallery.component.d.ts +0 -137
  1211. package/src/app/shared/image/gallery/image-gallery.module.d.ts +0 -15
  1212. package/src/app/shared/image/gallery/testing/gallegry.model.testing.d.ts +0 -12
  1213. package/src/app/shared/image/gallery/testing/gallery.service.testing.d.ts +0 -33
  1214. package/src/app/shared/image/gallery/testing/gallery.testing.d.ts +0 -16
  1215. package/src/app/shared/image/gallery/testing/gallery.testing.module.d.ts +0 -13
  1216. package/src/app/shared/image/image.model.d.ts +0 -7
  1217. package/src/app/shared/image/image.module.d.ts +0 -8
  1218. package/src/app/shared/image/image.service.d.ts +0 -36
  1219. package/src/app/shared/inputs.d.ts +0 -36
  1220. package/src/app/shared/interceptors/progess.interceptor.d.ts +0 -8
  1221. package/src/app/shared/logging/log-level.model.d.ts +0 -38
  1222. package/src/app/shared/logging/logger.model.d.ts +0 -68
  1223. package/src/app/shared/logging/logging-service.class.d.ts +0 -39
  1224. package/src/app/shared/logging/logging-service.config.d.ts +0 -25
  1225. package/src/app/shared/logging/logging-service.module.d.ts +0 -9
  1226. package/src/app/shared/markdown/markdown.component.d.ts +0 -86
  1227. package/src/app/shared/markdown/markdown.directive.d.ts +0 -13
  1228. package/src/app/shared/markdown/markdown.modal.d.ts +0 -49
  1229. package/src/app/shared/markdown/markdown.module.d.ts +0 -17
  1230. package/src/app/shared/markdown/markdown.service.d.ts +0 -37
  1231. package/src/app/shared/markdown/markdown.utils.d.ts +0 -26
  1232. package/src/app/shared/markdown/testing/markdown.test.d.ts +0 -18
  1233. package/src/app/shared/markdown/testing/markdown.testing.module.d.ts +0 -12
  1234. package/src/app/shared/material/autocomplete/material.autocomplete.config.d.ts +0 -74
  1235. package/src/app/shared/material/autocomplete/material.autocomplete.d.ts +0 -211
  1236. package/src/app/shared/material/autocomplete/material.autocomplete.module.d.ts +0 -22
  1237. package/src/app/shared/material/autocomplete/material.autocomplete.utils.d.ts +0 -5
  1238. package/src/app/shared/material/autocomplete/testing/autocomplete.test.d.ts +0 -48
  1239. package/src/app/shared/material/badge/badge.directive.d.ts +0 -43
  1240. package/src/app/shared/material/badge/badge.module.d.ts +0 -10
  1241. package/src/app/shared/material/badge/badge.test.d.ts +0 -21
  1242. package/src/app/shared/material/boolean/boolean.module.d.ts +0 -20
  1243. package/src/app/shared/material/boolean/material.boolean.d.ts +0 -93
  1244. package/src/app/shared/material/boolean/testing/boolean.test.page.d.ts +0 -26
  1245. package/src/app/shared/material/chips/chips.module.d.ts +0 -21
  1246. package/src/app/shared/material/chips/material.chips.d.ts +0 -164
  1247. package/src/app/shared/material/chips/testing/chips.test.d.ts +0 -32
  1248. package/src/app/shared/material/datetime/datetime.module.d.ts +0 -24
  1249. package/src/app/shared/material/datetime/material.date.d.ts +0 -90
  1250. package/src/app/shared/material/datetime/material.dateshort.d.ts +0 -89
  1251. package/src/app/shared/material/datetime/material.datetime.d.ts +0 -116
  1252. package/src/app/shared/material/datetime/testing/mat-date-time.test.d.ts +0 -37
  1253. package/src/app/shared/material/datetime/testing/mat-date.test.d.ts +0 -32
  1254. package/src/app/shared/material/datetime/testing/mat-dateshort.test.d.ts +0 -31
  1255. package/src/app/shared/material/duration/duration.module.d.ts +0 -18
  1256. package/src/app/shared/material/duration/duration.utils.d.ts +0 -2
  1257. package/src/app/shared/material/duration/material.duration.d.ts +0 -64
  1258. package/src/app/shared/material/duration/testing/mat-duration.test.d.ts +0 -23
  1259. package/src/app/shared/material/latlong/latlong.utils.d.ts +0 -59
  1260. package/src/app/shared/material/latlong/material.latlong-input.d.ts +0 -85
  1261. package/src/app/shared/material/latlong/material.latlong.d.ts +0 -90
  1262. package/src/app/shared/material/latlong/material.latlong.module.d.ts +0 -21
  1263. package/src/app/shared/material/latlong/testing/latlong.test.d.ts +0 -28
  1264. package/src/app/shared/material/material.animations.d.ts +0 -8
  1265. package/src/app/shared/material/material.config.d.ts +0 -3
  1266. package/src/app/shared/material/material.module.d.ts +0 -45
  1267. package/src/app/shared/material/material.testing.module.d.ts +0 -32
  1268. package/src/app/shared/material/paginator/material.paginator-i18n.d.ts +0 -12
  1269. package/src/app/shared/material/stepper/material.stepper-i18n.d.ts +0 -10
  1270. package/src/app/shared/material/swipe/material.swipe.d.ts +0 -89
  1271. package/src/app/shared/material/swipe/swipe.module.d.ts +0 -16
  1272. package/src/app/shared/material/swipe/testing/swipe.test.d.ts +0 -22
  1273. package/src/app/shared/material/test/test-component.d.ts +0 -75
  1274. package/src/app/shared/material/testing/common.test.d.ts +0 -25
  1275. package/src/app/shared/material/text/testing/text-form.testing.d.ts +0 -19
  1276. package/src/app/shared/material/text/text-form.component.d.ts +0 -66
  1277. package/src/app/shared/material/text/text-form.module.d.ts +0 -16
  1278. package/src/app/shared/modules.d.ts +0 -9
  1279. package/src/app/shared/named-filter/named-filter-selector.component.d.ts +0 -62
  1280. package/src/app/shared/named-filter/named-filter.model.d.ts +0 -32
  1281. package/src/app/shared/named-filter/named-filter.module.d.ts +0 -13
  1282. package/src/app/shared/named-filter/named-filter.service.d.ts +0 -32
  1283. package/src/app/shared/named-filter/testing/named-filter-selector.testing.d.ts +0 -34
  1284. package/src/app/shared/named-filter/testing/named-filter.testing.module.d.ts +0 -10
  1285. package/src/app/shared/observables.d.ts +0 -30
  1286. package/src/app/shared/pipes/arrays.pipe.d.ts +0 -82
  1287. package/src/app/shared/pipes/badge.pipes.d.ts +0 -7
  1288. package/src/app/shared/pipes/colors.pipe.d.ts +0 -9
  1289. package/src/app/shared/pipes/date-diff-duration.pipe.d.ts +0 -25
  1290. package/src/app/shared/pipes/date-format.pipe.d.ts +0 -35
  1291. package/src/app/shared/pipes/date-from-now.pipe.d.ts +0 -12
  1292. package/src/app/shared/pipes/dates.pipe.d.ts +0 -10
  1293. package/src/app/shared/pipes/display-with.pipe.d.ts +0 -8
  1294. package/src/app/shared/pipes/duration.pipe.d.ts +0 -23
  1295. package/src/app/shared/pipes/file-size.pipe.d.ts +0 -30
  1296. package/src/app/shared/pipes/form.pipes.d.ts +0 -69
  1297. package/src/app/shared/pipes/highlight.pipe.d.ts +0 -11
  1298. package/src/app/shared/pipes/html.pipes.d.ts +0 -22
  1299. package/src/app/shared/pipes/latlong-format.pipe.d.ts +0 -20
  1300. package/src/app/shared/pipes/maps.pipe.d.ts +0 -23
  1301. package/src/app/shared/pipes/maskito.pipe.d.ts +0 -14
  1302. package/src/app/shared/pipes/math.pipes.d.ts +0 -26
  1303. package/src/app/shared/pipes/ng-init.pipe.d.ts +0 -8
  1304. package/src/app/shared/pipes/number-format.pipe.d.ts +0 -9
  1305. package/src/app/shared/pipes/observable.pipes.d.ts +0 -25
  1306. package/src/app/shared/pipes/pipes.module.d.ts +0 -35
  1307. package/src/app/shared/pipes/property.pipes.d.ts +0 -41
  1308. package/src/app/shared/pipes/selection.pipes.d.ts +0 -62
  1309. package/src/app/shared/pipes/string.pipes.d.ts +0 -68
  1310. package/src/app/shared/pipes/translate-context.pipe.d.ts +0 -17
  1311. package/src/app/shared/pipes/types.pipes.d.ts +0 -30
  1312. package/src/app/shared/pipes/url.pipes.d.ts +0 -27
  1313. package/src/app/shared/platforms.d.ts +0 -16
  1314. package/src/app/shared/print/print.service.d.ts +0 -94
  1315. package/src/app/shared/regexps.d.ts +0 -32
  1316. package/src/app/shared/rx-state/rx-state.decorators.d.ts +0 -7
  1317. package/src/app/shared/rx-state/rx-state.module.d.ts +0 -10
  1318. package/src/app/shared/rx-state/rx-state.types.d.ts +0 -4
  1319. package/src/app/shared/services/entity-service.class.d.ts +0 -75
  1320. package/src/app/shared/services/job.utils.d.ts +0 -20
  1321. package/src/app/shared/services/memory-entity-service.class.d.ts +0 -79
  1322. package/src/app/shared/services/progress-bar.service.d.ts +0 -20
  1323. package/src/app/shared/services/startable-observable-service.class.d.ts +0 -36
  1324. package/src/app/shared/services/startable-service.class.d.ts +0 -37
  1325. package/src/app/shared/services/translate-context.service.d.ts +0 -29
  1326. package/src/app/shared/services/validator-service.class.d.ts +0 -11
  1327. package/src/app/shared/services.d.ts +0 -17
  1328. package/src/app/shared/shared-routing.module.d.ts +0 -23
  1329. package/src/app/shared/shared.module.d.ts +0 -33
  1330. package/src/app/shared/shared.testing.module.d.ts +0 -20
  1331. package/src/app/shared/storage/storage-explorer.component.d.ts +0 -59
  1332. package/src/app/shared/storage/storage-explorer.module.d.ts +0 -13
  1333. package/src/app/shared/storage/storage-explorer.testing-routing.module.d.ts +0 -9
  1334. package/src/app/shared/storage/storage-explorer.testing.module.d.ts +0 -10
  1335. package/src/app/shared/storage/storage.service.d.ts +0 -22
  1336. package/src/app/shared/storage/storage.utils.d.ts +0 -19
  1337. package/src/app/shared/testing/maskito.test.d.ts +0 -10
  1338. package/src/app/shared/testing/observable.test.d.ts +0 -25
  1339. package/src/app/shared/testing/tests.page.d.ts +0 -20
  1340. package/src/app/shared/toast/toast.testing.d.ts +0 -15
  1341. package/src/app/shared/toast/toast.testing.module.d.ts +0 -12
  1342. package/src/app/shared/toast/toasts.d.ts +0 -16
  1343. package/src/app/shared/toolbar/modal-toolbar.d.ts +0 -21
  1344. package/src/app/shared/toolbar/toolbar.d.ts +0 -70
  1345. package/src/app/shared/toolbar/toolbar.module.d.ts +0 -16
  1346. package/src/app/shared/types.d.ts +0 -36
  1347. package/src/app/shared/upload-file/testing/upload-file.testing.d.ts +0 -21
  1348. package/src/app/shared/upload-file/testing/upload-file.testing.module.d.ts +0 -11
  1349. package/src/app/shared/upload-file/upload-file-popover.component.d.ts +0 -41
  1350. package/src/app/shared/upload-file/upload-file.component.d.ts +0 -50
  1351. package/src/app/shared/upload-file/upload-file.model.d.ts +0 -30
  1352. package/src/app/shared/validator/form-error-adapter.class.d.ts +0 -33
  1353. package/src/app/shared/validator/validators.d.ts +0 -139
  1354. package/src/app/shared/version/versions.d.ts +0 -26
  1355. package/src/app/social/job/job.module.d.ts +0 -12
  1356. package/src/app/social/job/progression/job-progression.component.d.ts +0 -23
  1357. package/src/app/social/job/progression/job-progression.icon.d.ts +0 -62
  1358. package/src/app/social/job/progression/job-progression.list.d.ts +0 -19
  1359. package/src/app/social/job/progression/job-progression.model.d.ts +0 -10
  1360. package/src/app/social/job/progression/job-progression.service.d.ts +0 -33
  1361. package/src/app/social/job/testing/job-progression.testing.d.ts +0 -13
  1362. package/src/app/social/job/testing/job-progression.testing.service.d.ts +0 -9
  1363. package/src/app/social/job/testing/job.testing.module.d.ts +0 -11
  1364. package/src/app/social/message/message.form.d.ts +0 -36
  1365. package/src/app/social/message/message.modal.d.ts +0 -43
  1366. package/src/app/social/message/message.model.d.ts +0 -33
  1367. package/src/app/social/message/message.module.d.ts +0 -12
  1368. package/src/app/social/message/message.service.d.ts +0 -32
  1369. package/src/app/social/social.errors.d.ts +0 -9
  1370. package/src/app/social/social.module.d.ts +0 -20
  1371. package/src/app/social/social.testing.module.d.ts +0 -13
  1372. package/src/app/social/user-event/notification/user-event-notification.icon.d.ts +0 -32
  1373. package/src/app/social/user-event/notification/user-event-notification.list.d.ts +0 -71
  1374. package/src/app/social/user-event/testing/user-event.testing.d.ts +0 -35
  1375. package/src/app/social/user-event/testing/user-event.testing.model.d.ts +0 -42
  1376. package/src/app/social/user-event/testing/user-event.testing.module.d.ts +0 -11
  1377. package/src/app/social/user-event/testing/user-event.testing.service.d.ts +0 -42
  1378. package/src/app/social/user-event/user-event.model.d.ts +0 -44
  1379. package/src/app/social/user-event/user-event.module.d.ts +0 -13
  1380. package/src/app/social/user-event/user-event.service.d.ts +0 -124
  1381. package/src/environments/environment.class.d.ts +0 -75
  1382. package/src/environments/environment.d.ts +0 -2
  1383. package/src/environments/environment.loader.d.ts +0 -24
@@ -0,0 +1,1567 @@
1
+ import { Inject, Injectable, InjectionToken, Optional } from '@angular/core';
2
+ import { CryptoService, Keypair } from './crypto.service';
3
+ import { Department } from './model/department.model';
4
+ import { Account, AccountUtils, UserSettings } from './model/account.model';
5
+ import { Person, PersonUtils, UserProfileLabel } from './model/person.model';
6
+ import { LocalSettings, UsageMode } from './model/settings.model';
7
+ import { BehaviorSubject, from, Observable, Subject, Subscription } from 'rxjs';
8
+ import { FetchPolicy, gql } from '@apollo/client/core';
9
+ import { Storage } from '@ionic/storage-angular';
10
+
11
+ import { isEmptyArray, isNil, removeDuplicatesFromArray, sleep, toNumber } from '../../shared/functions';
12
+ import { BaseGraphqlService } from './base-graphql-service.class';
13
+ import { ErrorCodes, ServerErrorCodes } from './errors';
14
+ import { GraphqlService } from '../graphql/graphql.service';
15
+ import { LocalSettingsService } from './local-settings.service';
16
+ import { FormFieldDefinition, FormFieldDefinitionMap } from '../../shared/form/field.model';
17
+ import { NetworkService } from './network.service';
18
+ import { AuthTokenType } from './network.types';
19
+ import { FileService } from '../../shared/file/file.service';
20
+ import { MINIFY_ENTITY_FOR_POD, Referential, ReferentialUtils } from './model/referential.model';
21
+ import { StatusIds } from './model/model.enum';
22
+ import { Base58 } from './base58';
23
+ import { Environment, ENVIRONMENT } from '../../../environments/environment.class';
24
+ import { fromDateISOString } from '../../shared/dates';
25
+ import { firstNotNilPromise } from '../../shared/observables';
26
+ import { debounceTime, filter, map, switchMap } from 'rxjs/operators';
27
+ import { BaseEntityGraphqlMutations, BaseEntityGraphqlQueries, BaseEntityGraphqlSubscriptions } from './base-entity-service.class';
28
+ import { Moment } from 'moment';
29
+ import { ShowToastOptions, Toasts } from '../../shared/toast/toasts';
30
+ import { OverlayEventDetail } from '@ionic/core';
31
+ import { ToastController } from '@ionic/angular';
32
+ import { TranslateService } from '@ngx-translate/core';
33
+ import { TokenScope, UserToken } from './model/token.model';
34
+ import { AppPropertiesUtils } from '../form/properties/properties.utils';
35
+
36
+ export declare interface AccountDetails {
37
+ loaded: boolean;
38
+ keypair: Keypair;
39
+ authToken: string;
40
+ authBasic?: string;
41
+ pubkey: string;
42
+ person: Person;
43
+ department: Department;
44
+ mainProfile: string;
45
+ }
46
+
47
+ export interface AuthData {
48
+ username: string;
49
+ password: string;
50
+ offline?: boolean;
51
+ }
52
+
53
+ export interface RegisterData extends AuthData {
54
+ account: Account;
55
+ }
56
+
57
+ export interface ChangePasswordData {
58
+ password: string;
59
+ confirmPassword: string;
60
+ email: string;
61
+ }
62
+
63
+ const TOKEN_STORAGE_KEY = 'token';
64
+ const PUBKEY_STORAGE_KEY = 'pubkey';
65
+ const SECKEY_STORAGE_KEY = 'seckey';
66
+ const ACCOUNT_STORAGE_KEY = 'account';
67
+
68
+ const DEFAULT_AVATAR_IMAGE = 'assets/img/person.png';
69
+
70
+ export interface UserSettingsOptions {
71
+ options: FormFieldDefinitionMap;
72
+ remoteLocalSettingsKeys?: (keyof LocalSettings | string)[];
73
+ }
74
+
75
+ export const APP_USER_SETTINGS_OPTIONS = new InjectionToken<UserSettingsOptions>('UserSettingsOptions');
76
+ export const APP_USER_TOKEN_SCOPES = new InjectionToken<TokenScope[]>('UserTokenScopes');
77
+
78
+ /* ------------------------------------
79
+ * GraphQL queries
80
+ * ------------------------------------*/
81
+ const Fragments = {
82
+ account: gql`
83
+ fragment AccountFragment on AccountVO {
84
+ id
85
+ firstName
86
+ lastName
87
+ email
88
+ pubkey
89
+ avatar
90
+ statusId
91
+ updateDate
92
+ creationDate
93
+ profiles
94
+ settings {
95
+ ...UserSettingsFragment
96
+ }
97
+ department {
98
+ id
99
+ label
100
+ name
101
+ __typename
102
+ }
103
+ __typename
104
+ }
105
+ `,
106
+
107
+ settings: gql`
108
+ fragment UserSettingsFragment on UserSettingsVO {
109
+ id
110
+ locale
111
+ latLongFormat
112
+ content
113
+ nonce
114
+ updateDate
115
+ __typename
116
+ }
117
+ `,
118
+
119
+ token: gql`
120
+ fragment UserTokenFragment on UserTokenVO {
121
+ id
122
+ pubkey
123
+ name
124
+ flags
125
+ expirationDate
126
+ lastUsedDate
127
+ creationDate
128
+ updateDate
129
+ __typename
130
+ }
131
+ `,
132
+ };
133
+
134
+ // Account queries
135
+ const Queries: Partial<BaseEntityGraphqlQueries> & { loadWithTokens: any } = {
136
+ load: gql`
137
+ query Account {
138
+ data: account {
139
+ ...AccountFragment
140
+ }
141
+ }
142
+ ${Fragments.account}
143
+ ${Fragments.settings}
144
+ `,
145
+
146
+ loadWithTokens: gql`
147
+ query AccountWithToken {
148
+ data: account {
149
+ ...AccountFragment
150
+ tokens {
151
+ ...UserTokenFragment
152
+ }
153
+ }
154
+ }
155
+ ${Fragments.account}
156
+ ${Fragments.settings}
157
+ ${Fragments.token}
158
+ `,
159
+ };
160
+
161
+ // Check email query
162
+ const IsEmailExistsQuery: any = gql`
163
+ query IsEmailExists($email: String, $hash: String) {
164
+ isEmailExists(email: $email, hash: $hash)
165
+ }
166
+ `;
167
+
168
+ export declare interface IsEmailExistsVariables {
169
+ email: string;
170
+ hash: string;
171
+ }
172
+
173
+ // Account mutations
174
+ const Mutations: Partial<BaseEntityGraphqlMutations> & { saveWithTokens: any; saveSettings: any; create: any } = {
175
+ save: gql`
176
+ mutation SaveAccount($data: AccountVOInput) {
177
+ data: saveAccount(account: $data) {
178
+ ...AccountFragment
179
+ }
180
+ }
181
+ ${Fragments.account}
182
+ ${Fragments.settings}
183
+ `,
184
+
185
+ saveWithTokens: gql`
186
+ mutation SaveAccountWithTokens($data: AccountVOInput) {
187
+ data: saveAccount(account: $data) {
188
+ ...AccountFragment
189
+ tokens {
190
+ ...UserTokenFragment
191
+ }
192
+ }
193
+ }
194
+ ${Fragments.account}
195
+ ${Fragments.settings}
196
+ ${Fragments.token}
197
+ `,
198
+
199
+ create: gql`
200
+ mutation CreateAccount($data: AccountVOInput) {
201
+ data: createAccount(account: $data) {
202
+ ...AccountFragment
203
+ }
204
+ }
205
+ ${Fragments.account}
206
+ ${Fragments.settings}
207
+ `,
208
+
209
+ saveSettings: gql`
210
+ mutation SaveSettings($data: UserSettingsVOInput) {
211
+ data: saveSettings(settings: $data) {
212
+ ...UserSettingsFragment
213
+ }
214
+ }
215
+ ${Fragments.settings}
216
+ `,
217
+ };
218
+
219
+ // Sent confirmation email
220
+ const SendConfirmEmailQuery: any = gql`
221
+ query sendAccountConfirmationEmail($email: String, $locale: String) {
222
+ data: sendAccountConfirmationEmail(email: $email, locale: $locale)
223
+ }
224
+ `;
225
+
226
+ // Confirm account email
227
+ const ConfirmEmailQuery: any = gql`
228
+ query confirmAccountEmail($email: String, $code: String) {
229
+ data: confirmAccountEmail(email: $email, code: $code)
230
+ }
231
+ `;
232
+
233
+ // Send email to reset password
234
+ const SendResetPasswordEmailQuery: any = gql`
235
+ query SendResetPasswordEmail($username: String!, $locale: String!) {
236
+ sendResetPasswordEmail(username: $username, locale: $locale)
237
+ }
238
+ `;
239
+
240
+ const ResetAccountPubkeyQuery: any = gql`
241
+ query ResetPubkey($username: String!, $token: String!) {
242
+ data: resetAccountPubkey(username: $username, token: $token)
243
+ }
244
+ `;
245
+
246
+ const UpdatePubKeyQuery: any = gql`
247
+ query UpdateAccountPubkey($pubkey: String!) {
248
+ data: updateAccountPubkey(pubkey: $pubkey)
249
+ }
250
+ `;
251
+
252
+ // Authentication query
253
+ const AuthQuery: any = gql`
254
+ query Auth($token: String) {
255
+ authenticate(token: $token)
256
+ }
257
+ `;
258
+
259
+ // New auth challenge query
260
+ const AuthChallengeQuery: any = gql`
261
+ query AuthChallenge {
262
+ authChallenge {
263
+ challenge
264
+ pubkey
265
+ signature
266
+ }
267
+ }
268
+ `;
269
+
270
+ interface IAuthChallenge {
271
+ pubkey: string;
272
+ challenge: string;
273
+ signature: string;
274
+ }
275
+
276
+ const AccountSubscriptions: BaseEntityGraphqlSubscriptions = {
277
+ listenChanges: gql`
278
+ subscription updateAccount($interval: Int) {
279
+ data: updateAccount(interval: $interval) {
280
+ id
281
+ updateDate
282
+ }
283
+ }
284
+ `,
285
+ };
286
+
287
+ export interface AccountWatchOptions {
288
+ intervalInSeconds?: number;
289
+ }
290
+
291
+ @Injectable({ providedIn: 'root', deps: [ENVIRONMENT] })
292
+ export class AccountService extends BaseGraphqlService<Account, any, number, Account> {
293
+ onLogin = new Subject<Account>();
294
+ onWillLogout = new Subject<Account>();
295
+ onLogout = new Subject<void>();
296
+ onChange = new Subject<Account>();
297
+ onAuthTokenChange = new BehaviorSubject<string | undefined>(undefined);
298
+ onAuthBasicChange = new BehaviorSubject<string | undefined>(undefined);
299
+
300
+ private _listenChangesSubscription: Subscription = null;
301
+ private readonly _enableListenChanges: boolean;
302
+ private readonly _listenIntervalInSeconds: number;
303
+ private _cache: AccountDetails = {
304
+ loaded: false,
305
+ keypair: null,
306
+ authToken: null,
307
+ authBasic: null,
308
+ pubkey: null,
309
+ mainProfile: null,
310
+ person: null,
311
+ department: null,
312
+ };
313
+ private readonly _optionDefs: FormFieldDefinition[];
314
+ private readonly _remoteLocalSettingsKeys: (keyof LocalSettings | string)[];
315
+ private _$additionalFields = new BehaviorSubject<FormFieldDefinition[]>([]);
316
+ private _tokenType$ = new BehaviorSubject<AuthTokenType>(undefined);
317
+ private _apiTokenEnabled = true;
318
+
319
+ get account(): Account {
320
+ return this._cache.loaded ? this._data : undefined;
321
+ }
322
+
323
+ get person(): Person {
324
+ if (this._cache.loaded && !this._cache.person) {
325
+ this._cache.person = this._cache.loaded ? this._data.asPerson() : undefined;
326
+ }
327
+ return this._cache.person;
328
+ }
329
+
330
+ get department(): Department {
331
+ if (this._cache.loaded && !this._cache.department) {
332
+ this._cache.department = this._cache.loaded ? this._data.asPerson().department : undefined;
333
+ }
334
+ return this._cache.department;
335
+ }
336
+
337
+ get tokenType(): AuthTokenType {
338
+ return this._tokenType$.value;
339
+ }
340
+
341
+ set tokenType(value: AuthTokenType) {
342
+ if (this._tokenType$.value !== value) {
343
+ console.info('[account] Using authentication token type: ' + value);
344
+ this._tokenType$.next(value);
345
+ // Reset values
346
+ this._cache.authToken = undefined;
347
+ this.onAuthTokenChange.next(undefined);
348
+ this._cache.authBasic = undefined;
349
+ this.onAuthBasicChange.next(undefined);
350
+ }
351
+ }
352
+
353
+ get apiTokenEnabled(): boolean {
354
+ return this._apiTokenEnabled;
355
+ }
356
+
357
+ set apiTokenEnabled(value: boolean) {
358
+ this._apiTokenEnabled = value;
359
+ }
360
+
361
+ constructor(
362
+ protected network: NetworkService,
363
+ protected graphql: GraphqlService,
364
+ protected settings: LocalSettingsService,
365
+ protected storage: Storage,
366
+ protected file: FileService,
367
+ @Optional() private translate: TranslateService,
368
+ @Optional() private toastController: ToastController,
369
+ @Inject(ENVIRONMENT) protected environment: Environment,
370
+ @Optional() @Inject(APP_USER_SETTINGS_OPTIONS) options: UserSettingsOptions
371
+ ) {
372
+ super(graphql, environment);
373
+ this._enableListenChanges = !environment.account || environment.account.enableListenChanges !== false; // True by default
374
+ this._listenIntervalInSeconds = toNumber(environment.account && environment.account.listenIntervalInSeconds, 0); // no timer by default
375
+
376
+ this._debug = !environment.production;
377
+ if (this._debug) console.debug('[account-service] Creating service');
378
+ this._optionDefs = Object.values(options?.options || {});
379
+ this._remoteLocalSettingsKeys = options?.remoteLocalSettingsKeys || [];
380
+
381
+ this.resetData();
382
+
383
+ // Send auth token to the graphql layer, when changed
384
+ this.onAuthTokenChange.subscribe((token) => this.graphql.setAuthToken(token));
385
+ this.onAuthBasicChange.subscribe((basic) => this.graphql.setAuthBasic(basic));
386
+
387
+ // Force network to wait account service, after getting connection to the peer
388
+ this.network.on('beforeTryOnlineFinish', async (online) => {
389
+ // If online, wait a full restart, because it can force offline mode
390
+ if (online && (!this.started || this.isLogin())) {
391
+ console.debug('[account] Force networkService.tryOnline() to wait, that graphql and account service is restarted...');
392
+ await sleep(500); // wait graphql service to be restarted
393
+ if (!this.started) await this.ready();
394
+ }
395
+ });
396
+ }
397
+
398
+ async ngOnStart(): Promise<Account> {
399
+ await Promise.all([
400
+ this.settings.ready(),
401
+ // Wait token type to be set
402
+ firstNotNilPromise(this._tokenType$, { stop: this.stopSubject }),
403
+ ]);
404
+
405
+ // Listen graphql start (or restart)
406
+ this.registerSubscription(
407
+ this.graphql.stopSubject.subscribe(() => {
408
+ if (this.started && this.isLogin()) {
409
+ console.debug('[account] Restarting, to retry to authenticate...');
410
+ this.restart();
411
+ }
412
+ })
413
+ );
414
+
415
+ await this.restoreLocally();
416
+ await this.listenSettings();
417
+
418
+ return this._data;
419
+ }
420
+
421
+ protected async ngOnStop(): Promise<void> {
422
+ const hadAuthToken = this._cache.authToken && true;
423
+ const hadAuthBasic = this._cache.authBasic && true;
424
+ const hadAuth = hadAuthToken || hadAuthBasic;
425
+ this.resetData();
426
+ if (hadAuth) {
427
+ this.onLogout.next();
428
+ this.onChange.next(undefined);
429
+ if (hadAuthToken) this.onAuthTokenChange.next(undefined);
430
+ if (hadAuthBasic) this.onAuthBasicChange.next(undefined);
431
+ }
432
+ }
433
+
434
+ isLogin(): boolean {
435
+ return !!(this._cache.pubkey && this._cache.loaded);
436
+ }
437
+
438
+ isAuth(): boolean {
439
+ return !!(this._cache.pubkey && this._cache.keypair && this._cache.keypair.secretKey);
440
+ }
441
+
442
+ hasMinProfile(userProfile: UserProfileLabel): boolean {
443
+ // should be login, and status ENABLE or TEMPORARY
444
+ if (!this._data || !this._data.pubkey || (this._data.statusId !== StatusIds.ENABLE && this._data.statusId !== StatusIds.TEMPORARY)) {
445
+ return false;
446
+ }
447
+ return PersonUtils.hasUpperOrEqualsProfile(this._data.profiles, userProfile);
448
+ }
449
+
450
+ hasExactProfile(label: UserProfileLabel): boolean {
451
+ return AccountUtils.hasExactProfile(this._data, label);
452
+ }
453
+
454
+ hasProfileAndIsEnable(userProfile: UserProfileLabel): boolean {
455
+ return AccountUtils.hasProfileAndIsEnable(this._data, userProfile);
456
+ }
457
+
458
+ isAdmin(): boolean {
459
+ return this.hasProfileAndIsEnable('ADMIN');
460
+ }
461
+
462
+ isSupervisor(): boolean {
463
+ return this.hasProfileAndIsEnable('SUPERVISOR');
464
+ }
465
+
466
+ isUser(): boolean {
467
+ return this.hasProfileAndIsEnable('USER');
468
+ }
469
+
470
+ /**
471
+ * @deprecated
472
+ * @param mode
473
+ */
474
+ isUsageMode(mode: UsageMode): boolean {
475
+ return this.settings.isUsageMode(mode);
476
+ }
477
+
478
+ isOnlyGuest(): boolean {
479
+ // Should be login, and status ENABLE or TEMPORARY
480
+ if (!this._data || !this._data.pubkey || (this._data.statusId !== StatusIds.ENABLE && this._data.statusId !== StatusIds.TEMPORARY)) return false;
481
+ // Profile less then user
482
+ return !PersonUtils.hasUpperOrEqualsProfile(this._data.profiles, 'USER');
483
+ }
484
+
485
+ /**
486
+ *
487
+ * @param recorderDepartment
488
+ * @deprecated use ProgramRefService.canUserWriteEntity() instead
489
+ */
490
+ canUserWriteDataForDepartment(recorderDepartment: Referential | any): boolean {
491
+ if (ReferentialUtils.isEmpty(recorderDepartment)) {
492
+ return this.isAdmin();
493
+ }
494
+
495
+ // Should be login, and status ENABLE
496
+ if (!this._data || !this._data.pubkey || this._data.statusId !== StatusIds.ENABLE) return false;
497
+
498
+ if (!this._data.department || !this._data.department.id) {
499
+ console.warn('User account has no department ! Unable to check write right against recorderDepartment');
500
+ return false;
501
+ }
502
+
503
+ // Same recorder department: OK, user can write
504
+ if (this._data.department.id === recorderDepartment.id) return true;
505
+
506
+ // Cannot write
507
+ return false;
508
+ }
509
+
510
+ async register(data: RegisterData): Promise<Account> {
511
+ if (this.isLogin()) {
512
+ throw new Error('User already login. Please logout before register.');
513
+ }
514
+ if (!data.username || !data.password) throw new Error('Missing required username or password');
515
+
516
+ if (this._debug) console.debug('[account] Register new user account...', data.account);
517
+ this._cache.loaded = false;
518
+ const now = Date.now();
519
+
520
+ try {
521
+ const keypair = await CryptoService.scryptKeypair(data.username, data.password);
522
+ data.account.pubkey = Base58.encode(keypair.publicKey);
523
+
524
+ // Default values
525
+ data.account.settings = data.account.settings || new UserSettings();
526
+ data.account.settings.merge(this.settings.settings, this._remoteLocalSettingsKeys, true);
527
+ data.account.department.id = data.account.department.id || this.environment.defaultDepartmentId;
528
+
529
+ this._cache.keypair = keypair;
530
+ const account = await this.saveRemotely(data.account, keypair);
531
+
532
+ // Default values
533
+ account.avatar = account.avatar || this.environment.baseUrl + DEFAULT_AVATAR_IMAGE;
534
+ this._cache.mainProfile = PersonUtils.getMainProfile(account.profiles);
535
+
536
+ this._data = account;
537
+ this._cache.pubkey = account.pubkey;
538
+
539
+ // Try to auth on pod
540
+ await this.authenticate(data);
541
+
542
+ this._cache.loaded = true;
543
+
544
+ await this.saveLocally();
545
+
546
+ console.debug(`[account] Account successfully registered in ${Date.now() - now}ms`);
547
+
548
+ // Emit events
549
+ this.onLogin.next(this._data);
550
+ this.onChange.next(this._data);
551
+
552
+ // Listen remote changes
553
+ if (this._enableListenChanges) this.startListenRemoteChanges();
554
+
555
+ return this._data;
556
+ } catch (error) {
557
+ console.error((error && error.message) || error);
558
+ this.resetData();
559
+ throw error;
560
+ }
561
+ }
562
+
563
+ async authenticate(data?: AuthData) {
564
+ // Wait the auth token, then continue
565
+ const tokenType = await firstNotNilPromise(this._tokenType$);
566
+
567
+ // Basic auth
568
+ if (tokenType === 'basic' || tokenType === 'basic-and-token') {
569
+ // Generate the authBasic, if used
570
+ if (!this._cache.authBasic) {
571
+ // Skip if token already provided
572
+ if (!(this._cache.authToken && tokenType === 'basic-and-token')) {
573
+ if (!data || !data.username || !data.password) throw new Error('Missing username and password');
574
+ this._cache.authBasic = CryptoService.encodeBase64(`${data.username}:${data.password}`);
575
+ }
576
+ }
577
+ this.onAuthBasicChange.next(this._cache.authBasic);
578
+ }
579
+
580
+ // Generate the authToken, if used
581
+ if (tokenType === 'token' || tokenType === 'basic-and-token') {
582
+ try {
583
+ this._cache.authToken = await this.authenticateAndGetToken(this._cache.authToken);
584
+ } catch (error) {
585
+ // Never authenticate, or not ready for offline mode => exit
586
+ console.error(error);
587
+ this.resetData();
588
+ throw error;
589
+ }
590
+ }
591
+
592
+ // Forget authBasic, to switch to authToken
593
+ if (tokenType === 'basic-and-token') {
594
+ this._cache.authBasic = undefined;
595
+ this.onAuthBasicChange.next(undefined);
596
+ }
597
+ }
598
+
599
+ async login(data: AuthData): Promise<Account> {
600
+ if (!data || !data.username || !data.password) throw new Error('Missing required username or password');
601
+
602
+ console.debug('[account] Login...');
603
+
604
+ let keypair;
605
+ try {
606
+ keypair = await CryptoService.scryptKeypair(data.username, data.password);
607
+ } catch (error) {
608
+ console.error(error);
609
+ this.resetData();
610
+ throw { code: ErrorCodes.UNKNOWN_ERROR, message: 'ERROR.SCRYPT_ERROR' };
611
+ }
612
+
613
+ // Store pubkey+keypair
614
+ this._cache.pubkey = Base58.encode(keypair.publicKey);
615
+ this._cache.keypair = keypair;
616
+
617
+ // Try to load previous token
618
+ let previousToken: string = await this.storage.get(TOKEN_STORAGE_KEY);
619
+ previousToken = (previousToken && previousToken.startsWith(this._cache.pubkey) && previousToken) || null;
620
+
621
+ // Offline mode
622
+ const offline = this.settings.hasOfflineFeature() && (this.network.offline || data.offline === true);
623
+ if (offline) {
624
+ this._cache.authToken = previousToken;
625
+
626
+ // Make sure network if set as offline
627
+ this.network.setForceOffline(true, { showToast: false });
628
+ console.info(`[account] Login [OK] {pubkey: ${this._cache.pubkey.substr(0, 8)}}, {offline: true}`);
629
+ }
630
+
631
+ // Online mode: try to auth on pod
632
+ else {
633
+ try {
634
+ await this.authenticate(data);
635
+ } catch (error) {
636
+ // Never authenticate, or not ready for offline mode => exit
637
+ console.error(error);
638
+ this.resetData();
639
+ throw error;
640
+ }
641
+ }
642
+
643
+ // Load account data
644
+ try {
645
+ await this.loadData({ offline, fetchPolicy: 'network-only' });
646
+ } catch (err) {
647
+ // If account not found, check if email is valid
648
+ if (err && +err.code === ErrorCodes.LOAD_ACCOUNT_ERROR) {
649
+ // Check email exists
650
+ if (data.username.indexOf('@') !== -1) {
651
+ let isEmailExists;
652
+ try {
653
+ isEmailExists = await this.isEmailExists(data.username);
654
+ } catch (otherError) {
655
+ throw err; // resend the first error
656
+ }
657
+
658
+ // Email not exists (no account)
659
+ if (!isEmailExists) {
660
+ throw { code: ErrorCodes.UNKNOWN_ACCOUNT_EMAIL, message: 'ERROR.UNKNOWN_ACCOUNT_EMAIL' };
661
+ }
662
+ }
663
+
664
+ // Email exists, so error = 'bad password'
665
+ throw { code: ErrorCodes.BAD_PASSWORD, message: 'ERROR.BAD_PASSWORD' };
666
+ }
667
+
668
+ throw err; // resend the first error
669
+ }
670
+
671
+ try {
672
+ // Store to local storage
673
+ await this.saveLocally();
674
+ } catch (error) {
675
+ console.error(error);
676
+ this.resetData();
677
+ throw error;
678
+ }
679
+
680
+ // Emit event to observers
681
+ this.onLogin.next(this._data);
682
+ this.onChange.next(this._data);
683
+
684
+ if (this._enableListenChanges) this.startListenRemoteChanges();
685
+
686
+ return this._data;
687
+ }
688
+
689
+ async reload(opts?: { showToast?: boolean }): Promise<Account> {
690
+ if (!this._cache.pubkey) throw new Error('User not logged');
691
+ if (this.network.offline) throw new Error('Cannot check account in offline mode');
692
+
693
+ const now = Date.now();
694
+ console.debug(`[account] Reloading account...`);
695
+ const wasLogin = this.isLogin();
696
+
697
+ try {
698
+ await this.loadData();
699
+ await this.saveLocally();
700
+
701
+ console.debug(`[account] Reloading account [OK] in ${Date.now() - now}ms`);
702
+
703
+ // Emit login event to subscribers
704
+ this.onLogin.next(this._data);
705
+ this.onChange.next(this._data);
706
+
707
+ // Display toast (without await, because not need to wait toast close event)
708
+ if (!opts || opts.showToast !== false) {
709
+ this.showToast({ message: 'ACCOUNT.INFO.RELOADED', type: 'info' });
710
+ }
711
+
712
+ return this._data;
713
+ } catch (error) {
714
+ // Cannot reload but was login: force to logout
715
+ if (wasLogin && !this.isLogin()) {
716
+ console.error(`[account] Reloading account failed. Will force logout...`, error);
717
+ await this.logout();
718
+ } else {
719
+ throw error;
720
+ }
721
+ }
722
+ }
723
+
724
+ /**
725
+ * Create or update an user account, to the remote storage
726
+ *
727
+ * @param account
728
+ */
729
+ async save(account: Account): Promise<Account> {
730
+ if (!this._cache.pubkey) return Promise.reject('User not logged');
731
+ if (this._cache.pubkey !== account.pubkey) return Promise.reject('Not user account');
732
+
733
+ account = await this.saveRemotely(account, this._cache.keypair);
734
+
735
+ // Set defaults
736
+ account.avatar = account.avatar || this.environment.baseUrl + DEFAULT_AVATAR_IMAGE;
737
+ this._cache.mainProfile = PersonUtils.getMainProfile(account.profiles);
738
+
739
+ this._data = account;
740
+
741
+ // Update cache
742
+ this._cache.person = account.asPerson();
743
+ this._cache.department = this._cache.person.department;
744
+
745
+ this._cache.loaded = true;
746
+
747
+ // Save locally (in storage)
748
+ await this.saveLocally();
749
+
750
+ // Send event
751
+ this.onLogin.next(this._data);
752
+ this.onChange.next(this._data);
753
+
754
+ return this._data;
755
+ }
756
+
757
+ async logout(): Promise<void> {
758
+ const hadAuthToken = this._cache.authToken && true;
759
+ const hadAuthBasic = this._cache.authBasic && true;
760
+ const pubkey = this._cache && this._cache.pubkey;
761
+
762
+ // Notify observers
763
+ this.onWillLogout.next(this.account);
764
+
765
+ this.resetData();
766
+
767
+ if (!this.settings.hasOfflineFeature()) {
768
+ // Remove all data from the local storage
769
+ await Promise.all([
770
+ this.storage.remove(PUBKEY_STORAGE_KEY),
771
+ this.storage.remove(TOKEN_STORAGE_KEY),
772
+ this.storage.remove(ACCOUNT_STORAGE_KEY),
773
+ (pubkey && this.storage.remove(ACCOUNT_STORAGE_KEY + '#' + pubkey)) || Promise.resolve(),
774
+ this.storage.remove(SECKEY_STORAGE_KEY),
775
+ ]);
776
+ }
777
+
778
+ // Offline features enable: need to keep some data
779
+ else {
780
+ // Always remove only secret key
781
+ // But keep:
782
+ // - account by pubkey
783
+ // - auth token
784
+ await Promise.all([this.storage.remove(PUBKEY_STORAGE_KEY), this.storage.remove(ACCOUNT_STORAGE_KEY), this.storage.remove(SECKEY_STORAGE_KEY)]);
785
+ }
786
+
787
+ // Clean page history, in local settings
788
+ await this.settings.clearPageHistory();
789
+
790
+ // Notify observers
791
+ this.onLogout.next();
792
+ if (hadAuthToken) this.onAuthTokenChange.next(undefined);
793
+ if (hadAuthBasic) this.onAuthBasicChange.next(undefined);
794
+ this.onChange.next(undefined);
795
+ }
796
+
797
+ /**
798
+ * Load a account
799
+ *
800
+ * @param opts
801
+ */
802
+ async load(opts?: { offline?: boolean; fetchPolicy?: FetchPolicy; query?: any }): Promise<Account | undefined> {
803
+ const now = this._debug && Date.now();
804
+ if (this._debug) console.debug(`[account] Loading account...`);
805
+ let json: any;
806
+
807
+ // Load locally
808
+ const offline =
809
+ (this.network.offline && (!opts || (opts.fetchPolicy !== 'network-only' && opts.fetchPolicy !== 'no-cache'))) ||
810
+ (opts && opts.offline === true);
811
+ if (offline) {
812
+ json = await this.storage.get(ACCOUNT_STORAGE_KEY);
813
+ json = (json && typeof json === 'string' && JSON.parse(json)) || json;
814
+ json = (json && this._cache.pubkey && json.pubkey === this._cache.pubkey && json) || null;
815
+ if (!json && this._cache.pubkey) {
816
+ json = await this.storage.get(ACCOUNT_STORAGE_KEY + '#' + this._cache.pubkey);
817
+ json = (json && typeof json === 'string' && JSON.parse(json)) || json;
818
+ }
819
+ }
820
+
821
+ // Load remotely
822
+ else {
823
+ const query = opts?.query || (this.apiTokenEnabled ? Queries.loadWithTokens : Queries.load);
824
+ const { data } = await this.graphql.query<{ data: any }>({
825
+ query,
826
+ error: { code: ErrorCodes.LOAD_ACCOUNT_ERROR, message: 'ERROR.LOAD_ACCOUNT_ERROR' },
827
+ fetchPolicy: (opts && opts.fetchPolicy) || 'no-cache' || undefined,
828
+ });
829
+ json = data;
830
+ }
831
+
832
+ if (json) {
833
+ const account = Account.fromObject(json);
834
+ if (this._debug) console.debug(`[account] Account loaded in ${Date.now() - now}ms`, account);
835
+ return account;
836
+ } else {
837
+ console.warn(`[account] Account not found !`);
838
+ return undefined;
839
+ }
840
+ }
841
+
842
+ async generateToken(flags: number): Promise<string | undefined> {
843
+ const now = this._debug && Date.now();
844
+ if (this._debug) console.debug(`[account] Generate token...`);
845
+
846
+ const authChallenge = await this.getAuthChallenge();
847
+ // Add Flags to challenge
848
+ const challenge = `${authChallenge.challenge}:${flags}`;
849
+ const signature = await CryptoService.sign(challenge, this._cache.keypair);
850
+ const newToken = `${this._cache.pubkey}:${challenge}|${signature}`;
851
+
852
+ if (newToken) {
853
+ if (this._debug) console.debug(`[account] Token generated in ${Date.now() - now}ms`);
854
+ } else {
855
+ console.warn(`[account] Token generation failed !`);
856
+ }
857
+
858
+ return newToken;
859
+ }
860
+
861
+ /**
862
+ * Check if email is available for new account registration.
863
+ * Throw an error if not available
864
+ *
865
+ * @param email
866
+ */
867
+ async checkEmailAvailable(email: string): Promise<void> {
868
+ const isEmailExists = await this.isEmailExists(email);
869
+ if (isEmailExists) {
870
+ throw { code: ErrorCodes.EMAIL_ALREADY_REGISTERED, message: 'ERROR.EMAIL_ALREADY_REGISTERED' };
871
+ }
872
+ }
873
+
874
+ /**
875
+ * Check if email is exists in server.
876
+ *
877
+ * @param email
878
+ */
879
+ async isEmailExists(email: string): Promise<boolean> {
880
+ if (this._debug) console.debug('[account] Checking if {' + email + '} exists...');
881
+
882
+ const data = await this.graphql.query<{ isEmailExists: boolean }, IsEmailExistsVariables>({
883
+ query: IsEmailExistsQuery,
884
+ variables: {
885
+ email,
886
+ hash: undefined,
887
+ },
888
+ });
889
+
890
+ if (this._debug) console.debug('[account] Email exist: ' + (data && data.isEmailExists));
891
+
892
+ return data && data.isEmailExists;
893
+ }
894
+
895
+ async sendConfirmationEmail(email: string, locale?: string): Promise<boolean> {
896
+ locale = locale || this.settings.locale;
897
+ console.debug('[account] Sending confirmation email to {' + email + '} with locale {' + locale + '}...');
898
+
899
+ const { data } = await this.graphql.query<{ data: boolean }>({
900
+ query: SendConfirmEmailQuery,
901
+ variables: {
902
+ email,
903
+ locale,
904
+ },
905
+ error: {
906
+ code: ErrorCodes.SENT_CONFIRMATION_EMAIL_FAILED,
907
+ message: 'ERROR.SENT_ACCOUNT_CONFIRMATION_EMAIL_FAILED',
908
+ },
909
+ });
910
+
911
+ return data;
912
+ }
913
+
914
+ async confirmEmail(email: string, code: string): Promise<boolean> {
915
+ console.debug('[account] Sending confirm request for email {' + email + '} with code {' + code + '}...');
916
+
917
+ const { data } = await this.graphql.query<{ data: boolean }>({
918
+ query: ConfirmEmailQuery,
919
+ variables: {
920
+ email,
921
+ code,
922
+ },
923
+ error: {
924
+ code: ErrorCodes.CONFIRM_EMAIL_FAILED,
925
+ message: 'ERROR.CONFIRM_ACCOUNT_EMAIL_FAILED',
926
+ },
927
+ });
928
+ return data;
929
+ }
930
+
931
+ async sendResetPasswordEmail(username: string, locale?: string): Promise<boolean> {
932
+ locale = locale || this.settings.locale;
933
+
934
+ console.debug(`[account] Sending change password email to {${username}} with locale {${locale}}...`);
935
+
936
+ const { data: isOk } = await this.graphql.query<{ data: boolean }>({
937
+ query: SendResetPasswordEmailQuery,
938
+ variables: {
939
+ username,
940
+ locale,
941
+ },
942
+ error: {
943
+ code: ErrorCodes.AUTH_SEND_RESET_PASSWORD_EMAIL_ERROR,
944
+ message: 'ACCOUNT.ERROR.SEND_RESET_PASSWORD_EMAIL_ERROR',
945
+ },
946
+ fetchPolicy: 'no-cache',
947
+ });
948
+ return isOk;
949
+ }
950
+
951
+ async updatePubkey(data: AuthData): Promise<boolean> {
952
+ if (!data.username || !data.password) throw new Error('Missing required username or password');
953
+ if (!this.isLogin()) throw new Error('Should be login');
954
+
955
+ const keypair = await CryptoService.scryptKeypair(data.username, data.password);
956
+ const pubkey = Base58.encode(keypair.publicKey);
957
+
958
+ console.debug(`[account] Updating account pubkey to ${pubkey} ...`);
959
+
960
+ const { data: res } = await this.graphql.query<{ data: boolean }>({
961
+ query: UpdatePubKeyQuery,
962
+ variables: { pubkey },
963
+ error: {
964
+ code: ErrorCodes.AUTH_UPDATE_PUBKEY_ERROR,
965
+ message: 'ACCOUNT.ERROR.UPDATE_PUBKEY_ERROR',
966
+ },
967
+ fetchPolicy: 'no-cache',
968
+ });
969
+
970
+ console.debug(`[account] Updating account pubkey response`, res);
971
+
972
+ if (res) {
973
+ await this.logout();
974
+ await this.login(data);
975
+ }
976
+
977
+ return res;
978
+ }
979
+
980
+ async resetPubkey(data: AuthData, token: string): Promise<boolean> {
981
+ if (this.isLogin()) {
982
+ await this.logout();
983
+ }
984
+
985
+ // Parse challenge
986
+ const challenge = token.split('|', 2)[0].split(':', 2)[1];
987
+ const keypair = await CryptoService.scryptKeypair(data.username, data.password);
988
+ const pubkey = Base58.encode(keypair.publicKey);
989
+ const signature = await CryptoService.sign(challenge, keypair);
990
+ const newToken = `${pubkey}:${challenge}|${signature}`;
991
+
992
+ console.debug(`[account] Resetting account pubkey, using token: `, newToken);
993
+
994
+ const { data: res } = await this.graphql.query<{ data: boolean }>({
995
+ query: ResetAccountPubkeyQuery,
996
+ variables: { token: newToken, username: data.username },
997
+ error: {
998
+ code: ErrorCodes.AUTH_RESET_PUBKEY_ERROR,
999
+ message: 'ACCOUNT.ERROR.RESET_PUBKEY_ERROR',
1000
+ },
1001
+ fetchPolicy: 'no-cache',
1002
+ });
1003
+
1004
+ // Login
1005
+ if (res) {
1006
+ await this.login(data);
1007
+ }
1008
+
1009
+ return res;
1010
+ }
1011
+
1012
+ listenChanges(opts?: AccountWatchOptions): Subscription {
1013
+ if (this._enableListenChanges) return new Subscription(); // Already started: skip
1014
+
1015
+ return this.startListenRemoteChanges(opts);
1016
+ }
1017
+
1018
+ get additionalFields(): FormFieldDefinition[] {
1019
+ return this._$additionalFields.getValue();
1020
+ }
1021
+
1022
+ get $additionalFields(): Observable<FormFieldDefinition[]> {
1023
+ return this._$additionalFields.asObservable();
1024
+ }
1025
+
1026
+ getAdditionalField(key: string): FormFieldDefinition | undefined {
1027
+ return this._$additionalFields.getValue().find((f) => f.key === key);
1028
+ }
1029
+
1030
+ registerAdditionalField(field: FormFieldDefinition) {
1031
+ const values = this._$additionalFields.getValue();
1032
+ if (values.some((f) => f.key === field.key)) {
1033
+ throw new Error(`Additional account field {key: ${field.key}} already define.`);
1034
+ }
1035
+ if (this._debug) console.debug(`[account] Found additional account's field {key: ${field.key}}`);
1036
+ this._$additionalFields.next(values.concat(field));
1037
+ }
1038
+
1039
+ get optionDefs(): FormFieldDefinition[] {
1040
+ return this._optionDefs;
1041
+ }
1042
+
1043
+ registerOption(def: FormFieldDefinition) {
1044
+ if (this._optionDefs.findIndex((f) => f.key === def.key) !== -1) {
1045
+ throw new Error(`Additional option {${def.key}} already define.`);
1046
+ }
1047
+ if (this._debug) console.debug(`[account] Adding additional option {${def.key}}`, def);
1048
+ this._optionDefs.push(def);
1049
+ }
1050
+
1051
+ registerOptions(defs: FormFieldDefinition[]) {
1052
+ (defs || []).forEach((def) => this.registerOption(def));
1053
+ }
1054
+
1055
+ /* -- protected method -- */
1056
+
1057
+ protected resetData() {
1058
+ this.stopListenRemoteChanges();
1059
+ this._cache.loaded = false;
1060
+ this._cache.keypair = null;
1061
+ this._cache.authToken = null;
1062
+ this._cache.authBasic = null;
1063
+ this._cache.pubkey = null;
1064
+ this._cache.mainProfile = null;
1065
+ this._cache.person = null;
1066
+ this._cache.department = null;
1067
+ this._data = new Account();
1068
+ }
1069
+
1070
+ protected async loadData(opts?: { offline?: boolean; fetchPolicy?: FetchPolicy }): Promise<Account> {
1071
+ if (!this._cache.pubkey) throw new Error('User not logged');
1072
+
1073
+ this._cache.loaded = false;
1074
+
1075
+ console.debug('[account-service] Loading account data...');
1076
+ try {
1077
+ const account = (await this.load(opts)) || new Account();
1078
+
1079
+ // Set defaults
1080
+ account.avatar = account.avatar || this.environment.baseUrl + DEFAULT_AVATAR_IMAGE;
1081
+ account.settings = account.settings || new UserSettings();
1082
+ account.settings.locale = account.settings.locale || this.settings.locale;
1083
+ account.settings.latLongFormat = account.settings.latLongFormat || this.settings.latLongFormat || 'DDMM';
1084
+ account.settings.content = account.settings.content || {};
1085
+
1086
+ // Read main profile
1087
+ this._cache.mainProfile = PersonUtils.getMainProfile(account.profiles);
1088
+
1089
+ // Update, instead of replace it
1090
+ if (this._data) {
1091
+ this._data.fromObject(account);
1092
+ } else {
1093
+ this._data = account;
1094
+ }
1095
+ this._cache.loaded = true;
1096
+
1097
+ // Apply settings, found in remote account
1098
+ if (account.settings && this.settings.settings.accountInheritance) {
1099
+ console.debug('[account-service] Copying account settings into local settings...');
1100
+ const localSettings = this.settings.settings;
1101
+ const accountSettings = account.settings.asLocalSettings();
1102
+ const definitions = removeDuplicatesFromArray([...this.optionDefs, ...this.settings.optionDefs], 'key');
1103
+ const mergedProperties = AppPropertiesUtils.sanitize(
1104
+ {
1105
+ ...localSettings.properties,
1106
+ ...accountSettings.properties,
1107
+ },
1108
+ { definitions }
1109
+ );
1110
+
1111
+ // Merge local/account settings
1112
+ const settings = {
1113
+ ...localSettings,
1114
+ ...accountSettings,
1115
+ properties: mergedProperties,
1116
+ };
1117
+
1118
+ await this.settings.apply(settings);
1119
+ }
1120
+
1121
+ return this._data;
1122
+ } catch (error) {
1123
+ this.resetData();
1124
+ if (error.code && error.message) throw error;
1125
+
1126
+ console.error(error);
1127
+ throw {
1128
+ code: ErrorCodes.LOAD_ACCOUNT_ERROR,
1129
+ message: 'ERROR.LOAD_ACCOUNT_ERROR',
1130
+ };
1131
+ }
1132
+ }
1133
+
1134
+ protected async listenSettings(): Promise<void> {
1135
+ // When settings changed: save it remotely
1136
+ this.registerSubscription(
1137
+ this.settings.onChange
1138
+ .pipe(
1139
+ debounceTime(1000),
1140
+ filter(() => this.isLogin() && this.network.online)
1141
+ )
1142
+ .subscribe((settings) => this.saveLocalSettingsRemotely(settings))
1143
+ );
1144
+ }
1145
+
1146
+ protected async restoreLocally(): Promise<Account | undefined> {
1147
+ // Restore from storage
1148
+ const values = await Promise.all([
1149
+ this.storage.get(PUBKEY_STORAGE_KEY),
1150
+ this.storage.get(TOKEN_STORAGE_KEY),
1151
+ this.storage.get(SECKEY_STORAGE_KEY),
1152
+ ]);
1153
+ let pubkey = values[0];
1154
+ let token = values[1];
1155
+ const seckey = values[2];
1156
+
1157
+ // DEV only - auth by token
1158
+ if (!this.environment.production && this.environment.defaultAuthValues?.token) {
1159
+ token = token || this.environment.defaultAuthValues.token;
1160
+ pubkey = pubkey || token?.split(':', 2)[0];
1161
+ }
1162
+
1163
+ // Quit if no pubkey (not logged)
1164
+ if (!pubkey) return;
1165
+
1166
+ // Quit if could not auth on pod
1167
+ const canRemoteAuth = token || seckey || false;
1168
+ if (!canRemoteAuth) return;
1169
+
1170
+ if (this._debug) console.debug(`[account] Account restoration...`);
1171
+
1172
+ this._cache.authToken = token;
1173
+ this._cache.pubkey = pubkey;
1174
+ this._cache.keypair =
1175
+ (seckey && {
1176
+ publicKey: Base58.decode(pubkey),
1177
+ secretKey: Base58.decode(seckey),
1178
+ }) ||
1179
+ null;
1180
+
1181
+ // Online mode: try to connect to pod
1182
+ if (this.network.online) {
1183
+ try {
1184
+ await this.authenticate();
1185
+ if (!this._cache.authToken && !this._cache.authBasic) throw new Error('Authentication failed');
1186
+ } catch (error) {
1187
+ // Offline feature are enable: continue in offline mode
1188
+ if (this.settings.hasOfflineFeature()) {
1189
+ console.warn('[account] Unable to authenticate on pod: forcing offline mode');
1190
+ this.network.setForceOffline(true, { showToast: false });
1191
+ // Continue
1192
+ }
1193
+ // No offline features enable (=offline mode not allowed)
1194
+ else {
1195
+ console.error(error);
1196
+ this.logout();
1197
+ return;
1198
+ }
1199
+ }
1200
+ }
1201
+
1202
+ // Get the account, from pubkey
1203
+ let jsonAccount = await this.storage.get(`${ACCOUNT_STORAGE_KEY}#${pubkey}`);
1204
+ if (!jsonAccount) {
1205
+ // Try using the old storage key
1206
+ const accountStr = await this.storage.get(ACCOUNT_STORAGE_KEY);
1207
+ jsonAccount = accountStr && ((typeof accountStr === 'string' && JSON.parse(jsonAccount)) || accountStr);
1208
+ }
1209
+
1210
+ // Invalid account: do not use it
1211
+ if (!jsonAccount || jsonAccount.pubkey !== pubkey) {
1212
+ // DEV only: create a fake account with given username
1213
+ if (!this.environment.production && this.environment.defaultAuthValues.username) {
1214
+ const username = this.environment.defaultAuthValues.username;
1215
+ jsonAccount = { pubkey, username, firstName: username, lastName: username };
1216
+ } else {
1217
+ return;
1218
+ }
1219
+ }
1220
+
1221
+ // Transform to entity
1222
+ const account = Account.fromObject(jsonAccount);
1223
+
1224
+ // Update data
1225
+ this._data = account;
1226
+ this._cache.mainProfile = PersonUtils.getMainProfile(account.profiles);
1227
+ this._cache.loaded = true;
1228
+
1229
+ // Emit event
1230
+ this.onLogin.next(this._data);
1231
+ this.onChange.next(this._data);
1232
+
1233
+ if (this._enableListenChanges) this.startListenRemoteChanges();
1234
+
1235
+ if (this._debug) console.debug(`[account] Account restoration [OK] {pubkey: ${pubkey.substr(0, 8)}}, {profile: ${this._cache.mainProfile}}`);
1236
+
1237
+ return account;
1238
+ }
1239
+
1240
+ /**
1241
+ * Save account into the local storage
1242
+ */
1243
+ protected async saveLocally(): Promise<void> {
1244
+ if (!this._cache.pubkey) throw new Error('User not logged');
1245
+
1246
+ if (this._debug) console.debug(`[account] Saving account {${this._cache.pubkey.substring(0, 6)}} in local storage...`);
1247
+
1248
+ // Convert account to json
1249
+ const json = this._data.asObject({ keepTypename: true });
1250
+ const seckey = (this._cache.keypair && this._cache.keypair.secretKey && Base58.encode(this._cache.keypair.secretKey)) || null;
1251
+
1252
+ // Convert avatar URL to dataUrl (e.g. 'data:image/png:<base64 content>')
1253
+ const hasAvatarUrl =
1254
+ json.avatar && !json.avatar.endsWith(DEFAULT_AVATAR_IMAGE) && (json.avatar.startsWith('http://') || json.avatar.startsWith('https://'));
1255
+ if (hasAvatarUrl && this.network.online) {
1256
+ await this.file
1257
+ .getImage(json.avatar, {
1258
+ thumbnail: true,
1259
+ outputType: 'dataUrl',
1260
+ })
1261
+ .then((dataUrl) => {
1262
+ if (dataUrl && this._debug) console.debug('[account] Image fetched: ', dataUrl.substring(0, 50));
1263
+
1264
+ // TODO: make sure to display Base64 image in the menu top header
1265
+ //jsonAccount.avatar = dataUrl;
1266
+ })
1267
+ .catch((err) => {
1268
+ console.error(`[account] Error while fetching image: ${json.avatar}: ${err}`);
1269
+ });
1270
+ }
1271
+
1272
+ try {
1273
+ await Promise.all([
1274
+ this.storage.set(PUBKEY_STORAGE_KEY, this._cache.pubkey),
1275
+ this.storage.set(TOKEN_STORAGE_KEY, this._cache.authToken),
1276
+ this.storage.set(`${ACCOUNT_STORAGE_KEY}#${this._cache.pubkey}`, json),
1277
+ // Secret key (optional)
1278
+ (seckey && this.storage.set(SECKEY_STORAGE_KEY, seckey)) || this.storage.remove(SECKEY_STORAGE_KEY),
1279
+ // Remove old storage key
1280
+ this.storage.remove(ACCOUNT_STORAGE_KEY),
1281
+ ]);
1282
+
1283
+ if (this._debug) console.debug('[account] Account saved in local storage');
1284
+ } catch (err) {
1285
+ console.error('[account] Error while saving account locally: ' + ((err && err.message) || err), err);
1286
+ }
1287
+ }
1288
+
1289
+ async saveLocalSettingsRemotely(source: LocalSettings) {
1290
+ if (!source || !this.isLogin() || source.accountInheritance === false) return; // Skip
1291
+ const account = this.account;
1292
+
1293
+ // Merge local settings into account's settings
1294
+ const settings = UserSettings.fromObject(account.settings) || new UserSettings();
1295
+ const changed = settings.merge(source, this._remoteLocalSettingsKeys);
1296
+
1297
+ if (!changed) return; // Skip if unchanged
1298
+
1299
+ // Save remotely
1300
+ this.account.settings = settings;
1301
+ await this.saveSettingsRemotely(settings);
1302
+ }
1303
+
1304
+ /**
1305
+ * Create or update an user account
1306
+ *
1307
+ * @param account
1308
+ * @param keyPair
1309
+ */
1310
+ protected async saveRemotely(account: Account, keyPair?: Keypair): Promise<Account> {
1311
+ account.pubkey = account.pubkey || (keyPair && Base58.encode(keyPair.publicKey));
1312
+ if (!account.pubkey) throw new Error('Missing account pubkey');
1313
+
1314
+ const now = this._debug && Date.now();
1315
+ if (this._debug) console.debug(`[account] Saving account remotely...`);
1316
+
1317
+ const isNew = isNil(account.id);
1318
+
1319
+ // If this is an update: get existing account's updateDate, to avoid 'version error' when saving
1320
+ if (!isNew) {
1321
+ const existingAccount = await this.load({ fetchPolicy: 'network-only' });
1322
+ if (!existingAccount || !existingAccount.updateDate) {
1323
+ throw { code: ErrorCodes.ACCOUNT_NOT_EXISTS, message: 'ERROR.ACCOUNT_NOT_EXISTS' };
1324
+ }
1325
+ this.copyIdAndUpdateDate(existingAccount, account);
1326
+ }
1327
+
1328
+ // Merging settings - FIXME - Ludo - A revoir avec la MR sur le user settings
1329
+ //account.settings.content['pages'] = this.settings.settings.pages;
1330
+ //account.settings.content['pageHistory'] = this.settings.settings.pageHistory;
1331
+
1332
+ // Convert to json
1333
+ const json = account.asObject(MINIFY_ENTITY_FOR_POD);
1334
+
1335
+ // User not allow to change his profiles
1336
+ delete json.profiles;
1337
+
1338
+ const mutation = isNew ? Mutations.create : this._apiTokenEnabled ? Mutations.saveWithTokens : Mutations.save;
1339
+
1340
+ // Execute mutation
1341
+ const { data } = await this.graphql.mutate<{ data: Account }>({
1342
+ mutation,
1343
+ variables: { data: json },
1344
+ error: {
1345
+ code: ErrorCodes.SAVE_ACCOUNT_ERROR,
1346
+ message: 'ERROR.SAVE_ACCOUNT_ERROR',
1347
+ },
1348
+ });
1349
+
1350
+ // Copy update properties
1351
+ this.copyIdAndUpdateDate(data, account);
1352
+
1353
+ if (this._debug) console.debug(`[account] Account remotely saved in ${Date.now() - now}ms`);
1354
+
1355
+ return account;
1356
+ }
1357
+
1358
+ /**
1359
+ * Create or update user settings
1360
+ *
1361
+ * @param settings
1362
+ */
1363
+ protected async saveSettingsRemotely(settings: UserSettings) {
1364
+ const now = this._debug && Date.now();
1365
+ if (this._debug) console.debug(`[account] Saving settings remotely...`);
1366
+
1367
+ const json = settings.asObject(MINIFY_ENTITY_FOR_POD);
1368
+
1369
+ // Execute mutation
1370
+ const { data } = await this.graphql.mutate<{ data: UserSettings }>({
1371
+ mutation: Mutations.saveSettings,
1372
+ variables: { data: json },
1373
+ error: {
1374
+ code: ErrorCodes.SAVE_SETTINGS_ERROR,
1375
+ message: 'ERROR.SAVE_SETTINGS_ERROR',
1376
+ },
1377
+ });
1378
+
1379
+ // Copy update properties
1380
+ this.copyIdAndUpdateDateSettings(data, settings);
1381
+
1382
+ if (this._debug) console.debug(`[account] Settings remotely saved in ${Date.now() - now}ms`);
1383
+
1384
+ // Save into account
1385
+ if (this.account) this.account.settings = settings;
1386
+ }
1387
+
1388
+ protected async authenticateAndGetToken(token?: string, counter?: number): Promise<string> {
1389
+ if (!this._cache.pubkey) throw new Error('User not logged');
1390
+
1391
+ if (!counter) console.info('[account] Authentication on pod...');
1392
+
1393
+ if (counter > 4) {
1394
+ if (this._debug) console.debug(`[account] Failed to authentication on pod (after ${counter} attempts)`);
1395
+ throw { code: ErrorCodes.AUTH_SERVER_ERROR, message: 'ERROR.AUTH_SERVER_ERROR' };
1396
+ }
1397
+
1398
+ // Check if valid
1399
+ if (token) {
1400
+ const data = await this.graphql.query<{ authenticate: boolean }, { token: string }>({
1401
+ query: AuthQuery,
1402
+ variables: {
1403
+ token,
1404
+ },
1405
+ error: {
1406
+ code: ErrorCodes.UNAUTHORIZED,
1407
+ message: 'ERROR.UNAUTHORIZED',
1408
+ },
1409
+ fetchPolicy: 'no-cache',
1410
+ });
1411
+
1412
+ // Token is accepted by the server
1413
+ if (data && data.authenticate) {
1414
+ // Store the token
1415
+ this.onAuthTokenChange.next(token);
1416
+
1417
+ console.info(`[account] Authentication on pod [OK] {pubkey: '${this._cache.pubkey.substr(0, 8)}'}`);
1418
+ return token; // return the token
1419
+ }
1420
+
1421
+ // Continue (will retry with another challenge)
1422
+ }
1423
+
1424
+ // Generate a new token
1425
+ const authChallenge = await this.getAuthChallenge();
1426
+ // TODO: check server pubkey as a valid certificate
1427
+
1428
+ // Do the challenge
1429
+ const signature = await CryptoService.sign(authChallenge.challenge, this._cache.keypair);
1430
+ const newToken = `${this._cache.pubkey}:${authChallenge.challenge}|${signature}`;
1431
+
1432
+ // iterate with the new token
1433
+ return await this.authenticateAndGetToken(newToken, (counter || 1) + 1 /* increment */);
1434
+ }
1435
+
1436
+ protected async getAuthChallenge(): Promise<IAuthChallenge> {
1437
+ const challengeError = {
1438
+ code: ErrorCodes.AUTH_CHALLENGE_ERROR,
1439
+ message: 'ERROR.AUTH_CHALLENGE_ERROR',
1440
+ };
1441
+ const { authChallenge } = await this.graphql.query<{
1442
+ authChallenge: IAuthChallenge;
1443
+ }>({
1444
+ query: AuthChallengeQuery,
1445
+ variables: {},
1446
+ error: challengeError,
1447
+ fetchPolicy: 'network-only',
1448
+ });
1449
+
1450
+ // Check challenge
1451
+ if (!authChallenge) throw challengeError; // Should never occur
1452
+
1453
+ // Check server signature
1454
+ const signatureOK = await CryptoService.verify(authChallenge.challenge, authChallenge.signature, authChallenge.pubkey);
1455
+ if (!signatureOK) {
1456
+ console.warn('FIXME: Bad peer signature on auth challenge !', authChallenge);
1457
+ }
1458
+ return authChallenge;
1459
+ }
1460
+
1461
+ protected startListenRemoteChanges(opts?: AccountWatchOptions): Subscription {
1462
+ if (this._listenChangesSubscription) this.stopListenRemoteChanges(); // Stop previous subscription
1463
+ if (this.network.offline) return new Subscription(); // Offline: skip
1464
+
1465
+ this._listenChangesSubscription = this.watchChanges(opts).subscribe({
1466
+ next: (data) => {
1467
+ console.debug(`[account] Remote update detected at ${data.updateDate}`);
1468
+ this.reload();
1469
+ },
1470
+ error: (err) => {
1471
+ if (err && +err.code === ServerErrorCodes.NOT_FOUND) {
1472
+ console.info('[account] [WS] Account not exists anymore: force user to logout...', err);
1473
+ this.logout();
1474
+ } else if (err && +err.code === ServerErrorCodes.UNAUTHORIZED) {
1475
+ console.info('[account] [WS] Account not authorized: force user to logout...', err);
1476
+ this.logout();
1477
+ } else {
1478
+ console.warn('[account] [WS] Received error:', err);
1479
+ }
1480
+ },
1481
+ });
1482
+ this._listenChangesSubscription.add(() => {
1483
+ console.debug(`[account] Stop watching remote changes`);
1484
+ this._listenChangesSubscription = null;
1485
+ });
1486
+ return this._listenChangesSubscription;
1487
+ }
1488
+
1489
+ protected stopListenRemoteChanges() {
1490
+ this._listenChangesSubscription?.unsubscribe();
1491
+ }
1492
+
1493
+ protected watchChanges(opts?: AccountWatchOptions): Observable<Account> {
1494
+ if (!this.started) {
1495
+ // Wait service ready, then loop
1496
+ return from(this.ready()).pipe(switchMap(() => this.watchChanges(opts)));
1497
+ }
1498
+
1499
+ if (!this._cache.pubkey) throw new Error('Not logged in');
1500
+ if (this.network.offline) throw new Error('Cannot watch account changes: network is offline.');
1501
+
1502
+ const variables = {
1503
+ interval: toNumber(opts && opts.intervalInSeconds, this._listenIntervalInSeconds),
1504
+ };
1505
+
1506
+ console.debug(`[account] Watching remote changes, every ${variables.interval}s`);
1507
+
1508
+ return this.graphql
1509
+ .subscribe<{ data: any }>({
1510
+ query: AccountSubscriptions.listenChanges,
1511
+ variables,
1512
+ error: {
1513
+ code: ErrorCodes.SUBSCRIBE_ACCOUNT_ERROR,
1514
+ message: 'ACCOUNT.ERROR.SUBSCRIBE_ERROR',
1515
+ },
1516
+ })
1517
+ .pipe(
1518
+ map(({ data }) => data),
1519
+ // Keep only if newer
1520
+ filter((data) => {
1521
+ const currentUpdateDate: Moment = fromDateISOString(this._data?.updateDate);
1522
+ const remoteUpdateDate: Moment = fromDateISOString(data?.updateDate);
1523
+ return remoteUpdateDate && (!currentUpdateDate || !remoteUpdateDate.isSame(currentUpdateDate, 'millisecond'));
1524
+ })
1525
+ );
1526
+ }
1527
+
1528
+ protected copyIdAndUpdateDate(source: Account | undefined, target: Account) {
1529
+ if (!source) return;
1530
+
1531
+ target.id = source.id || target.id;
1532
+ target.updateDate = source.updateDate || target.updateDate;
1533
+
1534
+ // Update settings
1535
+ this.copyIdAndUpdateDateSettings(source.settings, target.settings);
1536
+
1537
+ // Update tokens
1538
+ if (this._apiTokenEnabled) {
1539
+ this.copyIdAndUpdateDateToken(source.tokens, target.tokens);
1540
+ }
1541
+ }
1542
+
1543
+ protected copyIdAndUpdateDateSettings(source: UserSettings | undefined, target: UserSettings) {
1544
+ if (!source) return;
1545
+
1546
+ target.id = source.id || target.id;
1547
+ target.updateDate = source.updateDate || target.updateDate;
1548
+ }
1549
+
1550
+ protected copyIdAndUpdateDateToken(sources: UserToken[] | undefined, targets: UserToken[]) {
1551
+ if (isEmptyArray(sources)) return;
1552
+
1553
+ sources.forEach((source) => {
1554
+ const target = targets.find((value) => UserToken.equals(value, source));
1555
+ if (target) {
1556
+ target.id = source.id || target.id;
1557
+ target.creationDate = source.creationDate || target.creationDate;
1558
+ target.updateDate = source.updateDate || target.updateDate;
1559
+ target.token = undefined;
1560
+ }
1561
+ });
1562
+ }
1563
+
1564
+ protected showToast<T = any>(opts: ShowToastOptions): Promise<OverlayEventDetail<T>> {
1565
+ return Toasts.show(this.toastController, this.translate, opts);
1566
+ }
1567
+ }