Skip to content

digitalaidseattle/seattle-humane-app

Repository files navigation

Digital Aid Seattle/Seattle Humane Website

GitHub commit activity (main)

Introduction

Digital Aid Seattle aims to amplify community impact with technology by connecting organizations who need technical solutions with skilled volunteers.

People across thousands of Seattle civic and nonprofit organizations have dedicated their lives to making the world safer, more equitable, and more sustainable. This work is responsible for so much good in the world, and we owe them a huge debt of gratitude.

Unfortunately, many of these organizations lack access to digital tools that are vital to success in the modern age. Nonprofits struggle to create and scale their impact without the resources they need.

Just outside their doors is a fleet of experts and technologists with the talent, capacity, and drive to build.

Seattle is world-renowned as a hub for technology talent, full of motivated builders, designers, and creators that want to use their skills for good. Digital Aid Seattle is bringing these communities together to create a sum greater than its parts.

This website is for organizations that want to learn more about partnering with Digital Aid Seattle and for passionate, skilled Seattlites who want to learn more about volunteering!

Technology Stack

The website is built using Next.js, a React-based framework for server-side rendering and static site generation. Learn more about Next.js here.

Vercel is used for deployment, providing a fast and scalable hosting environment for the website. Once a pull request is made, Vercel will automatically deploy a staged version of the website for final approval prior to deploying these changes to the public-facing website. Learn more about Vercel here.

Supabase is used for Postgres database services and authentication with Google and Azure accounts via OAuth.

System Requirements

Install:

  1. Git
  2. Node.js
  3. Yarn

Or, use VS Code Dev Containers to make the installation easy!

  1. Dev Containers

Local Environment Setup

Setup NextJS Application

  1. Go in the folder you want the project to exist, run:

    git clone https://github.com/openseattle/seattle-humane-app
  2. Open VS code.

  3. (Optional but recommended!) From VS code, open the command palette using ⇧⌘P on Mac or Ctrl+Shift+P on Windows and type:

    Dev Containers: Open Folder in Container...
    

    Note: For more information check out: https://code.visualstudio.com/docs/devcontainers/containers

  4. Open a shell and install dependecies by running:

    yarn install

Setup Environment Variables

This setup uses a shared cloud Supabase database for simplicity.

  1. Run the command:
    cp .env.local.example .env.local
  2. Request the NEXT_PUBLIC_SUPABASE_URL and NEXT_PUBLIC_SUPABASE_ANON_KEY from the team or go to settings > api from the Supabase Dashboard tp get them yourself. Other variables in .env.local can be ignored for now.

Run the application

  1. Run the command in your terminal from the project directory:
   yarn dev

Testing

  • To run all tests: yarn test.
  • To exclude tests while running your own, you may temporarily put 'x' in front of 'describe' or 'it'. However, DO NOT exclude tests on a PR to a sprint branch.

Setup Application with Local Database (Optional)

This section is only needed if you want to isolate your database and not use a shared environment.

Configure Environmental Variables

Local setup requires a few one-time steps. In the following steps, you will start Supabase locally and put values from Supabase into your .env.local file.

  1. Like before, create a copy of .env.local.example:

    cp .env.local.example .env.local
  2. Open the .env.local file in VSCode. You will need to put values in this file after the next step, so keep it open.

  3. Start Supabase locally. Open a local terminal window from the seattle-humane-app folder and run:

    npx supabase start

    Enter "y" when/if asked to install the Supabase package.

    Give it a moment to spin up the containers. When it's finished, it will display URLs and keys that need to go into your local environment file.

    Put the API URL after NEXT_PUBLIC_SUPABASE_URL= variable and the anon key after the NEXT_PUBLIC_SUPABASE_ANON_KEY= variable in the .env.local file. Double-check you copied the value correctly then save the file.

    (These steps are derived from the Original Supabase instructions here)

    Note: If you have existing Supabase containers running, you may need to run supabase stop --no-backup to reset your environment. Careful, this will delete anything saved in your local database.

  4. Run supabase stop to close Supabase when you are done.

Configure OAuth Environment Variables

  1. If you need to use OAuth, be sure to follow the steps listed in .env.local.example to set the OAuth variables. Once the variables are set, run:
    supabase stop # You need to stop Supabase execution so that the new configuration changes will be picked up.
    source .env.local
    supabase start

Running the application and backend locally (optional still)

Run the frontend

  1. Open a shell inside the docker container (default option when opening shells with Dev Container).

  2. Load the values from the env file into the environment by running:

      source .env.local
  3. Start development server

    yarn dev
  4. Open local instance in browser: http://localhost:3000.

  5. Use Ctrl+C to stop the server when you are done.

Generate lots of fake data (optional)

  1. Open a local terminal window from the seattle-humane-app folder and run:

    npm run gen-seed-data

    This will overwrite supabase/seed.sql and supabase will use the generated data when starting up.

  2. If you've already started supabase, first you have to stop it and clear the data by running

    npx supabase stop --no-backup

    Then Run Supabase

Run Supabase

  1. Open a local terminal window from the seattle-humane-app folder.

  2. Run supabase start. If Supabase is already running, you can stop it by running supabase stop first.

  3. Run supabase stop when you are done.

Manually updating Supabase types

  • To login to supabase: npx supabase login.
  • To update type file: npx supabase gen types typescript --project-id "liuebfxbxugpfsfwbkks" --schema public > supabase/database.types.ts