Filehigh importancesource

SelectEventMode.tsx

components/hooks/SelectEventMode.tsx

127
Lines
13555
Bytes
1
Exports
9
Imports
10
Keywords

What this is

This page documents one file from the repository and includes its full source so you can read it without leaving the docs site.

Beginner explanation

This file is one piece of the larger system. Its name, directory, imports, and exports show where it fits. Start by reading the exports and related files first.

How it is used

Start from the exports list and related files. Those are the easiest clues for where this file fits into the system.

Expert explanation

Architecturally, this file intersects with modes, ui-flow. It contains 127 lines, 9 detected imports, and 1 detected exports.

Important relationships

Detected exports

  • SelectEventMode

Keywords

hookstextoncancelelsehookeventmetadatasettingsjsonclaudehookeventtotalhookscount

Detected imports

  • react/compiler-runtime
  • figures
  • react
  • src/entrypoints/agentSdkTypes.js
  • src/utils/hooks/hooksConfigManager.js
  • ../../ink.js
  • ../../utils/stringUtils.js
  • ../CustomSelect/select.js
  • ../design-system/Dialog.js

Source notes

This page embeds the full file contents. Small or leaf files are still indexed honestly instead of being over-explained.

Open parent directory

Full source

import { c as _c } from "react/compiler-runtime";
/**
 * SelectEventMode is the entrypoint of the Hooks config menu, where the user
 * sees the list of available hook events.
 *
 * The /hooks menu is read-only: selecting an event lets you browse its
 * configured hooks but not modify them. To add or change hooks, users should
 * edit settings.json directly or ask Claude.
 */

import figures from 'figures';
import * as React from 'react';
import type { HookEvent } from 'src/entrypoints/agentSdkTypes.js';
import type { HookEventMetadata } from 'src/utils/hooks/hooksConfigManager.js';
import { Box, Link, Text } from '../../ink.js';
import { plural } from '../../utils/stringUtils.js';
import { Select } from '../CustomSelect/select.js';
import { Dialog } from '../design-system/Dialog.js';
type Props = {
  hookEventMetadata: Record<HookEvent, HookEventMetadata>;
  hooksByEvent: Partial<Record<HookEvent, number>>;
  totalHooksCount: number;
  restrictedByPolicy: boolean;
  onSelectEvent: (event: HookEvent) => void;
  onCancel: () => void;
};
export function SelectEventMode(t0) {
  const $ = _c(23);
  const {
    hookEventMetadata,
    hooksByEvent,
    totalHooksCount,
    restrictedByPolicy,
    onSelectEvent,
    onCancel
  } = t0;
  let t1;
  if ($[0] !== totalHooksCount) {
    t1 = plural(totalHooksCount, "hook");
    $[0] = totalHooksCount;
    $[1] = t1;
  } else {
    t1 = $[1];
  }
  const subtitle = `${totalHooksCount} ${t1} configured`;
  let t2;
  if ($[2] !== restrictedByPolicy) {
    t2 = restrictedByPolicy && <Box flexDirection="column"><Text color="suggestion">{figures.info} Hooks Restricted by Policy</Text><Text dimColor={true}>Only hooks from managed settings can run. User-defined hooks from ~/.claude/settings.json, .claude/settings.json, and .claude/settings.local.json are blocked.</Text></Box>;
    $[2] = restrictedByPolicy;
    $[3] = t2;
  } else {
    t2 = $[3];
  }
  let t3;
  if ($[4] === Symbol.for("react.memo_cache_sentinel")) {
    t3 = <Box flexDirection="column"><Text dimColor={true}>{figures.info} This menu is read-only. To add or modify hooks, edit settings.json directly or ask Claude.{" "}<Link url="https://code.claude.com/docs/en/hooks">Learn more</Link></Text></Box>;
    $[4] = t3;
  } else {
    t3 = $[4];
  }
  let t4;
  if ($[5] !== onSelectEvent) {
    t4 = value => {
      onSelectEvent(value as HookEvent);
    };
    $[5] = onSelectEvent;
    $[6] = t4;
  } else {
    t4 = $[6];
  }
  let t5;
  if ($[7] !== hookEventMetadata) {
    t5 = Object.entries(hookEventMetadata);
    $[7] = hookEventMetadata;
    $[8] = t5;
  } else {
    t5 = $[8];
  }
  let t6;
  if ($[9] !== hooksByEvent || $[10] !== t5) {
    t6 = t5.map(t7 => {
      const [name, metadata] = t7;
      const count = hooksByEvent[name as HookEvent] || 0;
      return {
        label: count > 0 ? <Text>{name} <Text color="suggestion">({count})</Text></Text> : name,
        value: name,
        description: metadata.summary
      };
    });
    $[9] = hooksByEvent;
    $[10] = t5;
    $[11] = t6;
  } else {
    t6 = $[11];
  }
  let t7;
  if ($[12] !== onCancel || $[13] !== t4 || $[14] !== t6) {
    t7 = <Box flexDirection="column"><Select onChange={t4} onCancel={onCancel} options={t6} /></Box>;
    $[12] = onCancel;
    $[13] = t4;
    $[14] = t6;
    $[15] = t7;
  } else {
    t7 = $[15];
  }
  let t8;
  if ($[16] !== t2 || $[17] !== t7) {
    t8 = <Box flexDirection="column" gap={1}>{t2}{t3}{t7}</Box>;
    $[16] = t2;
    $[17] = t7;
    $[18] = t8;
  } else {
    t8 = $[18];
  }
  let t9;
  if ($[19] !== onCancel || $[20] !== subtitle || $[21] !== t8) {
    t9 = <Dialog title="Hooks" subtitle={subtitle} onCancel={onCancel}>{t8}</Dialog>;
    $[19] = onCancel;
    $[20] = subtitle;
    $[21] = t8;
    $[22] = t9;
  } else {
    t9 = $[22];
  }
  return t9;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["figures","React","HookEvent","HookEventMetadata","Box","Link","Text","plural","Select","Dialog","Props","hookEventMetadata","Record","hooksByEvent","Partial","totalHooksCount","restrictedByPolicy","onSelectEvent","event","onCancel","SelectEventMode","t0","$","_c","t1","subtitle","t2","info","t3","Symbol","for","t4","value","t5","Object","entries","t6","map","t7","name","metadata","count","label","description","summary","t8","t9"],"sources":["SelectEventMode.tsx"],"sourcesContent":["/**\n * SelectEventMode is the entrypoint of the Hooks config menu, where the user\n * sees the list of available hook events.\n *\n * The /hooks menu is read-only: selecting an event lets you browse its\n * configured hooks but not modify them. To add or change hooks, users should\n * edit settings.json directly or ask Claude.\n */\n\nimport figures from 'figures'\nimport * as React from 'react'\nimport type { HookEvent } from 'src/entrypoints/agentSdkTypes.js'\nimport type { HookEventMetadata } from 'src/utils/hooks/hooksConfigManager.js'\nimport { Box, Link, Text } from '../../ink.js'\nimport { plural } from '../../utils/stringUtils.js'\nimport { Select } from '../CustomSelect/select.js'\nimport { Dialog } from '../design-system/Dialog.js'\n\ntype Props = {\n  hookEventMetadata: Record<HookEvent, HookEventMetadata>\n  hooksByEvent: Partial<Record<HookEvent, number>>\n  totalHooksCount: number\n  restrictedByPolicy: boolean\n  onSelectEvent: (event: HookEvent) => void\n  onCancel: () => void\n}\n\nexport function SelectEventMode({\n  hookEventMetadata,\n  hooksByEvent,\n  totalHooksCount,\n  restrictedByPolicy,\n  onSelectEvent,\n  onCancel,\n}: Props): React.ReactNode {\n  const subtitle = `${totalHooksCount} ${plural(totalHooksCount, 'hook')} configured`\n\n  return (\n    <Dialog title=\"Hooks\" subtitle={subtitle} onCancel={onCancel}>\n      <Box flexDirection=\"column\" gap={1}>\n        {restrictedByPolicy && (\n          <Box flexDirection=\"column\">\n            <Text color=\"suggestion\">\n              {figures.info} Hooks Restricted by Policy\n            </Text>\n            <Text dimColor>\n              Only hooks from managed settings can run. User-defined hooks from\n              ~/.claude/settings.json, .claude/settings.json, and\n              .claude/settings.local.json are blocked.\n            </Text>\n          </Box>\n        )}\n\n        <Box flexDirection=\"column\">\n          <Text dimColor>\n            {figures.info} This menu is read-only. To add or modify hooks, edit\n            settings.json directly or ask Claude.{' '}\n            <Link url=\"https://code.claude.com/docs/en/hooks\">Learn more</Link>\n          </Text>\n        </Box>\n\n        <Box flexDirection=\"column\">\n          <Select\n            onChange={value => {\n              onSelectEvent(value as HookEvent)\n            }}\n            onCancel={onCancel}\n            options={Object.entries(hookEventMetadata).map(\n              ([name, metadata]) => {\n                const count = hooksByEvent[name as HookEvent] || 0\n                return {\n                  label:\n                    count > 0 ? (\n                      <Text>\n                        {name} <Text color=\"suggestion\">({count})</Text>\n                      </Text>\n                    ) : (\n                      name\n                    ),\n                  value: name,\n                  description: metadata.summary,\n                }\n              },\n            )}\n          />\n        </Box>\n      </Box>\n    </Dialog>\n  )\n}\n"],"mappings":"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","ignoreList":[]}