waveterm/frontend/app/element/search.stories.tsx

153 lines
4.7 KiB
TypeScript
Raw Normal View History

2024-12-19 22:49:48 +01:00
// Copyright 2024, Command Line Inc.
// SPDX-License-Identifier: Apache-2.0
import type { Meta, StoryObj } from "@storybook/react";
import { useSetAtom } from "jotai";
import { useEffect } from "react";
import { Popover } from "./popover";
import { Search, useSearch } from "./search";
const meta: Meta<typeof Search> = {
title: "Elements/Search",
component: Search,
args: {},
};
export default meta;
type Story = StoryObj<typeof Popover>;
export const Default: Story = {
2024-12-19 22:49:48 +01:00
render: (args) => {
const props = useSearch();
const setIsOpen = useSetAtom<boolean, [boolean], void>(props.isOpen);
useEffect(() => {
setIsOpen(true);
}, []);
return (
<div
className="viewbox"
ref={props.anchorRef as React.RefObject<HTMLDivElement>}
style={{
border: "2px solid black",
width: "100%",
height: "200px",
background: "var(--main-bg-color)",
}}
>
<Search {...args} {...props} />
</div>
);
},
args: {},
};
export const AdditionalButtons: Story = {
render: (args) => {
const props = useSearch({ regex: true, caseSensitive: true, wholeWord: true });
const setIsOpen = useSetAtom<boolean, [boolean], void>(props.isOpen);
2024-12-19 22:49:48 +01:00
useEffect(() => {
setIsOpen(true);
}, []);
return (
<div
className="viewbox"
ref={props.anchorRef as React.RefObject<HTMLDivElement>}
style={{
border: "2px solid black",
width: "100%",
height: "200px",
background: "var(--main-bg-color)",
}}
>
<Search {...args} {...props} />
</div>
);
},
args: {},
};
export const Results10: Story = {
render: (args) => {
const props = useSearch();
const setIsOpen = useSetAtom<boolean, [boolean], void>(props.isOpen);
const setNumResults = useSetAtom<number, [number], void>(props.resultsCount);
2024-12-19 22:49:48 +01:00
useEffect(() => {
setIsOpen(true);
setNumResults(10);
}, []);
return (
<div
className="viewbox"
ref={props.anchorRef as React.RefObject<HTMLDivElement>}
style={{
border: "2px solid black",
width: "100%",
height: "200px",
background: "var(--main-bg-color)",
}}
>
<Search {...args} {...props} />
</div>
);
},
args: {},
};
export const InputAndResults10: Story = {
render: (args) => {
const props = useSearch();
const setIsOpen = useSetAtom<boolean, [boolean], void>(props.isOpen);
const setNumResults = useSetAtom<number, [number], void>(props.resultsCount);
const setSearch = useSetAtom<string, [string], void>(props.searchValue);
2024-12-19 22:49:48 +01:00
useEffect(() => {
setIsOpen(true);
setSearch("search term");
setTimeout(() => setNumResults(10), 10);
2024-12-19 22:49:48 +01:00
}, []);
return (
<div
className="viewbox"
ref={props.anchorRef as React.RefObject<HTMLDivElement>}
style={{
border: "2px solid black",
width: "100%",
height: "200px",
background: "var(--main-bg-color)",
}}
>
<Search {...args} {...props} />
</div>
);
},
args: {},
};
export const LongInputAndResults10: Story = {
render: (args) => {
const props = useSearch();
const setIsOpen = useSetAtom<boolean, [boolean], void>(props.isOpen);
const setNumResults = useSetAtom<number, [number], void>(props.resultsCount);
const setSearch = useSetAtom<string, [string], void>(props.searchValue);
2024-12-19 22:49:48 +01:00
useEffect(() => {
setIsOpen(true);
setSearch("search term ".repeat(10).trimEnd());
setTimeout(() => setNumResults(10), 10);
2024-12-19 22:49:48 +01:00
}, []);
return (
<div
className="viewbox"
ref={props.anchorRef as React.RefObject<HTMLDivElement>}
style={{
border: "2px solid black",
width: "100%",
height: "200px",
background: "var(--main-bg-color)",
}}
>
<Search {...args} {...props} />
</div>
);
},
args: {},
};