Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/erikboesen/yaleartsvisualizer
Project for the class Software Engineering (CPSC439) at Yale University.
https://github.com/erikboesen/yaleartsvisualizer
Last synced: about 2 months ago
JSON representation
Project for the class Software Engineering (CPSC439) at Yale University.
- Host: GitHub
- URL: https://github.com/erikboesen/yaleartsvisualizer
- Owner: ErikBoesen
- Created: 2023-09-07T16:50:11.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-08-06T17:20:16.000Z (5 months ago)
- Last Synced: 2024-10-09T23:03:48.753Z (3 months ago)
- Language: TypeScript
- Size: 5.31 MB
- Stars: 1
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Yale Arts Map
A graph exploration of the who and what in the Yale Arts scene.
Including, but not limited to, the YDN, Performing Arts, Yale SoA, School of Arch.[Tech Stack](#tech-stack) •
[Development](#development) •
[Configuration](#configuration)## Tech Stack
Yale Arts Map is a website centered around a force-directed graph representing the relationships of productions and people on campus. Its functionality is centered around this "graph", which persists and evolves naturally across navigation. Each page thus provides information and manipulates the graph around a different filterable "view" of the scraped database.
| Stack | Tooling | Dir |
| --- | --- | --- |
| **Frontend** | Next.js 14 (TypeScript, appDir) using Jotai, SWR, and d3-force | `frontend/` |
| **Backend (Client)** | Serverless Next.js API Handlers using Prisma | `frontend/src/app/api/` |
| **Backend (Scraper)** | Serverless Python AWS Lambda functions using a shared Prisma Lambda Layer | `backend/` |
| **Database** | PlanetScale MySQL and Prisma Data Proxy for pooling serverless connections | `frontend/prisma/` |
| **Infrastructure** | All backend resources codified with Terraform | `tf/` |A preview of our interface:
## Setup
We use `pre-commit` to perform some Terraform formatting and docs generation. To
install the tools, run the following (assuming you're on Mac with homebrew):```bash
# Install depenedencies for Terraform linting / doc gen
$ brew install pre-commit terraform-docs tflint tfsec checkov terrascan infracost tfupdate minamijoyo/hcledit/hcledit jq
# Configure Terraform docs templating
$ DIR=~/.git-template
$ git config --global init.templateDir ${DIR}
$ pre-commit init-templatedir -t pre-commit ${DIR}
# Install + run pre-commit on all files
$ pre-commit install
$ pre-commit run --all-files
```Most of use use VSCode for development. A recommended list of extensions can be found in `.vscode/extensions.json`.
## Development
### Frontend
To develop locally...
```bash
# Enter the frontend
$ cd YaleArtsVisualizer/frontend/
# Install dependencies and begin the local web server
$ yarn
$ yarn dev
```> **Note**
> You will need to fill out a `.env.local` file in the `frontend/` directory as described in the [Configuration](#configuration) section to be able to connect to the development backend from your local environment. However, if you are deploying your own `sandbox` environment, the correct `.env.local` file will be auto-generated for you upon applying your Terraform plan.## Configuration
The client app expects the following environment variables to be set in order
to communicate with the backend. Their corresponding locations from the Terraform
setup have been provided, but you should replace these after being given a valid
development .env file by a member of the team.```ini
# frontend/.env.local
DATABASE_URL=
```