/ components / memory / MemoryFileSelector.tsx
MemoryFileSelector.tsx
  1  import { c as _c } from "react/compiler-runtime";
  2  import { feature } from 'bun:bundle';
  3  import chalk from 'chalk';
  4  import { mkdir } from 'fs/promises';
  5  import { join } from 'path';
  6  import * as React from 'react';
  7  import { use, useEffect, useState } from 'react';
  8  import { getOriginalCwd } from '../../bootstrap/state.js';
  9  import { useExitOnCtrlCDWithKeybindings } from '../../hooks/useExitOnCtrlCDWithKeybindings.js';
 10  import { Box, Text } from '../../ink.js';
 11  import { useKeybinding } from '../../keybindings/useKeybinding.js';
 12  import { getAutoMemPath, isAutoMemoryEnabled } from '../../memdir/paths.js';
 13  import { logEvent } from '../../services/analytics/index.js';
 14  import { isAutoDreamEnabled } from '../../services/autoDream/config.js';
 15  import { readLastConsolidatedAt } from '../../services/autoDream/consolidationLock.js';
 16  import { useAppState } from '../../state/AppState.js';
 17  import { getAgentMemoryDir } from '../../tools/AgentTool/agentMemory.js';
 18  import { openPath } from '../../utils/browser.js';
 19  import { getMemoryFiles, type MemoryFileInfo } from '../../utils/claudemd.js';
 20  import { getClaudeConfigHomeDir } from '../../utils/envUtils.js';
 21  import { getDisplayPath } from '../../utils/file.js';
 22  import { formatRelativeTimeAgo } from '../../utils/format.js';
 23  import { projectIsInGitRepo } from '../../utils/memory/versions.js';
 24  import { updateSettingsForSource } from '../../utils/settings/settings.js';
 25  import { Select } from '../CustomSelect/index.js';
 26  import { ListItem } from '../design-system/ListItem.js';
 27  
 28  /* eslint-disable @typescript-eslint/no-require-imports */
 29  const teamMemPaths = feature('TEAMMEM') ? require('../../memdir/teamMemPaths.js') as typeof import('../../memdir/teamMemPaths.js') : null;
 30  /* eslint-enable @typescript-eslint/no-require-imports */
 31  
 32  interface ExtendedMemoryFileInfo extends MemoryFileInfo {
 33    isNested?: boolean;
 34    exists: boolean;
 35  }
 36  
 37  // Remember last selected path
 38  let lastSelectedPath: string | undefined;
 39  const OPEN_FOLDER_PREFIX = '__open_folder__';
 40  type Props = {
 41    onSelect: (path: string) => void;
 42    onCancel: () => void;
 43  };
 44  export function MemoryFileSelector(t0) {
 45    const $ = _c(58);
 46    const {
 47      onSelect,
 48      onCancel
 49    } = t0;
 50    const existingMemoryFiles = use(getMemoryFiles());
 51    const userMemoryPath = join(getClaudeConfigHomeDir(), "CLAUDE.md");
 52    const projectMemoryPath = join(getOriginalCwd(), "CLAUDE.md");
 53    const hasUserMemory = existingMemoryFiles.some(f => f.path === userMemoryPath);
 54    const hasProjectMemory = existingMemoryFiles.some(f_0 => f_0.path === projectMemoryPath);
 55    const allMemoryFiles = [...existingMemoryFiles.filter(_temp).map(_temp2), ...(hasUserMemory ? [] : [{
 56      path: userMemoryPath,
 57      type: "User" as const,
 58      content: "",
 59      exists: false
 60    }]), ...(hasProjectMemory ? [] : [{
 61      path: projectMemoryPath,
 62      type: "Project" as const,
 63      content: "",
 64      exists: false
 65    }])];
 66    const depths = new Map();
 67    const memoryOptions = allMemoryFiles.map(file => {
 68      const displayPath = getDisplayPath(file.path);
 69      const existsLabel = file.exists ? "" : " (new)";
 70      const depth = file.parent ? (depths.get(file.parent) ?? 0) + 1 : 0;
 71      depths.set(file.path, depth);
 72      const indent = depth > 0 ? "  ".repeat(depth - 1) : "";
 73      let label;
 74      if (file.type === "User" && !file.isNested && file.path === userMemoryPath) {
 75        label = "User memory";
 76      } else {
 77        if (file.type === "Project" && !file.isNested && file.path === projectMemoryPath) {
 78          label = "Project memory";
 79        } else {
 80          if (depth > 0) {
 81            label = `${indent}L ${displayPath}${existsLabel}`;
 82          } else {
 83            label = `${displayPath}`;
 84          }
 85        }
 86      }
 87      let description;
 88      const isGit = projectIsInGitRepo(getOriginalCwd());
 89      if (file.type === "User" && !file.isNested) {
 90        description = "Saved in ~/.claude/CLAUDE.md";
 91      } else {
 92        if (file.type === "Project" && !file.isNested && file.path === projectMemoryPath) {
 93          description = `${isGit ? "Checked in at" : "Saved in"} ./CLAUDE.md`;
 94        } else {
 95          if (file.parent) {
 96            description = "@-imported";
 97          } else {
 98            if (file.isNested) {
 99              description = "dynamically loaded";
100            } else {
101              description = "";
102            }
103          }
104        }
105      }
106      return {
107        label,
108        value: file.path,
109        description
110      };
111    });
112    const folderOptions = [];
113    const agentDefinitions = useAppState(_temp3);
114    if (isAutoMemoryEnabled()) {
115      let t1;
116      if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
117        t1 = {
118          label: "Open auto-memory folder",
119          value: `${OPEN_FOLDER_PREFIX}${getAutoMemPath()}`,
120          description: ""
121        };
122        $[0] = t1;
123      } else {
124        t1 = $[0];
125      }
126      folderOptions.push(t1);
127      if (feature("TEAMMEM") && teamMemPaths.isTeamMemoryEnabled()) {
128        let t2;
129        if ($[1] === Symbol.for("react.memo_cache_sentinel")) {
130          t2 = {
131            label: "Open team memory folder",
132            value: `${OPEN_FOLDER_PREFIX}${teamMemPaths.getTeamMemPath()}`,
133            description: ""
134          };
135          $[1] = t2;
136        } else {
137          t2 = $[1];
138        }
139        folderOptions.push(t2);
140      }
141      for (const agent of agentDefinitions.activeAgents) {
142        if (agent.memory) {
143          const agentDir = getAgentMemoryDir(agent.agentType, agent.memory);
144          folderOptions.push({
145            label: `Open ${chalk.bold(agent.agentType)} agent memory`,
146            value: `${OPEN_FOLDER_PREFIX}${agentDir}`,
147            description: `${agent.memory} scope`
148          });
149        }
150      }
151    }
152    memoryOptions.push(...folderOptions);
153    let t1;
154    if ($[2] !== memoryOptions) {
155      t1 = lastSelectedPath && memoryOptions.some(_temp4) ? lastSelectedPath : memoryOptions[0]?.value || "";
156      $[2] = memoryOptions;
157      $[3] = t1;
158    } else {
159      t1 = $[3];
160    }
161    const initialPath = t1;
162    const [autoMemoryOn, setAutoMemoryOn] = useState(isAutoMemoryEnabled);
163    const [autoDreamOn, setAutoDreamOn] = useState(isAutoDreamEnabled);
164    const [showDreamRow] = useState(isAutoMemoryEnabled);
165    const isDreamRunning = useAppState(_temp6);
166    const [lastDreamAt, setLastDreamAt] = useState(null);
167    let t2;
168    if ($[4] !== showDreamRow) {
169      t2 = () => {
170        if (!showDreamRow) {
171          return;
172        }
173        readLastConsolidatedAt().then(setLastDreamAt);
174      };
175      $[4] = showDreamRow;
176      $[5] = t2;
177    } else {
178      t2 = $[5];
179    }
180    let t3;
181    if ($[6] !== isDreamRunning || $[7] !== showDreamRow) {
182      t3 = [showDreamRow, isDreamRunning];
183      $[6] = isDreamRunning;
184      $[7] = showDreamRow;
185      $[8] = t3;
186    } else {
187      t3 = $[8];
188    }
189    useEffect(t2, t3);
190    let t4;
191    if ($[9] !== isDreamRunning || $[10] !== lastDreamAt) {
192      t4 = isDreamRunning ? "running" : lastDreamAt === null ? "" : lastDreamAt === 0 ? "never" : `last ran ${formatRelativeTimeAgo(new Date(lastDreamAt))}`;
193      $[9] = isDreamRunning;
194      $[10] = lastDreamAt;
195      $[11] = t4;
196    } else {
197      t4 = $[11];
198    }
199    const dreamStatus = t4;
200    const [focusedToggle, setFocusedToggle] = useState(null);
201    const toggleFocused = focusedToggle !== null;
202    const lastToggleIndex = showDreamRow ? 1 : 0;
203    let t5;
204    if ($[12] !== autoMemoryOn) {
205      t5 = function handleToggleAutoMemory() {
206        const newValue = !autoMemoryOn;
207        updateSettingsForSource("userSettings", {
208          autoMemoryEnabled: newValue
209        });
210        setAutoMemoryOn(newValue);
211        logEvent("tengu_auto_memory_toggled", {
212          enabled: newValue
213        });
214      };
215      $[12] = autoMemoryOn;
216      $[13] = t5;
217    } else {
218      t5 = $[13];
219    }
220    const handleToggleAutoMemory = t5;
221    let t6;
222    if ($[14] !== autoDreamOn) {
223      t6 = function handleToggleAutoDream() {
224        const newValue_0 = !autoDreamOn;
225        updateSettingsForSource("userSettings", {
226          autoDreamEnabled: newValue_0
227        });
228        setAutoDreamOn(newValue_0);
229        logEvent("tengu_auto_dream_toggled", {
230          enabled: newValue_0
231        });
232      };
233      $[14] = autoDreamOn;
234      $[15] = t6;
235    } else {
236      t6 = $[15];
237    }
238    const handleToggleAutoDream = t6;
239    useExitOnCtrlCDWithKeybindings();
240    let t7;
241    if ($[16] === Symbol.for("react.memo_cache_sentinel")) {
242      t7 = {
243        context: "Confirmation"
244      };
245      $[16] = t7;
246    } else {
247      t7 = $[16];
248    }
249    useKeybinding("confirm:no", onCancel, t7);
250    let t8;
251    if ($[17] !== focusedToggle || $[18] !== handleToggleAutoDream || $[19] !== handleToggleAutoMemory) {
252      t8 = () => {
253        if (focusedToggle === 0) {
254          handleToggleAutoMemory();
255        } else {
256          if (focusedToggle === 1) {
257            handleToggleAutoDream();
258          }
259        }
260      };
261      $[17] = focusedToggle;
262      $[18] = handleToggleAutoDream;
263      $[19] = handleToggleAutoMemory;
264      $[20] = t8;
265    } else {
266      t8 = $[20];
267    }
268    let t9;
269    if ($[21] !== toggleFocused) {
270      t9 = {
271        context: "Confirmation",
272        isActive: toggleFocused
273      };
274      $[21] = toggleFocused;
275      $[22] = t9;
276    } else {
277      t9 = $[22];
278    }
279    useKeybinding("confirm:yes", t8, t9);
280    let t10;
281    if ($[23] !== lastToggleIndex) {
282      t10 = () => {
283        setFocusedToggle(prev => prev !== null && prev < lastToggleIndex ? prev + 1 : null);
284      };
285      $[23] = lastToggleIndex;
286      $[24] = t10;
287    } else {
288      t10 = $[24];
289    }
290    let t11;
291    if ($[25] !== toggleFocused) {
292      t11 = {
293        context: "Select",
294        isActive: toggleFocused
295      };
296      $[25] = toggleFocused;
297      $[26] = t11;
298    } else {
299      t11 = $[26];
300    }
301    useKeybinding("select:next", t10, t11);
302    let t12;
303    if ($[27] === Symbol.for("react.memo_cache_sentinel")) {
304      t12 = () => {
305        setFocusedToggle(_temp7);
306      };
307      $[27] = t12;
308    } else {
309      t12 = $[27];
310    }
311    let t13;
312    if ($[28] !== toggleFocused) {
313      t13 = {
314        context: "Select",
315        isActive: toggleFocused
316      };
317      $[28] = toggleFocused;
318      $[29] = t13;
319    } else {
320      t13 = $[29];
321    }
322    useKeybinding("select:previous", t12, t13);
323    const t14 = focusedToggle === 0;
324    const t15 = autoMemoryOn ? "on" : "off";
325    let t16;
326    if ($[30] !== t15) {
327      t16 = <Text>Auto-memory: {t15}</Text>;
328      $[30] = t15;
329      $[31] = t16;
330    } else {
331      t16 = $[31];
332    }
333    let t17;
334    if ($[32] !== t14 || $[33] !== t16) {
335      t17 = <ListItem isFocused={t14}>{t16}</ListItem>;
336      $[32] = t14;
337      $[33] = t16;
338      $[34] = t17;
339    } else {
340      t17 = $[34];
341    }
342    let t18;
343    if ($[35] !== autoDreamOn || $[36] !== dreamStatus || $[37] !== focusedToggle || $[38] !== isDreamRunning || $[39] !== showDreamRow) {
344      t18 = showDreamRow && <ListItem isFocused={focusedToggle === 1} styled={false}><Text color={focusedToggle === 1 ? "suggestion" : undefined}>Auto-dream: {autoDreamOn ? "on" : "off"}{dreamStatus && <Text dimColor={true}> · {dreamStatus}</Text>}{!isDreamRunning && autoDreamOn && <Text dimColor={true}> · /dream to run</Text>}</Text></ListItem>;
345      $[35] = autoDreamOn;
346      $[36] = dreamStatus;
347      $[37] = focusedToggle;
348      $[38] = isDreamRunning;
349      $[39] = showDreamRow;
350      $[40] = t18;
351    } else {
352      t18 = $[40];
353    }
354    let t19;
355    if ($[41] !== t17 || $[42] !== t18) {
356      t19 = <Box flexDirection="column" marginBottom={1}>{t17}{t18}</Box>;
357      $[41] = t17;
358      $[42] = t18;
359      $[43] = t19;
360    } else {
361      t19 = $[43];
362    }
363    let t20;
364    if ($[44] !== onSelect) {
365      t20 = value => {
366        if (value.startsWith(OPEN_FOLDER_PREFIX)) {
367          const folderPath = value.slice(OPEN_FOLDER_PREFIX.length);
368          mkdir(folderPath, {
369            recursive: true
370          }).catch(_temp8).then(() => openPath(folderPath));
371          return;
372        }
373        lastSelectedPath = value;
374        onSelect(value);
375      };
376      $[44] = onSelect;
377      $[45] = t20;
378    } else {
379      t20 = $[45];
380    }
381    let t21;
382    if ($[46] !== lastToggleIndex) {
383      t21 = () => setFocusedToggle(lastToggleIndex);
384      $[46] = lastToggleIndex;
385      $[47] = t21;
386    } else {
387      t21 = $[47];
388    }
389    let t22;
390    if ($[48] !== initialPath || $[49] !== memoryOptions || $[50] !== onCancel || $[51] !== t20 || $[52] !== t21 || $[53] !== toggleFocused) {
391      t22 = <Select defaultFocusValue={initialPath} options={memoryOptions} isDisabled={toggleFocused} onChange={t20} onCancel={onCancel} onUpFromFirstItem={t21} />;
392      $[48] = initialPath;
393      $[49] = memoryOptions;
394      $[50] = onCancel;
395      $[51] = t20;
396      $[52] = t21;
397      $[53] = toggleFocused;
398      $[54] = t22;
399    } else {
400      t22 = $[54];
401    }
402    let t23;
403    if ($[55] !== t19 || $[56] !== t22) {
404      t23 = <Box flexDirection="column" width="100%">{t19}{t22}</Box>;
405      $[55] = t19;
406      $[56] = t22;
407      $[57] = t23;
408    } else {
409      t23 = $[57];
410    }
411    return t23;
412  }
413  function _temp8() {}
414  function _temp7(prev_0) {
415    return prev_0 !== null && prev_0 > 0 ? prev_0 - 1 : prev_0;
416  }
417  function _temp6(s_0) {
418    return Object.values(s_0.tasks).some(_temp5);
419  }
420  function _temp5(t) {
421    return t.type === "dream" && t.status === "running";
422  }
423  function _temp4(opt) {
424    return opt.value === lastSelectedPath;
425  }
426  function _temp3(s) {
427    return s.agentDefinitions;
428  }
429  function _temp2(f_2) {
430    return {
431      ...f_2,
432      exists: true
433    };
434  }
435  function _temp(f_1) {
436    return f_1.type !== "AutoMem" && f_1.type !== "TeamMem";
437  }
438  //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["feature","chalk","mkdir","join","React","use","useEffect","useState","getOriginalCwd","useExitOnCtrlCDWithKeybindings","Box","Text","useKeybinding","getAutoMemPath","isAutoMemoryEnabled","logEvent","isAutoDreamEnabled","readLastConsolidatedAt","useAppState","getAgentMemoryDir","openPath","getMemoryFiles","MemoryFileInfo","getClaudeConfigHomeDir","getDisplayPath","formatRelativeTimeAgo","projectIsInGitRepo","updateSettingsForSource","Select","ListItem","teamMemPaths","require","ExtendedMemoryFileInfo","isNested","exists","lastSelectedPath","OPEN_FOLDER_PREFIX","Props","onSelect","path","onCancel","MemoryFileSelector","t0","$","_c","existingMemoryFiles","userMemoryPath","projectMemoryPath","hasUserMemory","some","f","hasProjectMemory","f_0","allMemoryFiles","filter","_temp","map","_temp2","type","const","content","depths","Map","memoryOptions","file","displayPath","existsLabel","depth","parent","get","set","indent","repeat","label","description","isGit","value","folderOptions","agentDefinitions","_temp3","t1","Symbol","for","push","isTeamMemoryEnabled","t2","getTeamMemPath","agent","activeAgents","memory","agentDir","agentType","bold","_temp4","initialPath","autoMemoryOn","setAutoMemoryOn","autoDreamOn","setAutoDreamOn","showDreamRow","isDreamRunning","_temp6","lastDreamAt","setLastDreamAt","then","t3","t4","Date","dreamStatus","focusedToggle","setFocusedToggle","toggleFocused","lastToggleIndex","t5","handleToggleAutoMemory","newValue","autoMemoryEnabled","enabled","t6","handleToggleAutoDream","newValue_0","autoDreamEnabled","t7","context","t8","t9","isActive","t10","prev","t11","t12","_temp7","t13","t14","t15","t16","t17","t18","undefined","t19","t20","startsWith","folderPath","slice","length","recursive","catch","_temp8","t21","t22","t23","prev_0","s_0","Object","values","s","tasks","_temp5","t","status","opt","f_2","f_1"],"sources":["MemoryFileSelector.tsx"],"sourcesContent":["import { feature } from 'bun:bundle'\nimport chalk from 'chalk'\nimport { mkdir } from 'fs/promises'\nimport { join } from 'path'\nimport * as React from 'react'\nimport { use, useEffect, useState } from 'react'\nimport { getOriginalCwd } from '../../bootstrap/state.js'\nimport { useExitOnCtrlCDWithKeybindings } from '../../hooks/useExitOnCtrlCDWithKeybindings.js'\nimport { Box, Text } from '../../ink.js'\nimport { useKeybinding } from '../../keybindings/useKeybinding.js'\nimport { getAutoMemPath, isAutoMemoryEnabled } from '../../memdir/paths.js'\nimport { logEvent } from '../../services/analytics/index.js'\nimport { isAutoDreamEnabled } from '../../services/autoDream/config.js'\nimport { readLastConsolidatedAt } from '../../services/autoDream/consolidationLock.js'\nimport { useAppState } from '../../state/AppState.js'\nimport { getAgentMemoryDir } from '../../tools/AgentTool/agentMemory.js'\nimport { openPath } from '../../utils/browser.js'\nimport { getMemoryFiles, type MemoryFileInfo } from '../../utils/claudemd.js'\nimport { getClaudeConfigHomeDir } from '../../utils/envUtils.js'\nimport { getDisplayPath } from '../../utils/file.js'\nimport { formatRelativeTimeAgo } from '../../utils/format.js'\nimport { projectIsInGitRepo } from '../../utils/memory/versions.js'\nimport { updateSettingsForSource } from '../../utils/settings/settings.js'\nimport { Select } from '../CustomSelect/index.js'\nimport { ListItem } from '../design-system/ListItem.js'\n\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst teamMemPaths = feature('TEAMMEM')\n  ? (require('../../memdir/teamMemPaths.js') as typeof import('../../memdir/teamMemPaths.js'))\n  : null\n/* eslint-enable @typescript-eslint/no-require-imports */\n\ninterface ExtendedMemoryFileInfo extends MemoryFileInfo {\n  isNested?: boolean\n  exists: boolean\n}\n\n// Remember last selected path\nlet lastSelectedPath: string | undefined\n\nconst OPEN_FOLDER_PREFIX = '__open_folder__'\n\ntype Props = {\n  onSelect: (path: string) => void\n  onCancel: () => void\n}\n\nexport function MemoryFileSelector({\n  onSelect,\n  onCancel,\n}: Props): React.ReactNode {\n  const existingMemoryFiles = use(getMemoryFiles())\n\n  // Create entries for User and Project CLAUDE.md even if they don't exist\n  const userMemoryPath = join(getClaudeConfigHomeDir(), 'CLAUDE.md')\n  const projectMemoryPath = join(getOriginalCwd(), 'CLAUDE.md')\n\n  // Check if these are already in the existing files\n  const hasUserMemory = existingMemoryFiles.some(f => f.path === userMemoryPath)\n  const hasProjectMemory = existingMemoryFiles.some(\n    f => f.path === projectMemoryPath,\n  )\n\n  // Filter out AutoMem/TeamMem entrypoints: these are MEMORY.md files, and\n  // /memory already surfaces \"Open auto-memory folder\" / \"Open team memory\n  // folder\" options below. Listing the entrypoint file separately is redundant.\n  const allMemoryFiles: ExtendedMemoryFileInfo[] = [\n    ...existingMemoryFiles\n      .filter(f => f.type !== 'AutoMem' && f.type !== 'TeamMem')\n      .map(f => ({ ...f, exists: true })),\n    // Add User memory if it doesn't exist\n    ...(hasUserMemory\n      ? []\n      : [\n          {\n            path: userMemoryPath,\n            type: 'User' as const,\n            content: '',\n            exists: false,\n          },\n        ]),\n    // Add Project memory if it doesn't exist\n    ...(hasProjectMemory\n      ? []\n      : [\n          {\n            path: projectMemoryPath,\n            type: 'Project' as const,\n            content: '',\n            exists: false,\n          },\n        ]),\n  ]\n\n  const depths = new Map<string, number>()\n\n  // Create options for the select component\n  const memoryOptions = allMemoryFiles.map(file => {\n    const displayPath = getDisplayPath(file.path)\n    const existsLabel = file.exists ? '' : ' (new)'\n\n    // Calculate depth based on parent\n    const depth = file.parent ? (depths.get(file.parent) ?? 0) + 1 : 0\n    depths.set(file.path, depth)\n    const indent = depth > 0 ? '  '.repeat(depth - 1) : ''\n\n    // Format label based on type\n    let label: string\n    if (\n      file.type === 'User' &&\n      !file.isNested &&\n      file.path === userMemoryPath\n    ) {\n      label = `User memory`\n    } else if (\n      file.type === 'Project' &&\n      !file.isNested &&\n      file.path === projectMemoryPath\n    ) {\n      label = `Project memory`\n    } else if (depth > 0) {\n      // For child nodes (imported files), show indented with L\n      label = `${indent}L ${displayPath}${existsLabel}`\n    } else {\n      // For other memory files, just show the path\n      label = `${displayPath}`\n    }\n\n    // Create description based on type - keep the original descriptions for built-in types\n    let description: string\n    const isGit = projectIsInGitRepo(getOriginalCwd())\n\n    if (file.type === 'User' && !file.isNested) {\n      description = 'Saved in ~/.claude/CLAUDE.md'\n    } else if (\n      file.type === 'Project' &&\n      !file.isNested &&\n      file.path === projectMemoryPath\n    ) {\n      description = `${isGit ? 'Checked in at' : 'Saved in'} ./CLAUDE.md`\n    } else if (file.parent) {\n      // For imported files (with @-import)\n      description = '@-imported'\n    } else if (file.isNested) {\n      // For nested files (dynamically loaded)\n      description = 'dynamically loaded'\n    } else {\n      description = ''\n    }\n\n    return {\n      label,\n      value: file.path,\n      description,\n    }\n  })\n\n  // Add \"Open folder\" options for auto-memory and agent memory directories\n  const folderOptions: Array<{\n    label: string\n    value: string\n    description: string\n  }> = []\n\n  const agentDefinitions = useAppState(s => s.agentDefinitions)\n  if (isAutoMemoryEnabled()) {\n    // Always show auto-memory folder option\n    folderOptions.push({\n      label: 'Open auto-memory folder',\n      value: `${OPEN_FOLDER_PREFIX}${getAutoMemPath()}`,\n      description: '',\n    })\n\n    // Team memory directly below auto-memory (team dir is a subdir of auto dir)\n    if (feature('TEAMMEM') && teamMemPaths!.isTeamMemoryEnabled()) {\n      folderOptions.push({\n        label: 'Open team memory folder',\n        value: `${OPEN_FOLDER_PREFIX}${teamMemPaths!.getTeamMemPath()}`,\n        description: '',\n      })\n    }\n\n    // Add agent memory folders for agents that have memory configured\n    for (const agent of agentDefinitions.activeAgents) {\n      if (agent.memory) {\n        const agentDir = getAgentMemoryDir(agent.agentType, agent.memory)\n        folderOptions.push({\n          label: `Open ${chalk.bold(agent.agentType)} agent memory`,\n          value: `${OPEN_FOLDER_PREFIX}${agentDir}`,\n          description: `${agent.memory} scope`,\n        })\n      }\n    }\n  }\n\n  memoryOptions.push(...folderOptions)\n\n  // Initialize with last selected path if it's still in the options, otherwise use first option\n  const initialPath =\n    lastSelectedPath &&\n    memoryOptions.some(opt => opt.value === lastSelectedPath)\n      ? lastSelectedPath\n      : memoryOptions[0]?.value || ''\n\n  // Toggle state (local copy of settings so the UI updates immediately)\n  const [autoMemoryOn, setAutoMemoryOn] = useState(isAutoMemoryEnabled)\n  const [autoDreamOn, setAutoDreamOn] = useState(isAutoDreamEnabled)\n\n  // Dream row is only meaningful when auto-memory is on (dream consolidates\n  // that dir). Snapshot at mount so the row doesn't vanish mid-navigation\n  // if the user toggles auto-memory off.\n  const [showDreamRow] = useState(isAutoMemoryEnabled)\n\n  // Dream status: prefer live task state (this session fired it), fall back\n  // to the cross-process lock mtime.\n  const isDreamRunning = useAppState(s =>\n    Object.values(s.tasks).some(\n      t => t.type === 'dream' && t.status === 'running',\n    ),\n  )\n  const [lastDreamAt, setLastDreamAt] = useState<number | null>(null)\n  useEffect(() => {\n    if (!showDreamRow) return\n    void readLastConsolidatedAt().then(setLastDreamAt)\n  }, [showDreamRow, isDreamRunning])\n\n  const dreamStatus = isDreamRunning\n    ? 'running'\n    : lastDreamAt === null\n      ? '' // stat in flight\n      : lastDreamAt === 0\n        ? 'never'\n        : `last ran ${formatRelativeTimeAgo(new Date(lastDreamAt))}`\n\n  // null = Select has focus, 0 = auto-memory, 1 = auto-dream (if showDreamRow)\n  const [focusedToggle, setFocusedToggle] = useState<number | null>(null)\n  const toggleFocused = focusedToggle !== null\n  const lastToggleIndex = showDreamRow ? 1 : 0\n\n  function handleToggleAutoMemory(): void {\n    const newValue = !autoMemoryOn\n    updateSettingsForSource('userSettings', { autoMemoryEnabled: newValue })\n    setAutoMemoryOn(newValue)\n    logEvent('tengu_auto_memory_toggled', { enabled: newValue })\n  }\n\n  function handleToggleAutoDream(): void {\n    const newValue = !autoDreamOn\n    updateSettingsForSource('userSettings', { autoDreamEnabled: newValue })\n    setAutoDreamOn(newValue)\n    logEvent('tengu_auto_dream_toggled', { enabled: newValue })\n  }\n\n  useExitOnCtrlCDWithKeybindings()\n\n  useKeybinding('confirm:no', onCancel, { context: 'Confirmation' })\n\n  useKeybinding(\n    'confirm:yes',\n    () => {\n      if (focusedToggle === 0) handleToggleAutoMemory()\n      else if (focusedToggle === 1) handleToggleAutoDream()\n    },\n    { context: 'Confirmation', isActive: toggleFocused },\n  )\n  useKeybinding(\n    'select:next',\n    () => {\n      setFocusedToggle(prev =>\n        prev !== null && prev < lastToggleIndex ? prev + 1 : null,\n      )\n    },\n    { context: 'Select', isActive: toggleFocused },\n  )\n  useKeybinding(\n    'select:previous',\n    () => {\n      setFocusedToggle(prev => (prev !== null && prev > 0 ? prev - 1 : prev))\n    },\n    { context: 'Select', isActive: toggleFocused },\n  )\n\n  return (\n    <Box flexDirection=\"column\" width=\"100%\">\n      <Box flexDirection=\"column\" marginBottom={1}>\n        <ListItem isFocused={focusedToggle === 0}>\n          <Text>Auto-memory: {autoMemoryOn ? 'on' : 'off'}</Text>\n        </ListItem>\n        {showDreamRow && (\n          <ListItem isFocused={focusedToggle === 1} styled={false}>\n            <Text color={focusedToggle === 1 ? 'suggestion' : undefined}>\n              Auto-dream: {autoDreamOn ? 'on' : 'off'}\n              {dreamStatus && <Text dimColor> · {dreamStatus}</Text>}\n              {!isDreamRunning && autoDreamOn && (\n                <Text dimColor> · /dream to run</Text>\n              )}\n            </Text>\n          </ListItem>\n        )}\n      </Box>\n\n      <Select\n        defaultFocusValue={initialPath}\n        options={memoryOptions}\n        isDisabled={toggleFocused}\n        onChange={value => {\n          if (value.startsWith(OPEN_FOLDER_PREFIX)) {\n            const folderPath = value.slice(OPEN_FOLDER_PREFIX.length)\n            // Ensure folder exists before opening (idempotent; swallow\n            // permission errors to match previous behavior)\n            void mkdir(folderPath, { recursive: true })\n              .catch(() => {})\n              .then(() => openPath(folderPath))\n            return\n          }\n          lastSelectedPath = value // Remember the selection\n          onSelect(value)\n        }}\n        onCancel={onCancel}\n        onUpFromFirstItem={() => setFocusedToggle(lastToggleIndex)}\n      />\n    </Box>\n  )\n}\n"],"mappings":";AAAA,SAASA,OAAO,QAAQ,YAAY;AACpC,OAAOC,KAAK,MAAM,OAAO;AACzB,SAASC,KAAK,QAAQ,aAAa;AACnC,SAASC,IAAI,QAAQ,MAAM;AAC3B,OAAO,KAAKC,KAAK,MAAM,OAAO;AAC9B,SAASC,GAAG,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAChD,SAASC,cAAc,QAAQ,0BAA0B;AACzD,SAASC,8BAA8B,QAAQ,+CAA+C;AAC9F,SAASC,GAAG,EAAEC,IAAI,QAAQ,cAAc;AACxC,SAASC,aAAa,QAAQ,oCAAoC;AAClE,SAASC,cAAc,EAAEC,mBAAmB,QAAQ,uBAAuB;AAC3E,SAASC,QAAQ,QAAQ,mCAAmC;AAC5D,SAASC,kBAAkB,QAAQ,oCAAoC;AACvE,SAASC,sBAAsB,QAAQ,+CAA+C;AACtF,SAASC,WAAW,QAAQ,yBAAyB;AACrD,SAASC,iBAAiB,QAAQ,sCAAsC;AACxE,SAASC,QAAQ,QAAQ,wBAAwB;AACjD,SAASC,cAAc,EAAE,KAAKC,cAAc,QAAQ,yBAAyB;AAC7E,SAASC,sBAAsB,QAAQ,yBAAyB;AAChE,SAASC,cAAc,QAAQ,qBAAqB;AACpD,SAASC,qBAAqB,QAAQ,uBAAuB;AAC7D,SAASC,kBAAkB,QAAQ,gCAAgC;AACnE,SAASC,uBAAuB,QAAQ,kCAAkC;AAC1E,SAASC,MAAM,QAAQ,0BAA0B;AACjD,SAASC,QAAQ,QAAQ,8BAA8B;;AAEvD;AACA,MAAMC,YAAY,GAAG9B,OAAO,CAAC,SAAS,CAAC,GAClC+B,OAAO,CAAC,8BAA8B,CAAC,IAAI,OAAO,OAAO,8BAA8B,CAAC,GACzF,IAAI;AACR;;AAEA,UAAUC,sBAAsB,SAASV,cAAc,CAAC;EACtDW,QAAQ,CAAC,EAAE,OAAO;EAClBC,MAAM,EAAE,OAAO;AACjB;;AAEA;AACA,IAAIC,gBAAgB,EAAE,MAAM,GAAG,SAAS;AAExC,MAAMC,kBAAkB,GAAG,iBAAiB;AAE5C,KAAKC,KAAK,GAAG;EACXC,QAAQ,EAAE,CAACC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI;EAChCC,QAAQ,EAAE,GAAG,GAAG,IAAI;AACtB,CAAC;AAED,OAAO,SAAAC,mBAAAC,EAAA;EAAA,MAAAC,CAAA,GAAAC,EAAA;EAA4B;IAAAN,QAAA;IAAAE;EAAA,IAAAE,EAG3B;EACN,MAAAG,mBAAA,GAA4BxC,GAAG,CAACgB,cAAc,CAAC,CAAC,CAAC;EAGjD,MAAAyB,cAAA,GAAuB3C,IAAI,CAACoB,sBAAsB,CAAC,CAAC,EAAE,WAAW,CAAC;EAClE,MAAAwB,iBAAA,GAA0B5C,IAAI,CAACK,cAAc,CAAC,CAAC,EAAE,WAAW,CAAC;EAG7D,MAAAwC,aAAA,GAAsBH,mBAAmB,CAAAI,IAAK,CAACC,CAAA,IAAKA,CAAC,CAAAX,IAAK,KAAKO,cAAc,CAAC;EAC9E,MAAAK,gBAAA,GAAyBN,mBAAmB,CAAAI,IAAK,CAC/CG,GAAA,IAAKF,GAAC,CAAAX,IAAK,KAAKQ,iBAClB,CAAC;EAKD,MAAAM,cAAA,GAAiD,IAC5CR,mBAAmB,CAAAS,MACb,CAACC,KAAiD,CAAC,CAAAC,GACtD,CAACC,MAA6B,CAAC,MAEjCT,aAAa,GAAb,EASC,GATD,CAGE;IAAAT,IAAA,EACQO,cAAc;IAAAY,IAAA,EACd,MAAM,IAAIC,KAAK;IAAAC,OAAA,EACZ,EAAE;IAAA1B,MAAA,EACH;EACV,CAAC,CACF,OAEDiB,gBAAgB,GAAhB,EASC,GATD,CAGE;IAAAZ,IAAA,EACQQ,iBAAiB;IAAAW,IAAA,EACjB,SAAS,IAAIC,KAAK;IAAAC,OAAA,EACf,EAAE;IAAA1B,MAAA,EACH;EACV,CAAC,CACF,EACN;EAED,MAAA2B,MAAA,GAAe,IAAIC,GAAG,CAAiB,CAAC;EAGxC,MAAAC,aAAA,GAAsBV,cAAc,CAAAG,GAAI,CAACQ,IAAA;IACvC,MAAAC,WAAA,GAAoBzC,cAAc,CAACwC,IAAI,CAAAzB,IAAK,CAAC;IAC7C,MAAA2B,WAAA,GAAoBF,IAAI,CAAA9B,MAAuB,GAA3B,EAA2B,GAA3B,QAA2B;IAG/C,MAAAiC,KAAA,GAAcH,IAAI,CAAAI,MAAgD,GAApD,CAAeP,MAAM,CAAAQ,GAAI,CAACL,IAAI,CAAAI,MAAY,CAAC,IAA5B,CAA4B,IAAI,CAAK,GAApD,CAAoD;IAClEP,MAAM,CAAAS,GAAI,CAACN,IAAI,CAAAzB,IAAK,EAAE4B,KAAK,CAAC;IAC5B,MAAAI,MAAA,GAAeJ,KAAK,GAAG,CAA+B,GAA3B,IAAI,CAAAK,MAAO,CAACL,KAAK,GAAG,CAAM,CAAC,GAAvC,EAAuC;IAGlDM,GAAA,CAAAA,KAAA;IACJ,IACET,IAAI,CAAAN,IAAK,KAAK,MACA,IADd,CACCM,IAAI,CAAA/B,QACuB,IAA5B+B,IAAI,CAAAzB,IAAK,KAAKO,cAAc;MAE5B2B,KAAA,CAAAA,CAAA,CAAQA,aAAa;IAAhB;MACA,IACLT,IAAI,CAAAN,IAAK,KAAK,SACA,IADd,CACCM,IAAI,CAAA/B,QAC0B,IAA/B+B,IAAI,CAAAzB,IAAK,KAAKQ,iBAAiB;QAE/B0B,KAAA,CAAAA,CAAA,CAAQA,gBAAgB;MAAnB;QACA,IAAIN,KAAK,GAAG,CAAC;UAElBM,KAAA,CAAAA,CAAA,CAAQA,GAAGF,MAAM,KAAKN,WAAW,GAAGC,WAAW,EAAE;QAA5C;UAGLO,KAAA,CAAAA,CAAA,CAAQA,GAAGR,WAAW,EAAE;QAAnB;MACN;IAAA;IAGGS,GAAA,CAAAA,WAAA;IACJ,MAAAC,KAAA,GAAcjD,kBAAkB,CAAClB,cAAc,CAAC,CAAC,CAAC;IAElD,IAAIwD,IAAI,CAAAN,IAAK,KAAK,MAAwB,IAAtC,CAAyBM,IAAI,CAAA/B,QAAS;MACxCyC,WAAA,CAAAA,CAAA,CAAcA,8BAA8B;IAAjC;MACN,IACLV,IAAI,CAAAN,IAAK,KAAK,SACA,IADd,CACCM,IAAI,CAAA/B,QAC0B,IAA/B+B,IAAI,CAAAzB,IAAK,KAAKQ,iBAAiB;QAE/B2B,WAAA,CAAAA,CAAA,CAAcA,GAAGC,KAAK,GAAL,eAAoC,GAApC,UAAoC,cAAc;MAAxD;QACN,IAAIX,IAAI,CAAAI,MAAO;UAEpBM,WAAA,CAAAA,CAAA,CAAcA,YAAY;QAAf;UACN,IAAIV,IAAI,CAAA/B,QAAS;YAEtByC,WAAA,CAAAA,CAAA,CAAcA,oBAAoB;UAAvB;YAEXA,WAAA,CAAAA,CAAA,CAAcA,EAAE;UAAL;QACZ;MAAA;IAAA;IAAA,OAEM;MAAAD,KAAA;MAAAG,KAAA,EAEEZ,IAAI,CAAAzB,IAAK;MAAAmC;IAElB,CAAC;EAAA,CACF,CAAC;EAGF,MAAAG,aAAA,GAIK,EAAE;EAEP,MAAAC,gBAAA,GAAyB5D,WAAW,CAAC6D,MAAuB,CAAC;EAC7D,IAAIjE,mBAAmB,CAAC,CAAC;IAAA,IAAAkE,EAAA;IAAA,IAAArC,CAAA,QAAAsC,MAAA,CAAAC,GAAA;MAEJF,EAAA;QAAAP,KAAA,EACV,yBAAyB;QAAAG,KAAA,EACzB,GAAGxC,kBAAkB,GAAGvB,cAAc,CAAC,CAAC,EAAE;QAAA6D,WAAA,EACpC;MACf,CAAC;MAAA/B,CAAA,MAAAqC,EAAA;IAAA;MAAAA,EAAA,GAAArC,CAAA;IAAA;IAJDkC,aAAa,CAAAM,IAAK,CAACH,EAIlB,CAAC;IAGF,IAAIhF,OAAO,CAAC,SAAgD,CAAC,IAAnC8B,YAAY,CAAAsD,mBAAqB,CAAC,CAAC;MAAA,IAAAC,EAAA;MAAA,IAAA1C,CAAA,QAAAsC,MAAA,CAAAC,GAAA;QACxCG,EAAA;UAAAZ,KAAA,EACV,yBAAyB;UAAAG,KAAA,EACzB,GAAGxC,kBAAkB,GAAGN,YAAY,CAAAwD,cAAgB,CAAC,CAAC,EAAE;UAAAZ,WAAA,EAClD;QACf,CAAC;QAAA/B,CAAA,MAAA0C,EAAA;MAAA;QAAAA,EAAA,GAAA1C,CAAA;MAAA;MAJDkC,aAAa,CAAAM,IAAK,CAACE,EAIlB,CAAC;IAAA;IAIJ,KAAK,MAAAE,KAAW,IAAIT,gBAAgB,CAAAU,YAAa;MAC/C,IAAID,KAAK,CAAAE,MAAO;QACd,MAAAC,QAAA,GAAiBvE,iBAAiB,CAACoE,KAAK,CAAAI,SAAU,EAAEJ,KAAK,CAAAE,MAAO,CAAC;QACjEZ,aAAa,CAAAM,IAAK,CAAC;UAAAV,KAAA,EACV,QAAQxE,KAAK,CAAA2F,IAAK,CAACL,KAAK,CAAAI,SAAU,CAAC,eAAe;UAAAf,KAAA,EAClD,GAAGxC,kBAAkB,GAAGsD,QAAQ,EAAE;UAAAhB,WAAA,EAC5B,GAAGa,KAAK,CAAAE,MAAO;QAC9B,CAAC,CAAC;MAAA;IACH;EACF;EAGH1B,aAAa,CAAAoB,IAAK,IAAIN,aAAa,CAAC;EAAA,IAAAG,EAAA;EAAA,IAAArC,CAAA,QAAAoB,aAAA;IAIlCiB,EAAA,GAAA7C,gBACyD,IAAzD4B,aAAa,CAAAd,IAAK,CAAC4C,MAAqC,CAEvB,GAHjC1D,gBAGiC,GAA7B4B,aAAa,GAAU,EAAAa,KAAM,IAA7B,EAA6B;IAAAjC,CAAA,MAAAoB,aAAA;IAAApB,CAAA,MAAAqC,EAAA;EAAA;IAAAA,EAAA,GAAArC,CAAA;EAAA;EAJnC,MAAAmD,WAAA,GACEd,EAGiC;EAGnC,OAAAe,YAAA,EAAAC,eAAA,IAAwCzF,QAAQ,CAACO,mBAAmB,CAAC;EACrE,OAAAmF,WAAA,EAAAC,cAAA,IAAsC3F,QAAQ,CAACS,kBAAkB,CAAC;EAKlE,OAAAmF,YAAA,IAAuB5F,QAAQ,CAACO,mBAAmB,CAAC;EAIpD,MAAAsF,cAAA,GAAuBlF,WAAW,CAACmF,MAInC,CAAC;EACD,OAAAC,WAAA,EAAAC,cAAA,IAAsChG,QAAQ,CAAgB,IAAI,CAAC;EAAA,IAAA8E,EAAA;EAAA,IAAA1C,CAAA,QAAAwD,YAAA;IACzDd,EAAA,GAAAA,CAAA;MACR,IAAI,CAACc,YAAY;QAAA;MAAA;MACZlF,sBAAsB,CAAC,CAAC,CAAAuF,IAAK,CAACD,cAAc,CAAC;IAAA,CACnD;IAAA5D,CAAA,MAAAwD,YAAA;IAAAxD,CAAA,MAAA0C,EAAA;EAAA;IAAAA,EAAA,GAAA1C,CAAA;EAAA;EAAA,IAAA8D,EAAA;EAAA,IAAA9D,CAAA,QAAAyD,cAAA,IAAAzD,CAAA,QAAAwD,YAAA;IAAEM,EAAA,IAACN,YAAY,EAAEC,cAAc,CAAC;IAAAzD,CAAA,MAAAyD,cAAA;IAAAzD,CAAA,MAAAwD,YAAA;IAAAxD,CAAA,MAAA8D,EAAA;EAAA;IAAAA,EAAA,GAAA9D,CAAA;EAAA;EAHjCrC,SAAS,CAAC+E,EAGT,EAAEoB,EAA8B,CAAC;EAAA,IAAAC,EAAA;EAAA,IAAA/D,CAAA,QAAAyD,cAAA,IAAAzD,CAAA,SAAA2D,WAAA;IAEdI,EAAA,GAAAN,cAAc,GAAd,SAM8C,GAJ9DE,WAAW,KAAK,IAI8C,GAJ9D,EAI8D,GAF5DA,WAAW,KAAK,CAE4C,GAF5D,OAE4D,GAF5D,YAEc7E,qBAAqB,CAAC,IAAIkF,IAAI,CAACL,WAAW,CAAC,CAAC,EAAE;IAAA3D,CAAA,MAAAyD,cAAA;IAAAzD,CAAA,OAAA2D,WAAA;IAAA3D,CAAA,OAAA+D,EAAA;EAAA;IAAAA,EAAA,GAAA/D,CAAA;EAAA;EANlE,MAAAiE,WAAA,GAAoBF,EAM8C;EAGlE,OAAAG,aAAA,EAAAC,gBAAA,IAA0CvG,QAAQ,CAAgB,IAAI,CAAC;EACvE,MAAAwG,aAAA,GAAsBF,aAAa,KAAK,IAAI;EAC5C,MAAAG,eAAA,GAAwBb,YAAY,GAAZ,CAAoB,GAApB,CAAoB;EAAA,IAAAc,EAAA;EAAA,IAAAtE,CAAA,SAAAoD,YAAA;IAE5CkB,EAAA,YAAAC,uBAAA;MACE,MAAAC,QAAA,GAAiB,CAACpB,YAAY;MAC9BpE,uBAAuB,CAAC,cAAc,EAAE;QAAAyF,iBAAA,EAAqBD;MAAS,CAAC,CAAC;MACxEnB,eAAe,CAACmB,QAAQ,CAAC;MACzBpG,QAAQ,CAAC,2BAA2B,EAAE;QAAAsG,OAAA,EAAWF;MAAS,CAAC,CAAC;IAAA,CAC7D;IAAAxE,CAAA,OAAAoD,YAAA;IAAApD,CAAA,OAAAsE,EAAA;EAAA;IAAAA,EAAA,GAAAtE,CAAA;EAAA;EALD,MAAAuE,sBAAA,GAAAD,EAKC;EAAA,IAAAK,EAAA;EAAA,IAAA3E,CAAA,SAAAsD,WAAA;IAEDqB,EAAA,YAAAC,sBAAA;MACE,MAAAC,UAAA,GAAiB,CAACvB,WAAW;MAC7BtE,uBAAuB,CAAC,cAAc,EAAE;QAAA8F,gBAAA,EAAoBN;MAAS,CAAC,CAAC;MACvEjB,cAAc,CAACiB,UAAQ,CAAC;MACxBpG,QAAQ,CAAC,0BAA0B,EAAE;QAAAsG,OAAA,EAAWF;MAAS,CAAC,CAAC;IAAA,CAC5D;IAAAxE,CAAA,OAAAsD,WAAA;IAAAtD,CAAA,OAAA2E,EAAA;EAAA;IAAAA,EAAA,GAAA3E,CAAA;EAAA;EALD,MAAA4E,qBAAA,GAAAD,EAKC;EAED7G,8BAA8B,CAAC,CAAC;EAAA,IAAAiH,EAAA;EAAA,IAAA/E,CAAA,SAAAsC,MAAA,CAAAC,GAAA;IAEMwC,EAAA;MAAAC,OAAA,EAAW;IAAe,CAAC;IAAAhF,CAAA,OAAA+E,EAAA;EAAA;IAAAA,EAAA,GAAA/E,CAAA;EAAA;EAAjE/B,aAAa,CAAC,YAAY,EAAE4B,QAAQ,EAAEkF,EAA2B,CAAC;EAAA,IAAAE,EAAA;EAAA,IAAAjF,CAAA,SAAAkE,aAAA,IAAAlE,CAAA,SAAA4E,qBAAA,IAAA5E,CAAA,SAAAuE,sBAAA;IAIhEU,EAAA,GAAAA,CAAA;MACE,IAAIf,aAAa,KAAK,CAAC;QAAEK,sBAAsB,CAAC,CAAC;MAAA;QAC5C,IAAIL,aAAa,KAAK,CAAC;UAAEU,qBAAqB,CAAC,CAAC;QAAA;MAAA;IAAA,CACtD;IAAA5E,CAAA,OAAAkE,aAAA;IAAAlE,CAAA,OAAA4E,qBAAA;IAAA5E,CAAA,OAAAuE,sBAAA;IAAAvE,CAAA,OAAAiF,EAAA;EAAA;IAAAA,EAAA,GAAAjF,CAAA;EAAA;EAAA,IAAAkF,EAAA;EAAA,IAAAlF,CAAA,SAAAoE,aAAA;IACDc,EAAA;MAAAF,OAAA,EAAW,cAAc;MAAAG,QAAA,EAAYf;IAAc,CAAC;IAAApE,CAAA,OAAAoE,aAAA;IAAApE,CAAA,OAAAkF,EAAA;EAAA;IAAAA,EAAA,GAAAlF,CAAA;EAAA;EANtD/B,aAAa,CACX,aAAa,EACbgH,EAGC,EACDC,EACF,CAAC;EAAA,IAAAE,GAAA;EAAA,IAAApF,CAAA,SAAAqE,eAAA;IAGCe,GAAA,GAAAA,CAAA;MACEjB,gBAAgB,CAACkB,IAAA,IACfA,IAAI,KAAK,IAA8B,IAAtBA,IAAI,GAAGhB,eAAiC,GAAfgB,IAAI,GAAG,CAAQ,GAAzD,IACF,CAAC;IAAA,CACF;IAAArF,CAAA,OAAAqE,eAAA;IAAArE,CAAA,OAAAoF,GAAA;EAAA;IAAAA,GAAA,GAAApF,CAAA;EAAA;EAAA,IAAAsF,GAAA;EAAA,IAAAtF,CAAA,SAAAoE,aAAA;IACDkB,GAAA;MAAAN,OAAA,EAAW,QAAQ;MAAAG,QAAA,EAAYf;IAAc,CAAC;IAAApE,CAAA,OAAAoE,aAAA;IAAApE,CAAA,OAAAsF,GAAA;EAAA;IAAAA,GAAA,GAAAtF,CAAA;EAAA;EAPhD/B,aAAa,CACX,aAAa,EACbmH,GAIC,EACDE,GACF,CAAC;EAAA,IAAAC,GAAA;EAAA,IAAAvF,CAAA,SAAAsC,MAAA,CAAAC,GAAA;IAGCgD,GAAA,GAAAA,CAAA;MACEpB,gBAAgB,CAACqB,MAAqD,CAAC;IAAA,CACxE;IAAAxF,CAAA,OAAAuF,GAAA;EAAA;IAAAA,GAAA,GAAAvF,CAAA;EAAA;EAAA,IAAAyF,GAAA;EAAA,IAAAzF,CAAA,SAAAoE,aAAA;IACDqB,GAAA;MAAAT,OAAA,EAAW,QAAQ;MAAAG,QAAA,EAAYf;IAAc,CAAC;IAAApE,CAAA,OAAAoE,aAAA;IAAApE,CAAA,OAAAyF,GAAA;EAAA;IAAAA,GAAA,GAAAzF,CAAA;EAAA;EALhD/B,aAAa,CACX,iBAAiB,EACjBsH,GAEC,EACDE,GACF,CAAC;EAK0B,MAAAC,GAAA,GAAAxB,aAAa,KAAK,CAAC;EAClB,MAAAyB,GAAA,GAAAvC,YAAY,GAAZ,IAA2B,GAA3B,KAA2B;EAAA,IAAAwC,GAAA;EAAA,IAAA5F,CAAA,SAAA2F,GAAA;IAA/CC,GAAA,IAAC,IAAI,CAAC,aAAc,CAAAD,GAA0B,CAAE,EAA/C,IAAI,CAAkD;IAAA3F,CAAA,OAAA2F,GAAA;IAAA3F,CAAA,OAAA4F,GAAA;EAAA;IAAAA,GAAA,GAAA5F,CAAA;EAAA;EAAA,IAAA6F,GAAA;EAAA,IAAA7F,CAAA,SAAA0F,GAAA,IAAA1F,CAAA,SAAA4F,GAAA;IADzDC,GAAA,IAAC,QAAQ,CAAY,SAAmB,CAAnB,CAAAH,GAAkB,CAAC,CACtC,CAAAE,GAAsD,CACxD,EAFC,QAAQ,CAEE;IAAA5F,CAAA,OAAA0F,GAAA;IAAA1F,CAAA,OAAA4F,GAAA;IAAA5F,CAAA,OAAA6F,GAAA;EAAA;IAAAA,GAAA,GAAA7F,CAAA;EAAA;EAAA,IAAA8F,GAAA;EAAA,IAAA9F,CAAA,SAAAsD,WAAA,IAAAtD,CAAA,SAAAiE,WAAA,IAAAjE,CAAA,SAAAkE,aAAA,IAAAlE,CAAA,SAAAyD,cAAA,IAAAzD,CAAA,SAAAwD,YAAA;IACVsC,GAAA,GAAAtC,YAUA,IATC,CAAC,QAAQ,CAAY,SAAmB,CAAnB,CAAAU,aAAa,KAAK,EAAC,CAAU,MAAK,CAAL,MAAI,CAAC,CACrD,CAAC,IAAI,CAAQ,KAA8C,CAA9C,CAAAA,aAAa,KAAK,CAA4B,GAA9C,YAA8C,GAA9C6B,SAA6C,CAAC,CAAE,YAC9C,CAAAzC,WAAW,GAAX,IAA0B,GAA1B,KAAyB,CACrC,CAAAW,WAAqD,IAAtC,CAAC,IAAI,CAAC,QAAQ,CAAR,KAAO,CAAC,CAAC,GAAIA,YAAU,CAAE,EAA9B,IAAI,CAAgC,CACpD,EAACR,cAA6B,IAA9BH,WAEA,IADC,CAAC,IAAI,CAAC,QAAQ,CAAR,KAAO,CAAC,CAAC,gBAAgB,EAA9B,IAAI,CACP,CACF,EANC,IAAI,CAOP,EARC,QAAQ,CASV;IAAAtD,CAAA,OAAAsD,WAAA;IAAAtD,CAAA,OAAAiE,WAAA;IAAAjE,CAAA,OAAAkE,aAAA;IAAAlE,CAAA,OAAAyD,cAAA;IAAAzD,CAAA,OAAAwD,YAAA;IAAAxD,CAAA,OAAA8F,GAAA;EAAA;IAAAA,GAAA,GAAA9F,CAAA;EAAA;EAAA,IAAAgG,GAAA;EAAA,IAAAhG,CAAA,SAAA6F,GAAA,IAAA7F,CAAA,SAAA8F,GAAA;IAdHE,GAAA,IAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CAAe,YAAC,CAAD,GAAC,CACzC,CAAAH,GAEU,CACT,CAAAC,GAUD,CACF,EAfC,GAAG,CAeE;IAAA9F,CAAA,OAAA6F,GAAA;IAAA7F,CAAA,OAAA8F,GAAA;IAAA9F,CAAA,OAAAgG,GAAA;EAAA;IAAAA,GAAA,GAAAhG,CAAA;EAAA;EAAA,IAAAiG,GAAA;EAAA,IAAAjG,CAAA,SAAAL,QAAA;IAMMsG,GAAA,GAAAhE,KAAA;MACR,IAAIA,KAAK,CAAAiE,UAAW,CAACzG,kBAAkB,CAAC;QACtC,MAAA0G,UAAA,GAAmBlE,KAAK,CAAAmE,KAAM,CAAC3G,kBAAkB,CAAA4G,MAAO,CAAC;QAGpD9I,KAAK,CAAC4I,UAAU,EAAE;UAAAG,SAAA,EAAa;QAAK,CAAC,CAAC,CAAAC,KACnC,CAACC,MAAQ,CAAC,CAAA3C,IACX,CAAC,MAAMpF,QAAQ,CAAC0H,UAAU,CAAC,CAAC;QAAA;MAAA;MAGrC3G,gBAAA,CAAAA,CAAA,CAAmByC,KAAH;MAChBtC,QAAQ,CAACsC,KAAK,CAAC;IAAA,CAChB;IAAAjC,CAAA,OAAAL,QAAA;IAAAK,CAAA,OAAAiG,GAAA;EAAA;IAAAA,GAAA,GAAAjG,CAAA;EAAA;EAAA,IAAAyG,GAAA;EAAA,IAAAzG,CAAA,SAAAqE,eAAA;IAEkBoC,GAAA,GAAAA,CAAA,KAAMtC,gBAAgB,CAACE,eAAe,CAAC;IAAArE,CAAA,OAAAqE,eAAA;IAAArE,CAAA,OAAAyG,GAAA;EAAA;IAAAA,GAAA,GAAAzG,CAAA;EAAA;EAAA,IAAA0G,GAAA;EAAA,IAAA1G,CAAA,SAAAmD,WAAA,IAAAnD,CAAA,SAAAoB,aAAA,IAAApB,CAAA,SAAAH,QAAA,IAAAG,CAAA,SAAAiG,GAAA,IAAAjG,CAAA,SAAAyG,GAAA,IAAAzG,CAAA,SAAAoE,aAAA;IAlB5DsC,GAAA,IAAC,MAAM,CACcvD,iBAAW,CAAXA,YAAU,CAAC,CACrB/B,OAAa,CAAbA,cAAY,CAAC,CACVgD,UAAa,CAAbA,cAAY,CAAC,CACf,QAYT,CAZS,CAAA6B,GAYV,CAAC,CACSpG,QAAQ,CAARA,SAAO,CAAC,CACC,iBAAuC,CAAvC,CAAA4G,GAAsC,CAAC,GAC1D;IAAAzG,CAAA,OAAAmD,WAAA;IAAAnD,CAAA,OAAAoB,aAAA;IAAApB,CAAA,OAAAH,QAAA;IAAAG,CAAA,OAAAiG,GAAA;IAAAjG,CAAA,OAAAyG,GAAA;IAAAzG,CAAA,OAAAoE,aAAA;IAAApE,CAAA,OAAA0G,GAAA;EAAA;IAAAA,GAAA,GAAA1G,CAAA;EAAA;EAAA,IAAA2G,GAAA;EAAA,IAAA3G,CAAA,SAAAgG,GAAA,IAAAhG,CAAA,SAAA0G,GAAA;IArCJC,GAAA,IAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CAAO,KAAM,CAAN,MAAM,CACtC,CAAAX,GAeK,CAEL,CAAAU,GAmBC,CACH,EAtCC,GAAG,CAsCE;IAAA1G,CAAA,OAAAgG,GAAA;IAAAhG,CAAA,OAAA0G,GAAA;IAAA1G,CAAA,OAAA2G,GAAA;EAAA;IAAAA,GAAA,GAAA3G,CAAA;EAAA;EAAA,OAtCN2G,GAsCM;AAAA;AAlRH,SAAAH,OAAA;AAAA,SAAAhB,OAAAoB,MAAA;EAAA,OAsOyBvB,MAAI,KAAK,IAAgB,IAARA,MAAI,GAAG,CAAmB,GAAfA,MAAI,GAAG,CAAQ,GAA3CuB,MAA2C;AAAA;AAtOpE,SAAAlD,OAAAmD,GAAA;EAAA,OAyKHC,MAAM,CAAAC,MAAO,CAACC,GAAC,CAAAC,KAAM,CAAC,CAAA3G,IAAK,CACzB4G,MACF,CAAC;AAAA;AA3KE,SAAAA,OAAAC,CAAA;EAAA,OA0KIA,CAAC,CAAApG,IAAK,KAAK,OAAiC,IAAtBoG,CAAC,CAAAC,MAAO,KAAK,SAAS;AAAA;AA1KhD,SAAAlE,OAAAmE,GAAA;EAAA,OAyJuBA,GAAG,CAAApF,KAAM,KAAKzC,gBAAgB;AAAA;AAzJrD,SAAA4C,OAAA4E,CAAA;EAAA,OAqHqCA,CAAC,CAAA7E,gBAAiB;AAAA;AArHvD,SAAArB,OAAAwG,GAAA;EAAA,OAsBU;IAAA,GAAK/G,GAAC;IAAAhB,MAAA,EAAU;EAAK,CAAC;AAAA;AAtBhC,SAAAqB,MAAA2G,GAAA;EAAA,OAqBYhH,GAAC,CAAAQ,IAAK,KAAK,SAAiC,IAApBR,GAAC,CAAAQ,IAAK,KAAK,SAAS;AAAA","ignoreList":[]}