Skip to content

Latest commit

 

History

History
133 lines (103 loc) · 6.3 KB

README.md

File metadata and controls

133 lines (103 loc) · 6.3 KB

Supergood Reads

Try it out at: reads.supergood.cloud

Read about it on: supergood.site

Table of Contents

Welcome

Finally, one review site to rule them all! Use any rating schema to review any type of media. Use rating systems from Goodreads, Letterboxd, IMDB and more to review books, movies, or your own custom media types.

This is a demo project for experimenting with Vue integrations inside of Django templates. The theory was that this could be the ultimate web framework combination -- all the simplicity and development velocity of Django matched with all of the power of a full JavaScript framework.

It did not turn out to be the ultimate web framework of my dreams. There are way too many gotchas and edge cases and complexity for me to really recommend this approach to anyone else (I'll write a more complete postmortem in the future). But the integration does work! And it might serve as inspiration for the next developer who wants to give it a shot.

Some of those fun Vue + Django integrations include:

  • Vue SFC (Single File Componets) rendered as django templates
  • Autocomplete dropdown form fields
  • Support for Generic Model Relations in Django ModelForm Views
  • Conditional Form sections
  • And of course, a datepicker

Tooling

  • Python tooling: type-checking with mypy, packaging with Poetry, linting with pre-commit, multi-environment testing with nox
  • Vitejs JavaScript tooling: TypeScript and Vue.js compilation, hot reloading, linting, bundling
  • Styling: TailwindCSS, HeadlessUI, PostCSS
  • Docker: containerization for multiple deployment environments
  • Testing: with Pytest for Django code, jest and puppeteer for browser testing

Installation

  1. Install Python
    • I recommend using pyenv to manage installations of python. Pyenv allows you to install and use multiple versions of python on the same computer.
    • After pyenv is installed, run pyenv local inside this directory to install the version of python3 specified by the .python-version file.
    • If you really don't want to use pyenv, any version of python 3.x should work fine.
  2. Install Poetry
    • Poetry is the python dependency manager that this project uses. It can be installed here.
  3. Install python packages with Poetry.
    • make install
  4. Create a .env file.
    • make .env
  5. Install Nodejs
    • I recommend using nvm to manage installations of node. nvm (node version manager) allows you to install and use multiple versions of nodejs on the same computer.
    • After nvm is installed, run nvm use inside this directory to install the version of nodejs specified by the .nvmrc file.
  6. Install Nodejs packages
    • npm install
  7. Run initial data migrations
    • poetry run python manage.py migrate
  8. Install seed data
    • poetry run python manage.py supergood_reads_load_test_data

Running Locally

Now that your dependencies have been installed, you're ready to run the app.

  1. Start the django server.
    • make up
  2. In a separate terminal window, start the nodejs server.
    • make vite
    • Note: both servers must be running simultaneously for the app to function.
  3. Navigate to http://localhost:8000/app/review to try out the form.
  4. The app is not yet complete. The only thing that is finished is the review form itself -- there isn't yet a page that renders all of the reviews you've inputted. But you can inspect the raw data:
    • make shell
    • Once inside the shell, you can look at your raw django data. Example: Review.objects.all()

Running in Docker

  1. Build docker containers for local development
  • make build-local
  1. Start docker containers
  • make docker-up

You can find more commands in the Makefile.

Development Guide

Extra Installation steps

If you want to make contributions to the project, you need to run one additional installation step.

  1. Install nox
    • pip install --upgrade nox
    • Nox is used to manage the execution of this test suite. Nox is useful for testing reuseable external libraries that require testing across multiple versions of python or django.
  2. Install pre-commit
    • https://pre-commit.com/#install to install the pre-commit program itself.
    • pre-commit install to install the pre-commit hooks for this particular project.

Useful Commands

  1. Run the python test suite.
    • make pytest
  2. Run the javascript test suite.
    • make jest
  3. Run linting for all files of the project.
    • make lint
  4. Check for vulnerabilities in external packages.
    • make safety
  5. Check for type errors in python code.
    • make mypy

Add new MediaItem types and ReviewStrategies

SupergoodReads is fully extensible and allows developers to seamlessly add new review strategies and media types.

  1. Add your classes directly to a new SupergoodReadsConfig.
  2. In your Django settings, add SUPERGOOD_READS_CONFIG=[YourSupergoodReadsConfigClass]
  3. The rest of the site will be automatically generated around your config.

(See the DefaultSupergoodReadsConfig for an example.)

Thanks

Test data was provided by these datasets: