@topvisor/ui 1.1.0-apiClient.13 → 1.1.0-apiClient.26
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/.chunks/index-BEI7XZmU.amd.js +2 -0
- package/.chunks/index-BEI7XZmU.amd.js.map +1 -0
- package/.chunks/index-igPkes8X.es.js +48 -0
- package/.chunks/index-igPkes8X.es.js.map +1 -0
- package/api/index.amd.js +1 -1
- package/api/index.amd.js.map +1 -1
- package/api/index.js +100 -92
- package/api/index.js.map +1 -1
- package/dialog/dialog.amd.js +1 -1
- package/formsExt/formsExt.amd.js +1 -1
- package/formsExt/formsExt.amd.js.map +1 -1
- package/formsExt/formsExt.js +338 -331
- package/formsExt/formsExt.js.map +1 -1
- package/package.json +2 -1
- package/popup/popup.amd.js +1 -1
- package/types/api/api/mocker/index.d.ts +9 -0
- package/types/api/api/types/api.d.ts +5 -5
- package/types/api/api/types/client/request.d.ts +6 -0
- package/types/api/api/types/field.d.ts +1 -1
- package/types/api/api/types/mocker.d.ts +106 -0
- package/types/api/api/utils/common.d.ts +1 -1
- package/types/api/api/utils/filters.d.ts +1 -1
- package/types/components/formsExt/selector2/composables/useAPI.d.ts +3 -15
- package/types/components/formsExt/selector2/types.d.ts +15 -19
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
define(["require","exports","@faker-js/faker"],(function(k,s,d){"use strict";if(typeof y>"u")var y=window.Vue;const M=20,a=async(e,n,l)=>{if(e.delay){e.showLog&&console.log("genMock pause",e.delay);const{sleep:r}=await new Promise((u,c)=>k(["../utils/system.amd"],u,c));await r(e.delay)}const t={result:g(e,n,l),errors:void 0,nextOffset:void 0,total:void 0};if(delete t.errors,delete t.nextOffset,delete t.total,Array.isArray(t.result)&&e.total&&l&&l.limit){e.useFilter&&(t.result=t.result.filter(u=>{var c;return(c=e.useFilter)==null?void 0:c.call(e,u,l)}));const r=l.offset??0;t.result.length>l.limit+r&&(t.nextOffset=l.limit+r,t.total=e.total),t.result=t.result.slice(r,r+l.limit)}return e.showLog&&console.log("genMock complete",t),t},g=(e,n,l)=>{let t=e.seed??0;if(t===-1&&(t=Math.random()),e.result instanceof Function)return d.faker.seed(t),i(e.result);if(Array.isArray(e.result)){const r=e.result[0],u=[],c=e.total??(l==null?void 0:l.limit)??M;for(let o=0;o<c;o++)u.push(f(r,o,t,n));return u}return f(e.result,0,t,n)},f=(e,n,l,t)=>{const r={};for(const u in e){const c=e[u];t&&!t.includes(u)||(d.faker.seed(l+n),r[u]=i(c,n))}return r},i=(e,n=0)=>e(n);s.genMockItem=f,s.genMockResponse=a,s.genMockResult=g,s.genMockValue=i,Object.defineProperty(s,Symbol.toStringTag,{value:"Module"})}));
|
|
2
|
+
//# sourceMappingURL=index-BEI7XZmU.amd.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-BEI7XZmU.amd.js","sources":["../../src/api/api/mocker/index.ts"],"sourcesContent":["import { faker } from '@faker-js/faker';\n\nconst DEFAULT_LIMIT = 20;\n\nexport const genMockResponse = async (\n\toptions: Api.Mocker.Options<any, any>,\n\tfields?: readonly string[],\n\tparams?: Api.Mocker.Params,\n) => {\n\tif (options.delay) {\n\t\tif (options.showLog) {\n\t\t\tconsole.log('genMock pause', options.delay);\n\t\t}\n\n\t\tconst { sleep } = await import('@/core/utils/system');\n\n\t\tawait sleep(options.delay);\n\t}\n\n\tconst res = {\n\t\tresult: genMockResult(options, fields, params),\n\t\terrors: undefined,\n\t\tnextOffset: undefined as number | undefined,\n\t\ttotal: undefined as number | undefined,\n\t};\n\n\tdelete res.errors;\n\tdelete res.nextOffset;\n\tdelete res.total;\n\n\t// реализация `limit` и `offset`\n\tif (Array.isArray(res.result) && options.total && params && params.limit) {\n\t\tif (options.useFilter) {\n\t\t\tres.result = res.result.filter((resultItem) => options.useFilter?.(resultItem, params));\n\t\t}\n\n\t\tconst offset = params.offset ?? 0;\n\n\t\tif (res.result.length > params.limit + offset) {\n\t\t\tres.nextOffset = params.limit + offset;\n\t\t\tres.total = options.total;\n\t\t}\n\n\t\tres.result = res.result.slice(offset, offset + params.limit);\n\t}\n\n\tif (options.showLog) {\n\t\tconsole.log('genMock complete', res);\n\t}\n\n\treturn res;\n};\n\nexport const genMockResult = <Options extends Api.Mocker.Options<any, any>>(\n\toptions: Options,\n\tfields?: readonly string[],\n\tparams?: Api.Mocker.Params,\n): Api.Mocker.ToMockResult<Options['result']> => {\n\tlet seed: number | undefined = options.seed ?? 0;\n\tif (seed === -1) seed = Math.random();\n\n\tif (options.result instanceof Function) {\n\t\tfaker.seed(seed);\n\n\t\treturn genMockValue(options.result);\n\t}\n\n\tif (Array.isArray(options.result)) {\n\t\tconst genItem = options.result[0];\n\n\t\tconst result = [] as Api.Mocker.ToMockResult<Options['result']>;\n\n\t\t// для работы `useFilter()` применять `params.limit` можно только после применения фильтра\n\t\tconst total = options.total ?? params?.limit ?? DEFAULT_LIMIT;\n\n\t\tfor (let i = 0; i < total; i++) {\n\t\t\tresult.push(genMockItem(genItem, i, seed, fields));\n\t\t}\n\n\t\treturn result;\n\t}\n\n\treturn genMockItem(options.result, 0, seed, fields) as Api.Mocker.ToMockResult<Options['result']>;\n};\n\nexport const genMockItem = <T extends Api.Mocker.Item>(\n\tgenItem: T,\n\tn: number,\n\tseed: number,\n\tfields?: readonly string[],\n): Api.Mocker.ToMockItem<T> => {\n\tconst item = {} as Api.Mocker.ToMockItem<T>;\n\n\tfor (const key in genItem) {\n\t\tconst genValue = genItem[key];\n\n\t\tif (fields && !fields.includes(key)) continue;\n\n\t\t// seed для генерации одного объекта всегда одинаковый\n\t\tfaker.seed(seed + n);\n\n\t\titem[key] = genMockValue(genValue, n);\n\t}\n\n\treturn item;\n};\n\nexport const genMockValue = <T extends Api.Mocker.Value>(genValue: T, n: number = 0): Api.Mocker.ToMockValue<T> => {\n\treturn genValue(n);\n};\n"],"names":["genMockResponse","options","fields","params","sleep","res","offset","genMockResult","seed","faker","genMockValue","i","total","result","genMockItem","genItem","key","genValue","item"],"mappings":"yHAIOA,EAAA,MAAAC,EAAAC,EAAAC,IAAA,CAKN,GAAAF,EAAA,MAAA,CACCA,EAAA,sHAMA,MAAAG,EAAAH,EAAA,KAAA,2DAMY,MAAA,QASb,sDAAA,MAAA,QAAAI,EAAA,MAAA,GAAAJ,EAAA,OAAAE,GAAAA,EAAA,MAAA,CACCF,EAAA,mGAIA,MAAAK,EAAAH,EAAA,QAAA,EAEAE,EAAA,OAAA,OAAAF,EAAA,MAAAG,2BAECD,EAAA,MAAAJ,EAAA,OAGDI,EAAA,OAAAA,EAAA,OAAA,MAAAC,EAAAA,EAAAH,EAAA,KAAA,EAGD,OAAAF,EAAA,SACC,QAAA,IAAA,mBAAAI,CAAA,EAGDA,CACD,EAEOE,EAAA,CAAAN,EAAAC,EAAAC,IAAA,CAKN,IAAAK,EAAAP,EAAA,MAAA,EAGA,6BAAAA,EAAA,kBAAA,SACC,OAAAQ,EAAA,MAAA,KAAAD,CAAA,EAEAE,EAAAT,EAAA,MAAA,8FAWA,QAAAU,EAAA,EAAAA,EAAAC,EAAAD,IACCE,EAAA,KAAAC,EAAAC,EAAAJ,EAAAH,EAAAN,CAAA,CAAA,EAGD,OAAAW,EAGD,OAAAC,EAAAb,EAAA,OAAA,EAAAO,EAAAN,CAAA,CACD,EAEOY,EAAA,CAAAC,EAAA,EAAAP,EAAAN,IAAA,YAQN,UAAAc,KAAAD,EAAA,CACC,MAAAE,EAAAF,EAAAC,CAAA,sBAKAP,EAAA,MAAA,KAAAD,EAAA,CAAA,eAKD,OAAAU,CACD,EAEOR,EAAA,CAAAO,EAAA,EAAA,IACNA,EAAA,CAAA"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { faker as i } from "@faker-js/faker";
|
|
2
|
+
const d = 20, k = async (e, c, l) => {
|
|
3
|
+
if (e.delay) {
|
|
4
|
+
e.showLog && console.log("genMock pause", e.delay);
|
|
5
|
+
const { sleep: r } = await import("../utils/system.js");
|
|
6
|
+
await r(e.delay);
|
|
7
|
+
}
|
|
8
|
+
const t = {
|
|
9
|
+
result: g(e, c, l),
|
|
10
|
+
errors: void 0,
|
|
11
|
+
nextOffset: void 0,
|
|
12
|
+
total: void 0
|
|
13
|
+
};
|
|
14
|
+
if (delete t.errors, delete t.nextOffset, delete t.total, Array.isArray(t.result) && e.total && l && l.limit) {
|
|
15
|
+
e.useFilter && (t.result = t.result.filter((u) => {
|
|
16
|
+
var s;
|
|
17
|
+
return (s = e.useFilter) == null ? void 0 : s.call(e, u, l);
|
|
18
|
+
}));
|
|
19
|
+
const r = l.offset ?? 0;
|
|
20
|
+
t.result.length > l.limit + r && (t.nextOffset = l.limit + r, t.total = e.total), t.result = t.result.slice(r, r + l.limit);
|
|
21
|
+
}
|
|
22
|
+
return e.showLog && console.log("genMock complete", t), t;
|
|
23
|
+
}, g = (e, c, l) => {
|
|
24
|
+
let t = e.seed ?? 0;
|
|
25
|
+
if (t === -1 && (t = Math.random()), e.result instanceof Function)
|
|
26
|
+
return i.seed(t), o(e.result);
|
|
27
|
+
if (Array.isArray(e.result)) {
|
|
28
|
+
const r = e.result[0], u = [], s = e.total ?? (l == null ? void 0 : l.limit) ?? d;
|
|
29
|
+
for (let f = 0; f < s; f++)
|
|
30
|
+
u.push(n(r, f, t, c));
|
|
31
|
+
return u;
|
|
32
|
+
}
|
|
33
|
+
return n(e.result, 0, t, c);
|
|
34
|
+
}, n = (e, c, l, t) => {
|
|
35
|
+
const r = {};
|
|
36
|
+
for (const u in e) {
|
|
37
|
+
const s = e[u];
|
|
38
|
+
t && !t.includes(u) || (i.seed(l + c), r[u] = o(s, c));
|
|
39
|
+
}
|
|
40
|
+
return r;
|
|
41
|
+
}, o = (e, c = 0) => e(c);
|
|
42
|
+
export {
|
|
43
|
+
n as genMockItem,
|
|
44
|
+
k as genMockResponse,
|
|
45
|
+
g as genMockResult,
|
|
46
|
+
o as genMockValue
|
|
47
|
+
};
|
|
48
|
+
//# sourceMappingURL=index-igPkes8X.es.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-igPkes8X.es.js","sources":["../../src/api/api/mocker/index.ts"],"sourcesContent":["import { faker } from '@faker-js/faker';\n\nconst DEFAULT_LIMIT = 20;\n\nexport const genMockResponse = async (\n\toptions: Api.Mocker.Options<any, any>,\n\tfields?: readonly string[],\n\tparams?: Api.Mocker.Params,\n) => {\n\tif (options.delay) {\n\t\tif (options.showLog) {\n\t\t\tconsole.log('genMock pause', options.delay);\n\t\t}\n\n\t\tconst { sleep } = await import('@/core/utils/system');\n\n\t\tawait sleep(options.delay);\n\t}\n\n\tconst res = {\n\t\tresult: genMockResult(options, fields, params),\n\t\terrors: undefined,\n\t\tnextOffset: undefined as number | undefined,\n\t\ttotal: undefined as number | undefined,\n\t};\n\n\tdelete res.errors;\n\tdelete res.nextOffset;\n\tdelete res.total;\n\n\t// реализация `limit` и `offset`\n\tif (Array.isArray(res.result) && options.total && params && params.limit) {\n\t\tif (options.useFilter) {\n\t\t\tres.result = res.result.filter((resultItem) => options.useFilter?.(resultItem, params));\n\t\t}\n\n\t\tconst offset = params.offset ?? 0;\n\n\t\tif (res.result.length > params.limit + offset) {\n\t\t\tres.nextOffset = params.limit + offset;\n\t\t\tres.total = options.total;\n\t\t}\n\n\t\tres.result = res.result.slice(offset, offset + params.limit);\n\t}\n\n\tif (options.showLog) {\n\t\tconsole.log('genMock complete', res);\n\t}\n\n\treturn res;\n};\n\nexport const genMockResult = <Options extends Api.Mocker.Options<any, any>>(\n\toptions: Options,\n\tfields?: readonly string[],\n\tparams?: Api.Mocker.Params,\n): Api.Mocker.ToMockResult<Options['result']> => {\n\tlet seed: number | undefined = options.seed ?? 0;\n\tif (seed === -1) seed = Math.random();\n\n\tif (options.result instanceof Function) {\n\t\tfaker.seed(seed);\n\n\t\treturn genMockValue(options.result);\n\t}\n\n\tif (Array.isArray(options.result)) {\n\t\tconst genItem = options.result[0];\n\n\t\tconst result = [] as Api.Mocker.ToMockResult<Options['result']>;\n\n\t\t// для работы `useFilter()` применять `params.limit` можно только после применения фильтра\n\t\tconst total = options.total ?? params?.limit ?? DEFAULT_LIMIT;\n\n\t\tfor (let i = 0; i < total; i++) {\n\t\t\tresult.push(genMockItem(genItem, i, seed, fields));\n\t\t}\n\n\t\treturn result;\n\t}\n\n\treturn genMockItem(options.result, 0, seed, fields) as Api.Mocker.ToMockResult<Options['result']>;\n};\n\nexport const genMockItem = <T extends Api.Mocker.Item>(\n\tgenItem: T,\n\tn: number,\n\tseed: number,\n\tfields?: readonly string[],\n): Api.Mocker.ToMockItem<T> => {\n\tconst item = {} as Api.Mocker.ToMockItem<T>;\n\n\tfor (const key in genItem) {\n\t\tconst genValue = genItem[key];\n\n\t\tif (fields && !fields.includes(key)) continue;\n\n\t\t// seed для генерации одного объекта всегда одинаковый\n\t\tfaker.seed(seed + n);\n\n\t\titem[key] = genMockValue(genValue, n);\n\t}\n\n\treturn item;\n};\n\nexport const genMockValue = <T extends Api.Mocker.Value>(genValue: T, n: number = 0): Api.Mocker.ToMockValue<T> => {\n\treturn genValue(n);\n};\n"],"names":["DEFAULT_LIMIT","genMockResponse","options","fields","params","sleep","res","genMockResult","resultItem","_a","offset","seed","faker","genMockValue","genItem","result","total","i","genMockItem","n","item","key","genValue"],"mappings":";AAEA,MAAMA,IAAgB,IAETC,IAAkB,OAC9BC,GACAC,GACAC,MACI;AACJ,MAAIF,EAAQ,OAAO;AAClB,IAAIA,EAAQ,WACX,QAAQ,IAAI,iBAAiBA,EAAQ,KAAK;AAG3C,UAAM,EAAE,OAAAG,EAAA,IAAU,MAAM,OAAO,oBAAqB;AAEpD,UAAMA,EAAMH,EAAQ,KAAK;AAAA,EAC1B;AAEA,QAAMI,IAAM;AAAA,IACX,QAAQC,EAAcL,GAASC,GAAQC,CAAM;AAAA,IAC7C,QAAQ;AAAA,IACR,YAAY;AAAA,IACZ,OAAO;AAAA,EAAA;AAQR,MALA,OAAOE,EAAI,QACX,OAAOA,EAAI,YACX,OAAOA,EAAI,OAGP,MAAM,QAAQA,EAAI,MAAM,KAAKJ,EAAQ,SAASE,KAAUA,EAAO,OAAO;AACzE,IAAIF,EAAQ,cACXI,EAAI,SAASA,EAAI,OAAO,OAAO,CAACE;;AAAe,cAAAC,IAAAP,EAAQ,cAAR,gBAAAO,EAAA,KAAAP,GAAoBM,GAAYJ;AAAA,KAAO;AAGvF,UAAMM,IAASN,EAAO,UAAU;AAEhC,IAAIE,EAAI,OAAO,SAASF,EAAO,QAAQM,MACtCJ,EAAI,aAAaF,EAAO,QAAQM,GAChCJ,EAAI,QAAQJ,EAAQ,QAGrBI,EAAI,SAASA,EAAI,OAAO,MAAMI,GAAQA,IAASN,EAAO,KAAK;AAAA,EAC5D;AAEA,SAAIF,EAAQ,WACX,QAAQ,IAAI,oBAAoBI,CAAG,GAG7BA;AACR,GAEaC,IAAgB,CAC5BL,GACAC,GACAC,MACgD;AAChD,MAAIO,IAA2BT,EAAQ,QAAQ;AAG/C,MAFIS,MAAS,OAAIA,IAAO,KAAK,OAAA,IAEzBT,EAAQ,kBAAkB;AAC7B,WAAAU,EAAM,KAAKD,CAAI,GAERE,EAAaX,EAAQ,MAAM;AAGnC,MAAI,MAAM,QAAQA,EAAQ,MAAM,GAAG;AAClC,UAAMY,IAAUZ,EAAQ,OAAO,CAAC,GAE1Ba,IAAS,CAAA,GAGTC,IAAQd,EAAQ,UAASE,KAAA,gBAAAA,EAAQ,UAASJ;AAEhD,aAASiB,IAAI,GAAGA,IAAID,GAAOC;AAC1B,MAAAF,EAAO,KAAKG,EAAYJ,GAASG,GAAGN,GAAMR,CAAM,CAAC;AAGlD,WAAOY;AAAA,EACR;AAEA,SAAOG,EAAYhB,EAAQ,QAAQ,GAAGS,GAAMR,CAAM;AACnD,GAEae,IAAc,CAC1BJ,GACAK,GACAR,GACAR,MAC8B;AAC9B,QAAMiB,IAAO,CAAA;AAEb,aAAWC,KAAOP,GAAS;AAC1B,UAAMQ,IAAWR,EAAQO,CAAG;AAE5B,IAAIlB,KAAU,CAACA,EAAO,SAASkB,CAAG,MAGlCT,EAAM,KAAKD,IAAOQ,CAAC,GAEnBC,EAAKC,CAAG,IAAIR,EAAaS,GAAUH,CAAC;AAAA,EACrC;AAEA,SAAOC;AACR,GAEaP,IAAe,CAA6BS,GAAaH,IAAY,MAC1EG,EAASH,CAAC;"}
|
package/api/index.amd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(["require","exports","../.chunks/field-Cvv0SRcJ.amd"],(function(
|
|
1
|
+
define(["require","exports","@faker-js/faker","../.chunks/field-Cvv0SRcJ.amd"],(function(g,p,Y,k){"use strict";if(typeof B>"u")var B=window.Vue;const q=(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},S=(t,o,r)=>({result:t,errors:o,response:r}),J=t=>t.startsWith("/system_2/common/"),H=(t=!1,o=window.location.href,r)=>{const{protocol:e,hostname:n,port:s}=new URL(o),a=n.split("."),u=!t||a.length<=2||/^[\d.]+$/.test(n)||n==="localhost"?n:a.slice(-2).join(".");return`${e}//${u}${s?`:${s}`:""}`},N=(t,o,r)=>{const e={inLoading:!1,path:o,url:t.options.baseUrl+o,options:q(t.options.requestOptions),mockerOptions:void 0,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),setMocker:n=>(e.mockerOptions=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=t.genMiddlewareCtx(e,s);(f=(c=t.options).onPrepareData)==null||f.call(c,s,a);const{postInWindow:u}=await new Promise((x,y)=>g(["../.chunks/lazy-CiM2Ny-s.amd"],x,y));u(e.url,s,"_blank")},callInSelfWindow:async n=>{var c,f;const s=e.genData(n),a=t.genMiddlewareCtx(e,s);(f=(c=t.options).onPrepareData)==null||f.call(c,s,a);const{postInWindow:u}=await new Promise((x,y)=>g(["../.chunks/lazy-CiM2Ny-s.amd"],x,y));u(e.url,s,"_self")},genData:(n,s)=>{const a={...e.params};if(delete a.fetch_style,n){let u=[...n];r&&(u=u.filter(c=>r.includes(c))),a.fields=u}else r&&(a.fields=r);return s&&(a.fetch_style=s),a},async exec(n,s){var C,O,z,A,D,T,U,F,v,M,L,j,W,_,$;const a=t.options.Request,u=t.options.fetch,c=e.genData(n,s),f=t.genMiddlewareCtx(e,c);if((O=(C=t.options).onPrepareData)==null||O.call(C,c,f),e.mockerOptions){const{genMockResponse:d}=await new Promise((w,P)=>g(["../.chunks/index-BEI7XZmU.amd"],w,P));return await d(e.mockerOptions,n,c)}let x=e.url,y;e.options.method!=="POST"?x+="?"+await t.options.querySerializer(c):y=t.options.bodySerializer(c);let I;if(this.options.checkFingerprint){const d=this.path+this.options.checkFingerprint;(z=t.abortControllers[d])==null||z.abort();const w=new AbortController;t.abortControllers[d]=w,I=w.signal}const X={...t.options,method:e.options.method,body:y,signal:I};let m=new a(x,X);m.headers.set("x-request-id",f.id),m.headers.set("content-type","application/json"),m.headers.set("accept",e.options.accept);const h={...f,request:m};e.inLoading=!0,(D=(A=e.options).onLoading)==null||D.call(A,e.inLoading,h);let l;const b=await t.middlewareOnRequest(m,h);if(b instanceof Response?l=b:b instanceof a&&(m=b),!l)try{l=await u(m)}catch(d){l=await t.middlewareOnError(d,h)}finally{e.inLoading=!1,(U=(T=e.options).onLoading)==null||U.call(T,e.inLoading,h)}l=await t.middlewareOnResponse(l,h);let i,R,E;try{const d=(F=l.headers.get("content-type"))==null?void 0:F.includes("application/json");R=await l.text(),this.options.accept==="application/json"||d?i=JSON.parse(R):t.useExt?i=S(R,void 0,l):i=R}catch(d){if((d instanceof SyntaxError||d instanceof TypeError)&&(E=d,E.responseText=R),t.useExt&&E){let w=l.status,P=l.statusText;w===200&&(w=1e4,P="Error API response"),i=S(null,[{code:w,string:P}],l),t.options.useApiConsole&&console.error(d)}else throw d}return t.useExt&&(i.response=l,i&&((M=(v=e.options).onApiLoaded)==null||M.call(v,i,h)),i!=null&&i.errors&&(t.options.useApiConsole&&console.warn(new Error("API error"),{res:i}),(W=(j=e.options).onApiError)==null||W.call(j,i,{...h,formatError:E},(L=t.options.requestOptions)==null?void 0:L.onApiError)),i!=null&&i.messages&&(($=(_=e.options).onApiMessage)==null||$.call(_,i,h))),i}};return e};class V{options;useExt;middlewares=[];abortControllers={};constructor(o={},r){o.requestOptions=q(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)=>g(["../.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)=>g(["../.chunks/lazy-CiM2Ny-s.amd"],r,e));return o(...t)},K=async(...t)=>{const{dataToForm:o}=await new Promise((r,e)=>g(["../.chunks/lazy-CiM2Ny-s.amd"],r,e));return o(...t)},Q=(t={},o)=>new V(t,o);p.genFieldFilter=k.genFieldFilter,p.genFieldOrder=k.genFieldOrder,p.createClient=Q,p.dataToForm=K,p.genExtRes=S,p.getBaseDomainUrl=H,p.isPublicAPI=J,p.postInWindow=G,Object.defineProperty(p,Symbol.toStringTag,{value:"Module"})}));
|
|
2
2
|
//# sourceMappingURL=index.amd.js.map
|
package/api/index.amd.js.map
CHANGED
|
@@ -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":"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,iCAMC,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,iDAGCC,EAAA,IAAA,gBACAL,EAAA,iBAAAM,CAAA,EAAAD,wBAKU,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,GClPM,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"}
|
|
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, subdomain?: string) => {\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';\nimport { genMockResponse } from '../mocker';\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: Api.ClientRequest<RequestContext, FieldsNarrow> = {\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\tmockerOptions: undefined as Api.Mocker.Options<any, any> | undefined,\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\tsetMocker: (options) => {\n\t\t\tclientRequest.mockerOptions = 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?, fetchStyle?) {\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\tif (clientRequest.mockerOptions) {\n\t\t\t\tconst { genMockResponse } = await import('../mocker/');\n\n\t\t\t\treturn await genMockResponse(clientRequest.mockerOptions, fields, data);\n\t\t\t}\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","subdomain","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":"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"}
|
package/api/index.js
CHANGED
|
@@ -1,39 +1,42 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
},
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
import "@faker-js/faker";
|
|
2
|
+
import { g as X, a as Y } from "../.chunks/field-CyyFzM-Y.es.js";
|
|
3
|
+
const W = (t = {}) => {
|
|
4
|
+
var o;
|
|
5
|
+
return t = { ...t }, t.loadingEl ??= (o = globalThis.document) == null ? void 0 : o.body, t.loadingShowSpinner ??= !0, t.method ??= "POST", t.accept ??= "application/json", t;
|
|
6
|
+
}, F = (t, o, n) => ({
|
|
7
|
+
result: t,
|
|
8
|
+
errors: o,
|
|
8
9
|
response: n
|
|
9
|
-
}),
|
|
10
|
-
const { protocol:
|
|
11
|
-
return `${
|
|
12
|
-
}, _ = (
|
|
10
|
+
}), B = (t) => t.startsWith("/system_2/common/"), H = (t = !1, o = window.location.href, n) => {
|
|
11
|
+
const { protocol: e, hostname: s, port: r } = new URL(o), i = s.split("."), l = !t || i.length <= 2 || /^[\d.]+$/.test(s) || s === "localhost" ? s : i.slice(-2).join(".");
|
|
12
|
+
return `${e}//${l}${r ? `:${r}` : ""}`;
|
|
13
|
+
}, _ = (t, o, n) => {
|
|
13
14
|
const e = {
|
|
14
15
|
inLoading: !1,
|
|
15
|
-
path:
|
|
16
|
-
url:
|
|
17
|
-
options:
|
|
16
|
+
path: o,
|
|
17
|
+
url: t.options.baseUrl + o,
|
|
18
|
+
options: W(t.options.requestOptions),
|
|
19
|
+
mockerOptions: void 0,
|
|
18
20
|
params: {},
|
|
19
21
|
// незаполненное свойство
|
|
20
22
|
getInLoading: () => e.inLoading,
|
|
21
23
|
setParams: (s) => (e.params = { ...s }, e),
|
|
22
24
|
changeParams: (s) => (Object.assign(e.params, s), e),
|
|
23
25
|
setOptions: (s) => (Object.assign(e.options, s), e),
|
|
26
|
+
setMocker: (s) => (e.mockerOptions = s, e),
|
|
24
27
|
call: async (s) => e.exec(s),
|
|
25
28
|
callFetch: async (s, r) => e.exec(r, s),
|
|
26
29
|
callInNewWindow: async (s) => {
|
|
27
|
-
var
|
|
28
|
-
const r = e.genData(s), i =
|
|
29
|
-
(u = (
|
|
30
|
+
var c, u;
|
|
31
|
+
const r = e.genData(s), i = t.genMiddlewareCtx(e, r);
|
|
32
|
+
(u = (c = t.options).onPrepareData) == null || u.call(c, r, i);
|
|
30
33
|
const { postInWindow: l } = await import("../.chunks/lazy-Crun7esL.es.js");
|
|
31
34
|
l(e.url, r, "_blank");
|
|
32
35
|
},
|
|
33
36
|
callInSelfWindow: async (s) => {
|
|
34
|
-
var
|
|
35
|
-
const r = e.genData(s), i =
|
|
36
|
-
(u = (
|
|
37
|
+
var c, u;
|
|
38
|
+
const r = e.genData(s), i = t.genMiddlewareCtx(e, r);
|
|
39
|
+
(u = (c = t.options).onPrepareData) == null || u.call(c, r, i);
|
|
37
40
|
const { postInWindow: l } = await import("../.chunks/lazy-Crun7esL.es.js");
|
|
38
41
|
l(e.url, r, "_self");
|
|
39
42
|
},
|
|
@@ -41,7 +44,7 @@ const j = (o = {}) => {
|
|
|
41
44
|
const i = { ...e.params };
|
|
42
45
|
if (delete i.fetch_style, s) {
|
|
43
46
|
let l = [...s];
|
|
44
|
-
n && (l = l.filter((
|
|
47
|
+
n && (l = l.filter((c) => n.includes(c))), i.fields = l;
|
|
45
48
|
} else
|
|
46
49
|
n && (i.fields = n);
|
|
47
50
|
return r && (i.fetch_style = r), i;
|
|
@@ -50,57 +53,62 @@ const j = (o = {}) => {
|
|
|
50
53
|
* Общая функция выполнения запросов
|
|
51
54
|
*/
|
|
52
55
|
async exec(s, r) {
|
|
53
|
-
var
|
|
54
|
-
const i =
|
|
55
|
-
(
|
|
56
|
+
var q, b, S, C, I, O, A, D, P, U, T, L, M, k, z;
|
|
57
|
+
const i = t.options.Request, l = t.options.fetch, c = e.genData(s, r), u = t.genMiddlewareCtx(e, c);
|
|
58
|
+
if ((b = (q = t.options).onPrepareData) == null || b.call(q, c, u), e.mockerOptions) {
|
|
59
|
+
const { genMockResponse: p } = await import("../.chunks/index-igPkes8X.es.js");
|
|
60
|
+
return await p(e.mockerOptions, s, c);
|
|
61
|
+
}
|
|
56
62
|
let y = e.url, R;
|
|
57
|
-
e.options.method !== "POST" ? y += "?" + await
|
|
58
|
-
let
|
|
63
|
+
e.options.method !== "POST" ? y += "?" + await t.options.querySerializer(c) : R = t.options.bodySerializer(c);
|
|
64
|
+
let E;
|
|
59
65
|
if (this.options.checkFingerprint) {
|
|
60
|
-
const
|
|
61
|
-
|
|
66
|
+
const p = this.path + this.options.checkFingerprint;
|
|
67
|
+
(S = t.abortControllers[p]) == null || S.abort();
|
|
68
|
+
const w = new AbortController();
|
|
69
|
+
t.abortControllers[p] = w, E = w.signal;
|
|
62
70
|
}
|
|
63
|
-
const
|
|
64
|
-
...
|
|
71
|
+
const j = {
|
|
72
|
+
...t.options,
|
|
65
73
|
method: e.options.method,
|
|
66
74
|
body: R,
|
|
67
|
-
signal:
|
|
75
|
+
signal: E
|
|
68
76
|
};
|
|
69
|
-
let h = new i(y,
|
|
77
|
+
let h = new i(y, j);
|
|
70
78
|
h.headers.set("x-request-id", u.id), h.headers.set("content-type", "application/json"), h.headers.set("accept", e.options.accept);
|
|
71
79
|
const f = {
|
|
72
80
|
...u,
|
|
73
81
|
request: h
|
|
74
82
|
};
|
|
75
|
-
e.inLoading = !0, (
|
|
76
|
-
let
|
|
77
|
-
const
|
|
78
|
-
if (
|
|
83
|
+
e.inLoading = !0, (I = (C = e.options).onLoading) == null || I.call(C, e.inLoading, f);
|
|
84
|
+
let d;
|
|
85
|
+
const m = await t.middlewareOnRequest(h, f);
|
|
86
|
+
if (m instanceof Response ? d = m : m instanceof i && (h = m), !d)
|
|
79
87
|
try {
|
|
80
|
-
|
|
81
|
-
} catch (
|
|
82
|
-
|
|
88
|
+
d = await l(h);
|
|
89
|
+
} catch (p) {
|
|
90
|
+
d = await t.middlewareOnError(p, f);
|
|
83
91
|
} finally {
|
|
84
|
-
e.inLoading = !1, (
|
|
92
|
+
e.inLoading = !1, (A = (O = e.options).onLoading) == null || A.call(O, e.inLoading, f);
|
|
85
93
|
}
|
|
86
|
-
|
|
87
|
-
let a,
|
|
94
|
+
d = await t.middlewareOnResponse(d, f);
|
|
95
|
+
let a, x, g;
|
|
88
96
|
try {
|
|
89
|
-
const
|
|
90
|
-
|
|
91
|
-
} catch (
|
|
92
|
-
if ((
|
|
93
|
-
let
|
|
94
|
-
|
|
97
|
+
const p = (D = d.headers.get("content-type")) == null ? void 0 : D.includes("application/json");
|
|
98
|
+
x = await d.text(), this.options.accept === "application/json" || p ? a = JSON.parse(x) : t.useExt ? a = F(x, void 0, d) : a = x;
|
|
99
|
+
} catch (p) {
|
|
100
|
+
if ((p instanceof SyntaxError || p instanceof TypeError) && (g = p, g.responseText = x), t.useExt && g) {
|
|
101
|
+
let w = d.status, v = d.statusText;
|
|
102
|
+
w === 200 && (w = 1e4, v = "Error API response"), a = F(null, [
|
|
95
103
|
{
|
|
96
|
-
code:
|
|
97
|
-
string:
|
|
104
|
+
code: w,
|
|
105
|
+
string: v
|
|
98
106
|
}
|
|
99
|
-
],
|
|
107
|
+
], d), t.options.useApiConsole && console.error(p);
|
|
100
108
|
} else
|
|
101
|
-
throw
|
|
109
|
+
throw p;
|
|
102
110
|
}
|
|
103
|
-
return
|
|
111
|
+
return t.useExt && (a.response = d, a && ((U = (P = e.options).onApiLoaded) == null || U.call(P, a, f)), a != null && a.errors && (t.options.useApiConsole && console.warn(new Error("API error"), { res: a }), (M = (L = e.options).onApiError) == null || M.call(L, a, { ...f, formatError: g }, (T = t.options.requestOptions) == null ? void 0 : T.onApiError)), a != null && a.messages && ((z = (k = e.options).onApiMessage) == null || z.call(k, a, f))), a;
|
|
104
112
|
}
|
|
105
113
|
};
|
|
106
114
|
return e;
|
|
@@ -110,23 +118,23 @@ class $ {
|
|
|
110
118
|
useExt;
|
|
111
119
|
middlewares = [];
|
|
112
120
|
abortControllers = {};
|
|
113
|
-
constructor(
|
|
114
|
-
|
|
121
|
+
constructor(o = {}, n) {
|
|
122
|
+
o.requestOptions = W(o.requestOptions), o.useApiConsole ??= !0, o.fetch ??= globalThis.fetch, o.Request ??= globalThis.Request, o.querySerializer ??= async (e) => {
|
|
115
123
|
const { querySerializer: s } = await import("../.chunks/lazy-Crun7esL.es.js");
|
|
116
124
|
return s(e);
|
|
117
|
-
},
|
|
125
|
+
}, o.bodySerializer ??= (e) => typeof e == "string" ? e : JSON.stringify(e), this.options = o, this.useExt = n;
|
|
118
126
|
}
|
|
119
127
|
generateUUID() {
|
|
120
|
-
return crypto != null && crypto.randomUUID ? crypto.randomUUID() : "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, (
|
|
128
|
+
return crypto != null && crypto.randomUUID ? crypto.randomUUID() : "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, (o) => {
|
|
121
129
|
const n = Math.random() * 16 | 0;
|
|
122
|
-
return (
|
|
130
|
+
return (o === "x" ? n : n & 3 | 8).toString(16);
|
|
123
131
|
});
|
|
124
132
|
}
|
|
125
133
|
/**
|
|
126
134
|
* Зарегистрировать middleware
|
|
127
135
|
*/
|
|
128
|
-
use(
|
|
129
|
-
this.middlewares.push(
|
|
136
|
+
use(o) {
|
|
137
|
+
this.middlewares.push(o);
|
|
130
138
|
}
|
|
131
139
|
/**
|
|
132
140
|
* Создать объект запроса
|
|
@@ -138,19 +146,19 @@ class $ {
|
|
|
138
146
|
* @param path Путь метода API
|
|
139
147
|
* @param fieldsNarrow Список получаемых полей, для методов API с моделью. Если объект запроса переиспользуется, и список полей меняется, указывайте его непосредственно при вызове `api.call()`
|
|
140
148
|
*/
|
|
141
|
-
gen(
|
|
142
|
-
return _(this,
|
|
149
|
+
gen(o, n) {
|
|
150
|
+
return _(this, o, n);
|
|
143
151
|
}
|
|
144
152
|
/**
|
|
145
153
|
* Создать объект запроса, не описанного в OpenAPI
|
|
146
154
|
*/
|
|
147
|
-
genAny(
|
|
148
|
-
return this.gen(
|
|
155
|
+
genAny(o, n) {
|
|
156
|
+
return this.gen(o, n);
|
|
149
157
|
}
|
|
150
158
|
/**
|
|
151
159
|
* Создать контекст выполнения запроса
|
|
152
160
|
*/
|
|
153
|
-
genMiddlewareCtx(
|
|
161
|
+
genMiddlewareCtx(o, n) {
|
|
154
162
|
const e = this.generateUUID(), s = Object.freeze({
|
|
155
163
|
baseUrl: this.options.baseUrl,
|
|
156
164
|
querySerializer: this.options.querySerializer,
|
|
@@ -160,11 +168,11 @@ class $ {
|
|
|
160
168
|
});
|
|
161
169
|
return {
|
|
162
170
|
useExt: this.useExt,
|
|
163
|
-
requestOptions:
|
|
171
|
+
requestOptions: o.options,
|
|
164
172
|
data: n,
|
|
165
173
|
middlewareData: {},
|
|
166
174
|
options: s,
|
|
167
|
-
schemaPath:
|
|
175
|
+
schemaPath: o.path,
|
|
168
176
|
id: e
|
|
169
177
|
};
|
|
170
178
|
}
|
|
@@ -175,23 +183,23 @@ class $ {
|
|
|
175
183
|
* @param middlewareCtx Контекст выполнения запроса
|
|
176
184
|
* @return Новый экземпляр `Request` или `Response` при модификации запроса, или undefined
|
|
177
185
|
*/
|
|
178
|
-
async middlewareOnRequest(
|
|
186
|
+
async middlewareOnRequest(o, n) {
|
|
179
187
|
var e;
|
|
180
188
|
for (const s of this.middlewares) {
|
|
181
189
|
const r = await ((e = s.onRequest) == null ? void 0 : e.call(s, {
|
|
182
190
|
...n,
|
|
183
|
-
request:
|
|
191
|
+
request: o
|
|
184
192
|
}));
|
|
185
193
|
if (r)
|
|
186
194
|
if (r instanceof Request)
|
|
187
|
-
|
|
195
|
+
o = r;
|
|
188
196
|
else {
|
|
189
197
|
if (r instanceof Response)
|
|
190
198
|
return r;
|
|
191
199
|
throw new Error("onRequest: must return new Request() or Response() when modifying the request");
|
|
192
200
|
}
|
|
193
201
|
}
|
|
194
|
-
return
|
|
202
|
+
return o;
|
|
195
203
|
}
|
|
196
204
|
/**
|
|
197
205
|
* Обработчик middleware.onResponse
|
|
@@ -200,9 +208,9 @@ class $ {
|
|
|
200
208
|
* @param middlewareCtx
|
|
201
209
|
* @return Новый экземпляр `Response` при успешной обработке или выбрасывает ошибку
|
|
202
210
|
*/
|
|
203
|
-
async middlewareOnError(
|
|
211
|
+
async middlewareOnError(o, n) {
|
|
204
212
|
var s;
|
|
205
|
-
let e =
|
|
213
|
+
let e = o;
|
|
206
214
|
for (const r of this.middlewares) {
|
|
207
215
|
const i = await ((s = r.onError) == null ? void 0 : s.call(r, {
|
|
208
216
|
...n,
|
|
@@ -227,37 +235,37 @@ class $ {
|
|
|
227
235
|
* @param middlewareCtx Контекст выполнения запроса
|
|
228
236
|
* @return Новый экземпляр `Response` при модификации ответа, или undefined
|
|
229
237
|
*/
|
|
230
|
-
async middlewareOnResponse(
|
|
238
|
+
async middlewareOnResponse(o, n) {
|
|
231
239
|
var e;
|
|
232
240
|
for (const s of this.middlewares) {
|
|
233
241
|
const r = await ((e = s.onResponse) == null ? void 0 : e.call(s, {
|
|
234
242
|
...n,
|
|
235
|
-
response:
|
|
243
|
+
response: o
|
|
236
244
|
}));
|
|
237
245
|
if (r) {
|
|
238
246
|
if (!(r instanceof Response))
|
|
239
247
|
throw new Error("onResponse: must return new Response() when modifying the response");
|
|
240
|
-
|
|
248
|
+
o = r;
|
|
241
249
|
}
|
|
242
250
|
}
|
|
243
|
-
return
|
|
251
|
+
return o;
|
|
244
252
|
}
|
|
245
253
|
}
|
|
246
|
-
const
|
|
247
|
-
const { postInWindow:
|
|
248
|
-
return
|
|
249
|
-
},
|
|
250
|
-
const { dataToForm:
|
|
251
|
-
return
|
|
252
|
-
},
|
|
254
|
+
const N = async (...t) => {
|
|
255
|
+
const { postInWindow: o } = await import("../.chunks/lazy-Crun7esL.es.js");
|
|
256
|
+
return o(...t);
|
|
257
|
+
}, G = async (...t) => {
|
|
258
|
+
const { dataToForm: o } = await import("../.chunks/lazy-Crun7esL.es.js");
|
|
259
|
+
return o(...t);
|
|
260
|
+
}, K = (t = {}, o) => new $(t, o);
|
|
253
261
|
export {
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
+
K as createClient,
|
|
263
|
+
G as dataToForm,
|
|
264
|
+
F as genExtRes,
|
|
265
|
+
X as genFieldFilter,
|
|
266
|
+
Y as genFieldOrder,
|
|
267
|
+
H as getBaseDomainUrl,
|
|
268
|
+
B as isPublicAPI,
|
|
269
|
+
N as postInWindow
|
|
262
270
|
};
|
|
263
271
|
//# sourceMappingURL=index.js.map
|