Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update Frontend Setup Documentation #287

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

derekvmcintire
Copy link
Contributor

@derekvmcintire derekvmcintire commented Dec 18, 2024

key changes:

  • Add a little context about what GLFS does (room for more detail here if we want)
  • Update instructions on installing nvm to use the official curl command and not an npm package
  • Update example bash commands to use node v18 as required instead of v20
  • Add scripts table with descriptions
  • Break the process into clearer steps

Pasting the markdown below so you don't have to go search for what it looks like:

H.E.A.T. Frontend Setup Documentation

This guide will help you set up the frontend application for the Home Energy
Analysis Tool (H.E.A.T.) project. Please follow these instructions carefully.


Prerequisites

Install Git Large File Storage (Git LFS)

Git LFS is required to manage large files in the repository. Choose one of the
methods below to install it:

Method 1: Using Homebrew (Recommended)

brew install git-lfs
git lfs install

Method 2: Manual Installation

  1. Download the Git LFS installer from git-lfs.com.
  2. Unzip the downloaded file and navigate to the extracted folder:
    cd ~/Downloads/git-lfs-<version>
  3. Run the installation script:
    ./install.sh
    git lfs install
  4. Confirm the installation with:
    git lfs install

For more details, visit the
official documentation.


Repository Setup

  1. Fork the repository
    Go to the
    home-energy-analysis-tool repository
    and click the "Fork" button at the top right to create your own copy of the
    repository.

  2. Clone your forked repository
    After forking, clone your fork to your local machine using the following
    command (replace your-username with your GitHub username):

    git clone [email protected]:your-username/home-energy-analysis-tool.git
  3. Navigate to the project directory
    Change into the heat-stack directory within the project:

    cd home-energy-analysis-tool/heat-stack
  4. Copy the example environment file
    Copy the example environment file into a new .env file:

    cp .env.example .env

Node.js Setup

The project requires Node.js version 18 to avoid engine errors with node v19+.
Use Node Version Manager (NVM)
for managing Node.js versions (nvm is preinstalled in coding spaces).

Install NVM (Official Method)

  1. Download and install NVM:
    curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.1/install.sh | bash
  2. Restart your terminal. Ensure NVM is installed by running:
    nvm --version
  3. Install Node.js version 18:
    nvm install 18
  4. Use Node.js version 18:
    nvm use 18

Install Dependencies and Build

  1. Install project dependencies:

    npm install
  2. Build the rules engine into the public/pyodide-env folder:

    npm run buildpy
  3. Start the development server:

    npm run dev

If you encounter errors during this process, try the following steps:

  • Delete the node_modules folder and package-lock.json file:
    rm -rf node_modules package-lock.json
  • Reinstall dependencies:
    npm install
  • Run the development server again:
    npm run dev

Setting Up in GitHub Codespaces

If using GitHub Codespaces, follow these steps:

  1. Navigate to the project directory:

    cd home-energy-analysis-tool/heat-stack
  2. Create an environment file:

    cp .env.example .env
  3. Use Node.js version 18:

    nvm use 18
  4. Install dependencies and build:

    npm install
    npm run buildpy
    npm run dev
  5. Disable auto-save in VSCode (this is to avoid auto recompiling and page
    refresh while making changes):

    • Go to File > Preferences > Settings.
    • Search for "Auto Save" and uncheck it.
    • For reference, see
      this Stack Overflow post.

Handling Special Cases

Updating Pyodide

If the version of Pyodide changes or you encounter issues with the Pyodide
environment:

  1. Copy the necessary Pyodide files:
    cp ./node_modules/pyodide/* public/pyodide-env/
  2. Ensure the correct numpy wheel file is in the public/pyodide-env folder.
    If missing:
    • Download the latest Pyodide release from
      Pyodide releases.
    • Extract the file and locate the numpy wheel file.
    • Copy it into the public/pyodide-env folder.
  3. Check the Pyodide version:
    npm list pyodide
    Ensure the numpy file matches the version.

Fixing Loader Errors

If you encounter a loader error, run:

npm run postinstall

Additional Notes

  • The npm audit fix command can resolve minor dependency issues.
  • For a clean setup, ensure sufficient disk space (at least 1GB).

Script Overview

Below is a table summarizing the available scripts in the project:

Script Description
npm run build Runs all build-related tasks.
npm run build:icons Generates icons for the project.
npm run build:remix Builds the Remix application using Vite.
npm run build:server Builds the server files.
npm run predev Prepares the environment before starting development (e.g., generates icons).
npm run dev Starts the development server.
npm run prisma:studio Launches the Prisma Studio UI for database management.
npm run format Formats the codebase using Prettier.
npm run lint Lints the codebase using ESLint.
npm run setup Runs setup tasks including building, migrations, and Playwright setup.
npm run start Starts the application in production mode.
npm run start:mocks Starts the application with mock data in production mode.
npm run test Runs unit tests and builds the Python rules engine.
npm run buildpy Builds the Python rules engine and copies it to the public/pyodide-env folder.
npm run coverage Runs tests and generates a coverage report.
npm run test:e2e Runs end-to-end tests interactively.
npm run test:e2e:run Runs end-to-end tests in CI mode.
npm run test:e2e:install Installs dependencies for Playwright end-to-end tests.
npm run typecheck Checks TypeScript types.
npm run validate Validates the project by running linting, type-checking, and testing.

Epic Stack Docs:

The Epic Stack 🚀

Ditch analysis paralysis and start shipping Epic Web apps.

This is an opinionated project starter and reference that allows teams to ship their ideas to production faster and on a more stable foundation based on the experience of Kent C. Dodds and contributors.

npx create-epic-app@latest

The Epic Stack

The Epic Stack


Watch Kent's Introduction to The Epic Stack

Epic Stack Talk slide showing Flynn Rider with knives, the text "I've been around and I've got opinions" and Kent speaking in the corner

"The Epic Stack" by Kent C. Dodds

Docs

Read the docs
(please 🙏).

Support

Branding

Want to talk about the Epic Stack in a blog post or talk? Great! Here are some
assets you can use in your material:
EpicWeb.dev/brand

Thanks

You rock 🪨

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant