Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added public/png-svg.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added public/rounding-tool.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added public/square-tool.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
4 changes: 3 additions & 1 deletion src/app/(tools)/svg-to-png/svg-tool.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,9 @@ function SVGToolCore(props: { fileUploaderProps: FileUploaderResult }) {
);

// Get the actual numeric scale value
const effectiveScale = scale === "custom" ? customScale : scale;
const effectiveScale = scale === "custom"
? (customScale === 0 ? 1 : customScale) // Revert to 1 if custom scale is 0
: scale;

if (!imageMetadata)
return (
Expand Down
68 changes: 57 additions & 11 deletions src/app/page.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,35 @@
import Link from "next/link";
import Image from "next/image";

const tools = [
{
href: "/svg-to-png",
title: "SVG to PNG Converter",
description: "Convert and scale SVG files to high-quality PNG images",
image: "/png-svg.jpg",
placeholderColor: "bg-blue-500",
},
{
href: "/square-image",
title: "Square Image Generator",
description: "Transform any image into a perfect square without distortion",
image: "/square-tool.jpg",
placeholderColor: "bg-purple-500",
},
{
href: "/rounded-border",
title: "Corner Rounder",
description: "Add smooth rounded corners to your images with ease",
image: "/rounding-tool.jpg",
placeholderColor: "bg-green-500",
},
];

export default function Home() {
return (
<div className="flex min-h-screen flex-col justify-between p-8 font-[family-name:var(--font-geist-sans)] sm:p-20">
<main className="flex flex-grow flex-col items-center justify-center">
<div>
<div className="mb-12 text-center">
Hi. I&apos;m{" "}
<a
href="https://twitter.com/t3dotgg"
Expand All @@ -16,17 +41,38 @@ export default function Home() {
</a>
. I built these tools because I was annoyed they did not exist.
</div>
<div className="mt-4"></div>
<Link href="/svg-to-png" className="text-blue-500 hover:underline">
SVG to PNG converter
</Link>
<Link href="/square-image" className="text-blue-500 hover:underline">
Square image generator
</Link>
<Link href="/rounded-border" className="text-blue-500 hover:underline">
Corner Rounder
</Link>

<div className="grid grid-cols-1 gap-6 sm:grid-cols-2 lg:grid-cols-3">
{tools.map((tool) => (
<Link
key={tool.href}
href={tool.href}
className="group flex flex-col hover:scale-[1.02] rounded-lg border border-gray-200 bg-white/10 p-6 shadow-sm transition-all hover:shadow-md dark:border-gray-800 dark:bg-white/10"
>
<div className="mb-4 aspect-square w-full overflow-hidden rounded-lg">
{tool.image ? (
<Image
src={tool.image}
alt={tool.title}
width={250}
height={250}
className="h-full w-full object-cover"
/>
) : (
<div className={`h-full w-full ${tool.placeholderColor}`} />
)}
</div>
<h2 className="mb-2 text-xl font-semibold text-gray-900 dark:text-white">
{tool.title}
</h2>
<p className="text-sm text-gray-600 dark:text-gray-400">
{tool.description}
</p>
</Link>
))}
</div>
</main>

<footer className="mt-8 text-center text-sm text-gray-500">
<a
href="https://github.com/t3dotgg/quickpic"
Expand Down
Loading