mirror of
https://github.com/nextui-org/nextui.git
synced 2025-12-08 19:26:11 +00:00
* feat: Slider Component (#1686) * feat(slider): initial structure * chore(slider): readme improved * fix: fixed border color of slider track * docs: added range story * feat: added rtl support to slider * feat: improved value label formatting * feat: refactor styling and add colors support to slider * chore: improved thumb color * docs: improved slider stories * chore(slider): default color changed by foreground * Update packages/core/theme/src/components/slider.ts Co-authored-by: Jakob Guddas <github@jguddas.de> * feat: added fillOffset prop * Update packages/components/slider/src/use-slider.ts * fix(slider): animation * Update packages/components/slider/src/use-slider.ts * Update packages/core/theme/src/components/slider.ts * feat: slider steps * refactor: renamed variables * feat: improved slider step styling * fix: hide infinite steps * fix: fixed step transparency issue * fix: fixed thumb focus issue * Update packages/components/slider/src/use-slider.ts Co-authored-by: Junior Garcia <jrgarciadev@gmail.com> * feat(slider): vertical orientation added, start & end content, bug fixes * chore(slider): tests added * fix(docs): scrollbar added to the sidebar (#1743) * feat(slider): marks added * chore(slider): example ts-doc changed * feat(slider): vertical marks support * feat(core): slider tooltip support added, popover modified (#1746) * Feat/slider custom styles (#1751) * feat(slider): custom styles story added * fix(slider): custom styles on different sizes * Fix/slider tooltip android position (#1753) * feat(slider): custom styles story added * fix(slider): tooltip update position dependecies added * fix(popover): arrow placements improved * feat(slider): docs started, custom thumb and custom output stories added * feat(slider): render function added to custom render the slider parts * feat(slider): docs in progress, new properties and examples added * fix(slider): some issues fixed, output renamed to value, documentation improved * feat(slider): docs done * chore: changeset --------- Co-authored-by: Jakob Guddas <github@jguddas.de> * Client side routing (#1764) * feat(slider): initial structure * chore(slider): readme improved * fix: fixed border color of slider track * docs: added range story * feat: added rtl support to slider * feat: improved value label formatting * feat: refactor styling and add colors support to slider * chore: improved thumb color * docs: improved slider stories * chore(slider): default color changed by foreground * Update packages/core/theme/src/components/slider.ts Co-authored-by: Jakob Guddas <github@jguddas.de> * feat: added fillOffset prop * Update packages/components/slider/src/use-slider.ts * fix(slider): animation * Update packages/components/slider/src/use-slider.ts * Update packages/core/theme/src/components/slider.ts * feat: slider steps * refactor: renamed variables * feat: improved slider step styling * fix: hide infinite steps * fix: fixed step transparency issue * fix: fixed thumb focus issue * Update packages/components/slider/src/use-slider.ts Co-authored-by: Junior Garcia <jrgarciadev@gmail.com> * feat(slider): vertical orientation added, start & end content, bug fixes * chore(slider): tests added * feat(slider): marks added * chore(slider): example ts-doc changed * feat(slider): vertical marks support * feat(core): slider tooltip support added, popover modified (#1746) * Feat/slider custom styles (#1751) * feat(slider): custom styles story added * fix(slider): custom styles on different sizes * Fix/slider tooltip android position (#1753) * feat(slider): custom styles story added * fix(slider): tooltip update position dependecies added * fix(popover): arrow placements improved * feat(slider): docs started, custom thumb and custom output stories added * feat(slider): render function added to custom render the slider parts * feat(slider): docs in progress, new properties and examples added * fix(slider): some issues fixed, output renamed to value, documentation improved * feat(slider): docs done * chore: changeset * chore: react aria packages upgraded * feat(system): router provider added * feat: client side routing support added to items components * chore(docs): routing docs started * chore: changeset * feat(docs): client side routing documented * feat(pagination): client router support added to pagination * fix(link): csr added --------- Co-authored-by: Jakob Guddas <github@jguddas.de> * feat: added RTL support to accordion component (#1725) * feat: added RTL support to accordion component * Create healthy-cobras-crash.md * feat: added RTL support to avatar and avatar group component (#1727) * feat: added RTL support to avatar and avatar group components * Create tender-penguins-love.md * Update tender-penguins-love.md * feat: added RTL support to button group component (#1726) * feat: added RTL support to button component * feat: added RTL support to button component * Create orange-bobcats-kneel.md * Update button.ts * refactor(root): styles refactor (#1688) * refactor(root): styles refactor * chore(tabs): remove needless type extends * fix(tabs): typecheck * Breadcrumbs component (#1794) * feat(components): breadcrumbs initial structure * feat(breadcrumbs): tests and examples added * feat(docs): breadcrumbs documentation done * feat(docs): breadcrumbs docs done * chore(breadcrumbs): readme changed * fix(slider): Place last dragged slider handle over the other handle (#1778) * Set `data-focused` in handle * Style focused handle on top * Add tests * fix(core): tests and build * fix(button): show only spinner if button isLoading & isIconOnly (#1800) * fix(button): show only spinner if button isLoading & isIconOnly * chore: add changeset * fix(button): remove repeating code * Fix blur/opaque Popover (#1812) * fix(popover): double underlay click * chore: use ref instead of a state * Feat/controlled scroll shadow (#1819) * feat(scroll-shadow): logic improved, controlled support added * feat(scroll-shadow): controlled visibility * fix(scroll-shadow): visibility tests * Autocomplete component (Single Selection) (#1797) * feat(autocomplete): initial structure * feat(core): use press custom hook implemented, autocomplete improved, input and select animations fixed * chore(button): add console.log on press * feat(core): select & input label position, autocomplete improvements, listbox and menu empty state * chore: tailwind-variants upgraded * chore: autocomplete stories in progress * fix: input and select label placement * fix(autocomplete): popover trigger * chore(root): react-aria pkgs and framer-motion upgraded * fix(input,select): outside label scale removed * feat(autocomplete): more stories and use cases supported * fix(core): custom items support on collection-based comps, menu generic items support added * chore(core): tailwind-variants upgraded, custom tv function adapted * chore(docs): select on-change controlled e.g. changed, sandpack theme fixed * chore(autocomplete): docs started, tests added * chore: in progress * feat(menu): top and end content added, autocomplete docs improved * feat(docs): autocomplete documentation almost done * fix(input): outside styles * feat(docs): autocomplete async filtering added * chore(docs): autocomplete highlighted lines added * feat(docs): autocomplete a11y and slots added * feat(docs): autocomplete a11y and slots added * feat(docs): autocomplete docs done * fix(root): peer dependencies (#1848) * Fix/small issues (#1851) * fix(input): visible outline * fix(button): button group radius prop * chore(navbar): menu item active status added * fix(docs): pagination missing keys custom items * fix(core): extendVariants support added to collection-based components * fix(theme): card body padding * chore(theme): transition added to menu/listbox items * fix(input): textarea styles fixed, new prop added * chore(input): textarea height animated * feat(button): hover opacity added * chore(textarea): hide scroll when the limit hasn't been reached * chore(docs): updated badge added to textarea * feat(docs): blog v2.2.0 image and entry added * fix(avatar): ring primary color * chore(docs): tabs added again, autocomplete iframes removed --------- Co-authored-by: Jakob Guddas <github@jguddas.de> Co-authored-by: Maurici Abad Gutierrez <hello@mauriciabad.com> Co-authored-by: Ivan Kucher <dev.kucher@gmail.com>
170 lines
3.9 KiB
TypeScript
170 lines
3.9 KiB
TypeScript
import React from "react";
|
|
import {Meta} from "@storybook/react";
|
|
import {scrollShadow, button} from "@nextui-org/theme";
|
|
import Lorem from "react-lorem-component";
|
|
|
|
import {
|
|
ScrollShadow,
|
|
ScrollShadowProps,
|
|
ScrollShadowOrientation,
|
|
ScrollShadowVisibility,
|
|
} from "../src";
|
|
|
|
export default {
|
|
title: "Components/ScrollShadow",
|
|
component: ScrollShadow,
|
|
argTypes: {
|
|
orientation: {
|
|
control: {type: "select"},
|
|
options: ["horizontal", "vertical"],
|
|
},
|
|
offset: {
|
|
control: {type: "number"},
|
|
},
|
|
visible: {
|
|
control: {type: "select"},
|
|
options: ["auto", "top", "bottom", "both", "left", "right"],
|
|
},
|
|
children: {
|
|
table: {
|
|
disable: true,
|
|
},
|
|
},
|
|
},
|
|
decorators: [
|
|
(Story) => (
|
|
<div className="flex items-center justify-center w-screen h-screen">
|
|
<Story />
|
|
</div>
|
|
),
|
|
],
|
|
} as Meta<typeof ScrollShadow>;
|
|
|
|
const defaultProps = {
|
|
...scrollShadow.defaultVariants,
|
|
visible: "auto",
|
|
className: "w-[300px] h-[400px]",
|
|
children: <Lorem count={10} />,
|
|
};
|
|
|
|
const Template = (args: ScrollShadowProps) => <ScrollShadow {...args} />;
|
|
|
|
const ControlledTemplate = ({children, ...args}: ScrollShadowProps) => {
|
|
const [visible, setVisible] = React.useState<ScrollShadowVisibility>("top");
|
|
const [orientation, setOrientation] = React.useState<ScrollShadowOrientation>("vertical");
|
|
|
|
const states: Record<ScrollShadowOrientation, ScrollShadowVisibility[]> = {
|
|
["vertical"]: ["top", "bottom", "both"],
|
|
["horizontal"]: ["left", "right", "both"],
|
|
};
|
|
|
|
const orientationStates: ScrollShadowOrientation[] = ["vertical", "horizontal"];
|
|
|
|
return (
|
|
<div className="flex flex-col gap-3">
|
|
<ScrollShadow
|
|
{...args}
|
|
className={orientation === "horizontal" ? "max-w-[300px] max-h-[400px]" : args.className}
|
|
orientation={orientation}
|
|
visible={visible}
|
|
>
|
|
{orientation === "horizontal" ? <div className="w-[800px]">{children}</div> : children}
|
|
</ScrollShadow>
|
|
<p className="text-default-500">Orientation: {orientation}</p>
|
|
<p className="text-default-500">Visible state: {visible}</p>
|
|
<div className="flex mt-2 gap-2">
|
|
{orientationStates.map((o) => (
|
|
<button
|
|
key={o}
|
|
className={button({
|
|
color: orientation === o ? "primary" : "default",
|
|
})}
|
|
onClick={() => {
|
|
if (o === "horizontal") {
|
|
setVisible("left");
|
|
} else {
|
|
setVisible("top");
|
|
}
|
|
setOrientation(o);
|
|
}}
|
|
>
|
|
{o}
|
|
</button>
|
|
))}
|
|
</div>
|
|
<div className="flex mt-2 gap-2">
|
|
{states[orientation].map((state) => (
|
|
<button
|
|
key={state}
|
|
className={button({
|
|
color: visible === state ? "primary" : "default",
|
|
})}
|
|
onClick={() => setVisible(state)}
|
|
>
|
|
{state}
|
|
</button>
|
|
))}
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export const Default = {
|
|
render: Template,
|
|
args: {
|
|
...defaultProps,
|
|
},
|
|
};
|
|
|
|
export const Controlled = {
|
|
render: ControlledTemplate,
|
|
args: {
|
|
...defaultProps,
|
|
},
|
|
};
|
|
|
|
export const HideScrollBar = {
|
|
render: Template,
|
|
args: {
|
|
...defaultProps,
|
|
hideScrollBar: true,
|
|
},
|
|
};
|
|
|
|
export const CustomShadowSize = {
|
|
render: Template,
|
|
args: {
|
|
...defaultProps,
|
|
size: 100,
|
|
},
|
|
};
|
|
|
|
export const HorizontalOrientation = {
|
|
render: Template,
|
|
args: {
|
|
...defaultProps,
|
|
orientation: "horizontal",
|
|
className: "max-w-[400px] max-h-[500px]",
|
|
children: (
|
|
<div className="w-[800px]">
|
|
<Lorem count={10} />,
|
|
</div>
|
|
),
|
|
},
|
|
};
|
|
|
|
export const ShadowOffset = {
|
|
render: Template,
|
|
args: {
|
|
...defaultProps,
|
|
offset: 100,
|
|
orientation: "horizontal",
|
|
className: "max-w-[400px] max-h-[500px]",
|
|
children: (
|
|
<div className="w-[800px]">
|
|
<Lorem count={10} />,
|
|
</div>
|
|
),
|
|
},
|
|
};
|