Skip to content

MuckRock/documentcloud-frontend

Folders and files

NameName
Last commit message
Last commit date
Feb 20, 2024
Mar 1, 2024
Jan 9, 2024
Nov 13, 2023
Apr 1, 2024
Jan 24, 2024
Feb 1, 2024
Jan 9, 2024
May 26, 2023
Feb 1, 2024
Aug 23, 2023
Feb 14, 2024
Dec 12, 2023
Mar 17, 2023
Jan 18, 2024
Jan 19, 2024
Feb 23, 2024
Feb 23, 2024
Feb 9, 2024
Mar 11, 2021
Jan 18, 2024
Feb 2, 2024
Jan 24, 2024
Mar 28, 2024
Mar 28, 2024
Nov 17, 2023
Nov 8, 2023
Mar 21, 2024
Feb 28, 2024
Feb 23, 2024
Feb 28, 2024
Feb 28, 2024
Nov 13, 2023
Jan 18, 2024
Nov 8, 2023
Nov 8, 2023

Repository files navigation

DocumentCloud frontend

DocumentCloud Frontend · Squarelet · MuckRock · DocumentCloud

The main frontend for DocumentCloud, written in Svelte.

Usage

This project depends on both Squarelet and the DocumentCloud (Django). Follow the steps in their READMEs before setting up this project.

This project is a Svelte + Webpack project wrapped in Docker compose.

In order to install dependencies inside the Docker container, run:

make install

Once the node modules have been installed, start the app with:

make dev

Warning: Don't just run docker compose up like you would with some of the other repos. The containers listed in local.yml aren't intended to be run simultaneously.

Set up your hosts:

echo "127.0.0.1 www.dev.documentcloud.org" | sudo tee -a /etc/hosts

Once everything is up and running, you should be able to see the website live at www.dev.documentcloud.org. Note the frontend is not yet functional.

Building for production

Run make build to build the production version of the app. The project will be output in the public directory.

Architecture

See the Wiki for information on the DocumentCloud architecture.

Browser support

DocumentCloud is tested and runs on recent versions of modern browsers -- Chrome, FireFox, Safari and Microsoft Edge. Older versions of those browsers will likely work, too, but we can't guarantee a bug-free experience on versions from more than a year ago, or on browsers that no longer receive updates, such as Internet Explorer.

Developing

Installing new packages

Run the relevant npm install ... command and then get the change mirrored on the Docker image by running make install.

Unit tests

Run unit tests with npm test.

Browser tests

All of the browser test commands depend on the front end running, so start the app with make dev and start the backend and Squarelet as well.

Running tests locally

Run npm run test:browser in another terminal. This will run Playwright using Chromium and Firefox.

Development

The functional tests are organized like this:

tests
├── README.md
├── anonymous
│   ├── manager
│   │   └── app.spec.js
│   ├── pages
│   │   └── home.spec.js
│   └── viewer
│       └── document.spec.js
└── fixtures
    ├── Small pdf.pdf
    ├── development.json
    ├── production.json
    ├── staging.json
    └── the-nature-of-the-firm-CPEC11.pdf

Tests are organized around major parts of the codebase -- manager, pages and viewer. Tests under anonymous don't use an authenticated user.

Tests rely on specific docouments available in each environment, which will have different URLs, so lists of known documents are provided in development.json, staging.json and production.json. Those correspond to the NODE_ENV environment variable.

Storybooks

Storybooks are used to create isolated environments for developing, testing and demonstrating the Svelte components that compose the user interface.

Storybooks run locally to your machine, not in the Docker container.

To run the Storybook dev server:

npm run storybook

To set and manage your Node version, you can use NVM:

node -v
nvm install 16
# or
nvm install --lts

Thanks

Chromatic

Thanks to Chromatic for providing the visual testing platform that helps us review UI changes and catch visual regressions.