@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,212 @@
1
+ import { componentWrapperDecorator, Meta, moduleMetadata, StoryObj } from '@storybook/angular';
2
+ import { Check, Dot, LucideAngularModule, Menu } from 'lucide-angular';
3
+
4
+ import { RdxDropdownMenuContentDirective } from '../src/dropdown-menu-content.directive';
5
+ import { RdxDropdownMenuItemCheckboxDirective } from '../src/dropdown-menu-item-checkbox.directive';
6
+ import { RdxDropdownMenuItemIndicatorDirective } from '../src/dropdown-menu-item-indicator.directive';
7
+ import { RdxDropdownMenuItemDirective } from '../src/dropdown-menu-item.directive';
8
+ import { RdxDropdownMenuSeparatorDirective } from '../src/dropdown-menu-separator.directive';
9
+ import { RdxDropdownMenuTriggerDirective } from '../src/dropdown-menu-trigger.directive';
10
+ import { DropdownMenuItemCheckboxExampleComponent } from './dropdown-menu-item-checkbox.component';
11
+ import { DropdownMenuItemRadioExampleComponent } from './dropdown-menu-item-radio.component';
12
+
13
+ export default {
14
+ title: 'Primitives/Dropdown Menu',
15
+ decorators: [
16
+ moduleMetadata({
17
+ imports: [
18
+ RdxDropdownMenuTriggerDirective,
19
+ RdxDropdownMenuItemDirective,
20
+ RdxDropdownMenuItemCheckboxDirective,
21
+ RdxDropdownMenuItemIndicatorDirective,
22
+ RdxDropdownMenuSeparatorDirective,
23
+ RdxDropdownMenuContentDirective,
24
+ LucideAngularModule,
25
+ LucideAngularModule.pick({ Menu, Check, Dot }),
26
+ DropdownMenuItemCheckboxExampleComponent,
27
+ DropdownMenuItemRadioExampleComponent
28
+ ]
29
+ }),
30
+ componentWrapperDecorator(
31
+ (story) => `
32
+ <div class="radix-themes light light-theme radix-themes-default-fonts rt-Flex rt-r-ai-start rt-r-jc-center rt-r-position-relative"
33
+ data-accent-color="indigo"
34
+ data-radius="medium"
35
+ data-scaling="100%"
36
+ >
37
+ ${story}
38
+ </div>`
39
+ )
40
+ ]
41
+ } as Meta;
42
+
43
+ type Story = StoryObj;
44
+
45
+ export const Default: Story = {
46
+ render: () => ({
47
+ template: `
48
+ <button [rdxDropdownMenuTrigger]="menu"
49
+ sideOffset="4"
50
+ alignOffset="-5"
51
+ class="IconButton" aria-label="Customise options">
52
+ <lucide-angular size="16" name="menu" style="height: 1.2rem;"></lucide-angular>
53
+ </button>
54
+
55
+ <ng-template #menu>
56
+ <div class="DropdownMenuContent" rdxDropdownMenuContent>
57
+ <button class="DropdownMenuItem" rdxDropdownMenuItem>
58
+ New Tab <div class="RightSlot">⌘ T</div>
59
+ </button>
60
+ <button class="DropdownMenuItem" rdxDropdownMenuItem disabled>
61
+ New Window <div class="RightSlot">⌘ N</div>
62
+ </button>
63
+ <button class="DropdownMenuItem" rdxDropdownMenuItem>
64
+ New Incognito Window
65
+ </button>
66
+ <div rdxDropdownMenuSeparator class="DropdownMenuSeparator"></div>
67
+ <div class="DropdownMenuLabel" rdxDropdownMenuLabel>
68
+ Label
69
+ </div>
70
+ <button
71
+ class="DropdownMenuItem"
72
+ rdxDropdownMenuItem
73
+ [rdxDropdownMenuTrigger]="share"
74
+ [side]="'right'"
75
+ >
76
+ Share <div class="RightSlot">></div>
77
+ </button>
78
+ <div rdxDropdownMenuSeparator class="DropdownMenuSeparator"></div>
79
+ <button class="DropdownMenuItem" rdxDropdownMenuItem>
80
+ Print… <div class="RightSlot">⌘ P</div>
81
+ </button>
82
+ </div>
83
+ </ng-template>
84
+
85
+ <ng-template #share>
86
+ <div class="DropdownMenuContent" rdxDropdownMenuContent>
87
+ <button class="DropdownMenuItem" rdxDropdownMenuItem>Undo</button>
88
+ <button class="DropdownMenuItem" rdxDropdownMenuItem>Redo</button>
89
+ <div rdxDropdownMenuSeparator class="DropdownMenuSeparator"></div>
90
+ <button class="DropdownMenuItem" rdxDropdownMenuItem>Cut</button>
91
+ <button class="DropdownMenuItem" rdxDropdownMenuItem>Copy</button>
92
+ <button class="DropdownMenuItem" rdxDropdownMenuItem>Paste</button>
93
+ </div>
94
+ </ng-template>
95
+
96
+ <style>
97
+ /* reset */
98
+ button {
99
+ all: unset;
100
+ }
101
+
102
+ .DropdownMenuContent {
103
+ flex-direction: column;
104
+ display: inline-flex;
105
+ min-width: 220px;
106
+ background-color: white;
107
+ border-radius: 6px;
108
+ padding: 5px;
109
+ box-shadow: 0px 10px 38px -10px rgba(22, 23, 24, 0.35), 0px 10px 20px -15px rgba(22, 23, 24, 0.2);
110
+ will-change: transform, opacity;
111
+ }
112
+
113
+ .DropdownMenuItem,
114
+ .DropdownMenuCheckboxItem,
115
+ .DropdownMenuRadioItem {
116
+ font-size: 13px;
117
+ line-height: 1;
118
+ color: var(--violet-11);
119
+ border-radius: 3px;
120
+ display: flex;
121
+ align-items: center;
122
+ height: 25px;
123
+ position: relative;
124
+ padding: 0 5px 0 25px;
125
+ user-select: none;
126
+ outline: none;
127
+ }
128
+
129
+ .DropdownMenuItem[data-disabled],
130
+ .DropdownMenuCheckboxItem[data-disabled],
131
+ .DropdownMenuRadioItem[data-disabled] {
132
+ color: var(--mauve-8);
133
+ pointer-events: none;
134
+ }
135
+ .DropdownMenuItem[data-highlighted],
136
+ .DropdownMenuCheckboxItem[data-highlighted],
137
+ .DropdownMenuRadioItem[data-highlighted] {
138
+ background-color: var(--violet-9);
139
+ color: var(--violet-1);
140
+ }
141
+
142
+ .DropdownMenuSeparator {
143
+ height: 1px;
144
+ background-color: var(--violet-6);
145
+ margin: 5px;
146
+ }
147
+
148
+ .DropdownMenuLabel {
149
+ padding-left: 25px;
150
+ font-size: 12px;
151
+ line-height: 25px;
152
+ color: var(--mauve-11);
153
+ }
154
+
155
+ .IconButton {
156
+ font-family: inherit;
157
+ border-radius: 100%;
158
+ height: 35px;
159
+ width: 35px;
160
+ display: inline-flex;
161
+ align-items: center;
162
+ justify-content: center;
163
+ color: var(--violet-11);
164
+ background-color: white;
165
+ box-shadow: 0 2px 10px var(--black-a7);
166
+ }
167
+
168
+ .DropdownMenuItemIndicator {
169
+ position: absolute;
170
+ left: 4px;
171
+ width: 25px;
172
+ display: inline-flex;
173
+ align-items: center;
174
+ justify-content: center;
175
+ }
176
+
177
+ .IconButton:hover {
178
+ background-color: var(--violet-3);
179
+ }
180
+
181
+ .IconButton:focus {
182
+ box-shadow: 0 0 0 2px black;
183
+ }
184
+
185
+ .RightSlot {
186
+ margin-left: auto;
187
+ padding-left: 20px;
188
+ color: var(--mauve-9);
189
+ display: flex;
190
+ flex-direction: row;
191
+ flex: 1;
192
+ justify-content: flex-end;
193
+ }
194
+
195
+ </style>
196
+ `
197
+ })
198
+ };
199
+
200
+ export const DropdownMenuItemCheckbox: Story = {
201
+ name: 'Checkbox',
202
+ render: () => ({
203
+ template: `<dropdown-menu-item-checkbox/>`
204
+ })
205
+ };
206
+
207
+ export const DropdownMenuItemRadio: Story = {
208
+ name: 'Radio',
209
+ render: () => ({
210
+ template: `<dropdown-menu-item-radio/>`
211
+ })
212
+ };
@@ -0,0 +1 @@
1
+ export * from './src/form-field-control';
File without changes
package/jest.config.ts ADDED
@@ -0,0 +1,21 @@
1
+ export default {
2
+ displayName: 'primitives',
3
+ preset: '../../jest.preset.cjs',
4
+ setupFilesAfterEnv: ['<rootDir>/test-setup.ts'],
5
+ coverageDirectory: '../../coverage/packages/primitives',
6
+ transform: {
7
+ '^.+\\.(ts|mjs|js|html)$': [
8
+ 'jest-preset-angular',
9
+ {
10
+ tsconfig: '<rootDir>/tsconfig.spec.json',
11
+ stringifyContentPathRegex: '\\.(html|svg)$'
12
+ }
13
+ ]
14
+ },
15
+ transformIgnorePatterns: ['node_modules/(?!.*\\.mjs$)'],
16
+ snapshotSerializers: [
17
+ 'jest-preset-angular/build/serializers/no-ng-attributes',
18
+ 'jest-preset-angular/build/serializers/ng-snapshot',
19
+ 'jest-preset-angular/build/serializers/html-comment'
20
+ ]
21
+ };
@@ -0,0 +1,99 @@
1
+ import { Component, DebugElement } from '@angular/core';
2
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
3
+ import { By } from '@angular/platform-browser';
4
+ import { RdxLabelDirective } from '../src/label.directive';
5
+
6
+ /* Explanation:
7
+
8
+ Environment Setup: In addition to the label, the template now includes a div and an input button to test interaction with different types of elements.
9
+
10
+ Double-click Prevention: Tests whether the directive correctly prevents default actions during a double-click, except on form elements like buttons.
11
+
12
+ Single Click Handling: Verifies that the directive does not interfere with default actions on single clicks.
13
+
14
+ Interaction with Children: Checks that double-clicks on non-form elements like divs also trigger prevention of default actions.*/
15
+ @Component({
16
+ template: `
17
+ <label rdxLabel>
18
+ Test Label
19
+ <div>Click Me</div>
20
+ <input type="button" value="Button" />
21
+ </label>
22
+ `
23
+ })
24
+ class TestComponent {}
25
+
26
+ describe('RdxLabelDirective', () => {
27
+ let fixture: ComponentFixture<TestComponent>;
28
+ let labelElement: DebugElement;
29
+ let inputElement: DebugElement;
30
+ let divElement: DebugElement;
31
+
32
+ beforeEach(async () => {
33
+ await TestBed.configureTestingModule({
34
+ imports: [RdxLabelDirective],
35
+ declarations: [TestComponent]
36
+ }).compileComponents();
37
+
38
+ fixture = TestBed.createComponent(TestComponent);
39
+ fixture.detectChanges();
40
+ labelElement = fixture.debugElement.query(By.directive(RdxLabelDirective));
41
+ inputElement = fixture.debugElement.query(By.css('input'));
42
+ divElement = fixture.debugElement.query(By.css('div'));
43
+ });
44
+
45
+ it('should create an instance of the directive', () => {
46
+ expect(labelElement).toBeTruthy();
47
+ });
48
+
49
+ it('should prevent default action on double-clicking the label, not on input elements', () => {
50
+ const mockEventLabel = new MouseEvent('mousedown', {
51
+ bubbles: true,
52
+ cancelable: true,
53
+ detail: 2
54
+ });
55
+ Object.defineProperty(mockEventLabel, 'target', { value: labelElement.nativeElement });
56
+ jest.spyOn(mockEventLabel, 'preventDefault');
57
+
58
+ labelElement.triggerEventHandler('mousedown', mockEventLabel);
59
+ expect(mockEventLabel.preventDefault).toHaveBeenCalled();
60
+
61
+ // Double-click event targeting the input element
62
+ const mockEventInput = new MouseEvent('mousedown', {
63
+ bubbles: true,
64
+ cancelable: true,
65
+ detail: 2
66
+ });
67
+ Object.defineProperty(mockEventInput, 'target', { value: inputElement.nativeElement });
68
+ jest.spyOn(mockEventInput, 'preventDefault');
69
+
70
+ labelElement.triggerEventHandler('mousedown', mockEventInput);
71
+ expect(mockEventInput.preventDefault).not.toHaveBeenCalled();
72
+ });
73
+
74
+ it('should not prevent default action on single clicks', () => {
75
+ const mockEvent = new MouseEvent('mousedown', {
76
+ bubbles: true,
77
+ cancelable: true,
78
+ detail: 1
79
+ });
80
+ Object.defineProperty(mockEvent, 'target', { value: labelElement.nativeElement });
81
+ jest.spyOn(mockEvent, 'preventDefault');
82
+
83
+ labelElement.triggerEventHandler('mousedown', mockEvent);
84
+ expect(mockEvent.preventDefault).not.toHaveBeenCalled();
85
+ });
86
+
87
+ it('should prevent default action when double-clicking non-button/input/select/textarea elements within the label', () => {
88
+ const mockEvent = new MouseEvent('mousedown', {
89
+ bubbles: true,
90
+ cancelable: true,
91
+ detail: 2
92
+ });
93
+ Object.defineProperty(mockEvent, 'target', { value: divElement.nativeElement });
94
+ jest.spyOn(mockEvent, 'preventDefault');
95
+
96
+ labelElement.triggerEventHandler('mousedown', mockEvent);
97
+ expect(mockEvent.preventDefault).toHaveBeenCalled();
98
+ });
99
+ });
@@ -0,0 +1,5 @@
1
+ {
2
+ "lib": {
3
+ "entryFile": "index.ts"
4
+ }
5
+ }
@@ -0,0 +1,58 @@
1
+ import { computed, Directive, ElementRef, inject, input, InputSignal } from '@angular/core';
2
+
3
+ let idIterator = 0;
4
+
5
+ @Directive({
6
+ selector: 'label[rdxLabel]',
7
+ exportAs: 'rdxLabel',
8
+ standalone: true,
9
+ host: {
10
+ '[attr.id]': 'this.elementId()',
11
+ '[attr.for]': 'htmlFor ? htmlFor() : null',
12
+ '(mousedown)': 'onMouseDown($event)'
13
+ }
14
+ })
15
+ export class RdxLabelDirective {
16
+ /**
17
+ * @type string
18
+ * @default 'rdx-label-{idIterator}'
19
+ */
20
+ readonly id: InputSignal<string> = input<string>(`rdx-label-${idIterator++}`);
21
+
22
+ /**
23
+ * @ignore
24
+ */
25
+ protected readonly elementId = computed(() => (this.id() ? this.id() : null));
26
+
27
+ /**
28
+ * The id of the element the label is associated with.
29
+ * @type string
30
+ * @default false
31
+ */
32
+ readonly htmlFor: InputSignal<string> = input<string>('');
33
+
34
+ /**
35
+ * @ignore
36
+ */
37
+ private readonly elementRef = inject(ElementRef<HTMLElement>);
38
+
39
+ // prevent text selection when double-clicking label
40
+ // The main problem with double-clicks in a web app is that
41
+ // you will have to create special code to handle this on touch enabled devices.
42
+ /**
43
+ * @ignore
44
+ */
45
+ onMouseDown(event: MouseEvent): void {
46
+ const target = event.target as HTMLElement;
47
+
48
+ // only prevent text selection if clicking inside the label itself
49
+ if (['BUTTON', 'INPUT', 'SELECT', 'TEXTAREA'].includes(target.tagName)) {
50
+ return;
51
+ }
52
+
53
+ // prevent text selection when double-clicking label
54
+ if (this.elementRef.nativeElement.contains(target) && !event.defaultPrevented && event.detail > 1) {
55
+ event.preventDefault();
56
+ }
57
+ }
58
+ }
@@ -0,0 +1,40 @@
1
+ import { ArgTypes, Canvas, Meta } from '@storybook/blocks';
2
+ import { RdxLabelDirective } from '../src/label.directive';
3
+ import * as LabelDirectiveStories from './label.stories';
4
+
5
+ <Meta title="Primitives/Label" />
6
+
7
+ # Label
8
+
9
+ #### Renders an accessible label associated with controls.
10
+
11
+ <Canvas sourceState="hidden" of={LabelDirectiveStories.Default} />
12
+
13
+ ## Features
14
+
15
+ - ✅ Text selection is prevented when double-clicking label.
16
+
17
+ ## Import
18
+
19
+ Get started with importing the directive:
20
+
21
+ ```typescript
22
+ import { RdxLabelDirective } from '@radix-ng/primitives/label';
23
+ ```
24
+
25
+ ## Examples
26
+
27
+ ```html
28
+ <label rdxLabel htmlFor="uniqId">First name</label>
29
+ <input class="Input" id="uniqId" type="text" />
30
+ ```
31
+
32
+ ## API Reference
33
+
34
+ <ArgTypes of={RdxLabelDirective} />
35
+
36
+ ## Accessibility
37
+
38
+ This component is based on the native `label` element, it will automatically apply the correct labelling
39
+ when wrapping controls or using the `for` attribute. For your own custom controls
40
+ to work correctly, ensure they use native elements such as `button` or `input` as a base.
@@ -0,0 +1,76 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { componentWrapperDecorator, Meta, moduleMetadata, StoryObj } from '@storybook/angular';
3
+ import { labelExclude } from '../../../../apps/storybook-radix/docs/utils/storybook';
4
+ import { RdxLabelDirective } from '../src/label.directive';
5
+
6
+ export default {
7
+ component: RdxLabelDirective,
8
+ title: 'Primitives/Label',
9
+ parameters: {
10
+ controls: {
11
+ exclude: labelExclude
12
+ }
13
+ },
14
+ decorators: [
15
+ moduleMetadata({
16
+ imports: [RdxLabelDirective, CommonModule]
17
+ }),
18
+ componentWrapperDecorator(
19
+ (story) =>
20
+ `<div class="radix-themes light light-theme"
21
+ data-radius="medium"
22
+ data-scaling="100%">${story}</div>`
23
+ )
24
+ ]
25
+ } as Meta<RdxLabelDirective>;
26
+
27
+ type Story = StoryObj<RdxLabelDirective>;
28
+
29
+ export const Default: Story = {
30
+ render: (args) => ({
31
+ props: {
32
+ ...args
33
+ },
34
+ template: `
35
+ <label rdxLabel htmlFor="uniqId">First Name </label>
36
+ <input type="text" class="Input" id="uniqId" />
37
+
38
+ <style>
39
+ input {
40
+ all: unset;
41
+ }
42
+
43
+ .Input {
44
+ width: 200px;
45
+ display: inline-flex;
46
+ align-items: center;
47
+ justify-content: center;
48
+ border-radius: 4px;
49
+ padding: 0 10px;
50
+ margin-left: 10px;
51
+ height: 35px;
52
+ font-size: 15px;
53
+ line-height: 1;
54
+ color: white;
55
+ background-color: var(--black-a5);
56
+ box-shadow: 0 0 0 1px var(--black-a9);
57
+ }
58
+
59
+ .Input:focus {
60
+ box-shadow: 0 0 0 2px black;
61
+ }
62
+ .Input::selection {
63
+ background-color: var(--black-a9);
64
+ color: white;
65
+ }
66
+
67
+ label {
68
+ color: white;
69
+ font-size: 15px;
70
+ line-height: 35px;
71
+ font-weight: 500;
72
+ }
73
+ </style>
74
+ `
75
+ })
76
+ };
package/menu/index.ts ADDED
@@ -0,0 +1,29 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { RdxMenuContentDirective } from './src/menu-content.directive';
3
+ import { RdxMenuDirective } from './src/menu-directive';
4
+ import { RdxMenuGroupDirective } from './src/menu-group.directive';
5
+ import { RdxMenuItemDirective } from './src/menu-item.directive';
6
+ import { RdxMenuLabelDirective } from './src/menu-label.directive';
7
+ import { RdxMenuSeparatorDirective } from './src/menu-separator.directive';
8
+
9
+ export * from './src/menu-content.directive';
10
+ export * from './src/menu-directive';
11
+ export * from './src/menu-group.directive';
12
+ export * from './src/menu-item.directive';
13
+ export * from './src/menu-label.directive';
14
+ export * from './src/menu-separator.directive';
15
+
16
+ const menuImports = [
17
+ RdxMenuDirective,
18
+ RdxMenuGroupDirective,
19
+ RdxMenuItemDirective,
20
+ RdxMenuSeparatorDirective,
21
+ RdxMenuContentDirective,
22
+ RdxMenuLabelDirective
23
+ ];
24
+
25
+ @NgModule({
26
+ imports: [...menuImports],
27
+ exports: [...menuImports]
28
+ })
29
+ export class MenuModule {}
@@ -0,0 +1,5 @@
1
+ {
2
+ "lib": {
3
+ "entryFile": "index.ts"
4
+ }
5
+ }
@@ -0,0 +1,9 @@
1
+ import { CdkMenu } from '@angular/cdk/menu';
2
+ import { Directive } from '@angular/core';
3
+
4
+ @Directive({
5
+ selector: '[MenuContent]',
6
+ standalone: true,
7
+ hostDirectives: [CdkMenu]
8
+ })
9
+ export class RdxMenuContentDirective {}
@@ -0,0 +1,10 @@
1
+ import { CdkMenu } from '@angular/cdk/menu';
2
+ import { Directive } from '@angular/core';
3
+
4
+ @Directive({
5
+ selector: '[Menu],[MenuSub]',
6
+ standalone: true,
7
+ host: {},
8
+ hostDirectives: [CdkMenu]
9
+ })
10
+ export class RdxMenuDirective {}
@@ -0,0 +1,12 @@
1
+ import { CdkMenuGroup } from '@angular/cdk/menu';
2
+ import { Directive } from '@angular/core';
3
+
4
+ @Directive({
5
+ selector: '[MenuGroup]',
6
+ standalone: true,
7
+ hostDirectives: [CdkMenuGroup],
8
+ host: {
9
+ role: 'group'
10
+ }
11
+ })
12
+ export class RdxMenuGroupDirective {}
@@ -0,0 +1,44 @@
1
+ import { BooleanInput } from '@angular/cdk/coercion';
2
+ import { CdkMenuItem } from '@angular/cdk/menu';
3
+ import { booleanAttribute, computed, Directive, effect, inject, input, Output } from '@angular/core';
4
+
5
+ // type radixProps = {
6
+ // disabled: boolean;
7
+ // onSelect: () => {};
8
+ // };
9
+
10
+ @Directive({
11
+ selector: '[MenuItem]',
12
+ standalone: true,
13
+ hostDirectives: [CdkMenuItem],
14
+ host: {
15
+ role: 'menuitem',
16
+ type: 'button',
17
+ tabindex: '0',
18
+ '[attr.data-orientation]': "'horizontal'",
19
+ //'[attr.data-highlighted]': "",
20
+ '[attr.data-disabled]': "disabledState() ? '' : undefined",
21
+ '[disabled]': 'disabledState()'
22
+ }
23
+ })
24
+ export class RdxMenuItemDirective {
25
+ private readonly cdkMenuItem = inject(CdkMenuItem, { host: true });
26
+
27
+ // When true, prevents the user from interacting with the item.
28
+ readonly disabled = input<boolean, BooleanInput>(false, {
29
+ transform: booleanAttribute,
30
+ alias: 'rdxDisabled'
31
+ });
32
+
33
+ protected readonly disabledState = computed(() => this.disabled());
34
+
35
+ // Event handler called when the user selects an item (via mouse or keyboard).
36
+ @Output()
37
+ onSelect = this.cdkMenuItem.triggered;
38
+
39
+ constructor() {
40
+ effect(() => {
41
+ this.cdkMenuItem.disabled = this.disabled();
42
+ });
43
+ }
44
+ }
@@ -0,0 +1,7 @@
1
+ import { Directive } from '@angular/core';
2
+
3
+ @Directive({
4
+ selector: 'div[MenuLabel]',
5
+ standalone: true
6
+ })
7
+ export class RdxMenuLabelDirective {}
@@ -0,0 +1,13 @@
1
+ import { Directive } from '@angular/core';
2
+ import { RdxSeparatorRootDirective } from '@radix-ng/primitives/separator';
3
+
4
+ @Directive({
5
+ selector: '[MenuSeparator]',
6
+ standalone: true,
7
+ hostDirectives: [RdxSeparatorRootDirective],
8
+ host: {
9
+ role: 'separator',
10
+ '[attr.aria-orientation]': "'horizontal'"
11
+ }
12
+ })
13
+ export class RdxMenuSeparatorDirective {}