@topvisor/ui 1.1.0-apiClient.13 → 1.1.0-apiClient.14

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/api/index.amd.js CHANGED
@@ -1,2 +1,2 @@
1
- define(["require","exports","../.chunks/field-Cvv0SRcJ.amd"],(function(x,u,P){"use strict";if(typeof _>"u")var _=window.Vue;const S=(o={})=>{var t;return o={...o},o.loadingEl??=(t=globalThis.document)==null?void 0:t.body,o.loadingShowSpinner??=!0,o.method??="POST",o.accept??="application/json",o},q=(o,t,r)=>({result:o,errors:t,response:r}),$=o=>o.startsWith("/system_2/common/"),B=(o=!1,t=window.location.href)=>{const{protocol:r,hostname:e,port:n}=new URL(t),s=e.split("."),a=!o||s.length<=2||/^[\d.]+$/.test(e)||e==="localhost"?e:s.slice(-2).join(".");return`${r}//${a}${n?`:${n}`:""}`},J=(o,t,r)=>{const e={inLoading:!1,path:t,url:o.options.baseUrl+t,options:S(o.options.requestOptions),params:{},getInLoading:()=>e.inLoading,setParams:n=>(e.params={...n},e),changeParams:n=>(Object.assign(e.params,n),e),setOptions:n=>(Object.assign(e.options,n),e),call:async n=>e.exec(n),callFetch:async(n,s)=>e.exec(s,n),callInNewWindow:async n=>{var c,f;const s=e.genData(n),a=o.genMiddlewareCtx(e,s);(f=(c=o.options).onPrepareData)==null||f.call(c,s,a);const{postInWindow:p}=await new Promise((g,m)=>x(["../.chunks/lazy-CiM2Ny-s.amd"],g,m));p(e.url,s,"_blank")},callInSelfWindow:async n=>{var c,f;const s=e.genData(n),a=o.genMiddlewareCtx(e,s);(f=(c=o.options).onPrepareData)==null||f.call(c,s,a);const{postInWindow:p}=await new Promise((g,m)=>x(["../.chunks/lazy-CiM2Ny-s.amd"],g,m));p(e.url,s,"_self")},genData:(n,s)=>{const a={...e.params};if(delete a.fetch_style,n){let p=[...n];r&&(p=p.filter(c=>r.includes(c))),a.fields=p}else r&&(a.fields=r);return s&&(a.fetch_style=s),a},async exec(n,s){var I,C,z,A,D,T,U,F,O,v,L,W,j,k;const a=o.options.Request,p=o.options.fetch,c=e.genData(n,s),f=o.genMiddlewareCtx(e,c);(C=(I=o.options).onPrepareData)==null||C.call(I,c,f);let g=e.url,m;e.options.method!=="POST"?g+="?"+await o.options.querySerializer(c):m=o.options.bodySerializer(c);let K;if(this.options.checkFingerprint){const l=this.path+this.options.checkFingerprint,R=new AbortController;o.abortControllers[l]=R}const Q={...o.options,method:e.options.method,body:m,signal:K};let w=new a(g,Q);w.headers.set("x-request-id",f.id),w.headers.set("content-type","application/json"),w.headers.set("accept",e.options.accept);const h={...f,request:w};e.inLoading=!0,(A=(z=e.options).onLoading)==null||A.call(z,e.inLoading,h);let d;const b=await o.middlewareOnRequest(w,h);if(b instanceof Response?d=b:b instanceof a&&(w=b),!d)try{d=await p(w)}catch(l){d=await o.middlewareOnError(l,h)}finally{e.inLoading=!1,(T=(D=e.options).onLoading)==null||T.call(D,e.inLoading,h)}d=await o.middlewareOnResponse(d,h);let i,y,E;try{const l=(U=d.headers.get("content-type"))==null?void 0:U.includes("application/json");y=await d.text(),this.options.accept==="application/json"||l?i=JSON.parse(y):o.useExt?i=q(y,void 0,d):i=y}catch(l){if((l instanceof SyntaxError||l instanceof TypeError)&&(E=l,E.responseText=y),o.useExt&&E){let R=d.status,M=d.statusText;R===200&&(R=1e4,M="Error API response"),i=q(null,[{code:R,string:M}],d),o.options.useApiConsole&&console.error(l)}else throw l}return o.useExt&&(i.response=d,i&&((O=(F=e.options).onApiLoaded)==null||O.call(F,i,h)),i!=null&&i.errors&&(o.options.useApiConsole&&console.warn(new Error("API error"),{res:i}),(W=(L=e.options).onApiError)==null||W.call(L,i,{...h,formatError:E},(v=o.options.requestOptions)==null?void 0:v.onApiError)),i!=null&&i.messages&&((k=(j=e.options).onApiMessage)==null||k.call(j,i,h))),i}};return e};class H{options;useExt;middlewares=[];abortControllers={};constructor(t={},r){t.requestOptions=S(t.requestOptions),t.useApiConsole??=!0,t.fetch??=globalThis.fetch,t.Request??=globalThis.Request,t.querySerializer??=async e=>{const{querySerializer:n}=await new Promise((s,a)=>x(["../.chunks/lazy-CiM2Ny-s.amd"],s,a));return n(e)},t.bodySerializer??=e=>typeof e=="string"?e:JSON.stringify(e),this.options=t,this.useExt=r}generateUUID(){return crypto!=null&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{const r=Math.random()*16|0;return(t==="x"?r:r&3|8).toString(16)})}use(t){this.middlewares.push(t)}gen(t,r){return J(this,t,r)}genAny(t,r){return this.gen(t,r)}genMiddlewareCtx(t,r){const e=this.generateUUID(),n=Object.freeze({baseUrl:this.options.baseUrl,querySerializer:this.options.querySerializer,bodySerializer:this.options.bodySerializer,Request:this.options.Request,fetch:this.options.fetch});return{useExt:this.useExt,requestOptions:t.options,data:r,middlewareData:{},options:n,schemaPath:t.path,id:e}}async middlewareOnRequest(t,r){var e;for(const n of this.middlewares){const s=await((e=n.onRequest)==null?void 0:e.call(n,{...r,request:t}));if(s)if(s instanceof Request)t=s;else{if(s instanceof Response)return s;throw new Error("onRequest: must return new Request() or Response() when modifying the request")}}return t}async middlewareOnError(t,r){var n;let e=t;for(const s of this.middlewares){const a=await((n=s.onError)==null?void 0:n.call(s,{...r,error:e}));if(a){if(a instanceof Response)return a;if(a instanceof Error){e=a;continue}throw new Error("onError: must return new Response() or instance of Error")}}throw e}async middlewareOnResponse(t,r){var e;for(const n of this.middlewares){const s=await((e=n.onResponse)==null?void 0:e.call(n,{...r,response:t}));if(s){if(!(s instanceof Response))throw new Error("onResponse: must return new Response() when modifying the response");t=s}}return t}}const N=async(...o)=>{const{postInWindow:t}=await new Promise((r,e)=>x(["../.chunks/lazy-CiM2Ny-s.amd"],r,e));return t(...o)},V=async(...o)=>{const{dataToForm:t}=await new Promise((r,e)=>x(["../.chunks/lazy-CiM2Ny-s.amd"],r,e));return t(...o)},G=(o={},t)=>new H(o,t);u.genFieldFilter=P.genFieldFilter,u.genFieldOrder=P.genFieldOrder,u.createClient=G,u.dataToForm=V,u.genExtRes=q,u.getBaseDomainUrl=B,u.isPublicAPI=$,u.postInWindow=N,Object.defineProperty(u,Symbol.toStringTag,{value:"Module"})}));
1
+ define(["require","exports","../.chunks/field-Cvv0SRcJ.amd"],(function(y,u,P){"use strict";if(typeof B>"u")var B=window.Vue;const S=(t={})=>{var o;return t={...t},t.loadingEl??=(o=globalThis.document)==null?void 0:o.body,t.loadingShowSpinner??=!0,t.method??="POST",t.accept??="application/json",t},q=(t,o,r)=>({result:t,errors:o,response:r}),J=t=>t.startsWith("/system_2/common/"),H=(t=!1,o=window.location.href)=>{const{protocol:r,hostname:e,port:n}=new URL(o),s=e.split("."),a=!t||s.length<=2||/^[\d.]+$/.test(e)||e==="localhost"?e:s.slice(-2).join(".");return`${r}//${a}${n?`:${n}`:""}`},N=(t,o,r)=>{const e={inLoading:!1,path:o,url:t.options.baseUrl+o,options:S(t.options.requestOptions),params:{},getInLoading:()=>e.inLoading,setParams:n=>(e.params={...n},e),changeParams:n=>(Object.assign(e.params,n),e),setOptions:n=>(Object.assign(e.options,n),e),call:async n=>e.exec(n),callFetch:async(n,s)=>e.exec(s,n),callInNewWindow:async n=>{var l,f;const s=e.genData(n),a=t.genMiddlewareCtx(e,s);(f=(l=t.options).onPrepareData)==null||f.call(l,s,a);const{postInWindow:p}=await new Promise((g,m)=>y(["../.chunks/lazy-CiM2Ny-s.amd"],g,m));p(e.url,s,"_blank")},callInSelfWindow:async n=>{var l,f;const s=e.genData(n),a=t.genMiddlewareCtx(e,s);(f=(l=t.options).onPrepareData)==null||f.call(l,s,a);const{postInWindow:p}=await new Promise((g,m)=>y(["../.chunks/lazy-CiM2Ny-s.amd"],g,m));p(e.url,s,"_self")},genData:(n,s)=>{const a={...e.params};if(delete a.fetch_style,n){let p=[...n];r&&(p=p.filter(l=>r.includes(l))),a.fields=p}else r&&(a.fields=r);return s&&(a.fetch_style=s),a},async exec(n,s){var C,z,A,D,T,U,F,O,v,L,W,j,k,M,_;const a=t.options.Request,p=t.options.fetch,l=e.genData(n,s),f=t.genMiddlewareCtx(e,l);(z=(C=t.options).onPrepareData)==null||z.call(C,l,f);let g=e.url,m;e.options.method!=="POST"?g+="?"+await t.options.querySerializer(l):m=t.options.bodySerializer(l);let I;if(this.options.checkFingerprint){const c=this.path+this.options.checkFingerprint;(A=t.abortControllers[c])==null||A.abort();const x=new AbortController;t.abortControllers[c]=x,I=x.signal}const X={...t.options,method:e.options.method,body:m,signal:I};let w=new a(g,X);w.headers.set("x-request-id",f.id),w.headers.set("content-type","application/json"),w.headers.set("accept",e.options.accept);const h={...f,request:w};e.inLoading=!0,(T=(D=e.options).onLoading)==null||T.call(D,e.inLoading,h);let d;const b=await t.middlewareOnRequest(w,h);if(b instanceof Response?d=b:b instanceof a&&(w=b),!d)try{d=await p(w)}catch(c){d=await t.middlewareOnError(c,h)}finally{e.inLoading=!1,(F=(U=e.options).onLoading)==null||F.call(U,e.inLoading,h)}d=await t.middlewareOnResponse(d,h);let i,R,E;try{const c=(O=d.headers.get("content-type"))==null?void 0:O.includes("application/json");R=await d.text(),this.options.accept==="application/json"||c?i=JSON.parse(R):t.useExt?i=q(R,void 0,d):i=R}catch(c){if((c instanceof SyntaxError||c instanceof TypeError)&&(E=c,E.responseText=R),t.useExt&&E){let x=d.status,$=d.statusText;x===200&&(x=1e4,$="Error API response"),i=q(null,[{code:x,string:$}],d),t.options.useApiConsole&&console.error(c)}else throw c}return t.useExt&&(i.response=d,i&&((L=(v=e.options).onApiLoaded)==null||L.call(v,i,h)),i!=null&&i.errors&&(t.options.useApiConsole&&console.warn(new Error("API error"),{res:i}),(k=(j=e.options).onApiError)==null||k.call(j,i,{...h,formatError:E},(W=t.options.requestOptions)==null?void 0:W.onApiError)),i!=null&&i.messages&&((_=(M=e.options).onApiMessage)==null||_.call(M,i,h))),i}};return e};class V{options;useExt;middlewares=[];abortControllers={};constructor(o={},r){o.requestOptions=S(o.requestOptions),o.useApiConsole??=!0,o.fetch??=globalThis.fetch,o.Request??=globalThis.Request,o.querySerializer??=async e=>{const{querySerializer:n}=await new Promise((s,a)=>y(["../.chunks/lazy-CiM2Ny-s.amd"],s,a));return n(e)},o.bodySerializer??=e=>typeof e=="string"?e:JSON.stringify(e),this.options=o,this.useExt=r}generateUUID(){return crypto!=null&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,o=>{const r=Math.random()*16|0;return(o==="x"?r:r&3|8).toString(16)})}use(o){this.middlewares.push(o)}gen(o,r){return N(this,o,r)}genAny(o,r){return this.gen(o,r)}genMiddlewareCtx(o,r){const e=this.generateUUID(),n=Object.freeze({baseUrl:this.options.baseUrl,querySerializer:this.options.querySerializer,bodySerializer:this.options.bodySerializer,Request:this.options.Request,fetch:this.options.fetch});return{useExt:this.useExt,requestOptions:o.options,data:r,middlewareData:{},options:n,schemaPath:o.path,id:e}}async middlewareOnRequest(o,r){var e;for(const n of this.middlewares){const s=await((e=n.onRequest)==null?void 0:e.call(n,{...r,request:o}));if(s)if(s instanceof Request)o=s;else{if(s instanceof Response)return s;throw new Error("onRequest: must return new Request() or Response() when modifying the request")}}return o}async middlewareOnError(o,r){var n;let e=o;for(const s of this.middlewares){const a=await((n=s.onError)==null?void 0:n.call(s,{...r,error:e}));if(a){if(a instanceof Response)return a;if(a instanceof Error){e=a;continue}throw new Error("onError: must return new Response() or instance of Error")}}throw e}async middlewareOnResponse(o,r){var e;for(const n of this.middlewares){const s=await((e=n.onResponse)==null?void 0:e.call(n,{...r,response:o}));if(s){if(!(s instanceof Response))throw new Error("onResponse: must return new Response() when modifying the response");o=s}}return o}}const G=async(...t)=>{const{postInWindow:o}=await new Promise((r,e)=>y(["../.chunks/lazy-CiM2Ny-s.amd"],r,e));return o(...t)},K=async(...t)=>{const{dataToForm:o}=await new Promise((r,e)=>y(["../.chunks/lazy-CiM2Ny-s.amd"],r,e));return o(...t)},Q=(t={},o)=>new V(t,o);u.genFieldFilter=P.genFieldFilter,u.genFieldOrder=P.genFieldOrder,u.createClient=Q,u.dataToForm=K,u.genExtRes=q,u.getBaseDomainUrl=H,u.isPublicAPI=J,u.postInWindow=G,Object.defineProperty(u,Symbol.toStringTag,{value:"Module"})}));
2
2
  //# sourceMappingURL=index.amd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.amd.js","sources":["../../src/api/api/client/request-options.ts","../../src/api/api/utils/common.ts","../../src/api/api/client/request.ts","../../src/api/api/client/client.ts","../../src/api/api/index.ts"],"sourcesContent":["export const createRequestOptions = (requestOptions: Partial<Api.ClientRequestOptions> = {}): Api.ClientRequestOptions => {\n\trequestOptions = { ...requestOptions };\n\trequestOptions.loadingEl ??= globalThis.document?.body;\n\trequestOptions.loadingShowSpinner ??= true;\n\trequestOptions.method ??= 'POST';\n\trequestOptions.accept ??= 'application/json';\n\n\treturn requestOptions as Api.ClientRequestOptions;\n};\n","/**\n * Сгенерировать объект ответа в формате расширения OpenAPI\n *\n * @see Api.Ext\n */\nexport const genExtRes = (\n\tresult: any,\n\terrors?: Api.Ext.Schemas['ResponseError']['errors'],\n\tresponse?: Response,\n): Api.Response<any> => {\n\treturn {\n\t\tresult,\n\t\terrors,\n\t\tresponse,\n\t};\n};\n\n/**\n * Это публичное API, к которому открыт доступ по прямой ссылке через GET\n *\n * Используется для кеширования и генерации файлов через API\n */\nexport const isPublicAPI = (path: Api.PathAbstract) => {\n\treturn path.startsWith('/system_2/common/');\n};\n\n/**\n * Сгенерировать baseUrl на основе текущего домена\n */\nexport const getBaseDomainUrl = (useMainDomain = false, input: string = window.location.href) => {\n\tconst { protocol, hostname, port } = new URL(input);\n\n\t/**\n\t * localhost / IP-адреса / одноуровневые домены оставляем как есть\n\t */\n\tconst parts = hostname.split('.');\n\tconst baseHostname = !useMainDomain || parts.length <= 2 || /^[\\d.]+$/.test(hostname) || hostname === 'localhost'\n\t\t? hostname\n\t\t: parts.slice(-2).join('.');\n\n\treturn `${protocol}//${baseHostname}${port ? `:${port}` : ''}`;\n};\n","import type { Client } from './client';\nimport { createRequestOptions } from './request-options';\nimport { genExtRes } from '../utils/common';\n\nexport const createRequest = <\n\tRequestContext extends Api.ClientRequestContext<any, any, any>,\n\tFieldsNarrow extends Api.ParamsFields<RequestContext>,\n>(\n\tclient: Client<RequestContext['Paths'], RequestContext['UseExt']>,\n\tpath: RequestContext['Path'],\n\tfieldsNarrow?: FieldsNarrow,\n): Api.ClientRequest<RequestContext, FieldsNarrow> => {\n\tconst clientRequest = {\n\t\tinLoading: false,\n\t\tpath: path as Api.PathAbstract,\n\t\turl: client.options.baseUrl + path,\n\t\toptions: createRequestOptions(client.options.requestOptions),\n\t\tparams: {} as any, // незаполненное свойство\n\t\tgetInLoading: () => clientRequest.inLoading,\n\n\t\tsetParams: (params) => {\n\t\t\tclientRequest.params = { ...params } as any;\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tchangeParams: (params) => {\n\t\t\tObject.assign(clientRequest.params, params);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tsetOptions: (options) => {\n\t\t\tObject.assign(clientRequest.options, options);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tcall: async (fields?) => {\n\t\t\treturn clientRequest.exec(fields);\n\t\t},\n\n\t\tcallFetch: async (fetchStyle, fields?) => {\n\t\t\treturn clientRequest.exec(fields, fetchStyle);\n\t\t},\n\n\t\tcallInNewWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_blank');\n\t\t},\n\n\t\tcallInSelfWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_self');\n\t\t},\n\n\t\tgenData: (fields?, fetchStyle?) => {\n\t\t\tconst post: any = { ...clientRequest.params };\n\n\t\t\t// в старом коде fields вставлялись в params, оставлено для совместимости\n\t\t\t// delete post.fields;\n\t\t\tdelete post.fetch_style;\n\n\t\t\t// поля, указанные при запуске запроса\n\t\t\tif (fields) {\n\t\t\t\tlet fieldsPrepared = [...fields as any[]];\n\n\t\t\t\t// поля, указанные при создании запроса\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tfieldsPrepared = fieldsPrepared.filter(field => fieldsNarrow.includes(field));\n\t\t\t\t}\n\n\t\t\t\tpost.fields = fieldsPrepared;\n\t\t\t} else {\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tpost.fields = fieldsNarrow;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (fetchStyle) {\n\t\t\t\tpost.fetch_style = fetchStyle;\n\t\t\t}\n\n\t\t\treturn post;\n\t\t},\n\n\t\t/**\n\t\t * Общая функция выполнения запросов\n\t\t */\n\t\tasync exec(fields?: FieldsNarrow, fetchStyle?: RequestContext['ParamsFetchStyle']): Promise<any> {\n\t\t\tconst Request = client.options.Request;\n\t\t\tconst fetch = client.options.fetch;\n\n\t\t\tconst data = clientRequest.genData(fields, fetchStyle);\n\n\t\t\tconst middlewareCtxWithoutRequest = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtxWithoutRequest);\n\n\t\t\tlet url = clientRequest.url;\n\n\t\t\tlet requestInitBody: string | undefined = undefined;\n\t\t\tif (clientRequest.options.method !== 'POST') {\n\t\t\t\turl += '?' + await client.options.querySerializer(data);\n\t\t\t} else {\n\t\t\t\trequestInitBody = client.options.bodySerializer(data);\n\t\t\t}\n\n\t\t\t// checkFingerprint\n\t\t\tlet requestInitSignal: AbortController['signal'] | undefined;\n\n\t\t\tif (this.options.checkFingerprint) {\n\t\t\t\tconst fingerprint = this.path + this.options.checkFingerprint;\n\n\t\t\t\tconst controller = new AbortController();\n\t\t\t\tclient.abortControllers[fingerprint] = controller;\n\n\t\t\t}\n\n\t\t\tconst requestInit = {\n\t\t\t\t...client.options,\n\t\t\t\tmethod: clientRequest.options.method,\n\t\t\t\tbody: requestInitBody,\n\t\t\t\tsignal: requestInitSignal,\n\t\t\t};\n\n\t\t\tlet request = new Request(url, requestInit);\n\n\t\t\trequest.headers.set('x-request-id', middlewareCtxWithoutRequest.id);\n\t\t\trequest.headers.set('content-type', 'application/json');\n\t\t\trequest.headers.set('accept', clientRequest.options.accept);\n\n\t\t\tconst middlewareCtx: Api.MiddlewareCallbackParams = {\n\t\t\t\t...middlewareCtxWithoutRequest,\n\t\t\t\trequest,\n\t\t\t};\n\n\t\t\tclientRequest.inLoading = true;\n\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\n\t\t\tlet response: Response | undefined = undefined;\n\n\t\t\tconst requestOrResponse = await client.middlewareOnRequest(request, middlewareCtx);\n\n\t\t\tif (requestOrResponse instanceof Response) {\n\t\t\t\tresponse = requestOrResponse;\n\t\t\t} else if (requestOrResponse instanceof Request) {\n\t\t\t\trequest = requestOrResponse;\n\t\t\t}\n\n\t\t\tif (!response) {\n\t\t\t\ttry {\n\t\t\t\t\tresponse = await fetch(request);\n\t\t\t\t} catch (e) {\n\t\t\t\t\tresponse = await client.middlewareOnError(e, middlewareCtx);\n\t\t\t\t} finally {\n\t\t\t\t\tclientRequest.inLoading = false;\n\t\t\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tresponse = await client.middlewareOnResponse(response, middlewareCtx);\n\n\t\t\tlet res: any;\n\t\t\tlet responseText: string | undefined;\n\t\t\tlet formatError: undefined | Api.FormatError = undefined;\n\n\t\t\ttry {\n\t\t\t\t// json - стандартные формат, он может быть возвращен в запросах с другим responseType, если в них произошла ошибка\n\t\t\t\tconst isJSON = response.headers.get('content-type')?.includes('application/json');\n\n\t\t\t\tresponseText = await response.text();\n\n\t\t\t\tif (this.options.accept === 'application/json' || isJSON) {\n\t\t\t\t\tres = JSON.parse(responseText);\n\t\t\t\t} else {\n\t\t\t\t\tif (client.useExt) {\n\t\t\t\t\t\tres = genExtRes(responseText, undefined, response);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tres = responseText;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tif (e instanceof SyntaxError || e instanceof TypeError) {\n\t\t\t\t\tformatError = e;\n\t\t\t\t\tformatError.responseText = responseText;\n\t\t\t\t}\n\n\t\t\t\t// если в результате не пришел json, сгенерировать объект результата и добавить информацию об ответе API\n\t\t\t\tif (client.useExt && formatError) {\n\t\t\t\t\tlet errorCode = response.status;\n\t\t\t\t\tlet errorMessage = response.statusText;\n\n\t\t\t\t\tif (errorCode === 200) {\n\t\t\t\t\t\terrorCode = 10000;\n\t\t\t\t\t\terrorMessage = 'Error API response';\n\t\t\t\t\t}\n\n\t\t\t\t\tres = genExtRes(null, [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcode: errorCode,\n\t\t\t\t\t\t\tstring: errorMessage,\n\t\t\t\t\t\t},\n\t\t\t\t\t], response);\n\n\t\t\t\t\tif (client.options.useApiConsole) console.error(e);\n\t\t\t\t} else {\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (client.useExt) {\n\t\t\t\tres.response = response;\n\n\t\t\t\tif (res) {\n\t\t\t\t\tclientRequest.options.onApiLoaded?.(res, middlewareCtx);\n\t\t\t\t}\n\n\t\t\t\tif (res?.errors) {\n\t\t\t\t\tif (client.options.useApiConsole) console.warn(new Error('API error'), { res });\n\n\t\t\t\t\tclientRequest.options.onApiError?.(res, { ...middlewareCtx, formatError }, client.options.requestOptions?.onApiError);\n\t\t\t\t}\n\n\t\t\t\tif (res?.messages) {\n\t\t\t\t\tclientRequest.options.onApiMessage?.(res, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn res;\n\t\t},\n\t};\n\n\treturn clientRequest;\n};\n","import { createRequestOptions } from './request-options';\nimport { createRequest } from './request';\n\nexport class Client<paths extends Api.PathsAbstract, UseExt extends Api.Ext.UseExt> {\n\n\treadonly options: Readonly<Api.ClientOptions>;\n\treadonly useExt: UseExt;\n\treadonly middlewares: Api.Middleware[] = [];\n\tabortControllers: Record<string, AbortController> = {};\n\n\tconstructor(clientOptions: Partial<Api.ClientOptions> = {}, useExt: UseExt) {\n\t\tclientOptions.requestOptions = createRequestOptions(clientOptions.requestOptions);\n\t\tclientOptions.useApiConsole ??= true;\n\n\t\tclientOptions.fetch ??= globalThis.fetch;\n\t\tclientOptions.Request ??= globalThis.Request;\n\t\tclientOptions.querySerializer ??= async (params) => {\n\t\t\tconst { querySerializer } = await import('../utils/lazy');\n\n\t\t\treturn querySerializer(params);\n\t\t}\n\t\tclientOptions.bodySerializer ??= (body) => typeof body === 'string' ? body : JSON.stringify(body);\n\n\t\tthis.options = clientOptions as Api.ClientOptions;\n\n\t\tthis.useExt = useExt;\n\t}\n\n\tgenerateUUID() {\n\t\tif (crypto?.randomUUID) {\n\t\t\treturn crypto.randomUUID();\n\t\t}\n\n\t\treturn 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {\n\t\t\tconst r = Math.random() * 16 | 0;\n\t\t\tconst v = c === 'x' ? r : (r & 0x3 | 0x8);\n\t\t\treturn v.toString(16);\n\t\t});\n\t}\n\n\t/**\n\t * Зарегистрировать middleware\n\t */\n\tuse(middleware: Api.Middleware) {\n\t\tthis.middlewares.push(middleware);\n\t}\n\n\t/**\n\t * Создать объект запроса\n\t *\n\t * После создания объекта он заполняется необходимыми данными и выполняет запросы к API с помощью APIRequest2.call();\n\t *\n\t * Опционально generic указывать нельзя, поэтому необходимо дублировать определение fetchStyle, [см.](https://github.com/Microsoft/TypeScript/issues/26242)\n\t *\n\t * @param path Путь метода API\n\t * @param fieldsNarrow Список получаемых полей, для методов API с моделью. Если объект запроса переиспользуется, и список полей меняется, указывайте его непосредственно при вызове `api.call()`\n\t */\n\tgen<\n\t\tPath extends Api.Path<paths>,\n\t\tFieldsNarrow extends Api.ParamsFields<Api.ClientRequestContext<paths, Path, UseExt>>\n\t>(\n\t\tpath: Path,\n\t\tfieldsNarrow?: FieldsNarrow,\n\t): Api.ClientRequest<Api.ClientRequestContext<paths, Path, UseExt>, FieldsNarrow> {\n\t\ttype RequestContext = Api.ClientRequestContext<paths, Path, UseExt>;\n\n\t\treturn createRequest<RequestContext, FieldsNarrow>(this, path, fieldsNarrow);\n\t}\n\n\t/**\n\t * Создать объект запроса, не описанного в OpenAPI\n\t */\n\tgenAny<\n\t\tParams extends Record<string, any>,\n\t\tResult = any,\n\t\tFieldsNarrow extends Api.Ext.Schemas['Fields'] | undefined = undefined\n\t>(path: Api.PathAbstract, fieldsNarrow?: FieldsNarrow): Api.ClientRequestCustom<UseExt, Params, Result> {\n\t\treturn this.gen(path as any, fieldsNarrow as any) as unknown as Api.ClientRequestCustom<UseExt, Params, Result>;\n\t}\n\n\t/**\n\t * Создать контекст выполнения запроса\n\t */\n\tgenMiddlewareCtx(\n\t\tclientRequest: Api.ClientRequest<any, any, any>,\n\t\tdata: Record<string, any>,\n\t): Omit<Api.MiddlewareCallbackParams, 'request'> {\n\t\tconst id = this.generateUUID();\n\n\t\tconst options: Api.BaseOptions = Object.freeze({\n\t\t\tbaseUrl: this.options.baseUrl,\n\t\t\tquerySerializer: this.options.querySerializer,\n\t\t\tbodySerializer: this.options.bodySerializer,\n\t\t\tRequest: this.options.Request,\n\t\t\tfetch: this.options.fetch,\n\t\t});\n\n\t\treturn {\n\t\t\tuseExt: this.useExt,\n\t\t\trequestOptions: clientRequest.options,\n\t\t\tdata,\n\t\t\tmiddlewareData: {},\n\t\t\toptions,\n\t\t\tschemaPath: clientRequest.path,\n\t\t\tid,\n\t\t};\n\t};\n\n\t/**\n\t * Обработчик middleware.onRequest\n\t *\n\t * @param request Запрос для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Request` или `Response` при модификации запроса, или undefined\n\t */\n\tasync middlewareOnRequest(\n\t\trequest: Request,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Request | Response | undefined> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onRequest?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\trequest,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Request) {\n\t\t\t\t\trequest = result;\n\t\t\t\t} else if (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error('onRequest: must return new Request() or Response() when modifying the request');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn request;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param `error` Ошибка, переданная для обработки\n\t * @param middlewareCtx\n\t * @return Новый экземпляр `Response` при успешной обработке или выбрасывает ошибку\n\t */\n\tasync middlewareOnError(\n\t\terror: Error | unknown,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response | never> {\n\t\tlet errorAfterMiddleware = error;\n\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onError?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\terror: errorAfterMiddleware,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (result instanceof Error) {\n\t\t\t\t\terrorAfterMiddleware = result;\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tthrow new Error('onError: must return new Response() or instance of Error');\n\t\t\t}\n\t\t}\n\n\t\tthrow errorAfterMiddleware;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param response Ответ для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Response` при модификации ответа, или undefined\n\t */\n\tasync middlewareOnResponse(\n\t\tresponse: Response,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onResponse?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\tresponse,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (!(result instanceof Response)) {\n\t\t\t\t\tthrow new Error('onResponse: must return new Response() when modifying the response');\n\t\t\t\t}\n\n\t\t\t\tresponse = result;\n\t\t\t}\n\t\t}\n\n\t\treturn response;\n\t}\n\n}\n","import { Client } from './client/client';\n\nexport * from './utils/field';\nexport * from './utils/common';\n\nexport const postInWindow: typeof import('./utils/lazy').postInWindow = async (...args) => {\n\tconst { postInWindow } = await import('./utils/lazy');\n\n\treturn postInWindow(...args);\n};\n\nexport const dataToForm: typeof import('./utils/lazy').dataToForm = async (...args) => {\n\tconst { dataToForm } = await import('./utils/lazy');\n\n\treturn dataToForm(...args);\n};\n\n/**\n * Создать API клиент\n *\n * @see Api.Ext.UseExt\n */\nexport const createClient = <\n\tpaths extends Api.PathsAbstract,\n\tUseExt extends Api.Ext.UseExt\n>(\n\tclientOptions: Partial<Api.ClientOptions> = {},\n\tuseExt: UseExt,\n) => {\n\treturn new Client<paths, UseExt>(clientOptions, useExt);\n};\n"],"names":["createRequestOptions","requestOptions","genExtRes","result","errors","response","isPublicAPI","path","getBaseDomainUrl","useMainDomain","input","protocol","hostname","port","baseHostname","parts","clientRequest","params","options","fields","fetchStyle","fieldsPrepared","field","fieldsNarrow","post","Request","client","fetch","url","data","requestInitSignal","controller","fingerprint","request","middlewareCtxWithoutRequest","requestOrResponse","e","res","responseText","isJSON","_g","formatError","errorCode","errorMessage","Client","clientOptions","useExt","querySerializer","body","c","middleware","id","middlewareCtx","_a","error","errorAfterMiddleware","postInWindow","args","postInWindow2","dataToForm","dataToForm2","createClient"],"mappings":"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"}
1
+ {"version":3,"file":"index.amd.js","sources":["../../src/api/api/client/request-options.ts","../../src/api/api/utils/common.ts","../../src/api/api/client/request.ts","../../src/api/api/client/client.ts","../../src/api/api/index.ts"],"sourcesContent":["export const createRequestOptions = (requestOptions: Partial<Api.ClientRequestOptions> = {}): Api.ClientRequestOptions => {\n\trequestOptions = { ...requestOptions };\n\trequestOptions.loadingEl ??= globalThis.document?.body;\n\trequestOptions.loadingShowSpinner ??= true;\n\trequestOptions.method ??= 'POST';\n\trequestOptions.accept ??= 'application/json';\n\n\treturn requestOptions as Api.ClientRequestOptions;\n};\n","/**\n * Сгенерировать объект ответа в формате расширения OpenAPI\n *\n * @see Api.Ext\n */\nexport const genExtRes = (\n\tresult: any,\n\terrors?: Api.Ext.Schemas['ResponseError']['errors'],\n\tresponse?: Response,\n): Api.Response<any> => {\n\treturn {\n\t\tresult,\n\t\terrors,\n\t\tresponse,\n\t};\n};\n\n/**\n * Это публичное API, к которому открыт доступ по прямой ссылке через GET\n *\n * Используется для кеширования и генерации файлов через API\n */\nexport const isPublicAPI = (path: Api.PathAbstract) => {\n\treturn path.startsWith('/system_2/common/');\n};\n\n/**\n * Сгенерировать baseUrl на основе текущего домена\n */\nexport const getBaseDomainUrl = (useMainDomain = false, input: string = window.location.href) => {\n\tconst { protocol, hostname, port } = new URL(input);\n\n\t/**\n\t * localhost / IP-адреса / одноуровневые домены оставляем как есть\n\t */\n\tconst parts = hostname.split('.');\n\tconst baseHostname = !useMainDomain || parts.length <= 2 || /^[\\d.]+$/.test(hostname) || hostname === 'localhost'\n\t\t? hostname\n\t\t: parts.slice(-2).join('.');\n\n\treturn `${protocol}//${baseHostname}${port ? `:${port}` : ''}`;\n};\n","import type { Client } from './client';\nimport { createRequestOptions } from './request-options';\nimport { genExtRes } from '../utils/common';\n\nexport const createRequest = <\n\tRequestContext extends Api.ClientRequestContext<any, any, any>,\n\tFieldsNarrow extends Api.ParamsFields<RequestContext>,\n>(\n\tclient: Client<RequestContext['Paths'], RequestContext['UseExt']>,\n\tpath: RequestContext['Path'],\n\tfieldsNarrow?: FieldsNarrow,\n): Api.ClientRequest<RequestContext, FieldsNarrow> => {\n\tconst clientRequest = {\n\t\tinLoading: false,\n\t\tpath: path as Api.PathAbstract,\n\t\turl: client.options.baseUrl + path,\n\t\toptions: createRequestOptions(client.options.requestOptions),\n\t\tparams: {} as any, // незаполненное свойство\n\t\tgetInLoading: () => clientRequest.inLoading,\n\n\t\tsetParams: (params) => {\n\t\t\tclientRequest.params = { ...params } as any;\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tchangeParams: (params) => {\n\t\t\tObject.assign(clientRequest.params, params);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tsetOptions: (options) => {\n\t\t\tObject.assign(clientRequest.options, options);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tcall: async (fields?) => {\n\t\t\treturn clientRequest.exec(fields);\n\t\t},\n\n\t\tcallFetch: async (fetchStyle, fields?) => {\n\t\t\treturn clientRequest.exec(fields, fetchStyle);\n\t\t},\n\n\t\tcallInNewWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_blank');\n\t\t},\n\n\t\tcallInSelfWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_self');\n\t\t},\n\n\t\tgenData: (fields?, fetchStyle?) => {\n\t\t\tconst post: any = { ...clientRequest.params };\n\n\t\t\t// в старом коде fields вставлялись в params, оставлено для совместимости\n\t\t\t// delete post.fields;\n\t\t\tdelete post.fetch_style;\n\n\t\t\t// поля, указанные при запуске запроса\n\t\t\tif (fields) {\n\t\t\t\tlet fieldsPrepared = [...fields as any[]];\n\n\t\t\t\t// поля, указанные при создании запроса\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tfieldsPrepared = fieldsPrepared.filter(field => fieldsNarrow.includes(field));\n\t\t\t\t}\n\n\t\t\t\tpost.fields = fieldsPrepared;\n\t\t\t} else {\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tpost.fields = fieldsNarrow;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (fetchStyle) {\n\t\t\t\tpost.fetch_style = fetchStyle;\n\t\t\t}\n\n\t\t\treturn post;\n\t\t},\n\n\t\t/**\n\t\t * Общая функция выполнения запросов\n\t\t */\n\t\tasync exec(fields?: FieldsNarrow, fetchStyle?: RequestContext['ParamsFetchStyle']): Promise<any> {\n\t\t\tconst Request = client.options.Request;\n\t\t\tconst fetch = client.options.fetch;\n\n\t\t\tconst data = clientRequest.genData(fields, fetchStyle);\n\n\t\t\tconst middlewareCtxWithoutRequest = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtxWithoutRequest);\n\n\t\t\tlet url = clientRequest.url;\n\n\t\t\tlet requestInitBody: string | undefined = undefined;\n\t\t\tif (clientRequest.options.method !== 'POST') {\n\t\t\t\turl += '?' + await client.options.querySerializer(data);\n\t\t\t} else {\n\t\t\t\trequestInitBody = client.options.bodySerializer(data);\n\t\t\t}\n\n\t\t\t// checkFingerprint\n\t\t\tlet requestInitSignal: AbortController['signal'] | undefined;\n\n\t\t\tif (this.options.checkFingerprint) {\n\t\t\t\tconst fingerprint = this.path + this.options.checkFingerprint;\n\n\t\t\t\tclient.abortControllers[fingerprint]?.abort();\n\n\t\t\t\tconst controller = new AbortController();\n\n\t\t\t\tclient.abortControllers[fingerprint] = controller;\n\t\t\t\trequestInitSignal = controller.signal;\n\t\t\t}\n\n\t\t\tconst requestInit = {\n\t\t\t\t...client.options,\n\t\t\t\tmethod: clientRequest.options.method,\n\t\t\t\tbody: requestInitBody,\n\t\t\t\tsignal: requestInitSignal,\n\t\t\t};\n\n\t\t\tlet request = new Request(url, requestInit);\n\n\t\t\trequest.headers.set('x-request-id', middlewareCtxWithoutRequest.id);\n\t\t\trequest.headers.set('content-type', 'application/json');\n\t\t\trequest.headers.set('accept', clientRequest.options.accept);\n\n\t\t\tconst middlewareCtx: Api.MiddlewareCallbackParams = {\n\t\t\t\t...middlewareCtxWithoutRequest,\n\t\t\t\trequest,\n\t\t\t};\n\n\t\t\tclientRequest.inLoading = true;\n\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\n\t\t\tlet response: Response | undefined = undefined;\n\n\t\t\tconst requestOrResponse = await client.middlewareOnRequest(request, middlewareCtx);\n\n\t\t\tif (requestOrResponse instanceof Response) {\n\t\t\t\tresponse = requestOrResponse;\n\t\t\t} else if (requestOrResponse instanceof Request) {\n\t\t\t\trequest = requestOrResponse;\n\t\t\t}\n\n\t\t\tif (!response) {\n\t\t\t\ttry {\n\t\t\t\t\tresponse = await fetch(request);\n\t\t\t\t} catch (e) {\n\t\t\t\t\tresponse = await client.middlewareOnError(e, middlewareCtx);\n\t\t\t\t} finally {\n\t\t\t\t\tclientRequest.inLoading = false;\n\t\t\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tresponse = await client.middlewareOnResponse(response, middlewareCtx);\n\n\t\t\tlet res: any;\n\t\t\tlet responseText: string | undefined;\n\t\t\tlet formatError: undefined | Api.FormatError = undefined;\n\n\t\t\ttry {\n\t\t\t\t// json - стандартные формат, он может быть возвращен в запросах с другим responseType, если в них произошла ошибка\n\t\t\t\tconst isJSON = response.headers.get('content-type')?.includes('application/json');\n\n\t\t\t\tresponseText = await response.text();\n\n\t\t\t\tif (this.options.accept === 'application/json' || isJSON) {\n\t\t\t\t\tres = JSON.parse(responseText);\n\t\t\t\t} else {\n\t\t\t\t\tif (client.useExt) {\n\t\t\t\t\t\tres = genExtRes(responseText, undefined, response);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tres = responseText;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tif (e instanceof SyntaxError || e instanceof TypeError) {\n\t\t\t\t\tformatError = e;\n\t\t\t\t\tformatError.responseText = responseText;\n\t\t\t\t}\n\n\t\t\t\t// если в результате не пришел json, сгенерировать объект результата и добавить информацию об ответе API\n\t\t\t\tif (client.useExt && formatError) {\n\t\t\t\t\tlet errorCode = response.status;\n\t\t\t\t\tlet errorMessage = response.statusText;\n\n\t\t\t\t\tif (errorCode === 200) {\n\t\t\t\t\t\terrorCode = 10000;\n\t\t\t\t\t\terrorMessage = 'Error API response';\n\t\t\t\t\t}\n\n\t\t\t\t\tres = genExtRes(null, [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcode: errorCode,\n\t\t\t\t\t\t\tstring: errorMessage,\n\t\t\t\t\t\t},\n\t\t\t\t\t], response);\n\n\t\t\t\t\tif (client.options.useApiConsole) console.error(e);\n\t\t\t\t} else {\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (client.useExt) {\n\t\t\t\tres.response = response;\n\n\t\t\t\tif (res) {\n\t\t\t\t\tclientRequest.options.onApiLoaded?.(res, middlewareCtx);\n\t\t\t\t}\n\n\t\t\t\tif (res?.errors) {\n\t\t\t\t\tif (client.options.useApiConsole) console.warn(new Error('API error'), { res });\n\n\t\t\t\t\tclientRequest.options.onApiError?.(res, { ...middlewareCtx, formatError }, client.options.requestOptions?.onApiError);\n\t\t\t\t}\n\n\t\t\t\tif (res?.messages) {\n\t\t\t\t\tclientRequest.options.onApiMessage?.(res, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn res;\n\t\t},\n\t};\n\n\treturn clientRequest;\n};\n","import { createRequestOptions } from './request-options';\nimport { createRequest } from './request';\n\nexport class Client<paths extends Api.PathsAbstract, UseExt extends Api.Ext.UseExt> {\n\n\treadonly options: Readonly<Api.ClientOptions>;\n\treadonly useExt: UseExt;\n\treadonly middlewares: Api.Middleware[] = [];\n\tabortControllers: Record<string, AbortController> = {};\n\n\tconstructor(clientOptions: Partial<Api.ClientOptions> = {}, useExt: UseExt) {\n\t\tclientOptions.requestOptions = createRequestOptions(clientOptions.requestOptions);\n\t\tclientOptions.useApiConsole ??= true;\n\n\t\tclientOptions.fetch ??= globalThis.fetch;\n\t\tclientOptions.Request ??= globalThis.Request;\n\t\tclientOptions.querySerializer ??= async (params) => {\n\t\t\tconst { querySerializer } = await import('../utils/lazy');\n\n\t\t\treturn querySerializer(params);\n\t\t}\n\t\tclientOptions.bodySerializer ??= (body) => typeof body === 'string' ? body : JSON.stringify(body);\n\n\t\tthis.options = clientOptions as Api.ClientOptions;\n\n\t\tthis.useExt = useExt;\n\t}\n\n\tgenerateUUID() {\n\t\tif (crypto?.randomUUID) {\n\t\t\treturn crypto.randomUUID();\n\t\t}\n\n\t\treturn 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {\n\t\t\tconst r = Math.random() * 16 | 0;\n\t\t\tconst v = c === 'x' ? r : (r & 0x3 | 0x8);\n\t\t\treturn v.toString(16);\n\t\t});\n\t}\n\n\t/**\n\t * Зарегистрировать middleware\n\t */\n\tuse(middleware: Api.Middleware) {\n\t\tthis.middlewares.push(middleware);\n\t}\n\n\t/**\n\t * Создать объект запроса\n\t *\n\t * После создания объекта он заполняется необходимыми данными и выполняет запросы к API с помощью APIRequest2.call();\n\t *\n\t * Опционально generic указывать нельзя, поэтому необходимо дублировать определение fetchStyle, [см.](https://github.com/Microsoft/TypeScript/issues/26242)\n\t *\n\t * @param path Путь метода API\n\t * @param fieldsNarrow Список получаемых полей, для методов API с моделью. Если объект запроса переиспользуется, и список полей меняется, указывайте его непосредственно при вызове `api.call()`\n\t */\n\tgen<\n\t\tPath extends Api.Path<paths>,\n\t\tFieldsNarrow extends Api.ParamsFields<Api.ClientRequestContext<paths, Path, UseExt>>\n\t>(\n\t\tpath: Path,\n\t\tfieldsNarrow?: FieldsNarrow,\n\t): Api.ClientRequest<Api.ClientRequestContext<paths, Path, UseExt>, FieldsNarrow> {\n\t\ttype RequestContext = Api.ClientRequestContext<paths, Path, UseExt>;\n\n\t\treturn createRequest<RequestContext, FieldsNarrow>(this, path, fieldsNarrow);\n\t}\n\n\t/**\n\t * Создать объект запроса, не описанного в OpenAPI\n\t */\n\tgenAny<\n\t\tParams extends Record<string, any>,\n\t\tResult = any,\n\t\tFieldsNarrow extends Api.Ext.Schemas['Fields'] | undefined = undefined\n\t>(path: Api.PathAbstract, fieldsNarrow?: FieldsNarrow): Api.ClientRequestCustom<UseExt, Params, Result> {\n\t\treturn this.gen(path as any, fieldsNarrow as any) as unknown as Api.ClientRequestCustom<UseExt, Params, Result>;\n\t}\n\n\t/**\n\t * Создать контекст выполнения запроса\n\t */\n\tgenMiddlewareCtx(\n\t\tclientRequest: Api.ClientRequest<any, any, any>,\n\t\tdata: Record<string, any>,\n\t): Omit<Api.MiddlewareCallbackParams, 'request'> {\n\t\tconst id = this.generateUUID();\n\n\t\tconst options: Api.BaseOptions = Object.freeze({\n\t\t\tbaseUrl: this.options.baseUrl,\n\t\t\tquerySerializer: this.options.querySerializer,\n\t\t\tbodySerializer: this.options.bodySerializer,\n\t\t\tRequest: this.options.Request,\n\t\t\tfetch: this.options.fetch,\n\t\t});\n\n\t\treturn {\n\t\t\tuseExt: this.useExt,\n\t\t\trequestOptions: clientRequest.options,\n\t\t\tdata,\n\t\t\tmiddlewareData: {},\n\t\t\toptions,\n\t\t\tschemaPath: clientRequest.path,\n\t\t\tid,\n\t\t};\n\t};\n\n\t/**\n\t * Обработчик middleware.onRequest\n\t *\n\t * @param request Запрос для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Request` или `Response` при модификации запроса, или undefined\n\t */\n\tasync middlewareOnRequest(\n\t\trequest: Request,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Request | Response | undefined> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onRequest?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\trequest,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Request) {\n\t\t\t\t\trequest = result;\n\t\t\t\t} else if (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error('onRequest: must return new Request() or Response() when modifying the request');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn request;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param `error` Ошибка, переданная для обработки\n\t * @param middlewareCtx\n\t * @return Новый экземпляр `Response` при успешной обработке или выбрасывает ошибку\n\t */\n\tasync middlewareOnError(\n\t\terror: Error | unknown,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response | never> {\n\t\tlet errorAfterMiddleware = error;\n\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onError?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\terror: errorAfterMiddleware,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (result instanceof Error) {\n\t\t\t\t\terrorAfterMiddleware = result;\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tthrow new Error('onError: must return new Response() or instance of Error');\n\t\t\t}\n\t\t}\n\n\t\tthrow errorAfterMiddleware;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param response Ответ для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Response` при модификации ответа, или undefined\n\t */\n\tasync middlewareOnResponse(\n\t\tresponse: Response,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onResponse?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\tresponse,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (!(result instanceof Response)) {\n\t\t\t\t\tthrow new Error('onResponse: must return new Response() when modifying the response');\n\t\t\t\t}\n\n\t\t\t\tresponse = result;\n\t\t\t}\n\t\t}\n\n\t\treturn response;\n\t}\n\n}\n","import { Client } from './client/client';\n\nexport * from './utils/field';\nexport * from './utils/common';\n\nexport const postInWindow: typeof import('./utils/lazy').postInWindow = async (...args) => {\n\tconst { postInWindow } = await import('./utils/lazy');\n\n\treturn postInWindow(...args);\n};\n\nexport const dataToForm: typeof import('./utils/lazy').dataToForm = async (...args) => {\n\tconst { dataToForm } = await import('./utils/lazy');\n\n\treturn dataToForm(...args);\n};\n\n/**\n * Создать API клиент\n *\n * @see Api.Ext.UseExt\n */\nexport const createClient = <\n\tpaths extends Api.PathsAbstract,\n\tUseExt extends Api.Ext.UseExt\n>(\n\tclientOptions: Partial<Api.ClientOptions> = {},\n\tuseExt: UseExt,\n) => {\n\treturn new Client<paths, UseExt>(clientOptions, useExt);\n};\n"],"names":["createRequestOptions","requestOptions","genExtRes","result","errors","response","isPublicAPI","path","getBaseDomainUrl","useMainDomain","input","protocol","hostname","port","baseHostname","parts","clientRequest","params","options","fields","fetchStyle","fieldsPrepared","field","fieldsNarrow","post","Request","client","fetch","url","data","requestInitSignal","controller","fingerprint","request","middlewareCtxWithoutRequest","requestOrResponse","e","res","responseText","isJSON","_h","formatError","errorCode","errorMessage","Client","clientOptions","useExt","querySerializer","body","c","middleware","id","middlewareCtx","_a","error","errorAfterMiddleware","postInWindow","args","postInWindow2","dataToForm","dataToForm2","createClient"],"mappings":"4HAAO,MAAAA,EAAA,CAAAC,EAAA,CAAA,IAAA,OACN,OAAAA,EAAA,CAAA,GAAAA,CAAA,4DAEAA,EAAA,qBAAA,GACAA,EAAA,SAAA,OACAA,EAAA,SAAA,mBAEAA,GCFMC,EAAA,CAAAC,EAAAC,EAAAC,KAKN,CAAO,OAAAF,EACN,OAAAC,eAWKE,EAAAC,GACNA,EAAA,WAAA,mBAAA,EAMMC,EAAA,CAAAC,EAAA,GAAAC,EAAA,OAAA,SAAA,OAAA,CACN,KAAA,CAAA,SAAAC,EAAA,SAAAC,EAAA,KAAAC,CAAA,EAAA,IAAA,IAAAH,CAAA,iBAMAI,EAAA,CAAAL,GAAAM,EAAA,QAAA,GAAA,WAAA,KAAAH,CAAA,GAAAA,IAAA,YAAAA,EAAAG,EAAA,MAAA,EAAA,EAAA,KAAA,GAAA,mCAKD,oCC5Ba,KAAAR,wEAIF,aAAA,IAAAS,EAAA,UACyB,UAAAC,IAGjCD,EAAA,OAAA,CAAA,GAAAC,CAAA,EAEAD,GACD,aAAAC,8BAKCD,GACD,WAAAE,+BAKCF,GACD,KAAA,MAAAG,GAGCH,EAAA,KAAAG,CAAA,EACD,UAAA,MAAAC,EAAAD,gBAIA,gBAAA,MAAAA,GAAA,wNAUoD,EACpD,iBAAA,MAAAA,GAAA,uNAUmD,EACnD,QAAA,CAAAA,EAAAC,IAAA,kDAWE,IAAAC,EAAA,CAAA,GAAAF,CAAA,MAICE,EAAAA,EAAA,OAAAC,GAAAC,EAAA,SAAAD,CAAA,CAAA,GAGDE,EAAA,OAAAH,CAAc,UAGbG,EAAA,OAAAD,cAKDC,EAAA,YAAAJ,GAGDI,CAAO,EACR,MAAA,KAAAL,EAAAC,EAAA,mCAMC,MAAAK,EAAAC,EAAA,QAAA,QACAC,EAAAD,EAAA,QAAA,sGAQA,IAAAE,EAAAZ,EAAA,gCAICY,GAAA,IAAA,MAAAF,EAAA,QAAA,gBAAAG,CAAA,gCAMD,IAAAC,EAEA,GAAA,KAAA,QAAA,iBAAA,4FAKC,MAAAC,EAAA,IAAA,gBAEAL,EAAA,iBAAAM,CAAA,EAAAD,EACAD,EAAAC,EAAA,6BAIU,OAAAf,EAAA,QAAA,cAEJ,OAAAc,wGAQPG,EAAA,QAAA,IAAA,SAAAjB,EAAA,QAAA,MAAA,WAEoD,GAAAkB,aAKpDlB,EAAA,UAAA,gHAOAmB,aAAA,aACYA,aAAAV,YAMX,GAAA,CACCpB,EAAA,MAAAsB,EAAAM,CAAA,CAA8B,OAAAG,EAAA,iCAE4B,QAAA,CAE1DpB,EAAA,UAAA,kGAOF,IAAAqB,EACAC,IAGA,GAAA,CAEC,MAAAC,GAAAC,EAAAnC,EAAA,QAAA,IAAA,cAAA,IAAA,YAAAmC,EAAA,SAAA,oBAEAF,EAAA,MAAAjC,EAAA,KAAA,8CAGCgC,EAAA,KAAA,MAAAC,CAAA,EAEAZ,EAAA,0BAKD,OAAAU,EAAA,CAQA,4DAJCK,EAAA,aAAAH,GAIDZ,EAAA,QAAAe,EAAA,CACC,IAAAC,EAAArC,EAAA,OACAsC,EAAAtC,EAAA,WAEAqC,IAAA,oCAKAL,EAAAnC,EAAA,KAAA,SAEQ,OAAAyC,CACE,MAIVjB,EAAA,QAAA,eAAA,QAAA,MAAAU,CAAA,CAAiD,KAEjD,OAAAA,EAIF,OAAAV,EAAA,SACCW,EAAA,SAAAhC,0DAMAgC,GAAA,MAAAA,EAAA,4MAMAA,GAAA,MAAAA,EAAA,iEAKDA,IAIF,OAAArB,GCrPM,MAAA4B,CAAA,CAA6E,QAE1E,0CAG4C,YAAAC,EAAA,CAAA,EAAAC,EAAA,sCAIpDD,EAAA,gBAAA,GAEAA,EAAA,QAAA,WAAA,MACAA,EAAA,UAAA,WAAA,QACAA,EAAA,kBAAA,MAAA5B,GAAA,4FAGC,OAAA8B,EAAA9B,CAAA,CAA6B,EAE9B4B,EAAA,iBAAAG,GAAA,OAAAA,GAAA,SAAAA,EAAA,KAAA,UAAAA,CAAA,EAEA,KAAA,QAAAH,EAEA,KAAA,OAAAC,EACD,cAAA,CAGC,OAAA,qBAAA,WACC,OAAA,WAAA,wFAMA,OADAG,IAAA,IAAA,EAAA,EAAA,EAAA,GACA,SAAA,EAAA,CAAoB,CAAA,SAQrB,KAAA,YAAA,KAAAC,CAAA,EACD,IAAA3C,EAAAgB,EAAA,oBAsBA,OAAAhB,EAAAgB,EAAA,sBAWA,iBAAAP,EAAAa,EAAA,CASC,MAAAsB,EAAA,KAAA,aAAA,EAEAjC,EAAA,OAAA,OAAA,CAA+C,QAAA,KAAA,QAAA,QACxB,gBAAA,KAAA,QAAA,gBACQ,eAAA,KAAA,QAAA,eACD,QAAA,KAAA,QAAA,QACP,MAAA,KAAA,QAAA,KACF,CAAA,EAGrB,MAAA,CAAO,OAAA,KAAA,OACO,eAAAF,EAAA,QACiB,KAAAa,oBAEb,QAAAX,EACjB,WAAAF,EAAA,WAIF,MAAA,oBAAAiB,EAAAmB,EAAA,OAaC,UAAAF,KAAA,KAAA,YAAA,CACC,MAAA/C,EAAA,OAAAkD,EAAAH,EAAA,YAAA,YAAAG,EAAA,KAAAH,EAAA,CAA4C,GAAAE,WAE3C,SAIA,GAAAjD,aAAA,gBACW,IAAAA,aAAA,SAEV,OAAAA,EAEA,MAAA,IAAA,MAAA,+EAAA,GAKH,OAAA8B,EACD,MAAA,kBAAAqB,EAAAF,EAAA,eAeC,UAAAF,KAAA,KAAA,YAAA,CACC,MAAA/C,EAAA,OAAAkD,EAAAH,EAAA,UAAA,YAAAG,EAAA,KAAAH,EAAA,CAA0C,GAAAE,EACtC,MAAAG,CACI,UAIP,GAAApD,aAAA,SACC,OAAAA,EAGD,GAAAA,aAAA,MAAA,cAMA,MAAA,IAAA,MAAA,0DAAA,GAIF,MAAAoD,EACD,MAAA,qBAAAlD,EAAA+C,EAAA,OAaC,UAAAF,KAAA,KAAA,YAAA,CACC,MAAA/C,EAAA,OAAAkD,EAAAH,EAAA,aAAA,YAAAG,EAAA,KAAAH,EAAA,CAA6C,GAAAE,YAE5C,UAIA,GAAA,EAAAjD,aAAA,UACC,MAAA,IAAA,MAAA,oEAAA,OAOH,OAAAE,EAGF,CCxMO,MAAAmD,EAAA,SAAAC,IAAA,yFAGN,OAAAC,EAAA,GAAAD,CAAA,CACD,EAEOE,EAAA,SAAAF,IAAA,uFAGN,OAAAG,EAAA,GAAAH,CAAA,CACD,EAOOI,EAAA,CAAAhB,EAAA,CAAA,EAAAC,IAON,IAAAF,EAAAC,EAAAC,CAAA"}
package/api/index.js CHANGED
@@ -1,20 +1,20 @@
1
- import { g as Q, a as V } from "../.chunks/field-CyyFzM-Y.es.js";
2
- const j = (o = {}) => {
3
- var t;
4
- return o = { ...o }, o.loadingEl ??= (t = globalThis.document) == null ? void 0 : t.body, o.loadingShowSpinner ??= !0, o.method ??= "POST", o.accept ??= "application/json", o;
5
- }, W = (o, t, n) => ({
6
- result: o,
7
- errors: t,
1
+ import { g as V, a as X } from "../.chunks/field-CyyFzM-Y.es.js";
2
+ const M = (t = {}) => {
3
+ var o;
4
+ return t = { ...t }, t.loadingEl ??= (o = globalThis.document) == null ? void 0 : o.body, t.loadingShowSpinner ??= !0, t.method ??= "POST", t.accept ??= "application/json", t;
5
+ }, v = (t, o, n) => ({
6
+ result: t,
7
+ errors: o,
8
8
  response: n
9
- }), k = (o) => o.startsWith("/system_2/common/"), J = (o = !1, t = window.location.href) => {
10
- const { protocol: n, hostname: e, port: s } = new URL(t), r = e.split("."), i = !o || r.length <= 2 || /^[\d.]+$/.test(e) || e === "localhost" ? e : r.slice(-2).join(".");
11
- return `${n}//${i}${s ? `:${s}` : ""}`;
12
- }, _ = (o, t, n) => {
9
+ }), J = (t) => t.startsWith("/system_2/common/"), B = (t = !1, o = window.location.href) => {
10
+ const { protocol: n, hostname: e, port: s } = new URL(o), r = e.split("."), a = !t || r.length <= 2 || /^[\d.]+$/.test(e) || e === "localhost" ? e : r.slice(-2).join(".");
11
+ return `${n}//${a}${s ? `:${s}` : ""}`;
12
+ }, $ = (t, o, n) => {
13
13
  const e = {
14
14
  inLoading: !1,
15
- path: t,
16
- url: o.options.baseUrl + t,
17
- options: j(o.options.requestOptions),
15
+ path: o,
16
+ url: t.options.baseUrl + o,
17
+ options: M(t.options.requestOptions),
18
18
  params: {},
19
19
  // незаполненное свойство
20
20
  getInLoading: () => e.inLoading,
@@ -25,108 +25,110 @@ const j = (o = {}) => {
25
25
  callFetch: async (s, r) => e.exec(r, s),
26
26
  callInNewWindow: async (s) => {
27
27
  var d, u;
28
- const r = e.genData(s), i = o.genMiddlewareCtx(e, r);
29
- (u = (d = o.options).onPrepareData) == null || u.call(d, r, i);
28
+ const r = e.genData(s), a = t.genMiddlewareCtx(e, r);
29
+ (u = (d = t.options).onPrepareData) == null || u.call(d, r, a);
30
30
  const { postInWindow: l } = await import("../.chunks/lazy-Crun7esL.es.js");
31
31
  l(e.url, r, "_blank");
32
32
  },
33
33
  callInSelfWindow: async (s) => {
34
34
  var d, u;
35
- const r = e.genData(s), i = o.genMiddlewareCtx(e, r);
36
- (u = (d = o.options).onPrepareData) == null || u.call(d, r, i);
35
+ const r = e.genData(s), a = t.genMiddlewareCtx(e, r);
36
+ (u = (d = t.options).onPrepareData) == null || u.call(d, r, a);
37
37
  const { postInWindow: l } = await import("../.chunks/lazy-Crun7esL.es.js");
38
38
  l(e.url, r, "_self");
39
39
  },
40
40
  genData: (s, r) => {
41
- const i = { ...e.params };
42
- if (delete i.fetch_style, s) {
41
+ const a = { ...e.params };
42
+ if (delete a.fetch_style, s) {
43
43
  let l = [...s];
44
- n && (l = l.filter((d) => n.includes(d))), i.fields = l;
44
+ n && (l = l.filter((d) => n.includes(d))), a.fields = l;
45
45
  } else
46
- n && (i.fields = n);
47
- return r && (i.fetch_style = r), i;
46
+ n && (a.fields = n);
47
+ return r && (a.fetch_style = r), a;
48
48
  },
49
49
  /**
50
50
  * Общая функция выполнения запросов
51
51
  */
52
52
  async exec(s, r) {
53
- var E, q, b, S, I, C, A, D, P, U, T, L, z, O;
54
- const i = o.options.Request, l = o.options.fetch, d = e.genData(s, r), u = o.genMiddlewareCtx(e, d);
55
- (q = (E = o.options).onPrepareData) == null || q.call(E, d, u);
53
+ var q, b, S, C, I, A, D, P, U, T, L, z, O, F, W;
54
+ const a = t.options.Request, l = t.options.fetch, d = e.genData(s, r), u = t.genMiddlewareCtx(e, d);
55
+ (b = (q = t.options).onPrepareData) == null || b.call(q, d, u);
56
56
  let y = e.url, R;
57
- e.options.method !== "POST" ? y += "?" + await o.options.querySerializer(d) : R = o.options.bodySerializer(d);
58
- let v;
57
+ e.options.method !== "POST" ? y += "?" + await t.options.querySerializer(d) : R = t.options.bodySerializer(d);
58
+ let E;
59
59
  if (this.options.checkFingerprint) {
60
- const c = this.path + this.options.checkFingerprint, x = new AbortController();
61
- o.abortControllers[c] = x;
60
+ const c = this.path + this.options.checkFingerprint;
61
+ (S = t.abortControllers[c]) == null || S.abort();
62
+ const w = new AbortController();
63
+ t.abortControllers[c] = w, E = w.signal;
62
64
  }
63
- const M = {
64
- ...o.options,
65
+ const _ = {
66
+ ...t.options,
65
67
  method: e.options.method,
66
68
  body: R,
67
- signal: v
69
+ signal: E
68
70
  };
69
- let h = new i(y, M);
71
+ let h = new a(y, _);
70
72
  h.headers.set("x-request-id", u.id), h.headers.set("content-type", "application/json"), h.headers.set("accept", e.options.accept);
71
73
  const f = {
72
74
  ...u,
73
75
  request: h
74
76
  };
75
- e.inLoading = !0, (S = (b = e.options).onLoading) == null || S.call(b, e.inLoading, f);
77
+ e.inLoading = !0, (I = (C = e.options).onLoading) == null || I.call(C, e.inLoading, f);
76
78
  let p;
77
- const g = await o.middlewareOnRequest(h, f);
78
- if (g instanceof Response ? p = g : g instanceof i && (h = g), !p)
79
+ const g = await t.middlewareOnRequest(h, f);
80
+ if (g instanceof Response ? p = g : g instanceof a && (h = g), !p)
79
81
  try {
80
82
  p = await l(h);
81
83
  } catch (c) {
82
- p = await o.middlewareOnError(c, f);
84
+ p = await t.middlewareOnError(c, f);
83
85
  } finally {
84
- e.inLoading = !1, (C = (I = e.options).onLoading) == null || C.call(I, e.inLoading, f);
86
+ e.inLoading = !1, (D = (A = e.options).onLoading) == null || D.call(A, e.inLoading, f);
85
87
  }
86
- p = await o.middlewareOnResponse(p, f);
87
- let a, w, m;
88
+ p = await t.middlewareOnResponse(p, f);
89
+ let i, x, m;
88
90
  try {
89
- const c = (A = p.headers.get("content-type")) == null ? void 0 : A.includes("application/json");
90
- w = await p.text(), this.options.accept === "application/json" || c ? a = JSON.parse(w) : o.useExt ? a = W(w, void 0, p) : a = w;
91
+ const c = (P = p.headers.get("content-type")) == null ? void 0 : P.includes("application/json");
92
+ x = await p.text(), this.options.accept === "application/json" || c ? i = JSON.parse(x) : t.useExt ? i = v(x, void 0, p) : i = x;
91
93
  } catch (c) {
92
- if ((c instanceof SyntaxError || c instanceof TypeError) && (m = c, m.responseText = w), o.useExt && m) {
93
- let x = p.status, F = p.statusText;
94
- x === 200 && (x = 1e4, F = "Error API response"), a = W(null, [
94
+ if ((c instanceof SyntaxError || c instanceof TypeError) && (m = c, m.responseText = x), t.useExt && m) {
95
+ let w = p.status, j = p.statusText;
96
+ w === 200 && (w = 1e4, j = "Error API response"), i = v(null, [
95
97
  {
96
- code: x,
97
- string: F
98
+ code: w,
99
+ string: j
98
100
  }
99
- ], p), o.options.useApiConsole && console.error(c);
101
+ ], p), t.options.useApiConsole && console.error(c);
100
102
  } else
101
103
  throw c;
102
104
  }
103
- return o.useExt && (a.response = p, a && ((P = (D = e.options).onApiLoaded) == null || P.call(D, a, f)), a != null && a.errors && (o.options.useApiConsole && console.warn(new Error("API error"), { res: a }), (L = (T = e.options).onApiError) == null || L.call(T, a, { ...f, formatError: m }, (U = o.options.requestOptions) == null ? void 0 : U.onApiError)), a != null && a.messages && ((O = (z = e.options).onApiMessage) == null || O.call(z, a, f))), a;
105
+ return t.useExt && (i.response = p, i && ((T = (U = e.options).onApiLoaded) == null || T.call(U, i, f)), i != null && i.errors && (t.options.useApiConsole && console.warn(new Error("API error"), { res: i }), (O = (z = e.options).onApiError) == null || O.call(z, i, { ...f, formatError: m }, (L = t.options.requestOptions) == null ? void 0 : L.onApiError)), i != null && i.messages && ((W = (F = e.options).onApiMessage) == null || W.call(F, i, f))), i;
104
106
  }
105
107
  };
106
108
  return e;
107
109
  };
108
- class $ {
110
+ class k {
109
111
  options;
110
112
  useExt;
111
113
  middlewares = [];
112
114
  abortControllers = {};
113
- constructor(t = {}, n) {
114
- t.requestOptions = j(t.requestOptions), t.useApiConsole ??= !0, t.fetch ??= globalThis.fetch, t.Request ??= globalThis.Request, t.querySerializer ??= async (e) => {
115
+ constructor(o = {}, n) {
116
+ o.requestOptions = M(o.requestOptions), o.useApiConsole ??= !0, o.fetch ??= globalThis.fetch, o.Request ??= globalThis.Request, o.querySerializer ??= async (e) => {
115
117
  const { querySerializer: s } = await import("../.chunks/lazy-Crun7esL.es.js");
116
118
  return s(e);
117
- }, t.bodySerializer ??= (e) => typeof e == "string" ? e : JSON.stringify(e), this.options = t, this.useExt = n;
119
+ }, o.bodySerializer ??= (e) => typeof e == "string" ? e : JSON.stringify(e), this.options = o, this.useExt = n;
118
120
  }
119
121
  generateUUID() {
120
- return crypto != null && crypto.randomUUID ? crypto.randomUUID() : "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, (t) => {
122
+ return crypto != null && crypto.randomUUID ? crypto.randomUUID() : "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, (o) => {
121
123
  const n = Math.random() * 16 | 0;
122
- return (t === "x" ? n : n & 3 | 8).toString(16);
124
+ return (o === "x" ? n : n & 3 | 8).toString(16);
123
125
  });
124
126
  }
125
127
  /**
126
128
  * Зарегистрировать middleware
127
129
  */
128
- use(t) {
129
- this.middlewares.push(t);
130
+ use(o) {
131
+ this.middlewares.push(o);
130
132
  }
131
133
  /**
132
134
  * Создать объект запроса
@@ -138,19 +140,19 @@ class $ {
138
140
  * @param path Путь метода API
139
141
  * @param fieldsNarrow Список получаемых полей, для методов API с моделью. Если объект запроса переиспользуется, и список полей меняется, указывайте его непосредственно при вызове `api.call()`
140
142
  */
141
- gen(t, n) {
142
- return _(this, t, n);
143
+ gen(o, n) {
144
+ return $(this, o, n);
143
145
  }
144
146
  /**
145
147
  * Создать объект запроса, не описанного в OpenAPI
146
148
  */
147
- genAny(t, n) {
148
- return this.gen(t, n);
149
+ genAny(o, n) {
150
+ return this.gen(o, n);
149
151
  }
150
152
  /**
151
153
  * Создать контекст выполнения запроса
152
154
  */
153
- genMiddlewareCtx(t, n) {
155
+ genMiddlewareCtx(o, n) {
154
156
  const e = this.generateUUID(), s = Object.freeze({
155
157
  baseUrl: this.options.baseUrl,
156
158
  querySerializer: this.options.querySerializer,
@@ -160,11 +162,11 @@ class $ {
160
162
  });
161
163
  return {
162
164
  useExt: this.useExt,
163
- requestOptions: t.options,
165
+ requestOptions: o.options,
164
166
  data: n,
165
167
  middlewareData: {},
166
168
  options: s,
167
- schemaPath: t.path,
169
+ schemaPath: o.path,
168
170
  id: e
169
171
  };
170
172
  }
@@ -175,23 +177,23 @@ class $ {
175
177
  * @param middlewareCtx Контекст выполнения запроса
176
178
  * @return Новый экземпляр `Request` или `Response` при модификации запроса, или undefined
177
179
  */
178
- async middlewareOnRequest(t, n) {
180
+ async middlewareOnRequest(o, n) {
179
181
  var e;
180
182
  for (const s of this.middlewares) {
181
183
  const r = await ((e = s.onRequest) == null ? void 0 : e.call(s, {
182
184
  ...n,
183
- request: t
185
+ request: o
184
186
  }));
185
187
  if (r)
186
188
  if (r instanceof Request)
187
- t = r;
189
+ o = r;
188
190
  else {
189
191
  if (r instanceof Response)
190
192
  return r;
191
193
  throw new Error("onRequest: must return new Request() or Response() when modifying the request");
192
194
  }
193
195
  }
194
- return t;
196
+ return o;
195
197
  }
196
198
  /**
197
199
  * Обработчик middleware.onResponse
@@ -200,19 +202,19 @@ class $ {
200
202
  * @param middlewareCtx
201
203
  * @return Новый экземпляр `Response` при успешной обработке или выбрасывает ошибку
202
204
  */
203
- async middlewareOnError(t, n) {
205
+ async middlewareOnError(o, n) {
204
206
  var s;
205
- let e = t;
207
+ let e = o;
206
208
  for (const r of this.middlewares) {
207
- const i = await ((s = r.onError) == null ? void 0 : s.call(r, {
209
+ const a = await ((s = r.onError) == null ? void 0 : s.call(r, {
208
210
  ...n,
209
211
  error: e
210
212
  }));
211
- if (i) {
212
- if (i instanceof Response)
213
- return i;
214
- if (i instanceof Error) {
215
- e = i;
213
+ if (a) {
214
+ if (a instanceof Response)
215
+ return a;
216
+ if (a instanceof Error) {
217
+ e = a;
216
218
  continue;
217
219
  }
218
220
  throw new Error("onError: must return new Response() or instance of Error");
@@ -227,37 +229,37 @@ class $ {
227
229
  * @param middlewareCtx Контекст выполнения запроса
228
230
  * @return Новый экземпляр `Response` при модификации ответа, или undefined
229
231
  */
230
- async middlewareOnResponse(t, n) {
232
+ async middlewareOnResponse(o, n) {
231
233
  var e;
232
234
  for (const s of this.middlewares) {
233
235
  const r = await ((e = s.onResponse) == null ? void 0 : e.call(s, {
234
236
  ...n,
235
- response: t
237
+ response: o
236
238
  }));
237
239
  if (r) {
238
240
  if (!(r instanceof Response))
239
241
  throw new Error("onResponse: must return new Response() when modifying the response");
240
- t = r;
242
+ o = r;
241
243
  }
242
244
  }
243
- return t;
245
+ return o;
244
246
  }
245
247
  }
246
- const B = async (...o) => {
247
- const { postInWindow: t } = await import("../.chunks/lazy-Crun7esL.es.js");
248
- return t(...o);
249
- }, H = async (...o) => {
250
- const { dataToForm: t } = await import("../.chunks/lazy-Crun7esL.es.js");
251
- return t(...o);
252
- }, N = (o = {}, t) => new $(o, t);
248
+ const H = async (...t) => {
249
+ const { postInWindow: o } = await import("../.chunks/lazy-Crun7esL.es.js");
250
+ return o(...t);
251
+ }, N = async (...t) => {
252
+ const { dataToForm: o } = await import("../.chunks/lazy-Crun7esL.es.js");
253
+ return o(...t);
254
+ }, G = (t = {}, o) => new k(t, o);
253
255
  export {
254
- N as createClient,
255
- H as dataToForm,
256
- W as genExtRes,
257
- Q as genFieldFilter,
258
- V as genFieldOrder,
259
- J as getBaseDomainUrl,
260
- k as isPublicAPI,
261
- B as postInWindow
256
+ G as createClient,
257
+ N as dataToForm,
258
+ v as genExtRes,
259
+ V as genFieldFilter,
260
+ X as genFieldOrder,
261
+ B as getBaseDomainUrl,
262
+ J as isPublicAPI,
263
+ H as postInWindow
262
264
  };
263
265
  //# sourceMappingURL=index.js.map
package/api/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/api/api/client/request-options.ts","../../src/api/api/utils/common.ts","../../src/api/api/client/request.ts","../../src/api/api/client/client.ts","../../src/api/api/index.ts"],"sourcesContent":["export const createRequestOptions = (requestOptions: Partial<Api.ClientRequestOptions> = {}): Api.ClientRequestOptions => {\n\trequestOptions = { ...requestOptions };\n\trequestOptions.loadingEl ??= globalThis.document?.body;\n\trequestOptions.loadingShowSpinner ??= true;\n\trequestOptions.method ??= 'POST';\n\trequestOptions.accept ??= 'application/json';\n\n\treturn requestOptions as Api.ClientRequestOptions;\n};\n","/**\n * Сгенерировать объект ответа в формате расширения OpenAPI\n *\n * @see Api.Ext\n */\nexport const genExtRes = (\n\tresult: any,\n\terrors?: Api.Ext.Schemas['ResponseError']['errors'],\n\tresponse?: Response,\n): Api.Response<any> => {\n\treturn {\n\t\tresult,\n\t\terrors,\n\t\tresponse,\n\t};\n};\n\n/**\n * Это публичное API, к которому открыт доступ по прямой ссылке через GET\n *\n * Используется для кеширования и генерации файлов через API\n */\nexport const isPublicAPI = (path: Api.PathAbstract) => {\n\treturn path.startsWith('/system_2/common/');\n};\n\n/**\n * Сгенерировать baseUrl на основе текущего домена\n */\nexport const getBaseDomainUrl = (useMainDomain = false, input: string = window.location.href) => {\n\tconst { protocol, hostname, port } = new URL(input);\n\n\t/**\n\t * localhost / IP-адреса / одноуровневые домены оставляем как есть\n\t */\n\tconst parts = hostname.split('.');\n\tconst baseHostname = !useMainDomain || parts.length <= 2 || /^[\\d.]+$/.test(hostname) || hostname === 'localhost'\n\t\t? hostname\n\t\t: parts.slice(-2).join('.');\n\n\treturn `${protocol}//${baseHostname}${port ? `:${port}` : ''}`;\n};\n","import type { Client } from './client';\nimport { createRequestOptions } from './request-options';\nimport { genExtRes } from '../utils/common';\n\nexport const createRequest = <\n\tRequestContext extends Api.ClientRequestContext<any, any, any>,\n\tFieldsNarrow extends Api.ParamsFields<RequestContext>,\n>(\n\tclient: Client<RequestContext['Paths'], RequestContext['UseExt']>,\n\tpath: RequestContext['Path'],\n\tfieldsNarrow?: FieldsNarrow,\n): Api.ClientRequest<RequestContext, FieldsNarrow> => {\n\tconst clientRequest = {\n\t\tinLoading: false,\n\t\tpath: path as Api.PathAbstract,\n\t\turl: client.options.baseUrl + path,\n\t\toptions: createRequestOptions(client.options.requestOptions),\n\t\tparams: {} as any, // незаполненное свойство\n\t\tgetInLoading: () => clientRequest.inLoading,\n\n\t\tsetParams: (params) => {\n\t\t\tclientRequest.params = { ...params } as any;\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tchangeParams: (params) => {\n\t\t\tObject.assign(clientRequest.params, params);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tsetOptions: (options) => {\n\t\t\tObject.assign(clientRequest.options, options);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tcall: async (fields?) => {\n\t\t\treturn clientRequest.exec(fields);\n\t\t},\n\n\t\tcallFetch: async (fetchStyle, fields?) => {\n\t\t\treturn clientRequest.exec(fields, fetchStyle);\n\t\t},\n\n\t\tcallInNewWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_blank');\n\t\t},\n\n\t\tcallInSelfWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_self');\n\t\t},\n\n\t\tgenData: (fields?, fetchStyle?) => {\n\t\t\tconst post: any = { ...clientRequest.params };\n\n\t\t\t// в старом коде fields вставлялись в params, оставлено для совместимости\n\t\t\t// delete post.fields;\n\t\t\tdelete post.fetch_style;\n\n\t\t\t// поля, указанные при запуске запроса\n\t\t\tif (fields) {\n\t\t\t\tlet fieldsPrepared = [...fields as any[]];\n\n\t\t\t\t// поля, указанные при создании запроса\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tfieldsPrepared = fieldsPrepared.filter(field => fieldsNarrow.includes(field));\n\t\t\t\t}\n\n\t\t\t\tpost.fields = fieldsPrepared;\n\t\t\t} else {\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tpost.fields = fieldsNarrow;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (fetchStyle) {\n\t\t\t\tpost.fetch_style = fetchStyle;\n\t\t\t}\n\n\t\t\treturn post;\n\t\t},\n\n\t\t/**\n\t\t * Общая функция выполнения запросов\n\t\t */\n\t\tasync exec(fields?: FieldsNarrow, fetchStyle?: RequestContext['ParamsFetchStyle']): Promise<any> {\n\t\t\tconst Request = client.options.Request;\n\t\t\tconst fetch = client.options.fetch;\n\n\t\t\tconst data = clientRequest.genData(fields, fetchStyle);\n\n\t\t\tconst middlewareCtxWithoutRequest = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtxWithoutRequest);\n\n\t\t\tlet url = clientRequest.url;\n\n\t\t\tlet requestInitBody: string | undefined = undefined;\n\t\t\tif (clientRequest.options.method !== 'POST') {\n\t\t\t\turl += '?' + await client.options.querySerializer(data);\n\t\t\t} else {\n\t\t\t\trequestInitBody = client.options.bodySerializer(data);\n\t\t\t}\n\n\t\t\t// checkFingerprint\n\t\t\tlet requestInitSignal: AbortController['signal'] | undefined;\n\n\t\t\tif (this.options.checkFingerprint) {\n\t\t\t\tconst fingerprint = this.path + this.options.checkFingerprint;\n\n\t\t\t\tconst controller = new AbortController();\n\t\t\t\tclient.abortControllers[fingerprint] = controller;\n\n\t\t\t}\n\n\t\t\tconst requestInit = {\n\t\t\t\t...client.options,\n\t\t\t\tmethod: clientRequest.options.method,\n\t\t\t\tbody: requestInitBody,\n\t\t\t\tsignal: requestInitSignal,\n\t\t\t};\n\n\t\t\tlet request = new Request(url, requestInit);\n\n\t\t\trequest.headers.set('x-request-id', middlewareCtxWithoutRequest.id);\n\t\t\trequest.headers.set('content-type', 'application/json');\n\t\t\trequest.headers.set('accept', clientRequest.options.accept);\n\n\t\t\tconst middlewareCtx: Api.MiddlewareCallbackParams = {\n\t\t\t\t...middlewareCtxWithoutRequest,\n\t\t\t\trequest,\n\t\t\t};\n\n\t\t\tclientRequest.inLoading = true;\n\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\n\t\t\tlet response: Response | undefined = undefined;\n\n\t\t\tconst requestOrResponse = await client.middlewareOnRequest(request, middlewareCtx);\n\n\t\t\tif (requestOrResponse instanceof Response) {\n\t\t\t\tresponse = requestOrResponse;\n\t\t\t} else if (requestOrResponse instanceof Request) {\n\t\t\t\trequest = requestOrResponse;\n\t\t\t}\n\n\t\t\tif (!response) {\n\t\t\t\ttry {\n\t\t\t\t\tresponse = await fetch(request);\n\t\t\t\t} catch (e) {\n\t\t\t\t\tresponse = await client.middlewareOnError(e, middlewareCtx);\n\t\t\t\t} finally {\n\t\t\t\t\tclientRequest.inLoading = false;\n\t\t\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tresponse = await client.middlewareOnResponse(response, middlewareCtx);\n\n\t\t\tlet res: any;\n\t\t\tlet responseText: string | undefined;\n\t\t\tlet formatError: undefined | Api.FormatError = undefined;\n\n\t\t\ttry {\n\t\t\t\t// json - стандартные формат, он может быть возвращен в запросах с другим responseType, если в них произошла ошибка\n\t\t\t\tconst isJSON = response.headers.get('content-type')?.includes('application/json');\n\n\t\t\t\tresponseText = await response.text();\n\n\t\t\t\tif (this.options.accept === 'application/json' || isJSON) {\n\t\t\t\t\tres = JSON.parse(responseText);\n\t\t\t\t} else {\n\t\t\t\t\tif (client.useExt) {\n\t\t\t\t\t\tres = genExtRes(responseText, undefined, response);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tres = responseText;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tif (e instanceof SyntaxError || e instanceof TypeError) {\n\t\t\t\t\tformatError = e;\n\t\t\t\t\tformatError.responseText = responseText;\n\t\t\t\t}\n\n\t\t\t\t// если в результате не пришел json, сгенерировать объект результата и добавить информацию об ответе API\n\t\t\t\tif (client.useExt && formatError) {\n\t\t\t\t\tlet errorCode = response.status;\n\t\t\t\t\tlet errorMessage = response.statusText;\n\n\t\t\t\t\tif (errorCode === 200) {\n\t\t\t\t\t\terrorCode = 10000;\n\t\t\t\t\t\terrorMessage = 'Error API response';\n\t\t\t\t\t}\n\n\t\t\t\t\tres = genExtRes(null, [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcode: errorCode,\n\t\t\t\t\t\t\tstring: errorMessage,\n\t\t\t\t\t\t},\n\t\t\t\t\t], response);\n\n\t\t\t\t\tif (client.options.useApiConsole) console.error(e);\n\t\t\t\t} else {\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (client.useExt) {\n\t\t\t\tres.response = response;\n\n\t\t\t\tif (res) {\n\t\t\t\t\tclientRequest.options.onApiLoaded?.(res, middlewareCtx);\n\t\t\t\t}\n\n\t\t\t\tif (res?.errors) {\n\t\t\t\t\tif (client.options.useApiConsole) console.warn(new Error('API error'), { res });\n\n\t\t\t\t\tclientRequest.options.onApiError?.(res, { ...middlewareCtx, formatError }, client.options.requestOptions?.onApiError);\n\t\t\t\t}\n\n\t\t\t\tif (res?.messages) {\n\t\t\t\t\tclientRequest.options.onApiMessage?.(res, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn res;\n\t\t},\n\t};\n\n\treturn clientRequest;\n};\n","import { createRequestOptions } from './request-options';\nimport { createRequest } from './request';\n\nexport class Client<paths extends Api.PathsAbstract, UseExt extends Api.Ext.UseExt> {\n\n\treadonly options: Readonly<Api.ClientOptions>;\n\treadonly useExt: UseExt;\n\treadonly middlewares: Api.Middleware[] = [];\n\tabortControllers: Record<string, AbortController> = {};\n\n\tconstructor(clientOptions: Partial<Api.ClientOptions> = {}, useExt: UseExt) {\n\t\tclientOptions.requestOptions = createRequestOptions(clientOptions.requestOptions);\n\t\tclientOptions.useApiConsole ??= true;\n\n\t\tclientOptions.fetch ??= globalThis.fetch;\n\t\tclientOptions.Request ??= globalThis.Request;\n\t\tclientOptions.querySerializer ??= async (params) => {\n\t\t\tconst { querySerializer } = await import('../utils/lazy');\n\n\t\t\treturn querySerializer(params);\n\t\t}\n\t\tclientOptions.bodySerializer ??= (body) => typeof body === 'string' ? body : JSON.stringify(body);\n\n\t\tthis.options = clientOptions as Api.ClientOptions;\n\n\t\tthis.useExt = useExt;\n\t}\n\n\tgenerateUUID() {\n\t\tif (crypto?.randomUUID) {\n\t\t\treturn crypto.randomUUID();\n\t\t}\n\n\t\treturn 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {\n\t\t\tconst r = Math.random() * 16 | 0;\n\t\t\tconst v = c === 'x' ? r : (r & 0x3 | 0x8);\n\t\t\treturn v.toString(16);\n\t\t});\n\t}\n\n\t/**\n\t * Зарегистрировать middleware\n\t */\n\tuse(middleware: Api.Middleware) {\n\t\tthis.middlewares.push(middleware);\n\t}\n\n\t/**\n\t * Создать объект запроса\n\t *\n\t * После создания объекта он заполняется необходимыми данными и выполняет запросы к API с помощью APIRequest2.call();\n\t *\n\t * Опционально generic указывать нельзя, поэтому необходимо дублировать определение fetchStyle, [см.](https://github.com/Microsoft/TypeScript/issues/26242)\n\t *\n\t * @param path Путь метода API\n\t * @param fieldsNarrow Список получаемых полей, для методов API с моделью. Если объект запроса переиспользуется, и список полей меняется, указывайте его непосредственно при вызове `api.call()`\n\t */\n\tgen<\n\t\tPath extends Api.Path<paths>,\n\t\tFieldsNarrow extends Api.ParamsFields<Api.ClientRequestContext<paths, Path, UseExt>>\n\t>(\n\t\tpath: Path,\n\t\tfieldsNarrow?: FieldsNarrow,\n\t): Api.ClientRequest<Api.ClientRequestContext<paths, Path, UseExt>, FieldsNarrow> {\n\t\ttype RequestContext = Api.ClientRequestContext<paths, Path, UseExt>;\n\n\t\treturn createRequest<RequestContext, FieldsNarrow>(this, path, fieldsNarrow);\n\t}\n\n\t/**\n\t * Создать объект запроса, не описанного в OpenAPI\n\t */\n\tgenAny<\n\t\tParams extends Record<string, any>,\n\t\tResult = any,\n\t\tFieldsNarrow extends Api.Ext.Schemas['Fields'] | undefined = undefined\n\t>(path: Api.PathAbstract, fieldsNarrow?: FieldsNarrow): Api.ClientRequestCustom<UseExt, Params, Result> {\n\t\treturn this.gen(path as any, fieldsNarrow as any) as unknown as Api.ClientRequestCustom<UseExt, Params, Result>;\n\t}\n\n\t/**\n\t * Создать контекст выполнения запроса\n\t */\n\tgenMiddlewareCtx(\n\t\tclientRequest: Api.ClientRequest<any, any, any>,\n\t\tdata: Record<string, any>,\n\t): Omit<Api.MiddlewareCallbackParams, 'request'> {\n\t\tconst id = this.generateUUID();\n\n\t\tconst options: Api.BaseOptions = Object.freeze({\n\t\t\tbaseUrl: this.options.baseUrl,\n\t\t\tquerySerializer: this.options.querySerializer,\n\t\t\tbodySerializer: this.options.bodySerializer,\n\t\t\tRequest: this.options.Request,\n\t\t\tfetch: this.options.fetch,\n\t\t});\n\n\t\treturn {\n\t\t\tuseExt: this.useExt,\n\t\t\trequestOptions: clientRequest.options,\n\t\t\tdata,\n\t\t\tmiddlewareData: {},\n\t\t\toptions,\n\t\t\tschemaPath: clientRequest.path,\n\t\t\tid,\n\t\t};\n\t};\n\n\t/**\n\t * Обработчик middleware.onRequest\n\t *\n\t * @param request Запрос для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Request` или `Response` при модификации запроса, или undefined\n\t */\n\tasync middlewareOnRequest(\n\t\trequest: Request,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Request | Response | undefined> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onRequest?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\trequest,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Request) {\n\t\t\t\t\trequest = result;\n\t\t\t\t} else if (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error('onRequest: must return new Request() or Response() when modifying the request');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn request;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param `error` Ошибка, переданная для обработки\n\t * @param middlewareCtx\n\t * @return Новый экземпляр `Response` при успешной обработке или выбрасывает ошибку\n\t */\n\tasync middlewareOnError(\n\t\terror: Error | unknown,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response | never> {\n\t\tlet errorAfterMiddleware = error;\n\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onError?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\terror: errorAfterMiddleware,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (result instanceof Error) {\n\t\t\t\t\terrorAfterMiddleware = result;\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tthrow new Error('onError: must return new Response() or instance of Error');\n\t\t\t}\n\t\t}\n\n\t\tthrow errorAfterMiddleware;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param response Ответ для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Response` при модификации ответа, или undefined\n\t */\n\tasync middlewareOnResponse(\n\t\tresponse: Response,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onResponse?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\tresponse,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (!(result instanceof Response)) {\n\t\t\t\t\tthrow new Error('onResponse: must return new Response() when modifying the response');\n\t\t\t\t}\n\n\t\t\t\tresponse = result;\n\t\t\t}\n\t\t}\n\n\t\treturn response;\n\t}\n\n}\n","import { Client } from './client/client';\n\nexport * from './utils/field';\nexport * from './utils/common';\n\nexport const postInWindow: typeof import('./utils/lazy').postInWindow = async (...args) => {\n\tconst { postInWindow } = await import('./utils/lazy');\n\n\treturn postInWindow(...args);\n};\n\nexport const dataToForm: typeof import('./utils/lazy').dataToForm = async (...args) => {\n\tconst { dataToForm } = await import('./utils/lazy');\n\n\treturn dataToForm(...args);\n};\n\n/**\n * Создать API клиент\n *\n * @see Api.Ext.UseExt\n */\nexport const createClient = <\n\tpaths extends Api.PathsAbstract,\n\tUseExt extends Api.Ext.UseExt\n>(\n\tclientOptions: Partial<Api.ClientOptions> = {},\n\tuseExt: UseExt,\n) => {\n\treturn new Client<paths, UseExt>(clientOptions, useExt);\n};\n"],"names":["createRequestOptions","requestOptions","_a","genExtRes","result","errors","response","isPublicAPI","path","getBaseDomainUrl","useMainDomain","input","protocol","hostname","port","parts","baseHostname","createRequest","client","fieldsNarrow","clientRequest","params","options","fields","fetchStyle","data","middlewareCtx","_b","postInWindow","post","fieldsPrepared","field","Request","fetch","middlewareCtxWithoutRequest","url","requestInitBody","requestInitSignal","fingerprint","controller","requestInit","request","_d","_c","requestOrResponse","e","_f","_e","res","responseText","formatError","isJSON","_g","errorCode","errorMessage","_i","_h","_l","_k","_j","_n","_m","Client","clientOptions","useExt","querySerializer","body","c","r","middleware","id","error","errorAfterMiddleware","args","dataToForm","createClient"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../src/api/api/client/request-options.ts","../../src/api/api/utils/common.ts","../../src/api/api/client/request.ts","../../src/api/api/client/client.ts","../../src/api/api/index.ts"],"sourcesContent":["export const createRequestOptions = (requestOptions: Partial<Api.ClientRequestOptions> = {}): Api.ClientRequestOptions => {\n\trequestOptions = { ...requestOptions };\n\trequestOptions.loadingEl ??= globalThis.document?.body;\n\trequestOptions.loadingShowSpinner ??= true;\n\trequestOptions.method ??= 'POST';\n\trequestOptions.accept ??= 'application/json';\n\n\treturn requestOptions as Api.ClientRequestOptions;\n};\n","/**\n * Сгенерировать объект ответа в формате расширения OpenAPI\n *\n * @see Api.Ext\n */\nexport const genExtRes = (\n\tresult: any,\n\terrors?: Api.Ext.Schemas['ResponseError']['errors'],\n\tresponse?: Response,\n): Api.Response<any> => {\n\treturn {\n\t\tresult,\n\t\terrors,\n\t\tresponse,\n\t};\n};\n\n/**\n * Это публичное API, к которому открыт доступ по прямой ссылке через GET\n *\n * Используется для кеширования и генерации файлов через API\n */\nexport const isPublicAPI = (path: Api.PathAbstract) => {\n\treturn path.startsWith('/system_2/common/');\n};\n\n/**\n * Сгенерировать baseUrl на основе текущего домена\n */\nexport const getBaseDomainUrl = (useMainDomain = false, input: string = window.location.href) => {\n\tconst { protocol, hostname, port } = new URL(input);\n\n\t/**\n\t * localhost / IP-адреса / одноуровневые домены оставляем как есть\n\t */\n\tconst parts = hostname.split('.');\n\tconst baseHostname = !useMainDomain || parts.length <= 2 || /^[\\d.]+$/.test(hostname) || hostname === 'localhost'\n\t\t? hostname\n\t\t: parts.slice(-2).join('.');\n\n\treturn `${protocol}//${baseHostname}${port ? `:${port}` : ''}`;\n};\n","import type { Client } from './client';\nimport { createRequestOptions } from './request-options';\nimport { genExtRes } from '../utils/common';\n\nexport const createRequest = <\n\tRequestContext extends Api.ClientRequestContext<any, any, any>,\n\tFieldsNarrow extends Api.ParamsFields<RequestContext>,\n>(\n\tclient: Client<RequestContext['Paths'], RequestContext['UseExt']>,\n\tpath: RequestContext['Path'],\n\tfieldsNarrow?: FieldsNarrow,\n): Api.ClientRequest<RequestContext, FieldsNarrow> => {\n\tconst clientRequest = {\n\t\tinLoading: false,\n\t\tpath: path as Api.PathAbstract,\n\t\turl: client.options.baseUrl + path,\n\t\toptions: createRequestOptions(client.options.requestOptions),\n\t\tparams: {} as any, // незаполненное свойство\n\t\tgetInLoading: () => clientRequest.inLoading,\n\n\t\tsetParams: (params) => {\n\t\t\tclientRequest.params = { ...params } as any;\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tchangeParams: (params) => {\n\t\t\tObject.assign(clientRequest.params, params);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tsetOptions: (options) => {\n\t\t\tObject.assign(clientRequest.options, options);\n\n\t\t\treturn clientRequest;\n\t\t},\n\n\t\tcall: async (fields?) => {\n\t\t\treturn clientRequest.exec(fields);\n\t\t},\n\n\t\tcallFetch: async (fetchStyle, fields?) => {\n\t\t\treturn clientRequest.exec(fields, fetchStyle);\n\t\t},\n\n\t\tcallInNewWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_blank');\n\t\t},\n\n\t\tcallInSelfWindow: async (fields?) => {\n\t\t\tconst data = clientRequest.genData(fields);\n\n\t\t\tconst middlewareCtx = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtx);\n\n\t\t\tconst { postInWindow } = await import('../utils/lazy');\n\t\t\tvoid postInWindow(clientRequest.url, data, '_self');\n\t\t},\n\n\t\tgenData: (fields?, fetchStyle?) => {\n\t\t\tconst post: any = { ...clientRequest.params };\n\n\t\t\t// в старом коде fields вставлялись в params, оставлено для совместимости\n\t\t\t// delete post.fields;\n\t\t\tdelete post.fetch_style;\n\n\t\t\t// поля, указанные при запуске запроса\n\t\t\tif (fields) {\n\t\t\t\tlet fieldsPrepared = [...fields as any[]];\n\n\t\t\t\t// поля, указанные при создании запроса\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tfieldsPrepared = fieldsPrepared.filter(field => fieldsNarrow.includes(field));\n\t\t\t\t}\n\n\t\t\t\tpost.fields = fieldsPrepared;\n\t\t\t} else {\n\t\t\t\tif (fieldsNarrow) {\n\t\t\t\t\tpost.fields = fieldsNarrow;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (fetchStyle) {\n\t\t\t\tpost.fetch_style = fetchStyle;\n\t\t\t}\n\n\t\t\treturn post;\n\t\t},\n\n\t\t/**\n\t\t * Общая функция выполнения запросов\n\t\t */\n\t\tasync exec(fields?: FieldsNarrow, fetchStyle?: RequestContext['ParamsFetchStyle']): Promise<any> {\n\t\t\tconst Request = client.options.Request;\n\t\t\tconst fetch = client.options.fetch;\n\n\t\t\tconst data = clientRequest.genData(fields, fetchStyle);\n\n\t\t\tconst middlewareCtxWithoutRequest = client.genMiddlewareCtx(clientRequest, data);\n\n\t\t\tclient.options.onPrepareData?.(data, middlewareCtxWithoutRequest);\n\n\t\t\tlet url = clientRequest.url;\n\n\t\t\tlet requestInitBody: string | undefined = undefined;\n\t\t\tif (clientRequest.options.method !== 'POST') {\n\t\t\t\turl += '?' + await client.options.querySerializer(data);\n\t\t\t} else {\n\t\t\t\trequestInitBody = client.options.bodySerializer(data);\n\t\t\t}\n\n\t\t\t// checkFingerprint\n\t\t\tlet requestInitSignal: AbortController['signal'] | undefined;\n\n\t\t\tif (this.options.checkFingerprint) {\n\t\t\t\tconst fingerprint = this.path + this.options.checkFingerprint;\n\n\t\t\t\tclient.abortControllers[fingerprint]?.abort();\n\n\t\t\t\tconst controller = new AbortController();\n\n\t\t\t\tclient.abortControllers[fingerprint] = controller;\n\t\t\t\trequestInitSignal = controller.signal;\n\t\t\t}\n\n\t\t\tconst requestInit = {\n\t\t\t\t...client.options,\n\t\t\t\tmethod: clientRequest.options.method,\n\t\t\t\tbody: requestInitBody,\n\t\t\t\tsignal: requestInitSignal,\n\t\t\t};\n\n\t\t\tlet request = new Request(url, requestInit);\n\n\t\t\trequest.headers.set('x-request-id', middlewareCtxWithoutRequest.id);\n\t\t\trequest.headers.set('content-type', 'application/json');\n\t\t\trequest.headers.set('accept', clientRequest.options.accept);\n\n\t\t\tconst middlewareCtx: Api.MiddlewareCallbackParams = {\n\t\t\t\t...middlewareCtxWithoutRequest,\n\t\t\t\trequest,\n\t\t\t};\n\n\t\t\tclientRequest.inLoading = true;\n\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\n\t\t\tlet response: Response | undefined = undefined;\n\n\t\t\tconst requestOrResponse = await client.middlewareOnRequest(request, middlewareCtx);\n\n\t\t\tif (requestOrResponse instanceof Response) {\n\t\t\t\tresponse = requestOrResponse;\n\t\t\t} else if (requestOrResponse instanceof Request) {\n\t\t\t\trequest = requestOrResponse;\n\t\t\t}\n\n\t\t\tif (!response) {\n\t\t\t\ttry {\n\t\t\t\t\tresponse = await fetch(request);\n\t\t\t\t} catch (e) {\n\t\t\t\t\tresponse = await client.middlewareOnError(e, middlewareCtx);\n\t\t\t\t} finally {\n\t\t\t\t\tclientRequest.inLoading = false;\n\t\t\t\t\tclientRequest.options.onLoading?.(clientRequest.inLoading, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tresponse = await client.middlewareOnResponse(response, middlewareCtx);\n\n\t\t\tlet res: any;\n\t\t\tlet responseText: string | undefined;\n\t\t\tlet formatError: undefined | Api.FormatError = undefined;\n\n\t\t\ttry {\n\t\t\t\t// json - стандартные формат, он может быть возвращен в запросах с другим responseType, если в них произошла ошибка\n\t\t\t\tconst isJSON = response.headers.get('content-type')?.includes('application/json');\n\n\t\t\t\tresponseText = await response.text();\n\n\t\t\t\tif (this.options.accept === 'application/json' || isJSON) {\n\t\t\t\t\tres = JSON.parse(responseText);\n\t\t\t\t} else {\n\t\t\t\t\tif (client.useExt) {\n\t\t\t\t\t\tres = genExtRes(responseText, undefined, response);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tres = responseText;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tif (e instanceof SyntaxError || e instanceof TypeError) {\n\t\t\t\t\tformatError = e;\n\t\t\t\t\tformatError.responseText = responseText;\n\t\t\t\t}\n\n\t\t\t\t// если в результате не пришел json, сгенерировать объект результата и добавить информацию об ответе API\n\t\t\t\tif (client.useExt && formatError) {\n\t\t\t\t\tlet errorCode = response.status;\n\t\t\t\t\tlet errorMessage = response.statusText;\n\n\t\t\t\t\tif (errorCode === 200) {\n\t\t\t\t\t\terrorCode = 10000;\n\t\t\t\t\t\terrorMessage = 'Error API response';\n\t\t\t\t\t}\n\n\t\t\t\t\tres = genExtRes(null, [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcode: errorCode,\n\t\t\t\t\t\t\tstring: errorMessage,\n\t\t\t\t\t\t},\n\t\t\t\t\t], response);\n\n\t\t\t\t\tif (client.options.useApiConsole) console.error(e);\n\t\t\t\t} else {\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (client.useExt) {\n\t\t\t\tres.response = response;\n\n\t\t\t\tif (res) {\n\t\t\t\t\tclientRequest.options.onApiLoaded?.(res, middlewareCtx);\n\t\t\t\t}\n\n\t\t\t\tif (res?.errors) {\n\t\t\t\t\tif (client.options.useApiConsole) console.warn(new Error('API error'), { res });\n\n\t\t\t\t\tclientRequest.options.onApiError?.(res, { ...middlewareCtx, formatError }, client.options.requestOptions?.onApiError);\n\t\t\t\t}\n\n\t\t\t\tif (res?.messages) {\n\t\t\t\t\tclientRequest.options.onApiMessage?.(res, middlewareCtx);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn res;\n\t\t},\n\t};\n\n\treturn clientRequest;\n};\n","import { createRequestOptions } from './request-options';\nimport { createRequest } from './request';\n\nexport class Client<paths extends Api.PathsAbstract, UseExt extends Api.Ext.UseExt> {\n\n\treadonly options: Readonly<Api.ClientOptions>;\n\treadonly useExt: UseExt;\n\treadonly middlewares: Api.Middleware[] = [];\n\tabortControllers: Record<string, AbortController> = {};\n\n\tconstructor(clientOptions: Partial<Api.ClientOptions> = {}, useExt: UseExt) {\n\t\tclientOptions.requestOptions = createRequestOptions(clientOptions.requestOptions);\n\t\tclientOptions.useApiConsole ??= true;\n\n\t\tclientOptions.fetch ??= globalThis.fetch;\n\t\tclientOptions.Request ??= globalThis.Request;\n\t\tclientOptions.querySerializer ??= async (params) => {\n\t\t\tconst { querySerializer } = await import('../utils/lazy');\n\n\t\t\treturn querySerializer(params);\n\t\t}\n\t\tclientOptions.bodySerializer ??= (body) => typeof body === 'string' ? body : JSON.stringify(body);\n\n\t\tthis.options = clientOptions as Api.ClientOptions;\n\n\t\tthis.useExt = useExt;\n\t}\n\n\tgenerateUUID() {\n\t\tif (crypto?.randomUUID) {\n\t\t\treturn crypto.randomUUID();\n\t\t}\n\n\t\treturn 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {\n\t\t\tconst r = Math.random() * 16 | 0;\n\t\t\tconst v = c === 'x' ? r : (r & 0x3 | 0x8);\n\t\t\treturn v.toString(16);\n\t\t});\n\t}\n\n\t/**\n\t * Зарегистрировать middleware\n\t */\n\tuse(middleware: Api.Middleware) {\n\t\tthis.middlewares.push(middleware);\n\t}\n\n\t/**\n\t * Создать объект запроса\n\t *\n\t * После создания объекта он заполняется необходимыми данными и выполняет запросы к API с помощью APIRequest2.call();\n\t *\n\t * Опционально generic указывать нельзя, поэтому необходимо дублировать определение fetchStyle, [см.](https://github.com/Microsoft/TypeScript/issues/26242)\n\t *\n\t * @param path Путь метода API\n\t * @param fieldsNarrow Список получаемых полей, для методов API с моделью. Если объект запроса переиспользуется, и список полей меняется, указывайте его непосредственно при вызове `api.call()`\n\t */\n\tgen<\n\t\tPath extends Api.Path<paths>,\n\t\tFieldsNarrow extends Api.ParamsFields<Api.ClientRequestContext<paths, Path, UseExt>>\n\t>(\n\t\tpath: Path,\n\t\tfieldsNarrow?: FieldsNarrow,\n\t): Api.ClientRequest<Api.ClientRequestContext<paths, Path, UseExt>, FieldsNarrow> {\n\t\ttype RequestContext = Api.ClientRequestContext<paths, Path, UseExt>;\n\n\t\treturn createRequest<RequestContext, FieldsNarrow>(this, path, fieldsNarrow);\n\t}\n\n\t/**\n\t * Создать объект запроса, не описанного в OpenAPI\n\t */\n\tgenAny<\n\t\tParams extends Record<string, any>,\n\t\tResult = any,\n\t\tFieldsNarrow extends Api.Ext.Schemas['Fields'] | undefined = undefined\n\t>(path: Api.PathAbstract, fieldsNarrow?: FieldsNarrow): Api.ClientRequestCustom<UseExt, Params, Result> {\n\t\treturn this.gen(path as any, fieldsNarrow as any) as unknown as Api.ClientRequestCustom<UseExt, Params, Result>;\n\t}\n\n\t/**\n\t * Создать контекст выполнения запроса\n\t */\n\tgenMiddlewareCtx(\n\t\tclientRequest: Api.ClientRequest<any, any, any>,\n\t\tdata: Record<string, any>,\n\t): Omit<Api.MiddlewareCallbackParams, 'request'> {\n\t\tconst id = this.generateUUID();\n\n\t\tconst options: Api.BaseOptions = Object.freeze({\n\t\t\tbaseUrl: this.options.baseUrl,\n\t\t\tquerySerializer: this.options.querySerializer,\n\t\t\tbodySerializer: this.options.bodySerializer,\n\t\t\tRequest: this.options.Request,\n\t\t\tfetch: this.options.fetch,\n\t\t});\n\n\t\treturn {\n\t\t\tuseExt: this.useExt,\n\t\t\trequestOptions: clientRequest.options,\n\t\t\tdata,\n\t\t\tmiddlewareData: {},\n\t\t\toptions,\n\t\t\tschemaPath: clientRequest.path,\n\t\t\tid,\n\t\t};\n\t};\n\n\t/**\n\t * Обработчик middleware.onRequest\n\t *\n\t * @param request Запрос для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Request` или `Response` при модификации запроса, или undefined\n\t */\n\tasync middlewareOnRequest(\n\t\trequest: Request,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Request | Response | undefined> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onRequest?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\trequest,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Request) {\n\t\t\t\t\trequest = result;\n\t\t\t\t} else if (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t} else {\n\t\t\t\t\tthrow new Error('onRequest: must return new Request() or Response() when modifying the request');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn request;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param `error` Ошибка, переданная для обработки\n\t * @param middlewareCtx\n\t * @return Новый экземпляр `Response` при успешной обработке или выбрасывает ошибку\n\t */\n\tasync middlewareOnError(\n\t\terror: Error | unknown,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response | never> {\n\t\tlet errorAfterMiddleware = error;\n\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onError?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\terror: errorAfterMiddleware,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (result instanceof Response) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (result instanceof Error) {\n\t\t\t\t\terrorAfterMiddleware = result;\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tthrow new Error('onError: must return new Response() or instance of Error');\n\t\t\t}\n\t\t}\n\n\t\tthrow errorAfterMiddleware;\n\t}\n\n\t/**\n\t * Обработчик middleware.onResponse\n\t *\n\t * @param response Ответ для обработки\n\t * @param middlewareCtx Контекст выполнения запроса\n\t * @return Новый экземпляр `Response` при модификации ответа, или undefined\n\t */\n\tasync middlewareOnResponse(\n\t\tresponse: Response,\n\t\tmiddlewareCtx: Api.MiddlewareCallbackParams,\n\t): Promise<Response> {\n\t\tfor (const middleware of this.middlewares) {\n\t\t\tconst result = await middleware.onResponse?.({\n\t\t\t\t...middlewareCtx,\n\t\t\t\tresponse,\n\t\t\t});\n\n\t\t\tif (result) {\n\t\t\t\tif (!(result instanceof Response)) {\n\t\t\t\t\tthrow new Error('onResponse: must return new Response() when modifying the response');\n\t\t\t\t}\n\n\t\t\t\tresponse = result;\n\t\t\t}\n\t\t}\n\n\t\treturn response;\n\t}\n\n}\n","import { Client } from './client/client';\n\nexport * from './utils/field';\nexport * from './utils/common';\n\nexport const postInWindow: typeof import('./utils/lazy').postInWindow = async (...args) => {\n\tconst { postInWindow } = await import('./utils/lazy');\n\n\treturn postInWindow(...args);\n};\n\nexport const dataToForm: typeof import('./utils/lazy').dataToForm = async (...args) => {\n\tconst { dataToForm } = await import('./utils/lazy');\n\n\treturn dataToForm(...args);\n};\n\n/**\n * Создать API клиент\n *\n * @see Api.Ext.UseExt\n */\nexport const createClient = <\n\tpaths extends Api.PathsAbstract,\n\tUseExt extends Api.Ext.UseExt\n>(\n\tclientOptions: Partial<Api.ClientOptions> = {},\n\tuseExt: UseExt,\n) => {\n\treturn new Client<paths, UseExt>(clientOptions, useExt);\n};\n"],"names":["createRequestOptions","requestOptions","_a","genExtRes","result","errors","response","isPublicAPI","path","getBaseDomainUrl","useMainDomain","input","protocol","hostname","port","parts","baseHostname","createRequest","client","fieldsNarrow","clientRequest","params","options","fields","fetchStyle","data","middlewareCtx","_b","postInWindow","post","fieldsPrepared","field","Request","fetch","middlewareCtxWithoutRequest","url","requestInitBody","requestInitSignal","fingerprint","_c","controller","requestInit","request","_e","_d","requestOrResponse","e","_g","_f","res","responseText","formatError","isJSON","_h","errorCode","errorMessage","_j","_i","_m","_l","_k","_o","_n","Client","clientOptions","useExt","querySerializer","body","c","r","middleware","id","error","errorAfterMiddleware","args","dataToForm","createClient"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@topvisor/ui",
3
3
  "private": false,
4
- "version": "1.1.0-apiClient.13",
4
+ "version": "1.1.0-apiClient.14",
5
5
  "type": "module",
6
6
  "description": "Topvisor UI-kit Vue",
7
7
  "author": "Topvisor",