@vpmedia/simplify 1.21.0 → 1.22.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/README.md
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
# @vpmedia/simplify
|
|
2
2
|
|
|
3
|
-
[](https://badge.fury.io/js/@vpmedia%2Fsimplify)
|
|
4
4
|
[](https://github.com/vpmedia/simplify/actions/workflows/ci.yml)
|
|
5
5
|
|
|
6
6
|
@vpmedia/simplify TBD
|
package/package.json
CHANGED
|
@@ -3,18 +3,19 @@ import { underscoreToCamelCase } from './underscoreToCamelCase.js';
|
|
|
3
3
|
/**
|
|
4
4
|
* Maps server data to client data.
|
|
5
5
|
* @param {object} data - The server input data.
|
|
6
|
+
* @param {boolean} isRecursive - Use recursive serialization.
|
|
6
7
|
* @returns {object} The output data.
|
|
7
8
|
*/
|
|
8
|
-
export const serverDataToState = (data) => {
|
|
9
|
+
export const serverDataToState = (data, isRecursive = false) => {
|
|
9
10
|
if (Array.isArray(data)) {
|
|
10
|
-
return data.map((entry) => serverDataToState(entry));
|
|
11
|
+
return data.map((entry) => serverDataToState(entry, isRecursive));
|
|
11
12
|
}
|
|
12
13
|
|
|
13
14
|
if (data !== null && typeof data === 'object') {
|
|
14
15
|
const result = {};
|
|
15
16
|
for (const [key, value] of Object.entries(data)) {
|
|
16
17
|
const clientKey = underscoreToCamelCase(key);
|
|
17
|
-
result[clientKey] = serverDataToState(value);
|
|
18
|
+
result[clientKey] = isRecursive ? serverDataToState(value) : value;
|
|
18
19
|
}
|
|
19
20
|
return result;
|
|
20
21
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { serverDataToState } from './serverDataToState.js';
|
|
2
2
|
|
|
3
|
-
test('serverDataToState()', () => {
|
|
3
|
+
test('serverDataToState() recursive', () => {
|
|
4
4
|
const state = serverDataToState({
|
|
5
5
|
my_array: [{ key_a: 'value1' }],
|
|
6
6
|
my_data: { key_a: 'value1' },
|
|
@@ -9,7 +9,7 @@ test('serverDataToState()', () => {
|
|
|
9
9
|
my_number: 1000,
|
|
10
10
|
my_string: 'a',
|
|
11
11
|
my_var: 'test',
|
|
12
|
-
});
|
|
12
|
+
}, true);
|
|
13
13
|
expect(state.myArray[0].keyA).toBe('value1');
|
|
14
14
|
expect(state.myData.keyA).toBe('value1');
|
|
15
15
|
expect(state.myList[0]).toBe(1);
|
|
@@ -18,3 +18,23 @@ test('serverDataToState()', () => {
|
|
|
18
18
|
expect(state.myString).toBe('a');
|
|
19
19
|
expect(state.myVar).toBe('test');
|
|
20
20
|
});
|
|
21
|
+
|
|
22
|
+
test('serverDataToState() non-recursive', () => {
|
|
23
|
+
const state = serverDataToState({
|
|
24
|
+
my_array: [{ key_a: 'value1' }],
|
|
25
|
+
my_data: { key_a: 'value1' },
|
|
26
|
+
my_list: [1, 2, 3],
|
|
27
|
+
my_null: null,
|
|
28
|
+
my_number: 1000,
|
|
29
|
+
my_string: 'a',
|
|
30
|
+
my_var: 'test',
|
|
31
|
+
}, false);
|
|
32
|
+
expect(state.myArray[0].key_a).toBe('value1');
|
|
33
|
+
expect(state.myData.key_a).toBe('value1');
|
|
34
|
+
expect(state.myList[0]).toBe(1);
|
|
35
|
+
expect(state.myNull).toBe(null);
|
|
36
|
+
expect(state.myNumber).toBe(1000);
|
|
37
|
+
expect(state.myString).toBe('a');
|
|
38
|
+
expect(state.myVar).toBe('test');
|
|
39
|
+
});
|
|
40
|
+
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export function serverDataToState(data: object): object;
|
|
1
|
+
export function serverDataToState(data: object, isRecursive?: boolean): object;
|
|
2
2
|
//# sourceMappingURL=serverDataToState.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"serverDataToState.d.ts","sourceRoot":"","sources":["../../src/util/serverDataToState.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"serverDataToState.d.ts","sourceRoot":"","sources":["../../src/util/serverDataToState.js"],"names":[],"mappings":"AAQO,wCAJI,MAAM,gBACN,OAAO,GACL,MAAM,CAiBlB"}
|