worked on GarageApp stuff
This commit is contained in:
parent
60aaf17af3
commit
eb606572b0
51919 changed files with 2168177 additions and 18 deletions
65
node_modules/@mui/material/Tabs/ScrollbarSize.js
generated
vendored
Normal file
65
node_modules/@mui/material/Tabs/ScrollbarSize.js
generated
vendored
Normal file
|
|
@ -0,0 +1,65 @@
|
|||
"use strict";
|
||||
'use client';
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = ScrollbarSize;
|
||||
var React = _interopRequireWildcard(require("react"));
|
||||
var _propTypes = _interopRequireDefault(require("prop-types"));
|
||||
var _debounce = _interopRequireDefault(require("../utils/debounce"));
|
||||
var _utils = require("../utils");
|
||||
var _jsxRuntime = require("react/jsx-runtime");
|
||||
const styles = {
|
||||
width: 99,
|
||||
height: 99,
|
||||
position: 'absolute',
|
||||
top: -9999,
|
||||
overflow: 'scroll'
|
||||
};
|
||||
|
||||
/**
|
||||
* @ignore - internal component.
|
||||
* The component originates from https://github.com/STORIS/react-scrollbar-size.
|
||||
* It has been moved into the core in order to minimize the bundle size.
|
||||
*/
|
||||
function ScrollbarSize(props) {
|
||||
const {
|
||||
onChange,
|
||||
...other
|
||||
} = props;
|
||||
const scrollbarHeight = React.useRef();
|
||||
const nodeRef = React.useRef(null);
|
||||
const setMeasurements = () => {
|
||||
scrollbarHeight.current = nodeRef.current.offsetHeight - nodeRef.current.clientHeight;
|
||||
};
|
||||
(0, _utils.unstable_useEnhancedEffect)(() => {
|
||||
const handleResize = (0, _debounce.default)(() => {
|
||||
const prevHeight = scrollbarHeight.current;
|
||||
setMeasurements();
|
||||
if (prevHeight !== scrollbarHeight.current) {
|
||||
onChange(scrollbarHeight.current);
|
||||
}
|
||||
});
|
||||
const containerWindow = (0, _utils.ownerWindow)(nodeRef.current);
|
||||
containerWindow.addEventListener('resize', handleResize);
|
||||
return () => {
|
||||
handleResize.clear();
|
||||
containerWindow.removeEventListener('resize', handleResize);
|
||||
};
|
||||
}, [onChange]);
|
||||
React.useEffect(() => {
|
||||
setMeasurements();
|
||||
onChange(scrollbarHeight.current);
|
||||
}, [onChange]);
|
||||
return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
|
||||
style: styles,
|
||||
...other,
|
||||
ref: nodeRef
|
||||
});
|
||||
}
|
||||
process.env.NODE_ENV !== "production" ? ScrollbarSize.propTypes = {
|
||||
onChange: _propTypes.default.func.isRequired
|
||||
} : void 0;
|
||||
272
node_modules/@mui/material/Tabs/Tabs.d.ts
generated
vendored
Normal file
272
node_modules/@mui/material/Tabs/Tabs.d.ts
generated
vendored
Normal file
|
|
@ -0,0 +1,272 @@
|
|||
import * as React from 'react';
|
||||
import { SxProps } from '@mui/system';
|
||||
import { OverridableStringUnion } from '@mui/types';
|
||||
import { CreateSlotsAndSlotProps, SlotProps } from "../utils/types.js";
|
||||
import { Theme } from "../styles/index.js";
|
||||
import TabScrollButton, { TabScrollButtonProps } from "../TabScrollButton/index.js";
|
||||
import { OverridableComponent, OverrideProps } from "../OverridableComponent/index.js";
|
||||
import { TabsClasses } from "./tabsClasses.js";
|
||||
import SvgIcon from "../SvgIcon/index.js";
|
||||
export interface TabsPropsIndicatorColorOverrides {}
|
||||
export interface TabsRootSlotPropsOverrides {}
|
||||
export interface TabsScrollerSlotPropsOverrides {}
|
||||
export interface TabsListSlotPropsOverrides {}
|
||||
export interface TabsScrollbarSlotPropsOverrides {}
|
||||
export interface TabsIndicatorSlotPropsOverrides {}
|
||||
export interface TabsScrollButtonsSlotPropsOverrides {}
|
||||
export interface TabsStartScrollButtonIconSlotPropsOverrides {}
|
||||
export interface TabsEndScrollButtonIconSlotPropsOverrides {}
|
||||
export interface TabsSlots {
|
||||
/**
|
||||
* The component used for the popper.
|
||||
* @default div
|
||||
*/
|
||||
root: React.ElementType;
|
||||
/**
|
||||
* The component used for the scroller.
|
||||
* @default div
|
||||
*/
|
||||
scroller: React.ElementType;
|
||||
/**
|
||||
* The component used for the flex container.
|
||||
* @default div
|
||||
*/
|
||||
list: React.ElementType;
|
||||
/**
|
||||
* The component used for the scroller.
|
||||
* @default ScrollbarSize
|
||||
*/
|
||||
scrollbar: React.ElementType;
|
||||
/**
|
||||
* The component used for the tab indicator.
|
||||
* @default span
|
||||
*/
|
||||
indicator: React.ElementType;
|
||||
/**
|
||||
* The component used for the scroll button.
|
||||
* @default TabScrollButton
|
||||
*/
|
||||
scrollButtons: React.ElementType;
|
||||
/**
|
||||
* The component used for the start scroll button icon.
|
||||
* @default KeyboardArrowLeft
|
||||
*/
|
||||
startScrollButtonIcon: React.ElementType;
|
||||
/**
|
||||
* The component used for the end scroll button icon.
|
||||
* @default KeyboardArrowRight
|
||||
*/
|
||||
endScrollButtonIcon: React.ElementType;
|
||||
}
|
||||
export type TabsSlotsAndSlotProps = CreateSlotsAndSlotProps<TabsSlots, {
|
||||
/**
|
||||
* Props forwarded to the root slot.
|
||||
* By default, the avaible props are based on the div element.
|
||||
*/
|
||||
root: SlotProps<'div', TabsRootSlotPropsOverrides, TabsOwnerState>;
|
||||
/**
|
||||
* Props forwarded to the scroller slot.
|
||||
* By default, the avaible props are based on the div element.
|
||||
*/
|
||||
scroller: SlotProps<'div', TabsScrollerSlotPropsOverrides, TabsOwnerState>;
|
||||
/**
|
||||
* Props forwarded to the list slot.
|
||||
* By default, the avaible props are based on the div element.
|
||||
*/
|
||||
list: SlotProps<'div', TabsListSlotPropsOverrides, TabsOwnerState>;
|
||||
/**
|
||||
* Props forwarded to the scrollbar slot.
|
||||
* By default, the avaible props are based on the div element.
|
||||
*/
|
||||
scrollbar: SlotProps<'div', {
|
||||
onChange?: (scrollbarWidth: undefined | number) => void;
|
||||
} & TabsScrollbarSlotPropsOverrides, TabsOwnerState>;
|
||||
/**
|
||||
* Props forwarded to the indicator slot.
|
||||
* By default, the avaible props are based on the span element.
|
||||
*/
|
||||
indicator: SlotProps<'span', TabsIndicatorSlotPropsOverrides, TabsOwnerState>;
|
||||
/**
|
||||
* Props forwarded to the scrollButton slot.
|
||||
* By default, the avaible props are based on the [TabScrollButton](https://mui.com/material-ui/api/tab-scroll-button/#props) component.
|
||||
*/
|
||||
scrollButtons: SlotProps<typeof TabScrollButton, TabsScrollButtonsSlotPropsOverrides, TabsOwnerState>;
|
||||
/**
|
||||
* Props forwarded to the startScrollButtonIcon slot.
|
||||
* By default, the avaible props are based on the [SvgIcon](https://mui.com/material-ui/api/svg-icon/#props) component.
|
||||
*/
|
||||
startScrollButtonIcon: SlotProps<typeof SvgIcon, TabsStartScrollButtonIconSlotPropsOverrides, TabsOwnerState>;
|
||||
/**
|
||||
* Props forwarded to the endScrollButtonIcon slot.
|
||||
* By default, the avaible props are based on the [SvgIcon](https://mui.com/material-ui/api/svg-icon/#props) component.
|
||||
*/
|
||||
endScrollButtonIcon: SlotProps<typeof SvgIcon, TabsEndScrollButtonIconSlotPropsOverrides, TabsOwnerState>;
|
||||
}> & {
|
||||
slots?: {
|
||||
/**
|
||||
* @deprecated Use `slots.startScrollButtonIcon` instead.
|
||||
*/
|
||||
StartScrollButtonIcon?: React.ElementType;
|
||||
/**
|
||||
* @deprecated Use `slots.endScrollButtonIcon` instead.
|
||||
*/
|
||||
EndScrollButtonIcon?: React.ElementType;
|
||||
};
|
||||
};
|
||||
export interface TabsOwnerState extends Omit<TabsProps, 'slots' | 'slotProps'> {
|
||||
vertical: boolean;
|
||||
fixed: boolean;
|
||||
hideScrollbar: boolean;
|
||||
scrollableX: boolean;
|
||||
scrollableY: boolean;
|
||||
centered: boolean;
|
||||
scrollButtonsHideMobile: boolean;
|
||||
}
|
||||
export interface TabsOwnProps extends TabsSlotsAndSlotProps {
|
||||
/**
|
||||
* Callback fired when the component mounts.
|
||||
* This is useful when you want to trigger an action programmatically.
|
||||
* It supports two actions: `updateIndicator()` and `updateScrollButtons()`
|
||||
*
|
||||
* @param {object} actions This object contains all possible actions
|
||||
* that can be triggered programmatically.
|
||||
*/
|
||||
action?: React.Ref<TabsActions>;
|
||||
/**
|
||||
* If `true`, the scroll buttons aren't forced hidden on mobile.
|
||||
* By default the scroll buttons are hidden on mobile and takes precedence over `scrollButtons`.
|
||||
* @default false
|
||||
*/
|
||||
allowScrollButtonsMobile?: boolean;
|
||||
/**
|
||||
* The label for the Tabs as a string.
|
||||
*/
|
||||
'aria-label'?: string;
|
||||
/**
|
||||
* An id or list of ids separated by a space that label the Tabs.
|
||||
*/
|
||||
'aria-labelledby'?: string;
|
||||
/**
|
||||
* If `true`, the tabs are centered.
|
||||
* This prop is intended for large views.
|
||||
* @default false
|
||||
*/
|
||||
centered?: boolean;
|
||||
/**
|
||||
* The content of the component.
|
||||
*/
|
||||
children?: React.ReactNode;
|
||||
/**
|
||||
* Override or extend the styles applied to the component.
|
||||
*/
|
||||
classes?: Partial<TabsClasses>;
|
||||
/**
|
||||
* Determines the color of the indicator.
|
||||
* @default 'primary'
|
||||
*/
|
||||
indicatorColor?: OverridableStringUnion<'secondary' | 'primary', TabsPropsIndicatorColorOverrides>;
|
||||
/**
|
||||
* Callback fired when the value changes.
|
||||
*
|
||||
* @param {React.SyntheticEvent} event The event source of the callback. **Warning**: This is a generic event not a change event.
|
||||
* @param {any} value We default to the index of the child (number)
|
||||
*/
|
||||
onChange?: (event: React.SyntheticEvent, value: any) => void;
|
||||
/**
|
||||
* The component orientation (layout flow direction).
|
||||
* @default 'horizontal'
|
||||
*/
|
||||
orientation?: 'horizontal' | 'vertical';
|
||||
/**
|
||||
* The component used to render the scroll buttons.
|
||||
* @deprecated use the `slots.scrollButtons` prop instead. This prop will be removed in a future major release. See [Migrating from deprecated APIs](https://mui.com/material-ui/migration/migrating-from-deprecated-apis/) for more details.
|
||||
* @default TabScrollButton
|
||||
*/
|
||||
ScrollButtonComponent?: React.ElementType;
|
||||
/**
|
||||
* Determine behavior of scroll buttons when tabs are set to scroll:
|
||||
*
|
||||
* - `auto` will only present them when not all the items are visible.
|
||||
* - `true` will always present them.
|
||||
* - `false` will never present them.
|
||||
*
|
||||
* By default the scroll buttons are hidden on mobile.
|
||||
* This behavior can be disabled with `allowScrollButtonsMobile`.
|
||||
* @default 'auto'
|
||||
*/
|
||||
scrollButtons?: 'auto' | true | false;
|
||||
/**
|
||||
* If `true` the selected tab changes on focus. Otherwise it only
|
||||
* changes on activation.
|
||||
*/
|
||||
selectionFollowsFocus?: boolean;
|
||||
/**
|
||||
* Props applied to the tab indicator element.
|
||||
* @deprecated use the `slotProps.indicator` prop instead. This prop will be removed in a future major release. See [Migrating from deprecated APIs](https://mui.com/material-ui/migration/migrating-from-deprecated-apis/) for more details.
|
||||
* @default {}
|
||||
*/
|
||||
TabIndicatorProps?: React.HTMLAttributes<HTMLDivElement> & {
|
||||
sx?: SxProps<Theme>;
|
||||
};
|
||||
/**
|
||||
* Props applied to the [`TabScrollButton`](https://mui.com/material-ui/api/tab-scroll-button/) element.
|
||||
* @deprecated use the `slotProps.scrollButtons` prop instead. This prop will be removed in a future major release. See [Migrating from deprecated APIs](https://mui.com/material-ui/migration/migrating-from-deprecated-apis/) for more details.
|
||||
* @default {}
|
||||
*/
|
||||
TabScrollButtonProps?: Partial<TabScrollButtonProps>;
|
||||
/**
|
||||
* Determines the color of the `Tab`.
|
||||
* @default 'primary'
|
||||
*/
|
||||
textColor?: 'secondary' | 'primary' | 'inherit';
|
||||
/**
|
||||
* The value of the currently selected `Tab`.
|
||||
* If you don't want any selected `Tab`, you can set this prop to `false`.
|
||||
*/
|
||||
value?: any;
|
||||
/**
|
||||
* Determines additional display behavior of the tabs:
|
||||
*
|
||||
* - `scrollable` will invoke scrolling properties and allow for horizontally
|
||||
* scrolling (or swiping) of the tab bar.
|
||||
* - `fullWidth` will make the tabs grow to use all the available space,
|
||||
* which should be used for small views, like on mobile.
|
||||
* - `standard` will render the default state.
|
||||
* @default 'standard'
|
||||
*/
|
||||
variant?: 'standard' | 'scrollable' | 'fullWidth';
|
||||
/**
|
||||
* If `true`, the scrollbar is visible. It can be useful when displaying
|
||||
* a long vertical list of tabs.
|
||||
* @default false
|
||||
*/
|
||||
visibleScrollbar?: boolean;
|
||||
/**
|
||||
* The system prop that allows defining system overrides as well as additional CSS styles.
|
||||
*/
|
||||
sx?: SxProps<Theme>;
|
||||
}
|
||||
export interface TabsTypeMap<AdditionalProps = {}, RootComponent extends React.ElementType = 'div'> {
|
||||
props: AdditionalProps & TabsOwnProps;
|
||||
defaultComponent: RootComponent;
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* Demos:
|
||||
*
|
||||
* - [Tabs](https://mui.com/material-ui/react-tabs/)
|
||||
*
|
||||
* API:
|
||||
*
|
||||
* - [Tabs API](https://mui.com/material-ui/api/tabs/)
|
||||
*/
|
||||
declare const Tabs: OverridableComponent<TabsTypeMap>;
|
||||
export interface TabsActions {
|
||||
updateIndicator(): void;
|
||||
updateScrollButtons(): void;
|
||||
}
|
||||
export type TabsProps<RootComponent extends React.ElementType = TabsTypeMap['defaultComponent'], AdditionalProps = {}> = OverrideProps<TabsTypeMap<AdditionalProps, RootComponent>, RootComponent> & {
|
||||
component?: React.ElementType;
|
||||
};
|
||||
export default Tabs;
|
||||
962
node_modules/@mui/material/Tabs/Tabs.js
generated
vendored
Normal file
962
node_modules/@mui/material/Tabs/Tabs.js
generated
vendored
Normal file
|
|
@ -0,0 +1,962 @@
|
|||
"use strict";
|
||||
'use client';
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
var React = _interopRequireWildcard(require("react"));
|
||||
var _reactIs = require("react-is");
|
||||
var _propTypes = _interopRequireDefault(require("prop-types"));
|
||||
var _clsx = _interopRequireDefault(require("clsx"));
|
||||
var _refType = _interopRequireDefault(require("@mui/utils/refType"));
|
||||
var _composeClasses = _interopRequireDefault(require("@mui/utils/composeClasses"));
|
||||
var _RtlProvider = require("@mui/system/RtlProvider");
|
||||
var _useSlotProps = _interopRequireDefault(require("@mui/utils/useSlotProps"));
|
||||
var _zeroStyled = require("../zero-styled");
|
||||
var _memoTheme = _interopRequireDefault(require("../utils/memoTheme"));
|
||||
var _DefaultPropsProvider = require("../DefaultPropsProvider");
|
||||
var _debounce = _interopRequireDefault(require("../utils/debounce"));
|
||||
var _animate = _interopRequireDefault(require("../internal/animate"));
|
||||
var _ScrollbarSize = _interopRequireDefault(require("./ScrollbarSize"));
|
||||
var _TabScrollButton = _interopRequireDefault(require("../TabScrollButton"));
|
||||
var _useEventCallback = _interopRequireDefault(require("../utils/useEventCallback"));
|
||||
var _tabsClasses = _interopRequireWildcard(require("./tabsClasses"));
|
||||
var _ownerDocument = _interopRequireDefault(require("../utils/ownerDocument"));
|
||||
var _ownerWindow = _interopRequireDefault(require("../utils/ownerWindow"));
|
||||
var _useSlot = _interopRequireDefault(require("../utils/useSlot"));
|
||||
var _jsxRuntime = require("react/jsx-runtime");
|
||||
const nextItem = (list, item) => {
|
||||
if (list === item) {
|
||||
return list.firstChild;
|
||||
}
|
||||
if (item && item.nextElementSibling) {
|
||||
return item.nextElementSibling;
|
||||
}
|
||||
return list.firstChild;
|
||||
};
|
||||
const previousItem = (list, item) => {
|
||||
if (list === item) {
|
||||
return list.lastChild;
|
||||
}
|
||||
if (item && item.previousElementSibling) {
|
||||
return item.previousElementSibling;
|
||||
}
|
||||
return list.lastChild;
|
||||
};
|
||||
const moveFocus = (list, currentFocus, traversalFunction) => {
|
||||
let wrappedOnce = false;
|
||||
let nextFocus = traversalFunction(list, currentFocus);
|
||||
while (nextFocus) {
|
||||
// Prevent infinite loop.
|
||||
if (nextFocus === list.firstChild) {
|
||||
if (wrappedOnce) {
|
||||
return;
|
||||
}
|
||||
wrappedOnce = true;
|
||||
}
|
||||
|
||||
// Same logic as useAutocomplete.js
|
||||
const nextFocusDisabled = nextFocus.disabled || nextFocus.getAttribute('aria-disabled') === 'true';
|
||||
if (!nextFocus.hasAttribute('tabindex') || nextFocusDisabled) {
|
||||
// Move to the next element.
|
||||
nextFocus = traversalFunction(list, nextFocus);
|
||||
} else {
|
||||
nextFocus.focus();
|
||||
return;
|
||||
}
|
||||
}
|
||||
};
|
||||
const useUtilityClasses = ownerState => {
|
||||
const {
|
||||
vertical,
|
||||
fixed,
|
||||
hideScrollbar,
|
||||
scrollableX,
|
||||
scrollableY,
|
||||
centered,
|
||||
scrollButtonsHideMobile,
|
||||
classes
|
||||
} = ownerState;
|
||||
const slots = {
|
||||
root: ['root', vertical && 'vertical'],
|
||||
scroller: ['scroller', fixed && 'fixed', hideScrollbar && 'hideScrollbar', scrollableX && 'scrollableX', scrollableY && 'scrollableY'],
|
||||
list: ['list', 'flexContainer', vertical && 'flexContainerVertical', vertical && 'vertical', centered && 'centered'],
|
||||
indicator: ['indicator'],
|
||||
scrollButtons: ['scrollButtons', scrollButtonsHideMobile && 'scrollButtonsHideMobile'],
|
||||
scrollableX: [scrollableX && 'scrollableX'],
|
||||
hideScrollbar: [hideScrollbar && 'hideScrollbar']
|
||||
};
|
||||
return (0, _composeClasses.default)(slots, _tabsClasses.getTabsUtilityClass, classes);
|
||||
};
|
||||
const TabsRoot = (0, _zeroStyled.styled)('div', {
|
||||
name: 'MuiTabs',
|
||||
slot: 'Root',
|
||||
overridesResolver: (props, styles) => {
|
||||
const {
|
||||
ownerState
|
||||
} = props;
|
||||
return [{
|
||||
[`& .${_tabsClasses.default.scrollButtons}`]: styles.scrollButtons
|
||||
}, {
|
||||
[`& .${_tabsClasses.default.scrollButtons}`]: ownerState.scrollButtonsHideMobile && styles.scrollButtonsHideMobile
|
||||
}, styles.root, ownerState.vertical && styles.vertical];
|
||||
}
|
||||
})((0, _memoTheme.default)(({
|
||||
theme
|
||||
}) => ({
|
||||
overflow: 'hidden',
|
||||
minHeight: 48,
|
||||
// Add iOS momentum scrolling for iOS < 13.0
|
||||
WebkitOverflowScrolling: 'touch',
|
||||
display: 'flex',
|
||||
variants: [{
|
||||
props: ({
|
||||
ownerState
|
||||
}) => ownerState.vertical,
|
||||
style: {
|
||||
flexDirection: 'column'
|
||||
}
|
||||
}, {
|
||||
props: ({
|
||||
ownerState
|
||||
}) => ownerState.scrollButtonsHideMobile,
|
||||
style: {
|
||||
[`& .${_tabsClasses.default.scrollButtons}`]: {
|
||||
[theme.breakpoints.down('sm')]: {
|
||||
display: 'none'
|
||||
}
|
||||
}
|
||||
}
|
||||
}]
|
||||
})));
|
||||
const TabsScroller = (0, _zeroStyled.styled)('div', {
|
||||
name: 'MuiTabs',
|
||||
slot: 'Scroller',
|
||||
overridesResolver: (props, styles) => {
|
||||
const {
|
||||
ownerState
|
||||
} = props;
|
||||
return [styles.scroller, ownerState.fixed && styles.fixed, ownerState.hideScrollbar && styles.hideScrollbar, ownerState.scrollableX && styles.scrollableX, ownerState.scrollableY && styles.scrollableY];
|
||||
}
|
||||
})({
|
||||
position: 'relative',
|
||||
display: 'inline-block',
|
||||
flex: '1 1 auto',
|
||||
whiteSpace: 'nowrap',
|
||||
variants: [{
|
||||
props: ({
|
||||
ownerState
|
||||
}) => ownerState.fixed,
|
||||
style: {
|
||||
overflowX: 'hidden',
|
||||
width: '100%'
|
||||
}
|
||||
}, {
|
||||
props: ({
|
||||
ownerState
|
||||
}) => ownerState.hideScrollbar,
|
||||
style: {
|
||||
// Hide dimensionless scrollbar on macOS
|
||||
scrollbarWidth: 'none',
|
||||
// Firefox
|
||||
'&::-webkit-scrollbar': {
|
||||
display: 'none' // Safari + Chrome
|
||||
}
|
||||
}
|
||||
}, {
|
||||
props: ({
|
||||
ownerState
|
||||
}) => ownerState.scrollableX,
|
||||
style: {
|
||||
overflowX: 'auto',
|
||||
overflowY: 'hidden'
|
||||
}
|
||||
}, {
|
||||
props: ({
|
||||
ownerState
|
||||
}) => ownerState.scrollableY,
|
||||
style: {
|
||||
overflowY: 'auto',
|
||||
overflowX: 'hidden'
|
||||
}
|
||||
}]
|
||||
});
|
||||
const List = (0, _zeroStyled.styled)('div', {
|
||||
name: 'MuiTabs',
|
||||
slot: 'List',
|
||||
overridesResolver: (props, styles) => {
|
||||
const {
|
||||
ownerState
|
||||
} = props;
|
||||
return [styles.list, styles.flexContainer, ownerState.vertical && styles.flexContainerVertical, ownerState.centered && styles.centered];
|
||||
}
|
||||
})({
|
||||
display: 'flex',
|
||||
variants: [{
|
||||
props: ({
|
||||
ownerState
|
||||
}) => ownerState.vertical,
|
||||
style: {
|
||||
flexDirection: 'column'
|
||||
}
|
||||
}, {
|
||||
props: ({
|
||||
ownerState
|
||||
}) => ownerState.centered,
|
||||
style: {
|
||||
justifyContent: 'center'
|
||||
}
|
||||
}]
|
||||
});
|
||||
const TabsIndicator = (0, _zeroStyled.styled)('span', {
|
||||
name: 'MuiTabs',
|
||||
slot: 'Indicator'
|
||||
})((0, _memoTheme.default)(({
|
||||
theme
|
||||
}) => ({
|
||||
position: 'absolute',
|
||||
height: 2,
|
||||
bottom: 0,
|
||||
width: '100%',
|
||||
transition: theme.transitions.create(),
|
||||
variants: [{
|
||||
props: {
|
||||
indicatorColor: 'primary'
|
||||
},
|
||||
style: {
|
||||
backgroundColor: (theme.vars || theme).palette.primary.main
|
||||
}
|
||||
}, {
|
||||
props: {
|
||||
indicatorColor: 'secondary'
|
||||
},
|
||||
style: {
|
||||
backgroundColor: (theme.vars || theme).palette.secondary.main
|
||||
}
|
||||
}, {
|
||||
props: ({
|
||||
ownerState
|
||||
}) => ownerState.vertical,
|
||||
style: {
|
||||
height: '100%',
|
||||
width: 2,
|
||||
right: 0
|
||||
}
|
||||
}]
|
||||
})));
|
||||
const TabsScrollbarSize = (0, _zeroStyled.styled)(_ScrollbarSize.default)({
|
||||
overflowX: 'auto',
|
||||
overflowY: 'hidden',
|
||||
// Hide dimensionless scrollbar on macOS
|
||||
scrollbarWidth: 'none',
|
||||
// Firefox
|
||||
'&::-webkit-scrollbar': {
|
||||
display: 'none' // Safari + Chrome
|
||||
}
|
||||
});
|
||||
const defaultIndicatorStyle = {};
|
||||
let warnedOnceTabPresent = false;
|
||||
const Tabs = /*#__PURE__*/React.forwardRef(function Tabs(inProps, ref) {
|
||||
const props = (0, _DefaultPropsProvider.useDefaultProps)({
|
||||
props: inProps,
|
||||
name: 'MuiTabs'
|
||||
});
|
||||
const theme = (0, _zeroStyled.useTheme)();
|
||||
const isRtl = (0, _RtlProvider.useRtl)();
|
||||
const {
|
||||
'aria-label': ariaLabel,
|
||||
'aria-labelledby': ariaLabelledBy,
|
||||
action,
|
||||
centered = false,
|
||||
children: childrenProp,
|
||||
className,
|
||||
component = 'div',
|
||||
allowScrollButtonsMobile = false,
|
||||
indicatorColor = 'primary',
|
||||
onChange,
|
||||
orientation = 'horizontal',
|
||||
ScrollButtonComponent,
|
||||
// TODO: remove in v7 (deprecated in v6)
|
||||
scrollButtons = 'auto',
|
||||
selectionFollowsFocus,
|
||||
slots = {},
|
||||
slotProps = {},
|
||||
TabIndicatorProps = {},
|
||||
// TODO: remove in v7 (deprecated in v6)
|
||||
TabScrollButtonProps = {},
|
||||
// TODO: remove in v7 (deprecated in v6)
|
||||
textColor = 'primary',
|
||||
value,
|
||||
variant = 'standard',
|
||||
visibleScrollbar = false,
|
||||
...other
|
||||
} = props;
|
||||
const scrollable = variant === 'scrollable';
|
||||
const vertical = orientation === 'vertical';
|
||||
const scrollStart = vertical ? 'scrollTop' : 'scrollLeft';
|
||||
const start = vertical ? 'top' : 'left';
|
||||
const end = vertical ? 'bottom' : 'right';
|
||||
const clientSize = vertical ? 'clientHeight' : 'clientWidth';
|
||||
const size = vertical ? 'height' : 'width';
|
||||
const ownerState = {
|
||||
...props,
|
||||
component,
|
||||
allowScrollButtonsMobile,
|
||||
indicatorColor,
|
||||
orientation,
|
||||
vertical,
|
||||
scrollButtons,
|
||||
textColor,
|
||||
variant,
|
||||
visibleScrollbar,
|
||||
fixed: !scrollable,
|
||||
hideScrollbar: scrollable && !visibleScrollbar,
|
||||
scrollableX: scrollable && !vertical,
|
||||
scrollableY: scrollable && vertical,
|
||||
centered: centered && !scrollable,
|
||||
scrollButtonsHideMobile: !allowScrollButtonsMobile
|
||||
};
|
||||
const classes = useUtilityClasses(ownerState);
|
||||
const startScrollButtonIconProps = (0, _useSlotProps.default)({
|
||||
elementType: slots.StartScrollButtonIcon,
|
||||
externalSlotProps: slotProps.startScrollButtonIcon,
|
||||
ownerState
|
||||
});
|
||||
const endScrollButtonIconProps = (0, _useSlotProps.default)({
|
||||
elementType: slots.EndScrollButtonIcon,
|
||||
externalSlotProps: slotProps.endScrollButtonIcon,
|
||||
ownerState
|
||||
});
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
if (centered && scrollable) {
|
||||
console.error('MUI: You can not use the `centered={true}` and `variant="scrollable"` properties ' + 'at the same time on a `Tabs` component.');
|
||||
}
|
||||
}
|
||||
const [mounted, setMounted] = React.useState(false);
|
||||
const [indicatorStyle, setIndicatorStyle] = React.useState(defaultIndicatorStyle);
|
||||
const [displayStartScroll, setDisplayStartScroll] = React.useState(false);
|
||||
const [displayEndScroll, setDisplayEndScroll] = React.useState(false);
|
||||
const [updateScrollObserver, setUpdateScrollObserver] = React.useState(false);
|
||||
const [scrollerStyle, setScrollerStyle] = React.useState({
|
||||
overflow: 'hidden',
|
||||
scrollbarWidth: 0
|
||||
});
|
||||
const valueToIndex = new Map();
|
||||
const tabsRef = React.useRef(null);
|
||||
const tabListRef = React.useRef(null);
|
||||
const externalForwardedProps = {
|
||||
slots,
|
||||
slotProps: {
|
||||
indicator: TabIndicatorProps,
|
||||
scrollButton: TabScrollButtonProps,
|
||||
...slotProps
|
||||
}
|
||||
};
|
||||
const getTabsMeta = () => {
|
||||
const tabsNode = tabsRef.current;
|
||||
let tabsMeta;
|
||||
if (tabsNode) {
|
||||
const rect = tabsNode.getBoundingClientRect();
|
||||
// create a new object with ClientRect class props + scrollLeft
|
||||
tabsMeta = {
|
||||
clientWidth: tabsNode.clientWidth,
|
||||
scrollLeft: tabsNode.scrollLeft,
|
||||
scrollTop: tabsNode.scrollTop,
|
||||
scrollWidth: tabsNode.scrollWidth,
|
||||
top: rect.top,
|
||||
bottom: rect.bottom,
|
||||
left: rect.left,
|
||||
right: rect.right
|
||||
};
|
||||
}
|
||||
let tabMeta;
|
||||
if (tabsNode && value !== false) {
|
||||
const children = tabListRef.current.children;
|
||||
if (children.length > 0) {
|
||||
const tab = children[valueToIndex.get(value)];
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
if (!tab) {
|
||||
console.error([`MUI: The \`value\` provided to the Tabs component is invalid.`, `None of the Tabs' children match with "${value}".`, valueToIndex.keys ? `You can provide one of the following values: ${Array.from(valueToIndex.keys()).join(', ')}.` : null].join('\n'));
|
||||
}
|
||||
}
|
||||
tabMeta = tab ? tab.getBoundingClientRect() : null;
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
if (process.env.NODE_ENV !== 'test' && !warnedOnceTabPresent && tabMeta && tabMeta.width === 0 && tabMeta.height === 0 &&
|
||||
// if the whole Tabs component is hidden, don't warn
|
||||
tabsMeta.clientWidth !== 0) {
|
||||
tabsMeta = null;
|
||||
console.error(['MUI: The `value` provided to the Tabs component is invalid.', `The Tab with this \`value\` ("${value}") is not part of the document layout.`, "Make sure the tab item is present in the document or that it's not `display: none`."].join('\n'));
|
||||
warnedOnceTabPresent = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return {
|
||||
tabsMeta,
|
||||
tabMeta
|
||||
};
|
||||
};
|
||||
const updateIndicatorState = (0, _useEventCallback.default)(() => {
|
||||
const {
|
||||
tabsMeta,
|
||||
tabMeta
|
||||
} = getTabsMeta();
|
||||
let startValue = 0;
|
||||
let startIndicator;
|
||||
if (vertical) {
|
||||
startIndicator = 'top';
|
||||
if (tabMeta && tabsMeta) {
|
||||
startValue = tabMeta.top - tabsMeta.top + tabsMeta.scrollTop;
|
||||
}
|
||||
} else {
|
||||
startIndicator = isRtl ? 'right' : 'left';
|
||||
if (tabMeta && tabsMeta) {
|
||||
startValue = (isRtl ? -1 : 1) * (tabMeta[startIndicator] - tabsMeta[startIndicator] + tabsMeta.scrollLeft);
|
||||
}
|
||||
}
|
||||
const newIndicatorStyle = {
|
||||
[startIndicator]: startValue,
|
||||
// May be wrong until the font is loaded.
|
||||
[size]: tabMeta ? tabMeta[size] : 0
|
||||
};
|
||||
if (typeof indicatorStyle[startIndicator] !== 'number' || typeof indicatorStyle[size] !== 'number') {
|
||||
setIndicatorStyle(newIndicatorStyle);
|
||||
} else {
|
||||
const dStart = Math.abs(indicatorStyle[startIndicator] - newIndicatorStyle[startIndicator]);
|
||||
const dSize = Math.abs(indicatorStyle[size] - newIndicatorStyle[size]);
|
||||
if (dStart >= 1 || dSize >= 1) {
|
||||
setIndicatorStyle(newIndicatorStyle);
|
||||
}
|
||||
}
|
||||
});
|
||||
const scroll = (scrollValue, {
|
||||
animation = true
|
||||
} = {}) => {
|
||||
if (animation) {
|
||||
(0, _animate.default)(scrollStart, tabsRef.current, scrollValue, {
|
||||
duration: theme.transitions.duration.standard
|
||||
});
|
||||
} else {
|
||||
tabsRef.current[scrollStart] = scrollValue;
|
||||
}
|
||||
};
|
||||
const moveTabsScroll = delta => {
|
||||
let scrollValue = tabsRef.current[scrollStart];
|
||||
if (vertical) {
|
||||
scrollValue += delta;
|
||||
} else {
|
||||
scrollValue += delta * (isRtl ? -1 : 1);
|
||||
}
|
||||
scroll(scrollValue);
|
||||
};
|
||||
const getScrollSize = () => {
|
||||
const containerSize = tabsRef.current[clientSize];
|
||||
let totalSize = 0;
|
||||
const children = Array.from(tabListRef.current.children);
|
||||
for (let i = 0; i < children.length; i += 1) {
|
||||
const tab = children[i];
|
||||
if (totalSize + tab[clientSize] > containerSize) {
|
||||
// If the first item is longer than the container size, then only scroll
|
||||
// by the container size.
|
||||
if (i === 0) {
|
||||
totalSize = containerSize;
|
||||
}
|
||||
break;
|
||||
}
|
||||
totalSize += tab[clientSize];
|
||||
}
|
||||
return totalSize;
|
||||
};
|
||||
const handleStartScrollClick = () => {
|
||||
moveTabsScroll(-1 * getScrollSize());
|
||||
};
|
||||
const handleEndScrollClick = () => {
|
||||
moveTabsScroll(getScrollSize());
|
||||
};
|
||||
const [ScrollbarSlot, {
|
||||
onChange: scrollbarOnChange,
|
||||
...scrollbarSlotProps
|
||||
}] = (0, _useSlot.default)('scrollbar', {
|
||||
className: (0, _clsx.default)(classes.scrollableX, classes.hideScrollbar),
|
||||
elementType: TabsScrollbarSize,
|
||||
shouldForwardComponentProp: true,
|
||||
externalForwardedProps,
|
||||
ownerState
|
||||
});
|
||||
|
||||
// TODO Remove <ScrollbarSize /> as browser support for hiding the scrollbar
|
||||
// with CSS improves.
|
||||
const handleScrollbarSizeChange = React.useCallback(scrollbarWidth => {
|
||||
scrollbarOnChange?.(scrollbarWidth);
|
||||
setScrollerStyle({
|
||||
overflow: null,
|
||||
scrollbarWidth
|
||||
});
|
||||
}, [scrollbarOnChange]);
|
||||
const [ScrollButtonsSlot, scrollButtonSlotProps] = (0, _useSlot.default)('scrollButtons', {
|
||||
className: (0, _clsx.default)(classes.scrollButtons, TabScrollButtonProps.className),
|
||||
elementType: _TabScrollButton.default,
|
||||
externalForwardedProps,
|
||||
ownerState,
|
||||
additionalProps: {
|
||||
orientation,
|
||||
slots: {
|
||||
StartScrollButtonIcon: slots.startScrollButtonIcon || slots.StartScrollButtonIcon,
|
||||
EndScrollButtonIcon: slots.endScrollButtonIcon || slots.EndScrollButtonIcon
|
||||
},
|
||||
slotProps: {
|
||||
startScrollButtonIcon: startScrollButtonIconProps,
|
||||
endScrollButtonIcon: endScrollButtonIconProps
|
||||
}
|
||||
}
|
||||
});
|
||||
const getConditionalElements = () => {
|
||||
const conditionalElements = {};
|
||||
conditionalElements.scrollbarSizeListener = scrollable ? /*#__PURE__*/(0, _jsxRuntime.jsx)(ScrollbarSlot, {
|
||||
...scrollbarSlotProps,
|
||||
onChange: handleScrollbarSizeChange
|
||||
}) : null;
|
||||
const scrollButtonsActive = displayStartScroll || displayEndScroll;
|
||||
const showScrollButtons = scrollable && (scrollButtons === 'auto' && scrollButtonsActive || scrollButtons === true);
|
||||
conditionalElements.scrollButtonStart = showScrollButtons ? /*#__PURE__*/(0, _jsxRuntime.jsx)(ScrollButtonsSlot, {
|
||||
direction: isRtl ? 'right' : 'left',
|
||||
onClick: handleStartScrollClick,
|
||||
disabled: !displayStartScroll,
|
||||
...scrollButtonSlotProps
|
||||
}) : null;
|
||||
conditionalElements.scrollButtonEnd = showScrollButtons ? /*#__PURE__*/(0, _jsxRuntime.jsx)(ScrollButtonsSlot, {
|
||||
direction: isRtl ? 'left' : 'right',
|
||||
onClick: handleEndScrollClick,
|
||||
disabled: !displayEndScroll,
|
||||
...scrollButtonSlotProps
|
||||
}) : null;
|
||||
return conditionalElements;
|
||||
};
|
||||
const scrollSelectedIntoView = (0, _useEventCallback.default)(animation => {
|
||||
const {
|
||||
tabsMeta,
|
||||
tabMeta
|
||||
} = getTabsMeta();
|
||||
if (!tabMeta || !tabsMeta) {
|
||||
return;
|
||||
}
|
||||
if (tabMeta[start] < tabsMeta[start]) {
|
||||
// left side of button is out of view
|
||||
const nextScrollStart = tabsMeta[scrollStart] + (tabMeta[start] - tabsMeta[start]);
|
||||
scroll(nextScrollStart, {
|
||||
animation
|
||||
});
|
||||
} else if (tabMeta[end] > tabsMeta[end]) {
|
||||
// right side of button is out of view
|
||||
const nextScrollStart = tabsMeta[scrollStart] + (tabMeta[end] - tabsMeta[end]);
|
||||
scroll(nextScrollStart, {
|
||||
animation
|
||||
});
|
||||
}
|
||||
});
|
||||
const updateScrollButtonState = (0, _useEventCallback.default)(() => {
|
||||
if (scrollable && scrollButtons !== false) {
|
||||
setUpdateScrollObserver(!updateScrollObserver);
|
||||
}
|
||||
});
|
||||
React.useEffect(() => {
|
||||
const handleResize = (0, _debounce.default)(() => {
|
||||
// If the Tabs component is replaced by Suspense with a fallback, the last
|
||||
// ResizeObserver's handler that runs because of the change in the layout is trying to
|
||||
// access a dom node that is no longer there (as the fallback component is being shown instead).
|
||||
// See https://github.com/mui/material-ui/issues/33276
|
||||
// TODO: Add tests that will ensure the component is not failing when
|
||||
// replaced by Suspense with a fallback, once React is updated to version 18
|
||||
if (tabsRef.current) {
|
||||
updateIndicatorState();
|
||||
}
|
||||
});
|
||||
let resizeObserver;
|
||||
|
||||
/**
|
||||
* @type {MutationCallback}
|
||||
*/
|
||||
const handleMutation = records => {
|
||||
records.forEach(record => {
|
||||
record.removedNodes.forEach(item => {
|
||||
resizeObserver?.unobserve(item);
|
||||
});
|
||||
record.addedNodes.forEach(item => {
|
||||
resizeObserver?.observe(item);
|
||||
});
|
||||
});
|
||||
handleResize();
|
||||
updateScrollButtonState();
|
||||
};
|
||||
const win = (0, _ownerWindow.default)(tabsRef.current);
|
||||
win.addEventListener('resize', handleResize);
|
||||
let mutationObserver;
|
||||
if (typeof ResizeObserver !== 'undefined') {
|
||||
resizeObserver = new ResizeObserver(handleResize);
|
||||
Array.from(tabListRef.current.children).forEach(child => {
|
||||
resizeObserver.observe(child);
|
||||
});
|
||||
}
|
||||
if (typeof MutationObserver !== 'undefined') {
|
||||
mutationObserver = new MutationObserver(handleMutation);
|
||||
mutationObserver.observe(tabListRef.current, {
|
||||
childList: true
|
||||
});
|
||||
}
|
||||
return () => {
|
||||
handleResize.clear();
|
||||
win.removeEventListener('resize', handleResize);
|
||||
mutationObserver?.disconnect();
|
||||
resizeObserver?.disconnect();
|
||||
};
|
||||
}, [updateIndicatorState, updateScrollButtonState]);
|
||||
|
||||
/**
|
||||
* Toggle visibility of start and end scroll buttons
|
||||
* Using IntersectionObserver on first and last Tabs.
|
||||
*/
|
||||
React.useEffect(() => {
|
||||
const tabListChildren = Array.from(tabListRef.current.children);
|
||||
const length = tabListChildren.length;
|
||||
if (typeof IntersectionObserver !== 'undefined' && length > 0 && scrollable && scrollButtons !== false) {
|
||||
const firstTab = tabListChildren[0];
|
||||
const lastTab = tabListChildren[length - 1];
|
||||
const observerOptions = {
|
||||
root: tabsRef.current,
|
||||
threshold: 0.99
|
||||
};
|
||||
const handleScrollButtonStart = entries => {
|
||||
setDisplayStartScroll(!entries[0].isIntersecting);
|
||||
};
|
||||
const firstObserver = new IntersectionObserver(handleScrollButtonStart, observerOptions);
|
||||
firstObserver.observe(firstTab);
|
||||
const handleScrollButtonEnd = entries => {
|
||||
setDisplayEndScroll(!entries[0].isIntersecting);
|
||||
};
|
||||
const lastObserver = new IntersectionObserver(handleScrollButtonEnd, observerOptions);
|
||||
lastObserver.observe(lastTab);
|
||||
return () => {
|
||||
firstObserver.disconnect();
|
||||
lastObserver.disconnect();
|
||||
};
|
||||
}
|
||||
return undefined;
|
||||
}, [scrollable, scrollButtons, updateScrollObserver, childrenProp?.length]);
|
||||
React.useEffect(() => {
|
||||
setMounted(true);
|
||||
}, []);
|
||||
React.useEffect(() => {
|
||||
updateIndicatorState();
|
||||
});
|
||||
React.useEffect(() => {
|
||||
// Don't animate on the first render.
|
||||
scrollSelectedIntoView(defaultIndicatorStyle !== indicatorStyle);
|
||||
}, [scrollSelectedIntoView, indicatorStyle]);
|
||||
React.useImperativeHandle(action, () => ({
|
||||
updateIndicator: updateIndicatorState,
|
||||
updateScrollButtons: updateScrollButtonState
|
||||
}), [updateIndicatorState, updateScrollButtonState]);
|
||||
const [IndicatorSlot, indicatorSlotProps] = (0, _useSlot.default)('indicator', {
|
||||
className: (0, _clsx.default)(classes.indicator, TabIndicatorProps.className),
|
||||
elementType: TabsIndicator,
|
||||
externalForwardedProps,
|
||||
ownerState,
|
||||
additionalProps: {
|
||||
style: indicatorStyle
|
||||
}
|
||||
});
|
||||
const indicator = /*#__PURE__*/(0, _jsxRuntime.jsx)(IndicatorSlot, {
|
||||
...indicatorSlotProps
|
||||
});
|
||||
let childIndex = 0;
|
||||
const children = React.Children.map(childrenProp, child => {
|
||||
if (! /*#__PURE__*/React.isValidElement(child)) {
|
||||
return null;
|
||||
}
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
if ((0, _reactIs.isFragment)(child)) {
|
||||
console.error(["MUI: The Tabs component doesn't accept a Fragment as a child.", 'Consider providing an array instead.'].join('\n'));
|
||||
}
|
||||
}
|
||||
const childValue = child.props.value === undefined ? childIndex : child.props.value;
|
||||
valueToIndex.set(childValue, childIndex);
|
||||
const selected = childValue === value;
|
||||
childIndex += 1;
|
||||
return /*#__PURE__*/React.cloneElement(child, {
|
||||
fullWidth: variant === 'fullWidth',
|
||||
indicator: selected && !mounted && indicator,
|
||||
selected,
|
||||
selectionFollowsFocus,
|
||||
onChange,
|
||||
textColor,
|
||||
value: childValue,
|
||||
...(childIndex === 1 && value === false && !child.props.tabIndex ? {
|
||||
tabIndex: 0
|
||||
} : {})
|
||||
});
|
||||
});
|
||||
const handleKeyDown = event => {
|
||||
// Check if a modifier key (Alt, Shift, Ctrl, Meta) is pressed
|
||||
if (event.altKey || event.shiftKey || event.ctrlKey || event.metaKey) {
|
||||
return;
|
||||
}
|
||||
const list = tabListRef.current;
|
||||
const currentFocus = (0, _ownerDocument.default)(list).activeElement;
|
||||
// Keyboard navigation assumes that [role="tab"] are siblings
|
||||
// though we might warn in the future about nested, interactive elements
|
||||
// as a a11y violation
|
||||
const role = currentFocus.getAttribute('role');
|
||||
if (role !== 'tab') {
|
||||
return;
|
||||
}
|
||||
let previousItemKey = orientation === 'horizontal' ? 'ArrowLeft' : 'ArrowUp';
|
||||
let nextItemKey = orientation === 'horizontal' ? 'ArrowRight' : 'ArrowDown';
|
||||
if (orientation === 'horizontal' && isRtl) {
|
||||
// swap previousItemKey with nextItemKey
|
||||
previousItemKey = 'ArrowRight';
|
||||
nextItemKey = 'ArrowLeft';
|
||||
}
|
||||
switch (event.key) {
|
||||
case previousItemKey:
|
||||
event.preventDefault();
|
||||
moveFocus(list, currentFocus, previousItem);
|
||||
break;
|
||||
case nextItemKey:
|
||||
event.preventDefault();
|
||||
moveFocus(list, currentFocus, nextItem);
|
||||
break;
|
||||
case 'Home':
|
||||
event.preventDefault();
|
||||
moveFocus(list, null, nextItem);
|
||||
break;
|
||||
case 'End':
|
||||
event.preventDefault();
|
||||
moveFocus(list, null, previousItem);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
};
|
||||
const conditionalElements = getConditionalElements();
|
||||
const [RootSlot, rootSlotProps] = (0, _useSlot.default)('root', {
|
||||
ref,
|
||||
className: (0, _clsx.default)(classes.root, className),
|
||||
elementType: TabsRoot,
|
||||
externalForwardedProps: {
|
||||
...externalForwardedProps,
|
||||
...other,
|
||||
component
|
||||
},
|
||||
ownerState
|
||||
});
|
||||
const [ScrollerSlot, scrollerSlotProps] = (0, _useSlot.default)('scroller', {
|
||||
ref: tabsRef,
|
||||
className: classes.scroller,
|
||||
elementType: TabsScroller,
|
||||
externalForwardedProps,
|
||||
ownerState,
|
||||
additionalProps: {
|
||||
style: {
|
||||
overflow: scrollerStyle.overflow,
|
||||
[vertical ? `margin${isRtl ? 'Left' : 'Right'}` : 'marginBottom']: visibleScrollbar ? undefined : -scrollerStyle.scrollbarWidth
|
||||
}
|
||||
}
|
||||
});
|
||||
const [ListSlot, listSlotProps] = (0, _useSlot.default)('list', {
|
||||
ref: tabListRef,
|
||||
className: (0, _clsx.default)(classes.list, classes.flexContainer),
|
||||
elementType: List,
|
||||
externalForwardedProps,
|
||||
ownerState,
|
||||
getSlotProps: handlers => ({
|
||||
...handlers,
|
||||
onKeyDown: event => {
|
||||
handleKeyDown(event);
|
||||
handlers.onKeyDown?.(event);
|
||||
}
|
||||
})
|
||||
});
|
||||
return /*#__PURE__*/(0, _jsxRuntime.jsxs)(RootSlot, {
|
||||
...rootSlotProps,
|
||||
children: [conditionalElements.scrollButtonStart, conditionalElements.scrollbarSizeListener, /*#__PURE__*/(0, _jsxRuntime.jsxs)(ScrollerSlot, {
|
||||
...scrollerSlotProps,
|
||||
children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(ListSlot, {
|
||||
"aria-label": ariaLabel,
|
||||
"aria-labelledby": ariaLabelledBy,
|
||||
"aria-orientation": orientation === 'vertical' ? 'vertical' : null,
|
||||
role: "tablist",
|
||||
...listSlotProps,
|
||||
children: children
|
||||
}), mounted && indicator]
|
||||
}), conditionalElements.scrollButtonEnd]
|
||||
});
|
||||
});
|
||||
process.env.NODE_ENV !== "production" ? Tabs.propTypes /* remove-proptypes */ = {
|
||||
// ┌────────────────────────────── Warning ──────────────────────────────┐
|
||||
// │ These PropTypes are generated from the TypeScript type definitions. │
|
||||
// │ To update them, edit the d.ts file and run `pnpm proptypes`. │
|
||||
// └─────────────────────────────────────────────────────────────────────┘
|
||||
/**
|
||||
* Callback fired when the component mounts.
|
||||
* This is useful when you want to trigger an action programmatically.
|
||||
* It supports two actions: `updateIndicator()` and `updateScrollButtons()`
|
||||
*
|
||||
* @param {object} actions This object contains all possible actions
|
||||
* that can be triggered programmatically.
|
||||
*/
|
||||
action: _refType.default,
|
||||
/**
|
||||
* If `true`, the scroll buttons aren't forced hidden on mobile.
|
||||
* By default the scroll buttons are hidden on mobile and takes precedence over `scrollButtons`.
|
||||
* @default false
|
||||
*/
|
||||
allowScrollButtonsMobile: _propTypes.default.bool,
|
||||
/**
|
||||
* The label for the Tabs as a string.
|
||||
*/
|
||||
'aria-label': _propTypes.default.string,
|
||||
/**
|
||||
* An id or list of ids separated by a space that label the Tabs.
|
||||
*/
|
||||
'aria-labelledby': _propTypes.default.string,
|
||||
/**
|
||||
* If `true`, the tabs are centered.
|
||||
* This prop is intended for large views.
|
||||
* @default false
|
||||
*/
|
||||
centered: _propTypes.default.bool,
|
||||
/**
|
||||
* The content of the component.
|
||||
*/
|
||||
children: _propTypes.default.node,
|
||||
/**
|
||||
* Override or extend the styles applied to the component.
|
||||
*/
|
||||
classes: _propTypes.default.object,
|
||||
/**
|
||||
* @ignore
|
||||
*/
|
||||
className: _propTypes.default.string,
|
||||
/**
|
||||
* The component used for the root node.
|
||||
* Either a string to use a HTML element or a component.
|
||||
*/
|
||||
component: _propTypes.default.elementType,
|
||||
/**
|
||||
* Determines the color of the indicator.
|
||||
* @default 'primary'
|
||||
*/
|
||||
indicatorColor: _propTypes.default /* @typescript-to-proptypes-ignore */.oneOfType([_propTypes.default.oneOf(['primary', 'secondary']), _propTypes.default.string]),
|
||||
/**
|
||||
* Callback fired when the value changes.
|
||||
*
|
||||
* @param {React.SyntheticEvent} event The event source of the callback. **Warning**: This is a generic event not a change event.
|
||||
* @param {any} value We default to the index of the child (number)
|
||||
*/
|
||||
onChange: _propTypes.default.func,
|
||||
/**
|
||||
* The component orientation (layout flow direction).
|
||||
* @default 'horizontal'
|
||||
*/
|
||||
orientation: _propTypes.default.oneOf(['horizontal', 'vertical']),
|
||||
/**
|
||||
* The component used to render the scroll buttons.
|
||||
* @deprecated use the `slots.scrollButtons` prop instead. This prop will be removed in a future major release. See [Migrating from deprecated APIs](https://mui.com/material-ui/migration/migrating-from-deprecated-apis/) for more details.
|
||||
* @default TabScrollButton
|
||||
*/
|
||||
ScrollButtonComponent: _propTypes.default.elementType,
|
||||
/**
|
||||
* Determine behavior of scroll buttons when tabs are set to scroll:
|
||||
*
|
||||
* - `auto` will only present them when not all the items are visible.
|
||||
* - `true` will always present them.
|
||||
* - `false` will never present them.
|
||||
*
|
||||
* By default the scroll buttons are hidden on mobile.
|
||||
* This behavior can be disabled with `allowScrollButtonsMobile`.
|
||||
* @default 'auto'
|
||||
*/
|
||||
scrollButtons: _propTypes.default /* @typescript-to-proptypes-ignore */.oneOf(['auto', false, true]),
|
||||
/**
|
||||
* If `true` the selected tab changes on focus. Otherwise it only
|
||||
* changes on activation.
|
||||
*/
|
||||
selectionFollowsFocus: _propTypes.default.bool,
|
||||
/**
|
||||
* The props used for each slot inside.
|
||||
* @default {}
|
||||
*/
|
||||
slotProps: _propTypes.default.shape({
|
||||
endScrollButtonIcon: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
|
||||
indicator: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
|
||||
list: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
|
||||
root: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
|
||||
scrollbar: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
|
||||
scrollButtons: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
|
||||
scroller: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object]),
|
||||
startScrollButtonIcon: _propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object])
|
||||
}),
|
||||
/**
|
||||
* The components used for each slot inside.
|
||||
* @default {}
|
||||
*/
|
||||
slots: _propTypes.default.shape({
|
||||
endScrollButtonIcon: _propTypes.default.elementType,
|
||||
EndScrollButtonIcon: _propTypes.default.elementType,
|
||||
indicator: _propTypes.default.elementType,
|
||||
list: _propTypes.default.elementType,
|
||||
root: _propTypes.default.elementType,
|
||||
scrollbar: _propTypes.default.elementType,
|
||||
scrollButtons: _propTypes.default.elementType,
|
||||
scroller: _propTypes.default.elementType,
|
||||
startScrollButtonIcon: _propTypes.default.elementType,
|
||||
StartScrollButtonIcon: _propTypes.default.elementType
|
||||
}),
|
||||
/**
|
||||
* The system prop that allows defining system overrides as well as additional CSS styles.
|
||||
*/
|
||||
sx: _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object, _propTypes.default.bool])), _propTypes.default.func, _propTypes.default.object]),
|
||||
/**
|
||||
* Props applied to the tab indicator element.
|
||||
* @deprecated use the `slotProps.indicator` prop instead. This prop will be removed in a future major release. See [Migrating from deprecated APIs](https://mui.com/material-ui/migration/migrating-from-deprecated-apis/) for more details.
|
||||
* @default {}
|
||||
*/
|
||||
TabIndicatorProps: _propTypes.default.object,
|
||||
/**
|
||||
* Props applied to the [`TabScrollButton`](https://mui.com/material-ui/api/tab-scroll-button/) element.
|
||||
* @deprecated use the `slotProps.scrollButtons` prop instead. This prop will be removed in a future major release. See [Migrating from deprecated APIs](https://mui.com/material-ui/migration/migrating-from-deprecated-apis/) for more details.
|
||||
* @default {}
|
||||
*/
|
||||
TabScrollButtonProps: _propTypes.default.object,
|
||||
/**
|
||||
* Determines the color of the `Tab`.
|
||||
* @default 'primary'
|
||||
*/
|
||||
textColor: _propTypes.default.oneOf(['inherit', 'primary', 'secondary']),
|
||||
/**
|
||||
* The value of the currently selected `Tab`.
|
||||
* If you don't want any selected `Tab`, you can set this prop to `false`.
|
||||
*/
|
||||
value: _propTypes.default.any,
|
||||
/**
|
||||
* Determines additional display behavior of the tabs:
|
||||
*
|
||||
* - `scrollable` will invoke scrolling properties and allow for horizontally
|
||||
* scrolling (or swiping) of the tab bar.
|
||||
* - `fullWidth` will make the tabs grow to use all the available space,
|
||||
* which should be used for small views, like on mobile.
|
||||
* - `standard` will render the default state.
|
||||
* @default 'standard'
|
||||
*/
|
||||
variant: _propTypes.default.oneOf(['fullWidth', 'scrollable', 'standard']),
|
||||
/**
|
||||
* If `true`, the scrollbar is visible. It can be useful when displaying
|
||||
* a long vertical list of tabs.
|
||||
* @default false
|
||||
*/
|
||||
visibleScrollbar: _propTypes.default.bool
|
||||
} : void 0;
|
||||
var _default = exports.default = Tabs;
|
||||
4
node_modules/@mui/material/Tabs/index.d.ts
generated
vendored
Normal file
4
node_modules/@mui/material/Tabs/index.d.ts
generated
vendored
Normal file
|
|
@ -0,0 +1,4 @@
|
|||
export { default } from "./Tabs.js";
|
||||
export * from "./Tabs.js";
|
||||
export { default as tabsClasses } from "./tabsClasses.js";
|
||||
export * from "./tabsClasses.js";
|
||||
35
node_modules/@mui/material/Tabs/index.js
generated
vendored
Normal file
35
node_modules/@mui/material/Tabs/index.js
generated
vendored
Normal file
|
|
@ -0,0 +1,35 @@
|
|||
"use strict";
|
||||
|
||||
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
var _exportNames = {
|
||||
tabsClasses: true
|
||||
};
|
||||
Object.defineProperty(exports, "default", {
|
||||
enumerable: true,
|
||||
get: function () {
|
||||
return _Tabs.default;
|
||||
}
|
||||
});
|
||||
Object.defineProperty(exports, "tabsClasses", {
|
||||
enumerable: true,
|
||||
get: function () {
|
||||
return _tabsClasses.default;
|
||||
}
|
||||
});
|
||||
var _Tabs = _interopRequireDefault(require("./Tabs"));
|
||||
var _tabsClasses = _interopRequireWildcard(require("./tabsClasses"));
|
||||
Object.keys(_tabsClasses).forEach(function (key) {
|
||||
if (key === "default" || key === "__esModule") return;
|
||||
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
||||
if (key in exports && exports[key] === _tabsClasses[key]) return;
|
||||
Object.defineProperty(exports, key, {
|
||||
enumerable: true,
|
||||
get: function () {
|
||||
return _tabsClasses[key];
|
||||
}
|
||||
});
|
||||
});
|
||||
36
node_modules/@mui/material/Tabs/tabsClasses.d.ts
generated
vendored
Normal file
36
node_modules/@mui/material/Tabs/tabsClasses.d.ts
generated
vendored
Normal file
|
|
@ -0,0 +1,36 @@
|
|||
export interface TabsClasses {
|
||||
/** Styles applied to the root element. */
|
||||
root: string;
|
||||
/** Styles applied to the root element if `orientation="vertical"`. */
|
||||
vertical: string;
|
||||
/** Styles applied to the flex container element. */
|
||||
/** @deprecated use `list` instead. See [Migrating from deprecated APIs](/material-ui/migration/migrating-from-deprecated-apis/) for more details. */
|
||||
flexContainer: string;
|
||||
/** Styles applied to the flex container element if `orientation="vertical"`. */
|
||||
/** @deprecated use a combination of `list` and `vertical` instead. See [Migrating from deprecated APIs](/material-ui/migration/migrating-from-deprecated-apis/) for more details. */
|
||||
flexContainerVertical: string;
|
||||
/** Styles applied to the list element. */
|
||||
list: string;
|
||||
/** Styles applied to the flex container element if `centered={true}` & `!variant="scrollable"`. */
|
||||
centered: string;
|
||||
/** Styles applied to the tablist element. */
|
||||
scroller: string;
|
||||
/** Styles applied to the tablist element if `!variant="scrollable"`. */
|
||||
fixed: string;
|
||||
/** Styles applied to the tablist element if `variant="scrollable"` and `orientation="horizontal"`. */
|
||||
scrollableX: string;
|
||||
/** Styles applied to the tablist element if `variant="scrollable"` and `orientation="vertical"`. */
|
||||
scrollableY: string;
|
||||
/** Styles applied to the tablist element if `variant="scrollable"` and `visibleScrollbar={false}`. */
|
||||
hideScrollbar: string;
|
||||
/** Styles applied to the ScrollButtonComponent component. */
|
||||
scrollButtons: string;
|
||||
/** Styles applied to the ScrollButtonComponent component if `allowScrollButtonsMobile={true}`. */
|
||||
scrollButtonsHideMobile: string;
|
||||
/** Styles applied to the TabIndicator component. */
|
||||
indicator: string;
|
||||
}
|
||||
export type TabsClassKey = keyof TabsClasses;
|
||||
export declare function getTabsUtilityClass(slot: string): string;
|
||||
declare const tabsClasses: TabsClasses;
|
||||
export default tabsClasses;
|
||||
15
node_modules/@mui/material/Tabs/tabsClasses.js
generated
vendored
Normal file
15
node_modules/@mui/material/Tabs/tabsClasses.js
generated
vendored
Normal file
|
|
@ -0,0 +1,15 @@
|
|||
"use strict";
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
exports.getTabsUtilityClass = getTabsUtilityClass;
|
||||
var _generateUtilityClasses = _interopRequireDefault(require("@mui/utils/generateUtilityClasses"));
|
||||
var _generateUtilityClass = _interopRequireDefault(require("@mui/utils/generateUtilityClass"));
|
||||
function getTabsUtilityClass(slot) {
|
||||
return (0, _generateUtilityClass.default)('MuiTabs', slot);
|
||||
}
|
||||
const tabsClasses = (0, _generateUtilityClasses.default)('MuiTabs', ['root', 'vertical', 'list', 'flexContainer', 'flexContainerVertical', 'centered', 'scroller', 'fixed', 'scrollableX', 'scrollableY', 'hideScrollbar', 'scrollButtons', 'scrollButtonsHideMobile', 'indicator']);
|
||||
var _default = exports.default = tabsClasses;
|
||||
Loading…
Add table
Add a link
Reference in a new issue