mango-ui-v3/components/TableElements.tsx

107 lines
2.7 KiB
TypeScript
Raw Normal View History

import { Disclosure } from '@headlessui/react'
2022-02-10 17:50:40 -08:00
import { ChevronDownIcon } from '@heroicons/react/solid'
2022-02-14 10:33:09 -08:00
import { ReactNode } from 'react'
2021-09-03 05:11:21 -07:00
export const Table = ({ children }) => (
2022-02-10 15:48:14 -08:00
<table className="min-w-full">{children}</table>
2021-09-03 05:11:21 -07:00
)
export const TrHead = ({ children }) => (
<tr className="text-th-fgd-3 text-xs">{children}</tr>
)
export const Th = ({ children }) => (
<th className="px-4 pb-2 text-left font-normal" scope="col">
2021-09-03 05:11:21 -07:00
{children}
</th>
)
2022-02-10 15:48:14 -08:00
export const TrBody = ({ children }) => (
<tr className="border-b border-th-bkg-4">{children}</tr>
2021-09-03 05:11:21 -07:00
)
export const Td = ({
children,
className,
}: {
children: ReactNode
className?: string
}) => (
<td className={`px-4 h-16 text-sm text-th-fgd-2 ${className}`}>{children}</td>
2021-09-03 05:11:21 -07:00
)
type ExpandableRowProps = {
buttonTemplate: React.ReactNode
index: number
panelTemplate: React.ReactNode
rounded?: boolean
}
export const ExpandableRow = ({
buttonTemplate,
index,
panelTemplate,
rounded,
}: ExpandableRowProps) => {
return (
<Disclosure>
{({ open }) => (
<>
<Disclosure.Button
className={`${
index % 2 === 0 ? `bg-th-bkg-3` : `bg-th-bkg-4`
} default-transition flex items-center justify-between font-normal p-4 text-th-fgd-1 w-full hover:filter hover:brightness-90 focus:outline-none ${
rounded
? open
? 'rounded-b-none'
: 'rounded-md'
: 'rounded-none'
}`}
>
{buttonTemplate}
<div className="flex items-center justify-end pl-5">
<ChevronDownIcon
className={`${
open ? 'transform rotate-180' : 'transform rotate-360'
} default-transition h-5 flex-shrink-0 w-5 text-th-primary`}
/>
</div>
</Disclosure.Button>
<Disclosure.Panel
className={`${
index % 2 === 0
? `bg-[rgba(255,255,255,0.03)]`
: `bg-[rgba(255,255,255,0.07)]`
} px-4 ${
rounded
? open
? 'rounded-b-md'
: 'rounded-none'
: 'rounded-none'
}`}
>
<div className="py-4">{panelTemplate}</div>
</Disclosure.Panel>
</>
)}
</Disclosure>
)
}
type RowProps = {
children: React.ReactNode
index: number
}
export const Row = ({ children, index }: RowProps) => {
return (
<div
className={`${
index % 2 === 0 ? `bg-th-bkg-3` : `bg-th-bkg-4`
} default-transition font-normal p-4 rounded-none text-th-fgd-1 w-full`}
>
{children}
</div>
)
}