@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.
@@ -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-C9GeHmDw.js";
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-C9GeHmDw.js";
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-CdHun-yT.js"), "./components/SwDropdown.vue": () => import("./SwDropdown-CTYMdMot.js"), "./components/SwDropdownItem.vue": () => import("./SwDropdownItem-wFMHwJJk.js"), "./components/SwFormItem.vue": () => import("./SwFormItem-CaA4jsoa.js"), "./components/SwInput.vue": () => import("./SwInput-XYCew4uT.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 = {};
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
@@ -1,5 +1,5 @@
1
1
  import "vue";
2
- import { A as s, L as t, c as e } from "./index-C9GeHmDw.js";
2
+ import { A as s, L as t, c as e } from "./index-BX3qWVnL.js";
3
3
  export {
4
4
  s as Alert,
5
5
  t as Library,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@studio-west/component-sw",
3
- "version": "0.5.56",
3
+ "version": "0.5.58",
4
4
  "description": "Vue components of Component SW collection.",
5
5
  "type": "module",
6
6
  "keywords": [
@@ -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
- };