@radix-ng/primitives 0.11.0 → 0.12.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 (445) hide show
  1. package/.compodocrc.json +12 -0
  2. package/CHANGELOG.md +182 -0
  3. package/LICENSE +21 -0
  4. package/accordion/__tests__/accordion-content.directive.spec.ts +8 -0
  5. package/accordion/__tests__/accordion-header.directive.spec.ts +8 -0
  6. package/accordion/__tests__/accordion-item.directive.spec.ts +8 -0
  7. package/accordion/__tests__/accordion-root.directive.spec.ts +8 -0
  8. package/accordion/__tests__/accordion-trigger.directive.spec.ts +8 -0
  9. package/accordion/ng-package.json +5 -0
  10. package/accordion/src/accordion-content.directive.ts +46 -0
  11. package/accordion/src/accordion-header.directive.ts +15 -0
  12. package/accordion/src/accordion-item.directive.ts +216 -0
  13. package/accordion/src/accordion-root.directive.ts +205 -0
  14. package/accordion/src/accordion-trigger.directive.ts +37 -0
  15. package/accordion/stories/accordion.docs.mdx +77 -0
  16. package/accordion/stories/accordion.stories.ts +340 -0
  17. package/alert-dialog/{index.d.ts → index.ts} +1 -0
  18. package/alert-dialog/ng-package.json +5 -0
  19. package/alert-dialog/src/alert-dialog-cancel.directive.ts +17 -0
  20. package/alert-dialog/src/alert-dialog-content.directive.ts +24 -0
  21. package/alert-dialog/src/alert-dialog-root.directive.ts +15 -0
  22. package/alert-dialog/src/alert-dialog-title.directive.ts +7 -0
  23. package/alert-dialog/src/alert-dialog-trigger.directive.ts +17 -0
  24. package/alert-dialog/src/alert-dialog.service.ts +51 -0
  25. package/alert-dialog/stories/alert-dialog.stories.ts +139 -0
  26. package/avatar/__tests__/avatar-fallback.directive.spec.ts +31 -0
  27. package/avatar/__tests__/avatar-image.directive.spec.ts +36 -0
  28. package/avatar/ng-package.json +5 -0
  29. package/avatar/src/avatar-fallback.directive.ts +62 -0
  30. package/avatar/src/avatar-image.directive.ts +55 -0
  31. package/avatar/src/avatar-root.directive.ts +35 -0
  32. package/avatar/src/avatar.config.ts +29 -0
  33. package/avatar/stories/avatar.docs.mdx +37 -0
  34. package/avatar/stories/avatar.stories.ts +87 -0
  35. package/button/__tests__/.gitkeep +0 -0
  36. package/button/src/button-abstract.directive.ts +46 -0
  37. package/checkbox/ng-package.json +5 -0
  38. package/checkbox/src/checkbox-button.directive.ts +26 -0
  39. package/checkbox/src/checkbox-indicator.directive.ts +16 -0
  40. package/checkbox/src/checkbox-input.directive.ts +36 -0
  41. package/checkbox/src/checkbox.directive.ts +146 -0
  42. package/checkbox/src/checkbox.token.ts +8 -0
  43. package/checkbox/stories/checkbox-group.component.ts +87 -0
  44. package/checkbox/stories/checkbox-group.styles.scss +49 -0
  45. package/checkbox/stories/checkbox-indeterminate.component.ts +52 -0
  46. package/checkbox/stories/checkbox.docs.mdx +58 -0
  47. package/checkbox/stories/checkbox.stories.ts +105 -0
  48. package/collapsible/__tests__/collapsible-content.directive.spec.ts +30 -0
  49. package/collapsible/__tests__/collapsible-root.directive.spec.ts +27 -0
  50. package/collapsible/__tests__/collapsible-trigger.directive.spec.ts +30 -0
  51. package/collapsible/ng-package.json +5 -0
  52. package/collapsible/src/collapsible-content.directive.ts +34 -0
  53. package/collapsible/src/collapsible-content.token.ts +6 -0
  54. package/collapsible/src/collapsible-root.directive.ts +120 -0
  55. package/collapsible/src/collapsible-trigger.directive.ts +44 -0
  56. package/collapsible/stories/collapsible-animation.component.ts +116 -0
  57. package/collapsible/stories/collapsible-external-triggering.component.ts +86 -0
  58. package/collapsible/stories/collapsible.docs.mdx +53 -0
  59. package/collapsible/stories/collapsible.stories.ts +151 -0
  60. package/context-menu/README.md +1 -0
  61. package/context-menu/index.ts +10 -0
  62. package/context-menu/ng-package.json +5 -0
  63. package/context-menu/src/context-menu-content.directive.ts +47 -0
  64. package/context-menu/src/context-menu-item-checkbox.directive.ts +30 -0
  65. package/context-menu/src/context-menu-item-indicator.directive.ts +14 -0
  66. package/context-menu/src/context-menu-item-radio-group.directive.ts +31 -0
  67. package/context-menu/src/context-menu-item-radio.directive.ts +69 -0
  68. package/context-menu/src/context-menu-item-selectable.ts +18 -0
  69. package/context-menu/src/context-menu-item.directive.ts +65 -0
  70. package/context-menu/src/context-menu-label.directive.ts +7 -0
  71. package/context-menu/src/context-menu-separator.directive.ts +13 -0
  72. package/context-menu/src/context-menu-trigger.directive.ts +82 -0
  73. package/context-menu/stories/context-menu.docs.mdx +23 -0
  74. package/context-menu/stories/context-menu.stories.ts +253 -0
  75. package/core/index.ts +3 -0
  76. package/core/src/accessor/provide-value-accessor.ts +20 -0
  77. package/core/src/auto-focus.directive.ts +81 -0
  78. package/core/src/inject-ng-control.ts +28 -0
  79. package/core/src/mount.ts +27 -0
  80. package/dialog/README.md +1 -0
  81. package/dialog/__tests__/dialog-content.directive.spec.ts +77 -0
  82. package/dialog/__tests__/dialog-trigger.directive.spec.ts +85 -0
  83. package/dialog/index.ts +31 -0
  84. package/dialog/ng-package.json +5 -0
  85. package/dialog/src/dialog-close.directive.ts +18 -0
  86. package/dialog/src/dialog-content.directive.ts +45 -0
  87. package/dialog/src/dialog-description.directive.ts +7 -0
  88. package/dialog/src/dialog-dismiss.directive.ts +18 -0
  89. package/dialog/src/dialog-ref.ts +70 -0
  90. package/dialog/src/dialog-title.directive.ts +7 -0
  91. package/dialog/src/dialog-trigger.directive.ts +52 -0
  92. package/dialog/src/dialog.config.ts +55 -0
  93. package/dialog/src/dialog.injectors.ts +12 -0
  94. package/dialog/src/dialog.providers.ts +27 -0
  95. package/dialog/src/dialog.service.ts +94 -0
  96. package/dialog/stories/dialog.docs.mdx +32 -0
  97. package/dialog/stories/dialog.stories.ts +233 -0
  98. package/dropdown-menu/ng-package.json +5 -0
  99. package/dropdown-menu/src/dropdown-menu-content.directive.ts +47 -0
  100. package/dropdown-menu/src/dropdown-menu-item-checkbox.directive.ts +30 -0
  101. package/dropdown-menu/src/dropdown-menu-item-indicator.directive.ts +14 -0
  102. package/dropdown-menu/src/dropdown-menu-item-radio-group.directive.ts +31 -0
  103. package/dropdown-menu/src/dropdown-menu-item-radio.directive.ts +72 -0
  104. package/dropdown-menu/src/dropdown-menu-item-selectable.ts +18 -0
  105. package/dropdown-menu/src/dropdown-menu-item.directive.ts +66 -0
  106. package/dropdown-menu/src/dropdown-menu-label.directive.ts +7 -0
  107. package/dropdown-menu/src/dropdown-menu-separator.directive.ts +13 -0
  108. package/dropdown-menu/src/dropdown-menu-trigger.directive.ts +185 -0
  109. package/dropdown-menu/stories/dropdown-menu-item-checkbox.component.ts +104 -0
  110. package/dropdown-menu/stories/dropdown-menu-item-checkbox.styles.scss +106 -0
  111. package/dropdown-menu/stories/dropdown-menu-item-radio.component.ts +95 -0
  112. package/dropdown-menu/stories/dropdown-menu-item-radio.styles.scss +106 -0
  113. package/dropdown-menu/stories/dropdown.docs.mdx +27 -0
  114. package/dropdown-menu/stories/dropdown.stories.ts +212 -0
  115. package/form-field/index.ts +1 -0
  116. package/form-field/src/.gitkeep +0 -0
  117. package/jest.config.ts +21 -0
  118. package/label/__tests__/label-root.directive.spec.ts +99 -0
  119. package/label/ng-package.json +5 -0
  120. package/label/src/label.directive.ts +58 -0
  121. package/label/stories/label.docs.mdx +40 -0
  122. package/label/stories/label.stories.ts +76 -0
  123. package/menu/index.ts +29 -0
  124. package/menu/ng-package.json +5 -0
  125. package/menu/src/menu-content.directive.ts +9 -0
  126. package/menu/src/menu-directive.ts +10 -0
  127. package/menu/src/menu-group.directive.ts +12 -0
  128. package/menu/src/menu-item.directive.ts +44 -0
  129. package/menu/src/menu-label.directive.ts +7 -0
  130. package/menu/src/menu-separator.directive.ts +13 -0
  131. package/menubar/index.ts +38 -0
  132. package/menubar/ng-package.json +5 -0
  133. package/menubar/src/menubar-content.directive.ts +9 -0
  134. package/menubar/src/menubar-item-checkbox.directive.ts +32 -0
  135. package/menubar/src/menubar-item-indicator.directive.ts +10 -0
  136. package/menubar/src/menubar-item-radio.directive.ts +33 -0
  137. package/menubar/src/menubar-item.directive.ts +12 -0
  138. package/menubar/src/menubar-radio-group.directive.ts +9 -0
  139. package/menubar/src/menubar-root.directive.ts +15 -0
  140. package/menubar/src/menubar-separator.directive.ts +9 -0
  141. package/menubar/src/menubar-trigger.directive.ts +40 -0
  142. package/menubar/stories/menubar.stories.ts +229 -0
  143. package/ng-package.json +8 -0
  144. package/package.json +4 -112
  145. package/portal/stories/portal.docs.mdx +85 -0
  146. package/presence/__test__/presence-test.component.ts +51 -0
  147. package/presence/__test__/presence.spec.ts +50 -0
  148. package/presence/index.ts +4 -0
  149. package/presence/src/presence.ts +119 -0
  150. package/presence/src/transitions/transition.collapse.ts +99 -0
  151. package/presence/src/transitions/transition.toast.ts +27 -0
  152. package/presence/src/types.ts +20 -0
  153. package/presence/src/utils.ts +63 -0
  154. package/presence/stories/presence-story.componen.ts +69 -0
  155. package/presence/stories/presence.docs.mdx +40 -0
  156. package/presence/stories/presence.stories.ts +29 -0
  157. package/progress/__test__/progress.spec.ts +55 -0
  158. package/progress/{index.d.ts → index.ts} +1 -0
  159. package/progress/ng-package.json +5 -0
  160. package/progress/src/progress-indicator.directive.ts +26 -0
  161. package/progress/src/progress-root.directive.ts +134 -0
  162. package/progress/stories/progress.docs.mdx +65 -0
  163. package/progress/stories/progress.stories.ts +66 -0
  164. package/project.json +39 -0
  165. package/radio/{index.d.ts → index.ts} +1 -0
  166. package/radio/ng-package.json +5 -0
  167. package/radio/src/radio-indicator.directive.ts +17 -0
  168. package/radio/src/radio-item.directive.ts +68 -0
  169. package/radio/src/radio-root.directive.ts +207 -0
  170. package/radio/src/{radio-tokens.d.ts → radio-tokens.ts} +5 -1
  171. package/radio/stories/radio-group.component.ts +39 -0
  172. package/radio/stories/radio-group.styles.scss +70 -0
  173. package/radio/stories/radio.docs.mdx +68 -0
  174. package/radio/stories/radio.stories.ts +155 -0
  175. package/separator/__tests__/separator.directive.spec.ts +58 -0
  176. package/separator/ng-package.json +5 -0
  177. package/separator/src/separator.directive.ts +35 -0
  178. package/separator/stories/separator.docs.mdx +37 -0
  179. package/separator/stories/separator.stories.ts +82 -0
  180. package/slider/src/slider-input.directive.ts +0 -0
  181. package/slider/src/slider-thumb.directives.ts +60 -0
  182. package/slider/src/slider-track.directive.ts +11 -0
  183. package/slider/src/slider.directive.ts +59 -0
  184. package/slider/src/slider.types.ts +4 -0
  185. package/switch/index.ts +22 -0
  186. package/switch/ng-package.json +5 -0
  187. package/switch/src/switch-input.directive.ts +24 -0
  188. package/switch/src/switch-root.directive.ts +127 -0
  189. package/switch/src/switch-thumb.directive.ts +15 -0
  190. package/switch/stories/switch.docs.mdx +83 -0
  191. package/switch/stories/switch.stories.ts +149 -0
  192. package/tabs/__tests__/tabs-context.service.spec.ts +35 -0
  193. package/tabs/index.ts +26 -0
  194. package/tabs/ng-package.json +5 -0
  195. package/tabs/src/tabs-content.directive.ts +23 -0
  196. package/tabs/src/tabs-context.service.ts +43 -0
  197. package/tabs/src/tabs-list.directive.ts +21 -0
  198. package/tabs/src/tabs-root.directive.ts +70 -0
  199. package/tabs/src/tabs-trigger.directive.ts +55 -0
  200. package/tabs/stories/tabs.stories.ts +213 -0
  201. package/test-setup.ts +1 -0
  202. package/toggle/__tests__/toggle.directive.spec.ts +87 -0
  203. package/toggle/ng-package.json +5 -0
  204. package/toggle/src/toggle.directive.ts +49 -0
  205. package/toggle/stories/toggle.docs.mdx +60 -0
  206. package/toggle/stories/toggle.stories.ts +84 -0
  207. package/toggle-group/ng-package.json +5 -0
  208. package/toggle-group/src/toggle-group-button.directive.ts +73 -0
  209. package/toggle-group/src/toggle-group-button.token.ts +8 -0
  210. package/toggle-group/src/toggle-group-multi.directive.ts +158 -0
  211. package/toggle-group/src/toggle-group.directive.ts +148 -0
  212. package/toggle-group/src/toggle-group.token.ts +11 -0
  213. package/toggle-group/stories/toggle-group.docs.mdx +87 -0
  214. package/toggle-group/stories/toggle-group.stories.ts +95 -0
  215. package/tsconfig.doc.json +11 -0
  216. package/tsconfig.json +29 -0
  217. package/tsconfig.lib.json +19 -0
  218. package/tsconfig.lib.prod.json +12 -0
  219. package/tsconfig.spec.json +11 -0
  220. package/visually-hidden/README.md +3 -0
  221. package/visually-hidden/stories/visually-hidden.docs.mdx +36 -0
  222. package/accordion/src/accordion-content.directive.d.ts +0 -16
  223. package/accordion/src/accordion-header.directive.d.ts +0 -7
  224. package/accordion/src/accordion-item.directive.d.ts +0 -62
  225. package/accordion/src/accordion-root.directive.d.ts +0 -78
  226. package/accordion/src/accordion-trigger.directive.d.ts +0 -15
  227. package/alert-dialog/src/alert-dialog-cancel.directive.d.ts +0 -7
  228. package/alert-dialog/src/alert-dialog-content.directive.d.ts +0 -9
  229. package/alert-dialog/src/alert-dialog-root.directive.d.ts +0 -9
  230. package/alert-dialog/src/alert-dialog-title.directive.d.ts +0 -5
  231. package/alert-dialog/src/alert-dialog-trigger.directive.d.ts +0 -7
  232. package/alert-dialog/src/alert-dialog.service.d.ts +0 -14
  233. package/avatar/src/avatar-fallback.directive.d.ts +0 -27
  234. package/avatar/src/avatar-image.directive.d.ts +0 -16
  235. package/avatar/src/avatar-root.directive.d.ts +0 -21
  236. package/avatar/src/avatar.config.d.ts +0 -13
  237. package/checkbox/src/checkbox-button.directive.d.ts +0 -8
  238. package/checkbox/src/checkbox-indicator.directive.d.ts +0 -6
  239. package/checkbox/src/checkbox-input.directive.d.ts +0 -9
  240. package/checkbox/src/checkbox.directive.d.ts +0 -75
  241. package/checkbox/src/checkbox.token.d.ts +0 -4
  242. package/collapsible/src/collapsible-content.directive.d.ts +0 -17
  243. package/collapsible/src/collapsible-content.token.d.ts +0 -3
  244. package/collapsible/src/collapsible-root.directive.d.ts +0 -55
  245. package/collapsible/src/collapsible-trigger.directive.d.ts +0 -26
  246. package/compodoc/documentation.json +0 -11395
  247. package/dropdown-menu/src/dropdown-menu-content.directive.d.ts +0 -15
  248. package/dropdown-menu/src/dropdown-menu-item-checkbox.directive.d.ts +0 -9
  249. package/dropdown-menu/src/dropdown-menu-item-indicator.directive.d.ts +0 -7
  250. package/dropdown-menu/src/dropdown-menu-item-radio-group.directive.d.ts +0 -12
  251. package/dropdown-menu/src/dropdown-menu-item-radio.directive.d.ts +0 -19
  252. package/dropdown-menu/src/dropdown-menu-item-selectable.d.ts +0 -12
  253. package/dropdown-menu/src/dropdown-menu-item.directive.d.ts +0 -17
  254. package/dropdown-menu/src/dropdown-menu-label.directive.d.ts +0 -5
  255. package/dropdown-menu/src/dropdown-menu-separator.directive.d.ts +0 -6
  256. package/dropdown-menu/src/dropdown-menu-trigger.directive.d.ts +0 -43
  257. package/esm2022/accordion/index.mjs +0 -6
  258. package/esm2022/accordion/radix-ng-primitives-accordion.mjs +0 -5
  259. package/esm2022/accordion/src/accordion-content.directive.mjs +0 -36
  260. package/esm2022/accordion/src/accordion-header.directive.mjs +0 -23
  261. package/esm2022/accordion/src/accordion-item.directive.mjs +0 -170
  262. package/esm2022/accordion/src/accordion-root.directive.mjs +0 -157
  263. package/esm2022/accordion/src/accordion-trigger.directive.mjs +0 -42
  264. package/esm2022/alert-dialog/index.mjs +0 -7
  265. package/esm2022/alert-dialog/radix-ng-primitives-alert-dialog.mjs +0 -5
  266. package/esm2022/alert-dialog/src/alert-dialog-cancel.directive.mjs +0 -24
  267. package/esm2022/alert-dialog/src/alert-dialog-content.directive.mjs +0 -34
  268. package/esm2022/alert-dialog/src/alert-dialog-root.directive.mjs +0 -25
  269. package/esm2022/alert-dialog/src/alert-dialog-title.directive.mjs +0 -14
  270. package/esm2022/alert-dialog/src/alert-dialog-trigger.directive.mjs +0 -24
  271. package/esm2022/alert-dialog/src/alert-dialog.service.mjs +0 -47
  272. package/esm2022/avatar/index.mjs +0 -5
  273. package/esm2022/avatar/radix-ng-primitives-avatar.mjs +0 -5
  274. package/esm2022/avatar/src/avatar-fallback.directive.mjs +0 -54
  275. package/esm2022/avatar/src/avatar-image.directive.mjs +0 -48
  276. package/esm2022/avatar/src/avatar-root.directive.mjs +0 -38
  277. package/esm2022/avatar/src/avatar.config.mjs +0 -17
  278. package/esm2022/checkbox/index.mjs +0 -6
  279. package/esm2022/checkbox/radix-ng-primitives-checkbox.mjs +0 -5
  280. package/esm2022/checkbox/src/checkbox-button.directive.mjs +0 -33
  281. package/esm2022/checkbox/src/checkbox-indicator.directive.mjs +0 -24
  282. package/esm2022/checkbox/src/checkbox-input.directive.mjs +0 -41
  283. package/esm2022/checkbox/src/checkbox.directive.mjs +0 -141
  284. package/esm2022/checkbox/src/checkbox.token.mjs +0 -6
  285. package/esm2022/collapsible/index.mjs +0 -4
  286. package/esm2022/collapsible/radix-ng-primitives-collapsible.mjs +0 -5
  287. package/esm2022/collapsible/src/collapsible-content.directive.mjs +0 -45
  288. package/esm2022/collapsible/src/collapsible-content.token.mjs +0 -3
  289. package/esm2022/collapsible/src/collapsible-root.directive.mjs +0 -118
  290. package/esm2022/collapsible/src/collapsible-trigger.directive.mjs +0 -49
  291. package/esm2022/dropdown-menu/index.mjs +0 -11
  292. package/esm2022/dropdown-menu/radix-ng-primitives-dropdown-menu.mjs +0 -5
  293. package/esm2022/dropdown-menu/src/dropdown-menu-content.directive.mjs +0 -56
  294. package/esm2022/dropdown-menu/src/dropdown-menu-item-checkbox.directive.mjs +0 -36
  295. package/esm2022/dropdown-menu/src/dropdown-menu-item-indicator.directive.mjs +0 -22
  296. package/esm2022/dropdown-menu/src/dropdown-menu-item-radio-group.directive.mjs +0 -37
  297. package/esm2022/dropdown-menu/src/dropdown-menu-item-radio.directive.mjs +0 -64
  298. package/esm2022/dropdown-menu/src/dropdown-menu-item-selectable.mjs +0 -31
  299. package/esm2022/dropdown-menu/src/dropdown-menu-item.directive.mjs +0 -71
  300. package/esm2022/dropdown-menu/src/dropdown-menu-label.directive.mjs +0 -14
  301. package/esm2022/dropdown-menu/src/dropdown-menu-separator.directive.mjs +0 -21
  302. package/esm2022/dropdown-menu/src/dropdown-menu-trigger.directive.mjs +0 -176
  303. package/esm2022/index.mjs +0 -2
  304. package/esm2022/label/index.mjs +0 -2
  305. package/esm2022/label/radix-ng-primitives-label.mjs +0 -5
  306. package/esm2022/label/src/label.directive.mjs +0 -59
  307. package/esm2022/menu/index.mjs +0 -45
  308. package/esm2022/menu/radix-ng-primitives-menu.mjs +0 -5
  309. package/esm2022/menu/src/menu-content.directive.mjs +0 -17
  310. package/esm2022/menu/src/menu-directive.mjs +0 -18
  311. package/esm2022/menu/src/menu-group.directive.mjs +0 -20
  312. package/esm2022/menu/src/menu-item.directive.mjs +0 -46
  313. package/esm2022/menu/src/menu-label.directive.mjs +0 -14
  314. package/esm2022/menu/src/menu-separator.directive.mjs +0 -21
  315. package/esm2022/menubar/index.mjs +0 -60
  316. package/esm2022/menubar/radix-ng-primitives-menubar.mjs +0 -5
  317. package/esm2022/menubar/src/menubar-content.directive.mjs +0 -17
  318. package/esm2022/menubar/src/menubar-item-checkbox.directive.mjs +0 -34
  319. package/esm2022/menubar/src/menubar-item-indicator.directive.mjs +0 -17
  320. package/esm2022/menubar/src/menubar-item-radio.directive.mjs +0 -35
  321. package/esm2022/menubar/src/menubar-item.directive.mjs +0 -20
  322. package/esm2022/menubar/src/menubar-radio-group.directive.mjs +0 -17
  323. package/esm2022/menubar/src/menubar-root.directive.mjs +0 -24
  324. package/esm2022/menubar/src/menubar-separator.directive.mjs +0 -17
  325. package/esm2022/menubar/src/menubar-trigger.directive.mjs +0 -45
  326. package/esm2022/progress/index.mjs +0 -3
  327. package/esm2022/progress/radix-ng-primitives-progress.mjs +0 -5
  328. package/esm2022/progress/src/progress-indicator.directive.mjs +0 -34
  329. package/esm2022/progress/src/progress-root.directive.mjs +0 -127
  330. package/esm2022/radio/index.mjs +0 -4
  331. package/esm2022/radio/radix-ng-primitives-radio.mjs +0 -5
  332. package/esm2022/radio/src/radio-indicator.directive.mjs +0 -25
  333. package/esm2022/radio/src/radio-item.directive.mjs +0 -70
  334. package/esm2022/radio/src/radio-root.directive.mjs +0 -194
  335. package/esm2022/radio/src/radio-tokens.mjs +0 -3
  336. package/esm2022/radix-ng-primitives.mjs +0 -5
  337. package/esm2022/separator/index.mjs +0 -2
  338. package/esm2022/separator/radix-ng-primitives-separator.mjs +0 -5
  339. package/esm2022/separator/src/separator.directive.mjs +0 -31
  340. package/esm2022/switch/index.mjs +0 -30
  341. package/esm2022/switch/radix-ng-primitives-switch.mjs +0 -5
  342. package/esm2022/switch/src/switch-input.directive.mjs +0 -32
  343. package/esm2022/switch/src/switch-root.directive.mjs +0 -95
  344. package/esm2022/switch/src/switch-thumb.directive.mjs +0 -23
  345. package/esm2022/tabs/index.mjs +0 -38
  346. package/esm2022/tabs/radix-ng-primitives-tabs.mjs +0 -5
  347. package/esm2022/tabs/src/tabs-content.directive.mjs +0 -29
  348. package/esm2022/tabs/src/tabs-context.service.mjs +0 -43
  349. package/esm2022/tabs/src/tabs-list.directive.mjs +0 -23
  350. package/esm2022/tabs/src/tabs-root.directive.mjs +0 -54
  351. package/esm2022/tabs/src/tabs-trigger.directive.mjs +0 -52
  352. package/esm2022/toggle/index.mjs +0 -2
  353. package/esm2022/toggle/radix-ng-primitives-toggle.mjs +0 -5
  354. package/esm2022/toggle/src/toggle.directive.mjs +0 -39
  355. package/esm2022/toggle-group/index.mjs +0 -6
  356. package/esm2022/toggle-group/radix-ng-primitives-toggle-group.mjs +0 -5
  357. package/esm2022/toggle-group/src/toggle-group-button.directive.mjs +0 -75
  358. package/esm2022/toggle-group/src/toggle-group-button.token.mjs +0 -6
  359. package/esm2022/toggle-group/src/toggle-group-multi.directive.mjs +0 -143
  360. package/esm2022/toggle-group/src/toggle-group.directive.mjs +0 -134
  361. package/esm2022/toggle-group/src/toggle-group.token.mjs +0 -6
  362. package/fesm2022/radix-ng-primitives-accordion.mjs +0 -418
  363. package/fesm2022/radix-ng-primitives-accordion.mjs.map +0 -1
  364. package/fesm2022/radix-ng-primitives-alert-dialog.mjs +0 -161
  365. package/fesm2022/radix-ng-primitives-alert-dialog.mjs.map +0 -1
  366. package/fesm2022/radix-ng-primitives-avatar.mjs +0 -156
  367. package/fesm2022/radix-ng-primitives-avatar.mjs.map +0 -1
  368. package/fesm2022/radix-ng-primitives-checkbox.mjs +0 -241
  369. package/fesm2022/radix-ng-primitives-checkbox.mjs.map +0 -1
  370. package/fesm2022/radix-ng-primitives-collapsible.mjs +0 -213
  371. package/fesm2022/radix-ng-primitives-collapsible.mjs.map +0 -1
  372. package/fesm2022/radix-ng-primitives-dropdown-menu.mjs +0 -502
  373. package/fesm2022/radix-ng-primitives-dropdown-menu.mjs.map +0 -1
  374. package/fesm2022/radix-ng-primitives-label.mjs +0 -66
  375. package/fesm2022/radix-ng-primitives-label.mjs.map +0 -1
  376. package/fesm2022/radix-ng-primitives-menu.mjs +0 -158
  377. package/fesm2022/radix-ng-primitives-menu.mjs.map +0 -1
  378. package/fesm2022/radix-ng-primitives-menubar.mjs +0 -245
  379. package/fesm2022/radix-ng-primitives-menubar.mjs.map +0 -1
  380. package/fesm2022/radix-ng-primitives-progress.mjs +0 -165
  381. package/fesm2022/radix-ng-primitives-progress.mjs.map +0 -1
  382. package/fesm2022/radix-ng-primitives-radio.mjs +0 -289
  383. package/fesm2022/radix-ng-primitives-radio.mjs.map +0 -1
  384. package/fesm2022/radix-ng-primitives-separator.mjs +0 -38
  385. package/fesm2022/radix-ng-primitives-separator.mjs.map +0 -1
  386. package/fesm2022/radix-ng-primitives-switch.mjs +0 -173
  387. package/fesm2022/radix-ng-primitives-switch.mjs.map +0 -1
  388. package/fesm2022/radix-ng-primitives-tabs.mjs +0 -222
  389. package/fesm2022/radix-ng-primitives-tabs.mjs.map +0 -1
  390. package/fesm2022/radix-ng-primitives-toggle-group.mjs +0 -358
  391. package/fesm2022/radix-ng-primitives-toggle-group.mjs.map +0 -1
  392. package/fesm2022/radix-ng-primitives-toggle.mjs +0 -46
  393. package/fesm2022/radix-ng-primitives-toggle.mjs.map +0 -1
  394. package/fesm2022/radix-ng-primitives.mjs +0 -4
  395. package/fesm2022/radix-ng-primitives.mjs.map +0 -1
  396. package/label/src/label.directive.d.ts +0 -29
  397. package/menu/index.d.ts +0 -18
  398. package/menu/src/menu-content.directive.d.ts +0 -6
  399. package/menu/src/menu-directive.d.ts +0 -6
  400. package/menu/src/menu-group.directive.d.ts +0 -6
  401. package/menu/src/menu-item.directive.d.ts +0 -12
  402. package/menu/src/menu-label.directive.d.ts +0 -5
  403. package/menu/src/menu-separator.directive.d.ts +0 -6
  404. package/menubar/index.d.ts +0 -24
  405. package/menubar/src/menubar-content.directive.d.ts +0 -6
  406. package/menubar/src/menubar-item-checkbox.directive.d.ts +0 -14
  407. package/menubar/src/menubar-item-indicator.directive.d.ts +0 -5
  408. package/menubar/src/menubar-item-radio.directive.d.ts +0 -14
  409. package/menubar/src/menubar-item.directive.d.ts +0 -8
  410. package/menubar/src/menubar-radio-group.directive.d.ts +0 -6
  411. package/menubar/src/menubar-root.directive.d.ts +0 -7
  412. package/menubar/src/menubar-separator.directive.d.ts +0 -6
  413. package/menubar/src/menubar-trigger.directive.d.ts +0 -11
  414. package/progress/src/progress-indicator.directive.d.ts +0 -16
  415. package/progress/src/progress-root.directive.d.ts +0 -63
  416. package/radio/src/radio-indicator.directive.d.ts +0 -9
  417. package/radio/src/radio-item.directive.d.ts +0 -21
  418. package/radio/src/radio-root.directive.d.ts +0 -72
  419. package/separator/src/separator.directive.d.ts +0 -22
  420. package/switch/index.d.ts +0 -13
  421. package/switch/src/switch-input.directive.d.ts +0 -6
  422. package/switch/src/switch-root.directive.d.ts +0 -51
  423. package/switch/src/switch-thumb.directive.d.ts +0 -6
  424. package/tabs/index.d.ts +0 -15
  425. package/tabs/src/tabs-content.directive.d.ts +0 -8
  426. package/tabs/src/tabs-context.service.d.ts +0 -22
  427. package/tabs/src/tabs-list.directive.d.ts +0 -6
  428. package/tabs/src/tabs-root.directive.d.ts +0 -37
  429. package/tabs/src/tabs-trigger.directive.d.ts +0 -19
  430. package/toggle/src/toggle.directive.d.ts +0 -30
  431. package/toggle-group/src/toggle-group-button.directive.d.ts +0 -39
  432. package/toggle-group/src/toggle-group-button.token.d.ts +0 -4
  433. package/toggle-group/src/toggle-group-multi.directive.d.ts +0 -93
  434. package/toggle-group/src/toggle-group.directive.d.ts +0 -84
  435. package/toggle-group/src/toggle-group.token.d.ts +0 -5
  436. /package/accordion/{index.d.ts → index.ts} +0 -0
  437. /package/avatar/{index.d.ts → index.ts} +0 -0
  438. /package/checkbox/{index.d.ts → index.ts} +0 -0
  439. /package/collapsible/{index.d.ts → index.ts} +0 -0
  440. /package/dropdown-menu/{index.d.ts → index.ts} +0 -0
  441. /package/{index.d.ts → index.ts} +0 -0
  442. /package/label/{index.d.ts → index.ts} +0 -0
  443. /package/separator/{index.d.ts → index.ts} +0 -0
  444. /package/toggle/{index.d.ts → index.ts} +0 -0
  445. /package/toggle-group/{index.d.ts → index.ts} +0 -0
@@ -0,0 +1,205 @@
1
+ import { FocusKeyManager } from '@angular/cdk/a11y';
2
+ import { Directionality } from '@angular/cdk/bidi';
3
+ import { UniqueSelectionDispatcher } from '@angular/cdk/collections';
4
+ import { ENTER, SPACE } from '@angular/cdk/keycodes';
5
+ import {
6
+ AfterContentInit,
7
+ booleanAttribute,
8
+ ContentChildren,
9
+ Directive,
10
+ EventEmitter,
11
+ forwardRef,
12
+ inject,
13
+ InjectionToken,
14
+ Input,
15
+ OnDestroy,
16
+ Output,
17
+ QueryList
18
+ } from '@angular/core';
19
+ import { merge, Subject, Subscription } from 'rxjs';
20
+ import { RdxAccordionItemDirective } from './accordion-item.directive';
21
+
22
+ export type RdxAccordionType = 'single' | 'multiple';
23
+ export type RdxAccordionOrientation = 'horizontal' | 'vertical';
24
+
25
+ export const RdxAccordionRootToken = new InjectionToken<RdxAccordionRootDirective>('RdxAccordionRootDirective');
26
+
27
+ let nextId = 0;
28
+
29
+ @Directive({
30
+ selector: '[rdxAccordionRoot]',
31
+ standalone: true,
32
+ providers: [
33
+ { provide: RdxAccordionRootToken, useExisting: RdxAccordionRootDirective },
34
+ { provide: UniqueSelectionDispatcher, useClass: UniqueSelectionDispatcher }
35
+ ],
36
+ host: {
37
+ '[attr.data-orientation]': 'orientation',
38
+ '(keydown)': 'handleKeydown($event)'
39
+ }
40
+ })
41
+ export class RdxAccordionRootDirective implements AfterContentInit, OnDestroy {
42
+ /**
43
+ * @ignore
44
+ */
45
+ protected readonly selectionDispatcher = inject(UniqueSelectionDispatcher);
46
+ /**
47
+ * @ignore
48
+ */
49
+ protected readonly dir = inject(Directionality, { optional: true });
50
+
51
+ /**
52
+ * @ignore
53
+ */
54
+ protected keyManager: FocusKeyManager<RdxAccordionItemDirective>;
55
+
56
+ /**
57
+ * @ignore
58
+ */
59
+ readonly id: string = `rdx-accordion-${nextId++}`;
60
+
61
+ /**
62
+ * @ignore
63
+ */
64
+ readonly openCloseAllActions = new Subject<boolean>();
65
+
66
+ get isMultiple(): boolean {
67
+ return this.type === 'multiple';
68
+ }
69
+
70
+ /** Whether the Accordion is disabled. */
71
+ @Input({ transform: booleanAttribute }) disabled: boolean;
72
+
73
+ /**
74
+ * The orientation of the accordion.
75
+ */
76
+ @Input() orientation: RdxAccordionOrientation = 'vertical';
77
+ /**
78
+ * @private
79
+ * @ignore
80
+ */
81
+ @ContentChildren(forwardRef(() => RdxAccordionItemDirective), { descendants: true })
82
+ items: QueryList<RdxAccordionItemDirective>;
83
+
84
+ /**
85
+ * The value of the item to expand when initially rendered and type is "single". Use when you do not need to control the state of the items.
86
+ */
87
+ @Input()
88
+ set defaultValue(value: string[] | string) {
89
+ if (value !== this._defaultValue) {
90
+ this._defaultValue = Array.isArray(value) ? value : [value];
91
+ }
92
+ }
93
+
94
+ get defaultValue(): string[] | string {
95
+ return this.isMultiple ? this._defaultValue : this._defaultValue[0];
96
+ }
97
+
98
+ /**
99
+ * Determines whether one or multiple items can be opened at the same time.
100
+ */
101
+ @Input() type: RdxAccordionType = 'single';
102
+ /**
103
+ * @ignore
104
+ */
105
+ @Input() collapsible = true;
106
+ /**
107
+ * The controlled value of the item to expand
108
+ */
109
+ @Input()
110
+ set value(value: string[] | string) {
111
+ if (value !== this._value) {
112
+ this._value = Array.isArray(value) ? value : [value];
113
+
114
+ this.selectionDispatcher.notify(this.value as unknown as string, this.id);
115
+ }
116
+ }
117
+
118
+ get value(): string[] | string {
119
+ if (this._value === undefined) {
120
+ return this.defaultValue;
121
+ }
122
+
123
+ return this.isMultiple ? this._value : this._value[0];
124
+ }
125
+
126
+ @Output() readonly onValueChange: EventEmitter<void> = new EventEmitter<void>();
127
+
128
+ private _value?: string[];
129
+ private _defaultValue: string[] | string = [];
130
+
131
+ private onValueChangeSubscription: Subscription;
132
+
133
+ /**
134
+ * @ignore
135
+ */
136
+ ngAfterContentInit(): void {
137
+ this.selectionDispatcher.notify((this._value ?? this._defaultValue) as unknown as string, this.id);
138
+
139
+ this.keyManager = new FocusKeyManager(this.items).withHomeAndEnd();
140
+
141
+ if (this.orientation === 'horizontal') {
142
+ this.keyManager.withHorizontalOrientation(this.dir?.value || 'ltr');
143
+ } else {
144
+ this.keyManager.withVerticalOrientation();
145
+ }
146
+
147
+ this.onValueChangeSubscription = merge(...this.items.map((item) => item.expandedChange)).subscribe(() =>
148
+ this.onValueChange.emit()
149
+ );
150
+ }
151
+
152
+ /**
153
+ * @ignore
154
+ */
155
+ ngOnDestroy() {
156
+ this.openCloseAllActions.complete();
157
+ this.onValueChangeSubscription.unsubscribe();
158
+ }
159
+
160
+ /**
161
+ * @ignore
162
+ */
163
+ handleKeydown(event: KeyboardEvent) {
164
+ if (!this.keyManager.activeItem) {
165
+ this.keyManager.setFirstItemActive();
166
+ }
167
+
168
+ const activeItem = this.keyManager.activeItem;
169
+
170
+ if (
171
+ (event.keyCode === ENTER || event.keyCode === SPACE) &&
172
+ !this.keyManager.isTyping() &&
173
+ activeItem &&
174
+ !activeItem.disabled
175
+ ) {
176
+ event.preventDefault();
177
+ activeItem.toggle();
178
+ } else {
179
+ this.keyManager.onKeydown(event);
180
+ }
181
+ }
182
+
183
+ /** Opens all enabled accordion items in an accordion where multi is enabled.
184
+ * @ignore
185
+ */
186
+ openAll(): void {
187
+ if (this.isMultiple) {
188
+ this.openCloseAllActions.next(true);
189
+ }
190
+ }
191
+
192
+ /** Closes all enabled accordion items.
193
+ * @ignore
194
+ */
195
+ closeAll(): void {
196
+ this.openCloseAllActions.next(false);
197
+ }
198
+
199
+ /**
200
+ * @ignore
201
+ */
202
+ setActiveItem(item: RdxAccordionItemDirective) {
203
+ this.keyManager.setActiveItem(item);
204
+ }
205
+ }
@@ -0,0 +1,37 @@
1
+ import { Directive, ElementRef, inject } from '@angular/core';
2
+ import { RdxAccordionItemDirective } from './accordion-item.directive';
3
+ import { RdxAccordionRootDirective } from './accordion-root.directive';
4
+
5
+ @Directive({
6
+ selector: '[rdxAccordionTrigger]',
7
+ standalone: true,
8
+ host: {
9
+ '[attr.role]': '"button"',
10
+ '[attr.aria-expanded]': 'item.expanded',
11
+ '[attr.data-state]': 'item.dataState',
12
+ '[attr.data-disabled]': 'item.disabled',
13
+ '[attr.disabled]': 'item.disabled ? "" : null',
14
+ '[attr.data-orientation]': 'item.orientation',
15
+ '(click)': 'onClick()'
16
+ }
17
+ })
18
+ export class RdxAccordionTriggerDirective {
19
+ protected readonly nativeElement = inject(ElementRef).nativeElement;
20
+ protected readonly accordionRoot = inject(RdxAccordionRootDirective);
21
+ protected readonly item = inject(RdxAccordionItemDirective);
22
+
23
+ /**
24
+ * Fires when trigger clicked
25
+ */
26
+ onClick(): void {
27
+ if (!this.accordionRoot.collapsible && this.item.expanded) return;
28
+
29
+ this.item.toggle();
30
+
31
+ this.accordionRoot.setActiveItem(this.item);
32
+ }
33
+
34
+ focus() {
35
+ this.nativeElement.focus();
36
+ }
37
+ }
@@ -0,0 +1,77 @@
1
+ import { ArgTypes, Canvas, Meta } from '@storybook/blocks';
2
+ import * as AccordionStories from './accordion.stories';
3
+ import { RdxAccordionRootDirective } from '../src/accordion-root.directive';
4
+ import { RdxAccordionItemDirective } from '../src/accordion-item.directive';
5
+ import { RdxAccordionTriggerDirective } from '../src/accordion-trigger.directive';
6
+ import { RdxAccordionContentDirective } from '../src/accordion-content.directive';
7
+
8
+ <Meta title="Primitives/Accordion" />
9
+
10
+ # Accordion
11
+
12
+ #### A vertically stacked set of interactive headings that each reveal an associated section of content.
13
+
14
+ ## Single
15
+
16
+ <Canvas sourceState="hidden" of={AccordionStories.Default} />
17
+
18
+ ## Multiple
19
+
20
+ <Canvas sourceState="hidden" of={AccordionStories.Multiple} />
21
+
22
+ ## Horizontal
23
+
24
+ <Canvas sourceState="hidden" of={AccordionStories.Horizontal} />
25
+
26
+ ## Features
27
+
28
+ - ✅ Full keyboard navigation.
29
+ - ✅ Supports horizontal/vertical orientation.
30
+ - ✅ Supports Right to Left direction.
31
+ - ✅ Can expand one or multiple items.
32
+ - ✅ Can be controlled or uncontrolled.
33
+
34
+ ## Anatomy
35
+
36
+ ```html
37
+ <div rdxAccordionRoot>
38
+ <div rdxAccordionItem>
39
+ <div rdxAccordionHeader>
40
+ <button rdxAccordionTrigger></button>
41
+ </div>
42
+ <div rdxAccordionContent></div>
43
+ </div>
44
+ </div>
45
+ ```
46
+
47
+ ## Import
48
+
49
+ Get started with importing the directives:
50
+
51
+ ```typescript
52
+ import {
53
+ RdxAccordionRootDirective,
54
+ RdxAccordionItemDirective,
55
+ RdxAccordionHeaderDirective,
56
+ RdxAccordionTriggerDirective,
57
+ RdxAccordionContentDirective
58
+ } from '@radix-ng/primitives/accordion';
59
+ ```
60
+
61
+ ## API Reference
62
+
63
+ ## RdxAccordionRootDirective
64
+
65
+ <ArgTypes of={RdxAccordionRootDirective} />
66
+
67
+ ## RdxAccordionItemDirective
68
+
69
+ <ArgTypes of={RdxAccordionItemDirective} />
70
+
71
+ ## RdxAccordionTriggerDirective
72
+
73
+ <ArgTypes of={RdxAccordionTriggerDirective} />
74
+
75
+ ## RdxAccordionContentDirective
76
+
77
+ <ArgTypes of={RdxAccordionContentDirective} />
@@ -0,0 +1,340 @@
1
+ import { BrowserAnimationsModule, provideAnimations } from '@angular/platform-browser/animations';
2
+ import { componentWrapperDecorator, Meta, moduleMetadata, StoryObj } from '@storybook/angular';
3
+ import { ChevronDown, LucideAngularModule } from 'lucide-angular';
4
+ import { RdxAccordionContentDirective } from '../src/accordion-content.directive';
5
+ import { RdxAccordionHeaderDirective } from '../src/accordion-header.directive';
6
+ import { RdxAccordionItemDirective } from '../src/accordion-item.directive';
7
+ import { RdxAccordionRootDirective } from '../src/accordion-root.directive';
8
+ import { RdxAccordionTriggerDirective } from '../src/accordion-trigger.directive';
9
+
10
+ export default {
11
+ title: 'Primitives/Accordion',
12
+ decorators: [
13
+ moduleMetadata({
14
+ imports: [
15
+ RdxAccordionRootDirective,
16
+ RdxAccordionItemDirective,
17
+ RdxAccordionHeaderDirective,
18
+ RdxAccordionTriggerDirective,
19
+ RdxAccordionContentDirective,
20
+ BrowserAnimationsModule,
21
+ LucideAngularModule,
22
+ LucideAngularModule.pick({ ChevronDown })
23
+ ],
24
+ providers: [provideAnimations()]
25
+ }),
26
+ componentWrapperDecorator(
27
+ (story) => `
28
+ <div class="radix-themes light light-theme radix-themes-default-fonts"
29
+ data-accent-color="indigo"
30
+ data-radius="medium"
31
+ data-scaling="100%"
32
+ >
33
+ ${story}
34
+ </div>
35
+
36
+ <style>
37
+ /* reset */
38
+ button,
39
+ h3 {
40
+ all: unset;
41
+ }
42
+
43
+ .AccordionRoot {
44
+ border-radius: 6px;
45
+ background-color: var(--mauve-6);
46
+ box-shadow: 0 2px 10px var(--black-a4);
47
+ }
48
+
49
+ .AccordionRoot[data-orientation="vertical"] {
50
+ width: 300px;
51
+ }
52
+
53
+ .AccordionRoot[data-orientation="horizontal"] {
54
+ height: 300px;
55
+
56
+ display: flex;
57
+ flex-direction: row;
58
+ }
59
+
60
+ .AccordionItem {
61
+ overflow: hidden;
62
+ margin-top: 1px;
63
+ }
64
+
65
+ .AccordionItem[data-orientation="horizontal"] {
66
+ display: flex;
67
+ }
68
+
69
+ .AccordionItem[data-orientation="vertical"]:first-child {
70
+ margin-top: 0;
71
+ border-top-left-radius: 4px;
72
+ border-top-right-radius: 4px;
73
+ }
74
+
75
+ .AccordionItem[data-orientation="vertical"]:last-child {
76
+ border-bottom-left-radius: 4px;
77
+ border-bottom-right-radius: 4px;
78
+ }
79
+
80
+ .AccordionItem[data-orientation="horizontal"]:first-child {
81
+ margin-top: 0;
82
+ border-top-left-radius: 4px;
83
+ border-bottom-left-radius: 4px;
84
+ }
85
+
86
+ .AccordionItem[data-orientation="horizontal"]:last-child {
87
+ border-top-right-radius: 4px;
88
+ border-bottom-right-radius: 4px;
89
+ }
90
+
91
+ .AccordionItem:focus-within {
92
+ position: relative;
93
+ z-index: 1;
94
+ box-shadow: 0 0 0 2px var(--mauve-12);
95
+ }
96
+
97
+ .AccordionHeader {
98
+ display: flex;
99
+ }
100
+
101
+ .AccordionTrigger {
102
+ font-family: inherit;
103
+ padding: 0 20px;
104
+ height: 45px;
105
+ flex: 1;
106
+ display: flex;
107
+ align-items: center;
108
+ justify-content: space-between;
109
+ font-size: 15px;
110
+ line-height: 1;
111
+ color: var(--violet-11);
112
+ box-shadow: 0 1px 0 var(--mauve-6);
113
+ background-color: white;
114
+ cursor: default;
115
+ }
116
+
117
+ .AccordionTrigger[data-orientation="horizontal"] {
118
+ height: 100%;
119
+ padding: 20px;
120
+ writing-mode: vertical-rl;
121
+ }
122
+
123
+ .AccordionTrigger[data-disabled="true"] {
124
+ color: var(--gray-7);
125
+ }
126
+
127
+ .AccordionTrigger:hover {
128
+ background-color: var(--mauve-2);
129
+ }
130
+
131
+ .AccordionContent {
132
+ display: flex;
133
+ overflow: hidden;
134
+ font-size: 15px;
135
+ color: var(--mauve-11);
136
+ background-color: var(--mauve-2);
137
+ }
138
+ .AccordionContent[data-orientation='vertical'][data-state='open'] {
139
+ animation: slideDown 300ms cubic-bezier(0.87, 0, 0.13, 1);
140
+ }
141
+ .AccordionContent[data-orientation='vertical'][data-state='closed'] {
142
+ animation: slideUp 300ms cubic-bezier(0.87, 0, 0.13, 1);
143
+ }
144
+
145
+ .AccordionContent[data-orientation='horizontal'][data-state='open'] {
146
+ animation: slideRight 300ms cubic-bezier(0.87, 0, 0.13, 1);
147
+ }
148
+ .AccordionContent[data-orientation='horizontal'][data-state='closed'] {
149
+ animation: slideLeft 300ms cubic-bezier(0.87, 0, 0.13, 1);
150
+ }
151
+
152
+ .AccordionContentText {
153
+ padding: 15px 20px;
154
+ }
155
+
156
+ .AccordionChevron {
157
+ display: flex;
158
+ color: var(--violet-10);
159
+ transition: transform 300ms cubic-bezier(0.87, 0, 0.13, 1);
160
+ }
161
+ .AccordionTrigger[data-state='open'] > .AccordionChevron {
162
+ transform: rotate(180deg);
163
+ }
164
+
165
+ .horizontal-flex-container {
166
+ display: flex;
167
+ }
168
+
169
+ @keyframes slideDown {
170
+ from {
171
+ height: 0;
172
+ }
173
+ to {
174
+ height: var(--radix-accordion-content-height);
175
+ }
176
+ }
177
+
178
+ @keyframes slideUp {
179
+ from {
180
+ height: var(--radix-accordion-content-height);
181
+ }
182
+ to {
183
+ height: 0;
184
+ }
185
+ }
186
+
187
+ @keyframes slideRight {
188
+ from {
189
+ width: 0;
190
+ }
191
+ to {
192
+ width: var(--radix-accordion-content-width);
193
+ }
194
+ }
195
+
196
+ @keyframes slideLeft {
197
+ from {
198
+ width: var(--radix-accordion-content-width);
199
+ }
200
+ to {
201
+ width: 0;
202
+ }
203
+ }
204
+ </style>`
205
+ )
206
+ ]
207
+ } as Meta;
208
+
209
+ type Story = StoryObj;
210
+
211
+ export const Default: Story = {
212
+ render: () => ({
213
+ template: `
214
+ <div class="AccordionRoot" rdxAccordionRoot [defaultValue]="'item-1'">
215
+ <div [value]="'item-1'" class="AccordionItem" rdxAccordionItem>
216
+ <div class="AccordionHeader" rdxAccordionHeader>
217
+ <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it accessible?
218
+ <lucide-icon class="AccordionChevron" aria-hidden size="16" name="chevron-down"/>
219
+ </button>
220
+ </div>
221
+ <div class="AccordionContent" rdxAccordionContent>
222
+ <div class="AccordionContentText">
223
+ Yes. It adheres to the WAI-ARIA design pattern.
224
+ </div>
225
+ </div>
226
+ </div>
227
+
228
+ <div [value]="'item-2'" class="AccordionItem" rdxAccordionItem [disabled]="true">
229
+ <div class="AccordionHeader" rdxAccordionHeader>
230
+ <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it unstyled?
231
+ <lucide-icon class="AccordionChevron" aria-hidden size="16" name="chevron-down"/>
232
+ </button>
233
+ </div>
234
+ <div class="AccordionContent" rdxAccordionContent>
235
+ <div class="AccordionContentText">
236
+ Yes. It's unstyled by default, giving you freedom over the look and feel.
237
+ </div>
238
+ </div>
239
+ </div>
240
+
241
+ <div [value]="'item-3'" class="AccordionItem" rdxAccordionItem>
242
+ <div class="AccordionHeader" rdxAccordionHeader>
243
+ <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Can it be animated?
244
+ <lucide-icon class="AccordionChevron" aria-hidden size="16" name="chevron-down"/>
245
+ </button>
246
+ </div>
247
+ <div class="AccordionContent" rdxAccordionContent>
248
+ <div class="AccordionContentText">
249
+ Yes! You can animate the Accordion with CSS or JavaScript.
250
+ </div>
251
+ </div>
252
+ </div>
253
+ </div>
254
+ `
255
+ })
256
+ };
257
+
258
+ export const Multiple: Story = {
259
+ render: () => ({
260
+ template: `
261
+ <div class="AccordionRoot" rdxAccordionRoot [value]="['item-2', 'item-3']" [type]="'multiple'">
262
+ <div [value]="'item-1'" class="AccordionItem" rdxAccordionItem>
263
+ <div class="AccordionHeader" rdxAccordionHeader>
264
+ <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it accessible?</button>
265
+ </div>
266
+ <div class="AccordionContent" rdxAccordionContent >
267
+ <div class="AccordionContentText">
268
+ Yes. It adheres to the WAI-ARIA design pattern.
269
+ </div>
270
+ </div>
271
+ </div>
272
+
273
+ <div [value]="'item-2'" class="AccordionItem" rdxAccordionItem>
274
+ <div class="AccordionHeader" rdxAccordionHeader>
275
+ <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it unstyled?</button>
276
+ </div>
277
+ <div class="AccordionContent" rdxAccordionContent>
278
+ <div class="AccordionContentText">
279
+ Yes. It's unstyled by default, giving you freedom over the look and feel.
280
+ </div>
281
+ </div>
282
+ </div>
283
+
284
+ <div [value]="'item-3'" class="AccordionItem" rdxAccordionItem>
285
+ <div class="AccordionHeader" rdxAccordionHeader>
286
+ <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Can it be animated?</button>
287
+ </div>
288
+ <div class="AccordionContent" rdxAccordionContent>
289
+ <div class="AccordionContentText">
290
+ Yes! You can animate the Accordion with CSS or JavaScript.
291
+ </div>
292
+ </div>
293
+ </div>
294
+ </div>
295
+ `
296
+ })
297
+ };
298
+
299
+ export const Horizontal: Story = {
300
+ render: () => ({
301
+ template: `
302
+ <div class="horizontal-flex-container">
303
+ <div class="AccordionRoot" rdxAccordionRoot [defaultValue]="'item-1'" [orientation]="'horizontal'">
304
+ <div [value]="'item-1'" class="AccordionItem" rdxAccordionItem>
305
+ <div class="AccordionHeader" rdxAccordionHeader>
306
+ <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it accessible?</button>
307
+ </div>
308
+ <div class="AccordionContent" rdxAccordionContent>
309
+ <div class="AccordionContentText">
310
+ Yes. It adheres to the WAI-ARIA design pattern.
311
+ </div>
312
+ </div>
313
+ </div>
314
+
315
+ <div [value]="'item-2'" class="AccordionItem" rdxAccordionItem [disabled]="true">
316
+ <div class="AccordionHeader" rdxAccordionHeader>
317
+ <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it unstyled?</button>
318
+ </div>
319
+ <div class="AccordionContent" rdxAccordionContent>
320
+ <div class="AccordionContentText">
321
+ Yes. It's unstyled by default, giving you freedom over the look and feel.
322
+ </div>
323
+ </div>
324
+ </div>
325
+
326
+ <div [value]="'item-3'" class="AccordionItem" rdxAccordionItem>
327
+ <div class="AccordionHeader" rdxAccordionHeader>
328
+ <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Can it be animated?</button>
329
+ </div>
330
+ <div class="AccordionContent" rdxAccordionContent>
331
+ <div class="AccordionContentText">
332
+ Yes! You can animate the Accordion with CSS or JavaScript.
333
+ </div>
334
+ </div>
335
+ </div>
336
+ </div>
337
+ </div>
338
+ `
339
+ })
340
+ };
@@ -3,4 +3,5 @@ export * from './src/alert-dialog-content.directive';
3
3
  export * from './src/alert-dialog-root.directive';
4
4
  export * from './src/alert-dialog-title.directive';
5
5
  export * from './src/alert-dialog-trigger.directive';
6
+
6
7
  export * from './src/alert-dialog.service';
@@ -0,0 +1,5 @@
1
+ {
2
+ "lib": {
3
+ "entryFile": "index.ts"
4
+ }
5
+ }
@@ -0,0 +1,17 @@
1
+ import { Directive, inject } from '@angular/core';
2
+ import { AlertDialogService } from './alert-dialog.service';
3
+
4
+ @Directive({
5
+ selector: '[rdxAlertDialogCancel]',
6
+ standalone: true,
7
+ host: {
8
+ '(click)': 'onClick()'
9
+ }
10
+ })
11
+ export class AlertDialogCancelDirective {
12
+ private readonly alertDialogService = inject(AlertDialogService);
13
+
14
+ onClick() {
15
+ this.alertDialogService.close();
16
+ }
17
+ }