@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,65 +0,0 @@
1
- import { CDK_MENU, CdkMenuItem } from '@angular/cdk/menu';
2
- import { booleanAttribute, Directive, ElementRef, EventEmitter, inject, Input, Output } from '@angular/core';
3
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
-
5
- import { RdxContextMenuContentDirective } from './context-menu-content.directive';
6
-
7
- @Directive({
8
- selector: '[rdxContextMenuItem]',
9
- standalone: true,
10
- host: {
11
- type: 'button',
12
- '[attr.data-orientation]': '"vertical"',
13
- '[attr.data-highlighted]': 'highlighted ? "" : null',
14
- '[attr.data-disabled]': 'disabled ? "" : null',
15
- '[attr.disabled]': 'disabled ? "" : null',
16
- '(pointermove)': 'onPointerMove()',
17
- '(focus)': 'menu.highlighted.next(this)',
18
- '(keydown)': 'onKeydown($event)'
19
- },
20
- providers: [
21
- { provide: CdkMenuItem, useExisting: RdxContextMenuItemDirective },
22
- { provide: CDK_MENU, useExisting: RdxContextMenuContentDirective }
23
- ]
24
- })
25
- export class RdxContextMenuItemDirective extends CdkMenuItem {
26
- protected readonly menu = inject(RdxContextMenuContentDirective);
27
- protected readonly nativeElement = inject(ElementRef).nativeElement;
28
-
29
- highlighted = false;
30
-
31
- @Input({ transform: booleanAttribute }) override disabled = false;
32
-
33
- @Output() readonly onSelect = new EventEmitter<void>();
34
-
35
- constructor() {
36
- super();
37
-
38
- this.menu.highlighted.pipe(takeUntilDestroyed()).subscribe((value) => {
39
- if (value !== this) {
40
- this.highlighted = false;
41
- }
42
- });
43
-
44
- this.triggered.subscribe(this.onSelect);
45
- }
46
-
47
- protected onPointerMove() {
48
- this.nativeElement.focus({ preventScroll: true });
49
- this.menu.updateActiveItem(this);
50
- }
51
-
52
- protected onKeydown(event: KeyboardEvent) {
53
- if (this.nativeElement.tagName !== 'BUTTON' && ['Enter', ' '].includes(event.key)) {
54
- event.preventDefault();
55
- }
56
-
57
- if (event.key === 'Escape') {
58
- if (!this.menu.closeOnEscape) {
59
- event.stopPropagation();
60
- } else {
61
- this.menu.onEscapeKeyDown(event);
62
- }
63
- }
64
- }
65
- }
@@ -1,7 +0,0 @@
1
- import { Directive } from '@angular/core';
2
-
3
- @Directive({
4
- selector: '[rdxContextMenuLabel]',
5
- standalone: true
6
- })
7
- export class RdxContextMenuLabelDirective {}
@@ -1,13 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import { RdxSeparatorRootDirective } from '@radix-ng/primitives/separator';
3
-
4
- @Directive({
5
- selector: '[rdxContextMenuSeparator]',
6
- standalone: true,
7
- hostDirectives: [RdxSeparatorRootDirective],
8
- host: {
9
- role: 'separator',
10
- '[attr.aria-orientation]': "'horizontal'"
11
- }
12
- })
13
- export class RdxContextMenuSeparatorDirective {}
@@ -1,82 +0,0 @@
1
- import { CdkContextMenuTrigger, MENU_STACK, MENU_TRIGGER, MenuStack } from '@angular/cdk/menu';
2
- import { ConnectedPosition } from '@angular/cdk/overlay';
3
- import { booleanAttribute, Directive, Input, numberAttribute, TemplateRef } from '@angular/core';
4
- import { outputFromObservable } from '@angular/core/rxjs-interop';
5
-
6
- export enum ContextMenuSide {
7
- Top = 'top',
8
- Right = 'right',
9
- Bottom = 'bottom',
10
- Left = 'left'
11
- }
12
-
13
- const ContextMenuPositions: Record<ContextMenuSide, ConnectedPosition> = {
14
- top: {
15
- originX: 'start',
16
- originY: 'top',
17
- overlayX: 'start',
18
- overlayY: 'bottom',
19
- offsetX: 0,
20
- offsetY: 0
21
- },
22
- right: {
23
- originX: 'end',
24
- originY: 'top',
25
- overlayX: 'start',
26
- overlayY: 'top',
27
- offsetX: 0,
28
- offsetY: 0
29
- },
30
- bottom: {
31
- originX: 'start',
32
- originY: 'bottom',
33
- overlayX: 'start',
34
- overlayY: 'top',
35
- offsetX: 0,
36
- offsetY: 0
37
- },
38
- left: {
39
- originX: 'start',
40
- originY: 'top',
41
- overlayX: 'end',
42
- overlayY: 'top',
43
- offsetX: 0,
44
- offsetY: 0
45
- }
46
- };
47
-
48
- @Directive({
49
- selector: '[rdxContextMenuTrigger]',
50
- standalone: true,
51
- host: {
52
- '[attr.data-state]': "isOpen() ? 'open': 'closed'",
53
- '[attr.data-disabled]': "disabled ? '' : null",
54
-
55
- '(contextmenu)': '_openOnContextMenu($event)'
56
- },
57
- providers: [
58
- { provide: MENU_TRIGGER, useExisting: RdxContextMenuTriggerDirective },
59
- { provide: MENU_STACK, useClass: MenuStack }
60
- ]
61
- })
62
- export class RdxContextMenuTriggerDirective extends CdkContextMenuTrigger {
63
- override menuPosition = [{ ...ContextMenuPositions[ContextMenuSide.Bottom] }];
64
-
65
- @Input()
66
- set rdxContextMenuTrigger(value: TemplateRef<unknown> | null) {
67
- this.menuTemplateRef = value;
68
- }
69
-
70
- @Input({ transform: numberAttribute })
71
- set alignOffset(value: number) {
72
- this.defaultPosition.offsetX = value;
73
- }
74
-
75
- @Input({ transform: booleanAttribute }) override disabled = false;
76
-
77
- onOpenChange = outputFromObservable(this.opened);
78
-
79
- get defaultPosition(): ConnectedPosition {
80
- return this.menuPosition[0];
81
- }
82
- }
@@ -1,23 +0,0 @@
1
- import { Canvas, Meta } from '@storybook/blocks';
2
- import * as ContextMenuStories from './context-menu.stories';
3
-
4
- <Meta title="Primitives/Context Menu" />
5
-
6
- # Context Menu
7
-
8
- #### Displays a menu to the user—such as a set of actions or functions—triggered by a button.
9
-
10
- <Canvas sourceState="hidden" of={ContextMenuStories.Default} height="300px" />
11
-
12
- ## Features
13
-
14
- - ✅ Supports submenus with configurable reading direction.
15
- - ✅ Supports items, labels, groups of items.
16
- - ✅ Supports checkable items (single or multiple) with optional indeterminate state.
17
- - ✅ Supports modal and non-modal modes.
18
- - ✅ Customize side, alignment, offsets, collision handling.
19
- - ✅ Focus is fully managed.
20
- - ✅ Full keyboard navigation.
21
- - ✅ Typeahead support.
22
- - ✅ Dismissing and layering behavior is highly customizable.
23
- - ✅ Triggers with a long press on touch devices
@@ -1,253 +0,0 @@
1
- import {
2
- RdxDropdownMenuContentDirective,
3
- RdxDropdownMenuItemDirective,
4
- RdxDropdownMenuTriggerDirective
5
- } from '@radix-ng/primitives/dropdown-menu';
6
- import { componentWrapperDecorator, Meta, moduleMetadata, StoryObj } from '@storybook/angular';
7
- import { Check, Dot, LucideAngularModule, Menu } from 'lucide-angular';
8
-
9
- import { RdxContextMenuContentDirective } from '../src/context-menu-content.directive';
10
- import { RdxContextMenuItemCheckboxDirective } from '../src/context-menu-item-checkbox.directive';
11
- import { RdxContextMenuItemIndicatorDirective } from '../src/context-menu-item-indicator.directive';
12
- import { RdxContextMenuItemRadioGroupDirective } from '../src/context-menu-item-radio-group.directive';
13
- import { RdxContextMenuItemRadioDirective } from '../src/context-menu-item-radio.directive';
14
- import { RdxContextMenuItemDirective } from '../src/context-menu-item.directive';
15
- import { RdxContextMenuSeparatorDirective } from '../src/context-menu-separator.directive';
16
- import { RdxContextMenuTriggerDirective } from '../src/context-menu-trigger.directive';
17
-
18
- export default {
19
- title: 'Primitives/Context Menu',
20
- decorators: [
21
- moduleMetadata({
22
- imports: [
23
- RdxContextMenuTriggerDirective,
24
- RdxDropdownMenuTriggerDirective,
25
- RdxContextMenuItemDirective,
26
- RdxDropdownMenuItemDirective,
27
- RdxContextMenuItemCheckboxDirective,
28
- RdxContextMenuItemRadioDirective,
29
- RdxContextMenuItemRadioGroupDirective,
30
- RdxContextMenuItemIndicatorDirective,
31
- RdxContextMenuSeparatorDirective,
32
- RdxContextMenuContentDirective,
33
- RdxDropdownMenuContentDirective,
34
- LucideAngularModule,
35
- LucideAngularModule.pick({ Menu, Check, Dot })
36
- ]
37
- }),
38
- componentWrapperDecorator(
39
- (story) => `
40
- <div class="radix-themes light light-theme radix-themes-default-fonts rt-Flex rt-r-ai-start rt-r-jc-center rt-r-position-relative"
41
- data-accent-color="indigo"
42
- data-radius="medium"
43
- data-scaling="100%"
44
- >
45
- ${story}
46
- </div>`
47
- )
48
- ]
49
- } as Meta;
50
-
51
- type Story = StoryObj;
52
-
53
- export const Default: Story = {
54
- render: () => ({
55
- template: `
56
- <div class="context-menu-trigger"
57
- [rdxContextMenuTrigger]="menu">
58
- Right click here
59
- </div>
60
-
61
- <ng-template #menu>
62
- <div class="ContextMenuContent" rdxContextMenuContent>
63
- <button class="ContextMenuItem" rdxContextMenuItem>
64
- Back <div class="RightSlot">⌘ + [</div>
65
- </button>
66
- <button class="ContextMenuItem" rdxContextMenuItem disabled>
67
- Forward <div class="RightSlot">⌘ + ]</div>
68
- </button>
69
- <button class="ContextMenuItem" rdxContextMenuItem>
70
- Reload <div class="RightSlot">⌘ + R</div>
71
- </button>
72
- <button
73
- class="ContextMenuItem"
74
- rdxContextMenuItem
75
- [rdxDropdownMenuTrigger]="share"
76
- [side]="'right'"
77
- >
78
- More Tools <div class="RightSlot">></div>
79
- </button>
80
-
81
- <div rdxContextMenuSeparator class="ContextMenuSeparator"></div>
82
-
83
- <button class="ContextMenuItem" rdxContextMenuItemCheckbox [checked]="true">
84
- <div class="ContextMenuItemIndicator" rdxContextMenuItemIndicator>
85
- <lucide-icon size="16" name="check"></lucide-icon>
86
- </div>
87
- Show Bookmarks <div class="RightSlot">⌘ + B</div>
88
- </button>
89
- <button class="ContextMenuItem" rdxContextMenuItemCheckbox>
90
- <div class="ContextMenuItemIndicator" rdxContextMenuItemIndicator>
91
- <lucide-icon size="16" name="check"></lucide-icon>
92
- </div>
93
- Show Full URLs
94
- </button>
95
-
96
- <div rdxContextMenuSeparator class="ContextMenuSeparator"></div>
97
-
98
- <div class="ContextMenuLabel" rdxContextMenuLabel>People</div>
99
- <div class="ContextMenuItemRadioGroup" rdxContextMenuItemRadioGroup [value]="'1'">
100
- <button class="ContextMenuItem" rdxContextMenuItemRadio [value]="'1'">
101
- <div class="ContextMenuItemIndicator" rdxContextMenuItemIndicator>
102
- <lucide-icon size="16" name="dot" strokeWidth="8"></lucide-icon>
103
- </div>
104
- Pedro Duarte
105
- </button>
106
- <button class="ContextMenuItem" rdxContextMenuItemRadio [value]="'2'">
107
- <div class="ContextMenuItemIndicator" rdxContextMenuItemIndicator>
108
- <lucide-icon size="16" name="dot" strokeWidth="8"></lucide-icon>
109
- </div>
110
- Colm Tuite
111
- </button>
112
- </div>
113
- </div>
114
- </ng-template>
115
-
116
- <ng-template #share>
117
- <div class="DropdownMenuContent" rdxDropdownMenuContent>
118
- <button class="DropdownMenuItem" rdxDropdownMenuItem>Undo</button>
119
- <button class="DropdownMenuItem" rdxDropdownMenuItem>Redo</button>
120
- <div rdxDropdownMenuSeparator class="DropdownMenuSeparator"></div>
121
- <button class="DropdownMenuItem" rdxDropdownMenuItem>Cut</button>
122
- <button class="DropdownMenuItem" rdxDropdownMenuItem>Copy</button>
123
- <button class="DropdownMenuItem" rdxDropdownMenuItem>Paste</button>
124
- </div>
125
- </ng-template>
126
-
127
- <style>
128
- .context-menu-trigger {
129
- display: block;
130
- border: 2px dashed #fff;
131
- color: #fff;
132
- border-radius: 4px;
133
- font-size: 15px;
134
- -webkit-user-select: none;
135
- user-select: none;
136
- padding: 45px 0;
137
- width: 300px;
138
- text-align: center;
139
-
140
- &:focus: {
141
- outline: none;
142
- box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.5);
143
- },
144
-
145
- &[data-state="open"]: {
146
- background-color: lightblue;
147
- /*display: flex;*/
148
- /*align-items: center;*/
149
- /*justify-content: center;*/
150
- /*width: 200vw;*/
151
- /*height: 200vh;*/
152
- /*gap: 20;*/
153
- }
154
- }
155
- /* reset */
156
- button {
157
- all: unset;
158
- }
159
-
160
- .ContextMenuContent,
161
- .DropdownMenuContent {
162
- flex-direction: column;
163
- display: inline-flex;
164
- min-width: 220px;
165
- background-color: white;
166
- border-radius: 6px;
167
- padding: 5px;
168
- box-shadow: 0 10px 38px -10px rgba(22, 23, 24, 0.35), 0 10px 20px -15px rgba(22, 23, 24, 0.2);
169
- will-change: transform, opacity;
170
- }
171
-
172
- .ContextMenuItem,
173
- .DropdownMenuItem,
174
- .ContextMenuCheckboxItem,
175
- .ContextMenuRadioItem {
176
- font-size: 13px;
177
- line-height: 1;
178
- color: var(--violet-11);
179
- border-radius: 3px;
180
- display: flex;
181
- align-items: center;
182
- height: 25px;
183
- position: relative;
184
- padding: 0 5px 0 25px;
185
- user-select: none;
186
- outline: none;
187
- }
188
-
189
- .ContextMenuItem[data-disabled],
190
- .DropdownMenuItem[data-disabled],
191
- .ContextMenuCheckboxItem[data-disabled],
192
- .ContextMenuRadioItem[data-disabled] {
193
- color: var(--mauve-8);
194
- pointer-events: none;
195
- }
196
- .ContextMenuItem[data-highlighted],
197
- .DropdownMenuItem[data-highlighted],
198
- .ContextMenuCheckboxItem[data-highlighted],
199
- .ContextMenuRadioItem[data-highlighted] {
200
- background-color: var(--violet-9);
201
- color: var(--violet-1);
202
- }
203
-
204
- .DropdownMenuSeparator,
205
- .ContextMenuSeparator {
206
- height: 1px;
207
- background-color: var(--violet-6);
208
- margin: 5px;
209
- }
210
-
211
- .ContextMenuLabel {
212
- padding-left: 25px;
213
- font-size: 12px;
214
- line-height: 25px;
215
- color: var(--mauve-11);
216
- }
217
-
218
- .ContextMenuItemIndicator {
219
- position: absolute;
220
- left: 4px;
221
- width: 25px;
222
- display: inline-flex;
223
- align-items: center;
224
- justify-content: center;
225
- }
226
-
227
- .ContextMenuItemRadioGroup {
228
- display: flex;
229
- flex-direction: column;
230
- }
231
-
232
- .IconButton:hover {
233
- background-color: var(--violet-3);
234
- }
235
-
236
- .IconButton:focus {
237
- box-shadow: 0 0 0 2px black;
238
- }
239
-
240
- .RightSlot {
241
- margin-left: auto;
242
- padding-left: 20px;
243
- color: var(--mauve-9);
244
- display: flex;
245
- flex-direction: row;
246
- flex: 1;
247
- justify-content: flex-end;
248
- }
249
-
250
- </style>
251
- `
252
- })
253
- };
package/core/index.ts DELETED
@@ -1,3 +0,0 @@
1
- export * from './src/accessor/provide-value-accessor';
2
- export * from './src/auto-focus.directive';
3
- export * from './src/inject-ng-control';
@@ -1,20 +0,0 @@
1
- import { Provider, Type } from '@angular/core';
2
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
-
4
- /**
5
- * Include in the providers section of a component which utilizes ControlValueAccessor to redundant code.
6
- *
7
- * ```ts
8
- * @Directive({
9
- * providers: [provideValueAccessor(ExampleDirective)]
10
- *}
11
- * export class ExampleDirective{}
12
- * ```
13
- */
14
- export function provideValueAccessor(type: Type<never>): Provider {
15
- return {
16
- provide: NG_VALUE_ACCESSOR,
17
- useExisting: type,
18
- multi: true
19
- };
20
- }
@@ -1,81 +0,0 @@
1
- import { booleanAttribute, Directive, ElementRef, inject, Input, NgZone } from '@angular/core';
2
-
3
- /*
4
- * <div [rdxAutoFocus]="true"></div>
5
- */
6
-
7
- @Directive({
8
- selector: '[rdxAutoFocus]',
9
- standalone: true
10
- })
11
- export class RdxAutoFocusDirective {
12
- #elementRef = inject(ElementRef);
13
- #ngZone = inject(NgZone);
14
-
15
- private _autoSelect = false;
16
-
17
- /**
18
- * @default false
19
- */
20
- @Input({ alias: 'rdxAutoFocus', transform: booleanAttribute })
21
- set autoFocus(value: boolean) {
22
- if (value) {
23
- // Note: Running this outside Angular's zone because `element.focus()` does not trigger change detection.
24
- this.#ngZone.runOutsideAngular(() =>
25
- // Note: `element.focus()` causes re-layout which might lead to frame drops on slower devices.
26
- // https://gist.github.com/paulirish/5d52fb081b3570c81e3a#setting-focus
27
- // `setTimeout` is a macrotask executed within the current rendering frame.
28
- // Animation tasks are executed in the next rendering frame.
29
- reqAnimationFrame(() => {
30
- this.#elementRef.nativeElement.focus();
31
- if (this._autoSelect && this.#elementRef.nativeElement.select) {
32
- this.#elementRef.nativeElement.select();
33
- }
34
- })
35
- );
36
- }
37
- }
38
-
39
- // Setter for autoSelect attribute to enable text selection when autoFocus is true.
40
- @Input({ transform: booleanAttribute })
41
- set autoSelect(value: boolean) {
42
- this._autoSelect = value;
43
- }
44
- }
45
-
46
- const availablePrefixes = ['moz', 'ms', 'webkit'];
47
-
48
- function requestAnimationFramePolyfill(): typeof requestAnimationFrame {
49
- let lastTime = 0;
50
-
51
- return function (callback: FrameRequestCallback): number {
52
- const currTime = new Date().getTime();
53
- const timeToCall = Math.max(0, 16 - (currTime - lastTime));
54
-
55
- const id = setTimeout(() => {
56
- callback(currTime + timeToCall);
57
- }, timeToCall) as any;
58
-
59
- lastTime = currTime + timeToCall;
60
-
61
- return id;
62
- };
63
- }
64
-
65
- // Function to get the appropriate requestAnimationFrame method with fallback to polyfill.
66
- function getRequestAnimationFrame(): typeof requestAnimationFrame {
67
- if (typeof window === 'undefined') {
68
- return () => 0;
69
- }
70
- if (window.requestAnimationFrame) {
71
- // https://github.com/vuejs/vue/issues/4465
72
- return window.requestAnimationFrame.bind(window);
73
- }
74
-
75
- const prefix = availablePrefixes.filter((key) => `${key}RequestAnimationFrame` in window)[0];
76
-
77
- return prefix ? (window as any)[`${prefix}RequestAnimationFrame`] : requestAnimationFramePolyfill();
78
- }
79
-
80
- // Get the requestAnimationFrame function or its polyfill.
81
- const reqAnimationFrame = getRequestAnimationFrame();
@@ -1,28 +0,0 @@
1
- import { inject } from '@angular/core';
2
- import { FormControlDirective, FormControlName, NgControl, NgModel } from '@angular/forms';
3
-
4
- export function injectNgControl(params: {
5
- optional: true;
6
- }): FormControlDirective | FormControlName | NgModel | undefined;
7
- export function injectNgControl(params: { optional: false }): FormControlDirective | FormControlName | NgModel;
8
- export function injectNgControl(): FormControlDirective | FormControlName | NgModel;
9
-
10
- export function injectNgControl(params?: { optional: true } | { optional: false }) {
11
- const ngControl = inject(NgControl, { self: true, optional: true });
12
-
13
- if (!params?.optional && !ngControl) throw new Error('NgControl not found');
14
-
15
- if (
16
- ngControl instanceof FormControlDirective ||
17
- ngControl instanceof FormControlName ||
18
- ngControl instanceof NgModel
19
- ) {
20
- return ngControl;
21
- }
22
-
23
- if (params?.optional) {
24
- return undefined;
25
- }
26
-
27
- throw new Error('NgControl is not an instance of FormControlDirective, FormControlName or NgModel');
28
- }
package/core/src/mount.ts DELETED
@@ -1,27 +0,0 @@
1
- import { AfterViewInit, Directive } from '@angular/core';
2
-
3
- const callAll =
4
- <T extends (...a: never[]) => void>(...fns: (T | undefined)[]) =>
5
- (...a: Parameters<T>) => {
6
- fns.forEach(function (fn) {
7
- fn?.(...a);
8
- });
9
- };
10
-
11
- @Directive({
12
- standalone: true
13
- })
14
- export class OnMountDirective implements AfterViewInit {
15
- #onMountFns?: () => void;
16
-
17
- onMount(fn: () => void) {
18
- this.#onMountFns = callAll(this.#onMountFns, fn);
19
- }
20
-
21
- ngAfterViewInit() {
22
- if (!this.#onMountFns) {
23
- throw new Error('The onMount function must be called before the component is mounted.');
24
- }
25
- this.#onMountFns();
26
- }
27
- }
@@ -1,77 +0,0 @@
1
- import { Component, DebugElement } from '@angular/core';
2
- import { ComponentFixture, TestBed } from '@angular/core/testing';
3
- import { By } from '@angular/platform-browser';
4
- import { Subject } from 'rxjs';
5
- import { RdxDialogContentDirective } from '../src/dialog-content.directive';
6
- import { RdxDialogRef } from '../src/dialog-ref';
7
-
8
- @Component({
9
- template: '<div rdxDialogContent>Dialog Content</div>'
10
- })
11
- class TestComponent {}
12
-
13
- describe('RdxDialogContentDirective', () => {
14
- let fixture: ComponentFixture<TestComponent>;
15
- let directiveElement: DebugElement;
16
- let directive: RdxDialogContentDirective;
17
- let dialogRefMock: jest.Mocked<RdxDialogRef>;
18
- let closedSubject: Subject<any>;
19
-
20
- beforeEach(async () => {
21
- closedSubject = new Subject();
22
- dialogRefMock = {
23
- closed$: closedSubject.asObservable(),
24
- close: jest.fn(),
25
- dismiss: jest.fn()
26
- } as any;
27
-
28
- await TestBed.configureTestingModule({
29
- declarations: [TestComponent],
30
- imports: [RdxDialogContentDirective],
31
- providers: [
32
- { provide: RdxDialogRef, useValue: dialogRefMock }]
33
- }).compileComponents();
34
-
35
- fixture = TestBed.createComponent(TestComponent);
36
- directiveElement = fixture.debugElement.query(By.directive(RdxDialogContentDirective));
37
- directive = directiveElement.injector.get(RdxDialogContentDirective);
38
- fixture.detectChanges();
39
- });
40
-
41
- it('should create', () => {
42
- expect(directive).toBeTruthy();
43
- });
44
-
45
- it('should have correct initial state', () => {
46
- expect(directive['state']()).toBe('open');
47
- });
48
-
49
- it('should update state when dialog is closed', () => {
50
- closedSubject.next(undefined);
51
- fixture.detectChanges();
52
- expect(directive['state']()).toBe('closed');
53
- });
54
-
55
- it('should call dialogRef.dismiss when dismiss method is called', () => {
56
- directive.dismiss();
57
- expect(dialogRefMock.dismiss).toHaveBeenCalled();
58
- });
59
-
60
- it('should call dialogRef.dismiss when dismiss method is called', () => {
61
- directive.dismiss();
62
- expect(dialogRefMock.dismiss).toHaveBeenCalled();
63
- });
64
-
65
- it('should have correct host bindings', () => {
66
- const element = directiveElement.nativeElement;
67
- expect(element.getAttribute('role')).toBe('dialog');
68
- expect(element.getAttribute('aria-describedby')).toBe('true');
69
- expect(element.getAttribute('aria-labelledby')).toBe('true');
70
- expect(element.getAttribute('data-state')).toBe('open');
71
-
72
- closedSubject.next(undefined);
73
- fixture.detectChanges();
74
-
75
- expect(element.getAttribute('data-state')).toBe('closed');
76
- });
77
- });