2024-06-14 13:36:39 +02:00
[English ](../../contributing.md )
| [Українська ](./contributing_ua.md )
| [Русский ](./contributing_ru.md )
| [Türkçe ](./contributing_tr.md )
| [Deutsch ](./contributing_de.md )
| [Français ](./contributing_fr.md )
| [Português (BR) ](./contributing_pt_br.md )
| [한국어 ](./contributing_kr.md )
| [বাংলা ](./contributing_bn.md )
| [Español ](./contributing_es.md )
| [Italiano ](./contributing_it.md )
| [Română ](./contributing_ro.md )
| **Polski**
| [简体中文 ](./contributing_cn.md )
| [正體中文 ](./contributing_zhtw.md )
| [日本語 ](./contributing_ja.md )
| [हिंदी ](./contributing_hi.md )
2023-12-01 23:15:19 +01:00
## Wspólnie uczynijmy Bruno lepszym !!
Cieszymy się, że chcesz udoskonalić Bruno. Poniżej znajdziesz wskazówki, jak rozpocząć pracę z Bruno na Twoim komputerze.
### Stos Technologiczny
Bruno jest zbudowane przy użyciu Next.js i React. Używamy również electron do stworzenia wersji desktopowej (która obsługuje lokalne kolekcje)
Biblioteki, których używamy
- CSS - Tailwind
- Edytory Kodu - Codemirror
- Zarządzanie Stanem - Redux
- Ikony - Tabler Icons
- Formularze - formik
- Walidacja Schematu - Yup
- Klient Zapytań - axios
- Obserwator Systemu Plików - chokidar
### Zależności
2024-08-22 14:43:29 +02:00
Będziesz potrzebować [Node v20.x lub najnowszej wersji LTS ](https://nodejs.org/en/ ) oraz npm 8.x. W projekcie używamy npm workspaces
2023-12-01 23:15:19 +01:00
## Rozwój
Bruno jest rozwijane jako aplikacja desktopowa. Musisz załadować aplikację, uruchamiając aplikację Next.js w jednym terminalu, a następnie uruchomić aplikację electron w innym terminalu.
### Zależności
- NodeJS v18
### Lokalny Rozwój
2024-06-14 13:36:39 +02:00
```bash
2023-12-01 23:15:19 +01:00
# użyj wersji nodejs 18
nvm use
# zainstaluj zależności
npm i --legacy-peer-deps
# zbuduj dokumentację graphql
npm run build:graphql-docs
# zbuduj zapytanie bruno
npm run build:bruno-query
# uruchom aplikację next (terminal 1)
npm run dev:web
# uruchom aplikację electron (terminal 2)
npm run dev:electron
2024-06-14 13:36:39 +02:00
```
2023-12-01 23:15:19 +01:00
### Rozwiązywanie Problemów
Możesz napotkać błąd `Unsupported platform` podczas uruchamiania `npm install` . Aby to naprawić, będziesz musiał usunąć `node_modules` i `package-lock.json` , a następnie uruchomić `npm install` . Powinno to zainstalować wszystkie niezbędne pakiety potrzebne do uruchomienia aplikacji.
```shell
# Usuń node_modules w podkatalogach
find ./ -type d -name "node_modules" -print0 | while read -d $'\0' dir; do
rm -rf "$dir"
done
# Usuń package-lock w podkatalogach
find . -type f -name "package-lock.json" -delete
2024-06-14 13:36:39 +02:00
```
2023-12-01 23:15:19 +01:00
### Testowanie
```bash
# bruno-schema
npm test --workspace=packages/bruno-schema
# bruno-lang
npm test --workspace=packages/bruno-lang
```
### Tworzenie Pull Request
- Prosimy, aby PR były małe i skoncentrowane na jednej rzeczy
- Prosimy przestrzegać formatu tworzenia gałęzi
- feature/[nazwa funkcji]: Ta gałąź powinna zawierać zmiany dotyczące konkretnej funkcji
- Przykład: feature/dark-mode
- bugfix/[nazwa błędu]: Ta gałąź powinna zawierać tylko poprawki dla konkretnego błędu
- Przykład bugfix/bug-1