Sider.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. "use strict";
  2. "use client";
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  5. Object.defineProperty(exports, "__esModule", {
  6. value: true
  7. });
  8. exports.default = exports.SiderContext = void 0;
  9. var _react = _interopRequireWildcard(require("react"));
  10. var React = _react;
  11. var _BarsOutlined = _interopRequireDefault(require("@ant-design/icons/BarsOutlined"));
  12. var _LeftOutlined = _interopRequireDefault(require("@ant-design/icons/LeftOutlined"));
  13. var _RightOutlined = _interopRequireDefault(require("@ant-design/icons/RightOutlined"));
  14. var _classnames = _interopRequireDefault(require("classnames"));
  15. var _omit = _interopRequireDefault(require("rc-util/lib/omit"));
  16. var _mediaQueryUtil = require("../_util/mediaQueryUtil");
  17. var _configProvider = require("../config-provider");
  18. var _context = require("./context");
  19. var _sider = _interopRequireDefault(require("./style/sider"));
  20. var __rest = void 0 && (void 0).__rest || function (s, e) {
  21. var t = {};
  22. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  23. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  24. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  25. }
  26. return t;
  27. };
  28. const dimensionMaxMap = {
  29. xs: '479.98px',
  30. sm: '575.98px',
  31. md: '767.98px',
  32. lg: '991.98px',
  33. xl: '1199.98px',
  34. xxl: '1599.98px'
  35. };
  36. const isNumeric = value => !Number.isNaN(Number.parseFloat(value)) && isFinite(value);
  37. const SiderContext = exports.SiderContext = /*#__PURE__*/React.createContext({});
  38. const generateId = (() => {
  39. let i = 0;
  40. return (prefix = '') => {
  41. i += 1;
  42. return `${prefix}${i}`;
  43. };
  44. })();
  45. const Sider = /*#__PURE__*/React.forwardRef((props, ref) => {
  46. const {
  47. prefixCls: customizePrefixCls,
  48. className,
  49. trigger,
  50. children,
  51. defaultCollapsed = false,
  52. theme = 'dark',
  53. style = {},
  54. collapsible = false,
  55. reverseArrow = false,
  56. width = 200,
  57. collapsedWidth = 80,
  58. zeroWidthTriggerStyle,
  59. breakpoint,
  60. onCollapse,
  61. onBreakpoint
  62. } = props,
  63. otherProps = __rest(props, ["prefixCls", "className", "trigger", "children", "defaultCollapsed", "theme", "style", "collapsible", "reverseArrow", "width", "collapsedWidth", "zeroWidthTriggerStyle", "breakpoint", "onCollapse", "onBreakpoint"]);
  64. const {
  65. siderHook
  66. } = (0, _react.useContext)(_context.LayoutContext);
  67. const [collapsed, setCollapsed] = (0, _react.useState)('collapsed' in props ? props.collapsed : defaultCollapsed);
  68. const [below, setBelow] = (0, _react.useState)(false);
  69. (0, _react.useEffect)(() => {
  70. if ('collapsed' in props) {
  71. setCollapsed(props.collapsed);
  72. }
  73. }, [props.collapsed]);
  74. const handleSetCollapsed = (value, type) => {
  75. if (!('collapsed' in props)) {
  76. setCollapsed(value);
  77. }
  78. onCollapse === null || onCollapse === void 0 ? void 0 : onCollapse(value, type);
  79. };
  80. // =========================== Prefix ===========================
  81. const {
  82. getPrefixCls,
  83. direction
  84. } = (0, _react.useContext)(_configProvider.ConfigContext);
  85. const prefixCls = getPrefixCls('layout-sider', customizePrefixCls);
  86. const [wrapCSSVar, hashId, cssVarCls] = (0, _sider.default)(prefixCls);
  87. // ========================= Responsive =========================
  88. const responsiveHandlerRef = (0, _react.useRef)(null);
  89. responsiveHandlerRef.current = mql => {
  90. setBelow(mql.matches);
  91. onBreakpoint === null || onBreakpoint === void 0 ? void 0 : onBreakpoint(mql.matches);
  92. if (collapsed !== mql.matches) {
  93. handleSetCollapsed(mql.matches, 'responsive');
  94. }
  95. };
  96. (0, _react.useEffect)(() => {
  97. function responsiveHandler(mql) {
  98. var _a;
  99. return (_a = responsiveHandlerRef.current) === null || _a === void 0 ? void 0 : _a.call(responsiveHandlerRef, mql);
  100. }
  101. let mql;
  102. if (typeof (window === null || window === void 0 ? void 0 : window.matchMedia) !== 'undefined' && breakpoint && breakpoint in dimensionMaxMap) {
  103. mql = window.matchMedia(`screen and (max-width: ${dimensionMaxMap[breakpoint]})`);
  104. (0, _mediaQueryUtil.addMediaQueryListener)(mql, responsiveHandler);
  105. responsiveHandler(mql);
  106. }
  107. return () => {
  108. (0, _mediaQueryUtil.removeMediaQueryListener)(mql, responsiveHandler);
  109. };
  110. }, [breakpoint]); // in order to accept dynamic 'breakpoint' property, we need to add 'breakpoint' into dependency array.
  111. (0, _react.useEffect)(() => {
  112. const uniqueId = generateId('ant-sider-');
  113. siderHook.addSider(uniqueId);
  114. return () => siderHook.removeSider(uniqueId);
  115. }, []);
  116. const toggle = () => {
  117. handleSetCollapsed(!collapsed, 'clickTrigger');
  118. };
  119. const divProps = (0, _omit.default)(otherProps, ['collapsed']);
  120. const rawWidth = collapsed ? collapsedWidth : width;
  121. // use "px" as fallback unit for width
  122. const siderWidth = isNumeric(rawWidth) ? `${rawWidth}px` : String(rawWidth);
  123. // special trigger when collapsedWidth == 0
  124. const zeroWidthTrigger = parseFloat(String(collapsedWidth || 0)) === 0 ? (/*#__PURE__*/React.createElement("span", {
  125. onClick: toggle,
  126. className: (0, _classnames.default)(`${prefixCls}-zero-width-trigger`, `${prefixCls}-zero-width-trigger-${reverseArrow ? 'right' : 'left'}`),
  127. style: zeroWidthTriggerStyle
  128. }, trigger || /*#__PURE__*/React.createElement(_BarsOutlined.default, null))) : null;
  129. const reverseIcon = direction === 'rtl' === !reverseArrow;
  130. const iconObj = {
  131. expanded: reverseIcon ? /*#__PURE__*/React.createElement(_RightOutlined.default, null) : /*#__PURE__*/React.createElement(_LeftOutlined.default, null),
  132. collapsed: reverseIcon ? /*#__PURE__*/React.createElement(_LeftOutlined.default, null) : /*#__PURE__*/React.createElement(_RightOutlined.default, null)
  133. };
  134. const status = collapsed ? 'collapsed' : 'expanded';
  135. const defaultTrigger = iconObj[status];
  136. const triggerDom = trigger !== null ? zeroWidthTrigger || (/*#__PURE__*/React.createElement("div", {
  137. className: `${prefixCls}-trigger`,
  138. onClick: toggle,
  139. style: {
  140. width: siderWidth
  141. }
  142. }, trigger || defaultTrigger)) : null;
  143. const divStyle = Object.assign(Object.assign({}, style), {
  144. flex: `0 0 ${siderWidth}`,
  145. maxWidth: siderWidth,
  146. minWidth: siderWidth,
  147. width: siderWidth
  148. });
  149. const siderCls = (0, _classnames.default)(prefixCls, `${prefixCls}-${theme}`, {
  150. [`${prefixCls}-collapsed`]: !!collapsed,
  151. [`${prefixCls}-has-trigger`]: collapsible && trigger !== null && !zeroWidthTrigger,
  152. [`${prefixCls}-below`]: !!below,
  153. [`${prefixCls}-zero-width`]: parseFloat(siderWidth) === 0
  154. }, className, hashId, cssVarCls);
  155. const contextValue = React.useMemo(() => ({
  156. siderCollapsed: collapsed
  157. }), [collapsed]);
  158. return wrapCSSVar(/*#__PURE__*/React.createElement(SiderContext.Provider, {
  159. value: contextValue
  160. }, /*#__PURE__*/React.createElement("aside", Object.assign({
  161. className: siderCls
  162. }, divProps, {
  163. style: divStyle,
  164. ref: ref
  165. }), /*#__PURE__*/React.createElement("div", {
  166. className: `${prefixCls}-children`
  167. }, children), collapsible || below && zeroWidthTrigger ? triggerDom : null)));
  168. });
  169. if (process.env.NODE_ENV !== 'production') {
  170. Sider.displayName = 'Sider';
  171. }
  172. var _default = exports.default = Sider;