mirror of
https://github.com/supabase/supabase.git
synced 2026-06-20 19:16:04 +08:00
* 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 commit1b0a985fcb. * 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 commit86c3973ffa. * Revert "try new sentry wrapper for api" This reverts commitf67623ebad. * Revert "upgrade to next 14" This reverts commita24dd6131e. * 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>
56 lines
1.4 KiB
TypeScript
56 lines
1.4 KiB
TypeScript
type Props = {
|
|
type?: 'primary' | 'secondary'
|
|
text: string
|
|
url?: string
|
|
className?: string
|
|
hideArrow?: boolean
|
|
}
|
|
|
|
const Button = (props: Props) => {
|
|
const { type = 'primary', text, url, className, hideArrow = false } = props
|
|
|
|
const colorClass =
|
|
type === 'primary'
|
|
? 'px-3 py-2 shadow-sm border border-transparent text-white bg-brand-400 hover:bg-brand-300 focus:ring-2 focus:ring-offset-2 focus:ring-brand-300'
|
|
: 'text-brand-400 bg-none'
|
|
|
|
const textClass = type === 'primary' ? 'font-medium left-3 group-hover:left-0' : 'font-normal'
|
|
|
|
const arrowClass = type === 'primary' ? '' : 'relative -left-1 group-hover:left-0'
|
|
|
|
let buttonStyles = {
|
|
textShadow: 'none',
|
|
}
|
|
if (type === 'primary') {
|
|
buttonStyles.textShadow = '0px 0px 6px rgba(13, 128, 86, 0.8)'
|
|
}
|
|
|
|
const renderButton = () => (
|
|
<button
|
|
type="button"
|
|
className={`
|
|
group inline-flex items-center rounded-md text-sm
|
|
leading-4 transition focus:outline-none ${colorClass} ${className}
|
|
`}
|
|
style={buttonStyles}
|
|
>
|
|
<span
|
|
className={`
|
|
relative transition-all ${url ? textClass : ''}
|
|
`}
|
|
>
|
|
{text}
|
|
</span>
|
|
{url && (
|
|
<span className={`ml-2 opacity-0 transition-all group-hover:opacity-100 ${arrowClass}`}>
|
|
→
|
|
</span>
|
|
)}
|
|
</button>
|
|
)
|
|
|
|
return url ? <a href={url}>{renderButton()}</a> : renderButton()
|
|
}
|
|
|
|
export default Button
|