baseui/README.md
2018-11-01 12:10:29 +01:00

112 lines
2.9 KiB
Markdown

![build status](https://ci.drone1.basehosts.de/api/badges/panel/baseui/status.svg)
# basispanel UI
## Entwicklungsprozess
### Allgemeines
- auf Branch `master` dürfen nur Anton und Sebastian pushen
- Branch `matdev` ist für Mathias
- Anton und Sebastian mergen regelmäßig zu `matdev`, damit Mathias möglichst neue Komponenten auf dem aktuellen Stand einbaut
- nachdem in `matdev` neue vue-Komponenten angelegt wurden, welche bis dahin nur HTML und CSS enthalten, mergen Anton oder Sebastian `matdev` auf `master` um Logik einzubauen
### Linux
```bash
# falls nicht bereits vorhanden
git clone ssh://git@gitbase.de:2222/panel/baseui.git
cd baseui
# die Branch auschecken, für die man verantwortlich ist
git checkout matdev # z.B. für Mathias
# Änderungen vom Server holen, fall nicht gerade geklont wurde
git pull
# fehlende Module installieren
npm install
# entwickeln und gleichzeitig webpack laufen lassen
npm run dev
# oder für eingebauten Server mit Hot-Reload
npm run serve
```
### Windows
- z.B. SourceTree für GIT
- Repository `ssh://git@gitbase.de:2222/panel/baseui.git` clonen
- Branch wechseln (`matdev` für Mathias)
- Konsole (cmd oder PowerShell) aufrufen
- ins Verzeichnis ..../basispanel-ui wechseln
```powershell
# fehlende Module installieren (falls im Windows Probleme auftauchen [z.B. Permission denied], node_modules/ Verzeichnis löschen und nochmal probieren)
npm install
# entwickeln und gleichzeitig webpack laufen lassen
npm run win-dev
# oder für eingebauten Server mit Hot-Reload
npm run win-serve
```
## Änderungen hochladen
### Linux
```bash
# eigene Änderungen commiten
git commit -m "Commit Nachricht"
# Commits zum Server pushen
git push
```
### Windows
- Commiten und Pushen wie gewohnt
## Aufbau des Repos
- `assets` = für Bilder und sonstige "statische" Dateien
- `conf` = Konfiguration der UI für jeweiligen Einsatz
- `src` = sämtlicher Quellcode zur UI
- `src/components` = Vue-Komponenten, die allgemein für die UI gültig sind
- `src/fonts` = Icon-Fonts
- `src/views` = Vue-Komponenten, die für den speziellen Einsatz entwickelt werden, z.B. spezielle Listen, Forms, ... (dieses Verzeichnis wird nach später aus dem Repo entfernt, um die UI allgeimengültig zu halten)
## Build-Prozess
- wird auf Drone-Server durch `.drone.yml` automatisch erledigt
```bash
# Module installieren (erzeugt node_modules/)
npm install
# bundle bauen
npm run build
```
- nach erfolgreichem Build sind folgende Verzeichnisse und Datein für das Produktiv-System bestimmt:
- assets/
- build/
- conf/
- index.html
## Deployment
- in `.gitlab.yml` ist der Deploy für alle Branches auf "http://ui.basispanel.de/" eingerichtet
- master: http://ui.basispanel.de/master/
- matdev: http://ui.basispanel.de/matdev/
## bei Problemen
- wenn `git pull` oder `git push` mal nicht klappt wegen gleichzeitiger Änderungen auf dem Server und lokal --> Jemanden anrufen, der Ahnung hat oder GIT-Tutorials lesen ;)