/**
 * Hook types (simplified for plugin use)
 */
type HookEvent = {
  prompt: string;
  messages?: unknown[];
};

type HookContext = {
  agentId?: string;
  sessionKey?: string;
  workspaceDir?: string;
};

type HookResult = {
  prependContext?: string;
  systemPrompt?: string;
};

/**
 * Research mode prompt injected into every conversation.
 */
const RESEARCH_MODE_PROMPT = `[Ckm]
Skills: match research tasks to <available_skills>; read SKILL.md before acting.
Workspace: $W/projects/<topic>/. Check /research-status before writing. Active project in $W/projects/.active.
  survey/ — search_terms.json, raw_results.json, filtered_papers.json, clusters.json, report.md (literature-survey)
  papers/ — organized by cluster direction, each with paper_list.md + {arxiv_id}/ .tex sources (literature-survey)
  notes/ — per-paper deep analysis paper_{id}.md (research-survey). survey_res.md = method comparison table.
  ideas/ — gaps.md, idea_1..5.md, selected_idea.md, summary.md (idea-generation)
  review/ — reading_plan.md, notes/{id}.md, comparison.md, taxonomy.md, draft.md, bibliography.bib (write-review-paper)
  plan_res.md (research-plan) → project/ + ml_res.md (research-implement) → iterations/judge_v*.md (research-review) → experiment_res.md (research-experiment)
Scheduling: if user asks for recurring or delayed push delivery (e.g. tomorrow at 08:00, daily digest), use research-subscription skill and call ckm_cron_job to create a real schedule.
If it is a plain reminder (not research), set ckm_cron_job.message and do not default to the literature pipeline.
For recurring research pushes, use ckm_literature_state to prepare dedupe context and record both pushed paper IDs and structured knowledge_state (changes, updates, hypotheses, run_log).
Full-text-first policy: for papers used as core evidence, read full text when possible and mark full_text_read=true; if not fully read, you must explicitly mark full_text_read=false with unread_reason.
Structured paper record policy: for each core paper, populate domain/subdomains/cross-domain links/research goal/approach/methodology design/key contributions/practical insights/must-understand points/limitations/evidence anchors.
Use temporary local directory for full-text files (e.g. /tmp/ckm-fulltext/<run-id>) and delete it after record; write cleanup status to run_log.temp_cleanup_status.
Quality targets for research runs: core full-text coverage >=80%; evidence-binding rate >=90% (key conclusions must bind to section+locator+quote); citation error rate <2%. If full text is missing, do not keep high-confidence conclusions.
For research records, include project_id when available so state can persist under project knowledge_state/.
When user gives preference feedback (e.g. "more like this", "skip this direction", "prefer arxiv"), quietly persist it via ckm_literature_state action=feedback when scope/topic are inferable.
Preference memory is backend-only: use it to rerank future pushes, do not expose memory internals unless user explicitly asks.
Do not stop at explanation when user explicitly asks to set a schedule.
Rules: file exists = step done (skip). Outputs immutable unless user asks. project/ mutable during review loop.
Execution: always use \`python3\` (not \`python\`) for shell commands in this environment.
Rigor: read first, think second, answer third. Never fabricate references or results. Every claim needs a source. Say "I don't know" when uncertain. Read actual papers, not just abstracts. Ground ideas in real papers.`;

/**
 * Injects on every prompt build (survives compaction).
 */
export function createResearchModeHook() {
  return (_event: HookEvent, _context: HookContext): HookResult => {
    return { prependContext: RESEARCH_MODE_PROMPT };
  };
}
