Junior Garcia baec55029d
Feat/select component (#1313)
* chore(root): menu and select components in progress

* chore(root): merged with main

* feat(menu): stories created

* feat(dropdown): menu migrated to menu component

* feat(select): base implementation in progress

* feat(select): listbox implemented

* feat(select): scroll overflow and auto scroll added

* feat(select): colors & variants improved, inside placement complete, outside pending

* feat(scroll-shadow): new component in progress

* feat(select): scroll shadow integrated

* fix(select): popover implementation, more scroll shadow stories added

* feat(listbox): custom styles example added to stories

* chore(listbox): overflow hidden removed

* feat(select): variants and styles completed

* chore(select): description story added

* feat(select): more stories added

* fix(select): dynamic collections inference, styles improved, more stories added

* fix(select): auto scroll to selected item, scroll padding added

* chore(select): scroll behavior changed to nearest

* feat(select): custom item story added

* fix(select): autoscroll fixed

* feat(select): multi select support added

* feat(select): more examples added, clean-package modified to remove dev packages

* chore(modal): useImperativeHandle removed

* feat(select): render value story improved

* feat(docs): listbox & scroll shadow docs done

* feat(docs): select documentation in progress

* fix: select aria label (#1425)

* feat(docs): more examples added

* feat(docs): select multiple added, storybook favicon changed

* fix: added value to aria label of select (#1431)

* feat(select): more examples added, storybook favicon changed

* fix(popover): dialog role removed

* feat(select): api added, async loading exampled added

* fix: fixed list box on click not working with sr click (#1439)

* feat(select): async items loading support added and documented

* feat(root): input styles updated to be as the select ones

* chore(root): listbox and scroll shadow readme updated

* feat(select): ts examples added, banner updated

* fix(popover): voiceover closes when focusing an item fixed

* chore(select): focus scope removed

* fix(popover): free solo popover added to use without a trigger

* feat(select): blog post added

* chore(docs): search meta generated, multi controlled onchange example fixed

* chore(root): changeset added

---------

Co-authored-by: Jakob Guddas <github@jguddas.de>
2023-08-21 12:28:01 +00:00

73 lines
2.2 KiB
TypeScript

const ListboxWrapper = `const ListboxWrapper = ({children}) => (
<div className="w-full max-w-[260px] border-small px-1 py-2 rounded-small border-default-200 dark:border-default-100">
{children}
</div>
);`;
const App = `import {Listbox, ListboxItem, RadioGroup, Radio} from "@nextui-org/react";
import {ListboxWrapper} from "./ListboxWrapper";
export default function App() {
const [selectedVariant, setSelectedVariant] = React.useState("solid")
const [selectedColor, setSelectedColor] = React.useState("default")
const variants = ["solid", "bordered", "light", "flat", "faded", "shadow"];
const colors = ["default", "primary", "secondary", "success", "warning", "danger"];
return (
<div className="flex flex-col gap-4">
<ListboxWrapper>
<Listbox
aria-label="Listbox Variants"
color={selectedColor}
variant={selectedVariant}
>
<ListboxItem key="new">New file</ListboxItem>
<ListboxItem key="copy">Copy link</ListboxItem>
<ListboxItem key="edit">Edit file</ListboxItem>
<ListboxItem key="delete" className="text-danger" color="danger">
Delete file
</ListboxItem>
</Listbox>
</ListboxWrapper>
<div className="flex flex-col gap-2">
<RadioGroup
label="Select listbox item variant"
orientation="horizontal"
color={selectedVariant}
defaultValue="solid"
onValueChange={setSelectedVariant}
>
{variants.map((variant) => (
<Radio key={variant} value={variant} className="capitalize">
{variant}
</Radio>
))}
</RadioGroup>
<RadioGroup
label="Select listbox item color"
orientation="horizontal"
color={selectedColor}
defaultValue="default"
onValueChange={setSelectedColor}
>
{colors.map((color) => (
<Radio key={color} value={color} className="capitalize">
{color}
</Radio>
))}
</RadioGroup>
</div>
</div>
);
}`;
const react = {
"/App.jsx": App,
"/ListboxWrapper.jsx": ListboxWrapper,
};
export default {
...react,
};