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