@mui/base
Version:
Base UI is a library of headless ('unstyled') React components and low-level hooks. You gain complete control over your app's CSS and accessibility features.
30 lines • 946 B
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
import { listReducer, ListActionTypes, moveHighlight } from '../useList';
import { TabsListActionTypes } from './useTabsList.types';
export function tabsListReducer(state, action) {
if (action.type === TabsListActionTypes.valueChange) {
return _extends({}, state, {
highlightedValue: action.value
});
}
const newState = listReducer(state, action);
const {
context: {
selectionFollowsFocus
}
} = action;
if (action.type === ListActionTypes.itemsChange) {
if (newState.selectedValues.length > 0) {
return _extends({}, newState, {
highlightedValue: newState.selectedValues[0]
});
}
moveHighlight(null, 'reset', action.context);
}
if (selectionFollowsFocus && newState.highlightedValue != null) {
return _extends({}, newState, {
selectedValues: [newState.highlightedValue]
});
}
return newState;
}