@topvisor/ui 1.3.5-5.0 → 1.4.0-TopGroupSelector.10
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/core-BL-38XF7.es.js +196 -0
- package/.chunks/core-BL-38XF7.es.js.map +1 -0
- package/.chunks/core-BsPx05H9.amd.js +2 -0
- package/.chunks/core-BsPx05H9.amd.js.map +1 -0
- package/.chunks/{datepicker-CPrHVH4x.amd.js → datepicker-3coUsFW2.amd.js} +2 -2
- package/.chunks/{datepicker-CPrHVH4x.amd.js.map → datepicker-3coUsFW2.amd.js.map} +1 -1
- package/.chunks/{datepicker-J8Zg9mKt.es.js → datepicker-D1Hw3a3o.es.js} +14 -17
- package/.chunks/{datepicker-J8Zg9mKt.es.js.map → datepicker-D1Hw3a3o.es.js.map} +1 -1
- package/.chunks/dialog_regionSelectorRegions-1UVhgK2f.es.js +180 -0
- package/.chunks/dialog_regionSelectorRegions-1UVhgK2f.es.js.map +1 -0
- package/.chunks/dialog_regionSelectorRegions-CZ8IX7la.amd.js +2 -0
- package/.chunks/dialog_regionSelectorRegions-CZ8IX7la.amd.js.map +1 -0
- package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-DvkvzHEY.es.js → dialogs.vue_vue_type_script_setup_true_lang-DRbTG0vh.es.js} +111 -112
- package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-DvkvzHEY.es.js.map → dialogs.vue_vue_type_script_setup_true_lang-DRbTG0vh.es.js.map} +1 -1
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-Dq9kWWMg.amd.js +2 -0
- package/.chunks/{dialogs.vue_vue_type_script_setup_true_lang-8KsNy0Bd.amd.js.map → dialogs.vue_vue_type_script_setup_true_lang-Dq9kWWMg.amd.js.map} +1 -1
- package/.chunks/forms-BseC3Ftz.es.js +2035 -0
- package/.chunks/{forms-COXAfg9G.es.js.map → forms-BseC3Ftz.es.js.map} +1 -1
- package/.chunks/forms-CUSCBQu3.amd.js +3 -0
- package/.chunks/{forms-DXX5M4DO.amd.js.map → forms-CUSCBQu3.amd.js.map} +1 -1
- package/.chunks/index-DLUtoTUg.amd.js +2 -0
- package/.chunks/index-DLUtoTUg.amd.js.map +1 -0
- package/.chunks/index-DkQWJkMc.es.js +54 -0
- package/.chunks/index-DkQWJkMc.es.js.map +1 -0
- package/.chunks/notice-Cl3ZgiHm.es.js +191 -0
- package/.chunks/{notice-P7CXfEuX.es.js.map → notice-Cl3ZgiHm.es.js.map} +1 -1
- package/.chunks/notice-DwjipV21.amd.js +4 -0
- package/.chunks/{notice-CSGn_jTM.amd.js.map → notice-DwjipV21.amd.js.map} +1 -1
- package/.chunks/page.vue_vue_type_script_setup_true_lang-CjIiZU-D.amd.js +2 -0
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-DHPOnLj5.amd.js.map → page.vue_vue_type_script_setup_true_lang-CjIiZU-D.amd.js.map} +1 -1
- package/.chunks/page.vue_vue_type_script_setup_true_lang-CpRJQFD1.es.js +139 -0
- package/.chunks/{page.vue_vue_type_script_setup_true_lang-D9m45rLs.es.js.map → page.vue_vue_type_script_setup_true_lang-CpRJQFD1.es.js.map} +1 -1
- package/.chunks/policy.vue_vue_type_style_index_0_lang-BBDJEs5Q.es.js +496 -0
- package/.chunks/policy.vue_vue_type_style_index_0_lang-BBDJEs5Q.es.js.map +1 -0
- package/.chunks/policy.vue_vue_type_style_index_0_lang-DJOaMdBm.amd.js +2 -0
- package/.chunks/policy.vue_vue_type_style_index_0_lang-DJOaMdBm.amd.js.map +1 -0
- package/.chunks/popup-DRuyYFGB.amd.js +2 -0
- package/.chunks/popup-DRuyYFGB.amd.js.map +1 -0
- package/.chunks/popup-Jw_Yyg3U.es.js +470 -0
- package/.chunks/popup-Jw_Yyg3U.es.js.map +1 -0
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DD59yF6H.es.js +209 -0
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DD59yF6H.es.js.map +1 -0
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DtiT6NE4.amd.js +2 -0
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-DtiT6NE4.amd.js.map +1 -0
- package/.chunks/utils-CzHUG_xz.amd.js +2 -0
- package/.chunks/{utils-D505nRsu.amd.js.map → utils-CzHUG_xz.amd.js.map} +1 -1
- package/.chunks/utils-D9nYQabE.amd.js +2 -0
- package/.chunks/{utils-DmxcQpWA.amd.js.map → utils-D9nYQabE.amd.js.map} +1 -1
- package/.chunks/{utils-CWm0zAtM.es.js → utils-Q69SXlnV.es.js} +192 -208
- package/.chunks/{utils-CWm0zAtM.es.js.map → utils-Q69SXlnV.es.js.map} +1 -1
- package/.chunks/{utils-Rbz9mxy6.es.js → utils-YrUExsH7.es.js} +23 -24
- package/.chunks/{utils-Rbz9mxy6.es.js.map → utils-YrUExsH7.es.js.map} +1 -1
- package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-TVpBXc9F.es.js → widgetInput.vue_vue_type_script_setup_true_lang-CDkeKVqY.es.js} +2 -2
- package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-TVpBXc9F.es.js.map → widgetInput.vue_vue_type_script_setup_true_lang-CDkeKVqY.es.js.map} +1 -1
- package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-BU-FdL6d.amd.js → widgetInput.vue_vue_type_script_setup_true_lang-CkE912ll.amd.js} +2 -2
- package/.chunks/{widgetInput.vue_vue_type_script_setup_true_lang-BU-FdL6d.amd.js.map → widgetInput.vue_vue_type_script_setup_true_lang-CkE912ll.amd.js.map} +1 -1
- package/api/index.amd.js +1 -1
- package/api/index.amd.js.map +1 -1
- package/api/index.js +138 -133
- package/api/index.js.map +1 -1
- package/assets/dialog_regionSelectorRegions.css +1 -0
- package/assets/forms.css +1 -1
- package/assets/policy.css +1 -0
- package/assets/popupHint.css +1 -1
- package/assets/project.css +1 -1
- package/charts/charts.amd.js +1 -1
- package/charts/charts.amd.js.map +1 -1
- package/charts/charts.js +80 -80
- package/charts/charts.js.map +1 -1
- package/core/app.amd.js +1 -1
- package/core/app.amd.js.map +1 -1
- package/core/app.js +93 -96
- package/core/app.js.map +1 -1
- package/dialog/dialog.amd.js +1 -1
- package/dialog/dialog.amd.js.map +1 -1
- package/dialog/dialog.js +13 -13
- package/dialog/dialog.js.map +1 -1
- package/extra/extra.amd.js +1 -1
- package/extra/extra.amd.js.map +1 -1
- package/extra/extra.js +20 -23
- package/extra/extra.js.map +1 -1
- package/forms/forms.amd.js +1 -1
- package/forms/forms.js +5 -5
- package/formsExt/formsExt.amd.js +1 -1
- package/formsExt/formsExt.amd.js.map +1 -1
- package/formsExt/formsExt.js +180 -541
- package/formsExt/formsExt.js.map +1 -1
- package/layout/layout.amd.js +1 -1
- package/layout/layout.js +6 -6
- package/package.json +1 -1
- package/popup/popup.amd.js +1 -1
- package/popup/popup.amd.js.map +1 -1
- package/popup/popup.js +43 -46
- package/popup/popup.js.map +1 -1
- package/popup/worker.amd.js +1 -1
- package/popup/worker.amd.js.map +1 -1
- package/popup/worker.js +11 -9
- package/popup/worker.js.map +1 -1
- package/project/project.amd.js +1 -1
- package/project/project.amd.js.map +1 -1
- package/project/project.js +847 -579
- package/project/project.js.map +1 -1
- package/src/api/api/client/client.d.ts +5 -0
- package/src/api/api/mocker/index.d.ts +3 -3
- package/src/api/api/types/client/request.d.ts +6 -0
- package/src/api/api/types/mocker.d.ts +2 -2
- package/src/components/formsExt/formsExt.d.ts +1 -0
- package/src/components/formsExt/selector2/cache.d.ts +12 -0
- package/src/components/formsExt/selector2/composables/useAPI.d.ts +2033 -0
- package/src/components/formsExt/selector2/composables/useMenu.d.ts +2045 -5
- package/src/components/formsExt/selector2/itemMulti.vue.d.ts +3 -3
- package/src/components/formsExt/selector2/selector2.vue.d.ts +9 -3
- package/src/components/formsExt/selector2/types.d.ts +25 -8
- package/src/components/formsExt/selector2/utils.d.ts +16 -0
- package/src/components/popup/lib/popup.d.ts +1 -2
- package/src/components/popup/popup/opener/types.d.ts +6 -2
- package/src/components/popup/popup/types.d.ts +3 -2
- package/src/components/popup/popup.d.ts +1 -1
- package/src/components/project/groupSelector/folders/folders.vue.d.ts +18 -0
- package/src/components/project/groupSelector/folders/types.d.ts +63 -0
- package/src/components/project/groupSelector/folders/utils.d.ts +63 -0
- package/src/components/project/groupSelector/groupSelector.vue.d.ts +33 -0
- package/src/components/project/groupSelector/groups/groups.vue.d.ts +126 -0
- package/src/components/project/groupSelector/groups/types.d.ts +58 -0
- package/src/components/project/groupSelector/groups/utils.d.ts +92 -0
- package/src/components/project/groupSelector/stories/mocks/folders.d.ts +4 -0
- package/src/components/project/groupSelector/stories/mocks/groups.d.ts +2 -0
- package/src/components/project/groupSelector/stories/mocks/index.d.ts +7 -0
- package/src/components/project/groupSelector/types.d.ts +133 -0
- package/src/components/project/project.d.ts +5 -4
- package/src/components/project/{selectorRegion → regionSelector}/utils/utils.d.ts +3 -3
- package/src/core/utils/composables/useWatch.d.ts +32 -0
- package/tabs/tabs.amd.js +1 -1
- package/tabs/tabs.amd.js.map +1 -1
- package/tabs/tabs.js +24 -24
- package/tabs/tabs.js.map +1 -1
- package/tabsView/tabsView.amd.js +1 -1
- package/tabsView/tabsView.amd.js.map +1 -1
- package/tabsView/tabsView.js +131 -133
- package/tabsView/tabsView.js.map +1 -1
- package/utils/clipboard.amd.js +1 -1
- package/utils/clipboard.js +1 -1
- package/utils/date.amd.js +1 -1
- package/utils/date.js +1 -1
- package/utils/device.amd.js +1 -1
- package/utils/device.js +1 -1
- package/utils/lodash.amd.js +1 -1
- package/utils/lodash.js +1 -1
- package/utils/price.amd.js +1 -1
- package/utils/price.js +1 -1
- package/utils/scroll.amd.js +1 -1
- package/utils/scroll.amd.js.map +1 -1
- package/utils/scroll.js +14 -14
- package/utils/scroll.js.map +1 -1
- package/utils/searchers.amd.js +1 -1
- package/utils/searchers.js +3 -3
- package/utils/string.amd.js +1 -1
- package/utils/string.amd.js.map +1 -1
- package/utils/string.js +3 -7
- package/utils/string.js.map +1 -1
- package/.chunks/core-CaWxDXrZ.es.js +0 -197
- package/.chunks/core-CaWxDXrZ.es.js.map +0 -1
- package/.chunks/core-DmO1i1Ua.amd.js +0 -2
- package/.chunks/core-DmO1i1Ua.amd.js.map +0 -1
- package/.chunks/dialog_selectorRegions-DoEjgXtb.es.js +0 -190
- package/.chunks/dialog_selectorRegions-DoEjgXtb.es.js.map +0 -1
- package/.chunks/dialog_selectorRegions-DzufTzj9.amd.js +0 -2
- package/.chunks/dialog_selectorRegions-DzufTzj9.amd.js.map +0 -1
- package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-8KsNy0Bd.amd.js +0 -2
- package/.chunks/forms-COXAfg9G.es.js +0 -2047
- package/.chunks/forms-DXX5M4DO.amd.js +0 -3
- package/.chunks/index-BEI7XZmU.amd.js +0 -2
- package/.chunks/index-BEI7XZmU.amd.js.map +0 -1
- package/.chunks/index-igPkes8X.es.js +0 -48
- package/.chunks/index-igPkes8X.es.js.map +0 -1
- package/.chunks/listItem.vue_vue_type_script_setup_true_lang--W1RouXP.es.js +0 -199
- package/.chunks/listItem.vue_vue_type_script_setup_true_lang--W1RouXP.es.js.map +0 -1
- package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DzV225TL.amd.js +0 -2
- package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DzV225TL.amd.js.map +0 -1
- package/.chunks/menu.vue_vue_type_style_index_0_lang-BiyxTfdE.es.js +0 -112
- package/.chunks/menu.vue_vue_type_style_index_0_lang-BiyxTfdE.es.js.map +0 -1
- package/.chunks/menu.vue_vue_type_style_index_0_lang-D3OAqOqX.amd.js +0 -2
- package/.chunks/menu.vue_vue_type_style_index_0_lang-D3OAqOqX.amd.js.map +0 -1
- package/.chunks/notice-CSGn_jTM.amd.js +0 -4
- package/.chunks/notice-P7CXfEuX.es.js +0 -194
- package/.chunks/opener.vue_vue_type_script_setup_true_lang-DRzrTv7Q.es.js +0 -36
- package/.chunks/opener.vue_vue_type_script_setup_true_lang-DRzrTv7Q.es.js.map +0 -1
- package/.chunks/opener.vue_vue_type_script_setup_true_lang-gNZhYkDf.amd.js +0 -2
- package/.chunks/opener.vue_vue_type_script_setup_true_lang-gNZhYkDf.amd.js.map +0 -1
- package/.chunks/page.vue_vue_type_script_setup_true_lang-D9m45rLs.es.js +0 -143
- package/.chunks/page.vue_vue_type_script_setup_true_lang-DHPOnLj5.amd.js +0 -2
- package/.chunks/popup-CF4k7j3U.amd.js +0 -2
- package/.chunks/popup-CF4k7j3U.amd.js.map +0 -1
- package/.chunks/popup-G7FYKscC.es.js +0 -485
- package/.chunks/popup-G7FYKscC.es.js.map +0 -1
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-Cce9ZdtW.amd.js +0 -2
- package/.chunks/popupHint.vue_vue_type_style_index_0_lang-Cce9ZdtW.amd.js.map +0 -1
- package/.chunks/utils-D505nRsu.amd.js +0 -2
- package/.chunks/utils-DmxcQpWA.amd.js +0 -2
- package/assets/dialog_selectorRegions.css +0 -1
- package/assets/formsExt.css +0 -1
- package/assets/listItem.css +0 -1
- package/assets/menu.css +0 -1
- package/src/components/popup/popup/opener.vue.d.ts +0 -17
- /package/src/components/project/{selectorCompetitors/selectorCompetitors.vue.d.ts → competitorSelector/competitorSelector.vue.d.ts} +0 -0
- /package/src/components/project/{selectorCompetitors → competitorSelector}/composables.d.ts +0 -0
- /package/src/components/project/{selectorCompetitors → competitorSelector}/types.d.ts +0 -0
- /package/src/components/project/{selectorRegion → regionSelector}/composables/compare.d.ts +0 -0
- /package/src/components/project/{selectorRegion → regionSelector}/composables/selectRegion.d.ts +0 -0
- /package/src/components/project/{selectorRegion → regionSelector}/composables/selectSearcher.d.ts +0 -0
- /package/src/components/project/{selectorRegion → regionSelector}/composables/selectorRegion.d.ts +0 -0
- /package/src/components/project/{selectorRegion/dialog_selectorRegions/dialog_selectorRegions.vue.d.ts → regionSelector/dialog_regionSelectorRegions/dialog_regionSelectorRegions.vue.d.ts} +0 -0
- /package/src/components/project/{selectorRegion/dialog_selectorRegions → regionSelector/dialog_regionSelectorRegions}/types.d.ts +0 -0
- /package/src/components/project/{selectorRegion/selectorRegion.vue.d.ts → regionSelector/regionSelector.vue.d.ts} +0 -0
- /package/src/components/project/{selectorRegion → regionSelector}/types.d.ts +0 -0
- /package/src/components/project/{selectorRegion → regionSelector}/utils/consts.d.ts +0 -0
package/api/index.js
CHANGED
|
@@ -1,142 +1,141 @@
|
|
|
1
|
-
import { g as
|
|
2
|
-
const
|
|
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) => ({
|
|
1
|
+
import { g as z, a as j } from "../.chunks/field-CyyFzM-Y.es.js";
|
|
2
|
+
const O = (o = {}) => (o = { ...o }, o.loadingEl ??= globalThis.document?.body, o.loadingShowSpinner ??= !0, o.method ??= "POST", o.accept ??= "application/json", o), S = (o, t, s) => ({
|
|
6
3
|
result: o,
|
|
7
4
|
errors: t,
|
|
8
|
-
response:
|
|
9
|
-
}),
|
|
10
|
-
const { protocol: e, hostname:
|
|
11
|
-
return `${e}//${d}${
|
|
12
|
-
},
|
|
13
|
-
(t) => t instanceof FileList || t instanceof File || t instanceof Blob || Array.isArray(t) && t.some((
|
|
14
|
-
),
|
|
5
|
+
response: s
|
|
6
|
+
}), k = (o) => o.startsWith("/system_2/common/"), A = (o = !1, t = window.location.href, s) => {
|
|
7
|
+
const { protocol: e, hostname: r, port: n } = new URL(t), i = r.split("."), d = !o || i.length <= 2 || /^[\d.]+$/.test(r) || r === "localhost" ? r : i.slice(-2).join(".");
|
|
8
|
+
return `${e}//${d}${n ? `:${n}` : ""}`;
|
|
9
|
+
}, F = (o) => Object.values(o).some(
|
|
10
|
+
(t) => t instanceof FileList || t instanceof File || t instanceof Blob || Array.isArray(t) && t.some((s) => s instanceof File || s instanceof Blob)
|
|
11
|
+
), C = (o, t, s) => {
|
|
15
12
|
const e = {
|
|
16
13
|
inLoading: !1,
|
|
17
14
|
path: t,
|
|
18
15
|
url: o.options.baseUrl + t,
|
|
19
|
-
options:
|
|
16
|
+
options: O(o.options.requestOptions),
|
|
20
17
|
mockerOptions: void 0,
|
|
21
18
|
params: {},
|
|
22
19
|
// незаполненное свойство
|
|
23
20
|
getInLoading: () => e.inLoading,
|
|
24
|
-
setParams: (
|
|
25
|
-
changeParams: (
|
|
26
|
-
setOptions: (
|
|
27
|
-
setMocker: (
|
|
28
|
-
call: async (
|
|
29
|
-
callFetch: async (
|
|
30
|
-
callInNewWindow: async (
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
(u = (p = o.options).onPrepareData) == null || u.call(p, r, i);
|
|
21
|
+
setParams: (r) => (e.params = { ...r }, e),
|
|
22
|
+
changeParams: (r) => (Object.assign(e.params, r), e),
|
|
23
|
+
setOptions: (r) => (Object.assign(e.options, r), e),
|
|
24
|
+
setMocker: (r) => (e.mockerOptions = r, e),
|
|
25
|
+
call: async (r) => e.exec(r),
|
|
26
|
+
callFetch: async (r, n) => e.exec(n, r),
|
|
27
|
+
callInNewWindow: async (r) => {
|
|
28
|
+
const n = e.genData(r), i = o.genMiddlewareCtx(e, n);
|
|
29
|
+
o.options.onPrepareData?.(n, i);
|
|
34
30
|
const { postInWindow: d } = await import("../.chunks/lazy-40pjr8cZ.es.js");
|
|
35
|
-
d(e.url,
|
|
31
|
+
d(e.url, n, "_blank");
|
|
36
32
|
},
|
|
37
|
-
callInSelfWindow: async (
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
(u = (p = o.options).onPrepareData) == null || u.call(p, r, i);
|
|
33
|
+
callInSelfWindow: async (r) => {
|
|
34
|
+
const n = e.genData(r), i = o.genMiddlewareCtx(e, n);
|
|
35
|
+
o.options.onPrepareData?.(n, i);
|
|
41
36
|
const { postInWindow: d } = await import("../.chunks/lazy-40pjr8cZ.es.js");
|
|
42
|
-
d(e.url,
|
|
37
|
+
d(e.url, n, "_self");
|
|
43
38
|
},
|
|
44
|
-
genData: (
|
|
39
|
+
genData: (r, n) => {
|
|
45
40
|
const i = { ...e.params };
|
|
46
|
-
if (delete i.fetch_style,
|
|
47
|
-
let d = [...
|
|
48
|
-
|
|
41
|
+
if (delete i.fetch_style, r) {
|
|
42
|
+
let d = [...r];
|
|
43
|
+
s && (d = d.filter((l) => s.includes(l))), i.fields = d;
|
|
49
44
|
} else
|
|
50
|
-
|
|
51
|
-
return
|
|
45
|
+
s && (i.fields = s);
|
|
46
|
+
return n && (i.fetch_style = n), i;
|
|
47
|
+
},
|
|
48
|
+
abortByFingerprint: () => {
|
|
49
|
+
if (!e.options.checkFingerprint) return;
|
|
50
|
+
const r = e.path + e.options.checkFingerprint;
|
|
51
|
+
o.abortControllers[r]?.abort(
|
|
52
|
+
new DOMException(`Stopped previous request by fingerprint: ${e.options.checkFingerprint}`, "AbortError")
|
|
53
|
+
);
|
|
54
|
+
const n = new AbortController();
|
|
55
|
+
return o.abortControllers[r] = n, n.signal;
|
|
52
56
|
},
|
|
53
57
|
/**
|
|
54
58
|
* Общая функция выполнения запросов
|
|
55
59
|
*/
|
|
56
|
-
async exec(
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
return await c(e.mockerOptions, s, p);
|
|
62
|
-
}
|
|
63
|
-
const y = $(p);
|
|
64
|
-
if (y && e.options.method !== "POST")
|
|
60
|
+
async exec(r, n) {
|
|
61
|
+
const i = o.options.Request, d = o.options.fetch, l = e.genData(r, n), g = o.genMiddlewareCtx(e, l);
|
|
62
|
+
o.options.onPrepareData?.(l, g);
|
|
63
|
+
const x = F(l);
|
|
64
|
+
if (x && e.options.method !== "POST")
|
|
65
65
|
throw new Error("Files can be sent only in POST requests");
|
|
66
|
-
let
|
|
67
|
-
if (
|
|
66
|
+
let R = e.url, y;
|
|
67
|
+
if (x) {
|
|
68
68
|
if (e.options.method !== "POST")
|
|
69
69
|
throw new Error("Files can be sent only in POST requests");
|
|
70
|
-
const { formDataSerializer:
|
|
71
|
-
|
|
72
|
-
} else e.options.method !== "POST" ?
|
|
73
|
-
let E;
|
|
74
|
-
if (
|
|
75
|
-
const
|
|
76
|
-
|
|
77
|
-
const w = new AbortController();
|
|
78
|
-
o.abortControllers[c] = w, E = w.signal;
|
|
70
|
+
const { formDataSerializer: p } = await import("../.chunks/lazy-40pjr8cZ.es.js");
|
|
71
|
+
y = p(l);
|
|
72
|
+
} else e.options.method !== "POST" ? R += "?" + await o.options.querySerializer(l) : y = o.options.bodySerializer(l);
|
|
73
|
+
let E = e.abortByFingerprint();
|
|
74
|
+
if (e.mockerOptions) {
|
|
75
|
+
const { genMockResponse: p } = await import("../.chunks/index-DkQWJkMc.es.js");
|
|
76
|
+
return await p(e.mockerOptions, r, l, E);
|
|
79
77
|
}
|
|
80
|
-
const
|
|
78
|
+
const P = {
|
|
81
79
|
...o.options,
|
|
82
80
|
method: e.options.method,
|
|
83
|
-
body:
|
|
81
|
+
body: y,
|
|
84
82
|
signal: E
|
|
85
83
|
};
|
|
86
|
-
let
|
|
87
|
-
|
|
88
|
-
const
|
|
89
|
-
...
|
|
90
|
-
request:
|
|
84
|
+
let f = new i(R, P);
|
|
85
|
+
f.headers.set("x-request-id", g.id), f.headers.set("accept", e.options.accept), x || f.headers.set("content-type", "application/json");
|
|
86
|
+
const u = {
|
|
87
|
+
...g,
|
|
88
|
+
request: f
|
|
91
89
|
};
|
|
92
|
-
e.inLoading = !0,
|
|
93
|
-
let
|
|
94
|
-
const
|
|
95
|
-
if (
|
|
90
|
+
e.inLoading = !0, e.options.onLoading?.(e.inLoading, u);
|
|
91
|
+
let a;
|
|
92
|
+
const w = await o.middlewareOnRequest(f, u);
|
|
93
|
+
if (w instanceof Response ? a = w : w instanceof i && (f = w), !a)
|
|
96
94
|
try {
|
|
97
|
-
|
|
98
|
-
} catch (
|
|
99
|
-
|
|
95
|
+
a = await d(f);
|
|
96
|
+
} catch (p) {
|
|
97
|
+
a = await o.middlewareOnError(p, u);
|
|
100
98
|
} finally {
|
|
101
|
-
e.inLoading = !1,
|
|
99
|
+
e.inLoading = !1, e.options.onLoading?.(e.inLoading, u);
|
|
102
100
|
}
|
|
103
|
-
|
|
104
|
-
let
|
|
101
|
+
a = await o.middlewareOnResponse(a, u);
|
|
102
|
+
let c, h, m;
|
|
105
103
|
try {
|
|
106
|
-
const
|
|
107
|
-
|
|
108
|
-
} catch (
|
|
109
|
-
if ((
|
|
110
|
-
let
|
|
111
|
-
|
|
104
|
+
const p = a.headers.get("content-type")?.includes("application/json");
|
|
105
|
+
h = await a.text(), this.options.accept === "application/json" || p ? c = JSON.parse(h) : o.useExt ? c = S(h, void 0, a) : c = h;
|
|
106
|
+
} catch (p) {
|
|
107
|
+
if ((p instanceof SyntaxError || p instanceof TypeError) && (m = p, m.responseText = h), o.useExt && m) {
|
|
108
|
+
let b = a.status, q = a.statusText;
|
|
109
|
+
b === 200 && (b = 1e4, q = "Error API response"), c = S(null, [
|
|
112
110
|
{
|
|
113
|
-
code:
|
|
114
|
-
string:
|
|
111
|
+
code: b,
|
|
112
|
+
string: q
|
|
115
113
|
}
|
|
116
|
-
],
|
|
114
|
+
], a), o.options.useApiConsole && console.error(p);
|
|
117
115
|
} else
|
|
118
|
-
throw
|
|
116
|
+
throw p;
|
|
119
117
|
}
|
|
120
|
-
return o.useExt && (
|
|
118
|
+
return o.useExt && (c.response = a, c && e.options.onApiLoaded?.(c, u), c?.errors && (o.options.useApiConsole && console.warn(new Error("API error"), { res: c }), e.options.onApiError?.(c, { ...u, formatError: m }, o.options.requestOptions?.onApiError)), c?.messages && e.options.onApiMessage?.(c, u)), c;
|
|
121
119
|
}
|
|
122
120
|
};
|
|
123
121
|
return e;
|
|
124
122
|
};
|
|
125
|
-
class
|
|
123
|
+
class I {
|
|
126
124
|
options;
|
|
127
125
|
useExt;
|
|
128
126
|
middlewares = [];
|
|
127
|
+
mokerByPath = /* @__PURE__ */ new Map();
|
|
129
128
|
abortControllers = {};
|
|
130
|
-
constructor(t = {},
|
|
131
|
-
t.requestOptions =
|
|
132
|
-
const { querySerializer:
|
|
133
|
-
return
|
|
134
|
-
}, t.bodySerializer ??= (e) => typeof e == "string" ? e : JSON.stringify(e), this.options = t, this.useExt =
|
|
129
|
+
constructor(t = {}, s) {
|
|
130
|
+
t.requestOptions = O(t.requestOptions), t.useApiConsole ??= !0, t.fetch ??= globalThis.fetch, t.Request ??= globalThis.Request, t.querySerializer ??= async (e) => {
|
|
131
|
+
const { querySerializer: r } = await import("../.chunks/lazy-40pjr8cZ.es.js");
|
|
132
|
+
return r(e);
|
|
133
|
+
}, t.bodySerializer ??= (e) => typeof e == "string" ? e : JSON.stringify(e), this.options = t, this.useExt = s;
|
|
135
134
|
}
|
|
136
135
|
generateUUID() {
|
|
137
|
-
return crypto
|
|
138
|
-
const
|
|
139
|
-
return (t === "x" ?
|
|
136
|
+
return crypto?.randomUUID ? crypto.randomUUID() : "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, (t) => {
|
|
137
|
+
const s = Math.random() * 16 | 0;
|
|
138
|
+
return (t === "x" ? s : s & 3 | 8).toString(16);
|
|
140
139
|
});
|
|
141
140
|
}
|
|
142
141
|
/**
|
|
@@ -155,20 +154,20 @@ class J {
|
|
|
155
154
|
* @param path Путь метода API
|
|
156
155
|
* @param fieldsNarrow Список получаемых полей, для методов API с моделью. Если объект запроса переиспользуется, и список полей меняется, указывайте его непосредственно при вызове `api.call()`
|
|
157
156
|
*/
|
|
158
|
-
gen(t,
|
|
159
|
-
return
|
|
157
|
+
gen(t, s) {
|
|
158
|
+
return C(this, t, s);
|
|
160
159
|
}
|
|
161
160
|
/**
|
|
162
161
|
* Создать объект запроса, не описанного в OpenAPI
|
|
163
162
|
*/
|
|
164
|
-
genAny(t,
|
|
165
|
-
return this.gen(t,
|
|
163
|
+
genAny(t, s) {
|
|
164
|
+
return this.gen(t, s);
|
|
166
165
|
}
|
|
167
166
|
/**
|
|
168
167
|
* Создать контекст выполнения запроса
|
|
169
168
|
*/
|
|
170
|
-
genMiddlewareCtx(t,
|
|
171
|
-
const e = this.generateUUID(),
|
|
169
|
+
genMiddlewareCtx(t, s) {
|
|
170
|
+
const e = this.generateUUID(), r = Object.freeze({
|
|
172
171
|
baseUrl: this.options.baseUrl,
|
|
173
172
|
querySerializer: this.options.querySerializer,
|
|
174
173
|
bodySerializer: this.options.bodySerializer,
|
|
@@ -178,9 +177,9 @@ class J {
|
|
|
178
177
|
return {
|
|
179
178
|
useExt: this.useExt,
|
|
180
179
|
requestOptions: t.options,
|
|
181
|
-
data:
|
|
180
|
+
data: s,
|
|
182
181
|
middlewareData: {},
|
|
183
|
-
options:
|
|
182
|
+
options: r,
|
|
184
183
|
schemaPath: t.path,
|
|
185
184
|
id: e
|
|
186
185
|
};
|
|
@@ -192,13 +191,12 @@ class J {
|
|
|
192
191
|
* @param middlewareCtx Контекст выполнения запроса
|
|
193
192
|
* @return Новый экземпляр `Request` или `Response` при модификации запроса, или undefined
|
|
194
193
|
*/
|
|
195
|
-
async middlewareOnRequest(t,
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
...n,
|
|
194
|
+
async middlewareOnRequest(t, s) {
|
|
195
|
+
for (const e of this.middlewares) {
|
|
196
|
+
const r = await e.onRequest?.({
|
|
197
|
+
...s,
|
|
200
198
|
request: t
|
|
201
|
-
})
|
|
199
|
+
});
|
|
202
200
|
if (r)
|
|
203
201
|
if (r instanceof Request)
|
|
204
202
|
t = r;
|
|
@@ -217,19 +215,18 @@ class J {
|
|
|
217
215
|
* @param middlewareCtx
|
|
218
216
|
* @return Новый экземпляр `Response` при успешной обработке или выбрасывает ошибку
|
|
219
217
|
*/
|
|
220
|
-
async middlewareOnError(t,
|
|
221
|
-
var s;
|
|
218
|
+
async middlewareOnError(t, s) {
|
|
222
219
|
let e = t;
|
|
223
220
|
for (const r of this.middlewares) {
|
|
224
|
-
const
|
|
225
|
-
...
|
|
221
|
+
const n = await r.onError?.({
|
|
222
|
+
...s,
|
|
226
223
|
error: e
|
|
227
|
-
})
|
|
228
|
-
if (
|
|
229
|
-
if (
|
|
230
|
-
return
|
|
231
|
-
if (
|
|
232
|
-
e =
|
|
224
|
+
});
|
|
225
|
+
if (n) {
|
|
226
|
+
if (n instanceof Response)
|
|
227
|
+
return n;
|
|
228
|
+
if (n instanceof Error) {
|
|
229
|
+
e = n;
|
|
233
230
|
continue;
|
|
234
231
|
}
|
|
235
232
|
throw new Error("onError: must return new Response() or instance of Error");
|
|
@@ -244,13 +241,12 @@ class J {
|
|
|
244
241
|
* @param middlewareCtx Контекст выполнения запроса
|
|
245
242
|
* @return Новый экземпляр `Response` при модификации ответа, или undefined
|
|
246
243
|
*/
|
|
247
|
-
async middlewareOnResponse(t,
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
...n,
|
|
244
|
+
async middlewareOnResponse(t, s) {
|
|
245
|
+
for (const e of this.middlewares) {
|
|
246
|
+
const r = await e.onResponse?.({
|
|
247
|
+
...s,
|
|
252
248
|
response: t
|
|
253
|
-
})
|
|
249
|
+
});
|
|
254
250
|
if (r) {
|
|
255
251
|
if (!(r instanceof Response))
|
|
256
252
|
throw new Error("onResponse: must return new Response() when modifying the response");
|
|
@@ -259,22 +255,31 @@ class J {
|
|
|
259
255
|
}
|
|
260
256
|
return t;
|
|
261
257
|
}
|
|
258
|
+
/**
|
|
259
|
+
* Установить генератор данных вместо реальных запросов к серверу для конкретного метода API
|
|
260
|
+
*/
|
|
261
|
+
setMocker(t, s) {
|
|
262
|
+
this.mokerByPath.set(t, s), this.genOriginal || (this.genOriginal = this.gen.bind(this), this.gen = (e, r) => {
|
|
263
|
+
const n = this.genOriginal(e, r), i = this.mokerByPath.get(e);
|
|
264
|
+
return i && n.setMocker(i), n;
|
|
265
|
+
});
|
|
266
|
+
}
|
|
262
267
|
}
|
|
263
|
-
const
|
|
268
|
+
const T = async (...o) => {
|
|
264
269
|
const { postInWindow: t } = await import("../.chunks/lazy-40pjr8cZ.es.js");
|
|
265
270
|
return t(...o);
|
|
266
|
-
},
|
|
271
|
+
}, D = async (...o) => {
|
|
267
272
|
const { dataToForm: t } = await import("../.chunks/lazy-40pjr8cZ.es.js");
|
|
268
273
|
return t(...o);
|
|
269
|
-
},
|
|
274
|
+
}, M = (o = {}, t) => new I(o, t);
|
|
270
275
|
export {
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
276
|
+
M as createClient,
|
|
277
|
+
D as dataToForm,
|
|
278
|
+
S as genExtRes,
|
|
279
|
+
z as genFieldFilter,
|
|
280
|
+
j as genFieldOrder,
|
|
281
|
+
A as getBaseDomainUrl,
|
|
282
|
+
k as isPublicAPI,
|
|
283
|
+
T as postInWindow
|
|
279
284
|
};
|
|
280
285
|
//# 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, 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';\n\n/**\n * Проверить передаются ли файлы\n */\nconst checkHasFiles = (data: Record<string, any>): boolean => {\n\treturn Object.values(data).some(value =>\n\t\tvalue instanceof FileList ||\n\t\tvalue instanceof File ||\n\t\tvalue instanceof Blob ||\n\t\tArray.isArray(value) && value.some(item => item instanceof File || item instanceof Blob),\n\t);\n};\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\tconst hasFiles = checkHasFiles(data);\n\t\t\tif (hasFiles && clientRequest.options.method !== 'POST') {\n\t\t\t\tthrow new Error('Files can be sent only in POST requests');\n\t\t\t}\n\n\t\t\tlet url = clientRequest.url;\n\n\t\t\tlet requestInitBody: string | FormData | undefined = undefined;\n\n\t\t\tif (hasFiles) {\n\t\t\t\tif (clientRequest.options.method !== 'POST') {\n\t\t\t\t\tthrow new Error('Files can be sent only in POST requests');\n\t\t\t\t}\n\n\t\t\t\tconst { formDataSerializer } = await import('../utils/lazy');\n\t\t\t\trequestInitBody = formDataSerializer(data);\n\t\t\t} else if (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: 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('accept', clientRequest.options.accept);\n\n\t\t\t// при отправке данных в `FormData` `fetch()` сам укажет правильный заголовок `multipart/form-data`\n\t\t\tif (!hasFiles) {\n\t\t\t\trequest.headers.set('content-type', 'application/json');\n\t\t\t}\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","subdomain","protocol","hostname","port","parts","baseHostname","checkHasFiles","data","value","item","createRequest","client","fieldsNarrow","clientRequest","params","options","fields","fetchStyle","middlewareCtx","_b","postInWindow","post","fieldsPrepared","field","Request","fetch","middlewareCtxWithoutRequest","genMockResponse","hasFiles","url","requestInitBody","formDataSerializer","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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"}
|
|
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, 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';\n\n/**\n * Проверить передаются ли файлы\n */\nconst checkHasFiles = (data: Record<string, any>): boolean => {\n\treturn Object.values(data).some(value =>\n\t\tvalue instanceof FileList ||\n\t\tvalue instanceof File ||\n\t\tvalue instanceof Blob ||\n\t\tArray.isArray(value) && value.some(item => item instanceof File || item instanceof Blob),\n\t);\n};\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\tabortByFingerprint: () => {\n\t\t\tif (!clientRequest.options.checkFingerprint) return;\n\n\t\t\tconst fingerprint = clientRequest.path + clientRequest.options.checkFingerprint;\n\n\t\t\tclient.abortControllers[fingerprint]?.abort(\n\t\t\t\tnew DOMException(`Stopped previous request by fingerprint: ${clientRequest.options.checkFingerprint}`, 'AbortError'),\n\t\t\t);\n\n\t\t\tconst controller = new AbortController();\n\n\t\t\tclient.abortControllers[fingerprint] = controller;\n\n\t\t\treturn controller.signal;\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\tconst hasFiles = checkHasFiles(data);\n\t\t\tif (hasFiles && clientRequest.options.method !== 'POST') {\n\t\t\t\tthrow new Error('Files can be sent only in POST requests');\n\t\t\t}\n\n\t\t\tlet url = clientRequest.url;\n\n\t\t\tlet requestInitBody: string | FormData | undefined = undefined;\n\n\t\t\tif (hasFiles) {\n\t\t\t\tif (clientRequest.options.method !== 'POST') {\n\t\t\t\t\tthrow new Error('Files can be sent only in POST requests');\n\t\t\t\t}\n\n\t\t\t\tconst { formDataSerializer } = await import('../utils/lazy');\n\t\t\t\trequestInitBody = formDataSerializer(data);\n\t\t\t} else if (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 = clientRequest.abortByFingerprint();\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, requestInitSignal);\n\t\t\t}\n\n\t\t\tconst requestInit: 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('accept', clientRequest.options.accept);\n\n\t\t\t// при отправке данных в `FormData` `fetch()` сам укажет правильный заголовок `multipart/form-data`\n\t\t\tif (!hasFiles) {\n\t\t\t\trequest.headers.set('content-type', 'application/json');\n\t\t\t}\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\tprivate mokerByPath = new Map<Api.Path<paths>, Api.Mocker.Options<any, any>>();\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\t/**\n\t * Установить генератор данных вместо реальных запросов к серверу для конкретного метода API\n\t */\n\tsetMocker<\n\t\tResult extends Api.Mocker.Result = Api.Mocker.Result,\n\t\tParams extends Api.Mocker.Params = Api.Mocker.Params\n\t>(\n\t\tpath: Api.Path<paths>,\n\t\tmocker: Api.Mocker.Options<Result, Params>,\n\t) {\n\t\tthis.mokerByPath.set(path, mocker);\n\n\t\t// @ts-ignore\n\t\tif (!this.genOriginal) {\n\t\t\t// @ts-ignore\n\t\t\tthis.genOriginal = this.gen.bind(this);\n\n\t\t\tthis.gen = (_path, fieldsNarrow) => {\n\t\t\t\t// @ts-ignore\n\t\t\t\tconst api = this.genOriginal(_path, fieldsNarrow);\n\n\t\t\t\tconst mocker = this.mokerByPath.get(_path);\n\t\t\t\tif (mocker) {\n\t\t\t\t\tapi.setMocker(mocker);\n\t\t\t\t}\n\n\t\t\t\treturn api;\n\t\t\t};\n\t\t}\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","parts","baseHostname","checkHasFiles","data","value","item","createRequest","client","fieldsNarrow","clientRequest","params","options","fields","fetchStyle","middlewareCtx","postInWindow","post","fieldsPrepared","field","fingerprint","controller","Request","fetch","middlewareCtxWithoutRequest","hasFiles","url","requestInitBody","formDataSerializer","requestInitSignal","genMockResponse","requestInit","request","requestOrResponse","e","res","responseText","formatError","isJSON","errorCode","errorMessage","Client","clientOptions","useExt","querySerializer","body","c","r","middleware","id","error","errorAfterMiddleware","mocker","_path","api","args","dataToForm","createClient"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
#dialog_regionSelectorRegions .modal-body{--scroll-offset-top: 40px}.dialog_regionSelectorRegions_header,.dialog_regionSelectorRegions_region{padding-right:10px;padding-left:10px;display:flex;align-items:center;gap:4px}.dialog_regionSelectorRegions_header{background:inherit;height:40px;padding-left:10px;gap:2px;position:sticky;top:0}.dialog_regionSelectorRegions_sortButton{--top-icon-size: 18px}.dialog_regionSelectorRegions_region{border-radius:var(--top-radius-2)}.dialog_regionSelectorRegions_region:hover{background:var(--color-bg-shading-1)}.dialog_regionSelectorRegions_region .top-forms-optionLabel_title{gap:4px}.dialog_regionSelectorRegions_regionSearcherIcon{--top-icon-size: 20px;color:var(--color-text-3);margin:0 4px 0 2px}.dialog_regionSelectorRegions_regionAreaName{color:var(--color-text-3);font-size:var(--top-font-size-s)}
|