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
- components/design-system/Byline.tsx
- components/design-system/Dialog.tsx
- components/design-system/Divider.tsx
- components/design-system/FuzzyPicker.tsx
- components/design-system/KeyboardShortcutHint.tsx
- components/design-system/ListItem.tsx
- components/design-system/LoadingState.tsx
- components/design-system/Pane.tsx
Detected exports
Props
Keywords
colorthemebordercolorbordertopcolorborderbottomcolorborderleftcolorborderrightcolorbackgroundcolorvoidkeyof
Detected imports
react/compiler-runtimereact../../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.
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":";AAAA,OAAOA,KAAK,IAAI,KAAKC,iBAAiB,EAAE,KAAKC,GAAG,QAAQ,OAAO;AAC/D,OAAOC,GAAG,MAAM,6BAA6B;AAC7C,cAAcC,UAAU,QAAQ,kBAAkB;AAClD,cAAcC,UAAU,QAAQ,iCAAiC;AACjE,cAAcC,UAAU,QAAQ,iCAAiC;AACjE,cAAcC,aAAa,QAAQ,oCAAoC;AACvE,cAAcC,KAAK,EAAEC,MAAM,QAAQ,qBAAqB;AACxD,SAASC,QAAQ,EAAE,KAAKC,KAAK,QAAQ,sBAAsB;AAC3D,SAASC,QAAQ,QAAQ,oBAAoB;;AAE7C;AACA,KAAKC,gBAAgB,GAAG;EACtB,SAASC,WAAW,CAAC,EAAE,MAAMH,KAAK,GAAGH,KAAK;EAC1C,SAASO,cAAc,CAAC,EAAE,MAAMJ,KAAK,GAAGH,KAAK;EAC7C,SAASQ,iBAAiB,CAAC,EAAE,MAAML,KAAK,GAAGH,KAAK;EAChD,SAASS,eAAe,CAAC,EAAE,MAAMN,KAAK,GAAGH,KAAK;EAC9C,SAASU,gBAAgB,CAAC,EAAE,MAAMP,KAAK,GAAGH,KAAK;EAC/C,SAASW,eAAe,CAAC,EAAE,MAAMR,KAAK,GAAGH,KAAK;AAChD,CAAC;;AAED;AACA,KAAKY,uBAAuB,GAAGC,IAAI,CACjCZ,MAAM,EACJ,UAAU,GACV,aAAa,GACb,gBAAgB,GAChB,mBAAmB,GACnB,iBAAiB,GACjB,kBAAkB,GAClB,iBAAiB,CACpB;AAED,OAAO,KAAKa,KAAK,GAAGF,uBAAuB,GACzCP,gBAAgB,GAAG;EACjBU,GAAG,CAAC,EAAErB,GAAG,CAACE,UAAU,CAAC;EACrBoB,QAAQ,CAAC,EAAE,MAAM;EACjBC,SAAS,CAAC,EAAE,OAAO;EACnBC,OAAO,CAAC,EAAE,CAACC,KAAK,EAAEtB,UAAU,EAAE,GAAG,IAAI;EACrCuB,OAAO,CAAC,EAAE,CAACD,KAAK,EAAErB,UAAU,EAAE,GAAG,IAAI;EACrCuB,cAAc,CAAC,EAAE,CAACF,KAAK,EAAErB,UAAU,EAAE,GAAG,IAAI;EAC5CwB,MAAM,CAAC,EAAE,CAACH,KAAK,EAAErB,UAAU,EAAE,GAAG,IAAI;EACpCyB,aAAa,CAAC,EAAE,CAACJ,KAAK,EAAErB,UAAU,EAAE,GAAG,IAAI;EAC3C0B,SAAS,CAAC,EAAE,CAACL,KAAK,EAAEpB,aAAa,EAAE,GAAG,IAAI;EAC1C0B,gBAAgB,CAAC,EAAE,CAACN,KAAK,EAAEpB,aAAa,EAAE,GAAG,IAAI;EACjD2B,YAAY,CAAC,EAAE,GAAG,GAAG,IAAI;EACzBC,YAAY,CAAC,EAAE,GAAG,GAAG,IAAI;AAC3B,CAAC;;AAEH;AACA;AACA;AACA,SAASC,YAAYA,CACnBC,KAAK,EAAE,MAAM1B,KAAK,GAAGH,KAAK,GAAG,SAAS,EACtC8B,KAAK,EAAE3B,KAAK,CACb,EAAEH,KAAK,GAAG,SAAS,CAAC;EACnB,IAAI,CAAC6B,KAAK,EAAE,OAAOE,SAAS;EAC5B;EACA,IACEF,KAAK,CAACG,UAAU,CAAC,MAAM,CAAC,IACxBH,KAAK,CAACG,UAAU,CAAC,GAAG,CAAC,IACrBH,KAAK,CAACG,UAAU,CAAC,UAAU,CAAC,IAC5BH,KAAK,CAACG,UAAU,CAAC,OAAO,CAAC,EACzB;IACA,OAAOH,KAAK,IAAI7B,KAAK;EACvB;EACA;EACA,OAAO8B,KAAK,CAACD,KAAK,IAAI,MAAM1B,KAAK,CAAC,IAAIH,KAAK;AAC7C;;AAEA;AACA;AACA;AACA;AACA,SAAAiC,UAAAC,EAAA;EAAA,MAAAC,CAAA,GAAAC,EAAA;EAAA,IAAAzB,eAAA;EAAA,IAAAH,iBAAA;EAAA,IAAAF,WAAA;EAAA,IAAAG,eAAA;EAAA,IAAAC,gBAAA;EAAA,IAAAH,cAAA;EAAA,IAAA8B,QAAA;EAAA,IAAAtB,GAAA;EAAA,IAAAuB,IAAA;EAAA,IAAAH,CAAA,QAAAD,EAAA;IAAmB;MAAA5B,WAAA;MAAAC,cAAA;MAAAC,iBAAA;MAAAC,eAAA;MAAAC,gBAAA;MAAAC,eAAA;MAAA0B,QAAA;MAAAtB,GAAA;MAAA,GAAAuB;IAAA,IAAAJ,EAUQ;IAAAC,CAAA,MAAAD,EAAA;IAAAC,CAAA,MAAAxB,eAAA;IAAAwB,CAAA,MAAA3B,iBAAA;IAAA2B,CAAA,MAAA7B,WAAA;IAAA6B,CAAA,MAAA1B,eAAA;IAAA0B,CAAA,MAAAzB,gBAAA;IAAAyB,CAAA,MAAA5B,cAAA;IAAA4B,CAAA,MAAAE,QAAA;IAAAF,CAAA,MAAApB,GAAA;IAAAoB,CAAA,MAAAG,IAAA;EAAA;IAAA3B,eAAA,GAAAwB,CAAA;IAAA3B,iBAAA,GAAA2B,CAAA;IAAA7B,WAAA,GAAA6B,CAAA;IAAA1B,eAAA,GAAA0B,CAAA;IAAAzB,gBAAA,GAAAyB,CAAA;IAAA5B,cAAA,GAAA4B,CAAA;IAAAE,QAAA,GAAAF,CAAA;IAAApB,GAAA,GAAAoB,CAAA;IAAAG,IAAA,GAAAH,CAAA;EAAA;EACzB,OAAAI,SAAA,IAAoBnC,QAAQ,CAAC,CAAC;EAAA,IAAAoC,yBAAA;EAAA,IAAAC,mBAAA;EAAA,IAAAC,uBAAA;EAAA,IAAAC,wBAAA;EAAA,IAAAC,sBAAA;EAAA,IAAAC,EAAA;EAAA,IAAAV,CAAA,SAAAxB,eAAA,IAAAwB,CAAA,SAAA3B,iBAAA,IAAA2B,CAAA,SAAA7B,WAAA,IAAA6B,CAAA,SAAA1B,eAAA,IAAA0B,CAAA,SAAAzB,gBAAA,IAAAyB,CAAA,SAAA5B,cAAA,IAAA4B,CAAA,SAAAI,SAAA;IAC9B,MAAAT,KAAA,GAAc5B,QAAQ,CAACqC,SAAS,CAAC;IAGjCE,mBAAA,GAA4Bb,YAAY,CAACtB,WAAW,EAAEwB,KAAK,CAAC;IAC5Dc,sBAAA,GAA+BhB,YAAY,CAACrB,cAAc,EAAEuB,KAAK,CAAC;IAClEU,yBAAA,GAAkCZ,YAAY,CAACpB,iBAAiB,EAAEsB,KAAK,CAAC;IACxEY,uBAAA,GAAgCd,YAAY,CAACnB,eAAe,EAAEqB,KAAK,CAAC;IACpEa,wBAAA,GAAiCf,YAAY,CAAClB,gBAAgB,EAAEoB,KAAK,CAAC;IACtCe,EAAA,GAAAjB,YAAY,CAACjB,eAAe,EAAEmB,KAAK,CAAC;IAAAK,CAAA,OAAAxB,eAAA;IAAAwB,CAAA,OAAA3B,iBAAA;IAAA2B,CAAA,OAAA7B,WAAA;IAAA6B,CAAA,OAAA1B,eAAA;IAAA0B,CAAA,OAAAzB,gBAAA;IAAAyB,CAAA,OAAA5B,cAAA;IAAA4B,CAAA,OAAAI,SAAA;IAAAJ,CAAA,OAAAK,yBAAA;IAAAL,CAAA,OAAAM,mBAAA;IAAAN,CAAA,OAAAO,uBAAA;IAAAP,CAAA,OAAAQ,wBAAA;IAAAR,CAAA,OAAAS,sBAAA;IAAAT,CAAA,OAAAU,EAAA;EAAA;IAAAL,yBAAA,GAAAL,CAAA;IAAAM,mBAAA,GAAAN,CAAA;IAAAO,uBAAA,GAAAP,CAAA;IAAAQ,wBAAA,GAAAR,CAAA;IAAAS,sBAAA,GAAAT,CAAA;IAAAU,EAAA,GAAAV,CAAA;EAAA;EAApE,MAAAW,uBAAA,GAAgCD,EAAoC;EAAA,IAAAE,EAAA;EAAA,IAAAZ,CAAA,SAAAE,QAAA,IAAAF,CAAA,SAAApB,GAAA,IAAAoB,CAAA,SAAAW,uBAAA,IAAAX,CAAA,SAAAK,yBAAA,IAAAL,CAAA,SAAAM,mBAAA,IAAAN,CAAA,SAAAO,uBAAA,IAAAP,CAAA,SAAAQ,wBAAA,IAAAR,CAAA,SAAAS,sBAAA,IAAAT,CAAA,SAAAG,IAAA;IAGlES,EAAA,IAAC,GAAG,CACGhC,GAAG,CAAHA,IAAE,CAAC,CACK0B,WAAmB,CAAnBA,oBAAkB,CAAC,CAChBG,cAAsB,CAAtBA,uBAAqB,CAAC,CACnBJ,iBAAyB,CAAzBA,0BAAwB,CAAC,CAC3BE,eAAuB,CAAvBA,wBAAsB,CAAC,CACtBC,gBAAwB,CAAxBA,yBAAuB,CAAC,CACzBG,eAAuB,CAAvBA,wBAAsB,CAAC,KACpCR,IAAI,EAEPD,SAAO,CACV,EAXC,GAAG,CAWE;IAAAF,CAAA,OAAAE,QAAA;IAAAF,CAAA,OAAApB,GAAA;IAAAoB,CAAA,OAAAW,uBAAA;IAAAX,CAAA,OAAAK,yBAAA;IAAAL,CAAA,OAAAM,mBAAA;IAAAN,CAAA,OAAAO,uBAAA;IAAAP,CAAA,OAAAQ,wBAAA;IAAAR,CAAA,OAAAS,sBAAA;IAAAT,CAAA,OAAAG,IAAA;IAAAH,CAAA,OAAAY,EAAA;EAAA;IAAAA,EAAA,GAAAZ,CAAA;EAAA;EAAA,OAXNY,EAWM;AAAA;AAIV,eAAed,SAAS","ignoreList":[]}