UNPKG

@gravity-ui/uikit

Version:

Gravity UI base styling and components

45 lines (44 loc) 1.8 kB
import * as React from 'react'; import { KeyCode } from "../../../constants.js"; import { TAB_DATA_ATTRIBUTE, bTab } from "../constants.js"; import { TabContext } from "../contexts/TabContext.js"; export function useTab(tabProps) { const tabContext = React.useContext(TabContext); if (!tabContext) { throw new Error('<Tab> must be used within <TabList>'); } const currentValue = tabContext.value; const tabId = `${tabContext.id}:t:${tabProps.value}`; const panelId = tabContext.isProvider ? `${tabContext.id}:p:${tabProps.value}` : undefined; const isSelected = currentValue === tabProps.value; const isDisabled = tabProps.disabled; const isFocused = tabContext.isFocused; const onClick = (event) => { if (!tabProps.disabled) { tabContext.onUpdate?.(tabProps.value); tabProps.onClick?.(event); } }; const onKeyDown = (event) => { if ((event.key === KeyCode.SPACEBAR || event.key === KeyCode.ENTER) && !tabProps.disabled) { tabContext.onUpdate?.(tabProps.value); tabProps.onKeyDown?.(event); } }; const { value: _value, icon: _icon, counter: _counter, label: _label, disabled: _disabled, href: _href, component: _component, qa: _qa, ...htmlProps } = tabProps; return { ...htmlProps, role: 'tab', 'aria-selected': isSelected, 'aria-disabled': isDisabled, 'aria-controls': panelId, id: tabId, tabIndex: isSelected && !isDisabled && !isFocused ? 0 : -1, onClick, onKeyDown, className: bTab({ active: isSelected, disabled: isDisabled }, tabProps.className), 'data-qa': tabProps.qa, [TAB_DATA_ATTRIBUTE]: tabProps.value, }; } //# sourceMappingURL=useTab.js.map