mirror of
https://github.com/supabase/supabase.git
synced 2026-05-23 01:39:34 +08:00
* migrate some www components to tokens * consolidate InteractiveShimmerCard to Panel component * update tokens in blog * update tokens in careers page * update tokens in customers section * update tokens in open-source section * update tokens in Realtime page * update tokens in Storage and Vector * update tokens in SplitCodeBlockCarousel * update tokens in PGCharts * remove unused css files * update tokens in Card * update tokens in Pricing page * clean up priving page imports * remove hardcoded theme vars * migrate first half of defaultTheme.ts to tokens * migrate second half of defaultTheme.ts to tokens * improve inputs * add foreground to text-light and text-lighter * add foreground to text-light and text-lighter * migrate docs components with styling tokens * migrate docs components with styling tokens * fix broken Repos component * fix broken classes in blog * update tokens on Button and other components * update tokens on IconPanel * update studio main layout base styling tokens * update tokens across studio, docs and www * update tokens across studio, docs and www * update ui/Panel to styling tokens * update ExampleProject and TableEditorMenu tokens * www vector page tokens * update studio UI tokens * update other studio UI tokens * update more studio UI tokens * change tokens here, change tokens there * finish updating colors with tokens variables * add gui sandbox for theme experimentation * use common package for www, docs and studio and fix Command K tokens * provide light mode default tokens options * fix conflict leftover * update loading line * fix className typo * fix prettier * update themeSandbox preset default values * fix text-background0 * prettier * update warningBanner with warning color * switch all border-border with border-default * improve border-secondary and foreground-muted in light mode * force ring color on toggle * fix button bg color and border-muted light token * fix input bg color * fix dark button hover * fix homepage product card * fix code-hike table header colors * button dark border * remove tabIndex leftover from homepage main ctas --------- Co-authored-by: Kevin Grüneberg <k.grueneberg1994@gmail.com> Co-authored-by: Jonathan Summers-Muir <MildTomato@users.noreply.github.com>
43 lines
1.4 KiB
TypeScript
43 lines
1.4 KiB
TypeScript
import * as Accordion from '@radix-ui/react-accordion'
|
|
import React from 'react'
|
|
import { IconChevronRight } from '~/../../packages/ui'
|
|
|
|
const RefDetailCollapse: React.FC<
|
|
React.PropsWithChildren<{ id: string; label: string; defaultOpen?: boolean }>
|
|
> = ({ defaultOpen = true, ...props }) => {
|
|
return (
|
|
<Accordion.Root
|
|
className="AccordionRoot"
|
|
type="single"
|
|
defaultValue={defaultOpen ? `${props.id}` : ''}
|
|
collapsible
|
|
>
|
|
<Accordion.Item className="AccordionItem" value={`${props.id}`}>
|
|
<Accordion.Trigger asChild>
|
|
<button
|
|
className={[
|
|
'transition-all ease-out',
|
|
'h-8',
|
|
'bg-surface-100 data-open:bg-surface-200',
|
|
'border w-full flex items-center gap-3 px-5',
|
|
'rounded-tl rounded-tr',
|
|
'data-closed:rounded-bl data-closed:rounded-br',
|
|
'text-foreground-light text-xs',
|
|
].join(' ')}
|
|
>
|
|
<div className="data-open-parent:rotate-90 text-foreground-lighter">
|
|
<IconChevronRight size={12} strokeWidth={2} />
|
|
</div>
|
|
{props.label}
|
|
</button>
|
|
</Accordion.Trigger>
|
|
<Accordion.Content className="transition data-open:animate-slide-down data-closed:animate-slide-up">
|
|
{props.children}
|
|
</Accordion.Content>
|
|
</Accordion.Item>
|
|
</Accordion.Root>
|
|
)
|
|
}
|
|
|
|
export default RefDetailCollapse
|