stone-kit 0.0.1045 → 0.0.1049
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +88 -88
- package/dist/FilterWithSave-BxUAZs3U.js +2683 -0
- package/dist/components/CheckBoxNew/CheckBoxNew.js +5 -5
- package/dist/components/CommercialLotCard/CommercialLotCard.d.ts +1 -1
- package/dist/components/CommercialLotCard/CommercialLotCard.js +10 -79
- package/dist/components/CommercialLotCard/components/PaymentLink/PaymentLink.d.ts +2 -1
- package/dist/components/CommercialLotCard/components/PaymentLink/PaymentLink.js +9 -9
- package/dist/components/CommercialLotCard/components/Snippets/Snippets.js +27 -98
- package/dist/components/CommercialLotCard/components/Tags/Tags.js +1 -1
- package/dist/components/CommercialLotCard/types/CommercialLotCard.types.d.ts +1 -0
- package/dist/components/FilterWithSave/hooks/useFilterWithSave.js +26 -54
- package/dist/components/FilterWithSave/ui/FilterWithSave.js +7 -323
- package/dist/components/FormModal/ui/ModalForm.js +29 -1516
- package/dist/components/Logo/ui/Logo.js +6 -6
- package/dist/components/LotCard/hooks/useLotCard.js +24 -6
- package/dist/components/LotCard/index.js +2 -2
- package/dist/components/LotCard/ui/LotCard.js +11 -221
- package/dist/components/ModalSuccess/ModalSuccess.js +1 -1
- package/dist/components/RoundButton/ui/RoundButton.js +1 -1
- package/dist/components/Select/ui/Category.js +2 -2
- package/dist/components/Select/ui/Option.js +2 -2
- package/dist/components/Select/ui/Select.js +2 -2
- package/dist/components/SliderNavigation/ui/SliderNavigation.js +6 -6
- package/dist/components/SortSelect/index.js +1 -1
- package/dist/components/SortSelect/ui/SortSelect.js +26 -108
- package/dist/components/SummarySelect/ui/SummarySelect.js +1 -1
- package/dist/components/TabSelect/ui/TabSelect.js +4 -4
- package/dist/components/TabSwitcher/index.js +2 -2
- package/dist/components/TabSwitcher/ui/TabSwitcher.js +26 -121
- package/dist/components/Tag/ui/Tag.js +97 -96
- package/dist/components/Tag/ui/Tag.types.d.ts +1 -0
- package/dist/components/Tag/ui/Tag.types.js +2 -1
- package/dist/layout/components/Header/Header.js +65 -44
- package/dist/layout/components/Menu.js +37 -15
- package/dist/main.js +65 -70
- package/dist/pages/ButtonsPage/Buttons.js +61 -44
- package/dist/pages/FormsPage/FormsPage.js +42 -22
- package/dist/pages/IconsPage/IconsPage.js +31 -9
- package/dist/pages/InputPage/InputPage.js +32 -10
- package/dist/pages/LogoPage/LogoPage.js +36 -13
- package/dist/pages/LotsPage/LotsPage.js +38 -30
- package/dist/pages/LotsPage/const.d.ts +4 -1
- package/dist/pages/LotsPage/const.js +30 -4
- package/dist/pages/ModalsPage/ModalPage.js +66 -46
- package/dist/pages/SelectPage/SelectPage.js +40 -41
- package/dist/pages/TabsPage/TabsPage.js +1 -1
- package/dist/pages/TagsPage/TagsPage.js +44 -23
- package/dist/stone-kit.css +1 -1
- package/dist/stories/entities/CommercialLotCard/CommercialLotCard.stories.js +1 -1
- package/dist/stories/shared/ui/Button/Button.stories.js +4 -4
- package/dist/stories/shared/ui/FilterWithSave/FilterWithSave.stories.js +1 -1
- package/dist/stories/shared/ui/FormModal/FormModal.stories.js +7 -7
- package/dist/stories/shared/ui/SortSelect/SortSelect.stories.js +1 -1
- package/dist/stories/shared/ui/TabSwitcher/TabSwitcher.stories.js +1 -1
- package/dist/stories/shared/ui/Tag/Tag.stories.js +4 -4
- package/package.json +1 -1
- package/dist/useLotCard-D-gK4J_o.js +0 -186
- package/dist/{Option-DmDx_xOt.js → Option-DdjBe9yb.js} +1 -1
|
@@ -0,0 +1,2683 @@
|
|
|
1
|
+
import { jsx as o, jsxs as F, Fragment as it } from "react/jsx-runtime";
|
|
2
|
+
import { NewIcon as Se } from "./components/NewIcon/ui/NewIcon.js";
|
|
3
|
+
import { Modal as ot } from "./components/Modal/ui/Modal.js";
|
|
4
|
+
import { Text as ct } from "./components/Text/ui/Text.js";
|
|
5
|
+
import { c as Ie, g as or } from "./index-YnD2EP-S.js";
|
|
6
|
+
import { Button as Ae } from "./components/Button/ui/Button.js";
|
|
7
|
+
import "./components/mobileButton/ui/MobileButton.js";
|
|
8
|
+
import "./components/DestinationTab/ui/DestinationTab.js";
|
|
9
|
+
import "./components/RoundButton/ui/RoundButton.js";
|
|
10
|
+
import { Tag as De } from "./components/Tag/ui/Tag.js";
|
|
11
|
+
import "./components/Switcher/ui/Switcher.js";
|
|
12
|
+
import { Flex as cr } from "./components/Flex/ui/Flex.js";
|
|
13
|
+
import { Input as tt } from "./components/Input/ui/Input.js";
|
|
14
|
+
import E, { useState as Te, useRef as Mt, useEffect as Oe } from "react";
|
|
15
|
+
import "react-dom";
|
|
16
|
+
import "./components/GroupedInput/ui/GroupedInputs.js";
|
|
17
|
+
import "./components/MetroTag/ui/MetroTag.js";
|
|
18
|
+
import { checkLargeOffice as jt } from "./shared/checkLargeOffice.js";
|
|
19
|
+
import { sclMillion as Nt } from "./shared/mlnRound.js";
|
|
20
|
+
import "./components/Select/ui/Select.js";
|
|
21
|
+
import { useClientWidth as _e } from "./shared/useClientWidth.js";
|
|
22
|
+
import { s as ce, u as dr } from "./useSortSelect-IeonkD5d.js";
|
|
23
|
+
import "./components/SliderNavigation/ui/SliderNavigation.js";
|
|
24
|
+
import "./components/LotCardSkeleton/ui/LotCardSkeleton.js";
|
|
25
|
+
import "./components/TabSelect/ui/TabSelect.js";
|
|
26
|
+
import { nameReg as ur, phoneReg as fr, emailReg as mr } from "./components/FormModal/utils/reg.js";
|
|
27
|
+
import { CheckBox as wt } from "./components/CheckBox/CheckBox.js";
|
|
28
|
+
import { TextArea as pr } from "./components/TextArea/TextArea.js";
|
|
29
|
+
import { fmtNumber as hr } from "./shared/fmtNumber.js";
|
|
30
|
+
import { Price as yr } from "./components/CommercialLotCard/components/Price/Price.js";
|
|
31
|
+
import { O as Ct } from "./Option-DdjBe9yb.js";
|
|
32
|
+
import "./components/CheckBoxNew/CheckBoxNew.js";
|
|
33
|
+
import "./components/CheckboxSelect/ui/CheckboxSelect.js";
|
|
34
|
+
import { getTagsFeatures as gr } from "./components/CommercialLotCard/utils/getTagsFeatures.js";
|
|
35
|
+
import { Tags as kt } from "./components/CommercialLotCard/components/Tags/Tags.js";
|
|
36
|
+
import { FavoriteIcon as qt } from "./components/FavoriteIcon/FavoriteIcon.js";
|
|
37
|
+
import { PaymentLink as vr } from "./components/CommercialLotCard/components/PaymentLink/PaymentLink.js";
|
|
38
|
+
import { getTagsFeatures as br } from "./components/LotCard/utils/getTagsFeatures.js";
|
|
39
|
+
import { checkBedroomsCount as xr } from "./components/LotCard/utils/checkBedroomsCount.js";
|
|
40
|
+
import { formatPayment as Sr } from "./components/LotCard/utils/monthlyPayment.js";
|
|
41
|
+
import { formatPrice as Re } from "./components/LotCard/utils/formatPrice.js";
|
|
42
|
+
const Fr = "_root_1qhai_1", Nr = "_text_1qhai_18", wr = "_textMini_1qhai_26", Cr = "_rootCol_1qhai_32", kr = "_item_1qhai_38", Tr = "_whiteRow_1qhai_57", Ar = "_firstItem_1qhai_68", Pr = "_lastItem_1qhai_72", Ir = "_whiteRowGrayLabel_1qhai_103", Lr = "_labelItem_1qhai_118", Wr = "_outlined_1qhai_147", Vr = "_apart_1qhai_204", Br = "_isLong_1qhai_204", Or = "_autoWidth_1qhai_219", _r = "_mini_1qhai_233", Er = "_isDisabled_1qhai_241", Dr = "_grayRow_1qhai_265", ee = {
|
|
43
|
+
root: Fr,
|
|
44
|
+
text: Nr,
|
|
45
|
+
textMini: wr,
|
|
46
|
+
rootCol: Cr,
|
|
47
|
+
item: kr,
|
|
48
|
+
whiteRow: Tr,
|
|
49
|
+
firstItem: Ar,
|
|
50
|
+
lastItem: Pr,
|
|
51
|
+
whiteRowGrayLabel: Ir,
|
|
52
|
+
labelItem: Lr,
|
|
53
|
+
outlined: Wr,
|
|
54
|
+
apart: Vr,
|
|
55
|
+
isLong: Br,
|
|
56
|
+
autoWidth: Or,
|
|
57
|
+
mini: _r,
|
|
58
|
+
isDisabled: Er,
|
|
59
|
+
grayRow: Dr,
|
|
60
|
+
"tiny-size": "_tiny-size_1qhai_293",
|
|
61
|
+
"small-size": "_small-size_1qhai_298",
|
|
62
|
+
"medium-size": "_medium-size_1qhai_303",
|
|
63
|
+
"large-size": "_large-size_1qhai_308",
|
|
64
|
+
"text-tiny-size": "_text-tiny-size_1qhai_313",
|
|
65
|
+
"text-small-size": "_text-small-size_1qhai_319",
|
|
66
|
+
"text-medium-size": "_text-medium-size_1qhai_324",
|
|
67
|
+
"text-large-size": "_text-large-size_1qhai_329",
|
|
68
|
+
"small-size_m": "_small-size_m_1qhai_335",
|
|
69
|
+
"medium-size_m": "_medium-size_m_1qhai_339",
|
|
70
|
+
"large-size_m": "_large-size_m_1qhai_343",
|
|
71
|
+
"text-small-size_m": "_text-small-size_m_1qhai_347",
|
|
72
|
+
"text-medium-size_m": "_text-medium-size_m_1qhai_351",
|
|
73
|
+
"text-large-size_m": "_text-large-size_m_1qhai_355",
|
|
74
|
+
"small-size_l": "_small-size_l_1qhai_370",
|
|
75
|
+
"medium-size_l": "_medium-size_l_1qhai_374",
|
|
76
|
+
"large-size_l": "_large-size_l_1qhai_378",
|
|
77
|
+
"text-small-size_l": "_text-small-size_l_1qhai_382",
|
|
78
|
+
"text-medium-size_l": "_text-medium-size_l_1qhai_386",
|
|
79
|
+
"text-large-size_l": "_text-large-size_l_1qhai_390"
|
|
80
|
+
}, Ge = Ie.bind(ee), Rr = ({
|
|
81
|
+
children: e,
|
|
82
|
+
variant: r = "whiteRow",
|
|
83
|
+
isApart: t = !1,
|
|
84
|
+
addClassName: i = "",
|
|
85
|
+
col: l = !1
|
|
86
|
+
}) => /* @__PURE__ */ o("div", { className: Ge(ee.root, ee[r], { [ee.rootCol]: l, [ee.apart]: t }, i), children: e }), zt = (e) => {
|
|
87
|
+
const { isTablet: r, isDesktop: t } = _e(), {
|
|
88
|
+
index: i,
|
|
89
|
+
children: l,
|
|
90
|
+
addItemClassName: n,
|
|
91
|
+
addLabelClassname: d,
|
|
92
|
+
addTextClass: u,
|
|
93
|
+
size_s: W = "large",
|
|
94
|
+
size_m: T,
|
|
95
|
+
size_l: p,
|
|
96
|
+
disabled: b = !1,
|
|
97
|
+
itemsLength: g = 0,
|
|
98
|
+
isLongOn: V = !0,
|
|
99
|
+
width: A,
|
|
100
|
+
width_m: w,
|
|
101
|
+
width_l: N,
|
|
102
|
+
mini: B = !1,
|
|
103
|
+
dataTestId: v,
|
|
104
|
+
ref: x,
|
|
105
|
+
...P
|
|
106
|
+
} = e, S = (l?.toString().length ? l?.toString().length > 2 : !1) && V, D = (q, R) => q && w ? w : R && N ? N : A, G = !A && !w && !N && S;
|
|
107
|
+
return /* @__PURE__ */ F("label", { className: Ge(ee.labelItem, { [ee.isLong]: S }, d), children: [
|
|
108
|
+
/* @__PURE__ */ o(
|
|
109
|
+
"input",
|
|
110
|
+
{
|
|
111
|
+
ref: x,
|
|
112
|
+
type: "checkbox",
|
|
113
|
+
...P,
|
|
114
|
+
disabled: b
|
|
115
|
+
}
|
|
116
|
+
),
|
|
117
|
+
/* @__PURE__ */ o(
|
|
118
|
+
"div",
|
|
119
|
+
{
|
|
120
|
+
style: { width: D(r, t) },
|
|
121
|
+
"data-testid": v,
|
|
122
|
+
className: Ge(
|
|
123
|
+
ee.item,
|
|
124
|
+
{
|
|
125
|
+
[ee.firstItem]: i === 0,
|
|
126
|
+
[ee.lastItem]: i === g - 1,
|
|
127
|
+
[ee.isDisabled]: b,
|
|
128
|
+
[ee.autoWidth]: G,
|
|
129
|
+
[ee.mini]: B
|
|
130
|
+
},
|
|
131
|
+
ee[`${W}-size`],
|
|
132
|
+
ee[`${T}-size_m`],
|
|
133
|
+
ee[`${p}-size_l`],
|
|
134
|
+
n
|
|
135
|
+
),
|
|
136
|
+
children: /* @__PURE__ */ o(
|
|
137
|
+
ct,
|
|
138
|
+
{
|
|
139
|
+
className: Ge(
|
|
140
|
+
ee.text,
|
|
141
|
+
ee[`text-${W}-size`],
|
|
142
|
+
ee[`text-${T}-size_m`],
|
|
143
|
+
ee[`text-${p}-size_l`],
|
|
144
|
+
{ [ee.textMini]: B },
|
|
145
|
+
u
|
|
146
|
+
),
|
|
147
|
+
children: l
|
|
148
|
+
}
|
|
149
|
+
)
|
|
150
|
+
}
|
|
151
|
+
)
|
|
152
|
+
] });
|
|
153
|
+
};
|
|
154
|
+
zt.displayName = "TabSwitcherItem";
|
|
155
|
+
const Ue = Object.assign(Rr, {
|
|
156
|
+
Item: zt
|
|
157
|
+
}), Mr = "_root_g40xm_1", jr = "_lotBtn_g40xm_12", qr = "_rootDisable_g40xm_26", zr = "_lotImageWrapper_g40xm_26", Xr = "_lotInfoWrapper_g40xm_27", Ur = "_infoHeader_g40xm_48", Zr = "_monthlyWrapper_g40xm_57", Gr = "_price_g40xm_67", Hr = "_monthlyPayment_g40xm_74", Jr = "_decor_g40xm_80", Yr = "_lotPropertyListMobile_g40xm_87", Kr = "_lotPropertyItem_g40xm_95", Qr = "_lotPropertyListDesktop_g40xm_112", $r = "_lotPriceWrapper_g40xm_116", es = "_discountWrapper_g40xm_122", ts = "_discountPrice_g40xm_133", rs = "_priceWrap_g40xm_145", ss = "_snippetLast_g40xm_155", is = "_snippet_g40xm_155", ns = "_tagsMobile_g40xm_170", as = "_discountTag_g40xm_185", ls = "_lotPricePerMetr_g40xm_189", os = "_btnWrapper_g40xm_194", cs = "_title_g40xm_201", ds = "_snippets_g40xm_205", us = "_retailSnippets_g40xm_210", fs = "_shownSnippets_g40xm_215", ms = "_addSnippets_g40xm_240", ps = "_addSnippetsActive_g40xm_256", hs = "_addSnippetsList_g40xm_261", ys = "_closeSnippetBtn_g40xm_305", gs = "_rootRow_g40xm_317", vs = "_rowTablet_g40xm_328", bs = "_rootRightSide_g40xm_369", xs = "_topWrapper_g40xm_386", Ss = "_botWrapper_g40xm_391", Fs = "_lotPriceWrapperRow_g40xm_422", Ns = "_fullscreenBtn_g40xm_432", ws = "_projectLotPricePerMetr_g40xm_451", Cs = "_paymentClass_g40xm_491", k = {
|
|
158
|
+
root: Mr,
|
|
159
|
+
lotBtn: jr,
|
|
160
|
+
rootDisable: qr,
|
|
161
|
+
lotImageWrapper: zr,
|
|
162
|
+
lotInfoWrapper: Xr,
|
|
163
|
+
infoHeader: Ur,
|
|
164
|
+
monthlyWrapper: Zr,
|
|
165
|
+
price: Gr,
|
|
166
|
+
monthlyPayment: Hr,
|
|
167
|
+
decor: Jr,
|
|
168
|
+
lotPropertyListMobile: Yr,
|
|
169
|
+
lotPropertyItem: Kr,
|
|
170
|
+
lotPropertyListDesktop: Qr,
|
|
171
|
+
lotPriceWrapper: $r,
|
|
172
|
+
discountWrapper: es,
|
|
173
|
+
discountPrice: ts,
|
|
174
|
+
priceWrap: rs,
|
|
175
|
+
snippetLast: ss,
|
|
176
|
+
snippet: is,
|
|
177
|
+
tagsMobile: ns,
|
|
178
|
+
discountTag: as,
|
|
179
|
+
lotPricePerMetr: ls,
|
|
180
|
+
btnWrapper: os,
|
|
181
|
+
title: cs,
|
|
182
|
+
snippets: ds,
|
|
183
|
+
retailSnippets: us,
|
|
184
|
+
shownSnippets: fs,
|
|
185
|
+
addSnippets: ms,
|
|
186
|
+
addSnippetsActive: ps,
|
|
187
|
+
addSnippetsList: hs,
|
|
188
|
+
closeSnippetBtn: ys,
|
|
189
|
+
rootRow: gs,
|
|
190
|
+
rowTablet: vs,
|
|
191
|
+
rootRightSide: bs,
|
|
192
|
+
topWrapper: xs,
|
|
193
|
+
botWrapper: Ss,
|
|
194
|
+
lotPriceWrapperRow: Fs,
|
|
195
|
+
fullscreenBtn: Ns,
|
|
196
|
+
projectLotPricePerMetr: ws,
|
|
197
|
+
paymentClass: Cs
|
|
198
|
+
}, We = Ie.bind(k), ks = ({ lot: e, rowConditions: r }) => {
|
|
199
|
+
const {
|
|
200
|
+
status: t,
|
|
201
|
+
direction: i,
|
|
202
|
+
area: l,
|
|
203
|
+
floor: n,
|
|
204
|
+
endFloor: d,
|
|
205
|
+
floorsNumber: u,
|
|
206
|
+
type: W,
|
|
207
|
+
isCorner: T,
|
|
208
|
+
windowViews: p,
|
|
209
|
+
subTypeName: b,
|
|
210
|
+
number: g,
|
|
211
|
+
bedroomsCount: V,
|
|
212
|
+
mortgageMonthlyPayment: A
|
|
213
|
+
} = e, [w, N] = Te(!1), B = t === 2, v = i === 1, x = W === 11, P = l ? l + " м²" : "", S = n && u ? (d && d !== n ? n + "-" + d : n) + " из " + u : "", D = br({ ...e }), { isTablet: G, isDesktop: q, isMobile: R, currentClientWidth: te } = _e(), O = typeof r < "u" ? r : q || G, I = () => x ? u ? "Кол-во этажей: " + u : "" : S ? "Этаж: " + S : "", L = () => x ? u ? /* @__PURE__ */ F("li", { className: We(k.lotPropertyItem), children: [
|
|
214
|
+
/* @__PURE__ */ o("div", { children: "Количество этажей" }),
|
|
215
|
+
/* @__PURE__ */ o("div", { children: u })
|
|
216
|
+
] }) : null : S ? /* @__PURE__ */ F("li", { className: We(k.lotPropertyItem), children: [
|
|
217
|
+
/* @__PURE__ */ o("div", { children: "Этаж" }),
|
|
218
|
+
/* @__PURE__ */ o("div", { children: S })
|
|
219
|
+
] }) : null, M = () => {
|
|
220
|
+
if (W === 3) {
|
|
221
|
+
if (R && (!p || p.length === 0))
|
|
222
|
+
return null;
|
|
223
|
+
let U = 0;
|
|
224
|
+
const _ = q ? 36 : 28, Y = [], K = [];
|
|
225
|
+
if (T) {
|
|
226
|
+
const Q = "Угловая";
|
|
227
|
+
if (U + Q.length <= _)
|
|
228
|
+
Y.push(Q), U += Q.length;
|
|
229
|
+
else
|
|
230
|
+
return Y;
|
|
231
|
+
}
|
|
232
|
+
if (p) {
|
|
233
|
+
const Q = p.filter((le) => le && le.trim() !== "");
|
|
234
|
+
let ae = 0, me = U;
|
|
235
|
+
for (let le = 0; le < Q.length; le++) {
|
|
236
|
+
const Fe = Q[le], we = ae > 0 ? " " + Fe : Fe;
|
|
237
|
+
if (me + we.length <= _)
|
|
238
|
+
Y.push(Fe), me += we.length, ae++;
|
|
239
|
+
else {
|
|
240
|
+
if (ae === 0) {
|
|
241
|
+
const Ne = _ - me;
|
|
242
|
+
if (Ne > 3) {
|
|
243
|
+
const z = Fe.substring(0, Ne - 3) + "...";
|
|
244
|
+
Y.push(z), me = _;
|
|
245
|
+
} else
|
|
246
|
+
Y.push("..."), me += 3;
|
|
247
|
+
}
|
|
248
|
+
K.push(...Q.slice(le));
|
|
249
|
+
break;
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
U = me;
|
|
253
|
+
}
|
|
254
|
+
return /* @__PURE__ */ F("div", { className: k.retailSnippets, children: [
|
|
255
|
+
/* @__PURE__ */ o("ul", { className: k.shownSnippets, children: Y?.map((Q, ae) => /* @__PURE__ */ o("li", { children: Q }, ae)) }),
|
|
256
|
+
K?.length > 0 && /* @__PURE__ */ F(
|
|
257
|
+
"div",
|
|
258
|
+
{
|
|
259
|
+
className: We(k.addSnippets, { [k.addSnippetsActive]: w }),
|
|
260
|
+
onClick: (Q) => {
|
|
261
|
+
q || (Q.stopPropagation(), Q.preventDefault(), N((ae) => !ae));
|
|
262
|
+
},
|
|
263
|
+
onMouseEnter: () => {
|
|
264
|
+
q && N(!0);
|
|
265
|
+
},
|
|
266
|
+
onMouseLeave: () => {
|
|
267
|
+
q && N(!1);
|
|
268
|
+
},
|
|
269
|
+
children: [
|
|
270
|
+
"+" + K?.length,
|
|
271
|
+
w && /* @__PURE__ */ F("ul", { className: k.addSnippetsList, children: [
|
|
272
|
+
K.map((Q, ae) => /* @__PURE__ */ o("li", { children: Q }, ae)),
|
|
273
|
+
/* @__PURE__ */ o("div", { className: k.closeSnippetBtn, children: /* @__PURE__ */ o(
|
|
274
|
+
Se,
|
|
275
|
+
{
|
|
276
|
+
name: "close",
|
|
277
|
+
size: "16",
|
|
278
|
+
color: "#ffffff"
|
|
279
|
+
}
|
|
280
|
+
) })
|
|
281
|
+
] })
|
|
282
|
+
]
|
|
283
|
+
}
|
|
284
|
+
)
|
|
285
|
+
] });
|
|
286
|
+
}
|
|
287
|
+
return D.length ? /* @__PURE__ */ o("div", { className: k.snippets, children: D.map((U, _) => {
|
|
288
|
+
const Y = _ === D.length - 1;
|
|
289
|
+
return /* @__PURE__ */ o(
|
|
290
|
+
"div",
|
|
291
|
+
{
|
|
292
|
+
className: We(k.snippet, Y ? "" : k.snippetLast),
|
|
293
|
+
children: U.text
|
|
294
|
+
},
|
|
295
|
+
_
|
|
296
|
+
);
|
|
297
|
+
}) }) : null;
|
|
298
|
+
};
|
|
299
|
+
return {
|
|
300
|
+
currentClientWidth: te,
|
|
301
|
+
isBuilding: x,
|
|
302
|
+
LotCardInfo: () => {
|
|
303
|
+
const U = v && W && b ? b : xr(V), _ = x ? U : `${U}${g ? `, ${g}` : ""}`;
|
|
304
|
+
return /* @__PURE__ */ o(it, { children: /* @__PURE__ */ F("div", { className: We(k.monthlyWrapper), children: [
|
|
305
|
+
_ && /* @__PURE__ */ o(
|
|
306
|
+
ct,
|
|
307
|
+
{
|
|
308
|
+
className: We(k.infoHeader),
|
|
309
|
+
html: _
|
|
310
|
+
}
|
|
311
|
+
),
|
|
312
|
+
A && /* @__PURE__ */ o("div", { className: k.monthlyPayment, children: Sr(A) }),
|
|
313
|
+
/* @__PURE__ */ o(M, {})
|
|
314
|
+
] }) });
|
|
315
|
+
},
|
|
316
|
+
tagFeatures: D,
|
|
317
|
+
FloorByType: L,
|
|
318
|
+
isTablet: G,
|
|
319
|
+
isDesktop: q,
|
|
320
|
+
getFloorStr: I,
|
|
321
|
+
isReserved: B,
|
|
322
|
+
isMobile: R,
|
|
323
|
+
areaStr: P,
|
|
324
|
+
floorStr: S,
|
|
325
|
+
isShowSnippet: w,
|
|
326
|
+
setIsShowSnippet: N,
|
|
327
|
+
rowConditionsVar: O
|
|
328
|
+
};
|
|
329
|
+
}, Ts = "", oe = Ie.bind(k), Hn = ({
|
|
330
|
+
lot: e,
|
|
331
|
+
handleBtnForm: r,
|
|
332
|
+
handleFullScreenBtn: t,
|
|
333
|
+
btnDisabled: i,
|
|
334
|
+
addClassname: l,
|
|
335
|
+
btnName: n = "Уточнить детали",
|
|
336
|
+
imgNode: d,
|
|
337
|
+
rowConditions: u,
|
|
338
|
+
addClassnameLotImage: W,
|
|
339
|
+
isFavorite: T,
|
|
340
|
+
favoriteClickHandler: p
|
|
341
|
+
}) => {
|
|
342
|
+
const {
|
|
343
|
+
housing: b,
|
|
344
|
+
sellingPricePerMeter: g,
|
|
345
|
+
interiorPlanImg: V,
|
|
346
|
+
direction: A,
|
|
347
|
+
floorPlanImg: w,
|
|
348
|
+
discount: N,
|
|
349
|
+
sellingPrice: B,
|
|
350
|
+
sellingPriceBeforeDiscount: v
|
|
351
|
+
} = e, x = !!e.project?.showPriceSubType?.some((z) => Number(z.filter) === e.subType), P = x && Number(e.sellingPrice) && e.bestPurchasingConditions, S = !x && e.bestPurchasingConditions && Number(e.sellingPrice), D = jt(e), G = x && Number(B) && !D, q = () => G ? "С учётом скидки -1% в честь дня рождения STONE" : "Скидка 1% в честь дня рождения STONE", R = () => {
|
|
352
|
+
if (S)
|
|
353
|
+
return {
|
|
354
|
+
notMobileText: `Первоначальный взнос ${e.bestPurchasingConditions} %`,
|
|
355
|
+
mobileText: `${e.bestPurchasingConditions} %`
|
|
356
|
+
};
|
|
357
|
+
if (e.hasBestPurchasingConditions) return {
|
|
358
|
+
notMobileText: "Рассрочка 0% на весь срок",
|
|
359
|
+
mobileText: "0% на весь срок"
|
|
360
|
+
};
|
|
361
|
+
if (P && e.bestPurchasingConditions) {
|
|
362
|
+
const z = e.bestPurchasingConditions * 0.01 * Number(e.sellingPrice);
|
|
363
|
+
return {
|
|
364
|
+
notMobileText: `Первоначальный взнос ${Nt(z)} млн ₽`,
|
|
365
|
+
mobileText: `${Nt(z)} млн ₽`
|
|
366
|
+
};
|
|
367
|
+
}
|
|
368
|
+
return {
|
|
369
|
+
notMobileText: null,
|
|
370
|
+
mobileText: null
|
|
371
|
+
};
|
|
372
|
+
}, O = S ? "Первоначальный взнос" : e.hasBestPurchasingConditions ? "Рассрочка" : P ? "Первоначальный взнос" : "", { notMobileText: I, mobileText: L } = R(), M = q(), {
|
|
373
|
+
getFloorStr: j,
|
|
374
|
+
FloorByType: U,
|
|
375
|
+
areaStr: _,
|
|
376
|
+
isReserved: Y,
|
|
377
|
+
rowConditionsVar: K,
|
|
378
|
+
currentClientWidth: Q,
|
|
379
|
+
isMobile: ae,
|
|
380
|
+
isBuilding: me,
|
|
381
|
+
LotCardInfo: le
|
|
382
|
+
} = ks({ lot: e, rowConditions: u });
|
|
383
|
+
if (!Q) return null;
|
|
384
|
+
const Fe = () => /* @__PURE__ */ F("div", { className: oe(k.lotImageWrapper, W), children: [
|
|
385
|
+
d || /* @__PURE__ */ o(
|
|
386
|
+
"img",
|
|
387
|
+
{
|
|
388
|
+
loading: "lazy",
|
|
389
|
+
src: V ?? w ?? Ts,
|
|
390
|
+
width: 280,
|
|
391
|
+
height: 200,
|
|
392
|
+
alt: "logo_image"
|
|
393
|
+
}
|
|
394
|
+
),
|
|
395
|
+
p && /* @__PURE__ */ o(qt, { handleClickFavorite: (z) => {
|
|
396
|
+
p && p(e), z.preventDefault(), z.stopPropagation();
|
|
397
|
+
}, isFavorite: T })
|
|
398
|
+
] }), we = () => /* @__PURE__ */ F("div", { className: oe(k.btnWrapper), children: [
|
|
399
|
+
/* @__PURE__ */ o(
|
|
400
|
+
Ae,
|
|
401
|
+
{
|
|
402
|
+
as: "button",
|
|
403
|
+
"data-testid": "lot_fullscreen",
|
|
404
|
+
disabled: i,
|
|
405
|
+
variant: "whiteStroke",
|
|
406
|
+
additionalClass: k.fullscreenBtn,
|
|
407
|
+
onClick: (z) => {
|
|
408
|
+
z.preventDefault(), t && t();
|
|
409
|
+
},
|
|
410
|
+
children: /* @__PURE__ */ o(
|
|
411
|
+
Se,
|
|
412
|
+
{
|
|
413
|
+
name: "fullscreen",
|
|
414
|
+
color: "#777E90",
|
|
415
|
+
size: "20"
|
|
416
|
+
}
|
|
417
|
+
)
|
|
418
|
+
}
|
|
419
|
+
),
|
|
420
|
+
/* @__PURE__ */ o(
|
|
421
|
+
Ae,
|
|
422
|
+
{
|
|
423
|
+
as: "button",
|
|
424
|
+
size: "medium",
|
|
425
|
+
disabled: Y,
|
|
426
|
+
variant: Y ? "gray" : "blue",
|
|
427
|
+
width: "full",
|
|
428
|
+
additionalClass: k.lotBtn,
|
|
429
|
+
"data-testid": "lot_form",
|
|
430
|
+
post: Y ? /* @__PURE__ */ o(
|
|
431
|
+
Se,
|
|
432
|
+
{
|
|
433
|
+
name: "lock",
|
|
434
|
+
size: "24",
|
|
435
|
+
color: "#777E90"
|
|
436
|
+
}
|
|
437
|
+
) : void 0,
|
|
438
|
+
onClick: (z) => {
|
|
439
|
+
z.preventDefault(), r(z);
|
|
440
|
+
},
|
|
441
|
+
children: n
|
|
442
|
+
}
|
|
443
|
+
)
|
|
444
|
+
] }), Ne = () => /* @__PURE__ */ F("div", { className: k.rootRightSide, children: [
|
|
445
|
+
/* @__PURE__ */ F("div", { className: k.topWrapper, children: [
|
|
446
|
+
K && /* @__PURE__ */ o(le, {}),
|
|
447
|
+
!ae && !Y && /* @__PURE__ */ F("div", { style: { display: "flex", alignItems: "flex-end", flexDirection: "column" }, children: [
|
|
448
|
+
/* @__PURE__ */ F("div", { className: k.priceWrap, children: [
|
|
449
|
+
!!N && /* @__PURE__ */ o("div", { className: k.discountWrapper, children: !D && N && B && v && K && /* @__PURE__ */ F("div", { className: oe(k.discountPrice), children: [
|
|
450
|
+
/* @__PURE__ */ o("span", { children: x && Re(v ?? B, !1, A) }),
|
|
451
|
+
x && /* @__PURE__ */ o(
|
|
452
|
+
De,
|
|
453
|
+
{
|
|
454
|
+
additionalClass: oe(k.discountTag),
|
|
455
|
+
variant: "gold",
|
|
456
|
+
size: "tiny",
|
|
457
|
+
children: "-" + Number(N) + "%"
|
|
458
|
+
}
|
|
459
|
+
)
|
|
460
|
+
] }) }),
|
|
461
|
+
!D && K && /* @__PURE__ */ o(
|
|
462
|
+
"div",
|
|
463
|
+
{
|
|
464
|
+
className: k.price,
|
|
465
|
+
children: x ? Re(B, !1, A) : "Цена по запросу"
|
|
466
|
+
}
|
|
467
|
+
),
|
|
468
|
+
D && K && /* @__PURE__ */ o("div", { className: k.price, children: "Цена по запросу" })
|
|
469
|
+
] }),
|
|
470
|
+
!D && /* @__PURE__ */ o("div", { className: k.paymentClass, children: M || I })
|
|
471
|
+
] }),
|
|
472
|
+
g && !Y && /* @__PURE__ */ o("div", { className: oe(k.lotPricePerMetr, k.projectLotPricePerMetr), children: Re(g, !0, A) })
|
|
473
|
+
] }),
|
|
474
|
+
/* @__PURE__ */ F("div", { className: k.botWrapper, children: [
|
|
475
|
+
/* @__PURE__ */ o("div", { className: oe(k.lotPriceWrapper, k.infoWrapper, { [k.lotPriceWrapperRow]: !K }), children: /* @__PURE__ */ F("div", { className: oe(k.lotInfoWrapper), children: [
|
|
476
|
+
/* @__PURE__ */ F("div", { className: oe(k.lotPropertyListDesktop), children: [
|
|
477
|
+
_ && /* @__PURE__ */ o(De, { variant: "gray", fontWeight: "large", children: _ }),
|
|
478
|
+
!me && b && /* @__PURE__ */ o(De, { variant: "gray", children: b }),
|
|
479
|
+
j() && /* @__PURE__ */ o(De, { variant: "gray", children: j() })
|
|
480
|
+
] }),
|
|
481
|
+
/* @__PURE__ */ F("ul", { className: oe(k.lotPropertyListMobile), children: [
|
|
482
|
+
_ && /* @__PURE__ */ F("li", { className: oe(k.lotPropertyItem), children: [
|
|
483
|
+
/* @__PURE__ */ o("div", { children: "Площадь" }),
|
|
484
|
+
/* @__PURE__ */ o("div", { children: _ })
|
|
485
|
+
] }),
|
|
486
|
+
!me && b && /* @__PURE__ */ F("li", { className: oe(k.lotPropertyItem), children: [
|
|
487
|
+
/* @__PURE__ */ o("div", { children: b?.split(" ")[0] }),
|
|
488
|
+
/* @__PURE__ */ o("div", { children: b?.split(" ")[1] })
|
|
489
|
+
] }),
|
|
490
|
+
/* @__PURE__ */ o(U, {}),
|
|
491
|
+
!D && O && /* @__PURE__ */ F("li", { className: oe(k.lotPropertyItem), children: [
|
|
492
|
+
/* @__PURE__ */ o("div", { children: O }),
|
|
493
|
+
/* @__PURE__ */ o("div", { children: L })
|
|
494
|
+
] })
|
|
495
|
+
] })
|
|
496
|
+
] }) }),
|
|
497
|
+
(ae && !Y || !K) && /* @__PURE__ */ F("div", { style: { display: "flex", alignItems: "flex-start", flexDirection: "column", gap: "8px" }, children: [
|
|
498
|
+
/* @__PURE__ */ F("div", { className: k.priceWrap, children: [
|
|
499
|
+
/* @__PURE__ */ o("div", { className: k.discountWrapper, children: !D && N && B && v && /* @__PURE__ */ F("div", { className: oe(k.discountPrice), children: [
|
|
500
|
+
x && /* @__PURE__ */ o("span", { children: Re(v ?? B, !1, A) }),
|
|
501
|
+
x && /* @__PURE__ */ o(
|
|
502
|
+
De,
|
|
503
|
+
{
|
|
504
|
+
additionalClass: oe(k.discountTag),
|
|
505
|
+
variant: "gold",
|
|
506
|
+
size: "tiny",
|
|
507
|
+
children: "-" + Number(N) + "%"
|
|
508
|
+
}
|
|
509
|
+
)
|
|
510
|
+
] }) }),
|
|
511
|
+
!D && /* @__PURE__ */ o(
|
|
512
|
+
"div",
|
|
513
|
+
{
|
|
514
|
+
className: k.price,
|
|
515
|
+
children: x ? Re(B, !1, A) : "Цена по запросу"
|
|
516
|
+
}
|
|
517
|
+
),
|
|
518
|
+
D && /* @__PURE__ */ o("div", { className: k.price, children: "Цена по запросу" })
|
|
519
|
+
] }),
|
|
520
|
+
/* @__PURE__ */ o("div", { className: k.paymentClass, children: M })
|
|
521
|
+
] }),
|
|
522
|
+
/* @__PURE__ */ o(we, {})
|
|
523
|
+
] })
|
|
524
|
+
] });
|
|
525
|
+
return /* @__PURE__ */ F(
|
|
526
|
+
"div",
|
|
527
|
+
{
|
|
528
|
+
className: oe(k.root, l, {
|
|
529
|
+
[k.rootDisable]: Y,
|
|
530
|
+
[k.rootRow]: K,
|
|
531
|
+
[k.rowTablet]: !K
|
|
532
|
+
}),
|
|
533
|
+
"data-testid": "lot_card",
|
|
534
|
+
children: [
|
|
535
|
+
/* @__PURE__ */ o(Fe, {}),
|
|
536
|
+
!K && /* @__PURE__ */ o("div", { className: oe(k.title), children: /* @__PURE__ */ o(le, {}) }),
|
|
537
|
+
/* @__PURE__ */ o(Ne, {})
|
|
538
|
+
]
|
|
539
|
+
}
|
|
540
|
+
);
|
|
541
|
+
}, Ze = Ie.bind(ce), As = ({
|
|
542
|
+
options: e,
|
|
543
|
+
selectedOption: r,
|
|
544
|
+
placeholder: t = "",
|
|
545
|
+
error: i,
|
|
546
|
+
disabled: l,
|
|
547
|
+
additionalClass: n = "",
|
|
548
|
+
onChange: d,
|
|
549
|
+
onBlur: u,
|
|
550
|
+
mini: W,
|
|
551
|
+
openOnTop: T = !1,
|
|
552
|
+
onClickItem: p,
|
|
553
|
+
onCLickSelect: b,
|
|
554
|
+
onOpenClick: g
|
|
555
|
+
}) => {
|
|
556
|
+
const [V, A] = Te(!1), w = Mt(null), { isMobile: N } = _e(), { handleBlur: B, getInputValue: v, getOption: x, handleDocumentClick: P } = dr({
|
|
557
|
+
selectedOption: r,
|
|
558
|
+
onClickOption: p,
|
|
559
|
+
setSelectedOption: d,
|
|
560
|
+
setIsOpen: A,
|
|
561
|
+
containerRef: w,
|
|
562
|
+
isMobile: N,
|
|
563
|
+
placeholder: t,
|
|
564
|
+
onChange: d,
|
|
565
|
+
onBlur: u
|
|
566
|
+
});
|
|
567
|
+
return Oe(() => (document.addEventListener("click", P), () => {
|
|
568
|
+
document.removeEventListener("click", P);
|
|
569
|
+
}), []), /* @__PURE__ */ F(
|
|
570
|
+
"div",
|
|
571
|
+
{
|
|
572
|
+
ref: w,
|
|
573
|
+
className: Ze(
|
|
574
|
+
ce.sortSelectWrapper,
|
|
575
|
+
{ [ce.sortSelectWrapperError]: i },
|
|
576
|
+
{ [ce.sortSelectWrapperTop]: T },
|
|
577
|
+
n
|
|
578
|
+
),
|
|
579
|
+
tabIndex: 0,
|
|
580
|
+
onBlur: B,
|
|
581
|
+
onClick: () => {
|
|
582
|
+
b && b();
|
|
583
|
+
},
|
|
584
|
+
children: [
|
|
585
|
+
/* @__PURE__ */ F("div", { className: Ze(ce.inputWrapper), children: [
|
|
586
|
+
/* @__PURE__ */ o(
|
|
587
|
+
"input",
|
|
588
|
+
{
|
|
589
|
+
type: "text",
|
|
590
|
+
readOnly: !0,
|
|
591
|
+
value: v(),
|
|
592
|
+
className: Ze(
|
|
593
|
+
ce.selectedOptions,
|
|
594
|
+
{ [ce.selectOptionsDisabled]: l },
|
|
595
|
+
{ [ce.selectionOptionMini]: W }
|
|
596
|
+
),
|
|
597
|
+
onClick: () => {
|
|
598
|
+
V || g && g(), A(!V);
|
|
599
|
+
}
|
|
600
|
+
}
|
|
601
|
+
),
|
|
602
|
+
/* @__PURE__ */ o(
|
|
603
|
+
Se,
|
|
604
|
+
{
|
|
605
|
+
name: "twoArrows",
|
|
606
|
+
size: "24",
|
|
607
|
+
additionalClass: ce.icon
|
|
608
|
+
}
|
|
609
|
+
)
|
|
610
|
+
] }),
|
|
611
|
+
V && N && /* @__PURE__ */ F(
|
|
612
|
+
ot,
|
|
613
|
+
{
|
|
614
|
+
isOpen: V,
|
|
615
|
+
emitIsOpen: A,
|
|
616
|
+
additionalClassModalBody: ce.modalAddBody,
|
|
617
|
+
additionalClass: ce.selectModal,
|
|
618
|
+
createPortalObj: { domNode: document.querySelector("body") },
|
|
619
|
+
isTransparentBack: !0,
|
|
620
|
+
children: [
|
|
621
|
+
/* @__PURE__ */ F("div", { className: ce.mobileSortHeader, children: [
|
|
622
|
+
/* @__PURE__ */ o(ct, { children: "Сортировка" }),
|
|
623
|
+
/* @__PURE__ */ o("div", { onClick: () => A(!1), children: /* @__PURE__ */ o(
|
|
624
|
+
Se,
|
|
625
|
+
{
|
|
626
|
+
name: "close",
|
|
627
|
+
size: "20"
|
|
628
|
+
}
|
|
629
|
+
) })
|
|
630
|
+
] }),
|
|
631
|
+
/* @__PURE__ */ o("div", { className: ce.mobileOptionList, children: e?.map((S) => x(S)) })
|
|
632
|
+
]
|
|
633
|
+
}
|
|
634
|
+
),
|
|
635
|
+
V && !N && /* @__PURE__ */ o("div", { className: Ze(ce.optionsList, { [ce.optionListOnTop]: T }), children: e?.map((S) => x(S)) })
|
|
636
|
+
]
|
|
637
|
+
}
|
|
638
|
+
);
|
|
639
|
+
};
|
|
640
|
+
As.displayName = "SortSelect";
|
|
641
|
+
const Ps = "_btn_ky28a_1", Is = "_modal_ky28a_9", Ls = "_modalBody_ky28a_16", Ws = "_root_ky28a_21", Vs = "_title_ky28a_34", Bs = "_description_ky28a_41", Os = "_inputWrapper_ky28a_48", _s = "_linkPolicy_ky28a_55", Es = "_telegramLink_ky28a_60", Ds = "_telegramWrapper_ky28a_65", Rs = "_telegram_ky28a_60", Ms = "_orText_ky28a_88", js = "_checkboxText_ky28a_116", re = {
|
|
642
|
+
btn: Ps,
|
|
643
|
+
modal: Is,
|
|
644
|
+
modalBody: Ls,
|
|
645
|
+
root: Ws,
|
|
646
|
+
title: Vs,
|
|
647
|
+
description: Bs,
|
|
648
|
+
inputWrapper: Os,
|
|
649
|
+
linkPolicy: _s,
|
|
650
|
+
telegramLink: Es,
|
|
651
|
+
telegramWrapper: Ds,
|
|
652
|
+
telegram: Rs,
|
|
653
|
+
orText: Ms,
|
|
654
|
+
checkboxText: js
|
|
655
|
+
};
|
|
656
|
+
var ze = (e) => e.type === "checkbox", Pe = (e) => e instanceof Date, fe = (e) => e == null;
|
|
657
|
+
const Xt = (e) => typeof e == "object";
|
|
658
|
+
var ie = (e) => !fe(e) && !Array.isArray(e) && Xt(e) && !Pe(e), Ut = (e) => ie(e) && e.target ? ze(e.target) ? e.target.checked : e.target.value : e, qs = (e) => e.substring(0, e.search(/\.\d+(\.|$)/)) || e, Zt = (e, r) => e.has(qs(r)), zs = (e) => {
|
|
659
|
+
const r = e.constructor && e.constructor.prototype;
|
|
660
|
+
return ie(r) && r.hasOwnProperty("isPrototypeOf");
|
|
661
|
+
}, dt = typeof window < "u" && typeof window.HTMLElement < "u" && typeof document < "u";
|
|
662
|
+
function ne(e) {
|
|
663
|
+
let r;
|
|
664
|
+
const t = Array.isArray(e), i = typeof FileList < "u" ? e instanceof FileList : !1;
|
|
665
|
+
if (e instanceof Date)
|
|
666
|
+
r = new Date(e);
|
|
667
|
+
else if (!(dt && (e instanceof Blob || i)) && (t || ie(e)))
|
|
668
|
+
if (r = t ? [] : Object.create(Object.getPrototypeOf(e)), !t && !zs(e))
|
|
669
|
+
r = e;
|
|
670
|
+
else
|
|
671
|
+
for (const l in e)
|
|
672
|
+
e.hasOwnProperty(l) && (r[l] = ne(e[l]));
|
|
673
|
+
else
|
|
674
|
+
return e;
|
|
675
|
+
return r;
|
|
676
|
+
}
|
|
677
|
+
var Ke = (e) => /^\w*$/.test(e), $ = (e) => e === void 0, ut = (e) => Array.isArray(e) ? e.filter(Boolean) : [], ft = (e) => ut(e.replace(/["|']|\]/g, "").split(/\.|\[/)), h = (e, r, t) => {
|
|
678
|
+
if (!r || !ie(e))
|
|
679
|
+
return t;
|
|
680
|
+
const i = (Ke(r) ? [r] : ft(r)).reduce((l, n) => fe(l) ? l : l[n], e);
|
|
681
|
+
return $(i) || i === e ? $(e[r]) ? t : e[r] : i;
|
|
682
|
+
}, pe = (e) => typeof e == "boolean", J = (e, r, t) => {
|
|
683
|
+
let i = -1;
|
|
684
|
+
const l = Ke(r) ? [r] : ft(r), n = l.length, d = n - 1;
|
|
685
|
+
for (; ++i < n; ) {
|
|
686
|
+
const u = l[i];
|
|
687
|
+
let W = t;
|
|
688
|
+
if (i !== d) {
|
|
689
|
+
const T = e[u];
|
|
690
|
+
W = ie(T) || Array.isArray(T) ? T : isNaN(+l[i + 1]) ? {} : [];
|
|
691
|
+
}
|
|
692
|
+
if (u === "__proto__" || u === "constructor" || u === "prototype")
|
|
693
|
+
return;
|
|
694
|
+
e[u] = W, e = e[u];
|
|
695
|
+
}
|
|
696
|
+
};
|
|
697
|
+
const He = {
|
|
698
|
+
BLUR: "blur",
|
|
699
|
+
FOCUS_OUT: "focusout",
|
|
700
|
+
CHANGE: "change"
|
|
701
|
+
}, ve = {
|
|
702
|
+
onBlur: "onBlur",
|
|
703
|
+
onChange: "onChange",
|
|
704
|
+
onSubmit: "onSubmit",
|
|
705
|
+
onTouched: "onTouched",
|
|
706
|
+
all: "all"
|
|
707
|
+
}, Ce = {
|
|
708
|
+
max: "max",
|
|
709
|
+
min: "min",
|
|
710
|
+
maxLength: "maxLength",
|
|
711
|
+
minLength: "minLength",
|
|
712
|
+
pattern: "pattern",
|
|
713
|
+
required: "required",
|
|
714
|
+
validate: "validate"
|
|
715
|
+
}, Gt = E.createContext(null);
|
|
716
|
+
Gt.displayName = "HookFormContext";
|
|
717
|
+
const mt = () => E.useContext(Gt);
|
|
718
|
+
var Ht = (e, r, t, i = !0) => {
|
|
719
|
+
const l = {
|
|
720
|
+
defaultValues: r._defaultValues
|
|
721
|
+
};
|
|
722
|
+
for (const n in e)
|
|
723
|
+
Object.defineProperty(l, n, {
|
|
724
|
+
get: () => {
|
|
725
|
+
const d = n;
|
|
726
|
+
return r._proxyFormState[d] !== ve.all && (r._proxyFormState[d] = !i || ve.all), t && (t[d] = !0), e[d];
|
|
727
|
+
}
|
|
728
|
+
});
|
|
729
|
+
return l;
|
|
730
|
+
};
|
|
731
|
+
const pt = typeof window < "u" ? E.useLayoutEffect : E.useEffect;
|
|
732
|
+
function Xs(e) {
|
|
733
|
+
const r = mt(), { control: t = r.control, disabled: i, name: l, exact: n } = e || {}, [d, u] = E.useState(t._formState), W = E.useRef({
|
|
734
|
+
isDirty: !1,
|
|
735
|
+
isLoading: !1,
|
|
736
|
+
dirtyFields: !1,
|
|
737
|
+
touchedFields: !1,
|
|
738
|
+
validatingFields: !1,
|
|
739
|
+
isValidating: !1,
|
|
740
|
+
isValid: !1,
|
|
741
|
+
errors: !1
|
|
742
|
+
});
|
|
743
|
+
return pt(() => t._subscribe({
|
|
744
|
+
name: l,
|
|
745
|
+
formState: W.current,
|
|
746
|
+
exact: n,
|
|
747
|
+
callback: (T) => {
|
|
748
|
+
!i && u({
|
|
749
|
+
...t._formState,
|
|
750
|
+
...T
|
|
751
|
+
});
|
|
752
|
+
}
|
|
753
|
+
}), [l, i, n]), E.useEffect(() => {
|
|
754
|
+
W.current.isValid && t._setValid(!0);
|
|
755
|
+
}, [t]), E.useMemo(() => Ht(d, t, W.current, !1), [d, t]);
|
|
756
|
+
}
|
|
757
|
+
var he = (e) => typeof e == "string", nt = (e, r, t, i, l) => he(e) ? (i && r.watch.add(e), h(t, e, l)) : Array.isArray(e) ? e.map((n) => (i && r.watch.add(n), h(t, n))) : (i && (r.watchAll = !0), t), at = (e) => fe(e) || !Xt(e);
|
|
758
|
+
function be(e, r, t = /* @__PURE__ */ new WeakSet()) {
|
|
759
|
+
if (at(e) || at(r))
|
|
760
|
+
return e === r;
|
|
761
|
+
if (Pe(e) && Pe(r))
|
|
762
|
+
return e.getTime() === r.getTime();
|
|
763
|
+
const i = Object.keys(e), l = Object.keys(r);
|
|
764
|
+
if (i.length !== l.length)
|
|
765
|
+
return !1;
|
|
766
|
+
if (t.has(e) || t.has(r))
|
|
767
|
+
return !0;
|
|
768
|
+
t.add(e), t.add(r);
|
|
769
|
+
for (const n of i) {
|
|
770
|
+
const d = e[n];
|
|
771
|
+
if (!l.includes(n))
|
|
772
|
+
return !1;
|
|
773
|
+
if (n !== "ref") {
|
|
774
|
+
const u = r[n];
|
|
775
|
+
if (Pe(d) && Pe(u) || ie(d) && ie(u) || Array.isArray(d) && Array.isArray(u) ? !be(d, u, t) : d !== u)
|
|
776
|
+
return !1;
|
|
777
|
+
}
|
|
778
|
+
}
|
|
779
|
+
return !0;
|
|
780
|
+
}
|
|
781
|
+
function Us(e) {
|
|
782
|
+
const r = mt(), { control: t = r.control, name: i, defaultValue: l, disabled: n, exact: d, compute: u } = e || {}, W = E.useRef(l), T = E.useRef(u), p = E.useRef(void 0), b = E.useRef(t), g = E.useRef(i);
|
|
783
|
+
T.current = u;
|
|
784
|
+
const [V, A] = E.useState(() => {
|
|
785
|
+
const P = t._getWatch(i, W.current);
|
|
786
|
+
return T.current ? T.current(P) : P;
|
|
787
|
+
}), w = E.useCallback((P) => {
|
|
788
|
+
const S = nt(i, t._names, P || t._formValues, !1, W.current);
|
|
789
|
+
return T.current ? T.current(S) : S;
|
|
790
|
+
}, [t._formValues, t._names, i]), N = E.useCallback((P) => {
|
|
791
|
+
if (!n) {
|
|
792
|
+
const S = nt(i, t._names, P || t._formValues, !1, W.current);
|
|
793
|
+
if (T.current) {
|
|
794
|
+
const D = T.current(S);
|
|
795
|
+
be(D, p.current) || (A(D), p.current = D);
|
|
796
|
+
} else
|
|
797
|
+
A(S);
|
|
798
|
+
}
|
|
799
|
+
}, [t._formValues, t._names, n, i]);
|
|
800
|
+
pt(() => ((b.current !== t || !be(g.current, i)) && (b.current = t, g.current = i, N()), t._subscribe({
|
|
801
|
+
name: i,
|
|
802
|
+
formState: {
|
|
803
|
+
values: !0
|
|
804
|
+
},
|
|
805
|
+
exact: d,
|
|
806
|
+
callback: (P) => {
|
|
807
|
+
N(P.values);
|
|
808
|
+
}
|
|
809
|
+
})), [t, d, i, N]), E.useEffect(() => t._removeUnmounted());
|
|
810
|
+
const B = b.current !== t, v = g.current, x = E.useMemo(() => {
|
|
811
|
+
if (n)
|
|
812
|
+
return null;
|
|
813
|
+
const P = !B && !be(v, i);
|
|
814
|
+
return B || P ? w() : null;
|
|
815
|
+
}, [n, B, i, v, w]);
|
|
816
|
+
return x !== null ? x : V;
|
|
817
|
+
}
|
|
818
|
+
function Zs(e) {
|
|
819
|
+
const r = mt(), { name: t, disabled: i, control: l = r.control, shouldUnregister: n, defaultValue: d } = e, u = Zt(l._names.array, t), W = E.useMemo(() => h(l._formValues, t, h(l._defaultValues, t, d)), [l, t, d]), T = Us({
|
|
820
|
+
control: l,
|
|
821
|
+
name: t,
|
|
822
|
+
defaultValue: W,
|
|
823
|
+
exact: !0
|
|
824
|
+
}), p = Xs({
|
|
825
|
+
control: l,
|
|
826
|
+
name: t,
|
|
827
|
+
exact: !0
|
|
828
|
+
}), b = E.useRef(e), g = E.useRef(void 0), V = E.useRef(l.register(t, {
|
|
829
|
+
...e.rules,
|
|
830
|
+
value: T,
|
|
831
|
+
...pe(e.disabled) ? { disabled: e.disabled } : {}
|
|
832
|
+
}));
|
|
833
|
+
b.current = e;
|
|
834
|
+
const A = E.useMemo(() => Object.defineProperties({}, {
|
|
835
|
+
invalid: {
|
|
836
|
+
enumerable: !0,
|
|
837
|
+
get: () => !!h(p.errors, t)
|
|
838
|
+
},
|
|
839
|
+
isDirty: {
|
|
840
|
+
enumerable: !0,
|
|
841
|
+
get: () => !!h(p.dirtyFields, t)
|
|
842
|
+
},
|
|
843
|
+
isTouched: {
|
|
844
|
+
enumerable: !0,
|
|
845
|
+
get: () => !!h(p.touchedFields, t)
|
|
846
|
+
},
|
|
847
|
+
isValidating: {
|
|
848
|
+
enumerable: !0,
|
|
849
|
+
get: () => !!h(p.validatingFields, t)
|
|
850
|
+
},
|
|
851
|
+
error: {
|
|
852
|
+
enumerable: !0,
|
|
853
|
+
get: () => h(p.errors, t)
|
|
854
|
+
}
|
|
855
|
+
}), [p, t]), w = E.useCallback((x) => V.current.onChange({
|
|
856
|
+
target: {
|
|
857
|
+
value: Ut(x),
|
|
858
|
+
name: t
|
|
859
|
+
},
|
|
860
|
+
type: He.CHANGE
|
|
861
|
+
}), [t]), N = E.useCallback(() => V.current.onBlur({
|
|
862
|
+
target: {
|
|
863
|
+
value: h(l._formValues, t),
|
|
864
|
+
name: t
|
|
865
|
+
},
|
|
866
|
+
type: He.BLUR
|
|
867
|
+
}), [t, l._formValues]), B = E.useCallback((x) => {
|
|
868
|
+
const P = h(l._fields, t);
|
|
869
|
+
P && x && (P._f.ref = {
|
|
870
|
+
focus: () => x.focus && x.focus(),
|
|
871
|
+
select: () => x.select && x.select(),
|
|
872
|
+
setCustomValidity: (S) => x.setCustomValidity(S),
|
|
873
|
+
reportValidity: () => x.reportValidity()
|
|
874
|
+
});
|
|
875
|
+
}, [l._fields, t]), v = E.useMemo(() => ({
|
|
876
|
+
name: t,
|
|
877
|
+
value: T,
|
|
878
|
+
...pe(i) || p.disabled ? { disabled: p.disabled || i } : {},
|
|
879
|
+
onChange: w,
|
|
880
|
+
onBlur: N,
|
|
881
|
+
ref: B
|
|
882
|
+
}), [t, i, p.disabled, w, N, B, T]);
|
|
883
|
+
return E.useEffect(() => {
|
|
884
|
+
const x = l._options.shouldUnregister || n, P = g.current;
|
|
885
|
+
P && P !== t && !u && l.unregister(P), l.register(t, {
|
|
886
|
+
...b.current.rules,
|
|
887
|
+
...pe(b.current.disabled) ? { disabled: b.current.disabled } : {}
|
|
888
|
+
});
|
|
889
|
+
const S = (D, G) => {
|
|
890
|
+
const q = h(l._fields, D);
|
|
891
|
+
q && q._f && (q._f.mount = G);
|
|
892
|
+
};
|
|
893
|
+
if (S(t, !0), x) {
|
|
894
|
+
const D = ne(h(l._options.defaultValues, t, b.current.defaultValue));
|
|
895
|
+
J(l._defaultValues, t, D), $(h(l._formValues, t)) && J(l._formValues, t, D);
|
|
896
|
+
}
|
|
897
|
+
return !u && l.register(t), g.current = t, () => {
|
|
898
|
+
(u ? x && !l._state.action : x) ? l.unregister(t) : S(t, !1);
|
|
899
|
+
};
|
|
900
|
+
}, [t, l, u, n]), E.useEffect(() => {
|
|
901
|
+
l._setDisabledField({
|
|
902
|
+
disabled: i,
|
|
903
|
+
name: t
|
|
904
|
+
});
|
|
905
|
+
}, [i, t, l]), E.useMemo(() => ({
|
|
906
|
+
field: v,
|
|
907
|
+
formState: p,
|
|
908
|
+
fieldState: A
|
|
909
|
+
}), [v, p, A]);
|
|
910
|
+
}
|
|
911
|
+
const Gs = (e) => e.render(Zs(e));
|
|
912
|
+
var Hs = (e, r, t, i, l) => r ? {
|
|
913
|
+
...t[e],
|
|
914
|
+
types: {
|
|
915
|
+
...t[e] && t[e].types ? t[e].types : {},
|
|
916
|
+
[i]: l || !0
|
|
917
|
+
}
|
|
918
|
+
} : {}, je = (e) => Array.isArray(e) ? e : [e], Tt = () => {
|
|
919
|
+
let e = [];
|
|
920
|
+
return {
|
|
921
|
+
get observers() {
|
|
922
|
+
return e;
|
|
923
|
+
},
|
|
924
|
+
next: (l) => {
|
|
925
|
+
for (const n of e)
|
|
926
|
+
n.next && n.next(l);
|
|
927
|
+
},
|
|
928
|
+
subscribe: (l) => (e.push(l), {
|
|
929
|
+
unsubscribe: () => {
|
|
930
|
+
e = e.filter((n) => n !== l);
|
|
931
|
+
}
|
|
932
|
+
}),
|
|
933
|
+
unsubscribe: () => {
|
|
934
|
+
e = [];
|
|
935
|
+
}
|
|
936
|
+
};
|
|
937
|
+
};
|
|
938
|
+
function Jt(e, r) {
|
|
939
|
+
const t = {};
|
|
940
|
+
for (const i in e)
|
|
941
|
+
if (e.hasOwnProperty(i)) {
|
|
942
|
+
const l = e[i], n = r[i];
|
|
943
|
+
if (l && ie(l) && n) {
|
|
944
|
+
const d = Jt(l, n);
|
|
945
|
+
ie(d) && (t[i] = d);
|
|
946
|
+
} else e[i] && (t[i] = n);
|
|
947
|
+
}
|
|
948
|
+
return t;
|
|
949
|
+
}
|
|
950
|
+
var ue = (e) => ie(e) && !Object.keys(e).length, ht = (e) => e.type === "file", xe = (e) => typeof e == "function", Je = (e) => {
|
|
951
|
+
if (!dt)
|
|
952
|
+
return !1;
|
|
953
|
+
const r = e ? e.ownerDocument : 0;
|
|
954
|
+
return e instanceof (r && r.defaultView ? r.defaultView.HTMLElement : HTMLElement);
|
|
955
|
+
}, Yt = (e) => e.type === "select-multiple", yt = (e) => e.type === "radio", Js = (e) => yt(e) || ze(e), rt = (e) => Je(e) && e.isConnected;
|
|
956
|
+
function Ys(e, r) {
|
|
957
|
+
const t = r.slice(0, -1).length;
|
|
958
|
+
let i = 0;
|
|
959
|
+
for (; i < t; )
|
|
960
|
+
e = $(e) ? i++ : e[r[i++]];
|
|
961
|
+
return e;
|
|
962
|
+
}
|
|
963
|
+
function Ks(e) {
|
|
964
|
+
for (const r in e)
|
|
965
|
+
if (e.hasOwnProperty(r) && !$(e[r]))
|
|
966
|
+
return !1;
|
|
967
|
+
return !0;
|
|
968
|
+
}
|
|
969
|
+
function se(e, r) {
|
|
970
|
+
const t = Array.isArray(r) ? r : Ke(r) ? [r] : ft(r), i = t.length === 1 ? e : Ys(e, t), l = t.length - 1, n = t[l];
|
|
971
|
+
return i && delete i[n], l !== 0 && (ie(i) && ue(i) || Array.isArray(i) && Ks(i)) && se(e, t.slice(0, -1)), e;
|
|
972
|
+
}
|
|
973
|
+
var Qs = (e) => {
|
|
974
|
+
for (const r in e)
|
|
975
|
+
if (xe(e[r]))
|
|
976
|
+
return !0;
|
|
977
|
+
return !1;
|
|
978
|
+
};
|
|
979
|
+
function Kt(e) {
|
|
980
|
+
return Array.isArray(e) || ie(e) && !Qs(e);
|
|
981
|
+
}
|
|
982
|
+
function lt(e, r = {}) {
|
|
983
|
+
for (const t in e)
|
|
984
|
+
Kt(e[t]) ? (r[t] = Array.isArray(e[t]) ? [] : {}, lt(e[t], r[t])) : $(e[t]) || (r[t] = !0);
|
|
985
|
+
return r;
|
|
986
|
+
}
|
|
987
|
+
function Be(e, r, t) {
|
|
988
|
+
t || (t = lt(r));
|
|
989
|
+
for (const i in e)
|
|
990
|
+
Kt(e[i]) ? $(r) || at(t[i]) ? t[i] = lt(e[i], Array.isArray(e[i]) ? [] : {}) : Be(e[i], fe(r) ? {} : r[i], t[i]) : t[i] = !be(e[i], r[i]);
|
|
991
|
+
return t;
|
|
992
|
+
}
|
|
993
|
+
const At = {
|
|
994
|
+
value: !1,
|
|
995
|
+
isValid: !1
|
|
996
|
+
}, Pt = { value: !0, isValid: !0 };
|
|
997
|
+
var Qt = (e) => {
|
|
998
|
+
if (Array.isArray(e)) {
|
|
999
|
+
if (e.length > 1) {
|
|
1000
|
+
const r = e.filter((t) => t && t.checked && !t.disabled).map((t) => t.value);
|
|
1001
|
+
return { value: r, isValid: !!r.length };
|
|
1002
|
+
}
|
|
1003
|
+
return e[0].checked && !e[0].disabled ? (
|
|
1004
|
+
// @ts-expect-error expected to work in the browser
|
|
1005
|
+
e[0].attributes && !$(e[0].attributes.value) ? $(e[0].value) || e[0].value === "" ? Pt : { value: e[0].value, isValid: !0 } : Pt
|
|
1006
|
+
) : At;
|
|
1007
|
+
}
|
|
1008
|
+
return At;
|
|
1009
|
+
}, $t = (e, { valueAsNumber: r, valueAsDate: t, setValueAs: i }) => $(e) ? e : r ? e === "" ? NaN : e && +e : t && he(e) ? new Date(e) : i ? i(e) : e;
|
|
1010
|
+
const It = {
|
|
1011
|
+
isValid: !1,
|
|
1012
|
+
value: null
|
|
1013
|
+
};
|
|
1014
|
+
var er = (e) => Array.isArray(e) ? e.reduce((r, t) => t && t.checked && !t.disabled ? {
|
|
1015
|
+
isValid: !0,
|
|
1016
|
+
value: t.value
|
|
1017
|
+
} : r, It) : It;
|
|
1018
|
+
function Lt(e) {
|
|
1019
|
+
const r = e.ref;
|
|
1020
|
+
return ht(r) ? r.files : yt(r) ? er(e.refs).value : Yt(r) ? [...r.selectedOptions].map(({ value: t }) => t) : ze(r) ? Qt(e.refs).value : $t($(r.value) ? e.ref.value : r.value, e);
|
|
1021
|
+
}
|
|
1022
|
+
var $s = (e, r, t, i) => {
|
|
1023
|
+
const l = {};
|
|
1024
|
+
for (const n of e) {
|
|
1025
|
+
const d = h(r, n);
|
|
1026
|
+
d && J(l, n, d._f);
|
|
1027
|
+
}
|
|
1028
|
+
return {
|
|
1029
|
+
criteriaMode: t,
|
|
1030
|
+
names: [...e],
|
|
1031
|
+
fields: l,
|
|
1032
|
+
shouldUseNativeValidation: i
|
|
1033
|
+
};
|
|
1034
|
+
}, Ye = (e) => e instanceof RegExp, Me = (e) => $(e) ? e : Ye(e) ? e.source : ie(e) ? Ye(e.value) ? e.value.source : e.value : e, Wt = (e) => ({
|
|
1035
|
+
isOnSubmit: !e || e === ve.onSubmit,
|
|
1036
|
+
isOnBlur: e === ve.onBlur,
|
|
1037
|
+
isOnChange: e === ve.onChange,
|
|
1038
|
+
isOnAll: e === ve.all,
|
|
1039
|
+
isOnTouch: e === ve.onTouched
|
|
1040
|
+
});
|
|
1041
|
+
const Vt = "AsyncFunction";
|
|
1042
|
+
var ei = (e) => !!e && !!e.validate && !!(xe(e.validate) && e.validate.constructor.name === Vt || ie(e.validate) && Object.values(e.validate).find((r) => r.constructor.name === Vt)), ti = (e) => e.mount && (e.required || e.min || e.max || e.maxLength || e.minLength || e.pattern || e.validate), Bt = (e, r, t) => !t && (r.watchAll || r.watch.has(e) || [...r.watch].some((i) => e.startsWith(i) && /^\.\w+/.test(e.slice(i.length))));
|
|
1043
|
+
const qe = (e, r, t, i) => {
|
|
1044
|
+
for (const l of t || Object.keys(e)) {
|
|
1045
|
+
const n = h(e, l);
|
|
1046
|
+
if (n) {
|
|
1047
|
+
const { _f: d, ...u } = n;
|
|
1048
|
+
if (d) {
|
|
1049
|
+
if (d.refs && d.refs[0] && r(d.refs[0], l) && !i)
|
|
1050
|
+
return !0;
|
|
1051
|
+
if (d.ref && r(d.ref, d.name) && !i)
|
|
1052
|
+
return !0;
|
|
1053
|
+
if (qe(u, r))
|
|
1054
|
+
break;
|
|
1055
|
+
} else if (ie(u) && qe(u, r))
|
|
1056
|
+
break;
|
|
1057
|
+
}
|
|
1058
|
+
}
|
|
1059
|
+
};
|
|
1060
|
+
function Ot(e, r, t) {
|
|
1061
|
+
const i = h(e, t);
|
|
1062
|
+
if (i || Ke(t))
|
|
1063
|
+
return {
|
|
1064
|
+
error: i,
|
|
1065
|
+
name: t
|
|
1066
|
+
};
|
|
1067
|
+
const l = t.split(".");
|
|
1068
|
+
for (; l.length; ) {
|
|
1069
|
+
const n = l.join("."), d = h(r, n), u = h(e, n);
|
|
1070
|
+
if (d && !Array.isArray(d) && t !== n)
|
|
1071
|
+
return { name: t };
|
|
1072
|
+
if (u && u.type)
|
|
1073
|
+
return {
|
|
1074
|
+
name: n,
|
|
1075
|
+
error: u
|
|
1076
|
+
};
|
|
1077
|
+
if (u && u.root && u.root.type)
|
|
1078
|
+
return {
|
|
1079
|
+
name: `${n}.root`,
|
|
1080
|
+
error: u.root
|
|
1081
|
+
};
|
|
1082
|
+
l.pop();
|
|
1083
|
+
}
|
|
1084
|
+
return {
|
|
1085
|
+
name: t
|
|
1086
|
+
};
|
|
1087
|
+
}
|
|
1088
|
+
var ri = (e, r, t, i) => {
|
|
1089
|
+
t(e);
|
|
1090
|
+
const { name: l, ...n } = e;
|
|
1091
|
+
return ue(n) || Object.keys(n).length >= Object.keys(r).length || Object.keys(n).find((d) => r[d] === (!i || ve.all));
|
|
1092
|
+
}, si = (e, r, t) => !e || !r || e === r || je(e).some((i) => i && (t ? i === r : i.startsWith(r) || r.startsWith(i))), ii = (e, r, t, i, l) => l.isOnAll ? !1 : !t && l.isOnTouch ? !(r || e) : (t ? i.isOnBlur : l.isOnBlur) ? !e : (t ? i.isOnChange : l.isOnChange) ? e : !0, ni = (e, r) => !ut(h(e, r)).length && se(e, r), ai = (e, r, t) => {
|
|
1093
|
+
const i = je(h(e, t));
|
|
1094
|
+
return J(i, "root", r[t]), J(e, t, i), e;
|
|
1095
|
+
};
|
|
1096
|
+
function _t(e, r, t = "validate") {
|
|
1097
|
+
if (he(e) || Array.isArray(e) && e.every(he) || pe(e) && !e)
|
|
1098
|
+
return {
|
|
1099
|
+
type: t,
|
|
1100
|
+
message: he(e) ? e : "",
|
|
1101
|
+
ref: r
|
|
1102
|
+
};
|
|
1103
|
+
}
|
|
1104
|
+
var Ve = (e) => ie(e) && !Ye(e) ? e : {
|
|
1105
|
+
value: e,
|
|
1106
|
+
message: ""
|
|
1107
|
+
}, Et = async (e, r, t, i, l, n) => {
|
|
1108
|
+
const { ref: d, refs: u, required: W, maxLength: T, minLength: p, min: b, max: g, pattern: V, validate: A, name: w, valueAsNumber: N, mount: B } = e._f, v = h(t, w);
|
|
1109
|
+
if (!B || r.has(w))
|
|
1110
|
+
return {};
|
|
1111
|
+
const x = u ? u[0] : d, P = (I) => {
|
|
1112
|
+
l && x.reportValidity && (x.setCustomValidity(pe(I) ? "" : I || ""), x.reportValidity());
|
|
1113
|
+
}, S = {}, D = yt(d), G = ze(d), q = D || G, R = (N || ht(d)) && $(d.value) && $(v) || Je(d) && d.value === "" || v === "" || Array.isArray(v) && !v.length, te = Hs.bind(null, w, i, S), O = (I, L, M, j = Ce.maxLength, U = Ce.minLength) => {
|
|
1114
|
+
const _ = I ? L : M;
|
|
1115
|
+
S[w] = {
|
|
1116
|
+
type: I ? j : U,
|
|
1117
|
+
message: _,
|
|
1118
|
+
ref: d,
|
|
1119
|
+
...te(I ? j : U, _)
|
|
1120
|
+
};
|
|
1121
|
+
};
|
|
1122
|
+
if (n ? !Array.isArray(v) || !v.length : W && (!q && (R || fe(v)) || pe(v) && !v || G && !Qt(u).isValid || D && !er(u).isValid)) {
|
|
1123
|
+
const { value: I, message: L } = he(W) ? { value: !!W, message: W } : Ve(W);
|
|
1124
|
+
if (I && (S[w] = {
|
|
1125
|
+
type: Ce.required,
|
|
1126
|
+
message: L,
|
|
1127
|
+
ref: x,
|
|
1128
|
+
...te(Ce.required, L)
|
|
1129
|
+
}, !i))
|
|
1130
|
+
return P(L), S;
|
|
1131
|
+
}
|
|
1132
|
+
if (!R && (!fe(b) || !fe(g))) {
|
|
1133
|
+
let I, L;
|
|
1134
|
+
const M = Ve(g), j = Ve(b);
|
|
1135
|
+
if (!fe(v) && !isNaN(v)) {
|
|
1136
|
+
const U = d.valueAsNumber || v && +v;
|
|
1137
|
+
fe(M.value) || (I = U > M.value), fe(j.value) || (L = U < j.value);
|
|
1138
|
+
} else {
|
|
1139
|
+
const U = d.valueAsDate || new Date(v), _ = (Q) => /* @__PURE__ */ new Date((/* @__PURE__ */ new Date()).toDateString() + " " + Q), Y = d.type == "time", K = d.type == "week";
|
|
1140
|
+
he(M.value) && v && (I = Y ? _(v) > _(M.value) : K ? v > M.value : U > new Date(M.value)), he(j.value) && v && (L = Y ? _(v) < _(j.value) : K ? v < j.value : U < new Date(j.value));
|
|
1141
|
+
}
|
|
1142
|
+
if ((I || L) && (O(!!I, M.message, j.message, Ce.max, Ce.min), !i))
|
|
1143
|
+
return P(S[w].message), S;
|
|
1144
|
+
}
|
|
1145
|
+
if ((T || p) && !R && (he(v) || n && Array.isArray(v))) {
|
|
1146
|
+
const I = Ve(T), L = Ve(p), M = !fe(I.value) && v.length > +I.value, j = !fe(L.value) && v.length < +L.value;
|
|
1147
|
+
if ((M || j) && (O(M, I.message, L.message), !i))
|
|
1148
|
+
return P(S[w].message), S;
|
|
1149
|
+
}
|
|
1150
|
+
if (V && !R && he(v)) {
|
|
1151
|
+
const { value: I, message: L } = Ve(V);
|
|
1152
|
+
if (Ye(I) && !v.match(I) && (S[w] = {
|
|
1153
|
+
type: Ce.pattern,
|
|
1154
|
+
message: L,
|
|
1155
|
+
ref: d,
|
|
1156
|
+
...te(Ce.pattern, L)
|
|
1157
|
+
}, !i))
|
|
1158
|
+
return P(L), S;
|
|
1159
|
+
}
|
|
1160
|
+
if (A) {
|
|
1161
|
+
if (xe(A)) {
|
|
1162
|
+
const I = await A(v, t), L = _t(I, x);
|
|
1163
|
+
if (L && (S[w] = {
|
|
1164
|
+
...L,
|
|
1165
|
+
...te(Ce.validate, L.message)
|
|
1166
|
+
}, !i))
|
|
1167
|
+
return P(L.message), S;
|
|
1168
|
+
} else if (ie(A)) {
|
|
1169
|
+
let I = {};
|
|
1170
|
+
for (const L in A) {
|
|
1171
|
+
if (!ue(I) && !i)
|
|
1172
|
+
break;
|
|
1173
|
+
const M = _t(await A[L](v, t), x, L);
|
|
1174
|
+
M && (I = {
|
|
1175
|
+
...M,
|
|
1176
|
+
...te(L, M.message)
|
|
1177
|
+
}, P(M.message), i && (S[w] = I));
|
|
1178
|
+
}
|
|
1179
|
+
if (!ue(I) && (S[w] = {
|
|
1180
|
+
ref: x,
|
|
1181
|
+
...I
|
|
1182
|
+
}, !i))
|
|
1183
|
+
return S;
|
|
1184
|
+
}
|
|
1185
|
+
}
|
|
1186
|
+
return P(!0), S;
|
|
1187
|
+
};
|
|
1188
|
+
const li = {
|
|
1189
|
+
mode: ve.onSubmit,
|
|
1190
|
+
reValidateMode: ve.onChange,
|
|
1191
|
+
shouldFocusError: !0
|
|
1192
|
+
};
|
|
1193
|
+
function oi(e = {}) {
|
|
1194
|
+
let r = {
|
|
1195
|
+
...li,
|
|
1196
|
+
...e
|
|
1197
|
+
}, t = {
|
|
1198
|
+
submitCount: 0,
|
|
1199
|
+
isDirty: !1,
|
|
1200
|
+
isReady: !1,
|
|
1201
|
+
isLoading: xe(r.defaultValues),
|
|
1202
|
+
isValidating: !1,
|
|
1203
|
+
isSubmitted: !1,
|
|
1204
|
+
isSubmitting: !1,
|
|
1205
|
+
isSubmitSuccessful: !1,
|
|
1206
|
+
isValid: !1,
|
|
1207
|
+
touchedFields: {},
|
|
1208
|
+
dirtyFields: {},
|
|
1209
|
+
validatingFields: {},
|
|
1210
|
+
errors: r.errors || {},
|
|
1211
|
+
disabled: r.disabled || !1
|
|
1212
|
+
}, i = {}, l = ie(r.defaultValues) || ie(r.values) ? ne(r.defaultValues || r.values) || {} : {}, n = r.shouldUnregister ? {} : ne(l), d = {
|
|
1213
|
+
action: !1,
|
|
1214
|
+
mount: !1,
|
|
1215
|
+
watch: !1
|
|
1216
|
+
}, u = {
|
|
1217
|
+
mount: /* @__PURE__ */ new Set(),
|
|
1218
|
+
disabled: /* @__PURE__ */ new Set(),
|
|
1219
|
+
unMount: /* @__PURE__ */ new Set(),
|
|
1220
|
+
array: /* @__PURE__ */ new Set(),
|
|
1221
|
+
watch: /* @__PURE__ */ new Set()
|
|
1222
|
+
}, W, T = 0;
|
|
1223
|
+
const p = {
|
|
1224
|
+
isDirty: !1,
|
|
1225
|
+
dirtyFields: !1,
|
|
1226
|
+
validatingFields: !1,
|
|
1227
|
+
touchedFields: !1,
|
|
1228
|
+
isValidating: !1,
|
|
1229
|
+
isValid: !1,
|
|
1230
|
+
errors: !1
|
|
1231
|
+
};
|
|
1232
|
+
let b = {
|
|
1233
|
+
...p
|
|
1234
|
+
};
|
|
1235
|
+
const g = {
|
|
1236
|
+
array: Tt(),
|
|
1237
|
+
state: Tt()
|
|
1238
|
+
}, V = r.criteriaMode === ve.all, A = (s) => (a) => {
|
|
1239
|
+
clearTimeout(T), T = setTimeout(s, a);
|
|
1240
|
+
}, w = async (s) => {
|
|
1241
|
+
if (!r.disabled && (p.isValid || b.isValid || s)) {
|
|
1242
|
+
const a = r.resolver ? ue((await G()).errors) : await R(i, !0);
|
|
1243
|
+
a !== t.isValid && g.state.next({
|
|
1244
|
+
isValid: a
|
|
1245
|
+
});
|
|
1246
|
+
}
|
|
1247
|
+
}, N = (s, a) => {
|
|
1248
|
+
!r.disabled && (p.isValidating || p.validatingFields || b.isValidating || b.validatingFields) && ((s || Array.from(u.mount)).forEach((c) => {
|
|
1249
|
+
c && (a ? J(t.validatingFields, c, a) : se(t.validatingFields, c));
|
|
1250
|
+
}), g.state.next({
|
|
1251
|
+
validatingFields: t.validatingFields,
|
|
1252
|
+
isValidating: !ue(t.validatingFields)
|
|
1253
|
+
}));
|
|
1254
|
+
}, B = (s, a = [], c, y, m = !0, f = !0) => {
|
|
1255
|
+
if (y && c && !r.disabled) {
|
|
1256
|
+
if (d.action = !0, f && Array.isArray(h(i, s))) {
|
|
1257
|
+
const C = c(h(i, s), y.argA, y.argB);
|
|
1258
|
+
m && J(i, s, C);
|
|
1259
|
+
}
|
|
1260
|
+
if (f && Array.isArray(h(t.errors, s))) {
|
|
1261
|
+
const C = c(h(t.errors, s), y.argA, y.argB);
|
|
1262
|
+
m && J(t.errors, s, C), ni(t.errors, s);
|
|
1263
|
+
}
|
|
1264
|
+
if ((p.touchedFields || b.touchedFields) && f && Array.isArray(h(t.touchedFields, s))) {
|
|
1265
|
+
const C = c(h(t.touchedFields, s), y.argA, y.argB);
|
|
1266
|
+
m && J(t.touchedFields, s, C);
|
|
1267
|
+
}
|
|
1268
|
+
(p.dirtyFields || b.dirtyFields) && (t.dirtyFields = Be(l, n)), g.state.next({
|
|
1269
|
+
name: s,
|
|
1270
|
+
isDirty: O(s, a),
|
|
1271
|
+
dirtyFields: t.dirtyFields,
|
|
1272
|
+
errors: t.errors,
|
|
1273
|
+
isValid: t.isValid
|
|
1274
|
+
});
|
|
1275
|
+
} else
|
|
1276
|
+
J(n, s, a);
|
|
1277
|
+
}, v = (s, a) => {
|
|
1278
|
+
J(t.errors, s, a), g.state.next({
|
|
1279
|
+
errors: t.errors
|
|
1280
|
+
});
|
|
1281
|
+
}, x = (s) => {
|
|
1282
|
+
t.errors = s, g.state.next({
|
|
1283
|
+
errors: t.errors,
|
|
1284
|
+
isValid: !1
|
|
1285
|
+
});
|
|
1286
|
+
}, P = (s, a, c, y) => {
|
|
1287
|
+
const m = h(i, s);
|
|
1288
|
+
if (m) {
|
|
1289
|
+
const f = h(n, s, $(c) ? h(l, s) : c);
|
|
1290
|
+
$(f) || y && y.defaultChecked || a ? J(n, s, a ? f : Lt(m._f)) : M(s, f), d.mount && w();
|
|
1291
|
+
}
|
|
1292
|
+
}, S = (s, a, c, y, m) => {
|
|
1293
|
+
let f = !1, C = !1;
|
|
1294
|
+
const Z = {
|
|
1295
|
+
name: s
|
|
1296
|
+
};
|
|
1297
|
+
if (!r.disabled) {
|
|
1298
|
+
if (!c || y) {
|
|
1299
|
+
(p.isDirty || b.isDirty) && (C = t.isDirty, t.isDirty = Z.isDirty = O(), f = C !== Z.isDirty);
|
|
1300
|
+
const H = be(h(l, s), a);
|
|
1301
|
+
C = !!h(t.dirtyFields, s), H ? se(t.dirtyFields, s) : J(t.dirtyFields, s, !0), Z.dirtyFields = t.dirtyFields, f = f || (p.dirtyFields || b.dirtyFields) && C !== !H;
|
|
1302
|
+
}
|
|
1303
|
+
if (c) {
|
|
1304
|
+
const H = h(t.touchedFields, s);
|
|
1305
|
+
H || (J(t.touchedFields, s, c), Z.touchedFields = t.touchedFields, f = f || (p.touchedFields || b.touchedFields) && H !== c);
|
|
1306
|
+
}
|
|
1307
|
+
f && m && g.state.next(Z);
|
|
1308
|
+
}
|
|
1309
|
+
return f ? Z : {};
|
|
1310
|
+
}, D = (s, a, c, y) => {
|
|
1311
|
+
const m = h(t.errors, s), f = (p.isValid || b.isValid) && pe(a) && t.isValid !== a;
|
|
1312
|
+
if (r.delayError && c ? (W = A(() => v(s, c)), W(r.delayError)) : (clearTimeout(T), W = null, c ? J(t.errors, s, c) : se(t.errors, s)), (c ? !be(m, c) : m) || !ue(y) || f) {
|
|
1313
|
+
const C = {
|
|
1314
|
+
...y,
|
|
1315
|
+
...f && pe(a) ? { isValid: a } : {},
|
|
1316
|
+
errors: t.errors,
|
|
1317
|
+
name: s
|
|
1318
|
+
};
|
|
1319
|
+
t = {
|
|
1320
|
+
...t,
|
|
1321
|
+
...C
|
|
1322
|
+
}, g.state.next(C);
|
|
1323
|
+
}
|
|
1324
|
+
}, G = async (s) => {
|
|
1325
|
+
N(s, !0);
|
|
1326
|
+
const a = await r.resolver(n, r.context, $s(s || u.mount, i, r.criteriaMode, r.shouldUseNativeValidation));
|
|
1327
|
+
return N(s), a;
|
|
1328
|
+
}, q = async (s) => {
|
|
1329
|
+
const { errors: a } = await G(s);
|
|
1330
|
+
if (s)
|
|
1331
|
+
for (const c of s) {
|
|
1332
|
+
const y = h(a, c);
|
|
1333
|
+
y ? J(t.errors, c, y) : se(t.errors, c);
|
|
1334
|
+
}
|
|
1335
|
+
else
|
|
1336
|
+
t.errors = a;
|
|
1337
|
+
return a;
|
|
1338
|
+
}, R = async (s, a, c = {
|
|
1339
|
+
valid: !0
|
|
1340
|
+
}) => {
|
|
1341
|
+
for (const y in s) {
|
|
1342
|
+
const m = s[y];
|
|
1343
|
+
if (m) {
|
|
1344
|
+
const { _f: f, ...C } = m;
|
|
1345
|
+
if (f) {
|
|
1346
|
+
const Z = u.array.has(f.name), H = m._f && ei(m._f);
|
|
1347
|
+
H && p.validatingFields && N([f.name], !0);
|
|
1348
|
+
const ye = await Et(m, u.disabled, n, V, r.shouldUseNativeValidation && !a, Z);
|
|
1349
|
+
if (H && p.validatingFields && N([f.name]), ye[f.name] && (c.valid = !1, a))
|
|
1350
|
+
break;
|
|
1351
|
+
!a && (h(ye, f.name) ? Z ? ai(t.errors, ye, f.name) : J(t.errors, f.name, ye[f.name]) : se(t.errors, f.name));
|
|
1352
|
+
}
|
|
1353
|
+
!ue(C) && await R(C, a, c);
|
|
1354
|
+
}
|
|
1355
|
+
}
|
|
1356
|
+
return c.valid;
|
|
1357
|
+
}, te = () => {
|
|
1358
|
+
for (const s of u.unMount) {
|
|
1359
|
+
const a = h(i, s);
|
|
1360
|
+
a && (a._f.refs ? a._f.refs.every((c) => !rt(c)) : !rt(a._f.ref)) && z(s);
|
|
1361
|
+
}
|
|
1362
|
+
u.unMount = /* @__PURE__ */ new Set();
|
|
1363
|
+
}, O = (s, a) => !r.disabled && (s && a && J(n, s, a), !be(Q(), l)), I = (s, a, c) => nt(s, u, {
|
|
1364
|
+
...d.mount ? n : $(a) ? l : he(s) ? { [s]: a } : a
|
|
1365
|
+
}, c, a), L = (s) => ut(h(d.mount ? n : l, s, r.shouldUnregister ? h(l, s, []) : [])), M = (s, a, c = {}) => {
|
|
1366
|
+
const y = h(i, s);
|
|
1367
|
+
let m = a;
|
|
1368
|
+
if (y) {
|
|
1369
|
+
const f = y._f;
|
|
1370
|
+
f && (!f.disabled && J(n, s, $t(a, f)), m = Je(f.ref) && fe(a) ? "" : a, Yt(f.ref) ? [...f.ref.options].forEach((C) => C.selected = m.includes(C.value)) : f.refs ? ze(f.ref) ? f.refs.forEach((C) => {
|
|
1371
|
+
(!C.defaultChecked || !C.disabled) && (Array.isArray(m) ? C.checked = !!m.find((Z) => Z === C.value) : C.checked = m === C.value || !!m);
|
|
1372
|
+
}) : f.refs.forEach((C) => C.checked = C.value === m) : ht(f.ref) ? f.ref.value = "" : (f.ref.value = m, f.ref.type || g.state.next({
|
|
1373
|
+
name: s,
|
|
1374
|
+
values: ne(n)
|
|
1375
|
+
})));
|
|
1376
|
+
}
|
|
1377
|
+
(c.shouldDirty || c.shouldTouch) && S(s, m, c.shouldTouch, c.shouldDirty, !0), c.shouldValidate && K(s);
|
|
1378
|
+
}, j = (s, a, c) => {
|
|
1379
|
+
for (const y in a) {
|
|
1380
|
+
if (!a.hasOwnProperty(y))
|
|
1381
|
+
return;
|
|
1382
|
+
const m = a[y], f = s + "." + y, C = h(i, f);
|
|
1383
|
+
(u.array.has(s) || ie(m) || C && !C._f) && !Pe(m) ? j(f, m, c) : M(f, m, c);
|
|
1384
|
+
}
|
|
1385
|
+
}, U = (s, a, c = {}) => {
|
|
1386
|
+
const y = h(i, s), m = u.array.has(s), f = ne(a);
|
|
1387
|
+
J(n, s, f), m ? (g.array.next({
|
|
1388
|
+
name: s,
|
|
1389
|
+
values: ne(n)
|
|
1390
|
+
}), (p.isDirty || p.dirtyFields || b.isDirty || b.dirtyFields) && c.shouldDirty && g.state.next({
|
|
1391
|
+
name: s,
|
|
1392
|
+
dirtyFields: Be(l, n),
|
|
1393
|
+
isDirty: O(s, f)
|
|
1394
|
+
})) : y && !y._f && !fe(f) ? j(s, f, c) : M(s, f, c), Bt(s, u) && g.state.next({ ...t, name: s }), g.state.next({
|
|
1395
|
+
name: d.mount ? s : void 0,
|
|
1396
|
+
values: ne(n)
|
|
1397
|
+
});
|
|
1398
|
+
}, _ = async (s) => {
|
|
1399
|
+
d.mount = !0;
|
|
1400
|
+
const a = s.target;
|
|
1401
|
+
let c = a.name, y = !0;
|
|
1402
|
+
const m = h(i, c), f = (H) => {
|
|
1403
|
+
y = Number.isNaN(H) || Pe(H) && isNaN(H.getTime()) || be(H, h(n, c, H));
|
|
1404
|
+
}, C = Wt(r.mode), Z = Wt(r.reValidateMode);
|
|
1405
|
+
if (m) {
|
|
1406
|
+
let H, ye;
|
|
1407
|
+
const Xe = a.type ? Lt(m._f) : Ut(s), ke = s.type === He.BLUR || s.type === He.FOCUS_OUT, nr = !ti(m._f) && !r.resolver && !h(t.errors, c) && !m._f.deps || ii(ke, h(t.touchedFields, c), t.isSubmitted, Z, C), $e = Bt(c, u, ke);
|
|
1408
|
+
J(n, c, Xe), ke ? (!a || !a.readOnly) && (m._f.onBlur && m._f.onBlur(s), W && W(0)) : m._f.onChange && m._f.onChange(s);
|
|
1409
|
+
const et = S(c, Xe, ke), ar = !ue(et) || $e;
|
|
1410
|
+
if (!ke && g.state.next({
|
|
1411
|
+
name: c,
|
|
1412
|
+
type: s.type,
|
|
1413
|
+
values: ne(n)
|
|
1414
|
+
}), nr)
|
|
1415
|
+
return (p.isValid || b.isValid) && (r.mode === "onBlur" ? ke && w() : ke || w()), ar && g.state.next({ name: c, ...$e ? {} : et });
|
|
1416
|
+
if (!ke && $e && g.state.next({ ...t }), r.resolver) {
|
|
1417
|
+
const { errors: St } = await G([c]);
|
|
1418
|
+
if (f(Xe), y) {
|
|
1419
|
+
const lr = Ot(t.errors, i, c), Ft = Ot(St, i, lr.name || c);
|
|
1420
|
+
H = Ft.error, c = Ft.name, ye = ue(St);
|
|
1421
|
+
}
|
|
1422
|
+
} else
|
|
1423
|
+
N([c], !0), H = (await Et(m, u.disabled, n, V, r.shouldUseNativeValidation))[c], N([c]), f(Xe), y && (H ? ye = !1 : (p.isValid || b.isValid) && (ye = await R(i, !0)));
|
|
1424
|
+
y && (m._f.deps && (!Array.isArray(m._f.deps) || m._f.deps.length > 0) && K(m._f.deps), D(c, ye, H, et));
|
|
1425
|
+
}
|
|
1426
|
+
}, Y = (s, a) => {
|
|
1427
|
+
if (h(t.errors, a) && s.focus)
|
|
1428
|
+
return s.focus(), 1;
|
|
1429
|
+
}, K = async (s, a = {}) => {
|
|
1430
|
+
let c, y;
|
|
1431
|
+
const m = je(s);
|
|
1432
|
+
if (r.resolver) {
|
|
1433
|
+
const f = await q($(s) ? s : m);
|
|
1434
|
+
c = ue(f), y = s ? !m.some((C) => h(f, C)) : c;
|
|
1435
|
+
} else s ? (y = (await Promise.all(m.map(async (f) => {
|
|
1436
|
+
const C = h(i, f);
|
|
1437
|
+
return await R(C && C._f ? { [f]: C } : C);
|
|
1438
|
+
}))).every(Boolean), !(!y && !t.isValid) && w()) : y = c = await R(i);
|
|
1439
|
+
return g.state.next({
|
|
1440
|
+
...!he(s) || (p.isValid || b.isValid) && c !== t.isValid ? {} : { name: s },
|
|
1441
|
+
...r.resolver || !s ? { isValid: c } : {},
|
|
1442
|
+
errors: t.errors
|
|
1443
|
+
}), a.shouldFocus && !y && qe(i, Y, s ? m : u.mount), y;
|
|
1444
|
+
}, Q = (s, a) => {
|
|
1445
|
+
let c = {
|
|
1446
|
+
...d.mount ? n : l
|
|
1447
|
+
};
|
|
1448
|
+
return a && (c = Jt(a.dirtyFields ? t.dirtyFields : t.touchedFields, c)), $(s) ? c : he(s) ? h(c, s) : s.map((y) => h(c, y));
|
|
1449
|
+
}, ae = (s, a) => ({
|
|
1450
|
+
invalid: !!h((a || t).errors, s),
|
|
1451
|
+
isDirty: !!h((a || t).dirtyFields, s),
|
|
1452
|
+
error: h((a || t).errors, s),
|
|
1453
|
+
isValidating: !!h(t.validatingFields, s),
|
|
1454
|
+
isTouched: !!h((a || t).touchedFields, s)
|
|
1455
|
+
}), me = (s) => {
|
|
1456
|
+
s && je(s).forEach((a) => se(t.errors, a)), g.state.next({
|
|
1457
|
+
errors: s ? t.errors : {}
|
|
1458
|
+
});
|
|
1459
|
+
}, le = (s, a, c) => {
|
|
1460
|
+
const y = (h(i, s, { _f: {} })._f || {}).ref, m = h(t.errors, s) || {}, { ref: f, message: C, type: Z, ...H } = m;
|
|
1461
|
+
J(t.errors, s, {
|
|
1462
|
+
...H,
|
|
1463
|
+
...a,
|
|
1464
|
+
ref: y
|
|
1465
|
+
}), g.state.next({
|
|
1466
|
+
name: s,
|
|
1467
|
+
errors: t.errors,
|
|
1468
|
+
isValid: !1
|
|
1469
|
+
}), c && c.shouldFocus && y && y.focus && y.focus();
|
|
1470
|
+
}, Fe = (s, a) => xe(s) ? g.state.subscribe({
|
|
1471
|
+
next: (c) => "values" in c && s(I(void 0, a), c)
|
|
1472
|
+
}) : I(s, a, !0), we = (s) => g.state.subscribe({
|
|
1473
|
+
next: (a) => {
|
|
1474
|
+
si(s.name, a.name, s.exact) && ri(a, s.formState || p, ir, s.reRenderRoot) && s.callback({
|
|
1475
|
+
values: { ...n },
|
|
1476
|
+
...t,
|
|
1477
|
+
...a,
|
|
1478
|
+
defaultValues: l
|
|
1479
|
+
});
|
|
1480
|
+
}
|
|
1481
|
+
}).unsubscribe, Ne = (s) => (d.mount = !0, b = {
|
|
1482
|
+
...b,
|
|
1483
|
+
...s.formState
|
|
1484
|
+
}, we({
|
|
1485
|
+
...s,
|
|
1486
|
+
formState: b
|
|
1487
|
+
})), z = (s, a = {}) => {
|
|
1488
|
+
for (const c of s ? je(s) : u.mount)
|
|
1489
|
+
u.mount.delete(c), u.array.delete(c), a.keepValue || (se(i, c), se(n, c)), !a.keepError && se(t.errors, c), !a.keepDirty && se(t.dirtyFields, c), !a.keepTouched && se(t.touchedFields, c), !a.keepIsValidating && se(t.validatingFields, c), !r.shouldUnregister && !a.keepDefaultValue && se(l, c);
|
|
1490
|
+
g.state.next({
|
|
1491
|
+
values: ne(n)
|
|
1492
|
+
}), g.state.next({
|
|
1493
|
+
...t,
|
|
1494
|
+
...a.keepDirty ? { isDirty: O() } : {}
|
|
1495
|
+
}), !a.keepIsValid && w();
|
|
1496
|
+
}, Le = ({ disabled: s, name: a }) => {
|
|
1497
|
+
(pe(s) && d.mount || s || u.disabled.has(a)) && (s ? u.disabled.add(a) : u.disabled.delete(a));
|
|
1498
|
+
}, Ee = (s, a = {}) => {
|
|
1499
|
+
let c = h(i, s);
|
|
1500
|
+
const y = pe(a.disabled) || pe(r.disabled);
|
|
1501
|
+
return J(i, s, {
|
|
1502
|
+
...c || {},
|
|
1503
|
+
_f: {
|
|
1504
|
+
...c && c._f ? c._f : { ref: { name: s } },
|
|
1505
|
+
name: s,
|
|
1506
|
+
mount: !0,
|
|
1507
|
+
...a
|
|
1508
|
+
}
|
|
1509
|
+
}), u.mount.add(s), c ? Le({
|
|
1510
|
+
disabled: pe(a.disabled) ? a.disabled : r.disabled,
|
|
1511
|
+
name: s
|
|
1512
|
+
}) : P(s, !0, a.value), {
|
|
1513
|
+
...y ? { disabled: a.disabled || r.disabled } : {},
|
|
1514
|
+
...r.progressive ? {
|
|
1515
|
+
required: !!a.required,
|
|
1516
|
+
min: Me(a.min),
|
|
1517
|
+
max: Me(a.max),
|
|
1518
|
+
minLength: Me(a.minLength),
|
|
1519
|
+
maxLength: Me(a.maxLength),
|
|
1520
|
+
pattern: Me(a.pattern)
|
|
1521
|
+
} : {},
|
|
1522
|
+
name: s,
|
|
1523
|
+
onChange: _,
|
|
1524
|
+
onBlur: _,
|
|
1525
|
+
ref: (m) => {
|
|
1526
|
+
if (m) {
|
|
1527
|
+
Ee(s, a), c = h(i, s);
|
|
1528
|
+
const f = $(m.value) && m.querySelectorAll && m.querySelectorAll("input,select,textarea")[0] || m, C = Js(f), Z = c._f.refs || [];
|
|
1529
|
+
if (C ? Z.find((H) => H === f) : f === c._f.ref)
|
|
1530
|
+
return;
|
|
1531
|
+
J(i, s, {
|
|
1532
|
+
_f: {
|
|
1533
|
+
...c._f,
|
|
1534
|
+
...C ? {
|
|
1535
|
+
refs: [
|
|
1536
|
+
...Z.filter(rt),
|
|
1537
|
+
f,
|
|
1538
|
+
...Array.isArray(h(l, s)) ? [{}] : []
|
|
1539
|
+
],
|
|
1540
|
+
ref: { type: f.type, name: s }
|
|
1541
|
+
} : { ref: f }
|
|
1542
|
+
}
|
|
1543
|
+
}), P(s, !1, void 0, f);
|
|
1544
|
+
} else
|
|
1545
|
+
c = h(i, s, {}), c._f && (c._f.mount = !1), (r.shouldUnregister || a.shouldUnregister) && !(Zt(u.array, s) && d.action) && u.unMount.add(s);
|
|
1546
|
+
}
|
|
1547
|
+
};
|
|
1548
|
+
}, Qe = () => r.shouldFocusError && qe(i, Y, u.mount), tr = (s) => {
|
|
1549
|
+
pe(s) && (g.state.next({ disabled: s }), qe(i, (a, c) => {
|
|
1550
|
+
const y = h(i, c);
|
|
1551
|
+
y && (a.disabled = y._f.disabled || s, Array.isArray(y._f.refs) && y._f.refs.forEach((m) => {
|
|
1552
|
+
m.disabled = y._f.disabled || s;
|
|
1553
|
+
}));
|
|
1554
|
+
}, 0, !1));
|
|
1555
|
+
}, gt = (s, a) => async (c) => {
|
|
1556
|
+
let y;
|
|
1557
|
+
c && (c.preventDefault && c.preventDefault(), c.persist && c.persist());
|
|
1558
|
+
let m = ne(n);
|
|
1559
|
+
if (g.state.next({
|
|
1560
|
+
isSubmitting: !0
|
|
1561
|
+
}), r.resolver) {
|
|
1562
|
+
const { errors: f, values: C } = await G();
|
|
1563
|
+
t.errors = f, m = ne(C);
|
|
1564
|
+
} else
|
|
1565
|
+
await R(i);
|
|
1566
|
+
if (u.disabled.size)
|
|
1567
|
+
for (const f of u.disabled)
|
|
1568
|
+
se(m, f);
|
|
1569
|
+
if (se(t.errors, "root"), ue(t.errors)) {
|
|
1570
|
+
g.state.next({
|
|
1571
|
+
errors: {}
|
|
1572
|
+
});
|
|
1573
|
+
try {
|
|
1574
|
+
await s(m, c);
|
|
1575
|
+
} catch (f) {
|
|
1576
|
+
y = f;
|
|
1577
|
+
}
|
|
1578
|
+
} else
|
|
1579
|
+
a && await a({ ...t.errors }, c), Qe(), setTimeout(Qe);
|
|
1580
|
+
if (g.state.next({
|
|
1581
|
+
isSubmitted: !0,
|
|
1582
|
+
isSubmitting: !1,
|
|
1583
|
+
isSubmitSuccessful: ue(t.errors) && !y,
|
|
1584
|
+
submitCount: t.submitCount + 1,
|
|
1585
|
+
errors: t.errors
|
|
1586
|
+
}), y)
|
|
1587
|
+
throw y;
|
|
1588
|
+
}, rr = (s, a = {}) => {
|
|
1589
|
+
h(i, s) && ($(a.defaultValue) ? U(s, ne(h(l, s))) : (U(s, a.defaultValue), J(l, s, ne(a.defaultValue))), a.keepTouched || se(t.touchedFields, s), a.keepDirty || (se(t.dirtyFields, s), t.isDirty = a.defaultValue ? O(s, ne(h(l, s))) : O()), a.keepError || (se(t.errors, s), p.isValid && w()), g.state.next({ ...t }));
|
|
1590
|
+
}, vt = (s, a = {}) => {
|
|
1591
|
+
const c = s ? ne(s) : l, y = ne(c), m = ue(s), f = m ? l : y;
|
|
1592
|
+
if (a.keepDefaultValues || (l = c), !a.keepValues) {
|
|
1593
|
+
if (a.keepDirtyValues) {
|
|
1594
|
+
const C = /* @__PURE__ */ new Set([
|
|
1595
|
+
...u.mount,
|
|
1596
|
+
...Object.keys(Be(l, n))
|
|
1597
|
+
]);
|
|
1598
|
+
for (const Z of Array.from(C))
|
|
1599
|
+
h(t.dirtyFields, Z) ? J(f, Z, h(n, Z)) : U(Z, h(f, Z));
|
|
1600
|
+
} else {
|
|
1601
|
+
if (dt && $(s))
|
|
1602
|
+
for (const C of u.mount) {
|
|
1603
|
+
const Z = h(i, C);
|
|
1604
|
+
if (Z && Z._f) {
|
|
1605
|
+
const H = Array.isArray(Z._f.refs) ? Z._f.refs[0] : Z._f.ref;
|
|
1606
|
+
if (Je(H)) {
|
|
1607
|
+
const ye = H.closest("form");
|
|
1608
|
+
if (ye) {
|
|
1609
|
+
ye.reset();
|
|
1610
|
+
break;
|
|
1611
|
+
}
|
|
1612
|
+
}
|
|
1613
|
+
}
|
|
1614
|
+
}
|
|
1615
|
+
if (a.keepFieldsRef)
|
|
1616
|
+
for (const C of u.mount)
|
|
1617
|
+
U(C, h(f, C));
|
|
1618
|
+
else
|
|
1619
|
+
i = {};
|
|
1620
|
+
}
|
|
1621
|
+
n = r.shouldUnregister ? a.keepDefaultValues ? ne(l) : {} : ne(f), g.array.next({
|
|
1622
|
+
values: { ...f }
|
|
1623
|
+
}), g.state.next({
|
|
1624
|
+
values: { ...f }
|
|
1625
|
+
});
|
|
1626
|
+
}
|
|
1627
|
+
u = {
|
|
1628
|
+
mount: a.keepDirtyValues ? u.mount : /* @__PURE__ */ new Set(),
|
|
1629
|
+
unMount: /* @__PURE__ */ new Set(),
|
|
1630
|
+
array: /* @__PURE__ */ new Set(),
|
|
1631
|
+
disabled: /* @__PURE__ */ new Set(),
|
|
1632
|
+
watch: /* @__PURE__ */ new Set(),
|
|
1633
|
+
watchAll: !1,
|
|
1634
|
+
focus: ""
|
|
1635
|
+
}, d.mount = !p.isValid || !!a.keepIsValid || !!a.keepDirtyValues || !r.shouldUnregister && !ue(f), d.watch = !!r.shouldUnregister, g.state.next({
|
|
1636
|
+
submitCount: a.keepSubmitCount ? t.submitCount : 0,
|
|
1637
|
+
isDirty: m ? !1 : a.keepDirty ? t.isDirty : !!(a.keepDefaultValues && !be(s, l)),
|
|
1638
|
+
isSubmitted: a.keepIsSubmitted ? t.isSubmitted : !1,
|
|
1639
|
+
dirtyFields: m ? {} : a.keepDirtyValues ? a.keepDefaultValues && n ? Be(l, n) : t.dirtyFields : a.keepDefaultValues && s ? Be(l, s) : a.keepDirty ? t.dirtyFields : {},
|
|
1640
|
+
touchedFields: a.keepTouched ? t.touchedFields : {},
|
|
1641
|
+
errors: a.keepErrors ? t.errors : {},
|
|
1642
|
+
isSubmitSuccessful: a.keepIsSubmitSuccessful ? t.isSubmitSuccessful : !1,
|
|
1643
|
+
isSubmitting: !1,
|
|
1644
|
+
defaultValues: l
|
|
1645
|
+
});
|
|
1646
|
+
}, bt = (s, a) => vt(xe(s) ? s(n) : s, a), sr = (s, a = {}) => {
|
|
1647
|
+
const c = h(i, s), y = c && c._f;
|
|
1648
|
+
if (y) {
|
|
1649
|
+
const m = y.refs ? y.refs[0] : y.ref;
|
|
1650
|
+
m.focus && (m.focus(), a.shouldSelect && xe(m.select) && m.select());
|
|
1651
|
+
}
|
|
1652
|
+
}, ir = (s) => {
|
|
1653
|
+
t = {
|
|
1654
|
+
...t,
|
|
1655
|
+
...s
|
|
1656
|
+
};
|
|
1657
|
+
}, xt = {
|
|
1658
|
+
control: {
|
|
1659
|
+
register: Ee,
|
|
1660
|
+
unregister: z,
|
|
1661
|
+
getFieldState: ae,
|
|
1662
|
+
handleSubmit: gt,
|
|
1663
|
+
setError: le,
|
|
1664
|
+
_subscribe: we,
|
|
1665
|
+
_runSchema: G,
|
|
1666
|
+
_focusError: Qe,
|
|
1667
|
+
_getWatch: I,
|
|
1668
|
+
_getDirty: O,
|
|
1669
|
+
_setValid: w,
|
|
1670
|
+
_setFieldArray: B,
|
|
1671
|
+
_setDisabledField: Le,
|
|
1672
|
+
_setErrors: x,
|
|
1673
|
+
_getFieldArray: L,
|
|
1674
|
+
_reset: vt,
|
|
1675
|
+
_resetDefaultValues: () => xe(r.defaultValues) && r.defaultValues().then((s) => {
|
|
1676
|
+
bt(s, r.resetOptions), g.state.next({
|
|
1677
|
+
isLoading: !1
|
|
1678
|
+
});
|
|
1679
|
+
}),
|
|
1680
|
+
_removeUnmounted: te,
|
|
1681
|
+
_disableForm: tr,
|
|
1682
|
+
_subjects: g,
|
|
1683
|
+
_proxyFormState: p,
|
|
1684
|
+
get _fields() {
|
|
1685
|
+
return i;
|
|
1686
|
+
},
|
|
1687
|
+
get _formValues() {
|
|
1688
|
+
return n;
|
|
1689
|
+
},
|
|
1690
|
+
get _state() {
|
|
1691
|
+
return d;
|
|
1692
|
+
},
|
|
1693
|
+
set _state(s) {
|
|
1694
|
+
d = s;
|
|
1695
|
+
},
|
|
1696
|
+
get _defaultValues() {
|
|
1697
|
+
return l;
|
|
1698
|
+
},
|
|
1699
|
+
get _names() {
|
|
1700
|
+
return u;
|
|
1701
|
+
},
|
|
1702
|
+
set _names(s) {
|
|
1703
|
+
u = s;
|
|
1704
|
+
},
|
|
1705
|
+
get _formState() {
|
|
1706
|
+
return t;
|
|
1707
|
+
},
|
|
1708
|
+
get _options() {
|
|
1709
|
+
return r;
|
|
1710
|
+
},
|
|
1711
|
+
set _options(s) {
|
|
1712
|
+
r = {
|
|
1713
|
+
...r,
|
|
1714
|
+
...s
|
|
1715
|
+
};
|
|
1716
|
+
}
|
|
1717
|
+
},
|
|
1718
|
+
subscribe: Ne,
|
|
1719
|
+
trigger: K,
|
|
1720
|
+
register: Ee,
|
|
1721
|
+
handleSubmit: gt,
|
|
1722
|
+
watch: Fe,
|
|
1723
|
+
setValue: U,
|
|
1724
|
+
getValues: Q,
|
|
1725
|
+
reset: bt,
|
|
1726
|
+
resetField: rr,
|
|
1727
|
+
clearErrors: me,
|
|
1728
|
+
unregister: z,
|
|
1729
|
+
setError: le,
|
|
1730
|
+
setFocus: sr,
|
|
1731
|
+
getFieldState: ae
|
|
1732
|
+
};
|
|
1733
|
+
return {
|
|
1734
|
+
...xt,
|
|
1735
|
+
formControl: xt
|
|
1736
|
+
};
|
|
1737
|
+
}
|
|
1738
|
+
function ci(e = {}) {
|
|
1739
|
+
const r = E.useRef(void 0), t = E.useRef(void 0), [i, l] = E.useState({
|
|
1740
|
+
isDirty: !1,
|
|
1741
|
+
isValidating: !1,
|
|
1742
|
+
isLoading: xe(e.defaultValues),
|
|
1743
|
+
isSubmitted: !1,
|
|
1744
|
+
isSubmitting: !1,
|
|
1745
|
+
isSubmitSuccessful: !1,
|
|
1746
|
+
isValid: !1,
|
|
1747
|
+
submitCount: 0,
|
|
1748
|
+
dirtyFields: {},
|
|
1749
|
+
touchedFields: {},
|
|
1750
|
+
validatingFields: {},
|
|
1751
|
+
errors: e.errors || {},
|
|
1752
|
+
disabled: e.disabled || !1,
|
|
1753
|
+
isReady: !1,
|
|
1754
|
+
defaultValues: xe(e.defaultValues) ? void 0 : e.defaultValues
|
|
1755
|
+
});
|
|
1756
|
+
if (!r.current)
|
|
1757
|
+
if (e.formControl)
|
|
1758
|
+
r.current = {
|
|
1759
|
+
...e.formControl,
|
|
1760
|
+
formState: i
|
|
1761
|
+
}, e.defaultValues && !xe(e.defaultValues) && e.formControl.reset(e.defaultValues, e.resetOptions);
|
|
1762
|
+
else {
|
|
1763
|
+
const { formControl: d, ...u } = oi(e);
|
|
1764
|
+
r.current = {
|
|
1765
|
+
...u,
|
|
1766
|
+
formState: i
|
|
1767
|
+
};
|
|
1768
|
+
}
|
|
1769
|
+
const n = r.current.control;
|
|
1770
|
+
return n._options = e, pt(() => {
|
|
1771
|
+
const d = n._subscribe({
|
|
1772
|
+
formState: n._proxyFormState,
|
|
1773
|
+
callback: () => l({ ...n._formState }),
|
|
1774
|
+
reRenderRoot: !0
|
|
1775
|
+
});
|
|
1776
|
+
return l((u) => ({
|
|
1777
|
+
...u,
|
|
1778
|
+
isReady: !0
|
|
1779
|
+
})), n._formState.isReady = !0, d;
|
|
1780
|
+
}, [n]), E.useEffect(() => n._disableForm(e.disabled), [n, e.disabled]), E.useEffect(() => {
|
|
1781
|
+
e.mode && (n._options.mode = e.mode), e.reValidateMode && (n._options.reValidateMode = e.reValidateMode);
|
|
1782
|
+
}, [n, e.mode, e.reValidateMode]), E.useEffect(() => {
|
|
1783
|
+
e.errors && (n._setErrors(e.errors), n._focusError());
|
|
1784
|
+
}, [n, e.errors]), E.useEffect(() => {
|
|
1785
|
+
e.shouldUnregister && n._subjects.state.next({
|
|
1786
|
+
values: n._getWatch()
|
|
1787
|
+
});
|
|
1788
|
+
}, [n, e.shouldUnregister]), E.useEffect(() => {
|
|
1789
|
+
if (n._proxyFormState.isDirty) {
|
|
1790
|
+
const d = n._getDirty();
|
|
1791
|
+
d !== i.isDirty && n._subjects.state.next({
|
|
1792
|
+
isDirty: d
|
|
1793
|
+
});
|
|
1794
|
+
}
|
|
1795
|
+
}, [n, i.isDirty]), E.useEffect(() => {
|
|
1796
|
+
e.values && !be(e.values, t.current) ? (n._reset(e.values, {
|
|
1797
|
+
keepFieldsRef: !0,
|
|
1798
|
+
...n._options.resetOptions
|
|
1799
|
+
}), t.current = e.values, l((d) => ({ ...d }))) : n._resetDefaultValues();
|
|
1800
|
+
}, [n, e.values]), E.useEffect(() => {
|
|
1801
|
+
n._state.mount || (n._setValid(), n._state.mount = !0), n._state.watch && (n._state.watch = !1, n._subjects.state.next({ ...n._formState })), n._removeUnmounted();
|
|
1802
|
+
}), r.current.formState = Ht(i, n), r.current;
|
|
1803
|
+
}
|
|
1804
|
+
var di = /* @__PURE__ */ ((e) => (e.PRIVACY_POLICY = "privacy-policy", e.PERSONAL_DATA = "personal-data", e.MAILING = "mailing", e.STONE_VALUE = "stone-value", e))(di || {});
|
|
1805
|
+
const ui = Ie.bind(re), fi = "Я принимаю условия Политики обработки и защиты персональных данных, даю согласия на обработку персональных данных", Jn = ({
|
|
1806
|
+
isFormOpen: e,
|
|
1807
|
+
setIsFormOpen: r,
|
|
1808
|
+
isNews: t,
|
|
1809
|
+
title: i,
|
|
1810
|
+
isEmail: l,
|
|
1811
|
+
isPhone: n,
|
|
1812
|
+
isTextArea: d,
|
|
1813
|
+
telegramLink: u = "https://t.me/stone_developer",
|
|
1814
|
+
isRequiredPhone: W = !0,
|
|
1815
|
+
isRequiredEmail: T = !1,
|
|
1816
|
+
isRequiredPhoneOrEmail: p,
|
|
1817
|
+
textAreaPlaceholder: b,
|
|
1818
|
+
subTitle: g,
|
|
1819
|
+
submitHandler: V,
|
|
1820
|
+
modalWidth: A = "442px",
|
|
1821
|
+
rowsTextArea: w = 2,
|
|
1822
|
+
advCheckBox: N = { text: fi, isRequired: !0 },
|
|
1823
|
+
isAdvCheckBox: B,
|
|
1824
|
+
addTitleClassName: v,
|
|
1825
|
+
createPortalObj: x,
|
|
1826
|
+
telegramClickHandler: P = () => null,
|
|
1827
|
+
blurHandler: S,
|
|
1828
|
+
handlerButton: D,
|
|
1829
|
+
block_name: G,
|
|
1830
|
+
policiesMap: q,
|
|
1831
|
+
emitCheckBox: R,
|
|
1832
|
+
emitAdvCheckBox: te
|
|
1833
|
+
}) => {
|
|
1834
|
+
const {
|
|
1835
|
+
register: O,
|
|
1836
|
+
handleSubmit: I,
|
|
1837
|
+
reset: L,
|
|
1838
|
+
control: M,
|
|
1839
|
+
watch: j,
|
|
1840
|
+
setValue: U,
|
|
1841
|
+
formState: { errors: _ }
|
|
1842
|
+
} = ci(), Y = !!j("email"), K = j("personalCheckBox"), Q = j("advCheckBox");
|
|
1843
|
+
Oe(() => {
|
|
1844
|
+
typeof K < "u" && R && R();
|
|
1845
|
+
}, [R, K]), Oe(() => {
|
|
1846
|
+
typeof Q < "u" && te && te();
|
|
1847
|
+
}, [te, Q]);
|
|
1848
|
+
const { isMobile: ae, currentClientWidth: me } = _e(), le = j("personalCheckBox"), Fe = j("advCheckBox"), we = (z) => {
|
|
1849
|
+
V(z), L();
|
|
1850
|
+
}, Ne = (z, { action_element_status: Le, action_element: Ee }) => {
|
|
1851
|
+
S && S({
|
|
1852
|
+
e: z,
|
|
1853
|
+
analyticParams: { action_element: Ee, action_element_status: Le, block_name: G }
|
|
1854
|
+
});
|
|
1855
|
+
};
|
|
1856
|
+
return Oe(() => {
|
|
1857
|
+
if (!q)
|
|
1858
|
+
return;
|
|
1859
|
+
const z = ["personal-data", "privacy-policy", ...t ? [
|
|
1860
|
+
"mailing"
|
|
1861
|
+
/* MAILING */
|
|
1862
|
+
] : []];
|
|
1863
|
+
le ? U(
|
|
1864
|
+
"policy-slug",
|
|
1865
|
+
z.join(", "),
|
|
1866
|
+
{ shouldDirty: !0 }
|
|
1867
|
+
) : U("policy-slug", "", { shouldDirty: !0 });
|
|
1868
|
+
}, [q, le]), me ? /* @__PURE__ */ o(
|
|
1869
|
+
ot,
|
|
1870
|
+
{
|
|
1871
|
+
additionalClass: re.modal,
|
|
1872
|
+
additionalClassModalBody: re.modalBody,
|
|
1873
|
+
createPortalObj: x,
|
|
1874
|
+
isOpen: e,
|
|
1875
|
+
isTransparentBack: !0,
|
|
1876
|
+
emitIsOpen: () => r(!1),
|
|
1877
|
+
opacity: 0.7,
|
|
1878
|
+
children: /* @__PURE__ */ F(
|
|
1879
|
+
"div",
|
|
1880
|
+
{
|
|
1881
|
+
className: re.root,
|
|
1882
|
+
style: { width: ae ? "100%" : A },
|
|
1883
|
+
"data-testid": "modal_window",
|
|
1884
|
+
children: [
|
|
1885
|
+
/* @__PURE__ */ o(
|
|
1886
|
+
"div",
|
|
1887
|
+
{
|
|
1888
|
+
className: ui(re.title, v),
|
|
1889
|
+
dangerouslySetInnerHTML: { __html: i ?? "Оставить обращение" }
|
|
1890
|
+
}
|
|
1891
|
+
),
|
|
1892
|
+
t && /* @__PURE__ */ F("div", { className: re.telegramWrapper, children: [
|
|
1893
|
+
/* @__PURE__ */ o(
|
|
1894
|
+
"a",
|
|
1895
|
+
{
|
|
1896
|
+
className: re.telegramLink,
|
|
1897
|
+
href: u,
|
|
1898
|
+
target: "_blank",
|
|
1899
|
+
"data-testid": "modal_telegram_link",
|
|
1900
|
+
children: /* @__PURE__ */ F(
|
|
1901
|
+
"div",
|
|
1902
|
+
{
|
|
1903
|
+
className: re.telegram,
|
|
1904
|
+
onClick: P,
|
|
1905
|
+
children: [
|
|
1906
|
+
/* @__PURE__ */ o("div", { children: "Подписаться в Telegram" }),
|
|
1907
|
+
/* @__PURE__ */ o(Se, { name: "telegram" })
|
|
1908
|
+
]
|
|
1909
|
+
}
|
|
1910
|
+
)
|
|
1911
|
+
}
|
|
1912
|
+
),
|
|
1913
|
+
/* @__PURE__ */ o("div", { className: re.orText, children: "или" })
|
|
1914
|
+
] }),
|
|
1915
|
+
!t && /* @__PURE__ */ o(
|
|
1916
|
+
"div",
|
|
1917
|
+
{
|
|
1918
|
+
className: re.description,
|
|
1919
|
+
dangerouslySetInnerHTML: {
|
|
1920
|
+
__html: g && !t ? "Оставьте номер телефона для получения консультации" : `${/* @__PURE__ */ o("div", { children: "привет" })}`
|
|
1921
|
+
}
|
|
1922
|
+
}
|
|
1923
|
+
),
|
|
1924
|
+
/* @__PURE__ */ F("form", { onSubmit: I(we), children: [
|
|
1925
|
+
/* @__PURE__ */ F(cr, { className: re.inputWrapper, children: [
|
|
1926
|
+
/* @__PURE__ */ o(
|
|
1927
|
+
tt,
|
|
1928
|
+
{
|
|
1929
|
+
width: "full",
|
|
1930
|
+
size_s: "large",
|
|
1931
|
+
variant: "light",
|
|
1932
|
+
placeholder: "Введите имя",
|
|
1933
|
+
"data-testid": "modal_name",
|
|
1934
|
+
...O("name", { required: !0, pattern: ur }),
|
|
1935
|
+
onBlur: (z) => Ne(z, {
|
|
1936
|
+
action_element_status: _.name ? "error" : "success",
|
|
1937
|
+
action_element: `input_${G}_name`
|
|
1938
|
+
}),
|
|
1939
|
+
error: !!_.name
|
|
1940
|
+
}
|
|
1941
|
+
),
|
|
1942
|
+
n && /* @__PURE__ */ o(
|
|
1943
|
+
Gs,
|
|
1944
|
+
{
|
|
1945
|
+
name: "phone",
|
|
1946
|
+
control: M,
|
|
1947
|
+
rules: {
|
|
1948
|
+
required: T || W || p && !Y,
|
|
1949
|
+
pattern: { value: fr, message: "" }
|
|
1950
|
+
},
|
|
1951
|
+
defaultValue: "",
|
|
1952
|
+
render: ({ field: z }) => /* @__PURE__ */ o(
|
|
1953
|
+
tt,
|
|
1954
|
+
{
|
|
1955
|
+
inputMode: "numeric",
|
|
1956
|
+
isPhoneIMask: !0,
|
|
1957
|
+
...z,
|
|
1958
|
+
width: "full",
|
|
1959
|
+
"data-testid": "phone_modal",
|
|
1960
|
+
type: "tel",
|
|
1961
|
+
error: !!_.phone,
|
|
1962
|
+
size_s: "large",
|
|
1963
|
+
variant: "light",
|
|
1964
|
+
onBlur: (Le) => Ne(Le, {
|
|
1965
|
+
action_element_status: _.phone ? "error" : "success",
|
|
1966
|
+
action_element: `input_${G}_phone`
|
|
1967
|
+
})
|
|
1968
|
+
}
|
|
1969
|
+
)
|
|
1970
|
+
}
|
|
1971
|
+
),
|
|
1972
|
+
l && /* @__PURE__ */ o(
|
|
1973
|
+
tt,
|
|
1974
|
+
{
|
|
1975
|
+
width: "full",
|
|
1976
|
+
size_s: "large",
|
|
1977
|
+
variant: "light",
|
|
1978
|
+
placeholder: "Введите email",
|
|
1979
|
+
"data-testid": "modal_email",
|
|
1980
|
+
...O("email", {
|
|
1981
|
+
required: T || p && !Y,
|
|
1982
|
+
pattern: mr
|
|
1983
|
+
}),
|
|
1984
|
+
error: !!_.email,
|
|
1985
|
+
onBlur: (z) => Ne(z, {
|
|
1986
|
+
action_element_status: _.email ? "error" : "success",
|
|
1987
|
+
action_element: `input_${G}_email`
|
|
1988
|
+
})
|
|
1989
|
+
}
|
|
1990
|
+
),
|
|
1991
|
+
d && /* @__PURE__ */ o(
|
|
1992
|
+
pr,
|
|
1993
|
+
{
|
|
1994
|
+
"data-testid": "modal_textarea",
|
|
1995
|
+
placeholder: b,
|
|
1996
|
+
rows: w,
|
|
1997
|
+
width: "full",
|
|
1998
|
+
...O("textarea")
|
|
1999
|
+
}
|
|
2000
|
+
),
|
|
2001
|
+
N && !t && B && /* @__PURE__ */ o(
|
|
2002
|
+
wt,
|
|
2003
|
+
{
|
|
2004
|
+
"data-testid": "modal_advCheckBox",
|
|
2005
|
+
isChecked: Fe,
|
|
2006
|
+
error: !!_.advCheckBox,
|
|
2007
|
+
text: N.text,
|
|
2008
|
+
...O("advCheckBox", { required: N?.isRequired })
|
|
2009
|
+
}
|
|
2010
|
+
),
|
|
2011
|
+
/* @__PURE__ */ F(
|
|
2012
|
+
wt,
|
|
2013
|
+
{
|
|
2014
|
+
"data-testid": "modal_personalCheckBox",
|
|
2015
|
+
isChecked: le,
|
|
2016
|
+
error: !!_.personalCheckBox,
|
|
2017
|
+
...O("personalCheckBox", { required: !t }),
|
|
2018
|
+
children: [
|
|
2019
|
+
t && /* @__PURE__ */ F("div", { className: re.checkboxText, children: [
|
|
2020
|
+
"Я принимаю условия",
|
|
2021
|
+
" ",
|
|
2022
|
+
/* @__PURE__ */ o(
|
|
2023
|
+
"a",
|
|
2024
|
+
{
|
|
2025
|
+
className: re.linkPolicy,
|
|
2026
|
+
href: q?.[
|
|
2027
|
+
"personal-data"
|
|
2028
|
+
/* PERSONAL_DATA */
|
|
2029
|
+
] || "/documents/docs",
|
|
2030
|
+
target: "_blank",
|
|
2031
|
+
rel: "noopener noreferrer",
|
|
2032
|
+
children: "Политики обработки"
|
|
2033
|
+
}
|
|
2034
|
+
),
|
|
2035
|
+
" ",
|
|
2036
|
+
"и",
|
|
2037
|
+
" ",
|
|
2038
|
+
/* @__PURE__ */ o(
|
|
2039
|
+
"a",
|
|
2040
|
+
{
|
|
2041
|
+
className: re.linkPolicy,
|
|
2042
|
+
href: q?.[
|
|
2043
|
+
"privacy-policy"
|
|
2044
|
+
/* PRIVACY_POLICY */
|
|
2045
|
+
] || "/documents/politika-konfidenczialnosti",
|
|
2046
|
+
target: "_blank",
|
|
2047
|
+
rel: "noopener noreferrer",
|
|
2048
|
+
children: "защиты персональных данных"
|
|
2049
|
+
}
|
|
2050
|
+
),
|
|
2051
|
+
", даю",
|
|
2052
|
+
" ",
|
|
2053
|
+
/* @__PURE__ */ o(
|
|
2054
|
+
"a",
|
|
2055
|
+
{
|
|
2056
|
+
className: re.linkPolicy,
|
|
2057
|
+
href: q?.mailing || "/documents/soglasie-na-rassylki",
|
|
2058
|
+
target: "_blank",
|
|
2059
|
+
rel: "noopener noreferrer",
|
|
2060
|
+
children: "согласие на получение новостных и рекламных сообщений"
|
|
2061
|
+
}
|
|
2062
|
+
)
|
|
2063
|
+
] }),
|
|
2064
|
+
!t && /* @__PURE__ */ F("div", { className: re.checkboxText, children: [
|
|
2065
|
+
"Я принимаю условия",
|
|
2066
|
+
" ",
|
|
2067
|
+
/* @__PURE__ */ o(
|
|
2068
|
+
"a",
|
|
2069
|
+
{
|
|
2070
|
+
className: re.linkPolicy,
|
|
2071
|
+
href: q?.[
|
|
2072
|
+
"privacy-policy"
|
|
2073
|
+
/* PRIVACY_POLICY */
|
|
2074
|
+
] || "/documents/politika-konfidenczialnosti",
|
|
2075
|
+
target: "_blank",
|
|
2076
|
+
rel: "noopener noreferrer",
|
|
2077
|
+
children: "Политики обработки и защиты персональных данных"
|
|
2078
|
+
}
|
|
2079
|
+
),
|
|
2080
|
+
", даю",
|
|
2081
|
+
" ",
|
|
2082
|
+
/* @__PURE__ */ o(
|
|
2083
|
+
"a",
|
|
2084
|
+
{
|
|
2085
|
+
className: re.linkPolicy,
|
|
2086
|
+
href: q?.[
|
|
2087
|
+
"personal-data"
|
|
2088
|
+
/* PERSONAL_DATA */
|
|
2089
|
+
] || "/documents/docs",
|
|
2090
|
+
target: "_blank",
|
|
2091
|
+
rel: "noopener noreferrer",
|
|
2092
|
+
children: "согласие на обработку персональных данных"
|
|
2093
|
+
}
|
|
2094
|
+
)
|
|
2095
|
+
] })
|
|
2096
|
+
]
|
|
2097
|
+
}
|
|
2098
|
+
),
|
|
2099
|
+
/* @__PURE__ */ o(
|
|
2100
|
+
Ae,
|
|
2101
|
+
{
|
|
2102
|
+
"data-testid": "modal_submit",
|
|
2103
|
+
variant: "blue",
|
|
2104
|
+
width: "full",
|
|
2105
|
+
type: "submit",
|
|
2106
|
+
size: "large",
|
|
2107
|
+
as: "button",
|
|
2108
|
+
additionalClass: re.modalBtn,
|
|
2109
|
+
onClick: () => {
|
|
2110
|
+
D && D();
|
|
2111
|
+
},
|
|
2112
|
+
disabled: !!_.name || !!_.phone && W || !!_.email && T || !!_.advCheckBox && N?.isRequired || !!_.personalCheckBox && !t,
|
|
2113
|
+
children: "Отправить запрос"
|
|
2114
|
+
}
|
|
2115
|
+
)
|
|
2116
|
+
] }),
|
|
2117
|
+
/* @__PURE__ */ o(
|
|
2118
|
+
Ae,
|
|
2119
|
+
{
|
|
2120
|
+
additionalClass: re.btn,
|
|
2121
|
+
onClick: () => r(!1),
|
|
2122
|
+
as: "button",
|
|
2123
|
+
variant: "gray",
|
|
2124
|
+
type: "button",
|
|
2125
|
+
size: "small",
|
|
2126
|
+
children: /* @__PURE__ */ o(
|
|
2127
|
+
Se,
|
|
2128
|
+
{
|
|
2129
|
+
name: "close",
|
|
2130
|
+
size: "16",
|
|
2131
|
+
color: "#141416"
|
|
2132
|
+
}
|
|
2133
|
+
)
|
|
2134
|
+
}
|
|
2135
|
+
)
|
|
2136
|
+
] })
|
|
2137
|
+
]
|
|
2138
|
+
}
|
|
2139
|
+
)
|
|
2140
|
+
}
|
|
2141
|
+
) : null;
|
|
2142
|
+
}, mi = "_snippet_1vgdm_1", pi = "_snippetLast_1vgdm_9", hi = "_snippets_1vgdm_25", yi = "_retailSnippets_1vgdm_30", gi = "_shownSnippets_1vgdm_35", vi = "_addSnippets_1vgdm_64", bi = "_addSnippetsActive_1vgdm_80", xi = "_addSnippetsList_1vgdm_85", Si = "_closeSnippetBtn_1vgdm_129", ge = {
|
|
2143
|
+
snippet: mi,
|
|
2144
|
+
snippetLast: pi,
|
|
2145
|
+
snippets: hi,
|
|
2146
|
+
retailSnippets: yi,
|
|
2147
|
+
shownSnippets: gi,
|
|
2148
|
+
addSnippets: vi,
|
|
2149
|
+
addSnippetsActive: bi,
|
|
2150
|
+
addSnippetsList: xi,
|
|
2151
|
+
closeSnippetBtn: Si
|
|
2152
|
+
}, Dt = Ie.bind(ge), Fi = ({ lot: e }) => {
|
|
2153
|
+
const { type: r, windowViews: t, isCorner: i } = e || {}, [l, n] = Te(!1), d = gr({ ...e }), { isDesktop: u, isMobile: W } = _e();
|
|
2154
|
+
if (r === 3) {
|
|
2155
|
+
if (W && (!t || t.length === 0))
|
|
2156
|
+
return null;
|
|
2157
|
+
let T = 0;
|
|
2158
|
+
const p = u ? 36 : 28, b = [], g = [];
|
|
2159
|
+
if (i) {
|
|
2160
|
+
const V = "Угловая";
|
|
2161
|
+
if (T + V.length <= p)
|
|
2162
|
+
b.push(V), T += V.length;
|
|
2163
|
+
else
|
|
2164
|
+
return b;
|
|
2165
|
+
}
|
|
2166
|
+
if (t) {
|
|
2167
|
+
const V = t.filter((N) => N && N.trim() !== "");
|
|
2168
|
+
let A = 0, w = T;
|
|
2169
|
+
for (let N = 0; N < V.length; N++) {
|
|
2170
|
+
const B = V[N], v = A > 0 ? " " + B : B;
|
|
2171
|
+
if (w + v.length <= p)
|
|
2172
|
+
b.push(B), w += v.length, A++;
|
|
2173
|
+
else {
|
|
2174
|
+
if (A === 0) {
|
|
2175
|
+
const x = p - w;
|
|
2176
|
+
if (x > 3) {
|
|
2177
|
+
const P = B.substring(0, x - 3) + "...";
|
|
2178
|
+
b.push(P), w = p;
|
|
2179
|
+
} else
|
|
2180
|
+
b.push("..."), w += 3;
|
|
2181
|
+
}
|
|
2182
|
+
g.push(...V.slice(N));
|
|
2183
|
+
break;
|
|
2184
|
+
}
|
|
2185
|
+
}
|
|
2186
|
+
T = w;
|
|
2187
|
+
}
|
|
2188
|
+
return /* @__PURE__ */ F("div", { className: ge.retailSnippets, children: [
|
|
2189
|
+
/* @__PURE__ */ o("ul", { className: ge.shownSnippets, children: b?.map((V, A) => /* @__PURE__ */ o("li", { className: ge.snippets, children: V }, A)) }),
|
|
2190
|
+
g?.length > 0 && /* @__PURE__ */ F(
|
|
2191
|
+
"div",
|
|
2192
|
+
{
|
|
2193
|
+
className: Dt(ge.addSnippets, { [ge.addSnippetsActive]: l }),
|
|
2194
|
+
onClick: (V) => {
|
|
2195
|
+
u || (V.stopPropagation(), V.preventDefault(), n((A) => !A));
|
|
2196
|
+
},
|
|
2197
|
+
onMouseEnter: () => {
|
|
2198
|
+
u && n(!0);
|
|
2199
|
+
},
|
|
2200
|
+
onMouseLeave: () => {
|
|
2201
|
+
u && n(!1);
|
|
2202
|
+
},
|
|
2203
|
+
children: [
|
|
2204
|
+
"+" + g?.length,
|
|
2205
|
+
l && /* @__PURE__ */ F("ul", { className: ge.addSnippetsList, children: [
|
|
2206
|
+
g.map((V, A) => /* @__PURE__ */ o("li", { children: V }, A)),
|
|
2207
|
+
/* @__PURE__ */ o("div", { className: ge.closeSnippetBtn, children: /* @__PURE__ */ o(
|
|
2208
|
+
Se,
|
|
2209
|
+
{
|
|
2210
|
+
name: "close",
|
|
2211
|
+
size: "16",
|
|
2212
|
+
color: "#ffffff"
|
|
2213
|
+
}
|
|
2214
|
+
) })
|
|
2215
|
+
] })
|
|
2216
|
+
]
|
|
2217
|
+
}
|
|
2218
|
+
)
|
|
2219
|
+
] });
|
|
2220
|
+
}
|
|
2221
|
+
return d.length ? /* @__PURE__ */ o("div", { className: ge.snippets, children: d.map((T, p) => {
|
|
2222
|
+
const b = p === d.length - 1;
|
|
2223
|
+
return /* @__PURE__ */ o(
|
|
2224
|
+
"div",
|
|
2225
|
+
{
|
|
2226
|
+
className: Dt(ge.snippet, b ? "" : ge.snippetLast),
|
|
2227
|
+
children: T.text
|
|
2228
|
+
},
|
|
2229
|
+
p
|
|
2230
|
+
);
|
|
2231
|
+
}) }) : null;
|
|
2232
|
+
}, Ni = "_root_1jvyk_1", wi = "_lotImageWrapper_1jvyk_17", Ci = "_lotNameContent_1jvyk_24", ki = "_lotNameWrapper_1jvyk_30", Ti = "_lotName_1jvyk_24", Ai = "_lotNumber_1jvyk_45", Pi = "_content_1jvyk_54", Ii = "_featuresWrapper_1jvyk_60", Li = "_tags_1jvyk_65", Wi = "_discountText_1jvyk_69", Vi = "_rootRow_1jvyk_77", Bi = "_price_1jvyk_112", Oi = "_paymentLink_1jvyk_115", de = {
|
|
2233
|
+
root: Ni,
|
|
2234
|
+
lotImageWrapper: wi,
|
|
2235
|
+
lotNameContent: Ci,
|
|
2236
|
+
lotNameWrapper: ki,
|
|
2237
|
+
lotName: Ti,
|
|
2238
|
+
lotNumber: Ai,
|
|
2239
|
+
content: Pi,
|
|
2240
|
+
featuresWrapper: Ii,
|
|
2241
|
+
tags: Li,
|
|
2242
|
+
discountText: Wi,
|
|
2243
|
+
rootRow: Vi,
|
|
2244
|
+
price: Bi,
|
|
2245
|
+
paymentLink: Oi
|
|
2246
|
+
}, _i = Ie.bind(de), Yn = ({
|
|
2247
|
+
lot: e,
|
|
2248
|
+
imgNode: r,
|
|
2249
|
+
onPriceClickHandler: t,
|
|
2250
|
+
addClassname: i,
|
|
2251
|
+
isVertical: l = !1,
|
|
2252
|
+
isFavorite: n,
|
|
2253
|
+
favoriteClickHandler: d,
|
|
2254
|
+
isMoreDetails: u
|
|
2255
|
+
}) => {
|
|
2256
|
+
const { interiorPlanImg: W, floorPlanImg: T, area: p, subTypeName: b, number: g, sellingPrice: V } = e || {}, A = b + ", " + hr(p) + "м²", w = W ?? T ?? "";
|
|
2257
|
+
if (!e) return null;
|
|
2258
|
+
const N = !!e.project?.showPriceSubType?.some((S) => Number(S.filter) === e.subType), B = jt(e), v = N && Number(V) && !B, P = v ? "С учётом скидки -1% в честь дня рождения STONE" : "Скидка 1% в честь дня рождения STONE";
|
|
2259
|
+
return /* @__PURE__ */ F("div", { className: _i(de.root, i, { [de.rootRow]: !l }), children: [
|
|
2260
|
+
/* @__PURE__ */ F("div", { className: de.lotImageWrapper, children: [
|
|
2261
|
+
r || /* @__PURE__ */ o(
|
|
2262
|
+
"img",
|
|
2263
|
+
{
|
|
2264
|
+
loading: "lazy",
|
|
2265
|
+
src: w,
|
|
2266
|
+
width: 295,
|
|
2267
|
+
height: 213,
|
|
2268
|
+
alt: "logo_image"
|
|
2269
|
+
}
|
|
2270
|
+
),
|
|
2271
|
+
d && /* @__PURE__ */ o(
|
|
2272
|
+
qt,
|
|
2273
|
+
{
|
|
2274
|
+
handleClickFavorite: (S) => {
|
|
2275
|
+
d && d(e), S.preventDefault(), S.stopPropagation();
|
|
2276
|
+
},
|
|
2277
|
+
isFavorite: n
|
|
2278
|
+
}
|
|
2279
|
+
)
|
|
2280
|
+
] }),
|
|
2281
|
+
/* @__PURE__ */ F("div", { className: de.content, children: [
|
|
2282
|
+
/* @__PURE__ */ F("div", { className: de.lotNameWrapper, children: [
|
|
2283
|
+
/* @__PURE__ */ F("div", { className: de.lotNameContent, children: [
|
|
2284
|
+
/* @__PURE__ */ o("p", { className: de.lotName, children: A }),
|
|
2285
|
+
/* @__PURE__ */ o("p", { className: de.lotNumber, children: g }),
|
|
2286
|
+
/* @__PURE__ */ o(Fi, { lot: e }),
|
|
2287
|
+
/* @__PURE__ */ o(kt, { lot: e, classname: de.tags })
|
|
2288
|
+
] }),
|
|
2289
|
+
/* @__PURE__ */ F("div", { style: { display: "flex", flexDirection: "column", gap: "8px" }, children: [
|
|
2290
|
+
/* @__PURE__ */ o(
|
|
2291
|
+
yr,
|
|
2292
|
+
{
|
|
2293
|
+
lot: e,
|
|
2294
|
+
isVertical: l,
|
|
2295
|
+
onPriceClickHandler: t,
|
|
2296
|
+
classname: de.price
|
|
2297
|
+
}
|
|
2298
|
+
),
|
|
2299
|
+
!B && /* @__PURE__ */ o("div", { className: de.discountText, children: P })
|
|
2300
|
+
] })
|
|
2301
|
+
] }),
|
|
2302
|
+
/* @__PURE__ */ F("div", { className: de.featuresWrapper, children: [
|
|
2303
|
+
/* @__PURE__ */ o(kt, { lot: e, classname: de.tags }),
|
|
2304
|
+
/* @__PURE__ */ o(vr, { specialProgram: e.specialProgram, classname: de.paymentLink, isMoreDetails: u })
|
|
2305
|
+
] })
|
|
2306
|
+
] })
|
|
2307
|
+
] });
|
|
2308
|
+
}, Ei = "_root_1v1y9_1", Di = "_filterWithSaveModal_1v1y9_15", Ri = "_modalAddBody_1v1y9_20", Mi = "_closeBtn_1v1y9_29", ji = "_btnName_1v1y9_35", qi = "_modalTitle_1v1y9_39", zi = "_tabSWitcherWrapper_1v1y9_48", Xi = "_switcherTitle_1v1y9_77", Ui = "_switcherScroll_1v1y9_84", Zi = "_tabs_1v1y9_93", Gi = "_selectWrapper_1v1y9_98", Hi = "_filterOption_1v1y9_102", Ji = "_btnWrapper_1v1y9_110", Yi = "_resetBtn_1v1y9_116", Ki = "_saveBtn_1v1y9_117", Qi = "_desktopWrapper_1v1y9_121", $i = "_desktopWrapperOpen_1v1y9_144", X = {
|
|
2309
|
+
root: Ei,
|
|
2310
|
+
filterWithSaveModal: Di,
|
|
2311
|
+
modalAddBody: Ri,
|
|
2312
|
+
closeBtn: Mi,
|
|
2313
|
+
btnName: ji,
|
|
2314
|
+
modalTitle: qi,
|
|
2315
|
+
tabSWitcherWrapper: zi,
|
|
2316
|
+
switcherTitle: Xi,
|
|
2317
|
+
switcherScroll: Ui,
|
|
2318
|
+
tabs: Zi,
|
|
2319
|
+
selectWrapper: Gi,
|
|
2320
|
+
filterOption: Hi,
|
|
2321
|
+
btnWrapper: Ji,
|
|
2322
|
+
resetBtn: Yi,
|
|
2323
|
+
saveBtn: Ki,
|
|
2324
|
+
desktopWrapper: Qi,
|
|
2325
|
+
desktopWrapperOpen: $i
|
|
2326
|
+
};
|
|
2327
|
+
var st = { exports: {} };
|
|
2328
|
+
var Rt;
|
|
2329
|
+
function en() {
|
|
2330
|
+
return Rt || (Rt = 1, (function(e) {
|
|
2331
|
+
(function() {
|
|
2332
|
+
var r = {}.hasOwnProperty;
|
|
2333
|
+
function t() {
|
|
2334
|
+
for (var n = "", d = 0; d < arguments.length; d++) {
|
|
2335
|
+
var u = arguments[d];
|
|
2336
|
+
u && (n = l(n, i.call(this, u)));
|
|
2337
|
+
}
|
|
2338
|
+
return n;
|
|
2339
|
+
}
|
|
2340
|
+
function i(n) {
|
|
2341
|
+
if (typeof n == "string" || typeof n == "number")
|
|
2342
|
+
return this && this[n] || n;
|
|
2343
|
+
if (typeof n != "object")
|
|
2344
|
+
return "";
|
|
2345
|
+
if (Array.isArray(n))
|
|
2346
|
+
return t.apply(this, n);
|
|
2347
|
+
if (n.toString !== Object.prototype.toString && !n.toString.toString().includes("[native code]"))
|
|
2348
|
+
return n.toString();
|
|
2349
|
+
var d = "";
|
|
2350
|
+
for (var u in n)
|
|
2351
|
+
r.call(n, u) && n[u] && (d = l(d, this && this[u] || u));
|
|
2352
|
+
return d;
|
|
2353
|
+
}
|
|
2354
|
+
function l(n, d) {
|
|
2355
|
+
return d ? n ? n + " " + d : n + d : n;
|
|
2356
|
+
}
|
|
2357
|
+
e.exports ? (t.default = t, e.exports = t) : window.classNames = t;
|
|
2358
|
+
})();
|
|
2359
|
+
})(st)), st.exports;
|
|
2360
|
+
}
|
|
2361
|
+
var tn = en();
|
|
2362
|
+
const rn = /* @__PURE__ */ or(tn), sn = ({
|
|
2363
|
+
selectedTabs: e = [],
|
|
2364
|
+
selectedValues: r = [],
|
|
2365
|
+
onClickItem: t,
|
|
2366
|
+
disabledOptions: i = [],
|
|
2367
|
+
tabs: l = [],
|
|
2368
|
+
onChange: n,
|
|
2369
|
+
setSelectedTabs: d,
|
|
2370
|
+
onSaveClick: u,
|
|
2371
|
+
onClearClick: W
|
|
2372
|
+
}) => {
|
|
2373
|
+
const { isMobile: T } = _e(), [p, b] = Te(!1), g = Mt(null), [V, A] = Te(e), [w] = Te(r), [N, B] = Te(V), [v, x] = Te(w), P = (R) => {
|
|
2374
|
+
if (t && t(R), i.some((O) => O.value === R.value))
|
|
2375
|
+
return;
|
|
2376
|
+
const te = v.some((O) => O.value === R.value) ? v.filter((O) => O.value !== R.value) : [...v, R];
|
|
2377
|
+
x(te);
|
|
2378
|
+
}, S = () => {
|
|
2379
|
+
A(l), B(l), x([]), W(), n && (n([]), d?.(l));
|
|
2380
|
+
}, D = () => {
|
|
2381
|
+
x(r), B(e);
|
|
2382
|
+
}, G = () => {
|
|
2383
|
+
D(), b(!1);
|
|
2384
|
+
}, q = (R) => {
|
|
2385
|
+
R.stopPropagation(), u(), n && (d?.(N), n(v)), b(!1);
|
|
2386
|
+
};
|
|
2387
|
+
return Oe(() => {
|
|
2388
|
+
p || B((R) => JSON.stringify(R) !== JSON.stringify(e) ? e : R);
|
|
2389
|
+
}, [p, e]), Oe(() => {
|
|
2390
|
+
const R = (te) => {
|
|
2391
|
+
if (!g.current) return;
|
|
2392
|
+
const O = te.target;
|
|
2393
|
+
g.current.contains(O) || O.closest("svg") || G();
|
|
2394
|
+
};
|
|
2395
|
+
return p ? document.addEventListener("click", R) : document.removeEventListener("click", R), () => {
|
|
2396
|
+
document.removeEventListener("click", R);
|
|
2397
|
+
};
|
|
2398
|
+
}, [p]), {
|
|
2399
|
+
isMobile: T,
|
|
2400
|
+
handleClearClick: S,
|
|
2401
|
+
handleCloseModal: G,
|
|
2402
|
+
handleOptionClick: P,
|
|
2403
|
+
handleSaveClick: q,
|
|
2404
|
+
localSelectedTabs: N,
|
|
2405
|
+
selectedOptions: v,
|
|
2406
|
+
setSelectedOptions: x,
|
|
2407
|
+
isModalOpen: p,
|
|
2408
|
+
setIsModalOpen: b,
|
|
2409
|
+
setLocalSelectedTabs: B,
|
|
2410
|
+
containerRef: g
|
|
2411
|
+
};
|
|
2412
|
+
}, nn = rn.bind(X), Kn = ({
|
|
2413
|
+
disabledOptions: e,
|
|
2414
|
+
tabs: r = [],
|
|
2415
|
+
selectOptions: t = [],
|
|
2416
|
+
onChange: i,
|
|
2417
|
+
onClick: l = () => null,
|
|
2418
|
+
selectedValues: n,
|
|
2419
|
+
setSelectedTabs: d,
|
|
2420
|
+
selectedTabs: u,
|
|
2421
|
+
onClickItem: W,
|
|
2422
|
+
onCLickSelect: T,
|
|
2423
|
+
dataTestId: p,
|
|
2424
|
+
onSaveClick: b = () => null,
|
|
2425
|
+
onClearClick: g = () => null,
|
|
2426
|
+
onTabClick: V = () => null,
|
|
2427
|
+
btnName: A = "Фильтр"
|
|
2428
|
+
}) => {
|
|
2429
|
+
const {
|
|
2430
|
+
handleCloseModal: w,
|
|
2431
|
+
localSelectedTabs: N,
|
|
2432
|
+
selectedOptions: B,
|
|
2433
|
+
isMobile: v,
|
|
2434
|
+
handleOptionClick: x,
|
|
2435
|
+
handleClearClick: P,
|
|
2436
|
+
handleSaveClick: S,
|
|
2437
|
+
isModalOpen: D,
|
|
2438
|
+
setLocalSelectedTabs: G,
|
|
2439
|
+
setIsModalOpen: q,
|
|
2440
|
+
containerRef: R
|
|
2441
|
+
} = sn({
|
|
2442
|
+
selectedTabs: u,
|
|
2443
|
+
onClickItem: W,
|
|
2444
|
+
setSelectedTabs: d,
|
|
2445
|
+
tabs: r,
|
|
2446
|
+
onChange: i,
|
|
2447
|
+
disabledOptions: e,
|
|
2448
|
+
selectedValues: n,
|
|
2449
|
+
onSaveClick: b,
|
|
2450
|
+
onClearClick: g
|
|
2451
|
+
}), te = () => /* @__PURE__ */ F(it, { children: [
|
|
2452
|
+
/* @__PURE__ */ o(
|
|
2453
|
+
"div",
|
|
2454
|
+
{
|
|
2455
|
+
className: X.closeBtn,
|
|
2456
|
+
onClick: () => {
|
|
2457
|
+
w();
|
|
2458
|
+
},
|
|
2459
|
+
children: /* @__PURE__ */ o(
|
|
2460
|
+
Se,
|
|
2461
|
+
{
|
|
2462
|
+
name: "close",
|
|
2463
|
+
size: "24"
|
|
2464
|
+
}
|
|
2465
|
+
)
|
|
2466
|
+
}
|
|
2467
|
+
),
|
|
2468
|
+
/* @__PURE__ */ o("div", { className: X.modalTitle, children: "Фильтры" }),
|
|
2469
|
+
/* @__PURE__ */ F("div", { className: X.tabSWitcherWrapper, children: [
|
|
2470
|
+
/* @__PURE__ */ o("div", { className: X.switcherTitle, children: "Готовность" }),
|
|
2471
|
+
/* @__PURE__ */ o("div", { className: X.switcherScroll, children: /* @__PURE__ */ o(
|
|
2472
|
+
Ue,
|
|
2473
|
+
{
|
|
2474
|
+
variant: "grayRow",
|
|
2475
|
+
addClassName: X.tabs,
|
|
2476
|
+
isApart: !0,
|
|
2477
|
+
children: r?.map((O, I) => {
|
|
2478
|
+
const L = O.value;
|
|
2479
|
+
return /* @__PURE__ */ o(
|
|
2480
|
+
Ue.Item,
|
|
2481
|
+
{
|
|
2482
|
+
itemsLength: r?.length,
|
|
2483
|
+
mini: !0,
|
|
2484
|
+
size_s: "small",
|
|
2485
|
+
value: L,
|
|
2486
|
+
onClick: () => {
|
|
2487
|
+
},
|
|
2488
|
+
checked: N?.find((M) => M.value === L)?.state ?? !1,
|
|
2489
|
+
onChange: () => {
|
|
2490
|
+
G?.(
|
|
2491
|
+
(M) => M.map((j) => j.value === L ? { ...j, state: !j.state } : j)
|
|
2492
|
+
);
|
|
2493
|
+
},
|
|
2494
|
+
index: I,
|
|
2495
|
+
children: L
|
|
2496
|
+
},
|
|
2497
|
+
I
|
|
2498
|
+
);
|
|
2499
|
+
})
|
|
2500
|
+
}
|
|
2501
|
+
) })
|
|
2502
|
+
] }),
|
|
2503
|
+
/* @__PURE__ */ o("div", { className: X.selectWrapper, children: t?.map((O, I) => /* @__PURE__ */ o(
|
|
2504
|
+
Ct,
|
|
2505
|
+
{
|
|
2506
|
+
sizeIcon: "24",
|
|
2507
|
+
addClassName: X.filterOption,
|
|
2508
|
+
disabledOptions: [],
|
|
2509
|
+
clickableOptions: t?.map((L) => L.value.toString()),
|
|
2510
|
+
selectedOptions: B,
|
|
2511
|
+
option: O,
|
|
2512
|
+
handleOptionClick: x
|
|
2513
|
+
},
|
|
2514
|
+
I
|
|
2515
|
+
)) }),
|
|
2516
|
+
/* @__PURE__ */ F("div", { className: X.btnWrapper, children: [
|
|
2517
|
+
/* @__PURE__ */ o(
|
|
2518
|
+
Ae,
|
|
2519
|
+
{
|
|
2520
|
+
as: "button",
|
|
2521
|
+
variant: "gray",
|
|
2522
|
+
additionalClass: X.resetBtn,
|
|
2523
|
+
onClick: P,
|
|
2524
|
+
children: "Сбросить"
|
|
2525
|
+
}
|
|
2526
|
+
),
|
|
2527
|
+
/* @__PURE__ */ o(
|
|
2528
|
+
Ae,
|
|
2529
|
+
{
|
|
2530
|
+
as: "button",
|
|
2531
|
+
additionalClass: X.saveBtn,
|
|
2532
|
+
onClick: S,
|
|
2533
|
+
children: "Сохранить"
|
|
2534
|
+
}
|
|
2535
|
+
)
|
|
2536
|
+
] })
|
|
2537
|
+
] });
|
|
2538
|
+
return /* @__PURE__ */ F(it, { children: [
|
|
2539
|
+
/* @__PURE__ */ F("div", { style: { position: "relative" }, children: [
|
|
2540
|
+
/* @__PURE__ */ F(
|
|
2541
|
+
"div",
|
|
2542
|
+
{
|
|
2543
|
+
className: X.root,
|
|
2544
|
+
"data-testid": p,
|
|
2545
|
+
onClick: () => {
|
|
2546
|
+
T && T(), l && l(), v ? q((O) => !O) : D || q(!0);
|
|
2547
|
+
},
|
|
2548
|
+
children: [
|
|
2549
|
+
/* @__PURE__ */ o("div", { className: X.btnName, children: A }),
|
|
2550
|
+
/* @__PURE__ */ o(
|
|
2551
|
+
Se,
|
|
2552
|
+
{
|
|
2553
|
+
name: "filter",
|
|
2554
|
+
size: "16"
|
|
2555
|
+
}
|
|
2556
|
+
)
|
|
2557
|
+
]
|
|
2558
|
+
}
|
|
2559
|
+
),
|
|
2560
|
+
!v && /* @__PURE__ */ F(
|
|
2561
|
+
"div",
|
|
2562
|
+
{
|
|
2563
|
+
ref: R,
|
|
2564
|
+
className: nn(X.desktopWrapper, { [X.desktopWrapperOpen]: D }),
|
|
2565
|
+
children: [
|
|
2566
|
+
/* @__PURE__ */ o(
|
|
2567
|
+
"div",
|
|
2568
|
+
{
|
|
2569
|
+
className: X.closeBtn,
|
|
2570
|
+
onClick: () => {
|
|
2571
|
+
w();
|
|
2572
|
+
},
|
|
2573
|
+
children: /* @__PURE__ */ o(
|
|
2574
|
+
Se,
|
|
2575
|
+
{
|
|
2576
|
+
name: "close",
|
|
2577
|
+
size: "24"
|
|
2578
|
+
}
|
|
2579
|
+
)
|
|
2580
|
+
}
|
|
2581
|
+
),
|
|
2582
|
+
/* @__PURE__ */ o("div", { className: X.modalTitle, children: "Фильтры" }),
|
|
2583
|
+
/* @__PURE__ */ F("div", { className: X.tabSWitcherWrapper, children: [
|
|
2584
|
+
/* @__PURE__ */ o("div", { className: X.switcherTitle, children: "Готовность" }),
|
|
2585
|
+
/* @__PURE__ */ o("div", { className: X.switcherScroll, children: /* @__PURE__ */ o(
|
|
2586
|
+
Ue,
|
|
2587
|
+
{
|
|
2588
|
+
variant: "grayRow",
|
|
2589
|
+
addClassName: X.tabs,
|
|
2590
|
+
isApart: !0,
|
|
2591
|
+
children: r?.map((O, I) => {
|
|
2592
|
+
const L = O.value;
|
|
2593
|
+
return /* @__PURE__ */ o(
|
|
2594
|
+
Ue.Item,
|
|
2595
|
+
{
|
|
2596
|
+
itemsLength: r?.length,
|
|
2597
|
+
dataTestId: `filterWithSave_year_${L}_tab`,
|
|
2598
|
+
size_s: "small",
|
|
2599
|
+
mini: !0,
|
|
2600
|
+
value: L,
|
|
2601
|
+
onClick: () => V(),
|
|
2602
|
+
checked: N?.find((M) => M.value === L)?.state ?? !1,
|
|
2603
|
+
onChange: () => {
|
|
2604
|
+
G?.(
|
|
2605
|
+
(M) => M.map((j) => j.value === L ? { ...j, state: !j.state } : j)
|
|
2606
|
+
);
|
|
2607
|
+
},
|
|
2608
|
+
index: I,
|
|
2609
|
+
addItemClassName: X.tabSwitcher,
|
|
2610
|
+
children: L
|
|
2611
|
+
},
|
|
2612
|
+
I
|
|
2613
|
+
);
|
|
2614
|
+
})
|
|
2615
|
+
}
|
|
2616
|
+
) })
|
|
2617
|
+
] }),
|
|
2618
|
+
/* @__PURE__ */ o("div", { className: X.selectWrapper, children: t?.map((O, I) => /* @__PURE__ */ o(
|
|
2619
|
+
Ct,
|
|
2620
|
+
{
|
|
2621
|
+
sizeIcon: "24",
|
|
2622
|
+
dataTestId: `filterWIthSave_${I}_select`,
|
|
2623
|
+
addClassName: X.filterOption,
|
|
2624
|
+
disabledOptions: [],
|
|
2625
|
+
clickableOptions: t?.map((L) => L.value.toString()),
|
|
2626
|
+
selectedOptions: B,
|
|
2627
|
+
option: O,
|
|
2628
|
+
handleOptionClick: x
|
|
2629
|
+
},
|
|
2630
|
+
I
|
|
2631
|
+
)) }),
|
|
2632
|
+
/* @__PURE__ */ F("div", { className: X.btnWrapper, children: [
|
|
2633
|
+
/* @__PURE__ */ o(
|
|
2634
|
+
Ae,
|
|
2635
|
+
{
|
|
2636
|
+
"data-testid": "filterWithSave_clear_btn",
|
|
2637
|
+
as: "button",
|
|
2638
|
+
variant: "gray",
|
|
2639
|
+
additionalClass: X.resetBtn,
|
|
2640
|
+
onClick: P,
|
|
2641
|
+
children: "Сбросить"
|
|
2642
|
+
}
|
|
2643
|
+
),
|
|
2644
|
+
/* @__PURE__ */ o(
|
|
2645
|
+
Ae,
|
|
2646
|
+
{
|
|
2647
|
+
"data-testid": "filterWithSave_save_btn",
|
|
2648
|
+
as: "button",
|
|
2649
|
+
additionalClass: X.saveBtn,
|
|
2650
|
+
onClick: S,
|
|
2651
|
+
children: "Сохранить"
|
|
2652
|
+
}
|
|
2653
|
+
)
|
|
2654
|
+
] })
|
|
2655
|
+
]
|
|
2656
|
+
}
|
|
2657
|
+
)
|
|
2658
|
+
] }),
|
|
2659
|
+
v && /* @__PURE__ */ o(
|
|
2660
|
+
ot,
|
|
2661
|
+
{
|
|
2662
|
+
isOpen: D,
|
|
2663
|
+
emitIsOpen: q,
|
|
2664
|
+
isTransparentBack: !0,
|
|
2665
|
+
additionalClassModalBody: X.modalAddBody,
|
|
2666
|
+
additionalClass: X.filterWithSaveModal,
|
|
2667
|
+
children: /* @__PURE__ */ o(te, {})
|
|
2668
|
+
}
|
|
2669
|
+
)
|
|
2670
|
+
] });
|
|
2671
|
+
};
|
|
2672
|
+
export {
|
|
2673
|
+
Yn as C,
|
|
2674
|
+
Kn as F,
|
|
2675
|
+
Hn as L,
|
|
2676
|
+
Jn as M,
|
|
2677
|
+
di as P,
|
|
2678
|
+
As as S,
|
|
2679
|
+
Ue as T,
|
|
2680
|
+
Fi as a,
|
|
2681
|
+
sn as b,
|
|
2682
|
+
ks as u
|
|
2683
|
+
};
|