source dump of claude code
0
fork

Configure Feed

Select the types of activity you want to include in your feed.

at main 206 lines 24 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import { useCallback, useEffect, useMemo, useRef, useState } from 'react'; 3import { isFeedbackSurveyDisabled } from 'src/services/analytics/config.js'; 4import { checkStatsigFeatureGate_CACHED_MAY_BE_STALE } from 'src/services/analytics/growthbook.js'; 5import { type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, logEvent } from 'src/services/analytics/index.js'; 6import { shouldUseSessionMemoryCompaction } from '../../services/compact/sessionMemoryCompact.js'; 7import type { Message } from '../../types/message.js'; 8import { isEnvTruthy } from '../../utils/envUtils.js'; 9import { isCompactBoundaryMessage } from '../../utils/messages.js'; 10import { logOTelEvent } from '../../utils/telemetry/events.js'; 11import { useSurveyState } from './useSurveyState.js'; 12import type { FeedbackSurveyResponse } from './utils.js'; 13const HIDE_THANKS_AFTER_MS = 3000; 14const POST_COMPACT_SURVEY_GATE = 'tengu_post_compact_survey'; 15const SURVEY_PROBABILITY = 0.2; // Show survey 20% of the time after compaction 16 17function hasMessageAfterBoundary(messages: Message[], boundaryUuid: string): boolean { 18 const boundaryIndex = messages.findIndex(msg => msg.uuid === boundaryUuid); 19 if (boundaryIndex === -1) { 20 return false; 21 } 22 23 // Check if there's a user or assistant message after the boundary 24 for (let i = boundaryIndex + 1; i < messages.length; i++) { 25 const msg = messages[i]; 26 if (msg && (msg.type === 'user' || msg.type === 'assistant')) { 27 return true; 28 } 29 } 30 return false; 31} 32export function usePostCompactSurvey(messages, isLoading, t0, t1) { 33 const $ = _c(23); 34 const hasActivePrompt = t0 === undefined ? false : t0; 35 let t2; 36 if ($[0] !== t1) { 37 t2 = t1 === undefined ? {} : t1; 38 $[0] = t1; 39 $[1] = t2; 40 } else { 41 t2 = $[1]; 42 } 43 const { 44 enabled: t3 45 } = t2; 46 const enabled = t3 === undefined ? true : t3; 47 const [gateEnabled, setGateEnabled] = useState(null); 48 let t4; 49 if ($[2] === Symbol.for("react.memo_cache_sentinel")) { 50 t4 = new Set(); 51 $[2] = t4; 52 } else { 53 t4 = $[2]; 54 } 55 const seenCompactBoundaries = useRef(t4); 56 const pendingCompactBoundaryUuid = useRef(null); 57 const onOpen = _temp; 58 const onSelect = _temp2; 59 let t5; 60 if ($[3] === Symbol.for("react.memo_cache_sentinel")) { 61 t5 = { 62 hideThanksAfterMs: HIDE_THANKS_AFTER_MS, 63 onOpen, 64 onSelect 65 }; 66 $[3] = t5; 67 } else { 68 t5 = $[3]; 69 } 70 const { 71 state, 72 lastResponse, 73 open, 74 handleSelect 75 } = useSurveyState(t5); 76 let t6; 77 let t7; 78 if ($[4] !== enabled) { 79 t6 = () => { 80 if (!enabled) { 81 return; 82 } 83 setGateEnabled(checkStatsigFeatureGate_CACHED_MAY_BE_STALE(POST_COMPACT_SURVEY_GATE)); 84 }; 85 t7 = [enabled]; 86 $[4] = enabled; 87 $[5] = t6; 88 $[6] = t7; 89 } else { 90 t6 = $[5]; 91 t7 = $[6]; 92 } 93 useEffect(t6, t7); 94 let t8; 95 if ($[7] !== messages) { 96 t8 = new Set(messages.filter(_temp3).map(_temp4)); 97 $[7] = messages; 98 $[8] = t8; 99 } else { 100 t8 = $[8]; 101 } 102 const currentCompactBoundaries = t8; 103 let t10; 104 let t9; 105 if ($[9] !== currentCompactBoundaries || $[10] !== enabled || $[11] !== gateEnabled || $[12] !== hasActivePrompt || $[13] !== isLoading || $[14] !== messages || $[15] !== open || $[16] !== state) { 106 t9 = () => { 107 if (!enabled) { 108 return; 109 } 110 if (state !== "closed" || isLoading) { 111 return; 112 } 113 if (hasActivePrompt) { 114 return; 115 } 116 if (gateEnabled !== true) { 117 return; 118 } 119 if (isFeedbackSurveyDisabled()) { 120 return; 121 } 122 if (isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_FEEDBACK_SURVEY)) { 123 return; 124 } 125 if (pendingCompactBoundaryUuid.current !== null) { 126 if (hasMessageAfterBoundary(messages, pendingCompactBoundaryUuid.current)) { 127 pendingCompactBoundaryUuid.current = null; 128 if (Math.random() < SURVEY_PROBABILITY) { 129 open(); 130 } 131 return; 132 } 133 } 134 const newBoundaries = Array.from(currentCompactBoundaries).filter(uuid => !seenCompactBoundaries.current.has(uuid)); 135 if (newBoundaries.length > 0) { 136 seenCompactBoundaries.current = new Set(currentCompactBoundaries); 137 pendingCompactBoundaryUuid.current = newBoundaries[newBoundaries.length - 1]; 138 } 139 }; 140 t10 = [enabled, currentCompactBoundaries, state, isLoading, hasActivePrompt, gateEnabled, messages, open]; 141 $[9] = currentCompactBoundaries; 142 $[10] = enabled; 143 $[11] = gateEnabled; 144 $[12] = hasActivePrompt; 145 $[13] = isLoading; 146 $[14] = messages; 147 $[15] = open; 148 $[16] = state; 149 $[17] = t10; 150 $[18] = t9; 151 } else { 152 t10 = $[17]; 153 t9 = $[18]; 154 } 155 useEffect(t9, t10); 156 let t11; 157 if ($[19] !== handleSelect || $[20] !== lastResponse || $[21] !== state) { 158 t11 = { 159 state, 160 lastResponse, 161 handleSelect 162 }; 163 $[19] = handleSelect; 164 $[20] = lastResponse; 165 $[21] = state; 166 $[22] = t11; 167 } else { 168 t11 = $[22]; 169 } 170 return t11; 171} 172function _temp4(msg_0) { 173 return msg_0.uuid; 174} 175function _temp3(msg) { 176 return isCompactBoundaryMessage(msg); 177} 178function _temp2(appearanceId_0, selected) { 179 const smCompactionEnabled_0 = shouldUseSessionMemoryCompaction(); 180 logEvent("tengu_post_compact_survey_event", { 181 event_type: "responded" as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, 182 appearance_id: appearanceId_0 as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, 183 response: selected as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, 184 session_memory_compaction_enabled: smCompactionEnabled_0 as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS 185 }); 186 logOTelEvent("feedback_survey", { 187 event_type: "responded", 188 appearance_id: appearanceId_0, 189 response: selected, 190 survey_type: "post_compact" 191 }); 192} 193function _temp(appearanceId) { 194 const smCompactionEnabled = shouldUseSessionMemoryCompaction(); 195 logEvent("tengu_post_compact_survey_event", { 196 event_type: "appeared" as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, 197 appearance_id: appearanceId as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, 198 session_memory_compaction_enabled: smCompactionEnabled as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS 199 }); 200 logOTelEvent("feedback_survey", { 201 event_type: "appeared", 202 appearance_id: appearanceId, 203 survey_type: "post_compact" 204 }); 205} 206//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useCallback","useEffect","useMemo","useRef","useState","isFeedbackSurveyDisabled","checkStatsigFeatureGate_CACHED_MAY_BE_STALE","AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS","logEvent","shouldUseSessionMemoryCompaction","Message","isEnvTruthy","isCompactBoundaryMessage","logOTelEvent","useSurveyState","FeedbackSurveyResponse","HIDE_THANKS_AFTER_MS","POST_COMPACT_SURVEY_GATE","SURVEY_PROBABILITY","hasMessageAfterBoundary","messages","boundaryUuid","boundaryIndex","findIndex","msg","uuid","i","length","type","usePostCompactSurvey","isLoading","t0","t1","$","_c","hasActivePrompt","undefined","t2","enabled","t3","gateEnabled","setGateEnabled","t4","Symbol","for","Set","seenCompactBoundaries","pendingCompactBoundaryUuid","onOpen","_temp","onSelect","_temp2","t5","hideThanksAfterMs","state","lastResponse","open","handleSelect","t6","t7","t8","filter","_temp3","map","_temp4","currentCompactBoundaries","t10","t9","process","env","CLAUDE_CODE_DISABLE_FEEDBACK_SURVEY","current","Math","random","newBoundaries","Array","from","has","t11","msg_0","appearanceId_0","selected","smCompactionEnabled_0","event_type","appearance_id","appearanceId","response","session_memory_compaction_enabled","smCompactionEnabled","survey_type"],"sources":["usePostCompactSurvey.tsx"],"sourcesContent":["import { useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { isFeedbackSurveyDisabled } from 'src/services/analytics/config.js'\nimport { checkStatsigFeatureGate_CACHED_MAY_BE_STALE } from 'src/services/analytics/growthbook.js'\nimport {\n  type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  logEvent,\n} from 'src/services/analytics/index.js'\nimport { shouldUseSessionMemoryCompaction } from '../../services/compact/sessionMemoryCompact.js'\nimport type { Message } from '../../types/message.js'\nimport { isEnvTruthy } from '../../utils/envUtils.js'\nimport { isCompactBoundaryMessage } from '../../utils/messages.js'\nimport { logOTelEvent } from '../../utils/telemetry/events.js'\nimport { useSurveyState } from './useSurveyState.js'\nimport type { FeedbackSurveyResponse } from './utils.js'\n\nconst HIDE_THANKS_AFTER_MS = 3000\nconst POST_COMPACT_SURVEY_GATE = 'tengu_post_compact_survey'\nconst SURVEY_PROBABILITY = 0.2 // Show survey 20% of the time after compaction\n\nfunction hasMessageAfterBoundary(\n  messages: Message[],\n  boundaryUuid: string,\n): boolean {\n  const boundaryIndex = messages.findIndex(msg => msg.uuid === boundaryUuid)\n  if (boundaryIndex === -1) {\n    return false\n  }\n\n  // Check if there's a user or assistant message after the boundary\n  for (let i = boundaryIndex + 1; i < messages.length; i++) {\n    const msg = messages[i]\n    if (msg && (msg.type === 'user' || msg.type === 'assistant')) {\n      return true\n    }\n  }\n  return false\n}\n\nexport function usePostCompactSurvey(\n  messages: Message[],\n  isLoading: boolean,\n  hasActivePrompt = false,\n  { enabled = true }: { enabled?: boolean } = {},\n): {\n  state:\n    | 'closed'\n    | 'open'\n    | 'thanks'\n    | 'transcript_prompt'\n    | 'submitting'\n    | 'submitted'\n  lastResponse: FeedbackSurveyResponse | null\n  handleSelect: (selected: FeedbackSurveyResponse) => void\n} {\n  const [gateEnabled, setGateEnabled] = useState<boolean | null>(null)\n  const seenCompactBoundaries = useRef<Set<string>>(new Set())\n  // Track the compact boundary we're waiting on (to show survey after next message)\n  const pendingCompactBoundaryUuid = useRef<string | null>(null)\n\n  const onOpen = useCallback((appearanceId: string) => {\n    const smCompactionEnabled = shouldUseSessionMemoryCompaction()\n    logEvent('tengu_post_compact_survey_event', {\n      event_type:\n        'appeared' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      appearance_id:\n        appearanceId as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      session_memory_compaction_enabled:\n        smCompactionEnabled as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n    })\n    void logOTelEvent('feedback_survey', {\n      event_type: 'appeared',\n      appearance_id: appearanceId,\n      survey_type: 'post_compact',\n    })\n  }, [])\n\n  const onSelect = useCallback(\n    (appearanceId: string, selected: FeedbackSurveyResponse) => {\n      const smCompactionEnabled = shouldUseSessionMemoryCompaction()\n      logEvent('tengu_post_compact_survey_event', {\n        event_type:\n          'responded' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        appearance_id:\n          appearanceId as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        response:\n          selected as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        session_memory_compaction_enabled:\n          smCompactionEnabled as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      })\n      void logOTelEvent('feedback_survey', {\n        event_type: 'responded',\n        appearance_id: appearanceId,\n        response: selected,\n        survey_type: 'post_compact',\n      })\n    },\n    [],\n  )\n\n  const { state, lastResponse, open, handleSelect } = useSurveyState({\n    hideThanksAfterMs: HIDE_THANKS_AFTER_MS,\n    onOpen,\n    onSelect,\n  })\n\n  // Check the feature gate on mount\n  useEffect(() => {\n    if (!enabled) return\n    setGateEnabled(\n      checkStatsigFeatureGate_CACHED_MAY_BE_STALE(POST_COMPACT_SURVEY_GATE),\n    )\n  }, [enabled])\n\n  // Find compact boundary messages\n  const currentCompactBoundaries = useMemo(\n    () =>\n      new Set(\n        messages\n          .filter(msg => isCompactBoundaryMessage(msg))\n          .map(msg => msg.uuid),\n      ),\n    [messages],\n  )\n\n  // Detect new compact boundaries and defer showing survey until next message\n  useEffect(() => {\n    if (!enabled) return\n\n    // Don't process if already showing\n    if (state !== 'closed' || isLoading) {\n      return\n    }\n\n    // Don't show survey when permission or ask question prompts are visible\n    if (hasActivePrompt) {\n      return\n    }\n\n    // Check if the gate is enabled\n    if (gateEnabled !== true) {\n      return\n    }\n\n    if (isFeedbackSurveyDisabled()) {\n      return\n    }\n\n    // Check if survey is explicitly disabled\n    if (isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_FEEDBACK_SURVEY)) {\n      return\n    }\n\n    // First, check if we have a pending compact and a new message has arrived\n    if (pendingCompactBoundaryUuid.current !== null) {\n      if (\n        hasMessageAfterBoundary(messages, pendingCompactBoundaryUuid.current)\n      ) {\n        // A new message arrived after the compact - decide whether to show survey\n        pendingCompactBoundaryUuid.current = null\n\n        // Only show survey 20% of the time\n        if (Math.random() < SURVEY_PROBABILITY) {\n          open()\n        }\n        return\n      }\n    }\n\n    // Find new compact boundaries that we haven't seen yet\n    const newBoundaries = Array.from(currentCompactBoundaries).filter(\n      uuid => !seenCompactBoundaries.current.has(uuid),\n    )\n\n    if (newBoundaries.length > 0) {\n      // Mark these boundaries as seen\n      seenCompactBoundaries.current = new Set(currentCompactBoundaries)\n\n      // Don't show survey immediately - wait for next message\n      // Store the most recent new boundary UUID\n      pendingCompactBoundaryUuid.current =\n        newBoundaries[newBoundaries.length - 1]!\n    }\n  }, [\n    enabled,\n    currentCompactBoundaries,\n    state,\n    isLoading,\n    hasActivePrompt,\n    gateEnabled,\n    messages,\n    open,\n  ])\n\n  return { state, lastResponse, handleSelect }\n}\n"],"mappings":"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","ignoreList":[]}