Sider.js 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.siderProps = exports.default = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  10. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  11. var _type = require("../_util/type");
  12. var _initDefaultProps = _interopRequireDefault(require("../_util/props-util/initDefaultProps"));
  13. var _isNumeric = _interopRequireDefault(require("../_util/isNumeric"));
  14. var _BarsOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/BarsOutlined"));
  15. var _RightOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/RightOutlined"));
  16. var _LeftOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/LeftOutlined"));
  17. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  18. var _injectionKey = require("./injectionKey");
  19. const dimensionMaxMap = {
  20. xs: '479.98px',
  21. sm: '575.98px',
  22. md: '767.98px',
  23. lg: '991.98px',
  24. xl: '1199.98px',
  25. xxl: '1599.98px',
  26. xxxl: '1999.98px'
  27. };
  28. const siderProps = () => ({
  29. prefixCls: String,
  30. collapsible: {
  31. type: Boolean,
  32. default: undefined
  33. },
  34. collapsed: {
  35. type: Boolean,
  36. default: undefined
  37. },
  38. defaultCollapsed: {
  39. type: Boolean,
  40. default: undefined
  41. },
  42. reverseArrow: {
  43. type: Boolean,
  44. default: undefined
  45. },
  46. zeroWidthTriggerStyle: {
  47. type: Object,
  48. default: undefined
  49. },
  50. trigger: _vueTypes.default.any,
  51. width: _vueTypes.default.oneOfType([_vueTypes.default.number, _vueTypes.default.string]),
  52. collapsedWidth: _vueTypes.default.oneOfType([_vueTypes.default.number, _vueTypes.default.string]),
  53. breakpoint: _vueTypes.default.oneOf((0, _type.tuple)('xs', 'sm', 'md', 'lg', 'xl', 'xxl', 'xxxl')),
  54. theme: _vueTypes.default.oneOf((0, _type.tuple)('light', 'dark')).def('dark'),
  55. onBreakpoint: Function,
  56. onCollapse: Function
  57. });
  58. exports.siderProps = siderProps;
  59. const generateId = (() => {
  60. let i = 0;
  61. return function () {
  62. let prefix = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
  63. i += 1;
  64. return `${prefix}${i}`;
  65. };
  66. })();
  67. var _default = exports.default = (0, _vue.defineComponent)({
  68. compatConfig: {
  69. MODE: 3
  70. },
  71. name: 'ALayoutSider',
  72. inheritAttrs: false,
  73. props: (0, _initDefaultProps.default)(siderProps(), {
  74. collapsible: false,
  75. defaultCollapsed: false,
  76. reverseArrow: false,
  77. width: 200,
  78. collapsedWidth: 80
  79. }),
  80. emits: ['breakpoint', 'update:collapsed', 'collapse'],
  81. setup(props, _ref) {
  82. let {
  83. emit,
  84. attrs,
  85. slots
  86. } = _ref;
  87. const {
  88. prefixCls
  89. } = (0, _useConfigInject.default)('layout-sider', props);
  90. const siderHook = (0, _vue.inject)(_injectionKey.SiderHookProviderKey, undefined);
  91. const collapsed = (0, _vue.shallowRef)(!!(props.collapsed !== undefined ? props.collapsed : props.defaultCollapsed));
  92. const below = (0, _vue.shallowRef)(false);
  93. (0, _vue.watch)(() => props.collapsed, () => {
  94. collapsed.value = !!props.collapsed;
  95. });
  96. (0, _vue.provide)(_injectionKey.SiderCollapsedKey, collapsed);
  97. const handleSetCollapsed = (value, type) => {
  98. if (props.collapsed === undefined) {
  99. collapsed.value = value;
  100. }
  101. emit('update:collapsed', value);
  102. emit('collapse', value, type);
  103. };
  104. // ========================= Responsive =========================
  105. const responsiveHandlerRef = (0, _vue.shallowRef)(mql => {
  106. below.value = mql.matches;
  107. emit('breakpoint', mql.matches);
  108. if (collapsed.value !== mql.matches) {
  109. handleSetCollapsed(mql.matches, 'responsive');
  110. }
  111. });
  112. let mql;
  113. function responsiveHandler(mql) {
  114. return responsiveHandlerRef.value(mql);
  115. }
  116. const uniqueId = generateId('ant-sider-');
  117. siderHook && siderHook.addSider(uniqueId);
  118. (0, _vue.onMounted)(() => {
  119. (0, _vue.watch)(() => props.breakpoint, () => {
  120. try {
  121. mql === null || mql === void 0 ? void 0 : mql.removeEventListener('change', responsiveHandler);
  122. } catch (error) {
  123. mql === null || mql === void 0 ? void 0 : mql.removeListener(responsiveHandler);
  124. }
  125. if (typeof window !== 'undefined') {
  126. const {
  127. matchMedia
  128. } = window;
  129. if (matchMedia && props.breakpoint && props.breakpoint in dimensionMaxMap) {
  130. mql = matchMedia(`(max-width: ${dimensionMaxMap[props.breakpoint]})`);
  131. try {
  132. mql.addEventListener('change', responsiveHandler);
  133. } catch (error) {
  134. mql.addListener(responsiveHandler);
  135. }
  136. responsiveHandler(mql);
  137. }
  138. }
  139. }, {
  140. immediate: true
  141. });
  142. });
  143. (0, _vue.onBeforeUnmount)(() => {
  144. try {
  145. mql === null || mql === void 0 ? void 0 : mql.removeEventListener('change', responsiveHandler);
  146. } catch (error) {
  147. mql === null || mql === void 0 ? void 0 : mql.removeListener(responsiveHandler);
  148. }
  149. siderHook && siderHook.removeSider(uniqueId);
  150. });
  151. const toggle = () => {
  152. handleSetCollapsed(!collapsed.value, 'clickTrigger');
  153. };
  154. return () => {
  155. var _a, _b;
  156. const pre = prefixCls.value;
  157. const {
  158. collapsedWidth,
  159. width,
  160. reverseArrow,
  161. zeroWidthTriggerStyle,
  162. trigger = (_a = slots.trigger) === null || _a === void 0 ? void 0 : _a.call(slots),
  163. collapsible,
  164. theme
  165. } = props;
  166. const rawWidth = collapsed.value ? collapsedWidth : width;
  167. // use "px" as fallback unit for width
  168. const siderWidth = (0, _isNumeric.default)(rawWidth) ? `${rawWidth}px` : String(rawWidth);
  169. // special trigger when collapsedWidth == 0
  170. const zeroWidthTrigger = parseFloat(String(collapsedWidth || 0)) === 0 ? (0, _vue.createVNode)("span", {
  171. "onClick": toggle,
  172. "class": (0, _classNames.default)(`${pre}-zero-width-trigger`, `${pre}-zero-width-trigger-${reverseArrow ? 'right' : 'left'}`),
  173. "style": zeroWidthTriggerStyle
  174. }, [trigger || (0, _vue.createVNode)(_BarsOutlined.default, null, null)]) : null;
  175. const iconObj = {
  176. expanded: reverseArrow ? (0, _vue.createVNode)(_RightOutlined.default, null, null) : (0, _vue.createVNode)(_LeftOutlined.default, null, null),
  177. collapsed: reverseArrow ? (0, _vue.createVNode)(_LeftOutlined.default, null, null) : (0, _vue.createVNode)(_RightOutlined.default, null, null)
  178. };
  179. const status = collapsed.value ? 'collapsed' : 'expanded';
  180. const defaultTrigger = iconObj[status];
  181. const triggerDom = trigger !== null ? zeroWidthTrigger || (0, _vue.createVNode)("div", {
  182. "class": `${pre}-trigger`,
  183. "onClick": toggle,
  184. "style": {
  185. width: siderWidth
  186. }
  187. }, [trigger || defaultTrigger]) : null;
  188. const divStyle = [attrs.style, {
  189. flex: `0 0 ${siderWidth}`,
  190. maxWidth: siderWidth,
  191. minWidth: siderWidth,
  192. width: siderWidth
  193. }];
  194. const siderCls = (0, _classNames.default)(pre, `${pre}-${theme}`, {
  195. [`${pre}-collapsed`]: !!collapsed.value,
  196. [`${pre}-has-trigger`]: collapsible && trigger !== null && !zeroWidthTrigger,
  197. [`${pre}-below`]: !!below.value,
  198. [`${pre}-zero-width`]: parseFloat(siderWidth) === 0
  199. }, attrs.class);
  200. return (0, _vue.createVNode)("aside", (0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), {}, {
  201. "class": siderCls,
  202. "style": divStyle
  203. }), [(0, _vue.createVNode)("div", {
  204. "class": `${pre}-children`
  205. }, [(_b = slots.default) === null || _b === void 0 ? void 0 : _b.call(slots)]), collapsible || below.value && zeroWidthTrigger ? triggerDom : null]);
  206. };
  207. }
  208. });