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
@@ -0,0 +1,1090 @@
1
+ import { Component, HostListener, } from "@angular/core";
2
+ import dayjs from "dayjs";
3
+ import "dayjs/locale/en";
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../../../services/auth.service";
6
+ import * as i2 from "@angular/router";
7
+ import * as i3 from "tango-app-ui-global";
8
+ import * as i4 from "@angular/common";
9
+ import * as i5 from "../../../common/custom-select/custom-select.component";
10
+ import * as i6 from "@angular/forms";
11
+ export class ZoneHeaderComponent {
12
+ auth;
13
+ router;
14
+ gs;
15
+ cd;
16
+ dayjs = dayjs;
17
+ isCustomDate = (m) => {
18
+ if (m.isSame(this.dayjs(), "day")) {
19
+ return "invalid-date"; // disable today
20
+ }
21
+ return false;
22
+ };
23
+ selectedDateRange = { startDate: dayjs().subtract(30, 'days'),
24
+ endDate: dayjs().subtract(1, "days"), };
25
+ selectedFilters = {
26
+ client: null,
27
+ clientName: null,
28
+ clients: [],
29
+ store: null,
30
+ stores: [],
31
+ date: null,
32
+ group: [],
33
+ location: [],
34
+ country: [],
35
+ };
36
+ Opendropdown = false;
37
+ dropdownOpen = null; // 'location' or 'group'
38
+ searchLocationText = "";
39
+ searchGroupText = "";
40
+ locations = [];
41
+ filteredLocations = [];
42
+ groupsData = [];
43
+ filteredGroups = [];
44
+ filteredStores = [];
45
+ stores = [];
46
+ searchStoreText = '';
47
+ clientList = [];
48
+ selectedClient;
49
+ locationLabel = [];
50
+ groupLabel = [];
51
+ users;
52
+ url;
53
+ filteredCountries = [];
54
+ countryLabel = [];
55
+ searchCountryText = "";
56
+ countries = [];
57
+ constructor(auth, router, gs, cd) {
58
+ this.auth = auth;
59
+ this.router = router;
60
+ this.gs = gs;
61
+ this.cd = cd;
62
+ }
63
+ onClick(event) {
64
+ const target = event.target;
65
+ if (!target.closest('.dropdown2')) {
66
+ this.Opendropdown = false;
67
+ }
68
+ }
69
+ closeDropdown1() {
70
+ this.Opendropdown = false;
71
+ }
72
+ zoneData = [
73
+ {
74
+ "storeId": "11-1578",
75
+ "storeName": "LKST1757"
76
+ },
77
+ {
78
+ "storeId": "11-1919",
79
+ "storeName": "LKST2329"
80
+ },
81
+ {
82
+ "storeId": "11-2222",
83
+ "storeName": "LKST2554"
84
+ },
85
+ {
86
+ "storeId": "11-2391",
87
+ "storeName": "LKST2598"
88
+ },
89
+ {
90
+ "storeId": "11-376",
91
+ "storeName": "LKST646"
92
+ },
93
+ {
94
+ "storeId": "11-82",
95
+ "storeName": "LKST84"
96
+ }
97
+ ];
98
+ ngOnInit() {
99
+ // this.setRangesBasedOnRoute();
100
+ // Listen for route changes to update ranges
101
+ // this.router?.events?.subscribe((event) => {
102
+ // if (event instanceof NavigationEnd) {
103
+ // this.setRangesBasedOnRoute();
104
+ // }
105
+ // });
106
+ this.url = this.router.url.split("?")[0].split('/');
107
+ const user = JSON.parse(localStorage.getItem('user-info'));
108
+ this.users = user;
109
+ this.gs?.manageRefreshTrigger?.subscribe((e) => {
110
+ if (e) {
111
+ if (user.userType === 'tango') {
112
+ this.getClient();
113
+ }
114
+ else {
115
+ const storedFilters = localStorage.getItem("header-filters");
116
+ if (storedFilters) {
117
+ const headerFilters = JSON.parse(storedFilters);
118
+ this.filteredStores = headerFilters?.stores.map((store) => ({
119
+ ...store,
120
+ checked: store.checked
121
+ }));
122
+ }
123
+ }
124
+ }
125
+ });
126
+ // Fetch client data if the user is of type 'tango'
127
+ if (user.userType === 'tango') {
128
+ this.getClient();
129
+ }
130
+ else {
131
+ this.getCountry();
132
+ this.getLocations();
133
+ this.getGroups();
134
+ this.getStore();
135
+ const clientFilters = localStorage.getItem("client-details");
136
+ if (clientFilters) {
137
+ const headerclientFilters = JSON.parse(clientFilters);
138
+ this.selectedClient = {
139
+ trafficDateRange: headerclientFilters.trafficDateRange
140
+ };
141
+ }
142
+ }
143
+ // Load filters from localStorage if they exist
144
+ const storedFilters = localStorage.getItem("header-filters1");
145
+ if (storedFilters) {
146
+ const headerFilters = JSON.parse(storedFilters);
147
+ if (headerFilters.date) {
148
+ this.selectedDateRange = {
149
+ startDate: this.dayjs("09-09-2025").format("YYYY-MM-DD"),
150
+ endDate: this.dayjs("09-09-2025").format("YYYY-MM-DD"),
151
+ };
152
+ headerFilters.date = this.selectedDateRange;
153
+ }
154
+ // Initialize selectedFilters with defaults or existing values
155
+ this.selectedFilters = {
156
+ client: headerFilters.client || this.users.client || '11',
157
+ clientName: headerFilters.clientName || '',
158
+ clients: headerFilters.clients || [],
159
+ store: headerFilters.store || null,
160
+ date: headerFilters.date || {},
161
+ stores: headerFilters.stores || [],
162
+ group: headerFilters.group || [],
163
+ location: headerFilters.location || [],
164
+ country: headerFilters.country || []
165
+ };
166
+ // Sync filtered data with stored selections
167
+ this.filteredCountries = this.syncWithLocalStorage(headerFilters.country);
168
+ this.filteredLocations = this.syncWithLocalStorage(headerFilters.location);
169
+ this.filteredGroups = this.syncWithLocalStorage(headerFilters.group);
170
+ this.filteredStores = this.syncWithLocalStorage(headerFilters.stores);
171
+ // Format date range if it exists
172
+ if (headerFilters.date) {
173
+ this.selectedDateRange = {
174
+ startDate: this.dayjs("09-09-2025").format("YYYY-MM-DD"),
175
+ endDate: this.dayjs("09-09-2025").format("YYYY-MM-DD"),
176
+ };
177
+ }
178
+ headerFilters.date = this.selectedDateRange;
179
+ // console.log("3")
180
+ // Emit data via service and update localStorage
181
+ this.emitAndStoreFilters();
182
+ }
183
+ else {
184
+ // Initialize empty states if no header filters are present in localStorage
185
+ this.resetFilters();
186
+ // console.log("2")
187
+ }
188
+ }
189
+ syncWithLocalStorage(items) {
190
+ return items
191
+ ? items.map((item) => ({
192
+ ...item,
193
+ checked: item.checked === true
194
+ }))
195
+ : [];
196
+ }
197
+ emitAndStoreFilters() {
198
+ this.gs.dataRangeValue.next(this.selectedFilters);
199
+ localStorage.setItem("header-filters1", JSON.stringify(this.selectedFilters));
200
+ // console.log("1")
201
+ }
202
+ /**
203
+ * Reset selectedFilters and all related arrays to empty states
204
+ */
205
+ resetFilters() {
206
+ this.selectedFilters = {
207
+ client: null,
208
+ clientName: '',
209
+ clients: [],
210
+ store: null,
211
+ date: {},
212
+ stores: [],
213
+ group: [],
214
+ location: [],
215
+ country: []
216
+ };
217
+ this.filteredLocations = [];
218
+ this.filteredGroups = [];
219
+ this.filteredStores = [];
220
+ this.filteredCountries = [];
221
+ }
222
+ getClient() {
223
+ this.auth.getClients().subscribe({
224
+ next: (e) => {
225
+ if (e) {
226
+ this.clientList = e.data.result;
227
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters1") || "{}");
228
+ if (headerFilters.client) {
229
+ this.clientList.find((obj) => {
230
+ if (obj.clientId === headerFilters.client) {
231
+ this.selectedClient = obj;
232
+ }
233
+ });
234
+ // const startDate = this.dayjs(headerFilters.date.startDate);
235
+ // const endDate = this.dayjs(headerFilters.date.endDate);
236
+ // const differenceInDays = endDate.diff(startDate, 'days');
237
+ // if (differenceInDays >= 90 && this.selectedClient?.trafficDateRange === 90) {
238
+ // this.selectedDateRange = {
239
+ // startDate: this.dayjs(headerFilters.date.startDate, "YYYY-MM-DD").subtract(-90, 'days').format("DD-MM-YYYY"),
240
+ // endDate: this.dayjs(headerFilters.date.endDate, "YYYY-MM-DD").format("DD-MM-YYYY"),
241
+ // };
242
+ // } else {
243
+ // this.selectedDateRange = {
244
+ // startDate: this.dayjs(this.selectedDateRange.startDate, "YYYY-MM-DD").format("DD-MM-YYYY"),
245
+ // endDate: this.dayjs(this.selectedDateRange.endDate, "YYYY-MM-DD").format("DD-MM-YYYY"),
246
+ // };
247
+ // }
248
+ this.selectedFilters.client = headerFilters.client;
249
+ this.selectedFilters.clientName = headerFilters.clientName;
250
+ this.selectedFilters.clients = headerFilters.clients;
251
+ this.selectedFilters.store = headerFilters.store;
252
+ this.selectedFilters.date = headerFilters.date;
253
+ this.selectedFilters.stores = headerFilters.stores;
254
+ this.selectedFilters.group = headerFilters.group;
255
+ this.selectedFilters.location = headerFilters.location;
256
+ this.selectedFilters.country = headerFilters.country;
257
+ this.gs.dataRangeValue.next(this.selectedFilters);
258
+ // console.log("2")
259
+ // Ensure locations and groups are loaded before fetching stores
260
+ this.getCountry();
261
+ this.getLocations();
262
+ this.getGroups();
263
+ // Fetch stores only after locations and groups are set
264
+ this.getStore();
265
+ }
266
+ else {
267
+ this.selectedClient = this.clientList[0];
268
+ this.selectedFilters.client = this.selectedClient.clientId ? this.selectedClient.clientId : '11';
269
+ this.selectedFilters.clientName = this.selectedClient.clientName;
270
+ this.selectedFilters.clients = headerFilters.clients;
271
+ this.selectedFilters.store = headerFilters.store;
272
+ this.selectedFilters.date = headerFilters.date;
273
+ this.selectedFilters.stores = headerFilters.stores;
274
+ this.selectedFilters.group = headerFilters.group;
275
+ this.selectedFilters.location = headerFilters.location;
276
+ this.selectedFilters.country = headerFilters.country;
277
+ localStorage.setItem("header-filters1", JSON.stringify(this.selectedFilters));
278
+ this.gs.dataRangeValue.next(this.selectedFilters);
279
+ // console.log("3")
280
+ this.cd.detectChanges();
281
+ // Ensure locations and groups are loaded before fetching stores
282
+ this.getCountry();
283
+ this.getLocations();
284
+ this.getGroups();
285
+ // Fetch stores only after locations and groups are set
286
+ this.getStore();
287
+ }
288
+ }
289
+ else {
290
+ this.selectedClient = this.clientList[0];
291
+ this.selectedFilters.client = this.selectedClient.clientId ? this.selectedClient.clientId : '11';
292
+ this.selectedFilters.clientName = this.selectedClient.clientName;
293
+ // Ensure locations and groups are loaded before fetching stores
294
+ this.getCountry();
295
+ this.getLocations();
296
+ this.getGroups();
297
+ // Fetch stores only after locations and groups are set
298
+ this.getStore();
299
+ localStorage.setItem("header-filters1", JSON.stringify(this.selectedFilters));
300
+ this.gs.dataRangeValue.next(this.selectedFilters);
301
+ // console.log("4")
302
+ this.cd.detectChanges();
303
+ }
304
+ this.getUserInfo(this.selectedFilters.client);
305
+ },
306
+ });
307
+ }
308
+ getUserInfo(client) {
309
+ let obj = {
310
+ clientId: client ? client : '11'
311
+ };
312
+ if (client) {
313
+ this.auth.getHeaderUsers(obj).subscribe({
314
+ next: (e) => {
315
+ localStorage.setItem("usersEmail-info", JSON.stringify(e?.data?.userEmailData || []));
316
+ }
317
+ });
318
+ }
319
+ }
320
+ onClientSelect(event) {
321
+ // Update the selected client
322
+ this.selectedClient = event;
323
+ // Clear previous filtered data and selections
324
+ this.filteredGroups = [];
325
+ this.filteredStores = [];
326
+ this.filteredLocations = [];
327
+ this.selectedFilters.stores = [];
328
+ this.selectedFilters.group = [];
329
+ this.selectedFilters.location = [];
330
+ this.selectedFilters.country = [];
331
+ // Fetch header filters from localStorage
332
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters1") || "{}");
333
+ // Update the selected filters with the new client
334
+ this.selectedFilters.client = this.selectedClient.clientId ? this.selectedClient.clientId : '11';
335
+ this.selectedFilters.clientName = this.selectedClient.clientName;
336
+ // Remove old store, group, and location data from the header filters
337
+ delete headerFilters.stores;
338
+ delete headerFilters.groups;
339
+ delete headerFilters.location;
340
+ delete headerFilters.country;
341
+ // Fetch new data based on the new client
342
+ this.getCountry();
343
+ this.getLocations();
344
+ this.getStore();
345
+ this.getGroups();
346
+ // Update localStorage with the new client selection and empty filter data
347
+ localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));
348
+ window.location.reload();
349
+ // Emit data to the global service
350
+ // this.gs.dataRangeValue.next(this.selectedFilters);
351
+ // Trigger change detection to reflect UI changes
352
+ this.cd.detectChanges();
353
+ }
354
+ ranges = {
355
+ // Today: [dayjs(), dayjs()],
356
+ Yesterday: [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],
357
+ 'This Week': [dayjs().subtract(7, 'days'), dayjs().subtract(1, 'days')],
358
+ 'Last Week': [
359
+ dayjs().subtract(14, 'days').startOf('day'),
360
+ dayjs().subtract(8, 'days').endOf('day'),
361
+ ],
362
+ 'This Month': [dayjs().subtract(30, 'days'), dayjs().subtract(1, 'days')],
363
+ 'Last Month': [
364
+ dayjs().subtract(1, 'month').startOf('month'),
365
+ dayjs().subtract(1, 'month').endOf('month'),
366
+ ],
367
+ };
368
+ onStartDateChange(event) {
369
+ if (this.dayjs(event.startDate).isValid()) {
370
+ if (this.selectedClient?.traxDateRange === 90) {
371
+ this.isCustomDate = (m) => {
372
+ const isValidDate = m > this.dayjs() || m > this.dayjs(event.startDate.add(90, "days"));
373
+ return isValidDate ? "invalid-date" : false;
374
+ };
375
+ }
376
+ else {
377
+ this.isCustomDate = (m) => {
378
+ const isValidDate = m > this.dayjs() || m > this.dayjs(event.startDate.add(180, "days"));
379
+ return isValidDate ? "invalid-date" : false;
380
+ };
381
+ }
382
+ }
383
+ }
384
+ datechange(event) {
385
+ if (event && event.startDate && event.endDate) {
386
+ if (this.dayjs(event.startDate).isValid() &&
387
+ this.dayjs(event.endDate).isValid()) {
388
+ this.selectedDateRange.startDate = event.startDate;
389
+ this.selectedDateRange.endDate = event.endDate;
390
+ var datetime = {
391
+ startDate: this.dayjs(event.startDate, "DD-MM-YYYY").format("YYYY-MM-DD"),
392
+ endDate: this.dayjs(event.endDate, "DD-MM-YYYY").format("YYYY-MM-DD"),
393
+ };
394
+ this.selectedFilters.date = datetime;
395
+ localStorage.setItem("header-filters1", JSON.stringify(this.selectedFilters));
396
+ window.location.reload();
397
+ // this.gs.dataRangeValue.next(this.selectedFilters);
398
+ }
399
+ }
400
+ }
401
+ opendropdown(e) {
402
+ e.stopPropagation();
403
+ this.Opendropdown = !this.Opendropdown;
404
+ }
405
+ getLocations() {
406
+ const country = this.countries
407
+ .filter(country => country.checked)
408
+ .map(country => country.country);
409
+ // const headerFilters: any = JSON.parse(localStorage.getItem("header-filters1") || "{}");
410
+ let obj = {
411
+ clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId || '11',
412
+ country,
413
+ city: [],
414
+ group: [],
415
+ };
416
+ this.auth.getLocation(obj).subscribe({
417
+ next: (res) => {
418
+ let cityList = this.selectedFilters?.location?.filter((location) => location.checked).map((loc) => loc.city);
419
+ // Map the fetched locations with default unchecked state
420
+ this.locations = res?.data?.locationData.map((city) => ({
421
+ city: city.city,
422
+ // checked: cityList?.length ? cityList.includes(city.city) : true,
423
+ checked: cityList?.includes(city.city) ? true : false,
424
+ }));
425
+ // Sync the fetched locations with any stored checked values in localStorage
426
+ if (this.selectedFilters.location && Array.isArray(this.selectedFilters.location)) {
427
+ this.filteredLocations = this.locations.map(location => {
428
+ const matchedLocation = this.selectedFilters.location.find((loc) => loc.city === location.city);
429
+ return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;
430
+ });
431
+ }
432
+ else {
433
+ this.filteredLocations = this.locations;
434
+ }
435
+ if (this.searchLocationText) {
436
+ this.filteredLocations = this.locations.filter((location) => location.city.toLowerCase().includes(this.searchLocationText.toLowerCase()));
437
+ }
438
+ const selectedLocations = this.locations.filter((location) => location.checked).map((location) => location.city);
439
+ if (selectedLocations.length > 0) {
440
+ setTimeout(() => {
441
+ this.getGroups();
442
+ this.getStore(); // Fetch stores based on selected groups
443
+ }, 1000);
444
+ }
445
+ if (!selectedLocations.length && country.length) {
446
+ this.getGroups();
447
+ }
448
+ },
449
+ error: (err) => {
450
+ console.error("Failed to fetch locations", err);
451
+ },
452
+ });
453
+ }
454
+ isAllLocationsSelected() {
455
+ return this.filteredLocations.every(location => location.checked);
456
+ }
457
+ selectedLocationsLabel() {
458
+ const selectedLocations = this.locationLabel = this.searchLocationText.length ? this.locations
459
+ .filter(location => location.checked).map(location => location.city) : this.filteredLocations
460
+ .filter(location => location.checked).map(location => location.city);
461
+ return selectedLocations.length === 0
462
+ ? ''
463
+ : selectedLocations.length === 1
464
+ ? selectedLocations[0]
465
+ : `${selectedLocations.length} Regions`;
466
+ }
467
+ removeLocation() {
468
+ this.Reset();
469
+ }
470
+ getGroups() {
471
+ const country = this.countries
472
+ .filter(country => country.checked)
473
+ .map(country => country.country);
474
+ let city;
475
+ city = this.locations
476
+ .filter(location => location.checked)
477
+ .map(location => location.city);
478
+ if (!city.length && country.length) {
479
+ city = this.locations.map((loc) => loc.city);
480
+ }
481
+ const obj = { country, city, clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId, group: [] };
482
+ this.auth.getGroups(obj).subscribe({
483
+ next: (res) => {
484
+ let checkedGroup = this.selectedFilters?.group?.filter((group) => group.checked).map((group) => group.groupName);
485
+ const combinedGroups = res?.data?.groupData?.map((groupName) => ({
486
+ groupName: groupName.groupName,
487
+ checked: checkedGroup?.includes(groupName.groupName) ? true : false,
488
+ // checked: checkedGroup?.length ? checkedGroup.includes(groupName.groupName) : true,
489
+ }));
490
+ this.groupsData = combinedGroups;
491
+ if (this.searchGroupText.length) {
492
+ this.filteredGroups = combinedGroups.filter((item) => item.groupName.toLowerCase().includes(this.searchGroupText));
493
+ }
494
+ else {
495
+ this.filteredGroups = combinedGroups;
496
+ }
497
+ // Auto-fetch stores when groups are selected
498
+ const selectedGroups = this.groupsData.filter((group) => group.checked).map((group) => group.groupName);
499
+ if (selectedGroups.length > 0) {
500
+ setTimeout(() => {
501
+ this.getStore(); // Fetch stores based on selected groups
502
+ }, 1000);
503
+ }
504
+ },
505
+ error: (err) => {
506
+ console.error("Failed to fetch groups", err);
507
+ },
508
+ });
509
+ }
510
+ toggleDropdown(type) {
511
+ if (this.dropdownOpen === type) {
512
+ // If the dropdown is open, close it and avoid resetting the selected values unnecessarily
513
+ this.dropdownOpen = null;
514
+ }
515
+ else {
516
+ // Open the specific dropdown and handle data fetching only if necessary
517
+ this.dropdownOpen = type;
518
+ if (type === 'country') {
519
+ // Fetch countries only if not already fetched and no search text exists
520
+ if ((!this.filteredCountries || this.filteredCountries.length === 0) && !this.searchCountryText.trim()) {
521
+ this.getCountry();
522
+ }
523
+ }
524
+ if (type === 'group') {
525
+ // Fetch groups only if there are selected cities and no active search text
526
+ const selectedCities = this.locations
527
+ .filter((location) => location.checked)
528
+ .map((location) => location.city);
529
+ // Fetch groups only if locations are selected, no search text exists, and dropdown is opened
530
+ if (this.filteredLocations.length > 0 || (selectedCities.length > 0 && !this.searchGroupText.trim())) {
531
+ this.getGroups();
532
+ }
533
+ else {
534
+ this.filteredGroups = []; // Clear groups if no locations are selected
535
+ }
536
+ }
537
+ if (type === 'store') {
538
+ // Fetch stores only if not already fetched and no search text is active
539
+ if ((!this.filteredStores || this.filteredStores.length === 0) && !this.searchStoreText.trim()) {
540
+ this.getStore();
541
+ }
542
+ }
543
+ }
544
+ }
545
+ handleGroupDropdownClick() {
546
+ if (this.dropdownOpen === 'group') {
547
+ this.resetSelectedGroups();
548
+ }
549
+ this.toggleDropdown('group');
550
+ }
551
+ resetSelectedGroups() {
552
+ this.filteredGroups.forEach((group) => (group.checked = false));
553
+ this.searchGroupText = "";
554
+ }
555
+ selectedGroupsLabel() {
556
+ const selectedGroups = this.groupLabel = this.searchGroupText.length ? this.groupsData.filter((group) => group.checked) : this.filteredGroups.filter((group) => group.checked);
557
+ return selectedGroups.length === 0
558
+ ? ""
559
+ : selectedGroups.length === 1
560
+ ? selectedGroups[0].groupName
561
+ : `${selectedGroups.length} Clusters`;
562
+ }
563
+ removeGroup() {
564
+ this.Reset();
565
+ }
566
+ isAllGroupsSelected() {
567
+ return this.filteredGroups.length ? this.filteredGroups.every((group) => group.checked) : false;
568
+ }
569
+ getStore() {
570
+ const country = this.countries
571
+ .filter(country => country.checked)
572
+ .map(country => country.country);
573
+ const city = this.locations
574
+ .filter(location => location.checked)
575
+ .map(location => location.city);
576
+ const group = this.groupsData
577
+ .filter(group => group.checked)
578
+ .map(group => group.groupName);
579
+ const data = {
580
+ country,
581
+ city,
582
+ clusters: group,
583
+ clientId: this.users.clientId || this.selectedFilters.client
584
+ };
585
+ this.auth.getHeaderStores(data).subscribe({
586
+ next: (res) => {
587
+ if (res && res.code === 200) {
588
+ // Initialize stores from API response
589
+ this.stores = this.zoneData;
590
+ // Check if there are previously selected stores
591
+ const checkedStoreIds = this.selectedFilters?.stores
592
+ ? this.selectedFilters.stores.filter((store) => store.checked).map((store) => store.storeId)
593
+ : [];
594
+ // Sync the `checked` state
595
+ this.stores.forEach(store => {
596
+ store.checked = checkedStoreIds.length
597
+ ? checkedStoreIds.includes(store.storeId) // Use previous selection
598
+ : true; // Default to true if no previous selection
599
+ });
600
+ // Apply search filter if search text is present
601
+ if (this.searchStoreText.length) {
602
+ this.filteredStores = this.stores.filter(store => store.storeName.toLowerCase().includes(this.searchStoreText.toLowerCase()));
603
+ }
604
+ else {
605
+ this.filteredStores = [...this.stores];
606
+ }
607
+ // Update `selectedFilters.stores` to reflect the current state
608
+ this.selectedFilters.stores = this.filteredStores.map(store => ({
609
+ storeId: store.storeId,
610
+ storeName: store.storeName,
611
+ checked: store.checked
612
+ }));
613
+ // this.selectedFilters.country = country;
614
+ // Save updated filters to localStorage
615
+ localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));
616
+ // Trigger UI change detection
617
+ this.cd.detectChanges();
618
+ }
619
+ else {
620
+ // Handle empty or error response
621
+ this.clearStoresState();
622
+ }
623
+ },
624
+ error: (err) => {
625
+ console.error("Failed to fetch stores", err);
626
+ this.clearStoresState();
627
+ }
628
+ });
629
+ }
630
+ // Clear stores state and reset filters
631
+ clearStoresState() {
632
+ this.stores = [];
633
+ this.filteredStores = [];
634
+ this.selectedFilters.stores = [];
635
+ localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));
636
+ }
637
+ resetSelectedStores() {
638
+ this.filteredStores.forEach((store) => (store.checked = false));
639
+ this.searchStoreText = "";
640
+ }
641
+ selectedStoresLabel() {
642
+ const selectedStores = this.searchStoreText.length ? this.stores.filter((store) => store.checked) : this.filteredStores.filter((store) => store.checked);
643
+ return selectedStores.length === 0
644
+ ? "0 Stores"
645
+ : selectedStores.length === 1
646
+ ? selectedStores[0].storeName
647
+ : `${selectedStores.length} Stores`;
648
+ }
649
+ isAllStoresSelected() {
650
+ return this.filteredStores.length > 0 && this.filteredStores.every(store => store.checked);
651
+ }
652
+ // Method to handle dropdown item selection
653
+ updateSelectedStores() {
654
+ this.filteredStores.forEach(store => {
655
+ const filteredStore = this.stores.findIndex(fStore => fStore.storeId === store.storeId);
656
+ if (filteredStore != -1) {
657
+ this.stores[filteredStore].checked = store.checked; // Sync the checked state with full store list
658
+ }
659
+ });
660
+ // Update selectedFilters based on the current store selection
661
+ this.selectedFilters.stores = this.stores.filter(store => store.checked);
662
+ // Update localStorage with the latest selection
663
+ localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));
664
+ // Emit updated filters via service
665
+ // this.gs.dataRangeValue.next(this.selectedFilters);
666
+ // Trigger change detection if necessary
667
+ this.cd.detectChanges();
668
+ }
669
+ toggleSelectAllLocations(event) {
670
+ const isChecked = event.target.checked;
671
+ this.filteredLocations.forEach((location) => (location.checked = isChecked));
672
+ this.updateSelectedLocations();
673
+ }
674
+ toggleSelectAllStores(event) {
675
+ const checked = event.target.checked;
676
+ // Apply the selection to both filtered and full list of stores
677
+ this.filteredStores.forEach(store => store.checked = checked);
678
+ this.stores.forEach(store => {
679
+ const filteredStore = this.filteredStores.find(fStore => fStore.storeId === store.storeId);
680
+ if (filteredStore) {
681
+ store.checked = checked; // Sync the checked state with full store list
682
+ }
683
+ });
684
+ // Update the selected stores and persist the selection
685
+ this.updateSelectedStores();
686
+ }
687
+ updateSelectedLocations() {
688
+ // When locations are selected, fetch the related groups
689
+ const selectedCities = this.filteredLocations
690
+ .filter((location) => location.checked)
691
+ .map((location) => location.city);
692
+ this.filteredLocations.forEach((location) => {
693
+ let findLocationIndex = this.locations.findIndex((loc) => loc.city == location.city);
694
+ if (findLocationIndex != -1) {
695
+ this.locations[findLocationIndex].checked = location.checked;
696
+ }
697
+ });
698
+ if (selectedCities.length > 0 || !selectedCities.length) {
699
+ this.selectedFilters.stores = [];
700
+ this.groupsData = [];
701
+ this.getGroups(); // Fetch groups based on selected cities
702
+ // If there are selected groups, fetch the stores based on selected groups
703
+ this.getStore();
704
+ this.selectedFilters.location = this.locations;
705
+ }
706
+ else {
707
+ this.filteredGroups = []; // Clear groups if no locations are selected
708
+ this.selectedFilters.location = [];
709
+ }
710
+ this.selectedFilters.group = [];
711
+ this.filteredStores = []; // Reset stores as well
712
+ this.searchGroupText = '';
713
+ this.searchStoreText = '';
714
+ // this.Opendropdown = false;
715
+ }
716
+ toggleSelectAllGroups(event) {
717
+ const isChecked = event.target.checked;
718
+ this.filteredGroups.forEach((group) => (group.checked = isChecked));
719
+ this.updateSelectedGroups();
720
+ }
721
+ updateSelectedGroups() {
722
+ // Fetch the relevant stores after groups are selected
723
+ const selectedGroups = this.filteredGroups
724
+ .filter((group) => group.checked)
725
+ .map((group) => group.groupName);
726
+ this.filteredGroups.forEach((group) => {
727
+ let findGroupIndex = this.groupsData.findIndex((item) => item.groupName == group.groupName);
728
+ if (findGroupIndex != -1) {
729
+ this.groupsData[findGroupIndex].checked = group.checked;
730
+ }
731
+ });
732
+ if (selectedGroups.length > 0 || !selectedGroups.length) {
733
+ this.selectedFilters.stores = [];
734
+ // If there are selected groups, fetch the stores based on selected groups
735
+ this.getStore();
736
+ this.selectedFilters.group = this.groupsData;
737
+ }
738
+ else {
739
+ // If no groups are selected, clear the stores list
740
+ this.filteredStores = [];
741
+ // Also, update localStorage to reflect the cleared store selection
742
+ this.selectedFilters.stores = [];
743
+ localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));
744
+ // Emit data via service
745
+ // this.gs.dataRangeValue.next(this.selectedFilters);
746
+ }
747
+ // Clear the search store text when groups are updated
748
+ this.searchStoreText = '';
749
+ }
750
+ Reset() {
751
+ setTimeout(() => {
752
+ // Clear selected groups, stores, and locations
753
+ this.filteredCountries = [];
754
+ this.filteredGroups = [];
755
+ this.filteredStores = [];
756
+ this.filteredLocations = []; // Reset locations as well
757
+ this.locations = [];
758
+ this.groupsData = [];
759
+ this.stores = [];
760
+ this.countries = [];
761
+ // Clear search input fields
762
+ this.searchLocationText = "";
763
+ this.searchGroupText = "";
764
+ this.searchStoreText = "";
765
+ this.selectedFilters.stores = [];
766
+ this.selectedFilters.group = [];
767
+ this.selectedFilters.location = [];
768
+ this.selectedFilters.country = [];
769
+ // Fetch locations, groups, and stores again
770
+ this.getCountry();
771
+ this.getLocations();
772
+ this.getStore();
773
+ this.getGroups();
774
+ // Reset the filters in selectedFilters
775
+ // // Once stores are fetched, mark all as checked
776
+ // setTimeout(() => {
777
+ // this.filteredStores = this.stores.map(store => ({
778
+ // ...store,
779
+ // checked: true // Mark all stores as checked
780
+ // }));
781
+ // // Sync selectedFilters with the updated store state
782
+ // this.selectedFilters.stores = this.filteredStores.map(store => ({
783
+ // ...store,
784
+ // checked: true
785
+ // }));
786
+ // Update localStorage with the latest selectedFilters
787
+ localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));
788
+ window.location.reload();
789
+ // Emit the reset filters to update other components if needed
790
+ // this.gs.dataRangeValue.next(this.selectedFilters);
791
+ // Trigger change detection
792
+ this.cd.detectChanges();
793
+ // Adding a slight delay to ensure stores are fetched first
794
+ // Close dropdown after reset if necessary
795
+ this.Opendropdown = false;
796
+ }, 100);
797
+ }
798
+ filterLocations() {
799
+ const searchText = this.searchLocationText.toLowerCase();
800
+ if (searchText) {
801
+ // Preserve the checked state during filtering
802
+ this.filteredLocations = this.locations
803
+ .map(location => ({
804
+ ...location,
805
+ checked: this.filteredLocations.find(l => l.city === location.city)?.checked || false
806
+ }))
807
+ .filter(location => location?.city?.toLowerCase().includes(searchText));
808
+ }
809
+ else {
810
+ // Restore the original checked state when search text is cleared
811
+ this.filteredLocations = this.locations.map(location => ({
812
+ ...location,
813
+ checked: this.selectedFilters.location.find((l) => l.city === location.city)?.checked || false
814
+ }));
815
+ }
816
+ }
817
+ filterGroups() {
818
+ const searchText = this.searchGroupText.toLowerCase();
819
+ if (searchText) {
820
+ // Preserve the checked state during filtering
821
+ this.filteredGroups = this.groupsData
822
+ .map(group => ({
823
+ ...group,
824
+ checked: this.filteredGroups.find(g => g.groupName === group.groupName)?.checked || false
825
+ }))
826
+ .filter(group => group?.groupName?.toLowerCase().includes(searchText));
827
+ }
828
+ else {
829
+ // Restore the original checked state when search text is cleared
830
+ this.filteredGroups = this.groupsData.map(group => ({
831
+ ...group,
832
+ checked: this.selectedFilters.group.find((g) => g.groupName === group.groupName)?.checked || false
833
+ }));
834
+ }
835
+ }
836
+ filterStores() {
837
+ const searchText = this.searchStoreText.toLowerCase();
838
+ // Preserve checked states during filtering
839
+ if (searchText) {
840
+ // Filter based on search text while preserving checked state
841
+ this.filteredStores = this.stores
842
+ .map(store => ({
843
+ ...store,
844
+ // Check if the store is already checked in filteredStores, fallback to original stores' checked state
845
+ checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked || store.checked || false
846
+ }))
847
+ .filter(store => store.storeName.toLowerCase().includes(searchText));
848
+ }
849
+ else {
850
+ // When the search text is cleared, restore the original list with preserved checked states
851
+ this.filteredStores = this.stores.map(store => ({
852
+ ...store,
853
+ // Preserve the checked state based on the selected filters
854
+ checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked || store.checked || false
855
+ }));
856
+ }
857
+ }
858
+ closeDropdown() {
859
+ this.dropdownOpen = null;
860
+ }
861
+ clickOutside(event) {
862
+ const clickedInside = event.target.closest(".dropdown-container");
863
+ const clickedoutSide = event.target.closest(".dropdown2");
864
+ if (!clickedInside) {
865
+ this.closeDropdown();
866
+ }
867
+ if (!clickedoutSide) {
868
+ this.closeDropdown1();
869
+ }
870
+ }
871
+ // getCountry(): void {
872
+ // // const headerFilters: any = JSON.parse(localStorage.getItem("header-filters1") || "{}");
873
+ // let obj ={
874
+ // clientId: this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId,
875
+ // }
876
+ // this.auth.getCountry(obj).subscribe({
877
+ // next: (res: any) => {
878
+ // let countryList = this.selectedFilters?.country?.filter((country:any) => country.checked).map((loc:any) => loc.allCountry);
879
+ // // Map the fetched countries with default unchecked state
880
+ // this.countires = res?.data?.countryData.map((allCountry: any) => ({
881
+ // allCountry: allCountry.allCountry,
882
+ // checked: countryList?.includes(allCountry.allCountry) ? true : false,
883
+ // }));
884
+ // // Sync the fetched countries with any stored checked values in localStorage
885
+ // if (this.selectedFilters.country && Array.isArray(this.selectedFilters.country)) {
886
+ // this.filteredCountries = this.countries.map(country => {
887
+ // const matchedLocation = this.selectedFilters.country.find((loc: any) => loc.allCountry === country.allCountry);
888
+ // return matchedLocation ? { ...country, checked: matchedLocation.checked } : country;
889
+ // });
890
+ // } else {
891
+ // this.filteredCountries = this.countries;
892
+ // }
893
+ // if(this.searchLocationText) {
894
+ // this.filteredCountries = this.countries.filter((country:any) => country.city.toLowerCase().includes(this.searchLocationText.toLowerCase()))
895
+ // }
896
+ // const selectedCountries = this.countries.filter((country) => country.checked).map((country) => country.allCountry);
897
+ // if (selectedCountries.length > 0) {
898
+ // setTimeout(()=>{
899
+ // this.getStore(); // Fetch stores based on selected groups
900
+ // },1000)
901
+ // }
902
+ // },
903
+ // error: (err) => {
904
+ // console.error("Failed to fetch countries", err);
905
+ // },
906
+ // });
907
+ // }
908
+ // selectedCountriesLabel(): string {
909
+ // const selectedCountries = this.countryLabel = this.searchLocationText.length ? this.countries
910
+ // .filter(country => country.checked).map(country => country.allCountry) : this.filteredCountries
911
+ // .filter(country => country.checked).map(country => country.allCountry);
912
+ // return selectedCountries.length === 0
913
+ // ? ''
914
+ // : selectedCountries.length === 1
915
+ // ? selectedCountries[0]
916
+ // : `${selectedCountries.length} countries`;
917
+ // }
918
+ // isAllCountriesSelected(): boolean {
919
+ // return this.filteredCountries.every(country => country.checked);
920
+ // }
921
+ // filterCountries(): void {
922
+ // const searchText = this.searchCountryText.toLowerCase();
923
+ // if (searchText) {
924
+ // // Preserve the checked state during filtering
925
+ // this.filteredCountries = this.countires
926
+ // .map(country => ({
927
+ // ...country,
928
+ // checked: this.filteredCountries.find(l => l.allCountry === country.allCountry)?.checked || false
929
+ // }))
930
+ // .filter(location =>
931
+ // location?.allCountry?.toLowerCase().includes(searchText)
932
+ // );
933
+ // } else {
934
+ // // Restore the original checked state when search text is cleared
935
+ // this.filteredCountries = this.countires.map(country => ({
936
+ // ...country,
937
+ // checked: this.selectedFilters.country.find((l:any) => l.allCountry === country.allCountry)?.checked || false
938
+ // }));
939
+ // }
940
+ // }
941
+ getCountry() {
942
+ let obj = {
943
+ clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId,
944
+ };
945
+ this.auth.getCountry(obj).subscribe({
946
+ next: (res) => {
947
+ // Extract selected countries from existing filters (if any)
948
+ let countryList = this.selectedFilters?.country?.filter((country) => country.checked).map((loc) => loc.country);
949
+ // Map API response to frontend model
950
+ this.countries = res?.data?.countryData.map((item) => ({
951
+ country: item.country,
952
+ // checked: countryList?.length ? countryList.includes(item.country) : true,
953
+ // checked: cityList?.length ? cityList.includes(city.city) : true,
954
+ checked: countryList?.includes(item.country) ? true : false,
955
+ }));
956
+ if (this.selectedFilters.country && Array.isArray(this.selectedFilters.country)) {
957
+ this.filteredCountries = this.countries.map(location => {
958
+ const matchedLocation = this.selectedFilters.country.find((loc) => loc.country === location.country);
959
+ return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;
960
+ });
961
+ }
962
+ else {
963
+ this.filteredCountries = this.countries;
964
+ }
965
+ // Initially, all countries are visible
966
+ this.filteredCountries = [...this.countries];
967
+ // If a search text already exists, filter immediately
968
+ if (this.searchCountryText) {
969
+ this.filterCountries();
970
+ }
971
+ // Fetch stores if at least one country is selected
972
+ let selectedCountries = this.countries.filter((country) => country.checked);
973
+ if (selectedCountries.length > 0) {
974
+ setTimeout(() => {
975
+ this.getLocations();
976
+ this.getStore(); // fetch stores
977
+ }, 1000);
978
+ }
979
+ },
980
+ error: (err) => {
981
+ console.error("Failed to fetch countries", err);
982
+ },
983
+ });
984
+ }
985
+ selectedCountriesLabel() {
986
+ const selectedCountries = this.searchCountryText.length
987
+ ? this.filteredCountries.filter(country => country.checked).map(country => country.country)
988
+ : this.countries.filter(country => country.checked).map(country => country.country);
989
+ return selectedCountries.length === 0
990
+ ? ''
991
+ : selectedCountries.length === 1
992
+ ? selectedCountries[0]
993
+ : `${selectedCountries.length} countries`;
994
+ }
995
+ filterCountries() {
996
+ const searchText = this.searchCountryText.toLowerCase();
997
+ if (searchText) {
998
+ // Filter and preserve checked state
999
+ this.filteredCountries = this.countries
1000
+ .map(country => ({
1001
+ ...country,
1002
+ checked: this.filteredCountries.find(c => c.country === country.country)?.checked || false
1003
+ }))
1004
+ .filter(country => country.country.toLowerCase().includes(searchText));
1005
+ }
1006
+ else {
1007
+ // Reset to full list
1008
+ this.filteredCountries = this.countries.map((country) => ({
1009
+ ...country,
1010
+ checked: this.selectedFilters.country?.find((c) => c.country === country.country)?.checked || false
1011
+ }));
1012
+ }
1013
+ }
1014
+ isAllCountriesSelected() {
1015
+ return this.filteredCountries.length > 0 && this.filteredCountries.every(country => country.checked);
1016
+ }
1017
+ toggleSelectAllCountries(event) {
1018
+ const isChecked = event.target.checked;
1019
+ this.filteredCountries.forEach((country) => (country.checked = isChecked));
1020
+ this.updateSelectedCountries();
1021
+ }
1022
+ updateSelectedCountries() {
1023
+ // When locations are selected, fetch the related groups
1024
+ const selectedCountries = this.filteredCountries
1025
+ .filter((country) => country.checked)
1026
+ .map((country) => country.country);
1027
+ this.filteredCountries.forEach((country) => {
1028
+ let findCountryIndex = this.countries.findIndex((loc) => loc.country == country.country);
1029
+ if (findCountryIndex != -1) {
1030
+ this.countries[findCountryIndex].checked = country.checked;
1031
+ }
1032
+ });
1033
+ if (selectedCountries.length > 0 || !selectedCountries.length) {
1034
+ this.selectedFilters.stores = [];
1035
+ this.groupsData = [];
1036
+ this.locations = [];
1037
+ this.getLocations();
1038
+ this.getGroups(); // Fetch groups based on selected cities
1039
+ // If there are selected groups, fetch the stores based on selected groups
1040
+ this.getStore();
1041
+ this.selectedFilters.country = this.filteredCountries;
1042
+ }
1043
+ else {
1044
+ this.filteredGroups = []; // Clear groups if no locations are selected
1045
+ this.selectedFilters.country = [];
1046
+ }
1047
+ this.selectedFilters.group = [];
1048
+ this.filteredStores = []; // Reset stores as well
1049
+ this.searchGroupText = '';
1050
+ this.searchStoreText = '';
1051
+ // this.Opendropdown = false;
1052
+ }
1053
+ removeCountry() {
1054
+ this.Reset();
1055
+ }
1056
+ Apply() {
1057
+ // Close the dropdown
1058
+ this.Opendropdown = false;
1059
+ // Fetch existing filters from localStorage
1060
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters1") || "{}");
1061
+ this.selectedFilters.store = null;
1062
+ // Ensure current selections are reflected
1063
+ this.selectedFilters.country = this.filteredCountries;
1064
+ this.selectedFilters.location = this.locations;
1065
+ this.selectedFilters.group = this.groupsData;
1066
+ this.selectedFilters.stores = headerFilters.stores ? headerFilters.stores : this.stores;
1067
+ // Store updated filters back in localStorage
1068
+ localStorage.setItem("header-filters1", JSON.stringify(this.selectedFilters));
1069
+ // this.gs.dataRangeValue.next(this.selectedFilters);
1070
+ window.location.reload();
1071
+ // Emit the updated filters via the service
1072
+ // this.gs.dataRangeValue.next(this.selectedFilters);
1073
+ // Trigger refresh if necessary
1074
+ // this.gs.manageRefreshTrigger.next(true);
1075
+ this.cd.detectChanges();
1076
+ }
1077
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ZoneHeaderComponent, deps: [{ token: i1.AuthService }, { token: i2.Router }, { token: i3.GlobalStateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
1078
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ZoneHeaderComponent, selector: "lib-zone-header", host: { listeners: { "document:click": "clickOutside($event)" } }, ngImport: i0, template: "<div class=\"\">\r\n <label *ngIf=\"selectedCountriesLabel()\" class=\"badge badge-light-default mx-2\">{{selectedCountriesLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeCountry()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedLocationsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedLocationsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeLocation()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedGroupsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedGroupsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label class=\"badge badge-light-default\">{{selectedStoresLabel()}}</label>\r\n</div>\r\n\r\n\r\n<div class=\"wrapper me-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<!-- <div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div> -->\r\n<div class=\"position-relative\">\r\n <button type=\"button\" (click)=\"opendropdown($event)\" class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n <!-- <span class=\"me-2\">Filter</span> -->\r\n <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </button>\r\n\r\n <div *ngIf=\"Opendropdown\" class=\"card p-5 dropdown2 position-absolute z-1 end-0\" style=\"z-index: 1 !important;\" (clickOutside)=\"closeDropdown1()\">\r\n <div class=\"dropdown-title d-flex justify-content-between mb-2\">Filter Options\r\n <button class=\"btn btn-outline w-25 ms-3 btn-resize\" (click)=\"Reset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-25 btn-resize\" (click)=\"Apply()\">Apply</button>\r\n </div>\r\n\r\n <!-- Country Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('country')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedCountriesLabel()\"\r\n readonly\r\n placeholder=\"Select country\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'country'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search country\" \r\n [(ngModel)]=\"searchCountryText\" \r\n (ngModelChange)=\"filterCountries()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllCountries\" \r\n [checked]=\"isAllCountriesSelected()\" \r\n (change)=\"toggleSelectAllCountries($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllCountries\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let country of filteredCountries\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"country.country\" \r\n [(ngModel)]=\"country.checked\"\r\n (change)=\"updateSelectedCountries()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"country.country\">\r\n {{ country.country }}\r\n </label>\r\n \r\n </div>\r\n </div>\r\n</div>\r\n\r\n <!-- Location Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('location')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedLocationsLabel()\"\r\n readonly\r\n placeholder=\"Select Region\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'location'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search Region\" \r\n [(ngModel)]=\"searchLocationText\" \r\n (ngModelChange)=\"filterLocations()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllLocations\" \r\n [checked]=\"isAllLocationsSelected()\" \r\n (change)=\"toggleSelectAllLocations($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllLocations\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let location of filteredLocations\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"location.city\" \r\n [(ngModel)]=\"location.checked\"\r\n (change)=\"updateSelectedLocations()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"location.city\">\r\n {{ location.city }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('group')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedGroupsLabel()\" readonly\r\n placeholder=\"Select clusters\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'group'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search clusters\" \r\n [(ngModel)]=\"searchGroupText\" \r\n (ngModelChange)=\"filterGroups()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllGroups\" \r\n [checked]=\"isAllGroupsSelected()\" \r\n (change)=\"toggleSelectAllGroups($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllGroups\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let group of filteredGroups\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"group.groupName\"\r\n [(ngModel)]=\"group.checked\"\r\n (change)=\"updateSelectedGroups()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"group.groupName\">\r\n {{ group.groupName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n<!-- Store Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('store')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedStoresLabel()\"\r\n readonly\r\n placeholder=\"Select stores\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'store'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search stores\" \r\n [(ngModel)]=\"searchStoreText\" \r\n (ngModelChange)=\"filterStores()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllStores\" \r\n [checked]=\"isAllStoresSelected()\" \r\n (change)=\"toggleSelectAllStores($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllStores\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let store of filteredStores\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"store.storeId\"\r\n [(ngModel)]=\"store.checked\"\r\n (change)=\"updateSelectedStores()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"store.storeId\">\r\n {{ store.storeName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n </div>\r\n</div>", styles: [".daterangepicker{display:block!important;top:153.85px!important;left:900px!important;right:0}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize}::ng-deep .applyBtn{display:none!important}:host::ng-deep .md-drppicker .btn{line-height:10px!important}:host::ng-deep .daterangepicker-input+.ngx-daterangepicker-material .applyBtn{display:none}:host::ng-deep .md-drppicker.drops-down-right.ltr.double.show-ranges.shown{top:65px!important;left:-470px!important;height:365px!important}:host::ng-deep .md-drppicker .btn{border-radius:8px!important;border:1px solid var(--Primary-600, #00A3FF)!important;background:var(--Primary-600, #00A3FF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--White, #FFF)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize}:host::ng-deep .md-drppicker .ranges ul li button{padding:12px 16px;width:160px;color:var(--Gray-700, #344054);font-size:14px;font-weight:400;line-height:20px;background:none;border:none;text-align:left;cursor:pointer}:host::ng-deep .md-drppicker td.active,:host::ng-deep .md-drppicker td.active:hover{background-color:#029cf4!important;border-radius:20px!important;color:var(--White, #FFF)!important;text-align:center!important;font-size:14px!important;font-weight:500!important;line-height:20px}:host::ng-deep .md-drppicker.ltr .ranges{float:left;margin-top:10px!important}:host::ng-deep .md-drppicker td.in-range{background:var(--Primary-50, #EAF8FF)}:host::ng-deep .md-drppicker .ranges ul li button.active{background:var(--Primary-50, #EAF8FF)!important;border-radius:8px!important;color:var(--Primary-700, #009BF3);font-size:14px!important;font-weight:500!important;line-height:20px!important}:host::ng-deep table th,:host::ng-deep table td{width:40px!important;height:40px!important;padding:10px 8px!important}:host::ng-deep .md-drppicker td.available.prev,:host::ng-deep .md-drppicker th.available.prev{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep .md-drppicker td.available.next,:host::ng-deep .md-drppicker th.available.next{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep table th{border-bottom:0px solid var(--Gray-200, #EAECF0)!important;background:transparent!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:16px!important;font-weight:500!important;line-height:24px}:host::ng-deep .md-drppicker td.available.today{pointer-events:none;text-decoration:line-through;color:#a9a9a9}:host::ng-deep .md-drppicker .btn.btn-default{border-radius:8px!important;border:1px solid var(--Gray-300, #D0D5DD)!important;background:var(--White, #FFF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize;margin-right:10px!important}:host::ng-deep .md-drppicker td.available.invalid-date{text-decoration:line-through;pointer-events:none;color:#a9a9a9}.wrapper{min-width:200px}.btn-primary{line-height:18px!important}.filter-label{color:var(--Gray-500, #667085)!important;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-transform:capitalize}.position-relative{position:relative}.filter-icon{cursor:pointer}.dropdown-container{position:relative;display:inline-block;width:100%}.dropdown-header{cursor:pointer;width:100%}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize;width:100%;box-sizing:border-box}.dropdown-menu{position:absolute;top:100%;left:0;right:0;border:1px solid #ccc;background-color:#fff;z-index:1000;max-height:230px;overflow-y:auto;display:block;box-sizing:border-box;padding:10px 5px}.dropdown-item{padding:6px 0}.dropdown-item:hover{background-color:#f1f1f1}.dropdown-item input[type=checkbox]{margin-right:10px}.custom-dropdown-menu{border-radius:4px;box-shadow:0 1px 2px #1018280d}.custom-dropdown-item{display:flex;align-items:center}.custom-dropdown-item input{margin-left:10px}.btn-resize{font-size:13px!important;height:29px!important;line-height:11px!important;padding:3px!important}.dropdown2{position:absolute;top:70px;min-width:270px!important}.dropdown2 .dropdown-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:24px}.dropdown2 .dropdown{position:relative;display:inline-block}.dropdown2 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}.form-check-label{color:var(--Gray-700, #344054)!important;font-size:14px;font-style:normal;font-weight:500;line-height:20px}input[type=checkbox]{width:16px!important;height:16px!important;margin:0 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.CustomSelectComponent, selector: "lib-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] });
1079
+ }
1080
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ZoneHeaderComponent, decorators: [{
1081
+ type: Component,
1082
+ args: [{ selector: 'lib-zone-header', template: "<div class=\"\">\r\n <label *ngIf=\"selectedCountriesLabel()\" class=\"badge badge-light-default mx-2\">{{selectedCountriesLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeCountry()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedLocationsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedLocationsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeLocation()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedGroupsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedGroupsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label class=\"badge badge-light-default\">{{selectedStoresLabel()}}</label>\r\n</div>\r\n\r\n\r\n<div class=\"wrapper me-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<!-- <div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div> -->\r\n<div class=\"position-relative\">\r\n <button type=\"button\" (click)=\"opendropdown($event)\" class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n <!-- <span class=\"me-2\">Filter</span> -->\r\n <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </button>\r\n\r\n <div *ngIf=\"Opendropdown\" class=\"card p-5 dropdown2 position-absolute z-1 end-0\" style=\"z-index: 1 !important;\" (clickOutside)=\"closeDropdown1()\">\r\n <div class=\"dropdown-title d-flex justify-content-between mb-2\">Filter Options\r\n <button class=\"btn btn-outline w-25 ms-3 btn-resize\" (click)=\"Reset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-25 btn-resize\" (click)=\"Apply()\">Apply</button>\r\n </div>\r\n\r\n <!-- Country Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('country')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedCountriesLabel()\"\r\n readonly\r\n placeholder=\"Select country\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'country'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search country\" \r\n [(ngModel)]=\"searchCountryText\" \r\n (ngModelChange)=\"filterCountries()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllCountries\" \r\n [checked]=\"isAllCountriesSelected()\" \r\n (change)=\"toggleSelectAllCountries($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllCountries\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let country of filteredCountries\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"country.country\" \r\n [(ngModel)]=\"country.checked\"\r\n (change)=\"updateSelectedCountries()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"country.country\">\r\n {{ country.country }}\r\n </label>\r\n \r\n </div>\r\n </div>\r\n</div>\r\n\r\n <!-- Location Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('location')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedLocationsLabel()\"\r\n readonly\r\n placeholder=\"Select Region\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'location'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search Region\" \r\n [(ngModel)]=\"searchLocationText\" \r\n (ngModelChange)=\"filterLocations()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllLocations\" \r\n [checked]=\"isAllLocationsSelected()\" \r\n (change)=\"toggleSelectAllLocations($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllLocations\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let location of filteredLocations\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"location.city\" \r\n [(ngModel)]=\"location.checked\"\r\n (change)=\"updateSelectedLocations()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"location.city\">\r\n {{ location.city }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('group')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedGroupsLabel()\" readonly\r\n placeholder=\"Select clusters\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'group'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search clusters\" \r\n [(ngModel)]=\"searchGroupText\" \r\n (ngModelChange)=\"filterGroups()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllGroups\" \r\n [checked]=\"isAllGroupsSelected()\" \r\n (change)=\"toggleSelectAllGroups($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllGroups\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let group of filteredGroups\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"group.groupName\"\r\n [(ngModel)]=\"group.checked\"\r\n (change)=\"updateSelectedGroups()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"group.groupName\">\r\n {{ group.groupName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n<!-- Store Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('store')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedStoresLabel()\"\r\n readonly\r\n placeholder=\"Select stores\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'store'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search stores\" \r\n [(ngModel)]=\"searchStoreText\" \r\n (ngModelChange)=\"filterStores()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllStores\" \r\n [checked]=\"isAllStoresSelected()\" \r\n (change)=\"toggleSelectAllStores($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllStores\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let store of filteredStores\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"store.storeId\"\r\n [(ngModel)]=\"store.checked\"\r\n (change)=\"updateSelectedStores()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"store.storeId\">\r\n {{ store.storeName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n </div>\r\n</div>", styles: [".daterangepicker{display:block!important;top:153.85px!important;left:900px!important;right:0}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize}::ng-deep .applyBtn{display:none!important}:host::ng-deep .md-drppicker .btn{line-height:10px!important}:host::ng-deep .daterangepicker-input+.ngx-daterangepicker-material .applyBtn{display:none}:host::ng-deep .md-drppicker.drops-down-right.ltr.double.show-ranges.shown{top:65px!important;left:-470px!important;height:365px!important}:host::ng-deep .md-drppicker .btn{border-radius:8px!important;border:1px solid var(--Primary-600, #00A3FF)!important;background:var(--Primary-600, #00A3FF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--White, #FFF)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize}:host::ng-deep .md-drppicker .ranges ul li button{padding:12px 16px;width:160px;color:var(--Gray-700, #344054);font-size:14px;font-weight:400;line-height:20px;background:none;border:none;text-align:left;cursor:pointer}:host::ng-deep .md-drppicker td.active,:host::ng-deep .md-drppicker td.active:hover{background-color:#029cf4!important;border-radius:20px!important;color:var(--White, #FFF)!important;text-align:center!important;font-size:14px!important;font-weight:500!important;line-height:20px}:host::ng-deep .md-drppicker.ltr .ranges{float:left;margin-top:10px!important}:host::ng-deep .md-drppicker td.in-range{background:var(--Primary-50, #EAF8FF)}:host::ng-deep .md-drppicker .ranges ul li button.active{background:var(--Primary-50, #EAF8FF)!important;border-radius:8px!important;color:var(--Primary-700, #009BF3);font-size:14px!important;font-weight:500!important;line-height:20px!important}:host::ng-deep table th,:host::ng-deep table td{width:40px!important;height:40px!important;padding:10px 8px!important}:host::ng-deep .md-drppicker td.available.prev,:host::ng-deep .md-drppicker th.available.prev{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep .md-drppicker td.available.next,:host::ng-deep .md-drppicker th.available.next{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep table th{border-bottom:0px solid var(--Gray-200, #EAECF0)!important;background:transparent!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:16px!important;font-weight:500!important;line-height:24px}:host::ng-deep .md-drppicker td.available.today{pointer-events:none;text-decoration:line-through;color:#a9a9a9}:host::ng-deep .md-drppicker .btn.btn-default{border-radius:8px!important;border:1px solid var(--Gray-300, #D0D5DD)!important;background:var(--White, #FFF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize;margin-right:10px!important}:host::ng-deep .md-drppicker td.available.invalid-date{text-decoration:line-through;pointer-events:none;color:#a9a9a9}.wrapper{min-width:200px}.btn-primary{line-height:18px!important}.filter-label{color:var(--Gray-500, #667085)!important;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-transform:capitalize}.position-relative{position:relative}.filter-icon{cursor:pointer}.dropdown-container{position:relative;display:inline-block;width:100%}.dropdown-header{cursor:pointer;width:100%}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize;width:100%;box-sizing:border-box}.dropdown-menu{position:absolute;top:100%;left:0;right:0;border:1px solid #ccc;background-color:#fff;z-index:1000;max-height:230px;overflow-y:auto;display:block;box-sizing:border-box;padding:10px 5px}.dropdown-item{padding:6px 0}.dropdown-item:hover{background-color:#f1f1f1}.dropdown-item input[type=checkbox]{margin-right:10px}.custom-dropdown-menu{border-radius:4px;box-shadow:0 1px 2px #1018280d}.custom-dropdown-item{display:flex;align-items:center}.custom-dropdown-item input{margin-left:10px}.btn-resize{font-size:13px!important;height:29px!important;line-height:11px!important;padding:3px!important}.dropdown2{position:absolute;top:70px;min-width:270px!important}.dropdown2 .dropdown-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:24px}.dropdown2 .dropdown{position:relative;display:inline-block}.dropdown2 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}.form-check-label{color:var(--Gray-700, #344054)!important;font-size:14px;font-style:normal;font-weight:500;line-height:20px}input[type=checkbox]{width:16px!important;height:16px!important;margin:0 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}\n"] }]
1083
+ }], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.Router }, { type: i3.GlobalStateService }, { type: i0.ChangeDetectorRef }], propDecorators: { onClick: [{
1084
+ type: HostListener,
1085
+ args: ['document:click', ['$event']]
1086
+ }], clickOutside: [{
1087
+ type: HostListener,
1088
+ args: ["document:click", ["$event"]]
1089
+ }] } });
1090
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zone-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/zone-header/zone-header.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/zone-header/zone-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostListener,\r\n  OnInit,\r\n} from \"@angular/core\";\r\nimport dayjs from \"dayjs\";\r\nimport \"dayjs/locale/en\";\r\nimport { AuthService } from \"../../../../services/auth.service\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\nimport { NavigationEnd, Router } from \"@angular/router\";\r\n\r\n@Component({\r\n  selector: 'lib-zone-header',\r\n  templateUrl: './zone-header.component.html',\r\n  styleUrl: './zone-header.component.scss'\r\n})\r\nexport class ZoneHeaderComponent implements OnInit {\r\ndayjs = dayjs;\r\nisCustomDate = (m: dayjs.Dayjs) => {\r\n  if (m.isSame(this.dayjs(), \"day\")) {\r\n    return \"invalid-date\"; // disable today\r\n  }\r\n  return false;\r\n};\r\n\r\n  selectedDateRange: any = { startDate: dayjs().subtract(30, 'days'),\r\n    endDate: dayjs().subtract(1, \"days\"),};\r\n  selectedFilters: any = {\r\n    client: null,\r\n    clientName: null,\r\n    clients: [],\r\n    store: null,\r\n    stores: [],\r\n    date: null,\r\n    group: [],\r\n    location: [],\r\n    country: [],\r\n  };\r\n  Opendropdown: boolean = false;\r\n  dropdownOpen: string | null = null; // 'location' or 'group'\r\n  searchLocationText: string = \"\";\r\n  searchGroupText: string = \"\";\r\n  locations: any[] = [];\r\n  filteredLocations: any[] = [];\r\n  groupsData: any[] = [];\r\n  filteredGroups: any[] = [];\r\n  filteredStores: any[] = [];\r\n  stores:any[] = []\r\n  searchStoreText:string = '';\r\n  clientList:any = []\r\n  selectedClient:any\r\n  locationLabel: any[]=[];\r\n  groupLabel: any[]=[];\r\n  users: any;\r\n  url: any;\r\n  filteredCountries: any[] = [];\r\n  countryLabel: any[]=[];\r\n  searchCountryText: string = \"\";\r\n  countries: any[] = [];\r\n  constructor(\r\n    private auth: AuthService,    private router: Router,\r\n    public gs: GlobalStateService,\r\n    private cd: ChangeDetectorRef,\r\n  ) {}\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onClick (event: MouseEvent) {\r\n    const target = event.target as HTMLElement;\r\n    if(!target.closest('.dropdown2')) {\r\n      this.Opendropdown = false;\r\n    }\r\n  }\r\n  closeDropdown1(){\r\n    this.Opendropdown = false;\r\n  }\r\n\r\n  zoneData =[\r\n    {\r\n        \"storeId\": \"11-1578\",\r\n        \"storeName\": \"LKST1757\"\r\n    },\r\n    {\r\n        \"storeId\": \"11-1919\",\r\n        \"storeName\": \"LKST2329\"\r\n    },\r\n    {\r\n        \"storeId\": \"11-2222\",\r\n        \"storeName\": \"LKST2554\"\r\n    },\r\n    {\r\n        \"storeId\": \"11-2391\",\r\n        \"storeName\": \"LKST2598\"\r\n    },\r\n    {\r\n        \"storeId\": \"11-376\",\r\n        \"storeName\": \"LKST646\"\r\n    },\r\n    {\r\n        \"storeId\": \"11-82\",\r\n        \"storeName\": \"LKST84\"\r\n    }\r\n]\r\n\r\n  ngOnInit(): void {\r\n    // this.setRangesBasedOnRoute();\r\n\r\n    // Listen for route changes to update ranges\r\n    // this.router?.events?.subscribe((event) => {\r\n    //   if (event instanceof NavigationEnd) {\r\n    //     this.setRangesBasedOnRoute();\r\n    //   }\r\n    // });\r\n    this.url = this.router.url.split(\"?\")[0].split('/');\r\n    const user = JSON.parse(localStorage.getItem('user-info') as string);\r\n    this.users = user;\r\n    this.gs?.manageRefreshTrigger?.subscribe((e) => {      \r\n      if (e) {\r\n        if (user.userType === 'tango') {\r\n        this.getClient();\r\n        } else{\r\n          const storedFilters = localStorage.getItem(\"header-filters\");\r\n          if (storedFilters) {\r\n          const headerFilters = JSON.parse(storedFilters);\r\n          this.filteredStores = headerFilters?.stores.map((store:any) => ({\r\n            ...store,\r\n            checked: store.checked\r\n          }));\r\n        }\r\n        }\r\n      }\r\n    });\r\n \r\n    // Fetch client data if the user is of type 'tango'\r\n    if (user.userType === 'tango') {\r\n      this.getClient();\r\n    } else {\r\n      this.getCountry();\r\n      this.getLocations();\r\n      this.getGroups();\r\n      this.getStore();\r\n      const clientFilters = localStorage.getItem(\"client-details\");\r\n      if (clientFilters) {\r\n        const headerclientFilters = JSON.parse(clientFilters);\r\n      this.selectedClient = {\r\n      trafficDateRange : headerclientFilters.trafficDateRange\r\n      }\r\n      }\r\n    }\r\n   \r\n    // Load filters from localStorage if they exist\r\n    const storedFilters = localStorage.getItem(\"header-filters1\");\r\n    if (storedFilters) {\r\n      const headerFilters = JSON.parse(storedFilters);\r\n   if (headerFilters.date) {\r\n    \r\n        this.selectedDateRange = {\r\n          startDate: this.dayjs(\"09-09-2025\").format(\"YYYY-MM-DD\"),\r\n          endDate: this.dayjs(\"09-09-2025\").format(\"YYYY-MM-DD\"),\r\n          \r\n        };\r\n      headerFilters.date = this.selectedDateRange;\r\n      } \r\n      \r\n      // Initialize selectedFilters with defaults or existing values\r\n      this.selectedFilters = {\r\n        client: headerFilters.client || this.users.client || '11',\r\n        clientName: headerFilters.clientName || '',\r\n        clients: headerFilters.clients || [],\r\n        store: headerFilters.store || null,\r\n        date: headerFilters.date || {},\r\n        stores: headerFilters.stores || [],\r\n        group: headerFilters.group || [],\r\n        location: headerFilters.location || [],\r\n        country: headerFilters.country || []\r\n      };\r\n  \r\n      // Sync filtered data with stored selections\r\n      this.filteredCountries = this.syncWithLocalStorage(headerFilters.country);\r\n      this.filteredLocations = this.syncWithLocalStorage(headerFilters.location);\r\n      this.filteredGroups = this.syncWithLocalStorage(headerFilters.group);\r\n      this.filteredStores = this.syncWithLocalStorage(headerFilters.stores);\r\n  \r\n      // Format date range if it exists\r\n      if (headerFilters.date) {\r\n    \r\n         this.selectedDateRange = {\r\n          startDate: this.dayjs(\"09-09-2025\").format(\"YYYY-MM-DD\"),\r\n          endDate: this.dayjs(\"09-09-2025\").format(\"YYYY-MM-DD\"),\r\n        };\r\n      } \r\n       headerFilters.date = this.selectedDateRange;\r\n      // console.log(\"3\")\r\n      // Emit data via service and update localStorage\r\nthis.emitAndStoreFilters();\r\n    } else {\r\n      // Initialize empty states if no header filters are present in localStorage\r\n      this.resetFilters();\r\n      // console.log(\"2\")\r\n    }\r\n  }\r\n  private syncWithLocalStorage(items: any[]): any[] {\r\n    return items\r\n      ? items.map((item: any) => ({\r\n          ...item,\r\n          checked: item.checked === true\r\n        }))\r\n      : [];\r\n  }\r\n  \r\n  private emitAndStoreFilters(): void {\r\n    this.gs.dataRangeValue.next(this.selectedFilters);\r\n    localStorage.setItem(\"header-filters1\", JSON.stringify(this.selectedFilters));\r\n    // console.log(\"1\")\r\n  }\r\n  \r\n  /**\r\n   * Reset selectedFilters and all related arrays to empty states\r\n   */\r\n  private resetFilters(): void {\r\n    this.selectedFilters = {\r\n      client: null,\r\n      clientName: '',\r\n      clients: [],\r\n      store: null,\r\n      date: {},\r\n      stores: [],\r\n      group: [],\r\n      location: [],\r\n      country: []\r\n    };\r\n    this.filteredLocations = [];\r\n    this.filteredGroups = [];\r\n    this.filteredStores = [];\r\n    this.filteredCountries = [];\r\n  }\r\ngetClient(){\r\n  this.auth.getClients().subscribe({\r\n    next: (e) => {\r\n      if (e) {\r\n        this.clientList = e.data.result;\r\n        const headerFilters: any = JSON.parse(\r\n          localStorage.getItem(\"header-filters1\") || \"{}\"\r\n        );\r\n        if (headerFilters.client) {\r\n          this.clientList.find((obj: any) => {\r\n            if (obj.clientId === headerFilters.client) {\r\n              this.selectedClient = obj;\r\n            }\r\n          });\r\n          // const startDate = this.dayjs(headerFilters.date.startDate);\r\n          // const endDate = this.dayjs(headerFilters.date.endDate);\r\n          // const differenceInDays = endDate.diff(startDate, 'days');\r\n          // if (differenceInDays >= 90 && this.selectedClient?.trafficDateRange === 90) {\r\n          //   this.selectedDateRange = {\r\n          //     startDate: this.dayjs(headerFilters.date.startDate, \"YYYY-MM-DD\").subtract(-90, 'days').format(\"DD-MM-YYYY\"),\r\n          //     endDate: this.dayjs(headerFilters.date.endDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n          //   };\r\n          // } else {\r\n          //   this.selectedDateRange = {\r\n          //     startDate: this.dayjs(this.selectedDateRange.startDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n          //     endDate: this.dayjs(this.selectedDateRange.endDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n          //   };\r\n          // }\r\n          this.selectedFilters.client = headerFilters.client;\r\n          this.selectedFilters.clientName = headerFilters.clientName;\r\n          this.selectedFilters.clients = headerFilters.clients;\r\n          this.selectedFilters.store = headerFilters.store;\r\n          this.selectedFilters.date = headerFilters.date;\r\n          this.selectedFilters.stores = headerFilters.stores;\r\n          this.selectedFilters.group = headerFilters.group;\r\n          this.selectedFilters.location = headerFilters.location;\r\n          this.selectedFilters.country = headerFilters.country;\r\n          this.gs.dataRangeValue.next(this.selectedFilters);\r\n          // console.log(\"2\")\r\n                 // Ensure locations and groups are loaded before fetching stores\r\n this.getCountry();  \r\n this.getLocations();\r\n this.getGroups();\r\n  // Fetch stores only after locations and groups are set\r\n  this.getStore();\r\n      } else {\r\n        this.selectedClient = this.clientList[0];\r\n        this.selectedFilters.client =  this.selectedClient.clientId ? this.selectedClient.clientId :'11' ;\r\n        this.selectedFilters.clientName = this.selectedClient.clientName\r\n      this.selectedFilters.clients = headerFilters.clients;\r\n      this.selectedFilters.store = headerFilters.store;\r\n      this.selectedFilters.date = headerFilters.date;\r\n      this.selectedFilters.stores = headerFilters.stores;\r\n      this.selectedFilters.group = headerFilters.group;\r\n      this.selectedFilters.location = headerFilters.location;\r\n      this.selectedFilters.country = headerFilters.country;\r\n        localStorage.setItem(\r\n          \"header-filters1\",\r\n          JSON.stringify(this.selectedFilters) \r\n        );\r\n        this.gs.dataRangeValue.next(this.selectedFilters);\r\n        // console.log(\"3\")\r\n        this.cd.detectChanges();\r\n               // Ensure locations and groups are loaded before fetching stores\r\n this.getCountry();\r\n this.getLocations();\r\n this.getGroups();\r\n  // Fetch stores only after locations and groups are set\r\n  this.getStore();\r\n      }\r\n\r\n\r\n    } else {\r\n      this.selectedClient = this.clientList[0];\r\n      this.selectedFilters.client =  this.selectedClient.clientId ? this.selectedClient.clientId :'11';\r\n      this.selectedFilters.clientName = this.selectedClient.clientName\r\n       // Ensure locations and groups are loaded before fetching stores\r\n this.getCountry();\r\n this.getLocations();\r\n this.getGroups();\r\n // Fetch stores only after locations and groups are set\r\n this.getStore();\r\n      localStorage.setItem(\r\n        \"header-filters1\",\r\n        JSON.stringify(this.selectedFilters) \r\n      );\r\n      this.gs.dataRangeValue.next(this.selectedFilters);\r\n      // console.log(\"4\")\r\n      this.cd.detectChanges();\r\n    }\r\n  this.getUserInfo(this.selectedFilters.client);\r\n\r\n    },\r\n  });\r\n}\r\ngetUserInfo(client:any){\r\n  let obj ={\r\n      clientId: client ? client :'11'\r\n  }\r\n  if(client){\r\n    this.auth.getHeaderUsers(obj).subscribe({\r\n      next: (e) => {\r\n        localStorage.setItem(\r\n          \"usersEmail-info\",\r\n          JSON.stringify(e?.data?.userEmailData || [])\r\n        );\r\n      } \r\n    })\r\n  }\r\n}\r\nonClientSelect(event: any): void {\r\n  // Update the selected client\r\n  this.selectedClient = event;\r\n  // Clear previous filtered data and selections\r\n  this.filteredGroups = [];\r\n  this.filteredStores = [];\r\n  this.filteredLocations = [];\r\n  this.selectedFilters.stores = [];\r\n  this.selectedFilters.group = [];\r\n  this.selectedFilters.location = [];\r\n  this.selectedFilters.country = [];\r\n\r\n\r\n  // Fetch header filters from localStorage\r\n  const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters1\") || \"{}\");\r\n  \r\n  // Update the selected filters with the new client\r\n  this.selectedFilters.client = this.selectedClient.clientId ? this.selectedClient.clientId :'11';\r\n  this.selectedFilters.clientName = this.selectedClient.clientName;\r\n  \r\n  // Remove old store, group, and location data from the header filters\r\n  delete headerFilters.stores;\r\n  delete headerFilters.groups;\r\n  delete headerFilters.location;\r\n  delete headerFilters.country;\r\n\r\n  \r\n  // Fetch new data based on the new client\r\n  this.getCountry();\r\n  this.getLocations();\r\n  this.getStore();\r\n  this.getGroups();\r\n\r\n  // Update localStorage with the new client selection and empty filter data\r\n  localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));\r\n  window.location.reload()\r\n  // Emit data to the global service\r\n  // this.gs.dataRangeValue.next(this.selectedFilters);\r\n  // Trigger change detection to reflect UI changes\r\n  this.cd.detectChanges();\r\n}\r\n\r\n\r\n\r\nranges:any = {\r\n  // Today: [dayjs(), dayjs()],\r\n  Yesterday: [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],\r\n  'This Week': [dayjs().subtract(7, 'days'), dayjs().subtract(1, 'days')],\r\n  'Last Week': [\r\n    dayjs().subtract(14, 'days').startOf('day'),\r\n    dayjs().subtract(8, 'days').endOf('day'),\r\n  ],\r\n  'This Month': [dayjs().subtract(30, 'days'), dayjs().subtract(1, 'days')],\r\n  'Last Month': [\r\n    dayjs().subtract(1, 'month').startOf('month'),\r\n    dayjs().subtract(1, 'month').endOf('month'),\r\n  ],\r\n};\r\n\r\n  onStartDateChange(event: any) {\r\n    if (this.dayjs(event.startDate).isValid()) {\r\n         if(this.selectedClient?.traxDateRange === 90){\r\n             this.isCustomDate = (m: dayjs.Dayjs) => {\r\n               const isValidDate =\r\n                 m > this.dayjs() || m > this.dayjs(event.startDate.add(90, \"days\"));\r\n               return isValidDate ? \"invalid-date\" : false;\r\n             };\r\n           } else {\r\n            this.isCustomDate = (m: dayjs.Dayjs) => {\r\n        const isValidDate =\r\n          m > this.dayjs() || m > this.dayjs(event.startDate.add(180, \"days\"));\r\n        return isValidDate ? \"invalid-date\" : false;\r\n      };\r\n         }\r\n    \r\n    }\r\n  }\r\n\r\n  datechange(event: any) {\r\n    if (event && event.startDate && event.endDate) {\r\n      if (\r\n        this.dayjs(event.startDate).isValid() &&\r\n        this.dayjs(event.endDate).isValid()\r\n      ) {\r\n        this.selectedDateRange.startDate = event.startDate;\r\n        this.selectedDateRange.endDate = event.endDate;\r\n        var datetime = {\r\n          startDate: this.dayjs(event.startDate, \"DD-MM-YYYY\").format(\r\n            \"YYYY-MM-DD\"\r\n          ),\r\n          endDate: this.dayjs(event.endDate, \"DD-MM-YYYY\").format(\"YYYY-MM-DD\"),\r\n        };\r\n        this.selectedFilters.date = datetime;\r\n        localStorage.setItem(\r\n          \"header-filters1\",\r\n          JSON.stringify(this.selectedFilters)\r\n        );\r\n        window.location.reload()\r\n      // this.gs.dataRangeValue.next(this.selectedFilters);\r\n      }\r\n    } \r\n  }\r\n  opendropdown(e:MouseEvent) {\r\n    e.stopPropagation();\r\n    this.Opendropdown = !this.Opendropdown;\r\n  }\r\n  getLocations(): void {\r\n    const country = this.countries\r\n    .filter(country => country.checked)\r\n    .map(country => country.country);  \r\n    // const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters1\") || \"{}\");\r\n    let obj ={\r\n     clientId: this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId || '11',\r\n     country,\r\n     city: [],\r\n     group: [],\r\n    }\r\n    this.auth.getLocation(obj).subscribe({\r\n      next: (res: any) => {\r\n        let cityList = this.selectedFilters?.location?.filter((location:any) => location.checked).map((loc:any) => loc.city);\r\n        // Map the fetched locations with default unchecked state\r\n        this.locations = res?.data?.locationData.map((city: any) => ({\r\n          city: city.city,\r\n          // checked: cityList?.length ? cityList.includes(city.city) : true,\r\n          checked: cityList?.includes(city.city) ? true : false,\r\n        }));\r\n  \r\n        // Sync the fetched locations with any stored checked values in localStorage\r\n        if (this.selectedFilters.location && Array.isArray(this.selectedFilters.location)) {\r\n          this.filteredLocations = this.locations.map(location => {\r\n            const matchedLocation = this.selectedFilters.location.find((loc: any) => loc.city === location.city);\r\n            return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;\r\n          });\r\n        } else {\r\n          this.filteredLocations = this.locations;\r\n        }\r\n\r\n        if(this.searchLocationText) {\r\n          this.filteredLocations = this.locations.filter((location:any) => location.city.toLowerCase().includes(this.searchLocationText.toLowerCase()))\r\n        }\r\n        const selectedLocations = this.locations.filter((location) => location.checked).map((location) => location.city);\r\n        if (selectedLocations.length > 0) {\r\n          setTimeout(()=>{\r\n            this.getGroups();\r\n            this.getStore(); // Fetch stores based on selected groups\r\n          },1000)\r\n        }\r\n\r\n        if(!selectedLocations.length && country.length) {\r\n          this.getGroups();\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch locations\", err);\r\n      },\r\n    });\r\n  }\r\n  \r\n  isAllLocationsSelected(): boolean {\r\n    return this.filteredLocations.every(location => location.checked);\r\n\r\n  }\r\n  \r\n  selectedLocationsLabel(): string {\r\n    const selectedLocations = this.locationLabel = this.searchLocationText.length ? this.locations\r\n      .filter(location => location.checked).map(location => location.city) :  this.filteredLocations\r\n      .filter(location => location.checked).map(location => location.city);\r\n    return selectedLocations.length === 0\r\n      ? ''\r\n      : selectedLocations.length === 1\r\n      ? selectedLocations[0]\r\n      : `${selectedLocations.length} Regions`;\r\n  }\r\n\r\n  removeLocation(): void {\r\n    this.Reset();\r\n  }\r\n  \r\n  getGroups(): void {  \r\n    const country = this.countries\r\n      .filter(country => country.checked)\r\n      .map(country => country.country);  \r\n    let city;\r\n    city = this.locations\r\n      .filter(location => location.checked)\r\n      .map(location => location.city);\r\n\r\n      if(!city.length && country.length) {\r\n        city = this.locations.map((loc) => loc.city);\r\n      }\r\n    const obj = { country,city,clientId:this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId,group:[] };\r\n    this.auth.getGroups(obj).subscribe({\r\n      next: (res: any) => {\r\n        let checkedGroup = this.selectedFilters?.group?.filter((group:any) => group.checked).map((group:any) => group.groupName);\r\n        const combinedGroups = res?.data?.groupData?.map((groupName: any) => ({\r\n          groupName: groupName.groupName,\r\n          checked: checkedGroup?.includes(groupName.groupName) ? true : false,\r\n          // checked: checkedGroup?.length ? checkedGroup.includes(groupName.groupName) : true,\r\n        }));\r\n        this.groupsData = combinedGroups;\r\n        if(this.searchGroupText.length) {\r\n          this.filteredGroups = combinedGroups.filter((item:any) => item.groupName.toLowerCase().includes(this.searchGroupText));\r\n        }\r\n        else {\r\n          this.filteredGroups = combinedGroups;\r\n        }\r\n  \r\n        // Auto-fetch stores when groups are selected\r\n        const selectedGroups = this.groupsData.filter((group) => group.checked).map((group) => group.groupName);\r\n        if (selectedGroups.length > 0) {\r\n          setTimeout(()=>{\r\n            this.getStore(); // Fetch stores based on selected groups\r\n          },1000)\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch groups\", err);\r\n      },\r\n    });\r\n  }\r\n\r\n  toggleDropdown(type: 'country' | 'location' | 'group' | 'store'): void {\r\n    if (this.dropdownOpen === type) {\r\n      // If the dropdown is open, close it and avoid resetting the selected values unnecessarily\r\n      this.dropdownOpen = null;\r\n    } else {\r\n      // Open the specific dropdown and handle data fetching only if necessary\r\n      this.dropdownOpen = type;\r\n\r\n      if (type === 'country') {\r\n        // Fetch countries only if not already fetched and no search text exists\r\n        if ((!this.filteredCountries || this.filteredCountries.length === 0) && !this.searchCountryText.trim()) {\r\n          this.getCountry();\r\n        }\r\n      }\r\n  \r\n      if (type === 'group') {\r\n        // Fetch groups only if there are selected cities and no active search text\r\n        const selectedCities = this.locations\r\n          .filter((location) => location.checked)\r\n          .map((location) => location.city);\r\n  \r\n        // Fetch groups only if locations are selected, no search text exists, and dropdown is opened\r\n      if (this.filteredLocations.length > 0 || (selectedCities.length > 0 && !this.searchGroupText.trim())) {\r\n        this.getGroups();\r\n      } else {\r\n        this.filteredGroups = []; // Clear groups if no locations are selected\r\n      }\r\n    }\r\n\r\n    if (type === 'store') {\r\n      // Fetch stores only if not already fetched and no search text is active\r\n      if ((!this.filteredStores || this.filteredStores.length === 0) && !this.searchStoreText.trim()) {\r\n        this.getStore();\r\n      } \r\n    }\r\n    }\r\n  }\r\n  \r\n  \r\n  handleGroupDropdownClick(): void {\r\n    if (this.dropdownOpen === 'group') {\r\n      this.resetSelectedGroups();\r\n    }\r\n    this.toggleDropdown('group');\r\n  }\r\n\r\n  resetSelectedGroups(): void {\r\n    this.filteredGroups.forEach((group) => (group.checked = false));\r\n    this.searchGroupText = \"\";\r\n  }\r\n  selectedGroupsLabel(): string {\r\n    const selectedGroups = this.groupLabel = this.searchGroupText.length ? this.groupsData.filter((group) => group.checked) : this.filteredGroups.filter((group) => group.checked);\r\n    return selectedGroups.length === 0\r\n      ? \"\"\r\n      : selectedGroups.length === 1\r\n      ? selectedGroups[0].groupName\r\n      : `${selectedGroups.length} Clusters`;\r\n  }\r\n  removeGroup(): void {\r\n    this.Reset();\r\n   \r\n  }\r\n  \r\n\r\n  isAllGroupsSelected(): boolean {\r\n    \r\n    return this.filteredGroups.length ? this.filteredGroups.every((group) => group.checked) : false;\r\n  }\r\n        \r\n  getStore(): void {\r\n    const country = this.countries\r\n    .filter(country => country.checked)\r\n    .map(country => country.country);\r\n    const city = this.locations\r\n      .filter(location => location.checked)\r\n      .map(location => location.city);\r\n    const group = this.groupsData\r\n      .filter(group => group.checked)\r\n      .map(group => group.groupName);\r\n  \r\n    const data = {\r\n      country,\r\n      city,\r\n      clusters: group,\r\n      clientId: this.users.clientId || this.selectedFilters.client\r\n    };\r\n  \r\n    this.auth.getHeaderStores(data).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200) {\r\n          // Initialize stores from API response\r\n          this.stores = this.zoneData;\r\n          // Check if there are previously selected stores\r\n          const checkedStoreIds = this.selectedFilters?.stores\r\n            ? this.selectedFilters.stores.filter((store:any) => store.checked).map((store:any) => store.storeId)\r\n            : [];\r\n          // Sync the `checked` state\r\n          this.stores.forEach(store => {\r\n            store.checked = checkedStoreIds.length\r\n              ? checkedStoreIds.includes(store.storeId) // Use previous selection\r\n              : true; // Default to true if no previous selection\r\n          });\r\n  \r\n          // Apply search filter if search text is present\r\n          if (this.searchStoreText.length) {\r\n            this.filteredStores = this.stores.filter(store =>\r\n              store.storeName.toLowerCase().includes(this.searchStoreText.toLowerCase())\r\n            );\r\n          } else {\r\n            this.filteredStores = [...this.stores];\r\n          }\r\n  \r\n          // Update `selectedFilters.stores` to reflect the current state\r\n          this.selectedFilters.stores = this.filteredStores.map(store => ({\r\n            storeId: store.storeId,\r\n            storeName: store.storeName,\r\n            checked: store.checked\r\n          }));\r\n          // this.selectedFilters.country = country;\r\n  \r\n          // Save updated filters to localStorage\r\n          localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));\r\n  \r\n          // Trigger UI change detection\r\n          this.cd.detectChanges();\r\n        } else {\r\n          // Handle empty or error response\r\n          this.clearStoresState();\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch stores\", err);\r\n        this.clearStoresState();\r\n      }\r\n    });\r\n  }\r\n  \r\n  // Clear stores state and reset filters\r\n  private clearStoresState(): void {\r\n    this.stores = [];\r\n    this.filteredStores = [];\r\n    this.selectedFilters.stores = [];\r\n    localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));\r\n  }\r\n  \r\n  resetSelectedStores(): void {\r\n    this.filteredStores.forEach((store) => (store.checked = false));\r\n    this.searchStoreText = \"\";\r\n  }\r\n\r\n  selectedStoresLabel(): string {\r\n    const selectedStores = this.searchStoreText.length ? this.stores.filter((store) => store.checked) : this.filteredStores.filter((store) => store.checked);\r\n    return selectedStores.length === 0\r\n      ? \"0 Stores\"\r\n      : selectedStores.length === 1\r\n      ? selectedStores[0].storeName\r\n      : `${selectedStores.length} Stores`;\r\n  }\r\n\r\n  isAllStoresSelected(): boolean {\r\n    return this.filteredStores.length > 0 && this.filteredStores.every(store => store.checked);\r\n  }\r\n// Method to handle dropdown item selection\r\nupdateSelectedStores(): void {\r\n  this.filteredStores.forEach(store => {\r\n    const filteredStore = this.stores.findIndex(fStore => fStore.storeId === store.storeId);\r\n    if (filteredStore != -1) {\r\n      this.stores[filteredStore].checked = store.checked; // Sync the checked state with full store list\r\n    }\r\n  });  \r\n  // Update selectedFilters based on the current store selection\r\n  this.selectedFilters.stores = this.stores.filter(store => store.checked);\r\n\r\n  // Update localStorage with the latest selection\r\n  localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));\r\n\r\n  // Emit updated filters via service\r\n  // this.gs.dataRangeValue.next(this.selectedFilters);\r\n\r\n  // Trigger change detection if necessary\r\n  this.cd.detectChanges();\r\n}\r\n  toggleSelectAllLocations(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredLocations.forEach((location) => (location.checked = isChecked));\r\n    this.updateSelectedLocations();\r\n  }\r\n\r\n  toggleSelectAllStores(event: Event): void {\r\n    const checked = (event.target as HTMLInputElement).checked;\r\n  \r\n    // Apply the selection to both filtered and full list of stores\r\n    this.filteredStores.forEach(store => store.checked = checked);\r\n    this.stores.forEach(store => {\r\n      const filteredStore = this.filteredStores.find(fStore => fStore.storeId === store.storeId);\r\n      if (filteredStore) {\r\n        store.checked = checked; // Sync the checked state with full store list\r\n      }\r\n    });\r\n  \r\n    // Update the selected stores and persist the selection\r\n    this.updateSelectedStores();\r\n  }\r\n\r\n  updateSelectedLocations(): void {\r\n    // When locations are selected, fetch the related groups\r\n    const selectedCities = this.filteredLocations\r\n      .filter((location) => location.checked)\r\n      .map((location) => location.city);\r\n    this.filteredLocations.forEach((location:any) => {\r\n      let findLocationIndex = this.locations.findIndex((loc:any) => loc.city == location.city);\r\n      if(findLocationIndex != -1) {\r\n        this.locations[findLocationIndex].checked = location.checked;\r\n      }\r\n    })\r\n    if (selectedCities.length > 0 || !selectedCities.length) {\r\n      this.selectedFilters.stores =[];\r\n      this.groupsData =[]\r\n      this.getGroups(); // Fetch groups based on selected cities\r\n      // If there are selected groups, fetch the stores based on selected groups\r\n      this.getStore();\r\n      this.selectedFilters.location = this.locations;\r\n     \r\n    } else {\r\n      this.filteredGroups = []; // Clear groups if no locations are selected\r\n      this.selectedFilters.location = [];\r\n    }\r\n    \r\n    this.selectedFilters.group = [];\r\n    this.filteredStores = []; // Reset stores as well\r\n    this.searchGroupText = '';\r\n    this.searchStoreText = '';\r\n    // this.Opendropdown = false;\r\n  }\r\n\r\n  toggleSelectAllGroups(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredGroups.forEach((group) => (group.checked = isChecked));\r\n    this.updateSelectedGroups();\r\n  }\r\n\r\n  updateSelectedGroups(): void {\r\n    // Fetch the relevant stores after groups are selected\r\n    const selectedGroups = this.filteredGroups\r\n      .filter((group) => group.checked)\r\n      .map((group) => group.groupName);\r\n\r\n    this.filteredGroups.forEach((group:any) => {\r\n      let findGroupIndex = this.groupsData.findIndex((item:any) => item.groupName == group.groupName);\r\n      if(findGroupIndex != -1) {\r\n        this.groupsData[findGroupIndex].checked = group.checked;\r\n      }\r\n    }) \r\n    if (selectedGroups.length > 0 || !selectedGroups.length) {\r\n      this.selectedFilters.stores =[];\r\n      // If there are selected groups, fetch the stores based on selected groups\r\n      this.getStore();\r\n      this.selectedFilters.group = this.groupsData;\r\n    } else {\r\n      // If no groups are selected, clear the stores list\r\n      this.filteredStores = [];\r\n      \r\n      // Also, update localStorage to reflect the cleared store selection\r\n      this.selectedFilters.stores = [];\r\n      localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));\r\n  \r\n      // Emit data via service\r\n      // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    }\r\n  \r\n    // Clear the search store text when groups are updated\r\n    this.searchStoreText = '';\r\n  }\r\n  \r\n\r\n  Reset(): void {\r\n    setTimeout(()=>{\r\n     // Clear selected groups, stores, and locations\r\n  this.filteredCountries = []\r\n  this.filteredGroups = [];\r\n  this.filteredStores = [];\r\n  this.filteredLocations = []; // Reset locations as well\r\nthis.locations =[];this.groupsData =[]; this.stores =[]; this.countries =[];\r\n  // Clear search input fields\r\n  this.searchLocationText = \"\";\r\n  this.searchGroupText = \"\";\r\n  this.searchStoreText = \"\";\r\nthis.selectedFilters.stores =[];\r\nthis.selectedFilters.group =[];\r\nthis.selectedFilters.location =[];\r\nthis.selectedFilters.country =[];\r\n\r\n \r\n  // Fetch locations, groups, and stores again\r\n  this.getCountry();\r\n  this.getLocations();\r\n  this.getStore();\r\n  this.getGroups();\r\n  // Reset the filters in selectedFilters\r\n\r\n\r\n  // // Once stores are fetched, mark all as checked\r\n  // setTimeout(() => {\r\n  //   this.filteredStores = this.stores.map(store => ({\r\n  //     ...store,\r\n  //     checked: true  // Mark all stores as checked\r\n  //   }));\r\n\r\n  //   // Sync selectedFilters with the updated store state\r\n  //   this.selectedFilters.stores = this.filteredStores.map(store => ({\r\n  //     ...store,\r\n  //     checked: true\r\n  //   }));\r\n\r\n    // Update localStorage with the latest selectedFilters\r\n    localStorage.setItem('header-filters1', JSON.stringify(this.selectedFilters));\r\n window.location.reload()\r\n    // Emit the reset filters to update other components if needed\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    // Trigger change detection\r\n    this.cd.detectChanges();\r\n   // Adding a slight delay to ensure stores are fetched first\r\n \r\n  \r\n    // Close dropdown after reset if necessary\r\n    this.Opendropdown = false;\r\n  },100)\r\n  }\r\n  \r\n  \r\n  \r\n\r\n  filterLocations(): void {    \r\n    const searchText = this.searchLocationText.toLowerCase();\r\n    \r\n    if (searchText) {\r\n      // Preserve the checked state during filtering\r\n      this.filteredLocations = this.locations\r\n        .map(location => ({\r\n          ...location,\r\n          checked: this.filteredLocations.find(l => l.city === location.city)?.checked || false\r\n        }))\r\n        .filter(location =>\r\n          location?.city?.toLowerCase().includes(searchText)\r\n        );\r\n    } else {\r\n      // Restore the original checked state when search text is cleared\r\n      this.filteredLocations = this.locations.map(location => ({\r\n        ...location,\r\n        checked: this.selectedFilters.location.find((l:any) => l.city === location.city)?.checked || false\r\n      }));\r\n    }\r\n  }\r\n  \r\n\r\n  filterGroups(): void {  \r\n    const searchText = this.searchGroupText.toLowerCase();\r\n    \r\n    if (searchText) {\r\n      // Preserve the checked state during filtering\r\n      this.filteredGroups = this.groupsData\r\n        .map(group => ({\r\n          ...group,\r\n          checked: this.filteredGroups.find(g => g.groupName === group.groupName)?.checked || false\r\n        }))\r\n        .filter(group =>\r\n          group?.groupName?.toLowerCase().includes(searchText)\r\n        );\r\n    } else {\r\n      // Restore the original checked state when search text is cleared\r\n      this.filteredGroups = this.groupsData.map(group => ({\r\n        ...group,\r\n        checked: this.selectedFilters.group.find((g:any) => g.groupName === group.groupName)?.checked || false\r\n      }));\r\n    }\r\n  }\r\n  \r\n  \r\n  filterStores(): void {\r\n    const searchText = this.searchStoreText.toLowerCase();\r\n    // Preserve checked states during filtering\r\n    if (searchText) {\r\n      // Filter based on search text while preserving checked state\r\n      this.filteredStores = this.stores\r\n        .map(store => ({\r\n          ...store,\r\n          // Check if the store is already checked in filteredStores, fallback to original stores' checked state\r\n          checked: this.selectedFilters.stores.find((s: any) => s.storeId === store.storeId)?.checked || store.checked || false\r\n        }))\r\n        .filter(store => store.storeName.toLowerCase().includes(searchText));\r\n    } else {\r\n      // When the search text is cleared, restore the original list with preserved checked states\r\n      this.filteredStores = this.stores.map(store => ({\r\n        ...store,\r\n        // Preserve the checked state based on the selected filters\r\n        checked: this.selectedFilters.stores.find((s: any) => s.storeId === store.storeId)?.checked || store.checked || false\r\n      }));\r\n    }\r\n  }\r\n\r\n  closeDropdown(): void {\r\n    this.dropdownOpen = null;\r\n  }\r\n\r\n  @HostListener(\"document:click\", [\"$event\"])\r\n  clickOutside(event: MouseEvent): void {\r\n    const clickedInside = (event.target as HTMLElement).closest(\r\n      \".dropdown-container\"\r\n    );\r\n    const clickedoutSide = (event.target as HTMLElement).closest(\r\n      \".dropdown2\"\r\n    );\r\n    if (!clickedInside) {\r\n      this.closeDropdown();\r\n    }\r\n    if(!clickedoutSide) {\r\n      this.closeDropdown1();\r\n    }\r\n\r\n  }\r\n\r\n  // getCountry(): void {\r\n  //   // const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters1\") || \"{}\");\r\n  //   let obj ={\r\n  //    clientId: this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId,\r\n  //   }\r\n  //   this.auth.getCountry(obj).subscribe({\r\n  //     next: (res: any) => {\r\n  //       let countryList = this.selectedFilters?.country?.filter((country:any) => country.checked).map((loc:any) => loc.allCountry);\r\n  //       // Map the fetched countries with default unchecked state\r\n  //       this.countires = res?.data?.countryData.map((allCountry: any) => ({\r\n  //         allCountry: allCountry.allCountry,\r\n  //         checked: countryList?.includes(allCountry.allCountry) ? true : false,\r\n  //       }));\r\n  \r\n  //       // Sync the fetched countries with any stored checked values in localStorage\r\n  //       if (this.selectedFilters.country && Array.isArray(this.selectedFilters.country)) {\r\n  //         this.filteredCountries = this.countries.map(country => {\r\n  //           const matchedLocation = this.selectedFilters.country.find((loc: any) => loc.allCountry === country.allCountry);\r\n  //           return matchedLocation ? { ...country, checked: matchedLocation.checked } : country;\r\n  //         });\r\n  //       } else {\r\n  //         this.filteredCountries = this.countries;\r\n  //       }\r\n\r\n  //       if(this.searchLocationText) {\r\n  //         this.filteredCountries = this.countries.filter((country:any) => country.city.toLowerCase().includes(this.searchLocationText.toLowerCase()))\r\n  //       }\r\n  //       const selectedCountries = this.countries.filter((country) => country.checked).map((country) => country.allCountry);\r\n  //       if (selectedCountries.length > 0) {\r\n  //         setTimeout(()=>{\r\n  //           this.getStore(); // Fetch stores based on selected groups\r\n  //         },1000)\r\n  //       }\r\n  //     },\r\n  //     error: (err) => {\r\n  //       console.error(\"Failed to fetch countries\", err);\r\n  //     },\r\n  //   });\r\n  // }\r\n\r\n  // selectedCountriesLabel(): string {\r\n  //   const selectedCountries = this.countryLabel = this.searchLocationText.length ? this.countries\r\n  //     .filter(country => country.checked).map(country => country.allCountry) :  this.filteredCountries\r\n  //     .filter(country => country.checked).map(country => country.allCountry);\r\n  //   return selectedCountries.length === 0\r\n  //     ? ''\r\n  //     : selectedCountries.length === 1\r\n  //     ? selectedCountries[0]\r\n  //     : `${selectedCountries.length} countries`;\r\n  // }\r\n\r\n  // isAllCountriesSelected(): boolean {\r\n  //   return this.filteredCountries.every(country => country.checked);\r\n\r\n  // }\r\n  // filterCountries(): void {    \r\n  //   const searchText = this.searchCountryText.toLowerCase();\r\n    \r\n  //   if (searchText) {\r\n  //     // Preserve the checked state during filtering\r\n  //     this.filteredCountries = this.countires\r\n  //       .map(country => ({\r\n  //         ...country,\r\n  //         checked: this.filteredCountries.find(l => l.allCountry === country.allCountry)?.checked || false\r\n  //       }))\r\n  //       .filter(location =>\r\n  //         location?.allCountry?.toLowerCase().includes(searchText)\r\n  //       );\r\n  //   } else {\r\n  //     // Restore the original checked state when search text is cleared\r\n  //     this.filteredCountries = this.countires.map(country => ({\r\n  //       ...country,\r\n  //       checked: this.selectedFilters.country.find((l:any) => l.allCountry === country.allCountry)?.checked || false\r\n  //     }));\r\n  //   }\r\n  // }\r\n  \r\n\r\n    getCountry(): void {\r\n    let obj = {\r\n      clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId,\r\n    };\r\n    \r\n    this.auth.getCountry(obj).subscribe({\r\n      next: (res: any) => {\r\n        // Extract selected countries from existing filters (if any)\r\n        let countryList = this.selectedFilters?.country?.filter((country: any) => country.checked).map((loc: any) => loc.country);\r\n  \r\n        // Map API response to frontend model\r\n        this.countries = res?.data?.countryData.map((item: any) => ({\r\n          country: item.country,\r\n          // checked: countryList?.length ? countryList.includes(item.country) : true,\r\n          // checked: cityList?.length ? cityList.includes(city.city) : true,\r\n          checked: countryList?.includes(item.country) ? true : false,\r\n          \r\n        }));\r\n        if (this.selectedFilters.country && Array.isArray(this.selectedFilters.country)) {\r\n          this.filteredCountries = this.countries.map(location => {\r\n            const matchedLocation = this.selectedFilters.country.find((loc: any) => loc.country === location.country);\r\n            return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;\r\n          });\r\n        } else {\r\n          this.filteredCountries = this.countries;\r\n        }\r\n\r\n\r\n        // Initially, all countries are visible\r\n        this.filteredCountries = [...this.countries];\r\n        \r\n\r\n        // If a search text already exists, filter immediately\r\n        if (this.searchCountryText) {\r\n          this.filterCountries();\r\n        }\r\n  \r\n        // Fetch stores if at least one country is selected\r\n        let selectedCountries = this.countries.filter((country) => country.checked);\r\n        if (selectedCountries.length > 0) {\r\n          setTimeout(() => {\r\n            this.getLocations();\r\n            this.getStore(); // fetch stores\r\n          }, 1000);\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch countries\", err);\r\n      },\r\n    });\r\n  }\r\n\r\n  selectedCountriesLabel(): string {\r\n    const selectedCountries = this.searchCountryText.length\r\n      ? this.filteredCountries.filter(country => country.checked).map(country => country.country)\r\n      : this.countries.filter(country => country.checked).map(country => country.country);\r\n  \r\n    return selectedCountries.length === 0\r\n      ? ''\r\n      : selectedCountries.length === 1\r\n      ? selectedCountries[0]\r\n      : `${selectedCountries.length} countries`;\r\n  }\r\n\r\n  filterCountries(): void {\r\n    const searchText = this.searchCountryText.toLowerCase();\r\n    \r\n    if (searchText) {\r\n      // Filter and preserve checked state\r\n      this.filteredCountries = this.countries\r\n        .map(country => ({\r\n          ...country,\r\n          checked: this.filteredCountries.find(c => c.country === country.country)?.checked || false\r\n        }))\r\n        .filter(country => country.country.toLowerCase().includes(searchText));\r\n    } else {\r\n      // Reset to full list\r\n      this.filteredCountries = this.countries.map((country: Country) => ({\r\n        ...country,\r\n        checked: this.selectedFilters.country?.find((c: any) => c.country === country.country)?.checked || false\r\n      }));\r\n    }\r\n  }\r\n\r\n  isAllCountriesSelected(): boolean {\r\n    return this.filteredCountries.length > 0 && this.filteredCountries.every(country => country.checked);\r\n  }\r\n  toggleSelectAllCountries(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredCountries.forEach((country) => (country.checked = isChecked));\r\n    this.updateSelectedCountries();\r\n    \r\n  }\r\n  \r\n  updateSelectedCountries(): void {\r\n    // When locations are selected, fetch the related groups\r\n    const selectedCountries = this.filteredCountries\r\n      .filter((country) => country.checked)\r\n      .map((country) => country.country);\r\n    this.filteredCountries.forEach((country:any) => {\r\n      let findCountryIndex = this.countries.findIndex((loc:any) => loc.country == country.country);\r\n      if(findCountryIndex != -1) {\r\n        this.countries[findCountryIndex].checked = country.checked;\r\n      }\r\n    })\r\n    if (selectedCountries.length > 0 || !selectedCountries.length) {\r\n      this.selectedFilters.stores =[];\r\n      this.groupsData =[]\r\n      this.locations =[];\r\n      this.getLocations();\r\n      this.getGroups(); // Fetch groups based on selected cities\r\n      // If there are selected groups, fetch the stores based on selected groups\r\n      this.getStore();\r\n      this.selectedFilters.country = this.filteredCountries;\r\n     \r\n    } else {\r\n      this.filteredGroups = []; // Clear groups if no locations are selected\r\n      this.selectedFilters.country = [];\r\n    }\r\n    \r\n    this.selectedFilters.group = [];\r\n    this.filteredStores = []; // Reset stores as well\r\n    this.searchGroupText = '';\r\n    this.searchStoreText = '';\r\n    // this.Opendropdown = false;\r\n  }\r\n\r\n  removeCountry(): void {\r\n    this.Reset();\r\n  }\r\n\r\n  Apply(): void {\r\n    // Close the dropdown\r\n    this.Opendropdown = false;\r\n  \r\n    // Fetch existing filters from localStorage\r\n    const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters1\") || \"{}\");\r\n    this.selectedFilters.store =  null\r\n  \r\n    // Ensure current selections are reflected\r\n    this.selectedFilters.country = this.filteredCountries;\r\n    this.selectedFilters.location = this.locations;\r\n    this.selectedFilters.group = this.groupsData;\r\n    this.selectedFilters.stores = headerFilters.stores ? headerFilters.stores : this.stores;\r\n    // Store updated filters back in localStorage\r\n    localStorage.setItem(\"header-filters1\", JSON.stringify(this.selectedFilters));\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    window.location.reload()\r\n    // Emit the updated filters via the service\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    // Trigger refresh if necessary\r\n    // this.gs.manageRefreshTrigger.next(true);\r\n    this.cd.detectChanges();\r\n  }\r\n  \r\n\r\n\r\n}\r\ninterface City {\r\n  city: string;\r\n}\r\n\r\ninterface Location {\r\n  city: City;\r\n  checked: boolean;\r\n}\r\ninterface Country {\r\n  country: string;\r\n  checked: boolean;\r\n}\r\n","<div class=\"\">\r\n    <label *ngIf=\"selectedCountriesLabel()\" class=\"badge badge-light-default mx-2\">{{selectedCountriesLabel()}} \r\n        <span class=\"cursor-pointer\" (click)=\"removeCountry()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span>\r\n    </label>\r\n    <label *ngIf=\"selectedLocationsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedLocationsLabel()}} \r\n        <span class=\"cursor-pointer\" (click)=\"removeLocation()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span>\r\n    </label>\r\n    <label *ngIf=\"selectedGroupsLabel()\"  class=\"badge badge-light-default mx-2\">{{selectedGroupsLabel()}} \r\n        <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span>\r\n    </label>\r\n    <label  class=\"badge badge-light-default\">{{selectedStoresLabel()}}</label>\r\n</div>\r\n\r\n\r\n<div class=\"wrapper me-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<!-- <div class=\"d-flex align-items-center position-relative my-1\">\r\n    <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n            <path\r\n                d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n                stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </span>\r\n    <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n        ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n        [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n        [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n        [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n        (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div> -->\r\n<div class=\"position-relative\">\r\n    <button type=\"button\" (click)=\"opendropdown($event)\"  class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n        <!-- <span class=\"me-2\">Filter</span> -->\r\n        <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </button>\r\n\r\n    <div *ngIf=\"Opendropdown\" class=\"card p-5 dropdown2 position-absolute z-1 end-0\" style=\"z-index: 1 !important;\" (clickOutside)=\"closeDropdown1()\">\r\n        <div class=\"dropdown-title d-flex justify-content-between mb-2\">Filter Options\r\n            <button class=\"btn btn-outline w-25 ms-3 btn-resize\" (click)=\"Reset()\"> Reset </button>\r\n            <button class=\"btn btn-primary w-25  btn-resize\" (click)=\"Apply()\">Apply</button>\r\n        </div>\r\n\r\n             <!-- Country Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('country')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedCountriesLabel()\"\r\n            readonly\r\n            placeholder=\"Select country\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'country'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search country\" \r\n            [(ngModel)]=\"searchCountryText\" \r\n            (ngModelChange)=\"filterCountries()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllCountries\" \r\n                [checked]=\"isAllCountriesSelected()\" \r\n                (change)=\"toggleSelectAllCountries($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllCountries\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let country of filteredCountries\"\r\n        >\r\n        <input \r\n        class=\"form-check-input cursor-pointer\" \r\n        type=\"checkbox\" \r\n        [id]=\"country.country\" \r\n        [(ngModel)]=\"country.checked\"\r\n        (change)=\"updateSelectedCountries()\" \r\n      />\r\n      <label class=\"form-check-label\" [for]=\"country.country\">\r\n        {{ country.country }}\r\n      </label>\r\n      \r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n     <!-- Location Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('location')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedLocationsLabel()\"\r\n            readonly\r\n            placeholder=\"Select Region\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'location'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search Region\" \r\n            [(ngModel)]=\"searchLocationText\" \r\n            (ngModelChange)=\"filterLocations()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllLocations\" \r\n                [checked]=\"isAllLocationsSelected()\" \r\n                (change)=\"toggleSelectAllLocations($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllLocations\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let location of filteredLocations\"\r\n        >\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                [id]=\"location.city\" \r\n                [(ngModel)]=\"location.checked\"\r\n                (change)=\"updateSelectedLocations()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"location.city\">\r\n                {{ location.city }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Group Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('group')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedGroupsLabel()\" readonly\r\n            placeholder=\"Select clusters\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'group'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search clusters\" \r\n            [(ngModel)]=\"searchGroupText\" \r\n            (ngModelChange)=\"filterGroups()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllGroups\" \r\n                [checked]=\"isAllGroupsSelected()\" \r\n                (change)=\"toggleSelectAllGroups($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllGroups\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let group of filteredGroups\"\r\n        >\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                [id]=\"group.groupName\"\r\n                [(ngModel)]=\"group.checked\"\r\n                (change)=\"updateSelectedGroups()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"group.groupName\">\r\n                {{ group.groupName }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n\r\n<!-- Store Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('store')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\"\r\n            [value]=\"selectedStoresLabel()\"\r\n            readonly\r\n            placeholder=\"Select stores\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'store'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search \" \r\n            placeholder=\"Search stores\" \r\n            [(ngModel)]=\"searchStoreText\" \r\n            (ngModelChange)=\"filterStores()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllStores\" \r\n                [checked]=\"isAllStoresSelected()\" \r\n                (change)=\"toggleSelectAllStores($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllStores\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let store of filteredStores\"\r\n        >\r\n            <input \r\n                class=\"form-check-input\" \r\n                type=\"checkbox\" \r\n                [id]=\"store.storeId\"\r\n                [(ngModel)]=\"store.checked\"\r\n                (change)=\"updateSelectedStores()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"store.storeId\">\r\n                {{ store.storeName }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n    </div>\r\n</div>"]}