@weave-design-system/react 0.1.0
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/index.cjs +7729 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +677 -0
- package/dist/index.d.ts +677 -0
- package/dist/index.js +7654 -0
- package/dist/index.js.map +1 -0
- package/dist/theme.css +2 -0
- package/dist/tokens.cjs +78 -0
- package/dist/tokens.cjs.map +1 -0
- package/dist/tokens.d.cts +67 -0
- package/dist/tokens.d.ts +67 -0
- package/dist/tokens.js +70 -0
- package/dist/tokens.js.map +1 -0
- package/package.json +103 -0
- package/src/data-display/activity-feed/ActivityFeed.stories.tsx +16 -0
- package/src/data-display/activity-feed/ActivityFeed.test.tsx +11 -0
- package/src/data-display/activity-feed/ActivityFeed.tsx +34 -0
- package/src/data-display/activity-feed/index.ts +2 -0
- package/src/data-display/circular-progress/CircularProgress.stories.tsx +10 -0
- package/src/data-display/circular-progress/CircularProgress.test.tsx +11 -0
- package/src/data-display/circular-progress/CircularProgress.tsx +35 -0
- package/src/data-display/circular-progress/index.ts +2 -0
- package/src/data-display/empty-state/EmptyState.stories.tsx +15 -0
- package/src/data-display/empty-state/EmptyState.test.tsx +18 -0
- package/src/data-display/empty-state/EmptyState.tsx +34 -0
- package/src/data-display/empty-state/index.ts +2 -0
- package/src/data-display/progress-bar/ProgressBar.stories.tsx +10 -0
- package/src/data-display/progress-bar/ProgressBar.test.tsx +15 -0
- package/src/data-display/progress-bar/ProgressBar.tsx +38 -0
- package/src/data-display/progress-bar/index.ts +2 -0
- package/src/data-display/stat-card/StatCard.stories.tsx +10 -0
- package/src/data-display/stat-card/StatCard.test.tsx +15 -0
- package/src/data-display/stat-card/StatCard.tsx +40 -0
- package/src/data-display/stat-card/index.ts +2 -0
- package/src/data-display/table/Table.stories.tsx +44 -0
- package/src/data-display/table/Table.test.tsx +16 -0
- package/src/data-display/table/Table.tsx +71 -0
- package/src/data-display/table/index.ts +1 -0
- package/src/data-display/timeline/Timeline.stories.tsx +16 -0
- package/src/data-display/timeline/Timeline.test.tsx +11 -0
- package/src/data-display/timeline/Timeline.tsx +44 -0
- package/src/data-display/timeline/index.ts +2 -0
- package/src/docs/ComponentOverview.mdx +192 -0
- package/src/docs/DesignTokens.mdx +235 -0
- package/src/docs/GettingStarted.mdx +145 -0
- package/src/feedback/alert-banner/AlertBanner.stories.tsx +10 -0
- package/src/feedback/alert-banner/AlertBanner.test.tsx +16 -0
- package/src/feedback/alert-banner/AlertBanner.tsx +47 -0
- package/src/feedback/alert-banner/index.ts +2 -0
- package/src/feedback/modal/Modal.stories.tsx +31 -0
- package/src/feedback/modal/Modal.test.tsx +33 -0
- package/src/feedback/modal/Modal.tsx +88 -0
- package/src/feedback/modal/index.ts +2 -0
- package/src/feedback/skeleton-loader/SkeletonLoader.stories.tsx +23 -0
- package/src/feedback/skeleton-loader/SkeletonLoader.test.tsx +14 -0
- package/src/feedback/skeleton-loader/SkeletonLoader.tsx +61 -0
- package/src/feedback/skeleton-loader/index.ts +2 -0
- package/src/feedback/toast/Toast.stories.tsx +27 -0
- package/src/feedback/toast/Toast.test.tsx +32 -0
- package/src/feedback/toast/Toast.tsx +106 -0
- package/src/feedback/toast/index.ts +2 -0
- package/src/hooks/index.ts +3 -0
- package/src/hooks/use-controllable-state.ts +34 -0
- package/src/hooks/use-focus-trap.ts +56 -0
- package/src/hooks/use-reduced-motion.ts +17 -0
- package/src/index.ts +148 -0
- package/src/layout/card/Card.stories.tsx +45 -0
- package/src/layout/card/Card.test.tsx +23 -0
- package/src/layout/card/Card.tsx +42 -0
- package/src/layout/card/Card.types.ts +6 -0
- package/src/layout/card/index.ts +2 -0
- package/src/layout/command-palette/CommandPalette.stories.tsx +34 -0
- package/src/layout/command-palette/CommandPalette.test.tsx +43 -0
- package/src/layout/command-palette/CommandPalette.tsx +188 -0
- package/src/layout/command-palette/CommandPalette.types.ts +18 -0
- package/src/layout/command-palette/index.ts +2 -0
- package/src/layout/sidebar/Sidebar.stories.tsx +60 -0
- package/src/layout/sidebar/Sidebar.test.tsx +27 -0
- package/src/layout/sidebar/Sidebar.tsx +57 -0
- package/src/layout/sidebar/Sidebar.types.ts +14 -0
- package/src/layout/sidebar/index.ts +2 -0
- package/src/layout/top-bar/TopBar.stories.tsx +51 -0
- package/src/layout/top-bar/TopBar.test.tsx +18 -0
- package/src/layout/top-bar/TopBar.tsx +19 -0
- package/src/layout/top-bar/TopBar.types.ts +10 -0
- package/src/layout/top-bar/index.ts +2 -0
- package/src/navigation/breadcrumbs/Breadcrumbs.stories.tsx +30 -0
- package/src/navigation/breadcrumbs/Breadcrumbs.test.tsx +43 -0
- package/src/navigation/breadcrumbs/Breadcrumbs.tsx +45 -0
- package/src/navigation/breadcrumbs/Breadcrumbs.types.ts +12 -0
- package/src/navigation/breadcrumbs/index.ts +2 -0
- package/src/navigation/sidebar-nav-item/SidebarNavItem.stories.tsx +41 -0
- package/src/navigation/sidebar-nav-item/SidebarNavItem.test.tsx +46 -0
- package/src/navigation/sidebar-nav-item/SidebarNavItem.tsx +38 -0
- package/src/navigation/sidebar-nav-item/SidebarNavItem.types.ts +12 -0
- package/src/navigation/sidebar-nav-item/index.ts +2 -0
- package/src/navigation/tabs/Tabs.stories.tsx +47 -0
- package/src/navigation/tabs/Tabs.test.tsx +67 -0
- package/src/navigation/tabs/Tabs.tsx +111 -0
- package/src/navigation/tabs/Tabs.types.ts +36 -0
- package/src/navigation/tabs/index.ts +2 -0
- package/src/patterns/accordion/Accordion.stories.tsx +25 -0
- package/src/patterns/accordion/Accordion.test.tsx +44 -0
- package/src/patterns/accordion/Accordion.tsx +92 -0
- package/src/patterns/accordion/index.ts +2 -0
- package/src/patterns/action-menu/ActionMenu.stories.tsx +18 -0
- package/src/patterns/action-menu/ActionMenu.test.tsx +18 -0
- package/src/patterns/action-menu/ActionMenu.tsx +41 -0
- package/src/patterns/action-menu/index.ts +2 -0
- package/src/patterns/carousel/Carousel.stories.tsx +16 -0
- package/src/patterns/carousel/Carousel.test.tsx +16 -0
- package/src/patterns/carousel/Carousel.tsx +69 -0
- package/src/patterns/carousel/index.ts +2 -0
- package/src/patterns/image-placeholder/ImagePlaceholder.stories.tsx +9 -0
- package/src/patterns/image-placeholder/ImagePlaceholder.test.tsx +10 -0
- package/src/patterns/image-placeholder/ImagePlaceholder.tsx +21 -0
- package/src/patterns/image-placeholder/index.ts +2 -0
- package/src/patterns/notification-dot/NotificationDot.stories.tsx +17 -0
- package/src/patterns/notification-dot/NotificationDot.test.tsx +14 -0
- package/src/patterns/notification-dot/NotificationDot.tsx +18 -0
- package/src/patterns/notification-dot/index.ts +2 -0
- package/src/patterns/pagination/Pagination.stories.tsx +14 -0
- package/src/patterns/pagination/Pagination.test.tsx +22 -0
- package/src/patterns/pagination/Pagination.tsx +67 -0
- package/src/patterns/pagination/index.ts +2 -0
- package/src/primitives/avatar/Avatar.stories.tsx +46 -0
- package/src/primitives/avatar/Avatar.test.tsx +35 -0
- package/src/primitives/avatar/Avatar.tsx +49 -0
- package/src/primitives/avatar/Avatar.types.ts +21 -0
- package/src/primitives/avatar/AvatarGroup.tsx +27 -0
- package/src/primitives/avatar/index.ts +3 -0
- package/src/primitives/badge/Badge.stories.tsx +28 -0
- package/src/primitives/badge/Badge.test.tsx +23 -0
- package/src/primitives/badge/Badge.tsx +44 -0
- package/src/primitives/badge/Badge.types.ts +14 -0
- package/src/primitives/badge/index.ts +2 -0
- package/src/primitives/button/Button.stories.tsx +81 -0
- package/src/primitives/button/Button.test.tsx +64 -0
- package/src/primitives/button/Button.tsx +85 -0
- package/src/primitives/button/Button.types.ts +17 -0
- package/src/primitives/button/index.ts +2 -0
- package/src/primitives/checkbox/Checkbox.stories.tsx +27 -0
- package/src/primitives/checkbox/Checkbox.test.tsx +30 -0
- package/src/primitives/checkbox/Checkbox.tsx +79 -0
- package/src/primitives/checkbox/Checkbox.types.ts +12 -0
- package/src/primitives/checkbox/index.ts +2 -0
- package/src/primitives/combobox/Combobox.stories.tsx +44 -0
- package/src/primitives/combobox/Combobox.test.tsx +44 -0
- package/src/primitives/combobox/Combobox.tsx +201 -0
- package/src/primitives/combobox/Combobox.types.ts +25 -0
- package/src/primitives/combobox/index.ts +2 -0
- package/src/primitives/date-input/DateInput.stories.tsx +23 -0
- package/src/primitives/date-input/DateInput.test.tsx +22 -0
- package/src/primitives/date-input/DateInput.tsx +66 -0
- package/src/primitives/date-input/DateInput.types.ts +10 -0
- package/src/primitives/date-input/index.ts +2 -0
- package/src/primitives/file-upload/FileUploadDropzone.stories.tsx +27 -0
- package/src/primitives/file-upload/FileUploadDropzone.test.tsx +26 -0
- package/src/primitives/file-upload/FileUploadDropzone.tsx +99 -0
- package/src/primitives/file-upload/FileUploadDropzone.types.ts +14 -0
- package/src/primitives/file-upload/index.ts +2 -0
- package/src/primitives/input/InputGroup.stories.tsx +31 -0
- package/src/primitives/input/InputGroup.test.tsx +40 -0
- package/src/primitives/input/InputGroup.tsx +65 -0
- package/src/primitives/input/InputGroup.types.ts +12 -0
- package/src/primitives/input/index.ts +2 -0
- package/src/primitives/link/Link.stories.tsx +28 -0
- package/src/primitives/link/Link.test.tsx +23 -0
- package/src/primitives/link/Link.tsx +28 -0
- package/src/primitives/link/Link.types.ts +8 -0
- package/src/primitives/link/index.ts +2 -0
- package/src/primitives/radio/Radio.stories.tsx +29 -0
- package/src/primitives/radio/Radio.test.tsx +32 -0
- package/src/primitives/radio/Radio.tsx +59 -0
- package/src/primitives/radio/Radio.types.ts +6 -0
- package/src/primitives/radio/index.ts +2 -0
- package/src/primitives/select/SelectGroup.stories.tsx +33 -0
- package/src/primitives/select/SelectGroup.test.tsx +34 -0
- package/src/primitives/select/SelectGroup.tsx +72 -0
- package/src/primitives/select/SelectGroup.types.ts +12 -0
- package/src/primitives/select/index.ts +2 -0
- package/src/primitives/slider/Slider.stories.tsx +23 -0
- package/src/primitives/slider/Slider.test.tsx +28 -0
- package/src/primitives/slider/Slider.tsx +80 -0
- package/src/primitives/slider/Slider.types.ts +22 -0
- package/src/primitives/slider/index.ts +2 -0
- package/src/primitives/textarea/TextareaGroup.stories.tsx +27 -0
- package/src/primitives/textarea/TextareaGroup.test.tsx +24 -0
- package/src/primitives/textarea/TextareaGroup.tsx +59 -0
- package/src/primitives/textarea/TextareaGroup.types.ts +10 -0
- package/src/primitives/textarea/index.ts +2 -0
- package/src/primitives/toggle/Toggle.stories.tsx +27 -0
- package/src/primitives/toggle/Toggle.test.tsx +31 -0
- package/src/primitives/toggle/Toggle.tsx +65 -0
- package/src/primitives/toggle/Toggle.types.ts +16 -0
- package/src/primitives/toggle/index.ts +2 -0
- package/src/primitives/tooltip/Tooltip.stories.tsx +45 -0
- package/src/primitives/tooltip/Tooltip.test.tsx +28 -0
- package/src/primitives/tooltip/Tooltip.tsx +94 -0
- package/src/primitives/tooltip/Tooltip.types.ts +16 -0
- package/src/primitives/tooltip/index.ts +2 -0
- package/src/productivity/comment-thread/CommentThread.stories.tsx +20 -0
- package/src/productivity/comment-thread/CommentThread.test.tsx +21 -0
- package/src/productivity/comment-thread/CommentThread.tsx +47 -0
- package/src/productivity/comment-thread/index.ts +2 -0
- package/src/productivity/kanban-board/KanbanBoard.tsx +41 -0
- package/src/productivity/kanban-board/index.ts +2 -0
- package/src/productivity/kanban-column/KanbanColumn.stories.tsx +131 -0
- package/src/productivity/kanban-column/KanbanColumn.test.tsx +18 -0
- package/src/productivity/kanban-column/KanbanColumn.tsx +58 -0
- package/src/productivity/kanban-column/SortableTaskCard.tsx +46 -0
- package/src/productivity/kanban-column/index.ts +4 -0
- package/src/productivity/priority-selector/PrioritySelector.stories.tsx +14 -0
- package/src/productivity/priority-selector/PrioritySelector.test.tsx +18 -0
- package/src/productivity/priority-selector/PrioritySelector.tsx +40 -0
- package/src/productivity/priority-selector/index.ts +2 -0
- package/src/productivity/rich-text-toolbar/RichTextToolbar.stories.tsx +19 -0
- package/src/productivity/rich-text-toolbar/RichTextToolbar.test.tsx +21 -0
- package/src/productivity/rich-text-toolbar/RichTextToolbar.tsx +50 -0
- package/src/productivity/rich-text-toolbar/index.ts +2 -0
- package/src/productivity/task-card/TaskCard.stories.tsx +20 -0
- package/src/productivity/task-card/TaskCard.test.tsx +21 -0
- package/src/productivity/task-card/TaskCard.tsx +76 -0
- package/src/productivity/task-card/index.ts +2 -0
- package/src/test-setup.ts +1 -0
- package/src/tokens/index.ts +1 -0
- package/src/tokens/tokens.ts +71 -0
- package/src/tokens/weave-theme.css +168 -0
- package/src/utils/cn.ts +6 -0
- package/src/utils/index.ts +1 -0
package/dist/theme.css
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */
|
|
2
|
+
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-x-reverse:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:"Satoshi", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--color-black:#000;--color-white:#fff;--spacing:4px;--container-xs:20rem;--container-sm:24rem;--container-md:28rem;--container-lg:32rem;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wider:.05em;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--ease-in:cubic-bezier(.55, 0, 1, .45);--ease-out:cubic-bezier(.22, 1, .36, 1);--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-bg:#faf7f2;--color-surface:#f0ebe3;--color-border:#d9d2c7;--color-text-primary:#2c2825;--color-text-secondary:#6b635a;--color-rust:#b85c38;--color-rust-light:#f0d5c5;--color-rust-dark:#8e4429;--color-forest:#3d6b5e;--color-forest-light:#d4e5df;--color-success:#5e8a6b;--color-success-light:#dde9e0;--color-warning:#c49a3c;--color-warning-light:#f5edd4;--color-error:#b84a3c;--color-error-light:#f3d9d5;--color-info:#7a8a9a;--color-info-light:#e0e5ea;--color-saffron:#d4923a;--color-saffron-light:#f5e3c8;--text-display:2.5rem;--text-h1:2rem;--text-h2:1.625rem;--text-h3:1.375rem;--text-body-lg:1.125rem;--text-body:1rem;--text-body-sm:.875rem;--text-caption:.75rem;--text-code:.875rem;--leading-h1:40px;--leading-h2:34px;--leading-h3:30px;--leading-body-lg:28px;--leading-body:24px;--leading-body-sm:20px;--leading-caption:16px;--radius-full:9999px;--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--animate-skeleton-pulse:skeleton-pulse 2s ease-in-out infinite;--animate-fade-in:fade-in var(--duration-slow) var(--ease-out);--animate-scale-in:scale-in var(--duration-slow) var(--ease-out);--animate-slide-in-right:slide-in-right var(--duration-normal) var(--ease-out)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.-top-0\.5{top:calc(var(--spacing) * -.5)}.top-1\/2{top:50%}.-right-0\.5{right:calc(var(--spacing) * -.5)}.right-2{right:calc(var(--spacing) * 2)}.right-3{right:calc(var(--spacing) * 3)}.right-4{right:calc(var(--spacing) * 4)}.bottom-3{bottom:calc(var(--spacing) * 3)}.bottom-4{bottom:calc(var(--spacing) * 4)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing) * 2)}.z-50{z-index:50}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.mx-1{margin-inline:calc(var(--spacing) * 1)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-6{margin-top:calc(var(--spacing) * 6)}.-mr-0\.5{margin-right:calc(var(--spacing) * -.5)}.-mb-px{margin-bottom:-1px}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.-ml-1{margin-left:calc(var(--spacing) * -1)}.ml-0\.5{margin-left:calc(var(--spacing) * .5)}.ml-4{margin-left:calc(var(--spacing) * 4)}.ml-10{margin-left:calc(var(--spacing) * 10)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-3{height:calc(var(--spacing) * 3)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-14{height:calc(var(--spacing) * 14)}.h-16{height:calc(var(--spacing) * 16)}.h-48{height:calc(var(--spacing) * 48)}.h-\[500px\]{height:500px}.h-full{height:100%}.h-px{height:1px}.max-h-60{max-height:calc(var(--spacing) * 60)}.max-h-72{max-height:calc(var(--spacing) * 72)}.min-h-25{min-height:calc(var(--spacing) * 25)}.min-h-\[80px\]{min-height:80px}.w-2{width:calc(var(--spacing) * 2)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-3{width:calc(var(--spacing) * 3)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-8{width:calc(var(--spacing) * 8)}.w-11{width:calc(var(--spacing) * 11)}.w-14{width:calc(var(--spacing) * 14)}.w-16{width:calc(var(--spacing) * 16)}.w-56{width:calc(var(--spacing) * 56)}.w-60{width:calc(var(--spacing) * 60)}.w-72{width:calc(var(--spacing) * 72)}.w-full{width:100%}.w-px{width:1px}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.max-w-xs{max-width:var(--container-xs)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[36px\]{min-width:36px}.flex-1{flex:1}.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-\[2px\]{--tw-translate-x:2px;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-\[22px\]{--tw-translate-x:22px;translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.scale-0{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-\[1\.02\]{scale:1.02}.-rotate-90{rotate:-90deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-fade-in{animation:var(--animate-fade-in)}.animate-scale-in{animation:var(--animate-scale-in)}.animate-skeleton-pulse{animation:var(--animate-skeleton-pulse)}.animate-slide-in-right{animation:var(--animate-slide-in-right)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-grab{cursor:grab}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-y{resize:vertical}.appearance-none{appearance:none}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.-space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * -2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * -2) * calc(1 - var(--tw-space-x-reverse)))}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-border>:not(:last-child)){border-color:var(--color-border)}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:var(--radius-full)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-border{border-color:var(--color-border)}.border-error{border-color:var(--color-error)}.border-info{border-color:var(--color-info)}.border-rust{border-color:var(--color-rust)}.border-success{border-color:var(--color-success)}.border-transparent{border-color:#0000}.border-warning{border-color:var(--color-warning)}.bg-bg{background-color:var(--color-bg)}.bg-border{background-color:var(--color-border)}.bg-error{background-color:var(--color-error)}.bg-error-light{background-color:var(--color-error-light)}.bg-forest{background-color:var(--color-forest)}.bg-forest-light{background-color:var(--color-forest-light)}.bg-info-light{background-color:var(--color-info-light)}.bg-rust{background-color:var(--color-rust)}.bg-rust-light{background-color:var(--color-rust-light)}.bg-rust-light\/30{background-color:#f0d5c54d}@supports (color:color-mix(in lab, red, red)){.bg-rust-light\/30{background-color:color-mix(in oklab, var(--color-rust-light) 30%, transparent)}}.bg-saffron-light{background-color:var(--color-saffron-light)}.bg-success-light{background-color:var(--color-success-light)}.bg-surface{background-color:var(--color-surface)}.bg-surface\/50{background-color:#f0ebe380}@supports (color:color-mix(in lab, red, red)){.bg-surface\/50{background-color:color-mix(in oklab, var(--color-surface) 50%, transparent)}}.bg-text-primary{background-color:var(--color-text-primary)}.bg-text-primary\/30{background-color:#2c28254d}@supports (color:color-mix(in lab, red, red)){.bg-text-primary\/30{background-color:color-mix(in oklab, var(--color-text-primary) 30%, transparent)}}.bg-transparent{background-color:#0000}.bg-warning{background-color:var(--color-warning)}.bg-warning-light{background-color:var(--color-warning-light)}.bg-white{background-color:var(--color-white)}.bg-white\/60{background-color:#fff9}@supports (color:color-mix(in lab, red, red)){.bg-white\/60{background-color:color-mix(in oklab, var(--color-white) 60%, transparent)}}.bg-white\/80{background-color:#fffc}@supports (color:color-mix(in lab, red, red)){.bg-white\/80{background-color:color-mix(in oklab, var(--color-white) 80%, transparent)}}.object-cover{object-fit:cover}.p-0\.5{padding:calc(var(--spacing) * .5)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.p-20{padding:calc(var(--spacing) * 20)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-16{padding-block:calc(var(--spacing) * 16)}.pt-\[20vh\]{padding-top:20vh}.pr-10{padding-right:calc(var(--spacing) * 10)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-6{padding-bottom:calc(var(--spacing) * 6)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.text-error{color:var(--color-error)}.text-forest{color:var(--color-forest)}.text-info{color:var(--color-info)}.text-rust{color:var(--color-rust)}.text-rust-dark{color:var(--color-rust-dark)}.text-saffron{color:var(--color-saffron)}.text-success{color:var(--color-success)}.text-text-primary{color:var(--color-text-primary)}.text-text-secondary{color:var(--color-text-secondary)}.text-warning{color:var(--color-warning)}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.no-underline{text-decoration-line:none}.underline{text-decoration-line:underline}.underline-offset-2{text-underline-offset:2px}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-80{opacity:.8}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-1{--tw-shadow:0 1px 3px var(--tw-shadow-color,#2c28250f);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-2{--tw-shadow:0 4px 12px var(--tw-shadow-color,#2c282514);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-3{--tw-shadow:0 8px 24px var(--tw-shadow-color,#2c28251f);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-4{--tw-shadow:0 16px 48px var(--tw-shadow-color,#2c282529);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-bg{--tw-ring-color:var(--color-bg)}.ring-white{--tw-ring-color:var(--color-white)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.ease-spring{--tw-ease:var(--ease-spring);transition-timing-function:var(--ease-spring)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.peer-checked\:scale-100:is(:where(.peer):checked~*){--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y)}.peer-checked\:border-rust:is(:where(.peer):checked~*){border-color:var(--color-rust)}.peer-focus-visible\:outline-2:is(:where(.peer):focus-visible~*){outline-style:var(--tw-outline-style);outline-width:2px}.peer-focus-visible\:outline-offset-2:is(:where(.peer):focus-visible~*){outline-offset:2px}.peer-focus-visible\:outline-rust:is(:where(.peer):focus-visible~*){outline-color:var(--color-rust)}.placeholder\:text-text-secondary::placeholder{color:var(--color-text-secondary)}.last\:border-0:last-child{border-style:var(--tw-border-style);border-width:0}.last\:pb-0:last-child{padding-bottom:calc(var(--spacing) * 0)}@media (hover:hover){.hover\:-translate-y-0\.5:hover{--tw-translate-y:calc(var(--spacing) * -.5);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:bg-black\/10:hover{background-color:#0000001a}@supports (color:color-mix(in lab, red, red)){.hover\:bg-black\/10:hover{background-color:color-mix(in oklab, var(--color-black) 10%, transparent)}}.hover\:bg-border\/30:hover{background-color:#d9d2c74d}@supports (color:color-mix(in lab, red, red)){.hover\:bg-border\/30:hover{background-color:color-mix(in oklab, var(--color-border) 30%, transparent)}}.hover\:bg-border\/50:hover{background-color:#d9d2c780}@supports (color:color-mix(in lab, red, red)){.hover\:bg-border\/50:hover{background-color:color-mix(in oklab, var(--color-border) 50%, transparent)}}.hover\:bg-error-light:hover{background-color:var(--color-error-light)}.hover\:bg-error\/90:hover{background-color:#b84a3ce6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-error\/90:hover{background-color:color-mix(in oklab, var(--color-error) 90%, transparent)}}.hover\:bg-forest\/90:hover{background-color:#3d6b5ee6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-forest\/90:hover{background-color:color-mix(in oklab, var(--color-forest) 90%, transparent)}}.hover\:bg-rust-dark:hover{background-color:var(--color-rust-dark)}.hover\:bg-surface:hover{background-color:var(--color-surface)}.hover\:bg-surface\/50:hover{background-color:#f0ebe380}@supports (color:color-mix(in lab, red, red)){.hover\:bg-surface\/50:hover{background-color:color-mix(in oklab, var(--color-surface) 50%, transparent)}}.hover\:bg-white:hover{background-color:var(--color-white)}.hover\:text-rust:hover{color:var(--color-rust)}.hover\:text-rust-dark:hover{color:var(--color-rust-dark)}.hover\:text-text-primary:hover{color:var(--color-text-primary)}.hover\:shadow-2:hover{--tw-shadow:0 4px 12px var(--tw-shadow-color,#2c282514);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}}.focus\:border-rust:focus{border-color:var(--color-rust)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-rust-light:focus{--tw-ring-color:var(--color-rust-light)}.focus-visible\:outline-2:focus-visible{outline-style:var(--tw-outline-style);outline-width:2px}.focus-visible\:outline-offset-2:focus-visible{outline-offset:2px}.focus-visible\:outline-rust:focus-visible{outline-color:var(--color-rust)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.active\:scale-\[0\.97\]:active{scale:.97}.active\:cursor-grabbing:active{cursor:grabbing}.active\:bg-border:active{background-color:var(--color-border)}.active\:bg-error\/80:active{background-color:#b84a3ccc}@supports (color:color-mix(in lab, red, red)){.active\:bg-error\/80:active{background-color:color-mix(in oklab, var(--color-error) 80%, transparent)}}.active\:bg-forest\/80:active{background-color:#3d6b5ecc}@supports (color:color-mix(in lab, red, red)){.active\:bg-forest\/80:active{background-color:color-mix(in oklab, var(--color-forest) 80%, transparent)}}.active\:bg-rust-dark\/90:active{background-color:#8e4429e6}@supports (color:color-mix(in lab, red, red)){.active\:bg-rust-dark\/90:active{background-color:color-mix(in oklab, var(--color-rust-dark) 90%, transparent)}}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-border:disabled{background-color:var(--color-border)}.disabled\:text-text-secondary:disabled{color:var(--color-text-secondary)}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:active\:scale-100:disabled:active{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y)}.\[\&\:\:-moz-range-thumb\]\:h-5::-moz-range-thumb{height:calc(var(--spacing) * 5)}.\[\&\:\:-moz-range-thumb\]\:w-5::-moz-range-thumb{width:calc(var(--spacing) * 5)}.\[\&\:\:-moz-range-thumb\]\:appearance-none::-moz-range-thumb{appearance:none}.\[\&\:\:-moz-range-thumb\]\:rounded-full::-moz-range-thumb{border-radius:var(--radius-full)}.\[\&\:\:-moz-range-thumb\]\:border-2::-moz-range-thumb{border-style:var(--tw-border-style);border-width:2px}.\[\&\:\:-moz-range-thumb\]\:border-white::-moz-range-thumb{border-color:var(--color-white)}.\[\&\:\:-moz-range-thumb\]\:bg-rust::-moz-range-thumb{background-color:var(--color-rust)}.\[\&\:\:-moz-range-thumb\]\:shadow-2::-moz-range-thumb{--tw-shadow:0 4px 12px var(--tw-shadow-color,#2c282514);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.\[\&\:\:-webkit-slider-thumb\]\:h-5::-webkit-slider-thumb{height:calc(var(--spacing) * 5)}.\[\&\:\:-webkit-slider-thumb\]\:w-5::-webkit-slider-thumb{width:calc(var(--spacing) * 5)}.\[\&\:\:-webkit-slider-thumb\]\:appearance-none::-webkit-slider-thumb{appearance:none}.\[\&\:\:-webkit-slider-thumb\]\:rounded-full::-webkit-slider-thumb{border-radius:var(--radius-full)}.\[\&\:\:-webkit-slider-thumb\]\:border-2::-webkit-slider-thumb{border-style:var(--tw-border-style);border-width:2px}.\[\&\:\:-webkit-slider-thumb\]\:border-white::-webkit-slider-thumb{border-color:var(--color-white)}.\[\&\:\:-webkit-slider-thumb\]\:bg-rust::-webkit-slider-thumb{background-color:var(--color-rust)}.\[\&\:\:-webkit-slider-thumb\]\:shadow-2::-webkit-slider-thumb{--tw-shadow:0 4px 12px var(--tw-shadow-color,#2c282514);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.\[\&\:\:-webkit-slider-thumb\]\:transition-transform::-webkit-slider-thumb{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.\[\&\:\:-webkit-slider-thumb\]\:hover\:scale-110::-webkit-slider-thumb:hover{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}}.\[\&\>tr\:last-child\]\:border-0>tr:last-child{border-style:var(--tw-border-style);border-width:0}}:root{--duration-micro:.1s;--duration-fast:.2s;--duration-normal:.35s;--duration-slow:.5s}@media (prefers-reduced-motion:reduce){:root{--duration-micro:0s;--duration-fast:0s;--duration-normal:0s;--duration-slow:0s}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}
|
package/dist/tokens.cjs
ADDED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
// src/tokens/tokens.ts
|
|
4
|
+
var colors = {
|
|
5
|
+
bg: "#FAF7F2",
|
|
6
|
+
surface: "#F0EBE3",
|
|
7
|
+
border: "#D9D2C7",
|
|
8
|
+
textPrimary: "#2C2825",
|
|
9
|
+
textSecondary: "#6B635A",
|
|
10
|
+
white: "#FFFFFF",
|
|
11
|
+
rust: "#B85C38",
|
|
12
|
+
rustLight: "#F0D5C5",
|
|
13
|
+
rustDark: "#8E4429",
|
|
14
|
+
forest: "#3D6B5E",
|
|
15
|
+
forestLight: "#D4E5DF",
|
|
16
|
+
success: "#5E8A6B",
|
|
17
|
+
successLight: "#DDE9E0",
|
|
18
|
+
warning: "#C49A3C",
|
|
19
|
+
warningLight: "#F5EDD4",
|
|
20
|
+
error: "#B84A3C",
|
|
21
|
+
errorLight: "#F3D9D5",
|
|
22
|
+
info: "#7A8A9A",
|
|
23
|
+
infoLight: "#E0E5EA",
|
|
24
|
+
saffron: "#D4923A",
|
|
25
|
+
saffronLight: "#F5E3C8"
|
|
26
|
+
};
|
|
27
|
+
var spacing = {
|
|
28
|
+
1: "4px",
|
|
29
|
+
2: "8px",
|
|
30
|
+
3: "12px",
|
|
31
|
+
4: "16px",
|
|
32
|
+
5: "20px",
|
|
33
|
+
6: "24px",
|
|
34
|
+
8: "32px",
|
|
35
|
+
10: "40px",
|
|
36
|
+
12: "48px",
|
|
37
|
+
16: "64px",
|
|
38
|
+
20: "80px",
|
|
39
|
+
24: "96px"
|
|
40
|
+
};
|
|
41
|
+
var radii = {
|
|
42
|
+
sm: "6px",
|
|
43
|
+
md: "10px",
|
|
44
|
+
lg: "16px",
|
|
45
|
+
xl: "24px",
|
|
46
|
+
full: "9999px"
|
|
47
|
+
};
|
|
48
|
+
var shadows = {
|
|
49
|
+
1: "0 1px 3px rgba(44, 40, 37, 0.06)",
|
|
50
|
+
2: "0 4px 12px rgba(44, 40, 37, 0.08)",
|
|
51
|
+
3: "0 8px 24px rgba(44, 40, 37, 0.12)",
|
|
52
|
+
4: "0 16px 48px rgba(44, 40, 37, 0.16)"
|
|
53
|
+
};
|
|
54
|
+
var durations = {
|
|
55
|
+
micro: "100ms",
|
|
56
|
+
fast: "200ms",
|
|
57
|
+
normal: "350ms",
|
|
58
|
+
slow: "500ms"
|
|
59
|
+
};
|
|
60
|
+
var easings = {
|
|
61
|
+
out: "cubic-bezier(0.22, 1, 0.36, 1)",
|
|
62
|
+
in: "cubic-bezier(0.55, 0, 1, 0.45)",
|
|
63
|
+
spring: "cubic-bezier(0.34, 1.56, 0.64, 1)"
|
|
64
|
+
};
|
|
65
|
+
var typography = {
|
|
66
|
+
fontSans: "'Satoshi', system-ui, -apple-system, sans-serif",
|
|
67
|
+
fontMono: "'JetBrains Mono', 'Fira Code', monospace"
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
exports.colors = colors;
|
|
71
|
+
exports.durations = durations;
|
|
72
|
+
exports.easings = easings;
|
|
73
|
+
exports.radii = radii;
|
|
74
|
+
exports.shadows = shadows;
|
|
75
|
+
exports.spacing = spacing;
|
|
76
|
+
exports.typography = typography;
|
|
77
|
+
//# sourceMappingURL=tokens.cjs.map
|
|
78
|
+
//# sourceMappingURL=tokens.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/tokens/tokens.ts"],"names":[],"mappings":";;;AAAO,IAAM,MAAA,GAAS;AAAA,EACpB,EAAA,EAAI,SAAA;AAAA,EACJ,OAAA,EAAS,SAAA;AAAA,EACT,MAAA,EAAQ,SAAA;AAAA,EACR,WAAA,EAAa,SAAA;AAAA,EACb,aAAA,EAAe,SAAA;AAAA,EACf,KAAA,EAAO,SAAA;AAAA,EACP,IAAA,EAAM,SAAA;AAAA,EACN,SAAA,EAAW,SAAA;AAAA,EACX,QAAA,EAAU,SAAA;AAAA,EACV,MAAA,EAAQ,SAAA;AAAA,EACR,WAAA,EAAa,SAAA;AAAA,EACb,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc,SAAA;AAAA,EACd,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc,SAAA;AAAA,EACd,KAAA,EAAO,SAAA;AAAA,EACP,UAAA,EAAY,SAAA;AAAA,EACZ,IAAA,EAAM,SAAA;AAAA,EACN,SAAA,EAAW,SAAA;AAAA,EACX,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc;AAChB;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,CAAA,EAAG,KAAA;AAAA,EACH,CAAA,EAAG,KAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI;AACN;AAEO,IAAM,KAAA,GAAQ;AAAA,EACnB,EAAA,EAAI,KAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,IAAA,EAAM;AACR;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,CAAA,EAAG,kCAAA;AAAA,EACH,CAAA,EAAG,mCAAA;AAAA,EACH,CAAA,EAAG,mCAAA;AAAA,EACH,CAAA,EAAG;AACL;AAEO,IAAM,SAAA,GAAY;AAAA,EACvB,KAAA,EAAO,OAAA;AAAA,EACP,IAAA,EAAM,OAAA;AAAA,EACN,MAAA,EAAQ,OAAA;AAAA,EACR,IAAA,EAAM;AACR;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,GAAA,EAAK,gCAAA;AAAA,EACL,EAAA,EAAI,gCAAA;AAAA,EACJ,MAAA,EAAQ;AACV;AAEO,IAAM,UAAA,GAAa;AAAA,EACxB,QAAA,EAAU,iDAAA;AAAA,EACV,QAAA,EAAU;AACZ","file":"tokens.cjs","sourcesContent":["export const colors = {\n bg: '#FAF7F2',\n surface: '#F0EBE3',\n border: '#D9D2C7',\n textPrimary: '#2C2825',\n textSecondary: '#6B635A',\n white: '#FFFFFF',\n rust: '#B85C38',\n rustLight: '#F0D5C5',\n rustDark: '#8E4429',\n forest: '#3D6B5E',\n forestLight: '#D4E5DF',\n success: '#5E8A6B',\n successLight: '#DDE9E0',\n warning: '#C49A3C',\n warningLight: '#F5EDD4',\n error: '#B84A3C',\n errorLight: '#F3D9D5',\n info: '#7A8A9A',\n infoLight: '#E0E5EA',\n saffron: '#D4923A',\n saffronLight: '#F5E3C8',\n} as const;\n\nexport const spacing = {\n 1: '4px',\n 2: '8px',\n 3: '12px',\n 4: '16px',\n 5: '20px',\n 6: '24px',\n 8: '32px',\n 10: '40px',\n 12: '48px',\n 16: '64px',\n 20: '80px',\n 24: '96px',\n} as const;\n\nexport const radii = {\n sm: '6px',\n md: '10px',\n lg: '16px',\n xl: '24px',\n full: '9999px',\n} as const;\n\nexport const shadows = {\n 1: '0 1px 3px rgba(44, 40, 37, 0.06)',\n 2: '0 4px 12px rgba(44, 40, 37, 0.08)',\n 3: '0 8px 24px rgba(44, 40, 37, 0.12)',\n 4: '0 16px 48px rgba(44, 40, 37, 0.16)',\n} as const;\n\nexport const durations = {\n micro: '100ms',\n fast: '200ms',\n normal: '350ms',\n slow: '500ms',\n} as const;\n\nexport const easings = {\n out: 'cubic-bezier(0.22, 1, 0.36, 1)',\n in: 'cubic-bezier(0.55, 0, 1, 0.45)',\n spring: 'cubic-bezier(0.34, 1.56, 0.64, 1)',\n} as const;\n\nexport const typography = {\n fontSans: \"'Satoshi', system-ui, -apple-system, sans-serif\",\n fontMono: \"'JetBrains Mono', 'Fira Code', monospace\",\n} as const;\n"]}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
declare const colors: {
|
|
2
|
+
readonly bg: "#FAF7F2";
|
|
3
|
+
readonly surface: "#F0EBE3";
|
|
4
|
+
readonly border: "#D9D2C7";
|
|
5
|
+
readonly textPrimary: "#2C2825";
|
|
6
|
+
readonly textSecondary: "#6B635A";
|
|
7
|
+
readonly white: "#FFFFFF";
|
|
8
|
+
readonly rust: "#B85C38";
|
|
9
|
+
readonly rustLight: "#F0D5C5";
|
|
10
|
+
readonly rustDark: "#8E4429";
|
|
11
|
+
readonly forest: "#3D6B5E";
|
|
12
|
+
readonly forestLight: "#D4E5DF";
|
|
13
|
+
readonly success: "#5E8A6B";
|
|
14
|
+
readonly successLight: "#DDE9E0";
|
|
15
|
+
readonly warning: "#C49A3C";
|
|
16
|
+
readonly warningLight: "#F5EDD4";
|
|
17
|
+
readonly error: "#B84A3C";
|
|
18
|
+
readonly errorLight: "#F3D9D5";
|
|
19
|
+
readonly info: "#7A8A9A";
|
|
20
|
+
readonly infoLight: "#E0E5EA";
|
|
21
|
+
readonly saffron: "#D4923A";
|
|
22
|
+
readonly saffronLight: "#F5E3C8";
|
|
23
|
+
};
|
|
24
|
+
declare const spacing: {
|
|
25
|
+
readonly 1: "4px";
|
|
26
|
+
readonly 2: "8px";
|
|
27
|
+
readonly 3: "12px";
|
|
28
|
+
readonly 4: "16px";
|
|
29
|
+
readonly 5: "20px";
|
|
30
|
+
readonly 6: "24px";
|
|
31
|
+
readonly 8: "32px";
|
|
32
|
+
readonly 10: "40px";
|
|
33
|
+
readonly 12: "48px";
|
|
34
|
+
readonly 16: "64px";
|
|
35
|
+
readonly 20: "80px";
|
|
36
|
+
readonly 24: "96px";
|
|
37
|
+
};
|
|
38
|
+
declare const radii: {
|
|
39
|
+
readonly sm: "6px";
|
|
40
|
+
readonly md: "10px";
|
|
41
|
+
readonly lg: "16px";
|
|
42
|
+
readonly xl: "24px";
|
|
43
|
+
readonly full: "9999px";
|
|
44
|
+
};
|
|
45
|
+
declare const shadows: {
|
|
46
|
+
readonly 1: "0 1px 3px rgba(44, 40, 37, 0.06)";
|
|
47
|
+
readonly 2: "0 4px 12px rgba(44, 40, 37, 0.08)";
|
|
48
|
+
readonly 3: "0 8px 24px rgba(44, 40, 37, 0.12)";
|
|
49
|
+
readonly 4: "0 16px 48px rgba(44, 40, 37, 0.16)";
|
|
50
|
+
};
|
|
51
|
+
declare const durations: {
|
|
52
|
+
readonly micro: "100ms";
|
|
53
|
+
readonly fast: "200ms";
|
|
54
|
+
readonly normal: "350ms";
|
|
55
|
+
readonly slow: "500ms";
|
|
56
|
+
};
|
|
57
|
+
declare const easings: {
|
|
58
|
+
readonly out: "cubic-bezier(0.22, 1, 0.36, 1)";
|
|
59
|
+
readonly in: "cubic-bezier(0.55, 0, 1, 0.45)";
|
|
60
|
+
readonly spring: "cubic-bezier(0.34, 1.56, 0.64, 1)";
|
|
61
|
+
};
|
|
62
|
+
declare const typography: {
|
|
63
|
+
readonly fontSans: "'Satoshi', system-ui, -apple-system, sans-serif";
|
|
64
|
+
readonly fontMono: "'JetBrains Mono', 'Fira Code', monospace";
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
export { colors, durations, easings, radii, shadows, spacing, typography };
|
package/dist/tokens.d.ts
ADDED
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
declare const colors: {
|
|
2
|
+
readonly bg: "#FAF7F2";
|
|
3
|
+
readonly surface: "#F0EBE3";
|
|
4
|
+
readonly border: "#D9D2C7";
|
|
5
|
+
readonly textPrimary: "#2C2825";
|
|
6
|
+
readonly textSecondary: "#6B635A";
|
|
7
|
+
readonly white: "#FFFFFF";
|
|
8
|
+
readonly rust: "#B85C38";
|
|
9
|
+
readonly rustLight: "#F0D5C5";
|
|
10
|
+
readonly rustDark: "#8E4429";
|
|
11
|
+
readonly forest: "#3D6B5E";
|
|
12
|
+
readonly forestLight: "#D4E5DF";
|
|
13
|
+
readonly success: "#5E8A6B";
|
|
14
|
+
readonly successLight: "#DDE9E0";
|
|
15
|
+
readonly warning: "#C49A3C";
|
|
16
|
+
readonly warningLight: "#F5EDD4";
|
|
17
|
+
readonly error: "#B84A3C";
|
|
18
|
+
readonly errorLight: "#F3D9D5";
|
|
19
|
+
readonly info: "#7A8A9A";
|
|
20
|
+
readonly infoLight: "#E0E5EA";
|
|
21
|
+
readonly saffron: "#D4923A";
|
|
22
|
+
readonly saffronLight: "#F5E3C8";
|
|
23
|
+
};
|
|
24
|
+
declare const spacing: {
|
|
25
|
+
readonly 1: "4px";
|
|
26
|
+
readonly 2: "8px";
|
|
27
|
+
readonly 3: "12px";
|
|
28
|
+
readonly 4: "16px";
|
|
29
|
+
readonly 5: "20px";
|
|
30
|
+
readonly 6: "24px";
|
|
31
|
+
readonly 8: "32px";
|
|
32
|
+
readonly 10: "40px";
|
|
33
|
+
readonly 12: "48px";
|
|
34
|
+
readonly 16: "64px";
|
|
35
|
+
readonly 20: "80px";
|
|
36
|
+
readonly 24: "96px";
|
|
37
|
+
};
|
|
38
|
+
declare const radii: {
|
|
39
|
+
readonly sm: "6px";
|
|
40
|
+
readonly md: "10px";
|
|
41
|
+
readonly lg: "16px";
|
|
42
|
+
readonly xl: "24px";
|
|
43
|
+
readonly full: "9999px";
|
|
44
|
+
};
|
|
45
|
+
declare const shadows: {
|
|
46
|
+
readonly 1: "0 1px 3px rgba(44, 40, 37, 0.06)";
|
|
47
|
+
readonly 2: "0 4px 12px rgba(44, 40, 37, 0.08)";
|
|
48
|
+
readonly 3: "0 8px 24px rgba(44, 40, 37, 0.12)";
|
|
49
|
+
readonly 4: "0 16px 48px rgba(44, 40, 37, 0.16)";
|
|
50
|
+
};
|
|
51
|
+
declare const durations: {
|
|
52
|
+
readonly micro: "100ms";
|
|
53
|
+
readonly fast: "200ms";
|
|
54
|
+
readonly normal: "350ms";
|
|
55
|
+
readonly slow: "500ms";
|
|
56
|
+
};
|
|
57
|
+
declare const easings: {
|
|
58
|
+
readonly out: "cubic-bezier(0.22, 1, 0.36, 1)";
|
|
59
|
+
readonly in: "cubic-bezier(0.55, 0, 1, 0.45)";
|
|
60
|
+
readonly spring: "cubic-bezier(0.34, 1.56, 0.64, 1)";
|
|
61
|
+
};
|
|
62
|
+
declare const typography: {
|
|
63
|
+
readonly fontSans: "'Satoshi', system-ui, -apple-system, sans-serif";
|
|
64
|
+
readonly fontMono: "'JetBrains Mono', 'Fira Code', monospace";
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
export { colors, durations, easings, radii, shadows, spacing, typography };
|
package/dist/tokens.js
ADDED
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
// src/tokens/tokens.ts
|
|
2
|
+
var colors = {
|
|
3
|
+
bg: "#FAF7F2",
|
|
4
|
+
surface: "#F0EBE3",
|
|
5
|
+
border: "#D9D2C7",
|
|
6
|
+
textPrimary: "#2C2825",
|
|
7
|
+
textSecondary: "#6B635A",
|
|
8
|
+
white: "#FFFFFF",
|
|
9
|
+
rust: "#B85C38",
|
|
10
|
+
rustLight: "#F0D5C5",
|
|
11
|
+
rustDark: "#8E4429",
|
|
12
|
+
forest: "#3D6B5E",
|
|
13
|
+
forestLight: "#D4E5DF",
|
|
14
|
+
success: "#5E8A6B",
|
|
15
|
+
successLight: "#DDE9E0",
|
|
16
|
+
warning: "#C49A3C",
|
|
17
|
+
warningLight: "#F5EDD4",
|
|
18
|
+
error: "#B84A3C",
|
|
19
|
+
errorLight: "#F3D9D5",
|
|
20
|
+
info: "#7A8A9A",
|
|
21
|
+
infoLight: "#E0E5EA",
|
|
22
|
+
saffron: "#D4923A",
|
|
23
|
+
saffronLight: "#F5E3C8"
|
|
24
|
+
};
|
|
25
|
+
var spacing = {
|
|
26
|
+
1: "4px",
|
|
27
|
+
2: "8px",
|
|
28
|
+
3: "12px",
|
|
29
|
+
4: "16px",
|
|
30
|
+
5: "20px",
|
|
31
|
+
6: "24px",
|
|
32
|
+
8: "32px",
|
|
33
|
+
10: "40px",
|
|
34
|
+
12: "48px",
|
|
35
|
+
16: "64px",
|
|
36
|
+
20: "80px",
|
|
37
|
+
24: "96px"
|
|
38
|
+
};
|
|
39
|
+
var radii = {
|
|
40
|
+
sm: "6px",
|
|
41
|
+
md: "10px",
|
|
42
|
+
lg: "16px",
|
|
43
|
+
xl: "24px",
|
|
44
|
+
full: "9999px"
|
|
45
|
+
};
|
|
46
|
+
var shadows = {
|
|
47
|
+
1: "0 1px 3px rgba(44, 40, 37, 0.06)",
|
|
48
|
+
2: "0 4px 12px rgba(44, 40, 37, 0.08)",
|
|
49
|
+
3: "0 8px 24px rgba(44, 40, 37, 0.12)",
|
|
50
|
+
4: "0 16px 48px rgba(44, 40, 37, 0.16)"
|
|
51
|
+
};
|
|
52
|
+
var durations = {
|
|
53
|
+
micro: "100ms",
|
|
54
|
+
fast: "200ms",
|
|
55
|
+
normal: "350ms",
|
|
56
|
+
slow: "500ms"
|
|
57
|
+
};
|
|
58
|
+
var easings = {
|
|
59
|
+
out: "cubic-bezier(0.22, 1, 0.36, 1)",
|
|
60
|
+
in: "cubic-bezier(0.55, 0, 1, 0.45)",
|
|
61
|
+
spring: "cubic-bezier(0.34, 1.56, 0.64, 1)"
|
|
62
|
+
};
|
|
63
|
+
var typography = {
|
|
64
|
+
fontSans: "'Satoshi', system-ui, -apple-system, sans-serif",
|
|
65
|
+
fontMono: "'JetBrains Mono', 'Fira Code', monospace"
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
export { colors, durations, easings, radii, shadows, spacing, typography };
|
|
69
|
+
//# sourceMappingURL=tokens.js.map
|
|
70
|
+
//# sourceMappingURL=tokens.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/tokens/tokens.ts"],"names":[],"mappings":";AAAO,IAAM,MAAA,GAAS;AAAA,EACpB,EAAA,EAAI,SAAA;AAAA,EACJ,OAAA,EAAS,SAAA;AAAA,EACT,MAAA,EAAQ,SAAA;AAAA,EACR,WAAA,EAAa,SAAA;AAAA,EACb,aAAA,EAAe,SAAA;AAAA,EACf,KAAA,EAAO,SAAA;AAAA,EACP,IAAA,EAAM,SAAA;AAAA,EACN,SAAA,EAAW,SAAA;AAAA,EACX,QAAA,EAAU,SAAA;AAAA,EACV,MAAA,EAAQ,SAAA;AAAA,EACR,WAAA,EAAa,SAAA;AAAA,EACb,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc,SAAA;AAAA,EACd,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc,SAAA;AAAA,EACd,KAAA,EAAO,SAAA;AAAA,EACP,UAAA,EAAY,SAAA;AAAA,EACZ,IAAA,EAAM,SAAA;AAAA,EACN,SAAA,EAAW,SAAA;AAAA,EACX,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc;AAChB;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,CAAA,EAAG,KAAA;AAAA,EACH,CAAA,EAAG,KAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI;AACN;AAEO,IAAM,KAAA,GAAQ;AAAA,EACnB,EAAA,EAAI,KAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,IAAA,EAAM;AACR;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,CAAA,EAAG,kCAAA;AAAA,EACH,CAAA,EAAG,mCAAA;AAAA,EACH,CAAA,EAAG,mCAAA;AAAA,EACH,CAAA,EAAG;AACL;AAEO,IAAM,SAAA,GAAY;AAAA,EACvB,KAAA,EAAO,OAAA;AAAA,EACP,IAAA,EAAM,OAAA;AAAA,EACN,MAAA,EAAQ,OAAA;AAAA,EACR,IAAA,EAAM;AACR;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,GAAA,EAAK,gCAAA;AAAA,EACL,EAAA,EAAI,gCAAA;AAAA,EACJ,MAAA,EAAQ;AACV;AAEO,IAAM,UAAA,GAAa;AAAA,EACxB,QAAA,EAAU,iDAAA;AAAA,EACV,QAAA,EAAU;AACZ","file":"tokens.js","sourcesContent":["export const colors = {\n bg: '#FAF7F2',\n surface: '#F0EBE3',\n border: '#D9D2C7',\n textPrimary: '#2C2825',\n textSecondary: '#6B635A',\n white: '#FFFFFF',\n rust: '#B85C38',\n rustLight: '#F0D5C5',\n rustDark: '#8E4429',\n forest: '#3D6B5E',\n forestLight: '#D4E5DF',\n success: '#5E8A6B',\n successLight: '#DDE9E0',\n warning: '#C49A3C',\n warningLight: '#F5EDD4',\n error: '#B84A3C',\n errorLight: '#F3D9D5',\n info: '#7A8A9A',\n infoLight: '#E0E5EA',\n saffron: '#D4923A',\n saffronLight: '#F5E3C8',\n} as const;\n\nexport const spacing = {\n 1: '4px',\n 2: '8px',\n 3: '12px',\n 4: '16px',\n 5: '20px',\n 6: '24px',\n 8: '32px',\n 10: '40px',\n 12: '48px',\n 16: '64px',\n 20: '80px',\n 24: '96px',\n} as const;\n\nexport const radii = {\n sm: '6px',\n md: '10px',\n lg: '16px',\n xl: '24px',\n full: '9999px',\n} as const;\n\nexport const shadows = {\n 1: '0 1px 3px rgba(44, 40, 37, 0.06)',\n 2: '0 4px 12px rgba(44, 40, 37, 0.08)',\n 3: '0 8px 24px rgba(44, 40, 37, 0.12)',\n 4: '0 16px 48px rgba(44, 40, 37, 0.16)',\n} as const;\n\nexport const durations = {\n micro: '100ms',\n fast: '200ms',\n normal: '350ms',\n slow: '500ms',\n} as const;\n\nexport const easings = {\n out: 'cubic-bezier(0.22, 1, 0.36, 1)',\n in: 'cubic-bezier(0.55, 0, 1, 0.45)',\n spring: 'cubic-bezier(0.34, 1.56, 0.64, 1)',\n} as const;\n\nexport const typography = {\n fontSans: \"'Satoshi', system-ui, -apple-system, sans-serif\",\n fontMono: \"'JetBrains Mono', 'Fira Code', monospace\",\n} as const;\n"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@weave-design-system/react",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "A human-centered design system for productivity software",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"sideEffects": [
|
|
7
|
+
"**/*.css"
|
|
8
|
+
],
|
|
9
|
+
"main": "./dist/index.cjs",
|
|
10
|
+
"module": "./dist/index.js",
|
|
11
|
+
"types": "./dist/index.d.ts",
|
|
12
|
+
"exports": {
|
|
13
|
+
".": {
|
|
14
|
+
"import": {
|
|
15
|
+
"types": "./dist/index.d.ts",
|
|
16
|
+
"default": "./dist/index.js"
|
|
17
|
+
},
|
|
18
|
+
"require": {
|
|
19
|
+
"types": "./dist/index.d.cts",
|
|
20
|
+
"default": "./dist/index.cjs"
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
"./theme.css": "./dist/theme.css",
|
|
24
|
+
"./tokens": {
|
|
25
|
+
"import": {
|
|
26
|
+
"types": "./dist/tokens.d.ts",
|
|
27
|
+
"default": "./dist/tokens.js"
|
|
28
|
+
},
|
|
29
|
+
"require": {
|
|
30
|
+
"types": "./dist/tokens.d.cts",
|
|
31
|
+
"default": "./dist/tokens.cjs"
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
"files": [
|
|
36
|
+
"dist",
|
|
37
|
+
"src"
|
|
38
|
+
],
|
|
39
|
+
"scripts": {
|
|
40
|
+
"dev": "storybook dev -p 6006",
|
|
41
|
+
"build": "pnpm build:js && pnpm build:css",
|
|
42
|
+
"build:js": "tsup",
|
|
43
|
+
"build:css": "npx @tailwindcss/cli -i src/tokens/weave-theme.css -o dist/theme.css --minify",
|
|
44
|
+
"build-storybook": "storybook build",
|
|
45
|
+
"test": "vitest run",
|
|
46
|
+
"test:watch": "vitest",
|
|
47
|
+
"lint": "eslint src/",
|
|
48
|
+
"typecheck": "tsc --noEmit",
|
|
49
|
+
"prepublishOnly": "pnpm build && pnpm test && pnpm typecheck"
|
|
50
|
+
},
|
|
51
|
+
"peerDependencies": {
|
|
52
|
+
"react": "^18.0.0 || ^19.0.0",
|
|
53
|
+
"react-dom": "^18.0.0 || ^19.0.0"
|
|
54
|
+
},
|
|
55
|
+
"dependencies": {
|
|
56
|
+
"@dnd-kit/core": "^6.3.1",
|
|
57
|
+
"@dnd-kit/sortable": "^10.0.0",
|
|
58
|
+
"@dnd-kit/utilities": "^3.2.2",
|
|
59
|
+
"clsx": "^2.1.0",
|
|
60
|
+
"lucide-react": "^0.470.0",
|
|
61
|
+
"tailwind-merge": "^3.0.0"
|
|
62
|
+
},
|
|
63
|
+
"devDependencies": {
|
|
64
|
+
"@floating-ui/react": "^0.27.0",
|
|
65
|
+
"@storybook/addon-a11y": "^8.6.0",
|
|
66
|
+
"@storybook/addon-docs": "^8.6.0",
|
|
67
|
+
"@storybook/addon-viewport": "^8.6.0",
|
|
68
|
+
"@storybook/react": "^8.6.0",
|
|
69
|
+
"@storybook/react-vite": "^8.6.0",
|
|
70
|
+
"@tailwindcss/cli": "^4.0.0",
|
|
71
|
+
"@tailwindcss/oxide-darwin-arm64": "^4.2.1",
|
|
72
|
+
"@tailwindcss/vite": "^4.0.0",
|
|
73
|
+
"@testing-library/jest-dom": "^6.0.0",
|
|
74
|
+
"@testing-library/react": "^16.0.0",
|
|
75
|
+
"@testing-library/user-event": "^14.0.0",
|
|
76
|
+
"@types/react": "^18.0.0",
|
|
77
|
+
"@types/react-dom": "^18.0.0",
|
|
78
|
+
"jsdom": "^25.0.0",
|
|
79
|
+
"react": "^18.3.0",
|
|
80
|
+
"react-dom": "^18.3.0",
|
|
81
|
+
"storybook": "^8.6.0",
|
|
82
|
+
"tailwindcss": "^4.0.0",
|
|
83
|
+
"tsup": "^8.0.0",
|
|
84
|
+
"typescript": "^5.7.0",
|
|
85
|
+
"vite": "^6.0.0",
|
|
86
|
+
"vitest": "^3.0.0"
|
|
87
|
+
},
|
|
88
|
+
"keywords": [
|
|
89
|
+
"design-system",
|
|
90
|
+
"react",
|
|
91
|
+
"components",
|
|
92
|
+
"tailwindcss",
|
|
93
|
+
"weave"
|
|
94
|
+
],
|
|
95
|
+
"license": "MIT",
|
|
96
|
+
"packageManager": "pnpm@10.32.1",
|
|
97
|
+
"pnpm": {
|
|
98
|
+
"onlyBuiltDependencies": [
|
|
99
|
+
"esbuild",
|
|
100
|
+
"@parcel/watcher"
|
|
101
|
+
]
|
|
102
|
+
}
|
|
103
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/react';
|
|
2
|
+
import { ActivityFeed } from './ActivityFeed';
|
|
3
|
+
|
|
4
|
+
const meta: Meta<typeof ActivityFeed> = { title: 'Data Display/ActivityFeed', component: ActivityFeed, tags: ['autodocs'] };
|
|
5
|
+
export default meta;
|
|
6
|
+
type Story = StoryObj<typeof ActivityFeed>;
|
|
7
|
+
|
|
8
|
+
export const Default: Story = {
|
|
9
|
+
args: {
|
|
10
|
+
items: [
|
|
11
|
+
{ id: '1', name: 'Alice', action: 'completed the design review', timestamp: '2 min ago' },
|
|
12
|
+
{ id: '2', name: 'Bob', action: 'commented on the homepage task', timestamp: '15 min ago' },
|
|
13
|
+
{ id: '3', name: 'Charlie', action: 'moved "API integration" to Done', timestamp: '1 hour ago' },
|
|
14
|
+
],
|
|
15
|
+
},
|
|
16
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { render, screen } from '@testing-library/react';
|
|
2
|
+
import { describe, it, expect } from 'vitest';
|
|
3
|
+
import { ActivityFeed } from './ActivityFeed';
|
|
4
|
+
|
|
5
|
+
describe('ActivityFeed', () => {
|
|
6
|
+
it('renders items with name and action', () => {
|
|
7
|
+
render(<ActivityFeed items={[{ id: '1', name: 'Alice', action: 'completed task', timestamp: '1h ago' }]} />);
|
|
8
|
+
expect(screen.getByText('Alice')).toBeInTheDocument();
|
|
9
|
+
expect(screen.getByText('completed task')).toBeInTheDocument();
|
|
10
|
+
});
|
|
11
|
+
});
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { cn } from '../../utils/cn';
|
|
2
|
+
import { Avatar } from '../../primitives/avatar';
|
|
3
|
+
|
|
4
|
+
export interface ActivityItem {
|
|
5
|
+
id: string;
|
|
6
|
+
name: string;
|
|
7
|
+
avatarSrc?: string;
|
|
8
|
+
action: string;
|
|
9
|
+
timestamp: string;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export interface ActivityFeedProps {
|
|
13
|
+
items: ActivityItem[];
|
|
14
|
+
className?: string;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export function ActivityFeed({ items, className }: ActivityFeedProps) {
|
|
18
|
+
return (
|
|
19
|
+
<div className={cn('flex flex-col', className)}>
|
|
20
|
+
{items.map((item) => (
|
|
21
|
+
<div key={item.id} className="flex items-start gap-3 py-3 border-b border-border last:border-0">
|
|
22
|
+
<Avatar name={item.name} src={item.avatarSrc} size="sm" />
|
|
23
|
+
<div className="flex-1 min-w-0">
|
|
24
|
+
<p style={{ fontSize: 'var(--text-body-sm)', lineHeight: 'var(--leading-body-sm)' }}>
|
|
25
|
+
<span className="text-text-primary font-medium">{item.name}</span>{' '}
|
|
26
|
+
<span className="text-text-secondary">{item.action}</span>
|
|
27
|
+
</p>
|
|
28
|
+
<p className="text-text-secondary mt-0.5" style={{ fontSize: 'var(--text-caption)' }}>{item.timestamp}</p>
|
|
29
|
+
</div>
|
|
30
|
+
</div>
|
|
31
|
+
))}
|
|
32
|
+
</div>
|
|
33
|
+
);
|
|
34
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/react';
|
|
2
|
+
import { CircularProgress } from './CircularProgress';
|
|
3
|
+
|
|
4
|
+
const meta: Meta<typeof CircularProgress> = { title: 'Data Display/CircularProgress', component: CircularProgress, tags: ['autodocs'] };
|
|
5
|
+
export default meta;
|
|
6
|
+
type Story = StoryObj<typeof CircularProgress>;
|
|
7
|
+
|
|
8
|
+
export const Default: Story = { args: { value: 72 } };
|
|
9
|
+
export const Full: Story = { args: { value: 100 } };
|
|
10
|
+
export const Small: Story = { args: { value: 45, size: 48, strokeWidth: 4 } };
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { render, screen } from '@testing-library/react';
|
|
2
|
+
import { describe, it, expect } from 'vitest';
|
|
3
|
+
import { CircularProgress } from './CircularProgress';
|
|
4
|
+
|
|
5
|
+
describe('CircularProgress', () => {
|
|
6
|
+
it('renders with percentage', () => {
|
|
7
|
+
render(<CircularProgress value={75} />);
|
|
8
|
+
expect(screen.getByRole('progressbar')).toBeInTheDocument();
|
|
9
|
+
expect(screen.getByText('75%')).toBeInTheDocument();
|
|
10
|
+
});
|
|
11
|
+
});
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { cn } from '../../utils/cn';
|
|
2
|
+
|
|
3
|
+
export interface CircularProgressProps {
|
|
4
|
+
value: number;
|
|
5
|
+
max?: number;
|
|
6
|
+
size?: number;
|
|
7
|
+
strokeWidth?: number;
|
|
8
|
+
className?: string;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export function CircularProgress({ value, max = 100, size = 80, strokeWidth = 6, className }: CircularProgressProps) {
|
|
12
|
+
const percent = Math.min(100, Math.max(0, (value / max) * 100));
|
|
13
|
+
const radius = (size - strokeWidth) / 2;
|
|
14
|
+
const circumference = 2 * Math.PI * radius;
|
|
15
|
+
const offset = circumference - (percent / 100) * circumference;
|
|
16
|
+
|
|
17
|
+
return (
|
|
18
|
+
<div className={cn('relative inline-flex items-center justify-center', className)} style={{ width: size, height: size }} role="progressbar" aria-valuenow={value} aria-valuemin={0} aria-valuemax={max}>
|
|
19
|
+
<svg width={size} height={size} className="-rotate-90">
|
|
20
|
+
<circle cx={size / 2} cy={size / 2} r={radius} fill="none" stroke="var(--color-border)" strokeWidth={strokeWidth} />
|
|
21
|
+
<circle
|
|
22
|
+
cx={size / 2} cy={size / 2} r={radius} fill="none" stroke="var(--color-rust)" strokeWidth={strokeWidth}
|
|
23
|
+
strokeDasharray={circumference} strokeDashoffset={offset} strokeLinecap="round"
|
|
24
|
+
className="transition-all" style={{ transitionDuration: 'var(--duration-normal)' }}
|
|
25
|
+
/>
|
|
26
|
+
</svg>
|
|
27
|
+
<span
|
|
28
|
+
className="absolute font-bold text-text-primary tabular-nums"
|
|
29
|
+
style={{ fontSize: 'var(--text-body-sm)' }}
|
|
30
|
+
>
|
|
31
|
+
{Math.round(percent)}%
|
|
32
|
+
</span>
|
|
33
|
+
</div>
|
|
34
|
+
);
|
|
35
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/react';
|
|
2
|
+
import { FileText, Inbox } from 'lucide-react';
|
|
3
|
+
import { EmptyState } from './EmptyState';
|
|
4
|
+
|
|
5
|
+
const meta: Meta<typeof EmptyState> = { title: 'Data Display/EmptyState', component: EmptyState, tags: ['autodocs'] };
|
|
6
|
+
export default meta;
|
|
7
|
+
type Story = StoryObj<typeof EmptyState>;
|
|
8
|
+
|
|
9
|
+
export const WithAction: Story = {
|
|
10
|
+
args: { icon: <FileText size={28} />, title: 'No tasks yet', description: 'Ready to start something? Create your first task.', actionLabel: 'Create Task', onAction: () => {} },
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export const NoAction: Story = {
|
|
14
|
+
args: { icon: <Inbox size={28} />, title: 'Inbox zero', description: "You're all caught up. Nice work!" },
|
|
15
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { render, screen } from '@testing-library/react';
|
|
2
|
+
import userEvent from '@testing-library/user-event';
|
|
3
|
+
import { describe, it, expect, vi } from 'vitest';
|
|
4
|
+
import { EmptyState } from './EmptyState';
|
|
5
|
+
|
|
6
|
+
describe('EmptyState', () => {
|
|
7
|
+
it('renders title and description', () => {
|
|
8
|
+
render(<EmptyState icon={<span>IC</span>} title="No items" description="Create one" />);
|
|
9
|
+
expect(screen.getByText('No items')).toBeInTheDocument();
|
|
10
|
+
expect(screen.getByText('Create one')).toBeInTheDocument();
|
|
11
|
+
});
|
|
12
|
+
it('calls action on click', async () => {
|
|
13
|
+
const onAction = vi.fn();
|
|
14
|
+
render(<EmptyState icon={<span>IC</span>} title="Empty" actionLabel="Add" onAction={onAction} />);
|
|
15
|
+
await userEvent.click(screen.getByRole('button', { name: 'Add' }));
|
|
16
|
+
expect(onAction).toHaveBeenCalledOnce();
|
|
17
|
+
});
|
|
18
|
+
});
|