mis-crystal-design-system 2.4.9 → 2.5.2

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 (308) hide show
  1. package/action-list/action-list.component.d.ts +0 -1
  2. package/action-list/index.d.ts +1 -1
  3. package/action-list/mis-crystal-design-system-action-list.metadata.json +1 -1
  4. package/action-list/public_api.d.ts +2 -2
  5. package/async-search-dropdown/async-dropdown.component.d.ts +4 -4
  6. package/async-search-dropdown/index.d.ts +1 -1
  7. package/async-search-dropdown/mis-crystal-design-system-async-search-dropdown.metadata.json +1 -1
  8. package/async-search-dropdown/public_api.d.ts +2 -2
  9. package/bundles/mis-crystal-design-system-action-list.umd.js +3 -11
  10. package/bundles/mis-crystal-design-system-action-list.umd.js.map +1 -1
  11. package/bundles/mis-crystal-design-system-action-list.umd.min.js +1 -1
  12. package/bundles/mis-crystal-design-system-action-list.umd.min.js.map +1 -1
  13. package/bundles/mis-crystal-design-system-async-search-dropdown.umd.js +15 -15
  14. package/bundles/mis-crystal-design-system-async-search-dropdown.umd.js.map +1 -1
  15. package/bundles/mis-crystal-design-system-async-search-dropdown.umd.min.js +1 -1
  16. package/bundles/mis-crystal-design-system-async-search-dropdown.umd.min.js.map +1 -1
  17. package/bundles/mis-crystal-design-system-button.umd.js +25 -25
  18. package/bundles/mis-crystal-design-system-button.umd.js.map +1 -1
  19. package/bundles/mis-crystal-design-system-button.umd.min.js +1 -1
  20. package/bundles/mis-crystal-design-system-button.umd.min.js.map +1 -1
  21. package/bundles/mis-crystal-design-system-checkbox.umd.js +5 -6
  22. package/bundles/mis-crystal-design-system-checkbox.umd.js.map +1 -1
  23. package/bundles/mis-crystal-design-system-checkbox.umd.min.js.map +1 -1
  24. package/bundles/mis-crystal-design-system-chip.umd.js +6 -7
  25. package/bundles/mis-crystal-design-system-chip.umd.js.map +1 -1
  26. package/bundles/mis-crystal-design-system-chip.umd.min.js +1 -1
  27. package/bundles/mis-crystal-design-system-chip.umd.min.js.map +1 -1
  28. package/bundles/mis-crystal-design-system-datepicker_v2.umd.js +28 -45
  29. package/bundles/mis-crystal-design-system-datepicker_v2.umd.js.map +1 -1
  30. package/bundles/mis-crystal-design-system-datepicker_v2.umd.min.js +2 -2
  31. package/bundles/mis-crystal-design-system-datepicker_v2.umd.min.js.map +1 -1
  32. package/bundles/mis-crystal-design-system-daterangepicker_v2.umd.js +28 -60
  33. package/bundles/mis-crystal-design-system-daterangepicker_v2.umd.js.map +1 -1
  34. package/bundles/mis-crystal-design-system-daterangepicker_v2.umd.min.js +1 -1
  35. package/bundles/mis-crystal-design-system-daterangepicker_v2.umd.min.js.map +1 -1
  36. package/bundles/mis-crystal-design-system-drawer.umd.js +9 -12
  37. package/bundles/mis-crystal-design-system-drawer.umd.js.map +1 -1
  38. package/bundles/mis-crystal-design-system-drawer.umd.min.js.map +1 -1
  39. package/bundles/mis-crystal-design-system-dropdown.umd.js +384 -29
  40. package/bundles/mis-crystal-design-system-dropdown.umd.js.map +1 -1
  41. package/bundles/mis-crystal-design-system-dropdown.umd.min.js +15 -1
  42. package/bundles/mis-crystal-design-system-dropdown.umd.min.js.map +1 -1
  43. package/bundles/mis-crystal-design-system-fab.umd.js +11 -14
  44. package/bundles/mis-crystal-design-system-fab.umd.js.map +1 -1
  45. package/bundles/mis-crystal-design-system-fab.umd.min.js.map +1 -1
  46. package/bundles/mis-crystal-design-system-input.umd.js +7 -7
  47. package/bundles/mis-crystal-design-system-input.umd.js.map +1 -1
  48. package/bundles/mis-crystal-design-system-input.umd.min.js +1 -1
  49. package/bundles/mis-crystal-design-system-input.umd.min.js.map +1 -1
  50. package/bundles/mis-crystal-design-system-loader.umd.js +3 -4
  51. package/bundles/mis-crystal-design-system-loader.umd.js.map +1 -1
  52. package/bundles/mis-crystal-design-system-loader.umd.min.js +1 -1
  53. package/bundles/mis-crystal-design-system-loader.umd.min.js.map +1 -1
  54. package/bundles/mis-crystal-design-system-modal.umd.js +8 -12
  55. package/bundles/mis-crystal-design-system-modal.umd.js.map +1 -1
  56. package/bundles/mis-crystal-design-system-modal.umd.min.js.map +1 -1
  57. package/bundles/mis-crystal-design-system-multi-select-dropdown.umd.js +61 -29
  58. package/bundles/mis-crystal-design-system-multi-select-dropdown.umd.js.map +1 -1
  59. package/bundles/mis-crystal-design-system-multi-select-dropdown.umd.min.js +2 -2
  60. package/bundles/mis-crystal-design-system-multi-select-dropdown.umd.min.js.map +1 -1
  61. package/bundles/mis-crystal-design-system-nested-multi-select-dropdown.umd.js +71 -32
  62. package/bundles/mis-crystal-design-system-nested-multi-select-dropdown.umd.js.map +1 -1
  63. package/bundles/mis-crystal-design-system-nested-multi-select-dropdown.umd.min.js +2 -2
  64. package/bundles/mis-crystal-design-system-nested-multi-select-dropdown.umd.min.js.map +1 -1
  65. package/bundles/mis-crystal-design-system-radio-button.umd.js +6 -7
  66. package/bundles/mis-crystal-design-system-radio-button.umd.js.map +1 -1
  67. package/bundles/mis-crystal-design-system-radio-button.umd.min.js +1 -1
  68. package/bundles/mis-crystal-design-system-radio-button.umd.min.js.map +1 -1
  69. package/bundles/mis-crystal-design-system-switch.umd.js +3 -4
  70. package/bundles/mis-crystal-design-system-switch.umd.js.map +1 -1
  71. package/bundles/mis-crystal-design-system-switch.umd.min.js +1 -1
  72. package/bundles/mis-crystal-design-system-switch.umd.min.js.map +1 -1
  73. package/bundles/mis-crystal-design-system-table.umd.js +40 -58
  74. package/bundles/mis-crystal-design-system-table.umd.js.map +1 -1
  75. package/bundles/mis-crystal-design-system-table.umd.min.js +1 -1
  76. package/bundles/mis-crystal-design-system-table.umd.min.js.map +1 -1
  77. package/bundles/mis-crystal-design-system-toast.umd.js +28 -33
  78. package/bundles/mis-crystal-design-system-toast.umd.js.map +1 -1
  79. package/bundles/mis-crystal-design-system-toast.umd.min.js +1 -1
  80. package/bundles/mis-crystal-design-system-toast.umd.min.js.map +1 -1
  81. package/bundles/mis-crystal-design-system-tooltip.umd.js +1 -1
  82. package/bundles/mis-crystal-design-system-tooltip.umd.js.map +1 -1
  83. package/bundles/mis-crystal-design-system-tooltip.umd.min.js +1 -1
  84. package/bundles/mis-crystal-design-system-tooltip.umd.min.js.map +1 -1
  85. package/bundles/mis-crystal-design-system.umd.js.map +1 -1
  86. package/button/button.component.d.ts +4 -4
  87. package/button/button.directive.d.ts +3 -3
  88. package/button/button.directive.scss +1 -1
  89. package/button/button.module.d.ts +1 -1
  90. package/button/index.d.ts +1 -1
  91. package/button/mis-crystal-design-system-button.metadata.json +1 -1
  92. package/button/public_api.d.ts +2 -2
  93. package/checkbox/checkbox.component.d.ts +3 -3
  94. package/checkbox/checkbox.module.d.ts +1 -1
  95. package/checkbox/index.d.ts +1 -1
  96. package/checkbox/mis-crystal-design-system-checkbox.metadata.json +1 -1
  97. package/checkbox/public_api.d.ts +2 -2
  98. package/chip/chip.component.d.ts +2 -2
  99. package/chip/chip.module.d.ts +1 -1
  100. package/chip/index.d.ts +1 -1
  101. package/chip/mis-crystal-design-system-chip.metadata.json +1 -1
  102. package/chip/public_api.d.ts +2 -2
  103. package/datepicker_v2/index.d.ts +1 -1
  104. package/datepicker_v2/mis-crystal-design-system-datepicker_v2.metadata.json +1 -1
  105. package/datepicker_v2/public_api.d.ts +3 -3
  106. package/datepicker_v2/tz-datepicker.directive.d.ts +0 -2
  107. package/daterangepicker_v2/index.d.ts +1 -1
  108. package/daterangepicker_v2/mis-crystal-design-system-daterangepicker_v2.metadata.json +1 -1
  109. package/daterangepicker_v2/public_api.d.ts +3 -3
  110. package/daterangepicker_v2/tz-daterangepicker.directive.d.ts +0 -1
  111. package/drawer/index.d.ts +1 -1
  112. package/drawer/mis-crystal-design-system-drawer.metadata.json +1 -1
  113. package/drawer/public_api.d.ts +4 -4
  114. package/dropdown/dropdown.component.d.ts +10 -4
  115. package/dropdown/dropdown.module.d.ts +1 -1
  116. package/dropdown/index.d.ts +1 -1
  117. package/dropdown/mis-crystal-design-system-dropdown.metadata.json +1 -1
  118. package/dropdown/public_api.d.ts +2 -2
  119. package/esm2015/action-list/action-list.component.js +4 -12
  120. package/esm2015/action-list/action-list.module.js +3 -2
  121. package/esm2015/action-list/index.js +2 -2
  122. package/esm2015/action-list/public_api.js +3 -3
  123. package/esm2015/async-search-dropdown/async-dropdown.component.js +25 -25
  124. package/esm2015/async-search-dropdown/async-dropdown.module.js +7 -7
  125. package/esm2015/async-search-dropdown/index.js +2 -2
  126. package/esm2015/async-search-dropdown/public_api.js +3 -3
  127. package/esm2015/button/button.component.js +10 -10
  128. package/esm2015/button/button.directive.js +19 -19
  129. package/esm2015/button/button.module.js +5 -5
  130. package/esm2015/button/index.js +2 -2
  131. package/esm2015/button/public_api.js +3 -3
  132. package/esm2015/checkbox/checkbox.component.js +8 -9
  133. package/esm2015/checkbox/checkbox.module.js +5 -5
  134. package/esm2015/checkbox/index.js +2 -2
  135. package/esm2015/checkbox/public_api.js +3 -3
  136. package/esm2015/chip/chip.component.js +8 -9
  137. package/esm2015/chip/chip.module.js +4 -4
  138. package/esm2015/chip/index.js +2 -2
  139. package/esm2015/chip/public_api.js +3 -3
  140. package/esm2015/datepicker_v2/datepicker-constants.js +2 -2
  141. package/esm2015/datepicker_v2/datepicker.module.js +5 -4
  142. package/esm2015/datepicker_v2/index.js +2 -2
  143. package/esm2015/datepicker_v2/models/dp-config.model.js +1 -1
  144. package/esm2015/datepicker_v2/public_api.js +3 -3
  145. package/esm2015/datepicker_v2/tz-datepicker.directive.js +4 -24
  146. package/esm2015/datepicker_v2/tz-dp-container/tz-dp-container.component.js +12 -9
  147. package/esm2015/datepicker_v2/utils/index.js +13 -13
  148. package/esm2015/daterangepicker_v2/daterangepicker-constants.js +2 -2
  149. package/esm2015/daterangepicker_v2/daterangepicker.module.js +4 -3
  150. package/esm2015/daterangepicker_v2/index.js +2 -2
  151. package/esm2015/daterangepicker_v2/public_api.js +3 -3
  152. package/esm2015/daterangepicker_v2/tz-daterangepicker.directive.js +3 -12
  153. package/esm2015/daterangepicker_v2/tz-drp-container/tz-drp-container.component.js +15 -38
  154. package/esm2015/daterangepicker_v2/utils/index.js +13 -13
  155. package/esm2015/drawer/drawer-body/drawer-body.component.js +4 -7
  156. package/esm2015/drawer/drawer.module.js +4 -4
  157. package/esm2015/drawer/drawer.service.js +4 -4
  158. package/esm2015/drawer/index.js +2 -2
  159. package/esm2015/drawer/public_api.js +5 -5
  160. package/esm2015/dropdown/dropdown.component.js +67 -26
  161. package/esm2015/dropdown/dropdown.module.js +7 -6
  162. package/esm2015/dropdown/index.js +2 -2
  163. package/esm2015/dropdown/public_api.js +3 -3
  164. package/esm2015/fab/fab.component.js +11 -14
  165. package/esm2015/fab/fab.module.js +3 -3
  166. package/esm2015/fab/index.js +2 -2
  167. package/esm2015/fab/public_api.js +3 -3
  168. package/esm2015/index.js +2 -2
  169. package/esm2015/input/directives/input/input.directive.js +7 -7
  170. package/esm2015/input/index.js +2 -2
  171. package/esm2015/input/mis-input.component.js +8 -8
  172. package/esm2015/input/mis-input.module.js +7 -7
  173. package/esm2015/input/public_api.js +4 -4
  174. package/esm2015/loader/index.js +2 -2
  175. package/esm2015/loader/loader.component.js +5 -6
  176. package/esm2015/loader/loader.module.js +4 -4
  177. package/esm2015/loader/public_api.js +3 -3
  178. package/esm2015/menu/index.js +2 -2
  179. package/esm2015/modal/index.js +2 -2
  180. package/esm2015/modal/modal.module.js +10 -14
  181. package/esm2015/modal/modal.service.js +3 -3
  182. package/esm2015/modal/module-wrapper/module-wrapper.component.js +4 -4
  183. package/esm2015/modal/public_api.js +5 -5
  184. package/esm2015/multi-select-dropdown/index.js +2 -2
  185. package/esm2015/multi-select-dropdown/multi-select-dropdown.component.js +80 -44
  186. package/esm2015/multi-select-dropdown/multi-select-dropdown.module.js +9 -8
  187. package/esm2015/multi-select-dropdown/public_api.js +3 -3
  188. package/esm2015/nested-multi-select-dropdown/index.js +2 -2
  189. package/esm2015/nested-multi-select-dropdown/nested-multi-select-dropdown.component.js +72 -29
  190. package/esm2015/nested-multi-select-dropdown/nested-multi-select-dropdown.module.js +9 -8
  191. package/esm2015/nested-multi-select-dropdown/public_api.js +3 -3
  192. package/esm2015/public-api.js +1 -1
  193. package/esm2015/radio-button/index.js +2 -2
  194. package/esm2015/radio-button/public_api.js +3 -3
  195. package/esm2015/radio-button/radio-button.component.js +9 -10
  196. package/esm2015/radio-button/radio-button.module.js +5 -5
  197. package/esm2015/switch/index.js +2 -2
  198. package/esm2015/switch/public_api.js +3 -3
  199. package/esm2015/switch/switch.component.js +6 -7
  200. package/esm2015/switch/switch.module.js +5 -5
  201. package/esm2015/table/custom-table-cell.directive.js +3 -3
  202. package/esm2015/table/filter/filter.component.js +11 -13
  203. package/esm2015/table/index.js +2 -2
  204. package/esm2015/table/public_api.js +5 -5
  205. package/esm2015/table/sub-table/sub-table.component.js +12 -13
  206. package/esm2015/table/table.component.js +21 -22
  207. package/esm2015/table/table.module.js +7 -21
  208. package/esm2015/toast/index.js +2 -2
  209. package/esm2015/toast/toast.component.js +12 -14
  210. package/esm2015/toast/toast.data.service.js +3 -3
  211. package/esm2015/toast/toast.module.js +9 -9
  212. package/esm2015/toast/toast.service.js +23 -26
  213. package/esm2015/tooltip/tooltip.directive.js +1 -1
  214. package/esm2015/tooltip/tooltip.module.js +3 -2
  215. package/fab/index.d.ts +1 -1
  216. package/fab/mis-crystal-design-system-fab.metadata.json +1 -1
  217. package/fab/public_api.d.ts +2 -2
  218. package/fesm2015/mis-crystal-design-system-action-list.js +5 -13
  219. package/fesm2015/mis-crystal-design-system-action-list.js.map +1 -1
  220. package/fesm2015/mis-crystal-design-system-async-search-dropdown.js +20 -20
  221. package/fesm2015/mis-crystal-design-system-async-search-dropdown.js.map +1 -1
  222. package/fesm2015/mis-crystal-design-system-button.js +25 -25
  223. package/fesm2015/mis-crystal-design-system-button.js.map +1 -1
  224. package/fesm2015/mis-crystal-design-system-checkbox.js +5 -6
  225. package/fesm2015/mis-crystal-design-system-checkbox.js.map +1 -1
  226. package/fesm2015/mis-crystal-design-system-chip.js +6 -7
  227. package/fesm2015/mis-crystal-design-system-chip.js.map +1 -1
  228. package/fesm2015/mis-crystal-design-system-datepicker_v2.js +28 -45
  229. package/fesm2015/mis-crystal-design-system-datepicker_v2.js.map +1 -1
  230. package/fesm2015/mis-crystal-design-system-daterangepicker_v2.js +32 -64
  231. package/fesm2015/mis-crystal-design-system-daterangepicker_v2.js.map +1 -1
  232. package/fesm2015/mis-crystal-design-system-drawer.js +9 -12
  233. package/fesm2015/mis-crystal-design-system-drawer.js.map +1 -1
  234. package/fesm2015/mis-crystal-design-system-dropdown.js +67 -26
  235. package/fesm2015/mis-crystal-design-system-dropdown.js.map +1 -1
  236. package/fesm2015/mis-crystal-design-system-fab.js +11 -14
  237. package/fesm2015/mis-crystal-design-system-fab.js.map +1 -1
  238. package/fesm2015/mis-crystal-design-system-input.js +8 -8
  239. package/fesm2015/mis-crystal-design-system-input.js.map +1 -1
  240. package/fesm2015/mis-crystal-design-system-loader.js +3 -4
  241. package/fesm2015/mis-crystal-design-system-loader.js.map +1 -1
  242. package/fesm2015/mis-crystal-design-system-modal.js +8 -12
  243. package/fesm2015/mis-crystal-design-system-modal.js.map +1 -1
  244. package/fesm2015/mis-crystal-design-system-multi-select-dropdown.js +80 -44
  245. package/fesm2015/mis-crystal-design-system-multi-select-dropdown.js.map +1 -1
  246. package/fesm2015/mis-crystal-design-system-nested-multi-select-dropdown.js +72 -29
  247. package/fesm2015/mis-crystal-design-system-nested-multi-select-dropdown.js.map +1 -1
  248. package/fesm2015/mis-crystal-design-system-radio-button.js +6 -7
  249. package/fesm2015/mis-crystal-design-system-radio-button.js.map +1 -1
  250. package/fesm2015/mis-crystal-design-system-switch.js +3 -4
  251. package/fesm2015/mis-crystal-design-system-switch.js.map +1 -1
  252. package/fesm2015/mis-crystal-design-system-table.js +42 -60
  253. package/fesm2015/mis-crystal-design-system-table.js.map +1 -1
  254. package/fesm2015/mis-crystal-design-system-toast.js +28 -33
  255. package/fesm2015/mis-crystal-design-system-toast.js.map +1 -1
  256. package/fesm2015/mis-crystal-design-system-tooltip.js +2 -2
  257. package/fesm2015/mis-crystal-design-system-tooltip.js.map +1 -1
  258. package/fesm2015/mis-crystal-design-system.js.map +1 -1
  259. package/index.d.ts +1 -1
  260. package/input/directives/input/input.directive.d.ts +3 -3
  261. package/input/index.d.ts +1 -1
  262. package/input/mis-crystal-design-system-input.metadata.json +1 -1
  263. package/input/mis-input.component.d.ts +4 -4
  264. package/input/public_api.d.ts +3 -3
  265. package/loader/index.d.ts +1 -1
  266. package/loader/loader.component.d.ts +1 -1
  267. package/loader/loader.module.d.ts +1 -1
  268. package/loader/mis-crystal-design-system-loader.metadata.json +1 -1
  269. package/loader/public_api.d.ts +2 -2
  270. package/menu/index.d.ts +1 -1
  271. package/modal/index.d.ts +1 -1
  272. package/modal/mis-crystal-design-system-modal.metadata.json +1 -1
  273. package/modal/modal.module.d.ts +1 -1
  274. package/modal/public_api.d.ts +4 -4
  275. package/multi-select-dropdown/index.d.ts +1 -1
  276. package/multi-select-dropdown/mis-crystal-design-system-multi-select-dropdown.metadata.json +1 -1
  277. package/multi-select-dropdown/multi-select-dropdown.component.d.ts +9 -3
  278. package/multi-select-dropdown/multi-select-dropdown.module.d.ts +1 -1
  279. package/multi-select-dropdown/public_api.d.ts +2 -2
  280. package/nested-multi-select-dropdown/index.d.ts +1 -1
  281. package/nested-multi-select-dropdown/mis-crystal-design-system-nested-multi-select-dropdown.metadata.json +1 -1
  282. package/nested-multi-select-dropdown/nested-multi-select-dropdown.component.d.ts +10 -4
  283. package/nested-multi-select-dropdown/nested-multi-select-dropdown.module.d.ts +1 -1
  284. package/nested-multi-select-dropdown/public_api.d.ts +2 -2
  285. package/package.json +1 -1
  286. package/radio-button/index.d.ts +1 -1
  287. package/radio-button/mis-crystal-design-system-radio-button.metadata.json +1 -1
  288. package/radio-button/public_api.d.ts +2 -2
  289. package/radio-button/radio-button.component.d.ts +2 -2
  290. package/radio-button/radio-button.module.d.ts +1 -1
  291. package/switch/index.d.ts +1 -1
  292. package/switch/mis-crystal-design-system-switch.metadata.json +1 -1
  293. package/switch/public_api.d.ts +2 -2
  294. package/switch/switch.component.d.ts +2 -2
  295. package/switch/switch.module.d.ts +1 -1
  296. package/table/custom-table-cell.directive.d.ts +1 -1
  297. package/table/filter/filter.component.d.ts +1 -1
  298. package/table/index.d.ts +1 -1
  299. package/table/mis-crystal-design-system-table.metadata.json +1 -1
  300. package/table/public_api.d.ts +7 -7
  301. package/table/sub-table/sub-table.component.d.ts +6 -6
  302. package/table/table.component.d.ts +6 -6
  303. package/toast/index.d.ts +1 -1
  304. package/toast/mis-crystal-design-system-toast.metadata.json +1 -1
  305. package/toast/toast.component.d.ts +1 -1
  306. package/toast/toast.module.d.ts +1 -1
  307. package/toast/toast.service.d.ts +3 -3
  308. package/tooltip/mis-crystal-design-system-tooltip.metadata.json +1 -1
@@ -1,13 +1,17 @@
1
1
  import { __rest } from 'tslib';
2
- import { EventEmitter, Component, ElementRef, Input, Output, HostListener, NgModule } from '@angular/core';
2
+ import { EventEmitter, Component, ElementRef, ViewContainerRef, Input, Output, ViewChild, NgModule } from '@angular/core';
3
+ import { TemplatePortal } from '@angular/cdk/portal';
4
+ import { ConnectionPositionPair, OverlayConfig, Overlay, OverlayModule } from '@angular/cdk/overlay';
3
5
  import { CommonModule } from '@angular/common';
4
6
  import { FormsModule } from '@angular/forms';
5
7
  import { CheckboxModule } from 'mis-crystal-design-system/checkbox';
6
8
  import { ButtonModule } from 'mis-crystal-design-system/button';
7
9
 
8
10
  class MultiSelectDropdownComponent {
9
- constructor(eRef) {
11
+ constructor(eRef, overlay, viewContainerRef) {
10
12
  this.eRef = eRef;
13
+ this.overlay = overlay;
14
+ this.viewContainerRef = viewContainerRef;
11
15
  this.searchInput = "";
12
16
  this.isOpen = false;
13
17
  this.localSelectedItems = [];
@@ -26,34 +30,27 @@ class MultiSelectDropdownComponent {
26
30
  this.showSelectedCount = false;
27
31
  this.noDataMessage = "No Data";
28
32
  this.options = {
29
- sortLabels: true,
33
+ sortLabels: true
30
34
  };
31
35
  this.hideApplyButton = false;
32
36
  this.onChange = new EventEmitter();
33
37
  }
34
38
  set data(values) {
35
- this.localData = values.map((item) => {
39
+ this.localData = values.map(item => {
36
40
  return Object.assign(Object.assign({}, item), { checked: false });
37
41
  });
38
42
  }
39
43
  set selectedItems(values) {
40
44
  this.handlerSetLocalSelectedItems(values);
41
45
  }
42
- clickout(event) {
43
- const isClickedOutside = !this.eRef.nativeElement.contains(event.target);
44
- if (isClickedOutside) {
45
- this.onCancel();
46
- }
47
- }
48
46
  ngOnInit() { }
49
47
  handlerSetLocalSelectedItems(values) {
50
48
  this.localSelectedItems = values;
51
- this.localData = this.localData.map((item) => {
52
- if (item.value === this.SELECT_ALL_ENUM &&
53
- this.localData.every((a) => a.checked)) {
49
+ this.localData = this.localData.map(item => {
50
+ if (item.value === this.SELECT_ALL_ENUM && this.localData.every(a => a.checked)) {
54
51
  return Object.assign(Object.assign({}, item), { checked: true });
55
52
  }
56
- if (values.some((base) => base.value === item.value)) {
53
+ if (values.some(base => base.value === item.value)) {
57
54
  return Object.assign(Object.assign({}, item), { checked: true });
58
55
  }
59
56
  else {
@@ -76,9 +73,47 @@ class MultiSelectDropdownComponent {
76
73
  this.handlerSetLocalSelectedItems(this.localSelectedItems);
77
74
  this.localData = this.formatValues(this.localData);
78
75
  }
76
+ if (this.isOpen)
77
+ this.openDropdown(this.popupContainer, this.selectElement.nativeElement);
78
+ else
79
+ this.onCancel();
80
+ }
81
+ openDropdown(template, origin) {
82
+ const positionsBottom = [
83
+ new ConnectionPositionPair({ originX: "start", originY: "bottom" }, { overlayX: "start", overlayY: "top" }, 0, 4),
84
+ new ConnectionPositionPair({ originX: "end", originY: "bottom" }, { overlayX: "end", overlayY: "top" }, 0, 4)
85
+ ];
86
+ const positionsTop = [
87
+ new ConnectionPositionPair({ originX: "start", originY: "top" }, { overlayX: "start", overlayY: "bottom" }, 0, -4),
88
+ new ConnectionPositionPair({ originX: "end", originY: "top" }, { overlayX: "end", overlayY: "bottom" }, 0, -4)
89
+ ];
90
+ const positionStrategy = this.overlay
91
+ .position()
92
+ .flexibleConnectedTo(origin)
93
+ .withPositions([
94
+ ...(this.dropdownListPosition === "Right" ? positionsBottom.reverse() : positionsBottom),
95
+ ...(this.dropdownListPosition === "Right" ? positionsTop.reverse() : positionsTop)
96
+ ])
97
+ .withPush(true);
98
+ const configs = new OverlayConfig({
99
+ hasBackdrop: true,
100
+ backdropClass: "cdk-overlay-transparent-backdrop",
101
+ scrollStrategy: this.overlay.scrollStrategies.reposition(),
102
+ positionStrategy,
103
+ width: origin.clientWidth
104
+ });
105
+ this.overlayRef = this.overlay.create(configs);
106
+ if (this.dropdownListWidth)
107
+ this.overlayRef.updateSize({ width: this.dropdownListWidth });
108
+ if (this.dropdownListHeight)
109
+ this.overlayRef.updateSize({ height: this.dropdownListHeight });
110
+ this.overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));
111
+ this.overlayRef.backdropClick().subscribe(res => {
112
+ this.onCancel();
113
+ });
79
114
  }
80
115
  filterByValue(array, string) {
81
- return array.filter((o) => o.label.toLowerCase().includes(string.toLowerCase()));
116
+ return array.filter(o => o.label.toLowerCase().includes(string.toLowerCase()));
82
117
  }
83
118
  searchInputOnChange(newValue) {
84
119
  this.searchInput = newValue;
@@ -94,20 +129,18 @@ class MultiSelectDropdownComponent {
94
129
  let sortedArray = array;
95
130
  if (this.options.sortLabels) {
96
131
  const checkedValues = array
97
- .filter((a) => a.checked)
98
- .sort((a, b) => a.label > b.label ? 1 : b.label > a.label ? -1 : 0);
132
+ .filter(a => a.checked)
133
+ .sort((a, b) => (a.label > b.label ? 1 : b.label > a.label ? -1 : 0));
99
134
  const unCheckedValues = array
100
- .filter((a) => !a.checked)
101
- .sort((a, b) => a.label > b.label ? 1 : b.label > a.label ? -1 : 0);
102
- sortedArray = [...checkedValues, ...unCheckedValues].filter((t) => t.value !== this.SELECT_ALL_ENUM);
135
+ .filter(a => !a.checked)
136
+ .sort((a, b) => (a.label > b.label ? 1 : b.label > a.label ? -1 : 0));
137
+ sortedArray = [...checkedValues, ...unCheckedValues].filter(t => t.value !== this.SELECT_ALL_ENUM);
103
138
  }
104
- if (!sortedArray.some((option) => option.value === this.SELECT_ALL_ENUM) &&
105
- this.enableSelectAll &&
106
- sortedArray.length > 0) {
139
+ if (!sortedArray.some(option => option.value === this.SELECT_ALL_ENUM) && this.enableSelectAll && sortedArray.length > 0) {
107
140
  sortedArray.unshift({
108
141
  label: "Select all",
109
142
  value: this.SELECT_ALL_ENUM,
110
- checked: sortedArray.every((y) => y.checked),
143
+ checked: sortedArray.every(y => y.checked)
111
144
  });
112
145
  }
113
146
  return sortedArray;
@@ -115,7 +148,7 @@ class MultiSelectDropdownComponent {
115
148
  toggleSelectedItems(event, item) {
116
149
  event.stopPropagation();
117
150
  if (this.enableSelectAll && item.value === this.SELECT_ALL_ENUM) {
118
- this.localData = this.localData.map((t) => (Object.assign(Object.assign({}, t), { checked: !item.checked })));
151
+ this.localData = this.localData.map(t => (Object.assign(Object.assign({}, t), { checked: !item.checked })));
119
152
  if (this.hideApplyButton) {
120
153
  this.applyFilters();
121
154
  }
@@ -123,34 +156,31 @@ class MultiSelectDropdownComponent {
123
156
  }
124
157
  if (item.checked) {
125
158
  this.localData = [
126
- ...this.localData.map((a) => {
159
+ ...this.localData.map(a => {
127
160
  if (a.value === item.value || a.value === this.SELECT_ALL_ENUM) {
128
161
  return Object.assign(Object.assign({}, a), { checked: false });
129
162
  }
130
163
  return a;
131
- }),
164
+ })
132
165
  ];
133
166
  }
134
167
  else {
135
168
  this.localData = [
136
- ...this.localData.map((a) => {
169
+ ...this.localData.map(a => {
137
170
  if (a.value === item.value) {
138
171
  return Object.assign(Object.assign({}, a), { checked: true });
139
172
  }
140
173
  return a;
141
- }),
174
+ })
142
175
  ];
143
- if (this.enableSelectAll &&
144
- this.localData
145
- .filter((r) => r.value !== this.SELECT_ALL_ENUM)
146
- .every((t) => t.checked)) {
176
+ if (this.enableSelectAll && this.localData.filter(r => r.value !== this.SELECT_ALL_ENUM).every(t => t.checked)) {
147
177
  this.localData = [
148
- ...this.localData.map((a) => {
178
+ ...this.localData.map(a => {
149
179
  if (a.value === this.SELECT_ALL_ENUM) {
150
180
  return Object.assign(Object.assign({}, a), { checked: true });
151
181
  }
152
182
  return a;
153
- }),
183
+ })
154
184
  ];
155
185
  }
156
186
  }
@@ -163,10 +193,10 @@ class MultiSelectDropdownComponent {
163
193
  }
164
194
  applyFilters() {
165
195
  this.onChange.emit(this.localData
166
- .filter((a) => {
196
+ .filter(a => {
167
197
  return a.checked && a.value !== this.SELECT_ALL_ENUM;
168
198
  })
169
- .map((item) => {
199
+ .map(item => {
170
200
  const { checked } = item, data = __rest(item, ["checked"]);
171
201
  return data;
172
202
  }));
@@ -181,9 +211,10 @@ class MultiSelectDropdownComponent {
181
211
  this.searchInput = "";
182
212
  }
183
213
  onCancel() {
214
+ var _a;
184
215
  this.isSearchInputFocused = false;
185
- this.localData = this.localData.map((a) => {
186
- if (this.localSelectedItems.some((b) => b.value === a.value && String(b.checked) !== String(a.checked))) {
216
+ this.localData = this.localData.map(a => {
217
+ if (this.localSelectedItems.some(b => b.value === a.value && String(b.checked) !== String(a.checked))) {
187
218
  return a;
188
219
  }
189
220
  else {
@@ -192,17 +223,21 @@ class MultiSelectDropdownComponent {
192
223
  });
193
224
  this.isOpen = false;
194
225
  this.searchInput = "";
226
+ (_a = this.overlayRef) === null || _a === void 0 ? void 0 : _a.detach();
227
+ this.searchInput = "";
195
228
  }
196
229
  }
197
230
  MultiSelectDropdownComponent.decorators = [
198
231
  { type: Component, args: [{
199
232
  selector: "mis-multi-select-dropdown",
200
- template: "<div\n class=\"container\"\n [ngStyle]=\"{\n height: height.length > 0 ? height : '',\n width: width.length > 0 ? width : ''\n }\"\n>\n <div class=\"dropdown\" (click)=\"toggleDropdown()\" [ngStyle]=\"{ background: isOpen ? '#E6EBF7' : '' }\">\n <div class=\"label\">\n <p class=\"text\">{{ label }}</p>\n <p *ngIf=\"showSelectedCount && localSelectedItems?.length > 0\" class=\"count\">\n {{ localSelectedItems?.length }}\n </p>\n </div>\n <svg\n class=\"handle\"\n [ngStyle]=\"{ transform: isOpen ? 'rotate(180deg)' : 'rotate(0deg)' }\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M13.825 7.15845L10 10.9751L6.175 7.15845L5 8.33345L10 13.3334L15 8.33345L13.825 7.15845Z\"\n fill=\"#181F33\"\n />\n </svg>\n </div>\n <div style=\"flex-basis: 0\"></div>\n <div style=\"width: 100%; position: relative\">\n <div\n *ngIf=\"isOpen\"\n class=\"popup-container\"\n [ngStyle]=\"{\n height: dropdownListHeight,\n width: dropdownListWidth\n }\"\n [ngClass]=\"{\n 'position-left': dropdownListPosition === 'Left',\n 'position-right': dropdownListPosition === 'Right'\n }\"\n >\n <div *ngIf=\"searchEnabled\" class=\"search-container\">\n <svg\n *ngIf=\"!isSearchInputFocused\"\n class=\"search-icon\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M4.21508 11.1456C4.21508 7.3179 7.33722 4.21165 11.1926 4.21165C15.048 4.21165 18.1702 7.3179 18.1702 11.1456C18.1702 12.6931 17.6599 14.1226 16.7972 15.2767L15.3685 16.7013C14.2044 17.5668 12.759 18.0796 11.1926 18.0796C7.33722 18.0796 4.21508 14.9734 4.21508 11.1456ZM15.9421 17.7835C14.6021 18.7329 12.9627 19.2913 11.1926 19.2913C6.66977 19.2913 3 15.6461 3 11.1456C3 6.64512 6.66977 3 11.1926 3C15.7155 3 19.3852 6.64512 19.3852 11.1456C19.3852 12.9371 18.8037 14.5931 17.8184 15.9375L19.8361 17.4048C20.6705 17.912 21.7554 18.6543 20.2454 20.215C18.7353 21.7756 18.0099 20.6663 17.4991 19.8364L15.9421 17.7835Z\"\n fill=\"#6A737D\"\n />\n </svg>\n <input\n [ngModel]=\"searchInput\"\n [ngStyle]=\"{\n paddingLeft: isSearchInputFocused ? '12px' : '45px',\n border: isSearchInputFocused ? '1px solid #0937B2' : '1px solid #e0e0e0',\n paddingRight: isSearchInputFocused ? '45px' : '10px'\n }\"\n (ngModelChange)=\"searchInputOnChange($event)\"\n [placeholder]=\"isSearchInputFocused ? '' : 'Search Keyword'\"\n (focus)=\"searchInputFocused(true)\"\n class=\"search-input\"\n />\n <svg\n *ngIf=\"isSearchInputFocused\"\n class=\"cancel-icon\"\n (click)=\"searchInputCanceled($event)\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M8.87446 7.32144C8.44588 6.89285 7.751 6.89285 7.32242 7.32144C6.89383 7.75002 6.89383 8.4449 7.32242 8.87349L10.4488 11.9999L7.32357 15.1252C6.89498 15.5538 6.89498 16.2486 7.32357 16.6772C7.75215 17.1058 8.44703 17.1058 8.87561 16.6772L12.0009 13.552L15.1261 16.6772C15.5547 17.1058 16.2496 17.1058 16.6781 16.6772C17.1067 16.2486 17.1067 15.5537 16.6781 15.1251L13.5529 11.9999L16.6793 8.87354C17.1079 8.44496 17.1079 7.75008 16.6793 7.3215C16.2507 6.89291 15.5558 6.89291 15.1273 7.3215L12.0009 10.4479L8.87446 7.32144Z\"\n fill=\"#6A737D\"\n />\n </svg>\n </div>\n <div class=\"items\">\n <div class=\"item\" (click)=\"toggleSelectedItems($event, item)\" *ngFor=\"let item of searchInput ? searchData : localData\">\n <div class=\"checkbox-container-wrapper\">\n <div class=\"checkbox-container\">\n <mis-checkbox [checked]=\"item.checked\"></mis-checkbox>\n </div>\n <p class=\"label\">\n {{ item.label }}\n </p>\n </div>\n <div class=\"icon-container\" *ngIf=\"item.icon\">\n <img class=\"icon\" [src]=\"item.icon\" alt=\"no img\" />\n </div>\n </div>\n <div class=\"noData\" *ngIf=\"(searchInput ? searchData : localData).length === 0\">\n {{ searchInput === \"\" ? noDataMessage : \"No results\" }}\n </div>\n </div>\n <div *ngIf=\"localData.length !== 0 && !hideApplyButton\" class=\"actions-container\">\n <div style=\"width: calc(50% - 4px)\">\n <mis-button [name]=\"'Reset'\" [type]=\"'Text'\" [width]=\"'100%'\" (click)=\"onReset()\"></mis-button>\n </div>\n <div style=\"width: calc(50% - 4px)\">\n <mis-button [name]=\"'Apply'\" [type]=\"'Solid'\" [width]=\"'100%'\" (click)=\"applyFilters()\"></mis-button>\n </div>\n </div>\n </div>\n </div>\n</div>\n",
201
- styles: [".container{position:relative;display:flex;justify-content:center;align-items:center;flex-wrap:wrap;height:32px;width:256px;font-family:Lato,sans-serif!important}.container .dropdown{height:inherit;border:1px solid #e0e0e0;border-radius:6px;background-color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;width:100%;padding:0 12px;overflow:hidden}.container .dropdown:hover{background-color:#f5f7fc}.container .dropdown .label{display:flex;justify-content:flex-start;align-items:center;width:calc(100% - 32px)}.container .dropdown .label,.container .dropdown .label .text{font-style:normal;font-weight:400;font-size:14px;line-height:20px;letter-spacing:.2px;color:#181f33}.container .dropdown .label .text{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.container .dropdown .label .count{background-color:#e0e0e0;border-radius:50%;padding:2px 7px;margin:0 0 0 8px;font-style:normal;font-weight:400;font-size:14px;line-height:20px;text-align:center;letter-spacing:.2px;color:#181f33}.container .dropdown .handle{width:24px;height:24px;transition:.3s;position:absolute;right:12px;border-radius:50%;overflow:hidden}.container .popup-container{position:absolute;top:4px;width:100%;max-height:340px;padding-bottom:0;border:1px solid #e0e0e0;border-radius:8px;background-color:#fff;box-shadow:0 12px 24px 0 rgba(0,0,0,.12);overflow:scroll;overflow-x:hidden;display:flex;flex-direction:column;justify-content:space-between;z-index:100}.container .popup-container::-webkit-scrollbar{width:0;height:0}.container .popup-container .search-container{position:relative;box-sizing:border-box;padding:8px}.container .popup-container .search-container .search-icon{position:absolute;width:24px;height:24px;top:50%;transform:translateY(-50%);left:18px;z-index:1}.container .popup-container .search-container .search-input{height:40px;width:100%;padding:12px;border:1px solid #e0e0e0;box-sizing:border-box;border-radius:8px;outline:none;caret-color:#0937b2;font-style:normal;font-weight:400;font-size:12px;line-height:18px;display:flex;align-items:center;letter-spacing:.2px;color:#181f33}.container .popup-container .search-container .cancel-icon{position:absolute;cursor:pointer;width:24px;height:24px;top:50%;transform:translateY(-50%);right:18px;z-index:1}.container .popup-container .items{padding:8px 0 8px 8px;overflow-y:scroll;height:100%}.container .popup-container .items::-webkit-scrollbar{width:5px;height:0}.container .popup-container .items::-webkit-scrollbar-thumb{background:#9aa7b4;border-radius:10px}.container .popup-container .items .noData{display:flex;justify-content:center;align-items:center;font-style:normal;font-weight:400;font-size:14px;line-height:20px;letter-spacing:.2px;color:#181f33}.container .popup-container .items .item{cursor:pointer;display:flex;justify-content:flex-start;align-items:center;padding:8px 12px;border-radius:6px;height:auto}.container .popup-container .items .item:hover{background-color:#f5f7fc}.container .popup-container .items .item .checkbox-container-wrapper{display:flex;justify-content:flex-start;align-items:center;width:90%}.container .popup-container .items .item .checkbox-container-wrapper .checkbox-container{display:block;position:relative;cursor:pointer;font-size:22px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.container .popup-container .items .item .checkbox-container-wrapper .checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.container .popup-container .items .item .checkbox-container-wrapper .checkbox-container input:checked~.checkmark:after{display:block}.container .popup-container .items .item .checkbox-container-wrapper .checkbox-container .checkmark{position:absolute;top:-8px;left:0;height:15px;width:15px;border-radius:4px;background-color:#0079f1;border:1px solid #6a737d}.container .popup-container .items .item .checkbox-container-wrapper .checkbox-container .checkmark:after{content:\"\";position:absolute;display:none;left:5px;top:2px;width:3px;height:6px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.container .popup-container .items .item .checkbox-container-wrapper .label{margin:0 0 0 8px;line-height:20px;font-size:14px;font-style:normal;font-weight:400;letter-spacing:.200000003px}.container .popup-container .items .item .icon-container{width:10%;display:flex;justify-content:flex-end}.container .popup-container .items .item .icon-container .icon{width:20px;height:20px}.container .popup-container .actions-container{display:flex;justify-content:space-between;bottom:0;align-items:center;position:-webkit-sticky;position:sticky;padding:16px;background-color:#fff;border-top:1px solid #e0e0e0}.container .popup-container .actions-container .cancel{cursor:pointer;padding:10px 32px;text-align:center;font-size:16px;line-height:24px;border-radius:8px}.container .popup-container .actions-container .cancel:hover{background:rgba(9,55,178,.04)}.container .popup-container .actions-container .apply{cursor:pointer;padding:10px 32px;text-align:center;color:#fff;font-size:16px;line-height:24px;background:#0937b2;border-radius:8px}.position-left{right:0}.position-right{left:0}"]
233
+ template: "<div\n class=\"container\"\n [ngStyle]=\"{\n height: height.length > 0 ? height : '',\n width: width.length > 0 ? width : ''\n }\"\n>\n <div\n class=\"dropdown\"\n #select\n tabindex=\"0\"\n (keyup.enter)=\"toggleDropdown()\"\n (click)=\"toggleDropdown()\"\n [ngStyle]=\"{ background: isOpen ? '#E6EBF7' : '' }\"\n >\n <div class=\"label\">\n <p class=\"text\">{{ label }}</p>\n <p *ngIf=\"showSelectedCount && localSelectedItems?.length > 0\" class=\"count\">\n {{ localSelectedItems?.length }}\n </p>\n </div>\n <svg\n class=\"handle\"\n [ngStyle]=\"{ transform: isOpen ? 'rotate(180deg)' : 'rotate(0deg)' }\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M13.825 7.15845L10 10.9751L6.175 7.15845L5 8.33345L10 13.3334L15 8.33345L13.825 7.15845Z\"\n fill=\"#181F33\"\n />\n </svg>\n </div>\n</div>\n<ng-template #popupContainer>\n <div\n class=\"popup-container\"\n [ngStyle]=\"{\n height: dropdownListHeight,\n width: dropdownListWidth\n }\"\n [ngClass]=\"{\n 'position-left': dropdownListPosition === 'Left',\n 'position-right': dropdownListPosition === 'Right'\n }\"\n >\n <div *ngIf=\"searchEnabled\" class=\"search-container\">\n <svg\n *ngIf=\"!isSearchInputFocused\"\n class=\"search-icon\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M4.21508 11.1456C4.21508 7.3179 7.33722 4.21165 11.1926 4.21165C15.048 4.21165 18.1702 7.3179 18.1702 11.1456C18.1702 12.6931 17.6599 14.1226 16.7972 15.2767L15.3685 16.7013C14.2044 17.5668 12.759 18.0796 11.1926 18.0796C7.33722 18.0796 4.21508 14.9734 4.21508 11.1456ZM15.9421 17.7835C14.6021 18.7329 12.9627 19.2913 11.1926 19.2913C6.66977 19.2913 3 15.6461 3 11.1456C3 6.64512 6.66977 3 11.1926 3C15.7155 3 19.3852 6.64512 19.3852 11.1456C19.3852 12.9371 18.8037 14.5931 17.8184 15.9375L19.8361 17.4048C20.6705 17.912 21.7554 18.6543 20.2454 20.215C18.7353 21.7756 18.0099 20.6663 17.4991 19.8364L15.9421 17.7835Z\"\n fill=\"#6A737D\"\n />\n </svg>\n <input\n [ngModel]=\"searchInput\"\n [ngStyle]=\"{\n paddingLeft: isSearchInputFocused ? '12px' : '45px',\n border: isSearchInputFocused ? '1px solid #0937B2' : '1px solid #e0e0e0',\n paddingRight: isSearchInputFocused ? '45px' : '10px'\n }\"\n (ngModelChange)=\"searchInputOnChange($event)\"\n [placeholder]=\"isSearchInputFocused ? '' : 'Search Keyword'\"\n (focus)=\"searchInputFocused(true)\"\n class=\"search-input\"\n />\n <svg\n *ngIf=\"isSearchInputFocused\"\n class=\"cancel-icon\"\n (click)=\"searchInputCanceled($event)\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M8.87446 7.32144C8.44588 6.89285 7.751 6.89285 7.32242 7.32144C6.89383 7.75002 6.89383 8.4449 7.32242 8.87349L10.4488 11.9999L7.32357 15.1252C6.89498 15.5538 6.89498 16.2486 7.32357 16.6772C7.75215 17.1058 8.44703 17.1058 8.87561 16.6772L12.0009 13.552L15.1261 16.6772C15.5547 17.1058 16.2496 17.1058 16.6781 16.6772C17.1067 16.2486 17.1067 15.5537 16.6781 15.1251L13.5529 11.9999L16.6793 8.87354C17.1079 8.44496 17.1079 7.75008 16.6793 7.3215C16.2507 6.89291 15.5558 6.89291 15.1273 7.3215L12.0009 10.4479L8.87446 7.32144Z\"\n fill=\"#6A737D\"\n />\n </svg>\n </div>\n <div class=\"items\">\n <div\n class=\"item\"\n tabindex=\"0\"\n (keyup.enter)=\"toggleSelectedItems($event, item)\"\n (click)=\"toggleSelectedItems($event, item)\"\n *ngFor=\"let item of searchInput ? searchData : localData\"\n >\n <div class=\"checkbox-container-wrapper\">\n <div class=\"checkbox-container\">\n <mis-checkbox [checked]=\"item.checked\" tabindex=\"-1\"></mis-checkbox>\n </div>\n <p class=\"label\">\n {{ item.label }}\n </p>\n </div>\n <div class=\"icon-container\" *ngIf=\"item.icon\">\n <img class=\"icon\" [src]=\"item.icon\" alt=\"no img\" />\n </div>\n </div>\n <div class=\"noData\" *ngIf=\"(searchInput ? searchData : localData).length === 0\">\n {{ searchInput === \"\" ? noDataMessage : \"No results\" }}\n </div>\n </div>\n <div *ngIf=\"localData.length !== 0 && !hideApplyButton\" class=\"actions-container\">\n <div style=\"width: calc(50% - 4px)\">\n <mis-button [name]=\"'Reset'\" [type]=\"'Text'\" [width]=\"'100%'\" (click)=\"onReset()\"></mis-button>\n </div>\n <div style=\"width: calc(50% - 4px)\">\n <mis-button [name]=\"'Apply'\" [type]=\"'Solid'\" [width]=\"'100%'\" (click)=\"applyFilters()\"></mis-button>\n </div>\n </div>\n </div>\n</ng-template>\n",
234
+ styles: [".container{position:relative;display:flex;justify-content:center;align-items:center;flex-wrap:wrap;height:32px;width:256px;font-family:Lato,sans-serif!important}.container .dropdown{height:inherit;border:1px solid #e0e0e0;border-radius:6px;background-color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;width:100%;padding:0 12px;overflow:hidden}.container .dropdown:focus-visible,.container .dropdown:hover{background-color:#f5f7fc;outline:none}.container .dropdown .label{display:flex;justify-content:flex-start;align-items:center;width:calc(100% - 32px)}.container .dropdown .label,.container .dropdown .label .text{font-style:normal;font-weight:400;font-size:14px;line-height:20px;letter-spacing:.2px;color:#181f33}.container .dropdown .label .text{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.container .dropdown .label .count{background-color:#e0e0e0;border-radius:50%;padding:2px 7px;margin:0 0 0 8px;font-style:normal;font-weight:400;font-size:14px;line-height:20px;text-align:center;letter-spacing:.2px;color:#181f33}.container .dropdown .handle{width:24px;height:24px;transition:.3s;position:absolute;right:12px;border-radius:50%;overflow:hidden}.popup-container{width:100%;max-height:340px;padding-bottom:0;border:1px solid #e0e0e0;border-radius:8px;background-color:#fff;box-shadow:0 12px 24px 0 rgba(0,0,0,.12);display:flex;flex-direction:column;overflow:hidden;justify-content:space-between}.popup-container::-webkit-scrollbar{width:0;height:0}.popup-container .search-container{position:relative;box-sizing:border-box;padding:8px}.popup-container .search-container .search-icon{position:absolute;width:24px;height:24px;top:50%;transform:translateY(-50%);left:18px;z-index:1}.popup-container .search-container .search-input{height:40px;width:100%;padding:12px;border:1px solid #e0e0e0;box-sizing:border-box;border-radius:8px;outline:none;caret-color:#0937b2;font-style:normal;font-weight:400;font-size:12px;line-height:18px;display:flex;align-items:center;letter-spacing:.2px;color:#181f33}.popup-container .search-container .cancel-icon{position:absolute;cursor:pointer;width:24px;height:24px;top:50%;transform:translateY(-50%);right:18px;z-index:1}.popup-container .items{padding:8px 0 8px 8px;overflow-y:scroll}.popup-container .items::-webkit-scrollbar{width:5px;height:0}.popup-container .items::-webkit-scrollbar-thumb{background:#9aa7b4;border-radius:10px}.popup-container .items .noData{display:flex;justify-content:center;align-items:center;font-style:normal;font-weight:400;font-size:14px;line-height:20px;letter-spacing:.2px;color:#181f33}.popup-container .items .item{cursor:pointer;display:flex;justify-content:flex-start;align-items:center;padding:8px 12px;border-radius:6px;height:auto}.popup-container .items .item:focus-visible,.popup-container .items .item:hover{background-color:#f5f7fc;outline:none}.popup-container .items .item .checkbox-container-wrapper{display:flex;justify-content:flex-start;align-items:center;width:90%}.popup-container .items .item .checkbox-container-wrapper .checkbox-container{display:block;position:relative;cursor:pointer;font-size:22px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.popup-container .items .item .checkbox-container-wrapper .checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.popup-container .items .item .checkbox-container-wrapper .checkbox-container input:checked~.checkmark:after{display:block}.popup-container .items .item .checkbox-container-wrapper .checkbox-container .checkmark{position:absolute;top:-8px;left:0;height:15px;width:15px;border-radius:4px;background-color:#0079f1;border:1px solid #6a737d}.popup-container .items .item .checkbox-container-wrapper .checkbox-container .checkmark:after{content:\"\";position:absolute;display:none;left:5px;top:2px;width:3px;height:6px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.popup-container .items .item .checkbox-container-wrapper .label{margin:0 0 0 8px;line-height:20px;font-size:14px;font-style:normal;font-weight:400;letter-spacing:.2;text-overflow:ellipsis;overflow:hidden}.popup-container .items .item .icon-container{width:10%;display:flex;justify-content:flex-end}.popup-container .items .item .icon-container .icon{width:20px;height:20px}.popup-container .actions-container{display:flex;justify-content:space-between;bottom:0;align-items:center;position:-webkit-sticky;position:sticky;padding:16px;background-color:#fff;border-top:1px solid #e0e0e0}.popup-container .actions-container .cancel{cursor:pointer;padding:10px 32px;text-align:center;font-size:16px;line-height:24px;border-radius:8px}.popup-container .actions-container .cancel:hover{background:rgba(9,55,178,.04)}.popup-container .actions-container .apply{cursor:pointer;padding:10px 32px;text-align:center;color:#fff;font-size:16px;line-height:24px;background:#0937b2;border-radius:8px}"]
202
235
  },] }
203
236
  ];
204
237
  MultiSelectDropdownComponent.ctorParameters = () => [
205
- { type: ElementRef }
238
+ { type: ElementRef },
239
+ { type: Overlay },
240
+ { type: ViewContainerRef }
206
241
  ];
207
242
  MultiSelectDropdownComponent.propDecorators = {
208
243
  data: [{ type: Input }],
@@ -220,7 +255,8 @@ MultiSelectDropdownComponent.propDecorators = {
220
255
  selectedItems: [{ type: Input }],
221
256
  hideApplyButton: [{ type: Input }],
222
257
  onChange: [{ type: Output }],
223
- clickout: [{ type: HostListener, args: ["document:click", ["$event"],] }]
258
+ selectElement: [{ type: ViewChild, args: ["select", { static: false },] }],
259
+ popupContainer: [{ type: ViewChild, args: ["popupContainer", { static: false },] }]
224
260
  };
225
261
 
226
262
  class MultiSelectDropdownModule {
@@ -231,7 +267,7 @@ class MultiSelectDropdownModule {
231
267
  MultiSelectDropdownModule.decorators = [
232
268
  { type: NgModule, args: [{
233
269
  declarations: [MultiSelectDropdownComponent],
234
- imports: [CommonModule, FormsModule, CheckboxModule, ButtonModule],
270
+ imports: [CommonModule, FormsModule, OverlayModule, CheckboxModule, ButtonModule],
235
271
  exports: [MultiSelectDropdownComponent]
236
272
  },] }
237
273
  ];
@@ -1 +1 @@
1
- {"version":3,"file":"mis-crystal-design-system-multi-select-dropdown.js","sources":["../../../projects/mis-components/multi-select-dropdown/multi-select-dropdown.component.ts","../../../projects/mis-components/multi-select-dropdown/multi-select-dropdown.module.ts","../../../projects/mis-components/multi-select-dropdown/mis-crystal-design-system-multi-select-dropdown.ts"],"sourcesContent":["import {\n Component,\n ElementRef,\n EventEmitter,\n HostListener,\n Input,\n OnInit,\n Output,\n} from \"@angular/core\";\n@Component({\n selector: \"mis-multi-select-dropdown\",\n templateUrl: \"./multi-select-dropdown.component.html\",\n styleUrls: [\"./multi-select-dropdown.component.scss\"],\n})\nexport class MultiSelectDropdownComponent implements OnInit {\n searchInput: string = \"\";\n isOpen = false;\n localSelectedItems: MultiSelectDropdownItem[] = [];\n localData: MultiSelectDropdownItem[] = [];\n searchData: MultiSelectDropdownItem[] = [];\n isSearchInputFocused: boolean = false;\n SELECT_ALL_ENUM = \"SELECT_ALL_ENABLED\";\n @Input() set data(values: MultiSelectDropdownItem[]) {\n this.localData = values.map((item) => {\n return { ...item, checked: false };\n });\n }\n @Input() label: string = \"Select\";\n @Input() height: string = \"\";\n @Input() width: string = \"\";\n @Input() dropdownListHeight: string = \"\";\n @Input() dropdownListWidth: string = \"\";\n @Input() dropdownListPosition: \"Left\" | \"Right\" = \"Left\";\n @Input() enableSelectAll: boolean = false;\n @Input() searchEnabled: boolean = true;\n @Input() showSelectedCount: boolean = false;\n @Input() noDataMessage: string = \"No Data\";\n @Input() options: OPTIONS = {\n sortLabels: true,\n };\n @Input() set selectedItems(values: MultiSelectDropdownItem[]) {\n this.handlerSetLocalSelectedItems(values);\n }\n @Input() hideApplyButton: boolean = false;\n @Output() onChange: EventEmitter<any> = new EventEmitter();\n @HostListener(\"document:click\", [\"$event\"])\n clickout(event) {\n const isClickedOutside = !this.eRef.nativeElement.contains(event.target);\n if (isClickedOutside) {\n this.onCancel();\n }\n }\n constructor(private eRef: ElementRef) {}\n\n ngOnInit() {}\n\n handlerSetLocalSelectedItems(values) {\n this.localSelectedItems = values;\n this.localData = this.localData.map((item) => {\n if (\n item.value === this.SELECT_ALL_ENUM &&\n this.localData.every((a) => a.checked)\n ) {\n return { ...item, checked: true };\n }\n if (values.some((base) => base.value === item.value)) {\n return { ...item, checked: true };\n } else {\n return { ...item, checked: false };\n }\n });\n this.localData = this.formatValues(this.localData);\n }\n\n searchInputFocused(isFocused: boolean) {\n this.isSearchInputFocused = isFocused;\n }\n\n searchInputCanceled(event) {\n event.stopPropagation();\n this.searchInput = \"\";\n this.isSearchInputFocused = false;\n }\n\n toggleDropdown() {\n this.isOpen = !this.isOpen;\n if (this.isOpen) {\n this.handlerSetLocalSelectedItems(this.localSelectedItems);\n this.localData = this.formatValues(this.localData);\n }\n }\n\n filterByValue(array: MultiSelectDropdownItem[], string: string) {\n return array.filter((o) =>\n o.label.toLowerCase().includes(string.toLowerCase())\n );\n }\n\n searchInputOnChange(newValue) {\n this.searchInput = newValue;\n if (newValue) {\n this.searchData = this.filterByValue(this.localData, newValue);\n } else {\n this.searchData = [];\n this.searchInput = \"\";\n }\n }\n\n formatValues(array: MultiSelectDropdownItem[]) {\n let sortedArray = array;\n if (this.options.sortLabels) {\n const checkedValues = array\n .filter((a) => a.checked)\n .sort((a: MultiSelectDropdownItem, b: MultiSelectDropdownItem) =>\n a.label > b.label ? 1 : b.label > a.label ? -1 : 0\n );\n const unCheckedValues = array\n .filter((a) => !a.checked)\n .sort((a: MultiSelectDropdownItem, b: MultiSelectDropdownItem) =>\n a.label > b.label ? 1 : b.label > a.label ? -1 : 0\n );\n sortedArray = [...checkedValues, ...unCheckedValues].filter(\n (t) => t.value !== this.SELECT_ALL_ENUM\n );\n }\n if (\n !sortedArray.some((option) => option.value === this.SELECT_ALL_ENUM) &&\n this.enableSelectAll &&\n sortedArray.length > 0\n ) {\n sortedArray.unshift({\n label: \"Select all\",\n value: this.SELECT_ALL_ENUM,\n checked: sortedArray.every((y) => y.checked),\n });\n }\n return sortedArray;\n }\n\n toggleSelectedItems(event, item: MultiSelectDropdownItem) {\n event.stopPropagation();\n if (this.enableSelectAll && item.value === this.SELECT_ALL_ENUM) {\n this.localData = this.localData.map((t) => ({\n ...t,\n checked: !item.checked,\n }));\n if (this.hideApplyButton) {\n this.applyFilters();\n }\n return;\n }\n if (item.checked) {\n this.localData = [\n ...this.localData.map((a) => {\n if (a.value === item.value || a.value === this.SELECT_ALL_ENUM) {\n return {\n ...a,\n checked: false,\n };\n }\n return a;\n }),\n ];\n } else {\n this.localData = [\n ...this.localData.map((a) => {\n if (a.value === item.value) {\n return {\n ...a,\n checked: true,\n };\n }\n return a;\n }),\n ];\n if (\n this.enableSelectAll &&\n this.localData\n .filter((r) => r.value !== this.SELECT_ALL_ENUM)\n .every((t) => t.checked)\n ) {\n this.localData = [\n ...this.localData.map((a) => {\n if (a.value === this.SELECT_ALL_ENUM) {\n return {\n ...a,\n checked: true,\n };\n }\n return a;\n }),\n ];\n }\n }\n if (this.searchEnabled) {\n this.searchInputOnChange(this.searchInput);\n }\n if (this.hideApplyButton) {\n this.applyFilters();\n }\n }\n\n applyFilters() {\n this.onChange.emit(\n this.localData\n .filter((a) => {\n return a.checked && a.value !== this.SELECT_ALL_ENUM;\n })\n .map((item) => {\n const { checked, ...data } = item;\n return data;\n })\n );\n if (!this.hideApplyButton) {\n this.onCancel();\n }\n }\n\n onReset() {\n this.isSearchInputFocused = false;\n this.onChange.emit([]);\n this.isOpen = false;\n this.searchInput = \"\";\n }\n\n onCancel() {\n this.isSearchInputFocused = false;\n this.localData = this.localData.map((a) => {\n if (\n this.localSelectedItems.some(\n (b) => b.value === a.value && String(b.checked) !== String(a.checked)\n )\n ) {\n return a;\n } else {\n return {\n ...a,\n checked: false,\n };\n }\n });\n this.isOpen = false;\n this.searchInput = \"\";\n }\n}\nexport interface MultiSelectDropdownItem {\n label: string;\n value: string;\n checked?: boolean;\n icon?: string;\n}\nexport interface OPTIONS {\n sortLabels: boolean;\n}\n","import { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { NgModule, ModuleWithProviders } from '@angular/core';\nimport { MultiSelectDropdownComponent } from './multi-select-dropdown.component';\nimport { CheckboxModule } from 'mis-crystal-design-system/checkbox';\nimport { ButtonModule } from 'mis-crystal-design-system/button';\n\n@NgModule({\n declarations: [MultiSelectDropdownComponent],\n imports: [CommonModule, FormsModule, CheckboxModule, ButtonModule],\n exports: [MultiSelectDropdownComponent]\n})\nexport class MultiSelectDropdownModule {\n static forRoot(): ModuleWithProviders<MultiSelectDropdownModule> {\n return { ngModule: MultiSelectDropdownModule, providers: [] };\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;MAca,4BAA4B;IAsCvC,YAAoB,IAAgB;QAAhB,SAAI,GAAJ,IAAI,CAAY;QArCpC,gBAAW,GAAW,EAAE,CAAC;QACzB,WAAM,GAAG,KAAK,CAAC;QACf,uBAAkB,GAA8B,EAAE,CAAC;QACnD,cAAS,GAA8B,EAAE,CAAC;QAC1C,eAAU,GAA8B,EAAE,CAAC;QAC3C,yBAAoB,GAAY,KAAK,CAAC;QACtC,oBAAe,GAAG,oBAAoB,CAAC;QAM9B,UAAK,GAAW,QAAQ,CAAC;QACzB,WAAM,GAAW,EAAE,CAAC;QACpB,UAAK,GAAW,EAAE,CAAC;QACnB,uBAAkB,GAAW,EAAE,CAAC;QAChC,sBAAiB,GAAW,EAAE,CAAC;QAC/B,yBAAoB,GAAqB,MAAM,CAAC;QAChD,oBAAe,GAAY,KAAK,CAAC;QACjC,kBAAa,GAAY,IAAI,CAAC;QAC9B,sBAAiB,GAAY,KAAK,CAAC;QACnC,kBAAa,GAAW,SAAS,CAAC;QAClC,YAAO,GAAY;YAC1B,UAAU,EAAE,IAAI;SACjB,CAAC;QAIO,oBAAe,GAAY,KAAK,CAAC;QAChC,aAAQ,GAAsB,IAAI,YAAY,EAAE,CAAC;KAQnB;IA9BxC,IAAa,IAAI,CAAC,MAAiC;QACjD,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI;YAC/B,uCAAY,IAAI,KAAE,OAAO,EAAE,KAAK,IAAG;SACpC,CAAC,CAAC;KACJ;IAcD,IAAa,aAAa,CAAC,MAAiC;QAC1D,IAAI,CAAC,4BAA4B,CAAC,MAAM,CAAC,CAAC;KAC3C;IAID,QAAQ,CAAC,KAAK;QACZ,MAAM,gBAAgB,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACzE,IAAI,gBAAgB,EAAE;YACpB,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;KACF;IAGD,QAAQ,MAAK;IAEb,4BAA4B,CAAC,MAAM;QACjC,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC;QACjC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,IAAI;YACvC,IACE,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe;gBACnC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EACtC;gBACA,uCAAY,IAAI,KAAE,OAAO,EAAE,IAAI,IAAG;aACnC;YACD,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,EAAE;gBACpD,uCAAY,IAAI,KAAE,OAAO,EAAE,IAAI,IAAG;aACnC;iBAAM;gBACL,uCAAY,IAAI,KAAE,OAAO,EAAE,KAAK,IAAG;aACpC;SACF,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;KACpD;IAED,kBAAkB,CAAC,SAAkB;QACnC,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAC;KACvC;IAED,mBAAmB,CAAC,KAAK;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;KACnC;IAED,cAAc;QACZ,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;QAC3B,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAC3D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACpD;KACF;IAED,aAAa,CAAC,KAAgC,EAAE,MAAc;QAC5D,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KACpB,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CACrD,CAAC;KACH;IAED,mBAAmB,CAAC,QAAQ;QAC1B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC;QAC5B,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;SAChE;aAAM;YACL,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;SACvB;KACF;IAED,YAAY,CAAC,KAAgC;QAC3C,IAAI,WAAW,GAAG,KAAK,CAAC;QACxB,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE;YAC3B,MAAM,aAAa,GAAG,KAAK;iBACxB,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;iBACxB,IAAI,CAAC,CAAC,CAA0B,EAAE,CAA0B,KAC3D,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CACnD,CAAC;YACJ,MAAM,eAAe,GAAG,KAAK;iBAC1B,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;iBACzB,IAAI,CAAC,CAAC,CAA0B,EAAE,CAA0B,KAC3D,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CACnD,CAAC;YACJ,WAAW,GAAG,CAAC,GAAG,aAAa,EAAE,GAAG,eAAe,CAAC,CAAC,MAAM,CACzD,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,CACxC,CAAC;SACH;QACD,IACE,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,CAAC;YACpE,IAAI,CAAC,eAAe;YACpB,WAAW,CAAC,MAAM,GAAG,CAAC,EACtB;YACA,WAAW,CAAC,OAAO,CAAC;gBAClB,KAAK,EAAE,YAAY;gBACnB,KAAK,EAAE,IAAI,CAAC,eAAe;gBAC3B,OAAO,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;aAC7C,CAAC,CAAC;SACJ;QACD,OAAO,WAAW,CAAC;KACpB;IAED,mBAAmB,CAAC,KAAK,EAAE,IAA6B;QACtD,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,EAAE;YAC/D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,sCACjC,CAAC,KACJ,OAAO,EAAE,CAAC,IAAI,CAAC,OAAO,IACtB,CAAC,CAAC;YACJ,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;YACD,OAAO;SACR;QACD,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,SAAS,GAAG;gBACf,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;oBACtB,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,EAAE;wBAC9D,uCACK,CAAC,KACJ,OAAO,EAAE,KAAK,IACd;qBACH;oBACD,OAAO,CAAC,CAAC;iBACV,CAAC;aACH,CAAC;SACH;aAAM;YACL,IAAI,CAAC,SAAS,GAAG;gBACf,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;oBACtB,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE;wBAC1B,uCACK,CAAC,KACJ,OAAO,EAAE,IAAI,IACb;qBACH;oBACD,OAAO,CAAC,CAAC;iBACV,CAAC;aACH,CAAC;YACF,IACE,IAAI,CAAC,eAAe;gBACpB,IAAI,CAAC,SAAS;qBACX,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,CAAC;qBAC/C,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAC1B;gBACA,IAAI,CAAC,SAAS,GAAG;oBACf,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;wBACtB,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,EAAE;4BACpC,uCACK,CAAC,KACJ,OAAO,EAAE,IAAI,IACb;yBACH;wBACD,OAAO,CAAC,CAAC;qBACV,CAAC;iBACH,CAAC;aACH;SACF;QACD,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC5C;QACD,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;KACF;IAED,YAAY;QACV,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,IAAI,CAAC,SAAS;aACX,MAAM,CAAC,CAAC,CAAC;YACR,OAAO,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,eAAe,CAAC;SACtD,CAAC;aACD,GAAG,CAAC,CAAC,IAAI;YACR,MAAM,EAAE,OAAO,KAAc,IAAI,EAAb,IAAI,UAAK,IAAI,EAA3B,WAAoB,CAAO,CAAC;YAClC,OAAO,IAAI,CAAC;SACb,CAAC,CACL,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACzB,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;KACF;IAED,OAAO;QACL,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;KACvB;IAED,QAAQ;QACN,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;YACpC,IACE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAC1B,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,KAAK,IAAI,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CACtE,EACD;gBACA,OAAO,CAAC,CAAC;aACV;iBAAM;gBACL,uCACK,CAAC,KACJ,OAAO,EAAE,KAAK,IACd;aACH;SACF,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;KACvB;;;YA1OF,SAAS,SAAC;gBACT,QAAQ,EAAE,2BAA2B;gBACrC,gwKAAqD;;aAEtD;;;YAXC,UAAU;;;mBAoBT,KAAK;oBAKL,KAAK;qBACL,KAAK;oBACL,KAAK;iCACL,KAAK;gCACL,KAAK;mCACL,KAAK;8BACL,KAAK;4BACL,KAAK;gCACL,KAAK;4BACL,KAAK;sBACL,KAAK;4BAGL,KAAK;8BAGL,KAAK;uBACL,MAAM;uBACN,YAAY,SAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;;;MCjC/B,yBAAyB;IAClC,OAAO,OAAO;QACV,OAAO,EAAE,QAAQ,EAAE,yBAAyB,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC;KACjE;;;YARJ,QAAQ,SAAC;gBACN,YAAY,EAAE,CAAC,4BAA4B,CAAC;gBAC5C,OAAO,EAAE,CAAC,YAAY,EAAE,WAAW,EAAE,cAAc,EAAE,YAAY,CAAC;gBAClE,OAAO,EAAE,CAAC,4BAA4B,CAAC;aAC1C;;;ACXD;;;;;;"}
1
+ {"version":3,"file":"mis-crystal-design-system-multi-select-dropdown.js","sources":["../../../projects/mis-components/multi-select-dropdown/multi-select-dropdown.component.ts","../../../projects/mis-components/multi-select-dropdown/multi-select-dropdown.module.ts","../../../projects/mis-components/multi-select-dropdown/mis-crystal-design-system-multi-select-dropdown.ts"],"sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild, ViewContainerRef } from \"@angular/core\";\nimport { TemplatePortal } from \"@angular/cdk/portal\";\nimport { OverlayRef, Overlay, ConnectionPositionPair, OverlayConfig } from \"@angular/cdk/overlay\";\n@Component({\n selector: \"mis-multi-select-dropdown\",\n templateUrl: \"./multi-select-dropdown.component.html\",\n styleUrls: [\"./multi-select-dropdown.component.scss\"]\n})\nexport class MultiSelectDropdownComponent implements OnInit {\n searchInput: string = \"\";\n isOpen = false;\n localSelectedItems: MultiSelectDropdownItem[] = [];\n localData: MultiSelectDropdownItem[] = [];\n searchData: MultiSelectDropdownItem[] = [];\n isSearchInputFocused: boolean = false;\n SELECT_ALL_ENUM = \"SELECT_ALL_ENABLED\";\n @Input() set data(values: MultiSelectDropdownItem[]) {\n this.localData = values.map(item => {\n return { ...item, checked: false };\n });\n }\n @Input() label: string = \"Select\";\n @Input() height: string = \"\";\n @Input() width: string = \"\";\n @Input() dropdownListHeight: string = \"\";\n @Input() dropdownListWidth: string = \"\";\n @Input() dropdownListPosition: \"Left\" | \"Right\" = \"Left\";\n @Input() enableSelectAll: boolean = false;\n @Input() searchEnabled: boolean = true;\n @Input() showSelectedCount: boolean = false;\n @Input() noDataMessage: string = \"No Data\";\n @Input() options: OPTIONS = {\n sortLabels: true\n };\n @Input() set selectedItems(values: MultiSelectDropdownItem[]) {\n this.handlerSetLocalSelectedItems(values);\n }\n @Input() hideApplyButton: boolean = false;\n @Output() onChange: EventEmitter<any> = new EventEmitter();\n\n @ViewChild(\"select\", { static: false }) selectElement: ElementRef;\n @ViewChild(\"popupContainer\", { static: false }) popupContainer: TemplateRef<Element>;\n private overlayRef: OverlayRef;\n\n constructor(private eRef: ElementRef, private overlay: Overlay, private viewContainerRef: ViewContainerRef) {}\n ngOnInit() {}\n\n handlerSetLocalSelectedItems(values) {\n this.localSelectedItems = values;\n this.localData = this.localData.map(item => {\n if (item.value === this.SELECT_ALL_ENUM && this.localData.every(a => a.checked)) {\n return { ...item, checked: true };\n }\n if (values.some(base => base.value === item.value)) {\n return { ...item, checked: true };\n } else {\n return { ...item, checked: false };\n }\n });\n this.localData = this.formatValues(this.localData);\n }\n\n searchInputFocused(isFocused: boolean) {\n this.isSearchInputFocused = isFocused;\n }\n\n searchInputCanceled(event) {\n event.stopPropagation();\n this.searchInput = \"\";\n this.isSearchInputFocused = false;\n }\n\n toggleDropdown() {\n this.isOpen = !this.isOpen;\n if (this.isOpen) {\n this.handlerSetLocalSelectedItems(this.localSelectedItems);\n this.localData = this.formatValues(this.localData);\n }\n if (this.isOpen) this.openDropdown(this.popupContainer, this.selectElement.nativeElement);\n else this.onCancel();\n }\n\n private openDropdown(template: TemplateRef<Element>, origin: HTMLElement): void {\n const positionsBottom = [\n new ConnectionPositionPair({ originX: \"start\", originY: \"bottom\" }, { overlayX: \"start\", overlayY: \"top\" }, 0, 4),\n new ConnectionPositionPair({ originX: \"end\", originY: \"bottom\" }, { overlayX: \"end\", overlayY: \"top\" }, 0, 4)\n ];\n const positionsTop = [\n new ConnectionPositionPair({ originX: \"start\", originY: \"top\" }, { overlayX: \"start\", overlayY: \"bottom\" }, 0, -4),\n new ConnectionPositionPair({ originX: \"end\", originY: \"top\" }, { overlayX: \"end\", overlayY: \"bottom\" }, 0, -4)\n ];\n const positionStrategy = this.overlay\n .position()\n .flexibleConnectedTo(origin)\n .withPositions([\n ...(this.dropdownListPosition === \"Right\" ? positionsBottom.reverse() : positionsBottom),\n ...(this.dropdownListPosition === \"Right\" ? positionsTop.reverse() : positionsTop)\n ])\n .withPush(true);\n const configs = new OverlayConfig({\n hasBackdrop: true,\n backdropClass: \"cdk-overlay-transparent-backdrop\",\n scrollStrategy: this.overlay.scrollStrategies.reposition(),\n positionStrategy,\n width: origin.clientWidth\n });\n this.overlayRef = this.overlay.create(configs);\n if (this.dropdownListWidth) this.overlayRef.updateSize({ width: this.dropdownListWidth });\n if (this.dropdownListHeight) this.overlayRef.updateSize({ height: this.dropdownListHeight });\n this.overlayRef.attach(new TemplatePortal(template, this.viewContainerRef));\n this.overlayRef.backdropClick().subscribe(res => {\n this.onCancel();\n });\n }\n\n filterByValue(array: MultiSelectDropdownItem[], string: string) {\n return array.filter(o => o.label.toLowerCase().includes(string.toLowerCase()));\n }\n\n searchInputOnChange(newValue) {\n this.searchInput = newValue;\n if (newValue) {\n this.searchData = this.filterByValue(this.localData, newValue);\n } else {\n this.searchData = [];\n this.searchInput = \"\";\n }\n }\n\n formatValues(array: MultiSelectDropdownItem[]) {\n let sortedArray = array;\n if (this.options.sortLabels) {\n const checkedValues = array\n .filter(a => a.checked)\n .sort((a: MultiSelectDropdownItem, b: MultiSelectDropdownItem) => (a.label > b.label ? 1 : b.label > a.label ? -1 : 0));\n const unCheckedValues = array\n .filter(a => !a.checked)\n .sort((a: MultiSelectDropdownItem, b: MultiSelectDropdownItem) => (a.label > b.label ? 1 : b.label > a.label ? -1 : 0));\n sortedArray = [...checkedValues, ...unCheckedValues].filter(t => t.value !== this.SELECT_ALL_ENUM);\n }\n if (!sortedArray.some(option => option.value === this.SELECT_ALL_ENUM) && this.enableSelectAll && sortedArray.length > 0) {\n sortedArray.unshift({\n label: \"Select all\",\n value: this.SELECT_ALL_ENUM,\n checked: sortedArray.every(y => y.checked)\n });\n }\n return sortedArray;\n }\n\n toggleSelectedItems(event, item: MultiSelectDropdownItem) {\n event.stopPropagation();\n if (this.enableSelectAll && item.value === this.SELECT_ALL_ENUM) {\n this.localData = this.localData.map(t => ({\n ...t,\n checked: !item.checked\n }));\n if (this.hideApplyButton) {\n this.applyFilters();\n }\n return;\n }\n if (item.checked) {\n this.localData = [\n ...this.localData.map(a => {\n if (a.value === item.value || a.value === this.SELECT_ALL_ENUM) {\n return {\n ...a,\n checked: false\n };\n }\n return a;\n })\n ];\n } else {\n this.localData = [\n ...this.localData.map(a => {\n if (a.value === item.value) {\n return {\n ...a,\n checked: true\n };\n }\n return a;\n })\n ];\n if (this.enableSelectAll && this.localData.filter(r => r.value !== this.SELECT_ALL_ENUM).every(t => t.checked)) {\n this.localData = [\n ...this.localData.map(a => {\n if (a.value === this.SELECT_ALL_ENUM) {\n return {\n ...a,\n checked: true\n };\n }\n return a;\n })\n ];\n }\n }\n if (this.searchEnabled) {\n this.searchInputOnChange(this.searchInput);\n }\n if (this.hideApplyButton) {\n this.applyFilters();\n }\n }\n\n applyFilters() {\n this.onChange.emit(\n this.localData\n .filter(a => {\n return a.checked && a.value !== this.SELECT_ALL_ENUM;\n })\n .map(item => {\n const { checked, ...data } = item;\n return data;\n })\n );\n if (!this.hideApplyButton) {\n this.onCancel();\n }\n }\n\n onReset() {\n this.isSearchInputFocused = false;\n this.onChange.emit([]);\n this.isOpen = false;\n this.searchInput = \"\";\n }\n\n onCancel() {\n this.isSearchInputFocused = false;\n this.localData = this.localData.map(a => {\n if (this.localSelectedItems.some(b => b.value === a.value && String(b.checked) !== String(a.checked))) {\n return a;\n } else {\n return {\n ...a,\n checked: false\n };\n }\n });\n this.isOpen = false;\n this.searchInput = \"\";\n this.overlayRef?.detach();\n this.searchInput = \"\";\n }\n}\nexport interface MultiSelectDropdownItem {\n label: string;\n value: string;\n checked?: boolean;\n icon?: string;\n}\nexport interface OPTIONS {\n sortLabels: boolean;\n}\n","import { CommonModule } from \"@angular/common\";\nimport { FormsModule } from \"@angular/forms\";\nimport { NgModule, ModuleWithProviders } from \"@angular/core\";\nimport { MultiSelectDropdownComponent } from \"./multi-select-dropdown.component\";\nimport { CheckboxModule } from \"mis-crystal-design-system/checkbox\";\nimport { OverlayModule } from \"@angular/cdk/overlay\";\nimport { ButtonModule } from \"mis-crystal-design-system/button\";\n\n@NgModule({\n declarations: [MultiSelectDropdownComponent],\n imports: [CommonModule, FormsModule, OverlayModule, CheckboxModule, ButtonModule],\n exports: [MultiSelectDropdownComponent]\n})\nexport class MultiSelectDropdownModule {\n static forRoot(): ModuleWithProviders<MultiSelectDropdownModule> {\n return { ngModule: MultiSelectDropdownModule, providers: [] };\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}