Backend complete: - Migration 017: Add category column to ai_prompts - placeholder_resolver.py: 20+ placeholders with resolver functions - Extended routers/prompts.py with CRUD endpoints: * POST /api/prompts (create) * PUT /api/prompts/:id (update) * DELETE /api/prompts/:id (delete) * POST /api/prompts/:id/duplicate * PUT /api/prompts/reorder * POST /api/prompts/preview * GET /api/prompts/placeholders * POST /api/prompts/generate (KI-assisted generation) * POST /api/prompts/:id/optimize (KI analysis) - Extended models.py with PromptCreate, PromptUpdate, PromptGenerateRequest Frontend: - AdminPromptsPage.jsx: Full CRUD UI with category filter, reordering Meta-Features: - KI generates prompts from goal description + example data - KI analyzes and optimizes existing prompts Next: PromptEditModal, PromptGenerator, api.js integration Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
23 lines
1.3 KiB
SQL
23 lines
1.3 KiB
SQL
-- Migration 017: AI Prompts Flexibilisierung (Issue #28)
|
|
-- Add category column to ai_prompts for better organization and filtering
|
|
|
|
-- Add category column
|
|
ALTER TABLE ai_prompts ADD COLUMN IF NOT EXISTS category VARCHAR(20) DEFAULT 'ganzheitlich';
|
|
|
|
-- Create index for category filtering
|
|
CREATE INDEX IF NOT EXISTS idx_ai_prompts_category ON ai_prompts(category);
|
|
|
|
-- Add comment
|
|
COMMENT ON COLUMN ai_prompts.category IS 'Prompt category: körper, ernährung, training, schlaf, vitalwerte, ziele, ganzheitlich';
|
|
|
|
-- Update existing prompts with appropriate categories
|
|
-- Based on slug patterns and content
|
|
UPDATE ai_prompts SET category = 'körper' WHERE slug IN ('koerperkomposition', 'gewichtstrend', 'umfaenge', 'caliper');
|
|
UPDATE ai_prompts SET category = 'ernährung' WHERE slug IN ('ernaehrung', 'kalorienbilanz', 'protein', 'makros');
|
|
UPDATE ai_prompts SET category = 'training' WHERE slug IN ('aktivitaet', 'trainingsanalyse', 'erholung', 'leistung');
|
|
UPDATE ai_prompts SET category = 'schlaf' WHERE slug LIKE '%schlaf%';
|
|
UPDATE ai_prompts SET category = 'vitalwerte' WHERE slug IN ('vitalwerte', 'herzfrequenz', 'ruhepuls', 'hrv');
|
|
UPDATE ai_prompts SET category = 'ziele' WHERE slug LIKE '%ziel%' OR slug LIKE '%goal%';
|
|
|
|
-- Pipeline prompts remain 'ganzheitlich' (default)
|