@synerise/ds-utils 1.7.1 → 1.8.0
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.
- package/CHANGELOG.md +6 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +2 -0
- package/dist/useDebounce/useDebounce.d.ts +1 -0
- package/dist/useDebounce/useDebounce.js +22 -0
- package/dist/useResizeObserver/useResizeObserver.js +3 -1
- package/package.json +5 -7
- package/dist/useDelimiterEscape/__specs__/testCases.d.ts +0 -6
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,12 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [1.8.0](https://github.com/synerise/synerise-design/compare/@synerise/ds-utils@1.7.1...@synerise/ds-utils@1.8.0) (2026-04-10)
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
- **table-new:** initial commit ([a524cb9](https://github.com/synerise/synerise-design/commit/a524cb9cfa464921edb9531ccf002dcc25a3b105))
|
|
11
|
+
|
|
6
12
|
## [1.7.1](https://github.com/synerise/synerise-design/compare/@synerise/ds-utils@1.7.0...@synerise/ds-utils@1.7.1) (2026-03-24)
|
|
7
13
|
|
|
8
14
|
**Note:** Version bump only for package @synerise/ds-utils
|
package/dist/index.d.ts
CHANGED
|
@@ -3,6 +3,7 @@ export { default as toCamelCase } from './toCamelCase/toCamelCase';
|
|
|
3
3
|
export { useOnClickOutside, type HandledEventsType, } from './useOnClickOutside/useOnClickOutside';
|
|
4
4
|
export { renderWithHighlight } from './renderWithHighlight/renderWithHighlight';
|
|
5
5
|
export { useStableId } from './useStableId/useStableId';
|
|
6
|
+
export { useDebounce } from './useDebounce/useDebounce';
|
|
6
7
|
export { default as selectColorByLetter } from './selectColorByLetter/selectColorByLetter';
|
|
7
8
|
export { default as focusWithArrowKeys } from './focusWithArrowKeys/focusWithArrowKeys';
|
|
8
9
|
export { default as escapeRegEx } from './regex/regex';
|
package/dist/index.js
CHANGED
|
@@ -3,6 +3,7 @@ import { default as default3 } from "./toCamelCase/toCamelCase.js";
|
|
|
3
3
|
import { useOnClickOutside } from "./useOnClickOutside/useOnClickOutside.js";
|
|
4
4
|
import { renderWithHighlight } from "./renderWithHighlight/renderWithHighlight.js";
|
|
5
5
|
import { useStableId } from "./useStableId/useStableId.js";
|
|
6
|
+
import { useDebounce } from "./useDebounce/useDebounce.js";
|
|
6
7
|
import { default as default4 } from "./selectColorByLetter/selectColorByLetter.js";
|
|
7
8
|
import { default as default5 } from "./focusWithArrowKeys/focusWithArrowKeys.js";
|
|
8
9
|
import { default as default6 } from "./regex/regex.js";
|
|
@@ -45,6 +46,7 @@ export {
|
|
|
45
46
|
default3 as toCamelCase,
|
|
46
47
|
default10 as useBreakpoint,
|
|
47
48
|
default11 as useCombinedRefs,
|
|
49
|
+
useDebounce,
|
|
48
50
|
useDelimiterEscape,
|
|
49
51
|
default13 as useElementInView,
|
|
50
52
|
useIsMounted,
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const useDebounce: <T extends unknown[]>(callback: (...args: T) => void, delay?: number) => (...args: T) => void;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { useRef, useCallback, useEffect } from "react";
|
|
2
|
+
const useDebounce = (callback, delay = 100) => {
|
|
3
|
+
const timerRef = useRef(null);
|
|
4
|
+
const debounced = useCallback((...args) => {
|
|
5
|
+
if (timerRef.current) {
|
|
6
|
+
clearTimeout(timerRef.current);
|
|
7
|
+
}
|
|
8
|
+
timerRef.current = setTimeout(() => {
|
|
9
|
+
callback(...args);
|
|
10
|
+
timerRef.current = null;
|
|
11
|
+
}, delay);
|
|
12
|
+
}, [callback, delay]);
|
|
13
|
+
useEffect(() => () => {
|
|
14
|
+
if (timerRef.current) {
|
|
15
|
+
clearTimeout(timerRef.current);
|
|
16
|
+
}
|
|
17
|
+
}, []);
|
|
18
|
+
return debounced;
|
|
19
|
+
};
|
|
20
|
+
export {
|
|
21
|
+
useDebounce
|
|
22
|
+
};
|
|
@@ -7,7 +7,6 @@ const useResizeObserver = (elementRef, resizeHandler) => {
|
|
|
7
7
|
contentRect
|
|
8
8
|
} = entries[0];
|
|
9
9
|
setDimensions(contentRect);
|
|
10
|
-
resizeHandler && resizeHandler(contentRect);
|
|
11
10
|
};
|
|
12
11
|
if ("requestAnimationFrame" in window) {
|
|
13
12
|
window.requestAnimationFrame(runHandler);
|
|
@@ -21,6 +20,9 @@ const useResizeObserver = (elementRef, resizeHandler) => {
|
|
|
21
20
|
const disconnect = useCallback(() => {
|
|
22
21
|
resizeObserver.disconnect();
|
|
23
22
|
}, [resizeObserver]);
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
resizeHandler && resizeHandler(dimensions);
|
|
25
|
+
}, [dimensions, resizeHandler]);
|
|
24
26
|
useEffect(() => {
|
|
25
27
|
if (elementRef.current) {
|
|
26
28
|
observe();
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@synerise/ds-utils",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.8.0",
|
|
4
4
|
"description": "Utils UI Component for the Synerise Design System",
|
|
5
5
|
"license": "ISC",
|
|
6
6
|
"repository": "synerise/synerise-design",
|
|
@@ -17,13 +17,10 @@
|
|
|
17
17
|
},
|
|
18
18
|
"scripts": {
|
|
19
19
|
"build": "vite build",
|
|
20
|
-
"build:css": "node ../../../scripts/style/less.js",
|
|
21
|
-
"build:js": "babel --delete-dir-on-start --root-mode upward src --out-dir dist --extensions '.js,.ts,.tsx'",
|
|
22
20
|
"build:watch": "vite build --watch",
|
|
23
|
-
"defs": "tsc --declaration --outDir dist/ --emitDeclarationOnly",
|
|
24
21
|
"pack:ci": "pnpm pack --pack-destination ../../storybook/storybook-static/static",
|
|
25
22
|
"prepublish": "pnpm run build",
|
|
26
|
-
"test": "
|
|
23
|
+
"test": "vitest run",
|
|
27
24
|
"types": "tsc --noEmit",
|
|
28
25
|
"check:circular-dependencies": "madge --circular --extensions ts,tsx,js,jsx --ts-config tsconfig.json src/ --exclude '/dist/'",
|
|
29
26
|
"upgrade:ds": "ncu -f \"@synerise/ds-*\" -u"
|
|
@@ -40,7 +37,8 @@
|
|
|
40
37
|
"peerDependencies": {
|
|
41
38
|
"@synerise/ds-core": "^1",
|
|
42
39
|
"react": ">=16.9.0 <= 18.3.1",
|
|
43
|
-
"styled-components": "^5.3.3"
|
|
40
|
+
"styled-components": "^5.3.3",
|
|
41
|
+
"vitest": "4"
|
|
44
42
|
},
|
|
45
|
-
"gitHead": "
|
|
43
|
+
"gitHead": "ce3c6d75efe8573a2b274853636f959b75a6cd32"
|
|
46
44
|
}
|