@percepta/utils 0.1.10 → 0.1.11

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.
Files changed (169) hide show
  1. package/dist/config/getEnvConfig.cjs +32 -0
  2. package/dist/config/getEnvConfig.cjs.map +1 -0
  3. package/dist/config/getEnvConfig.d.cts +72 -0
  4. package/dist/config/getEnvConfig.d.cts.map +1 -0
  5. package/dist/config/getEnvConfig.d.ts +72 -0
  6. package/dist/config/getEnvConfig.d.ts.map +1 -0
  7. package/dist/config/getEnvConfig.js +31 -0
  8. package/dist/config/getEnvConfig.js.map +1 -0
  9. package/dist/config/index.d.cts +1 -0
  10. package/dist/config/index.d.ts +1 -0
  11. package/dist/index.cjs +16 -0
  12. package/dist/index.d.cts +8 -0
  13. package/dist/index.d.ts +8 -0
  14. package/dist/index.js +8 -0
  15. package/dist/utils/assertNever.cjs +8 -0
  16. package/dist/utils/assertNever.cjs.map +1 -0
  17. package/dist/utils/assertNever.d.cts +5 -0
  18. package/dist/utils/assertNever.d.cts.map +1 -0
  19. package/dist/utils/assertNever.d.ts +5 -0
  20. package/dist/utils/assertNever.d.ts.map +1 -0
  21. package/dist/utils/assertNever.js +8 -0
  22. package/dist/utils/assertNever.js.map +1 -0
  23. package/dist/utils/batchAsync.cjs +16 -0
  24. package/dist/utils/batchAsync.cjs.map +1 -0
  25. package/dist/utils/batchAsync.d.cts +5 -0
  26. package/dist/utils/batchAsync.d.cts.map +1 -0
  27. package/dist/utils/batchAsync.d.ts +5 -0
  28. package/dist/utils/batchAsync.d.ts.map +1 -0
  29. package/dist/utils/batchAsync.js +16 -0
  30. package/dist/utils/batchAsync.js.map +1 -0
  31. package/dist/utils/index.d.cts +6 -0
  32. package/dist/utils/index.d.ts +6 -0
  33. package/dist/utils/logNever.cjs +9 -0
  34. package/dist/utils/logNever.cjs.map +1 -0
  35. package/dist/utils/logNever.d.cts +6 -0
  36. package/dist/utils/logNever.d.cts.map +1 -0
  37. package/dist/utils/logNever.d.ts +6 -0
  38. package/dist/utils/logNever.d.ts.map +1 -0
  39. package/dist/utils/logNever.js +9 -0
  40. package/dist/utils/logNever.js.map +1 -0
  41. package/dist/utils/promiseAllValues.cjs +9 -0
  42. package/dist/utils/promiseAllValues.cjs.map +1 -0
  43. package/dist/utils/promiseAllValues.d.cts +6 -0
  44. package/dist/utils/promiseAllValues.d.cts.map +1 -0
  45. package/dist/utils/promiseAllValues.d.ts +6 -0
  46. package/dist/utils/promiseAllValues.d.ts.map +1 -0
  47. package/dist/utils/promiseAllValues.js +9 -0
  48. package/dist/utils/promiseAllValues.js.map +1 -0
  49. package/dist/utils/replaceAt.cjs +18 -0
  50. package/dist/utils/replaceAt.cjs.map +1 -0
  51. package/dist/{esnext/src/utils/replaceAt.d.ts → utils/replaceAt.d.cts} +5 -2
  52. package/dist/utils/replaceAt.d.cts.map +1 -0
  53. package/dist/{cjs/src/utils → utils}/replaceAt.d.ts +4 -1
  54. package/dist/utils/replaceAt.d.ts.map +1 -0
  55. package/dist/utils/replaceAt.js +18 -0
  56. package/dist/utils/replaceAt.js.map +1 -0
  57. package/dist/utils/zodKeyedTypeUnion.cjs +16 -0
  58. package/dist/utils/zodKeyedTypeUnion.cjs.map +1 -0
  59. package/dist/utils/zodKeyedTypeUnion.d.cts +18 -0
  60. package/dist/utils/zodKeyedTypeUnion.d.cts.map +1 -0
  61. package/dist/utils/zodKeyedTypeUnion.d.ts +18 -0
  62. package/dist/utils/zodKeyedTypeUnion.d.ts.map +1 -0
  63. package/dist/utils/zodKeyedTypeUnion.js +16 -0
  64. package/dist/utils/zodKeyedTypeUnion.js.map +1 -0
  65. package/package.json +27 -17
  66. package/dist/cjs/src/config/getEnvConfig.d.ts +0 -164
  67. package/dist/cjs/src/config/getEnvConfig.d.ts.map +0 -1
  68. package/dist/cjs/src/config/getEnvConfig.js +0 -30
  69. package/dist/cjs/src/config/getEnvConfig.js.map +0 -1
  70. package/dist/cjs/src/config/index.d.ts +0 -2
  71. package/dist/cjs/src/config/index.d.ts.map +0 -1
  72. package/dist/cjs/src/config/index.js +0 -18
  73. package/dist/cjs/src/config/index.js.map +0 -1
  74. package/dist/cjs/src/index.d.ts +0 -3
  75. package/dist/cjs/src/index.d.ts.map +0 -1
  76. package/dist/cjs/src/index.js +0 -19
  77. package/dist/cjs/src/index.js.map +0 -1
  78. package/dist/cjs/src/utils/__tests__/assertNever.test.d.ts +0 -2
  79. package/dist/cjs/src/utils/__tests__/assertNever.test.d.ts.map +0 -1
  80. package/dist/cjs/src/utils/__tests__/assertNever.test.js +0 -22
  81. package/dist/cjs/src/utils/__tests__/assertNever.test.js.map +0 -1
  82. package/dist/cjs/src/utils/__tests__/batchAsync.test.d.ts +0 -2
  83. package/dist/cjs/src/utils/__tests__/batchAsync.test.d.ts.map +0 -1
  84. package/dist/cjs/src/utils/__tests__/batchAsync.test.js +0 -47
  85. package/dist/cjs/src/utils/__tests__/batchAsync.test.js.map +0 -1
  86. package/dist/cjs/src/utils/assertNever.d.ts +0 -2
  87. package/dist/cjs/src/utils/assertNever.d.ts.map +0 -1
  88. package/dist/cjs/src/utils/assertNever.js +0 -7
  89. package/dist/cjs/src/utils/assertNever.js.map +0 -1
  90. package/dist/cjs/src/utils/batchAsync.d.ts +0 -2
  91. package/dist/cjs/src/utils/batchAsync.d.ts.map +0 -1
  92. package/dist/cjs/src/utils/batchAsync.js +0 -18
  93. package/dist/cjs/src/utils/batchAsync.js.map +0 -1
  94. package/dist/cjs/src/utils/index.d.ts +0 -7
  95. package/dist/cjs/src/utils/index.d.ts.map +0 -1
  96. package/dist/cjs/src/utils/index.js +0 -23
  97. package/dist/cjs/src/utils/index.js.map +0 -1
  98. package/dist/cjs/src/utils/logNever.d.ts +0 -3
  99. package/dist/cjs/src/utils/logNever.d.ts.map +0 -1
  100. package/dist/cjs/src/utils/logNever.js +0 -8
  101. package/dist/cjs/src/utils/logNever.js.map +0 -1
  102. package/dist/cjs/src/utils/promiseAllValues.d.ts +0 -6
  103. package/dist/cjs/src/utils/promiseAllValues.d.ts.map +0 -1
  104. package/dist/cjs/src/utils/promiseAllValues.js +0 -12
  105. package/dist/cjs/src/utils/promiseAllValues.js.map +0 -1
  106. package/dist/cjs/src/utils/replaceAt.d.ts.map +0 -1
  107. package/dist/cjs/src/utils/replaceAt.js +0 -17
  108. package/dist/cjs/src/utils/replaceAt.js.map +0 -1
  109. package/dist/cjs/src/utils/zodKeyedTypeUnion.d.ts +0 -17
  110. package/dist/cjs/src/utils/zodKeyedTypeUnion.d.ts.map +0 -1
  111. package/dist/cjs/src/utils/zodKeyedTypeUnion.js +0 -15
  112. package/dist/cjs/src/utils/zodKeyedTypeUnion.js.map +0 -1
  113. package/dist/cjs/tsconfig.tsbuildinfo +0 -1
  114. package/dist/cjs/vitest.config.d.ts +0 -3
  115. package/dist/cjs/vitest.config.d.ts.map +0 -1
  116. package/dist/cjs/vitest.config.js +0 -5
  117. package/dist/cjs/vitest.config.js.map +0 -1
  118. package/dist/esnext/src/config/getEnvConfig.d.ts +0 -164
  119. package/dist/esnext/src/config/getEnvConfig.d.ts.map +0 -1
  120. package/dist/esnext/src/config/getEnvConfig.js +0 -26
  121. package/dist/esnext/src/config/getEnvConfig.js.map +0 -1
  122. package/dist/esnext/src/config/index.d.ts +0 -2
  123. package/dist/esnext/src/config/index.d.ts.map +0 -1
  124. package/dist/esnext/src/config/index.js +0 -2
  125. package/dist/esnext/src/config/index.js.map +0 -1
  126. package/dist/esnext/src/index.d.ts +0 -3
  127. package/dist/esnext/src/index.d.ts.map +0 -1
  128. package/dist/esnext/src/index.js +0 -3
  129. package/dist/esnext/src/index.js.map +0 -1
  130. package/dist/esnext/src/utils/__tests__/assertNever.test.d.ts +0 -2
  131. package/dist/esnext/src/utils/__tests__/assertNever.test.d.ts.map +0 -1
  132. package/dist/esnext/src/utils/__tests__/assertNever.test.js +0 -20
  133. package/dist/esnext/src/utils/__tests__/assertNever.test.js.map +0 -1
  134. package/dist/esnext/src/utils/__tests__/batchAsync.test.d.ts +0 -2
  135. package/dist/esnext/src/utils/__tests__/batchAsync.test.d.ts.map +0 -1
  136. package/dist/esnext/src/utils/__tests__/batchAsync.test.js +0 -45
  137. package/dist/esnext/src/utils/__tests__/batchAsync.test.js.map +0 -1
  138. package/dist/esnext/src/utils/assertNever.d.ts +0 -2
  139. package/dist/esnext/src/utils/assertNever.d.ts.map +0 -1
  140. package/dist/esnext/src/utils/assertNever.js +0 -4
  141. package/dist/esnext/src/utils/assertNever.js.map +0 -1
  142. package/dist/esnext/src/utils/batchAsync.d.ts +0 -2
  143. package/dist/esnext/src/utils/batchAsync.d.ts.map +0 -1
  144. package/dist/esnext/src/utils/batchAsync.js +0 -15
  145. package/dist/esnext/src/utils/batchAsync.js.map +0 -1
  146. package/dist/esnext/src/utils/index.d.ts +0 -7
  147. package/dist/esnext/src/utils/index.d.ts.map +0 -1
  148. package/dist/esnext/src/utils/index.js +0 -7
  149. package/dist/esnext/src/utils/index.js.map +0 -1
  150. package/dist/esnext/src/utils/logNever.d.ts +0 -3
  151. package/dist/esnext/src/utils/logNever.d.ts.map +0 -1
  152. package/dist/esnext/src/utils/logNever.js +0 -5
  153. package/dist/esnext/src/utils/logNever.js.map +0 -1
  154. package/dist/esnext/src/utils/promiseAllValues.d.ts +0 -6
  155. package/dist/esnext/src/utils/promiseAllValues.d.ts.map +0 -1
  156. package/dist/esnext/src/utils/promiseAllValues.js +0 -9
  157. package/dist/esnext/src/utils/promiseAllValues.js.map +0 -1
  158. package/dist/esnext/src/utils/replaceAt.d.ts.map +0 -1
  159. package/dist/esnext/src/utils/replaceAt.js +0 -14
  160. package/dist/esnext/src/utils/replaceAt.js.map +0 -1
  161. package/dist/esnext/src/utils/zodKeyedTypeUnion.d.ts +0 -17
  162. package/dist/esnext/src/utils/zodKeyedTypeUnion.d.ts.map +0 -1
  163. package/dist/esnext/src/utils/zodKeyedTypeUnion.js +0 -12
  164. package/dist/esnext/src/utils/zodKeyedTypeUnion.js.map +0 -1
  165. package/dist/esnext/tsconfig.tsbuildinfo +0 -1
  166. package/dist/esnext/vitest.config.d.ts +0 -3
  167. package/dist/esnext/vitest.config.d.ts.map +0 -1
  168. package/dist/esnext/vitest.config.js +0 -3
  169. package/dist/esnext/vitest.config.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"vitest.config.d.ts","sourceRoot":"","sources":["../../vitest.config.ts"],"names":[],"mappings":";AAEA,wBAAsC"}
@@ -1,5 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const vitest_1 = require("@percepta/build/vitest");
4
- exports.default = (0, vitest_1.createVitestConfig)({});
5
- //# sourceMappingURL=vitest.config.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"vitest.config.js","sourceRoot":"","sources":["../../vitest.config.ts"],"names":[],"mappings":";;AAAA,mDAA4D;AAE5D,kBAAe,IAAA,2BAAkB,EAAC,EAAE,CAAC,CAAC"}
@@ -1,164 +0,0 @@
1
- import { z } from "zod";
2
- export declare const BASE_ENV_SCHEMA: z.ZodObject<{
3
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
4
- development: "development";
5
- production: "production";
6
- test: "test";
7
- }>>;
8
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
9
- debug: "debug";
10
- info: "info";
11
- warn: "warn";
12
- error: "error";
13
- }>>>;
14
- }, z.core.$strip>;
15
- export type BaseEnvConfig = z.infer<typeof BASE_ENV_SCHEMA>;
16
- export declare function createEnvConfig<TExtension extends z.ZodRawShape>(extensionSchema: z.ZodObject<TExtension>): {
17
- getEnvConfig: () => z.core.$InferObjectOutput<(("NODE_ENV" | "LOG_LEVEL") & keyof TExtension extends never ? {
18
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
19
- development: "development";
20
- production: "production";
21
- test: "test";
22
- }>>;
23
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
24
- debug: "debug";
25
- info: "info";
26
- warn: "warn";
27
- error: "error";
28
- }>>>;
29
- } & TExtension : ({
30
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
31
- development: "development";
32
- production: "production";
33
- test: "test";
34
- }>>;
35
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
36
- debug: "debug";
37
- info: "info";
38
- warn: "warn";
39
- error: "error";
40
- }>>>;
41
- } extends infer T_2 extends z.core.util.SomeObject ? { [K in keyof T_2 as K extends keyof TExtension ? never : K]: {
42
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
43
- development: "development";
44
- production: "production";
45
- test: "test";
46
- }>>;
47
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
48
- debug: "debug";
49
- info: "info";
50
- warn: "warn";
51
- error: "error";
52
- }>>>;
53
- }[K]; } : never) & { [K_1 in keyof TExtension]: TExtension[K_1]; }) extends infer T ? { [k in keyof T]: (("NODE_ENV" | "LOG_LEVEL") & keyof TExtension extends never ? {
54
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
55
- development: "development";
56
- production: "production";
57
- test: "test";
58
- }>>;
59
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
60
- debug: "debug";
61
- info: "info";
62
- warn: "warn";
63
- error: "error";
64
- }>>>;
65
- } & TExtension : ({
66
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
67
- development: "development";
68
- production: "production";
69
- test: "test";
70
- }>>;
71
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
72
- debug: "debug";
73
- info: "info";
74
- warn: "warn";
75
- error: "error";
76
- }>>>;
77
- } extends infer T_1 extends z.core.util.SomeObject ? { [K in keyof T_1 as K extends keyof TExtension ? never : K]: {
78
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
79
- development: "development";
80
- production: "production";
81
- test: "test";
82
- }>>;
83
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
84
- debug: "debug";
85
- info: "info";
86
- warn: "warn";
87
- error: "error";
88
- }>>>;
89
- }[K]; } : never) & { [K_1 in keyof TExtension]: TExtension[K_1]; })[k]; } : never, {}>;
90
- schema: z.ZodObject<(("NODE_ENV" | "LOG_LEVEL") & keyof TExtension extends never ? {
91
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
92
- development: "development";
93
- production: "production";
94
- test: "test";
95
- }>>;
96
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
97
- debug: "debug";
98
- info: "info";
99
- warn: "warn";
100
- error: "error";
101
- }>>>;
102
- } & TExtension : ({
103
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
104
- development: "development";
105
- production: "production";
106
- test: "test";
107
- }>>;
108
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
109
- debug: "debug";
110
- info: "info";
111
- warn: "warn";
112
- error: "error";
113
- }>>>;
114
- } extends infer T_2 extends z.core.util.SomeObject ? { [K in keyof T_2 as K extends keyof TExtension ? never : K]: {
115
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
116
- development: "development";
117
- production: "production";
118
- test: "test";
119
- }>>;
120
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
121
- debug: "debug";
122
- info: "info";
123
- warn: "warn";
124
- error: "error";
125
- }>>>;
126
- }[K]; } : never) & { [K_1 in keyof TExtension]: TExtension[K_1]; }) extends infer T ? { [k in keyof T]: (("NODE_ENV" | "LOG_LEVEL") & keyof TExtension extends never ? {
127
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
128
- development: "development";
129
- production: "production";
130
- test: "test";
131
- }>>;
132
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
133
- debug: "debug";
134
- info: "info";
135
- warn: "warn";
136
- error: "error";
137
- }>>>;
138
- } & TExtension : ({
139
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
140
- development: "development";
141
- production: "production";
142
- test: "test";
143
- }>>;
144
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
145
- debug: "debug";
146
- info: "info";
147
- warn: "warn";
148
- error: "error";
149
- }>>>;
150
- } extends infer T_1 extends z.core.util.SomeObject ? { [K in keyof T_1 as K extends keyof TExtension ? never : K]: {
151
- NODE_ENV: z.ZodDefault<z.ZodEnum<{
152
- development: "development";
153
- production: "production";
154
- test: "test";
155
- }>>;
156
- LOG_LEVEL: z.ZodDefault<z.ZodPipe<z.ZodString, z.ZodEnum<{
157
- debug: "debug";
158
- info: "info";
159
- warn: "warn";
160
- error: "error";
161
- }>>>;
162
- }[K]; } : never) & { [K_1 in keyof TExtension]: TExtension[K_1]; })[k]; } : never, z.core.$strip>;
163
- };
164
- //# sourceMappingURL=getEnvConfig.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getEnvConfig.d.ts","sourceRoot":"","sources":["../../../../src/config/getEnvConfig.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,eAAO,MAAM,eAAe;;;;;;;;;;;;iBAS1B,CAAC;AAEH,MAAM,MAAM,aAAa,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,eAAe,CAAC,CAAC;AAG5D,wBAAgB,eAAe,CAAC,UAAU,SAAS,CAAC,CAAC,WAAW,EAC9D,eAAe,EAAE,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAezC"}
@@ -1,26 +0,0 @@
1
- // @percepta/config/src/createEnvConfig.ts
2
- import { z } from "zod";
3
- // Base schema that all apps get
4
- export const BASE_ENV_SCHEMA = z.object({
5
- NODE_ENV: z
6
- .enum(["development", "production", "test"])
7
- .default("development"),
8
- LOG_LEVEL: z
9
- .string()
10
- .toLowerCase()
11
- .pipe(z.enum(["debug", "info", "warn", "error"]))
12
- .default("info"),
13
- });
14
- // Factory that creates a configured getEnvConfig
15
- export function createEnvConfig(extensionSchema) {
16
- const schema = BASE_ENV_SCHEMA.extend(extensionSchema.shape);
17
- let _cached;
18
- function getEnvConfig() {
19
- if (_cached == null) {
20
- _cached = schema.parse(process.env);
21
- }
22
- return _cached;
23
- }
24
- return { getEnvConfig, schema };
25
- }
26
- //# sourceMappingURL=getEnvConfig.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getEnvConfig.js","sourceRoot":"","sources":["../../../../src/config/getEnvConfig.ts"],"names":[],"mappings":"AAAA,0CAA0C;AAC1C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,gCAAgC;AAChC,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,CAAC,MAAM,CAAC;IACtC,QAAQ,EAAE,CAAC;SACR,IAAI,CAAC,CAAC,aAAa,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;SAC3C,OAAO,CAAC,aAAa,CAAC;IACzB,SAAS,EAAE,CAAC;SACT,MAAM,EAAE;SACR,WAAW,EAAE;SACb,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;SAChD,OAAO,CAAC,MAAM,CAAC;CACnB,CAAC,CAAC;AAIH,iDAAiD;AACjD,MAAM,UAAU,eAAe,CAC7B,eAAwC;IAExC,MAAM,MAAM,GAAG,eAAe,CAAC,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IAG7D,IAAI,OAA2B,CAAC;IAEhC,SAAS,YAAY;QACnB,IAAI,OAAO,IAAI,IAAI,EAAE,CAAC;YACpB,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACtC,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,CAAC;AAClC,CAAC"}
@@ -1,2 +0,0 @@
1
- export * from "./getEnvConfig";
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/config/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC"}
@@ -1,2 +0,0 @@
1
- export * from "./getEnvConfig";
2
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/config/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC"}
@@ -1,3 +0,0 @@
1
- export * from "./utils";
2
- export * from "./config";
3
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC"}
@@ -1,3 +0,0 @@
1
- export * from "./utils";
2
- export * from "./config";
3
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=assertNever.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"assertNever.test.d.ts","sourceRoot":"","sources":["../../../../../src/utils/__tests__/assertNever.test.ts"],"names":[],"mappings":""}
@@ -1,20 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { assertNever } from "../assertNever";
3
- describe(assertNever, () => {
4
- it("throws an error on unhandled types", () => {
5
- function getInvalidType() {
6
- return 0;
7
- }
8
- expect(() => {
9
- const invalidType = getInvalidType();
10
- switch (invalidType) {
11
- case 1:
12
- case 2:
13
- return;
14
- default:
15
- assertNever(invalidType);
16
- }
17
- }).toThrow();
18
- });
19
- });
20
- //# sourceMappingURL=assertNever.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"assertNever.test.js","sourceRoot":"","sources":["../../../../../src/utils/__tests__/assertNever.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAG5C,SAAS,cAAc;YACrB,OAAO,CAAU,CAAC;QACpB,CAAC;QAED,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;YACrC,QAAQ,WAAW,EAAE,CAAC;gBACpB,KAAK,CAAC,CAAC;gBACP,KAAK,CAAC;oBACJ,OAAO;gBACT;oBACE,WAAW,CAAC,WAAW,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=batchAsync.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"batchAsync.test.d.ts","sourceRoot":"","sources":["../../../../../src/utils/__tests__/batchAsync.test.ts"],"names":[],"mappings":""}
@@ -1,45 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { batchAsync } from "../batchAsync";
3
- describe(batchAsync, () => {
4
- it("processes all items and returns results in order", async () => {
5
- const values = [1, 2, 3, 4, 5];
6
- const result = await batchAsync(values, 2, (v) => Promise.resolve(v * 10));
7
- expect(result).toEqual([10, 20, 30, 40, 50]);
8
- });
9
- it("passes the original index to the iteratee", async () => {
10
- const values = ["a", "b", "c"];
11
- const indices = [];
12
- await batchAsync(values, 2, (_v, index) => {
13
- indices.push(index);
14
- return Promise.resolve();
15
- });
16
- expect(indices).toEqual([0, 1, 2]);
17
- });
18
- it("processes items in batches of the given size", async () => {
19
- const concurrencyLog = [];
20
- let inFlight = 0;
21
- const values = [1, 2, 3, 4, 5];
22
- await batchAsync(values, 2, async (v) => {
23
- inFlight++;
24
- concurrencyLog.push(inFlight);
25
- await new Promise((resolve) => setTimeout(resolve, 10));
26
- inFlight--;
27
- return v;
28
- });
29
- // Each batch should have at most 2 in flight
30
- expect(Math.max(...concurrencyLog)).toBeLessThanOrEqual(2);
31
- });
32
- it("returns an empty array for empty input", async () => {
33
- const result = await batchAsync([], 5, (v) => Promise.resolve(v));
34
- expect(result).toEqual([]);
35
- });
36
- it("handles batch size larger than input", async () => {
37
- const result = await batchAsync([1, 2], 100, (v) => Promise.resolve(v * 2));
38
- expect(result).toEqual([2, 4]);
39
- });
40
- it("throws when batchSize is 0 or negative", async () => {
41
- await expect(batchAsync([1], 0, (v) => Promise.resolve(v))).rejects.toThrow("batchSize must be greater than 0");
42
- await expect(batchAsync([1], -1, (v) => Promise.resolve(v))).rejects.toThrow("batchSize must be greater than 0");
43
- });
44
- });
45
- //# sourceMappingURL=batchAsync.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"batchAsync.test.js","sourceRoot":"","sources":["../../../../../src/utils/__tests__/batchAsync.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACxB,EAAE,CAAC,kDAAkD,EAAE,KAAK,IAAI,EAAE;QAChE,MAAM,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/B,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QAC3E,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QACzD,MAAM,MAAM,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAC/B,MAAM,OAAO,GAAa,EAAE,CAAC;QAC7B,MAAM,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE;YACxC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACpB,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;QAC5D,MAAM,cAAc,GAAa,EAAE,CAAC;QACpC,IAAI,QAAQ,GAAG,CAAC,CAAC;QAEjB,MAAM,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/B,MAAM,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YACtC,QAAQ,EAAE,CAAC;YACX,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC9B,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;YACxD,QAAQ,EAAE,CAAC;YACX,OAAO,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;QAEH,6CAA6C;QAC7C,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAClE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC5E,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CACzE,kCAAkC,CACnC,CAAC;QACF,MAAM,MAAM,CACV,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAC/C,CAAC,OAAO,CAAC,OAAO,CAAC,kCAAkC,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,2 +0,0 @@
1
- export declare function assertNever(value: never): never;
2
- //# sourceMappingURL=assertNever.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"assertNever.d.ts","sourceRoot":"","sources":["../../../../src/utils/assertNever.ts"],"names":[],"mappings":"AAAA,wBAAgB,WAAW,CAAC,KAAK,EAAE,KAAK,GAAG,KAAK,CAE/C"}
@@ -1,4 +0,0 @@
1
- export function assertNever(value) {
2
- throw new Error("Unexpected value.", { cause: value });
3
- }
4
- //# sourceMappingURL=assertNever.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"assertNever.js","sourceRoot":"","sources":["../../../../src/utils/assertNever.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,WAAW,CAAC,KAAY;IACtC,MAAM,IAAI,KAAK,CAAC,mBAAmB,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;AACzD,CAAC"}
@@ -1,2 +0,0 @@
1
- export declare function batchAsync<TValue, TReturn>(values: TValue[], batchSize: number, iteratee: (value: TValue, index: number) => Promise<TReturn>): Promise<TReturn[]>;
2
- //# sourceMappingURL=batchAsync.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"batchAsync.d.ts","sourceRoot":"","sources":["../../../../src/utils/batchAsync.ts"],"names":[],"mappings":"AAEA,wBAAsB,UAAU,CAAC,MAAM,EAAE,OAAO,EAC9C,MAAM,EAAE,MAAM,EAAE,EAChB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,GAC3D,OAAO,CAAC,OAAO,EAAE,CAAC,CAgBpB"}
@@ -1,15 +0,0 @@
1
- import { chunk, flatten } from "lodash-es";
2
- export async function batchAsync(values, batchSize, iteratee) {
3
- if (batchSize <= 0) {
4
- throw new Error("batchSize must be greater than 0");
5
- }
6
- const results = [];
7
- const valuesWithIndex = values.map((value, index) => [value, index]);
8
- const chunkedValues = chunk(valuesWithIndex, batchSize);
9
- for (const chunkGroup of chunkedValues) {
10
- const chunkResults = await Promise.all(chunkGroup.map(([value, index]) => iteratee(value, index)));
11
- results.push(chunkResults);
12
- }
13
- return flatten(results);
14
- }
15
- //# sourceMappingURL=batchAsync.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"batchAsync.js","sourceRoot":"","sources":["../../../../src/utils/batchAsync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAE3C,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,MAAgB,EAChB,SAAiB,EACjB,QAA4D;IAE5D,IAAI,SAAS,IAAI,CAAC,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;IACtD,CAAC;IACD,MAAM,OAAO,GAAgB,EAAE,CAAC;IAChC,MAAM,eAAe,GAAG,MAAM,CAAC,GAAG,CAChC,CAAC,KAAK,EAAE,KAAK,EAAkC,EAAE,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,CACjE,CAAC;IACF,MAAM,aAAa,GAAG,KAAK,CAAC,eAAe,EAAE,SAAS,CAAC,CAAC;IACxD,KAAK,MAAM,UAAU,IAAI,aAAa,EAAE,CAAC;QACvC,MAAM,YAAY,GAAG,MAAM,OAAO,CAAC,GAAG,CACpC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAC3D,CAAC;QACF,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7B,CAAC;IACD,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC;AAC1B,CAAC"}
@@ -1,7 +0,0 @@
1
- export * from "./assertNever";
2
- export * from "./batchAsync";
3
- export * from "./logNever";
4
- export * from "./promiseAllValues";
5
- export * from "./replaceAt";
6
- export * from "./zodKeyedTypeUnion";
7
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,qBAAqB,CAAC"}
@@ -1,7 +0,0 @@
1
- export * from "./assertNever";
2
- export * from "./batchAsync";
3
- export * from "./logNever";
4
- export * from "./promiseAllValues";
5
- export * from "./replaceAt";
6
- export * from "./zodKeyedTypeUnion";
7
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,qBAAqB,CAAC"}
@@ -1,3 +0,0 @@
1
- export declare function logNever(value: never): void;
2
- export declare function logNever<TReturn>(value: never, returnValue: TReturn): TReturn;
3
- //# sourceMappingURL=logNever.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"logNever.d.ts","sourceRoot":"","sources":["../../../../src/utils/logNever.ts"],"names":[],"mappings":"AAAA,wBAAgB,QAAQ,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;AAC7C,wBAAgB,QAAQ,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,OAAO,GAAG,OAAO,CAAC"}
@@ -1,5 +0,0 @@
1
- export function logNever(value, returnValue) {
2
- console.error("Unexpected value.", value);
3
- return returnValue;
4
- }
5
- //# sourceMappingURL=logNever.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"logNever.js","sourceRoot":"","sources":["../../../../src/utils/logNever.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,QAAQ,CAAC,KAAY,EAAE,WAAqB;IAC1D,OAAO,CAAC,KAAK,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC;IAC1C,OAAO,WAAW,CAAC;AACrB,CAAC"}
@@ -1,6 +0,0 @@
1
- type PromiseObject<T> = {
2
- [K in keyof T]: Promise<T[K]>;
3
- };
4
- export declare function promiseAllValues<T>(promiseObject: PromiseObject<T>): Promise<T>;
5
- export {};
6
- //# sourceMappingURL=promiseAllValues.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"promiseAllValues.d.ts","sourceRoot":"","sources":["../../../../src/utils/promiseAllValues.ts"],"names":[],"mappings":"AAEA,KAAK,aAAa,CAAC,CAAC,IAAI;KACrB,CAAC,IAAI,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;CAC9B,CAAC;AAEF,wBAAsB,gBAAgB,CAAC,CAAC,EACtC,aAAa,EAAE,aAAa,CAAC,CAAC,CAAC,GAC9B,OAAO,CAAC,CAAC,CAAC,CAWZ"}
@@ -1,9 +0,0 @@
1
- import { fromPairs } from "lodash-es";
2
- export async function promiseAllValues(promiseObject) {
3
- const results = await Promise.all(Object.entries(promiseObject).map(async ([key, promise]) => [
4
- key,
5
- await promise,
6
- ]));
7
- return fromPairs(results);
8
- }
9
- //# sourceMappingURL=promiseAllValues.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"promiseAllValues.js","sourceRoot":"","sources":["../../../../src/utils/promiseAllValues.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAMtC,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,aAA+B;IAE/B,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,GAAG,CAC/B,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,GAAG,CAC/B,KAAK,EAAE,CAAC,GAAG,EAAE,OAAO,CAAC,EAA8B,EAAE,CAAC;QACpD,GAAG;QACH,MAAM,OAAO;KACd,CACF,CACF,CAAC;IAEF,OAAO,SAAS,CAAC,OAAO,CAAM,CAAC;AACjC,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"replaceAt.d.ts","sourceRoot":"","sources":["../../../../src/utils/replaceAt.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,wBAAgB,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,CAAC,EAAE,CAIrE"}
@@ -1,14 +0,0 @@
1
- /**
2
- * Returns a new array with the element at the specified index replaced.
3
- *
4
- * @param array The source array
5
- * @param index The index of the element to replace
6
- * @param value The new value to insert at the index
7
- * @returns A new array with the replacement applied
8
- */
9
- export function replaceAt(array, index, value) {
10
- const newArray = [...array];
11
- newArray[index] = value;
12
- return newArray;
13
- }
14
- //# sourceMappingURL=replaceAt.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"replaceAt.js","sourceRoot":"","sources":["../../../../src/utils/replaceAt.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,MAAM,UAAU,SAAS,CAAI,KAAU,EAAE,KAAa,EAAE,KAAQ;IAC9D,MAAM,QAAQ,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;IAC5B,QAAQ,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;IACxB,OAAO,QAAQ,CAAC;AAClB,CAAC"}
@@ -1,17 +0,0 @@
1
- import { type KeyedTypeUnion, type ValueForTypeKey } from "keyed-type-union";
2
- import { z } from "zod";
3
- type SchemasByType<TTypeUnion extends KeyedTypeUnion<Record<string, unknown>, TTypeKey>, TTypeKey extends string = "type"> = {
4
- [TType in TTypeUnion[TTypeKey]]: z.ZodType<ValueForTypeKey<TTypeUnion, TType, TTypeKey>>;
5
- };
6
- /**
7
- * Creates a Zod schema for a discriminated union of type-union types.
8
- * We can use this util alongside keyed-type-union for stricter type union patterns.
9
- *
10
- * @param schemasByType A record of type keys to their corresponding Zod schemas.
11
- * @param typeKey The optional key used to discriminate between the different types in the union.
12
- * @returns A Zod schema for the discriminated union.
13
- */
14
- export declare function zodKeyedTypeUnion<TTypeUnion extends KeyedTypeUnion<Record<string, unknown>>>(schemasByType: SchemasByType<TTypeUnion>): z.ZodType<TTypeUnion>;
15
- export declare function zodKeyedTypeUnion<TTypeUnion extends KeyedTypeUnion<Record<string, unknown>, TTypeKey>, TTypeKey extends string>(schemasByType: SchemasByType<TTypeUnion, TTypeKey>, typeKey: TTypeKey): z.ZodType<TTypeUnion>;
16
- export {};
17
- //# sourceMappingURL=zodKeyedTypeUnion.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"zodKeyedTypeUnion.d.ts","sourceRoot":"","sources":["../../../../src/utils/zodKeyedTypeUnion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAC7E,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,KAAK,aAAa,CAChB,UAAU,SAAS,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,QAAQ,CAAC,EACpE,QAAQ,SAAS,MAAM,GAAG,MAAM,IAC9B;KACD,KAAK,IAAI,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,CACxC,eAAe,CAAC,UAAU,EAAE,KAAK,EAAE,QAAQ,CAAC,CAC7C;CACF,CAAC;AAEF;;;;;;;GAOG;AACH,wBAAgB,iBAAiB,CAC/B,UAAU,SAAS,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,EAC1D,aAAa,EAAE,aAAa,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;AACnE,wBAAgB,iBAAiB,CAC/B,UAAU,SAAS,cAAc,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,QAAQ,CAAC,EACpE,QAAQ,SAAS,MAAM,EAEvB,aAAa,EAAE,aAAa,CAAC,UAAU,EAAE,QAAQ,CAAC,EAClD,OAAO,EAAE,QAAQ,GAChB,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC"}
@@ -1,12 +0,0 @@
1
- import { z } from "zod";
2
- export function zodKeyedTypeUnion(schemasByType, typeKey = "type") {
3
- /**
4
- * There are a lot of casts here because of our fancy generics.
5
- * We won't worry about them for now; we'll just use our tests to ensure runtime safety.
6
- */
7
- return z.discriminatedUnion(typeKey, Object.entries(schemasByType).map(([type, schema]) => z.object({
8
- [typeKey]: z.literal(type),
9
- [type]: schema,
10
- })));
11
- }
12
- //# sourceMappingURL=zodKeyedTypeUnion.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"zodKeyedTypeUnion.js","sourceRoot":"","sources":["../../../../src/utils/zodKeyedTypeUnion.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AA6BxB,MAAM,UAAU,iBAAiB,CAI/B,aAAkD,EAClD,UAAoB,MAAe;IAEnC;;;OAGG;IACH,OAAO,CAAC,CAAC,kBAAkB,CACzB,OAAO,EACP,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,EAAE,CACnD,CAAC,CAAC,MAAM,CAAC;QACP,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;QAC1B,CAAC,IAAI,CAAC,EAAE,MAAe;KACxB,CAAC,CACM,CACF,CAAC;AACb,CAAC"}