Compare commits

..

No commits in common. "9fa6c5dea7f84bd8e030b26302e8642ca155b0f8" and "43e6c3e7f4091c351d237d00a52bec809a64d10e" have entirely different histories.

2 changed files with 0 additions and 104 deletions

View File

@ -101,13 +101,6 @@ def map_focus_to_score_components() -> Dict[str, str]:
'blood_pressure': 'health',
'hrv': 'health',
'general_health': 'health',
# Nutrition → nutrition_score
'protein_intake': 'nutrition',
'calorie_balance': 'nutrition',
'macro_consistency': 'nutrition',
'meal_timing': 'nutrition',
'hydration': 'nutrition',
}

View File

@ -1,97 +0,0 @@
-- Migration 033: Nutrition Focus Areas
-- Date: 2026-03-28
-- Purpose: Add missing nutrition category to complete focus area coverage
-- ============================================================================
-- Part 1: Add Nutrition Focus Areas
-- ============================================================================
INSERT INTO focus_area_definitions (key, name_de, name_en, icon, category, description) VALUES
-- Nutrition Category
('protein_intake', 'Proteinzufuhr', 'Protein Intake', '🥩', 'nutrition', 'Ausreichend Protein für Muskelaufbau/-erhalt'),
('calorie_balance', 'Kalorienbilanz', 'Calorie Balance', '⚖️', 'nutrition', 'Energiebilanz passend zum Ziel (Defizit/Überschuss)'),
('macro_consistency', 'Makro-Konsistenz', 'Macro Consistency', '📊', 'nutrition', 'Gleichmäßige Makronährstoff-Verteilung'),
('meal_timing', 'Mahlzeiten-Timing', 'Meal Timing', '', 'nutrition', 'Regelmäßige Mahlzeiten und optimales Timing'),
('hydration', 'Flüssigkeitszufuhr', 'Hydration', '💧', 'nutrition', 'Ausreichende Flüssigkeitsaufnahme')
ON CONFLICT (key) DO NOTHING;
-- ============================================================================
-- Part 2: Auto-Mapping for Nutrition-Related Goals
-- ============================================================================
-- Helper function to get focus_area_id by key
CREATE OR REPLACE FUNCTION get_focus_area_id(area_key VARCHAR)
RETURNS UUID AS $$
BEGIN
RETURN (SELECT id FROM focus_area_definitions WHERE key = area_key LIMIT 1);
END;
$$ LANGUAGE plpgsql;
-- Weight Loss goals → calorie_balance (40%) + protein_intake (30%)
-- (Already mapped to weight_loss in migration 031, adding nutrition aspects)
INSERT INTO goal_focus_contributions (goal_id, focus_area_id, contribution_weight)
SELECT g.id, fa.id,
CASE fa.key
WHEN 'calorie_balance' THEN 40.00
WHEN 'protein_intake' THEN 30.00
END
FROM goals g
CROSS JOIN focus_area_definitions fa
WHERE g.goal_type = 'weight'
AND fa.key IN ('calorie_balance', 'protein_intake')
ON CONFLICT (goal_id, focus_area_id) DO NOTHING;
-- Body Fat goals → calorie_balance (30%) + protein_intake (40%)
INSERT INTO goal_focus_contributions (goal_id, focus_area_id, contribution_weight)
SELECT g.id, fa.id,
CASE fa.key
WHEN 'calorie_balance' THEN 30.00
WHEN 'protein_intake' THEN 40.00
END
FROM goals g
CROSS JOIN focus_area_definitions fa
WHERE g.goal_type = 'body_fat'
AND fa.key IN ('calorie_balance', 'protein_intake')
ON CONFLICT (goal_id, focus_area_id) DO NOTHING;
-- Lean Mass goals → protein_intake (60%) + calorie_balance (20%)
INSERT INTO goal_focus_contributions (goal_id, focus_area_id, contribution_weight)
SELECT g.id, fa.id,
CASE fa.key
WHEN 'protein_intake' THEN 60.00
WHEN 'calorie_balance' THEN 20.00
END
FROM goals g
CROSS JOIN focus_area_definitions fa
WHERE g.goal_type = 'lean_mass'
AND fa.key IN ('protein_intake', 'calorie_balance')
ON CONFLICT (goal_id, focus_area_id) DO NOTHING;
-- Strength goals → protein_intake (20%)
INSERT INTO goal_focus_contributions (goal_id, focus_area_id, contribution_weight)
SELECT g.id, get_focus_area_id('protein_intake'), 20.00
FROM goals g
WHERE g.goal_type = 'strength'
ON CONFLICT (goal_id, focus_area_id) DO NOTHING;
-- Cleanup helper function
DROP FUNCTION IF EXISTS get_focus_area_id(VARCHAR);
-- ============================================================================
-- Summary
-- ============================================================================
COMMENT ON COLUMN focus_area_definitions.category IS
'Categories: body_composition, training, endurance, coordination, mental, recovery, health, nutrition';
-- Count nutrition focus areas
DO $$
DECLARE
nutrition_count INT;
BEGIN
SELECT COUNT(*) INTO nutrition_count
FROM focus_area_definitions
WHERE category = 'nutrition';
RAISE NOTICE 'Migration 033 complete: % nutrition focus areas added', nutrition_count;
END $$;