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,44 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
3
|
+
import { useToc } from './hook';
|
|
4
|
+
export { useToc } from './hook';
|
|
5
|
+
import { TocDefault } from './default';
|
|
6
|
+
import { TocMinimal } from './minimal';
|
|
7
|
+
import { TocInline } from './inline';
|
|
8
|
+
|
|
9
|
+
function Toc({
|
|
10
|
+
variant = "default",
|
|
11
|
+
zigzag = false,
|
|
12
|
+
multi = false,
|
|
13
|
+
title,
|
|
14
|
+
collapsible = true,
|
|
15
|
+
defaultOpen = false
|
|
16
|
+
}) {
|
|
17
|
+
const { headings, active, activeRange } = useToc(variant !== "minimal" && multi);
|
|
18
|
+
if (headings.length === 0) return null;
|
|
19
|
+
if (variant === "inline") {
|
|
20
|
+
return /* @__PURE__ */ jsx(
|
|
21
|
+
TocInline,
|
|
22
|
+
{
|
|
23
|
+
headings,
|
|
24
|
+
title,
|
|
25
|
+
collapsible,
|
|
26
|
+
defaultOpen
|
|
27
|
+
}
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
return /* @__PURE__ */ jsx("aside", { className: "w-56 shrink-0 hidden lg:block py-12 pl-8", children: /* @__PURE__ */ jsxs("div", { className: "sticky top-12", children: [
|
|
31
|
+
/* @__PURE__ */ jsx("p", { className: "text-xs text-muted mb-4", children: "on this page" }),
|
|
32
|
+
variant === "minimal" ? /* @__PURE__ */ jsx(TocMinimal, { headings, active, zigzag }) : /* @__PURE__ */ jsx(
|
|
33
|
+
TocDefault,
|
|
34
|
+
{
|
|
35
|
+
headings,
|
|
36
|
+
active,
|
|
37
|
+
activeRange,
|
|
38
|
+
zigzag
|
|
39
|
+
}
|
|
40
|
+
)
|
|
41
|
+
] }) });
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export { Toc };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { Heading } from './hook.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* props for the inline table of contents component
|
|
6
|
+
*/
|
|
7
|
+
interface TocInlineProps {
|
|
8
|
+
/** list of headings to display */
|
|
9
|
+
headings: Heading[];
|
|
10
|
+
/** title shown above the toc */
|
|
11
|
+
title?: string;
|
|
12
|
+
/** whether the toc can be collapsed */
|
|
13
|
+
collapsible?: boolean;
|
|
14
|
+
/** initial open state when collapsible */
|
|
15
|
+
defaultOpen?: boolean;
|
|
16
|
+
}
|
|
17
|
+
declare function TocInlineBase({ headings, title, collapsible, defaultOpen, }: TocInlineProps): React.ReactElement | null;
|
|
18
|
+
declare const TocInline: react.MemoExoticComponent<typeof TocInlineBase>;
|
|
19
|
+
|
|
20
|
+
export { TocInline, type TocInlineProps };
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
3
|
+
import { memo, useState, useCallback } from 'react';
|
|
4
|
+
|
|
5
|
+
function TocInlineBase({
|
|
6
|
+
headings,
|
|
7
|
+
title = "on this page",
|
|
8
|
+
collapsible = true,
|
|
9
|
+
defaultOpen = false
|
|
10
|
+
}) {
|
|
11
|
+
const [open, setOpen] = useState(defaultOpen);
|
|
12
|
+
const toggle = useCallback(() => {
|
|
13
|
+
setOpen((prev) => !prev);
|
|
14
|
+
}, []);
|
|
15
|
+
if (headings.length === 0) return null;
|
|
16
|
+
const content = /* @__PURE__ */ jsx("div", { className: "flex flex-col text-sm text-muted", children: headings.map((heading) => /* @__PURE__ */ jsx(
|
|
17
|
+
"a",
|
|
18
|
+
{
|
|
19
|
+
href: `#${heading.id}`,
|
|
20
|
+
className: "border-l border-line py-1.5 hover:text-fg transition-colors",
|
|
21
|
+
style: { paddingLeft: 12 * Math.max(heading.level - 1, 1) },
|
|
22
|
+
children: heading.text
|
|
23
|
+
},
|
|
24
|
+
heading.id
|
|
25
|
+
)) });
|
|
26
|
+
if (!collapsible) {
|
|
27
|
+
return /* @__PURE__ */ jsxs(
|
|
28
|
+
"nav",
|
|
29
|
+
{
|
|
30
|
+
"aria-label": "table of contents",
|
|
31
|
+
className: "my-6 rounded-lg border border-line bg-surface/30 p-4",
|
|
32
|
+
children: [
|
|
33
|
+
/* @__PURE__ */ jsx("p", { className: "text-xs font-medium text-fg mb-3", children: title }),
|
|
34
|
+
content
|
|
35
|
+
]
|
|
36
|
+
}
|
|
37
|
+
);
|
|
38
|
+
}
|
|
39
|
+
return /* @__PURE__ */ jsxs(
|
|
40
|
+
"nav",
|
|
41
|
+
{
|
|
42
|
+
"aria-label": "table of contents",
|
|
43
|
+
className: "my-6 rounded-lg border border-line bg-surface/30",
|
|
44
|
+
children: [
|
|
45
|
+
/* @__PURE__ */ jsxs(
|
|
46
|
+
"button",
|
|
47
|
+
{
|
|
48
|
+
type: "button",
|
|
49
|
+
onClick: toggle,
|
|
50
|
+
"aria-expanded": open,
|
|
51
|
+
className: "w-full flex items-center justify-between px-4 py-3 text-xs font-medium text-fg",
|
|
52
|
+
children: [
|
|
53
|
+
title,
|
|
54
|
+
/* @__PURE__ */ jsx(
|
|
55
|
+
"svg",
|
|
56
|
+
{
|
|
57
|
+
className: `w-4 h-4 transition-transform ${open ? "rotate-180" : ""}`,
|
|
58
|
+
fill: "none",
|
|
59
|
+
viewBox: "0 0 24 24",
|
|
60
|
+
stroke: "currentColor",
|
|
61
|
+
"aria-hidden": "true",
|
|
62
|
+
children: /* @__PURE__ */ jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 9l-7 7-7-7" })
|
|
63
|
+
}
|
|
64
|
+
)
|
|
65
|
+
]
|
|
66
|
+
}
|
|
67
|
+
),
|
|
68
|
+
open && /* @__PURE__ */ jsx("div", { className: "px-4 pb-4", children: content })
|
|
69
|
+
]
|
|
70
|
+
}
|
|
71
|
+
);
|
|
72
|
+
}
|
|
73
|
+
const TocInline = memo(TocInlineBase);
|
|
74
|
+
|
|
75
|
+
export { TocInline };
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { JSX } from 'react';
|
|
3
|
+
import { Heading } from './hook.js';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Props for the TocMinimal component
|
|
7
|
+
*/
|
|
8
|
+
interface Props {
|
|
9
|
+
/** List of headings to display in the table of contents */
|
|
10
|
+
headings: Heading[];
|
|
11
|
+
/** ID of the currently active heading */
|
|
12
|
+
active: string;
|
|
13
|
+
/** Enable zigzag line style instead of default vertical bar */
|
|
14
|
+
zigzag?: boolean;
|
|
15
|
+
}
|
|
16
|
+
declare function TocMinimalBase({ headings, active, zigzag }: Props): JSX.Element;
|
|
17
|
+
/**
|
|
18
|
+
* Minimal table of contents component with scroll progress indicator
|
|
19
|
+
*/
|
|
20
|
+
declare const TocMinimal: react.MemoExoticComponent<typeof TocMinimalBase>;
|
|
21
|
+
|
|
22
|
+
export { TocMinimal };
|
|
@@ -0,0 +1,136 @@
|
|
|
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 TocMinimalBase({ headings, active, zigzag }) {
|
|
7
|
+
const containerRef = useRef(null);
|
|
8
|
+
const thumbRef = useRef(null);
|
|
9
|
+
const progressRef = useRef(null);
|
|
10
|
+
const [svg, setSvg] = useState(null);
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (!zigzag || !containerRef.current || headings.length === 0) return;
|
|
13
|
+
const container = containerRef.current;
|
|
14
|
+
function update() {
|
|
15
|
+
const result = buildZigzagPath(headings, container);
|
|
16
|
+
if (result) setSvg(result);
|
|
17
|
+
}
|
|
18
|
+
const observer = new ResizeObserver(update);
|
|
19
|
+
update();
|
|
20
|
+
observer.observe(container);
|
|
21
|
+
return () => observer.disconnect();
|
|
22
|
+
}, [headings, zigzag]);
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
const container = containerRef.current;
|
|
25
|
+
const thumb = thumbRef.current;
|
|
26
|
+
const progress = progressRef.current;
|
|
27
|
+
if (!container) return;
|
|
28
|
+
let ticking = false;
|
|
29
|
+
function update() {
|
|
30
|
+
const scrollTop = window.scrollY;
|
|
31
|
+
const docHeight = document.documentElement.scrollHeight - window.innerHeight;
|
|
32
|
+
const percent = docHeight > 0 ? scrollTop / docHeight : 0;
|
|
33
|
+
if (progress) {
|
|
34
|
+
progress.style.height = `${percent * 100}%`;
|
|
35
|
+
} else if (thumb && container) {
|
|
36
|
+
const containerHeight = container.offsetHeight;
|
|
37
|
+
const thumbHeight = 12;
|
|
38
|
+
const maxTop = containerHeight - thumbHeight;
|
|
39
|
+
const y = percent * maxTop;
|
|
40
|
+
thumb.style.transform = `translateY(${y}px)`;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
function onScroll() {
|
|
44
|
+
if (!ticking) {
|
|
45
|
+
requestAnimationFrame(() => {
|
|
46
|
+
update();
|
|
47
|
+
ticking = false;
|
|
48
|
+
});
|
|
49
|
+
ticking = true;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
update();
|
|
53
|
+
window.addEventListener("scroll", onScroll, { passive: true });
|
|
54
|
+
window.addEventListener("resize", update, { passive: true });
|
|
55
|
+
return () => {
|
|
56
|
+
window.removeEventListener("scroll", onScroll);
|
|
57
|
+
window.removeEventListener("resize", update);
|
|
58
|
+
};
|
|
59
|
+
}, [svg]);
|
|
60
|
+
if (zigzag) {
|
|
61
|
+
return /* @__PURE__ */ jsxs("nav", { "aria-label": "table of contents", className: "relative", children: [
|
|
62
|
+
svg && /* @__PURE__ */ jsx(
|
|
63
|
+
"div",
|
|
64
|
+
{
|
|
65
|
+
className: "absolute left-0 top-0 pointer-events-none z-10",
|
|
66
|
+
style: {
|
|
67
|
+
width: svg.width,
|
|
68
|
+
height: svg.height,
|
|
69
|
+
maskImage: `url("data:image/svg+xml,${encodeURIComponent(
|
|
70
|
+
`<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>`
|
|
71
|
+
)}")`
|
|
72
|
+
},
|
|
73
|
+
children: /* @__PURE__ */ jsx(
|
|
74
|
+
"div",
|
|
75
|
+
{
|
|
76
|
+
ref: progressRef,
|
|
77
|
+
className: "w-full bg-fg transition-[height] duration-100 ease-out"
|
|
78
|
+
}
|
|
79
|
+
)
|
|
80
|
+
}
|
|
81
|
+
),
|
|
82
|
+
/* @__PURE__ */ jsx("div", { ref: containerRef, className: "flex flex-col", children: headings.map((heading, i) => /* @__PURE__ */ jsxs(
|
|
83
|
+
"a",
|
|
84
|
+
{
|
|
85
|
+
href: `#${heading.id}`,
|
|
86
|
+
"aria-current": active === heading.id ? "location" : void 0,
|
|
87
|
+
className: `relative py-1.5 text-sm transition-colors ${active === heading.id ? "text-fg" : "text-muted hover:text-fg"}`,
|
|
88
|
+
style: { paddingLeft: getItemOffset(heading.level) },
|
|
89
|
+
children: [
|
|
90
|
+
/* @__PURE__ */ jsx(
|
|
91
|
+
ZigzagLine,
|
|
92
|
+
{
|
|
93
|
+
heading,
|
|
94
|
+
upper: headings[i - 1]?.level,
|
|
95
|
+
lower: headings[i + 1]?.level
|
|
96
|
+
}
|
|
97
|
+
),
|
|
98
|
+
heading.text
|
|
99
|
+
]
|
|
100
|
+
},
|
|
101
|
+
heading.id
|
|
102
|
+
)) })
|
|
103
|
+
] });
|
|
104
|
+
}
|
|
105
|
+
return /* @__PURE__ */ jsxs("nav", { "aria-label": "table of contents", className: "flex gap-3", children: [
|
|
106
|
+
/* @__PURE__ */ jsx(
|
|
107
|
+
"div",
|
|
108
|
+
{
|
|
109
|
+
ref: containerRef,
|
|
110
|
+
className: "relative w-0.5 bg-line rounded-full",
|
|
111
|
+
role: "presentation",
|
|
112
|
+
"aria-hidden": "true",
|
|
113
|
+
children: /* @__PURE__ */ jsx(
|
|
114
|
+
"div",
|
|
115
|
+
{
|
|
116
|
+
ref: thumbRef,
|
|
117
|
+
className: "absolute left-0 top-0 w-full h-3 bg-fg rounded-full",
|
|
118
|
+
style: { willChange: "transform" }
|
|
119
|
+
}
|
|
120
|
+
)
|
|
121
|
+
}
|
|
122
|
+
),
|
|
123
|
+
/* @__PURE__ */ jsx("ul", { role: "list", className: "space-y-1", children: headings.map((heading) => /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsx(
|
|
124
|
+
"a",
|
|
125
|
+
{
|
|
126
|
+
href: `#${heading.id}`,
|
|
127
|
+
"aria-current": active === heading.id ? "location" : void 0,
|
|
128
|
+
className: `block text-xs py-1 transition-colors ${heading.level === 3 ? "pl-2" : ""} ${active === heading.id ? "text-fg" : "text-muted hover:text-fg"}`,
|
|
129
|
+
children: heading.text
|
|
130
|
+
}
|
|
131
|
+
) }, heading.id)) })
|
|
132
|
+
] });
|
|
133
|
+
}
|
|
134
|
+
const TocMinimal = memo(TocMinimalBase);
|
|
135
|
+
|
|
136
|
+
export { TocMinimal };
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
+
import { Heading } from './hook.js';
|
|
3
|
+
|
|
4
|
+
interface Props {
|
|
5
|
+
heading: Heading;
|
|
6
|
+
upper?: number;
|
|
7
|
+
lower?: number;
|
|
8
|
+
}
|
|
9
|
+
declare function ZigzagLine({ heading, upper, lower }: Props): react_jsx_runtime.JSX.Element;
|
|
10
|
+
declare function getItemOffset(level: number): number;
|
|
11
|
+
interface ZigzagPath {
|
|
12
|
+
path: string;
|
|
13
|
+
width: number;
|
|
14
|
+
height: number;
|
|
15
|
+
}
|
|
16
|
+
declare function buildZigzagPath(headings: Heading[], container: HTMLElement): ZigzagPath | null;
|
|
17
|
+
|
|
18
|
+
export { ZigzagLine, type ZigzagPath, buildZigzagPath, getItemOffset };
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
function getLineOffset(level) {
|
|
5
|
+
return level >= 3 ? 10 : 0;
|
|
6
|
+
}
|
|
7
|
+
function ZigzagLine({ heading, upper = heading.level, lower = heading.level }) {
|
|
8
|
+
const offset = getLineOffset(heading.level);
|
|
9
|
+
const upperOffset = getLineOffset(upper);
|
|
10
|
+
const lowerOffset = getLineOffset(lower);
|
|
11
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
12
|
+
offset !== upperOffset && /* @__PURE__ */ jsx("svg", { viewBox: "0 0 16 16", className: "absolute -top-1.5 left-0 size-4", "aria-hidden": "true", children: /* @__PURE__ */ jsx(
|
|
13
|
+
"line",
|
|
14
|
+
{
|
|
15
|
+
x1: upperOffset,
|
|
16
|
+
y1: "0",
|
|
17
|
+
x2: offset,
|
|
18
|
+
y2: "12",
|
|
19
|
+
className: "stroke-line",
|
|
20
|
+
strokeWidth: "1"
|
|
21
|
+
}
|
|
22
|
+
) }),
|
|
23
|
+
/* @__PURE__ */ jsx(
|
|
24
|
+
"div",
|
|
25
|
+
{
|
|
26
|
+
className: `absolute inset-y-0 w-px bg-line ${offset !== upperOffset ? "top-1.5" : ""} ${offset !== lowerOffset ? "bottom-1.5" : ""}`,
|
|
27
|
+
style: { left: offset }
|
|
28
|
+
}
|
|
29
|
+
)
|
|
30
|
+
] });
|
|
31
|
+
}
|
|
32
|
+
function getItemOffset(level) {
|
|
33
|
+
return level >= 3 ? 26 : 14;
|
|
34
|
+
}
|
|
35
|
+
function buildZigzagPath(headings, container) {
|
|
36
|
+
if (container.clientHeight === 0) return null;
|
|
37
|
+
let w = 0;
|
|
38
|
+
let h = 0;
|
|
39
|
+
const d = [];
|
|
40
|
+
for (let i = 0; i < headings.length; i++) {
|
|
41
|
+
const item = headings[i];
|
|
42
|
+
if (!item) continue;
|
|
43
|
+
const element = container.querySelector(`a[href="#${item.id}"]`);
|
|
44
|
+
if (!element) continue;
|
|
45
|
+
const styles = getComputedStyle(element);
|
|
46
|
+
const offset = item.level >= 3 ? 10.5 : 0.5;
|
|
47
|
+
const top = element.offsetTop + parseFloat(styles.paddingTop);
|
|
48
|
+
const bottom = element.offsetTop + element.clientHeight - parseFloat(styles.paddingBottom);
|
|
49
|
+
w = Math.max(offset, w);
|
|
50
|
+
h = Math.max(h, bottom);
|
|
51
|
+
d.push(`${i === 0 ? "M" : "L"}${offset} ${top}`);
|
|
52
|
+
d.push(`L${offset} ${bottom}`);
|
|
53
|
+
}
|
|
54
|
+
return { path: d.join(" "), width: w + 1, height: h };
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
export { ZigzagLine, buildZigzagPath, getItemOffset };
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
interface TocProgressProps {
|
|
5
|
+
headings: {
|
|
6
|
+
id: string;
|
|
7
|
+
text: string;
|
|
8
|
+
level: number;
|
|
9
|
+
}[];
|
|
10
|
+
className?: string;
|
|
11
|
+
activeClassName?: string;
|
|
12
|
+
lineColor?: string;
|
|
13
|
+
}
|
|
14
|
+
declare function TocProgressBase({ headings, className, activeClassName, lineColor }: TocProgressProps): react_jsx_runtime.JSX.Element;
|
|
15
|
+
declare const TocProgress: react.MemoExoticComponent<typeof TocProgressBase>;
|
|
16
|
+
|
|
17
|
+
export { TocProgress, type TocProgressProps };
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { memo, useState, useRef, useEffect, useCallback } from 'react';
|
|
4
|
+
|
|
5
|
+
const indent = (level) => level >= 4 ? "pl-8" : level === 3 ? "pl-4" : "";
|
|
6
|
+
function TocProgressBase({ headings, className, activeClassName, lineColor }) {
|
|
7
|
+
const [active, setActive] = useState("");
|
|
8
|
+
const listRef = useRef(null);
|
|
9
|
+
const [indicator, setIndicator] = useState({ top: 0, height: 0 });
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
if (headings.length === 0) return;
|
|
12
|
+
const elements = headings.map((h) => document.getElementById(h.id)).filter((el) => el !== null);
|
|
13
|
+
if (elements.length === 0) return;
|
|
14
|
+
const observer = new IntersectionObserver(
|
|
15
|
+
(entries) => {
|
|
16
|
+
for (const entry of entries) {
|
|
17
|
+
if (entry.isIntersecting) {
|
|
18
|
+
setActive(entry.target.id);
|
|
19
|
+
break;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
{ rootMargin: "-80px 0px -60% 0px", threshold: 0 }
|
|
24
|
+
);
|
|
25
|
+
for (const el of elements) observer.observe(el);
|
|
26
|
+
return () => observer.disconnect();
|
|
27
|
+
}, [headings]);
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
if (!active || !listRef.current) return;
|
|
30
|
+
const current = listRef.current.querySelector(`a[href="#${active}"]`);
|
|
31
|
+
const link = current instanceof HTMLElement ? current : null;
|
|
32
|
+
if (!link) return;
|
|
33
|
+
const top = listRef.current.getBoundingClientRect().top;
|
|
34
|
+
const rect = link.getBoundingClientRect();
|
|
35
|
+
setIndicator({ top: rect.top - top, height: rect.height });
|
|
36
|
+
}, [active]);
|
|
37
|
+
const scroll = useCallback((id) => {
|
|
38
|
+
document.getElementById(id)?.scrollIntoView({ behavior: "smooth" });
|
|
39
|
+
}, []);
|
|
40
|
+
return /* @__PURE__ */ jsxs("nav", { "aria-label": "Table of contents", className: `relative ${className || ""}`, children: [
|
|
41
|
+
/* @__PURE__ */ jsx("div", { className: "absolute left-0 top-0 bottom-0 w-0.5 bg-line", "aria-hidden": "true" }),
|
|
42
|
+
/* @__PURE__ */ jsx(
|
|
43
|
+
"div",
|
|
44
|
+
{
|
|
45
|
+
className: `absolute left-0 w-0.5 transition-all duration-200 ${activeClassName || "bg-fg"}`,
|
|
46
|
+
style: { top: indicator.top, height: indicator.height, backgroundColor: lineColor },
|
|
47
|
+
"aria-hidden": "true"
|
|
48
|
+
}
|
|
49
|
+
),
|
|
50
|
+
/* @__PURE__ */ jsx("ul", { ref: listRef, role: "list", children: headings.map((h) => /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsx(
|
|
51
|
+
"a",
|
|
52
|
+
{
|
|
53
|
+
href: `#${h.id}`,
|
|
54
|
+
onClick: (e) => {
|
|
55
|
+
e.preventDefault();
|
|
56
|
+
scroll(h.id);
|
|
57
|
+
},
|
|
58
|
+
"aria-current": active === h.id ? "location" : void 0,
|
|
59
|
+
className: `block py-1 pl-4 text-sm transition-colors ${indent(h.level)} ${active === h.id ? "text-fg font-medium" : "text-muted hover:text-fg"}`,
|
|
60
|
+
children: h.text
|
|
61
|
+
}
|
|
62
|
+
) }, h.id)) })
|
|
63
|
+
] });
|
|
64
|
+
}
|
|
65
|
+
const TocProgress = memo(TocProgressBase);
|
|
66
|
+
|
|
67
|
+
export { TocProgress };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ReactNode, JSX } from 'react';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* props for tooltip component
|
|
5
|
+
* @param content - tooltip text or element
|
|
6
|
+
* @param children - trigger element
|
|
7
|
+
* @param side - tooltip position relative to trigger
|
|
8
|
+
* @param delay - show delay in milliseconds
|
|
9
|
+
* @example <Tooltip content="copy"><button>...</button></Tooltip>
|
|
10
|
+
*/
|
|
11
|
+
interface TooltipProps {
|
|
12
|
+
content: ReactNode;
|
|
13
|
+
children: ReactNode;
|
|
14
|
+
side?: "top" | "bottom";
|
|
15
|
+
delay?: number;
|
|
16
|
+
}
|
|
17
|
+
declare function Tooltip({ content, children, side, delay }: TooltipProps): JSX.Element;
|
|
18
|
+
|
|
19
|
+
export { Tooltip, type TooltipProps };
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { useState, useRef, useId, useCallback, useEffect } from 'react';
|
|
4
|
+
import { useEscapeKey } from '../hooks/escapekey';
|
|
5
|
+
|
|
6
|
+
function Tooltip({ content, children, side = "top", delay = 200 }) {
|
|
7
|
+
const [show, setShow] = useState(false);
|
|
8
|
+
const [position, setPosition] = useState({ x: 0, y: 0 });
|
|
9
|
+
const triggerRef = useRef(null);
|
|
10
|
+
const tooltipRef = useRef(null);
|
|
11
|
+
const timeoutRef = useRef(null);
|
|
12
|
+
const id = useId();
|
|
13
|
+
const tooltipId = `tooltip-${id}`;
|
|
14
|
+
const hide = useCallback(() => {
|
|
15
|
+
if (timeoutRef.current) clearTimeout(timeoutRef.current);
|
|
16
|
+
setShow(false);
|
|
17
|
+
}, []);
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
return () => {
|
|
20
|
+
if (timeoutRef.current) clearTimeout(timeoutRef.current);
|
|
21
|
+
};
|
|
22
|
+
}, []);
|
|
23
|
+
useEscapeKey(hide, show);
|
|
24
|
+
const updatePosition = useCallback(() => {
|
|
25
|
+
if (!triggerRef.current || !tooltipRef.current) return;
|
|
26
|
+
const trigger = triggerRef.current.getBoundingClientRect();
|
|
27
|
+
const tooltip = tooltipRef.current.getBoundingClientRect();
|
|
28
|
+
const x = trigger.left + trigger.width / 2 - tooltip.width / 2;
|
|
29
|
+
const y = side === "top" ? trigger.top - tooltip.height - 8 : trigger.bottom + 8;
|
|
30
|
+
setPosition({ x, y });
|
|
31
|
+
}, [side]);
|
|
32
|
+
const handleEnter = useCallback(() => {
|
|
33
|
+
timeoutRef.current = setTimeout(() => {
|
|
34
|
+
setShow(true);
|
|
35
|
+
requestAnimationFrame(updatePosition);
|
|
36
|
+
}, delay);
|
|
37
|
+
}, [delay, updatePosition]);
|
|
38
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
39
|
+
/* @__PURE__ */ jsx(
|
|
40
|
+
"span",
|
|
41
|
+
{
|
|
42
|
+
ref: triggerRef,
|
|
43
|
+
onMouseEnter: handleEnter,
|
|
44
|
+
onMouseLeave: hide,
|
|
45
|
+
onFocus: handleEnter,
|
|
46
|
+
onBlur: hide,
|
|
47
|
+
tabIndex: 0,
|
|
48
|
+
"aria-describedby": show ? tooltipId : void 0,
|
|
49
|
+
className: "inline",
|
|
50
|
+
children
|
|
51
|
+
}
|
|
52
|
+
),
|
|
53
|
+
show && /* @__PURE__ */ jsxs(
|
|
54
|
+
"div",
|
|
55
|
+
{
|
|
56
|
+
ref: tooltipRef,
|
|
57
|
+
id: tooltipId,
|
|
58
|
+
role: "tooltip",
|
|
59
|
+
className: "fixed z-50 px-2 py-1 text-xs bg-fg text-bg rounded shadow-lg pointer-events-none",
|
|
60
|
+
style: { left: position.x, top: position.y },
|
|
61
|
+
children: [
|
|
62
|
+
content,
|
|
63
|
+
/* @__PURE__ */ jsx(
|
|
64
|
+
"div",
|
|
65
|
+
{
|
|
66
|
+
"aria-hidden": "true",
|
|
67
|
+
className: `absolute left-1/2 -translate-x-1/2 w-2 h-2 bg-fg rotate-45 ${side === "top" ? "-bottom-1" : "-top-1"}`
|
|
68
|
+
}
|
|
69
|
+
)
|
|
70
|
+
]
|
|
71
|
+
}
|
|
72
|
+
)
|
|
73
|
+
] });
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
export { Tooltip };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { IconSearch } from './icons';
|
|
4
|
+
|
|
5
|
+
function Trigger({ onOpen }) {
|
|
6
|
+
return /* @__PURE__ */ jsxs("button", { type: "button", onClick: onOpen, className: "flex items-center gap-2 w-full px-3 py-2 text-xs text-muted bg-surface border border-line rounded-lg hover:border-dim transition-colors", children: [
|
|
7
|
+
/* @__PURE__ */ jsx(IconSearch, { className: "w-3.5 h-3.5", size: 14 }),
|
|
8
|
+
/* @__PURE__ */ jsx("span", { className: "flex-1 text-left", children: "search" }),
|
|
9
|
+
/* @__PURE__ */ jsx("kbd", { className: "px-1.5 py-0.5 text-[10px] bg-bg border border-line rounded", children: "\u2318K" })
|
|
10
|
+
] });
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export { Trigger };
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { memo } from 'react';
|
|
4
|
+
import { z } from 'zod';
|
|
5
|
+
|
|
6
|
+
const row = z.object({
|
|
7
|
+
t: z.enum(["q", "c"]),
|
|
8
|
+
l: z.number().int().nonnegative(),
|
|
9
|
+
ch: z.number().int().nonnegative(),
|
|
10
|
+
tx: z.string().optional()
|
|
11
|
+
});
|
|
12
|
+
const rows = z.array(row);
|
|
13
|
+
function read(data) {
|
|
14
|
+
if (!data) return [];
|
|
15
|
+
try {
|
|
16
|
+
const raw = JSON.parse(data);
|
|
17
|
+
const parsed = rows.safeParse(raw);
|
|
18
|
+
if (!parsed.success) return [];
|
|
19
|
+
return parsed.data.map((value) => ({
|
|
20
|
+
type: value.t === "q" ? "query" : "completion",
|
|
21
|
+
line: value.l,
|
|
22
|
+
character: value.ch,
|
|
23
|
+
text: value.tx
|
|
24
|
+
}));
|
|
25
|
+
} catch {
|
|
26
|
+
return [];
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
const TwoslashBase = memo(function TwoslashBase2({ data, noerrors }) {
|
|
30
|
+
const items = read(data);
|
|
31
|
+
if (items.length === 0 && !noerrors) return null;
|
|
32
|
+
return /* @__PURE__ */ jsxs("div", { className: "border-t border-line/60 bg-surface/40 px-4 py-3 text-xs text-muted", "aria-label": "TypeScript notes", children: [
|
|
33
|
+
noerrors ? /* @__PURE__ */ jsx("div", { className: "mb-2 text-green-400", children: "no errors expected" }) : null,
|
|
34
|
+
items.length > 0 ? /* @__PURE__ */ jsx("ul", { className: "space-y-1", role: "list", children: items.map((value, index) => /* @__PURE__ */ jsxs("li", { className: "font-mono", children: [
|
|
35
|
+
/* @__PURE__ */ jsx("span", { className: "text-fg", children: value.type }),
|
|
36
|
+
" ",
|
|
37
|
+
/* @__PURE__ */ jsxs("span", { className: "text-dim", children: [
|
|
38
|
+
"line ",
|
|
39
|
+
value.line + 1,
|
|
40
|
+
", col ",
|
|
41
|
+
value.character + 1
|
|
42
|
+
] }),
|
|
43
|
+
value.text ? /* @__PURE__ */ jsxs("span", { className: "text-muted", children: [
|
|
44
|
+
": ",
|
|
45
|
+
value.text
|
|
46
|
+
] }) : null
|
|
47
|
+
] }, `${value.type}-${value.line}-${value.character}-${index}`)) }) : null
|
|
48
|
+
] });
|
|
49
|
+
});
|
|
50
|
+
const Twoslash = TwoslashBase;
|
|
51
|
+
|
|
52
|
+
export { Twoslash };
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* @description metadata for a single property in the type table
|
|
6
|
+
*/
|
|
7
|
+
interface TypeInfo {
|
|
8
|
+
type: string;
|
|
9
|
+
default?: string;
|
|
10
|
+
description?: ReactNode;
|
|
11
|
+
required?: boolean;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* @description props for the typetable component
|
|
15
|
+
*/
|
|
16
|
+
interface TypeTableProps {
|
|
17
|
+
data: Record<string, TypeInfo>;
|
|
18
|
+
}
|
|
19
|
+
declare const TypeTable: react.NamedExoticComponent<TypeTableProps>;
|
|
20
|
+
|
|
21
|
+
export { type TypeInfo, TypeTable, type TypeTableProps };
|