The Mini Movie DB is a simple clone of The Movie DB built with Preact and GraphQL. It's an example application which runs inside of CodeSandbox with a back-end built to deploy to AWS Lambda.
I built The Mini Movie DB as part of a take-home coding challenge. You can use it as an example of how to build a simple Preact + GraphQL application! Have fun!
The best way to run this code is to simply open it in CodeSandbox!
There you can both see it in action and edit the code live in your browser.
If you'd like to play with the GraphQL API directly, here's a playground.
But what if I want to run this locally?
Well if you really want to do that, simply clone the repo and getting started is as easy as:
1. Install dependencies:
yarn
2. Run it!
yarn dev
That'll spin up both the api server and the front-end. As a bonus, the dev
script opens a playground for you automatically. You can reach the front-end at: http://localhost:8080/
Yeah! If you're running this locally, you'll need to get a few things for different parts to work:
- Your own api key from The Movie DB, here's the instructions. Once you have that, you'll need to create a new file at the root of the project named
serverless.env.yml
with the following key:movieDBApiKey: "<YOUR_API_KEY_HERE>"
- If you want to deploy your server, you'll need to first set up Serverless. Once your credentials are configured and you've created an IAM profile, you should be able to run the deployment commands. You'll also need to set your
apikey
environment variable inside your Lambda settings, here's a guide. - The project is set up to use Travis for continuous integration and deployment, Codecov for code coverage reporting, Greenkeeper to track dependency versions, and Snyk to protect against security vulnerabilities. Assuming you forked this repo and you want to get all of that working, you'll need to sign up for each and follow their setup instructions. I'll leave that one for you to figure out!
- Lastly if you want to use Wallaby to continually run tests as you code, you'll need to get a license and configure your editor, after that the included config should help you use that tool.
- There's some other goodies you can take advantage of in your local environment, such as ESLint and Prettier, which may require extra plugins for your editor of choice before you can use them.
And here's some other commands you can run:
yarn start
: Starts the server and the client without opening a playgroundyarn deploy:dev
: Deploys the api server to AWS to the development stageyarn deploy:prod
: Deploys the api server to AWS to the production stageyarn test
: Runs unit tests for both the server and the client
Everything here is released as-is, without support. PRs for bug fixes are appreciated, but there are no plans to maintain this project. Hope you find it useful!