| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | "use client" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { Button } from "@/components/ui/button" | 
					
						
							|  |  |  | import { Dialog, DialogContent, DialogHeader, DialogTitle, DialogTrigger } from "@/components/ui/dialog" | 
					
						
							|  |  |  | import { REPO_PATH } from "@/constants" | 
					
						
							|  |  |  | import { DialogDescription } from "@radix-ui/react-dialog" | 
					
						
							|  |  |  | import { ExternalLink, PlusCircle } from "lucide-react" | 
					
						
							|  |  |  | import Link from "next/link" | 
					
						
							|  |  |  | import { useState } from "react" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const ISSUE_TEMPLATES = [ | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		id: "add_monochrome_icon", | 
					
						
							|  |  |  | 		name: "Add light & dark icon", | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 		description: "Submit a new icon with both light and dark versions for optimal theme compatibility.", | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 		url: `${REPO_PATH}/issues/new?template=add_monochrome_icon.yml`, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		id: "add_normal_icon", | 
					
						
							|  |  |  | 		name: "Add normal icon", | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 		description: "Submit a new icon that works well across both light and dark themes.", | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 		url: `${REPO_PATH}/issues/new?template=add_normal_icon.yml`, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		id: "update_monochrome_icon", | 
					
						
							|  |  |  | 		name: "Update light & dark icon", | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 		description: "Improve an existing icon by updating both light and dark versions.", | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 		url: `${REPO_PATH}/issues/new?template=update_monochrome_icon.yml`, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		id: "update_normal_icon", | 
					
						
							|  |  |  | 		name: "Update normal icon", | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 		description: "Improve an existing icon that works across both light and dark themes.", | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 		url: `${REPO_PATH}/issues/new?template=update_normal_icon.yml`, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		id: "blank_issue", | 
					
						
							|  |  |  | 		name: "Something else", | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 		description: "Create a custom issue for other suggestions, bug reports, or improvements.", | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 		url: `${REPO_PATH}/issues/new?template=BLANK_ISSUE`, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | ] | 
					
						
							|  |  |  | export function IconSubmissionContent({ onClose }: { onClose?: () => void }) { | 
					
						
							|  |  |  | 	return ( | 
					
						
							|  |  |  | 		<div className="flex flex-col gap-4"> | 
					
						
							|  |  |  | 			<div className="flex flex-col gap-2"> | 
					
						
							|  |  |  | 				{ISSUE_TEMPLATES.map((template) => ( | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 					<Link key={template.id} href={template.url} className="w-full group" target="_blank" rel="noopener noreferrer"> | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 						<Button | 
					
						
							|  |  |  | 							key={template.id} | 
					
						
							|  |  |  | 							variant="outline" | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 							className="w-full flex flex-col items-start gap-1 h-auto p-4 text-left cursor-pointer hover:bg-rose-500/10 dark:hover:bg-rose-900/30 hover:border-rose-500 dark:hover:border-rose-500 transition-all duration-300" | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 						> | 
					
						
							|  |  |  | 							<div className="flex w-full items-center justify-between"> | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 								<span className="font-medium group-hover:text-rose-500 transition-all duration-300">{template.name}</span> | 
					
						
							|  |  |  | 								<ExternalLink className="h-4 w-4 text-muted-foreground group-hover:text-rose-500 transition-all duration-300" /> | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 							</div> | 
					
						
							|  |  |  | 							<span className="text-xs text-muted-foreground">{template.description}</span> | 
					
						
							|  |  |  | 						</Button> | 
					
						
							|  |  |  | 					</Link> | 
					
						
							|  |  |  | 				))} | 
					
						
							|  |  |  | 			</div> | 
					
						
							|  |  |  | 		</div> | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | export function IconSubmissionForm() { | 
					
						
							|  |  |  | 	const [open, setOpen] = useState(false) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return ( | 
					
						
							|  |  |  | 		<Dialog open={open} onOpenChange={setOpen}> | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 			<DialogTrigger asChild> | 
					
						
							|  |  |  | 				<Button | 
					
						
							|  |  |  | 					variant="outline" | 
					
						
							|  |  |  | 					className="hidden md:inline-flex cursor-pointer hover:bg-rose-500/10 dark:hover:bg-rose-900/30 hover:border-rose-500 dark:hover:border-rose-500 transition-all duration-300" | 
					
						
							|  |  |  | 				> | 
					
						
							|  |  |  | 					<PlusCircle className="h-4 w-4 transition-all duration-300" /> Contribute new icon | 
					
						
							|  |  |  | 				</Button> | 
					
						
							|  |  |  | 			</DialogTrigger> | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 			<DialogContent className="md:max-w-4xl backdrop-blur-2xl"> | 
					
						
							|  |  |  | 				<DialogHeader> | 
					
						
							| 
									
										
										
										
											2025-04-17 07:21:19 +02:00
										 |  |  | 					<DialogTitle>Contribute a new icon</DialogTitle> | 
					
						
							|  |  |  | 					<DialogDescription>Choose a template below to suggest a new icon or improve an existing one.</DialogDescription> | 
					
						
							| 
									
										
										
										
											2025-04-16 16:18:20 +02:00
										 |  |  | 				</DialogHeader> | 
					
						
							|  |  |  | 				<div className="mt-4"> | 
					
						
							|  |  |  | 					<IconSubmissionContent onClose={() => setOpen(false)} /> | 
					
						
							|  |  |  | 				</div> | 
					
						
							|  |  |  | 			</DialogContent> | 
					
						
							|  |  |  | 		</Dialog> | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | } |