* update deps + image codemod (studio) * update next links (studio) * update deps * update links (ui) * remove next-transpile-modules * move next-themes dependency * chore: update ConfirmDialog * chore: remove old ConfirmModal js file. migrated to TS * dependency wrangling * remove empty page * update next links (www) * First run bump react-data-grid-v7 beta 4 * fix package-lock.json * more deps wrangling * update recharts * update sentry options * fix some broken things in www * studio fixes * fix graphiql * fix studio build * fix menu hydration * small build error * update turbo * fix www typescript errors * docs image codemod * links codemod docs * fix docs typescript errors * move useConsent to ui to prevent circular deps * Fix links * Fix homepage * Fix links * move studio/ to apps/ * Revert "move studio/ to apps/" This reverts commit 1b0a985fcb7569f29c8a6dd05b9c3063152547b9. * disable outputFileTracingRoot * remove outputFileTracingRoot * fix homepage product cards * fix PrivacySettings links * Fix links * Fix the build for www. * Minor fixes for JWTGenerator. * Fix the docs and ui tests. * Revert codehike back to 0.8.3 * remove ConfirmAlert() * reenable babel because mobx hates me * fix blog image and comparison page avatar * Fix svg errors * update image synthax * Fix code hike * Move the button in a div so that it doesn't inherit its parent height and make the button look weird. * When components are defined in a component, they get recreated on each render. This makes them unstable in certain cases and causes infinite rerenders. * Replace the next/head usage with next/script. * Chore/upgrade next 13 fix table editor (#18431) * fix table editor styling and fix row deletion logic * Fix deleting selected rows from header, and fix checkboxes not clearing up * Fix deleting all rows when filter applied, and fix deleting all rows * Fix grid size styling issue * Fix TS error * Hydration errors * studio org pages fixes * fix more studio links * audit logs fixes * dropdown icon styling fixes * fix some images in www * upgrade to next 14 * try new sentry wrapper for api * see if this is even invoked * Revert "see if this is even invoked" This reverts commit 86c3973ffa7f8ef5e1eb6d95a5809156cebf217b. * Revert "try new sentry wrapper for api" This reverts commit f67623ebad0f241d7e9fe275d50f7707bf64c474. * Revert "upgrade to next 14" This reverts commit a24dd6131eaff475a90ef991c2f832a64e4aaa2b. * chore: allow node version 19/20 * Try to fix the LogTable so that it renders with the newer "react-data-grid" version. * Fix type errors in the log renderer code. * Fix the replication screen. * Add the CSS for the GraphiQL. * Fix SQL editor results rendering * Lint * Fix SQL editor results height issue * Fix auth RLS not invalidating RQ when toggling RLS * Fix database tables new/edit column regressed * Fix migrations page empty state if migrations schema not yet created * Fix API side panel docs temp remove postgrest text for column description PK and FK * Fix + improve timeout handling in SQL editor --------- Co-authored-by: Jonathan Summers-Muir <MildTomato@users.noreply.github.com> Co-authored-by: Joshen Lim <joshenlimek@gmail.com> Co-authored-by: Francesco Sansalvadore <f.sansalvadore@gmail.com> Co-authored-by: Terry Sutton <saltcod@gmail.com> Co-authored-by: Ivan Vasilov <vasilov.ivan@gmail.com> Co-authored-by: Kevin Grüneberg <k.grueneberg1994@gmail.com>
84 lines
2.3 KiB
TypeScript
84 lines
2.3 KiB
TypeScript
import { FC, PropsWithChildren, useState } from 'react'
|
|
import { IconXCircle } from '~/../../packages/ui'
|
|
|
|
interface IOptions {
|
|
name?: string
|
|
}
|
|
|
|
type IOption = any
|
|
|
|
type OptionsSubComponents = {
|
|
Option: IOption
|
|
}
|
|
|
|
const Options: FC<PropsWithChildren<IOptions>> & OptionsSubComponents = (props) => {
|
|
const [open, setOpen] = useState(false)
|
|
return (
|
|
<div className="mt-0">
|
|
<button
|
|
className={[
|
|
'px-5',
|
|
'border-t border-l border-r border-scale-500',
|
|
'text-left text-sm text-scale-1100',
|
|
'hover:bg-scale-300 transition-all',
|
|
|
|
'flex items-center gap-2',
|
|
open ? 'w-full py-1.5 rounded-tl-lg rounded-tr-lg' : 'py-1 border-b rounded-full',
|
|
].join(' ')}
|
|
onClick={() => setOpen(!open)}
|
|
>
|
|
<div className="">
|
|
<div className={[!open ? 'rotate-45' : 'rotate-0'].join(' ')}>
|
|
<IconXCircle size={14} />
|
|
</div>
|
|
</div>
|
|
{`${!open ? `Open` : `Close`} ${props.name ?? 'accepted values'}`}
|
|
</button>
|
|
<div
|
|
className={['transition-all opacity-0', open ? 'opacity-100 h-auto' : 'invisible h-0'].join(
|
|
' '
|
|
)}
|
|
>
|
|
{props.children}
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
const Option: FC<IOption> = (props) => {
|
|
return (
|
|
<div
|
|
className="
|
|
px-5 py-3 first:border-t border-b border-l border-r
|
|
border-scale-500
|
|
last:rounded-bl-lg last:rounded-br-lg
|
|
flex flex-col gap-3
|
|
"
|
|
>
|
|
<div className="flex gap-3 items-center">
|
|
<span className="text-sm text-scale-1200 font-mono font-medium">
|
|
{props.name ?? 'no-name'}
|
|
</span>
|
|
<span>
|
|
{props.isOptional ? (
|
|
<div className="text-[10px] px-3 tracking-wide font-mono text-scale-900">Optional</div>
|
|
) : (
|
|
<div className="text-[10px] border border-amber-700 bg-amber-300 text-amber-900 px-2 tracking-wide font-mono py-0.25 rounded-full">
|
|
REQUIRED
|
|
</div>
|
|
)}
|
|
</span>
|
|
<span className="text-scale-900 text-xs">{props.type ?? 'no type'}</span>
|
|
</div>
|
|
|
|
{props.description && <p className="text-sm text-scale-1000 m-0">{props.description}</p>}
|
|
|
|
{props.children}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
Options.Option = Option
|
|
|
|
export default Options
|