@cuby-ui/core 0.0.194 → 0.0.195

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 (337) hide show
  1. package/animations/animations.d.ts +36 -36
  2. package/animations/index.d.ts +1 -1
  3. package/classes/accessors.d.ts +17 -17
  4. package/classes/driver.d.ts +16 -16
  5. package/classes/index.d.ts +3 -3
  6. package/classes/vehicle.d.ts +6 -6
  7. package/components/accordion/accordion-item/accordion-item.component.d.ts +11 -11
  8. package/components/accordion/accordion.component.d.ts +5 -5
  9. package/components/accordion/accordion.module.d.ts +11 -11
  10. package/components/accordion/index.d.ts +3 -3
  11. package/components/alert/alert.component.d.ts +13 -13
  12. package/components/alert/alert.interfaces.d.ts +9 -9
  13. package/components/alert/alert.module.d.ts +11 -11
  14. package/components/alert/alert.service.d.ts +7 -7
  15. package/components/alert/alert.tokens.d.ts +16 -16
  16. package/components/alert/alert.types.d.ts +3 -3
  17. package/components/alert/alerts.component.d.ts +17 -17
  18. package/components/alert/index.d.ts +8 -8
  19. package/components/badge/badge.component.d.ts +10 -10
  20. package/components/badge/badge.module.d.ts +8 -8
  21. package/components/badge/badge.options.d.ts +8 -8
  22. package/components/badge/index.d.ts +2 -2
  23. package/components/banner/banner.component.d.ts +21 -21
  24. package/components/banner/banner.module.d.ts +11 -11
  25. package/components/banner/banner.options.d.ts +13 -13
  26. package/components/banner/index.d.ts +3 -3
  27. package/components/breadcrumbs/breadcrumb/breadcrumb.component.d.ts +6 -6
  28. package/components/breadcrumbs/breadcrumbs.component.d.ts +7 -7
  29. package/components/breadcrumbs/breadcrumbs.module.d.ts +10 -10
  30. package/components/breadcrumbs/index.d.ts +3 -3
  31. package/components/button/button.component.d.ts +38 -38
  32. package/components/button/button.module.d.ts +9 -9
  33. package/components/button/button.options.d.ts +9 -9
  34. package/components/button/index.d.ts +3 -3
  35. package/components/button-group/button-group.component.d.ts +5 -5
  36. package/components/button-group/button-group.module.d.ts +7 -7
  37. package/components/button-group/index.d.ts +2 -2
  38. package/components/checkbox/checkbox.component.d.ts +5 -5
  39. package/components/checkbox/checkbox.module.d.ts +7 -7
  40. package/components/checkbox/index.d.ts +2 -2
  41. package/components/context-menu/context-menu.component.d.ts +39 -39
  42. package/components/context-menu/context-menu.module.d.ts +9 -9
  43. package/components/context-menu/index.d.ts +2 -2
  44. package/components/dialog/dialog-actions/dialog-actions.component.d.ts +5 -5
  45. package/components/dialog/dialog-header/dialog-header.component.d.ts +13 -13
  46. package/components/dialog/dialog.component.d.ts +33 -33
  47. package/components/dialog/dialog.interfaces.d.ts +11 -11
  48. package/components/dialog/dialog.module.d.ts +14 -14
  49. package/components/dialog/dialog.service.d.ts +7 -7
  50. package/components/dialog/dialog.tokens.d.ts +8 -8
  51. package/components/dialog/dialogs.component.d.ts +18 -18
  52. package/components/dialog/index.d.ts +8 -8
  53. package/components/form-field/form-field.component.d.ts +5 -5
  54. package/components/form-field/form-field.module.d.ts +7 -7
  55. package/components/form-field/index.d.ts +2 -2
  56. package/components/hint/hint.component.d.ts +7 -7
  57. package/components/hint/hint.module.d.ts +7 -7
  58. package/components/hint/index.d.ts +2 -2
  59. package/components/icon-button/icon-button.component.d.ts +13 -13
  60. package/components/icon-button/icon-button.module.d.ts +9 -9
  61. package/components/icon-button/index.d.ts +2 -2
  62. package/components/index.d.ts +26 -26
  63. package/components/input-number/index.d.ts +2 -2
  64. package/components/input-number/input-number.component.d.ts +38 -38
  65. package/components/input-number/input-number.module.d.ts +12 -12
  66. package/components/input-password/index.d.ts +2 -2
  67. package/components/input-password/input-password.component.d.ts +31 -31
  68. package/components/input-password/input-password.module.d.ts +11 -11
  69. package/components/input-text/index.d.ts +2 -2
  70. package/components/input-text/input-text.component.d.ts +31 -31
  71. package/components/input-text/input-text.module.d.ts +11 -11
  72. package/components/input-time/index.d.ts +3 -3
  73. package/components/input-time/input-time.component.d.ts +36 -36
  74. package/components/input-time/input-time.module.d.ts +12 -12
  75. package/components/input-time/input-time.options.d.ts +7 -7
  76. package/components/label/index.d.ts +2 -2
  77. package/components/label/label.component.d.ts +6 -6
  78. package/components/label/label.module.d.ts +8 -8
  79. package/components/notification/index.d.ts +3 -3
  80. package/components/notification/notification.component.d.ts +18 -18
  81. package/components/notification/notification.module.d.ts +9 -9
  82. package/components/notification/notification.options.d.ts +17 -17
  83. package/components/radio/index.d.ts +2 -2
  84. package/components/radio/radio.component.d.ts +5 -5
  85. package/components/radio/radio.module.d.ts +7 -7
  86. package/components/root/index.d.ts +3 -3
  87. package/components/root/root.component.d.ts +11 -11
  88. package/components/root/root.module.d.ts +11 -11
  89. package/components/root/root.options.d.ts +1 -1
  90. package/components/select/index.d.ts +2 -2
  91. package/components/select/select.component.d.ts +53 -53
  92. package/components/select/select.module.d.ts +11 -11
  93. package/components/svg/index.d.ts +2 -2
  94. package/components/svg/svg.component.d.ts +16 -16
  95. package/components/svg/svg.module.d.ts +8 -8
  96. package/components/tabs/index.d.ts +3 -3
  97. package/components/tabs/tab/index.d.ts +1 -1
  98. package/components/tabs/tab/tab.component.d.ts +8 -8
  99. package/components/tabs/tabs.component.d.ts +16 -16
  100. package/components/tabs/tabs.module.d.ts +8 -8
  101. package/components/textarea/index.d.ts +2 -2
  102. package/components/textarea/textarea.component.d.ts +10 -10
  103. package/components/textarea/textarea.module.d.ts +7 -7
  104. package/components/toggle/index.d.ts +2 -2
  105. package/components/toggle/toggle.component.d.ts +5 -5
  106. package/components/toggle/toggle.module.d.ts +7 -7
  107. package/directives/index.d.ts +2 -2
  108. package/directives/text-field-controller/index.d.ts +8 -8
  109. package/directives/text-field-controller/text-field-controller.module.d.ts +11 -11
  110. package/directives/text-field-controller/text-field-controller.provider.d.ts +4 -4
  111. package/directives/text-field-controller/text-field-icon-left.directive.d.ts +9 -9
  112. package/directives/text-field-controller/text-field-id.directive.d.ts +8 -8
  113. package/directives/text-field-controller/text-field-is-error.directive.d.ts +8 -8
  114. package/directives/text-field-controller/text-field-placeholder.directive.d.ts +8 -8
  115. package/directives/text-field-controller/text-field-size.directive.d.ts +9 -9
  116. package/directives/text-field-controller/text-field.controller.d.ts +20 -20
  117. package/directives/tooltip/index.d.ts +16 -16
  118. package/directives/tooltip/tooltip-describe.directive.d.ts +16 -16
  119. package/directives/tooltip/tooltip-driver.directive.d.ts +7 -7
  120. package/directives/tooltip/tooltip-host.directive.d.ts +9 -9
  121. package/directives/tooltip/tooltip-hover.directive.d.ts +21 -21
  122. package/directives/tooltip/tooltip-manual.directive.d.ts +13 -13
  123. package/directives/tooltip/tooltip-options.directive.d.ts +36 -36
  124. package/directives/tooltip/tooltip-overflow.directive.d.ts +8 -8
  125. package/directives/tooltip/tooltip-pointer.directive.d.ts +10 -10
  126. package/directives/tooltip/tooltip-position.directive.d.ts +20 -20
  127. package/directives/tooltip/tooltip-unstyled.component.d.ts +17 -17
  128. package/directives/tooltip/tooltip.component.d.ts +33 -33
  129. package/directives/tooltip/tooltip.d.ts +13 -13
  130. package/directives/tooltip/tooltip.directive.d.ts +26 -26
  131. package/directives/tooltip/tooltip.providers.d.ts +5 -5
  132. package/directives/tooltip/tooltip.service.d.ts +13 -13
  133. package/directives/tooltip/tooltips.component.d.ts +12 -12
  134. package/esm2022/animations/animations.mjs +271 -271
  135. package/esm2022/animations/index.mjs +1 -1
  136. package/esm2022/classes/accessors.mjs +30 -30
  137. package/esm2022/classes/driver.mjs +34 -34
  138. package/esm2022/classes/index.mjs +3 -3
  139. package/esm2022/classes/vehicle.mjs +6 -6
  140. package/esm2022/components/accordion/accordion-item/accordion-item.component.mjs +27 -27
  141. package/esm2022/components/accordion/accordion.component.mjs +10 -10
  142. package/esm2022/components/accordion/accordion.module.mjs +36 -36
  143. package/esm2022/components/accordion/index.mjs +3 -3
  144. package/esm2022/components/alert/alert.component.mjs +35 -35
  145. package/esm2022/components/alert/alert.interfaces.mjs +1 -1
  146. package/esm2022/components/alert/alert.module.mjs +39 -39
  147. package/esm2022/components/alert/alert.service.mjs +16 -16
  148. package/esm2022/components/alert/alert.tokens.mjs +19 -19
  149. package/esm2022/components/alert/alert.types.mjs +1 -1
  150. package/esm2022/components/alert/alerts.component.mjs +35 -35
  151. package/esm2022/components/alert/index.mjs +8 -8
  152. package/esm2022/components/badge/badge.component.mjs +30 -30
  153. package/esm2022/components/badge/badge.module.mjs +17 -17
  154. package/esm2022/components/badge/badge.options.mjs +7 -7
  155. package/esm2022/components/badge/index.mjs +2 -2
  156. package/esm2022/components/banner/banner.component.mjs +67 -67
  157. package/esm2022/components/banner/banner.module.mjs +30 -30
  158. package/esm2022/components/banner/banner.options.mjs +5 -5
  159. package/esm2022/components/banner/index.mjs +3 -3
  160. package/esm2022/components/breadcrumbs/breadcrumb/breadcrumb.component.mjs +15 -15
  161. package/esm2022/components/breadcrumbs/breadcrumbs.component.mjs +16 -16
  162. package/esm2022/components/breadcrumbs/breadcrumbs.module.mjs +32 -32
  163. package/esm2022/components/breadcrumbs/index.mjs +3 -3
  164. package/esm2022/components/button/button.component.mjs +137 -137
  165. package/esm2022/components/button/button.module.mjs +23 -23
  166. package/esm2022/components/button/button.options.mjs +9 -9
  167. package/esm2022/components/button/index.mjs +3 -3
  168. package/esm2022/components/button-group/button-group.component.mjs +10 -10
  169. package/esm2022/components/button-group/button-group.module.mjs +15 -15
  170. package/esm2022/components/button-group/index.mjs +2 -2
  171. package/esm2022/components/checkbox/checkbox.component.mjs +10 -10
  172. package/esm2022/components/checkbox/checkbox.module.mjs +15 -15
  173. package/esm2022/components/checkbox/index.mjs +2 -2
  174. package/esm2022/components/context-menu/context-menu.component.mjs +147 -147
  175. package/esm2022/components/context-menu/context-menu.module.mjs +23 -23
  176. package/esm2022/components/context-menu/index.mjs +2 -2
  177. package/esm2022/components/dialog/dialog-actions/dialog-actions.component.mjs +10 -10
  178. package/esm2022/components/dialog/dialog-header/dialog-header.component.mjs +27 -27
  179. package/esm2022/components/dialog/dialog.component.mjs +66 -66
  180. package/esm2022/components/dialog/dialog.interfaces.mjs +1 -1
  181. package/esm2022/components/dialog/dialog.module.mjs +48 -48
  182. package/esm2022/components/dialog/dialog.service.mjs +16 -16
  183. package/esm2022/components/dialog/dialog.tokens.mjs +11 -11
  184. package/esm2022/components/dialog/dialogs.component.mjs +50 -50
  185. package/esm2022/components/dialog/index.mjs +8 -8
  186. package/esm2022/components/form-field/form-field.component.mjs +10 -10
  187. package/esm2022/components/form-field/form-field.module.mjs +15 -15
  188. package/esm2022/components/form-field/index.mjs +2 -2
  189. package/esm2022/components/hint/hint.component.mjs +18 -18
  190. package/esm2022/components/hint/hint.module.mjs +15 -15
  191. package/esm2022/components/hint/index.mjs +2 -2
  192. package/esm2022/components/icon-button/icon-button.component.mjs +31 -31
  193. package/esm2022/components/icon-button/icon-button.module.mjs +23 -23
  194. package/esm2022/components/icon-button/index.mjs +2 -2
  195. package/esm2022/components/index.mjs +26 -26
  196. package/esm2022/components/input-number/index.mjs +2 -2
  197. package/esm2022/components/input-number/input-number.component.mjs +112 -112
  198. package/esm2022/components/input-number/input-number.module.mjs +35 -35
  199. package/esm2022/components/input-password/index.mjs +2 -2
  200. package/esm2022/components/input-password/input-password.component.mjs +88 -88
  201. package/esm2022/components/input-password/input-password.module.mjs +32 -32
  202. package/esm2022/components/input-text/index.mjs +2 -2
  203. package/esm2022/components/input-text/input-text.component.mjs +86 -86
  204. package/esm2022/components/input-text/input-text.module.mjs +32 -32
  205. package/esm2022/components/input-time/index.mjs +3 -3
  206. package/esm2022/components/input-time/input-time.component.mjs +98 -98
  207. package/esm2022/components/input-time/input-time.module.mjs +35 -35
  208. package/esm2022/components/input-time/input-time.options.mjs +7 -7
  209. package/esm2022/components/label/index.mjs +2 -2
  210. package/esm2022/components/label/label.component.mjs +16 -16
  211. package/esm2022/components/label/label.module.mjs +17 -17
  212. package/esm2022/components/notification/index.mjs +3 -3
  213. package/esm2022/components/notification/notification.component.mjs +46 -46
  214. package/esm2022/components/notification/notification.module.mjs +23 -23
  215. package/esm2022/components/notification/notification.options.mjs +52 -52
  216. package/esm2022/components/radio/index.mjs +2 -2
  217. package/esm2022/components/radio/radio.component.mjs +10 -10
  218. package/esm2022/components/radio/radio.module.mjs +15 -15
  219. package/esm2022/components/root/index.mjs +3 -3
  220. package/esm2022/components/root/root.component.mjs +31 -31
  221. package/esm2022/components/root/root.module.mjs +30 -30
  222. package/esm2022/components/root/root.options.mjs +1 -1
  223. package/esm2022/components/select/index.mjs +2 -2
  224. package/esm2022/components/select/select.component.mjs +171 -171
  225. package/esm2022/components/select/select.module.mjs +31 -31
  226. package/esm2022/components/svg/index.mjs +2 -2
  227. package/esm2022/components/svg/svg.component.mjs +49 -49
  228. package/esm2022/components/svg/svg.module.mjs +17 -17
  229. package/esm2022/components/tabs/index.mjs +3 -3
  230. package/esm2022/components/tabs/tab/index.mjs +1 -1
  231. package/esm2022/components/tabs/tab/tab.component.mjs +20 -20
  232. package/esm2022/components/tabs/tabs.component.mjs +48 -48
  233. package/esm2022/components/tabs/tabs.module.mjs +17 -17
  234. package/esm2022/components/textarea/index.mjs +2 -2
  235. package/esm2022/components/textarea/textarea.component.mjs +34 -34
  236. package/esm2022/components/textarea/textarea.module.mjs +15 -15
  237. package/esm2022/components/toggle/index.mjs +2 -2
  238. package/esm2022/components/toggle/toggle.component.mjs +10 -10
  239. package/esm2022/components/toggle/toggle.module.mjs +15 -15
  240. package/esm2022/cuby-ui-core.mjs +4 -4
  241. package/esm2022/directives/index.mjs +2 -2
  242. package/esm2022/directives/text-field-controller/index.mjs +8 -8
  243. package/esm2022/directives/text-field-controller/text-field-controller.module.mjs +39 -39
  244. package/esm2022/directives/text-field-controller/text-field-controller.provider.mjs +23 -23
  245. package/esm2022/directives/text-field-controller/text-field-icon-left.directive.mjs +20 -20
  246. package/esm2022/directives/text-field-controller/text-field-id.directive.mjs +20 -20
  247. package/esm2022/directives/text-field-controller/text-field-is-error.directive.mjs +23 -23
  248. package/esm2022/directives/text-field-controller/text-field-placeholder.directive.mjs +20 -20
  249. package/esm2022/directives/text-field-controller/text-field-size.directive.mjs +23 -23
  250. package/esm2022/directives/text-field-controller/text-field.controller.mjs +24 -24
  251. package/esm2022/directives/tooltip/index.mjs +16 -16
  252. package/esm2022/directives/tooltip/tooltip-describe.directive.mjs +44 -44
  253. package/esm2022/directives/tooltip/tooltip-driver.directive.mjs +17 -17
  254. package/esm2022/directives/tooltip/tooltip-host.directive.mjs +25 -25
  255. package/esm2022/directives/tooltip/tooltip-hover.directive.mjs +52 -52
  256. package/esm2022/directives/tooltip/tooltip-manual.directive.mjs +30 -30
  257. package/esm2022/directives/tooltip/tooltip-options.directive.mjs +82 -82
  258. package/esm2022/directives/tooltip/tooltip-overflow.directive.mjs +30 -30
  259. package/esm2022/directives/tooltip/tooltip-pointer.directive.mjs +30 -30
  260. package/esm2022/directives/tooltip/tooltip-position.directive.mjs +96 -96
  261. package/esm2022/directives/tooltip/tooltip-unstyled.component.mjs +39 -39
  262. package/esm2022/directives/tooltip/tooltip.component.mjs +98 -98
  263. package/esm2022/directives/tooltip/tooltip.directive.mjs +91 -91
  264. package/esm2022/directives/tooltip/tooltip.mjs +26 -26
  265. package/esm2022/directives/tooltip/tooltip.providers.mjs +6 -6
  266. package/esm2022/directives/tooltip/tooltip.service.mjs +27 -27
  267. package/esm2022/directives/tooltip/tooltips.component.mjs +32 -32
  268. package/esm2022/index.mjs +8 -7
  269. package/esm2022/interceptors/index.mjs +2 -0
  270. package/esm2022/interceptors/x-ndjson.interceptor.mjs +48 -0
  271. package/esm2022/interfaces/context-menu-item.mjs +1 -1
  272. package/esm2022/interfaces/index.mjs +3 -3
  273. package/esm2022/interfaces/option.mjs +1 -1
  274. package/esm2022/services/index.mjs +4 -4
  275. package/esm2022/services/position.service.mjs +22 -22
  276. package/esm2022/services/theme.options.mjs +5 -5
  277. package/esm2022/services/theme.service.mjs +29 -29
  278. package/esm2022/services/visual-viewport.service.mjs +27 -27
  279. package/esm2022/tokens/animations-speed.mjs +7 -7
  280. package/esm2022/tokens/index.mjs +3 -3
  281. package/esm2022/tokens/reduced-motion.mjs +5 -5
  282. package/esm2022/tokens/viewport.mjs +30 -30
  283. package/esm2022/types/appearance.mjs +1 -1
  284. package/esm2022/types/hint-type.mjs +1 -1
  285. package/esm2022/types/index.mjs +9 -9
  286. package/esm2022/types/point.mjs +1 -1
  287. package/esm2022/types/portal-item.mjs +1 -1
  288. package/esm2022/types/position.mjs +1 -1
  289. package/esm2022/types/resizing.mjs +1 -1
  290. package/esm2022/types/shape.mjs +1 -1
  291. package/esm2022/types/size.mjs +1 -1
  292. package/esm2022/types/status.mjs +1 -1
  293. package/esm2022/utils/format/index.mjs +2 -2
  294. package/esm2022/utils/format/remove-spaces.mjs +3 -3
  295. package/esm2022/utils/format/replace.mjs +4 -4
  296. package/esm2022/utils/index.mjs +2 -2
  297. package/esm2022/utils/miscellaneous/index.mjs +3 -3
  298. package/esm2022/utils/miscellaneous/is-obscured.mjs +7 -7
  299. package/esm2022/utils/miscellaneous/override-options.mjs +10 -10
  300. package/esm2022/utils/miscellaneous/to-animation-options.mjs +13 -13
  301. package/fesm2022/cuby-ui-core.mjs +3230 -3183
  302. package/fesm2022/cuby-ui-core.mjs.map +1 -1
  303. package/index.d.ts +7 -6
  304. package/interceptors/index.d.ts +1 -0
  305. package/interceptors/x-ndjson.interceptor.d.ts +2 -0
  306. package/interfaces/context-menu-item.d.ts +7 -7
  307. package/interfaces/index.d.ts +2 -2
  308. package/interfaces/option.d.ts +5 -5
  309. package/package.json +6 -6
  310. package/services/index.d.ts +4 -4
  311. package/services/position.service.d.ts +10 -10
  312. package/services/theme.options.d.ts +5 -5
  313. package/services/theme.service.d.ts +12 -12
  314. package/services/visual-viewport.service.d.ts +9 -9
  315. package/styles/reset.scss +111 -0
  316. package/tokens/animations-speed.d.ts +4 -4
  317. package/tokens/index.d.ts +3 -3
  318. package/tokens/reduced-motion.d.ts +1 -1
  319. package/tokens/viewport.d.ts +7 -7
  320. package/types/appearance.d.ts +8 -8
  321. package/types/hint-type.d.ts +1 -1
  322. package/types/index.d.ts +9 -9
  323. package/types/point.d.ts +1 -1
  324. package/types/portal-item.d.ts +9 -9
  325. package/types/position.d.ts +2 -2
  326. package/types/resizing.d.ts +2 -2
  327. package/types/shape.d.ts +1 -1
  328. package/types/size.d.ts +4 -4
  329. package/types/status.d.ts +1 -1
  330. package/utils/format/index.d.ts +2 -2
  331. package/utils/format/remove-spaces.d.ts +1 -1
  332. package/utils/format/replace.d.ts +1 -1
  333. package/utils/index.d.ts +2 -2
  334. package/utils/miscellaneous/index.d.ts +3 -3
  335. package/utils/miscellaneous/is-obscured.d.ts +4 -4
  336. package/utils/miscellaneous/override-options.d.ts +1 -1
  337. package/utils/miscellaneous/to-animation-options.d.ts +4 -4
@@ -1,172 +1,172 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, Input, ElementRef, ViewChild, HostBinding, ViewContainerRef, HostListener } from '@angular/core';
2
- import { DOCUMENT } from '@angular/common';
3
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
- import { CuiDestroyService } from '@cuby-ui/cdk';
5
- import { cuiProvide, CuiClickOutsideDirective } from '@cuby-ui/cdk';
6
- import { takeUntil } from 'rxjs';
7
- import { CUI_TEXT_FIELD_CONTROLLER, CUI_TEXT_FILED_CONTROLLER_PROVIDER } from '../../directives';
8
- import { CUI_ROOT_SELECTOR } from '../root';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "@cuby-ui/cdk";
11
- import * as i2 from "@angular/common";
12
- import * as i3 from "../svg/svg.component";
13
- export class CuiSelectComponent {
14
- constructor() {
15
- this.element = inject(ElementRef).nativeElement;
16
- this.document = inject(DOCUMENT);
17
- this.changeDetectorRef = inject(ChangeDetectorRef);
18
- this.viewContainerRef = inject(ViewContainerRef);
19
- this.destroy$ = inject(CuiDestroyService, { self: true });
20
- this.cuiTextFieldController = inject(CUI_TEXT_FIELD_CONTROLLER);
21
- this.cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });
22
- this.SPACE_BETWEEN_BUTTON_AND_OPTIONS = 3;
23
- this.isOpened = false;
24
- this.isOptionsListAbove = false;
25
- this.gap = `${this.SPACE_BETWEEN_BUTTON_AND_OPTIONS}px`;
26
- }
27
- get id() {
28
- return this.cuiTextFieldController.id;
29
- }
30
- get size() {
31
- return this.cuiTextFieldController.size;
32
- }
33
- get placeholder() {
34
- return this.cuiTextFieldController.placeholder;
35
- }
36
- get isError() {
37
- return this.cuiTextFieldController.isError;
38
- }
39
- trackByFn(_, item) {
40
- return item.label;
41
- }
42
- writeValue(value) {
43
- this.value = value;
44
- // TODO: Непонятно, зачем нужно в construction вторая часть выражения
45
- this.selectedOption = this.options.find(option => option.value === value) ?? value;
46
- this.changeDetectorRef.markForCheck();
47
- }
48
- registerOnChange(fn) {
49
- this.onChange = fn;
50
- }
51
- registerOnTouched(fn) {
52
- this.onTouched = fn;
53
- }
54
- ngOnInit() {
55
- this.initClickOutsideSubscription();
56
- }
57
- ngOnDestroy() {
58
- this.clearViewContainerRef();
59
- }
60
- setDisabledState(isDisabled) {
61
- this.isDisabled = isDisabled;
62
- this.changeDetectorRef.markForCheck();
63
- }
64
- onSelect(event, option) {
65
- event.stopPropagation();
66
- if (option.isDisabled) {
67
- return;
68
- }
69
- this.value = option.value;
70
- this.selectedOption = option;
71
- this.onChange(this.value);
72
- this.onSwitch();
73
- this.onTouched();
74
- this.changeDetectorRef.markForCheck();
75
- }
76
- onSwitch() {
77
- if (!this.options.length && !this.defaultOptionText) {
78
- return;
79
- }
80
- if (!this.isOpened) {
81
- this.open();
82
- return;
83
- }
84
- this.close();
85
- }
86
- onClose() {
87
- this.close();
88
- }
89
- onWindowResize() {
90
- this.button.nativeElement.blur();
91
- this.close();
92
- }
93
- initClickOutsideSubscription() {
94
- this.cuiClickOutsideDirective.cuiClickOutside
95
- .pipe(takeUntil(this.destroy$))
96
- .subscribe(() => {
97
- if (this.isOpened) {
98
- this.onTouched();
99
- }
100
- this.close();
101
- });
102
- }
103
- open() {
104
- this.isOpened = true;
105
- const rootElement = this.document.querySelector(CUI_ROOT_SELECTOR);
106
- const { top: elementRectTop, left: elementRectLeft, bottom: elementRectBottom } = this.element.getBoundingClientRect();
107
- const distanceToBottom = this.document.documentElement.clientHeight
108
- - (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);
109
- const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.optionsWrapper);
110
- const node = embeddedViewRef.rootNodes[0];
111
- const nodeStyles = node.style;
112
- this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;
113
- embeddedViewRef.detectChanges();
114
- nodeStyles.width = this.element.offsetWidth + 'px';
115
- nodeStyles.left = window.scrollX + elementRectLeft + 'px';
116
- if (this.isOptionsListAbove) {
117
- nodeStyles.top = window.scrollY + elementRectTop
118
- - this.getOptionsListHeightContainer.nativeElement.offsetHeight
119
- - this.SPACE_BETWEEN_BUTTON_AND_OPTIONS
120
- + 'px';
121
- }
122
- else {
123
- nodeStyles.top = window.scrollY + elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS + 'px';
124
- }
125
- rootElement.appendChild(this.viewContainerRef.createEmbeddedView(this.backdrop).rootNodes[0]);
126
- rootElement.appendChild(embeddedViewRef.rootNodes[0]);
127
- }
128
- close() {
129
- this.isOpened = false;
130
- this.clearViewContainerRef();
131
- }
132
- clearViewContainerRef() {
133
- this.viewContainerRef.clear();
134
- }
135
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
136
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CuiSelectComponent, selector: "cui-select[options]", inputs: { options: "options", defaultOptionText: "defaultOptionText" }, host: { listeners: { "window:resize": "onWindowResize()" }, properties: { "style.--c-gap": "this.gap" } }, providers: [
137
- CUI_TEXT_FILED_CONTROLLER_PROVIDER,
138
- cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
139
- CuiDestroyService
140
- ], viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }, { propertyName: "getOptionsListHeightContainer", first: true, predicate: ["getOptionsListHeightContainer"], descendants: true }, { propertyName: "backdrop", first: true, predicate: ["backdrop"], descendants: true }, { propertyName: "optionsWrapper", first: true, predicate: ["optionsWrapper"], descendants: true }], hostDirectives: [{ directive: i1.CuiClickOutsideDirective }], ngImport: i0, template: "<button\r\n #button\r\n type=\"button\"\r\n [attr.id]=\"id\"\r\n [attr.data-size]=\"size\"\r\n [disabled]=\"isDisabled\"\r\n class=\"c-button\"\r\n [class.c-button_active]=\"isOpened\"\r\n [class.c-button_with-error]=\"isError\"\r\n (click)=\"onSwitch()\"\r\n>\r\n <ng-container *ngIf=\"selectedOption; else placeholderTemplate\">\r\n {{ selectedOption.label }}\r\n </ng-container>\r\n <ng-template #placeholderTemplate>\r\n <span class=\"c-placeholder\">{{ placeholder }}</span>\r\n </ng-template>\r\n <cui-svg\r\n icon=\"cuiIconChevronDown\"\r\n color=\"var(--cui-base-500)\"\r\n />\r\n</button>\r\n<ng-template #backdrop>\r\n <div class=\"c-backdrop\"></div>\r\n</ng-template>\r\n<ng-template #optionsWrapper>\r\n <div\r\n cuiFocusTrap\r\n class=\"c-options__wrapper\"\r\n [class.c-options__wrapper_top]=\"isOptionsListAbove\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n </div>\r\n</ng-template>\r\n<div\r\n #getOptionsListHeightContainer\r\n class=\"c-get-options-list-height-container\"\r\n>\r\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n</div>\r\n<ng-template #optionsList>\r\n <ul\r\n class=\"c-options\"\r\n [class.c-options_top]=\"isOptionsListAbove\"\r\n >\r\n <ng-container *ngIf=\"options.length; else empty\">\r\n <li *ngFor=\"let option of options; trackBy: trackByFn\">\r\n <button\r\n type=\"button\"\r\n class=\"c-option-button\"\r\n [class.c-option-button_selected]=\"selectedOption === option\"\r\n [disabled]=\"option.isDisabled\"\r\n (click)=\"onSelect($event, option)\"\r\n >\r\n <span>{{ option.label }}</span>\r\n <cui-svg\r\n *ngIf=\"selectedOption === option\"\r\n icon=\"cuiIconCheckSm\"\r\n color=\"var(--cui-info)\"\r\n class=\"c-option-button__icon\"\r\n />\r\n </button>\r\n </li>\r\n </ng-container>\r\n <ng-template #empty>\r\n <li *ngIf=\"defaultOptionText\">\r\n <button\r\n type=\"button\"\r\n class=\"c-option-button\"\r\n (click)=\"onClose()\"\r\n >\r\n {{ defaultOptionText }}\r\n </button>\r\n </li>\r\n </ng-template>\r\n </ul>\r\n</ng-template>\r\n", styles: [":host{display:block;font-family:var(--cui-main-font);position:relative}.c-button{border:0;flex-shrink:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:0 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;border:1px solid var(--cui-base-200);border-radius:8px;cursor:pointer;background:var(--cui-input);color:var(--cui-base-900);font-family:var(--cui-main-font);text-align:start}.c-button:hover{border-color:var(--cui-base-300)}.c-button_active.c-button_active,.c-button:focus{box-shadow:0 0 0 2px var(--cui-focus);border-color:var(--cui-info)}.c-button:disabled{cursor:not-allowed;opacity:.5;background:var(--cui-base-50);border-color:var(--cui-base-200)}.c-button[data-size=sm]{padding-top:7px;padding-bottom:7px}.c-button[data-size=md]{padding-top:8px;padding-bottom:8px}.c-button_with-error{border-color:var(--cui-danger)}.c-button_with-error:focus{box-shadow:0 0 0 2px #d92d2040;border-color:var(--cui-danger)}.c-placeholder{color:var(--cui-base-400)}.c-backdrop{position:fixed;inset:0}.c-options__wrapper{position:absolute;font-family:var(--cui-main-font);z-index:1}.c-get-options-list-height-container{position:fixed;visibility:hidden}.c-options{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;overflow:auto;max-height:180px;border:1px solid var(--cui-base-200);border-radius:8px;background:var(--cui-base-0);color:var(--cui-base-900)}.c-option-button{padding:8px 11px 8px 0;border:0;flex-shrink:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px;text-align:start}.c-option-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-option-button:hover{background:var(--cui-base-50)}}.c-option-button_selected{background:var(--cui-base-50)}.c-option-button:disabled{background:unset;opacity:50%}.c-option-button__icon{margin-left:auto}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "directive", type: i1.CuiFocusTrapDirective, selector: "[cuiFocusTrap]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
141
- }
142
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectComponent, decorators: [{
143
- type: Component,
144
- args: [{ selector: 'cui-select[options]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
145
- CUI_TEXT_FILED_CONTROLLER_PROVIDER,
146
- cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
147
- CuiDestroyService
148
- ], hostDirectives: [CuiClickOutsideDirective], template: "<button\r\n #button\r\n type=\"button\"\r\n [attr.id]=\"id\"\r\n [attr.data-size]=\"size\"\r\n [disabled]=\"isDisabled\"\r\n class=\"c-button\"\r\n [class.c-button_active]=\"isOpened\"\r\n [class.c-button_with-error]=\"isError\"\r\n (click)=\"onSwitch()\"\r\n>\r\n <ng-container *ngIf=\"selectedOption; else placeholderTemplate\">\r\n {{ selectedOption.label }}\r\n </ng-container>\r\n <ng-template #placeholderTemplate>\r\n <span class=\"c-placeholder\">{{ placeholder }}</span>\r\n </ng-template>\r\n <cui-svg\r\n icon=\"cuiIconChevronDown\"\r\n color=\"var(--cui-base-500)\"\r\n />\r\n</button>\r\n<ng-template #backdrop>\r\n <div class=\"c-backdrop\"></div>\r\n</ng-template>\r\n<ng-template #optionsWrapper>\r\n <div\r\n cuiFocusTrap\r\n class=\"c-options__wrapper\"\r\n [class.c-options__wrapper_top]=\"isOptionsListAbove\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n </div>\r\n</ng-template>\r\n<div\r\n #getOptionsListHeightContainer\r\n class=\"c-get-options-list-height-container\"\r\n>\r\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n</div>\r\n<ng-template #optionsList>\r\n <ul\r\n class=\"c-options\"\r\n [class.c-options_top]=\"isOptionsListAbove\"\r\n >\r\n <ng-container *ngIf=\"options.length; else empty\">\r\n <li *ngFor=\"let option of options; trackBy: trackByFn\">\r\n <button\r\n type=\"button\"\r\n class=\"c-option-button\"\r\n [class.c-option-button_selected]=\"selectedOption === option\"\r\n [disabled]=\"option.isDisabled\"\r\n (click)=\"onSelect($event, option)\"\r\n >\r\n <span>{{ option.label }}</span>\r\n <cui-svg\r\n *ngIf=\"selectedOption === option\"\r\n icon=\"cuiIconCheckSm\"\r\n color=\"var(--cui-info)\"\r\n class=\"c-option-button__icon\"\r\n />\r\n </button>\r\n </li>\r\n </ng-container>\r\n <ng-template #empty>\r\n <li *ngIf=\"defaultOptionText\">\r\n <button\r\n type=\"button\"\r\n class=\"c-option-button\"\r\n (click)=\"onClose()\"\r\n >\r\n {{ defaultOptionText }}\r\n </button>\r\n </li>\r\n </ng-template>\r\n </ul>\r\n</ng-template>\r\n", styles: [":host{display:block;font-family:var(--cui-main-font);position:relative}.c-button{border:0;flex-shrink:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:0 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;border:1px solid var(--cui-base-200);border-radius:8px;cursor:pointer;background:var(--cui-input);color:var(--cui-base-900);font-family:var(--cui-main-font);text-align:start}.c-button:hover{border-color:var(--cui-base-300)}.c-button_active.c-button_active,.c-button:focus{box-shadow:0 0 0 2px var(--cui-focus);border-color:var(--cui-info)}.c-button:disabled{cursor:not-allowed;opacity:.5;background:var(--cui-base-50);border-color:var(--cui-base-200)}.c-button[data-size=sm]{padding-top:7px;padding-bottom:7px}.c-button[data-size=md]{padding-top:8px;padding-bottom:8px}.c-button_with-error{border-color:var(--cui-danger)}.c-button_with-error:focus{box-shadow:0 0 0 2px #d92d2040;border-color:var(--cui-danger)}.c-placeholder{color:var(--cui-base-400)}.c-backdrop{position:fixed;inset:0}.c-options__wrapper{position:absolute;font-family:var(--cui-main-font);z-index:1}.c-get-options-list-height-container{position:fixed;visibility:hidden}.c-options{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;overflow:auto;max-height:180px;border:1px solid var(--cui-base-200);border-radius:8px;background:var(--cui-base-0);color:var(--cui-base-900)}.c-option-button{padding:8px 11px 8px 0;border:0;flex-shrink:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px;text-align:start}.c-option-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-option-button:hover{background:var(--cui-base-50)}}.c-option-button_selected{background:var(--cui-base-50)}.c-option-button:disabled{background:unset;opacity:50%}.c-option-button__icon{margin-left:auto}\n"] }]
149
- }], propDecorators: { options: [{
150
- type: Input
151
- }], defaultOptionText: [{
152
- type: Input
153
- }], button: [{
154
- type: ViewChild,
155
- args: ['button']
156
- }], getOptionsListHeightContainer: [{
157
- type: ViewChild,
158
- args: ['getOptionsListHeightContainer']
159
- }], backdrop: [{
160
- type: ViewChild,
161
- args: ['backdrop']
162
- }], optionsWrapper: [{
163
- type: ViewChild,
164
- args: ['optionsWrapper']
165
- }], gap: [{
166
- type: HostBinding,
167
- args: ['style.--c-gap']
168
- }], onWindowResize: [{
169
- type: HostListener,
170
- args: ['window:resize']
171
- }] } });
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, Input, ElementRef, ViewChild, HostBinding, ViewContainerRef, HostListener } from '@angular/core';
2
+ import { DOCUMENT } from '@angular/common';
3
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import { CuiDestroyService } from '@cuby-ui/cdk';
5
+ import { cuiProvide, CuiClickOutsideDirective } from '@cuby-ui/cdk';
6
+ import { takeUntil } from 'rxjs';
7
+ import { CUI_TEXT_FIELD_CONTROLLER, CUI_TEXT_FILED_CONTROLLER_PROVIDER } from '../../directives';
8
+ import { CUI_ROOT_SELECTOR } from '../root';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@cuby-ui/cdk";
11
+ import * as i2 from "@angular/common";
12
+ import * as i3 from "../svg/svg.component";
13
+ export class CuiSelectComponent {
14
+ constructor() {
15
+ this.element = inject(ElementRef).nativeElement;
16
+ this.document = inject(DOCUMENT);
17
+ this.changeDetectorRef = inject(ChangeDetectorRef);
18
+ this.viewContainerRef = inject(ViewContainerRef);
19
+ this.destroy$ = inject(CuiDestroyService, { self: true });
20
+ this.cuiTextFieldController = inject(CUI_TEXT_FIELD_CONTROLLER);
21
+ this.cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });
22
+ this.SPACE_BETWEEN_BUTTON_AND_OPTIONS = 3;
23
+ this.isOpened = false;
24
+ this.isOptionsListAbove = false;
25
+ this.gap = `${this.SPACE_BETWEEN_BUTTON_AND_OPTIONS}px`;
26
+ }
27
+ get id() {
28
+ return this.cuiTextFieldController.id;
29
+ }
30
+ get size() {
31
+ return this.cuiTextFieldController.size;
32
+ }
33
+ get placeholder() {
34
+ return this.cuiTextFieldController.placeholder;
35
+ }
36
+ get isError() {
37
+ return this.cuiTextFieldController.isError;
38
+ }
39
+ trackByFn(_, item) {
40
+ return item.label;
41
+ }
42
+ writeValue(value) {
43
+ this.value = value;
44
+ // TODO: Непонятно, зачем нужно в construction вторая часть выражения
45
+ this.selectedOption = this.options.find(option => option.value === value) ?? value;
46
+ this.changeDetectorRef.markForCheck();
47
+ }
48
+ registerOnChange(fn) {
49
+ this.onChange = fn;
50
+ }
51
+ registerOnTouched(fn) {
52
+ this.onTouched = fn;
53
+ }
54
+ ngOnInit() {
55
+ this.initClickOutsideSubscription();
56
+ }
57
+ ngOnDestroy() {
58
+ this.clearViewContainerRef();
59
+ }
60
+ setDisabledState(isDisabled) {
61
+ this.isDisabled = isDisabled;
62
+ this.changeDetectorRef.markForCheck();
63
+ }
64
+ onSelect(event, option) {
65
+ event.stopPropagation();
66
+ if (option.isDisabled) {
67
+ return;
68
+ }
69
+ this.value = option.value;
70
+ this.selectedOption = option;
71
+ this.onChange(this.value);
72
+ this.onSwitch();
73
+ this.onTouched();
74
+ this.changeDetectorRef.markForCheck();
75
+ }
76
+ onSwitch() {
77
+ if (!this.options.length && !this.defaultOptionText) {
78
+ return;
79
+ }
80
+ if (!this.isOpened) {
81
+ this.open();
82
+ return;
83
+ }
84
+ this.close();
85
+ }
86
+ onClose() {
87
+ this.close();
88
+ }
89
+ onWindowResize() {
90
+ this.button.nativeElement.blur();
91
+ this.close();
92
+ }
93
+ initClickOutsideSubscription() {
94
+ this.cuiClickOutsideDirective.cuiClickOutside
95
+ .pipe(takeUntil(this.destroy$))
96
+ .subscribe(() => {
97
+ if (this.isOpened) {
98
+ this.onTouched();
99
+ }
100
+ this.close();
101
+ });
102
+ }
103
+ open() {
104
+ this.isOpened = true;
105
+ const rootElement = this.document.querySelector(CUI_ROOT_SELECTOR);
106
+ const { top: elementRectTop, left: elementRectLeft, bottom: elementRectBottom } = this.element.getBoundingClientRect();
107
+ const distanceToBottom = this.document.documentElement.clientHeight
108
+ - (elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS);
109
+ const embeddedViewRef = this.viewContainerRef.createEmbeddedView(this.optionsWrapper);
110
+ const node = embeddedViewRef.rootNodes[0];
111
+ const nodeStyles = node.style;
112
+ this.isOptionsListAbove = distanceToBottom < this.getOptionsListHeightContainer.nativeElement.offsetHeight;
113
+ embeddedViewRef.detectChanges();
114
+ nodeStyles.width = this.element.offsetWidth + 'px';
115
+ nodeStyles.left = window.scrollX + elementRectLeft + 'px';
116
+ if (this.isOptionsListAbove) {
117
+ nodeStyles.top = window.scrollY + elementRectTop
118
+ - this.getOptionsListHeightContainer.nativeElement.offsetHeight
119
+ - this.SPACE_BETWEEN_BUTTON_AND_OPTIONS
120
+ + 'px';
121
+ }
122
+ else {
123
+ nodeStyles.top = window.scrollY + elementRectBottom + this.SPACE_BETWEEN_BUTTON_AND_OPTIONS + 'px';
124
+ }
125
+ rootElement.appendChild(this.viewContainerRef.createEmbeddedView(this.backdrop).rootNodes[0]);
126
+ rootElement.appendChild(embeddedViewRef.rootNodes[0]);
127
+ }
128
+ close() {
129
+ this.isOpened = false;
130
+ this.clearViewContainerRef();
131
+ }
132
+ clearViewContainerRef() {
133
+ this.viewContainerRef.clear();
134
+ }
135
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
136
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CuiSelectComponent, selector: "cui-select[options]", inputs: { options: "options", defaultOptionText: "defaultOptionText" }, host: { listeners: { "window:resize": "onWindowResize()" }, properties: { "style.--c-gap": "this.gap" } }, providers: [
137
+ CUI_TEXT_FILED_CONTROLLER_PROVIDER,
138
+ cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
139
+ CuiDestroyService
140
+ ], viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }, { propertyName: "getOptionsListHeightContainer", first: true, predicate: ["getOptionsListHeightContainer"], descendants: true }, { propertyName: "backdrop", first: true, predicate: ["backdrop"], descendants: true }, { propertyName: "optionsWrapper", first: true, predicate: ["optionsWrapper"], descendants: true }], hostDirectives: [{ directive: i1.CuiClickOutsideDirective }], ngImport: i0, template: "<button\r\n #button\r\n type=\"button\"\r\n [attr.id]=\"id\"\r\n [attr.data-size]=\"size\"\r\n [disabled]=\"isDisabled\"\r\n class=\"c-button\"\r\n [class.c-button_active]=\"isOpened\"\r\n [class.c-button_with-error]=\"isError\"\r\n (click)=\"onSwitch()\"\r\n>\r\n <ng-container *ngIf=\"selectedOption; else placeholderTemplate\">\r\n {{ selectedOption.label }}\r\n </ng-container>\r\n <ng-template #placeholderTemplate>\r\n <span class=\"c-placeholder\">{{ placeholder }}</span>\r\n </ng-template>\r\n <cui-svg\r\n icon=\"cuiIconChevronDown\"\r\n color=\"var(--cui-base-500)\"\r\n />\r\n</button>\r\n<ng-template #backdrop>\r\n <div class=\"c-backdrop\"></div>\r\n</ng-template>\r\n<ng-template #optionsWrapper>\r\n <div\r\n cuiFocusTrap\r\n class=\"c-options__wrapper\"\r\n [class.c-options__wrapper_top]=\"isOptionsListAbove\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n </div>\r\n</ng-template>\r\n<div\r\n #getOptionsListHeightContainer\r\n class=\"c-get-options-list-height-container\"\r\n>\r\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n</div>\r\n<ng-template #optionsList>\r\n <ul\r\n class=\"c-options\"\r\n [class.c-options_top]=\"isOptionsListAbove\"\r\n >\r\n <ng-container *ngIf=\"options.length; else empty\">\r\n <li *ngFor=\"let option of options; trackBy: trackByFn\">\r\n <button\r\n type=\"button\"\r\n class=\"c-option-button\"\r\n [class.c-option-button_selected]=\"selectedOption === option\"\r\n [disabled]=\"option.isDisabled\"\r\n (click)=\"onSelect($event, option)\"\r\n >\r\n <span>{{ option.label }}</span>\r\n <cui-svg\r\n *ngIf=\"selectedOption === option\"\r\n icon=\"cuiIconCheckSm\"\r\n color=\"var(--cui-info)\"\r\n class=\"c-option-button__icon\"\r\n />\r\n </button>\r\n </li>\r\n </ng-container>\r\n <ng-template #empty>\r\n <li *ngIf=\"defaultOptionText\">\r\n <button\r\n type=\"button\"\r\n class=\"c-option-button\"\r\n (click)=\"onClose()\"\r\n >\r\n {{ defaultOptionText }}\r\n </button>\r\n </li>\r\n </ng-template>\r\n </ul>\r\n</ng-template>\r\n", styles: [":host{display:block;font-family:var(--cui-main-font);position:relative}.c-button{border:0;flex-shrink:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:0 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;border:1px solid var(--cui-base-200);border-radius:8px;cursor:pointer;background:var(--cui-input);color:var(--cui-base-900);font-family:var(--cui-main-font);text-align:start}.c-button:hover{border-color:var(--cui-base-300)}.c-button_active.c-button_active,.c-button:focus{box-shadow:0 0 0 2px var(--cui-focus);border-color:var(--cui-info)}.c-button:disabled{cursor:not-allowed;opacity:.5;background:var(--cui-base-50);border-color:var(--cui-base-200)}.c-button[data-size=sm]{padding-top:7px;padding-bottom:7px}.c-button[data-size=md]{padding-top:8px;padding-bottom:8px}.c-button_with-error{border-color:var(--cui-danger)}.c-button_with-error:focus{box-shadow:0 0 0 2px #d92d2040;border-color:var(--cui-danger)}.c-placeholder{color:var(--cui-base-400)}.c-backdrop{position:fixed;inset:0}.c-options__wrapper{position:absolute;font-family:var(--cui-main-font);z-index:1}.c-get-options-list-height-container{position:fixed;visibility:hidden}.c-options{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;overflow:auto;max-height:180px;border:1px solid var(--cui-base-200);border-radius:8px;background:var(--cui-base-0);color:var(--cui-base-900)}.c-option-button{padding:8px 11px 8px 0;border:0;flex-shrink:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px;text-align:start}.c-option-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-option-button:hover{background:var(--cui-base-50)}}.c-option-button_selected{background:var(--cui-base-50)}.c-option-button:disabled{background:unset;opacity:50%}.c-option-button__icon{margin-left:auto}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "directive", type: i1.CuiFocusTrapDirective, selector: "[cuiFocusTrap]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
141
+ }
142
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectComponent, decorators: [{
143
+ type: Component,
144
+ args: [{ selector: 'cui-select[options]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
145
+ CUI_TEXT_FILED_CONTROLLER_PROVIDER,
146
+ cuiProvide(NG_VALUE_ACCESSOR, CuiSelectComponent, true),
147
+ CuiDestroyService
148
+ ], hostDirectives: [CuiClickOutsideDirective], template: "<button\r\n #button\r\n type=\"button\"\r\n [attr.id]=\"id\"\r\n [attr.data-size]=\"size\"\r\n [disabled]=\"isDisabled\"\r\n class=\"c-button\"\r\n [class.c-button_active]=\"isOpened\"\r\n [class.c-button_with-error]=\"isError\"\r\n (click)=\"onSwitch()\"\r\n>\r\n <ng-container *ngIf=\"selectedOption; else placeholderTemplate\">\r\n {{ selectedOption.label }}\r\n </ng-container>\r\n <ng-template #placeholderTemplate>\r\n <span class=\"c-placeholder\">{{ placeholder }}</span>\r\n </ng-template>\r\n <cui-svg\r\n icon=\"cuiIconChevronDown\"\r\n color=\"var(--cui-base-500)\"\r\n />\r\n</button>\r\n<ng-template #backdrop>\r\n <div class=\"c-backdrop\"></div>\r\n</ng-template>\r\n<ng-template #optionsWrapper>\r\n <div\r\n cuiFocusTrap\r\n class=\"c-options__wrapper\"\r\n [class.c-options__wrapper_top]=\"isOptionsListAbove\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n </div>\r\n</ng-template>\r\n<div\r\n #getOptionsListHeightContainer\r\n class=\"c-get-options-list-height-container\"\r\n>\r\n <ng-container *ngTemplateOutlet=\"optionsList\"/>\r\n</div>\r\n<ng-template #optionsList>\r\n <ul\r\n class=\"c-options\"\r\n [class.c-options_top]=\"isOptionsListAbove\"\r\n >\r\n <ng-container *ngIf=\"options.length; else empty\">\r\n <li *ngFor=\"let option of options; trackBy: trackByFn\">\r\n <button\r\n type=\"button\"\r\n class=\"c-option-button\"\r\n [class.c-option-button_selected]=\"selectedOption === option\"\r\n [disabled]=\"option.isDisabled\"\r\n (click)=\"onSelect($event, option)\"\r\n >\r\n <span>{{ option.label }}</span>\r\n <cui-svg\r\n *ngIf=\"selectedOption === option\"\r\n icon=\"cuiIconCheckSm\"\r\n color=\"var(--cui-info)\"\r\n class=\"c-option-button__icon\"\r\n />\r\n </button>\r\n </li>\r\n </ng-container>\r\n <ng-template #empty>\r\n <li *ngIf=\"defaultOptionText\">\r\n <button\r\n type=\"button\"\r\n class=\"c-option-button\"\r\n (click)=\"onClose()\"\r\n >\r\n {{ defaultOptionText }}\r\n </button>\r\n </li>\r\n </ng-template>\r\n </ul>\r\n</ng-template>\r\n", styles: [":host{display:block;font-family:var(--cui-main-font);position:relative}.c-button{border:0;flex-shrink:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:0 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;border:1px solid var(--cui-base-200);border-radius:8px;cursor:pointer;background:var(--cui-input);color:var(--cui-base-900);font-family:var(--cui-main-font);text-align:start}.c-button:hover{border-color:var(--cui-base-300)}.c-button_active.c-button_active,.c-button:focus{box-shadow:0 0 0 2px var(--cui-focus);border-color:var(--cui-info)}.c-button:disabled{cursor:not-allowed;opacity:.5;background:var(--cui-base-50);border-color:var(--cui-base-200)}.c-button[data-size=sm]{padding-top:7px;padding-bottom:7px}.c-button[data-size=md]{padding-top:8px;padding-bottom:8px}.c-button_with-error{border-color:var(--cui-danger)}.c-button_with-error:focus{box-shadow:0 0 0 2px #d92d2040;border-color:var(--cui-danger)}.c-placeholder{color:var(--cui-base-400)}.c-backdrop{position:fixed;inset:0}.c-options__wrapper{position:absolute;font-family:var(--cui-main-font);z-index:1}.c-get-options-list-height-container{position:fixed;visibility:hidden}.c-options{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;overflow:auto;max-height:180px;border:1px solid var(--cui-base-200);border-radius:8px;background:var(--cui-base-0);color:var(--cui-base-900)}.c-option-button{padding:8px 11px 8px 0;border:0;flex-shrink:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px;text-align:start}.c-option-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-option-button:hover{background:var(--cui-base-50)}}.c-option-button_selected{background:var(--cui-base-50)}.c-option-button:disabled{background:unset;opacity:50%}.c-option-button__icon{margin-left:auto}\n"] }]
149
+ }], propDecorators: { options: [{
150
+ type: Input
151
+ }], defaultOptionText: [{
152
+ type: Input
153
+ }], button: [{
154
+ type: ViewChild,
155
+ args: ['button']
156
+ }], getOptionsListHeightContainer: [{
157
+ type: ViewChild,
158
+ args: ['getOptionsListHeightContainer']
159
+ }], backdrop: [{
160
+ type: ViewChild,
161
+ args: ['backdrop']
162
+ }], optionsWrapper: [{
163
+ type: ViewChild,
164
+ args: ['optionsWrapper']
165
+ }], gap: [{
166
+ type: HostBinding,
167
+ args: ['style.--c-gap']
168
+ }], onWindowResize: [{
169
+ type: HostListener,
170
+ args: ['window:resize']
171
+ }] } });
172
172
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9zZWxlY3Qvc2VsZWN0LnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixpQkFBaUIsRUFDakIsU0FBUyxFQUNULE1BQU0sRUFDTixLQUFLLEVBQ0wsVUFBVSxFQUNWLFNBQVMsRUFDVCxXQUFXLEVBQ1gsZ0JBQWdCLEVBQ2hCLFlBQVksRUFDYixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0MsT0FBTyxFQUF3QixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXpFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNqRCxPQUFPLEVBQUUsVUFBVSxFQUFFLHdCQUF3QixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ3BFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFJakMsT0FBTyxFQUFFLHlCQUF5QixFQUFFLGtDQUFrQyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakcsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sU0FBUyxDQUFDOzs7OztBQWM1QyxNQUFNLE9BQU8sa0JBQWtCO0lBWi9CO1FBYW1CLFlBQU8sR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsYUFBYSxDQUFDO1FBQzNDLGFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDNUIsc0JBQWlCLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDOUMscUJBQWdCLEdBQUcsTUFBTSxDQUFDLGdCQUFn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cUJBQXFCO1FBQzNCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNoQyxDQUFDOytHQXpMVSxrQkFBa0I7bUdBQWxCLGtCQUFrQixpT0FQbEI7WUFDVCxrQ0FBa0M7WUFDbEMsVUFBVSxDQUFDLGlCQUFpQixFQUFFLGtCQUFrQixFQUFFLElBQUksQ0FBQztZQUN2RCxpQkFBaUI7U0FDbEIscWZDbENILHN4RUE2RUE7OzRGRHhDYSxrQkFBa0I7a0JBWjlCLFNBQVM7K0JBQ0UscUJBQXFCLG1CQUdkLHVCQUF1QixDQUFDLE1BQU0sYUFDcEM7d0JBQ1Qsa0NBQWtDO3dCQUNsQyxVQUFVLENBQUMsaUJBQWlCLHNCQUFzQixJQUFJLENBQUM7d0JBQ3ZELGlCQUFpQjtxQkFDbEIsa0JBQ2UsQ0FBQyx3QkFBd0IsQ0FBQzs4QkFzQm5DLE9BQU87c0JBRGIsS0FBSztnQkFJQyxpQkFBaUI7c0JBRHZCLEtBQUs7Z0JBSWEsTUFBTTtzQkFEeEIsU0FBUzt1QkFBQyxRQUFRO2dCQUlBLDZCQUE2QjtzQkFEL0MsU0FBUzt1QkFBQywrQkFBK0I7Z0JBSXZCLFFBQVE7c0JBRDFCLFNBQVM7dUJBQUMsVUFBVTtnQkFJRixjQUFjO3NCQURoQyxTQUFTO3VCQUFDLGdCQUFnQjtnQkFJakIsR0FBRztzQkFEWixXQUFXO3VCQUFDLGVBQWU7Z0JBd0ZsQixjQUFjO3NCQUR2QixZQUFZO3VCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE9uRGVzdHJveSwgT25Jbml0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1xyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIENvbXBvbmVudCxcclxuICBpbmplY3QsXHJcbiAgSW5wdXQsXHJcbiAgRWxlbWVudFJlZixcclxuICBWaWV3Q2hpbGQsXHJcbiAgSG9zdEJpbmRpbmcsXHJcbiAgVmlld0NvbnRhaW5lclJlZixcclxuICBIb3N0TGlzdGVuZXJcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRE9DVU1FTlQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB0eXBlIHsgQ3VpT25DaGFuZ2UsIEN1aU9uVG91Y2hlZCwgQ3VpTnVsbGFibGUgfSBmcm9tICdAY3VieS11aS9jZGsnO1xyXG5pbXBvcnQgeyBDdWlEZXN0cm95U2VydmljZSB9IGZyb20gJ0BjdWJ5LXVpL2Nkayc7XHJcbmltcG9ydCB7IGN1aVByb3ZpZGUsIEN1aUNsaWNrT3V0c2lkZURpcmVjdGl2ZSB9IGZyb20gJ0BjdWJ5LXVpL2Nkayc7XHJcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xyXG5cclxuaW1wb3J0IHR5cGUgeyBDdWlPcHRpb24gfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcclxuaW1wb3J0IHR5cGUgeyBDdWlTaXplTWQsIEN1aVNpemVTbSB9IGZyb20gJy4uLy4uL3R5cGVzJztcclxuaW1wb3J0IHsgQ1VJX1RFWFRfRklFTERfQ09OVFJPTExFUiwgQ1VJX1RFWFRfRklMRURfQ09OVFJPTExFUl9QUk9WSURFUiB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMnO1xyXG5pbXBvcnQgeyBDVUlfUk9PVF9TRUxFQ1RPUiB9IGZyb20gJy4uL3Jvb3QnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdjdWktc2VsZWN0W29wdGlvbnNdJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2VsZWN0LnRlbXBsYXRlLmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3NlbGVjdC5zdHlsZS5zY3NzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICBDVUlfVEVYVF9GSUxFRF9DT05UUk9MTEVSX1BST1ZJREVSLFxyXG4gICAgY3VpUHJvdmlkZShOR19WQUxVRV9BQ0NFU1NPUiwgQ3VpU2VsZWN0Q29tcG9uZW50LCB0cnVlKSxcclxuICAgIEN1aURlc3Ryb3lTZXJ2aWNlXHJcbiAgXSxcclxuICBob3N0RGlyZWN0aXZlczogW0N1aUNsaWNrT3V0c2lkZURpcmVjdGl2ZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIEN1aVNlbGVjdENvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBPbkluaXQsIE9uRGVzdHJveSB7XHJcbiAgcHJpdmF0ZSByZWFkb25seSBlbGVtZW50ID0gaW5qZWN0KEVsZW1lbnRSZWYpLm5hdGl2ZUVsZW1lbnQ7XHJcbiAgcHJpdmF0ZSByZWFkb25seSBkb2N1bWVudCA9IGluamVjdChET0NVTUVOVCk7XHJcbiAgcHJpdmF0ZSByZWFkb25seSBjaGFuZ2VEZXRlY3RvclJlZiA9IGluamVjdChDaGFuZ2VEZXRlY3RvclJlZik7XHJcbiAgcHJpdmF0ZSByZWFkb25seSB2aWV3Q29udGFpbmVyUmVmID0gaW5qZWN0KFZpZXdDb250YWluZXJSZWYpO1xyXG4gIHByaXZhdGUgcmVhZG9ubHkgZGVzdHJveSQgPSBpbmplY3QoQ3VpRGVzdHJveVNlcnZpY2UsIHtzZWxmOiB0cnVlfSk7XHJcbiAgcHJpdmF0ZSByZWFkb25seSBjdWlUZXh0RmllbGRDb250cm9sbGVyID0gaW5qZWN0KENVSV9URVhUX0ZJRUxEX0NPTlRST0xMRVIpO1xyXG4gIHByaXZhdGUgcmVhZG9ubHkgY3VpQ2xpY2tPdXRzaWRlRGlyZWN0aXZlID0gaW5qZWN0KEN1aUNsaWNrT3V0c2lkZURpcmVjdGl2ZSwge3NlbGY6IHRydWV9KTtcclxuXHJcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IFNQQUNFX0JFVFdFRU5fQlVUVE9OX0FORF9PUFRJT05TID0gMztcclxuXHJcbiAgcHJvdGVjdGVkIGlzT3BlbmVkID0gZmFsc2U7XHJcbiAgcHJvdGVjdGVkIGlzT3B0aW9uc0xpc3RBYm92ZSA9IGZhbHNlO1xyXG4gIHByb3RlY3RlZCB2YWx1ZSE6IEN1aU51bGxhYmxlPHVua25vd24+O1xyXG4gIHByb3RlY3RlZCBvbkNoYW5nZSE6IEN1aU9uQ2hhbmdlPHVua25vd24+O1xyXG4gIHByb3RlY3RlZCBvblRvdWNoZWQhOiBDdWlPblRvdWNoZWQ7XHJcbiAgcHJvdGVjdGVkIGlzRGlzYWJsZWQhOiBib29sZWFuO1xyXG4gIHByb3RlY3RlZCBzZWxlY3RlZE9wdGlvbj86IEN1aU9wdGlvbjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgb3B0aW9ucyE6IEN1aU9wdGlvbltdO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBkZWZhdWx0T3B0aW9uVGV4dD86IHN0cmluZztcclxuXHJcbiAgQFZpZXdDaGlsZCgnYnV0dG9uJylcclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgYnV0dG9uITogRWxlbWVudFJlZjxIVE1MQnV0dG9uRWxlbWVudD47XHJcblxyXG4gIEBWaWV3Q2hpbGQoJ2dldE9wdGlvbnNMaXN0SGVpZ2h0Q29udGFpbmVyJylcclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgZ2V0T3B0aW9uc0xpc3RIZWlnaHRDb250YWluZXIhOiBFbGVtZW50UmVmPEhUTUxVTGlzdEVsZW1lbnQ+O1xyXG5cclxuICBAVmlld0NoaWxkKCdiYWNrZHJvcCcpXHJcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGJhY2tkcm9wITogVGVtcGxhdGVSZWY8dW5rbm93bj47XHJcblxyXG4gIEBWaWV3Q2hpbGQoJ29wdGlvbnNXcmFwcGVyJylcclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgb3B0aW9uc1dyYXBwZXIhOiBUZW1wbGF0ZVJlZjx1bmtub3duPjtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS4tLWMtZ2FwJylcclxuICBwcm90ZWN0ZWQgZ2FwID0gYCR7dGhpcy5TUEFDRV9CRVRXRUVOX0JVVFRPTl9BTkRfT1BUSU9OU31weGA7XHJcblxyXG4gIHByb3RlY3RlZCBnZXQgaWQoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcclxuICAgIHJldHVybiB0aGlzLmN1aVRleHRGaWVsZENvbnRyb2xsZXIuaWQ7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgZ2V0IHNpemUoKTogQ3VpU2l6ZVNtIHwgQ3VpU2l6ZU1kIHtcclxuICAgIHJldHVybiB0aGlzLmN1aVRleHRGaWVsZENvbnRyb2xsZXIuc2l6ZTtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCBnZXQgcGxhY2Vob2xkZXIoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcclxuICAgIHJldHVybiB0aGlzLmN1aVRleHRGaWVsZENvbnRyb2xsZXIucGxhY2Vob2xkZXI7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgZ2V0IGlzRXJyb3IoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5jdWlUZXh0RmllbGRDb250cm9sbGVyLmlzRXJyb3I7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgdHJhY2tCeUZuKF86IG51bWJlciwgaXRlbTogQ3VpT3B0aW9uKTogc3RyaW5nIHtcclxuICAgIHJldHVybiBpdGVtLmxhYmVsO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHdyaXRlVmFsdWUodmFsdWU6IHVua25vd24pOiB2b2lkIHtcclxuICAgIHRoaXMudmFsdWUgPSB2YWx1ZTtcclxuICAgIC8vIFRPRE86INCd0LXQv9C+0L3Rj9GC0L3Qviwg0LfQsNGH0LXQvCDQvdGD0LbQvdC+INCyIGNvbnN0cnVjdGlvbiDQstGC0L7RgNCw0Y8g0YfQsNGB0YLRjCDQstGL0YDQsNC20LXQvdC40Y9cclxuICAgIHRoaXMuc2VsZWN0ZWRPcHRpb24gPSB0aGlzLm9wdGlvbnMuZmluZChvcHRpb24gPT4gb3B0aW9uLnZhbHVlID09PSB2YWx1ZSkgPz8gdmFsdWUgYXMgQ3VpT3B0aW9uO1xyXG5cclxuICAgIHRoaXMuY2hhbmdlRGV0ZWN0b3JSZWYubWFya0ZvckNoZWNrKCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgcmVnaXN0ZXJPbkNoYW5nZShmbjogQ3VpT25DaGFuZ2U8dW5rbm93bj4pOiB2b2lkIHtcclxuICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcclxuICB9XHJcblxyXG4gIHB1YmxpYyByZWdpc3Rlck9uVG91Y2hlZChmbjogQ3VpT25Ub3VjaGVkKTogdm9pZCB7XHJcbiAgICB0aGlzLm9uVG91Y2hlZCA9IGZuO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5pbml0Q2xpY2tPdXRzaWRlU3Vic2NyaXB0aW9uKCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICB0aGlzLmNsZWFyVmlld0NvbnRhaW5lclJlZigpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xyXG4gICAgdGhpcy5pc0Rpc2FibGVkID0gaXNEaXNhYmxlZDtcclxuXHJcbiAgICB0aGlzLmNoYW5nZURldGVjdG9yUmVmLm1hcmtGb3JDaGVjaygpO1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIG9uU2VsZWN0KGV2ZW50OiBFdmVudCwgb3B0aW9uOiBDdWlPcHRpb24pOiB2b2lkIHtcclxuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xyXG5cclxuICAgIGlmIChvcHRpb24uaXNEaXNhYmxlZCkge1xyXG4gICAgICByZXR1cm5cclxuICAgIH1cclxuXHJcbiAgICB0aGlzLnZhbHVlID0gb3B0aW9uLnZhbHVlO1xyXG4gICAgdGhpcy5zZWxlY3RlZE9wdGlvbiA9IG9wdGlvbjtcclxuXHJcbiAgICB0aGlzLm9uQ2hhbmdlKHRoaXMudmFsdWUpO1xyXG4gICAgdGhpcy5vblN3aXRjaCgpO1xyXG4gICAgdGhpcy5vblRvdWNoZWQoKTtcclxuICAgIHRoaXMuY2hhbmdlRGV0ZWN0b3JSZWYubWFya0ZvckNoZWNrKCk7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgb25Td2l0Y2goKTogdm9pZCB7XHJcbiAgICBpZiAoIXRoaXMub3B0aW9ucy5sZW5ndGggJiYgIXRoaXMuZGVmYXVsdE9wdGlvblRleHQpIHtcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG5cclxuICAgIGlmICghdGhpcy5pc09wZW5lZCkge1xyXG4gICAgICB0aGlzLm9wZW4oKTtcclxuXHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcbiAgICB0aGlzLmNsb3NlKCk7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgb25DbG9zZSgpOiB2b2lkIHtcclxuICAgIHRoaXMuY2xvc2UoKTtcclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ3dpbmRvdzpyZXNpemUnKVxyXG4gIHByb3RlY3RlZCBvbldpbmRvd1Jlc2l6ZSgpOiB2b2lkIHtcclxuICAgIHRoaXMuYnV0dG9uLm5hdGl2ZUVsZW1lbnQuYmx1cigpO1xyXG4gICAgdGhpcy5jbG9zZSgpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBpbml0Q2xpY2tPdXRzaWRlU3Vic2NyaXB0aW9uKCk6IHZvaWQge1xyXG4gICAgdGhpcy5jdWlDbGlja091dHNpZGVEaXJlY3RpdmUuY3VpQ2xpY2tPdXRzaWRlXHJcbiAgICAucGlwZSh0YWtlVW50aWwodGhpcy5kZXN0cm95JCkpXHJcbiAgICAuc3Vic2NyaWJlKCgpID0+IHtcclxuICAgICAgaWYgKHRoaXMuaXNPcGVuZWQpIHtcclxuICAgICAgICB0aGlzLm9uVG91Y2hlZCgpO1xyXG4gICAgICB9XHJcblxyXG4gICAgICB0aGlzLmNsb3NlKCk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgb3BlbigpOiB2b2lkIHtcclxuICAgIHRoaXMuaXNPcGVuZWQgPSB0cnVlO1xyXG5cclxuICAgIGNvbnN0IHJvb3RFbGVtZW50ID0gdGhpcy5kb2N1bWVudC5xdWVyeVNlbGVjdG9yKENVSV9ST09UX1NFTEVDVE9SKSE7XHJcbiAgICBjb25zdCB7XHJcbiAgICAgIHRvcDogZWxlbWVudFJlY3RUb3AsXHJcbiAgICAgIGxlZnQ6IGVsZW1lbnRSZWN0TGVmdCxcclxuICAgICAgYm90dG9tOiBlbGVtZW50UmVjdEJvdHRvbVxyXG4gICAgfSA9IHRoaXMuZWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcclxuICAgIGNvbnN0IGRpc3RhbmNlVG9Cb3R0b20gPSB0aGlzLmRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5jbGllbnRIZWlnaHRcclxuICAgICAgLSAoZWxlbWVudFJlY3RCb3R0b20gKyB0aGlzLlNQQUNFX0JFVFdFRU5fQlVUVE9OX0FORF9PUFRJT05TKTtcclxuICAgIGNvbnN0IGVtYmVkZGVkVmlld1JlZiA9IHRoaXMudmlld0NvbnRhaW5lclJlZi5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy5vcHRpb25zV3JhcHBlcik7XHJcbiAgICBjb25zdCBub2RlID0gZW1iZWRkZWRWaWV3UmVmLnJvb3ROb2Rlc1swXTtcclxuICAgIGNvbnN0IG5vZGVTdHlsZXMgPSBub2RlLnN0eWxlO1xyXG5cclxuICAgIHRoaXMuaXNPcHRpb25zTGlzdEFib3ZlID0gZGlzdGFuY2VUb0JvdHRvbSA8IHRoaXMuZ2V0T3B0aW9uc0xpc3RIZWlnaHRDb250YWluZXIubmF0aXZlRWxlbWVudC5vZmZzZXRIZWlnaHQ7XHJcblxyXG4gICAgZW1iZWRkZWRWaWV3UmVmLmRldGVjdENoYW5nZXMoKTtcclxuXHJcbiAgICBub2RlU3R5bGVzLndpZHRoID0gdGhpcy5lbGVtZW50Lm9mZnNldFdpZHRoICsgJ3B4JztcclxuICAgIG5vZGVTdHlsZXMubGVmdCA9IHdpbmRvdy5zY3JvbGxYICsgZWxlbWVudFJlY3RMZWZ0ICsgJ3B4JztcclxuXHJcbiAgICBpZiAodGhpcy5pc09wdGlvbnNMaXN0QWJvdmUpIHtcclxuICAgICAgbm9kZVN0eWxlcy50b3AgPSB3aW5kb3cuc2Nyb2xsWSArIGVsZW1lbnRSZWN0VG9wXHJcbiAgICAgICAgLSB0aGlzLmdldE9wdGlvbnNMaXN0SGVpZ2h0Q29udGFpbmVyLm5hdGl2ZUVsZW1lbnQub2Zmc2V0SGVpZ2h0XHJcbiAgICAgICAgLSB0aGlzLlNQQUNFX0JFVFdFRU5fQlVUVE9OX0FORF9PUFRJT05TXHJcbiAgICAgICAgKyAncHgnO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgbm9kZVN0eWxlcy50b3AgPSB3aW5kb3cuc2Nyb2xsWSArIGVsZW1lbnRSZWN0Qm90dG9tICsgdGhpcy5TUEFDRV9CRVRXRUVOX0JVVFRPTl9BTkRfT1BUSU9OUyArICdweCc7XHJcbiAgICB9XHJcblxyXG4gICAgcm9vdEVsZW1lbnQuYXBwZW5kQ2hpbGQodGhpcy52aWV3Q29udGFpbmVyUmVmLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLmJhY2tkcm9wKS5yb290Tm9kZXNbMF0pO1xyXG4gICAgcm9vdEVsZW1lbnQuYXBwZW5kQ2hpbGQoZW1iZWRkZWRWaWV3UmVmLnJvb3ROb2Rlc1swXSk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGNsb3NlKCk6IHZvaWQge1xyXG4gICAgdGhpcy5pc09wZW5lZCA9IGZhbHNlO1xyXG5cclxuICAgIHRoaXMuY2xlYXJWaWV3Q29udGFpbmVyUmVmKCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGNsZWFyVmlld0NvbnRhaW5lclJlZigpOiB2b2lkIHtcclxuICAgIHRoaXMudmlld0NvbnRhaW5lclJlZi5jbGVhcigpO1xyXG4gIH1cclxufVxyXG4iLCI8YnV0dG9uXHJcbiAgICAjYnV0dG9uXHJcbiAgICB0eXBlPVwiYnV0dG9uXCJcclxuICAgIFthdHRyLmlkXT1cImlkXCJcclxuICAgIFthdHRyLmRhdGEtc2l6ZV09XCJzaXplXCJcclxuICAgIFtkaXNhYmxlZF09XCJpc0Rpc2FibGVkXCJcclxuICAgIGNsYXNzPVwiYy1idXR0b25cIlxyXG4gICAgW2NsYXNzLmMtYnV0dG9uX2FjdGl2ZV09XCJpc09wZW5lZFwiXHJcbiAgICBbY2xhc3MuYy1idXR0b25fd2l0aC1lcnJvcl09XCJpc0Vycm9yXCJcclxuICAgIChjbGljayk9XCJvblN3aXRjaCgpXCJcclxuPlxyXG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJzZWxlY3RlZE9wdGlvbjsgZWxzZSBwbGFjZWhvbGRlclRlbXBsYXRlXCI+XHJcbiAgICB7eyBzZWxlY3RlZE9wdGlvbi5sYWJlbCB9fVxyXG4gIDwvbmctY29udGFpbmVyPlxyXG4gIDxuZy10ZW1wbGF0ZSAjcGxhY2Vob2xkZXJUZW1wbGF0ZT5cclxuICAgIDxzcGFuIGNsYXNzPVwiYy1wbGFjZWhvbGRlclwiPnt7IHBsYWNlaG9sZGVyIH19PC9zcGFuPlxyXG4gIDwvbmctdGVtcGxhdGU+XHJcbiAgPGN1aS1zdmdcclxuICAgIGljb249XCJjdWlJY29uQ2hldnJvbkRvd25cIlxyXG4gICAgY29sb3I9XCJ2YXIoLS1jdWktYmFzZS01MDApXCJcclxuICAvPlxyXG48L2J1dHRvbj5cclxuPG5nLXRlbXBsYXRlICNiYWNrZHJvcD5cclxuICA8ZGl2IGNsYXNzPVwiYy1iYWNrZHJvcFwiPjwvZGl2PlxyXG48L25nLXRlbXBsYXRlPlxyXG48bmctdGVtcGxhdGUgI29wdGlvbnNXcmFwcGVyPlxyXG4gIDxkaXZcclxuICAgIGN1aUZvY3VzVHJhcFxyXG4gICAgY2xhc3M9XCJjLW9wdGlvbnNfX3dyYXBwZXJcIlxyXG4gICAgW2NsYXNzLmMtb3B0aW9uc19fd3JhcHBlcl90b3BdPVwiaXNPcHRpb25zTGlzdEFib3ZlXCJcclxuICA+XHJcbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwib3B0aW9uc0xpc3RcIi8+XHJcbiAgPC9kaXY+XHJcbjwvbmctdGVtcGxhdGU+XHJcbjxkaXZcclxuICAgICNnZXRPcHRpb25zTGlzdEhlaWdodENvbnRhaW5lclxyXG4gICAgY2xhc3M9XCJjLWdldC1vcHRpb25zLWxpc3QtaGVpZ2h0LWNvbnRhaW5lclwiXHJcbj5cclxuICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwib3B0aW9uc0xpc3RcIi8+XHJcbjwvZGl2PlxyXG48bmctdGVtcGxhdGUgI29wdGlvbnNMaXN0PlxyXG4gIDx1bFxyXG4gICAgY2xhc3M9XCJjLW9wdGlvbnNcIlxyXG4gICAgW2NsYXNzLmMtb3B0aW9uc190b3BdPVwiaXNPcHRpb25zTGlzdEFib3ZlXCJcclxuICA+XHJcbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwib3B0aW9ucy5sZW5ndGg7IGVsc2UgZW1wdHlcIj5cclxuICAgICAgPGxpICpuZ0Zvcj1cImxldCBvcHRpb24gb2Ygb3B0aW9uczsgdHJhY2tCeTogdHJhY2tCeUZuXCI+XHJcbiAgICAgICAgPGJ1dHRvblxyXG4gICAgICAgICAgdHlwZT1cImJ1dHRvblwiXHJcbiAgICAgICAgICBjbGFzcz1cImMtb3B0aW9uLWJ1dHRvblwiXHJcbiAgICAgICAgICBbY2xhc3MuYy1vcHRpb24tYnV0dG9uX3NlbGVjdGVkXT1cInNlbGVjdGVkT3B0aW9uID09PSBvcHRpb25cIlxyXG4gICAgICAgICAgW2Rpc2FibGVkXT1cIm9wdGlvbi5pc0Rpc2FibGVkXCJcclxuICAgICAgICAgIChjbGljayk9XCJvblNlbGVjdCgkZXZlbnQsIG9wdGlvbilcIlxyXG4gICAgICAgID5cclxuICAgICAgICAgIDxzcGFuPnt7IG9wdGlvbi5sYWJlbCB9fTwvc3Bhbj5cclxuICAgICAgICAgIDxjdWktc3ZnXHJcbiAgICAgICAgICAgICpuZ0lmPVwic2VsZWN0ZWRPcHRpb24gPT09IG9wdGlvblwiXHJcbiAgICAgICAgICAgIGljb249XCJjdWlJY29uQ2hlY2tTbVwiXHJcbiAgICAgICAgICAgIGNvbG9yPVwidmFyKC0tY3VpLWluZm8pXCJcclxuICAgICAgICAgICAgY2xhc3M9XCJjLW9wdGlvbi1idXR0b25fX2ljb25cIlxyXG4gICAgICAgICAgLz5cclxuICAgICAgICA8L2J1dHRvbj5cclxuICAgICAgPC9saT5cclxuICAgIDwvbmctY29udGFpbmVyPlxyXG4gICAgPG5nLXRlbXBsYXRlICNlbXB0eT5cclxuICAgICAgPGxpICpuZ0lmPVwiZGVmYXVsdE9wdGlvblRleHRcIj5cclxuICAgICAgICA8YnV0dG9uXHJcbiAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcclxuICAgICAgICAgIGNsYXNzPVwiYy1vcHRpb24tYnV0dG9uXCJcclxuICAgICAgICAgIChjbGljayk9XCJvbkNsb3NlKClcIlxyXG4gICAgICAgID5cclxuICAgICAgICAgIHt7IGRlZmF1bHRPcHRpb25UZXh0IH19XHJcbiAgICAgICAgPC9idXR0b24+XHJcbiAgICAgIDwvbGk+XHJcbiAgICA8L25nLXRlbXBsYXRlPlxyXG4gIDwvdWw+XHJcbjwvbmctdGVtcGxhdGU+XHJcbiJdfQ==
@@ -1,32 +1,32 @@
1
- import { NgModule } from '@angular/core';
2
- import { CommonModule } from '@angular/common';
3
- import { CuiSelectComponent } from './select.component';
4
- import { CuiSvgModule } from '../svg';
5
- import { CuiTextFieldControllerModule } from '../../directives';
6
- import { CuiFocusTrapDirective } from '@cuby-ui/cdk';
7
- import * as i0 from "@angular/core";
8
- export class CuiSelectModule {
9
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
10
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectModule, declarations: [CuiSelectComponent], imports: [CommonModule,
11
- CuiSvgModule,
12
- CuiFocusTrapDirective], exports: [CuiSelectComponent,
13
- CuiTextFieldControllerModule] }); }
14
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectModule, imports: [CommonModule,
15
- CuiSvgModule, CuiTextFieldControllerModule] }); }
16
- }
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectModule, decorators: [{
18
- type: NgModule,
19
- args: [{
20
- imports: [
21
- CommonModule,
22
- CuiSvgModule,
23
- CuiFocusTrapDirective
24
- ],
25
- declarations: [CuiSelectComponent],
26
- exports: [
27
- CuiSelectComponent,
28
- CuiTextFieldControllerModule
29
- ]
30
- }]
31
- }] });
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { CuiSelectComponent } from './select.component';
4
+ import { CuiSvgModule } from '../svg';
5
+ import { CuiTextFieldControllerModule } from '../../directives';
6
+ import { CuiFocusTrapDirective } from '@cuby-ui/cdk';
7
+ import * as i0 from "@angular/core";
8
+ export class CuiSelectModule {
9
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
10
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectModule, declarations: [CuiSelectComponent], imports: [CommonModule,
11
+ CuiSvgModule,
12
+ CuiFocusTrapDirective], exports: [CuiSelectComponent,
13
+ CuiTextFieldControllerModule] }); }
14
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectModule, imports: [CommonModule,
15
+ CuiSvgModule, CuiTextFieldControllerModule] }); }
16
+ }
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSelectModule, decorators: [{
18
+ type: NgModule,
19
+ args: [{
20
+ imports: [
21
+ CommonModule,
22
+ CuiSvgModule,
23
+ CuiFocusTrapDirective
24
+ ],
25
+ declarations: [CuiSelectComponent],
26
+ exports: [
27
+ CuiSelectComponent,
28
+ CuiTextFieldControllerModule
29
+ ]
30
+ }]
31
+ }] });
32
32
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9zZWxlY3Qvc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ3RDLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFjckQsTUFBTSxPQUFPLGVBQWU7K0dBQWYsZUFBZTtnSEFBZixlQUFlLGlCQU5YLGtCQUFrQixhQUovQixZQUFZO1lBQ1osWUFBWTtZQUNaLHFCQUFxQixhQUlyQixrQkFBa0I7WUFDbEIsNEJBQTRCO2dIQUduQixlQUFlLFlBVnhCLFlBQVk7WUFDWixZQUFZLEVBTVosNEJBQTRCOzs0RkFHbkIsZUFBZTtrQkFaM0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixZQUFZO3dCQUNaLHFCQUFxQjtxQkFDdEI7b0JBQ0QsWUFBWSxFQUFFLENBQUMsa0JBQWtCLENBQUM7b0JBQ2xDLE9BQU8sRUFBRTt3QkFDUCxrQkFBa0I7d0JBQ2xCLDRCQUE0QjtxQkFDN0I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuaW1wb3J0IHsgQ3VpU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3QuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQ3VpU3ZnTW9kdWxlIH0gZnJvbSAnLi4vc3ZnJztcclxuaW1wb3J0IHsgQ3VpVGV4dEZpZWxkQ29udHJvbGxlck1vZHVsZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMnO1xyXG5pbXBvcnQgeyBDdWlGb2N1c1RyYXBEaXJlY3RpdmUgfSBmcm9tICdAY3VieS11aS9jZGsnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBDdWlTdmdNb2R1bGUsXHJcbiAgICBDdWlGb2N1c1RyYXBEaXJlY3RpdmVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW0N1aVNlbGVjdENvbXBvbmVudF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgQ3VpU2VsZWN0Q29tcG9uZW50LFxyXG4gICAgQ3VpVGV4dEZpZWxkQ29udHJvbGxlck1vZHVsZVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEN1aVNlbGVjdE1vZHVsZSB7XHJcbn1cclxuIl19
@@ -1,3 +1,3 @@
1
- export * from './svg.component';
2
- export * from './svg.module';
1
+ export * from './svg.component';
2
+ export * from './svg.module';
3
3
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvc3ZnL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3N2Zy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3N2Zy5tb2R1bGUnO1xyXG4iXX0=
@@ -1,50 +1,50 @@
1
- import { ChangeDetectionStrategy, Component, HostBinding, inject, Input } from '@angular/core';
2
- import { DomSanitizer } from '@angular/platform-browser';
3
- import { CUI_ICONS, cuiIsIcon } from '@cuby-ui/icons';
4
- import * as i0 from "@angular/core";
5
- export class CuiSvgComponent {
6
- constructor() {
7
- this.domSanitizer = inject(DomSanitizer);
8
- }
9
- set icon(icon) {
10
- // TODO: В данном случае подключаются все иконки (вероятно, можно как-то оптимизировано их подключать)
11
- this.safeSvgContent = this.domSanitizer.bypassSecurityTrustHtml(cuiIsIcon(icon)
12
- ? CUI_ICONS[icon]
13
- : icon);
14
- }
15
- get isWithStrokeWidth() {
16
- return !!this.strokeWidth;
17
- }
18
- get isWithColor() {
19
- return !!this.color;
20
- }
21
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSvgComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
22
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CuiSvgComponent, selector: "cui-svg[icon]", inputs: { width: "width", height: "height", strokeWidth: "strokeWidth", color: "color", icon: "icon" }, host: { properties: { "style.--stroke-width": "this.strokeWidth", "style.--color": "this.color", "class._with-stroke-width": "this.isWithStrokeWidth", "class._with-color": "this.isWithColor" } }, ngImport: i0, template: "<span\r\n [innerHTML]=\"safeSvgContent\"\r\n [style.width.px]=\"width\"\r\n [style.height.px]=\"height\"\r\n></span>", styles: [":host{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;vertical-align:middle;line-height:0}:host ::ng-deep svg{width:100%;height:100%}:host._with-stroke-width ::ng-deep [stroke-width]{stroke-width:var(--stroke-width)}:host._with-color ::ng-deep [stroke]{stroke:var(--color)}:host._with-color ::ng-deep [fill]:not([fill=none]){fill:var(--color)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
23
- }
24
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSvgComponent, decorators: [{
25
- type: Component,
26
- args: [{ selector: 'cui-svg[icon]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span\r\n [innerHTML]=\"safeSvgContent\"\r\n [style.width.px]=\"width\"\r\n [style.height.px]=\"height\"\r\n></span>", styles: [":host{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;vertical-align:middle;line-height:0}:host ::ng-deep svg{width:100%;height:100%}:host._with-stroke-width ::ng-deep [stroke-width]{stroke-width:var(--stroke-width)}:host._with-color ::ng-deep [stroke]{stroke:var(--color)}:host._with-color ::ng-deep [fill]:not([fill=none]){fill:var(--color)}\n"] }]
27
- }], propDecorators: { width: [{
28
- type: Input
29
- }], height: [{
30
- type: Input
31
- }], strokeWidth: [{
32
- type: Input
33
- }, {
34
- type: HostBinding,
35
- args: ['style.--stroke-width']
36
- }], color: [{
37
- type: Input
38
- }, {
39
- type: HostBinding,
40
- args: ['style.--color']
41
- }], icon: [{
42
- type: Input
43
- }], isWithStrokeWidth: [{
44
- type: HostBinding,
45
- args: ['class._with-stroke-width']
46
- }], isWithColor: [{
47
- type: HostBinding,
48
- args: ['class._with-color']
49
- }] } });
1
+ import { ChangeDetectionStrategy, Component, HostBinding, inject, Input } from '@angular/core';
2
+ import { DomSanitizer } from '@angular/platform-browser';
3
+ import { CUI_ICONS, cuiIsIcon } from '@cuby-ui/icons';
4
+ import * as i0 from "@angular/core";
5
+ export class CuiSvgComponent {
6
+ constructor() {
7
+ this.domSanitizer = inject(DomSanitizer);
8
+ }
9
+ set icon(icon) {
10
+ // TODO: В данном случае подключаются все иконки (вероятно, можно как-то оптимизировано их подключать)
11
+ this.safeSvgContent = this.domSanitizer.bypassSecurityTrustHtml(cuiIsIcon(icon)
12
+ ? CUI_ICONS[icon]
13
+ : icon);
14
+ }
15
+ get isWithStrokeWidth() {
16
+ return !!this.strokeWidth;
17
+ }
18
+ get isWithColor() {
19
+ return !!this.color;
20
+ }
21
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSvgComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
22
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CuiSvgComponent, selector: "cui-svg[icon]", inputs: { width: "width", height: "height", strokeWidth: "strokeWidth", color: "color", icon: "icon" }, host: { properties: { "style.--stroke-width": "this.strokeWidth", "style.--color": "this.color", "class._with-stroke-width": "this.isWithStrokeWidth", "class._with-color": "this.isWithColor" } }, ngImport: i0, template: "<span\r\n [innerHTML]=\"safeSvgContent\"\r\n [style.width.px]=\"width\"\r\n [style.height.px]=\"height\"\r\n></span>", styles: [":host{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;vertical-align:middle;line-height:0}:host ::ng-deep svg{width:100%;height:100%}:host._with-stroke-width ::ng-deep [stroke-width]{stroke-width:var(--stroke-width)}:host._with-color ::ng-deep [stroke]{stroke:var(--color)}:host._with-color ::ng-deep [fill]:not([fill=none]){fill:var(--color)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
23
+ }
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CuiSvgComponent, decorators: [{
25
+ type: Component,
26
+ args: [{ selector: 'cui-svg[icon]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span\r\n [innerHTML]=\"safeSvgContent\"\r\n [style.width.px]=\"width\"\r\n [style.height.px]=\"height\"\r\n></span>", styles: [":host{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;vertical-align:middle;line-height:0}:host ::ng-deep svg{width:100%;height:100%}:host._with-stroke-width ::ng-deep [stroke-width]{stroke-width:var(--stroke-width)}:host._with-color ::ng-deep [stroke]{stroke:var(--color)}:host._with-color ::ng-deep [fill]:not([fill=none]){fill:var(--color)}\n"] }]
27
+ }], propDecorators: { width: [{
28
+ type: Input
29
+ }], height: [{
30
+ type: Input
31
+ }], strokeWidth: [{
32
+ type: Input
33
+ }, {
34
+ type: HostBinding,
35
+ args: ['style.--stroke-width']
36
+ }], color: [{
37
+ type: Input
38
+ }, {
39
+ type: HostBinding,
40
+ args: ['style.--color']
41
+ }], icon: [{
42
+ type: Input
43
+ }], isWithStrokeWidth: [{
44
+ type: HostBinding,
45
+ args: ['class._with-stroke-width']
46
+ }], isWithColor: [{
47
+ type: HostBinding,
48
+ args: ['class._with-color']
49
+ }] } });
50
50
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ZnLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9zdmcvc3ZnLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9zdmcvc3ZnLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsV0FBVyxFQUNYLE1BQU0sRUFDTixLQUFLLEVBQ04sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFlBQVksRUFBWSxNQUFNLDJCQUEyQixDQUFDO0FBR25FLE9BQU8sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBUXRELE1BQU0sT0FBTyxlQUFlO0lBTjVCO1FBT21CLGlCQUFZLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO0tBbUN0RDtJQWpCQyxJQUNXLElBQUksQ0FBQyxJQUFzQjtRQUNwQyxzR0FBc0c7UUFDdEcsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLHVCQUF1QixDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUM7WUFDN0UsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUM7WUFDakIsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ1osQ0FBQztJQUVELElBQ1csaUJBQWlCO1FBQzFCLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDNUIsQ0FBQztJQUVELElBQ1csV0FBVztRQUNwQixPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RCLENBQUM7K0dBbkNVLGVBQWU7bUdBQWYsZUFBZSxpV0NsQjVCLHlIQUlROzs0RkRjSyxlQUFlO2tCQU4zQixTQUFTOytCQUNFLGVBQWUsbUJBR1IsdUJBQXVCLENBQUMsTUFBTTs4QkFReEMsS0FBSztzQkFEWCxLQUFLO2dCQUlDLE1BQU07c0JBRFosS0FBSztnQkFLQyxXQUFXO3NCQUZqQixLQUFLOztzQkFDTCxXQUFXO3VCQUFDLHNCQUFzQjtnQkFLNUIsS0FBSztzQkFGWCxLQUFLOztzQkFDTCxXQUFXO3VCQUFDLGVBQWU7Z0JBSWpCLElBQUk7c0JBRGQsS0FBSztnQkFTSyxpQkFBaUI7c0JBRDNCLFdBQVc7dUJBQUMsMEJBQTBCO2dCQU01QixXQUFXO3NCQURyQixXQUFXO3VCQUFDLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgQ29tcG9uZW50LFxyXG4gIEhvc3RCaW5kaW5nLFxyXG4gIGluamVjdCxcclxuICBJbnB1dFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIsIFNhZmVIdG1sIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcblxyXG5pbXBvcnQgdHlwZSB7IEN1aUljb24gfSBmcm9tICdAY3VieS11aS9pY29ucyc7XHJcbmltcG9ydCB7IENVSV9JQ09OUywgY3VpSXNJY29uIH0gZnJvbSAnQGN1YnktdWkvaWNvbnMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdjdWktc3ZnW2ljb25dJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc3ZnLnRlbXBsYXRlLmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3N2Zy5zdHlsZS5zY3NzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIEN1aVN2Z0NvbXBvbmVudCB7XHJcbiAgcHJpdmF0ZSByZWFkb25seSBkb21TYW5pdGl6ZXIgPSBpbmplY3QoRG9tU2FuaXRpemVyKTtcclxuXHJcbiAgcHJvdGVjdGVkIHNhZmVTdmdDb250ZW50ITogU2FmZUh0bWw7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHdpZHRoPzogbnVtYmVyO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBoZWlnaHQ/OiBudW1iZXI7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS4tLXN0cm9rZS13aWR0aCcpXHJcbiAgcHVibGljIHN0cm9rZVdpZHRoPzogbnVtYmVyO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIEBIb3N0QmluZGluZygnc3R5bGUuLS1jb2xvcicpXHJcbiAgcHVibGljIGNvbG9yPzogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZXQgaWNvbihpY29uOiBDdWlJY29uIHwgc3RyaW5nKSB7XHJcbiAgICAvLyBUT0RPOiDQkiDQtNCw0L3QvdC+0Lwg0YHQu9GD0YfQsNC1INC/0L7QtNC60LvRjtGH0LDRjtGC0YHRjyDQstGB0LUg0LjQutC+0L3QutC4ICjQstC10YDQvtGP0YLQvdC+LCDQvNC+0LbQvdC+INC60LDQui3RgtC+INC+0L/RgtC40LzQuNC30LjRgNC+0LLQsNC90L4g0LjRhSDQv9C+0LTQutC70Y7Rh9Cw0YLRjClcclxuICAgIHRoaXMuc2FmZVN2Z0NvbnRlbnQgPSB0aGlzLmRvbVNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0SHRtbChjdWlJc0ljb24oaWNvbilcclxuICAgICAgPyBDVUlfSUNPTlNbaWNvbl1cclxuICAgICAgOiBpY29uKTtcclxuICB9XHJcblxyXG4gIEBIb3N0QmluZGluZygnY2xhc3MuX3dpdGgtc3Ryb2tlLXdpZHRoJylcclxuICBwdWJsaWMgZ2V0IGlzV2l0aFN0cm9rZVdpZHRoKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuICEhdGhpcy5zdHJva2VXaWR0aDtcclxuICB9XHJcblxyXG4gIEBIb3N0QmluZGluZygnY2xhc3MuX3dpdGgtY29sb3InKVxyXG4gIHB1YmxpYyBnZXQgaXNXaXRoQ29sb3IoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gISF0aGlzLmNvbG9yO1xyXG4gIH1cclxufVxyXG4iLCI8c3BhblxyXG4gIFtpbm5lckhUTUxdPVwic2FmZVN2Z0NvbnRlbnRcIlxyXG4gIFtzdHlsZS53aWR0aC5weF09XCJ3aWR0aFwiXHJcbiAgW3N0eWxlLmhlaWdodC5weF09XCJoZWlnaHRcIlxyXG4+PC9zcGFuPiJdfQ==