125 lines
3.4 KiB
TypeScript
Raw Normal View History

2024-10-21 13:57:45 -06:00
"use client"
2024-07-23 17:30:49 -04:00
2024-10-21 13:57:45 -06:00
import { Button } from "@/components/ui/button"
import {
Popover,
PopoverContent,
PopoverTrigger,
} from "@/components/ui/popover"
import { useTerminal } from "@/context/TerminalContext"
import { Sandbox, User } from "@/lib/types"
import { Globe } from "lucide-react"
import { useEffect, useState } from "react"
2024-07-23 17:30:49 -04:00
2024-08-17 23:08:11 -04:00
export default function DeployButtonModal({
userData,
data,
}: {
2024-10-21 13:57:45 -06:00
userData: User
data: Sandbox
2024-08-17 23:08:11 -04:00
}) {
const { deploy, getAppExists } = useTerminal()
2024-10-21 13:57:45 -06:00
const [isDeploying, setIsDeploying] = useState(false)
const [isDeployed, setIsDeployed] = useState(false)
const [deployButtonVisible, setDeployButtonEnabled] = useState(false)
useEffect(() => {
const checkDeployment = async () => {
if (getAppExists) {
const exists = await getAppExists(data.id)
setDeployButtonEnabled(exists.success)
setIsDeployed((exists.success && exists.exists) ?? false)
}
}
checkDeployment()
}, [data.id, getAppExists])
2024-07-23 17:30:49 -04:00
const handleDeploy = () => {
if (isDeploying) {
2024-10-21 13:57:45 -06:00
console.log("Stopping deployment...")
setIsDeploying(false)
2024-07-23 17:30:49 -04:00
} else {
2024-10-21 13:57:45 -06:00
console.log("Starting deployment...")
setIsDeploying(true)
2024-08-18 07:16:59 -07:00
deploy(() => {
2024-10-21 13:57:45 -06:00
setIsDeploying(false)
setIsDeployed(true)
2024-10-21 13:57:45 -06:00
})
2024-07-23 17:30:49 -04:00
}
2024-10-21 13:57:45 -06:00
}
2024-07-23 17:30:49 -04:00
return (
<>
2024-08-17 23:08:11 -04:00
<Popover>
<PopoverTrigger asChild>
{deployButtonVisible && (
<Button variant="outline">
<Globe className="w-4 h-4 mr-2" />
Deploy
</Button>
)}
2024-08-17 23:08:11 -04:00
</PopoverTrigger>
2024-10-21 13:57:45 -06:00
<PopoverContent
className="p-4 w-full max-w-xs sm:max-w-sm md:max-w-md lg:max-w-lg xl:max-w-xl rounded-lg shadow-lg"
style={{ backgroundColor: "rgb(10,10,10)", color: "white" }}
>
2024-08-17 23:08:11 -04:00
<h3 className="font-semibold text-gray-300 mb-2">Domains</h3>
<div className="flex flex-col gap-4">
<DeploymentOption
icon={<Globe className="text-gray-500 w-5 h-5" />}
domain={`${data.id}.gitwit.app`}
timestamp="Deployed 1m ago"
2024-08-17 23:08:11 -04:00
user={userData.name}
isDeployed={isDeployed}
2024-08-17 23:08:11 -04:00
/>
</div>
2024-10-21 13:57:45 -06:00
<Button
variant="outline"
className="mt-4 w-full bg-[#0a0a0a] text-white hover:bg-[#262626]"
onClick={handleDeploy}
>
{isDeploying ? "Deploying..." : isDeployed ? "Update" : "Deploy"}
2024-08-17 23:08:11 -04:00
</Button>
</PopoverContent>
</Popover>
2024-07-23 17:30:49 -04:00
</>
2024-10-21 13:57:45 -06:00
)
2024-08-17 23:08:11 -04:00
}
2024-10-21 13:57:45 -06:00
function DeploymentOption({
icon,
domain,
timestamp,
user,
isDeployed,
2024-10-21 13:57:45 -06:00
}: {
icon: React.ReactNode
domain: string
timestamp: string
user: string
isDeployed: boolean
2024-10-21 13:57:45 -06:00
}) {
2024-08-17 23:08:11 -04:00
return (
<div className="flex flex-col gap-2 w-full text-left p-2 rounded-md border border-gray-700 bg-gray-900">
<div className="flex items-start gap-2 relative">
<div className="flex-shrink-0">{icon}</div>
{isDeployed ? (
<a
href={`https://${domain}`}
target="_blank"
rel="noopener noreferrer"
className="font-semibold text-gray-300 hover:underline"
>
{domain}
</a>
) : (
<span className="font-semibold text-gray-300">{domain}</span>
)}
2024-08-17 23:08:11 -04:00
</div>
2024-10-21 13:57:45 -06:00
<p className="text-sm text-gray-400 mt-0 ml-7">
{isDeployed ? `${timestamp}${user}` : "Never deployed"}
2024-10-21 13:57:45 -06:00
</p>
2024-08-17 23:08:11 -04:00
</div>
2024-10-21 13:57:45 -06:00
)
2024-08-17 23:08:11 -04:00
}