@topvisor/ui 1.5.0 → 1.5.1-0
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/{api-DW3Y93Lp.amd.js → api-CBMWBeCS.amd.js} +2 -2
- package/.chunks/{api-DW3Y93Lp.amd.js.map → api-CBMWBeCS.amd.js.map} +1 -1
- package/.chunks/{api-DW3Y93Lp.esm.js → api-CBMWBeCS.esm.js} +2 -2
- package/.chunks/{api-DW3Y93Lp.esm.js.map → api-CBMWBeCS.esm.js.map} +1 -1
- package/.chunks/{app-Df8tFGnf.amd.js → app-DyAn8Ury.amd.js} +2 -2
- package/.chunks/{app-Df8tFGnf.amd.js.map → app-DyAn8Ury.amd.js.map} +1 -1
- package/.chunks/{app-Df8tFGnf.esm.js → app-DyAn8Ury.esm.js} +6 -6
- package/.chunks/{app-Df8tFGnf.esm.js.map → app-DyAn8Ury.esm.js.map} +1 -1
- package/.chunks/{datepicker-06ASYGz9.amd.js → datepicker-BmHkZfBO.amd.js} +2 -2
- package/.chunks/{datepicker-06ASYGz9.amd.js.map → datepicker-BmHkZfBO.amd.js.map} +1 -1
- package/.chunks/{datepicker-06ASYGz9.esm.js → datepicker-BmHkZfBO.esm.js} +2 -2
- package/.chunks/{datepicker-06ASYGz9.esm.js.map → datepicker-BmHkZfBO.esm.js.map} +1 -1
- package/.chunks/{dialog-TwUfHMd8.amd.js → dialog-bIV6Y2PF.amd.js} +2 -2
- package/.chunks/{dialog-TwUfHMd8.amd.js.map → dialog-bIV6Y2PF.amd.js.map} +1 -1
- package/.chunks/{dialog-TwUfHMd8.esm.js → dialog-bIV6Y2PF.esm.js} +4 -4
- package/.chunks/{dialog-TwUfHMd8.esm.js.map → dialog-bIV6Y2PF.esm.js.map} +1 -1
- package/.chunks/{dialog_regionSelectorRegions-D2PDcJOI.amd.js → dialog_regionSelectorRegions-gPKA93af.amd.js} +2 -2
- package/.chunks/{dialog_regionSelectorRegions-D2PDcJOI.amd.js.map → dialog_regionSelectorRegions-gPKA93af.amd.js.map} +1 -1
- package/.chunks/{dialog_regionSelectorRegions-D2PDcJOI.esm.js → dialog_regionSelectorRegions-gPKA93af.esm.js} +5 -5
- package/.chunks/{dialog_regionSelectorRegions-D2PDcJOI.esm.js.map → dialog_regionSelectorRegions-gPKA93af.esm.js.map} +1 -1
- package/.chunks/{dialogs-69JOByg2.amd.js → dialogs-CE8F7A0M.amd.js} +2 -2
- package/.chunks/{dialogs-69JOByg2.amd.js.map → dialogs-CE8F7A0M.amd.js.map} +1 -1
- package/.chunks/{dialogs-69JOByg2.esm.js → dialogs-CE8F7A0M.esm.js} +3 -3
- package/.chunks/{dialogs-69JOByg2.esm.js.map → dialogs-CE8F7A0M.esm.js.map} +1 -1
- package/.chunks/{forms-3oS4Utyg.amd.js → forms-DByj6MWE.amd.js} +2 -2
- package/.chunks/{forms-3oS4Utyg.amd.js.map → forms-DByj6MWE.amd.js.map} +1 -1
- package/.chunks/{forms-3oS4Utyg.esm.js → forms-DByj6MWE.esm.js} +5 -5
- package/.chunks/{forms-3oS4Utyg.esm.js.map → forms-DByj6MWE.esm.js.map} +1 -1
- package/.chunks/{formsExt-CdLb48ea.amd.js → formsExt-LekJqOck.amd.js} +2 -2
- package/.chunks/formsExt-LekJqOck.amd.js.map +1 -0
- package/.chunks/{formsExt-CdLb48ea.esm.js → formsExt-LekJqOck.esm.js} +5 -4
- package/.chunks/formsExt-LekJqOck.esm.js.map +1 -0
- package/.chunks/{notice-CBraHnl2.amd.js → notice-Ds5K-ei_.amd.js} +2 -2
- package/.chunks/{notice-CBraHnl2.amd.js.map → notice-Ds5K-ei_.amd.js.map} +1 -1
- package/.chunks/{notice-CBraHnl2.esm.js → notice-Ds5K-ei_.esm.js} +2 -2
- package/.chunks/{notice-CBraHnl2.esm.js.map → notice-Ds5K-ei_.esm.js.map} +1 -1
- package/.chunks/popup-BxGYabRi.amd.js +2 -0
- package/.chunks/popup-BxGYabRi.amd.js.map +1 -0
- package/.chunks/{popup--ITACA7I.esm.js → popup-BxGYabRi.esm.js} +8 -7
- package/.chunks/popup-BxGYabRi.esm.js.map +1 -0
- package/.chunks/popup-Cvyqovn6.amd.js +2 -0
- package/.chunks/popup-Cvyqovn6.amd.js.map +1 -0
- package/.chunks/{popup-CAy1LTfy.esm.js → popup-Cvyqovn6.esm.js} +4 -4
- package/.chunks/popup-Cvyqovn6.esm.js.map +1 -0
- package/.chunks/{utils-BAP3Hzmk.amd.js → utils-mRLC32Uo.amd.js} +2 -2
- package/.chunks/{utils-BAP3Hzmk.amd.js.map → utils-mRLC32Uo.amd.js.map} +1 -1
- package/.chunks/{utils-BAP3Hzmk.esm.js → utils-mRLC32Uo.esm.js} +4 -4
- package/.chunks/{utils-BAP3Hzmk.esm.js.map → utils-mRLC32Uo.esm.js.map} +1 -1
- package/.chunks/{utils-DI45Ujdf.amd.js → utils-sPSU5tXH.amd.js} +2 -2
- package/.chunks/{utils-DI45Ujdf.amd.js.map → utils-sPSU5tXH.amd.js.map} +1 -1
- package/.chunks/{utils-DI45Ujdf.esm.js → utils-sPSU5tXH.esm.js} +3 -3
- package/.chunks/{utils-DI45Ujdf.esm.js.map → utils-sPSU5tXH.esm.js.map} +1 -1
- package/.chunks/worker-Cx7e_9o9.amd.js +2 -0
- package/.chunks/worker-Cx7e_9o9.amd.js.map +1 -0
- package/.chunks/{worker-OsfdwnCi.esm.js → worker-Cx7e_9o9.esm.js} +21 -3
- package/.chunks/worker-Cx7e_9o9.esm.js.map +1 -0
- package/api/index.amd.js +1 -1
- package/api/index.amd.js.map +1 -1
- package/api/index.js +1 -1
- package/assets/project.css +1 -1
- package/autoload-css-manifest.amd.json +4 -4
- package/autoload-css-manifest.json +4 -4
- package/charts/charts.amd.js +1 -1
- package/charts/charts.amd.js.map +1 -1
- package/charts/charts.js +1 -1
- package/core/app.amd.js +1 -1
- package/core/app.amd.js.map +1 -1
- package/core/app.js +4 -4
- package/dialog/dialog.amd.js +1 -1
- package/dialog/dialog.amd.js.map +1 -1
- package/dialog/dialog.js +3 -3
- package/forms/forms.amd.js +1 -1
- package/forms/forms.amd.js.map +1 -1
- package/forms/forms.js +1 -1
- package/formsExt/formsExt.amd.js +1 -1
- package/formsExt/formsExt.amd.js.map +1 -1
- package/formsExt/formsExt.js +1 -1
- package/layout/layout.amd.js +1 -1
- package/layout/layout.amd.js.map +1 -1
- package/layout/layout.js +1 -1
- package/package.json +1 -1
- package/popup/popup.amd.js +1 -1
- package/popup/popup.amd.js.map +1 -1
- package/popup/popup.js +1 -1
- package/popup/worker.amd.js +1 -1
- package/popup/worker.amd.js.map +1 -1
- package/popup/worker.js +1 -1
- package/project/project.amd.js +1 -1
- package/project/project.amd.js.map +1 -1
- package/project/project.js +260 -215
- package/project/project.js.map +1 -1
- package/src/components/formsExt/selector2/types.d.ts +10 -0
- package/src/components/popup/lib/worker.d.ts +13 -1
- package/src/components/project/groupSelector/groups/types.d.ts +6 -0
- package/src/components/project/groupSelector/groups/utils.d.ts +43 -1
- package/src/components/project/groupSelector/types.d.ts +8 -0
- package/tabsView/tabsView.amd.js +1 -1
- package/tabsView/tabsView.amd.js.map +1 -1
- package/tabsView/tabsView.js +2 -2
- package/utils/clipboard.amd.js +1 -1
- package/utils/clipboard.amd.js.map +1 -1
- package/utils/clipboard.js +1 -1
- package/utils/date.amd.js +1 -1
- package/utils/date.amd.js.map +1 -1
- package/utils/date.js +1 -1
- package/utils/device.amd.js +1 -1
- package/utils/device.amd.js.map +1 -1
- package/utils/device.js +1 -1
- package/utils/lodash.amd.js +1 -1
- package/utils/lodash.amd.js.map +1 -1
- package/utils/lodash.js +1 -1
- package/utils/price.amd.js +1 -1
- package/utils/price.amd.js.map +1 -1
- package/utils/price.js +1 -1
- package/utils/searchers.amd.js +1 -1
- package/utils/searchers.amd.js.map +1 -1
- package/utils/searchers.js +1 -1
- package/utils/string.amd.js +1 -1
- package/utils/string.amd.js.map +1 -1
- package/utils/string.js +1 -1
- package/.chunks/formsExt-CdLb48ea.amd.js.map +0 -1
- package/.chunks/formsExt-CdLb48ea.esm.js.map +0 -1
- package/.chunks/popup--ITACA7I.amd.js +0 -2
- package/.chunks/popup--ITACA7I.amd.js.map +0 -1
- package/.chunks/popup--ITACA7I.esm.js.map +0 -1
- package/.chunks/popup-CAy1LTfy.amd.js +0 -2
- package/.chunks/popup-CAy1LTfy.amd.js.map +0 -1
- package/.chunks/popup-CAy1LTfy.esm.js.map +0 -1
- package/.chunks/worker-OsfdwnCi.amd.js +0 -2
- package/.chunks/worker-OsfdwnCi.amd.js.map +0 -1
- package/.chunks/worker-OsfdwnCi.esm.js.map +0 -1
package/utils/searchers.amd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define([`require`,`exports`,`../.chunks/app-
|
|
1
|
+
define([`require`,`exports`,`../.chunks/app-DyAn8Ury.amd`],function(e,t){"use strict";if(n===void 0)var n=window.Vue;Object.defineProperty(t,`__esModule`,{value:!0}),t.searchersNames=t.prepareVolumeType=t.getSearcherGIcon=t.getLangLabel=t.getDeviceGIcon=t.genVolumeLabel=void 0,t.searchersNames={0:`Yandex`,20:`Yandex.com`,21:`Yandex.com.tr`,1:`Google`,4:`YouTube`,5:`Bing`,7:`Seznam`,8:`AppStore`,9:`GooglePlay`,101:`VK`,102:`Facebook`,103:`Twitter`},t.getSearcherGIcon=e=>{let t=``;switch(typeof e==`string`&&(e=Number(e)),e){case 0:t=``;break;case 20:case 21:t=``;break;case 1:t=``;break;case 2:t=``;break;case 3:t=``;break;case 4:t=``;break;case 5:t=``;break;case 6:t=``;break;case 7:t=``;break;case 8:t=``;break;case 9:t=``;break;case null:t=``;break}return t},t.getDeviceGIcon=e=>{let t=``;switch(typeof e==`string`&&(e=Number(e)),e%10){case 0:t=``;break;case 1:t=``;break;case 2:t=``;break}return t},t.getLangLabel=(e,t)=>{switch(typeof e==`string`&&(e=Number(e)),e*1){case 1:case 4:case 5:case 6:case 8:case 9:return t}return``},t.genVolumeLabel=(e,t,n)=>{switch(t*1){case 0:switch(n*1){case 2:e=`"${e}"`;break;case 3:e=`"!${e}"`;break;case 5:e=`"[${e}]"`;break;case 6:e=`"[!${e}]"`;break}break;case 1:e=`[${e}]`;break}return e},t.prepareVolumeType=(e,t)=>{switch(t===null&&(t=6),e){case 1:t=3;break;case 2:t=2;break;case 5:t>1&&(t=1);break;default:[1,2,3,5,6].includes(t)||(t=3)}return t}});
|
|
2
2
|
//# sourceMappingURL=searchers.amd.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["utils/searchers.js","../../src/core/utils/searchers.ts"],"names":["vue","exports"],"mappings":"AAAA,OAAO,CAAC,UAAW,UAAW,8BAAiC,CAAE,SAAU,EAAS,EAAS,CACzF,aAAA,GAAAA,IAAA,OAAA,IAAAA,EAAA,OAAA,ICIS,OAAiB,eAAAC,EAAA,aAAA,CAAA,MAAA,GAAA,CAAA,CAC1B,EAAA,eAAA,EAAA,kBAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,eAAA,EAAA,eAAA,IAAA,GD0HA,EAAQ,eCxHP,CACD,EAAA,SACA,GAAA,aACA,GAAA,gBACA,EAAA,SACA,EAAA,UACA,EAAA,OACE,EAAA,SACA,EAAA,WACA,EAAA,aAO2B,IAAA,KAC5B,IAAO,WAIX,IAFI,UAGH,CDmGE,EAAQ,iBCnGL,GAAA,CACG,IAAA,EAAA,GAEP,OAAA,OAAA,GAAA,WAAA,EAAA,OAAA,EAAA,EAAA,EAAA,CACI,IAAA,GACA,EAAA,IACG,MAEP,IAAA,IACI,IAAA,IACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MDvBS,KAAK,KC0BT,EAAA,IAM2D,MAKlE,OAFI,GDwCD,EAAQ,eCrCL,GAAA,CACG,IAAA,EAAA,GAEP,OAAA,OAAA,GAAA,WAAA,EAAA,OAAA,EAAA,EAAA,EAAA,GAAA,CACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MDnCS,IAAK,GCsCT,EAAA,IAMmD,MAIpD,OAAA,GDcH,EAAQ,cCbL,EAAA,IAAA,CACA,OAAA,OAAA,GAAA,WAAA,EAAA,OAAA,EAAA,EAAA,EAAA,EAAA,CACA,IAAA,GACA,IAAA,GAEJ,IAAO,GD5CE,IAAK,GC+CT,IAAA,GAMsC,IAAoB,GAA0C,OAAA,EAGrG,MAAA,IDHH,EAAQ,gBCID,EAAa,EAArB,IAAA,CACC,OAAK,EAAA,EAAL,CACS,IAAU,GAElB,OAAA,EAAA,EAAA,CACI,IAAA,GACe,EAAA,IAAA,EAAA,GAEnB,MACI,IAAA,GACe,EAAA,KAAA,EAAA,GAEnB,MACI,IAAA,GACgB,EAAA,KAAA,EAAA,IAEpB,MDvDe,IAAK,GCyDtB,EAAA,MAAA,EAAA,IAEI,MAGJ,MDzDS,IAAK,GC4DT,EAAA,IAAA,EAAA,GAM+C,MAKhD,OAAA,GDxCH,EAAQ,mBCyCI,EAAA,IAAA,CAEb,OAAA,IAAA,OAAA,EAAA,GAAA,EAAA,CACI,IAAA,GACS,EAAA,EAEb,MACI,IAAA,GACgB,EAAa,EAEjC,MAEK,IAAA,GAAC,EAAA,IAAA,EAAA,GAAG,MAAG,QAAA,CAAG,EAAG,EAAuB,EDhE5B,ECmER,EDjEK,CAAC,SAAS,EAAE,GAAK,EAAI,GAE1B,OAAO,IAQb","sourcesContent":["define([\"require\", \"exports\", \"../.chunks/app-
|
|
1
|
+
{"version":3,"sources":["utils/searchers.js","../../src/core/utils/searchers.ts"],"names":["vue","exports"],"mappings":"AAAA,OAAO,CAAC,UAAW,UAAW,8BAAiC,CAAE,SAAU,EAAS,EAAS,CACzF,aAAA,GAAAA,IAAA,OAAA,IAAAA,EAAA,OAAA,ICIS,OAAiB,eAAAC,EAAA,aAAA,CAAA,MAAA,GAAA,CAAA,CAC1B,EAAA,eAAA,EAAA,kBAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,eAAA,EAAA,eAAA,IAAA,GD0HA,EAAQ,eCxHP,CACD,EAAA,SACA,GAAA,aACA,GAAA,gBACA,EAAA,SACA,EAAA,UACA,EAAA,OACE,EAAA,SACA,EAAA,WACA,EAAA,aAO2B,IAAA,KAC5B,IAAO,WAIX,IAFI,UAGH,CDmGE,EAAQ,iBCnGL,GAAA,CACG,IAAA,EAAA,GAEP,OAAA,OAAA,GAAA,WAAA,EAAA,OAAA,EAAA,EAAA,EAAA,CACI,IAAA,GACA,EAAA,IACG,MAEP,IAAA,IACI,IAAA,IACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MDvBS,KAAK,KC0BT,EAAA,IAM2D,MAKlE,OAFI,GDwCD,EAAQ,eCrCL,GAAA,CACG,IAAA,EAAA,GAEP,OAAA,OAAA,GAAA,WAAA,EAAA,OAAA,EAAA,EAAA,EAAA,GAAA,CACI,IAAA,GACG,EAAA,IAEP,MACI,IAAA,GACG,EAAA,IAEP,MDnCS,IAAK,GCsCT,EAAA,IAMmD,MAIpD,OAAA,GDcH,EAAQ,cCbL,EAAA,IAAA,CACA,OAAA,OAAA,GAAA,WAAA,EAAA,OAAA,EAAA,EAAA,EAAA,EAAA,CACA,IAAA,GACA,IAAA,GAEJ,IAAO,GD5CE,IAAK,GC+CT,IAAA,GAMsC,IAAoB,GAA0C,OAAA,EAGrG,MAAA,IDHH,EAAQ,gBCID,EAAa,EAArB,IAAA,CACC,OAAK,EAAA,EAAL,CACS,IAAU,GAElB,OAAA,EAAA,EAAA,CACI,IAAA,GACe,EAAA,IAAA,EAAA,GAEnB,MACI,IAAA,GACe,EAAA,KAAA,EAAA,GAEnB,MACI,IAAA,GACgB,EAAA,KAAA,EAAA,IAEpB,MDvDe,IAAK,GCyDtB,EAAA,MAAA,EAAA,IAEI,MAGJ,MDzDS,IAAK,GC4DT,EAAA,IAAA,EAAA,GAM+C,MAKhD,OAAA,GDxCH,EAAQ,mBCyCI,EAAA,IAAA,CAEb,OAAA,IAAA,OAAA,EAAA,GAAA,EAAA,CACI,IAAA,GACS,EAAA,EAEb,MACI,IAAA,GACgB,EAAa,EAEjC,MAEK,IAAA,GAAC,EAAA,IAAA,EAAA,GAAG,MAAG,QAAA,CAAG,EAAG,EAAuB,EDhE5B,ECmER,EDjEK,CAAC,SAAS,EAAE,GAAK,EAAI,GAE1B,OAAO,IAQb","sourcesContent":["define([\"require\", \"exports\", \"../.chunks/app-DyAn8Ury.esm.js\"], function (require, exports) {\n \"use strict\";\n Object.defineProperty(exports, \"__esModule\", { value: true });\n exports.searchersNames = exports.prepareVolumeType = exports.getSearcherGIcon = exports.getLangLabel = exports.getDeviceGIcon = exports.genVolumeLabel = void 0;\n //#region src/core/utils/searchers.ts\n var e = {\n 0: \"Yandex\",\n 20: \"Yandex.com\",\n 21: \"Yandex.com.tr\",\n 1: \"Google\",\n 4: \"YouTube\",\n 5: \"Bing\",\n 7: \"Seznam\",\n 8: \"AppStore\",\n 9: \"GooglePlay\",\n 101: \"VK\",\n 102: \"Facebook\",\n 103: \"Twitter\"\n }, t = (e) => {\n let t = \"\";\n switch (typeof e == \"string\" && (e = Number(e)), e) {\n case 0:\n t = \"\";\n break;\n case 20:\n case 21:\n t = \"\";\n break;\n case 1:\n t = \"\";\n break;\n case 2:\n t = \"\";\n break;\n case 3:\n t = \"\";\n break;\n case 4:\n t = \"\";\n break;\n case 5:\n t = \"\";\n break;\n case 6:\n t = \"\";\n break;\n case 7:\n t = \"\";\n break;\n case 8:\n t = \"\";\n break;\n case 9:\n t = \"\";\n break;\n case null:\n t = \"\";\n break;\n }\n return t;\n }, n = (e) => {\n let t = \"\";\n switch (typeof e == \"string\" && (e = Number(e)), e % 10) {\n case 0:\n t = \"\";\n break;\n case 1:\n t = \"\";\n break;\n case 2:\n t = \"\";\n break;\n }\n return t;\n }, r = (e, t) => {\n switch (typeof e == \"string\" && (e = Number(e)), e * 1) {\n case 1:\n case 4:\n case 5:\n case 6:\n case 8:\n case 9: return t;\n }\n return \"\";\n }, i = (e, t, n) => {\n switch (t * 1) {\n case 0:\n switch (n * 1) {\n case 2:\n e = `\"${e}\"`;\n break;\n case 3:\n e = `\"!${e}\"`;\n break;\n case 5:\n e = `\"[${e}]\"`;\n break;\n case 6:\n e = `\"[!${e}]\"`;\n break;\n }\n break;\n case 1:\n e = `[${e}]`;\n break;\n }\n return e;\n }, a = (e, t) => {\n switch (t === null && (t = 6), e) {\n case 1:\n t = 3;\n break;\n case 2:\n t = 2;\n break;\n case 5:\n t > 1 && (t = 1);\n break;\n default: [\n 1,\n 2,\n 3,\n 5,\n 6\n ].includes(t) || (t = 3);\n }\n return t;\n };\n exports.searchersNames = e;\n exports.getSearcherGIcon = t;\n exports.getDeviceGIcon = n;\n exports.getLangLabel = r;\n exports.genVolumeLabel = i;\n exports.prepareVolumeType = a;\n});\n//# sourceMappingURL=searchers.js.map\n","import { useI18nLang } from '@/core/app';\n\n/**\n * Вспомогательный класс для работы с разными Поисковиками\n */\nexport const searchersNames = {\n\t0: 'Yandex',\n\t20: 'Yandex.com',\n\t21: 'Yandex.com.tr',\n\t1: 'Google',\n\t4: 'YouTube',\n\t5: 'Bing',\n\t7: 'Seznam',\n\t8: 'AppStore',\n\t9: 'GooglePlay',\n\t101: 'VK',\n\t102: 'Facebook',\n\t103: 'Twitter',\n};\n\n/**\n * Получить иконку ПС\n * @param searcherKey - цифра или строка с цифрой обозначающая ПС. Если null вернется иконка с глобусом\n */\nexport const getSearcherGIcon = (searcherKey: number | string | undefined): string => {\n\tlet icon = '';\n\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\n\n\tswitch (searcherKey) {\n\t\tcase 0:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 20:\n\t\tcase 21:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 1:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 3:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 4:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 5:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 6:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 7:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 8:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 9:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase null:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t}\n\n\treturn icon;\n};\n\n/**\n * Получить иконку устройства (ПК, планшет, смартфон)\n */\nexport const getDeviceGIcon = (device: number | string): string => {\n\tlet icon = '';\n\n\tif (typeof device === 'string') device = Number(device);\n\n\tswitch (device % 10) {\n\t\tcase 0:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 1:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t}\n\n\treturn icon;\n};\n\n/**\n * Получить иконку языка\n */\nexport const getLangLabel = (searcherKey: number | string, lang: string) => {\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\n\n\tswitch (searcherKey * 1) {\n\t\tcase 1:\n\t\tcase 4:\n\t\tcase 5:\n\t\tcase 6:\n\t\tcase 8:\n\t\tcase 9:\n\t\t\treturn lang;\n\t}\n\n\treturn '';\n};\n\n/**\n * Сгенерировать заголовок типа частоты\n */\nexport const genVolumeLabel = (label: string, searcherKey: 0 | 1, volumeType: 1 | 2 | 3 | 5 | 6): string => {\n\tswitch (searcherKey * 1) {\n\t\t// Яндекс\n\t\tcase 0:\n\t\t\tswitch (volumeType * 1) {\n\t\t\t\tcase 2:\n\t\t\t\t\tlabel = `\"${label}\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 3:\n\t\t\t\t\tlabel = `\"!${label}\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 5:\n\t\t\t\t\tlabel = `\"[${label}]\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 6:\n\t\t\t\t\tlabel = `\"[!${label}]\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\tbreak;\n\t\t// Google\n\t\tcase 1:\n\t\t\tlabel = `[${label}]`;\n\n\t\t\tbreak;\n\t}\n\n\treturn label;\n};\n\n/**\n * Проверить значение частоты, вернуть правильное значение частоты\n */\nexport const prepareVolumeType = (searcherKey: number, volumeType: number): number => {\n\t// по умолчанию выбрана сама точная частота\n\tif (volumeType === null) volumeType = 6;\n\n\tswitch (searcherKey) {\n\t\tcase 1:\n\t\t\tvolumeType = 3;\n\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\tvolumeType = 2;\n\n\t\t\tbreak;\n\t\tcase 5:\n\t\t\tif (volumeType > 1) volumeType = 1;\n\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tif (![1, 2, 3, 5, 6].includes(volumeType)) volumeType = 3;\n\t}\n\n\treturn volumeType;\n};\n"]}
|
package/utils/searchers.js
CHANGED
package/utils/string.amd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define([`require`,`exports`,`../.chunks/forms-
|
|
1
|
+
define([`require`,`exports`,`../.chunks/forms-DByj6MWE.amd`,`./check.amd`],function(e,t,n,r){"use strict";if(i===void 0)var i=window.Vue;Object.defineProperty(t,`__esModule`,{value:!0}),t.toRoditPadej=t.toCapitalize=t.rusToLatin=t.numberWithWord=t.numberEnding=t.nl2br=t.isUrl=t.htmlspecialchars=t.highlightHtml=t.getRandomHash=t.genIntHash=t.genFlagLinkByCountryCode=t.extractIconAndContent=t.ellipsis=t.camelToSnakeCase=t.addLinkTags=t.addCommasWhite=t.REGEXP_START_SYMBOL_ICON=void 0;var a=RegExp(`^[^a-zа-я0-9_%#!?.:'"«»[\\](){} \\r\\n\\t<>&/+-]`,`i`),o=e=>{let t=e?.[0]?.match(a);return{icon:t?e[0]:null,content:t?e.substring(1):e}},s=e=>{e+=``;let t=0;if(!e.length)return t;for(let n=0;n<e.length;n++){let r=e.charCodeAt(n);t=(t<<5)-t+r,t&=t}return t<0&&(t*=-1),t},c=e=>/^\w+:\/\/([\w-]+\.)+[\w-]+(:\d+)?(\/|$)/.test(e),l=e=>{let t=e+``;t=t.replace(`-`,`–`);let n=t.split(`.`),r=n[0],i=n.length>1?`.`+n[1]:``;if(r.replace(/[+–]/,``).length<=4)return t;let a=/(\d+)(\d{3})/;for(;a.test(r);)r=r.replace(a,`$1 $2`);return r+i},u=e=>e===void 0?``:e.replace(/\r\n|\r|\n/g,`<br>`),d=e=>typeof e==`string`?e.trim()!==``&&!isNaN(Number(e)):!0;t.REGEXP_START_SYMBOL_ICON=a,t.extractIconAndContent=o,t.genIntHash=s,t.isUrl=c,t.addCommasWhite=l,t.nl2br=u,t.numberWithWord=(e,t=2,n=1e3,r=``)=>{if(d(e))e=Number(e);else return String(e);let i=10**t,a;return a=Math.abs(e)>n**3?Math.round(e/n**3*i)/i+` <small>G`+r+`</small>`:Math.abs(e)>n**2?Math.round(e/n**2*i)/i+` <small>M`+r+`</small>`:Math.abs(e)>n?Math.round(e/n*i)/i+` <small>K`+r+`</small>`:Math.round(e*i)/i+``,a=a.replace(/^(-?\d+)(\d{3})/,`$1 $2`),a},t.ellipsis=(e,t,n=1)=>{if(e==null)return``;if(e+=``,t==null||e.length<=t)return e;if(n===0)e=e.substr(e.length-t,t),e=`...`+e;else if(n===1){let n=e.substr(0,t/2),r=e.substr(e.length-t/2,Math.ceil(t/2));e=n+`...`+r}else n===2&&(e=e.substr(0,t),e+=`...`);return e},t.numberEnding=(e,t,r,i)=>{if((0,n.D)().value===`en`)return e===1?r:t;let a=e%100,o=e%10;return a>=5&&a<=20||o===0?t:o===1?r:o>=2&&o<=4?i:o>=5&&o<=9?t:i},t.toRoditPadej=e=>{if((0,n.D)().value!=`ru`||e==``)return e;let t=e.split(` `);return $.map(t,function(e,n){e+=`а`,e=e.replace(`оа`,`о`),e=e.replace(`аяа`,`ой`),e=e.replace(`шийа`,`шого`),e=e.replace(`ыйа`,`ого`),e=e.replace(`йа`,`я`),e=e.replace(`ьа`,`я`),e=e.replace(`яа`,`и`),e=e.replace(`оваа`,`овой`),e=e.replace(`аа`,`ы`),e=e.replace(`кия`,`кого`),e=e.replace(`каи`,`кой`),t[n]=e}),e=t.join(` `),e},t.rusToLatin=e=>{let t={а:`a`,б:`b`,в:`v`,г:`g`,д:`d`,е:`e`,ё:`e`,ж:`j`,з:`z`,и:`i`,й:`i`,к:`k`,л:`l`,м:`m`,н:`n`,о:`o`,п:`p`,р:`r`,с:`s`,т:`t`,у:`u`,ф:`f`,х:`h`,ц:`c`,ч:`ch`,ш:`sh`,щ:`shch`,ъ:``,ы:`y`,ь:``,э:`e`,ю:`u`,я:`ya`},n=e.split(` `);return $.map(n,function(e,r){let i=[];for(let n=0;n<e.length;++n)i.push(t[e[n]]||t[e[n].toLowerCase()]==null&&e[n]||t[e[n].toLowerCase()].replace(/^(.)/,function(e){return e.toUpperCase()}));n[r]=i.join(``)}),e=n.join(` `),e},t.htmlspecialchars=e=>(e=e.replace(/&/g,`&`).replace(/</g,`<`).replace(/>/g,`>`).replace(/"/g,`"`).replace(/'/g,`'`),e),t.highlightHtml=(e,t)=>{let n=null;switch(t.operator){case`CONTAINS`:case`REGEXP`:try{let e=t.values[0];t.operator!=`REGEXP`&&(e=e.replace(/([()\[\]])/g,`\\$1`)),n=RegExp(`(`+e+`)`,`gi`)}catch{return e}break}return e=e.replace(n,`<b class="found">$1</b>`),e},t.camelToSnakeCase=e=>e.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map(e=>e.toLowerCase()).join(`_`),t.genFlagLinkByCountryCode=e=>`/controller/file/?src=${`/cloud/common/flags/`+e.toUpperCase()+`.svg`}`,t.addLinkTags=e=>{let t=(0,r.getDomainRegexp)(),n=`(([\\/?\\w&=%+#;:-]*(\\.\\w+)?))*`,i=RegExp(`(^|[\\s>(),])([a-z0-9а-яё_.]+@${t}${n})`,`gui`);e=e.replace(i,`$1<a href="mailto:$2" target="_blank" rel="noopener">↑[$2]↓</a>`);let a=RegExp(`(^|[\\s>(),])(https?:\/\/)?(${t}${n})`,`gui`);return e=e.replace(a,`$1<a href="√$2$3" target="_blank" rel="nofollow noopener">$2$3</a>`),e=e.replaceAll(`√http`,`http`),e=e.replaceAll(`√`,`http://`),e=e.replaceAll(/(↑\[|]↓)/g,``),e},t.toCapitalize=e=>e.charAt(0).toUpperCase()+e.slice(1),t.getRandomHash=(e=20)=>{let t=``;for(let n=0;n<e;n++)t+=`AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890`[Math.floor(Math.random()*62)];return t}});
|
|
2
2
|
//# sourceMappingURL=string.amd.js.map
|
package/utils/string.amd.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["utils/string.js","../../src/core/utils/string.ts"],"names":["vue","exports","n","r","i","a","o","s","c","forms_3oS4Utyg_esm_js_1","t","check_js_1"],"mappings":"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","sourcesContent":["define([\"require\", \"exports\", \"../.chunks/forms-3oS4Utyg.esm.js\", \"./check.js\"], function (require, exports, forms_3oS4Utyg_esm_js_1, check_js_1) {\n \"use strict\";\n Object.defineProperty(exports, \"__esModule\", { value: true });\n exports.toRoditPadej = exports.toCapitalize = exports.rusToLatin = exports.numberWithWord = exports.numberEnding = exports.nl2br = exports.isUrl = exports.htmlspecialchars = exports.highlightHtml = exports.getRandomHash = exports.genIntHash = exports.genFlagLinkByCountryCode = exports.extractIconAndContent = exports.ellipsis = exports.camelToSnakeCase = exports.addLinkTags = exports.addCommasWhite = exports.REGEXP_START_SYMBOL_ICON = void 0;\n //#region src/core/utils/string.ts\n var n = /* @__PURE__ */ RegExp(\"^[^a-zа-я0-9_%#!?.:'\\\"«»[\\\\](){} \\\\r\\\\n\\\\t<>&/+-]\", \"i\"), r = (e) => {\n let t = e?.[0]?.match(n);\n return {\n icon: t ? e[0] : null,\n content: t ? e.substring(1) : e\n };\n }, i = (e) => {\n e += \"\";\n let t = 0;\n if (!e.length)\n return t;\n for (let n = 0; n < e.length; n++) {\n let r = e.charCodeAt(n);\n t = (t << 5) - t + r, t &= t;\n }\n return t < 0 && (t *= -1), t;\n }, a = (e) => /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(e), o = (e) => {\n let t = e + \"\";\n t = t.replace(\"-\", \"–\");\n let n = t.split(\".\"), r = n[0], i = n.length > 1 ? \".\" + n[1] : \"\";\n if (r.replace(/[+–]/, \"\").length <= 4)\n return t;\n let a = /(\\d+)(\\d{3})/;\n for (; a.test(r);)\n r = r.replace(a, \"$1 $2\");\n return r + i;\n }, s = (e) => e === void 0 ? \"\" : e.replace(/\\r\\n|\\r|\\n/g, \"<br>\"), c = (e) => typeof e == \"string\" ? e.trim() !== \"\" && !isNaN(Number(e)) : !0, l = (e, t = 2, n = 1e3, r = \"\") => {\n if (c(e))\n e = Number(e);\n else\n return String(e);\n let i = 10 ** t, a;\n return a = Math.abs(e) > n ** 3 ? Math.round(e / n ** 3 * i) / i + \" <small>G\" + r + \"</small>\" : Math.abs(e) > n ** 2 ? Math.round(e / n ** 2 * i) / i + \" <small>M\" + r + \"</small>\" : Math.abs(e) > n ? Math.round(e / n * i) / i + \" <small>K\" + r + \"</small>\" : Math.round(e * i) / i + \"\", a = a.replace(/^(-?\\d+)(\\d{3})/, \"$1 $2\"), a;\n }, u = (e, t, n = 1) => {\n if (e == null)\n return \"\";\n if (e += \"\", t == null || e.length <= t)\n return e;\n if (n === 0)\n e = e.substr(e.length - t, t), e = \"...\" + e;\n else if (n === 1) {\n let n = e.substr(0, t / 2), r = e.substr(e.length - t / 2, Math.ceil(t / 2));\n e = n + \"...\" + r;\n }\n else\n n === 2 && (e = e.substr(0, t), e += \"...\");\n return e;\n }, d = (t, n, r, i) => {\n if ((0, forms_3oS4Utyg_esm_js_1.D)().value === \"en\")\n return t === 1 ? r : n;\n let a = t % 100, o = t % 10;\n return a >= 5 && a <= 20 || o === 0 ? n : o === 1 ? r : o >= 2 && o <= 4 ? i : o >= 5 && o <= 9 ? n : i;\n }, f = (t) => {\n if ((0, forms_3oS4Utyg_esm_js_1.D)().value != \"ru\" || t == \"\")\n return t;\n let n = t.split(\" \");\n return $.map(n, function (e, t) {\n e += \"а\", e = e.replace(\"оа\", \"о\"), e = e.replace(\"аяа\", \"ой\"), e = e.replace(\"шийа\", \"шого\"), e = e.replace(\"ыйа\", \"ого\"), e = e.replace(\"йа\", \"я\"), e = e.replace(\"ьа\", \"я\"), e = e.replace(\"яа\", \"и\"), e = e.replace(\"оваа\", \"овой\"), e = e.replace(\"аа\", \"ы\"), e = e.replace(\"кия\", \"кого\"), e = e.replace(\"каи\", \"кой\"), n[t] = e;\n }), t = n.join(\" \"), t;\n }, p = (e) => {\n let t = {\n а: \"a\",\n б: \"b\",\n в: \"v\",\n г: \"g\",\n д: \"d\",\n е: \"e\",\n ё: \"e\",\n ж: \"j\",\n з: \"z\",\n и: \"i\",\n й: \"i\",\n к: \"k\",\n л: \"l\",\n м: \"m\",\n н: \"n\",\n о: \"o\",\n п: \"p\",\n р: \"r\",\n с: \"s\",\n т: \"t\",\n у: \"u\",\n ф: \"f\",\n х: \"h\",\n ц: \"c\",\n ч: \"ch\",\n ш: \"sh\",\n щ: \"shch\",\n ъ: \"\",\n ы: \"y\",\n ь: \"\",\n э: \"e\",\n ю: \"u\",\n я: \"ya\"\n }, n = e.split(\" \");\n return $.map(n, function (e, r) {\n let i = [];\n for (let n = 0; n < e.length; ++n)\n i.push(t[e[n]] || t[e[n].toLowerCase()] == null && e[n] || t[e[n].toLowerCase()].replace(/^(.)/, function (e) {\n return e.toUpperCase();\n }));\n n[r] = i.join(\"\");\n }), e = n.join(\" \"), e;\n }, m = (e) => (e = e.replace(/&/g, \"&\").replace(/</g, \"<\").replace(/>/g, \">\").replace(/\"/g, \""\").replace(/'/g, \"'\"), e), h = (e, t) => {\n let n = null;\n switch (t.operator) {\n case \"CONTAINS\":\n case \"REGEXP\":\n try {\n let e = t.values[0];\n t.operator != \"REGEXP\" && (e = e.replace(/([()\\[\\]])/g, \"\\\\$1\")), n = RegExp(\"(\" + e + \")\", \"gi\");\n }\n catch {\n return e;\n }\n break;\n }\n return e = e.replace(n, \"<b class=\\\"found\\\">$1</b>\"), e;\n }, g = (e) => e.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map((e) => e.toLowerCase()).join(\"_\"), _ = (e) => `/controller/file/?src=${\"/cloud/common/flags/\" + e.toUpperCase() + \".svg\"}`, v = (e) => {\n let n = (0, check_js_1.getDomainRegexp)(), r = \"(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*\", i = RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${n}${r})`, \"gui\");\n e = e.replace(i, \"$1<a href=\\\"mailto:$2\\\" target=\\\"_blank\\\" rel=\\\"noopener\\\">↑[$2]↓</a>\");\n let a = RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${n}${r})`, \"gui\");\n return e = e.replace(a, \"$1<a href=\\\"√$2$3\\\" target=\\\"_blank\\\" rel=\\\"nofollow noopener\\\">$2$3</a>\"), e = e.replaceAll(\"√http\", \"http\"), e = e.replaceAll(\"√\", \"http://\"), e = e.replaceAll(/(↑\\[|]↓)/g, \"\"), e;\n }, y = (e) => e.charAt(0).toUpperCase() + e.slice(1), b = (e = 20) => {\n let t = \"\";\n for (let n = 0; n < e; n++)\n t += \"AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890\"[Math.floor(Math.random() * 62)];\n return t;\n };\n exports.REGEXP_START_SYMBOL_ICON = n;\n exports.extractIconAndContent = r;\n exports.genIntHash = i;\n exports.isUrl = a;\n exports.addCommasWhite = o;\n exports.nl2br = s;\n exports.numberWithWord = l;\n exports.ellipsis = u;\n exports.numberEnding = d;\n exports.toRoditPadej = f;\n exports.rusToLatin = p;\n exports.htmlspecialchars = m;\n exports.highlightHtml = h;\n exports.camelToSnakeCase = g;\n exports.genFlagLinkByCountryCode = _;\n exports.addLinkTags = v;\n exports.toCapitalize = y;\n exports.getRandomHash = b;\n});\n//# sourceMappingURL=string.js.map\n","/**\n * Работа со строками\n * @packageDocumentation\n */\n\nimport { getDomainRegexp } from '@/core/utils/check';\nimport { useI18nLang } from '@/core/plugins/i18n';\n\nexport const REGEXP_START_SYMBOL_ICON = new RegExp('^[^a-zа-я0-9_%#!?.:\\'\"«»[\\\\](){} \\\\r\\\\n\\\\t<>&/+-]', 'i');\n\n/**\n * Извлекает иконку и оставшийся контент из строки\n *\n * Возвращает объект со свойствами:\n * - `icon`: содержит символ иконки, если он присутствует, иначе `null`\n * - `content`: содержит оставшийся текст без символа иконки, если он был извлечен, или всю строку\n */\nexport const extractIconAndContent = (content: string) => {\n\tconst iconExists = content?.[0]?.match(REGEXP_START_SYMBOL_ICON);\n\n\treturn {\n\t\ticon: iconExists ? content[0] : null,\n\t\tcontent: iconExists ? content.substring(1) : content,\n\t};\n};\n\n/**\n * Сгенерировать числовой хэш от строки для идентификатора\n */\nexport const genIntHash = (string: string): number => {\n\tstring += '';\n\n\tlet hash = 0;\n\tif (!string.length) return hash;\n\n\tfor (let i = 0; i < string.length; i++) {\n\t\tconst char = string.charCodeAt(i);\n\t\thash = ((hash << 5) - hash) + char;\n\t\thash = hash & hash;\n\t}\n\n\tif (hash < 0) hash *= -1;\n\n\treturn hash;\n};\n\n/**\n * Проверить, что переданная строка является URL\n */\nexport const isUrl = (url: string): boolean => {\n\treturn /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(url);\n};\n\n/**\n * Добавляет пробелы между разрядами если требуется\n * @param nStr строка с числом\n */\nexport const addCommasWhite = (n: number | string): string => {\n\tlet nStr = n + '';\n\n\tnStr = nStr.replace('-', '–');\n\n\tlet x = nStr.split('.');\n\tlet x1 = x[0];\n\tlet x2 = (x.length > 1) ? ('.' + x[1]) : '';\n\n\tif (x1.replace(/[+–]/, '').length <= 4) return nStr;\n\n\tconst rgx = /(\\d+)(\\d{3})/;\n\twhile (rgx.test(x1)) {\n\t\tx1 = x1.replace(rgx, '$1' + ' ' + '$2');\n\t}\n\treturn x1 + x2;\n};\n\n/**\n * Вставляет HTML-код разрыва строки перед каждым переводом строки\n */\nexport const nl2br = (str: string): string => {\n\tif (str === undefined) return '';\n\n\treturn str.replace(/\\r\\n|\\r|\\n/g, '<br>');\n};\n/**\n * Проверяет, является ли строка числом (целым или с плавающей точкой)\n */\nconst isNumeric = (string: number | string): boolean => {\n\tif (typeof string === 'string') {\n\t\treturn string.trim() !== '' && !isNaN(Number(string));\n\t}\n\n\treturn true;\n};\n\n/**\n * Перевести число без деситичной приставки в число с деситичной приставкой степеней тысячи (с параметрами по умолчанию 1255 -> '1.26 K')\n * @param number\n * @param precision - точность, количество знаков после запятой\n * @param dimension - размерность, по умолчанию 1000\n * @param suffix - суффикс к десятичной приставке (по умолчанию выводится латинская заглавная буква)\n */\nexport const numberWithWord = (number: number | string, precision = 2, dimension = 1000, suffix = ''): string => {\n\tif (!isNumeric(number)) {\n\t\treturn String(number);\n\t} else {\n\t\tnumber = Number(number);\n\t}\n\n\tconst k = Math.pow(10, precision);\n\n\tlet numberStr: string;\n\tif (Math.abs(number) > Math.pow(dimension, 3)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 3) * k) / k + ' <small>G' + suffix + '</small>';\n\t} else if (Math.abs(number) > Math.pow(dimension, 2)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 2) * k) / k + ' <small>M' + suffix + '</small>';\n\t} else if (Math.abs(number) > dimension) {\n\t\tnumberStr = Math.round(number / dimension * k) / k + ' <small>K' + suffix + '</small>';\n\t} else {\n\t\tnumberStr = Math.round(number * k) / k + '';\n\t}\n\n\tnumberStr = numberStr.replace(/^(-?\\d+)(\\d{3})/, '$1 $2');\n\n\treturn numberStr;\n};\n\n/**\n * Обрезать текст под три точки\n * @param string\n * @param max_length - максимальное количество символов текста, остальное обрежеться\n * @param pos - область обрезки 0-начало | 1-середина | 2-конец строки\n */\nexport const ellipsis = (string: string, max_length: number, pos: 0 | 1 | 2 = 1): string => {\n\tif (string == undefined) return '';\n\n\tstring += '';\n\tif (max_length == undefined || string.length <= max_length) return string;\n\n\tif (pos === 0) {\n\t\tstring = string.substr(string.length - max_length, max_length);\n\t\tstring = '...' + string;\n\t} else if (pos === 1) {\n\t\tconst string1 = string.substr(0, max_length / 2);\n\t\tconst string2 = string.substr(string.length - max_length / 2, Math.ceil(max_length / 2));\n\t\tstring = string1 + '...' + string2;\n\t} else if (pos === 2) {\n\t\tstring = string.substr(0, max_length);\n\t\tstring = string + '...';\n\t}\n\n\treturn string;\n};\n\n/**\n * Сгенерировать строку текста для вывода количества в разном склонении\n * @param num\n * @param ending0 - родительный падеж, множ. число (10 модулей)\n * @param ending1 - именительный падеж, ед. число (1 модуль)\n * @param ending2 - винительный падеж, множ. число (3 модуля)\n */\nexport const numberEnding = (num: number, ending0: string, ending1: string, ending2: string): string => {\n\t// склонение по множественному числу\n\tif (useI18nLang().value === 'en') {\n\t\tif (num === 1) {\n\t\t\treturn ending1;\n\t\t} else {\n\t\t\treturn ending0;\n\t\t}\n\t}\n\n\tconst num100 = num % 100;\n\tconst num10 = num % 10;\n\n\tif (num100 >= 5 && num100 <= 20) {\n\t\treturn ending0;\n\t} else if (num10 === 0) {\n\t\treturn ending0;\n\t} else if (num10 === 1) {\n\t\treturn ending1;\n\t} else if (num10 >= 2 && num10 <= 4) {\n\t\treturn ending2;\n\t} else if (num10 >= 5 && num10 <= 9) {\n\t\treturn ending0;\n\t} else {\n\t\treturn ending2;\n\t}\n};\n\n/**\n * Перевести строку в родительный падеж\n */\nexport const toRoditPadej = (str: string): string => {\n\tif (useI18nLang().value != 'ru' || str == '') return str;\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tstr = str + 'а';\n\t\tstr = str.replace('оа', 'о');\n\t\tstr = str.replace('аяа', 'ой');\n\t\tstr = str.replace('шийа', 'шого');\n\t\tstr = str.replace('ыйа', 'ого');\n\t\tstr = str.replace('йа', 'я');\n\t\tstr = str.replace('ьа', 'я');\n\t\tstr = str.replace('яа', 'и');\n\t\tstr = str.replace('оваа', 'овой');\n\t\tstr = str.replace('аа', 'ы');\n\t\tstr = str.replace('кия', 'кого');\n\t\tstr = str.replace('каи', 'кой');\n\n\t\tstr_array[index] = str;\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Транслитерация текста\n */\nexport const rusToLatin = (str: string): string => {\n\tconst ru: { [index: string]: string } = {\n\t\t'а': 'a', 'б': 'b', 'в': 'v', 'г': 'g', 'д': 'd',\n\t\t'е': 'e', 'ё': 'e', 'ж': 'j', 'з': 'z', 'и': 'i',\n\t\t'й': 'i', 'к': 'k', 'л': 'l', 'м': 'm', 'н': 'n',\n\t\t'о': 'o', 'п': 'p', 'р': 'r', 'с': 's', 'т': 't',\n\t\t'у': 'u', 'ф': 'f', 'х': 'h', 'ц': 'c', 'ч': 'ch',\n\t\t'ш': 'sh', 'щ': 'shch', 'ъ': '', 'ы': 'y', 'ь': '',\n\t\t'э': 'e', 'ю': 'u', 'я': 'ya',\n\t};\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tconst newStr: string[] = [];\n\t\tfor (let i = 0; i < str.length; ++i) {\n\t\t\tnewStr.push(\n\t\t\t\tru[str[i]] || ru[str[i].toLowerCase()] == undefined && str[i] || ru[str[i].toLowerCase()].replace(/^(.)/, function (match) {\n\t\t\t\t\treturn match.toUpperCase();\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\tstr_array[index] = newStr.join('');\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Замена html-символов (`&`, `<`, `>`, `\"`, `'`) на имена литер (`&` -> `&`)\n */\nexport const htmlspecialchars = (str: string): string => {\n\tstr = str\n\t\t.replace(/&/g, '&')\n\t\t.replace(/</g, '<')\n\t\t.replace(/>/g, '>')\n\t\t.replace(/\"/g, '"')\n\t\t.replace(/'/g, ''');\n\n\treturn str;\n};\n\n/**\n * Выделить нужное в тексте желтым цветом\n * поиск происходит по строке fieldFilter.values[0]\n */\nexport const highlightHtml = (text: string, fieldFilter: { operator: 'CONTAINS' | 'REGEXP', values: string[] }): string => {\n\tlet regExp: RegExp | null = null;\n\n\tswitch (fieldFilter.operator) {\n\t\tcase 'CONTAINS':\n\t\tcase 'REGEXP':\n\t\t\ttry {\n\t\t\t\tlet regExpString = fieldFilter.values[0];\n\t\t\t\tif (fieldFilter.operator != 'REGEXP') regExpString = regExpString.replace(/([()\\[\\]])/g, '\\\\$1');\n\n\t\t\t\tregExp = new RegExp('(' + regExpString + ')', 'gi');\n\t\t\t} catch (exception) {\n\t\t\t\treturn text;\n\t\t\t}\n\n\t\t\tbreak;\n\t}\n\n\ttext = text.replace(regExp!, '<b class=\"found\">$1</b>');\n\n\treturn text;\n};\n\n/**\n * Пример: logHTTPCodesHundreds => log_http_codes_hundreds\n */\nexport const camelToSnakeCase = (str: string): string | undefined => {\n\treturn str.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map(token => token.toLowerCase()).join('_');\n};\n\n/**\n * Получить url изображения флага, по коду страны по стандарту ISO 3166-1 alpha-2\n *\n * @todo Опубликовать в CDN или брать c публичного CDN\n */\nexport const genFlagLinkByCountryCode = (countryCode: string) => {\n\tconst urlImage = '/cloud/common/flags/' + countryCode.toUpperCase() + '.svg';\n\treturn `/controller/file/?src=${urlImage}`;\n};\n\n/**\n * Обернуть все ссылки и email в тексте в html-тег `<a>`.\n *\n * Для email ставиться префикс `mailto:`\n */\nexport const addLinkTags = (text: string): string => {\n\tconst domainRegexp = getDomainRegexp();\n\tconst afterDomainRegexp = '(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*';\n\n\tconst regexpMailto = new RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpMailto, `$1<a href=\"mailto:$2\" target=\"_blank\" rel=\"noopener\">↑[$2]↓</a>`);\n\n\tconst regexpLink = new RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpLink, `$1<a href=\"√$2$3\" target=\"_blank\" rel=\"nofollow noopener\">$2$3</a>`);\n\n\ttext = text.replaceAll('√http', 'http');\n\ttext = text.replaceAll('√', 'http://');\n\ttext = text.replaceAll(/(↑\\[|]↓)/g, '');\n\n\treturn text;\n};\n\n/**\n * Перевести первую букву строки в верхний регистр\n */\nexport const toCapitalize = (str: string): string => {\n\treturn str.charAt(0).toUpperCase() + str.slice(1);\n};\n\n/**\n * Получить случайную строку\n */\nexport const getRandomHash = (length: number = 20): string => {\n\tconst l = 'AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890';\n\n\tlet result = '';\n\tfor (let i = 0; i < length; i++) {\n\t\tresult += l[Math.floor(Math.random() * l.length)];\n\t}\n\n\treturn result;\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["utils/string.js","../../src/core/utils/string.ts"],"names":["vue","exports","n","r","i","a","o","s","c","forms_DByj6MWE_esm_js_1","t","check_js_1"],"mappings":"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","sourcesContent":["define([\"require\", \"exports\", \"../.chunks/forms-DByj6MWE.esm.js\", \"./check.js\"], function (require, exports, forms_DByj6MWE_esm_js_1, check_js_1) {\n \"use strict\";\n Object.defineProperty(exports, \"__esModule\", { value: true });\n exports.toRoditPadej = exports.toCapitalize = exports.rusToLatin = exports.numberWithWord = exports.numberEnding = exports.nl2br = exports.isUrl = exports.htmlspecialchars = exports.highlightHtml = exports.getRandomHash = exports.genIntHash = exports.genFlagLinkByCountryCode = exports.extractIconAndContent = exports.ellipsis = exports.camelToSnakeCase = exports.addLinkTags = exports.addCommasWhite = exports.REGEXP_START_SYMBOL_ICON = void 0;\n //#region src/core/utils/string.ts\n var n = /* @__PURE__ */ RegExp(\"^[^a-zа-я0-9_%#!?.:'\\\"«»[\\\\](){} \\\\r\\\\n\\\\t<>&/+-]\", \"i\"), r = (e) => {\n let t = e?.[0]?.match(n);\n return {\n icon: t ? e[0] : null,\n content: t ? e.substring(1) : e\n };\n }, i = (e) => {\n e += \"\";\n let t = 0;\n if (!e.length)\n return t;\n for (let n = 0; n < e.length; n++) {\n let r = e.charCodeAt(n);\n t = (t << 5) - t + r, t &= t;\n }\n return t < 0 && (t *= -1), t;\n }, a = (e) => /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(e), o = (e) => {\n let t = e + \"\";\n t = t.replace(\"-\", \"–\");\n let n = t.split(\".\"), r = n[0], i = n.length > 1 ? \".\" + n[1] : \"\";\n if (r.replace(/[+–]/, \"\").length <= 4)\n return t;\n let a = /(\\d+)(\\d{3})/;\n for (; a.test(r);)\n r = r.replace(a, \"$1 $2\");\n return r + i;\n }, s = (e) => e === void 0 ? \"\" : e.replace(/\\r\\n|\\r|\\n/g, \"<br>\"), c = (e) => typeof e == \"string\" ? e.trim() !== \"\" && !isNaN(Number(e)) : !0, l = (e, t = 2, n = 1e3, r = \"\") => {\n if (c(e))\n e = Number(e);\n else\n return String(e);\n let i = 10 ** t, a;\n return a = Math.abs(e) > n ** 3 ? Math.round(e / n ** 3 * i) / i + \" <small>G\" + r + \"</small>\" : Math.abs(e) > n ** 2 ? Math.round(e / n ** 2 * i) / i + \" <small>M\" + r + \"</small>\" : Math.abs(e) > n ? Math.round(e / n * i) / i + \" <small>K\" + r + \"</small>\" : Math.round(e * i) / i + \"\", a = a.replace(/^(-?\\d+)(\\d{3})/, \"$1 $2\"), a;\n }, u = (e, t, n = 1) => {\n if (e == null)\n return \"\";\n if (e += \"\", t == null || e.length <= t)\n return e;\n if (n === 0)\n e = e.substr(e.length - t, t), e = \"...\" + e;\n else if (n === 1) {\n let n = e.substr(0, t / 2), r = e.substr(e.length - t / 2, Math.ceil(t / 2));\n e = n + \"...\" + r;\n }\n else\n n === 2 && (e = e.substr(0, t), e += \"...\");\n return e;\n }, d = (t, n, r, i) => {\n if ((0, forms_DByj6MWE_esm_js_1.D)().value === \"en\")\n return t === 1 ? r : n;\n let a = t % 100, o = t % 10;\n return a >= 5 && a <= 20 || o === 0 ? n : o === 1 ? r : o >= 2 && o <= 4 ? i : o >= 5 && o <= 9 ? n : i;\n }, f = (t) => {\n if ((0, forms_DByj6MWE_esm_js_1.D)().value != \"ru\" || t == \"\")\n return t;\n let n = t.split(\" \");\n return $.map(n, function (e, t) {\n e += \"а\", e = e.replace(\"оа\", \"о\"), e = e.replace(\"аяа\", \"ой\"), e = e.replace(\"шийа\", \"шого\"), e = e.replace(\"ыйа\", \"ого\"), e = e.replace(\"йа\", \"я\"), e = e.replace(\"ьа\", \"я\"), e = e.replace(\"яа\", \"и\"), e = e.replace(\"оваа\", \"овой\"), e = e.replace(\"аа\", \"ы\"), e = e.replace(\"кия\", \"кого\"), e = e.replace(\"каи\", \"кой\"), n[t] = e;\n }), t = n.join(\" \"), t;\n }, p = (e) => {\n let t = {\n а: \"a\",\n б: \"b\",\n в: \"v\",\n г: \"g\",\n д: \"d\",\n е: \"e\",\n ё: \"e\",\n ж: \"j\",\n з: \"z\",\n и: \"i\",\n й: \"i\",\n к: \"k\",\n л: \"l\",\n м: \"m\",\n н: \"n\",\n о: \"o\",\n п: \"p\",\n р: \"r\",\n с: \"s\",\n т: \"t\",\n у: \"u\",\n ф: \"f\",\n х: \"h\",\n ц: \"c\",\n ч: \"ch\",\n ш: \"sh\",\n щ: \"shch\",\n ъ: \"\",\n ы: \"y\",\n ь: \"\",\n э: \"e\",\n ю: \"u\",\n я: \"ya\"\n }, n = e.split(\" \");\n return $.map(n, function (e, r) {\n let i = [];\n for (let n = 0; n < e.length; ++n)\n i.push(t[e[n]] || t[e[n].toLowerCase()] == null && e[n] || t[e[n].toLowerCase()].replace(/^(.)/, function (e) {\n return e.toUpperCase();\n }));\n n[r] = i.join(\"\");\n }), e = n.join(\" \"), e;\n }, m = (e) => (e = e.replace(/&/g, \"&\").replace(/</g, \"<\").replace(/>/g, \">\").replace(/\"/g, \""\").replace(/'/g, \"'\"), e), h = (e, t) => {\n let n = null;\n switch (t.operator) {\n case \"CONTAINS\":\n case \"REGEXP\":\n try {\n let e = t.values[0];\n t.operator != \"REGEXP\" && (e = e.replace(/([()\\[\\]])/g, \"\\\\$1\")), n = RegExp(\"(\" + e + \")\", \"gi\");\n }\n catch {\n return e;\n }\n break;\n }\n return e = e.replace(n, \"<b class=\\\"found\\\">$1</b>\"), e;\n }, g = (e) => e.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map((e) => e.toLowerCase()).join(\"_\"), _ = (e) => `/controller/file/?src=${\"/cloud/common/flags/\" + e.toUpperCase() + \".svg\"}`, v = (e) => {\n let n = (0, check_js_1.getDomainRegexp)(), r = \"(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*\", i = RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${n}${r})`, \"gui\");\n e = e.replace(i, \"$1<a href=\\\"mailto:$2\\\" target=\\\"_blank\\\" rel=\\\"noopener\\\">↑[$2]↓</a>\");\n let a = RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${n}${r})`, \"gui\");\n return e = e.replace(a, \"$1<a href=\\\"√$2$3\\\" target=\\\"_blank\\\" rel=\\\"nofollow noopener\\\">$2$3</a>\"), e = e.replaceAll(\"√http\", \"http\"), e = e.replaceAll(\"√\", \"http://\"), e = e.replaceAll(/(↑\\[|]↓)/g, \"\"), e;\n }, y = (e) => e.charAt(0).toUpperCase() + e.slice(1), b = (e = 20) => {\n let t = \"\";\n for (let n = 0; n < e; n++)\n t += \"AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890\"[Math.floor(Math.random() * 62)];\n return t;\n };\n exports.REGEXP_START_SYMBOL_ICON = n;\n exports.extractIconAndContent = r;\n exports.genIntHash = i;\n exports.isUrl = a;\n exports.addCommasWhite = o;\n exports.nl2br = s;\n exports.numberWithWord = l;\n exports.ellipsis = u;\n exports.numberEnding = d;\n exports.toRoditPadej = f;\n exports.rusToLatin = p;\n exports.htmlspecialchars = m;\n exports.highlightHtml = h;\n exports.camelToSnakeCase = g;\n exports.genFlagLinkByCountryCode = _;\n exports.addLinkTags = v;\n exports.toCapitalize = y;\n exports.getRandomHash = b;\n});\n//# sourceMappingURL=string.js.map\n","/**\n * Работа со строками\n * @packageDocumentation\n */\n\nimport { getDomainRegexp } from '@/core/utils/check';\nimport { useI18nLang } from '@/core/plugins/i18n';\n\nexport const REGEXP_START_SYMBOL_ICON = new RegExp('^[^a-zа-я0-9_%#!?.:\\'\"«»[\\\\](){} \\\\r\\\\n\\\\t<>&/+-]', 'i');\n\n/**\n * Извлекает иконку и оставшийся контент из строки\n *\n * Возвращает объект со свойствами:\n * - `icon`: содержит символ иконки, если он присутствует, иначе `null`\n * - `content`: содержит оставшийся текст без символа иконки, если он был извлечен, или всю строку\n */\nexport const extractIconAndContent = (content: string) => {\n\tconst iconExists = content?.[0]?.match(REGEXP_START_SYMBOL_ICON);\n\n\treturn {\n\t\ticon: iconExists ? content[0] : null,\n\t\tcontent: iconExists ? content.substring(1) : content,\n\t};\n};\n\n/**\n * Сгенерировать числовой хэш от строки для идентификатора\n */\nexport const genIntHash = (string: string): number => {\n\tstring += '';\n\n\tlet hash = 0;\n\tif (!string.length) return hash;\n\n\tfor (let i = 0; i < string.length; i++) {\n\t\tconst char = string.charCodeAt(i);\n\t\thash = ((hash << 5) - hash) + char;\n\t\thash = hash & hash;\n\t}\n\n\tif (hash < 0) hash *= -1;\n\n\treturn hash;\n};\n\n/**\n * Проверить, что переданная строка является URL\n */\nexport const isUrl = (url: string): boolean => {\n\treturn /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(url);\n};\n\n/**\n * Добавляет пробелы между разрядами если требуется\n * @param nStr строка с числом\n */\nexport const addCommasWhite = (n: number | string): string => {\n\tlet nStr = n + '';\n\n\tnStr = nStr.replace('-', '–');\n\n\tlet x = nStr.split('.');\n\tlet x1 = x[0];\n\tlet x2 = (x.length > 1) ? ('.' + x[1]) : '';\n\n\tif (x1.replace(/[+–]/, '').length <= 4) return nStr;\n\n\tconst rgx = /(\\d+)(\\d{3})/;\n\twhile (rgx.test(x1)) {\n\t\tx1 = x1.replace(rgx, '$1' + ' ' + '$2');\n\t}\n\treturn x1 + x2;\n};\n\n/**\n * Вставляет HTML-код разрыва строки перед каждым переводом строки\n */\nexport const nl2br = (str: string): string => {\n\tif (str === undefined) return '';\n\n\treturn str.replace(/\\r\\n|\\r|\\n/g, '<br>');\n};\n/**\n * Проверяет, является ли строка числом (целым или с плавающей точкой)\n */\nconst isNumeric = (string: number | string): boolean => {\n\tif (typeof string === 'string') {\n\t\treturn string.trim() !== '' && !isNaN(Number(string));\n\t}\n\n\treturn true;\n};\n\n/**\n * Перевести число без деситичной приставки в число с деситичной приставкой степеней тысячи (с параметрами по умолчанию 1255 -> '1.26 K')\n * @param number\n * @param precision - точность, количество знаков после запятой\n * @param dimension - размерность, по умолчанию 1000\n * @param suffix - суффикс к десятичной приставке (по умолчанию выводится латинская заглавная буква)\n */\nexport const numberWithWord = (number: number | string, precision = 2, dimension = 1000, suffix = ''): string => {\n\tif (!isNumeric(number)) {\n\t\treturn String(number);\n\t} else {\n\t\tnumber = Number(number);\n\t}\n\n\tconst k = Math.pow(10, precision);\n\n\tlet numberStr: string;\n\tif (Math.abs(number) > Math.pow(dimension, 3)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 3) * k) / k + ' <small>G' + suffix + '</small>';\n\t} else if (Math.abs(number) > Math.pow(dimension, 2)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 2) * k) / k + ' <small>M' + suffix + '</small>';\n\t} else if (Math.abs(number) > dimension) {\n\t\tnumberStr = Math.round(number / dimension * k) / k + ' <small>K' + suffix + '</small>';\n\t} else {\n\t\tnumberStr = Math.round(number * k) / k + '';\n\t}\n\n\tnumberStr = numberStr.replace(/^(-?\\d+)(\\d{3})/, '$1 $2');\n\n\treturn numberStr;\n};\n\n/**\n * Обрезать текст под три точки\n * @param string\n * @param max_length - максимальное количество символов текста, остальное обрежеться\n * @param pos - область обрезки 0-начало | 1-середина | 2-конец строки\n */\nexport const ellipsis = (string: string, max_length: number, pos: 0 | 1 | 2 = 1): string => {\n\tif (string == undefined) return '';\n\n\tstring += '';\n\tif (max_length == undefined || string.length <= max_length) return string;\n\n\tif (pos === 0) {\n\t\tstring = string.substr(string.length - max_length, max_length);\n\t\tstring = '...' + string;\n\t} else if (pos === 1) {\n\t\tconst string1 = string.substr(0, max_length / 2);\n\t\tconst string2 = string.substr(string.length - max_length / 2, Math.ceil(max_length / 2));\n\t\tstring = string1 + '...' + string2;\n\t} else if (pos === 2) {\n\t\tstring = string.substr(0, max_length);\n\t\tstring = string + '...';\n\t}\n\n\treturn string;\n};\n\n/**\n * Сгенерировать строку текста для вывода количества в разном склонении\n * @param num\n * @param ending0 - родительный падеж, множ. число (10 модулей)\n * @param ending1 - именительный падеж, ед. число (1 модуль)\n * @param ending2 - винительный падеж, множ. число (3 модуля)\n */\nexport const numberEnding = (num: number, ending0: string, ending1: string, ending2: string): string => {\n\t// склонение по множественному числу\n\tif (useI18nLang().value === 'en') {\n\t\tif (num === 1) {\n\t\t\treturn ending1;\n\t\t} else {\n\t\t\treturn ending0;\n\t\t}\n\t}\n\n\tconst num100 = num % 100;\n\tconst num10 = num % 10;\n\n\tif (num100 >= 5 && num100 <= 20) {\n\t\treturn ending0;\n\t} else if (num10 === 0) {\n\t\treturn ending0;\n\t} else if (num10 === 1) {\n\t\treturn ending1;\n\t} else if (num10 >= 2 && num10 <= 4) {\n\t\treturn ending2;\n\t} else if (num10 >= 5 && num10 <= 9) {\n\t\treturn ending0;\n\t} else {\n\t\treturn ending2;\n\t}\n};\n\n/**\n * Перевести строку в родительный падеж\n */\nexport const toRoditPadej = (str: string): string => {\n\tif (useI18nLang().value != 'ru' || str == '') return str;\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tstr = str + 'а';\n\t\tstr = str.replace('оа', 'о');\n\t\tstr = str.replace('аяа', 'ой');\n\t\tstr = str.replace('шийа', 'шого');\n\t\tstr = str.replace('ыйа', 'ого');\n\t\tstr = str.replace('йа', 'я');\n\t\tstr = str.replace('ьа', 'я');\n\t\tstr = str.replace('яа', 'и');\n\t\tstr = str.replace('оваа', 'овой');\n\t\tstr = str.replace('аа', 'ы');\n\t\tstr = str.replace('кия', 'кого');\n\t\tstr = str.replace('каи', 'кой');\n\n\t\tstr_array[index] = str;\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Транслитерация текста\n */\nexport const rusToLatin = (str: string): string => {\n\tconst ru: { [index: string]: string } = {\n\t\t'а': 'a', 'б': 'b', 'в': 'v', 'г': 'g', 'д': 'd',\n\t\t'е': 'e', 'ё': 'e', 'ж': 'j', 'з': 'z', 'и': 'i',\n\t\t'й': 'i', 'к': 'k', 'л': 'l', 'м': 'm', 'н': 'n',\n\t\t'о': 'o', 'п': 'p', 'р': 'r', 'с': 's', 'т': 't',\n\t\t'у': 'u', 'ф': 'f', 'х': 'h', 'ц': 'c', 'ч': 'ch',\n\t\t'ш': 'sh', 'щ': 'shch', 'ъ': '', 'ы': 'y', 'ь': '',\n\t\t'э': 'e', 'ю': 'u', 'я': 'ya',\n\t};\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tconst newStr: string[] = [];\n\t\tfor (let i = 0; i < str.length; ++i) {\n\t\t\tnewStr.push(\n\t\t\t\tru[str[i]] || ru[str[i].toLowerCase()] == undefined && str[i] || ru[str[i].toLowerCase()].replace(/^(.)/, function (match) {\n\t\t\t\t\treturn match.toUpperCase();\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\tstr_array[index] = newStr.join('');\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Замена html-символов (`&`, `<`, `>`, `\"`, `'`) на имена литер (`&` -> `&`)\n */\nexport const htmlspecialchars = (str: string): string => {\n\tstr = str\n\t\t.replace(/&/g, '&')\n\t\t.replace(/</g, '<')\n\t\t.replace(/>/g, '>')\n\t\t.replace(/\"/g, '"')\n\t\t.replace(/'/g, ''');\n\n\treturn str;\n};\n\n/**\n * Выделить нужное в тексте желтым цветом\n * поиск происходит по строке fieldFilter.values[0]\n */\nexport const highlightHtml = (text: string, fieldFilter: { operator: 'CONTAINS' | 'REGEXP', values: string[] }): string => {\n\tlet regExp: RegExp | null = null;\n\n\tswitch (fieldFilter.operator) {\n\t\tcase 'CONTAINS':\n\t\tcase 'REGEXP':\n\t\t\ttry {\n\t\t\t\tlet regExpString = fieldFilter.values[0];\n\t\t\t\tif (fieldFilter.operator != 'REGEXP') regExpString = regExpString.replace(/([()\\[\\]])/g, '\\\\$1');\n\n\t\t\t\tregExp = new RegExp('(' + regExpString + ')', 'gi');\n\t\t\t} catch (exception) {\n\t\t\t\treturn text;\n\t\t\t}\n\n\t\t\tbreak;\n\t}\n\n\ttext = text.replace(regExp!, '<b class=\"found\">$1</b>');\n\n\treturn text;\n};\n\n/**\n * Пример: logHTTPCodesHundreds => log_http_codes_hundreds\n */\nexport const camelToSnakeCase = (str: string): string | undefined => {\n\treturn str.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map(token => token.toLowerCase()).join('_');\n};\n\n/**\n * Получить url изображения флага, по коду страны по стандарту ISO 3166-1 alpha-2\n *\n * @todo Опубликовать в CDN или брать c публичного CDN\n */\nexport const genFlagLinkByCountryCode = (countryCode: string) => {\n\tconst urlImage = '/cloud/common/flags/' + countryCode.toUpperCase() + '.svg';\n\treturn `/controller/file/?src=${urlImage}`;\n};\n\n/**\n * Обернуть все ссылки и email в тексте в html-тег `<a>`.\n *\n * Для email ставиться префикс `mailto:`\n */\nexport const addLinkTags = (text: string): string => {\n\tconst domainRegexp = getDomainRegexp();\n\tconst afterDomainRegexp = '(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*';\n\n\tconst regexpMailto = new RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpMailto, `$1<a href=\"mailto:$2\" target=\"_blank\" rel=\"noopener\">↑[$2]↓</a>`);\n\n\tconst regexpLink = new RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpLink, `$1<a href=\"√$2$3\" target=\"_blank\" rel=\"nofollow noopener\">$2$3</a>`);\n\n\ttext = text.replaceAll('√http', 'http');\n\ttext = text.replaceAll('√', 'http://');\n\ttext = text.replaceAll(/(↑\\[|]↓)/g, '');\n\n\treturn text;\n};\n\n/**\n * Перевести первую букву строки в верхний регистр\n */\nexport const toCapitalize = (str: string): string => {\n\treturn str.charAt(0).toUpperCase() + str.slice(1);\n};\n\n/**\n * Получить случайную строку\n */\nexport const getRandomHash = (length: number = 20): string => {\n\tconst l = 'AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890';\n\n\tlet result = '';\n\tfor (let i = 0; i < length; i++) {\n\t\tresult += l[Math.floor(Math.random() * l.length)];\n\t}\n\n\treturn result;\n};\n"]}
|
package/utils/string.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { D as e } from "../.chunks/forms-
|
|
1
|
+
import { D as e } from "../.chunks/forms-DByj6MWE.esm.js";
|
|
2
2
|
import { getDomainRegexp as t } from "./check.js";
|
|
3
3
|
//#region src/core/utils/string.ts
|
|
4
4
|
var n = /* @__PURE__ */ RegExp("^[^a-zа-я0-9_%#!?.:'\"«»[\\](){} \\r\\n\\t<>&/+-]", "i"), r = (e) => {
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[".chunks/formsExt-CdLb48ea.esm.js","../../src/components/formsExt/menu/menu.vue","../../src/components/formsExt/selector2/itemMulti.vue","../../src/components/formsExt/selector2/cache.ts","../../src/components/formsExt/selector2/composables/useAPI.ts","../../src/components/formsExt/selector2/utils.ts","../../src/components/formsExt/selector2/composables/useMenu.ts","../../src/components/formsExt/selector2/selector2.vue","../../src/components/formsExt/editArea/editArea.vue","../../src/components/formsExt/editInput/editInput.vue","../../src/components/formsExt/libs/optionGroup/optionGroup.vue","../../src/components/formsExt/radioGroup/radioGroup.vue","../../src/components/formsExt/checkboxGroup/checkboxGroup.vue","../../src/components/formsExt/info/info.vue","../../src/components/formsExt/policy/policy.vue"],"names":["vue","exports","K","ee","vue_1","r","i","a","o","c","n","t","s","l","forms_3oS4Utyg_esm_js_1","te","ne","q","J","Y","X","re","ie","u","d","f","ae","oe","Z","se","field_CjkpGeA7_esm_js_1","ce","h","m","p","b","x","S","C","e","keyboard_js_1","w","le","ue","de","fe","pe","T","D","O","k","W","G","g","popup_CAy1LTfy_esm_js_1","$slots","me","he","$core","ge","Q","$","_e","$props","ve","ye","be","xe","Se","Ce","we","Te","Ee"],"mappings":"AAAA,OAAO,CAAC,UAAW,UAAW,uBAA2B,uBAA2B,wBAAwB,uBAA2B,MAAO,qBAAuB,4CAAA,CAAA,SAAa,EAAS,EAAS,EAAyB,EAAyB,EAAe,EAAyB,EAAO,CACjS,aAAA,GAAAA,IAAA,OAAA,IAAAA,EAAA,OAAA,IACA,OAAO,eAAeC,EAAS,aAAc,CAAE,MAAO,GAAM,CAAC,CAC7D,EAAQ,EAAI,EAAQ,EAAI,EAAQ,EAAI,EAAQ,EAAI,EAAQ,EAAI,EAAQ,EAAI,EAAQ,EAAI,EAAQ,EAAI,EAAQ,EAAI,EAAQ,EAAI,EAAQ,EAAI,IAAK,GAEzI,IAAIC,EAAI,CACJ,IAAK,EACL,MAAO,qBACV,CAAEC,GAAsB,EAAGC,EAAM,iBAAiB,CAC/C,OAAQ,OACR,OAAwB,EAAGA,EAAM,aAAa,CAC1C,WAAY,EAAE,CACd,MAAO,EAAE,CACT,WAAY,CAAE,KAAM,QAAS,CAC7B,mBAAoB,CAAE,KAAM,QAAS,CACrC,QAAS,CAAE,QAAS,UAAW,CAC/B,cAAe,EAAC,CACnB,CAAE,CACC,WAAY,CAAE,SAAU,CAAC,EAAG,CAC5B,eAAgB,EAAC,CACpB,CAAC,CACF,MAAO,CAAC,oBAAoB,CAC5B,MAAM,EAAG,CACL,IAAIC,EAAI,EAAGC,GAAK,EAAGF,EAAM,UAAU,EAAG,aAAa,CAAEG,GAAK,EAAGH,EAAM,MAAM,CACzE,CAACC,EAAE,YAAc,OAAOC,EAAE,OAAS,UAAY,OAAOA,EAAE,OAAS,UAAY,QAAQ,KAAK,6DAAiE,OAAOA,EAAE,MAAM,CAAED,EAAE,YAAc,CAAC,MAAM,QAAQC,EAAE,MAAM,EAAI,QAAQ,KAAK,4DAAgE,OAAOA,EAAE,MAAM,CAAED,EAAE,YAAc,CAACA,EAAE,oBAAsB,MAAM,QAAQC,EAAE,MAAM,EAAI,CAACA,EAAE,MAAM,QAAUD,EAAE,MAAM,KAAO,EAAE,MAAQ,CAACA,EAAE,MAAM,IAAI,MAAQA,EAAE,MAAM,IAAI,MAAM,ECjBzc,IAIRG,EAAmB,GAAA,MAAA,QAIdF,EAAA,MAAK,CAAAA,EAAA,MAAA,SAAA,EAAA,MAAA,CAAA,EAAA,QAAAA,EAAA,MAAAG,GAAA,EAAA,EAAA,CAAA,IAAA,CAGL,GAAc,MAAQ,QAAMH,EAAA,MAAW,CAAA,CAmB5C,IAAMI,EAAAJ,EAAA,MAAc,OAIlB,CASG,GAAcK,EAAA,CACID,EAAA,SAAO,EAAAL,EAAA,MAAA,IAAA,GAAA,EAAA,MAAA,EAEtB,IAAAM,EAAAD,EAAA,QAAA,EAAA,MAAA,CAC4BC,IAAM,GAAID,EAAA,KAAQ,EAAK,MAAM,CAAAA,EAAA,OAAAC,EAAA,EAAA,MASvD,EAAWD,EAAA,SAAc,GAAYA,EAAA,KACpC,EAEF,MAAM,EAAM,CAAA,CAAA,EAAA,MAAA,CAId,CAAAL,EAAA,oBAAwC,CAAAK,EAAY,SAE/D,EAAM,CAAA,EAAA,MAAQ,EAAA,EAAA,MAAAA,EAEd,OAGkB,EAAA,MAAA,EAAA,OAIH,EAAsB,GAAA,CACzB,GAAAH,EAAA,MAAA,aAAwBA,EAAA,MAAA,aAC3B,EACN,UAAe,KAAO,IAAG,EAAI,OAAA,CAAA,GAE3B,OAEc,EAAA,gBAAkB,CAC7B,IAAA,EAAa,EAAG,OAAM,EAAA,GAAA,IAUG,EAAA,MAAS,WAAAA,EAAA,MAAA,WAAA,GAC1B,GAAM,EAAA,CAAA,IAAA,CACX,IAAAF,EAAAE,EAAA,MAAA,cAAA,cAAA,CAKa,GAAA,CAAAF,EAUuB,OASpB,IAAAC,EAAAD,EAAA,WAAAE,EAAA,MAAA,WAAA,GAAAC,EAAAH,EAAA,WAAAE,EAAA,MAAA,WAAAF,EAAA,YAAA,GAAAO,EAAAL,EAAA,MAAA,WAAAE,EAAAF,EAAA,MAAA,YAAAA,EAAA,MAAA,WAAAM,EAAsBP,EAAWM,IAAA,EAAWN,GAAAE,EAAAC,IAAA,EAAAD,EAAAD,EAAA,MAAA,aAAAM,IAAA,IAAA,MAAA,EAAAC,EAAA,IAAA,CAAAA,EAAA,EAAA,IAAAP,EAAA,MAAA,CAAA,QAAA,CAAA,WAAAM,EAAA,CAAA,EAAA,IAAA,EAAA,CAAAN,EAAA,MAAA,SAAA,CAAS,KAAAM,EAQ1D,SAAA,EAAA,SAAA,OACZ,CAAA,GAED,MAAM,CACA,GAAM,MAAM,QAAGP,EAAQ,MAAM,CAAM,CAClD,GAAAA,EAAA,MAAA,SAAAD,EAAA,MAAA,OAAA,CDjFsB,EAAE,MAAQ,CAACA,EAAE,MAAM,GAAG,MAAQA,EAAE,MAAM,GAAG,MAAM,CCoF5C,ODjFP,EAAE,MAAQA,EAAE,MAAM,IAAK,GAAM,EAAE,MAAQ,EAAE,MAAM,GC2F7D,OAAA,EAAAD,EAAA,eAAA,EAAA,CAAA,EAAA,CAAA,EAAA,EAAAA,EAAA,eAAA,EAAA,CAAA,EAAA,CAAA,EAAA,EAAA,MAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,oBAAA,MAAA,CACE,QAAA,KDvFQ,IAAKG,EACL,OCsFoC,EAAAH,EAAO,gBAAA,CDrFvC,WAAY,CAAC,GC0FvB,aAAA,EAAA,SAAA,CAAA,EAaI,CAAA,CARL,QAAA,EACA,CAAA,GAAA,EAAAA,EAAA,WAAA,CAAA,EAAA,EAAA,EAAAA,EAAA,oBAAAA,EAAA,SAAA,MAAA,EAAAA,EAAA,YAAA,EAAA,MAAA,KAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,aAAAU,EAAA,GAAA,EAAAV,EAAA,YAAA,CAAA,QAAA,CAAA,EAAA,CAAA,EAAA,CACE,MAAoB,gBACA,MAAA,QAEH,QAAK,GAAAK,EAAA,EAAA,EAAA,SAAA,EAAA,QAAA,CAAnB,SAAAD,EAAA,EAAA,CACQ,CAAA,EAAf,EAAKJ,EAAO,aAAA,CAAA,EAAA,EAAA,CAAA,CAAA,EAAA,QAAA,CD3FK,KAAM,UACN,IAAK,EAAGA,EAAM,aAAe,EAAE,EC+F9CA,EAAM,kBAAa,EAAKA,EAAA,iBAD/B,EAgBM,QAhBN,CAIC,EAWY,CAAA,CAAA,CATL,IAAA,IACA,CAAA,IAAA,GAAA,CAAA,CAAA,KAAA,CAAA,UAAA,WAAA,CAAA,EAAA,CAAA,IAAA,EAAA,MAAA,QAAAE,EAAA,MAAA,EAAA,EAAA,gBAAA,EAAAF,EAAA,YAAA,EAAA,EAAAA,EAAA,oBAAA,MAAAF,EAAA,EAAA,EAAAE,EAAA,aAAAU,EAAA,GAAA,EAAAV,EAAA,YAAA,EAAA,cAAA,CACE,MAAA,gBACF,MAAW,QACA,QAAW,GAEH,QAAA,EAAc,KAAA,GAAA,GAAA,CAA5B,SAAAE,EAAA,MAAA,SAAA,EAAA,MAAA,OACP,CAAA,EAAA,EAAAF,EAAA,aAAqB,CAAA,EAAA,EAAA,CAAA,CAAA,EAAA,cAAA,QAAA,CDlGD,KAAM,UACN,IAAK,EAAGA,EAAM,aAAe,EAAE,EAAGA,EAAM,kBAAkB,EAAGA,EAAM,iBAAiB,EAAE,cAAc,QAAQ,CAAE,EAAE,CAAC,CAAC,CAClH,IAAK,IACR,CAAG,IAAK,GAAE,CAAC,CAAE,KAAM,CAAC,WAAW,CAAC,CAAC,CAAC,GAAK,EAAGA,EAAM,oBAAoB,GAAI,CAAC,EAAE,CAAC,CAAE,GAAG,GAErG,CAAC,CAAEW,EAAK,CAAE,MAAO,uCAAwC,CAAEC,GAAsB,EAAGZ,EAAM,iBAAiB,CACxG,OAAQ,YACR,MAAO,CACH,GAAI,EAAE,CACN,KAAM,EAAC,CACV,CACD,MAAO,CAAC,SE1Ff,CAIE,MAAM,EAAA,CACN,OAAc,EAAA,MAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,oBAAA,MAAAW,EAAA,EAAA,EAAAX,EAAA,kBAAA,EAAAA,EAAA,iBAAA,EAAA,KAAA,CAAA,IAAA,EAAA,EAAA,EAAAA,EAAA,oBAAA,OAAA,CACR,MAAA,gCAAmB,gBAAA,IAAI,QAAA,EAAA,KAAA,GAAA,EAAA,MAAA,SAAA,CAAI,GAAA,EAAA,GACvB,KAAA,EAAA,KF2FQ,CAAC,CACF,YAAa,EAAE,MAAQ,EAAGA,EAAM,mBAAqB,GAAK,CAAC,OAAO,CAAA,CGtGzE,CAAA,KAAgB,GAAI,CAAA,CAAA,GASpB,CAAA,CAAea,EAAmC,IAAA,IAAAC,EAAA,GAAA,CACxDD,EAAS,IAAA,EAAO,EAAA,OAAO,EAI7BE,EAFiB,GAAK,CAKE,IAAkB,EAAA,OACjB,IAAU,MAAa,GAIzB,OACR,KAAI,UAAA,EAAA,OAAS,CAAI,IAAM,EAGtC,IAAkB,IAAU,GCxBhBC,GAEZ,EACA,IACAH,EAAA,IACI,EAAA,EAAA,IAAA,EAAA,CAAAI,GAAA,EAAA,EAAA,IAAA,CAIEJ,EAAQ,IAAe,EAKvB,EAAYA,EAAI,IAAM,EAKxB,IAAA,IAAA,CAAAA,EAAA,IAAA,EAAA,EAAA,IAAA,EAAA,EAAA,EAEQK,GAAI,EAAO,EAAA,EAAA,IAClB,CAQC,IAAU,GAAA,EAAAlB,EAAkE,KAAA,EAAA,CAAA,CAAAI,GAAA,EAAAJ,EAAA,KAAA,CAAA,EAAA,CAAAQ,GAAA,EAAAR,EAAA,KAAA,EAAA,CAAAK,EAAA,GAAAI,EAC5E,GAAK,CAAA,EAAA,OAAA,QAAA,EAAA,OAAA,MAAA,KAEJ,IAAWU,EAAuB,SAAO,CAEjC,GAAA,CAAA,EACoB,OAKhC,IAAA,EAFI,EAAAJ,EAAA,EAAA,CAAA,IAAA,GJ8EI,GAAI,EAAG,CIxEC,IAAI,EAAMC,EAAA,EAAA,EAAA,KAAA,CAEZ,GAAA,EAEL,OAAY,EAAA,oBAAS,CAAA,EAG/B,IAAA,EAAA,MAAA,EAAA,MAAA,CJuES,GAAI,EAAE,OIpEY,OACL,GAAI,CAAA,MAAA,QAAA,EAAA,OAAA,CAAA,CACb,QAAA,KAAY,iCAAkC,CAE3D,OAGG,IACH,EAAmB,EAAI,OAAM,UAGvB,GAAA,EAAA,KAAA,IAAA,IAAA,EAAA,OAAA,IAAA,GAAA,CAMK,GAAO,IAAoB,GAAA,CAC7B,QAAA,KAAA,YAAA,EAAA,mBAAA,CAEE,OAOA,OAAA,GAASC,EAAA,EAAA,EAAA,KAAA,EAAA,CAAA,GAEhBG,EAAA,KAAO,IAAS,CAGgB,GAE3B,CAAA,EACQ,OACA,GAElB,EAAa,CAasB,GAAK,CAAMX,GAAEL,EAAI,MAoC9C,OACM,EAAA,OAAA,OAAAK,OAGZ,EAAA,OAAA,OAAA,EACA,IAAA,EAAAJ,EAAA,CAAA,EAAA,MAAA,CAAA,EACA,IAAA,EAAA,MA9B6Bc,GAAuB,CAIpD,EAAA,MAAA,CAAA,EAAA,EAAA,QAAA,IAAA,EAAA,EAAA,WAAA,EAAA,EAAA,MAAA,EAAA,MAAA,OAAA,EAAA,OAAA,CAAA,EAAA,MAAA,EAAA,SAAkBE,GAAA,EAASX,EAAW,OAAAU,EAAA,CAAA,EAAA,CAAA,IAAA,CACjC,MAAA,CAIJ,WAAA,EJwBS,MAAO,EIpBK,UAA0BhB,EJsBtC,aAAcI,EACd,KAAMY,EILhB,sBAAA,EAAA,EAAA,CAAA,IAAA,CCjJyB,GAAA,EAKd,CA4Ba,GAAA,EAAA,OAAad,EAAA,CAGM,EAAA,oBAGnC,CAAK,EAAe,MAAW,EAAA,CClCxC,OAkBC,IAAAD,GAAA,EAAA,MAAA,SAAA,EAAA,EAAAJ,EAAAoB,GAAA,CAAAD,EAAA,CAAA,EAAA,IAQW,EAMNE,EAAA,EAELC,EADS,KAAAC,GAAA,EACL,EAAW,EAAM,CAAA,IAAA,GAAU,EAQ1B,KAAkC,KAAe,MAAA,QAAA,EAAA,CAAA,EAAA,KAAA,GAAA,EAAA,KAAA,EAAA,IAAA,EAAA,OAAA,EAAA,KAAA,CAAA,EAAA,OAAA,EAAA,KAAA,MAAA,QAAA,EAAA,CAAA,EAAA,KAAA,GAAA,EAAA,KAAA,EAAA,GAAA,CAAA,EAAA,KAAA,EAAA,GAAAC,GAAA,EAAA,EAAA,IAAA,CAChD,IAAuBxB,EAAA,EAAA,OAAA,SAAA,EAAA,CAY7B,EAVKA,EAAA,OAA0B,GAC1B,EAAA,OAAkB,EAAA,CAAA,GAAUA,EAAA,MAAA,EAC/ByB,EAGU,GAAa,EAGzB,WAAa,CAAA,EAAA,CAAA,CAAA,CAAQ,EAAA,aAA0B,CAAG,QAE3CzB,EAAA,CAAA,EAMF0B,GAA6B,EAE7B,EAAA,EAAA,EAAA,EAA2B,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,IAAA,CACnB,IAAQC,GAAiB,EAAA5B,EAAA,KAAA,GAAA,CAAA,EAAA,CAUjC,GAAwB,EACG,MAAM,EAAAU,EAGlC,IAAkB,CASlB,OAC0B,IAOR,CAAG,MAAE,CNqEjB,EAAE,MAAQ,IMtDT,MAAmB,EAAA,CAC7BmB,EAAA,YAAaD,EAAA,MAAA,QAAbE,GAAAC,GAAA,EAAA/B,EAAA,cAAA,CACM,IAAA,EAAA,EAAA,CAGJ,MAAoB,CAAAE,GAAAC,EAAA,QAAA,OAAAA,EAAA,OAAA,WAAA,EAAA,KAAAA,EAAA,OAAA,EAAA,KAAA,EAAA,EAAA,EAAA,OAAA,QAAA,GAAA,EAAA,KAAA,CAAA,GAAA,EAAA,CAAA,CAAA,CAAA,GAEpB,CAAA6B,GAAA,EAAAhC,EAAA,KAAA,EAAA,CAAA,CAAAiC,MAAA,CAEI,EAAA,MAAAC,GAAA,EAEcA,MAAQ,CACrB,IAAsBC,EAAAP,EAAA,MAAA,aAAA,CAAA,GAAA,EAAAQ,EAAA,sBAAAD,EAAA,CAAA,EAAA,EAAA,CAAAhC,EAAAkB,EAAA,EAAA,CAAA,MAAA,CACAA,EAAA,GAAA,GAAA,EAAA,eAAwB,OAAA,aAEpCA,EAAS,KAAA,CAAA,EAAA,UAAAlB,GAAA,EAAA,KAAAA,EAAA,CAAA,EAAA,KAAA,GAAAkB,EAAA,CAAA,IAGxB,IAAA,IAAAd,KAAAwB,EAAA,MACD,OAAAxB,EAAA,eAAA,KAAA,CACkC,IAAO,QAUX,GAAO,CAAa,EAChDA,ENqCkB,MMtBX,IAAO,YAcK,GAAAc,EAAA,OAAA,CACrB,IAAAc,EAAAd,EAAA,OACiBA,EAAA,GAAA,GAAA,EAAA,eAAA,OAAA,aAAA,IAAA,EAAAc,GAAA5B,EAIT,MNSQ,QMDH,IAAA,EAAOY,EAAA,OAA0B,SAAa,KAGtD,CAAA,EAAAZ,EAAA,KAAA,aAAA,CAAAH,EAAAe,EAAA,OAAA,OAAA,GAAA,IAAA,KAAA,CAAA,IAAA,GAAA,OAAAZ,EAAA4B,IAAA,UAAA,OAAA5B,EAAA4B,IAAA,SAAA5B,EAAA4B,GAAA,GAAA,CAAA,KAAA,IAAA,CAAA,aAAA,EAQ2B,GAAA5B,EAAA,KAAA,OAAA4B,EAAA,EAAA/B,GAAA,SAAA+B,EAAA,EAAA/B,GAAA,SAAA,EAAA,IAAA,IAAA+B,GAAA,IAAA,EAAAd,EAAA,QAAAd,EAAA,CAAAc,EAAA,KAAAd,EAAA,EAsCpB,GAAA,GAAA,CAAA,EAAA,KAAA,GAAAsB,EAAA,MAAA,MAAA,CAAAzB,EAAA,OAAAwB,EAAA,QAAA,CAAAvB,EAAA,OAAAA,EAAA,MAAA8B,EAAA,IAAA3B,EAAA,OAAA,CAAA,EAAA,KAAA,GAAAD,EAAA,KAAA,aAAA,GAAA4B,EAAA,EAAA,CACZ,IAAA,EAAA,CN3CgB,GAAI,KMsDH,KAAAP,EAAA,MAEqB,CAIbnB,EAG3B,QAAM,EAAsB,cAAA,CAAA,aAAA,CAAA,EAAA,EAAA,EAAA,KAAA,EAAA,CAE1B,OAAAP,IAAA,EAAA,EAAA,OAAA,GAAA,CAAAsB,EAAAjB,EAAA,MAAA4B,EAAA,CAAA,EAAA,GAEIE,EAAA,GAAA,CAACF,EAAA,eAAA,OAAA,SAAAA,EAAA,eAAA,OAAA,aAAAA,EAAA,KAAA,OAAA7B,EAAA,aAAA6B,EAAA,CAAA1B,EAAA,SAAAP,GAAA,MAAA,QAAAK,EAAA,MAAA,CAAAiB,EAAAjB,EAAA,MAAA4B,EAAA,GAAA,EAAA,MAAA,CAAA,GAAA5B,EAAA,MAAA4B,EAAA,EAAA,EAAA,MAAAA,EAAA,eAAA,CAAO,GAAA,EAAO,GACA,GAAAN,EAAA,WAAA,CAClB,IAAAM,EAAA,CAAA,EAAAN,EAAA,MAAA,CACF3B,GAAWiC,EAAA,KAAA5B,EAAA,EAAA,EAAAP,EAAA,OAAAmC,MAAA,CAGLF,GAAA,EACL,OA2BF,EAAAjC,EAAA,OAAA,CACAO,EACA,EACAqB,EACA,KAAA,CAxBUK,GAAA,EAE2B,CAIrB,UAFqB,CAAA,EN3DvB,KAAM,EMgFpB,CAAA,CAZI,MAAM,CNjEA,WAAYL,EM8EtB,YAAA,EN5EU,WAAY,EACZ,aAAcI,EACd,WAAYK,EACZ,mBAAsB,CAClB,GAAI,MAAM,QAAQ9B,EAAE,MAAM,CACtB,OACJ,IAAI4B,EAAIH,EAAE,MAAM,OAAQ,GAAM,CAAC,CAAC,QAAS,YAAY,CAAC,SAAS,EAAE,eAAe,MAAQ,GAAG,CAAC,CAC5F,EAAE,MAAQ,CAAE,GAAGG,GAAGA,EAAE,UAAW,GAAMA,EAAE,KAAO5B,EAAE,MAAM,GAAG,CAAG,GAAK4B,EAAE,QAAS,EAEhF,iBAAkB,KAAO,IAAM,CAC3B,MAAM,QAAQ5B,EAAE,MAAM,GAAK,EAAE,MAAQA,EAAE,MAAM,OAAQ,GAAMA,EAAE,KAAO4B,EAAE,IAAM5B,EAAE,OAAS4B,EAAE,KAAK,GAErG,EACFG,EAAK,CACJ,IAAK,EACL,MAAO,4BACV,CAAEC,EAAK,CACJ,IAAK,EACL,MAAO,wCACV,CAAEC,EAAK,CACJ,IAAK,EACL,MAAO,yCACV,CAAEC,EAAK,CAAE,MAAO,6BAA8B,CAAEC,GAAsB,EAAG1C,EAAM,iBAAiB,CAC7F,OAAQ,YACR,OAAwB,EAAGA,EAAM,aAAa,CAC1C,WAAY,EAAE,CACd,MAAO,CAAE,YAAe,EAAE,CAAE,CAC5B,MAAO,EAAE,CACT,SAAU,CAAE,KAAM,QAAS,CAC3B,KAAM,EAAE,CACR,YAAa,EAAE,CACf,KAAM,CAAE,QAAS,IAAK,CACtB,QAAS,CAAE,KAAM,QAAS,CAC1B,iBAAkB,CACd,KAAM,QACN,QAAS,IAAK,GACjB,CACD,WAAY,CAAE,QAAS,QAAS,CAChC,aAAc,CAAE,YAAe,CAAC,KAAM,OAAO,CAAE,CAC/C,YAAa,EAAE,CACf,aAAc,CAAE,KAAM,QAAS,CAC/B,IAAK,EAAE,CACP,mBAAoB,EAAE,CACtB,UAAW,CAAE,QAAS,EAAG,CACzB,SAAU,CAAE,KAAM,QAAS,CAC3B,qBAAsB,CAAE,KAAM,QAAS,CACvC,2BAA4B,CAAE,KAAM,QAAS,CAC7C,yBAA0B,EAAE,COhR1B,oBASgC,CAAoB,KAIpD,QAAA,CAQb,YAAsC,CAAA,KAAU,QAAA,CACtC,WAGL,CACH,KAAe,CAAA,QAAW,OAIvB,CAAA,CAUE,WAAa,CAAA,KAAU,QAAA,CAIb,YACX,EAAA,CAGL,sBAAA,CAAA,KAAA,QAAA,CAEsB,eAEb,EAAA,CAmDH,CAAA,CAGF,WAAA,CAAqB,SAAK,CAAA,EAAW,CACxC,eAAA,EAAA,CAGG,CAAc,CAYf,OAAW,EAAAA,EAAA,aAAA,CAAA,aAAA,OAAA,CAAA,CAAA,oBAAA,CAAA,CAEf,MAAU,EAAA,CAAV,OAAA,EAAA,KAAA,GAAA,CACM,IAAA,EAAA,EAAAG,GAAA,EAAAH,EAAA,UAAA,EAAA,aAAA,CAAAI,EAAA,EACA,EAAA,CAAA,YAAA,EAAA,CAAA,IAAA,CACcC,EAAM,aACrB,GAAAS,EAAAT,EAAA,WACA,KAAA,CAAA,EAAA,MAAiB,MAEb,EAAM,CAAA,EAAK,aAAA,MAAA,EAAA,EAAA,WAAA,OAAA,OAAA,EAAA,0BAAA,CAGlB,EAAA,aAAA,MAAA,EAAA,EACI,CAAAsC,GAAA,EAAA,SAAAtC,EAAA,qBAAAc,EAAA,WAAA,MAAA,GACA,CAAA,CACA,IAAAX,GAAA,EAAAR,EAAA,cAAA,EAAA,aAAA,UAAA,EAAA,aAAA,EAAA,aAAA,UAAAU,EAAA,EAAA,MAAA,SAAA,QAAA,EAAA,WAAA,CAAAL,EAAAa,EAAA,EAAA,IAAA,EAAA,mBAAA,EAAA,UAAA,EAAA,SAAA,CAAAC,EAAAQ,EAAAxB,EAAAC,GAAA,EAAAJ,EAAA,OAAA,EAAA,QAAA,CAAA,EAAA,aAAA,EAAAA,EAAA,OAAA,EAAA,aAAA,EAAA,EAAAA,EAAA,OAAA,EAAA,uBAAA,EAAA,EAAAA,EAAA,OAAA,EAAA,6BAAA,EAAA,EAAAA,EAAA,OAAA,EAAA,2BAAA,EAAA,EAAAA,EAAA,OAAA,EAAA,sBAAA,EAAA,EAAAA,EAAA,OAAA,EAAA,eAAA,CAAAQ,EAAA,EAAA,UAAAH,EAAA,CAAAe,GAAA,EAAApB,EAAA,cAAA,EAAA,YAAA,YAAAQ,EAAA,QAAA,SAAA,WAAA,MAAA,CAAA6B,GAAA,EAAArC,EAAA,KAAA,KAAA,CAAA2C,MAAAN,EAAA,OAAA,MACAhC,EAAA,aAAA,EAAAL,EAAA,OAAAmB,EAAA,eAAA,CACAd,EAAA,qBAAAc,EAAA,WAAA,MAAA,EACA,CACO,IAAAyB,GAAA,EAAA5C,EAAA,cAAA,MAAA,QAAAG,EAAA,MAAA,EAAA,EAAA,aAAA,CAAA,EAAA,uBAAAK,EAAA,QAAA,SAAA,EAAA,YAAAL,EAAA,OAAA,MAAA,EAAA,YAAA,CAAA0C,EAAA,GAAA,CAEX,IAAA,EAAA,CAAA,EACI,OAAA,EAAA,IAAA,CAC0B,IAAA,SAK9B,IAAA,YPuJqB,MAAM,QAAQ1C,EAAE,MAAM,GAAK,EAAE,gBAAgB,CAAE,EAAE,iBAAiB,CAAEA,EAAE,MAAM,KAAK,EOnJ5E,MAGE,IAAA,UA6BW,IAAA,aACvC,IAEG,YAMe,IAAA,YAGnB,IAAI,QASgB,IAAA,IAES,EACpB,CAAA,EAW+B,MAC5B,IAAA,SAEUK,EAAA,QAAe,UAAGW,EAAA,aACpC,CPwFkB,MAER,IAAI,EAAI,EAAE,IAAI,SAAW,GAAK,CAAC,EAAE,SAAW,CAAC,EAAE,SOoFnDX,EAAA,QAAA,SAAAA,EAAA,QAAA,WAAA,IAAA,EAAA,CAAA,GAAAmC,GAAA,EAAA,UAAA,EAAA,CAAA,GAAA,IAAAnC,EAAA,QAAA,UAAA,EAAA,gBAAA,CAAA,EAAA,iBAAA,CAAA,IAAAW,EAAA,WAAA,QAAA,EAAA,WAAA,MAAA,EAAA,OAAA,EAAA,eAAA,OAAA,GAnIN2B,EAAA,GAAA,CAAA,EAAA,gBAAA,CAAA3B,EAAA,gBAAA,EACC4B,MAAA,CACC1C,EAAA,YAASA,EAAA,qBAAAc,EAAA,WAAA,MAAA,CAAA,EAAA,CAAAf,EAAA,OAAA,EACd4C,MAAiB,CACVxC,EAAA,QAAA,SAAAW,EAAA,WAAA,OAAAA,EAAA,aAAA,EACPrB,EAAA,GAAoB,CACpB,IAAA,EAAkB,EAAA,OACR,EAAA,WAAe,EAAA,aAAsB,EAAA,cAAU,IAAAO,EAAA,KAAA,CAAA,EAAA,EAEzC,OAsDJ,EAAA,IArDZ,CAKO,IAAA,GAAA,EAAAL,EAAA,kBAAA,YAAA,CAAAI,GAAA,EAAAJ,EAAA,kBAAA,aAAA,CAAAiD,GAAA,EAAAjD,EAAA,kBAAA,YAAA,CAAA2C,GAAA,EAAA3C,EAAA,kBAAA,eAAA,CP8CM,OAAQ,EAAGA,EAAM,YAAY,EAAG,EAAGA,EAAM,cAAc,EAAGA,EAAM,OAAOkD,EAAwB,EAAE,CAAE,CAC/F,QAAS,WACT,IAAKb,EACL,OOjDiJ,EAAA,KAAA,GAAeU,GAAA,CPkDhK,QAAS,EAAE,KAAQ,GAAMC,GAAG,CAC5B,oBOnDoP,EAAA,KAAA,IAAA,EAAAhD,EAAA,OAAAK,EAAA,CAAAP,EAAA,EAAA,CAAA,IAAA,GPoDpP,MOpDoR,CAAA,EPqDpR,mBOrD6T,EAA8B,iBAAAU,EAAA,QAAA,WAAA,EAAA,kBAAA,CAAA,GPuD3V,SAAUA,EAAE,QAAU,WAAa,EAAGR,EAAM,OAAOmB,EAAE,CAAC,YAAW,CO5ChF,EAAA,EAAAnB,EAAA,aAAA,CACQ,QAAA,EAAAA,EAAA,aAAA,EAAA,EAAAA,EAAA,kBAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,cAAA,EAAAA,EAAA,yBAAAoB,EAAA,MAAA,EAAA,EAAApB,EAAA,YAAA,EAAA,YAAA,CACC,MAAA,CACH,gBAAe,CAAA,EAIrB,4BAAA,EAAA,aACA,iBAAA,EAAA,aAAA,CAAA,CAAA,EAAA,YAC4B,eAAiB,CAAA,EAAA,aAAmBQ,EAAA,QAAW,SAC9D,kBAAW,CAAA,GP2CI,YO3CpB,EAAK,MAAA,CAAA,EP4Cc,eAAgB,EAAE,SOjCnC,sBAAA,CAAA,EAAA,SADJ,YAAA,EAAA,QAJM,CACE,KAAA,EAAA,KACE,SAAA,IP0CO,UAAWqC,EACX,OAAQ,EAAE,KAAQ,GAAMrC,EAAE,QAAU,WAAa,EAAGR,EAAM,OAAOmB,EAAE,CAAC,aAAa,CACjF,YAAayB,EAAE,MACf,MAAO,EAAE,MACT,YAAapC,EAAE,QAAU,UAAY,EAAE,QAAU,IAAK,GAAI,MAAQ,IAAK,GOzCpE,YAAkB,EAAAR,EAAA,OAEtCmB,EAAA,CAAA,WADF,MAGuB,sBAErB,EAAA,KAAA,GADH,CAAA,EAAWnB,EAAA,OAAAmB,EAAA,CAAA,WAAA,MAAA,EAIO,CAAA,CAAA,CPoCE,SAAU,EAAGnB,EAAM,aAAe,COnCnD,EAAA,cAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,oBAAA,MAAAsC,EAAA,GAAA,EAAAtC,EAAA,WAAA,CAAA,EAAA,EAAA,EAAAA,EAAA,oBAAAA,EAAA,SAAA,MAAA,EAAAA,EAAA,YAAAG,EAAA,MAAA,KAAA,EAAAH,EAAA,YAAA,EAAA,EAAAA,EAAA,aAAAY,EAAA,CACkB,GAAA,EAAA,GAChB,KAAA,EAAA,KPqC2B,UAAW,EAAGZ,EAAM,OAAOmB,EAAE,CAAC,iBACjC,CAAE,KAAM,EAAG,CACR,KACA,OACA,WACH,CAAC,EAAE,CAAE,IAAI,EAAE,CAAC,GAAK,EAAGnB,EAAM,oBAAoB,GAAI,CAAC,EAAE,CAC1DQ,EAAE,QAAU,UAAY,CAAC,EAAE,cAAgB,EAAGR,EAAM,YAAY,EAAG,EAAGA,EAAM,oBAAoB,OAAQuC,GAAK,EAAGvC,EAAM,iBAAiB,MAAM,QAAQG,EAAE,MAAM,CAAG,GAAKA,EAAE,MAAM,KAAK,CAAE,EAAE,GAAK,EAAGH,EAAM,oBAAoB,GAAI,CAAC,EAAE,CAC/N,EAAE,aAAe,CAACG,EAAE,MAAM,SAAW,EAAGH,EAAM,YAAY,EAAG,EAAGA,EAAM,oBAAoB,OAAQwC,GAAK,EAAGxC,EAAM,iBAAiB4C,EAAE,MAAM,CAAE,EAAE,GAAK,EAAG5C,EAAM,oBAAoB,GAAI,CAAC,EAAE,CACtL,EAAE,YAAc,CAAC,EAAE,aAAe,CAAC,EAAE,cAAgB,EAAGA,EAAM,OAAOmB,EAAE,CAAC,aAAa,MAAM,OAAS,GAAK,CAAC,EAAE,WAAa,EAAGnB,EAAM,YAAY,EAAG,EAAGA,EAAM,oBAAoB,OAAQ,CAClL,IAAK,EACL,MAAO,mCACP,0BAA2B,OO/ErC,QAAA8C,EPiFO,CAAC,GAAK,EAAG9C,EAAM,oBAAoB,GAAI,CAAC,EAAC,COjFxC,CAAA,CACA,EAAA,EA0DS,CAAA,GAAA,CAAxB,QACE,OACX,cAA8B,QP4BZ,cACA,aACH,CAAC,EAAG,CAAC,COzBViD,EACR,EAAA,QAIDE,IAAO,GPwBc,CAAE,SAAU,CAAC,EAAE,COtBzC,CAAA,CAAAR,EAAA,EAAA,eAAA,CAAA,CAAA,CAAA,CAAA,CAOS,aAAA,EAAA3C,EADF,aAAI,GPmBS,EAAGA,EAAM,WAAW,CAAC,EAAE,EAAG,EAAGA,EAAM,oBAAoBA,EAAM,SAAU,MAAO,EAAGA,EAAM,aAAa,EAAGA,EAAM,OAAOmB,EAAE,CAAC,aAAa,MAAQ,KAAQ,EAAGnB,EAAM,YAAY,EAAG,EAAGA,EAAM,cAAc,EAAGA,EAAM,OAAOkD,EAAwB,EAAE,EAAG,EAAGlD,EAAM,YAAY,CACnQ,IAAK,EAAE,IAAM,IAAK,GAClB,MAAO,CACH,aAAc,CAAC,MAAM,QAAQG,EAAE,MAAM,EAAI,CAAC,EAAE,aAAeA,EAAE,MAAM,KAAO,EAAE,IAAMA,EAAE,MAAM,OAAS,EAAE,KACrG,yBAA0B,EAAE,MAAQ,EAAGH,EAAM,OAAO,EAAE,CACtD,yBAA0B,EAAE,MAAQ,EAAGA,EAAM,OAAO,KAAI,COnBlD,CPqBV,aAAc,CAAC,EAAE,cAAgB,EAAGA,EAAM,OAAOU,EAAwB,EAAE,CAAC,MAAM,SOpBnF,CAAA,CAAA,QAAA,CAAA,EAAA,CAAA,EAAA,cAAA,CAAA,QAAA,IAAA,EAAAV,EAAA,OAAAmB,EAAA,CAAA,WAAA,EAAA,CAAA,CAAA,CAAA,CPsBC,SAAU,EAAGnB,EAAM,aAAe,CAAC,EAAE,OAAO,MAAQ,EAAGA,EAAM,YAAY,EAAE,OAAQ,OAAQ,COrB7F,IAAU,EPuBA,KAAM,EOhB/B,CAAA,GAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,oBAAAA,EAAA,SAAA,CAAA,IAAA,EAAA,CAAA,EAAA,EAAAA,EAAA,kBAAA,EAAAA,EAAA,iBAAA,EAAA,KAAA,CAAA,EAAA,CAAA,CAAA,GAAA,EAAA,CAAA,CPkBiB,EAAG,EACN,CAAE,KAAM,CACL,QOdY,ePgBZ,UACH,CAAC,EAAE,CAAE,IAAI,EOhFO,EAAA,EAAAA,EAAA,OAAAmB,EAAA,CAAA,aAAA,MAAA,QAAA,EAAA,EAAAnB,EAAA,OAAAmB,EAAA,CAAA,YAAA,GAAA,EAAAnB,EAAA,YAAA,EAAA,EAAAA,EAAA,cAAA,EAAAA,EAAA,OAAAkD,EAAA,EAAA,CAAA,CAA5B,IAAA,EACV,KACC,UACO,CAAA,CACD,SAAA,EAAAlD,EAAA,aAAA,CAAA,EAAA,EAAAA,EAAA,OAAAK,EAAA,CAAA,UAAA,QAAA,EAAAL,EAAA,OAAAK,EAAA,CAAA,aAAA,QAAA,EAAAL,EAAA,YAAA,EAAA,EAAAA,EAAA,oBAAAA,EAAA,SAAA,CAAA,IAAA,EAAA,CAAA,EAAA,EAAAA,EAAA,kBAAA,EAAAA,EAAA,iBAAA,EAAA,MAAA,OAAA,WAAA,CAAA,EAAA,CAAA,CAAA,GAAA,IAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,cAAA,EAAAA,EAAA,OAAAU,EAAA,EAAA,CAAA,CACoB,IAAA,EPkFM,KAAM,UOhFnB,CAAA,EAAa,CAAA,CAC9B,EAAA,EPkFmB,CAAC,GAAK,EAAGV,EAAM,oBAAoB,GAAI,CAAC,EAAE,EAC1C,EAAGA,EAAM,OAAOK,EAAE,CAAC,aAAa,QAAU,EAAGL,EAAM,OAAOK,EAAE,CAAC,UAAU,OAASG,EAAE,QAAU,WAAa,EAAGR,EAAM,YAAY,EAAG,EAAGA,EAAM,aAAaI,EAAG,CAAE,IAAK,EAAG,CAAC,GAAK,EAAGJ,EAAM,oBAAoB,GAAI,CAAC,EAAC,CACjN,CAAC,CACF,EAAG,EACN,CAAE,CAACQ,EAAE,QAAU,QAAU,CAClB,KAAM,SOzFH,IAAA,EAAAR,EAAA,aAAA,EAAA,EAAAA,EAAA,oBAAA,MAAAyC,EAAA,EAAA,EAAAzC,EAAA,iBAAA,EAAAA,EAAA,cAAA,EAAAA,EAAA,OAAAkD,EAAA,EAAA,CAAA,CP2FS,MAAO,QO3FV,KAAA,IAMC,YAAM,EAAAlD,EAAA,OAKxBmB,EAAA,CAAA,WAAA,MPmFoB,sBAAuB,EAAE,KAAQ,GAAM,CAAC,EAAGnB,EAAM,OAAOmB,EAAE,CAAC,WAAW,MAAQ,EOvFvG,UAAA,CAAA,EAAA,EAAAnB,EAAA,OAAAK,EAAA,CAAA,aAAA,QAAA,EAAAL,EAAA,OAAAK,EAAA,CAAA,UAAA,MACA,YAAAuC,EAAA,MPyFsB,CAAE,KAAM,EAAG,COvF9B,aPyFsB,YACA,cACH,CAAC,CAAE,CAAC,CACGK,EACA9C,EAAE,MACF,IAAK,GACL,CAAE,SAAU,CAAC,EAAE,CAClB,CAAC,CAAC,CAAE,EAAE,cAAgB,CAAC,EAAE,MAAM,MAAM,WAAa,EAAGH,EAAM,YAAY,EAAG,EAAGA,EAAM,aAAa,EAAG,CACpG,IAAK,EACL,MAAO,SACP,MAAO,QACV,CAAE,CACC,SAAU,EAAGA,EAAM,aAAe,EAAE,EAAGA,EAAM,kBAAkB,EAAGA,EAAM,iBAAiB,EAAE,MAAM,OAAO,OAAO,CAAE,EAAE,CAAC,CAAC,CACrH,EAAG,EACN,CAAC,GAAK,EAAGA,EAAM,oBAAoB,GAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CACvD,IAAK,IACR,CAAG,IAAK,GAAE,CAAC,CAAE,KAAM,CAAC,mBAAoB,WAAW,CAAC,GAGpE,CAAC,CAAEoD,EAAK,CAAE,MAAO,sBAAuB,CAAEC,GAAsB,EAAGrD,EAAM,iBAAiB,CACvF,OAAQ,WACR,MAAO,CACH,aAAc,CAAE,QAAS,GAAI,CAC7B,MAAO,EAAE,CACT,WAAY,CAAE,QAAS,SAAU,CACjC,WAAY,CAAE,QAAS,OAAQ,CAC/B,UAAW,CAAE,QAAS,QAAS,CAC/B,UAAW,CAAE,KAAM,QAAS,CAC5B,kBAAmB,CAAE,KAAM,QAAS,CACpC,iBAAkB,CAAE,KAAM,QAAS,CACnC,WAAY,EAAE,CACd,KAAM,EAAE,CACR,YAAa,EAAE,CACf,QAAS,EAAE,CACX,KAAM,EAAE,CACR,UAAW,EAAE,CACb,WAAY,CACR,KAAM,QACN,QAAS,CAAC,EQ3dpB,CASA,SAEM,CAAA,KAAQ,QAAM,CAGpB,SAAe,CAAA,KAAA,QAAA,CACV,QAAA,CAAA,KAAA,QAAgC,CACpC,KAAQ,EAAA,CAEb,UAAA,EAAA,CRgdO,CQ7cG,MAAc,CAGpB,SACK,QR6cC,eACH,CACD,MAAM,EAAG,CAAE,KAAM,GAAK,CAClB,IAAIM,EAAI,EAAGL,EAAI,EAAGC,GAAK,EQ1cwCF,EAAA,KAAAM,EAAA,aAAA,CAAAH,GAAA,EAAAH,EAAA,KAAAM,EAAA,UAAA,CAAAF,GAAA,EAAAJ,EAAA,cAAAE,EAAA,QAAAI,EAAA,aAAA,CAAA,EAAA,GAAA,CAMlEL,EAAA,SAASkD,EAAO,CAAA,EAAA,MAAA7C,EAAA,cRscV,MAAU,CQrchB,GAAAA,EAAA,mBAAA,CAAAF,EAAA,MAAA,CACAH,EAAA,QAAE,CAID,ORqcM,EAAE,MAAQK,EAAE,cACb,MAAU,CQlc+FA,EAAA,kBAAAL,EAAA,eAAA,EAwBnH,OAAA,EAAA,MAAA,EAAAD,EAAA,YAAA,EAAA,EAAAA,EAAA,oBAAA,MAAA,CAAA,OAAA,EAAAA,EAAA,gBAAA,CAfQ,eAAA,CAAA,ER8bO,kCQ9bG,EAAA,iBACZ,CAAA,CAAA,CAAA,CAAA,EAAA,OAAA,EAAA,OAAA,UAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,oBAAA,MAAA,CACO,IAAA,EACP,MAAA,uBACK,QAAA,EAAA,KAAA,GAAA,GAAA,CACC,CAAA,EAAA,EAAAA,EAAA,YAAA,EAAA,OAAA,UAAA,EAAA,KAAA,EAAA,EAAAA,EAAA,kBAAA,EAAAA,EAAA,iBAAA,EAAA,MAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,GAAA,EAAAA,EAAA,oBAAA,GAAA,CAAA,EAAA,EAAA,EAAAA,EAAA,oBAAA,MAAA,CAAA,OAAA,EAAAA,EAAA,gBAAA,CACF,oBAAA,CAAA,EACA,sBAAA,CAAA,EACD,eAAA,CAAA,EACH,YAAA,EAAA,QACD,YAAAG,EAAA,MACA,CAAA,CAAA,CAAA,EAAQ,EAAAH,EAAS,aAAAU,EAAA,EAAA,CAClB,WAAiBR,EAAA,MACJ,sBAAA,EACC,KAAO,GAAU,EAAA,MAAA,ER8bhB,KAAM,EAAE,KACR,YAAa,EAAE,YACf,KAAM,EAAE,KACR,UAAW,EAAE,UACb,WAAY,EAAE,WACd,SAAU,EAAE,SACZ,SAAU,EAAE,SACZ,QAAS,EAAE,QACX,KAAM,EAAE,KACR,MAAO,uBACP,QAAS,EAAE,SAAa,EAAE,MAAQ,CAAC,EQnchD,OAAa,EAAA,SAAA,EAAA,MAAA,CAAA,ERqcA,QAAS,EAAE,EAAGF,EAAM,UAAU,EAAG,CAAC,MAAM,CAAC,CAAE,EAAE,MAAQ,EAAGA,EAAM,WAAW,EAAGA,EAAM,eAAgB,GAAM,EAAEE,EAAE,MAAM,CAAE,CAAC,OAAO,CAAC,CAAE,CAAC,QAAQ,CAAC,CAAA,CQpc/I,CAAM,KAAA,EAAA,CACb,aACA,OACE,cACA,OAIAoD,YADN,aAGE,WRmce,WACA,UACA,OQhcb,CAAA,EAAA,EAAAtD,EAAA,oBAAA,MAAAoD,EAAA,CAAAhD,EAAA,OAAA,EAAA,oBAAA,EAAAJ,EAAA,YAAA,EAAA,EAAAA,EAAA,aAAAU,EAAA,EAAA,CAEa,IAAA,EACX,KAAO,EAAA,MAAU,MAAA,SAAA,IAAA,GAIX,MAAM,sBADlB,MAAA,QAGE,QAAU,OR8bS,QAAS,EACZ,EAAG,EAAGV,EAAM,aAAa,CAAE,EAAG,EAAG,CAAE,CAAC,EAAE,MAAM,MAAM,SAAW,IAAK,GAAI,CAC/D,KAAM,UACN,IAAK,EAAGA,EAAM,aAAe,EAAE,EAAGA,EAAM,kBAAkB,EAAGA,EAAM,iBAAiB,EAAE,WAAW,CAAE,EAAE,CAAC,CAAC,CACvG,IAAK,IACR,CAAC,CAAC,CAAE,KAAM,CAAC,OAAO,CAAC,GAAK,EAAGA,EAAM,oBAAoB,GAAI,CAAC,EAAE,CAAEI,EAAE,QAAU,EAAGJ,EAAM,YAAY,EAAG,EAAGA,EAAM,aAAaU,EAAwB,EAAG,CACpJ,IAAK,EACL,MAAO,sBACP,KAAM,EAAE,MAAM,MAAM,SAAW,IAAM,GACrC,QAAS,EAAE,KAAQ,GAAM,EAAER,EAAE,MAAK,CACrC,EAAG,EAAGF,EAAM,aAAa,CAAE,EAAG,EAAG,CAAE,CAAC,EAAE,MAAM,MAAM,SAAW,IAAK,GAAI,CAC/D,KAAM,UACN,IAAK,EAAGA,EAAM,aAAe,EAAE,EAAGA,EAAM,kBAAkB,EAAGA,EAAM,iBAAiB,EAAE,WAAW,CAAE,EAAE,CAAC,CAAC,CSrjBxF,IAAA,IAE7B,CAAkB,CAAA,CAAA,KAAA,CAAA,OAAA,CAAA,GAAA,EAAAA,EAAA,oBAAA,GAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,EAAA,GAElC,CAAA,CAAAuD,EAAA,CAAA,MAAA,gBAAA,CAAAC,GAAA,EAAAxD,EAAA,iBAAA,CAEI,OAEA,YACA,MAAA,CTmjBM,WAAY,EAAE,CACd,oBS5hBL,CAnBN,KAUY,QAAA,CTsiBD,MAAO,EAAE,CS5iBjB,OAAoB,EAAM,CT8iBrB,CACD,MAAO,CAAC,oBAAoB,CAC5B,MAAM,EAAG,CS7iBWmD,KAAAA,GAAO,CAArB,IAAA7C,EAAA,EAAAL,GAAA,EAAAD,EAAA,KAAAM,EAAA,WAAA,ET+iBD,ES9iBTN,EAA4B,WAAAM,EAAA,eAAA,CT+iBhB,EAAE,MAAQA,EAAE,YACd,CACF,IAAIJ,EAAI,EAAGE,MAAU,CS3iBzBF,EAAA,oBAAAD,EAAA,MAAA,EAEF,OACF,EAAA,MAAa,EAAAD,EAAA,YAAA,EAAA,EAAAA,EAAA,oBAAA,MAAAuD,EAAA,EAAA,EAAAvD,EAAA,aAAAU,EAAA,GAAA,EAAAV,EAAA,YAAA,EAAA,MAAA,CT4iBG,iBAAkB,EAAE,MAAQ,EAAGA,EAAM,WAAW,EAAGA,EAAM,eAAgB,GAAM,EAAE,MAAQ,EAAE,WAAY,CAAC,OAAO,CAAC,CAAE,CAAC,MAAM,CAAC,CAC1H,WAAY,EAAGA,EAAM,WAAW,EAAGA,EAAM,eAAeI,EAAG,CAAC,OAAO,CAAC,CAAE,CAAC,QAAQ,CAAC,CAChF,WAAYH,EAAE,MACd,sBAAuB,EAAE,KAAQ,GAAM,EAAE,MAAQ,EACpD,CAAC,EAAG,EAAGD,EAAM,aAAa,CAAE,EAAG,EAAG,CAAE,CAAC,EAAE,OAAO,QAAU,CACjD,KAAM,UACN,IAAK,EAAGA,EAAM,aAAe,EAAE,EAAGA,EAAM,YAAY,EAAE,OAAQ,UAAU,CAAC,CAAC,CAC1E,IAAK,IACR,CAAG,IAAK,GAAE,CAAC,CAAE,KAAM,CAAC,YAAa,aAAa,CAAC,CAAEC,EAAE,QAAU,EAAE,YAAc,EAAE,sBAAwB,EAAGD,EAAM,YAAY,EAAG,EAAGA,EAAM,aAAaU,EAAwB,GAAI,EAAGV,EAAM,YAAY,CACvM,IAAK,EACL,KAAM,IACN,QAAS,OACZ,CAAE,EAAE,OAAQ,CAAE,QAASI,EAAG,CAAC,CAAE,KAAM,GAAG,GAAK,EAAGJ,EAAM,oBAAoB,GAAI,CAAC,EAAE,CAAC,CAAC,GAE7F,CAAC,CAAEyD,GAAqB,EAAGzD,EAAM,iBAAiB,CU3lBjD,OAAwC,cAUxC,OAAa,EAAAA,EAAA,aAAA,CACM,WAAgB,EAAA,CAE9B,MAAc,EAAA,CAmBpB,KAAW,CAAA,QAAO,IAAA,CAEV,cAAiB,CAAA,KAAK,QAAQ,CVgkB/B,QAAS,CAAE,KU1gBhB,QAAA,CV2gBE,CAAE,CU5jBL,WAAA,CAAA,SAAA,CAAA,EAAA,CACE,eAAA,EAAA,CV8jBC,CAAC,CACF,MAAO,CAAC,oBAAoB,CAC5B,MAAM,EAAG,CACL,IAAI,GUjkBqJ,EAAAA,EAAS,UAAA,EAAA,aAAA,CAAAM,EAAA,EAAAL,GAAA,EAAAD,EAAA,KAAA,KAAA,EVkkBjK,EAAGA,EUlkBsL,OAAA,MAAA,CVmkBtL,IAAI,EAAIM,EAAE,MAAM,IAAK,GAAM,EAAE,MAAM,CU3jB3B,MAAQ,QAAK,EAAA,MAAA,CAiBpB,EAAA,MAAA,KAAA,GAXE,CAAA,EAAA,SAAR,EAAA,CAAA,GALR,EAgBc,MAAA,EAAA,MAAA,OAAA,GAAA,EAAA,SAAA,EAAA,CAAA,EAAA,EAAA,SAAA,EAAA,MAAA,GAAA,EAAA,MAAA,EAAA,IAAA,IAAAL,EAAA,OAAA,cAAA,4BAAA,EAAA,gBAAA,EAfP,CAAA,UAAA,CAAA,EAAA,CAAA,CV4jBE,IAAI,EAAI,eU5jBkC,KAAA,QAAM,CV6jBhD,OAAQ,EAAG,MAAQ,EAAGD,EAAM,YAAY,EAAG,EAAGA,EAAM,oBAAoB,MAAO,CAC3E,QAAS,QUzjBZ,IAAAC,EV2jBG,OAAQ,EAAGD,EAAM,gBU3jBf,CACD,kBAAA,CAAA,GACA,iCAAA,OAAA,EAAA,cAAA,EAAA,CAAA,EACG,wBAAA,CAAA,GACf,YAAA,EAAA,MAAA,CAAA,CAAA,EAAA,KACe,YAAK,EAAA,QV4jBR,CAAA,CU1jBF,CAAA,CAAA,MAAA,QAAA,EAAA,MAAA,GAAA,EAAAA,EAAA,WAAA,CAAA,EAAA,EAAA,EAAAA,EAAA,oBAAAA,EAAA,SAAA,CAAA,IAAA,EAAA,EAAA,EAAAA,EAAA,YAAA,EAAA,MAAA,KAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,aAAAU,EAAA,EAAA,CACP,OAAU,EAAAV,EAAA,gBAAA,CV4jBM,gCAAiC,EAAE,MAAM,SAASM,EAAE,MAAM,CAC1D,uBAAwB,CAAC,EAC5B,CAAC,CACF,WAAY,EAAE,MACd,sBAAuB,EAAE,KAAQ,GAAM,EAAE,MAAQ,EACjD,MAAOA,EAAE,MACT,MAAOA,EAAE,MACT,SAAUA,EAAE,SACZ,QAAS,EAAE,QACX,gBU9iBNA,EAAA,KAhBJ,EAAA,EAAAN,EAAA,aAAA,CAAA,EAAA,EAAA,CAAA,CAAAM,EAAA,MAAA,CVgkBc,KAAM,UACN,IAAK,EAAGN,EAAM,aAAe,EAAE,EAAGA,EAAM,kBAAkB,EAAGA,EAAM,iBAAiBM,EAAE,MAAM,CAAE,EAAE,CAAC,CAAC,CAClG,IAAK,IU7jBhB,CAAA,IAAA,GAAA,CAAA,CAAA,KAAA,CV+jBO,QU9jBf,aACY,QACA,QACG,WACf,UACe,gBVgkBH,CU9jBY,EAAK,CAAA,IAAA,IAAA,EAAAN,EAAA,WAAA,CAAA,EAAA,EAAA,EAAAA,EAAA,oBAAAA,EAAA,SAAA,CAAA,IAAA,EAAA,EAAA,EAAAA,EAAA,YAAA,EAAA,MAAA,KAAA,EAAAA,EAAA,YAAA,EAAA,EAAAA,EAAA,aAAAU,EAAA,EAAA,CAAnB,OAAA,EAAAV,EAAA,gBAAA,CACF,gCAAKM,EAAA,QAAA,EAAA,MVgkBM,uBAAwB,CAAC,EAC5B,CAAC,CACF,WAAY,EAAE,MACd,sBAAuB,EAAE,KAAQ,GAAM,EAAE,MAAQ,EACjD,KAAM,EACN,MAAOA,EAAE,MACT,MAAOA,EAAE,MACT,SAAUA,EAAE,SACZ,QAAS,EAAE,QACX,gBAAiBA,EAAE,KACtB,EAAG,EAAGN,EAAM,aAAa,CAAE,EAAG,EAAG,CAAE,CAACM,EAAE,MAAQ,CACvC,KAAM,UACN,IAAK,EAAGN,EAAM,aAAe,EAAE,EAAGA,EAAM,kBAAkB,EAAGA,EAAM,iBAAiBM,EAAE,MAAM,CAAE,EAAE,CAAC,CAAC,CAClG,IAAK,IACR,CAAG,IAAK,GAAE,CAAC,CAAE,KAAM,CACpB,QACA,aACA,QACA,QACA,WACA,UACA,gBACH,CAAC,EAAE,CAAE,IAAI,EAAE,CAAE,EAAE,GAE3B,CAAC,CAAEoD,GAAsB,EAAG1D,EAAM,iBAAiB,CW7qBlD,OAAwC,aX+qBtC,OW9pBO,EAAAA,EAAA,aAAA,CARP,WAAA,EAAA,CXwqBI,MWvqBD,EAAA,CXwqBC,KAAM,EAAE,CWvqBV2D,cAAO,CAAA,KAAA,QAAA,CACRA,QAAO,CAAA,KAAA,QAAA,CACb,CAAA,CACSA,WAAO,CAAA,SAAA,CAAA,EAAA,CXyqBP,eAAgB,EAAC,CACpB,CAAC,CACF,MAAO,CAAC,oBAAoB,CAC5B,MAAM,EAAG,CACL,IAAI,GAAK,EAAG3D,EAAM,UAAU,EAAG,aAAa,CAC5C,OAAQ,EAAG,MAAQ,EAAGA,EAAM,YAAY,EAAG,EAAGA,EAAM,aAAayD,EAAG,CAChE,MAAO,iBACP,WAAY,EAAE,MACd,sBAAuB,EAAE,KAAQ,GAAM,EAAE,MAAQ,EACjD,MAAO,EAAE,OAAO,MAChB,KAAM,EAAE,OAAO,KACf,cAAe,EAAE,OAAO,cACxB,QAAS,EAAE,OAAO,QACrB,CAAE,CACC,SAAU,EAAGzD,EAAM,aAAe,EAAE,EAAGA,EAAM,YAAY,EAAE,OAAQ,UAAU,CAAC,CAAC,CAC/E,EAAG,EACN,CAAE,EAAG,CACF,aACA,QACA,OACA,gBACA,UACH,CAAC,GAET,CAAC,CAAE4D,GAAsB,EAAG5D,EAAM,iBAAiB,CY/sBlD,OAAwC,gBZitBtC,OYhsBO,EAAAA,EAAA,aAAA,CARP,WAAA,EAAA,CZ0sBI,MYzsBD,EAAA,CZ0sBC,KAAM,EAAE,CYzsBV2D,cAAO,CAAA,KAAA,QAAA,CACRA,QAAO,CAAA,KAAA,QAAA,CACb,CAAA,CACSA,WAAO,CAAA,SAAA,CAAA,EAAA,CZ2sBP,eAAgB,EAAC,CACpB,CAAC,CACF,MAAO,CAAC,oBAAoB,CAC5B,MAAM,EAAG,CACL,IAAI,GAAK,EAAG3D,EAAM,UAAU,EAAG,aAAa,CAC5C,OAAQ,EAAG,MAAQ,EAAGA,EAAM,YAAY,EAAG,EAAGA,EAAM,aAAayD,EAAG,CAChE,MAAO,oBACP,WAAY,EAAE,MACd,sBAAuB,EAAE,KAAQ,GAAM,EAAE,MAAQ,EACjD,MAAO,EAAE,OAAO,MAChB,KAAM,EAAE,OAAO,KACf,cAAe,EAAE,OAAO,cACxB,QAAS,EAAE,OAAO,QACrB,CAAE,CACC,SAAU,EAAGzD,EAAM,aAAe,EAAE,EAAGA,EAAM,YAAY,EAAE,OAAQ,UAAU,CAAC,CAAC,CAC/E,EAAG,EACN,CAAE,EAAG,CACF,aACA,QACA,OACA,gBACA,UACH,CAAC,GAET,CAAC,CAAE6D,EAAK,CAAC,gBAAgB,CAAEC,EAAK,CAAE,MAAO,gBAAiB,CAAEC,EAAK,CAC9D,IAAK,EACL,MAAO,iBACV,CAAEC,GAAsB,EAAGhE,EAAM,iBAAiB,CavuBpD,OAAA,OAIK,MAFN,CbwuBU,KAAM,EAAE,CACR,QAAS,CAAE,QAAS,UAAW,CAC/B,KAAM,CAAE,QAAS,UAAU,CAC9B,CACD,MAAM,EAAG,CACL,OAAQ,EAAG,MAAQ,EAAGA,EAAM,YAAY,EAAG,EAAGA,EAAM,oBAAoB,MAAO,CAC3E,OAAQ,EAAGA,EAAM,gBAAgB,CAC7B,WAAY,CAAC,GACZ,YAAc,EAAE,MAAO,CAAC,GACxB,oBAAsB,EAAE,SAAU,CAAC,EACvC,CAAC,CACF,gBAAiB,EAAE,KACtB,CAAE,EAAE,EAAGA,EAAM,oBAAoB,MAAO8D,EAAI,EAAE,EAAG9D,EAAM,YAAY,EAAE,OAAQ,UAAU,CAAC,CAAC,CAAE,EAAE,OAAO,aAAe,EAAGA,EAAM,YAAY,EAAG,EAAGA,EAAM,oBAAoB,OAAQ+D,EAAI,EAAE,EAAG/D,EAAM,YAAY,EAAE,OAAQ,aAAa,CAAC,CAAC,GAAK,EAAGA,EAAM,oBAAoB,GAAI,CAAC,EAAE,CAAC,CAAE,GAAI6D,EAAG,Gc7vBzR,CAAA,CAAAI,EAAQ,CdgwBX,IAAK,EACL,MAAO,acpvBP,CAAAC,EAFN,CAAA,MACI,mBAAK,CAAAC,EAAA,CAAA,YAAA,CAAAC,GAAA,EAAApE,EAAA,iBAAA,CAMF,OAAA,SAFN,MAAM,CACN,MAAQ,EAAA,CdqvBC,YAAa,EAAE,Cc7uBb,WAAA,EAAA,CAJX,CACC,MAAO,CAAA,SAAA,CdovBH,MAAM,EAAG,CAAE,KAAM,GAAK,CAClB,IAAIM,EAAI,EcnvBDL,GAAb,EAAAD,EAAA,KAAU,CAAA,EAAA,CAAAE,MAAA,CdovBA,EAAE,MAAQ,CAAC,EAAGI,EAAE,SAAS,EAE7B,OAAQ,EAAG,IAAML,EAAE,QAAU,EAAGD,EAAM,YAAY,EAAG,EAAGA,EAAM,oBAAoB,MAAOiE,EAAI,EACxF,EAAGjE,EAAM,oBAAoB,MAAOkE,GAAK,EAAGlE,EAAM,iBAAiB,EAAE,MAAM,CAAE,EAAE,EAC/E,EAAGA,EAAM,oBAAoB,MAAO,CACjC,MAAO,yBACP,UAAW,EAAE,YAChB,CAAE,KAAM,EAAGmE,EAAG,EACd,EAAGnE,EAAM,cAAc,EAAGA,EAAM,OAAOU,EAAwB,EAAE,CAAE,CAChE,KAAM,IACN,QAASR,EACZ,CAAE,CACC,SAAU,EAAGF,EAAM,aAAe,EAAE,EAAGA,EAAM,kBAAkB,EAAGA,EAAM,iBAAiB,EAAE,WAAW,CAAE,EAAE,CAAC,CAAC,CAC5G,EAAG,EACN,CAAA,CACJ,CAAC,GAAK,EAAGA,EAAM,oBAAoB,GAAI,CAAC,EAAE,EAElD,CAAC,CACF,EAAQ,EAAID,EACZ,EAAQ,EAAIuB,EACZ,EAAQ,EAAIC,EACZ,EAAQ,EAAIE,EACZ,EAAQ,EAAIiB,EACZ,EAAQ,EAAIW,EACZ,EAAQ,EAAIG,EACZ,EAAQ,EAAIE,EACZ,EAAQ,EAAIE,EACZ,EAAQ,EAAII,EACZ,EAAQ,EAAII,GACd","sourcesContent":["define([\"require\", \"exports\", \"./forms-3oS4Utyg.esm.js\", \"./field-CjkpGeA7.esm.js\", \"../utils/keyboard.js\", \"./popup-CAy1LTfy.esm.js\", \"vue\", \"./api-DW3Y93Lp.esm.js\"], function (require, exports, forms_3oS4Utyg_esm_js_1, field_CjkpGeA7_esm_js_1, keyboard_js_1, popup_CAy1LTfy_esm_js_1, vue_1) {\n \"use strict\";\n Object.defineProperty(exports, \"__esModule\", { value: true });\n exports.u = exports.t = exports.s = exports.r = exports.o = exports.n = exports.l = exports.i = exports.d = exports.c = exports.a = void 0;\n //#region src/components/formsExt/menu/menu.vue?vue&type=script&setup=true&lang.ts\n var K = {\n key: 0,\n class: \"top-menu_selectAll\"\n }, ee = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"menu\",\n props: /* @__PURE__ */ (0, vue_1.mergeModels)({\n modelValue: {},\n items: {},\n isMultiple: { type: Boolean },\n canBeEmptyMultiple: { type: Boolean },\n styling: { default: \"default\" },\n selectAllItem: {}\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: [\"update:modelValue\"],\n setup(e) {\n let r = e, i = (0, vue_1.useModel)(e, \"modelValue\"), a = (0, vue_1.ref)();\n !r.isMultiple && typeof i.value != \"string\" && typeof i.value != \"number\" && console.warn(\"Type check failed for prop \\\"modelValue\\\". Expected String: \" + typeof i.value), r.isMultiple && !Array.isArray(i.value) && console.warn(\"Type check failed for prop \\\"modelValue\\\". Expected Array: \" + typeof i.value), r.isMultiple && !r.canBeEmptyMultiple && Array.isArray(i.value) && !i.value.length && r.items[0] && (i.value = [r.items[0]?.href ?? r.items[0]?.value]);\n let o = (e) => Array.isArray(i.value) ? i.value.includes(e.value) : e.value === i.value, c = (e, t = !1) => {\n if (Array.isArray(i.value)) {\n let n = i.value.slice();\n if (t) {\n n.length || (n = r.items.map((e) => e.value));\n let t = n.indexOf(e.value);\n t === -1 ? n.push(e.value) : n.splice(t, 1);\n }\n else\n n = n.length === 1 && n[0] === e.value ? [] : [e.value];\n !r.canBeEmptyMultiple && !n.length && (n = [e.value]), i.value = n;\n return;\n }\n i.value = e.value;\n }, l = (e) => {\n if (a.value.scrollWidth <= a.value.offsetWidth || e.shiftKey || Math.abs(e.deltaY) < 50)\n return;\n e.preventDefault();\n let t = e.deltaY > 0 ? 30 : -30;\n a.value.scrollLeft = a.value.scrollLeft + t;\n }, u = (e = !0) => {\n let r = a.value.querySelector(\".top-active\");\n if (!r)\n return;\n let i = r.offsetLeft - a.value.offsetLeft - 24, o = r.offsetLeft - a.value.offsetLeft + r.clientWidth + 24, s = a.value.scrollLeft, c = a.value.clientWidth + a.value.scrollLeft, l;\n i < s && (l = i), o > c && (l = o - a.value.clientWidth), l !== void 0 && ((0, forms_3oS4Utyg_esm_js_1.G)() ? forms_3oS4Utyg_esm_js_1.O.$?.(a.value).animate({ scrollLeft: l }, e ? 200 : 0) : a.value.scrollTo({\n left: l,\n behavior: e ? \"smooth\" : \"auto\"\n }));\n }, d = () => {\n if (Array.isArray(i.value)) {\n if (i.value.length === r.items.length) {\n i.value = [r.items[0].href ?? r.items[0].value];\n return;\n }\n i.value = r.items.map((e) => e.href ?? e.value);\n }\n };\n return (0, vue_1.onMounted)(() => u(!1)), (0, vue_1.onUpdated)(() => u(!0)), (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n ref_key: \"el\",\n ref: a,\n class: (0, vue_1.normalizeClass)({\n \"top-menu\": !0,\n [\"top-style_\" + e.styling]: !0\n }),\n onWheel: l\n }, [((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, null, (0, vue_1.renderList)(e.items, (e) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_3oS4Utyg_esm_js_1.h, (0, vue_1.mergeProps)({ ref_for: !0 }, e, {\n class: \"top-menu_item\",\n color: \"theme\",\n onClick: (t) => c(e, t.ctrlKey || t.metaKey),\n isActive: o(e)\n }), (0, vue_1.createSlots)({ _: 2 }, [e.content ? {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.content), 1)]),\n key: \"0\"\n } : void 0]), 1040, [\"onClick\", \"isActive\"]))), 256)), Array.isArray(i.value) && e.selectAllItem ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", K, [(0, vue_1.createVNode)(forms_3oS4Utyg_esm_js_1.h, (0, vue_1.mergeProps)(e.selectAllItem, {\n class: \"top-menu_item\",\n color: \"theme\",\n styling: \"\",\n onClick: n[0] ||= (e) => d(),\n isActive: i.value.length === e.items.length\n }), (0, vue_1.createSlots)({ _: 2 }, [e.selectAllItem.content ? {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.selectAllItem.content), 1)]),\n key: \"0\"\n } : void 0]), 1040, [\"isActive\"])])) : (0, vue_1.createCommentVNode)(\"\", !0)], 34));\n }\n }), te = { class: \"top-selector2_itemMulti top-ellipsis\" }, ne = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"itemMulti\",\n props: {\n id: {},\n name: {}\n },\n emits: [\"delete\"],\n setup(e) {\n return (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", te, [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.name) + \" \", 1), (0, vue_1.createElementVNode)(\"span\", {\n class: \"top-selector2_itemMultiDelete\",\n \"data-top-icon\": \"\",\n onClick: n[0] ||= (n) => t.$emit(\"delete\", {\n id: e.id,\n name: e.name\n }),\n onMousedown: n[1] ||= (0, vue_1.withModifiers)(() => { }, [\"stop\"])\n }, null, 32)]));\n }\n }), q = /* @__PURE__ */ new Map(), J = (e) => {\n q.get(e)?.clear();\n }, Y = (e) => {\n let t = window.mo?.user?.id;\n return JSON.stringify(e.params) + \":\" + e.url + \":\" + t;\n }, X = (e, t) => q.get(t)?.get(e), re = (e, t, n) => {\n q.has(t) || q.set(t, /* @__PURE__ */ new Map()), q.get(t)?.set(e, n);\n }, ie = (e, t, n, i) => {\n let a = (0, vue_1.ref)([]), o = (0, vue_1.ref)(!1), s = (0, vue_1.ref)(0), c = \"\", l;\n e && !e.params.limit && (e.params.limit = 100);\n let u = async () => {\n if (!e)\n return;\n let t = i ? Y(e) : void 0;\n if (t) {\n let n = X(t, e.path);\n if (n)\n return e.abortByFingerprint(), n;\n }\n let n = await e.call();\n if (n.errors)\n return;\n if (!Array.isArray(n.result)) {\n console.warn(\"Array expected in `res.result`\");\n return;\n }\n let r = n.result.findIndex((e) => e.id === void 0 || e.name === void 0);\n if (r !== -1) {\n console.warn(`В result[${r}] нет id или name`);\n return;\n }\n return t && re(t, e.path, n), n;\n }, d = async (n) => {\n if (!e)\n return;\n if (n) {\n if (!l || o.value)\n return;\n e.params.offset = l;\n }\n else\n e.params.offset = 0;\n t?.(e, c), o.value = !0;\n let r = await u();\n o.value = !1, s.value++, r && (l = r.nextOffset, n ? a.value = a.value.concat(r.result) : a.value = r.result);\n }, f = (0, forms_3oS4Utyg_esm_js_1.P)(() => d(!1), 200);\n return {\n apiRequest: e,\n items: a,\n isLoading: o,\n countLoading: s,\n load: d,\n setSearchTextAndLoad: (t, r = !0) => {\n if (e) {\n if (t.length < n) {\n e.abortByFingerprint(), a.value = [];\n return;\n }\n t === c && a.value.length || (c = t, r ? f() : d(!1));\n }\n }\n };\n }, ae = 0, oe = null, Z = (e, t, n = !0) => n && t.id === null ? Array.isArray(e) ? e.some((e) => e.id === t.id && e.name === t.name) : t.name === e.name : Array.isArray(e) ? e.some((e) => e.id === t.id) : t.id === e.id, se = (e, t, n) => {\n let r = e.params.filters ?? [];\n r = r.filter((e) => e.name !== n), t && r.push((0, field_CjkpGeA7_esm_js_1.t)(n, \"CONTAINS\", [t])), e.changeParams({ filters: r });\n }, ce = (t, n, r, i, a, o, s, c, l, u, f, p, m) => {\n let h = (0, vue_1.ref)(\"\"), _ = {\n id: 0,\n name: (0, forms_3oS4Utyg_esm_js_1.E)().Common.All\n }, v = () => {\n h.value = \"\";\n }, y = () => !(!m.apiRequest || h.value.length >= p), b = (0, vue_1.computed)(() => {\n let e = [];\n return !i && a.value && (typeof a.value == \"string\" && (_.name = a.value), e.push(_)), r.value?.forEach((t) => e.push({ ...t })), e;\n }), x = (0, vue_1.ref)([]), S = () => {\n x.value = C();\n }, C = () => {\n let e = h.value.toLowerCase(), n = (0, keyboard_js_1.invertKeyboardLayout)(e), r = [], a, f = [], p = () => {\n f.at(-1)?.listItemProps?.type === \"delimiter\" && f.pop(), f.length &&= (a && r.push(a), r.push(...f), 0);\n };\n for (let t of b.value)\n switch (t.listItemProps?.type) {\n case \"title\":\n p(), a = t;\n break;\n case \"delimiter\":\n if (f.length) {\n let e = f.length;\n f.at(-1)?.listItemProps?.type === \"delimiter\" && e--, f[e] = t;\n }\n break;\n default:\n let r = u.value?.includes(\"id\"), i = t.name.toLowerCase(), o = u.value?.filter((e) => e !== \"id\").map((e) => typeof t[e] == \"string\" || typeof t[e] == \"number\" ? t[e] : \"\").join(\"☼\").toLowerCase();\n (r && t.id === Number(e) || o?.includes(e) || o?.includes(n)) && (i === e || i === n ? f.unshift(t) : f.push(t));\n }\n if (p(), r.push(...m.items.value), o.value && h.value && (!c.value || c.value(e)) && (s.value || !r.find((t) => t.name.toLowerCase() === e))) {\n let e = {\n id: null,\n name: h.value\n };\n l.value && (e.listItemProps = { closeByClick: !1 }), r.push(e);\n }\n return i && (r = r.filter((e) => !Z(t.value, e))), r;\n }, w = (e) => {\n e.listItemProps?.type === \"title\" || e.listItemProps?.type === \"delimiter\" || e.id === null && (n(\"appendItem\", e), l.value) || (i && Array.isArray(t.value) ? Z(t.value, e) || (t.value = [...t.value, e]) : t.value = e, setTimeout(() => {\n v();\n }));\n };\n if (m.apiRequest) {\n let e = [r, m.items];\n i && e.push(t), (0, vue_1.watch)(e, () => {\n S();\n });\n }\n else\n (0, vue_1.watch)([\n t,\n r,\n h\n ], () => {\n S();\n }, {\n immediate: !0,\n deep: 2\n });\n return {\n searchText: h,\n resetSearch: v,\n genIsShort: y,\n itemsForShow: x,\n selectItem: w,\n selectNextItem: () => {\n if (Array.isArray(t.value))\n return;\n let e = x.value.filter((e) => ![\"title\", \"delimiter\"].includes(e.listItemProps?.type ?? \"\"));\n t.value = { ...e[(e.findIndex((e) => e.id === t.value.id) + 1) % e.length] };\n },\n deleteItemByItem: async (e) => {\n Array.isArray(t.value) && (t.value = t.value.filter((t) => t.id !== e.id || t.name !== e.name));\n }\n };\n }, le = {\n key: 0,\n class: \"top-selector2_activeItems\"\n }, ue = {\n key: 1,\n class: \"top-selector2_activeName top-ellipsis\"\n }, de = {\n key: 2,\n class: \"top-selector2_placeholder top-ellipsis\"\n }, fe = { class: \"top-selector2_searchWidget\" }, pe = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"selector2\",\n props: /* @__PURE__ */ (0, vue_1.mergeModels)({\n modelValue: {},\n items: { default: () => [] },\n title: {},\n disabled: { type: Boolean },\n icon: {},\n modificator: {},\n size: { default: \"s\" },\n isError: { type: Boolean },\n openByFocusInput: {\n type: Boolean,\n default: void 0\n },\n searchType: { default: \"popup\" },\n searchFields: { default: () => [\"id\", \"name\"] },\n placeholder: {},\n hasCloserBtn: { type: Boolean },\n api: {},\n apiSetSearchParams: {},\n minLength: { default: 0 },\n useCache: { type: Boolean },\n appendSearchToResult: { type: Boolean },\n appendSearchAllowDuplicate: { type: Boolean },\n appendSearchToResultCond: {},\n appendWithoutSelect: { type: Boolean },\n multiselect: { type: Boolean },\n useAllItem: { type: [Boolean, String] },\n addChanger: { type: Boolean },\n buttonProps: {},\n selectedAsPlaceholder: { type: Boolean },\n openerShortcut: {}\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: /* @__PURE__ */ (0, vue_1.mergeModels)([\"appendItem\", \"open\"], [\"update:modelValue\"]),\n setup(e, { expose: t, emit: r }) {\n let i = e, a = (0, vue_1.useModel)(e, \"modelValue\"), o = r;\n t({ resetCache: (e = !1) => {\n c.apiRequest && (e && J(c.apiRequest.path), c.items.value = [], c.countLoading.value = 0, c.apiRequest.params.offset = 0, requestAnimationFrame(() => {\n u.itemsForShow.value = [];\n }), T()?.elPopup && c.setSearchTextAndLoad(u.searchText.value));\n } });\n let s = (0, vue_1.computed)(() => i.searchType === \"inline\" && i.multiselect || i.searchType === \"inline\" && forms_3oS4Utyg_esm_js_1.O.state.isMobile ? \"popup\" : i.searchType), c = ie(i.api, i.apiSetSearchParams, i.minLength, i.useCache), u = ce(a, o, (0, vue_1.toRef)(i, \"items\"), i.multiselect, (0, vue_1.toRef)(i, \"useAllItem\"), (0, vue_1.toRef)(i, \"appendSearchToResult\"), (0, vue_1.toRef)(i, \"appendSearchAllowDuplicate\"), (0, vue_1.toRef)(i, \"appendSearchToResultCond\"), (0, vue_1.toRef)(i, \"appendWithoutSelect\"), (0, vue_1.toRef)(i, \"searchFields\"), s, i.minLength, c), d = (0, vue_1.computed)(() => i.buttonProps ? \"TopButton\" : s.value === \"inline\" ? \"TopInput\" : \"div\"), w = (0, vue_1.ref)(null), T = () => w.value?.popup;\n c.apiRequest && (0, vue_1.watch)(u.searchText, () => {\n c.setSearchTextAndLoad(u.searchText.value);\n });\n let D = (0, vue_1.computed)(() => Array.isArray(a.value) || i.multiselect || !i.selectedAsPlaceholder && s.value !== \"inline\" ? i.placeholder : a.value?.name || i.placeholder), O = (e) => {\n let t = !1;\n switch (e.key) {\n case \"Delete\":\n case \"Backspace\":\n Array.isArray(a.value) && (e.preventDefault(), e.stopPropagation(), a.value.pop());\n break;\n case \"ArrowUp\":\n case \"ArrowRight\":\n case \"ArrowDown\":\n case \"ArrowLeft\":\n case \"Enter\":\n case \" \":\n t = !0;\n break;\n case \"Escape\":\n s.value === \"inline\" && u.resetSearch();\n break;\n }\n let n = e.key.length === 1 && !e.ctrlKey && !e.metaKey;\n (s.value === \"popup\" || s.value === \"inline\") && n && (t = !0), T()?.elPopup && (t = !1), t && (s.value === \"popup\" && (e.preventDefault(), e.stopPropagation(), n && (u.searchText.value || (u.searchText.value = e.key))), e.currentTarget?.click());\n }, k = (e) => {\n e.preventDefault(), u.selectNextItem();\n }, W = () => {\n c.apiRequest && c.setSearchTextAndLoad(u.searchText.value, !1), o(\"open\");\n }, G = () => {\n s.value === \"popup\" && u.searchText.value && u.resetSearch();\n }, K = (e) => {\n let t = e.target;\n t.scrollTop / (t.scrollHeight - t.offsetHeight) > .8 && c.load(!0);\n };\n return (t, r) => {\n let i = (0, vue_1.resolveComponent)(\"TopButton\"), o = (0, vue_1.resolveComponent)(\"TopLoadbar\"), g = (0, vue_1.resolveDirective)(\"top-focus\"), T = (0, vue_1.resolveDirective)(\"top-shortcut\");\n return (0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.unref)(popup_CAy1LTfy_esm_js_1.s), {\n ref_key: \"popupRef\",\n ref: w,\n onOpen: r[3] ||= (e) => W(),\n onClose: r[4] ||= (e) => G(),\n onScrollContentList: r[5] ||= (e) => (0, vue_1.unref)(c) ? K(e) : void 0,\n notch: !1,\n transitionDuration: 0,\n openByFocusInput: s.value === \"inline\" && (e.openByFocusInput ?? !0),\n disabled: s.value === \"inline\" && (0, vue_1.unref)(u).genIsShort()\n }, (0, vue_1.createSlots)({\n opener: (0, vue_1.withCtx)(() => [(0, vue_1.withDirectives)(((0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.resolveDynamicComponent)(d.value), (0, vue_1.mergeProps)(e.buttonProps, {\n class: {\n \"top-selector2\": !0,\n \"top-selector2-multiselect\": e.multiselect,\n [\"top-selector2-\" + e.modificator]: !!e.modificator,\n \"top-as-input\": !e.buttonProps && s.value !== \"inline\",\n \"top-as-selector\": !0,\n [\"top-size_\" + e.size]: !0,\n \"top-disabled\": e.disabled,\n \"top-forms-focusable\": !e.disabled,\n \"top-error\": e.isError\n },\n icon: e.icon,\n tabindex: \"0\",\n onKeydown: O,\n onBlur: r[0] ||= (e) => s.value === \"inline\" && (0, vue_1.unref)(u).resetSearch(),\n placeholder: D.value,\n title: e.title,\n captionType: s.value === \"inline\" && e.title !== void 0 ? \"top\" : void 0,\n modelValue: (0, vue_1.unref)(u).searchText.value,\n \"onUpdate:modelValue\": r[1] ||= (e) => (0, vue_1.unref)(u).searchText.value = e\n }), {\n default: (0, vue_1.withCtx)(() => [\n e.multiselect ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", le, [((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, null, (0, vue_1.renderList)(a.value, (e) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(ne, {\n id: e.id,\n name: e.name,\n onDelete: (0, vue_1.unref)(u).deleteItemByItem\n }, null, 8, [\n \"id\",\n \"name\",\n \"onDelete\"\n ]))), 256))])) : (0, vue_1.createCommentVNode)(\"\", !0),\n s.value !== \"inline\" && !e.multiselect ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"span\", ue, (0, vue_1.toDisplayString)(Array.isArray(a.value) ? \"\" : a.value.name), 1)) : (0, vue_1.createCommentVNode)(\"\", !0),\n e.multiselect && !a.value.length ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"span\", de, (0, vue_1.toDisplayString)(D.value), 1)) : (0, vue_1.createCommentVNode)(\"\", !0),\n e.addChanger && !e.buttonProps && !e.multiselect && (0, vue_1.unref)(u).itemsForShow.value.length > 1 && !e.disabled ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"span\", {\n key: 3,\n class: \"top-changer top-changer-selector\",\n \"data-top-popup-disabled\": \"true\",\n onClick: k\n })) : (0, vue_1.createCommentVNode)(\"\", !0)\n ]),\n _: 1\n }, 16, [\n \"class\",\n \"icon\",\n \"placeholder\",\n \"title\",\n \"captionType\",\n \"modelValue\"\n ])), [[\n g,\n e.isError,\n void 0,\n { onupdate: !0 }\n ], [T, e.openerShortcut]])]),\n contentList: (0, vue_1.withCtx)(() => [\n ((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, null, (0, vue_1.renderList)((0, vue_1.unref)(u).itemsForShow.value, (r) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.unref)(popup_CAy1LTfy_esm_js_1.o), (0, vue_1.mergeProps)({\n key: r.id ?? void 0,\n class: {\n \"top-active\": !Array.isArray(a.value) && !e.multiselect && a.value.id === r.id && a.value.name === r.name,\n \"top-selector2_item-all\": r.id === (0, vue_1.unref)(0),\n \"top-selector2_item-new\": r.id === (0, vue_1.unref)(null)\n },\n closeByClick: !e.multiselect || (0, vue_1.unref)(forms_3oS4Utyg_esm_js_1.O).state.isMobile\n }, { ref_for: !0 }, r.listItemProps, { onClick: (e) => (0, vue_1.unref)(u).selectItem(r) }), {\n default: (0, vue_1.withCtx)(() => [t.$slots.item ? (0, vue_1.renderSlot)(t.$slots, \"item\", {\n key: 0,\n item: r\n }) : ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(vue_1.Fragment, { key: 1 }, [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(r.name), 1)], 64))]),\n _: 2\n }, 1040, [\n \"class\",\n \"closeByClick\",\n \"onClick\"\n ]))), 128)),\n !(0, vue_1.unref)(u).itemsForShow.value.length && !(0, vue_1.unref)(u).genIsShort() ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.unref)(popup_CAy1LTfy_esm_js_1.o), {\n key: 0,\n type: \"regular\"\n }, {\n default: (0, vue_1.withCtx)(() => [!(0, vue_1.unref)(c).isLoading.value || (0, vue_1.unref)(c).countLoading.value ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(vue_1.Fragment, { key: 0 }, [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(t.$i18n.Common.No_results), 1)], 64)) : ((0, vue_1.openBlock)(), (0, vue_1.createBlock)((0, vue_1.unref)(forms_3oS4Utyg_esm_js_1.t), {\n key: 1,\n type: \"circles\"\n }))]),\n _: 1\n })) : (0, vue_1.createCommentVNode)(\"\", !0),\n (0, vue_1.unref)(c).countLoading.value && (0, vue_1.unref)(c).isLoading.value && s.value === \"inline\" ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(o, { key: 1 })) : (0, vue_1.createCommentVNode)(\"\", !0)\n ]),\n _: 2\n }, [s.value === \"popup\" ? {\n name: \"widget\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createElementVNode)(\"div\", fe, [(0, vue_1.withDirectives)((0, vue_1.createVNode)((0, vue_1.unref)(popup_CAy1LTfy_esm_js_1.a), {\n title: \"Поиск\",\n icon: \"\",\n modelValue: (0, vue_1.unref)(u).searchText.value,\n \"onUpdate:modelValue\": r[2] ||= (e) => (0, vue_1.unref)(u).searchText.value = e,\n isLoading: !!(0, vue_1.unref)(c).countLoading.value && (0, vue_1.unref)(c).isLoading.value,\n placeholder: D.value\n }, null, 8, [\n \"modelValue\",\n \"isLoading\",\n \"placeholder\"\n ]), [[\n g,\n a.value,\n void 0,\n { onupdate: !0 }\n ]]), e.hasCloserBtn && !t.$core.state.isMobile ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(i, {\n key: 0,\n class: \"closer\",\n color: \"theme\"\n }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(t.$i18n.Common.Cancel), 1)]),\n _: 1\n })) : (0, vue_1.createCommentVNode)(\"\", !0)])]),\n key: \"0\"\n } : void 0]), 1032, [\"openByFocusInput\", \"disabled\"]);\n };\n }\n }), me = { class: \"top-editArea_footer\" }, he = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"editArea\",\n props: {\n defaultValue: { default: \"\" },\n title: {},\n cancelText: { default: \"Cancel\" },\n submitText: { default: \"Send\" },\n closeText: { default: \"Close\" },\n isFocused: { type: Boolean },\n forceShowCloseBtn: { type: Boolean },\n attachToKeyboard: { type: Boolean },\n modelValue: {},\n name: {},\n placeholder: {},\n styling: {},\n rows: {},\n minHeight: {},\n expandable: {\n type: Boolean,\n default: !0\n },\n disabled: { type: Boolean },\n readonly: { type: Boolean },\n isError: { type: Boolean },\n hint: {},\n maxLength: {}\n },\n emits: [\n \"submit\",\n \"close\",\n \"clickOnTitle\"\n ],\n setup(e, { emit: t }) {\n let n = e, r = t, i = (0, vue_1.ref)(n.defaultValue), a = (0, vue_1.ref)(n.isFocused), o = (0, vue_1.computed)(() => i.value !== n.defaultValue), l = (e) => {\n r(\"submit\", e), i.value = n.defaultValue;\n }, u = () => {\n if (n.forceShowCloseBtn && !o.value) {\n r(\"close\");\n return;\n }\n i.value = n.defaultValue;\n }, d = () => {\n n.attachToKeyboard && r(\"clickOnTitle\");\n };\n return (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", { class: (0, vue_1.normalizeClass)({\n \"top-editArea\": !0,\n \"top-editArea-attachedToKeyboard\": e.attachToKeyboard\n }) }, [e.title || t.$slots.caption ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n key: 0,\n class: \"top-editArea_caption\",\n onClick: n[0] ||= (e) => d()\n }, [(0, vue_1.renderSlot)(t.$slots, \"caption\", {}, () => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.title), 1)])])) : (0, vue_1.createCommentVNode)(\"\", !0), (0, vue_1.createElementVNode)(\"div\", { class: (0, vue_1.normalizeClass)({\n \"top-editArea_form\": !0,\n \"top-forms-focusable\": !0,\n \"top-as-input\": !0,\n \"top-error\": e.isError,\n \"top-focus\": a.value\n }) }, [(0, vue_1.createVNode)(forms_3oS4Utyg_esm_js_1.r, {\n modelValue: i.value,\n \"onUpdate:modelValue\": n[1] ||= (e) => i.value = e,\n name: e.name,\n placeholder: e.placeholder,\n rows: e.rows,\n minHeight: e.minHeight,\n expandable: e.expandable,\n disabled: e.disabled,\n readonly: e.readonly,\n isError: e.isError,\n hint: e.hint,\n class: \"top-editArea_element\",\n onFocus: n[2] ||= () => a.value = !0,\n onBlur: n[3] ||= () => a.value = !1,\n onKeyup: [(0, vue_1.withKeys)(u, [\"esc\"]), n[4] ||= (0, vue_1.withKeys)((0, vue_1.withModifiers)((e) => l(i.value), [\"ctrl\"]), [\"enter\"])]\n }, null, 8, [\n \"modelValue\",\n \"name\",\n \"placeholder\",\n \"rows\",\n \"minHeight\",\n \"expandable\",\n \"disabled\",\n \"readonly\",\n \"isError\",\n \"hint\"\n ]), (0, vue_1.createElementVNode)(\"div\", me, [o.value || e.forceShowCloseBtn ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_3oS4Utyg_esm_js_1.h, {\n key: 0,\n icon: t.$core.state.isMobile ? \"\" : \"\",\n class: \"top-editArea_button\",\n color: \"theme\",\n styling: \"soft\",\n onClick: u\n }, (0, vue_1.createSlots)({ _: 2 }, [t.$core.state.isMobile ? void 0 : {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.cancelText), 1)]),\n key: \"0\"\n }]), 1032, [\"icon\"])) : (0, vue_1.createCommentVNode)(\"\", !0), o.value ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_3oS4Utyg_esm_js_1.h, {\n key: 1,\n class: \"top-editArea_button\",\n icon: t.$core.state.isMobile ? \"\" : \"\",\n onClick: n[5] ||= (e) => l(i.value)\n }, (0, vue_1.createSlots)({ _: 2 }, [t.$core.state.isMobile ? void 0 : {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.submitText), 1)]),\n key: \"0\"\n }]), 1032, [\"icon\"])) : (0, vue_1.createCommentVNode)(\"\", !0)])], 2)], 2));\n }\n }), ge = { class: \"top-editInput\" }, Q = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"editInput\",\n props: {\n modelValue: {},\n alwaysShowSubmitBtn: { type: Boolean },\n input: {},\n button: {}\n },\n emits: [\"update:modelValue\"],\n setup(e, { emit: t }) {\n let n = e, r = (0, vue_1.ref)(n.modelValue);\n (0, vue_1.watch)(() => n.modelValue, () => {\n r.value = n.modelValue;\n });\n let i = t, o = () => {\n i(\"update:modelValue\", r.value);\n };\n return (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", ge, [(0, vue_1.createVNode)(forms_3oS4Utyg_esm_js_1.c, (0, vue_1.mergeProps)(e.input, {\n onKeydownCapture: n[0] ||= (0, vue_1.withKeys)((0, vue_1.withModifiers)((t) => r.value = e.modelValue, [\"stop\"]), [\"esc\"]),\n onKeydown: (0, vue_1.withKeys)((0, vue_1.withModifiers)(o, [\"stop\"]), [\"enter\"]),\n modelValue: r.value,\n \"onUpdate:modelValue\": n[1] ||= (e) => r.value = e\n }), (0, vue_1.createSlots)({ _: 2 }, [t.$slots.caption ? {\n name: \"caption\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.renderSlot)(t.$slots, \"caption\")]),\n key: \"0\"\n } : void 0]), 1040, [\"onKeydown\", \"modelValue\"]), r.value !== e.modelValue || e.alwaysShowSubmitBtn ? ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_3oS4Utyg_esm_js_1.h, (0, vue_1.mergeProps)({\n key: 0,\n icon: \"\",\n styling: \"soft\"\n }, e.button, { onClick: o }), null, 16)) : (0, vue_1.createCommentVNode)(\"\", !0)]));\n }\n }), $ = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"optionGroup\",\n props: /* @__PURE__ */ (0, vue_1.mergeModels)({\n modelValue: {},\n items: {},\n size: { default: \"s\" },\n showIndicator: { type: Boolean },\n isError: { type: Boolean }\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: [\"update:modelValue\"],\n setup(e) {\n let t = (0, vue_1.useModel)(e, \"modelValue\"), n = e, r = (0, vue_1.ref)(null);\n (0, vue_1.watch)(t, () => {\n let e = n.items.map((e) => e.value);\n Array.isArray(t.value) ? t.value.find((t) => !e.includes(t)) && (t.value = t.value.filter((t) => e.includes(t))) : e.includes(t.value) || (t.value = e[0] ?? \"\"), r.value?.querySelector(\".radioGroup_item-selected\")?.scrollIntoView();\n }, { immediate: !0 });\n let a = \"optionGroup-\" + Math.random();\n return (n, s) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n ref_key: \"elRef\",\n ref: r,\n class: (0, vue_1.normalizeClass)({\n \"top-optionGroup\": !0,\n [\"top-optionGroup-showIndicator_\" + Number(e.showIndicator)]: !0,\n \"top-scrollBarXHidding\": !0,\n [\"top-size_\" + e.size]: !!e.size,\n \"top-error\": e.isError\n })\n }, [Array.isArray(t.value) ? ((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, { key: 0 }, (0, vue_1.renderList)(e.items, (n) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_3oS4Utyg_esm_js_1.f, {\n class: (0, vue_1.normalizeClass)({\n \"top-optionGroup_item-selected\": t.value.includes(n.value),\n \"top-optionGroup_item\": !0\n }),\n modelValue: t.value,\n \"onUpdate:modelValue\": s[0] ||= (e) => t.value = e,\n value: n.value,\n title: n.title,\n disabled: n.disabled,\n isError: e.isError,\n \"data-top-icon\": n.icon\n }, (0, vue_1.createSlots)({ _: 2 }, [n.label ? {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(n.label), 1)]),\n key: \"0\"\n } : void 0]), 1032, [\n \"class\",\n \"modelValue\",\n \"value\",\n \"title\",\n \"disabled\",\n \"isError\",\n \"data-top-icon\"\n ]))), 256)) : ((0, vue_1.openBlock)(!0), (0, vue_1.createElementBlock)(vue_1.Fragment, { key: 1 }, (0, vue_1.renderList)(e.items, (n) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)(forms_3oS4Utyg_esm_js_1.a, {\n class: (0, vue_1.normalizeClass)({\n \"top-optionGroup_item-selected\": n.value === t.value,\n \"top-optionGroup_item\": !0\n }),\n modelValue: t.value,\n \"onUpdate:modelValue\": s[1] ||= (e) => t.value = e,\n name: a,\n value: n.value,\n title: n.title,\n disabled: n.disabled,\n isError: e.isError,\n \"data-top-icon\": n.icon\n }, (0, vue_1.createSlots)({ _: 2 }, [n.label ? {\n name: \"default\",\n fn: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(n.label), 1)]),\n key: \"0\"\n } : void 0]), 1032, [\n \"class\",\n \"modelValue\",\n \"value\",\n \"title\",\n \"disabled\",\n \"isError\",\n \"data-top-icon\"\n ]))), 256))], 2));\n }\n }), _e = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"radioGroup\",\n props: /* @__PURE__ */ (0, vue_1.mergeModels)({\n modelValue: {},\n items: {},\n size: {},\n showIndicator: { type: Boolean },\n isError: { type: Boolean }\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: [\"update:modelValue\"],\n setup(e) {\n let t = (0, vue_1.useModel)(e, \"modelValue\");\n return (e, n) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)($, {\n class: \"top-radioGroup\",\n modelValue: t.value,\n \"onUpdate:modelValue\": n[0] ||= (e) => t.value = e,\n items: e.$props.items,\n size: e.$props.size,\n showIndicator: e.$props.showIndicator,\n isError: e.$props.isError\n }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.renderSlot)(e.$slots, \"default\")]),\n _: 3\n }, 8, [\n \"modelValue\",\n \"items\",\n \"size\",\n \"showIndicator\",\n \"isError\"\n ]));\n }\n }), ve = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"checkboxGroup\",\n props: /* @__PURE__ */ (0, vue_1.mergeModels)({\n modelValue: {},\n items: {},\n size: {},\n showIndicator: { type: Boolean },\n isError: { type: Boolean }\n }, {\n modelValue: { required: !0 },\n modelModifiers: {}\n }),\n emits: [\"update:modelValue\"],\n setup(e) {\n let t = (0, vue_1.useModel)(e, \"modelValue\");\n return (e, n) => ((0, vue_1.openBlock)(), (0, vue_1.createBlock)($, {\n class: \"top-checkboxGroup\",\n modelValue: t.value,\n \"onUpdate:modelValue\": n[0] ||= (e) => t.value = e,\n items: e.$props.items,\n size: e.$props.size,\n showIndicator: e.$props.showIndicator,\n isError: e.$props.isError\n }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.renderSlot)(e.$slots, \"default\")]),\n _: 3\n }, 8, [\n \"modelValue\",\n \"items\",\n \"size\",\n \"showIndicator\",\n \"isError\"\n ]));\n }\n }), ye = [\"data-top-icon\"], be = { class: \"top-info_text\" }, xe = {\n key: 0,\n class: \"top-info_value\"\n }, Se = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"info\",\n props: {\n icon: {},\n styling: { default: \"default\" },\n size: { default: \"default\" }\n },\n setup(e) {\n return (t, n) => ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", {\n class: (0, vue_1.normalizeClass)({\n \"top-info\": !0,\n [\"top-size_\" + e.size]: !0,\n [\"top-info-styling_\" + e.styling]: !0\n }),\n \"data-top-icon\": e.icon\n }, [(0, vue_1.createElementVNode)(\"div\", be, [(0, vue_1.renderSlot)(t.$slots, \"default\")]), t.$slots.additional ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"span\", xe, [(0, vue_1.renderSlot)(t.$slots, \"additional\")])) : (0, vue_1.createCommentVNode)(\"\", !0)], 10, ye));\n }\n }), Ce = {\n key: 0,\n class: \"top-policy\"\n }, we = { class: \"top-policy_title\" }, Te = [\"innerHTML\"], Ee = /* @__PURE__ */ (0, vue_1.defineComponent)({\n __name: \"policy\",\n props: {\n title: {},\n description: {},\n acceptText: {}\n },\n emits: [\"accept\"],\n setup(e, { emit: t }) {\n let n = t, r = (0, vue_1.ref)(!0), i = () => {\n r.value = !1, n(\"accept\");\n };\n return (t, n) => r.value ? ((0, vue_1.openBlock)(), (0, vue_1.createElementBlock)(\"div\", Ce, [\n (0, vue_1.createElementVNode)(\"div\", we, (0, vue_1.toDisplayString)(e.title), 1),\n (0, vue_1.createElementVNode)(\"div\", {\n class: \"top-policy_description\",\n innerHTML: e.description\n }, null, 8, Te),\n (0, vue_1.createVNode)((0, vue_1.unref)(forms_3oS4Utyg_esm_js_1.h), {\n size: \"m\",\n onClick: i\n }, {\n default: (0, vue_1.withCtx)(() => [(0, vue_1.createTextVNode)((0, vue_1.toDisplayString)(e.acceptText), 1)]),\n _: 1\n })\n ])) : (0, vue_1.createCommentVNode)(\"\", !0);\n }\n });\n exports.d = ee;\n exports.c = ae;\n exports.l = oe;\n exports.u = se;\n exports.s = pe;\n exports.o = he;\n exports.a = Q;\n exports.i = _e;\n exports.r = ve;\n exports.n = Se;\n exports.t = Ee;\n});\n//# sourceMappingURL=formsExt-CdLb48ea.esm.js.map\n","<script setup lang=\"ts\">\nimport { onMounted, onUpdated, ref } from 'vue';\nimport type { Item, Props } from './types';\nimport Core from '@/core/core/core';\nimport { isSafari } from '@/core/utils/device';\nimport TopButton from '@/components/forms/button/button.vue';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tstyling: 'default',\n});\n\nconst model = defineModel({\n\trequired: true,\n});\n\nconst el = ref();\n\n// валидация типа modelValue без возможности выбора нескольких значений (ожидается строка или число)\nif (!props.isMultiple && typeof (model.value) !== 'string' && typeof (model.value) !== 'number') {\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected String: ' + typeof (model.value));\n}\n\n// валидация типа modelValue с возможностью выбора нескольких значений (ожидается массив)\nif (props.isMultiple && !Array.isArray(model.value)) {\n\tconsole.warn('Type check failed for prop \"modelValue\". Expected Array: ' + typeof (model.value));\n}\n\n/**\n * Для множественного выбора без пустого множества\n *\n * Если ничего не выбрано, присваиваем 1-ое значение\n */\nif (props.isMultiple && !props.canBeEmptyMultiple && Array.isArray(model.value) && !model.value.length && props.items[0]) {\n\tmodel.value = [props.items[0]?.href ?? props.items[0]?.value];\n}\n\nconst itemIsActive = (item: Item) => {\n\tif (!Array.isArray(model.value)) {\n\t\treturn item.value === model.value;\n\t}\n\n\treturn model.value.includes(item.value);\n};\n\n/**\n * Выбрать элемент\n * @param item\n * @param toggle - добавить или исключить элемент, для isMultiple\n */\nconst select = (item: Item, toggle = false) => {\n\tif (Array.isArray(model.value)) {\n\t\tlet modelNew = model.value.slice();\n\n\t\tif (toggle) {\n\t\t\tif (!modelNew.length) modelNew = props.items.map(item => item.value);\n\n\t\t\tconst index = modelNew.indexOf(item.value);\n\t\t\tif (index === -1) {\n\t\t\t\tmodelNew.push(item.value);\n\t\t\t} else {\n\t\t\t\tmodelNew.splice(index, 1);\n\t\t\t}\n\t\t} else {\n\t\t\tif (modelNew.length === 1 && modelNew[0] === item.value) {\n\t\t\t\tmodelNew = [];\n\t\t\t} else {\n\t\t\t\tmodelNew = [item.value];\n\t\t\t}\n\t\t}\n\n\t\tif (!props.canBeEmptyMultiple && !modelNew.length) modelNew = [item.value];\n\n\t\tmodel.value = modelNew;\n\n\t\treturn;\n\t}\n\n\tmodel.value = item.value;\n};\n\n// вертикальный скролл в горизонтальный скролл\nconst onWheel = (event: WheelEvent) => {\n\tif (el.value.scrollWidth <= el.value.offsetWidth) return;\n\tif (event.shiftKey) return;\n\tif (Math.abs(event.deltaY) < 50) return; // устройство с высокой точностью, например тачпад\n\n\tevent.preventDefault();\n\n\tconst delta = event.deltaY > 0 ? 30 : -30;\n\tel.value.scrollLeft = el.value.scrollLeft + delta;\n};\n\n/**\n * Замена стандартному scrollIntoView, который меняет скролл документа\n *\n * Выравнивание по ближнему краю элемента\n *\n * Выравнивается таким образом, чтобы был виден соседний элемент\n */\nconst scrollIntoView = (isSmooth = true) => {\n\tconst elBtn = el.value.querySelector('.top-active');\n\tif (!elBtn) return;\n\n\tconst gap = 24;\n\n\t// левая и правая координаты элемента\n\tconst leftMargin = elBtn.offsetLeft - el.value.offsetLeft - gap;\n\tconst rightMargin = elBtn.offsetLeft - el.value.offsetLeft + elBtn.clientWidth + gap;\n\n\t// левая и правая границы видимой части меню\n\tconst leftMarginParent = el.value.scrollLeft;\n\tconst rightMarginParent = el.value.clientWidth + el.value.scrollLeft;\n\n\tlet scrollLeft: number | undefined = undefined;\n\n\t// левую границу элемента к левой границе меню\n\tif (leftMargin < leftMarginParent) scrollLeft = leftMargin;\n\n\t// правую границу элемента к правой границе меню\n\tif (rightMargin > rightMarginParent) scrollLeft = rightMargin - el.value.clientWidth;\n\n\tif (scrollLeft !== undefined) {\n\t\tif (isSafari()) {\n\t\t\tCore.$?.(el.value).animate({ scrollLeft: scrollLeft }, isSmooth ? 200 : 0);\n\t\t} else {\n\t\t\tel.value.scrollTo({ left: scrollLeft, behavior: isSmooth ? 'smooth' : 'auto' });\n\t\t}\n\t}\n};\n\n/**\n * Выбрать все элементы в меню\n */\nconst selectAll = () => {\n\tif (!Array.isArray(model.value)) return;\n\n\tif (model.value.length === props.items.length) {\n\t\tmodel.value = [props.items[0].href ?? props.items[0].value];\n\t\treturn;\n\t}\n\n\tmodel.value = props.items.map(item => item.href ?? item.value);\n};\n\nonMounted(() => scrollIntoView(false));\nonUpdated(() => scrollIntoView(true));\n\n</script>\n\n<template>\n\t<div\n\t\tref=\"el\"\n\t\t:class=\"{\n\t\t\t'top-menu': true,\n\t\t\t['top-style_' + styling]: true,\n\t\t\t// ['top-unwrap-x']: styling === 'default',\n\t\t}\"\n\t\t@wheel=\"onWheel\"\n\t>\n\t\t<TopButton\n\t\t\tv-for=\"item in items\"\n\t\t\t:=\"item\"\n\t\t\tclass=\"top-menu_item\"\n\t\t\tcolor=\"theme\"\n\t\t\t@click=\"select(item, $event.ctrlKey || $event.metaKey)\"\n\t\t\t:isActive=\"itemIsActive(item)\"\n\t\t>\n\t\t\t<template #default v-if=\"item.content\">\n\t\t\t\t{{ item.content }}\n\t\t\t</template>\n\t\t</TopButton>\n\n\t\t<div\n\t\t\tv-if=\"Array.isArray(model) && selectAllItem\"\n\t\t\tclass=\"top-menu_selectAll\"\n\t\t>\n\t\t\t<TopButton\n\t\t\t\t:=\"selectAllItem\"\n\t\t\t\tclass=\"top-menu_item\"\n\t\t\t\tcolor=\"theme\"\n\t\t\t\tstyling=\"\"\n\t\t\t\t@click=\"selectAll()\"\n\t\t\t\t:isActive=\"model.length === items.length\"\n\t\t\t>\n\t\t\t\t<template #default v-if=\"selectAllItem.content\">\n\t\t\t\t\t{{ selectAllItem.content }}\n\t\t\t\t</template>\n\t\t\t</TopButton>\n\t\t</div>\n\t</div>\n</template>\n\n<style>\n.top-menu {\n\t--scroll-thumb-color: var(--color-line-1);\n\t--scroll-thumb-color-hover: var(--color-line-2);\n\t--scroll-thumb-color-active: var(--color-line-3);\n\n\tmax-width: 100%;\n\tdisplay: flex;\n\talign-items: flex-start;\n\tgap: var(--top-gap-2);\n\toverflow-x: auto;\n\tscrollbar-width: none; /* firefox */\n\n\t/* предотвратить натинвые события браузера (назад / вперед) */\n\toverscroll-behavior-x: contain;\n}\n\n.top-menu::-webkit-scrollbar { display: none; }\n\n.top-menu .top-menu_item {\n\t--top-button-color: var(--color-text-2);\n\n\toutline-offset: -2px !important;\n\tmin-width: 0;\n\tmax-width: 200px;\n\tmargin: 0;\n\tflex-shrink: 0;\n}\n\n.top-menu .top-menu_item[data-top-icon] {\n\t--top-icon-color: var(--color-text-2);\n}\n\n.top-menu_selectAll {\n\tposition: sticky;\n\tright: 0;\n\tbackground: var(--color-layout-front-1);\n\tborder-left: 1px solid var(--color-line-1);\n\tpadding-left: var(--top-padding-1);\n\tbox-shadow: var(--color-layout-front-1) var(--top-padding-2) 0px;\n}\n\n/* style default */\n.top-menu.top-style_default .top-menu_item {\n\t--top-forms-radius: 0;\n\t--top-forms-border-color: transparent;\n\t--top-forms-border-width: 2px;\n\n\tfilter: none;\n\tbox-shadow: none;\n\tborder: none;\n\tborder-bottom: var(--top-forms-border-width) solid var(--top-forms-border-color);\n\tbackground: none;\n}\n\n.top-style_default > .top-menu_item > [data-top-badge] {\n\tmargin-top: 0;\n}\n\n.top-menu.top-style_default .top-menu_item:hover {\n\t--top-icon-color: var(--color-text-1);\n\t--top-button-color: var(--color-text-1);\n\t--top-forms-border-color: var(--color-line-2);\n}\n\n.top-menu.top-style_default .top-menu_item:active,\n.top-menu.top-style_default .top-menu_item.top-active {\n\t--top-icon-color: var(--color-text-primary);\n\t--top-button-color: var(--color-text-1);\n\t--top-forms-border-color: var(--color-line-primary-1);\n}\n\n.top-menu.top-style_default .top-menu_selectAll {\n\tpadding-left: var(--top-padding-2);\n}\n\n/* style bar */\n.top-menu.top-style_bar {\n\tborder-radius: var(--top-radius-3);\n\tborder: 1px solid var(--color-line-2);\n\tpadding: var(--top-padding-1);\n\tgap: 3px;\n}\n.top-menu.top-style_bar .top-menu_item {\n\t--top-button-background-color-hover: var(--color-layer-1);\n\t--top-button-background-color-active: var(--color-layer-2);\n\t--top-button-background-color-selected: var(--color-layer-primary-1);\n\n\tposition: relative;\n}\n\n.top-menu.top-style_bar .top-menu_item:hover {\n\t--top-icon-color: var(--color-text-1);\n\t--top-button-color: var(--color-text-1);\n}\n\n.top-menu.top-style_bar .top-menu_item.top-active {\n\t--top-icon-color: var(--color-text-primary);\n\t--top-button-color: var(--color-text-primary);\n}\n\n/* разделители кнопок в баре */\n.top-menu.top-style_bar .top-menu_item:not(:first-child):not(.top-active):not(:hover):after {\n\tcontent: \"\";\n\tbackground: var(--color-line-1-opacity);\n\twidth: 1px;\n\theight: 60%;\n\tdisplay: block;\n\tposition: absolute;\n\tleft: -2px;\n}\n.top-menu.top-style_bar .top-menu_item.top-active + .top-menu_item:after,\n.top-menu.top-style_bar .top-menu_item:hover + .top-menu_item:after {\n\tcontent: none !important;\n}\n\n/*\n.top-style_bar > .top-menu_item > [data-top-badge] {\n\tmargin-top: -3px;\n}\n*/\n\n/** TODO: .top-unwrap-x надо вынести глобально в UI или добавить в стили для storybook */\n/*\n.top-menu.top-unwrap-x {\n\tpadding-right: var(--top-unwrap-x);\n\tpadding-left: var(--top-unwrap-x);\n\tmargin-right: calc(0px - var(--top-unwrap-x));\n\tmargin-left: calc(0px - var(--top-unwrap-x));\n}\n*/\n</style>\n","<script setup lang=\"ts\">\nimport type { EmitsItemMulti, PropsItemMulti } from './types';\n\ndefineProps<PropsItemMulti>();\ndefineEmits<EmitsItemMulti>();\n</script>\n\n<template>\n\t<div class=\"top-selector2_itemMulti top-ellipsis\">\n\t\t{{ name }}\n\n\t\t<span\n\t\t\tclass=\"top-selector2_itemMultiDelete\"\n\t\t\tdata-top-icon=\"\"\n\t\t\t@click=\"$emit('delete', {id, name})\"\n\t\t\t@mousedown.stop\n\t\t></span>\n\t</div>\n</template>\n\n<style>\n.top-selector2_itemMulti {\n\tbox-sizing: border-box;\n\tpadding-left: var(--top-padding-2);\n\tborder-radius: var(--top-radius-1, 4px);\n\tborder: 1px solid var(--color-line-primary-1);\n\tbackground: var(--color-layer-primary-2);\n\tmin-height: 22px;\n\tmax-width: 100%;\n\tcolor: var(--color-text-1);\n\tflex-grow: 0;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tgap: var(--top-gap-1);\n}\n\n.top-selector2_itemMultiDelete {\n\t--top-icon-size: 14px;\n\t--top-icon-width: 18px;\n\t--top-icon-color: var(--color-text-1);\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\theight: 100%;\n\tcursor: pointer;\n}\n\n.top-selector2_itemMultiDelete:hover {\n\tbackground: var(--color-layer-primary-2);\n}\n\n@media screen and (min-width: 900px) {\n\t.top-selector2.top-active .top-selector2_itemMultiDelete {\n\t\tz-index: calc(var(--top-popup-z-index) + 1);\n\t}\n}\n</style>\n","import type { Props } from './types';\n\n/**\n * Список кешей для конкретного API метода\n */\nexport const cacheByMethod = new Map<Api.PathAbstract, Map<string, any>>();\n\n/**\n * Сброс кеша конкретного API метода\n */\nexport const clearCache = (apiPath: Api.PathAbstract) => {\n\tcacheByMethod.get(apiPath)?.clear();\n};\n\nexport const genCacheKey = (api: NonNullable<Props['api']>) => {\n\tconst userId = window['mo']?.user?.id;\n\n\tconst cacheKey = JSON.stringify(api.params) + ':' + api.url + ':' + userId;\n\n\treturn cacheKey;\n};\n\nexport const getCache = (cacheKey: string, apiPath: Api.PathAbstract) => {\n\treturn cacheByMethod.get(apiPath)?.get(cacheKey);\n};\n\nexport const setCache = (cacheKey: string, apiPath: Api.PathAbstract, data: any) => {\n\tif (!cacheByMethod.has(apiPath)) {\n\t\tcacheByMethod.set(apiPath, new Map());\n\t}\n\n\tcacheByMethod.get(apiPath)?.set(cacheKey, data);\n};\n","import { ref } from 'vue';\nimport { debounce } from '../../../../core/utils/lodash';\nimport type { Item, Props } from '../types';\nimport { genCacheKey, getCache, setCache } from '../cache';\n\nexport type API = ReturnType<typeof useAPI>;\n\nexport const useAPI = (\n\tapi: Props['api'],\n\tapiSetSearchParams: Props['apiSetSearchParams'],\n\tminLength: number,\n\tuseCache: Props['useCache'],\n) => {\n\t/**\n\t * Список, полученный через API\n\t */\n\tconst items = ref<Item[]>([]);\n\n\t/**\n\t * Флаг - идет загрузка\n\t */\n\tconst isLoading = ref(false);\n\n\tconst countLoading = ref(0);\n\n\tlet searchText = '';\n\tlet nextOffset: number | null | undefined;\n\n\tif (api && !api.params.limit) {\n\t\tapi.params.limit = 100;\n\t}\n\n\t/**\n\t * Выполнить обращение к API\n\t *\n\t * При ошибке вернет undefined\n\t */\n\tconst callAPI = async (): Promise<Api.ResponseSuccess<any, 'get'> | undefined> => {\n\t\tif (!api) return;\n\n\t\tconst cacheKey = useCache ? genCacheKey(api) : undefined;\n\n\t\tif (cacheKey) {\n\t\t\tconst cache = getCache(cacheKey, api.path);\n\t\t\tif (cache) {\n\t\t\t\t// остановить запущенные api запросы\n\t\t\t\tapi.abortByFingerprint();\n\n\t\t\t\treturn cache;\n\t\t\t}\n\t\t}\n\n\t\tconst res = await api.call();\n\n\t\tif (res.errors) return;\n\n\t\tif (!Array.isArray(res.result)) {\n\t\t\tconsole.warn('Array expected in `res.result`');\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst indexWithError = (res.result as Array<Item | any>).findIndex(item => item.id === undefined || item.name === undefined);\n\t\tif (indexWithError !== -1) {\n\t\t\tconsole.warn(`В result[${indexWithError}] нет id или name`);\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (cacheKey) {\n\t\t\tsetCache(cacheKey, api.path, res);\n\t\t}\n\n\t\treturn res as Api.ResponseSuccess<any, 'get'>;\n\t};\n\n\t/**\n\t * Загрузить items\n\t */\n\tconst load = async (append: boolean) => {\n\t\tif (!api) return;\n\n\t\tif (append) {\n\t\t\t// данных о следующих страницах не обнаружено\n\t\t\tif (!nextOffset) return;\n\n\t\t\t// дозагружать нельзя, если не завершена предыдущая загрузка\n\t\t\tif (isLoading.value) return;\n\n\t\t\tapi.params.offset = nextOffset;\n\t\t} else {\n\t\t\tapi.params.offset = 0;\n\t\t}\n\n\t\tapiSetSearchParams?.(api, searchText);\n\n\t\tisLoading.value = true;\n\t\tconst res = await callAPI();\n\t\tisLoading.value = false;\n\n\t\tcountLoading.value++;\n\n\t\tif (!res) return;\n\n\t\tnextOffset = res.nextOffset;\n\n\t\tif (append) {\n\t\t\titems.value = items.value.concat(res.result);\n\t\t} else {\n\t\t\titems.value = res.result;\n\t\t}\n\t};\n\n\tconst loadDebounce = debounce(() => load(false), 200);\n\n\t/**\n\t * Выполнить поиск по указанному тексту\n\t *\n\t * Если длина текста меньше minLength, поиск не будет произведен\n\t *\n\t * Если текст не изменился, поиск не будет произведен\n\t *\n\t * @param newSearchText - текст поиска\n\t * @param useDebounce - дедупликация загрузки списка\n\t */\n\tconst setSearchTextAndLoad = (newSearchText: string, useDebounce = true) => {\n\t\tif (!api) return;\n\n\t\t// остановить начатый поиск и сбросить результаты\n\t\tif (newSearchText.length < minLength) {\n\t\t\tapi.abortByFingerprint();\n\n\t\t\titems.value = [];\n\n\t\t\treturn;\n\t\t}\n\n\t\t// условия поиска не поменялись, данные загружены\n\t\tif (newSearchText === searchText && items.value.length) return;\n\n\t\tsearchText = newSearchText;\n\n\t\tif (useDebounce) {\n\t\t\tvoid loadDebounce();\n\t\t} else {\n\t\t\tvoid load(false);\n\t\t}\n\t};\n\n\treturn {\n\t\tapiRequest: api,\n\t\titems,\n\t\tisLoading,\n\t\tcountLoading,\n\t\tload,\n\t\tsetSearchTextAndLoad,\n\t};\n};\n","import type { Item, Props } from './types';\nimport { genFieldFilter } from '@/api/api';\n\n/**\n * Универсальный id для всех элементов \"Все элементы\" / \"Без фильтра\" в `TopSelector`\n */\nexport const ITEM_ID_ALL = 0;\n\n/**\n * Универсальный id для всех добавляемых элементов через `TopSelector`\n */\nexport const ITEM_ID_NEW = null;\n\n/**\n * Выбран ли элемент\n */\nexport const isSelected = (modelValue: Props['modelValue'], item: Item, checkNameForNullId = true) => {\n\tif (checkNameForNullId && item.id === ITEM_ID_NEW) {\n\t\tif (Array.isArray(modelValue)) {\n\t\t\treturn modelValue.some(itemSelected => itemSelected.id === item.id && itemSelected.name === item.name);\n\t\t} else {\n\t\t\treturn item.name === modelValue.name;\n\t\t}\n\t}\n\n\tif (Array.isArray(modelValue)) {\n\t\treturn modelValue.some(itemSelected => itemSelected.id === item.id);\n\t} else {\n\t\treturn item.id === modelValue.id;\n\t}\n};\n\n/**\n * Вспомогательная утилита для создания `callback` функции на добавление фильтра по полю в api запрос\n *\n * Другие фильтры по указанному полю будут удалены\n *\n * @param api - api, которое используется в `TopSelector`\n * @param search - введенная строка поиска\n * @param fieldName - имя поля, по которому надо добавить фильтр на поиск по нестрогому соответствию\n *\n * @todo Объединить с apiSetSearchParamsFilter() из @/components/project/projectSelector/utils.ts\n */\nexport const apiSetSearchParamsFilter = (api: NonNullable<Props['api']>, search: string, fieldName: string) => {\n\tlet filters = api.params.filters ?? [];\n\n\t// удаление других фильтров по этому полю\n\tfilters = filters.filter((filter) => filter.name !== fieldName);\n\n\tif (search) {\n\t\tfilters.push(genFieldFilter(fieldName, 'CONTAINS', [search]));\n\t}\n\n\tapi.changeParams({ filters });\n};\n","import { computed, type ComputedRef, ref, type Ref, watch } from 'vue';\nimport { invertKeyboardLayout } from '@/core/utils/keyboard';\nimport type { Item, Props } from '../types';\nimport { type API } from './useAPI';\nimport { isSelected, ITEM_ID_ALL, ITEM_ID_NEW } from '../utils';\nimport { useI18n } from '@/core/plugins/i18n';\n\n/**\n * Функционал поиска\n */\nexport const useMenu = (\n\tmodel: Ref<Props['modelValue']>,\n\temits: ReturnType<typeof defineEmits>,\n\titems: Ref<Props['items']>,\n\tmultiselect: Props['multiselect'],\n\tuseAllItem: Ref<Props['useAllItem']>,\n\tappendSearchToResult: Ref<Props['appendSearchToResult']>,\n\tappendSearchAllowDuplicate: Ref<Props['appendSearchAllowDuplicate']>,\n\tappendSearchToResultCond: Ref<Props['appendSearchToResultCond']>,\n\tappendWithoutSelect: Ref<Props['appendWithoutSelect']>,\n\tsearchFields: Ref<Props['searchFields']>,\n\tsearchType: Ref<Props['searchType']>,\n\tminLength: number,\n\tapi: API,\n) => {\n\t/**\n\t * Текст поиска по результатам\n\t */\n\tconst searchText = ref('');\n\n\t/**\n\t * Объект, представляющий опцию \"Все\"\n\t */\n\tconst itemAll = {\n\t\tid: ITEM_ID_ALL,\n\t\tname: useI18n().Common.All as string,\n\t};\n\n\t/**\n\t * Сброс поиска\n\t */\n\tconst resetSearch = () => {\n\t\tsearchText.value = '';\n\t};\n\n\t/**\n\t * Является ли строка поиска достаточной длины для отображения меню\n\t */\n\tconst genIsShort = () => {\n\t\tif (!api.apiRequest) return false;\n\t\tif (searchText.value.length >= minLength) return false;\n\n\t\treturn true;\n\t};\n\n\t/**\n\t * Варианты выбора: props.items + \"Выбрать все\"\n\t */\n\tconst localItems: ComputedRef<Item[]> = computed(() => {\n\t\tconst localItems: Item[] = [];\n\n\t\tif (!multiselect && useAllItem.value) {\n\t\t\tif (typeof useAllItem.value === 'string') {\n\t\t\t\titemAll.name = useAllItem.value;\n\t\t\t}\n\n\t\t\tlocalItems.push(itemAll);\n\t\t}\n\n\t\titems.value?.forEach(item => localItems.push({ ...item }));\n\n\t\treturn localItems;\n\t});\n\n\t/**\n\t * Не используем `computed` в пользу ручного порядка пересчета значения\n\t */\n\tconst itemsForShow = ref<Item[]>([]);\n\n\tconst recalcItemsForShow = () => {\n\t\titemsForShow.value = genItemsForShow();\n\t};\n\n\t/**\n\t * Подготовленный список меню, который содержит в сумме:\n\t * - prop.items: указанный список с учетом фильтра и опций компонента\n\t * - api.items: результаты api запроса, если используется api\n\t *\n\t * @returns Отфильтрованный массив элементов для отображения\n\t */\n\tconst genItemsForShow = () => {\n\t\tconst searchString = searchText.value.toLowerCase();\n\t\tconst searchStringInvertKeyboard = invertKeyboardLayout(searchString);\n\n\t\tlet items: Item[] = [];\n\n\t\t/**\n\t\t * Элемент текущего разделителя в цикле\n\t\t *\n\t\t * Для скрытия / отображения только нужных заголовков и разделителей при поиске\n\t\t *\n\t\t * Логика для `api.items` должна реализовываться в api или api клиенте при генерации элементов\n\t\t */\n\t\tlet itemTitleCategory: Item | undefined;\n\t\tconst itemsCategory: Item[] = [];\n\n\t\t/**\n\t\t * Добавить элементы в результирующий список\n\t\t */\n\t\tconst flushCategory = () => {\n\t\t\t// крайний разделитель не выводить\n\t\t\tif (itemsCategory.at(-1)?.listItemProps?.type === 'delimiter') {\n\t\t\t\titemsCategory.pop();\n\t\t\t}\n\n\t\t\tif (itemsCategory.length) {\n\t\t\t\tif (itemTitleCategory) {\n\t\t\t\t\titems.push(itemTitleCategory);\n\t\t\t\t}\n\n\t\t\t\titems.push(...itemsCategory);\n\n\t\t\t\titemsCategory.length = 0;\n\t\t\t}\n\t\t};\n\n\t\tfor (const item of localItems.value) {\n\t\t\tswitch (item.listItemProps?.type) {\n\t\t\t\tcase 'title':\n\t\t\t\t\tflushCategory();\n\n\t\t\t\t\titemTitleCategory = item;\n\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 'delimiter':\n\t\t\t\t\t// вставить разделитель один раз и только если категория не пуста\n\t\t\t\t\tif (itemsCategory.length) {\n\t\t\t\t\t\tlet index = itemsCategory.length;\n\t\t\t\t\t\tif (itemsCategory.at(-1)?.listItemProps?.type === 'delimiter') index--;\n\n\t\t\t\t\t\titemsCategory[index] = item;\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\tconst hasIdSearch = searchFields.value?.includes('id');\n\t\t\t\t\tconst name = item.name.toLowerCase();\n\n\t\t\t\t\tconst searchFieldsText = searchFields.value\n\t\t\t\t\t\t?.filter(field => field !== 'id')\n\t\t\t\t\t\t.map(field => typeof item[field] === 'string' || typeof item[field] === 'number' ? item[field] : '')\n\t\t\t\t\t\t.join('☼')\n\t\t\t\t\t\t.toLowerCase();\n\n\t\t\t\t\tif (\n\t\t\t\t\t\t(hasIdSearch && item.id === Number(searchString)) ||\n\t\t\t\t\t\tsearchFieldsText?.includes(searchString) ||\n\t\t\t\t\t\tsearchFieldsText?.includes(searchStringInvertKeyboard)\n\t\t\t\t\t) {\n\t\t\t\t\t\tif (name === searchString || name === searchStringInvertKeyboard) {\n\t\t\t\t\t\t\t// точные совпадения в начало\n\t\t\t\t\t\t\titemsCategory.unshift(item);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\titemsCategory.push(item);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tflushCategory();\n\n\t\titems.push(...api.items.value);\n\n\t\t// ввод произвольного значения\n\t\tif (\n\t\t\tappendSearchToResult.value &&\n\t\t\t!!searchText.value &&\n\t\t\t(!appendSearchToResultCond.value || appendSearchToResultCond.value(searchString)) &&\n\n\t\t\t// предложить добавить элемент, если нет точного совпадения или разрешены дубликаты\n\t\t\t(\n\t\t\t\tappendSearchAllowDuplicate.value ||\n\t\t\t\t!items.find((item) => item.name.toLowerCase() === searchString)\n\t\t\t)\n\t\t) {\n\t\t\tconst itemNew: Item = {\n\t\t\t\tid: ITEM_ID_NEW,\n\t\t\t\tname: searchText.value,\n\t\t\t};\n\n\t\t\tif (appendWithoutSelect.value) {\n\t\t\t\titemNew.listItemProps = { closeByClick: false }\n\t\t\t}\n\n\t\t\t// предложение всегда отображается внизу, чтобы не мешать результатам поиска\n\t\t\titems.push(itemNew);\n\t\t}\n\n\t\tif (multiselect) {\n\t\t\titems = items.filter(item => !isSelected(model.value, item));\n\t\t}\n\n\t\treturn items;\n\t};\n\n\t/**\n\t * Выбрать элемент\n\t *\n\t * @param item Элемент для выбора\n\t */\n\tconst selectItem = (item: Item) => {\n\t\t// это невыбираемый элемент\n\t\tif (item.listItemProps?.type === 'title' || item.listItemProps?.type === 'delimiter') {\n\t\t\treturn;\n\t\t}\n\n\t\tif (item.id === ITEM_ID_NEW) {\n\t\t\temits('appendItem', item);\n\n\t\t\tif (appendWithoutSelect.value) return;\n\t\t}\n\n\t\tif (multiselect && Array.isArray(model.value)) {\n\t\t\tif (!isSelected(model.value, item)) {\n\t\t\t\tmodel.value = [...model.value, item];\n\t\t\t}\n\t\t} else {\n\t\t\tmodel.value = item;\n\t\t}\n\n\t\t/**\n\t\t * Отложить перерисовку\n\t\t *\n\t\t * fix: Перерисовка меню выполняется раньше, чем срабатывает `click`.\n\t\t * Из-за этого обработчик кликов думает, что клик был вне меню и не закрывает окно\n\t\t *\n\t\t * Файл: @/components/popup/lib/popup.globalEvents.ts\n\t\t *\n\t\t * Функция: onclick()\n\t\t *\n\t\t * ```\n\t\t * const elPopup = e.target.closest<HTMLElement>('.top-popup-wrapper');\n\t\t * ```\n\t\t */\n\t\tsetTimeout(() => {\n\t\t\t/**\n\t\t\t * Завершить поиск после выбора\n\t\t\t */\n\t\t\tresetSearch();\n\t\t});\n\n\t\t// /**\n\t\t// * При изменении значения модели в режиме inline необходимо очистить поле поиска,\n\t\t// * так как поиск больше не актуален после выбора значения\n\t\t// */\n\t\t// if (searchType.value === 'inline') {\n\t\t// \tresetSearch();\n\t\t// }\n\t};\n\n\tif (api.apiRequest) {\n\t\t// загрузка только при открытии popup\n\t\tconst fieldsForWatch: any = [items, api.items];\n\n\t\t// model нужен только для multiselect, без необходимости не использовать для улучшения UX при работе с API\n\t\tif (multiselect) {\n\t\t\tfieldsForWatch.push(model);\n\t\t}\n\n\t\twatch(fieldsForWatch, () => {\n\t\t\trecalcItemsForShow();\n\t\t});\n\t} else {\n\t\twatch([model, items, searchText], () => {\n\t\t\trecalcItemsForShow();\n\t\t}, {\n\t\t\timmediate: true,\n\n\t\t\t// слежение за изменениями `items`\n\t\t\tdeep: 2,\n\t\t});\n\t}\n\n\t/**\n\t * Выбрать следующее значение\n\t */\n\tconst selectNextItem = () => {\n\t\tif (Array.isArray(model.value)) return;\n\n\t\tconst selectableItems = itemsForShow.value.filter((item) => !['title', 'delimiter'].includes(item.listItemProps?.type ?? ''));\n\n\t\tconst currentIndex = selectableItems.findIndex(item => item.id === (model.value as Item).id);\n\t\tconst nextIndex = (currentIndex + 1) % selectableItems.length;\n\t\tmodel.value = { ...selectableItems[nextIndex] };\n\t};\n\n\t/**\n\t * Удалить элемент, `id` и `name` которого равны указанному `item`\n\t */\n\tconst deleteItemByItem = async (item: Item) => {\n\t\tif (Array.isArray(model.value)) {\n\t\t\tmodel.value = model.value.filter((itemI) => itemI.id !== item.id || itemI.name !== item.name);\n\t\t}\n\t};\n\n\treturn {\n\t\tsearchText,\n\t\tresetSearch,\n\t\tgenIsShort,\n\t\titemsForShow,\n\t\tselectItem,\n\t\tselectNextItem,\n\t\tdeleteItemByItem,\n\t};\n};\n","<script setup lang=\"ts\">\nimport { computed, ref, toRef, watch } from 'vue';\nimport Core from '@/core/core/core';\nimport { TopPopup, TopPopupListItem, TopPopupWidgetInput } from '@/components/popup/popup';\nimport { TopPreloader } from '@/components/forms/forms';\nimport type { Emits, Item, Props, Slots } from './types';\nimport Selector2ItemMulti from './itemMulti.vue';\nimport { useAPI } from './composables/useAPI';\nimport { useMenu } from './composables/useMenu';\nimport type { TopLibPopup } from '../../popup/lib/popup';\nimport { clearCache } from './cache';\nimport { ITEM_ID_ALL, ITEM_ID_NEW } from './utils';\n\nconst props = withDefaults(defineProps<Props>(), {\n\titems: () => [] as Item[],\n\tsize: 's',\n\tminLength: 0,\n\tsearchType: 'popup',\n\topenByFocusInput: undefined,\n\tsearchFields: () => ['id', 'name'],\n});\n\nconst model = defineModel<Props['modelValue']>({ required: true });\n\ndefineSlots<Slots>();\n\nconst emits = defineEmits<Emits>();\n\ndefineExpose({\n\t/**\n\t * Сброс локального кеша и кеша api\n\t *\n\t * @param resetAPICache - Сбросить API кеш, по умолчанию не сбрасывается. Для случаев, когда загруженные данные становятся неактуальными\n\t */\n\tresetCache: (resetAPICache: boolean = false) => {\n\t\tif (!api.apiRequest) return;\n\n\t\t// сброс кеша api\n\t\tif (resetAPICache) {\n\t\t\tclearCache(api.apiRequest.path);\n\t\t}\n\n\t\t// сброс кеша списка\n\t\tapi.items.value = [];\n\n\t\t// сброс флага первичной загрузки\n\t\tapi.countLoading.value = 0;\n\n\t\t// сброс параметров дозагрузки\n\t\tapi.apiRequest.params.offset = 0;\n\n\t\t// сброс кеша локального списка с дополнительными элементами, например `useAllItem`\n\t\trequestAnimationFrame(() => {\n\t\t\tmenu.itemsForShow.value = [];\n\t\t});\n\n\t\t// сразу загрузить данные после сброса, если popup уже открыт\n\t\tif (getPopup()?.elPopup) {\n\t\t\tapi.setSearchTextAndLoad(menu.searchText.value);\n\t\t}\n\t},\n});\n\nconst searchTypeLocal = computed(() => {\n\t// multiselect не поддерживает inline ввода\n\tif (props.searchType === 'inline' && props.multiselect) return 'popup';\n\n\t// В мобильной версии popup работает в полноэкранном режиме\n\tif (props.searchType === 'inline' && Core.state.isMobile) return 'popup';\n\n\treturn props.searchType;\n});\n\n/**\n * Объект для работы с API\n */\nconst api = useAPI(props.api, props.apiSetSearchParams, props.minLength, props.useCache);\n\n/**\n * Объект для работы с меню\n */\nconst menu = useMenu(\n\tmodel,\n\temits,\n\ttoRef(props, 'items'),\n\tprops.multiselect,\n\ttoRef(props, 'useAllItem'),\n\ttoRef(props, 'appendSearchToResult'),\n\ttoRef(props, 'appendSearchAllowDuplicate'),\n\ttoRef(props, 'appendSearchToResultCond'),\n\ttoRef(props, 'appendWithoutSelect'),\n\ttoRef(props, 'searchFields'),\n\tsearchTypeLocal,\n\tprops.minLength,\n\tapi,\n);\n\nconst component = computed(() => {\n\tif (props.buttonProps) return 'TopButton';\n\tif (searchTypeLocal.value === 'inline') return 'TopInput';\n\n\treturn 'div';\n});\n\n/**\n * Экземпляр компонента Popup\n */\nconst popupRef = ref<any>(null);\n\n/**\n * Получить доступ к объекту popup\n */\nconst getPopup = (): TopLibPopup | undefined => {\n\treturn popupRef.value?.popup;\n};\n\nif (api.apiRequest) {\n\t// отложенный поиск при вводе текста\n\twatch(menu.searchText, () => {\n\t\tapi.setSearchTextAndLoad(menu.searchText.value);\n\t});\n}\n\nconst placeholder = computed(() => {\n\tif (Array.isArray(model.value) || props.multiselect || !props.selectedAsPlaceholder && searchTypeLocal.value !== 'inline') {\n\t\treturn props.placeholder;\n\t}\n\n\treturn model.value?.name || props.placeholder;\n});\n\n/**\n * Обработчик ввода клавиш на кнопке или поле ввода\n */\nconst onOpenerKeydown = (e: KeyboardEvent) => {\n\tlet needOpen = false;\n\n\tswitch (e.key) {\n\t\tcase 'Delete':\n\t\tcase 'Backspace':\n\t\t\tif (Array.isArray(model.value)) {\n\t\t\t\te.preventDefault();\n\t\t\t\te.stopPropagation();\n\n\t\t\t\tmodel.value.pop();\n\t\t\t}\n\n\t\t\tbreak;\n\t\tcase 'ArrowUp':\n\t\tcase 'ArrowRight':\n\t\tcase 'ArrowDown':\n\t\tcase 'ArrowLeft':\n\t\tcase 'Enter':\n\t\tcase ' ':\n\t\t\tneedOpen = true;\n\n\t\t\tbreak;\n\t\tcase 'Escape':\n\t\t\tif (searchTypeLocal.value === 'inline') {\n\t\t\t\t// очистка введенного текста\n\t\t\t\tmenu.resetSearch();\n\t\t\t}\n\n\t\t\tbreak;\n\t}\n\n\t// введен символ\n\tconst symbolPressed = e.key.length === 1 && !e.ctrlKey && !e.metaKey;\n\n\t// введен символ\n\tif (searchTypeLocal.value === 'popup' || searchTypeLocal.value === 'inline') {\n\t\tif (symbolPressed) {\n\t\t\tneedOpen = true;\n\t\t}\n\t}\n\n\t// popup уже открыт\n\tif (getPopup()?.elPopup) {\n\t\tneedOpen = false;\n\t}\n\n\tif (needOpen) {\n\t\tif (searchTypeLocal.value === 'popup') {\n\t\t\te.preventDefault();\n\t\t\te.stopPropagation();\n\n\t\t\t// введен символ\n\t\t\tif (symbolPressed) {\n\t\t\t\t// начало ввода, сразу ввести первый символ вместе с открытием popup\n\t\t\t\tif (!menu.searchText.value) {\n\t\t\t\t\tmenu.searchText.value = e.key;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t(e.currentTarget as HTMLElement)?.click();\n\t}\n};\n\nconst onClickChanger = (e: MouseEvent) => {\n\te.preventDefault();\n\n\tmenu.selectNextItem();\n};\n\n/**\n * Обработчик открытия попапа\n */\nconst onOpen = () => {\n\tif (api.apiRequest) {\n\t\t// при открытии сразу выполнить поиск\n\t\tapi.setSearchTextAndLoad(menu.searchText.value, false);\n\t}\n\n\temits('open');\n};\n\n/**\n * Обработчик закрытия попапа\n */\nconst onClose = () => {\n\t// очистка введенного текста, в режиме `inline` input вызывается при `blur`\n\tif (searchTypeLocal.value === 'popup') {\n\t\tif (menu.searchText.value) menu.resetSearch();\n\t}\n};\n\n/**\n * Обработчик прокрутки списка контента\n *\n * Для дозагрузки элеменов через api\n *\n * @param {Event} e - Событие прокрутки\n */\nconst onScrollContentList = (e: Event) => {\n\tconst el = e.target as HTMLElement;\n\n\tif (el.scrollTop / (el.scrollHeight - el.offsetHeight) > 0.8) {\n\t\tapi.load(true);\n\t}\n};\n\nif (import.meta.env.STORYBOOK) {\n\twatch(\n\t\t() => props.multiselect,\n\t\t() => {\n\t\t\tif (props.multiselect) {\n\t\t\t\tif (!Array.isArray(model.value)) {\n\t\t\t\t\tmodel.value = [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tid: 1,\n\t\t\t\t\t\t\tname: 'Выбери меня',\n\t\t\t\t\t\t},\n\t\t\t\t\t];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (Array.isArray(model.value)) {\n\t\t\t\t\tmodel.value = {\n\t\t\t\t\t\tid: null,\n\t\t\t\t\t\tname: '',\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t{ immediate: true },\n\t);\n\n\twatch(\n\t\t() => props.searchType,\n\t\t() => {\n\t\t\t// пауза для установки props в адресной строке\n\t\t\tsetTimeout(() => {\n\t\t\t\tlocation.reload();\n\t\t\t}, 500);\n\t\t},\n\t);\n}\n</script>\n\n<template>\n\t<TopPopup\n\t\tref=\"popupRef\"\n\t\t@open=\"onOpen()\"\n\t\t@close=\"onClose()\"\n\t\t@scrollContentList=\"api ? onScrollContentList($event) : undefined\"\n\t\t:notch=\"false\"\n\t\t:transitionDuration=\"0\"\n\t\t:openByFocusInput=\"searchTypeLocal === 'inline' && (openByFocusInput ?? true)\"\n\t\t:disabled=\"searchTypeLocal === 'inline' && menu.genIsShort()\"\n\t>\n\t\t<template #opener>\n\t\t\t<component\n\t\t\t\t:is=\"component\"\n\n\t\t\t\t:=\"buttonProps\"\n\n\t\t\t\t:class=\"{\n\t\t\t\t\t'top-selector2': true,\n\t\t\t\t\t'top-selector2-multiselect': multiselect,\n\t\t\t\t\t['top-selector2-' + modificator]: !!modificator,\n\t\t\t\t\t'top-as-input': !buttonProps && searchTypeLocal !== 'inline',\n\t\t\t\t\t'top-as-selector': true,\n\t\t\t\t\t['top-size_' + size]: true,\n\t\t\t\t\t['top-disabled']: disabled,\n\t\t\t\t\t['top-forms-focusable']: !disabled,\n\t\t\t\t\t['top-error']: isError,\n\t\t\t\t}\"\n\t\t\t\t:icon\n\t\t\t\ttabindex=\"0\"\n\t\t\t\t@keydown=\"onOpenerKeydown\"\n\t\t\t\t@blur=\"searchTypeLocal === 'inline' && menu.resetSearch()\"\n\t\t\t\tv-top-focus.onupdate=\"isError\"\n\t\t\t\tv-top-shortcut=\"openerShortcut\"\n\n\t\t\t\t:placeholder\n\t\t\t\t:title\n\t\t\t\t:captionType=\"searchTypeLocal === 'inline' && title !== undefined ? 'top' : undefined\"\n\t\t\t\tv-model=\"menu.searchText.value\"\n\t\t\t>\n\t\t\t\t<template v-if=\"multiselect\">\n\t\t\t\t\t<div class=\"top-selector2_activeItems\">\n\t\t\t\t\t\t<Selector2ItemMulti\n\t\t\t\t\t\t\tv-for=\"item of model as Item[]\"\n\t\t\t\t\t\t\t:id=\"item.id\"\n\t\t\t\t\t\t\t:name=\"item.name\"\n\t\t\t\t\t\t\t@delete=\"menu.deleteItemByItem\"\n\t\t\t\t\t\t/>\n\t\t\t\t\t</div>\n\t\t\t\t</template>\n\n\t\t\t\t<span v-if=\"searchTypeLocal !== 'inline' && !multiselect\" class=\"top-selector2_activeName top-ellipsis\">\n\t\t\t\t\t{{ !Array.isArray(model) ? model.name : '' }}\n\t\t\t\t</span>\n\n\t\t\t\t<span v-if=\"multiselect && !model.length\" class=\"top-selector2_placeholder top-ellipsis\">\n\t\t\t\t\t{{ placeholder }}\n\t\t\t\t</span>\n\n\t\t\t\t<span\n\t\t\t\t\tv-if=\"addChanger && !buttonProps && !multiselect && menu.itemsForShow.value.length > 1 && !disabled\"\n\t\t\t\t\tclass=\"top-changer top-changer-selector\"\n\t\t\t\t\tdata-top-popup-disabled=\"true\"\n\t\t\t\t\t@click=\"onClickChanger\"\n\t\t\t\t></span>\n\t\t\t</component>\n\t\t</template>\n\n\t\t<template #widget v-if=\"searchTypeLocal === 'popup'\">\n\t\t\t<div class=\"top-selector2_searchWidget\">\n\t\t\t\t<TopPopupWidgetInput\n\t\t\t\t\ttitle=\"Поиск\"\n\t\t\t\t\ticon=\"\"\n\t\t\t\t\tv-model=\"menu.searchText.value\"\n\t\t\t\t\tv-top-focus.onupdate=\"model\"\n\t\t\t\t\t:isLoading=\"!!api.countLoading.value && api.isLoading.value\"\n\t\t\t\t\t:placeholder\n\t\t\t\t/>\n\n\t\t\t\t<TopButton\n\t\t\t\t\tv-if=\"hasCloserBtn && !$core.state.isMobile\"\n\t\t\t\t\tclass=\"closer\"\n\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t>\n\t\t\t\t\t{{ $i18n.Common.Cancel }}\n\t\t\t\t</TopButton>\n\t\t\t</div>\n\t\t</template>\n\n\t\t<template #contentList>\n\t\t\t<TopPopupListItem\n\t\t\t\tv-for=\"item of menu.itemsForShow.value\"\n\t\t\t\t:key=\"item.id ?? undefined\"\n\t\t\t\t:class=\"{\n\t\t\t\t\t'top-active': !Array.isArray(model) && !multiselect && model.id === item.id && model.name === item.name,\n\t\t\t\t\t'top-selector2_item-all':item.id === ITEM_ID_ALL,\n\t\t\t\t\t'top-selector2_item-new':item.id === ITEM_ID_NEW,\n\t\t\t\t}\"\n\t\t\t\t:closeByClick=\"!multiselect || Core.state.isMobile\"\n\t\t\t\t:=\"item.listItemProps\"\n\t\t\t\t@click=\"menu.selectItem(item)\"\n\t\t\t>\n\t\t\t\t<slot\n\t\t\t\t\tv-if=\"$slots.item\"\n\t\t\t\t\tname=\"item\"\n\t\t\t\t\t:item\n\t\t\t\t></slot>\n\n\t\t\t\t<template\n\t\t\t\t\tv-else\n\t\t\t\t>\n\t\t\t\t\t{{ item.name }}\n\t\t\t\t</template>\n\t\t\t</TopPopupListItem>\n\n\t\t\t<!-- Элементов для отображения нет -->\n\t\t\t<template v-if=\"!menu.itemsForShow.value.length && !menu.genIsShort()\">\n\t\t\t\t<TopPopupListItem type=\"regular\">\n\t\t\t\t\t<template v-if=\"!api.isLoading.value || api.countLoading.value\">\n\t\t\t\t\t\t{{ $i18n.Common.No_results }}\n\t\t\t\t\t</template>\n\n\t\t\t\t\t<!-- Индикатор первичной загрузки -->\n\t\t\t\t\t<TopPreloader\n\t\t\t\t\t\tv-else\n\t\t\t\t\t\ttype=\"circles\"\n\t\t\t\t\t/>\n\t\t\t\t</TopPopupListItem>\n\t\t\t</template>\n\n\t\t\t<!-- Индикатор повторной загрузки -->\n\t\t\t<TopLoadbar v-if=\"!!api.countLoading.value && api.isLoading.value && searchTypeLocal === 'inline'\"/>\n\t\t</template>\n\t</TopPopup>\n</template>\n\n<style>\n.top-selector2 {\n\twidth: 180px;\n}\n\n.top-selector2::placeholder,\n.top-selector2_placeholder {\n\tcolor: var(--color-text-2);\n}\n\n.top-selector2_placeholder {\n\tpadding-left: var(--top-padding-1);\n}\n\n.top-selector2.top-as-input {\n\tpadding: var(--top-padding-1) var(--top-forms-padding);\n}\n\n.top-selector2.top-selector2-multiselect {\n\twidth: auto;\n\tpadding: var(--top-padding-1);\n\tflex-grow: 1;\n}\n\n.top-selector2.top-active {\n\t--top-forms-border-color: var(--top-forms-border-color-hover);\n}\n\n.top-selector2_searchWidget {\n\tdisplay: flex;\n\tgap: var(--top-gap-2);\n}\n\n.top-selector2_activeItems {\n\tdisplay: flex;\n\tflex-wrap: wrap;\n\tgap: var(--top-padding-1);\n\tmax-width: 100%;\n}\n\n.top-selector2_activeName {\n\tfont-size: var(--top-font-size);\n\twhite-space: nowrap;\n}\n\n.top-changer-selector {\n\twidth: auto;\n\tpadding: var(--top-padding-1);\n\tmargin: calc(0px - var(--top-padding-1));\n\ttransform: translateX(0);\n}\n\n.top-selector2.top-button {\n\tjustify-content: start;\n}\n\n.top-selector2.top-input_input ~ .top-changer-selector {\n\ttransform: translateX(-52px);\n}\n\n.top-selector2.top-as-selector {\n\tpadding-right: calc(var(--top-selector-arrow-width) + var(--top-padding-2));\n}\n</style>\n","<script setup lang=\"ts\">\nimport { computed, ref } from 'vue';\nimport Button from '@/components/forms/button/button.vue';\nimport type { Emits, Props, Slots } from './types';\nimport Textarea from '@/components/forms/textarea/textarea.vue';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tdefaultValue: '',\n\tcancelText: 'Cancel',\n\tsubmitText: 'Send',\n\tcloseText: 'Close',\n\texpandable: true,\n});\n\ndefineSlots<Slots>();\nconst emit = defineEmits<Emits>();\n\nconst localValue = ref(props.defaultValue);\n\nconst isFocused = ref(props.isFocused);\n\nconst isChanged = computed(() => localValue.value !== props.defaultValue);\n\nconst submit = (value: string) => {\n\temit('submit', value);\n\n\tlocalValue.value = props.defaultValue;\n};\n\nconst cancel = () => {\n\tif (props.forceShowCloseBtn && !isChanged.value) {\n\t\temit('close');\n\n\t\treturn;\n\t}\n\n\tlocalValue.value = props.defaultValue;\n};\n\nconst clickOnTitle = () => {\n\tif (props.attachToKeyboard) emit('clickOnTitle');\n};\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t'top-editArea': true,\n\t\t\t'top-editArea-attachedToKeyboard': attachToKeyboard,\n\t\t}\"\n\t>\n\t\t<div\n\t\t\tv-if=\"title || $slots.caption\"\n\t\t\tclass=\"top-editArea_caption\"\n\t\t\t@click=\"clickOnTitle()\"\n\t\t>\n\t\t\t<slot name=\"caption\">\n\t\t\t\t{{ title }}\n\t\t\t</slot>\n\t\t</div>\n\n\t\t<div\n\t\t\t:class=\"{\n\t\t\t\t'top-editArea_form': true,\n\t\t\t\t'top-forms-focusable': true,\n\t\t\t\t'top-as-input': true,\n\t\t\t\t'top-error': isError,\n\t\t\t\t'top-focus': isFocused,\n\t\t\t}\"\n\t\t>\n\t\t\t<Textarea\n\t\t\t\tv-model=\"localValue\"\n\t\t\t\t:name=\"name\"\n\t\t\t\t:placeholder=\"placeholder\"\n\t\t\t\t:rows=\"rows\"\n\t\t\t\t:minHeight=\"minHeight\"\n\t\t\t\t:expandable=\"expandable\"\n\t\t\t\t:disabled=\"disabled\"\n\t\t\t\t:readonly=\"readonly\"\n\t\t\t\t:isError=\"isError\"\n\t\t\t\t:hint=\"hint\"\n\t\t\t\tclass=\"top-editArea_element\"\n\t\t\t\t@focus=\"() => isFocused = true\"\n\t\t\t\t@blur=\"() => isFocused = false\"\n\t\t\t\t@keyup.esc=\"cancel\"\n\t\t\t\t@keyup.ctrl.enter=\"submit(localValue)\"\n\t\t\t/>\n\n\t\t\t<div class=\"top-editArea_footer\">\n\t\t\t\t<Button\n\t\t\t\t\tv-if=\"isChanged || forceShowCloseBtn\"\n\t\t\t\t\t:icon=\"$core.state.isMobile ? '': ''\"\n\t\t\t\t\tclass=\"top-editArea_button\"\n\t\t\t\t\tcolor=\"theme\"\n\t\t\t\t\tstyling=\"soft\"\n\t\t\t\t\t@click=\"cancel\"\n\t\t\t\t>\n\t\t\t\t\t<template\n\t\t\t\t\t\t#default\n\t\t\t\t\t\tv-if=\"!$core.state.isMobile\"\n\t\t\t\t\t>\n\t\t\t\t\t\t{{ cancelText }}\n\t\t\t\t\t</template>\n\t\t\t\t</Button>\n\n\t\t\t\t<Button\n\t\t\t\t\tclass=\"top-editArea_button\"\n\t\t\t\t\tv-if=\"isChanged\"\n\t\t\t\t\t:icon=\"$core.state.isMobile ? '': ''\"\n\t\t\t\t\t@click=\"submit(localValue)\"\n\t\t\t\t>\n\t\t\t\t\t<template\n\t\t\t\t\t\t#default\n\t\t\t\t\t\tv-if=\"!$core.state.isMobile\"\n\t\t\t\t\t>\n\t\t\t\t\t\t{{ submitText }}\n\t\t\t\t\t</template>\n\t\t\t\t</Button>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</template>\n\n<style>\n.top-editArea {\n\t--top-editArea-bottom: env(keyboard-inset-height, 0px);\n\t--top-editArea-offset-bottom: 0px;\n\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: 6px;\n}\n\n.top-editArea_caption {\n\tfont-size: 12px;\n}\n\n.top-editArea_form {\n\tflex-direction: column;\n}\n\n/* textarea в EditArea */\n.top-textarea {\n\twidth: 100%;\n}\n\n.top-editArea_element.top-textarea_textarea {\n\t--top-forms-border-width: 0px;\n\n\toutline: none;\n\tanimation: none;\n}\n\n/* footer */\n.top-editArea_footer {\n\tpadding: var(--top-forms-padding);\n\tdisplay: flex;\n\tmin-height: 32px;\n\talign-self: flex-end;\n\tjustify-content: flex-end;\n\tgap: var(--top-forms-padding);\n}\n\n/* attachedToKeyboard */\n.top-editArea-attachedToKeyboard {\n\tbackground: var(--top-forms-background-color);\n\tposition: fixed;\n\tbottom: calc(var(--top-editArea-offset-bottom) + var(--top-editArea-bottom));\n\tright: 0;\n\tleft: 0;\n\tz-index: 2;\n\tgap: 0;\n\ttransition: bottom var(--transition-fast);\n}\n\n.top-editArea-attachedToKeyboard .top-editArea_form {\n\tborder-radius: 0;\n\tborder: none;\n\tborder-top: 1px solid var(--top-forms-border-color);\n}\n\n.top-editArea-attachedToKeyboard .top-editArea_title {\n\tcursor: pointer;\n\tborder-top: 1px solid var(--color-line-2-opacity);\n\tpadding: var(--top-forms-padding);\n}\n\n.top-editArea-attachedToKeyboard .top-editArea_footer > [data-top-icon] {\n\tborder-radius: 100%;\n}\n\n@media screen and (max-width: 900px) {\n\t.top-editArea_form {\n\t\tflex-direction: row;\n\t}\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref, watch } from 'vue';\nimport type { Emits, Props } from './types';\nimport TopInput from '@/components/forms/input/input.vue';\nimport TopButton from '@/components/forms/button/button.vue';\n\nconst props = defineProps<Props>();\n\nconst intermediateValue = ref(props.modelValue);\n\nwatch(() => props.modelValue, () => {\n\tintermediateValue.value = props.modelValue;\n});\n\nconst emit = defineEmits<Emits>();\n\nconst submit = () => {\n\temit('update:modelValue', intermediateValue.value);\n};\n</script>\n\n<template>\n\t<div class=\"top-editInput\">\n\t\t<TopInput\n\t\t\t:=\"input\"\n\t\t\t@keydown.esc.capture.stop=\"intermediateValue = modelValue\"\n\t\t\t@keydown.enter.stop=\"submit\"\n\t\t\tv-model=\"intermediateValue\"\n\t\t>\n\t\t\t<template #caption v-if=\"$slots.caption\">\n\t\t\t\t<slot name=\"caption\"></slot>\n\t\t\t</template>\n\t\t</TopInput>\n\n\t\t<TopButton\n\t\t\tv-if=\"intermediateValue !== modelValue || alwaysShowSubmitBtn\"\n\t\t\ticon=\"\"\n\t\t\tstyling=\"soft\"\n\t\t\t:=\"button\"\n\t\t\t@click=\"submit\"\n\t\t/>\n\t</div>\n</template>\n\n<style>\n.top-editInput {\n\twidth: 220px;\n\tflex-grow: 1;\n\tdisplay: flex;\n\talign-items: flex-end;\n\tgap: var(--top-gap-1);\n}\n\n.top-editInput .top-input {\n\twidth: unset;\n\tflex-grow: 1;\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref, watch } from 'vue';\nimport type { Props } from './types';\nimport TopCheckbox from '@/components/forms/checkbox/checkbox.vue';\nimport TopRadio from '@/components/forms/radio/radio.vue';\n\nconst model = defineModel<Props['modelValue']>({\n\trequired: true,\n});\n\nconst props = withDefaults(defineProps<Props>(), {\n\tsize: 's',\n});\n\nconst elRef = ref<HTMLElement | null>(null);\n\nwatch(model, () => {\n\tconst valuesAvailable = props.items.map(item => item.value);\n\n\tif (Array.isArray(model.value)) {\n\t\t// есть ли неподдерживаемые значения\n\t\tconst valueIsWrong = model.value.find((value) => {\n\t\t\treturn !valuesAvailable.includes(value);\n\t\t});\n\n\t\tif (valueIsWrong) {\n\t\t\t// оставить только поддерживаемые значения\n\t\t\tmodel.value = model.value.filter((value) => {\n\t\t\t\treturn valuesAvailable.includes(value);\n\t\t\t});\n\t\t}\n\t} else {\n\t\tif (!valuesAvailable.includes(model.value)) {\n\t\t\tmodel.value = valuesAvailable[0] ?? '';\n\t\t}\n\t}\n\n\telRef.value?.querySelector('.radioGroup_item-selected')?.scrollIntoView();\n}, { immediate: true });\n\nconst name = 'optionGroup-' + Math.random();\n</script>\n\n<template>\n\t<div\n\t\tref=\"elRef\"\n\t\t:class=\"{\n\t\t\t['top-optionGroup']: true,\n\t\t\t['top-optionGroup-showIndicator_' + Number(showIndicator)]: true,\n\t\t\t['top-scrollBarXHidding']: true,\n\t\t\t['top-size_' + size]: !!size,\n\t\t\t['top-error']: isError,\n\t\t}\"\n\t>\n\t\t<template v-if=\"Array.isArray(model)\">\n\t\t\t<TopCheckbox\n\t\t\t\t:class=\"{\n\t\t\t\t\t['top-optionGroup_item-selected']: model.includes(item.value),\n\t\t\t\t\t['top-optionGroup_item']: true,\n\t\t\t\t}\"\n\t\t\t\tv-for=\"item of items\"\n\t\t\t\tv-model=\"model\"\n\t\t\t\t:value=\"item.value\"\n\t\t\t\t:title=\"item.title\"\n\t\t\t\t:disabled=\"item.disabled\"\n\t\t\t\t:isError\n\t\t\t\t:data-top-icon=\"item.icon\"\n\t\t\t>\n\t\t\t\t<template #default v-if=\"item.label\">\n\t\t\t\t\t{{ item.label }}\n\t\t\t\t</template>\n\t\t\t</TopCheckbox>\n\t\t</template>\n\n\t\t<template v-else>\n\t\t\t<TopRadio\n\t\t\t\t:class=\"{\n\t\t\t\t\t['top-optionGroup_item-selected']: item.value === model,\n\t\t\t\t\t['top-optionGroup_item']: true,\n\t\t\t\t}\"\n\t\t\t\tv-for=\"item of items\"\n\t\t\t\tv-model=\"model\"\n\t\t\t\t:name\n\t\t\t\t:value=\"item.value\"\n\t\t\t\t:title=\"item.title\"\n\t\t\t\t:disabled=\"item.disabled\"\n\t\t\t\t:isError\n\t\t\t\t:data-top-icon=\"item.icon\"\n\t\t\t>\n\t\t\t\t<template #default v-if=\"item.label\">\n\t\t\t\t\t{{ item.label }}\n\t\t\t\t</template>\n\t\t\t</TopRadio>\n\t\t</template>\n\t</div>\n</template>\n\n<style>\n.top-optionGroup {\n\tuser-select: none;\n\tbox-sizing: border-box;\n\tborder-radius: 8px;\n\tbackground-color: var(--color-layout-middle);\n\theight: var(--top-forms-base-height);\n\tpadding: 2px;\n\tgap: 2px;\n\tdisplay: flex;\n\talign-items: flex-start;\n}\n\n.top-optionGroup_item {\n\tcursor: pointer;\n\tbox-sizing: border-box;\n\tborder-radius: 6px;\n\theight: calc(var(--top-forms-base-height) - 4px);\n\tpadding: 1px var(--top-padding-2);\n\tcolor: var(--color-text-2);\n\tfont-weight: 400;\n\twhite-space: nowrap;\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tflex-grow: 1;\n\tgap: var(--top-gap-1);\n}\n\n.top-optionGroup_item:hover {\n\tbackground-color: var(--color-layout-front-1);\n\tbox-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);\n}\n\n.top-optionGroup_item-selected {\n\tcolor: var(--color-text-1);\n\tbackground-color: var(--color-bg-lightning-1);\n\tbox-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);\n}\n\n.top-optionGroup_item > .top-forms-optionLabel {\n\tflex-grow: 0;\n}\n\n/* indicator */\n.top-optionGroup-showIndicator_0 > .top-optionGroup_item {\n\tjustify-content: center;\n}\n\n.top-optionGroup-showIndicator_0 > .top-optionGroup_item:has(:focus-visible) {\n\toutline: 2px solid var(--color-bg-primary-2);\n\toutline-offset: -1px;\n}\n\n.top-optionGroup-showIndicator_1 > .top-optionGroup_item {\n\tpadding: 1px 3px;\n\tjustify-content: flex-start;\n}\n\n.top-optionGroup-showIndicator_0 > .top-optionGroup_item > .top-forms-option {\n\topacity: 0;\n\twidth: 0;\n\theight: 0;\n\tposition: absolute;\n}\n\n.top-optionGroup_item > .top-forms-option {\n\torder: -1;\n}\n</style>\n","<script setup lang=\"ts\">\nimport OptionGroup from '../libs/optionGroup/optionGroup.vue';\n\nimport type { Props } from './types';\n\nconst model = defineModel<Props['modelValue']>({\n\trequired: true,\n});\n\ndefineProps<Props>();\n</script>\n\n<template>\n\t<OptionGroup\n\t\tclass=\"top-radioGroup\"\n\t\tv-model=\"model\"\n\t\t:items=\"$props.items\"\n\t\t:size=\"$props.size\"\n\t\t:showIndicator=\"$props.showIndicator\"\n\t\t:isError=\"$props.isError\"\n\t>\n\t\t<slot/>\n\t</OptionGroup>\n</template>\n","<script setup lang=\"ts\">\nimport OptionGroup from '../libs/optionGroup/optionGroup.vue';\n\nimport type { Props } from './types';\n\nconst model = defineModel<Props['modelValue']>({\n\trequired: true,\n});\n\ndefineProps<Props>();\n</script>\n\n<template>\n\t<OptionGroup\n\t\tclass=\"top-checkboxGroup\"\n\t\tv-model=\"model\"\n\t\t:items=\"$props.items\"\n\t\t:size=\"$props.size\"\n\t\t:showIndicator=\"$props.showIndicator\"\n\t\t:isError=\"$props.isError\"\n\t>\n\t\t<slot/>\n\t</OptionGroup>\n</template>\n","<script lang=\"ts\" setup>\nimport type { Props, Slots } from './types';\n\nwithDefaults(defineProps<Props>(), {\n\tstyling: 'default',\n\tsize: 'default',\n});\n\ndefineSlots<Slots>();\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t['top-info']: true,\n\t\t\t['top-size_' + size]: true,\n\t\t\t['top-info-styling_' + styling]: true,\n\t\t}\"\n\t\t:data-top-icon=\"icon\"\n\t>\n\t\t<div class=\"top-info_text\">\n\t\t\t<slot></slot>\n\t\t</div>\n\n\t\t<span v-if=\"$slots.additional\" class=\"top-info_value\">\n\t\t\t<slot name=\"additional\"></slot>\n\t\t</span>\n\t</div>\n</template>\n\n<style>\n.top-info {\n\t--top-icon-width: var(--top-icon-size);\n\n\tborder-radius: var(--top-forms-radius);\n\tbox-sizing: border-box;\n\tmin-height: var(--top-forms-base-height);\n\tpadding: var(--top-padding-1) var(--top-padding-2);\n\tflex-grow: 5;\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: var(--top-gap-2);\n}\n\n.top-info_text {\n\tflex-grow: 1;\n}\n\n.top-info_value {\n\tfont-weight: bold;\n}\n\n/* size */\n.top-info.top-size_default {\n\tborder-radius: var(--top-radius-3);\n\tpadding: var(--top-padding-4);\n}\n\n/* styling */\n.top-info-styling_default {\n\t--top-icon-color: var(--color-text-2);\n\n\tbackground: var(--color-layer-1);\n}\n\n.top-info-styling_info {\n\t--top-icon-color: var(--color-text-primary);\n\n\tbackground: var(--color-layer-primary-1);\n}\n\n.top-info-styling_warning {\n\t--top-icon-color: var(--color-text-warning);\n\n\tbackground: var(--color-layer-warning-1);\n}\n\n.top-info-styling_negative {\n\t--top-icon-color: var(--color-text-negative);\n\n\tbackground: var(--color-layer-negative-1);\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref } from 'vue';\nimport { TopButton } from '@/components/forms/forms';\nimport type { Emits, Props } from '@/components/formsExt/policy/types';\n\ndefineProps<Props>();\nconst emits = defineEmits<Emits>();\n\nconst isVisible = ref(true);\n\nconst onAccept = () => {\n\tisVisible.value = false;\n\n\temits('accept');\n};\n</script>\n\n<template>\n\t<div\n\t\tv-if=\"isVisible\"\n\t\tclass=\"top-policy\"\n\t>\n\t\t<div class=\"top-policy_title\">\n\t\t\t{{ title }}\n\t\t</div>\n\n\t\t<div\n\t\t\tclass=\"top-policy_description\"\n\t\t\tv-html=\"description\"\n\t\t></div>\n\n\t\t<TopButton\n\t\t\tsize=\"m\"\n\t\t\t@click=\"onAccept\"\n\t\t>\n\t\t\t{{ acceptText }}\n\t\t</TopButton>\n\t</div>\n</template>\n\n<style>\n.top-policy {\n\tbox-sizing: border-box;\n\tbox-shadow: var(--top-shadow-b);\n\tborder-radius: var(--top-radius-4);\n\tbackground: var(--color-bg-lightning-1);\n\twidth: 600px;\n\tpadding: var(--top-padding-4);\n\tposition: fixed;\n\tright: var(--top-gap-10);\n\tbottom: var(--top-gap-10);\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: var(--top-gap-4);\n\tz-index: 10000;\n}\n\n.top-policy_title {\n\tfont-size: 24px;\n\tfont-weight: 700;\n}\n\n.top-policy_description {\n\tfont-size: 14px;\n}\n\n@media screen and (max-width: 900px) {\n\t.top-policy {\n\t\twidth: 100%;\n\t\tright: 0;\n\t\tbottom: calc(var(--top-gap-5) + var(--toolbar-height, 0px));\n\t}\n}\n</style>\n"]}
|