/ commands / session / session.tsx
session.tsx
  1  import { c as _c } from "react/compiler-runtime";
  2  import { toString as qrToString } from 'qrcode';
  3  import * as React from 'react';
  4  import { useEffect, useState } from 'react';
  5  import { Pane } from '../../components/design-system/Pane.js';
  6  import { Box, Text } from '../../ink.js';
  7  import { useKeybinding } from '../../keybindings/useKeybinding.js';
  8  import { useAppState } from '../../state/AppState.js';
  9  import type { LocalJSXCommandCall } from '../../types/command.js';
 10  import { logForDebugging } from '../../utils/debug.js';
 11  type Props = {
 12    onDone: () => void;
 13  };
 14  function SessionInfo(t0) {
 15    const $ = _c(19);
 16    const {
 17      onDone
 18    } = t0;
 19    const remoteSessionUrl = useAppState(_temp);
 20    const [qrCode, setQrCode] = useState("");
 21    let t1;
 22    let t2;
 23    if ($[0] !== remoteSessionUrl) {
 24      t1 = () => {
 25        if (!remoteSessionUrl) {
 26          return;
 27        }
 28        const url = remoteSessionUrl;
 29        const generateQRCode = async function generateQRCode() {
 30          const qr = await qrToString(url, {
 31            type: "utf8",
 32            errorCorrectionLevel: "L"
 33          });
 34          setQrCode(qr);
 35        };
 36        generateQRCode().catch(_temp2);
 37      };
 38      t2 = [remoteSessionUrl];
 39      $[0] = remoteSessionUrl;
 40      $[1] = t1;
 41      $[2] = t2;
 42    } else {
 43      t1 = $[1];
 44      t2 = $[2];
 45    }
 46    useEffect(t1, t2);
 47    let t3;
 48    if ($[3] === Symbol.for("react.memo_cache_sentinel")) {
 49      t3 = {
 50        context: "Confirmation"
 51      };
 52      $[3] = t3;
 53    } else {
 54      t3 = $[3];
 55    }
 56    useKeybinding("confirm:no", onDone, t3);
 57    if (!remoteSessionUrl) {
 58      let t4;
 59      if ($[4] === Symbol.for("react.memo_cache_sentinel")) {
 60        t4 = <Pane><Text color="warning">Not in remote mode. Start with `claude --remote` to use this command.</Text><Text dimColor={true}>(press esc to close)</Text></Pane>;
 61        $[4] = t4;
 62      } else {
 63        t4 = $[4];
 64      }
 65      return t4;
 66    }
 67    let T0;
 68    let t4;
 69    let t5;
 70    if ($[5] !== qrCode) {
 71      const lines = qrCode.split("\n").filter(_temp3);
 72      const isLoading = lines.length === 0;
 73      T0 = Pane;
 74      if ($[9] === Symbol.for("react.memo_cache_sentinel")) {
 75        t4 = <Box marginBottom={1}><Text bold={true}>Remote session</Text></Box>;
 76        $[9] = t4;
 77      } else {
 78        t4 = $[9];
 79      }
 80      t5 = isLoading ? <Text dimColor={true}>Generating QR code…</Text> : lines.map(_temp4);
 81      $[5] = qrCode;
 82      $[6] = T0;
 83      $[7] = t4;
 84      $[8] = t5;
 85    } else {
 86      T0 = $[6];
 87      t4 = $[7];
 88      t5 = $[8];
 89    }
 90    let t6;
 91    if ($[10] === Symbol.for("react.memo_cache_sentinel")) {
 92      t6 = <Text dimColor={true}>Open in browser: </Text>;
 93      $[10] = t6;
 94    } else {
 95      t6 = $[10];
 96    }
 97    let t7;
 98    if ($[11] !== remoteSessionUrl) {
 99      t7 = <Box marginTop={1}>{t6}<Text color="ide">{remoteSessionUrl}</Text></Box>;
100      $[11] = remoteSessionUrl;
101      $[12] = t7;
102    } else {
103      t7 = $[12];
104    }
105    let t8;
106    if ($[13] === Symbol.for("react.memo_cache_sentinel")) {
107      t8 = <Box marginTop={1}><Text dimColor={true}>(press esc to close)</Text></Box>;
108      $[13] = t8;
109    } else {
110      t8 = $[13];
111    }
112    let t9;
113    if ($[14] !== T0 || $[15] !== t4 || $[16] !== t5 || $[17] !== t7) {
114      t9 = <T0>{t4}{t5}{t7}{t8}</T0>;
115      $[14] = T0;
116      $[15] = t4;
117      $[16] = t5;
118      $[17] = t7;
119      $[18] = t9;
120    } else {
121      t9 = $[18];
122    }
123    return t9;
124  }
125  function _temp4(line_0, i) {
126    return <Text key={i}>{line_0}</Text>;
127  }
128  function _temp3(line) {
129    return line.length > 0;
130  }
131  function _temp2(e) {
132    logForDebugging("QR code generation failed", e);
133  }
134  function _temp(s) {
135    return s.remoteSessionUrl;
136  }
137  export const call: LocalJSXCommandCall = async onDone => {
138    return <SessionInfo onDone={onDone} />;
139  };
140  //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["toString","qrToString","React","useEffect","useState","Pane","Box","Text","useKeybinding","useAppState","LocalJSXCommandCall","logForDebugging","Props","onDone","SessionInfo","t0","$","_c","remoteSessionUrl","_temp","qrCode","setQrCode","t1","t2","url","generateQRCode","qr","type","errorCorrectionLevel","catch","_temp2","t3","Symbol","for","context","t4","T0","t5","lines","split","filter","_temp3","isLoading","length","map","_temp4","t6","t7","t8","t9","line_0","i","line","e","s","call"],"sources":["session.tsx"],"sourcesContent":["import { toString as qrToString } from 'qrcode'\nimport * as React from 'react'\nimport { useEffect, useState } from 'react'\nimport { Pane } from '../../components/design-system/Pane.js'\nimport { Box, Text } from '../../ink.js'\nimport { useKeybinding } from '../../keybindings/useKeybinding.js'\nimport { useAppState } from '../../state/AppState.js'\nimport type { LocalJSXCommandCall } from '../../types/command.js'\nimport { logForDebugging } from '../../utils/debug.js'\n\ntype Props = {\n  onDone: () => void\n}\n\nfunction SessionInfo({ onDone }: Props): React.ReactNode {\n  const remoteSessionUrl = useAppState(s => s.remoteSessionUrl)\n  const [qrCode, setQrCode] = useState<string>('')\n\n  // Generate QR code when URL is available\n  useEffect(() => {\n    if (!remoteSessionUrl) return\n\n    const url = remoteSessionUrl\n    async function generateQRCode(): Promise<void> {\n      const qr = await qrToString(url, {\n        type: 'utf8',\n        errorCorrectionLevel: 'L',\n      })\n      setQrCode(qr)\n    }\n    // Intentionally silent fail - URL is still shown so QR is non-critical\n    generateQRCode().catch(e => {\n      logForDebugging('QR code generation failed', e)\n    })\n  }, [remoteSessionUrl])\n\n  // Handle ESC to dismiss\n  useKeybinding('confirm:no', onDone, { context: 'Confirmation' })\n\n  // Not in remote mode\n  if (!remoteSessionUrl) {\n    return (\n      <Pane>\n        <Text color=\"warning\">\n          Not in remote mode. Start with `claude --remote` to use this command.\n        </Text>\n        <Text dimColor>(press esc to close)</Text>\n      </Pane>\n    )\n  }\n\n  const lines = qrCode.split('\\n').filter(line => line.length > 0)\n  const isLoading = lines.length === 0\n\n  return (\n    <Pane>\n      <Box marginBottom={1}>\n        <Text bold>Remote session</Text>\n      </Box>\n\n      {/* QR Code - silently fails if generation errors, URL is still shown */}\n      {isLoading ? (\n        <Text dimColor>Generating QR code…</Text>\n      ) : (\n        lines.map((line, i) => <Text key={i}>{line}</Text>)\n      )}\n\n      {/* URL */}\n      <Box marginTop={1}>\n        <Text dimColor>Open in browser: </Text>\n        <Text color=\"ide\">{remoteSessionUrl}</Text>\n      </Box>\n\n      <Box marginTop={1}>\n        <Text dimColor>(press esc to close)</Text>\n      </Box>\n    </Pane>\n  )\n}\n\nexport const call: LocalJSXCommandCall = async onDone => {\n  return <SessionInfo onDone={onDone} />\n}\n"],"mappings":"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","ignoreList":[]}