@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,85 +0,0 @@
1
- import { Component, OnInit, TemplateRef, ViewChild } from '@angular/core';
2
- import { ComponentFixture, TestBed } from '@angular/core/testing';
3
- import { By } from '@angular/platform-browser';
4
- import { of } from 'rxjs';
5
- import { RdxDialogRef } from '../src/dialog-ref';
6
- import { RdxDialogTriggerDirective } from '../src/dialog-trigger.directive';
7
- import { RdxDialogConfig } from '../src/dialog.config';
8
- import { RdxDialogService } from '../src/dialog.service';
9
-
10
- @Component({
11
- template: `
12
- <button [rdxDialogTrigger]="dialogTemplate" [rdxDialogConfig]="config">Open Dialog</button>
13
- <ng-template #dialogTemplate>Dialog Content</ng-template>
14
- `
15
- })
16
- class TestHostComponent implements OnInit {
17
- @ViewChild('dialogTemplate') dialogTemplate: TemplateRef<any>;
18
-
19
- config: RdxDialogConfig<unknown>;
20
-
21
- ngOnInit() {
22
- this.config = {
23
- content: this.dialogTemplate,
24
- modal: true,
25
- ariaLabel: 'Test Dialog',
26
- autoFocus: 'first-tabbable',
27
- canClose: () => true,
28
- canCloseWithBackdrop: true,
29
- mode: 'default'
30
- };
31
- }
32
- }
33
-
34
- describe('RdxDialogTriggerDirective', () => {
35
- let fixture: ComponentFixture<TestHostComponent>;
36
- let directive: RdxDialogTriggerDirective;
37
- let dialogServiceMock: jest.Mocked<RdxDialogService>;
38
- let dialogRefMock: jest.Mocked<RdxDialogRef>;
39
-
40
- beforeEach(async () => {
41
- dialogRefMock = {
42
- closed$: of(undefined)
43
- } as any;
44
-
45
- dialogServiceMock = {
46
- open: jest.fn().mockReturnValue(dialogRefMock)
47
- } as any;
48
-
49
- await TestBed.configureTestingModule({
50
- declarations: [TestHostComponent],
51
- imports: [RdxDialogTriggerDirective],
52
- providers: [
53
- { provide: RdxDialogService, useValue: dialogServiceMock }]
54
- }).compileComponents();
55
-
56
- fixture = TestBed.createComponent(TestHostComponent);
57
- fixture.detectChanges();
58
-
59
- const directiveEl = fixture.debugElement.query(By.directive(RdxDialogTriggerDirective));
60
- directive = directiveEl.injector.get(RdxDialogTriggerDirective);
61
- });
62
-
63
- it('should create', () => {
64
- expect(directive).toBeTruthy();
65
- });
66
-
67
- it('should have correct initial state', () => {
68
- expect(directive.isOpen()).toBe(false);
69
- expect(directive.state()).toBe('closed');
70
- });
71
-
72
- it('should have correct aria attributes', () => {
73
- const button = fixture.debugElement.query(By.css('button'));
74
- expect(button.nativeElement.getAttribute('aria-haspopup')).toBe('dialog');
75
- expect(button.nativeElement.getAttribute('aria-expanded')).toBe('false');
76
- expect(button.nativeElement.getAttribute('data-state')).toBe('closed');
77
-
78
- button.nativeElement.click();
79
-
80
- fixture.detectChanges();
81
-
82
- expect(button.nativeElement.getAttribute('aria-expanded')).toBe('true');
83
- expect(button.nativeElement.getAttribute('data-state')).toBe('open');
84
- });
85
- });
package/dialog/index.ts DELETED
@@ -1,31 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import { RdxDialogCloseDirective } from './src/dialog-close.directive';
3
- import { RdxDialogContentDirective } from './src/dialog-content.directive';
4
- import { RdxDialogDescriptionDirective } from './src/dialog-description.directive';
5
- import { RdxDialogDismissDirective } from './src/dialog-dismiss.directive';
6
- import { RdxDialogTitleDirective } from './src/dialog-title.directive';
7
- import { RdxDialogTriggerDirective } from './src/dialog-trigger.directive';
8
-
9
- export * from './src/dialog-close.directive';
10
- export * from './src/dialog-content.directive';
11
- export * from './src/dialog-description.directive';
12
- export * from './src/dialog-dismiss.directive';
13
- export * from './src/dialog-ref';
14
- export * from './src/dialog-title.directive';
15
- export * from './src/dialog-trigger.directive';
16
- export * from './src/dialog.config';
17
- export * from './src/dialog.injectors';
18
- export * from './src/dialog.providers';
19
- export * from './src/dialog.service';
20
-
21
- const dialogImports = [
22
- RdxDialogTriggerDirective,
23
- RdxDialogContentDirective,
24
- RdxDialogTitleDirective,
25
- RdxDialogCloseDirective,
26
- RdxDialogDescriptionDirective,
27
- RdxDialogDismissDirective
28
- ];
29
-
30
- @NgModule({ imports: [...dialogImports], exports: [...dialogImports] })
31
- export class RdxDialogModule {}
@@ -1,5 +0,0 @@
1
- {
2
- "lib": {
3
- "entryFile": "index.ts"
4
- }
5
- }
@@ -1,18 +0,0 @@
1
- import { Directive, inject } from '@angular/core';
2
- import { RdxDialogRef } from './dialog-ref';
3
-
4
- @Directive({
5
- selector: 'button[rdxDialogClose]',
6
- standalone: true,
7
- host: {
8
- type: 'button',
9
- '(click)': 'onClick()'
10
- }
11
- })
12
- export class RdxDialogCloseDirective {
13
- private readonly ref = inject<RdxDialogRef>(RdxDialogRef);
14
-
15
- protected onClick(): void {
16
- this.ref.close();
17
- }
18
- }
@@ -1,45 +0,0 @@
1
- import { computed, DestroyRef, Directive, inject, signal } from '@angular/core';
2
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
- import { RdxDialogRef } from './dialog-ref';
4
- import { getState, RdxDialogResult } from './dialog.config';
5
-
6
- @Directive({
7
- selector: '[rdxDialogContent]',
8
- standalone: true,
9
- host: {
10
- role: 'dialog',
11
- '[attr.aria-describedby]': '"true"',
12
- '[attr.aria-labelledby]': '"true"',
13
- '[attr.data-state]': 'state()'
14
- }
15
- })
16
- export class RdxDialogContentDirective<C = unknown> {
17
- private readonly dialogRef = inject<RdxDialogRef<C>>(RdxDialogRef);
18
- private readonly destroyRef = inject(DestroyRef);
19
-
20
- private readonly isOpen = signal(true);
21
-
22
- readonly state = computed(() => getState(this.isOpen()));
23
-
24
- constructor() {
25
- this.dialogRef.closed$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
26
- this.isOpen.set(false);
27
- });
28
- }
29
-
30
- /**
31
- * Closes the dialog with a specified result.
32
- *
33
- * @param result The result to be passed back when closing the dialog
34
- */
35
- close(result: RdxDialogResult<C>): void {
36
- this.dialogRef.close(result);
37
- }
38
-
39
- /**
40
- * Dismisses the dialog without a result.
41
- */
42
- dismiss(): void {
43
- this.dialogRef.dismiss();
44
- }
45
- }
@@ -1,7 +0,0 @@
1
- import { Directive } from '@angular/core';
2
-
3
- @Directive({
4
- selector: '[rdxDialogDescription]',
5
- standalone: true
6
- })
7
- export class RdxDialogDescriptionDirective {}
@@ -1,18 +0,0 @@
1
- import { Directive, inject } from '@angular/core';
2
- import { RdxDialogRef } from './dialog-ref';
3
-
4
- @Directive({
5
- selector: 'button[rdxDialogDismiss]',
6
- standalone: true,
7
- host: {
8
- type: 'button',
9
- '(click)': 'onClick()'
10
- }
11
- })
12
- export class RdxDialogDismissDirective {
13
- private readonly ref = inject<RdxDialogRef>(RdxDialogRef);
14
-
15
- protected onClick(): void {
16
- this.ref.dismiss();
17
- }
18
- }
@@ -1,70 +0,0 @@
1
- import { DialogRef } from '@angular/cdk/dialog';
2
- import { filter, isObservable, map, Observable, of, take } from 'rxjs';
3
- import { RdxDialogConfig, RdxDialogResult } from './dialog.config';
4
-
5
- export const DISMISSED_VALUE = {} as const;
6
-
7
- function isDismissed(v: unknown): v is typeof DISMISSED_VALUE {
8
- return v === DISMISSED_VALUE;
9
- }
10
-
11
- /**
12
- * Represents a reference to an open dialog.
13
- * Provides methods and observables to interact with and monitor the dialog's state.
14
- * @template C - The type of the dialog's content component
15
- */
16
- export class RdxDialogRef<C = unknown> {
17
- closed$: Observable<RdxDialogResult<C> | undefined> = this.cdkRef.closed.pipe(
18
- map((res): RdxDialogResult<C> | undefined => (isDismissed(res) ? undefined : res))
19
- );
20
-
21
- dismissed$: Observable<void> = this.cdkRef.closed.pipe(
22
- filter((res) => res === DISMISSED_VALUE),
23
- map((): void => undefined)
24
- );
25
-
26
- result$: Observable<RdxDialogResult<C>> = this.cdkRef.closed.pipe(
27
- filter((res): res is RdxDialogResult<C> => !isDismissed(res))
28
- );
29
-
30
- /**
31
- * @param cdkRef - Reference to the underlying CDK dialog
32
- * @param config - Configuration options for the dialog
33
- */
34
- constructor(
35
- public readonly cdkRef: DialogRef<RdxDialogResult<C> | typeof DISMISSED_VALUE, C>,
36
- public readonly config: RdxDialogConfig<C>
37
- ) {}
38
-
39
- get instance(): C | null {
40
- return this.cdkRef.componentInstance;
41
- }
42
-
43
- /**
44
- * Attempts to dismiss the dialog
45
- * Checks the canClose condition before dismissing
46
- */
47
- dismiss(): void {
48
- if (!this.instance) {
49
- return;
50
- }
51
- const canClose = this.config.canClose?.(this.instance) ?? true;
52
- const canClose$ = isObservable(canClose) ? canClose : of(canClose);
53
- canClose$.pipe(take(1)).subscribe((close) => {
54
- if (close) {
55
- this.cdkRef.close(DISMISSED_VALUE);
56
- }
57
- });
58
- }
59
-
60
- close(result: RdxDialogResult<C>): void {
61
- this.cdkRef.close(result);
62
- }
63
- }
64
-
65
- /**
66
- * Represents a simplified interface for dialog interaction
67
- * Typically used by dialog content components
68
- * @template R - The type of the result when closing the dialog
69
- */
70
- export type RdxDialogSelfRef<R> = { dismiss(): void; close(res: R): void };
@@ -1,7 +0,0 @@
1
- import { Directive } from '@angular/core';
2
-
3
- @Directive({
4
- selector: '[rdxDialogTitle]',
5
- standalone: true
6
- })
7
- export class RdxDialogTitleDirective {}
@@ -1,52 +0,0 @@
1
- import { computed, Directive, inject, Input, input, signal, TemplateRef } from '@angular/core';
2
- import { RdxDialogRef } from './dialog-ref';
3
- import { getState, RdxDialogConfig, RdxDialogState } from './dialog.config';
4
- import { provideRdxDialog } from './dialog.providers';
5
- import { RdxDialogService } from './dialog.service';
6
-
7
- let nextId = 0;
8
-
9
- // Primitive.button
10
- @Directive({
11
- selector: '[rdxDialogTrigger]',
12
- standalone: true,
13
- providers: [provideRdxDialog()],
14
- host: {
15
- type: 'button',
16
- '[attr.id]': 'id()',
17
- '[attr.aria-haspopup]': '"dialog"',
18
- '[attr.aria-expanded]': 'isOpen()',
19
- '[attr.aria-controls]': 'dialogId()',
20
- '[attr.data-state]': 'state()',
21
- '(click)': 'onClick()'
22
- }
23
- })
24
- export class RdxDialogTriggerDirective {
25
- private readonly dialogService = inject(RdxDialogService);
26
-
27
- readonly id = input(`rdx-dialog-trigger-${nextId++}`);
28
- readonly dialogId = computed(() => `rdx-dialog-${this.id()}`);
29
-
30
- @Input({ required: true, alias: 'rdxDialogTrigger' }) dialog: TemplateRef<void>;
31
-
32
- @Input({ alias: 'rdxDialogConfig' }) dialogConfig: RdxDialogConfig<unknown>;
33
-
34
- readonly isOpen = signal(false);
35
- readonly state = computed<RdxDialogState>(() => getState(this.isOpen()));
36
-
37
- private currentDialogRef: RdxDialogRef | null = null;
38
-
39
- protected onClick() {
40
- this.currentDialogRef = this.dialogService.open({
41
- ...this.dialogConfig,
42
- content: this.dialog
43
- });
44
-
45
- this.isOpen.set(true);
46
-
47
- this.currentDialogRef.closed$.subscribe(() => {
48
- this.isOpen.set(false);
49
- this.currentDialogRef = null;
50
- });
51
- }
52
- }
@@ -1,55 +0,0 @@
1
- import { AutoFocusTarget, DialogConfig } from '@angular/cdk/dialog';
2
- import { ComponentType } from '@angular/cdk/overlay';
3
- import { TemplateRef } from '@angular/core';
4
- import { Observable } from 'rxjs';
5
-
6
- const ɵdialogData = Symbol.for('rdxDialogData');
7
- const ɵdialogResult = Symbol.for('rdxDialogResult');
8
-
9
- export type ɵDialogDataFlag = { [ɵdialogData]: unknown };
10
- export type ɵDialogResultFlag<R> = { [ɵdialogResult]: R };
11
-
12
- export type RdxDialogData<T> = {
13
- [K in keyof T]: T[K] extends ɵDialogDataFlag ? Omit<T[K], typeof ɵdialogData> : never;
14
- }[keyof T];
15
-
16
- type DialogRefProps<C> = { [K in keyof C]: C[K] extends ɵDialogResultFlag<unknown> ? K : never }[keyof C] & keyof C;
17
- export type RdxDialogResult<C> =
18
- DialogRefProps<C> extends never ? void : C[DialogRefProps<C>] extends ɵDialogResultFlag<infer T> ? T : void;
19
-
20
- type RdxDialogMode = 'default' | 'drawer' | 'drawer-bottom';
21
-
22
- type RdxBaseDialogConfig<C> = {
23
- content: ComponentType<C> | TemplateRef<C>;
24
-
25
- data: RdxDialogData<C>;
26
-
27
- modal?: boolean;
28
-
29
- ariaLabel?: string;
30
-
31
- autoFocus?: AutoFocusTarget | 'first-input' | string;
32
-
33
- canClose?: (comp: C) => boolean | Observable<boolean>;
34
-
35
- canCloseWithBackdrop?: boolean;
36
-
37
- cdkConfigOverride?: Partial<DialogConfig<C>>;
38
-
39
- mode?: RdxDialogMode;
40
-
41
- backdropClass?: string;
42
-
43
- panelClasses?: string[];
44
- };
45
-
46
- export type RdxDialogConfig<T> =
47
- RdxDialogData<T> extends never
48
- ? Omit<RdxBaseDialogConfig<T>, 'data'>
49
- : RdxBaseDialogConfig<T> & { data: Required<RdxDialogData<T>> };
50
-
51
- export type RdxDialogState = 'open' | 'closed';
52
-
53
- export function getState(open: boolean): RdxDialogState {
54
- return open ? 'open' : 'closed';
55
- }
@@ -1,12 +0,0 @@
1
- import { DIALOG_DATA } from '@angular/cdk/dialog';
2
- import { inject } from '@angular/core';
3
- import { RdxDialogRef, RdxDialogSelfRef } from './dialog-ref';
4
- import { ɵDialogDataFlag, ɵDialogResultFlag } from './dialog.config';
5
-
6
- export function injectDialogData<TData>(): TData & ɵDialogDataFlag {
7
- return inject<TData & ɵDialogDataFlag>(DIALOG_DATA);
8
- }
9
-
10
- export function injectDialogRef<R = void>(): RdxDialogSelfRef<R> & ɵDialogResultFlag<R> {
11
- return inject<RdxDialogSelfRef<R>>(RdxDialogRef) as RdxDialogSelfRef<R> & ɵDialogResultFlag<R>;
12
- }
@@ -1,94 +0,0 @@
1
- import { Dialog } from '@angular/cdk/dialog';
2
- import { inject, Injectable, Injector, Renderer2 } from '@angular/core';
3
- import { filter, isObservable, merge, of, switchMap, take, takeUntil } from 'rxjs';
4
- import { DISMISSED_VALUE, RdxDialogRef } from './dialog-ref';
5
- import type { RdxDialogConfig, RdxDialogResult } from './dialog.config';
6
-
7
- /**
8
- * Modality control: When `isModal` is set to `true`, the dialog will:
9
- *
10
- * - Have a backdrop that blocks interaction with the rest of the page
11
- * - Disable closing by clicking outside or pressing Escape
12
- * - Set `aria-modal="true"` for screen readers
13
- * - Automatically focus the first tabbable element in the dialog
14
- * - Restore focus to the element that opened the dialog when it's closed
15
- *
16
- *
17
- * When `isModal` is `false`, the dialog will:
18
- *
19
- * - Not have a backdrop, allowing interaction with the rest of the page
20
- * - Allow closing by clicking outside or pressing Escape
21
- * - Not set `aria-modal` attribute
22
- * - Not automatically manage focus
23
- */
24
- @Injectable()
25
- export class RdxDialogService {
26
- #cdkDialog = inject(Dialog);
27
- #injector = inject(Injector);
28
-
29
- open<C>(config: RdxDialogConfig<C>): RdxDialogRef<C> {
30
- let dialogRef: RdxDialogRef<C>;
31
- let modeClasses: string[] = [];
32
-
33
- switch (config.mode) {
34
- case 'drawer':
35
- modeClasses = ['mod-drawer'];
36
- break;
37
- case 'drawer-bottom':
38
- modeClasses = ['mod-drawer', 'mod-bottom'];
39
- break;
40
- }
41
-
42
- const cdkRef = this.#cdkDialog.open<RdxDialogResult<C> | typeof DISMISSED_VALUE, unknown, C>(config.content, {
43
- ariaModal: config.modal ?? true,
44
- hasBackdrop: config.modal ?? true,
45
- data: 'data' in config ? config.data : null,
46
- restoreFocus: true,
47
- role: 'dialog',
48
- disableClose: true,
49
- closeOnDestroy: true,
50
- injector: this.#injector,
51
- backdropClass: config.backdropClass ? config.backdropClass : 'cdk-overlay-dark-backdrop',
52
- panelClass: ['dialog', ...modeClasses, ...(config.panelClasses || [])],
53
- autoFocus: config.autoFocus === 'first-input' ? 'dialog' : (config.autoFocus ?? 'first-tabbable'),
54
- ariaLabel: config.ariaLabel,
55
- templateContext: () => ({ dialogRef: dialogRef }),
56
- providers: (ref) => {
57
- dialogRef = new RdxDialogRef(ref, config);
58
- return [
59
- {
60
- provide: RdxDialogRef,
61
- useValue: dialogRef
62
- }
63
- ];
64
- },
65
- // @FIXME
66
- ...(config.cdkConfigOverride || ({} as any))
67
- });
68
-
69
- if (cdkRef.componentRef) {
70
- cdkRef.componentRef.injector
71
- .get(Renderer2)
72
- .setStyle(cdkRef.componentRef.location.nativeElement, 'display', 'contents');
73
- }
74
-
75
- merge(cdkRef.backdropClick, cdkRef.keydownEvents.pipe(filter((e) => e.key === 'Escape' && !e.defaultPrevented)))
76
- .pipe(
77
- filter(() => config.canCloseWithBackdrop ?? true),
78
- switchMap(() => {
79
- const canClose = (cdkRef.componentInstance && config.canClose?.(cdkRef.componentInstance)) ?? true;
80
- const canClose$ = isObservable(canClose) ? canClose : of(canClose);
81
- return canClose$.pipe(take(1));
82
- }),
83
-
84
- takeUntil(dialogRef!.closed$)
85
- )
86
- .subscribe((canClose) => {
87
- if (canClose) {
88
- cdkRef.close(DISMISSED_VALUE);
89
- }
90
- });
91
-
92
- return dialogRef!;
93
- }
94
- }
@@ -1,32 +0,0 @@
1
- import { Canvas, Meta } from '@storybook/blocks';
2
- import * as DialogStories from './dialog.stories';
3
-
4
- <Meta title="Primitives/Dialog" />
5
-
6
- # Dialog
7
-
8
- <Canvas sourceState="hidden" of={DialogStories.Default} />
9
-
10
- ## Features
11
- - ✅ Supports modal and non-modal modes.
12
- - ✅ Focus is automatically trapped when modal.
13
- - ✅ Can be controlled or uncontrolled.
14
- - ✅ Esc closes the component automatically.
15
-
16
- ### Anatomy
17
- Import all parts and piece them together.
18
-
19
- ```html
20
-
21
- <button [rdxDialogTrigger]="dialog">Open Dialog</button>
22
-
23
- <ng-template #dialog>
24
- <div rdxDialogContent>
25
- <h2 rdxDialogTitle></h2>
26
- <p rdxDialogDescription></p>
27
- <button rdxDialogClose></button>
28
- <button rdxDialogDismiss>X</button>
29
- </div>
30
- </ng-template>
31
-
32
- ```