@radix-ng/primitives 0.12.1 → 0.13.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 (497) hide show
  1. package/README.md +3 -1
  2. package/accordion/index.d.ts +16 -0
  3. package/accordion/src/accordion-content.directive.d.ts +11 -0
  4. package/accordion/src/accordion-header.directive.d.ts +7 -0
  5. package/accordion/src/accordion-item.directive.d.ts +82 -0
  6. package/accordion/src/accordion-root.directive.d.ts +93 -0
  7. package/accordion/src/accordion-trigger.directive.d.ts +15 -0
  8. package/alert-dialog/{index.ts → index.d.ts} +0 -1
  9. package/alert-dialog/src/alert-dialog-cancel.directive.d.ts +7 -0
  10. package/alert-dialog/src/alert-dialog-content.directive.d.ts +9 -0
  11. package/alert-dialog/src/alert-dialog-root.directive.d.ts +9 -0
  12. package/alert-dialog/src/alert-dialog-title.directive.d.ts +5 -0
  13. package/alert-dialog/src/alert-dialog-trigger.directive.d.ts +7 -0
  14. package/alert-dialog/src/alert-dialog.service.d.ts +14 -0
  15. package/avatar/src/avatar-fallback.directive.d.ts +28 -0
  16. package/avatar/src/avatar-image.directive.d.ts +21 -0
  17. package/avatar/src/avatar-root.directive.d.ts +21 -0
  18. package/avatar/src/avatar.config.d.ts +13 -0
  19. package/checkbox/src/checkbox-button.directive.d.ts +8 -0
  20. package/checkbox/src/checkbox-indicator.directive.d.ts +6 -0
  21. package/checkbox/src/checkbox-input.directive.d.ts +9 -0
  22. package/checkbox/src/checkbox.directive.d.ts +75 -0
  23. package/checkbox/src/checkbox.token.d.ts +4 -0
  24. package/collapsible/src/collapsible-content.directive.d.ts +17 -0
  25. package/collapsible/src/collapsible-content.token.d.ts +3 -0
  26. package/collapsible/src/collapsible-root.directive.d.ts +55 -0
  27. package/collapsible/src/collapsible-trigger.directive.d.ts +26 -0
  28. package/compodoc/documentation.json +14249 -0
  29. package/context-menu/index.d.ts +26 -0
  30. package/context-menu/src/context-menu-content.directive.d.ts +15 -0
  31. package/context-menu/src/context-menu-item-checkbox.directive.d.ts +9 -0
  32. package/context-menu/src/context-menu-item-indicator.directive.d.ts +7 -0
  33. package/context-menu/src/context-menu-item-radio-group.directive.d.ts +12 -0
  34. package/context-menu/src/context-menu-item-radio.directive.d.ts +19 -0
  35. package/context-menu/src/context-menu-item-selectable.d.ts +12 -0
  36. package/context-menu/src/context-menu-item.directive.d.ts +17 -0
  37. package/context-menu/src/context-menu-label.directive.d.ts +5 -0
  38. package/context-menu/src/context-menu-separator.directive.d.ts +6 -0
  39. package/context-menu/src/context-menu-trigger.directive.d.ts +31 -0
  40. package/dialog/index.d.ts +23 -0
  41. package/dialog/src/dialog-close.directive.d.ts +7 -0
  42. package/dialog/src/dialog-content.directive.d.ts +21 -0
  43. package/dialog/src/dialog-description.directive.d.ts +5 -0
  44. package/dialog/src/dialog-dismiss.directive.d.ts +7 -0
  45. package/dialog/src/dialog-ref.d.ts +37 -0
  46. package/dialog/src/dialog-title.directive.d.ts +5 -0
  47. package/dialog/src/dialog-trigger.directive.d.ts +16 -0
  48. package/dialog/src/dialog.config.d.ts +39 -0
  49. package/dialog/src/dialog.injectors.d.ts +4 -0
  50. package/dialog/src/{dialog.providers.ts → dialog.providers.d.ts} +3 -11
  51. package/dialog/src/dialog.service.d.ts +26 -0
  52. package/dropdown-menu/index.d.ts +26 -0
  53. package/dropdown-menu/src/dropdown-menu-content.directive.d.ts +15 -0
  54. package/dropdown-menu/src/dropdown-menu-item-checkbox.directive.d.ts +9 -0
  55. package/dropdown-menu/src/dropdown-menu-item-indicator.directive.d.ts +7 -0
  56. package/dropdown-menu/src/dropdown-menu-item-radio-group.directive.d.ts +12 -0
  57. package/dropdown-menu/src/dropdown-menu-item-radio.directive.d.ts +19 -0
  58. package/dropdown-menu/src/dropdown-menu-item-selectable.d.ts +12 -0
  59. package/dropdown-menu/src/dropdown-menu-item.directive.d.ts +17 -0
  60. package/dropdown-menu/src/dropdown-menu-label.directive.d.ts +5 -0
  61. package/dropdown-menu/src/dropdown-menu-separator.directive.d.ts +6 -0
  62. package/dropdown-menu/src/dropdown-menu-trigger.directive.d.ts +46 -0
  63. package/esm2022/accordion/index.mjs +40 -0
  64. package/esm2022/accordion/radix-ng-primitives-accordion.mjs +5 -0
  65. package/esm2022/accordion/src/accordion-content.directive.mjs +42 -0
  66. package/esm2022/accordion/src/accordion-header.directive.mjs +23 -0
  67. package/esm2022/accordion/src/accordion-item.directive.mjs +187 -0
  68. package/esm2022/accordion/src/accordion-root.directive.mjs +172 -0
  69. package/esm2022/accordion/src/accordion-trigger.directive.mjs +42 -0
  70. package/esm2022/alert-dialog/index.mjs +7 -0
  71. package/esm2022/alert-dialog/radix-ng-primitives-alert-dialog.mjs +5 -0
  72. package/esm2022/alert-dialog/src/alert-dialog-cancel.directive.mjs +24 -0
  73. package/esm2022/alert-dialog/src/alert-dialog-content.directive.mjs +34 -0
  74. package/esm2022/alert-dialog/src/alert-dialog-root.directive.mjs +24 -0
  75. package/esm2022/alert-dialog/src/alert-dialog-title.directive.mjs +14 -0
  76. package/esm2022/alert-dialog/src/alert-dialog-trigger.directive.mjs +24 -0
  77. package/esm2022/alert-dialog/src/alert-dialog.service.mjs +46 -0
  78. package/esm2022/avatar/index.mjs +5 -0
  79. package/esm2022/avatar/radix-ng-primitives-avatar.mjs +5 -0
  80. package/esm2022/avatar/src/avatar-fallback.directive.mjs +60 -0
  81. package/esm2022/avatar/src/avatar-image.directive.mjs +52 -0
  82. package/esm2022/avatar/src/avatar-root.directive.mjs +38 -0
  83. package/esm2022/avatar/src/avatar.config.mjs +17 -0
  84. package/esm2022/checkbox/index.mjs +6 -0
  85. package/esm2022/checkbox/radix-ng-primitives-checkbox.mjs +5 -0
  86. package/esm2022/checkbox/src/checkbox-button.directive.mjs +33 -0
  87. package/esm2022/checkbox/src/checkbox-indicator.directive.mjs +24 -0
  88. package/esm2022/checkbox/src/checkbox-input.directive.mjs +41 -0
  89. package/esm2022/checkbox/src/checkbox.directive.mjs +141 -0
  90. package/esm2022/checkbox/src/checkbox.token.mjs +6 -0
  91. package/esm2022/collapsible/index.mjs +4 -0
  92. package/esm2022/collapsible/radix-ng-primitives-collapsible.mjs +5 -0
  93. package/esm2022/collapsible/src/collapsible-content.directive.mjs +45 -0
  94. package/esm2022/collapsible/src/collapsible-content.token.mjs +3 -0
  95. package/esm2022/collapsible/src/collapsible-root.directive.mjs +118 -0
  96. package/esm2022/collapsible/src/collapsible-trigger.directive.mjs +49 -0
  97. package/esm2022/context-menu/index.mjs +65 -0
  98. package/esm2022/context-menu/radix-ng-primitives-context-menu.mjs +5 -0
  99. package/esm2022/context-menu/src/context-menu-content.directive.mjs +56 -0
  100. package/esm2022/context-menu/src/context-menu-item-checkbox.directive.mjs +39 -0
  101. package/esm2022/context-menu/src/context-menu-item-indicator.directive.mjs +22 -0
  102. package/esm2022/context-menu/src/context-menu-item-radio-group.directive.mjs +37 -0
  103. package/esm2022/context-menu/src/context-menu-item-radio.directive.mjs +67 -0
  104. package/esm2022/context-menu/src/context-menu-item-selectable.mjs +31 -0
  105. package/esm2022/context-menu/src/context-menu-item.directive.mjs +70 -0
  106. package/esm2022/context-menu/src/context-menu-label.directive.mjs +14 -0
  107. package/esm2022/context-menu/src/context-menu-separator.directive.mjs +21 -0
  108. package/esm2022/context-menu/src/context-menu-trigger.directive.mjs +92 -0
  109. package/esm2022/dialog/index.mjs +50 -0
  110. package/esm2022/dialog/radix-ng-primitives-dialog.mjs +5 -0
  111. package/esm2022/dialog/src/dialog-close.directive.mjs +25 -0
  112. package/esm2022/dialog/src/dialog-content.directive.mjs +46 -0
  113. package/esm2022/dialog/src/dialog-description.directive.mjs +14 -0
  114. package/esm2022/dialog/src/dialog-dismiss.directive.mjs +25 -0
  115. package/esm2022/dialog/src/dialog-ref.mjs +46 -0
  116. package/esm2022/dialog/src/dialog-title.directive.mjs +14 -0
  117. package/esm2022/dialog/src/dialog-trigger.directive.mjs +54 -0
  118. package/esm2022/dialog/src/dialog.config.mjs +6 -0
  119. package/esm2022/dialog/src/dialog.injectors.mjs +10 -0
  120. package/esm2022/dialog/src/dialog.providers.mjs +26 -0
  121. package/esm2022/dialog/src/dialog.service.mjs +96 -0
  122. package/esm2022/dropdown-menu/index.mjs +68 -0
  123. package/esm2022/dropdown-menu/radix-ng-primitives-dropdown-menu.mjs +5 -0
  124. package/esm2022/dropdown-menu/src/dropdown-menu-content.directive.mjs +56 -0
  125. package/esm2022/dropdown-menu/src/dropdown-menu-item-checkbox.directive.mjs +39 -0
  126. package/esm2022/dropdown-menu/src/dropdown-menu-item-indicator.directive.mjs +22 -0
  127. package/esm2022/dropdown-menu/src/dropdown-menu-item-radio-group.directive.mjs +37 -0
  128. package/esm2022/dropdown-menu/src/dropdown-menu-item-radio.directive.mjs +67 -0
  129. package/esm2022/dropdown-menu/src/dropdown-menu-item-selectable.mjs +31 -0
  130. package/esm2022/dropdown-menu/src/dropdown-menu-item.directive.mjs +71 -0
  131. package/esm2022/dropdown-menu/src/dropdown-menu-label.directive.mjs +14 -0
  132. package/esm2022/dropdown-menu/src/dropdown-menu-separator.directive.mjs +21 -0
  133. package/esm2022/dropdown-menu/src/dropdown-menu-trigger.directive.mjs +179 -0
  134. package/esm2022/index.mjs +2 -0
  135. package/esm2022/label/index.mjs +2 -0
  136. package/esm2022/label/radix-ng-primitives-label.mjs +5 -0
  137. package/esm2022/label/src/label.directive.mjs +59 -0
  138. package/esm2022/menu/index.mjs +45 -0
  139. package/esm2022/menu/radix-ng-primitives-menu.mjs +5 -0
  140. package/esm2022/menu/src/menu-content.directive.mjs +17 -0
  141. package/esm2022/menu/src/menu-directive.mjs +18 -0
  142. package/esm2022/menu/src/menu-group.directive.mjs +20 -0
  143. package/esm2022/menu/src/menu-item.directive.mjs +46 -0
  144. package/esm2022/menu/src/menu-label.directive.mjs +14 -0
  145. package/esm2022/menu/src/menu-separator.directive.mjs +21 -0
  146. package/esm2022/menubar/index.mjs +60 -0
  147. package/esm2022/menubar/radix-ng-primitives-menubar.mjs +5 -0
  148. package/esm2022/menubar/src/menubar-content.directive.mjs +17 -0
  149. package/esm2022/menubar/src/menubar-item-checkbox.directive.mjs +34 -0
  150. package/esm2022/menubar/src/menubar-item-indicator.directive.mjs +17 -0
  151. package/esm2022/menubar/src/menubar-item-radio.directive.mjs +35 -0
  152. package/esm2022/menubar/src/menubar-item.directive.mjs +20 -0
  153. package/esm2022/menubar/src/menubar-radio-group.directive.mjs +17 -0
  154. package/esm2022/menubar/src/menubar-root.directive.mjs +24 -0
  155. package/esm2022/menubar/src/menubar-separator.directive.mjs +17 -0
  156. package/esm2022/menubar/src/menubar-trigger.directive.mjs +45 -0
  157. package/esm2022/progress/index.mjs +25 -0
  158. package/esm2022/progress/radix-ng-primitives-progress.mjs +5 -0
  159. package/esm2022/progress/src/progress-indicator.directive.mjs +34 -0
  160. package/esm2022/progress/src/progress-root.directive.mjs +127 -0
  161. package/esm2022/radio/index.mjs +4 -0
  162. package/esm2022/radio/radix-ng-primitives-radio.mjs +5 -0
  163. package/esm2022/radio/src/radio-indicator.directive.mjs +25 -0
  164. package/esm2022/radio/src/radio-item.directive.mjs +70 -0
  165. package/esm2022/radio/src/radio-root.directive.mjs +194 -0
  166. package/esm2022/radio/src/radio-tokens.mjs +3 -0
  167. package/esm2022/radix-ng-primitives.mjs +5 -0
  168. package/esm2022/separator/index.mjs +2 -0
  169. package/esm2022/separator/radix-ng-primitives-separator.mjs +5 -0
  170. package/esm2022/separator/src/separator.directive.mjs +32 -0
  171. package/esm2022/switch/index.mjs +30 -0
  172. package/esm2022/switch/radix-ng-primitives-switch.mjs +5 -0
  173. package/esm2022/switch/src/switch-input.directive.mjs +32 -0
  174. package/esm2022/switch/src/switch-root.directive.mjs +95 -0
  175. package/esm2022/switch/src/switch-thumb.directive.mjs +23 -0
  176. package/esm2022/tabs/index.mjs +38 -0
  177. package/esm2022/tabs/radix-ng-primitives-tabs.mjs +5 -0
  178. package/esm2022/tabs/src/tabs-content.directive.mjs +29 -0
  179. package/esm2022/tabs/src/tabs-context.service.mjs +43 -0
  180. package/esm2022/tabs/src/tabs-list.directive.mjs +23 -0
  181. package/esm2022/tabs/src/tabs-root.directive.mjs +54 -0
  182. package/esm2022/tabs/src/tabs-trigger.directive.mjs +52 -0
  183. package/esm2022/toggle/index.mjs +2 -0
  184. package/esm2022/toggle/radix-ng-primitives-toggle.mjs +5 -0
  185. package/esm2022/toggle/src/toggle.directive.mjs +39 -0
  186. package/esm2022/toggle-group/index.mjs +6 -0
  187. package/esm2022/toggle-group/radix-ng-primitives-toggle-group.mjs +5 -0
  188. package/esm2022/toggle-group/src/toggle-group-button.directive.mjs +75 -0
  189. package/esm2022/toggle-group/src/toggle-group-button.token.mjs +6 -0
  190. package/esm2022/toggle-group/src/toggle-group-multi.directive.mjs +143 -0
  191. package/esm2022/toggle-group/src/toggle-group.directive.mjs +134 -0
  192. package/esm2022/toggle-group/src/toggle-group.token.mjs +6 -0
  193. package/fesm2022/radix-ng-primitives-accordion.mjs +483 -0
  194. package/fesm2022/radix-ng-primitives-accordion.mjs.map +1 -0
  195. package/fesm2022/radix-ng-primitives-alert-dialog.mjs +159 -0
  196. package/fesm2022/radix-ng-primitives-alert-dialog.mjs.map +1 -0
  197. package/fesm2022/radix-ng-primitives-avatar.mjs +166 -0
  198. package/fesm2022/radix-ng-primitives-avatar.mjs.map +1 -0
  199. package/fesm2022/radix-ng-primitives-checkbox.mjs +241 -0
  200. package/fesm2022/radix-ng-primitives-checkbox.mjs.map +1 -0
  201. package/fesm2022/radix-ng-primitives-collapsible.mjs +213 -0
  202. package/fesm2022/radix-ng-primitives-collapsible.mjs.map +1 -0
  203. package/fesm2022/radix-ng-primitives-context-menu.mjs +463 -0
  204. package/fesm2022/radix-ng-primitives-context-menu.mjs.map +1 -0
  205. package/fesm2022/radix-ng-primitives-dialog.mjs +373 -0
  206. package/fesm2022/radix-ng-primitives-dialog.mjs.map +1 -0
  207. package/fesm2022/radix-ng-primitives-dropdown-menu.mjs +555 -0
  208. package/fesm2022/radix-ng-primitives-dropdown-menu.mjs.map +1 -0
  209. package/fesm2022/radix-ng-primitives-label.mjs +66 -0
  210. package/fesm2022/radix-ng-primitives-label.mjs.map +1 -0
  211. package/fesm2022/radix-ng-primitives-menu.mjs +158 -0
  212. package/fesm2022/radix-ng-primitives-menu.mjs.map +1 -0
  213. package/fesm2022/radix-ng-primitives-menubar.mjs +245 -0
  214. package/fesm2022/radix-ng-primitives-menubar.mjs.map +1 -0
  215. package/fesm2022/radix-ng-primitives-progress.mjs +184 -0
  216. package/fesm2022/radix-ng-primitives-progress.mjs.map +1 -0
  217. package/fesm2022/radix-ng-primitives-radio.mjs +289 -0
  218. package/fesm2022/radix-ng-primitives-radio.mjs.map +1 -0
  219. package/fesm2022/radix-ng-primitives-separator.mjs +39 -0
  220. package/fesm2022/radix-ng-primitives-separator.mjs.map +1 -0
  221. package/fesm2022/radix-ng-primitives-switch.mjs +173 -0
  222. package/fesm2022/radix-ng-primitives-switch.mjs.map +1 -0
  223. package/fesm2022/radix-ng-primitives-tabs.mjs +222 -0
  224. package/fesm2022/radix-ng-primitives-tabs.mjs.map +1 -0
  225. package/fesm2022/radix-ng-primitives-toggle-group.mjs +358 -0
  226. package/fesm2022/radix-ng-primitives-toggle-group.mjs.map +1 -0
  227. package/fesm2022/radix-ng-primitives-toggle.mjs +46 -0
  228. package/fesm2022/radix-ng-primitives-toggle.mjs.map +1 -0
  229. package/fesm2022/radix-ng-primitives.mjs +4 -0
  230. package/fesm2022/radix-ng-primitives.mjs.map +1 -0
  231. package/label/src/label.directive.d.ts +29 -0
  232. package/menu/index.d.ts +18 -0
  233. package/menu/src/menu-content.directive.d.ts +6 -0
  234. package/menu/src/menu-directive.d.ts +6 -0
  235. package/menu/src/menu-group.directive.d.ts +6 -0
  236. package/menu/src/menu-item.directive.d.ts +12 -0
  237. package/menu/src/menu-label.directive.d.ts +5 -0
  238. package/menu/src/menu-separator.directive.d.ts +6 -0
  239. package/menubar/index.d.ts +24 -0
  240. package/menubar/src/menubar-content.directive.d.ts +6 -0
  241. package/menubar/src/menubar-item-checkbox.directive.d.ts +14 -0
  242. package/menubar/src/menubar-item-indicator.directive.d.ts +5 -0
  243. package/menubar/src/menubar-item-radio.directive.d.ts +14 -0
  244. package/menubar/src/menubar-item.directive.d.ts +8 -0
  245. package/menubar/src/menubar-radio-group.directive.d.ts +6 -0
  246. package/menubar/src/menubar-root.directive.d.ts +7 -0
  247. package/menubar/src/menubar-separator.directive.d.ts +6 -0
  248. package/menubar/src/menubar-trigger.directive.d.ts +11 -0
  249. package/package.json +124 -4
  250. package/progress/index.d.ts +11 -0
  251. package/progress/src/progress-indicator.directive.d.ts +16 -0
  252. package/progress/src/progress-root.directive.d.ts +63 -0
  253. package/radio/{index.ts → index.d.ts} +0 -1
  254. package/radio/src/radio-indicator.directive.d.ts +9 -0
  255. package/radio/src/radio-item.directive.d.ts +21 -0
  256. package/radio/src/radio-root.directive.d.ts +72 -0
  257. package/radio/src/{radio-tokens.ts → radio-tokens.d.ts} +1 -5
  258. package/separator/src/separator.directive.d.ts +22 -0
  259. package/switch/index.d.ts +13 -0
  260. package/switch/src/switch-input.directive.d.ts +6 -0
  261. package/switch/src/switch-root.directive.d.ts +51 -0
  262. package/switch/src/switch-thumb.directive.d.ts +6 -0
  263. package/tabs/index.d.ts +15 -0
  264. package/tabs/src/tabs-content.directive.d.ts +8 -0
  265. package/tabs/src/tabs-context.service.d.ts +22 -0
  266. package/tabs/src/tabs-list.directive.d.ts +6 -0
  267. package/tabs/src/tabs-root.directive.d.ts +37 -0
  268. package/tabs/src/tabs-trigger.directive.d.ts +19 -0
  269. package/toggle/src/toggle.directive.d.ts +30 -0
  270. package/toggle-group/src/toggle-group-button.directive.d.ts +39 -0
  271. package/toggle-group/src/toggle-group-button.token.d.ts +4 -0
  272. package/toggle-group/src/toggle-group-multi.directive.d.ts +93 -0
  273. package/toggle-group/src/toggle-group.directive.d.ts +84 -0
  274. package/toggle-group/src/toggle-group.token.d.ts +5 -0
  275. package/.compodocrc.json +0 -12
  276. package/CHANGELOG.md +0 -189
  277. package/accordion/__tests__/accordion-content.directive.spec.ts +0 -8
  278. package/accordion/__tests__/accordion-header.directive.spec.ts +0 -8
  279. package/accordion/__tests__/accordion-item.directive.spec.ts +0 -8
  280. package/accordion/__tests__/accordion-root.directive.spec.ts +0 -8
  281. package/accordion/__tests__/accordion-trigger.directive.spec.ts +0 -8
  282. package/accordion/index.ts +0 -5
  283. package/accordion/ng-package.json +0 -5
  284. package/accordion/src/accordion-content.directive.ts +0 -46
  285. package/accordion/src/accordion-header.directive.ts +0 -15
  286. package/accordion/src/accordion-item.directive.ts +0 -216
  287. package/accordion/src/accordion-root.directive.ts +0 -205
  288. package/accordion/src/accordion-trigger.directive.ts +0 -37
  289. package/accordion/stories/accordion.docs.mdx +0 -77
  290. package/accordion/stories/accordion.stories.ts +0 -340
  291. package/alert-dialog/ng-package.json +0 -5
  292. package/alert-dialog/src/alert-dialog-cancel.directive.ts +0 -17
  293. package/alert-dialog/src/alert-dialog-content.directive.ts +0 -24
  294. package/alert-dialog/src/alert-dialog-root.directive.ts +0 -15
  295. package/alert-dialog/src/alert-dialog-title.directive.ts +0 -7
  296. package/alert-dialog/src/alert-dialog-trigger.directive.ts +0 -17
  297. package/alert-dialog/src/alert-dialog.service.ts +0 -51
  298. package/alert-dialog/stories/alert-dialog.stories.ts +0 -139
  299. package/avatar/__tests__/avatar-fallback.directive.spec.ts +0 -31
  300. package/avatar/__tests__/avatar-image.directive.spec.ts +0 -36
  301. package/avatar/ng-package.json +0 -5
  302. package/avatar/src/avatar-fallback.directive.ts +0 -62
  303. package/avatar/src/avatar-image.directive.ts +0 -55
  304. package/avatar/src/avatar-root.directive.ts +0 -35
  305. package/avatar/src/avatar.config.ts +0 -29
  306. package/avatar/stories/avatar.docs.mdx +0 -37
  307. package/avatar/stories/avatar.stories.ts +0 -87
  308. package/button/__tests__/.gitkeep +0 -0
  309. package/button/src/button-abstract.directive.ts +0 -46
  310. package/checkbox/ng-package.json +0 -5
  311. package/checkbox/src/checkbox-button.directive.ts +0 -26
  312. package/checkbox/src/checkbox-indicator.directive.ts +0 -16
  313. package/checkbox/src/checkbox-input.directive.ts +0 -36
  314. package/checkbox/src/checkbox.directive.ts +0 -146
  315. package/checkbox/src/checkbox.token.ts +0 -8
  316. package/checkbox/stories/checkbox-group.component.ts +0 -87
  317. package/checkbox/stories/checkbox-group.styles.scss +0 -49
  318. package/checkbox/stories/checkbox-indeterminate.component.ts +0 -52
  319. package/checkbox/stories/checkbox.docs.mdx +0 -58
  320. package/checkbox/stories/checkbox.stories.ts +0 -105
  321. package/collapsible/__tests__/collapsible-content.directive.spec.ts +0 -30
  322. package/collapsible/__tests__/collapsible-root.directive.spec.ts +0 -27
  323. package/collapsible/__tests__/collapsible-trigger.directive.spec.ts +0 -30
  324. package/collapsible/ng-package.json +0 -5
  325. package/collapsible/src/collapsible-content.directive.ts +0 -34
  326. package/collapsible/src/collapsible-content.token.ts +0 -6
  327. package/collapsible/src/collapsible-root.directive.ts +0 -120
  328. package/collapsible/src/collapsible-trigger.directive.ts +0 -44
  329. package/collapsible/stories/collapsible-animation.component.ts +0 -116
  330. package/collapsible/stories/collapsible-external-triggering.component.ts +0 -86
  331. package/collapsible/stories/collapsible.docs.mdx +0 -53
  332. package/collapsible/stories/collapsible.stories.ts +0 -151
  333. package/context-menu/index.ts +0 -10
  334. package/context-menu/ng-package.json +0 -5
  335. package/context-menu/src/context-menu-content.directive.ts +0 -47
  336. package/context-menu/src/context-menu-item-checkbox.directive.ts +0 -30
  337. package/context-menu/src/context-menu-item-indicator.directive.ts +0 -14
  338. package/context-menu/src/context-menu-item-radio-group.directive.ts +0 -31
  339. package/context-menu/src/context-menu-item-radio.directive.ts +0 -69
  340. package/context-menu/src/context-menu-item-selectable.ts +0 -18
  341. package/context-menu/src/context-menu-item.directive.ts +0 -65
  342. package/context-menu/src/context-menu-label.directive.ts +0 -7
  343. package/context-menu/src/context-menu-separator.directive.ts +0 -13
  344. package/context-menu/src/context-menu-trigger.directive.ts +0 -82
  345. package/context-menu/stories/context-menu.docs.mdx +0 -23
  346. package/context-menu/stories/context-menu.stories.ts +0 -253
  347. package/core/index.ts +0 -3
  348. package/core/src/accessor/provide-value-accessor.ts +0 -20
  349. package/core/src/auto-focus.directive.ts +0 -81
  350. package/core/src/inject-ng-control.ts +0 -28
  351. package/core/src/mount.ts +0 -27
  352. package/dialog/__tests__/dialog-content.directive.spec.ts +0 -77
  353. package/dialog/__tests__/dialog-trigger.directive.spec.ts +0 -85
  354. package/dialog/index.ts +0 -31
  355. package/dialog/ng-package.json +0 -5
  356. package/dialog/src/dialog-close.directive.ts +0 -18
  357. package/dialog/src/dialog-content.directive.ts +0 -45
  358. package/dialog/src/dialog-description.directive.ts +0 -7
  359. package/dialog/src/dialog-dismiss.directive.ts +0 -18
  360. package/dialog/src/dialog-ref.ts +0 -70
  361. package/dialog/src/dialog-title.directive.ts +0 -7
  362. package/dialog/src/dialog-trigger.directive.ts +0 -52
  363. package/dialog/src/dialog.config.ts +0 -55
  364. package/dialog/src/dialog.injectors.ts +0 -12
  365. package/dialog/src/dialog.service.ts +0 -94
  366. package/dialog/stories/dialog.docs.mdx +0 -32
  367. package/dialog/stories/dialog.stories.ts +0 -233
  368. package/dropdown-menu/index.ts +0 -10
  369. package/dropdown-menu/ng-package.json +0 -5
  370. package/dropdown-menu/src/dropdown-menu-content.directive.ts +0 -47
  371. package/dropdown-menu/src/dropdown-menu-item-checkbox.directive.ts +0 -30
  372. package/dropdown-menu/src/dropdown-menu-item-indicator.directive.ts +0 -14
  373. package/dropdown-menu/src/dropdown-menu-item-radio-group.directive.ts +0 -31
  374. package/dropdown-menu/src/dropdown-menu-item-radio.directive.ts +0 -72
  375. package/dropdown-menu/src/dropdown-menu-item-selectable.ts +0 -18
  376. package/dropdown-menu/src/dropdown-menu-item.directive.ts +0 -66
  377. package/dropdown-menu/src/dropdown-menu-label.directive.ts +0 -7
  378. package/dropdown-menu/src/dropdown-menu-separator.directive.ts +0 -13
  379. package/dropdown-menu/src/dropdown-menu-trigger.directive.ts +0 -185
  380. package/dropdown-menu/stories/dropdown-menu-item-checkbox.component.ts +0 -104
  381. package/dropdown-menu/stories/dropdown-menu-item-checkbox.styles.scss +0 -106
  382. package/dropdown-menu/stories/dropdown-menu-item-radio.component.ts +0 -95
  383. package/dropdown-menu/stories/dropdown-menu-item-radio.styles.scss +0 -106
  384. package/dropdown-menu/stories/dropdown.docs.mdx +0 -27
  385. package/dropdown-menu/stories/dropdown.stories.ts +0 -212
  386. package/form-field/index.ts +0 -1
  387. package/form-field/src/.gitkeep +0 -0
  388. package/jest.config.ts +0 -21
  389. package/label/__tests__/label-root.directive.spec.ts +0 -99
  390. package/label/ng-package.json +0 -5
  391. package/label/src/label.directive.ts +0 -58
  392. package/label/stories/label.docs.mdx +0 -40
  393. package/label/stories/label.stories.ts +0 -76
  394. package/menu/index.ts +0 -29
  395. package/menu/ng-package.json +0 -5
  396. package/menu/src/menu-content.directive.ts +0 -9
  397. package/menu/src/menu-directive.ts +0 -10
  398. package/menu/src/menu-group.directive.ts +0 -12
  399. package/menu/src/menu-item.directive.ts +0 -44
  400. package/menu/src/menu-label.directive.ts +0 -7
  401. package/menu/src/menu-separator.directive.ts +0 -13
  402. package/menubar/index.ts +0 -38
  403. package/menubar/ng-package.json +0 -5
  404. package/menubar/src/menubar-content.directive.ts +0 -9
  405. package/menubar/src/menubar-item-checkbox.directive.ts +0 -32
  406. package/menubar/src/menubar-item-indicator.directive.ts +0 -10
  407. package/menubar/src/menubar-item-radio.directive.ts +0 -33
  408. package/menubar/src/menubar-item.directive.ts +0 -12
  409. package/menubar/src/menubar-radio-group.directive.ts +0 -9
  410. package/menubar/src/menubar-root.directive.ts +0 -15
  411. package/menubar/src/menubar-separator.directive.ts +0 -9
  412. package/menubar/src/menubar-trigger.directive.ts +0 -40
  413. package/menubar/stories/menubar.stories.ts +0 -229
  414. package/ng-package.json +0 -8
  415. package/portal/stories/portal.docs.mdx +0 -85
  416. package/presence/__test__/presence-test.component.ts +0 -51
  417. package/presence/__test__/presence.spec.ts +0 -50
  418. package/presence/index.ts +0 -4
  419. package/presence/src/presence.ts +0 -119
  420. package/presence/src/transitions/transition.collapse.ts +0 -99
  421. package/presence/src/transitions/transition.toast.ts +0 -27
  422. package/presence/src/types.ts +0 -20
  423. package/presence/src/utils.ts +0 -63
  424. package/presence/stories/presence-story.componen.ts +0 -69
  425. package/presence/stories/presence.docs.mdx +0 -40
  426. package/presence/stories/presence.stories.ts +0 -29
  427. package/progress/__test__/progress.spec.ts +0 -55
  428. package/progress/index.ts +0 -4
  429. package/progress/ng-package.json +0 -5
  430. package/progress/src/progress-indicator.directive.ts +0 -26
  431. package/progress/src/progress-root.directive.ts +0 -134
  432. package/progress/stories/progress.docs.mdx +0 -65
  433. package/progress/stories/progress.stories.ts +0 -66
  434. package/project.json +0 -39
  435. package/radio/ng-package.json +0 -5
  436. package/radio/src/radio-indicator.directive.ts +0 -17
  437. package/radio/src/radio-item.directive.ts +0 -68
  438. package/radio/src/radio-root.directive.ts +0 -207
  439. package/radio/stories/radio-group.component.ts +0 -39
  440. package/radio/stories/radio-group.styles.scss +0 -70
  441. package/radio/stories/radio.docs.mdx +0 -68
  442. package/radio/stories/radio.stories.ts +0 -155
  443. package/separator/__tests__/separator.directive.spec.ts +0 -58
  444. package/separator/ng-package.json +0 -5
  445. package/separator/src/separator.directive.ts +0 -35
  446. package/separator/stories/separator.docs.mdx +0 -37
  447. package/separator/stories/separator.stories.ts +0 -82
  448. package/slider/src/slider-input.directive.ts +0 -0
  449. package/slider/src/slider-thumb.directives.ts +0 -60
  450. package/slider/src/slider-track.directive.ts +0 -11
  451. package/slider/src/slider.directive.ts +0 -59
  452. package/slider/src/slider.types.ts +0 -4
  453. package/switch/index.ts +0 -22
  454. package/switch/ng-package.json +0 -5
  455. package/switch/src/switch-input.directive.ts +0 -24
  456. package/switch/src/switch-root.directive.ts +0 -127
  457. package/switch/src/switch-thumb.directive.ts +0 -15
  458. package/switch/stories/switch.docs.mdx +0 -83
  459. package/switch/stories/switch.stories.ts +0 -149
  460. package/tabs/__tests__/tabs-context.service.spec.ts +0 -35
  461. package/tabs/index.ts +0 -26
  462. package/tabs/ng-package.json +0 -5
  463. package/tabs/src/tabs-content.directive.ts +0 -23
  464. package/tabs/src/tabs-context.service.ts +0 -43
  465. package/tabs/src/tabs-list.directive.ts +0 -21
  466. package/tabs/src/tabs-root.directive.ts +0 -70
  467. package/tabs/src/tabs-trigger.directive.ts +0 -55
  468. package/tabs/stories/tabs.stories.ts +0 -213
  469. package/test-setup.ts +0 -1
  470. package/toggle/__tests__/toggle.directive.spec.ts +0 -87
  471. package/toggle/ng-package.json +0 -5
  472. package/toggle/src/toggle.directive.ts +0 -49
  473. package/toggle/stories/toggle.docs.mdx +0 -60
  474. package/toggle/stories/toggle.stories.ts +0 -84
  475. package/toggle-group/ng-package.json +0 -5
  476. package/toggle-group/src/toggle-group-button.directive.ts +0 -73
  477. package/toggle-group/src/toggle-group-button.token.ts +0 -8
  478. package/toggle-group/src/toggle-group-multi.directive.ts +0 -158
  479. package/toggle-group/src/toggle-group.directive.ts +0 -148
  480. package/toggle-group/src/toggle-group.token.ts +0 -11
  481. package/toggle-group/stories/toggle-group.docs.mdx +0 -87
  482. package/toggle-group/stories/toggle-group.stories.ts +0 -95
  483. package/tsconfig.doc.json +0 -11
  484. package/tsconfig.json +0 -29
  485. package/tsconfig.lib.json +0 -19
  486. package/tsconfig.lib.prod.json +0 -12
  487. package/tsconfig.spec.json +0 -11
  488. package/visually-hidden/README.md +0 -3
  489. package/visually-hidden/stories/visually-hidden.docs.mdx +0 -36
  490. /package/avatar/{index.ts → index.d.ts} +0 -0
  491. /package/checkbox/{index.ts → index.d.ts} +0 -0
  492. /package/collapsible/{index.ts → index.d.ts} +0 -0
  493. /package/{index.ts → index.d.ts} +0 -0
  494. /package/label/{index.ts → index.d.ts} +0 -0
  495. /package/separator/{index.ts → index.d.ts} +0 -0
  496. /package/toggle/{index.ts → index.d.ts} +0 -0
  497. /package/toggle-group/{index.ts → index.d.ts} +0 -0
@@ -1,340 +0,0 @@
1
- import { BrowserAnimationsModule, provideAnimations } from '@angular/platform-browser/animations';
2
- import { componentWrapperDecorator, Meta, moduleMetadata, StoryObj } from '@storybook/angular';
3
- import { ChevronDown, LucideAngularModule } from 'lucide-angular';
4
- import { RdxAccordionContentDirective } from '../src/accordion-content.directive';
5
- import { RdxAccordionHeaderDirective } from '../src/accordion-header.directive';
6
- import { RdxAccordionItemDirective } from '../src/accordion-item.directive';
7
- import { RdxAccordionRootDirective } from '../src/accordion-root.directive';
8
- import { RdxAccordionTriggerDirective } from '../src/accordion-trigger.directive';
9
-
10
- export default {
11
- title: 'Primitives/Accordion',
12
- decorators: [
13
- moduleMetadata({
14
- imports: [
15
- RdxAccordionRootDirective,
16
- RdxAccordionItemDirective,
17
- RdxAccordionHeaderDirective,
18
- RdxAccordionTriggerDirective,
19
- RdxAccordionContentDirective,
20
- BrowserAnimationsModule,
21
- LucideAngularModule,
22
- LucideAngularModule.pick({ ChevronDown })
23
- ],
24
- providers: [provideAnimations()]
25
- }),
26
- componentWrapperDecorator(
27
- (story) => `
28
- <div class="radix-themes light light-theme radix-themes-default-fonts"
29
- data-accent-color="indigo"
30
- data-radius="medium"
31
- data-scaling="100%"
32
- >
33
- ${story}
34
- </div>
35
-
36
- <style>
37
- /* reset */
38
- button,
39
- h3 {
40
- all: unset;
41
- }
42
-
43
- .AccordionRoot {
44
- border-radius: 6px;
45
- background-color: var(--mauve-6);
46
- box-shadow: 0 2px 10px var(--black-a4);
47
- }
48
-
49
- .AccordionRoot[data-orientation="vertical"] {
50
- width: 300px;
51
- }
52
-
53
- .AccordionRoot[data-orientation="horizontal"] {
54
- height: 300px;
55
-
56
- display: flex;
57
- flex-direction: row;
58
- }
59
-
60
- .AccordionItem {
61
- overflow: hidden;
62
- margin-top: 1px;
63
- }
64
-
65
- .AccordionItem[data-orientation="horizontal"] {
66
- display: flex;
67
- }
68
-
69
- .AccordionItem[data-orientation="vertical"]:first-child {
70
- margin-top: 0;
71
- border-top-left-radius: 4px;
72
- border-top-right-radius: 4px;
73
- }
74
-
75
- .AccordionItem[data-orientation="vertical"]:last-child {
76
- border-bottom-left-radius: 4px;
77
- border-bottom-right-radius: 4px;
78
- }
79
-
80
- .AccordionItem[data-orientation="horizontal"]:first-child {
81
- margin-top: 0;
82
- border-top-left-radius: 4px;
83
- border-bottom-left-radius: 4px;
84
- }
85
-
86
- .AccordionItem[data-orientation="horizontal"]:last-child {
87
- border-top-right-radius: 4px;
88
- border-bottom-right-radius: 4px;
89
- }
90
-
91
- .AccordionItem:focus-within {
92
- position: relative;
93
- z-index: 1;
94
- box-shadow: 0 0 0 2px var(--mauve-12);
95
- }
96
-
97
- .AccordionHeader {
98
- display: flex;
99
- }
100
-
101
- .AccordionTrigger {
102
- font-family: inherit;
103
- padding: 0 20px;
104
- height: 45px;
105
- flex: 1;
106
- display: flex;
107
- align-items: center;
108
- justify-content: space-between;
109
- font-size: 15px;
110
- line-height: 1;
111
- color: var(--violet-11);
112
- box-shadow: 0 1px 0 var(--mauve-6);
113
- background-color: white;
114
- cursor: default;
115
- }
116
-
117
- .AccordionTrigger[data-orientation="horizontal"] {
118
- height: 100%;
119
- padding: 20px;
120
- writing-mode: vertical-rl;
121
- }
122
-
123
- .AccordionTrigger[data-disabled="true"] {
124
- color: var(--gray-7);
125
- }
126
-
127
- .AccordionTrigger:hover {
128
- background-color: var(--mauve-2);
129
- }
130
-
131
- .AccordionContent {
132
- display: flex;
133
- overflow: hidden;
134
- font-size: 15px;
135
- color: var(--mauve-11);
136
- background-color: var(--mauve-2);
137
- }
138
- .AccordionContent[data-orientation='vertical'][data-state='open'] {
139
- animation: slideDown 300ms cubic-bezier(0.87, 0, 0.13, 1);
140
- }
141
- .AccordionContent[data-orientation='vertical'][data-state='closed'] {
142
- animation: slideUp 300ms cubic-bezier(0.87, 0, 0.13, 1);
143
- }
144
-
145
- .AccordionContent[data-orientation='horizontal'][data-state='open'] {
146
- animation: slideRight 300ms cubic-bezier(0.87, 0, 0.13, 1);
147
- }
148
- .AccordionContent[data-orientation='horizontal'][data-state='closed'] {
149
- animation: slideLeft 300ms cubic-bezier(0.87, 0, 0.13, 1);
150
- }
151
-
152
- .AccordionContentText {
153
- padding: 15px 20px;
154
- }
155
-
156
- .AccordionChevron {
157
- display: flex;
158
- color: var(--violet-10);
159
- transition: transform 300ms cubic-bezier(0.87, 0, 0.13, 1);
160
- }
161
- .AccordionTrigger[data-state='open'] > .AccordionChevron {
162
- transform: rotate(180deg);
163
- }
164
-
165
- .horizontal-flex-container {
166
- display: flex;
167
- }
168
-
169
- @keyframes slideDown {
170
- from {
171
- height: 0;
172
- }
173
- to {
174
- height: var(--radix-accordion-content-height);
175
- }
176
- }
177
-
178
- @keyframes slideUp {
179
- from {
180
- height: var(--radix-accordion-content-height);
181
- }
182
- to {
183
- height: 0;
184
- }
185
- }
186
-
187
- @keyframes slideRight {
188
- from {
189
- width: 0;
190
- }
191
- to {
192
- width: var(--radix-accordion-content-width);
193
- }
194
- }
195
-
196
- @keyframes slideLeft {
197
- from {
198
- width: var(--radix-accordion-content-width);
199
- }
200
- to {
201
- width: 0;
202
- }
203
- }
204
- </style>`
205
- )
206
- ]
207
- } as Meta;
208
-
209
- type Story = StoryObj;
210
-
211
- export const Default: Story = {
212
- render: () => ({
213
- template: `
214
- <div class="AccordionRoot" rdxAccordionRoot [defaultValue]="'item-1'">
215
- <div [value]="'item-1'" class="AccordionItem" rdxAccordionItem>
216
- <div class="AccordionHeader" rdxAccordionHeader>
217
- <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it accessible?
218
- <lucide-icon class="AccordionChevron" aria-hidden size="16" name="chevron-down"/>
219
- </button>
220
- </div>
221
- <div class="AccordionContent" rdxAccordionContent>
222
- <div class="AccordionContentText">
223
- Yes. It adheres to the WAI-ARIA design pattern.
224
- </div>
225
- </div>
226
- </div>
227
-
228
- <div [value]="'item-2'" class="AccordionItem" rdxAccordionItem [disabled]="true">
229
- <div class="AccordionHeader" rdxAccordionHeader>
230
- <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it unstyled?
231
- <lucide-icon class="AccordionChevron" aria-hidden size="16" name="chevron-down"/>
232
- </button>
233
- </div>
234
- <div class="AccordionContent" rdxAccordionContent>
235
- <div class="AccordionContentText">
236
- Yes. It's unstyled by default, giving you freedom over the look and feel.
237
- </div>
238
- </div>
239
- </div>
240
-
241
- <div [value]="'item-3'" class="AccordionItem" rdxAccordionItem>
242
- <div class="AccordionHeader" rdxAccordionHeader>
243
- <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Can it be animated?
244
- <lucide-icon class="AccordionChevron" aria-hidden size="16" name="chevron-down"/>
245
- </button>
246
- </div>
247
- <div class="AccordionContent" rdxAccordionContent>
248
- <div class="AccordionContentText">
249
- Yes! You can animate the Accordion with CSS or JavaScript.
250
- </div>
251
- </div>
252
- </div>
253
- </div>
254
- `
255
- })
256
- };
257
-
258
- export const Multiple: Story = {
259
- render: () => ({
260
- template: `
261
- <div class="AccordionRoot" rdxAccordionRoot [value]="['item-2', 'item-3']" [type]="'multiple'">
262
- <div [value]="'item-1'" class="AccordionItem" rdxAccordionItem>
263
- <div class="AccordionHeader" rdxAccordionHeader>
264
- <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it accessible?</button>
265
- </div>
266
- <div class="AccordionContent" rdxAccordionContent >
267
- <div class="AccordionContentText">
268
- Yes. It adheres to the WAI-ARIA design pattern.
269
- </div>
270
- </div>
271
- </div>
272
-
273
- <div [value]="'item-2'" class="AccordionItem" rdxAccordionItem>
274
- <div class="AccordionHeader" rdxAccordionHeader>
275
- <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it unstyled?</button>
276
- </div>
277
- <div class="AccordionContent" rdxAccordionContent>
278
- <div class="AccordionContentText">
279
- Yes. It's unstyled by default, giving you freedom over the look and feel.
280
- </div>
281
- </div>
282
- </div>
283
-
284
- <div [value]="'item-3'" class="AccordionItem" rdxAccordionItem>
285
- <div class="AccordionHeader" rdxAccordionHeader>
286
- <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Can it be animated?</button>
287
- </div>
288
- <div class="AccordionContent" rdxAccordionContent>
289
- <div class="AccordionContentText">
290
- Yes! You can animate the Accordion with CSS or JavaScript.
291
- </div>
292
- </div>
293
- </div>
294
- </div>
295
- `
296
- })
297
- };
298
-
299
- export const Horizontal: Story = {
300
- render: () => ({
301
- template: `
302
- <div class="horizontal-flex-container">
303
- <div class="AccordionRoot" rdxAccordionRoot [defaultValue]="'item-1'" [orientation]="'horizontal'">
304
- <div [value]="'item-1'" class="AccordionItem" rdxAccordionItem>
305
- <div class="AccordionHeader" rdxAccordionHeader>
306
- <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it accessible?</button>
307
- </div>
308
- <div class="AccordionContent" rdxAccordionContent>
309
- <div class="AccordionContentText">
310
- Yes. It adheres to the WAI-ARIA design pattern.
311
- </div>
312
- </div>
313
- </div>
314
-
315
- <div [value]="'item-2'" class="AccordionItem" rdxAccordionItem [disabled]="true">
316
- <div class="AccordionHeader" rdxAccordionHeader>
317
- <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Is it unstyled?</button>
318
- </div>
319
- <div class="AccordionContent" rdxAccordionContent>
320
- <div class="AccordionContentText">
321
- Yes. It's unstyled by default, giving you freedom over the look and feel.
322
- </div>
323
- </div>
324
- </div>
325
-
326
- <div [value]="'item-3'" class="AccordionItem" rdxAccordionItem>
327
- <div class="AccordionHeader" rdxAccordionHeader>
328
- <button class="AccordionTrigger" type="button" rdxAccordionTrigger>Can it be animated?</button>
329
- </div>
330
- <div class="AccordionContent" rdxAccordionContent>
331
- <div class="AccordionContentText">
332
- Yes! You can animate the Accordion with CSS or JavaScript.
333
- </div>
334
- </div>
335
- </div>
336
- </div>
337
- </div>
338
- `
339
- })
340
- };
@@ -1,5 +0,0 @@
1
- {
2
- "lib": {
3
- "entryFile": "index.ts"
4
- }
5
- }
@@ -1,17 +0,0 @@
1
- import { Directive, inject } from '@angular/core';
2
- import { AlertDialogService } from './alert-dialog.service';
3
-
4
- @Directive({
5
- selector: '[rdxAlertDialogCancel]',
6
- standalone: true,
7
- host: {
8
- '(click)': 'onClick()'
9
- }
10
- })
11
- export class AlertDialogCancelDirective {
12
- private readonly alertDialogService = inject(AlertDialogService);
13
-
14
- onClick() {
15
- this.alertDialogService.close();
16
- }
17
- }
@@ -1,24 +0,0 @@
1
- import { CdkTrapFocus } from '@angular/cdk/a11y';
2
- import { Directive, ElementRef, inject, Input, Renderer2 } from '@angular/core';
3
-
4
- @Directive({
5
- selector: '[rdxAlertDialogContent]',
6
- hostDirectives: [
7
- {
8
- directive: CdkTrapFocus
9
- }
10
- ],
11
- standalone: true,
12
- host: {
13
- '[attr.data-state]': 'open',
14
- '[attr.cdkTrapFocusAutoCapture]': 'true'
15
- }
16
- })
17
- export class AlertDialogContentDirective {
18
- private readonly renderer = inject(Renderer2);
19
- private readonly elementRef = inject(ElementRef);
20
-
21
- @Input() set maxWidth(value: string) {
22
- this.renderer.setStyle(this.elementRef.nativeElement, 'maxWidth', value);
23
- }
24
- }
@@ -1,15 +0,0 @@
1
- import { Directive, inject, Input, TemplateRef, ViewContainerRef } from '@angular/core';
2
- import { AlertDialogService } from './alert-dialog.service';
3
-
4
- @Directive({
5
- selector: '[rdxAlertDialogRoot]',
6
- standalone: true
7
- })
8
- export class AlertDialogRootDirective {
9
- private readonly viewContainerRef = inject(ViewContainerRef);
10
- private readonly alertDialogService = inject(AlertDialogService);
11
-
12
- @Input() set content(template: TemplateRef<any>) {
13
- this.alertDialogService.setDialogContent(this.viewContainerRef, template);
14
- }
15
- }
@@ -1,7 +0,0 @@
1
- import { Directive } from '@angular/core';
2
-
3
- @Directive({
4
- selector: '[rdxAlertDialogTitle]',
5
- standalone: true
6
- })
7
- export class AlertDialogTitleDirective {}
@@ -1,17 +0,0 @@
1
- import { Directive, inject } from '@angular/core';
2
- import { AlertDialogService } from './alert-dialog.service';
3
-
4
- @Directive({
5
- selector: '[rdxAlertDialogTrigger]',
6
- standalone: true,
7
- host: {
8
- '(click)': 'handleClick()'
9
- }
10
- })
11
- export class AlertDialogTriggerDirective {
12
- private readonly alertDialogService = inject(AlertDialogService);
13
-
14
- handleClick() {
15
- this.alertDialogService.open();
16
- }
17
- }
@@ -1,51 +0,0 @@
1
- import { Overlay, OverlayRef } from '@angular/cdk/overlay';
2
- import { TemplatePortal } from '@angular/cdk/portal';
3
- import { Injectable, TemplateRef, ViewContainerRef } from '@angular/core';
4
-
5
- @Injectable({
6
- providedIn: 'root'
7
- })
8
- export class AlertDialogService {
9
- private overlayRef: OverlayRef | null | undefined;
10
- private dialogContent:
11
- | {
12
- viewContainerRef: ViewContainerRef;
13
- template: TemplateRef<any>;
14
- }
15
- | undefined;
16
-
17
- constructor(private overlay: Overlay) {}
18
-
19
- setDialogContent(viewContainerRef: ViewContainerRef, template: TemplateRef<any>) {
20
- this.dialogContent = { viewContainerRef, template };
21
- }
22
-
23
- open() {
24
- if (!this.dialogContent) {
25
- throw new Error('Dialog content is not set');
26
- }
27
-
28
- this.overlayRef = this.overlay.create({
29
- hasBackdrop: true,
30
- backdropClass: 'cdk-overlay-dark-backdrop',
31
- positionStrategy: this.overlay.position().global().centerHorizontally().centerVertically()
32
- });
33
-
34
- const templatePortal = new TemplatePortal(this.dialogContent.template, this.dialogContent.viewContainerRef);
35
- this.overlayRef.attach(templatePortal);
36
-
37
- this.overlayRef.keydownEvents().subscribe((event) => {
38
- if (event.key === 'Escape' || event.code === 'Escape') {
39
- this.close();
40
- }
41
- });
42
- this.overlayRef.backdropClick().subscribe(() => this.close());
43
- }
44
-
45
- close() {
46
- if (this.overlayRef) {
47
- this.overlayRef.dispose();
48
- this.overlayRef = null;
49
- }
50
- }
51
- }
@@ -1,139 +0,0 @@
1
- import { OverlayModule } from '@angular/cdk/overlay';
2
- import { PortalModule } from '@angular/cdk/portal';
3
- import { componentWrapperDecorator, Meta, moduleMetadata, StoryObj } from '@storybook/angular';
4
- import { AlertDialogCancelDirective } from '../src/alert-dialog-cancel.directive';
5
- import { AlertDialogContentDirective } from '../src/alert-dialog-content.directive';
6
- import { AlertDialogRootDirective } from '../src/alert-dialog-root.directive';
7
- import { AlertDialogTitleDirective } from '../src/alert-dialog-title.directive';
8
- import { AlertDialogTriggerDirective } from '../src/alert-dialog-trigger.directive';
9
- import { AlertDialogService } from '../src/alert-dialog.service';
10
-
11
- export default {
12
- title: 'Primitives/Alert Dialog',
13
- decorators: [
14
- moduleMetadata({
15
- imports: [
16
- AlertDialogContentDirective,
17
- AlertDialogRootDirective,
18
- AlertDialogTitleDirective,
19
- AlertDialogTriggerDirective,
20
- AlertDialogCancelDirective,
21
- OverlayModule,
22
- PortalModule
23
- ],
24
- providers: [AlertDialogService]
25
- }),
26
- componentWrapperDecorator(
27
- (story) =>
28
- `
29
- <div class="radix-themes light light-theme"
30
- data-radius="medium"
31
- data-scaling="100%">${story}</div>`
32
- )
33
- ]
34
- } as Meta;
35
-
36
- type Story = StoryObj;
37
-
38
- export const Default: Story = {
39
- render: (args) => ({
40
- props: args,
41
- template: `
42
-
43
- <div rdxAlertDialogRoot [content]="alertDialogContent">
44
- <button rdxAlertDialogTrigger class="Button violet">Delete account</button>
45
- <ng-template #alertDialogContent>
46
- <div rdxAlertDialogContent maxWidth="450" class="AlertDialogContent">
47
- <h2 rdxAlertDialogTitle class="AlertDialogTitle">Are you absolutely sure?</h2>
48
- <p class="AlertDialogDescription">
49
- This action cannot be undone. This will permanently delete your account and remove your data from our servers.
50
- </p>
51
- <div style="display: flex; gap: 3px; margin-top: 4px; justify-content: flex-end;">
52
- <button rdxAlertDialogCancel class="Button mauve">Cancel</button>
53
- <button class="Button red">Revoke access</button>
54
- </div>
55
- </div>
56
- </ng-template>
57
- </div>
58
-
59
- <style>
60
-
61
- .AlertDialogContent {
62
- background-color: white;
63
- border-radius: 6px;
64
- box-shadow: hsl(206 22% 7% / 35%) 0px 10px 38px -10px, hsl(206 22% 7% / 20%) 0px 10px 20px -15px;
65
- position: fixed;
66
- top: 50%;
67
- left: 50%;
68
- transform: translate(-50%, -50%);
69
- width: 90vw;
70
- max-width: 500px;
71
- max-height: 85vh;
72
- padding: 25px;
73
- animation: contentShow 150ms cubic-bezier(0.16, 1, 0.3, 1);
74
- }
75
-
76
- .AlertDialogTitle {
77
- margin: 0;
78
- color: var(--mauve-12);
79
- font-size: 17px;
80
- font-weight: 500;
81
- }
82
-
83
- .AlertDialogDescription {
84
- margin-bottom: 20px;
85
- color: var(--mauve-11);
86
- font-size: 15px;
87
- line-height: 1.5;
88
- }
89
-
90
- button {
91
- all: unset;
92
- }
93
- Button {
94
- display: inline-flex;
95
- align-items: center;
96
- justify-content: center;
97
- border-radius: 4px;
98
- padding: 0 15px;
99
- font-size: 15px;
100
- line-height: 1;
101
- font-weight: 500;
102
- height: 35px;
103
- }
104
- .Button.violet {
105
- background-color: white;
106
- color: var(--violet-11);
107
- box-shadow: 0 2px 10px var(--black-a7);
108
- }
109
- .Button.violet:hover {
110
- background-color: var(--mauve-3);
111
- }
112
- .Button.violet:focus {
113
- box-shadow: 0 0 0 2px black;
114
- }
115
- .Button.red {
116
- background-color: var(--red-4);
117
- color: var(--red-11);
118
- }
119
- .Button.red:hover {
120
- background-color: var(--red-5);
121
- }
122
- .Button.red:focus {
123
- box-shadow: 0 0 0 2px var(--red-7);
124
- }
125
- .Button.mauve {
126
- background-color: var(--mauve-4);
127
- color: var(--mauve-11);
128
- }
129
- .Button.mauve:hover {
130
- background-color: var(--mauve-5);
131
- }
132
- .Button.mauve:focus {
133
- box-shadow: 0 0 0 2px var(--mauve-7);
134
- }
135
- </style>
136
-
137
- `
138
- })
139
- };
@@ -1,31 +0,0 @@
1
- import { Component, PLATFORM_ID } from '@angular/core';
2
- import { ComponentFixture, TestBed } from '@angular/core/testing';
3
- import { RdxAvatarFallbackDirective } from '../src/avatar-fallback.directive';
4
- import { RdxAvatarRootDirective } from '../src/avatar-root.directive';
5
-
6
- @Component({
7
- selector: 'rdx-mock-component',
8
- standalone: true,
9
- imports: [RdxAvatarFallbackDirective, RdxAvatarRootDirective],
10
- template: `
11
- <span rdxAvatarRoot>
12
- <span rdxAvatarFallback>fallback</span>
13
- <span rdxAvatarFallback>fallback2</span>
14
- </span>
15
- `
16
- })
17
- class RdxMockComponent {}
18
-
19
- describe('RdxAvatarFallbackDirective', () => {
20
- let component: RdxMockComponent;
21
- let fixture: ComponentFixture<RdxMockComponent>;
22
-
23
- beforeEach(() => {
24
- fixture = TestBed.overrideProvider(PLATFORM_ID, { useValue: 'browser' }).createComponent(RdxMockComponent);
25
- component = fixture.componentInstance;
26
- });
27
-
28
- it('should compile', () => {
29
- expect(component).toBeTruthy();
30
- });
31
- });