bb-plane-fork/packages/propel/src/scrollarea/scrollarea.stories.tsx
Aaryan Khandelwal 22339b9786
[WEB-5602] feat: new design system (#8220)
* chore: init tailwind v4

* chore: update all configs

* chore: add source to parse monorepo packages

* chore: combine all css files

* feat: added extended colors

* chore: update typography

* chore: update extended color var names

* refactor: remove initial spacing variable and update dark mode selector

* chore: update css files

* chore: update animations

* chore: remove spacing tokens

* fix: external css files

* chore: update tailwind-merge version

* chore: update font family

* chore: added brief agents.md and story for new design system

* chore: enhance design system documentation with rare exceptions for visual separation

* chore: add fontsource package for typography

* chore: material symbols font added

* chore: update shadow default

* chore: add stroke and outline theme vars

* chore: update ring and fill colors

* chore: overwrite tailwind typography tokens

* chore: add high contrast mode tokens

* chore: update scrollbar colors

* chore: backward compatibility for buttons and placeholders

* chore: add priority colors

* chore: update urgent priority color

* chore: update plan colors

* chore: add missing utility class

* chore: update height and padding classes

* chore: update label colors

* chore: add missing utlity

* chore: add typography plugin to space app

* chore: replace existing classNames with new design system tokens #8244 (#8278)

* chore: update border colors

* chore: update all borders

* chore: update text colors

* chore: update css variables

* chore: update font sizes and weights

* chore: update bg colors

* chore: sync changes

* fix: uncomment spacing-1200 variable in variables.css

* chore: update primary colors

* refactor: updated border to border-subtle

* refactor: update various components and improve UI consistency across the application

* updated classnames

* updated classnames

* refactor: update color-related class names to use new design system variables for consistency

* chore: default automations

* chore: update text sizes

* chore: home and power k

* chore: home and power k

* chore: replace ui package button components

* chore: update text sizes

* chore: updated issue identifier (#8275)

* refactor: top navigation and sidebar design token (#8276)

* chore: update all button components (#8277)

* chore: new button component

* chore: update existing buttons

* chore: overwrite tailwind typography tokens

* fix: twMerge config + fixed cn instances

* refactor: toast design token updated (#8279)

* chore: update existing buttons

* chore: tooltip design token updatged (#8280)

* chore: moved cn utility to propel (#8281)

* chore: update space app UI (#8285)

* chore; update space app filters component

* fix: button whitespace wrap

* chore: space app votes

* chore: update dropdown components

* refactor: auth, onboarding, sidebar, and common component design token migration (#8291)

* chore: checkbox component design token updated

* chore: indicator and oauth component design token updated

* chore: sidebar design token updated

* chore: auth and onboarding design token updated

* chore: update divider color

* style: update background colors and hover effects across list components

* fix: tailwind merge

* refactor: toggle switch design token migration and header utility classname added (#8295)

* chore: toggle component design token updated

* chore: h-header utility class added

* chore: updated color tokens for work item detail page (#8296)

* chore: update react-day-picker UI

* refactor: update button sizes and styles in filters components

* refactor: breadcrumbs design token updated (#8297)

* chore: update priority icon colors

* refactor: updated layout variables

* chore: update plan card primary CTA

* Chore update editor design system (#8299)

* refactor: update styles for callout, color selector, logo selector, and image uploader

* refactor:fix image

* chore: update settings UI

* chore: updated notifications color and size tokens (#8302)

* chore: update sm button border radius

* fix: logo renderer

* chore: icon button component

* chore: remove deprecated classes

* chore: remove deprecated classes

* chore: update editor list spacing

* fix: icon button size

* chore: improvements (#8309)

* chore: update cycles and modules pages

* refactor: update background styles across various components to use new design system colors

* fix: button type errors

* chore: update modals design system (#8310)

* refactor: callout bg

* refactor: code  bg

* refactor: modal size and variant

---------

Co-authored-by: Aaryan Khandelwal <aaryankhandu123@gmail.com>

* chore: update next-themes

* design: update billing and plans component styles and remove unused utility functions (#8313)

* refactor: empty state design token migration and improvements (#8315)

* fix: profile page

* refactor: tabs design token updated (#8316)

* chore: updated buttons and tokens for work items (#8317)

* fix: adjust trial button spacing in checkout modal

* chore: update add button hover state

* fix: type error (#8318)

* fix: type error

* chore: code refactor

* refactor: update button sizes and background styles in rich filters components

* refactor: update editor bg

* refactor: enhance Gantt chart sidebar functionality and styling

- Removed unused  prop from .
- Updated  to include new props for better block management and scrolling behavior.
- Improved auto-scroll functionality for Gantt chart items.
- Adjusted styles in  component for consistent design.

* regression: gantt design

* chore: new badge component

* fix: favorite star

* chore: update backgroung, typography and button sizes across workspace settings general and members pages

* fix: header button sizes

* fix: emoji icon logo (#8323)

* more fixes

* chore: update settings sidebar

* refactor: avatar component

* chore: updated work item detail sidebar (#8327)

* refactor: update link preview

* fix: work item property dropdowns

* fix: dropdown buttons border radius

* chore: update power k translation

* chore: updated profile activity design (#8328)

* chore: update settings pages

* chore: update work item sidebar alignments (#8330)

* refactor: admin design system

* chore: update page header

---------

Co-authored-by: Jayash Tripathy <76092296+JayashTripathy@users.noreply.github.com>
Co-authored-by: VipinDevelops <vipinchaudhary1809@gmail.com>
Co-authored-by: Vamsi Krishna <46787868+vamsikrishnamathala@users.noreply.github.com>
Co-authored-by: Anmol Singh Bhatia <121005188+anmolsinghbhatia@users.noreply.github.com>
Co-authored-by: gakshita <akshitagoyal1516@gmail.com>
Co-authored-by: Palanikannan M <akashmalinimurugu@gmail.com>
Co-authored-by: Prateek Shourya <prateekshourya29@gmail.com>
Co-authored-by: b-saikrishnakanth <bsaikrishnakanth97@gmail.com>
Co-authored-by: M. Palanikannan <73993394+Palanikannan1437@users.noreply.github.com>

* fix: formatting

* reexport types

* fix: lint error

---------

Co-authored-by: Jayash Tripathy <76092296+JayashTripathy@users.noreply.github.com>
Co-authored-by: VipinDevelops <vipinchaudhary1809@gmail.com>
Co-authored-by: Vamsi Krishna <46787868+vamsikrishnamathala@users.noreply.github.com>
Co-authored-by: Anmol Singh Bhatia <121005188+anmolsinghbhatia@users.noreply.github.com>
Co-authored-by: gakshita <akshitagoyal1516@gmail.com>
Co-authored-by: Palanikannan M <akashmalinimurugu@gmail.com>
Co-authored-by: Prateek Shourya <prateekshourya29@gmail.com>
Co-authored-by: b-saikrishnakanth <bsaikrishnakanth97@gmail.com>
Co-authored-by: M. Palanikannan <73993394+Palanikannan1437@users.noreply.github.com>
2025-12-12 20:50:14 +05:30

298 lines
9.3 KiB
TypeScript

import type { Meta, StoryObj } from "@storybook/react-vite";
import { ScrollArea } from "./scrollarea";
const meta = {
title: "Components/ScrollArea",
component: ScrollArea,
parameters: {
layout: "padded",
docs: {
description: {
component:
"A customizable scroll area component with multiple size variants, scroll behaviors, and orientations.",
},
},
},
args: {
size: "md",
scrollType: "always",
orientation: "vertical",
},
} satisfies Meta<typeof ScrollArea>;
export default meta;
type Story = StoryObj<typeof meta>;
export const Default: Story = {
render(args) {
return (
<ScrollArea {...args} className="h-64 w-80 border rounded-lg">
<div className="p-4 space-y-4">
<h3 className="text-16 font-semibold">Long Text Content</h3>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed do eiusmod tempor incididunt ut labore et
dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex
ea commodo consequat.
</p>
<p>
Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.
Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est
laborum.
</p>
<p>
Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem
aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.
</p>
<p>
Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni
dolores eos qui ratione voluptatem sequi nesciunt.
</p>
</div>
</ScrollArea>
);
},
};
export const Sizes: Story = {
render() {
const content = (
<div className="p-4 space-y-2">
{[...Array(10)].map((_, i) => (
<p key={i}>Line {i + 1}: This is some scrollable content to demonstrate different sizes.</p>
))}
</div>
);
return (
<div className="flex flex-col gap-6">
<div className="space-y-2">
<div className="text-13 font-medium">Small</div>
<ScrollArea className="h-48 w-80 border rounded-lg" size="sm">
{content}
</ScrollArea>
</div>
<div className="space-y-2">
<div className="text-13 font-medium">Medium</div>
<ScrollArea className="h-48 w-80 border rounded-lg" size="md">
{content}
</ScrollArea>
</div>
<div className="space-y-2">
<div className="text-13 font-medium">Large</div>
<ScrollArea className="h-48 w-80 border rounded-lg" size="lg">
{content}
</ScrollArea>
</div>
</div>
);
},
};
export const ScrollTypeAlways: Story = {
render() {
return (
<ScrollArea className="h-64 w-80 border rounded-lg" scrollType="always">
<div className="p-4 space-y-2">
<h3 className="text-16 font-semibold">Always Visible Scrollbar</h3>
{[...Array(15)].map((_, i) => (
<p key={i}>Line {i + 1}: The scrollbar is always visible.</p>
))}
</div>
</ScrollArea>
);
},
};
export const ScrollTypeScroll: Story = {
render() {
return (
<ScrollArea className="h-64 w-80 border rounded-lg" scrollType="scroll">
<div className="p-4 space-y-2">
<h3 className="text-16 font-semibold">Scroll to Show</h3>
<p className="text-13 text-placeholder">Scrollbar appears when scrolling</p>
{[...Array(15)].map((_, i) => (
<p key={i}>Line {i + 1}: Try scrolling to see the scrollbar appear.</p>
))}
</div>
</ScrollArea>
);
},
};
export const ScrollTypeHover: Story = {
render() {
return (
<ScrollArea className="h-64 w-80 border rounded-lg" scrollType="hover">
<div className="p-4 space-y-2">
<h3 className="text-16 font-semibold">Hover to Show</h3>
<p className="text-13 text-placeholder">Scrollbar appears on hover</p>
{[...Array(15)].map((_, i) => (
<p key={i}>Line {i + 1}: Hover over the area to see the scrollbar.</p>
))}
</div>
</ScrollArea>
);
},
};
export const HorizontalScroll: Story = {
render() {
return (
<ScrollArea className="h-32 w-96 border rounded-lg" orientation="horizontal">
<div className="flex gap-4 p-4 w-[1200px]">
{[...Array(12)].map((_, i) => (
<div key={i} className="flex-shrink-0 w-32 h-20 bg-layer-1 rounded-sm flex items-center justify-center">
Item {i + 1}
</div>
))}
</div>
</ScrollArea>
);
},
};
export const BothDirections: Story = {
render() {
return (
<ScrollArea className="h-64 w-96 border rounded-lg">
<div className="w-[800px] p-4 space-y-2">
<h3 className="text-16 font-semibold">Both Directions</h3>
<p className="text-13 text-placeholder">Content scrolls both vertically and horizontally</p>
{[...Array(20)].map((_, i) => (
<p key={i}>
Line {i + 1}: This line is very long and extends beyond the container width to demonstrate horizontal
scrolling along with vertical scrolling.
</p>
))}
</div>
</ScrollArea>
);
},
};
export const ListExample: Story = {
render() {
return (
<ScrollArea className="h-80 w-96 border rounded-lg">
<div className="p-4">
<h3 className="text-16 font-semibold mb-4">User List</h3>
<div className="space-y-2">
{[...Array(25)].map((_, i) => (
<div
key={i}
className="flex items-center gap-3 p-3 bg-layer-1 rounded-sm hover:bg-surface-2 cursor-pointer"
>
<div className="w-10 h-10 rounded-full bg-accent-primary flex items-center justify-center text-on-color font-medium">
{String.fromCharCode(65 + (i % 26))}
</div>
<div>
<div className="font-medium">User {i + 1}</div>
<div className="text-13 text-placeholder">user{i + 1}@example.com</div>
</div>
</div>
))}
</div>
</div>
</ScrollArea>
);
},
};
export const CodeBlock: Story = {
render() {
const code = `function fibonacci(n) {
if (n <= 1) return n;
let a = 0, b = 1;
for (let i = 2; i <= n; i++) {
const temp = a + b;
a = b;
b = temp;
}
return b;
}
// Example usage
console.log(fibonacci(10)); // 55
console.log(fibonacci(20)); // 6765
const numbers = [1, 2, 3, 4, 5];
const doubled = numbers.map(n => n * 2);
console.log(doubled); // [2, 4, 6, 8, 10]
async function fetchData() {
try {
const response = await fetch('https://api.example.com/data');
const data = await response.json();
return data;
} catch (error) {
console.error('Error fetching data:', error);
}
}`;
return (
<ScrollArea className="h-96 w-full max-w-2xl border rounded-lg bg-surface-1">
<pre className="p-4 text-13">
<code>{code}</code>
</pre>
</ScrollArea>
);
},
};
export const ChatMessages: Story = {
render() {
return (
<ScrollArea className="h-96 w-full max-w-md border rounded-lg">
<div className="p-4 space-y-4">
{[...Array(20)].map((_, i) => (
<div key={i} className={`flex ${i % 3 === 0 ? "justify-end" : "justify-start"}`}>
<div
className={`max-w-[70%] p-3 rounded-lg ${i % 3 === 0 ? "bg-accent-primary text-on-color" : "bg-layer-1"}`}
>
<div className="text-13">{i % 3 === 0 ? "You" : `User ${i + 1}`}</div>
<div className="mt-1">Message content for message number {i + 1}</div>
</div>
</div>
))}
</div>
</ScrollArea>
);
},
};
export const DataTable: Story = {
render() {
return (
<ScrollArea className="h-96 w-full max-w-3xl border rounded-lg">
<table className="w-full">
<thead className="bg-layer-1 sticky top-0">
<tr>
<th className="px-4 py-2 text-left">ID</th>
<th className="px-4 py-2 text-left">Name</th>
<th className="px-4 py-2 text-left">Email</th>
<th className="px-4 py-2 text-left">Status</th>
</tr>
</thead>
<tbody>
{[...Array(50)].map((_, i) => (
<tr key={i} className="border-t border-subtle hover:bg-layer-1">
<td className="px-4 py-2">#{i + 1}</td>
<td className="px-4 py-2">User {i + 1}</td>
<td className="px-4 py-2">user{i + 1}@example.com</td>
<td className="px-4 py-2">
<span
className={`px-2 py-1 rounded-sm text-11 ${i % 3 === 0 ? "bg-green-500/20 text-green-500" : "bg-gray-500/20 text-gray-500"}`}
>
{i % 3 === 0 ? "Active" : "Inactive"}
</span>
</td>
</tr>
))}
</tbody>
</table>
</ScrollArea>
);
},
};