/ components / LogoV2 / Feed.tsx
Feed.tsx
  1  import { c as _c } from "react/compiler-runtime";
  2  import * as React from 'react';
  3  import { stringWidth } from '../../ink/stringWidth.js';
  4  import { Box, Text } from '../../ink.js';
  5  import { truncate } from '../../utils/format.js';
  6  export type FeedLine = {
  7    text: string;
  8    timestamp?: string;
  9  };
 10  export type FeedConfig = {
 11    title: string;
 12    lines: FeedLine[];
 13    footer?: string;
 14    emptyMessage?: string;
 15    customContent?: {
 16      content: React.ReactNode;
 17      width: number;
 18    };
 19  };
 20  type FeedProps = {
 21    config: FeedConfig;
 22    actualWidth: number;
 23  };
 24  export function calculateFeedWidth(config: FeedConfig): number {
 25    const {
 26      title,
 27      lines,
 28      footer,
 29      emptyMessage,
 30      customContent
 31    } = config;
 32    let maxWidth = stringWidth(title);
 33    if (customContent !== undefined) {
 34      maxWidth = Math.max(maxWidth, customContent.width);
 35    } else if (lines.length === 0 && emptyMessage) {
 36      maxWidth = Math.max(maxWidth, stringWidth(emptyMessage));
 37    } else {
 38      const gap = '  ';
 39      const maxTimestampWidth = Math.max(0, ...lines.map(line => line.timestamp ? stringWidth(line.timestamp) : 0));
 40      for (const line of lines) {
 41        const timestampWidth = maxTimestampWidth > 0 ? maxTimestampWidth : 0;
 42        const lineWidth = stringWidth(line.text) + (timestampWidth > 0 ? timestampWidth + gap.length : 0);
 43        maxWidth = Math.max(maxWidth, lineWidth);
 44      }
 45    }
 46    if (footer) {
 47      maxWidth = Math.max(maxWidth, stringWidth(footer));
 48    }
 49    return maxWidth;
 50  }
 51  export function Feed(t0) {
 52    const $ = _c(15);
 53    const {
 54      config,
 55      actualWidth
 56    } = t0;
 57    const {
 58      title,
 59      lines,
 60      footer,
 61      emptyMessage,
 62      customContent
 63    } = config;
 64    let t1;
 65    if ($[0] !== lines) {
 66      t1 = Math.max(0, ...lines.map(_temp));
 67      $[0] = lines;
 68      $[1] = t1;
 69    } else {
 70      t1 = $[1];
 71    }
 72    const maxTimestampWidth = t1;
 73    let t2;
 74    if ($[2] !== title) {
 75      t2 = <Text bold={true} color="claude">{title}</Text>;
 76      $[2] = title;
 77      $[3] = t2;
 78    } else {
 79      t2 = $[3];
 80    }
 81    let t3;
 82    if ($[4] !== actualWidth || $[5] !== customContent || $[6] !== emptyMessage || $[7] !== footer || $[8] !== lines || $[9] !== maxTimestampWidth) {
 83      t3 = customContent ? <>{customContent.content}{footer && <Text dimColor={true} italic={true}>{truncate(footer, actualWidth)}</Text>}</> : lines.length === 0 && emptyMessage ? <Text dimColor={true}>{truncate(emptyMessage, actualWidth)}</Text> : <>{lines.map((line_0, index) => {
 84          const textWidth = Math.max(10, actualWidth - (maxTimestampWidth > 0 ? maxTimestampWidth + 2 : 0));
 85          return <Text key={index}>{maxTimestampWidth > 0 && <><Text dimColor={true}>{(line_0.timestamp || "").padEnd(maxTimestampWidth)}</Text>{"  "}</>}<Text>{truncate(line_0.text, textWidth)}</Text></Text>;
 86        })}{footer && <Text dimColor={true} italic={true}>{truncate(footer, actualWidth)}</Text>}</>;
 87      $[4] = actualWidth;
 88      $[5] = customContent;
 89      $[6] = emptyMessage;
 90      $[7] = footer;
 91      $[8] = lines;
 92      $[9] = maxTimestampWidth;
 93      $[10] = t3;
 94    } else {
 95      t3 = $[10];
 96    }
 97    let t4;
 98    if ($[11] !== actualWidth || $[12] !== t2 || $[13] !== t3) {
 99      t4 = <Box flexDirection="column" width={actualWidth}>{t2}{t3}</Box>;
100      $[11] = actualWidth;
101      $[12] = t2;
102      $[13] = t3;
103      $[14] = t4;
104    } else {
105      t4 = $[14];
106    }
107    return t4;
108  }
109  function _temp(line) {
110    return line.timestamp ? stringWidth(line.timestamp) : 0;
111  }
112  //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","stringWidth","Box","Text","truncate","FeedLine","text","timestamp","FeedConfig","title","lines","footer","emptyMessage","customContent","content","ReactNode","width","FeedProps","config","actualWidth","calculateFeedWidth","maxWidth","undefined","Math","max","length","gap","maxTimestampWidth","map","line","timestampWidth","lineWidth","Feed","t0","$","_c","t1","_temp","t2","t3","line_0","index","textWidth","padEnd","t4"],"sources":["Feed.tsx"],"sourcesContent":["import * as React from 'react'\nimport { stringWidth } from '../../ink/stringWidth.js'\nimport { Box, Text } from '../../ink.js'\nimport { truncate } from '../../utils/format.js'\n\nexport type FeedLine = {\n  text: string\n  timestamp?: string\n}\n\nexport type FeedConfig = {\n  title: string\n  lines: FeedLine[]\n  footer?: string\n  emptyMessage?: string\n  customContent?: { content: React.ReactNode; width: number }\n}\n\ntype FeedProps = {\n  config: FeedConfig\n  actualWidth: number\n}\n\nexport function calculateFeedWidth(config: FeedConfig): number {\n  const { title, lines, footer, emptyMessage, customContent } = config\n\n  let maxWidth = stringWidth(title)\n\n  if (customContent !== undefined) {\n    maxWidth = Math.max(maxWidth, customContent.width)\n  } else if (lines.length === 0 && emptyMessage) {\n    maxWidth = Math.max(maxWidth, stringWidth(emptyMessage))\n  } else {\n    const gap = '  '\n    const maxTimestampWidth = Math.max(\n      0,\n      ...lines.map(line => (line.timestamp ? stringWidth(line.timestamp) : 0)),\n    )\n\n    for (const line of lines) {\n      const timestampWidth = maxTimestampWidth > 0 ? maxTimestampWidth : 0\n      const lineWidth =\n        stringWidth(line.text) +\n        (timestampWidth > 0 ? timestampWidth + gap.length : 0)\n      maxWidth = Math.max(maxWidth, lineWidth)\n    }\n  }\n\n  if (footer) {\n    maxWidth = Math.max(maxWidth, stringWidth(footer))\n  }\n\n  return maxWidth\n}\n\nexport function Feed({ config, actualWidth }: FeedProps): React.ReactNode {\n  const { title, lines, footer, emptyMessage, customContent } = config\n\n  const gap = '  '\n  const maxTimestampWidth = Math.max(\n    0,\n    ...lines.map(line => (line.timestamp ? stringWidth(line.timestamp) : 0)),\n  )\n\n  return (\n    <Box flexDirection=\"column\" width={actualWidth}>\n      <Text bold color=\"claude\">\n        {title}\n      </Text>\n      {customContent ? (\n        <>\n          {customContent.content}\n          {footer && (\n            <Text dimColor italic>\n              {truncate(footer, actualWidth)}\n            </Text>\n          )}\n        </>\n      ) : lines.length === 0 && emptyMessage ? (\n        <Text dimColor>{truncate(emptyMessage, actualWidth)}</Text>\n      ) : (\n        <>\n          {lines.map((line, index) => {\n            const textWidth = Math.max(\n              10,\n              actualWidth -\n                (maxTimestampWidth > 0 ? maxTimestampWidth + gap.length : 0),\n            )\n\n            return (\n              <Text key={index}>\n                {maxTimestampWidth > 0 && (\n                  <>\n                    <Text dimColor>\n                      {(line.timestamp || '').padEnd(maxTimestampWidth)}\n                    </Text>\n                    {gap}\n                  </>\n                )}\n                <Text>{truncate(line.text, textWidth)}</Text>\n              </Text>\n            )\n          })}\n          {footer && (\n            <Text dimColor italic>\n              {truncate(footer, actualWidth)}\n            </Text>\n          )}\n        </>\n      )}\n    </Box>\n  )\n}\n"],"mappings":"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","ignoreList":[]}