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,100 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { memo, forwardRef, useId, useRef, useState, useCallback, useEffect } from 'react';
|
|
4
|
+
import { ErrorMessage } from './errormessage';
|
|
5
|
+
import { FormLabel } from './formlabel';
|
|
6
|
+
|
|
7
|
+
const variants = {
|
|
8
|
+
default: "border-line bg-surface text-fg placeholder:text-muted focus:border-accent",
|
|
9
|
+
error: "border-red-500/50 bg-red-500/5 text-fg placeholder:text-muted focus:border-red-500"
|
|
10
|
+
};
|
|
11
|
+
const sizes = {
|
|
12
|
+
sm: "px-2.5 py-1.5 text-xs min-h-[60px]",
|
|
13
|
+
md: "px-3 py-2 text-sm min-h-[80px]",
|
|
14
|
+
lg: "px-4 py-3 text-base min-h-[100px]"
|
|
15
|
+
};
|
|
16
|
+
const Textarea = memo(forwardRef(function Textarea2({
|
|
17
|
+
variant = "default",
|
|
18
|
+
size = "md",
|
|
19
|
+
label,
|
|
20
|
+
error,
|
|
21
|
+
hint,
|
|
22
|
+
autoresize = false,
|
|
23
|
+
showCount = false,
|
|
24
|
+
tooltip,
|
|
25
|
+
maxLength,
|
|
26
|
+
className = "",
|
|
27
|
+
id,
|
|
28
|
+
value,
|
|
29
|
+
defaultValue,
|
|
30
|
+
onChange,
|
|
31
|
+
...props
|
|
32
|
+
}, ref) {
|
|
33
|
+
const generatedId = useId();
|
|
34
|
+
const textareaId = id || generatedId;
|
|
35
|
+
const errorId = error ? `${textareaId}-error` : void 0;
|
|
36
|
+
const hintId = hint && !error ? `${textareaId}-hint` : void 0;
|
|
37
|
+
const countId = showCount ? `${textareaId}-count` : void 0;
|
|
38
|
+
const describedBy = [errorId, hintId, countId].filter(Boolean).join(" ") || void 0;
|
|
39
|
+
const actualVariant = error ? "error" : variant;
|
|
40
|
+
const internalRef = useRef(null);
|
|
41
|
+
const [charCount, setCharCount] = useState(() => {
|
|
42
|
+
const initial = value ?? defaultValue ?? "";
|
|
43
|
+
return typeof initial === "string" ? initial.length : 0;
|
|
44
|
+
});
|
|
45
|
+
const resize = useCallback(() => {
|
|
46
|
+
const textarea = internalRef.current;
|
|
47
|
+
if (!textarea || !autoresize) return;
|
|
48
|
+
textarea.style.height = "auto";
|
|
49
|
+
textarea.style.height = `${textarea.scrollHeight}px`;
|
|
50
|
+
}, [autoresize]);
|
|
51
|
+
useEffect(() => {
|
|
52
|
+
resize();
|
|
53
|
+
}, [resize, value]);
|
|
54
|
+
const handleChange = (e) => {
|
|
55
|
+
setCharCount(e.target.value.length);
|
|
56
|
+
if (autoresize) resize();
|
|
57
|
+
onChange?.(e);
|
|
58
|
+
};
|
|
59
|
+
const setRefs = useCallback(
|
|
60
|
+
(node) => {
|
|
61
|
+
internalRef.current = node;
|
|
62
|
+
if (typeof ref === "function") {
|
|
63
|
+
ref(node);
|
|
64
|
+
} else if (ref) {
|
|
65
|
+
ref.current = node;
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
[ref]
|
|
69
|
+
);
|
|
70
|
+
return /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-1.5", children: [
|
|
71
|
+
label && /* @__PURE__ */ jsx(FormLabel, { label, tooltip, htmlFor: textareaId }),
|
|
72
|
+
/* @__PURE__ */ jsx(
|
|
73
|
+
"textarea",
|
|
74
|
+
{
|
|
75
|
+
ref: setRefs,
|
|
76
|
+
id: textareaId,
|
|
77
|
+
"aria-invalid": actualVariant === "error" ? true : void 0,
|
|
78
|
+
"aria-describedby": describedBy,
|
|
79
|
+
maxLength,
|
|
80
|
+
value,
|
|
81
|
+
defaultValue,
|
|
82
|
+
onChange: handleChange,
|
|
83
|
+
className: `rounded-md border outline-none transition-colors resize-vertical ${variants[actualVariant]} ${sizes[size]} ${autoresize ? "resize-none overflow-hidden" : ""} ${className}`.trim(),
|
|
84
|
+
...props
|
|
85
|
+
}
|
|
86
|
+
),
|
|
87
|
+
/* @__PURE__ */ jsxs("div", { className: "flex justify-between gap-2", children: [
|
|
88
|
+
/* @__PURE__ */ jsxs("div", { className: "flex-1", children: [
|
|
89
|
+
error && /* @__PURE__ */ jsx(ErrorMessage, { id: errorId, children: error }),
|
|
90
|
+
hint && !error && /* @__PURE__ */ jsx("span", { id: hintId, className: "text-xs text-muted", children: hint })
|
|
91
|
+
] }),
|
|
92
|
+
showCount && /* @__PURE__ */ jsxs("span", { id: countId, className: "text-xs text-muted", "aria-live": "polite", children: [
|
|
93
|
+
charCount,
|
|
94
|
+
maxLength ? `/${maxLength}` : ""
|
|
95
|
+
] })
|
|
96
|
+
] })
|
|
97
|
+
] });
|
|
98
|
+
}));
|
|
99
|
+
|
|
100
|
+
export { Textarea };
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { JSX } from 'react';
|
|
3
|
+
|
|
4
|
+
type Theme = "light" | "dark" | "system";
|
|
5
|
+
interface ThemeToggleProps {
|
|
6
|
+
defaultTheme?: Theme;
|
|
7
|
+
}
|
|
8
|
+
declare function ThemeToggleBase({ defaultTheme }: ThemeToggleProps): JSX.Element;
|
|
9
|
+
declare const ThemeToggle: react.MemoExoticComponent<typeof ThemeToggleBase>;
|
|
10
|
+
|
|
11
|
+
export { type Theme, ThemeToggle, type ThemeToggleProps };
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { memo, useState, useEffect, useCallback } from 'react';
|
|
4
|
+
|
|
5
|
+
function istheme(value) {
|
|
6
|
+
return value === "light" || value === "dark" || value === "system";
|
|
7
|
+
}
|
|
8
|
+
function resolves(theme) {
|
|
9
|
+
if (theme === "system") {
|
|
10
|
+
return window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light";
|
|
11
|
+
}
|
|
12
|
+
return theme;
|
|
13
|
+
}
|
|
14
|
+
function ThemeToggleBase({ defaultTheme = "dark" }) {
|
|
15
|
+
const [theme, setTheme] = useState(null);
|
|
16
|
+
const [resolved, setResolved] = useState(null);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
const raw = localStorage.getItem("theme");
|
|
19
|
+
const initial = istheme(raw) ? raw : defaultTheme;
|
|
20
|
+
setTheme(initial);
|
|
21
|
+
setResolved(resolves(initial));
|
|
22
|
+
}, [defaultTheme]);
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (!theme) return;
|
|
25
|
+
const apply = () => {
|
|
26
|
+
const r = resolves(theme);
|
|
27
|
+
setResolved(r);
|
|
28
|
+
document.documentElement.classList.toggle("dark", r === "dark");
|
|
29
|
+
};
|
|
30
|
+
apply();
|
|
31
|
+
localStorage.setItem("theme", theme);
|
|
32
|
+
if (theme === "system") {
|
|
33
|
+
const media = window.matchMedia("(prefers-color-scheme: dark)");
|
|
34
|
+
media.addEventListener("change", apply);
|
|
35
|
+
return () => media.removeEventListener("change", apply);
|
|
36
|
+
}
|
|
37
|
+
}, [theme]);
|
|
38
|
+
const toggle = useCallback(() => {
|
|
39
|
+
setTheme((t) => t === "dark" ? "light" : "dark");
|
|
40
|
+
}, []);
|
|
41
|
+
if (!resolved) {
|
|
42
|
+
return /* @__PURE__ */ jsx(
|
|
43
|
+
"button",
|
|
44
|
+
{
|
|
45
|
+
type: "button",
|
|
46
|
+
className: "p-2 text-muted hover:text-fg transition-colors",
|
|
47
|
+
"aria-label": "toggle theme",
|
|
48
|
+
disabled: true,
|
|
49
|
+
children: /* @__PURE__ */ jsx("span", { className: "size-4 block" })
|
|
50
|
+
}
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
return /* @__PURE__ */ jsx(
|
|
54
|
+
"button",
|
|
55
|
+
{
|
|
56
|
+
type: "button",
|
|
57
|
+
onClick: toggle,
|
|
58
|
+
className: "p-2 text-muted hover:text-fg transition-colors",
|
|
59
|
+
"aria-label": `switch to ${resolved === "dark" ? "light" : "dark"} theme`,
|
|
60
|
+
children: resolved === "dark" ? /* @__PURE__ */ jsx("svg", { "aria-hidden": "true", viewBox: "0 0 16 16", fill: "currentColor", className: "size-4", children: /* @__PURE__ */ jsx("path", { d: "M8 12a4 4 0 100-8 4 4 0 000 8zM8 0a.75.75 0 01.75.75v1.5a.75.75 0 01-1.5 0V.75A.75.75 0 018 0zm0 13a.75.75 0 01.75.75v1.5a.75.75 0 01-1.5 0v-1.5A.75.75 0 018 13zM3.05 2.343a.75.75 0 011.06 0l1.061 1.061a.75.75 0 01-1.06 1.06L3.05 3.404a.75.75 0 010-1.06zm8.84 8.84a.75.75 0 011.06 0l1.06 1.06a.75.75 0 01-1.06 1.061l-1.06-1.06a.75.75 0 010-1.06zM16 8a.75.75 0 01-.75.75h-1.5a.75.75 0 010-1.5h1.5A.75.75 0 0116 8zM3 8a.75.75 0 01-.75.75H.75a.75.75 0 010-1.5h1.5A.75.75 0 013 8zm10.657-4.95a.75.75 0 010 1.061l-1.06 1.06a.75.75 0 11-1.061-1.06l1.06-1.06a.75.75 0 011.06 0zm-8.84 8.84a.75.75 0 010 1.06l-1.06 1.06a.75.75 0 11-1.061-1.06l1.06-1.06a.75.75 0 011.06 0z" }) }) : /* @__PURE__ */ jsx("svg", { "aria-hidden": "true", viewBox: "0 0 16 16", fill: "currentColor", className: "size-4", children: /* @__PURE__ */ jsx("path", { d: "M9.598 1.591a.75.75 0 01.785-.175 7 7 0 11-8.967 8.967.75.75 0 01.961-.96 5.5 5.5 0 007.046-7.046.75.75 0 01.175-.786zm1.616 1.945a7 7 0 01-7.678 7.678 5.5 5.5 0 107.678-7.678z" }) })
|
|
61
|
+
}
|
|
62
|
+
);
|
|
63
|
+
}
|
|
64
|
+
const ThemeToggle = memo(ThemeToggleBase);
|
|
65
|
+
|
|
66
|
+
export { ThemeToggle };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
|
|
4
|
+
type ThemeMode = "light" | "dark" | "system";
|
|
5
|
+
type ThemeContextValue = {
|
|
6
|
+
theme: ThemeMode;
|
|
7
|
+
resolved: "light" | "dark";
|
|
8
|
+
setTheme: (theme: ThemeMode) => void;
|
|
9
|
+
};
|
|
10
|
+
type ThemeProviderProps = {
|
|
11
|
+
children: ReactNode;
|
|
12
|
+
defaultTheme?: ThemeMode;
|
|
13
|
+
storageKey?: string;
|
|
14
|
+
attribute?: string;
|
|
15
|
+
};
|
|
16
|
+
declare function ThemeProvider({ children, defaultTheme, storageKey, attribute, }: ThemeProviderProps): react_jsx_runtime.JSX.Element;
|
|
17
|
+
declare function useTheme(): ThemeContextValue;
|
|
18
|
+
|
|
19
|
+
export { type ThemeContextValue, type ThemeMode, ThemeProvider, type ThemeProviderProps, useTheme };
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { createContext, useState, useEffect, useMemo, useContext } from 'react';
|
|
4
|
+
|
|
5
|
+
const ThemeContext = createContext(null);
|
|
6
|
+
function istheme(value) {
|
|
7
|
+
return value === "light" || value === "dark" || value === "system";
|
|
8
|
+
}
|
|
9
|
+
function resolve(theme) {
|
|
10
|
+
if (theme === "system") {
|
|
11
|
+
return window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light";
|
|
12
|
+
}
|
|
13
|
+
return theme;
|
|
14
|
+
}
|
|
15
|
+
function ThemeProvider({
|
|
16
|
+
children,
|
|
17
|
+
defaultTheme = "system",
|
|
18
|
+
storageKey = "fromsrc-theme",
|
|
19
|
+
attribute = "data-theme"
|
|
20
|
+
}) {
|
|
21
|
+
const [theme, setTheme] = useState(() => {
|
|
22
|
+
if (typeof window === "undefined") return defaultTheme;
|
|
23
|
+
const stored = localStorage.getItem(storageKey);
|
|
24
|
+
return istheme(stored) ? stored : defaultTheme;
|
|
25
|
+
});
|
|
26
|
+
const [resolved, setResolved] = useState(() => {
|
|
27
|
+
if (typeof window === "undefined") return "light";
|
|
28
|
+
return resolve(theme);
|
|
29
|
+
});
|
|
30
|
+
useEffect(() => {
|
|
31
|
+
const r = resolve(theme);
|
|
32
|
+
setResolved(r);
|
|
33
|
+
document.documentElement.setAttribute(attribute, r);
|
|
34
|
+
document.documentElement.classList.toggle("dark", r === "dark");
|
|
35
|
+
localStorage.setItem(storageKey, theme);
|
|
36
|
+
}, [theme, attribute, storageKey]);
|
|
37
|
+
useEffect(() => {
|
|
38
|
+
if (theme !== "system") return;
|
|
39
|
+
const media = window.matchMedia("(prefers-color-scheme: dark)");
|
|
40
|
+
const handler = () => {
|
|
41
|
+
const r = resolve(theme);
|
|
42
|
+
setResolved(r);
|
|
43
|
+
document.documentElement.setAttribute(attribute, r);
|
|
44
|
+
document.documentElement.classList.toggle("dark", r === "dark");
|
|
45
|
+
};
|
|
46
|
+
media.addEventListener("change", handler);
|
|
47
|
+
return () => media.removeEventListener("change", handler);
|
|
48
|
+
}, [theme, attribute]);
|
|
49
|
+
const value = useMemo(() => ({ theme, resolved, setTheme }), [theme, resolved]);
|
|
50
|
+
return /* @__PURE__ */ jsx(ThemeContext.Provider, { value, children });
|
|
51
|
+
}
|
|
52
|
+
function useTheme() {
|
|
53
|
+
const context = useContext(ThemeContext);
|
|
54
|
+
if (!context) throw new Error("useTheme must be used within ThemeProvider");
|
|
55
|
+
return context;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export { ThemeProvider, useTheme };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { ReactNode, JSX } from 'react';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Represents a single toast notification.
|
|
5
|
+
*/
|
|
6
|
+
interface Toast {
|
|
7
|
+
id: string;
|
|
8
|
+
message: string;
|
|
9
|
+
type: "info" | "success" | "warning" | "error";
|
|
10
|
+
duration?: number;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Context value for managing toasts.
|
|
14
|
+
*/
|
|
15
|
+
interface ToastContextValue {
|
|
16
|
+
toasts: Toast[];
|
|
17
|
+
add: (toast: Omit<Toast, "id">) => void;
|
|
18
|
+
remove: (id: string) => void;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Provider component for toast notifications.
|
|
22
|
+
*/
|
|
23
|
+
declare function ToastProvider({ children }: {
|
|
24
|
+
children: ReactNode;
|
|
25
|
+
}): JSX.Element;
|
|
26
|
+
/**
|
|
27
|
+
* Hook to access toast context.
|
|
28
|
+
*/
|
|
29
|
+
declare function useToast(): ToastContextValue;
|
|
30
|
+
|
|
31
|
+
export { type Toast, ToastProvider, useToast };
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { createContext, useState, useRef, useCallback, useEffect, useContext } from 'react';
|
|
4
|
+
import { IconXCircle, IconAlertCircle, IconCheckCircle, IconInfo, IconX } from './icons';
|
|
5
|
+
|
|
6
|
+
const ToastContext = createContext(null);
|
|
7
|
+
function ToastProvider({ children }) {
|
|
8
|
+
const [toasts, setToasts] = useState([]);
|
|
9
|
+
const timers = useRef(/* @__PURE__ */ new Map());
|
|
10
|
+
const counter = useRef(0);
|
|
11
|
+
const remove = useCallback((id) => {
|
|
12
|
+
const timer = timers.current.get(id);
|
|
13
|
+
if (timer) {
|
|
14
|
+
clearTimeout(timer);
|
|
15
|
+
timers.current.delete(id);
|
|
16
|
+
}
|
|
17
|
+
setToasts((t) => t.filter((x) => x.id !== id));
|
|
18
|
+
}, []);
|
|
19
|
+
const add = useCallback((toast) => {
|
|
20
|
+
counter.current += 1;
|
|
21
|
+
const id = `toast-${counter.current}`;
|
|
22
|
+
setToasts((t) => [...t, { ...toast, id }]);
|
|
23
|
+
const duration = toast.duration ?? 5e3;
|
|
24
|
+
const timer = setTimeout(() => {
|
|
25
|
+
timers.current.delete(id);
|
|
26
|
+
setToasts((t) => t.filter((x) => x.id !== id));
|
|
27
|
+
}, duration);
|
|
28
|
+
timers.current.set(id, timer);
|
|
29
|
+
}, []);
|
|
30
|
+
useEffect(() => {
|
|
31
|
+
return () => {
|
|
32
|
+
for (const timer of timers.current.values()) clearTimeout(timer);
|
|
33
|
+
timers.current.clear();
|
|
34
|
+
};
|
|
35
|
+
}, []);
|
|
36
|
+
return /* @__PURE__ */ jsxs(ToastContext.Provider, { value: { toasts, add, remove }, children: [
|
|
37
|
+
children,
|
|
38
|
+
/* @__PURE__ */ jsx(ToastContainer, {})
|
|
39
|
+
] });
|
|
40
|
+
}
|
|
41
|
+
function useToast() {
|
|
42
|
+
const ctx = useContext(ToastContext);
|
|
43
|
+
if (!ctx) throw new Error("useToast must be used within ToastProvider");
|
|
44
|
+
return ctx;
|
|
45
|
+
}
|
|
46
|
+
const icons = {
|
|
47
|
+
info: IconInfo,
|
|
48
|
+
success: IconCheckCircle,
|
|
49
|
+
warning: IconAlertCircle,
|
|
50
|
+
error: IconXCircle
|
|
51
|
+
};
|
|
52
|
+
const styles = {
|
|
53
|
+
info: "border-blue-500/30 bg-blue-500/10",
|
|
54
|
+
success: "border-green-500/30 bg-green-500/10",
|
|
55
|
+
warning: "border-yellow-500/30 bg-yellow-500/10",
|
|
56
|
+
error: "border-red-500/30 bg-red-500/10"
|
|
57
|
+
};
|
|
58
|
+
function ToastContainer() {
|
|
59
|
+
const { toasts, remove } = useToast();
|
|
60
|
+
const handleDismiss = useCallback(
|
|
61
|
+
(id) => () => {
|
|
62
|
+
remove(id);
|
|
63
|
+
},
|
|
64
|
+
[remove]
|
|
65
|
+
);
|
|
66
|
+
if (toasts.length === 0) return null;
|
|
67
|
+
return /* @__PURE__ */ jsx(
|
|
68
|
+
"div",
|
|
69
|
+
{
|
|
70
|
+
role: "region",
|
|
71
|
+
"aria-label": "notifications",
|
|
72
|
+
"aria-live": "polite",
|
|
73
|
+
"aria-atomic": "false",
|
|
74
|
+
"aria-relevant": "additions removals",
|
|
75
|
+
className: "fixed bottom-4 right-4 z-50 flex flex-col gap-2",
|
|
76
|
+
children: toasts.map((toast) => {
|
|
77
|
+
const Icon = icons[toast.type];
|
|
78
|
+
return /* @__PURE__ */ jsxs(
|
|
79
|
+
"div",
|
|
80
|
+
{
|
|
81
|
+
className: `flex items-center gap-3 rounded-lg border px-4 py-3 shadow-lg ${styles[toast.type]}`,
|
|
82
|
+
role: "alert",
|
|
83
|
+
"aria-live": toast.type === "error" ? "assertive" : "polite",
|
|
84
|
+
"aria-atomic": "true",
|
|
85
|
+
children: [
|
|
86
|
+
/* @__PURE__ */ jsx(Icon, { size: 20, className: "shrink-0", "aria-hidden": "true" }),
|
|
87
|
+
/* @__PURE__ */ jsx("span", { className: "text-sm", children: toast.message }),
|
|
88
|
+
/* @__PURE__ */ jsx(
|
|
89
|
+
"button",
|
|
90
|
+
{
|
|
91
|
+
type: "button",
|
|
92
|
+
onClick: handleDismiss(toast.id),
|
|
93
|
+
className: "ml-2 rounded p-1 hover:bg-white/10",
|
|
94
|
+
"aria-label": "dismiss notification",
|
|
95
|
+
children: /* @__PURE__ */ jsx(IconX, { size: 16, "aria-hidden": "true" })
|
|
96
|
+
}
|
|
97
|
+
)
|
|
98
|
+
]
|
|
99
|
+
},
|
|
100
|
+
toast.id
|
|
101
|
+
);
|
|
102
|
+
})
|
|
103
|
+
}
|
|
104
|
+
);
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
export { ToastProvider, useToast };
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import * as react from 'react';
|
|
2
|
+
import { JSX } from 'react';
|
|
3
|
+
import { Heading } from './hook.js';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Props for the table of contents component
|
|
7
|
+
*/
|
|
8
|
+
interface Props {
|
|
9
|
+
/** Array of heading objects to display */
|
|
10
|
+
headings: Heading[];
|
|
11
|
+
/** Currently active heading id */
|
|
12
|
+
active: string;
|
|
13
|
+
/** Array of heading ids in the active range */
|
|
14
|
+
activeRange: string[];
|
|
15
|
+
/** Enable zigzag line decoration */
|
|
16
|
+
zigzag?: boolean;
|
|
17
|
+
}
|
|
18
|
+
declare function TocDefaultBase({ headings, active, activeRange, zigzag }: Props): JSX.Element;
|
|
19
|
+
declare const TocDefault: react.MemoExoticComponent<typeof TocDefaultBase>;
|
|
20
|
+
|
|
21
|
+
export { TocDefault };
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { memo, useRef, useState, useEffect } from 'react';
|
|
4
|
+
import { ZigzagLine, getItemOffset, buildZigzagPath } from './zigzag';
|
|
5
|
+
|
|
6
|
+
function TocDefaultBase({ headings, active, activeRange, zigzag }) {
|
|
7
|
+
const containerRef = useRef(null);
|
|
8
|
+
const [svg, setSvg] = useState(null);
|
|
9
|
+
const [thumb, setThumb] = useState({ top: 0, height: 0 });
|
|
10
|
+
const range = activeRange.length > 0 ? activeRange : active ? [active] : [];
|
|
11
|
+
const isActive = (id) => range.includes(id);
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
if (!zigzag || !containerRef.current || headings.length === 0) return;
|
|
14
|
+
const container = containerRef.current;
|
|
15
|
+
function update() {
|
|
16
|
+
const result = buildZigzagPath(headings, container);
|
|
17
|
+
if (result) setSvg(result);
|
|
18
|
+
}
|
|
19
|
+
const observer = new ResizeObserver(update);
|
|
20
|
+
update();
|
|
21
|
+
observer.observe(container);
|
|
22
|
+
return () => observer.disconnect();
|
|
23
|
+
}, [headings, zigzag]);
|
|
24
|
+
useEffect(() => {
|
|
25
|
+
if (!zigzag || !containerRef.current || range.length === 0) return;
|
|
26
|
+
const container = containerRef.current;
|
|
27
|
+
let upper = Infinity;
|
|
28
|
+
let lower = 0;
|
|
29
|
+
for (const id of range) {
|
|
30
|
+
const element = container.querySelector(`a[href="#${id}"]`);
|
|
31
|
+
if (!element) continue;
|
|
32
|
+
const styles = getComputedStyle(element);
|
|
33
|
+
const top = element.offsetTop + parseFloat(styles.paddingTop);
|
|
34
|
+
const bottom = element.offsetTop + element.clientHeight - parseFloat(styles.paddingBottom);
|
|
35
|
+
upper = Math.min(upper, top);
|
|
36
|
+
lower = Math.max(lower, bottom);
|
|
37
|
+
}
|
|
38
|
+
if (upper !== Infinity) {
|
|
39
|
+
setThumb({ top: upper, height: lower - upper });
|
|
40
|
+
}
|
|
41
|
+
}, [range, zigzag]);
|
|
42
|
+
if (zigzag) {
|
|
43
|
+
return /* @__PURE__ */ jsxs("nav", { "aria-label": "Table of contents", className: "relative", children: [
|
|
44
|
+
svg && /* @__PURE__ */ jsx(
|
|
45
|
+
"div",
|
|
46
|
+
{
|
|
47
|
+
"aria-hidden": "true",
|
|
48
|
+
className: "absolute left-0 top-0 pointer-events-none z-10",
|
|
49
|
+
style: {
|
|
50
|
+
width: svg.width,
|
|
51
|
+
height: svg.height,
|
|
52
|
+
maskImage: `url("data:image/svg+xml,${encodeURIComponent(
|
|
53
|
+
`<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 ${svg.width} ${svg.height}"><path d="${svg.path}" stroke="black" stroke-width="1" fill="none" /></svg>`
|
|
54
|
+
)}")`
|
|
55
|
+
},
|
|
56
|
+
children: /* @__PURE__ */ jsx(
|
|
57
|
+
"div",
|
|
58
|
+
{
|
|
59
|
+
className: "absolute w-full bg-fg transition-[top,height] duration-150",
|
|
60
|
+
style: { top: thumb.top, height: thumb.height }
|
|
61
|
+
}
|
|
62
|
+
)
|
|
63
|
+
}
|
|
64
|
+
),
|
|
65
|
+
/* @__PURE__ */ jsx("div", { ref: containerRef, className: "flex flex-col relative", children: headings.map((heading, i) => /* @__PURE__ */ jsxs(
|
|
66
|
+
"a",
|
|
67
|
+
{
|
|
68
|
+
href: `#${heading.id}`,
|
|
69
|
+
"aria-current": isActive(heading.id) ? "location" : void 0,
|
|
70
|
+
className: `relative py-1.5 text-sm transition-colors ${isActive(heading.id) ? "text-fg" : "text-muted hover:text-fg"}`,
|
|
71
|
+
style: { paddingLeft: getItemOffset(heading.level) },
|
|
72
|
+
children: [
|
|
73
|
+
/* @__PURE__ */ jsx(
|
|
74
|
+
ZigzagLine,
|
|
75
|
+
{
|
|
76
|
+
heading,
|
|
77
|
+
upper: headings[i - 1]?.level,
|
|
78
|
+
lower: headings[i + 1]?.level
|
|
79
|
+
}
|
|
80
|
+
),
|
|
81
|
+
heading.text
|
|
82
|
+
]
|
|
83
|
+
},
|
|
84
|
+
heading.id
|
|
85
|
+
)) })
|
|
86
|
+
] });
|
|
87
|
+
}
|
|
88
|
+
return /* @__PURE__ */ jsx("nav", { "aria-label": "Table of contents", className: "border-l border-line", children: /* @__PURE__ */ jsx("ul", { role: "list", className: "space-y-1", children: headings.map((heading) => /* @__PURE__ */ jsx("li", { children: /* @__PURE__ */ jsx(
|
|
89
|
+
"a",
|
|
90
|
+
{
|
|
91
|
+
href: `#${heading.id}`,
|
|
92
|
+
"aria-current": isActive(heading.id) ? "location" : void 0,
|
|
93
|
+
className: `block text-xs py-1 transition-colors border-l-2 -ml-px ${heading.level === 3 ? "pl-6" : "pl-4"} ${isActive(heading.id) ? "text-fg border-fg" : "text-muted hover:text-fg border-transparent"}`,
|
|
94
|
+
children: heading.text
|
|
95
|
+
}
|
|
96
|
+
) }, heading.id)) }) });
|
|
97
|
+
}
|
|
98
|
+
const TocDefault = memo(TocDefaultBase);
|
|
99
|
+
|
|
100
|
+
export { TocDefault };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
interface Heading {
|
|
2
|
+
id: string;
|
|
3
|
+
text: string;
|
|
4
|
+
level: number;
|
|
5
|
+
}
|
|
6
|
+
interface TocState {
|
|
7
|
+
headings: Heading[];
|
|
8
|
+
active: string;
|
|
9
|
+
activeRange: string[];
|
|
10
|
+
}
|
|
11
|
+
declare function useToc(multi?: boolean): TocState;
|
|
12
|
+
|
|
13
|
+
export { type Heading, type TocState, useToc };
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { useState, useEffect } from 'react';
|
|
3
|
+
|
|
4
|
+
function cleanheading(text) {
|
|
5
|
+
return text.replace(/\s*#+\s*$/, "").trim();
|
|
6
|
+
}
|
|
7
|
+
function useToc(multi = false) {
|
|
8
|
+
const [headings, setHeadings] = useState([]);
|
|
9
|
+
const [active, setActive] = useState("");
|
|
10
|
+
const [activeRange, setActiveRange] = useState([]);
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
function scan() {
|
|
13
|
+
const elements = document.querySelectorAll("article h2, article h3, article h4, article h5, article h6");
|
|
14
|
+
const items = [];
|
|
15
|
+
elements.forEach((el) => {
|
|
16
|
+
if (el.id) {
|
|
17
|
+
const level = Number(el.tagName.replace("H", ""));
|
|
18
|
+
items.push({
|
|
19
|
+
id: el.id,
|
|
20
|
+
text: cleanheading(el.textContent || ""),
|
|
21
|
+
level: Number.isFinite(level) ? level : 2
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
if (items.length > 0) {
|
|
26
|
+
setHeadings(items);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
scan();
|
|
30
|
+
const observer = new MutationObserver(() => {
|
|
31
|
+
scan();
|
|
32
|
+
});
|
|
33
|
+
const article = document.querySelector("article");
|
|
34
|
+
if (article) {
|
|
35
|
+
observer.observe(article, { childList: true, subtree: true });
|
|
36
|
+
}
|
|
37
|
+
return () => observer.disconnect();
|
|
38
|
+
}, []);
|
|
39
|
+
useEffect(() => {
|
|
40
|
+
if (headings.length === 0) return;
|
|
41
|
+
function findClosest() {
|
|
42
|
+
let closest = headings[0]?.id || "";
|
|
43
|
+
let minDistance = Infinity;
|
|
44
|
+
for (const { id } of headings) {
|
|
45
|
+
const el = document.getElementById(id);
|
|
46
|
+
if (!el) continue;
|
|
47
|
+
const rect = el.getBoundingClientRect();
|
|
48
|
+
const distance = Math.abs(rect.top);
|
|
49
|
+
if (distance < minDistance) {
|
|
50
|
+
minDistance = distance;
|
|
51
|
+
closest = id;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
return closest;
|
|
55
|
+
}
|
|
56
|
+
if (multi) {
|
|
57
|
+
const visible = /* @__PURE__ */ new Set();
|
|
58
|
+
const observer = new IntersectionObserver(
|
|
59
|
+
(entries) => {
|
|
60
|
+
for (const entry of entries) {
|
|
61
|
+
if (entry.isIntersecting) {
|
|
62
|
+
visible.add(entry.target.id);
|
|
63
|
+
} else {
|
|
64
|
+
visible.delete(entry.target.id);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
if (visible.size === 0) {
|
|
68
|
+
const closest = findClosest();
|
|
69
|
+
setActive(closest);
|
|
70
|
+
setActiveRange(closest ? [closest] : []);
|
|
71
|
+
} else {
|
|
72
|
+
const ordered = headings.filter((h) => visible.has(h.id));
|
|
73
|
+
setActive(ordered[0]?.id || "");
|
|
74
|
+
setActiveRange(ordered.map((h) => h.id));
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
{ rootMargin: "0px", threshold: 0.9 }
|
|
78
|
+
);
|
|
79
|
+
for (const { id } of headings) {
|
|
80
|
+
const el = document.getElementById(id);
|
|
81
|
+
if (el) observer.observe(el);
|
|
82
|
+
}
|
|
83
|
+
return () => observer.disconnect();
|
|
84
|
+
}
|
|
85
|
+
let ticking = false;
|
|
86
|
+
function update() {
|
|
87
|
+
const atBottom = window.innerHeight + Math.ceil(window.scrollY) >= document.documentElement.scrollHeight;
|
|
88
|
+
if (atBottom && headings.length > 0) {
|
|
89
|
+
const last = headings[headings.length - 1];
|
|
90
|
+
if (last) setActive(last.id);
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
const offset = 100;
|
|
94
|
+
let current = "";
|
|
95
|
+
const items = headings.slice(0, -1);
|
|
96
|
+
for (const { id } of items) {
|
|
97
|
+
const el = document.getElementById(id);
|
|
98
|
+
if (!el) continue;
|
|
99
|
+
if (el.getBoundingClientRect().top <= offset) {
|
|
100
|
+
current = id;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
if (!current && headings.length > 0) {
|
|
104
|
+
const first = headings[0];
|
|
105
|
+
if (first) current = first.id;
|
|
106
|
+
}
|
|
107
|
+
setActive(current);
|
|
108
|
+
}
|
|
109
|
+
function onScroll() {
|
|
110
|
+
if (!ticking) {
|
|
111
|
+
requestAnimationFrame(() => {
|
|
112
|
+
update();
|
|
113
|
+
ticking = false;
|
|
114
|
+
});
|
|
115
|
+
ticking = true;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
update();
|
|
119
|
+
window.addEventListener("scroll", onScroll, { passive: true });
|
|
120
|
+
return () => window.removeEventListener("scroll", onScroll);
|
|
121
|
+
}, [headings, multi]);
|
|
122
|
+
return { headings, active, activeRange };
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
export { useToc };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
+
export { Heading, TocState, useToc } from './hook.js';
|
|
3
|
+
|
|
4
|
+
type TocVariant = "default" | "minimal" | "inline";
|
|
5
|
+
interface TocProps {
|
|
6
|
+
variant?: TocVariant;
|
|
7
|
+
zigzag?: boolean;
|
|
8
|
+
multi?: boolean;
|
|
9
|
+
title?: string;
|
|
10
|
+
collapsible?: boolean;
|
|
11
|
+
defaultOpen?: boolean;
|
|
12
|
+
}
|
|
13
|
+
declare function Toc({ variant, zigzag, multi, title, collapsible, defaultOpen, }: TocProps): react_jsx_runtime.JSX.Element | null;
|
|
14
|
+
|
|
15
|
+
export { Toc, type TocProps, type TocVariant };
|