@tuki-io/tuki-widgets 0.0.26 → 0.0.28

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 (374) hide show
  1. package/.editorconfig +16 -0
  2. package/.vscode/extensions.json +4 -0
  3. package/.vscode/launch.json +20 -0
  4. package/.vscode/tasks.json +42 -0
  5. package/README.md +10 -9
  6. package/angular.json +41 -0
  7. package/package.json +40 -43
  8. package/projects/tuki/widgets/README.md +24 -0
  9. package/projects/tuki/widgets/karma.conf.js +44 -0
  10. package/projects/tuki/widgets/ng-package.json +7 -0
  11. package/projects/tuki/widgets/package.json +13 -0
  12. package/projects/tuki/widgets/src/lib/widgets.component.spec.ts +23 -0
  13. package/projects/tuki/widgets/src/lib/widgets.component.ts +20 -0
  14. package/projects/tuki/widgets/src/lib/widgets.module.ts +16 -0
  15. package/projects/tuki/widgets/src/lib/widgets.service.spec.ts +16 -0
  16. package/projects/tuki/widgets/src/lib/widgets.service.ts +9 -0
  17. package/{public-api.d.ts → projects/tuki/widgets/src/public-api.ts} +4 -0
  18. package/projects/tuki/widgets/src/test.ts +27 -0
  19. package/projects/tuki/widgets/tsconfig.lib.json +36 -0
  20. package/projects/tuki/widgets/tsconfig.lib.prod.json +10 -0
  21. package/projects/tuki/widgets/tsconfig.spec.json +17 -0
  22. package/projects/tuki/widgets/user-device-manage/ng-package.json +7 -0
  23. package/projects/tuki/widgets/user-device-manage/public-api.ts +8 -0
  24. package/projects/tuki/widgets/user-device-manage/src/app.constants.ts +96 -0
  25. package/projects/tuki/widgets/user-device-manage/src/assets/icons/arrow-left.svg +5 -0
  26. package/projects/tuki/widgets/user-device-manage/src/assets/icons/arrow-right.svg +5 -0
  27. package/projects/tuki/widgets/user-device-manage/src/assets/icons/close_icon_x.svg +3 -0
  28. package/projects/tuki/widgets/user-device-manage/src/assets/icons/delete_icon.svg +5 -0
  29. package/projects/tuki/widgets/user-device-manage/src/assets/icons/dragger-vertical-icon.svg +3 -0
  30. package/projects/tuki/widgets/user-device-manage/src/assets/icons/icon_user.svg +1 -0
  31. package/projects/tuki/widgets/user-device-manage/src/assets/icons/vartical_divider_icon.svg +3 -0
  32. package/projects/tuki/widgets/user-device-manage/src/classes/device.ts +292 -0
  33. package/projects/tuki/widgets/user-device-manage/src/classes/line-association-interface.ts +50 -0
  34. package/projects/tuki/widgets/user-device-manage/src/classes/line-association.ts +177 -0
  35. package/projects/tuki/widgets/user-device-manage/src/classes/line-call-info-display.ts +21 -0
  36. package/projects/tuki/widgets/user-device-manage/src/classes/line-directory.ts +41 -0
  37. package/projects/tuki/widgets/user-device-manage/src/classes/line.ts +144 -0
  38. package/projects/tuki/widgets/user-device-manage/src/classes/notification.ts +40 -0
  39. package/projects/tuki/widgets/user-device-manage/src/classes/recording-options.ts +6 -0
  40. package/projects/tuki/widgets/user-device-manage/src/classes/simplified-user.ts +169 -0
  41. package/projects/tuki/widgets/user-device-manage/src/classes/site-defaults.ts +167 -0
  42. package/projects/tuki/widgets/user-device-manage/src/classes/translation-pattern.ts +50 -0
  43. package/projects/tuki/widgets/user-device-manage/src/classes/types.ts +19 -0
  44. package/projects/tuki/widgets/user-device-manage/src/classes/user-interface.ts +225 -0
  45. package/projects/tuki/widgets/user-device-manage/src/classes/user.ts +8 -0
  46. package/projects/tuki/widgets/user-device-manage/src/common-functions.ts +16 -0
  47. package/projects/tuki/widgets/user-device-manage/src/confirm-dialog/info-dialog.component.html +14 -0
  48. package/projects/tuki/widgets/user-device-manage/src/confirm-dialog/info-dialog.component.scss +79 -0
  49. package/projects/tuki/widgets/user-device-manage/src/confirm-dialog/info-dialog.component.ts +35 -0
  50. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/associated-line-row/associated-line-row.component.css +97 -0
  51. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/associated-line-row/associated-line-row.component.html +21 -0
  52. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/associated-line-row/associated-line-row.component.ts +28 -0
  53. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-details-box/device-associated-line-details-box.component.css +20 -0
  54. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-details-box/device-associated-line-details-box.component.html +6 -0
  55. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-details-box/device-associated-line-details-box.component.ts +13 -0
  56. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-extension/device-associated-line-extension.component.html +6 -0
  57. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-extension/device-associated-line-extension.component.scss +4 -0
  58. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-extension/device-associated-line-extension.component.ts +63 -0
  59. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line.component.html +241 -0
  60. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line.component.scss +500 -0
  61. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line.component.ts +194 -0
  62. package/projects/tuki/widgets/user-device-manage/src/device-list/device-list.component.html +27 -0
  63. package/projects/tuki/widgets/user-device-manage/src/device-list/device-list.component.scss +131 -0
  64. package/projects/tuki/widgets/user-device-manage/src/device-list/device-list.component.ts +25 -0
  65. package/projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.html +209 -0
  66. package/projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.scss +502 -0
  67. package/projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.ts +354 -0
  68. package/projects/tuki/widgets/user-device-manage/src/environments/environment.prod.ts +9 -0
  69. package/projects/tuki/widgets/user-device-manage/src/environments/environment.ts +10 -0
  70. package/projects/tuki/widgets/user-device-manage/src/interseptors/auth.interceptor.ts +35 -0
  71. package/projects/tuki/widgets/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.html +50 -0
  72. package/projects/tuki/widgets/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.scss +8 -0
  73. package/projects/tuki/widgets/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.ts +81 -0
  74. package/projects/tuki/widgets/user-device-manage/src/material.module.ts +87 -0
  75. package/projects/tuki/widgets/user-device-manage/src/notifications/notification.component.html +33 -0
  76. package/projects/tuki/widgets/user-device-manage/src/notifications/notification.component.scss +84 -0
  77. package/projects/tuki/widgets/user-device-manage/src/notifications/notification.component.ts +46 -0
  78. package/projects/tuki/widgets/user-device-manage/src/removeKynFromIBM.service.ts +25 -0
  79. package/projects/tuki/widgets/user-device-manage/src/services/api.service.ts +87 -0
  80. package/projects/tuki/widgets/user-device-manage/src/services/common-functions.ts +17 -0
  81. package/projects/tuki/widgets/user-device-manage/src/services/device.service.ts +95 -0
  82. package/projects/tuki/widgets/user-device-manage/src/services/dns.service.ts +111 -0
  83. package/projects/tuki/widgets/user-device-manage/src/services/line.service.ts +89 -0
  84. package/projects/tuki/widgets/user-device-manage/src/services/notification.service.ts +68 -0
  85. package/projects/tuki/widgets/user-device-manage/src/services/removeKynFromIBM.service.ts +25 -0
  86. package/projects/tuki/widgets/user-device-manage/src/services/site-settings.service.ts +82 -0
  87. package/projects/tuki/widgets/user-device-manage/src/services/sorting-utils.service.ts +203 -0
  88. package/projects/tuki/widgets/user-device-manage/src/services/user.service.ts +283 -0
  89. package/projects/tuki/widgets/user-device-manage/src/services/utils.service.ts +87 -0
  90. package/projects/tuki/widgets/user-device-manage/src/services/validation.service.ts +829 -0
  91. package/projects/tuki/widgets/user-device-manage/src/styles/_variables.scss +90 -0
  92. package/projects/tuki/widgets/user-device-manage/src/styles/form.scss +231 -0
  93. package/projects/tuki/widgets/user-device-manage/src/styles/icons.scss +32 -0
  94. package/projects/tuki/widgets/user-device-manage/src/styles/styles.scss +110 -0
  95. package/projects/tuki/widgets/user-device-manage/src/styles/tables.scss +30 -0
  96. package/projects/tuki/widgets/user-device-manage/src/user-device-manage.module.ts +73 -0
  97. package/projects/tuki/widgets/user-device-manage/src/utils/app-loader/app-loader.component.html +6 -0
  98. package/projects/tuki/widgets/user-device-manage/src/utils/app-loader/app-loader.component.scss +11 -0
  99. package/projects/tuki/widgets/user-device-manage/src/utils/app-loader/app-loader.ts +13 -0
  100. package/projects/tuki/widgets/user-manage/ng-package.json +7 -0
  101. package/projects/tuki/widgets/user-manage/src/app.constants.ts +50 -0
  102. package/projects/tuki/widgets/user-manage/src/assets/icons/arrow-left.svg +5 -0
  103. package/projects/tuki/widgets/user-manage/src/assets/icons/arrow-right.svg +5 -0
  104. package/projects/tuki/widgets/user-manage/src/assets/icons/delete_icon.svg +5 -0
  105. package/projects/tuki/widgets/user-manage/src/assets/icons/dragger-vertical-icon.svg +3 -0
  106. package/projects/tuki/widgets/user-manage/src/assets/icons/icon_user.svg +1 -0
  107. package/projects/tuki/widgets/user-manage/src/assets/icons/vartical_divider_icon.svg +3 -0
  108. package/projects/tuki/widgets/user-manage/src/classes/device.ts +232 -0
  109. package/projects/tuki/widgets/user-manage/src/classes/line-association-interface.ts +43 -0
  110. package/projects/tuki/widgets/user-manage/src/classes/line-association.ts +161 -0
  111. package/projects/tuki/widgets/user-manage/src/classes/line-call-info-display.ts +21 -0
  112. package/projects/tuki/widgets/user-manage/src/classes/line-directory.ts +42 -0
  113. package/projects/tuki/widgets/user-manage/src/classes/line.ts +144 -0
  114. package/projects/tuki/widgets/user-manage/src/classes/notification.ts +39 -0
  115. package/projects/tuki/widgets/user-manage/src/classes/pagination.ts +18 -0
  116. package/projects/tuki/widgets/user-manage/src/classes/recording-options.ts +6 -0
  117. package/projects/tuki/widgets/user-manage/src/classes/simplified-user.ts +165 -0
  118. package/projects/tuki/widgets/user-manage/src/classes/table-data.ts +6 -0
  119. package/projects/tuki/widgets/user-manage/src/classes/translation-pattern.ts +49 -0
  120. package/projects/tuki/widgets/user-manage/src/classes/user-interface.ts +225 -0
  121. package/projects/tuki/widgets/user-manage/src/classes/user-list.ts +42 -0
  122. package/projects/tuki/widgets/user-manage/src/classes/user.ts +8 -0
  123. package/projects/tuki/widgets/user-manage/src/common-functions.ts +16 -0
  124. package/projects/tuki/widgets/user-manage/src/device-list/device-list.component.html +27 -0
  125. package/projects/tuki/widgets/user-manage/src/device-list/device-list.component.scss +131 -0
  126. package/projects/tuki/widgets/user-manage/src/device-list/device-list.component.ts +25 -0
  127. package/projects/tuki/widgets/user-manage/src/environments/environment.prod.ts +9 -0
  128. package/projects/tuki/widgets/user-manage/src/environments/environment.ts +10 -0
  129. package/projects/tuki/widgets/user-manage/src/interseptors/auth.interceptor.ts +35 -0
  130. package/projects/tuki/widgets/user-manage/src/lazy-loading-select/lazy-loading-select.component.html +50 -0
  131. package/projects/tuki/widgets/user-manage/src/lazy-loading-select/lazy-loading-select.component.scss +8 -0
  132. package/projects/tuki/widgets/user-manage/src/lazy-loading-select/lazy-loading-select.component.ts +81 -0
  133. package/projects/tuki/widgets/user-manage/src/material.module.ts +85 -0
  134. package/projects/tuki/widgets/user-manage/src/notifications/notification.component.html +33 -0
  135. package/projects/tuki/widgets/user-manage/src/notifications/notification.component.scss +84 -0
  136. package/projects/tuki/widgets/user-manage/src/notifications/notification.component.ts +46 -0
  137. package/projects/tuki/widgets/user-manage/src/removeKynFromIBM.service.ts +25 -0
  138. package/projects/tuki/widgets/user-manage/src/services/api.service.ts +90 -0
  139. package/projects/tuki/widgets/user-manage/src/services/dns.service.ts +116 -0
  140. package/projects/tuki/widgets/user-manage/src/services/line.service.ts +31 -0
  141. package/projects/tuki/widgets/user-manage/src/services/notification.service.ts +68 -0
  142. package/projects/tuki/widgets/user-manage/src/services/removeKynFromIBM.service.ts +25 -0
  143. package/projects/tuki/widgets/user-manage/src/services/site-settings.service.ts +35 -0
  144. package/projects/tuki/widgets/user-manage/src/services/sorting-utils.service.ts +203 -0
  145. package/projects/tuki/widgets/user-manage/src/services/user.service.ts +242 -0
  146. package/projects/tuki/widgets/user-manage/src/services/users-search.service.ts +58 -0
  147. package/projects/tuki/widgets/user-manage/src/services/utils.service.ts +71 -0
  148. package/projects/tuki/widgets/user-manage/src/styles/_variables.scss +90 -0
  149. package/projects/tuki/widgets/user-manage/src/styles/form.scss +231 -0
  150. package/projects/tuki/widgets/user-manage/src/styles/icons.scss +32 -0
  151. package/projects/tuki/widgets/user-manage/src/styles/styles.scss +110 -0
  152. package/projects/tuki/widgets/user-manage/src/styles/tables.scss +30 -0
  153. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling-extension/user-calling-extension.component.html +10 -0
  154. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling-extension/user-calling-extension.component.scss +429 -0
  155. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling-extension/user-calling-extension.component.ts +63 -0
  156. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.html +32 -0
  157. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.scss +444 -0
  158. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.ts +89 -0
  159. package/projects/tuki/widgets/user-manage/src/user-details/notification.service.ts +68 -0
  160. package/projects/tuki/widgets/user-manage/src/user-info/user-info.component.html +29 -0
  161. package/projects/tuki/widgets/user-manage/src/user-info/user-info.component.scss +64 -0
  162. package/projects/tuki/widgets/user-manage/src/user-info/user-info.component.ts +19 -0
  163. package/projects/tuki/widgets/user-manage/src/user-manage-widget.component.html +292 -0
  164. package/projects/tuki/widgets/user-manage/src/user-manage-widget.component.scss +463 -0
  165. package/projects/tuki/widgets/user-manage/src/user-manage-widget.component.ts +212 -0
  166. package/projects/tuki/widgets/user-manage/src/user-manage.module.ts +63 -0
  167. package/projects/tuki/widgets/user-manage/src/utils/app-loader/app-loader.component.html +6 -0
  168. package/projects/tuki/widgets/user-manage/src/utils/app-loader/app-loader.component.scss +11 -0
  169. package/projects/tuki/widgets/user-manage/src/utils/app-loader/app-loader.ts +13 -0
  170. package/projects/tuki/widgets/user-manage/src/utils/pagination/pagination.component.html +26 -0
  171. package/projects/tuki/widgets/user-manage/src/utils/pagination/pagination.component.scss +41 -0
  172. package/projects/tuki/widgets/user-manage/src/utils/pagination/pagination.component.ts +41 -0
  173. package/projects/tuki/widgets/users-list/ng-package.json +6 -0
  174. package/projects/tuki/widgets/users-list/src/app.constants.ts +50 -0
  175. package/projects/tuki/widgets/users-list/src/assets/icons/close_icon_modal.svg +3 -0
  176. package/projects/tuki/widgets/users-list/src/assets/icons/icon_user.svg +1 -0
  177. package/projects/tuki/widgets/users-list/src/classes/device.ts +225 -0
  178. package/projects/tuki/widgets/users-list/src/classes/line.ts +144 -0
  179. package/projects/tuki/widgets/users-list/src/classes/notification.ts +38 -0
  180. package/projects/tuki/widgets/users-list/src/classes/pagination.ts +18 -0
  181. package/projects/tuki/widgets/users-list/src/classes/simlified-user.ts +74 -0
  182. package/projects/tuki/widgets/users-list/src/classes/table-data.ts +6 -0
  183. package/projects/tuki/widgets/users-list/src/classes/user-interface.ts +225 -0
  184. package/projects/tuki/widgets/users-list/src/classes/user-list.ts +47 -0
  185. package/projects/tuki/widgets/users-list/src/classes/user.ts +8 -0
  186. package/projects/tuki/widgets/users-list/src/material.module.ts +94 -0
  187. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/move-user-stepper.component.css +183 -0
  188. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/move-user-stepper.component.html +93 -0
  189. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/move-user-stepper.component.ts +95 -0
  190. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-wizard.component.css +38 -0
  191. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-wizard.component.html +11 -0
  192. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-wizard.component.ts +34 -0
  193. package/projects/tuki/widgets/users-list/src/services/api-webex.service.ts +13 -0
  194. package/projects/tuki/widgets/users-list/src/services/api.service.ts +90 -0
  195. package/projects/tuki/widgets/users-list/src/services/dns.service.ts +128 -0
  196. package/projects/tuki/widgets/users-list/src/services/events-communication.service.ts +11 -0
  197. package/projects/tuki/widgets/users-list/src/services/notification.service.ts +68 -0
  198. package/projects/tuki/widgets/users-list/src/services/removeKynFromIBM.service.ts +25 -0
  199. package/projects/tuki/widgets/users-list/src/services/user.service.ts +168 -0
  200. package/projects/tuki/widgets/users-list/src/services/users-search.service.ts +135 -0
  201. package/projects/tuki/widgets/users-list/src/user-list-confirm-dialog/user-list-confirm-dialog.component.html +14 -0
  202. package/projects/tuki/widgets/users-list/src/user-list-confirm-dialog/user-list-confirm-dialog.component.scss +79 -0
  203. package/projects/tuki/widgets/users-list/src/user-list-confirm-dialog/user-list-confirm-dialog.component.ts +35 -0
  204. package/projects/tuki/widgets/users-list/src/users-list.component.css +4 -0
  205. package/projects/tuki/widgets/users-list/src/users-list.component.css.map +1 -0
  206. package/projects/tuki/widgets/users-list/src/users-list.component.html +86 -0
  207. package/projects/tuki/widgets/users-list/src/users-list.component.scss +572 -0
  208. package/projects/tuki/widgets/users-list/src/users-list.component.ts +283 -0
  209. package/projects/tuki/widgets/users-list/src/users-list.module.ts +51 -0
  210. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.css +11 -0
  211. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.css.map +1 -0
  212. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.html +6 -0
  213. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.scss +11 -0
  214. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.ts +13 -0
  215. package/projects/tuki/widgets/users-list/src/utils/common-functions.ts +16 -0
  216. package/projects/tuki/widgets/users-list/src/utils/notifications/notification.component.html +33 -0
  217. package/projects/tuki/widgets/users-list/src/utils/notifications/notification.component.scss +84 -0
  218. package/projects/tuki/widgets/users-list/src/utils/notifications/notification.component.ts +46 -0
  219. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.css +45 -0
  220. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.css.map +1 -0
  221. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.html +26 -0
  222. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.scss +41 -0
  223. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.ts +41 -0
  224. package/projects/tuki/widgets/users-list/src/utils/utils.service.ts +71 -0
  225. package/tsconfig.json +46 -0
  226. package/esm2020/lib/widgets.component.mjs +0 -22
  227. package/esm2020/lib/widgets.module.mjs +0 -21
  228. package/esm2020/lib/widgets.service.mjs +0 -14
  229. package/esm2020/public-api.mjs +0 -7
  230. package/esm2020/tuki-io-tuki-widgets.mjs +0 -5
  231. package/esm2020/user-manage/public-api.mjs +0 -7
  232. package/esm2020/user-manage/src/app.constants.mjs +0 -50
  233. package/esm2020/user-manage/src/classes/device.mjs +0 -24
  234. package/esm2020/user-manage/src/classes/line-association-interface.mjs +0 -2
  235. package/esm2020/user-manage/src/classes/line-association.mjs +0 -110
  236. package/esm2020/user-manage/src/classes/line-call-info-display.mjs +0 -10
  237. package/esm2020/user-manage/src/classes/line-directory.mjs +0 -27
  238. package/esm2020/user-manage/src/classes/line.mjs +0 -18
  239. package/esm2020/user-manage/src/classes/notification.mjs +0 -32
  240. package/esm2020/user-manage/src/classes/pagination.mjs +0 -8
  241. package/esm2020/user-manage/src/classes/recording-options.mjs +0 -7
  242. package/esm2020/user-manage/src/classes/simplified-user.mjs +0 -109
  243. package/esm2020/user-manage/src/classes/table-data.mjs +0 -2
  244. package/esm2020/user-manage/src/classes/translation-pattern.mjs +0 -32
  245. package/esm2020/user-manage/src/classes/user-list.mjs +0 -10
  246. package/esm2020/user-manage/src/common-functions.mjs +0 -19
  247. package/esm2020/user-manage/src/environments/environment.mjs +0 -11
  248. package/esm2020/user-manage/src/interseptors/auth.interceptor.mjs +0 -36
  249. package/esm2020/user-manage/src/lazy-loading-select/lazy-loading-select.component.mjs +0 -74
  250. package/esm2020/user-manage/src/material.module.mjs +0 -188
  251. package/esm2020/user-manage/src/notifications/notification.component.mjs +0 -35
  252. package/esm2020/user-manage/src/removeKynFromIBM.service.mjs +0 -25
  253. package/esm2020/user-manage/src/services/api.service.mjs +0 -79
  254. package/esm2020/user-manage/src/services/dns.service.mjs +0 -110
  255. package/esm2020/user-manage/src/services/line.service.mjs +0 -34
  256. package/esm2020/user-manage/src/services/notification.service.mjs +0 -62
  257. package/esm2020/user-manage/src/services/removeKynFromIBM.service.mjs +0 -25
  258. package/esm2020/user-manage/src/services/site-settings.service.mjs +0 -36
  259. package/esm2020/user-manage/src/services/sorting-utils.service.mjs +0 -197
  260. package/esm2020/user-manage/src/services/user.service.mjs +0 -207
  261. package/esm2020/user-manage/src/services/users-search.service.mjs +0 -49
  262. package/esm2020/user-manage/src/services/utils.service.mjs +0 -73
  263. package/esm2020/user-manage/src/user-calling/user-calling-extension/user-calling-extension.component.mjs +0 -65
  264. package/esm2020/user-manage/src/user-calling/user-calling.component.mjs +0 -78
  265. package/esm2020/user-manage/src/user-info/user-info.component.mjs +0 -20
  266. package/esm2020/user-manage/src/user-manage-widget.component.mjs +0 -193
  267. package/esm2020/user-manage/src/user-manage.module.mjs +0 -96
  268. package/esm2020/user-manage/src/utils/app-loader/app-loader.mjs +0 -14
  269. package/esm2020/user-manage/src/utils/pagination/pagination.component.mjs +0 -43
  270. package/esm2020/user-manage/tuki-io-tuki-widgets-user-manage.mjs +0 -5
  271. package/esm2020/users-list/public-api.mjs +0 -9
  272. package/esm2020/users-list/src/app.constants.mjs +0 -46
  273. package/esm2020/users-list/src/classes/device.mjs +0 -7
  274. package/esm2020/users-list/src/classes/line.mjs +0 -18
  275. package/esm2020/users-list/src/classes/notification.mjs +0 -31
  276. package/esm2020/users-list/src/classes/pagination.mjs +0 -8
  277. package/esm2020/users-list/src/classes/simlified-user.mjs +0 -50
  278. package/esm2020/users-list/src/classes/table-data.mjs +0 -2
  279. package/esm2020/users-list/src/classes/user-list.mjs +0 -13
  280. package/esm2020/users-list/src/material.module.mjs +0 -195
  281. package/esm2020/users-list/src/services/api-webex.service.mjs +0 -17
  282. package/esm2020/users-list/src/services/api.service.mjs +0 -78
  283. package/esm2020/users-list/src/services/events-communication.service.mjs +0 -14
  284. package/esm2020/users-list/src/services/notification.service.mjs +0 -62
  285. package/esm2020/users-list/src/services/removeKynFromIBM.service.mjs +0 -25
  286. package/esm2020/users-list/src/services/user.service.mjs +0 -129
  287. package/esm2020/users-list/src/services/users-search.service.mjs +0 -99
  288. package/esm2020/users-list/src/users-list.component.mjs +0 -187
  289. package/esm2020/users-list/src/users-list.module.mjs +0 -62
  290. package/esm2020/users-list/src/utils/app-loader/app-loader.mjs +0 -14
  291. package/esm2020/users-list/src/utils/common-functions.mjs +0 -19
  292. package/esm2020/users-list/src/utils/pagination/pagination.component.mjs +0 -43
  293. package/esm2020/users-list/src/utils/utils.service.mjs +0 -73
  294. package/esm2020/users-list/tuki-io-tuki-widgets-users-list.mjs +0 -5
  295. package/fesm2015/tuki-io-tuki-widgets-user-manage.mjs +0 -2074
  296. package/fesm2015/tuki-io-tuki-widgets-user-manage.mjs.map +0 -1
  297. package/fesm2015/tuki-io-tuki-widgets-users-list.mjs +0 -1100
  298. package/fesm2015/tuki-io-tuki-widgets-users-list.mjs.map +0 -1
  299. package/fesm2015/tuki-io-tuki-widgets.mjs +0 -63
  300. package/fesm2015/tuki-io-tuki-widgets.mjs.map +0 -1
  301. package/fesm2020/tuki-io-tuki-widgets-user-manage.mjs +0 -2057
  302. package/fesm2020/tuki-io-tuki-widgets-user-manage.mjs.map +0 -1
  303. package/fesm2020/tuki-io-tuki-widgets-users-list.mjs +0 -1093
  304. package/fesm2020/tuki-io-tuki-widgets-users-list.mjs.map +0 -1
  305. package/fesm2020/tuki-io-tuki-widgets.mjs +0 -63
  306. package/fesm2020/tuki-io-tuki-widgets.mjs.map +0 -1
  307. package/index.d.ts +0 -5
  308. package/lib/widgets.component.d.ts +0 -8
  309. package/lib/widgets.module.d.ts +0 -7
  310. package/lib/widgets.service.d.ts +0 -6
  311. package/user-manage/index.d.ts +0 -5
  312. package/user-manage/src/app.constants.d.ts +0 -29
  313. package/user-manage/src/classes/device.d.ts +0 -186
  314. package/user-manage/src/classes/line-association-interface.d.ts +0 -40
  315. package/user-manage/src/classes/line-association.d.ts +0 -55
  316. package/user-manage/src/classes/line-call-info-display.d.ts +0 -11
  317. package/user-manage/src/classes/line-directory.d.ts +0 -16
  318. package/user-manage/src/classes/line.d.ts +0 -140
  319. package/user-manage/src/classes/notification.d.ts +0 -18
  320. package/user-manage/src/classes/pagination.d.ts +0 -13
  321. package/user-manage/src/classes/recording-options.d.ts +0 -5
  322. package/user-manage/src/classes/simplified-user.d.ts +0 -50
  323. package/user-manage/src/classes/table-data.d.ts +0 -5
  324. package/user-manage/src/classes/translation-pattern.d.ts +0 -18
  325. package/user-manage/src/classes/user-list.d.ts +0 -34
  326. package/user-manage/src/common-functions.d.ts +0 -1
  327. package/user-manage/src/environments/environment.d.ts +0 -9
  328. package/user-manage/src/interseptors/auth.interceptor.d.ts +0 -9
  329. package/user-manage/src/lazy-loading-select/lazy-loading-select.component.d.ts +0 -35
  330. package/user-manage/src/material.module.d.ts +0 -28
  331. package/user-manage/src/notifications/notification.component.d.ts +0 -19
  332. package/user-manage/src/removeKynFromIBM.service.d.ts +0 -8
  333. package/user-manage/src/services/api.service.d.ts +0 -21
  334. package/user-manage/src/services/dns.service.d.ts +0 -14
  335. package/user-manage/src/services/line.service.d.ts +0 -17
  336. package/user-manage/src/services/notification.service.d.ts +0 -18
  337. package/user-manage/src/services/removeKynFromIBM.service.d.ts +0 -8
  338. package/user-manage/src/services/site-settings.service.d.ts +0 -9
  339. package/user-manage/src/services/sorting-utils.service.d.ts +0 -26
  340. package/user-manage/src/services/user.service.d.ts +0 -43
  341. package/user-manage/src/services/users-search.service.d.ts +0 -25
  342. package/user-manage/src/services/utils.service.d.ts +0 -9
  343. package/user-manage/src/user-calling/user-calling-extension/user-calling-extension.component.d.ts +0 -24
  344. package/user-manage/src/user-calling/user-calling.component.d.ts +0 -30
  345. package/user-manage/src/user-info/user-info.component.d.ts +0 -9
  346. package/user-manage/src/user-manage-widget.component.d.ts +0 -39
  347. package/user-manage/src/user-manage.module.d.ts +0 -20
  348. package/user-manage/src/utils/app-loader/app-loader.d.ts +0 -6
  349. package/user-manage/src/utils/pagination/pagination.component.d.ts +0 -18
  350. package/users-list/index.d.ts +0 -5
  351. package/users-list/src/app.constants.d.ts +0 -28
  352. package/users-list/src/classes/device.d.ts +0 -224
  353. package/users-list/src/classes/line.d.ts +0 -140
  354. package/users-list/src/classes/notification.d.ts +0 -18
  355. package/users-list/src/classes/pagination.d.ts +0 -13
  356. package/users-list/src/classes/simlified-user.d.ts +0 -25
  357. package/users-list/src/classes/table-data.d.ts +0 -5
  358. package/users-list/src/classes/user-list.d.ts +0 -36
  359. package/users-list/src/material.module.d.ts +0 -29
  360. package/users-list/src/services/api-webex.service.d.ts +0 -8
  361. package/users-list/src/services/api.service.d.ts +0 -21
  362. package/users-list/src/services/events-communication.service.d.ts +0 -8
  363. package/users-list/src/services/notification.service.d.ts +0 -18
  364. package/users-list/src/services/removeKynFromIBM.service.d.ts +0 -8
  365. package/users-list/src/services/user.service.d.ts +0 -32
  366. package/users-list/src/services/users-search.service.d.ts +0 -31
  367. package/users-list/src/users-list.component.d.ts +0 -49
  368. package/users-list/src/users-list.module.d.ts +0 -13
  369. package/users-list/src/utils/app-loader/app-loader.d.ts +0 -6
  370. package/users-list/src/utils/common-functions.d.ts +0 -1
  371. package/users-list/src/utils/pagination/pagination.component.d.ts +0 -18
  372. package/users-list/src/utils/utils.service.d.ts +0 -9
  373. /package/{user-manage/public-api.d.ts → projects/tuki/widgets/user-manage/public-api.ts} +0 -0
  374. /package/{users-list/public-api.d.ts → projects/tuki/widgets/users-list/public-api.ts} +0 -0
@@ -0,0 +1,444 @@
1
+ table {
2
+ border-collapse: collapse;
3
+ border-spacing: 0;
4
+ }
5
+ #user-calling {
6
+ height: calc(100vh - 100px);
7
+ table {
8
+ margin: 10px 0;
9
+ width: 100%;
10
+ }
11
+ th {
12
+ color: black;
13
+ text-align: left;
14
+ background: #efefef;
15
+ font-size: 14px;
16
+ font-weight: 500;
17
+ padding: 2px 5px;
18
+ }
19
+ }
20
+ //@import url( 'https://fonts.googleapis.com/css?family=Roboto:400,700|Material+Icons');
21
+ //@import url('https://fonts.googleapis.com/css?family=Raleway:400,100,200,300,500,600,800,700,900');
22
+ @import url('https://fonts.googleapis.com/css?family=Poppins:400,100,200,300,500,600,800,700,900');
23
+ //@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400&display=swap');
24
+
25
+ $fa-font-path : '../../node_modules/font-awesome/fonts';
26
+
27
+ //$common-font: Raleway, 'Raleway', sans-serif;
28
+ //$special-font: Raleway, 'Roboto', sans-serif;
29
+ //$content-font: 'Roboto', sans-serif;
30
+ //$buttons-font: Raleway, 'Raleway', sans-serif;
31
+ //$input-font: 'Roboto', sans-serif;
32
+ $menu-font: Poppins, 'Poppins', sans-serif;
33
+ $main-font: Poppins, 'Poppins', sans-serif;
34
+ //$sub-menu-font: Inter, 'Inter', sans-serif;
35
+ $font-size: 14px;
36
+ $txt-color: rgba(0, 0, 0, 0.87);
37
+ $table-title-color: rgba(0,0,0,.54);;
38
+ $txt-grey-color: #454e5e;
39
+ $header-gradient: linear-gradient(90deg,#0d56aa,#0d56ab);
40
+ $poppins-font: Poppins, 'Poppins', sans-serif;
41
+
42
+ $icon-color: #8E9FB7;
43
+ $active-color: #0D56AA;
44
+ $icon-box-color: #0773BC;
45
+ $mark-color: #009FDB;
46
+ $hover-color: #0985A0;
47
+ $error-color: #C73636;
48
+ $main-txt-color: #333;
49
+
50
+ $table-border-color: rgba(0, 0, 0, 0.12);
51
+ $input-border-color: rgba(0, 0, 0, 0.30);
52
+ $bg-color: #F7F9FB;
53
+
54
+ $error-bg-color: #f2dede;
55
+ $error-border-color: #ebccd1;
56
+ $error-txt-color: #bc1e1b;
57
+ $qob-error-color: #E70707;
58
+
59
+ $warning-bg-color: #fcf8e3;
60
+ $warning-border-color: #e5e1cd;
61
+ $warning-txt-color: #8a6d3b;
62
+
63
+ $success-bg-color: #e3f4dc;
64
+ $success-border-color: #b3d692;
65
+ $success-txt-color: #3c763d;
66
+
67
+ $read-only-txt-color: rgba(0, 0, 0, 0.38);
68
+ $my-menu-txt-color: #555555;
69
+
70
+ $page-background-color: #F3F6F6;
71
+ $disabled-button-text-color: #BABCC5;
72
+ $dark-elements-color: #2C355D;
73
+ $dark-disabled-btn-color: #DFE3E7;
74
+ $disabled-color: #DFE3E7;
75
+ $link-color: #0985A0;
76
+ $title-color: #0985A0;
77
+ $active-link-color: #0985A0;
78
+ $text-color: #646464;
79
+ $light-border-color: #DEE5EA;
80
+ $icon-background: #D2E5E5;
81
+
82
+ // QOB style
83
+ $navy: #2399DA;
84
+ $dark-blue: #2C355D;
85
+ $qob-danger-color: #E70707;
86
+ $qob-disabled-color: #D4D4D4;
87
+
88
+ // WEBEX STYLE
89
+
90
+ $webex-body-bg: #f7f7f7;
91
+
92
+
93
+ $webex-icon-bg: #d0d0d0;
94
+ $webex-icon-color: #2a2a2a;
95
+ $webex-text-color: #252525;
96
+
97
+ $webex-tr-hover-bg: #ededed;
98
+ $webex-tr-border: #dedede;
99
+
100
+ $webex-table-th-bg: #f7f7f7;
101
+ $webex-table-th-txt: #636363;
102
+ $webex-table-th-size: 12px;
103
+
104
+ $webex-table-td-bg: #fff;
105
+ $webex-table-td-txt: #636363;
106
+ $webex-table-td-size: 14px;
107
+
108
+ $webex-pagination-txt: #636363;
109
+ $webex-pagination-hover-bg: #ededed;
110
+
111
+ .mat-error {
112
+ color: $error-color;
113
+ margin: 13px 0 0 0;
114
+ }
115
+ .select-box {
116
+ border-radius: 30px;
117
+ background: #F3F6F6;
118
+ border: 1px solid #E2E9EF;
119
+ height: 35px;
120
+ position: relative;
121
+
122
+ select {
123
+ border: none !important;
124
+ background: transparent;
125
+ height: 100%;
126
+ width: 92%;
127
+ margin: auto;
128
+ display: block;
129
+ }
130
+
131
+ }
132
+
133
+ option:focus, option:focus-visible {
134
+ border: none !important;
135
+ outline: none !important;
136
+ }
137
+ option {
138
+ height: 30px;
139
+ cursor: pointer;
140
+ color: $webex-pagination-txt;
141
+ }
142
+ option:hover {
143
+ background: $webex-pagination-hover-bg !important;
144
+ }
145
+
146
+
147
+ .fa:hover {
148
+ color: #0d56aa!important;
149
+ }
150
+ .mat-icon-button {
151
+ background: transparent;
152
+ }
153
+ .icon-webex-box {
154
+ width: 2rem;
155
+ height: 2rem;
156
+ font-size: .7rem;
157
+ line-height: 1rem;
158
+ display: inline-block;
159
+ background: $webex-icon-bg;
160
+ border-radius: 2rem;
161
+ line-height: 40px;
162
+ text-align: center;
163
+ }
164
+ .icon-webex {
165
+ filter: invert(12%) sepia(14%) saturate(4%) hue-rotate(354deg) brightness(103%) contrast(90%);
166
+ background-repeat: no-repeat;
167
+ background-position: center;
168
+ display: inline-block;
169
+ height: 1rem;
170
+ width: 1rem;
171
+ }
172
+ .icon-webex-user {
173
+ background-image: url('../assets/icons/icon_user.svg');
174
+ }
175
+ .icon-user-status {
176
+ display: inline-block;
177
+
178
+ }
179
+
180
+
181
+
182
+
183
+
184
+ *{
185
+ margin: 0;
186
+ }
187
+
188
+ body {
189
+ background: $webex-body-bg;
190
+ }
191
+ body, th, td {
192
+ font-family: $main-font;
193
+ font-size: 14px;
194
+ }
195
+ th {
196
+ color: rgba(0,0,0,.54);
197
+ text-align: left;
198
+ }
199
+ td {
200
+ box-sizing: border-box;
201
+ padding: 10px 5px 10px 0;
202
+ }
203
+ .content-box {
204
+ margin: auto;
205
+ position: relative;
206
+ width: 95%;
207
+
208
+ table {
209
+ width: 100%
210
+ }
211
+ }
212
+ .edit-icon-td {
213
+ width: 50px;
214
+ position: relative;
215
+
216
+ button {
217
+ position: absolute;
218
+ top: 4px;
219
+ }
220
+ }
221
+ .mat-progress-spinner circle, .mat-spinner circle {
222
+ stroke: gray !important;
223
+ }
224
+ .data-loader {
225
+ position: absolute;
226
+ top: calc(50% - 25px);
227
+ left: calc(50% - 25px);
228
+ }
229
+ .flex-box {
230
+ display: flex;
231
+ justify-content: flex-start;
232
+ }
233
+
234
+ .spinner-container {
235
+ width: 100%;
236
+ display: flex;
237
+ justify-content: center;
238
+ align-items: center;
239
+ }
240
+ .spinner-container ::ng-deep .mat-progress-spinner circle, .mat-spinner circle {
241
+ stroke: #000000;
242
+ }
243
+
244
+
245
+ .user-info-box {
246
+ background: white;
247
+ display: grid;
248
+ grid-template-columns: 30% 70%;
249
+ border-radius: 8px;
250
+ border: rgba(0, 0, 0, 0.2) 1px solid;
251
+ padding: 24px;
252
+ font-weight: 400;
253
+ font-size: 14px;
254
+
255
+ h3 {
256
+ display: block;
257
+ font-weight: 500;
258
+ font-size: 16px;
259
+ }
260
+ }
261
+ .mat-divider{
262
+ margin: 5px 0 !important;
263
+ }
264
+ .info-boxes-container {
265
+ padding: 24px 0;
266
+ display: flex;
267
+ flex-direction: column;
268
+ gap: 24px;
269
+ }
270
+ .header-box {
271
+ height: 60px;
272
+ width: 100%;
273
+ line-height: 60px;
274
+ background: white;
275
+ border-bottom: 1px solid #dedddd;
276
+
277
+ .header-back-block {
278
+ float: left;
279
+ }
280
+ .header-button-block {
281
+ float: right;
282
+ }
283
+ }
284
+
285
+
286
+ .webex-table {
287
+ width: 100%;
288
+ margin: auto;
289
+
290
+ tr {
291
+ border-bottom: 1px solid $webex-tr-border;
292
+ }
293
+ th {
294
+ background: $webex-table-th-bg;
295
+ color: $webex-table-th-txt;
296
+ font-size: $webex-table-th-size;
297
+ }
298
+ td {
299
+ background: $webex-table-td-bg;
300
+ color: $webex-table-td-txt;
301
+ font-size: $webex-table-td-size;
302
+ }
303
+ tr:hover td {
304
+ background: $webex-tr-hover-bg;
305
+ cursor: pointer;
306
+ }
307
+ th.mat-header-cell, td.mat-cell, td.mat-footer-cell {
308
+ border-bottom: 1px solid $webex-tr-border;
309
+ }
310
+ tr.mat-header-row {
311
+ height: 37px;
312
+ }
313
+ }
314
+
315
+
316
+ .mat-form-field {
317
+ padding: 0 0 5px 0;
318
+ width: 93%;
319
+ }
320
+ .mat-form-field.mat-form-field-disabled {
321
+ border-bottom: none;
322
+ }
323
+ .mat-error {
324
+ color: $error-color;
325
+ margin: 13px 0 0 0;
326
+ }
327
+ .select-box {
328
+ border-radius: 30px;
329
+ background: #F3F6F6;
330
+ border: 1px solid #E2E9EF;
331
+ height: 35px;
332
+ position: relative;
333
+
334
+ select {
335
+ border: none !important;
336
+ background: transparent;
337
+ height: 100%;
338
+ width: 92%;
339
+ margin: auto;
340
+ display: block;
341
+ }
342
+
343
+ }
344
+
345
+ option:focus, option:focus-visible {
346
+ border: none !important;
347
+ outline: none !important;
348
+ }
349
+ option {
350
+ height: 30px;
351
+ cursor: pointer;
352
+ color: $webex-pagination-txt;
353
+ }
354
+ option:hover {
355
+ background: $webex-pagination-hover-bg !important;
356
+ }
357
+ .mat-select {
358
+ height: 100% !important;
359
+ line-height: 35px !important;
360
+ }
361
+ .info-holder, .input-holder {
362
+ display: grid;
363
+ grid-template-columns: 30% 70%;
364
+ align-items: baseline;
365
+
366
+ &__name{
367
+ font-weight: 500 !important;
368
+ font-size: 14px !important;
369
+ }
370
+ &__inputs{
371
+ & .input-holder{
372
+ display: grid;
373
+ grid-template-columns: 30% 70%;
374
+ align-items: baseline;
375
+ &__name{
376
+ font-weight: 400 !important;
377
+ font-size: 14px !important;
378
+ }
379
+ }
380
+ }
381
+ }
382
+
383
+
384
+
385
+ .mat-divider{
386
+ margin: 12px 0;
387
+ }
388
+ table {
389
+ border-collapse: collapse;
390
+ border-spacing: 0;
391
+ }
392
+
393
+ .mat-form-field-appearance-outline .mat-form-field-infix {
394
+ padding: 0px !important;
395
+ }
396
+
397
+ .mat-divider{
398
+ margin: 12px 0;
399
+ }
400
+
401
+ ::ng-deep .mat-form-field-wrapper {
402
+ height: 30px;
403
+ }
404
+ ::ng-deep .mat-form-field-flex{
405
+ height: 30px;
406
+ }
407
+
408
+ ::ng-deep .mat-form-field-appearance-outline .mat-form-field-outline{
409
+ height: 35px;
410
+ }
411
+
412
+ :ng-deep .mat-form-field-outline .mat-form-field-outline-thick{
413
+ height: 35px;
414
+ }
415
+
416
+ ::ng-deep .mat-select{
417
+ line-height: 20px;
418
+ }
419
+
420
+ ::ng-deep .mat-form-field-infix {
421
+ border-top: 0px !important;
422
+ }
423
+ ::ng-deep .mat-tab-group {
424
+ font-family: "Inter", sans-serif;
425
+ }
426
+
427
+ ::ng-deep .mat-tab-label {
428
+ font-weight: 500 !important;
429
+ font-size: 16px !important;
430
+ height: auto !important;
431
+ min-width: auto !important;
432
+ padding: 0 !important;
433
+ opacity: 1 !important;
434
+ color: black !important;
435
+ }
436
+
437
+ ::ng-deep .mat-ink-bar {
438
+ background-color: black !important;
439
+ height: 3px !important;
440
+ }
441
+ ::ng-deep .mat-tab-labels {
442
+ gap: 30px;
443
+ }
444
+
@@ -0,0 +1,89 @@
1
+ import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';
2
+ import { FormControl, FormGroup } from '@angular/forms';
3
+ import { SimplifiedUser } from '../classes/simplified-user';
4
+ import { LineAssociation } from '../classes/line-association';
5
+ import { LineAssociationInterface } from '../classes/line-association-interface';
6
+ import { UserService } from '../services/user.service';
7
+ import { DnsService } from '../services/dns.service';
8
+
9
+ @Component({
10
+ selector: 'app-user-calling',
11
+ templateUrl: './user-calling.component.html',
12
+ styleUrls: ['./user-calling.component.scss'],
13
+ })
14
+ export class UserCallingComponent implements OnInit {
15
+ @Input() siteId!: number;
16
+ @Input() userId!: string;
17
+ @Output() onExtensionChange = new EventEmitter<any>();
18
+ public dataPending!: boolean;
19
+
20
+ get form(): FormGroup {
21
+ return this.userService?.user?.devices[0] && this.userService?.user?.devices[0].lineAssociations[0].form;
22
+ }
23
+
24
+ get formControl(): FormControl {
25
+ const control = this.form?.get('directoryNumber') as FormControl;
26
+ return control;
27
+ }
28
+
29
+ get lineAssociation(): LineAssociation | LineAssociationInterface {
30
+ return this.userService?.user?.devices[0].lineAssociations[0];
31
+ }
32
+
33
+ get user(): SimplifiedUser {
34
+ return this.userService.user;
35
+ }
36
+
37
+
38
+ constructor(
39
+ public userService: UserService,
40
+ private dnsService: DnsService
41
+ ) {
42
+ }
43
+
44
+ ngOnInit(): void {
45
+ // this.getData();
46
+ }
47
+
48
+ onDirectoryNumberChange(value: any): void {
49
+ if (this.lineAssociation && this.lineAssociation.directoryNumber) {
50
+ // @ts-ignore
51
+ this.userService.user.devices[0].lineAssociations[0].directoryNumber.directoryNumber = value;
52
+ this.onExtensionChange.next(true);
53
+ }
54
+ }
55
+
56
+ public onChangeField(token: string): void {
57
+ if (!token) {
58
+ return;
59
+ }
60
+ (this.userService.user as any)[token] = this.form?.get(token)?.value;
61
+
62
+ }
63
+
64
+ public toggleEditMode() {
65
+ this.userService.user.toggleEditMode();
66
+ }
67
+
68
+ public isSavingDisabled(): boolean {
69
+ return !this.userService.hasUnsavedChanges() || this.userService.hasExistedUserId;
70
+ }
71
+
72
+ public onChangeExtension(value: string): void {
73
+ if (this.lineAssociation && this.lineAssociation.directoryNumber) {
74
+ // @ts-ignore
75
+ this.userService.user.devices[0].lineAssociations[0].directoryNumber.directoryNumber = value;
76
+ }
77
+ }
78
+
79
+ private getData() {
80
+ this.dataPending = true;
81
+ this.dnsService.getNumberRange(String(this.siteId), this.userId)
82
+ .subscribe({
83
+ complete: (v: any) => {
84
+ this.dataPending = false;
85
+ },
86
+ error: (e: any) => this.dataPending = false,
87
+ });
88
+ }
89
+ }
@@ -0,0 +1,68 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { Notification } from './classes/notification';
3
+ import { Subject } from 'rxjs';
4
+ const SUCCESS_TIME = 5000;
5
+ const INACTIVE_SESSION_MESSAGE = 'Your session was lost due to inactivity. Please login again';
6
+ const INACTIVE_SESSION = 'SESSION_INACTIVE';
7
+
8
+ @Injectable()
9
+ export class NotificationService {
10
+
11
+ public listChange = new Subject();
12
+
13
+ private max = 0;
14
+ private list: Notification[] = [];
15
+
16
+ constructor(
17
+ ) {
18
+ }
19
+
20
+ error(message: string, ttl?: number): void {
21
+ this.notify('error', message, ttl);
22
+ }
23
+
24
+ success(message: string, ttl?: number): void {
25
+ this.notify('success', message, (!ttl) ? SUCCESS_TIME : ttl);
26
+ }
27
+
28
+ warning(message: string, ttl?: number): void {
29
+ this.notify('warning', message, ttl);
30
+ }
31
+
32
+ info(message: string, ttl?: number): void {
33
+ this.notify('info', message, ttl);
34
+ }
35
+ private notify(type: string, message: string, ttl?: number): void {
36
+ const found = this.list.find((n: Notification) => n.message === message);
37
+ if (found) {
38
+ this.remove(found);
39
+ }
40
+ const notification = new Notification({
41
+ id: ++this.max,
42
+ type, message, ttl
43
+ });
44
+ if (notification.ttl > 0) {
45
+ notification.timerId = setTimeout(() => this.remove(notification, true), notification.ttl);
46
+ }
47
+ this.list.push(notification);
48
+ this.listChange.next(this.list);
49
+ }
50
+
51
+ remove(notification: Notification, auto?: boolean): void {
52
+ if (!auto && notification.timerId) {
53
+ // clear timeout in case of manual remove
54
+ clearInterval(notification.timerId);
55
+ }
56
+ this.list = this.list.filter(n => n.id !== notification.id);
57
+ this.listChange.next(this.list);
58
+ }
59
+
60
+ private removeInactiveSessionError(): void {
61
+ if (!this.list || !this.list.length) {
62
+ return;
63
+ }
64
+ this.list = this.list.filter(n => n.message !== INACTIVE_SESSION_MESSAGE && n.message !== INACTIVE_SESSION);
65
+ this.listChange.next(this.list);
66
+ }
67
+
68
+ }
@@ -0,0 +1,29 @@
1
+ <div class="info-holder">
2
+ <div class="content-box flex-box">
3
+ <div class="info-holder__user-image">
4
+ <img src="../../../assets/a24749b225874bb3e3a4cb5d2f42e82c.png" alt="" class="avatar">
5
+ </div>
6
+ <div class="info-holder__user-information">
7
+ <div class="info-holder__user-name">{{name}}</div>
8
+ <div class="info-holder__user-breadcrumbs">
9
+ <div class="is-active" *ngIf="active; else notActive">
10
+ <span class="icon-user-status icon-user-status-active"></span>Active
11
+ </div>
12
+ <div class="icon-separator"></div>
13
+ <div class="email">{{email}}</div>
14
+ <div class="icon-separator"></div>
15
+ <div class="position">{{position}}</div>
16
+ </div>
17
+ </div>
18
+ </div>
19
+
20
+ </div>
21
+
22
+ <ng-template #notActive>
23
+ <div class="is-active">
24
+ <svg width="8" height="9" viewBox="0 0 8 9" fill="none" xmlns="http://www.w3.org/2000/svg">
25
+ <path fill-rule="evenodd" clip-rule="evenodd" d="M4 8.5C6.20914 8.5 8 6.70914 8 4.5C8 2.29086 6.20914 0.5 4 0.5C1.79086 0.5 0 2.29086 0 4.5C0 6.70914 1.79086 8.5 4 8.5Z" fill="grey"/>
26
+ </svg>
27
+ <div>Not active</div>
28
+ </div>
29
+ </ng-template>
@@ -0,0 +1,64 @@
1
+ .info-holder {
2
+ display: flex;
3
+ gap: 16px;
4
+ align-items: center;
5
+ font-family: "Inter", sans-serif;
6
+ height: 102px;
7
+ width: 100%;
8
+ background: white;
9
+ margin: 0 0 30px 0;
10
+
11
+ &__user-image {
12
+ img {
13
+ width: 40px;
14
+ border-radius: 120px;
15
+ margin: 20px 0 0 0;
16
+ }
17
+ }
18
+
19
+ &__user-information {
20
+ padding: 10px;
21
+ margin: 10px;
22
+ gap: 10px;
23
+ display: flex;
24
+ flex-direction: column;
25
+ }
26
+
27
+ &__user-name {
28
+ font-size: 20px;
29
+ font-weight: 500;
30
+ }
31
+
32
+ &__user-breadcrumbs {
33
+ display: flex;
34
+ gap: 8px;
35
+ font-weight: 400;
36
+ font-size: 14px;
37
+ color: rgba(0, 0, 0, 0.7);
38
+ align-items: center;
39
+ }
40
+
41
+ .icon-separator {
42
+ height: 5px;
43
+ width: 5px;
44
+ background-color: rgba(0, 0, 0, 0.7);
45
+ border-radius: 50%;
46
+ }
47
+
48
+ .is-active {
49
+ display: flex;
50
+ gap: 8px;
51
+ align-items: center;
52
+ }
53
+ }
54
+ .icon-user-status {
55
+ width: .5rem;
56
+ height: .5rem;
57
+ border-radius: 50%;
58
+ background-color: #707070;
59
+ margin: 0 5px 0 0;
60
+ }
61
+ .icon-user-status.icon-user-status-active {
62
+ background-color: #1d805f;
63
+ display:inline-block;
64
+ }
@@ -0,0 +1,19 @@
1
+ import { Component, Input } from '@angular/core';
2
+
3
+ @Component({
4
+ selector: 'app-user-info',
5
+ templateUrl: './user-info.component.html',
6
+ styleUrls: ['./user-info.component.scss']
7
+ })
8
+ export class UserInfoComponent {
9
+ @Input()
10
+ name!: string;
11
+ @Input()
12
+ active!: boolean;
13
+ @Input()
14
+ email!: string;
15
+ @Input()
16
+ position!: string;
17
+
18
+
19
+ }