stackscan 0.1.6

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 (369) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +222 -0
  3. package/dist/add.d.mts +3 -0
  4. package/dist/add.d.ts +3 -0
  5. package/dist/add.js +83 -0
  6. package/dist/add.mjs +7 -0
  7. package/dist/batch-import.d.mts +6 -0
  8. package/dist/batch-import.d.ts +6 -0
  9. package/dist/batch-import.js +5724 -0
  10. package/dist/batch-import.mjs +12 -0
  11. package/dist/chunk-22J2UHU7.mjs +1980 -0
  12. package/dist/chunk-2KG7JDHY.mjs +19 -0
  13. package/dist/chunk-2O2NMD7M.mjs +127 -0
  14. package/dist/chunk-3HEYJTUE.mjs +157 -0
  15. package/dist/chunk-3LPZV7KA.mjs +15 -0
  16. package/dist/chunk-3O2C34CJ.mjs +174 -0
  17. package/dist/chunk-3R4TXOZA.mjs +179 -0
  18. package/dist/chunk-3RJHZIII.mjs +174 -0
  19. package/dist/chunk-3XKWCBY6.mjs +105 -0
  20. package/dist/chunk-4OMBB3R6.mjs +52 -0
  21. package/dist/chunk-4THN5TT4.mjs +185 -0
  22. package/dist/chunk-4WCVZS6B.mjs +178 -0
  23. package/dist/chunk-5MNAT56X.mjs +23 -0
  24. package/dist/chunk-5VH7N3X6.mjs +109 -0
  25. package/dist/chunk-6A4WEZDZ.mjs +14 -0
  26. package/dist/chunk-6MIRBLO4.mjs +15 -0
  27. package/dist/chunk-6RCTNUF4.mjs +17 -0
  28. package/dist/chunk-7F4KWGMM.mjs +45 -0
  29. package/dist/chunk-7KF2HEU2.mjs +56 -0
  30. package/dist/chunk-7KONWCSX.mjs +15 -0
  31. package/dist/chunk-7TIXAYVC.mjs +10122 -0
  32. package/dist/chunk-ADMVFPX7.mjs +150 -0
  33. package/dist/chunk-AFJCX5SK.mjs +22 -0
  34. package/dist/chunk-ATNEVZPV.mjs +25 -0
  35. package/dist/chunk-BBP27ZGZ.mjs +4841 -0
  36. package/dist/chunk-BGT3PANW.mjs +64 -0
  37. package/dist/chunk-BJIQZNKU.mjs +184 -0
  38. package/dist/chunk-BKQW4ZNZ.mjs +19 -0
  39. package/dist/chunk-BMQTYZOD.mjs +144 -0
  40. package/dist/chunk-CZADURZD.mjs +674 -0
  41. package/dist/chunk-D2DOGM2Y.mjs +19 -0
  42. package/dist/chunk-D32C3FU6.mjs +45 -0
  43. package/dist/chunk-D6FFDX4P.mjs +158 -0
  44. package/dist/chunk-DUAFJVBN.mjs +44 -0
  45. package/dist/chunk-E24PAHCZ.mjs +146 -0
  46. package/dist/chunk-E3OD2BXY.mjs +14 -0
  47. package/dist/chunk-E4K5XYFI.mjs +210767 -0
  48. package/dist/chunk-EH2SEQZP.mjs +10119 -0
  49. package/dist/chunk-EH4FWTP5.mjs +21 -0
  50. package/dist/chunk-EOKQCSHI.mjs +10 -0
  51. package/dist/chunk-EQ4WRCPP.mjs +16 -0
  52. package/dist/chunk-EYXTSAAW.mjs +64 -0
  53. package/dist/chunk-F6Z4WXOF.mjs +146 -0
  54. package/dist/chunk-FM5BCBKT.mjs +77 -0
  55. package/dist/chunk-GXKIDBAX.mjs +146 -0
  56. package/dist/chunk-H6HA3IZE.mjs +1980 -0
  57. package/dist/chunk-H7WNQ3SS.mjs +23 -0
  58. package/dist/chunk-HBJEQ63D.mjs +205 -0
  59. package/dist/chunk-HTTDBNRT.mjs +146 -0
  60. package/dist/chunk-HYUKJUPF.mjs +177 -0
  61. package/dist/chunk-IFEEO473.mjs +49 -0
  62. package/dist/chunk-IILZ43EE.mjs +25 -0
  63. package/dist/chunk-ITGRHGUT.mjs +158 -0
  64. package/dist/chunk-J5JVDMED.mjs +45 -0
  65. package/dist/chunk-JH3SW4KH.mjs +4896 -0
  66. package/dist/chunk-JHVWSHNY.mjs +32 -0
  67. package/dist/chunk-JLFOQXQG.mjs +26 -0
  68. package/dist/chunk-K4BNSVJP.mjs +16 -0
  69. package/dist/chunk-KCDUZXVN.mjs +157 -0
  70. package/dist/chunk-KMDEPBKS.mjs +685 -0
  71. package/dist/chunk-L4AQWDD2.mjs +92 -0
  72. package/dist/chunk-L7I4UC35.mjs +158 -0
  73. package/dist/chunk-LB3L25FS.mjs +1980 -0
  74. package/dist/chunk-LDA354A3.mjs +158 -0
  75. package/dist/chunk-LSUI3VI4.mjs +19 -0
  76. package/dist/chunk-MB2X3DXF.mjs +45 -0
  77. package/dist/chunk-MBL4CIFG.mjs +28 -0
  78. package/dist/chunk-MLAUEAUQ.mjs +27 -0
  79. package/dist/chunk-NGEKE4DQ.mjs +23 -0
  80. package/dist/chunk-NJ4FK5BO.mjs +19 -0
  81. package/dist/chunk-OJZZPNXQ.mjs +1985 -0
  82. package/dist/chunk-P24PKCUA.mjs +25 -0
  83. package/dist/chunk-PFQIKEIL.mjs +15 -0
  84. package/dist/chunk-Q5ASM7HE.mjs +45 -0
  85. package/dist/chunk-Q7X2R7N7.mjs +16 -0
  86. package/dist/chunk-QAIJCQWH.mjs +157 -0
  87. package/dist/chunk-QQAUZGVG.mjs +2166 -0
  88. package/dist/chunk-QUIF3FJ2.mjs +55 -0
  89. package/dist/chunk-RDFZ4GVM.mjs +23 -0
  90. package/dist/chunk-RFRKMUNA.mjs +49 -0
  91. package/dist/chunk-RIIQA6S6.mjs +2204 -0
  92. package/dist/chunk-SGOSAU2P.mjs +51 -0
  93. package/dist/chunk-SLYSEMYE.mjs +21 -0
  94. package/dist/chunk-SNKLZ7VB.mjs +36 -0
  95. package/dist/chunk-TKKUEAN6.mjs +45 -0
  96. package/dist/chunk-TMH7EUXF.mjs +179 -0
  97. package/dist/chunk-TP55TF47.mjs +1980 -0
  98. package/dist/chunk-U4AFTAZI.mjs +1980 -0
  99. package/dist/chunk-U4EXCWGR.mjs +174 -0
  100. package/dist/chunk-U4OINWJM.mjs +42 -0
  101. package/dist/chunk-U63TGBAS.mjs +179 -0
  102. package/dist/chunk-UESFH6US.mjs +210773 -0
  103. package/dist/chunk-UITLHBZA.mjs +164 -0
  104. package/dist/chunk-VFD26CTJ.mjs +16 -0
  105. package/dist/chunk-VSWWWPO7.mjs +205 -0
  106. package/dist/chunk-VUVPGH7A.mjs +157 -0
  107. package/dist/chunk-W34IFT2J.mjs +45 -0
  108. package/dist/chunk-WPSGF5DK.mjs +92 -0
  109. package/dist/chunk-WPU2XV5B.mjs +25 -0
  110. package/dist/chunk-WTPR7TOE.mjs +146 -0
  111. package/dist/chunk-X3ATBJ5Q.mjs +14 -0
  112. package/dist/chunk-XMZATJRD.mjs +23 -0
  113. package/dist/chunk-Y2Y225MR.mjs +117 -0
  114. package/dist/chunk-YNDKJ5QJ.mjs +89 -0
  115. package/dist/chunk-YPQNYUP3.mjs +92 -0
  116. package/dist/chunk-ZH22D4SN.mjs +179 -0
  117. package/dist/chunk-ZSJJGBQR.mjs +39 -0
  118. package/dist/chunk-ZSMMBZHO.mjs +64 -0
  119. package/dist/chunk-ZTXCA3NN.mjs +74 -0
  120. package/dist/chunk-ZYMQR24Z.mjs +145 -0
  121. package/dist/cli.d.mts +1 -0
  122. package/dist/cli.d.ts +1 -0
  123. package/dist/cli.js +5770 -0
  124. package/dist/cli.mjs +25 -0
  125. package/dist/config.d.mts +5 -0
  126. package/dist/config.d.ts +5 -0
  127. package/dist/config.js +41 -0
  128. package/dist/config.mjs +7 -0
  129. package/dist/defaults.d.mts +3 -0
  130. package/dist/defaults.d.ts +3 -0
  131. package/dist/defaults.js +47 -0
  132. package/dist/defaults.mjs +7 -0
  133. package/dist/detectors/ci.d.mts +5 -0
  134. package/dist/detectors/ci.d.ts +5 -0
  135. package/dist/detectors/ci.js +59 -0
  136. package/dist/detectors/ci.mjs +7 -0
  137. package/dist/detectors/docker.d.mts +5 -0
  138. package/dist/detectors/docker.d.ts +5 -0
  139. package/dist/detectors/docker.js +50 -0
  140. package/dist/detectors/docker.mjs +7 -0
  141. package/dist/detectors/next.d.mts +7 -0
  142. package/dist/detectors/next.d.ts +7 -0
  143. package/dist/detectors/next.js +49 -0
  144. package/dist/detectors/next.mjs +7 -0
  145. package/dist/detectors/prisma.d.mts +7 -0
  146. package/dist/detectors/prisma.d.ts +7 -0
  147. package/dist/detectors/prisma.js +48 -0
  148. package/dist/detectors/prisma.mjs +7 -0
  149. package/dist/import.d.mts +2 -0
  150. package/dist/import.d.ts +2 -0
  151. package/dist/import.js +2062 -0
  152. package/dist/import.mjs +53 -0
  153. package/dist/output.d.mts +7 -0
  154. package/dist/output.d.ts +7 -0
  155. package/dist/output.js +3619 -0
  156. package/dist/output.mjs +13 -0
  157. package/dist/scan.d.mts +7 -0
  158. package/dist/scan.d.ts +7 -0
  159. package/dist/scan.js +5725 -0
  160. package/dist/scan.mjs +12 -0
  161. package/dist/scanner.d.mts +5 -0
  162. package/dist/scanner.d.ts +5 -0
  163. package/dist/scanner.js +5514 -0
  164. package/dist/scanner.mjs +14 -0
  165. package/dist/simple-icons-hex.d.mts +6751 -0
  166. package/dist/simple-icons-hex.d.ts +6751 -0
  167. package/dist/simple-icons-hex.js +10118 -0
  168. package/dist/simple-icons-hex.mjs +6736 -0
  169. package/dist/sync.d.mts +7 -0
  170. package/dist/sync.d.ts +7 -0
  171. package/dist/sync.js +5725 -0
  172. package/dist/sync.mjs +160 -0
  173. package/dist/techDefinitions.d.mts +5 -0
  174. package/dist/techDefinitions.d.ts +5 -0
  175. package/dist/techDefinitions.js +2004 -0
  176. package/dist/techDefinitions.mjs +7 -0
  177. package/dist/techMap.d.mts +5 -0
  178. package/dist/techMap.d.ts +5 -0
  179. package/dist/techMap.js +2018 -0
  180. package/dist/techMap.mjs +8 -0
  181. package/dist/types.d.mts +24 -0
  182. package/dist/types.d.ts +24 -0
  183. package/dist/types.js +18 -0
  184. package/dist/types.mjs +1 -0
  185. package/dist/typescript-7Q5RIVZY.mjs +6 -0
  186. package/dist/typescript-T5HXSZZS.mjs +5 -0
  187. package/dist/watch.d.mts +3 -0
  188. package/dist/watch.d.ts +3 -0
  189. package/dist/watch.js +2122 -0
  190. package/dist/watch.mjs +13 -0
  191. package/package.json +57 -0
  192. package/public/assets/logos/ai/huggingface.svg +1 -0
  193. package/public/assets/logos/ai/langchain.svg +1 -0
  194. package/public/assets/logos/ai/openai.svg +1 -0
  195. package/public/assets/logos/ai/replicate.svg +1 -0
  196. package/public/assets/logos/ai/tensorflow.svg +1 -0
  197. package/public/assets/logos/api/apollographql.svg +1 -0
  198. package/public/assets/logos/api/graphql.svg +1 -0
  199. package/public/assets/logos/api/relay.svg +1 -0
  200. package/public/assets/logos/api/trpc.svg +1 -0
  201. package/public/assets/logos/auth/argo.svg +1 -0
  202. package/public/assets/logos/auth/auth0.svg +1 -0
  203. package/public/assets/logos/auth/authjs.svg +73 -0
  204. package/public/assets/logos/auth/clerk.svg +1 -0
  205. package/public/assets/logos/auth/firebase.svg +1 -0
  206. package/public/assets/logos/auth/jsonwebtokens.svg +1 -0
  207. package/public/assets/logos/auth/keycloak.svg +1 -0
  208. package/public/assets/logos/auth/passport.svg +1 -0
  209. package/public/assets/logos/automation/lerna.svg +1 -0
  210. package/public/assets/logos/automation/nx.svg +1 -0
  211. package/public/assets/logos/automation/turborepo.svg +1 -0
  212. package/public/assets/logos/backend/adonisjs.svg +1 -0
  213. package/public/assets/logos/backend/express.svg +1 -0
  214. package/public/assets/logos/backend/fastify.svg +1 -0
  215. package/public/assets/logos/backend/koa.svg +1 -0
  216. package/public/assets/logos/backend/nestjs.svg +1 -0
  217. package/public/assets/logos/build/babel.svg +1 -0
  218. package/public/assets/logos/build/esbuild.svg +1 -0
  219. package/public/assets/logos/build/rollupdotjs.svg +1 -0
  220. package/public/assets/logos/build/snowpack.svg +1 -0
  221. package/public/assets/logos/build/swc.svg +1 -0
  222. package/public/assets/logos/build/vite.svg +15 -0
  223. package/public/assets/logos/build/webpack.svg +1 -0
  224. package/public/assets/logos/ci/circleci.svg +1 -0
  225. package/public/assets/logos/ci/githubactions.svg +1 -0
  226. package/public/assets/logos/ci/gitlab.svg +1 -0
  227. package/public/assets/logos/ci/jenkins.svg +1 -0
  228. package/public/assets/logos/ci/travisci.svg +1 -0
  229. package/public/assets/logos/cloud/cloudflare.svg +1 -0
  230. package/public/assets/logos/cloud/googlecloud.svg +1 -0
  231. package/public/assets/logos/cloud/microsoftazure.svg +1 -0
  232. package/public/assets/logos/cms/contentful.svg +1 -0
  233. package/public/assets/logos/cms/directus.svg +1 -0
  234. package/public/assets/logos/cms/ghost.svg +1 -0
  235. package/public/assets/logos/cms/keystone.svg +1 -0
  236. package/public/assets/logos/cms/sanity.svg +1 -0
  237. package/public/assets/logos/cms/shopify.svg +1 -0
  238. package/public/assets/logos/cms/strapi.svg +1 -0
  239. package/public/assets/logos/cms/wordpress.svg +1 -0
  240. package/public/assets/logos/container/docker.svg +1 -0
  241. package/public/assets/logos/container/kubernetes.svg +1 -0
  242. package/public/assets/logos/css/antdesign.svg +1 -0
  243. package/public/assets/logos/css/bootstrap.svg +1 -0
  244. package/public/assets/logos/css/bulma.svg +1 -0
  245. package/public/assets/logos/css/chakraui.svg +1 -0
  246. package/public/assets/logos/css/daisyui.svg +1 -0
  247. package/public/assets/logos/css/fallback/mantine-logo.svg +1 -0
  248. package/public/assets/logos/css/fallback/shadcnui.svg +1 -0
  249. package/public/assets/logos/css/foundation.svg +1 -0
  250. package/public/assets/logos/css/headlessui.svg +1 -0
  251. package/public/assets/logos/css/less.svg +1 -0
  252. package/public/assets/logos/css/mui.svg +1 -0
  253. package/public/assets/logos/css/postcss.svg +1 -0
  254. package/public/assets/logos/css/radixui.svg +1 -0
  255. package/public/assets/logos/css/sass.svg +1 -0
  256. package/public/assets/logos/css/shadcnui.svg +1 -0
  257. package/public/assets/logos/css/styledcomponents.svg +1 -0
  258. package/public/assets/logos/css/tailwindcss.svg +1 -0
  259. package/public/assets/logos/database/amazondynamodb.svg +1 -0
  260. package/public/assets/logos/database/apachecassandra.svg +1 -0
  261. package/public/assets/logos/database/cockroachlabs.svg +1 -0
  262. package/public/assets/logos/database/duckdb.svg +1 -0
  263. package/public/assets/logos/database/elasticsearch.svg +1 -0
  264. package/public/assets/logos/database/fauna.svg +3 -0
  265. package/public/assets/logos/database/mariadb.svg +1 -0
  266. package/public/assets/logos/database/mongodb.svg +1 -0
  267. package/public/assets/logos/database/mysql.svg +1 -0
  268. package/public/assets/logos/database/planetscale.svg +1 -0
  269. package/public/assets/logos/database/postgresql.svg +1 -0
  270. package/public/assets/logos/database/redis.svg +1 -0
  271. package/public/assets/logos/database/sqlite.svg +1 -0
  272. package/public/assets/logos/database/supabase.svg +1 -0
  273. package/public/assets/logos/database/surrealdb.svg +1 -0
  274. package/public/assets/logos/devops/ansible.svg +1 -0
  275. package/public/assets/logos/devops/pulumi.svg +1 -0
  276. package/public/assets/logos/devops/serverless.svg +1 -0
  277. package/public/assets/logos/devops/terraform.svg +1 -0
  278. package/public/assets/logos/fallback/31557565.svg +32 -0
  279. package/public/assets/logos/fallback/Drizzle--Streamline-Simple-Icons.svg +7 -0
  280. package/public/assets/logos/fallback/changesets.svg +43 -0
  281. package/public/assets/logos/fallback/lemonsqueezy.svg +8 -0
  282. package/public/assets/logos/fallback/mantine-logo.svg +1 -0
  283. package/public/assets/logos/fallback/reactquery.svg +12 -0
  284. package/public/assets/logos/fallback/shadcnui.svg +21 -0
  285. package/public/assets/logos/fallback/stitches.svg +10 -0
  286. package/public/assets/logos/format/prettier.svg +1 -0
  287. package/public/assets/logos/frontend/alpinedotjs.svg +1 -0
  288. package/public/assets/logos/frontend/angular.svg +1 -0
  289. package/public/assets/logos/frontend/astro.svg +1 -0
  290. package/public/assets/logos/frontend/backbone.svg +1 -0
  291. package/public/assets/logos/frontend/emberdotjs.svg +1 -0
  292. package/public/assets/logos/frontend/htmx.svg +1 -0
  293. package/public/assets/logos/frontend/lit.svg +1 -0
  294. package/public/assets/logos/frontend/nextdotjs.svg +1 -0
  295. package/public/assets/logos/frontend/nuxt.svg +1 -0
  296. package/public/assets/logos/frontend/preact.svg +1 -0
  297. package/public/assets/logos/frontend/qwik.svg +1 -0
  298. package/public/assets/logos/frontend/react.svg +1 -0
  299. package/public/assets/logos/frontend/remix.svg +1 -0
  300. package/public/assets/logos/frontend/solid.svg +1 -0
  301. package/public/assets/logos/frontend/svelte.svg +1 -0
  302. package/public/assets/logos/frontend/vuedotjs.svg +1 -0
  303. package/public/assets/logos/hosting/netlify.svg +1 -0
  304. package/public/assets/logos/hosting/railway.svg +1 -0
  305. package/public/assets/logos/hosting/render.svg +1 -0
  306. package/public/assets/logos/hosting/vercel.svg +1 -0
  307. package/public/assets/logos/language/csharp.svg +1 -0
  308. package/public/assets/logos/language/go.svg +1 -0
  309. package/public/assets/logos/language/javascript.svg +1 -0
  310. package/public/assets/logos/language/openjdk.svg +1 -0
  311. package/public/assets/logos/language/php.svg +1 -0
  312. package/public/assets/logos/language/python.svg +1 -0
  313. package/public/assets/logos/language/ruby.svg +1 -0
  314. package/public/assets/logos/language/rust.svg +1 -0
  315. package/public/assets/logos/language/typescript.svg +1 -0
  316. package/public/assets/logos/lint/commitlint.svg +1 -0
  317. package/public/assets/logos/lint/eslint.svg +1 -0
  318. package/public/assets/logos/lint/husky.svg +3 -0
  319. package/public/assets/logos/lint/lintstaged.svg +3 -0
  320. package/public/assets/logos/mobile/capacitor.svg +1 -0
  321. package/public/assets/logos/mobile/expo.svg +1 -0
  322. package/public/assets/logos/mobile/flutter.svg +1 -0
  323. package/public/assets/logos/mobile/ionic.svg +1 -0
  324. package/public/assets/logos/mobile/react.svg +1 -0
  325. package/public/assets/logos/network/axios.svg +1 -0
  326. package/public/assets/logos/network/brandfetch.svg +1 -0
  327. package/public/assets/logos/network/grpc.svg +1 -0
  328. package/public/assets/logos/network/openapiinitiative.svg +1 -0
  329. package/public/assets/logos/network/swr.svg +1 -0
  330. package/public/assets/logos/orm/drizzle.svg +1 -0
  331. package/public/assets/logos/orm/mongoose.svg +1 -0
  332. package/public/assets/logos/orm/prisma.svg +1 -0
  333. package/public/assets/logos/orm/typeorm.svg +1 -0
  334. package/public/assets/logos/package/npm.svg +1 -0
  335. package/public/assets/logos/package/pnpm.svg +1 -0
  336. package/public/assets/logos/package/yarn.svg +1 -0
  337. package/public/assets/logos/payment/fallback/lemonsqueezy.svg +1 -0
  338. package/public/assets/logos/payment/paypal.svg +1 -0
  339. package/public/assets/logos/payment/stripe.svg +1 -0
  340. package/public/assets/logos/runtime/bun.svg +1 -0
  341. package/public/assets/logos/runtime/deno.svg +1 -0
  342. package/public/assets/logos/ssg/eleventy.svg +1 -0
  343. package/public/assets/logos/ssg/gatsby.svg +1 -0
  344. package/public/assets/logos/ssg/hugo.svg +1 -0
  345. package/public/assets/logos/ssg/jekyll.svg +1 -0
  346. package/public/assets/logos/state/mobx.svg +1 -0
  347. package/public/assets/logos/state/recoil.svg +1 -0
  348. package/public/assets/logos/state/redux.svg +1 -0
  349. package/public/assets/logos/state/xstate.svg +1 -0
  350. package/public/assets/logos/state/zustand.svg +1 -0
  351. package/public/assets/logos/testing/chai.svg +1 -0
  352. package/public/assets/logos/testing/cypress.svg +1 -0
  353. package/public/assets/logos/testing/jasmine.svg +1 -0
  354. package/public/assets/logos/testing/jest.svg +1 -0
  355. package/public/assets/logos/testing/mocha.svg +1 -0
  356. package/public/assets/logos/testing/playwright.svg +1 -0
  357. package/public/assets/logos/testing/puppeteer.svg +1 -0
  358. package/public/assets/logos/testing/storybook.svg +1 -0
  359. package/public/assets/logos/testing/testinglibrary.svg +1 -0
  360. package/public/assets/logos/testing/vitest.svg +1 -0
  361. package/public/assets/logos/utility/d3.svg +1 -0
  362. package/public/assets/logos/utility/leaflet.svg +1 -0
  363. package/public/assets/logos/utility/lodash.svg +1 -0
  364. package/public/assets/logos/utility/pyup.svg +1 -0
  365. package/public/assets/logos/utility/reactivex.svg +1 -0
  366. package/public/assets/logos/utility/threedotjs.svg +1 -0
  367. package/public/assets/logos/utility/zod.svg +1 -0
  368. package/public/stackscan-white.svg +26 -0
  369. package/public/stackscan.svg +26 -0
@@ -0,0 +1,23 @@
1
+ import {
2
+ techDefinitions
3
+ } from "./chunk-OJZZPNXQ.mjs";
4
+ import {
5
+ init_esm_shims
6
+ } from "./chunk-RDFZ4GVM.mjs";
7
+
8
+ // src/techMap.ts
9
+ init_esm_shims();
10
+ var techMap = {};
11
+ for (const def of techDefinitions) {
12
+ for (const alias of def.aliases) {
13
+ techMap[alias] = {
14
+ name: def.name,
15
+ logo: def.logo,
16
+ type: def.category
17
+ };
18
+ }
19
+ }
20
+
21
+ export {
22
+ techMap
23
+ };
@@ -0,0 +1,205 @@
1
+ // src/techMap.ts
2
+ var techMap = {
3
+ "typescript": { name: "TypeScript", logo: "language/typescript.svg", type: "language" },
4
+ "javascript": { name: "JavaScript", logo: "language/javascript.svg", type: "language" },
5
+ "python": { name: "Python", logo: "language/python.svg", type: "language" },
6
+ "go": { name: "Go", logo: "language/go.svg", type: "language" },
7
+ "rust": { name: "Rust", logo: "language/rust.svg", type: "language" },
8
+ "php": { name: "PHP", logo: "language/php.svg", type: "language" },
9
+ "ruby": { name: "Ruby", logo: "language/ruby.svg", type: "language" },
10
+ "java": { name: "Java", logo: "language/openjdk.svg", type: "language" },
11
+ "csharp": { name: "C#", logo: "language/csharp.svg", type: "language" },
12
+ "react": { name: "React", logo: "frontend/react.svg", type: "frontend" },
13
+ "react-dom": { name: "ReactDOM", logo: "frontend/react.svg", type: "frontend" },
14
+ "next": { name: "Next.js", logo: "frontend/nextdotjs.svg", type: "frontend" },
15
+ "remix": { name: "Remix", logo: "frontend/remix.svg", type: "frontend" },
16
+ "astro": { name: "Astro", logo: "frontend/astro.svg", type: "frontend" },
17
+ "svelte": { name: "Svelte", logo: "frontend/svelte.svg", type: "frontend" },
18
+ "@sveltejs/kit": { name: "SvelteKit", logo: "frontend/svelte.svg", type: "frontend" },
19
+ "solid-js": { name: "SolidJS", logo: "frontend/solid.svg", type: "frontend" },
20
+ "preact": { name: "Preact", logo: "frontend/preact.svg", type: "frontend" },
21
+ "vue": { name: "Vue", logo: "vuedotjs.svg", type: "frontend" },
22
+ "nuxt": { name: "Nuxt", logo: "frontend/nuxt.svg", type: "frontend" },
23
+ "@angular/core": { name: "Angular", logo: "frontend/angular.svg", type: "frontend" },
24
+ "lit": { name: "Lit", logo: "frontend/lit.svg", type: "frontend" },
25
+ "@builder.io/qwik": { name: "Qwik", logo: "frontend/qwik.svg", type: "frontend" },
26
+ "ember-source": { name: "Ember", logo: "frontend/emberdotjs.svg", type: "frontend" },
27
+ "backbone": { name: "Backbone", logo: "frontend/backbone.svg", type: "frontend" },
28
+ "alpinejs": { name: "AlpineJS", logo: "frontend/alpinedotjs.svg", type: "frontend" },
29
+ "htmx.org": { name: "HTMX", logo: "frontend/htmx.svg", type: "frontend" },
30
+ "tailwindcss": { name: "TailwindCSS", logo: "css/tailwindcss.svg", type: "css" },
31
+ "bootstrap": { name: "Bootstrap", logo: "css/bootstrap.svg", type: "css" },
32
+ "bulma": { name: "Bulma", logo: "css/bulma.svg", type: "css" },
33
+ "foundation-sites": { name: "Foundation", logo: "css/foundation.svg", type: "css" },
34
+ "@mui/material": { name: "Material UI", logo: "css/mui.svg", type: "css" },
35
+ "@chakra-ui/react": { name: "Chakra UI", logo: "css/chakraui.svg", type: "css" },
36
+ "@mantine/core": { name: "Mantine", logo: "fallback/mantine-logo.svg", type: "css" },
37
+ "shadcn": { name: "ShadCN UI", logo: "fallback/shadcnui.svg", type: "css" },
38
+ "daisyui": { name: "DaisyUI", logo: "css/daisyui.svg", type: "css" },
39
+ "antd": { name: "Ant Design", logo: "css/antdesign.svg", type: "css" },
40
+ "@radix-ui/react": { name: "Radix UI", logo: "css/radixui.svg", type: "css" },
41
+ "@headlessui/react": { name: "Headless UI", logo: "css/headlessui.svg", type: "css" },
42
+ "@emotion/react": { name: "Emotion", logo: "emotion.svg", type: "css" },
43
+ "styled-components": { name: "Styled Components", logo: "css/styledcomponents.svg", type: "css" },
44
+ "@stitches/react": { name: "Stitches", logo: "fallback/stitches.svg", type: "css" },
45
+ "sass": { name: "Sass", logo: "css/sass.svg", type: "css" },
46
+ "less": { name: "Less", logo: "css/less.svg", type: "css" },
47
+ "postcss": { name: "PostCSS", logo: "css/postcss.svg", type: "css" },
48
+ "redux": { name: "Redux", logo: "state/redux.svg", type: "state" },
49
+ "mobx": { name: "MobX", logo: "state/mobx.svg", type: "state" },
50
+ "zustand": { name: "Zustand", logo: "state/zustand.svg", type: "state" },
51
+ "jotai": { name: "Jotai", logo: "jotai.svg", type: "state" },
52
+ "recoil": { name: "Recoil", logo: "state/recoil.svg", type: "state" },
53
+ "xstate": { name: "XState", logo: "state/xstate.svg", type: "state" },
54
+ "@tanstack/react-query": { name: "TanStack Query", logo: "fallback/reactquery.svg", type: "state" },
55
+ "@reduxjs/toolkit": { name: "RTK Query", logo: "state/redux.svg", type: "state" },
56
+ "vite": { name: "Vite", logo: "build/vite.svg", type: "build" },
57
+ "webpack": { name: "Webpack", logo: "build/webpack.svg", type: "build" },
58
+ "parcel-bundler": { name: "Parcel", logo: "parcel.svg", type: "build" },
59
+ "rollup": { name: "Rollup", logo: "build/rollupdotjs.svg", type: "build" },
60
+ "snowpack": { name: "Snowpack", logo: "build/snowpack.svg", type: "build" },
61
+ "turbopack": { name: "Turbopack", logo: "build/webpack.svg", type: "build" },
62
+ "@swc/core": { name: "SWC", logo: "build/swc.svg", type: "build" },
63
+ "esbuild": { name: "ESBuild", logo: "build/esbuild.svg", type: "build" },
64
+ "@babel/core": { name: "Babel", logo: "build/babel.svg", type: "build" },
65
+ "tsup": { name: "Tsup", logo: "tsup.svg", type: "build" },
66
+ "jest": { name: "Jest", logo: "testing/jest.svg", type: "testing" },
67
+ "@playwright/test": { name: "Playwright", logo: "testing/playwright.svg", type: "testing" },
68
+ "cypress": { name: "Cypress", logo: "testing/cypress.svg", type: "testing" },
69
+ "vitest": { name: "Vitest", logo: "testing/vitest.svg", type: "testing" },
70
+ "mocha": { name: "Mocha", logo: "testing/mocha.svg", type: "testing" },
71
+ "chai": { name: "Chai", logo: "testing/chai.svg", type: "testing" },
72
+ "@testing-library/react": { name: "Testing Library", logo: "testing/testinglibrary.svg", type: "testing" },
73
+ "jasmine": { name: "Jasmine", logo: "testing/jasmine.svg", type: "testing" },
74
+ "puppeteer": { name: "Puppeteer", logo: "testing/puppeteer.svg", type: "testing" },
75
+ "@storybook/react": { name: "Storybook", logo: "testing/storybook.svg", type: "testing" },
76
+ "express": { name: "Express", logo: "backend/express.svg", type: "backend" },
77
+ "fastify": { name: "Fastify", logo: "backend/fastify.svg", type: "backend" },
78
+ "@nestjs/core": { name: "NestJS", logo: "backend/nestjs.svg", type: "backend" },
79
+ "koa": { name: "Koa", logo: "backend/koa.svg", type: "backend" },
80
+ "@hapi/hapi": { name: "Hapi", logo: "hapi.svg", type: "backend" },
81
+ "bun": { name: "Bun", logo: "runtime/bun.svg", type: "runtime" },
82
+ "deno": { name: "Deno", logo: "runtime/deno.svg", type: "runtime" },
83
+ "@adonisjs/core": { name: "AdonisJS", logo: "backend/adonisjs.svg", type: "backend" },
84
+ "@feathersjs/feathers": { name: "FeatherJS", logo: "feather.svg", type: "backend" },
85
+ "@trpc/server": { name: "tRPC", logo: "api/trpc.svg", type: "api" },
86
+ "graphql-yoga": { name: "GraphQL Yoga", logo: "api/graphql.svg", type: "api" },
87
+ "apollo-server": { name: "Apollo Server", logo: "apollographql.svg", type: "api" },
88
+ "graphql": { name: "GraphQL", logo: "api/graphql.svg", type: "api" },
89
+ "@apollo/client": { name: "Apollo Client", logo: "apollographql.svg", type: "api" },
90
+ "urql": { name: "Urql", logo: "api/graphql.svg", type: "api" },
91
+ "relay-runtime": { name: "Relay", logo: "api/relay.svg", type: "api" },
92
+ "@graphql-codegen/cli": { name: "GraphQL Codegen", logo: "api/graphql.svg", type: "api" },
93
+ "prisma": { name: "Prisma", logo: "orm/prisma.svg", type: "orm" },
94
+ "mongoose": { name: "Mongoose", logo: "orm/mongoose.svg", type: "orm" },
95
+ "typeorm": { name: "TypeORM", logo: "orm/typeorm.svg", type: "orm" },
96
+ "drizzle-orm": { name: "Drizzle ORM", logo: "fallback/Drizzle--Streamline-Simple-Icons.svg", type: "orm" },
97
+ "pg": { name: "PostgreSQL", logo: "database/postgresql.svg", type: "database" },
98
+ "mysql": { name: "MySQL", logo: "database/mysql.svg", type: "database" },
99
+ "mysql2": { name: "MySQL", logo: "database/mysql.svg", type: "database" },
100
+ "mariadb": { name: "MariaDB", logo: "database/mariadb.svg", type: "database" },
101
+ "sqlite3": { name: "SQLite", logo: "database/sqlite.svg", type: "database" },
102
+ "mongodb": { name: "MongoDB", logo: "database/mongodb.svg", type: "database" },
103
+ "redis": { name: "Redis", logo: "database/redis.svg", type: "database" },
104
+ "@elastic/elasticsearch": { name: "Elasticsearch", logo: "database/elasticsearch.svg", type: "database" },
105
+ "cassandra-driver": { name: "Cassandra", logo: "database/apachecassandra.svg", type: "database" },
106
+ "@aws-sdk/client-dynamodb": { name: "DynamoDB", logo: "database/amazondynamodb.svg", type: "database" },
107
+ "@google-cloud/firestore": { name: "Firestore", logo: "firebase.svg", type: "database" },
108
+ "@supabase/supabase-js": { name: "Supabase", logo: "database/supabase.svg", type: "database" },
109
+ "@planetscale/database": { name: "PlanetScale", logo: "database/planetscale.svg", type: "database" },
110
+ "faunadb": { name: "FaunaDB", logo: "database/fauna.svg", type: "database" },
111
+ "@cockroachdb/prisma-adapter": { name: "CockroachDB", logo: "cockroachlabs.svg", type: "database" },
112
+ "surrealdb.js": { name: "SurrealDB", logo: "database/surrealdb.svg", type: "database" },
113
+ "duckdb": { name: "DuckDB", logo: "database/duckdb.svg", type: "database" },
114
+ "axios": { name: "Axios", logo: "network/axios.svg", type: "network" },
115
+ "node-fetch": { name: "Fetch", logo: "brandfetch.svg", type: "network" },
116
+ "swr": { name: "SWR", logo: "network/swr.svg", type: "network" },
117
+ "got": { name: "Got", logo: "go.svg", type: "network" },
118
+ "@grpc/grpc-js": { name: "gRPC", logo: "network/grpc.svg", type: "network" },
119
+ "openapi": { name: "OpenAPI", logo: "network/openapiinitiative.svg", type: "network" },
120
+ "superagent": { name: "SuperAgent", logo: "superagent.svg", type: "network" },
121
+ "auth0": { name: "Auth0", logo: "auth/auth0.svg", type: "auth" },
122
+ "@clerk/nextjs": { name: "Clerk", logo: "auth/clerk.svg", type: "auth" },
123
+ "@supabase/auth-helpers-nextjs": { name: "Supabase Auth", logo: "supabase.svg", type: "auth" },
124
+ "firebase": { name: "Firebase Auth", logo: "auth/firebase.svg", type: "auth" },
125
+ "next-auth": { name: "NextAuth", logo: "nextdotjs.svg", type: "auth" },
126
+ "jsonwebtoken": { name: "JWT", logo: "jsonwebtokens.svg", type: "auth" },
127
+ "passport": { name: "Passport.js", logo: "auth/passport.svg", type: "auth" },
128
+ "bcrypt": { name: "bcrypt", logo: "bcrypt.svg", type: "auth" },
129
+ "argon2": { name: "argon2", logo: "argo.svg", type: "auth" },
130
+ "keycloak-js": { name: "Keycloak", logo: "auth/keycloak.svg", type: "auth" },
131
+ "openai": { name: "OpenAI SDK", logo: "ai/openai.svg", type: "ai" },
132
+ "langchain": { name: "LangChain", logo: "ai/langchain.svg", type: "ai" },
133
+ "@tensorflow/tfjs": { name: "TensorFlow.js", logo: "tensorflow.svg", type: "ai" },
134
+ "@huggingface/inference": { name: "HuggingFace", logo: "ai/huggingface.svg", type: "ai" },
135
+ "replicate": { name: "Replicate", logo: "ai/replicate.svg", type: "ai" },
136
+ "ai": { name: "Vercel AI SDK", logo: "vercel.svg", type: "ai" },
137
+ "@xenova/transformers": { name: "Transformers.js", logo: "transformers.svg", type: "ai" },
138
+ "github-actions": { name: "GitHub Actions", logo: "ci/githubactions.svg", type: "ci" },
139
+ "gitlab-ci": { name: "GitLab CI", logo: "gitlab.svg", type: "ci" },
140
+ "circleci": { name: "CircleCI", logo: "ci/circleci.svg", type: "ci" },
141
+ "travis-ci": { name: "Travis CI", logo: "ci/travisci.svg", type: "ci" },
142
+ "jenkins": { name: "Jenkins", logo: "ci/jenkins.svg", type: "ci" },
143
+ "docker": { name: "Docker", logo: "container/docker.svg", type: "container" },
144
+ "docker-compose": { name: "Docker Compose", logo: "container/docker.svg", type: "container" },
145
+ "kubernetes": { name: "Kubernetes", logo: "container/kubernetes.svg", type: "container" },
146
+ "terraform": { name: "Terraform", logo: "devops/terraform.svg", type: "devops" },
147
+ "ansible": { name: "Ansible", logo: "devops/ansible.svg", type: "devops" },
148
+ "@pulumi/pulumi": { name: "Pulumi", logo: "devops/pulumi.svg", type: "devops" },
149
+ "serverless": { name: "Serverless Framework", logo: "devops/serverless.svg", type: "devops" },
150
+ "aws-sdk": { name: "AWS", logo: "amazonwebservices.svg", type: "cloud" },
151
+ "@azure/core-client": { name: "Azure", logo: "cloud/microsoftazure.svg", type: "cloud" },
152
+ "@google-cloud/storage": { name: "Google Cloud", logo: "cloud/googlecloud.svg", type: "cloud" },
153
+ "vercel": { name: "Vercel", logo: "hosting/vercel.svg", type: "hosting" },
154
+ "netlify": { name: "Netlify", logo: "hosting/netlify.svg", type: "hosting" },
155
+ "@railway/cli": { name: "Railway", logo: "hosting/railway.svg", type: "hosting" },
156
+ "render": { name: "Render", logo: "hosting/render.svg", type: "hosting" },
157
+ "@cloudflare/workers-types": { name: "Cloudflare", logo: "cloud/cloudflare.svg", type: "cloud" },
158
+ "eslint": { name: "ESLint", logo: "lint/eslint.svg", type: "lint" },
159
+ "prettier": { name: "Prettier", logo: "format/prettier.svg", type: "format" },
160
+ "husky": { name: "Husky", logo: "husqvarna.svg", type: "lint" },
161
+ "lint-staged": { name: "Lint-staged", logo: "lintstaged.svg", type: "lint" },
162
+ "commitizen": { name: "Commitizen", logo: "commitizen.svg", type: "lint" },
163
+ "@commitlint/cli": { name: "Commitlint", logo: "lint/commitlint.svg", type: "lint" },
164
+ "npm": { name: "npm", logo: "package/npm.svg", type: "package" },
165
+ "pnpm": { name: "pnpm", logo: "package/pnpm.svg", type: "package" },
166
+ "yarn": { name: "Yarn", logo: "package/yarn.svg", type: "package" },
167
+ "@11ty/eleventy": { name: "11ty", logo: "eleventy.svg", type: "ssg" },
168
+ "hugo": { name: "Hugo", logo: "ssg/hugo.svg", type: "ssg" },
169
+ "jekyll": { name: "Jekyll", logo: "ssg/jekyll.svg", type: "ssg" },
170
+ "gatsby": { name: "Gatsby", logo: "ssg/gatsby.svg", type: "ssg" },
171
+ "wordpress": { name: "WordPress", logo: "cms/wordpress.svg", type: "cms" },
172
+ "@shopify/shopify-api": { name: "Shopify", logo: "cms/shopify.svg", type: "cms" },
173
+ "@sanity/client": { name: "Sanity", logo: "cms/sanity.svg", type: "cms" },
174
+ "contentful": { name: "Contentful", logo: "cms/contentful.svg", type: "cms" },
175
+ "@strapi/strapi": { name: "Strapi", logo: "cms/strapi.svg", type: "cms" },
176
+ "ghost": { name: "Ghost", logo: "cms/ghost.svg", type: "cms" },
177
+ "@keystone-6/core": { name: "KeystoneJS", logo: "keystone.svg", type: "cms" },
178
+ "directus": { name: "Directus", logo: "cms/directus.svg", type: "cms" },
179
+ "turborepo": { name: "TurboRepo", logo: "automation/turborepo.svg", type: "automation" },
180
+ "nx": { name: "Nx", logo: "automation/nx.svg", type: "automation" },
181
+ "lerna": { name: "Lerna", logo: "automation/lerna.svg", type: "automation" },
182
+ "@changesets/cli": { name: "Changesets", logo: "fallback/changesets.svg", type: "automation" },
183
+ "react-native": { name: "React Native", logo: "mobile/react.svg", type: "mobile" },
184
+ "expo": { name: "Expo", logo: "mobile/expo.svg", type: "mobile" },
185
+ "flutter": { name: "Flutter", logo: "mobile/flutter.svg", type: "mobile" },
186
+ "@ionic/angular": { name: "Ionic", logo: "mobile/ionic.svg", type: "mobile" },
187
+ "@capacitor/core": { name: "Capacitor", logo: "mobile/capacitor.svg", type: "mobile" },
188
+ "lodash": { name: "Lodash", logo: "utility/lodash.svg", type: "utility" },
189
+ "dayjs": { name: "Day.js", logo: "dayjs.svg", type: "utility" },
190
+ "moment": { name: "Moment.js", logo: "moment.svg", type: "utility" },
191
+ "zod": { name: "Zod", logo: "utility/zod.svg", type: "utility" },
192
+ "yup": { name: "Yup", logo: "pyup.svg", type: "utility" },
193
+ "joi": { name: "Joi", logo: "joi.svg", type: "utility" },
194
+ "rxjs": { name: "RxJS", logo: "utility/reactivex.svg", type: "utility" },
195
+ "three": { name: "Three.js", logo: "utility/threedotjs.svg", type: "utility" },
196
+ "leaflet": { name: "Leaflet", logo: "utility/leaflet.svg", type: "utility" },
197
+ "d3": { name: "D3.js", logo: "utility/d3.svg", type: "utility" },
198
+ "stripe": { name: "Stripe", logo: "payment/stripe.svg", type: "payment" },
199
+ "@paypal/checkout-server-sdk": { name: "PayPal SDK", logo: "paypal.svg", type: "payment" },
200
+ "@lemonsqueezy/lemonsqueezy.js": { name: "LemonSqueezy", logo: "fallback/lemonsqueezy.svg", type: "payment" }
201
+ };
202
+
203
+ export {
204
+ techMap
205
+ };
@@ -0,0 +1,146 @@
1
+ import {
2
+ copyAssets,
3
+ generateMarkdown
4
+ } from "./chunk-ZH22D4SN.mjs";
5
+ import {
6
+ simple_icons_hex_default
7
+ } from "./chunk-EH2SEQZP.mjs";
8
+ import {
9
+ techMap
10
+ } from "./chunk-2KG7JDHY.mjs";
11
+
12
+ // src/sync.ts
13
+ import fs from "fs";
14
+ import path from "path";
15
+ var BASE_DIR = path.join(process.cwd(), "stacksync");
16
+ async function sync(options = {}) {
17
+ console.log("\u{1F680} Starting Sync...");
18
+ if (options.color) {
19
+ console.log(`\u{1F3A8} Color mode: ${options.color}`);
20
+ }
21
+ if (!fs.existsSync(BASE_DIR)) {
22
+ console.log(`Creating stacksync directory at: ${BASE_DIR}`);
23
+ fs.mkdirSync(BASE_DIR, { recursive: true });
24
+ console.log('Please place your project folders inside "stacksync/" and run this command again.');
25
+ process.exit(0);
26
+ }
27
+ organizePackageFiles();
28
+ const entries = fs.readdirSync(BASE_DIR, { withFileTypes: true });
29
+ const projectDirs = entries.filter((dirent) => dirent.isDirectory() && dirent.name !== "input" && dirent.name !== "output");
30
+ if (projectDirs.length === 0) {
31
+ console.log('\u26A0\uFE0F No project directories found in "stacksync/".');
32
+ return;
33
+ }
34
+ console.log(`Found ${projectDirs.length} projects to process.
35
+ `);
36
+ const allProjects = [];
37
+ const allTechs = [];
38
+ for (const dir of projectDirs) {
39
+ const projectPath = path.join(BASE_DIR, dir.name);
40
+ const packageJsonPath = path.join(projectPath, "package.json");
41
+ if (fs.existsSync(packageJsonPath)) {
42
+ try {
43
+ const content = fs.readFileSync(packageJsonPath, "utf-8");
44
+ const pkg = JSON.parse(content);
45
+ const allDeps = { ...pkg.dependencies, ...pkg.devDependencies };
46
+ const detectedTechs = [];
47
+ Object.keys(allDeps).forEach((dep) => {
48
+ if (techMap[dep]) {
49
+ const tech = techMap[dep];
50
+ let color = null;
51
+ if (options.color === "white") color = "#FFFFFF";
52
+ else if (options.color === "black") color = "#000000";
53
+ else if (options.color && options.color.startsWith("#")) color = options.color;
54
+ else {
55
+ const depSlug = dep.toLowerCase();
56
+ const nameSlug = tech.name.toLowerCase();
57
+ const nameSlugNoSpaces = tech.name.toLowerCase().replace(/\s+/g, "");
58
+ const hex = simple_icons_hex_default[depSlug] || simple_icons_hex_default[nameSlug] || simple_icons_hex_default[nameSlugNoSpaces];
59
+ if (hex) color = `#${hex}`;
60
+ }
61
+ detectedTechs.push({
62
+ name: tech.name,
63
+ slug: dep,
64
+ logo: `https://raw.githubusercontent.com/benjamindotdev/stacksync/main/public/assets/logos/${tech.logo}`,
65
+ relativePath: `public/assets/logos/${tech.logo}`,
66
+ color
67
+ });
68
+ }
69
+ });
70
+ const uniqueTechs = Array.from(new Set(detectedTechs.map((t) => t.slug))).map((slug) => detectedTechs.find((t) => t.slug === slug));
71
+ allTechs.push(...uniqueTechs);
72
+ fs.writeFileSync(
73
+ path.join(projectPath, "stack.json"),
74
+ JSON.stringify(uniqueTechs, null, 2)
75
+ );
76
+ const mdContent = generateMarkdown(uniqueTechs);
77
+ fs.writeFileSync(path.join(projectPath, "stack.md"), mdContent);
78
+ allProjects.push({
79
+ name: dir.name,
80
+ techs: uniqueTechs
81
+ });
82
+ console.log(`\u2705 ${dir.name.padEnd(20)} -> stack.json (${uniqueTechs.length} techs)`);
83
+ } catch (err) {
84
+ console.error(`\u274C Error processing ${dir.name}:`, err.message);
85
+ }
86
+ } else {
87
+ console.warn(`\u26A0\uFE0F Skipping "${dir.name}": No package.json found.`);
88
+ }
89
+ }
90
+ if (allProjects.length > 0) {
91
+ const assetsDir = path.join(process.cwd(), "assets", "logos");
92
+ const uniqueAllTechs = Array.from(new Set(allTechs.map((t) => t.slug))).map((slug) => allTechs.find((t) => t.slug === slug));
93
+ const techsForCopy = uniqueAllTechs.map((t) => ({
94
+ ...t,
95
+ logo: t.relativePath.replace("public/assets/logos/", "")
96
+ // Restore "frameworks/react.svg"
97
+ }));
98
+ await copyAssets(techsForCopy, assetsDir, { colorMode: options.color });
99
+ updateRootReadme(allProjects);
100
+ }
101
+ console.log("\n\u2728 Sync complete.");
102
+ }
103
+ function updateRootReadme(projects) {
104
+ const readmePath = path.join(process.cwd(), "README.md");
105
+ if (!fs.existsSync(readmePath)) {
106
+ console.log("\u26A0\uFE0F No root README.md found to update.");
107
+ return;
108
+ }
109
+ let readmeContent = fs.readFileSync(readmePath, "utf-8");
110
+ const startMarker = "<!-- STACKSYNC_START -->";
111
+ const endMarker = "<!-- STACKSYNC_END -->";
112
+ let newSection = `${startMarker}
113
+ ## My Projects
114
+
115
+ `;
116
+ for (const p of projects) {
117
+ newSection += `### ${p.name}
118
+ `;
119
+ newSection += `<p>
120
+ `;
121
+ for (const t of p.techs) {
122
+ const src = t.relativePath || t.logo;
123
+ newSection += ` <img src="${src}" alt="${t.name}" height="25" style="margin-right: 10px;" />
124
+ `;
125
+ }
126
+ newSection += `</p>
127
+
128
+ `;
129
+ }
130
+ newSection += `${endMarker}`;
131
+ if (readmeContent.includes(startMarker) && readmeContent.includes(endMarker)) {
132
+ const regex = new RegExp(`${startMarker}[\\s\\S]*?${endMarker}`);
133
+ readmeContent = readmeContent.replace(regex, newSection);
134
+ console.log(`\u{1F4DD} Updated root README.md with ${projects.length} projects.`);
135
+ } else {
136
+ readmeContent += `
137
+
138
+ ${newSection}`;
139
+ console.log(`\u{1F4DD} Appended projects to root README.md.`);
140
+ }
141
+ fs.writeFileSync(readmePath, readmeContent);
142
+ }
143
+
144
+ export {
145
+ sync
146
+ };
@@ -0,0 +1,177 @@
1
+ import {
2
+ copyAssets,
3
+ generateMarkdown
4
+ } from "./chunk-ZH22D4SN.mjs";
5
+ import {
6
+ simple_icons_hex_default
7
+ } from "./chunk-EH2SEQZP.mjs";
8
+ import {
9
+ techMap
10
+ } from "./chunk-2KG7JDHY.mjs";
11
+
12
+ // src/sync.ts
13
+ import fs from "fs";
14
+ import path from "path";
15
+ var BASE_DIR = path.join(process.cwd(), "stacksync");
16
+ function organizePackageFiles() {
17
+ if (!fs.existsSync(BASE_DIR)) return;
18
+ const entries = fs.readdirSync(BASE_DIR, { withFileTypes: true });
19
+ const packageFiles = entries.filter(
20
+ (dirent) => dirent.isFile() && dirent.name.startsWith("package") && dirent.name.endsWith(".json")
21
+ );
22
+ if (packageFiles.length > 0) {
23
+ console.log(`\u{1F4E6} Found ${packageFiles.length} loose package.json files. Organizing...`);
24
+ }
25
+ for (const file of packageFiles) {
26
+ const filePath = path.join(BASE_DIR, file.name);
27
+ try {
28
+ const content = fs.readFileSync(filePath, "utf-8");
29
+ const pkg = JSON.parse(content);
30
+ if (!pkg.name) {
31
+ console.warn(`\u26A0\uFE0F Skipping ${file.name}: No "name" field found in package.json`);
32
+ continue;
33
+ }
34
+ const folderName = pkg.name.replace(/^@/, "").replace(/\//g, "-");
35
+ const targetDir = path.join(BASE_DIR, folderName);
36
+ const targetFile = path.join(targetDir, "package.json");
37
+ if (!fs.existsSync(targetDir)) {
38
+ fs.mkdirSync(targetDir, { recursive: true });
39
+ }
40
+ fs.renameSync(filePath, targetFile);
41
+ console.log(`\u2705 Moved ${file.name} -> ${folderName}/package.json`);
42
+ } catch (error) {
43
+ console.error(`\u274C Error processing ${file.name}:`, error);
44
+ }
45
+ }
46
+ }
47
+ async function sync(options = {}) {
48
+ console.log("\u{1F680} Starting Sync...");
49
+ if (options.color) {
50
+ console.log(`\u{1F3A8} Color mode: ${options.color}`);
51
+ }
52
+ if (!fs.existsSync(BASE_DIR)) {
53
+ console.log(`Creating stacksync directory at: ${BASE_DIR}`);
54
+ fs.mkdirSync(BASE_DIR, { recursive: true });
55
+ console.log('Please place your project folders inside "stacksync/" and run this command again.');
56
+ process.exit(0);
57
+ }
58
+ organizePackageFiles();
59
+ const entries = fs.readdirSync(BASE_DIR, { withFileTypes: true });
60
+ const projectDirs = entries.filter((dirent) => dirent.isDirectory() && dirent.name !== "input" && dirent.name !== "output");
61
+ if (projectDirs.length === 0) {
62
+ console.log('\u26A0\uFE0F No project directories found in "stacksync/".');
63
+ return;
64
+ }
65
+ console.log(`Found ${projectDirs.length} projects to process.
66
+ `);
67
+ const allProjects = [];
68
+ const allTechs = [];
69
+ for (const dir of projectDirs) {
70
+ const projectPath = path.join(BASE_DIR, dir.name);
71
+ const packageJsonPath = path.join(projectPath, "package.json");
72
+ if (fs.existsSync(packageJsonPath)) {
73
+ try {
74
+ const content = fs.readFileSync(packageJsonPath, "utf-8");
75
+ const pkg = JSON.parse(content);
76
+ const allDeps = { ...pkg.dependencies, ...pkg.devDependencies };
77
+ const detectedTechs = [];
78
+ Object.keys(allDeps).forEach((dep) => {
79
+ if (techMap[dep]) {
80
+ const tech = techMap[dep];
81
+ let color = null;
82
+ if (options.color === "white") color = "#FFFFFF";
83
+ else if (options.color === "black") color = "#000000";
84
+ else if (options.color && options.color.startsWith("#")) color = options.color;
85
+ else {
86
+ const depSlug = dep.toLowerCase();
87
+ const nameSlug = tech.name.toLowerCase();
88
+ const nameSlugNoSpaces = tech.name.toLowerCase().replace(/\s+/g, "");
89
+ const hex = simple_icons_hex_default[depSlug] || simple_icons_hex_default[nameSlug] || simple_icons_hex_default[nameSlugNoSpaces];
90
+ if (hex) color = `#${hex}`;
91
+ }
92
+ detectedTechs.push({
93
+ name: tech.name,
94
+ slug: dep,
95
+ logo: `https://raw.githubusercontent.com/benjamindotdev/stacksync/main/public/assets/logos/${tech.logo}`,
96
+ relativePath: `public/assets/logos/${tech.logo}`,
97
+ color
98
+ });
99
+ }
100
+ });
101
+ const uniqueTechs = Array.from(new Set(detectedTechs.map((t) => t.slug))).map((slug) => detectedTechs.find((t) => t.slug === slug));
102
+ allTechs.push(...uniqueTechs);
103
+ fs.writeFileSync(
104
+ path.join(projectPath, "stack.json"),
105
+ JSON.stringify(uniqueTechs, null, 2)
106
+ );
107
+ const mdContent = generateMarkdown(uniqueTechs);
108
+ fs.writeFileSync(path.join(projectPath, "stack.md"), mdContent);
109
+ allProjects.push({
110
+ name: dir.name,
111
+ techs: uniqueTechs
112
+ });
113
+ console.log(`\u2705 ${dir.name.padEnd(20)} -> stack.json (${uniqueTechs.length} techs)`);
114
+ } catch (err) {
115
+ console.error(`\u274C Error processing ${dir.name}:`, err.message);
116
+ }
117
+ } else {
118
+ console.warn(`\u26A0\uFE0F Skipping "${dir.name}": No package.json found.`);
119
+ }
120
+ }
121
+ if (allProjects.length > 0) {
122
+ const assetsDir = path.join(process.cwd(), "assets", "logos");
123
+ const uniqueAllTechs = Array.from(new Set(allTechs.map((t) => t.slug))).map((slug) => allTechs.find((t) => t.slug === slug));
124
+ const techsForCopy = uniqueAllTechs.map((t) => ({
125
+ ...t,
126
+ logo: t.relativePath.replace("public/assets/logos/", "")
127
+ // Restore "frameworks/react.svg"
128
+ }));
129
+ await copyAssets(techsForCopy, assetsDir, { colorMode: options.color });
130
+ updateRootReadme(allProjects);
131
+ }
132
+ console.log("\n\u2728 Sync complete.");
133
+ }
134
+ function updateRootReadme(projects) {
135
+ const readmePath = path.join(process.cwd(), "README.md");
136
+ if (!fs.existsSync(readmePath)) {
137
+ console.log("\u26A0\uFE0F No root README.md found to update.");
138
+ return;
139
+ }
140
+ let readmeContent = fs.readFileSync(readmePath, "utf-8");
141
+ const startMarker = "<!-- STACKSYNC_START -->";
142
+ const endMarker = "<!-- STACKSYNC_END -->";
143
+ let newSection = `${startMarker}
144
+ ## My Projects
145
+
146
+ `;
147
+ for (const p of projects) {
148
+ newSection += `### ${p.name}
149
+ `;
150
+ newSection += `<p>
151
+ `;
152
+ for (const t of p.techs) {
153
+ const src = t.relativePath || t.logo;
154
+ newSection += ` <img src="${src}" alt="${t.name}" height="25" style="margin-right: 10px;" />
155
+ `;
156
+ }
157
+ newSection += `</p>
158
+
159
+ `;
160
+ }
161
+ newSection += `${endMarker}`;
162
+ if (readmeContent.includes(startMarker) && readmeContent.includes(endMarker)) {
163
+ const regex = new RegExp(`${startMarker}[\\s\\S]*?${endMarker}`);
164
+ readmeContent = readmeContent.replace(regex, newSection);
165
+ console.log(`\u{1F4DD} Updated root README.md with ${projects.length} projects.`);
166
+ } else {
167
+ readmeContent += `
168
+
169
+ ${newSection}`;
170
+ console.log(`\u{1F4DD} Appended projects to root README.md.`);
171
+ }
172
+ fs.writeFileSync(readmePath, readmeContent);
173
+ }
174
+
175
+ export {
176
+ sync
177
+ };
@@ -0,0 +1,49 @@
1
+ // src/add.ts
2
+ import fs from "fs-extra";
3
+ import path from "path";
4
+ import chalk from "chalk";
5
+ var BASE_DIR = path.join(process.cwd(), "stackscan");
6
+ async function add(sourcePath) {
7
+ let absoluteSourcePath = path.resolve(sourcePath);
8
+ if (!fs.existsSync(absoluteSourcePath)) {
9
+ console.error(chalk.red(`\u274C Path not found: ${sourcePath}`));
10
+ process.exit(1);
11
+ }
12
+ if (fs.statSync(absoluteSourcePath).isDirectory()) {
13
+ absoluteSourcePath = path.join(absoluteSourcePath, "package.json");
14
+ if (!fs.existsSync(absoluteSourcePath)) {
15
+ console.error(chalk.red(`\u274C No package.json found in directory: ${sourcePath}`));
16
+ process.exit(1);
17
+ }
18
+ }
19
+ try {
20
+ const content = fs.readFileSync(absoluteSourcePath, "utf-8");
21
+ const pkg = JSON.parse(content);
22
+ if (!pkg.name) {
23
+ console.error(chalk.red(`\u274C No "name" field found in ${sourcePath}`));
24
+ process.exit(1);
25
+ }
26
+ const baseFolderName = pkg.name.replace(/^@/, "").replace(/\//g, "-");
27
+ let folderName = baseFolderName;
28
+ let targetDir = path.join(BASE_DIR, folderName);
29
+ let counter = 1;
30
+ while (fs.existsSync(targetDir)) {
31
+ folderName = `${baseFolderName}-${counter}`;
32
+ targetDir = path.join(BASE_DIR, folderName);
33
+ counter++;
34
+ }
35
+ const targetFile = path.join(targetDir, "package.json");
36
+ if (!fs.existsSync(targetDir)) {
37
+ fs.mkdirSync(targetDir, { recursive: true });
38
+ }
39
+ fs.copyFileSync(absoluteSourcePath, targetFile);
40
+ console.log(chalk.green(`\u2705 Added project "${pkg.name}" to stackscan/${folderName}`));
41
+ } catch (error) {
42
+ console.error(chalk.red(`\u274C Error processing ${sourcePath}:`), error);
43
+ process.exit(1);
44
+ }
45
+ }
46
+
47
+ export {
48
+ add
49
+ };
@@ -0,0 +1,25 @@
1
+ // src/detectors/ci.ts
2
+ import fs from "fs-extra";
3
+ import path from "path";
4
+ async function detectCI(repoPath) {
5
+ if (await fs.pathExists(path.join(repoPath, ".github/workflows"))) {
6
+ return { name: "GitHub Actions", logo: "githubactions.svg", type: "ci" };
7
+ }
8
+ if (await fs.pathExists(path.join(repoPath, ".gitlab-ci.yml"))) {
9
+ return { name: "GitLab CI", logo: "gitlab.svg", type: "ci" };
10
+ }
11
+ if (await fs.pathExists(path.join(repoPath, ".circleci"))) {
12
+ return { name: "CircleCI", logo: "circleci.svg", type: "ci" };
13
+ }
14
+ if (await fs.pathExists(path.join(repoPath, ".travis.yml"))) {
15
+ return { name: "Travis CI", logo: "travisci.svg", type: "ci" };
16
+ }
17
+ if (await fs.pathExists(path.join(repoPath, "azure-pipelines.yml"))) {
18
+ return { name: "Azure Pipelines", logo: "azurepipelines.svg", type: "ci" };
19
+ }
20
+ return null;
21
+ }
22
+
23
+ export {
24
+ detectCI
25
+ };