465c049251f16a288c5daeadc29642e49f8e54ca
- fl.attorney.agent (AbstractModel): manual-only substantive analysis fired from the case AI tab. Builds a full case context (parties, children, financials, issue tags, prior analyses) plus candidate statute/caselaw lists, and asks Claude to author a strategy memo, draft arguments/counterarguments, write a risk narrative, and assess substantial change (FL 61.30(1)(b)) - Grounds output in the real library: the model may only pick statutes/case law from the supplied candidates, which are then resolved back to records and linked (fl.analysis.cited_statute_ids / matched_caselaw_ids, case.caselaw_ids) - Rule-based fallback produces a usable memo (complexity, statutes by category, caselaw by tag, risk flags) when the API is unavailable — never a raw error - fl.analysis: add analysis_type, strategy_memo (Html), risk_narrative, cited_statute_ids; surface them in the analysis views - fl.case: add attorney_memo_id + related memo/risk display; action_run_attorney_agent opens the memo; "Generate Attorney Strategy Memo" button on the AI tab (admin) - Refactor fl_ai_engine: extract shared call_claude_json(system, user) + _extract_json so both agents and the engine share one Claude/JSON path Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
Description
No description provided
Languages
Python
91.9%
JavaScript
5.6%
CSS
2.5%