docs(standards): zentrale Anleitung zur automatisierten Versionierung hinzugefügt
- beschreibt das Versionskonzept für package.json, package-lock.json und .env.* - erklärt die Verwendung von bumpVersion.js und Husky-Hooks - hilft neuen und bestehenden Entwicklern, konsistent zu arbeiten - gilt als Standardrichtlinie für zukünftige Projekte
This commit is contained in:
@@ -25,4 +25,4 @@ NEXT_PUBLIC_USE_MOCKS=true
|
|||||||
NEXT_PUBLIC_BASE_PATH=/talas5
|
NEXT_PUBLIC_BASE_PATH=/talas5
|
||||||
# Oder leer lassen für direkten Zugriff -> NEXT_PUBLIC_BASE_PATH=
|
# Oder leer lassen für direkten Zugriff -> NEXT_PUBLIC_BASE_PATH=
|
||||||
# App-Versionsnummer
|
# App-Versionsnummer
|
||||||
NEXT_PUBLIC_APP_VERSION=1.1.271
|
NEXT_PUBLIC_APP_VERSION=1.1.272
|
||||||
|
|||||||
@@ -26,4 +26,4 @@ NEXT_PUBLIC_BASE_PATH=/talas5
|
|||||||
# Oder leer lassen für direkten Zugriff -> NEXT_PUBLIC_BASE_PATH=
|
# Oder leer lassen für direkten Zugriff -> NEXT_PUBLIC_BASE_PATH=
|
||||||
|
|
||||||
# App-Versionsnummer
|
# App-Versionsnummer
|
||||||
NEXT_PUBLIC_APP_VERSION=1.1.271
|
NEXT_PUBLIC_APP_VERSION=1.1.272
|
||||||
66
docs/standards/versioning.md
Normal file
66
docs/standards/versioning.md
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
# 📦 Versionierung im Projekt
|
||||||
|
|
||||||
|
## 🎯 Ziel
|
||||||
|
|
||||||
|
Dieses Projekt verwendet eine automatisierte und konsistente Versionsverwaltung, um Klarheit über
|
||||||
|
die aktuelle App-Version zu gewährleisten und manuelle Fehler zu vermeiden.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🗂️ Wo wird die Version gespeichert?
|
||||||
|
|
||||||
|
Die App-Version ist in **vier Dateien synchron enthalten**:
|
||||||
|
|
||||||
|
| Datei | Zweck |
|
||||||
|
| ------------------- | ----------------------------------------- |
|
||||||
|
| `package.json` | Hauptquelle für Version (npm, Git) |
|
||||||
|
| `package-lock.json` | Technischer Zustand des Builds |
|
||||||
|
| `.env.development` | Anzeige in der UI zur Entwicklungszeit |
|
||||||
|
| `.env.production` | Anzeige in der UI auf Produktionssystemen |
|
||||||
|
|
||||||
|
Beispiel-Eintrag in `.env.*`:
|
||||||
|
|
||||||
|
```env
|
||||||
|
NEXT_PUBLIC_APP_VERSION=1.1.265
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## ⚙️ Wie wird die Version erhöht?
|
||||||
|
|
||||||
|
Die Version wird automatisch durch folgendes Skript erhöht:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
node scripts/bumpVersion.js
|
||||||
|
```
|
||||||
|
|
||||||
|
### Dieses Skript erledigt:
|
||||||
|
|
||||||
|
- Erhöhung der Patch-Version (z. B. `1.1.265` → `1.1.266`)
|
||||||
|
- Aktualisierung von `package.json`
|
||||||
|
- Erstellung eines synchronen `package-lock.json`
|
||||||
|
- Aktualisierung der `.env.development` und `.env.production` mit neuer Version
|
||||||
|
|
||||||
|
Das Skript wird zusätzlich automatisch beim Git-Commit über Husky (`.husky/pre-commit`) ausgeführt.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🧠 Warum ist das hilfreich?
|
||||||
|
|
||||||
|
- Die UI zeigt **immer die aktuelle App-Version**, über `process.env.NEXT_PUBLIC_APP_VERSION`
|
||||||
|
- Git-History, Deployments und ZIP-Versionen sind nachvollziehbar
|
||||||
|
- Keine Inkonsistenzen durch manuelle Pflege
|
||||||
|
- Reproduzierbare Builds dank `package-lock.json`
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 🧑💻 Hinweis für neue Entwickler
|
||||||
|
|
||||||
|
- ❌ Niemals die Versionsnummer manuell in nur einer Datei ändern!
|
||||||
|
- ✅ Immer das Skript nutzen oder den Commit-Hook wirken lassen.
|
||||||
|
- 🔁 Nach Konflikten: Stelle sicher, dass `package-lock.json` und `.env.*` konsistent sind.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
📘 Für technische Details siehe auch:
|
||||||
|
[`/docs/config/versioning.md`](../config/versioning.md)
|
||||||
4
package-lock.json
generated
4
package-lock.json
generated
@@ -1,12 +1,12 @@
|
|||||||
{
|
{
|
||||||
"name": "nodemap",
|
"name": "nodemap",
|
||||||
"version": "1.1.271",
|
"version": "1.1.272",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "nodemap",
|
"name": "nodemap",
|
||||||
"version": "1.1.271",
|
"version": "1.1.272",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@emotion/react": "^11.13.3",
|
"@emotion/react": "^11.13.3",
|
||||||
"@emotion/styled": "^11.13.0",
|
"@emotion/styled": "^11.13.0",
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "nodemap",
|
"name": "nodemap",
|
||||||
"version": "1.1.271",
|
"version": "1.1.272",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@emotion/react": "^11.13.3",
|
"@emotion/react": "^11.13.3",
|
||||||
"@emotion/styled": "^11.13.0",
|
"@emotion/styled": "^11.13.0",
|
||||||
|
|||||||
Reference in New Issue
Block a user