fromsrc 0.0.2 → 0.0.22
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/dist/access.d.ts +7 -7
- package/dist/access.js +12 -5
- package/dist/adapter.js +8 -16
- package/dist/adapterbrowser.js +6 -10
- package/dist/adapternext.js +7 -18
- package/dist/adapterreactrouter.js +5 -9
- package/dist/adapterremix.js +8 -17
- package/dist/adaptertanstack.js +6 -10
- package/dist/algolia.js +43 -21
- package/dist/analytics.d.ts +1 -1
- package/dist/analytics.js +16 -10
- package/dist/ansi.js +76 -37
- package/dist/api.d.ts +10 -10
- package/dist/api.js +14 -11
- package/dist/audit.d.ts +6 -6
- package/dist/audit.js +29 -10
- package/dist/autotype.js +20 -10
- package/dist/batch.d.ts +6 -6
- package/dist/batch.js +16 -9
- package/dist/changelog.js +28 -14
- package/dist/changelogutil.d.ts +4 -4
- package/dist/changelogutil.js +33 -13
- package/dist/cli.d.ts +6 -6
- package/dist/cli.js +7 -3
- package/dist/client.d.ts +1 -1
- package/dist/codesample.d.ts +4 -4
- package/dist/codesample.js +63 -24
- package/dist/collapse.js +31 -13
- package/dist/collections.js +36 -16
- package/dist/components/accordion.d.ts +1 -1
- package/dist/components/accordion.js +5 -1
- package/dist/components/alert.d.ts +1 -1
- package/dist/components/alert.js +24 -13
- package/dist/components/announce.js +40 -17
- package/dist/components/autofill.js +18 -8
- package/dist/components/avatar.js +4 -4
- package/dist/components/avatarstack.js +2 -2
- package/dist/components/backtotop.d.ts +1 -1
- package/dist/components/backtotop.js +18 -5
- package/dist/components/badge.js +9 -4
- package/dist/components/banner.js +22 -5
- package/dist/components/breadcrumb.js +11 -4
- package/dist/components/breadcrumbnav.js +37 -21
- package/dist/components/button.js +23 -8
- package/dist/components/callout.d.ts +1 -1
- package/dist/components/callout.js +35 -31
- package/dist/components/changelog.js +21 -8
- package/dist/components/checkbox.js +32 -19
- package/dist/components/code.d.ts +1 -1
- package/dist/components/code.js +6 -3
- package/dist/components/codeblock.js +157 -39
- package/dist/components/codecopy.d.ts +1 -1
- package/dist/components/codecopy.js +36 -13
- package/dist/components/codegroup.js +87 -25
- package/dist/components/collapsible.d.ts +1 -1
- package/dist/components/collapsible.js +5 -1
- package/dist/components/command.d.ts +1 -1
- package/dist/components/command.js +42 -15
- package/dist/components/compare.js +20 -8
- package/dist/components/content.js +121 -79
- package/dist/components/copybutton.d.ts +1 -1
- package/dist/components/copybutton.js +14 -7
- package/dist/components/countdown.js +9 -3
- package/dist/components/create.js +34 -24
- package/dist/components/definition.js +11 -4
- package/dist/components/diffview.js +63 -29
- package/dist/components/divider.js +5 -1
- package/dist/components/docheader.js +8 -1
- package/dist/components/doclinkcard.js +27 -3
- package/dist/components/dropdown.d.ts +1 -1
- package/dist/components/dropdown.js +32 -11
- package/dist/components/dynamiccode.js +5 -3
- package/dist/components/editlink.js +35 -23
- package/dist/components/embed.js +15 -7
- package/dist/components/endpoint.d.ts +3 -3
- package/dist/components/endpoint.js +24 -9
- package/dist/components/errormessage.d.ts +1 -1
- package/dist/components/errormessage.js +4 -1
- package/dist/components/expandcode.d.ts +1 -1
- package/dist/components/expandcode.js +6 -2
- package/dist/components/feature.js +8 -1
- package/dist/components/featuregrid.d.ts +4 -4
- package/dist/components/featuregrid.js +7 -1
- package/dist/components/feedback.js +11 -7
- package/dist/components/feedbackwidget.js +18 -12
- package/dist/components/files.d.ts +1 -1
- package/dist/components/files.js +52 -18
- package/dist/components/folder.d.ts +1 -1
- package/dist/components/folder.js +21 -4
- package/dist/components/footer.js +5 -1
- package/dist/components/formlabel.d.ts +1 -1
- package/dist/components/formlabel.js +31 -18
- package/dist/components/github.js +43 -14
- package/dist/components/graph.js +38 -14
- package/dist/components/heading.js +36 -29
- package/dist/components/headingcopy.js +13 -5
- package/dist/components/hero.js +20 -14
- package/dist/components/highlight.d.ts +2 -2
- package/dist/components/highlight.js +14 -8
- package/dist/components/hover.d.ts +2 -2
- package/dist/components/hover.js +11 -4
- package/dist/components/icons.js +4 -1
- package/dist/components/inlinetoc.js +3 -1
- package/dist/components/input.js +13 -3
- package/dist/components/install.js +34 -24
- package/dist/components/kbd.js +19 -11
- package/dist/components/langicon.d.ts +1 -1
- package/dist/components/langicon.js +32 -24
- package/dist/components/language.d.ts +1 -1
- package/dist/components/language.js +12 -4
- package/dist/components/lastupdated.d.ts +2 -2
- package/dist/components/lastupdated.js +36 -12
- package/dist/components/link.d.ts +1 -1
- package/dist/components/linkcard.js +3 -1
- package/dist/components/list.d.ts +1 -1
- package/dist/components/list.js +4 -1
- package/dist/components/math.js +33 -8
- package/dist/components/mermaid.js +3 -3
- package/dist/components/mobilenav.d.ts +2 -1
- package/dist/components/mobilenav.js +116 -47
- package/dist/components/modal.d.ts +1 -1
- package/dist/components/modal.js +9 -2
- package/dist/components/navlink.js +17 -3
- package/dist/components/openapi.d.ts +1 -1
- package/dist/components/openapi.js +102 -32
- package/dist/components/openapischema.d.ts +1 -1
- package/dist/components/openapischema.js +29 -9
- package/dist/components/openapitags.js +6 -2
- package/dist/components/pagetransition.js +5 -3
- package/dist/components/pagination.js +5 -4
- package/dist/components/panel.js +92 -16
- package/dist/components/playground.d.ts +1 -1
- package/dist/components/playground.js +153 -50
- package/dist/components/popover.js +9 -7
- package/dist/components/prelink.js +40 -9
- package/dist/components/prevnext.d.ts +1 -1
- package/dist/components/prevnext.js +36 -16
- package/dist/components/progress.js +2 -2
- package/dist/components/property.js +4 -2
- package/dist/components/quote.d.ts +2 -2
- package/dist/components/quote.js +32 -4
- package/dist/components/radio.js +36 -18
- package/dist/components/rating.js +14 -3
- package/dist/components/recent.d.ts +1 -1
- package/dist/components/recent.js +26 -10
- package/dist/components/responsive.js +21 -13
- package/dist/components/results.js +8 -4
- package/dist/components/screenshot.js +61 -21
- package/dist/components/scrollprogress.js +9 -5
- package/dist/components/scrollspy.d.ts +2 -2
- package/dist/components/scrollspy.js +9 -3
- package/dist/components/search.js +47 -18
- package/dist/components/searchbutton.js +3 -1
- package/dist/components/searchdialog.js +36 -23
- package/dist/components/searcher.d.ts +1 -1
- package/dist/components/searcher.js +51 -26
- package/dist/components/select.js +27 -13
- package/dist/components/shortcuts.d.ts +1 -1
- package/dist/components/shortcuts.js +57 -38
- package/dist/components/sidebar.d.ts +2 -1
- package/dist/components/sidebar.js +209 -64
- package/dist/components/sidebarfilter.d.ts +1 -1
- package/dist/components/sidebarfilter.js +33 -9
- package/dist/components/sidebarscript.d.ts +5 -0
- package/dist/components/sidebarscript.js +5 -0
- package/dist/components/skeleton.js +15 -3
- package/dist/components/spinner.js +13 -3
- package/dist/components/status.js +20 -8
- package/dist/components/steps.js +3 -1
- package/dist/components/switch.js +4 -4
- package/dist/components/table.js +37 -12
- package/dist/components/tabnav.d.ts +1 -1
- package/dist/components/tabnav.js +48 -36
- package/dist/components/tabs.d.ts +1 -1
- package/dist/components/tabs.js +56 -40
- package/dist/components/tag.js +8 -3
- package/dist/components/terminal.js +14 -4
- package/dist/components/textarea.js +96 -82
- package/dist/components/theme.d.ts +1 -1
- package/dist/components/theme.js +26 -4
- package/dist/components/themeprovider.d.ts +4 -4
- package/dist/components/themeprovider.js +16 -5
- package/dist/components/toast.d.ts +1 -1
- package/dist/components/toast.js +23 -14
- package/dist/components/toc/default.d.ts +1 -1
- package/dist/components/toc/default.js +28 -13
- package/dist/components/toc/hook.js +28 -14
- package/dist/components/toc/index.js +8 -4
- package/dist/components/toc/inline.js +12 -2
- package/dist/components/toc/minimal.js +11 -5
- package/dist/components/toc/zigzag.d.ts +1 -1
- package/dist/components/toc/zigzag.js +37 -17
- package/dist/components/tocprogress.d.ts +1 -1
- package/dist/components/tocprogress.js +66 -34
- package/dist/components/tooltip.d.ts +1 -1
- package/dist/components/tooltip.js +20 -8
- package/dist/components/trigger.js +13 -5
- package/dist/components/twoslash.js +49 -26
- package/dist/components/typetable.js +23 -4
- package/dist/components/typewriter.js +6 -2
- package/dist/components/version.js +40 -14
- package/dist/components/video.js +25 -15
- package/dist/components/zoom.js +6 -2
- package/dist/config.d.ts +2 -2
- package/dist/config.js +56 -30
- package/dist/content.d.ts +5 -5
- package/dist/content.js +121 -57
- package/dist/contentcache.d.ts +10 -10
- package/dist/contentcache.js +9 -5
- package/dist/contentdiff.d.ts +4 -4
- package/dist/contentdiff.js +16 -8
- package/dist/contributors.d.ts +4 -4
- package/dist/contributors.js +49 -19
- package/dist/diff.d.ts +6 -6
- package/dist/diff.js +37 -16
- package/dist/draft.d.ts +11 -11
- package/dist/draft.js +9 -5
- package/dist/env.js +21 -7
- package/dist/export.js +4 -4
- package/dist/frontmatter.js +11 -9
- package/dist/github.js +60 -30
- package/dist/gitsource.d.ts +1 -1
- package/dist/gitsource.js +16 -9
- package/dist/hash.d.ts +6 -6
- package/dist/hash.js +19 -7
- package/dist/highlight.d.ts +4 -4
- package/dist/highlight.js +34 -14
- package/dist/hooks/anchor.js +26 -14
- package/dist/hooks/arrownav.js +25 -7
- package/dist/hooks/async.js +3 -3
- package/dist/hooks/battery.js +11 -3
- package/dist/hooks/breakpoint.js +10 -2
- package/dist/hooks/clickoutside.js +10 -3
- package/dist/hooks/clipboard-paste.js +7 -3
- package/dist/hooks/clipboard.d.ts +2 -2
- package/dist/hooks/clipboard.js +21 -15
- package/dist/hooks/copy.js +11 -6
- package/dist/hooks/countdown.js +1 -1
- package/dist/hooks/counter.js +1 -1
- package/dist/hooks/escapekey.js +6 -1
- package/dist/hooks/eventlistener.js +3 -1
- package/dist/hooks/eventsource.js +4 -2
- package/dist/hooks/eyedropper.js +7 -3
- package/dist/hooks/favicon.js +1 -1
- package/dist/hooks/fetch.js +12 -4
- package/dist/hooks/focustrap.js +20 -8
- package/dist/hooks/focuswithin.js +6 -2
- package/dist/hooks/form.d.ts +2 -2
- package/dist/hooks/form.js +15 -2
- package/dist/hooks/fullscreen.js +1 -1
- package/dist/hooks/geolocation.js +8 -8
- package/dist/hooks/hotkeys.js +19 -7
- package/dist/hooks/hover.d.ts +4 -1
- package/dist/hooks/hover.js +3 -1
- package/dist/hooks/idle.js +13 -3
- package/dist/hooks/infinitescroll.js +4 -2
- package/dist/hooks/interval.js +3 -1
- package/dist/hooks/inview.js +7 -3
- package/dist/hooks/keyboard.js +36 -12
- package/dist/hooks/keypress.js +6 -2
- package/dist/hooks/list.js +11 -1
- package/dist/hooks/longpress.js +3 -3
- package/dist/hooks/map.js +1 -1
- package/dist/hooks/measure.js +16 -7
- package/dist/hooks/mediarecorder.js +7 -3
- package/dist/hooks/networkstate.js +4 -2
- package/dist/hooks/os.js +12 -4
- package/dist/hooks/pagination.js +6 -4
- package/dist/hooks/permission.js +6 -2
- package/dist/hooks/queue.js +4 -2
- package/dist/hooks/readprogress.js +6 -2
- package/dist/hooks/resizeobserver.js +6 -4
- package/dist/hooks/script.js +1 -1
- package/dist/hooks/scrolllock.js +6 -2
- package/dist/hooks/scrollspy.js +4 -2
- package/dist/hooks/selection.js +6 -3
- package/dist/hooks/share.js +18 -9
- package/dist/hooks/speechrecognition.js +7 -3
- package/dist/hooks/stepper.js +4 -4
- package/dist/hooks/storage.js +9 -3
- package/dist/hooks/stylesheet.js +4 -2
- package/dist/hooks/textselection.js +6 -3
- package/dist/hooks/throttle.js +6 -2
- package/dist/hooks/undoredo.js +19 -11
- package/dist/hooks/vibrate.js +3 -1
- package/dist/hooks/viewtransition.js +8 -4
- package/dist/hooks/wakelock.js +12 -7
- package/dist/hooks/websocket.js +4 -2
- package/dist/hooks/windowsize.js +2 -2
- package/dist/i18n.d.ts +2 -2
- package/dist/i18n.js +27 -14
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/lastmodified.js +11 -5
- package/dist/linkcheck.d.ts +6 -6
- package/dist/linkcheck.js +55 -14
- package/dist/llms.js +20 -4
- package/dist/manifest.js +7 -7
- package/dist/mcp.js +28 -22
- package/dist/mdtoc.d.ts +4 -4
- package/dist/mdtoc.js +11 -5
- package/dist/mdxscope.d.ts +2 -2
- package/dist/mdxscope.js +3 -1
- package/dist/meta.js +19 -7
- package/dist/migrate.js +35 -25
- package/dist/navgen.d.ts +8 -8
- package/dist/navgen.js +73 -30
- package/dist/navtree.d.ts +1 -1
- package/dist/navtree.js +39 -19
- package/dist/oembed.d.ts +4 -4
- package/dist/oembed.js +24 -18
- package/dist/ogimage.d.ts +11 -11
- package/dist/ogimage.js +24 -24
- package/dist/openapi.js +60 -33
- package/dist/openapiguard.js +21 -11
- package/dist/openapiutil.js +66 -20
- package/dist/orama.js +52 -34
- package/dist/pipeline.d.ts +4 -4
- package/dist/pipeline.js +4 -4
- package/dist/preload.d.ts +2 -2
- package/dist/preload.js +4 -4
- package/dist/ranking.d.ts +6 -6
- package/dist/ranking.js +39 -13
- package/dist/readtime.js +3 -1
- package/dist/redirects.d.ts +2 -2
- package/dist/redirects.js +20 -12
- package/dist/rehype.js +16 -9
- package/dist/rehypeautolink.d.ts +2 -2
- package/dist/rehypeautolink.js +25 -23
- package/dist/rehypecode.js +38 -28
- package/dist/rehypecopy.js +17 -13
- package/dist/rehypeinline.js +33 -27
- package/dist/rehypelinks.js +28 -20
- package/dist/rehyperaw.js +9 -3
- package/dist/rehypeslug.d.ts +1 -1
- package/dist/rehypeslug.js +23 -19
- package/dist/rehypetablewrap.d.ts +2 -2
- package/dist/rehypetablewrap.js +9 -5
- package/dist/rehypetoc.d.ts +1 -1
- package/dist/rehypetoc.js +15 -7
- package/dist/remark.js +28 -13
- package/dist/remarkadmonition.js +40 -14
- package/dist/remarkannotation.d.ts +2 -2
- package/dist/remarkannotation.js +26 -10
- package/dist/remarkbadge.js +43 -31
- package/dist/remarkblockmath.js +29 -15
- package/dist/remarkcallout.js +32 -14
- package/dist/remarkcaption.js +28 -16
- package/dist/remarkcodetitle.js +29 -13
- package/dist/remarkcolumns.js +22 -10
- package/dist/remarkdetails.js +34 -14
- package/dist/remarkdirective.js +47 -20
- package/dist/remarkembed.js +38 -22
- package/dist/remarkfiletree.js +29 -19
- package/dist/remarkfootnote.js +46 -18
- package/dist/remarkgfm.js +13 -8
- package/dist/remarkheadingid.js +16 -6
- package/dist/remarkimage.js +54 -34
- package/dist/remarkinclude.js +20 -8
- package/dist/remarkinstall.js +20 -12
- package/dist/remarklinkcard.js +33 -14
- package/dist/remarkmath.js +34 -15
- package/dist/remarkmermaid.js +10 -6
- package/dist/remarkmeta.d.ts +2 -2
- package/dist/remarkmeta.js +15 -5
- package/dist/remarkreadingtime.d.ts +2 -2
- package/dist/remarkreadingtime.js +3 -1
- package/dist/remarksteps.js +26 -14
- package/dist/remarkstructure.js +16 -10
- package/dist/remarktabs.js +31 -14
- package/dist/remarktoc.js +40 -24
- package/dist/remarkts2js.js +51 -40
- package/dist/remarktwoslash.d.ts +4 -4
- package/dist/remarktwoslash.js +24 -14
- package/dist/remarkvideo.d.ts +4 -4
- package/dist/remarkvideo.js +42 -16
- package/dist/schema.d.ts +14 -14
- package/dist/schema.js +2 -2
- package/dist/search.js +106 -48
- package/dist/searchindex.js +86 -34
- package/dist/searchpolicy.js +1 -1
- package/dist/searchscore.js +5 -5
- package/dist/searchtypo.js +30 -10
- package/dist/seo.d.ts +2 -2
- package/dist/seo.js +14 -14
- package/dist/shortcodes.d.ts +4 -4
- package/dist/shortcodes.js +25 -20
- package/dist/sitemap.js +18 -8
- package/dist/snippets.js +26 -18
- package/dist/source.js +75 -41
- package/dist/stats.d.ts +4 -4
- package/dist/stats.js +18 -12
- package/dist/testing.d.ts +7 -7
- package/dist/testing.js +74 -29
- package/dist/themeutil.d.ts +6 -6
- package/dist/themeutil.js +145 -27
- package/dist/typegen.js +31 -12
- package/dist/validate.js +19 -7
- package/dist/validator.d.ts +11 -11
- package/dist/validator.js +68 -19
- package/dist/versioning.d.ts +7 -7
- package/dist/versioning.js +27 -11
- package/dist/watcher.js +39 -15
- package/dist/webhook.d.ts +6 -6
- package/dist/webhook.js +34 -12
- package/dist/workspace.js +26 -12
- package/package.json +137 -137
- package/styles/reset.css +1 -1
|
@@ -2,21 +2,26 @@ import { jsxs, jsx } from 'react/jsx-runtime';
|
|
|
2
2
|
import { memo } from 'react';
|
|
3
3
|
|
|
4
4
|
const methodColors = {
|
|
5
|
-
GET: "bg-emerald-500/10 text-emerald-400 border-emerald-500/20",
|
|
6
|
-
POST: "bg-blue-500/10 text-blue-400 border-blue-500/20",
|
|
7
|
-
PUT: "bg-amber-500/10 text-amber-400 border-amber-500/20",
|
|
8
|
-
PATCH: "bg-orange-500/10 text-orange-400 border-orange-500/20",
|
|
9
5
|
DELETE: "bg-red-500/10 text-red-400 border-red-500/20",
|
|
6
|
+
GET: "bg-emerald-500/10 text-emerald-400 border-emerald-500/20",
|
|
10
7
|
HEAD: "bg-cyan-500/10 text-cyan-400 border-cyan-500/20",
|
|
11
8
|
OPTIONS: "bg-violet-500/10 text-violet-400 border-violet-500/20",
|
|
9
|
+
PATCH: "bg-orange-500/10 text-orange-400 border-orange-500/20",
|
|
10
|
+
POST: "bg-blue-500/10 text-blue-400 border-blue-500/20",
|
|
11
|
+
PUT: "bg-amber-500/10 text-amber-400 border-amber-500/20",
|
|
12
12
|
TRACE: "bg-pink-500/10 text-pink-400 border-pink-500/20"
|
|
13
13
|
};
|
|
14
|
-
function EndpointBase({
|
|
14
|
+
function EndpointBase({
|
|
15
|
+
method,
|
|
16
|
+
path,
|
|
17
|
+
description,
|
|
18
|
+
children
|
|
19
|
+
}) {
|
|
15
20
|
return /* @__PURE__ */ jsxs(
|
|
16
21
|
"article",
|
|
17
22
|
{
|
|
18
23
|
className: "my-6 rounded-lg border border-line overflow-hidden",
|
|
19
|
-
"aria-labelledby": `endpoint-${method}-${path.
|
|
24
|
+
"aria-labelledby": `endpoint-${method}-${path.replaceAll("/", "-")}`,
|
|
20
25
|
children: [
|
|
21
26
|
/* @__PURE__ */ jsxs("header", { className: "flex items-center gap-3 px-4 py-3 bg-surface/50 border-b border-line", children: [
|
|
22
27
|
/* @__PURE__ */ jsx(
|
|
@@ -31,7 +36,7 @@ function EndpointBase({ method, path, description, children }) {
|
|
|
31
36
|
/* @__PURE__ */ jsx(
|
|
32
37
|
"code",
|
|
33
38
|
{
|
|
34
|
-
id: `endpoint-${method}-${path.
|
|
39
|
+
id: `endpoint-${method}-${path.replaceAll("/", "-")}`,
|
|
35
40
|
className: "text-sm font-mono text-fg",
|
|
36
41
|
children: path
|
|
37
42
|
}
|
|
@@ -44,7 +49,13 @@ function EndpointBase({ method, path, description, children }) {
|
|
|
44
49
|
);
|
|
45
50
|
}
|
|
46
51
|
const Endpoint = memo(EndpointBase);
|
|
47
|
-
function ParamBase({
|
|
52
|
+
function ParamBase({
|
|
53
|
+
name,
|
|
54
|
+
type,
|
|
55
|
+
required,
|
|
56
|
+
description,
|
|
57
|
+
children
|
|
58
|
+
}) {
|
|
48
59
|
const paramId = `param-${name}`;
|
|
49
60
|
return /* @__PURE__ */ jsxs(
|
|
50
61
|
"div",
|
|
@@ -73,7 +84,11 @@ function ParamBase({ name, type, required, description, children }) {
|
|
|
73
84
|
);
|
|
74
85
|
}
|
|
75
86
|
const Param = memo(ParamBase);
|
|
76
|
-
function ResponseBase({
|
|
87
|
+
function ResponseBase({
|
|
88
|
+
status,
|
|
89
|
+
description,
|
|
90
|
+
children
|
|
91
|
+
}) {
|
|
77
92
|
const number = typeof status === "string" ? Number(status) : status;
|
|
78
93
|
const isSuccess = Number.isFinite(number) && number >= 200 && number < 300;
|
|
79
94
|
const isError = Number.isFinite(number) && number >= 400;
|
|
@@ -5,7 +5,7 @@ interface ErrorMessageProps {
|
|
|
5
5
|
id?: string;
|
|
6
6
|
children: ReactNode;
|
|
7
7
|
}
|
|
8
|
-
declare function ErrorMessageInner({ id, children }: ErrorMessageProps): React.ReactElement;
|
|
8
|
+
declare function ErrorMessageInner({ id, children, }: ErrorMessageProps): React.ReactElement;
|
|
9
9
|
declare const ErrorMessage: react.MemoExoticComponent<typeof ErrorMessageInner>;
|
|
10
10
|
|
|
11
11
|
export { ErrorMessage, type ErrorMessageProps };
|
|
@@ -2,7 +2,10 @@
|
|
|
2
2
|
import { jsx } from 'react/jsx-runtime';
|
|
3
3
|
import { memo } from 'react';
|
|
4
4
|
|
|
5
|
-
function ErrorMessageInner({
|
|
5
|
+
function ErrorMessageInner({
|
|
6
|
+
id,
|
|
7
|
+
children
|
|
8
|
+
}) {
|
|
6
9
|
return /* @__PURE__ */ jsx("span", { id, className: "text-xs text-red-400", role: "alert", children });
|
|
7
10
|
}
|
|
8
11
|
const ErrorMessage = memo(ErrorMessageInner);
|
|
@@ -7,7 +7,7 @@ interface ExpandCodeProps {
|
|
|
7
7
|
maxLines?: number;
|
|
8
8
|
defaultOpen?: boolean;
|
|
9
9
|
}
|
|
10
|
-
declare function ExpandCodeComponent({ children, maxLines, defaultOpen }: ExpandCodeProps): react_jsx_runtime.JSX.Element;
|
|
10
|
+
declare function ExpandCodeComponent({ children, maxLines, defaultOpen, }: ExpandCodeProps): react_jsx_runtime.JSX.Element;
|
|
11
11
|
declare const ExpandCode: react.MemoExoticComponent<typeof ExpandCodeComponent>;
|
|
12
12
|
|
|
13
13
|
export { ExpandCode, type ExpandCodeProps };
|
|
@@ -3,14 +3,18 @@ import { jsxs, jsx } from 'react/jsx-runtime';
|
|
|
3
3
|
import { memo, useRef, useState, useEffect } from 'react';
|
|
4
4
|
|
|
5
5
|
const LINE_HEIGHT = 20.8;
|
|
6
|
-
function ExpandCodeComponent({
|
|
6
|
+
function ExpandCodeComponent({
|
|
7
|
+
children,
|
|
8
|
+
maxLines = 15,
|
|
9
|
+
defaultOpen = false
|
|
10
|
+
}) {
|
|
7
11
|
const contentRef = useRef(null);
|
|
8
12
|
const [isOpen, setIsOpen] = useState(defaultOpen);
|
|
9
13
|
const [needsExpand, setNeedsExpand] = useState(false);
|
|
10
14
|
const [collapsedHeight, setCollapsedHeight] = useState(0);
|
|
11
15
|
useEffect(() => {
|
|
12
16
|
if (contentRef.current) {
|
|
13
|
-
const scrollHeight = contentRef.current
|
|
17
|
+
const { scrollHeight } = contentRef.current;
|
|
14
18
|
const maxHeight = maxLines * LINE_HEIGHT;
|
|
15
19
|
if (scrollHeight > maxHeight) {
|
|
16
20
|
setNeedsExpand(true);
|
|
@@ -27,7 +27,14 @@ const Features = memo(function Features2({
|
|
|
27
27
|
columns = 2
|
|
28
28
|
}) {
|
|
29
29
|
const gridClass = columns === 3 ? "sm:grid-cols-2 lg:grid-cols-3" : "sm:grid-cols-2";
|
|
30
|
-
return /* @__PURE__ */ jsx(
|
|
30
|
+
return /* @__PURE__ */ jsx(
|
|
31
|
+
"section",
|
|
32
|
+
{
|
|
33
|
+
className: `grid gap-4 sm:gap-6 my-6 ${gridClass}`,
|
|
34
|
+
"aria-label": "Features",
|
|
35
|
+
children
|
|
36
|
+
}
|
|
37
|
+
);
|
|
31
38
|
});
|
|
32
39
|
const FeatureCard = memo(function FeatureCard2({
|
|
33
40
|
icon,
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import * as react from 'react';
|
|
2
2
|
import { ReactNode } from 'react';
|
|
3
3
|
|
|
4
|
-
|
|
4
|
+
interface FeatureGridItem {
|
|
5
5
|
icon?: ReactNode;
|
|
6
6
|
title: string;
|
|
7
7
|
description: string;
|
|
8
8
|
href?: string;
|
|
9
|
-
}
|
|
10
|
-
|
|
9
|
+
}
|
|
10
|
+
interface FeatureGridProps {
|
|
11
11
|
items: FeatureGridItem[];
|
|
12
12
|
columns?: 2 | 3 | 4;
|
|
13
13
|
className?: string;
|
|
14
|
-
}
|
|
14
|
+
}
|
|
15
15
|
declare const FeatureGrid: react.NamedExoticComponent<FeatureGridProps>;
|
|
16
16
|
|
|
17
17
|
export { FeatureGrid, type FeatureGridItem, type FeatureGridProps };
|
|
@@ -30,7 +30,13 @@ const FeatureGrid = memo(function FeatureGrid2({
|
|
|
30
30
|
columns = 3,
|
|
31
31
|
className
|
|
32
32
|
}) {
|
|
33
|
-
return /* @__PURE__ */ jsx(
|
|
33
|
+
return /* @__PURE__ */ jsx(
|
|
34
|
+
"div",
|
|
35
|
+
{
|
|
36
|
+
className: `grid grid-cols-1 gap-4 sm:grid-cols-2 ${columnsMap[columns]} ${className ?? ""}`,
|
|
37
|
+
children: items.map((item) => /* @__PURE__ */ jsx(Card, { item }, item.title))
|
|
38
|
+
}
|
|
39
|
+
);
|
|
34
40
|
});
|
|
35
41
|
|
|
36
42
|
export { FeatureGrid };
|
|
@@ -7,13 +7,17 @@ function FeedbackBase({ onFeedback }) {
|
|
|
7
7
|
const [submitted, setSubmitted] = useState(false);
|
|
8
8
|
const [selected, setSelected] = useState(null);
|
|
9
9
|
const handlePositive = useCallback(async () => {
|
|
10
|
-
if (submitted)
|
|
10
|
+
if (submitted) {
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
11
13
|
setSelected(true);
|
|
12
14
|
setSubmitted(true);
|
|
13
15
|
await onFeedback?.(true);
|
|
14
16
|
}, [submitted, onFeedback]);
|
|
15
17
|
const handleNegative = useCallback(async () => {
|
|
16
|
-
if (submitted)
|
|
18
|
+
if (submitted) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
17
21
|
setSelected(false);
|
|
18
22
|
setSubmitted(true);
|
|
19
23
|
await onFeedback?.(false);
|
|
@@ -25,12 +29,12 @@ function FeedbackBase({ onFeedback }) {
|
|
|
25
29
|
role: "status",
|
|
26
30
|
"aria-live": "polite",
|
|
27
31
|
className: "flex items-center gap-2 text-sm text-muted",
|
|
28
|
-
children: selected ? "
|
|
32
|
+
children: selected ? "Thanks for your feedback" : "Sorry to hear that"
|
|
29
33
|
}
|
|
30
34
|
);
|
|
31
35
|
}
|
|
32
|
-
return /* @__PURE__ */ jsxs("div", { role: "group", "aria-label": "
|
|
33
|
-
/* @__PURE__ */ jsx("span", { id: "feedback-label", className: "text-sm text-muted", children: "
|
|
36
|
+
return /* @__PURE__ */ jsxs("div", { role: "group", "aria-label": "Feedback", className: "flex items-center gap-3", children: [
|
|
37
|
+
/* @__PURE__ */ jsx("span", { id: "feedback-label", className: "text-sm text-muted", children: "Was this helpful?" }),
|
|
34
38
|
/* @__PURE__ */ jsxs("div", { role: "group", "aria-labelledby": "feedback-label", className: "flex gap-1", children: [
|
|
35
39
|
/* @__PURE__ */ jsx(
|
|
36
40
|
"button",
|
|
@@ -38,7 +42,7 @@ function FeedbackBase({ onFeedback }) {
|
|
|
38
42
|
type: "button",
|
|
39
43
|
onClick: handlePositive,
|
|
40
44
|
className: "rounded-md p-1.5 text-muted hover:bg-surface hover:text-fg transition-colors",
|
|
41
|
-
"aria-label": "
|
|
45
|
+
"aria-label": "Yes, helpful",
|
|
42
46
|
"aria-pressed": selected === true,
|
|
43
47
|
children: /* @__PURE__ */ jsx(IconThumbsUp, { "aria-hidden": "true", size: 16 })
|
|
44
48
|
}
|
|
@@ -49,7 +53,7 @@ function FeedbackBase({ onFeedback }) {
|
|
|
49
53
|
type: "button",
|
|
50
54
|
onClick: handleNegative,
|
|
51
55
|
className: "rounded-md p-1.5 text-muted hover:bg-surface hover:text-fg transition-colors",
|
|
52
|
-
"aria-label": "
|
|
56
|
+
"aria-label": "No, not helpful",
|
|
53
57
|
"aria-pressed": selected === false,
|
|
54
58
|
children: /* @__PURE__ */ jsx(IconThumbsDown, { "aria-hidden": "true", size: 16 })
|
|
55
59
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
-
import { memo, useState, useRef, useCallback, useEffect } from 'react';
|
|
4
3
|
import { usePathname } from 'next/navigation';
|
|
4
|
+
import { memo, useState, useRef, useCallback, useEffect } from 'react';
|
|
5
5
|
import { IconThumbsUp, IconThumbsDown } from './icons';
|
|
6
6
|
|
|
7
7
|
function FeedbackWidgetBase({ onSubmit }) {
|
|
@@ -16,10 +16,14 @@ function FeedbackWidgetBase({ onSubmit }) {
|
|
|
16
16
|
setStage("input");
|
|
17
17
|
}, []);
|
|
18
18
|
useEffect(() => {
|
|
19
|
-
if (stage === "input")
|
|
19
|
+
if (stage === "input") {
|
|
20
|
+
inputRef.current?.focus();
|
|
21
|
+
}
|
|
20
22
|
}, [stage]);
|
|
21
23
|
useEffect(() => {
|
|
22
|
-
if (stage !== "done")
|
|
24
|
+
if (stage !== "done") {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
23
27
|
const timer = setTimeout(() => setVisible(false), 2e3);
|
|
24
28
|
return () => clearTimeout(timer);
|
|
25
29
|
}, [stage]);
|
|
@@ -29,7 +33,9 @@ function FeedbackWidgetBase({ onSubmit }) {
|
|
|
29
33
|
}, [helpful, message, path, onSubmit]);
|
|
30
34
|
const keydown = useCallback(
|
|
31
35
|
(e) => {
|
|
32
|
-
if (e.key === "Enter")
|
|
36
|
+
if (e.key === "Enter") {
|
|
37
|
+
submit();
|
|
38
|
+
}
|
|
33
39
|
},
|
|
34
40
|
[submit]
|
|
35
41
|
);
|
|
@@ -39,7 +45,7 @@ function FeedbackWidgetBase({ onSubmit }) {
|
|
|
39
45
|
className: `flex flex-col items-center gap-3 py-8 transition-opacity duration-500 ${visible ? "opacity-100" : "opacity-0"}`,
|
|
40
46
|
children: [
|
|
41
47
|
stage === "ask" && /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-3", children: [
|
|
42
|
-
/* @__PURE__ */ jsx("span", { className: "text-sm text-muted", children: "
|
|
48
|
+
/* @__PURE__ */ jsx("span", { className: "text-sm text-muted", children: "Was this helpful?" }),
|
|
43
49
|
/* @__PURE__ */ jsxs("div", { className: "flex gap-1", children: [
|
|
44
50
|
/* @__PURE__ */ jsx(
|
|
45
51
|
"button",
|
|
@@ -47,7 +53,7 @@ function FeedbackWidgetBase({ onSubmit }) {
|
|
|
47
53
|
type: "button",
|
|
48
54
|
onClick: () => select(true),
|
|
49
55
|
className: "rounded-md p-1.5 text-muted hover:bg-surface hover:text-fg transition-colors",
|
|
50
|
-
"aria-label": "
|
|
56
|
+
"aria-label": "Yes, helpful",
|
|
51
57
|
children: /* @__PURE__ */ jsx(IconThumbsUp, { "aria-hidden": "true", size: 16 })
|
|
52
58
|
}
|
|
53
59
|
),
|
|
@@ -57,7 +63,7 @@ function FeedbackWidgetBase({ onSubmit }) {
|
|
|
57
63
|
type: "button",
|
|
58
64
|
onClick: () => select(false),
|
|
59
65
|
className: "rounded-md p-1.5 text-muted hover:bg-surface hover:text-fg transition-colors",
|
|
60
|
-
"aria-label": "
|
|
66
|
+
"aria-label": "No, not helpful",
|
|
61
67
|
children: /* @__PURE__ */ jsx(IconThumbsDown, { "aria-hidden": "true", size: 16 })
|
|
62
68
|
}
|
|
63
69
|
)
|
|
@@ -72,8 +78,8 @@ function FeedbackWidgetBase({ onSubmit }) {
|
|
|
72
78
|
value: message,
|
|
73
79
|
onChange: (e) => setMessage(e.target.value),
|
|
74
80
|
onKeyDown: keydown,
|
|
75
|
-
placeholder: "
|
|
76
|
-
"aria-label": "
|
|
81
|
+
placeholder: "Share feedback",
|
|
82
|
+
"aria-label": "Feedback",
|
|
77
83
|
className: "h-8 w-56 rounded-md border border-line bg-surface px-3 text-sm text-fg placeholder:text-muted outline-none focus:border-accent transition-colors"
|
|
78
84
|
}
|
|
79
85
|
),
|
|
@@ -83,7 +89,7 @@ function FeedbackWidgetBase({ onSubmit }) {
|
|
|
83
89
|
type: "button",
|
|
84
90
|
onClick: submit,
|
|
85
91
|
className: "h-8 rounded-md border border-line bg-surface px-3 text-sm text-muted hover:text-fg transition-colors",
|
|
86
|
-
children: "
|
|
92
|
+
children: "Send"
|
|
87
93
|
}
|
|
88
94
|
),
|
|
89
95
|
/* @__PURE__ */ jsx(
|
|
@@ -92,11 +98,11 @@ function FeedbackWidgetBase({ onSubmit }) {
|
|
|
92
98
|
type: "button",
|
|
93
99
|
onClick: submit,
|
|
94
100
|
className: "h-8 rounded-md px-2 text-sm text-muted hover:text-fg transition-colors",
|
|
95
|
-
children: "
|
|
101
|
+
children: "Skip"
|
|
96
102
|
}
|
|
97
103
|
)
|
|
98
104
|
] }),
|
|
99
|
-
stage === "done" && /* @__PURE__ */ jsx("span", { className: "text-sm text-muted", role: "status", "aria-live": "polite", children: "
|
|
105
|
+
stage === "done" && /* @__PURE__ */ jsx("span", { className: "text-sm text-muted", role: "status", "aria-live": "polite", children: "Thanks" })
|
|
100
106
|
]
|
|
101
107
|
}
|
|
102
108
|
);
|
|
@@ -16,6 +16,6 @@ interface FolderProps {
|
|
|
16
16
|
children?: ReactNode;
|
|
17
17
|
defaultOpen?: boolean;
|
|
18
18
|
}
|
|
19
|
-
declare function Folder({ name, children, defaultOpen }: FolderProps): ReactNode;
|
|
19
|
+
declare function Folder({ name, children, defaultOpen, }: FolderProps): ReactNode;
|
|
20
20
|
|
|
21
21
|
export { File, type FileProps, Files, type FilesProps, Folder, type FolderProps };
|
package/dist/components/files.js
CHANGED
|
@@ -2,7 +2,10 @@
|
|
|
2
2
|
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
3
3
|
import { memo, useState, useCallback } from 'react';
|
|
4
4
|
|
|
5
|
-
const Files = memo(function Files2({
|
|
5
|
+
const Files = memo(function Files2({
|
|
6
|
+
children,
|
|
7
|
+
label = "File tree"
|
|
8
|
+
}) {
|
|
6
9
|
return /* @__PURE__ */ jsx(
|
|
7
10
|
"div",
|
|
8
11
|
{
|
|
@@ -22,65 +25,95 @@ const File = memo(function File2({ name, icon }) {
|
|
|
22
25
|
tabIndex: 0,
|
|
23
26
|
className: "flex items-center gap-2 px-2 py-1 text-muted rounded focus:outline-none focus:ring-1 focus:ring-fg/20",
|
|
24
27
|
children: [
|
|
25
|
-
icon || /* @__PURE__ */ jsx(
|
|
28
|
+
icon || /* @__PURE__ */ jsx(
|
|
29
|
+
"svg",
|
|
30
|
+
{
|
|
31
|
+
"aria-hidden": "true",
|
|
32
|
+
viewBox: "0 0 16 16",
|
|
33
|
+
fill: "currentColor",
|
|
34
|
+
className: "size-4 shrink-0",
|
|
35
|
+
children: /* @__PURE__ */ jsx("path", { d: "M2 1.75C2 .784 2.784 0 3.75 0h6.586c.464 0 .909.184 1.237.513l2.914 2.914c.329.328.513.773.513 1.237v9.586A1.75 1.75 0 0113.25 16h-9.5A1.75 1.75 0 012 14.25V1.75z" })
|
|
36
|
+
}
|
|
37
|
+
),
|
|
26
38
|
/* @__PURE__ */ jsx("span", { children: name })
|
|
27
39
|
]
|
|
28
40
|
}
|
|
29
41
|
);
|
|
30
42
|
});
|
|
31
|
-
function Folder({
|
|
43
|
+
function Folder({
|
|
44
|
+
name,
|
|
45
|
+
children,
|
|
46
|
+
defaultOpen = false
|
|
47
|
+
}) {
|
|
32
48
|
const [open, setOpen] = useState(defaultOpen);
|
|
33
|
-
const toelement = useCallback(
|
|
34
|
-
|
|
35
|
-
|
|
49
|
+
const toelement = useCallback(
|
|
50
|
+
(value) => value instanceof HTMLElement ? value : null,
|
|
51
|
+
[]
|
|
52
|
+
);
|
|
36
53
|
const toggle = useCallback(() => {
|
|
37
54
|
setOpen((prev) => !prev);
|
|
38
55
|
}, []);
|
|
39
56
|
const handleKeyDown = useCallback(
|
|
40
57
|
(event) => {
|
|
41
58
|
switch (event.key) {
|
|
42
|
-
case "ArrowRight":
|
|
59
|
+
case "ArrowRight": {
|
|
43
60
|
if (!open) {
|
|
44
61
|
setOpen(true);
|
|
45
62
|
event.preventDefault();
|
|
46
63
|
}
|
|
47
64
|
break;
|
|
48
|
-
|
|
65
|
+
}
|
|
66
|
+
case "ArrowLeft": {
|
|
49
67
|
if (open) {
|
|
50
68
|
setOpen(false);
|
|
51
69
|
event.preventDefault();
|
|
52
70
|
}
|
|
53
71
|
break;
|
|
54
|
-
|
|
72
|
+
}
|
|
73
|
+
case "ArrowDown": {
|
|
55
74
|
{
|
|
56
|
-
const next = event.currentTarget.closest(
|
|
57
|
-
|
|
75
|
+
const next = event.currentTarget.closest(
|
|
76
|
+
"[role=treeitem]"
|
|
77
|
+
)?.nextElementSibling;
|
|
78
|
+
const focusable = toelement(
|
|
79
|
+
next?.querySelector("button, [tabindex='0']")
|
|
80
|
+
);
|
|
58
81
|
focusable?.focus();
|
|
59
82
|
event.preventDefault();
|
|
60
83
|
}
|
|
61
84
|
break;
|
|
62
|
-
|
|
85
|
+
}
|
|
86
|
+
case "ArrowUp": {
|
|
63
87
|
{
|
|
64
|
-
const prev = event.currentTarget.closest(
|
|
65
|
-
|
|
88
|
+
const prev = event.currentTarget.closest(
|
|
89
|
+
"[role=treeitem]"
|
|
90
|
+
)?.previousElementSibling;
|
|
91
|
+
const focusable = toelement(
|
|
92
|
+
prev?.querySelector("button, [tabindex='0']")
|
|
93
|
+
);
|
|
66
94
|
focusable?.focus();
|
|
67
95
|
event.preventDefault();
|
|
68
96
|
}
|
|
69
97
|
break;
|
|
98
|
+
}
|
|
70
99
|
case "Enter":
|
|
71
|
-
case " ":
|
|
100
|
+
case " ": {
|
|
72
101
|
toggle();
|
|
73
102
|
event.preventDefault();
|
|
74
103
|
break;
|
|
75
|
-
|
|
104
|
+
}
|
|
105
|
+
case "Home": {
|
|
76
106
|
{
|
|
77
107
|
const tree = event.currentTarget.closest("[role=tree]");
|
|
78
|
-
const first = toelement(
|
|
108
|
+
const first = toelement(
|
|
109
|
+
tree?.querySelector("button, [tabindex='0']")
|
|
110
|
+
);
|
|
79
111
|
first?.focus();
|
|
80
112
|
event.preventDefault();
|
|
81
113
|
}
|
|
82
114
|
break;
|
|
83
|
-
|
|
115
|
+
}
|
|
116
|
+
case "End": {
|
|
84
117
|
{
|
|
85
118
|
const tree = event.currentTarget.closest("[role=tree]");
|
|
86
119
|
const all = tree?.querySelectorAll("button, [tabindex='0']");
|
|
@@ -89,6 +122,7 @@ function Folder({ name, children, defaultOpen = false }) {
|
|
|
89
122
|
event.preventDefault();
|
|
90
123
|
}
|
|
91
124
|
break;
|
|
125
|
+
}
|
|
92
126
|
}
|
|
93
127
|
},
|
|
94
128
|
[open, toggle, toelement]
|
|
@@ -10,6 +10,6 @@ interface Props {
|
|
|
10
10
|
depth?: number;
|
|
11
11
|
defaultOpenLevel?: number;
|
|
12
12
|
}
|
|
13
|
-
declare function Folder({ folder, basePath, depth, defaultOpenLevel }: Props): ReactNode;
|
|
13
|
+
declare function Folder({ folder, basePath, depth, defaultOpenLevel, }: Props): ReactNode;
|
|
14
14
|
|
|
15
15
|
export { Folder };
|
|
@@ -5,19 +5,28 @@ import { usePathname } from 'next/navigation';
|
|
|
5
5
|
import { useState, useEffect, useCallback } from 'react';
|
|
6
6
|
import { NavLink } from './navlink';
|
|
7
7
|
|
|
8
|
-
function Folder({
|
|
8
|
+
function Folder({
|
|
9
|
+
folder,
|
|
10
|
+
basePath,
|
|
11
|
+
depth = 1,
|
|
12
|
+
defaultOpenLevel = 0
|
|
13
|
+
}) {
|
|
9
14
|
const pathname = usePathname();
|
|
10
15
|
const isActive = folder.href && pathname === folder.href;
|
|
11
16
|
const hasActiveChild = folder.items.some((item) => {
|
|
12
17
|
if (item.type === "folder") {
|
|
13
|
-
return item.items.some(
|
|
18
|
+
return item.items.some(
|
|
19
|
+
(child) => child.type === "item" && pathname === child.href
|
|
20
|
+
);
|
|
14
21
|
}
|
|
15
22
|
return item.type === "item" && pathname === item.href;
|
|
16
23
|
});
|
|
17
24
|
const shouldAutoOpen = folder.defaultOpen ?? depth <= defaultOpenLevel;
|
|
18
25
|
const [open, setOpen] = useState(shouldAutoOpen);
|
|
19
26
|
useEffect(() => {
|
|
20
|
-
if (hasActiveChild || isActive)
|
|
27
|
+
if (hasActiveChild || isActive) {
|
|
28
|
+
setOpen(true);
|
|
29
|
+
}
|
|
21
30
|
}, [hasActiveChild, isActive]);
|
|
22
31
|
const toggle = useCallback(() => {
|
|
23
32
|
setOpen((prev) => !prev);
|
|
@@ -67,7 +76,15 @@ function Folder({ folder, basePath, depth = 1, defaultOpenLevel = 0 }) {
|
|
|
67
76
|
viewBox: "0 0 24 24",
|
|
68
77
|
stroke: "currentColor",
|
|
69
78
|
"aria-hidden": "true",
|
|
70
|
-
children: /* @__PURE__ */ jsx(
|
|
79
|
+
children: /* @__PURE__ */ jsx(
|
|
80
|
+
"path",
|
|
81
|
+
{
|
|
82
|
+
strokeLinecap: "round",
|
|
83
|
+
strokeLinejoin: "round",
|
|
84
|
+
strokeWidth: 2,
|
|
85
|
+
d: "M19 9l-7 7-7-7"
|
|
86
|
+
}
|
|
87
|
+
)
|
|
71
88
|
}
|
|
72
89
|
)
|
|
73
90
|
}
|
|
@@ -2,7 +2,11 @@
|
|
|
2
2
|
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
3
|
import { memo } from 'react';
|
|
4
4
|
|
|
5
|
-
const Footer = memo(function Footer2({
|
|
5
|
+
const Footer = memo(function Footer2({
|
|
6
|
+
columns,
|
|
7
|
+
copyright,
|
|
8
|
+
className
|
|
9
|
+
}) {
|
|
6
10
|
return /* @__PURE__ */ jsxs(
|
|
7
11
|
"footer",
|
|
8
12
|
{
|
|
@@ -18,7 +18,7 @@ interface FormLabelProps {
|
|
|
18
18
|
* Shared form label with optional tooltip info icon.
|
|
19
19
|
* Consolidates the label+tooltip pattern used across form components.
|
|
20
20
|
*/
|
|
21
|
-
declare function FormLabelInner({ label, tooltip, htmlFor, id }: FormLabelProps): JSX.Element;
|
|
21
|
+
declare function FormLabelInner({ label, tooltip, htmlFor, id, }: FormLabelProps): JSX.Element;
|
|
22
22
|
declare const FormLabel: react.MemoExoticComponent<typeof FormLabelInner>;
|
|
23
23
|
|
|
24
24
|
export { FormLabel, type FormLabelProps };
|
|
@@ -3,24 +3,37 @@ import { jsxs, jsx } from 'react/jsx-runtime';
|
|
|
3
3
|
import { memo } from 'react';
|
|
4
4
|
import { Tooltip } from './tooltip';
|
|
5
5
|
|
|
6
|
-
function FormLabelInner({
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
6
|
+
function FormLabelInner({
|
|
7
|
+
label,
|
|
8
|
+
tooltip,
|
|
9
|
+
htmlFor,
|
|
10
|
+
id
|
|
11
|
+
}) {
|
|
12
|
+
return /* @__PURE__ */ jsxs(
|
|
13
|
+
"label",
|
|
14
|
+
{
|
|
15
|
+
id,
|
|
16
|
+
htmlFor,
|
|
17
|
+
className: "flex items-center gap-1.5 text-sm font-medium text-fg",
|
|
18
|
+
children: [
|
|
19
|
+
label,
|
|
20
|
+
tooltip && /* @__PURE__ */ jsx(Tooltip, { content: tooltip, children: /* @__PURE__ */ jsxs(
|
|
21
|
+
"svg",
|
|
22
|
+
{
|
|
23
|
+
"aria-hidden": "true",
|
|
24
|
+
className: "h-3.5 w-3.5 text-muted",
|
|
25
|
+
fill: "none",
|
|
26
|
+
stroke: "currentColor",
|
|
27
|
+
viewBox: "0 0 24 24",
|
|
28
|
+
children: [
|
|
29
|
+
/* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "10", strokeWidth: 2 }),
|
|
30
|
+
/* @__PURE__ */ jsx("path", { strokeLinecap: "round", strokeWidth: 2, d: "M12 16v-4m0-4h.01" })
|
|
31
|
+
]
|
|
32
|
+
}
|
|
33
|
+
) })
|
|
34
|
+
]
|
|
35
|
+
}
|
|
36
|
+
);
|
|
24
37
|
}
|
|
25
38
|
const FormLabel = memo(FormLabelInner);
|
|
26
39
|
|