@studio-west/component-sw 0.5.50 → 0.5.52

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