@etsoo/shared 1.0.98 → 1.1.2
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 +1 -0
- package/__tests__/Utils.ts +12 -0
- package/lib/cjs/DataTypes.d.ts +4 -1
- package/lib/cjs/Utils.d.ts +7 -0
- package/lib/cjs/Utils.js +9 -0
- package/lib/mjs/DataTypes.d.ts +4 -1
- package/lib/mjs/Utils.d.ts +7 -0
- package/lib/mjs/Utils.js +9 -0
- package/package.json +6 -6
- package/src/DataTypes.ts +5 -3
- package/src/Utils.ts +16 -0
package/README.md
CHANGED
|
@@ -62,6 +62,7 @@ Data type definitions and type safe functions
|
|
|
62
62
|
|getIdValue|Get object id field value|
|
|
63
63
|
|getItemId|Get item id|
|
|
64
64
|
|getItemLabel|Get item label|
|
|
65
|
+
|getResult|Get input function or value result|
|
|
65
66
|
|getStringValue|Get object string field value|
|
|
66
67
|
|isBasicName|Check the type is a basic type or not (type guard)|
|
|
67
68
|
|isSimpleObject|Is the target a simple object, all values are simple type (Type guard)|
|
package/__tests__/Utils.ts
CHANGED
|
@@ -133,3 +133,15 @@ test('Test for snakeNameToWord', () => {
|
|
|
133
133
|
test('Tests for mergeClasses', () => {
|
|
134
134
|
expect(Utils.mergeClasses('a', '', 'b ', undefined, 'c')).toBe('a b c');
|
|
135
135
|
});
|
|
136
|
+
|
|
137
|
+
test('Tests for getResult', () => {
|
|
138
|
+
// Arrange
|
|
139
|
+
type test = ((visible: boolean) => number) | number;
|
|
140
|
+
const input: test = (visible) => (visible ? 1 : 0);
|
|
141
|
+
const inputNumber: test = 5;
|
|
142
|
+
|
|
143
|
+
// Act & assert
|
|
144
|
+
expect(Utils.getResult(input, true)).toBe(1);
|
|
145
|
+
expect(Utils.getResult(input, false)).toBe(0);
|
|
146
|
+
expect(Utils.getResult(inputNumber)).toBe(5);
|
|
147
|
+
});
|
package/lib/cjs/DataTypes.d.ts
CHANGED
|
@@ -115,8 +115,11 @@ export declare namespace DataTypes {
|
|
|
115
115
|
type IdType = number | string;
|
|
116
116
|
/**
|
|
117
117
|
* Add or edit conditional type for same data model
|
|
118
|
+
* Dynamic add changedFields for editing case
|
|
118
119
|
*/
|
|
119
|
-
type AddOrEditType<T, Editing extends boolean> = Editing extends true ? T : Partial<T
|
|
120
|
+
type AddOrEditType<T, Editing extends boolean> = (Editing extends true ? T : Partial<T>) & {
|
|
121
|
+
changedFields?: string[];
|
|
122
|
+
};
|
|
120
123
|
/**
|
|
121
124
|
* Enum value type
|
|
122
125
|
*/
|
package/lib/cjs/Utils.d.ts
CHANGED
|
@@ -69,6 +69,13 @@ export declare namespace Utils {
|
|
|
69
69
|
* @returns
|
|
70
70
|
*/
|
|
71
71
|
function getDataChanges(input: {}, initData: {}, ignoreFields?: string[]): string[];
|
|
72
|
+
/**
|
|
73
|
+
* Get input function or value result
|
|
74
|
+
* @param input Input function or value
|
|
75
|
+
* @param args Arguments
|
|
76
|
+
* @returns Result
|
|
77
|
+
*/
|
|
78
|
+
const getResult: <R extends DataTypes.Simple, F extends (...args: any[]) => R>(input: R | F, ...args: Parameters<F>) => R;
|
|
72
79
|
/**
|
|
73
80
|
* Get time zone
|
|
74
81
|
* @returns Timezone
|
package/lib/cjs/Utils.js
CHANGED
|
@@ -125,6 +125,15 @@ var Utils;
|
|
|
125
125
|
return changes;
|
|
126
126
|
}
|
|
127
127
|
Utils.getDataChanges = getDataChanges;
|
|
128
|
+
/**
|
|
129
|
+
* Get input function or value result
|
|
130
|
+
* @param input Input function or value
|
|
131
|
+
* @param args Arguments
|
|
132
|
+
* @returns Result
|
|
133
|
+
*/
|
|
134
|
+
Utils.getResult = (input, ...args) => {
|
|
135
|
+
return typeof input === 'function' ? input(...args) : input;
|
|
136
|
+
};
|
|
128
137
|
/**
|
|
129
138
|
* Get time zone
|
|
130
139
|
* @returns Timezone
|
package/lib/mjs/DataTypes.d.ts
CHANGED
|
@@ -115,8 +115,11 @@ export declare namespace DataTypes {
|
|
|
115
115
|
type IdType = number | string;
|
|
116
116
|
/**
|
|
117
117
|
* Add or edit conditional type for same data model
|
|
118
|
+
* Dynamic add changedFields for editing case
|
|
118
119
|
*/
|
|
119
|
-
type AddOrEditType<T, Editing extends boolean> = Editing extends true ? T : Partial<T
|
|
120
|
+
type AddOrEditType<T, Editing extends boolean> = (Editing extends true ? T : Partial<T>) & {
|
|
121
|
+
changedFields?: string[];
|
|
122
|
+
};
|
|
120
123
|
/**
|
|
121
124
|
* Enum value type
|
|
122
125
|
*/
|
package/lib/mjs/Utils.d.ts
CHANGED
|
@@ -69,6 +69,13 @@ export declare namespace Utils {
|
|
|
69
69
|
* @returns
|
|
70
70
|
*/
|
|
71
71
|
function getDataChanges(input: {}, initData: {}, ignoreFields?: string[]): string[];
|
|
72
|
+
/**
|
|
73
|
+
* Get input function or value result
|
|
74
|
+
* @param input Input function or value
|
|
75
|
+
* @param args Arguments
|
|
76
|
+
* @returns Result
|
|
77
|
+
*/
|
|
78
|
+
const getResult: <R extends DataTypes.Simple, F extends (...args: any[]) => R>(input: R | F, ...args: Parameters<F>) => R;
|
|
72
79
|
/**
|
|
73
80
|
* Get time zone
|
|
74
81
|
* @returns Timezone
|
package/lib/mjs/Utils.js
CHANGED
|
@@ -122,6 +122,15 @@ export var Utils;
|
|
|
122
122
|
return changes;
|
|
123
123
|
}
|
|
124
124
|
Utils.getDataChanges = getDataChanges;
|
|
125
|
+
/**
|
|
126
|
+
* Get input function or value result
|
|
127
|
+
* @param input Input function or value
|
|
128
|
+
* @param args Arguments
|
|
129
|
+
* @returns Result
|
|
130
|
+
*/
|
|
131
|
+
Utils.getResult = (input, ...args) => {
|
|
132
|
+
return typeof input === 'function' ? input(...args) : input;
|
|
133
|
+
};
|
|
125
134
|
/**
|
|
126
135
|
* Get time zone
|
|
127
136
|
* @returns Timezone
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@etsoo/shared",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.1.2",
|
|
4
4
|
"description": "TypeScript shared utilities and functions",
|
|
5
5
|
"main": "lib/cjs/index.js",
|
|
6
6
|
"module": "lib/mjs/index.js",
|
|
@@ -55,12 +55,12 @@
|
|
|
55
55
|
"dependencies": {},
|
|
56
56
|
"devDependencies": {
|
|
57
57
|
"@types/jest": "^27.4.0",
|
|
58
|
-
"@typescript-eslint/eslint-plugin": "^5.
|
|
59
|
-
"@typescript-eslint/parser": "^5.
|
|
60
|
-
"eslint": "^8.
|
|
58
|
+
"@typescript-eslint/eslint-plugin": "^5.9.0",
|
|
59
|
+
"@typescript-eslint/parser": "^5.9.0",
|
|
60
|
+
"eslint": "^8.6.0",
|
|
61
61
|
"eslint-config-airbnb-base": "^15.0.0",
|
|
62
|
-
"eslint-plugin-import": "^2.25.
|
|
63
|
-
"jest": "^27.4.
|
|
62
|
+
"eslint-plugin-import": "^2.25.4",
|
|
63
|
+
"jest": "^27.4.7",
|
|
64
64
|
"ts-jest": "^27.1.2",
|
|
65
65
|
"typescript": "^4.5.4"
|
|
66
66
|
}
|
package/src/DataTypes.ts
CHANGED
|
@@ -149,10 +149,12 @@ export namespace DataTypes {
|
|
|
149
149
|
|
|
150
150
|
/**
|
|
151
151
|
* Add or edit conditional type for same data model
|
|
152
|
+
* Dynamic add changedFields for editing case
|
|
152
153
|
*/
|
|
153
|
-
export type AddOrEditType<
|
|
154
|
-
|
|
155
|
-
|
|
154
|
+
export type AddOrEditType<
|
|
155
|
+
T,
|
|
156
|
+
Editing extends boolean
|
|
157
|
+
> = (Editing extends true ? T : Partial<T>) & { changedFields?: string[] };
|
|
156
158
|
|
|
157
159
|
/**
|
|
158
160
|
* Enum value type
|
package/src/Utils.ts
CHANGED
|
@@ -187,6 +187,22 @@ export namespace Utils {
|
|
|
187
187
|
return changes;
|
|
188
188
|
}
|
|
189
189
|
|
|
190
|
+
/**
|
|
191
|
+
* Get input function or value result
|
|
192
|
+
* @param input Input function or value
|
|
193
|
+
* @param args Arguments
|
|
194
|
+
* @returns Result
|
|
195
|
+
*/
|
|
196
|
+
export const getResult = <
|
|
197
|
+
R extends DataTypes.Simple,
|
|
198
|
+
F extends (...args: any[]) => R
|
|
199
|
+
>(
|
|
200
|
+
input: F | R,
|
|
201
|
+
...args: Parameters<F>
|
|
202
|
+
): R => {
|
|
203
|
+
return typeof input === 'function' ? input(...args) : input;
|
|
204
|
+
};
|
|
205
|
+
|
|
190
206
|
/**
|
|
191
207
|
* Get time zone
|
|
192
208
|
* @returns Timezone
|