@stryke/types 0.10.23 → 0.10.24
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/dist/array.d.cts +122 -2
- package/dist/array.d.cts.map +1 -0
- package/dist/array.d.mts +122 -2
- package/dist/array.d.mts.map +1 -0
- package/dist/async.d.cts +111 -2
- package/dist/async.d.cts.map +1 -0
- package/dist/async.d.mts +111 -2
- package/dist/async.d.mts.map +1 -0
- package/dist/base.cjs +3 -1
- package/dist/base.d.cts +331 -2
- package/dist/base.d.cts.map +1 -0
- package/dist/base.d.mts +331 -2
- package/dist/base.d.mts.map +1 -0
- package/dist/base.mjs +3 -1
- package/dist/base.mjs.map +1 -0
- package/dist/configuration.d.cts +71 -2
- package/dist/configuration.d.cts.map +1 -0
- package/dist/configuration.d.mts +71 -2
- package/dist/configuration.d.mts.map +1 -0
- package/dist/file.d.cts +51 -2
- package/dist/file.d.cts.map +1 -0
- package/dist/file.d.mts +51 -2
- package/dist/file.d.mts.map +1 -0
- package/dist/form.d.cts +40 -2
- package/dist/form.d.cts.map +1 -0
- package/dist/form.d.mts +40 -2
- package/dist/form.d.mts.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.cts +19 -18
- package/dist/index.d.mts +19 -18
- package/dist/index.mjs +1 -1
- package/dist/json.d.cts +70 -2
- package/dist/json.d.cts.map +1 -0
- package/dist/json.d.mts +70 -2
- package/dist/json.d.mts.map +1 -0
- package/dist/logic.d.cts +124 -2
- package/dist/logic.d.cts.map +1 -0
- package/dist/logic.d.mts +124 -2
- package/dist/logic.d.mts.map +1 -0
- package/dist/messages.d.cts +21 -2
- package/dist/messages.d.cts.map +1 -0
- package/dist/messages.d.mts +21 -2
- package/dist/messages.d.mts.map +1 -0
- package/dist/navigator.d.cts +42 -2
- package/dist/navigator.d.cts.map +1 -0
- package/dist/navigator.d.mts +42 -2
- package/dist/navigator.d.mts.map +1 -0
- package/dist/number.d.cts +181 -2
- package/dist/number.d.cts.map +1 -0
- package/dist/number.d.mts +181 -2
- package/dist/number.d.mts.map +1 -0
- package/dist/object.d.cts +394 -2
- package/dist/object.d.cts.map +1 -0
- package/dist/object.d.mts +394 -2
- package/dist/object.d.mts.map +1 -0
- package/dist/package-json.d.cts +261 -2
- package/dist/package-json.d.cts.map +1 -0
- package/dist/package-json.d.mts +261 -2
- package/dist/package-json.d.mts.map +1 -0
- package/dist/package-manager.d.cts +6 -2
- package/dist/package-manager.d.cts.map +1 -0
- package/dist/package-manager.d.mts +6 -2
- package/dist/package-manager.d.mts.map +1 -0
- package/dist/string.d.cts +81 -2
- package/dist/string.d.cts.map +1 -0
- package/dist/string.d.mts +81 -2
- package/dist/string.d.mts.map +1 -0
- package/dist/system.d.cts +5 -2
- package/dist/system.d.cts.map +1 -0
- package/dist/system.d.mts +5 -2
- package/dist/system.d.mts.map +1 -0
- package/dist/tsconfig.d.cts +803 -2
- package/dist/tsconfig.d.cts.map +1 -0
- package/dist/tsconfig.d.mts +803 -2
- package/dist/tsconfig.d.mts.map +1 -0
- package/dist/user.d.cts +29 -2
- package/dist/user.d.cts.map +1 -0
- package/dist/user.d.mts +29 -2
- package/dist/user.d.mts.map +1 -0
- package/dist/utilities.d.cts +51 -2
- package/dist/utilities.d.cts.map +1 -0
- package/dist/utilities.d.mts +51 -2
- package/dist/utilities.d.mts.map +1 -0
- package/dist/validations.d.cts +21 -2
- package/dist/validations.d.cts.map +1 -0
- package/dist/validations.d.mts +21 -2
- package/dist/validations.d.mts.map +1 -0
- package/package.json +3 -3
- package/dist/array-DVtfX_TI.d.mts +0 -122
- package/dist/array-DVtfX_TI.d.mts.map +0 -1
- package/dist/array-DtIKbcDr.d.cts +0 -122
- package/dist/array-DtIKbcDr.d.cts.map +0 -1
- package/dist/async-BtPWg6IL.d.mts +0 -111
- package/dist/async-BtPWg6IL.d.mts.map +0 -1
- package/dist/async-eKWh-_sF.d.cts +0 -111
- package/dist/async-eKWh-_sF.d.cts.map +0 -1
- package/dist/base-CiIyKS-b.d.mts +0 -331
- package/dist/base-CiIyKS-b.d.mts.map +0 -1
- package/dist/base-Cpeh4C5c.cjs +0 -3
- package/dist/base-DmFPRVSE.mjs +0 -3
- package/dist/base-DmFPRVSE.mjs.map +0 -1
- package/dist/base-EF17pdAI.d.cts +0 -331
- package/dist/base-EF17pdAI.d.cts.map +0 -1
- package/dist/configuration-5Q2wg3Id.d.mts +0 -71
- package/dist/configuration-5Q2wg3Id.d.mts.map +0 -1
- package/dist/configuration-Dvz7q6dd.d.cts +0 -71
- package/dist/configuration-Dvz7q6dd.d.cts.map +0 -1
- package/dist/file-dM8RAMNC.d.cts +0 -51
- package/dist/file-dM8RAMNC.d.cts.map +0 -1
- package/dist/file-eWushyiM.d.mts +0 -51
- package/dist/file-eWushyiM.d.mts.map +0 -1
- package/dist/form-mTzpZCeA.d.cts +0 -40
- package/dist/form-mTzpZCeA.d.cts.map +0 -1
- package/dist/form-sNCVXIEk.d.mts +0 -40
- package/dist/form-sNCVXIEk.d.mts.map +0 -1
- package/dist/json-BlaU0Pbq.d.cts +0 -70
- package/dist/json-BlaU0Pbq.d.cts.map +0 -1
- package/dist/json-C3wqh2t3.d.mts +0 -70
- package/dist/json-C3wqh2t3.d.mts.map +0 -1
- package/dist/logic-BoEG5A3-.d.cts +0 -374
- package/dist/logic-BoEG5A3-.d.cts.map +0 -1
- package/dist/logic-h9Jrrpsk.d.mts +0 -374
- package/dist/logic-h9Jrrpsk.d.mts.map +0 -1
- package/dist/messages-Bxu_o13x.d.mts +0 -21
- package/dist/messages-Bxu_o13x.d.mts.map +0 -1
- package/dist/messages-PtLJRJeN.d.cts +0 -21
- package/dist/messages-PtLJRJeN.d.cts.map +0 -1
- package/dist/navigator-DLpMW73v.d.mts +0 -42
- package/dist/navigator-DLpMW73v.d.mts.map +0 -1
- package/dist/navigator-wsxMUGqK.d.cts +0 -42
- package/dist/navigator-wsxMUGqK.d.cts.map +0 -1
- package/dist/object-B3Rc0f80.d.mts +0 -392
- package/dist/object-B3Rc0f80.d.mts.map +0 -1
- package/dist/object-DyLgFijN.d.cts +0 -392
- package/dist/object-DyLgFijN.d.cts.map +0 -1
- package/dist/package-json-BYMmXu4B.d.mts +0 -261
- package/dist/package-json-BYMmXu4B.d.mts.map +0 -1
- package/dist/package-json-DMeUqEmW.d.cts +0 -261
- package/dist/package-json-DMeUqEmW.d.cts.map +0 -1
- package/dist/package-manager-PRcovqs-.d.mts +0 -6
- package/dist/package-manager-PRcovqs-.d.mts.map +0 -1
- package/dist/package-manager-tcG2TLVT.d.cts +0 -6
- package/dist/package-manager-tcG2TLVT.d.cts.map +0 -1
- package/dist/system-BxYi2_rE.d.mts +0 -5
- package/dist/system-BxYi2_rE.d.mts.map +0 -1
- package/dist/system-n1LPjzuJ.d.cts +0 -5
- package/dist/system-n1LPjzuJ.d.cts.map +0 -1
- package/dist/tsconfig-C6dWY2RO.d.cts +0 -803
- package/dist/tsconfig-C6dWY2RO.d.cts.map +0 -1
- package/dist/tsconfig-CUKA7cEN.d.mts +0 -803
- package/dist/tsconfig-CUKA7cEN.d.mts.map +0 -1
- package/dist/user-CkdO4wnf.d.mts +0 -29
- package/dist/user-CkdO4wnf.d.mts.map +0 -1
- package/dist/user-CovHR6Ne.d.cts +0 -29
- package/dist/user-CovHR6Ne.d.cts.map +0 -1
- package/dist/utilities-BVS-gcgS.d.mts +0 -51
- package/dist/utilities-BVS-gcgS.d.mts.map +0 -1
- package/dist/utilities-Jb4ggdM-.d.cts +0 -51
- package/dist/utilities-Jb4ggdM-.d.cts.map +0 -1
- package/dist/validations-C_7osVpS.d.mts +0 -21
- package/dist/validations-C_7osVpS.d.mts.map +0 -1
- package/dist/validations-CvwxY4RE.d.cts +0 -21
- package/dist/validations-CvwxY4RE.d.cts.map +0 -1
package/dist/base.d.cts
CHANGED
|
@@ -1,2 +1,331 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import { TypedArray } from "./array.cjs";
|
|
2
|
+
|
|
3
|
+
//#region src/base.d.ts
|
|
4
|
+
type SerializablePrimitive = null | undefined | string | number | boolean | bigint;
|
|
5
|
+
type Primitive = SerializablePrimitive | symbol;
|
|
6
|
+
/**
|
|
7
|
+
* Matches any primitive, `void`, `Date`, or `RegExp` value.
|
|
8
|
+
*/
|
|
9
|
+
type BuiltIns = Primitive | void | Date | RegExp;
|
|
10
|
+
/**
|
|
11
|
+
* Matches any non-primitive object
|
|
12
|
+
*/
|
|
13
|
+
type AtomicObject = Function | Promise<any> | Date | RegExp;
|
|
14
|
+
/** Determines if the passed value is of a specific type */
|
|
15
|
+
type TypeTester = (value: any) => boolean;
|
|
16
|
+
/**
|
|
17
|
+
* The interface for a type mapping (key =\> function) to use for {@link getType}.
|
|
18
|
+
* export * The key represents the name of the type. The function represents the {@link TypeTester | test method}.
|
|
19
|
+
* The map should be ordered by testing preference, with more specific tests first.
|
|
20
|
+
* If a test returns true, it is selected, and the key is returned as the type.
|
|
21
|
+
*/
|
|
22
|
+
type TypeMap = Record<string, TypeTester>;
|
|
23
|
+
declare const emptyObjectSymbol: unique symbol;
|
|
24
|
+
type FunctionOrValue<Value> = Value extends (() => infer X) ? X : Value;
|
|
25
|
+
/**
|
|
26
|
+
* A [[List]]
|
|
27
|
+
*
|
|
28
|
+
* @example
|
|
29
|
+
* ```ts
|
|
30
|
+
* type list0 = [1, 2, 3]
|
|
31
|
+
* type list1 = number[]
|
|
32
|
+
* ```
|
|
33
|
+
*
|
|
34
|
+
* @param A - its type
|
|
35
|
+
* @returns [[List]]
|
|
36
|
+
*/
|
|
37
|
+
type List<A = any> = ReadonlyArray<A>;
|
|
38
|
+
/**
|
|
39
|
+
* Alias to create a [[Function]]
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```ts
|
|
43
|
+
* import { FunctionLike } from '@stryke/types'
|
|
44
|
+
*
|
|
45
|
+
* type test0 = FunctionLike<[string, number], boolean>
|
|
46
|
+
* /// (args_0: string, args_1: number) => boolean
|
|
47
|
+
* ```
|
|
48
|
+
*
|
|
49
|
+
* @param P - parameters
|
|
50
|
+
* @param R - return type
|
|
51
|
+
* @returns [[Function]]
|
|
52
|
+
*/
|
|
53
|
+
type FunctionLike<P extends List = any, R$1 = any> = (...args: P) => R$1;
|
|
54
|
+
type AnyFunction = FunctionLike<any, any>;
|
|
55
|
+
type Nullish = undefined | null;
|
|
56
|
+
type Nullishable<T> = T | Nullish;
|
|
57
|
+
type NonNullishObject = object;
|
|
58
|
+
type NativeClass = abstract new (...args: any) => any;
|
|
59
|
+
type AnyNumber = number | number;
|
|
60
|
+
type AnyString = string | string;
|
|
61
|
+
type AnyBoolean = boolean | boolean;
|
|
62
|
+
type AnyArray = any[];
|
|
63
|
+
type PlainObject = Record<any, object>;
|
|
64
|
+
type AnyMap = Map<any, any>;
|
|
65
|
+
type AnyWeakMap = WeakMap<WeakKey, any>;
|
|
66
|
+
type EmptyArray = [];
|
|
67
|
+
interface EmptyObject {
|
|
68
|
+
[emptyObjectSymbol]?: never;
|
|
69
|
+
}
|
|
70
|
+
type Any = boolean | number | bigint | string | null | undefined | void | symbol | object | PlainObject | AnyArray | AnyMap | AnyWeakMap;
|
|
71
|
+
/**
|
|
72
|
+
* The valid types of the index for an `Indexable` type object
|
|
73
|
+
*/
|
|
74
|
+
type IndexType = string | number | symbol;
|
|
75
|
+
/**
|
|
76
|
+
* The declaration of a ***dictionary-type*** object with a specific type
|
|
77
|
+
*
|
|
78
|
+
* @see {@link Indexable}
|
|
79
|
+
* @see {@link IndexType}
|
|
80
|
+
* @see {@link Dictionary}
|
|
81
|
+
*/
|
|
82
|
+
type TypedIndexable<T> = Record<IndexType, T>;
|
|
83
|
+
/**
|
|
84
|
+
* The declaration of a ***dictionary-type*** object
|
|
85
|
+
*
|
|
86
|
+
* @see {@link TypedIndexable}
|
|
87
|
+
* @see {@link IndexType}
|
|
88
|
+
* @see {@link Dictionary}
|
|
89
|
+
*/
|
|
90
|
+
type Indexable = TypedIndexable<any>;
|
|
91
|
+
/**
|
|
92
|
+
* The declaration of a ***dictionary-type*** object with a specific type
|
|
93
|
+
*
|
|
94
|
+
* @see {@link Indexable}
|
|
95
|
+
* @see {@link IndexType}
|
|
96
|
+
* @see {@link TypedIndexable}
|
|
97
|
+
*/
|
|
98
|
+
type Dictionary<T> = Record<string, T>;
|
|
99
|
+
declare const EMPTY_STRING = "";
|
|
100
|
+
declare const NEWLINE_STRING = "\r\n";
|
|
101
|
+
declare const EMPTY_OBJECT: {};
|
|
102
|
+
type AnyCase<T extends IndexType> = string extends T ? string : T extends `${infer F1}${infer F2}${infer R}` ? `${Uppercase<F1> | Lowercase<F1>}${Uppercase<F2> | Lowercase<F2>}${AnyCase<R>}` : T extends `${infer F}${infer R}` ? `${Uppercase<F> | Lowercase<F>}${AnyCase<R>}` : typeof EMPTY_STRING;
|
|
103
|
+
type Newable<T> = new (..._args: never[]) => T;
|
|
104
|
+
interface Abstract<T> {
|
|
105
|
+
prototype: T;
|
|
106
|
+
}
|
|
107
|
+
interface Clonable<T> {
|
|
108
|
+
clone: () => T;
|
|
109
|
+
}
|
|
110
|
+
type MaybePromise<T> = T | Promise<T>;
|
|
111
|
+
type ReducerFunction<TState, TAction> = (state: TState, action: TAction) => TState;
|
|
112
|
+
declare const TYPE_ARGUMENTS = "Arguments";
|
|
113
|
+
declare const TYPE_ARRAY = "Array";
|
|
114
|
+
declare const TYPE_OBJECT = "Object";
|
|
115
|
+
declare const TYPE_MAP = "Map";
|
|
116
|
+
declare const TYPE_SET = "Set";
|
|
117
|
+
type Collection = IArguments | unknown[] | Map<unknown, unknown> | Record<string | number | symbol, unknown> | Set<unknown>;
|
|
118
|
+
type NonUndefined<T> = T extends undefined ? never : T;
|
|
119
|
+
type BrowserNativeObject = Date | File;
|
|
120
|
+
type DeepPartial<T> = T extends BrowserNativeObject | NestedValue ? T : { [K in keyof T]?: DeepPartial<T[K]> };
|
|
121
|
+
type Rollback = Record<string, (initialValue: any, currentValue: any) => any>;
|
|
122
|
+
/**
|
|
123
|
+
* Extract all required keys from the given type.
|
|
124
|
+
*
|
|
125
|
+
* @remarks
|
|
126
|
+
* This is useful when you want to create a new type that contains different type values for the required keys only or use the list of keys for validation purposes, etc...
|
|
127
|
+
*/
|
|
128
|
+
type RequiredKeysOf<BaseType extends object> = Exclude<{ [Key in keyof BaseType]: BaseType extends Record<Key, BaseType[Key]> ? Key : never }[keyof BaseType], undefined>;
|
|
129
|
+
/**
|
|
130
|
+
* Returns a boolean for whether the two given types are equal.
|
|
131
|
+
*
|
|
132
|
+
* @remarks
|
|
133
|
+
* Use-cases: If you want to make a conditional branch based on the result of a comparison of two types.
|
|
134
|
+
*
|
|
135
|
+
* @see https://github.com/microsoft/TypeScript/issues/27024#issuecomment-421529650
|
|
136
|
+
* @see https://stackoverflow.com/questions/68961864/how-does-the-equals-work-in-typescript/68963796#68963796
|
|
137
|
+
*/
|
|
138
|
+
type IsEqual<A, B> = (<G>() => G extends A ? 1 : 2) extends (<G>() => G extends B ? 1 : 2) ? true : false;
|
|
139
|
+
type Filter<KeyType$1, ExcludeType> = IsEqual<KeyType$1, ExcludeType> extends true ? never : KeyType$1 extends ExcludeType ? never : KeyType$1;
|
|
140
|
+
interface ExceptOptions {
|
|
141
|
+
/**
|
|
142
|
+
Disallow assigning non-specified properties.
|
|
143
|
+
Note that any omitted properties in the resulting type will be present in autocomplete as `undefined`.
|
|
144
|
+
@defaultValue false
|
|
145
|
+
*/
|
|
146
|
+
requireExactProps?: boolean;
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Create a type from an object type without certain keys.
|
|
150
|
+
*
|
|
151
|
+
* @remarks
|
|
152
|
+
* We recommend setting the `requireExactProps` option to `true`.
|
|
153
|
+
*
|
|
154
|
+
* This type is a stricter version of [`Omit`](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-3-5.html#the-omit-helper-type). The `Omit` type does not restrict the omitted keys to be keys present on the given type, while `Except` does. The benefits of a stricter type are avoiding typos and allowing the compiler to pick up on rename refactors automatically.
|
|
155
|
+
*
|
|
156
|
+
* This type was proposed to the TypeScript team, which declined it, saying they prefer that libraries implement stricter versions of the built-in types ([microsoft/TypeScript#30825](https://github.com/microsoft/TypeScript/issues/30825#issuecomment-523668235)).
|
|
157
|
+
*/
|
|
158
|
+
type Except<ObjectType, KeysType extends keyof ObjectType, Options extends ExceptOptions = {
|
|
159
|
+
requireExactProps: false;
|
|
160
|
+
}> = { [KeyType in keyof ObjectType as Filter<KeyType, KeysType>]: ObjectType[KeyType] } & (Options["requireExactProps"] extends true ? Partial<Record<KeysType, never>> : Record<string, never>);
|
|
161
|
+
/**
|
|
162
|
+
* Useful to flatten the type output to improve type hints shown in editors. And also to transform an interface into a type to aide with assignability.
|
|
163
|
+
*
|
|
164
|
+
* @remarks
|
|
165
|
+
* Sometimes it is desired to pass a value as a function argument that has a different type. At first inspection it may seem assignable, and then you discover it is not because the `value`'s type definition was defined as an interface. In the following example, `fn` requires an argument of type `Record<string, unknown>`. If the value is defined as a literal, then it is assignable. And if the `value` is defined as type using the `Simplify` utility the value is assignable. But if the `value` is defined as an interface, it is not assignable because the interface is not sealed and elsewhere a non-string property could be added to the interface.
|
|
166
|
+
*
|
|
167
|
+
* If the type definition must be an interface (perhaps it was defined in a third-party npm package), then the `value` can be defined as `const value: Simplify<SomeInterface> = ...`. Then `value` will be assignable to the `fn` argument. Or the `value` can be cast as `Simplify<SomeInterface>` if you can't re-declare the `value`.
|
|
168
|
+
*
|
|
169
|
+
* @see https://github.com/microsoft/TypeScript/issues/15300
|
|
170
|
+
*/
|
|
171
|
+
type Simplify<T> = { [KeyType in keyof T]: T[KeyType] } & {};
|
|
172
|
+
/**
|
|
173
|
+
* Create a type that makes the given keys required. The remaining keys are kept as is. The sister of the `SetOptional` type.
|
|
174
|
+
*
|
|
175
|
+
* @remarks
|
|
176
|
+
* Use-case: You want to define a single model where the only thing that changes is whether or not some of the keys are required.
|
|
177
|
+
*/
|
|
178
|
+
type SetRequired<BaseType, Keys extends keyof BaseType> = BaseType extends unknown ? Simplify<Except<BaseType, Keys> & Required<Pick<BaseType, Keys>>> : never;
|
|
179
|
+
declare const $NestedValue: unique symbol;
|
|
180
|
+
type NestedValue<TValue extends object = object> = {
|
|
181
|
+
[$NestedValue]: never;
|
|
182
|
+
} & TValue;
|
|
183
|
+
interface RefObject<T> {
|
|
184
|
+
current: T;
|
|
185
|
+
}
|
|
186
|
+
interface Identity<T = string> {
|
|
187
|
+
id: T;
|
|
188
|
+
}
|
|
189
|
+
interface Versioned {
|
|
190
|
+
version: number;
|
|
191
|
+
}
|
|
192
|
+
interface Sequenced {
|
|
193
|
+
/**
|
|
194
|
+
* The sequence number (version, or event counter, etc.) of the record
|
|
195
|
+
*/
|
|
196
|
+
sequence: number;
|
|
197
|
+
}
|
|
198
|
+
interface Typed {
|
|
199
|
+
/**
|
|
200
|
+
* The type of the record
|
|
201
|
+
*/
|
|
202
|
+
__type: string;
|
|
203
|
+
}
|
|
204
|
+
interface ClassTypeCheckable<T> extends Typed {
|
|
205
|
+
/**
|
|
206
|
+
* Run type check on the given value
|
|
207
|
+
* @param value - The value to check
|
|
208
|
+
* @returns True if the value is of the type of the class
|
|
209
|
+
*/
|
|
210
|
+
isTypeOf: (value: unknown) => value is T;
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* Matches non-recursive types.
|
|
214
|
+
*/
|
|
215
|
+
type NonRecursiveType = BuiltIns | Function | (new (...arguments_: any[]) => unknown);
|
|
216
|
+
type IsPrimitive<T> = [T] extends [Primitive] ? true : false;
|
|
217
|
+
type IsNever<T> = [T] extends [never] ? true : false;
|
|
218
|
+
type IsAny<T> = 0 extends 1 & T ? true : false;
|
|
219
|
+
type IsNull<T> = [T] extends [null] ? true : false;
|
|
220
|
+
type IsUndefined<T> = T extends undefined ? true : false;
|
|
221
|
+
type IsUnknown<T> = unknown extends T ? IsNull<T> extends false ? true : false : false;
|
|
222
|
+
type IsNullish<T> = IsNull<T> & IsUndefined<T>;
|
|
223
|
+
type IsFunction<T> = T extends AnyFunction ? true : false;
|
|
224
|
+
/**
|
|
225
|
+
* Declare locally scoped properties on `globalThis`.
|
|
226
|
+
*
|
|
227
|
+
* When defining a global variable in a declaration file is inappropriate, it can be helpful to define a `type` or `interface` (say `ExtraGlobals`) with the global variable and then cast `globalThis` via code like `globalThis as unknown as ExtraGlobals`.
|
|
228
|
+
*
|
|
229
|
+
* Instead of casting through `unknown`, you can update your `type` or `interface` to extend `GlobalThis` and then directly cast `globalThis`.
|
|
230
|
+
*
|
|
231
|
+
* @example
|
|
232
|
+
* ```
|
|
233
|
+
* import type { GlobalThis } from '@stryke/types';
|
|
234
|
+
*
|
|
235
|
+
* type ExtraGlobals = GlobalThis & {
|
|
236
|
+
* readonly GLOBAL_TOKEN: string;
|
|
237
|
+
* };
|
|
238
|
+
*
|
|
239
|
+
* (globalThis as ExtraGlobals).GLOBAL_TOKEN;
|
|
240
|
+
* ```
|
|
241
|
+
*/
|
|
242
|
+
type GlobalThis = typeof globalThis;
|
|
243
|
+
/**
|
|
244
|
+
* Matches a [`class`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes).
|
|
245
|
+
*/
|
|
246
|
+
interface Class<T, Arguments extends unknown[] = any[]> {
|
|
247
|
+
prototype: Pick<T, keyof T>;
|
|
248
|
+
new (...arguments_: Arguments): T;
|
|
249
|
+
}
|
|
250
|
+
/**
|
|
251
|
+
* Matches a [`class` constructor](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes).
|
|
252
|
+
*/
|
|
253
|
+
type Constructor<T, Arguments extends unknown[] = any[]> = new (...arguments_: Arguments) => T;
|
|
254
|
+
/**
|
|
255
|
+
* Matches an [`abstract class`](https://www.typescriptlang.org/docs/handbook/classes.html#abstract-classes).
|
|
256
|
+
*
|
|
257
|
+
* @privateRemarks
|
|
258
|
+
* We cannot use a `type` here because TypeScript throws: 'abstract' modifier cannot appear on a type member. (1070)
|
|
259
|
+
*/
|
|
260
|
+
interface AbstractClass<T, Arguments extends unknown[] = any[]> extends AbstractConstructor<T, Arguments> {
|
|
261
|
+
prototype: Pick<T, keyof T>;
|
|
262
|
+
}
|
|
263
|
+
/**
|
|
264
|
+
* Matches an [`abstract class`](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-4-2.html#abstract-construct-signatures) constructor.
|
|
265
|
+
*/
|
|
266
|
+
type AbstractConstructor<T, Arguments extends unknown[] = any[]> = abstract new (...arguments_: Arguments) => T;
|
|
267
|
+
/**
|
|
268
|
+
* Create a tuple type of the given length `<L>` and fill it with the given type `<Fill>`.
|
|
269
|
+
*
|
|
270
|
+
* If `<Fill>` is not provided, it will default to `unknown`.
|
|
271
|
+
*
|
|
272
|
+
* @see https://itnext.io/implementing-arithmetic-within-typescripts-type-system-a1ef140a6f6f
|
|
273
|
+
*/
|
|
274
|
+
type BuildTuple<L extends number, Fill = unknown, T extends readonly unknown[] = []> = T["length"] extends L ? T : BuildTuple<L, Fill, [...T, Fill]>;
|
|
275
|
+
/**
|
|
276
|
+
* Test if the given function has multiple call signatures.
|
|
277
|
+
*
|
|
278
|
+
* Needed to handle the case of a single call signature with properties.
|
|
279
|
+
*
|
|
280
|
+
* Multiple call signatures cannot currently be supported due to a TypeScript limitation.
|
|
281
|
+
* @see https://github.com/microsoft/TypeScript/issues/29732
|
|
282
|
+
*/
|
|
283
|
+
type HasMultipleCallSignatures<T extends (...arguments_: any[]) => unknown> = T extends {
|
|
284
|
+
(...arguments_: infer A): unknown;
|
|
285
|
+
(...arguments_: infer B): unknown;
|
|
286
|
+
} ? B extends A ? A extends B ? false : true : true : false;
|
|
287
|
+
type StructuredCloneablePrimitive = string | number | bigint | boolean | null | undefined | boolean | number | string;
|
|
288
|
+
type StructuredCloneableData = ArrayBuffer | DataView | Date | Error | RegExp | TypedArray | Blob | File;
|
|
289
|
+
type StructuredCloneableCollection = readonly StructuredCloneable[] | {
|
|
290
|
+
readonly [key: string]: StructuredCloneable;
|
|
291
|
+
readonly [key: number]: StructuredCloneable;
|
|
292
|
+
} | ReadonlyMap<StructuredCloneable, StructuredCloneable> | ReadonlySet<StructuredCloneable>;
|
|
293
|
+
/**
|
|
294
|
+
* Matches a value that can be losslessly cloned using `structuredClone`.
|
|
295
|
+
*
|
|
296
|
+
* Note:
|
|
297
|
+
* - Custom error types will be cloned as the base `Error` type
|
|
298
|
+
* - This type doesn't include types exclusive to the TypeScript DOM library (e.g. `DOMRect` and `VideoFrame`)
|
|
299
|
+
*
|
|
300
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Structured_clone_algorithm
|
|
301
|
+
*
|
|
302
|
+
* @example
|
|
303
|
+
* ```
|
|
304
|
+
* import type { StructuredCloneable } from '@stryke/types';
|
|
305
|
+
*
|
|
306
|
+
* class CustomClass {}
|
|
307
|
+
*
|
|
308
|
+
* // @ts-expect-error
|
|
309
|
+
* const error: StructuredCloneable = {
|
|
310
|
+
* custom: new CustomClass(),
|
|
311
|
+
* };
|
|
312
|
+
*
|
|
313
|
+
* structuredClone(error);
|
|
314
|
+
* //=> {custom: {}}
|
|
315
|
+
*
|
|
316
|
+
* const good: StructuredCloneable = {
|
|
317
|
+
* number: 3,
|
|
318
|
+
* date: new Date(),
|
|
319
|
+
* map: new Map<string, number>(),
|
|
320
|
+
* }
|
|
321
|
+
*
|
|
322
|
+
* good.map.set('key', 1);
|
|
323
|
+
*
|
|
324
|
+
* structuredClone(good);
|
|
325
|
+
* //=> {number: 3, date: Date(2022-10-17 22:22:35.920), map: Map {'key' -> 1}}
|
|
326
|
+
* ```
|
|
327
|
+
*/
|
|
328
|
+
type StructuredCloneable = StructuredCloneablePrimitive | StructuredCloneableData | StructuredCloneableCollection;
|
|
329
|
+
//#endregion
|
|
330
|
+
export { $NestedValue, Abstract, AbstractClass, AbstractConstructor, Any, AnyArray, AnyBoolean, AnyCase, AnyFunction, AnyMap, AnyNumber, AnyString, AnyWeakMap, AtomicObject, BrowserNativeObject, BuildTuple, BuiltIns, Class, ClassTypeCheckable, Clonable, Collection, Constructor, DeepPartial, Dictionary, EMPTY_OBJECT, EMPTY_STRING, EmptyArray, EmptyObject, Except, Filter, FunctionLike, FunctionOrValue, GlobalThis, HasMultipleCallSignatures, Identity, IndexType, Indexable, IsAny, IsEqual, IsFunction, IsNever, IsNull, IsNullish, IsPrimitive, IsUndefined, IsUnknown, List, MaybePromise, NEWLINE_STRING, NativeClass, NestedValue, Newable, NonNullishObject, NonRecursiveType, NonUndefined, Nullish, Nullishable, PlainObject, Primitive, ReducerFunction, RefObject, RequiredKeysOf, Rollback, Sequenced, SerializablePrimitive, SetRequired, Simplify, StructuredCloneable, TYPE_ARGUMENTS, TYPE_ARRAY, TYPE_MAP, TYPE_OBJECT, TYPE_SET, TypeMap, TypeTester, Typed, TypedIndexable, Versioned };
|
|
331
|
+
//# sourceMappingURL=base.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base.d.cts","names":[],"sources":["../src/base.ts"],"sourcesContent":[],"mappings":"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"}
|