fromsrc 0.0.0 → 0.0.2

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 (684) hide show
  1. package/README.md +49 -0
  2. package/dist/access.d.ts +23 -0
  3. package/dist/access.js +54 -0
  4. package/dist/adapter.d.ts +31 -0
  5. package/dist/adapter.js +59 -0
  6. package/dist/adapterastro.d.ts +6 -0
  7. package/dist/adapterastro.js +6 -0
  8. package/dist/adapterbrowser.d.ts +6 -0
  9. package/dist/adapterbrowser.js +38 -0
  10. package/dist/adapternext.d.ts +6 -0
  11. package/dist/adapternext.js +49 -0
  12. package/dist/adapterreactrouter.d.ts +6 -0
  13. package/dist/adapterreactrouter.js +37 -0
  14. package/dist/adapterremix.d.ts +6 -0
  15. package/dist/adapterremix.js +41 -0
  16. package/dist/adaptertanstack.d.ts +6 -0
  17. package/dist/adaptertanstack.js +38 -0
  18. package/dist/adaptervite.d.ts +6 -0
  19. package/dist/adaptervite.js +6 -0
  20. package/dist/algolia.d.ts +16 -0
  21. package/dist/algolia.js +83 -0
  22. package/dist/analytics.d.ts +31 -0
  23. package/dist/analytics.js +61 -0
  24. package/dist/ansi.d.ts +5 -0
  25. package/dist/ansi.js +192 -0
  26. package/dist/api.d.ts +30 -0
  27. package/dist/api.js +75 -0
  28. package/dist/astro.d.ts +3 -0
  29. package/dist/astro.js +3 -0
  30. package/dist/audit.d.ts +19 -0
  31. package/dist/audit.js +78 -0
  32. package/dist/autotype.d.ts +17 -0
  33. package/dist/autotype.js +73 -0
  34. package/dist/batch.d.ts +22 -0
  35. package/dist/batch.js +68 -0
  36. package/dist/browser.d.ts +5 -0
  37. package/dist/browser.js +53 -0
  38. package/dist/changelog.d.ts +27 -0
  39. package/dist/changelog.js +87 -0
  40. package/dist/changelogutil.d.ts +20 -0
  41. package/dist/changelogutil.js +84 -0
  42. package/dist/cli.d.ts +24 -0
  43. package/dist/cli.js +76 -0
  44. package/dist/client.d.ts +212 -0
  45. package/dist/client.js +202 -0
  46. package/dist/codesample.d.ts +20 -0
  47. package/dist/codesample.js +115 -0
  48. package/dist/collapse.d.ts +5 -0
  49. package/dist/collapse.js +101 -0
  50. package/dist/collections.d.ts +32 -0
  51. package/dist/collections.js +82 -0
  52. package/dist/components/accordion.d.ts +22 -0
  53. package/dist/components/accordion.js +54 -0
  54. package/dist/components/alert.d.ts +18 -0
  55. package/dist/components/alert.js +30 -0
  56. package/dist/components/announce.d.ts +11 -0
  57. package/dist/components/announce.js +38 -0
  58. package/dist/components/autofill.d.ts +27 -0
  59. package/dist/components/autofill.js +152 -0
  60. package/dist/components/avatar.d.ts +42 -0
  61. package/dist/components/avatar.js +67 -0
  62. package/dist/components/avatarstack.d.ts +23 -0
  63. package/dist/components/avatarstack.js +54 -0
  64. package/dist/components/backtotop.d.ts +20 -0
  65. package/dist/components/backtotop.js +42 -0
  66. package/dist/components/badge.d.ts +17 -0
  67. package/dist/components/badge.js +25 -0
  68. package/dist/components/banner.d.ts +21 -0
  69. package/dist/components/banner.js +63 -0
  70. package/dist/components/breadcrumb.d.ts +25 -0
  71. package/dist/components/breadcrumb.js +35 -0
  72. package/dist/components/breadcrumbnav.d.ts +15 -0
  73. package/dist/components/breadcrumbnav.js +60 -0
  74. package/dist/components/button.d.ts +22 -0
  75. package/dist/components/button.js +47 -0
  76. package/dist/components/callout.d.ts +26 -0
  77. package/dist/components/callout.js +91 -0
  78. package/dist/components/cards.d.ts +34 -0
  79. package/dist/components/cards.js +24 -0
  80. package/dist/components/changelog.d.ts +34 -0
  81. package/dist/components/changelog.js +50 -0
  82. package/dist/components/checkbox.d.ts +26 -0
  83. package/dist/components/checkbox.js +80 -0
  84. package/dist/components/code.d.ts +27 -0
  85. package/dist/components/code.js +36 -0
  86. package/dist/components/codeblock.d.ts +12 -0
  87. package/dist/components/codeblock.js +102 -0
  88. package/dist/components/codecopy.d.ts +12 -0
  89. package/dist/components/codecopy.js +56 -0
  90. package/dist/components/codegroup.d.ts +22 -0
  91. package/dist/components/codegroup.js +134 -0
  92. package/dist/components/collapsible.d.ts +29 -0
  93. package/dist/components/collapsible.js +64 -0
  94. package/dist/components/command.d.ts +22 -0
  95. package/dist/components/command.js +138 -0
  96. package/dist/components/compare.d.ts +54 -0
  97. package/dist/components/compare.js +88 -0
  98. package/dist/components/content.d.ts +12 -0
  99. package/dist/components/content.js +232 -0
  100. package/dist/components/copyable.d.ts +25 -0
  101. package/dist/components/copyable.js +51 -0
  102. package/dist/components/copybutton.d.ts +11 -0
  103. package/dist/components/copybutton.js +50 -0
  104. package/dist/components/countdown.d.ts +18 -0
  105. package/dist/components/countdown.js +112 -0
  106. package/dist/components/create.d.ts +10 -0
  107. package/dist/components/create.js +149 -0
  108. package/dist/components/definition.d.ts +43 -0
  109. package/dist/components/definition.js +46 -0
  110. package/dist/components/diffview.d.ts +12 -0
  111. package/dist/components/diffview.js +129 -0
  112. package/dist/components/divider.d.ts +19 -0
  113. package/dist/components/divider.js +24 -0
  114. package/dist/components/docheader.d.ts +17 -0
  115. package/dist/components/docheader.js +24 -0
  116. package/dist/components/doclinkcard.d.ts +19 -0
  117. package/dist/components/doclinkcard.js +37 -0
  118. package/dist/components/docslayout.d.ts +14 -0
  119. package/dist/components/docslayout.js +24 -0
  120. package/dist/components/dropdown.d.ts +23 -0
  121. package/dist/components/dropdown.js +134 -0
  122. package/dist/components/dynamiccode.d.ts +12 -0
  123. package/dist/components/dynamiccode.js +40 -0
  124. package/dist/components/editlink.d.ts +15 -0
  125. package/dist/components/editlink.js +45 -0
  126. package/dist/components/embed.d.ts +45 -0
  127. package/dist/components/embed.js +85 -0
  128. package/dist/components/endpoint.d.ts +58 -0
  129. package/dist/components/endpoint.js +100 -0
  130. package/dist/components/errormessage.d.ts +11 -0
  131. package/dist/components/errormessage.js +10 -0
  132. package/dist/components/expandcode.d.ts +13 -0
  133. package/dist/components/expandcode.js +58 -0
  134. package/dist/components/feature.d.ts +31 -0
  135. package/dist/components/feature.js +58 -0
  136. package/dist/components/featuregrid.d.ts +17 -0
  137. package/dist/components/featuregrid.js +36 -0
  138. package/dist/components/feedback.d.ts +14 -0
  139. package/dist/components/feedback.js +62 -0
  140. package/dist/components/feedbackwidget.d.ts +14 -0
  141. package/dist/components/feedbackwidget.js +106 -0
  142. package/dist/components/files.d.ts +21 -0
  143. package/dist/components/files.js +133 -0
  144. package/dist/components/folder.d.ts +15 -0
  145. package/dist/components/folder.js +102 -0
  146. package/dist/components/footer.d.ts +16 -0
  147. package/dist/components/footer.js +28 -0
  148. package/dist/components/formlabel.d.ts +24 -0
  149. package/dist/components/formlabel.js +27 -0
  150. package/dist/components/github.d.ts +14 -0
  151. package/dist/components/github.js +99 -0
  152. package/dist/components/graph.d.ts +36 -0
  153. package/dist/components/graph.js +210 -0
  154. package/dist/components/heading.d.ts +25 -0
  155. package/dist/components/heading.js +82 -0
  156. package/dist/components/headingcopy.d.ts +3 -0
  157. package/dist/components/headingcopy.js +31 -0
  158. package/dist/components/hero.d.ts +16 -0
  159. package/dist/components/hero.js +28 -0
  160. package/dist/components/highlight.d.ts +41 -0
  161. package/dist/components/highlight.js +42 -0
  162. package/dist/components/hover.d.ts +23 -0
  163. package/dist/components/hover.js +79 -0
  164. package/dist/components/icons.d.ts +30 -0
  165. package/dist/components/icons.js +419 -0
  166. package/dist/components/inlinetoc.d.ts +19 -0
  167. package/dist/components/inlinetoc.js +28 -0
  168. package/dist/components/input.d.ts +25 -0
  169. package/dist/components/input.js +42 -0
  170. package/dist/components/install.d.ts +10 -0
  171. package/dist/components/install.js +149 -0
  172. package/dist/components/kbd.d.ts +22 -0
  173. package/dist/components/kbd.js +30 -0
  174. package/dist/components/langicon.d.ts +8 -0
  175. package/dist/components/langicon.js +48 -0
  176. package/dist/components/language.d.ts +17 -0
  177. package/dist/components/language.js +123 -0
  178. package/dist/components/lastupdated.d.ts +12 -0
  179. package/dist/components/lastupdated.js +44 -0
  180. package/dist/components/link.d.ts +14 -0
  181. package/dist/components/link.js +53 -0
  182. package/dist/components/linkcard.d.ts +33 -0
  183. package/dist/components/linkcard.js +50 -0
  184. package/dist/components/list.d.ts +50 -0
  185. package/dist/components/list.js +55 -0
  186. package/dist/components/math.d.ts +34 -0
  187. package/dist/components/math.js +63 -0
  188. package/dist/components/mermaid.d.ts +19 -0
  189. package/dist/components/mermaid.js +79 -0
  190. package/dist/components/mobilenav.d.ts +17 -0
  191. package/dist/components/mobilenav.js +263 -0
  192. package/dist/components/modal.d.ts +18 -0
  193. package/dist/components/modal.js +69 -0
  194. package/dist/components/navbar.d.ts +19 -0
  195. package/dist/components/navbar.js +45 -0
  196. package/dist/components/navlink.d.ts +14 -0
  197. package/dist/components/navlink.js +77 -0
  198. package/dist/components/note.d.ts +28 -0
  199. package/dist/components/note.js +60 -0
  200. package/dist/components/openapi.d.ts +14 -0
  201. package/dist/components/openapi.js +145 -0
  202. package/dist/components/openapischema.d.ts +13 -0
  203. package/dist/components/openapischema.js +51 -0
  204. package/dist/components/openapitags.d.ts +13 -0
  205. package/dist/components/openapitags.js +20 -0
  206. package/dist/components/pagetransition.d.ts +13 -0
  207. package/dist/components/pagetransition.js +37 -0
  208. package/dist/components/pagination.d.ts +26 -0
  209. package/dist/components/pagination.js +68 -0
  210. package/dist/components/panel.d.ts +25 -0
  211. package/dist/components/panel.js +75 -0
  212. package/dist/components/playground.d.ts +14 -0
  213. package/dist/components/playground.js +89 -0
  214. package/dist/components/popover.d.ts +18 -0
  215. package/dist/components/popover.js +109 -0
  216. package/dist/components/prelink.d.ts +10 -0
  217. package/dist/components/prelink.js +46 -0
  218. package/dist/components/prevnext.d.ts +17 -0
  219. package/dist/components/prevnext.js +43 -0
  220. package/dist/components/progress.d.ts +30 -0
  221. package/dist/components/progress.js +74 -0
  222. package/dist/components/property.d.ts +24 -0
  223. package/dist/components/property.js +44 -0
  224. package/dist/components/quote.d.ts +44 -0
  225. package/dist/components/quote.js +41 -0
  226. package/dist/components/radio.d.ts +48 -0
  227. package/dist/components/radio.js +140 -0
  228. package/dist/components/rating.d.ts +22 -0
  229. package/dist/components/rating.js +100 -0
  230. package/dist/components/readtime.d.ts +17 -0
  231. package/dist/components/readtime.js +26 -0
  232. package/dist/components/recent.d.ts +12 -0
  233. package/dist/components/recent.js +23 -0
  234. package/dist/components/responsive.d.ts +35 -0
  235. package/dist/components/responsive.js +73 -0
  236. package/dist/components/results.d.ts +20 -0
  237. package/dist/components/results.js +72 -0
  238. package/dist/components/screenshot.d.ts +33 -0
  239. package/dist/components/screenshot.js +52 -0
  240. package/dist/components/scrollprogress.d.ts +12 -0
  241. package/dist/components/scrollprogress.js +56 -0
  242. package/dist/components/scrollspy.d.ts +18 -0
  243. package/dist/components/scrollspy.js +51 -0
  244. package/dist/components/search.d.ts +19 -0
  245. package/dist/components/search.js +228 -0
  246. package/dist/components/searchbutton.d.ts +10 -0
  247. package/dist/components/searchbutton.js +51 -0
  248. package/dist/components/searchdialog.d.ts +19 -0
  249. package/dist/components/searchdialog.js +108 -0
  250. package/dist/components/searcher.d.ts +12 -0
  251. package/dist/components/searcher.js +121 -0
  252. package/dist/components/select.d.ts +39 -0
  253. package/dist/components/select.js +162 -0
  254. package/dist/components/shortcuts.d.ts +17 -0
  255. package/dist/components/shortcuts.js +62 -0
  256. package/dist/components/sidebar.d.ts +35 -0
  257. package/dist/components/sidebar.js +215 -0
  258. package/dist/components/sidebarfilter.d.ts +13 -0
  259. package/dist/components/sidebarfilter.js +50 -0
  260. package/dist/components/skeleton.d.ts +40 -0
  261. package/dist/components/skeleton.js +59 -0
  262. package/dist/components/skiplink.d.ts +12 -0
  263. package/dist/components/skiplink.js +21 -0
  264. package/dist/components/spinner.d.ts +34 -0
  265. package/dist/components/spinner.js +56 -0
  266. package/dist/components/status.d.ts +27 -0
  267. package/dist/components/status.js +63 -0
  268. package/dist/components/steps.d.ts +30 -0
  269. package/dist/components/steps.js +15 -0
  270. package/dist/components/switch.d.ts +26 -0
  271. package/dist/components/switch.js +79 -0
  272. package/dist/components/table.d.ts +36 -0
  273. package/dist/components/table.js +138 -0
  274. package/dist/components/tabnav.d.ts +30 -0
  275. package/dist/components/tabnav.js +199 -0
  276. package/dist/components/tabs.d.ts +15 -0
  277. package/dist/components/tabs.js +96 -0
  278. package/dist/components/tag.d.ts +32 -0
  279. package/dist/components/tag.js +38 -0
  280. package/dist/components/terminal.d.ts +48 -0
  281. package/dist/components/terminal.js +62 -0
  282. package/dist/components/textarea.d.ts +30 -0
  283. package/dist/components/textarea.js +100 -0
  284. package/dist/components/theme.d.ts +11 -0
  285. package/dist/components/theme.js +66 -0
  286. package/dist/components/themeprovider.d.ts +19 -0
  287. package/dist/components/themeprovider.js +58 -0
  288. package/dist/components/toast.d.ts +31 -0
  289. package/dist/components/toast.js +107 -0
  290. package/dist/components/toc/default.d.ts +21 -0
  291. package/dist/components/toc/default.js +100 -0
  292. package/dist/components/toc/hook.d.ts +13 -0
  293. package/dist/components/toc/hook.js +125 -0
  294. package/dist/components/toc/index.d.ts +15 -0
  295. package/dist/components/toc/index.js +44 -0
  296. package/dist/components/toc/inline.d.ts +20 -0
  297. package/dist/components/toc/inline.js +75 -0
  298. package/dist/components/toc/minimal.d.ts +22 -0
  299. package/dist/components/toc/minimal.js +136 -0
  300. package/dist/components/toc/zigzag.d.ts +18 -0
  301. package/dist/components/toc/zigzag.js +57 -0
  302. package/dist/components/tocprogress.d.ts +17 -0
  303. package/dist/components/tocprogress.js +67 -0
  304. package/dist/components/tooltip.d.ts +19 -0
  305. package/dist/components/tooltip.js +76 -0
  306. package/dist/components/trigger.d.ts +8 -0
  307. package/dist/components/trigger.js +13 -0
  308. package/dist/components/twoslash.d.ts +9 -0
  309. package/dist/components/twoslash.js +52 -0
  310. package/dist/components/typetable.d.ts +21 -0
  311. package/dist/components/typetable.js +68 -0
  312. package/dist/components/typewriter.d.ts +20 -0
  313. package/dist/components/typewriter.js +50 -0
  314. package/dist/components/version.d.ts +29 -0
  315. package/dist/components/version.js +181 -0
  316. package/dist/components/video.d.ts +33 -0
  317. package/dist/components/video.js +147 -0
  318. package/dist/components/zoom.d.ts +9 -0
  319. package/dist/components/zoom.js +110 -0
  320. package/dist/config.d.ts +54 -0
  321. package/dist/config.js +102 -0
  322. package/dist/content.d.ts +83 -0
  323. package/dist/content.js +464 -0
  324. package/dist/contentcache.d.ts +28 -0
  325. package/dist/contentcache.js +76 -0
  326. package/dist/contentdiff.d.ts +19 -0
  327. package/dist/contentdiff.js +48 -0
  328. package/dist/contributors.d.ts +22 -0
  329. package/dist/contributors.js +64 -0
  330. package/dist/diff.d.ts +25 -0
  331. package/dist/diff.js +117 -0
  332. package/dist/draft.d.ts +33 -0
  333. package/dist/draft.js +62 -0
  334. package/dist/env.d.ts +12 -0
  335. package/dist/env.js +50 -0
  336. package/dist/export.d.ts +9 -0
  337. package/dist/export.js +32 -0
  338. package/dist/frontmatter.d.ts +19 -0
  339. package/dist/frontmatter.js +65 -0
  340. package/dist/github.d.ts +15 -0
  341. package/dist/github.js +254 -0
  342. package/dist/gitsource.d.ts +23 -0
  343. package/dist/gitsource.js +50 -0
  344. package/dist/hash.d.ts +21 -0
  345. package/dist/hash.js +65 -0
  346. package/dist/highlight.d.ts +18 -0
  347. package/dist/highlight.js +90 -0
  348. package/dist/hooks/anchor.d.ts +7 -0
  349. package/dist/hooks/anchor.js +44 -0
  350. package/dist/hooks/arrownav.d.ts +11 -0
  351. package/dist/hooks/arrownav.js +49 -0
  352. package/dist/hooks/async.d.ts +9 -0
  353. package/dist/hooks/async.js +28 -0
  354. package/dist/hooks/battery.d.ts +8 -0
  355. package/dist/hooks/battery.js +34 -0
  356. package/dist/hooks/breakpoint.d.ts +6 -0
  357. package/dist/hooks/breakpoint.js +34 -0
  358. package/dist/hooks/clickoutside.d.ts +11 -0
  359. package/dist/hooks/clickoutside.js +19 -0
  360. package/dist/hooks/clipboard-paste.d.ts +8 -0
  361. package/dist/hooks/clipboard-paste.js +18 -0
  362. package/dist/hooks/clipboard.d.ts +9 -0
  363. package/dist/hooks/clipboard.js +24 -0
  364. package/dist/hooks/colorscheme.d.ts +4 -0
  365. package/dist/hooks/colorscheme.js +18 -0
  366. package/dist/hooks/copy.d.ts +12 -0
  367. package/dist/hooks/copy.js +28 -0
  368. package/dist/hooks/countdown.d.ts +10 -0
  369. package/dist/hooks/countdown.js +41 -0
  370. package/dist/hooks/counter.d.ts +10 -0
  371. package/dist/hooks/counter.js +12 -0
  372. package/dist/hooks/debounce.d.ts +9 -0
  373. package/dist/hooks/debounce.js +16 -0
  374. package/dist/hooks/documenttitle.d.ts +3 -0
  375. package/dist/hooks/documenttitle.js +20 -0
  376. package/dist/hooks/documentvisibility.d.ts +4 -0
  377. package/dist/hooks/documentvisibility.js +19 -0
  378. package/dist/hooks/escapekey.d.ts +8 -0
  379. package/dist/hooks/escapekey.js +18 -0
  380. package/dist/hooks/eventlistener.d.ts +13 -0
  381. package/dist/hooks/eventlistener.js +15 -0
  382. package/dist/hooks/eventsource.d.ts +10 -0
  383. package/dist/hooks/eventsource.js +31 -0
  384. package/dist/hooks/eyedropper.d.ts +8 -0
  385. package/dist/hooks/eyedropper.js +23 -0
  386. package/dist/hooks/favicon.d.ts +3 -0
  387. package/dist/hooks/favicon.js +14 -0
  388. package/dist/hooks/fetch.d.ts +8 -0
  389. package/dist/hooks/fetch.js +29 -0
  390. package/dist/hooks/focustrap.d.ts +12 -0
  391. package/dist/hooks/focustrap.js +62 -0
  392. package/dist/hooks/focuswithin.d.ts +6 -0
  393. package/dist/hooks/focuswithin.js +24 -0
  394. package/dist/hooks/form.d.ts +20 -0
  395. package/dist/hooks/form.js +42 -0
  396. package/dist/hooks/fullscreen.d.ts +10 -0
  397. package/dist/hooks/fullscreen.js +34 -0
  398. package/dist/hooks/geolocation.d.ts +10 -0
  399. package/dist/hooks/geolocation.js +38 -0
  400. package/dist/hooks/hash.d.ts +3 -0
  401. package/dist/hooks/hash.js +21 -0
  402. package/dist/hooks/hotkeys.d.ts +11 -0
  403. package/dist/hooks/hotkeys.js +35 -0
  404. package/dist/hooks/hover.d.ts +3 -0
  405. package/dist/hooks/hover.js +22 -0
  406. package/dist/hooks/idle.d.ts +3 -0
  407. package/dist/hooks/idle.js +28 -0
  408. package/dist/hooks/infinitescroll.d.ts +9 -0
  409. package/dist/hooks/infinitescroll.js +31 -0
  410. package/dist/hooks/interval.d.ts +3 -0
  411. package/dist/hooks/interval.js +16 -0
  412. package/dist/hooks/inview.d.ts +10 -0
  413. package/dist/hooks/inview.js +28 -0
  414. package/dist/hooks/keyboard.d.ts +14 -0
  415. package/dist/hooks/keyboard.js +82 -0
  416. package/dist/hooks/keypress.d.ts +3 -0
  417. package/dist/hooks/keypress.js +23 -0
  418. package/dist/hooks/list.d.ts +14 -0
  419. package/dist/hooks/list.js +28 -0
  420. package/dist/hooks/longpress.d.ts +10 -0
  421. package/dist/hooks/longpress.js +24 -0
  422. package/dist/hooks/map.d.ts +12 -0
  423. package/dist/hooks/map.js +23 -0
  424. package/dist/hooks/measure.d.ts +16 -0
  425. package/dist/hooks/measure.js +34 -0
  426. package/dist/hooks/media.d.ts +33 -0
  427. package/dist/hooks/media.js +35 -0
  428. package/dist/hooks/mediarecorder.d.ts +11 -0
  429. package/dist/hooks/mediarecorder.js +37 -0
  430. package/dist/hooks/mounted.d.ts +3 -0
  431. package/dist/hooks/mounted.js +12 -0
  432. package/dist/hooks/mouseposition.d.ts +7 -0
  433. package/dist/hooks/mouseposition.js +16 -0
  434. package/dist/hooks/networkstate.d.ts +10 -0
  435. package/dist/hooks/networkstate.js +34 -0
  436. package/dist/hooks/online.d.ts +3 -0
  437. package/dist/hooks/online.js +20 -0
  438. package/dist/hooks/orientation.d.ts +8 -0
  439. package/dist/hooks/orientation.js +20 -0
  440. package/dist/hooks/os.d.ts +4 -0
  441. package/dist/hooks/os.js +15 -0
  442. package/dist/hooks/pageleave.d.ts +3 -0
  443. package/dist/hooks/pageleave.js +18 -0
  444. package/dist/hooks/pagination.d.ts +26 -0
  445. package/dist/hooks/pagination.js +49 -0
  446. package/dist/hooks/permission.d.ts +5 -0
  447. package/dist/hooks/permission.js +29 -0
  448. package/dist/hooks/preferredlanguage.d.ts +3 -0
  449. package/dist/hooks/preferredlanguage.js +17 -0
  450. package/dist/hooks/previous.d.ts +3 -0
  451. package/dist/hooks/previous.js +12 -0
  452. package/dist/hooks/queue.d.ts +11 -0
  453. package/dist/hooks/queue.js +23 -0
  454. package/dist/hooks/readprogress.d.ts +6 -0
  455. package/dist/hooks/readprogress.js +32 -0
  456. package/dist/hooks/resizeobserver.d.ts +10 -0
  457. package/dist/hooks/resizeobserver.js +25 -0
  458. package/dist/hooks/script.d.ts +4 -0
  459. package/dist/hooks/script.js +30 -0
  460. package/dist/hooks/scrolldirection.d.ts +4 -0
  461. package/dist/hooks/scrolldirection.js +33 -0
  462. package/dist/hooks/scrolllock.d.ts +3 -0
  463. package/dist/hooks/scrolllock.js +38 -0
  464. package/dist/hooks/scrollspy.d.ts +7 -0
  465. package/dist/hooks/scrollspy.js +28 -0
  466. package/dist/hooks/scrolltop.d.ts +7 -0
  467. package/dist/hooks/scrolltop.js +19 -0
  468. package/dist/hooks/selection.d.ts +12 -0
  469. package/dist/hooks/selection.js +32 -0
  470. package/dist/hooks/share.d.ts +13 -0
  471. package/dist/hooks/share.js +37 -0
  472. package/dist/hooks/speechrecognition.d.ts +10 -0
  473. package/dist/hooks/speechrecognition.js +34 -0
  474. package/dist/hooks/stepper.d.ts +13 -0
  475. package/dist/hooks/stepper.js +31 -0
  476. package/dist/hooks/storage.d.ts +5 -0
  477. package/dist/hooks/storage.js +57 -0
  478. package/dist/hooks/stylesheet.d.ts +4 -0
  479. package/dist/hooks/stylesheet.js +30 -0
  480. package/dist/hooks/textselection.d.ts +7 -0
  481. package/dist/hooks/textselection.js +24 -0
  482. package/dist/hooks/throttle.d.ts +3 -0
  483. package/dist/hooks/throttle.js +28 -0
  484. package/dist/hooks/toggle.d.ts +13 -0
  485. package/dist/hooks/toggle.js +10 -0
  486. package/dist/hooks/undoredo.d.ts +12 -0
  487. package/dist/hooks/undoredo.js +50 -0
  488. package/dist/hooks/vibrate.d.ts +7 -0
  489. package/dist/hooks/vibrate.js +15 -0
  490. package/dist/hooks/viewtransition.d.ts +9 -0
  491. package/dist/hooks/viewtransition.js +38 -0
  492. package/dist/hooks/wakelock.d.ts +9 -0
  493. package/dist/hooks/wakelock.js +32 -0
  494. package/dist/hooks/websocket.d.ts +10 -0
  495. package/dist/hooks/websocket.js +30 -0
  496. package/dist/hooks/windowsize.d.ts +7 -0
  497. package/dist/hooks/windowsize.js +17 -0
  498. package/dist/i18n.d.ts +30 -0
  499. package/dist/i18n.js +73 -0
  500. package/dist/index.d.ts +115 -0
  501. package/dist/index.js +107 -0
  502. package/dist/lastmodified.d.ts +4 -0
  503. package/dist/lastmodified.js +24 -0
  504. package/dist/linkcheck.d.ts +26 -0
  505. package/dist/linkcheck.js +113 -0
  506. package/dist/llms.d.ts +14 -0
  507. package/dist/llms.js +39 -0
  508. package/dist/manifest.d.ts +24 -0
  509. package/dist/manifest.js +31 -0
  510. package/dist/mcp.d.ts +56 -0
  511. package/dist/mcp.js +74 -0
  512. package/dist/mdtoc.d.ts +16 -0
  513. package/dist/mdtoc.js +59 -0
  514. package/dist/mdxscope.d.ts +17 -0
  515. package/dist/mdxscope.js +58 -0
  516. package/dist/meta.d.ts +19 -0
  517. package/dist/meta.js +71 -0
  518. package/dist/migrate.d.ts +17 -0
  519. package/dist/migrate.js +108 -0
  520. package/dist/navgen.d.ts +31 -0
  521. package/dist/navgen.js +147 -0
  522. package/dist/navtree.d.ts +28 -0
  523. package/dist/navtree.js +93 -0
  524. package/dist/next.d.ts +3 -0
  525. package/dist/next.js +3 -0
  526. package/dist/oembed.d.ts +20 -0
  527. package/dist/oembed.js +62 -0
  528. package/dist/ogimage.d.ts +45 -0
  529. package/dist/ogimage.js +62 -0
  530. package/dist/openapi.d.ts +6 -0
  531. package/dist/openapi.js +141 -0
  532. package/dist/openapiguard.d.ts +22 -0
  533. package/dist/openapiguard.js +87 -0
  534. package/dist/openapiutil.d.ts +72 -0
  535. package/dist/openapiutil.js +61 -0
  536. package/dist/orama.d.ts +16 -0
  537. package/dist/orama.js +100 -0
  538. package/dist/pipeline.d.ts +19 -0
  539. package/dist/pipeline.js +40 -0
  540. package/dist/preload.d.ts +15 -0
  541. package/dist/preload.js +19 -0
  542. package/dist/ranking.d.ts +28 -0
  543. package/dist/ranking.js +95 -0
  544. package/dist/reactrouter.d.ts +3 -0
  545. package/dist/reactrouter.js +3 -0
  546. package/dist/readtime.d.ts +3 -0
  547. package/dist/readtime.js +8 -0
  548. package/dist/redirects.d.ts +27 -0
  549. package/dist/redirects.js +74 -0
  550. package/dist/rehype.d.ts +5 -0
  551. package/dist/rehype.js +30 -0
  552. package/dist/rehypeautolink.d.ts +11 -0
  553. package/dist/rehypeautolink.js +43 -0
  554. package/dist/rehypecode.d.ts +6 -0
  555. package/dist/rehypecode.js +68 -0
  556. package/dist/rehypecopy.d.ts +6 -0
  557. package/dist/rehypecopy.js +29 -0
  558. package/dist/rehypeinline.d.ts +6 -0
  559. package/dist/rehypeinline.js +32 -0
  560. package/dist/rehypelinks.d.ts +10 -0
  561. package/dist/rehypelinks.js +49 -0
  562. package/dist/rehyperaw.d.ts +6 -0
  563. package/dist/rehyperaw.js +27 -0
  564. package/dist/rehypeslug.d.ts +7 -0
  565. package/dist/rehypeslug.js +39 -0
  566. package/dist/rehypetablewrap.d.ts +9 -0
  567. package/dist/rehypetablewrap.js +24 -0
  568. package/dist/rehypetoc.d.ts +16 -0
  569. package/dist/rehypetoc.js +61 -0
  570. package/dist/remark.d.ts +6 -0
  571. package/dist/remark.js +48 -0
  572. package/dist/remarkadmonition.d.ts +6 -0
  573. package/dist/remarkadmonition.js +78 -0
  574. package/dist/remarkannotation.d.ts +10 -0
  575. package/dist/remarkannotation.js +65 -0
  576. package/dist/remarkbadge.d.ts +6 -0
  577. package/dist/remarkbadge.js +40 -0
  578. package/dist/remarkblockmath.d.ts +6 -0
  579. package/dist/remarkblockmath.js +57 -0
  580. package/dist/remarkcallout.d.ts +6 -0
  581. package/dist/remarkcallout.js +65 -0
  582. package/dist/remarkcaption.d.ts +6 -0
  583. package/dist/remarkcaption.js +48 -0
  584. package/dist/remarkcodetitle.d.ts +6 -0
  585. package/dist/remarkcodetitle.js +39 -0
  586. package/dist/remarkcolumns.d.ts +6 -0
  587. package/dist/remarkcolumns.js +67 -0
  588. package/dist/remarkdetails.d.ts +6 -0
  589. package/dist/remarkdetails.js +61 -0
  590. package/dist/remarkdirective.d.ts +7 -0
  591. package/dist/remarkdirective.js +98 -0
  592. package/dist/remarkembed.d.ts +6 -0
  593. package/dist/remarkembed.js +72 -0
  594. package/dist/remarkfiletree.d.ts +6 -0
  595. package/dist/remarkfiletree.js +67 -0
  596. package/dist/remarkfootnote.d.ts +6 -0
  597. package/dist/remarkfootnote.js +63 -0
  598. package/dist/remarkgfm.d.ts +6 -0
  599. package/dist/remarkgfm.js +60 -0
  600. package/dist/remarkheadingid.d.ts +6 -0
  601. package/dist/remarkheadingid.js +40 -0
  602. package/dist/remarkimage.d.ts +11 -0
  603. package/dist/remarkimage.js +91 -0
  604. package/dist/remarkinclude.d.ts +10 -0
  605. package/dist/remarkinclude.js +49 -0
  606. package/dist/remarkinstall.d.ts +6 -0
  607. package/dist/remarkinstall.js +52 -0
  608. package/dist/remarklinkcard.d.ts +6 -0
  609. package/dist/remarklinkcard.js +38 -0
  610. package/dist/remarkmath.d.ts +6 -0
  611. package/dist/remarkmath.js +69 -0
  612. package/dist/remarkmermaid.d.ts +6 -0
  613. package/dist/remarkmermaid.js +21 -0
  614. package/dist/remarkmeta.d.ts +15 -0
  615. package/dist/remarkmeta.js +63 -0
  616. package/dist/remarkreadingtime.d.ts +11 -0
  617. package/dist/remarkreadingtime.js +44 -0
  618. package/dist/remarksteps.d.ts +6 -0
  619. package/dist/remarksteps.js +56 -0
  620. package/dist/remarkstructure.d.ts +18 -0
  621. package/dist/remarkstructure.js +53 -0
  622. package/dist/remarktabs.d.ts +6 -0
  623. package/dist/remarktabs.js +42 -0
  624. package/dist/remarktoc.d.ts +6 -0
  625. package/dist/remarktoc.js +47 -0
  626. package/dist/remarkts2js.d.ts +6 -0
  627. package/dist/remarkts2js.js +88 -0
  628. package/dist/remarktwoslash.d.ts +20 -0
  629. package/dist/remarktwoslash.js +86 -0
  630. package/dist/remarkvideo.d.ts +16 -0
  631. package/dist/remarkvideo.js +59 -0
  632. package/dist/remix.d.ts +3 -0
  633. package/dist/remix.js +3 -0
  634. package/dist/schema.d.ts +54 -0
  635. package/dist/schema.js +17 -0
  636. package/dist/search.d.ts +24 -0
  637. package/dist/search.js +155 -0
  638. package/dist/searchindex.d.ts +28 -0
  639. package/dist/searchindex.js +184 -0
  640. package/dist/searchpolicy.d.ts +5 -0
  641. package/dist/searchpolicy.js +9 -0
  642. package/dist/searchscore.d.ts +30 -0
  643. package/dist/searchscore.js +54 -0
  644. package/dist/searchtypo.d.ts +3 -0
  645. package/dist/searchtypo.js +47 -0
  646. package/dist/seo.d.ts +26 -0
  647. package/dist/seo.js +69 -0
  648. package/dist/shortcodes.d.ts +13 -0
  649. package/dist/shortcodes.js +61 -0
  650. package/dist/sitemap.d.ts +25 -0
  651. package/dist/sitemap.js +69 -0
  652. package/dist/snippets.d.ts +18 -0
  653. package/dist/snippets.js +89 -0
  654. package/dist/source.d.ts +23 -0
  655. package/dist/source.js +188 -0
  656. package/dist/stats.d.ts +25 -0
  657. package/dist/stats.js +81 -0
  658. package/dist/tanstack.d.ts +3 -0
  659. package/dist/tanstack.js +3 -0
  660. package/dist/testing.d.ts +35 -0
  661. package/dist/testing.js +134 -0
  662. package/dist/themeutil.d.ts +31 -0
  663. package/dist/themeutil.js +92 -0
  664. package/dist/typegen.d.ts +10 -0
  665. package/dist/typegen.js +74 -0
  666. package/dist/types.d.ts +267 -0
  667. package/dist/types.js +1 -0
  668. package/dist/validate.d.ts +13 -0
  669. package/dist/validate.js +78 -0
  670. package/dist/validator.d.ts +35 -0
  671. package/dist/validator.js +53 -0
  672. package/dist/versioning.d.ts +32 -0
  673. package/dist/versioning.js +62 -0
  674. package/dist/vite.d.ts +3 -0
  675. package/dist/vite.js +3 -0
  676. package/dist/watcher.d.ts +19 -0
  677. package/dist/watcher.js +82 -0
  678. package/dist/webhook.d.ts +25 -0
  679. package/dist/webhook.js +67 -0
  680. package/dist/workspace.d.ts +26 -0
  681. package/dist/workspace.js +81 -0
  682. package/package.json +138 -11
  683. package/styles/reset.css +3 -0
  684. package/index.js +0 -3
@@ -0,0 +1,100 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import { memo, forwardRef, useId, useRef, useState, useCallback, useEffect } from 'react';
4
+ import { ErrorMessage } from './errormessage';
5
+ import { FormLabel } from './formlabel';
6
+
7
+ const variants = {
8
+ default: "border-line bg-surface text-fg placeholder:text-muted focus:border-accent",
9
+ error: "border-red-500/50 bg-red-500/5 text-fg placeholder:text-muted focus:border-red-500"
10
+ };
11
+ const sizes = {
12
+ sm: "px-2.5 py-1.5 text-xs min-h-[60px]",
13
+ md: "px-3 py-2 text-sm min-h-[80px]",
14
+ lg: "px-4 py-3 text-base min-h-[100px]"
15
+ };
16
+ const Textarea = memo(forwardRef(function Textarea2({
17
+ variant = "default",
18
+ size = "md",
19
+ label,
20
+ error,
21
+ hint,
22
+ autoresize = false,
23
+ showCount = false,
24
+ tooltip,
25
+ maxLength,
26
+ className = "",
27
+ id,
28
+ value,
29
+ defaultValue,
30
+ onChange,
31
+ ...props
32
+ }, ref) {
33
+ const generatedId = useId();
34
+ const textareaId = id || generatedId;
35
+ const errorId = error ? `${textareaId}-error` : void 0;
36
+ const hintId = hint && !error ? `${textareaId}-hint` : void 0;
37
+ const countId = showCount ? `${textareaId}-count` : void 0;
38
+ const describedBy = [errorId, hintId, countId].filter(Boolean).join(" ") || void 0;
39
+ const actualVariant = error ? "error" : variant;
40
+ const internalRef = useRef(null);
41
+ const [charCount, setCharCount] = useState(() => {
42
+ const initial = value ?? defaultValue ?? "";
43
+ return typeof initial === "string" ? initial.length : 0;
44
+ });
45
+ const resize = useCallback(() => {
46
+ const textarea = internalRef.current;
47
+ if (!textarea || !autoresize) return;
48
+ textarea.style.height = "auto";
49
+ textarea.style.height = `${textarea.scrollHeight}px`;
50
+ }, [autoresize]);
51
+ useEffect(() => {
52
+ resize();
53
+ }, [resize, value]);
54
+ const handleChange = (e) => {
55
+ setCharCount(e.target.value.length);
56
+ if (autoresize) resize();
57
+ onChange?.(e);
58
+ };
59
+ const setRefs = useCallback(
60
+ (node) => {
61
+ internalRef.current = node;
62
+ if (typeof ref === "function") {
63
+ ref(node);
64
+ } else if (ref) {
65
+ ref.current = node;
66
+ }
67
+ },
68
+ [ref]
69
+ );
70
+ return /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-1.5", children: [
71
+ label && /* @__PURE__ */ jsx(FormLabel, { label, tooltip, htmlFor: textareaId }),
72
+ /* @__PURE__ */ jsx(
73
+ "textarea",
74
+ {
75
+ ref: setRefs,
76
+ id: textareaId,
77
+ "aria-invalid": actualVariant === "error" ? true : void 0,
78
+ "aria-describedby": describedBy,
79
+ maxLength,
80
+ value,
81
+ defaultValue,
82
+ onChange: handleChange,
83
+ className: `rounded-md border outline-none transition-colors resize-vertical ${variants[actualVariant]} ${sizes[size]} ${autoresize ? "resize-none overflow-hidden" : ""} ${className}`.trim(),
84
+ ...props
85
+ }
86
+ ),
87
+ /* @__PURE__ */ jsxs("div", { className: "flex justify-between gap-2", children: [
88
+ /* @__PURE__ */ jsxs("div", { className: "flex-1", children: [
89
+ error && /* @__PURE__ */ jsx(ErrorMessage, { id: errorId, children: error }),
90
+ hint && !error && /* @__PURE__ */ jsx("span", { id: hintId, className: "text-xs text-muted", children: hint })
91
+ ] }),
92
+ showCount && /* @__PURE__ */ jsxs("span", { id: countId, className: "text-xs text-muted", "aria-live": "polite", children: [
93
+ charCount,
94
+ maxLength ? `/${maxLength}` : ""
95
+ ] })
96
+ ] })
97
+ ] });
98
+ }));
99
+
100
+ export { Textarea };
@@ -0,0 +1,11 @@
1
+ import * as react from 'react';
2
+ import { JSX } from 'react';
3
+
4
+ type Theme = "light" | "dark" | "system";
5
+ interface ThemeToggleProps {
6
+ defaultTheme?: Theme;
7
+ }
8
+ declare function ThemeToggleBase({ defaultTheme }: ThemeToggleProps): JSX.Element;
9
+ declare const ThemeToggle: react.MemoExoticComponent<typeof ThemeToggleBase>;
10
+
11
+ export { type Theme, ThemeToggle, type ThemeToggleProps };
@@ -0,0 +1,66 @@
1
+ "use client";
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { memo, useState, useEffect, useCallback } from 'react';
4
+
5
+ function istheme(value) {
6
+ return value === "light" || value === "dark" || value === "system";
7
+ }
8
+ function resolves(theme) {
9
+ if (theme === "system") {
10
+ return window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light";
11
+ }
12
+ return theme;
13
+ }
14
+ function ThemeToggleBase({ defaultTheme = "dark" }) {
15
+ const [theme, setTheme] = useState(null);
16
+ const [resolved, setResolved] = useState(null);
17
+ useEffect(() => {
18
+ const raw = localStorage.getItem("theme");
19
+ const initial = istheme(raw) ? raw : defaultTheme;
20
+ setTheme(initial);
21
+ setResolved(resolves(initial));
22
+ }, [defaultTheme]);
23
+ useEffect(() => {
24
+ if (!theme) return;
25
+ const apply = () => {
26
+ const r = resolves(theme);
27
+ setResolved(r);
28
+ document.documentElement.classList.toggle("dark", r === "dark");
29
+ };
30
+ apply();
31
+ localStorage.setItem("theme", theme);
32
+ if (theme === "system") {
33
+ const media = window.matchMedia("(prefers-color-scheme: dark)");
34
+ media.addEventListener("change", apply);
35
+ return () => media.removeEventListener("change", apply);
36
+ }
37
+ }, [theme]);
38
+ const toggle = useCallback(() => {
39
+ setTheme((t) => t === "dark" ? "light" : "dark");
40
+ }, []);
41
+ if (!resolved) {
42
+ return /* @__PURE__ */ jsx(
43
+ "button",
44
+ {
45
+ type: "button",
46
+ className: "p-2 text-muted hover:text-fg transition-colors",
47
+ "aria-label": "toggle theme",
48
+ disabled: true,
49
+ children: /* @__PURE__ */ jsx("span", { className: "size-4 block" })
50
+ }
51
+ );
52
+ }
53
+ return /* @__PURE__ */ jsx(
54
+ "button",
55
+ {
56
+ type: "button",
57
+ onClick: toggle,
58
+ className: "p-2 text-muted hover:text-fg transition-colors",
59
+ "aria-label": `switch to ${resolved === "dark" ? "light" : "dark"} theme`,
60
+ children: resolved === "dark" ? /* @__PURE__ */ jsx("svg", { "aria-hidden": "true", viewBox: "0 0 16 16", fill: "currentColor", className: "size-4", children: /* @__PURE__ */ jsx("path", { d: "M8 12a4 4 0 100-8 4 4 0 000 8zM8 0a.75.75 0 01.75.75v1.5a.75.75 0 01-1.5 0V.75A.75.75 0 018 0zm0 13a.75.75 0 01.75.75v1.5a.75.75 0 01-1.5 0v-1.5A.75.75 0 018 13zM3.05 2.343a.75.75 0 011.06 0l1.061 1.061a.75.75 0 01-1.06 1.06L3.05 3.404a.75.75 0 010-1.06zm8.84 8.84a.75.75 0 011.06 0l1.06 1.06a.75.75 0 01-1.06 1.061l-1.06-1.06a.75.75 0 010-1.06zM16 8a.75.75 0 01-.75.75h-1.5a.75.75 0 010-1.5h1.5A.75.75 0 0116 8zM3 8a.75.75 0 01-.75.75H.75a.75.75 0 010-1.5h1.5A.75.75 0 013 8zm10.657-4.95a.75.75 0 010 1.061l-1.06 1.06a.75.75 0 11-1.061-1.06l1.06-1.06a.75.75 0 011.06 0zm-8.84 8.84a.75.75 0 010 1.06l-1.06 1.06a.75.75 0 11-1.061-1.06l1.06-1.06a.75.75 0 011.06 0z" }) }) : /* @__PURE__ */ jsx("svg", { "aria-hidden": "true", viewBox: "0 0 16 16", fill: "currentColor", className: "size-4", children: /* @__PURE__ */ jsx("path", { d: "M9.598 1.591a.75.75 0 01.785-.175 7 7 0 11-8.967 8.967.75.75 0 01.961-.96 5.5 5.5 0 007.046-7.046.75.75 0 01.175-.786zm1.616 1.945a7 7 0 01-7.678 7.678 5.5 5.5 0 107.678-7.678z" }) })
61
+ }
62
+ );
63
+ }
64
+ const ThemeToggle = memo(ThemeToggleBase);
65
+
66
+ export { ThemeToggle };
@@ -0,0 +1,19 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { ReactNode } from 'react';
3
+
4
+ type ThemeMode = "light" | "dark" | "system";
5
+ type ThemeContextValue = {
6
+ theme: ThemeMode;
7
+ resolved: "light" | "dark";
8
+ setTheme: (theme: ThemeMode) => void;
9
+ };
10
+ type ThemeProviderProps = {
11
+ children: ReactNode;
12
+ defaultTheme?: ThemeMode;
13
+ storageKey?: string;
14
+ attribute?: string;
15
+ };
16
+ declare function ThemeProvider({ children, defaultTheme, storageKey, attribute, }: ThemeProviderProps): react_jsx_runtime.JSX.Element;
17
+ declare function useTheme(): ThemeContextValue;
18
+
19
+ export { type ThemeContextValue, type ThemeMode, ThemeProvider, type ThemeProviderProps, useTheme };
@@ -0,0 +1,58 @@
1
+ "use client";
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { createContext, useState, useEffect, useMemo, useContext } from 'react';
4
+
5
+ const ThemeContext = createContext(null);
6
+ function istheme(value) {
7
+ return value === "light" || value === "dark" || value === "system";
8
+ }
9
+ function resolve(theme) {
10
+ if (theme === "system") {
11
+ return window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light";
12
+ }
13
+ return theme;
14
+ }
15
+ function ThemeProvider({
16
+ children,
17
+ defaultTheme = "system",
18
+ storageKey = "fromsrc-theme",
19
+ attribute = "data-theme"
20
+ }) {
21
+ const [theme, setTheme] = useState(() => {
22
+ if (typeof window === "undefined") return defaultTheme;
23
+ const stored = localStorage.getItem(storageKey);
24
+ return istheme(stored) ? stored : defaultTheme;
25
+ });
26
+ const [resolved, setResolved] = useState(() => {
27
+ if (typeof window === "undefined") return "light";
28
+ return resolve(theme);
29
+ });
30
+ useEffect(() => {
31
+ const r = resolve(theme);
32
+ setResolved(r);
33
+ document.documentElement.setAttribute(attribute, r);
34
+ document.documentElement.classList.toggle("dark", r === "dark");
35
+ localStorage.setItem(storageKey, theme);
36
+ }, [theme, attribute, storageKey]);
37
+ useEffect(() => {
38
+ if (theme !== "system") return;
39
+ const media = window.matchMedia("(prefers-color-scheme: dark)");
40
+ const handler = () => {
41
+ const r = resolve(theme);
42
+ setResolved(r);
43
+ document.documentElement.setAttribute(attribute, r);
44
+ document.documentElement.classList.toggle("dark", r === "dark");
45
+ };
46
+ media.addEventListener("change", handler);
47
+ return () => media.removeEventListener("change", handler);
48
+ }, [theme, attribute]);
49
+ const value = useMemo(() => ({ theme, resolved, setTheme }), [theme, resolved]);
50
+ return /* @__PURE__ */ jsx(ThemeContext.Provider, { value, children });
51
+ }
52
+ function useTheme() {
53
+ const context = useContext(ThemeContext);
54
+ if (!context) throw new Error("useTheme must be used within ThemeProvider");
55
+ return context;
56
+ }
57
+
58
+ export { ThemeProvider, useTheme };
@@ -0,0 +1,31 @@
1
+ import { ReactNode, JSX } from 'react';
2
+
3
+ /**
4
+ * Represents a single toast notification.
5
+ */
6
+ interface Toast {
7
+ id: string;
8
+ message: string;
9
+ type: "info" | "success" | "warning" | "error";
10
+ duration?: number;
11
+ }
12
+ /**
13
+ * Context value for managing toasts.
14
+ */
15
+ interface ToastContextValue {
16
+ toasts: Toast[];
17
+ add: (toast: Omit<Toast, "id">) => void;
18
+ remove: (id: string) => void;
19
+ }
20
+ /**
21
+ * Provider component for toast notifications.
22
+ */
23
+ declare function ToastProvider({ children }: {
24
+ children: ReactNode;
25
+ }): JSX.Element;
26
+ /**
27
+ * Hook to access toast context.
28
+ */
29
+ declare function useToast(): ToastContextValue;
30
+
31
+ export { type Toast, ToastProvider, useToast };
@@ -0,0 +1,107 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import { createContext, useState, useRef, useCallback, useEffect, useContext } from 'react';
4
+ import { IconXCircle, IconAlertCircle, IconCheckCircle, IconInfo, IconX } from './icons';
5
+
6
+ const ToastContext = createContext(null);
7
+ function ToastProvider({ children }) {
8
+ const [toasts, setToasts] = useState([]);
9
+ const timers = useRef(/* @__PURE__ */ new Map());
10
+ const counter = useRef(0);
11
+ const remove = useCallback((id) => {
12
+ const timer = timers.current.get(id);
13
+ if (timer) {
14
+ clearTimeout(timer);
15
+ timers.current.delete(id);
16
+ }
17
+ setToasts((t) => t.filter((x) => x.id !== id));
18
+ }, []);
19
+ const add = useCallback((toast) => {
20
+ counter.current += 1;
21
+ const id = `toast-${counter.current}`;
22
+ setToasts((t) => [...t, { ...toast, id }]);
23
+ const duration = toast.duration ?? 5e3;
24
+ const timer = setTimeout(() => {
25
+ timers.current.delete(id);
26
+ setToasts((t) => t.filter((x) => x.id !== id));
27
+ }, duration);
28
+ timers.current.set(id, timer);
29
+ }, []);
30
+ useEffect(() => {
31
+ return () => {
32
+ for (const timer of timers.current.values()) clearTimeout(timer);
33
+ timers.current.clear();
34
+ };
35
+ }, []);
36
+ return /* @__PURE__ */ jsxs(ToastContext.Provider, { value: { toasts, add, remove }, children: [
37
+ children,
38
+ /* @__PURE__ */ jsx(ToastContainer, {})
39
+ ] });
40
+ }
41
+ function useToast() {
42
+ const ctx = useContext(ToastContext);
43
+ if (!ctx) throw new Error("useToast must be used within ToastProvider");
44
+ return ctx;
45
+ }
46
+ const icons = {
47
+ info: IconInfo,
48
+ success: IconCheckCircle,
49
+ warning: IconAlertCircle,
50
+ error: IconXCircle
51
+ };
52
+ const styles = {
53
+ info: "border-blue-500/30 bg-blue-500/10",
54
+ success: "border-green-500/30 bg-green-500/10",
55
+ warning: "border-yellow-500/30 bg-yellow-500/10",
56
+ error: "border-red-500/30 bg-red-500/10"
57
+ };
58
+ function ToastContainer() {
59
+ const { toasts, remove } = useToast();
60
+ const handleDismiss = useCallback(
61
+ (id) => () => {
62
+ remove(id);
63
+ },
64
+ [remove]
65
+ );
66
+ if (toasts.length === 0) return null;
67
+ return /* @__PURE__ */ jsx(
68
+ "div",
69
+ {
70
+ role: "region",
71
+ "aria-label": "notifications",
72
+ "aria-live": "polite",
73
+ "aria-atomic": "false",
74
+ "aria-relevant": "additions removals",
75
+ className: "fixed bottom-4 right-4 z-50 flex flex-col gap-2",
76
+ children: toasts.map((toast) => {
77
+ const Icon = icons[toast.type];
78
+ return /* @__PURE__ */ jsxs(
79
+ "div",
80
+ {
81
+ className: `flex items-center gap-3 rounded-lg border px-4 py-3 shadow-lg ${styles[toast.type]}`,
82
+ role: "alert",
83
+ "aria-live": toast.type === "error" ? "assertive" : "polite",
84
+ "aria-atomic": "true",
85
+ children: [
86
+ /* @__PURE__ */ jsx(Icon, { size: 20, className: "shrink-0", "aria-hidden": "true" }),
87
+ /* @__PURE__ */ jsx("span", { className: "text-sm", children: toast.message }),
88
+ /* @__PURE__ */ jsx(
89
+ "button",
90
+ {
91
+ type: "button",
92
+ onClick: handleDismiss(toast.id),
93
+ className: "ml-2 rounded p-1 hover:bg-white/10",
94
+ "aria-label": "dismiss notification",
95
+ children: /* @__PURE__ */ jsx(IconX, { size: 16, "aria-hidden": "true" })
96
+ }
97
+ )
98
+ ]
99
+ },
100
+ toast.id
101
+ );
102
+ })
103
+ }
104
+ );
105
+ }
106
+
107
+ export { ToastProvider, useToast };
@@ -0,0 +1,21 @@
1
+ import * as react from 'react';
2
+ import { JSX } from 'react';
3
+ import { Heading } from './hook.js';
4
+
5
+ /**
6
+ * Props for the table of contents component
7
+ */
8
+ interface Props {
9
+ /** Array of heading objects to display */
10
+ headings: Heading[];
11
+ /** Currently active heading id */
12
+ active: string;
13
+ /** Array of heading ids in the active range */
14
+ activeRange: string[];
15
+ /** Enable zigzag line decoration */
16
+ zigzag?: boolean;
17
+ }
18
+ declare function TocDefaultBase({ headings, active, activeRange, zigzag }: Props): JSX.Element;
19
+ declare const TocDefault: react.MemoExoticComponent<typeof TocDefaultBase>;
20
+
21
+ export { TocDefault };
@@ -0,0 +1,100 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import { memo, useRef, useState, useEffect } from 'react';
4
+ import { ZigzagLine, getItemOffset, buildZigzagPath } from './zigzag';
5
+
6
+ function TocDefaultBase({ headings, active, activeRange, zigzag }) {
7
+ const containerRef = useRef(null);
8
+ const [svg, setSvg] = useState(null);
9
+ const [thumb, setThumb] = useState({ top: 0, height: 0 });
10
+ const range = activeRange.length > 0 ? activeRange : active ? [active] : [];
11
+ const isActive = (id) => range.includes(id);
12
+ useEffect(() => {
13
+ if (!zigzag || !containerRef.current || headings.length === 0) return;
14
+ const container = containerRef.current;
15
+ function update() {
16
+ const result = buildZigzagPath(headings, container);
17
+ if (result) setSvg(result);
18
+ }
19
+ const observer = new ResizeObserver(update);
20
+ update();
21
+ observer.observe(container);
22
+ return () => observer.disconnect();
23
+ }, [headings, zigzag]);
24
+ useEffect(() => {
25
+ if (!zigzag || !containerRef.current || range.length === 0) return;
26
+ const container = containerRef.current;
27
+ let upper = Infinity;
28
+ let lower = 0;
29
+ for (const id of range) {
30
+ const element = container.querySelector(`a[href="#${id}"]`);
31
+ if (!element) continue;
32
+ const styles = getComputedStyle(element);
33
+ const top = element.offsetTop + parseFloat(styles.paddingTop);
34
+ const bottom = element.offsetTop + element.clientHeight - parseFloat(styles.paddingBottom);
35
+ upper = Math.min(upper, top);
36
+ lower = Math.max(lower, bottom);
37
+ }
38
+ if (upper !== Infinity) {
39
+ setThumb({ top: upper, height: lower - upper });
40
+ }
41
+ }, [range, zigzag]);
42
+ if (zigzag) {
43
+ return /* @__PURE__ */ jsxs("nav", { "aria-label": "Table of contents", className: "relative", children: [
44
+ svg && /* @__PURE__ */ jsx(
45
+ "div",
46
+ {
47
+ "aria-hidden": "true",
48
+ className: "absolute left-0 top-0 pointer-events-none z-10",
49
+ style: {
50
+ width: svg.width,
51
+ height: svg.height,
52
+ maskImage: `url("data:image/svg+xml,${encodeURIComponent(
53
+ `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 ${svg.width} ${svg.height}"><path d="${svg.path}" stroke="black" stroke-width="1" fill="none" /></svg>`
54
+ )}")`
55
+ },
56
+ children: /* @__PURE__ */ jsx(
57
+ "div",
58
+ {
59
+ className: "absolute w-full bg-fg transition-[top,height] duration-150",
60
+ style: { top: thumb.top, height: thumb.height }
61
+ }
62
+ )
63
+ }
64
+ ),
65
+ /* @__PURE__ */ jsx("div", { ref: containerRef, className: "flex flex-col relative", children: headings.map((heading, i) => /* @__PURE__ */ jsxs(
66
+ "a",
67
+ {
68
+ href: `#${heading.id}`,
69
+ "aria-current": isActive(heading.id) ? "location" : void 0,
70
+ className: `relative py-1.5 text-sm transition-colors ${isActive(heading.id) ? "text-fg" : "text-muted hover:text-fg"}`,
71
+ style: { paddingLeft: getItemOffset(heading.level) },
72
+ children: [
73
+ /* @__PURE__ */ jsx(
74
+ ZigzagLine,
75
+ {
76
+ heading,
77
+ upper: headings[i - 1]?.level,
78
+ lower: headings[i + 1]?.level
79
+ }
80
+ ),
81
+ heading.text
82
+ ]
83
+ },
84
+ heading.id
85
+ )) })
86
+ ] });
87
+ }
88
+ return /* @__PURE__ */ jsx("nav", { "aria-label": "Table of contents", className: "border-l border-line", children: /* @__PURE__ */ jsx("ul", { role: "list", className: "space-y-1", children: headings.map((heading) => /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsx(
89
+ "a",
90
+ {
91
+ href: `#${heading.id}`,
92
+ "aria-current": isActive(heading.id) ? "location" : void 0,
93
+ className: `block text-xs py-1 transition-colors border-l-2 -ml-px ${heading.level === 3 ? "pl-6" : "pl-4"} ${isActive(heading.id) ? "text-fg border-fg" : "text-muted hover:text-fg border-transparent"}`,
94
+ children: heading.text
95
+ }
96
+ ) }, heading.id)) }) });
97
+ }
98
+ const TocDefault = memo(TocDefaultBase);
99
+
100
+ export { TocDefault };
@@ -0,0 +1,13 @@
1
+ interface Heading {
2
+ id: string;
3
+ text: string;
4
+ level: number;
5
+ }
6
+ interface TocState {
7
+ headings: Heading[];
8
+ active: string;
9
+ activeRange: string[];
10
+ }
11
+ declare function useToc(multi?: boolean): TocState;
12
+
13
+ export { type Heading, type TocState, useToc };
@@ -0,0 +1,125 @@
1
+ "use client";
2
+ import { useState, useEffect } from 'react';
3
+
4
+ function cleanheading(text) {
5
+ return text.replace(/\s*#+\s*$/, "").trim();
6
+ }
7
+ function useToc(multi = false) {
8
+ const [headings, setHeadings] = useState([]);
9
+ const [active, setActive] = useState("");
10
+ const [activeRange, setActiveRange] = useState([]);
11
+ useEffect(() => {
12
+ function scan() {
13
+ const elements = document.querySelectorAll("article h2, article h3, article h4, article h5, article h6");
14
+ const items = [];
15
+ elements.forEach((el) => {
16
+ if (el.id) {
17
+ const level = Number(el.tagName.replace("H", ""));
18
+ items.push({
19
+ id: el.id,
20
+ text: cleanheading(el.textContent || ""),
21
+ level: Number.isFinite(level) ? level : 2
22
+ });
23
+ }
24
+ });
25
+ if (items.length > 0) {
26
+ setHeadings(items);
27
+ }
28
+ }
29
+ scan();
30
+ const observer = new MutationObserver(() => {
31
+ scan();
32
+ });
33
+ const article = document.querySelector("article");
34
+ if (article) {
35
+ observer.observe(article, { childList: true, subtree: true });
36
+ }
37
+ return () => observer.disconnect();
38
+ }, []);
39
+ useEffect(() => {
40
+ if (headings.length === 0) return;
41
+ function findClosest() {
42
+ let closest = headings[0]?.id || "";
43
+ let minDistance = Infinity;
44
+ for (const { id } of headings) {
45
+ const el = document.getElementById(id);
46
+ if (!el) continue;
47
+ const rect = el.getBoundingClientRect();
48
+ const distance = Math.abs(rect.top);
49
+ if (distance < minDistance) {
50
+ minDistance = distance;
51
+ closest = id;
52
+ }
53
+ }
54
+ return closest;
55
+ }
56
+ if (multi) {
57
+ const visible = /* @__PURE__ */ new Set();
58
+ const observer = new IntersectionObserver(
59
+ (entries) => {
60
+ for (const entry of entries) {
61
+ if (entry.isIntersecting) {
62
+ visible.add(entry.target.id);
63
+ } else {
64
+ visible.delete(entry.target.id);
65
+ }
66
+ }
67
+ if (visible.size === 0) {
68
+ const closest = findClosest();
69
+ setActive(closest);
70
+ setActiveRange(closest ? [closest] : []);
71
+ } else {
72
+ const ordered = headings.filter((h) => visible.has(h.id));
73
+ setActive(ordered[0]?.id || "");
74
+ setActiveRange(ordered.map((h) => h.id));
75
+ }
76
+ },
77
+ { rootMargin: "0px", threshold: 0.9 }
78
+ );
79
+ for (const { id } of headings) {
80
+ const el = document.getElementById(id);
81
+ if (el) observer.observe(el);
82
+ }
83
+ return () => observer.disconnect();
84
+ }
85
+ let ticking = false;
86
+ function update() {
87
+ const atBottom = window.innerHeight + Math.ceil(window.scrollY) >= document.documentElement.scrollHeight;
88
+ if (atBottom && headings.length > 0) {
89
+ const last = headings[headings.length - 1];
90
+ if (last) setActive(last.id);
91
+ return;
92
+ }
93
+ const offset = 100;
94
+ let current = "";
95
+ const items = headings.slice(0, -1);
96
+ for (const { id } of items) {
97
+ const el = document.getElementById(id);
98
+ if (!el) continue;
99
+ if (el.getBoundingClientRect().top <= offset) {
100
+ current = id;
101
+ }
102
+ }
103
+ if (!current && headings.length > 0) {
104
+ const first = headings[0];
105
+ if (first) current = first.id;
106
+ }
107
+ setActive(current);
108
+ }
109
+ function onScroll() {
110
+ if (!ticking) {
111
+ requestAnimationFrame(() => {
112
+ update();
113
+ ticking = false;
114
+ });
115
+ ticking = true;
116
+ }
117
+ }
118
+ update();
119
+ window.addEventListener("scroll", onScroll, { passive: true });
120
+ return () => window.removeEventListener("scroll", onScroll);
121
+ }, [headings, multi]);
122
+ return { headings, active, activeRange };
123
+ }
124
+
125
+ export { useToc };
@@ -0,0 +1,15 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ export { Heading, TocState, useToc } from './hook.js';
3
+
4
+ type TocVariant = "default" | "minimal" | "inline";
5
+ interface TocProps {
6
+ variant?: TocVariant;
7
+ zigzag?: boolean;
8
+ multi?: boolean;
9
+ title?: string;
10
+ collapsible?: boolean;
11
+ defaultOpen?: boolean;
12
+ }
13
+ declare function Toc({ variant, zigzag, multi, title, collapsible, defaultOpen, }: TocProps): react_jsx_runtime.JSX.Element | null;
14
+
15
+ export { Toc, type TocProps, type TocVariant };