@tuki-io/tuki-widgets 0.0.65 → 0.0.67

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 (233) hide show
  1. package/.editorconfig +16 -16
  2. package/.vscode/extensions.json +4 -4
  3. package/.vscode/launch.json +20 -20
  4. package/.vscode/tasks.json +42 -42
  5. package/README.md +25 -25
  6. package/package.json +1 -1
  7. package/projects/tuki/widgets/README.md +24 -24
  8. package/projects/tuki/widgets/di2mt/public-api.ts +3 -3
  9. package/projects/tuki/widgets/di2mt/widgets/site-upgrade/site-upgrade.module.ts +1 -1
  10. package/projects/tuki/widgets/karma.conf.js +44 -44
  11. package/projects/tuki/widgets/ng-package.json +10 -7
  12. package/projects/tuki/widgets/package.json +1 -1
  13. package/projects/tuki/widgets/src/lib/widgets.component.spec.ts +23 -23
  14. package/projects/tuki/widgets/src/lib/widgets.component.ts +20 -20
  15. package/projects/tuki/widgets/src/lib/widgets.module.ts +16 -16
  16. package/projects/tuki/widgets/src/lib/widgets.service.spec.ts +16 -16
  17. package/projects/tuki/widgets/src/lib/widgets.service.ts +9 -9
  18. package/projects/tuki/widgets/src/public-api.ts +7 -7
  19. package/projects/tuki/widgets/src/test.ts +27 -27
  20. package/projects/tuki/widgets/styles.scss +572 -572
  21. package/projects/tuki/widgets/tsconfig.lib.json +36 -36
  22. package/projects/tuki/widgets/tsconfig.lib.prod.json +10 -10
  23. package/projects/tuki/widgets/tsconfig.spec.json +17 -17
  24. package/projects/tuki/widgets/user-device-manage/ng-package.json +7 -7
  25. package/projects/tuki/widgets/user-device-manage/public-api.ts +8 -8
  26. package/projects/tuki/widgets/user-device-manage/src/app.constants.ts +96 -96
  27. package/projects/tuki/widgets/user-device-manage/src/assets/icons/arrow-left.svg +5 -5
  28. package/projects/tuki/widgets/user-device-manage/src/assets/icons/arrow-right.svg +5 -5
  29. package/projects/tuki/widgets/user-device-manage/src/assets/icons/close_icon_x.svg +3 -3
  30. package/projects/tuki/widgets/user-device-manage/src/assets/icons/delete_icon.svg +5 -5
  31. package/projects/tuki/widgets/user-device-manage/src/assets/icons/dragger-vertical-icon.svg +3 -3
  32. package/projects/tuki/widgets/user-device-manage/src/assets/icons/vartical_divider_icon.svg +3 -3
  33. package/projects/tuki/widgets/user-device-manage/src/classes/device.ts +292 -292
  34. package/projects/tuki/widgets/user-device-manage/src/classes/line-association-interface.ts +50 -50
  35. package/projects/tuki/widgets/user-device-manage/src/classes/line-association.ts +177 -177
  36. package/projects/tuki/widgets/user-device-manage/src/classes/line-call-info-display.ts +21 -21
  37. package/projects/tuki/widgets/user-device-manage/src/classes/line-directory.ts +41 -41
  38. package/projects/tuki/widgets/user-device-manage/src/classes/line.ts +144 -144
  39. package/projects/tuki/widgets/user-device-manage/src/classes/notification.ts +40 -40
  40. package/projects/tuki/widgets/user-device-manage/src/classes/recording-options.ts +6 -6
  41. package/projects/tuki/widgets/user-device-manage/src/classes/simplified-user.ts +169 -169
  42. package/projects/tuki/widgets/user-device-manage/src/classes/site-defaults.ts +167 -167
  43. package/projects/tuki/widgets/user-device-manage/src/classes/translation-pattern.ts +50 -50
  44. package/projects/tuki/widgets/user-device-manage/src/classes/types.ts +19 -19
  45. package/projects/tuki/widgets/user-device-manage/src/classes/user-interface.ts +225 -225
  46. package/projects/tuki/widgets/user-device-manage/src/classes/user.ts +8 -8
  47. package/projects/tuki/widgets/user-device-manage/src/common-functions.ts +16 -16
  48. package/projects/tuki/widgets/user-device-manage/src/confirm-dialog/info-dialog.component.html +14 -14
  49. package/projects/tuki/widgets/user-device-manage/src/confirm-dialog/info-dialog.component.scss +80 -80
  50. package/projects/tuki/widgets/user-device-manage/src/confirm-dialog/info-dialog.component.ts +35 -35
  51. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/associated-line-row/associated-line-row.component.html +21 -21
  52. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/associated-line-row/associated-line-row.component.scss +97 -97
  53. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/associated-line-row/associated-line-row.component.ts +28 -28
  54. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-details-box/device-associated-line-details-box.component.html +5 -5
  55. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-details-box/device-associated-line-details-box.component.scss +19 -19
  56. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-details-box/device-associated-line-details-box.component.ts +13 -13
  57. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-extension/device-associated-line-extension.component.html +6 -6
  58. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-extension/device-associated-line-extension.component.scss +4 -4
  59. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line-extension/device-associated-line-extension.component.ts +63 -63
  60. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line.component.html +241 -241
  61. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line.component.scss +500 -500
  62. package/projects/tuki/widgets/user-device-manage/src/device-associated-line/device-associated-line.component.ts +194 -194
  63. package/projects/tuki/widgets/user-device-manage/src/device-list/device-list.component.html +27 -27
  64. package/projects/tuki/widgets/user-device-manage/src/device-list/device-list.component.scss +131 -131
  65. package/projects/tuki/widgets/user-device-manage/src/device-list/device-list.component.ts +25 -25
  66. package/projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.html +209 -209
  67. package/projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.scss +502 -502
  68. package/projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.ts +354 -354
  69. package/projects/tuki/widgets/user-device-manage/src/environments/environment.prod.ts +9 -9
  70. package/projects/tuki/widgets/user-device-manage/src/environments/environment.ts +10 -10
  71. package/projects/tuki/widgets/user-device-manage/src/interseptors/auth.interceptor.ts +35 -35
  72. package/projects/tuki/widgets/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.html +50 -50
  73. package/projects/tuki/widgets/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.scss +8 -8
  74. package/projects/tuki/widgets/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.ts +81 -81
  75. package/projects/tuki/widgets/user-device-manage/src/material.module.ts +87 -87
  76. package/projects/tuki/widgets/user-device-manage/src/notifications/notification.component.html +33 -33
  77. package/projects/tuki/widgets/user-device-manage/src/notifications/notification.component.scss +84 -84
  78. package/projects/tuki/widgets/user-device-manage/src/notifications/notification.component.ts +46 -46
  79. package/projects/tuki/widgets/user-device-manage/src/removeKynFromIBM.service.ts +25 -25
  80. package/projects/tuki/widgets/user-device-manage/src/services/api.service.ts +87 -87
  81. package/projects/tuki/widgets/user-device-manage/src/services/common-functions.ts +17 -17
  82. package/projects/tuki/widgets/user-device-manage/src/services/device.service.ts +95 -95
  83. package/projects/tuki/widgets/user-device-manage/src/services/dns.service.ts +111 -111
  84. package/projects/tuki/widgets/user-device-manage/src/services/line.service.ts +89 -89
  85. package/projects/tuki/widgets/user-device-manage/src/services/notification.service.ts +68 -68
  86. package/projects/tuki/widgets/user-device-manage/src/services/removeKynFromIBM.service.ts +25 -25
  87. package/projects/tuki/widgets/user-device-manage/src/services/site-settings.service.ts +82 -82
  88. package/projects/tuki/widgets/user-device-manage/src/services/sorting-utils.service.ts +203 -203
  89. package/projects/tuki/widgets/user-device-manage/src/services/user.service.ts +283 -283
  90. package/projects/tuki/widgets/user-device-manage/src/services/utils.service.ts +87 -87
  91. package/projects/tuki/widgets/user-device-manage/src/services/validation.service.ts +829 -829
  92. package/projects/tuki/widgets/user-device-manage/src/styles/_variables.scss +90 -90
  93. package/projects/tuki/widgets/user-device-manage/src/styles/form.scss +231 -231
  94. package/projects/tuki/widgets/user-device-manage/src/styles/icons.scss +32 -32
  95. package/projects/tuki/widgets/user-device-manage/src/styles/styles.scss +110 -110
  96. package/projects/tuki/widgets/user-device-manage/src/styles/tables.scss +30 -30
  97. package/projects/tuki/widgets/user-device-manage/src/user-device-manage.module.ts +73 -73
  98. package/projects/tuki/widgets/user-device-manage/src/utils/app-loader/app-loader.component.html +6 -6
  99. package/projects/tuki/widgets/user-device-manage/src/utils/app-loader/app-loader.component.scss +11 -11
  100. package/projects/tuki/widgets/user-device-manage/src/utils/app-loader/app-loader.ts +13 -13
  101. package/projects/tuki/widgets/user-manage/ng-package.json +7 -7
  102. package/projects/tuki/widgets/user-manage/public-api.ts +6 -6
  103. package/projects/tuki/widgets/user-manage/src/app.constants.ts +50 -50
  104. package/projects/tuki/widgets/user-manage/src/assets/icons/arrow-left.svg +5 -5
  105. package/projects/tuki/widgets/user-manage/src/assets/icons/arrow-right.svg +5 -5
  106. package/projects/tuki/widgets/user-manage/src/assets/icons/delete_icon.svg +5 -5
  107. package/projects/tuki/widgets/user-manage/src/assets/icons/dragger-vertical-icon.svg +3 -3
  108. package/projects/tuki/widgets/user-manage/src/assets/icons/vartical_divider_icon.svg +3 -3
  109. package/projects/tuki/widgets/user-manage/src/classes/device.ts +232 -232
  110. package/projects/tuki/widgets/user-manage/src/classes/line-association-interface.ts +43 -43
  111. package/projects/tuki/widgets/user-manage/src/classes/line-association.ts +161 -161
  112. package/projects/tuki/widgets/user-manage/src/classes/line-call-info-display.ts +21 -21
  113. package/projects/tuki/widgets/user-manage/src/classes/line-directory.ts +42 -42
  114. package/projects/tuki/widgets/user-manage/src/classes/line.ts +144 -144
  115. package/projects/tuki/widgets/user-manage/src/classes/notification.ts +39 -39
  116. package/projects/tuki/widgets/user-manage/src/classes/pagination.ts +18 -18
  117. package/projects/tuki/widgets/user-manage/src/classes/recording-options.ts +6 -6
  118. package/projects/tuki/widgets/user-manage/src/classes/simplified-user.ts +165 -165
  119. package/projects/tuki/widgets/user-manage/src/classes/table-data.ts +6 -6
  120. package/projects/tuki/widgets/user-manage/src/classes/translation-pattern.ts +49 -49
  121. package/projects/tuki/widgets/user-manage/src/classes/user-interface.ts +225 -225
  122. package/projects/tuki/widgets/user-manage/src/classes/user-list.ts +42 -42
  123. package/projects/tuki/widgets/user-manage/src/classes/user.ts +8 -8
  124. package/projects/tuki/widgets/user-manage/src/common-functions.ts +16 -16
  125. package/projects/tuki/widgets/user-manage/src/device-list/device-list.component.html +27 -27
  126. package/projects/tuki/widgets/user-manage/src/device-list/device-list.component.scss +131 -131
  127. package/projects/tuki/widgets/user-manage/src/device-list/device-list.component.ts +25 -25
  128. package/projects/tuki/widgets/user-manage/src/environments/environment.prod.ts +9 -9
  129. package/projects/tuki/widgets/user-manage/src/environments/environment.ts +10 -10
  130. package/projects/tuki/widgets/user-manage/src/interseptors/auth.interceptor.ts +35 -35
  131. package/projects/tuki/widgets/user-manage/src/lazy-loading-select/lazy-loading-select.component.html +50 -50
  132. package/projects/tuki/widgets/user-manage/src/lazy-loading-select/lazy-loading-select.component.scss +8 -8
  133. package/projects/tuki/widgets/user-manage/src/lazy-loading-select/lazy-loading-select.component.ts +81 -81
  134. package/projects/tuki/widgets/user-manage/src/material.module.ts +85 -85
  135. package/projects/tuki/widgets/user-manage/src/notifications/notification.component.html +33 -33
  136. package/projects/tuki/widgets/user-manage/src/notifications/notification.component.scss +84 -84
  137. package/projects/tuki/widgets/user-manage/src/notifications/notification.component.ts +46 -46
  138. package/projects/tuki/widgets/user-manage/src/removeKynFromIBM.service.ts +25 -25
  139. package/projects/tuki/widgets/user-manage/src/services/api.service.ts +90 -90
  140. package/projects/tuki/widgets/user-manage/src/services/dns.service.ts +116 -116
  141. package/projects/tuki/widgets/user-manage/src/services/line.service.ts +31 -31
  142. package/projects/tuki/widgets/user-manage/src/services/notification.service.ts +68 -68
  143. package/projects/tuki/widgets/user-manage/src/services/removeKynFromIBM.service.ts +25 -25
  144. package/projects/tuki/widgets/user-manage/src/services/site-settings.service.ts +35 -35
  145. package/projects/tuki/widgets/user-manage/src/services/sorting-utils.service.ts +203 -203
  146. package/projects/tuki/widgets/user-manage/src/services/user.service.ts +242 -242
  147. package/projects/tuki/widgets/user-manage/src/services/users-search.service.ts +59 -59
  148. package/projects/tuki/widgets/user-manage/src/services/utils.service.ts +71 -71
  149. package/projects/tuki/widgets/user-manage/src/styles/_variables.scss +90 -90
  150. package/projects/tuki/widgets/user-manage/src/styles/form.scss +231 -231
  151. package/projects/tuki/widgets/user-manage/src/styles/icons.scss +32 -32
  152. package/projects/tuki/widgets/user-manage/src/styles/styles.scss +110 -110
  153. package/projects/tuki/widgets/user-manage/src/styles/tables.scss +30 -30
  154. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling-extension/user-calling-extension.component.html +10 -10
  155. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling-extension/user-calling-extension.component.scss +429 -429
  156. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling-extension/user-calling-extension.component.ts +63 -63
  157. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.html +32 -32
  158. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.scss +444 -444
  159. package/projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.ts +89 -89
  160. package/projects/tuki/widgets/user-manage/src/user-details/notification.service.ts +68 -68
  161. package/projects/tuki/widgets/user-manage/src/user-info/user-info.component.html +29 -29
  162. package/projects/tuki/widgets/user-manage/src/user-info/user-info.component.scss +64 -64
  163. package/projects/tuki/widgets/user-manage/src/user-info/user-info.component.ts +19 -19
  164. package/projects/tuki/widgets/user-manage/src/user-manage-widget.component.html +290 -290
  165. package/projects/tuki/widgets/user-manage/src/user-manage-widget.component.scss +463 -463
  166. package/projects/tuki/widgets/user-manage/src/user-manage-widget.component.ts +212 -212
  167. package/projects/tuki/widgets/user-manage/src/user-manage.module.ts +63 -63
  168. package/projects/tuki/widgets/user-manage/src/utils/app-loader/app-loader.component.html +6 -6
  169. package/projects/tuki/widgets/user-manage/src/utils/app-loader/app-loader.component.scss +11 -11
  170. package/projects/tuki/widgets/user-manage/src/utils/app-loader/app-loader.ts +13 -13
  171. package/projects/tuki/widgets/user-manage/src/utils/pagination/pagination.component.html +26 -26
  172. package/projects/tuki/widgets/user-manage/src/utils/pagination/pagination.component.scss +41 -41
  173. package/projects/tuki/widgets/user-manage/src/utils/pagination/pagination.component.ts +41 -41
  174. package/projects/tuki/widgets/users-list/ng-package.json +6 -6
  175. package/projects/tuki/widgets/users-list/public-api.ts +8 -8
  176. package/projects/tuki/widgets/users-list/src/app.constants.ts +54 -54
  177. package/projects/tuki/widgets/users-list/src/assets/icons/close_icon_modal.svg +3 -3
  178. package/projects/tuki/widgets/users-list/src/assets/icons/move_user_to_another_location.svg +14 -14
  179. package/projects/tuki/widgets/users-list/src/assets/icons/white-close-icon.svg +3 -3
  180. package/projects/tuki/widgets/users-list/src/classes/app-location.ts +36 -36
  181. package/projects/tuki/widgets/users-list/src/classes/device.ts +225 -225
  182. package/projects/tuki/widgets/users-list/src/classes/line.ts +144 -144
  183. package/projects/tuki/widgets/users-list/src/classes/move-user.ts +225 -225
  184. package/projects/tuki/widgets/users-list/src/classes/notification.ts +38 -38
  185. package/projects/tuki/widgets/users-list/src/classes/pagination.ts +18 -18
  186. package/projects/tuki/widgets/users-list/src/classes/simlified-user.ts +74 -74
  187. package/projects/tuki/widgets/users-list/src/classes/table-data.ts +6 -6
  188. package/projects/tuki/widgets/users-list/src/classes/user-interface.ts +225 -225
  189. package/projects/tuki/widgets/users-list/src/classes/user-list.ts +47 -47
  190. package/projects/tuki/widgets/users-list/src/classes/user.ts +8 -8
  191. package/projects/tuki/widgets/users-list/src/material.module.ts +94 -94
  192. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/device-move-user/device-move-user-wizard.component.html +37 -37
  193. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/device-move-user/device-move-user-wizard.component.scss +129 -129
  194. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/device-move-user/device-move-user-wizard.component.ts +46 -46
  195. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/device-move-user-tab/devices-move-user-wizard-tab.component.html +31 -31
  196. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/device-move-user-tab/devices-move-user-wizard-tab.component.scss +20 -20
  197. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/device-move-user-tab/devices-move-user-wizard-tab.component.ts +26 -26
  198. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/move-user-stepper.component.html +222 -222
  199. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/move-user-stepper.component.scss +239 -239
  200. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-stepper/move-user-stepper.component.ts +206 -206
  201. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-wizard.component.html +12 -12
  202. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-wizard.component.scss +41 -41
  203. package/projects/tuki/widgets/users-list/src/move-user-wizard/move-user-wizard.component.ts +36 -36
  204. package/projects/tuki/widgets/users-list/src/services/api-webex.service.ts +14 -14
  205. package/projects/tuki/widgets/users-list/src/services/api.service.ts +90 -90
  206. package/projects/tuki/widgets/users-list/src/services/dns.service.ts +128 -128
  207. package/projects/tuki/widgets/users-list/src/services/events-communication.service.ts +11 -11
  208. package/projects/tuki/widgets/users-list/src/services/move-user.service.ts +59 -59
  209. package/projects/tuki/widgets/users-list/src/services/notification.service.ts +68 -68
  210. package/projects/tuki/widgets/users-list/src/services/removeKynFromIBM.service.ts +25 -25
  211. package/projects/tuki/widgets/users-list/src/services/site-settings.service.ts +26 -26
  212. package/projects/tuki/widgets/users-list/src/services/user.service.ts +159 -159
  213. package/projects/tuki/widgets/users-list/src/services/users-search.service.ts +137 -137
  214. package/projects/tuki/widgets/users-list/src/styles/styles.scss +572 -572
  215. package/projects/tuki/widgets/users-list/src/user-list-confirm-dialog/user-list-confirm-dialog.component.html +15 -15
  216. package/projects/tuki/widgets/users-list/src/user-list-confirm-dialog/user-list-confirm-dialog.component.scss +103 -103
  217. package/projects/tuki/widgets/users-list/src/user-list-confirm-dialog/user-list-confirm-dialog.component.ts +35 -35
  218. package/projects/tuki/widgets/users-list/src/users-list.component.html +86 -86
  219. package/projects/tuki/widgets/users-list/src/users-list.component.scss +572 -572
  220. package/projects/tuki/widgets/users-list/src/users-list.component.ts +312 -312
  221. package/projects/tuki/widgets/users-list/src/users-list.module.ts +63 -63
  222. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.html +6 -6
  223. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.component.scss +11 -11
  224. package/projects/tuki/widgets/users-list/src/utils/app-loader/app-loader.ts +13 -13
  225. package/projects/tuki/widgets/users-list/src/utils/common-functions.ts +32 -32
  226. package/projects/tuki/widgets/users-list/src/utils/notifications/notification.component.html +33 -33
  227. package/projects/tuki/widgets/users-list/src/utils/notifications/notification.component.scss +84 -84
  228. package/projects/tuki/widgets/users-list/src/utils/notifications/notification.component.ts +46 -46
  229. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.html +26 -26
  230. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.scss +41 -41
  231. package/projects/tuki/widgets/users-list/src/utils/pagination/pagination.component.ts +41 -41
  232. package/projects/tuki/widgets/users-list/src/utils/utils.service.ts +71 -71
  233. package/tsconfig.json +46 -46
@@ -1,89 +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
- }
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
+ }
@@ -1,68 +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
- }
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
+ }
@@ -1,29 +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>
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>
@@ -1,64 +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
- }
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
+ }
@@ -1,19 +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
- }
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
+ }