Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jeremiasvillane/snipper
A simple URL shortener created using Next.js 14, Typescript, NextAuth, Next-Themes, NextUI, Framer Motion, Headless-UI, Prisma, PostgreSQL and Tailwind CSS.
https://github.com/jeremiasvillane/snipper
framer-motion headless-ui next-themes nextauth nextjs nextui postgresql prisma project server-actions tailwindcss typescript
Last synced: about 1 month ago
JSON representation
A simple URL shortener created using Next.js 14, Typescript, NextAuth, Next-Themes, NextUI, Framer Motion, Headless-UI, Prisma, PostgreSQL and Tailwind CSS.
- Host: GitHub
- URL: https://github.com/jeremiasvillane/snipper
- Owner: JeremiasVillane
- License: mit
- Created: 2023-10-29T18:56:23.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-03-12T22:08:26.000Z (12 months ago)
- Last Synced: 2024-05-04T00:17:48.901Z (10 months ago)
- Topics: framer-motion, headless-ui, next-themes, nextauth, nextjs, nextui, postgresql, prisma, project, server-actions, tailwindcss, typescript
- Language: TypeScript
- Homepage: https://snppr.vercel.app
- Size: 3.05 MB
- Stars: 5
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![]()
# Snipper: A simple URL shortener/tracker.
data:image/s3,"s3://crabby-images/9df7e/9df7e4a1b6b1f62a3d96a4d6387b771673c5ef62" alt="Version"
[data:image/s3,"s3://crabby-images/45597/455971d54b3358af8f25bda0777cf9e6168afb52" alt="License"](https://github.com/jeremiasvillane/snipper/blob/main/LICENSE)
[data:image/s3,"s3://crabby-images/d594e/d594e8a327552d490d7765590e71f23e825def64" alt="FOSSA Status"](https://app.fossa.com/projects/git%2Bgithub.com%2FJeremiasVillane%2Fsnipper?ref=badge_shield&issueType=license)
[data:image/s3,"s3://crabby-images/66d2a/66d2aa6f1e0afe66f640aa4ac2de0141d66555dc" alt="Prettier"](https://github.com/prettier/prettier)
data:image/s3,"s3://crabby-images/f8258/f82585d475694410e5099df29c7da65787c87d06" alt="Last commit"---
This is a [Next.js](https://nextjs.org) project implementing [TypeScript](https://www.typescriptlang.org), [NextAuth](https://next-auth.js.org), [Next-Themes](https://www.npmjs.com/package/next-themes), [NextUI](https://nextui.org), [HeadlessUI](https://headlessui.com), [Framer Motion](https://www.framer.com/motion), [Prisma](https://www.prisma.io), [PostgreSQL](https://www.postgresql.org) and [Tailwind CSS](https://tailwindcss.com).
## Features:
- Generate uniques links
- Track how many times a link has been clicked
- Redirection screen
- UI created with TailwindCSS and NextUI
- Full responsivity and mobile UI
- Light / Dark mode using next-themes
- ORM using Prisma
- PostgreSQL database using Vercel Storage
- Authentication with next-auth
- This project uses [`next/font`](https://nextjs.org/docs/basic-features/font-optimization) to automatically optimize and load Google Fonts.### Prerequisites
**Node version 20.x.x**
### Setup .env file
```js
POSTGRES_PRISMA_URL =
"postgresql://username:password@host:port/database?schema=public";
POSTGRES_URL_NON_POOLING =
"postgresql://username:password@host:port/database?schema=public";
NEXT_PUBLIC_APP_URL = "https://www.your-deploy-url.com";NEXTAUTH_SECRET = "secretkey";
NEXTAUTH_URL = "https://www.your-deploy-url.com";// Visit: https://console.cloud.google.com/apis/credentials
GOOGLE_CLIENT_ID = "your-google-client-id";
GOOGLE_CLIENT_SECRET = "your-google-client-secret";
```### Setup Prisma
Add PostgreSQL Database (I used Vercel Storage)
```shell
npx prisma generate
npx prisma db push```
### Start the app
```shell
npm run dev
```Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
## Screenshots
Show
### Landing
data:image/s3,"s3://crabby-images/e2772/e27729fd5a1a3f3c3b95b3d62733fdb5fa792c58" alt="screen01"
### Form to create a new Link
data:image/s3,"s3://crabby-images/6bb40/6bb40e2fb1a1773a43e315d49b935d0d7740d485" alt="screen02"
### Modal to copy the new link
data:image/s3,"s3://crabby-images/425b3/425b3c13bd70ddc083b2aca05f74821cad5c2551" alt="screen03"
### My Links section
data:image/s3,"s3://crabby-images/e57d1/e57d1ab45e9af3f085be8172d9d2671bfa6c4893" alt="screen04"
### Light Theme
data:image/s3,"s3://crabby-images/b17a6/b17a6064994342477251e49647e3407da1d3e28b" alt="screen05"
### Profile section
data:image/s3,"s3://crabby-images/fc18f/fc18faca2a94d3156b58e64aca4c807e8c629ed3" alt="screen06"
### About section (mobile)
data:image/s3,"s3://crabby-images/77fc6/77fc63fb4e6a839eff56018099049ac207bfbd79" alt="screen07"
## License
Distributed under the [**MIT License**](LICENSE).
[data:image/s3,"s3://crabby-images/ee34b/ee34bfc1ddfc9aa372bbe64747848fc374a30b6a" alt="FOSSA Status"](https://app.fossa.com/projects/git%2Bgithub.com%2FJeremiasVillane%2Fsnipper?ref=badge_large&issueType=license)
## Contact me
- [LinkedIn](https://snppr.vercel.app/2Vt7W2xMe)