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 { 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
|
|
|
}) {
|
2024-10-21 13:57:45 -06:00
|
|
|
const { deploy } = useTerminal()
|
|
|
|
const [isDeploying, setIsDeploying] = useState(false)
|
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)
|
|
|
|
})
|
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>
|
|
|
|
<Button variant="outline">
|
|
|
|
<Globe className="w-4 h-4 mr-2" />
|
|
|
|
Deploy
|
|
|
|
</Button>
|
|
|
|
</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 1h ago"
|
|
|
|
user={userData.name}
|
|
|
|
/>
|
|
|
|
</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..." : "Update"}
|
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,
|
|
|
|
}: {
|
|
|
|
icon: React.ReactNode
|
|
|
|
domain: string
|
|
|
|
timestamp: string
|
|
|
|
user: string
|
|
|
|
}) {
|
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>
|
|
|
|
<a
|
|
|
|
href={`https://${domain}`}
|
|
|
|
target="_blank"
|
|
|
|
rel="noopener noreferrer"
|
|
|
|
className="font-semibold text-gray-300 hover:underline"
|
|
|
|
>
|
|
|
|
{domain}
|
|
|
|
</a>
|
|
|
|
</div>
|
2024-10-21 13:57:45 -06:00
|
|
|
<p className="text-sm text-gray-400 mt-0 ml-7">
|
|
|
|
{timestamp} • {user}
|
|
|
|
</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
|
|
|
}
|