tokentracker-cli 0.30.0 → 0.31.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.ja.md +3 -1
- package/README.ko.md +3 -1
- package/README.md +3 -1
- package/README.zh-CN.md +3 -1
- package/dashboard/dist/assets/{ActivityHeatmap-BzW0rtoR.js → ActivityHeatmap-BjiEMIl2.js} +1 -1
- package/dashboard/dist/assets/{Card-wgEcKm5u.js → Card-Nlgzr57Q.js} +1 -1
- package/dashboard/dist/assets/DashboardPage-z7rLj1gX.js +19 -0
- package/dashboard/dist/assets/{DevicePage-D82cqG-v.js → DevicePage-B1NhBt9Q.js} +1 -1
- package/dashboard/dist/assets/DialogTitle-CEBn-oBo.js +12 -0
- package/dashboard/dist/assets/FadeIn-Dbk47nhk.js +1 -0
- package/dashboard/dist/assets/{HeaderGithubStar-CSBGOKw2.js → HeaderGithubStar-B0OAKXVw.js} +1 -1
- package/dashboard/dist/assets/{IpCheckPage-WXEmhuVW.js → IpCheckPage-C0wQLtdK.js} +1 -1
- package/dashboard/dist/assets/{LandingPage-ap4xIJva.js → LandingPage-DWSbmVip.js} +2 -2
- package/dashboard/dist/assets/{LeaderboardAvatar-CjaHOh8E.js → LeaderboardAvatar-CLMnffKE.js} +1 -1
- package/dashboard/dist/assets/LeaderboardPage-CZvefN8H.js +6 -0
- package/dashboard/dist/assets/{LeaderboardProfileModal-BX4b5Uqc.js → LeaderboardProfileModal-DasxA8Lo.js} +3 -3
- package/dashboard/dist/assets/LeaderboardProfilePage-DJJ7l3Ix.js +1 -0
- package/dashboard/dist/assets/LimitsPage-xUmhxOqT.js +2 -0
- package/dashboard/dist/assets/{LocalOnlyNotice-D43ZmQJl.js → LocalOnlyNotice-B3uM29rj.js} +1 -1
- package/dashboard/dist/assets/{LoginPage-gqSOnPUr.js → LoginPage-BejL6eIO.js} +1 -1
- package/dashboard/dist/assets/PopoverPopup-V6vxWbIV.js +1 -0
- package/dashboard/dist/assets/SettingsPage-DossFM4s.js +1 -0
- package/dashboard/dist/assets/SkillsPage-COwiRUo1.js +1 -0
- package/dashboard/dist/assets/WidgetsPage-CtkM_RQn.js +1 -0
- package/dashboard/dist/assets/WrappedPage-BpXrsSoG.js +1 -0
- package/dashboard/dist/assets/agent-logos-D6Jmq7E1.js +1 -0
- package/dashboard/dist/assets/{arrow-up-right-BXWeIpuU.js → arrow-up-right-BS0sCPTz.js} +1 -1
- package/dashboard/dist/assets/check-DKwh5hl-.js +1 -0
- package/dashboard/dist/assets/{chevron-down-u-JNpncG.js → chevron-down-DyiXbuAL.js} +1 -1
- package/dashboard/dist/assets/{download-DvfHniid.js → download-CqDWRO99.js} +1 -1
- package/dashboard/dist/assets/{info-BdrJIus6.js → info-DMW1GFmI.js} +1 -1
- package/dashboard/dist/assets/main-CjFrTufR.css +1 -0
- package/dashboard/dist/assets/main-uqC1VAKB.js +959 -0
- package/dashboard/dist/assets/{use-limits-display-prefs-DU4WDeXF.js → use-limits-display-prefs-C04zvO7N.js} +1 -1
- package/dashboard/dist/assets/{use-native-settings-CefuRE0t.js → use-native-settings-BvFr6zgZ.js} +1 -1
- package/dashboard/dist/assets/{use-usage-limits-BvZsTD3e.js → use-usage-limits-5fwy0xeB.js} +1 -1
- package/dashboard/dist/assets/useCurrency-vRzRfd7L.js +1 -0
- package/dashboard/dist/index.html +2 -2
- package/dashboard/dist/share.html +2 -2
- package/package.json +1 -1
- package/src/lib/local-api.js +67 -0
- package/src/lib/pricing/seed-snapshot.json +1 -1
- package/src/lib/skill-usage.js +267 -0
- package/src/lib/skills-manager.js +371 -13
- package/dashboard/dist/assets/DashboardPage-BH_InuuJ.js +0 -19
- package/dashboard/dist/assets/DialogTitle-QumMNQjm.js +0 -12
- package/dashboard/dist/assets/FadeIn-B2rj5E5l.js +0 -1
- package/dashboard/dist/assets/LeaderboardPage-DN4Sd56j.js +0 -6
- package/dashboard/dist/assets/LeaderboardProfilePage-hkIYzooc.js +0 -1
- package/dashboard/dist/assets/LimitsPage-BgoAXuwU.js +0 -2
- package/dashboard/dist/assets/PopoverPopup-BkMR2-Ij.js +0 -1
- package/dashboard/dist/assets/ProviderIcon-No-nxvR1.js +0 -1
- package/dashboard/dist/assets/SettingsPage-BVpnWPq9.js +0 -1
- package/dashboard/dist/assets/SkillsPage-DnIxIt1d.js +0 -1
- package/dashboard/dist/assets/WidgetsPage-DY7qT8jg.js +0 -1
- package/dashboard/dist/assets/WrappedPage-BTkoEQPM.js +0 -1
- package/dashboard/dist/assets/agent-logos-Dp5LiRgu.js +0 -1
- package/dashboard/dist/assets/check-B_JRaxbD.js +0 -1
- package/dashboard/dist/assets/main-BojOq9Ae.css +0 -1
- package/dashboard/dist/assets/main-DhcQGvkP.js +0 -917
- package/dashboard/dist/assets/use-reduced-motion-nzFM1j1r.js +0 -1
- package/dashboard/dist/assets/useCurrency-C62kk8HZ.js +0 -1
package/dashboard/dist/assets/{LeaderboardAvatar-CjaHOh8E.js → LeaderboardAvatar-CLMnffKE.js}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{R as l,u as c,
|
|
1
|
+
import{R as l,u as c,N as h}from"./main-uqC1VAKB.js";function x(n){let t=0;const e=String(n??"");for(let r=0;r<e.length;r+=1)t=Math.imul(31,t)+e.charCodeAt(r)|0;return Math.abs(t)%360}function d(n){const t=String(n??"").trim();if(!t)return"?";const e=t.split(/\s+/).filter(Boolean);if(e.length>=2){const r=e[0][0]||"",i=e[1][0]||"";return`${r}${i}`.toUpperCase()}return t.slice(0,2).toUpperCase()}const m={sm:"h-7 w-7 min-h-7 min-w-7 text-[10px]",md:"h-8 w-8 min-h-8 min-w-8 text-[11px]",lg:"h-14 w-14 min-h-14 min-w-14 text-base",xl:"h-[68px] w-[68px] min-h-[68px] min-w-[68px] text-xl"};function g({avatarUrl:n,displayName:t,seed:e,size:r="md",className:i}){const o=m[r]||m.md,u=x(e??t??""),s=typeof n=="string"?n.trim():"",[f,a]=l.useState(!1);return l.useEffect(()=>{a(!1)},[s]),s&&!f?c.jsx("img",{src:s,alt:"",referrerPolicy:"no-referrer",onError:()=>a(!0),className:h("rounded-full object-cover ring-1 ring-white/10",o,i)}):c.jsx("div",{className:h("flex shrink-0 items-center justify-center rounded-full font-semibold text-white ring-1 ring-white/10",o,i),style:{backgroundColor:`hsl(${u} 42% 34%)`},"aria-hidden":!0,children:d(t)})}export{g as L};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/LeaderboardProfileModal-DasxA8Lo.js","assets/main-uqC1VAKB.js","assets/main-CjFrTufR.css","assets/useCurrency-vRzRfd7L.js","assets/LeaderboardAvatar-CLMnffKE.js","assets/ActivityHeatmap-BjiEMIl2.js","assets/info-DMW1GFmI.js","assets/arrow-up-right-BS0sCPTz.js","assets/check-DKwh5hl-.js","assets/DialogTitle-CEBn-oBo.js"])))=>i.map(i=>d[i]);
|
|
2
|
+
import{c as Zr,r as i,R as q,M as rt,u as l,N as T,s as y,ai as Qr,aj as en,O as tn,Q as rn,ak as nn,i as on,a as an,al as sn,U as ln,A as cn,P as dn,L as un,D as fn,a4 as wr,B as gn,am as hn,an as bn,ao as Zt,ap as pn,_ as mn,E as xn}from"./main-uqC1VAKB.js";import{u as vn}from"./useCurrency-vRzRfd7L.js";import{L as Tt}from"./LeaderboardAvatar-CLMnffKE.js";import{C as yn}from"./chevron-down-DyiXbuAL.js";const wn=[["path",{d:"M5 12h14",key:"1ays0h"}],["path",{d:"m12 5 7 7-7 7",key:"xquz4c"}]],kn=Zr("arrow-right",wn);function Sn(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return i.useMemo(()=>n=>{t.forEach(o=>o(n))},t)}const kt=typeof window<"u"&&typeof window.document<"u"&&typeof window.document.createElement<"u";function Ye(e){const t=Object.prototype.toString.call(e);return t==="[object Window]"||t==="[object global]"}function Yt(e){return"nodeType"in e}function J(e){var t,r;return e?Ye(e)?e:Yt(e)&&(t=(r=e.ownerDocument)==null?void 0:r.defaultView)!=null?t:window:window}function Wt(e){const{Document:t}=J(e);return e instanceof t}function ut(e){return Ye(e)?!1:e instanceof J(e).HTMLElement}function kr(e){return e instanceof J(e).SVGElement}function We(e){return e?Ye(e)?e.document:Yt(e)?Wt(e)?e:ut(e)||kr(e)?e.ownerDocument:document:document:document}const me=kt?i.useLayoutEffect:i.useEffect;function Xt(e){const t=i.useRef(e);return me(()=>{t.current=e}),i.useCallback(function(){for(var r=arguments.length,n=new Array(r),o=0;o<r;o++)n[o]=arguments[o];return t.current==null?void 0:t.current(...n)},[])}function Nn(){const e=i.useRef(null),t=i.useCallback((n,o)=>{e.current=setInterval(n,o)},[]),r=i.useCallback(()=>{e.current!==null&&(clearInterval(e.current),e.current=null)},[]);return[t,r]}function it(e,t){t===void 0&&(t=[e]);const r=i.useRef(e);return me(()=>{r.current!==e&&(r.current=e)},t),r}function ft(e,t){const r=i.useRef();return i.useMemo(()=>{const n=e(r.current);return r.current=n,n},[...t])}function mt(e){const t=Xt(e),r=i.useRef(null),n=i.useCallback(o=>{o!==r.current&&t?.(o,r.current),r.current=o},[]);return[r,n]}function Lt(e){const t=i.useRef();return i.useEffect(()=>{t.current=e},[e]),t.current}let Et={};function gt(e,t){return i.useMemo(()=>{if(t)return t;const r=Et[e]==null?0:Et[e]+1;return Et[e]=r,e+"-"+r},[e,t])}function Sr(e){return function(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),o=1;o<r;o++)n[o-1]=arguments[o];return n.reduce((a,s)=>{const c=Object.entries(s);for(const[d,u]of c){const g=a[d];g!=null&&(a[d]=g+e*u)}return a},{...t})}}const Ke=Sr(1),st=Sr(-1);function Cn(e){return"clientX"in e&&"clientY"in e}function Ht(e){if(!e)return!1;const{KeyboardEvent:t}=J(e.target);return t&&e instanceof t}function Rn(e){if(!e)return!1;const{TouchEvent:t}=J(e.target);return t&&e instanceof t}function Ot(e){if(Rn(e)){if(e.touches&&e.touches.length){const{clientX:t,clientY:r}=e.touches[0];return{x:t,y:r}}else if(e.changedTouches&&e.changedTouches.length){const{clientX:t,clientY:r}=e.changedTouches[0];return{x:t,y:r}}}return Cn(e)?{x:e.clientX,y:e.clientY}:null}const lt=Object.freeze({Translate:{toString(e){if(!e)return;const{x:t,y:r}=e;return"translate3d("+(t?Math.round(t):0)+"px, "+(r?Math.round(r):0)+"px, 0)"}},Scale:{toString(e){if(!e)return;const{scaleX:t,scaleY:r}=e;return"scaleX("+t+") scaleY("+r+")"}},Transform:{toString(e){if(e)return[lt.Translate.toString(e),lt.Scale.toString(e)].join(" ")}},Transition:{toString(e){let{property:t,duration:r,easing:n}=e;return t+" "+r+"ms "+n}}}),Qt="a,frame,iframe,input:not([type=hidden]):not(:disabled),select:not(:disabled),textarea:not(:disabled),button:not(:disabled),*[tabindex]";function Dn(e){return e.matches(Qt)?e:e.querySelector(Qt)}const jn={display:"none"};function En(e){let{id:t,value:r}=e;return q.createElement("div",{id:t,style:jn},r)}function _n(e){let{id:t,announcement:r,ariaLiveType:n="assertive"}=e;const o={position:"fixed",top:0,left:0,width:1,height:1,margin:-1,border:0,padding:0,overflow:"hidden",clip:"rect(0 0 0 0)",clipPath:"inset(100%)",whiteSpace:"nowrap"};return q.createElement("div",{id:t,style:o,role:"status","aria-live":n,"aria-atomic":!0},r)}function An(){const[e,t]=i.useState("");return{announce:i.useCallback(n=>{n!=null&&t(n)},[]),announcement:e}}const Nr=i.createContext(null);function Mn(e){const t=i.useContext(Nr);i.useEffect(()=>{if(!t)throw new Error("useDndMonitor must be used within a children of <DndContext>");return t(e)},[e,t])}function In(){const[e]=i.useState(()=>new Set),t=i.useCallback(n=>(e.add(n),()=>e.delete(n)),[e]);return[i.useCallback(n=>{let{type:o,event:a}=n;e.forEach(s=>{var c;return(c=s[o])==null?void 0:c.call(s,a)})},[e]),t]}const Tn={draggable:`
|
|
3
|
+
To pick up a draggable item, press the space bar.
|
|
4
|
+
While dragging, use the arrow keys to move the item.
|
|
5
|
+
Press space again to drop the item in its new position, or press escape to cancel.
|
|
6
|
+
`},Ln={onDragStart(e){let{active:t}=e;return"Picked up draggable item "+t.id+"."},onDragOver(e){let{active:t,over:r}=e;return r?"Draggable item "+t.id+" was moved over droppable area "+r.id+".":"Draggable item "+t.id+" is no longer over a droppable area."},onDragEnd(e){let{active:t,over:r}=e;return r?"Draggable item "+t.id+" was dropped over droppable area "+r.id:"Draggable item "+t.id+" was dropped."},onDragCancel(e){let{active:t}=e;return"Dragging was cancelled. Draggable item "+t.id+" was dropped."}};function On(e){let{announcements:t=Ln,container:r,hiddenTextDescribedById:n,screenReaderInstructions:o=Tn}=e;const{announce:a,announcement:s}=An(),c=gt("DndLiveRegion"),[d,u]=i.useState(!1);if(i.useEffect(()=>{u(!0)},[]),Mn(i.useMemo(()=>({onDragStart(f){let{active:p}=f;a(t.onDragStart({active:p}))},onDragMove(f){let{active:p,over:h}=f;t.onDragMove&&a(t.onDragMove({active:p,over:h}))},onDragOver(f){let{active:p,over:h}=f;a(t.onDragOver({active:p,over:h}))},onDragEnd(f){let{active:p,over:h}=f;a(t.onDragEnd({active:p,over:h}))},onDragCancel(f){let{active:p,over:h}=f;a(t.onDragCancel({active:p,over:h}))}}),[a,t])),!d)return null;const g=q.createElement(q.Fragment,null,q.createElement(En,{id:n,value:o.draggable}),q.createElement(_n,{id:c,announcement:s}));return r?rt.createPortal(g,r):g}var z;(function(e){e.DragStart="dragStart",e.DragMove="dragMove",e.DragEnd="dragEnd",e.DragCancel="dragCancel",e.DragOver="dragOver",e.RegisterDroppable="registerDroppable",e.SetDroppableDisabled="setDroppableDisabled",e.UnregisterDroppable="unregisterDroppable"})(z||(z={}));function xt(){}function er(e,t){return i.useMemo(()=>({sensor:e,options:t??{}}),[e,t])}function Pn(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return i.useMemo(()=>[...t].filter(n=>n!=null),[...t])}const ue=Object.freeze({x:0,y:0});function Cr(e,t){return Math.sqrt(Math.pow(e.x-t.x,2)+Math.pow(e.y-t.y,2))}function Rr(e,t){let{data:{value:r}}=e,{data:{value:n}}=t;return r-n}function zn(e,t){let{data:{value:r}}=e,{data:{value:n}}=t;return n-r}function tr(e){let{left:t,top:r,height:n,width:o}=e;return[{x:t,y:r},{x:t+o,y:r},{x:t,y:r+n},{x:t+o,y:r+n}]}function Dr(e,t){if(!e||e.length===0)return null;const[r]=e;return r[t]}function rr(e,t,r){return t===void 0&&(t=e.left),r===void 0&&(r=e.top),{x:t+e.width*.5,y:r+e.height*.5}}const Bn=e=>{let{collisionRect:t,droppableRects:r,droppableContainers:n}=e;const o=rr(t,t.left,t.top),a=[];for(const s of n){const{id:c}=s,d=r.get(c);if(d){const u=Cr(rr(d),o);a.push({id:c,data:{droppableContainer:s,value:u}})}}return a.sort(Rr)},$n=e=>{let{collisionRect:t,droppableRects:r,droppableContainers:n}=e;const o=tr(t),a=[];for(const s of n){const{id:c}=s,d=r.get(c);if(d){const u=tr(d),g=o.reduce((p,h,w)=>p+Cr(u[w],h),0),f=Number((g/4).toFixed(4));a.push({id:c,data:{droppableContainer:s,value:f}})}}return a.sort(Rr)};function Fn(e,t){const r=Math.max(t.top,e.top),n=Math.max(t.left,e.left),o=Math.min(t.left+t.width,e.left+e.width),a=Math.min(t.top+t.height,e.top+e.height),s=o-n,c=a-r;if(n<o&&r<a){const d=t.width*t.height,u=e.width*e.height,g=s*c,f=g/(d+u-g);return Number(f.toFixed(4))}return 0}const Un=e=>{let{collisionRect:t,droppableRects:r,droppableContainers:n}=e;const o=[];for(const a of n){const{id:s}=a,c=r.get(s);if(c){const d=Fn(c,t);d>0&&o.push({id:s,data:{droppableContainer:a,value:d}})}}return o.sort(zn)};function Kn(e,t,r){return{...e,scaleX:t&&r?t.width/r.width:1,scaleY:t&&r?t.height/r.height:1}}function jr(e,t){return e&&t?{x:e.left-t.left,y:e.top-t.top}:ue}function Yn(e){return function(r){for(var n=arguments.length,o=new Array(n>1?n-1:0),a=1;a<n;a++)o[a-1]=arguments[a];return o.reduce((s,c)=>({...s,top:s.top+e*c.y,bottom:s.bottom+e*c.y,left:s.left+e*c.x,right:s.right+e*c.x}),{...r})}}const Wn=Yn(1);function Xn(e){if(e.startsWith("matrix3d(")){const t=e.slice(9,-1).split(/, /);return{x:+t[12],y:+t[13],scaleX:+t[0],scaleY:+t[5]}}else if(e.startsWith("matrix(")){const t=e.slice(7,-1).split(/, /);return{x:+t[4],y:+t[5],scaleX:+t[0],scaleY:+t[3]}}return null}function Hn(e,t,r){const n=Xn(t);if(!n)return e;const{scaleX:o,scaleY:a,x:s,y:c}=n,d=e.left-s-(1-o)*parseFloat(r),u=e.top-c-(1-a)*parseFloat(r.slice(r.indexOf(" ")+1)),g=o?e.width/o:e.width,f=a?e.height/a:e.height;return{width:g,height:f,top:u,right:d+g,bottom:u+f,left:d}}const Gn={ignoreTransform:!1};function Xe(e,t){t===void 0&&(t=Gn);let r=e.getBoundingClientRect();if(t.ignoreTransform){const{transform:u,transformOrigin:g}=J(e).getComputedStyle(e);u&&(r=Hn(r,u,g))}const{top:n,left:o,width:a,height:s,bottom:c,right:d}=r;return{top:n,left:o,width:a,height:s,bottom:c,right:d}}function nr(e){return Xe(e,{ignoreTransform:!0})}function Vn(e){const t=e.innerWidth,r=e.innerHeight;return{top:0,left:0,right:t,bottom:r,width:t,height:r}}function qn(e,t){return t===void 0&&(t=J(e).getComputedStyle(e)),t.position==="fixed"}function Jn(e,t){t===void 0&&(t=J(e).getComputedStyle(e));const r=/(auto|scroll|overlay)/;return["overflow","overflowX","overflowY"].some(o=>{const a=t[o];return typeof a=="string"?r.test(a):!1})}function St(e,t){const r=[];function n(o){if(t!=null&&r.length>=t||!o)return r;if(Wt(o)&&o.scrollingElement!=null&&!r.includes(o.scrollingElement))return r.push(o.scrollingElement),r;if(!ut(o)||kr(o)||r.includes(o))return r;const a=J(e).getComputedStyle(o);return o!==e&&Jn(o,a)&&r.push(o),qn(o,a)?r:n(o.parentNode)}return e?n(e):r}function Er(e){const[t]=St(e,1);return t??null}function _t(e){return!kt||!e?null:Ye(e)?e:Yt(e)?Wt(e)||e===We(e).scrollingElement?window:ut(e)?e:null:null}function _r(e){return Ye(e)?e.scrollX:e.scrollLeft}function Ar(e){return Ye(e)?e.scrollY:e.scrollTop}function Pt(e){return{x:_r(e),y:Ar(e)}}var F;(function(e){e[e.Forward=1]="Forward",e[e.Backward=-1]="Backward"})(F||(F={}));function Mr(e){return!kt||!e?!1:e===document.scrollingElement}function Ir(e){const t={x:0,y:0},r=Mr(e)?{height:window.innerHeight,width:window.innerWidth}:{height:e.clientHeight,width:e.clientWidth},n={x:e.scrollWidth-r.width,y:e.scrollHeight-r.height},o=e.scrollTop<=t.y,a=e.scrollLeft<=t.x,s=e.scrollTop>=n.y,c=e.scrollLeft>=n.x;return{isTop:o,isLeft:a,isBottom:s,isRight:c,maxScroll:n,minScroll:t}}const Zn={x:.2,y:.2};function Qn(e,t,r,n,o){let{top:a,left:s,right:c,bottom:d}=r;n===void 0&&(n=10),o===void 0&&(o=Zn);const{isTop:u,isBottom:g,isLeft:f,isRight:p}=Ir(e),h={x:0,y:0},w={x:0,y:0},m={height:t.height*o.y,width:t.width*o.x};return!u&&a<=t.top+m.height?(h.y=F.Backward,w.y=n*Math.abs((t.top+m.height-a)/m.height)):!g&&d>=t.bottom-m.height&&(h.y=F.Forward,w.y=n*Math.abs((t.bottom-m.height-d)/m.height)),!p&&c>=t.right-m.width?(h.x=F.Forward,w.x=n*Math.abs((t.right-m.width-c)/m.width)):!f&&s<=t.left+m.width&&(h.x=F.Backward,w.x=n*Math.abs((t.left+m.width-s)/m.width)),{direction:h,speed:w}}function eo(e){if(e===document.scrollingElement){const{innerWidth:a,innerHeight:s}=window;return{top:0,left:0,right:a,bottom:s,width:a,height:s}}const{top:t,left:r,right:n,bottom:o}=e.getBoundingClientRect();return{top:t,left:r,right:n,bottom:o,width:e.clientWidth,height:e.clientHeight}}function Tr(e){return e.reduce((t,r)=>Ke(t,Pt(r)),ue)}function to(e){return e.reduce((t,r)=>t+_r(r),0)}function ro(e){return e.reduce((t,r)=>t+Ar(r),0)}function no(e,t){if(t===void 0&&(t=Xe),!e)return;const{top:r,left:n,bottom:o,right:a}=t(e);Er(e)&&(o<=0||a<=0||r>=window.innerHeight||n>=window.innerWidth)&&e.scrollIntoView({block:"center",inline:"center"})}const oo=[["x",["left","right"],to],["y",["top","bottom"],ro]];class Gt{constructor(t,r){this.rect=void 0,this.width=void 0,this.height=void 0,this.top=void 0,this.bottom=void 0,this.right=void 0,this.left=void 0;const n=St(r),o=Tr(n);this.rect={...t},this.width=t.width,this.height=t.height;for(const[a,s,c]of oo)for(const d of s)Object.defineProperty(this,d,{get:()=>{const u=c(n),g=o[a]-u;return this.rect[d]+g},enumerable:!0});Object.defineProperty(this,"rect",{enumerable:!1})}}class nt{constructor(t){this.target=void 0,this.listeners=[],this.removeAll=()=>{this.listeners.forEach(r=>{var n;return(n=this.target)==null?void 0:n.removeEventListener(...r)})},this.target=t}add(t,r,n){var o;(o=this.target)==null||o.addEventListener(t,r,n),this.listeners.push([t,r,n])}}function ao(e){const{EventTarget:t}=J(e);return e instanceof t?e:We(e)}function At(e,t){const r=Math.abs(e.x),n=Math.abs(e.y);return typeof t=="number"?Math.sqrt(r**2+n**2)>t:"x"in t&&"y"in t?r>t.x&&n>t.y:"x"in t?r>t.x:"y"in t?n>t.y:!1}var oe;(function(e){e.Click="click",e.DragStart="dragstart",e.Keydown="keydown",e.ContextMenu="contextmenu",e.Resize="resize",e.SelectionChange="selectionchange",e.VisibilityChange="visibilitychange"})(oe||(oe={}));function or(e){e.preventDefault()}function io(e){e.stopPropagation()}var j;(function(e){e.Space="Space",e.Down="ArrowDown",e.Right="ArrowRight",e.Left="ArrowLeft",e.Up="ArrowUp",e.Esc="Escape",e.Enter="Enter",e.Tab="Tab"})(j||(j={}));const Lr={start:[j.Space,j.Enter],cancel:[j.Esc],end:[j.Space,j.Enter,j.Tab]},so=(e,t)=>{let{currentCoordinates:r}=t;switch(e.code){case j.Right:return{...r,x:r.x+25};case j.Left:return{...r,x:r.x-25};case j.Down:return{...r,y:r.y+25};case j.Up:return{...r,y:r.y-25}}};class Vt{constructor(t){this.props=void 0,this.autoScrollEnabled=!1,this.referenceCoordinates=void 0,this.listeners=void 0,this.windowListeners=void 0,this.props=t;const{event:{target:r}}=t;this.props=t,this.listeners=new nt(We(r)),this.windowListeners=new nt(J(r)),this.handleKeyDown=this.handleKeyDown.bind(this),this.handleCancel=this.handleCancel.bind(this),this.attach()}attach(){this.handleStart(),this.windowListeners.add(oe.Resize,this.handleCancel),this.windowListeners.add(oe.VisibilityChange,this.handleCancel),setTimeout(()=>this.listeners.add(oe.Keydown,this.handleKeyDown))}handleStart(){const{activeNode:t,onStart:r}=this.props,n=t.node.current;n&&no(n),r(ue)}handleKeyDown(t){if(Ht(t)){const{active:r,context:n,options:o}=this.props,{keyboardCodes:a=Lr,coordinateGetter:s=so,scrollBehavior:c="smooth"}=o,{code:d}=t;if(a.end.includes(d)){this.handleEnd(t);return}if(a.cancel.includes(d)){this.handleCancel(t);return}const{collisionRect:u}=n.current,g=u?{x:u.left,y:u.top}:ue;this.referenceCoordinates||(this.referenceCoordinates=g);const f=s(t,{active:r,context:n.current,currentCoordinates:g});if(f){const p=st(f,g),h={x:0,y:0},{scrollableAncestors:w}=n.current;for(const m of w){const x=t.code,{isTop:k,isRight:S,isLeft:v,isBottom:C,maxScroll:E,minScroll:R}=Ir(m),N=eo(m),D={x:Math.min(x===j.Right?N.right-N.width/2:N.right,Math.max(x===j.Right?N.left:N.left+N.width/2,f.x)),y:Math.min(x===j.Down?N.bottom-N.height/2:N.bottom,Math.max(x===j.Down?N.top:N.top+N.height/2,f.y))},L=x===j.Right&&!S||x===j.Left&&!v,I=x===j.Down&&!C||x===j.Up&&!k;if(L&&D.x!==f.x){const _=m.scrollLeft+p.x,Z=x===j.Right&&_<=E.x||x===j.Left&&_>=R.x;if(Z&&!p.y){m.scrollTo({left:_,behavior:c});return}Z?h.x=m.scrollLeft-_:h.x=x===j.Right?m.scrollLeft-E.x:m.scrollLeft-R.x,h.x&&m.scrollBy({left:-h.x,behavior:c});break}else if(I&&D.y!==f.y){const _=m.scrollTop+p.y,Z=x===j.Down&&_<=E.y||x===j.Up&&_>=R.y;if(Z&&!p.x){m.scrollTo({top:_,behavior:c});return}Z?h.y=m.scrollTop-_:h.y=x===j.Down?m.scrollTop-E.y:m.scrollTop-R.y,h.y&&m.scrollBy({top:-h.y,behavior:c});break}}this.handleMove(t,Ke(st(f,this.referenceCoordinates),h))}}}handleMove(t,r){const{onMove:n}=this.props;t.preventDefault(),n(r)}handleEnd(t){const{onEnd:r}=this.props;t.preventDefault(),this.detach(),r()}handleCancel(t){const{onCancel:r}=this.props;t.preventDefault(),this.detach(),r()}detach(){this.listeners.removeAll(),this.windowListeners.removeAll()}}Vt.activators=[{eventName:"onKeyDown",handler:(e,t,r)=>{let{keyboardCodes:n=Lr,onActivation:o}=t,{active:a}=r;const{code:s}=e.nativeEvent;if(n.start.includes(s)){const c=a.activatorNode.current;return c&&e.target!==c?!1:(e.preventDefault(),o?.({event:e.nativeEvent}),!0)}return!1}}];function ar(e){return!!(e&&"distance"in e)}function ir(e){return!!(e&&"delay"in e)}class qt{constructor(t,r,n){var o;n===void 0&&(n=ao(t.event.target)),this.props=void 0,this.events=void 0,this.autoScrollEnabled=!0,this.document=void 0,this.activated=!1,this.initialCoordinates=void 0,this.timeoutId=null,this.listeners=void 0,this.documentListeners=void 0,this.windowListeners=void 0,this.props=t,this.events=r;const{event:a}=t,{target:s}=a;this.props=t,this.events=r,this.document=We(s),this.documentListeners=new nt(this.document),this.listeners=new nt(n),this.windowListeners=new nt(J(s)),this.initialCoordinates=(o=Ot(a))!=null?o:ue,this.handleStart=this.handleStart.bind(this),this.handleMove=this.handleMove.bind(this),this.handleEnd=this.handleEnd.bind(this),this.handleCancel=this.handleCancel.bind(this),this.handleKeydown=this.handleKeydown.bind(this),this.removeTextSelection=this.removeTextSelection.bind(this),this.attach()}attach(){const{events:t,props:{options:{activationConstraint:r,bypassActivationConstraint:n}}}=this;if(this.listeners.add(t.move.name,this.handleMove,{passive:!1}),this.listeners.add(t.end.name,this.handleEnd),t.cancel&&this.listeners.add(t.cancel.name,this.handleCancel),this.windowListeners.add(oe.Resize,this.handleCancel),this.windowListeners.add(oe.DragStart,or),this.windowListeners.add(oe.VisibilityChange,this.handleCancel),this.windowListeners.add(oe.ContextMenu,or),this.documentListeners.add(oe.Keydown,this.handleKeydown),r){if(n!=null&&n({event:this.props.event,activeNode:this.props.activeNode,options:this.props.options}))return this.handleStart();if(ir(r)){this.timeoutId=setTimeout(this.handleStart,r.delay),this.handlePending(r);return}if(ar(r)){this.handlePending(r);return}}this.handleStart()}detach(){this.listeners.removeAll(),this.windowListeners.removeAll(),setTimeout(this.documentListeners.removeAll,50),this.timeoutId!==null&&(clearTimeout(this.timeoutId),this.timeoutId=null)}handlePending(t,r){const{active:n,onPending:o}=this.props;o(n,t,this.initialCoordinates,r)}handleStart(){const{initialCoordinates:t}=this,{onStart:r}=this.props;t&&(this.activated=!0,this.documentListeners.add(oe.Click,io,{capture:!0}),this.removeTextSelection(),this.documentListeners.add(oe.SelectionChange,this.removeTextSelection),r(t))}handleMove(t){var r;const{activated:n,initialCoordinates:o,props:a}=this,{onMove:s,options:{activationConstraint:c}}=a;if(!o)return;const d=(r=Ot(t))!=null?r:ue,u=st(o,d);if(!n&&c){if(ar(c)){if(c.tolerance!=null&&At(u,c.tolerance))return this.handleCancel();if(At(u,c.distance))return this.handleStart()}if(ir(c)&&At(u,c.tolerance))return this.handleCancel();this.handlePending(c,u);return}t.cancelable&&t.preventDefault(),s(d)}handleEnd(){const{onAbort:t,onEnd:r}=this.props;this.detach(),this.activated||t(this.props.active),r()}handleCancel(){const{onAbort:t,onCancel:r}=this.props;this.detach(),this.activated||t(this.props.active),r()}handleKeydown(t){t.code===j.Esc&&this.handleCancel()}removeTextSelection(){var t;(t=this.document.getSelection())==null||t.removeAllRanges()}}const lo={cancel:{name:"pointercancel"},move:{name:"pointermove"},end:{name:"pointerup"}};class Jt extends qt{constructor(t){const{event:r}=t,n=We(r.target);super(t,lo,n)}}Jt.activators=[{eventName:"onPointerDown",handler:(e,t)=>{let{nativeEvent:r}=e,{onActivation:n}=t;return!r.isPrimary||r.button!==0?!1:(n?.({event:r}),!0)}}];const co={move:{name:"mousemove"},end:{name:"mouseup"}};var zt;(function(e){e[e.RightClick=2]="RightClick"})(zt||(zt={}));class uo extends qt{constructor(t){super(t,co,We(t.event.target))}}uo.activators=[{eventName:"onMouseDown",handler:(e,t)=>{let{nativeEvent:r}=e,{onActivation:n}=t;return r.button===zt.RightClick?!1:(n?.({event:r}),!0)}}];const Mt={cancel:{name:"touchcancel"},move:{name:"touchmove"},end:{name:"touchend"}};class fo extends qt{constructor(t){super(t,Mt)}static setup(){return window.addEventListener(Mt.move.name,t,{capture:!1,passive:!1}),function(){window.removeEventListener(Mt.move.name,t)};function t(){}}}fo.activators=[{eventName:"onTouchStart",handler:(e,t)=>{let{nativeEvent:r}=e,{onActivation:n}=t;const{touches:o}=r;return o.length>1?!1:(n?.({event:r}),!0)}}];var ot;(function(e){e[e.Pointer=0]="Pointer",e[e.DraggableRect=1]="DraggableRect"})(ot||(ot={}));var vt;(function(e){e[e.TreeOrder=0]="TreeOrder",e[e.ReversedTreeOrder=1]="ReversedTreeOrder"})(vt||(vt={}));function go(e){let{acceleration:t,activator:r=ot.Pointer,canScroll:n,draggingRect:o,enabled:a,interval:s=5,order:c=vt.TreeOrder,pointerCoordinates:d,scrollableAncestors:u,scrollableAncestorRects:g,delta:f,threshold:p}=e;const h=bo({delta:f,disabled:!a}),[w,m]=Nn(),x=i.useRef({x:0,y:0}),k=i.useRef({x:0,y:0}),S=i.useMemo(()=>{switch(r){case ot.Pointer:return d?{top:d.y,bottom:d.y,left:d.x,right:d.x}:null;case ot.DraggableRect:return o}},[r,o,d]),v=i.useRef(null),C=i.useCallback(()=>{const R=v.current;if(!R)return;const N=x.current.x*k.current.x,D=x.current.y*k.current.y;R.scrollBy(N,D)},[]),E=i.useMemo(()=>c===vt.TreeOrder?[...u].reverse():u,[c,u]);i.useEffect(()=>{if(!a||!u.length||!S){m();return}for(const R of E){if(n?.(R)===!1)continue;const N=u.indexOf(R),D=g[N];if(!D)continue;const{direction:L,speed:I}=Qn(R,D,S,t,p);for(const _ of["x","y"])h[_][L[_]]||(I[_]=0,L[_]=0);if(I.x>0||I.y>0){m(),v.current=R,w(C,s),x.current=I,k.current=L;return}}x.current={x:0,y:0},k.current={x:0,y:0},m()},[t,C,n,m,a,s,JSON.stringify(S),JSON.stringify(h),w,u,E,g,JSON.stringify(p)])}const ho={x:{[F.Backward]:!1,[F.Forward]:!1},y:{[F.Backward]:!1,[F.Forward]:!1}};function bo(e){let{delta:t,disabled:r}=e;const n=Lt(t);return ft(o=>{if(r||!n||!o)return ho;const a={x:Math.sign(t.x-n.x),y:Math.sign(t.y-n.y)};return{x:{[F.Backward]:o.x[F.Backward]||a.x===-1,[F.Forward]:o.x[F.Forward]||a.x===1},y:{[F.Backward]:o.y[F.Backward]||a.y===-1,[F.Forward]:o.y[F.Forward]||a.y===1}}},[r,t,n])}function po(e,t){const r=t!=null?e.get(t):void 0,n=r?r.node.current:null;return ft(o=>{var a;return t==null?null:(a=n??o)!=null?a:null},[n,t])}function mo(e,t){return i.useMemo(()=>e.reduce((r,n)=>{const{sensor:o}=n,a=o.activators.map(s=>({eventName:s.eventName,handler:t(s.handler,n)}));return[...r,...a]},[]),[e,t])}var ct;(function(e){e[e.Always=0]="Always",e[e.BeforeDragging=1]="BeforeDragging",e[e.WhileDragging=2]="WhileDragging"})(ct||(ct={}));var Bt;(function(e){e.Optimized="optimized"})(Bt||(Bt={}));const sr=new Map;function xo(e,t){let{dragging:r,dependencies:n,config:o}=t;const[a,s]=i.useState(null),{frequency:c,measure:d,strategy:u}=o,g=i.useRef(e),f=x(),p=it(f),h=i.useCallback(function(k){k===void 0&&(k=[]),!p.current&&s(S=>S===null?k:S.concat(k.filter(v=>!S.includes(v))))},[p]),w=i.useRef(null),m=ft(k=>{if(f&&!r)return sr;if(!k||k===sr||g.current!==e||a!=null){const S=new Map;for(let v of e){if(!v)continue;if(a&&a.length>0&&!a.includes(v.id)&&v.rect.current){S.set(v.id,v.rect.current);continue}const C=v.node.current,E=C?new Gt(d(C),C):null;v.rect.current=E,E&&S.set(v.id,E)}return S}return k},[e,a,r,f,d]);return i.useEffect(()=>{g.current=e},[e]),i.useEffect(()=>{f||h()},[r,f]),i.useEffect(()=>{a&&a.length>0&&s(null)},[JSON.stringify(a)]),i.useEffect(()=>{f||typeof c!="number"||w.current!==null||(w.current=setTimeout(()=>{h(),w.current=null},c))},[c,f,h,...n]),{droppableRects:m,measureDroppableContainers:h,measuringScheduled:a!=null};function x(){switch(u){case ct.Always:return!1;case ct.BeforeDragging:return r;default:return!r}}}function Or(e,t){return ft(r=>e?r||(typeof t=="function"?t(e):e):null,[t,e])}function vo(e,t){return Or(e,t)}function yo(e){let{callback:t,disabled:r}=e;const n=Xt(t),o=i.useMemo(()=>{if(r||typeof window>"u"||typeof window.MutationObserver>"u")return;const{MutationObserver:a}=window;return new a(n)},[n,r]);return i.useEffect(()=>()=>o?.disconnect(),[o]),o}function Nt(e){let{callback:t,disabled:r}=e;const n=Xt(t),o=i.useMemo(()=>{if(r||typeof window>"u"||typeof window.ResizeObserver>"u")return;const{ResizeObserver:a}=window;return new a(n)},[r]);return i.useEffect(()=>()=>o?.disconnect(),[o]),o}function wo(e){return new Gt(Xe(e),e)}function lr(e,t,r){t===void 0&&(t=wo);const[n,o]=i.useState(null);function a(){o(d=>{if(!e)return null;if(e.isConnected===!1){var u;return(u=d??r)!=null?u:null}const g=t(e);return JSON.stringify(d)===JSON.stringify(g)?d:g})}const s=yo({callback(d){if(e)for(const u of d){const{type:g,target:f}=u;if(g==="childList"&&f instanceof HTMLElement&&f.contains(e)){a();break}}}}),c=Nt({callback:a});return me(()=>{a(),e?(c?.observe(e),s?.observe(document.body,{childList:!0,subtree:!0})):(c?.disconnect(),s?.disconnect())},[e]),n}function ko(e){const t=Or(e);return jr(e,t)}const cr=[];function So(e){const t=i.useRef(e),r=ft(n=>e?n&&n!==cr&&e&&t.current&&e.parentNode===t.current.parentNode?n:St(e):cr,[e]);return i.useEffect(()=>{t.current=e},[e]),r}function No(e){const[t,r]=i.useState(null),n=i.useRef(e),o=i.useCallback(a=>{const s=_t(a.target);s&&r(c=>c?(c.set(s,Pt(s)),new Map(c)):null)},[]);return i.useEffect(()=>{const a=n.current;if(e!==a){s(a);const c=e.map(d=>{const u=_t(d);return u?(u.addEventListener("scroll",o,{passive:!0}),[u,Pt(u)]):null}).filter(d=>d!=null);r(c.length?new Map(c):null),n.current=e}return()=>{s(e),s(a)};function s(c){c.forEach(d=>{const u=_t(d);u?.removeEventListener("scroll",o)})}},[o,e]),i.useMemo(()=>e.length?t?Array.from(t.values()).reduce((a,s)=>Ke(a,s),ue):Tr(e):ue,[e,t])}function dr(e,t){t===void 0&&(t=[]);const r=i.useRef(null);return i.useEffect(()=>{r.current=null},t),i.useEffect(()=>{const n=e!==ue;n&&!r.current&&(r.current=e),!n&&r.current&&(r.current=null)},[e]),r.current?st(e,r.current):ue}function Co(e){i.useEffect(()=>{if(!kt)return;const t=e.map(r=>{let{sensor:n}=r;return n.setup==null?void 0:n.setup()});return()=>{for(const r of t)r?.()}},e.map(t=>{let{sensor:r}=t;return r}))}function Ro(e,t){return i.useMemo(()=>e.reduce((r,n)=>{let{eventName:o,handler:a}=n;return r[o]=s=>{a(s,t)},r},{}),[e,t])}function Pr(e){return i.useMemo(()=>e?Vn(e):null,[e])}const ur=[];function Do(e,t){t===void 0&&(t=Xe);const[r]=e,n=Pr(r?J(r):null),[o,a]=i.useState(ur);function s(){a(()=>e.length?e.map(d=>Mr(d)?n:new Gt(t(d),d)):ur)}const c=Nt({callback:s});return me(()=>{c?.disconnect(),s(),e.forEach(d=>c?.observe(d))},[e]),o}function jo(e){if(!e)return null;if(e.children.length>1)return e;const t=e.children[0];return ut(t)?t:e}function Eo(e){let{measure:t}=e;const[r,n]=i.useState(null),o=i.useCallback(u=>{for(const{target:g}of u)if(ut(g)){n(f=>{const p=t(g);return f?{...f,width:p.width,height:p.height}:p});break}},[t]),a=Nt({callback:o}),s=i.useCallback(u=>{const g=jo(u);a?.disconnect(),g&&a?.observe(g),n(g?t(g):null)},[t,a]),[c,d]=mt(s);return i.useMemo(()=>({nodeRef:c,rect:r,setRef:d}),[r,c,d])}const _o=[{sensor:Jt,options:{}},{sensor:Vt,options:{}}],Ao={current:{}},pt={draggable:{measure:nr},droppable:{measure:nr,strategy:ct.WhileDragging,frequency:Bt.Optimized},dragOverlay:{measure:Xe}};class at extends Map{get(t){var r;return t!=null&&(r=super.get(t))!=null?r:void 0}toArray(){return Array.from(this.values())}getEnabled(){return this.toArray().filter(t=>{let{disabled:r}=t;return!r})}getNodeFor(t){var r,n;return(r=(n=this.get(t))==null?void 0:n.node.current)!=null?r:void 0}}const Mo={activatorEvent:null,active:null,activeNode:null,activeNodeRect:null,collisions:null,containerNodeRect:null,draggableNodes:new Map,droppableRects:new Map,droppableContainers:new at,over:null,dragOverlay:{nodeRef:{current:null},rect:null,setRef:xt},scrollableAncestors:[],scrollableAncestorRects:[],measuringConfiguration:pt,measureDroppableContainers:xt,windowRect:null,measuringScheduled:!1},Io={activatorEvent:null,activators:[],active:null,activeNodeRect:null,ariaDescribedById:{draggable:""},dispatch:xt,draggableNodes:new Map,over:null,measureDroppableContainers:xt},Ct=i.createContext(Io),zr=i.createContext(Mo);function To(){return{draggable:{active:null,initialCoordinates:{x:0,y:0},nodes:new Map,translate:{x:0,y:0}},droppable:{containers:new at}}}function Lo(e,t){switch(t.type){case z.DragStart:return{...e,draggable:{...e.draggable,initialCoordinates:t.initialCoordinates,active:t.active}};case z.DragMove:return e.draggable.active==null?e:{...e,draggable:{...e.draggable,translate:{x:t.coordinates.x-e.draggable.initialCoordinates.x,y:t.coordinates.y-e.draggable.initialCoordinates.y}}};case z.DragEnd:case z.DragCancel:return{...e,draggable:{...e.draggable,active:null,initialCoordinates:{x:0,y:0},translate:{x:0,y:0}}};case z.RegisterDroppable:{const{element:r}=t,{id:n}=r,o=new at(e.droppable.containers);return o.set(n,r),{...e,droppable:{...e.droppable,containers:o}}}case z.SetDroppableDisabled:{const{id:r,key:n,disabled:o}=t,a=e.droppable.containers.get(r);if(!a||n!==a.key)return e;const s=new at(e.droppable.containers);return s.set(r,{...a,disabled:o}),{...e,droppable:{...e.droppable,containers:s}}}case z.UnregisterDroppable:{const{id:r,key:n}=t,o=e.droppable.containers.get(r);if(!o||n!==o.key)return e;const a=new at(e.droppable.containers);return a.delete(r),{...e,droppable:{...e.droppable,containers:a}}}default:return e}}function Oo(e){let{disabled:t}=e;const{active:r,activatorEvent:n,draggableNodes:o}=i.useContext(Ct),a=Lt(n),s=Lt(r?.id);return i.useEffect(()=>{if(!t&&!n&&a&&s!=null){if(!Ht(a)||document.activeElement===a.target)return;const c=o.get(s);if(!c)return;const{activatorNode:d,node:u}=c;if(!d.current&&!u.current)return;requestAnimationFrame(()=>{for(const g of[d.current,u.current]){if(!g)continue;const f=Dn(g);if(f){f.focus();break}}})}},[n,t,o,s,a]),null}function Po(e,t){let{transform:r,...n}=t;return e!=null&&e.length?e.reduce((o,a)=>a({transform:o,...n}),r):r}function zo(e){return i.useMemo(()=>({draggable:{...pt.draggable,...e?.draggable},droppable:{...pt.droppable,...e?.droppable},dragOverlay:{...pt.dragOverlay,...e?.dragOverlay}}),[e?.draggable,e?.droppable,e?.dragOverlay])}function Bo(e){let{activeNode:t,measure:r,initialRect:n,config:o=!0}=e;const a=i.useRef(!1),{x:s,y:c}=typeof o=="boolean"?{x:o,y:o}:o;me(()=>{if(!s&&!c||!t){a.current=!1;return}if(a.current||!n)return;const u=t?.node.current;if(!u||u.isConnected===!1)return;const g=r(u),f=jr(g,n);if(s||(f.x=0),c||(f.y=0),a.current=!0,Math.abs(f.x)>0||Math.abs(f.y)>0){const p=Er(u);p&&p.scrollBy({top:f.y,left:f.x})}},[t,s,c,n,r])}const Br=i.createContext({...ue,scaleX:1,scaleY:1});var Me;(function(e){e[e.Uninitialized=0]="Uninitialized",e[e.Initializing=1]="Initializing",e[e.Initialized=2]="Initialized"})(Me||(Me={}));const $o=i.memo(function(t){var r,n,o,a;let{id:s,accessibility:c,autoScroll:d=!0,children:u,sensors:g=_o,collisionDetection:f=Un,measuring:p,modifiers:h,...w}=t;const m=i.useReducer(Lo,void 0,To),[x,k]=m,[S,v]=In(),[C,E]=i.useState(Me.Uninitialized),R=C===Me.Initialized,{draggable:{active:N,nodes:D,translate:L},droppable:{containers:I}}=x,_=N!=null?D.get(N):null,Z=i.useRef({initial:null,translated:null}),G=i.useMemo(()=>{var K;return N!=null?{id:N,data:(K=_?.data)!=null?K:Ao,rect:Z}:null},[N,_]),Q=i.useRef(null),[xe,ze]=i.useState(null),[H,Be]=i.useState(null),ae=it(w,Object.values(w)),B=gt("DndDescribedBy",s),ke=i.useMemo(()=>I.getEnabled(),[I]),W=zo(p),{droppableRects:ie,measureDroppableContainers:fe,measuringScheduled:Se}=xo(ke,{dragging:R,dependencies:[L.x,L.y],config:W.droppable}),O=po(D,N),$e=i.useMemo(()=>H?Ot(H):null,[H]),se=Pe(),P=vo(O,W.draggable.measure);Bo({activeNode:N!=null?D.get(N):null,config:se.layoutShiftCompensation,initialRect:P,measure:W.draggable.measure});const A=lr(O,W.draggable.measure,P),Ie=lr(O?O.parentElement:null),U=i.useRef({activatorEvent:null,active:null,activeNode:O,collisionRect:null,collisions:null,droppableRects:ie,draggableNodes:D,draggingNode:null,draggingNodeRect:null,droppableContainers:I,over:null,scrollableAncestors:[],scrollAdjustedTranslate:null}),Ne=I.getNodeFor((r=U.current.over)==null?void 0:r.id),te=Eo({measure:W.dragOverlay.measure}),ve=(n=te.nodeRef.current)!=null?n:O,ye=R?(o=te.rect)!=null?o:A:null,ge=!!(te.nodeRef.current&&te.rect),Te=ko(ge?null:A),He=Pr(ve?J(ve):null),le=So(R?Ne??O:null),Le=Do(le),Oe=Po(h,{transform:{x:L.x-Te.x,y:L.y-Te.y,scaleX:1,scaleY:1},activatorEvent:H,active:G,activeNodeRect:A,containerNodeRect:Ie,draggingNodeRect:ye,over:U.current.over,overlayNodeRect:te.rect,scrollableAncestors:le,scrollableAncestorRects:Le,windowRect:He}),Ge=$e?Ke($e,L):null,Fe=No(le),Ce=dr(Fe),Rt=dr(Fe,[A]),Re=Ke(Oe,Ce),De=ye?Wn(ye,Oe):null,je=G&&De?f({active:G,collisionRect:De,droppableRects:ie,droppableContainers:ke,pointerCoordinates:Ge}):null,Ve=Dr(je,"id"),[he,Ee]=i.useState(null),qe=ge?Oe:Ke(Oe,Rt),b=Kn(qe,(a=he?.rect)!=null?a:null,A),M=i.useRef(null),re=i.useCallback((K,V)=>{let{sensor:X,options:$}=V;if(Q.current==null)return;const ne=D.get(Q.current);if(!ne)return;const ee=K.nativeEvent,be=new X({active:Q.current,activeNode:ne,event:ee,options:$,context:U,onAbort(Y){if(!D.get(Y))return;const{onDragAbort:pe}=ae.current,we={id:Y};pe?.(we),S({type:"onDragAbort",event:we})},onPending(Y,_e,pe,we){if(!D.get(Y))return;const{onDragPending:et}=ae.current,Ae={id:Y,constraint:_e,initialCoordinates:pe,offset:we};et?.(Ae),S({type:"onDragPending",event:Ae})},onStart(Y){const _e=Q.current;if(_e==null)return;const pe=D.get(_e);if(!pe)return;const{onDragStart:we}=ae.current,Qe={activatorEvent:ee,active:{id:_e,data:pe.data,rect:Z}};rt.unstable_batchedUpdates(()=>{we?.(Qe),E(Me.Initializing),k({type:z.DragStart,initialCoordinates:Y,active:_e}),S({type:"onDragStart",event:Qe}),ze(M.current),Be(ee)})},onMove(Y){k({type:z.DragMove,coordinates:Y})},onEnd:Ue(z.DragEnd),onCancel:Ue(z.DragCancel)});M.current=be;function Ue(Y){return async function(){const{active:pe,collisions:we,over:Qe,scrollAdjustedTranslate:et}=U.current;let Ae=null;if(pe&&et){const{cancelDrop:tt}=ae.current;Ae={activatorEvent:ee,active:pe,collisions:we,delta:et,over:Qe},Y===z.DragEnd&&typeof tt=="function"&&await Promise.resolve(tt(Ae))&&(Y=z.DragCancel)}Q.current=null,rt.unstable_batchedUpdates(()=>{k({type:Y}),E(Me.Uninitialized),Ee(null),ze(null),Be(null),M.current=null;const tt=Y===z.DragEnd?"onDragEnd":"onDragCancel";if(Ae){const jt=ae.current[tt];jt?.(Ae),S({type:tt,event:Ae})}})}}},[D]),Je=i.useCallback((K,V)=>(X,$)=>{const ne=X.nativeEvent,ee=D.get($);if(Q.current!==null||!ee||ne.dndKit||ne.defaultPrevented)return;const be={active:ee};K(X,V.options,be)===!0&&(ne.dndKit={capturedBy:V.sensor},Q.current=$,re(X,V))},[D,re]),Ze=mo(g,Je);Co(g),me(()=>{A&&C===Me.Initializing&&E(Me.Initialized)},[A,C]),i.useEffect(()=>{const{onDragMove:K}=ae.current,{active:V,activatorEvent:X,collisions:$,over:ne}=U.current;if(!V||!X)return;const ee={active:V,activatorEvent:X,collisions:$,delta:{x:Re.x,y:Re.y},over:ne};rt.unstable_batchedUpdates(()=>{K?.(ee),S({type:"onDragMove",event:ee})})},[Re.x,Re.y]),i.useEffect(()=>{const{active:K,activatorEvent:V,collisions:X,droppableContainers:$,scrollAdjustedTranslate:ne}=U.current;if(!K||Q.current==null||!V||!ne)return;const{onDragOver:ee}=ae.current,be=$.get(Ve),Ue=be&&be.rect.current?{id:be.id,rect:be.rect.current,data:be.data,disabled:be.disabled}:null,Y={active:K,activatorEvent:V,collisions:X,delta:{x:ne.x,y:ne.y},over:Ue};rt.unstable_batchedUpdates(()=>{Ee(Ue),ee?.(Y),S({type:"onDragOver",event:Y})})},[Ve]),me(()=>{U.current={activatorEvent:H,active:G,activeNode:O,collisionRect:De,collisions:je,droppableRects:ie,draggableNodes:D,draggingNode:ve,draggingNodeRect:ye,droppableContainers:I,over:he,scrollableAncestors:le,scrollAdjustedTranslate:Re},Z.current={initial:ye,translated:De}},[G,O,je,De,D,ve,ye,ie,I,he,le,Re]),go({...se,delta:L,draggingRect:De,pointerCoordinates:Ge,scrollableAncestors:le,scrollableAncestorRects:Le});const Dt=i.useMemo(()=>({active:G,activeNode:O,activeNodeRect:A,activatorEvent:H,collisions:je,containerNodeRect:Ie,dragOverlay:te,draggableNodes:D,droppableContainers:I,droppableRects:ie,over:he,measureDroppableContainers:fe,scrollableAncestors:le,scrollableAncestorRects:Le,measuringConfiguration:W,measuringScheduled:Se,windowRect:He}),[G,O,A,H,je,Ie,te,D,I,ie,he,fe,le,Le,W,Se,He]),ce=i.useMemo(()=>({activatorEvent:H,activators:Ze,active:G,activeNodeRect:A,ariaDescribedById:{draggable:B},dispatch:k,draggableNodes:D,over:he,measureDroppableContainers:fe}),[H,Ze,G,A,k,B,D,he,fe]);return q.createElement(Nr.Provider,{value:v},q.createElement(Ct.Provider,{value:ce},q.createElement(zr.Provider,{value:Dt},q.createElement(Br.Provider,{value:b},u)),q.createElement(Oo,{disabled:c?.restoreFocus===!1})),q.createElement(On,{...c,hiddenTextDescribedById:B}));function Pe(){const K=xe?.autoScrollEnabled===!1,V=typeof d=="object"?d.enabled===!1:d===!1,X=R&&!K&&!V;return typeof d=="object"?{...d,enabled:X}:{enabled:X}}}),Fo=i.createContext(null),fr="button",Uo="Draggable";function Ko(e){let{id:t,data:r,disabled:n=!1,attributes:o}=e;const a=gt(Uo),{activators:s,activatorEvent:c,active:d,activeNodeRect:u,ariaDescribedById:g,draggableNodes:f,over:p}=i.useContext(Ct),{role:h=fr,roleDescription:w="draggable",tabIndex:m=0}=o??{},x=d?.id===t,k=i.useContext(x?Br:Fo),[S,v]=mt(),[C,E]=mt(),R=Ro(s,t),N=it(r);me(()=>(f.set(t,{id:t,key:a,node:S,activatorNode:C,data:N}),()=>{const L=f.get(t);L&&L.key===a&&f.delete(t)}),[f,t]);const D=i.useMemo(()=>({role:h,tabIndex:m,"aria-disabled":n,"aria-pressed":x&&h===fr?!0:void 0,"aria-roledescription":w,"aria-describedby":g.draggable}),[n,h,m,x,w,g.draggable]);return{active:d,activatorEvent:c,activeNodeRect:u,attributes:D,isDragging:x,listeners:n?void 0:R,node:S,over:p,setNodeRef:v,setActivatorNodeRef:E,transform:k}}function Yo(){return i.useContext(zr)}const Wo="Droppable",Xo={timeout:25};function Ho(e){let{data:t,disabled:r=!1,id:n,resizeObserverConfig:o}=e;const a=gt(Wo),{active:s,dispatch:c,over:d,measureDroppableContainers:u}=i.useContext(Ct),g=i.useRef({disabled:r}),f=i.useRef(!1),p=i.useRef(null),h=i.useRef(null),{disabled:w,updateMeasurementsFor:m,timeout:x}={...Xo,...o},k=it(m??n),S=i.useCallback(()=>{if(!f.current){f.current=!0;return}h.current!=null&&clearTimeout(h.current),h.current=setTimeout(()=>{u(Array.isArray(k.current)?k.current:[k.current]),h.current=null},x)},[x]),v=Nt({callback:S,disabled:w||!s}),C=i.useCallback((D,L)=>{v&&(L&&(v.unobserve(L),f.current=!1),D&&v.observe(D))},[v]),[E,R]=mt(C),N=it(t);return i.useEffect(()=>{!v||!E.current||(v.disconnect(),f.current=!1,v.observe(E.current))},[E,v]),i.useEffect(()=>(c({type:z.RegisterDroppable,element:{id:n,key:a,disabled:r,node:E,rect:p,data:N}}),()=>c({type:z.UnregisterDroppable,key:a,id:n})),[n]),i.useEffect(()=>{r!==g.current.disabled&&(c({type:z.SetDroppableDisabled,id:n,key:a,disabled:r}),g.current.disabled=r)},[n,a,r,c]),{active:s,rect:p,isOver:d?.id===n,node:E,over:d,setNodeRef:R}}const Go=e=>{let{transform:t}=e;return{...t,y:0}};function $r(e,t,r){const n=e.slice();return n.splice(r<0?n.length+r:r,0,n.splice(t,1)[0]),n}function Vo(e,t){return e.reduce((r,n,o)=>{const a=t.get(n);return a&&(r[o]=a),r},Array(e.length))}function ht(e){return e!==null&&e>=0}function qo(e,t){if(e===t)return!0;if(e.length!==t.length)return!1;for(let r=0;r<e.length;r++)if(e[r]!==t[r])return!1;return!0}function Jo(e){return typeof e=="boolean"?{draggable:e,droppable:e}:e}const bt={scaleX:1,scaleY:1},Zo=e=>{var t;let{rects:r,activeNodeRect:n,activeIndex:o,overIndex:a,index:s}=e;const c=(t=r[o])!=null?t:n;if(!c)return null;const d=Qo(r,s,o);if(s===o){const u=r[a];return u?{x:o<a?u.left+u.width-(c.left+c.width):u.left-c.left,y:0,...bt}:null}return s>o&&s<=a?{x:-c.width-d,y:0,...bt}:s<o&&s>=a?{x:c.width+d,y:0,...bt}:{x:0,y:0,...bt}};function Qo(e,t,r){const n=e[t],o=e[t-1],a=e[t+1];return!n||!o&&!a?0:r<t?o?n.left-(o.left+o.width):a.left-(n.left+n.width):a?a.left-(n.left+n.width):n.left-(o.left+o.width)}const Fr=e=>{let{rects:t,activeIndex:r,overIndex:n,index:o}=e;const a=$r(t,n,r),s=t[o],c=a[o];return!c||!s?null:{x:c.left-s.left,y:c.top-s.top,scaleX:c.width/s.width,scaleY:c.height/s.height}},Ur="Sortable",Kr=q.createContext({activeIndex:-1,containerId:Ur,disableTransforms:!1,items:[],overIndex:-1,useDragOverlay:!1,sortedRects:[],strategy:Fr,disabled:{draggable:!1,droppable:!1}});function ea(e){let{children:t,id:r,items:n,strategy:o=Fr,disabled:a=!1}=e;const{active:s,dragOverlay:c,droppableRects:d,over:u,measureDroppableContainers:g}=Yo(),f=gt(Ur,r),p=c.rect!==null,h=i.useMemo(()=>n.map(R=>typeof R=="object"&&"id"in R?R.id:R),[n]),w=s!=null,m=s?h.indexOf(s.id):-1,x=u?h.indexOf(u.id):-1,k=i.useRef(h),S=!qo(h,k.current),v=x!==-1&&m===-1||S,C=Jo(a);me(()=>{S&&w&&g(h)},[S,h,w,g]),i.useEffect(()=>{k.current=h},[h]);const E=i.useMemo(()=>({activeIndex:m,containerId:f,disabled:C,disableTransforms:v,items:h,overIndex:x,useDragOverlay:p,sortedRects:Vo(h,d),strategy:o}),[m,f,C.draggable,C.droppable,v,h,x,d,p,o]);return q.createElement(Kr.Provider,{value:E},t)}const ta=e=>{let{id:t,items:r,activeIndex:n,overIndex:o}=e;return $r(r,n,o).indexOf(t)},ra=e=>{let{containerId:t,isSorting:r,wasDragging:n,index:o,items:a,newIndex:s,previousItems:c,previousContainerId:d,transition:u}=e;return!u||!n||c!==a&&o===s?!1:r?!0:s!==o&&t===d},na={duration:200,easing:"ease"},Yr="transform",oa=lt.Transition.toString({property:Yr,duration:0,easing:"linear"}),aa={roleDescription:"sortable"};function ia(e){let{disabled:t,index:r,node:n,rect:o}=e;const[a,s]=i.useState(null),c=i.useRef(r);return me(()=>{if(!t&&r!==c.current&&n.current){const d=o.current;if(d){const u=Xe(n.current,{ignoreTransform:!0}),g={x:d.left-u.left,y:d.top-u.top,scaleX:d.width/u.width,scaleY:d.height/u.height};(g.x||g.y)&&s(g)}}r!==c.current&&(c.current=r)},[t,r,n,o]),i.useEffect(()=>{a&&s(null)},[a]),a}function sa(e){let{animateLayoutChanges:t=ra,attributes:r,disabled:n,data:o,getNewIndex:a=ta,id:s,strategy:c,resizeObserverConfig:d,transition:u=na}=e;const{items:g,containerId:f,activeIndex:p,disabled:h,disableTransforms:w,sortedRects:m,overIndex:x,useDragOverlay:k,strategy:S}=i.useContext(Kr),v=la(n,h),C=g.indexOf(s),E=i.useMemo(()=>({sortable:{containerId:f,index:C,items:g},...o}),[f,o,C,g]),R=i.useMemo(()=>g.slice(g.indexOf(s)),[g,s]),{rect:N,node:D,isOver:L,setNodeRef:I}=Ho({id:s,data:E,disabled:v.droppable,resizeObserverConfig:{updateMeasurementsFor:R,...d}}),{active:_,activatorEvent:Z,activeNodeRect:G,attributes:Q,setNodeRef:xe,listeners:ze,isDragging:H,over:Be,setActivatorNodeRef:ae,transform:B}=Ko({id:s,data:E,attributes:{...aa,...r},disabled:v.draggable}),ke=Sn(I,xe),W=!!_,ie=W&&!w&&ht(p)&&ht(x),fe=!k&&H,Se=fe&&ie?B:null,$e=ie?Se??(c??S)({rects:m,activeNodeRect:G,activeIndex:p,overIndex:x,index:C}):null,se=ht(p)&&ht(x)?a({id:s,items:g,activeIndex:p,overIndex:x}):C,P=_?.id,A=i.useRef({activeId:P,items:g,newIndex:se,containerId:f}),Ie=g!==A.current.items,U=t({active:_,containerId:f,isDragging:H,isSorting:W,id:s,index:C,items:g,newIndex:A.current.newIndex,previousItems:A.current.items,previousContainerId:A.current.containerId,transition:u,wasDragging:A.current.activeId!=null}),Ne=ia({disabled:!U,index:C,node:D,rect:N});return i.useEffect(()=>{W&&A.current.newIndex!==se&&(A.current.newIndex=se),f!==A.current.containerId&&(A.current.containerId=f),g!==A.current.items&&(A.current.items=g)},[W,se,f,g]),i.useEffect(()=>{if(P===A.current.activeId)return;if(P&&!A.current.activeId){A.current.activeId=P;return}const ve=setTimeout(()=>{A.current.activeId=P},50);return()=>clearTimeout(ve)},[P]),{active:_,activeIndex:p,attributes:Q,data:E,rect:N,index:C,newIndex:se,items:g,isOver:L,isSorting:W,isDragging:H,listeners:ze,node:D,overIndex:x,over:Be,setNodeRef:ke,setActivatorNodeRef:ae,setDroppableNodeRef:I,setDraggableNodeRef:xe,transform:Ne??$e,transition:te()};function te(){if(Ne||Ie&&A.current.newIndex===C)return oa;if(!(fe&&!Ht(Z)||!u)&&(W||U))return lt.Transition.toString({...u,property:Yr})}}function la(e,t){var r,n;return typeof e=="boolean"?{draggable:e,droppable:!1}:{draggable:(r=e?.draggable)!=null?r:t.draggable,droppable:(n=e?.droppable)!=null?n:t.droppable}}function yt(e){if(!e)return!1;const t=e.data.current;return!!(t&&"sortable"in t&&typeof t.sortable=="object"&&"containerId"in t.sortable&&"items"in t.sortable&&"index"in t.sortable)}const ca=[j.Down,j.Right,j.Up,j.Left],da=(e,t)=>{let{context:{active:r,collisionRect:n,droppableRects:o,droppableContainers:a,over:s,scrollableAncestors:c}}=t;if(ca.includes(e.code)){if(e.preventDefault(),!r||!n)return;const d=[];a.getEnabled().forEach(f=>{if(!f||f!=null&&f.disabled)return;const p=o.get(f.id);if(p)switch(e.code){case j.Down:n.top<p.top&&d.push(f);break;case j.Up:n.top>p.top&&d.push(f);break;case j.Left:n.left>p.left&&d.push(f);break;case j.Right:n.left<p.left&&d.push(f);break}});const u=$n({collisionRect:n,droppableRects:o,droppableContainers:d});let g=Dr(u,"id");if(g===s?.id&&u.length>1&&(g=u[1].id),g!=null){const f=a.get(r.id),p=a.get(g),h=p?o.get(p.id):null,w=p?.node.current;if(w&&h&&f&&p){const x=St(w).some((R,N)=>c[N]!==R),k=Wr(f,p),S=ua(f,p),v=x||!k?{x:0,y:0}:{x:S?n.width-h.width:0,y:S?n.height-h.height:0},C={x:h.left,y:h.top};return v.x&&v.y?C:st(C,v)}}}};function Wr(e,t){return!yt(e)||!yt(t)?!1:e.data.current.sortable.containerId===t.data.current.sortable.containerId}function ua(e,t){return!yt(e)||!yt(t)||!Wr(e,t)?!1:e.data.current.sortable.index<t.data.current.sortable.index}function dt(e,{min:t,max:r,fallback:n}){const o=Number(e);if(!Number.isFinite(o))return n;const a=Math.floor(o);return a<t?t:a>r?r:a}function fa(e,t){const r=dt(t,{min:0,max:1e6,fallback:0}),n=dt(e,{min:1,max:Math.max(1,r||1),fallback:1});if(r<=1)return[1];const o=new Set([1,r,n-2,n-1,n,n+1,n+2]),a=Array.from(o).filter(d=>Number.isInteger(d)&&d>=1&&d<=r).sort((d,u)=>d-u),s=[];let c=null;for(const d of a)c!=null&&d-c>1&&s.push(null),s.push(d),c=d;return s}function ga({page:e,totalPages:t}){const r=typeof t=="number"&&Number.isFinite(t)&&t>=0,n=r?dt(t,{min:0,max:1e6,fallback:0}):null,o=dt(e,{min:1,max:r?Math.max(1,n||1):1e6,fallback:1}),a=o>1,s=r?o<n:!0;return{canPrev:a,canNext:s,safePage:o,safeTotal:n}}function ha({entries:e,me:t,meLabel:r}){const n=Array.isArray(e)?e:[],o=t&&typeof t.rank=="number"?t.rank:null;return!o||n.some(s=>!!s?.is_me)?n:[{rank:o,is_me:!0,is_pinned:!0,user_id:t?.user_id??null,display_name:r,avatar_url:t?.avatar_url??null,github_url:null,is_public:!1,gpt_tokens:t?.gpt_tokens??"0",claude_tokens:t?.claude_tokens??"0",gemini_tokens:t?.gemini_tokens??"0",cursor_tokens:t?.cursor_tokens??"0",opencode_tokens:t?.opencode_tokens??"0",openclaw_tokens:t?.openclaw_tokens??"0",hermes_tokens:t?.hermes_tokens??"0",kiro_tokens:t?.kiro_tokens??"0",copilot_tokens:t?.copilot_tokens??"0",kimi_tokens:t?.kimi_tokens??"0",other_tokens:t?.other_tokens??"0",total_tokens:t?.total_tokens??"0",estimated_cost_usd:t?.estimated_cost_usd??null},...n]}function ba(e,t){const r=Number(e),n=Number(t);return!Number.isFinite(r)||r<1||!Number.isFinite(n)||n<1?null:Math.ceil(r/n)}const pa=new Set(["/brand-logos/cursor.svg","/brand-logos/kimi.svg","/brand-logos/kiro.svg","/brand-logos/copilot.svg"]);function ma({iconSrc:e,label:t}){return l.jsxs("span",{className:"inline-flex items-center gap-3",children:[e?l.jsx("img",{src:e,alt:"",width:16,height:16,className:`h-4 w-4 shrink-0 object-contain opacity-90 ${pa.has(e)?"dark:invert":""}`}):null,l.jsx("span",{className:"whitespace-nowrap",children:t})]})}const wt=[{key:"gpt_tokens",copyKey:"leaderboard.column.codex",icon:"/brand-logos/codex.svg"},{key:"claude_tokens",copyKey:"leaderboard.column.claude",icon:"/brand-logos/claude-code.svg"},{key:"gemini_tokens",copyKey:"leaderboard.column.gemini",icon:"/brand-logos/gemini.svg"},{key:"cursor_tokens",copyKey:"leaderboard.column.cursor",icon:"/brand-logos/cursor.svg"},{key:"kiro_tokens",copyKey:"leaderboard.column.kiro",icon:"/brand-logos/kiro.svg"},{key:"copilot_tokens",copyKey:"leaderboard.column.copilot",icon:"/brand-logos/copilot.svg"},{key:"kimi_tokens",copyKey:"leaderboard.column.kimi",icon:"/brand-logos/kimi.svg"},{key:"opencode_tokens",copyKey:"leaderboard.column.opencode",icon:"/brand-logos/opencode.svg"},{key:"openclaw_tokens",copyKey:"leaderboard.column.openclaw",icon:"/brand-logos/openclaw.svg"},{key:"hermes_tokens",copyKey:"leaderboard.column.hermes",icon:"/brand-logos/hermes.svg"},{key:"other_tokens",copyKey:"leaderboard.column.supplemental",icon:null}],Xr="sticky left-0 z-40 w-14 min-w-14 max-w-14 sm:w-[72px] sm:min-w-[72px] sm:max-w-[72px] bg-white dark:bg-oai-gray-950 px-2.5 sm:px-4 py-4 align-middle",Hr="sticky left-[55px] sm:left-[71px] z-40 min-w-[96px] sm:min-w-[200px] max-w-[170px] sm:max-w-[min(260px,45vw)] border-l border-r border-oai-gray-200 dark:border-oai-gray-800 bg-white dark:bg-oai-gray-950 px-3 sm:px-4 py-4 align-middle";function $t(e){return T("sticky left-0 z-30 w-14 min-w-14 max-w-14 sm:w-[72px] sm:min-w-[72px] sm:max-w-[72px] px-2.5 sm:px-4 py-4 whitespace-nowrap",e?"bg-oai-brand-50 dark:bg-emerald-950":"bg-white dark:bg-oai-gray-950 group-hover:bg-oai-gray-50 dark:group-hover:bg-oai-gray-900/60")}function Ft(e){return T("sticky left-[55px] sm:left-[71px] z-30 hover:z-50 min-w-[96px] sm:min-w-[200px] max-w-[170px] sm:max-w-[min(260px,45vw)] border-l border-r border-oai-gray-200 dark:border-oai-gray-800 px-3 sm:px-4 py-4 min-w-0",e?"bg-oai-brand-50 dark:bg-emerald-950":"bg-white dark:bg-oai-gray-950 group-hover:bg-oai-gray-50 dark:group-hover:bg-oai-gray-900/60")}function de({className:e}){return l.jsx("div",{className:T("rounded bg-oai-gray-200/70 dark:bg-oai-gray-800/70 animate-pulse",e)})}function xa({index:e}){const t=e<3?"w-24":e<8?"w-20":"w-16",r=e<3?"w-16":"w-12",n=e<5?"w-14":"w-10";return l.jsxs("tr",{className:"group",children:[l.jsx("td",{className:T($t(!1),"!group-hover:bg-transparent"),children:l.jsx(de,{className:"h-4 w-6"})}),l.jsx("td",{className:T(Ft(!1),"!group-hover:bg-transparent"),children:l.jsxs("div",{className:"flex items-center gap-4",children:[l.jsx(de,{className:"h-8 w-8 min-w-8 rounded-full"}),l.jsx(de,{className:T("h-4",t)})]})}),l.jsx("td",{className:"px-4 py-4 bg-white dark:bg-oai-gray-950",children:l.jsx(de,{className:T("h-4",r)})}),l.jsx("td",{className:"px-4 py-4 bg-white dark:bg-oai-gray-950",children:l.jsx(de,{className:"h-4 w-12"})}),wt.map(o=>l.jsx("td",{className:"px-4 py-4 bg-white dark:bg-oai-gray-950",children:l.jsx(de,{className:T("h-4",n)})},o.key))]})}function va({rows:e=10}){return l.jsx("div",{className:"w-full overflow-x-auto",children:l.jsxs("table",{className:"min-w-max w-full text-left text-sm",children:[l.jsx("thead",{className:"border-b border-oai-gray-200 dark:border-oai-gray-800",children:l.jsxs("tr",{children:[l.jsx("th",{className:T(Xr,"font-medium text-oai-gray-500 dark:text-oai-gray-400"),children:l.jsx(de,{className:"h-3.5 w-6"})}),l.jsx("th",{className:T(Hr,"font-medium text-oai-gray-500 dark:text-oai-gray-400"),children:l.jsx(de,{className:"h-3.5 w-12"})}),l.jsx("th",{className:"px-4 py-4",children:l.jsx(de,{className:"h-3.5 w-10"})}),l.jsx("th",{className:"px-4 py-4",children:l.jsx(de,{className:"h-3.5 w-14"})}),wt.map(t=>l.jsx("th",{className:"px-4 py-4",children:l.jsx(de,{className:"h-3.5 w-12"})},t.key))]})}),l.jsx("tbody",{className:"divide-y divide-oai-gray-100 dark:divide-oai-gray-800/50",children:Array.from({length:e},(t,r)=>l.jsx(xa,{index:r},r))})]})})}function ya({id:e,thClassName:t,children:r}){const{attributes:n,listeners:o,setNodeRef:a,transform:s,transition:c,isDragging:d}=sa({id:e}),u=lt.Transform.toString(s)||"";i.useLayoutEffect(()=>{const f=document.querySelectorAll(`td[data-column-key="${e}"]`),p="0 2px 10px rgba(15, 23, 42, 0.10), 0 1px 3px rgba(15, 23, 42, 0.06)";return f.forEach(h=>{h.style.transform=u,h.style.transition=c||"",h.style.zIndex=d?"20":"",h.style.position=u?"relative":"",h.style.boxShadow=d?p:""}),()=>{f.forEach(h=>{h.style.transform="",h.style.transition="",h.style.zIndex="",h.style.position="",h.style.boxShadow=""})}},[e,u,c,d]);const g={transform:u,transition:c,position:u?"relative":void 0,zIndex:d?20:void 0,boxShadow:d?"0 2px 10px rgba(15, 23, 42, 0.10), 0 1px 3px rgba(15, 23, 42, 0.06)":void 0};return l.jsx("th",{ref:a,style:g,className:T(t,"group/col select-none cursor-grab active:cursor-grabbing touch-none"),...n,...o,children:l.jsxs("div",{className:"flex items-center justify-end gap-2",children:[l.jsx("span",{"aria-hidden":"true",className:T("-mr-1 inline-flex h-4 w-3 shrink-0 items-center justify-center text-oai-gray-400 dark:text-oai-gray-600","opacity-0 transition-opacity duration-150 group-hover/col:opacity-100",d&&"opacity-100"),children:l.jsxs("svg",{viewBox:"0 0 8 14",width:"8",height:"14",fill:"currentColor","aria-hidden":"true",children:[l.jsx("circle",{cx:"2",cy:"2",r:"1"}),l.jsx("circle",{cx:"6",cy:"2",r:"1"}),l.jsx("circle",{cx:"2",cy:"7",r:"1"}),l.jsx("circle",{cx:"6",cy:"7",r:"1"}),l.jsx("circle",{cx:"2",cy:"12",r:"1"}),l.jsx("circle",{cx:"6",cy:"12",r:"1"})]})}),r]})})}const Gr="tokentracker.leaderboard.columnOrder.v1";function wa(){if(typeof window>"u")return null;try{const e=window.localStorage.getItem(Gr);if(!e)return null;const t=JSON.parse(e);return Array.isArray(t)?t.filter(r=>typeof r=="string"):null}catch{return null}}function It(e){if(!(typeof window>"u"))try{window.localStorage.setItem(Gr,JSON.stringify(e))}catch{}}function gr(e,t){if(!e)return t;const r=new Set(t),n=e.filter(a=>r.has(a)),o=t.filter(a=>!n.includes(a));return[...n,...o]}function ka(e){const t=i.useMemo(()=>e.join("|"),[e]),[r,n]=i.useState(()=>gr(wa(),e));i.useEffect(()=>{n(s=>{const c=gr(s,e);return c.length===s.length&&c.every((u,g)=>u===s[g])?s:(It(c),c)})},[t,e]);const o=i.useCallback((s,c)=>{!s||!c||s===c||n(d=>{const u=d.indexOf(s),g=d.indexOf(c);if(u===-1||g===-1)return d;const f=d.slice(),[p]=f.splice(u,1);return f.splice(g,0,p),It(f),f})},[]),a=i.useCallback(()=>{It(e),n(e)},[e]);return{order:r,reorder:o,reset:a}}function Sa(e,t){const r=Number(e),n=Number(t);return!Number.isFinite(r)||r<1||!Number.isFinite(n)||n<1?null:Math.min(100,Math.max(1,Math.ceil(r/n*100)))}function Vr(e){return typeof e=="string"?e.trim():""}function Na(e){const t=Vr(e);return t?t.toLowerCase()==="anonymous":!0}function Ca({me:e,totalEntries:t,meLabel:r,onOpenProfile:n,onJumpToMe:o,canJump:a,className:s}){const c=e&&typeof e.rank=="number"?e.rank:null;if(!c)return null;const d=Number(t)||0,u=Sa(c,d),g=Vr(e?.display_name),f=!g||Na(g)?r||"You":g,p=e?.user_id||f,h=n||(a?o:null),w=typeof h=="function",m=w?"button":"div",x=w?{type:"button",onClick:h,"aria-label":y(n?"leaderboard.summary.view_profile":"leaderboard.summary.jump_to_me")}:{};return l.jsxs(m,{...x,className:T("group inline-flex h-9 items-center gap-2.5 rounded-full border pl-1 pr-3.5 transition-all duration-300 select-none shadow-[0_1px_2px_rgba(0,0,0,0.03)]",w?"border-oai-gray-200 hover:border-oai-brand-400 dark:border-oai-gray-800 dark:hover:border-oai-brand-500/80 bg-oai-gray-50/50 dark:bg-white/[0.02] backdrop-blur-md hover:bg-oai-brand-50/40 dark:hover:bg-oai-brand-950/20 active:scale-[0.97] hover:shadow-[0_4px_12px_rgba(0,0,0,0.05)] dark:hover:shadow-[0_4px_20px_rgba(0,0,0,0.25)] dark:ring-1 dark:ring-white/[0.04] dark:hover:ring-white/[0.08]":"border-oai-gray-100 dark:border-oai-gray-800/60 bg-oai-gray-50/20 dark:bg-white/[0.01] backdrop-blur-sm dark:ring-1 dark:ring-white/[0.02]",s),children:[l.jsx(Tt,{size:"sm",avatarUrl:e?.avatar_url,displayName:f,seed:p}),l.jsx("span",{className:"hidden sm:inline max-w-[120px] truncate text-xs font-semibold text-oai-black dark:text-oai-gray-200 group-hover:text-oai-brand-600 dark:group-hover:text-oai-brand-400 transition-colors",children:f}),l.jsxs("span",{className:"text-xs font-bold tabular-nums text-oai-gray-800 dark:text-white",children:["#",c.toLocaleString()]}),u!=null&&l.jsx("span",{className:T("hidden sm:inline-flex items-center rounded-full px-2 py-0.5 text-[9px] font-extrabold tracking-wider tabular-nums uppercase transition-colors duration-300 ring-1",u<=10?"bg-amber-500/10 text-amber-600 dark:bg-amber-500/15 dark:text-amber-400 ring-amber-500/20":"bg-oai-brand-100/50 text-oai-brand-700 dark:bg-oai-brand-500/10 dark:text-oai-brand-400 ring-oai-brand-500/10"),children:y("leaderboard.summary.percentile",{p:String(u)})}),w?l.jsx(kn,{"aria-hidden":!0,className:"size-3 text-oai-gray-400 transition-all duration-300 group-hover:text-oai-brand-500 dark:text-oai-gray-500 group-hover:translate-x-0.5 group-hover:scale-110"}):l.jsxs("span",{className:"relative flex h-1.5 w-1.5 shrink-0 items-center justify-center ml-1",title:"You are here",children:[l.jsx("span",{className:"absolute inline-flex h-full w-full animate-ping rounded-full bg-emerald-400 opacity-75 duration-1000"}),l.jsx("span",{className:"relative inline-flex h-1.5 w-1.5 rounded-full bg-emerald-500"})]})]})}const Ra=i.lazy(()=>mn(()=>import("./LeaderboardProfileModal-DasxA8Lo.js"),__vite__mapDeps([0,1,2,3,4,5,6,7,8,9])).then(e=>({default:e.LeaderboardProfileModal}))),Ut=[10,20,50,100],Kt=20,qr="tokentracker:leaderboard:pageSize";function Da(){if(typeof window>"u")return Kt;try{const e=window.localStorage.getItem(qr),t=Number(e);if(Ut.includes(t))return t}catch{}return Kt}function hr(e,t,r){const n=Number(e);if(!Number.isFinite(n)||n<=0)return"-";const o=gn(t),a=t===xn?n:n*r;return a>=1e3?`${o}${Math.round(a).toLocaleString()}`:a>=10?`${o}${Math.round(a)}`:`${o}${a.toFixed(2)}`}function br({value:e}){return l.jsxs(l.Fragment,{children:[l.jsx("span",{className:"sm:hidden",children:fn(e)}),l.jsx("span",{className:"hidden sm:inline",children:wr(e)})]})}function pr(e,t,r){const n=t?"text-oai-gray-700 dark:text-oai-gray-300":"text-oai-gray-500 dark:text-oai-gray-400",o=t?"bg-oai-brand-50 dark:bg-oai-brand-900/10":"bg-white dark:bg-oai-gray-950 group-hover:bg-oai-gray-50 dark:group-hover:bg-oai-gray-900/60";return r.map(a=>l.jsx("td",{"data-column-key":a.key,className:T("hidden sm:table-cell px-3 sm:px-4 py-4 whitespace-nowrap text-right tabular-nums",n,o),children:wr(e?.[a.key])},a.key))}const ja={1:{text:"text-amber-600 dark:text-amber-400",badge:"bg-amber-50 dark:bg-amber-900/20"},2:{text:"text-gray-500 dark:text-gray-300",badge:"bg-gray-50 dark:bg-gray-800/40"},3:{text:"text-orange-700 dark:text-orange-400",badge:"bg-orange-50 dark:bg-orange-900/20"}};function mr({rank:e,placeholder:t}){const r=ja[e];return r?l.jsx("span",{className:T("inline-flex items-center justify-center h-7 w-7 rounded-full text-xs font-bold",r.text,r.badge),children:e}):l.jsx("span",{className:"inline-flex items-center justify-center h-7 w-7 text-sm",children:e??t})}function xr(e){if(typeof e!="string")return null;const t=e.trim().toLowerCase();return t==="week"||t==="month"||t==="total"?t:null}function Ea(e){if(!e)return y("shared.error.prefix",{error:y("leaderboard.error.unknown")});const t=e?.message||String(e),r=String(t||"").trim()||y("leaderboard.error.unknown");return y("shared.error.prefix",{error:r})}function Jr(e){return typeof e!="string"?"":e.trim()}function _a(e){const t=Jr(e);return t?t.toLowerCase()==="anonymous":!0}function vr(e,t){const r=typeof e?.user_id=="string"?e.user_id.trim():"";return r||`${e?.rank??""}:${t}`}function yr({githubUrl:e}){return l.jsxs("span",{className:"relative inline-flex items-center group/gh shrink-0",children:[l.jsx("a",{href:e,target:"_blank",rel:"noopener noreferrer",onClick:t=>t.stopPropagation(),"aria-label":y("leaderboard.github.aria"),className:"text-oai-black hover:text-oai-gray-500 dark:text-white dark:hover:text-oai-gray-400 transition-colors",children:l.jsx(dn,{provider:"GITHUB",size:16})}),l.jsxs("span",{role:"tooltip",className:"invisible opacity-0 group-hover/gh:visible group-hover/gh:opacity-100 absolute right-0 bottom-full mb-2 whitespace-nowrap rounded-md bg-oai-black dark:bg-oai-gray-700 px-2.5 py-1.5 text-[11px] leading-relaxed text-white shadow-lg transition-opacity duration-150 z-50 before:content-[''] before:absolute before:inset-x-0 before:top-full before:h-2.5",children:[l.jsx("span",{className:"block",children:y("leaderboard.github.tooltipAction")}),l.jsxs("span",{className:"block text-oai-gray-300 dark:text-oai-gray-400",children:[y("leaderboard.github.tooltipPrefix")," ",l.jsx(un,{to:"/settings",onClick:t=>t.stopPropagation(),className:"text-white underline underline-offset-2 decoration-oai-gray-400 hover:text-oai-brand-300 hover:decoration-oai-brand-300",children:y("leaderboard.github.tooltipSettingsLink")}),y("leaderboard.github.tooltipSuffix")]})]})]})}function La({auth:e,signedIn:t,sessionSoftExpired:r}){const n=Qr(),o=en(),{openLoginModal:a}=tn(),{signedIn:s,loading:c,user:d}=rn(),{currency:u,rate:g}=vn(),f=i.useMemo(()=>nn(),[]),p=on(),h=t&&!r,w=i.useMemo(()=>h&&(typeof e=="function"||typeof e=="string"||e&&typeof e=="object")?e:null,[e,h]),m=h?w:null,x=h&&an(m),k=y("shared.placeholder.short"),S=i.useMemo(()=>wt.map(b=>b.key),[]),{order:v,reorder:C}=ka(S),E=i.useMemo(()=>{const b=new Map;for(const M of wt)b.set(M.key,M);return b},[]),R=i.useMemo(()=>v.map(b=>E.get(b)).filter(Boolean),[v,E]),N=Pn(er(Jt,{activationConstraint:{distance:6}}),er(Vt,{coordinateGetter:da})),D=i.useCallback(b=>{const{active:M,over:re}=b;!re||M.id===re.id||C(String(M.id),String(re.id))},[C]),[L,I]=i.useState(1),[_,Z]=i.useState(Da),[G,Q]=i.useState(null),xe=i.useCallback(b=>{typeof b=="string"&&b.trim()&&Q(b.trim())},[]),ze=i.useCallback(()=>Q(null),[]),H=i.useCallback(b=>{const M=Ut.includes(b)?b:Kt;Z(M),I(1);try{window.localStorage.setItem(qr,String(M))}catch{}},[]),[Be,ae]=i.useState(0),[B,ke]=i.useState(()=>({loading:!1,error:null,data:null})),[W,ie]=i.useState(()=>sn()),[fe,Se]=i.useState(!1),O=i.useMemo(()=>{const b=new URLSearchParams(n?.search||"");return xr(b.get("period"))||"total"},[n?.search]),$e=b=>{const M=xr(b);if(!M||M===O)return;const re=new URLSearchParams(n?.search||"");re.set("period",M),I(1),o(`${n?.pathname||"/leaderboard"}?${re.toString()}`,{replace:!0})};i.useEffect(()=>{c||p||s||a()},[s,c,p,a]),i.useEffect(()=>{I(1)},[O]);const se=i.useMemo(()=>(dt(L,{min:1,max:1e6,fallback:1})-1)*_,[L,_]);i.useEffect(()=>{if(!f&&!p)return;let b=!0;return ke(M=>({...M,loading:!0,error:null})),(async()=>{const M=await ln({userId:d?.id||null,period:O,limit:_,offset:se});b&&ke({loading:!1,error:null,data:M})})().catch(M=>{b&&ke({loading:!1,error:Ea(M),data:null})}),()=>{b=!1}},[f,d?.id,se,Be,p,O,_]);const P=B.data,A=P?.total_pages??null,Ie=P?.total_entries??0,U=P?.page??L,Ne=i.useMemo(()=>fa(U,A),[U,A]),te=P?.from||null,ve=P?.to||null,ye=P?.generated_at||null,ge=P?.me||null,Te=y("leaderboard.me_label"),He=y("leaderboard.anon_label"),le=y("leaderboard.period.week"),Le=y("leaderboard.period.month"),Oe=y("leaderboard.period.total"),Ge=O==="month"?Le:O==="total"?Oe:le,Fe=i.useMemo(()=>{const b=Array.isArray(P?.entries)?P.entries:[];return ha({entries:b,me:ge,meLabel:Te})},[P?.entries,ge,Te]),Ce=i.useMemo(()=>ba(ge?.rank,_),[ge?.rank,_]),Rt=Ce!=null&&Ce===U,Re=i.useCallback(()=>{Ce!=null&&I(Ce)},[Ce]),De=async()=>{Se(!0);try{hn(!0),ie(!0),await bn(()=>Zt(m));const b=await Zt(m);b&&await pn({accessToken:b,period:O,source:"leaderboard-enable-sync"}),ae(M=>M+1)}catch(b){console.warn("[tokentracker] sync:",b)}finally{Se(!1)}},{canPrev:je,canNext:Ve}=ga({page:U,totalPages:A}),he=Array.isArray(Fe)&&Fe.length!==0;let Ee=null;B.loading?Ee=l.jsx(va,{rows:_}):B.error?Ee=l.jsx("div",{className:"px-6 py-12 text-center",children:l.jsx("p",{className:"text-sm text-red-500 dark:text-red-400",children:B.error})}):he?Ee=l.jsx($o,{sensors:N,collisionDetection:Bn,modifiers:[Go],onDragEnd:D,children:l.jsx("div",{className:"w-full overflow-x-auto",children:l.jsxs("table",{className:"min-w-full sm:min-w-max w-full text-left text-sm",children:[l.jsx("thead",{className:"border-b border-oai-gray-200 dark:border-oai-gray-800",children:l.jsxs("tr",{children:[l.jsx("th",{className:T(Xr,"text-[11px] font-semibold uppercase tracking-wider text-oai-gray-400 dark:text-oai-gray-500"),children:y("leaderboard.column.rank")}),l.jsx("th",{className:T(Hr,"text-[11px] font-semibold uppercase tracking-wider text-oai-gray-400 dark:text-oai-gray-500"),children:y("leaderboard.column.user")}),l.jsx("th",{className:"px-3 sm:px-4 py-4 text-[11px] font-semibold uppercase tracking-wider text-oai-gray-400 dark:text-oai-gray-500 whitespace-nowrap text-right align-middle",children:y("leaderboard.column.total")}),l.jsx("th",{className:"hidden sm:table-cell px-3 sm:px-4 py-4 text-[11px] font-semibold uppercase tracking-wider text-oai-gray-400 dark:text-oai-gray-500 whitespace-nowrap text-right align-middle",title:"Based on estimated API pricing, not actual billing",children:y("leaderboard.column.est_cost")}),l.jsx(ea,{items:v,strategy:Zo,children:R.map(b=>l.jsx(ya,{id:b.key,thClassName:"hidden sm:table-cell px-3 sm:px-4 py-4 text-[11px] font-semibold uppercase tracking-wider text-oai-gray-400 dark:text-oai-gray-500 whitespace-nowrap align-middle",children:l.jsx(ma,{iconSrc:b.icon,label:y(b.copyKey)})},b.key))})]})}),l.jsx("tbody",{className:"divide-y divide-oai-gray-100 dark:divide-oai-gray-800/50",children:Fe.map((b,M)=>{if(b?.is_ellipsis){const $=4+R.length;return l.jsx("tr",{"aria-hidden":"true",children:l.jsx("td",{colSpan:$,className:"px-4 py-2 text-center text-oai-gray-400 dark:text-oai-gray-600 bg-white dark:bg-oai-gray-950 select-none tracking-[0.4em] text-xs",children:"···"})},`ellipsis-${M}`)}const re=!!b?.is_me,Je=typeof b?.user_id=="string"?b.user_id:null,Ze=Jr(b?.display_name),Dt=_a(Ze)?He:Ze,ce=re?Te:Dt,Pe=!!Je,X=Pe?{role:"button",tabIndex:0,onClick:Pe?()=>xe(Je):void 0,onKeyDown:Pe?$=>{($.key==="Enter"||$.key===" ")&&($.preventDefault(),xe(Je))}:void 0,"aria-label":y("leaderboard.profile_modal.row_aria",{name:ce})}:{};if(re){const $=!!b?.is_pinned;return l.jsxs("tr",{...X,className:T("bg-oai-brand-50 dark:bg-oai-brand-900/10 transition-colors",$?"border-t border-b border-oai-brand-300/40 dark:border-oai-brand-500/20":"border-y border-oai-brand-300/40 dark:border-oai-brand-500/30",Pe&&"cursor-pointer focus:outline-none focus-visible:ring-2 focus-visible:ring-oai-brand-500/60"),children:[l.jsx("td",{className:T($t(!0),"relative font-semibold text-oai-brand-600 dark:text-oai-brand-400",$&&"before:absolute before:left-0 before:top-[15%] before:h-[70%] before:w-[3px] before:rounded-r before:bg-oai-brand-500 dark:before:bg-oai-brand-400"),children:l.jsx(mr,{rank:b?.rank,placeholder:k})}),l.jsx("td",{className:Ft(!0),children:l.jsxs("div",{className:"flex min-w-0 items-center gap-2",children:[l.jsx(Tt,{avatarUrl:b?.avatar_url,displayName:ce,seed:vr(b,ce)}),l.jsx("span",{className:"truncate font-semibold text-oai-black dark:text-oai-white",children:ce}),b?.github_url&&l.jsx(yr,{githubUrl:b.github_url})]})}),l.jsx("td",{className:"px-3 sm:px-4 py-4 font-medium text-oai-black dark:text-oai-white whitespace-nowrap text-right tabular-nums bg-oai-brand-50 dark:bg-oai-brand-900/10",children:l.jsx(br,{value:b?.total_tokens})}),l.jsx("td",{className:"hidden sm:table-cell px-3 sm:px-4 py-4 font-medium text-oai-brand-600 dark:text-oai-brand-400 whitespace-nowrap text-right tabular-nums bg-oai-brand-50 dark:bg-oai-brand-900/10",title:"Based on estimated API pricing, not actual billing",children:hr(b?.estimated_cost_usd,u,g)}),pr(b,!0,R)]},`row-${b?.rank}-${ce}${$?"-pin":""}`)}return l.jsxs("tr",{...X,className:T("group transition-colors",Pe&&"cursor-pointer hover:bg-oai-gray-50 dark:hover:bg-oai-gray-900/60 focus:outline-none focus-visible:ring-2 focus-visible:ring-oai-brand-500/60"),children:[l.jsx("td",{className:T($t(!1),"font-medium text-oai-gray-500 dark:text-oai-gray-400"),children:l.jsx(mr,{rank:b?.rank,placeholder:k})}),l.jsx("td",{className:Ft(!1),children:l.jsxs("div",{className:"flex min-w-0 items-center gap-2",children:[l.jsx(Tt,{avatarUrl:b?.avatar_url,displayName:ce,seed:vr(b,ce)}),l.jsx("span",{className:"truncate font-medium text-oai-gray-800 dark:text-oai-gray-200",children:ce}),b?.github_url&&l.jsx(yr,{githubUrl:b.github_url})]})}),l.jsx("td",{className:"px-3 sm:px-4 py-4 font-semibold text-oai-gray-800 dark:text-oai-gray-200 whitespace-nowrap text-right tabular-nums bg-white dark:bg-oai-gray-950 group-hover:bg-oai-gray-50 dark:group-hover:bg-oai-gray-900/60",children:l.jsx(br,{value:b?.total_tokens})}),l.jsx("td",{className:"hidden sm:table-cell px-3 sm:px-4 py-4 text-oai-gray-500 dark:text-oai-gray-400 whitespace-nowrap text-right tabular-nums bg-white dark:bg-oai-gray-950 group-hover:bg-oai-gray-50 dark:group-hover:bg-oai-gray-900/60",title:"Based on estimated API pricing, not actual billing",children:hr(b?.estimated_cost_usd,u,g)}),pr(b,!1,R)]},`row-${b?.rank}-${ce}`)})})]})})}):Ee=l.jsx("div",{className:"px-6 py-12 text-center",children:l.jsx("p",{className:"text-sm text-oai-gray-500 dark:text-oai-gray-400",children:y("leaderboard.empty")})});let qe=null;return typeof A=="number"?qe=Ne.map((b,M)=>b==null?l.jsx("span",{className:"px-2 text-oai-gray-400 dark:text-oai-gray-500",children:y("leaderboard.pagination.ellipsis")},`ellipsis-${M}`):l.jsx("button",{className:T("flex h-8 w-8 items-center justify-center rounded-md text-sm font-medium transition-colors",b===U?"bg-oai-gray-200 dark:bg-oai-gray-800 text-oai-black dark:text-white":"text-oai-gray-500 dark:text-oai-gray-400 hover:bg-oai-gray-100 dark:hover:bg-oai-gray-800 hover:text-oai-black dark:hover:text-white"),onClick:()=>I(b),disabled:B.loading,children:String(b)},`page-${b}`)):qe=l.jsx("span",{className:"text-sm text-oai-gray-500 dark:text-oai-gray-400",children:y("leaderboard.pagination.page_unknown",{page:String(U)})}),l.jsxs("div",{className:"flex flex-col flex-1 text-oai-black dark:text-oai-white font-oai antialiased",children:[l.jsx("main",{className:"flex-1 pt-8 sm:pt-10 pb-12 sm:pb-16",children:l.jsxs("div",{className:"mx-auto max-w-6xl px-4 sm:px-6",children:[l.jsxs("div",{className:"mb-5 sm:mb-6",children:[l.jsx("h1",{className:"text-3xl sm:text-4xl font-semibold tracking-tight text-oai-black dark:text-white mb-2 sm:mb-3",children:y("leaderboard.title")}),l.jsxs("p",{className:"text-oai-gray-500 dark:text-oai-gray-400 text-sm sm:text-base",children:[O==="total"?y("leaderboard.range.total"):te&&ve?y("leaderboard.range",{period:Ge,from:te,to:ve}):y("leaderboard.range_loading",{period:Ge}),ye&&l.jsx("span",{className:"ml-2 pl-2 border-l border-oai-gray-200 dark:border-oai-gray-800 hidden sm:inline-block text-oai-gray-400 dark:text-oai-gray-500 text-xs",children:y("leaderboard.generated_at",{ts:ye})})]})]}),l.jsxs("div",{className:"mb-6 sm:mb-8 flex flex-row items-center justify-between gap-3",children:[l.jsx("div",{className:"inline-flex h-9 p-1 border border-oai-gray-200 dark:border-oai-gray-800 rounded-full items-center relative",children:["week","month","total"].map(b=>{const M=O===b;return l.jsxs("button",{onClick:()=>$e(b),disabled:B.loading,className:T("px-3 sm:px-4 h-7 text-sm font-medium rounded-full flex items-center justify-center transition-colors relative",M?"text-oai-black dark:text-white":"text-oai-gray-500 dark:text-oai-gray-400 hover:text-oai-gray-800 dark:hover:text-oai-gray-200"),children:[l.jsx("span",{className:"relative z-10",children:b==="week"?le:b==="month"?Le:Oe}),M&&l.jsx(cn.div,{layoutId:"leaderboard-period-active-bg",className:"absolute inset-0 bg-oai-gray-200 dark:bg-oai-gray-800 rounded-full z-0",transition:{type:"spring",stiffness:380,damping:30}})]},b)})}),l.jsx(Ca,{me:ge,totalEntries:Ie,meLabel:Te,onOpenProfile:ge?.user_id?()=>xe(ge.user_id):void 0,onJumpToMe:Re,canJump:Ce!=null&&!Rt&&!B.loading,className:"shrink-0"})]}),!t&&l.jsxs("div",{className:"mb-6 flex flex-col gap-2 sm:flex-row sm:items-center sm:justify-between text-sm",children:[l.jsx("p",{className:"text-oai-gray-500 dark:text-oai-gray-400",children:y("leaderboard.signin_prompt")}),l.jsx("button",{onClick:a,className:"shrink-0 whitespace-nowrap self-start sm:self-auto px-3 py-1.5 text-sm font-medium text-oai-gray-600 dark:text-oai-gray-300 border border-oai-gray-300 dark:border-oai-gray-700 rounded-md hover:text-oai-black dark:hover:text-white hover:border-oai-gray-400 dark:hover:border-oai-gray-600 transition-colors",children:y("leaderboard.signin_button")})]}),h&&x&&!W&&l.jsxs("div",{className:"mb-6 flex flex-col gap-2 sm:flex-row sm:items-center sm:justify-between text-sm",children:[l.jsx("p",{className:"text-oai-gray-500 dark:text-oai-gray-400",children:y("leaderboard.sync_prompt")}),l.jsx("button",{onClick:De,disabled:fe,className:"shrink-0 whitespace-nowrap self-start sm:self-auto px-3 py-1.5 text-sm font-medium text-oai-gray-600 dark:text-oai-gray-300 border border-oai-gray-300 dark:border-oai-gray-700 rounded-md hover:text-oai-black dark:hover:text-white hover:border-oai-gray-400 dark:hover:border-oai-gray-600 disabled:opacity-50 transition-colors",children:fe?y("leaderboard.sync_button.busy"):y("leaderboard.sync_button.idle")})]}),l.jsxs("div",{className:"rounded-xl border border-oai-gray-200 dark:border-oai-gray-800 overflow-hidden",children:[Ee,l.jsxs("div",{className:"px-6 py-3 border-t border-oai-gray-200 dark:border-oai-gray-800 flex flex-wrap items-center justify-end gap-x-4 gap-y-2",children:[l.jsxs("div",{className:"flex items-center gap-2 text-sm text-oai-gray-500 dark:text-oai-gray-400",children:[l.jsx("label",{htmlFor:"leaderboard-page-size",className:"whitespace-nowrap",children:y("leaderboard.pagination.page_size_label")}),l.jsxs("div",{className:"relative",children:[l.jsx("select",{id:"leaderboard-page-size",value:_,onChange:b=>H(Number(b.target.value)),disabled:B.loading,className:"appearance-none pl-3 pr-8 py-1 rounded-md bg-white dark:bg-oai-gray-950 border border-oai-gray-300 dark:border-oai-gray-700 text-oai-gray-700 dark:text-oai-gray-300 hover:border-oai-gray-400 dark:hover:border-oai-gray-600 focus:outline-none focus:ring-2 focus:ring-oai-brand-500 disabled:opacity-50 transition-colors",children:Ut.map(b=>l.jsx("option",{value:b,children:b},b))}),l.jsx(yn,{className:"pointer-events-none absolute right-2 top-1/2 -translate-y-1/2 h-3.5 w-3.5 text-oai-gray-500 dark:text-oai-gray-400",strokeWidth:2,"aria-hidden":"true"})]})]}),l.jsx("div",{className:"h-5 w-px bg-oai-gray-200 dark:bg-oai-gray-800","aria-hidden":"true"}),l.jsx("button",{className:T("px-3 py-1.5 text-sm font-medium text-oai-gray-500 dark:text-oai-gray-400 rounded-md transition-colors",je&&!B.loading?"hover:bg-oai-gray-100 dark:hover:bg-oai-gray-800 hover:text-oai-black dark:hover:text-white":"opacity-50 cursor-not-allowed"),onClick:()=>I(b=>Math.max(1,b-1)),disabled:!je||B.loading,children:y("leaderboard.pagination.prev")}),l.jsx("div",{className:"flex flex-wrap items-center gap-1",children:qe}),l.jsx("button",{className:T("px-3 py-1.5 text-sm font-medium text-oai-gray-500 dark:text-oai-gray-400 rounded-md transition-colors",Ve&&!B.loading?"hover:bg-oai-gray-100 dark:hover:bg-oai-gray-800 hover:text-oai-black dark:hover:text-white":"opacity-50 cursor-not-allowed"),onClick:()=>I(b=>b+1),disabled:!Ve||B.loading,children:y("leaderboard.pagination.next")})]})]})]})}),l.jsx("footer",{className:"border-t border-oai-gray-200 dark:border-oai-gray-900 py-8 transition-colors duration-200",children:l.jsxs("div",{className:"mx-auto flex max-w-6xl items-center justify-between px-4 sm:px-6 text-sm text-oai-gray-400 dark:text-oai-gray-500",children:[l.jsx("p",{children:y("landing.v2.footer.line")}),l.jsx("a",{href:"https://github.com/mm7894215/TokenTracker",className:"text-oai-gray-400 dark:text-oai-gray-500 hover:text-oai-black dark:hover:text-white transition-colors",target:"_blank",rel:"noopener noreferrer",children:y("landing.v2.nav.github")})]})}),l.jsx(i.Suspense,{fallback:null,children:l.jsx(Ra,{isOpen:!!G,userId:G,period:O,accessToken:m,onClose:ze})})]})}export{La as LeaderboardPage};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{c as D,r as g,
|
|
1
|
+
import{c as D,r as g,cj as Q,u as e,s as n,ck as V,ao as ee,cl as ae,N as c,Q as re,cm as te,ce as se,L as ie,e as oe,P as T,X as ne,D as I,C as le,a5 as de}from"./main-uqC1VAKB.js";import{u as ce}from"./useCurrency-vRzRfd7L.js";import{L as W}from"./LeaderboardAvatar-CLMnffKE.js";import{A as me}from"./ActivityHeatmap-BjiEMIl2.js";import{A as F}from"./arrow-up-right-BS0sCPTz.js";import{C as xe}from"./check-DKwh5hl-.js";import{D as ge,a as pe,b as he,c as fe,d as be,e as ue}from"./DialogTitle-CEBn-oBo.js";import"./info-DMW1GFmI.js";const ye=[["path",{d:"m18 16 4-4-4-4",key:"1inbqp"}],["path",{d:"m6 8-4 4 4 4",key:"15zrgr"}],["path",{d:"m14.5 4-5 16",key:"e7oirm"}]],ke=D("code-xml",ye);const je=[["path",{d:"M2 9.5a5.5 5.5 0 0 1 9.591-3.676.56.56 0 0 0 .818 0A5.49 5.49 0 0 1 22 9.5c0 2.29-1.5 4-3 5.5l-5.492 5.313a2 2 0 0 1-3 .019L5 15c-1.5-1.5-3-3.2-3-5.5",key:"mvr1a0"}]],ve=D("heart",je);const Ne=[["path",{d:"M9 17H7A5 5 0 0 1 7 7h2",key:"8i5ue5"}],["path",{d:"M15 7h2a5 5 0 1 1 0 10h-2",key:"1b9ql8"}],["line",{x1:"8",x2:"16",y1:"12",y2:"12",key:"1jonct"}]],_e=D("link-2",Ne),C="tokentracker_likes";function H(a){if(!a)return!1;try{const r=localStorage.getItem(C);return r?!!JSON.parse(r)?.[a]:!1}catch{return!1}}function z(a,r){if(a)try{const t=localStorage.getItem(C),s=t?JSON.parse(t):{};r?s[a]=!0:delete s[a],localStorage.setItem(C,JSON.stringify(s))}catch{}}function E({userId:a}){const[r,t]=g.useState(!1),[s,i]=g.useState(0),[l,m]=g.useState(!1),[d,p]=g.useState(!1),[y,k]=g.useState(!1),[j,M]=g.useState([]),[v,b]=g.useState(!1),N=g.useRef(0);g.useEffect(()=>{let o=!1;return a?(m(!1),t(H(a)),Q({userId:a}).then(x=>{o||(i(Number(x?.count)||0),m(!0))}).catch(()=>{o||(i(0),m(!0))}),()=>{o=!0}):(m(!1),()=>{o=!0})},[a]);const _=()=>{k(!0),setTimeout(()=>k(!1),450),b(!0),setTimeout(()=>b(!1),500);const o=["#ff4757","#ff6b81","#ffa502","#70a1ff","#2ed573","#a29bfe"],x=["circle","heart"],f=[];for(let h=0;h<12;h++){const S=(h*30+Math.random()*20-10)*(Math.PI/180),A=45+Math.random()*45,G=Math.cos(S)*A,X=Math.sin(S)*A-(10+Math.random()*15),q=Math.random()*360-180,J=6+Math.random()*8,Y=o[Math.floor(Math.random()*o.length)],Z=x[Math.floor(Math.random()*x.length)],K=++N.current;f.push({id:K,tx:G,ty:X,rot:q,size:J,color:Y,shape:Z})}M(h=>[...h,...f]),setTimeout(()=>{M(h=>h.filter(S=>!f.find(A=>A.id===S.id)))},850)},u=async o=>{p(!0);try{const x=await V({userId:a,delta:o}),f=Number(x?.count);Number.isFinite(f)&&i(f)}catch{t(x=>!x),i(x=>Math.max(0,x-o)),z(a,!H(a))}finally{p(!1)}},w=o=>{o.stopPropagation(),!(!a||!l||d)&&(r?(t(!1),i(x=>Math.max(0,x-1)),z(a,!1),u(-1)):(t(!0),i(x=>x+1),z(a,!0),_(),u(1)))};return e.jsxs("div",{className:"relative inline-flex items-center select-none z-10",children:[e.jsx("style",{dangerouslySetInnerHTML:{__html:`
|
|
2
2
|
@keyframes tt-like-pop {
|
|
3
3
|
0% { transform: scale(1); }
|
|
4
4
|
25% { transform: scale(0.75); }
|
|
@@ -38,7 +38,7 @@ import{c as D,r as g,aS as Z,u as e,s as n,aT as Q,ai as ee,aU as ae,H as c,J as
|
|
|
38
38
|
.tt-num-anim {
|
|
39
39
|
animation: tt-num-scroll 0.25s ease-out forwards;
|
|
40
40
|
}
|
|
41
|
-
`}}),j.map(o=>e.jsx("span",{className:"tt-particle",style:{"--tx":`${o.tx}px`,"--ty":`${o.ty}px`,"--rot":`${o.rot}deg`,width:`${o.size}px`,height:`${o.size}px`,backgroundColor:o.shape==="circle"?o.color:"transparent",borderRadius:o.shape==="circle"?"50%":"0",animation:"tt-particle-fly 0.8s cubic-bezier(0.1, 0.8, 0.3, 1) forwards"},children:o.shape==="heart"&&e.jsx("svg",{viewBox:"0 0 24 24",width:"100%",height:"100%",fill:o.color,className:"w-full h-full",children:e.jsx("path",{d:"M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z"})})},o.id)),e.jsxs("button",{type:"button",onClick:w,disabled:!l||d,"aria-label":r?n("leaderboard.profile.like.aria_unlike"):n("leaderboard.profile.like.aria_like"),className:`group flex items-center justify-center gap-1.5 h-8 min-w-[48px] px-2.5 rounded-full border transition-all duration-300 outline-none focus-visible:ring-2 focus-visible:ring-rose-500/50 disabled:opacity-60 disabled:cursor-default ${r?"bg-rose-50/60 border-rose-200/80 text-rose-500 dark:bg-rose-950/20 dark:border-rose-900/40 dark:text-rose-400 shadow-sm":"bg-white/80 border-oai-gray-200 text-oai-gray-500 hover:border-rose-200 hover:text-rose-500 hover:bg-rose-50/30 dark:bg-oai-gray-950/50 dark:border-white/10 dark:text-oai-gray-400 dark:hover:border-rose-900/50 dark:hover:text-rose-400 dark:hover:bg-rose-950/5"}`,children:[e.jsx("span",{className:y?"tt-animate-pop":"group-active:scale-90 transition-transform duration-100",children:e.jsx(ve,{size:14,className:`transition-all duration-300 ${r?"fill-rose-500 text-rose-500 dark:fill-rose-400 dark:text-rose-400":"fill-transparent"}`})}),e.jsx("span",{className:`text-[12px] font-bold font-mono tabular-nums tracking-tight ${r?"text-rose-600 dark:text-rose-400":"text-oai-gray-600 dark:text-oai-gray-400"} ${v?"tt-num-anim":""}`,children:l?s:"·"})]})]})}function we(a,r,t){const s=Number(a);return!Number.isFinite(s)||s<0?"—":s>0&&s<.01?`<${r==="USD"?"$":""}0.01`:le(s,{decimals:2,currency:r,rate:t})}function
|
|
41
|
+
`}}),j.map(o=>e.jsx("span",{className:"tt-particle",style:{"--tx":`${o.tx}px`,"--ty":`${o.ty}px`,"--rot":`${o.rot}deg`,width:`${o.size}px`,height:`${o.size}px`,backgroundColor:o.shape==="circle"?o.color:"transparent",borderRadius:o.shape==="circle"?"50%":"0",animation:"tt-particle-fly 0.8s cubic-bezier(0.1, 0.8, 0.3, 1) forwards"},children:o.shape==="heart"&&e.jsx("svg",{viewBox:"0 0 24 24",width:"100%",height:"100%",fill:o.color,className:"w-full h-full",children:e.jsx("path",{d:"M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z"})})},o.id)),e.jsxs("button",{type:"button",onClick:w,disabled:!l||d,"aria-label":r?n("leaderboard.profile.like.aria_unlike"):n("leaderboard.profile.like.aria_like"),className:`group flex items-center justify-center gap-1.5 h-8 min-w-[48px] px-2.5 rounded-full border transition-all duration-300 outline-none focus-visible:ring-2 focus-visible:ring-rose-500/50 disabled:opacity-60 disabled:cursor-default ${r?"bg-rose-50/60 border-rose-200/80 text-rose-500 dark:bg-rose-950/20 dark:border-rose-900/40 dark:text-rose-400 shadow-sm":"bg-white/80 border-oai-gray-200 text-oai-gray-500 hover:border-rose-200 hover:text-rose-500 hover:bg-rose-50/30 dark:bg-oai-gray-950/50 dark:border-white/10 dark:text-oai-gray-400 dark:hover:border-rose-900/50 dark:hover:text-rose-400 dark:hover:bg-rose-950/5"}`,children:[e.jsx("span",{className:y?"tt-animate-pop":"group-active:scale-90 transition-transform duration-100",children:e.jsx(ve,{size:14,className:`transition-all duration-300 ${r?"fill-rose-500 text-rose-500 dark:fill-rose-400 dark:text-rose-400":"fill-transparent"}`})}),e.jsx("span",{className:`text-[12px] font-bold font-mono tabular-nums tracking-tight ${r?"text-rose-600 dark:text-rose-400":"text-oai-gray-600 dark:text-oai-gray-400"} ${v?"tt-num-anim":""}`,children:l?s:"·"})]})]})}function we(a,r,t){const s=Number(a);return!Number.isFinite(s)||s<0?"—":s>0&&s<.01?`<${r==="USD"?"$":""}0.01`:le(s,{decimals:2,currency:r,rate:t})}function R(a,r,t){const s=Number(a);if(!Number.isFinite(s)||s<0)return"—";if(s<1e3)return we(s,r,t);const i=r==="USD"?s:s*(t||1);return`${r==="USD"?"$":""}${I(i,{decimals:1})}`}function $(a){const r=Number(a);return!Number.isFinite(r)||r<=0?"0":I(r,{decimals:1})}function Se(a){const r=Array.isArray(a)?a:[];if(r.length===0)return null;const t=r.map(i=>({day:i.date,total_tokens:i.total_tokens,models:i.models||null})),s=r[r.length-1]?.date;return oe({dailyRows:t,weeks:52,to:s})}const Ae=`
|
|
42
42
|
@keyframes tt-shimmer {
|
|
43
43
|
100% { transform: translateX(100%); }
|
|
44
44
|
}
|
|
@@ -69,4 +69,4 @@ import{c as D,r as g,aS as Z,u as e,s as n,aT as Q,ai as ee,aU as ae,H as c,J as
|
|
|
69
69
|
rgba(255, 255, 255, 0) 100%
|
|
70
70
|
);
|
|
71
71
|
}
|
|
72
|
-
`;function Le({variant:a="modal"}){const r="rounded bg-oai-gray-200/50 dark:bg-oai-gray-800/40 tt-shimmer-bar",t=a==="page";return e.jsxs("div",{children:[e.jsx("style",{dangerouslySetInnerHTML:{__html:Ae}}),t?e.jsxs("div",{className:"flex items-start gap-5 px-6 sm:px-8 pt-8 pb-7 animate-fade-in",children:[e.jsx("div",{className:"h-[68px] w-[68px] rounded-full bg-oai-gray-200/50 dark:bg-oai-gray-800/40 tt-shimmer-bar shrink-0"}),e.jsxs("div",{className:"flex-1 min-w-0 flex items-start justify-between gap-4 pt-0.5",children:[e.jsxs("div",{className:"min-w-0 space-y-2.5",children:[e.jsx("div",{className:c(r,"h-7 w-48")}),e.jsx("div",{className:c(r,"h-3.5 w-32")})]}),e.jsxs("div",{className:"shrink-0 space-y-1.5 flex flex-col items-end",children:[e.jsx("div",{className:c(r,"h-2.5 w-8")}),e.jsx("div",{className:c(r,"h-7 w-12")})]})]})]}):e.jsxs("div",{className:"flex items-start gap-4 px-6 pt-6 pb-5 border-b border-oai-gray-200/80 dark:border-oai-gray-800/60 animate-fade-in",children:[e.jsx("div",{className:"h-14 w-14 rounded-full bg-oai-gray-200/50 dark:bg-oai-gray-800/40 tt-shimmer-bar shrink-0"}),e.jsxs("div",{className:"flex-1 min-w-0 space-y-2 pt-1",children:[e.jsx("div",{className:c(r,"h-4 w-40")}),e.jsx("div",{className:c(r,"h-3 w-56")})]}),e.jsx("div",{className:c(r,"h-4 w-4 shrink-0 mt-1")})]}),e.jsxs("div",{className:c("space-y-6",t?"px-6 sm:px-8 pt-6 pb-8 border-t border-oai-gray-200/80 dark:border-oai-gray-800/60":"px-6 py-5"),children:[e.jsx("div",{className:"grid grid-cols-4 gap-x-6 gap-y-4",children:Array.from({length:4}).map((s,i)=>e.jsxs("div",{children:[e.jsx("div",{className:c(r,"h-6 w-20")}),e.jsx("div",{className:c(r,"mt-2 h-3 w-14")})]},i))}),e.jsx("div",{className:"space-y-3 border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:Array.from({length:3}).map((s,i)=>e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:c(r,"h-3 w-24")}),e.jsx("div",{className:c(r,"h-3 w-44")})]},i))}),e.jsxs("div",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsx("div",{className:c(r,"h-3 w-44 mb-4")}),e.jsx("div",{className:"grid grid-cols-[repeat(52,1fr)] gap-[2px]",children:Array.from({length:364}).map((s,i)=>e.jsx("div",{className:"aspect-square rounded-[2px] bg-oai-gray-200/40 dark:bg-oai-gray-800/30 tt-shimmer-bar"},i))})]}),e.jsxs("div",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsx("div",{className:c(r,"h-3 w-28 mb-3")}),e.jsx("div",{className:"space-y-2.5",children:Array.from({length:5}).map((s,i)=>e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:c(r,"h-4 w-4")}),e.jsx("div",{className:c(r,"h-3 w-16")}),e.jsx("div",{className:c(r,"h-[3px] flex-1")}),e.jsx("div",{className:c(r,"h-3 w-12")})]},i))})]})]})]})}function O(a){if(!a)return null;const r=String(a).match(/github\.com\/([A-Za-z0-9][A-Za-z0-9-]{0,38})/i);return r?r[1]:null}function R({children:a}){return e.jsx("h3",{className:"text-[11px] uppercase tracking-[0.08em] text-oai-gray-500 dark:text-oai-gray-400 mb-3",children:a})}function L({value:a,label:r}){return e.jsxs("div",{children:[e.jsx("div",{className:"text-2xl font-black tabular-nums tracking-tight leading-none text-oai-black dark:text-white",style:{fontFamily:'"DIN Alternate-Bold", "DIN Alternate", "DIN Condensed-Bold", "Impact", -apple-system, sans-serif',fontWeight:900},children:a}),e.jsx("div",{className:"mt-1.5 text-[11px] text-oai-gray-500 dark:text-oai-gray-400",children:r})]})}function P({label:a,children:r}){return e.jsxs("div",{className:"flex items-baseline gap-3 text-sm",children:[e.jsx("dt",{className:"shrink-0 w-28 whitespace-nowrap text-oai-gray-500 dark:text-oai-gray-400",children:a}),e.jsx("dd",{className:"min-w-0 flex-1 text-oai-gray-900 dark:text-oai-gray-100 tabular-nums truncate flex items-baseline gap-2 flex-wrap",children:r})]})}function Me({user:a,onClose:r}){const t=O(a?.github_url);return e.jsxs("div",{className:"flex items-center gap-4 px-6 pt-6 pb-5 border-b border-oai-gray-200/80 dark:border-oai-gray-800/60",children:[e.jsx(W,{avatarUrl:a?.avatar_url,displayName:a?.display_name||"",seed:a?.user_id||a?.display_name,size:"lg",className:"shrink-0 ring-1 ring-oai-gray-200 dark:ring-oai-gray-800"}),e.jsxs("div",{className:"min-w-0 flex-1",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("h2",{className:"truncate text-base font-semibold text-oai-black dark:text-white",children:a?.display_name||"—"}),a?.rank?e.jsx("span",{className:c("shrink-0 inline-flex items-center px-2 py-0.5 rounded text-xs font-bold font-mono uppercase tracking-wider border shadow-sm",a.rank===1&&"bg-amber-500/10 text-amber-600 border-amber-500/20 dark:text-amber-400 dark:bg-amber-400/10",a.rank===2&&"bg-slate-500/10 text-slate-600 border-slate-500/20 dark:text-slate-400 dark:bg-slate-400/10",a.rank===3&&"bg-orange-500/10 text-orange-700 border-orange-500/20 dark:text-orange-400 dark:bg-orange-400/10",a.rank>3&&"bg-oai-gray-100 dark:bg-oai-gray-900/60 text-oai-gray-500 dark:text-oai-gray-400 border-oai-gray-200/60 dark:border-oai-gray-800"),children:n("leaderboard.profile_modal.rank",{rank:a.rank})}):null]}),t&&e.jsxs("a",{href:a.github_url,target:"_blank",rel:"noopener noreferrer",className:"mt-1 inline-flex items-center gap-1 text-[12px] text-oai-gray-500 dark:text-oai-gray-400 hover:text-oai-gray-800 dark:hover:text-oai-gray-200 transition-colors",children:[e.jsx(T,{provider:"GITHUB",size:11}),e.jsxs("span",{children:["@",t]})]})]}),a?.user_id&&e.jsx("div",{className:"shrink-0 flex items-center justify-center",children:e.jsx(E,{userId:a.user_id})}),r&&e.jsx("button",{type:"button",onClick:r,className:"shrink-0 -mr-1 -mt-1 flex h-8 w-8 items-center justify-center rounded-md text-oai-gray-500 dark:text-oai-gray-400 hover:text-oai-gray-900 dark:hover:text-white hover:bg-oai-gray-100 dark:hover:bg-oai-gray-800 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-oai-brand/50 transition-colors group","aria-label":n("leaderboard.profile_modal.close"),children:e.jsx(ne,{size:16,strokeWidth:2,"aria-hidden":!0,className:"transition-transform duration-200 group-hover:rotate-90 group-active:scale-90"})})]})}function ze({user:a}){const r=O(a?.github_url),t=Number(a?.rank)||0,s=t===1?"text-amber-500 dark:text-amber-400":t===2?"text-slate-500 dark:text-slate-300":t===3?"text-orange-600 dark:text-orange-400":"text-oai-gray-400 dark:text-oai-gray-500";return e.jsxs("div",{className:"flex items-center gap-5 px-6 sm:px-8 pt-8 pb-7",children:[e.jsx(W,{avatarUrl:a?.avatar_url,displayName:a?.display_name||"",seed:a?.user_id||a?.display_name,size:"xl",className:"shrink-0 ring-1 ring-oai-gray-200 dark:ring-oai-gray-800"}),e.jsxs("div",{className:"min-w-0 flex-1 flex items-center justify-between gap-4",children:[e.jsxs("div",{className:"min-w-0 flex-1",children:[e.jsxs("div",{className:"flex items-center gap-3 flex-wrap",children:[e.jsx("h1",{className:"truncate text-2xl sm:text-[28px] font-semibold tracking-tight leading-tight text-oai-black dark:text-white",children:a?.display_name||"—"}),a?.user_id&&e.jsx(E,{userId:a.user_id})]}),r?e.jsxs("a",{href:a.github_url,target:"_blank",rel:"noopener noreferrer",className:"mt-2 inline-flex items-center gap-1.5 text-sm text-oai-gray-500 dark:text-oai-gray-400 hover:text-oai-gray-900 dark:hover:text-white transition-colors",children:[e.jsx(T,{provider:"GITHUB",size:13}),e.jsxs("span",{children:["@",r]})]}):null]}),t?e.jsxs("div",{className:"shrink-0 text-right leading-none",children:[e.jsx("div",{className:"text-[10px] font-medium uppercase tracking-[0.14em] text-oai-gray-400 dark:text-oai-gray-500",children:n("leaderboard.profile.hero.rank_label")}),e.jsx("div",{className:c("mt-1.5 text-3xl font-black tabular-nums tracking-tight",s),children:n("leaderboard.profile_modal.rank",{rank:t})})]}):null]})]})}function Pe({data:a}){const r=Array.isArray(a)?a:[];return r.length===0?e.jsx("p",{className:"text-xs text-oai-gray-500 dark:text-oai-gray-400",children:n("leaderboard.profile_modal.providers.none")}):e.jsx("ul",{className:"space-y-2",children:r.map(t=>{const s=Math.max(0,Math.min(1,Number(t?.percent)||0));return e.jsxs("li",{className:"flex items-center gap-3 text-xs",children:[e.jsx("span",{className:"shrink-0 inline-flex items-center justify-center w-4 h-4",children:e.jsx(T,{provider:String(t.source).toUpperCase(),size:14})}),e.jsx("span",{className:"shrink-0 capitalize w-16 text-oai-gray-700 dark:text-oai-gray-300",children:t.source}),e.jsx("span",{className:"flex-1 h-[3px] rounded-full bg-oai-gray-200/60 dark:bg-oai-gray-800/80 overflow-hidden",children:e.jsx("span",{className:"block h-full bg-oai-brand-500 dark:bg-oai-brand-400",style:{width:`${(s*100).toFixed(1)}%`}})}),e.jsx("span",{className:"shrink-0 w-14 text-right tabular-nums text-oai-gray-700 dark:text-oai-gray-300",children:C(t.total_tokens)}),e.jsxs("span",{className:"shrink-0 w-10 text-right tabular-nums text-oai-gray-500 dark:text-oai-gray-400",children:[(s*100).toFixed(0),"%"]})]},t.source)})})}function B({icon:a,label:r,value:t}){const[s,i]=g.useState(!1),l=async()=>{await de(t)&&(i(!0),setTimeout(()=>i(!1),1600))};return e.jsxs("button",{type:"button",onClick:l,className:c("inline-flex items-center gap-1.5 rounded-md border px-2.5 py-1 text-xs font-medium transition-colors",s?"border-emerald-500/30 text-emerald-600 dark:text-emerald-400 bg-emerald-500/[0.06]":"border-oai-gray-200 dark:border-oai-gray-800 text-oai-gray-600 dark:text-oai-gray-300 hover:text-oai-gray-900 dark:hover:text-oai-gray-100 hover:border-oai-gray-300 dark:hover:border-oai-gray-700 hover:bg-oai-gray-50 dark:hover:bg-oai-gray-900/40"),children:[s?e.jsx(xe,{size:13,strokeWidth:2,"aria-hidden":!0}):e.jsx(a,{size:13,strokeWidth:2,"aria-hidden":!0}),e.jsx("span",{children:s?n("leaderboard.profile_modal.badge.copied"):r})]})}function $e({data:a,currency:r,rate:t,onClose:s,variant:i="modal"}){const{user:l,totals:m,streak:d,best_day:p,models:y,by_provider:k,heatmap:j,period:M}=a,v=i==="page",b=g.useMemo(()=>Se(j),[j]),N=y?.favorite?.model_name,_=Number(y?.count)||0,u=re(),w=!!(u?.user?.id&&l?.user_id&&u.user.id===l.user_id),o=l?.user_id?`https://www.tokentracker.cc/u/${l.user_id}`:null,x=l?.user_id?`[}/functions/tokentracker-embed-svg?user_id=${l.user_id}&theme=dark)](${o}?ref=readme)`:null;return e.jsxs(e.Fragment,{children:[v?e.jsx(ze,{user:l}):e.jsx(Me,{user:l,onClose:s}),e.jsxs("div",{className:c("space-y-6",v?"px-6 sm:px-8 pt-6 pb-8 border-t border-oai-gray-200/80 dark:border-oai-gray-800/60":"flex-1 min-h-0 overflow-y-auto oai-scrollbar px-6 py-5"),children:[e.jsxs("div",{className:"grid grid-cols-4 gap-x-6 gap-y-4",children:[e.jsx(L,{value:C(m?.total_tokens),label:n("leaderboard.profile_modal.stat.total_tokens")}),e.jsx(L,{value:F(m?.estimated_cost_usd,r,t),label:n("leaderboard.profile_modal.stat.total_cost")}),e.jsx(L,{value:String(m?.active_days??0),label:n("leaderboard.profile_modal.stat.active_days")}),e.jsx(L,{value:F(m?.avg_per_day_usd,r,t),label:n("leaderboard.profile_modal.stat.avg_per_day")})]}),e.jsxs("dl",{className:"space-y-2 border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsxs(P,{label:n("leaderboard.profile_modal.streak.current"),children:[e.jsx("span",{className:"font-mono text-xs tracking-tight bg-oai-gray-100/60 dark:bg-oai-gray-900/50 px-1.5 py-0.5 rounded border border-oai-gray-200/30 dark:border-oai-gray-800/30",children:n("leaderboard.profile_modal.streak.days",{count:d?.current_days??0})}),e.jsxs("span",{className:"text-xs text-oai-gray-500 dark:text-oai-gray-400 font-mono",children:["(max ",d?.longest_days??0,")"]})]}),e.jsx(P,{label:n("leaderboard.profile_modal.best_day.title"),children:p?e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"font-mono text-xs tracking-tight bg-oai-gray-100/60 dark:bg-oai-gray-900/50 px-1.5 py-0.5 rounded border border-oai-gray-200/30 dark:border-oai-gray-800/30",children:C(p.total_tokens)}),e.jsxs("span",{className:"text-xs text-oai-gray-500 dark:text-oai-gray-400 font-mono",children:["on ",p.date]})]}):e.jsx("span",{className:"text-xs text-oai-gray-400 dark:text-oai-gray-500 font-mono",children:n("leaderboard.profile_modal.best_day.none")})}),e.jsx(P,{label:n("leaderboard.profile_modal.models.favorite"),children:N?e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"font-mono text-xs tracking-tight bg-oai-gray-100/60 dark:bg-oai-gray-900/50 px-1.5 py-0.5 rounded border border-oai-gray-200/30 dark:border-oai-gray-800/30 truncate max-w-[200px] inline-block align-bottom",children:N}),_>1&&e.jsx("span",{className:"text-xs text-oai-gray-500 dark:text-oai-gray-400 font-mono",children:n("leaderboard.profile_modal.models.count",{count:_})})]}):e.jsx("span",{className:"text-xs text-oai-gray-400 dark:text-oai-gray-500 font-mono",children:n("leaderboard.profile_modal.models.none")})})]}),b&&e.jsxs("section",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsx(R,{children:n("leaderboard.profile_modal.heatmap.title")}),e.jsx("div",{className:"min-w-0",children:e.jsx(me,{heatmap:b,hideLegend:!0,embedded:!0})})]}),e.jsxs("section",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsx(R,{children:n("leaderboard.profile_modal.providers.title")}),e.jsx(Pe,{data:k})]}),l?.user_id&&(s||w)&&e.jsxs("div",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-4 flex flex-wrap items-center justify-between gap-x-4 gap-y-3",children:[s&&(se()?e.jsxs("a",{href:o,target:"_blank",rel:"noopener noreferrer",onClick:s,className:"group inline-flex items-center gap-1 text-xs font-medium text-oai-gray-700 hover:text-oai-gray-950 dark:text-oai-gray-300 dark:hover:text-oai-white transition-colors",children:[e.jsx("span",{children:n("leaderboard.profile_modal.view_full")}),e.jsx(H,{size:13,strokeWidth:2,"aria-hidden":!0,className:"transition-transform duration-200 group-hover:translate-x-0.5 group-hover:-translate-y-0.5"})]}):e.jsxs(ie,{to:`/u/${l.user_id}`,onClick:s,className:"group inline-flex items-center gap-1 text-xs font-medium text-oai-gray-700 hover:text-oai-gray-950 dark:text-oai-gray-300 dark:hover:text-oai-white transition-colors",children:[e.jsx("span",{children:n("leaderboard.profile_modal.view_full")}),e.jsx(H,{size:13,strokeWidth:2,"aria-hidden":!0,className:"transition-transform duration-200 group-hover:translate-x-0.5 group-hover:-translate-y-0.5"})]})),w&&e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(B,{icon:_e,label:n("leaderboard.profile_modal.badge.copy_url"),value:o}),e.jsx(B,{icon:ke,label:n("leaderboard.profile_modal.badge.copy"),value:x})]})]})]})]})}function Ce({userId:a,period:r,accessToken:t,enabled:s=!0}){const[i,l]=g.useState({loading:!1,error:null,data:null});return g.useEffect(()=>{if(!s||!a)return;let m=!0;return l({loading:!0,error:null,data:null}),(async()=>{try{const d=t?await ee(t):null;if(!m)return;const p=await ae({accessToken:d,userId:a,period:r||"week"});if(!m)return;l({loading:!1,error:null,data:p})}catch(d){if(!m)return;d?.status===404?l({loading:!1,error:null,data:null}):l({loading:!1,error:d?.message||String(d),data:null})}})(),()=>{m=!1}},[s,a,r,t]),i}function Ee({isOpen:a,onClose:r,userId:t,period:s,accessToken:i}){const{currency:l,rate:m}=ce(),d=Ce({userId:t,period:s,accessToken:i,enabled:a});return e.jsx(ge,{open:a,onOpenChange:p=>{p||r?.()},children:e.jsxs(pe,{children:[e.jsx(he,{className:"cost-modal-backdrop"}),e.jsx(fe,{className:"fixed inset-0 z-[101] flex items-center justify-center p-4",children:e.jsxs(be,{className:c("cost-modal-popup","relative w-full max-w-[540px] max-h-[calc(100vh-2rem)] flex flex-col","rounded-2xl bg-white dark:bg-oai-gray-950","shadow-[0_20px_60px_-20px_rgba(0,0,0,0.25)] dark:shadow-[0_20px_60px_-10px_rgba(0,0,0,0.65)]","ring-1 ring-oai-gray-200 dark:ring-oai-gray-800 overflow-hidden","dark:border-t dark:border-white/[0.08]"),children:[e.jsx(ue,{render:e.jsx("h2",{className:"sr-only"}),children:d.data?.user?.display_name||n("leaderboard.profile_modal.loading")}),d.loading&&e.jsx(Le,{}),!d.loading&&d.error&&e.jsx("div",{className:"flex-1 flex items-center justify-center min-h-[280px]",children:e.jsx("p",{className:"text-sm text-red-500 dark:text-red-400",children:n("leaderboard.profile_modal.error")})}),!d.loading&&!d.error&&!d.data&&e.jsx("div",{className:"flex-1 flex items-center justify-center min-h-[280px]",children:e.jsx("p",{className:"text-sm text-oai-gray-500 dark:text-oai-gray-400",children:n("leaderboard.profile_modal.empty")})}),!d.loading&&!d.error&&d.data&&e.jsx($e,{data:d.data,currency:l,rate:m,onClose:r})]})})]})})}export{Ee as LeaderboardProfileModal,$e as ProfileContent,Le as ProfileSkeleton,Ce as useLeaderboardProfileData};
|
|
72
|
+
`;function Le({variant:a="modal"}){const r="rounded bg-oai-gray-200/50 dark:bg-oai-gray-800/40 tt-shimmer-bar",t=a==="page";return e.jsxs("div",{children:[e.jsx("style",{dangerouslySetInnerHTML:{__html:Ae}}),t?e.jsxs("div",{className:"flex items-start gap-5 px-6 sm:px-8 pt-8 pb-7 animate-fade-in",children:[e.jsx("div",{className:"h-[68px] w-[68px] rounded-full bg-oai-gray-200/50 dark:bg-oai-gray-800/40 tt-shimmer-bar shrink-0"}),e.jsxs("div",{className:"flex-1 min-w-0 flex items-start justify-between gap-4 pt-0.5",children:[e.jsxs("div",{className:"min-w-0 space-y-2.5",children:[e.jsx("div",{className:c(r,"h-7 w-48")}),e.jsx("div",{className:c(r,"h-3.5 w-32")})]}),e.jsxs("div",{className:"shrink-0 space-y-1.5 flex flex-col items-end",children:[e.jsx("div",{className:c(r,"h-2.5 w-8")}),e.jsx("div",{className:c(r,"h-7 w-12")})]})]})]}):e.jsxs("div",{className:"flex items-start gap-4 px-6 pt-6 pb-5 border-b border-oai-gray-200/80 dark:border-oai-gray-800/60 animate-fade-in",children:[e.jsx("div",{className:"h-14 w-14 rounded-full bg-oai-gray-200/50 dark:bg-oai-gray-800/40 tt-shimmer-bar shrink-0"}),e.jsxs("div",{className:"flex-1 min-w-0 space-y-2 pt-1",children:[e.jsx("div",{className:c(r,"h-4 w-40")}),e.jsx("div",{className:c(r,"h-3 w-56")})]}),e.jsx("div",{className:c(r,"h-4 w-4 shrink-0 mt-1")})]}),e.jsxs("div",{className:c("space-y-6",t?"px-6 sm:px-8 pt-6 pb-8 border-t border-oai-gray-200/80 dark:border-oai-gray-800/60":"px-6 py-5"),children:[e.jsx("div",{className:"grid grid-cols-4 gap-x-6 gap-y-4",children:Array.from({length:4}).map((s,i)=>e.jsxs("div",{children:[e.jsx("div",{className:c(r,"h-6 w-20")}),e.jsx("div",{className:c(r,"mt-2 h-3 w-14")})]},i))}),e.jsx("div",{className:"space-y-3 border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:Array.from({length:3}).map((s,i)=>e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:c(r,"h-3 w-24")}),e.jsx("div",{className:c(r,"h-3 w-44")})]},i))}),e.jsxs("div",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsx("div",{className:c(r,"h-3 w-44 mb-4")}),e.jsx("div",{className:"grid grid-cols-[repeat(52,1fr)] gap-[2px]",children:Array.from({length:364}).map((s,i)=>e.jsx("div",{className:"aspect-square rounded-[2px] bg-oai-gray-200/40 dark:bg-oai-gray-800/30 tt-shimmer-bar"},i))})]}),e.jsxs("div",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsx("div",{className:c(r,"h-3 w-28 mb-3")}),e.jsx("div",{className:"space-y-2.5",children:Array.from({length:5}).map((s,i)=>e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:c(r,"h-4 w-4")}),e.jsx("div",{className:c(r,"h-3 w-16")}),e.jsx("div",{className:c(r,"h-[3px] flex-1")}),e.jsx("div",{className:c(r,"h-3 w-12")})]},i))})]})]})]})}function O(a){if(!a)return null;const r=String(a).match(/github\.com\/([A-Za-z0-9][A-Za-z0-9-]{0,38})/i);return r?r[1]:null}function U({children:a}){return e.jsx("h3",{className:"text-[11px] uppercase tracking-[0.08em] text-oai-gray-500 dark:text-oai-gray-400 mb-3",children:a})}function L({value:a,label:r}){return e.jsxs("div",{children:[e.jsx("div",{className:"text-2xl font-black tabular-nums tracking-tight leading-none text-oai-black dark:text-white",style:{fontFamily:'"DIN Alternate-Bold", "DIN Alternate", "DIN Condensed-Bold", "Impact", -apple-system, sans-serif',fontWeight:900},children:a}),e.jsx("div",{className:"mt-1.5 text-[11px] text-oai-gray-500 dark:text-oai-gray-400",children:r})]})}function P({label:a,children:r}){return e.jsxs("div",{className:"flex items-baseline gap-3 text-sm",children:[e.jsx("dt",{className:"shrink-0 w-28 whitespace-nowrap text-oai-gray-500 dark:text-oai-gray-400",children:a}),e.jsx("dd",{className:"min-w-0 flex-1 text-oai-gray-900 dark:text-oai-gray-100 tabular-nums truncate flex items-baseline gap-2 flex-wrap",children:r})]})}function Me({user:a,onClose:r}){const t=O(a?.github_url);return e.jsxs("div",{className:"flex items-center gap-4 px-6 pt-6 pb-5 border-b border-oai-gray-200/80 dark:border-oai-gray-800/60",children:[e.jsx(W,{avatarUrl:a?.avatar_url,displayName:a?.display_name||"",seed:a?.user_id||a?.display_name,size:"lg",className:"shrink-0 ring-1 ring-oai-gray-200 dark:ring-oai-gray-800"}),e.jsxs("div",{className:"min-w-0 flex-1",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("h2",{className:"truncate text-base font-semibold text-oai-black dark:text-white",children:a?.display_name||"—"}),a?.rank?e.jsx("span",{className:c("shrink-0 inline-flex items-center px-2 py-0.5 rounded text-xs font-bold font-mono uppercase tracking-wider border shadow-sm",a.rank===1&&"bg-amber-500/10 text-amber-600 border-amber-500/20 dark:text-amber-400 dark:bg-amber-400/10",a.rank===2&&"bg-slate-500/10 text-slate-600 border-slate-500/20 dark:text-slate-400 dark:bg-slate-400/10",a.rank===3&&"bg-orange-500/10 text-orange-700 border-orange-500/20 dark:text-orange-400 dark:bg-orange-400/10",a.rank>3&&"bg-oai-gray-100 dark:bg-oai-gray-900/60 text-oai-gray-500 dark:text-oai-gray-400 border-oai-gray-200/60 dark:border-oai-gray-800"),children:n("leaderboard.profile_modal.rank",{rank:a.rank})}):null]}),t&&e.jsxs("a",{href:a.github_url,target:"_blank",rel:"noopener noreferrer",className:"mt-1 inline-flex items-center gap-1 text-[12px] text-oai-gray-500 dark:text-oai-gray-400 hover:text-oai-gray-800 dark:hover:text-oai-gray-200 transition-colors",children:[e.jsx(T,{provider:"GITHUB",size:11}),e.jsxs("span",{children:["@",t]})]})]}),a?.user_id&&e.jsx("div",{className:"shrink-0 flex items-center justify-center",children:e.jsx(E,{userId:a.user_id})}),r&&e.jsx("button",{type:"button",onClick:r,className:"shrink-0 -mr-1 -mt-1 flex h-8 w-8 items-center justify-center rounded-md text-oai-gray-500 dark:text-oai-gray-400 hover:text-oai-gray-900 dark:hover:text-white hover:bg-oai-gray-100 dark:hover:bg-oai-gray-800 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-oai-brand/50 transition-colors group","aria-label":n("leaderboard.profile_modal.close"),children:e.jsx(ne,{size:16,strokeWidth:2,"aria-hidden":!0,className:"transition-transform duration-200 group-hover:rotate-90 group-active:scale-90"})})]})}function ze({user:a}){const r=O(a?.github_url),t=Number(a?.rank)||0,s=t===1?"text-amber-500 dark:text-amber-400":t===2?"text-slate-500 dark:text-slate-300":t===3?"text-orange-600 dark:text-orange-400":"text-oai-gray-400 dark:text-oai-gray-500";return e.jsxs("div",{className:"flex items-center gap-5 px-6 sm:px-8 pt-8 pb-7",children:[e.jsx(W,{avatarUrl:a?.avatar_url,displayName:a?.display_name||"",seed:a?.user_id||a?.display_name,size:"xl",className:"shrink-0 ring-1 ring-oai-gray-200 dark:ring-oai-gray-800"}),e.jsxs("div",{className:"min-w-0 flex-1 flex items-center justify-between gap-4",children:[e.jsxs("div",{className:"min-w-0 flex-1",children:[e.jsxs("div",{className:"flex items-center gap-3 flex-wrap",children:[e.jsx("h1",{className:"truncate text-2xl sm:text-[28px] font-semibold tracking-tight leading-tight text-oai-black dark:text-white",children:a?.display_name||"—"}),a?.user_id&&e.jsx(E,{userId:a.user_id})]}),r?e.jsxs("a",{href:a.github_url,target:"_blank",rel:"noopener noreferrer",className:"mt-2 inline-flex items-center gap-1.5 text-sm text-oai-gray-500 dark:text-oai-gray-400 hover:text-oai-gray-900 dark:hover:text-white transition-colors",children:[e.jsx(T,{provider:"GITHUB",size:13}),e.jsxs("span",{children:["@",r]})]}):null]}),t?e.jsxs("div",{className:"shrink-0 text-right leading-none",children:[e.jsx("div",{className:"text-[10px] font-medium uppercase tracking-[0.14em] text-oai-gray-400 dark:text-oai-gray-500",children:n("leaderboard.profile.hero.rank_label")}),e.jsx("div",{className:c("mt-1.5 text-3xl font-black tabular-nums tracking-tight",s),children:n("leaderboard.profile_modal.rank",{rank:t})})]}):null]})]})}function Pe({data:a}){const r=Array.isArray(a)?a:[];return r.length===0?e.jsx("p",{className:"text-xs text-oai-gray-500 dark:text-oai-gray-400",children:n("leaderboard.profile_modal.providers.none")}):e.jsx("ul",{className:"space-y-2",children:r.map(t=>{const s=Math.max(0,Math.min(1,Number(t?.percent)||0));return e.jsxs("li",{className:"flex items-center gap-3 text-xs",children:[e.jsx("span",{className:"shrink-0 inline-flex items-center justify-center w-4 h-4",children:e.jsx(T,{provider:String(t.source).toUpperCase(),size:14})}),e.jsx("span",{className:"shrink-0 capitalize w-16 text-oai-gray-700 dark:text-oai-gray-300",children:t.source}),e.jsx("span",{className:"flex-1 h-[3px] rounded-full bg-oai-gray-200/60 dark:bg-oai-gray-800/80 overflow-hidden",children:e.jsx("span",{className:"block h-full bg-oai-brand-500 dark:bg-oai-brand-400",style:{width:`${(s*100).toFixed(1)}%`}})}),e.jsx("span",{className:"shrink-0 w-14 text-right tabular-nums text-oai-gray-700 dark:text-oai-gray-300",children:$(t.total_tokens)}),e.jsxs("span",{className:"shrink-0 w-10 text-right tabular-nums text-oai-gray-500 dark:text-oai-gray-400",children:[(s*100).toFixed(0),"%"]})]},t.source)})})}function B({icon:a,label:r,value:t}){const[s,i]=g.useState(!1),l=async()=>{await de(t)&&(i(!0),setTimeout(()=>i(!1),1600))};return e.jsxs("button",{type:"button",onClick:l,className:c("inline-flex items-center gap-1.5 rounded-md border px-2.5 py-1 text-xs font-medium transition-colors",s?"border-emerald-500/30 text-emerald-600 dark:text-emerald-400 bg-emerald-500/[0.06]":"border-oai-gray-200 dark:border-oai-gray-800 text-oai-gray-600 dark:text-oai-gray-300 hover:text-oai-gray-900 dark:hover:text-oai-gray-100 hover:border-oai-gray-300 dark:hover:border-oai-gray-700 hover:bg-oai-gray-50 dark:hover:bg-oai-gray-900/40"),children:[s?e.jsx(xe,{size:13,strokeWidth:2,"aria-hidden":!0}):e.jsx(a,{size:13,strokeWidth:2,"aria-hidden":!0}),e.jsx("span",{children:s?n("leaderboard.profile_modal.badge.copied"):r})]})}function Ce({data:a,currency:r,rate:t,onClose:s,variant:i="modal"}){const{user:l,totals:m,streak:d,best_day:p,models:y,by_provider:k,heatmap:j,period:M}=a,v=i==="page",b=g.useMemo(()=>Se(j),[j]),N=y?.favorite?.model_name,_=Number(y?.count)||0,u=re(),w=!!(u?.user?.id&&l?.user_id&&u.user.id===l.user_id),o=l?.user_id?`https://www.tokentracker.cc/u/${l.user_id}`:null,x=l?.user_id?`[}/functions/tokentracker-embed-svg?user_id=${l.user_id}&theme=dark)](${o}?ref=readme)`:null;return e.jsxs(e.Fragment,{children:[v?e.jsx(ze,{user:l}):e.jsx(Me,{user:l,onClose:s}),e.jsxs("div",{className:c("space-y-6",v?"px-6 sm:px-8 pt-6 pb-8 border-t border-oai-gray-200/80 dark:border-oai-gray-800/60":"flex-1 min-h-0 overflow-y-auto oai-scrollbar px-6 py-5"),children:[e.jsxs("div",{className:"grid grid-cols-2 sm:grid-cols-4 gap-x-6 gap-y-4",children:[e.jsx(L,{value:$(m?.total_tokens),label:n("leaderboard.profile_modal.stat.total_tokens")}),e.jsx(L,{value:R(m?.estimated_cost_usd,r,t),label:n("leaderboard.profile_modal.stat.total_cost")}),e.jsx(L,{value:String(m?.active_days??0),label:n("leaderboard.profile_modal.stat.active_days")}),e.jsx(L,{value:R(m?.avg_per_day_usd,r,t),label:n("leaderboard.profile_modal.stat.avg_per_day")})]}),e.jsxs("dl",{className:"space-y-2 border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsxs(P,{label:n("leaderboard.profile_modal.streak.current"),children:[e.jsx("span",{className:"font-mono text-xs tracking-tight bg-oai-gray-100/60 dark:bg-oai-gray-900/50 px-1.5 py-0.5 rounded border border-oai-gray-200/30 dark:border-oai-gray-800/30",children:n("leaderboard.profile_modal.streak.days",{count:d?.current_days??0})}),e.jsxs("span",{className:"text-xs text-oai-gray-500 dark:text-oai-gray-400 font-mono",children:["(max ",d?.longest_days??0,")"]})]}),e.jsx(P,{label:n("leaderboard.profile_modal.best_day.title"),children:p?e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"font-mono text-xs tracking-tight bg-oai-gray-100/60 dark:bg-oai-gray-900/50 px-1.5 py-0.5 rounded border border-oai-gray-200/30 dark:border-oai-gray-800/30",children:$(p.total_tokens)}),e.jsxs("span",{className:"text-xs text-oai-gray-500 dark:text-oai-gray-400 font-mono",children:["on ",p.date]})]}):e.jsx("span",{className:"text-xs text-oai-gray-400 dark:text-oai-gray-500 font-mono",children:n("leaderboard.profile_modal.best_day.none")})}),e.jsx(P,{label:n("leaderboard.profile_modal.models.favorite"),children:N?e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"font-mono text-xs tracking-tight bg-oai-gray-100/60 dark:bg-oai-gray-900/50 px-1.5 py-0.5 rounded border border-oai-gray-200/30 dark:border-oai-gray-800/30 truncate max-w-[200px] inline-block align-bottom",children:N}),_>1&&e.jsx("span",{className:"text-xs text-oai-gray-500 dark:text-oai-gray-400 font-mono",children:n("leaderboard.profile_modal.models.count",{count:_})})]}):e.jsx("span",{className:"text-xs text-oai-gray-400 dark:text-oai-gray-500 font-mono",children:n("leaderboard.profile_modal.models.none")})})]}),b&&e.jsxs("section",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsx(U,{children:n("leaderboard.profile_modal.heatmap.title")}),e.jsx("div",{className:"min-w-0",children:e.jsx(me,{heatmap:b,hideLegend:!0,embedded:!0})})]}),e.jsxs("section",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-5",children:[e.jsx(U,{children:n("leaderboard.profile_modal.providers.title")}),e.jsx(Pe,{data:k})]}),l?.user_id&&(s||w)&&e.jsxs("div",{className:"border-t border-oai-gray-200/70 dark:border-oai-gray-800/60 pt-4 flex flex-wrap items-center justify-between gap-x-4 gap-y-3",children:[s&&(se()?e.jsxs("a",{href:o,target:"_blank",rel:"noopener noreferrer",onClick:s,className:"group inline-flex items-center gap-1 text-xs font-medium text-oai-gray-700 hover:text-oai-gray-950 dark:text-oai-gray-300 dark:hover:text-oai-white transition-colors",children:[e.jsx("span",{children:n("leaderboard.profile_modal.view_full")}),e.jsx(F,{size:13,strokeWidth:2,"aria-hidden":!0,className:"transition-transform duration-200 group-hover:translate-x-0.5 group-hover:-translate-y-0.5"})]}):e.jsxs(ie,{to:`/u/${l.user_id}`,onClick:s,className:"group inline-flex items-center gap-1 text-xs font-medium text-oai-gray-700 hover:text-oai-gray-950 dark:text-oai-gray-300 dark:hover:text-oai-white transition-colors",children:[e.jsx("span",{children:n("leaderboard.profile_modal.view_full")}),e.jsx(F,{size:13,strokeWidth:2,"aria-hidden":!0,className:"transition-transform duration-200 group-hover:translate-x-0.5 group-hover:-translate-y-0.5"})]})),w&&e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(B,{icon:_e,label:n("leaderboard.profile_modal.badge.copy_url"),value:o}),e.jsx(B,{icon:ke,label:n("leaderboard.profile_modal.badge.copy"),value:x})]})]})]})]})}function $e({userId:a,period:r,accessToken:t,enabled:s=!0}){const[i,l]=g.useState({loading:!1,error:null,data:null});return g.useEffect(()=>{if(!s||!a)return;let m=!0;return l({loading:!0,error:null,data:null}),(async()=>{try{const d=t?await ee(t):null;if(!m)return;const p=await ae({accessToken:d,userId:a,period:r||"week"});if(!m)return;l({loading:!1,error:null,data:p})}catch(d){if(!m)return;d?.status===404?l({loading:!1,error:null,data:null}):l({loading:!1,error:d?.message||String(d),data:null})}})(),()=>{m=!1}},[s,a,r,t]),i}function We({isOpen:a,onClose:r,userId:t,period:s,accessToken:i}){const{currency:l,rate:m}=ce(),d=$e({userId:t,period:s,accessToken:i,enabled:a});return e.jsx(ge,{open:a,onOpenChange:p=>{p||r?.()},children:e.jsxs(pe,{children:[e.jsx(he,{className:"cost-modal-backdrop"}),e.jsx(fe,{className:"fixed inset-0 z-[101] flex items-center justify-center p-4",children:e.jsxs(be,{className:c("cost-modal-popup","relative w-full max-w-[540px] max-h-[calc(100vh-2rem)] flex flex-col","rounded-2xl bg-white dark:bg-oai-gray-950","shadow-[0_20px_60px_-20px_rgba(0,0,0,0.25)] dark:shadow-[0_20px_60px_-10px_rgba(0,0,0,0.65)]","ring-1 ring-oai-gray-200 dark:ring-oai-gray-800 overflow-hidden","dark:border-t dark:border-white/[0.08]"),children:[e.jsx(ue,{render:e.jsx("h2",{className:"sr-only"}),children:d.data?.user?.display_name||n("leaderboard.profile_modal.loading")}),d.loading&&e.jsx(Le,{}),!d.loading&&d.error&&e.jsx("div",{className:"flex-1 flex items-center justify-center min-h-[280px]",children:e.jsx("p",{className:"text-sm text-red-500 dark:text-red-400",children:n("leaderboard.profile_modal.error")})}),!d.loading&&!d.error&&!d.data&&e.jsx("div",{className:"flex-1 flex items-center justify-center min-h-[280px]",children:e.jsx("p",{className:"text-sm text-oai-gray-500 dark:text-oai-gray-400",children:n("leaderboard.profile_modal.empty")})}),!d.loading&&!d.error&&d.data&&e.jsx(Ce,{data:d.data,currency:l,rate:m,onClose:r})]})})]})})}export{We as LeaderboardProfileModal,Ce as ProfileContent,Le as ProfileSkeleton,$e as useLeaderboardProfileData};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{r as d,u as e,K as j,O as w,Q as N,L as k,aq as L,s,a6 as I}from"./main-uqC1VAKB.js";import{u as T}from"./useCurrency-vRzRfd7L.js";import{H as M}from"./HeaderGithubStar-B0OAKXVw.js";import{useLeaderboardProfileData as C,ProfileSkeleton as _,ProfileContent as E}from"./LeaderboardProfileModal-DasxA8Lo.js";import"./LeaderboardAvatar-CLMnffKE.js";import"./ActivityHeatmap-BjiEMIl2.js";import"./info-DMW1GFmI.js";import"./arrow-up-right-BS0sCPTz.js";import"./check-DKwh5hl-.js";import"./DialogTitle-CEBn-oBo.js";const l=18;function y(){return e.jsxs("svg",{"aria-hidden":!0,width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("circle",{cx:"12",cy:"12",r:"4"}),e.jsx("path",{d:"M12 2v2"}),e.jsx("path",{d:"M12 20v2"}),e.jsx("path",{d:"m4.93 4.93 1.41 1.41"}),e.jsx("path",{d:"m17.66 17.66 1.41 1.41"}),e.jsx("path",{d:"M2 12h2"}),e.jsx("path",{d:"M20 12h2"}),e.jsx("path",{d:"m6.34 17.66-1.41 1.41"}),e.jsx("path",{d:"m19.07 4.93-1.41 1.41"})]})}function v(){return e.jsx("svg",{"aria-hidden":!0,width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:e.jsx("path",{d:"M12 3a6 6 0 0 0 9 9 9 9 0 1 1-9-9Z"})})}function S(){return e.jsxs("svg",{"aria-hidden":!0,width:l,height:l,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("rect",{x:"2",y:"3",width:"20",height:"14",rx:"2"}),e.jsx("path",{d:"M8 21h8"}),e.jsx("path",{d:"M12 17v4"})]})}const P=[{value:"light",label:"Light",Icon:y},{value:"dark",label:"Dark",Icon:v},{value:"system",label:"System",Icon:S}];function O(a){return a==="dark"?v:y}function W({theme:a,resolvedTheme:h,onSetTheme:g,className:u="",direction:m="down",align:p="right"}){const[o,x]=d.useState(!1),c=d.useRef(null),n=d.useCallback(()=>x(!1),[]);d.useEffect(()=>{if(!o)return;const r=i=>{c.current&&!c.current.contains(i.target)&&n()};return document.addEventListener("mousedown",r),()=>document.removeEventListener("mousedown",r)},[o,n]),d.useEffect(()=>{if(!o)return;const r=i=>{i.key==="Escape"&&n()};return document.addEventListener("keydown",r),()=>document.removeEventListener("keydown",r)},[o,n]);const b=O(h);return e.jsxs("div",{ref:c,className:`relative ${u}`,children:[e.jsx("button",{type:"button","aria-label":"Theme","aria-expanded":o,onClick:()=>x(r=>!r),className:"flex items-center justify-center w-9 h-9 rounded-lg text-oai-gray-600 dark:text-oai-gray-400 hover:bg-oai-gray-100 dark:hover:bg-oai-gray-800 hover:text-oai-black dark:hover:text-white transition-colors",children:e.jsx(b,{})}),o&&e.jsx("div",{className:`absolute z-50 min-w-[140px] py-1 rounded-lg border border-oai-gray-200 dark:border-oai-gray-800 bg-white dark:bg-oai-gray-900 shadow-lg ${m==="up"?"bottom-full mb-1":"top-full mt-1"} ${p==="left"?"left-0":"right-0"}`,children:P.map(({value:r,label:i,Icon:f})=>{const t=a===r;return e.jsxs("button",{type:"button",onClick:()=>{g(r),n()},className:`flex w-full items-center gap-2.5 px-3 py-2 text-sm transition-colors ${t?"text-oai-black dark:text-white bg-oai-gray-100 dark:bg-oai-gray-800":"text-oai-gray-600 dark:text-oai-gray-400 hover:bg-oai-gray-50 dark:hover:bg-oai-gray-800/60 hover:text-oai-black dark:hover:text-white"}`,children:[e.jsx(f,{}),e.jsx("span",{children:i})]},r)})})]})}function K({auth:a,signedIn:h,sessionSoftExpired:g,userId:u}){const{currency:m,rate:p}=T(),{theme:o,resolvedTheme:x,setTheme:c}=j(),{openLoginModal:n}=w(),{signedIn:b,loading:r}=N(),i=h&&!g,f=d.useMemo(()=>i&&(typeof a=="function"||typeof a=="string"||a&&typeof a=="object")?a:null,[a,i]),t=C({userId:u,period:"total",accessToken:f});return e.jsxs("div",{className:"flex flex-col min-h-screen bg-oai-gray-50 dark:bg-oai-gray-950 text-oai-black dark:text-oai-white font-oai antialiased transition-colors duration-200",children:[e.jsx("header",{className:"sticky top-0 z-50 w-full px-4 pt-4 pb-2 transition-all duration-300 pointer-events-none",children:e.jsxs("div",{className:"mx-auto max-w-3xl rounded-2xl border border-oai-gray-200/50 dark:border-white/10 bg-white/75 dark:bg-oai-gray-950/60 backdrop-blur-xl shadow-[0_8px_30px_rgb(0,0,0,0.04)] dark:shadow-[0_8px_30px_rgb(0,0,0,0.3)] flex h-14 items-center justify-between px-3 sm:px-4 pointer-events-auto transition-all duration-300",children:[e.jsxs("div",{className:"flex items-center gap-4",children:[e.jsxs(k,{to:"/",className:"flex items-center gap-3 no-underline outline-none rounded-md focus-visible:ring-2 focus-visible:ring-indigo-500 transition-opacity hover:opacity-80 active:scale-95",children:[e.jsx("img",{src:"/app-icon.png",alt:"",width:24,height:24,className:"rounded-md"}),e.jsx("span",{className:"text-sm font-semibold tracking-wide text-oai-black dark:text-white uppercase",children:"Token Tracker"})]}),e.jsx("div",{className:"hidden sm:block scale-90 origin-left opacity-90 hover:opacity-100 transition-opacity",children:e.jsx(M,{})})]}),e.jsxs("div",{className:"flex items-center gap-1.5 sm:gap-2",children:[e.jsxs(k,{to:"/leaderboard",className:"group no-underline inline-flex items-center gap-1.5 h-8 px-3 text-xs font-bold rounded-lg border border-oai-gray-200 dark:border-white/10 bg-transparent text-oai-gray-700 dark:text-oai-gray-300 hover:bg-oai-gray-100 dark:hover:bg-white/5 hover:text-oai-black dark:hover:text-white transition-all duration-200 active:scale-95 shadow-sm",children:[e.jsx(L,{size:13,strokeWidth:2.5,"aria-hidden":!0,className:"transition-transform duration-150 ease-out group-hover:scale-110 group-hover:rotate-6"}),e.jsx("span",{children:s("leaderboard.profile.nav.back")})]}),r?e.jsx("div",{className:"h-8 w-16 animate-pulse rounded-lg bg-oai-gray-200 dark:bg-white/10","aria-hidden":!0}):b?e.jsx(I,{}):e.jsx("button",{type:"button",onClick:n,className:"inline-flex h-8 min-w-[76px] items-center justify-center rounded-lg bg-oai-gray-900 dark:bg-white text-white dark:text-oai-gray-950 hover:bg-oai-gray-800 dark:hover:bg-oai-gray-100 transition-all duration-200 active:scale-[0.98] select-none text-xs font-bold shadow-sm",children:s("header.auth.sign_in_aria")})]})]})}),e.jsx("main",{className:"flex-1 pt-4 pb-10 sm:pt-6 sm:pb-16",children:e.jsx("div",{className:"mx-auto max-w-2xl px-4 sm:px-6",children:e.jsxs("div",{className:"rounded-2xl bg-white dark:bg-oai-gray-950 ring-1 ring-oai-gray-200 dark:ring-oai-gray-800 overflow-hidden shadow-sm dark:shadow-none",children:[t.loading&&e.jsx(_,{variant:"page"}),!t.loading&&t.error&&e.jsx("div",{className:"px-6 py-16 text-center",children:e.jsx("p",{className:"text-sm text-red-500 dark:text-red-400",children:s("leaderboard.profile_modal.error")})}),!t.loading&&!t.error&&!t.data&&e.jsx("div",{className:"px-6 py-16 text-center",children:e.jsx("p",{className:"text-sm text-oai-gray-500 dark:text-oai-gray-400",children:s("leaderboard.profile_modal.empty")})}),!t.loading&&!t.error&&t.data&&e.jsx(E,{data:t.data,currency:m,rate:p,variant:"page"})]})})}),e.jsx("footer",{className:"border-t border-oai-gray-200 dark:border-oai-gray-900 py-8 transition-colors duration-200",children:e.jsxs("div",{className:"mx-auto flex max-w-2xl items-center justify-between px-4 sm:px-6 text-sm text-oai-gray-400 dark:text-oai-gray-500",children:[e.jsx("p",{children:s("landing.v2.footer.line")}),e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx(W,{theme:o,resolvedTheme:x,onSetTheme:c,direction:"up",align:"right"}),e.jsx(k,{to:"/leaderboard",className:"text-oai-gray-400 dark:text-oai-gray-500 hover:text-oai-black dark:hover:text-white transition-colors",children:s("leaderboard.profile.nav.back")})]})]})})]})}export{K as LeaderboardProfilePage};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{u as r,N as g,s as n,r as j,i as v,L as k,as as N}from"./main-uqC1VAKB.js";import{u as L}from"./use-usage-limits-5fwy0xeB.js";import{u as E}from"./use-limits-display-prefs-C04zvO7N.js";import{C as h}from"./Card-Nlgzr57Q.js";import{F as O}from"./FadeIn-Dbk47nhk.js";import{L as P}from"./LocalOnlyNotice-B3uM29rj.js";import"./arrow-up-right-BS0sCPTz.js";import"./download-CqDWRO99.js";const C=[3,2,3,3,2,2,3];function m({className:s}){return r.jsx("div",{className:g("rounded bg-oai-gray-200/70 dark:bg-oai-gray-800/70 animate-pulse",s)})}function T(){return r.jsxs("div",{className:"flex items-center gap-2",children:[r.jsx(m,{className:"h-3 w-12 shrink-0"}),r.jsx(m,{className:"flex-1 h-1.5 rounded-full min-w-0"}),r.jsx(m,{className:"h-3 w-[30px] shrink-0"}),r.jsx(m,{className:"h-3 w-6 shrink-0"})]})}function R({bars:s,index:e}){const i=e%3===0?"w-24":e%3===1?"w-20":"w-[4.5rem]";return r.jsxs("div",{className:"flex flex-col gap-1.5",children:[r.jsxs("div",{className:"flex items-center gap-1.5",children:[r.jsx(m,{className:"h-[14px] w-[14px] rounded shrink-0"}),r.jsx(m,{className:g("h-4",i)})]}),Array.from({length:s},(l,a)=>r.jsx(T,{},a))]})}function S(){return r.jsx(h,{children:r.jsxs("div",{className:"flex flex-col gap-3",children:[r.jsx(m,{className:"h-3.5 w-28"}),C.map((s,e)=>r.jsx(R,{bars:s,index:e},e))]})})}function t(s){if(!s)return null;const e=typeof s=="number"?s*1e3:Date.parse(s);if(!Number.isFinite(e))return null;const i=e-Date.now();if(i<=0)return n("shared.time.now");const l=Math.floor(i/6e4);if(l<60)return`${l}m`;const a=Math.floor(l/60);return a<24?`${a}h`:`${Math.floor(a/24)}d`}function I(s){return s>=90?"bg-red-500":s>=70?"bg-amber-500":"bg-emerald-500"}function o({label:s,pct:e,reset:i}){const l=Math.max(0,Math.min(100,Number(e)||0)),a=Math.round(l),u=l>0&&a===0?Math.max(l,.35):l,x=l>0&&a===0?"<1":String(a);return r.jsxs("div",{className:"flex items-center gap-2",children:[r.jsx("span",{className:"text-[11px] text-oai-gray-500 dark:text-oai-gray-400 w-12 shrink-0",children:s}),r.jsx("div",{className:"flex-1 bg-oai-gray-100 dark:bg-oai-gray-700/50 rounded-full h-1.5 overflow-hidden",children:r.jsx("div",{className:`${I(a)} rounded-full h-full transition-[width] duration-500 ease-out`,style:{width:`${u}%`,minWidth:l>0?"3px":0}})}),r.jsxs("span",{className:"text-[11px] tabular-nums text-oai-gray-500 dark:text-oai-gray-400 w-[30px] text-right shrink-0",children:[x,"%"]}),i?r.jsx("span",{className:"text-[10px] text-oai-gray-400 dark:text-oai-gray-500 w-6 text-right shrink-0",children:i}):null]})}function d({name:s,icon:e,children:i}){const a=e==="/brand-logos/cursor.svg"||e==="/brand-logos/kiro.svg"||e==="/brand-logos/copilot.svg"||e==="/brand-logos/kimi.svg"?"w-[14px] h-[14px] dark:invert":"w-[14px] h-[14px]";return r.jsxs("div",{className:"flex flex-col gap-1.5",children:[r.jsxs("div",{className:"flex items-center gap-1.5",children:[e?r.jsx("img",{src:e,alt:"",className:a}):null,r.jsx("span",{className:"text-sm font-medium text-oai-black dark:text-oai-white",children:s})]}),i]})}const A=["claude","codex","cursor","gemini","kimi","kiro","copilot","antigravity"],M={claude:{name:"Claude",icon:"/brand-logos/claude-code.svg"},codex:{name:"Codex",icon:"/brand-logos/codex.svg"},cursor:{name:"Cursor",icon:"/brand-logos/cursor.svg"},gemini:{name:"Gemini",icon:"/brand-logos/gemini.svg"},kimi:{name:"Kimi",icon:"/brand-logos/kimi.svg"},kiro:{name:"Kiro",icon:"/brand-logos/kiro.svg"},copilot:{name:"GitHub Copilot",icon:"/brand-logos/copilot.svg"},antigravity:{name:"Antigravity",icon:"/brand-logos/antigravity.svg"}};function c({children:s,tone:e="neutral"}){const i=e==="error"?"text-red-600 dark:text-red-400":"text-oai-gray-500 dark:text-oai-gray-400";return r.jsx("div",{className:`text-[11px] leading-snug ${i}`,children:s})}function D(s,e){const i=M[s];if(!i)return null;if(!e?.configured)return r.jsx(d,{name:i.name,icon:i.icon,children:r.jsx(c,{children:n("limits.status.not_connected")})},s);if(e.error)return r.jsx(d,{name:i.name,icon:i.icon,children:r.jsx(c,{tone:"error",children:n("shared.error.prefix",{error:e.error})})},s);switch(s){case"claude":return r.jsxs(d,{name:i.name,icon:i.icon,children:[e.five_hour?r.jsx(o,{label:"5h",pct:e.five_hour.utilization,reset:t(e.five_hour.resets_at)}):null,e.seven_day?r.jsx(o,{label:"7d",pct:e.seven_day.utilization,reset:t(e.seven_day.resets_at)}):null,e.seven_day_opus?r.jsx(o,{label:"Opus",pct:e.seven_day_opus.utilization,reset:t(e.seven_day_opus.resets_at)}):null,!e.five_hour&&!e.seven_day&&!e.seven_day_opus?r.jsx(c,{children:n("limits.status.no_data")}):null]},"claude");case"codex":return r.jsxs(d,{name:i.name,icon:i.icon,children:[e.primary_window?r.jsx(o,{label:"5h",pct:e.primary_window.used_percent,reset:t(e.primary_window.reset_at)}):null,e.secondary_window?r.jsx(o,{label:"7d",pct:e.secondary_window.used_percent,reset:t(e.secondary_window.reset_at)}):null,!e.primary_window&&!e.secondary_window?r.jsx(c,{children:n("limits.status.no_data")}):null]},"codex");case"cursor":return r.jsxs(d,{name:i.name,icon:i.icon,children:[e.primary_window?r.jsx(o,{label:n("limits.label.cursor_plan"),pct:e.primary_window.used_percent,reset:t(e.primary_window.reset_at)}):null,e.secondary_window?r.jsx(o,{label:n("limits.label.cursor_auto"),pct:e.secondary_window.used_percent,reset:t(e.secondary_window.reset_at)}):null,e.tertiary_window?r.jsx(o,{label:n("limits.label.cursor_api"),pct:e.tertiary_window.used_percent,reset:t(e.tertiary_window.reset_at)}):null,!e.primary_window&&!e.secondary_window&&!e.tertiary_window?r.jsx(c,{children:n("limits.status.no_data")}):null]},"cursor");case"gemini":return r.jsxs(d,{name:i.name,icon:i.icon,children:[e.primary_window?r.jsx(o,{label:"Pro",pct:e.primary_window.used_percent,reset:t(e.primary_window.reset_at)}):null,e.secondary_window?r.jsx(o,{label:"Flash",pct:e.secondary_window.used_percent,reset:t(e.secondary_window.reset_at)}):null,e.tertiary_window?r.jsx(o,{label:"Lite",pct:e.tertiary_window.used_percent,reset:t(e.tertiary_window.reset_at)}):null,!e.primary_window&&!e.secondary_window&&!e.tertiary_window?r.jsx(c,{children:n("limits.status.no_data")}):null]},"gemini");case"kimi":return r.jsxs(d,{name:i.name,icon:i.icon,children:[e.primary_window?r.jsx(o,{label:n("limits.label.kimi_weekly"),pct:e.primary_window.used_percent,reset:t(e.primary_window.reset_at)}):null,e.secondary_window?r.jsx(o,{label:n("limits.label.kimi_5h"),pct:e.secondary_window.used_percent,reset:t(e.secondary_window.reset_at)}):null,e.tertiary_window?r.jsx(o,{label:n("limits.label.kimi_total"),pct:e.tertiary_window.used_percent,reset:t(e.tertiary_window.reset_at)}):null,e.parallel_limit?r.jsx(c,{children:n("limits.label.kimi_parallel",{count:e.parallel_limit})}):null,!e.primary_window&&!e.secondary_window&&!e.tertiary_window?r.jsx(c,{children:n("limits.status.no_data")}):null]},"kimi");case"kiro":return r.jsxs(d,{name:i.name,icon:i.icon,children:[e.primary_window?r.jsx(o,{label:n("limits.label.kiro_month"),pct:e.primary_window.used_percent,reset:t(e.primary_window.reset_at)}):null,e.secondary_window?r.jsx(o,{label:n("limits.label.kiro_bonus"),pct:e.secondary_window.used_percent,reset:t(e.secondary_window.reset_at)}):null,!e.primary_window&&!e.secondary_window?r.jsx(c,{children:n("limits.status.no_data")}):null]},"kiro");case"antigravity":return r.jsxs(d,{name:i.name,icon:i.icon,children:[e.primary_window?r.jsx(o,{label:"Claude",pct:e.primary_window.used_percent,reset:t(e.primary_window.reset_at)}):null,e.secondary_window?r.jsx(o,{label:"G Pro",pct:e.secondary_window.used_percent,reset:t(e.secondary_window.reset_at)}):null,e.tertiary_window?r.jsx(o,{label:"Flash",pct:e.tertiary_window.used_percent,reset:t(e.tertiary_window.reset_at)}):null,!e.primary_window&&!e.secondary_window&&!e.tertiary_window?r.jsx(c,{children:n("limits.status.no_data")}):null]},"antigravity");case"copilot":return r.jsxs(d,{name:i.name,icon:i.icon,children:[e.primary_window?r.jsx(o,{label:n("limits.label.copilot_premium"),pct:e.primary_window.used_percent,reset:t(e.primary_window.reset_at)}):null,e.secondary_window?r.jsx(o,{label:n("limits.label.copilot_chat"),pct:e.secondary_window.used_percent,reset:t(e.secondary_window.reset_at)}):null,!e.primary_window&&!e.secondary_window?r.jsx(c,{children:n("limits.status.no_data")}):null,e.otel_has_files||e.otel_enabled?null:r.jsx(H,{defaultDir:e.otel_default_dir})]},"copilot");default:return null}}function H({defaultDir:s}){const[e,i]=j.useState(!1),a=["export COPILOT_OTEL_ENABLED=true","export COPILOT_OTEL_EXPORTER_TYPE=file",`export COPILOT_OTEL_FILE_EXPORTER_PATH="${s||"$HOME/.copilot/otel"}/copilot-otel-$(date +%Y%m%d).jsonl"`].join(`
|
|
2
|
+
`),u=async()=>{try{await navigator.clipboard.writeText(a),i(!0),setTimeout(()=>i(!1),1600)}catch{}};return r.jsxs("div",{className:"mt-1 rounded-md border border-amber-300/60 dark:border-amber-700/40 bg-amber-50/50 dark:bg-amber-900/10 px-2.5 py-2 text-[11px] text-oai-gray-600 dark:text-oai-gray-300",children:[r.jsx("div",{className:"font-medium text-oai-gray-700 dark:text-oai-gray-200",children:n("limits.copilot.otelHint.title")}),r.jsx("div",{className:"mt-0.5 leading-snug",children:n("limits.copilot.otelHint.body")}),r.jsx("pre",{className:"mt-1.5 overflow-x-auto rounded bg-oai-gray-100 dark:bg-oai-gray-900/60 px-2 py-1.5 font-mono text-[10.5px] leading-tight whitespace-pre",children:a}),r.jsx("button",{type:"button",onClick:u,className:"mt-1 inline-flex items-center gap-1 rounded border border-oai-gray-300 dark:border-oai-gray-700 px-1.5 py-0.5 text-[10.5px] text-oai-gray-700 dark:text-oai-gray-200 hover:bg-oai-gray-100 dark:hover:bg-oai-gray-800 transition-colors",children:e?n("limits.copilot.otelHint.copied"):n("limits.copilot.otelHint.copy")})]})}function $({claude:s,codex:e,cursor:i,gemini:l,kimi:a,kiro:u,antigravity:x,copilot:b,order:p,visibility:_}){const f={claude:s,codex:e,cursor:i,gemini:l,kimi:a,kiro:u,antigravity:x,copilot:b},y=(Array.isArray(p)&&p.length>0?p:A).filter(w=>!_||_[w]!==!1).map(w=>D(w,f[w])).filter(Boolean);return r.jsx(O,{delay:.15,children:r.jsx(h,{children:r.jsxs("div",{className:"flex flex-col gap-3",children:[r.jsx("h3",{className:"text-sm font-medium text-oai-gray-500 dark:text-oai-gray-300 uppercase tracking-wide",children:n("limits.panel.title")}),y.length>0?y:r.jsx(c,{children:n("limits.status.all_hidden")})]})})})}const F=typeof window<"u"&&(window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1");function q(){const{data:s,error:e,isLoading:i}=L({initialRefresh:!0}),l=E();return!F&&!v()?r.jsx("div",{className:"flex flex-col flex-1 text-oai-black dark:text-oai-white font-oai antialiased",children:r.jsx(P,{})}):r.jsx("div",{className:"flex flex-col flex-1 text-oai-black dark:text-oai-white font-oai antialiased",children:r.jsx("main",{className:"flex-1 pt-8 sm:pt-10 pb-12 sm:pb-16",children:r.jsxs("div",{className:"mx-auto max-w-6xl px-4 sm:px-6",children:[r.jsxs("div",{className:"flex flex-row items-start justify-between gap-4 mb-8",children:[r.jsxs("div",{className:"min-w-0",children:[r.jsx("h1",{className:"text-3xl sm:text-4xl font-semibold tracking-tight text-oai-black dark:text-white mb-3",children:n("nav.limits")}),r.jsx("p",{className:"text-oai-gray-500 dark:text-oai-gray-400 text-sm sm:text-base",children:n("limits.page.subtitle")})]}),r.jsx(k,{to:"/settings","aria-label":n("limits.page.openSettings"),title:n("limits.page.openSettings"),className:"shrink-0 inline-flex h-9 w-9 items-center justify-center rounded-lg border border-oai-gray-200 dark:border-oai-gray-800 text-oai-gray-600 dark:text-oai-gray-400 hover:bg-oai-gray-100 dark:hover:bg-oai-gray-800 hover:text-oai-black dark:hover:text-white transition-colors no-underline focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-oai-brand-500",children:r.jsx(N,{className:"h-4 w-4","aria-hidden":!0})})]}),i?r.jsx(S,{}):r.jsxs(r.Fragment,{children:[e?r.jsx("p",{className:"mb-4 text-sm text-red-500 dark:text-red-400",children:n("shared.error.prefix",{error:e})}):null,r.jsx($,{claude:s?.claude,codex:s?.codex,cursor:s?.cursor,gemini:s?.gemini,kimi:s?.kimi,kiro:s?.kiro,antigravity:s?.antigravity,copilot:s?.copilot,order:l.order,visibility:l.visibility})]})]})})})}export{q as LimitsPage};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{u as e,s as t}from"./main-
|
|
1
|
+
import{u as e,s as t}from"./main-uqC1VAKB.js";import{A as r}from"./arrow-up-right-BS0sCPTz.js";import{D as o}from"./download-CqDWRO99.js";const i="https://github.com/mm7894215/TokenTracker/releases/latest";function c(){const a=()=>{try{window.location.href="tokentracker://open"}catch{}};return e.jsx("div",{className:"flex flex-1 flex-col items-center justify-center px-6 py-20 text-center",children:e.jsxs("div",{className:"max-w-md",children:[e.jsx("h2",{className:"text-lg font-semibold text-oai-black dark:text-white",children:t("local_only.title")}),e.jsx("p",{className:"mt-2 text-sm leading-relaxed text-oai-gray-500 dark:text-oai-gray-400",children:t("local_only.body")}),e.jsxs("div",{className:"mt-6 flex flex-wrap items-center justify-center gap-3",children:[e.jsxs("button",{type:"button",onClick:a,className:"inline-flex h-9 items-center gap-1.5 rounded-full px-4 text-sm font-medium bg-oai-gray-900 text-white hover:bg-oai-gray-800 dark:bg-white dark:text-oai-gray-900 dark:hover:bg-oai-gray-100 transition-colors",children:[e.jsx("span",{children:t("local_only.open_app")}),e.jsx(r,{size:14,strokeWidth:2,"aria-hidden":!0})]}),e.jsxs("a",{href:i,target:"_blank",rel:"noopener noreferrer",className:"inline-flex h-9 items-center gap-1.5 rounded-full px-4 text-sm font-medium ring-1 ring-oai-gray-200 dark:ring-oai-gray-800 text-oai-gray-700 dark:text-oai-gray-300 hover:bg-oai-gray-100 dark:hover:bg-oai-gray-900 transition-colors",children:[e.jsx(o,{size:14,strokeWidth:2,"aria-hidden":!0}),e.jsx("span",{children:t("local_only.download")})]})]})]})})}export{c as L};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{aj as Y,au as Z,Q as ee,r,s,u as e,L as G,N as v}from"./main-uqC1VAKB.js";function te(n){const a=new URLSearchParams(n).get("next");return typeof a!="string"||a.length===0||!a.startsWith("/")||a.startsWith("//")?"/dashboard":a}const Q={google:"Google",github:"GitHub",microsoft:"Microsoft",discord:"Discord",linkedin:"LinkedIn",facebook:"Facebook",instagram:"Instagram",tiktok:"TikTok",apple:"Apple",x:"X",spotify:"Spotify"};function V(n){const a=String(n||"").trim();return Q[a]?Q[a]:a.replace(/-/g," ")}function ie(){const n=Y(),[a,A]=Z(),{enabled:o,loading:g,signedIn:f,refreshUser:C,signInWithPassword:E,signUp:M,signInWithOAuth:I,getPublicAuthConfig:F}=ee(),m=r.useMemo(()=>te(a.toString()),[a]),[l,j]=r.useState("signin"),[x,$]=r.useState(""),[h,H]=r.useState(""),[N,X]=r.useState(""),[k,p]=r.useState(!1),[O,c]=r.useState(null),[U,b]=r.useState(null),[S,B]=r.useState(!0),[_,R]=r.useState([]),[P,T]=r.useState([]),[W,z]=r.useState(8);r.useEffect(()=>{const t=a.get("insforge_status"),i=a.get("insforge_type"),u=a.get("insforge_error");t==="success"&&i==="verify_email"?b(s("login.verify_email_success")):t==="error"&&i==="verify_email"&&u&&b(s("shared.error.prefix",{error:u}))},[a]),r.useEffect(()=>{if(!o){B(!1);return}let t=!0;return(async()=>{const{data:i,error:u}=await F();t&&(u||!i?(R(["google","github"]),T([])):(R(Array.isArray(i.oAuthProviders)?i.oAuthProviders:[]),T(Array.isArray(i.customOAuthProviders)?i.customOAuthProviders:[]),typeof i.passwordMinLength=="number"&&i.passwordMinLength>0&&z(i.passwordMinLength)),B(!1))})(),()=>{t=!1}},[o,F]);const d=r.useMemo(()=>a.get("native")==="1",[a]),y=r.useMemo(()=>a.get("provider")||null,[a]);r.useEffect(()=>{if(!(!o||g)&&f){if(d){window.location.href="/auth/native-callback";return}n(m,{replace:!0})}},[o,g,f,n,m,d]),r.useEffect(()=>{o&&C()},[o,C]);const q=r.useMemo(()=>typeof window>"u"||d?"":`${window.location.origin}/`,[d]),D=r.useMemo(()=>typeof window>"u"?"":`${window.location.origin}/`,[]),J=r.useCallback(async t=>{t.preventDefault(),c(null),p(!0);try{if(l==="signup"){const{data:u,error:L}=await M({email:x.trim(),password:h,name:N.trim()||void 0,redirectTo:D});if(L){c(L.message||String(L));return}if(u?.requireEmailVerification){b(s("login.verify_email_pending")),j("signin");return}n(m,{replace:!0});return}const{error:i}=await E({email:x.trim(),password:h});if(i){c(i.message||String(i));return}n(m,{replace:!0})}finally{p(!1)}},[l,x,h,N,M,E,n,m,D]),w=r.useCallback(async t=>{c(null),p(!0);try{const{error:i}=await I(t,q);i&&c(i.message||String(i))}finally{p(!1)}},[I,q]);r.useEffect(()=>{if(d&&typeof window<"u")try{window.sessionStorage.setItem("tokentracker_native_login","1")}catch{}},[d]),r.useEffect(()=>{if(!o||g||f||S||!d||!y)return;[..._,...P].includes(y)&&w(y)},[o,g,f,S,d,y,_,P,w]);const K=r.useCallback(()=>{A(t=>{const i=new URLSearchParams(t);return i.delete("insforge_status"),i.delete("insforge_type"),i.delete("insforge_error"),i},{replace:!0}),b(null)},[A]);return o?e.jsxs("div",{className:"min-h-screen bg-oai-gray-950 text-oai-white font-oai antialiased dark flex flex-col",children:[e.jsx("header",{className:"border-b border-oai-gray-900 px-4 sm:px-6 h-16 flex items-center justify-between",children:e.jsx(G,{to:"/",className:"text-sm font-medium text-oai-gray-400 hover:text-white no-underline focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-oai-brand-500 rounded",children:s("login.back_home")})}),e.jsx("main",{className:"flex-1 flex items-center justify-center px-4 py-12",children:e.jsxs("div",{className:"w-full max-w-md space-y-8",children:[e.jsxs("div",{className:"text-center",children:[e.jsx("h1",{className:"text-2xl font-semibold text-white tracking-tight",children:s("login.title")}),e.jsx("p",{className:"mt-2 text-sm text-oai-gray-500",children:s("login.subtitle")})]}),U?e.jsxs("div",{className:"rounded-lg border border-oai-gray-800 bg-oai-gray-900/50 px-4 py-3 text-sm text-oai-gray-300 flex justify-between gap-3 items-start",role:"status",children:[e.jsx("span",{children:U}),e.jsx("button",{type:"button",onClick:K,className:"shrink-0 text-oai-gray-500 hover:text-white text-xs",children:s("login.dismiss")})]}):null,O?e.jsx("p",{className:"text-sm text-red-400",role:"alert",children:s("shared.error.prefix",{error:O})}):null,e.jsx("div",{className:"space-y-3",children:S?e.jsx("div",{className:"h-11 rounded-lg bg-oai-gray-900 animate-pulse","aria-hidden":!0}):e.jsxs(e.Fragment,{children:[_.map(t=>e.jsx("button",{type:"button",disabled:k,onClick:()=>w(t),className:v("w-full h-11 rounded-lg border border-oai-gray-700 bg-oai-gray-900 text-sm font-medium text-white","hover:bg-oai-gray-800 transition-colors disabled:opacity-50"),children:s("login.oauth.continue",{provider:V(t)})},t)),P.map(t=>e.jsx("button",{type:"button",disabled:k,onClick:()=>w(t),className:v("w-full h-11 rounded-lg border border-oai-gray-700 bg-oai-gray-900 text-sm font-medium text-white","hover:bg-oai-gray-800 transition-colors disabled:opacity-50"),children:s("login.oauth.continue",{provider:V(t)})},t))]})}),e.jsxs("div",{className:"relative",children:[e.jsx("div",{className:"absolute inset-0 flex items-center","aria-hidden":!0,children:e.jsx("span",{className:"w-full border-t border-oai-gray-800"})}),e.jsx("div",{className:"relative flex justify-center text-xs uppercase tracking-wider",children:e.jsx("span",{className:"bg-oai-gray-950 px-3 text-oai-gray-600",children:s("login.divider")})})]}),e.jsxs("div",{className:"flex rounded-lg border border-oai-gray-800 p-0.5 bg-oai-gray-900/50",children:[e.jsx("button",{type:"button",className:v("flex-1 py-2 text-sm font-medium rounded-md transition-colors",l==="signin"?"bg-oai-gray-800 text-white":"text-oai-gray-500 hover:text-oai-gray-300"),onClick:()=>{j("signin"),c(null)},children:s("login.tab.sign_in")}),e.jsx("button",{type:"button",className:v("flex-1 py-2 text-sm font-medium rounded-md transition-colors",l==="signup"?"bg-oai-gray-800 text-white":"text-oai-gray-500 hover:text-oai-gray-300"),onClick:()=>{j("signup"),c(null)},children:s("login.tab.sign_up")})]}),e.jsxs("form",{onSubmit:J,className:"space-y-4",children:[l==="signup"?e.jsxs("div",{children:[e.jsx("label",{htmlFor:"login-name",className:"block text-xs font-medium text-oai-gray-500 mb-1",children:s("login.field.name")}),e.jsx("input",{id:"login-name",type:"text",autoComplete:"name",value:N,onChange:t=>X(t.target.value),className:"w-full h-11 rounded-lg border border-oai-gray-800 bg-oai-gray-900 px-3 text-sm text-white placeholder-oai-gray-600 focus:outline-none focus:ring-2 focus:ring-oai-brand-500",placeholder:s("login.field.name_placeholder")})]}):null,e.jsxs("div",{children:[e.jsx("label",{htmlFor:"login-email",className:"block text-xs font-medium text-oai-gray-500 mb-1",children:s("login.field.email")}),e.jsx("input",{id:"login-email",type:"email",autoComplete:"email",required:!0,value:x,onChange:t=>$(t.target.value),className:"w-full h-11 rounded-lg border border-oai-gray-800 bg-oai-gray-900 px-3 text-sm text-white placeholder-oai-gray-600 focus:outline-none focus:ring-2 focus:ring-oai-brand-500"})]}),e.jsxs("div",{children:[e.jsx("label",{htmlFor:"login-password",className:"block text-xs font-medium text-oai-gray-500 mb-1",children:s("login.field.password")}),e.jsx("input",{id:"login-password",type:"password",autoComplete:l==="signup"?"new-password":"current-password",required:!0,minLength:l==="signup"?W:void 0,value:h,onChange:t=>H(t.target.value),className:"w-full h-11 rounded-lg border border-oai-gray-800 bg-oai-gray-900 px-3 text-sm text-white placeholder-oai-gray-600 focus:outline-none focus:ring-2 focus:ring-oai-brand-500"}),l==="signup"?e.jsx("p",{className:"mt-1 text-xs text-oai-gray-600",children:s("login.password_hint",{min:String(W)})}):null]}),e.jsx("button",{type:"submit",disabled:k||g,className:"w-full h-11 rounded-lg bg-white text-oai-gray-950 text-sm font-semibold hover:bg-oai-gray-100 transition-colors disabled:opacity-50",children:l==="signup"?s("login.submit.sign_up"):s("login.submit.sign_in")})]})]})})]}):e.jsxs("div",{className:"min-h-screen bg-oai-gray-950 text-oai-white font-oai antialiased dark flex flex-col",children:[e.jsx("header",{className:"border-b border-oai-gray-900 px-4 sm:px-6 py-4",children:e.jsx(G,{to:"/",className:"text-sm font-medium text-oai-gray-400 hover:text-white no-underline",children:s("login.back_home")})}),e.jsx("main",{className:"flex-1 flex items-center justify-center px-4",children:e.jsx("p",{className:"text-oai-gray-400 text-center max-w-md",children:s("login.cloud_only")})})]})}export{ie as LoginPage};
|