Energie-Bonus aufgeteilt in Sofort + Neukunden
EnergyContractDetails.bonus war ein einzelnes Feld. Strom-/Gas- Verträge haben aber typischerweise zwei Boni (Sofort beim Wechsel + Neukunden-Bonus nach 12 Monaten), die getrennt verbucht werden müssen. Migration 20260524100000_split_energy_bonus: - ADD COLUMN IF NOT EXISTS instantBonus, newCustomerBonus - bestehende `bonus`-Werte → instantBonus (Annahme: Sofort) - DROP COLUMN IF EXISTS bonus UI: - ContractForm zeigt zwei Input-Felder - Detail-Ansicht zeigt beide einzeln + Gesamtbonus - Kostenvorschau listet beide einzeln, dann Gesamt, dann effektive Jahreskosten Cost-Calc: calculateCosts() bekommt beide Boni; CostCalculation liefert instantBonus, newCustomerBonus, totalBonus. PDF-Template: drei neue Variablen energyDetails.instantBonus, .newCustomerBonus, .totalBonus. Live-verifiziert auf dev: PUT mit beiden Werten → DB persistiert, GET liefert zurueck. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,30 @@
|
||||
-- Energie-Bonus in Sofort-Bonus + Neukunden-Bonus aufteilen.
|
||||
-- Bestehende Werte werden nach `instantBonus` migriert (Annahme: bei
|
||||
-- Bestandsverträgen war "Bonus" üblicherweise der Sofort-Bonus).
|
||||
-- Wer das anders hatte, kann die Werte über die UI nachträglich verschieben.
|
||||
--
|
||||
-- IF NOT EXISTS macht den Re-Deploy auf Prod sicher, falls jemand schon
|
||||
-- `prisma db push` gefahren hat.
|
||||
|
||||
ALTER TABLE `EnergyContractDetails`
|
||||
ADD COLUMN IF NOT EXISTS `instantBonus` DOUBLE NULL,
|
||||
ADD COLUMN IF NOT EXISTS `newCustomerBonus` DOUBLE NULL;
|
||||
|
||||
-- Daten kopieren, sofern die alte Spalte noch existiert und das Ziel leer ist
|
||||
SET @col_exists := (
|
||||
SELECT COUNT(*) FROM information_schema.COLUMNS
|
||||
WHERE TABLE_SCHEMA = DATABASE()
|
||||
AND TABLE_NAME = 'EnergyContractDetails'
|
||||
AND COLUMN_NAME = 'bonus'
|
||||
);
|
||||
SET @sql := IF(
|
||||
@col_exists > 0,
|
||||
'UPDATE `EnergyContractDetails` SET `instantBonus` = `bonus` WHERE `bonus` IS NOT NULL AND `instantBonus` IS NULL',
|
||||
'SELECT "bonus-Spalte existiert nicht mehr, nichts zu migrieren"'
|
||||
);
|
||||
PREPARE stmt FROM @sql;
|
||||
EXECUTE stmt;
|
||||
DEALLOCATE PREPARE stmt;
|
||||
|
||||
-- Alte Spalte droppen, falls vorhanden
|
||||
ALTER TABLE `EnergyContractDetails` DROP COLUMN IF EXISTS `bonus`;
|
||||
Reference in New Issue
Block a user