UNPKG

@mantine/core

Version:

React components library focused on usability, accessibility and developer experience

125 lines (122 loc) 3.42 kB
import React, { forwardRef } from 'react'; import { useComponentDefaultProps } from '@mantine/styles'; import { TabsList } from './TabsList/TabsList.js'; import { TabsPanel } from './TabsPanel/TabsPanel.js'; import { Tab } from './Tab/Tab.js'; import { TabsProvider } from './TabsProvider.js'; import useStyles from './Tabs.styles.js'; import { Box } from '../Box/Box.js'; var __defProp = Object.defineProperty; var __defProps = Object.defineProperties; var __getOwnPropDescs = Object.getOwnPropertyDescriptors; var __getOwnPropSymbols = Object.getOwnPropertySymbols; var __hasOwnProp = Object.prototype.hasOwnProperty; var __propIsEnum = Object.prototype.propertyIsEnumerable; var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; var __spreadValues = (a, b) => { for (var prop in b || (b = {})) if (__hasOwnProp.call(b, prop)) __defNormalProp(a, prop, b[prop]); if (__getOwnPropSymbols) for (var prop of __getOwnPropSymbols(b)) { if (__propIsEnum.call(b, prop)) __defNormalProp(a, prop, b[prop]); } return a; }; var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b)); var __objRest = (source, exclude) => { var target = {}; for (var prop in source) if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0) target[prop] = source[prop]; if (source != null && __getOwnPropSymbols) for (var prop of __getOwnPropSymbols(source)) { if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop)) target[prop] = source[prop]; } return target; }; const defaultProps = { orientation: "horizontal", loop: true, activateTabWithKeyboard: true, allowTabDeactivation: false, unstyled: false, inverted: false, variant: "default", placement: "left" }; const Tabs = forwardRef((props, ref) => { const _a = useComponentDefaultProps("Tabs", defaultProps, props), { defaultValue, value, orientation, loop, activateTabWithKeyboard, allowTabDeactivation, children, id, onTabChange, variant, color, className, unstyled, classNames, styles, radius, inverted, keepMounted, placement } = _a, others = __objRest(_a, [ "defaultValue", "value", "orientation", "loop", "activateTabWithKeyboard", "allowTabDeactivation", "children", "id", "onTabChange", "variant", "color", "className", "unstyled", "classNames", "styles", "radius", "inverted", "keepMounted", "placement" ]); const { classes, cx } = useStyles({ orientation, color, radius, inverted, placement }, { unstyled, name: "Tabs", classNames, styles, variant }); return /* @__PURE__ */ React.createElement(TabsProvider, { activateTabWithKeyboard, defaultValue, orientation, onTabChange, value, id, loop, allowTabDeactivation, color, variant, radius, inverted, keepMounted, placement, classNames, styles, unstyled }, /* @__PURE__ */ React.createElement(Box, __spreadProps(__spreadValues({}, others), { className: cx(classes.root, className), id, ref }), children)); }); Tabs.List = TabsList; Tabs.Tab = Tab; Tabs.Panel = TabsPanel; Tabs.displayName = "@mantine/core/Tabs"; export { Tabs }; //# sourceMappingURL=Tabs.js.map