👍🎉 Thank you for checking out the project and wanting to contribute! 🎉👍
The following document is a (work in progress) guide for contributing to Solid Developer Tools. It is a work in progress, so please feel free to suggest changes and improvements. If you have any questions, please feel free to ask on the Solid Discord. (We have a #solid-devtools channel there)
[pnpm
](https://pnpm.io/ and eslint
— that's it.
This project uses pnpm for package management. If you don't have it installed, you can install it with npm install -g pnpm
.
If this is your first time pulling the repository onto a local branch, then run pnpm install
to install all the dependencies and pnpm build
to build all the packages — this is important because all of the packages are linked together, using the pnpm
workspace feature. If you don't do this, you will get errors when trying to run the project.
You should reinstall the dependencies and rebuild the packages whenever you pull from the main branch. This is because the dependencies and packages may have changed. If you experience any issues, try removing the node_modules
folder (rm -Force -Recurse .\node_modules\
or rm -rf node_modules/
) and repeating the steps above.
The code is formatted with prettier. You can use it if you want, or not, it's up to you because the code get's formatted automatically by a github action. If you want to use it, you can run pnpm format
to format the code.
If you want to run the E2E tests, you need to install the dependencies by running pnpm exec playwright install --with-deps chromium
(or npx playwright install --with-deps chromium
), then run pnpm test:e2e
.
I'm working on a linux machine right now, but everything should be wokking the same way regardless of OS. Please make an issue if it's not.
Alternatively, if something is off, I recommend using Gitpod or Codeflow for development. Both of them are free for oss projects like this one and will give you a stable development environment.
Here is a list of the commands you can run in the project:
pnpm dev:ext
— Run the extension in development mode.
Important if you want to work on the chrome extension. (The script may fail sometimes after changes, so keep an eye on the console, and restart it if neccessary)
Builds all of the client packages in the watch mode. Those are the packages that run in the users browser. (client, shared, locator, debugger, frontend, overlay)
pnpm dev:sandbox
— Opens the sandbox playground with overlay component
pnpm dev:sandbox:ext
— Opens the sandbox playground with extension client
Watchout, build-test
may freeze your computer a bit :)
When you make a PR, the CI will run all of these commands, so you don't have to worry about it.
This project uses changesets to manage package versions. If you want to make a change to a package, you can run pnpm changeset
and it will guide you through the process.
-
Run
pnpm dev:ext
to start the extension in development mode -
Open the chrome://extensions page
-
Enable the developer mode
- Click on the "Load unpacked" button and select the
extension/dist/chrome
directory (orextension/dist/firefox
if you are using firefox)
- The extendion is now loaded and ready to go! Now run open any page with Solid and you should be able to open the devtools.