@xhsreds/reds-rn-next 0.9.0 → 0.9.1-feat-image-2202510231126

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.
Files changed (40) hide show
  1. package/coverage/.tmp/coverage-0.json +1 -1
  2. package/coverage/.tmp/coverage-1.json +1 -1
  3. package/coverage/.tmp/coverage-10.json +1 -1
  4. package/coverage/.tmp/coverage-11.json +1 -1
  5. package/coverage/.tmp/coverage-12.json +1 -1
  6. package/coverage/.tmp/coverage-13.json +1 -1
  7. package/coverage/.tmp/coverage-14.json +1 -1
  8. package/coverage/.tmp/coverage-15.json +1 -1
  9. package/coverage/.tmp/coverage-16.json +1 -1
  10. package/coverage/.tmp/coverage-17.json +1 -1
  11. package/coverage/.tmp/coverage-2.json +1 -1
  12. package/coverage/.tmp/coverage-21.json +1 -1
  13. package/coverage/.tmp/coverage-22.json +1 -1
  14. package/coverage/.tmp/coverage-23.json +1 -1
  15. package/coverage/.tmp/coverage-24.json +1 -1
  16. package/coverage/.tmp/coverage-25.json +1 -1
  17. package/coverage/.tmp/coverage-26.json +1 -1
  18. package/coverage/.tmp/coverage-27.json +1 -1
  19. package/coverage/.tmp/coverage-29.json +1 -1
  20. package/coverage/.tmp/coverage-3.json +1 -1
  21. package/coverage/.tmp/coverage-30.json +1 -1
  22. package/coverage/.tmp/coverage-34.json +1 -1
  23. package/coverage/.tmp/coverage-35.json +1 -1
  24. package/coverage/.tmp/coverage-36.json +1 -1
  25. package/coverage/.tmp/coverage-38.json +1 -1
  26. package/coverage/.tmp/coverage-39.json +1 -1
  27. package/coverage/.tmp/coverage-4.json +1 -1
  28. package/coverage/.tmp/coverage-40.json +1 -1
  29. package/coverage/.tmp/coverage-41.json +1 -1
  30. package/coverage/.tmp/coverage-5.json +1 -1
  31. package/coverage/.tmp/coverage-6.json +1 -1
  32. package/coverage/.tmp/coverage-7.json +1 -1
  33. package/coverage/.tmp/coverage-8.json +1 -1
  34. package/coverage/.tmp/coverage-9.json +1 -1
  35. package/lib/cjs/components/Image/VisibilitySensor.js +18 -76
  36. package/lib/cjs/components/Image/VisibilitySensor.js.map +1 -1
  37. package/lib/esm/components/Image/VisibilitySensor.js +20 -78
  38. package/lib/esm/components/Image/VisibilitySensor.js.map +1 -1
  39. package/package.json +1 -1
  40. package/src/components/Image/VisibilitySensor.tsx +30 -84
@@ -6,20 +6,17 @@ var _rollupPluginBabelHelpers = require('../../_chunks/C9tZEm0t.js');
6
6
  var React = require('react');
7
7
  var reactNative = require('react-native');
8
8
 
9
- var _excluded = ["onChange", "disabled", "triggerOnce", "delay", "threshold", "children"];
9
+ var _excluded = ["onChange", "disabled", "threshold", "children"];
10
10
  var VisibilitySensor = /*#__PURE__*/React.forwardRef(function (props, ref) {
11
11
  var onChange = props.onChange,
12
12
  _props$disabled = props.disabled,
13
13
  disabled = _props$disabled === void 0 ? false : _props$disabled,
14
- _props$triggerOnce = props.triggerOnce,
15
- triggerOnce = _props$triggerOnce === void 0 ? false : _props$triggerOnce;
16
- props.delay;
17
- var _props$threshold = props.threshold,
14
+ _props$threshold = props.threshold,
18
15
  threshold = _props$threshold === void 0 ? {} : _props$threshold,
19
16
  children = props.children,
20
17
  rest = _rollupPluginBabelHelpers._objectWithoutProperties(props, _excluded);
21
18
  var localRef = React.useRef(null);
22
- var hasMountedRef = React.useRef(false);
19
+ var measuredOnceRef = React.useRef(false);
23
20
  React.useImperativeHandle(ref, function () {
24
21
  return {
25
22
  getInnerRef: function getInnerRef() {
@@ -27,83 +24,28 @@ var VisibilitySensor = /*#__PURE__*/React.forwardRef(function (props, ref) {
27
24
  }
28
25
  };
29
26
  });
30
- var _useState = React.useState({
31
- rectTop: 0,
32
- rectBottom: 0,
33
- rectLeft: 0,
34
- rectRight: 0,
35
- rectWidth: 0,
36
- rectHeight: 0
37
- }),
38
- _useState2 = _rollupPluginBabelHelpers._slicedToArray(_useState, 2),
39
- rectDimensions = _useState2[0],
40
- setRectDimensions = _useState2[1];
41
- var _useState3 = React.useState(void 0),
42
- _useState4 = _rollupPluginBabelHelpers._slicedToArray(_useState3, 2),
43
- lastValue = _useState4[0],
44
- setLastValue = _useState4[1];
45
- var _useState5 = React.useState(false),
46
- _useState6 = _rollupPluginBabelHelpers._slicedToArray(_useState5, 2),
47
- active = _useState6[0],
48
- setActive = _useState6[1];
49
- var measureInnerView = function measureInnerView() {
27
+ var measureOnce = React.useCallback(function () {
50
28
  var _localRef$current;
51
- if (!active) return;
52
- (_localRef$current = localRef.current) === null || _localRef$current === void 0 || _localRef$current.measure(function (_x, _y, width, height, pageX, pageY) {
53
- var dimensions = {
54
- rectTop: pageY,
55
- rectBottom: pageY + height,
56
- rectLeft: pageX,
57
- rectRight: pageX + width,
58
- rectWidth: width,
59
- rectHeight: height
60
- };
61
- if (rectDimensions.rectTop !== dimensions.rectTop || rectDimensions.rectBottom !== dimensions.rectBottom || rectDimensions.rectLeft !== dimensions.rectLeft || rectDimensions.rectRight !== dimensions.rectRight || rectDimensions.rectWidth !== dimensions.rectWidth || rectDimensions.rectHeight !== dimensions.rectHeight) {
62
- setRectDimensions(dimensions);
63
- }
29
+ if (disabled || measuredOnceRef.current) return;
30
+ var win = reactNative.Dimensions.get("window");
31
+ (_localRef$current = localRef.current) === null || _localRef$current === void 0 || _localRef$current.measure(function (_, __, width, height, pageX, pageY) {
32
+ if (measuredOnceRef.current) return;
33
+ var isVisible = pageY + (threshold.top || 0) <= win.height && pageY + height - (threshold.bottom || 0) >= 0 && pageX + (threshold.left || 0) <= win.width && pageX + width - (threshold.right || 0) >= 0;
34
+ measuredOnceRef.current = true;
35
+ onChange(isVisible);
64
36
  });
65
- };
66
- var startWatching = React.useCallback(function () {
67
- if (!active) setActive(true);
68
- }, [active]);
69
- var stopWatching = React.useCallback(function () {
70
- if (active) setActive(false);
71
- }, [active]);
72
- React.useEffect(function () {
73
- if (!disabled) {
74
- startWatching();
75
- }
76
- return function () {
77
- stopWatching();
78
- };
79
- }, [disabled, startWatching, stopWatching]);
37
+ }, [disabled, onChange, threshold]);
80
38
  React.useEffect(function () {
81
- if (!hasMountedRef.current) {
82
- hasMountedRef.current = true;
83
- return;
39
+ if (!disabled && !measuredOnceRef.current) {
40
+ requestAnimationFrame(function () {
41
+ return measureOnce();
42
+ });
84
43
  }
85
- var window = reactNative.Dimensions.get("window");
86
- var isVisible = rectDimensions.rectTop + (threshold.top || 0) <= window.height &&
87
- // Top edge is within the bottom of the window
88
- rectDimensions.rectBottom - (threshold.bottom || 0) >= 0 &&
89
- // Bottom edge is within the top of the window
90
- rectDimensions.rectLeft + (threshold.left || 0) <= window.width &&
91
- // Left edge is within the right of the window
92
- rectDimensions.rectRight - (threshold.right || 0) >= 0;
93
- if (lastValue !== isVisible) {
94
- setLastValue(isVisible);
95
- onChange(isVisible);
96
- if (isVisible && triggerOnce) {
97
- stopWatching();
98
- }
99
- }
100
- }, [rectDimensions, lastValue]);
44
+ }, [disabled, measureOnce]);
101
45
  return /* @__PURE__ */React.createElement(reactNative.View, _rollupPluginBabelHelpers._objectSpread2(_rollupPluginBabelHelpers._objectSpread2({
102
46
  ref: localRef
103
47
  }, rest), {}, {
104
- onLayout: function onLayout() {
105
- return measureInnerView();
106
- }
48
+ onLayout: measureOnce
107
49
  }), children);
108
50
  });
109
51
 
@@ -1 +1 @@
1
- {"version":3,"file":"VisibilitySensor.js","sources":["../../../../src/components/Image/VisibilitySensor.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState, forwardRef, useImperativeHandle } from \"react\";\nimport { Dimensions, type ScaledSize, View } from \"react-native\";\nimport type { VisibilitySensorRef, VisibilitySensorProps, RectDimensionsState } from \"./interface/visibilitySensor\";\n// function useInterval(callback: () => void, delay: number | null) {\n// const savedCallback = useRef(callback);\n// useEffect(() => {\n// savedCallback.current = callback;\n// }, [callback]);\n// useEffect(() => {\n// if (delay === null || delay === undefined) {\n// return;\n// }\n// const id = setInterval(() => savedCallback.current(), delay);\n// return () => clearInterval(id);\n// }, [delay]);\n// }\nconst VisibilitySensor = forwardRef<VisibilitySensorRef, VisibilitySensorProps>((props, ref) => {\n const { onChange, disabled = false, triggerOnce = false, delay, threshold = {}, children, ...rest } = props;\n const localRef = useRef<View>(null);\n const hasMountedRef = useRef(false);\n useImperativeHandle(ref, () => ({\n getInnerRef: () => localRef.current,\n }));\n const [rectDimensions, setRectDimensions] = useState<RectDimensionsState>({\n rectTop: 0,\n rectBottom: 0,\n rectLeft: 0,\n rectRight: 0,\n rectWidth: 0,\n rectHeight: 0,\n });\n const [lastValue, setLastValue] = useState<boolean | undefined>(undefined);\n const [active, setActive] = useState<boolean>(false);\n const measureInnerView = () => {\n if (!active) return;\n localRef.current?.measure((_x: number, _y: number, width: number, height: number, pageX: number, pageY: number) => {\n const dimensions = {\n rectTop: pageY,\n rectBottom: pageY + height,\n rectLeft: pageX,\n rectRight: pageX + width,\n rectWidth: width,\n rectHeight: height,\n };\n if (\n rectDimensions.rectTop !== dimensions.rectTop ||\n rectDimensions.rectBottom !== dimensions.rectBottom ||\n rectDimensions.rectLeft !== dimensions.rectLeft ||\n rectDimensions.rectRight !== dimensions.rectRight ||\n rectDimensions.rectWidth !== dimensions.rectWidth ||\n rectDimensions.rectHeight !== dimensions.rectHeight\n ) {\n setRectDimensions(dimensions);\n }\n });\n };\n // useInterval(measureInnerView, delay || 100);\n const startWatching = useCallback(() => {\n if (!active) setActive(true);\n }, [active]);\n const stopWatching = useCallback(() => {\n if (active) setActive(false);\n }, [active]);\n useEffect(() => {\n if (!disabled) {\n startWatching();\n }\n return () => {\n stopWatching();\n };\n }, [disabled, startWatching, stopWatching]);\n useEffect(() => {\n if (!hasMountedRef.current) {\n hasMountedRef.current = true;\n return;\n }\n const window: ScaledSize = Dimensions.get(\"window\");\n const isVisible: boolean =\n rectDimensions.rectTop + (threshold.top || 0) <= window.height && // Top edge is within the bottom of the window\n rectDimensions.rectBottom - (threshold.bottom || 0) >= 0 && // Bottom edge is within the top of the window\n rectDimensions.rectLeft + (threshold.left || 0) <= window.width && // Left edge is within the right of the window\n rectDimensions.rectRight - (threshold.right || 0) >= 0; // Right edge is within the left of the window\n if (lastValue !== isVisible) {\n setLastValue(isVisible);\n onChange(isVisible);\n if (isVisible && triggerOnce) {\n stopWatching();\n }\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [rectDimensions, lastValue]);\n return (\n <View ref={localRef} {...rest} onLayout={() => measureInnerView()}>\n {children}\n </View>\n );\n});\nexport default VisibilitySensor;\n"],"names":["VisibilitySensor","forwardRef","props","ref","onChange","_props$disabled","disabled","_props$triggerOnce","triggerOnce","delay","_props$threshold","threshold","children","rest","_excluded","localRef","useRef","hasMountedRef","useImperativeHandle","getInnerRef","current","_useState","useState","rectTop","rectBottom","rectLeft","rectRight","rectWidth","rectHeight","_useState2","_slicedToArray","rectDimensions","setRectDimensions","_useState3","_useState4","lastValue","setLastValue","_useState5","_useState6","active","setActive","measureInnerView","_localRef$current","measure","_x","_y","width","height","pageX","pageY","dimensions","startWatching","useCallback","stopWatching","useEffect","window","Dimensions","get","isVisible","top","bottom","left","right","React","createElement","View","_objectSpread","onLayout"],"mappings":"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"}
1
+ {"version":3,"file":"VisibilitySensor.js","sources":["../../../../src/components/Image/VisibilitySensor.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, forwardRef, useImperativeHandle } from \"react\";\nimport { Dimensions, View } from \"react-native\";\nimport type { VisibilitySensorRef, VisibilitySensorProps } from \"./interface/visibilitySensor\";\n\n// Measure visibility once on first layout to avoid state-driven re-render loops\nconst VisibilitySensor = forwardRef<VisibilitySensorRef, VisibilitySensorProps>((props, ref) => {\n const { onChange, disabled = false, threshold = {}, children, ...rest } = props;\n const localRef = useRef<View>(null);\n const measuredOnceRef = useRef(false);\n\n useImperativeHandle(ref, () => ({\n getInnerRef: () => localRef.current,\n }));\n\n const measureOnce = useCallback(() => {\n if (disabled || measuredOnceRef.current) return;\n const win = Dimensions.get(\"window\");\n localRef.current?.measure((_, __, width: number, height: number, pageX: number, pageY: number) => {\n if (measuredOnceRef.current) return; // guard against double-calls in same frame\n const isVisible =\n pageY + (threshold.top || 0) <= win.height &&\n pageY + height - (threshold.bottom || 0) >= 0 &&\n pageX + (threshold.left || 0) <= win.width &&\n pageX + width - (threshold.right || 0) >= 0;\n measuredOnceRef.current = true;\n onChange(isVisible);\n });\n }, [disabled, onChange, threshold]);\n\n // If initially disabled, measure once when enabled later\n useEffect(() => {\n if (!disabled && !measuredOnceRef.current) {\n requestAnimationFrame(() => measureOnce());\n }\n }, [disabled, measureOnce]);\n\n return (\n <View ref={localRef} {...rest} onLayout={measureOnce}>\n {children}\n </View>\n );\n});\n\nexport default VisibilitySensor;\n"],"names":["VisibilitySensor","forwardRef","props","ref","onChange","_props$disabled","disabled","_props$threshold","threshold","children","rest","_objectWithoutProperties","_excluded","localRef","useRef","measuredOnceRef","useImperativeHandle","getInnerRef","current","measureOnce","useCallback","_localRef$current","win","Dimensions","get","measure","_","__","width","height","pageX","pageY","isVisible","top","bottom","left","right","useEffect","requestAnimationFrame","React","createElement","View","onLayout"],"mappings":";;;;;;;;;AAKMA,IAAAA,gBAAmB,gBAAAC,gBAAA,CAAuD,UAACC,KAAA,EAAOC,GAAQ,EAAA;AACxF,EAAA,IAAEC,QAAU,GAAwDF,KAAA,CAAlEE,QAAU;IAAAC,eAAA,GAAwDH,KAAA,CAAxDI,QAAA;AAAAA,IAAAA,QAAA,GAAAD,eAAA,KAAW,KAAA,CAAA,GAAA,KAAO,GAAAA,eAAA;IAAAE,gBAAA,GAAsCL,KAAA,CAAtCM,SAAA;AAAAA,IAAAA,SAAA,GAAAD,gBAAA,KAAA,KAAA,CAAA,GAAY,EAAI,GAAAA,gBAAA;IAAAE,QAAA,GAAsBP,KAAA,CAAtBO,QAAA;AAAaC,IAAAA,IAAA,GAAAC,kDAAA,CAAST,KAAA,EAAAU,SAAA,CAAA,CAAA;AACpE,EAAA,IAAAC,QAAA,GAAWC,aAAa,IAAI,CAAA,CAAA;AAC5B,EAAA,IAAAC,eAAA,GAAkBD,aAAO,KAAK,CAAA,CAAA;EAEpCE,yBAAA,CAAoBb,KAAK,YAAA;IAAA,OAAO;MAC9Bc,WAAA,EAAa,SAAbA,WAAAA,GAAA;QAAA,OAAmBJ,QAAS,CAAAK,OAAA,CAAA;AAAA,OAAA;KAC5B,CAAA;AAAA,GAAA,CAAA,CAAA;AAEI,EAAA,IAAAC,WAAA,GAAcC,kBAAY,YAAM;AAAA,IAAA,IAAAC,iBAAA,CAAA;AAChC,IAAA,IAAAf,QAAA,IAAYS,gBAAgBG,OAAS,EAAA,OAAA;AACnC,IAAA,IAAAI,GAAA,GAAMC,sBAAW,CAAAC,GAAA,CAAI,QAAQ,CAAA,CAAA;IAC1B,CAAAH,iBAAA,GAAAR,QAAA,CAAAK,OAAA,cAAAG,iBAAA,KAAA,KAAA,CAAA,IAAAA,iBAAA,CAASI,QAAQ,UAACC,CAAA,EAAGC,IAAIC,KAAe,EAAAC,MAAA,EAAgBC,OAAeC,KAAkB,EAAA;MAChG,IAAIhB,gBAAgBG,OAAS,EAAA,OAAA;MACvB,IAAAc,SAAA,GACJD,SAASvB,SAAU,CAAAyB,GAAA,IAAO,MAAMX,GAAI,CAAAO,MAAA,IACpCE,KAAQ,GAAAF,MAAA,IAAUrB,SAAU,CAAA0B,MAAA,IAAU,MAAM,CAC5C,IAAAJ,KAAA,IAAStB,SAAU,CAAA2B,IAAA,IAAQ,CAAM,CAAA,IAAAb,GAAA,CAAIM,SACrCE,KAAQ,GAAAF,KAAA,IAASpB,SAAU,CAAA4B,KAAA,IAAS,CAAM,CAAA,IAAA,CAAA,CAAA;MAC5CrB,eAAA,CAAgBG,OAAU,GAAA,IAAA,CAAA;MAC1Bd,QAAA,CAAS4B,SAAS,CAAA,CAAA;AACpB,KAAC,CAAA,CAAA;GACA,EAAA,CAAC1B,QAAU,EAAAF,QAAA,EAAUI,SAAS,CAAC,CAAA,CAAA;AAGlC6B,EAAAA,eAAA,CAAU,YAAM;AACd,IAAA,IAAI,CAAC/B,QAAA,IAAY,CAACS,eAAA,CAAgBG,OAAS,EAAA;AACnBoB,MAAAA,qBAAA,CAAA,YAAA;QAAA,OAAMnB,aAAa,CAAA;OAAA,CAAA,CAAA;AAC3C,KAAA;AACF,GAAG,EAAA,CAACb,QAAU,EAAAa,WAAW,CAAC,CAAA,CAAA;EAGxB,sBAAAoB,KAAA,CAAAC,aAAA,CAACC;AAAKtC,IAAAA,GAAK,EAAAU,QAAAA;AAAA,GAAA,EAAcH,IAAM,CAAA,EAAA,EAAA,EAAA;AAAAgC,IAAAA,QAAA,EAAUvB,WAAAA;MACtCV,QACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -1,21 +1,18 @@
1
- import { i as _objectWithoutProperties, _ as _slicedToArray, a as _objectSpread2 } from '../../_chunks/CAkwE9ZD.js';
2
- import React, { forwardRef, useRef, useImperativeHandle, useState, useCallback, useEffect } from 'react';
1
+ import { i as _objectWithoutProperties, a as _objectSpread2 } from '../../_chunks/CAkwE9ZD.js';
2
+ import React, { forwardRef, useRef, useImperativeHandle, useCallback, useEffect } from 'react';
3
3
  import { Dimensions, View } from 'react-native';
4
4
 
5
- var _excluded = ["onChange", "disabled", "triggerOnce", "delay", "threshold", "children"];
5
+ var _excluded = ["onChange", "disabled", "threshold", "children"];
6
6
  var VisibilitySensor = /*#__PURE__*/forwardRef(function (props, ref) {
7
7
  var onChange = props.onChange,
8
8
  _props$disabled = props.disabled,
9
9
  disabled = _props$disabled === void 0 ? false : _props$disabled,
10
- _props$triggerOnce = props.triggerOnce,
11
- triggerOnce = _props$triggerOnce === void 0 ? false : _props$triggerOnce;
12
- props.delay;
13
- var _props$threshold = props.threshold,
10
+ _props$threshold = props.threshold,
14
11
  threshold = _props$threshold === void 0 ? {} : _props$threshold,
15
12
  children = props.children,
16
13
  rest = _objectWithoutProperties(props, _excluded);
17
14
  var localRef = useRef(null);
18
- var hasMountedRef = useRef(false);
15
+ var measuredOnceRef = useRef(false);
19
16
  useImperativeHandle(ref, function () {
20
17
  return {
21
18
  getInnerRef: function getInnerRef() {
@@ -23,83 +20,28 @@ var VisibilitySensor = /*#__PURE__*/forwardRef(function (props, ref) {
23
20
  }
24
21
  };
25
22
  });
26
- var _useState = useState({
27
- rectTop: 0,
28
- rectBottom: 0,
29
- rectLeft: 0,
30
- rectRight: 0,
31
- rectWidth: 0,
32
- rectHeight: 0
33
- }),
34
- _useState2 = _slicedToArray(_useState, 2),
35
- rectDimensions = _useState2[0],
36
- setRectDimensions = _useState2[1];
37
- var _useState3 = useState(void 0),
38
- _useState4 = _slicedToArray(_useState3, 2),
39
- lastValue = _useState4[0],
40
- setLastValue = _useState4[1];
41
- var _useState5 = useState(false),
42
- _useState6 = _slicedToArray(_useState5, 2),
43
- active = _useState6[0],
44
- setActive = _useState6[1];
45
- var measureInnerView = function measureInnerView() {
23
+ var measureOnce = useCallback(function () {
46
24
  var _localRef$current;
47
- if (!active) return;
48
- (_localRef$current = localRef.current) === null || _localRef$current === void 0 || _localRef$current.measure(function (_x, _y, width, height, pageX, pageY) {
49
- var dimensions = {
50
- rectTop: pageY,
51
- rectBottom: pageY + height,
52
- rectLeft: pageX,
53
- rectRight: pageX + width,
54
- rectWidth: width,
55
- rectHeight: height
56
- };
57
- if (rectDimensions.rectTop !== dimensions.rectTop || rectDimensions.rectBottom !== dimensions.rectBottom || rectDimensions.rectLeft !== dimensions.rectLeft || rectDimensions.rectRight !== dimensions.rectRight || rectDimensions.rectWidth !== dimensions.rectWidth || rectDimensions.rectHeight !== dimensions.rectHeight) {
58
- setRectDimensions(dimensions);
59
- }
25
+ if (disabled || measuredOnceRef.current) return;
26
+ var win = Dimensions.get("window");
27
+ (_localRef$current = localRef.current) === null || _localRef$current === void 0 || _localRef$current.measure(function (_, __, width, height, pageX, pageY) {
28
+ if (measuredOnceRef.current) return;
29
+ var isVisible = pageY + (threshold.top || 0) <= win.height && pageY + height - (threshold.bottom || 0) >= 0 && pageX + (threshold.left || 0) <= win.width && pageX + width - (threshold.right || 0) >= 0;
30
+ measuredOnceRef.current = true;
31
+ onChange(isVisible);
60
32
  });
61
- };
62
- var startWatching = useCallback(function () {
63
- if (!active) setActive(true);
64
- }, [active]);
65
- var stopWatching = useCallback(function () {
66
- if (active) setActive(false);
67
- }, [active]);
68
- useEffect(function () {
69
- if (!disabled) {
70
- startWatching();
71
- }
72
- return function () {
73
- stopWatching();
74
- };
75
- }, [disabled, startWatching, stopWatching]);
33
+ }, [disabled, onChange, threshold]);
76
34
  useEffect(function () {
77
- if (!hasMountedRef.current) {
78
- hasMountedRef.current = true;
79
- return;
35
+ if (!disabled && !measuredOnceRef.current) {
36
+ requestAnimationFrame(function () {
37
+ return measureOnce();
38
+ });
80
39
  }
81
- var window = Dimensions.get("window");
82
- var isVisible = rectDimensions.rectTop + (threshold.top || 0) <= window.height &&
83
- // Top edge is within the bottom of the window
84
- rectDimensions.rectBottom - (threshold.bottom || 0) >= 0 &&
85
- // Bottom edge is within the top of the window
86
- rectDimensions.rectLeft + (threshold.left || 0) <= window.width &&
87
- // Left edge is within the right of the window
88
- rectDimensions.rectRight - (threshold.right || 0) >= 0;
89
- if (lastValue !== isVisible) {
90
- setLastValue(isVisible);
91
- onChange(isVisible);
92
- if (isVisible && triggerOnce) {
93
- stopWatching();
94
- }
95
- }
96
- }, [rectDimensions, lastValue]);
40
+ }, [disabled, measureOnce]);
97
41
  return /* @__PURE__ */React.createElement(View, _objectSpread2(_objectSpread2({
98
42
  ref: localRef
99
43
  }, rest), {}, {
100
- onLayout: function onLayout() {
101
- return measureInnerView();
102
- }
44
+ onLayout: measureOnce
103
45
  }), children);
104
46
  });
105
47
 
@@ -1 +1 @@
1
- {"version":3,"file":"VisibilitySensor.js","sources":["../../../../src/components/Image/VisibilitySensor.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState, forwardRef, useImperativeHandle } from \"react\";\nimport { Dimensions, type ScaledSize, View } from \"react-native\";\nimport type { VisibilitySensorRef, VisibilitySensorProps, RectDimensionsState } from \"./interface/visibilitySensor\";\n// function useInterval(callback: () => void, delay: number | null) {\n// const savedCallback = useRef(callback);\n// useEffect(() => {\n// savedCallback.current = callback;\n// }, [callback]);\n// useEffect(() => {\n// if (delay === null || delay === undefined) {\n// return;\n// }\n// const id = setInterval(() => savedCallback.current(), delay);\n// return () => clearInterval(id);\n// }, [delay]);\n// }\nconst VisibilitySensor = forwardRef<VisibilitySensorRef, VisibilitySensorProps>((props, ref) => {\n const { onChange, disabled = false, triggerOnce = false, delay, threshold = {}, children, ...rest } = props;\n const localRef = useRef<View>(null);\n const hasMountedRef = useRef(false);\n useImperativeHandle(ref, () => ({\n getInnerRef: () => localRef.current,\n }));\n const [rectDimensions, setRectDimensions] = useState<RectDimensionsState>({\n rectTop: 0,\n rectBottom: 0,\n rectLeft: 0,\n rectRight: 0,\n rectWidth: 0,\n rectHeight: 0,\n });\n const [lastValue, setLastValue] = useState<boolean | undefined>(undefined);\n const [active, setActive] = useState<boolean>(false);\n const measureInnerView = () => {\n if (!active) return;\n localRef.current?.measure((_x: number, _y: number, width: number, height: number, pageX: number, pageY: number) => {\n const dimensions = {\n rectTop: pageY,\n rectBottom: pageY + height,\n rectLeft: pageX,\n rectRight: pageX + width,\n rectWidth: width,\n rectHeight: height,\n };\n if (\n rectDimensions.rectTop !== dimensions.rectTop ||\n rectDimensions.rectBottom !== dimensions.rectBottom ||\n rectDimensions.rectLeft !== dimensions.rectLeft ||\n rectDimensions.rectRight !== dimensions.rectRight ||\n rectDimensions.rectWidth !== dimensions.rectWidth ||\n rectDimensions.rectHeight !== dimensions.rectHeight\n ) {\n setRectDimensions(dimensions);\n }\n });\n };\n // useInterval(measureInnerView, delay || 100);\n const startWatching = useCallback(() => {\n if (!active) setActive(true);\n }, [active]);\n const stopWatching = useCallback(() => {\n if (active) setActive(false);\n }, [active]);\n useEffect(() => {\n if (!disabled) {\n startWatching();\n }\n return () => {\n stopWatching();\n };\n }, [disabled, startWatching, stopWatching]);\n useEffect(() => {\n if (!hasMountedRef.current) {\n hasMountedRef.current = true;\n return;\n }\n const window: ScaledSize = Dimensions.get(\"window\");\n const isVisible: boolean =\n rectDimensions.rectTop + (threshold.top || 0) <= window.height && // Top edge is within the bottom of the window\n rectDimensions.rectBottom - (threshold.bottom || 0) >= 0 && // Bottom edge is within the top of the window\n rectDimensions.rectLeft + (threshold.left || 0) <= window.width && // Left edge is within the right of the window\n rectDimensions.rectRight - (threshold.right || 0) >= 0; // Right edge is within the left of the window\n if (lastValue !== isVisible) {\n setLastValue(isVisible);\n onChange(isVisible);\n if (isVisible && triggerOnce) {\n stopWatching();\n }\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [rectDimensions, lastValue]);\n return (\n <View ref={localRef} {...rest} onLayout={() => measureInnerView()}>\n {children}\n </View>\n );\n});\nexport default VisibilitySensor;\n"],"names":["VisibilitySensor","forwardRef","props","ref","onChange","_props$disabled","disabled","_props$triggerOnce","triggerOnce","delay","_props$threshold","threshold","children","rest","_excluded","localRef","useRef","hasMountedRef","useImperativeHandle","getInnerRef","current","_useState","useState","rectTop","rectBottom","rectLeft","rectRight","rectWidth","rectHeight","_useState2","_slicedToArray","rectDimensions","setRectDimensions","_useState3","_useState4","lastValue","setLastValue","_useState5","_useState6","active","setActive","measureInnerView","_localRef$current","measure","_x","_y","width","height","pageX","pageY","dimensions","startWatching","useCallback","stopWatching","useEffect","window","Dimensions","get","isVisible","top","bottom","left","right","React","createElement","View","_objectSpread","onLayout"],"mappings":"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"}
1
+ {"version":3,"file":"VisibilitySensor.js","sources":["../../../../src/components/Image/VisibilitySensor.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, forwardRef, useImperativeHandle } from \"react\";\nimport { Dimensions, View } from \"react-native\";\nimport type { VisibilitySensorRef, VisibilitySensorProps } from \"./interface/visibilitySensor\";\n\n// Measure visibility once on first layout to avoid state-driven re-render loops\nconst VisibilitySensor = forwardRef<VisibilitySensorRef, VisibilitySensorProps>((props, ref) => {\n const { onChange, disabled = false, threshold = {}, children, ...rest } = props;\n const localRef = useRef<View>(null);\n const measuredOnceRef = useRef(false);\n\n useImperativeHandle(ref, () => ({\n getInnerRef: () => localRef.current,\n }));\n\n const measureOnce = useCallback(() => {\n if (disabled || measuredOnceRef.current) return;\n const win = Dimensions.get(\"window\");\n localRef.current?.measure((_, __, width: number, height: number, pageX: number, pageY: number) => {\n if (measuredOnceRef.current) return; // guard against double-calls in same frame\n const isVisible =\n pageY + (threshold.top || 0) <= win.height &&\n pageY + height - (threshold.bottom || 0) >= 0 &&\n pageX + (threshold.left || 0) <= win.width &&\n pageX + width - (threshold.right || 0) >= 0;\n measuredOnceRef.current = true;\n onChange(isVisible);\n });\n }, [disabled, onChange, threshold]);\n\n // If initially disabled, measure once when enabled later\n useEffect(() => {\n if (!disabled && !measuredOnceRef.current) {\n requestAnimationFrame(() => measureOnce());\n }\n }, [disabled, measureOnce]);\n\n return (\n <View ref={localRef} {...rest} onLayout={measureOnce}>\n {children}\n </View>\n );\n});\n\nexport default VisibilitySensor;\n"],"names":["VisibilitySensor","forwardRef","props","ref","onChange","_props$disabled","disabled","_props$threshold","threshold","children","rest","_objectWithoutProperties","_excluded","localRef","useRef","measuredOnceRef","useImperativeHandle","getInnerRef","current","measureOnce","useCallback","_localRef$current","win","Dimensions","get","measure","_","__","width","height","pageX","pageY","isVisible","top","bottom","left","right","useEffect","requestAnimationFrame","React","createElement","View","onLayout"],"mappings":";;;;;AAKMA,IAAAA,gBAAmB,gBAAAC,UAAA,CAAuD,UAACC,KAAA,EAAOC,GAAQ,EAAA;AACxF,EAAA,IAAEC,QAAU,GAAwDF,KAAA,CAAlEE,QAAU;IAAAC,eAAA,GAAwDH,KAAA,CAAxDI,QAAA;AAAAA,IAAAA,QAAA,GAAAD,eAAA,KAAW,KAAA,CAAA,GAAA,KAAO,GAAAA,eAAA;IAAAE,gBAAA,GAAsCL,KAAA,CAAtCM,SAAA;AAAAA,IAAAA,SAAA,GAAAD,gBAAA,KAAA,KAAA,CAAA,GAAY,EAAI,GAAAA,gBAAA;IAAAE,QAAA,GAAsBP,KAAA,CAAtBO,QAAA;AAAaC,IAAAA,IAAA,GAAAC,wBAAA,CAAST,KAAA,EAAAU,SAAA,CAAA,CAAA;AACpE,EAAA,IAAAC,QAAA,GAAWC,OAAa,IAAI,CAAA,CAAA;AAC5B,EAAA,IAAAC,eAAA,GAAkBD,OAAO,KAAK,CAAA,CAAA;EAEpCE,mBAAA,CAAoBb,KAAK,YAAA;IAAA,OAAO;MAC9Bc,WAAA,EAAa,SAAbA,WAAAA,GAAA;QAAA,OAAmBJ,QAAS,CAAAK,OAAA,CAAA;AAAA,OAAA;KAC5B,CAAA;AAAA,GAAA,CAAA,CAAA;AAEI,EAAA,IAAAC,WAAA,GAAcC,YAAY,YAAM;AAAA,IAAA,IAAAC,iBAAA,CAAA;AAChC,IAAA,IAAAf,QAAA,IAAYS,gBAAgBG,OAAS,EAAA,OAAA;AACnC,IAAA,IAAAI,GAAA,GAAMC,UAAW,CAAAC,GAAA,CAAI,QAAQ,CAAA,CAAA;IAC1B,CAAAH,iBAAA,GAAAR,QAAA,CAAAK,OAAA,cAAAG,iBAAA,KAAA,KAAA,CAAA,IAAAA,iBAAA,CAASI,QAAQ,UAACC,CAAA,EAAGC,IAAIC,KAAe,EAAAC,MAAA,EAAgBC,OAAeC,KAAkB,EAAA;MAChG,IAAIhB,gBAAgBG,OAAS,EAAA,OAAA;MACvB,IAAAc,SAAA,GACJD,SAASvB,SAAU,CAAAyB,GAAA,IAAO,MAAMX,GAAI,CAAAO,MAAA,IACpCE,KAAQ,GAAAF,MAAA,IAAUrB,SAAU,CAAA0B,MAAA,IAAU,MAAM,CAC5C,IAAAJ,KAAA,IAAStB,SAAU,CAAA2B,IAAA,IAAQ,CAAM,CAAA,IAAAb,GAAA,CAAIM,SACrCE,KAAQ,GAAAF,KAAA,IAASpB,SAAU,CAAA4B,KAAA,IAAS,CAAM,CAAA,IAAA,CAAA,CAAA;MAC5CrB,eAAA,CAAgBG,OAAU,GAAA,IAAA,CAAA;MAC1Bd,QAAA,CAAS4B,SAAS,CAAA,CAAA;AACpB,KAAC,CAAA,CAAA;GACA,EAAA,CAAC1B,QAAU,EAAAF,QAAA,EAAUI,SAAS,CAAC,CAAA,CAAA;AAGlC6B,EAAAA,SAAA,CAAU,YAAM;AACd,IAAA,IAAI,CAAC/B,QAAA,IAAY,CAACS,eAAA,CAAgBG,OAAS,EAAA;AACnBoB,MAAAA,qBAAA,CAAA,YAAA;QAAA,OAAMnB,aAAa,CAAA;OAAA,CAAA,CAAA;AAC3C,KAAA;AACF,GAAG,EAAA,CAACb,QAAU,EAAAa,WAAW,CAAC,CAAA,CAAA;EAGxB,sBAAAoB,KAAA,CAAAC,aAAA,CAACC;AAAKtC,IAAAA,GAAK,EAAAU,QAAAA;AAAA,GAAA,EAAcH,IAAM,CAAA,EAAA,EAAA,EAAA;AAAAgC,IAAAA,QAAA,EAAUvB,WAAAA;MACtCV,QACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xhsreds/reds-rn-next",
3
- "version": "0.9.0",
3
+ "version": "0.9.1-feat-image-2202510231126",
4
4
  "author": "贾斌(呀哈) <jiabin@xiaohongshu.com>",
5
5
  "license": "ISC",
6
6
  "dependencies": {
@@ -1,98 +1,44 @@
1
- import React, { useCallback, useEffect, useRef, useState, forwardRef, useImperativeHandle } from "react";
2
- import { Dimensions, type ScaledSize, View } from "react-native";
3
- import type { VisibilitySensorRef, VisibilitySensorProps, RectDimensionsState } from "./interface/visibilitySensor";
4
- // function useInterval(callback: () => void, delay: number | null) {
5
- // const savedCallback = useRef(callback);
6
- // useEffect(() => {
7
- // savedCallback.current = callback;
8
- // }, [callback]);
9
- // useEffect(() => {
10
- // if (delay === null || delay === undefined) {
11
- // return;
12
- // }
13
- // const id = setInterval(() => savedCallback.current(), delay);
14
- // return () => clearInterval(id);
15
- // }, [delay]);
16
- // }
1
+ import React, { useCallback, useEffect, useRef, forwardRef, useImperativeHandle } from "react";
2
+ import { Dimensions, View } from "react-native";
3
+ import type { VisibilitySensorRef, VisibilitySensorProps } from "./interface/visibilitySensor";
4
+
5
+ // Measure visibility once on first layout to avoid state-driven re-render loops
17
6
  const VisibilitySensor = forwardRef<VisibilitySensorRef, VisibilitySensorProps>((props, ref) => {
18
- const { onChange, disabled = false, triggerOnce = false, delay, threshold = {}, children, ...rest } = props;
7
+ const { onChange, disabled = false, threshold = {}, children, ...rest } = props;
19
8
  const localRef = useRef<View>(null);
20
- const hasMountedRef = useRef(false);
9
+ const measuredOnceRef = useRef(false);
10
+
21
11
  useImperativeHandle(ref, () => ({
22
12
  getInnerRef: () => localRef.current,
23
13
  }));
24
- const [rectDimensions, setRectDimensions] = useState<RectDimensionsState>({
25
- rectTop: 0,
26
- rectBottom: 0,
27
- rectLeft: 0,
28
- rectRight: 0,
29
- rectWidth: 0,
30
- rectHeight: 0,
31
- });
32
- const [lastValue, setLastValue] = useState<boolean | undefined>(undefined);
33
- const [active, setActive] = useState<boolean>(false);
34
- const measureInnerView = () => {
35
- if (!active) return;
36
- localRef.current?.measure((_x: number, _y: number, width: number, height: number, pageX: number, pageY: number) => {
37
- const dimensions = {
38
- rectTop: pageY,
39
- rectBottom: pageY + height,
40
- rectLeft: pageX,
41
- rectRight: pageX + width,
42
- rectWidth: width,
43
- rectHeight: height,
44
- };
45
- if (
46
- rectDimensions.rectTop !== dimensions.rectTop ||
47
- rectDimensions.rectBottom !== dimensions.rectBottom ||
48
- rectDimensions.rectLeft !== dimensions.rectLeft ||
49
- rectDimensions.rectRight !== dimensions.rectRight ||
50
- rectDimensions.rectWidth !== dimensions.rectWidth ||
51
- rectDimensions.rectHeight !== dimensions.rectHeight
52
- ) {
53
- setRectDimensions(dimensions);
54
- }
14
+
15
+ const measureOnce = useCallback(() => {
16
+ if (disabled || measuredOnceRef.current) return;
17
+ const win = Dimensions.get("window");
18
+ localRef.current?.measure((_, __, width: number, height: number, pageX: number, pageY: number) => {
19
+ if (measuredOnceRef.current) return; // guard against double-calls in same frame
20
+ const isVisible =
21
+ pageY + (threshold.top || 0) <= win.height &&
22
+ pageY + height - (threshold.bottom || 0) >= 0 &&
23
+ pageX + (threshold.left || 0) <= win.width &&
24
+ pageX + width - (threshold.right || 0) >= 0;
25
+ measuredOnceRef.current = true;
26
+ onChange(isVisible);
55
27
  });
56
- };
57
- // useInterval(measureInnerView, delay || 100);
58
- const startWatching = useCallback(() => {
59
- if (!active) setActive(true);
60
- }, [active]);
61
- const stopWatching = useCallback(() => {
62
- if (active) setActive(false);
63
- }, [active]);
64
- useEffect(() => {
65
- if (!disabled) {
66
- startWatching();
67
- }
68
- return () => {
69
- stopWatching();
70
- };
71
- }, [disabled, startWatching, stopWatching]);
28
+ }, [disabled, onChange, threshold]);
29
+
30
+ // If initially disabled, measure once when enabled later
72
31
  useEffect(() => {
73
- if (!hasMountedRef.current) {
74
- hasMountedRef.current = true;
75
- return;
76
- }
77
- const window: ScaledSize = Dimensions.get("window");
78
- const isVisible: boolean =
79
- rectDimensions.rectTop + (threshold.top || 0) <= window.height && // Top edge is within the bottom of the window
80
- rectDimensions.rectBottom - (threshold.bottom || 0) >= 0 && // Bottom edge is within the top of the window
81
- rectDimensions.rectLeft + (threshold.left || 0) <= window.width && // Left edge is within the right of the window
82
- rectDimensions.rectRight - (threshold.right || 0) >= 0; // Right edge is within the left of the window
83
- if (lastValue !== isVisible) {
84
- setLastValue(isVisible);
85
- onChange(isVisible);
86
- if (isVisible && triggerOnce) {
87
- stopWatching();
88
- }
32
+ if (!disabled && !measuredOnceRef.current) {
33
+ requestAnimationFrame(() => measureOnce());
89
34
  }
90
- // eslint-disable-next-line react-hooks/exhaustive-deps
91
- }, [rectDimensions, lastValue]);
35
+ }, [disabled, measureOnce]);
36
+
92
37
  return (
93
- <View ref={localRef} {...rest} onLayout={() => measureInnerView()}>
38
+ <View ref={localRef} {...rest} onLayout={measureOnce}>
94
39
  {children}
95
40
  </View>
96
41
  );
97
42
  });
43
+
98
44
  export default VisibilitySensor;