@bettergi/utils 0.1.6 → 0.1.7

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/README.md CHANGED
@@ -183,4 +183,7 @@ const uuid = generateUUID(false);
183
183
  // 数组洗牌
184
184
  const arr = [1, 2, 3, 4, 5];
185
185
  const shuffled = shuffleArray(arr);
186
+
187
+ // 深度合并多个对象:{ x: 1, y: { a: 2, b: 4, c: 5 }, d: 6 }
188
+ const result = deepMerge({ x: 1, y: { a: 2, b: 3 } }, { y: { b: 4, c: 5 }, d: 6 });
186
189
  ```
package/dist/misc.d.ts CHANGED
@@ -9,3 +9,9 @@ export declare const generateUUID: (withDashes?: boolean) => string;
9
9
  * @returns 洗牌后的新数组
10
10
  */
11
11
  export declare const shuffleArray: <T>(array: T[]) => T[];
12
+ /**
13
+ * 深度合并多个对象
14
+ * @param objects 多个对象
15
+ * @returns 合并后的对象副本
16
+ */
17
+ export declare const deepMerge: (...objects: any[]) => any;
package/dist/misc.js CHANGED
@@ -24,3 +24,18 @@ export const shuffleArray = (array) => {
24
24
  }
25
25
  return shuffled;
26
26
  };
27
+ /**
28
+ * 深度合并多个对象
29
+ * @param objects 多个对象
30
+ * @returns 合并后的对象副本
31
+ */
32
+ export const deepMerge = (...objects) => {
33
+ const isPlainObject = (input) => input?.constructor === Object;
34
+ return objects.reduce((result, obj) => {
35
+ return Object.entries(obj).reduce((acc, [key, value]) => {
36
+ const recursive = isPlainObject(acc[key]) && isPlainObject(value);
37
+ acc[key] = recursive ? deepMerge(acc[key], value) : value;
38
+ return acc;
39
+ }, result);
40
+ }, {});
41
+ };
package/dist/store.d.ts CHANGED
@@ -5,3 +5,9 @@
5
5
  * @param name 存储对象的名称,将作为文件名(不包扩展名)
6
6
  */
7
7
  export declare const useStore: <T extends Record<string, any>>(name: string) => T;
8
+ /**
9
+ * 创建一个带有默认值的持久化存储对象,用于管理应用状态数据
10
+ * @param name 存储对象的名称,将作为文件名(不包扩展名)
11
+ * @param defaults 默认值数据对象
12
+ */
13
+ export declare const useStoreWithDefaults: <T extends Record<string, any>>(name: string, defaults: Partial<T>) => T;
package/dist/store.js CHANGED
@@ -1,3 +1,4 @@
1
+ import { deepMerge } from "./misc";
1
2
  /**
2
3
  * 创建一个持久化存储对象,用于管理应用状态数据
3
4
  * 该函数会创建一个代理对象,对该对象的所有属性的修改都会自动同步到相应的JSON文件(脚本的 `store` 目录下)中。
@@ -50,3 +51,13 @@ export const useStore = (name) => {
50
51
  };
51
52
  return createProxy(obj);
52
53
  };
54
+ /**
55
+ * 创建一个带有默认值的持久化存储对象,用于管理应用状态数据
56
+ * @param name 存储对象的名称,将作为文件名(不包扩展名)
57
+ * @param defaults 默认值数据对象
58
+ */
59
+ export const useStoreWithDefaults = (name, defaults) => {
60
+ const store = useStore(name);
61
+ Object.assign(store, deepMerge(defaults, store));
62
+ return store;
63
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bettergi/utils",
3
- "version": "0.1.6",
3
+ "version": "0.1.7",
4
4
  "description": "开发 BetterGI 脚本常用工具集",
5
5
  "type": "module",
6
6
  "author": "Bread Grocery<https://github.com/breadgrocery>",