1
0
mirror of https://github.com/ZeroCatDev/Classworks.git synced 2026-03-21 09:13:10 +00:00
Classworks/assets/VTabs-BRmwp2-j.js

2 lines
5.0 KiB
JavaScript

import{H as q,I as j,h as M,E as J,J as K,K as L,L as Q,m as Z,M as p}from"./index-C2sjQt3C.js";import{e as F,a as ee,V as te}from"./VTable-xbJIIn5x.js";import{f as G,u as W,a4 as ae,p as X,a5 as ne,a6 as se,n as le,j as ie,s as E,aj as oe,F as re}from"./vendor-vuetify-DYDJMXkZ.js";import{j as T,k as D,N as de,n as ue,F as Y,m as P,b as R,e as N,t as r}from"./vendor-vue-PFj_oO9L.js";import{b as I,m as ce}from"./VChip-C5r6iPJT.js";const _=X({fixed:Boolean,sliderColor:String,sliderTransition:String,sliderTransitionDuration:[String,Number],hideSlider:Boolean,inset:Boolean,direction:{type:String,default:"horizontal"},...ne(K({selectedClass:"v-tab--selected",variant:"text"}),["active","block","flat","location","position","symbol"])},"VTab"),ve=G()({name:"VTab",props:_(),setup(e,d){let{slots:C,attrs:t}=d;const{textColorClasses:g,textColorStyles:k}=q(()=>e.sliderColor),{backgroundColorClasses:V,backgroundColorStyles:w}=j(()=>e.sliderColor),h=R(),x=R(),u=N(()=>e.direction==="horizontal"),m=N(()=>{var s,n;return((n=(s=h.value)==null?void 0:s.group)==null?void 0:n.isSelected.value)??!1});function a(s,n){return{opacity:[0,1]}}function l(s,n){return e.direction==="vertical"?{transform:["scaleY(0)","scaleY(1)"]}:{transform:["scaleX(0)","scaleX(1)"]}}function c(s,n){const i=n.getBoundingClientRect(),o=s.getBoundingClientRect(),v=u.value?"x":"y",b=u.value?"X":"Y",S=u.value?"right":"bottom",f=u.value?"width":"height",$=i[v],H=o[v],y=$>H?i[S]-o[S]:i[v]-o[v],U=Math.sign(y)>0?u.value?"right":"bottom":Math.sign(y)<0?u.value?"left":"top":"center",A=(Math.abs(y)+(Math.sign(y)<0?i[f]:o[f]))/Math.max(i[f],o[f])||0,O=i[f]/o[f]||0,z=1.5;return{transform:[`translate${b}(${y}px) scale${b}(${O})`,`translate${b}(${y/z}px) scale${b}(${(A-1)/z+1})`,"none"],transformOrigin:Array(3).fill(U)}}function B(s){var i,o;let{value:n}=s;if(n){const v=(o=(i=h.value)==null?void 0:i.$el.parentElement)==null?void 0:o.querySelector(".v-tab--selected .v-tab__slider"),b=x.value;if(!v||!b)return;const S=getComputedStyle(v).backgroundColor,f={fade:a,grow:l,shift:c}[e.sliderTransition??"shift"]??c,$=Number(e.sliderTransitionDuration)||({fade:400,grow:350,shift:225}[e.sliderTransition??"shift"]??225);ae(b,{backgroundColor:[S,S],...f(b,v)},{duration:$,easing:se})}}return W(()=>{const s=M.filterProps(e);return T(M,P({symbol:F,ref:h,class:["v-tab",e.class,m.value&&e.inset?V.value:[]],style:[e.style,m.value&&e.inset?w.value:[],{backgroundColor:m.value&&e.inset?"transparent !important":void 0}],tabindex:m.value?0:-1,role:"tab","aria-selected":String(m.value),active:!1},s,t,{block:e.fixed,maxWidth:e.fixed?300:void 0,"onGroup:selected":B}),{...C,default:()=>{var n;return D(Y,null,[((n=C.default)==null?void 0:n.call(C))??e.text,!e.hideSlider&&D("div",{ref:x,class:ue(["v-tab__slider",e.inset?V.value:g.value]),style:de([k.value,e.inset?w.value:g.value])},null)])}})}),J({},h)}});function be(e){return e?e.map(d=>re(d)?d:{text:d,value:d}):[]}const fe=X({alignTabs:{type:String,default:"start"},color:String,fixedTabs:Boolean,items:{type:Array,default:()=>[]},stacked:Boolean,bgColor:String,grow:Boolean,height:{type:[Number,String],default:void 0},hideSlider:Boolean,inset:Boolean,insetPadding:[String,Number],insetRadius:[String,Number],sliderColor:String,...oe(_(),["spaced","sliderTransition","sliderTransitionDuration"]),...ce({mandatory:"force",selectedClass:"v-tab-item--selected"}),...p(),...Z()},"VTabs"),Se=G()({name:"VTabs",props:fe(),emits:{"update:modelValue":e=>!0},setup(e,d){let{attrs:C,slots:t}=d;const g=le(e,"modelValue"),k=N(()=>be(e.items)),{densityClasses:V}=L(e),{backgroundColorClasses:w,backgroundColorStyles:h}=j(()=>e.bgColor),{scopeId:x}=Q();return ie({VTab:{color:r(e,"color"),direction:r(e,"direction"),stacked:r(e,"stacked"),fixed:r(e,"fixedTabs"),inset:r(e,"inset"),sliderColor:r(e,"sliderColor"),sliderTransition:r(e,"sliderTransition"),sliderTransitionDuration:r(e,"sliderTransitionDuration"),hideSlider:r(e,"hideSlider")}}),W(()=>{const u=I.filterProps(e),m=!!(t.window||e.items.length>0);return D(Y,null,[T(I,P(u,{modelValue:g.value,"onUpdate:modelValue":a=>g.value=a,class:["v-tabs",`v-tabs--${e.direction}`,`v-tabs--align-tabs-${e.alignTabs}`,{"v-tabs--fixed-tabs":e.fixedTabs,"v-tabs--grow":e.grow,"v-tabs--inset":e.inset,"v-tabs--stacked":e.stacked},V.value,w.value,e.class],style:[{"--v-tabs-height":E(e.height),"--v-tabs-inset-padding":e.inset?E(e.insetPadding):void 0,"--v-tabs-inset-radius":e.inset?E(e.insetRadius):void 0},h.value,e.style],role:"tablist",symbol:F},x,C),{default:t.default??(()=>k.value.map(a=>{var l;return((l=t.tab)==null?void 0:l.call(t,{item:a}))??T(ve,P(a,{key:a.text,value:a.value,spaced:e.spaced}),{default:t[`tab.${a.value}`]?()=>{var c;return(c=t[`tab.${a.value}`])==null?void 0:c.call(t,{item:a})}:void 0})})),prev:t.prev,next:t.next}),m&&T(te,P({modelValue:g.value,"onUpdate:modelValue":a=>g.value=a,key:"tabs-window"},x),{default:()=>{var a;return[k.value.map(l=>{var c;return((c=t.item)==null?void 0:c.call(t,{item:l}))??T(ee,{value:l.value},{default:()=>{var B;return(B=t[`item.${l.value}`])==null?void 0:B.call(t,{item:l})}})}),(a=t.window)==null?void 0:a.call(t)]}})])}),{}}});export{Se as V,ve as a};