πŸ“„ File detail

components/LogoV2/Feed.tsx

🧩 .tsxπŸ“ 112 linesπŸ’Ύ 13,804 bytesπŸ“ text
← Back to All Files

🎯 Use case

This file lives under β€œcomponents/”, which covers shared React UI pieces. On the API surface it exposes FeedLine, FeedConfig, calculateFeedWidth, and Feed β€” mainly types, interfaces, or factory objects. Dependencies touch React UI. It composes internal code from ink and utils (relative imports).

Generated from folder role, exports, dependency roots, and inline comments β€” not hand-reviewed for every path.

🧠 Inline summary

import { c as _c } from "react/compiler-runtime"; import * as React from 'react'; import { stringWidth } from '../../ink/stringWidth.js'; import { Box, Text } from '../../ink.js'; import { truncate } from '../../utils/format.js';

πŸ“€ Exports (heuristic)

  • FeedLine
  • FeedConfig
  • calculateFeedWidth
  • Feed

πŸ“š External import roots

Package roots from from "…" (relative paths omitted).

  • react

πŸ–₯️ Source preview

import { c as _c } from "react/compiler-runtime";
import * as React from 'react';
import { stringWidth } from '../../ink/stringWidth.js';
import { Box, Text } from '../../ink.js';
import { truncate } from '../../utils/format.js';
export type FeedLine = {
  text: string;
  timestamp?: string;
};
export type FeedConfig = {
  title: string;
  lines: FeedLine[];
  footer?: string;
  emptyMessage?: string;
  customContent?: {
    content: React.ReactNode;
    width: number;
  };
};
type FeedProps = {
  config: FeedConfig;
  actualWidth: number;
};
export function calculateFeedWidth(config: FeedConfig): number {
  const {
    title,
    lines,
    footer,
    emptyMessage,
    customContent
  } = config;
  let maxWidth = stringWidth(title);
  if (customContent !== undefined) {
    maxWidth = Math.max(maxWidth, customContent.width);
  } else if (lines.length === 0 && emptyMessage) {
    maxWidth = Math.max(maxWidth, stringWidth(emptyMessage));
  } else {
    const gap = '  ';
    const maxTimestampWidth = Math.max(0, ...lines.map(line => line.timestamp ? stringWidth(line.timestamp) : 0));
    for (const line of lines) {
      const timestampWidth = maxTimestampWidth > 0 ? maxTimestampWidth : 0;
      const lineWidth = stringWidth(line.text) + (timestampWidth > 0 ? timestampWidth + gap.length : 0);
      maxWidth = Math.max(maxWidth, lineWidth);
    }
  }
  if (footer) {
    maxWidth = Math.max(maxWidth, stringWidth(footer));
  }
  return maxWidth;
}
export function Feed(t0) {
  const $ = _c(15);
  const {
    config,
    actualWidth
  } = t0;
  const {
    title,
    lines,
    footer,
    emptyMessage,
    customContent
  } = config;
  let t1;
  if ($[0] !== lines) {
    t1 = Math.max(0, ...lines.map(_temp));
    $[0] = lines;
    $[1] = t1;
  } else {
    t1 = $[1];
  }
  const maxTimestampWidth = t1;
  let t2;
  if ($[2] !== title) {
    t2 = <Text bold={true} color="claude">{title}</Text>;
    $[2] = title;
    $[3] = t2;
  } else {
    t2 = $[3];
  }
  let t3;
  if ($[4] !== actualWidth || $[5] !== customContent || $[6] !== emptyMessage || $[7] !== footer || $[8] !== lines || $[9] !== maxTimestampWidth) {
    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) => {
        const textWidth = Math.max(10, actualWidth - (maxTimestampWidth > 0 ? maxTimestampWidth + 2 : 0));
        return <Text key={index}>{maxTimestampWidth > 0 && <><Text dimColor={true}>{(line_0.timestamp || "").padEnd(maxTimestampWidth)}</Text>{"  "}</>}<Text>{truncate(line_0.text, textWidth)}</Text></Text>;
      })}{footer && <Text dimColor={true} italic={true}>{truncate(footer, actualWidth)}</Text>}</>;
    $[4] = actualWidth;
    $[5] = customContent;
    $[6] = emptyMessage;
    $[7] = footer;
    $[8] = lines;
    $[9] = maxTimestampWidth;
    $[10] = t3;
  } else {
    t3 = $[10];
  }
  let t4;
  if ($[11] !== actualWidth || $[12] !== t2 || $[13] !== t3) {
    t4 = <Box flexDirection="column" width={actualWidth}>{t2}{t3}</Box>;
    $[11] = actualWidth;
    $[12] = t2;
    $[13] = t3;
    $[14] = t4;
  } else {
    t4 = $[14];
  }
  return t4;
}
function _temp(line) {
  return line.timestamp ? stringWidth(line.timestamp) : 0;
}
//# 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":[]}