forked from cerc-io/snowballtools-base
style: projects and settings
This commit is contained in:
parent
07b21a835e
commit
3214cfc1d4
@ -1,5 +1,5 @@
|
|||||||
<!doctype html>
|
<!doctype html>
|
||||||
<html lang="en" class="dark dark:bg-background">
|
<html lang="en" class="dark dark:bg-background dark:text-foreground">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8" />
|
<meta charset="utf-8" />
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
||||||
@ -10,6 +10,12 @@
|
|||||||
<meta name="theme-color" content="#ffffff" />
|
<meta name="theme-color" content="#ffffff" />
|
||||||
<link rel="manifest" href="/manifest.json" />
|
<link rel="manifest" href="/manifest.json" />
|
||||||
<title>Laconic</title>
|
<title>Laconic</title>
|
||||||
|
<link rel="preconnect" href="https://fonts.googleapis.com" />
|
||||||
|
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin />
|
||||||
|
<link
|
||||||
|
href="https://fonts.googleapis.com/css2?family=DM+Mono:ital,wght@0,300;0,400;0,500;1,300;1,400;1,500&display=swap"
|
||||||
|
rel="stylesheet"
|
||||||
|
/>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="root"></div>
|
<div id="root"></div>
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { Link } from 'react-router-dom';
|
import { Link } from 'react-router-dom';
|
||||||
import { Heading } from './shared/Heading';
|
|
||||||
|
|
||||||
interface LogoProps {
|
interface LogoProps {
|
||||||
orgSlug?: string;
|
orgSlug?: string;
|
||||||
|
@ -24,8 +24,8 @@ const Stepper = ({ activeStep, stepperValues }: StepperProps) => {
|
|||||||
<div
|
<div
|
||||||
className={`text-sm ${
|
className={`text-sm ${
|
||||||
activeStep === stepperValue.step
|
activeStep === stepperValue.step
|
||||||
? 'text-black font-semibold'
|
? 'text-black font-semibold dark:text-foreground'
|
||||||
: 'text-gray-600'
|
: 'text-gray-600 dark:text-foreground-secondary'
|
||||||
}`}
|
}`}
|
||||||
>
|
>
|
||||||
{stepperValue.label}
|
{stepperValue.label}
|
||||||
|
@ -4,7 +4,9 @@ export const projectCardTheme = tv({
|
|||||||
slots: {
|
slots: {
|
||||||
wrapper: [
|
wrapper: [
|
||||||
'bg-surface-card',
|
'bg-surface-card',
|
||||||
|
'dark:bg-overlay2',
|
||||||
'shadow-card',
|
'shadow-card',
|
||||||
|
'dark:shadow-background',
|
||||||
'rounded-2xl',
|
'rounded-2xl',
|
||||||
'flex',
|
'flex',
|
||||||
'flex-col',
|
'flex-col',
|
||||||
@ -17,10 +19,16 @@ export const projectCardTheme = tv({
|
|||||||
'text-sm',
|
'text-sm',
|
||||||
'font-medium',
|
'font-medium',
|
||||||
'text-elements-high-em',
|
'text-elements-high-em',
|
||||||
|
'dark:text-foreground',
|
||||||
'tracking-[-0.006em]',
|
'tracking-[-0.006em]',
|
||||||
'truncate',
|
'truncate',
|
||||||
],
|
],
|
||||||
description: ['text-xs', 'text-elements-low-em', 'truncate'],
|
description: [
|
||||||
|
'text-xs',
|
||||||
|
'text-elements-low-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
|
'truncate',
|
||||||
|
],
|
||||||
icons: ['flex', 'items-center', 'gap-1'],
|
icons: ['flex', 'items-center', 'gap-1'],
|
||||||
lowerContent: [
|
lowerContent: [
|
||||||
'transition-colors',
|
'transition-colors',
|
||||||
@ -32,6 +40,7 @@ export const projectCardTheme = tv({
|
|||||||
'gap-2',
|
'gap-2',
|
||||||
'rounded-b-2xl',
|
'rounded-b-2xl',
|
||||||
'group-hover:bg-surface-card-hovered',
|
'group-hover:bg-surface-card-hovered',
|
||||||
|
'dark:group-hover:bg-overlay3',
|
||||||
],
|
],
|
||||||
latestDeployment: ['flex', 'items-center', 'gap-2'],
|
latestDeployment: ['flex', 'items-center', 'gap-2'],
|
||||||
deploymentStatusContainer: [
|
deploymentStatusContainer: [
|
||||||
@ -42,10 +51,15 @@ export const projectCardTheme = tv({
|
|||||||
'justify-center',
|
'justify-center',
|
||||||
],
|
],
|
||||||
deploymentStatus: ['w-1', 'h-1', 'rounded-full'],
|
deploymentStatus: ['w-1', 'h-1', 'rounded-full'],
|
||||||
deploymentName: ['text-xs', 'text-elements-low-em'],
|
deploymentName: [
|
||||||
|
'text-xs',
|
||||||
|
'text-elements-low-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
|
],
|
||||||
deploymentText: [
|
deploymentText: [
|
||||||
'text-xs',
|
'text-xs',
|
||||||
'text-elements-low-em',
|
'text-elements-low-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
'font-mono',
|
'font-mono',
|
||||||
'flex',
|
'flex',
|
||||||
'items-center',
|
'items-center',
|
||||||
@ -53,9 +67,11 @@ export const projectCardTheme = tv({
|
|||||||
],
|
],
|
||||||
wavyBorder: [
|
wavyBorder: [
|
||||||
'bg-surface-card',
|
'bg-surface-card',
|
||||||
|
'dark:bg-background',
|
||||||
'transition-colors',
|
'transition-colors',
|
||||||
'duration-150',
|
'duration-150',
|
||||||
'group-hover:bg-surface-card-hovered',
|
'group-hover:bg-surface-card-hovered',
|
||||||
|
'dark:group-hover:bg-overlay2',
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
variants: {
|
variants: {
|
||||||
@ -67,7 +83,7 @@ export const projectCardTheme = tv({
|
|||||||
deploymentStatus: ['bg-orange-400'],
|
deploymentStatus: ['bg-orange-400'],
|
||||||
},
|
},
|
||||||
failure: {
|
failure: {
|
||||||
deploymentStatus: ['bg-rose-500'],
|
deploymentStatus: ['bg-error'],
|
||||||
},
|
},
|
||||||
pending: {
|
pending: {
|
||||||
deploymentStatus: ['bg-gray-500'],
|
deploymentStatus: ['bg-gray-500'],
|
||||||
|
@ -88,7 +88,7 @@ export const ProjectCard = ({
|
|||||||
</div>
|
</div>
|
||||||
{/* Icons */}
|
{/* Icons */}
|
||||||
<div className={theme.icons()}>
|
<div className={theme.icons()}>
|
||||||
{hasError && <WarningDiamondIcon className="text-elements-danger" />}
|
{hasError && <WarningDiamondIcon className="text-error" />}
|
||||||
<Menu placement="bottom-end">
|
<Menu placement="bottom-end">
|
||||||
<MenuHandler>
|
<MenuHandler>
|
||||||
<Button
|
<Button
|
||||||
@ -101,12 +101,15 @@ export const ProjectCard = ({
|
|||||||
<HorizontalDotIcon />
|
<HorizontalDotIcon />
|
||||||
</Button>
|
</Button>
|
||||||
</MenuHandler>
|
</MenuHandler>
|
||||||
<MenuList>
|
<MenuList className="dark:bg-overlay3 dark:shadow-background dark:border-none">
|
||||||
<MenuItem onClick={navigateToSettingsOnClick}>
|
<MenuItem
|
||||||
|
onClick={navigateToSettingsOnClick}
|
||||||
|
className="text-foreground"
|
||||||
|
>
|
||||||
Project settings
|
Project settings
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem
|
<MenuItem
|
||||||
className="text-red-500"
|
className="text-error"
|
||||||
onClick={navigateToSettingsOnClick}
|
onClick={navigateToSettingsOnClick}
|
||||||
>
|
>
|
||||||
Delete project
|
Delete project
|
||||||
|
@ -16,7 +16,7 @@ export const Activity = ({
|
|||||||
<div className="flex items-center justify-between">
|
<div className="flex items-center justify-between">
|
||||||
<Heading className="text-lg leading-6 font-medium">Activity</Heading>
|
<Heading className="text-lg leading-6 font-medium">Activity</Heading>
|
||||||
<Button variant="tertiary" size="sm">
|
<Button variant="tertiary" size="sm">
|
||||||
See all
|
SEE ALL
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
<div className="mt-5">
|
<div className="mt-5">
|
||||||
|
@ -18,7 +18,6 @@ import { Button, Heading, Tag } from 'components/shared';
|
|||||||
const WAIT_DURATION = 5000;
|
const WAIT_DURATION = 5000;
|
||||||
|
|
||||||
const DIALOG_STYLE = {
|
const DIALOG_STYLE = {
|
||||||
backgroundColor: 'rgba(0,0,0, .9)',
|
|
||||||
padding: '2em',
|
padding: '2em',
|
||||||
borderRadius: '0.5em',
|
borderRadius: '0.5em',
|
||||||
marginLeft: '0.5em',
|
marginLeft: '0.5em',
|
||||||
@ -86,27 +85,27 @@ export const AuctionCard = ({ project }: { project: Project }) => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<div className="p-3 gap-2 rounded-xl border border-gray-200 transition-colors hover:bg-base-bg-alternate flex flex-col mt-8">
|
<div className="p-3 gap-2 rounded-xl border dark:border-overlay3 border-gray-200 transition-colors hover:bg-base-bg-alternate dark:hover:bg-overlay3 flex flex-col mt-8">
|
||||||
<div className="flex justify-between items-center">
|
<div className="flex justify-between items-center">
|
||||||
<Heading className="text-lg leading-6 font-medium">
|
<Heading className="text-lg leading-6 font-medium">
|
||||||
Auction details
|
Auction details
|
||||||
</Heading>
|
</Heading>
|
||||||
<Button onClick={handleOpenDialog} variant="tertiary" size="sm">
|
<Button onClick={handleOpenDialog} variant="tertiary" size="sm">
|
||||||
View details
|
VIEW DETAILS
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="flex justify-between items-center mt-2">
|
<div className="flex justify-between items-center mt-2">
|
||||||
<span className="text-elements-high-em text-sm font-medium tracking-tight">
|
<span className="text-elements-high-em dark:text-foreground-secondary text-sm font-medium tracking-tight">
|
||||||
Auction Id
|
Auction Id
|
||||||
</span>
|
</span>
|
||||||
<span className="text-elements-mid-em text-sm text-right">
|
<span className="text-elements-mid-em dark:text-foreground text-sm text-right">
|
||||||
{project.auctionId}
|
{project.auctionId}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="flex justify-between items-center mt-1">
|
<div className="flex justify-between items-center mt-1">
|
||||||
<span className="text-elements-high-em text-sm font-medium tracking-tight">
|
<span className="text-elements-high-em dark:text-foreground-secondary text-sm font-medium tracking-tight">
|
||||||
Auction Status
|
Auction Status
|
||||||
</span>
|
</span>
|
||||||
<div className="ml-2">{renderAuctionStatus()}</div>
|
<div className="ml-2">{renderAuctionStatus()}</div>
|
||||||
@ -116,17 +115,20 @@ export const AuctionCard = ({ project }: { project: Project }) => {
|
|||||||
<>
|
<>
|
||||||
{deployers?.length > 0 ? (
|
{deployers?.length > 0 ? (
|
||||||
<div>
|
<div>
|
||||||
<span className="text-elements-high-em text-sm font-medium tracking-tight">
|
<span className="text-elements-high-em dark:text-foreground-secondary text-sm font-medium tracking-tight">
|
||||||
Deployer LRNs
|
Deployer LRNs
|
||||||
</span>
|
</span>
|
||||||
{deployers.map((deployer, index) => (
|
{deployers.map((deployer, index) => (
|
||||||
<p key={index} className="text-elements-mid-em text-sm">
|
<p
|
||||||
|
key={index}
|
||||||
|
className="text-elements-mid-em dark:text-foreground text-sm"
|
||||||
|
>
|
||||||
{'\u2022'} {deployer.deployerLrn}
|
{'\u2022'} {deployer.deployerLrn}
|
||||||
</p>
|
</p>
|
||||||
))}
|
))}
|
||||||
|
|
||||||
<div className="flex justify-between items-center mt-1">
|
<div className="flex justify-between items-center mt-1">
|
||||||
<span className="text-elements-high-em text-sm font-medium tracking-tight">
|
<span className="text-elements-high-em dark:text-foreground-secondary text-sm font-medium tracking-tight">
|
||||||
Deployer Funds Status
|
Deployer Funds Status
|
||||||
</span>
|
</span>
|
||||||
<div className="ml-2">
|
<div className="ml-2">
|
||||||
@ -141,7 +143,7 @@ export const AuctionCard = ({ project }: { project: Project }) => {
|
|||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
<div className="mt-3">
|
<div className="mt-3">
|
||||||
<span className="text-elements-high-em text-sm font-medium tracking-tight">
|
<span className="text-elements-high-em dark:text-foreground-secondary text-sm font-medium tracking-tight">
|
||||||
No winning deployers
|
No winning deployers
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
@ -155,15 +157,24 @@ export const AuctionCard = ({ project }: { project: Project }) => {
|
|||||||
onClose={handleCloseDialog}
|
onClose={handleCloseDialog}
|
||||||
fullWidth
|
fullWidth
|
||||||
maxWidth="md"
|
maxWidth="md"
|
||||||
|
PaperProps={{
|
||||||
|
className: 'dark:bg-overlay2',
|
||||||
|
}}
|
||||||
>
|
>
|
||||||
<DialogTitle>Auction Details</DialogTitle>
|
<DialogTitle className="dark:text-foreground">
|
||||||
|
Auction Details
|
||||||
|
</DialogTitle>
|
||||||
<DialogContent style={DIALOG_STYLE}>
|
<DialogContent style={DIALOG_STYLE}>
|
||||||
{auctionDetails && (
|
{auctionDetails && (
|
||||||
<pre>{JSON.stringify(auctionDetails, null, 2)}</pre>
|
<pre className="dark:text-foreground-secondary">
|
||||||
|
{JSON.stringify(auctionDetails, null, 2)}
|
||||||
|
</pre>
|
||||||
)}
|
)}
|
||||||
</DialogContent>
|
</DialogContent>
|
||||||
<DialogActions>
|
<DialogActions>
|
||||||
<Button onClick={handleCloseDialog}>Close</Button>
|
<Button onClick={handleCloseDialog} shape="default">
|
||||||
|
CLOSE
|
||||||
|
</Button>
|
||||||
</DialogActions>
|
</DialogActions>
|
||||||
</Dialog>
|
</Dialog>
|
||||||
</>
|
</>
|
||||||
|
@ -18,7 +18,7 @@ export const OverviewInfo = ({
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="flex justify-between gap-2 py-3 text-sm items-center">
|
<div className="flex justify-between gap-2 py-3 text-sm items-center">
|
||||||
<div className="flex gap-2 items-center text-elements-high-em">
|
<div className="flex gap-2 items-center text-elements-high-em dark:text-foreground-secondary">
|
||||||
{styledIcon}
|
{styledIcon}
|
||||||
{label}
|
{label}
|
||||||
</div>
|
</div>
|
||||||
|
@ -93,11 +93,11 @@ const AddMemberDialog = ({
|
|||||||
/>
|
/>
|
||||||
</Modal.Body>
|
</Modal.Body>
|
||||||
<Modal.Footer>
|
<Modal.Footer>
|
||||||
<Button onClick={handleOpen} variant="secondary">
|
<Button onClick={handleOpen} variant="danger" shape="default">
|
||||||
Cancel
|
Cancel
|
||||||
</Button>
|
</Button>
|
||||||
<Button type="submit" disabled={!isValid}>
|
<Button type="submit" disabled={!isValid} shape="default">
|
||||||
Send invite
|
SEND INVITE
|
||||||
</Button>
|
</Button>
|
||||||
</Modal.Footer>
|
</Modal.Footer>
|
||||||
</form>
|
</form>
|
||||||
|
@ -24,7 +24,7 @@ const DisplayEnvironmentVariables = ({
|
|||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<div
|
<div
|
||||||
className="flex gap-4 p-2"
|
className="flex gap-4 p-2 dark:text-foreground"
|
||||||
onClick={() => setOpenCollapse((cur) => !cur)}
|
onClick={() => setOpenCollapse((cur) => !cur)}
|
||||||
>
|
>
|
||||||
{openCollapse ? <ChevronUpSmallIcon /> : <ChevronDownSmallIcon />}
|
{openCollapse ? <ChevronUpSmallIcon /> : <ChevronDownSmallIcon />}
|
||||||
@ -33,7 +33,7 @@ const DisplayEnvironmentVariables = ({
|
|||||||
</div>
|
</div>
|
||||||
<Collapse open={openCollapse}>
|
<Collapse open={openCollapse}>
|
||||||
{variables.length === 0 ? (
|
{variables.length === 0 ? (
|
||||||
<div className="bg-slate-100 rounded-xl flex-col p-4">
|
<div className="bg-slate-100 dark:bg-overlay2 dark:text-foreground rounded-xl flex-col p-4">
|
||||||
No environment variables added yet. Once you add them, they'll show
|
No environment variables added yet. Once you add them, they'll show
|
||||||
up here.
|
up here.
|
||||||
</div>
|
</div>
|
||||||
|
@ -80,7 +80,7 @@ const MemberCard = ({
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
className={`flex py-1 items-center ${!isFirstCard && 'mt-1 border-t border-gray-300'}`}
|
className={`flex py-1 items-center ${!isFirstCard && 'mt-1 border-t border-gray-300'} dark:text-foreground`}
|
||||||
>
|
>
|
||||||
<div className="basis-1/2">
|
<div className="basis-1/2">
|
||||||
{member.name && (
|
{member.name && (
|
||||||
|
@ -102,8 +102,8 @@ const SetupDomain = () => {
|
|||||||
)}
|
)}
|
||||||
|
|
||||||
<div className="self-stretch">
|
<div className="self-stretch">
|
||||||
<Button disabled={!isValid} type="submit">
|
<Button disabled={!isValid} type="submit" shape="default">
|
||||||
Next
|
NEXT
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
@ -30,7 +30,12 @@ export const avatarTheme = tv(
|
|||||||
fallback: ['text-elements-warning', 'bg-base-bg-emphasized-warning'],
|
fallback: ['text-elements-warning', 'bg-base-bg-emphasized-warning'],
|
||||||
},
|
},
|
||||||
blue: {
|
blue: {
|
||||||
fallback: ['text-elements-info', 'bg-base-bg-emphasized-info'],
|
fallback: [
|
||||||
|
'text-elements-info',
|
||||||
|
'bg-base-bg-emphasized-info',
|
||||||
|
'dark:text-foreground',
|
||||||
|
'dark:bg-primary',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
size: {
|
size: {
|
||||||
|
@ -16,6 +16,7 @@ export const buttonTheme = tv(
|
|||||||
'disabled:cursor-not-allowed',
|
'disabled:cursor-not-allowed',
|
||||||
'transition-colors',
|
'transition-colors',
|
||||||
'duration-150',
|
'duration-150',
|
||||||
|
'font-mono',
|
||||||
],
|
],
|
||||||
variants: {
|
variants: {
|
||||||
size: {
|
size: {
|
||||||
@ -28,7 +29,7 @@ export const buttonTheme = tv(
|
|||||||
true: 'w-full',
|
true: 'w-full',
|
||||||
},
|
},
|
||||||
shape: {
|
shape: {
|
||||||
default: 'rounded-lg',
|
default: 'rounded',
|
||||||
rounded: 'rounded-full',
|
rounded: 'rounded-full',
|
||||||
},
|
},
|
||||||
iconOnly: {
|
iconOnly: {
|
||||||
@ -95,7 +96,7 @@ export const buttonTheme = tv(
|
|||||||
'text-elements-on-danger',
|
'text-elements-on-danger',
|
||||||
'border',
|
'border',
|
||||||
'border-transparent',
|
'border-transparent',
|
||||||
'bg-border-danger',
|
'bg-error',
|
||||||
'hover:bg-controls-danger-hovered',
|
'hover:bg-controls-danger-hovered',
|
||||||
'focus-visible:bg-controls-danger-hovered',
|
'focus-visible:bg-controls-danger-hovered',
|
||||||
'disabled:text-elements-on-disabled',
|
'disabled:text-elements-on-disabled',
|
||||||
|
@ -40,11 +40,11 @@ abbr[title] {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile {
|
.react-calendar__tile {
|
||||||
@apply h-12 w-12 text-elements-high-em;
|
@apply h-12 w-12 text-elements-high-em dark:text-foreground;
|
||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile:hover {
|
.react-calendar__tile:hover {
|
||||||
@apply bg-base-bg-emphasized rounded-lg;
|
@apply bg-base-bg-emphasized dark:bg-overlay3 rounded-lg;
|
||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile:focus-visible {
|
.react-calendar__tile:focus-visible {
|
||||||
@ -52,7 +52,7 @@ abbr[title] {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile--now {
|
.react-calendar__tile--now {
|
||||||
@apply bg-base-bg-emphasized text-elements-high-em rounded-lg;
|
@apply bg-base-bg-emphasized dark:bg-overlay3 text-elements-high-em rounded-lg;
|
||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile--now:hover {
|
.react-calendar__tile--now:hover {
|
||||||
@ -77,7 +77,7 @@ abbr[title] {
|
|||||||
|
|
||||||
/* Range -- START */
|
/* Range -- START */
|
||||||
.react-calendar__tile--range {
|
.react-calendar__tile--range {
|
||||||
@apply bg-controls-secondary text-elements-on-secondary rounded-none;
|
@apply bg-controls-secondary dark:bg-overlay3 text-elements-on-secondary rounded-none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile--range:hover {
|
.react-calendar__tile--range:hover {
|
||||||
@ -89,7 +89,7 @@ abbr[title] {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile--rangeStart {
|
.react-calendar__tile--rangeStart {
|
||||||
@apply bg-controls-primary text-elements-on-primary rounded-lg;
|
@apply bg-controls-primary dark:bg-primary text-elements-on-primary rounded-lg;
|
||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile--rangeStart:hover {
|
.react-calendar__tile--rangeStart:hover {
|
||||||
@ -101,7 +101,7 @@ abbr[title] {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile--rangeEnd {
|
.react-calendar__tile--rangeEnd {
|
||||||
@apply bg-controls-primary text-elements-on-primary rounded-lg;
|
@apply bg-controls-primary dark:bg-primary text-elements-on-primary rounded-lg;
|
||||||
}
|
}
|
||||||
|
|
||||||
.react-calendar__tile--rangeEnd:hover {
|
.react-calendar__tile--rangeEnd:hover {
|
||||||
|
@ -5,7 +5,9 @@ export const calendarTheme = tv({
|
|||||||
wrapper: [
|
wrapper: [
|
||||||
'max-w-[352px]',
|
'max-w-[352px]',
|
||||||
'bg-surface-floating',
|
'bg-surface-floating',
|
||||||
|
'dark:bg-overlay2',
|
||||||
'shadow-dropdown',
|
'shadow-dropdown',
|
||||||
|
'dark:shadow-background',
|
||||||
'rounded-xl',
|
'rounded-xl',
|
||||||
],
|
],
|
||||||
calendar: ['flex', 'flex-col', 'py-2', 'px-2', 'gap-2'],
|
calendar: ['flex', 'flex-col', 'py-2', 'px-2', 'gap-2'],
|
||||||
@ -28,9 +30,12 @@ export const calendarTheme = tv({
|
|||||||
'border',
|
'border',
|
||||||
'border-border-interactive',
|
'border-border-interactive',
|
||||||
'text-elements-high-em',
|
'text-elements-high-em',
|
||||||
|
'dark:text-foreground',
|
||||||
'shadow-field',
|
'shadow-field',
|
||||||
'bg-white',
|
'bg-white',
|
||||||
|
'dark:bg-overlay3',
|
||||||
'hover:bg-base-bg-alternate',
|
'hover:bg-base-bg-alternate',
|
||||||
|
'dark:hover:bg-foreground-secondary',
|
||||||
'focus-visible:bg-base-bg-alternate',
|
'focus-visible:bg-base-bg-alternate',
|
||||||
],
|
],
|
||||||
footer: [
|
footer: [
|
||||||
|
@ -280,6 +280,7 @@ export const Calendar = ({
|
|||||||
showNavigation={false}
|
showNavigation={false}
|
||||||
selectRange={selectRange}
|
selectRange={selectRange}
|
||||||
onChange={handleChange}
|
onChange={handleChange}
|
||||||
|
// tileClassName="dark:text-foreground-secondary dark:hover:bg-overlay3"
|
||||||
onClickMonth={(date) => handleChangeNavigation('month', date)}
|
onClickMonth={(date) => handleChangeNavigation('month', date)}
|
||||||
onClickYear={(date) => handleChangeNavigation('year', date)}
|
onClickYear={(date) => handleChangeNavigation('year', date)}
|
||||||
/>
|
/>
|
||||||
@ -297,19 +298,20 @@ export const Calendar = ({
|
|||||||
) : (
|
) : (
|
||||||
<>
|
<>
|
||||||
{value && (
|
{value && (
|
||||||
<Button variant="danger" onClick={handleReset}>
|
<Button variant="danger" onClick={handleReset} shape="default">
|
||||||
Reset
|
RESET
|
||||||
</Button>
|
</Button>
|
||||||
)}
|
)}
|
||||||
<div className="space-x-3">
|
<div className="space-x-3">
|
||||||
<Button variant="tertiary" onClick={onCancel}>
|
<Button variant="tertiary" onClick={onCancel} shape="default">
|
||||||
Cancel
|
CANCEL
|
||||||
</Button>
|
</Button>
|
||||||
<Button
|
<Button
|
||||||
disabled={!value}
|
disabled={!value}
|
||||||
onClick={() => (value ? onSelect?.(value) : null)}
|
onClick={() => (value ? onSelect?.(value) : null)}
|
||||||
|
shape="default"
|
||||||
>
|
>
|
||||||
Select
|
SELECT
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</>
|
</>
|
||||||
|
@ -11,7 +11,9 @@ export const getCheckboxVariant = tv({
|
|||||||
'focus-visible:text-controls-disabled',
|
'focus-visible:text-controls-disabled',
|
||||||
'group-focus-visible:text-controls-disabled',
|
'group-focus-visible:text-controls-disabled',
|
||||||
'data-[state=checked]:text-elements-on-primary',
|
'data-[state=checked]:text-elements-on-primary',
|
||||||
|
'dark:data-[state=checked]:text-foreground',
|
||||||
'data-[state=checked]:group-focus-visible:text-elements-on-primary',
|
'data-[state=checked]:group-focus-visible:text-elements-on-primary',
|
||||||
|
'dark:data-[state=checked]:group-focus-visible:text-foreground',
|
||||||
'data-[state=indeterminate]:text-elements-on-primary',
|
'data-[state=indeterminate]:text-elements-on-primary',
|
||||||
'data-[state=checked]:data-[disabled]:text-elements-on-disabled-active',
|
'data-[state=checked]:data-[disabled]:text-elements-on-disabled-active',
|
||||||
],
|
],
|
||||||
@ -23,6 +25,7 @@ export const getCheckboxVariant = tv({
|
|||||||
'border',
|
'border',
|
||||||
'border-border-interactive/10',
|
'border-border-interactive/10',
|
||||||
'bg-controls-tertiary',
|
'bg-controls-tertiary',
|
||||||
|
'dark:bg-background',
|
||||||
'rounded-md',
|
'rounded-md',
|
||||||
'transition-all',
|
'transition-all',
|
||||||
'duration-150',
|
'duration-150',
|
||||||
@ -30,9 +33,13 @@ export const getCheckboxVariant = tv({
|
|||||||
'shadow-button',
|
'shadow-button',
|
||||||
'group-hover:border-border-interactive/[0.14]',
|
'group-hover:border-border-interactive/[0.14]',
|
||||||
'group-hover:bg-controls-tertiary',
|
'group-hover:bg-controls-tertiary',
|
||||||
|
'dark:group-hover:bg-overlay',
|
||||||
'data-[state=checked]:bg-controls-primary',
|
'data-[state=checked]:bg-controls-primary',
|
||||||
|
'dark:data-[state=checked]:bg-primary',
|
||||||
'data-[state=checked]:hover:bg-controls-primary-hovered',
|
'data-[state=checked]:hover:bg-controls-primary-hovered',
|
||||||
|
'dark:data-[state=checked]:hover:bg-primary-hovered',
|
||||||
'data-[state=checked]:focus-visible:bg-controls-primary-hovered',
|
'data-[state=checked]:focus-visible:bg-controls-primary-hovered',
|
||||||
|
'dark:data-[state=checked]:focus-visible:bg-primary-hovered',
|
||||||
'data-[disabled]:bg-controls-disabled',
|
'data-[disabled]:bg-controls-disabled',
|
||||||
'data-[disabled]:shadow-none',
|
'data-[disabled]:shadow-none',
|
||||||
'data-[disabled]:hover:border-border-interactive/10',
|
'data-[disabled]:hover:border-border-interactive/10',
|
||||||
@ -43,12 +50,17 @@ export const getCheckboxVariant = tv({
|
|||||||
'text-sm',
|
'text-sm',
|
||||||
'tracking-[-0.006em]',
|
'tracking-[-0.006em]',
|
||||||
'text-elements-high-em',
|
'text-elements-high-em',
|
||||||
|
'dark:text-foreground',
|
||||||
'flex',
|
'flex',
|
||||||
'flex-col',
|
'flex-col',
|
||||||
'gap-1',
|
'gap-1',
|
||||||
'px-1',
|
'px-1',
|
||||||
],
|
],
|
||||||
description: ['text-xs', 'text-elements-low-em'],
|
description: [
|
||||||
|
'text-xs',
|
||||||
|
'text-elements-low-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
variants: {
|
variants: {
|
||||||
disabled: {
|
disabled: {
|
||||||
|
@ -1,7 +1,12 @@
|
|||||||
import { tv, type VariantProps } from 'tailwind-variants';
|
import { tv, type VariantProps } from 'tailwind-variants';
|
||||||
|
|
||||||
export const headingTheme = tv({
|
export const headingTheme = tv({
|
||||||
base: ['text-elements-high-em', 'font-display', 'font-normal'],
|
base: [
|
||||||
|
'text-elements-high-em',
|
||||||
|
'dark:text-foreground',
|
||||||
|
'font-display',
|
||||||
|
'font-normal',
|
||||||
|
],
|
||||||
});
|
});
|
||||||
|
|
||||||
export type HeadingVariants = VariantProps<typeof headingTheme>;
|
export type HeadingVariants = VariantProps<typeof headingTheme>;
|
||||||
|
@ -14,10 +14,15 @@ export const inputTheme = tv(
|
|||||||
'disabled:cursor-not-allowed',
|
'disabled:cursor-not-allowed',
|
||||||
'disabled:bg-controls-disabled',
|
'disabled:bg-controls-disabled',
|
||||||
],
|
],
|
||||||
label: ['text-sm', 'text-elements-high-em'],
|
label: [
|
||||||
|
'text-sm',
|
||||||
|
'text-elements-high-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
|
],
|
||||||
description: ['text-xs', 'text-elements-low-em'],
|
description: ['text-xs', 'text-elements-low-em'],
|
||||||
input: [
|
input: [
|
||||||
'focus-ring',
|
'focus-ring',
|
||||||
|
'dark:focus:ring-0',
|
||||||
'block',
|
'block',
|
||||||
'w-full',
|
'w-full',
|
||||||
'h-full',
|
'h-full',
|
||||||
|
@ -31,6 +31,7 @@ export const modalTheme = tv({
|
|||||||
'sm:px-6',
|
'sm:px-6',
|
||||||
'sm:py-5',
|
'sm:py-5',
|
||||||
'bg-base-bg-alternate',
|
'bg-base-bg-alternate',
|
||||||
|
'dark:bg-overlay2',
|
||||||
],
|
],
|
||||||
headerTitle: [
|
headerTitle: [
|
||||||
'text-base',
|
'text-base',
|
||||||
@ -39,7 +40,11 @@ export const modalTheme = tv({
|
|||||||
'sm:tracking-normal',
|
'sm:tracking-normal',
|
||||||
'text-elements-high-em',
|
'text-elements-high-em',
|
||||||
],
|
],
|
||||||
headerDescription: ['text-sm', 'text-elements-low-em'],
|
headerDescription: [
|
||||||
|
'text-sm',
|
||||||
|
'text-elements-low-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
|
],
|
||||||
footer: ['flex', 'gap-3', 'px-4', 'pb-4', 'pt-7', 'sm:pb-6', 'sm:px-6'],
|
footer: ['flex', 'gap-3', 'px-4', 'pb-4', 'pt-7', 'sm:pb-6', 'sm:px-6'],
|
||||||
content: [
|
content: [
|
||||||
'h-fit',
|
'h-fit',
|
||||||
@ -53,8 +58,11 @@ export const modalTheme = tv({
|
|||||||
'sm:max-w-[562px]',
|
'sm:max-w-[562px]',
|
||||||
'rounded-2xl',
|
'rounded-2xl',
|
||||||
'bg-base-bg',
|
'bg-base-bg',
|
||||||
|
'dark:bg-overlay',
|
||||||
'shadow-card',
|
'shadow-card',
|
||||||
|
'dark:shadow-background',
|
||||||
'text-elements-high-em',
|
'text-elements-high-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
],
|
],
|
||||||
body: ['flex-1', 'px-4', 'pt-4', 'sm:pt-6', 'sm:px-6'],
|
body: ['flex-1', 'px-4', 'pt-4', 'sm:pt-6', 'sm:px-6'],
|
||||||
},
|
},
|
||||||
|
@ -4,7 +4,12 @@ export const radioTheme = tv({
|
|||||||
slots: {
|
slots: {
|
||||||
root: ['flex', 'gap-3'],
|
root: ['flex', 'gap-3'],
|
||||||
wrapper: ['flex', 'items-center', 'gap-2', 'group'],
|
wrapper: ['flex', 'items-center', 'gap-2', 'group'],
|
||||||
label: ['text-sm', 'tracking-[-0.006em]', 'text-elements-high-em'],
|
label: [
|
||||||
|
'text-sm',
|
||||||
|
'tracking-[-0.006em]',
|
||||||
|
'text-elements-high-em',
|
||||||
|
'dark:text-foreground',
|
||||||
|
],
|
||||||
radio: [
|
radio: [
|
||||||
'w-5',
|
'w-5',
|
||||||
'h-5',
|
'h-5',
|
||||||
@ -17,6 +22,7 @@ export const radioTheme = tv({
|
|||||||
'focus-ring',
|
'focus-ring',
|
||||||
// Checked
|
// Checked
|
||||||
'data-[state=checked]:bg-controls-primary',
|
'data-[state=checked]:bg-controls-primary',
|
||||||
|
'data-[state=checked]:bg-controls-primary',
|
||||||
'data-[state=checked]:group-hover:bg-controls-primary-hovered',
|
'data-[state=checked]:group-hover:bg-controls-primary-hovered',
|
||||||
],
|
],
|
||||||
indicator: [
|
indicator: [
|
||||||
@ -36,6 +42,7 @@ export const radioTheme = tv({
|
|||||||
'after:group-focus-visible:bg-controls-disabled',
|
'after:group-focus-visible:bg-controls-disabled',
|
||||||
// Checked
|
// Checked
|
||||||
'after:data-[state=checked]:bg-elements-on-primary',
|
'after:data-[state=checked]:bg-elements-on-primary',
|
||||||
|
'dark:after:data-[state=checked]:bg-primary-hovered',
|
||||||
'after:data-[state=checked]:group-hover:bg-elements-on-primary',
|
'after:data-[state=checked]:group-hover:bg-elements-on-primary',
|
||||||
'after:data-[state=checked]:group-focus-visible:bg-elements-on-primary',
|
'after:data-[state=checked]:group-focus-visible:bg-elements-on-primary',
|
||||||
],
|
],
|
||||||
|
@ -3,8 +3,16 @@ import { VariantProps, tv } from 'tailwind-variants';
|
|||||||
export const selectTheme = tv({
|
export const selectTheme = tv({
|
||||||
slots: {
|
slots: {
|
||||||
container: ['flex', 'flex-col', 'relative', 'gap-2', 'w-full'],
|
container: ['flex', 'flex-col', 'relative', 'gap-2', 'w-full'],
|
||||||
label: ['text-sm', 'text-elements-high-em'],
|
label: [
|
||||||
description: ['text-xs', 'text-elements-low-em'],
|
'text-sm',
|
||||||
|
'text-elements-high-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
|
],
|
||||||
|
description: [
|
||||||
|
'text-xs',
|
||||||
|
'text-elements-low-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
|
],
|
||||||
inputWrapper: [
|
inputWrapper: [
|
||||||
'relative',
|
'relative',
|
||||||
'flex',
|
'flex',
|
||||||
@ -14,6 +22,7 @@ export const selectTheme = tv({
|
|||||||
'w-full',
|
'w-full',
|
||||||
'rounded-lg',
|
'rounded-lg',
|
||||||
'bg-transparent',
|
'bg-transparent',
|
||||||
|
'dark:bg-overlay2',
|
||||||
'text-elements-mid-em',
|
'text-elements-mid-em',
|
||||||
'shadow-sm',
|
'shadow-sm',
|
||||||
'border',
|
'border',
|
||||||
@ -22,7 +31,7 @@ export const selectTheme = tv({
|
|||||||
'disabled:shadow-none',
|
'disabled:shadow-none',
|
||||||
'disabled:border-none',
|
'disabled:border-none',
|
||||||
],
|
],
|
||||||
input: ['outline-none'],
|
input: ['outline-none', 'dark:bg-overlay2', 'dark:text-foreground'],
|
||||||
iconContainer: [
|
iconContainer: [
|
||||||
'absolute',
|
'absolute',
|
||||||
'inset-y-0',
|
'inset-y-0',
|
||||||
@ -32,9 +41,15 @@ export const selectTheme = tv({
|
|||||||
'z-10',
|
'z-10',
|
||||||
'cursor-pointer',
|
'cursor-pointer',
|
||||||
],
|
],
|
||||||
icon: ['text-elements-mid-em'],
|
icon: ['text-elements-mid-em', 'dark:text-foreground-secondary'],
|
||||||
helperIcon: [],
|
helperIcon: [],
|
||||||
helperText: ['flex', 'gap-2', 'items-center', 'text-elements-low-em'],
|
helperText: [
|
||||||
|
'flex',
|
||||||
|
'gap-2',
|
||||||
|
'items-center',
|
||||||
|
'text-elements-low-em',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
|
],
|
||||||
popover: [
|
popover: [
|
||||||
'z-20',
|
'z-20',
|
||||||
'absolute',
|
'absolute',
|
||||||
@ -44,12 +59,14 @@ export const selectTheme = tv({
|
|||||||
'gap-0.5',
|
'gap-0.5',
|
||||||
'min-w-full',
|
'min-w-full',
|
||||||
'bg-surface-floating',
|
'bg-surface-floating',
|
||||||
|
'dark:bg-overlay2',
|
||||||
'shadow-dropdown',
|
'shadow-dropdown',
|
||||||
'w-auto',
|
'w-auto',
|
||||||
'max-h-60',
|
'max-h-60',
|
||||||
'overflow-auto',
|
'overflow-auto',
|
||||||
'border',
|
'border',
|
||||||
'border-gray-200',
|
'border-gray-200',
|
||||||
|
'dark:border-overlay',
|
||||||
'rounded-xl',
|
'rounded-xl',
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
@ -79,7 +96,7 @@ export const selectTheme = tv({
|
|||||||
'shadow-none',
|
'shadow-none',
|
||||||
'focus:outline-border-danger',
|
'focus:outline-border-danger',
|
||||||
],
|
],
|
||||||
helperText: ['text-elements-danger'],
|
helperText: ['text-error'],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
size: {
|
size: {
|
||||||
|
@ -12,11 +12,12 @@ export const selectItemTheme = tv({
|
|||||||
'group',
|
'group',
|
||||||
'data-[disabled]:cursor-not-allowed',
|
'data-[disabled]:cursor-not-allowed',
|
||||||
],
|
],
|
||||||
icon: ['h-4.5', 'w-4.5', 'text-elements-high-em'],
|
icon: ['h-4.5', 'w-4.5', 'text-elements-high-em', 'dark:text-foreground'],
|
||||||
content: ['flex', 'flex-1', 'whitespace-nowrap'],
|
content: ['flex', 'flex-1', 'whitespace-nowrap'],
|
||||||
label: [
|
label: [
|
||||||
'text-sm',
|
'text-sm',
|
||||||
'text-elements-high-em',
|
'text-elements-high-em',
|
||||||
|
'dark:text-foreground',
|
||||||
'tracking-[-0.006em]',
|
'tracking-[-0.006em]',
|
||||||
'data-[disabled]:text-elements-disabled',
|
'data-[disabled]:text-elements-disabled',
|
||||||
],
|
],
|
||||||
@ -47,7 +48,11 @@ export const selectItemTheme = tv({
|
|||||||
},
|
},
|
||||||
active: {
|
active: {
|
||||||
true: {
|
true: {
|
||||||
wrapper: ['bg-base-bg-emphasized', 'data-[disabled]:bg-transparent'],
|
wrapper: [
|
||||||
|
'bg-base-bg-emphasized',
|
||||||
|
'dark:bg-overlay3',
|
||||||
|
'data-[disabled]:bg-transparent',
|
||||||
|
],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -87,15 +87,15 @@ export const Sidebar = ({ mobileOpen }: SidebarProps) => {
|
|||||||
value=""
|
value=""
|
||||||
className="hidden lg:flex"
|
className="hidden lg:flex"
|
||||||
>
|
>
|
||||||
<a className="cursor-pointer" onClick={handleLogOut}>
|
<a className="cursor-pointer font-mono" onClick={handleLogOut}>
|
||||||
Log Out
|
LOG OUT
|
||||||
</a>
|
</a>
|
||||||
</Tabs.Trigger>
|
</Tabs.Trigger>
|
||||||
<Tabs.Trigger icon={<QuestionMarkRoundIcon />} value="">
|
<Tabs.Trigger icon={<QuestionMarkRoundIcon />} value="">
|
||||||
<a className="cursor-pointer">Documentation</a>
|
<a className="cursor-pointer font-mono">DOCUMENTATION</a>
|
||||||
</Tabs.Trigger>
|
</Tabs.Trigger>
|
||||||
<Tabs.Trigger icon={<LifeBuoyIcon />} value="">
|
<Tabs.Trigger icon={<LifeBuoyIcon />} value="">
|
||||||
<a className="cursor-pointer">Support</a>
|
<a className="cursor-pointer font-mono">SUPPORT</a>
|
||||||
</Tabs.Trigger>
|
</Tabs.Trigger>
|
||||||
</Tabs.List>
|
</Tabs.List>
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
@ -45,6 +45,7 @@ export const switchTheme = tv({
|
|||||||
true: {
|
true: {
|
||||||
switch: [
|
switch: [
|
||||||
'bg-controls-primary',
|
'bg-controls-primary',
|
||||||
|
'dark:bg-primary',
|
||||||
'hover:bg-controls-primary-hovered',
|
'hover:bg-controls-primary-hovered',
|
||||||
'focus-visible:bg-controls-primary-hovered',
|
'focus-visible:bg-controls-primary-hovered',
|
||||||
],
|
],
|
||||||
|
@ -8,6 +8,7 @@ export const tableTheme = tv({
|
|||||||
'border-b',
|
'border-b',
|
||||||
'border-sky-950/opacity-5',
|
'border-sky-950/opacity-5',
|
||||||
'text-sky-950',
|
'text-sky-950',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
'text-sm',
|
'text-sm',
|
||||||
'font-medium',
|
'font-medium',
|
||||||
'leading-tight',
|
'leading-tight',
|
||||||
@ -17,6 +18,7 @@ export const tableTheme = tv({
|
|||||||
columnHeaderCell: [
|
columnHeaderCell: [
|
||||||
'p-4',
|
'p-4',
|
||||||
'text-sky-950',
|
'text-sky-950',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
'text-sm',
|
'text-sm',
|
||||||
'font-medium',
|
'font-medium',
|
||||||
'uppercase',
|
'uppercase',
|
||||||
@ -26,6 +28,7 @@ export const tableTheme = tv({
|
|||||||
rowHeaderCell: [
|
rowHeaderCell: [
|
||||||
'p-4',
|
'p-4',
|
||||||
'text-slate-600',
|
'text-slate-600',
|
||||||
|
'dark:text-foreground',
|
||||||
'text-sm',
|
'text-sm',
|
||||||
'font-normal',
|
'font-normal',
|
||||||
'leading-tight',
|
'leading-tight',
|
||||||
@ -36,6 +39,7 @@ export const tableTheme = tv({
|
|||||||
'whitespace-nowrap',
|
'whitespace-nowrap',
|
||||||
'text-sm',
|
'text-sm',
|
||||||
'text-slate-600',
|
'text-slate-600',
|
||||||
|
'dark:text-foreground',
|
||||||
'font-normal',
|
'font-normal',
|
||||||
'text-left',
|
'text-left',
|
||||||
],
|
],
|
||||||
|
@ -11,6 +11,7 @@ export const tabsTheme = tv({
|
|||||||
'cursor-default',
|
'cursor-default',
|
||||||
'select-none',
|
'select-none',
|
||||||
'text-elements-low-em',
|
'text-elements-low-em',
|
||||||
|
'dark:text-foreground',
|
||||||
'border-b-2',
|
'border-b-2',
|
||||||
'border-transparent',
|
'border-transparent',
|
||||||
'hover:border-border-interactive/10',
|
'hover:border-border-interactive/10',
|
||||||
@ -20,6 +21,7 @@ export const tabsTheme = tv({
|
|||||||
'data-[state=active]:font-medium',
|
'data-[state=active]:font-medium',
|
||||||
'data-[state=active]:text-elements-high-em',
|
'data-[state=active]:text-elements-high-em',
|
||||||
'data-[state=active]:border-elements-high-em',
|
'data-[state=active]:border-elements-high-em',
|
||||||
|
'data-[state=active]:border-primary',
|
||||||
// Vertical
|
// Vertical
|
||||||
'data-[orientation=vertical]:px-3',
|
'data-[orientation=vertical]:px-3',
|
||||||
'data-[orientation=vertical]:py-3',
|
'data-[orientation=vertical]:py-3',
|
||||||
|
@ -6,8 +6,10 @@ export const tooltipTheme = tv({
|
|||||||
'z-tooltip',
|
'z-tooltip',
|
||||||
'rounded-md',
|
'rounded-md',
|
||||||
'bg-surface-high-contrast',
|
'bg-surface-high-contrast',
|
||||||
|
'dark:bg-overlay3',
|
||||||
'p-2',
|
'p-2',
|
||||||
'text-elements-on-high-contrast',
|
'text-elements-on-high-contrast',
|
||||||
|
'dark:text-foreground-secondary',
|
||||||
],
|
],
|
||||||
arrow: ['fill-surface-high-contrast'],
|
arrow: ['fill-surface-high-contrast'],
|
||||||
},
|
},
|
||||||
|
@ -144,6 +144,7 @@
|
|||||||
@layer utilities {
|
@layer utilities {
|
||||||
.focus-ring {
|
.focus-ring {
|
||||||
@apply focus-visible:ring-[3px] focus-visible:ring-snowball-200 focus-visible:ring-offset-1 focus-visible:ring-offset-snowball-500 focus-visible:outline-none;
|
@apply focus-visible:ring-[3px] focus-visible:ring-snowball-200 focus-visible:ring-offset-1 focus-visible:ring-offset-snowball-500 focus-visible:outline-none;
|
||||||
|
@apply focus-visible:ring-[3px] dark:focus-visible:ring-primary focus-visible:ring-offset-1 dark:focus-visible:ring-offset-primary focus-visible:outline-none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@keyframes dialog-overlay-show {
|
@keyframes dialog-overlay-show {
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
import { CloudyFlow } from 'components/CloudyFlow';
|
|
||||||
import { Login } from './auth/Login';
|
import { Login } from './auth/Login';
|
||||||
|
|
||||||
const AuthPage = () => {
|
const AuthPage = () => {
|
||||||
|
@ -3,105 +3,28 @@ import { Navigate } from 'react-router-dom';
|
|||||||
import { useGQLClient } from '../context/GQLClientContext';
|
import { useGQLClient } from '../context/GQLClientContext';
|
||||||
import { Organization } from 'gql-client';
|
import { Organization } from 'gql-client';
|
||||||
|
|
||||||
const owner = {
|
|
||||||
id: 'user',
|
|
||||||
name: 'Cody',
|
|
||||||
email: 'cody@cfb.dev',
|
|
||||||
isVerified: true,
|
|
||||||
createdAt: '2024-10-22-12:00:00Z',
|
|
||||||
updatedAt: '2024-10-22-12:00:00Z',
|
|
||||||
gitHubToken: 'token',
|
|
||||||
};
|
|
||||||
|
|
||||||
const domain = {
|
|
||||||
id: 'domain',
|
|
||||||
branch: 'idk',
|
|
||||||
name: 'Domain',
|
|
||||||
status: 'Live',
|
|
||||||
redirectTo: null,
|
|
||||||
createdAt: '2024-10-22-12:00:00Z',
|
|
||||||
updatedAt: '2024-10-22-12:00:00Z',
|
|
||||||
};
|
|
||||||
const deployment = {
|
|
||||||
id: 'deployment',
|
|
||||||
domain,
|
|
||||||
branch: 'branch',
|
|
||||||
commitHash: 'beefb0d',
|
|
||||||
commitMessage: 'beef',
|
|
||||||
deployerLrn: 'deployer',
|
|
||||||
environment: 'Development',
|
|
||||||
isCurrent: true,
|
|
||||||
status: 'Ready',
|
|
||||||
createdBy: owner,
|
|
||||||
createdAt: '2024-10-22-12:00:00Z',
|
|
||||||
updatedAt: '2024-10-22-12:00:00Z',
|
|
||||||
};
|
|
||||||
const member = {
|
|
||||||
id: 'member_id',
|
|
||||||
member: owner,
|
|
||||||
permissions: ['Edit'],
|
|
||||||
isPending: false,
|
|
||||||
createdAt: '2024-10-22-12:00:00Z',
|
|
||||||
updatedAt: '2024-10-22-12:00:00Z',
|
|
||||||
};
|
|
||||||
|
|
||||||
const environmentVariable = {
|
|
||||||
id: 'env_var_id',
|
|
||||||
environment: 'Development',
|
|
||||||
key: 'key',
|
|
||||||
value: 'value',
|
|
||||||
createdAt: '2024-10-22-12:00:00Z',
|
|
||||||
updatedAt: '2024-10-22-12:00:00Z',
|
|
||||||
};
|
|
||||||
const project = {
|
|
||||||
id: 'project',
|
|
||||||
owner,
|
|
||||||
deployments: [deployment],
|
|
||||||
name: 'Project',
|
|
||||||
repository: 'snowball',
|
|
||||||
prodBranch: 'main',
|
|
||||||
description: 'description',
|
|
||||||
template: 'template',
|
|
||||||
framework: 'framework',
|
|
||||||
webhooks: ['webhook'],
|
|
||||||
members: [member],
|
|
||||||
environmentVariables: [environmentVariable],
|
|
||||||
createdAt: '2024-10-22-12:00:00Z',
|
|
||||||
updatedAt: '2024-10-22-12:00:00Z',
|
|
||||||
};
|
|
||||||
|
|
||||||
const organizationMember = {
|
|
||||||
id: 'member_id',
|
|
||||||
member: owner,
|
|
||||||
role: 'Owner',
|
|
||||||
createdAt: '2024-10-22-12:00:00Z',
|
|
||||||
updatedAt: '2024-10-22-12:00:00Z',
|
|
||||||
};
|
|
||||||
const testOrg = {
|
|
||||||
id: 'org_id',
|
|
||||||
name: 'Test Org',
|
|
||||||
slug: 'test',
|
|
||||||
projects: [project],
|
|
||||||
createdAt: '2024-10-22-12:00:00Z',
|
|
||||||
updatedAt: '2024-10-22-12:00:00Z',
|
|
||||||
members: [organizationMember],
|
|
||||||
};
|
|
||||||
const Index = () => {
|
const Index = () => {
|
||||||
const client = useGQLClient();
|
const client = useGQLClient();
|
||||||
// const [organization, setOrganization] = useState<Organization>(testOrg);
|
const [organization, setOrganization] = useState<Organization>();
|
||||||
|
|
||||||
// const fetchUserOrganizations = useCallback(async () => {
|
const fetchUserOrganizations = useCallback(async () => {
|
||||||
// const { organizations } = await client.getOrganizations();
|
const { organizations } = await client.getOrganizations();
|
||||||
// // By default information of first organization displayed
|
// By default information of first organization displayed
|
||||||
// setOrganization(organizations[0]);
|
setOrganization(organizations[0]);
|
||||||
// }, []);
|
}, []);
|
||||||
//
|
|
||||||
// useEffect(() => {
|
useEffect(() => {
|
||||||
// fetchUserOrganizations();
|
fetchUserOrganizations();
|
||||||
// }, []);
|
}, []);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>{Boolean(testOrg) ? <Navigate to={testOrg!.slug} /> : <>Loading</>}</>
|
<>
|
||||||
|
{Boolean(organization) ? (
|
||||||
|
<Navigate to={organization!.slug} />
|
||||||
|
) : (
|
||||||
|
<>Loading</>
|
||||||
|
)}
|
||||||
|
</>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -6,11 +6,12 @@ import { Heading, Badge, Button } from 'components/shared';
|
|||||||
import { PlusIcon } from 'components/shared/CustomIcon';
|
import { PlusIcon } from 'components/shared/CustomIcon';
|
||||||
import { useGQLClient } from 'context/GQLClientContext';
|
import { useGQLClient } from 'context/GQLClientContext';
|
||||||
import { Project } from 'gql-client';
|
import { Project } from 'gql-client';
|
||||||
|
import { project as mockProject } from 'pages/index';
|
||||||
|
|
||||||
const Projects = () => {
|
const Projects = () => {
|
||||||
const client = useGQLClient();
|
const client = useGQLClient();
|
||||||
const { orgSlug } = useParams();
|
const { orgSlug } = useParams();
|
||||||
const [projects, setProjects] = useState<Project[]>([]);
|
const [projects, setProjects] = useState<Project[]>([mockProject]);
|
||||||
|
|
||||||
const fetchProjects = useCallback(async () => {
|
const fetchProjects = useCallback(async () => {
|
||||||
const { projectsInOrganization } = await client.getProjectsInOrganization(
|
const { projectsInOrganization } = await client.getProjectsInOrganization(
|
||||||
@ -39,7 +40,7 @@ const Projects = () => {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<Link to="projects/create">
|
<Link to="projects/create">
|
||||||
<Button leftIcon={<PlusIcon />}>Create project</Button>
|
<Button leftIcon={<PlusIcon />}>CREATE PROJECT</Button>
|
||||||
</Link>
|
</Link>
|
||||||
</div>
|
</div>
|
||||||
{/* List of projects */}
|
{/* List of projects */}
|
||||||
|
@ -78,7 +78,7 @@ const Id = () => {
|
|||||||
leftIcon={<ChevronLeft />}
|
leftIcon={<ChevronLeft />}
|
||||||
onClick={() => navigate(-1)}
|
onClick={() => navigate(-1)}
|
||||||
/>
|
/>
|
||||||
<Heading className="text-2xl font-medium truncate">
|
<Heading className="text-2xl font-medium truncate dark:text-foreground">
|
||||||
{project?.name}
|
{project?.name}
|
||||||
</Heading>
|
</Heading>
|
||||||
</div>
|
</div>
|
||||||
@ -88,17 +88,24 @@ const Id = () => {
|
|||||||
{...buttonSize}
|
{...buttonSize}
|
||||||
className="h-11 transition-colors"
|
className="h-11 transition-colors"
|
||||||
variant="tertiary"
|
variant="tertiary"
|
||||||
|
shape="default"
|
||||||
>
|
>
|
||||||
Open repo
|
OPEN REPO
|
||||||
</Button>
|
</Button>
|
||||||
</Link>
|
</Link>
|
||||||
{(project.deployments.length > 0) &&
|
{project.deployments.length > 0 && (
|
||||||
<Link to={`https://${project.name.toLowerCase()}.${project.deployments[0].deployer.baseDomain}`}>
|
<Link
|
||||||
<Button {...buttonSize} className="h-11 transition-colors">
|
to={`https://${project.name.toLowerCase()}.${project.deployments[0].deployer.baseDomain}`}
|
||||||
Go to app
|
>
|
||||||
|
<Button
|
||||||
|
{...buttonSize}
|
||||||
|
className="h-11 transition-colors"
|
||||||
|
shape="default"
|
||||||
|
>
|
||||||
|
GO TO APP
|
||||||
</Button>
|
</Button>
|
||||||
</Link>
|
</Link>
|
||||||
}
|
)}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<WavyBorder />
|
<WavyBorder />
|
||||||
|
@ -121,21 +121,22 @@ const DeploymentsTabPanel = () => {
|
|||||||
})
|
})
|
||||||
) : (
|
) : (
|
||||||
// TODO: Update the height based on the layout, need to re-styling the layout similar to create project layout
|
// TODO: Update the height based on the layout, need to re-styling the layout similar to create project layout
|
||||||
<div className="h-3/4 bg-base-bg-alternate flex flex-col rounded-xl items-center justify-center text-center gap-5">
|
<div className="h-3/4 bg-base-bg-alternate dark:bg-overlay3 flex flex-col rounded-xl items-center justify-center text-center gap-5">
|
||||||
<div className="space-y-1">
|
<div className="space-y-1">
|
||||||
<p className="font-medium tracking-[-0.011em] text-elements-high-em">
|
<p className="font-medium tracking-[-0.011em] text-elements-high-em dark:text-foreground">
|
||||||
No deployments found
|
No deployments found
|
||||||
</p>
|
</p>
|
||||||
<p className="text-sm tracking-[-0.006em] text-elements-mid-em">
|
<p className="text-sm tracking-[-0.006em] text-elements-mid-em dark:text-foreground-secondary">
|
||||||
Please change your search query or filters.
|
Please change your search query or filters.
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<Button
|
<Button
|
||||||
variant="tertiary"
|
variant="primary"
|
||||||
|
shape="default"
|
||||||
leftIcon={<RefreshIcon />}
|
leftIcon={<RefreshIcon />}
|
||||||
onClick={handleResetFilters}
|
onClick={handleResetFilters}
|
||||||
>
|
>
|
||||||
Reset filters
|
RESET FILTERS
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
@ -126,7 +126,7 @@ const OverviewTabPanel = () => {
|
|||||||
type="blue"
|
type="blue"
|
||||||
/>
|
/>
|
||||||
<div className="flex-1 space-y-1 overflow-hidden">
|
<div className="flex-1 space-y-1 overflow-hidden">
|
||||||
<Heading className="text-lg leading-6 font-medium truncate">
|
<Heading className="text-lg leading-6 font-medium truncate dark:text-foreground">
|
||||||
{project.name}
|
{project.name}
|
||||||
</Heading>
|
</Heading>
|
||||||
{project.deployments &&
|
{project.deployments &&
|
||||||
@ -136,7 +136,7 @@ const OverviewTabPanel = () => {
|
|||||||
<a
|
<a
|
||||||
key={index}
|
key={index}
|
||||||
href={`https://${project.name.toLowerCase()}.${deployment.deployer.baseDomain}`}
|
href={`https://${project.name.toLowerCase()}.${deployment.deployer.baseDomain}`}
|
||||||
className="text-sm text-elements-low-em tracking-tight truncate"
|
className="text-sm text-elements-low-em dark:text-foreground tracking-tight truncate"
|
||||||
>
|
>
|
||||||
{deployment.deployer.baseDomain}
|
{deployment.deployer.baseDomain}
|
||||||
</a>
|
</a>
|
||||||
@ -161,7 +161,7 @@ const OverviewTabPanel = () => {
|
|||||||
variant="tertiary"
|
variant="tertiary"
|
||||||
size="sm"
|
size="sm"
|
||||||
>
|
>
|
||||||
Setup
|
SETUP
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
@ -171,8 +171,8 @@ const OverviewTabPanel = () => {
|
|||||||
{/* SOURCE */}
|
{/* SOURCE */}
|
||||||
<OverviewInfo label="Source" icon={<GithubStrokeIcon />}>
|
<OverviewInfo label="Source" icon={<GithubStrokeIcon />}>
|
||||||
<div className="flex gap-2 items-center">
|
<div className="flex gap-2 items-center">
|
||||||
<BranchStrokeIcon className="text-elements-low-em w-4 h-5" />
|
<BranchStrokeIcon className="text-elements-low-em dark:text-foreground w-4 h-5" />
|
||||||
<span className="text-elements-high-em text-sm tracking-tighter">
|
<span className="text-elements-high-em dark:text-foreground-secondary text-sm tracking-tighter">
|
||||||
{project.deployments[0]?.branch}
|
{project.deployments[0]?.branch}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
@ -180,23 +180,25 @@ const OverviewTabPanel = () => {
|
|||||||
|
|
||||||
{/* DEPLOYMENT */}
|
{/* DEPLOYMENT */}
|
||||||
<OverviewInfo label="Deployment URL" icon={<CursorBoxIcon />}>
|
<OverviewInfo label="Deployment URL" icon={<CursorBoxIcon />}>
|
||||||
{project.deployments &&
|
{project.deployments &&
|
||||||
project.deployments.length > 0 &&
|
project.deployments.length > 0 &&
|
||||||
project.deployments.map((deployment) => (
|
project.deployments.map((deployment) => (
|
||||||
<div className="flex gap-2 items-center">
|
<div className="flex gap-2 items-center">
|
||||||
<Link to={`https://${project.name.toLowerCase()}.${deployment.deployer.baseDomain}`}>
|
<Link
|
||||||
<span className="text-controls-primary group hover:border-controls-primary transition-colors border-b border-b-transparent flex gap-2 items-center text-sm tracking-tight">
|
to={`https://${project.name.toLowerCase()}.${deployment.deployer.baseDomain}`}
|
||||||
{`https://${project.name.toLowerCase()}.${deployment.deployer.baseDomain}`}
|
>
|
||||||
<LinkIcon className="group-hover:rotate-45 transition-transform" />
|
<span className="text-controls-primary dark:text-foreground group hover:border-controls-primary transition-colors border-b border-b-transparent flex gap-2 items-center text-sm tracking-tight">
|
||||||
</span>
|
{`https://${project.name.toLowerCase()}.${deployment.deployer.baseDomain}`}
|
||||||
</Link>
|
<LinkIcon className="group-hover:rotate-45 transition-transform" />
|
||||||
</div>
|
</span>
|
||||||
))}
|
</Link>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
</OverviewInfo>
|
</OverviewInfo>
|
||||||
|
|
||||||
{/* DEPLOYMENT DATE */}
|
{/* DEPLOYMENT DATE */}
|
||||||
<OverviewInfo label="Deployment date" icon={<CalendarDaysIcon />}>
|
<OverviewInfo label="Deployment date" icon={<CalendarDaysIcon />}>
|
||||||
<div className="flex gap-2 items-center text-elements-high-em text-sm tracking-tighter">
|
<div className="flex gap-2 items-center text-elements-high-em dark:text-foreground text-sm tracking-tighter">
|
||||||
<span>{relativeTimeMs(project.deployments[0].createdAt)}</span>
|
<span>{relativeTimeMs(project.deployments[0].createdAt)}</span>
|
||||||
by
|
by
|
||||||
<Avatar
|
<Avatar
|
||||||
|
@ -8,7 +8,7 @@ import CollaboratorsTabPanel from './settings/Collaborators';
|
|||||||
import Domains from './settings/Domains';
|
import Domains from './settings/Domains';
|
||||||
|
|
||||||
const Integrations = () => (
|
const Integrations = () => (
|
||||||
<div>
|
<div className="dark:text-foreground">
|
||||||
Content of integrations tab
|
Content of integrations tab
|
||||||
<p className="block">
|
<p className="block">
|
||||||
There are many variations of passages of Lorem Ipsum available.
|
There are many variations of passages of Lorem Ipsum available.
|
||||||
|
@ -117,9 +117,10 @@ const CollaboratorsTabPanel = () => {
|
|||||||
size="md"
|
size="md"
|
||||||
onClick={() => setAddMemberDialogOpen((preVal) => !preVal)}
|
onClick={() => setAddMemberDialogOpen((preVal) => !preVal)}
|
||||||
leftIcon={<PlusIcon />}
|
leftIcon={<PlusIcon />}
|
||||||
variant="secondary"
|
variant="primary"
|
||||||
|
shape="default"
|
||||||
>
|
>
|
||||||
Add member
|
ADD MEMBER
|
||||||
</Button>
|
</Button>
|
||||||
}
|
}
|
||||||
>
|
>
|
||||||
|
@ -111,10 +111,10 @@ export const EnvironmentVariablesTabPanel = () => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<ProjectSettingContainer headingText="Environment variables">
|
<ProjectSettingContainer headingText="Environment variables">
|
||||||
<p className="text-slate-600 text-sm font-normal leading-tight">
|
<p className="text-slate-600 dark:text-foreground-secondary text-sm font-normal leading-tight">
|
||||||
A new deployment is required for your changes to take effect.
|
A new deployment is required for your changes to take effect.
|
||||||
</p>
|
</p>
|
||||||
<div className="bg-slate-100 rounded-xl flex-col">
|
<div className="bg-slate-100 dark:bg-overlay2 rounded-xl flex-col">
|
||||||
<Heading
|
<Heading
|
||||||
onClick={() => setCreateNewVariable((cur) => !cur)}
|
onClick={() => setCreateNewVariable((cur) => !cur)}
|
||||||
className="p-4"
|
className="p-4"
|
||||||
@ -131,12 +131,12 @@ export const EnvironmentVariablesTabPanel = () => {
|
|||||||
createEnvironmentVariablesHandler(data),
|
createEnvironmentVariablesHandler(data),
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
<div className="p-4 bg-slate-100">
|
<div className="p-4 bg-slate-100 dark:bg-overlay3">
|
||||||
<EnvironmentVariablesForm />
|
<EnvironmentVariablesForm />
|
||||||
</div>
|
</div>
|
||||||
<div className="p-2">
|
<div className="p-2">
|
||||||
<Button size="md" type="submit">
|
<Button size="md" type="submit" shape="default">
|
||||||
Save changes
|
SAVE CHANGES
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
@ -1,13 +1,11 @@
|
|||||||
import { useEffect, useMemo } from 'react';
|
import { useEffect, useMemo } from 'react';
|
||||||
import { useFieldArray, useFormContext } from 'react-hook-form';
|
import { useFieldArray, useFormContext } from 'react-hook-form';
|
||||||
|
|
||||||
// TODO: Use custom checkbox component
|
|
||||||
import { Checkbox } from '@snowballtools/material-tailwind-react-fork';
|
|
||||||
|
|
||||||
import { Button } from 'components/shared/Button';
|
import { Button } from 'components/shared/Button';
|
||||||
import { InlineNotification } from 'components/shared/InlineNotification';
|
import { InlineNotification } from 'components/shared/InlineNotification';
|
||||||
import AddEnvironmentVariableRow from 'components/projects/project/settings/AddEnvironmentVariableRow';
|
import AddEnvironmentVariableRow from 'components/projects/project/settings/AddEnvironmentVariableRow';
|
||||||
import { EnvironmentVariablesFormValues } from 'types/types';
|
import { EnvironmentVariablesFormValues } from 'types/types';
|
||||||
|
import { Checkbox } from 'components/shared/Checkbox';
|
||||||
|
|
||||||
const EnvironmentVariablesForm = () => {
|
const EnvironmentVariablesForm = () => {
|
||||||
const {
|
const {
|
||||||
@ -54,8 +52,12 @@ const EnvironmentVariablesForm = () => {
|
|||||||
/>
|
/>
|
||||||
))}
|
))}
|
||||||
<div className="flex gap-1 p-2">
|
<div className="flex gap-1 p-2">
|
||||||
<Button size="md" onClick={() => append({ key: '', value: '' })}>
|
<Button
|
||||||
+ Add variable
|
size="md"
|
||||||
|
onClick={() => append({ key: '', value: '' })}
|
||||||
|
shape="default"
|
||||||
|
>
|
||||||
|
+ ADD VARIABLE
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
{isFieldEmpty && (
|
{isFieldEmpty && (
|
||||||
|
@ -18,6 +18,7 @@ const GeneralTabPanel = () => {
|
|||||||
const client = useGQLClient();
|
const client = useGQLClient();
|
||||||
const { toast } = useToast();
|
const { toast } = useToast();
|
||||||
const { project, onUpdate } = useOutletContext<OutletContextType>();
|
const { project, onUpdate } = useOutletContext<OutletContextType>();
|
||||||
|
console.log(project);
|
||||||
|
|
||||||
const [transferOrganizations, setTransferOrganizations] = useState<
|
const [transferOrganizations, setTransferOrganizations] = useState<
|
||||||
SelectOption[]
|
SelectOption[]
|
||||||
@ -157,8 +158,9 @@ const GeneralTabPanel = () => {
|
|||||||
type="submit"
|
type="submit"
|
||||||
size="md"
|
size="md"
|
||||||
disabled={!updateProjectFormState.isDirty}
|
disabled={!updateProjectFormState.isDirty}
|
||||||
|
shape="default"
|
||||||
>
|
>
|
||||||
Save
|
SAVE
|
||||||
</Button>
|
</Button>
|
||||||
</form>
|
</form>
|
||||||
<form
|
<form
|
||||||
@ -185,8 +187,8 @@ const GeneralTabPanel = () => {
|
|||||||
setSelectedTransferOrganization(value as SelectOption)
|
setSelectedTransferOrganization(value as SelectOption)
|
||||||
}
|
}
|
||||||
/>
|
/>
|
||||||
<Button disabled type="submit" size="md">
|
<Button disabled type="submit" size="md" shape="default">
|
||||||
Transfer
|
TRANSFER
|
||||||
</Button>
|
</Button>
|
||||||
</form>
|
</form>
|
||||||
<TransferProjectDialog
|
<TransferProjectDialog
|
||||||
@ -211,7 +213,7 @@ const GeneralTabPanel = () => {
|
|||||||
onClick={handleDeleteProjectDialog}
|
onClick={handleDeleteProjectDialog}
|
||||||
leftIcon={<TrashIcon />}
|
leftIcon={<TrashIcon />}
|
||||||
>
|
>
|
||||||
Delete project
|
DELETE PROJECT
|
||||||
</Button>
|
</Button>
|
||||||
<DeleteProjectDialog
|
<DeleteProjectDialog
|
||||||
handleOpen={handleDeleteProjectDialog}
|
handleOpen={handleDeleteProjectDialog}
|
||||||
|
@ -139,7 +139,7 @@ const GitTabPanel = () => {
|
|||||||
<div className="self-stretch space-y-3">
|
<div className="self-stretch space-y-3">
|
||||||
<div className="flex justify-between mt-4">
|
<div className="flex justify-between mt-4">
|
||||||
<div>
|
<div>
|
||||||
<p className="text-slate-600 text-sm font-normal leading-tight">
|
<p className="text-slate-600 dark:text-foreground-secondary text-sm font-normal leading-tight">
|
||||||
Pull request comments
|
Pull request comments
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
@ -153,7 +153,7 @@ const GitTabPanel = () => {
|
|||||||
|
|
||||||
<div className="flex justify-between">
|
<div className="flex justify-between">
|
||||||
<div>
|
<div>
|
||||||
<p className="text-slate-600 text-sm font-normal leading-tight">
|
<p className="text-slate-600 dark:text-foreground-secondary text-sm font-normal leading-tight">
|
||||||
Commit comments
|
Commit comments
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
@ -171,18 +171,18 @@ const GitTabPanel = () => {
|
|||||||
className="space-y-3"
|
className="space-y-3"
|
||||||
>
|
>
|
||||||
<ProjectSettingHeader headingText="Production branch" />
|
<ProjectSettingHeader headingText="Production branch" />
|
||||||
<p className="text-slate-600 text-sm font-normal leading-tight">
|
<p className="text-slate-600 dark:text-foreground-secondary text-sm font-normal leading-tight">
|
||||||
By default, each commit pushed to the{' '}
|
By default, each commit pushed to the{' '}
|
||||||
<span className="font-bold">{project.prodBranch}</span> branch
|
<span className="font-bold">{project.prodBranch}</span> branch
|
||||||
initiates a production deployment. You can opt for a different branch
|
initiates a production deployment. You can opt for a different branch
|
||||||
for deployment in the settings.
|
for deployment in the settings.
|
||||||
</p>
|
</p>
|
||||||
<p className="text-slate-600 text-sm font-normal leading-tight">
|
<p className="text-slate-600 dark:text-foreground-secondary text-sm font-normal leading-tight">
|
||||||
Branch name
|
Branch name
|
||||||
</p>
|
</p>
|
||||||
<Input {...registerProdBranch('prodBranch')} />
|
<Input {...registerProdBranch('prodBranch')} />
|
||||||
<Button size="md" variant="primary">
|
<Button size="md" variant="primary" shape="default">
|
||||||
Save
|
SAVE
|
||||||
</Button>
|
</Button>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
@ -191,21 +191,21 @@ const GitTabPanel = () => {
|
|||||||
className="space-y-3"
|
className="space-y-3"
|
||||||
>
|
>
|
||||||
<ProjectSettingHeader headingText="Deploy webhooks" />
|
<ProjectSettingHeader headingText="Deploy webhooks" />
|
||||||
<p className="text-slate-600 text-sm font-normal leading-tight">
|
<p className="text-slate-600 dark:text-foreground-secondary text-sm font-normal leading-tight">
|
||||||
{' '}
|
{' '}
|
||||||
Webhooks configured to trigger when there is a change in a
|
Webhooks configured to trigger when there is a change in a
|
||||||
project's build or deployment status.
|
project's build or deployment status.
|
||||||
</p>
|
</p>
|
||||||
<div className="flex gap-1">
|
<div className="flex gap-1">
|
||||||
<div className="grow">
|
<div className="grow">
|
||||||
<p className="text-slate-600 text-sm font-normal leading-tight">
|
<p className="text-slate-600 dark:text-foreground-secondary text-sm font-normal leading-tight">
|
||||||
Webhook URL
|
Webhook URL
|
||||||
</p>
|
</p>
|
||||||
<Input {...registerWebhooks('webhookUrl')} />
|
<Input {...registerWebhooks('webhookUrl')} />
|
||||||
</div>
|
</div>
|
||||||
<div className="self-end">
|
<div className="self-end">
|
||||||
<Button size="sm" type="submit">
|
<Button size="sm" type="submit" shape="default">
|
||||||
Save
|
SAVE
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -102,9 +102,10 @@ const Config = () => {
|
|||||||
className="w-fit"
|
className="w-fit"
|
||||||
onClick={handleSubmitDomain}
|
onClick={handleSubmitDomain}
|
||||||
variant="primary"
|
variant="primary"
|
||||||
|
shape="default"
|
||||||
rightIcon={<ArrowRightCircleIcon />}
|
rightIcon={<ArrowRightCircleIcon />}
|
||||||
>
|
>
|
||||||
Finish
|
FINISH
|
||||||
</Button>
|
</Button>
|
||||||
</ProjectSettingContainer>
|
</ProjectSettingContainer>
|
||||||
);
|
);
|
||||||
|
@ -33,19 +33,29 @@ const AddDomain = () => {
|
|||||||
return (
|
return (
|
||||||
<div className="p-4">
|
<div className="p-4">
|
||||||
<div className="flex justify-between">
|
<div className="flex justify-between">
|
||||||
<Typography variant="h3">Add Domain</Typography>
|
<Typography variant="h3" className="dark:text-foreground">
|
||||||
|
Add Domain
|
||||||
|
</Typography>
|
||||||
<Link to={`/${orgSlug}/projects/${id}`}>
|
<Link to={`/${orgSlug}/projects/${id}`}>
|
||||||
<IconButton className="rounded-full" variant="outlined">
|
<IconButton
|
||||||
|
className="rounded-full dark:text-foreground dark:border-foreground"
|
||||||
|
variant="outlined"
|
||||||
|
>
|
||||||
X
|
X
|
||||||
</IconButton>
|
</IconButton>
|
||||||
</Link>
|
</Link>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className=" w-2/3 mx-auto">
|
<div className=" w-2/3 mx-auto">
|
||||||
<div className="bg-blue-gray-50 rounded-lg mt-6 mb-10">
|
<div className="bg-blue-gray-50 dark:bg-overlay rounded-lg mt-6 mb-10">
|
||||||
<div className="flex justify-start gap-3 p-5">
|
<div className="flex justify-start gap-3 p-5">
|
||||||
<i className="bg-gray-100 w-12 h-12 rounded-lg">^</i>
|
<i className="bg-gray-100 dark:bg-overlay dark:text-foreground w-12 h-12 rounded-lg">
|
||||||
<Typography className="my-auto w-1/3" variant="h5">
|
^
|
||||||
|
</i>
|
||||||
|
<Typography
|
||||||
|
className="my-auto w-1/3 dark:text-foreground"
|
||||||
|
variant="h5"
|
||||||
|
>
|
||||||
Project Name
|
Project Name
|
||||||
</Typography>
|
</Typography>
|
||||||
</div>
|
</div>
|
||||||
|
@ -13,6 +13,7 @@ export default withMT({
|
|||||||
background: '#0F0F0F',
|
background: '#0F0F0F',
|
||||||
overlay: '#18181A',
|
overlay: '#18181A',
|
||||||
overlay2: '#29292E',
|
overlay2: '#29292E',
|
||||||
|
overlay3: '#48474F',
|
||||||
primary: '#0000F4',
|
primary: '#0000F4',
|
||||||
'primary-hovered': '#0000F4AA',
|
'primary-hovered': '#0000F4AA',
|
||||||
foreground: '#FBFBFB',
|
foreground: '#FBFBFB',
|
||||||
@ -30,7 +31,7 @@ export default withMT({
|
|||||||
fontFamily: {
|
fontFamily: {
|
||||||
sans: ['Inter', 'sans-serif'],
|
sans: ['Inter', 'sans-serif'],
|
||||||
display: ['Inter Display', 'sans-serif'],
|
display: ['Inter Display', 'sans-serif'],
|
||||||
mono: ['JetBrains Mono', 'monospace'],
|
mono: ['DM Mono', 'monospace'],
|
||||||
},
|
},
|
||||||
fontSize: {
|
fontSize: {
|
||||||
'2xs': '0.625rem',
|
'2xs': '0.625rem',
|
||||||
|
Loading…
Reference in New Issue
Block a user