Filemedium importancesource

ThemedBox.tsx

components/design-system/ThemedBox.tsx

156
Lines
18043
Bytes
1
Exports
10
Imports
10
Keywords

What this is

This page documents one file from the repository and includes its full source so you can read it without leaving the docs site.

Beginner explanation

This file is one piece of the larger system. Its name, directory, imports, and exports show where it fits. Start by reading the exports and related files first.

How it is used

Start from the exports list and related files. Those are the easiest clues for where this file fits into the system.

Expert explanation

Architecturally, this file intersects with ui-flow. It contains 156 lines, 10 detected imports, and 1 detected exports.

Important relationships

Detected exports

  • Props

Keywords

colorthemebordercolorbordertopcolorborderbottomcolorborderleftcolorborderrightcolorbackgroundcolorvoidkeyof

Detected imports

  • react/compiler-runtime
  • react
  • ../../ink/components/Box.js
  • ../../ink/dom.js
  • ../../ink/events/click-event.js
  • ../../ink/events/focus-event.js
  • ../../ink/events/keyboard-event.js
  • ../../ink/styles.js
  • ../../utils/theme.js
  • ./ThemeProvider.js

Source notes

This page embeds the full file contents. Small or leaf files are still indexed honestly instead of being over-explained.

Open parent directory

Full source

import { c as _c } from "react/compiler-runtime";
import React, { type PropsWithChildren, type Ref } from 'react';
import Box from '../../ink/components/Box.js';
import type { DOMElement } from '../../ink/dom.js';
import type { ClickEvent } from '../../ink/events/click-event.js';
import type { FocusEvent } from '../../ink/events/focus-event.js';
import type { KeyboardEvent } from '../../ink/events/keyboard-event.js';
import type { Color, Styles } from '../../ink/styles.js';
import { getTheme, type Theme } from '../../utils/theme.js';
import { useTheme } from './ThemeProvider.js';

// Color props that accept theme keys
type ThemedColorProps = {
  readonly borderColor?: keyof Theme | Color;
  readonly borderTopColor?: keyof Theme | Color;
  readonly borderBottomColor?: keyof Theme | Color;
  readonly borderLeftColor?: keyof Theme | Color;
  readonly borderRightColor?: keyof Theme | Color;
  readonly backgroundColor?: keyof Theme | Color;
};

// Base Styles without color props (they'll be overridden)
type BaseStylesWithoutColors = Omit<Styles, 'textWrap' | 'borderColor' | 'borderTopColor' | 'borderBottomColor' | 'borderLeftColor' | 'borderRightColor' | 'backgroundColor'>;
export type Props = BaseStylesWithoutColors & ThemedColorProps & {
  ref?: Ref<DOMElement>;
  tabIndex?: number;
  autoFocus?: boolean;
  onClick?: (event: ClickEvent) => void;
  onFocus?: (event: FocusEvent) => void;
  onFocusCapture?: (event: FocusEvent) => void;
  onBlur?: (event: FocusEvent) => void;
  onBlurCapture?: (event: FocusEvent) => void;
  onKeyDown?: (event: KeyboardEvent) => void;
  onKeyDownCapture?: (event: KeyboardEvent) => void;
  onMouseEnter?: () => void;
  onMouseLeave?: () => void;
};

/**
 * Resolves a color value that may be a theme key to a raw Color.
 */
function resolveColor(color: keyof Theme | Color | undefined, theme: Theme): Color | undefined {
  if (!color) return undefined;
  // Check if it's a raw color (starts with rgb(, #, ansi256(, or ansi:)
  if (color.startsWith('rgb(') || color.startsWith('#') || color.startsWith('ansi256(') || color.startsWith('ansi:')) {
    return color as Color;
  }
  // It's a theme key - resolve it
  return theme[color as keyof Theme] as Color;
}

/**
 * Theme-aware Box component that resolves theme color keys to raw colors.
 * This wraps the base Box component with theme resolution for border colors.
 */
function ThemedBox(t0) {
  const $ = _c(33);
  let backgroundColor;
  let borderBottomColor;
  let borderColor;
  let borderLeftColor;
  let borderRightColor;
  let borderTopColor;
  let children;
  let ref;
  let rest;
  if ($[0] !== t0) {
    ({
      borderColor,
      borderTopColor,
      borderBottomColor,
      borderLeftColor,
      borderRightColor,
      backgroundColor,
      children,
      ref,
      ...rest
    } = t0);
    $[0] = t0;
    $[1] = backgroundColor;
    $[2] = borderBottomColor;
    $[3] = borderColor;
    $[4] = borderLeftColor;
    $[5] = borderRightColor;
    $[6] = borderTopColor;
    $[7] = children;
    $[8] = ref;
    $[9] = rest;
  } else {
    backgroundColor = $[1];
    borderBottomColor = $[2];
    borderColor = $[3];
    borderLeftColor = $[4];
    borderRightColor = $[5];
    borderTopColor = $[6];
    children = $[7];
    ref = $[8];
    rest = $[9];
  }
  const [themeName] = useTheme();
  let resolvedBorderBottomColor;
  let resolvedBorderColor;
  let resolvedBorderLeftColor;
  let resolvedBorderRightColor;
  let resolvedBorderTopColor;
  let t1;
  if ($[10] !== backgroundColor || $[11] !== borderBottomColor || $[12] !== borderColor || $[13] !== borderLeftColor || $[14] !== borderRightColor || $[15] !== borderTopColor || $[16] !== themeName) {
    const theme = getTheme(themeName);
    resolvedBorderColor = resolveColor(borderColor, theme);
    resolvedBorderTopColor = resolveColor(borderTopColor, theme);
    resolvedBorderBottomColor = resolveColor(borderBottomColor, theme);
    resolvedBorderLeftColor = resolveColor(borderLeftColor, theme);
    resolvedBorderRightColor = resolveColor(borderRightColor, theme);
    t1 = resolveColor(backgroundColor, theme);
    $[10] = backgroundColor;
    $[11] = borderBottomColor;
    $[12] = borderColor;
    $[13] = borderLeftColor;
    $[14] = borderRightColor;
    $[15] = borderTopColor;
    $[16] = themeName;
    $[17] = resolvedBorderBottomColor;
    $[18] = resolvedBorderColor;
    $[19] = resolvedBorderLeftColor;
    $[20] = resolvedBorderRightColor;
    $[21] = resolvedBorderTopColor;
    $[22] = t1;
  } else {
    resolvedBorderBottomColor = $[17];
    resolvedBorderColor = $[18];
    resolvedBorderLeftColor = $[19];
    resolvedBorderRightColor = $[20];
    resolvedBorderTopColor = $[21];
    t1 = $[22];
  }
  const resolvedBackgroundColor = t1;
  let t2;
  if ($[23] !== children || $[24] !== ref || $[25] !== resolvedBackgroundColor || $[26] !== resolvedBorderBottomColor || $[27] !== resolvedBorderColor || $[28] !== resolvedBorderLeftColor || $[29] !== resolvedBorderRightColor || $[30] !== resolvedBorderTopColor || $[31] !== rest) {
    t2 = <Box ref={ref} borderColor={resolvedBorderColor} borderTopColor={resolvedBorderTopColor} borderBottomColor={resolvedBorderBottomColor} borderLeftColor={resolvedBorderLeftColor} borderRightColor={resolvedBorderRightColor} backgroundColor={resolvedBackgroundColor} {...rest}>{children}</Box>;
    $[23] = children;
    $[24] = ref;
    $[25] = resolvedBackgroundColor;
    $[26] = resolvedBorderBottomColor;
    $[27] = resolvedBorderColor;
    $[28] = resolvedBorderLeftColor;
    $[29] = resolvedBorderRightColor;
    $[30] = resolvedBorderTopColor;
    $[31] = rest;
    $[32] = t2;
  } else {
    t2 = $[32];
  }
  return t2;
}
export default ThemedBox;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropsWithChildren","Ref","Box","DOMElement","ClickEvent","FocusEvent","KeyboardEvent","Color","Styles","getTheme","Theme","useTheme","ThemedColorProps","borderColor","borderTopColor","borderBottomColor","borderLeftColor","borderRightColor","backgroundColor","BaseStylesWithoutColors","Omit","Props","ref","tabIndex","autoFocus","onClick","event","onFocus","onFocusCapture","onBlur","onBlurCapture","onKeyDown","onKeyDownCapture","onMouseEnter","onMouseLeave","resolveColor","color","theme","undefined","startsWith","ThemedBox","t0","$","_c","children","rest","themeName","resolvedBorderBottomColor","resolvedBorderColor","resolvedBorderLeftColor","resolvedBorderRightColor","resolvedBorderTopColor","t1","resolvedBackgroundColor","t2"],"sources":["ThemedBox.tsx"],"sourcesContent":["import React, { type PropsWithChildren, type Ref } from 'react'\nimport Box from '../../ink/components/Box.js'\nimport type { DOMElement } from '../../ink/dom.js'\nimport type { ClickEvent } from '../../ink/events/click-event.js'\nimport type { FocusEvent } from '../../ink/events/focus-event.js'\nimport type { KeyboardEvent } from '../../ink/events/keyboard-event.js'\nimport type { Color, Styles } from '../../ink/styles.js'\nimport { getTheme, type Theme } from '../../utils/theme.js'\nimport { useTheme } from './ThemeProvider.js'\n\n// Color props that accept theme keys\ntype ThemedColorProps = {\n  readonly borderColor?: keyof Theme | Color\n  readonly borderTopColor?: keyof Theme | Color\n  readonly borderBottomColor?: keyof Theme | Color\n  readonly borderLeftColor?: keyof Theme | Color\n  readonly borderRightColor?: keyof Theme | Color\n  readonly backgroundColor?: keyof Theme | Color\n}\n\n// Base Styles without color props (they'll be overridden)\ntype BaseStylesWithoutColors = Omit<\n  Styles,\n  | 'textWrap'\n  | 'borderColor'\n  | 'borderTopColor'\n  | 'borderBottomColor'\n  | 'borderLeftColor'\n  | 'borderRightColor'\n  | 'backgroundColor'\n>\n\nexport type Props = BaseStylesWithoutColors &\n  ThemedColorProps & {\n    ref?: Ref<DOMElement>\n    tabIndex?: number\n    autoFocus?: boolean\n    onClick?: (event: ClickEvent) => void\n    onFocus?: (event: FocusEvent) => void\n    onFocusCapture?: (event: FocusEvent) => void\n    onBlur?: (event: FocusEvent) => void\n    onBlurCapture?: (event: FocusEvent) => void\n    onKeyDown?: (event: KeyboardEvent) => void\n    onKeyDownCapture?: (event: KeyboardEvent) => void\n    onMouseEnter?: () => void\n    onMouseLeave?: () => void\n  }\n\n/**\n * Resolves a color value that may be a theme key to a raw Color.\n */\nfunction resolveColor(\n  color: keyof Theme | Color | undefined,\n  theme: Theme,\n): Color | undefined {\n  if (!color) return undefined\n  // Check if it's a raw color (starts with rgb(, #, ansi256(, or ansi:)\n  if (\n    color.startsWith('rgb(') ||\n    color.startsWith('#') ||\n    color.startsWith('ansi256(') ||\n    color.startsWith('ansi:')\n  ) {\n    return color as Color\n  }\n  // It's a theme key - resolve it\n  return theme[color as keyof Theme] as Color\n}\n\n/**\n * Theme-aware Box component that resolves theme color keys to raw colors.\n * This wraps the base Box component with theme resolution for border colors.\n */\nfunction ThemedBox({\n  borderColor,\n  borderTopColor,\n  borderBottomColor,\n  borderLeftColor,\n  borderRightColor,\n  backgroundColor,\n  children,\n  ref,\n  ...rest\n}: PropsWithChildren<Props>): React.ReactNode {\n  const [themeName] = useTheme()\n  const theme = getTheme(themeName)\n\n  // Resolve theme keys to raw colors\n  const resolvedBorderColor = resolveColor(borderColor, theme)\n  const resolvedBorderTopColor = resolveColor(borderTopColor, theme)\n  const resolvedBorderBottomColor = resolveColor(borderBottomColor, theme)\n  const resolvedBorderLeftColor = resolveColor(borderLeftColor, theme)\n  const resolvedBorderRightColor = resolveColor(borderRightColor, theme)\n  const resolvedBackgroundColor = resolveColor(backgroundColor, theme)\n\n  return (\n    <Box\n      ref={ref}\n      borderColor={resolvedBorderColor}\n      borderTopColor={resolvedBorderTopColor}\n      borderBottomColor={resolvedBorderBottomColor}\n      borderLeftColor={resolvedBorderLeftColor}\n      borderRightColor={resolvedBorderRightColor}\n      backgroundColor={resolvedBackgroundColor}\n      {...rest}\n    >\n      {children}\n    </Box>\n  )\n}\n\nexport default ThemedBox\n"],"mappings":"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","ignoreList":[]}