@trackunit/react-core-hooks 1.7.51 → 1.7.52
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/index.cjs.js +16 -6
- package/index.esm.js +16 -6
- package/package.json +1 -1
- package/src/useFeatureBranchQueryString.d.ts +3 -1
- package/src/useWatch.d.ts +3 -1
package/index.cjs.js
CHANGED
|
@@ -412,8 +412,9 @@ const useImageUploader = () => {
|
|
|
412
412
|
*/
|
|
413
413
|
const useFeatureBranchQueryString = () => {
|
|
414
414
|
const { publicUrl, buildVersion, isFeatureBranch } = useEnvironment();
|
|
415
|
-
|
|
416
|
-
|
|
415
|
+
return react.useMemo(() => ({
|
|
416
|
+
featureBranchQueryParam: !publicUrl || !isFeatureBranch ? "" : `?fb_url=${encodeURIComponent(publicUrl)}&fb_version=${buildVersion}`,
|
|
417
|
+
}), [publicUrl, buildVersion, isFeatureBranch]);
|
|
417
418
|
};
|
|
418
419
|
|
|
419
420
|
const IRIS_APP_ASSET_PATH = "assets/";
|
|
@@ -1198,20 +1199,29 @@ const UNINITIALIZED = Symbol("UNINITIALIZED");
|
|
|
1198
1199
|
* @param props.value - The value to watch for changes
|
|
1199
1200
|
* @param props.onChange - Function to call when the value changes
|
|
1200
1201
|
* @param props.immediate - Whether to run the callback immediately on mount (default: false)
|
|
1202
|
+
* @param props.skip - Whether to skip watching for changes (default: false)
|
|
1201
1203
|
*/
|
|
1202
|
-
const useWatch = ({ value, onChange, immediate = false }) => {
|
|
1204
|
+
const useWatch = ({ value, onChange, immediate = false, skip = false }) => {
|
|
1203
1205
|
const prevValue = react.useRef(UNINITIALIZED);
|
|
1206
|
+
const onChangeRef = react.useRef(onChange);
|
|
1207
|
+
// Update the ref whenever onChange changes
|
|
1204
1208
|
react.useEffect(() => {
|
|
1209
|
+
onChangeRef.current = onChange;
|
|
1210
|
+
}, [onChange]);
|
|
1211
|
+
react.useEffect(() => {
|
|
1212
|
+
if (skip) {
|
|
1213
|
+
return;
|
|
1214
|
+
}
|
|
1205
1215
|
const prev = prevValue.current;
|
|
1206
1216
|
const hasChanged = prev === UNINITIALIZED ? false : !esToolkit.isEqual(value, prev);
|
|
1207
1217
|
if (immediate && prev === UNINITIALIZED) {
|
|
1208
|
-
|
|
1218
|
+
onChangeRef.current(value, null);
|
|
1209
1219
|
}
|
|
1210
1220
|
else if (hasChanged && prev !== UNINITIALIZED) {
|
|
1211
|
-
|
|
1221
|
+
onChangeRef.current(value, prev);
|
|
1212
1222
|
}
|
|
1213
1223
|
prevValue.current = value;
|
|
1214
|
-
}, [value,
|
|
1224
|
+
}, [value, immediate, skip]);
|
|
1215
1225
|
};
|
|
1216
1226
|
|
|
1217
1227
|
const WidgetConfigContext = react.createContext(null);
|
package/index.esm.js
CHANGED
|
@@ -410,8 +410,9 @@ const useImageUploader = () => {
|
|
|
410
410
|
*/
|
|
411
411
|
const useFeatureBranchQueryString = () => {
|
|
412
412
|
const { publicUrl, buildVersion, isFeatureBranch } = useEnvironment();
|
|
413
|
-
|
|
414
|
-
|
|
413
|
+
return useMemo(() => ({
|
|
414
|
+
featureBranchQueryParam: !publicUrl || !isFeatureBranch ? "" : `?fb_url=${encodeURIComponent(publicUrl)}&fb_version=${buildVersion}`,
|
|
415
|
+
}), [publicUrl, buildVersion, isFeatureBranch]);
|
|
415
416
|
};
|
|
416
417
|
|
|
417
418
|
const IRIS_APP_ASSET_PATH = "assets/";
|
|
@@ -1196,20 +1197,29 @@ const UNINITIALIZED = Symbol("UNINITIALIZED");
|
|
|
1196
1197
|
* @param props.value - The value to watch for changes
|
|
1197
1198
|
* @param props.onChange - Function to call when the value changes
|
|
1198
1199
|
* @param props.immediate - Whether to run the callback immediately on mount (default: false)
|
|
1200
|
+
* @param props.skip - Whether to skip watching for changes (default: false)
|
|
1199
1201
|
*/
|
|
1200
|
-
const useWatch = ({ value, onChange, immediate = false }) => {
|
|
1202
|
+
const useWatch = ({ value, onChange, immediate = false, skip = false }) => {
|
|
1201
1203
|
const prevValue = useRef(UNINITIALIZED);
|
|
1204
|
+
const onChangeRef = useRef(onChange);
|
|
1205
|
+
// Update the ref whenever onChange changes
|
|
1202
1206
|
useEffect(() => {
|
|
1207
|
+
onChangeRef.current = onChange;
|
|
1208
|
+
}, [onChange]);
|
|
1209
|
+
useEffect(() => {
|
|
1210
|
+
if (skip) {
|
|
1211
|
+
return;
|
|
1212
|
+
}
|
|
1203
1213
|
const prev = prevValue.current;
|
|
1204
1214
|
const hasChanged = prev === UNINITIALIZED ? false : !isEqual(value, prev);
|
|
1205
1215
|
if (immediate && prev === UNINITIALIZED) {
|
|
1206
|
-
|
|
1216
|
+
onChangeRef.current(value, null);
|
|
1207
1217
|
}
|
|
1208
1218
|
else if (hasChanged && prev !== UNINITIALIZED) {
|
|
1209
|
-
|
|
1219
|
+
onChangeRef.current(value, prev);
|
|
1210
1220
|
}
|
|
1211
1221
|
prevValue.current = value;
|
|
1212
|
-
}, [value,
|
|
1222
|
+
}, [value, immediate, skip]);
|
|
1213
1223
|
};
|
|
1214
1224
|
|
|
1215
1225
|
const WidgetConfigContext = createContext(null);
|
package/package.json
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
|
+
type FeatureBranchQueryString = `?fb_url=${string}&fb_version=${string}`;
|
|
1
2
|
/**
|
|
2
3
|
* Returns the query string to be appended to the URL when the app is served from a Feature Branch.
|
|
3
4
|
*/
|
|
4
5
|
export declare const useFeatureBranchQueryString: () => {
|
|
5
|
-
featureBranchQueryParam:
|
|
6
|
+
featureBranchQueryParam: "" | FeatureBranchQueryString;
|
|
6
7
|
};
|
|
8
|
+
export {};
|
package/src/useWatch.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
interface UseWatchOptions {
|
|
2
2
|
immediate?: boolean;
|
|
3
|
+
skip?: boolean;
|
|
3
4
|
}
|
|
4
5
|
interface UseWatchProps<TValue> extends UseWatchOptions {
|
|
5
6
|
value: TValue;
|
|
@@ -13,6 +14,7 @@ interface UseWatchProps<TValue> extends UseWatchOptions {
|
|
|
13
14
|
* @param props.value - The value to watch for changes
|
|
14
15
|
* @param props.onChange - Function to call when the value changes
|
|
15
16
|
* @param props.immediate - Whether to run the callback immediately on mount (default: false)
|
|
17
|
+
* @param props.skip - Whether to skip watching for changes (default: false)
|
|
16
18
|
*/
|
|
17
|
-
export declare const useWatch: <TValue>({ value, onChange, immediate }: UseWatchProps<TValue>) => void;
|
|
19
|
+
export declare const useWatch: <TValue>({ value, onChange, immediate, skip }: UseWatchProps<TValue>) => void;
|
|
18
20
|
export {};
|