@radix-ng/primitives 0.11.1 → 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 (449) 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/__tests__/dialog-content.directive.spec.ts +77 -0
  81. package/dialog/__tests__/dialog-trigger.directive.spec.ts +85 -0
  82. package/dialog/index.ts +31 -0
  83. package/dialog/ng-package.json +5 -0
  84. package/dialog/src/dialog-close.directive.ts +18 -0
  85. package/dialog/src/dialog-content.directive.ts +45 -0
  86. package/dialog/src/dialog-description.directive.ts +7 -0
  87. package/dialog/src/dialog-dismiss.directive.ts +18 -0
  88. package/dialog/src/dialog-ref.ts +70 -0
  89. package/dialog/src/dialog-title.directive.ts +7 -0
  90. package/dialog/src/dialog-trigger.directive.ts +52 -0
  91. package/dialog/src/dialog.config.ts +55 -0
  92. package/dialog/src/dialog.injectors.ts +12 -0
  93. package/dialog/src/dialog.providers.ts +27 -0
  94. package/dialog/src/dialog.service.ts +94 -0
  95. package/dialog/stories/dialog.docs.mdx +32 -0
  96. package/dialog/stories/dialog.stories.ts +233 -0
  97. package/dropdown-menu/ng-package.json +5 -0
  98. package/dropdown-menu/src/dropdown-menu-content.directive.ts +47 -0
  99. package/dropdown-menu/src/dropdown-menu-item-checkbox.directive.ts +30 -0
  100. package/dropdown-menu/src/dropdown-menu-item-indicator.directive.ts +14 -0
  101. package/dropdown-menu/src/dropdown-menu-item-radio-group.directive.ts +31 -0
  102. package/dropdown-menu/src/dropdown-menu-item-radio.directive.ts +72 -0
  103. package/dropdown-menu/src/dropdown-menu-item-selectable.ts +18 -0
  104. package/dropdown-menu/src/dropdown-menu-item.directive.ts +66 -0
  105. package/dropdown-menu/src/dropdown-menu-label.directive.ts +7 -0
  106. package/dropdown-menu/src/dropdown-menu-separator.directive.ts +13 -0
  107. package/dropdown-menu/src/dropdown-menu-trigger.directive.ts +185 -0
  108. package/dropdown-menu/stories/dropdown-menu-item-checkbox.component.ts +104 -0
  109. package/dropdown-menu/stories/dropdown-menu-item-checkbox.styles.scss +106 -0
  110. package/dropdown-menu/stories/dropdown-menu-item-radio.component.ts +95 -0
  111. package/dropdown-menu/stories/dropdown-menu-item-radio.styles.scss +106 -0
  112. package/dropdown-menu/stories/dropdown.docs.mdx +27 -0
  113. package/dropdown-menu/stories/dropdown.stories.ts +212 -0
  114. package/form-field/index.ts +1 -0
  115. package/form-field/src/.gitkeep +0 -0
  116. package/jest.config.ts +21 -0
  117. package/label/__tests__/label-root.directive.spec.ts +99 -0
  118. package/label/ng-package.json +5 -0
  119. package/label/src/label.directive.ts +58 -0
  120. package/label/stories/label.docs.mdx +40 -0
  121. package/label/stories/label.stories.ts +76 -0
  122. package/menu/index.ts +29 -0
  123. package/menu/ng-package.json +5 -0
  124. package/menu/src/menu-content.directive.ts +9 -0
  125. package/menu/src/menu-directive.ts +10 -0
  126. package/menu/src/menu-group.directive.ts +12 -0
  127. package/menu/src/menu-item.directive.ts +44 -0
  128. package/menu/src/menu-label.directive.ts +7 -0
  129. package/menu/src/menu-separator.directive.ts +13 -0
  130. package/menubar/index.ts +38 -0
  131. package/menubar/ng-package.json +5 -0
  132. package/menubar/src/menubar-content.directive.ts +9 -0
  133. package/menubar/src/menubar-item-checkbox.directive.ts +32 -0
  134. package/menubar/src/menubar-item-indicator.directive.ts +10 -0
  135. package/menubar/src/menubar-item-radio.directive.ts +33 -0
  136. package/menubar/src/menubar-item.directive.ts +12 -0
  137. package/menubar/src/menubar-radio-group.directive.ts +9 -0
  138. package/menubar/src/menubar-root.directive.ts +15 -0
  139. package/menubar/src/menubar-separator.directive.ts +9 -0
  140. package/menubar/src/menubar-trigger.directive.ts +40 -0
  141. package/menubar/stories/menubar.stories.ts +229 -0
  142. package/ng-package.json +8 -0
  143. package/package.json +4 -118
  144. package/portal/stories/portal.docs.mdx +85 -0
  145. package/presence/__test__/presence-test.component.ts +51 -0
  146. package/presence/__test__/presence.spec.ts +50 -0
  147. package/presence/index.ts +4 -0
  148. package/presence/src/presence.ts +119 -0
  149. package/presence/src/transitions/transition.collapse.ts +99 -0
  150. package/presence/src/transitions/transition.toast.ts +27 -0
  151. package/presence/src/types.ts +20 -0
  152. package/presence/src/utils.ts +63 -0
  153. package/presence/stories/presence-story.componen.ts +69 -0
  154. package/presence/stories/presence.docs.mdx +40 -0
  155. package/presence/stories/presence.stories.ts +29 -0
  156. package/progress/__test__/progress.spec.ts +55 -0
  157. package/progress/{index.d.ts → index.ts} +1 -0
  158. package/progress/ng-package.json +5 -0
  159. package/progress/src/progress-indicator.directive.ts +26 -0
  160. package/progress/src/progress-root.directive.ts +134 -0
  161. package/progress/stories/progress.docs.mdx +65 -0
  162. package/progress/stories/progress.stories.ts +66 -0
  163. package/project.json +39 -0
  164. package/radio/{index.d.ts → index.ts} +1 -0
  165. package/radio/ng-package.json +5 -0
  166. package/radio/src/radio-indicator.directive.ts +17 -0
  167. package/radio/src/radio-item.directive.ts +68 -0
  168. package/radio/src/radio-root.directive.ts +207 -0
  169. package/radio/src/{radio-tokens.d.ts → radio-tokens.ts} +5 -1
  170. package/radio/stories/radio-group.component.ts +39 -0
  171. package/radio/stories/radio-group.styles.scss +70 -0
  172. package/radio/stories/radio.docs.mdx +68 -0
  173. package/radio/stories/radio.stories.ts +155 -0
  174. package/separator/__tests__/separator.directive.spec.ts +58 -0
  175. package/separator/ng-package.json +5 -0
  176. package/separator/src/separator.directive.ts +35 -0
  177. package/separator/stories/separator.docs.mdx +37 -0
  178. package/separator/stories/separator.stories.ts +82 -0
  179. package/slider/src/slider-input.directive.ts +0 -0
  180. package/slider/src/slider-thumb.directives.ts +60 -0
  181. package/slider/src/slider-track.directive.ts +11 -0
  182. package/slider/src/slider.directive.ts +59 -0
  183. package/slider/src/slider.types.ts +4 -0
  184. package/switch/index.ts +22 -0
  185. package/switch/ng-package.json +5 -0
  186. package/switch/src/switch-input.directive.ts +24 -0
  187. package/switch/src/switch-root.directive.ts +127 -0
  188. package/switch/src/switch-thumb.directive.ts +15 -0
  189. package/switch/stories/switch.docs.mdx +83 -0
  190. package/switch/stories/switch.stories.ts +149 -0
  191. package/tabs/__tests__/tabs-context.service.spec.ts +35 -0
  192. package/tabs/index.ts +26 -0
  193. package/tabs/ng-package.json +5 -0
  194. package/tabs/src/tabs-content.directive.ts +23 -0
  195. package/tabs/src/tabs-context.service.ts +43 -0
  196. package/tabs/src/tabs-list.directive.ts +21 -0
  197. package/tabs/src/tabs-root.directive.ts +70 -0
  198. package/tabs/src/tabs-trigger.directive.ts +55 -0
  199. package/tabs/stories/tabs.stories.ts +213 -0
  200. package/test-setup.ts +1 -0
  201. package/toggle/__tests__/toggle.directive.spec.ts +87 -0
  202. package/toggle/ng-package.json +5 -0
  203. package/toggle/src/toggle.directive.ts +49 -0
  204. package/toggle/stories/toggle.docs.mdx +60 -0
  205. package/toggle/stories/toggle.stories.ts +84 -0
  206. package/toggle-group/ng-package.json +5 -0
  207. package/toggle-group/src/toggle-group-button.directive.ts +73 -0
  208. package/toggle-group/src/toggle-group-button.token.ts +8 -0
  209. package/toggle-group/src/toggle-group-multi.directive.ts +158 -0
  210. package/toggle-group/src/toggle-group.directive.ts +148 -0
  211. package/toggle-group/src/toggle-group.token.ts +11 -0
  212. package/toggle-group/stories/toggle-group.docs.mdx +87 -0
  213. package/toggle-group/stories/toggle-group.stories.ts +95 -0
  214. package/tsconfig.doc.json +11 -0
  215. package/tsconfig.json +29 -0
  216. package/tsconfig.lib.json +19 -0
  217. package/tsconfig.lib.prod.json +12 -0
  218. package/tsconfig.spec.json +11 -0
  219. package/visually-hidden/README.md +3 -0
  220. package/visually-hidden/stories/visually-hidden.docs.mdx +36 -0
  221. package/accordion/src/accordion-content.directive.d.ts +0 -11
  222. package/accordion/src/accordion-header.directive.d.ts +0 -7
  223. package/accordion/src/accordion-item.directive.d.ts +0 -64
  224. package/accordion/src/accordion-root.directive.d.ts +0 -78
  225. package/accordion/src/accordion-trigger.directive.d.ts +0 -15
  226. package/alert-dialog/src/alert-dialog-cancel.directive.d.ts +0 -7
  227. package/alert-dialog/src/alert-dialog-content.directive.d.ts +0 -9
  228. package/alert-dialog/src/alert-dialog-root.directive.d.ts +0 -9
  229. package/alert-dialog/src/alert-dialog-title.directive.d.ts +0 -5
  230. package/alert-dialog/src/alert-dialog-trigger.directive.d.ts +0 -7
  231. package/alert-dialog/src/alert-dialog.service.d.ts +0 -14
  232. package/avatar/src/avatar-fallback.directive.d.ts +0 -27
  233. package/avatar/src/avatar-image.directive.d.ts +0 -16
  234. package/avatar/src/avatar-root.directive.d.ts +0 -21
  235. package/avatar/src/avatar.config.d.ts +0 -13
  236. package/checkbox/src/checkbox-button.directive.d.ts +0 -8
  237. package/checkbox/src/checkbox-indicator.directive.d.ts +0 -6
  238. package/checkbox/src/checkbox-input.directive.d.ts +0 -9
  239. package/checkbox/src/checkbox.directive.d.ts +0 -75
  240. package/checkbox/src/checkbox.token.d.ts +0 -4
  241. package/collapsible/src/collapsible-content.directive.d.ts +0 -17
  242. package/collapsible/src/collapsible-content.token.d.ts +0 -3
  243. package/collapsible/src/collapsible-root.directive.d.ts +0 -55
  244. package/collapsible/src/collapsible-trigger.directive.d.ts +0 -26
  245. package/compodoc/documentation.json +0 -11759
  246. package/dropdown-menu/src/dropdown-menu-content.directive.d.ts +0 -15
  247. package/dropdown-menu/src/dropdown-menu-item-checkbox.directive.d.ts +0 -9
  248. package/dropdown-menu/src/dropdown-menu-item-indicator.directive.d.ts +0 -7
  249. package/dropdown-menu/src/dropdown-menu-item-radio-group.directive.d.ts +0 -12
  250. package/dropdown-menu/src/dropdown-menu-item-radio.directive.d.ts +0 -19
  251. package/dropdown-menu/src/dropdown-menu-item-selectable.d.ts +0 -12
  252. package/dropdown-menu/src/dropdown-menu-item.directive.d.ts +0 -17
  253. package/dropdown-menu/src/dropdown-menu-label.directive.d.ts +0 -5
  254. package/dropdown-menu/src/dropdown-menu-separator.directive.d.ts +0 -6
  255. package/dropdown-menu/src/dropdown-menu-trigger.directive.d.ts +0 -43
  256. package/esm2022/accordion/index.mjs +0 -6
  257. package/esm2022/accordion/radix-ng-primitives-accordion.mjs +0 -5
  258. package/esm2022/accordion/src/accordion-content.directive.mjs +0 -42
  259. package/esm2022/accordion/src/accordion-header.directive.mjs +0 -23
  260. package/esm2022/accordion/src/accordion-item.directive.mjs +0 -175
  261. package/esm2022/accordion/src/accordion-root.directive.mjs +0 -160
  262. package/esm2022/accordion/src/accordion-trigger.directive.mjs +0 -42
  263. package/esm2022/alert-dialog/index.mjs +0 -7
  264. package/esm2022/alert-dialog/radix-ng-primitives-alert-dialog.mjs +0 -5
  265. package/esm2022/alert-dialog/src/alert-dialog-cancel.directive.mjs +0 -24
  266. package/esm2022/alert-dialog/src/alert-dialog-content.directive.mjs +0 -34
  267. package/esm2022/alert-dialog/src/alert-dialog-root.directive.mjs +0 -25
  268. package/esm2022/alert-dialog/src/alert-dialog-title.directive.mjs +0 -14
  269. package/esm2022/alert-dialog/src/alert-dialog-trigger.directive.mjs +0 -24
  270. package/esm2022/alert-dialog/src/alert-dialog.service.mjs +0 -47
  271. package/esm2022/avatar/index.mjs +0 -5
  272. package/esm2022/avatar/radix-ng-primitives-avatar.mjs +0 -5
  273. package/esm2022/avatar/src/avatar-fallback.directive.mjs +0 -54
  274. package/esm2022/avatar/src/avatar-image.directive.mjs +0 -48
  275. package/esm2022/avatar/src/avatar-root.directive.mjs +0 -38
  276. package/esm2022/avatar/src/avatar.config.mjs +0 -17
  277. package/esm2022/checkbox/index.mjs +0 -6
  278. package/esm2022/checkbox/radix-ng-primitives-checkbox.mjs +0 -5
  279. package/esm2022/checkbox/src/checkbox-button.directive.mjs +0 -33
  280. package/esm2022/checkbox/src/checkbox-indicator.directive.mjs +0 -24
  281. package/esm2022/checkbox/src/checkbox-input.directive.mjs +0 -41
  282. package/esm2022/checkbox/src/checkbox.directive.mjs +0 -141
  283. package/esm2022/checkbox/src/checkbox.token.mjs +0 -6
  284. package/esm2022/collapsible/index.mjs +0 -4
  285. package/esm2022/collapsible/radix-ng-primitives-collapsible.mjs +0 -5
  286. package/esm2022/collapsible/src/collapsible-content.directive.mjs +0 -45
  287. package/esm2022/collapsible/src/collapsible-content.token.mjs +0 -3
  288. package/esm2022/collapsible/src/collapsible-root.directive.mjs +0 -118
  289. package/esm2022/collapsible/src/collapsible-trigger.directive.mjs +0 -49
  290. package/esm2022/dialog/index.mjs +0 -2
  291. package/esm2022/dialog/radix-ng-primitives-dialog.mjs +0 -5
  292. package/esm2022/dropdown-menu/index.mjs +0 -11
  293. package/esm2022/dropdown-menu/radix-ng-primitives-dropdown-menu.mjs +0 -5
  294. package/esm2022/dropdown-menu/src/dropdown-menu-content.directive.mjs +0 -56
  295. package/esm2022/dropdown-menu/src/dropdown-menu-item-checkbox.directive.mjs +0 -36
  296. package/esm2022/dropdown-menu/src/dropdown-menu-item-indicator.directive.mjs +0 -22
  297. package/esm2022/dropdown-menu/src/dropdown-menu-item-radio-group.directive.mjs +0 -37
  298. package/esm2022/dropdown-menu/src/dropdown-menu-item-radio.directive.mjs +0 -64
  299. package/esm2022/dropdown-menu/src/dropdown-menu-item-selectable.mjs +0 -31
  300. package/esm2022/dropdown-menu/src/dropdown-menu-item.directive.mjs +0 -71
  301. package/esm2022/dropdown-menu/src/dropdown-menu-label.directive.mjs +0 -14
  302. package/esm2022/dropdown-menu/src/dropdown-menu-separator.directive.mjs +0 -21
  303. package/esm2022/dropdown-menu/src/dropdown-menu-trigger.directive.mjs +0 -176
  304. package/esm2022/index.mjs +0 -2
  305. package/esm2022/label/index.mjs +0 -2
  306. package/esm2022/label/radix-ng-primitives-label.mjs +0 -5
  307. package/esm2022/label/src/label.directive.mjs +0 -59
  308. package/esm2022/menu/index.mjs +0 -45
  309. package/esm2022/menu/radix-ng-primitives-menu.mjs +0 -5
  310. package/esm2022/menu/src/menu-content.directive.mjs +0 -17
  311. package/esm2022/menu/src/menu-directive.mjs +0 -18
  312. package/esm2022/menu/src/menu-group.directive.mjs +0 -20
  313. package/esm2022/menu/src/menu-item.directive.mjs +0 -46
  314. package/esm2022/menu/src/menu-label.directive.mjs +0 -14
  315. package/esm2022/menu/src/menu-separator.directive.mjs +0 -21
  316. package/esm2022/menubar/index.mjs +0 -60
  317. package/esm2022/menubar/radix-ng-primitives-menubar.mjs +0 -5
  318. package/esm2022/menubar/src/menubar-content.directive.mjs +0 -17
  319. package/esm2022/menubar/src/menubar-item-checkbox.directive.mjs +0 -34
  320. package/esm2022/menubar/src/menubar-item-indicator.directive.mjs +0 -17
  321. package/esm2022/menubar/src/menubar-item-radio.directive.mjs +0 -35
  322. package/esm2022/menubar/src/menubar-item.directive.mjs +0 -20
  323. package/esm2022/menubar/src/menubar-radio-group.directive.mjs +0 -17
  324. package/esm2022/menubar/src/menubar-root.directive.mjs +0 -24
  325. package/esm2022/menubar/src/menubar-separator.directive.mjs +0 -17
  326. package/esm2022/menubar/src/menubar-trigger.directive.mjs +0 -45
  327. package/esm2022/progress/index.mjs +0 -3
  328. package/esm2022/progress/radix-ng-primitives-progress.mjs +0 -5
  329. package/esm2022/progress/src/progress-indicator.directive.mjs +0 -34
  330. package/esm2022/progress/src/progress-root.directive.mjs +0 -127
  331. package/esm2022/radio/index.mjs +0 -4
  332. package/esm2022/radio/radix-ng-primitives-radio.mjs +0 -5
  333. package/esm2022/radio/src/radio-indicator.directive.mjs +0 -25
  334. package/esm2022/radio/src/radio-item.directive.mjs +0 -70
  335. package/esm2022/radio/src/radio-root.directive.mjs +0 -194
  336. package/esm2022/radio/src/radio-tokens.mjs +0 -3
  337. package/esm2022/radix-ng-primitives.mjs +0 -5
  338. package/esm2022/separator/index.mjs +0 -2
  339. package/esm2022/separator/radix-ng-primitives-separator.mjs +0 -5
  340. package/esm2022/separator/src/separator.directive.mjs +0 -31
  341. package/esm2022/switch/index.mjs +0 -30
  342. package/esm2022/switch/radix-ng-primitives-switch.mjs +0 -5
  343. package/esm2022/switch/src/switch-input.directive.mjs +0 -32
  344. package/esm2022/switch/src/switch-root.directive.mjs +0 -95
  345. package/esm2022/switch/src/switch-thumb.directive.mjs +0 -23
  346. package/esm2022/tabs/index.mjs +0 -38
  347. package/esm2022/tabs/radix-ng-primitives-tabs.mjs +0 -5
  348. package/esm2022/tabs/src/tabs-content.directive.mjs +0 -29
  349. package/esm2022/tabs/src/tabs-context.service.mjs +0 -43
  350. package/esm2022/tabs/src/tabs-list.directive.mjs +0 -23
  351. package/esm2022/tabs/src/tabs-root.directive.mjs +0 -54
  352. package/esm2022/tabs/src/tabs-trigger.directive.mjs +0 -52
  353. package/esm2022/toggle/index.mjs +0 -2
  354. package/esm2022/toggle/radix-ng-primitives-toggle.mjs +0 -5
  355. package/esm2022/toggle/src/toggle.directive.mjs +0 -39
  356. package/esm2022/toggle-group/index.mjs +0 -6
  357. package/esm2022/toggle-group/radix-ng-primitives-toggle-group.mjs +0 -5
  358. package/esm2022/toggle-group/src/toggle-group-button.directive.mjs +0 -75
  359. package/esm2022/toggle-group/src/toggle-group-button.token.mjs +0 -6
  360. package/esm2022/toggle-group/src/toggle-group-multi.directive.mjs +0 -143
  361. package/esm2022/toggle-group/src/toggle-group.directive.mjs +0 -134
  362. package/esm2022/toggle-group/src/toggle-group.token.mjs +0 -6
  363. package/fesm2022/radix-ng-primitives-accordion.mjs +0 -431
  364. package/fesm2022/radix-ng-primitives-accordion.mjs.map +0 -1
  365. package/fesm2022/radix-ng-primitives-alert-dialog.mjs +0 -161
  366. package/fesm2022/radix-ng-primitives-alert-dialog.mjs.map +0 -1
  367. package/fesm2022/radix-ng-primitives-avatar.mjs +0 -156
  368. package/fesm2022/radix-ng-primitives-avatar.mjs.map +0 -1
  369. package/fesm2022/radix-ng-primitives-checkbox.mjs +0 -241
  370. package/fesm2022/radix-ng-primitives-checkbox.mjs.map +0 -1
  371. package/fesm2022/radix-ng-primitives-collapsible.mjs +0 -213
  372. package/fesm2022/radix-ng-primitives-collapsible.mjs.map +0 -1
  373. package/fesm2022/radix-ng-primitives-dialog.mjs +0 -4
  374. package/fesm2022/radix-ng-primitives-dialog.mjs.map +0 -1
  375. package/fesm2022/radix-ng-primitives-dropdown-menu.mjs +0 -502
  376. package/fesm2022/radix-ng-primitives-dropdown-menu.mjs.map +0 -1
  377. package/fesm2022/radix-ng-primitives-label.mjs +0 -66
  378. package/fesm2022/radix-ng-primitives-label.mjs.map +0 -1
  379. package/fesm2022/radix-ng-primitives-menu.mjs +0 -158
  380. package/fesm2022/radix-ng-primitives-menu.mjs.map +0 -1
  381. package/fesm2022/radix-ng-primitives-menubar.mjs +0 -245
  382. package/fesm2022/radix-ng-primitives-menubar.mjs.map +0 -1
  383. package/fesm2022/radix-ng-primitives-progress.mjs +0 -165
  384. package/fesm2022/radix-ng-primitives-progress.mjs.map +0 -1
  385. package/fesm2022/radix-ng-primitives-radio.mjs +0 -289
  386. package/fesm2022/radix-ng-primitives-radio.mjs.map +0 -1
  387. package/fesm2022/radix-ng-primitives-separator.mjs +0 -38
  388. package/fesm2022/radix-ng-primitives-separator.mjs.map +0 -1
  389. package/fesm2022/radix-ng-primitives-switch.mjs +0 -173
  390. package/fesm2022/radix-ng-primitives-switch.mjs.map +0 -1
  391. package/fesm2022/radix-ng-primitives-tabs.mjs +0 -222
  392. package/fesm2022/radix-ng-primitives-tabs.mjs.map +0 -1
  393. package/fesm2022/radix-ng-primitives-toggle-group.mjs +0 -358
  394. package/fesm2022/radix-ng-primitives-toggle-group.mjs.map +0 -1
  395. package/fesm2022/radix-ng-primitives-toggle.mjs +0 -46
  396. package/fesm2022/radix-ng-primitives-toggle.mjs.map +0 -1
  397. package/fesm2022/radix-ng-primitives.mjs +0 -4
  398. package/fesm2022/radix-ng-primitives.mjs.map +0 -1
  399. package/index.d.ts +0 -1
  400. package/label/src/label.directive.d.ts +0 -29
  401. package/menu/index.d.ts +0 -18
  402. package/menu/src/menu-content.directive.d.ts +0 -6
  403. package/menu/src/menu-directive.d.ts +0 -6
  404. package/menu/src/menu-group.directive.d.ts +0 -6
  405. package/menu/src/menu-item.directive.d.ts +0 -12
  406. package/menu/src/menu-label.directive.d.ts +0 -5
  407. package/menu/src/menu-separator.directive.d.ts +0 -6
  408. package/menubar/index.d.ts +0 -24
  409. package/menubar/src/menubar-content.directive.d.ts +0 -6
  410. package/menubar/src/menubar-item-checkbox.directive.d.ts +0 -14
  411. package/menubar/src/menubar-item-indicator.directive.d.ts +0 -5
  412. package/menubar/src/menubar-item-radio.directive.d.ts +0 -14
  413. package/menubar/src/menubar-item.directive.d.ts +0 -8
  414. package/menubar/src/menubar-radio-group.directive.d.ts +0 -6
  415. package/menubar/src/menubar-root.directive.d.ts +0 -7
  416. package/menubar/src/menubar-separator.directive.d.ts +0 -6
  417. package/menubar/src/menubar-trigger.directive.d.ts +0 -11
  418. package/progress/src/progress-indicator.directive.d.ts +0 -16
  419. package/progress/src/progress-root.directive.d.ts +0 -63
  420. package/radio/src/radio-indicator.directive.d.ts +0 -9
  421. package/radio/src/radio-item.directive.d.ts +0 -21
  422. package/radio/src/radio-root.directive.d.ts +0 -72
  423. package/separator/src/separator.directive.d.ts +0 -22
  424. package/switch/index.d.ts +0 -13
  425. package/switch/src/switch-input.directive.d.ts +0 -6
  426. package/switch/src/switch-root.directive.d.ts +0 -51
  427. package/switch/src/switch-thumb.directive.d.ts +0 -6
  428. package/tabs/index.d.ts +0 -15
  429. package/tabs/src/tabs-content.directive.d.ts +0 -8
  430. package/tabs/src/tabs-context.service.d.ts +0 -22
  431. package/tabs/src/tabs-list.directive.d.ts +0 -6
  432. package/tabs/src/tabs-root.directive.d.ts +0 -37
  433. package/tabs/src/tabs-trigger.directive.d.ts +0 -19
  434. package/toggle/src/toggle.directive.d.ts +0 -30
  435. package/toggle-group/src/toggle-group-button.directive.d.ts +0 -39
  436. package/toggle-group/src/toggle-group-button.token.d.ts +0 -4
  437. package/toggle-group/src/toggle-group-multi.directive.d.ts +0 -93
  438. package/toggle-group/src/toggle-group.directive.d.ts +0 -84
  439. package/toggle-group/src/toggle-group.token.d.ts +0 -5
  440. /package/accordion/{index.d.ts → index.ts} +0 -0
  441. /package/avatar/{index.d.ts → index.ts} +0 -0
  442. /package/checkbox/{index.d.ts → index.ts} +0 -0
  443. /package/collapsible/{index.d.ts → index.ts} +0 -0
  444. /package/dropdown-menu/{index.d.ts → index.ts} +0 -0
  445. /package/{dialog/index.d.ts → index.ts} +0 -0
  446. /package/label/{index.d.ts → index.ts} +0 -0
  447. /package/separator/{index.d.ts → index.ts} +0 -0
  448. /package/toggle/{index.d.ts → index.ts} +0 -0
  449. /package/toggle-group/{index.d.ts → index.ts} +0 -0
@@ -0,0 +1,27 @@
1
+ import { Component } from '@angular/core';
2
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
3
+ import { RdxCollapsibleRootDirective } from '../src/collapsible-root.directive';
4
+
5
+ @Component({
6
+ selector: 'rdx-collapsible-mock-trigger',
7
+ standalone: true,
8
+ imports: [RdxCollapsibleRootDirective],
9
+ template: `
10
+ <div CollapsibleRoot></div>
11
+ `
12
+ })
13
+ class RdxCollapsibleMockComponent {}
14
+
15
+ describe('RdxCollapsibleRootDirective', () => {
16
+ let component: RdxCollapsibleMockComponent;
17
+ let fixture: ComponentFixture<RdxCollapsibleMockComponent>;
18
+
19
+ beforeEach(() => {
20
+ fixture = TestBed.createComponent(RdxCollapsibleMockComponent);
21
+ component = fixture.componentInstance;
22
+ });
23
+
24
+ it('should create an instance', () => {
25
+ expect(component).toBeTruthy();
26
+ });
27
+ });
@@ -0,0 +1,30 @@
1
+ import { Component } from '@angular/core';
2
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
3
+ import { RdxCollapsibleRootDirective } from '../src/collapsible-root.directive';
4
+ import { RdxCollapsibleTriggerDirective } from '../src/collapsible-trigger.directive';
5
+
6
+ @Component({
7
+ selector: 'rdx-collapsible-mock-trigger',
8
+ standalone: true,
9
+ imports: [RdxCollapsibleRootDirective, RdxCollapsibleTriggerDirective],
10
+ template: `
11
+ <div CollapsibleRoot>
12
+ <button CollapsibleTrigger>Trigger</button>
13
+ </div>
14
+ `
15
+ })
16
+ class RdxCollapsibleMockComponent {}
17
+
18
+ describe('RdxCollapsibleTriggerDirective', () => {
19
+ let component: RdxCollapsibleMockComponent;
20
+ let fixture: ComponentFixture<RdxCollapsibleMockComponent>;
21
+
22
+ beforeEach(() => {
23
+ fixture = TestBed.createComponent(RdxCollapsibleMockComponent);
24
+ component = fixture.componentInstance;
25
+ });
26
+
27
+ it('should create an instance', () => {
28
+ expect(component).toBeTruthy();
29
+ });
30
+ });
@@ -0,0 +1,5 @@
1
+ {
2
+ "lib": {
3
+ "entryFile": "index.ts"
4
+ }
5
+ }
@@ -0,0 +1,34 @@
1
+ import { Directive, ElementRef, inject } from '@angular/core';
2
+ import { RdxCollapsibleContentToken } from './collapsible-content.token';
3
+ import { RdxCollapsibleRootDirective } from './collapsible-root.directive';
4
+
5
+ @Directive({
6
+ selector: '[rdxCollapsibleContent]',
7
+ standalone: true,
8
+ providers: [
9
+ {
10
+ provide: RdxCollapsibleContentToken,
11
+ useExisting: RdxCollapsibleContentDirective
12
+ }
13
+ ],
14
+ host: {
15
+ '[attr.data-state]': 'collapsible.getState()',
16
+ '[attr.data-disabled]': 'getDisabled()'
17
+ }
18
+ })
19
+ export class RdxCollapsibleContentDirective {
20
+ /**
21
+ * @ignore
22
+ */
23
+ protected readonly collapsible = inject(RdxCollapsibleRootDirective);
24
+
25
+ /**
26
+ * Reference to CollapsibleContent host element
27
+ * @ignore
28
+ */
29
+ elementRef = inject<ElementRef<HTMLElement>>(ElementRef);
30
+
31
+ getDisabled(): string | undefined {
32
+ return this.collapsible.disabled ? 'disabled' : undefined;
33
+ }
34
+ }
@@ -0,0 +1,6 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ import { RdxCollapsibleContentDirective } from './collapsible-content.directive';
3
+
4
+ export const RdxCollapsibleContentToken = new InjectionToken<RdxCollapsibleContentDirective>(
5
+ 'RdxCollapsibleContentToken'
6
+ );
@@ -0,0 +1,120 @@
1
+ import { contentChild, Directive, EventEmitter, inject, InjectionToken, Input, Output } from '@angular/core';
2
+ import { asyncScheduler } from 'rxjs';
3
+ import { RdxCollapsibleContentToken } from './collapsible-content.token';
4
+
5
+ const RdxCollapsibleRootToken = new InjectionToken<RdxCollapsibleRootDirective>('RdxCollapsibleRootToken');
6
+
7
+ export function injectCollapsible(): RdxCollapsibleRootDirective {
8
+ return inject(RdxCollapsibleRootDirective);
9
+ }
10
+
11
+ export type RdxCollapsibleState = 'open' | 'closed';
12
+
13
+ @Directive({
14
+ selector: '[rdxCollapsibleRoot]',
15
+ standalone: true,
16
+ exportAs: 'collapsibleRoot',
17
+ providers: [{ provide: RdxCollapsibleRootToken, useExisting: RdxCollapsibleRootDirective }],
18
+ host: {
19
+ '[attr.data-state]': 'getState()',
20
+ '[attr.data-disabled]': 'disabled ? "" : undefined'
21
+ }
22
+ })
23
+ export class RdxCollapsibleRootDirective {
24
+ /**
25
+ * Reference to RdxCollapsibleContent directive
26
+ * @private
27
+ * @ignore
28
+ */
29
+ private readonly contentDirective = contentChild.required(RdxCollapsibleContentToken);
30
+
31
+ /**
32
+ * Stores collapsible state
33
+ * @private
34
+ * @ignore
35
+ */
36
+ private _open = false;
37
+
38
+ /**
39
+ * Determines whether a directive is available for interaction.
40
+ * When true, prevents the user from interacting with the collapsible.
41
+ */
42
+ @Input() disabled = false;
43
+
44
+ /**
45
+ * The controlled open state of the collapsible.
46
+ * Sets the state of the directive. `true` - expanded, `false` - collapsed
47
+ * @param {boolean} value
48
+ */
49
+ @Input() set open(value: boolean) {
50
+ if (value !== this._open) {
51
+ this.onOpenChange.emit(value);
52
+ }
53
+
54
+ this._open = value;
55
+ this.setPresence();
56
+ }
57
+
58
+ /**
59
+ * Emitted with new value when directive state changed.
60
+ * Event handler called when the open state of the collapsible changes.
61
+ */
62
+ @Output() onOpenChange = new EventEmitter<boolean>();
63
+
64
+ /**
65
+ * Allows to change directive state
66
+ * @param {boolean | undefined} value
67
+ */
68
+ setOpen(value?: boolean) {
69
+ if (this.disabled) {
70
+ return;
71
+ }
72
+
73
+ if (value === undefined) {
74
+ this.open = !this._open;
75
+ } else {
76
+ this.open = value;
77
+ }
78
+
79
+ this.setPresence();
80
+ }
81
+
82
+ /**
83
+ * Returns directive state (open | closed)
84
+ */
85
+ getState(): RdxCollapsibleState {
86
+ return this._open ? 'open' : 'closed';
87
+ }
88
+
89
+ /**
90
+ * Returns current directive state
91
+ */
92
+ isOpen(): boolean {
93
+ return this._open;
94
+ }
95
+
96
+ /**
97
+ * Controls visibility of content
98
+ * @private
99
+ * @ignore
100
+ */
101
+ private setPresence(): void {
102
+ if (!this.contentDirective) {
103
+ return;
104
+ }
105
+
106
+ this.contentDirective().elementRef.nativeElement.setAttribute('data-state', this.getState());
107
+
108
+ if (this.isOpen()) {
109
+ this.contentDirective().elementRef.nativeElement.removeAttribute('hidden');
110
+ } else {
111
+ asyncScheduler.schedule(() => {
112
+ const animations = this.contentDirective().elementRef.nativeElement.getAnimations();
113
+
114
+ if (animations === undefined || animations.length === 0) {
115
+ this.contentDirective().elementRef.nativeElement.setAttribute('hidden', '');
116
+ }
117
+ });
118
+ }
119
+ }
120
+ }
@@ -0,0 +1,44 @@
1
+ import { Directive } from '@angular/core';
2
+ import { injectCollapsible, RdxCollapsibleState } from './collapsible-root.directive';
3
+
4
+ @Directive({
5
+ selector: '[rdxCollapsibleTrigger]',
6
+ standalone: true,
7
+ host: {
8
+ '(click)': 'onOpenToggle()',
9
+ '[attr.data-state]': 'getState()',
10
+ '[attr.aria-expanded]': 'getState() === "open" ? "true" : "false"',
11
+ '[disabled]': 'getDisabled()'
12
+ }
13
+ })
14
+ export class RdxCollapsibleTriggerDirective {
15
+ /**
16
+ * Reference to CollapsibleRoot
17
+ * @private
18
+ * @ignore
19
+ */
20
+ private readonly collapsible = injectCollapsible();
21
+
22
+ /**
23
+ * Called on trigger clicked
24
+ */
25
+ onOpenToggle(): void {
26
+ this.collapsible.setOpen();
27
+ }
28
+
29
+ /**
30
+ * Returns current directive state (open | closed)
31
+ * @ignore
32
+ */
33
+ getState(): RdxCollapsibleState {
34
+ return this.collapsible.getState();
35
+ }
36
+
37
+ /**
38
+ * Returns current trigger state
39
+ * @ignore
40
+ */
41
+ getDisabled(): string | undefined {
42
+ return this.collapsible.disabled ? 'disabled' : undefined;
43
+ }
44
+ }
@@ -0,0 +1,116 @@
1
+ import { animate, state, style, transition, trigger } from '@angular/animations';
2
+ import { Component } from '@angular/core';
3
+ import { LucideAngularModule } from 'lucide-angular';
4
+ import { RdxCollapsibleContentDirective } from '../src/collapsible-content.directive';
5
+ import { RdxCollapsibleRootDirective } from '../src/collapsible-root.directive';
6
+ import { RdxCollapsibleTriggerDirective } from '../src/collapsible-trigger.directive';
7
+
8
+ @Component({
9
+ selector: 'rdx-collapsible-animation',
10
+ standalone: true,
11
+ imports: [
12
+ RdxCollapsibleRootDirective,
13
+ RdxCollapsibleTriggerDirective,
14
+ RdxCollapsibleContentDirective,
15
+ LucideAngularModule
16
+ ],
17
+ // prettier-ignore
18
+ animations: [
19
+ trigger('contentExpansion', [
20
+ state('expanded', style({ height: '*', opacity: 1, visibility: 'visible' })),
21
+ state('collapsed', style({ height: '0px', opacity: 0, visibility: 'hidden' })),
22
+ transition('expanded <=> collapsed', animate('200ms cubic-bezier(.37,1.04,.68,.98)'))
23
+ ])
24
+ ],
25
+ styles: `
26
+ button {
27
+ all: unset;
28
+ }
29
+
30
+ .CollapsibleRoot {
31
+ width: 300px;
32
+ }
33
+
34
+ .IconButton {
35
+ font-family: inherit;
36
+ border-radius: 100%;
37
+ height: 25px;
38
+ width: 25px;
39
+ display: inline-flex;
40
+ align-items: center;
41
+ justify-content: center;
42
+ color: var(--violet-11);
43
+ box-shadow: 0 2px 10px var(--black-a7);
44
+ }
45
+
46
+ .IconButton[data-state='closed'] {
47
+ background-color: white;
48
+ }
49
+
50
+ .IconButton[data-state='open'] {
51
+ background-color: var(--violet-3);
52
+ }
53
+
54
+ .IconButton:hover {
55
+ background-color: var(--violet-3);
56
+ }
57
+
58
+ .IconButton:focus {
59
+ box-shadow: 0 0 0 2px black;
60
+ }
61
+
62
+ .Text {
63
+ color: var(--violet-11);
64
+ font-size: 15px;
65
+ line-height: 25px;
66
+ }
67
+
68
+ .Repository {
69
+ background-color: white;
70
+ border-radius: 4px;
71
+ margin: 10px 0;
72
+ padding: 10px;
73
+ box-shadow: 0 2px 10px var(--black-a7);
74
+ }
75
+ `,
76
+ template: `
77
+ <div
78
+ class="CollapsibleRoot"
79
+ #collapsibleRoot="collapsibleRoot"
80
+ [open]="open"
81
+ (onOpenChange)="onOpenChange($event)"
82
+ rdxCollapsibleRoot
83
+ >
84
+ <div style="display: flex; align-items: center; justify-content: space-between;">
85
+ <span class="Text" style="color: white">&#64;peduarte starred 3 repositories</span>
86
+ <button class="IconButton" rdxCollapsibleTrigger>
87
+ @if (open) {
88
+ <lucide-angular size="16" name="x" style="display: flex;" />
89
+ } @else {
90
+ <lucide-angular size="16" name="unfold-vertical" style="display: flex;" />
91
+ }
92
+ </button>
93
+ </div>
94
+
95
+ <div class="Repository">
96
+ <span class="Text">&#64;radix-ui/primitives</span>
97
+ </div>
98
+
99
+ <div [@contentExpansion]="collapsibleRoot.isOpen() ? 'expanded' : 'collapsed'" rdxCollapsibleContent>
100
+ <div class="Repository">
101
+ <span class="Text">&#64;radix-ui/colors</span>
102
+ </div>
103
+ <div class="Repository">
104
+ <span class="Text">&#64;stitches/react</span>
105
+ </div>
106
+ </div>
107
+ </div>
108
+ `
109
+ })
110
+ export class RdxCollapsibleAnimationComponent {
111
+ open = true;
112
+
113
+ onOpenChange($event: boolean) {
114
+ this.open = $event;
115
+ }
116
+ }
@@ -0,0 +1,86 @@
1
+ import { Component } from '@angular/core';
2
+ import { LucideAngularModule } from 'lucide-angular';
3
+ import { RdxCollapsibleContentDirective } from '../src/collapsible-content.directive';
4
+ import { RdxCollapsibleRootDirective } from '../src/collapsible-root.directive';
5
+
6
+ @Component({
7
+ selector: 'rdx-collapsible-external-triggering',
8
+ standalone: true,
9
+ imports: [
10
+ RdxCollapsibleRootDirective,
11
+ RdxCollapsibleContentDirective,
12
+ LucideAngularModule
13
+ ],
14
+ styles: `
15
+ .CollapsibleRoot {
16
+ width: 300px;
17
+ }
18
+
19
+ .ExternalTrigger {
20
+ font-family: inherit;
21
+ border-radius: 8px;
22
+
23
+ display: inline-flex;
24
+ align-items: center;
25
+ justify-content: center;
26
+ color: var(--violet-11);
27
+ box-shadow: 0 2px 10px var(--black-a7);
28
+ margin-bottom: 10px;
29
+ padding: 4px;
30
+ }
31
+
32
+ .ExternalTrigger[data-state='closed'] {
33
+ background-color: white;
34
+ }
35
+
36
+ .ExternalTrigger[data-state='open'] {
37
+ background-color: var(--violet-3);
38
+ }
39
+
40
+ .ExternalTrigger:hover {
41
+ background-color: var(--violet-3);
42
+ }
43
+
44
+ .ExternalTrigger:focus {
45
+ box-shadow: 0 0 0 2px black;
46
+ }
47
+
48
+ .Text {
49
+ color: var(--violet-11);
50
+ font-size: 15px;
51
+ line-height: 25px;
52
+ }
53
+
54
+ .Repository {
55
+ background-color: white;
56
+ border-radius: 4px;
57
+ margin: 10px 0;
58
+ padding: 10px;
59
+ box-shadow: 0 2px 10px var(--black-a7);
60
+ }
61
+ `,
62
+ template: `
63
+ <button class="ExternalTrigger" (click)="open = !open">External Trigger</button>
64
+ <div class="CollapsibleRoot" #collapsibleRoot="collapsibleRoot" [open]="open" rdxCollapsibleRoot>
65
+ <div style="display: flex; align-items: center; justify-content: space-between;">
66
+ <span class="Text" style="color: white">&#64;peduarte starred 3 repositories</span>
67
+ </div>
68
+
69
+ <div class="Repository">
70
+ <span class="Text">&#64;radix-ui/primitives</span>
71
+ </div>
72
+
73
+ <div rdxCollapsibleContent>
74
+ <div class="Repository">
75
+ <span class="Text">&#64;radix-ui/colors</span>
76
+ </div>
77
+ <div class="Repository">
78
+ <span class="Text">&#64;stitches/react</span>
79
+ </div>
80
+ </div>
81
+ </div>
82
+ `
83
+ })
84
+ export class RdxCollapsibleExternalTriggeringComponent {
85
+ open = true;
86
+ }
@@ -0,0 +1,53 @@
1
+ import { ArgTypes, Canvas, Meta } from '@storybook/blocks';
2
+ import * as CollapsibleStories from './collapsible.stories';
3
+ import { RdxCollapsibleRootDirective } from '../src/collapsible-root.directive';
4
+ import { RdxCollapsibleTriggerDirective } from '../src/collapsible-trigger.directive';
5
+ import { RdxCollapsibleContentDirective } from '../src/collapsible-content.directive';
6
+
7
+ <Meta title="Primitives/Collapsible" />
8
+
9
+ # Collapsible
10
+
11
+ #### An interactive component which expands/collapses a panel.
12
+
13
+ <Canvas sourceState="hidden" of={CollapsibleStories.Default} />
14
+
15
+ ## Features
16
+
17
+ - ✅ Full keyboard navigation.
18
+ - ✅ Can be controlled or uncontrolled.
19
+
20
+ ## Anatomy
21
+
22
+ ```html
23
+ <div rdxCollapsibleRoot [open]="...">
24
+ <button rdxCollapsibleTrigger>Trigger</button>
25
+ <div rdxCollapsibleContent>Content</div>
26
+ </div>
27
+ ```
28
+
29
+ ## Import
30
+
31
+ Get started with importing the directives:
32
+
33
+ ```typescript
34
+ import {
35
+ RdxCollapsibleRootDirective,
36
+ RdxCollapsibleTriggerDirective,
37
+ RdxCollapsibleContentDirective
38
+ } from '@radix-ng/primitives/collapsible';
39
+ ```
40
+
41
+ ## API Reference
42
+
43
+ ## RdxCollapsibleRootDirective
44
+
45
+ <ArgTypes of={RdxCollapsibleRootDirective} />
46
+
47
+ ## RdxCollapsibleTriggerDirective
48
+
49
+ <ArgTypes of={RdxCollapsibleTriggerDirective} />
50
+
51
+ ## RdxCollapsibleContentDirective
52
+
53
+ <ArgTypes of={RdxCollapsibleContentDirective} />
@@ -0,0 +1,151 @@
1
+ import { BrowserAnimationsModule, provideAnimations } from '@angular/platform-browser/animations';
2
+ import { componentWrapperDecorator, Meta, moduleMetadata, StoryObj } from '@storybook/angular';
3
+ import { LucideAngularModule, UnfoldVertical, X } from 'lucide-angular';
4
+ import { RdxCollapsibleContentDirective } from '../src/collapsible-content.directive';
5
+ import { RdxCollapsibleRootDirective } from '../src/collapsible-root.directive';
6
+ import { RdxCollapsibleTriggerDirective } from '../src/collapsible-trigger.directive';
7
+ import { RdxCollapsibleAnimationComponent } from './collapsible-animation.component';
8
+ import { RdxCollapsibleExternalTriggeringComponent } from './collapsible-external-triggering.component';
9
+
10
+ export default {
11
+ title: 'Primitives/Collapsible',
12
+ decorators: [
13
+ moduleMetadata({
14
+ imports: [
15
+ RdxCollapsibleRootDirective,
16
+ RdxCollapsibleTriggerDirective,
17
+ RdxCollapsibleContentDirective,
18
+ RdxCollapsibleExternalTriggeringComponent,
19
+ RdxCollapsibleAnimationComponent,
20
+ BrowserAnimationsModule,
21
+ LucideAngularModule,
22
+ LucideAngularModule.pick({ X, UnfoldVertical })
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
+ button {
38
+ all: unset;
39
+ }
40
+ .CollapsibleRoot {
41
+ width: 300px;
42
+ }
43
+
44
+ .IconButton {
45
+ font-family: inherit;
46
+ border-radius: 100%;
47
+ height: 25px;
48
+ width: 25px;
49
+ display: inline-flex;
50
+ align-items: center;
51
+ justify-content: center;
52
+ color: var(--violet-11);
53
+ box-shadow: 0 2px 10px var(--black-a7);
54
+ }
55
+
56
+ .IconButton[data-state='closed'] {
57
+ background-color: white;
58
+ }
59
+
60
+ .IconButton[data-state='open'] {
61
+ background-color: var(--violet-3);
62
+ }
63
+
64
+ .IconButton:hover {
65
+ background-color: var(--violet-3);
66
+ }
67
+
68
+ .IconButton:focus {
69
+ box-shadow: 0 0 0 2px black;
70
+ }
71
+
72
+ .Text {
73
+ color: var(--violet-11);
74
+ font-size: 15px;
75
+ line-height: 25px;
76
+ }
77
+
78
+ .Repository {
79
+ background-color: white;
80
+ border-radius: 4px;
81
+ margin: 10px 0;
82
+ padding: 10px;
83
+ box-shadow: 0 2px 10px var(--black-a7);
84
+ }
85
+ </style>`
86
+ )
87
+ ]
88
+ } as Meta;
89
+
90
+ type Story = StoryObj;
91
+
92
+ export const Default: Story = {
93
+ render: () => ({
94
+ template: `
95
+ <div class="CollapsibleRoot" rdxCollapsibleRoot [open]="true" #collapsibleRoot="collapsibleRoot">
96
+
97
+ <div style="display: flex; align-items: center; justify-content: space-between;">
98
+ <span class="Text" style="color: white">&#64;peduarte starred 3 repositories</span>
99
+ <button class="IconButton" rdxCollapsibleTrigger>
100
+ @if (collapsibleRoot.isOpen()) {
101
+ <lucide-angular size="16" name="x" style="display: flex;"></lucide-angular>
102
+ } @else {
103
+ <lucide-angular size="16" name="unfold-vertical" style="display: flex;"></lucide-angular>
104
+ }
105
+ </button>
106
+ </div>
107
+
108
+ <div class="Repository">
109
+ <span class="Text">&#64;radix-ui/primitives</span>
110
+ </div>
111
+
112
+ <div rdxCollapsibleContent>
113
+ <div class="Repository">
114
+ <span class="Text">&#64;radix-ui/colors</span>
115
+ </div>
116
+ <div class="Repository">
117
+ <span class="Text">&#64;stitches/react</span>
118
+ </div>
119
+ </div>
120
+ </div>
121
+ `
122
+ })
123
+ };
124
+
125
+ export const ExternalTrigger: Story = {
126
+ render: () => ({
127
+ template: `
128
+ <div class="radix-themes light light-theme radix-themes-default-fonts"
129
+ data-accent-color="indigo"
130
+ data-radius="medium"
131
+ data-scaling="100%"
132
+ >
133
+ <rdx-collapsible-external-triggering></rdx-collapsible-external-triggering>
134
+ </div>
135
+ `
136
+ })
137
+ };
138
+
139
+ export const Animation: Story = {
140
+ render: () => ({
141
+ template: `
142
+ <div class="radix-themes light light-theme radix-themes-default-fonts"
143
+ data-accent-color="indigo"
144
+ data-radius="medium"
145
+ data-scaling="100%"
146
+ >
147
+ <rdx-collapsible-animation></rdx-collapsible-animation>
148
+ </div>
149
+ `
150
+ })
151
+ };
@@ -0,0 +1 @@
1
+ # @radix-ng/primitives/context-menu