We currently have several ways of running a local development setup. If you get stuck please create a new discussion and we'll try to help you with the setup.
Each option supports different features:
TypeScript compilation 🔨
At a minimum, all of the options will transpile and serve the Grapher code, which can be viewed with Storybook for testing in a browser. This should be enough for simple bug fixes but a bit basic for more complex development.
Grapher Admin UI 🚜
This needs a working MySQL database and gives you an interactive admin UI for visually editing our charts as well as all our ~4000 charts and their data.
Full WordPress setup 🚀
This version needs a copy of our wordpress content that is currently only available for Our World In Data team members. With this you can test all parts of the publishing flow including site baking, full page previews for all content etc.
In increasing order of sophistication:
Visual Studio Code development containers (🚜.)
This uses Visual Studio Code with the remote containers extension and the Docker runtime installed. Everything else is automated to happen inside Docker containers so while you are developing locally, you do not have to install Node.js, MySQL, WordPress or any other dependencies on your main operating system. This also makes this setup easy to run on Windows if you are not familiar with using the Windows Subsystem for Linux.
Here you don't need Docker and you just set up node and yarn. This only gives you Typescript compilation, but there is no further overhead for your system.
Local setup with MySQL and Grapher admin (🚜)
Uses Docker to run the MySQL database alongside a local setup without MySQL. This setup the one used by a lot of the OWID staff and is recommended for bigger changes to Grapher.
This setup requires a WordPress database dump which is only available for OWID team members. As the name implies this gives you the full wordpress setup and allows work on all parts of our site publishing locally.
GitPod (🚜.)
This is a contributed web-based setup that needs no local tools whatsoever, just a web browser pointed at GitPod. This is an easy way to get started, but it is not actively maintained by the OWID team so it might not be working as well as the other options. This method takes around 30 minutes to initialize.