@studio-west/component-sw 0.5.69 → 0.5.71
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/dist/{SwDatePicker-CROaF64N.js → SwDatePicker-6Nx2U5RP.js} +1 -1
- package/dist/SwDropdown-CEyfIHM9.js +113 -0
- package/dist/{SwInput-DcKrmAmX.js → SwInput-BNY5PJgJ.js} +1 -1
- package/dist/{index-Cz1ZzITu.js → index-CY59LKKI.js} +7 -7
- package/dist/index.cjs +1 -1
- package/dist/index.js +1 -1
- package/package.json +1 -1
- package/dist/SwDropdown-CIiqbk4D.js +0 -113
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ref as D, computed as le, createElementBlock as v, openBlock as i, createElementVNode as r, createCommentVNode as N, withModifiers as c, renderSlot as M, createTextVNode as $, toDisplayString as k, unref as F, Fragment as T, renderList as E, normalizeClass as V } from "vue";
|
|
2
|
-
import { p as I } from "./index-
|
|
2
|
+
import { p as I } from "./index-CY59LKKI.js";
|
|
3
3
|
const ne = { class: "sw-data-picker" }, se = { class: "month_year" }, oe = { class: "text" }, ue = {
|
|
4
4
|
key: 0,
|
|
5
5
|
class: "week"
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { mergeModels as O, useModel as B, ref as f, computed as V, watchEffect as N, onMounted as P, onUnmounted as D, createElementBlock as $, openBlock as g, withModifiers as y, normalizeClass as z, renderSlot as M, createBlock as U, Teleport as X, createCommentVNode as Y, normalizeStyle as j, unref as q } from "vue";
|
|
2
|
+
const A = ["id"], G = {
|
|
3
|
+
__name: "SwDropdown",
|
|
4
|
+
props: /* @__PURE__ */ O({
|
|
5
|
+
class: { type: String, default: "" },
|
|
6
|
+
size: { type: String, default: "" },
|
|
7
|
+
type: { type: String, default: "" },
|
|
8
|
+
trigger: { type: String, default: "click" },
|
|
9
|
+
placement: { type: String, default: "bottom-left" },
|
|
10
|
+
maxWidth: { type: Number, default: 0 }
|
|
11
|
+
}, {
|
|
12
|
+
modelValue: {},
|
|
13
|
+
modelModifiers: {}
|
|
14
|
+
}),
|
|
15
|
+
emits: ["update:modelValue"],
|
|
16
|
+
setup(b, { expose: S }) {
|
|
17
|
+
const i = b, s = B(b, "modelValue"), c = f(null), p = f(null), v = f({}), E = Math.ceil(Math.random() * 1e3), k = f(0), C = V(
|
|
18
|
+
() => {
|
|
19
|
+
let n = ["sw-dropdown"];
|
|
20
|
+
return i.size.length > 0 && n.push("sw-" + i.size), i.type.length > 0 && n.push("sw-" + i.type), n;
|
|
21
|
+
}
|
|
22
|
+
), x = new ResizeObserver((n) => {
|
|
23
|
+
s.value && k.value++;
|
|
24
|
+
});
|
|
25
|
+
N(
|
|
26
|
+
() => {
|
|
27
|
+
if (!s.value || !p.value || !c.value) {
|
|
28
|
+
v.value = {};
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
x.observe(p.value);
|
|
32
|
+
let n = window.pageYOffset || document.documentElement.scrollTop, l = window.pageXOffset || document.documentElement.scrollLeft;
|
|
33
|
+
document.body.style.position = "fixed", document.body.style.top = `-${n}px`, document.body.style.left = `-${l}px`, document.body.style.position = "", document.body.style.top = "", document.body.style.left = "", document.documentElement.scrollTop = n, document.documentElement.scrollLeft = l;
|
|
34
|
+
const e = c.value.getBoundingClientRect();
|
|
35
|
+
let w = window.innerWidth, h = window.innerHeight, d = p.value.offsetHeight, u = p.value.offsetWidth, t = e.left + e.width / 2 + l, o = e.top + e.height / 2 + n, a = e.height / 2 + 8;
|
|
36
|
+
const [T, H] = i.placement.split("-", 2);
|
|
37
|
+
switch (T) {
|
|
38
|
+
case "bottom":
|
|
39
|
+
o = n + h - d - a - 8 < o ? o - a - d : o + a;
|
|
40
|
+
break;
|
|
41
|
+
case "top":
|
|
42
|
+
o = n + d + a + 8 > o ? o + a : o - a - d;
|
|
43
|
+
break;
|
|
44
|
+
case "left":
|
|
45
|
+
t = t - u - e.width / 2 - 8, o = o - d / 2;
|
|
46
|
+
break;
|
|
47
|
+
case "right":
|
|
48
|
+
t = t + e.width / 2 + 8, o = o - d / 2;
|
|
49
|
+
break;
|
|
50
|
+
}
|
|
51
|
+
switch (H) {
|
|
52
|
+
case "left":
|
|
53
|
+
t = l + w - 8 > t - e.width / 2 + u ? t - e.width / 2 : t - u + e.width / 2;
|
|
54
|
+
break;
|
|
55
|
+
case "right":
|
|
56
|
+
t = 8 < t + e.width / 2 - u ? t - u + e.width / 2 : t - e.width / 2;
|
|
57
|
+
break;
|
|
58
|
+
}
|
|
59
|
+
t + u > w && (t = w - u), t < 0 && (t = 0), o + d > h && (o = h - d), o < 0 && (o = 0), v.value = {
|
|
60
|
+
position: "absolute",
|
|
61
|
+
top: `${o}px`,
|
|
62
|
+
left: `${t}px`,
|
|
63
|
+
maxWidth: i.maxWidth === 0 ? "" : `${i.maxWidth}px`
|
|
64
|
+
};
|
|
65
|
+
},
|
|
66
|
+
{ flush: "post" }
|
|
67
|
+
);
|
|
68
|
+
const R = () => {
|
|
69
|
+
i.trigger === "click" && (s.value = !s.value);
|
|
70
|
+
}, L = () => {
|
|
71
|
+
i.trigger === "hover" && (s.value = !s.value);
|
|
72
|
+
}, W = () => {
|
|
73
|
+
i.trigger === "context" && (s.value = !s.value);
|
|
74
|
+
}, r = () => {
|
|
75
|
+
s.value && k.value++;
|
|
76
|
+
};
|
|
77
|
+
S({ handleResize: r });
|
|
78
|
+
const m = (n) => {
|
|
79
|
+
!n.target.closest(`[id="${E}"]`) && c.value && !c.value.contains(n.target) && (s.value = !1);
|
|
80
|
+
};
|
|
81
|
+
return P(() => {
|
|
82
|
+
window.addEventListener("resize", r), document.documentElement.ontouchstart !== void 0 ? document.documentElement.addEventListener("touchstart", m) : document.documentElement.addEventListener("click", m), window.onscrollend !== void 0 ? window.addEventListener("scrollend", r) : window.addEventListener("scroll", r);
|
|
83
|
+
}), D(() => {
|
|
84
|
+
x.disconnect(), window.removeEventListener("resize", r), document.documentElement.ontouchstart !== void 0 ? document.documentElement.removeEventListener("touchstart", m) : document.documentElement.removeEventListener("click", m), window.onscrollend !== void 0 ? window.removeEventListener("scrollend", r) : window.removeEventListener("scroll", r);
|
|
85
|
+
}), (n, l) => (g(), $("div", {
|
|
86
|
+
class: z(C.value),
|
|
87
|
+
onClick: l[0] || (l[0] = (e) => R()),
|
|
88
|
+
onMouseover: l[1] || (l[1] = y((e) => L(), ["stop"])),
|
|
89
|
+
onMouseleave: l[2] || (l[2] = y((e) => L(), ["stop"])),
|
|
90
|
+
onContextmenu: l[3] || (l[3] = y((e) => W(), ["stop"])),
|
|
91
|
+
ref_key: "dropdownRef",
|
|
92
|
+
ref: c
|
|
93
|
+
}, [
|
|
94
|
+
M(n.$slots, "default"),
|
|
95
|
+
(g(), U(X, { to: "body" }, [
|
|
96
|
+
s.value ? (g(), $("ul", {
|
|
97
|
+
key: 0,
|
|
98
|
+
ref_key: "popupRef",
|
|
99
|
+
ref: p,
|
|
100
|
+
id: q(E),
|
|
101
|
+
class: z(["sw-dropdown-popup", i.class]),
|
|
102
|
+
style: j(v.value),
|
|
103
|
+
tabindex: "-1"
|
|
104
|
+
}, [
|
|
105
|
+
M(n.$slots, "dropdown")
|
|
106
|
+
], 14, A)) : Y("", !0)
|
|
107
|
+
]))
|
|
108
|
+
], 34));
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
export {
|
|
112
|
+
G as default
|
|
113
|
+
};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { mergeModels as y, useModel as D, ref as V, computed as C, watch as I, createElementBlock as d, openBlock as u, normalizeClass as M, createBlock as v, renderSlot as _, createCommentVNode as x, withDirectives as A, createTextVNode as E, toDisplayString as R, createElementVNode as T, vModelDynamic as F } from "vue";
|
|
2
|
-
import { S } from "./index-
|
|
2
|
+
import { S } from "./index-CY59LKKI.js";
|
|
3
3
|
const O = ["for"], U = {
|
|
4
4
|
key: 0,
|
|
5
5
|
title: "Это поле обязательно для заполнения."
|
|
@@ -65,7 +65,7 @@ function G(e, n, t, o, s, r) {
|
|
|
65
65
|
}, null, 8, Y)
|
|
66
66
|
], 16));
|
|
67
67
|
}
|
|
68
|
-
const v = /* @__PURE__ */ B(H, [["render", G]]),
|
|
68
|
+
const v = /* @__PURE__ */ B(H, [["render", G]]), h = {
|
|
69
69
|
__name: "SwAlert",
|
|
70
70
|
props: {
|
|
71
71
|
message: { type: String, default: "Default message" },
|
|
@@ -127,14 +127,14 @@ const v = /* @__PURE__ */ B(H, [["render", G]]), y = {
|
|
|
127
127
|
}
|
|
128
128
|
}, U = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
129
129
|
__proto__: null,
|
|
130
|
-
default:
|
|
130
|
+
default: h
|
|
131
131
|
}, Symbol.toStringTag, { value: "Module" }));
|
|
132
132
|
let l = document.querySelector("div.sw-alert-wrapper");
|
|
133
133
|
function w(e = {}) {
|
|
134
134
|
l || (l = document.createElement("div"), l.className = "sw-alert-wrapper", document.body.appendChild(l));
|
|
135
135
|
const n = j({
|
|
136
136
|
setup() {
|
|
137
|
-
return () => O(
|
|
137
|
+
return () => O(h, {
|
|
138
138
|
...e,
|
|
139
139
|
onClose: () => {
|
|
140
140
|
l.removeChild(n._container), n.unmount();
|
|
@@ -144,15 +144,15 @@ function w(e = {}) {
|
|
|
144
144
|
}), t = n.mount(document.createElement("div"));
|
|
145
145
|
l.appendChild(t.$el);
|
|
146
146
|
}
|
|
147
|
-
const
|
|
148
|
-
for (const e in
|
|
147
|
+
const y = /* @__PURE__ */ Object.assign({ "./components/SwAlert.vue": () => Promise.resolve().then(() => U), "./components/SwButton.vue": () => import("./SwButton-85-tKHA7.js"), "./components/SwCollapse.vue": () => import("./SwCollapse-CuN3EbT6.js"), "./components/SwDatePicker.vue": () => import("./SwDatePicker-6Nx2U5RP.js"), "./components/SwDropdown.vue": () => import("./SwDropdown-CEyfIHM9.js"), "./components/SwDropdownItem.vue": () => import("./SwDropdownItem-wFMHwJJk.js"), "./components/SwFormItem.vue": () => import("./SwFormItem-CaA4jsoa.js"), "./components/SwInput.vue": () => import("./SwInput-BNY5PJgJ.js"), "./components/SwMessage.vue": () => import("./SwMessage-DgnLjLHt.js"), "./components/SwSection.vue": () => import("./SwSection-CQfw3-el.js"), "./components/SwSelect.vue": () => import("./SwSelect-C2RKinez.js"), "./components/SwSkeleton.vue": () => import("./SwSkeleton-B7ysp8L9.js"), "./components/SwSkeletonItem.vue": () => import("./SwSkeletonItem-CU7LvihY.js"), "./components/SwSwitch.vue": () => import("./SwSwitch-FMwJbEH7.js"), "./components/SwTabs.vue": () => import("./SwTabs-DkSI4oAh.js"), "./components/SwTabsPane.vue": () => import("./SwTabsPane-Dwtj8g7T.js") }), d = {};
|
|
148
|
+
for (const e in y) {
|
|
149
149
|
const n = e.split("/").pop().replace(".vue", "").replace(/-(\w)/g, (t, o) => o.toUpperCase());
|
|
150
|
-
d[n] = P(() =>
|
|
150
|
+
d[n] = P(() => y[e]());
|
|
151
151
|
}
|
|
152
152
|
const R = {
|
|
153
153
|
install(e) {
|
|
154
154
|
Object.keys(d).forEach((n) => {
|
|
155
|
-
e.component(n, d[n])
|
|
155
|
+
e.component(n, d[n]);
|
|
156
156
|
}), e.config.globalProperties.$Alert = w, e.provide("Alert", w);
|
|
157
157
|
}
|
|
158
158
|
};
|
package/dist/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(v,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(v=typeof globalThis<"u"?globalThis:v||self,e(v["component-sw"]={},v.vue))})(this,function(v,e){"use strict";function ee(s){return/^(https?:|mailto:|tel:)/.test(s)}function P(s,o){if(arguments.length===0||!s)return null;const t=o||"{Y}-{m}-{d} {G}:{i}:{s}";let l;typeof s=="object"?l=s:(typeof s=="string"&&(/^[0-9]+$/.test(s)?s=parseInt(s):s=s.replace(new RegExp(/-/gm),"/")),typeof s=="number"&&s.toString().length===10&&(s=s*1e3),l=new Date(s));const n="ru-RU",d={Y:l.getFullYear(),m:(l.getMonth()+1).toString().padStart(2,"0"),d:l.getDate(),dd:l.getDate().toString().padStart(2,"0"),G:l.getHours(),H:l.getHours().toString().padStart(2,"0"),i:l.getMinutes().toString().padStart(2,"0"),s:l.getSeconds().toString().padStart(2,"0"),D:new Intl.DateTimeFormat(n,{weekday:"short"}).format(l),F:new Intl.DateTimeFormat(n,{month:"long"}).format(l),M:new Intl.DateTimeFormat(n,{month:"short"}).format(l)};return t.replace(/{(dd|[YmdGHisDFM])+}/g,(u,p)=>d[p])}const te=(s,o)=>{const t=s.__vccOpts||s;for(const[l,n]of o)t[l]=n;return t},le={name:"SvgIcon",props:{prefix:{type:String,default:"icon"},iconClass:{type:String,required:!0},className:{type:String,default:""}},computed:{isExt(){return ee(this.iconClass)}}},oe=["href"];function ne(s,o,t,l,n,d){return d.isExt?(e.openBlock(),e.createElementBlock("div",e.mergeProps({key:0,style:"mask: url("+t.iconClass+") no-repeat 50% 50%;",class:"svg-external-icon svg-icon"},s.$attrs),null,16)):(e.openBlock(),e.createElementBlock("svg",e.mergeProps({key:1,class:"svg-icon "+t.className,"aria-hidden":"true"},s.$attrs),[e.createElementVNode("use",{href:"#"+t.prefix+"-"+t.iconClass},null,8,oe)],16))}const L=te(le,[["render",ne]]),U={__name:"SwAlert",props:{message:{type:String,default:"Default message"},before:{type:String,default:""},class:{type:String,default:""},after:{type:String,default:""},size:{type:String,default:""},duration:{type:Number,default:6e3},type:{type:String,default:"info",validator:s=>["success","warning","error","info"].includes(s)}},emits:["closed"],setup(s,{emit:o}){const t=s,l=o,n=e.ref(!1);let d=null;const u=()=>{n.value=!0,D()},p=()=>{n.value=!1,l("closed")},c=()=>{d&&(clearTimeout(d),d=null)},g=()=>{D()},D=()=>{d=setTimeout(p,t.duration)};e.onMounted(()=>{u()}),e.onUnmounted(()=>{d&&clearTimeout(d)});const E=e.computed(()=>{const m=["sw-alert"];return t.size.length>0&&m.push(`sw-${t.size}`),t.type.length>0&&m.push(`sw-${t.type}`),t.class.length>0&&m.push(t.class),m});return(m,w)=>(e.openBlock(),e.createBlock(e.Transition,{name:"fade"},{default:e.withCtx(()=>[n.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(E.value),onMouseenter:c,onMouseleave:g},[t.before.length>0?(e.openBlock(),e.createBlock(L,{key:0,"icon-class":t.before},null,8,["icon-class"])):e.renderSlot(m.$slots,"prefix",{key:1}),e.renderSlot(m.$slots,"default",{},()=>[e.createTextVNode(e.toDisplayString(t.message),1)]),t.after.length>0?(e.openBlock(),e.createBlock(L,{key:2,"icon-class":t.after,onClick:p},null,8,["icon-class"])):e.renderSlot(m.$slots,"suffix",{key:3})],34)):e.createCommentVNode("",!0)]),_:3}))}},ae=Object.freeze(Object.defineProperty({__proto__:null,default:U},Symbol.toStringTag,{value:"Module"}));let F=document.querySelector("div.sw-alert-wrapper");function R(s={}){F||(F=document.createElement("div"),F.className="sw-alert-wrapper",document.body.appendChild(F));const o=e.createApp({setup(){return()=>e.h(U,{...s,onClose:()=>{F.removeChild(o._container),o.unmount()}})}}),t=o.mount(document.createElement("div"));F.appendChild(t.$el)}const W=Object.assign({"./components/SwAlert.vue":()=>Promise.resolve().then(()=>ae),"./components/SwButton.vue":()=>Promise.resolve().then(()=>re),"./components/SwCollapse.vue":()=>Promise.resolve().then(()=>ie),"./components/SwDatePicker.vue":()=>Promise.resolve().then(()=>$e),"./components/SwDropdown.vue":()=>Promise.resolve().then(()=>Me),"./components/SwDropdownItem.vue":()=>Promise.resolve().then(()=>Ce),"./components/SwFormItem.vue":()=>Promise.resolve().then(()=>Te),"./components/SwInput.vue":()=>Promise.resolve().then(()=>xe),"./components/SwMessage.vue":()=>Promise.resolve().then(()=>je),"./components/SwSection.vue":()=>Promise.resolve().then(()=>Oe),"./components/SwSelect.vue":()=>Promise.resolve().then(()=>Ae),"./components/SwSkeleton.vue":()=>Promise.resolve().then(()=>He),"./components/SwSkeletonItem.vue":()=>Promise.resolve().then(()=>Re),"./components/SwSwitch.vue":()=>Promise.resolve().then(()=>We),"./components/SwTabs.vue":()=>Promise.resolve().then(()=>Je),"./components/SwTabsPane.vue":()=>Promise.resolve().then(()=>Ze)}),A={};for(const s in W){const o=s.split("/").pop().replace(".vue","").replace(/-(\w)/g,(t,l)=>l.toUpperCase());A[o]=e.defineAsyncComponent(()=>W[s]())}const se={install(s){Object.keys(A).forEach(o=>{s.component(o,A[o]),console.log(o)}),s.config.globalProperties.$Alert=R,s.provide("Alert",R)}},G={__name:"SwButton",props:{class:{type:String,default:""},size:{type:String,default:""},type:{type:String,default:""},round:{type:Boolean,default:!1},text:{type:Boolean,default:!1},link:{type:Boolean,default:!1},href:{type:String,default:""}},setup(s){const o=s,t=()=>{if(o.href.length>0){const n=document.createElement("a");n.setAttribute("href",o.href),n.setAttribute("target","_blank"),n.click()}},l=e.computed(()=>{let n=["sw-button"];return o.size.length>0&&n.push("sw-"+o.size),o.type.length>0&&n.push("sw-"+o.type),o.round&&n.push("sw-round"),o.text&&n.push("sw-text"),o.link&&n.push("sw-link"),o.class.length>0&&n.push(o.class),n});return(n,d)=>(e.openBlock(),e.createElementBlock("button",{class:e.normalizeClass(l.value),onClick:t},[e.renderSlot(n.$slots,"default")],2))}},re=Object.freeze(Object.defineProperty({__proto__:null,default:G},Symbol.toStringTag,{value:"Module"})),ie=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwCollapse",props:{visual:{type:Boolean,default:!0}},setup(s){e.onMounted(()=>{l.value="0px"});const o=e.ref(null),t=s;e.watch(()=>t.visual,()=>n());const l=e.ref("0px"),n=()=>{o.value&&(l.value=t.visual?o.value.scrollHeight+"px":"0px")};let d;return e.onMounted(()=>{n(),o.value&&(d=new ResizeObserver(n),d.observe(o.value))}),e.onBeforeUnmount(()=>{d&&d.disconnect()}),(u,p)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["sw-collapse",{open:t.visual}]),style:e.normalizeStyle({maxHeight:l.value}),ref_key:"collapse",ref:o},[e.renderSlot(u.$slots,"default")],6))}}},Symbol.toStringTag,{value:"Module"})),ce={class:"sw-data-picker"},de={class:"month_year"},pe={class:"text"},me={key:0,class:"week"},fe={key:1,class:"year"},ue=["onClick"],ge={key:2,class:"month"},he=["onClick"],ye={key:0},we={class:"month_year"},Se={class:"text"},ke={key:0,class:"week"},_e={key:1,class:"year"},be=["onClick"],Be={key:2,class:"month"},Ee=["onClick"],$e=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwDatePicker",props:{data:Object,limitation:{type:[Boolean,Array],default:()=>!1},range:{type:String,default:"solid"}},emits:["input"],setup(s,{emit:o}){var J,Q,Z,K;const t=s,l=o,n=e.ref(3),d=e.ref(new Date),u=e.ref(new Date),p=e.ref(new Date().getFullYear()),c=e.ref(new Date().getMonth()),g=e.ref(new Date().getFullYear()),D=e.ref(new Date().getMonth()),E=e.ref(new Date(p.value,c.value+1,1).getMonth()),m=e.ref([]),w=e.ref(0),h=e.ref(-1),S=e.ref(-1),k=e.ref(navigator.language||"ru"),y=/en|zh|ja|he/.test(k.value)?0:1,_=e.computed(()=>Array.from({length:12},(r,a)=>{const i=new Date(2024,a);return new Intl.DateTimeFormat(k.value,{month:"long"}).format(i)})),M=r=>{let a=r.split(r.match(/\D.*?\D?/));return a[0].length>2?a.join("-")+"T00:00:01":a.reverse().join("-")+"T00:00:01"};(J=t.data)!=null&&J.startDate&&(d.value=new Date(M(t.data.startDate)),p.value=d.value.getFullYear(),c.value=d.value.getMonth()),(Q=t.data)!=null&&Q.endDate&&t.range==="range"&&(u.value=new Date(M(t.data.endDate)),g.value=u.value.getFullYear(),D.value=u.value.getMonth());const T=()=>{m.value=[],w.value=0;const r=new Date(p.value,c.value,0);for(let i=r.getDate()-r.getDay()+y;i<=r.getDate();i++)r.getDay()!==6+y&&(m.value.push({day:i,month:r.getMonth(),year:r.getFullYear(),class:[]}),w.value++);const a=new Date(p.value,c.value+1,0).getDate();for(let i=1;i<=a;i++)m.value.push({day:i,month:c.value,year:p.value,class:[]}),w.value++;if(t.range==="range"){const i=new Date(p.value,c.value+1,1),f=new Date(p.value,c.value+2,0).getDate();for(let $=1;$<=f;$++)m.value.push({day:$,month:i.getMonth(),year:i.getFullYear(),class:[]})}C()},C=()=>{var a;if(!((a=t.data)!=null&&a.holiday))return;const r=(i,f)=>{i.forEach($=>{const[x,z,j]=$.split("-").map(Number),I=m.value.findIndex(q=>q.year===x&&q.month+1===z&&q.day===j);I!==-1&&(m.value[I].class[0]=f)})};r(t.data.holiday.preholidays,"preholiday"),r(t.data.holiday.holidays,"weekend"),r(t.data.holiday.holiday,"holiday"),r(t.data.holiday.nowork,"nowork")},V=()=>{if(!t.limitation||t.limitation.length<2)return!1;const r=[...t.limitation].sort((a,i)=>new Date(M(a.startDate)).getTime()-new Date(M(i.startDate)).getTime());for(let a=1;a<r.length;a++){const i=new Date(M(r[a-1].endDate));if(new Date(M(r[a].startDate))<=i)return console.warn("Warning: Диапазоны пересекаются:",r[a-1],r[a]),!0}return!1},b=(r,a,i)=>{if(!t.limitation||t.limitation.length===0)return!0;const f=new Date(r,a,i).getTime();for(let $ of t.limitation){const{startDate:x,endDate:z}=$;if(!x&&z){const j=new Date(M(z)).getTime();if(f<=j)return!1}if(x&&!z){const j=new Date(M(x)).getTime();if(f>=j)return!1}if(x&&z){const j=new Date(M(x)).getTime(),I=new Date(M(z)).getTime();if(j<=I){if(f>=j&&f<=I)return!1}else if(f>=j||f<=I)return!1}}return!0},B=(r,a)=>{const i=P(new Date(r.year,r.month,r.day),"{dd}.{m}.{Y}");t.range==="range"?S.value!==-1?(O(),h.value=a,m.value[a].class[1]="active"):h.value!==-1?(S.value=a,H(h.value,S.value,i)):(h.value=a,m.value[a].class[1]="active"):(h.value!==-1&&(m.value[h.value].class[1]=""),h.value=a,m.value[a].class[1]="active",l("input",{dateStart:i,count:1}))},O=()=>{m.value.forEach(r=>r.class[1]=""),h.value=-1,S.value=-1},H=(r,a,i)=>{let f=P(new Date(m.value[r].year,m.value[r].month,m.value[r].day),"{dd}.{m}.{Y}");if(a>=r){for(let $=r+1;$<a;$++)m.value[$].class[1]="select";l("input",{dateStart:f,dateEnd:i,count:Y(r,a)})}else{for(let $=a+1;$<r;$++)m.value[$].class[1]="select";l("input",{dateStart:i,dateEnd:f,count:Y(a,r)})}m.value[a].class[1]="active"},Y=(r,a)=>{var x;let i=Math.abs(r-a)+1,[f,$]=[Math.min(r,a),Math.max(r,a)];for(let z=f;z<=$;z++)((x=m.value[z])==null?void 0:x.class[0])==="holiday"&&i--;return i},N=(r,a)=>{b(r,a)&&(d.value=new Date(r,a,1),p.value=d.value.getFullYear(),c.value=d.value.getMonth(),E.value=new Date(r,a+1,1).getMonth(),t.range==="year"&&n.value===0?B({year:r,month:a,day:1},8):T())};if(T(),V(),(Z=t.data)!=null&&Z.startDate&&(h.value=m.value.findIndex(r=>r.day===d.value.getDate()&&r.month===c.value&&r.year===p.value),h.value!==-1&&(m.value[h.value].class[1]="active")),(K=t.data)!=null&&K.endDate&&t.range==="range"&&(S.value=m.value.findIndex(r=>r.day===u.value.getDate()&&r.month===D.value&&r.year===g.value),S.value!==-1)){m.value[S.value].class[1]="active";for(let r=h.value+1;r<S.value;r++)m.value[r].class[1]="select"}return(r,a)=>(e.openBlock(),e.createElementBlock("div",ce,[e.createElementVNode("div",null,[e.createElementVNode("p",de,[e.createElementVNode("span",null,[e.createElementVNode("button",{onClick:a[0]||(a[0]=e.withModifiers(i=>N(p.value-1,c.value),["prevent"]))},[e.renderSlot(r.$slots,"double-arrow",{},()=>[a[12]||(a[12]=e.createTextVNode("«"))])]),e.createElementVNode("button",{onClick:a[1]||(a[1]=e.withModifiers(i=>{n.value=0,N(p.value,c.value-1)},["prevent"]))},[e.renderSlot(r.$slots,"arrow",{},()=>[a[13]||(a[13]=e.createTextVNode("‹"))])])]),e.createElementVNode("span",pe,[e.createElementVNode("button",{onClick:a[2]||(a[2]=e.withModifiers(i=>n.value=1,["prevent"]))},e.toDisplayString(p.value),1),e.createElementVNode("button",{onClick:a[3]||(a[3]=e.withModifiers(i=>n.value=1,["prevent"]))},e.toDisplayString(e.unref(P)(d.value.setMonth(c.value),"{F}")),1)]),e.createElementVNode("span",null,[e.createElementVNode("button",{class:"sw-revers",onClick:a[4]||(a[4]=e.withModifiers(i=>{n.value=0,N(p.value,c.value+1)},["prevent"]))},[e.renderSlot(r.$slots,"arrow",{},()=>[a[14]||(a[14]=e.createTextVNode("‹"))])]),e.createElementVNode("button",{class:"sw-revers",onClick:a[5]||(a[5]=e.withModifiers(i=>N(p.value+1,c.value),["prevent"]))},[e.renderSlot(r.$slots,"double-arrow",{},()=>[a[15]||(a[15]=e.createTextVNode("«"))])])])]),t.range==="year"||n.value===1?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",me,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(7,(i,f)=>e.createElementVNode("button",{key:f,class:"disabled"},e.toDisplayString(e.unref(P)(new Date(1970,1,i+e.unref(y)),"{D}")),1)),64))])),t.range==="year"||n.value===1?(e.openBlock(),e.createElementBlock("div",fe,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(_.value,(i,f)=>(e.openBlock(),e.createElementBlock("button",{key:f,onClick:e.withModifiers($=>{n.value=0,N(p.value,f)},["prevent"]),class:e.normalizeClass(f===c.value?"active":"")},e.toDisplayString(i),11,ue))),128))])):(e.openBlock(),e.createElementBlock("div",ge,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,(i,f)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:f},[f<w.value+(7-new Date(p.value,c.value+1,1).getDay()+e.unref(y))%7?(e.openBlock(),e.createElementBlock("button",{key:0,class:e.normalizeClass(i.month===c.value&&b(i.year,i.month,i.day)?i.class:"disabled"),onClick:e.withModifiers(()=>{i.month===c.value&&B(i,f)},["prevent"])},e.toDisplayString(i.day),11,he)):e.createCommentVNode("",!0)],64))),128))]))]),t.range==="range"?(e.openBlock(),e.createElementBlock("div",ye,[e.createElementVNode("p",we,[e.createElementVNode("span",null,[e.createElementVNode("button",{onClick:a[6]||(a[6]=e.withModifiers(i=>N(p.value-1,c.value),["prevent"]))},[e.renderSlot(r.$slots,"double-arrow",{},()=>[a[16]||(a[16]=e.createTextVNode("«"))])]),e.createElementVNode("button",{onClick:a[7]||(a[7]=e.withModifiers(i=>{n.value=0,N(p.value,c.value-1)},["prevent"]))},[e.renderSlot(r.$slots,"arrow",{},()=>[a[17]||(a[17]=e.createTextVNode("‹"))])])]),e.createElementVNode("span",Se,[e.createElementVNode("button",{onClick:a[8]||(a[8]=e.withModifiers(i=>n.value=2,["prevent"]))},e.toDisplayString(new Date(p.value,c.value+1).getFullYear()),1),e.createElementVNode("button",{onClick:a[9]||(a[9]=e.withModifiers(i=>n.value=2,["prevent"]))},e.toDisplayString(e.unref(P)(d.value.setMonth(c.value+1),"{F}")),1)]),e.createElementVNode("span",null,[e.createElementVNode("button",{class:"sw-revers",onClick:a[10]||(a[10]=e.withModifiers(i=>{n.value=0,N(p.value,c.value+1)},["prevent"]))},[e.renderSlot(r.$slots,"arrow",{},()=>[a[18]||(a[18]=e.createTextVNode("‹"))])]),e.createElementVNode("button",{class:"sw-revers",onClick:a[11]||(a[11]=e.withModifiers(i=>N(p.value+1,c.value),["prevent"]))},[e.renderSlot(r.$slots,"double-arrow",{},()=>[a[19]||(a[19]=e.createTextVNode("«"))])])])]),n.value!==2?(e.openBlock(),e.createElementBlock("div",ke,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(7,(i,f)=>e.createElementVNode("button",{key:f,class:"disabled"},e.toDisplayString(e.unref(P)(new Date(1970,1,i+e.unref(y)),"{D}")),1)),64))])):e.createCommentVNode("",!0),n.value===2?(e.openBlock(),e.createElementBlock("div",_e,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(_.value,(i,f)=>(e.openBlock(),e.createElementBlock("button",{key:f,onClick:e.withModifiers($=>{n.value=0,N(p.value,f-1)},["prevent"]),class:e.normalizeClass(f===(c.value+1)%12?"active":"")},e.toDisplayString(i),11,be))),128))])):(e.openBlock(),e.createElementBlock("div",Be,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,(i,f)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:f},[f>=w.value-(7+new Date(p.value,c.value+1,1).getDay()-e.unref(y))%7?(e.openBlock(),e.createElementBlock("button",{key:0,class:e.normalizeClass(i.month===E.value&&b(i.year,i.month,i.day)?i.class:"disabled"),onClick:e.withModifiers(()=>{i.month===E.value&&B(i,f)},["prevent"])},e.toDisplayString(i.day),11,Ee)):e.createCommentVNode("",!0)],64))),128))]))])):e.createCommentVNode("",!0)]))}}},Symbol.toStringTag,{value:"Module"})),De=["id"],Me=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwDropdown",props:e.mergeModels({class:{type:String,default:""},size:{type:String,default:""},type:{type:String,default:""},trigger:{type:String,default:"click"},placement:{type:String,default:"bottom-left"},maxWidth:{type:Number,default:0}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(s,{expose:o}){const t=s,l=e.useModel(s,"modelValue"),n=e.ref(null),d=e.ref(null),u=e.ref({}),p=Math.ceil(Math.random()*1e3),c=e.ref(0),g=e.computed(()=>{let k=["sw-dropdown"];return t.size.length>0&&k.push("sw-"+t.size),t.type.length>0&&k.push("sw-"+t.type),k}),D=new ResizeObserver(k=>{l.value&&c.value++});e.watchEffect(()=>{if(console.log("watchEffect"),!l.value||!d.value||!n.value){u.value={};return}D.observe(d.value),c.value;let k=window.pageYOffset||document.documentElement.scrollTop,y=window.pageXOffset||document.documentElement.scrollLeft;document.body.style.position="fixed",document.body.style.top=`-${k}px`,document.body.style.left=`-${y}px`,document.body.style.position="",document.body.style.top="",document.body.style.left="",document.documentElement.scrollTop=k,document.documentElement.scrollLeft=y;const _=n.value.getBoundingClientRect();let M=window.innerWidth,T=window.innerHeight,C=d.value.offsetHeight,V=d.value.offsetWidth,b=_.left+_.width/2+y,B=_.top+_.height/2+k,O=_.height/2+8;const[H,Y]=t.placement.split("-",2);switch(H){case"bottom":B=k+T-C-O-8<B?B-O-C:B+O;break;case"top":B=k+C+O+8>B?B+O:B-O-C;break;case"left":b=b-V-_.width/2-8,B=B-C/2;break;case"right":b=b+_.width/2+8,B=B-C/2;break}switch(Y){case"left":b=y+M-8>b-_.width/2+V?b-_.width/2:b-V+_.width/2;break;case"right":b=8<b+_.width/2-V?b-V+_.width/2:b-_.width/2;break}b+V>M&&(b=M-V),b<0&&(b=0),B+C>T&&(B=T-C),B<0&&(B=0),u.value={position:"absolute",top:`${B}px`,left:`${b}px`,maxWidth:t.maxWidth===0?"":`${t.maxWidth}px`}},{flush:"post"});const E=()=>{t.trigger==="click"&&(l.value=!l.value),console.log("click")},m=()=>{t.trigger==="hover"&&(l.value=!l.value)},w=()=>{t.trigger==="context"&&(l.value=!l.value)},h=()=>{l.value&&c.value++,console.log("positionPopup",c.value)};o({handleResize:h});const S=k=>{!k.target.closest(`[id="${p}"]`)&&n.value&&!n.value.contains(k.target)&&(l.value=!1)};return e.onMounted(()=>{console.log("onMounted"),d.value&&D.observe(d.value),window.addEventListener("resize",h),document.documentElement.ontouchstart!==void 0?document.documentElement.addEventListener("touchstart",S):document.documentElement.addEventListener("click",S),window.onscrollend!==void 0?window.addEventListener("scrollend",h):window.addEventListener("scroll",h)}),e.onUnmounted(()=>{console.log("onUnmounted"),D.disconnect(),window.removeEventListener("resize",h),document.documentElement.ontouchstart!==void 0?document.documentElement.removeEventListener("touchstart",S):document.documentElement.removeEventListener("click",S),window.onscrollend!==void 0?window.removeEventListener("scrollend",h):window.removeEventListener("scroll",h)}),(k,y)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(g.value),onClick:y[0]||(y[0]=_=>E()),onMouseover:y[1]||(y[1]=e.withModifiers(_=>m(),["stop"])),onMouseleave:y[2]||(y[2]=e.withModifiers(_=>m(),["stop"])),onContextmenu:y[3]||(y[3]=e.withModifiers(_=>w(),["stop"])),ref_key:"dropdownRef",ref:n},[e.renderSlot(k.$slots,"default"),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[l.value?(e.openBlock(),e.createElementBlock("ul",{key:0,ref_key:"popupRef",ref:d,id:e.unref(p),class:e.normalizeClass(["sw-dropdown-popup",t.class]),style:e.normalizeStyle(u.value),tabindex:"-1"},[e.renderSlot(k.$slots,"dropdown")],14,De)):e.createCommentVNode("",!0)]))],34))}}},Symbol.toStringTag,{value:"Module"})),Ce=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwDropdownItem",props:{class:{type:String,default:""},size:{type:String,default:""},type:{type:String,default:""},iconBefore:{type:String,default:""}},setup(s){const o=s,t=e.computed(()=>{let l=["sw-dropdown-item"];return o.size.length>0&&l.push("sw-"+o.size),o.type.length>0&&l.push("sw-"+o.type),o.class.length>0&&l.push(o.class),l});return(l,n)=>{const d=e.resolveComponent("svg-icon");return e.openBlock(),e.createElementBlock("li",{class:e.normalizeClass(t.value)},[e.createVNode(d,{"icon-class":s.iconBefore},null,8,["icon-class"]),e.renderSlot(l.$slots,"default")],2)}}}},Symbol.toStringTag,{value:"Module"})),Te=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwFormItem",props:{class:{type:String,default:""},type:{type:String,default:""}},setup(s){const o=s,t=e.computed(()=>{let l=["sw-form-item"];return o.type.length>0&&l.push("sw-"+o.type),o.class.length>0&&l.push(o.class),l});return(l,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(t.value)},[e.renderSlot(l.$slots,"default")],2))}}},Symbol.toStringTag,{value:"Module"})),Ve=["for"],ze={key:0,title:"Это поле обязательно для заполнения."},Ne=["required","placeholder","type","id","name","size","maxlength","minlength","autofocus","readonly"],xe=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwInput",props:e.mergeModels({before:{type:String,default:""},after:{type:String,default:""},placeholder:{type:String,default:""},label:{type:String,default:""},name:{type:String,required:!0},class:{type:String,default:""},size:{type:String,default:""},type:{type:String,default:"text"},required:{type:Boolean,default:!1},maxlength:{type:Number,default:128},minlength:{type:Number,default:1},inputSize:{type:Number,default:60},autofocus:{type:Boolean,default:!1},readonly:{type:Boolean,default:!1}},{modelValue:{},modelModifiers:{}}),emits:e.mergeModels(["suffix","prefix","focusInput"],["update:modelValue"]),setup(s,{emit:o}){var m;const t=e.useModel(s,"modelValue"),l=s,n=e.ref(null),d=o,u=w=>{d("focusInput"),w.target.setSelectionRange(t.value.length,t.value.length),n.value!==null&&(n.value.style.top="-.6em")},p=w=>{var h;((h=t.value)==null?void 0:h.length)===0&&n.value!==null&&n.value.removeAttribute("style")};((m=t.value)==null?void 0:m.length)>0&&n.value!==null&&(n.value.style.top="-.6em");const c=()=>{d("suffix")},g=()=>{d("prefix")},D=e.computed(()=>{let w=["sw-input"];return l.size.length>0&&w.push("sw-"+l.size),l.class.length>0&&w.push(l.class),w});e.watch(t,(w,h)=>{l.type==="phone"&&(t.value=E(w,h))});const E=(w,h)=>{if(/^\+[0-9]\s/.test(h)&&w.length===2||/^\+0\s/.test(w))return"";const S=w;if(typeof S>"u"||S.length===0)return S;const k="+0 (___) ___-__-__";let y=0;const _=k.replace(/\D/g,""),M=S.replace(/\D/g,"");let T=k.replace(/[_\d]/g,V=>y<M.length?M.charAt(y++)||_.charAt(y):V);y=T.indexOf("_"),y!==-1&&(y=y<5?3:y,T=T.slice(0,y));let C=k.slice(0,S.length).replace(/_+/g,V=>`\\d{1,${V.length}}`).replace(/[+()]/g,"\\$&");if(C=new RegExp(`^${C}$`),T=T.replace(/[-—]$|(\) )$/g,""),!C.test(S)||S.length<5)return T};return(w,h)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(D.value)},[l.before.length>0?(e.openBlock(),e.createBlock(L,{key:0,"icon-class":l.before,onClick:g},null,8,["icon-class"])):e.renderSlot(w.$slots,"prefix",{key:1}),l.label.length>0?(e.openBlock(),e.createElementBlock("label",{key:2,for:l.name,ref_key:"lab",ref:n},[e.createTextVNode(e.toDisplayString(l.label),1),l.required?(e.openBlock(),e.createElementBlock("span",ze,"*")):e.createCommentVNode("",!0)],8,Ve)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":h[0]||(h[0]=S=>t.value=S),required:l.required,placeholder:l.required&&l.label.length===0?l.placeholder+"*":l.placeholder,type:l.type,id:l.name,name:l.name,size:l.inputSize,onFocus:u,onBlur:p,maxlength:l.maxlength,minlength:l.minlength,autofocus:l.autofocus,readonly:l.readonly},null,40,Ne),[[e.vModelDynamic,t.value]]),l.after.length>0?(e.openBlock(),e.createBlock(L,{key:3,"icon-class":l.after,onClick:c},null,8,["icon-class"])):e.renderSlot(w.$slots,"suffix",{key:4})],2))}}},Symbol.toStringTag,{value:"Module"})),ve={key:0},je=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwMessage",props:e.mergeModels({name:{type:String,default:""},class:{type:String,default:""},iconAfter:{type:String,default:""}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(s){const o=e.useModel(s,"modelValue"),t=s,l=e.ref(null),n=e.useSlots(),d=u=>{l.value&&!l.value.contains(u.target)&&(o.value=!1)};return e.watch(()=>o.value,async u=>{u?(await e.nextTick(),window.addEventListener("click",d,!0)):window.removeEventListener("click",d)}),e.onUnmounted(()=>{window.removeEventListener("click",d)}),(u,p)=>{var g;const c=e.resolveComponent("svg-icon");return o.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["sw-message",t.class]),ref_key:"messageRef",ref:l},[t.name.length>0||(g=e.unref(n))!=null&&g.header?(e.openBlock(),e.createElementBlock("header",ve,[e.renderSlot(u.$slots,"header",{},()=>[e.createTextVNode(e.toDisplayString(t.name)+" ",1),e.createVNode(G,{link:"",type:"primary",onClick:p[0]||(p[0]=D=>o.value=!1)},{default:e.withCtx(()=>[e.createVNode(c,{"icon-class":t.iconAfter},null,8,["icon-class"])]),_:1})])])):e.createCommentVNode("",!0),e.renderSlot(u.$slots,"default"),e.createElementVNode("footer",null,[e.renderSlot(u.$slots,"footer")])],2)):e.createCommentVNode("",!0)}}}},Symbol.toStringTag,{value:"Module"})),Oe=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwSection",props:{name:{type:String,default:""},class:{type:String,default:""},iconAfter:{type:String,default:""}},emits:["header"],setup(s,{emit:o}){const t=s,l=o,n=()=>{l("header")};return(d,u)=>{const p=e.resolveComponent("svg-icon");return e.openBlock(),e.createElementBlock("section",{class:e.normalizeClass(t.class)},[e.createElementVNode("header",{onClick:n},[e.renderSlot(d.$slots,"header",{},()=>[e.createTextVNode(e.toDisplayString(t.name)+" ",1),e.createVNode(p,{"icon-class":t.iconAfter},null,8,["icon-class"])])]),e.renderSlot(d.$slots,"default"),e.createElementVNode("footer",null,[e.renderSlot(d.$slots,"footer")])],2)}}}},Symbol.toStringTag,{value:"Module"})),Pe={class:"popup"},Fe={class:"wrapper"},Ie={class:"scrollbar"},Le=["onClick"],Ae=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwSelect",props:e.mergeModels({class:{type:String,default:""},size:{type:String,default:"large"},placeholder:{type:String,default:""},token:{type:String,default:""}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(s){const o=e.ref({fullText:""}),t=e.ref(!1),l=e.ref([]),n=e.useModel(s,"modelValue"),d=s;e.watch(n.text,c=>{c.length>3&&(o.value.fullText=c)}),e.watch(o.value.fullText,(c,g)=>{t.value=c.length>3&&c.length>g.length,c.length>3&&u()});const u=()=>{let c="https://suggestions.dadata.ru/suggestions/api/4_1/rs/suggest/address";console.log(o.value.fullText),axios.post(c,{query:o.value.fullText},{headers:{"Content-Type":"application/json",Accept:"application/json",Authorization:"Token "+d.token}}).then(g=>{console.log(g.data.suggestions),l.value=g.data.suggestions,l.value.length===1&&p(l.value[0])}).catch(g=>{console.log(g)})},p=c=>{o.value.fullText=c.value,t.value=!1;const g={};g.text=c.value,g.coords=[Number(c.data.geo_lat),Number(c.data.geo_lon)],g.suggestion=c.data,n.value=g};return(c,g)=>{const D=e.resolveComponent("sw-input");return e.openBlock(),e.createElementBlock("div",Pe,[e.createVNode(D,{size:d.size,modelValue:o.value.fullText,"onUpdate:modelValue":g[0]||(g[0]=E=>o.value.fullText=E),placeholder:s.placeholder},null,8,["size","modelValue","placeholder"]),e.withDirectives(e.createElementVNode("div",Fe,[e.createElementVNode("ul",Ie,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(l.value,(E,m)=>(e.openBlock(),e.createElementBlock("li",{tabindex:"1",key:m,onClick:w=>p(E)},e.toDisplayString(E.value),9,Le))),128))])],512),[[e.vShow,t.value]])])}}}},Symbol.toStringTag,{value:"Module"})),Ye={key:0},X={__name:"SwSkeletonItem",props:{width:{type:String,default:"100"},class:{type:String,default:""},animate:{type:Boolean,default:!1},size:{type:String,default:""}},setup(s){const o=s,t=e.computed(()=>{let n=["sw-skeleton-item"];return o.size.length>0&&n.push("sw-"+o.size),o.animate&&n.push("sw-animate"),o.class.length>0&&n.push(o.class),n}),l=e.computed(()=>({width:o.width+"%"}));return(n,d)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(t.value),style:e.normalizeStyle(l.value)},[o.animate?(e.openBlock(),e.createElementBlock("div",Ye)):e.createCommentVNode("",!0)],6))}},Re=Object.freeze(Object.defineProperty({__proto__:null,default:X},Symbol.toStringTag,{value:"Module"})),He=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwSkeleton",props:{class:{type:String,default:""},visual:{type:Boolean,default:!1}},setup(s){const o=s;return(t,l)=>o.visual?e.renderSlot(t.$slots,"default",{key:0}):(e.openBlock(),e.createElementBlock("div",{key:1,class:e.normalizeClass(["sw-skeleton",o.class])},[e.renderSlot(t.$slots,"skeleton",{},()=>[e.createVNode(X,{animate:"",size:"small"})])],2))}}},Symbol.toStringTag,{value:"Module"})),qe=["name","id"],Ue=["for","data-onlabel","data-offlabel"],We=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwSwitch",props:e.mergeModels({id:{type:String,default:"checkbox"},class:{type:String,default:""},name:{type:String,default:""},on:{type:String,default:""},off:{type:String,default:""},size:{type:String,default:""},checkbox:{type:Boolean,default:!1}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(s){const o=e.useModel(s,"modelValue"),t=s,l=e.computed(()=>{let n=["sw-switch"];return t.size.length>0&&n.push("sw-"+t.size),t.checkbox&&n.push("sw-checkbox"),t.class.length>0&&n.push(t.class),n});return(n,d)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(l.value)},[e.withDirectives(e.createElementVNode("input",{type:"checkbox",name:t.name,class:"sw-control",id:t.id,"onUpdate:modelValue":d[0]||(d[0]=u=>o.value=u)},null,8,qe),[[e.vModelCheckbox,o.value]]),e.createElementVNode("label",{for:t.id,class:"sw-label","data-onlabel":t.on,"data-offlabel":t.off},null,8,Ue),e.renderSlot(n.$slots,"default")],2))}}},Symbol.toStringTag,{value:"Module"})),Ge={key:0},Xe=["onClick"],Je=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwTabs",props:e.mergeModels({class:{type:String,default:""}},{modelValue:{},modelModifiers:{}}),emits:e.mergeModels(["tab-click"],["update:modelValue"]),setup(s,{emit:o}){e.ref(0);const t=e.ref([]),l=s,n=e.useModel(s,"modelValue"),d=o;function u(c){t.value.push(c)}function p(c){t.value=t.value.filter(g=>g!==c)}return e.provide("registerTab",u),e.provide("unregisterTab",p),e.provide("activeTab",n),e.provide("tabs",t),(c,g)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass("sw-tabs "+l.class)},[t.value.length!==0?(e.openBlock(),e.createElementBlock("header",Ge,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.value,(D,E)=>(e.openBlock(),e.createElementBlock("span",{key:E,class:e.normalizeClass([{active:n.value===E}]),onClick:m=>{n.value=E,d("tab-click",E)}},e.toDisplayString(D.label||D.title),11,Xe))),128))])):e.createCommentVNode("",!0),e.renderSlot(c.$slots,"default")],2))}}},Symbol.toStringTag,{value:"Module"})),Qe={key:0,class:"tab-content"},Ze=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwTabsPane",props:{title:{type:String,required:!0},label:{type:String,default:""}},setup(s){const o=s,t=e.inject("registerTab"),l=e.inject("unregisterTab");e.onMounted(()=>{t({title:o.title,label:o.label})}),e.onUnmounted(()=>{l({title:o.title,label:o.label})});const n=e.inject("activeTab"),d=e.inject("tabs"),u=e.computed(()=>d.value.findIndex(c=>c.title===o.title)),p=e.computed(()=>n.value===u.value);return(c,g)=>p.value?(e.openBlock(),e.createElementBlock("div",Qe,[e.renderSlot(c.$slots,"default")])):e.createCommentVNode("",!0)}}},Symbol.toStringTag,{value:"Module"}));v.Alert=R,v.Library=se,v.components=A,Object.defineProperty(v,Symbol.toStringTag,{value:"Module"})});
|
|
1
|
+
(function(v,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(v=typeof globalThis<"u"?globalThis:v||self,e(v["component-sw"]={},v.vue))})(this,function(v,e){"use strict";function ee(s){return/^(https?:|mailto:|tel:)/.test(s)}function P(s,n){if(arguments.length===0||!s)return null;const t=n||"{Y}-{m}-{d} {G}:{i}:{s}";let l;typeof s=="object"?l=s:(typeof s=="string"&&(/^[0-9]+$/.test(s)?s=parseInt(s):s=s.replace(new RegExp(/-/gm),"/")),typeof s=="number"&&s.toString().length===10&&(s=s*1e3),l=new Date(s));const o="ru-RU",d={Y:l.getFullYear(),m:(l.getMonth()+1).toString().padStart(2,"0"),d:l.getDate(),dd:l.getDate().toString().padStart(2,"0"),G:l.getHours(),H:l.getHours().toString().padStart(2,"0"),i:l.getMinutes().toString().padStart(2,"0"),s:l.getSeconds().toString().padStart(2,"0"),D:new Intl.DateTimeFormat(o,{weekday:"short"}).format(l),F:new Intl.DateTimeFormat(o,{month:"long"}).format(l),M:new Intl.DateTimeFormat(o,{month:"short"}).format(l)};return t.replace(/{(dd|[YmdGHisDFM])+}/g,(u,p)=>d[p])}const te=(s,n)=>{const t=s.__vccOpts||s;for(const[l,o]of n)t[l]=o;return t},le={name:"SvgIcon",props:{prefix:{type:String,default:"icon"},iconClass:{type:String,required:!0},className:{type:String,default:""}},computed:{isExt(){return ee(this.iconClass)}}},ne=["href"];function oe(s,n,t,l,o,d){return d.isExt?(e.openBlock(),e.createElementBlock("div",e.mergeProps({key:0,style:"mask: url("+t.iconClass+") no-repeat 50% 50%;",class:"svg-external-icon svg-icon"},s.$attrs),null,16)):(e.openBlock(),e.createElementBlock("svg",e.mergeProps({key:1,class:"svg-icon "+t.className,"aria-hidden":"true"},s.$attrs),[e.createElementVNode("use",{href:"#"+t.prefix+"-"+t.iconClass},null,8,ne)],16))}const L=te(le,[["render",oe]]),U={__name:"SwAlert",props:{message:{type:String,default:"Default message"},before:{type:String,default:""},class:{type:String,default:""},after:{type:String,default:""},size:{type:String,default:""},duration:{type:Number,default:6e3},type:{type:String,default:"info",validator:s=>["success","warning","error","info"].includes(s)}},emits:["closed"],setup(s,{emit:n}){const t=s,l=n,o=e.ref(!1);let d=null;const u=()=>{o.value=!0,M()},p=()=>{o.value=!1,l("closed")},c=()=>{d&&(clearTimeout(d),d=null)},g=()=>{M()},M=()=>{d=setTimeout(p,t.duration)};e.onMounted(()=>{u()}),e.onUnmounted(()=>{d&&clearTimeout(d)});const E=e.computed(()=>{const m=["sw-alert"];return t.size.length>0&&m.push(`sw-${t.size}`),t.type.length>0&&m.push(`sw-${t.type}`),t.class.length>0&&m.push(t.class),m});return(m,w)=>(e.openBlock(),e.createBlock(e.Transition,{name:"fade"},{default:e.withCtx(()=>[o.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(E.value),onMouseenter:c,onMouseleave:g},[t.before.length>0?(e.openBlock(),e.createBlock(L,{key:0,"icon-class":t.before},null,8,["icon-class"])):e.renderSlot(m.$slots,"prefix",{key:1}),e.renderSlot(m.$slots,"default",{},()=>[e.createTextVNode(e.toDisplayString(t.message),1)]),t.after.length>0?(e.openBlock(),e.createBlock(L,{key:2,"icon-class":t.after,onClick:p},null,8,["icon-class"])):e.renderSlot(m.$slots,"suffix",{key:3})],34)):e.createCommentVNode("",!0)]),_:3}))}},ae=Object.freeze(Object.defineProperty({__proto__:null,default:U},Symbol.toStringTag,{value:"Module"}));let F=document.querySelector("div.sw-alert-wrapper");function R(s={}){F||(F=document.createElement("div"),F.className="sw-alert-wrapper",document.body.appendChild(F));const n=e.createApp({setup(){return()=>e.h(U,{...s,onClose:()=>{F.removeChild(n._container),n.unmount()}})}}),t=n.mount(document.createElement("div"));F.appendChild(t.$el)}const W=Object.assign({"./components/SwAlert.vue":()=>Promise.resolve().then(()=>ae),"./components/SwButton.vue":()=>Promise.resolve().then(()=>re),"./components/SwCollapse.vue":()=>Promise.resolve().then(()=>ie),"./components/SwDatePicker.vue":()=>Promise.resolve().then(()=>$e),"./components/SwDropdown.vue":()=>Promise.resolve().then(()=>Me),"./components/SwDropdownItem.vue":()=>Promise.resolve().then(()=>Ce),"./components/SwFormItem.vue":()=>Promise.resolve().then(()=>Te),"./components/SwInput.vue":()=>Promise.resolve().then(()=>xe),"./components/SwMessage.vue":()=>Promise.resolve().then(()=>je),"./components/SwSection.vue":()=>Promise.resolve().then(()=>Oe),"./components/SwSelect.vue":()=>Promise.resolve().then(()=>Ae),"./components/SwSkeleton.vue":()=>Promise.resolve().then(()=>He),"./components/SwSkeletonItem.vue":()=>Promise.resolve().then(()=>Re),"./components/SwSwitch.vue":()=>Promise.resolve().then(()=>We),"./components/SwTabs.vue":()=>Promise.resolve().then(()=>Je),"./components/SwTabsPane.vue":()=>Promise.resolve().then(()=>Ze)}),A={};for(const s in W){const n=s.split("/").pop().replace(".vue","").replace(/-(\w)/g,(t,l)=>l.toUpperCase());A[n]=e.defineAsyncComponent(()=>W[s]())}const se={install(s){Object.keys(A).forEach(n=>{s.component(n,A[n])}),s.config.globalProperties.$Alert=R,s.provide("Alert",R)}},G={__name:"SwButton",props:{class:{type:String,default:""},size:{type:String,default:""},type:{type:String,default:""},round:{type:Boolean,default:!1},text:{type:Boolean,default:!1},link:{type:Boolean,default:!1},href:{type:String,default:""}},setup(s){const n=s,t=()=>{if(n.href.length>0){const o=document.createElement("a");o.setAttribute("href",n.href),o.setAttribute("target","_blank"),o.click()}},l=e.computed(()=>{let o=["sw-button"];return n.size.length>0&&o.push("sw-"+n.size),n.type.length>0&&o.push("sw-"+n.type),n.round&&o.push("sw-round"),n.text&&o.push("sw-text"),n.link&&o.push("sw-link"),n.class.length>0&&o.push(n.class),o});return(o,d)=>(e.openBlock(),e.createElementBlock("button",{class:e.normalizeClass(l.value),onClick:t},[e.renderSlot(o.$slots,"default")],2))}},re=Object.freeze(Object.defineProperty({__proto__:null,default:G},Symbol.toStringTag,{value:"Module"})),ie=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwCollapse",props:{visual:{type:Boolean,default:!0}},setup(s){e.onMounted(()=>{l.value="0px"});const n=e.ref(null),t=s;e.watch(()=>t.visual,()=>o());const l=e.ref("0px"),o=()=>{n.value&&(l.value=t.visual?n.value.scrollHeight+"px":"0px")};let d;return e.onMounted(()=>{o(),n.value&&(d=new ResizeObserver(o),d.observe(n.value))}),e.onBeforeUnmount(()=>{d&&d.disconnect()}),(u,p)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["sw-collapse",{open:t.visual}]),style:e.normalizeStyle({maxHeight:l.value}),ref_key:"collapse",ref:n},[e.renderSlot(u.$slots,"default")],6))}}},Symbol.toStringTag,{value:"Module"})),ce={class:"sw-data-picker"},de={class:"month_year"},pe={class:"text"},me={key:0,class:"week"},fe={key:1,class:"year"},ue=["onClick"],ge={key:2,class:"month"},he=["onClick"],ye={key:0},we={class:"month_year"},Se={class:"text"},ke={key:0,class:"week"},_e={key:1,class:"year"},be=["onClick"],Be={key:2,class:"month"},Ee=["onClick"],$e=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwDatePicker",props:{data:Object,limitation:{type:[Boolean,Array],default:()=>!1},range:{type:String,default:"solid"}},emits:["input"],setup(s,{emit:n}){var J,Q,Z,K;const t=s,l=n,o=e.ref(3),d=e.ref(new Date),u=e.ref(new Date),p=e.ref(new Date().getFullYear()),c=e.ref(new Date().getMonth()),g=e.ref(new Date().getFullYear()),M=e.ref(new Date().getMonth()),E=e.ref(new Date(p.value,c.value+1,1).getMonth()),m=e.ref([]),w=e.ref(0),h=e.ref(-1),S=e.ref(-1),k=e.ref(navigator.language||"ru"),y=/en|zh|ja|he/.test(k.value)?0:1,_=e.computed(()=>Array.from({length:12},(r,a)=>{const i=new Date(2024,a);return new Intl.DateTimeFormat(k.value,{month:"long"}).format(i)})),D=r=>{let a=r.split(r.match(/\D.*?\D?/));return a[0].length>2?a.join("-")+"T00:00:01":a.reverse().join("-")+"T00:00:01"};(J=t.data)!=null&&J.startDate&&(d.value=new Date(D(t.data.startDate)),p.value=d.value.getFullYear(),c.value=d.value.getMonth()),(Q=t.data)!=null&&Q.endDate&&t.range==="range"&&(u.value=new Date(D(t.data.endDate)),g.value=u.value.getFullYear(),M.value=u.value.getMonth());const T=()=>{m.value=[],w.value=0;const r=new Date(p.value,c.value,0);for(let i=r.getDate()-r.getDay()+y;i<=r.getDate();i++)r.getDay()!==6+y&&(m.value.push({day:i,month:r.getMonth(),year:r.getFullYear(),class:[]}),w.value++);const a=new Date(p.value,c.value+1,0).getDate();for(let i=1;i<=a;i++)m.value.push({day:i,month:c.value,year:p.value,class:[]}),w.value++;if(t.range==="range"){const i=new Date(p.value,c.value+1,1),f=new Date(p.value,c.value+2,0).getDate();for(let $=1;$<=f;$++)m.value.push({day:$,month:i.getMonth(),year:i.getFullYear(),class:[]})}C()},C=()=>{var a;if(!((a=t.data)!=null&&a.holiday))return;const r=(i,f)=>{i.forEach($=>{const[x,z,j]=$.split("-").map(Number),I=m.value.findIndex(q=>q.year===x&&q.month+1===z&&q.day===j);I!==-1&&(m.value[I].class[0]=f)})};r(t.data.holiday.preholidays,"preholiday"),r(t.data.holiday.holidays,"weekend"),r(t.data.holiday.holiday,"holiday"),r(t.data.holiday.nowork,"nowork")},V=()=>{if(!t.limitation||t.limitation.length<2)return!1;const r=[...t.limitation].sort((a,i)=>new Date(D(a.startDate)).getTime()-new Date(D(i.startDate)).getTime());for(let a=1;a<r.length;a++){const i=new Date(D(r[a-1].endDate));if(new Date(D(r[a].startDate))<=i)return console.warn("Warning: Диапазоны пересекаются:",r[a-1],r[a]),!0}return!1},b=(r,a,i)=>{if(!t.limitation||t.limitation.length===0)return!0;const f=new Date(r,a,i).getTime();for(let $ of t.limitation){const{startDate:x,endDate:z}=$;if(!x&&z){const j=new Date(D(z)).getTime();if(f<=j)return!1}if(x&&!z){const j=new Date(D(x)).getTime();if(f>=j)return!1}if(x&&z){const j=new Date(D(x)).getTime(),I=new Date(D(z)).getTime();if(j<=I){if(f>=j&&f<=I)return!1}else if(f>=j||f<=I)return!1}}return!0},B=(r,a)=>{const i=P(new Date(r.year,r.month,r.day),"{dd}.{m}.{Y}");t.range==="range"?S.value!==-1?(O(),h.value=a,m.value[a].class[1]="active"):h.value!==-1?(S.value=a,H(h.value,S.value,i)):(h.value=a,m.value[a].class[1]="active"):(h.value!==-1&&(m.value[h.value].class[1]=""),h.value=a,m.value[a].class[1]="active",l("input",{dateStart:i,count:1}))},O=()=>{m.value.forEach(r=>r.class[1]=""),h.value=-1,S.value=-1},H=(r,a,i)=>{let f=P(new Date(m.value[r].year,m.value[r].month,m.value[r].day),"{dd}.{m}.{Y}");if(a>=r){for(let $=r+1;$<a;$++)m.value[$].class[1]="select";l("input",{dateStart:f,dateEnd:i,count:Y(r,a)})}else{for(let $=a+1;$<r;$++)m.value[$].class[1]="select";l("input",{dateStart:i,dateEnd:f,count:Y(a,r)})}m.value[a].class[1]="active"},Y=(r,a)=>{var x;let i=Math.abs(r-a)+1,[f,$]=[Math.min(r,a),Math.max(r,a)];for(let z=f;z<=$;z++)((x=m.value[z])==null?void 0:x.class[0])==="holiday"&&i--;return i},N=(r,a)=>{b(r,a)&&(d.value=new Date(r,a,1),p.value=d.value.getFullYear(),c.value=d.value.getMonth(),E.value=new Date(r,a+1,1).getMonth(),t.range==="year"&&o.value===0?B({year:r,month:a,day:1},8):T())};if(T(),V(),(Z=t.data)!=null&&Z.startDate&&(h.value=m.value.findIndex(r=>r.day===d.value.getDate()&&r.month===c.value&&r.year===p.value),h.value!==-1&&(m.value[h.value].class[1]="active")),(K=t.data)!=null&&K.endDate&&t.range==="range"&&(S.value=m.value.findIndex(r=>r.day===u.value.getDate()&&r.month===M.value&&r.year===g.value),S.value!==-1)){m.value[S.value].class[1]="active";for(let r=h.value+1;r<S.value;r++)m.value[r].class[1]="select"}return(r,a)=>(e.openBlock(),e.createElementBlock("div",ce,[e.createElementVNode("div",null,[e.createElementVNode("p",de,[e.createElementVNode("span",null,[e.createElementVNode("button",{onClick:a[0]||(a[0]=e.withModifiers(i=>N(p.value-1,c.value),["prevent"]))},[e.renderSlot(r.$slots,"double-arrow",{},()=>[a[12]||(a[12]=e.createTextVNode("«"))])]),e.createElementVNode("button",{onClick:a[1]||(a[1]=e.withModifiers(i=>{o.value=0,N(p.value,c.value-1)},["prevent"]))},[e.renderSlot(r.$slots,"arrow",{},()=>[a[13]||(a[13]=e.createTextVNode("‹"))])])]),e.createElementVNode("span",pe,[e.createElementVNode("button",{onClick:a[2]||(a[2]=e.withModifiers(i=>o.value=1,["prevent"]))},e.toDisplayString(p.value),1),e.createElementVNode("button",{onClick:a[3]||(a[3]=e.withModifiers(i=>o.value=1,["prevent"]))},e.toDisplayString(e.unref(P)(d.value.setMonth(c.value),"{F}")),1)]),e.createElementVNode("span",null,[e.createElementVNode("button",{class:"sw-revers",onClick:a[4]||(a[4]=e.withModifiers(i=>{o.value=0,N(p.value,c.value+1)},["prevent"]))},[e.renderSlot(r.$slots,"arrow",{},()=>[a[14]||(a[14]=e.createTextVNode("‹"))])]),e.createElementVNode("button",{class:"sw-revers",onClick:a[5]||(a[5]=e.withModifiers(i=>N(p.value+1,c.value),["prevent"]))},[e.renderSlot(r.$slots,"double-arrow",{},()=>[a[15]||(a[15]=e.createTextVNode("«"))])])])]),t.range==="year"||o.value===1?e.createCommentVNode("",!0):(e.openBlock(),e.createElementBlock("div",me,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(7,(i,f)=>e.createElementVNode("button",{key:f,class:"disabled"},e.toDisplayString(e.unref(P)(new Date(1970,1,i+e.unref(y)),"{D}")),1)),64))])),t.range==="year"||o.value===1?(e.openBlock(),e.createElementBlock("div",fe,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(_.value,(i,f)=>(e.openBlock(),e.createElementBlock("button",{key:f,onClick:e.withModifiers($=>{o.value=0,N(p.value,f)},["prevent"]),class:e.normalizeClass(f===c.value?"active":"")},e.toDisplayString(i),11,ue))),128))])):(e.openBlock(),e.createElementBlock("div",ge,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,(i,f)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:f},[f<w.value+(7-new Date(p.value,c.value+1,1).getDay()+e.unref(y))%7?(e.openBlock(),e.createElementBlock("button",{key:0,class:e.normalizeClass(i.month===c.value&&b(i.year,i.month,i.day)?i.class:"disabled"),onClick:e.withModifiers(()=>{i.month===c.value&&B(i,f)},["prevent"])},e.toDisplayString(i.day),11,he)):e.createCommentVNode("",!0)],64))),128))]))]),t.range==="range"?(e.openBlock(),e.createElementBlock("div",ye,[e.createElementVNode("p",we,[e.createElementVNode("span",null,[e.createElementVNode("button",{onClick:a[6]||(a[6]=e.withModifiers(i=>N(p.value-1,c.value),["prevent"]))},[e.renderSlot(r.$slots,"double-arrow",{},()=>[a[16]||(a[16]=e.createTextVNode("«"))])]),e.createElementVNode("button",{onClick:a[7]||(a[7]=e.withModifiers(i=>{o.value=0,N(p.value,c.value-1)},["prevent"]))},[e.renderSlot(r.$slots,"arrow",{},()=>[a[17]||(a[17]=e.createTextVNode("‹"))])])]),e.createElementVNode("span",Se,[e.createElementVNode("button",{onClick:a[8]||(a[8]=e.withModifiers(i=>o.value=2,["prevent"]))},e.toDisplayString(new Date(p.value,c.value+1).getFullYear()),1),e.createElementVNode("button",{onClick:a[9]||(a[9]=e.withModifiers(i=>o.value=2,["prevent"]))},e.toDisplayString(e.unref(P)(d.value.setMonth(c.value+1),"{F}")),1)]),e.createElementVNode("span",null,[e.createElementVNode("button",{class:"sw-revers",onClick:a[10]||(a[10]=e.withModifiers(i=>{o.value=0,N(p.value,c.value+1)},["prevent"]))},[e.renderSlot(r.$slots,"arrow",{},()=>[a[18]||(a[18]=e.createTextVNode("‹"))])]),e.createElementVNode("button",{class:"sw-revers",onClick:a[11]||(a[11]=e.withModifiers(i=>N(p.value+1,c.value),["prevent"]))},[e.renderSlot(r.$slots,"double-arrow",{},()=>[a[19]||(a[19]=e.createTextVNode("«"))])])])]),o.value!==2?(e.openBlock(),e.createElementBlock("div",ke,[(e.openBlock(),e.createElementBlock(e.Fragment,null,e.renderList(7,(i,f)=>e.createElementVNode("button",{key:f,class:"disabled"},e.toDisplayString(e.unref(P)(new Date(1970,1,i+e.unref(y)),"{D}")),1)),64))])):e.createCommentVNode("",!0),o.value===2?(e.openBlock(),e.createElementBlock("div",_e,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(_.value,(i,f)=>(e.openBlock(),e.createElementBlock("button",{key:f,onClick:e.withModifiers($=>{o.value=0,N(p.value,f-1)},["prevent"]),class:e.normalizeClass(f===(c.value+1)%12?"active":"")},e.toDisplayString(i),11,be))),128))])):(e.openBlock(),e.createElementBlock("div",Be,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(m.value,(i,f)=>(e.openBlock(),e.createElementBlock(e.Fragment,{key:f},[f>=w.value-(7+new Date(p.value,c.value+1,1).getDay()-e.unref(y))%7?(e.openBlock(),e.createElementBlock("button",{key:0,class:e.normalizeClass(i.month===E.value&&b(i.year,i.month,i.day)?i.class:"disabled"),onClick:e.withModifiers(()=>{i.month===E.value&&B(i,f)},["prevent"])},e.toDisplayString(i.day),11,Ee)):e.createCommentVNode("",!0)],64))),128))]))])):e.createCommentVNode("",!0)]))}}},Symbol.toStringTag,{value:"Module"})),De=["id"],Me=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwDropdown",props:e.mergeModels({class:{type:String,default:""},size:{type:String,default:""},type:{type:String,default:""},trigger:{type:String,default:"click"},placement:{type:String,default:"bottom-left"},maxWidth:{type:Number,default:0}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(s,{expose:n}){const t=s,l=e.useModel(s,"modelValue"),o=e.ref(null),d=e.ref(null),u=e.ref({}),p=Math.ceil(Math.random()*1e3),c=e.ref(0),g=e.computed(()=>{let k=["sw-dropdown"];return t.size.length>0&&k.push("sw-"+t.size),t.type.length>0&&k.push("sw-"+t.type),k}),M=new ResizeObserver(k=>{l.value&&c.value++});e.watchEffect(()=>{if(!l.value||!d.value||!o.value){u.value={};return}M.observe(d.value);let k=window.pageYOffset||document.documentElement.scrollTop,y=window.pageXOffset||document.documentElement.scrollLeft;document.body.style.position="fixed",document.body.style.top=`-${k}px`,document.body.style.left=`-${y}px`,document.body.style.position="",document.body.style.top="",document.body.style.left="",document.documentElement.scrollTop=k,document.documentElement.scrollLeft=y;const _=o.value.getBoundingClientRect();let D=window.innerWidth,T=window.innerHeight,C=d.value.offsetHeight,V=d.value.offsetWidth,b=_.left+_.width/2+y,B=_.top+_.height/2+k,O=_.height/2+8;const[H,Y]=t.placement.split("-",2);switch(H){case"bottom":B=k+T-C-O-8<B?B-O-C:B+O;break;case"top":B=k+C+O+8>B?B+O:B-O-C;break;case"left":b=b-V-_.width/2-8,B=B-C/2;break;case"right":b=b+_.width/2+8,B=B-C/2;break}switch(Y){case"left":b=y+D-8>b-_.width/2+V?b-_.width/2:b-V+_.width/2;break;case"right":b=8<b+_.width/2-V?b-V+_.width/2:b-_.width/2;break}b+V>D&&(b=D-V),b<0&&(b=0),B+C>T&&(B=T-C),B<0&&(B=0),u.value={position:"absolute",top:`${B}px`,left:`${b}px`,maxWidth:t.maxWidth===0?"":`${t.maxWidth}px`}},{flush:"post"});const E=()=>{t.trigger==="click"&&(l.value=!l.value)},m=()=>{t.trigger==="hover"&&(l.value=!l.value)},w=()=>{t.trigger==="context"&&(l.value=!l.value)},h=()=>{l.value&&c.value++};n({handleResize:h});const S=k=>{!k.target.closest(`[id="${p}"]`)&&o.value&&!o.value.contains(k.target)&&(l.value=!1)};return e.onMounted(()=>{window.addEventListener("resize",h),document.documentElement.ontouchstart!==void 0?document.documentElement.addEventListener("touchstart",S):document.documentElement.addEventListener("click",S),window.onscrollend!==void 0?window.addEventListener("scrollend",h):window.addEventListener("scroll",h)}),e.onUnmounted(()=>{M.disconnect(),window.removeEventListener("resize",h),document.documentElement.ontouchstart!==void 0?document.documentElement.removeEventListener("touchstart",S):document.documentElement.removeEventListener("click",S),window.onscrollend!==void 0?window.removeEventListener("scrollend",h):window.removeEventListener("scroll",h)}),(k,y)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(g.value),onClick:y[0]||(y[0]=_=>E()),onMouseover:y[1]||(y[1]=e.withModifiers(_=>m(),["stop"])),onMouseleave:y[2]||(y[2]=e.withModifiers(_=>m(),["stop"])),onContextmenu:y[3]||(y[3]=e.withModifiers(_=>w(),["stop"])),ref_key:"dropdownRef",ref:o},[e.renderSlot(k.$slots,"default"),(e.openBlock(),e.createBlock(e.Teleport,{to:"body"},[l.value?(e.openBlock(),e.createElementBlock("ul",{key:0,ref_key:"popupRef",ref:d,id:e.unref(p),class:e.normalizeClass(["sw-dropdown-popup",t.class]),style:e.normalizeStyle(u.value),tabindex:"-1"},[e.renderSlot(k.$slots,"dropdown")],14,De)):e.createCommentVNode("",!0)]))],34))}}},Symbol.toStringTag,{value:"Module"})),Ce=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwDropdownItem",props:{class:{type:String,default:""},size:{type:String,default:""},type:{type:String,default:""},iconBefore:{type:String,default:""}},setup(s){const n=s,t=e.computed(()=>{let l=["sw-dropdown-item"];return n.size.length>0&&l.push("sw-"+n.size),n.type.length>0&&l.push("sw-"+n.type),n.class.length>0&&l.push(n.class),l});return(l,o)=>{const d=e.resolveComponent("svg-icon");return e.openBlock(),e.createElementBlock("li",{class:e.normalizeClass(t.value)},[e.createVNode(d,{"icon-class":s.iconBefore},null,8,["icon-class"]),e.renderSlot(l.$slots,"default")],2)}}}},Symbol.toStringTag,{value:"Module"})),Te=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwFormItem",props:{class:{type:String,default:""},type:{type:String,default:""}},setup(s){const n=s,t=e.computed(()=>{let l=["sw-form-item"];return n.type.length>0&&l.push("sw-"+n.type),n.class.length>0&&l.push(n.class),l});return(l,o)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(t.value)},[e.renderSlot(l.$slots,"default")],2))}}},Symbol.toStringTag,{value:"Module"})),Ve=["for"],ze={key:0,title:"Это поле обязательно для заполнения."},Ne=["required","placeholder","type","id","name","size","maxlength","minlength","autofocus","readonly"],xe=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwInput",props:e.mergeModels({before:{type:String,default:""},after:{type:String,default:""},placeholder:{type:String,default:""},label:{type:String,default:""},name:{type:String,required:!0},class:{type:String,default:""},size:{type:String,default:""},type:{type:String,default:"text"},required:{type:Boolean,default:!1},maxlength:{type:Number,default:128},minlength:{type:Number,default:1},inputSize:{type:Number,default:60},autofocus:{type:Boolean,default:!1},readonly:{type:Boolean,default:!1}},{modelValue:{},modelModifiers:{}}),emits:e.mergeModels(["suffix","prefix","focusInput"],["update:modelValue"]),setup(s,{emit:n}){var m;const t=e.useModel(s,"modelValue"),l=s,o=e.ref(null),d=n,u=w=>{d("focusInput"),w.target.setSelectionRange(t.value.length,t.value.length),o.value!==null&&(o.value.style.top="-.6em")},p=w=>{var h;((h=t.value)==null?void 0:h.length)===0&&o.value!==null&&o.value.removeAttribute("style")};((m=t.value)==null?void 0:m.length)>0&&o.value!==null&&(o.value.style.top="-.6em");const c=()=>{d("suffix")},g=()=>{d("prefix")},M=e.computed(()=>{let w=["sw-input"];return l.size.length>0&&w.push("sw-"+l.size),l.class.length>0&&w.push(l.class),w});e.watch(t,(w,h)=>{l.type==="phone"&&(t.value=E(w,h))});const E=(w,h)=>{if(/^\+[0-9]\s/.test(h)&&w.length===2||/^\+0\s/.test(w))return"";const S=w;if(typeof S>"u"||S.length===0)return S;const k="+0 (___) ___-__-__";let y=0;const _=k.replace(/\D/g,""),D=S.replace(/\D/g,"");let T=k.replace(/[_\d]/g,V=>y<D.length?D.charAt(y++)||_.charAt(y):V);y=T.indexOf("_"),y!==-1&&(y=y<5?3:y,T=T.slice(0,y));let C=k.slice(0,S.length).replace(/_+/g,V=>`\\d{1,${V.length}}`).replace(/[+()]/g,"\\$&");if(C=new RegExp(`^${C}$`),T=T.replace(/[-—]$|(\) )$/g,""),!C.test(S)||S.length<5)return T};return(w,h)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(M.value)},[l.before.length>0?(e.openBlock(),e.createBlock(L,{key:0,"icon-class":l.before,onClick:g},null,8,["icon-class"])):e.renderSlot(w.$slots,"prefix",{key:1}),l.label.length>0?(e.openBlock(),e.createElementBlock("label",{key:2,for:l.name,ref_key:"lab",ref:o},[e.createTextVNode(e.toDisplayString(l.label),1),l.required?(e.openBlock(),e.createElementBlock("span",ze,"*")):e.createCommentVNode("",!0)],8,Ve)):e.createCommentVNode("",!0),e.withDirectives(e.createElementVNode("input",{"onUpdate:modelValue":h[0]||(h[0]=S=>t.value=S),required:l.required,placeholder:l.required&&l.label.length===0?l.placeholder+"*":l.placeholder,type:l.type,id:l.name,name:l.name,size:l.inputSize,onFocus:u,onBlur:p,maxlength:l.maxlength,minlength:l.minlength,autofocus:l.autofocus,readonly:l.readonly},null,40,Ne),[[e.vModelDynamic,t.value]]),l.after.length>0?(e.openBlock(),e.createBlock(L,{key:3,"icon-class":l.after,onClick:c},null,8,["icon-class"])):e.renderSlot(w.$slots,"suffix",{key:4})],2))}}},Symbol.toStringTag,{value:"Module"})),ve={key:0},je=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwMessage",props:e.mergeModels({name:{type:String,default:""},class:{type:String,default:""},iconAfter:{type:String,default:""}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(s){const n=e.useModel(s,"modelValue"),t=s,l=e.ref(null),o=e.useSlots(),d=u=>{l.value&&!l.value.contains(u.target)&&(n.value=!1)};return e.watch(()=>n.value,async u=>{u?(await e.nextTick(),window.addEventListener("click",d,!0)):window.removeEventListener("click",d)}),e.onUnmounted(()=>{window.removeEventListener("click",d)}),(u,p)=>{var g;const c=e.resolveComponent("svg-icon");return n.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["sw-message",t.class]),ref_key:"messageRef",ref:l},[t.name.length>0||(g=e.unref(o))!=null&&g.header?(e.openBlock(),e.createElementBlock("header",ve,[e.renderSlot(u.$slots,"header",{},()=>[e.createTextVNode(e.toDisplayString(t.name)+" ",1),e.createVNode(G,{link:"",type:"primary",onClick:p[0]||(p[0]=M=>n.value=!1)},{default:e.withCtx(()=>[e.createVNode(c,{"icon-class":t.iconAfter},null,8,["icon-class"])]),_:1})])])):e.createCommentVNode("",!0),e.renderSlot(u.$slots,"default"),e.createElementVNode("footer",null,[e.renderSlot(u.$slots,"footer")])],2)):e.createCommentVNode("",!0)}}}},Symbol.toStringTag,{value:"Module"})),Oe=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwSection",props:{name:{type:String,default:""},class:{type:String,default:""},iconAfter:{type:String,default:""}},emits:["header"],setup(s,{emit:n}){const t=s,l=n,o=()=>{l("header")};return(d,u)=>{const p=e.resolveComponent("svg-icon");return e.openBlock(),e.createElementBlock("section",{class:e.normalizeClass(t.class)},[e.createElementVNode("header",{onClick:o},[e.renderSlot(d.$slots,"header",{},()=>[e.createTextVNode(e.toDisplayString(t.name)+" ",1),e.createVNode(p,{"icon-class":t.iconAfter},null,8,["icon-class"])])]),e.renderSlot(d.$slots,"default"),e.createElementVNode("footer",null,[e.renderSlot(d.$slots,"footer")])],2)}}}},Symbol.toStringTag,{value:"Module"})),Pe={class:"popup"},Fe={class:"wrapper"},Ie={class:"scrollbar"},Le=["onClick"],Ae=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwSelect",props:e.mergeModels({class:{type:String,default:""},size:{type:String,default:"large"},placeholder:{type:String,default:""},token:{type:String,default:""}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(s){const n=e.ref({fullText:""}),t=e.ref(!1),l=e.ref([]),o=e.useModel(s,"modelValue"),d=s;e.watch(o.text,c=>{c.length>3&&(n.value.fullText=c)}),e.watch(n.value.fullText,(c,g)=>{t.value=c.length>3&&c.length>g.length,c.length>3&&u()});const u=()=>{let c="https://suggestions.dadata.ru/suggestions/api/4_1/rs/suggest/address";console.log(n.value.fullText),axios.post(c,{query:n.value.fullText},{headers:{"Content-Type":"application/json",Accept:"application/json",Authorization:"Token "+d.token}}).then(g=>{console.log(g.data.suggestions),l.value=g.data.suggestions,l.value.length===1&&p(l.value[0])}).catch(g=>{console.log(g)})},p=c=>{n.value.fullText=c.value,t.value=!1;const g={};g.text=c.value,g.coords=[Number(c.data.geo_lat),Number(c.data.geo_lon)],g.suggestion=c.data,o.value=g};return(c,g)=>{const M=e.resolveComponent("sw-input");return e.openBlock(),e.createElementBlock("div",Pe,[e.createVNode(M,{size:d.size,modelValue:n.value.fullText,"onUpdate:modelValue":g[0]||(g[0]=E=>n.value.fullText=E),placeholder:s.placeholder},null,8,["size","modelValue","placeholder"]),e.withDirectives(e.createElementVNode("div",Fe,[e.createElementVNode("ul",Ie,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(l.value,(E,m)=>(e.openBlock(),e.createElementBlock("li",{tabindex:"1",key:m,onClick:w=>p(E)},e.toDisplayString(E.value),9,Le))),128))])],512),[[e.vShow,t.value]])])}}}},Symbol.toStringTag,{value:"Module"})),Ye={key:0},X={__name:"SwSkeletonItem",props:{width:{type:String,default:"100"},class:{type:String,default:""},animate:{type:Boolean,default:!1},size:{type:String,default:""}},setup(s){const n=s,t=e.computed(()=>{let o=["sw-skeleton-item"];return n.size.length>0&&o.push("sw-"+n.size),n.animate&&o.push("sw-animate"),n.class.length>0&&o.push(n.class),o}),l=e.computed(()=>({width:n.width+"%"}));return(o,d)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(t.value),style:e.normalizeStyle(l.value)},[n.animate?(e.openBlock(),e.createElementBlock("div",Ye)):e.createCommentVNode("",!0)],6))}},Re=Object.freeze(Object.defineProperty({__proto__:null,default:X},Symbol.toStringTag,{value:"Module"})),He=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwSkeleton",props:{class:{type:String,default:""},visual:{type:Boolean,default:!1}},setup(s){const n=s;return(t,l)=>n.visual?e.renderSlot(t.$slots,"default",{key:0}):(e.openBlock(),e.createElementBlock("div",{key:1,class:e.normalizeClass(["sw-skeleton",n.class])},[e.renderSlot(t.$slots,"skeleton",{},()=>[e.createVNode(X,{animate:"",size:"small"})])],2))}}},Symbol.toStringTag,{value:"Module"})),qe=["name","id"],Ue=["for","data-onlabel","data-offlabel"],We=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwSwitch",props:e.mergeModels({id:{type:String,default:"checkbox"},class:{type:String,default:""},name:{type:String,default:""},on:{type:String,default:""},off:{type:String,default:""},size:{type:String,default:""},checkbox:{type:Boolean,default:!1}},{modelValue:{},modelModifiers:{}}),emits:["update:modelValue"],setup(s){const n=e.useModel(s,"modelValue"),t=s,l=e.computed(()=>{let o=["sw-switch"];return t.size.length>0&&o.push("sw-"+t.size),t.checkbox&&o.push("sw-checkbox"),t.class.length>0&&o.push(t.class),o});return(o,d)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(l.value)},[e.withDirectives(e.createElementVNode("input",{type:"checkbox",name:t.name,class:"sw-control",id:t.id,"onUpdate:modelValue":d[0]||(d[0]=u=>n.value=u)},null,8,qe),[[e.vModelCheckbox,n.value]]),e.createElementVNode("label",{for:t.id,class:"sw-label","data-onlabel":t.on,"data-offlabel":t.off},null,8,Ue),e.renderSlot(o.$slots,"default")],2))}}},Symbol.toStringTag,{value:"Module"})),Ge={key:0},Xe=["onClick"],Je=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwTabs",props:e.mergeModels({class:{type:String,default:""}},{modelValue:{},modelModifiers:{}}),emits:e.mergeModels(["tab-click"],["update:modelValue"]),setup(s,{emit:n}){e.ref(0);const t=e.ref([]),l=s,o=e.useModel(s,"modelValue"),d=n;function u(c){t.value.push(c)}function p(c){t.value=t.value.filter(g=>g!==c)}return e.provide("registerTab",u),e.provide("unregisterTab",p),e.provide("activeTab",o),e.provide("tabs",t),(c,g)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass("sw-tabs "+l.class)},[t.value.length!==0?(e.openBlock(),e.createElementBlock("header",Ge,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(t.value,(M,E)=>(e.openBlock(),e.createElementBlock("span",{key:E,class:e.normalizeClass([{active:o.value===E}]),onClick:m=>{o.value=E,d("tab-click",E)}},e.toDisplayString(M.label||M.title),11,Xe))),128))])):e.createCommentVNode("",!0),e.renderSlot(c.$slots,"default")],2))}}},Symbol.toStringTag,{value:"Module"})),Qe={key:0,class:"tab-content"},Ze=Object.freeze(Object.defineProperty({__proto__:null,default:{__name:"SwTabsPane",props:{title:{type:String,required:!0},label:{type:String,default:""}},setup(s){const n=s,t=e.inject("registerTab"),l=e.inject("unregisterTab");e.onMounted(()=>{t({title:n.title,label:n.label})}),e.onUnmounted(()=>{l({title:n.title,label:n.label})});const o=e.inject("activeTab"),d=e.inject("tabs"),u=e.computed(()=>d.value.findIndex(c=>c.title===n.title)),p=e.computed(()=>o.value===u.value);return(c,g)=>p.value?(e.openBlock(),e.createElementBlock("div",Qe,[e.renderSlot(c.$slots,"default")])):e.createCommentVNode("",!0)}}},Symbol.toStringTag,{value:"Module"}));v.Alert=R,v.Library=se,v.components=A,Object.defineProperty(v,Symbol.toStringTag,{value:"Module"})});
|
package/dist/index.js
CHANGED
package/package.json
CHANGED
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
import { mergeModels as O, useModel as B, ref as v, computed as V, watchEffect as P, onMounted as N, onUnmounted as U, createElementBlock as $, openBlock as b, withModifiers as E, normalizeClass as z, renderSlot as M, createBlock as D, Teleport as X, createCommentVNode as Y, normalizeStyle as j, unref as q } from "vue";
|
|
2
|
-
const A = ["id"], G = {
|
|
3
|
-
__name: "SwDropdown",
|
|
4
|
-
props: /* @__PURE__ */ O({
|
|
5
|
-
class: { type: String, default: "" },
|
|
6
|
-
size: { type: String, default: "" },
|
|
7
|
-
type: { type: String, default: "" },
|
|
8
|
-
trigger: { type: String, default: "click" },
|
|
9
|
-
placement: { type: String, default: "bottom-left" },
|
|
10
|
-
maxWidth: { type: Number, default: 0 }
|
|
11
|
-
}, {
|
|
12
|
-
modelValue: {},
|
|
13
|
-
modelModifiers: {}
|
|
14
|
-
}),
|
|
15
|
-
emits: ["update:modelValue"],
|
|
16
|
-
setup(k, { expose: S }) {
|
|
17
|
-
const s = k, i = B(k, "modelValue"), p = v(null), r = v(null), w = v({}), x = Math.ceil(Math.random() * 1e3), m = v(0), C = V(
|
|
18
|
-
() => {
|
|
19
|
-
let n = ["sw-dropdown"];
|
|
20
|
-
return s.size.length > 0 && n.push("sw-" + s.size), s.type.length > 0 && n.push("sw-" + s.type), n;
|
|
21
|
-
}
|
|
22
|
-
), g = new ResizeObserver((n) => {
|
|
23
|
-
i.value && m.value++;
|
|
24
|
-
});
|
|
25
|
-
P(
|
|
26
|
-
() => {
|
|
27
|
-
if (console.log("watchEffect"), !i.value || !r.value || !p.value) {
|
|
28
|
-
w.value = {};
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
g.observe(r.value), m.value;
|
|
32
|
-
let n = window.pageYOffset || document.documentElement.scrollTop, l = window.pageXOffset || document.documentElement.scrollLeft;
|
|
33
|
-
document.body.style.position = "fixed", document.body.style.top = `-${n}px`, document.body.style.left = `-${l}px`, document.body.style.position = "", document.body.style.top = "", document.body.style.left = "", document.documentElement.scrollTop = n, document.documentElement.scrollLeft = l;
|
|
34
|
-
const e = p.value.getBoundingClientRect();
|
|
35
|
-
let h = window.innerWidth, y = window.innerHeight, d = r.value.offsetHeight, c = r.value.offsetWidth, t = e.left + e.width / 2 + l, o = e.top + e.height / 2 + n, a = e.height / 2 + 8;
|
|
36
|
-
const [T, H] = s.placement.split("-", 2);
|
|
37
|
-
switch (T) {
|
|
38
|
-
case "bottom":
|
|
39
|
-
o = n + y - d - a - 8 < o ? o - a - d : o + a;
|
|
40
|
-
break;
|
|
41
|
-
case "top":
|
|
42
|
-
o = n + d + a + 8 > o ? o + a : o - a - d;
|
|
43
|
-
break;
|
|
44
|
-
case "left":
|
|
45
|
-
t = t - c - e.width / 2 - 8, o = o - d / 2;
|
|
46
|
-
break;
|
|
47
|
-
case "right":
|
|
48
|
-
t = t + e.width / 2 + 8, o = o - d / 2;
|
|
49
|
-
break;
|
|
50
|
-
}
|
|
51
|
-
switch (H) {
|
|
52
|
-
case "left":
|
|
53
|
-
t = l + h - 8 > t - e.width / 2 + c ? t - e.width / 2 : t - c + e.width / 2;
|
|
54
|
-
break;
|
|
55
|
-
case "right":
|
|
56
|
-
t = 8 < t + e.width / 2 - c ? t - c + e.width / 2 : t - e.width / 2;
|
|
57
|
-
break;
|
|
58
|
-
}
|
|
59
|
-
t + c > h && (t = h - c), t < 0 && (t = 0), o + d > y && (o = y - d), o < 0 && (o = 0), w.value = {
|
|
60
|
-
position: "absolute",
|
|
61
|
-
top: `${o}px`,
|
|
62
|
-
left: `${t}px`,
|
|
63
|
-
maxWidth: s.maxWidth === 0 ? "" : `${s.maxWidth}px`
|
|
64
|
-
};
|
|
65
|
-
},
|
|
66
|
-
{ flush: "post" }
|
|
67
|
-
);
|
|
68
|
-
const R = () => {
|
|
69
|
-
s.trigger === "click" && (i.value = !i.value), console.log("click");
|
|
70
|
-
}, L = () => {
|
|
71
|
-
s.trigger === "hover" && (i.value = !i.value);
|
|
72
|
-
}, W = () => {
|
|
73
|
-
s.trigger === "context" && (i.value = !i.value);
|
|
74
|
-
}, u = () => {
|
|
75
|
-
i.value && m.value++, console.log("positionPopup", m.value);
|
|
76
|
-
};
|
|
77
|
-
S({ handleResize: u });
|
|
78
|
-
const f = (n) => {
|
|
79
|
-
!n.target.closest(`[id="${x}"]`) && p.value && !p.value.contains(n.target) && (i.value = !1);
|
|
80
|
-
};
|
|
81
|
-
return N(() => {
|
|
82
|
-
console.log("onMounted"), r.value && g.observe(r.value), window.addEventListener("resize", u), document.documentElement.ontouchstart !== void 0 ? document.documentElement.addEventListener("touchstart", f) : document.documentElement.addEventListener("click", f), window.onscrollend !== void 0 ? window.addEventListener("scrollend", u) : window.addEventListener("scroll", u);
|
|
83
|
-
}), U(() => {
|
|
84
|
-
console.log("onUnmounted"), g.disconnect(), window.removeEventListener("resize", u), document.documentElement.ontouchstart !== void 0 ? document.documentElement.removeEventListener("touchstart", f) : document.documentElement.removeEventListener("click", f), window.onscrollend !== void 0 ? window.removeEventListener("scrollend", u) : window.removeEventListener("scroll", u);
|
|
85
|
-
}), (n, l) => (b(), $("div", {
|
|
86
|
-
class: z(C.value),
|
|
87
|
-
onClick: l[0] || (l[0] = (e) => R()),
|
|
88
|
-
onMouseover: l[1] || (l[1] = E((e) => L(), ["stop"])),
|
|
89
|
-
onMouseleave: l[2] || (l[2] = E((e) => L(), ["stop"])),
|
|
90
|
-
onContextmenu: l[3] || (l[3] = E((e) => W(), ["stop"])),
|
|
91
|
-
ref_key: "dropdownRef",
|
|
92
|
-
ref: p
|
|
93
|
-
}, [
|
|
94
|
-
M(n.$slots, "default"),
|
|
95
|
-
(b(), D(X, { to: "body" }, [
|
|
96
|
-
i.value ? (b(), $("ul", {
|
|
97
|
-
key: 0,
|
|
98
|
-
ref_key: "popupRef",
|
|
99
|
-
ref: r,
|
|
100
|
-
id: q(x),
|
|
101
|
-
class: z(["sw-dropdown-popup", s.class]),
|
|
102
|
-
style: j(w.value),
|
|
103
|
-
tabindex: "-1"
|
|
104
|
-
}, [
|
|
105
|
-
M(n.$slots, "dropdown")
|
|
106
|
-
], 14, A)) : Y("", !0)
|
|
107
|
-
]))
|
|
108
|
-
], 34));
|
|
109
|
-
}
|
|
110
|
-
};
|
|
111
|
-
export {
|
|
112
|
-
G as default
|
|
113
|
-
};
|