@topvisor/ui 1.0.16 → 1.0.18-autofocus-3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (196) hide show
  1. package/.chunks/{datepicker-DW_EVh8-.amd.js → datepicker-2XyFBnpB.amd.js} +2 -2
  2. package/.chunks/{datepicker-DW_EVh8-.amd.js.map → datepicker-2XyFBnpB.amd.js.map} +1 -1
  3. package/.chunks/{datepicker-CDFryb2R.es.js → datepicker-CUB0U_lQ.es.js} +2 -2
  4. package/.chunks/{datepicker-CDFryb2R.es.js.map → datepicker-CUB0U_lQ.es.js.map} +1 -1
  5. package/.chunks/forms-CgS7En_e.amd.js +3 -0
  6. package/.chunks/{forms-CORLOoYZ.amd.js.map → forms-CgS7En_e.amd.js.map} +1 -1
  7. package/.chunks/forms-cAFIQajo.es.js +1995 -0
  8. package/.chunks/{forms-DmpPuKKh.es.js.map → forms-cAFIQajo.es.js.map} +1 -1
  9. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DwVG6MzF.amd.js +2 -0
  10. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DwVG6MzF.amd.js.map +1 -0
  11. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DxPx80QT.es.js +181 -0
  12. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-Cry_LWLq.es.js.map → listItem.vue_vue_type_script_setup_true_lang-DxPx80QT.es.js.map} +1 -1
  13. package/.chunks/{menu.vue_vue_type_style_index_0_lang-BQFq184r.es.js → menu.vue_vue_type_style_index_0_lang-BoLzlJHY.es.js} +24 -24
  14. package/.chunks/{menu.vue_vue_type_style_index_0_lang-BQFq184r.es.js.map → menu.vue_vue_type_style_index_0_lang-BoLzlJHY.es.js.map} +1 -1
  15. package/.chunks/{menu.vue_vue_type_style_index_0_lang-Chd1ygyG.amd.js → menu.vue_vue_type_style_index_0_lang-Dpm2Wnt9.amd.js} +2 -2
  16. package/.chunks/{menu.vue_vue_type_style_index_0_lang-Chd1ygyG.amd.js.map → menu.vue_vue_type_style_index_0_lang-Dpm2Wnt9.amd.js.map} +1 -1
  17. package/.chunks/{notice-BNik2ZIo.es.js → notice-DRCVp0mf.es.js} +2 -2
  18. package/.chunks/{notice-BNik2ZIo.es.js.map → notice-DRCVp0mf.es.js.map} +1 -1
  19. package/.chunks/{notice-BnvlWLlj.amd.js → notice-EerveAd9.amd.js} +2 -2
  20. package/.chunks/{notice-BnvlWLlj.amd.js.map → notice-EerveAd9.amd.js.map} +1 -1
  21. package/.chunks/popup-D6-5Xu_J.amd.js +2 -0
  22. package/.chunks/{popup-Dm9xIxVU.amd.js.map → popup-D6-5Xu_J.amd.js.map} +1 -1
  23. package/.chunks/{popup-BxLi2sMk.es.js → popup-DZDWzqMA.es.js} +4 -4
  24. package/.chunks/{popup-BxLi2sMk.es.js.map → popup-DZDWzqMA.es.js.map} +1 -1
  25. package/.chunks/punycode.es6-C2yitnNb.amd.js.map +1 -1
  26. package/.chunks/punycode.es6-CNI-zL6U.es.js.map +1 -1
  27. package/.chunks/store-CX_6ZXhO.es.js.map +1 -1
  28. package/.chunks/store-esTid5oI.amd.js.map +1 -1
  29. package/.chunks/{utils-k0wIxxij.amd.js → utils-CQcFLRGs.amd.js} +2 -2
  30. package/.chunks/{utils-k0wIxxij.amd.js.map → utils-CQcFLRGs.amd.js.map} +1 -1
  31. package/.chunks/{utils-DFwHp4q7.es.js → utils-DP2t2MXK.es.js} +85 -87
  32. package/.chunks/utils-DP2t2MXK.es.js.map +1 -0
  33. package/.chunks/{utils-CKpKCxOO.es.js → utils-DTkdtW9l.es.js} +78 -78
  34. package/.chunks/{utils-CKpKCxOO.es.js.map → utils-DTkdtW9l.es.js.map} +1 -1
  35. package/.chunks/utils-kDi9Zfjp.amd.js +2 -0
  36. package/.chunks/utils-kDi9Zfjp.amd.js.map +1 -0
  37. package/assets/core.css +1 -1
  38. package/assets/forms.css +1 -1
  39. package/assets/formsExt.css +1 -1
  40. package/assets/layout.css +1 -1
  41. package/assets/themes/dark-th.css +1 -1
  42. package/assets/themes/dark.css +1 -1
  43. package/assets/themes/light.css +1 -1
  44. package/charts/charts.amd.js +1 -1
  45. package/charts/charts.amd.js.map +1 -1
  46. package/charts/charts.js +1 -1
  47. package/components/charts/miniChart/miniChart.vue.d.ts +5 -5
  48. package/components/charts/miniCharts/miniCharts.vue.d.ts +9 -6
  49. package/components/core/notice/item/item.vue.d.ts +1 -1
  50. package/components/dialog/dialog/dialog.vue.d.ts +3 -2
  51. package/components/dialog/dialog/dialogs/dialogs.vue.d.ts +1 -1
  52. package/components/dialog/dialog/page/page.vue.d.ts +2 -1
  53. package/components/forms/avatar/avatar.vue.d.ts +1 -1
  54. package/components/forms/button/button.vue.d.ts +2 -1
  55. package/components/forms/button/types.d.ts +1 -0
  56. package/components/forms/checkbox/checkbox.vue.d.ts +7 -6
  57. package/components/forms/controlLabel/controlLabel.vue.d.ts +3 -2
  58. package/components/forms/hint/hint.vue.d.ts +1 -1
  59. package/components/forms/input/input.vue.d.ts +2 -1
  60. package/components/forms/inputDate/inputDate.vue.d.ts +3 -1
  61. package/components/forms/inputRange/inputRange.vue.d.ts +3 -2
  62. package/components/forms/loadbar/loadbar.vue.d.ts +1 -1
  63. package/components/forms/radio/radio.vue.d.ts +3 -2
  64. package/components/forms/select/select.vue.d.ts +5 -5
  65. package/components/forms/switcher/switcher.vue.d.ts +3 -2
  66. package/components/formsExt/editArea/editArea.vue.d.ts +1 -1
  67. package/components/formsExt/editInput/editInput.vue.d.ts +1 -1
  68. package/components/formsExt/formsExt.d.ts +2 -0
  69. package/components/formsExt/info/info.vue.d.ts +22 -0
  70. package/components/formsExt/info/types.d.ts +15 -0
  71. package/components/formsExt/menu/menu.vue.d.ts +7 -5
  72. package/components/formsExt/radioGroup/radioGroup.vue.d.ts +7 -5
  73. package/components/formsExt/selector2/itemMulti.vue.d.ts +1 -1
  74. package/components/formsExt/selector2/selector2.vue.d.ts +96 -8
  75. package/components/layout/islandRows/islandRows.vue.d.ts +3 -2
  76. package/components/layout/islandRows/islandRowsRow/islandRowsRow.vue.d.ts +3 -2
  77. package/components/layout/islandRows/islandRowsSubTitle/islandRowsSubTitle.vue.d.ts +18 -0
  78. package/components/layout/layout.d.ts +2 -0
  79. package/components/layout/rows/rows.vue.d.ts +3 -2
  80. package/components/popup/alert/alert.vue.d.ts +2 -1
  81. package/components/popup/confirm/confirm.vue.d.ts +2 -1
  82. package/components/popup/popup/listItem.vue.d.ts +2 -1
  83. package/components/popup/popup/opener.vue.d.ts +2 -1
  84. package/components/popup/popup/popup.vue.d.ts +2 -1
  85. package/components/popup/popup/widgetInput.vue.d.ts +4 -4
  86. package/components/popup/prompt/prompt.vue.d.ts +2 -1
  87. package/components/project/selectorCompetitors/selectorCompetitors.vue.d.ts +5 -5
  88. package/components/project/selectorRegion/selectorRegion.vue.d.ts +7 -7
  89. package/components/project/tagSelector/popupListItem/tagPopupListItem.vue.d.ts +5 -3
  90. package/components/project/tagSelector/popupOpener/popupOpener.vue.d.ts +6 -5
  91. package/components/project/tagSelector/tagIcon/tagIcon.vue.d.ts +1 -1
  92. package/components/project/tagSelector/tagSelector.vue.d.ts +6 -6
  93. package/components/tabs/tabs/content.vue.d.ts +3 -2
  94. package/components/tabs/tabs/tab.vue.d.ts +2 -1
  95. package/components/tabs/tabs/tabs.vue.d.ts +3 -2
  96. package/components/tabsView/tabsView/menu.vue.d.ts +9 -6
  97. package/components/tabsView/tabsView/menuDelimeter.vue.d.ts +1 -1
  98. package/components/tabsView/tabsView/menuItem.vue.d.ts +2 -1
  99. package/components/tabsView/tabsView/menuTitle.vue.d.ts +2 -1
  100. package/components/tabsView/tabsView/store.d.ts +5 -5
  101. package/components/tabsView/tabsView/tabsView.vue.d.ts +9 -6
  102. package/core/app.amd.js +1 -1
  103. package/core/app.amd.js.map +1 -1
  104. package/core/app.js +209 -162
  105. package/core/app.js.map +1 -1
  106. package/core/directives/focus.d.ts +3 -1
  107. package/core/directives/scrollIntoView.d.ts +3 -0
  108. package/core/directives/scrollShadow.d.ts +15 -0
  109. package/core/utils/number.d.ts +6 -0
  110. package/core/utils/scroll.d.ts +3 -2
  111. package/core/utils/string.d.ts +1 -1
  112. package/dialog/dialog.amd.js +1 -1
  113. package/dialog/dialog.amd.js.map +1 -1
  114. package/dialog/dialog.js +84 -79
  115. package/dialog/dialog.js.map +1 -1
  116. package/forms/forms.amd.js +1 -1
  117. package/forms/forms.js +1 -1
  118. package/forms/helpers.amd.js.map +1 -1
  119. package/formsExt/formsExt.amd.js +1 -1
  120. package/formsExt/formsExt.amd.js.map +1 -1
  121. package/formsExt/formsExt.js +330 -290
  122. package/formsExt/formsExt.js.map +1 -1
  123. package/layout/layout.amd.js +1 -1
  124. package/layout/layout.amd.js.map +1 -1
  125. package/layout/layout.js +33 -25
  126. package/layout/layout.js.map +1 -1
  127. package/package.json +31 -31
  128. package/popup/popup.amd.js +1 -1
  129. package/popup/popup.amd.js.map +1 -1
  130. package/popup/popup.js +17 -17
  131. package/popup/worker.amd.js +1 -1
  132. package/popup/worker.amd.js.map +1 -1
  133. package/popup/worker.js +9 -10
  134. package/popup/worker.js.map +1 -1
  135. package/project/project.amd.js +1 -1
  136. package/project/project.amd.js.map +1 -1
  137. package/project/project.js +307 -307
  138. package/tabsView/tabsView.amd.js +1 -1
  139. package/tabsView/tabsView.amd.js.map +1 -1
  140. package/tabsView/tabsView.js +37 -37
  141. package/utils/check.amd.js +1 -1
  142. package/utils/check.amd.js.map +1 -1
  143. package/utils/check.js +1 -1
  144. package/utils/check.js.map +1 -1
  145. package/utils/clipboard.amd.js +1 -1
  146. package/utils/clipboard.amd.js.map +1 -1
  147. package/utils/clipboard.js +1 -1
  148. package/utils/clipboard.js.map +1 -1
  149. package/utils/date.amd.js +1 -1
  150. package/utils/date.js +1 -1
  151. package/utils/device.amd.js +1 -1
  152. package/utils/device.js +1 -1
  153. package/utils/dom.amd.js +1 -1
  154. package/utils/dom.amd.js.map +1 -1
  155. package/utils/dom.js +30 -30
  156. package/utils/dom.js.map +1 -1
  157. package/utils/image.amd.js.map +1 -1
  158. package/utils/keyboard.amd.js.map +1 -1
  159. package/utils/lodash.amd.js +1 -1
  160. package/utils/lodash.js +1 -1
  161. package/utils/number.amd.js +1 -1
  162. package/utils/number.amd.js.map +1 -1
  163. package/utils/number.js +7 -3
  164. package/utils/number.js.map +1 -1
  165. package/utils/price.amd.js +1 -1
  166. package/utils/price.amd.js.map +1 -1
  167. package/utils/price.js +1 -1
  168. package/utils/price.js.map +1 -1
  169. package/utils/route.amd.js +1 -1
  170. package/utils/route.amd.js.map +1 -1
  171. package/utils/route.js +5 -5
  172. package/utils/route.js.map +1 -1
  173. package/utils/scroll.amd.js +1 -1
  174. package/utils/scroll.amd.js.map +1 -1
  175. package/utils/scroll.js +19 -14
  176. package/utils/scroll.js.map +1 -1
  177. package/utils/searchers.amd.js.map +1 -1
  178. package/utils/searchers.js.map +1 -1
  179. package/utils/string.amd.js +1 -1
  180. package/utils/string.amd.js.map +1 -1
  181. package/utils/string.js +48 -47
  182. package/utils/string.js.map +1 -1
  183. package/utils/system.amd.js.map +1 -1
  184. package/utils/system.js.map +1 -1
  185. package/utils/url.amd.js.map +1 -1
  186. package/utils/url.js.map +1 -1
  187. package/web-types.json +41 -0
  188. package/.chunks/forms-CORLOoYZ.amd.js +0 -3
  189. package/.chunks/forms-DmpPuKKh.es.js +0 -1944
  190. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-BZar2z_p.amd.js +0 -2
  191. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-BZar2z_p.amd.js.map +0 -1
  192. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-Cry_LWLq.es.js +0 -174
  193. package/.chunks/popup-Dm9xIxVU.amd.js +0 -2
  194. package/.chunks/utils-COOeS9rk.amd.js +0 -2
  195. package/.chunks/utils-COOeS9rk.amd.js.map +0 -1
  196. package/.chunks/utils-DFwHp4q7.es.js.map +0 -1
package/dialog/dialog.js CHANGED
@@ -1,7 +1,7 @@
1
- import { defineComponent as v, provide as f, onMounted as w, getCurrentInstance as b, watch as C, openBlock as n, createElementBlock as l, unref as s, normalizeClass as u, normalizeStyle as g, createElementVNode as i, renderSlot as p, computed as A, createBlock as m, Teleport as h, createCommentVNode as c, ref as k, onUpdated as T, KeepAlive as D, resolveDynamicComponent as $, mergeProps as P } from "vue";
2
- import { g as N, u as y } from "../.chunks/utils-CKpKCxOO.es.js";
3
- import { C as B } from "../.chunks/forms-DmpPuKKh.es.js";
4
- const S = ["id", "data-view-page-active", "data-modal", "data-position"], F = /* @__PURE__ */ v({
1
+ import { defineComponent as v, provide as w, onMounted as b, getCurrentInstance as C, watch as A, openBlock as s, createElementBlock as l, unref as n, normalizeClass as u, normalizeStyle as c, createElementVNode as i, renderSlot as p, computed as D, resolveDirective as _, createBlock as m, Teleport as h, withDirectives as k, createCommentVNode as g, ref as T, onUpdated as $, KeepAlive as P, resolveDynamicComponent as N, mergeProps as B } from "vue";
2
+ import { g as S, u as y } from "../.chunks/utils-DTkdtW9l.es.js";
3
+ import { C as E } from "../.chunks/forms-cAFIQajo.es.js";
4
+ const L = ["id", "data-view-page-active", "data-modal", "data-position"], J = /* @__PURE__ */ v({
5
5
  __name: "dialog",
6
6
  props: {
7
7
  id: {},
@@ -15,49 +15,49 @@ const S = ["id", "data-view-page-active", "data-modal", "data-position"], F = /*
15
15
  },
16
16
  emits: ["open", "close"],
17
17
  setup(d) {
18
- const o = N(d.id);
18
+ const o = S(d.id);
19
19
  if (!o)
20
20
  throw new Error("TopDialog cannot be used in a template, use useTopDialog() / useAsyncTopDialog()");
21
- return f("dialogWorker", o), w(() => {
21
+ return w("dialogWorker", o), b(() => {
22
22
  var t;
23
- const a = b(), e = a.parent;
23
+ const a = C(), e = a.parent;
24
24
  if (((t = e == null ? void 0 : e.parent) == null ? void 0 : t.type.name) !== "DialogWrapper")
25
25
  throw new Error("TopDialog cannot be used in a template, use useTopDialog()");
26
26
  if (Array.isArray(e.subTree.children) && e.subTree.children.length !== 1)
27
27
  throw new Error("TopDialog can has only one root element");
28
28
  o.onMounted(e, a);
29
- }), C(o.isOpened, () => {
29
+ }), A(o.isOpened, () => {
30
30
  o.isReady.value = !0;
31
31
  }, {
32
32
  flush: "post",
33
33
  once: !0
34
- }), (a, e) => (n(), l("div", {
35
- id: s(o).idAttr,
34
+ }), (a, e) => (s(), l("div", {
35
+ id: n(o).idAttr,
36
36
  class: u(["top-dialog", a.classes]),
37
- style: g({
37
+ style: c({
38
38
  "--top-dialog-width": a.width,
39
39
  "--top-dialog-height": a.height
40
40
  }),
41
41
  tabindex: "-1",
42
- "data-view-page-active": s(o).pageActive.value,
42
+ "data-view-page-active": n(o).pageActive.value,
43
43
  "data-modal": a.modal,
44
44
  "data-position": a.position
45
45
  }, [
46
46
  e[0] || (e[0] = i("div", { class: "modal-layer modal-layer-header" }, null, -1)),
47
47
  i("div", {
48
48
  class: "modal-layer modal-layer-body",
49
- style: g({ "min-height": a.height + "px" })
49
+ style: c({ "min-height": a.height + "px" })
50
50
  }, null, 4),
51
51
  p(a.$slots, "default")
52
- ], 14, S));
52
+ ], 14, L));
53
53
  }
54
- }), _ = {
54
+ }), W = {
55
55
  key: 0,
56
56
  style: { display: "none" }
57
- }, E = ["data-order", "data-view-page"], L = { class: "modal-header" }, W = { class: "top-title" }, M = { class: "buttons" }, R = ["title"], q = ["title"], z = ["data-order", "data-view-page"], I = { class: "modal-body" }, V = {
57
+ }, M = ["data-order", "data-view-page"], R = { class: "modal-header" }, q = { class: "top-title" }, z = { class: "buttons" }, I = ["title"], V = ["title"], K = ["data-order", "data-view-page"], O = { class: "modal-body" }, U = {
58
58
  key: 0,
59
59
  class: "modal-footer"
60
- }, G = /* @__PURE__ */ v({
60
+ }, Q = /* @__PURE__ */ v({
61
61
  __name: "page",
62
62
  props: {
63
63
  isLoading: { type: Boolean },
@@ -66,67 +66,72 @@ const S = ["id", "data-view-page-active", "data-modal", "data-position"], F = /*
66
66
  prevName: {}
67
67
  },
68
68
  setup(d) {
69
- const r = d, o = y(), a = A(() => {
69
+ const r = d, o = y(), a = D(() => {
70
70
  var e;
71
71
  return {
72
72
  active: ((e = o.pageActive) == null ? void 0 : e.value) === r.name,
73
73
  "i-load-data": r.isLoading || o.isLoadingPage.value
74
74
  };
75
75
  });
76
- return (e, t) => s(o).isReady.value ? (n(), l("div", _, [
77
- (n(), m(h, {
78
- to: "#" + s(o).idAttr + " .modal-layer-header",
79
- disabled: !s(o).needShowPage(e.name)
80
- }, [
81
- i("div", {
82
- "data-order": e.order,
83
- "data-view-page": e.name,
84
- class: u(a.value)
76
+ return (e, t) => {
77
+ const f = _("top-scroll-shadow");
78
+ return n(o).isReady.value ? (s(), l("div", W, [
79
+ (s(), m(h, {
80
+ to: "#" + n(o).idAttr + " .modal-layer-header",
81
+ disabled: !n(o).needShowPage(e.name)
85
82
  }, [
86
- i("div", L, [
87
- i("div", W, [
88
- p(e.$slots, "header")
89
- ]),
90
- i("div", M, [
91
- p(e.$slots, "headerButtons")
92
- ]),
93
- s(B).state.isMobile && e.prevName ? (n(), l("div", {
94
- key: 0,
95
- class: "close",
96
- title: e.$i18n.Common.Back,
97
- "data-top-icon": "",
98
- onClick: t[0] || (t[0] = (K) => s(o).open(e.prevName))
99
- }, null, 8, R)) : (n(), l("div", {
100
- key: 1,
101
- class: "close",
102
- title: e.$i18n.Common.Close,
103
- "data-top-icon": "",
104
- "data-action": "top-dialog-close"
105
- }, null, 8, q))
106
- ])
107
- ], 10, E)
108
- ], 8, ["to", "disabled"])),
109
- (n(), m(h, {
110
- to: "#" + s(o).idAttr + " .modal-layer-body",
111
- disabled: !s(o).needShowPage(e.name)
112
- }, [
113
- i("div", {
114
- "data-order": e.order,
115
- "data-view-page": e.name,
116
- class: u(a.value),
117
- style: g({ "--top-dialog-footer-height": e.$slots.footer ? void 0 : "0px" })
83
+ i("div", {
84
+ "data-order": e.order,
85
+ "data-view-page": e.name,
86
+ class: u(a.value)
87
+ }, [
88
+ i("div", R, [
89
+ i("div", q, [
90
+ p(e.$slots, "header")
91
+ ]),
92
+ i("div", z, [
93
+ p(e.$slots, "headerButtons")
94
+ ]),
95
+ n(E).state.isMobile && e.prevName ? (s(), l("div", {
96
+ key: 0,
97
+ class: "close",
98
+ title: e.$i18n.Common.Back,
99
+ "data-top-icon": "",
100
+ onClick: t[0] || (t[0] = (j) => n(o).open(e.prevName))
101
+ }, null, 8, I)) : (s(), l("div", {
102
+ key: 1,
103
+ class: "close",
104
+ title: e.$i18n.Common.Close,
105
+ "data-top-icon": "",
106
+ "data-action": "top-dialog-close"
107
+ }, null, 8, V))
108
+ ])
109
+ ], 10, M)
110
+ ], 8, ["to", "disabled"])),
111
+ (s(), m(h, {
112
+ to: "#" + n(o).idAttr + " .modal-layer-body",
113
+ disabled: !n(o).needShowPage(e.name)
118
114
  }, [
119
- i("div", I, [
120
- p(e.$slots, "body")
121
- ]),
122
- e.$slots.footer ? (n(), l("div", V, [
123
- p(e.$slots, "footer")
124
- ])) : c("", !0)
125
- ], 14, z)
126
- ], 8, ["to", "disabled"]))
127
- ])) : c("", !0);
115
+ i("div", {
116
+ "data-order": e.order,
117
+ "data-view-page": e.name,
118
+ class: u(["has_scroll_container", a.value]),
119
+ style: c({ "--top-dialog-footer-height": e.$slots.footer ? void 0 : "0px" })
120
+ }, [
121
+ k((s(), l("div", O, [
122
+ p(e.$slots, "body")
123
+ ])), [
124
+ [f]
125
+ ]),
126
+ e.$slots.footer ? (s(), l("div", U, [
127
+ p(e.$slots, "footer")
128
+ ])) : g("", !0)
129
+ ], 14, K)
130
+ ], 8, ["to", "disabled"]))
131
+ ])) : g("", !0);
132
+ };
128
133
  }
129
- }), H = {
134
+ }), X = {
130
135
  name: {
131
136
  type: String,
132
137
  required: !0
@@ -136,7 +141,7 @@ const S = ["id", "data-view-page-active", "data-modal", "data-position"], F = /*
136
141
  required: !0
137
142
  },
138
143
  prevName: String
139
- }, J = /* @__PURE__ */ v({
144
+ }, Y = /* @__PURE__ */ v({
140
145
  __name: "pageComponent",
141
146
  props: {
142
147
  component: {},
@@ -157,27 +162,27 @@ const S = ["id", "data-view-page-active", "data-modal", "data-position"], F = /*
157
162
  }
158
163
  };
159
164
  if (r.component.name === "AsyncComponentWrapper") {
160
- const e = k(!1);
161
- T(() => {
165
+ const e = T(!1);
166
+ $(() => {
162
167
  a(r.component, e);
163
168
  });
164
169
  }
165
- return (e, t) => (n(), m(D, {
170
+ return (e, t) => (s(), m(P, {
166
171
  include: e.keepAlive ? "" : "none"
167
172
  }, [
168
- s(o).needShowPage(e.name) ? (n(), m($(e.component), P({ key: 0 }, r, {
173
+ n(o).needShowPage(e.name) ? (s(), m(N(e.component), B({ key: 0 }, r, {
169
174
  name: e.name,
170
175
  order: e.order,
171
176
  prevName: e.prevName
172
- }), null, 16, ["name", "order", "prevName"])) : c("", !0)
177
+ }), null, 16, ["name", "order", "prevName"])) : g("", !0)
173
178
  ], 1032, ["include"]));
174
179
  }
175
180
  });
176
181
  export {
177
- F as TopDialog,
178
- G as TopDialogPage,
179
- J as TopDialogPageComponent,
180
- H as propsPageCommon,
182
+ J as TopDialog,
183
+ Q as TopDialogPage,
184
+ Y as TopDialogPageComponent,
185
+ X as propsPageCommon,
181
186
  y as useTopDialogSelf
182
187
  };
183
188
  //# sourceMappingURL=dialog.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"dialog.js","sources":["../../src/components/dialog/dialog/dialog.vue","../../src/components/dialog/dialog/page/page.vue","../../src/components/dialog/dialog/page/types.ts","../../src/components/dialog/dialog/pageComponent/pageComponent.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport type { ComponentInternalInstance } from 'vue';\r\nimport { getCurrentInstance, onMounted, provide, watch } from 'vue';\r\nimport { getDialogWorker } from './dialogs/dialogs.vue';\r\nimport type { Emits, Props, Slots } from './types';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\twidth: '600px',\r\n\theight: 'auto',\r\n\tmodal: true,\r\n\thistoryType: 'push',\r\n});\r\n\r\ndefineEmits<Emits>();\r\n\r\ndefineSlots<Slots>();\r\n\r\nconst dialog = getDialogWorker(props.id);\r\nif (!dialog) {\r\n\tthrow new Error('TopDialog cannot be used in a template, use useTopDialog() / useAsyncTopDialog()');\r\n}\r\n\r\n/**\r\n * Для useTopDialogSelf()\r\n */\r\nprovide('dialogWorker', dialog);\r\n\r\n/**\r\n * Инициализация начального состояния TopDialogHandle\r\n */\r\nonMounted(() => {\r\n\tconst topDialogBaseComponent = getCurrentInstance() as ComponentInternalInstance;\r\n\tconst topDialogComponent = topDialogBaseComponent.parent;\r\n\r\n\tif (topDialogComponent?.parent?.type.name !== 'DialogWrapper') {\r\n\t\tthrow new Error('TopDialog cannot be used in a template, use useTopDialog()');\r\n\t}\r\n\r\n\tif (Array.isArray(topDialogComponent.subTree.children) && topDialogComponent.subTree.children.length !== 1) {\r\n\t\tthrow new Error('TopDialog can has only one root element');\r\n\t}\r\n\r\n\tdialog.onMounted(topDialogComponent, topDialogBaseComponent);\r\n});\r\n\r\nwatch(dialog.isOpened, () => {\r\n\tdialog.isReady.value = true;\r\n}, {\r\n\tflush: 'post',\r\n\tonce: true,\r\n});\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\t:id=\"dialog.idAttr\"\r\n\t\tclass=\"top-dialog\"\r\n\t\t:class=\"classes\"\r\n\t\t:style=\"{\r\n\t\t\t\t'--top-dialog-width': width,\r\n\t\t\t\t'--top-dialog-height': height,\r\n\t\t\t}\"\r\n\t\ttabindex=\"-1\"\r\n\t\t:data-view-page-active=\"dialog.pageActive.value\"\r\n\t\t:data-modal=\"modal\"\r\n\t\t:data-position=\"position\"\r\n\t>\r\n\t\t<div class=\"modal-layer modal-layer-header\"></div>\r\n\r\n\t\t<div class=\"modal-layer modal-layer-body\" :style=\"{'min-height': height + 'px'}\"></div>\r\n\r\n\t\t<slot name=\"default\"></slot>\r\n\t</div>\r\n</template>\r\n","<script setup lang=\"ts\">\r\nimport { computed } from 'vue';\r\nimport Core from '@/core/core/core';\r\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\r\nimport type { Props, Slots } from './types';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\torder: 0,\r\n});\r\n\r\ndefineSlots<Slots>();\r\n\r\nconst dialog = useTopDialogSelf();\r\n\r\nconst classes = computed(() => {\r\n\treturn {\r\n\t\tactive: dialog.pageActive?.value === props.name,\r\n\t\t'i-load-data': props.isLoading || dialog.isLoadingPage.value,\r\n\t};\r\n});\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\tstyle=\"display: none\"\r\n\t\tv-if=\"dialog.isReady.value\"\r\n\t>\r\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-header'\" :disabled=\"!dialog.needShowPage(name)\">\r\n\t\t\t<div\r\n\t\t\t\t:data-order=\"order\"\r\n\t\t\t\t:data-view-page=\"name\"\r\n\t\t\t\t:class=\"classes\"\r\n\t\t\t>\r\n\t\t\t\t<div class=\"modal-header\">\r\n\t\t\t\t\t<div class=\"top-title\">\r\n\t\t\t\t\t\t<slot name=\"header\"></slot>\r\n\t\t\t\t\t</div>\r\n\r\n\t\t\t\t\t<div class=\"buttons\">\r\n\t\t\t\t\t\t<slot name=\"headerButtons\"></slot>\r\n\t\t\t\t\t</div>\r\n\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tv-if=\"Core.state.isMobile && prevName\"\r\n\t\t\t\t\t\tclass=\"close\"\r\n\t\t\t\t\t\t:title=\"$i18n.Common.Back\"\r\n\t\t\t\t\t\tdata-top-icon=\"\"\r\n\t\t\t\t\t\t@click=\"dialog.open(prevName)\"\r\n\t\t\t\t\t></div>\r\n\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tv-else\r\n\t\t\t\t\t\tclass=\"close\"\r\n\t\t\t\t\t\t:title=\"$i18n.Common.Close\"\r\n\t\t\t\t\t\tdata-top-icon=\"\"\r\n\t\t\t\t\t\tdata-action=\"top-dialog-close\"\r\n\t\t\t\t\t></div>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</Teleport>\r\n\r\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-body'\" :disabled=\"!dialog.needShowPage(name)\">\r\n\t\t\t<div\r\n\t\t\t\t:data-order=\"order\"\r\n\t\t\t\t:data-view-page=\"name\"\r\n\t\t\t\t:class=\"classes\"\r\n\t\t\t\t:style=\"{'--top-dialog-footer-height': $slots.footer ? undefined : '0px'}\"\r\n\t\t\t>\r\n\t\t\t\t<div class=\"modal-body\">\r\n\t\t\t\t\t<slot name=\"body\"></slot>\r\n\t\t\t\t</div>\r\n\r\n\t\t\t\t<div class=\"modal-footer\" v-if=\"$slots.footer\">\r\n\t\t\t\t\t<slot name=\"footer\"></slot>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</Teleport>\r\n\t</div>\r\n</template>\r\n","export interface Props extends PropsCommon {\r\n\t/**\r\n\t * Статус загрузки страницы диалогового окна\r\n\t *\r\n\t * При включении взаимодействие со страницей блокируется, отображается анимация загрузки\r\n\t */\r\n\tisLoading?: boolean;\r\n}\r\n\r\n/**\r\n * Общие props для компонентов реализуюущих TopDialogPage\r\n */\r\nexport interface PropsCommon {\r\n\t/**\r\n\t * Имя страницы для диалогового окна\r\n\t *\r\n\t * Имя страницы нужно для навигации между страницами в одном диалоговом окне\r\n\t */\r\n\tname: string,\r\n\r\n\t/**\r\n\t * Порядкой номер страницы в диалоговом окне\r\n\t *\r\n\t * Одна и та же страница может быть подключена в разные диалоговые окна и иметь разный порядковый номер\r\n\t */\r\n\torder: number,\r\n\r\n\t/**\r\n\t * Имя предыдущей страницы\r\n\t *\r\n\t * Для кнопки Назад / Закрыть в мобильной версии\r\n\t */\r\n\tprevName?: string,\r\n}\r\n\r\n/**\r\n * Общие props для компонентов реализуюущих TopDialogPage\r\n *\r\n * Для не SFC компонентов\r\n */\r\nexport const propsPageCommon = {\r\n\tname: {\r\n\t\ttype: String,\r\n\t\trequired: true,\r\n\t},\r\n\r\n\torder: {\r\n\t\ttype: Number,\r\n\t\trequired: true,\r\n\t},\r\n\r\n\tprevName: String,\r\n};\r\n\r\nexport interface Slots {\r\n\t/**\r\n\t * Шапка страницы\r\n\t */\r\n\theader(props: {}): any;\r\n\r\n\t/**\r\n\t * Кнопки для шапки страницы\r\n\t */\r\n\theaderButtons(props: {}): any;\r\n\r\n\t/**\r\n\t * Контент страницы\r\n\t */\r\n\tbody(props: {}): any;\r\n\r\n\t/**\r\n\t * Футер страницы\r\n\t */\r\n\tfooter(props: {}): any;\r\n}\r\n","<script setup lang=\"ts\">\r\nimport { type Component, onUpdated, ref, type Ref } from 'vue';\r\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\r\nimport type { Props } from './types';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tkeepAlive: true,\r\n});\r\n\r\nconst dialog = useTopDialogSelf();\r\n\r\n/**\r\n * Статус загрузи асинхронного компонента страницы диалогового окна\r\n */\r\nconst updateIsLoadingAsyncPage = (component: Component, isLoaded: Ref) => {\r\n\tif (isLoaded.value) return;\r\n\r\n\tif (component.name !== 'AsyncComponentWrapper') {\r\n\t\tisLoaded.value = true;\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tif (!dialog.needShowPage(props.name as string)) return;\r\n\r\n\tdialog.isLoadingPage.value = true;\r\n\r\n\t// @ts-ignore\r\n\tif (component.__asyncResolved) {\r\n\t\tisLoaded.value = true;\r\n\r\n\t\tdialog.isLoadingPage.value = false;\r\n\t}\r\n};\r\n\r\nif (props.component.name === 'AsyncComponentWrapper') {\r\n\tconst isLoaded = ref(false);\r\n\r\n\tonUpdated(() => {\r\n\t\tupdateIsLoadingAsyncPage(props.component, isLoaded);\r\n\t});\r\n}\r\n</script>\r\n\r\n<template>\r\n\t<!-- Teleport внутри при keepAlive размонитроваться не будет, см. TopDialogPage -->\r\n\t<KeepAlive :include=\"keepAlive ? '' : 'none'\">\r\n\t\t<Component\r\n\t\t\t:is=\"component\"\r\n\t\t\tv-if=\"dialog.needShowPage(name)\"\r\n\t\t\t:=\"props\"\r\n\t\t\t:name=\"name\"\r\n\t\t\t:order=\"order\"\r\n\t\t\t:prevName=\"prevName\"\r\n\t\t/>\r\n\t</KeepAlive>\r\n</template>\r\n"],"names":["dialog","getDialogWorker","__props","provide","onMounted","topDialogBaseComponent","getCurrentInstance","topDialogComponent","_a","watch","props","useTopDialogSelf","classes","computed","propsPageCommon","updateIsLoadingAsyncPage","component","isLoaded","ref","onUpdated"],"mappings":";;;;;;;;;;;;;;;;;AAiBM,UAAAA,IAASC,EAXDC,EAWuB,EAAE;AACvC,QAAI,CAACF;AACE,YAAA,IAAI,MAAM,kFAAkF;AAMnG,WAAAG,EAAQ,gBAAgBH,CAAM,GAK9BI,EAAU,MAAM;;AACf,YAAMC,IAAyBC,KACzBC,IAAqBF,EAAuB;AAElD,YAAIG,IAAAD,KAAA,gBAAAA,EAAoB,WAApB,gBAAAC,EAA4B,KAAK,UAAS;AACvC,cAAA,IAAI,MAAM,4DAA4D;AAGzE,UAAA,MAAM,QAAQD,EAAmB,QAAQ,QAAQ,KAAKA,EAAmB,QAAQ,SAAS,WAAW;AAClG,cAAA,IAAI,MAAM,yCAAyC;AAGnD,MAAAP,EAAA,UAAUO,GAAoBF,CAAsB;AAAA,IAAA,CAC3D,GAEKI,EAAAT,EAAO,UAAU,MAAM;AAC5B,MAAAA,EAAO,QAAQ,QAAQ;AAAA,IAAA,GACrB;AAAA,MACF,OAAO;AAAA,MACP,MAAM;AAAA,IAAA,CACN;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC5CD,UAAMU,IAAQR,GAMRF,IAASW,KAETC,IAAUC,EAAS,MAAM;;AACvB,aAAA;AAAA,QACN,UAAQL,IAAAR,EAAO,eAAP,gBAAAQ,EAAmB,WAAUE,EAAM;AAAA,QAC3C,eAAeA,EAAM,aAAaV,EAAO,cAAc;AAAA,MAAA;AAAA,IACxD,CACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ICqBYc,IAAkB;AAAA,EAC9B,MAAM;AAAA,IACL,MAAM;AAAA,IACN,UAAU;AAAA,EACX;AAAA,EAEA,OAAO;AAAA,IACN,MAAM;AAAA,IACN,UAAU;AAAA,EACX;AAAA,EAEA,UAAU;AACX;;;;;;;;;;;AC/CA,UAAMJ,IAAQR,GAIRF,IAASW,KAKTI,IAA2B,CAACC,GAAsBC,MAAkB;AACzE,UAAI,CAAAA,EAAS,OAET;AAAA,YAAAD,EAAU,SAAS,yBAAyB;AAC/C,UAAAC,EAAS,QAAQ;AAEjB;AAAA,QACD;AAEA,QAAKjB,EAAO,aAAaU,EAAM,IAAc,MAE7CV,EAAO,cAAc,QAAQ,IAGzBgB,EAAU,oBACbC,EAAS,QAAQ,IAEjBjB,EAAO,cAAc,QAAQ;AAAA;AAAA,IAC9B;AAGG,QAAAU,EAAM,UAAU,SAAS,yBAAyB;AAC/C,YAAAO,IAAWC,EAAI,EAAK;AAE1B,MAAAC,EAAU,MAAM;AACU,QAAAJ,EAAAL,EAAM,WAAWO,CAAQ;AAAA,MAAA,CAClD;AAAA,IACF;;;;;;;;;;;;"}
1
+ {"version":3,"file":"dialog.js","sources":["../../src/components/dialog/dialog/dialog.vue","../../src/components/dialog/dialog/page/page.vue","../../src/components/dialog/dialog/page/types.ts","../../src/components/dialog/dialog/pageComponent/pageComponent.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport type { ComponentInternalInstance } from 'vue';\r\nimport { getCurrentInstance, onMounted, provide, watch } from 'vue';\r\nimport { getDialogWorker } from './dialogs/dialogs.vue';\r\nimport type { Emits, Props, Slots } from './types';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\twidth: '600px',\r\n\theight: 'auto',\r\n\tmodal: true,\r\n\thistoryType: 'push',\r\n});\r\n\r\ndefineEmits<Emits>();\r\n\r\ndefineSlots<Slots>();\r\n\r\nconst dialog = getDialogWorker(props.id);\r\nif (!dialog) {\r\n\tthrow new Error('TopDialog cannot be used in a template, use useTopDialog() / useAsyncTopDialog()');\r\n}\r\n\r\n/**\r\n * Для useTopDialogSelf()\r\n */\r\nprovide('dialogWorker', dialog);\r\n\r\n/**\r\n * Инициализация начального состояния TopDialogHandle\r\n */\r\nonMounted(() => {\r\n\tconst topDialogBaseComponent = getCurrentInstance() as ComponentInternalInstance;\r\n\tconst topDialogComponent = topDialogBaseComponent.parent;\r\n\r\n\tif (topDialogComponent?.parent?.type.name !== 'DialogWrapper') {\r\n\t\tthrow new Error('TopDialog cannot be used in a template, use useTopDialog()');\r\n\t}\r\n\r\n\tif (Array.isArray(topDialogComponent.subTree.children) && topDialogComponent.subTree.children.length !== 1) {\r\n\t\tthrow new Error('TopDialog can has only one root element');\r\n\t}\r\n\r\n\tdialog.onMounted(topDialogComponent, topDialogBaseComponent);\r\n});\r\n\r\nwatch(dialog.isOpened, () => {\r\n\tdialog.isReady.value = true;\r\n}, {\r\n\tflush: 'post',\r\n\tonce: true,\r\n});\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\t:id=\"dialog.idAttr\"\r\n\t\tclass=\"top-dialog\"\r\n\t\t:class=\"classes\"\r\n\t\t:style=\"{\r\n\t\t\t\t'--top-dialog-width': width,\r\n\t\t\t\t'--top-dialog-height': height,\r\n\t\t\t}\"\r\n\t\ttabindex=\"-1\"\r\n\t\t:data-view-page-active=\"dialog.pageActive.value\"\r\n\t\t:data-modal=\"modal\"\r\n\t\t:data-position=\"position\"\r\n\t>\r\n\t\t<div class=\"modal-layer modal-layer-header\"></div>\r\n\r\n\t\t<div class=\"modal-layer modal-layer-body\" :style=\"{'min-height': height + 'px'}\"></div>\r\n\r\n\t\t<slot name=\"default\"></slot>\r\n\t</div>\r\n</template>\r\n","<script setup lang=\"ts\">\r\nimport { computed } from 'vue';\r\nimport Core from '@/core/core/core';\r\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\r\nimport type { Props, Slots } from './types';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\torder: 0,\r\n});\r\n\r\ndefineSlots<Slots>();\r\n\r\nconst dialog = useTopDialogSelf();\r\n\r\nconst classes = computed(() => {\r\n\treturn {\r\n\t\tactive: dialog.pageActive?.value === props.name,\r\n\t\t'i-load-data': props.isLoading || dialog.isLoadingPage.value,\r\n\t};\r\n});\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\tstyle=\"display: none\"\r\n\t\tv-if=\"dialog.isReady.value\"\r\n\t>\r\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-header'\" :disabled=\"!dialog.needShowPage(name)\">\r\n\t\t\t<div\r\n\t\t\t\t:data-order=\"order\"\r\n\t\t\t\t:data-view-page=\"name\"\r\n\t\t\t\t:class=\"classes\"\r\n\t\t\t>\r\n\t\t\t\t<div class=\"modal-header\">\r\n\t\t\t\t\t<div class=\"top-title\">\r\n\t\t\t\t\t\t<slot name=\"header\"></slot>\r\n\t\t\t\t\t</div>\r\n\r\n\t\t\t\t\t<div class=\"buttons\">\r\n\t\t\t\t\t\t<slot name=\"headerButtons\"></slot>\r\n\t\t\t\t\t</div>\r\n\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tv-if=\"Core.state.isMobile && prevName\"\r\n\t\t\t\t\t\tclass=\"close\"\r\n\t\t\t\t\t\t:title=\"$i18n.Common.Back\"\r\n\t\t\t\t\t\tdata-top-icon=\"\"\r\n\t\t\t\t\t\t@click=\"dialog.open(prevName)\"\r\n\t\t\t\t\t></div>\r\n\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tv-else\r\n\t\t\t\t\t\tclass=\"close\"\r\n\t\t\t\t\t\t:title=\"$i18n.Common.Close\"\r\n\t\t\t\t\t\tdata-top-icon=\"\"\r\n\t\t\t\t\t\tdata-action=\"top-dialog-close\"\r\n\t\t\t\t\t></div>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</Teleport>\r\n\r\n\t\t<Teleport :to=\"'#' + dialog.idAttr + ' .modal-layer-body'\" :disabled=\"!dialog.needShowPage(name)\">\r\n\t\t\t<div\r\n\t\t\t\t:data-order=\"order\"\r\n\t\t\t\t:data-view-page=\"name\"\r\n\t\t\t\tclass=\"has_scroll_container\"\r\n\t\t\t\t:class=\"classes\"\r\n\t\t\t\t:style=\"{'--top-dialog-footer-height': $slots.footer ? undefined : '0px'}\"\r\n\t\t\t>\r\n\t\t\t\t<div class=\"modal-body\" v-top-scroll-shadow>\r\n\t\t\t\t\t<slot name=\"body\"></slot>\r\n\t\t\t\t</div>\r\n\r\n\t\t\t\t<div class=\"modal-footer\" v-if=\"$slots.footer\">\r\n\t\t\t\t\t<slot name=\"footer\"></slot>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</Teleport>\r\n\t</div>\r\n</template>\r\n","export interface Props extends PropsCommon {\r\n\t/**\r\n\t * Статус загрузки страницы диалогового окна\r\n\t *\r\n\t * При включении взаимодействие со страницей блокируется, отображается анимация загрузки\r\n\t */\r\n\tisLoading?: boolean;\r\n}\r\n\r\n/**\r\n * Общие props для компонентов реализуюущих TopDialogPage\r\n */\r\nexport interface PropsCommon {\r\n\t/**\r\n\t * Имя страницы для диалогового окна\r\n\t *\r\n\t * Имя страницы нужно для навигации между страницами в одном диалоговом окне\r\n\t */\r\n\tname: string,\r\n\r\n\t/**\r\n\t * Порядкой номер страницы в диалоговом окне\r\n\t *\r\n\t * Одна и та же страница может быть подключена в разные диалоговые окна и иметь разный порядковый номер\r\n\t */\r\n\torder: number,\r\n\r\n\t/**\r\n\t * Имя предыдущей страницы\r\n\t *\r\n\t * Для кнопки Назад / Закрыть в мобильной версии\r\n\t */\r\n\tprevName?: string,\r\n}\r\n\r\n/**\r\n * Общие props для компонентов реализуюущих TopDialogPage\r\n *\r\n * Для не SFC компонентов\r\n */\r\nexport const propsPageCommon = {\r\n\tname: {\r\n\t\ttype: String,\r\n\t\trequired: true,\r\n\t},\r\n\r\n\torder: {\r\n\t\ttype: Number,\r\n\t\trequired: true,\r\n\t},\r\n\r\n\tprevName: String,\r\n};\r\n\r\nexport interface Slots {\r\n\t/**\r\n\t * Шапка страницы\r\n\t */\r\n\theader(props: {}): any;\r\n\r\n\t/**\r\n\t * Кнопки для шапки страницы\r\n\t */\r\n\theaderButtons(props: {}): any;\r\n\r\n\t/**\r\n\t * Контент страницы\r\n\t */\r\n\tbody(props: {}): any;\r\n\r\n\t/**\r\n\t * Футер страницы\r\n\t */\r\n\tfooter(props: {}): any;\r\n}\r\n","<script setup lang=\"ts\">\r\nimport { type Component, onUpdated, ref, type Ref } from 'vue';\r\nimport { useTopDialogSelf } from '@/components/dialog/dialog/composables/utils';\r\nimport type { Props } from './types';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tkeepAlive: true,\r\n});\r\n\r\nconst dialog = useTopDialogSelf();\r\n\r\n/**\r\n * Статус загрузи асинхронного компонента страницы диалогового окна\r\n */\r\nconst updateIsLoadingAsyncPage = (component: Component, isLoaded: Ref) => {\r\n\tif (isLoaded.value) return;\r\n\r\n\tif (component.name !== 'AsyncComponentWrapper') {\r\n\t\tisLoaded.value = true;\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tif (!dialog.needShowPage(props.name as string)) return;\r\n\r\n\tdialog.isLoadingPage.value = true;\r\n\r\n\t// @ts-ignore\r\n\tif (component.__asyncResolved) {\r\n\t\tisLoaded.value = true;\r\n\r\n\t\tdialog.isLoadingPage.value = false;\r\n\t}\r\n};\r\n\r\nif (props.component.name === 'AsyncComponentWrapper') {\r\n\tconst isLoaded = ref(false);\r\n\r\n\tonUpdated(() => {\r\n\t\tupdateIsLoadingAsyncPage(props.component, isLoaded);\r\n\t});\r\n}\r\n</script>\r\n\r\n<template>\r\n\t<!-- Teleport внутри при keepAlive размонитроваться не будет, см. TopDialogPage -->\r\n\t<KeepAlive :include=\"keepAlive ? '' : 'none'\">\r\n\t\t<Component\r\n\t\t\t:is=\"component\"\r\n\t\t\tv-if=\"dialog.needShowPage(name)\"\r\n\t\t\t:=\"props\"\r\n\t\t\t:name=\"name\"\r\n\t\t\t:order=\"order\"\r\n\t\t\t:prevName=\"prevName\"\r\n\t\t/>\r\n\t</KeepAlive>\r\n</template>\r\n"],"names":["dialog","getDialogWorker","__props","provide","onMounted","topDialogBaseComponent","getCurrentInstance","topDialogComponent","_a","watch","props","useTopDialogSelf","classes","computed","propsPageCommon","updateIsLoadingAsyncPage","component","isLoaded","ref","onUpdated"],"mappings":";;;;;;;;;;;;;;;;;AAiBM,UAAAA,IAASC,EAXDC,EAWuB,EAAE;AACvC,QAAI,CAACF;AACE,YAAA,IAAI,MAAM,kFAAkF;AAMnG,WAAAG,EAAQ,gBAAgBH,CAAM,GAK9BI,EAAU,MAAM;;AACf,YAAMC,IAAyBC,EAAmB,GAC5CC,IAAqBF,EAAuB;AAElD,YAAIG,IAAAD,KAAA,gBAAAA,EAAoB,WAApB,gBAAAC,EAA4B,KAAK,UAAS;AACvC,cAAA,IAAI,MAAM,4DAA4D;AAGzE,UAAA,MAAM,QAAQD,EAAmB,QAAQ,QAAQ,KAAKA,EAAmB,QAAQ,SAAS,WAAW;AAClG,cAAA,IAAI,MAAM,yCAAyC;AAGnD,MAAAP,EAAA,UAAUO,GAAoBF,CAAsB;AAAA,IAAA,CAC3D,GAEKI,EAAAT,EAAO,UAAU,MAAM;AAC5B,MAAAA,EAAO,QAAQ,QAAQ;AAAA,IAAA,GACrB;AAAA,MACF,OAAO;AAAA,MACP,MAAM;AAAA,IAAA,CACN;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC5CD,UAAMU,IAAQR,GAMRF,IAASW,EAAiB,GAE1BC,IAAUC,EAAS,MAAM;;AACvB,aAAA;AAAA,QACN,UAAQL,IAAAR,EAAO,eAAP,gBAAAQ,EAAmB,WAAUE,EAAM;AAAA,QAC3C,eAAeA,EAAM,aAAaV,EAAO,cAAc;AAAA,MACxD;AAAA,IAAA,CACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ICqBYc,IAAkB;AAAA,EAC9B,MAAM;AAAA,IACL,MAAM;AAAA,IACN,UAAU;AAAA,EACX;AAAA,EAEA,OAAO;AAAA,IACN,MAAM;AAAA,IACN,UAAU;AAAA,EACX;AAAA,EAEA,UAAU;AACX;;;;;;;;;;;AC/CA,UAAMJ,IAAQR,GAIRF,IAASW,EAAiB,GAK1BI,IAA2B,CAACC,GAAsBC,MAAkB;AACzE,UAAI,CAAAA,EAAS,OAET;AAAA,YAAAD,EAAU,SAAS,yBAAyB;AAC/C,UAAAC,EAAS,QAAQ;AAEjB;AAAA,QAAA;AAGD,QAAKjB,EAAO,aAAaU,EAAM,IAAc,MAE7CV,EAAO,cAAc,QAAQ,IAGzBgB,EAAU,oBACbC,EAAS,QAAQ,IAEjBjB,EAAO,cAAc,QAAQ;AAAA;AAAA,IAE/B;AAEI,QAAAU,EAAM,UAAU,SAAS,yBAAyB;AAC/C,YAAAO,IAAWC,EAAI,EAAK;AAE1B,MAAAC,EAAU,MAAM;AACU,QAAAJ,EAAAL,EAAM,WAAWO,CAAQ;AAAA,MAAA,CAClD;AAAA,IAAA;;;;;;;;;;;;"}
@@ -1,2 +1,2 @@
1
- define(["require","exports","../.chunks/forms-CORLOoYZ.amd"],function(n,T,a){"use strict";if(typeof e>"u")var e=window.Vue;T.TopAvatar=a.TopAvatar,T.TopButton=a.TopButton,T.TopCheckbox=a.TopCheckbox,T.TopControlLabel=a.TopControlLabel,T.TopHint=a.TopHint,T.TopInput=a.TopInput,T.TopInputDate=a.TopInputDate,T.TopInputRange=a.TopInputRange,T.TopLoadbar=a.TopLoadbar,T.TopRadio=a.TopRadio,T.TopSelect=a.TopSelect,T.TopSwitcher=a.TopSwitcher,T.TopTextarea=a.TopTextarea,Object.defineProperty(T,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","../.chunks/forms-CgS7En_e.amd"],function(n,T,a){"use strict";if(typeof e>"u")var e=window.Vue;T.TopAvatar=a.TopAvatar,T.TopButton=a.TopButton,T.TopCheckbox=a.TopCheckbox,T.TopControlLabel=a.TopControlLabel,T.TopHint=a.TopHint,T.TopInput=a.TopInput,T.TopInputDate=a.TopInputDate,T.TopInputRange=a.TopInputRange,T.TopLoadbar=a.TopLoadbar,T.TopRadio=a.TopRadio,T.TopSelect=a.TopSelect,T.TopSwitcher=a.TopSwitcher,T.TopTextarea=a.TopTextarea,Object.defineProperty(T,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=forms.amd.js.map
package/forms/forms.js CHANGED
@@ -1,4 +1,4 @@
1
- import { T as p, f as T, g as s, h as t, j as e, k as n, l as r, m as l, n as u, o as b, p as c, q as h, r as i } from "../.chunks/forms-DmpPuKKh.es.js";
1
+ import { T as p, f as T, g as s, h as t, j as e, k as n, l as r, m as l, n as u, o as b, p as c, q as h, r as i } from "../.chunks/forms-cAFIQajo.es.js";
2
2
  export {
3
3
  p as TopAvatar,
4
4
  T as TopButton,
@@ -1 +1 @@
1
- {"version":3,"file":"helpers.amd.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\r\n * Размеры\r\n */\r\nexport const sizes = {\r\n\txs: 'xs',\r\n\ts: 's',\r\n\tm: 'm',\r\n\tl: 'l',\r\n} as const;\r\n\r\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"yFAGO,MAAAA,EAAA,0BAKP"}
1
+ {"version":3,"file":"helpers.amd.js","sources":["../../src/components/forms/helpers.ts"],"sourcesContent":["/**\r\n * Размеры\r\n */\r\nexport const sizes = {\r\n\txs: 'xs',\r\n\ts: 's',\r\n\tm: 'm',\r\n\tl: 'l',\r\n} as const;\r\n\r\nexport type Size = typeof sizes[keyof typeof sizes];"],"names":["sizes"],"mappings":"yFAGO,MAAAA,EAAA,qBAGH,EAAA,GAEJ"}
@@ -1,2 +1,2 @@
1
- define(["require","exports","vue","../.chunks/forms-CORLOoYZ.amd","../utils/keyboard.amd","../popup/popup.amd","../.chunks/menu.vue_vue_type_style_index_0_lang-Chd1ygyG.amd","../require/css.amd!../assets/formsExt.css"],function(Y,w,e,V,S,C,I){"use strict";if(typeof e>"u")var e=window.Vue;const N={class:"top-editArea_footer"},M=e.defineComponent({__name:"editArea",props:{defaultValue:{default:""},title:{},cancelText:{default:"Cancel"},submitText:{default:"Send"},closeText:{default:"Close"},isFocused:{type:Boolean},forceShowCloseBtn:{type:Boolean},attachToKeyboard:{type:Boolean},modelValue:{},name:{},placeholder:{},rows:{},minHeight:{},expandable:{type:Boolean,default:!0},disabled:{type:Boolean},readonly:{type:Boolean},isError:{type:Boolean},hint:{}},emits:["submit","close","clickOnTitle"],setup(i,{emit:c}){const t=i,n=c,m=e.ref(t.defaultValue),f=e.ref(t.isFocused),s=e.computed(()=>m.value!==t.defaultValue),p=e.computed(()=>t.attachToKeyboard?"":t.forceShowCloseBtn&&!s.value?t.closeText:t.cancelText),u=d=>{n("submit",d),m.value=t.defaultValue},v=()=>{if(t.forceShowCloseBtn&&!s.value){n("close");return}m.value=t.defaultValue},h=()=>{t.attachToKeyboard&&n("clickOnTitle")};return(d,l)=>{const B=e.resolveDirective("top-focus");return e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-editArea":!0,"top-editArea-attachedToKeyboard":d.attachToKeyboard})},[d.title?(e.openBlock(),e.createElementBlock("div",{key:0,class:"top-editArea_title",onClick:l[0]||(l[0]=y=>h())},e.toDisplayString(d.title),1)):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass({"top-editArea_form":!0,"top-error":d.isError,"top-focus":f.value})},[e.withDirectives(e.createVNode(V._sfc_main$3,{modelValue:m.value,"onUpdate:modelValue":l[1]||(l[1]=y=>m.value=y),name:d.name,placeholder:d.placeholder,rows:d.rows,minHeight:d.minHeight,expandable:d.expandable,disabled:d.disabled,readonly:d.readonly,isError:d.isError,hint:d.hint,class:"top-editArea_element",onFocus:l[2]||(l[2]=()=>f.value=!0),onBlur:l[3]||(l[3]=()=>f.value=!1),onKeyup:[e.withKeys(v,["esc"]),l[4]||(l[4]=e.withKeys(e.withModifiers(y=>u(m.value),["ctrl"]),["enter"]))]},null,8,["modelValue","name","placeholder","rows","minHeight","expandable","disabled","readonly","isError","hint"]),[[B,{disabled:!f.value}]]),e.createElementVNode("div",N,[s.value||d.forceShowCloseBtn?(e.openBlock(),e.createBlock(V._sfc_main,{key:0,class:"top-editArea_button",color:"theme",styling:"soft",icon:d.attachToKeyboard?"":"",onClick:v},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(p.value),1)]),_:1},8,["icon"])):e.createCommentVNode("",!0),s.value?(e.openBlock(),e.createBlock(V._sfc_main,{key:1,class:"top-editArea_button",icon:d.attachToKeyboard?"":"",onClick:l[5]||(l[5]=y=>u(m.value))},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(d.attachToKeyboard?"":d.submitText),1)]),_:1},8,["icon"])):e.createCommentVNode("",!0)])],2)],2)}}}),$={class:"top-editInput"},L=e.defineComponent({__name:"editInput",props:{modelValue:{},input:{},button:{}},emits:["update:modelValue"],setup(i,{emit:c}){const t=i,n=e.ref(t.modelValue);e.watch(e.toRef(t.modelValue),()=>{n.value=t.modelValue});const m=c,f=()=>{m("update:modelValue",n.value)};return(s,p)=>(e.openBlock(),e.createElementBlock("div",$,[e.createVNode(V._sfc_main$2,e.mergeProps(s.input,{onKeydownCapture:p[0]||(p[0]=e.withKeys(e.withModifiers(u=>n.value=s.modelValue,["stop"]),["esc"])),onKeydown:e.withKeys(e.withModifiers(f,["stop"]),["enter"]),modelValue:n.value,"onUpdate:modelValue":p[1]||(p[1]=u=>n.value=u)}),null,16,["onKeydown","modelValue"]),n.value!==s.modelValue?(e.openBlock(),e.createBlock(V._sfc_main,e.mergeProps({key:0,icon:"",styling:"soft"},s.button,{onClick:f}),null,16)):e.createCommentVNode("",!0)]))}}),K=["data-top-icon","onClick"],P={key:0,class:"top-radioGroup_circle"},O=["value","disabled"],_=e.defineComponent({__name:"radioGroup",props:e.mergeModels({modelValue:{},radiosProps:{},showIndicator:{type:Boolean},size:{default:"s"},isError:{type:Boolean}},{modelValue:{required:!0},modelModifiers:{}}),emits:e.mergeModels(["update:modelValue"],["update:modelValue"]),setup(i,{emit:c}){const t=e.useModel(i,"modelValue"),n=i,m=e.ref(null);e.watch(t,()=>{var s,p,u,v,h;(s=n.radiosProps)!=null&&s.some(d=>d.value===t.value)||(t.value=((u=(p=n.radiosProps)==null?void 0:p[0])==null?void 0:u.value)??""),(h=(v=m.value)==null?void 0:v.querySelector(".radioGroup_item-selected"))==null||h.scrollIntoView()},{immediate:!0});const f="radioGroup-"+Math.random();return(s,p)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"elRef",ref:m,class:e.normalizeClass({"top-radioGroup":!0,"top-scrollBarXHidding":!0,["top-size_"+s.size]:!!s.size,"top-error":s.isError})},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.radiosProps,u=>(e.openBlock(),e.createElementBlock("label",{class:e.normalizeClass({"top-radioGroup_item-selected":u.value===t.value,"top-radioGroup_item":!0,"top-forms-focusable":!0,"top-disabled":u.disabled}),"data-top-icon":u.icon,onClick:v=>t.value=u.value},[e.createTextVNode(e.toDisplayString(u.title)+" ",1),s.showIndicator?(e.openBlock(),e.createElementBlock("span",P)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":p[0]||(p[0]=v=>t.value=v),name:f,type:"radio",class:e.normalizeClass({"top-unvisible":!0}),value:u.value,disabled:u.disabled},null,8,O),[[e.vModelRadio,t.value]])],10,K))),256))],2))}}),z=(i,c,t)=>{const n=e.ref([]),m=e.ref(!1);let f="",s;i&&!i.params.limit&&(i.params.limit=100);const p=async()=>{if(!i)return;let l,B;if(t&&(i.cache??=new Map,B=JSON.stringify(i.params),l=i.cache.get(B),l))return l;if(m.value=!0,l=await i.call(),m.value=!1,l.errors)return;if(!Array.isArray(l.result)){console.warn("В result ожидался массив");return}const y=l.result.findIndex(b=>b.id===void 0||b.name===void 0);if(y!==-1){console.warn(`В result[${y}] нет id или name`);return}return t&&i.cache.set(B,l),l},u=async()=>{if(!i)return;i.params.offset=0,i.params.search=f;const l=await p();l&&(s=l.nextOffset,n.value=l.result)},v=async()=>{if(!i||!s||m.value)return;i.params.offset=s,i.params.search=f;const l=await p();l&&(s=l.nextOffset,n.value=n.value.concat(l.result))},h=V.debounce(()=>u(),200);return{items:n,isLoading:m,loadAppend:v,setSearchTextAndLoad:(l,B=!0)=>{i&&(l.length<c||l===f&&n.value.length||(f=l,B?h():u()))}}},D={class:"top-selector2_itemMulti top-ellipsis"},F=e.defineComponent({__name:"itemMulti",props:{id:{},name:{}},emits:["delete"],setup(i){return(c,t)=>(e.openBlock(),e.createElementBlock("div",D,[e.createTextVNode(e.toDisplayString(c.name)+" ",1),e.createElementVNode("span",{class:"top-selector2_itemMultiDelete","data-top-icon":"",onClick:t[0]||(t[0]=n=>c.$emit("delete",c.id)),onMousedown:t[1]||(t[1]=e.withModifiers(()=>{},["stop"]))},null,32)]))}}),G={key:0,class:"top-selector2_activeItems"},H={key:1,class:"top-selector2_activeName top-ellipsis"},U=e.defineComponent({__name:"selector2",props:e.mergeModels({modelValue:{},items:{default:()=>[]},multiselect:{type:Boolean},disabled:{type:Boolean},size:{default:"s"},isError:{type:Boolean},apiRequest:{},minLength:{default:0},useCache:{type:Boolean},appendSearchToResult:{type:Boolean},appendAllValue:{type:Boolean},addChanger:{type:Boolean},placeholder:{},showSelectedInInput:{type:Boolean,default:!0}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(i){const c=i,t=e.useModel(i,"modelValue"),n=e.ref(""),m={id:0,name:"Все"},f=e.ref(null),s=()=>{var o;return(o=f.value)==null?void 0:o.popup};window.__STORYBOOK_PREVIEW__&&!c.modelValue&&e.watch(()=>c.multiselect,()=>{t.value=c.multiselect?[]:{id:null,name:""}},{immediate:!0});const p=z(c.apiRequest,c.minLength,c.useCache),u=e.computed(()=>{const o=[];return!c.multiselect&&c.appendAllValue&&o.push(m),c.items.forEach(r=>o.push({...r})),o}),v=(o,r=!0)=>r&&o.id===null?Array.isArray(t.value)?t.value.some(a=>a.id===o.id&&a.name===o.name):o.name===t.value.name:Array.isArray(t.value)?t.value.some(a=>a.id===o.id):o.id===t.value.id,h=e.computed(()=>{const o=n.value.toLowerCase(),r=S.invertKeyboardLayout(o);let a=[];return u.value.forEach(k=>{const g=k.name.toLowerCase();(k.id===Number(o)||g.includes(o)||g.includes(r))&&(g===o||g===r?a.unshift(k):a.push(k))}),a.push(...p.items.value),c.appendSearchToResult&&n.value&&(!a.length||a[0].name.toLowerCase()!==o)&&a.push({id:null,name:n.value}),c.multiselect&&(a=a.filter(k=>!v(k))),a}),d=async o=>{var r,a;if(c.multiselect){if(!Array.isArray(t.value)||v(o))return;const k=[...t.value];k.push({...o}),t.value=k,V.Core.state.isMobile?(r=s())==null||r.close():setTimeout(()=>{var g,T,A,E;(g=s())==null||g.recalcPosition(),(E=(A=(T=s())==null?void 0:T.elPopupWidget)==null?void 0:A.querySelector("input"))==null||E.focus(),n.value&&(h.value.length||(n.value="",p.items.value=[]))})}else n.value&&(n.value="",p.items.value=[]),JSON.stringify(o)!==JSON.stringify(t.value)&&(t.value={...o}),(a=s())==null||a.close()},l=()=>{if(!Array.isArray(t.value)){const r=(u.value.findIndex(a=>a.id===t.value.id)+1)%u.value.length;t.value={...u.value[r]}}},B=async o=>{Array.isArray(t.value)&&(t.value=t.value.filter(r=>r.id!==o),setTimeout(()=>{var r;(r=s())==null||r.recalcPosition()}))},y=e.ref(!1);c.apiRequest&&(e.watch(y,()=>{y.value&&p.setSearchTextAndLoad(n.value,!1)}),e.watch(n,()=>p.setSearchTextAndLoad(n.value)));const b=o=>{const r=o.target;r.scrollTop/(r.scrollHeight-r.offsetHeight)>.8&&p.loadAppend()};return(o,r)=>(e.openBlock(),e.createBlock(e.unref(C.TopPopup),{ref_key:"popupRef",ref:f,onOpen:r[1]||(r[1]=a=>y.value=!0),onClose:r[2]||(r[2]=a=>y.value=!1),onScrollContentList:r[3]||(r[3]=a=>o.apiRequest?b(a):void 0),notch:!1,transitionDuration:0},{opener:e.withCtx(()=>[e.createElementVNode("div",{class:e.normalizeClass({"top-selector2":!0,"top-selector2-multiselect":o.multiselect,["top-size_"+o.size]:!0,"top-disabled":o.disabled,"top-forms-focusable":!o.disabled,"top-error":o.isError})},[o.multiselect?(e.openBlock(),e.createElementBlock("div",G,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.value,a=>(e.openBlock(),e.createBlock(F,{id:a.id,name:a.name,onDelete:B},null,8,["id","name"]))),256))])):e.createCommentVNode("",!0),o.multiselect?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("span",H,e.toDisplayString(Array.isArray(t.value)?"":t.value.name),1)),o.addChanger&&!o.multiselect&&u.value.length>1&&!o.disabled?(e.openBlock(),e.createElementBlock("span",{key:2,class:"top-changer top-changer-selector",onClick:e.withModifiers(l,["stop"])})):e.createCommentVNode("",!0)],2)]),widget:e.withCtx(()=>[e.createVNode(e.unref(C.TopPopupWidgetInput),{title:"Поиск",icon:"",modelValue:n.value,"onUpdate:modelValue":r[0]||(r[0]=a=>n.value=a),isLoading:e.unref(p).isLoading.value,placeholder:!Array.isArray(t.value)&&!o.multiselect&&o.showSelectedInInput?t.value.name:o.placeholder},null,8,["modelValue","isLoading","placeholder"])]),contentList:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(h.value,a=>(e.openBlock(),e.createBlock(e.unref(C.TopPopupListItem),{class:e.normalizeClass({"top-active":!Array.isArray(t.value)&&!o.multiselect&&t.value.name===a.name}),key:a.id??void 0,onClick:e.withModifiers(k=>d(a),["stop"])},{default:e.withCtx(()=>[o.$slots.item?e.renderSlot(o.$slots,"item",{key:0,item:a}):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(a.name),1)],64))]),_:2},1032,["class","onClick"]))),128)),h.value.length?e.createCommentVNode("",!0):(e.openBlock(),e.createBlock(e.unref(C.TopPopupListItem),{key:0,type:"regular"},{default:e.withCtx(()=>r[4]||(r[4]=[e.createTextVNode(" Нет результатов ")])),_:1}))]),_:3},512))}}),W=M,J=L,R=_,j=U,X=I._sfc_main;w.TopEditArea=W,w.TopEditInput=J,w.TopMenu=X,w.TopRadioGroup=R,w.TopSelector2=j,Object.defineProperty(w,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","vue","../.chunks/forms-CgS7En_e.amd","../utils/keyboard.amd","../popup/popup.amd","../.chunks/menu.vue_vue_type_style_index_0_lang-Dpm2Wnt9.amd","../require/css.amd!../assets/formsExt.css"],function(te,V,e,B,S,w,I){"use strict";if(typeof e>"u")var e=window.Vue;const N={class:"top-editArea_footer"},$=e.defineComponent({__name:"editArea",props:{defaultValue:{default:""},title:{},cancelText:{default:"Cancel"},submitText:{default:"Send"},closeText:{default:"Close"},isFocused:{type:Boolean},forceShowCloseBtn:{type:Boolean},attachToKeyboard:{type:Boolean},modelValue:{},name:{},placeholder:{},rows:{},minHeight:{},expandable:{type:Boolean,default:!0},disabled:{type:Boolean},readonly:{type:Boolean},isError:{type:Boolean},hint:{}},emits:["submit","close","clickOnTitle"],setup(u,{emit:n}){const t=u,l=n,f=e.ref(t.defaultValue),v=e.ref(t.isFocused),s=e.computed(()=>f.value!==t.defaultValue),d=e.computed(()=>t.attachToKeyboard?"":t.forceShowCloseBtn&&!s.value?t.closeText:t.cancelText),p=i=>{l("submit",i),f.value=t.defaultValue},y=()=>{if(t.forceShowCloseBtn&&!s.value){l("close");return}f.value=t.defaultValue},k=()=>{t.attachToKeyboard&&l("clickOnTitle")};return(i,a)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-editArea":!0,"top-editArea-attachedToKeyboard":i.attachToKeyboard})},[i.title?(e.openBlock(),e.createElementBlock("div",{key:0,class:"top-editArea_title",onClick:a[0]||(a[0]=h=>k())},e.toDisplayString(i.title),1)):e.createCommentVNode("",!0),e.createElementVNode("div",{class:e.normalizeClass({"top-editArea_form":!0,"top-error":i.isError,"top-focus":v.value})},[e.createVNode(B._sfc_main$3,{modelValue:f.value,"onUpdate:modelValue":a[1]||(a[1]=h=>f.value=h),name:i.name,placeholder:i.placeholder,rows:i.rows,minHeight:i.minHeight,expandable:i.expandable,disabled:i.disabled,readonly:i.readonly,isError:i.isError,hint:i.hint,class:"top-editArea_element",onFocus:a[2]||(a[2]=()=>v.value=!0),onBlur:a[3]||(a[3]=()=>v.value=!1),onKeyup:[e.withKeys(y,["esc"]),a[4]||(a[4]=e.withKeys(e.withModifiers(h=>p(f.value),["ctrl"]),["enter"]))]},null,8,["modelValue","name","placeholder","rows","minHeight","expandable","disabled","readonly","isError","hint"]),e.createElementVNode("div",N,[!i.attachToKeyboard&&(s.value||i.forceShowCloseBtn)?(e.openBlock(),e.createBlock(B._sfc_main,{key:0,class:"top-editArea_button",color:"theme",styling:"soft",onClick:y},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(d.value),1)]),_:1})):e.createCommentVNode("",!0),s.value?(e.openBlock(),e.createBlock(B._sfc_main,{key:1,class:"top-editArea_button",icon:i.attachToKeyboard?"":"",onClick:a[5]||(a[5]=h=>p(f.value))},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(i.attachToKeyboard?"":i.submitText),1)]),_:1},8,["icon"])):e.createCommentVNode("",!0)])],2)],2))}}),L={class:"top-editInput"},M=e.defineComponent({__name:"editInput",props:{modelValue:{},input:{},button:{}},emits:["update:modelValue"],setup(u,{emit:n}){const t=u,l=e.ref(t.modelValue);e.watch(e.toRef(t.modelValue),()=>{l.value=t.modelValue});const f=n,v=()=>{f("update:modelValue",l.value)};return(s,d)=>(e.openBlock(),e.createElementBlock("div",L,[e.createVNode(B._sfc_main$2,e.mergeProps(s.input,{onKeydownCapture:d[0]||(d[0]=e.withKeys(e.withModifiers(p=>l.value=s.modelValue,["stop"]),["esc"])),onKeydown:e.withKeys(e.withModifiers(v,["stop"]),["enter"]),modelValue:l.value,"onUpdate:modelValue":d[1]||(d[1]=p=>l.value=p)}),null,16,["onKeydown","modelValue"]),l.value!==s.modelValue?(e.openBlock(),e.createBlock(B._sfc_main,e.mergeProps({key:0,icon:"",styling:"soft"},s.button,{onClick:v}),null,16)):e.createCommentVNode("",!0)]))}}),_=["data-top-icon","onClick"],K={key:0,class:"top-radioGroup_circle"},P=["value","disabled"],z=e.defineComponent({__name:"radioGroup",props:e.mergeModels({modelValue:{},radiosProps:{},showIndicator:{type:Boolean},size:{default:"s"},isError:{type:Boolean}},{modelValue:{required:!0},modelModifiers:{}}),emits:e.mergeModels(["update:modelValue"],["update:modelValue"]),setup(u,{emit:n}){const t=e.useModel(u,"modelValue"),l=u,f=e.ref(null);e.watch(t,()=>{var s,d,p,y,k;(s=l.radiosProps)!=null&&s.some(i=>i.value===t.value)||(t.value=((p=(d=l.radiosProps)==null?void 0:d[0])==null?void 0:p.value)??""),(k=(y=f.value)==null?void 0:y.querySelector(".radioGroup_item-selected"))==null||k.scrollIntoView()},{immediate:!0});const v="radioGroup-"+Math.random();return(s,d)=>(e.openBlock(),e.createElementBlock("div",{ref_key:"elRef",ref:f,class:e.normalizeClass({"top-radioGroup":!0,"top-scrollBarXHidding":!0,["top-size_"+s.size]:!!s.size,"top-error":s.isError})},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(s.radiosProps,p=>(e.openBlock(),e.createElementBlock("label",{class:e.normalizeClass({"top-radioGroup_item-selected":p.value===t.value,"top-radioGroup_item":!0,"top-forms-focusable":!0,"top-disabled":p.disabled}),"data-top-icon":p.icon,onClick:y=>t.value=p.value},[e.createTextVNode(e.toDisplayString(p.title)+" ",1),s.showIndicator?(e.openBlock(),e.createElementBlock("span",K)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":d[0]||(d[0]=y=>t.value=y),name:v,type:"radio",class:e.normalizeClass({"top-unvisible":!0}),value:p.value,disabled:p.disabled},null,8,P),[[e.vModelRadio,t.value]])],10,_))),256))],2))}}),D=(u,n,t)=>{const l=e.ref([]),f=e.ref(!1);let v="",s;u&&!u.params.limit&&(u.params.limit=100);const d=async()=>{if(!u)return;let a,h;if(t&&(u.cache??=new Map,h=JSON.stringify(u.params),a=u.cache.get(h),a))return a;if(f.value=!0,a=await u.call(),f.value=!1,a.errors)return;if(!Array.isArray(a.result)){console.warn("В result ожидался массив");return}const T=a.result.findIndex(C=>C.id===void 0||C.name===void 0);if(T!==-1){console.warn(`В result[${T}] нет id или name`);return}return t&&u.cache.set(h,a),a},p=async()=>{if(!u)return;u.params.offset=0,u.params.search=v;const a=await d();a&&(s=a.nextOffset,l.value=a.result)},y=async()=>{if(!u||!s||f.value)return;u.params.offset=s,u.params.search=v;const a=await d();a&&(s=a.nextOffset,l.value=l.value.concat(a.result))},k=B.debounce(()=>p(),200);return{items:l,isLoading:f,loadAppend:y,setSearchTextAndLoad:(a,h=!0)=>{u&&(a.length<n||a===v&&l.value.length||(v=a,h?k():p()))}}},O={class:"top-selector2_itemMulti top-ellipsis"},F=e.defineComponent({__name:"itemMulti",props:{id:{},name:{}},emits:["delete"],setup(u){return(n,t)=>(e.openBlock(),e.createElementBlock("div",O,[e.createTextVNode(e.toDisplayString(n.name)+" ",1),e.createElementVNode("span",{class:"top-selector2_itemMultiDelete","data-top-icon":"",onClick:t[0]||(t[0]=l=>n.$emit("delete",n.id)),onMousedown:t[1]||(t[1]=e.withModifiers(()=>{},["stop"]))},null,32)]))}}),G={key:0,class:"top-selector2_activeItems"},H={key:1,class:"top-selector2_activeName top-ellipsis"},R=e.defineComponent({__name:"selector2",props:e.mergeModels({modelValue:{},items:{default:()=>[]},multiselect:{type:Boolean},disabled:{type:Boolean},size:{default:"s"},isError:{type:Boolean},apiRequest:{},minLength:{default:0},useCache:{type:Boolean},appendSearchToResult:{type:Boolean},appendAllValue:{type:Boolean},addChanger:{type:Boolean},placeholder:{},showSelectedInInput:{type:Boolean,default:!0}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(u){const n=u,t=e.useModel(u,"modelValue"),l=e.ref(""),f={id:0,name:B.useI18n().Common.All},v=e.ref(null),s=()=>{var o;return(o=v.value)==null?void 0:o.popup};window.__STORYBOOK_PREVIEW__&&!n.modelValue&&e.watch(()=>n.multiselect,()=>{t.value=n.multiselect?[]:{id:null,name:""}},{immediate:!0});const d=D(n.apiRequest,n.minLength,n.useCache),p=e.computed(()=>{const o=[];return!n.multiselect&&n.appendAllValue&&o.push(f),n.items.forEach(r=>o.push({...r})),o}),y=(o,r=!0)=>r&&o.id===null?Array.isArray(t.value)?t.value.some(m=>m.id===o.id&&m.name===o.name):o.name===t.value.name:Array.isArray(t.value)?t.value.some(m=>m.id===o.id):o.id===t.value.id,k=e.computed(()=>{const o=l.value.toLowerCase(),r=S.invertKeyboardLayout(o);let m=[];return p.value.forEach(c=>{const g=c.name.toLowerCase();(c.id===Number(o)||g.includes(o)||g.includes(r))&&(g===o||g===r?m.unshift(c):m.push(c))}),m.push(...d.items.value),n.appendSearchToResult&&l.value&&(!m.length||m[0].name.toLowerCase()!==o)&&m.push({id:null,name:l.value}),n.multiselect&&(m=m.filter(c=>!y(c))),m}),i=e.ref(d.isLoading.value);e.watch(d.isLoading,()=>{i.value=d.isLoading.value});const a=async o=>{var r,m;if(n.multiselect){if(!Array.isArray(t.value)||y(o))return;n.apiRequest&&l.value&&(i.value=!0);const c=[...t.value];c.push({...o}),t.value=c,B.Core.state.isMobile?((r=s())==null||r.close(),l.value&&(l.value="",d.items.value=[])):setTimeout(()=>{var g,b,A,E;(g=s())==null||g.recalcPosition(),(E=(A=(b=s())==null?void 0:b.elPopupWidget)==null?void 0:A.querySelector("input"))==null||E.focus(),l.value&&(k.value.length?n.apiRequest&&(i.value=!1):(l.value="",d.items.value=[]))})}else l.value&&(l.value="",d.items.value=[]),JSON.stringify(o)!==JSON.stringify(t.value)&&(t.value={...o}),(m=s())==null||m.close()},h=()=>{if(!Array.isArray(t.value)){const r=(p.value.findIndex(m=>m.id===t.value.id)+1)%p.value.length;t.value={...p.value[r]}}},T=async o=>{Array.isArray(t.value)&&(t.value=t.value.filter(r=>r.id!==o),setTimeout(()=>{var r;(r=s())==null||r.recalcPosition()}))},C=e.ref(!1);n.apiRequest&&(e.watch(C,()=>{C.value&&d.setSearchTextAndLoad(l.value,!1)}),e.watch(l,()=>d.setSearchTextAndLoad(l.value)));const ee=o=>{const r=o.target;r.scrollTop/(r.scrollHeight-r.offsetHeight)>.8&&d.loadAppend()};return(o,r)=>{const m=e.resolveDirective("top-focus");return e.openBlock(),e.createBlock(e.unref(w.TopPopup),{ref_key:"popupRef",ref:v,onOpen:r[2]||(r[2]=c=>C.value=!0),onClose:r[3]||(r[3]=c=>C.value=!1),onScrollContentList:r[4]||(r[4]=c=>o.apiRequest?ee(c):void 0),notch:!1,transitionDuration:0},{opener:e.withCtx(()=>[e.withDirectives((e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-selector2":!0,"top-selector2-multiselect":o.multiselect,["top-size_"+o.size]:!0,"top-disabled":o.disabled,"top-forms-focusable":!o.disabled,"top-error":o.isError}),onKeydown:r[0]||(r[0]=e.withKeys(c=>c.currentTarget.click(),["enter","space"])),tabindex:"0"},[o.multiselect?(e.openBlock(),e.createElementBlock("div",G,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.value,c=>(e.openBlock(),e.createBlock(F,{id:c.id,name:c.name,onDelete:T},null,8,["id","name"]))),256))])):e.createCommentVNode("",!0),o.multiselect?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("span",H,e.toDisplayString(Array.isArray(t.value)?"":t.value.name),1)),o.addChanger&&!o.multiselect&&p.value.length>1&&!o.disabled?(e.openBlock(),e.createElementBlock("span",{key:2,class:"top-changer top-changer-selector",onClick:e.withModifiers(h,["stop"])})):e.createCommentVNode("",!0)],34)),[[m,o.isError,void 0,{onupdate:!0}]])]),widget:e.withCtx(()=>[e.createVNode(e.unref(w.TopPopupWidgetInput),{title:"Поиск",icon:"",modelValue:l.value,"onUpdate:modelValue":r[1]||(r[1]=c=>l.value=c),isLoading:i.value,placeholder:!Array.isArray(t.value)&&!o.multiselect&&o.showSelectedInInput?t.value.name:o.placeholder},null,8,["modelValue","isLoading","placeholder"])]),contentList:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(k.value,c=>(e.openBlock(),e.createBlock(e.unref(w.TopPopupListItem),{class:e.normalizeClass({"top-active":!Array.isArray(t.value)&&!o.multiselect&&t.value.name===c.name}),key:c.id??void 0,onClick:e.withModifiers(g=>a(c),["stop"])},{default:e.withCtx(()=>[o.$slots.item?e.renderSlot(o.$slots,"item",{key:0,item:c}):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createTextVNode(e.toDisplayString(c.name),1)],64))]),_:2},1032,["class","onClick"]))),128)),!i.value&&!k.value.length?(e.openBlock(),e.createBlock(e.unref(w.TopPopupListItem),{key:0,type:"regular"},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(o.$i18n.Common.No_results),1)]),_:1})):e.createCommentVNode("",!0)]),_:3},512)}}}),U=["data-top-icon"],W={class:"top-info_text"},J={key:0,class:"top-info_value"},j=e.defineComponent({__name:"info",props:{icon:{},styling:{default:"default"},size:{default:"default"},value:{}},setup(u){return(n,t)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-info":!0,["top-size_"+n.size]:!0,["top-info-styling_"+n.styling]:!0}),"data-top-icon":n.icon},[e.createElementVNode("div",W,[e.renderSlot(n.$slots,"default",{},()=>[t[0]||(t[0]=e.createTextVNode("Очень важная информация"))])]),n.value?(e.openBlock(),e.createElementBlock("span",J,e.toDisplayString(n.value),1)):e.createCommentVNode("",!0)],10,U))}}),X=$,Y=M,Q=z,Z=R,q=I._sfc_main,x=j;V.TopEditArea=X,V.TopEditInput=Y,V.TopInfo=x,V.TopMenu=q,V.TopRadioGroup=Q,V.TopSelector2=Z,Object.defineProperty(V,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=formsExt.amd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"formsExt.amd.js","sources":["../../src/components/formsExt/editArea/editArea.vue","../../src/components/formsExt/editInput/editInput.vue","../../src/components/formsExt/radioGroup/radioGroup.vue","../../src/components/formsExt/selector2/api.ts","../../src/components/formsExt/selector2/selector2.vue","../../src/components/formsExt/formsExt.ts"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { computed, ref } from 'vue';\r\nimport Button from '@/components/forms/button/button.vue';\r\nimport type { Emits, Props } from './editArea';\r\nimport Textarea from '@/components/forms/textarea/textarea.vue';\r\n\r\n// TODO: добавить переменную top-forms-fixed-height и использовать ее при добавлении отступов у страницы\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tdefaultValue: '',\r\n\tcancelText: 'Cancel',\r\n\tsubmitText: 'Send',\r\n\tcloseText: 'Close',\r\n\texpandable: true,\r\n});\r\n\r\nconst emit = defineEmits<Emits>();\r\n\r\nconst localValue = ref(props.defaultValue);\r\n\r\nconst isFocused = ref(props.isFocused);\r\n\r\nconst isChanged = computed(() => localValue.value !== props.defaultValue);\r\n\r\nconst cancelBtnText = computed(() => {\r\n\tif (props.attachToKeyboard) return '';\r\n\r\n\tif (props.forceShowCloseBtn && !isChanged.value) return props.closeText;\r\n\r\n\treturn props.cancelText;\r\n});\r\n\r\nconst submit = (value: string) => {\r\n\temit('submit', value);\r\n\r\n\tlocalValue.value = props.defaultValue;\r\n};\r\n\r\nconst cancel = () => {\r\n\tif (props.forceShowCloseBtn && !isChanged.value) {\r\n\t\temit('close');\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tlocalValue.value = props.defaultValue;\r\n};\r\n\r\nconst clickOnTitle = () => {\r\n\tif (props.attachToKeyboard) emit('clickOnTitle');\r\n};\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\t:class=\"{\r\n\t\t\t'top-editArea': true,\r\n\t\t\t'top-editArea-attachedToKeyboard': attachToKeyboard,\r\n\t\t}\"\r\n\t>\r\n\t\t<div\r\n\t\t\tv-if=\"title\"\r\n\t\t\tclass=\"top-editArea_title\"\r\n\t\t\t@click=\"clickOnTitle()\"\r\n\t\t>\r\n\t\t\t{{ title }}\r\n\t\t</div>\r\n\r\n\t\t<div\r\n\t\t\t:class=\"{\r\n\t\t\t\t'top-editArea_form': true,\r\n\t\t\t\t'top-error': isError,\r\n\t\t\t\t'top-focus': isFocused,\r\n\t\t\t}\"\r\n\t\t>\r\n\t\t\t<Textarea\r\n\t\t\t\tv-top-focus=\"{ disabled: !isFocused }\"\r\n\t\t\t\tv-model=\"localValue\"\r\n\t\t\t\t:name=\"name\"\r\n\t\t\t\t:placeholder=\"placeholder\"\r\n\t\t\t\t:rows=\"rows\"\r\n\t\t\t\t:minHeight=\"minHeight\"\r\n\t\t\t\t:expandable=\"expandable\"\r\n\t\t\t\t:disabled=\"disabled\"\r\n\t\t\t\t:readonly=\"readonly\"\r\n\t\t\t\t:isError=\"isError\"\r\n\t\t\t\t:hint=\"hint\"\r\n\t\t\t\tclass=\"top-editArea_element\"\r\n\t\t\t\t@focus=\"() => isFocused = true\"\r\n\t\t\t\t@blur=\"() => isFocused = false\"\r\n\t\t\t\t@keyup.esc=\"cancel\"\r\n\t\t\t\t@keyup.ctrl.enter=\"submit(localValue)\"\r\n\t\t\t/>\r\n\r\n\t\t\t<div class=\"top-editArea_footer\">\r\n\t\t\t\t<Button\r\n\t\t\t\t\tv-if=\"isChanged || forceShowCloseBtn\"\r\n\t\t\t\t\tclass=\"top-editArea_button\"\r\n\t\t\t\t\tcolor=\"theme\"\r\n\t\t\t\t\tstyling=\"soft\"\r\n\t\t\t\t\t:icon=\"attachToKeyboard ? '': ''\"\r\n\t\t\t\t\t@click=\"cancel\"\r\n\t\t\t\t>\r\n\t\t\t\t\t{{ cancelBtnText }}\r\n\t\t\t\t</Button>\r\n\r\n\t\t\t\t<Button\r\n\t\t\t\t\tclass=\"top-editArea_button\"\r\n\t\t\t\t\tv-if=\"isChanged\"\r\n\t\t\t\t\t:icon=\"attachToKeyboard ? '': ''\"\r\n\t\t\t\t\t@click=\"submit(localValue)\"\r\n\t\t\t\t>\r\n\t\t\t\t\t{{ attachToKeyboard ? '' : submitText }}\r\n\t\t\t\t</Button>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n</template>\r\n\r\n<style>\r\n.top-editArea {\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: 6px;\r\n}\r\n\r\n.top-editArea_title {\r\n\tfont-size: 12px;\r\n}\r\n\r\n.top-editArea_form {\r\n\tflex-direction: column;\r\n}\r\n\r\n.top-editArea_form:hover {\r\n\tborder-color: var(--top-forms-border-color-hover);\r\n}\r\n\r\n.top-editArea_form.top-focus {\r\n\tborder-color: var(--color-line-primary-1);\r\n\toutline: none;\r\n}\r\n\r\n/* textarea в EditArea */\r\n.top-textarea {\r\n\twidth: 100%;\r\n}\r\n\r\n.top-editArea_element.top-textarea_textarea {\r\n\tborder: none;\r\n\toutline: none;\r\n\tanimation: none;\r\n}\r\n\r\n/* footer */\r\n.top-editArea_footer {\r\n\tpadding: var(--top-forms-padding);\r\n\tdisplay: flex;\r\n\tmin-height: 32px;\r\n\tjustify-content: flex-end;\r\n\tgap: var(--top-forms-padding);\r\n}\r\n\r\n/* attachedToKeyboard */\r\n.top-editArea-attachedToKeyboard {\r\n\tbackground: var(--top-forms-background-color);\r\n\tmargin-bottom: env(keyboard-inset-height, 0);\r\n\tposition: fixed;\r\n\tbottom: 0;\r\n\tright: 0;\r\n\tleft: 0;\r\n\tz-index: 2;\r\n\tgap: 0;\r\n}\r\n\r\n.top-editArea-attachedToKeyboard .top-editArea_form {\r\n\tborder-radius: 0;\r\n\tborder: none;\r\n\tborder-top: 1px solid var(--top-forms-border-color);\r\n}\r\n\r\n.top-editArea-attachedToKeyboard .top-editArea_title {\r\n\tcursor: pointer;\r\n\tborder-top: 1px solid var(--color-line-2-opacity);\r\n\tpadding: var(--top-forms-padding);\r\n}\r\n\r\n.top-editArea-attachedToKeyboard .top-editArea_footer > [data-top-icon] {\r\n\tborder-radius: 100%;\r\n}\r\n\r\n.top-editArea-attachedToKeyboard .top-button.top-editArea_button {\r\n\tmin-width: auto;\r\n\tpadding: 0;\r\n}\r\n</style>\r\n","<script setup lang=\"ts\">\r\nimport { ref, toRef, watch } from 'vue';\r\nimport type { Emits, Props } from './editInput';\r\nimport TopInput from '@/components/forms/input/input.vue';\r\nimport TopButton from '@/components/forms/button/button.vue';\r\n\r\nconst props = defineProps<Props>();\r\n\r\nconst intermediateValue = ref(props.modelValue);\r\n\r\nwatch(toRef(props.modelValue), () => {\r\n\tintermediateValue.value = props.modelValue;\r\n});\r\n\r\nconst emit = defineEmits<Emits>();\r\n\r\nconst submit = () => {\r\n\temit('update:modelValue', intermediateValue.value);\r\n};\r\n</script>\r\n\r\n<template>\r\n\t<div class=\"top-editInput\">\r\n\t\t<TopInput\r\n\t\t\t:=\"input\"\r\n\t\t\t@keydown.esc.capture.stop=\"intermediateValue = modelValue\"\r\n\t\t\t@keydown.enter.stop=\"submit\"\r\n\t\t\tv-model=\"intermediateValue\"\r\n\t\t/>\r\n\r\n\t\t<TopButton\r\n\t\t\tv-if=\"intermediateValue !== modelValue\"\r\n\t\t\ticon=\"\"\r\n\t\t\tstyling=\"soft\"\r\n\t\t\t:=\"button\"\r\n\t\t\t@click=\"submit\"\r\n\t\t/>\r\n\t</div>\r\n</template>\r\n\r\n<style>\r\n.top-editInput {\r\n\twidth: 220px;\r\n\tflex-grow: 1;\r\n\tdisplay: flex;\r\n\talign-items: flex-end;\r\n\tgap: var(--top-gap-1);\r\n}\r\n\r\n.top-editInput .top-input {\r\n\twidth: unset;\r\n\tflex-grow: 1;\r\n}\r\n</style>\r\n","<script setup lang=\"ts\">\r\nimport type { Ref } from '@vue/reactivity';\r\nimport { ref, watch } from 'vue';\r\nimport type { Props, Emits } from './radioGroup';\r\n\r\nconst model = defineModel<string>({\r\n\trequired: true,\r\n});\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tsize: 's',\r\n});\r\n\r\nconst emit = defineEmits<Emits>();\r\n\r\nconst elRef: Ref<HTMLElement | null> = ref(null);\r\n\r\nwatch(model, () => {\r\n\tif (!props.radiosProps?.some(item => item.value === model.value)) {\r\n\t\tmodel.value = props.radiosProps?.[0]?.value ?? '';\r\n\t}\r\n\r\n\telRef.value?.querySelector('.radioGroup_item-selected')?.scrollIntoView();\r\n}, { immediate: true });\r\n\r\nconst uid = 'radioGroup-' + Math.random();\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\tref=\"elRef\"\r\n\t\t:class=\"{\r\n\t\t\t['top-radioGroup']: true,\r\n\t\t\t['top-scrollBarXHidding']: true,\r\n\t\t\t['top-size_' + size]: !!size,\r\n\t\t\t['top-error']: isError,\r\n\t\t}\"\r\n\t>\r\n\t\t<label\r\n\t\t\tv-for=\"item of radiosProps\"\r\n\t\t\t:class=\"{\r\n\t\t\t\t['top-radioGroup_item-selected']: item.value === model,\r\n\t\t\t\t['top-radioGroup_item']: true,\r\n\t\t\t\t['top-forms-focusable']: true,\r\n\t\t\t\t['top-disabled']: item.disabled,\r\n\t\t\t}\"\r\n\t\t\t:data-top-icon=\"item.icon\"\r\n\t\t\t@click=\"model = item.value\"\r\n\t\t>\r\n\t\t\t{{ item.title }}\r\n\r\n\t\t\t<span\r\n\t\t\t\tv-if=\"showIndicator\"\r\n\t\t\t\tclass=\"top-radioGroup_circle\"\r\n\t\t\t></span>\r\n\r\n\t\t\t<!-- Для нативной навигации -->\r\n\t\t\t<input\r\n\t\t\t\tv-model=\"model\"\r\n\t\t\t\t:name=\"uid\"\r\n\t\t\t\ttype=\"radio\"\r\n\t\t\t\t:class=\"{\r\n\t\t\t\t\t['top-unvisible']: true,\r\n\t\t\t\t}\"\r\n\t\t\t\t:value=\"item.value\"\r\n\t\t\t\t:disabled=\"item.disabled\"\r\n\t\t\t/>\r\n\t\t</label>\r\n\t</div>\r\n</template>\r\n\r\n<style>\r\n@import \"./styles/top-scrollBar.css\";\r\n\r\n.top-radioGroup {\r\n\tuser-select: none;\r\n\tbox-sizing: border-box;\r\n\tborder-radius: 8px;\r\n\tbackground-color: var(--color-layout-middle);\r\n\theight: var(--top-forms-base-height);\r\n\tpadding: 2px;\r\n\tgap: 2px;\r\n\tdisplay: flex;\r\n\talign-items: flex-start;\r\n}\r\n\r\n.top-radioGroup_item {\r\n\tcolor: var(--color-text-2);\r\n\tcursor: pointer;\r\n\tbox-sizing: border-box;\r\n\tborder-radius: 6px;\r\n\theight: calc(var(--top-forms-base-height) - 4px);\r\n\tpadding: 0 16px;\r\n\tfont-weight: 400;\r\n\twhite-space: nowrap;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tflex-grow: 1;\r\n\tgap: 4px;\r\n}\r\n\r\n.top-radioGroup_item:hover {\r\n\tbackground-color: var(--color-layout-front-1);\r\n\tbox-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);\r\n}\r\n\r\n/* selected */\r\n.top-radioGroup_item-selected {\r\n\tcolor: var(--color-text-1);\r\n\tpointer-events: none;\r\n\tbackground-color: var(--color-bg-lightning-1);\r\n\tbox-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);\r\n}\r\n\r\n/* circle */\r\n.top-radioGroup_circle {\r\n\tcontent: \"\";\r\n\tbox-sizing: border-box;\r\n\tborder: 1px solid var(--color-line-3-opacity);\r\n\tborder-radius: 50%;\r\n\tpadding: 3px;\r\n\tmargin-left: auto;\r\n\twidth: calc(var(--top-forms-option-height) - 3px * 2);\r\n\theight: calc(var(--top-forms-option-height) - 3px * 2);\r\n}\r\n\r\n.top-radioGroup_item:hover .top-radioGroup_circle:before {\r\n\tborder-color: var(--color-line-primary-1);\r\n}\r\n\r\n/* circle selected */\r\n.top-radioGroup_item-selected .top-radioGroup_circle {\r\n\tborder-color: var(--color-line-primary-1);\r\n\tborder-width: 5px;\r\n}\r\n\r\n.top-radioGroup_item-selected:hover .top-radioGroup_circle {\r\n\tborder-color: var(--color-line-primary-1);\r\n}\r\n\r\n/* top-error */\r\n.top-radioGroup.top-error .top-radioGroup_item:not(.top-disabled) .top-radioGroup_circle {\r\n\tborder-color: var(--color-line-negative-1);\r\n}\r\n</style>\r\n","import type { Ref } from 'vue';\r\nimport { ref } from 'vue';\r\nimport { debounce } from '@/core/utils/lodash';\r\nimport type { Item, Props } from './selector2';\r\n\r\nexport const useAPI = (apiRequest: Props['apiRequest'], minLength: number, useCache: Props['useCache']) => {\r\n\t/**\r\n\t * Список, полученный через API\r\n\t */\r\n\tconst items: Ref<Array<Item>> = ref([]);\r\n\r\n\t/**\r\n\t * Флаг - идет загрузка\r\n\t */\r\n\tconst isLoading = ref(false);\r\n\r\n\tlet _searchText = '';\r\n\tlet _nextOffset: number | undefined;\r\n\r\n\tif (apiRequest && !apiRequest.params.limit) {\r\n\t\tapiRequest.params.limit = 100;\r\n\t}\r\n\r\n\t/**\r\n\t * Выполнить обращение к API\r\n\t *\r\n\t * При ошибке вернет undefined\r\n\t */\r\n\tconst callAPIRequest = async (): Promise<{ nextOffset?: number, result: Array<Item> } | undefined> => {\r\n\t\tif (!apiRequest) return;\r\n\r\n\t\tlet res;\r\n\t\tlet cacheKey;\r\n\r\n\t\tif (useCache) {\r\n\t\t\t// кэш для полученных ответов через apiRequest\r\n\t\t\t// общий для всех компонентов, использующих apiRequest\r\n\t\t\tapiRequest.cache ??= new Map();\r\n\r\n\t\t\tcacheKey = JSON.stringify(apiRequest.params);\r\n\t\t\tres = apiRequest.cache.get(cacheKey);\r\n\r\n\t\t\tif (res) {\r\n\t\t\t\treturn res;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tisLoading.value = true;\r\n\t\tres = await apiRequest.call();\r\n\t\tisLoading.value = false;\r\n\r\n\t\tif (res.errors) return;\r\n\r\n\t\tif (!Array.isArray(res.result)) {\r\n\t\t\tconsole.warn(`В result ожидался массив`);\r\n\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst indexWithError = (res.result as Array<Item | any>).findIndex(item => item.id === undefined || item.name === undefined);\r\n\t\tif (indexWithError !== -1) {\r\n\t\t\tconsole.warn(`В result[${indexWithError}] нет id или name`);\r\n\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (useCache) {\r\n\t\t\tapiRequest.cache.set(cacheKey as string, res);\r\n\t\t}\r\n\r\n\t\treturn res;\r\n\t};\r\n\r\n\t/**\r\n\t * Загрузить items\r\n\t */\r\n\tconst load = async () => {\r\n\t\tif (!apiRequest) return;\r\n\r\n\t\tapiRequest.params.offset = 0;\r\n\t\tapiRequest.params.search = _searchText;\r\n\r\n\t\tconst res = await callAPIRequest();\r\n\t\tif (!res) return;\r\n\r\n\t\t_nextOffset = res.nextOffset;\r\n\r\n\t\titems.value = res.result;\r\n\t};\r\n\r\n\t/**\r\n\t * Загрузить следующую страницу items\r\n\t */\r\n\tconst loadAppend = async () => {\r\n\t\tif (!apiRequest) return;\r\n\r\n\t\t// данных о следующих страницах не обнаружено\r\n\t\tif (!_nextOffset) return;\r\n\r\n\t\t// дозагружать нельзя, если не завершена предыдущшая загрузка\r\n\t\tif (isLoading.value) return;\r\n\r\n\t\tapiRequest.params.offset = _nextOffset;\r\n\t\tapiRequest.params.search = _searchText;\r\n\r\n\t\tconst res = await callAPIRequest();\r\n\t\tif (!res) return;\r\n\r\n\t\t_nextOffset = res.nextOffset;\r\n\r\n\t\titems.value = items.value.concat(res.result);\r\n\t};\r\n\r\n\tconst loadDebounce = debounce(() => load(), 200);\r\n\r\n\t/**\r\n\t * Выполнить поиск по указанному тексту\r\n\t *\r\n\t * Если длина текста меньше minLength, поиск не будет проивзеден\r\n\t *\r\n\t * Если текст не изменился, поиск не будет проивзеден\r\n\t * @param searchText - текст поиска\r\n\t * @param useDebounce - отложенное выполнение поиска\r\n\t */\r\n\tconst setSearchTextAndLoad = (searchText: string, useDebounce = true) => {\r\n\t\tif (!apiRequest) return;\r\n\r\n\t\tif (searchText.length < minLength) return;\r\n\r\n\t\t// условия поиска не поменялись, данные загружены\r\n\t\tif (searchText === _searchText && items.value.length) return;\r\n\r\n\t\t_searchText = searchText;\r\n\r\n\t\tif (useDebounce) {\r\n\t\t\tloadDebounce();\r\n\t\t} else {\r\n\t\t\tvoid load();\r\n\t\t}\r\n\t};\r\n\r\n\treturn {\r\n\t\titems,\r\n\t\tisLoading,\r\n\t\tloadAppend,\r\n\t\tsetSearchTextAndLoad,\r\n\t};\r\n};\r\n","<script setup lang=\"ts\">\r\nimport type { Ref, ComputedRef, ModelRef, ComponentInstance } from 'vue';\r\nimport { computed, ref, watch } from 'vue';\r\nimport Core from '@/core/core/core';\r\nimport { invertKeyboardLayout } from '@/core/utils/keyboard';\r\nimport { TopPopup, TopPopupListItem, TopPopupWidgetInput } from '@/components/popup/popup';\r\nimport type PopupClass from '@/components/popup/lib/popup';\r\nimport type { Item, Props, Slots } from './selector2';\r\nimport { useAPI } from './api';\r\nimport Selector2ItemMulti from './itemMulti.vue';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\titems: () => [] as Array<Item>,\r\n\tsize: 's',\r\n\tminLength: 0,\r\n\tshowSelectedInInput: true,\r\n});\r\n\r\nconst model = defineModel<Props['modelValue']>() as ModelRef<Props['modelValue']>;\r\n\r\ndefineSlots<Slots>();\r\n\r\n/**\r\n * Текст поиска по результатам\r\n */\r\nconst searchText = ref('');\r\n\r\nconst itemAll = {\r\n\tid: 0,\r\n\tname: 'Все',\r\n};\r\n\r\n/**\r\n * Экземпляр компонента Popup\r\n */\r\nconst popupRef: Ref<ComponentInstance<typeof TopPopup> | null> = ref(null);\r\n\r\n/**\r\n * Получить доступ к объекту popup\r\n */\r\nconst getPopup = (): PopupClass | undefined => {\r\n\treturn popupRef.value?.popup;\r\n};\r\n\r\n// для storybook\r\nif ((window as any).__STORYBOOK_PREVIEW__ && !props.modelValue) {\r\n\twatch(\r\n\t\t() => props.multiselect,\r\n\t\t() => {\r\n\t\t\tmodel.value = props.multiselect ? [] : { id: null, name: '' };\r\n\t\t},\r\n\t\t{ immediate: true },\r\n\t);\r\n}\r\n\r\nconst API = useAPI(props.apiRequest, props.minLength, props.useCache);\r\n\r\n/**\r\n * Варианты выбора: props.items + \"Выбрать все\"\r\n */\r\nconst localItems: ComputedRef<Array<Item>> = computed(() => {\r\n\tconst items: Array<Item> = [];\r\n\r\n\tif (!props.multiselect && props.appendAllValue) {\r\n\t\titems.push(itemAll);\r\n\t}\r\n\r\n\tprops.items.forEach(item => items.push({ ...item }));\r\n\r\n\treturn items;\r\n});\r\n\r\n/**\r\n * Проверить, что элемент выбран\r\n */\r\nconst isSelected = (item: Item, checkNameForNullId = true) => {\r\n\tif (checkNameForNullId && item.id === null) {\r\n\t\tif (Array.isArray(model.value)) {\r\n\t\t\treturn model.value.some(itemSelected => itemSelected.id === item.id && itemSelected.name === item.name);\r\n\t\t} else {\r\n\t\t\treturn item.name === model.value.name;\r\n\t\t}\r\n\t}\r\n\r\n\tif (Array.isArray(model.value)) {\r\n\t\treturn model.value.some(itemSelected => itemSelected.id === item.id);\r\n\t} else {\r\n\t\treturn item.id === model.value.id;\r\n\t}\r\n};\r\n\r\n/**\r\n * Варианты выбора, которые выводятся\r\n */\r\nconst itemsForShow = computed(() => {\r\n\tconst searchString = searchText.value.toLowerCase();\r\n\tconst searchStringInvertKeyboard = invertKeyboardLayout(searchString);\r\n\r\n\tlet items: typeof localItems.value = [];\r\n\r\n\tlocalItems.value.forEach((item) => {\r\n\t\tconst itemName = item.name.toLowerCase();\r\n\r\n\t\tif (\r\n\t\t\titem.id === Number(searchString) ||\r\n\t\t\titemName.includes(searchString) ||\r\n\t\t\titemName.includes(searchStringInvertKeyboard)\r\n\t\t) {\r\n\t\t\tif (itemName === searchString || itemName === searchStringInvertKeyboard) {\r\n\t\t\t\titems.unshift(item);\r\n\t\t\t} else {\r\n\t\t\t\titems.push(item);\r\n\t\t\t}\r\n\t\t}\r\n\t});\r\n\r\n\titems.push(...API.items.value);\r\n\r\n\tif (\r\n\t\tprops.appendSearchToResult &&\r\n\t\t!!searchText.value &&\r\n\t\t(!items.length || items[0].name.toLowerCase() !== searchString)\r\n\t) {\r\n\t\titems.push({\r\n\t\t\tid: null,\r\n\t\t\tname: searchText.value,\r\n\t\t});\r\n\t}\r\n\r\n\tif (props.multiselect) {\r\n\t\titems = items.filter(item => !isSelected(item));\r\n\t}\r\n\r\n\treturn items;\r\n});\r\n\r\n/**\r\n * Выбрать значение\r\n *\r\n * Управляет закрытием окна\r\n */\r\nconst selectItem = async (item: Item) => {\r\n\tif (props.multiselect) {\r\n\t\tif (!Array.isArray(model.value)) return;\r\n\r\n\t\tif (isSelected(item)) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst newModel = [...model.value];\r\n\t\tnewModel.push({ ...item });\r\n\t\tmodel.value = newModel;\r\n\r\n\t\tif (Core.state.isMobile) {\r\n\t\t\tgetPopup()?.close();\r\n\t\t} else {\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tgetPopup()?.recalcPosition();\r\n\t\t\t\tgetPopup()?.elPopupWidget?.querySelector('input')?.focus();\r\n\r\n\t\t\t\t// сбросить введенный текст, только если больше не найдено результатов\r\n\t\t\t\tif (searchText.value) {\r\n\t\t\t\t\tif (!itemsForShow.value.length) {\r\n\t\t\t\t\t\tsearchText.value = '';\r\n\t\t\t\t\t\tAPI.items.value = [];\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t} else {\r\n\t\t// сбросить введенный текст\r\n\t\tif (searchText.value) {\r\n\t\t\tsearchText.value = '';\r\n\t\t\tAPI.items.value = [];\r\n\t\t}\r\n\r\n\t\tif (JSON.stringify(item) !== JSON.stringify(model.value)) {\r\n\t\t\tmodel.value = { ...item };\r\n\t\t}\r\n\r\n\t\tgetPopup()?.close();\r\n\t}\r\n};\r\n\r\n/**\r\n * Выбрать следующее значение\r\n */\r\nconst selectNextItem = () => {\r\n\tif (!Array.isArray(model.value)) {\r\n\t\tconst currentIndex = localItems.value.findIndex(item => item.id === (model.value as Item).id);\r\n\t\tconst nextIndex = (currentIndex + 1) % localItems.value.length;\r\n\t\tmodel.value = { ...localItems.value[nextIndex] };\r\n\t}\r\n};\r\n\r\n/**\r\n * Удалить выбранное значение по id\r\n * @param id\r\n */\r\nconst deleteItemById = async (id: Item['id']) => {\r\n\tif (Array.isArray(model.value)) {\r\n\t\tmodel.value = model.value.filter(item => item.id !== id);\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tgetPopup()?.recalcPosition();\r\n\t\t});\r\n\t}\r\n};\r\n\r\nconst isOpened = ref(false); // флаг попап открыт\r\n\r\nif (props.apiRequest) {\r\n\twatch(isOpened, () => {\r\n\t\tif (isOpened.value) {\r\n\t\t\t// при открытии сразу выполнить поиск\r\n\t\t\tAPI.setSearchTextAndLoad(searchText.value, false);\r\n\t\t}\r\n\t});\r\n\r\n\t// отложенный поиск при вводе текста\r\n\twatch(searchText, () => API.setSearchTextAndLoad(searchText.value));\r\n}\r\n\r\nconst onScrollContentList = (e: Event) => {\r\n\tconst el = e.target as HTMLElement;\r\n\r\n\tif (el.scrollTop / (el.scrollHeight - el.offsetHeight) > 0.8) {\r\n\t\tAPI.loadAppend();\r\n\t}\r\n};\r\n</script>\r\n\r\n<template>\r\n\t<TopPopup\r\n\t\tref=\"popupRef\"\r\n\t\t@open=\"isOpened = true\"\r\n\t\t@close=\"isOpened = false\"\r\n\t\t@scrollContentList=\"apiRequest ? onScrollContentList($event) : undefined\"\r\n\t\t:notch=\"false\"\r\n\t\t:transitionDuration=\"0\"\r\n\t>\r\n\t\t<template #opener>\r\n\t\t\t<div\r\n\t\t\t\t:class=\"{\r\n\t\t\t\t\t'top-selector2' : true,\r\n\t\t\t\t\t'top-selector2-multiselect': multiselect,\r\n\t\t\t\t\t['top-size_' + size]: true,\r\n\t\t\t\t\t['top-disabled']: disabled,\r\n\t\t\t\t\t['top-forms-focusable']: !disabled,\r\n\t\t\t\t\t['top-error']: isError,\r\n\t\t\t\t}\"\r\n\t\t\t>\r\n\t\t\t\t<template v-if=\"multiselect\">\r\n\t\t\t\t\t<div class=\"top-selector2_activeItems\">\r\n\t\t\t\t\t\t<Selector2ItemMulti\r\n\t\t\t\t\t\t\tv-for=\"item of model as Array<Item>\"\r\n\t\t\t\t\t\t\t:id=\"item.id\"\r\n\t\t\t\t\t\t\t:name=\"item.name\"\r\n\t\t\t\t\t\t\t@delete=\"deleteItemById\"\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</template>\r\n\r\n\t\t\t\t<span v-if=\"!multiselect\" class=\"top-selector2_activeName top-ellipsis\">\r\n\t\t\t\t\t{{ !Array.isArray(model) ? model.name : '' }}\r\n\t\t\t\t</span>\r\n\r\n\t\t\t\t<span\r\n\t\t\t\t\tv-if=\"addChanger && !multiselect && localItems.length > 1 && !disabled\"\r\n\t\t\t\t\tclass=\"top-changer top-changer-selector\"\r\n\t\t\t\t\t@click.stop=\"selectNextItem\"\r\n\t\t\t\t></span>\r\n\t\t\t</div>\r\n\t\t</template>\r\n\r\n\t\t<template #widget>\r\n\t\t\t<TopPopupWidgetInput\r\n\t\t\t\ttitle=\"Поиск\"\r\n\t\t\t\ticon=\"\"\r\n\t\t\t\tv-model=\"searchText\"\r\n\t\t\t\t:isLoading=\"API.isLoading.value\"\r\n\t\t\t\t:placeholder=\"!Array.isArray(model) && !multiselect && showSelectedInInput ? model.name : placeholder\"\r\n\t\t\t/>\r\n\t\t</template>\r\n\r\n\t\t<template #contentList>\r\n\t\t\t<TopPopupListItem\r\n\t\t\t\tv-for=\"item of itemsForShow\"\r\n\t\t\t\t:class=\"{\r\n\t\t\t\t\t'top-active': !Array.isArray(model) && !multiselect && model.name === item.name\r\n\t\t\t\t}\"\r\n\t\t\t\t:key=\"item.id ?? undefined\"\r\n\t\t\t\t@click.stop=\"selectItem(item)\"\r\n\t\t\t>\r\n\t\t\t\t<slot\r\n\t\t\t\t\tv-if=\"$slots.item\"\r\n\t\t\t\t\tname=\"item\"\r\n\t\t\t\t\t:item=\"item\"\r\n\t\t\t\t></slot>\r\n\r\n\t\t\t\t<template\r\n\t\t\t\t\tv-else\r\n\t\t\t\t>\r\n\t\t\t\t\t{{ item.name }}\r\n\t\t\t\t</template>\r\n\t\t\t</TopPopupListItem>\r\n\r\n\t\t\t<TopPopupListItem\r\n\t\t\t\tv-if=\"!itemsForShow.length\"\r\n\t\t\t\ttype=\"regular\"\r\n\t\t\t>\r\n\t\t\t\tНет результатов\r\n\t\t\t</TopPopupListItem>\r\n\t\t</template>\r\n\t</TopPopup>\r\n</template>\r\n\r\n<style>\r\n.top-selector2 {\r\n\twidth: 180px;\r\n\tmin-height: var(--top-forms-base-height);\r\n\tbox-sizing: border-box;\r\n\tposition: relative;\r\n\tdisplay: flex;\r\n\toverflow: hidden;\r\n\tpadding: var(--top-padding-1) var(--top-forms-padding);\r\n\tcolor: var(--top-forms-placeholder-color);\r\n\r\n\tborder-radius: var(--top-radius-2);\r\n\tborder: 1px solid var(--top-forms-border-color);\r\n\tbackground: var(--top-forms-background-color);\r\n}\r\n\r\n.top-selector2-multiselect {\r\n\twidth: unset;\r\n\tmin-width: 180px;\r\n\tpadding: var(--top-padding-1);\r\n}\r\n\r\n.top-selector2.top-active {\r\n\t--top-forms-border-color: var(--top-forms-border-color-hover);\r\n\t--top-forms-background-color: var(--top-forms-background-color-hover);\r\n}\r\n\r\n.top-selector2_activeItems {\r\n\tdisplay: flex;\r\n\tflex-wrap: wrap;\r\n\tgap: var(--top-padding-1);\r\n\tmax-width: 100%;\r\n}\r\n\r\n.top-selector2_activeName {\r\n\twhite-space: nowrap;\r\n}\r\n\r\n.top-changer-selector {\r\n\ttransform: translateX(-16px);\r\n}\r\n</style>\r\n","import type { ComponentCustomProps } from 'vue';\r\n\r\nimport EditArea from './editArea/editArea.vue';\r\nimport EditInput from './editInput/editInput.vue';\r\nimport RadioGroup from './radioGroup/radioGroup.vue';\r\nimport Selector2 from './selector2/selector2.vue';\r\nimport Menu from './menu/menu.vue';\r\n\r\nexport const TopEditArea = EditArea as typeof EditArea & ComponentCustomProps;\r\nexport const TopEditInput = EditInput as typeof EditInput & ComponentCustomProps;\r\nexport const TopRadioGroup = RadioGroup as typeof RadioGroup & ComponentCustomProps;\r\nexport const TopSelector2 = Selector2 as typeof Selector2 & ComponentCustomProps;\r\nexport const TopMenu = Menu as typeof Menu & ComponentCustomProps;\r\n"],"names":["props","__props","emit","__emit","isChanged","vue","localValue","cancelBtnText","submit","value","intermediateValue","elRef","model","_a","item","_c","_b","items","isLoading","_searchText","apiRequest","res","indexWithError","callAPIRequest","_nextOffset","loadAppend","searchText","minLength","popupRef","API","useAPI","localItems","itemAll","itemSelected","itemsForShow","searchStringInvertKeyboard","utils_keyboard","searchString","isSelected","selectItem","newModel","forms","getPopup","_d","nextIndex","deleteItemById","id","isOpened","onScrollContentList","e","el","TopEditArea","_sfc_main$4","TopEditInput","_sfc_main$3","TopRadioGroup","_sfc_main$2","TopSelector2","_sfc_main","TopMenu","menu_vue_vue_type_style_index_0_lang"],"mappings":"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"}
1
+ {"version":3,"file":"formsExt.amd.js","sources":["../../src/components/formsExt/editArea/editArea.vue","../../src/components/formsExt/editInput/editInput.vue","../../src/components/formsExt/radioGroup/radioGroup.vue","../../src/components/formsExt/selector2/api.ts","../../src/components/formsExt/selector2/selector2.vue","../../src/components/formsExt/formsExt.ts"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { computed, ref } from 'vue';\r\nimport Button from '@/components/forms/button/button.vue';\r\nimport type { Emits, Props } from './editArea';\r\nimport Textarea from '@/components/forms/textarea/textarea.vue';\r\n\r\n// TODO: добавить переменную top-forms-fixed-height и использовать ее при добавлении отступов у страницы\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tdefaultValue: '',\r\n\tcancelText: 'Cancel',\r\n\tsubmitText: 'Send',\r\n\tcloseText: 'Close',\r\n\texpandable: true,\r\n});\r\n\r\nconst emit = defineEmits<Emits>();\r\n\r\nconst localValue = ref(props.defaultValue);\r\n\r\nconst isFocused = ref(props.isFocused);\r\n\r\nconst isChanged = computed(() => localValue.value !== props.defaultValue);\r\n\r\nconst cancelBtnText = computed(() => {\r\n\tif (props.attachToKeyboard) return '';\r\n\r\n\tif (props.forceShowCloseBtn && !isChanged.value) return props.closeText;\r\n\r\n\treturn props.cancelText;\r\n});\r\n\r\nconst submit = (value: string) => {\r\n\temit('submit', value);\r\n\r\n\tlocalValue.value = props.defaultValue;\r\n};\r\n\r\nconst cancel = () => {\r\n\tif (props.forceShowCloseBtn && !isChanged.value) {\r\n\t\temit('close');\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tlocalValue.value = props.defaultValue;\r\n};\r\n\r\nconst clickOnTitle = () => {\r\n\tif (props.attachToKeyboard) emit('clickOnTitle');\r\n};\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\t:class=\"{\r\n\t\t\t'top-editArea': true,\r\n\t\t\t'top-editArea-attachedToKeyboard': attachToKeyboard,\r\n\t\t}\"\r\n\t>\r\n\t\t<div\r\n\t\t\tv-if=\"title\"\r\n\t\t\tclass=\"top-editArea_title\"\r\n\t\t\t@click=\"clickOnTitle()\"\r\n\t\t>\r\n\t\t\t{{ title }}\r\n\t\t</div>\r\n\r\n\t\t<div\r\n\t\t\t:class=\"{\r\n\t\t\t\t'top-editArea_form': true,\r\n\t\t\t\t'top-error': isError,\r\n\t\t\t\t'top-focus': isFocused,\r\n\t\t\t}\"\r\n\t\t>\r\n\t\t\t<Textarea\r\n\t\t\t\tv-model=\"localValue\"\r\n\t\t\t\t:name=\"name\"\r\n\t\t\t\t:placeholder=\"placeholder\"\r\n\t\t\t\t:rows=\"rows\"\r\n\t\t\t\t:minHeight=\"minHeight\"\r\n\t\t\t\t:expandable=\"expandable\"\r\n\t\t\t\t:disabled=\"disabled\"\r\n\t\t\t\t:readonly=\"readonly\"\r\n\t\t\t\t:isError=\"isError\"\r\n\t\t\t\t:hint=\"hint\"\r\n\t\t\t\tclass=\"top-editArea_element\"\r\n\t\t\t\t@focus=\"() => isFocused = true\"\r\n\t\t\t\t@blur=\"() => isFocused = false\"\r\n\t\t\t\t@keyup.esc=\"cancel\"\r\n\t\t\t\t@keyup.ctrl.enter=\"submit(localValue)\"\r\n\t\t\t/>\r\n\r\n\t\t\t<div class=\"top-editArea_footer\">\r\n\t\t\t\t<Button\r\n\t\t\t\t\tv-if=\"!attachToKeyboard && (isChanged || forceShowCloseBtn)\"\r\n\t\t\t\t\tclass=\"top-editArea_button\"\r\n\t\t\t\t\tcolor=\"theme\"\r\n\t\t\t\t\tstyling=\"soft\"\r\n\t\t\t\t\t@click=\"cancel\"\r\n\t\t\t\t>\r\n\t\t\t\t\t{{ cancelBtnText }}\r\n\t\t\t\t</Button>\r\n\r\n\t\t\t\t<Button\r\n\t\t\t\t\tclass=\"top-editArea_button\"\r\n\t\t\t\t\tv-if=\"isChanged\"\r\n\t\t\t\t\t:icon=\"attachToKeyboard ? '': ''\"\r\n\t\t\t\t\t@click=\"submit(localValue)\"\r\n\t\t\t\t>\r\n\t\t\t\t\t{{ attachToKeyboard ? '' : submitText }}\r\n\t\t\t\t</Button>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n</template>\r\n\r\n<style>\r\n.top-editArea {\r\n\tdisplay: flex;\r\n\tflex-direction: column;\r\n\tgap: 6px;\r\n}\r\n\r\n.top-editArea_title {\r\n\tfont-size: 12px;\r\n}\r\n\r\n.top-editArea_form {\r\n\tflex-direction: column;\r\n\toutline: none;\r\n}\r\n\r\n.top-editArea_form:not(.top-error):hover,\r\n.top-editArea_form:not(.top-error).top-focus {\r\n\tborder-color: var(--top-forms-border-color-hover);\r\n}\r\n\r\n/* textarea в EditArea */\r\n.top-textarea {\r\n\twidth: 100%;\r\n}\r\n\r\n.top-editArea_element.top-textarea_textarea {\r\n\tborder: none;\r\n\toutline: none;\r\n\tanimation: none;\r\n}\r\n\r\n/* footer */\r\n.top-editArea_footer {\r\n\tpadding: var(--top-forms-padding);\r\n\tdisplay: flex;\r\n\tmin-height: 32px;\r\n\tjustify-content: flex-end;\r\n\tgap: var(--top-forms-padding);\r\n}\r\n\r\n/* attachedToKeyboard */\r\n.top-editArea-attachedToKeyboard {\r\n\tbackground: var(--top-forms-background-color);\r\n\tmargin-bottom: env(keyboard-inset-height, 0);\r\n\tposition: fixed;\r\n\tbottom: 0;\r\n\tright: 0;\r\n\tleft: 0;\r\n\tz-index: 2;\r\n\tgap: 0;\r\n}\r\n\r\n.top-editArea-attachedToKeyboard .top-editArea_form {\r\n\tborder-radius: 0;\r\n\tborder: none;\r\n\tborder-top: 1px solid var(--top-forms-border-color);\r\n}\r\n\r\n.top-editArea-attachedToKeyboard .top-editArea_title {\r\n\tcursor: pointer;\r\n\tborder-top: 1px solid var(--color-line-2-opacity);\r\n\tpadding: var(--top-forms-padding);\r\n}\r\n\r\n.top-editArea-attachedToKeyboard .top-editArea_footer > [data-top-icon] {\r\n\tborder-radius: 100%;\r\n}\r\n\r\n.top-editArea-attachedToKeyboard .top-button.top-editArea_button {\r\n\tmin-width: auto;\r\n\tpadding: 0;\r\n}\r\n\r\n.top-editArea-attachedToKeyboard .top-button.top-editArea_button:before {\r\n\t--top-icon-size: 18px;\r\n}\r\n</style>\r\n","<script setup lang=\"ts\">\r\nimport { ref, toRef, watch } from 'vue';\r\nimport type { Emits, Props } from './editInput';\r\nimport TopInput from '@/components/forms/input/input.vue';\r\nimport TopButton from '@/components/forms/button/button.vue';\r\n\r\nconst props = defineProps<Props>();\r\n\r\nconst intermediateValue = ref(props.modelValue);\r\n\r\nwatch(toRef(props.modelValue), () => {\r\n\tintermediateValue.value = props.modelValue;\r\n});\r\n\r\nconst emit = defineEmits<Emits>();\r\n\r\nconst submit = () => {\r\n\temit('update:modelValue', intermediateValue.value);\r\n};\r\n</script>\r\n\r\n<template>\r\n\t<div class=\"top-editInput\">\r\n\t\t<TopInput\r\n\t\t\t:=\"input\"\r\n\t\t\t@keydown.esc.capture.stop=\"intermediateValue = modelValue\"\r\n\t\t\t@keydown.enter.stop=\"submit\"\r\n\t\t\tv-model=\"intermediateValue\"\r\n\t\t/>\r\n\r\n\t\t<TopButton\r\n\t\t\tv-if=\"intermediateValue !== modelValue\"\r\n\t\t\ticon=\"\"\r\n\t\t\tstyling=\"soft\"\r\n\t\t\t:=\"button\"\r\n\t\t\t@click=\"submit\"\r\n\t\t/>\r\n\t</div>\r\n</template>\r\n\r\n<style>\r\n.top-editInput {\r\n\twidth: 220px;\r\n\tflex-grow: 1;\r\n\tdisplay: flex;\r\n\talign-items: flex-end;\r\n\tgap: var(--top-gap-1);\r\n}\r\n\r\n.top-editInput .top-input {\r\n\twidth: unset;\r\n\tflex-grow: 1;\r\n}\r\n</style>\r\n","<script setup lang=\"ts\">\r\nimport type { Ref } from '@vue/reactivity';\r\nimport { ref, watch } from 'vue';\r\nimport type { Props, Emits } from './radioGroup';\r\n\r\nconst model = defineModel<string>({\r\n\trequired: true,\r\n});\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\tsize: 's',\r\n});\r\n\r\nconst emit = defineEmits<Emits>();\r\n\r\nconst elRef: Ref<HTMLElement | null> = ref(null);\r\n\r\nwatch(model, () => {\r\n\tif (!props.radiosProps?.some(item => item.value === model.value)) {\r\n\t\tmodel.value = props.radiosProps?.[0]?.value ?? '';\r\n\t}\r\n\r\n\telRef.value?.querySelector('.radioGroup_item-selected')?.scrollIntoView();\r\n}, { immediate: true });\r\n\r\nconst uid = 'radioGroup-' + Math.random();\r\n</script>\r\n\r\n<template>\r\n\t<div\r\n\t\tref=\"elRef\"\r\n\t\t:class=\"{\r\n\t\t\t['top-radioGroup']: true,\r\n\t\t\t['top-scrollBarXHidding']: true,\r\n\t\t\t['top-size_' + size]: !!size,\r\n\t\t\t['top-error']: isError,\r\n\t\t}\"\r\n\t>\r\n\t\t<label\r\n\t\t\tv-for=\"item of radiosProps\"\r\n\t\t\t:class=\"{\r\n\t\t\t\t['top-radioGroup_item-selected']: item.value === model,\r\n\t\t\t\t['top-radioGroup_item']: true,\r\n\t\t\t\t['top-forms-focusable']: true,\r\n\t\t\t\t['top-disabled']: item.disabled,\r\n\t\t\t}\"\r\n\t\t\t:data-top-icon=\"item.icon\"\r\n\t\t\t@click=\"model = item.value\"\r\n\t\t>\r\n\t\t\t{{ item.title }}\r\n\r\n\t\t\t<span\r\n\t\t\t\tv-if=\"showIndicator\"\r\n\t\t\t\tclass=\"top-radioGroup_circle\"\r\n\t\t\t></span>\r\n\r\n\t\t\t<!-- Для нативной навигации -->\r\n\t\t\t<input\r\n\t\t\t\tv-model=\"model\"\r\n\t\t\t\t:name=\"uid\"\r\n\t\t\t\ttype=\"radio\"\r\n\t\t\t\t:class=\"{\r\n\t\t\t\t\t['top-unvisible']: true,\r\n\t\t\t\t}\"\r\n\t\t\t\t:value=\"item.value\"\r\n\t\t\t\t:disabled=\"item.disabled\"\r\n\t\t\t/>\r\n\t\t</label>\r\n\t</div>\r\n</template>\r\n\r\n<style>\r\n@import \"./styles/top-scrollBar.css\";\r\n\r\n.top-radioGroup {\r\n\tuser-select: none;\r\n\tbox-sizing: border-box;\r\n\tborder-radius: 8px;\r\n\tbackground-color: var(--color-layout-middle);\r\n\theight: var(--top-forms-base-height);\r\n\tpadding: 2px;\r\n\tgap: 2px;\r\n\tdisplay: flex;\r\n\talign-items: flex-start;\r\n}\r\n\r\n.top-radioGroup_item {\r\n\tcolor: var(--color-text-2);\r\n\tcursor: pointer;\r\n\tbox-sizing: border-box;\r\n\tborder-radius: 6px;\r\n\theight: calc(var(--top-forms-base-height) - 4px);\r\n\tpadding: 0 16px;\r\n\tfont-weight: 400;\r\n\twhite-space: nowrap;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tflex-grow: 1;\r\n\tgap: 4px;\r\n}\r\n\r\n.top-radioGroup_item:hover {\r\n\tbackground-color: var(--color-layout-front-1);\r\n\tbox-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);\r\n}\r\n\r\n/* selected */\r\n.top-radioGroup_item-selected {\r\n\tcolor: var(--color-text-1);\r\n\tpointer-events: none;\r\n\tbackground-color: var(--color-bg-lightning-1);\r\n\tbox-shadow: 0px 4px 32px 0px rgba(4, 9, 84, 0.10), 0px 0px 4px 0px rgba(4, 9, 84, 0.08);\r\n}\r\n\r\n/* circle */\r\n.top-radioGroup_circle {\r\n\tcontent: \"\";\r\n\tbox-sizing: border-box;\r\n\tborder: 1px solid var(--color-line-3-opacity);\r\n\tborder-radius: 50%;\r\n\tpadding: 3px;\r\n\tmargin-left: auto;\r\n\twidth: calc(var(--top-forms-option-height) - 3px * 2);\r\n\theight: calc(var(--top-forms-option-height) - 3px * 2);\r\n}\r\n\r\n.top-radioGroup_item:hover .top-radioGroup_circle:before {\r\n\tborder-color: var(--color-line-primary-1);\r\n}\r\n\r\n/* circle selected */\r\n.top-radioGroup_item-selected .top-radioGroup_circle {\r\n\tborder-color: var(--color-line-primary-1);\r\n\tborder-width: 5px;\r\n}\r\n\r\n.top-radioGroup_item-selected:hover .top-radioGroup_circle {\r\n\tborder-color: var(--color-line-primary-1);\r\n}\r\n\r\n/* top-error */\r\n.top-radioGroup.top-error .top-radioGroup_item:not(.top-disabled) .top-radioGroup_circle {\r\n\tborder-color: var(--color-line-negative-1);\r\n}\r\n</style>\r\n","import type { Ref } from 'vue';\r\nimport { ref } from 'vue';\r\nimport { debounce } from '@/core/utils/lodash';\r\nimport type { Item, Props } from './selector2';\r\n\r\nexport const useAPI = (apiRequest: Props['apiRequest'], minLength: number, useCache: Props['useCache']) => {\r\n\t/**\r\n\t * Список, полученный через API\r\n\t */\r\n\tconst items: Ref<Array<Item>> = ref([]);\r\n\r\n\t/**\r\n\t * Флаг - идет загрузка\r\n\t */\r\n\tconst isLoading = ref(false);\r\n\r\n\tlet _searchText = '';\r\n\tlet _nextOffset: number | undefined;\r\n\r\n\tif (apiRequest && !apiRequest.params.limit) {\r\n\t\tapiRequest.params.limit = 100;\r\n\t}\r\n\r\n\t/**\r\n\t * Выполнить обращение к API\r\n\t *\r\n\t * При ошибке вернет undefined\r\n\t */\r\n\tconst callAPIRequest = async (): Promise<{ nextOffset?: number, result: Array<Item> } | undefined> => {\r\n\t\tif (!apiRequest) return;\r\n\r\n\t\tlet res;\r\n\t\tlet cacheKey;\r\n\r\n\t\tif (useCache) {\r\n\t\t\t// кэш для полученных ответов через apiRequest\r\n\t\t\t// общий для всех компонентов, использующих apiRequest\r\n\t\t\tapiRequest.cache ??= new Map();\r\n\r\n\t\t\tcacheKey = JSON.stringify(apiRequest.params);\r\n\t\t\tres = apiRequest.cache.get(cacheKey);\r\n\r\n\t\t\tif (res) {\r\n\t\t\t\treturn res;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tisLoading.value = true;\r\n\t\tres = await apiRequest.call();\r\n\t\tisLoading.value = false;\r\n\r\n\t\tif (res.errors) return;\r\n\r\n\t\tif (!Array.isArray(res.result)) {\r\n\t\t\tconsole.warn(`В result ожидался массив`);\r\n\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst indexWithError = (res.result as Array<Item | any>).findIndex(item => item.id === undefined || item.name === undefined);\r\n\t\tif (indexWithError !== -1) {\r\n\t\t\tconsole.warn(`В result[${indexWithError}] нет id или name`);\r\n\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (useCache) {\r\n\t\t\tapiRequest.cache.set(cacheKey as string, res);\r\n\t\t}\r\n\r\n\t\treturn res;\r\n\t};\r\n\r\n\t/**\r\n\t * Загрузить items\r\n\t */\r\n\tconst load = async () => {\r\n\t\tif (!apiRequest) return;\r\n\r\n\t\tapiRequest.params.offset = 0;\r\n\t\tapiRequest.params.search = _searchText;\r\n\r\n\t\tconst res = await callAPIRequest();\r\n\t\tif (!res) return;\r\n\r\n\t\t_nextOffset = res.nextOffset;\r\n\r\n\t\titems.value = res.result;\r\n\t};\r\n\r\n\t/**\r\n\t * Загрузить следующую страницу items\r\n\t */\r\n\tconst loadAppend = async () => {\r\n\t\tif (!apiRequest) return;\r\n\r\n\t\t// данных о следующих страницах не обнаружено\r\n\t\tif (!_nextOffset) return;\r\n\r\n\t\t// дозагружать нельзя, если не завершена предыдущшая загрузка\r\n\t\tif (isLoading.value) return;\r\n\r\n\t\tapiRequest.params.offset = _nextOffset;\r\n\t\tapiRequest.params.search = _searchText;\r\n\r\n\t\tconst res = await callAPIRequest();\r\n\t\tif (!res) return;\r\n\r\n\t\t_nextOffset = res.nextOffset;\r\n\r\n\t\titems.value = items.value.concat(res.result);\r\n\t};\r\n\r\n\tconst loadDebounce = debounce(() => load(), 200);\r\n\r\n\t/**\r\n\t * Выполнить поиск по указанному тексту\r\n\t *\r\n\t * Если длина текста меньше minLength, поиск не будет проивзеден\r\n\t *\r\n\t * Если текст не изменился, поиск не будет проивзеден\r\n\t * @param searchText - текст поиска\r\n\t * @param useDebounce - отложенное выполнение поиска\r\n\t */\r\n\tconst setSearchTextAndLoad = (searchText: string, useDebounce = true) => {\r\n\t\tif (!apiRequest) return;\r\n\r\n\t\tif (searchText.length < minLength) return;\r\n\r\n\t\t// условия поиска не поменялись, данные загружены\r\n\t\tif (searchText === _searchText && items.value.length) return;\r\n\r\n\t\t_searchText = searchText;\r\n\r\n\t\tif (useDebounce) {\r\n\t\t\tloadDebounce();\r\n\t\t} else {\r\n\t\t\tvoid load();\r\n\t\t}\r\n\t};\r\n\r\n\treturn {\r\n\t\titems,\r\n\t\tisLoading,\r\n\t\tloadAppend,\r\n\t\tsetSearchTextAndLoad,\r\n\t};\r\n};\r\n","<script setup lang=\"ts\">\r\nimport type { ComputedRef, ModelRef, ComponentInstance } from 'vue';\r\nimport { computed, ref, watch } from 'vue';\r\nimport Core from '@/core/core/core';\r\nimport { invertKeyboardLayout } from '@/core/utils/keyboard';\r\nimport { useI18n } from '@/core/plugins/i18n';\r\nimport { TopPopup, TopPopupListItem, TopPopupWidgetInput } from '@/components/popup/popup';\r\nimport type PopupClass from '@/components/popup/lib/popup';\r\nimport type { Item, Props, Slots } from './selector2';\r\nimport { useAPI } from './api';\r\nimport Selector2ItemMulti from './itemMulti.vue';\r\n\r\nconst props = withDefaults(defineProps<Props>(), {\r\n\titems: () => [] as Array<Item>,\r\n\tsize: 's',\r\n\tminLength: 0,\r\n\tshowSelectedInInput: true,\r\n});\r\n\r\nconst model = defineModel<Props['modelValue']>() as ModelRef<Props['modelValue']>;\r\n\r\ndefineSlots<Slots>();\r\n\r\n/**\r\n * Текст поиска по результатам\r\n */\r\nconst searchText = ref('');\r\n\r\nconst itemAll = {\r\n\tid: 0,\r\n\tname: useI18n().Common.All!,\r\n};\r\n\r\n/**\r\n * Экземпляр компонента Popup\r\n */\r\nconst popupRef = ref<ComponentInstance<typeof TopPopup> | null>(null);\r\n\r\n/**\r\n * Получить доступ к объекту popup\r\n */\r\nconst getPopup = (): PopupClass | undefined => {\r\n\treturn popupRef.value?.popup;\r\n};\r\n\r\n// для storybook\r\nif ((window as any).__STORYBOOK_PREVIEW__ && !props.modelValue) {\r\n\twatch(\r\n\t\t() => props.multiselect,\r\n\t\t() => {\r\n\t\t\tmodel.value = props.multiselect ? [] : { id: null, name: '' };\r\n\t\t},\r\n\t\t{ immediate: true },\r\n\t);\r\n}\r\n\r\nconst API = useAPI(props.apiRequest, props.minLength, props.useCache);\r\n\r\n/**\r\n * Варианты выбора: props.items + \"Выбрать все\"\r\n */\r\nconst localItems: ComputedRef<Array<Item>> = computed(() => {\r\n\tconst items: Array<Item> = [];\r\n\r\n\tif (!props.multiselect && props.appendAllValue) {\r\n\t\titems.push(itemAll);\r\n\t}\r\n\r\n\tprops.items.forEach(item => items.push({ ...item }));\r\n\r\n\treturn items;\r\n});\r\n\r\n/**\r\n * Проверить, что элемент выбран\r\n */\r\nconst isSelected = (item: Item, checkNameForNullId = true) => {\r\n\tif (checkNameForNullId && item.id === null) {\r\n\t\tif (Array.isArray(model.value)) {\r\n\t\t\treturn model.value.some(itemSelected => itemSelected.id === item.id && itemSelected.name === item.name);\r\n\t\t} else {\r\n\t\t\treturn item.name === model.value.name;\r\n\t\t}\r\n\t}\r\n\r\n\tif (Array.isArray(model.value)) {\r\n\t\treturn model.value.some(itemSelected => itemSelected.id === item.id);\r\n\t} else {\r\n\t\treturn item.id === model.value.id;\r\n\t}\r\n};\r\n\r\n/**\r\n * Варианты выбора, которые выводятся\r\n */\r\nconst itemsForShow = computed(() => {\r\n\tconst searchString = searchText.value.toLowerCase();\r\n\tconst searchStringInvertKeyboard = invertKeyboardLayout(searchString);\r\n\r\n\tlet items: typeof localItems.value = [];\r\n\r\n\tlocalItems.value.forEach((item) => {\r\n\t\tconst itemName = item.name.toLowerCase();\r\n\r\n\t\tif (\r\n\t\t\titem.id === Number(searchString) ||\r\n\t\t\titemName.includes(searchString) ||\r\n\t\t\titemName.includes(searchStringInvertKeyboard)\r\n\t\t) {\r\n\t\t\tif (itemName === searchString || itemName === searchStringInvertKeyboard) {\r\n\t\t\t\titems.unshift(item);\r\n\t\t\t} else {\r\n\t\t\t\titems.push(item);\r\n\t\t\t}\r\n\t\t}\r\n\t});\r\n\r\n\titems.push(...API.items.value);\r\n\r\n\tif (\r\n\t\tprops.appendSearchToResult &&\r\n\t\t!!searchText.value &&\r\n\t\t(!items.length || items[0].name.toLowerCase() !== searchString)\r\n\t) {\r\n\t\titems.push({\r\n\t\t\tid: null,\r\n\t\t\tname: searchText.value,\r\n\t\t});\r\n\t}\r\n\r\n\tif (props.multiselect) {\r\n\t\titems = items.filter(item => !isSelected(item));\r\n\t}\r\n\r\n\treturn items;\r\n});\r\n\r\n/**\r\n * Флаг - идет загрузка\r\n *\r\n * Скрывает вывод заглушки \"Нет результатов\" - для загрузки данных через API (multiselect = true) - (см. selectItem)\r\n */\r\nconst isLoading = ref(API.isLoading.value);\r\n\r\nwatch(API.isLoading, () => {\r\n\tisLoading.value = API.isLoading.value;\r\n});\r\n\r\n/**\r\n * Выбрать значение\r\n *\r\n * Управляет закрытием окна\r\n */\r\nconst selectItem = async (item: Item) => {\r\n\tif (props.multiselect) {\r\n\t\tif (!Array.isArray(model.value)) return;\r\n\r\n\t\tif (isSelected(item)) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (props.apiRequest && searchText.value) {\r\n\t\t\tisLoading.value = true;\r\n\t\t}\r\n\r\n\t\tconst newModel = [...model.value];\r\n\t\tnewModel.push({ ...item });\r\n\t\tmodel.value = newModel;\r\n\r\n\t\tif (Core.state.isMobile) {\r\n\t\t\tgetPopup()?.close();\r\n\r\n\t\t\t// сбросить введенный текст\r\n\t\t\tif (searchText.value) {\r\n\t\t\t\tsearchText.value = '';\r\n\t\t\t\tAPI.items.value = [];\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tgetPopup()?.recalcPosition();\r\n\t\t\t\tgetPopup()?.elPopupWidget?.querySelector('input')?.focus();\r\n\r\n\t\t\t\t// сбросить введенный текст, только если больше не найдено результатов\r\n\t\t\t\tif (searchText.value) {\r\n\t\t\t\t\tif (!itemsForShow.value.length) {\r\n\t\t\t\t\t\tsearchText.value = '';\r\n\t\t\t\t\t\tAPI.items.value = [];\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tif (props.apiRequest) {\r\n\t\t\t\t\t\t\tisLoading.value = false;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t} else {\r\n\t\t// сбросить введенный текст\r\n\t\tif (searchText.value) {\r\n\t\t\tsearchText.value = '';\r\n\t\t\tAPI.items.value = [];\r\n\t\t}\r\n\r\n\t\tif (JSON.stringify(item) !== JSON.stringify(model.value)) {\r\n\t\t\tmodel.value = { ...item };\r\n\t\t}\r\n\r\n\t\tgetPopup()?.close();\r\n\t}\r\n};\r\n\r\n/**\r\n * Выбрать следующее значение\r\n */\r\nconst selectNextItem = () => {\r\n\tif (!Array.isArray(model.value)) {\r\n\t\tconst currentIndex = localItems.value.findIndex(item => item.id === (model.value as Item).id);\r\n\t\tconst nextIndex = (currentIndex + 1) % localItems.value.length;\r\n\t\tmodel.value = { ...localItems.value[nextIndex] };\r\n\t}\r\n};\r\n\r\n/**\r\n * Удалить выбранное значение по id\r\n * @param id\r\n */\r\nconst deleteItemById = async (id: Item['id']) => {\r\n\tif (Array.isArray(model.value)) {\r\n\t\tmodel.value = model.value.filter(item => item.id !== id);\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tgetPopup()?.recalcPosition();\r\n\t\t});\r\n\t}\r\n};\r\n\r\nconst isOpened = ref(false); // флаг попап открыт\r\n\r\nif (props.apiRequest) {\r\n\twatch(isOpened, () => {\r\n\t\tif (isOpened.value) {\r\n\t\t\t// при открытии сразу выполнить поиск\r\n\t\t\tAPI.setSearchTextAndLoad(searchText.value, false);\r\n\t\t}\r\n\t});\r\n\r\n\t// отложенный поиск при вводе текста\r\n\twatch(searchText, () => API.setSearchTextAndLoad(searchText.value));\r\n}\r\n\r\nconst onScrollContentList = (e: Event) => {\r\n\tconst el = e.target as HTMLElement;\r\n\r\n\tif (el.scrollTop / (el.scrollHeight - el.offsetHeight) > 0.8) {\r\n\t\tAPI.loadAppend();\r\n\t}\r\n};\r\n</script>\r\n\r\n<template>\r\n\t<TopPopup\r\n\t\tref=\"popupRef\"\r\n\t\t@open=\"isOpened = true\"\r\n\t\t@close=\"isOpened = false\"\r\n\t\t@scrollContentList=\"apiRequest ? onScrollContentList($event) : undefined\"\r\n\t\t:notch=\"false\"\r\n\t\t:transitionDuration=\"0\"\r\n\t>\r\n\t\t<template #opener>\r\n\t\t\t<div\r\n\t\t\t\tv-top-focus.onupdate=\"isError\"\r\n\t\t\t\t:class=\"{\r\n\t\t\t\t\t'top-selector2' : true,\r\n\t\t\t\t\t'top-selector2-multiselect': multiselect,\r\n\t\t\t\t\t['top-size_' + size]: true,\r\n\t\t\t\t\t['top-disabled']: disabled,\r\n\t\t\t\t\t['top-forms-focusable']: !disabled,\r\n\t\t\t\t\t['top-error']: isError,\r\n\t\t\t\t}\"\r\n\t\t\t\t@keydown.enter.space=\"($event.currentTarget as HTMLElement).click()\"\r\n\t\t\t\ttabindex=\"0\"\r\n\t\t\t>\r\n\t\t\t\t<template v-if=\"multiselect\">\r\n\t\t\t\t\t<div class=\"top-selector2_activeItems\">\r\n\t\t\t\t\t\t<Selector2ItemMulti\r\n\t\t\t\t\t\t\tv-for=\"item of model as Array<Item>\"\r\n\t\t\t\t\t\t\t:id=\"item.id\"\r\n\t\t\t\t\t\t\t:name=\"item.name\"\r\n\t\t\t\t\t\t\t@delete=\"deleteItemById\"\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</template>\r\n\r\n\t\t\t\t<span v-if=\"!multiselect\" class=\"top-selector2_activeName top-ellipsis\">\r\n\t\t\t\t\t{{ !Array.isArray(model) ? model.name : '' }}\r\n\t\t\t\t</span>\r\n\r\n\t\t\t\t<span\r\n\t\t\t\t\tv-if=\"addChanger && !multiselect && localItems.length > 1 && !disabled\"\r\n\t\t\t\t\tclass=\"top-changer top-changer-selector\"\r\n\t\t\t\t\t@click.stop=\"selectNextItem\"\r\n\t\t\t\t></span>\r\n\t\t\t</div>\r\n\t\t</template>\r\n\r\n\t\t<template #widget>\r\n\t\t\t<TopPopupWidgetInput\r\n\t\t\t\ttitle=\"Поиск\"\r\n\t\t\t\ticon=\"\"\r\n\t\t\t\tv-model=\"searchText\"\r\n\t\t\t\t:isLoading=\"isLoading\"\r\n\t\t\t\t:placeholder=\"!Array.isArray(model) && !multiselect && showSelectedInInput ? model.name : placeholder\"\r\n\t\t\t/>\r\n\t\t</template>\r\n\r\n\t\t<template #contentList>\r\n\t\t\t<TopPopupListItem\r\n\t\t\t\tv-for=\"item of itemsForShow\"\r\n\t\t\t\t:class=\"{\r\n\t\t\t\t\t'top-active': !Array.isArray(model) && !multiselect && model.name === item.name\r\n\t\t\t\t}\"\r\n\t\t\t\t:key=\"item.id ?? undefined\"\r\n\t\t\t\t@click.stop=\"selectItem(item)\"\r\n\t\t\t>\r\n\t\t\t\t<slot\r\n\t\t\t\t\tv-if=\"$slots.item\"\r\n\t\t\t\t\tname=\"item\"\r\n\t\t\t\t\t:item=\"item\"\r\n\t\t\t\t></slot>\r\n\r\n\t\t\t\t<template\r\n\t\t\t\t\tv-else\r\n\t\t\t\t>\r\n\t\t\t\t\t{{ item.name }}\r\n\t\t\t\t</template>\r\n\t\t\t</TopPopupListItem>\r\n\r\n\t\t\t<TopPopupListItem\r\n\t\t\t\tv-if=\"!isLoading && !itemsForShow.length\"\r\n\t\t\t\ttype=\"regular\"\r\n\t\t\t>\r\n\t\t\t\t{{ $i18n.Common.No_results }}\r\n\t\t\t</TopPopupListItem>\r\n\t\t</template>\r\n\t</TopPopup>\r\n</template>\r\n\r\n<style>\r\n.top-selector2 {\r\n\twidth: 180px;\r\n\tmin-height: var(--top-forms-base-height);\r\n\tbox-sizing: border-box;\r\n\tposition: relative;\r\n\tdisplay: flex;\r\n\toverflow: hidden;\r\n\tpadding: var(--top-padding-1) var(--top-forms-padding);\r\n\tcolor: var(--top-forms-placeholder-color);\r\n\r\n\tborder-radius: var(--top-radius-2);\r\n\tborder: 1px solid var(--top-forms-border-color);\r\n\tbackground: var(--top-forms-background-color);\r\n}\r\n\r\n.top-selector2-multiselect {\r\n\twidth: unset;\r\n\tmin-width: 180px;\r\n\tpadding: var(--top-padding-1);\r\n}\r\n\r\n.top-selector2.top-active {\r\n\t--top-forms-border-color: var(--top-forms-border-color-hover);\r\n\t--top-forms-background-color: var(--top-forms-background-color-hover);\r\n}\r\n\r\n.top-selector2_activeItems {\r\n\tdisplay: flex;\r\n\tflex-wrap: wrap;\r\n\tgap: var(--top-padding-1);\r\n\tmax-width: 100%;\r\n}\r\n\r\n.top-selector2_activeName {\r\n\twhite-space: nowrap;\r\n}\r\n\r\n.top-changer-selector {\r\n\ttransform: translateX(-16px);\r\n}\r\n</style>\r\n","import type { ComponentCustomProps } from 'vue';\r\n\r\nimport EditArea from './editArea/editArea.vue';\r\nimport EditInput from './editInput/editInput.vue';\r\nimport RadioGroup from './radioGroup/radioGroup.vue';\r\nimport Selector2 from './selector2/selector2.vue';\r\nimport Menu from './menu/menu.vue';\r\nimport Info from './info/info.vue';\r\n\r\nexport const TopEditArea = EditArea as typeof EditArea & ComponentCustomProps;\r\nexport const TopEditInput = EditInput as typeof EditInput & ComponentCustomProps;\r\nexport const TopRadioGroup = RadioGroup as typeof RadioGroup & ComponentCustomProps;\r\nexport const TopSelector2 = Selector2 as typeof Selector2 & ComponentCustomProps;\r\nexport const TopMenu = Menu as typeof Menu & ComponentCustomProps;\r\nexport const TopInfo = Info as typeof Info & ComponentCustomProps;\r\n"],"names":["isChanged","vue","localValue","props","cancelBtnText","submit","value","emit","intermediateValue","elRef","model","_a","item","_c","_b","items","isLoading","_nextOffset","apiRequest","res","cacheKey","indexWithError","_searchText","callAPIRequest","loadAppend","searchText","minLength","loadDebounce","forms","popupRef","API","useAPI","localItems","itemAll","itemSelected","itemsForShow","searchStringInvertKeyboard","utils_keyboard","searchString","isSelected","selectItem","newModel","getPopup","nextIndex","deleteItemById","id","isOpened","onScrollContentList","e","el","TopEditArea","_sfc_main$5","TopEditInput","_sfc_main$4","TopRadioGroup","_sfc_main$3","TopSelector2","_sfc_main$1","TopMenu","menu_vue_vue_type_style_index_0_lang","TopInfo","_sfc_main"],"mappings":"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"}