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.
- package/README.md +49 -0
- package/dist/access.d.ts +23 -0
- package/dist/access.js +54 -0
- package/dist/adapter.d.ts +31 -0
- package/dist/adapter.js +59 -0
- package/dist/adapterastro.d.ts +6 -0
- package/dist/adapterastro.js +6 -0
- package/dist/adapterbrowser.d.ts +6 -0
- package/dist/adapterbrowser.js +38 -0
- package/dist/adapternext.d.ts +6 -0
- package/dist/adapternext.js +49 -0
- package/dist/adapterreactrouter.d.ts +6 -0
- package/dist/adapterreactrouter.js +37 -0
- package/dist/adapterremix.d.ts +6 -0
- package/dist/adapterremix.js +41 -0
- package/dist/adaptertanstack.d.ts +6 -0
- package/dist/adaptertanstack.js +38 -0
- package/dist/adaptervite.d.ts +6 -0
- package/dist/adaptervite.js +6 -0
- package/dist/algolia.d.ts +16 -0
- package/dist/algolia.js +83 -0
- package/dist/analytics.d.ts +31 -0
- package/dist/analytics.js +61 -0
- package/dist/ansi.d.ts +5 -0
- package/dist/ansi.js +192 -0
- package/dist/api.d.ts +30 -0
- package/dist/api.js +75 -0
- package/dist/astro.d.ts +3 -0
- package/dist/astro.js +3 -0
- package/dist/audit.d.ts +19 -0
- package/dist/audit.js +78 -0
- package/dist/autotype.d.ts +17 -0
- package/dist/autotype.js +73 -0
- package/dist/batch.d.ts +22 -0
- package/dist/batch.js +68 -0
- package/dist/browser.d.ts +5 -0
- package/dist/browser.js +53 -0
- package/dist/changelog.d.ts +27 -0
- package/dist/changelog.js +87 -0
- package/dist/changelogutil.d.ts +20 -0
- package/dist/changelogutil.js +84 -0
- package/dist/cli.d.ts +24 -0
- package/dist/cli.js +76 -0
- package/dist/client.d.ts +212 -0
- package/dist/client.js +202 -0
- package/dist/codesample.d.ts +20 -0
- package/dist/codesample.js +115 -0
- package/dist/collapse.d.ts +5 -0
- package/dist/collapse.js +101 -0
- package/dist/collections.d.ts +32 -0
- package/dist/collections.js +82 -0
- package/dist/components/accordion.d.ts +22 -0
- package/dist/components/accordion.js +54 -0
- package/dist/components/alert.d.ts +18 -0
- package/dist/components/alert.js +30 -0
- package/dist/components/announce.d.ts +11 -0
- package/dist/components/announce.js +38 -0
- package/dist/components/autofill.d.ts +27 -0
- package/dist/components/autofill.js +152 -0
- package/dist/components/avatar.d.ts +42 -0
- package/dist/components/avatar.js +67 -0
- package/dist/components/avatarstack.d.ts +23 -0
- package/dist/components/avatarstack.js +54 -0
- package/dist/components/backtotop.d.ts +20 -0
- package/dist/components/backtotop.js +42 -0
- package/dist/components/badge.d.ts +17 -0
- package/dist/components/badge.js +25 -0
- package/dist/components/banner.d.ts +21 -0
- package/dist/components/banner.js +63 -0
- package/dist/components/breadcrumb.d.ts +25 -0
- package/dist/components/breadcrumb.js +35 -0
- package/dist/components/breadcrumbnav.d.ts +15 -0
- package/dist/components/breadcrumbnav.js +60 -0
- package/dist/components/button.d.ts +22 -0
- package/dist/components/button.js +47 -0
- package/dist/components/callout.d.ts +26 -0
- package/dist/components/callout.js +91 -0
- package/dist/components/cards.d.ts +34 -0
- package/dist/components/cards.js +24 -0
- package/dist/components/changelog.d.ts +34 -0
- package/dist/components/changelog.js +50 -0
- package/dist/components/checkbox.d.ts +26 -0
- package/dist/components/checkbox.js +80 -0
- package/dist/components/code.d.ts +27 -0
- package/dist/components/code.js +36 -0
- package/dist/components/codeblock.d.ts +12 -0
- package/dist/components/codeblock.js +102 -0
- package/dist/components/codecopy.d.ts +12 -0
- package/dist/components/codecopy.js +56 -0
- package/dist/components/codegroup.d.ts +22 -0
- package/dist/components/codegroup.js +134 -0
- package/dist/components/collapsible.d.ts +29 -0
- package/dist/components/collapsible.js +64 -0
- package/dist/components/command.d.ts +22 -0
- package/dist/components/command.js +138 -0
- package/dist/components/compare.d.ts +54 -0
- package/dist/components/compare.js +88 -0
- package/dist/components/content.d.ts +12 -0
- package/dist/components/content.js +232 -0
- package/dist/components/copyable.d.ts +25 -0
- package/dist/components/copyable.js +51 -0
- package/dist/components/copybutton.d.ts +11 -0
- package/dist/components/copybutton.js +50 -0
- package/dist/components/countdown.d.ts +18 -0
- package/dist/components/countdown.js +112 -0
- package/dist/components/create.d.ts +10 -0
- package/dist/components/create.js +149 -0
- package/dist/components/definition.d.ts +43 -0
- package/dist/components/definition.js +46 -0
- package/dist/components/diffview.d.ts +12 -0
- package/dist/components/diffview.js +129 -0
- package/dist/components/divider.d.ts +19 -0
- package/dist/components/divider.js +24 -0
- package/dist/components/docheader.d.ts +17 -0
- package/dist/components/docheader.js +24 -0
- package/dist/components/doclinkcard.d.ts +19 -0
- package/dist/components/doclinkcard.js +37 -0
- package/dist/components/docslayout.d.ts +14 -0
- package/dist/components/docslayout.js +24 -0
- package/dist/components/dropdown.d.ts +23 -0
- package/dist/components/dropdown.js +134 -0
- package/dist/components/dynamiccode.d.ts +12 -0
- package/dist/components/dynamiccode.js +40 -0
- package/dist/components/editlink.d.ts +15 -0
- package/dist/components/editlink.js +45 -0
- package/dist/components/embed.d.ts +45 -0
- package/dist/components/embed.js +85 -0
- package/dist/components/endpoint.d.ts +58 -0
- package/dist/components/endpoint.js +100 -0
- package/dist/components/errormessage.d.ts +11 -0
- package/dist/components/errormessage.js +10 -0
- package/dist/components/expandcode.d.ts +13 -0
- package/dist/components/expandcode.js +58 -0
- package/dist/components/feature.d.ts +31 -0
- package/dist/components/feature.js +58 -0
- package/dist/components/featuregrid.d.ts +17 -0
- package/dist/components/featuregrid.js +36 -0
- package/dist/components/feedback.d.ts +14 -0
- package/dist/components/feedback.js +62 -0
- package/dist/components/feedbackwidget.d.ts +14 -0
- package/dist/components/feedbackwidget.js +106 -0
- package/dist/components/files.d.ts +21 -0
- package/dist/components/files.js +133 -0
- package/dist/components/folder.d.ts +15 -0
- package/dist/components/folder.js +102 -0
- package/dist/components/footer.d.ts +16 -0
- package/dist/components/footer.js +28 -0
- package/dist/components/formlabel.d.ts +24 -0
- package/dist/components/formlabel.js +27 -0
- package/dist/components/github.d.ts +14 -0
- package/dist/components/github.js +99 -0
- package/dist/components/graph.d.ts +36 -0
- package/dist/components/graph.js +210 -0
- package/dist/components/heading.d.ts +25 -0
- package/dist/components/heading.js +82 -0
- package/dist/components/headingcopy.d.ts +3 -0
- package/dist/components/headingcopy.js +31 -0
- package/dist/components/hero.d.ts +16 -0
- package/dist/components/hero.js +28 -0
- package/dist/components/highlight.d.ts +41 -0
- package/dist/components/highlight.js +42 -0
- package/dist/components/hover.d.ts +23 -0
- package/dist/components/hover.js +79 -0
- package/dist/components/icons.d.ts +30 -0
- package/dist/components/icons.js +419 -0
- package/dist/components/inlinetoc.d.ts +19 -0
- package/dist/components/inlinetoc.js +28 -0
- package/dist/components/input.d.ts +25 -0
- package/dist/components/input.js +42 -0
- package/dist/components/install.d.ts +10 -0
- package/dist/components/install.js +149 -0
- package/dist/components/kbd.d.ts +22 -0
- package/dist/components/kbd.js +30 -0
- package/dist/components/langicon.d.ts +8 -0
- package/dist/components/langicon.js +48 -0
- package/dist/components/language.d.ts +17 -0
- package/dist/components/language.js +123 -0
- package/dist/components/lastupdated.d.ts +12 -0
- package/dist/components/lastupdated.js +44 -0
- package/dist/components/link.d.ts +14 -0
- package/dist/components/link.js +53 -0
- package/dist/components/linkcard.d.ts +33 -0
- package/dist/components/linkcard.js +50 -0
- package/dist/components/list.d.ts +50 -0
- package/dist/components/list.js +55 -0
- package/dist/components/math.d.ts +34 -0
- package/dist/components/math.js +63 -0
- package/dist/components/mermaid.d.ts +19 -0
- package/dist/components/mermaid.js +79 -0
- package/dist/components/mobilenav.d.ts +17 -0
- package/dist/components/mobilenav.js +263 -0
- package/dist/components/modal.d.ts +18 -0
- package/dist/components/modal.js +69 -0
- package/dist/components/navbar.d.ts +19 -0
- package/dist/components/navbar.js +45 -0
- package/dist/components/navlink.d.ts +14 -0
- package/dist/components/navlink.js +77 -0
- package/dist/components/note.d.ts +28 -0
- package/dist/components/note.js +60 -0
- package/dist/components/openapi.d.ts +14 -0
- package/dist/components/openapi.js +145 -0
- package/dist/components/openapischema.d.ts +13 -0
- package/dist/components/openapischema.js +51 -0
- package/dist/components/openapitags.d.ts +13 -0
- package/dist/components/openapitags.js +20 -0
- package/dist/components/pagetransition.d.ts +13 -0
- package/dist/components/pagetransition.js +37 -0
- package/dist/components/pagination.d.ts +26 -0
- package/dist/components/pagination.js +68 -0
- package/dist/components/panel.d.ts +25 -0
- package/dist/components/panel.js +75 -0
- package/dist/components/playground.d.ts +14 -0
- package/dist/components/playground.js +89 -0
- package/dist/components/popover.d.ts +18 -0
- package/dist/components/popover.js +109 -0
- package/dist/components/prelink.d.ts +10 -0
- package/dist/components/prelink.js +46 -0
- package/dist/components/prevnext.d.ts +17 -0
- package/dist/components/prevnext.js +43 -0
- package/dist/components/progress.d.ts +30 -0
- package/dist/components/progress.js +74 -0
- package/dist/components/property.d.ts +24 -0
- package/dist/components/property.js +44 -0
- package/dist/components/quote.d.ts +44 -0
- package/dist/components/quote.js +41 -0
- package/dist/components/radio.d.ts +48 -0
- package/dist/components/radio.js +140 -0
- package/dist/components/rating.d.ts +22 -0
- package/dist/components/rating.js +100 -0
- package/dist/components/readtime.d.ts +17 -0
- package/dist/components/readtime.js +26 -0
- package/dist/components/recent.d.ts +12 -0
- package/dist/components/recent.js +23 -0
- package/dist/components/responsive.d.ts +35 -0
- package/dist/components/responsive.js +73 -0
- package/dist/components/results.d.ts +20 -0
- package/dist/components/results.js +72 -0
- package/dist/components/screenshot.d.ts +33 -0
- package/dist/components/screenshot.js +52 -0
- package/dist/components/scrollprogress.d.ts +12 -0
- package/dist/components/scrollprogress.js +56 -0
- package/dist/components/scrollspy.d.ts +18 -0
- package/dist/components/scrollspy.js +51 -0
- package/dist/components/search.d.ts +19 -0
- package/dist/components/search.js +228 -0
- package/dist/components/searchbutton.d.ts +10 -0
- package/dist/components/searchbutton.js +51 -0
- package/dist/components/searchdialog.d.ts +19 -0
- package/dist/components/searchdialog.js +108 -0
- package/dist/components/searcher.d.ts +12 -0
- package/dist/components/searcher.js +121 -0
- package/dist/components/select.d.ts +39 -0
- package/dist/components/select.js +162 -0
- package/dist/components/shortcuts.d.ts +17 -0
- package/dist/components/shortcuts.js +62 -0
- package/dist/components/sidebar.d.ts +35 -0
- package/dist/components/sidebar.js +215 -0
- package/dist/components/sidebarfilter.d.ts +13 -0
- package/dist/components/sidebarfilter.js +50 -0
- package/dist/components/skeleton.d.ts +40 -0
- package/dist/components/skeleton.js +59 -0
- package/dist/components/skiplink.d.ts +12 -0
- package/dist/components/skiplink.js +21 -0
- package/dist/components/spinner.d.ts +34 -0
- package/dist/components/spinner.js +56 -0
- package/dist/components/status.d.ts +27 -0
- package/dist/components/status.js +63 -0
- package/dist/components/steps.d.ts +30 -0
- package/dist/components/steps.js +15 -0
- package/dist/components/switch.d.ts +26 -0
- package/dist/components/switch.js +79 -0
- package/dist/components/table.d.ts +36 -0
- package/dist/components/table.js +138 -0
- package/dist/components/tabnav.d.ts +30 -0
- package/dist/components/tabnav.js +199 -0
- package/dist/components/tabs.d.ts +15 -0
- package/dist/components/tabs.js +96 -0
- package/dist/components/tag.d.ts +32 -0
- package/dist/components/tag.js +38 -0
- package/dist/components/terminal.d.ts +48 -0
- package/dist/components/terminal.js +62 -0
- package/dist/components/textarea.d.ts +30 -0
- package/dist/components/textarea.js +100 -0
- package/dist/components/theme.d.ts +11 -0
- package/dist/components/theme.js +66 -0
- package/dist/components/themeprovider.d.ts +19 -0
- package/dist/components/themeprovider.js +58 -0
- package/dist/components/toast.d.ts +31 -0
- package/dist/components/toast.js +107 -0
- package/dist/components/toc/default.d.ts +21 -0
- package/dist/components/toc/default.js +100 -0
- package/dist/components/toc/hook.d.ts +13 -0
- package/dist/components/toc/hook.js +125 -0
- package/dist/components/toc/index.d.ts +15 -0
- package/dist/components/toc/index.js +44 -0
- package/dist/components/toc/inline.d.ts +20 -0
- package/dist/components/toc/inline.js +75 -0
- package/dist/components/toc/minimal.d.ts +22 -0
- package/dist/components/toc/minimal.js +136 -0
- package/dist/components/toc/zigzag.d.ts +18 -0
- package/dist/components/toc/zigzag.js +57 -0
- package/dist/components/tocprogress.d.ts +17 -0
- package/dist/components/tocprogress.js +67 -0
- package/dist/components/tooltip.d.ts +19 -0
- package/dist/components/tooltip.js +76 -0
- package/dist/components/trigger.d.ts +8 -0
- package/dist/components/trigger.js +13 -0
- package/dist/components/twoslash.d.ts +9 -0
- package/dist/components/twoslash.js +52 -0
- package/dist/components/typetable.d.ts +21 -0
- package/dist/components/typetable.js +68 -0
- package/dist/components/typewriter.d.ts +20 -0
- package/dist/components/typewriter.js +50 -0
- package/dist/components/version.d.ts +29 -0
- package/dist/components/version.js +181 -0
- package/dist/components/video.d.ts +33 -0
- package/dist/components/video.js +147 -0
- package/dist/components/zoom.d.ts +9 -0
- package/dist/components/zoom.js +110 -0
- package/dist/config.d.ts +54 -0
- package/dist/config.js +102 -0
- package/dist/content.d.ts +83 -0
- package/dist/content.js +464 -0
- package/dist/contentcache.d.ts +28 -0
- package/dist/contentcache.js +76 -0
- package/dist/contentdiff.d.ts +19 -0
- package/dist/contentdiff.js +48 -0
- package/dist/contributors.d.ts +22 -0
- package/dist/contributors.js +64 -0
- package/dist/diff.d.ts +25 -0
- package/dist/diff.js +117 -0
- package/dist/draft.d.ts +33 -0
- package/dist/draft.js +62 -0
- package/dist/env.d.ts +12 -0
- package/dist/env.js +50 -0
- package/dist/export.d.ts +9 -0
- package/dist/export.js +32 -0
- package/dist/frontmatter.d.ts +19 -0
- package/dist/frontmatter.js +65 -0
- package/dist/github.d.ts +15 -0
- package/dist/github.js +254 -0
- package/dist/gitsource.d.ts +23 -0
- package/dist/gitsource.js +50 -0
- package/dist/hash.d.ts +21 -0
- package/dist/hash.js +65 -0
- package/dist/highlight.d.ts +18 -0
- package/dist/highlight.js +90 -0
- package/dist/hooks/anchor.d.ts +7 -0
- package/dist/hooks/anchor.js +44 -0
- package/dist/hooks/arrownav.d.ts +11 -0
- package/dist/hooks/arrownav.js +49 -0
- package/dist/hooks/async.d.ts +9 -0
- package/dist/hooks/async.js +28 -0
- package/dist/hooks/battery.d.ts +8 -0
- package/dist/hooks/battery.js +34 -0
- package/dist/hooks/breakpoint.d.ts +6 -0
- package/dist/hooks/breakpoint.js +34 -0
- package/dist/hooks/clickoutside.d.ts +11 -0
- package/dist/hooks/clickoutside.js +19 -0
- package/dist/hooks/clipboard-paste.d.ts +8 -0
- package/dist/hooks/clipboard-paste.js +18 -0
- package/dist/hooks/clipboard.d.ts +9 -0
- package/dist/hooks/clipboard.js +24 -0
- package/dist/hooks/colorscheme.d.ts +4 -0
- package/dist/hooks/colorscheme.js +18 -0
- package/dist/hooks/copy.d.ts +12 -0
- package/dist/hooks/copy.js +28 -0
- package/dist/hooks/countdown.d.ts +10 -0
- package/dist/hooks/countdown.js +41 -0
- package/dist/hooks/counter.d.ts +10 -0
- package/dist/hooks/counter.js +12 -0
- package/dist/hooks/debounce.d.ts +9 -0
- package/dist/hooks/debounce.js +16 -0
- package/dist/hooks/documenttitle.d.ts +3 -0
- package/dist/hooks/documenttitle.js +20 -0
- package/dist/hooks/documentvisibility.d.ts +4 -0
- package/dist/hooks/documentvisibility.js +19 -0
- package/dist/hooks/escapekey.d.ts +8 -0
- package/dist/hooks/escapekey.js +18 -0
- package/dist/hooks/eventlistener.d.ts +13 -0
- package/dist/hooks/eventlistener.js +15 -0
- package/dist/hooks/eventsource.d.ts +10 -0
- package/dist/hooks/eventsource.js +31 -0
- package/dist/hooks/eyedropper.d.ts +8 -0
- package/dist/hooks/eyedropper.js +23 -0
- package/dist/hooks/favicon.d.ts +3 -0
- package/dist/hooks/favicon.js +14 -0
- package/dist/hooks/fetch.d.ts +8 -0
- package/dist/hooks/fetch.js +29 -0
- package/dist/hooks/focustrap.d.ts +12 -0
- package/dist/hooks/focustrap.js +62 -0
- package/dist/hooks/focuswithin.d.ts +6 -0
- package/dist/hooks/focuswithin.js +24 -0
- package/dist/hooks/form.d.ts +20 -0
- package/dist/hooks/form.js +42 -0
- package/dist/hooks/fullscreen.d.ts +10 -0
- package/dist/hooks/fullscreen.js +34 -0
- package/dist/hooks/geolocation.d.ts +10 -0
- package/dist/hooks/geolocation.js +38 -0
- package/dist/hooks/hash.d.ts +3 -0
- package/dist/hooks/hash.js +21 -0
- package/dist/hooks/hotkeys.d.ts +11 -0
- package/dist/hooks/hotkeys.js +35 -0
- package/dist/hooks/hover.d.ts +3 -0
- package/dist/hooks/hover.js +22 -0
- package/dist/hooks/idle.d.ts +3 -0
- package/dist/hooks/idle.js +28 -0
- package/dist/hooks/infinitescroll.d.ts +9 -0
- package/dist/hooks/infinitescroll.js +31 -0
- package/dist/hooks/interval.d.ts +3 -0
- package/dist/hooks/interval.js +16 -0
- package/dist/hooks/inview.d.ts +10 -0
- package/dist/hooks/inview.js +28 -0
- package/dist/hooks/keyboard.d.ts +14 -0
- package/dist/hooks/keyboard.js +82 -0
- package/dist/hooks/keypress.d.ts +3 -0
- package/dist/hooks/keypress.js +23 -0
- package/dist/hooks/list.d.ts +14 -0
- package/dist/hooks/list.js +28 -0
- package/dist/hooks/longpress.d.ts +10 -0
- package/dist/hooks/longpress.js +24 -0
- package/dist/hooks/map.d.ts +12 -0
- package/dist/hooks/map.js +23 -0
- package/dist/hooks/measure.d.ts +16 -0
- package/dist/hooks/measure.js +34 -0
- package/dist/hooks/media.d.ts +33 -0
- package/dist/hooks/media.js +35 -0
- package/dist/hooks/mediarecorder.d.ts +11 -0
- package/dist/hooks/mediarecorder.js +37 -0
- package/dist/hooks/mounted.d.ts +3 -0
- package/dist/hooks/mounted.js +12 -0
- package/dist/hooks/mouseposition.d.ts +7 -0
- package/dist/hooks/mouseposition.js +16 -0
- package/dist/hooks/networkstate.d.ts +10 -0
- package/dist/hooks/networkstate.js +34 -0
- package/dist/hooks/online.d.ts +3 -0
- package/dist/hooks/online.js +20 -0
- package/dist/hooks/orientation.d.ts +8 -0
- package/dist/hooks/orientation.js +20 -0
- package/dist/hooks/os.d.ts +4 -0
- package/dist/hooks/os.js +15 -0
- package/dist/hooks/pageleave.d.ts +3 -0
- package/dist/hooks/pageleave.js +18 -0
- package/dist/hooks/pagination.d.ts +26 -0
- package/dist/hooks/pagination.js +49 -0
- package/dist/hooks/permission.d.ts +5 -0
- package/dist/hooks/permission.js +29 -0
- package/dist/hooks/preferredlanguage.d.ts +3 -0
- package/dist/hooks/preferredlanguage.js +17 -0
- package/dist/hooks/previous.d.ts +3 -0
- package/dist/hooks/previous.js +12 -0
- package/dist/hooks/queue.d.ts +11 -0
- package/dist/hooks/queue.js +23 -0
- package/dist/hooks/readprogress.d.ts +6 -0
- package/dist/hooks/readprogress.js +32 -0
- package/dist/hooks/resizeobserver.d.ts +10 -0
- package/dist/hooks/resizeobserver.js +25 -0
- package/dist/hooks/script.d.ts +4 -0
- package/dist/hooks/script.js +30 -0
- package/dist/hooks/scrolldirection.d.ts +4 -0
- package/dist/hooks/scrolldirection.js +33 -0
- package/dist/hooks/scrolllock.d.ts +3 -0
- package/dist/hooks/scrolllock.js +38 -0
- package/dist/hooks/scrollspy.d.ts +7 -0
- package/dist/hooks/scrollspy.js +28 -0
- package/dist/hooks/scrolltop.d.ts +7 -0
- package/dist/hooks/scrolltop.js +19 -0
- package/dist/hooks/selection.d.ts +12 -0
- package/dist/hooks/selection.js +32 -0
- package/dist/hooks/share.d.ts +13 -0
- package/dist/hooks/share.js +37 -0
- package/dist/hooks/speechrecognition.d.ts +10 -0
- package/dist/hooks/speechrecognition.js +34 -0
- package/dist/hooks/stepper.d.ts +13 -0
- package/dist/hooks/stepper.js +31 -0
- package/dist/hooks/storage.d.ts +5 -0
- package/dist/hooks/storage.js +57 -0
- package/dist/hooks/stylesheet.d.ts +4 -0
- package/dist/hooks/stylesheet.js +30 -0
- package/dist/hooks/textselection.d.ts +7 -0
- package/dist/hooks/textselection.js +24 -0
- package/dist/hooks/throttle.d.ts +3 -0
- package/dist/hooks/throttle.js +28 -0
- package/dist/hooks/toggle.d.ts +13 -0
- package/dist/hooks/toggle.js +10 -0
- package/dist/hooks/undoredo.d.ts +12 -0
- package/dist/hooks/undoredo.js +50 -0
- package/dist/hooks/vibrate.d.ts +7 -0
- package/dist/hooks/vibrate.js +15 -0
- package/dist/hooks/viewtransition.d.ts +9 -0
- package/dist/hooks/viewtransition.js +38 -0
- package/dist/hooks/wakelock.d.ts +9 -0
- package/dist/hooks/wakelock.js +32 -0
- package/dist/hooks/websocket.d.ts +10 -0
- package/dist/hooks/websocket.js +30 -0
- package/dist/hooks/windowsize.d.ts +7 -0
- package/dist/hooks/windowsize.js +17 -0
- package/dist/i18n.d.ts +30 -0
- package/dist/i18n.js +73 -0
- package/dist/index.d.ts +115 -0
- package/dist/index.js +107 -0
- package/dist/lastmodified.d.ts +4 -0
- package/dist/lastmodified.js +24 -0
- package/dist/linkcheck.d.ts +26 -0
- package/dist/linkcheck.js +113 -0
- package/dist/llms.d.ts +14 -0
- package/dist/llms.js +39 -0
- package/dist/manifest.d.ts +24 -0
- package/dist/manifest.js +31 -0
- package/dist/mcp.d.ts +56 -0
- package/dist/mcp.js +74 -0
- package/dist/mdtoc.d.ts +16 -0
- package/dist/mdtoc.js +59 -0
- package/dist/mdxscope.d.ts +17 -0
- package/dist/mdxscope.js +58 -0
- package/dist/meta.d.ts +19 -0
- package/dist/meta.js +71 -0
- package/dist/migrate.d.ts +17 -0
- package/dist/migrate.js +108 -0
- package/dist/navgen.d.ts +31 -0
- package/dist/navgen.js +147 -0
- package/dist/navtree.d.ts +28 -0
- package/dist/navtree.js +93 -0
- package/dist/next.d.ts +3 -0
- package/dist/next.js +3 -0
- package/dist/oembed.d.ts +20 -0
- package/dist/oembed.js +62 -0
- package/dist/ogimage.d.ts +45 -0
- package/dist/ogimage.js +62 -0
- package/dist/openapi.d.ts +6 -0
- package/dist/openapi.js +141 -0
- package/dist/openapiguard.d.ts +22 -0
- package/dist/openapiguard.js +87 -0
- package/dist/openapiutil.d.ts +72 -0
- package/dist/openapiutil.js +61 -0
- package/dist/orama.d.ts +16 -0
- package/dist/orama.js +100 -0
- package/dist/pipeline.d.ts +19 -0
- package/dist/pipeline.js +40 -0
- package/dist/preload.d.ts +15 -0
- package/dist/preload.js +19 -0
- package/dist/ranking.d.ts +28 -0
- package/dist/ranking.js +95 -0
- package/dist/reactrouter.d.ts +3 -0
- package/dist/reactrouter.js +3 -0
- package/dist/readtime.d.ts +3 -0
- package/dist/readtime.js +8 -0
- package/dist/redirects.d.ts +27 -0
- package/dist/redirects.js +74 -0
- package/dist/rehype.d.ts +5 -0
- package/dist/rehype.js +30 -0
- package/dist/rehypeautolink.d.ts +11 -0
- package/dist/rehypeautolink.js +43 -0
- package/dist/rehypecode.d.ts +6 -0
- package/dist/rehypecode.js +68 -0
- package/dist/rehypecopy.d.ts +6 -0
- package/dist/rehypecopy.js +29 -0
- package/dist/rehypeinline.d.ts +6 -0
- package/dist/rehypeinline.js +32 -0
- package/dist/rehypelinks.d.ts +10 -0
- package/dist/rehypelinks.js +49 -0
- package/dist/rehyperaw.d.ts +6 -0
- package/dist/rehyperaw.js +27 -0
- package/dist/rehypeslug.d.ts +7 -0
- package/dist/rehypeslug.js +39 -0
- package/dist/rehypetablewrap.d.ts +9 -0
- package/dist/rehypetablewrap.js +24 -0
- package/dist/rehypetoc.d.ts +16 -0
- package/dist/rehypetoc.js +61 -0
- package/dist/remark.d.ts +6 -0
- package/dist/remark.js +48 -0
- package/dist/remarkadmonition.d.ts +6 -0
- package/dist/remarkadmonition.js +78 -0
- package/dist/remarkannotation.d.ts +10 -0
- package/dist/remarkannotation.js +65 -0
- package/dist/remarkbadge.d.ts +6 -0
- package/dist/remarkbadge.js +40 -0
- package/dist/remarkblockmath.d.ts +6 -0
- package/dist/remarkblockmath.js +57 -0
- package/dist/remarkcallout.d.ts +6 -0
- package/dist/remarkcallout.js +65 -0
- package/dist/remarkcaption.d.ts +6 -0
- package/dist/remarkcaption.js +48 -0
- package/dist/remarkcodetitle.d.ts +6 -0
- package/dist/remarkcodetitle.js +39 -0
- package/dist/remarkcolumns.d.ts +6 -0
- package/dist/remarkcolumns.js +67 -0
- package/dist/remarkdetails.d.ts +6 -0
- package/dist/remarkdetails.js +61 -0
- package/dist/remarkdirective.d.ts +7 -0
- package/dist/remarkdirective.js +98 -0
- package/dist/remarkembed.d.ts +6 -0
- package/dist/remarkembed.js +72 -0
- package/dist/remarkfiletree.d.ts +6 -0
- package/dist/remarkfiletree.js +67 -0
- package/dist/remarkfootnote.d.ts +6 -0
- package/dist/remarkfootnote.js +63 -0
- package/dist/remarkgfm.d.ts +6 -0
- package/dist/remarkgfm.js +60 -0
- package/dist/remarkheadingid.d.ts +6 -0
- package/dist/remarkheadingid.js +40 -0
- package/dist/remarkimage.d.ts +11 -0
- package/dist/remarkimage.js +91 -0
- package/dist/remarkinclude.d.ts +10 -0
- package/dist/remarkinclude.js +49 -0
- package/dist/remarkinstall.d.ts +6 -0
- package/dist/remarkinstall.js +52 -0
- package/dist/remarklinkcard.d.ts +6 -0
- package/dist/remarklinkcard.js +38 -0
- package/dist/remarkmath.d.ts +6 -0
- package/dist/remarkmath.js +69 -0
- package/dist/remarkmermaid.d.ts +6 -0
- package/dist/remarkmermaid.js +21 -0
- package/dist/remarkmeta.d.ts +15 -0
- package/dist/remarkmeta.js +63 -0
- package/dist/remarkreadingtime.d.ts +11 -0
- package/dist/remarkreadingtime.js +44 -0
- package/dist/remarksteps.d.ts +6 -0
- package/dist/remarksteps.js +56 -0
- package/dist/remarkstructure.d.ts +18 -0
- package/dist/remarkstructure.js +53 -0
- package/dist/remarktabs.d.ts +6 -0
- package/dist/remarktabs.js +42 -0
- package/dist/remarktoc.d.ts +6 -0
- package/dist/remarktoc.js +47 -0
- package/dist/remarkts2js.d.ts +6 -0
- package/dist/remarkts2js.js +88 -0
- package/dist/remarktwoslash.d.ts +20 -0
- package/dist/remarktwoslash.js +86 -0
- package/dist/remarkvideo.d.ts +16 -0
- package/dist/remarkvideo.js +59 -0
- package/dist/remix.d.ts +3 -0
- package/dist/remix.js +3 -0
- package/dist/schema.d.ts +54 -0
- package/dist/schema.js +17 -0
- package/dist/search.d.ts +24 -0
- package/dist/search.js +155 -0
- package/dist/searchindex.d.ts +28 -0
- package/dist/searchindex.js +184 -0
- package/dist/searchpolicy.d.ts +5 -0
- package/dist/searchpolicy.js +9 -0
- package/dist/searchscore.d.ts +30 -0
- package/dist/searchscore.js +54 -0
- package/dist/searchtypo.d.ts +3 -0
- package/dist/searchtypo.js +47 -0
- package/dist/seo.d.ts +26 -0
- package/dist/seo.js +69 -0
- package/dist/shortcodes.d.ts +13 -0
- package/dist/shortcodes.js +61 -0
- package/dist/sitemap.d.ts +25 -0
- package/dist/sitemap.js +69 -0
- package/dist/snippets.d.ts +18 -0
- package/dist/snippets.js +89 -0
- package/dist/source.d.ts +23 -0
- package/dist/source.js +188 -0
- package/dist/stats.d.ts +25 -0
- package/dist/stats.js +81 -0
- package/dist/tanstack.d.ts +3 -0
- package/dist/tanstack.js +3 -0
- package/dist/testing.d.ts +35 -0
- package/dist/testing.js +134 -0
- package/dist/themeutil.d.ts +31 -0
- package/dist/themeutil.js +92 -0
- package/dist/typegen.d.ts +10 -0
- package/dist/typegen.js +74 -0
- package/dist/types.d.ts +267 -0
- package/dist/types.js +1 -0
- package/dist/validate.d.ts +13 -0
- package/dist/validate.js +78 -0
- package/dist/validator.d.ts +35 -0
- package/dist/validator.js +53 -0
- package/dist/versioning.d.ts +32 -0
- package/dist/versioning.js +62 -0
- package/dist/vite.d.ts +3 -0
- package/dist/vite.js +3 -0
- package/dist/watcher.d.ts +19 -0
- package/dist/watcher.js +82 -0
- package/dist/webhook.d.ts +25 -0
- package/dist/webhook.js +67 -0
- package/dist/workspace.d.ts +26 -0
- package/dist/workspace.js +81 -0
- package/package.json +138 -11
- package/styles/reset.css +3 -0
- package/index.js +0 -3
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { memo } from 'react';
|
|
4
|
+
import { Tooltip } from './tooltip';
|
|
5
|
+
|
|
6
|
+
function FormLabelInner({ label, tooltip, htmlFor, id }) {
|
|
7
|
+
return /* @__PURE__ */ jsxs("label", { id, htmlFor, className: "flex items-center gap-1.5 text-sm font-medium text-fg", children: [
|
|
8
|
+
label,
|
|
9
|
+
tooltip && /* @__PURE__ */ jsx(Tooltip, { content: tooltip, children: /* @__PURE__ */ jsxs(
|
|
10
|
+
"svg",
|
|
11
|
+
{
|
|
12
|
+
"aria-hidden": "true",
|
|
13
|
+
className: "h-3.5 w-3.5 text-muted",
|
|
14
|
+
fill: "none",
|
|
15
|
+
stroke: "currentColor",
|
|
16
|
+
viewBox: "0 0 24 24",
|
|
17
|
+
children: [
|
|
18
|
+
/* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "10", strokeWidth: 2 }),
|
|
19
|
+
/* @__PURE__ */ jsx("path", { strokeLinecap: "round", strokeWidth: 2, d: "M12 16v-4m0-4h.01" })
|
|
20
|
+
]
|
|
21
|
+
}
|
|
22
|
+
) })
|
|
23
|
+
] });
|
|
24
|
+
}
|
|
25
|
+
const FormLabel = memo(FormLabelInner);
|
|
26
|
+
|
|
27
|
+
export { FormLabel };
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { JSX } from 'react';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Props for the Github component
|
|
6
|
+
*/
|
|
7
|
+
interface GithubProps {
|
|
8
|
+
/** Repository in owner/name format */
|
|
9
|
+
repo: string;
|
|
10
|
+
}
|
|
11
|
+
declare function GithubComponent({ repo }: GithubProps): JSX.Element;
|
|
12
|
+
declare const Github: react.MemoExoticComponent<typeof GithubComponent>;
|
|
13
|
+
|
|
14
|
+
export { Github, type GithubProps };
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { memo, useState, useEffect } from 'react';
|
|
4
|
+
|
|
5
|
+
function format(n) {
|
|
6
|
+
if (n >= 1e3) {
|
|
7
|
+
return `${(n / 1e3).toFixed(1)}k`;
|
|
8
|
+
}
|
|
9
|
+
return n.toString();
|
|
10
|
+
}
|
|
11
|
+
function GithubComponent({ repo }) {
|
|
12
|
+
const [data, setData] = useState(null);
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
let mounted = true;
|
|
15
|
+
async function load() {
|
|
16
|
+
try {
|
|
17
|
+
const res = await fetch(`https://api.github.com/repos/${repo}`);
|
|
18
|
+
if (!res.ok || !mounted) return;
|
|
19
|
+
const json = await res.json();
|
|
20
|
+
if (!mounted) return;
|
|
21
|
+
const stars = typeof json.stargazers_count === "number" ? json.stargazers_count : 0;
|
|
22
|
+
const forks = typeof json.forks_count === "number" ? json.forks_count : 0;
|
|
23
|
+
setData({
|
|
24
|
+
stars,
|
|
25
|
+
forks,
|
|
26
|
+
description: json.description ?? null
|
|
27
|
+
});
|
|
28
|
+
} catch {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
load();
|
|
33
|
+
return () => {
|
|
34
|
+
mounted = false;
|
|
35
|
+
};
|
|
36
|
+
}, [repo]);
|
|
37
|
+
if (!data) {
|
|
38
|
+
return /* @__PURE__ */ jsxs(
|
|
39
|
+
"div",
|
|
40
|
+
{
|
|
41
|
+
role: "status",
|
|
42
|
+
"aria-live": "polite",
|
|
43
|
+
"aria-busy": "true",
|
|
44
|
+
"aria-label": `Loading ${repo} repository`,
|
|
45
|
+
className: "my-4 p-4 rounded-lg border border-line bg-surface/50 animate-pulse",
|
|
46
|
+
children: [
|
|
47
|
+
/* @__PURE__ */ jsx("div", { className: "h-4 bg-surface rounded w-1/3 mb-2", "aria-hidden": "true" }),
|
|
48
|
+
/* @__PURE__ */ jsx("div", { className: "h-3 bg-surface/50 rounded w-2/3", "aria-hidden": "true" })
|
|
49
|
+
]
|
|
50
|
+
}
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
return /* @__PURE__ */ jsxs(
|
|
54
|
+
"a",
|
|
55
|
+
{
|
|
56
|
+
href: `https://github.com/${repo}`,
|
|
57
|
+
target: "_blank",
|
|
58
|
+
rel: "noopener noreferrer",
|
|
59
|
+
"aria-label": `View ${repo} repository on GitHub with ${format(data.stars)} stars and ${format(data.forks)} forks`,
|
|
60
|
+
className: "my-4 p-4 rounded-lg border border-line bg-surface/30 hover:bg-surface/50 transition-colors flex items-start gap-4 no-underline",
|
|
61
|
+
children: [
|
|
62
|
+
/* @__PURE__ */ jsx(
|
|
63
|
+
"svg",
|
|
64
|
+
{
|
|
65
|
+
className: "w-6 h-6 text-fg shrink-0 mt-0.5",
|
|
66
|
+
fill: "currentColor",
|
|
67
|
+
viewBox: "0 0 24 24",
|
|
68
|
+
"aria-hidden": "true",
|
|
69
|
+
children: /* @__PURE__ */ jsx(
|
|
70
|
+
"path",
|
|
71
|
+
{
|
|
72
|
+
fillRule: "evenodd",
|
|
73
|
+
d: "M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z",
|
|
74
|
+
clipRule: "evenodd"
|
|
75
|
+
}
|
|
76
|
+
)
|
|
77
|
+
}
|
|
78
|
+
),
|
|
79
|
+
/* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0", children: [
|
|
80
|
+
/* @__PURE__ */ jsx("p", { className: "text-sm font-medium text-fg mb-1", children: repo }),
|
|
81
|
+
data.description && /* @__PURE__ */ jsx("p", { className: "text-xs text-muted mb-2 line-clamp-2", children: data.description }),
|
|
82
|
+
/* @__PURE__ */ jsxs("div", { className: "flex items-center gap-4 text-xs text-muted", "aria-hidden": "true", children: [
|
|
83
|
+
/* @__PURE__ */ jsxs("span", { className: "flex items-center gap-1", children: [
|
|
84
|
+
/* @__PURE__ */ jsx("svg", { className: "w-4 h-4", fill: "currentColor", viewBox: "0 0 16 16", "aria-hidden": "true", children: /* @__PURE__ */ jsx("path", { d: "M8 .25a.75.75 0 01.673.418l1.882 3.815 4.21.612a.75.75 0 01.416 1.279l-3.046 2.97.719 4.192a.75.75 0 01-1.088.791L8 12.347l-3.766 1.98a.75.75 0 01-1.088-.79l.72-4.194L.818 6.374a.75.75 0 01.416-1.28l4.21-.611L7.327.668A.75.75 0 018 .25z" }) }),
|
|
85
|
+
format(data.stars)
|
|
86
|
+
] }),
|
|
87
|
+
/* @__PURE__ */ jsxs("span", { className: "flex items-center gap-1", children: [
|
|
88
|
+
/* @__PURE__ */ jsx("svg", { className: "w-4 h-4", fill: "currentColor", viewBox: "0 0 16 16", "aria-hidden": "true", children: /* @__PURE__ */ jsx("path", { d: "M5 5.372v.878c0 .414.336.75.75.75h4.5a.75.75 0 00.75-.75v-.878a2.25 2.25 0 111.5 0v.878a2.25 2.25 0 01-2.25 2.25h-1.5v2.128a2.251 2.251 0 11-1.5 0V8.5h-1.5A2.25 2.25 0 013.5 6.25v-.878a2.25 2.25 0 111.5 0zM5 3.25a.75.75 0 10-1.5 0 .75.75 0 001.5 0zm6.75.75a.75.75 0 10.75-.75.75.75 0 00-.75.75z" }) }),
|
|
89
|
+
format(data.forks)
|
|
90
|
+
] })
|
|
91
|
+
] })
|
|
92
|
+
] })
|
|
93
|
+
]
|
|
94
|
+
}
|
|
95
|
+
);
|
|
96
|
+
}
|
|
97
|
+
const Github = memo(GithubComponent);
|
|
98
|
+
|
|
99
|
+
export { Github };
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { JSX } from 'react';
|
|
2
|
+
|
|
3
|
+
/** Node in the graph visualization */
|
|
4
|
+
interface GraphNode {
|
|
5
|
+
/** Unique identifier for the node */
|
|
6
|
+
id: string;
|
|
7
|
+
/** Display title shown below the node */
|
|
8
|
+
title: string;
|
|
9
|
+
/** Optional grouping category */
|
|
10
|
+
group?: string;
|
|
11
|
+
}
|
|
12
|
+
/** Connection between two nodes */
|
|
13
|
+
interface GraphLink {
|
|
14
|
+
/** ID of the source node */
|
|
15
|
+
source: string;
|
|
16
|
+
/** ID of the target node */
|
|
17
|
+
target: string;
|
|
18
|
+
}
|
|
19
|
+
/** Props for the Graph component */
|
|
20
|
+
interface GraphProps {
|
|
21
|
+
/** Array of nodes to display */
|
|
22
|
+
nodes: GraphNode[];
|
|
23
|
+
/** Array of links connecting nodes */
|
|
24
|
+
links: GraphLink[];
|
|
25
|
+
/** Callback when a node is clicked or activated */
|
|
26
|
+
onNodeClick?: (node: GraphNode) => void;
|
|
27
|
+
/** Canvas width in pixels */
|
|
28
|
+
width?: number;
|
|
29
|
+
/** Canvas height in pixels */
|
|
30
|
+
height?: number;
|
|
31
|
+
/** Accessible label for the graph */
|
|
32
|
+
label?: string;
|
|
33
|
+
}
|
|
34
|
+
declare function Graph({ nodes, links, onNodeClick, width, height, label, }: GraphProps): JSX.Element;
|
|
35
|
+
|
|
36
|
+
export { Graph, type GraphLink, type GraphNode, type GraphProps };
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { useRef, useState, useEffect, useCallback } from 'react';
|
|
4
|
+
|
|
5
|
+
const NODE_RADIUS = 8;
|
|
6
|
+
const HIT_RADIUS = NODE_RADIUS + 4;
|
|
7
|
+
function Graph({
|
|
8
|
+
nodes,
|
|
9
|
+
links,
|
|
10
|
+
onNodeClick,
|
|
11
|
+
width = 600,
|
|
12
|
+
height = 400,
|
|
13
|
+
label = "Graph visualization"
|
|
14
|
+
}) {
|
|
15
|
+
const canvasRef = useRef(null);
|
|
16
|
+
const [positions, setPositions] = useState(/* @__PURE__ */ new Map());
|
|
17
|
+
const [hovered, setHovered] = useState(null);
|
|
18
|
+
const [focused, setFocused] = useState(-1);
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
const newPositions = /* @__PURE__ */ new Map();
|
|
21
|
+
nodes.forEach((node, i) => {
|
|
22
|
+
const angle = 2 * Math.PI * i / nodes.length;
|
|
23
|
+
const radius = Math.min(width, height) * 0.35;
|
|
24
|
+
newPositions.set(node.id, {
|
|
25
|
+
x: width / 2 + radius * Math.cos(angle),
|
|
26
|
+
y: height / 2 + radius * Math.sin(angle)
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
setPositions(newPositions);
|
|
30
|
+
}, [nodes, width, height]);
|
|
31
|
+
const draw = useCallback(() => {
|
|
32
|
+
const canvas = canvasRef.current;
|
|
33
|
+
if (!canvas) return;
|
|
34
|
+
const ctx = canvas.getContext("2d");
|
|
35
|
+
if (!ctx) return;
|
|
36
|
+
const dpr = window.devicePixelRatio || 1;
|
|
37
|
+
canvas.width = width * dpr;
|
|
38
|
+
canvas.height = height * dpr;
|
|
39
|
+
ctx.scale(dpr, dpr);
|
|
40
|
+
ctx.clearRect(0, 0, width, height);
|
|
41
|
+
ctx.strokeStyle = "#333";
|
|
42
|
+
ctx.lineWidth = 1;
|
|
43
|
+
for (const link of links) {
|
|
44
|
+
const source = positions.get(link.source);
|
|
45
|
+
const target = positions.get(link.target);
|
|
46
|
+
if (!source || !target) continue;
|
|
47
|
+
ctx.beginPath();
|
|
48
|
+
ctx.moveTo(source.x, source.y);
|
|
49
|
+
ctx.lineTo(target.x, target.y);
|
|
50
|
+
ctx.stroke();
|
|
51
|
+
}
|
|
52
|
+
for (let i = 0; i < nodes.length; i++) {
|
|
53
|
+
const node = nodes[i];
|
|
54
|
+
if (!node) continue;
|
|
55
|
+
const pos = positions.get(node.id);
|
|
56
|
+
if (!pos) continue;
|
|
57
|
+
const isHovered = hovered === node.id;
|
|
58
|
+
const isFocused = focused === i;
|
|
59
|
+
ctx.beginPath();
|
|
60
|
+
ctx.arc(pos.x, pos.y, NODE_RADIUS, 0, 2 * Math.PI);
|
|
61
|
+
ctx.fillStyle = isHovered || isFocused ? "#1a1a1a" : "#0a0a0a";
|
|
62
|
+
ctx.fill();
|
|
63
|
+
ctx.strokeStyle = isHovered || isFocused ? "#888" : "#666";
|
|
64
|
+
ctx.lineWidth = isHovered || isFocused ? 3 : 2;
|
|
65
|
+
ctx.stroke();
|
|
66
|
+
if (isFocused) {
|
|
67
|
+
ctx.beginPath();
|
|
68
|
+
ctx.arc(pos.x, pos.y, NODE_RADIUS + 4, 0, 2 * Math.PI);
|
|
69
|
+
ctx.strokeStyle = "#4f9";
|
|
70
|
+
ctx.lineWidth = 2;
|
|
71
|
+
ctx.stroke();
|
|
72
|
+
}
|
|
73
|
+
ctx.fillStyle = isHovered || isFocused ? "#ccc" : "#999";
|
|
74
|
+
ctx.font = "12px system-ui";
|
|
75
|
+
ctx.textAlign = "center";
|
|
76
|
+
ctx.fillText(node.title, pos.x, pos.y + 24);
|
|
77
|
+
}
|
|
78
|
+
}, [nodes, links, positions, width, height, hovered, focused]);
|
|
79
|
+
useEffect(() => {
|
|
80
|
+
draw();
|
|
81
|
+
}, [draw]);
|
|
82
|
+
const findNode = useCallback(
|
|
83
|
+
(x, y) => {
|
|
84
|
+
for (const node of nodes) {
|
|
85
|
+
const pos = positions.get(node.id);
|
|
86
|
+
if (!pos) continue;
|
|
87
|
+
const dx = x - pos.x;
|
|
88
|
+
const dy = y - pos.y;
|
|
89
|
+
if (dx * dx + dy * dy < HIT_RADIUS * HIT_RADIUS) {
|
|
90
|
+
return node;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
return null;
|
|
94
|
+
},
|
|
95
|
+
[nodes, positions]
|
|
96
|
+
);
|
|
97
|
+
const handleClick = useCallback(
|
|
98
|
+
(e) => {
|
|
99
|
+
if (!onNodeClick) return;
|
|
100
|
+
const rect = canvasRef.current?.getBoundingClientRect();
|
|
101
|
+
if (!rect) return;
|
|
102
|
+
const x = e.clientX - rect.left;
|
|
103
|
+
const y = e.clientY - rect.top;
|
|
104
|
+
const node = findNode(x, y);
|
|
105
|
+
if (node) onNodeClick(node);
|
|
106
|
+
},
|
|
107
|
+
[onNodeClick, findNode]
|
|
108
|
+
);
|
|
109
|
+
const handleMove = useCallback(
|
|
110
|
+
(e) => {
|
|
111
|
+
const rect = canvasRef.current?.getBoundingClientRect();
|
|
112
|
+
if (!rect) return;
|
|
113
|
+
const x = e.clientX - rect.left;
|
|
114
|
+
const y = e.clientY - rect.top;
|
|
115
|
+
const node = findNode(x, y);
|
|
116
|
+
setHovered(node?.id ?? null);
|
|
117
|
+
},
|
|
118
|
+
[findNode]
|
|
119
|
+
);
|
|
120
|
+
const handleLeave = useCallback(() => {
|
|
121
|
+
setHovered(null);
|
|
122
|
+
}, []);
|
|
123
|
+
const handleKeyDown = useCallback(
|
|
124
|
+
(e) => {
|
|
125
|
+
if (nodes.length === 0) return;
|
|
126
|
+
switch (e.key) {
|
|
127
|
+
case "ArrowRight":
|
|
128
|
+
case "ArrowDown":
|
|
129
|
+
case "Tab": {
|
|
130
|
+
if (e.key === "Tab" && e.shiftKey) {
|
|
131
|
+
e.preventDefault();
|
|
132
|
+
setFocused((prev) => (prev - 1 + nodes.length) % nodes.length);
|
|
133
|
+
} else if (e.key === "Tab") {
|
|
134
|
+
e.preventDefault();
|
|
135
|
+
setFocused((prev) => (prev + 1) % nodes.length);
|
|
136
|
+
} else {
|
|
137
|
+
e.preventDefault();
|
|
138
|
+
setFocused((prev) => (prev + 1) % nodes.length);
|
|
139
|
+
}
|
|
140
|
+
break;
|
|
141
|
+
}
|
|
142
|
+
case "ArrowLeft":
|
|
143
|
+
case "ArrowUp": {
|
|
144
|
+
e.preventDefault();
|
|
145
|
+
setFocused((prev) => (prev - 1 + nodes.length) % nodes.length);
|
|
146
|
+
break;
|
|
147
|
+
}
|
|
148
|
+
case "Home": {
|
|
149
|
+
e.preventDefault();
|
|
150
|
+
setFocused(0);
|
|
151
|
+
break;
|
|
152
|
+
}
|
|
153
|
+
case "End": {
|
|
154
|
+
e.preventDefault();
|
|
155
|
+
setFocused(nodes.length - 1);
|
|
156
|
+
break;
|
|
157
|
+
}
|
|
158
|
+
case "Enter":
|
|
159
|
+
case " ": {
|
|
160
|
+
if (focused >= 0 && onNodeClick) {
|
|
161
|
+
e.preventDefault();
|
|
162
|
+
const node = nodes[focused];
|
|
163
|
+
if (node) onNodeClick(node);
|
|
164
|
+
}
|
|
165
|
+
break;
|
|
166
|
+
}
|
|
167
|
+
case "Escape": {
|
|
168
|
+
e.preventDefault();
|
|
169
|
+
setFocused(-1);
|
|
170
|
+
canvasRef.current?.blur();
|
|
171
|
+
break;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
},
|
|
175
|
+
[nodes, focused, onNodeClick]
|
|
176
|
+
);
|
|
177
|
+
const handleFocus = useCallback(() => {
|
|
178
|
+
if (focused < 0 && nodes.length > 0) {
|
|
179
|
+
setFocused(0);
|
|
180
|
+
}
|
|
181
|
+
}, [focused, nodes.length]);
|
|
182
|
+
const handleBlur = useCallback(() => {
|
|
183
|
+
setFocused(-1);
|
|
184
|
+
}, []);
|
|
185
|
+
return /* @__PURE__ */ jsx(
|
|
186
|
+
"canvas",
|
|
187
|
+
{
|
|
188
|
+
ref: canvasRef,
|
|
189
|
+
width,
|
|
190
|
+
height,
|
|
191
|
+
onClick: handleClick,
|
|
192
|
+
onMouseMove: handleMove,
|
|
193
|
+
onMouseLeave: handleLeave,
|
|
194
|
+
onKeyDown: handleKeyDown,
|
|
195
|
+
onFocus: handleFocus,
|
|
196
|
+
onBlur: handleBlur,
|
|
197
|
+
tabIndex: onNodeClick ? 0 : -1,
|
|
198
|
+
role: "img",
|
|
199
|
+
"aria-label": label,
|
|
200
|
+
className: "rounded-lg border border-line bg-bg outline-none focus-visible:ring-2 focus-visible:ring-green-400",
|
|
201
|
+
style: {
|
|
202
|
+
cursor: hovered && onNodeClick ? "pointer" : "default",
|
|
203
|
+
width,
|
|
204
|
+
height
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
export { Graph };
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { ReactNode, JSX } from 'react';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Props for the Anchor component
|
|
6
|
+
*/
|
|
7
|
+
interface AnchorProps {
|
|
8
|
+
/** Heading level (1-6) */
|
|
9
|
+
level: 1 | 2 | 3 | 4 | 5 | 6;
|
|
10
|
+
/** Unique identifier for the anchor link */
|
|
11
|
+
id: string;
|
|
12
|
+
/** Content to display inside the heading */
|
|
13
|
+
children: ReactNode;
|
|
14
|
+
/** Optional additional CSS classes */
|
|
15
|
+
className?: string;
|
|
16
|
+
}
|
|
17
|
+
declare const Anchor: react.NamedExoticComponent<AnchorProps>;
|
|
18
|
+
declare function H1(props: Omit<AnchorProps, "level">): JSX.Element;
|
|
19
|
+
declare function H2(props: Omit<AnchorProps, "level">): JSX.Element;
|
|
20
|
+
declare function H3(props: Omit<AnchorProps, "level">): JSX.Element;
|
|
21
|
+
declare function H4(props: Omit<AnchorProps, "level">): JSX.Element;
|
|
22
|
+
declare function H5(props: Omit<AnchorProps, "level">): JSX.Element;
|
|
23
|
+
declare function H6(props: Omit<AnchorProps, "level">): JSX.Element;
|
|
24
|
+
|
|
25
|
+
export { Anchor, type AnchorProps, H1, H2, H3, H4, H5, H6 };
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { memo, useCallback } from 'react';
|
|
4
|
+
import { useCopy } from '../hooks/copy';
|
|
5
|
+
|
|
6
|
+
const sizes = {
|
|
7
|
+
1: "text-3xl font-bold",
|
|
8
|
+
2: "text-2xl font-semibold",
|
|
9
|
+
3: "text-xl font-semibold",
|
|
10
|
+
4: "text-lg font-medium",
|
|
11
|
+
5: "text-base font-medium",
|
|
12
|
+
6: "text-sm font-medium"
|
|
13
|
+
};
|
|
14
|
+
const Anchor = memo(function Anchor2({
|
|
15
|
+
level,
|
|
16
|
+
id,
|
|
17
|
+
children,
|
|
18
|
+
className
|
|
19
|
+
}) {
|
|
20
|
+
const { copied, copy } = useCopy();
|
|
21
|
+
const Tag = `h${level}`;
|
|
22
|
+
const handleClick = useCallback(
|
|
23
|
+
(e) => {
|
|
24
|
+
e.preventDefault();
|
|
25
|
+
const url = `${window.location.origin}${window.location.pathname}#${id}`;
|
|
26
|
+
copy(url);
|
|
27
|
+
window.history.pushState(null, "", `#${id}`);
|
|
28
|
+
},
|
|
29
|
+
[id, copy]
|
|
30
|
+
);
|
|
31
|
+
return /* @__PURE__ */ jsxs(Tag, { id, className: `group relative scroll-mt-20 ${sizes[level]} ${className || ""}`, children: [
|
|
32
|
+
/* @__PURE__ */ jsx(
|
|
33
|
+
"a",
|
|
34
|
+
{
|
|
35
|
+
href: `#${id}`,
|
|
36
|
+
onClick: handleClick,
|
|
37
|
+
className: "absolute -left-6 top-1/2 -translate-y-1/2 opacity-0 group-hover:opacity-100 transition-opacity",
|
|
38
|
+
"aria-label": "copy link",
|
|
39
|
+
children: copied ? /* @__PURE__ */ jsx(
|
|
40
|
+
"svg",
|
|
41
|
+
{
|
|
42
|
+
"aria-hidden": "true",
|
|
43
|
+
viewBox: "0 0 16 16",
|
|
44
|
+
fill: "currentColor",
|
|
45
|
+
className: "size-4 text-green-500",
|
|
46
|
+
children: /* @__PURE__ */ jsx("path", { d: "M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z" })
|
|
47
|
+
}
|
|
48
|
+
) : /* @__PURE__ */ jsx(
|
|
49
|
+
"svg",
|
|
50
|
+
{
|
|
51
|
+
"aria-hidden": "true",
|
|
52
|
+
viewBox: "0 0 16 16",
|
|
53
|
+
fill: "currentColor",
|
|
54
|
+
className: "size-4 text-fg/40 hover:text-fg/60",
|
|
55
|
+
children: /* @__PURE__ */ jsx("path", { d: "M7.775 3.275a.75.75 0 001.06 1.06l1.25-1.25a2 2 0 112.83 2.83l-2.5 2.5a2 2 0 01-2.83 0 .75.75 0 00-1.06 1.06 3.5 3.5 0 004.95 0l2.5-2.5a3.5 3.5 0 00-4.95-4.95l-1.25 1.25zm-4.69 9.64a2 2 0 010-2.83l2.5-2.5a2 2 0 012.83 0 .75.75 0 001.06-1.06 3.5 3.5 0 00-4.95 0l-2.5 2.5a3.5 3.5 0 004.95 4.95l1.25-1.25a.75.75 0 00-1.06-1.06l-1.25 1.25a2 2 0 01-2.83 0z" })
|
|
56
|
+
}
|
|
57
|
+
)
|
|
58
|
+
}
|
|
59
|
+
),
|
|
60
|
+
children
|
|
61
|
+
] });
|
|
62
|
+
});
|
|
63
|
+
function H1(props) {
|
|
64
|
+
return /* @__PURE__ */ jsx(Anchor, { level: 1, ...props });
|
|
65
|
+
}
|
|
66
|
+
function H2(props) {
|
|
67
|
+
return /* @__PURE__ */ jsx(Anchor, { level: 2, ...props });
|
|
68
|
+
}
|
|
69
|
+
function H3(props) {
|
|
70
|
+
return /* @__PURE__ */ jsx(Anchor, { level: 3, ...props });
|
|
71
|
+
}
|
|
72
|
+
function H4(props) {
|
|
73
|
+
return /* @__PURE__ */ jsx(Anchor, { level: 4, ...props });
|
|
74
|
+
}
|
|
75
|
+
function H5(props) {
|
|
76
|
+
return /* @__PURE__ */ jsx(Anchor, { level: 5, ...props });
|
|
77
|
+
}
|
|
78
|
+
function H6(props) {
|
|
79
|
+
return /* @__PURE__ */ jsx(Anchor, { level: 6, ...props });
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
export { Anchor, H1, H2, H3, H4, H5, H6 };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { useEffect } from 'react';
|
|
3
|
+
|
|
4
|
+
function HeadingCopy() {
|
|
5
|
+
useEffect(() => {
|
|
6
|
+
function handler(e) {
|
|
7
|
+
const target = e.target;
|
|
8
|
+
if (!(target instanceof HTMLElement)) return;
|
|
9
|
+
if (!target.classList.contains("heading-anchor-icon")) return;
|
|
10
|
+
e.preventDefault();
|
|
11
|
+
const anchor = target.closest("a");
|
|
12
|
+
if (!anchor) return;
|
|
13
|
+
const id = anchor.getAttribute("href")?.replace("#", "");
|
|
14
|
+
if (!id) return;
|
|
15
|
+
const url = window.location.origin + window.location.pathname + "#" + id;
|
|
16
|
+
navigator.clipboard.writeText(url).then(() => {
|
|
17
|
+
const original = target.textContent;
|
|
18
|
+
target.textContent = "\u2713";
|
|
19
|
+
setTimeout(() => {
|
|
20
|
+
target.textContent = original;
|
|
21
|
+
}, 1500);
|
|
22
|
+
}).catch(() => {
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
document.addEventListener("click", handler);
|
|
26
|
+
return () => document.removeEventListener("click", handler);
|
|
27
|
+
}, []);
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export { HeadingCopy };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
|
|
3
|
+
interface HeroProps {
|
|
4
|
+
title: string;
|
|
5
|
+
description?: string;
|
|
6
|
+
actions?: {
|
|
7
|
+
label: string;
|
|
8
|
+
href: string;
|
|
9
|
+
variant?: "primary" | "secondary";
|
|
10
|
+
}[];
|
|
11
|
+
badge?: string;
|
|
12
|
+
className?: string;
|
|
13
|
+
}
|
|
14
|
+
declare const Hero: react.NamedExoticComponent<HeroProps>;
|
|
15
|
+
|
|
16
|
+
export { Hero, type HeroProps };
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { memo } from 'react';
|
|
4
|
+
|
|
5
|
+
const Hero = memo(function Hero2({
|
|
6
|
+
title,
|
|
7
|
+
description,
|
|
8
|
+
actions,
|
|
9
|
+
badge,
|
|
10
|
+
className
|
|
11
|
+
}) {
|
|
12
|
+
return /* @__PURE__ */ jsxs("div", { className: `flex flex-col items-center px-6 py-20 text-center ${className ?? ""}`, children: [
|
|
13
|
+
badge && /* @__PURE__ */ jsx("span", { className: "mb-4 rounded-full border border-line px-3 py-1 text-xs text-muted", children: badge }),
|
|
14
|
+
/* @__PURE__ */ jsx("h1", { className: "max-w-3xl text-4xl font-bold tracking-tight text-fg sm:text-5xl lg:text-6xl", children: title }),
|
|
15
|
+
description && /* @__PURE__ */ jsx("p", { className: "mt-6 max-w-2xl text-lg text-muted", children: description }),
|
|
16
|
+
actions && actions.length > 0 && /* @__PURE__ */ jsx("div", { className: "mt-8 flex flex-wrap items-center justify-center gap-3", children: actions.map((action) => /* @__PURE__ */ jsx(
|
|
17
|
+
"a",
|
|
18
|
+
{
|
|
19
|
+
href: action.href,
|
|
20
|
+
className: action.variant === "secondary" ? "rounded-lg border border-line bg-surface px-5 py-2.5 text-sm font-medium text-fg transition-colors hover:bg-surface/80" : "rounded-lg bg-accent px-5 py-2.5 text-sm font-medium text-white transition-colors hover:bg-accent/90",
|
|
21
|
+
children: action.label
|
|
22
|
+
},
|
|
23
|
+
action.href
|
|
24
|
+
)) })
|
|
25
|
+
] });
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
export { Hero };
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { ReactNode, JSX } from 'react';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Available highlight colors for the Highlight component
|
|
6
|
+
*/
|
|
7
|
+
type HighlightColor = "yellow" | "green" | "blue" | "red" | "purple";
|
|
8
|
+
/**
|
|
9
|
+
* Props for the Highlight component
|
|
10
|
+
*/
|
|
11
|
+
interface HighlightProps {
|
|
12
|
+
/** Content to highlight */
|
|
13
|
+
children: ReactNode;
|
|
14
|
+
/** Highlight color variant */
|
|
15
|
+
color?: HighlightColor;
|
|
16
|
+
}
|
|
17
|
+
declare function HighlightBase({ children, color }: HighlightProps): JSX.Element;
|
|
18
|
+
/**
|
|
19
|
+
* Renders highlighted text with customizable color
|
|
20
|
+
*/
|
|
21
|
+
declare const Highlight: react.MemoExoticComponent<typeof HighlightBase>;
|
|
22
|
+
/**
|
|
23
|
+
* Available underline styles for the Underline component
|
|
24
|
+
*/
|
|
25
|
+
type UnderlineStyle = "solid" | "wavy" | "dotted" | "dashed";
|
|
26
|
+
/**
|
|
27
|
+
* Props for the Underline component
|
|
28
|
+
*/
|
|
29
|
+
interface UnderlineProps {
|
|
30
|
+
/** Content to underline */
|
|
31
|
+
children: ReactNode;
|
|
32
|
+
/** Underline style variant */
|
|
33
|
+
style?: UnderlineStyle;
|
|
34
|
+
}
|
|
35
|
+
declare function UnderlineBase({ children, style }: UnderlineProps): JSX.Element;
|
|
36
|
+
/**
|
|
37
|
+
* Renders underlined text with customizable style
|
|
38
|
+
*/
|
|
39
|
+
declare const Underline: react.MemoExoticComponent<typeof UnderlineBase>;
|
|
40
|
+
|
|
41
|
+
export { Highlight, type HighlightColor, type HighlightProps, Underline, type UnderlineProps, type UnderlineStyle };
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { memo } from 'react';
|
|
3
|
+
|
|
4
|
+
const colors = {
|
|
5
|
+
yellow: "bg-yellow-500/20 text-yellow-200",
|
|
6
|
+
green: "bg-green-500/20 text-green-200",
|
|
7
|
+
blue: "bg-blue-500/20 text-blue-200",
|
|
8
|
+
red: "bg-red-500/20 text-red-200",
|
|
9
|
+
purple: "bg-purple-500/20 text-purple-200"
|
|
10
|
+
};
|
|
11
|
+
function HighlightBase({ children, color = "yellow" }) {
|
|
12
|
+
return /* @__PURE__ */ jsx(
|
|
13
|
+
"mark",
|
|
14
|
+
{
|
|
15
|
+
className: `rounded px-1 transition-colors ${colors[color]}`,
|
|
16
|
+
role: "mark",
|
|
17
|
+
"aria-label": `highlighted text in ${color}`,
|
|
18
|
+
children
|
|
19
|
+
}
|
|
20
|
+
);
|
|
21
|
+
}
|
|
22
|
+
const Highlight = memo(HighlightBase);
|
|
23
|
+
const underlineStyles = {
|
|
24
|
+
solid: "decoration-solid",
|
|
25
|
+
wavy: "decoration-wavy",
|
|
26
|
+
dotted: "decoration-dotted",
|
|
27
|
+
dashed: "decoration-dashed"
|
|
28
|
+
};
|
|
29
|
+
function UnderlineBase({ children, style = "solid" }) {
|
|
30
|
+
return /* @__PURE__ */ jsx(
|
|
31
|
+
"span",
|
|
32
|
+
{
|
|
33
|
+
className: `underline decoration-accent underline-offset-4 transition-colors ${underlineStyles[style]}`,
|
|
34
|
+
role: "text",
|
|
35
|
+
"aria-label": `underlined text with ${style} style`,
|
|
36
|
+
children
|
|
37
|
+
}
|
|
38
|
+
);
|
|
39
|
+
}
|
|
40
|
+
const Underline = memo(UnderlineBase);
|
|
41
|
+
|
|
42
|
+
export { Highlight, Underline };
|