tango-app-ui-shared 3.7.3-dev6-demo7 → 3.7.3-dev6-demo9

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 (402) hide show
  1. package/esm2022/lib/guards/auth.guard.mjs +26 -0
  2. package/esm2022/lib/guards/lead.guard.mjs +16 -0
  3. package/esm2022/lib/guards/stores.guard.mjs +16 -0
  4. package/esm2022/lib/guards/tickets.guard.mjs +16 -0
  5. package/esm2022/lib/i18n/index.mjs +3 -0
  6. package/esm2022/lib/i18n/translation.module.mjs +17 -0
  7. package/esm2022/lib/i18n/translation.service.mjs +53 -0
  8. package/esm2022/lib/i18n/vocabs/ch.mjs +106 -0
  9. package/esm2022/lib/i18n/vocabs/de.mjs +106 -0
  10. package/esm2022/lib/i18n/vocabs/en.mjs +106 -0
  11. package/esm2022/lib/i18n/vocabs/es.mjs +106 -0
  12. package/esm2022/lib/i18n/vocabs/fr.mjs +106 -0
  13. package/esm2022/lib/i18n/vocabs/jp.mjs +106 -0
  14. package/esm2022/lib/interceptors/http-auth-interceptor.mjs +124 -0
  15. package/esm2022/lib/interfaces/global-state.mjs +2 -0
  16. package/esm2022/lib/modules/common/common-shared.module.mjs +31 -0
  17. package/esm2022/lib/modules/common/custom-select/custom-select.component.mjs +155 -0
  18. package/esm2022/lib/modules/common/filters/filters.component.mjs +179 -0
  19. package/esm2022/lib/modules/common/pagination/pagination.component.mjs +49 -0
  20. package/esm2022/lib/modules/errors/error403/error403.component.mjs +33 -0
  21. package/esm2022/lib/modules/errors/error404/error404.component.mjs +44 -0
  22. package/esm2022/lib/modules/errors/error500/error500.component.mjs +45 -0
  23. package/esm2022/lib/modules/errors/errors-routing.module.mjs +48 -0
  24. package/esm2022/lib/modules/errors/errors.component.mjs +39 -0
  25. package/esm2022/lib/modules/errors/errors.module.mjs +37 -0
  26. package/esm2022/lib/modules/errors/invalid-ip/invalid-ip.component.mjs +44 -0
  27. package/esm2022/lib/modules/intro/contact-support/contact-support.component.mjs +19 -0
  28. package/esm2022/lib/modules/intro/intro-routing.module.mjs +24 -0
  29. package/esm2022/lib/modules/intro/intro.module.mjs +32 -0
  30. package/esm2022/lib/modules/intro/lead-intro/lead-intro.component.mjs +110 -0
  31. package/esm2022/lib/modules/layout/components/csm-assign-confirmation/csm-assign-confirmation.component.mjs +31 -0
  32. package/esm2022/lib/modules/layout/content/content.component.mjs +107 -0
  33. package/esm2022/lib/modules/layout/footer/footer.component.mjs +17 -0
  34. package/esm2022/lib/modules/layout/header/header-menu/header-menu.component.mjs +41 -0
  35. package/esm2022/lib/modules/layout/header/header.component.mjs +100 -0
  36. package/esm2022/lib/modules/layout/header/navbar/navbar.component.mjs +256 -0
  37. package/esm2022/lib/modules/layout/header/notifications-inner/notifications-inner.component.mjs +79 -0
  38. package/esm2022/lib/modules/layout/header/page-title/page-title.component.mjs +56 -0
  39. package/esm2022/lib/modules/layout/keenicon/icons.json +1 -0
  40. package/esm2022/lib/modules/layout/keenicon/keenicon.component.mjs +37 -0
  41. package/esm2022/lib/modules/layout/layout/layout.component.mjs +314 -0
  42. package/esm2022/lib/modules/layout/layout.module.mjs +198 -0
  43. package/esm2022/lib/modules/layout/scripts-init/scripts-init.component.mjs +74 -0
  44. package/esm2022/lib/modules/layout/scroll-top/scroll-top.component.mjs +74 -0
  45. package/esm2022/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.mjs +159 -0
  46. package/esm2022/lib/modules/layout/sidebar/sidebar-logo/sidebar-logo.component.mjs +45 -0
  47. package/esm2022/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.mjs +122 -0
  48. package/esm2022/lib/modules/layout/sidebar/sidebar.component.mjs +134 -0
  49. package/esm2022/lib/modules/layout/toolbar/accounting/accounting.component.mjs +16 -0
  50. package/esm2022/lib/modules/layout/toolbar/classic/classic.component.mjs +331 -0
  51. package/esm2022/lib/modules/layout/toolbar/client-settings/client-settings.component.mjs +88 -0
  52. package/esm2022/lib/modules/layout/toolbar/date-single-select/date-single-select.component.mjs +207 -0
  53. package/esm2022/lib/modules/layout/toolbar/datepicker/datepicker.component.mjs +158 -0
  54. package/esm2022/lib/modules/layout/toolbar/extended/extended.component.mjs +15 -0
  55. package/esm2022/lib/modules/layout/toolbar/metrics-header/metrics-header.component.mjs +1321 -0
  56. package/esm2022/lib/modules/layout/toolbar/reports/reports.component.mjs +18 -0
  57. package/esm2022/lib/modules/layout/toolbar/saas/saas.component.mjs +18 -0
  58. package/esm2022/lib/modules/layout/toolbar/single-clientstore-date/single-clientstore-date.component.mjs +216 -0
  59. package/esm2022/lib/modules/layout/toolbar/single-store/single-store.component.mjs +178 -0
  60. package/esm2022/lib/modules/layout/toolbar/single-storedate/single-storedate.component.mjs +166 -0
  61. package/esm2022/lib/modules/layout/toolbar/storesingle/storesingle.component.mjs +105 -0
  62. package/esm2022/lib/modules/layout/toolbar/toolbar.component.mjs +372 -0
  63. package/esm2022/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.mjs +1062 -0
  64. package/esm2022/lib/modules/layout/toolbar/traffic-nob/traffic-nob.component.mjs +795 -0
  65. package/esm2022/lib/modules/layout/toolbar/trax-header/trax-header.component.mjs +880 -0
  66. package/esm2022/lib/modules/layout/toolbar/trax-withoutdate/trax-withoutdate.component.mjs +729 -0
  67. package/esm2022/lib/modules/layout/toolbar/zone-header/zone-header.component.mjs +1090 -0
  68. package/esm2022/lib/modules/notification/conformation/conformation.component.mjs +22 -0
  69. package/esm2022/lib/modules/notification/notification/notification.component.mjs +317 -0
  70. package/esm2022/lib/modules/notification/notification-routing.module.mjs +28 -0
  71. package/esm2022/lib/modules/notification/notification.module.mjs +32 -0
  72. package/esm2022/lib/pipes/customDate.pipe.mjs +22 -0
  73. package/esm2022/lib/routes/route-wraper-modules/edge-wrapper.module.mjs +18 -0
  74. package/esm2022/lib/routes/route-wraper-modules/manage-wrapper.module.mjs +18 -0
  75. package/esm2022/lib/routes/route-wraper-modules/profile-wrapper.module.mjs +18 -0
  76. package/esm2022/lib/routes/route-wraper-modules/store-wrapper.module.mjs +18 -0
  77. package/esm2022/lib/routes/route-wraper-modules/ticket-wrapper.module.mjs +18 -0
  78. package/esm2022/lib/routes/routing.mjs +53 -0
  79. package/esm2022/lib/services/auth.service.mjs +141 -0
  80. package/esm2022/lib/services/notification.service.mjs +74 -0
  81. package/esm2022/lib/services/toast.service.mjs +83 -0
  82. package/esm2022/public-api.mjs +56 -0
  83. package/esm2022/tango-app-ui-shared.mjs +5 -0
  84. package/fesm2022/tango-app-ui-shared-edge-wrapper.module-CFDk0tvS.mjs +21 -0
  85. package/fesm2022/tango-app-ui-shared-edge-wrapper.module-CFDk0tvS.mjs.map +1 -0
  86. package/fesm2022/tango-app-ui-shared-intro.module-DYh4ZRha.mjs +188 -0
  87. package/fesm2022/tango-app-ui-shared-intro.module-DYh4ZRha.mjs.map +1 -0
  88. package/fesm2022/tango-app-ui-shared-manage-wrapper.module-BHyh4Njw.mjs +21 -0
  89. package/fesm2022/tango-app-ui-shared-manage-wrapper.module-BHyh4Njw.mjs.map +1 -0
  90. package/fesm2022/tango-app-ui-shared-notification.module-C5ZmCf8U.mjs +400 -0
  91. package/fesm2022/tango-app-ui-shared-notification.module-C5ZmCf8U.mjs.map +1 -0
  92. package/fesm2022/tango-app-ui-shared-profile-wrapper.module-BNC1AGOk.mjs +21 -0
  93. package/fesm2022/tango-app-ui-shared-profile-wrapper.module-BNC1AGOk.mjs.map +1 -0
  94. package/fesm2022/tango-app-ui-shared-store-wrapper.module-DdaCYHdv.mjs +21 -0
  95. package/fesm2022/tango-app-ui-shared-store-wrapper.module-DdaCYHdv.mjs.map +1 -0
  96. package/fesm2022/tango-app-ui-shared-ticket-wrapper.module-r32uKkDO.mjs +21 -0
  97. package/fesm2022/tango-app-ui-shared-ticket-wrapper.module-r32uKkDO.mjs.map +1 -0
  98. package/fesm2022/tango-app-ui-shared.mjs +12440 -0
  99. package/fesm2022/tango-app-ui-shared.mjs.map +1 -0
  100. package/index.d.ts +5 -0
  101. package/lib/guards/auth.guard.d.ts +10 -0
  102. package/lib/guards/lead.guard.d.ts +2 -0
  103. package/lib/guards/stores.guard.d.ts +2 -0
  104. package/lib/guards/tickets.guard.d.ts +2 -0
  105. package/{src/lib/i18n/index.ts → lib/i18n/index.d.ts} +2 -2
  106. package/lib/i18n/translation.module.d.ts +8 -0
  107. package/lib/i18n/translation.service.d.ts +19 -0
  108. package/lib/i18n/vocabs/ch.d.ts +104 -0
  109. package/lib/i18n/vocabs/de.d.ts +104 -0
  110. package/lib/i18n/vocabs/en.d.ts +104 -0
  111. package/lib/i18n/vocabs/es.d.ts +104 -0
  112. package/lib/i18n/vocabs/fr.d.ts +104 -0
  113. package/lib/i18n/vocabs/jp.d.ts +104 -0
  114. package/lib/interceptors/http-auth-interceptor.d.ts +19 -0
  115. package/lib/interfaces/global-state.d.ts +5 -0
  116. package/lib/modules/common/common-shared.module.d.ts +13 -0
  117. package/lib/modules/common/custom-select/custom-select.component.d.ts +33 -0
  118. package/lib/modules/common/filters/filters.component.d.ts +38 -0
  119. package/lib/modules/common/pagination/pagination.component.d.ts +18 -0
  120. package/lib/modules/errors/error403/error403.component.d.ts +14 -0
  121. package/lib/modules/errors/error404/error404.component.d.ts +15 -0
  122. package/lib/modules/errors/error500/error500.component.d.ts +15 -0
  123. package/lib/modules/errors/errors-routing.module.d.ts +7 -0
  124. package/lib/modules/errors/errors.component.d.ts +13 -0
  125. package/lib/modules/errors/errors.module.d.ts +13 -0
  126. package/lib/modules/errors/invalid-ip/invalid-ip.component.d.ts +17 -0
  127. package/lib/modules/intro/contact-support/contact-support.component.d.ts +9 -0
  128. package/lib/modules/intro/intro-routing.module.d.ts +7 -0
  129. package/lib/modules/intro/intro.module.d.ts +11 -0
  130. package/lib/modules/intro/lead-intro/lead-intro.component.d.ts +31 -0
  131. package/lib/modules/layout/components/csm-assign-confirmation/csm-assign-confirmation.component.d.ts +13 -0
  132. package/lib/modules/layout/content/content.component.d.ts +25 -0
  133. package/lib/modules/layout/footer/footer.component.d.ts +8 -0
  134. package/lib/modules/layout/header/header-menu/header-menu.component.d.ts +18 -0
  135. package/lib/modules/layout/header/header.component.d.ts +30 -0
  136. package/lib/modules/layout/header/navbar/navbar.component.d.ts +45 -0
  137. package/lib/modules/layout/header/notifications-inner/notifications-inner.component.d.ts +25 -0
  138. package/lib/modules/layout/header/page-title/page-title.component.d.ts +23 -0
  139. package/lib/modules/layout/keenicon/keenicon.component.d.ts +13 -0
  140. package/lib/modules/layout/layout/layout.component.d.ts +82 -0
  141. package/lib/modules/layout/layout.module.d.ts +50 -0
  142. package/lib/modules/layout/scripts-init/scripts-init.component.d.ts +19 -0
  143. package/lib/modules/layout/scroll-top/scroll-top.component.d.ts +19 -0
  144. package/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.d.ts +45 -0
  145. package/lib/modules/layout/sidebar/sidebar-logo/sidebar-logo.component.d.ts +19 -0
  146. package/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.d.ts +26 -0
  147. package/lib/modules/layout/sidebar/sidebar.component.d.ts +36 -0
  148. package/lib/modules/layout/toolbar/accounting/accounting.component.d.ts +8 -0
  149. package/lib/modules/layout/toolbar/classic/classic.component.d.ts +48 -0
  150. package/lib/modules/layout/toolbar/client-settings/client-settings.component.d.ts +16 -0
  151. package/lib/modules/layout/toolbar/date-single-select/date-single-select.component.d.ts +28 -0
  152. package/lib/modules/layout/toolbar/datepicker/datepicker.component.d.ts +28 -0
  153. package/lib/modules/layout/toolbar/extended/extended.component.d.ts +8 -0
  154. package/lib/modules/layout/toolbar/metrics-header/metrics-header.component.d.ts +103 -0
  155. package/lib/modules/layout/toolbar/reports/reports.component.d.ts +9 -0
  156. package/lib/modules/layout/toolbar/saas/saas.component.d.ts +9 -0
  157. package/lib/modules/layout/toolbar/single-clientstore-date/single-clientstore-date.component.d.ts +32 -0
  158. package/lib/modules/layout/toolbar/single-store/single-store.component.d.ts +33 -0
  159. package/lib/modules/layout/toolbar/single-storedate/single-storedate.component.d.ts +34 -0
  160. package/lib/modules/layout/toolbar/storesingle/storesingle.component.d.ts +24 -0
  161. package/lib/modules/layout/toolbar/toolbar.component.d.ts +57 -0
  162. package/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.d.ts +93 -0
  163. package/lib/modules/layout/toolbar/traffic-nob/traffic-nob.component.d.ts +80 -0
  164. package/lib/modules/layout/toolbar/trax-header/trax-header.component.d.ts +83 -0
  165. package/lib/modules/layout/toolbar/trax-withoutdate/trax-withoutdate.component.d.ts +74 -0
  166. package/lib/modules/layout/toolbar/zone-header/zone-header.component.d.ts +97 -0
  167. package/lib/modules/notification/conformation/conformation.component.d.ts +10 -0
  168. package/lib/modules/notification/notification/notification.component.d.ts +63 -0
  169. package/lib/modules/notification/notification-routing.module.d.ts +7 -0
  170. package/lib/modules/notification/notification.module.d.ts +11 -0
  171. package/lib/pipes/customDate.pipe.d.ts +7 -0
  172. package/lib/routes/route-wraper-modules/edge-wrapper.module.d.ts +7 -0
  173. package/lib/routes/route-wraper-modules/manage-wrapper.module.d.ts +7 -0
  174. package/lib/routes/route-wraper-modules/profile-wrapper.module.d.ts +7 -0
  175. package/lib/routes/route-wraper-modules/store-wrapper.module.d.ts +7 -0
  176. package/lib/routes/route-wraper-modules/ticket-wrapper.module.d.ts +7 -0
  177. package/lib/routes/routing.d.ts +3 -0
  178. package/lib/services/auth.service.d.ts +49 -0
  179. package/lib/services/notification.service.d.ts +30 -0
  180. package/lib/services/toast.service.d.ts +10 -0
  181. package/package.json +25 -12
  182. package/{src/public-api.ts → public-api.d.ts} +44 -71
  183. package/.eslintrc.json +0 -37
  184. package/ng-package.json +0 -7
  185. package/src/lib/guards/auth.guard.ts +0 -20
  186. package/src/lib/guards/lead.guard.ts +0 -16
  187. package/src/lib/guards/stores.guard.ts +0 -16
  188. package/src/lib/guards/tickets.guard.ts +0 -16
  189. package/src/lib/i18n/translation.module.ts +0 -9
  190. package/src/lib/i18n/translation.service.ts +0 -61
  191. package/src/lib/i18n/vocabs/ch.ts +0 -105
  192. package/src/lib/i18n/vocabs/de.ts +0 -105
  193. package/src/lib/i18n/vocabs/en.ts +0 -105
  194. package/src/lib/i18n/vocabs/es.ts +0 -105
  195. package/src/lib/i18n/vocabs/fr.ts +0 -105
  196. package/src/lib/i18n/vocabs/jp.ts +0 -105
  197. package/src/lib/interceptors/http-auth-interceptor.ts +0 -225
  198. package/src/lib/interfaces/global-state.ts +0 -6
  199. package/src/lib/modules/common/common-shared.module.ts +0 -20
  200. package/src/lib/modules/common/custom-select/custom-select.component.html +0 -42
  201. package/src/lib/modules/common/custom-select/custom-select.component.scss +0 -131
  202. package/src/lib/modules/common/custom-select/custom-select.component.spec.ts +0 -23
  203. package/src/lib/modules/common/custom-select/custom-select.component.ts +0 -149
  204. package/src/lib/modules/common/filters/filters.component.html +0 -76
  205. package/src/lib/modules/common/filters/filters.component.scss +0 -131
  206. package/src/lib/modules/common/filters/filters.component.spec.ts +0 -23
  207. package/src/lib/modules/common/filters/filters.component.ts +0 -181
  208. package/src/lib/modules/common/pagination/pagination.component.html +0 -26
  209. package/src/lib/modules/common/pagination/pagination.component.scss +0 -63
  210. package/src/lib/modules/common/pagination/pagination.component.spec.ts +0 -23
  211. package/src/lib/modules/common/pagination/pagination.component.ts +0 -46
  212. package/src/lib/modules/errors/error403/error403.component.html +0 -25
  213. package/src/lib/modules/errors/error403/error403.component.scss +0 -0
  214. package/src/lib/modules/errors/error403/error403.component.spec.ts +0 -23
  215. package/src/lib/modules/errors/error403/error403.component.ts +0 -28
  216. package/src/lib/modules/errors/error404/error404.component.html +0 -24
  217. package/src/lib/modules/errors/error404/error404.component.scss +0 -0
  218. package/src/lib/modules/errors/error404/error404.component.spec.ts +0 -25
  219. package/src/lib/modules/errors/error404/error404.component.ts +0 -50
  220. package/src/lib/modules/errors/error500/error500.component.html +0 -24
  221. package/src/lib/modules/errors/error500/error500.component.scss +0 -0
  222. package/src/lib/modules/errors/error500/error500.component.spec.ts +0 -25
  223. package/src/lib/modules/errors/error500/error500.component.ts +0 -50
  224. package/src/lib/modules/errors/errors-routing.module.ts +0 -40
  225. package/src/lib/modules/errors/errors.component.html +0 -15
  226. package/src/lib/modules/errors/errors.component.scss +0 -4
  227. package/src/lib/modules/errors/errors.component.spec.ts +0 -25
  228. package/src/lib/modules/errors/errors.component.ts +0 -42
  229. package/src/lib/modules/errors/errors.module.ts +0 -25
  230. package/src/lib/modules/errors/invalid-ip/invalid-ip.component.html +0 -16
  231. package/src/lib/modules/errors/invalid-ip/invalid-ip.component.scss +0 -0
  232. package/src/lib/modules/errors/invalid-ip/invalid-ip.component.spec.ts +0 -23
  233. package/src/lib/modules/errors/invalid-ip/invalid-ip.component.ts +0 -43
  234. package/src/lib/modules/intro/contact-support/contact-support.component.html +0 -30
  235. package/src/lib/modules/intro/contact-support/contact-support.component.scss +0 -60
  236. package/src/lib/modules/intro/contact-support/contact-support.component.spec.ts +0 -23
  237. package/src/lib/modules/intro/contact-support/contact-support.component.ts +0 -17
  238. package/src/lib/modules/intro/intro-routing.module.ts +0 -16
  239. package/src/lib/modules/intro/intro.module.ts +0 -21
  240. package/src/lib/modules/intro/lead-intro/lead-intro.component.html +0 -325
  241. package/src/lib/modules/intro/lead-intro/lead-intro.component.scss +0 -185
  242. package/src/lib/modules/intro/lead-intro/lead-intro.component.spec.ts +0 -23
  243. package/src/lib/modules/intro/lead-intro/lead-intro.component.ts +0 -120
  244. package/src/lib/modules/layout/components/csm-assign-confirmation/csm-assign-confirmation.component.html +0 -44
  245. package/src/lib/modules/layout/components/csm-assign-confirmation/csm-assign-confirmation.component.scss +0 -28
  246. package/src/lib/modules/layout/components/csm-assign-confirmation/csm-assign-confirmation.component.spec.ts +0 -23
  247. package/src/lib/modules/layout/components/csm-assign-confirmation/csm-assign-confirmation.component.ts +0 -24
  248. package/src/lib/modules/layout/content/content.component.html +0 -12
  249. package/src/lib/modules/layout/content/content.component.scss +0 -0
  250. package/src/lib/modules/layout/content/content.component.ts +0 -102
  251. package/src/lib/modules/layout/footer/footer.component.html +0 -29
  252. package/src/lib/modules/layout/footer/footer.component.scss +0 -7
  253. package/src/lib/modules/layout/footer/footer.component.spec.ts +0 -25
  254. package/src/lib/modules/layout/footer/footer.component.ts +0 -13
  255. package/src/lib/modules/layout/header/header-menu/header-menu.component.html +0 -27
  256. package/src/lib/modules/layout/header/header-menu/header-menu.component.scss +0 -4
  257. package/src/lib/modules/layout/header/header-menu/header-menu.component.spec.ts +0 -25
  258. package/src/lib/modules/layout/header/header-menu/header-menu.component.ts +0 -38
  259. package/src/lib/modules/layout/header/header.component.html +0 -90
  260. package/src/lib/modules/layout/header/header.component.scss +0 -7
  261. package/src/lib/modules/layout/header/header.component.spec.ts +0 -25
  262. package/src/lib/modules/layout/header/header.component.ts +0 -139
  263. package/src/lib/modules/layout/header/navbar/navbar.component.html +0 -156
  264. package/src/lib/modules/layout/header/navbar/navbar.component.scss +0 -223
  265. package/src/lib/modules/layout/header/navbar/navbar.component.spec.ts +0 -23
  266. package/src/lib/modules/layout/header/navbar/navbar.component.ts +0 -255
  267. package/src/lib/modules/layout/header/notifications-inner/notifications-inner.component.html +0 -200
  268. package/src/lib/modules/layout/header/notifications-inner/notifications-inner.component.scss +0 -139
  269. package/src/lib/modules/layout/header/notifications-inner/notifications-inner.component.ts +0 -76
  270. package/src/lib/modules/layout/header/page-title/page-title.component.html +0 -32
  271. package/src/lib/modules/layout/header/page-title/page-title.component.scss +0 -11
  272. package/src/lib/modules/layout/header/page-title/page-title.component.ts +0 -47
  273. package/src/lib/modules/layout/keenicon/icons.json +0 -1
  274. package/src/lib/modules/layout/keenicon/keenicon.component.html +0 -4
  275. package/src/lib/modules/layout/keenicon/keenicon.component.scss +0 -0
  276. package/src/lib/modules/layout/keenicon/keenicon.component.spec.ts +0 -23
  277. package/src/lib/modules/layout/keenicon/keenicon.component.ts +0 -30
  278. package/src/lib/modules/layout/layout/layout.component.html +0 -71
  279. package/src/lib/modules/layout/layout/layout.component.scss +0 -23
  280. package/src/lib/modules/layout/layout/layout.component.ts +0 -425
  281. package/src/lib/modules/layout/layout.module.ts +0 -129
  282. package/src/lib/modules/layout/scripts-init/scripts-init.component.html +0 -0
  283. package/src/lib/modules/layout/scripts-init/scripts-init.component.ts +0 -81
  284. package/src/lib/modules/layout/scroll-top/scroll-top.component.html +0 -1
  285. package/src/lib/modules/layout/scroll-top/scroll-top.component.ts +0 -75
  286. package/src/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.html +0 -70
  287. package/src/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.scss +0 -57
  288. package/src/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.spec.ts +0 -23
  289. package/src/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.ts +0 -136
  290. package/src/lib/modules/layout/sidebar/sidebar-logo/sidebar-logo.component.html +0 -26
  291. package/src/lib/modules/layout/sidebar/sidebar-logo/sidebar-logo.component.scss +0 -0
  292. package/src/lib/modules/layout/sidebar/sidebar-logo/sidebar-logo.component.spec.ts +0 -23
  293. package/src/lib/modules/layout/sidebar/sidebar-logo/sidebar-logo.component.ts +0 -36
  294. package/src/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.html +0 -761
  295. package/src/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.scss +0 -38
  296. package/src/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.spec.ts +0 -23
  297. package/src/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.ts +0 -130
  298. package/src/lib/modules/layout/sidebar/sidebar.component.html +0 -16
  299. package/src/lib/modules/layout/sidebar/sidebar.component.scss +0 -3
  300. package/src/lib/modules/layout/sidebar/sidebar.component.spec.ts +0 -23
  301. package/src/lib/modules/layout/sidebar/sidebar.component.ts +0 -203
  302. package/src/lib/modules/layout/toolbar/accounting/accounting.component.html +0 -84
  303. package/src/lib/modules/layout/toolbar/accounting/accounting.component.scss +0 -0
  304. package/src/lib/modules/layout/toolbar/accounting/accounting.component.spec.ts +0 -23
  305. package/src/lib/modules/layout/toolbar/accounting/accounting.component.ts +0 -14
  306. package/src/lib/modules/layout/toolbar/classic/classic.component.html +0 -69
  307. package/src/lib/modules/layout/toolbar/classic/classic.component.scss +0 -238
  308. package/src/lib/modules/layout/toolbar/classic/classic.component.spec.ts +0 -23
  309. package/src/lib/modules/layout/toolbar/classic/classic.component.ts +0 -389
  310. package/src/lib/modules/layout/toolbar/client-settings/client-settings.component.html +0 -4
  311. package/src/lib/modules/layout/toolbar/client-settings/client-settings.component.scss +0 -3
  312. package/src/lib/modules/layout/toolbar/client-settings/client-settings.component.spec.ts +0 -23
  313. package/src/lib/modules/layout/toolbar/client-settings/client-settings.component.ts +0 -91
  314. package/src/lib/modules/layout/toolbar/date-single-select/date-single-select.component.html +0 -22
  315. package/src/lib/modules/layout/toolbar/date-single-select/date-single-select.component.scss +0 -156
  316. package/src/lib/modules/layout/toolbar/date-single-select/date-single-select.component.spec.ts +0 -23
  317. package/src/lib/modules/layout/toolbar/date-single-select/date-single-select.component.ts +0 -238
  318. package/src/lib/modules/layout/toolbar/datepicker/datepicker.component.html +0 -14
  319. package/src/lib/modules/layout/toolbar/datepicker/datepicker.component.scss +0 -149
  320. package/src/lib/modules/layout/toolbar/datepicker/datepicker.component.spec.ts +0 -23
  321. package/src/lib/modules/layout/toolbar/datepicker/datepicker.component.ts +0 -183
  322. package/src/lib/modules/layout/toolbar/extended/extended.component.html +0 -100
  323. package/src/lib/modules/layout/toolbar/extended/extended.component.scss +0 -0
  324. package/src/lib/modules/layout/toolbar/extended/extended.component.spec.ts +0 -23
  325. package/src/lib/modules/layout/toolbar/extended/extended.component.ts +0 -12
  326. package/src/lib/modules/layout/toolbar/metrics-header/metrics-header.component.html +0 -311
  327. package/src/lib/modules/layout/toolbar/metrics-header/metrics-header.component.scss +0 -311
  328. package/src/lib/modules/layout/toolbar/metrics-header/metrics-header.component.spec.ts +0 -23
  329. package/src/lib/modules/layout/toolbar/metrics-header/metrics-header.component.ts +0 -1555
  330. package/src/lib/modules/layout/toolbar/reports/reports.component.html +0 -62
  331. package/src/lib/modules/layout/toolbar/reports/reports.component.scss +0 -0
  332. package/src/lib/modules/layout/toolbar/reports/reports.component.spec.ts +0 -23
  333. package/src/lib/modules/layout/toolbar/reports/reports.component.ts +0 -14
  334. package/src/lib/modules/layout/toolbar/saas/saas.component.html +0 -77
  335. package/src/lib/modules/layout/toolbar/saas/saas.component.scss +0 -0
  336. package/src/lib/modules/layout/toolbar/saas/saas.component.spec.ts +0 -23
  337. package/src/lib/modules/layout/toolbar/saas/saas.component.ts +0 -14
  338. package/src/lib/modules/layout/toolbar/single-clientstore-date/single-clientstore-date.component.html +0 -26
  339. package/src/lib/modules/layout/toolbar/single-clientstore-date/single-clientstore-date.component.scss +0 -176
  340. package/src/lib/modules/layout/toolbar/single-clientstore-date/single-clientstore-date.component.spec.ts +0 -23
  341. package/src/lib/modules/layout/toolbar/single-clientstore-date/single-clientstore-date.component.ts +0 -235
  342. package/src/lib/modules/layout/toolbar/single-store/single-store.component.html +0 -39
  343. package/src/lib/modules/layout/toolbar/single-store/single-store.component.scss +0 -176
  344. package/src/lib/modules/layout/toolbar/single-store/single-store.component.spec.ts +0 -23
  345. package/src/lib/modules/layout/toolbar/single-store/single-store.component.ts +0 -188
  346. package/src/lib/modules/layout/toolbar/single-storedate/single-storedate.component.html +0 -17
  347. package/src/lib/modules/layout/toolbar/single-storedate/single-storedate.component.scss +0 -172
  348. package/src/lib/modules/layout/toolbar/single-storedate/single-storedate.component.spec.ts +0 -23
  349. package/src/lib/modules/layout/toolbar/single-storedate/single-storedate.component.ts +0 -179
  350. package/src/lib/modules/layout/toolbar/storesingle/storesingle.component.html +0 -4
  351. package/src/lib/modules/layout/toolbar/storesingle/storesingle.component.scss +0 -19
  352. package/src/lib/modules/layout/toolbar/storesingle/storesingle.component.spec.ts +0 -23
  353. package/src/lib/modules/layout/toolbar/storesingle/storesingle.component.ts +0 -105
  354. package/src/lib/modules/layout/toolbar/toolbar.component.html +0 -64
  355. package/src/lib/modules/layout/toolbar/toolbar.component.scss +0 -0
  356. package/src/lib/modules/layout/toolbar/toolbar.component.spec.ts +0 -25
  357. package/src/lib/modules/layout/toolbar/toolbar.component.ts +0 -400
  358. package/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.html +0 -259
  359. package/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.scss +0 -305
  360. package/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.spec.ts +0 -23
  361. package/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.ts +0 -1202
  362. package/src/lib/modules/layout/toolbar/traffic-nob/traffic-nob.component.html +0 -199
  363. package/src/lib/modules/layout/toolbar/traffic-nob/traffic-nob.component.scss +0 -311
  364. package/src/lib/modules/layout/toolbar/traffic-nob/traffic-nob.component.spec.ts +0 -23
  365. package/src/lib/modules/layout/toolbar/traffic-nob/traffic-nob.component.ts +0 -899
  366. package/src/lib/modules/layout/toolbar/trax-header/trax-header.component.html +0 -204
  367. package/src/lib/modules/layout/toolbar/trax-header/trax-header.component.scss +0 -311
  368. package/src/lib/modules/layout/toolbar/trax-header/trax-header.component.spec.ts +0 -23
  369. package/src/lib/modules/layout/toolbar/trax-header/trax-header.component.ts +0 -1045
  370. package/src/lib/modules/layout/toolbar/trax-withoutdate/trax-withoutdate.component.html +0 -190
  371. package/src/lib/modules/layout/toolbar/trax-withoutdate/trax-withoutdate.component.scss +0 -311
  372. package/src/lib/modules/layout/toolbar/trax-withoutdate/trax-withoutdate.component.spec.ts +0 -23
  373. package/src/lib/modules/layout/toolbar/trax-withoutdate/trax-withoutdate.component.ts +0 -825
  374. package/src/lib/modules/layout/toolbar/zone-header/zone-header.component.html +0 -259
  375. package/src/lib/modules/layout/toolbar/zone-header/zone-header.component.scss +0 -305
  376. package/src/lib/modules/layout/toolbar/zone-header/zone-header.component.spec.ts +0 -23
  377. package/src/lib/modules/layout/toolbar/zone-header/zone-header.component.ts +0 -1242
  378. package/src/lib/modules/notification/conformation/conformation.component.html +0 -25
  379. package/src/lib/modules/notification/conformation/conformation.component.scss +0 -0
  380. package/src/lib/modules/notification/conformation/conformation.component.spec.ts +0 -23
  381. package/src/lib/modules/notification/conformation/conformation.component.ts +0 -23
  382. package/src/lib/modules/notification/notification/notification.component.html +0 -209
  383. package/src/lib/modules/notification/notification/notification.component.scss +0 -211
  384. package/src/lib/modules/notification/notification/notification.component.spec.ts +0 -23
  385. package/src/lib/modules/notification/notification/notification.component.ts +0 -310
  386. package/src/lib/modules/notification/notification-routing.module.ts +0 -20
  387. package/src/lib/modules/notification/notification.module.ts +0 -21
  388. package/src/lib/pipes/customDate.pipe.ts +0 -18
  389. package/src/lib/routes/route-wraper-modules/analyse-wrapper.module.ts +0 -12
  390. package/src/lib/routes/route-wraper-modules/edge-wrapper.module.ts +0 -11
  391. package/src/lib/routes/route-wraper-modules/manage-wrapper.module.ts +0 -11
  392. package/src/lib/routes/route-wraper-modules/profile-wrapper.module.ts +0 -12
  393. package/src/lib/routes/route-wraper-modules/store-wrapper.module.ts +0 -11
  394. package/src/lib/routes/route-wraper-modules/ticket-wrapper.module.ts +0 -10
  395. package/src/lib/routes/routing.ts +0 -56
  396. package/src/lib/services/auth.service.ts +0 -178
  397. package/src/lib/services/notification.service.spec.ts +0 -16
  398. package/src/lib/services/notification.service.ts +0 -73
  399. package/src/lib/services/toast.service.ts +0 -82
  400. package/tsconfig.lib.json +0 -14
  401. package/tsconfig.lib.prod.json +0 -10
  402. package/tsconfig.spec.json +0 -14
@@ -1,825 +0,0 @@
1
- import {
2
- ChangeDetectorRef,
3
- Component,
4
- HostListener,
5
- OnInit,
6
- } from "@angular/core";
7
- import dayjs from "dayjs";
8
- import "dayjs/locale/en";
9
- import { GlobalStateService } from "tango-app-ui-global";
10
- import { Router } from "@angular/router";
11
- import { AuthService } from "../../../../services/auth.service";
12
-
13
- @Component({
14
- selector: 'lib-trax-withoutdate',
15
- templateUrl: './trax-withoutdate.component.html',
16
- styleUrl: './trax-withoutdate.component.scss'
17
- })
18
- export class TraxWithoutdateComponent implements OnInit {
19
- dayjs = dayjs;
20
- isCustomDate = (m: dayjs.Dayjs) => {
21
- const isValidDate = m > this.dayjs();
22
- return isValidDate ? "invalid-date" : false;
23
- };
24
-
25
- selectedDateRange: any = { startDate: dayjs().subtract(30, 'days'),
26
- endDate: dayjs().subtract(1, "days"),};
27
- selectedFilters: any = {
28
- client: null,
29
- clientName: null,
30
- clients: [],
31
- store: null,
32
- stores: [],
33
- date: null,
34
- group: [],
35
- location: [],
36
- };
37
- Opendropdown: boolean = false;
38
- dropdownOpen: string | null = null; // 'location' or 'group'
39
- searchLocationText: string = "";
40
- searchGroupText: string = "";
41
- locations: any[] = [];
42
- filteredLocations: any[] = [];
43
- groupsData: any[] = [];
44
- filteredGroups: any[] = [];
45
- filteredStores: any[] = [];
46
- stores:any[] = []
47
- searchStoreText:string = '';
48
- clientList:any = []
49
- selectedClient:any
50
- locationLabel: any[]=[];
51
- groupLabel: any[]=[];
52
- users: any;
53
- url: any;
54
- constructor(
55
- private auth: AuthService,private router: Router,
56
- public gs: GlobalStateService,
57
- private cd: ChangeDetectorRef,
58
- ) {}
59
-
60
- @HostListener('document:click', ['$event'])
61
- onClick (event: MouseEvent) {
62
- const target = event.target as HTMLElement;
63
- if(!target.closest('.dropdown1')) {
64
- this.Opendropdown = false;
65
- }
66
- }
67
- closeDropdown1(){
68
- this.Opendropdown = false;
69
- }
70
- ngOnInit(): void {
71
- this.url = this.router.url.split("?")[0].split('/');
72
- const user = JSON.parse(localStorage.getItem('user-info') as string);
73
- this.users = user;
74
- this.gs?.manageRefreshTrigger?.subscribe((e) => {
75
- if (e) {
76
- if (user.userType === 'tango') {
77
- this.getClient();
78
- } else{
79
- const storedFilters = localStorage.getItem("header-filters");
80
- if (storedFilters) {
81
- const headerFilters = JSON.parse(storedFilters);
82
- this.filteredStores = headerFilters?.stores.map((store:any) => ({
83
- ...store,
84
- checked: store.checked
85
- }));
86
- }
87
- }
88
- }
89
- });
90
-
91
- if (user.userType === 'tango') {
92
- this.getClient();
93
- } else {
94
- this.getLocations();
95
- this.getGroups();
96
- this.getStore();
97
- }
98
-
99
- const storedFilters = localStorage.getItem("header-filters");
100
- if (storedFilters) {
101
- const headerFilters = JSON.parse(storedFilters);
102
-
103
- // Initialize selectedFilters with defaults or existing values
104
- this.selectedFilters = {
105
- client: headerFilters.client || this.users.client,
106
- clientName: headerFilters.clientName || '',
107
- clients: headerFilters.clients || [],
108
- store: headerFilters.store || null,
109
- date: headerFilters.date || {},
110
- stores: headerFilters.stores || [],
111
- group: headerFilters.group || [],
112
- location: headerFilters.location || []
113
- };
114
-
115
- // Sync filtered data with stored selections
116
- this.filteredLocations = this.syncWithLocalStorage(headerFilters.location);
117
- this.filteredGroups = this.syncWithLocalStorage(headerFilters.group);
118
- this.filteredStores = this.syncWithLocalStorage(headerFilters.stores);
119
- // Format date range if it exists
120
- // Emit data via service and update localStorage
121
- this.emitAndStoreFilters();
122
- } else {
123
- // Initialize empty states if no header filters are present in localStorage
124
- this.resetFilters();
125
- }
126
- }
127
- private syncWithLocalStorage(items: any[]): any[] {
128
- return items
129
- ? items.map((item: any) => ({
130
- ...item,
131
- checked: item.checked === true
132
- }))
133
- : [];
134
- }
135
- private emitAndStoreFilters(): void {
136
- this.gs.dataRangeValue.next(this.selectedFilters);
137
- localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
138
- }
139
-
140
- private resetFilters(): void {
141
- this.selectedFilters = {
142
- client: null,
143
- clientName: '',
144
- clients: [],
145
- store: null,
146
- date: {},
147
- stores: [],
148
- group: [],
149
- location: []
150
- };
151
- this.filteredLocations = [];
152
- this.filteredGroups = [];
153
- this.filteredStores = [];
154
- }
155
- getClient(){
156
- this.auth.getClients().subscribe({
157
- next: (e) => {
158
- if (e) {
159
- this.clientList = e.data.result;
160
- const headerFilters: any = JSON.parse(
161
- localStorage.getItem("header-filters") || "{}"
162
- );
163
- if (headerFilters.client) {
164
- this.clientList.find((obj: any) => {
165
- if (obj.clientId === headerFilters.client) {
166
- this.selectedClient = obj;
167
- }
168
- });
169
-
170
- this.selectedFilters.client = headerFilters.client;
171
- this.selectedFilters.clientName = headerFilters.clientName;
172
- this.selectedFilters.clients = headerFilters.clients;
173
- this.selectedFilters.store = headerFilters.store;
174
- this.selectedFilters.date = headerFilters.date;
175
- this.selectedFilters.stores = headerFilters.stores;
176
- this.selectedFilters.group = headerFilters.group;
177
- this.selectedFilters.location = headerFilters.location;
178
- this.gs.dataRangeValue.next(this.selectedFilters);
179
- // Ensure locations and groups are loaded before fetching stores
180
- this.getLocations();
181
- this.getGroups();
182
- // Fetch stores only after locations and groups are set
183
- this.getStore();
184
- } else {
185
- this.selectedClient = this.clientList[0];
186
- this.selectedFilters.client = this.selectedClient.clientId;
187
- this.selectedFilters.clientName = this.selectedClient.clientName
188
- this.selectedFilters.clients = headerFilters.clients;
189
- this.selectedFilters.store = headerFilters.store;
190
- this.selectedFilters.date = headerFilters.date;
191
- this.selectedFilters.stores = headerFilters.stores;
192
- this.selectedFilters.group = headerFilters.group;
193
- this.selectedFilters.location = headerFilters.location;
194
- localStorage.setItem(
195
- "header-filters",
196
- JSON.stringify(this.selectedFilters)
197
- );
198
- this.gs.dataRangeValue.next(this.selectedFilters);
199
- this.cd.detectChanges();
200
- // Ensure locations and groups are loaded before fetching stores
201
- this.getLocations();
202
- this.getGroups();
203
- // Fetch stores only after locations and groups are set
204
- this.getStore();
205
- }
206
-
207
-
208
- } else {
209
- this.selectedClient = this.clientList[0];
210
- this.selectedFilters.client = this.selectedClient.clientId;
211
- this.selectedFilters.clientName = this.selectedClient.clientName
212
- // Ensure locations and groups are loaded before fetching stores
213
- this.getLocations();
214
- this.getGroups();
215
- // Fetch stores only after locations and groups are set
216
- this.getStore();
217
- localStorage.setItem(
218
- "header-filters",
219
- JSON.stringify(this.selectedFilters)
220
- );
221
- this.gs.dataRangeValue.next(this.selectedFilters);
222
- // console.log("4")
223
- this.cd.detectChanges();
224
- }
225
- },
226
- });
227
- }
228
- onClientSelect(event: any): void {
229
- // Update the selected client
230
- this.selectedClient = event;
231
- // Clear previous filtered data and selections
232
- this.filteredGroups = [];
233
- this.filteredStores = [];
234
- this.filteredLocations = [];
235
- this.selectedFilters.stores = [];
236
- this.selectedFilters.group = [];
237
- this.selectedFilters.location = [];
238
-
239
- // Fetch header filters from localStorage
240
- const headerFilters: any = JSON.parse(localStorage.getItem("header-filters") || "{}");
241
-
242
- // Update the selected filters with the new client
243
- this.selectedFilters.client = this.selectedClient.clientId;
244
- this.selectedFilters.clientName = this.selectedClient.clientName;
245
-
246
- // Remove old store, group, and location data from the header filters
247
- delete headerFilters.stores;
248
- delete headerFilters.groups;
249
- delete headerFilters.location;
250
-
251
- // Fetch new data based on the new client
252
- this.getLocations();
253
- this.getStore();
254
- this.getGroups();
255
-
256
- // Update localStorage with the new client selection and empty filter data
257
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
258
- window.location.reload()
259
- this.cd.detectChanges();
260
- }
261
-
262
-
263
-
264
-
265
-
266
-
267
-
268
- opendropdown(e:MouseEvent) {
269
- e.stopPropagation();
270
- this.Opendropdown = !this.Opendropdown;
271
- }
272
- getLocations(): void {
273
- // const headerFilters: any = JSON.parse(localStorage.getItem("header-filters") || "{}");
274
- let obj ={
275
- clientId: this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId,
276
- city: [],
277
- group: [],
278
- }
279
- this.auth.getLocation(obj).subscribe({
280
- next: (res: any) => {
281
- let cityList = this.selectedFilters?.location?.filter((location:any) => location.checked).map((loc:any) => loc.city);
282
- // Map the fetched locations with default unchecked state
283
- this.locations = res?.data?.locationData.map((city: any) => ({
284
- city: city.city,
285
- checked: cityList?.includes(city.city) ? true : false,
286
- }));
287
-
288
- // Sync the fetched locations with any stored checked values in localStorage
289
- if (this.selectedFilters.location && Array.isArray(this.selectedFilters.location)) {
290
- this.filteredLocations = this.locations.map(location => {
291
- const matchedLocation = this.selectedFilters.location.find((loc: any) => loc.city === location.city);
292
- return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;
293
- });
294
- } else {
295
- this.filteredLocations = this.locations;
296
- }
297
-
298
- if(this.searchLocationText) {
299
- this.filteredLocations = this.locations.filter((location:any) => location.city.toLowerCase().includes(this.searchLocationText.toLowerCase()))
300
- }
301
- const selectedLocations = this.locations.filter((location) => location.checked).map((location) => location.city);
302
- if (selectedLocations.length > 0) {
303
- setTimeout(()=>{
304
- this.getStore(); // Fetch stores based on selected groups
305
- },1000)
306
- }
307
- },
308
- error: (err) => {
309
- console.error("Failed to fetch locations", err);
310
- },
311
- });
312
- }
313
-
314
- isAllLocationsSelected(): boolean {
315
- return this.filteredLocations.every(location => location.checked);
316
-
317
- }
318
-
319
- selectedLocationsLabel(): string {
320
- const selectedLocations = this.locationLabel = this.searchLocationText.length ? this.locations
321
- .filter(location => location.checked).map(location => location.city) : this.filteredLocations
322
- .filter(location => location.checked).map(location => location.city);
323
- return selectedLocations.length === 0
324
- ? ''
325
- : selectedLocations.length === 1
326
- ? selectedLocations[0]
327
- : `${selectedLocations.length} locations`;
328
- }
329
-
330
- removeLocation(): void {
331
- this.Reset();
332
- }
333
-
334
- getGroups(): void {
335
- const city = this.locations
336
- .filter(location => location.checked)
337
- .map(location => location.city);
338
- const obj = { city,clientId:this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId,group:[] };
339
- this.auth.getGroups(obj).subscribe({
340
- next: (res: any) => {
341
- let checkedGroup = this.selectedFilters?.group?.filter((group:any) => group.checked).map((group:any) => group.groupName);
342
- const combinedGroups = res?.data?.groupData?.map((groupName: any) => ({
343
- groupName: groupName.groupName,
344
- checked: checkedGroup?.includes(groupName.groupName) ? true : false,
345
- }));
346
- this.groupsData = combinedGroups;
347
- if(this.searchGroupText.length) {
348
- this.filteredGroups = combinedGroups.filter((item:any) => item.groupName.toLowerCase().includes(this.searchGroupText));
349
- }
350
- else {
351
- this.filteredGroups = combinedGroups;
352
- }
353
-
354
- // Auto-fetch stores when groups are selected
355
- const selectedGroups = this.groupsData.filter((group) => group.checked).map((group) => group.groupName);
356
- if (selectedGroups.length > 0) {
357
- setTimeout(()=>{
358
- this.getStore(); // Fetch stores based on selected groups
359
- },1000)
360
- }
361
- },
362
- error: (err) => {
363
- console.error("Failed to fetch groups", err);
364
- },
365
- });
366
- }
367
-
368
- toggleDropdown(type: 'location' | 'group' | 'store'): void {
369
- if (this.dropdownOpen === type) {
370
- // If the dropdown is open, close it and avoid resetting the selected values unnecessarily
371
- this.dropdownOpen = null;
372
- } else {
373
- // Open the specific dropdown and handle data fetching only if necessary
374
- this.dropdownOpen = type;
375
-
376
- if (type === 'group') {
377
- // Fetch groups only if there are selected cities and no active search text
378
- const selectedCities = this.locations
379
- .filter((location) => location.checked)
380
- .map((location) => location.city);
381
-
382
- // Fetch groups only if locations are selected, no search text exists, and dropdown is opened
383
- if (this.filteredLocations.length > 0 || (selectedCities.length > 0 && !this.searchGroupText.trim())) {
384
- this.getGroups();
385
- } else {
386
- this.filteredGroups = []; // Clear groups if no locations are selected
387
- }
388
- }
389
-
390
- if (type === 'store') {
391
- // Fetch stores only if not already fetched and no search text is active
392
- if ((!this.filteredStores || this.filteredStores.length === 0) && !this.searchStoreText.trim()) {
393
- this.getStore();
394
- }
395
- }
396
- }
397
- }
398
-
399
-
400
- handleGroupDropdownClick(): void {
401
- if (this.dropdownOpen === 'group') {
402
- this.resetSelectedGroups();
403
- }
404
- this.toggleDropdown('group');
405
- }
406
-
407
- resetSelectedGroups(): void {
408
- this.filteredGroups.forEach((group) => (group.checked = false));
409
- this.searchGroupText = "";
410
- }
411
- selectedGroupsLabel(): string {
412
- const selectedGroups = this.groupLabel = this.searchGroupText.length ? this.groupsData.filter((group) => group.checked) : this.filteredGroups.filter((group) => group.checked);
413
- return selectedGroups.length === 0
414
- ? ""
415
- : selectedGroups.length === 1
416
- ? selectedGroups[0].groupName
417
- : `${selectedGroups.length} Clusters`;
418
- }
419
- removeGroup(): void {
420
- this.Reset();
421
-
422
- }
423
-
424
-
425
- isAllGroupsSelected(): boolean {
426
-
427
- return this.filteredGroups.length ? this.filteredGroups.every((group) => group.checked) : false;
428
- }
429
-
430
- getStore(): void {
431
- const city = this.locations
432
- .filter(location => location.checked)
433
- .map(location => location.city);
434
-
435
- const group = this.groupsData
436
- .filter(group => group.checked)
437
- .map(group => group.groupName);
438
-
439
- const data = { city, clusters:group, clientId: this.users.clientId ? this.users.clientId : this.selectedFilters.client };
440
-
441
- this.auth.getHeadertraxStores(data).subscribe({
442
- next: (res: any) => {
443
- if(res &&res.code ===200){
444
- this.stores = res.data.storesData;
445
- // Retrieve checked store IDs from selectedFilters
446
- const checkedStoreIds = this.selectedFilters?.stores
447
- ? this.selectedFilters.stores.filter((store: any) => store.checked).map((store: any) => store.storeId)
448
- : [];
449
-
450
- this.stores.forEach(store => {
451
- if (checkedStoreIds.includes(store.storeId)) {
452
- store.checked = true; // Sync the checked state with full store list
453
- }
454
- });
455
-
456
-
457
- // Map the stores and retain the 'checked' status
458
- if(this.searchStoreText.length) {
459
- this.filteredStores = this.stores?.filter(store => store.storeName.toLowerCase().includes(this.searchStoreText));
460
- }
461
- else {
462
- this.filteredStores = this.stores;
463
- }
464
- // Ensure selectedFilters is in sync with filteredStores
465
- if (!this.selectedFilters.stores || !this.selectedFilters.stores.length) {
466
- this.stores.forEach(store => {
467
- store.checked = true; // Sync the checked state with full store list
468
- });
469
-
470
- // No previously selected stores, mark all as checked
471
- this.filteredStores = this.selectedFilters.stores = this.filteredStores.map(store => ({
472
- ...store,
473
- checked: true
474
- }));
475
- } else {
476
- // Update selectedFilters to reflect current state of stores
477
- this.selectedFilters.stores = this.filteredStores.map(store => ({
478
- ...store,
479
- checked: store.checked
480
- }));
481
- }
482
- // Update localStorage with the latest selectedFilters
483
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
484
-
485
- // Emit data via service
486
- // this.gs.dataRangeValue.next(this.selectedFilters);
487
- // Trigger change detection to reflect changes in the UI
488
- this.cd.detectChanges();
489
- } else {
490
- this.stores =[];
491
- this.selectedFilters.stores=[];
492
- this.filteredStores =[];
493
- this.selectedFilters.stores = this.filteredStores.map(store => ({
494
- ...store,
495
- checked: false
496
- }));
497
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
498
- }
499
- },
500
- error: (err) => {
501
- this.stores =[];
502
- this.selectedFilters.stores=[];
503
- this.filteredStores =[];
504
- this.selectedFilters.stores = this.filteredStores.map(store => ({
505
- ...store,
506
- checked: false
507
- }));
508
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
509
- console.error("Failed to fetch stores", err);
510
- },
511
- });
512
- }
513
-
514
-
515
- resetSelectedStores(): void {
516
- this.filteredStores.forEach((store) => (store.checked = false));
517
- this.searchStoreText = "";
518
- }
519
-
520
- selectedStoresLabel(): string {
521
- const selectedStores = this.searchStoreText.length ? this.stores.filter((store) => store.checked) : this.filteredStores.filter((store) => store.checked);
522
- return selectedStores.length === 0
523
- ? "0 Stores"
524
- : selectedStores.length === 1
525
- ? selectedStores[0].storeName
526
- : `${selectedStores.length} Stores`;
527
- }
528
-
529
- isAllStoresSelected(): boolean {
530
- return this.filteredStores.length > 0 && this.filteredStores.every(store => store.checked);
531
- }
532
- // Method to handle dropdown item selection
533
- updateSelectedStores(): void {
534
- this.filteredStores.forEach(store => {
535
- const filteredStore = this.stores.findIndex(fStore => fStore.storeId === store.storeId);
536
- if (filteredStore != -1) {
537
- this.stores[filteredStore].checked = store.checked; // Sync the checked state with full store list
538
- }
539
- });
540
- // Update selectedFilters based on the current store selection
541
- this.selectedFilters.stores = this.stores.filter(store => store.checked);
542
-
543
- // Update localStorage with the latest selection
544
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
545
-
546
- // Emit updated filters via service
547
- // this.gs.dataRangeValue.next(this.selectedFilters);
548
-
549
- // Trigger change detection if necessary
550
- this.cd.detectChanges();
551
- }
552
- toggleSelectAllLocations(event: any): void {
553
- const isChecked = event.target.checked;
554
- this.filteredLocations.forEach((location) => (location.checked = isChecked));
555
- this.updateSelectedLocations();
556
- }
557
-
558
- toggleSelectAllStores(event: Event): void {
559
- const checked = (event.target as HTMLInputElement).checked;
560
-
561
- // Apply the selection to both filtered and full list of stores
562
- this.filteredStores.forEach(store => store.checked = checked);
563
- this.stores.forEach(store => {
564
- const filteredStore = this.filteredStores.find(fStore => fStore.storeId === store.storeId);
565
- if (filteredStore) {
566
- store.checked = checked; // Sync the checked state with full store list
567
- }
568
- });
569
-
570
- // Update the selected stores and persist the selection
571
- this.updateSelectedStores();
572
- }
573
-
574
- updateSelectedLocations(): void {
575
- // When locations are selected, fetch the related groups
576
- const selectedCities = this.filteredLocations
577
- .filter((location) => location.checked)
578
- .map((location) => location.city);
579
- this.filteredLocations.forEach((location:any) => {
580
- let findLocationIndex = this.locations.findIndex((loc:any) => loc.city == location.city);
581
- if(findLocationIndex != -1) {
582
- this.locations[findLocationIndex].checked = location.checked;
583
- }
584
- })
585
- if (selectedCities.length > 0 || !selectedCities.length) {
586
- this.selectedFilters.stores =[];
587
- this.groupsData =[]
588
- this.getGroups(); // Fetch groups based on selected cities
589
- // If there are selected groups, fetch the stores based on selected groups
590
- this.getStore();
591
- this.selectedFilters.location = this.locations;
592
-
593
- } else {
594
- this.filteredGroups = []; // Clear groups if no locations are selected
595
- this.selectedFilters.location = [];
596
- }
597
-
598
- this.selectedFilters.group = [];
599
- this.filteredStores = []; // Reset stores as well
600
- this.searchGroupText = '';
601
- this.searchStoreText = '';
602
- // this.Opendropdown = false;
603
- }
604
-
605
- toggleSelectAllGroups(event: any): void {
606
- const isChecked = event.target.checked;
607
- this.filteredGroups.forEach((group) => (group.checked = isChecked));
608
- this.updateSelectedGroups();
609
- // if (!isChecked) {
610
- // this.selectedFilters.stores =[];
611
- // // If there are selected groups, fetch the stores based on selected groups
612
- // this.getStore();
613
- // }
614
- }
615
-
616
- updateSelectedGroups(): void {
617
- // Fetch the relevant stores after groups are selected
618
- const selectedGroups = this.filteredGroups
619
- .filter((group) => group.checked)
620
- .map((group) => group.groupName);
621
-
622
- this.filteredGroups.forEach((group:any) => {
623
- let findGroupIndex = this.groupsData.findIndex((item:any) => item.groupName == group.groupName);
624
- if(findGroupIndex != -1) {
625
- this.groupsData[findGroupIndex].checked = group.checked;
626
- }
627
- })
628
- if (selectedGroups.length > 0 || !selectedGroups.length) {
629
- this.selectedFilters.stores =[];
630
- // If there are selected groups, fetch the stores based on selected groups
631
- this.getStore();
632
- this.selectedFilters.group = this.groupsData;
633
- } else {
634
- // If no groups are selected, clear the stores list
635
- this.filteredStores = [];
636
-
637
- // Also, update localStorage to reflect the cleared store selection
638
- this.selectedFilters.stores = [];
639
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
640
-
641
- // Emit data via service
642
- // this.gs.dataRangeValue.next(this.selectedFilters);
643
- }
644
-
645
- // Clear the search store text when groups are updated
646
- this.searchStoreText = '';
647
- }
648
-
649
- Reset(): void {
650
- setTimeout(()=>{
651
- // Clear selected groups, stores, and locations
652
- this.filteredGroups = [];
653
- this.filteredStores = [];
654
- this.filteredLocations = []; // Reset locations as well
655
- this.locations =[];this.groupsData =[]; this.stores =[];
656
- // Clear search input fields
657
- this.searchLocationText = "";
658
- this.searchGroupText = "";
659
- this.searchStoreText = "";
660
- this.selectedFilters.stores =[];
661
- this.selectedFilters.group =[];
662
- this.selectedFilters.location =[];
663
-
664
-
665
- // Fetch locations, groups, and stores again
666
- this.getLocations();
667
- this.getStore();
668
- this.getGroups();
669
- // Reset the filters in selectedFilters
670
-
671
-
672
- // // Once stores are fetched, mark all as checked
673
- // setTimeout(() => {
674
- // this.filteredStores = this.stores.map(store => ({
675
- // ...store,
676
- // checked: true // Mark all stores as checked
677
- // }));
678
-
679
- // // Sync selectedFilters with the updated store state
680
- // this.selectedFilters.stores = this.filteredStores.map(store => ({
681
- // ...store,
682
- // checked: true
683
- // }));
684
-
685
- // Update localStorage with the latest selectedFilters
686
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
687
- window.location.reload()
688
- // Emit the reset filters to update other components if needed
689
- // this.gs.dataRangeValue.next(this.selectedFilters);
690
- // Trigger change detection
691
- this.cd.detectChanges();
692
- // Adding a slight delay to ensure stores are fetched first
693
-
694
-
695
- // Close dropdown after reset if necessary
696
- this.Opendropdown = false;
697
- },100)
698
- }
699
-
700
-
701
-
702
- Apply(): void {
703
- // Close the dropdown
704
- this.Opendropdown = false;
705
-
706
- // Fetch existing filters from localStorage
707
- const headerFilters: any = JSON.parse(localStorage.getItem("header-filters") || "{}");
708
- this.selectedFilters.store = null
709
- // Ensure current selections are reflected
710
- this.selectedFilters.location = this.locations;
711
- this.selectedFilters.group = this.groupsData;
712
- this.selectedFilters.stores = headerFilters.stores ? headerFilters.stores : this.stores;
713
-
714
-
715
- // Store updated filters back in localStorage
716
- localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
717
- window.location.reload()
718
- // Emit the updated filters via the service
719
- // this.gs.dataRangeValue.next(this.selectedFilters);
720
- // Trigger refresh if necessary
721
- // this.gs.manageRefreshTrigger.next(true);
722
- this.cd.detectChanges();
723
- }
724
-
725
- filterLocations(): void {
726
- const searchText = this.searchLocationText.toLowerCase();
727
-
728
- if (searchText) {
729
- // Preserve the checked state during filtering
730
- this.filteredLocations = this.locations
731
- .map(location => ({
732
- ...location,
733
- checked: this.filteredLocations.find(l => l.city === location.city)?.checked || false
734
- }))
735
- .filter(location =>
736
- location?.city?.toLowerCase().includes(searchText)
737
- );
738
- } else {
739
- // Restore the original checked state when search text is cleared
740
- this.filteredLocations = this.locations.map(location => ({
741
- ...location,
742
- checked: this.selectedFilters.location.find((l:any) => l.city === location.city)?.checked || false
743
- }));
744
- }
745
- }
746
-
747
-
748
- filterGroups(): void {
749
- const searchText = this.searchGroupText.toLowerCase();
750
-
751
- if (searchText) {
752
- // Preserve the checked state during filtering
753
- this.filteredGroups = this.groupsData
754
- .map(group => ({
755
- ...group,
756
- checked: this.filteredGroups.find(g => g.groupName === group.groupName)?.checked || false
757
- }))
758
- .filter(group =>
759
- group?.groupName?.toLowerCase().includes(searchText)
760
- );
761
- } else {
762
- // Restore the original checked state when search text is cleared
763
- this.filteredGroups = this.groupsData.map(group => ({
764
- ...group,
765
- checked: this.selectedFilters.group.find((g:any) => g.groupName === group.groupName)?.checked || false
766
- }));
767
- }
768
- }
769
-
770
-
771
- filterStores(): void {
772
- const searchText = this.searchStoreText.toLowerCase();
773
- // Preserve checked states during filtering
774
- if (searchText) {
775
- // Filter based on search text while preserving checked state
776
- this.filteredStores = this.stores
777
- .map(store => ({
778
- ...store,
779
- // Check if the store is already checked in filteredStores, fallback to original stores' checked state
780
- checked: this.selectedFilters.stores.find((s: any) => s.storeId === store.storeId)?.checked || store.checked || false
781
- }))
782
- .filter(store => store.storeName.toLowerCase().includes(searchText));
783
- } else {
784
- // When the search text is cleared, restore the original list with preserved checked states
785
- this.filteredStores = this.stores.map(store => ({
786
- ...store,
787
- // Preserve the checked state based on the selected filters
788
- checked: this.selectedFilters.stores.find((s: any) => s.storeId === store.storeId)?.checked || store.checked || false
789
- }));
790
- }
791
- }
792
-
793
-
794
-
795
- closeDropdown(): void {
796
- this.dropdownOpen = null;
797
- }
798
-
799
- @HostListener("document:click", ["$event"])
800
- clickOutside(event: MouseEvent): void {
801
- const clickedInside = (event.target as HTMLElement).closest(
802
- ".dropdown-container"
803
- );
804
- const clickedoutSide = (event.target as HTMLElement).closest(
805
- ".dropdown1"
806
- );
807
- if (!clickedInside) {
808
- this.closeDropdown();
809
- }
810
- if(!clickedoutSide) {
811
- this.closeDropdown1();
812
- }
813
-
814
- }
815
- }
816
- interface City {
817
- city: string;
818
- }
819
-
820
- interface Location {
821
- city: City;
822
- checked: boolean;
823
- }
824
-
825
-