@readyfor/api-client-base 1.22.0 → 1.22.1-pr1285.b385439

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 (57) hide show
  1. package/dist/_virtual/_rolldown/runtime.js +23 -0
  2. package/dist/apiClientConfigStore-CNRWwVM3.mjs +86 -0
  3. package/dist/apiClientConfigStore.d.ts +11 -10
  4. package/dist/apiClientConfigStore.js +10 -37
  5. package/dist/apiError.d.ts +24 -25
  6. package/dist/apiError.js +68 -95
  7. package/dist/fetcher.d.ts +8 -7
  8. package/dist/fetcher.js +57 -125
  9. package/dist/index.d.ts +10 -10
  10. package/dist/index.js +31 -38
  11. package/dist/index.mjs +146 -62
  12. package/dist/react/ApiClientConfigProvider.d.ts +10 -9
  13. package/dist/react/ApiClientConfigProvider.js +24 -41
  14. package/dist/react/index.d.ts +4 -7
  15. package/dist/react/index.js +10 -26
  16. package/dist/react/index.mjs +61 -23
  17. package/dist/react/swr.d.ts +10 -9
  18. package/dist/react/swr.js +24 -37
  19. package/dist/react/useApiClientConfig.d.ts +5 -5
  20. package/dist/react/useApiClientConfig.js +18 -50
  21. package/dist/requestUrl.d.ts +3 -2
  22. package/dist/requestUrl.js +14 -49
  23. package/dist/store.d.ts +6 -5
  24. package/dist/store.js +20 -43
  25. package/dist/types.d.ts +5 -11
  26. package/dist/types.js +0 -16
  27. package/dist/utils/headersInit.d.ts +3 -2
  28. package/dist/utils/headersInit.js +45 -49
  29. package/dist/utils/requestInit.d.ts +10 -3
  30. package/dist/utils/requestInit.js +14 -31
  31. package/dist/zod.d.ts +4 -3
  32. package/dist/zod.js +6 -30
  33. package/package.json +2 -19
  34. package/dist/apiClientConfigStore.mjs +0 -13
  35. package/dist/apiError.mjs +0 -19
  36. package/dist/chunk-3SEO7S3Q.mjs +0 -23
  37. package/dist/chunk-5JS6U5IM.mjs +0 -37
  38. package/dist/chunk-DH33ZDBG.mjs +0 -19
  39. package/dist/chunk-FNLUAQWC.mjs +0 -80
  40. package/dist/chunk-GD4RTKUU.mjs +0 -22
  41. package/dist/chunk-JCZWXJBU.mjs +0 -10
  42. package/dist/chunk-NOC6G3HZ.mjs +0 -21
  43. package/dist/chunk-NYICHGY2.mjs +0 -30
  44. package/dist/chunk-OVR3ZT2S.mjs +0 -118
  45. package/dist/chunk-QXFPBYPL.mjs +0 -25
  46. package/dist/chunk-TZUKIYFN.mjs +0 -14
  47. package/dist/chunk-WBQAMGXK.mjs +0 -0
  48. package/dist/fetcher.mjs +0 -20
  49. package/dist/react/ApiClientConfigProvider.mjs +0 -13
  50. package/dist/react/swr.mjs +0 -6
  51. package/dist/react/useApiClientConfig.mjs +0 -16
  52. package/dist/requestUrl.mjs +0 -10
  53. package/dist/store.mjs +0 -6
  54. package/dist/types.mjs +0 -1
  55. package/dist/utils/headersInit.mjs +0 -8
  56. package/dist/utils/requestInit.mjs +0 -7
  57. package/dist/zod.mjs +0 -8
@@ -0,0 +1,23 @@
1
+ //#region \0rolldown/runtime.js
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from === "object" || typeof from === "function") for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) {
10
+ key = keys[i];
11
+ if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {
12
+ get: ((k) => from[k]).bind(null, key),
13
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
14
+ });
15
+ }
16
+ return to;
17
+ };
18
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
19
+ value: mod,
20
+ enumerable: true
21
+ }) : target, mod));
22
+ //#endregion
23
+ exports.__toESM = __toESM;
@@ -0,0 +1,86 @@
1
+ //#region src/store.ts
2
+ const createStore = (initialState) => {
3
+ let state = initialState;
4
+ const listeners = /* @__PURE__ */ new Set();
5
+ const getState = () => state;
6
+ const setState = (fn) => {
7
+ state = fn(state);
8
+ listeners.forEach((listener) => listener());
9
+ };
10
+ const subscribe = (listener) => {
11
+ listeners.add(listener);
12
+ return () => listeners.delete(listener);
13
+ };
14
+ return {
15
+ getState,
16
+ setState,
17
+ subscribe
18
+ };
19
+ };
20
+ //#endregion
21
+ //#region src/utils/headersInit.ts
22
+ /**
23
+ * 二つのHeadersInitの情報を元に、新たなHeadersInitを作成する
24
+ *
25
+ * Set-Cookieヘッダーは両方のHeadersInitから取得し、マージ後のHeadersに追加される。
26
+ * それ以外のヘッダーは、後勝ちの形式で新たなHeadersInitにマージされる。
27
+ *
28
+ * ヘッダーを削除する仕組みなどは非対応。
29
+ *
30
+ * Set-Cookieを特別扱いするのは、Fetch APIの仕様に基づいている。
31
+ * https://fetch.spec.whatwg.org/#terminology-headers
32
+ *
33
+ * @param baseHeadersInit 元となるHeadersInit
34
+ * @param overrideHeadersInit 上書きしたいヘッダーを含むHeadersInit。
35
+ */
36
+ const mergeHeadersInit = (baseHeadersInit, overrideHeadersInit) => {
37
+ const base = new Headers(baseHeadersInit);
38
+ const override = new Headers(overrideHeadersInit);
39
+ const setCookies = base.getSetCookie().concat(override.getSetCookie());
40
+ base.delete("set-cookie");
41
+ override.delete("set-cookie");
42
+ const mergedHeaders = new Headers({
43
+ ...Object.fromEntries(base),
44
+ ...Object.fromEntries(override)
45
+ });
46
+ setCookies.forEach((cookie) => {
47
+ mergedHeaders.append("set-cookie", cookie);
48
+ });
49
+ return mergedHeaders;
50
+ };
51
+ /**
52
+ * OpenAPI から生成されたヘッダーオブジェクトを HeadersInit に変換する
53
+ *
54
+ * OpenAPI のヘッダーパラメータは boolean や number などの型を持つことがあるが、
55
+ * HTTP ヘッダーは文字列のみを受け付けるため、値を文字列に変換する。
56
+ * undefined の値は除外される。
57
+ *
58
+ * @param headers OpenAPI から生成されたヘッダーオブジェクト
59
+ * @returns HeadersInit として使用可能なオブジェクト
60
+ */
61
+ const toHeadersInit = (headers) => {
62
+ const result = {};
63
+ for (const [key, value] of Object.entries(headers)) if (value !== void 0) result[key] = String(value);
64
+ return result;
65
+ };
66
+ //#endregion
67
+ //#region src/utils/requestInit.ts
68
+ /**
69
+ * 第一引数と第二引数のequestInitをマージした新たなRequestInitを返す。
70
+ * 同じフィールドが存在する場合、第二引数の値で上書きされる。
71
+ * ただし、`headers`フィールドに関しては、`base`と`override`両方に有効なHeadersInitがある場合に限り、
72
+ * `mergeHeadersInit`を使用してヘッダーの内容をマージする
73
+ */
74
+ const mergeRequestInit = ({ headers: baseHeaders, ...base }, { headers: overrideHeaders, ...override }) => ({
75
+ ...base,
76
+ ...override,
77
+ headers: baseHeaders === void 0 ? overrideHeaders : overrideHeaders === void 0 ? baseHeaders : mergeHeadersInit(baseHeaders, overrideHeaders)
78
+ });
79
+ const store = globalThis[Symbol.for("@readyfor/api-client-base/config")] ??= createStore({});
80
+ const setApiClientConfig = (config) => store.setState(() => config);
81
+ const buildRequestInitWithDefaultConfig = (customRequestInit = {}) => {
82
+ const { defaultRequestInit = {} } = store.getState();
83
+ return mergeRequestInit(defaultRequestInit, customRequestInit);
84
+ };
85
+ //#endregion
86
+ export { mergeHeadersInit as a, mergeRequestInit as i, setApiClientConfig as n, toHeadersInit as o, store as r, createStore as s, buildRequestInitWithDefaultConfig as t };
@@ -1,22 +1,23 @@
1
- import { Store } from './store.js';
1
+ import { Store } from "./store.js";
2
2
 
3
+ //#region src/apiClientConfigStore.d.ts
3
4
  type DeserializeResponseConfig = {
4
- forceDeserializeResponse?: false;
5
+ forceDeserializeResponse?: false;
5
6
  } | {
6
- forceDeserializeResponse: true;
7
- onFailedDeserializeResponse: (input: RequestInfo, error: Error) => void;
7
+ forceDeserializeResponse: true;
8
+ onFailedDeserializeResponse: (input: RequestInfo, error: Error) => void;
8
9
  };
9
10
  type LoggingConfig = {
10
- showsSchemaParseError?: boolean;
11
+ showsSchemaParseError?: boolean;
11
12
  };
12
13
  type RequestConfig = {
13
- hostName?: string | ((path: string) => string);
14
- defaultRequestInit?: RequestInit;
15
- onError?: (error: unknown) => void;
14
+ hostName?: string | ((path: string) => string);
15
+ defaultRequestInit?: RequestInit;
16
+ onError?: (error: unknown) => void;
16
17
  };
17
18
  type Config = RequestConfig & DeserializeResponseConfig & LoggingConfig;
18
19
  declare const store: Store<Config>;
19
20
  declare const setApiClientConfig: (config: Config) => void;
20
21
  declare const buildRequestInitWithDefaultConfig: (customRequestInit?: RequestInit) => RequestInit;
21
-
22
- export { type Config, type RequestConfig, buildRequestInitWithDefaultConfig, setApiClientConfig, store };
22
+ //#endregion
23
+ export { Config, RequestConfig, buildRequestInitWithDefaultConfig, setApiClientConfig, store };
@@ -1,40 +1,13 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var apiClientConfigStore_exports = {};
20
- __export(apiClientConfigStore_exports, {
21
- buildRequestInitWithDefaultConfig: () => buildRequestInitWithDefaultConfig,
22
- setApiClientConfig: () => setApiClientConfig,
23
- store: () => store
24
- });
25
- module.exports = __toCommonJS(apiClientConfigStore_exports);
26
- var import_store = require("./store");
27
- var import_requestInit = require("./utils/requestInit");
28
- const defaultConfig = {};
29
- const store = globalThis[Symbol.for("@readyfor/api-client-base/config")] ??= (0, import_store.createStore)(defaultConfig);
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ const require_store = require("./store.js");
3
+ const require_utils_requestInit = require("./utils/requestInit.js");
4
+ const store = globalThis[Symbol.for("@readyfor/api-client-base/config")] ??= require_store.createStore({});
30
5
  const setApiClientConfig = (config) => store.setState(() => config);
31
6
  const buildRequestInitWithDefaultConfig = (customRequestInit = {}) => {
32
- const { defaultRequestInit = {} } = store.getState();
33
- return (0, import_requestInit.mergeRequestInit)(defaultRequestInit, customRequestInit);
7
+ const { defaultRequestInit = {} } = store.getState();
8
+ return require_utils_requestInit.mergeRequestInit(defaultRequestInit, customRequestInit);
34
9
  };
35
- // Annotate the CommonJS export names for ESM import in node:
36
- 0 && (module.exports = {
37
- buildRequestInitWithDefaultConfig,
38
- setApiClientConfig,
39
- store
40
- });
10
+ //#endregion
11
+ exports.buildRequestInitWithDefaultConfig = buildRequestInitWithDefaultConfig;
12
+ exports.setApiClientConfig = setApiClientConfig;
13
+ exports.store = store;
@@ -1,30 +1,29 @@
1
+ //#region src/apiError.d.ts
1
2
  type ErrorStatusCode = 301 | 302 | 400 | 401 | 403 | 404 | 409 | 413 | 418 | 422 | 500 | 502 | 503 | 504 | 901 | 999;
2
3
  declare const errorStatusCode: {
3
- readonly MOVED_PERMANENTLY: 301;
4
- readonly FOUND: 302;
5
- readonly BAD_REQUEST: 400;
6
- readonly UNAUTHORIZED: 401;
7
- readonly FORBIDDEN: 403;
8
- readonly NOT_FOUND: 404;
9
- readonly CONFLICT: 409;
10
- readonly PAYLOAD_TOO_LARGE: 413;
11
- readonly NETWORK_ERROR: 418;
12
- readonly UNPROCESSABLE_ENTITY: 422;
13
- readonly INTERNAL_SERVER_ERROR: 500;
14
- readonly BAD_GATEWAY: 502;
15
- readonly SERVER_UNAVAILABLE: 503;
16
- readonly GATEWAY_TIMEOUT: 504;
17
- readonly ZOD_ERROR: 901;
18
- readonly UNHANDLED_ERROR: 999;
19
- };
20
- declare const errorTitle: {
21
- [key in ErrorStatusCode]: string;
4
+ readonly MOVED_PERMANENTLY: 301;
5
+ readonly FOUND: 302;
6
+ readonly BAD_REQUEST: 400;
7
+ readonly UNAUTHORIZED: 401;
8
+ readonly FORBIDDEN: 403;
9
+ readonly NOT_FOUND: 404;
10
+ readonly CONFLICT: 409;
11
+ readonly PAYLOAD_TOO_LARGE: 413;
12
+ readonly NETWORK_ERROR: 418;
13
+ readonly UNPROCESSABLE_ENTITY: 422;
14
+ readonly INTERNAL_SERVER_ERROR: 500;
15
+ readonly BAD_GATEWAY: 502;
16
+ readonly SERVER_UNAVAILABLE: 503;
17
+ readonly GATEWAY_TIMEOUT: 504;
18
+ readonly ZOD_ERROR: 901;
19
+ readonly UNHANDLED_ERROR: 999;
22
20
  };
21
+ declare const errorTitle: { [key in ErrorStatusCode]: string };
23
22
  declare class HTTPError extends Error {
24
- status: ErrorStatusCode;
25
- body?: unknown;
26
- constructor(status: ErrorStatusCode);
27
- constructor(status: ErrorStatusCode, body: unknown);
23
+ status: ErrorStatusCode;
24
+ body?: unknown;
25
+ constructor(status: ErrorStatusCode);
26
+ constructor(status: ErrorStatusCode, body: unknown);
28
27
  }
29
28
  /**
30
29
  * duck typing で HTTPError の status を判定する。
@@ -36,5 +35,5 @@ declare const isHttpErrorWithStatus: (error: unknown, status: number) => boolean
36
35
  declare const getHttpErrorBody: (error: unknown) => unknown;
37
36
  declare const getHttpErrorBodyReason: (body: unknown) => string | undefined;
38
37
  declare const getErrorStatus: (response: unknown) => ErrorStatusCode | undefined;
39
-
40
- export { type ErrorStatusCode, HTTPError, errorStatusCode, errorTitle, getErrorStatus, getHttpErrorBody, getHttpErrorBodyReason, isHttpErrorWithStatus };
38
+ //#endregion
39
+ export { ErrorStatusCode, HTTPError, errorStatusCode, errorTitle, getErrorStatus, getHttpErrorBody, getHttpErrorBodyReason, isHttpErrorWithStatus };
package/dist/apiError.js CHANGED
@@ -1,105 +1,78 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var apiError_exports = {};
20
- __export(apiError_exports, {
21
- HTTPError: () => HTTPError,
22
- errorStatusCode: () => errorStatusCode,
23
- errorTitle: () => errorTitle,
24
- getErrorStatus: () => getErrorStatus,
25
- getHttpErrorBody: () => getHttpErrorBody,
26
- getHttpErrorBodyReason: () => getHttpErrorBodyReason,
27
- isHttpErrorWithStatus: () => isHttpErrorWithStatus
28
- });
29
- module.exports = __toCommonJS(apiError_exports);
30
- var import_zod = require("./zod");
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ const require_zod = require("./zod.js");
3
+ //#region src/apiError.ts
31
4
  const errorStatusCode = {
32
- MOVED_PERMANENTLY: 301,
33
- FOUND: 302,
34
- BAD_REQUEST: 400,
35
- UNAUTHORIZED: 401,
36
- FORBIDDEN: 403,
37
- NOT_FOUND: 404,
38
- CONFLICT: 409,
39
- PAYLOAD_TOO_LARGE: 413,
40
- NETWORK_ERROR: 418,
41
- UNPROCESSABLE_ENTITY: 422,
42
- INTERNAL_SERVER_ERROR: 500,
43
- BAD_GATEWAY: 502,
44
- SERVER_UNAVAILABLE: 503,
45
- GATEWAY_TIMEOUT: 504,
46
- ZOD_ERROR: 901,
47
- UNHANDLED_ERROR: 999
5
+ MOVED_PERMANENTLY: 301,
6
+ FOUND: 302,
7
+ BAD_REQUEST: 400,
8
+ UNAUTHORIZED: 401,
9
+ FORBIDDEN: 403,
10
+ NOT_FOUND: 404,
11
+ CONFLICT: 409,
12
+ PAYLOAD_TOO_LARGE: 413,
13
+ NETWORK_ERROR: 418,
14
+ UNPROCESSABLE_ENTITY: 422,
15
+ INTERNAL_SERVER_ERROR: 500,
16
+ BAD_GATEWAY: 502,
17
+ SERVER_UNAVAILABLE: 503,
18
+ GATEWAY_TIMEOUT: 504,
19
+ ZOD_ERROR: 901,
20
+ UNHANDLED_ERROR: 999
48
21
  };
49
22
  const errorTitle = {
50
- 301: "\u30DA\u30FC\u30B8\u304C\u79FB\u52D5\u3055\u308C\u3066\u3044\u307E\u3059",
51
- 302: "\u30DA\u30FC\u30B8\u304C\u4E00\u6642\u7684\u306B\u79FB\u52D5\u3055\u308C\u3066\u3044\u307E\u3059",
52
- 400: "\u30EA\u30AF\u30A8\u30B9\u30C8\u304C\u4E0D\u6B63\u3067\u3059",
53
- 401: "\u30ED\u30B0\u30A4\u30F3\u3057\u3066\u304F\u3060\u3055\u3044",
54
- 403: "\u4E0D\u6B63\u306A\u30C8\u30FC\u30AF\u30F3\u3067\u3059",
55
- 404: "\u30DA\u30FC\u30B8\u304C\u898B\u3064\u304B\u308A\u307E\u305B\u3093\u3067\u3057\u305F",
56
- 409: "\u7DE8\u96C6\u5185\u5BB9\u304C\u7AF6\u5408\u3057\u3066\u3044\u307E\u3059",
57
- 413: "\u901A\u4FE1\u306B\u5931\u6557\u3057\u307E\u3057\u305F",
58
- 418: "\u901A\u4FE1\u306B\u5931\u6557\u3057\u307E\u3057\u305F",
59
- 422: "\u30C7\u30FC\u30BF\u304C\u4E0D\u6B63\u3067\u3059",
60
- 500: "\u30B5\u30FC\u30D0\u30FC\u3067\u30A8\u30E9\u30FC\u304C\u8D77\u304D\u307E\u3057\u305F",
61
- 502: "\u30B5\u30FC\u30D0\u30FC\u3067\u30A8\u30E9\u30FC\u304C\u8D77\u304D\u307E\u3057\u305F",
62
- 503: "\u30E1\u30F3\u30C6\u30CA\u30F3\u30B9\u4E2D\u3067\u3059",
63
- 504: "\u901A\u4FE1\u306B\u5931\u6557\u3057\u307E\u3057\u305F",
64
- 901: "\u554F\u984C\u304C\u767A\u751F\u3057\u307E\u3057\u305F",
65
- 999: "\u30B5\u30FC\u30D0\u30FC\u3067\u30A8\u30E9\u30FC\u304C\u8D77\u304D\u307E\u3057\u305F"
23
+ 301: "ページが移動されています",
24
+ 302: "ページが一時的に移動されています",
25
+ 400: "リクエストが不正です",
26
+ 401: "ログインしてください",
27
+ 403: "不正なトークンです",
28
+ 404: "ページが見つかりませんでした",
29
+ 409: "編集内容が競合しています",
30
+ 413: "通信に失敗しました",
31
+ 418: "通信に失敗しました",
32
+ 422: "データが不正です",
33
+ 500: "サーバーでエラーが起きました",
34
+ 502: "サーバーでエラーが起きました",
35
+ 503: "メンテナンス中です",
36
+ 504: "通信に失敗しました",
37
+ 901: "問題が発生しました",
38
+ 999: "サーバーでエラーが起きました"
39
+ };
40
+ var HTTPError = class extends Error {
41
+ status;
42
+ body;
43
+ constructor(status, body) {
44
+ super(errorTitle[status]);
45
+ this.name = "HTTPError";
46
+ this.status = status;
47
+ this.body = body;
48
+ }
66
49
  };
67
- class HTTPError extends Error {
68
- status;
69
- body;
70
- constructor(status, body) {
71
- super(errorTitle[status]);
72
- this.name = "HTTPError";
73
- this.status = status;
74
- this.body = body;
75
- }
76
- }
50
+ /**
51
+ * duck typing で HTTPError の status を判定する。
52
+ * pnpm の strict isolation により instanceof HTTPError が
53
+ * 別バージョンのクラスと一致しないケースがあるため、
54
+ * プロパティベースで判定する。
55
+ */
77
56
  const isHttpErrorWithStatus = (error, status) => error instanceof Error && "status" in error && error.status === status;
78
57
  const getHttpErrorBody = (error) => error instanceof Error && "body" in error ? error.body : void 0;
79
58
  const getHttpErrorBodyReason = (body) => {
80
- if (body !== null && typeof body === "object" && "reason" in body) {
81
- const reason = body.reason;
82
- return typeof reason === "string" ? reason : void 0;
83
- }
84
- return void 0;
59
+ if (body !== null && typeof body === "object" && "reason" in body) {
60
+ const reason = body.reason;
61
+ return typeof reason === "string" ? reason : void 0;
62
+ }
85
63
  };
86
64
  const getErrorStatus = (response) => {
87
- if (response instanceof Object && "status" in response && typeof response["status"] === "number") {
88
- const status = Number(response["status"]);
89
- return Object.values(errorStatusCode).includes(status) ? status : 999;
90
- }
91
- if ((0, import_zod.isZodError)(response)) {
92
- return errorStatusCode.ZOD_ERROR;
93
- }
94
- return void 0;
65
+ if (response instanceof Object && "status" in response && typeof response["status"] === "number") {
66
+ const status = Number(response["status"]);
67
+ return Object.values(errorStatusCode).includes(status) ? status : 999;
68
+ }
69
+ if (require_zod.isZodError(response)) return errorStatusCode.ZOD_ERROR;
95
70
  };
96
- // Annotate the CommonJS export names for ESM import in node:
97
- 0 && (module.exports = {
98
- HTTPError,
99
- errorStatusCode,
100
- errorTitle,
101
- getErrorStatus,
102
- getHttpErrorBody,
103
- getHttpErrorBodyReason,
104
- isHttpErrorWithStatus
105
- });
71
+ //#endregion
72
+ exports.HTTPError = HTTPError;
73
+ exports.errorStatusCode = errorStatusCode;
74
+ exports.errorTitle = errorTitle;
75
+ exports.getErrorStatus = getErrorStatus;
76
+ exports.getHttpErrorBody = getHttpErrorBody;
77
+ exports.getHttpErrorBodyReason = getHttpErrorBodyReason;
78
+ exports.isHttpErrorWithStatus = isHttpErrorWithStatus;
package/dist/fetcher.d.ts CHANGED
@@ -1,17 +1,18 @@
1
- import { z } from 'zod';
1
+ import { z } from "zod";
2
2
 
3
+ //#region src/fetcher.d.ts
3
4
  declare const createJsonFetcher: <T = never>(schema: z.ZodType<T>, customRequestInit?: RequestInit) => (input: RequestInfo, requestInit?: RequestInit) => Promise<T>;
4
5
  declare const createTextFetcher: (customRequestInit?: RequestInit) => (input: RequestInfo, requestInit?: RequestInit) => Promise<string>;
5
6
  type BlobFetcherResponse = {
6
- body: Blob;
7
- headers: Headers;
7
+ body: Blob;
8
+ headers: Headers;
8
9
  };
9
10
  declare const createBlobFetcher: (customRequestInit?: RequestInit) => (input: RequestInfo, requestInit?: RequestInit) => Promise<BlobFetcherResponse>;
10
11
  type FileOrBlobFetcherResponse = {
11
- body: File | Blob;
12
- headers: Headers;
12
+ body: File | Blob;
13
+ headers: Headers;
13
14
  };
14
15
  declare const createFileOrBlobFetcher: (customRequestInit?: RequestInit) => (input: RequestInfo, requestInit?: RequestInit) => Promise<FileOrBlobFetcherResponse>;
15
16
  declare const createVoidFetcher: (customRequestInit?: RequestInit) => (input: RequestInfo, requestInit?: RequestInit) => Promise<void>;
16
-
17
- export { type BlobFetcherResponse, type FileOrBlobFetcherResponse, createBlobFetcher, createFileOrBlobFetcher, createJsonFetcher, createTextFetcher, createVoidFetcher };
17
+ //#endregion
18
+ export { BlobFetcherResponse, FileOrBlobFetcherResponse, createBlobFetcher, createFileOrBlobFetcher, createJsonFetcher, createTextFetcher, createVoidFetcher };
package/dist/fetcher.js CHANGED
@@ -1,136 +1,68 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var fetcher_exports = {};
20
- __export(fetcher_exports, {
21
- createBlobFetcher: () => createBlobFetcher,
22
- createFileOrBlobFetcher: () => createFileOrBlobFetcher,
23
- createJsonFetcher: () => createJsonFetcher,
24
- createTextFetcher: () => createTextFetcher,
25
- createVoidFetcher: () => createVoidFetcher
26
- });
27
- module.exports = __toCommonJS(fetcher_exports);
28
- var import_apiError = require("./apiError");
29
- var import_apiClientConfigStore = require("./apiClientConfigStore");
30
- var import_requestInit = require("./utils/requestInit");
31
- const defaultRequestInit = {
32
- credentials: "include"
33
- };
34
- const createJsonFetcher = (schema, customRequestInit = {}) => (input, requestInit = {}) => fetch(
35
- input,
36
- (0, import_requestInit.mergeRequestInit)(
37
- defaultRequestInit,
38
- (0, import_requestInit.mergeRequestInit)(customRequestInit, requestInit)
39
- )
40
- ).then(async (res) => {
41
- const text = await res.text();
42
- const body = text ? JSON.parse(text) : {};
43
- if (res.ok) return body;
44
- const code = Object.values(import_apiError.errorStatusCode).includes(res.status) ? res.status : 999;
45
- const error = new import_apiError.HTTPError(code, body);
46
- throw error;
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ const require_utils_requestInit = require("./utils/requestInit.js");
3
+ const require_apiClientConfigStore = require("./apiClientConfigStore.js");
4
+ const require_apiError = require("./apiError.js");
5
+ //#region src/fetcher.ts
6
+ const defaultRequestInit = { credentials: "include" };
7
+ const createJsonFetcher = (schema, customRequestInit = {}) => (input, requestInit = {}) => fetch(input, require_utils_requestInit.mergeRequestInit(defaultRequestInit, require_utils_requestInit.mergeRequestInit(customRequestInit, requestInit))).then(async (res) => {
8
+ const text = await res.text();
9
+ const body = text ? JSON.parse(text) : {};
10
+ if (res.ok) return body;
11
+ throw new require_apiError.HTTPError(Object.values(require_apiError.errorStatusCode).includes(res.status) ? res.status : 999, body);
47
12
  }).catch((error) => {
48
- import_apiClientConfigStore.store.getState().onError?.(error);
49
- throw error;
13
+ require_apiClientConfigStore.store.getState().onError?.(error);
14
+ throw error;
50
15
  }).then((parsedResponse) => {
51
- const result = schema.safeParse(parsedResponse);
52
- const config = import_apiClientConfigStore.store.getState();
53
- if (result.success) {
54
- return result.data;
55
- }
56
- if (config.showsSchemaParseError) {
57
- console.error(result.error);
58
- }
59
- if (config.forceDeserializeResponse) {
60
- config.onFailedDeserializeResponse(input, result.error);
61
- return parsedResponse;
62
- }
63
- throw result.error;
16
+ const result = schema.safeParse(parsedResponse);
17
+ const config = require_apiClientConfigStore.store.getState();
18
+ if (result.success) return result.data;
19
+ if (config.showsSchemaParseError) console.error(result.error);
20
+ if (config.forceDeserializeResponse) {
21
+ config.onFailedDeserializeResponse(input, result.error);
22
+ return parsedResponse;
23
+ }
24
+ throw result.error;
64
25
  });
65
- const createTextFetcher = (customRequestInit = {}) => (input, requestInit = {}) => fetch(
66
- input,
67
- (0, import_requestInit.mergeRequestInit)(
68
- defaultRequestInit,
69
- (0, import_requestInit.mergeRequestInit)(customRequestInit, requestInit)
70
- )
71
- ).then(async (res) => {
72
- const body = await res.text();
73
- if (res.ok) return body;
74
- const code = Object.values(import_apiError.errorStatusCode).includes(res.status) ? res.status : 999;
75
- const error = new import_apiError.HTTPError(code, body);
76
- throw error;
26
+ const createTextFetcher = (customRequestInit = {}) => (input, requestInit = {}) => fetch(input, require_utils_requestInit.mergeRequestInit(defaultRequestInit, require_utils_requestInit.mergeRequestInit(customRequestInit, requestInit))).then(async (res) => {
27
+ const body = await res.text();
28
+ if (res.ok) return body;
29
+ throw new require_apiError.HTTPError(Object.values(require_apiError.errorStatusCode).includes(res.status) ? res.status : 999, body);
77
30
  }).catch((error) => {
78
- import_apiClientConfigStore.store.getState().onError?.(error);
79
- throw error;
31
+ require_apiClientConfigStore.store.getState().onError?.(error);
32
+ throw error;
80
33
  });
81
- const createBlobFetcher = (customRequestInit = {}) => (input, requestInit = {}) => fetch(
82
- input,
83
- (0, import_requestInit.mergeRequestInit)(
84
- defaultRequestInit,
85
- (0, import_requestInit.mergeRequestInit)(customRequestInit, requestInit)
86
- )
87
- ).then(async (res) => {
88
- const body = await res.blob();
89
- if (res.ok) return { body, headers: res.headers };
90
- const code = Object.values(import_apiError.errorStatusCode).includes(res.status) ? res.status : 999;
91
- const error = new import_apiError.HTTPError(code, body);
92
- throw error;
34
+ const createBlobFetcher = (customRequestInit = {}) => (input, requestInit = {}) => fetch(input, require_utils_requestInit.mergeRequestInit(defaultRequestInit, require_utils_requestInit.mergeRequestInit(customRequestInit, requestInit))).then(async (res) => {
35
+ const body = await res.blob();
36
+ if (res.ok) return {
37
+ body,
38
+ headers: res.headers
39
+ };
40
+ throw new require_apiError.HTTPError(Object.values(require_apiError.errorStatusCode).includes(res.status) ? res.status : 999, body);
93
41
  }).catch((error) => {
94
- import_apiClientConfigStore.store.getState().onError?.(error);
95
- throw error;
42
+ require_apiClientConfigStore.store.getState().onError?.(error);
43
+ throw error;
96
44
  });
97
- const createFileOrBlobFetcher = (customRequestInit = {}) => (input, requestInit = {}) => fetch(
98
- input,
99
- (0, import_requestInit.mergeRequestInit)(
100
- defaultRequestInit,
101
- (0, import_requestInit.mergeRequestInit)(customRequestInit, requestInit)
102
- )
103
- ).then(async (res) => {
104
- const body = await res.blob();
105
- if (res.ok) return { body, headers: res.headers };
106
- const code = Object.values(import_apiError.errorStatusCode).includes(res.status) ? res.status : 999;
107
- const error = new import_apiError.HTTPError(code, body);
108
- throw error;
45
+ const createFileOrBlobFetcher = (customRequestInit = {}) => (input, requestInit = {}) => fetch(input, require_utils_requestInit.mergeRequestInit(defaultRequestInit, require_utils_requestInit.mergeRequestInit(customRequestInit, requestInit))).then(async (res) => {
46
+ const body = await res.blob();
47
+ if (res.ok) return {
48
+ body,
49
+ headers: res.headers
50
+ };
51
+ throw new require_apiError.HTTPError(Object.values(require_apiError.errorStatusCode).includes(res.status) ? res.status : 999, body);
109
52
  }).catch((error) => {
110
- import_apiClientConfigStore.store.getState().onError?.(error);
111
- throw error;
53
+ require_apiClientConfigStore.store.getState().onError?.(error);
54
+ throw error;
112
55
  });
113
- const createVoidFetcher = (customRequestInit = {}) => (input, requestInit = {}) => fetch(
114
- input,
115
- (0, import_requestInit.mergeRequestInit)(
116
- defaultRequestInit,
117
- (0, import_requestInit.mergeRequestInit)(customRequestInit, requestInit)
118
- )
119
- ).then(async (res) => {
120
- if (res.ok) return;
121
- const code = Object.values(import_apiError.errorStatusCode).includes(res.status) ? res.status : 999;
122
- const body = await res.text();
123
- const error = new import_apiError.HTTPError(code, body);
124
- throw error;
56
+ const createVoidFetcher = (customRequestInit = {}) => (input, requestInit = {}) => fetch(input, require_utils_requestInit.mergeRequestInit(defaultRequestInit, require_utils_requestInit.mergeRequestInit(customRequestInit, requestInit))).then(async (res) => {
57
+ if (res.ok) return;
58
+ throw new require_apiError.HTTPError(Object.values(require_apiError.errorStatusCode).includes(res.status) ? res.status : 999, await res.text());
125
59
  }).catch((error) => {
126
- import_apiClientConfigStore.store.getState().onError?.(error);
127
- throw error;
128
- });
129
- // Annotate the CommonJS export names for ESM import in node:
130
- 0 && (module.exports = {
131
- createBlobFetcher,
132
- createFileOrBlobFetcher,
133
- createJsonFetcher,
134
- createTextFetcher,
135
- createVoidFetcher
60
+ require_apiClientConfigStore.store.getState().onError?.(error);
61
+ throw error;
136
62
  });
63
+ //#endregion
64
+ exports.createBlobFetcher = createBlobFetcher;
65
+ exports.createFileOrBlobFetcher = createFileOrBlobFetcher;
66
+ exports.createJsonFetcher = createJsonFetcher;
67
+ exports.createTextFetcher = createTextFetcher;
68
+ exports.createVoidFetcher = createVoidFetcher;