Proof of concept, macOS menubar app & site for storing and sharing interesting finds from the Internet.
Clips is a Next.js app deployed on Vercel. It's sitting on top of a MongoDB instance, uses swr for data fetching and caching, emotion for styling, and basic cookie authentication under the hood. The menubar repository can be found here. More details about the project can be found on this post.
I enjoy building things – tinkering with new technologies, dabbling with design, and making things from ideation to launch. Clips is another culmination of my curiosity and the project that I've been experimenting with over the past few months. Clips is completely open – feel free to play with the hosted version on getclips.app or run your own instance/learn/build on top of it.
Clips is sitting on top of a MongoDB instance, uses reCAPTCHA, S3 for hosting images, and Sendgrid for emails. You'll want to grab the relevant keys for these services. The great thing is we can run this all for free!
Postel uses yarn
to manage dependencies – let's get started:
-
First we'll want to clone the repo – run
git clone [email protected]:timc1/clips.git
-
Update
.env.example
to.env.local
. This is where we'll store all keys for development. -
Setup a MongoDB account and DB here. Follow the instructions to create a new collection and grab the uri to connect to the database. Copy the uri into the
MONGO_URI
portion of the.env
. -
Setup a Sendgrid account here. Follow the instructions to send basic emails and copy the api key in
SENDGRID_API_KEY
-
Setup an IAM user with S3 access on your AWS account, and copy the access key id & secret access key in the
.env
as well. Setup 2 buckets and update these constants to reflect them. -
Setup reCAPTCHA here and copy the key into
.env
. -
Set a password for your session cookie – read more about it here.
-
Add a uuid to the JWT key.
Okay phew, done!
Run yarn install
to download dependencies.
Then yarn start
to get your local server running.
Since we're deploying on Vercel, make sure to edit the contents of now.json
with your own unique keys. Using the Vercel CLI you can just run vercel secrets add mongo-uri <KEY_HERE>
for each of the keys.
TODO – should've built tests incrementally but here we are. react-testing-library
would be rad.
Got questions? Feel free to email me [email protected] or shoot me a DM @timcchang!