We are very welcome for new developers.
We will try to give you good feedback in pull requests with explanations and guidance to learn something new.
Also, feel free to ask any questions about career and development. If you are helping us, we will try to mentor you.
- In the project, we are using English.
- Most contributors are not native speaker. Don’t be afraid of your language if you are not a native English speaker too.
- Feel free to use automatic translators. Use DeepL to write issues and the browser’s translation to read docs.
- Don’t know anything and need assistance?
- Have some unknown issue running the project server for development?
- Don’t know how to contribute?
You can ask any question to the maintainer in Telegram: @sitnik
. You can ask in English, Russian, or Spanish.
Our mentoring is a basic payback for your time and contribution to the project. Even a simple question can improve the guide for other beginners.
-
Install environment:
-
For lond-term contribution, we recommend installing Docker and Dev Container plugin to your text editor. All developers will have the same environment and the development tool will be isolated from the system in the container.
Then run the project inside that Dev Container. VS Code asks your in popup. But you can manually do it by pressing ⇧⌘P (Mac) / CtrlShiftP (Windows/Linux), selecting
Dev Containers: Open Folder in Container…
and then openingslowreader/
folder. -
You can also manually install Node.js and pnpm versions according to
.node-version
file andpackageManager
key inpackage.json
.
-
-
Then install all npm dependencies by
pnpm
:pnpm install pnpm prepare
-
Run tests to be sure that everything is OK (open issue if tests don’t work in your environment):
pnpm test
To run web clients, just call in the root of the project:
pnpm start
It will run a web server and proxy (the website, by default, can make HTTP requests only to its own servers; we need a proxy to send requests to RSS feeds on other servers).
To fill your web clients with real posts:
- Start web client.
- Open
localhost:5173/feeds/add
. - Add feeds from
loader-tests/feeds.yml
. - Open browser DevTools.
- Run
fillFeedsWithPosts()
.
To run the visual testing tool (Storybook), run it from the web/
folder:
cd web/
pnpm visual
It will show all UI components and all possible states of pages. It is the best tool to test browser compatibility or change CSS.
To work with the project, we recommend adding to your IDE or text editor:
- EditorConfig plugin to sync text editor settings. VS Code automatically takes these settings from the
.vscode/
folder. - Svelte syntax support for Web Client. Like
svelte.svelte-vscode
for VS Code.
You may also install Prettier and ESLint plugins or just use precommit
hook.
If you write docs, we recommend installing LanguageTool for grammar check. For VS Code, davidlday.languagetool-linter
.
Before any significant changes, read all README.md
to understand app architecture.
Read our checklist for pull requests. It contains things you should think about and can speed up code review a lot.
If you see that people made the same mistake several times, suggest adding a new item to the checklist to prevent repeating these mistakes.
If you are not just fixing a bug but want to join the core team, here is the path:
- Your first task is to test
pnpm test
in your environment and report issue. - Go to our Tasks plan and take next task from
Onboarding
column. IfOnboarding
is empty, you can look inReady to Take
.- Choose any task that fits the best to you. Labels can help you focus on your category.
- Write there
I want to take it
. - The task will be reserved for you for a week.
- Don’t worry if a week is not enough. Just make a draft PR.
- After the onboarding, you can take tasks from the
Ready to Take
column. See the discussions in issues to pick next one.
Feel free to ask maintainer about your next task.
We will mentor you in return for your participation, so don’t be afraid to ask questions.
We care about good commit messages. Try to think about them and describe more:
- git commit -m 'Fix issue'
+ git commit -m 'Fix <Loader> style in Safari'
In commit’s messages example why you did changes, not what you changed:
- git commit -m 'Add .editorconfig'
+ git commit -m 'Add .editorconfig to sync text editor settings'
We recommend signing your commits.
There is no any specific rules about git branch names.
Run pnpm test
before creating pull request.
Use Draft
pull request when it is not ready to review. When it will be ready press Ready for review
button.
After fixing issue mentioned in PR conversation, press Resolve conversation
button.