@auto-engineer/react-gen 1.134.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 (794) hide show
  1. package/dist/skills/design/SKILL.md +302 -0
  2. package/dist/skills/design/data/cip/deliverables.csv +51 -0
  3. package/dist/skills/design/data/cip/industries.csv +21 -0
  4. package/dist/skills/design/data/cip/mockup-contexts.csv +21 -0
  5. package/dist/skills/design/data/cip/styles.csv +21 -0
  6. package/dist/skills/design/data/icon/styles.csv +16 -0
  7. package/dist/skills/design/data/logo/colors.csv +56 -0
  8. package/dist/skills/design/data/logo/industries.csv +56 -0
  9. package/dist/skills/design/data/logo/styles.csv +56 -0
  10. package/dist/skills/design/references/banner-sizes-and-styles.md +118 -0
  11. package/dist/skills/design/references/cip-deliverable-guide.md +95 -0
  12. package/dist/skills/design/references/cip-design.md +121 -0
  13. package/dist/skills/design/references/cip-prompt-engineering.md +84 -0
  14. package/dist/skills/design/references/cip-style-guide.md +68 -0
  15. package/dist/skills/design/references/design-routing.md +207 -0
  16. package/dist/skills/design/references/icon-design.md +122 -0
  17. package/dist/skills/design/references/logo-color-psychology.md +101 -0
  18. package/dist/skills/design/references/logo-design.md +92 -0
  19. package/dist/skills/design/references/logo-prompt-engineering.md +158 -0
  20. package/dist/skills/design/references/logo-style-guide.md +109 -0
  21. package/dist/skills/design/references/slides-copywriting-formulas.md +84 -0
  22. package/dist/skills/design/references/slides-create.md +4 -0
  23. package/dist/skills/design/references/slides-html-template.md +295 -0
  24. package/dist/skills/design/references/slides-layout-patterns.md +137 -0
  25. package/dist/skills/design/references/slides-strategies.md +94 -0
  26. package/dist/skills/design/references/slides.md +42 -0
  27. package/dist/skills/design/references/social-photos-design.md +329 -0
  28. package/dist/skills/design/scripts/cip/core.py +215 -0
  29. package/dist/skills/design/scripts/cip/generate.py +484 -0
  30. package/dist/skills/design/scripts/cip/render-html.py +424 -0
  31. package/dist/skills/design/scripts/cip/search.py +127 -0
  32. package/dist/skills/design/scripts/icon/generate.py +487 -0
  33. package/dist/skills/design/scripts/logo/core.py +175 -0
  34. package/dist/skills/design/scripts/logo/generate.py +362 -0
  35. package/dist/skills/design/scripts/logo/search.py +114 -0
  36. package/dist/skills/design-system/SKILL.md +244 -0
  37. package/dist/skills/design-system/data/slide-backgrounds.csv +11 -0
  38. package/dist/skills/design-system/data/slide-charts.csv +26 -0
  39. package/dist/skills/design-system/data/slide-color-logic.csv +14 -0
  40. package/dist/skills/design-system/data/slide-copy.csv +26 -0
  41. package/dist/skills/design-system/data/slide-layout-logic.csv +16 -0
  42. package/dist/skills/design-system/data/slide-layouts.csv +26 -0
  43. package/dist/skills/design-system/data/slide-strategies.csv +16 -0
  44. package/dist/skills/design-system/data/slide-typography.csv +15 -0
  45. package/dist/skills/design-system/references/component-specs.md +236 -0
  46. package/dist/skills/design-system/references/component-tokens.md +214 -0
  47. package/dist/skills/design-system/references/primitive-tokens.md +203 -0
  48. package/dist/skills/design-system/references/semantic-tokens.md +215 -0
  49. package/dist/skills/design-system/references/states-and-variants.md +241 -0
  50. package/dist/skills/design-system/references/tailwind-integration.md +251 -0
  51. package/dist/skills/design-system/references/token-architecture.md +224 -0
  52. package/dist/skills/design-system/scripts/embed-tokens.cjs +97 -0
  53. package/dist/skills/design-system/scripts/fetch-background.py +317 -0
  54. package/dist/skills/design-system/scripts/generate-slide.py +753 -0
  55. package/dist/skills/design-system/scripts/generate-tokens.cjs +213 -0
  56. package/dist/skills/design-system/scripts/html-token-validator.py +327 -0
  57. package/dist/skills/design-system/scripts/search-slides.py +218 -0
  58. package/dist/skills/design-system/scripts/slide-token-validator.py +35 -0
  59. package/dist/skills/design-system/scripts/slide_search_core.py +453 -0
  60. package/dist/skills/design-system/scripts/validate-tokens.cjs +251 -0
  61. package/dist/skills/design-system/templates/design-tokens-starter.json +143 -0
  62. package/dist/skills/design-taste-frontend/SKILL.md +79 -0
  63. package/dist/skills/emil-design-engineering/SKILL.md +108 -0
  64. package/dist/skills/emil-design-engineering/animations.md +266 -0
  65. package/dist/skills/emil-design-engineering/component-design.md +382 -0
  66. package/dist/skills/emil-design-engineering/forms-controls.md +261 -0
  67. package/dist/skills/emil-design-engineering/marketing.md +160 -0
  68. package/dist/skills/emil-design-engineering/performance.md +222 -0
  69. package/dist/skills/emil-design-engineering/touch-accessibility.md +236 -0
  70. package/dist/skills/emil-design-engineering/ui-polish.md +303 -0
  71. package/dist/skills/frontend-design/SKILL.md +42 -0
  72. package/dist/skills/full-output-enforcement/SKILL.md +32 -0
  73. package/dist/skills/high-end-visual-design/SKILL.md +98 -0
  74. package/dist/skills/react-doctor/AGENTS.md +15 -0
  75. package/dist/skills/react-doctor/SKILL.md +19 -0
  76. package/dist/skills/redesign-existing-projects/SKILL.md +178 -0
  77. package/dist/skills/ui-styling/LICENSE.txt +202 -0
  78. package/dist/skills/ui-styling/SKILL.md +324 -0
  79. package/dist/skills/ui-styling/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  80. package/dist/skills/ui-styling/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  81. package/dist/skills/ui-styling/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  82. package/dist/skills/ui-styling/canvas-fonts/BigShoulders-OFL.txt +93 -0
  83. package/dist/skills/ui-styling/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  84. package/dist/skills/ui-styling/canvas-fonts/Boldonse-OFL.txt +93 -0
  85. package/dist/skills/ui-styling/canvas-fonts/Boldonse-Regular.ttf +0 -0
  86. package/dist/skills/ui-styling/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  87. package/dist/skills/ui-styling/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  88. package/dist/skills/ui-styling/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  89. package/dist/skills/ui-styling/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  90. package/dist/skills/ui-styling/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  91. package/dist/skills/ui-styling/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  92. package/dist/skills/ui-styling/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  93. package/dist/skills/ui-styling/canvas-fonts/DMMono-OFL.txt +93 -0
  94. package/dist/skills/ui-styling/canvas-fonts/DMMono-Regular.ttf +0 -0
  95. package/dist/skills/ui-styling/canvas-fonts/EricaOne-OFL.txt +94 -0
  96. package/dist/skills/ui-styling/canvas-fonts/EricaOne-Regular.ttf +0 -0
  97. package/dist/skills/ui-styling/canvas-fonts/GeistMono-Bold.ttf +0 -0
  98. package/dist/skills/ui-styling/canvas-fonts/GeistMono-OFL.txt +93 -0
  99. package/dist/skills/ui-styling/canvas-fonts/GeistMono-Regular.ttf +0 -0
  100. package/dist/skills/ui-styling/canvas-fonts/Gloock-OFL.txt +93 -0
  101. package/dist/skills/ui-styling/canvas-fonts/Gloock-Regular.ttf +0 -0
  102. package/dist/skills/ui-styling/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  103. package/dist/skills/ui-styling/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  104. package/dist/skills/ui-styling/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  105. package/dist/skills/ui-styling/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  106. package/dist/skills/ui-styling/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  107. package/dist/skills/ui-styling/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  108. package/dist/skills/ui-styling/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  109. package/dist/skills/ui-styling/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  110. package/dist/skills/ui-styling/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  111. package/dist/skills/ui-styling/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  112. package/dist/skills/ui-styling/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  113. package/dist/skills/ui-styling/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  114. package/dist/skills/ui-styling/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  115. package/dist/skills/ui-styling/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  116. package/dist/skills/ui-styling/canvas-fonts/Italiana-OFL.txt +93 -0
  117. package/dist/skills/ui-styling/canvas-fonts/Italiana-Regular.ttf +0 -0
  118. package/dist/skills/ui-styling/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  119. package/dist/skills/ui-styling/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  120. package/dist/skills/ui-styling/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  121. package/dist/skills/ui-styling/canvas-fonts/Jura-Light.ttf +0 -0
  122. package/dist/skills/ui-styling/canvas-fonts/Jura-Medium.ttf +0 -0
  123. package/dist/skills/ui-styling/canvas-fonts/Jura-OFL.txt +93 -0
  124. package/dist/skills/ui-styling/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  125. package/dist/skills/ui-styling/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  126. package/dist/skills/ui-styling/canvas-fonts/Lora-Bold.ttf +0 -0
  127. package/dist/skills/ui-styling/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  128. package/dist/skills/ui-styling/canvas-fonts/Lora-Italic.ttf +0 -0
  129. package/dist/skills/ui-styling/canvas-fonts/Lora-OFL.txt +93 -0
  130. package/dist/skills/ui-styling/canvas-fonts/Lora-Regular.ttf +0 -0
  131. package/dist/skills/ui-styling/canvas-fonts/NationalPark-Bold.ttf +0 -0
  132. package/dist/skills/ui-styling/canvas-fonts/NationalPark-OFL.txt +93 -0
  133. package/dist/skills/ui-styling/canvas-fonts/NationalPark-Regular.ttf +0 -0
  134. package/dist/skills/ui-styling/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  135. package/dist/skills/ui-styling/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  136. package/dist/skills/ui-styling/canvas-fonts/Outfit-Bold.ttf +0 -0
  137. package/dist/skills/ui-styling/canvas-fonts/Outfit-OFL.txt +93 -0
  138. package/dist/skills/ui-styling/canvas-fonts/Outfit-Regular.ttf +0 -0
  139. package/dist/skills/ui-styling/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  140. package/dist/skills/ui-styling/canvas-fonts/PixelifySans-OFL.txt +93 -0
  141. package/dist/skills/ui-styling/canvas-fonts/PoiretOne-OFL.txt +93 -0
  142. package/dist/skills/ui-styling/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  143. package/dist/skills/ui-styling/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  144. package/dist/skills/ui-styling/canvas-fonts/RedHatMono-OFL.txt +93 -0
  145. package/dist/skills/ui-styling/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  146. package/dist/skills/ui-styling/canvas-fonts/Silkscreen-OFL.txt +93 -0
  147. package/dist/skills/ui-styling/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  148. package/dist/skills/ui-styling/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  149. package/dist/skills/ui-styling/canvas-fonts/SmoochSans-OFL.txt +93 -0
  150. package/dist/skills/ui-styling/canvas-fonts/Tektur-Medium.ttf +0 -0
  151. package/dist/skills/ui-styling/canvas-fonts/Tektur-OFL.txt +93 -0
  152. package/dist/skills/ui-styling/canvas-fonts/Tektur-Regular.ttf +0 -0
  153. package/dist/skills/ui-styling/canvas-fonts/WorkSans-Bold.ttf +0 -0
  154. package/dist/skills/ui-styling/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  155. package/dist/skills/ui-styling/canvas-fonts/WorkSans-Italic.ttf +0 -0
  156. package/dist/skills/ui-styling/canvas-fonts/WorkSans-OFL.txt +93 -0
  157. package/dist/skills/ui-styling/canvas-fonts/WorkSans-Regular.ttf +0 -0
  158. package/dist/skills/ui-styling/canvas-fonts/YoungSerif-OFL.txt +93 -0
  159. package/dist/skills/ui-styling/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  160. package/dist/skills/ui-styling/references/canvas-design-system.md +320 -0
  161. package/dist/skills/ui-styling/references/shadcn-accessibility.md +471 -0
  162. package/dist/skills/ui-styling/references/shadcn-components.md +424 -0
  163. package/dist/skills/ui-styling/references/shadcn-theming.md +373 -0
  164. package/dist/skills/ui-styling/references/tailwind-customization.md +483 -0
  165. package/dist/skills/ui-styling/references/tailwind-responsive.md +382 -0
  166. package/dist/skills/ui-styling/references/tailwind-utilities.md +455 -0
  167. package/dist/skills/ui-styling/scripts/.coverage +0 -0
  168. package/dist/skills/ui-styling/scripts/requirements.txt +17 -0
  169. package/dist/skills/ui-styling/scripts/shadcn_add.py +292 -0
  170. package/dist/skills/ui-styling/scripts/tailwind_config_gen.py +456 -0
  171. package/dist/skills/ui-styling/scripts/tests/coverage-ui.json +1392 -0
  172. package/dist/skills/ui-styling/scripts/tests/requirements.txt +3 -0
  173. package/dist/skills/ui-styling/scripts/tests/test_shadcn_add.py +266 -0
  174. package/dist/skills/ui-styling/scripts/tests/test_tailwind_config_gen.py +336 -0
  175. package/dist/skills/ui-ux-pro-max/SKILL.md +659 -0
  176. package/dist/skills/ui-ux-pro-max/data/_sync_all.py +414 -0
  177. package/dist/skills/ui-ux-pro-max/data/app-interface.csv +31 -0
  178. package/dist/skills/ui-ux-pro-max/data/charts.csv +26 -0
  179. package/dist/skills/ui-ux-pro-max/data/colors.csv +162 -0
  180. package/dist/skills/ui-ux-pro-max/data/design.csv +1776 -0
  181. package/dist/skills/ui-ux-pro-max/data/draft.csv +1779 -0
  182. package/dist/skills/ui-ux-pro-max/data/google-fonts.csv +1924 -0
  183. package/dist/skills/ui-ux-pro-max/data/icons.csv +106 -0
  184. package/dist/skills/ui-ux-pro-max/data/landing.csv +35 -0
  185. package/dist/skills/ui-ux-pro-max/data/products.csv +162 -0
  186. package/dist/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
  187. package/dist/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  188. package/dist/skills/ui-ux-pro-max/data/styles.csv +85 -0
  189. package/dist/skills/ui-ux-pro-max/data/typography.csv +74 -0
  190. package/dist/skills/ui-ux-pro-max/data/ui-reasoning.csv +162 -0
  191. package/dist/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  192. package/dist/skills/ui-ux-pro-max/scripts/__pycache__/core.cpython-314.pyc +0 -0
  193. package/dist/skills/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-314.pyc +0 -0
  194. package/dist/skills/ui-ux-pro-max/scripts/core.py +247 -0
  195. package/dist/skills/ui-ux-pro-max/scripts/design_system.py +1067 -0
  196. package/dist/skills/ui-ux-pro-max/scripts/search.py +114 -0
  197. package/dist/skills/vercel-react-best-practices/AGENTS.md +2934 -0
  198. package/dist/skills/vercel-react-best-practices/README.md +123 -0
  199. package/dist/skills/vercel-react-best-practices/SKILL.md +136 -0
  200. package/dist/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  201. package/dist/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
  202. package/dist/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
  203. package/dist/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
  204. package/dist/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
  205. package/dist/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
  206. package/dist/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
  207. package/dist/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
  208. package/dist/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
  209. package/dist/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
  210. package/dist/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
  211. package/dist/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  212. package/dist/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
  213. package/dist/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
  214. package/dist/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
  215. package/dist/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
  216. package/dist/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
  217. package/dist/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
  218. package/dist/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
  219. package/dist/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
  220. package/dist/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
  221. package/dist/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
  222. package/dist/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
  223. package/dist/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
  224. package/dist/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
  225. package/dist/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
  226. package/dist/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
  227. package/dist/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
  228. package/dist/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
  229. package/dist/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
  230. package/dist/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  231. package/dist/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
  232. package/dist/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
  233. package/dist/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  234. package/dist/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  235. package/dist/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
  236. package/dist/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
  237. package/dist/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
  238. package/dist/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
  239. package/dist/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
  240. package/dist/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
  241. package/dist/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
  242. package/dist/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
  243. package/dist/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  244. package/dist/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
  245. package/dist/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
  246. package/dist/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
  247. package/dist/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
  248. package/dist/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
  249. package/dist/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
  250. package/dist/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
  251. package/dist/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
  252. package/dist/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
  253. package/dist/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
  254. package/dist/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
  255. package/dist/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
  256. package/dist/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
  257. package/dist/skills/web-animation-design/PRACTICAL-TIPS.md +304 -0
  258. package/dist/skills/web-animation-design/SKILL.md +336 -0
  259. package/dist/skills/web-design-guidelines/SKILL.md +39 -0
  260. package/dist/src/agents/create-constants-agent.d.ts +6 -0
  261. package/dist/src/agents/create-constants-agent.d.ts.map +1 -0
  262. package/dist/src/agents/create-constants-agent.js +42 -0
  263. package/dist/src/agents/create-constants-agent.js.map +1 -0
  264. package/dist/src/agents/create-landing-page-agent.d.ts +4 -0
  265. package/dist/src/agents/create-landing-page-agent.d.ts.map +1 -0
  266. package/dist/src/agents/create-landing-page-agent.js +62 -0
  267. package/dist/src/agents/create-landing-page-agent.js.map +1 -0
  268. package/dist/src/agents/create-narrative-agent.d.ts +4 -0
  269. package/dist/src/agents/create-narrative-agent.d.ts.map +1 -0
  270. package/dist/src/agents/create-narrative-agent.js +36 -0
  271. package/dist/src/agents/create-narrative-agent.js.map +1 -0
  272. package/dist/src/agents/create-pipeline.d.ts +9 -0
  273. package/dist/src/agents/create-pipeline.d.ts.map +1 -0
  274. package/dist/src/agents/create-pipeline.js +28 -0
  275. package/dist/src/agents/create-pipeline.js.map +1 -0
  276. package/dist/src/agents/create-router-agent.d.ts +4 -0
  277. package/dist/src/agents/create-router-agent.d.ts.map +1 -0
  278. package/dist/src/agents/create-router-agent.js +46 -0
  279. package/dist/src/agents/create-router-agent.js.map +1 -0
  280. package/dist/src/agents/create-theme-agent.d.ts +4 -0
  281. package/dist/src/agents/create-theme-agent.d.ts.map +1 -0
  282. package/dist/src/agents/create-theme-agent.js +105 -0
  283. package/dist/src/agents/create-theme-agent.js.map +1 -0
  284. package/dist/src/agents/create-validation-agent.d.ts +4 -0
  285. package/dist/src/agents/create-validation-agent.d.ts.map +1 -0
  286. package/dist/src/agents/create-validation-agent.js +36 -0
  287. package/dist/src/agents/create-validation-agent.js.map +1 -0
  288. package/dist/src/agents/scaffold-agent.d.ts +5 -0
  289. package/dist/src/agents/scaffold-agent.d.ts.map +1 -0
  290. package/dist/src/agents/scaffold-agent.js +11 -0
  291. package/dist/src/agents/scaffold-agent.js.map +1 -0
  292. package/dist/src/commands/generate-react-app.d.ts +27 -0
  293. package/dist/src/commands/generate-react-app.d.ts.map +1 -0
  294. package/dist/src/commands/generate-react-app.js +92 -0
  295. package/dist/src/commands/generate-react-app.js.map +1 -0
  296. package/dist/src/config.d.ts +3 -0
  297. package/dist/src/config.d.ts.map +1 -0
  298. package/dist/src/config.js +15 -0
  299. package/dist/src/config.js.map +1 -0
  300. package/dist/src/index.d.ts +10 -0
  301. package/dist/src/index.d.ts.map +1 -0
  302. package/dist/src/index.js +4 -0
  303. package/dist/src/index.js.map +1 -0
  304. package/dist/src/prompts/build-narrative-context.d.ts +3 -0
  305. package/dist/src/prompts/build-narrative-context.d.ts.map +1 -0
  306. package/dist/src/prompts/build-narrative-context.js +103 -0
  307. package/dist/src/prompts/build-narrative-context.js.map +1 -0
  308. package/dist/src/prompts/landing-page-system.d.ts +2 -0
  309. package/dist/src/prompts/landing-page-system.d.ts.map +1 -0
  310. package/dist/src/prompts/landing-page-system.js +63 -0
  311. package/dist/src/prompts/landing-page-system.js.map +1 -0
  312. package/dist/src/prompts/narrative-system.d.ts +2 -0
  313. package/dist/src/prompts/narrative-system.d.ts.map +1 -0
  314. package/dist/src/prompts/narrative-system.js +52 -0
  315. package/dist/src/prompts/narrative-system.js.map +1 -0
  316. package/dist/src/prompts/router-system.d.ts +2 -0
  317. package/dist/src/prompts/router-system.d.ts.map +1 -0
  318. package/dist/src/prompts/router-system.js +35 -0
  319. package/dist/src/prompts/router-system.js.map +1 -0
  320. package/dist/src/prompts/theme-system.d.ts +2 -0
  321. package/dist/src/prompts/theme-system.d.ts.map +1 -0
  322. package/dist/src/prompts/theme-system.js +126 -0
  323. package/dist/src/prompts/theme-system.js.map +1 -0
  324. package/dist/src/prompts/validation-system.d.ts +2 -0
  325. package/dist/src/prompts/validation-system.d.ts.map +1 -0
  326. package/dist/src/prompts/validation-system.js +28 -0
  327. package/dist/src/prompts/validation-system.js.map +1 -0
  328. package/dist/src/tools/check-imports.d.ts +6 -0
  329. package/dist/src/tools/check-imports.d.ts.map +1 -0
  330. package/dist/src/tools/check-imports.js +129 -0
  331. package/dist/src/tools/check-imports.js.map +1 -0
  332. package/dist/src/tools/exit-loop.d.ts +6 -0
  333. package/dist/src/tools/exit-loop.d.ts.map +1 -0
  334. package/dist/src/tools/exit-loop.js +12 -0
  335. package/dist/src/tools/exit-loop.js.map +1 -0
  336. package/dist/src/tools/list-files.d.ts +4 -0
  337. package/dist/src/tools/list-files.d.ts.map +1 -0
  338. package/dist/src/tools/list-files.js +36 -0
  339. package/dist/src/tools/list-files.js.map +1 -0
  340. package/dist/src/tools/read-file.d.ts +10 -0
  341. package/dist/src/tools/read-file.d.ts.map +1 -0
  342. package/dist/src/tools/read-file.js +21 -0
  343. package/dist/src/tools/read-file.js.map +1 -0
  344. package/dist/src/tools/run-eslint.d.ts +6 -0
  345. package/dist/src/tools/run-eslint.d.ts.map +1 -0
  346. package/dist/src/tools/run-eslint.js +27 -0
  347. package/dist/src/tools/run-eslint.js.map +1 -0
  348. package/dist/src/tools/run-tsc.d.ts +6 -0
  349. package/dist/src/tools/run-tsc.d.ts.map +1 -0
  350. package/dist/src/tools/run-tsc.js +27 -0
  351. package/dist/src/tools/run-tsc.js.map +1 -0
  352. package/dist/src/tools/write-file.d.ts +15 -0
  353. package/dist/src/tools/write-file.d.ts.map +1 -0
  354. package/dist/src/tools/write-file.js +44 -0
  355. package/dist/src/tools/write-file.js.map +1 -0
  356. package/dist/src/types.d.ts +330 -0
  357. package/dist/src/types.d.ts.map +1 -0
  358. package/dist/src/types.js +102 -0
  359. package/dist/src/types.js.map +1 -0
  360. package/dist/src/utils/create-skill-tool.d.ts +2 -0
  361. package/dist/src/utils/create-skill-tool.d.ts.map +1 -0
  362. package/dist/src/utils/create-skill-tool.js +13 -0
  363. package/dist/src/utils/create-skill-tool.js.map +1 -0
  364. package/dist/src/utils/parse-model.d.ts +3 -0
  365. package/dist/src/utils/parse-model.d.ts.map +1 -0
  366. package/dist/src/utils/parse-model.js +7 -0
  367. package/dist/src/utils/parse-model.js.map +1 -0
  368. package/dist/src/utils/slugify.d.ts +2 -0
  369. package/dist/src/utils/slugify.d.ts.map +1 -0
  370. package/dist/src/utils/slugify.js +7 -0
  371. package/dist/src/utils/slugify.js.map +1 -0
  372. package/dist/starter/.env.example +1 -0
  373. package/dist/starter/README.md +73 -0
  374. package/dist/starter/components.json +21 -0
  375. package/dist/starter/eslint.config.js +23 -0
  376. package/dist/starter/index.html +13 -0
  377. package/dist/starter/package-lock.json +7590 -0
  378. package/dist/starter/package.json +57 -0
  379. package/dist/starter/pnpm-lock.yaml +4479 -0
  380. package/dist/starter/public/favicon.svg +1 -0
  381. package/dist/starter/public/icons.svg +24 -0
  382. package/dist/starter/src/App.tsx +7 -0
  383. package/dist/starter/src/assets/hero.png +0 -0
  384. package/dist/starter/src/assets/vite.svg +1 -0
  385. package/dist/starter/src/components/error-boundary.tsx +38 -0
  386. package/dist/starter/src/components/not-found.tsx +16 -0
  387. package/dist/starter/src/components/ui/accordion.tsx +51 -0
  388. package/dist/starter/src/components/ui/alert-dialog.tsx +162 -0
  389. package/dist/starter/src/components/ui/alert.tsx +49 -0
  390. package/dist/starter/src/components/ui/aspect-ratio.tsx +9 -0
  391. package/dist/starter/src/components/ui/avatar.tsx +87 -0
  392. package/dist/starter/src/components/ui/badge.tsx +40 -0
  393. package/dist/starter/src/components/ui/breadcrumb.tsx +92 -0
  394. package/dist/starter/src/components/ui/button-group.tsx +74 -0
  395. package/dist/starter/src/components/ui/button.tsx +62 -0
  396. package/dist/starter/src/components/ui/calendar.tsx +158 -0
  397. package/dist/starter/src/components/ui/card.tsx +56 -0
  398. package/dist/starter/src/components/ui/carousel.tsx +215 -0
  399. package/dist/starter/src/components/ui/chart.tsx +296 -0
  400. package/dist/starter/src/components/ui/checkbox.tsx +29 -0
  401. package/dist/starter/src/components/ui/collapsible.tsx +15 -0
  402. package/dist/starter/src/components/ui/combobox.tsx +266 -0
  403. package/dist/starter/src/components/ui/command.tsx +136 -0
  404. package/dist/starter/src/components/ui/context-menu.tsx +211 -0
  405. package/dist/starter/src/components/ui/dialog.tsx +135 -0
  406. package/dist/starter/src/components/ui/direction.tsx +18 -0
  407. package/dist/starter/src/components/ui/drawer.tsx +106 -0
  408. package/dist/starter/src/components/ui/dropdown-menu.tsx +219 -0
  409. package/dist/starter/src/components/ui/empty.tsx +85 -0
  410. package/dist/starter/src/components/ui/field.tsx +225 -0
  411. package/dist/starter/src/components/ui/form.tsx +135 -0
  412. package/dist/starter/src/components/ui/hover-card.tsx +36 -0
  413. package/dist/starter/src/components/ui/input-group.tsx +146 -0
  414. package/dist/starter/src/components/ui/input-otp.tsx +68 -0
  415. package/dist/starter/src/components/ui/input.tsx +21 -0
  416. package/dist/starter/src/components/ui/item.tsx +157 -0
  417. package/dist/starter/src/components/ui/kbd.tsx +22 -0
  418. package/dist/starter/src/components/ui/label.tsx +19 -0
  419. package/dist/starter/src/components/ui/menubar.tsx +236 -0
  420. package/dist/starter/src/components/ui/native-select.tsx +44 -0
  421. package/dist/starter/src/components/ui/navigation-menu.tsx +142 -0
  422. package/dist/starter/src/components/ui/pagination.tsx +98 -0
  423. package/dist/starter/src/components/ui/popover.tsx +52 -0
  424. package/dist/starter/src/components/ui/progress.tsx +24 -0
  425. package/dist/starter/src/components/ui/radio-group.tsx +31 -0
  426. package/dist/starter/src/components/ui/resizable.tsx +47 -0
  427. package/dist/starter/src/components/ui/scroll-area.tsx +46 -0
  428. package/dist/starter/src/components/ui/select.tsx +162 -0
  429. package/dist/starter/src/components/ui/separator.tsx +26 -0
  430. package/dist/starter/src/components/ui/sheet.tsx +107 -0
  431. package/dist/starter/src/components/ui/sidebar.tsx +674 -0
  432. package/dist/starter/src/components/ui/skeleton.tsx +7 -0
  433. package/dist/starter/src/components/ui/slider.tsx +54 -0
  434. package/dist/starter/src/components/ui/sonner.tsx +31 -0
  435. package/dist/starter/src/components/ui/spinner.tsx +9 -0
  436. package/dist/starter/src/components/ui/switch.tsx +33 -0
  437. package/dist/starter/src/components/ui/table.tsx +75 -0
  438. package/dist/starter/src/components/ui/tabs.tsx +69 -0
  439. package/dist/starter/src/components/ui/textarea.tsx +18 -0
  440. package/dist/starter/src/components/ui/toggle-group.tsx +79 -0
  441. package/dist/starter/src/components/ui/toggle.tsx +41 -0
  442. package/dist/starter/src/components/ui/tooltip.tsx +42 -0
  443. package/dist/starter/src/hooks/use-mobile.ts +19 -0
  444. package/dist/starter/src/index.css +93 -0
  445. package/dist/starter/src/lib/graphql-client.ts +5 -0
  446. package/dist/starter/src/lib/providers.tsx +23 -0
  447. package/dist/starter/src/lib/utils.ts +6 -0
  448. package/dist/starter/src/main.tsx +16 -0
  449. package/dist/starter/tsconfig.app.json +32 -0
  450. package/dist/starter/tsconfig.json +4 -0
  451. package/dist/starter/tsconfig.node.json +26 -0
  452. package/dist/starter/vite.config.ts +16 -0
  453. package/dist/tsconfig.tsbuildinfo +1 -0
  454. package/package.json +47 -0
  455. package/skills/design/SKILL.md +302 -0
  456. package/skills/design/data/cip/deliverables.csv +51 -0
  457. package/skills/design/data/cip/industries.csv +21 -0
  458. package/skills/design/data/cip/mockup-contexts.csv +21 -0
  459. package/skills/design/data/cip/styles.csv +21 -0
  460. package/skills/design/data/icon/styles.csv +16 -0
  461. package/skills/design/data/logo/colors.csv +56 -0
  462. package/skills/design/data/logo/industries.csv +56 -0
  463. package/skills/design/data/logo/styles.csv +56 -0
  464. package/skills/design/references/banner-sizes-and-styles.md +118 -0
  465. package/skills/design/references/cip-deliverable-guide.md +95 -0
  466. package/skills/design/references/cip-design.md +121 -0
  467. package/skills/design/references/cip-prompt-engineering.md +84 -0
  468. package/skills/design/references/cip-style-guide.md +68 -0
  469. package/skills/design/references/design-routing.md +207 -0
  470. package/skills/design/references/icon-design.md +122 -0
  471. package/skills/design/references/logo-color-psychology.md +101 -0
  472. package/skills/design/references/logo-design.md +92 -0
  473. package/skills/design/references/logo-prompt-engineering.md +158 -0
  474. package/skills/design/references/logo-style-guide.md +109 -0
  475. package/skills/design/references/slides-copywriting-formulas.md +84 -0
  476. package/skills/design/references/slides-create.md +4 -0
  477. package/skills/design/references/slides-html-template.md +295 -0
  478. package/skills/design/references/slides-layout-patterns.md +137 -0
  479. package/skills/design/references/slides-strategies.md +94 -0
  480. package/skills/design/references/slides.md +42 -0
  481. package/skills/design/references/social-photos-design.md +329 -0
  482. package/skills/design/scripts/cip/core.py +215 -0
  483. package/skills/design/scripts/cip/generate.py +484 -0
  484. package/skills/design/scripts/cip/render-html.py +424 -0
  485. package/skills/design/scripts/cip/search.py +127 -0
  486. package/skills/design/scripts/icon/generate.py +487 -0
  487. package/skills/design/scripts/logo/core.py +175 -0
  488. package/skills/design/scripts/logo/generate.py +362 -0
  489. package/skills/design/scripts/logo/search.py +114 -0
  490. package/skills/design-system/SKILL.md +244 -0
  491. package/skills/design-system/data/slide-backgrounds.csv +11 -0
  492. package/skills/design-system/data/slide-charts.csv +26 -0
  493. package/skills/design-system/data/slide-color-logic.csv +14 -0
  494. package/skills/design-system/data/slide-copy.csv +26 -0
  495. package/skills/design-system/data/slide-layout-logic.csv +16 -0
  496. package/skills/design-system/data/slide-layouts.csv +26 -0
  497. package/skills/design-system/data/slide-strategies.csv +16 -0
  498. package/skills/design-system/data/slide-typography.csv +15 -0
  499. package/skills/design-system/references/component-specs.md +236 -0
  500. package/skills/design-system/references/component-tokens.md +214 -0
  501. package/skills/design-system/references/primitive-tokens.md +203 -0
  502. package/skills/design-system/references/semantic-tokens.md +215 -0
  503. package/skills/design-system/references/states-and-variants.md +241 -0
  504. package/skills/design-system/references/tailwind-integration.md +251 -0
  505. package/skills/design-system/references/token-architecture.md +224 -0
  506. package/skills/design-system/scripts/embed-tokens.cjs +97 -0
  507. package/skills/design-system/scripts/fetch-background.py +317 -0
  508. package/skills/design-system/scripts/generate-slide.py +753 -0
  509. package/skills/design-system/scripts/generate-tokens.cjs +213 -0
  510. package/skills/design-system/scripts/html-token-validator.py +327 -0
  511. package/skills/design-system/scripts/search-slides.py +218 -0
  512. package/skills/design-system/scripts/slide-token-validator.py +35 -0
  513. package/skills/design-system/scripts/slide_search_core.py +453 -0
  514. package/skills/design-system/scripts/validate-tokens.cjs +251 -0
  515. package/skills/design-system/templates/design-tokens-starter.json +143 -0
  516. package/skills/design-taste-frontend/SKILL.md +79 -0
  517. package/skills/emil-design-engineering/SKILL.md +108 -0
  518. package/skills/emil-design-engineering/animations.md +266 -0
  519. package/skills/emil-design-engineering/component-design.md +382 -0
  520. package/skills/emil-design-engineering/forms-controls.md +261 -0
  521. package/skills/emil-design-engineering/marketing.md +160 -0
  522. package/skills/emil-design-engineering/performance.md +222 -0
  523. package/skills/emil-design-engineering/touch-accessibility.md +236 -0
  524. package/skills/emil-design-engineering/ui-polish.md +303 -0
  525. package/skills/frontend-design/SKILL.md +42 -0
  526. package/skills/full-output-enforcement/SKILL.md +32 -0
  527. package/skills/high-end-visual-design/SKILL.md +98 -0
  528. package/skills/react-doctor/AGENTS.md +15 -0
  529. package/skills/react-doctor/SKILL.md +19 -0
  530. package/skills/redesign-existing-projects/SKILL.md +178 -0
  531. package/skills/ui-styling/LICENSE.txt +202 -0
  532. package/skills/ui-styling/SKILL.md +324 -0
  533. package/skills/ui-styling/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  534. package/skills/ui-styling/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  535. package/skills/ui-styling/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  536. package/skills/ui-styling/canvas-fonts/BigShoulders-OFL.txt +93 -0
  537. package/skills/ui-styling/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  538. package/skills/ui-styling/canvas-fonts/Boldonse-OFL.txt +93 -0
  539. package/skills/ui-styling/canvas-fonts/Boldonse-Regular.ttf +0 -0
  540. package/skills/ui-styling/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  541. package/skills/ui-styling/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  542. package/skills/ui-styling/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  543. package/skills/ui-styling/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  544. package/skills/ui-styling/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  545. package/skills/ui-styling/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  546. package/skills/ui-styling/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  547. package/skills/ui-styling/canvas-fonts/DMMono-OFL.txt +93 -0
  548. package/skills/ui-styling/canvas-fonts/DMMono-Regular.ttf +0 -0
  549. package/skills/ui-styling/canvas-fonts/EricaOne-OFL.txt +94 -0
  550. package/skills/ui-styling/canvas-fonts/EricaOne-Regular.ttf +0 -0
  551. package/skills/ui-styling/canvas-fonts/GeistMono-Bold.ttf +0 -0
  552. package/skills/ui-styling/canvas-fonts/GeistMono-OFL.txt +93 -0
  553. package/skills/ui-styling/canvas-fonts/GeistMono-Regular.ttf +0 -0
  554. package/skills/ui-styling/canvas-fonts/Gloock-OFL.txt +93 -0
  555. package/skills/ui-styling/canvas-fonts/Gloock-Regular.ttf +0 -0
  556. package/skills/ui-styling/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  557. package/skills/ui-styling/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  558. package/skills/ui-styling/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  559. package/skills/ui-styling/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  560. package/skills/ui-styling/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  561. package/skills/ui-styling/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  562. package/skills/ui-styling/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  563. package/skills/ui-styling/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  564. package/skills/ui-styling/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  565. package/skills/ui-styling/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  566. package/skills/ui-styling/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  567. package/skills/ui-styling/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  568. package/skills/ui-styling/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  569. package/skills/ui-styling/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  570. package/skills/ui-styling/canvas-fonts/Italiana-OFL.txt +93 -0
  571. package/skills/ui-styling/canvas-fonts/Italiana-Regular.ttf +0 -0
  572. package/skills/ui-styling/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  573. package/skills/ui-styling/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  574. package/skills/ui-styling/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  575. package/skills/ui-styling/canvas-fonts/Jura-Light.ttf +0 -0
  576. package/skills/ui-styling/canvas-fonts/Jura-Medium.ttf +0 -0
  577. package/skills/ui-styling/canvas-fonts/Jura-OFL.txt +93 -0
  578. package/skills/ui-styling/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  579. package/skills/ui-styling/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  580. package/skills/ui-styling/canvas-fonts/Lora-Bold.ttf +0 -0
  581. package/skills/ui-styling/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  582. package/skills/ui-styling/canvas-fonts/Lora-Italic.ttf +0 -0
  583. package/skills/ui-styling/canvas-fonts/Lora-OFL.txt +93 -0
  584. package/skills/ui-styling/canvas-fonts/Lora-Regular.ttf +0 -0
  585. package/skills/ui-styling/canvas-fonts/NationalPark-Bold.ttf +0 -0
  586. package/skills/ui-styling/canvas-fonts/NationalPark-OFL.txt +93 -0
  587. package/skills/ui-styling/canvas-fonts/NationalPark-Regular.ttf +0 -0
  588. package/skills/ui-styling/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  589. package/skills/ui-styling/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  590. package/skills/ui-styling/canvas-fonts/Outfit-Bold.ttf +0 -0
  591. package/skills/ui-styling/canvas-fonts/Outfit-OFL.txt +93 -0
  592. package/skills/ui-styling/canvas-fonts/Outfit-Regular.ttf +0 -0
  593. package/skills/ui-styling/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  594. package/skills/ui-styling/canvas-fonts/PixelifySans-OFL.txt +93 -0
  595. package/skills/ui-styling/canvas-fonts/PoiretOne-OFL.txt +93 -0
  596. package/skills/ui-styling/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  597. package/skills/ui-styling/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  598. package/skills/ui-styling/canvas-fonts/RedHatMono-OFL.txt +93 -0
  599. package/skills/ui-styling/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  600. package/skills/ui-styling/canvas-fonts/Silkscreen-OFL.txt +93 -0
  601. package/skills/ui-styling/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  602. package/skills/ui-styling/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  603. package/skills/ui-styling/canvas-fonts/SmoochSans-OFL.txt +93 -0
  604. package/skills/ui-styling/canvas-fonts/Tektur-Medium.ttf +0 -0
  605. package/skills/ui-styling/canvas-fonts/Tektur-OFL.txt +93 -0
  606. package/skills/ui-styling/canvas-fonts/Tektur-Regular.ttf +0 -0
  607. package/skills/ui-styling/canvas-fonts/WorkSans-Bold.ttf +0 -0
  608. package/skills/ui-styling/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  609. package/skills/ui-styling/canvas-fonts/WorkSans-Italic.ttf +0 -0
  610. package/skills/ui-styling/canvas-fonts/WorkSans-OFL.txt +93 -0
  611. package/skills/ui-styling/canvas-fonts/WorkSans-Regular.ttf +0 -0
  612. package/skills/ui-styling/canvas-fonts/YoungSerif-OFL.txt +93 -0
  613. package/skills/ui-styling/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  614. package/skills/ui-styling/references/canvas-design-system.md +320 -0
  615. package/skills/ui-styling/references/shadcn-accessibility.md +471 -0
  616. package/skills/ui-styling/references/shadcn-components.md +424 -0
  617. package/skills/ui-styling/references/shadcn-theming.md +373 -0
  618. package/skills/ui-styling/references/tailwind-customization.md +483 -0
  619. package/skills/ui-styling/references/tailwind-responsive.md +382 -0
  620. package/skills/ui-styling/references/tailwind-utilities.md +455 -0
  621. package/skills/ui-styling/scripts/.coverage +0 -0
  622. package/skills/ui-styling/scripts/requirements.txt +17 -0
  623. package/skills/ui-styling/scripts/shadcn_add.py +292 -0
  624. package/skills/ui-styling/scripts/tailwind_config_gen.py +456 -0
  625. package/skills/ui-styling/scripts/tests/coverage-ui.json +1392 -0
  626. package/skills/ui-styling/scripts/tests/requirements.txt +3 -0
  627. package/skills/ui-styling/scripts/tests/test_shadcn_add.py +266 -0
  628. package/skills/ui-styling/scripts/tests/test_tailwind_config_gen.py +336 -0
  629. package/skills/ui-ux-pro-max/SKILL.md +659 -0
  630. package/skills/ui-ux-pro-max/data/_sync_all.py +414 -0
  631. package/skills/ui-ux-pro-max/data/app-interface.csv +31 -0
  632. package/skills/ui-ux-pro-max/data/charts.csv +26 -0
  633. package/skills/ui-ux-pro-max/data/colors.csv +162 -0
  634. package/skills/ui-ux-pro-max/data/design.csv +1776 -0
  635. package/skills/ui-ux-pro-max/data/draft.csv +1779 -0
  636. package/skills/ui-ux-pro-max/data/google-fonts.csv +1924 -0
  637. package/skills/ui-ux-pro-max/data/icons.csv +106 -0
  638. package/skills/ui-ux-pro-max/data/landing.csv +35 -0
  639. package/skills/ui-ux-pro-max/data/products.csv +162 -0
  640. package/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
  641. package/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  642. package/skills/ui-ux-pro-max/data/styles.csv +85 -0
  643. package/skills/ui-ux-pro-max/data/typography.csv +74 -0
  644. package/skills/ui-ux-pro-max/data/ui-reasoning.csv +162 -0
  645. package/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  646. package/skills/ui-ux-pro-max/scripts/__pycache__/core.cpython-314.pyc +0 -0
  647. package/skills/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-314.pyc +0 -0
  648. package/skills/ui-ux-pro-max/scripts/core.py +247 -0
  649. package/skills/ui-ux-pro-max/scripts/design_system.py +1067 -0
  650. package/skills/ui-ux-pro-max/scripts/search.py +114 -0
  651. package/skills/vercel-react-best-practices/AGENTS.md +2934 -0
  652. package/skills/vercel-react-best-practices/README.md +123 -0
  653. package/skills/vercel-react-best-practices/SKILL.md +136 -0
  654. package/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  655. package/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
  656. package/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
  657. package/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
  658. package/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
  659. package/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
  660. package/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
  661. package/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
  662. package/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
  663. package/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
  664. package/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
  665. package/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  666. package/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
  667. package/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
  668. package/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
  669. package/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
  670. package/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
  671. package/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
  672. package/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
  673. package/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
  674. package/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
  675. package/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
  676. package/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
  677. package/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
  678. package/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
  679. package/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
  680. package/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
  681. package/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
  682. package/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
  683. package/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
  684. package/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  685. package/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
  686. package/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
  687. package/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  688. package/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  689. package/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
  690. package/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
  691. package/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
  692. package/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
  693. package/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
  694. package/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
  695. package/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
  696. package/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
  697. package/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  698. package/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
  699. package/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
  700. package/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
  701. package/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
  702. package/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
  703. package/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
  704. package/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
  705. package/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
  706. package/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
  707. package/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
  708. package/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
  709. package/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
  710. package/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
  711. package/skills/web-animation-design/PRACTICAL-TIPS.md +304 -0
  712. package/skills/web-animation-design/SKILL.md +336 -0
  713. package/skills/web-design-guidelines/SKILL.md +39 -0
  714. package/starter/.env.example +1 -0
  715. package/starter/README.md +73 -0
  716. package/starter/components.json +21 -0
  717. package/starter/eslint.config.js +23 -0
  718. package/starter/index.html +13 -0
  719. package/starter/package-lock.json +7590 -0
  720. package/starter/package.json +57 -0
  721. package/starter/pnpm-lock.yaml +4479 -0
  722. package/starter/public/favicon.svg +1 -0
  723. package/starter/public/icons.svg +24 -0
  724. package/starter/src/App.tsx +7 -0
  725. package/starter/src/assets/hero.png +0 -0
  726. package/starter/src/assets/vite.svg +1 -0
  727. package/starter/src/components/error-boundary.tsx +38 -0
  728. package/starter/src/components/not-found.tsx +16 -0
  729. package/starter/src/components/ui/accordion.tsx +51 -0
  730. package/starter/src/components/ui/alert-dialog.tsx +162 -0
  731. package/starter/src/components/ui/alert.tsx +49 -0
  732. package/starter/src/components/ui/aspect-ratio.tsx +9 -0
  733. package/starter/src/components/ui/avatar.tsx +87 -0
  734. package/starter/src/components/ui/badge.tsx +40 -0
  735. package/starter/src/components/ui/breadcrumb.tsx +92 -0
  736. package/starter/src/components/ui/button-group.tsx +74 -0
  737. package/starter/src/components/ui/button.tsx +62 -0
  738. package/starter/src/components/ui/calendar.tsx +158 -0
  739. package/starter/src/components/ui/card.tsx +56 -0
  740. package/starter/src/components/ui/carousel.tsx +215 -0
  741. package/starter/src/components/ui/chart.tsx +296 -0
  742. package/starter/src/components/ui/checkbox.tsx +29 -0
  743. package/starter/src/components/ui/collapsible.tsx +15 -0
  744. package/starter/src/components/ui/combobox.tsx +266 -0
  745. package/starter/src/components/ui/command.tsx +136 -0
  746. package/starter/src/components/ui/context-menu.tsx +211 -0
  747. package/starter/src/components/ui/dialog.tsx +135 -0
  748. package/starter/src/components/ui/direction.tsx +18 -0
  749. package/starter/src/components/ui/drawer.tsx +106 -0
  750. package/starter/src/components/ui/dropdown-menu.tsx +219 -0
  751. package/starter/src/components/ui/empty.tsx +85 -0
  752. package/starter/src/components/ui/field.tsx +225 -0
  753. package/starter/src/components/ui/form.tsx +135 -0
  754. package/starter/src/components/ui/hover-card.tsx +36 -0
  755. package/starter/src/components/ui/input-group.tsx +146 -0
  756. package/starter/src/components/ui/input-otp.tsx +68 -0
  757. package/starter/src/components/ui/input.tsx +21 -0
  758. package/starter/src/components/ui/item.tsx +157 -0
  759. package/starter/src/components/ui/kbd.tsx +22 -0
  760. package/starter/src/components/ui/label.tsx +19 -0
  761. package/starter/src/components/ui/menubar.tsx +236 -0
  762. package/starter/src/components/ui/native-select.tsx +44 -0
  763. package/starter/src/components/ui/navigation-menu.tsx +142 -0
  764. package/starter/src/components/ui/pagination.tsx +98 -0
  765. package/starter/src/components/ui/popover.tsx +52 -0
  766. package/starter/src/components/ui/progress.tsx +24 -0
  767. package/starter/src/components/ui/radio-group.tsx +31 -0
  768. package/starter/src/components/ui/resizable.tsx +47 -0
  769. package/starter/src/components/ui/scroll-area.tsx +46 -0
  770. package/starter/src/components/ui/select.tsx +162 -0
  771. package/starter/src/components/ui/separator.tsx +26 -0
  772. package/starter/src/components/ui/sheet.tsx +107 -0
  773. package/starter/src/components/ui/sidebar.tsx +674 -0
  774. package/starter/src/components/ui/skeleton.tsx +7 -0
  775. package/starter/src/components/ui/slider.tsx +54 -0
  776. package/starter/src/components/ui/sonner.tsx +31 -0
  777. package/starter/src/components/ui/spinner.tsx +9 -0
  778. package/starter/src/components/ui/switch.tsx +33 -0
  779. package/starter/src/components/ui/table.tsx +75 -0
  780. package/starter/src/components/ui/tabs.tsx +69 -0
  781. package/starter/src/components/ui/textarea.tsx +18 -0
  782. package/starter/src/components/ui/toggle-group.tsx +79 -0
  783. package/starter/src/components/ui/toggle.tsx +41 -0
  784. package/starter/src/components/ui/tooltip.tsx +42 -0
  785. package/starter/src/hooks/use-mobile.ts +19 -0
  786. package/starter/src/index.css +93 -0
  787. package/starter/src/lib/graphql-client.ts +5 -0
  788. package/starter/src/lib/providers.tsx +23 -0
  789. package/starter/src/lib/utils.ts +6 -0
  790. package/starter/src/main.tsx +16 -0
  791. package/starter/tsconfig.app.json +32 -0
  792. package/starter/tsconfig.json +4 -0
  793. package/starter/tsconfig.node.json +26 -0
  794. package/starter/vite.config.ts +16 -0
@@ -0,0 +1,74 @@
1
+ import { cva, type VariantProps } from 'class-variance-authority';
2
+ import { Slot } from 'radix-ui';
3
+ import { Separator } from '@/components/ui/separator';
4
+ import { cn } from '@/lib/utils';
5
+
6
+ const buttonGroupVariants = cva(
7
+ "flex w-fit items-stretch has-[>[data-slot=button-group]]:gap-2 [&>*]:focus-visible:relative [&>*]:focus-visible:z-10 has-[select[aria-hidden=true]:last-child]:[&>[data-slot=select-trigger]:last-of-type]:rounded-r-md [&>[data-slot=select-trigger]:not([class*='w-'])]:w-fit [&>input]:flex-1",
8
+ {
9
+ variants: {
10
+ orientation: {
11
+ horizontal:
12
+ '[&>*:not(:first-child)]:rounded-l-none [&>*:not(:first-child)]:border-l-0 [&>*:not(:last-child)]:rounded-r-none',
13
+ vertical:
14
+ 'flex-col [&>*:not(:first-child)]:rounded-t-none [&>*:not(:first-child)]:border-t-0 [&>*:not(:last-child)]:rounded-b-none',
15
+ },
16
+ },
17
+ defaultVariants: {
18
+ orientation: 'horizontal',
19
+ },
20
+ },
21
+ );
22
+
23
+ function ButtonGroup({
24
+ className,
25
+ orientation,
26
+ ...props
27
+ }: React.ComponentProps<'div'> & VariantProps<typeof buttonGroupVariants>) {
28
+ return (
29
+ <div
30
+ role="group"
31
+ data-slot="button-group"
32
+ data-orientation={orientation}
33
+ className={cn(buttonGroupVariants({ orientation }), className)}
34
+ {...props}
35
+ />
36
+ );
37
+ }
38
+
39
+ function ButtonGroupText({
40
+ className,
41
+ asChild = false,
42
+ ...props
43
+ }: React.ComponentProps<'div'> & {
44
+ asChild?: boolean;
45
+ }) {
46
+ const Comp = asChild ? Slot.Root : 'div';
47
+
48
+ return (
49
+ <Comp
50
+ className={cn(
51
+ "flex items-center gap-2 rounded-md border bg-muted px-4 text-sm font-medium shadow-xs [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4",
52
+ className,
53
+ )}
54
+ {...props}
55
+ />
56
+ );
57
+ }
58
+
59
+ function ButtonGroupSeparator({
60
+ className,
61
+ orientation = 'vertical',
62
+ ...props
63
+ }: React.ComponentProps<typeof Separator>) {
64
+ return (
65
+ <Separator
66
+ data-slot="button-group-separator"
67
+ orientation={orientation}
68
+ className={cn('relative m-0! self-stretch bg-input data-[orientation=vertical]:h-auto', className)}
69
+ {...props}
70
+ />
71
+ );
72
+ }
73
+
74
+ export { ButtonGroup, ButtonGroupSeparator, ButtonGroupText, buttonGroupVariants };
@@ -0,0 +1,62 @@
1
+ import { cva, type VariantProps } from 'class-variance-authority';
2
+ import { Slot } from 'radix-ui';
3
+ import type * as React from 'react';
4
+
5
+ import { cn } from '@/lib/utils';
6
+
7
+ const buttonVariants = cva(
8
+ "inline-flex shrink-0 items-center justify-center gap-2 rounded-md text-sm font-medium whitespace-nowrap transition-all outline-none focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 aria-invalid:border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
9
+ {
10
+ variants: {
11
+ variant: {
12
+ default: 'bg-primary text-primary-foreground hover:bg-primary/90',
13
+ destructive:
14
+ 'bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:bg-destructive/60 dark:focus-visible:ring-destructive/40',
15
+ outline:
16
+ 'border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:border-input dark:bg-input/30 dark:hover:bg-input/50',
17
+ secondary: 'bg-secondary text-secondary-foreground hover:bg-secondary/80',
18
+ ghost: 'hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50',
19
+ link: 'text-primary underline-offset-4 hover:underline',
20
+ },
21
+ size: {
22
+ default: 'h-9 px-4 py-2 has-[>svg]:px-3',
23
+ xs: "h-6 gap-1 rounded-md px-2 text-xs has-[>svg]:px-1.5 [&_svg:not([class*='size-'])]:size-3",
24
+ sm: 'h-8 gap-1.5 rounded-md px-3 has-[>svg]:px-2.5',
25
+ lg: 'h-10 rounded-md px-6 has-[>svg]:px-4',
26
+ icon: 'size-9',
27
+ 'icon-xs': "size-6 rounded-md [&_svg:not([class*='size-'])]:size-3",
28
+ 'icon-sm': 'size-8',
29
+ 'icon-lg': 'size-10',
30
+ },
31
+ },
32
+ defaultVariants: {
33
+ variant: 'default',
34
+ size: 'default',
35
+ },
36
+ },
37
+ );
38
+
39
+ function Button({
40
+ className,
41
+ variant = 'default',
42
+ size = 'default',
43
+ asChild = false,
44
+ ...props
45
+ }: React.ComponentProps<'button'> &
46
+ VariantProps<typeof buttonVariants> & {
47
+ asChild?: boolean;
48
+ }) {
49
+ const Comp = asChild ? Slot.Root : 'button';
50
+
51
+ return (
52
+ <Comp
53
+ data-slot="button"
54
+ data-variant={variant}
55
+ data-size={size}
56
+ className={cn(buttonVariants({ variant, size, className }))}
57
+ {...props}
58
+ />
59
+ );
60
+ }
61
+
62
+ export { Button, buttonVariants };
@@ -0,0 +1,158 @@
1
+ import { ChevronDownIcon, ChevronLeftIcon, ChevronRightIcon } from 'lucide-react';
2
+ import * as React from 'react';
3
+ import { type DayButton, DayPicker, getDefaultClassNames } from 'react-day-picker';
4
+ import { Button, buttonVariants } from '@/components/ui/button';
5
+ import { cn } from '@/lib/utils';
6
+
7
+ function Calendar({
8
+ className,
9
+ classNames,
10
+ showOutsideDays = true,
11
+ captionLayout = 'label',
12
+ buttonVariant = 'ghost',
13
+ formatters,
14
+ components,
15
+ ...props
16
+ }: React.ComponentProps<typeof DayPicker> & {
17
+ buttonVariant?: React.ComponentProps<typeof Button>['variant'];
18
+ }) {
19
+ const defaultClassNames = getDefaultClassNames();
20
+
21
+ return (
22
+ <DayPicker
23
+ showOutsideDays={showOutsideDays}
24
+ className={cn(
25
+ 'group/calendar bg-background p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent',
26
+ String.raw`rtl:**:[.rdp-button\_next>svg]:rotate-180`,
27
+ String.raw`rtl:**:[.rdp-button\_previous>svg]:rotate-180`,
28
+ className,
29
+ )}
30
+ captionLayout={captionLayout}
31
+ formatters={{
32
+ formatMonthDropdown: (date) => date.toLocaleString('default', { month: 'short' }),
33
+ ...formatters,
34
+ }}
35
+ classNames={{
36
+ root: cn('w-fit', defaultClassNames.root),
37
+ months: cn('relative flex flex-col gap-4 md:flex-row', defaultClassNames.months),
38
+ month: cn('flex w-full flex-col gap-4', defaultClassNames.month),
39
+ nav: cn('absolute inset-x-0 top-0 flex w-full items-center justify-between gap-1', defaultClassNames.nav),
40
+ button_previous: cn(
41
+ buttonVariants({ variant: buttonVariant }),
42
+ 'size-(--cell-size) p-0 select-none aria-disabled:opacity-50',
43
+ defaultClassNames.button_previous,
44
+ ),
45
+ button_next: cn(
46
+ buttonVariants({ variant: buttonVariant }),
47
+ 'size-(--cell-size) p-0 select-none aria-disabled:opacity-50',
48
+ defaultClassNames.button_next,
49
+ ),
50
+ month_caption: cn(
51
+ 'flex h-(--cell-size) w-full items-center justify-center px-(--cell-size)',
52
+ defaultClassNames.month_caption,
53
+ ),
54
+ dropdowns: cn(
55
+ 'flex h-(--cell-size) w-full items-center justify-center gap-1.5 text-sm font-medium',
56
+ defaultClassNames.dropdowns,
57
+ ),
58
+ dropdown_root: cn(
59
+ 'relative rounded-md border border-input shadow-xs has-focus:border-ring has-focus:ring-[3px] has-focus:ring-ring/50',
60
+ defaultClassNames.dropdown_root,
61
+ ),
62
+ dropdown: cn('absolute inset-0 bg-popover opacity-0', defaultClassNames.dropdown),
63
+ caption_label: cn(
64
+ 'font-medium select-none',
65
+ captionLayout === 'label'
66
+ ? 'text-sm'
67
+ : 'flex h-8 items-center gap-1 rounded-md pr-1 pl-2 text-sm [&>svg]:size-3.5 [&>svg]:text-muted-foreground',
68
+ defaultClassNames.caption_label,
69
+ ),
70
+ table: 'w-full border-collapse',
71
+ weekdays: cn('flex', defaultClassNames.weekdays),
72
+ weekday: cn(
73
+ 'flex-1 rounded-md text-[0.8rem] font-normal text-muted-foreground select-none',
74
+ defaultClassNames.weekday,
75
+ ),
76
+ week: cn('mt-2 flex w-full', defaultClassNames.week),
77
+ week_number_header: cn('w-(--cell-size) select-none', defaultClassNames.week_number_header),
78
+ week_number: cn('text-[0.8rem] text-muted-foreground select-none', defaultClassNames.week_number),
79
+ day: cn(
80
+ 'group/day relative aspect-square h-full w-full p-0 text-center select-none [&:last-child[data-selected=true]_button]:rounded-r-md',
81
+ props.showWeekNumber
82
+ ? '[&:nth-child(2)[data-selected=true]_button]:rounded-l-md'
83
+ : '[&:first-child[data-selected=true]_button]:rounded-l-md',
84
+ defaultClassNames.day,
85
+ ),
86
+ range_start: cn('rounded-l-md bg-accent', defaultClassNames.range_start),
87
+ range_middle: cn('rounded-none', defaultClassNames.range_middle),
88
+ range_end: cn('rounded-r-md bg-accent', defaultClassNames.range_end),
89
+ today: cn(
90
+ 'rounded-md bg-accent text-accent-foreground data-[selected=true]:rounded-none',
91
+ defaultClassNames.today,
92
+ ),
93
+ outside: cn('text-muted-foreground aria-selected:text-muted-foreground', defaultClassNames.outside),
94
+ disabled: cn('text-muted-foreground opacity-50', defaultClassNames.disabled),
95
+ hidden: cn('invisible', defaultClassNames.hidden),
96
+ ...classNames,
97
+ }}
98
+ components={{
99
+ Root: ({ className, rootRef, ...props }) => {
100
+ return <div data-slot="calendar" ref={rootRef} className={cn(className)} {...props} />;
101
+ },
102
+ Chevron: ({ className, orientation, ...props }) => {
103
+ if (orientation === 'left') {
104
+ return <ChevronLeftIcon className={cn('size-4', className)} {...props} />;
105
+ }
106
+
107
+ if (orientation === 'right') {
108
+ return <ChevronRightIcon className={cn('size-4', className)} {...props} />;
109
+ }
110
+
111
+ return <ChevronDownIcon className={cn('size-4', className)} {...props} />;
112
+ },
113
+ DayButton: CalendarDayButton,
114
+ WeekNumber: ({ children, ...props }) => {
115
+ return (
116
+ <td {...props}>
117
+ <div className="flex size-(--cell-size) items-center justify-center text-center">{children}</div>
118
+ </td>
119
+ );
120
+ },
121
+ ...components,
122
+ }}
123
+ {...props}
124
+ />
125
+ );
126
+ }
127
+
128
+ function CalendarDayButton({ className, day, modifiers, ...props }: React.ComponentProps<typeof DayButton>) {
129
+ const defaultClassNames = getDefaultClassNames();
130
+
131
+ const ref = React.useRef<HTMLButtonElement>(null);
132
+ React.useEffect(() => {
133
+ if (modifiers.focused) ref.current?.focus();
134
+ }, [modifiers.focused]);
135
+
136
+ return (
137
+ <Button
138
+ ref={ref}
139
+ variant="ghost"
140
+ size="icon"
141
+ data-day={day.date.toLocaleDateString()}
142
+ data-selected-single={
143
+ modifiers.selected && !modifiers.range_start && !modifiers.range_end && !modifiers.range_middle
144
+ }
145
+ data-range-start={modifiers.range_start}
146
+ data-range-end={modifiers.range_end}
147
+ data-range-middle={modifiers.range_middle}
148
+ className={cn(
149
+ 'flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-[3px] group-data-[focused=true]/day:ring-ring/50 data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground data-[range-middle=true]:rounded-none data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground dark:hover:text-accent-foreground [&>span]:text-xs [&>span]:opacity-70',
150
+ defaultClassNames.day,
151
+ className,
152
+ )}
153
+ {...props}
154
+ />
155
+ );
156
+ }
157
+
158
+ export { Calendar, CalendarDayButton };
@@ -0,0 +1,56 @@
1
+ import type * as React from 'react';
2
+
3
+ import { cn } from '@/lib/utils';
4
+
5
+ function Card({ className, ...props }: React.ComponentProps<'div'>) {
6
+ return (
7
+ <div
8
+ data-slot="card"
9
+ className={cn('flex flex-col gap-6 rounded-xl border bg-card py-6 text-card-foreground shadow-sm', className)}
10
+ {...props}
11
+ />
12
+ );
13
+ }
14
+
15
+ function CardHeader({ className, ...props }: React.ComponentProps<'div'>) {
16
+ return (
17
+ <div
18
+ data-slot="card-header"
19
+ className={cn(
20
+ '@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-2 px-6 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6',
21
+ className,
22
+ )}
23
+ {...props}
24
+ />
25
+ );
26
+ }
27
+
28
+ function CardTitle({ className, ...props }: React.ComponentProps<'div'>) {
29
+ return <div data-slot="card-title" className={cn('leading-none font-semibold', className)} {...props} />;
30
+ }
31
+
32
+ function CardDescription({ className, ...props }: React.ComponentProps<'div'>) {
33
+ return <div data-slot="card-description" className={cn('text-sm text-muted-foreground', className)} {...props} />;
34
+ }
35
+
36
+ function CardAction({ className, ...props }: React.ComponentProps<'div'>) {
37
+ return (
38
+ <div
39
+ data-slot="card-action"
40
+ className={cn('col-start-2 row-span-2 row-start-1 self-start justify-self-end', className)}
41
+ {...props}
42
+ />
43
+ );
44
+ }
45
+
46
+ function CardContent({ className, ...props }: React.ComponentProps<'div'>) {
47
+ return <div data-slot="card-content" className={cn('px-6', className)} {...props} />;
48
+ }
49
+
50
+ function CardFooter({ className, ...props }: React.ComponentProps<'div'>) {
51
+ return (
52
+ <div data-slot="card-footer" className={cn('flex items-center px-6 [.border-t]:pt-6', className)} {...props} />
53
+ );
54
+ }
55
+
56
+ export { Card, CardHeader, CardFooter, CardTitle, CardAction, CardDescription, CardContent };
@@ -0,0 +1,215 @@
1
+ 'use client';
2
+
3
+ import useEmblaCarousel, { type UseEmblaCarouselType } from 'embla-carousel-react';
4
+ import { ArrowLeft, ArrowRight } from 'lucide-react';
5
+ import * as React from 'react';
6
+ import { Button } from '@/components/ui/button';
7
+ import { cn } from '@/lib/utils';
8
+
9
+ type CarouselApi = UseEmblaCarouselType[1];
10
+ type UseCarouselParameters = Parameters<typeof useEmblaCarousel>;
11
+ type CarouselOptions = UseCarouselParameters[0];
12
+ type CarouselPlugin = UseCarouselParameters[1];
13
+
14
+ type CarouselProps = {
15
+ opts?: CarouselOptions;
16
+ plugins?: CarouselPlugin;
17
+ orientation?: 'horizontal' | 'vertical';
18
+ setApi?: (api: CarouselApi) => void;
19
+ };
20
+
21
+ type CarouselContextProps = {
22
+ carouselRef: ReturnType<typeof useEmblaCarousel>[0];
23
+ api: ReturnType<typeof useEmblaCarousel>[1];
24
+ scrollPrev: () => void;
25
+ scrollNext: () => void;
26
+ canScrollPrev: boolean;
27
+ canScrollNext: boolean;
28
+ } & CarouselProps;
29
+
30
+ const CarouselContext = React.createContext<CarouselContextProps | null>(null);
31
+
32
+ function useCarousel() {
33
+ const context = React.useContext(CarouselContext);
34
+
35
+ if (!context) {
36
+ throw new Error('useCarousel must be used within a <Carousel />');
37
+ }
38
+
39
+ return context;
40
+ }
41
+
42
+ function Carousel({
43
+ orientation = 'horizontal',
44
+ opts,
45
+ setApi,
46
+ plugins,
47
+ className,
48
+ children,
49
+ ...props
50
+ }: React.ComponentProps<'div'> & CarouselProps) {
51
+ const [carouselRef, api] = useEmblaCarousel(
52
+ {
53
+ ...opts,
54
+ axis: orientation === 'horizontal' ? 'x' : 'y',
55
+ },
56
+ plugins,
57
+ );
58
+ const [canScrollPrev, setCanScrollPrev] = React.useState(false);
59
+ const [canScrollNext, setCanScrollNext] = React.useState(false);
60
+
61
+ const onSelect = React.useCallback((api: CarouselApi) => {
62
+ if (!api) return;
63
+ setCanScrollPrev(api.canScrollPrev());
64
+ setCanScrollNext(api.canScrollNext());
65
+ }, []);
66
+
67
+ const scrollPrev = React.useCallback(() => {
68
+ api?.scrollPrev();
69
+ }, [api]);
70
+
71
+ const scrollNext = React.useCallback(() => {
72
+ api?.scrollNext();
73
+ }, [api]);
74
+
75
+ const handleKeyDown = React.useCallback(
76
+ (event: React.KeyboardEvent<HTMLDivElement>) => {
77
+ if (event.key === 'ArrowLeft') {
78
+ event.preventDefault();
79
+ scrollPrev();
80
+ } else if (event.key === 'ArrowRight') {
81
+ event.preventDefault();
82
+ scrollNext();
83
+ }
84
+ },
85
+ [scrollPrev, scrollNext],
86
+ );
87
+
88
+ React.useEffect(() => {
89
+ if (!api || !setApi) return;
90
+ setApi(api);
91
+ }, [api, setApi]);
92
+
93
+ React.useEffect(() => {
94
+ if (!api) return;
95
+ onSelect(api);
96
+ api.on('reInit', onSelect);
97
+ api.on('select', onSelect);
98
+
99
+ return () => {
100
+ api?.off('select', onSelect);
101
+ };
102
+ }, [api, onSelect]);
103
+
104
+ return (
105
+ <CarouselContext.Provider
106
+ value={{
107
+ carouselRef,
108
+ api: api,
109
+ opts,
110
+ orientation: orientation || (opts?.axis === 'y' ? 'vertical' : 'horizontal'),
111
+ scrollPrev,
112
+ scrollNext,
113
+ canScrollPrev,
114
+ canScrollNext,
115
+ }}
116
+ >
117
+ <div
118
+ onKeyDownCapture={handleKeyDown}
119
+ className={cn('relative', className)}
120
+ role="region"
121
+ aria-roledescription="carousel"
122
+ data-slot="carousel"
123
+ {...props}
124
+ >
125
+ {children}
126
+ </div>
127
+ </CarouselContext.Provider>
128
+ );
129
+ }
130
+
131
+ function CarouselContent({ className, ...props }: React.ComponentProps<'div'>) {
132
+ const { carouselRef, orientation } = useCarousel();
133
+
134
+ return (
135
+ <div ref={carouselRef} className="overflow-hidden" data-slot="carousel-content">
136
+ <div className={cn('flex', orientation === 'horizontal' ? '-ml-4' : '-mt-4 flex-col', className)} {...props} />
137
+ </div>
138
+ );
139
+ }
140
+
141
+ function CarouselItem({ className, ...props }: React.ComponentProps<'div'>) {
142
+ const { orientation } = useCarousel();
143
+
144
+ return (
145
+ <div
146
+ role="group"
147
+ aria-roledescription="slide"
148
+ data-slot="carousel-item"
149
+ className={cn('min-w-0 shrink-0 grow-0 basis-full', orientation === 'horizontal' ? 'pl-4' : 'pt-4', className)}
150
+ {...props}
151
+ />
152
+ );
153
+ }
154
+
155
+ function CarouselPrevious({
156
+ className,
157
+ variant = 'outline',
158
+ size = 'icon',
159
+ ...props
160
+ }: React.ComponentProps<typeof Button>) {
161
+ const { orientation, scrollPrev, canScrollPrev } = useCarousel();
162
+
163
+ return (
164
+ <Button
165
+ data-slot="carousel-previous"
166
+ variant={variant}
167
+ size={size}
168
+ className={cn(
169
+ 'absolute size-8 rounded-full',
170
+ orientation === 'horizontal'
171
+ ? 'top-1/2 -left-12 -translate-y-1/2'
172
+ : '-top-12 left-1/2 -translate-x-1/2 rotate-90',
173
+ className,
174
+ )}
175
+ disabled={!canScrollPrev}
176
+ onClick={scrollPrev}
177
+ {...props}
178
+ >
179
+ <ArrowLeft />
180
+ <span className="sr-only">Previous slide</span>
181
+ </Button>
182
+ );
183
+ }
184
+
185
+ function CarouselNext({
186
+ className,
187
+ variant = 'outline',
188
+ size = 'icon',
189
+ ...props
190
+ }: React.ComponentProps<typeof Button>) {
191
+ const { orientation, scrollNext, canScrollNext } = useCarousel();
192
+
193
+ return (
194
+ <Button
195
+ data-slot="carousel-next"
196
+ variant={variant}
197
+ size={size}
198
+ className={cn(
199
+ 'absolute size-8 rounded-full',
200
+ orientation === 'horizontal'
201
+ ? 'top-1/2 -right-12 -translate-y-1/2'
202
+ : '-bottom-12 left-1/2 -translate-x-1/2 rotate-90',
203
+ className,
204
+ )}
205
+ disabled={!canScrollNext}
206
+ onClick={scrollNext}
207
+ {...props}
208
+ >
209
+ <ArrowRight />
210
+ <span className="sr-only">Next slide</span>
211
+ </Button>
212
+ );
213
+ }
214
+
215
+ export { type CarouselApi, Carousel, CarouselContent, CarouselItem, CarouselPrevious, CarouselNext };