@alicloud/console-base-rc-side-panel 1.1.31 → 1.1.32-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = useEffectCollapsed;
8
+ var _react = require("react");
9
+ var _consoleBaseMessengerSidePanel = require("@alicloud/console-base-messenger-side-panel");
10
+ var _useCollapsed = _interopRequireDefault(require("./use-collapsed"));
11
+ function useEffectCollapsed() {
12
+ var collapsed = (0, _useCollapsed.default)();
13
+ var collapsedRef = (0, _react.useRef)(collapsed);
14
+ var prevCollapsedRef = (0, _react.useRef)(undefined);
15
+ var hasInitializedRef = (0, _react.useRef)(false);
16
+
17
+ // 更新 ref 以保存最新的 collapsed 值
18
+ collapsedRef.current = collapsed;
19
+
20
+ // 首次挂载时,延迟发送初始状态(等待异步获取和动画完成)
21
+ (0, _react.useEffect)(function () {
22
+ var timer = setTimeout(function () {
23
+ if (!hasInitializedRef.current) {
24
+ hasInitializedRef.current = true;
25
+ prevCollapsedRef.current = collapsedRef.current;
26
+ (0, _consoleBaseMessengerSidePanel.sidePanelCollapsed)(collapsedRef.current);
27
+ }
28
+ }, 300);
29
+ return function () {
30
+ return clearTimeout(timer);
31
+ };
32
+ }, []);
33
+
34
+ // 状态变化时,立即发送
35
+ (0, _react.useEffect)(function () {
36
+ if (hasInitializedRef.current && prevCollapsedRef.current !== collapsed) {
37
+ prevCollapsedRef.current = collapsed;
38
+ (0, _consoleBaseMessengerSidePanel.sidePanelCollapsed)(collapsed);
39
+ }
40
+ }, [collapsed]);
41
+ }
@@ -7,7 +7,9 @@ Object.defineProperty(exports, "__esModule", {
7
7
  exports.default = useEffects;
8
8
  var _useEffectToggleBodyClass = _interopRequireDefault(require("./use-effect-toggle-body-class"));
9
9
  var _useEffectQuickTop = _interopRequireDefault(require("./use-effect-quick-top"));
10
+ var _useEffectCollapsed = _interopRequireDefault(require("./use-effect-collapsed"));
10
11
  function useEffects() {
11
12
  (0, _useEffectToggleBodyClass.default)();
12
13
  (0, _useEffectQuickTop.default)();
14
+ (0, _useEffectCollapsed.default)();
13
15
  }
@@ -0,0 +1,34 @@
1
+ import { useEffect, useRef } from 'react';
2
+ import { sidePanelCollapsed } from '@alicloud/console-base-messenger-side-panel';
3
+ import useCollapsed from './use-collapsed';
4
+ export default function useEffectCollapsed() {
5
+ var collapsed = useCollapsed();
6
+ var collapsedRef = useRef(collapsed);
7
+ var prevCollapsedRef = useRef(undefined);
8
+ var hasInitializedRef = useRef(false);
9
+
10
+ // 更新 ref 以保存最新的 collapsed 值
11
+ collapsedRef.current = collapsed;
12
+
13
+ // 首次挂载时,延迟发送初始状态(等待异步获取和动画完成)
14
+ useEffect(function () {
15
+ var timer = setTimeout(function () {
16
+ if (!hasInitializedRef.current) {
17
+ hasInitializedRef.current = true;
18
+ prevCollapsedRef.current = collapsedRef.current;
19
+ sidePanelCollapsed(collapsedRef.current);
20
+ }
21
+ }, 300);
22
+ return function () {
23
+ return clearTimeout(timer);
24
+ };
25
+ }, []);
26
+
27
+ // 状态变化时,立即发送
28
+ useEffect(function () {
29
+ if (hasInitializedRef.current && prevCollapsedRef.current !== collapsed) {
30
+ prevCollapsedRef.current = collapsed;
31
+ sidePanelCollapsed(collapsed);
32
+ }
33
+ }, [collapsed]);
34
+ }
@@ -1,6 +1,8 @@
1
1
  import useEffectToggleBodyClass from './use-effect-toggle-body-class';
2
2
  import useEffectQuickTop from './use-effect-quick-top';
3
+ import useEffectCollapsed from './use-effect-collapsed';
3
4
  export default function useEffects() {
4
5
  useEffectToggleBodyClass();
5
6
  useEffectQuickTop();
7
+ useEffectCollapsed();
6
8
  }
@@ -0,0 +1 @@
1
+ export default function useEffectCollapsed(): void;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alicloud/console-base-rc-side-panel",
3
- "version": "1.1.31",
3
+ "version": "1.1.32-beta.2",
4
4
  "description": "ConsoleBase 组件 - 右侧边栏",
5
5
  "license": "MIT",
6
6
  "sideEffects": false,
@@ -35,6 +35,7 @@
35
35
  },
36
36
  "dependencies": {
37
37
  "@alicloud/console-base-intl-factory-basic": "^1.6.9",
38
+ "@alicloud/console-base-messenger-side-panel": "beta",
38
39
  "@alicloud/console-base-rc-button": "^1.8.4",
39
40
  "@alicloud/console-base-rc-easy-icon": "^1.0.1",
40
41
  "@alicloud/console-base-rc-flex": "^1.4.11",
@@ -50,6 +51,9 @@
50
51
  "immutability-helper": "^3.1.1",
51
52
  "react-draggable": "^4.4.6"
52
53
  },
54
+ "overrides": {
55
+ "@alicloud/console-base-messenger-side-panel": "beta"
56
+ },
53
57
  "scripts": {
54
58
  "start": "breezr start-storybook",
55
59
  "test": "breezr test:unit",