source dump of claude code
0
fork

Configure Feed

Select the types of activity you want to include in your feed.

at main 340 lines 41 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import React, { createContext, useCallback, useContext, useEffect, useState } from 'react'; 3import { useIsInsideModal, useModalScrollRef } from '../../context/modalContext.js'; 4import { useTerminalSize } from '../../hooks/useTerminalSize.js'; 5import ScrollBox from '../../ink/components/ScrollBox.js'; 6import type { KeyboardEvent } from '../../ink/events/keyboard-event.js'; 7import { stringWidth } from '../../ink/stringWidth.js'; 8import { Box, Text } from '../../ink.js'; 9import { useKeybindings } from '../../keybindings/useKeybinding.js'; 10import type { Theme } from '../../utils/theme.js'; 11type TabsProps = { 12 children: Array<React.ReactElement<TabProps>>; 13 title?: string; 14 color?: keyof Theme; 15 defaultTab?: string; 16 hidden?: boolean; 17 useFullWidth?: boolean; 18 /** Controlled mode: current selected tab id/title */ 19 selectedTab?: string; 20 /** Controlled mode: callback when tab changes */ 21 onTabChange?: (tabId: string) => void; 22 /** Optional banner to display below tabs header */ 23 banner?: React.ReactNode; 24 /** Disable keyboard navigation (e.g. when a child component handles arrow keys) */ 25 disableNavigation?: boolean; 26 /** 27 * Initial focus state for the tab header row. Defaults to true (header 28 * focused, nav always works). Keep the default for Select/list content — 29 * those only use up/down so there's no conflict; pass 30 * isDisabled={headerFocused} to the Select instead. Only set false when 31 * content actually binds left/right/tab (e.g. enum cycling), and show a 32 * "↑ tabs" footer hint — without it tabs look broken. 33 */ 34 initialHeaderFocused?: boolean; 35 /** 36 * Fixed height for the content area. When set, all tabs render within the 37 * same height (overflow hidden) so switching tabs doesn't cause layout 38 * shifts. Shorter tabs get whitespace; taller tabs are clipped. 39 */ 40 contentHeight?: number; 41 /** 42 * Let Tab/←/→ switch tabs from focused content. Opt-in since some 43 * content uses those keys; pass a reactive boolean to cede them when 44 * needed. Switching from content focuses the header. 45 */ 46 navFromContent?: boolean; 47}; 48type TabsContextValue = { 49 selectedTab: string | undefined; 50 width: number | undefined; 51 headerFocused: boolean; 52 focusHeader: () => void; 53 blurHeader: () => void; 54 registerOptIn: () => () => void; 55}; 56const TabsContext = createContext<TabsContextValue>({ 57 selectedTab: undefined, 58 width: undefined, 59 // Default for components rendered outside a Tabs (tests, standalone): 60 // content has focus, focusHeader is a no-op. 61 headerFocused: false, 62 focusHeader: () => {}, 63 blurHeader: () => {}, 64 registerOptIn: () => () => {} 65}); 66export function Tabs(t0) { 67 const $ = _c(25); 68 const { 69 title, 70 color, 71 defaultTab, 72 children, 73 hidden, 74 useFullWidth, 75 selectedTab: controlledSelectedTab, 76 onTabChange, 77 banner, 78 disableNavigation, 79 initialHeaderFocused: t1, 80 contentHeight, 81 navFromContent: t2 82 } = t0; 83 const initialHeaderFocused = t1 === undefined ? true : t1; 84 const navFromContent = t2 === undefined ? false : t2; 85 const { 86 columns: terminalWidth 87 } = useTerminalSize(); 88 const tabs = children.map(_temp); 89 const defaultTabIndex = defaultTab ? tabs.findIndex(tab => defaultTab === tab[0]) : 0; 90 const isControlled = controlledSelectedTab !== undefined; 91 const [internalSelectedTab, setInternalSelectedTab] = useState(defaultTabIndex !== -1 ? defaultTabIndex : 0); 92 const controlledTabIndex = isControlled ? tabs.findIndex(tab_0 => tab_0[0] === controlledSelectedTab) : -1; 93 const selectedTabIndex = isControlled ? controlledTabIndex !== -1 ? controlledTabIndex : 0 : internalSelectedTab; 94 const modalScrollRef = useModalScrollRef(); 95 const [headerFocused, setHeaderFocused] = useState(initialHeaderFocused); 96 let t3; 97 if ($[0] === Symbol.for("react.memo_cache_sentinel")) { 98 t3 = () => setHeaderFocused(true); 99 $[0] = t3; 100 } else { 101 t3 = $[0]; 102 } 103 const focusHeader = t3; 104 let t4; 105 if ($[1] === Symbol.for("react.memo_cache_sentinel")) { 106 t4 = () => setHeaderFocused(false); 107 $[1] = t4; 108 } else { 109 t4 = $[1]; 110 } 111 const blurHeader = t4; 112 const [optInCount, setOptInCount] = useState(0); 113 let t5; 114 if ($[2] === Symbol.for("react.memo_cache_sentinel")) { 115 t5 = () => { 116 setOptInCount(_temp2); 117 return () => setOptInCount(_temp3); 118 }; 119 $[2] = t5; 120 } else { 121 t5 = $[2]; 122 } 123 const registerOptIn = t5; 124 const optedIn = optInCount > 0; 125 const handleTabChange = offset => { 126 const newIndex = (selectedTabIndex + tabs.length + offset) % tabs.length; 127 const newTabId = tabs[newIndex]?.[0]; 128 if (isControlled && onTabChange && newTabId) { 129 onTabChange(newTabId); 130 } else { 131 setInternalSelectedTab(newIndex); 132 } 133 setHeaderFocused(true); 134 }; 135 const t6 = !hidden && !disableNavigation && headerFocused; 136 let t7; 137 if ($[3] !== t6) { 138 t7 = { 139 context: "Tabs", 140 isActive: t6 141 }; 142 $[3] = t6; 143 $[4] = t7; 144 } else { 145 t7 = $[4]; 146 } 147 useKeybindings({ 148 "tabs:next": () => handleTabChange(1), 149 "tabs:previous": () => handleTabChange(-1) 150 }, t7); 151 let t8; 152 if ($[5] !== headerFocused || $[6] !== hidden || $[7] !== optedIn) { 153 t8 = e => { 154 if (!headerFocused || !optedIn || hidden) { 155 return; 156 } 157 if (e.key === "down") { 158 e.preventDefault(); 159 setHeaderFocused(false); 160 } 161 }; 162 $[5] = headerFocused; 163 $[6] = hidden; 164 $[7] = optedIn; 165 $[8] = t8; 166 } else { 167 t8 = $[8]; 168 } 169 const handleKeyDown = t8; 170 const t9 = navFromContent && !headerFocused && optedIn && !hidden && !disableNavigation; 171 let t10; 172 if ($[9] !== t9) { 173 t10 = { 174 context: "Tabs", 175 isActive: t9 176 }; 177 $[9] = t9; 178 $[10] = t10; 179 } else { 180 t10 = $[10]; 181 } 182 useKeybindings({ 183 "tabs:next": () => { 184 handleTabChange(1); 185 setHeaderFocused(true); 186 }, 187 "tabs:previous": () => { 188 handleTabChange(-1); 189 setHeaderFocused(true); 190 } 191 }, t10); 192 const titleWidth = title ? stringWidth(title) + 1 : 0; 193 const tabsWidth = tabs.reduce(_temp4, 0); 194 const usedWidth = titleWidth + tabsWidth; 195 const spacerWidth = useFullWidth ? Math.max(0, terminalWidth - usedWidth) : 0; 196 const contentWidth = useFullWidth ? terminalWidth : undefined; 197 const T0 = Box; 198 const t11 = "column"; 199 const t12 = 0; 200 const t13 = true; 201 const t14 = modalScrollRef ? 0 : undefined; 202 const t15 = !hidden && <Box flexDirection="row" gap={1} flexShrink={modalScrollRef ? 0 : undefined}>{title !== undefined && <Text bold={true} color={color}>{title}</Text>}{tabs.map((t16, i) => { 203 const [id, title_0] = t16; 204 const isCurrent = selectedTabIndex === i; 205 const hasColorCursor = color && isCurrent && headerFocused; 206 return <Text key={id} backgroundColor={hasColorCursor ? color : undefined} color={hasColorCursor ? "inverseText" : undefined} inverse={isCurrent && !hasColorCursor} bold={isCurrent}>{" "}{title_0}{" "}</Text>; 207 })}{spacerWidth > 0 && <Text>{" ".repeat(spacerWidth)}</Text>}</Box>; 208 let t17; 209 if ($[11] !== children || $[12] !== contentHeight || $[13] !== contentWidth || $[14] !== hidden || $[15] !== modalScrollRef || $[16] !== selectedTabIndex) { 210 t17 = modalScrollRef ? <Box width={contentWidth} marginTop={hidden ? 0 : 1} flexShrink={0}><ScrollBox key={selectedTabIndex} ref={modalScrollRef} flexDirection="column" flexShrink={0}>{children}</ScrollBox></Box> : <Box width={contentWidth} marginTop={hidden ? 0 : 1} height={contentHeight} overflowY={contentHeight !== undefined ? "hidden" : undefined}>{children}</Box>; 211 $[11] = children; 212 $[12] = contentHeight; 213 $[13] = contentWidth; 214 $[14] = hidden; 215 $[15] = modalScrollRef; 216 $[16] = selectedTabIndex; 217 $[17] = t17; 218 } else { 219 t17 = $[17]; 220 } 221 let t18; 222 if ($[18] !== T0 || $[19] !== banner || $[20] !== handleKeyDown || $[21] !== t14 || $[22] !== t15 || $[23] !== t17) { 223 t18 = <T0 flexDirection={t11} tabIndex={t12} autoFocus={t13} onKeyDown={handleKeyDown} flexShrink={t14}>{t15}{banner}{t17}</T0>; 224 $[18] = T0; 225 $[19] = banner; 226 $[20] = handleKeyDown; 227 $[21] = t14; 228 $[22] = t15; 229 $[23] = t17; 230 $[24] = t18; 231 } else { 232 t18 = $[24]; 233 } 234 return <TabsContext.Provider value={{ 235 selectedTab: tabs[selectedTabIndex][0], 236 width: contentWidth, 237 headerFocused, 238 focusHeader, 239 blurHeader, 240 registerOptIn 241 }}>{t18}</TabsContext.Provider>; 242} 243function _temp4(sum, t0) { 244 const [, tabTitle] = t0; 245 return sum + (tabTitle ? stringWidth(tabTitle) : 0) + 2 + 1; 246} 247function _temp3(n_0) { 248 return n_0 - 1; 249} 250function _temp2(n) { 251 return n + 1; 252} 253function _temp(child) { 254 return [child.props.id ?? child.props.title, child.props.title]; 255} 256type TabProps = { 257 title: string; 258 id?: string; 259 children: React.ReactNode; 260}; 261export function Tab(t0) { 262 const $ = _c(4); 263 const { 264 title, 265 id, 266 children 267 } = t0; 268 const { 269 selectedTab, 270 width 271 } = useContext(TabsContext); 272 const insideModal = useIsInsideModal(); 273 if (selectedTab !== (id ?? title)) { 274 return null; 275 } 276 const t1 = insideModal ? 0 : undefined; 277 let t2; 278 if ($[0] !== children || $[1] !== t1 || $[2] !== width) { 279 t2 = <Box width={width} flexShrink={t1}>{children}</Box>; 280 $[0] = children; 281 $[1] = t1; 282 $[2] = width; 283 $[3] = t2; 284 } else { 285 t2 = $[3]; 286 } 287 return t2; 288} 289export function useTabsWidth() { 290 const { 291 width 292 } = useContext(TabsContext); 293 return width; 294} 295 296/** 297 * Opt into header-focus gating. Returns the current header focus state and a 298 * callback to hand focus back to the tab row. For a Select, pass 299 * `isDisabled={headerFocused}` and `onUpFromFirstItem={focusHeader}`; keep the 300 * parent Tabs' initialHeaderFocused at its default so tab/←/→ work on mount. 301 * 302 * Calling this hook registers a ↓-blurs-header opt-in on mount. Don't call it 303 * above an early return that renders static text — ↓ will blur the header with 304 * no onUpFromFirstItem to recover. Split the component so the hook only runs 305 * when the Select renders. 306 */ 307export function useTabHeaderFocus() { 308 const $ = _c(6); 309 const { 310 headerFocused, 311 focusHeader, 312 blurHeader, 313 registerOptIn 314 } = useContext(TabsContext); 315 let t0; 316 if ($[0] !== registerOptIn) { 317 t0 = [registerOptIn]; 318 $[0] = registerOptIn; 319 $[1] = t0; 320 } else { 321 t0 = $[1]; 322 } 323 useEffect(registerOptIn, t0); 324 let t1; 325 if ($[2] !== blurHeader || $[3] !== focusHeader || $[4] !== headerFocused) { 326 t1 = { 327 headerFocused, 328 focusHeader, 329 blurHeader 330 }; 331 $[2] = blurHeader; 332 $[3] = focusHeader; 333 $[4] = headerFocused; 334 $[5] = t1; 335 } else { 336 t1 = $[5]; 337 } 338 return t1; 339} 340//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","createContext","useCallback","useContext","useEffect","useState","useIsInsideModal","useModalScrollRef","useTerminalSize","ScrollBox","KeyboardEvent","stringWidth","Box","Text","useKeybindings","Theme","TabsProps","children","Array","ReactElement","TabProps","title","color","defaultTab","hidden","useFullWidth","selectedTab","onTabChange","tabId","banner","ReactNode","disableNavigation","initialHeaderFocused","contentHeight","navFromContent","TabsContextValue","width","headerFocused","focusHeader","blurHeader","registerOptIn","TabsContext","undefined","Tabs","t0","$","_c","controlledSelectedTab","t1","t2","columns","terminalWidth","tabs","map","_temp","defaultTabIndex","findIndex","tab","isControlled","internalSelectedTab","setInternalSelectedTab","controlledTabIndex","tab_0","selectedTabIndex","modalScrollRef","setHeaderFocused","t3","Symbol","for","t4","optInCount","setOptInCount","t5","_temp2","_temp3","optedIn","handleTabChange","offset","newIndex","length","newTabId","t6","t7","context","isActive","tabs:next","tabs:previous","t8","e","key","preventDefault","handleKeyDown","t9","t10","titleWidth","tabsWidth","reduce","_temp4","usedWidth","spacerWidth","Math","max","contentWidth","T0","t11","t12","t13","t14","t15","t16","i","id","title_0","isCurrent","hasColorCursor","repeat","t17","t18","sum","tabTitle","n_0","n","child","props","Tab","insideModal","useTabsWidth","useTabHeaderFocus"],"sources":["Tabs.tsx"],"sourcesContent":["import React, {\n  createContext,\n  useCallback,\n  useContext,\n  useEffect,\n  useState,\n} from 'react'\nimport {\n  useIsInsideModal,\n  useModalScrollRef,\n} from '../../context/modalContext.js'\nimport { useTerminalSize } from '../../hooks/useTerminalSize.js'\nimport ScrollBox from '../../ink/components/ScrollBox.js'\nimport type { KeyboardEvent } from '../../ink/events/keyboard-event.js'\nimport { stringWidth } from '../../ink/stringWidth.js'\nimport { Box, Text } from '../../ink.js'\nimport { useKeybindings } from '../../keybindings/useKeybinding.js'\nimport type { Theme } from '../../utils/theme.js'\n\ntype TabsProps = {\n  children: Array<React.ReactElement<TabProps>>\n  title?: string\n  color?: keyof Theme\n  defaultTab?: string\n  hidden?: boolean\n  useFullWidth?: boolean\n  /** Controlled mode: current selected tab id/title */\n  selectedTab?: string\n  /** Controlled mode: callback when tab changes */\n  onTabChange?: (tabId: string) => void\n  /** Optional banner to display below tabs header */\n  banner?: React.ReactNode\n  /** Disable keyboard navigation (e.g. when a child component handles arrow keys) */\n  disableNavigation?: boolean\n  /**\n   * Initial focus state for the tab header row. Defaults to true (header\n   * focused, nav always works). Keep the default for Select/list content —\n   * those only use up/down so there's no conflict; pass\n   * isDisabled={headerFocused} to the Select instead. Only set false when\n   * content actually binds left/right/tab (e.g. enum cycling), and show a\n   * \"↑ tabs\" footer hint — without it tabs look broken.\n   */\n  initialHeaderFocused?: boolean\n  /**\n   * Fixed height for the content area. When set, all tabs render within the\n   * same height (overflow hidden) so switching tabs doesn't cause layout\n   * shifts. Shorter tabs get whitespace; taller tabs are clipped.\n   */\n  contentHeight?: number\n  /**\n   * Let Tab/←/→ switch tabs from focused content. Opt-in since some\n   * content uses those keys; pass a reactive boolean to cede them when\n   * needed. Switching from content focuses the header.\n   */\n  navFromContent?: boolean\n}\n\ntype TabsContextValue = {\n  selectedTab: string | undefined\n  width: number | undefined\n  headerFocused: boolean\n  focusHeader: () => void\n  blurHeader: () => void\n  registerOptIn: () => () => void\n}\n\nconst TabsContext = createContext<TabsContextValue>({\n  selectedTab: undefined,\n  width: undefined,\n  // Default for components rendered outside a Tabs (tests, standalone):\n  // content has focus, focusHeader is a no-op.\n  headerFocused: false,\n  focusHeader: () => {},\n  blurHeader: () => {},\n  registerOptIn: () => () => {},\n})\n\nexport function Tabs({\n  title,\n  color,\n  defaultTab,\n  children,\n  hidden,\n  useFullWidth,\n  selectedTab: controlledSelectedTab,\n  onTabChange,\n  banner,\n  disableNavigation,\n  initialHeaderFocused = true,\n  contentHeight,\n  navFromContent = false,\n}: TabsProps): React.ReactNode {\n  const { columns: terminalWidth } = useTerminalSize()\n  const tabs = children.map(child => [\n    child.props.id ?? child.props.title,\n    child.props.title,\n  ])\n  const defaultTabIndex = defaultTab\n    ? tabs.findIndex(tab => defaultTab === tab[0])\n    : 0\n\n  // Support both controlled and uncontrolled modes\n  const isControlled = controlledSelectedTab !== undefined\n  const [internalSelectedTab, setInternalSelectedTab] = useState(\n    defaultTabIndex !== -1 ? defaultTabIndex : 0,\n  )\n\n  // In controlled mode, find the index of the controlled tab\n  const controlledTabIndex = isControlled\n    ? tabs.findIndex(tab => tab[0] === controlledSelectedTab)\n    : -1\n  const selectedTabIndex = isControlled\n    ? controlledTabIndex !== -1\n      ? controlledTabIndex\n      : 0\n    : internalSelectedTab\n\n  const modalScrollRef = useModalScrollRef()\n\n  // Header focus: left/right/tab only switch tabs when the header row is\n  // focused. Children with interactive content call focusHeader() (via\n  // useTabHeaderFocus) on up-arrow to hand focus back here; down-arrow\n  // returns it. Tabs that never call the hook see no behavior change —\n  // initialHeaderFocused defaults to true so nav always works.\n  const [headerFocused, setHeaderFocused] = useState(initialHeaderFocused)\n  const focusHeader = useCallback(() => setHeaderFocused(true), [])\n  const blurHeader = useCallback(() => setHeaderFocused(false), [])\n  // Count of mounted children using useTabHeaderFocus(). Down-arrow blur and\n  // the ↓ hint only engage when at least one child has opted in — otherwise\n  // pressing down on a legacy tab would strand the user with nav disabled.\n  const [optInCount, setOptInCount] = useState(0)\n  const registerOptIn = useCallback(() => {\n    setOptInCount(n => n + 1)\n    return () => setOptInCount(n => n - 1)\n  }, [])\n  const optedIn = optInCount > 0\n\n  const handleTabChange = (offset: number) => {\n    const newIndex = (selectedTabIndex + tabs.length + offset) % tabs.length\n    const newTabId = tabs[newIndex]?.[0]\n\n    if (isControlled && onTabChange && newTabId) {\n      onTabChange(newTabId)\n    } else {\n      setInternalSelectedTab(newIndex)\n    }\n    // Tab switching is a header action — stay focused so the user can keep\n    // cycling. The newly mounted tab can blur via its own interaction.\n    setHeaderFocused(true)\n  }\n\n  useKeybindings(\n    {\n      'tabs:next': () => handleTabChange(1),\n      'tabs:previous': () => handleTabChange(-1),\n    },\n    {\n      context: 'Tabs',\n      isActive: !hidden && !disableNavigation && headerFocused,\n    },\n  )\n\n  // When the header is focused, down-arrow returns focus to content. Only\n  // active when the selected tab has opted in via useTabHeaderFocus() —\n  // legacy tabs have nowhere to return focus to.\n  const handleKeyDown = (e: KeyboardEvent) => {\n    if (!headerFocused || !optedIn || hidden) return\n    if (e.key === 'down') {\n      e.preventDefault()\n      setHeaderFocused(false)\n    }\n  }\n\n  // Opt-in: same tabs:next/previous actions, active from content. Focuses\n  // the header so subsequent presses cycle via the handler above.\n  useKeybindings(\n    {\n      'tabs:next': () => {\n        handleTabChange(1)\n        setHeaderFocused(true)\n      },\n      'tabs:previous': () => {\n        handleTabChange(-1)\n        setHeaderFocused(true)\n      },\n    },\n    {\n      context: 'Tabs',\n      isActive:\n        navFromContent &&\n        !headerFocused &&\n        optedIn &&\n        !hidden &&\n        !disableNavigation,\n    },\n  )\n\n  // Calculate spacing to fill the available width. No keyboard hint in the\n  // header row — content footers own hints (see useTabHeaderFocus docs).\n  const titleWidth = title ? stringWidth(title) + 1 : 0 // +1 for gap\n  const tabsWidth = tabs.reduce(\n    (sum, [, tabTitle]) => sum + (tabTitle ? stringWidth(tabTitle) : 0) + 2 + 1, // +2 for padding, +1 for gap\n    0,\n  )\n  const usedWidth = titleWidth + tabsWidth\n  const spacerWidth = useFullWidth ? Math.max(0, terminalWidth - usedWidth) : 0\n\n  const contentWidth = useFullWidth ? terminalWidth : undefined\n\n  return (\n    <TabsContext.Provider\n      value={{\n        selectedTab: tabs[selectedTabIndex]![0],\n        width: contentWidth,\n        headerFocused,\n        focusHeader,\n        blurHeader,\n        registerOptIn,\n      }}\n    >\n      <Box\n        flexDirection=\"column\"\n        tabIndex={0}\n        autoFocus\n        onKeyDown={handleKeyDown}\n        // flexShrink=0 inside modal slot — the modal's absolute Box has no\n        // explicit height (grows to fit, maxHeight cap), so flexGrow=1 here\n        // resolves to 0 on re-render and the body blanks on Down arrow.\n        // See #23592. Outside modal, leave layout alone.\n        flexShrink={modalScrollRef ? 0 : undefined}\n      >\n        {!hidden && (\n          <Box\n            flexDirection=\"row\"\n            gap={1}\n            flexShrink={modalScrollRef ? 0 : undefined}\n          >\n            {title !== undefined && (\n              <Text bold color={color}>\n                {title}\n              </Text>\n            )}\n            {tabs.map(([id, title], i) => {\n              const isCurrent = selectedTabIndex === i\n              const hasColorCursor = color && isCurrent && headerFocused\n              return (\n                <Text\n                  key={id}\n                  backgroundColor={hasColorCursor ? color : undefined}\n                  color={hasColorCursor ? 'inverseText' : undefined}\n                  inverse={isCurrent && !hasColorCursor}\n                  bold={isCurrent}\n                >\n                  {' '}\n                  {title}{' '}\n                </Text>\n              )\n            })}\n            {spacerWidth > 0 && <Text>{' '.repeat(spacerWidth)}</Text>}\n          </Box>\n        )}\n        {banner}\n        {modalScrollRef ? (\n          // Inside the modal slot: own the ScrollBox here so the tabs\n          // header row above sits OUTSIDE the scroll area — it can never\n          // scroll off. The ref reaches REPL's ScrollKeybindingHandler via\n          // ModalContext. Keyed by selectedTabIndex → remounts on tab\n          // switch, resetting scrollTop to 0 without scrollTo() timing games.\n          <Box width={contentWidth} marginTop={hidden ? 0 : 1} flexShrink={0}>\n            <ScrollBox\n              key={selectedTabIndex}\n              ref={modalScrollRef}\n              flexDirection=\"column\"\n              flexShrink={0}\n            >\n              {children}\n            </ScrollBox>\n          </Box>\n        ) : (\n          <Box\n            width={contentWidth}\n            marginTop={hidden ? 0 : 1}\n            height={contentHeight}\n            overflowY={contentHeight !== undefined ? 'hidden' : undefined}\n          >\n            {children}\n          </Box>\n        )}\n      </Box>\n    </TabsContext.Provider>\n  )\n}\n\ntype TabProps = {\n  title: string\n  id?: string\n  children: React.ReactNode\n}\n\nexport function Tab({ title, id, children }: TabProps): React.ReactNode {\n  const { selectedTab, width } = useContext(TabsContext)\n  const insideModal = useIsInsideModal()\n  if (selectedTab !== (id ?? title)) {\n    return null\n  }\n\n  return (\n    <Box width={width} flexShrink={insideModal ? 0 : undefined}>\n      {children}\n    </Box>\n  )\n}\n\nexport function useTabsWidth(): number | undefined {\n  const { width } = useContext(TabsContext)\n  return width\n}\n\n/**\n * Opt into header-focus gating. Returns the current header focus state and a\n * callback to hand focus back to the tab row. For a Select, pass\n * `isDisabled={headerFocused}` and `onUpFromFirstItem={focusHeader}`; keep the\n * parent Tabs' initialHeaderFocused at its default so tab/←/→ work on mount.\n *\n * Calling this hook registers a ↓-blurs-header opt-in on mount. Don't call it\n * above an early return that renders static text — ↓ will blur the header with\n * no onUpFromFirstItem to recover. Split the component so the hook only runs\n * when the Select renders.\n */\nexport function useTabHeaderFocus(): {\n  headerFocused: boolean\n  focusHeader: () => void\n  blurHeader: () => void\n} {\n  const { headerFocused, focusHeader, blurHeader, registerOptIn } =\n    useContext(TabsContext)\n  useEffect(registerOptIn, [registerOptIn])\n  return { headerFocused, focusHeader, blurHeader }\n}\n"],"mappings":"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","ignoreList":[]}