feat(learning): אינדיקציית-תיק למצב למידת-קול + חילוץ-הלכות אחרי החלטה סופית #233
Reference in New Issue
Block a user
Delete Branch "worktree-case-learning-indicator"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
הצורך
אחרי שהיו"ר מעלה החלטה סופית ומריץ את שני הפייפליינים האוטומטיים — למידת-קול (
final_learning_pipeline.py) וחילוץ/אימות-הלכות (final_halacha_pipeline.py) — התיק לא הציג אם כל תהליך בוצע / הצליח / למה-נכשל / כמה הלכות חולצו. במיוחד תקלתchair_nameריק (2026-06-12) שמפילה בשקט את העתק-ה-case_law → חילוץ-הלכות לא מתחיל בכלל, בלי שזה גלוי. כעת מוצגות שתי אינדיקציות ליד כפתורי-ההרצה.הגישה — גזירה ממקור-יחיד (G1/G2)
רוב הנתונים כבר קיימים ב-DB; נגזרים במקום אחד ולא נוצר מסלול-מעקב מקביל. התוספת היחידה ל-DB: שדה-תיעוד-תוצאה לפייפליין-הלמידה (שהיום חסר סימון-כישלון מתמשך).
Backend
SCHEMA_V36—draft_final_pairs.learning_run(JSONB): שדה-תיעוד על פנקס-ההתאמה הקיים (INV-LRN4), חותם את תוצאת-הריצה (succeeded/failed+error+at). NULL = לא נרשמה תוצאה (=טרם-בוצע).set_learning_run_outcome()— חיתום על ה-pair האחרון;case_learning_status()— גזירה read-only מ-draft_final_pairs/style_corpus/decision_lessons/case_law/halachot.final_learning_pipeline.py— חותם outcome בהצלחה וב-except(surfaced, לא בלוע).case_getמוסיףlearning_status(→ MCP +/api/cases/{case}/details) + endpoint ייעודיGET /api/cases/{case}/learning-status— אותה פונקציית-גזירה, בלי כפילות-לוגיקה.UI (אושר דרך שער-העיצוב Claude Design — כרטיס
21-final-learning-status)useCaseLearningStatus(הורחבapi/learning.tsהקיים — לא מודול מקביל) + polling עדין בזמןpending/processing/busy.LearningStatusBadges— 2 שורות (למידת-קול / חילוץ-הלכות) עם badge + תת-שורה: מס' לקחים · רישום-קורפוס · מס' הוצעו / מס' הלכות + פירוק אושרו·ממתינות·נדחו / סיבת-כישלון / "לא נכנס לקורפוס".drafts-panelתחת "החלטה סופית של היו״ר" + אינוולידציה בכפתורי-ההרצה.אימות
מול ה-DB החי: הצליח+5 הלכות (8174-12-24, 2 אושרו/3 נדחו) · נכנס-אך-pending (1200-12-25) · לא-נכנס-לקורפוס (8125-09-24) · round-trip חיתום-כישלון (rollback).
tsc --noEmit+eslintנקיים על שלושת הקבצים. המיגרציה אומתה (learning_runקיימת).Invariants
draft_final_pairsהוא פנקס-ההתאמה;learning_runהוא שדה-תיעוד עליו.case_learning_status).🤖 Generated with Claude Code
אחרי העלאת החלטה סופית והרצת שני הפייפליינים האוטומטיים (למידת-קול, חילוץ/אימות-הלכות), התיק לא הציג אם כל תהליך בוצע/הצליח/למה-נכשל. במיוחד תקלת chair_name ריק (2026-06-12) שמפילה בשקט את העתק-ה-case_law → חילוץ-הלכות לא מתחיל בכלל, בלי שזה גלוי. כעת מוצגות שתי אינדיקציות ליד כפתורי-ההרצה. Backend (גזירה ממקור-יחיד, ללא מסלול-מעקב מקביל): - SCHEMA_V36: draft_final_pairs.learning_run (JSONB) — שדה-תיעוד על פנקס-ההתאמה (INV-LRN4), חותם את תוצאת-הריצה של פייפליין-הלמידה (succeeded/failed+סיבה+at). - set_learning_run_outcome() — חיתום הצלחה/כישלון על ה-pair האחרון. - case_learning_status() — גזירה read-only מ-draft_final_pairs/style_corpus/ decision_lessons/case_law/halachot: בוצע? הצליח? למה-לא? כמה הלכות חולצו. - final_learning_pipeline.py — חותם outcome בהצלחה וב-except (surfaced, לא בלוע). - חשיפה: case_get מוסיף learning_status (→MCP + /api/cases/{case}/details) + endpoint ייעודי GET /api/cases/{case}/learning-status (אותה פונקציה — בלי כפילות). UI (אושר דרך שער-העיצוב Claude Design — כרטיס 21-final-learning-status): - useCaseLearningStatus (api/learning.ts) — hook + polling עדין בזמן in-flight. - LearningStatusBadges — 2 שורות (למידת-קול / חילוץ-הלכות) עם badge + תת-שורה (מס' לקחים · רישום-קורפוס / מס' הלכות + פירוק אושרו/ממתינות/נדחו / סיבת-כישלון). - שילוב ב-drafts-panel תחת "החלטה סופית של היו״ר" + אינוולידציה בכפתורי-ההרצה. אומת מול ה-DB החי: הצליח+5 הלכות (8174-12-24) · נכנס-אך-pending (1200-12-25) · לא-נכנס-לקורפוס (8125-09-24) · round-trip חיתום-כישלון. tsc/eslint נקיים. Invariants: G1 (נרמול-במקור — גזירה, לא טלאי), G2 (אין מסלול מקביל — שדה על הפנקס הקיים + exposer יחיד), INV-LRN4 (פנקס-ההתאמה), INV-IA1 (מקור-אמת יחיד). Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>