@tailng-ui/primitives 0.1.0

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 (374) hide show
  1. package/README.md +36 -0
  2. package/package.json +13 -0
  3. package/src/index.d.ts +55 -0
  4. package/src/index.d.ts.map +1 -0
  5. package/src/index.js +61 -0
  6. package/src/index.js.map +1 -0
  7. package/src/lib/feedback/empty/tng-empty.d.ts +16 -0
  8. package/src/lib/feedback/empty/tng-empty.d.ts.map +1 -0
  9. package/src/lib/feedback/empty/tng-empty.js +68 -0
  10. package/src/lib/feedback/empty/tng-empty.js.map +1 -0
  11. package/src/lib/feedback/progress-bar/tng-progress-bar.d.ts +24 -0
  12. package/src/lib/feedback/progress-bar/tng-progress-bar.d.ts.map +1 -0
  13. package/src/lib/feedback/progress-bar/tng-progress-bar.js +100 -0
  14. package/src/lib/feedback/progress-bar/tng-progress-bar.js.map +1 -0
  15. package/src/lib/feedback/progress-spinner/tng-progress-spinner.d.ts +21 -0
  16. package/src/lib/feedback/progress-spinner/tng-progress-spinner.d.ts.map +1 -0
  17. package/src/lib/feedback/progress-spinner/tng-progress-spinner.js +87 -0
  18. package/src/lib/feedback/progress-spinner/tng-progress-spinner.js.map +1 -0
  19. package/src/lib/feedback/skeleton/tng-skeleton.d.ts +11 -0
  20. package/src/lib/feedback/skeleton/tng-skeleton.d.ts.map +1 -0
  21. package/src/lib/feedback/skeleton/tng-skeleton.js +44 -0
  22. package/src/lib/feedback/skeleton/tng-skeleton.js.map +1 -0
  23. package/src/lib/feedback/toast/tng-toast.d.ts +20 -0
  24. package/src/lib/feedback/toast/tng-toast.d.ts.map +1 -0
  25. package/src/lib/feedback/toast/tng-toast.js +79 -0
  26. package/src/lib/feedback/toast/tng-toast.js.map +1 -0
  27. package/src/lib/form/_shared/id/index.d.ts +4 -0
  28. package/src/lib/form/_shared/id/index.d.ts.map +1 -0
  29. package/src/lib/form/_shared/id/index.js +4 -0
  30. package/src/lib/form/_shared/id/index.js.map +1 -0
  31. package/src/lib/form/_shared/id/tng-unique-id.provider.d.ts +11 -0
  32. package/src/lib/form/_shared/id/tng-unique-id.provider.d.ts.map +1 -0
  33. package/src/lib/form/_shared/id/tng-unique-id.provider.js +15 -0
  34. package/src/lib/form/_shared/id/tng-unique-id.provider.js.map +1 -0
  35. package/src/lib/form/_shared/id/tng-unique-id.service.d.ts +9 -0
  36. package/src/lib/form/_shared/id/tng-unique-id.service.d.ts.map +1 -0
  37. package/src/lib/form/_shared/id/tng-unique-id.service.js +18 -0
  38. package/src/lib/form/_shared/id/tng-unique-id.service.js.map +1 -0
  39. package/src/lib/form/_shared/id/tng-unique-id.token.d.ts +8 -0
  40. package/src/lib/form/_shared/id/tng-unique-id.token.d.ts.map +1 -0
  41. package/src/lib/form/_shared/id/tng-unique-id.token.js +13 -0
  42. package/src/lib/form/_shared/id/tng-unique-id.token.js.map +1 -0
  43. package/src/lib/form/_shared/select/tng-select.host-api.d.ts +28 -0
  44. package/src/lib/form/_shared/select/tng-select.host-api.d.ts.map +1 -0
  45. package/src/lib/form/_shared/select/tng-select.host-api.js +1 -0
  46. package/src/lib/form/_shared/select/tng-select.host-api.js.map +1 -0
  47. package/src/lib/form/_shared/select/tng-select.overlay.shared.d.ts +38 -0
  48. package/src/lib/form/_shared/select/tng-select.overlay.shared.d.ts.map +1 -0
  49. package/src/lib/form/_shared/select/tng-select.overlay.shared.js +226 -0
  50. package/src/lib/form/_shared/select/tng-select.overlay.shared.js.map +1 -0
  51. package/src/lib/form/_shared/select/tng-select.parts.shared.d.ts +35 -0
  52. package/src/lib/form/_shared/select/tng-select.parts.shared.d.ts.map +1 -0
  53. package/src/lib/form/_shared/select/tng-select.parts.shared.js +199 -0
  54. package/src/lib/form/_shared/select/tng-select.parts.shared.js.map +1 -0
  55. package/src/lib/form/_shared/select/tng-select.tokens.shared.d.ts +8 -0
  56. package/src/lib/form/_shared/select/tng-select.tokens.shared.d.ts.map +1 -0
  57. package/src/lib/form/_shared/select/tng-select.tokens.shared.js +7 -0
  58. package/src/lib/form/_shared/select/tng-select.tokens.shared.js.map +1 -0
  59. package/src/lib/form/autocomplete/index.d.ts +7 -0
  60. package/src/lib/form/autocomplete/index.d.ts.map +1 -0
  61. package/src/lib/form/autocomplete/index.js +6 -0
  62. package/src/lib/form/autocomplete/index.js.map +1 -0
  63. package/src/lib/form/autocomplete/tng-autocomplete.d.ts +52 -0
  64. package/src/lib/form/autocomplete/tng-autocomplete.d.ts.map +1 -0
  65. package/src/lib/form/autocomplete/tng-autocomplete.js +95 -0
  66. package/src/lib/form/autocomplete/tng-autocomplete.js.map +1 -0
  67. package/src/lib/form/autocomplete/tng-autocomplete.listbox.d.ts +19 -0
  68. package/src/lib/form/autocomplete/tng-autocomplete.listbox.d.ts.map +1 -0
  69. package/src/lib/form/autocomplete/tng-autocomplete.listbox.js +123 -0
  70. package/src/lib/form/autocomplete/tng-autocomplete.listbox.js.map +1 -0
  71. package/src/lib/form/autocomplete/tng-autocomplete.listbox.tokens.d.ts +4 -0
  72. package/src/lib/form/autocomplete/tng-autocomplete.listbox.tokens.d.ts.map +1 -0
  73. package/src/lib/form/autocomplete/tng-autocomplete.listbox.tokens.js +3 -0
  74. package/src/lib/form/autocomplete/tng-autocomplete.listbox.tokens.js.map +1 -0
  75. package/src/lib/form/autocomplete/tng-autocomplete.listbox.types.d.ts +4 -0
  76. package/src/lib/form/autocomplete/tng-autocomplete.listbox.types.d.ts.map +1 -0
  77. package/src/lib/form/autocomplete/tng-autocomplete.listbox.types.js +1 -0
  78. package/src/lib/form/autocomplete/tng-autocomplete.listbox.types.js.map +1 -0
  79. package/src/lib/form/autocomplete/tng-autocomplete.overlay.d.ts +40 -0
  80. package/src/lib/form/autocomplete/tng-autocomplete.overlay.d.ts.map +1 -0
  81. package/src/lib/form/autocomplete/tng-autocomplete.overlay.js +236 -0
  82. package/src/lib/form/autocomplete/tng-autocomplete.overlay.js.map +1 -0
  83. package/src/lib/form/autocomplete/tng-autocomplete.parts.d.ts +38 -0
  84. package/src/lib/form/autocomplete/tng-autocomplete.parts.d.ts.map +1 -0
  85. package/src/lib/form/autocomplete/tng-autocomplete.parts.js +252 -0
  86. package/src/lib/form/autocomplete/tng-autocomplete.parts.js.map +1 -0
  87. package/src/lib/form/autocomplete/tng-autocomplete.tokens.d.ts +4 -0
  88. package/src/lib/form/autocomplete/tng-autocomplete.tokens.d.ts.map +1 -0
  89. package/src/lib/form/autocomplete/tng-autocomplete.tokens.js +3 -0
  90. package/src/lib/form/autocomplete/tng-autocomplete.tokens.js.map +1 -0
  91. package/src/lib/form/button-toggle/tng-button-toggle.d.ts +164 -0
  92. package/src/lib/form/button-toggle/tng-button-toggle.d.ts.map +1 -0
  93. package/src/lib/form/button-toggle/tng-button-toggle.js +1097 -0
  94. package/src/lib/form/button-toggle/tng-button-toggle.js.map +1 -0
  95. package/src/lib/form/checkbox/tng-checkbox.d.ts +48 -0
  96. package/src/lib/form/checkbox/tng-checkbox.d.ts.map +1 -0
  97. package/src/lib/form/checkbox/tng-checkbox.js +234 -0
  98. package/src/lib/form/checkbox/tng-checkbox.js.map +1 -0
  99. package/src/lib/form/chips/tng-chips.d.ts +4 -0
  100. package/src/lib/form/chips/tng-chips.d.ts.map +1 -0
  101. package/src/lib/form/chips/tng-chips.js +16 -0
  102. package/src/lib/form/chips/tng-chips.js.map +1 -0
  103. package/src/lib/form/combobox/tng-combobox.d.ts +4 -0
  104. package/src/lib/form/combobox/tng-combobox.d.ts.map +1 -0
  105. package/src/lib/form/combobox/tng-combobox.js +16 -0
  106. package/src/lib/form/combobox/tng-combobox.js.map +1 -0
  107. package/src/lib/form/input/tng-input.d.ts +87 -0
  108. package/src/lib/form/input/tng-input.d.ts.map +1 -0
  109. package/src/lib/form/input/tng-input.js +393 -0
  110. package/src/lib/form/input/tng-input.js.map +1 -0
  111. package/src/lib/form/input-otp/tng-input-otp.d.ts +7 -0
  112. package/src/lib/form/input-otp/tng-input-otp.d.ts.map +1 -0
  113. package/src/lib/form/input-otp/tng-input-otp.js +33 -0
  114. package/src/lib/form/input-otp/tng-input-otp.js.map +1 -0
  115. package/src/lib/form/label/tng-label.d.ts +6 -0
  116. package/src/lib/form/label/tng-label.d.ts.map +1 -0
  117. package/src/lib/form/label/tng-label.js +25 -0
  118. package/src/lib/form/label/tng-label.js.map +1 -0
  119. package/src/lib/form/listbox/listbox.directive.d.ts +51 -0
  120. package/src/lib/form/listbox/listbox.directive.d.ts.map +1 -0
  121. package/src/lib/form/listbox/listbox.directive.js +439 -0
  122. package/src/lib/form/listbox/listbox.directive.js.map +1 -0
  123. package/src/lib/form/listbox/option.directive.d.ts +22 -0
  124. package/src/lib/form/listbox/option.directive.d.ts.map +1 -0
  125. package/src/lib/form/listbox/option.directive.js +109 -0
  126. package/src/lib/form/listbox/option.directive.js.map +1 -0
  127. package/src/lib/form/listbox/tokens.d.ts +14 -0
  128. package/src/lib/form/listbox/tokens.d.ts.map +1 -0
  129. package/src/lib/form/listbox/tokens.js +13 -0
  130. package/src/lib/form/listbox/tokens.js.map +1 -0
  131. package/src/lib/form/multi-autocomplete/index.d.ts +10 -0
  132. package/src/lib/form/multi-autocomplete/index.d.ts.map +1 -0
  133. package/src/lib/form/multi-autocomplete/index.js +10 -0
  134. package/src/lib/form/multi-autocomplete/index.js.map +1 -0
  135. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.chip.d.ts +11 -0
  136. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.chip.d.ts.map +1 -0
  137. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.chip.js +98 -0
  138. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.chip.js.map +1 -0
  139. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.content.d.ts +10 -0
  140. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.content.d.ts.map +1 -0
  141. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.content.js +45 -0
  142. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.content.js.map +1 -0
  143. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.d.ts +43 -0
  144. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.d.ts.map +1 -0
  145. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.js +150 -0
  146. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.js.map +1 -0
  147. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.d.ts +20 -0
  148. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.d.ts.map +1 -0
  149. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.js +138 -0
  150. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.js.map +1 -0
  151. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.tokens.d.ts +4 -0
  152. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.tokens.d.ts.map +1 -0
  153. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.tokens.js +3 -0
  154. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.tokens.js.map +1 -0
  155. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.types.d.ts +18 -0
  156. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.types.d.ts.map +1 -0
  157. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.types.js +2 -0
  158. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.listbox.types.js.map +1 -0
  159. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.overlay.d.ts +4 -0
  160. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.overlay.d.ts.map +1 -0
  161. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.overlay.js +17 -0
  162. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.overlay.js.map +1 -0
  163. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.tokens.d.ts +4 -0
  164. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.tokens.d.ts.map +1 -0
  165. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.tokens.js +3 -0
  166. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.tokens.js.map +1 -0
  167. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.trigger.d.ts +21 -0
  168. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.trigger.d.ts.map +1 -0
  169. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.trigger.js +241 -0
  170. package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.trigger.js.map +1 -0
  171. package/src/lib/form/multi-select/index.d.ts +7 -0
  172. package/src/lib/form/multi-select/index.d.ts.map +1 -0
  173. package/src/lib/form/multi-select/index.js +6 -0
  174. package/src/lib/form/multi-select/index.js.map +1 -0
  175. package/src/lib/form/multi-select/tng-multi-select.d.ts +45 -0
  176. package/src/lib/form/multi-select/tng-multi-select.d.ts.map +1 -0
  177. package/src/lib/form/multi-select/tng-multi-select.js +136 -0
  178. package/src/lib/form/multi-select/tng-multi-select.js.map +1 -0
  179. package/src/lib/form/multi-select/tng-multi-select.listbox.d.ts +21 -0
  180. package/src/lib/form/multi-select/tng-multi-select.listbox.d.ts.map +1 -0
  181. package/src/lib/form/multi-select/tng-multi-select.listbox.js +107 -0
  182. package/src/lib/form/multi-select/tng-multi-select.listbox.js.map +1 -0
  183. package/src/lib/form/multi-select/tng-multi-select.listbox.tokens.d.ts +3 -0
  184. package/src/lib/form/multi-select/tng-multi-select.listbox.tokens.d.ts.map +1 -0
  185. package/src/lib/form/multi-select/tng-multi-select.listbox.tokens.js +3 -0
  186. package/src/lib/form/multi-select/tng-multi-select.listbox.tokens.js.map +1 -0
  187. package/src/lib/form/multi-select/tng-multi-select.listbox.types.d.ts +3 -0
  188. package/src/lib/form/multi-select/tng-multi-select.listbox.types.d.ts.map +1 -0
  189. package/src/lib/form/multi-select/tng-multi-select.listbox.types.js +1 -0
  190. package/src/lib/form/multi-select/tng-multi-select.listbox.types.js.map +1 -0
  191. package/src/lib/form/multi-select/tng-multi-select.overlay.d.ts +5 -0
  192. package/src/lib/form/multi-select/tng-multi-select.overlay.d.ts.map +1 -0
  193. package/src/lib/form/multi-select/tng-multi-select.overlay.js +5 -0
  194. package/src/lib/form/multi-select/tng-multi-select.overlay.js.map +1 -0
  195. package/src/lib/form/multi-select/tng-multi-select.parts.d.ts +5 -0
  196. package/src/lib/form/multi-select/tng-multi-select.parts.d.ts.map +1 -0
  197. package/src/lib/form/multi-select/tng-multi-select.parts.js +5 -0
  198. package/src/lib/form/multi-select/tng-multi-select.parts.js.map +1 -0
  199. package/src/lib/form/multi-select/tng-multi-select.tokens.d.ts +4 -0
  200. package/src/lib/form/multi-select/tng-multi-select.tokens.d.ts.map +1 -0
  201. package/src/lib/form/multi-select/tng-multi-select.tokens.js +3 -0
  202. package/src/lib/form/multi-select/tng-multi-select.tokens.js.map +1 -0
  203. package/src/lib/form/multiselect/tng-multiselect.d.ts +4 -0
  204. package/src/lib/form/multiselect/tng-multiselect.d.ts.map +1 -0
  205. package/src/lib/form/multiselect/tng-multiselect.js +16 -0
  206. package/src/lib/form/multiselect/tng-multiselect.js.map +1 -0
  207. package/src/lib/form/radio/tng-radio.d.ts +20 -0
  208. package/src/lib/form/radio/tng-radio.d.ts.map +1 -0
  209. package/src/lib/form/radio/tng-radio.js +86 -0
  210. package/src/lib/form/radio/tng-radio.js.map +1 -0
  211. package/src/lib/form/select/tng-select.d.ts +38 -0
  212. package/src/lib/form/select/tng-select.d.ts.map +1 -0
  213. package/src/lib/form/select/tng-select.js +106 -0
  214. package/src/lib/form/select/tng-select.js.map +1 -0
  215. package/src/lib/form/select/tng-select.listbox.d.ts +20 -0
  216. package/src/lib/form/select/tng-select.listbox.d.ts.map +1 -0
  217. package/src/lib/form/select/tng-select.listbox.js +123 -0
  218. package/src/lib/form/select/tng-select.listbox.js.map +1 -0
  219. package/src/lib/form/select/tng-select.listbox.tokens.d.ts +3 -0
  220. package/src/lib/form/select/tng-select.listbox.tokens.d.ts.map +1 -0
  221. package/src/lib/form/select/tng-select.listbox.tokens.js +3 -0
  222. package/src/lib/form/select/tng-select.listbox.tokens.js.map +1 -0
  223. package/src/lib/form/select/tng-select.listbox.types.d.ts +4 -0
  224. package/src/lib/form/select/tng-select.listbox.types.d.ts.map +1 -0
  225. package/src/lib/form/select/tng-select.listbox.types.js +1 -0
  226. package/src/lib/form/select/tng-select.listbox.types.js.map +1 -0
  227. package/src/lib/form/select/tng-select.overlay.d.ts +5 -0
  228. package/src/lib/form/select/tng-select.overlay.d.ts.map +1 -0
  229. package/src/lib/form/select/tng-select.overlay.js +5 -0
  230. package/src/lib/form/select/tng-select.overlay.js.map +1 -0
  231. package/src/lib/form/select/tng-select.parts.d.ts +5 -0
  232. package/src/lib/form/select/tng-select.parts.d.ts.map +1 -0
  233. package/src/lib/form/select/tng-select.parts.js +5 -0
  234. package/src/lib/form/select/tng-select.parts.js.map +1 -0
  235. package/src/lib/form/select/tng-select.tokens.d.ts +4 -0
  236. package/src/lib/form/select/tng-select.tokens.d.ts.map +1 -0
  237. package/src/lib/form/select/tng-select.tokens.js +3 -0
  238. package/src/lib/form/select/tng-select.tokens.js.map +1 -0
  239. package/src/lib/form/slider/tng-slider.d.ts +19 -0
  240. package/src/lib/form/slider/tng-slider.d.ts.map +1 -0
  241. package/src/lib/form/slider/tng-slider.js +84 -0
  242. package/src/lib/form/slider/tng-slider.js.map +1 -0
  243. package/src/lib/form/switch/tng-switch.d.ts +19 -0
  244. package/src/lib/form/switch/tng-switch.d.ts.map +1 -0
  245. package/src/lib/form/switch/tng-switch.js +79 -0
  246. package/src/lib/form/switch/tng-switch.js.map +1 -0
  247. package/src/lib/form/textarea/tng-textarea.d.ts +23 -0
  248. package/src/lib/form/textarea/tng-textarea.d.ts.map +1 -0
  249. package/src/lib/form/textarea/tng-textarea.js +119 -0
  250. package/src/lib/form/textarea/tng-textarea.js.map +1 -0
  251. package/src/lib/form/toggle/tng-toggle.d.ts +44 -0
  252. package/src/lib/form/toggle/tng-toggle.d.ts.map +1 -0
  253. package/src/lib/form/toggle/tng-toggle.js +203 -0
  254. package/src/lib/form/toggle/tng-toggle.js.map +1 -0
  255. package/src/lib/form/toggle-group/tng-toggle-group.d.ts +35 -0
  256. package/src/lib/form/toggle-group/tng-toggle-group.d.ts.map +1 -0
  257. package/src/lib/form/toggle-group/tng-toggle-group.js +156 -0
  258. package/src/lib/form/toggle-group/tng-toggle-group.js.map +1 -0
  259. package/src/lib/internal/combobox/combobox.active.d.ts +17 -0
  260. package/src/lib/internal/combobox/combobox.active.d.ts.map +1 -0
  261. package/src/lib/internal/combobox/combobox.active.js +19 -0
  262. package/src/lib/internal/combobox/combobox.active.js.map +1 -0
  263. package/src/lib/internal/combobox/combobox.commit.d.ts +20 -0
  264. package/src/lib/internal/combobox/combobox.commit.d.ts.map +1 -0
  265. package/src/lib/internal/combobox/combobox.commit.js +34 -0
  266. package/src/lib/internal/combobox/combobox.commit.js.map +1 -0
  267. package/src/lib/internal/combobox/combobox.keyboard.d.ts +39 -0
  268. package/src/lib/internal/combobox/combobox.keyboard.d.ts.map +1 -0
  269. package/src/lib/internal/combobox/combobox.keyboard.js +88 -0
  270. package/src/lib/internal/combobox/combobox.keyboard.js.map +1 -0
  271. package/src/lib/internal/combobox/combobox.listbox-api.d.ts +19 -0
  272. package/src/lib/internal/combobox/combobox.listbox-api.d.ts.map +1 -0
  273. package/src/lib/internal/combobox/combobox.listbox-api.js +5 -0
  274. package/src/lib/internal/combobox/combobox.listbox-api.js.map +1 -0
  275. package/src/lib/internal/combobox/index.d.ts +5 -0
  276. package/src/lib/internal/combobox/index.d.ts.map +1 -0
  277. package/src/lib/internal/combobox/index.js +4 -0
  278. package/src/lib/internal/combobox/index.js.map +1 -0
  279. package/src/lib/layout/accordion/tng-accordion.d.ts +150 -0
  280. package/src/lib/layout/accordion/tng-accordion.d.ts.map +1 -0
  281. package/src/lib/layout/accordion/tng-accordion.js +852 -0
  282. package/src/lib/layout/accordion/tng-accordion.js.map +1 -0
  283. package/src/lib/layout/bottom-sheet/tng-bottom-sheet.d.ts +4 -0
  284. package/src/lib/layout/bottom-sheet/tng-bottom-sheet.d.ts.map +1 -0
  285. package/src/lib/layout/bottom-sheet/tng-bottom-sheet.js +16 -0
  286. package/src/lib/layout/bottom-sheet/tng-bottom-sheet.js.map +1 -0
  287. package/src/lib/layout/card/tng-card.d.ts +31 -0
  288. package/src/lib/layout/card/tng-card.d.ts.map +1 -0
  289. package/src/lib/layout/card/tng-card.js +133 -0
  290. package/src/lib/layout/card/tng-card.js.map +1 -0
  291. package/src/lib/layout/collapsible/tng-collapsible.d.ts +28 -0
  292. package/src/lib/layout/collapsible/tng-collapsible.d.ts.map +1 -0
  293. package/src/lib/layout/collapsible/tng-collapsible.js +123 -0
  294. package/src/lib/layout/collapsible/tng-collapsible.js.map +1 -0
  295. package/src/lib/layout/drawer/tng-drawer.d.ts +177 -0
  296. package/src/lib/layout/drawer/tng-drawer.d.ts.map +1 -0
  297. package/src/lib/layout/drawer/tng-drawer.js +1147 -0
  298. package/src/lib/layout/drawer/tng-drawer.js.map +1 -0
  299. package/src/lib/layout/grid/tng-grid.d.ts +4 -0
  300. package/src/lib/layout/grid/tng-grid.d.ts.map +1 -0
  301. package/src/lib/layout/grid/tng-grid.js +16 -0
  302. package/src/lib/layout/grid/tng-grid.js.map +1 -0
  303. package/src/lib/layout/separator/tng-separator.d.ts +11 -0
  304. package/src/lib/layout/separator/tng-separator.d.ts.map +1 -0
  305. package/src/lib/layout/separator/tng-separator.js +47 -0
  306. package/src/lib/layout/separator/tng-separator.js.map +1 -0
  307. package/src/lib/layout/stepper/tng-stepper.d.ts +4 -0
  308. package/src/lib/layout/stepper/tng-stepper.d.ts.map +1 -0
  309. package/src/lib/layout/stepper/tng-stepper.js +16 -0
  310. package/src/lib/layout/stepper/tng-stepper.js.map +1 -0
  311. package/src/lib/layout/tree/tng-tree.d.ts +4 -0
  312. package/src/lib/layout/tree/tng-tree.d.ts.map +1 -0
  313. package/src/lib/layout/tree/tng-tree.js +16 -0
  314. package/src/lib/layout/tree/tng-tree.js.map +1 -0
  315. package/src/lib/navigation/breadcrumb/tng-breadcrumb.d.ts +17 -0
  316. package/src/lib/navigation/breadcrumb/tng-breadcrumb.d.ts.map +1 -0
  317. package/src/lib/navigation/breadcrumb/tng-breadcrumb.js +72 -0
  318. package/src/lib/navigation/breadcrumb/tng-breadcrumb.js.map +1 -0
  319. package/src/lib/navigation/context-menu/tng-context-menu.d.ts +36 -0
  320. package/src/lib/navigation/context-menu/tng-context-menu.d.ts.map +1 -0
  321. package/src/lib/navigation/context-menu/tng-context-menu.js +159 -0
  322. package/src/lib/navigation/context-menu/tng-context-menu.js.map +1 -0
  323. package/src/lib/navigation/dropdown-menu/tng-dropdown-menu.d.ts +4 -0
  324. package/src/lib/navigation/dropdown-menu/tng-dropdown-menu.d.ts.map +1 -0
  325. package/src/lib/navigation/dropdown-menu/tng-dropdown-menu.js +16 -0
  326. package/src/lib/navigation/dropdown-menu/tng-dropdown-menu.js.map +1 -0
  327. package/src/lib/navigation/menu/tng-menu.d.ts +173 -0
  328. package/src/lib/navigation/menu/tng-menu.d.ts.map +1 -0
  329. package/src/lib/navigation/menu/tng-menu.js +1026 -0
  330. package/src/lib/navigation/menu/tng-menu.js.map +1 -0
  331. package/src/lib/navigation/menubar/tng-menubar.d.ts +64 -0
  332. package/src/lib/navigation/menubar/tng-menubar.d.ts.map +1 -0
  333. package/src/lib/navigation/menubar/tng-menubar.js +478 -0
  334. package/src/lib/navigation/menubar/tng-menubar.js.map +1 -0
  335. package/src/lib/navigation/navigation-menu/tng-navigation-menu.d.ts +4 -0
  336. package/src/lib/navigation/navigation-menu/tng-navigation-menu.d.ts.map +1 -0
  337. package/src/lib/navigation/navigation-menu/tng-navigation-menu.js +16 -0
  338. package/src/lib/navigation/navigation-menu/tng-navigation-menu.js.map +1 -0
  339. package/src/lib/navigation/tabs/tng-tabs.d.ts +234 -0
  340. package/src/lib/navigation/tabs/tng-tabs.d.ts.map +1 -0
  341. package/src/lib/navigation/tabs/tng-tabs.js +1350 -0
  342. package/src/lib/navigation/tabs/tng-tabs.js.map +1 -0
  343. package/src/lib/navigation/toolbar/tng-toolbar.d.ts +4 -0
  344. package/src/lib/navigation/toolbar/tng-toolbar.d.ts.map +1 -0
  345. package/src/lib/navigation/toolbar/tng-toolbar.js +16 -0
  346. package/src/lib/navigation/toolbar/tng-toolbar.js.map +1 -0
  347. package/src/lib/overlay/tooltip/tng-tooltip.d.ts +25 -0
  348. package/src/lib/overlay/tooltip/tng-tooltip.d.ts.map +1 -0
  349. package/src/lib/overlay/tooltip/tng-tooltip.js +99 -0
  350. package/src/lib/overlay/tooltip/tng-tooltip.js.map +1 -0
  351. package/src/lib/utility/avatar/tng-avatar.d.ts +10 -0
  352. package/src/lib/utility/avatar/tng-avatar.d.ts.map +1 -0
  353. package/src/lib/utility/avatar/tng-avatar.js +42 -0
  354. package/src/lib/utility/avatar/tng-avatar.js.map +1 -0
  355. package/src/lib/utility/badge/tng-badge.d.ts +63 -0
  356. package/src/lib/utility/badge/tng-badge.d.ts.map +1 -0
  357. package/src/lib/utility/badge/tng-badge.js +345 -0
  358. package/src/lib/utility/badge/tng-badge.js.map +1 -0
  359. package/src/lib/utility/code-block/tng-code-block.d.ts +16 -0
  360. package/src/lib/utility/code-block/tng-code-block.d.ts.map +1 -0
  361. package/src/lib/utility/code-block/tng-code-block.js +68 -0
  362. package/src/lib/utility/code-block/tng-code-block.js.map +1 -0
  363. package/src/lib/utility/copy/tng-copy.d.ts +75 -0
  364. package/src/lib/utility/copy/tng-copy.d.ts.map +1 -0
  365. package/src/lib/utility/copy/tng-copy.js +544 -0
  366. package/src/lib/utility/copy/tng-copy.js.map +1 -0
  367. package/src/lib/utility/press/tng-press.d.ts +33 -0
  368. package/src/lib/utility/press/tng-press.d.ts.map +1 -0
  369. package/src/lib/utility/press/tng-press.js +207 -0
  370. package/src/lib/utility/press/tng-press.js.map +1 -0
  371. package/src/lib/utility/tag/tng-tag.d.ts +4 -0
  372. package/src/lib/utility/tag/tng-tag.d.ts.map +1 -0
  373. package/src/lib/utility/tag/tng-tag.js +16 -0
  374. package/src/lib/utility/tag/tng-tag.js.map +1 -0
@@ -0,0 +1,1097 @@
1
+ import { __decorate } from "tslib";
2
+ import { Directive, ElementRef, HostBinding, HostListener, booleanAttribute, inject, input, output, } from '@angular/core';
3
+ import { createTngIdFactory } from '@tailng-ui/cdk';
4
+ const createToggleId = createTngIdFactory('tng-button-toggle-item');
5
+ let nextRegistrationOrder = 0;
6
+ function normalizeDirectionInput(value) {
7
+ if (value === 'ltr' || value === 'rtl' || value === 'auto') {
8
+ return value;
9
+ }
10
+ return 'auto';
11
+ }
12
+ function normalizeOrientationInput(value) {
13
+ return value === 'vertical' ? 'vertical' : 'horizontal';
14
+ }
15
+ function normalizeActivationInput(value) {
16
+ return value === 'manual' ? 'manual' : 'auto';
17
+ }
18
+ function normalizeTypeInput(value) {
19
+ return value === 'multiple' ? 'multiple' : 'single';
20
+ }
21
+ function normalizeOptionalValueInput(value) {
22
+ if (value === undefined) {
23
+ return undefined;
24
+ }
25
+ if (value === null) {
26
+ return null;
27
+ }
28
+ if (typeof value === 'number' || typeof value === 'string') {
29
+ return value;
30
+ }
31
+ return String(value);
32
+ }
33
+ function normalizeValueArrayInput(value) {
34
+ if (value === null || value === undefined) {
35
+ return [];
36
+ }
37
+ if (Array.isArray(value)) {
38
+ return value
39
+ .map((item) => normalizeOptionalValueInput(item))
40
+ .filter((item) => item !== null && item !== undefined);
41
+ }
42
+ if (value instanceof Set) {
43
+ return Array.from(value)
44
+ .map((item) => normalizeOptionalValueInput(item))
45
+ .filter((item) => item !== null && item !== undefined);
46
+ }
47
+ const normalized = normalizeOptionalValueInput(value);
48
+ if (normalized === null || normalized === undefined) {
49
+ return [];
50
+ }
51
+ return [normalized];
52
+ }
53
+ function normalizeOptionalValueArrayInput(value) {
54
+ if (value === undefined) {
55
+ return undefined;
56
+ }
57
+ return normalizeValueArrayInput(value);
58
+ }
59
+ function uniqueValues(values) {
60
+ const unique = new Set();
61
+ for (const value of values) {
62
+ unique.add(value);
63
+ }
64
+ return Array.from(unique);
65
+ }
66
+ function valuesEqual(a, b) {
67
+ return a === b;
68
+ }
69
+ function compareByDomPosition(aElement, bElement, aOrder, bOrder) {
70
+ if (aElement === bElement) {
71
+ return 0;
72
+ }
73
+ const relativePosition = aElement.compareDocumentPosition(bElement);
74
+ if (relativePosition & Node.DOCUMENT_POSITION_FOLLOWING) {
75
+ return -1;
76
+ }
77
+ if (relativePosition & Node.DOCUMENT_POSITION_PRECEDING) {
78
+ return 1;
79
+ }
80
+ return aOrder - bOrder;
81
+ }
82
+ function isFocusableInteractiveElement(element) {
83
+ return (element.matches('a[href]') ||
84
+ element.matches('button') ||
85
+ element.matches('input') ||
86
+ element.matches('select') ||
87
+ element.matches('textarea') ||
88
+ element.matches('[tabindex]') ||
89
+ element.matches('[contenteditable="true"]'));
90
+ }
91
+ function setsEqual(a, b) {
92
+ if (a.size !== b.size) {
93
+ return false;
94
+ }
95
+ for (const value of a) {
96
+ if (!b.has(value)) {
97
+ return false;
98
+ }
99
+ }
100
+ return true;
101
+ }
102
+ export function resolveTngButtonToggleAriaPressed(pressed) {
103
+ return pressed ? 'true' : 'false';
104
+ }
105
+ export function resolveTngButtonToggleDataState(pressed) {
106
+ return pressed ? 'on' : 'off';
107
+ }
108
+ let TngButtonToggleGroup = class TngButtonToggleGroup {
109
+ hostRef = inject(ElementRef);
110
+ toggles = new Set();
111
+ initializedType = null;
112
+ uncontrolledSingleValue = null;
113
+ uncontrolledMultipleValues = new Set();
114
+ focusedValue = null;
115
+ hasSingleUserSelection = false;
116
+ hasMultipleUserSelection = false;
117
+ type = input('single', {
118
+ transform: normalizeTypeInput,
119
+ });
120
+ controlledValueInput = input(undefined, {
121
+ alias: 'tngButtonToggleValue',
122
+ transform: normalizeOptionalValueInput,
123
+ });
124
+ controlledValuesInput = input(undefined, {
125
+ alias: 'tngButtonToggleValues',
126
+ transform: normalizeOptionalValueArrayInput,
127
+ });
128
+ defaultValueInput = input(undefined, {
129
+ alias: 'tngButtonToggleDefaultValue',
130
+ transform: normalizeOptionalValueInput,
131
+ });
132
+ defaultValuesInput = input(undefined, {
133
+ alias: 'tngButtonToggleDefaultValues',
134
+ transform: normalizeOptionalValueArrayInput,
135
+ });
136
+ value = input(undefined, {
137
+ transform: normalizeOptionalValueInput,
138
+ });
139
+ values = input(undefined, {
140
+ transform: normalizeOptionalValueArrayInput,
141
+ });
142
+ defaultValue = input(undefined, {
143
+ transform: normalizeOptionalValueInput,
144
+ });
145
+ defaultValues = input([], {
146
+ transform: normalizeValueArrayInput,
147
+ });
148
+ allowEmpty = input(false, {
149
+ transform: booleanAttribute,
150
+ });
151
+ disabled = input(false, {
152
+ transform: booleanAttribute,
153
+ });
154
+ orientation = input('horizontal', {
155
+ transform: normalizeOrientationInput,
156
+ });
157
+ loop = input(true, {
158
+ transform: booleanAttribute,
159
+ });
160
+ activation = input('auto', {
161
+ transform: normalizeActivationInput,
162
+ });
163
+ dir = input('auto', {
164
+ transform: normalizeDirectionInput,
165
+ });
166
+ valueChange = output();
167
+ valuesChange = output();
168
+ toggleChange = output();
169
+ focusChange = output();
170
+ dataSlot = 'button-toggle-group';
171
+ get dataType() {
172
+ return this.type();
173
+ }
174
+ get dataOrientation() {
175
+ return this.orientation();
176
+ }
177
+ get dataDisabled() {
178
+ return this.disabled() ? 'true' : 'false';
179
+ }
180
+ get roleAttr() {
181
+ return this.type() === 'single' ? 'radiogroup' : 'group';
182
+ }
183
+ get ariaDisabled() {
184
+ return this.disabled() ? 'true' : null;
185
+ }
186
+ get ariaOrientation() {
187
+ return this.orientation();
188
+ }
189
+ ngDoCheck() {
190
+ this.syncStateFromRegistry();
191
+ }
192
+ registerToggle(toggle) {
193
+ this.toggles.add(toggle);
194
+ }
195
+ unregisterToggle(toggle) {
196
+ const orderedToggles = this.getOrderedToggles();
197
+ const removedIndex = orderedToggles.indexOf(toggle);
198
+ const removedValue = toggle.getValue();
199
+ const selectedSingleValue = this.getEffectiveSingleSelectedValue();
200
+ const focusedValue = this.resolveCurrentTabStopValue();
201
+ this.toggles.delete(toggle);
202
+ if (this.type() === 'single' &&
203
+ !this.isSingleControlled() &&
204
+ selectedSingleValue !== null &&
205
+ valuesEqual(selectedSingleValue, removedValue)) {
206
+ this.uncontrolledSingleValue = this.allowEmpty()
207
+ ? null
208
+ : this.resolveNeighborValueOnRemoval(orderedToggles, removedIndex);
209
+ }
210
+ if (this.type() === 'multiple' && !this.isMultipleControlled()) {
211
+ this.uncontrolledMultipleValues.delete(removedValue);
212
+ }
213
+ if (focusedValue !== null && valuesEqual(focusedValue, removedValue)) {
214
+ this.focusedValue = this.resolveNeighborValueOnRemoval(orderedToggles, removedIndex);
215
+ }
216
+ this.syncStateFromRegistry();
217
+ }
218
+ notifyToggleMutated(toggle) {
219
+ void toggle;
220
+ this.syncStateFromRegistry();
221
+ }
222
+ isDisabled() {
223
+ return this.disabled();
224
+ }
225
+ getToggleRole() {
226
+ return this.type() === 'single' ? 'radio' : null;
227
+ }
228
+ getToggleTabIndex(toggle) {
229
+ if (this.disabled() || toggle.isDisabledInContext()) {
230
+ return '-1';
231
+ }
232
+ const tabStop = this.resolveCurrentTabStopValue();
233
+ if (tabStop === null) {
234
+ return '-1';
235
+ }
236
+ return valuesEqual(tabStop, toggle.getValue()) ? '0' : '-1';
237
+ }
238
+ getToggleAriaChecked(toggle) {
239
+ if (this.type() !== 'single') {
240
+ return null;
241
+ }
242
+ return this.isToggleSelected(toggle) ? 'true' : 'false';
243
+ }
244
+ getToggleAriaPressed(toggle) {
245
+ if (this.type() !== 'multiple') {
246
+ return null;
247
+ }
248
+ return resolveTngButtonToggleAriaPressed(this.isToggleSelected(toggle));
249
+ }
250
+ isToggleSelected(toggle) {
251
+ if (this.type() === 'single') {
252
+ const selectedValue = this.getEffectiveSingleSelectedValue();
253
+ if (selectedValue === null) {
254
+ return false;
255
+ }
256
+ return valuesEqual(selectedValue, toggle.getValue());
257
+ }
258
+ const selectedValues = this.getEffectiveMultipleSelectedValues();
259
+ return selectedValues.has(toggle.getValue());
260
+ }
261
+ isToggleFocused(toggle) {
262
+ const tabStop = this.resolveCurrentTabStopValue();
263
+ if (tabStop === null) {
264
+ return false;
265
+ }
266
+ return valuesEqual(tabStop, toggle.getValue());
267
+ }
268
+ onToggleFocused(toggle, trigger) {
269
+ if (this.disabled() || toggle.isDisabledInContext()) {
270
+ return;
271
+ }
272
+ this.setFocusedValue(toggle.getValue(), trigger);
273
+ }
274
+ activateToggle(toggle, trigger) {
275
+ if (this.disabled() || toggle.isDisabledInContext()) {
276
+ return;
277
+ }
278
+ this.setFocusedValue(toggle.getValue(), trigger === 'programmatic' ? 'programmatic' : 'pointer');
279
+ if (this.type() === 'single') {
280
+ this.requestSingleToggle(toggle.getValue(), trigger);
281
+ return;
282
+ }
283
+ this.requestMultipleToggle(toggle.getValue(), trigger);
284
+ }
285
+ handleToggleKeydown(toggle, event) {
286
+ if (this.disabled() || toggle.isDisabledInContext()) {
287
+ return;
288
+ }
289
+ const focusMove = this.resolveFocusMove(event.key);
290
+ if (focusMove !== null) {
291
+ event.preventDefault();
292
+ this.moveFocusByAction(toggle, focusMove, 'keyboard');
293
+ return;
294
+ }
295
+ if (event.key !== 'Enter' && event.key !== ' ' && event.key !== 'Spacebar') {
296
+ return;
297
+ }
298
+ event.preventDefault();
299
+ this.activateToggle(toggle, 'keyboard');
300
+ }
301
+ select(value) {
302
+ const targetToggle = this.findEnabledToggleByValue(value);
303
+ if (targetToggle === null) {
304
+ return;
305
+ }
306
+ if (this.type() === 'single') {
307
+ this.requestSingleSelection(value, 'programmatic');
308
+ return;
309
+ }
310
+ this.requestMultipleSelection(value, true, 'programmatic');
311
+ }
312
+ deselect(value) {
313
+ if (this.type() === 'single') {
314
+ const selectedValue = this.getEffectiveSingleSelectedValue();
315
+ if (selectedValue === null ||
316
+ !valuesEqual(selectedValue, value) ||
317
+ (!this.allowEmpty() && this.findEnabledToggleByValue(value) !== null)) {
318
+ return;
319
+ }
320
+ this.applySingleSelection(null, value, false, 'programmatic');
321
+ return;
322
+ }
323
+ this.requestMultipleSelection(value, false, 'programmatic');
324
+ }
325
+ toggle(value) {
326
+ if (this.type() === 'single') {
327
+ const selectedValue = this.getEffectiveSingleSelectedValue();
328
+ if (selectedValue !== null && valuesEqual(selectedValue, value) && this.allowEmpty()) {
329
+ this.applySingleSelection(null, value, false, 'programmatic');
330
+ return;
331
+ }
332
+ this.requestSingleSelection(value, 'programmatic');
333
+ return;
334
+ }
335
+ this.requestMultipleToggle(value, 'programmatic');
336
+ }
337
+ focus(value) {
338
+ const targetToggle = this.findEnabledToggleByValue(value);
339
+ if (targetToggle === null) {
340
+ return;
341
+ }
342
+ this.moveFocusToToggle(targetToggle, 'programmatic');
343
+ }
344
+ next() {
345
+ this.moveFocusFromCurrentToggle('next', 'programmatic');
346
+ }
347
+ prev() {
348
+ this.moveFocusFromCurrentToggle('prev', 'programmatic');
349
+ }
350
+ requestSingleSelection(nextValue, trigger) {
351
+ const targetToggle = this.findEnabledToggleByValue(nextValue);
352
+ if (targetToggle === null) {
353
+ return;
354
+ }
355
+ const selectedValue = this.getEffectiveSingleSelectedValue();
356
+ if (selectedValue !== null && valuesEqual(selectedValue, nextValue)) {
357
+ return;
358
+ }
359
+ this.applySingleSelection(nextValue, nextValue, true, trigger);
360
+ }
361
+ requestSingleToggle(nextValue, trigger) {
362
+ const targetToggle = this.findEnabledToggleByValue(nextValue);
363
+ if (targetToggle === null) {
364
+ return;
365
+ }
366
+ const selectedValue = this.getEffectiveSingleSelectedValue();
367
+ if (selectedValue !== null && valuesEqual(selectedValue, nextValue)) {
368
+ if (!this.allowEmpty()) {
369
+ return;
370
+ }
371
+ this.applySingleSelection(null, nextValue, false, trigger);
372
+ return;
373
+ }
374
+ this.applySingleSelection(nextValue, nextValue, true, trigger);
375
+ }
376
+ applySingleSelection(nextValue, toggledValue, selected, trigger) {
377
+ const previousValue = this.getEffectiveSingleSelectedValue();
378
+ if (valuesEqual(previousValue, nextValue)) {
379
+ return;
380
+ }
381
+ if (!this.isSingleControlled()) {
382
+ this.uncontrolledSingleValue = nextValue;
383
+ this.hasSingleUserSelection = true;
384
+ }
385
+ this.valueChange.emit(nextValue);
386
+ this.toggleChange.emit({
387
+ value: toggledValue,
388
+ selected,
389
+ previousValue,
390
+ previousValues: previousValue === null ? [] : [previousValue],
391
+ values: nextValue === null ? [] : [nextValue],
392
+ trigger,
393
+ });
394
+ this.syncStateFromRegistry();
395
+ }
396
+ requestMultipleSelection(value, shouldSelect, trigger) {
397
+ const targetToggle = this.findEnabledToggleByValue(value);
398
+ if (targetToggle === null) {
399
+ return;
400
+ }
401
+ const previousSelection = this.getEffectiveMultipleSelectedValues();
402
+ const nextSelection = new Set(previousSelection);
403
+ if (shouldSelect) {
404
+ nextSelection.add(value);
405
+ }
406
+ else {
407
+ nextSelection.delete(value);
408
+ }
409
+ if (setsEqual(previousSelection, nextSelection)) {
410
+ return;
411
+ }
412
+ this.applyMultipleSelection(nextSelection, value, shouldSelect, trigger);
413
+ }
414
+ requestMultipleToggle(value, trigger) {
415
+ const targetToggle = this.findEnabledToggleByValue(value);
416
+ if (targetToggle === null) {
417
+ return;
418
+ }
419
+ const previousSelection = this.getEffectiveMultipleSelectedValues();
420
+ const nextSelection = new Set(previousSelection);
421
+ const selected = !nextSelection.has(value);
422
+ if (selected) {
423
+ nextSelection.add(value);
424
+ }
425
+ else {
426
+ nextSelection.delete(value);
427
+ }
428
+ this.applyMultipleSelection(nextSelection, value, selected, trigger);
429
+ }
430
+ applyMultipleSelection(nextSelection, toggledValue, selected, trigger) {
431
+ const previousSelection = this.getEffectiveMultipleSelectedValues();
432
+ if (setsEqual(previousSelection, nextSelection)) {
433
+ return;
434
+ }
435
+ if (!this.isMultipleControlled()) {
436
+ this.uncontrolledMultipleValues = new Set(nextSelection);
437
+ this.hasMultipleUserSelection = true;
438
+ }
439
+ const previousValues = this.getSelectedValuesInDomOrder(previousSelection);
440
+ const values = this.getSelectedValuesInDomOrder(nextSelection);
441
+ this.valuesChange.emit(values);
442
+ this.toggleChange.emit({
443
+ value: toggledValue,
444
+ selected,
445
+ previousValue: null,
446
+ previousValues,
447
+ values,
448
+ trigger,
449
+ });
450
+ this.syncStateFromRegistry();
451
+ }
452
+ resolveFocusMove(key) {
453
+ if (key === 'Home') {
454
+ return 'first';
455
+ }
456
+ if (key === 'End') {
457
+ return 'last';
458
+ }
459
+ if (this.orientation() === 'vertical') {
460
+ if (key === 'ArrowDown') {
461
+ return 'next';
462
+ }
463
+ if (key === 'ArrowUp') {
464
+ return 'prev';
465
+ }
466
+ return null;
467
+ }
468
+ if (key !== 'ArrowLeft' && key !== 'ArrowRight') {
469
+ return null;
470
+ }
471
+ const isRtl = this.resolveDirection() === 'rtl';
472
+ const moveToNext = key === (isRtl ? 'ArrowLeft' : 'ArrowRight');
473
+ return moveToNext ? 'next' : 'prev';
474
+ }
475
+ moveFocusByAction(sourceToggle, action, trigger) {
476
+ const enabledToggles = this.getEnabledToggles();
477
+ if (enabledToggles.length === 0) {
478
+ return;
479
+ }
480
+ const currentIndex = enabledToggles.indexOf(sourceToggle);
481
+ if (currentIndex < 0) {
482
+ return;
483
+ }
484
+ const nextToggle = this.resolveFocusTarget(enabledToggles, currentIndex, action);
485
+ if (nextToggle === null) {
486
+ return;
487
+ }
488
+ this.moveFocusToToggle(nextToggle, trigger);
489
+ if (this.activation() === 'auto' && this.type() === 'single') {
490
+ this.requestSingleSelection(nextToggle.getValue(), trigger === 'programmatic' ? 'programmatic' : 'keyboard');
491
+ }
492
+ }
493
+ moveFocusToToggle(toggle, trigger) {
494
+ if (this.disabled() || toggle.isDisabledInContext()) {
495
+ return;
496
+ }
497
+ this.setFocusedValue(toggle.getValue(), trigger);
498
+ toggle.focusSelf();
499
+ }
500
+ moveFocusFromCurrentToggle(direction, trigger) {
501
+ const enabledToggles = this.getEnabledToggles();
502
+ if (enabledToggles.length === 0) {
503
+ return;
504
+ }
505
+ const activeElement = this.hostRef.nativeElement.ownerDocument?.activeElement ?? null;
506
+ const activeToggle = this.findToggleContainingElement(activeElement);
507
+ const currentToggle = activeToggle ?? this.findEnabledToggleByValue(this.resolveCurrentTabStopValue(), enabledToggles);
508
+ if (currentToggle === null) {
509
+ return;
510
+ }
511
+ const currentIndex = enabledToggles.indexOf(currentToggle);
512
+ if (currentIndex < 0) {
513
+ return;
514
+ }
515
+ const nextToggle = this.resolveFocusTarget(enabledToggles, currentIndex, direction);
516
+ if (nextToggle === null) {
517
+ return;
518
+ }
519
+ this.moveFocusToToggle(nextToggle, trigger);
520
+ if (this.activation() === 'auto' && this.type() === 'single') {
521
+ this.requestSingleSelection(nextToggle.getValue(), trigger === 'programmatic' ? 'programmatic' : 'keyboard');
522
+ }
523
+ }
524
+ resolveFocusTarget(enabledToggles, currentIndex, action) {
525
+ if (enabledToggles.length === 0 || currentIndex < 0) {
526
+ return null;
527
+ }
528
+ if (action === 'first') {
529
+ return enabledToggles[0] ?? null;
530
+ }
531
+ if (action === 'last') {
532
+ return enabledToggles[enabledToggles.length - 1] ?? null;
533
+ }
534
+ if (action === 'next') {
535
+ if (currentIndex + 1 < enabledToggles.length) {
536
+ return enabledToggles[currentIndex + 1] ?? null;
537
+ }
538
+ return this.loop()
539
+ ? (enabledToggles[0] ?? null)
540
+ : (enabledToggles[currentIndex] ?? null);
541
+ }
542
+ if (currentIndex - 1 >= 0) {
543
+ return enabledToggles[currentIndex - 1] ?? null;
544
+ }
545
+ return this.loop()
546
+ ? (enabledToggles[enabledToggles.length - 1] ?? null)
547
+ : (enabledToggles[currentIndex] ?? null);
548
+ }
549
+ setFocusedValue(value, trigger) {
550
+ const previousValue = this.focusedValue;
551
+ if (previousValue !== null && valuesEqual(previousValue, value)) {
552
+ return;
553
+ }
554
+ this.focusedValue = value;
555
+ this.focusChange.emit({
556
+ value,
557
+ previousValue,
558
+ trigger,
559
+ });
560
+ }
561
+ resolveDirection() {
562
+ const configuredDirection = this.dir();
563
+ if (configuredDirection !== 'auto') {
564
+ return configuredDirection;
565
+ }
566
+ const host = this.hostRef.nativeElement;
567
+ const nearestDirection = host.closest('[dir]')?.getAttribute('dir') ??
568
+ host.ownerDocument?.documentElement.getAttribute('dir');
569
+ return nearestDirection?.toLowerCase() === 'rtl' ? 'rtl' : 'ltr';
570
+ }
571
+ syncStateFromRegistry() {
572
+ const currentType = this.type();
573
+ const enabledToggles = this.getEnabledToggles();
574
+ if (this.initializedType !== currentType) {
575
+ this.initializedType = currentType;
576
+ this.focusedValue = null;
577
+ this.hasSingleUserSelection = false;
578
+ this.hasMultipleUserSelection = false;
579
+ if (currentType === 'single') {
580
+ this.uncontrolledMultipleValues.clear();
581
+ if (!this.isSingleControlled()) {
582
+ this.uncontrolledSingleValue = this.resolveInitialSingleValue(enabledToggles);
583
+ }
584
+ }
585
+ else {
586
+ this.uncontrolledSingleValue = null;
587
+ if (!this.isMultipleControlled()) {
588
+ this.uncontrolledMultipleValues = new Set(this.resolveInitialMultipleValues(enabledToggles));
589
+ }
590
+ }
591
+ }
592
+ if (enabledToggles.length === 0) {
593
+ if (currentType === 'single' && !this.isSingleControlled()) {
594
+ this.uncontrolledSingleValue = null;
595
+ }
596
+ if (currentType === 'multiple' && !this.isMultipleControlled()) {
597
+ this.uncontrolledMultipleValues.clear();
598
+ }
599
+ this.focusedValue = null;
600
+ return;
601
+ }
602
+ if (currentType === 'single') {
603
+ this.syncSingleState(enabledToggles);
604
+ }
605
+ else {
606
+ this.syncMultipleState(enabledToggles);
607
+ }
608
+ this.focusedValue = this.resolveCurrentTabStopValue(enabledToggles);
609
+ }
610
+ syncSingleState(enabledToggles) {
611
+ if (this.isSingleControlled()) {
612
+ return;
613
+ }
614
+ const currentValue = this.uncontrolledSingleValue;
615
+ const hasEnabledCurrentValue = currentValue !== null && this.findEnabledToggleByValue(currentValue, enabledToggles) !== null;
616
+ if (hasEnabledCurrentValue) {
617
+ return;
618
+ }
619
+ this.uncontrolledSingleValue = this.allowEmpty()
620
+ ? null
621
+ : (enabledToggles[0]?.getValue() ?? null);
622
+ }
623
+ syncMultipleState(enabledToggles) {
624
+ if (this.isMultipleControlled()) {
625
+ return;
626
+ }
627
+ const enabledSet = new Set(enabledToggles.map((toggle) => toggle.getValue()));
628
+ const nextValues = new Set();
629
+ for (const value of this.uncontrolledMultipleValues) {
630
+ if (enabledSet.has(value)) {
631
+ nextValues.add(value);
632
+ }
633
+ }
634
+ this.uncontrolledMultipleValues = nextValues;
635
+ }
636
+ resolveInitialSingleValue(enabledToggles) {
637
+ if (enabledToggles.length === 0) {
638
+ return null;
639
+ }
640
+ const defaultValue = this.getDefaultSingleValueInput();
641
+ if (defaultValue !== undefined &&
642
+ defaultValue !== null &&
643
+ this.findEnabledToggleByValue(defaultValue, enabledToggles) !== null) {
644
+ return defaultValue;
645
+ }
646
+ if (this.allowEmpty()) {
647
+ return null;
648
+ }
649
+ return enabledToggles[0]?.getValue() ?? null;
650
+ }
651
+ resolveInitialMultipleValues(enabledToggles) {
652
+ if (enabledToggles.length === 0) {
653
+ return [];
654
+ }
655
+ const defaultValues = new Set(uniqueValues(this.getDefaultMultipleValuesInput()));
656
+ if (defaultValues.size === 0) {
657
+ return [];
658
+ }
659
+ const selectedValues = [];
660
+ for (const toggle of enabledToggles) {
661
+ const value = toggle.getValue();
662
+ if (defaultValues.has(value)) {
663
+ selectedValues.push(value);
664
+ }
665
+ }
666
+ return selectedValues;
667
+ }
668
+ resolveNeighborValueOnRemoval(orderedToggles, removedIndex) {
669
+ if (removedIndex < 0) {
670
+ return this.getEnabledToggles()[0]?.getValue() ?? null;
671
+ }
672
+ for (let index = removedIndex + 1; index < orderedToggles.length; index += 1) {
673
+ const candidate = orderedToggles[index];
674
+ if (candidate !== undefined && !candidate.isSelfDisabled()) {
675
+ return candidate.getValue();
676
+ }
677
+ }
678
+ for (let index = removedIndex - 1; index >= 0; index -= 1) {
679
+ const candidate = orderedToggles[index];
680
+ if (candidate !== undefined && !candidate.isSelfDisabled()) {
681
+ return candidate.getValue();
682
+ }
683
+ }
684
+ return null;
685
+ }
686
+ resolveNeighborForUnavailableToggle(toggle) {
687
+ const orderedToggles = this.getOrderedToggles();
688
+ const currentIndex = orderedToggles.indexOf(toggle);
689
+ if (currentIndex < 0) {
690
+ return this.getEnabledToggles()[0]?.getValue() ?? null;
691
+ }
692
+ for (let index = currentIndex + 1; index < orderedToggles.length; index += 1) {
693
+ const candidate = orderedToggles[index];
694
+ if (candidate !== undefined && !candidate.isSelfDisabled()) {
695
+ return candidate.getValue();
696
+ }
697
+ }
698
+ for (let index = currentIndex - 1; index >= 0; index -= 1) {
699
+ const candidate = orderedToggles[index];
700
+ if (candidate !== undefined && !candidate.isSelfDisabled()) {
701
+ return candidate.getValue();
702
+ }
703
+ }
704
+ return null;
705
+ }
706
+ isSingleControlled() {
707
+ if (this.type() !== 'single') {
708
+ return false;
709
+ }
710
+ return this.getControlledSingleValueInput() !== undefined;
711
+ }
712
+ isMultipleControlled() {
713
+ if (this.type() !== 'multiple') {
714
+ return false;
715
+ }
716
+ return this.getControlledMultipleValuesInput() !== undefined;
717
+ }
718
+ getEffectiveSingleSelectedValue(enabledToggles = this.getEnabledToggles()) {
719
+ if (this.type() !== 'single' || enabledToggles.length === 0) {
720
+ return null;
721
+ }
722
+ let selectedValue = this.isSingleControlled()
723
+ ? (this.getControlledSingleValueInput() ?? null)
724
+ : this.uncontrolledSingleValue;
725
+ if (!this.isSingleControlled() && !this.hasSingleUserSelection) {
726
+ const defaultValue = this.getDefaultSingleValueInput();
727
+ if (defaultValue !== undefined &&
728
+ defaultValue !== null &&
729
+ this.findEnabledToggleByValue(defaultValue, enabledToggles) !== null) {
730
+ selectedValue = defaultValue;
731
+ }
732
+ else if (defaultValue === null) {
733
+ selectedValue = null;
734
+ }
735
+ }
736
+ if (selectedValue !== null &&
737
+ this.findEnabledToggleByValue(selectedValue, enabledToggles) !== null) {
738
+ return selectedValue;
739
+ }
740
+ if (this.allowEmpty()) {
741
+ return null;
742
+ }
743
+ return enabledToggles[0]?.getValue() ?? null;
744
+ }
745
+ getEffectiveMultipleSelectedValues(enabledToggles = this.getEnabledToggles()) {
746
+ if (this.type() !== 'multiple' || enabledToggles.length === 0) {
747
+ return new Set();
748
+ }
749
+ const sourceValues = this.isMultipleControlled()
750
+ ? uniqueValues(this.getControlledMultipleValuesInput() ?? [])
751
+ : (!this.hasMultipleUserSelection
752
+ ? uniqueValues(this.getDefaultMultipleValuesInput())
753
+ : Array.from(this.uncontrolledMultipleValues));
754
+ const sourceSet = new Set(sourceValues);
755
+ const selectedSet = new Set();
756
+ for (const toggle of enabledToggles) {
757
+ const value = toggle.getValue();
758
+ if (sourceSet.has(value)) {
759
+ selectedSet.add(value);
760
+ }
761
+ }
762
+ return selectedSet;
763
+ }
764
+ resolveCurrentTabStopValue(enabledToggles = this.getEnabledToggles()) {
765
+ if (enabledToggles.length === 0) {
766
+ return null;
767
+ }
768
+ if (this.focusedValue !== null &&
769
+ this.findEnabledToggleByValue(this.focusedValue, enabledToggles) !== null) {
770
+ return this.focusedValue;
771
+ }
772
+ if (this.type() === 'single') {
773
+ const selectedValue = this.getEffectiveSingleSelectedValue(enabledToggles);
774
+ if (selectedValue !== null) {
775
+ return selectedValue;
776
+ }
777
+ return enabledToggles[0]?.getValue() ?? null;
778
+ }
779
+ const selectedValues = this.getEffectiveMultipleSelectedValues(enabledToggles);
780
+ for (const toggle of enabledToggles) {
781
+ const value = toggle.getValue();
782
+ if (selectedValues.has(value)) {
783
+ return value;
784
+ }
785
+ }
786
+ return enabledToggles[0]?.getValue() ?? null;
787
+ }
788
+ getSelectedValuesInDomOrder(selectedValues, orderedToggles = this.getOrderedToggles()) {
789
+ if (selectedValues.size === 0) {
790
+ return [];
791
+ }
792
+ const values = [];
793
+ for (const toggle of orderedToggles) {
794
+ const value = toggle.getValue();
795
+ if (selectedValues.has(value) && !toggle.isSelfDisabled()) {
796
+ values.push(value);
797
+ }
798
+ }
799
+ return values;
800
+ }
801
+ getOrderedToggles() {
802
+ const toggles = Array.from(this.toggles);
803
+ toggles.sort((a, b) => compareByDomPosition(a.getHostElement(), b.getHostElement(), a.getRegistrationOrder(), b.getRegistrationOrder()));
804
+ return toggles;
805
+ }
806
+ getEnabledToggles() {
807
+ return this.getOrderedToggles().filter((toggle) => !toggle.isSelfDisabled());
808
+ }
809
+ findEnabledToggleByValue(value, enabledToggles = this.getEnabledToggles()) {
810
+ if (value === null) {
811
+ return null;
812
+ }
813
+ return enabledToggles.find((toggle) => valuesEqual(toggle.getValue(), value)) ?? null;
814
+ }
815
+ findToggleContainingElement(element) {
816
+ if (element === null) {
817
+ return null;
818
+ }
819
+ const toggles = this.getOrderedToggles();
820
+ return (toggles.find((toggle) => {
821
+ const host = toggle.getHostElement();
822
+ return host === element || host.contains(element);
823
+ }) ?? null);
824
+ }
825
+ getControlledSingleValueInput() {
826
+ const explicit = this.controlledValueInput();
827
+ if (explicit !== undefined) {
828
+ return explicit;
829
+ }
830
+ return this.value();
831
+ }
832
+ getControlledMultipleValuesInput() {
833
+ const explicit = this.controlledValuesInput();
834
+ if (explicit !== undefined) {
835
+ return explicit;
836
+ }
837
+ return this.values();
838
+ }
839
+ getDefaultSingleValueInput() {
840
+ const explicit = this.defaultValueInput();
841
+ if (explicit !== undefined) {
842
+ return explicit;
843
+ }
844
+ return this.defaultValue();
845
+ }
846
+ getDefaultMultipleValuesInput() {
847
+ const explicit = this.defaultValuesInput();
848
+ if (explicit !== undefined) {
849
+ return explicit;
850
+ }
851
+ return this.defaultValues();
852
+ }
853
+ };
854
+ __decorate([
855
+ HostBinding('attr.data-slot')
856
+ ], TngButtonToggleGroup.prototype, "dataSlot", void 0);
857
+ __decorate([
858
+ HostBinding('attr.data-type')
859
+ ], TngButtonToggleGroup.prototype, "dataType", null);
860
+ __decorate([
861
+ HostBinding('attr.data-orientation')
862
+ ], TngButtonToggleGroup.prototype, "dataOrientation", null);
863
+ __decorate([
864
+ HostBinding('attr.data-disabled')
865
+ ], TngButtonToggleGroup.prototype, "dataDisabled", null);
866
+ __decorate([
867
+ HostBinding('attr.role')
868
+ ], TngButtonToggleGroup.prototype, "roleAttr", null);
869
+ __decorate([
870
+ HostBinding('attr.aria-disabled')
871
+ ], TngButtonToggleGroup.prototype, "ariaDisabled", null);
872
+ __decorate([
873
+ HostBinding('attr.aria-orientation')
874
+ ], TngButtonToggleGroup.prototype, "ariaOrientation", null);
875
+ TngButtonToggleGroup = __decorate([
876
+ Directive({
877
+ selector: '[tngButtonToggleGroup]',
878
+ exportAs: 'tngButtonToggleGroup',
879
+ standalone: true,
880
+ })
881
+ ], TngButtonToggleGroup);
882
+ export { TngButtonToggleGroup };
883
+ let TngButtonToggle = class TngButtonToggle {
884
+ hostRef = inject(ElementRef);
885
+ group = inject(TngButtonToggleGroup, { optional: true });
886
+ resolvedId = createToggleId();
887
+ registrationOrder = nextRegistrationOrder++;
888
+ lastKnownValue = null;
889
+ lastKnownDisabled = false;
890
+ toggleValueInput = input(undefined, {
891
+ alias: 'tngButtonToggleValue',
892
+ transform: normalizeOptionalValueInput,
893
+ });
894
+ valueInput = input(undefined, {
895
+ alias: 'value',
896
+ transform: normalizeOptionalValueInput,
897
+ });
898
+ disabledInput = input(false, {
899
+ alias: 'disabled',
900
+ transform: booleanAttribute,
901
+ });
902
+ pressedInput = input(false, {
903
+ alias: 'pressed',
904
+ transform: booleanAttribute,
905
+ });
906
+ dataSlot = 'button-toggle';
907
+ get id() {
908
+ return this.resolvedId;
909
+ }
910
+ typeAttr = 'button';
911
+ get roleAttr() {
912
+ return this.group?.getToggleRole() ?? null;
913
+ }
914
+ get tabIndexAttr() {
915
+ if (this.group === null) {
916
+ return null;
917
+ }
918
+ return this.group.getToggleTabIndex(this);
919
+ }
920
+ get ariaCheckedAttr() {
921
+ if (this.group === null) {
922
+ return null;
923
+ }
924
+ return this.group.getToggleAriaChecked(this);
925
+ }
926
+ get ariaPressedAttr() {
927
+ if (this.group !== null) {
928
+ return this.group.getToggleAriaPressed(this);
929
+ }
930
+ return resolveTngButtonToggleAriaPressed(this.pressedInput());
931
+ }
932
+ get ariaDisabledAttr() {
933
+ return this.isDisabledInContext() ? 'true' : null;
934
+ }
935
+ get dataDisabledAttr() {
936
+ return this.isDisabledInContext() ? 'true' : 'false';
937
+ }
938
+ get dataFocusedAttr() {
939
+ if (this.group === null) {
940
+ return 'false';
941
+ }
942
+ return this.group.isToggleFocused(this) ? 'true' : 'false';
943
+ }
944
+ get dataSelectedAttr() {
945
+ if (this.group === null) {
946
+ return this.pressedInput() ? 'true' : 'false';
947
+ }
948
+ return this.group.isToggleSelected(this) ? 'true' : 'false';
949
+ }
950
+ get dataStateAttr() {
951
+ return resolveTngButtonToggleDataState(this.dataSelectedAttr === 'true');
952
+ }
953
+ get disabledAttr() {
954
+ return this.isDisabledInContext() ? '' : null;
955
+ }
956
+ constructor() {
957
+ this.group?.registerToggle(this);
958
+ }
959
+ ngOnInit() {
960
+ this.syncResolvedIdFromHost();
961
+ this.lastKnownValue = this.getValue();
962
+ this.lastKnownDisabled = this.isDisabledInContext();
963
+ this.group?.notifyToggleMutated(this);
964
+ }
965
+ ngDoCheck() {
966
+ this.syncResolvedIdFromHost();
967
+ this.lastKnownValue = this.getValue();
968
+ this.lastKnownDisabled = this.isDisabledInContext();
969
+ }
970
+ ngOnDestroy() {
971
+ this.group?.unregisterToggle(this);
972
+ }
973
+ onClick(event) {
974
+ if (this.isDisabledInContext()) {
975
+ event.preventDefault();
976
+ return;
977
+ }
978
+ if (this.group === null) {
979
+ return;
980
+ }
981
+ const target = event.target;
982
+ if (target instanceof Element && target !== this.hostRef.nativeElement) {
983
+ if (isFocusableInteractiveElement(target) && this.hostRef.nativeElement.contains(target)) {
984
+ return;
985
+ }
986
+ }
987
+ this.focusSelf();
988
+ this.group.activateToggle(this, 'pointer');
989
+ }
990
+ onFocus() {
991
+ if (this.group === null || this.isDisabledInContext()) {
992
+ return;
993
+ }
994
+ this.group.onToggleFocused(this, 'pointer');
995
+ }
996
+ onKeydown(event) {
997
+ this.group?.handleToggleKeydown(this, event);
998
+ }
999
+ getRegistrationOrder() {
1000
+ return this.registrationOrder;
1001
+ }
1002
+ getHostElement() {
1003
+ return this.hostRef.nativeElement;
1004
+ }
1005
+ getValue() {
1006
+ const explicitValue = this.toggleValueInput() ?? this.valueInput();
1007
+ if (explicitValue !== undefined && explicitValue !== null) {
1008
+ return explicitValue;
1009
+ }
1010
+ const hostPropertyValue = this.hostRef.nativeElement.value;
1011
+ if (typeof hostPropertyValue === 'string' && hostPropertyValue.length > 0) {
1012
+ return hostPropertyValue;
1013
+ }
1014
+ const hostValue = this.hostRef.nativeElement.getAttribute('value');
1015
+ if (hostValue !== null && hostValue.length > 0) {
1016
+ return hostValue;
1017
+ }
1018
+ return this.resolvedId;
1019
+ }
1020
+ isDisabledInContext() {
1021
+ if (this.group?.isDisabled()) {
1022
+ return true;
1023
+ }
1024
+ return this.disabledInput();
1025
+ }
1026
+ isSelfDisabled() {
1027
+ return this.disabledInput();
1028
+ }
1029
+ focusSelf() {
1030
+ this.hostRef.nativeElement.focus();
1031
+ }
1032
+ syncResolvedIdFromHost() {
1033
+ const hostId = this.hostRef.nativeElement.getAttribute('id');
1034
+ if (hostId === null || hostId.length === 0 || hostId === this.resolvedId) {
1035
+ return false;
1036
+ }
1037
+ this.resolvedId = hostId;
1038
+ return true;
1039
+ }
1040
+ };
1041
+ __decorate([
1042
+ HostBinding('attr.data-slot')
1043
+ ], TngButtonToggle.prototype, "dataSlot", void 0);
1044
+ __decorate([
1045
+ HostBinding('attr.id')
1046
+ ], TngButtonToggle.prototype, "id", null);
1047
+ __decorate([
1048
+ HostBinding('attr.type')
1049
+ ], TngButtonToggle.prototype, "typeAttr", void 0);
1050
+ __decorate([
1051
+ HostBinding('attr.role')
1052
+ ], TngButtonToggle.prototype, "roleAttr", null);
1053
+ __decorate([
1054
+ HostBinding('attr.tabindex')
1055
+ ], TngButtonToggle.prototype, "tabIndexAttr", null);
1056
+ __decorate([
1057
+ HostBinding('attr.aria-checked')
1058
+ ], TngButtonToggle.prototype, "ariaCheckedAttr", null);
1059
+ __decorate([
1060
+ HostBinding('attr.aria-pressed')
1061
+ ], TngButtonToggle.prototype, "ariaPressedAttr", null);
1062
+ __decorate([
1063
+ HostBinding('attr.aria-disabled')
1064
+ ], TngButtonToggle.prototype, "ariaDisabledAttr", null);
1065
+ __decorate([
1066
+ HostBinding('attr.data-disabled')
1067
+ ], TngButtonToggle.prototype, "dataDisabledAttr", null);
1068
+ __decorate([
1069
+ HostBinding('attr.data-focused')
1070
+ ], TngButtonToggle.prototype, "dataFocusedAttr", null);
1071
+ __decorate([
1072
+ HostBinding('attr.data-selected')
1073
+ ], TngButtonToggle.prototype, "dataSelectedAttr", null);
1074
+ __decorate([
1075
+ HostBinding('attr.data-state')
1076
+ ], TngButtonToggle.prototype, "dataStateAttr", null);
1077
+ __decorate([
1078
+ HostBinding('attr.disabled')
1079
+ ], TngButtonToggle.prototype, "disabledAttr", null);
1080
+ __decorate([
1081
+ HostListener('click', ['$event'])
1082
+ ], TngButtonToggle.prototype, "onClick", null);
1083
+ __decorate([
1084
+ HostListener('focus')
1085
+ ], TngButtonToggle.prototype, "onFocus", null);
1086
+ __decorate([
1087
+ HostListener('keydown', ['$event'])
1088
+ ], TngButtonToggle.prototype, "onKeydown", null);
1089
+ TngButtonToggle = __decorate([
1090
+ Directive({
1091
+ selector: 'button[tngButtonToggle]',
1092
+ exportAs: 'tngButtonToggle',
1093
+ standalone: true,
1094
+ })
1095
+ ], TngButtonToggle);
1096
+ export { TngButtonToggle };
1097
+ //# sourceMappingURL=tng-button-toggle.js.map