/ components / permissions / PermissionPrompt.tsx
PermissionPrompt.tsx
  1  import { c as _c } from "react/compiler-runtime";
  2  import React, { type ReactNode, useCallback, useMemo, useState } from 'react';
  3  import { Box, Text } from '../../ink.js';
  4  import type { KeybindingAction } from '../../keybindings/types.js';
  5  import { useKeybindings } from '../../keybindings/useKeybinding.js';
  6  import { type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, logEvent } from '../../services/analytics/index.js';
  7  import { useSetAppState } from '../../state/AppState.js';
  8  import { type OptionWithDescription, Select } from '../CustomSelect/select.js';
  9  export type FeedbackType = 'accept' | 'reject';
 10  export type PermissionPromptOption<T extends string> = {
 11    value: T;
 12    label: ReactNode;
 13    feedbackConfig?: {
 14      type: FeedbackType;
 15      placeholder?: string;
 16    };
 17    keybinding?: KeybindingAction;
 18  };
 19  export type ToolAnalyticsContext = {
 20    toolName: string;
 21    isMcp: boolean;
 22  };
 23  export type PermissionPromptProps<T extends string> = {
 24    options: PermissionPromptOption<T>[];
 25    onSelect: (value: T, feedback?: string) => void;
 26    onCancel?: () => void;
 27    question?: string | ReactNode;
 28    toolAnalyticsContext?: ToolAnalyticsContext;
 29  };
 30  const DEFAULT_PLACEHOLDERS: Record<FeedbackType, string> = {
 31    accept: 'tell Claude what to do next',
 32    reject: 'tell Claude what to do differently'
 33  };
 34  
 35  /**
 36   * Shared component for permission prompts with optional feedback input.
 37   *
 38   * Handles:
 39   * - "Do you want to proceed?" question with optional Tab hint
 40   * - Feature flag check for feedback capability
 41   * - Input mode toggling (Tab to expand feedback input)
 42   * - Analytics events for feedback interactions
 43   * - Transforming options to Select-compatible format
 44   */
 45  export function PermissionPrompt(t0) {
 46    const $ = _c(54);
 47    const {
 48      options,
 49      onSelect,
 50      onCancel,
 51      question: t1,
 52      toolAnalyticsContext
 53    } = t0;
 54    const question = t1 === undefined ? "Do you want to proceed?" : t1;
 55    const setAppState = useSetAppState();
 56    const [acceptFeedback, setAcceptFeedback] = useState("");
 57    const [rejectFeedback, setRejectFeedback] = useState("");
 58    const [acceptInputMode, setAcceptInputMode] = useState(false);
 59    const [rejectInputMode, setRejectInputMode] = useState(false);
 60    const [focusedValue, setFocusedValue] = useState(null);
 61    const [acceptFeedbackModeEntered, setAcceptFeedbackModeEntered] = useState(false);
 62    const [rejectFeedbackModeEntered, setRejectFeedbackModeEntered] = useState(false);
 63    let t2;
 64    if ($[0] !== focusedValue || $[1] !== options) {
 65      let t3;
 66      if ($[3] !== focusedValue) {
 67        t3 = opt => opt.value === focusedValue;
 68        $[3] = focusedValue;
 69        $[4] = t3;
 70      } else {
 71        t3 = $[4];
 72      }
 73      t2 = options.find(t3);
 74      $[0] = focusedValue;
 75      $[1] = options;
 76      $[2] = t2;
 77    } else {
 78      t2 = $[2];
 79    }
 80    const focusedOption = t2;
 81    const focusedFeedbackType = focusedOption?.feedbackConfig?.type;
 82    const showTabHint = focusedFeedbackType === "accept" && !acceptInputMode || focusedFeedbackType === "reject" && !rejectInputMode;
 83    let t3;
 84    if ($[5] !== acceptInputMode || $[6] !== options || $[7] !== rejectInputMode) {
 85      let t4;
 86      if ($[9] !== acceptInputMode || $[10] !== rejectInputMode) {
 87        t4 = opt_0 => {
 88          const {
 89            value,
 90            label,
 91            feedbackConfig
 92          } = opt_0;
 93          if (!feedbackConfig) {
 94            return {
 95              label,
 96              value
 97            };
 98          }
 99          const {
100            type,
101            placeholder
102          } = feedbackConfig;
103          const isInputMode = type === "accept" ? acceptInputMode : rejectInputMode;
104          const onChange = type === "accept" ? setAcceptFeedback : setRejectFeedback;
105          const defaultPlaceholder = DEFAULT_PLACEHOLDERS[type];
106          if (isInputMode) {
107            return {
108              type: "input" as const,
109              label,
110              value,
111              placeholder: placeholder ?? defaultPlaceholder,
112              onChange,
113              allowEmptySubmitToCancel: true
114            };
115          }
116          return {
117            label,
118            value
119          };
120        };
121        $[9] = acceptInputMode;
122        $[10] = rejectInputMode;
123        $[11] = t4;
124      } else {
125        t4 = $[11];
126      }
127      t3 = options.map(t4);
128      $[5] = acceptInputMode;
129      $[6] = options;
130      $[7] = rejectInputMode;
131      $[8] = t3;
132    } else {
133      t3 = $[8];
134    }
135    const selectOptions = t3;
136    let t4;
137    if ($[12] !== acceptInputMode || $[13] !== options || $[14] !== rejectInputMode || $[15] !== toolAnalyticsContext?.isMcp || $[16] !== toolAnalyticsContext?.toolName) {
138      t4 = value_0 => {
139        const option = options.find(opt_1 => opt_1.value === value_0);
140        if (!option?.feedbackConfig) {
141          return;
142        }
143        const {
144          type: type_0
145        } = option.feedbackConfig;
146        const analyticsProps = {
147          toolName: toolAnalyticsContext?.toolName as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
148          isMcp: toolAnalyticsContext?.isMcp ?? false
149        };
150        if (type_0 === "accept") {
151          if (acceptInputMode) {
152            setAcceptInputMode(false);
153            logEvent("tengu_accept_feedback_mode_collapsed", analyticsProps);
154          } else {
155            setAcceptInputMode(true);
156            setAcceptFeedbackModeEntered(true);
157            logEvent("tengu_accept_feedback_mode_entered", analyticsProps);
158          }
159        } else {
160          if (type_0 === "reject") {
161            if (rejectInputMode) {
162              setRejectInputMode(false);
163              logEvent("tengu_reject_feedback_mode_collapsed", analyticsProps);
164            } else {
165              setRejectInputMode(true);
166              setRejectFeedbackModeEntered(true);
167              logEvent("tengu_reject_feedback_mode_entered", analyticsProps);
168            }
169          }
170        }
171      };
172      $[12] = acceptInputMode;
173      $[13] = options;
174      $[14] = rejectInputMode;
175      $[15] = toolAnalyticsContext?.isMcp;
176      $[16] = toolAnalyticsContext?.toolName;
177      $[17] = t4;
178    } else {
179      t4 = $[17];
180    }
181    const handleInputModeToggle = t4;
182    let t5;
183    if ($[18] !== acceptFeedback || $[19] !== acceptFeedbackModeEntered || $[20] !== onSelect || $[21] !== options || $[22] !== rejectFeedback || $[23] !== rejectFeedbackModeEntered || $[24] !== toolAnalyticsContext?.isMcp || $[25] !== toolAnalyticsContext?.toolName) {
184      t5 = value_1 => {
185        const option_0 = options.find(opt_2 => opt_2.value === value_1);
186        if (!option_0) {
187          return;
188        }
189        let feedback;
190        if (option_0.feedbackConfig) {
191          const rawFeedback = option_0.feedbackConfig.type === "accept" ? acceptFeedback : rejectFeedback;
192          const trimmedFeedback = rawFeedback.trim();
193          if (trimmedFeedback) {
194            feedback = trimmedFeedback;
195          }
196          const analyticsProps_0 = {
197            toolName: toolAnalyticsContext?.toolName as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
198            isMcp: toolAnalyticsContext?.isMcp ?? false,
199            has_instructions: !!trimmedFeedback,
200            instructions_length: trimmedFeedback?.length ?? 0,
201            entered_feedback_mode: option_0.feedbackConfig.type === "accept" ? acceptFeedbackModeEntered : rejectFeedbackModeEntered
202          };
203          if (option_0.feedbackConfig.type === "accept") {
204            logEvent("tengu_accept_submitted", analyticsProps_0);
205          } else {
206            if (option_0.feedbackConfig.type === "reject") {
207              logEvent("tengu_reject_submitted", analyticsProps_0);
208            }
209          }
210        }
211        onSelect(value_1, feedback);
212      };
213      $[18] = acceptFeedback;
214      $[19] = acceptFeedbackModeEntered;
215      $[20] = onSelect;
216      $[21] = options;
217      $[22] = rejectFeedback;
218      $[23] = rejectFeedbackModeEntered;
219      $[24] = toolAnalyticsContext?.isMcp;
220      $[25] = toolAnalyticsContext?.toolName;
221      $[26] = t5;
222    } else {
223      t5 = $[26];
224    }
225    const handleSelect = t5;
226    let handlers;
227    if ($[27] !== handleSelect || $[28] !== options) {
228      handlers = {};
229      for (const opt_3 of options) {
230        if (opt_3.keybinding) {
231          handlers[opt_3.keybinding] = () => handleSelect(opt_3.value);
232        }
233      }
234      $[27] = handleSelect;
235      $[28] = options;
236      $[29] = handlers;
237    } else {
238      handlers = $[29];
239    }
240    const keybindingHandlers = handlers;
241    let t6;
242    if ($[30] === Symbol.for("react.memo_cache_sentinel")) {
243      t6 = {
244        context: "Confirmation"
245      };
246      $[30] = t6;
247    } else {
248      t6 = $[30];
249    }
250    useKeybindings(keybindingHandlers, t6);
251    let t7;
252    if ($[31] !== onCancel || $[32] !== setAppState) {
253      t7 = () => {
254        logEvent("tengu_permission_request_escape", {});
255        setAppState(_temp);
256        onCancel?.();
257      };
258      $[31] = onCancel;
259      $[32] = setAppState;
260      $[33] = t7;
261    } else {
262      t7 = $[33];
263    }
264    const handleCancel = t7;
265    let t8;
266    if ($[34] !== question) {
267      t8 = typeof question === "string" ? <Text>{question}</Text> : question;
268      $[34] = question;
269      $[35] = t8;
270    } else {
271      t8 = $[35];
272    }
273    let t9;
274    if ($[36] !== acceptFeedback || $[37] !== acceptInputMode || $[38] !== options || $[39] !== rejectFeedback || $[40] !== rejectInputMode) {
275      t9 = value_2 => {
276        const newOption = options.find(opt_4 => opt_4.value === value_2);
277        if (newOption?.feedbackConfig?.type !== "accept" && acceptInputMode && !acceptFeedback.trim()) {
278          setAcceptInputMode(false);
279        }
280        if (newOption?.feedbackConfig?.type !== "reject" && rejectInputMode && !rejectFeedback.trim()) {
281          setRejectInputMode(false);
282        }
283        setFocusedValue(value_2);
284      };
285      $[36] = acceptFeedback;
286      $[37] = acceptInputMode;
287      $[38] = options;
288      $[39] = rejectFeedback;
289      $[40] = rejectInputMode;
290      $[41] = t9;
291    } else {
292      t9 = $[41];
293    }
294    let t10;
295    if ($[42] !== handleCancel || $[43] !== handleInputModeToggle || $[44] !== handleSelect || $[45] !== selectOptions || $[46] !== t9) {
296      t10 = <Select options={selectOptions} inlineDescriptions={true} onChange={handleSelect} onCancel={handleCancel} onFocus={t9} onInputModeToggle={handleInputModeToggle} />;
297      $[42] = handleCancel;
298      $[43] = handleInputModeToggle;
299      $[44] = handleSelect;
300      $[45] = selectOptions;
301      $[46] = t9;
302      $[47] = t10;
303    } else {
304      t10 = $[47];
305    }
306    const t11 = showTabHint && " \xB7 Tab to amend";
307    let t12;
308    if ($[48] !== t11) {
309      t12 = <Box marginTop={1}><Text dimColor={true}>Esc to cancel{t11}</Text></Box>;
310      $[48] = t11;
311      $[49] = t12;
312    } else {
313      t12 = $[49];
314    }
315    let t13;
316    if ($[50] !== t10 || $[51] !== t12 || $[52] !== t8) {
317      t13 = <Box flexDirection="column">{t8}{t10}{t12}</Box>;
318      $[50] = t10;
319      $[51] = t12;
320      $[52] = t8;
321      $[53] = t13;
322    } else {
323      t13 = $[53];
324    }
325    return t13;
326  }
327  function _temp(prev) {
328    return {
329      ...prev,
330      attribution: {
331        ...prev.attribution,
332        escapeCount: prev.attribution.escapeCount + 1
333      }
334    };
335  }
336  //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","ReactNode","useCallback","useMemo","useState","Box","Text","KeybindingAction","useKeybindings","AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS","logEvent","useSetAppState","OptionWithDescription","Select","FeedbackType","PermissionPromptOption","value","T","label","feedbackConfig","type","placeholder","keybinding","ToolAnalyticsContext","toolName","isMcp","PermissionPromptProps","options","onSelect","feedback","onCancel","question","toolAnalyticsContext","DEFAULT_PLACEHOLDERS","Record","accept","reject","PermissionPrompt","t0","$","_c","t1","undefined","setAppState","acceptFeedback","setAcceptFeedback","rejectFeedback","setRejectFeedback","acceptInputMode","setAcceptInputMode","rejectInputMode","setRejectInputMode","focusedValue","setFocusedValue","acceptFeedbackModeEntered","setAcceptFeedbackModeEntered","rejectFeedbackModeEntered","setRejectFeedbackModeEntered","t2","t3","opt","find","focusedOption","focusedFeedbackType","showTabHint","t4","opt_0","isInputMode","onChange","defaultPlaceholder","const","allowEmptySubmitToCancel","map","selectOptions","value_0","option","opt_1","type_0","analyticsProps","handleInputModeToggle","t5","value_1","option_0","opt_2","rawFeedback","trimmedFeedback","trim","analyticsProps_0","has_instructions","instructions_length","length","entered_feedback_mode","handleSelect","handlers","opt_3","keybindingHandlers","t6","Symbol","for","context","t7","_temp","handleCancel","t8","t9","value_2","newOption","opt_4","t10","t11","t12","t13","prev","attribution","escapeCount"],"sources":["PermissionPrompt.tsx"],"sourcesContent":["import React, { type ReactNode, useCallback, useMemo, useState } from 'react'\nimport { Box, Text } from '../../ink.js'\nimport type { KeybindingAction } from '../../keybindings/types.js'\nimport { useKeybindings } from '../../keybindings/useKeybinding.js'\nimport {\n  type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  logEvent,\n} from '../../services/analytics/index.js'\nimport { useSetAppState } from '../../state/AppState.js'\nimport { type OptionWithDescription, Select } from '../CustomSelect/select.js'\n\nexport type FeedbackType = 'accept' | 'reject'\n\nexport type PermissionPromptOption<T extends string> = {\n  value: T\n  label: ReactNode\n  feedbackConfig?: {\n    type: FeedbackType\n    placeholder?: string\n  }\n  keybinding?: KeybindingAction\n}\n\nexport type ToolAnalyticsContext = {\n  toolName: string\n  isMcp: boolean\n}\n\nexport type PermissionPromptProps<T extends string> = {\n  options: PermissionPromptOption<T>[]\n  onSelect: (value: T, feedback?: string) => void\n  onCancel?: () => void\n  question?: string | ReactNode\n  toolAnalyticsContext?: ToolAnalyticsContext\n}\n\nconst DEFAULT_PLACEHOLDERS: Record<FeedbackType, string> = {\n  accept: 'tell Claude what to do next',\n  reject: 'tell Claude what to do differently',\n}\n\n/**\n * Shared component for permission prompts with optional feedback input.\n *\n * Handles:\n * - \"Do you want to proceed?\" question with optional Tab hint\n * - Feature flag check for feedback capability\n * - Input mode toggling (Tab to expand feedback input)\n * - Analytics events for feedback interactions\n * - Transforming options to Select-compatible format\n */\nexport function PermissionPrompt<T extends string>({\n  options,\n  onSelect,\n  onCancel,\n  question = 'Do you want to proceed?',\n  toolAnalyticsContext,\n}: PermissionPromptProps<T>): React.ReactNode {\n  const setAppState = useSetAppState()\n  const [acceptFeedback, setAcceptFeedback] = useState('')\n  const [rejectFeedback, setRejectFeedback] = useState('')\n  const [acceptInputMode, setAcceptInputMode] = useState(false)\n  const [rejectInputMode, setRejectInputMode] = useState(false)\n  const [focusedValue, setFocusedValue] = useState<T | null>(null)\n  // Track whether user ever entered feedback mode (persists after collapse)\n  const [acceptFeedbackModeEntered, setAcceptFeedbackModeEntered] =\n    useState(false)\n  const [rejectFeedbackModeEntered, setRejectFeedbackModeEntered] =\n    useState(false)\n\n  // Find which option is focused and whether it has feedback config\n  const focusedOption = options.find(opt => opt.value === focusedValue)\n  const focusedFeedbackType = focusedOption?.feedbackConfig?.type\n\n  // Show Tab hint when focused on a feedback-enabled option that's not already in input mode\n  const showTabHint =\n    (focusedFeedbackType === 'accept' && !acceptInputMode) ||\n    (focusedFeedbackType === 'reject' && !rejectInputMode)\n\n  // Transform options to Select-compatible format\n  const selectOptions = useMemo((): OptionWithDescription<T>[] => {\n    return options.map(opt => {\n      const { value, label, feedbackConfig } = opt\n\n      // No feedback config = simple option\n      if (!feedbackConfig) {\n        return {\n          label,\n          value,\n        }\n      }\n\n      const { type, placeholder } = feedbackConfig\n      const isInputMode = type === 'accept' ? acceptInputMode : rejectInputMode\n      const onChange = type === 'accept' ? setAcceptFeedback : setRejectFeedback\n      const defaultPlaceholder = DEFAULT_PLACEHOLDERS[type]\n\n      // When in input mode, show input field\n      if (isInputMode) {\n        return {\n          type: 'input' as const,\n          label,\n          value,\n          placeholder: placeholder ?? defaultPlaceholder,\n          onChange,\n          allowEmptySubmitToCancel: true,\n        }\n      }\n\n      // Not in input mode - show simple option\n      return {\n        label,\n        value,\n      }\n    })\n  }, [options, acceptInputMode, rejectInputMode])\n\n  // Handle Tab key to toggle input mode\n  const handleInputModeToggle = useCallback(\n    (value: T) => {\n      const option = options.find(opt => opt.value === value)\n      if (!option?.feedbackConfig) return\n\n      const { type } = option.feedbackConfig\n      const analyticsProps = {\n        toolName:\n          toolAnalyticsContext?.toolName as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        isMcp: toolAnalyticsContext?.isMcp ?? false,\n      }\n\n      if (type === 'accept') {\n        if (acceptInputMode) {\n          setAcceptInputMode(false)\n          logEvent('tengu_accept_feedback_mode_collapsed', analyticsProps)\n        } else {\n          setAcceptInputMode(true)\n          setAcceptFeedbackModeEntered(true)\n          logEvent('tengu_accept_feedback_mode_entered', analyticsProps)\n        }\n      } else if (type === 'reject') {\n        if (rejectInputMode) {\n          setRejectInputMode(false)\n          logEvent('tengu_reject_feedback_mode_collapsed', analyticsProps)\n        } else {\n          setRejectInputMode(true)\n          setRejectFeedbackModeEntered(true)\n          logEvent('tengu_reject_feedback_mode_entered', analyticsProps)\n        }\n      }\n    },\n    [options, acceptInputMode, rejectInputMode, toolAnalyticsContext],\n  )\n\n  // Handle selection\n  const handleSelect = useCallback(\n    (value: T) => {\n      const option = options.find(opt => opt.value === value)\n      if (!option) return\n\n      // Get feedback if applicable\n      let feedback: string | undefined\n      if (option.feedbackConfig) {\n        const rawFeedback =\n          option.feedbackConfig.type === 'accept'\n            ? acceptFeedback\n            : rejectFeedback\n        const trimmedFeedback = rawFeedback.trim()\n\n        if (trimmedFeedback) {\n          feedback = trimmedFeedback\n        }\n\n        // Log accept/reject submission with feedback context\n        const analyticsProps = {\n          toolName:\n            toolAnalyticsContext?.toolName as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          isMcp: toolAnalyticsContext?.isMcp ?? false,\n          has_instructions: !!trimmedFeedback,\n          instructions_length: trimmedFeedback?.length ?? 0,\n          entered_feedback_mode:\n            option.feedbackConfig.type === 'accept'\n              ? acceptFeedbackModeEntered\n              : rejectFeedbackModeEntered,\n        }\n\n        if (option.feedbackConfig.type === 'accept') {\n          logEvent('tengu_accept_submitted', analyticsProps)\n        } else if (option.feedbackConfig.type === 'reject') {\n          logEvent('tengu_reject_submitted', analyticsProps)\n        }\n      }\n\n      onSelect(value, feedback)\n    },\n    [\n      options,\n      acceptFeedback,\n      rejectFeedback,\n      onSelect,\n      toolAnalyticsContext,\n      acceptFeedbackModeEntered,\n      rejectFeedbackModeEntered,\n    ],\n  )\n\n  // Register keybinding handlers for options that have a keybinding set\n  const keybindingHandlers = useMemo(() => {\n    const handlers: Record<string, () => void> = {}\n    for (const opt of options) {\n      if (opt.keybinding) {\n        handlers[opt.keybinding] = () => handleSelect(opt.value)\n      }\n    }\n    return handlers\n  }, [options, handleSelect])\n\n  useKeybindings(keybindingHandlers, { context: 'Confirmation' })\n\n  // Handle cancel (Esc)\n  const handleCancel = useCallback(() => {\n    logEvent('tengu_permission_request_escape', {})\n    // Increment escape count for attribution tracking\n    setAppState(prev => ({\n      ...prev,\n      attribution: {\n        ...prev.attribution,\n        escapeCount: prev.attribution.escapeCount + 1,\n      },\n    }))\n    onCancel?.()\n  }, [onCancel, setAppState])\n\n  return (\n    <Box flexDirection=\"column\">\n      {typeof question === 'string' ? <Text>{question}</Text> : question}\n      <Select\n        options={selectOptions}\n        inlineDescriptions\n        onChange={handleSelect}\n        onCancel={handleCancel}\n        onFocus={value => {\n          // Reset input mode when navigating away, but only if no text typed\n          const newOption = options.find(opt => opt.value === value)\n          if (\n            newOption?.feedbackConfig?.type !== 'accept' &&\n            acceptInputMode &&\n            !acceptFeedback.trim()\n          ) {\n            setAcceptInputMode(false)\n          }\n          if (\n            newOption?.feedbackConfig?.type !== 'reject' &&\n            rejectInputMode &&\n            !rejectFeedback.trim()\n          ) {\n            setRejectInputMode(false)\n          }\n          setFocusedValue(value)\n        }}\n        onInputModeToggle={handleInputModeToggle}\n      />\n      <Box marginTop={1}>\n        <Text dimColor>Esc to cancel{showTabHint && ' · Tab to amend'}</Text>\n      </Box>\n    </Box>\n  )\n}\n"],"mappings":"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","ignoreList":[]}