diff --git a/dist/assets/index-Ciepux24.js b/dist/assets/index-Ciepux24.js deleted file mode 100644 index a8f7b72..0000000 --- a/dist/assets/index-Ciepux24.js +++ /dev/null @@ -1,68 +0,0 @@ -function jf(e,t){for(var n=0;nr[l]})}}}return Object.freeze(Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}))}(function(){const t=document.createElement("link").relList;if(t&&t.supports&&t.supports("modulepreload"))return;for(const l of document.querySelectorAll('link[rel="modulepreload"]'))r(l);new MutationObserver(l=>{for(const i of l)if(i.type==="childList")for(const o of i.addedNodes)o.tagName==="LINK"&&o.rel==="modulepreload"&&r(o)}).observe(document,{childList:!0,subtree:!0});function n(l){const i={};return l.integrity&&(i.integrity=l.integrity),l.referrerPolicy&&(i.referrerPolicy=l.referrerPolicy),l.crossOrigin==="use-credentials"?i.credentials="include":l.crossOrigin==="anonymous"?i.credentials="omit":i.credentials="same-origin",i}function r(l){if(l.ep)return;l.ep=!0;const i=n(l);fetch(l.href,i)}})();function Pf(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var $u={exports:{}},Tl={},Wu={exports:{}},U={};/** - * @license React - * react.production.min.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */var xr=Symbol.for("react.element"),_f=Symbol.for("react.portal"),Lf=Symbol.for("react.fragment"),Rf=Symbol.for("react.strict_mode"),Tf=Symbol.for("react.profiler"),zf=Symbol.for("react.provider"),Of=Symbol.for("react.context"),If=Symbol.for("react.forward_ref"),Uf=Symbol.for("react.suspense"),Mf=Symbol.for("react.memo"),Df=Symbol.for("react.lazy"),Es=Symbol.iterator;function Ff(e){return e===null||typeof e!="object"?null:(e=Es&&e[Es]||e["@@iterator"],typeof e=="function"?e:null)}var Hu={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},Qu=Object.assign,Ku={};function _n(e,t,n){this.props=e,this.context=t,this.refs=Ku,this.updater=n||Hu}_n.prototype.isReactComponent={};_n.prototype.setState=function(e,t){if(typeof e!="object"&&typeof e!="function"&&e!=null)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,e,t,"setState")};_n.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")};function Gu(){}Gu.prototype=_n.prototype;function Co(e,t,n){this.props=e,this.context=t,this.refs=Ku,this.updater=n||Hu}var No=Co.prototype=new Gu;No.constructor=Co;Qu(No,_n.prototype);No.isPureReactComponent=!0;var Cs=Array.isArray,Xu=Object.prototype.hasOwnProperty,jo={current:null},Yu={key:!0,ref:!0,__self:!0,__source:!0};function Ju(e,t,n){var r,l={},i=null,o=null;if(t!=null)for(r in t.ref!==void 0&&(o=t.ref),t.key!==void 0&&(i=""+t.key),t)Xu.call(t,r)&&!Yu.hasOwnProperty(r)&&(l[r]=t[r]);var u=arguments.length-2;if(u===1)l.children=n;else if(1>>1,J=P[B];if(0>>1;Bl(On,T))Del(Zt,On)?(P[B]=Zt,P[De]=T,B=De):(P[B]=On,P[Me]=T,B=Me);else if(Del(Zt,T))P[B]=Zt,P[De]=T,B=De;else break e}}return z}function l(P,z){var T=P.sortIndex-z.sortIndex;return T!==0?T:P.id-z.id}if(typeof performance=="object"&&typeof performance.now=="function"){var i=performance;e.unstable_now=function(){return i.now()}}else{var o=Date,u=o.now();e.unstable_now=function(){return o.now()-u}}var s=[],c=[],m=1,d=null,v=3,x=!1,g=!1,S=!1,k=typeof setTimeout=="function"?setTimeout:null,p=typeof clearTimeout=="function"?clearTimeout:null,f=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function h(P){for(var z=n(c);z!==null;){if(z.callback===null)r(c);else if(z.startTime<=P)r(c),z.sortIndex=z.expirationTime,t(s,z);else break;z=n(c)}}function y(P){if(S=!1,h(P),!g)if(n(s)!==null)g=!0,Ut(C);else{var z=n(c);z!==null&&Se(y,z.startTime-P)}}function C(P,z){g=!1,S&&(S=!1,p(R),R=-1),x=!0;var T=v;try{for(h(z),d=n(s);d!==null&&(!(d.expirationTime>z)||P&&!se());){var B=d.callback;if(typeof B=="function"){d.callback=null,v=d.priorityLevel;var J=B(d.expirationTime<=z);z=e.unstable_now(),typeof J=="function"?d.callback=J:d===n(s)&&r(s),h(z)}else r(s);d=n(s)}if(d!==null)var Mt=!0;else{var Me=n(c);Me!==null&&Se(y,Me.startTime-z),Mt=!1}return Mt}finally{d=null,v=T,x=!1}}var j=!1,_=null,R=-1,A=5,O=-1;function se(){return!(e.unstable_now()-OP||125B?(P.sortIndex=T,t(c,P),n(s)===null&&P===n(c)&&(S?(p(R),R=-1):S=!0,Se(y,T-B))):(P.sortIndex=J,t(s,P),g||x||(g=!0,Ut(C))),P},e.unstable_shouldYield=se,e.unstable_wrapCallback=function(P){var z=v;return function(){var T=v;v=z;try{return P.apply(this,arguments)}finally{v=T}}}})(na);ta.exports=na;var Jf=ta.exports;/** - * @license React - * react-dom.production.min.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */var Zf=w,Pe=Jf;function E(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),Ni=Object.prototype.hasOwnProperty,qf=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,js={},Ps={};function bf(e){return Ni.call(Ps,e)?!0:Ni.call(js,e)?!1:qf.test(e)?Ps[e]=!0:(js[e]=!0,!1)}function ed(e,t,n,r){if(n!==null&&n.type===0)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return r?!1:n!==null?!n.acceptsBooleans:(e=e.toLowerCase().slice(0,5),e!=="data-"&&e!=="aria-");default:return!1}}function td(e,t,n,r){if(t===null||typeof t>"u"||ed(e,t,n,r))return!0;if(r)return!1;if(n!==null)switch(n.type){case 3:return!t;case 4:return t===!1;case 5:return isNaN(t);case 6:return isNaN(t)||1>t}return!1}function me(e,t,n,r,l,i,o){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=r,this.attributeNamespace=l,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=i,this.removeEmptyString=o}var oe={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){oe[e]=new me(e,0,!1,e,null,!1,!1)});[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];oe[t]=new me(t,1,!1,e[1],null,!1,!1)});["contentEditable","draggable","spellCheck","value"].forEach(function(e){oe[e]=new me(e,2,!1,e.toLowerCase(),null,!1,!1)});["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){oe[e]=new me(e,2,!1,e,null,!1,!1)});"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach(function(e){oe[e]=new me(e,3,!1,e.toLowerCase(),null,!1,!1)});["checked","multiple","muted","selected"].forEach(function(e){oe[e]=new me(e,3,!0,e,null,!1,!1)});["capture","download"].forEach(function(e){oe[e]=new me(e,4,!1,e,null,!1,!1)});["cols","rows","size","span"].forEach(function(e){oe[e]=new me(e,6,!1,e,null,!1,!1)});["rowSpan","start"].forEach(function(e){oe[e]=new me(e,5,!1,e.toLowerCase(),null,!1,!1)});var _o=/[\-:]([a-z])/g;function Lo(e){return e[1].toUpperCase()}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(e){var t=e.replace(_o,Lo);oe[t]=new me(t,1,!1,e,null,!1,!1)});"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach(function(e){var t=e.replace(_o,Lo);oe[t]=new me(t,1,!1,e,"http://www.w3.org/1999/xlink",!1,!1)});["xml:base","xml:lang","xml:space"].forEach(function(e){var t=e.replace(_o,Lo);oe[t]=new me(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)});["tabIndex","crossOrigin"].forEach(function(e){oe[e]=new me(e,1,!1,e.toLowerCase(),null,!1,!1)});oe.xlinkHref=new me("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1);["src","href","action","formAction"].forEach(function(e){oe[e]=new me(e,1,!1,e.toLowerCase(),null,!0,!0)});function Ro(e,t,n,r){var l=oe.hasOwnProperty(t)?oe[t]:null;(l!==null?l.type!==0:r||!(2u||l[o]!==i[u]){var s=` -`+l[o].replace(" at new "," at ");return e.displayName&&s.includes("")&&(s=s.replace("",e.displayName)),s}while(1<=o&&0<=u);break}}}finally{ei=!1,Error.prepareStackTrace=n}return(e=e?e.displayName||e.name:"")?$n(e):""}function nd(e){switch(e.tag){case 5:return $n(e.type);case 16:return $n("Lazy");case 13:return $n("Suspense");case 19:return $n("SuspenseList");case 0:case 2:case 15:return e=ti(e.type,!1),e;case 11:return e=ti(e.type.render,!1),e;case 1:return e=ti(e.type,!0),e;default:return""}}function Li(e){if(e==null)return null;if(typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case nn:return"Fragment";case tn:return"Portal";case ji:return"Profiler";case To:return"StrictMode";case Pi:return"Suspense";case _i:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case ia:return(e.displayName||"Context")+".Consumer";case la:return(e._context.displayName||"Context")+".Provider";case zo:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case Oo:return t=e.displayName||null,t!==null?t:Li(e.type)||"Memo";case dt:t=e._payload,e=e._init;try{return Li(e(t))}catch{}}return null}function rd(e){var t=e.type;switch(e.tag){case 24:return"Cache";case 9:return(t.displayName||"Context")+".Consumer";case 10:return(t._context.displayName||"Context")+".Provider";case 18:return"DehydratedFragment";case 11:return e=t.render,e=e.displayName||e.name||"",t.displayName||(e!==""?"ForwardRef("+e+")":"ForwardRef");case 7:return"Fragment";case 5:return t;case 4:return"Portal";case 3:return"Root";case 6:return"Text";case 16:return Li(t);case 8:return t===To?"StrictMode":"Mode";case 22:return"Offscreen";case 12:return"Profiler";case 21:return"Scope";case 13:return"Suspense";case 19:return"SuspenseList";case 25:return"TracingMarker";case 1:case 0:case 17:case 2:case 14:case 15:if(typeof t=="function")return t.displayName||t.name||null;if(typeof t=="string")return t}return null}function _t(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function sa(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function ld(e){var t=sa(e)?"checked":"value",n=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),r=""+e[t];if(!e.hasOwnProperty(t)&&typeof n<"u"&&typeof n.get=="function"&&typeof n.set=="function"){var l=n.get,i=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return l.call(this)},set:function(o){r=""+o,i.call(this,o)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(o){r=""+o},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function Rr(e){e._valueTracker||(e._valueTracker=ld(e))}function ua(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=sa(e)?e.checked?"true":"false":e.value),e=r,e!==n?(t.setValue(e),!0):!1}function il(e){if(e=e||(typeof document<"u"?document:void 0),typeof e>"u")return null;try{return e.activeElement||e.body}catch{return e.body}}function Ri(e,t){var n=t.checked;return G({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??e._wrapperState.initialChecked})}function Ls(e,t){var n=t.defaultValue==null?"":t.defaultValue,r=t.checked!=null?t.checked:t.defaultChecked;n=_t(t.value!=null?t.value:n),e._wrapperState={initialChecked:r,initialValue:n,controlled:t.type==="checkbox"||t.type==="radio"?t.checked!=null:t.value!=null}}function aa(e,t){t=t.checked,t!=null&&Ro(e,"checked",t,!1)}function Ti(e,t){aa(e,t);var n=_t(t.value),r=t.type;if(n!=null)r==="number"?(n===0&&e.value===""||e.value!=n)&&(e.value=""+n):e.value!==""+n&&(e.value=""+n);else if(r==="submit"||r==="reset"){e.removeAttribute("value");return}t.hasOwnProperty("value")?zi(e,t.type,n):t.hasOwnProperty("defaultValue")&&zi(e,t.type,_t(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function Rs(e,t,n){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var r=t.type;if(!(r!=="submit"&&r!=="reset"||t.value!==void 0&&t.value!==null))return;t=""+e._wrapperState.initialValue,n||t===e.value||(e.value=t),e.defaultValue=t}n=e.name,n!==""&&(e.name=""),e.defaultChecked=!!e._wrapperState.initialChecked,n!==""&&(e.name=n)}function zi(e,t,n){(t!=="number"||il(e.ownerDocument)!==e)&&(n==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}var Wn=Array.isArray;function hn(e,t,n,r){if(e=e.options,t){t={};for(var l=0;l"+t.valueOf().toString()+"",t=Tr.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function nr(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&n.nodeType===3){n.nodeValue=t;return}}e.textContent=t}var Kn={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},id=["Webkit","ms","Moz","O"];Object.keys(Kn).forEach(function(e){id.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),Kn[t]=Kn[e]})});function pa(e,t,n){return t==null||typeof t=="boolean"||t===""?"":n||typeof t!="number"||t===0||Kn.hasOwnProperty(e)&&Kn[e]?(""+t).trim():t+"px"}function ha(e,t){e=e.style;for(var n in t)if(t.hasOwnProperty(n)){var r=n.indexOf("--")===0,l=pa(n,t[n],r);n==="float"&&(n="cssFloat"),r?e.setProperty(n,l):e[n]=l}}var od=G({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function Ui(e,t){if(t){if(od[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(E(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(E(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(E(61))}if(t.style!=null&&typeof t.style!="object")throw Error(E(62))}}function Mi(e,t){if(e.indexOf("-")===-1)return typeof t.is=="string";switch(e){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}var Di=null;function Io(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var Fi=null,mn=null,vn=null;function Os(e){if(e=Er(e)){if(typeof Fi!="function")throw Error(E(280));var t=e.stateNode;t&&(t=Ml(t),Fi(e.stateNode,e.type,t))}}function ma(e){mn?vn?vn.push(e):vn=[e]:mn=e}function va(){if(mn){var e=mn,t=vn;if(vn=mn=null,Os(e),t)for(e=0;e>>=0,e===0?32:31-(gd(e)/yd|0)|0}var zr=64,Or=4194304;function Hn(e){switch(e&-e){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return e&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return e&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;default:return e}}function al(e,t){var n=e.pendingLanes;if(n===0)return 0;var r=0,l=e.suspendedLanes,i=e.pingedLanes,o=n&268435455;if(o!==0){var u=o&~l;u!==0?r=Hn(u):(i&=o,i!==0&&(r=Hn(i)))}else o=n&~l,o!==0?r=Hn(o):i!==0&&(r=Hn(i));if(r===0)return 0;if(t!==0&&t!==r&&!(t&l)&&(l=r&-r,i=t&-t,l>=i||l===16&&(i&4194240)!==0))return t;if(r&4&&(r|=n&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=r;0n;n++)t.push(e);return t}function Sr(e,t,n){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-$e(t),e[t]=n}function kd(e,t){var n=e.pendingLanes&~t;e.pendingLanes=t,e.suspendedLanes=0,e.pingedLanes=0,e.expiredLanes&=t,e.mutableReadLanes&=t,e.entangledLanes&=t,t=e.entanglements;var r=e.eventTimes;for(e=e.expirationTimes;0=Xn),$s=" ",Ws=!1;function Ma(e,t){switch(e){case"keyup":return Jd.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function Da(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var rn=!1;function qd(e,t){switch(e){case"compositionend":return Da(t);case"keypress":return t.which!==32?null:(Ws=!0,$s);case"textInput":return e=t.data,e===$s&&Ws?null:e;default:return null}}function bd(e,t){if(rn)return e==="compositionend"||!$o&&Ma(e,t)?(e=Ia(),Yr=Ao=vt=null,rn=!1,e):null;switch(e){case"paste":return null;case"keypress":if(!(t.ctrlKey||t.altKey||t.metaKey)||t.ctrlKey&&t.altKey){if(t.char&&1=t)return{node:n,offset:t-e};e=r}e:{for(;n;){if(n.nextSibling){n=n.nextSibling;break e}n=n.parentNode}n=void 0}n=Gs(n)}}function Va(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?Va(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function $a(){for(var e=window,t=il();t instanceof e.HTMLIFrameElement;){try{var n=typeof t.contentWindow.location.href=="string"}catch{n=!1}if(n)e=t.contentWindow;else break;t=il(e.document)}return t}function Wo(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t&&(t==="input"&&(e.type==="text"||e.type==="search"||e.type==="tel"||e.type==="url"||e.type==="password")||t==="textarea"||e.contentEditable==="true")}function up(e){var t=$a(),n=e.focusedElem,r=e.selectionRange;if(t!==n&&n&&n.ownerDocument&&Va(n.ownerDocument.documentElement,n)){if(r!==null&&Wo(n)){if(t=r.start,e=r.end,e===void 0&&(e=t),"selectionStart"in n)n.selectionStart=t,n.selectionEnd=Math.min(e,n.value.length);else if(e=(t=n.ownerDocument||document)&&t.defaultView||window,e.getSelection){e=e.getSelection();var l=n.textContent.length,i=Math.min(r.start,l);r=r.end===void 0?i:Math.min(r.end,l),!e.extend&&i>r&&(l=r,r=i,i=l),l=Xs(n,i);var o=Xs(n,r);l&&o&&(e.rangeCount!==1||e.anchorNode!==l.node||e.anchorOffset!==l.offset||e.focusNode!==o.node||e.focusOffset!==o.offset)&&(t=t.createRange(),t.setStart(l.node,l.offset),e.removeAllRanges(),i>r?(e.addRange(t),e.extend(o.node,o.offset)):(t.setEnd(o.node,o.offset),e.addRange(t)))}}for(t=[],e=n;e=e.parentNode;)e.nodeType===1&&t.push({element:e,left:e.scrollLeft,top:e.scrollTop});for(typeof n.focus=="function"&&n.focus(),n=0;n=document.documentMode,ln=null,Hi=null,Jn=null,Qi=!1;function Ys(e,t,n){var r=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;Qi||ln==null||ln!==il(r)||(r=ln,"selectionStart"in r&&Wo(r)?r={start:r.selectionStart,end:r.selectionEnd}:(r=(r.ownerDocument&&r.ownerDocument.defaultView||window).getSelection(),r={anchorNode:r.anchorNode,anchorOffset:r.anchorOffset,focusNode:r.focusNode,focusOffset:r.focusOffset}),Jn&&ur(Jn,r)||(Jn=r,r=dl(Hi,"onSelect"),0un||(e.current=Zi[un],Zi[un]=null,un--)}function V(e,t){un++,Zi[un]=e.current,e.current=t}var Lt={},fe=Tt(Lt),ye=Tt(!1),Ht=Lt;function Sn(e,t){var n=e.type.contextTypes;if(!n)return Lt;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var l={},i;for(i in n)l[i]=t[i];return r&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=l),l}function we(e){return e=e.childContextTypes,e!=null}function hl(){W(ye),W(fe)}function nu(e,t,n){if(fe.current!==Lt)throw Error(E(168));V(fe,t),V(ye,n)}function Za(e,t,n){var r=e.stateNode;if(t=t.childContextTypes,typeof r.getChildContext!="function")return n;r=r.getChildContext();for(var l in r)if(!(l in t))throw Error(E(108,rd(e)||"Unknown",l));return G({},n,r)}function ml(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||Lt,Ht=fe.current,V(fe,e),V(ye,ye.current),!0}function ru(e,t,n){var r=e.stateNode;if(!r)throw Error(E(169));n?(e=Za(e,t,Ht),r.__reactInternalMemoizedMergedChildContext=e,W(ye),W(fe),V(fe,e)):W(ye),V(ye,n)}var qe=null,Dl=!1,mi=!1;function qa(e){qe===null?qe=[e]:qe.push(e)}function xp(e){Dl=!0,qa(e)}function zt(){if(!mi&&qe!==null){mi=!0;var e=0,t=F;try{var n=qe;for(F=1;e>=o,l-=o,be=1<<32-$e(t)+l|n<R?(A=_,_=null):A=_.sibling;var O=v(p,_,h[R],y);if(O===null){_===null&&(_=A);break}e&&_&&O.alternate===null&&t(p,_),f=i(O,f,R),j===null?C=O:j.sibling=O,j=O,_=A}if(R===h.length)return n(p,_),H&&Dt(p,R),C;if(_===null){for(;RR?(A=_,_=null):A=_.sibling;var se=v(p,_,O.value,y);if(se===null){_===null&&(_=A);break}e&&_&&se.alternate===null&&t(p,_),f=i(se,f,R),j===null?C=se:j.sibling=se,j=se,_=A}if(O.done)return n(p,_),H&&Dt(p,R),C;if(_===null){for(;!O.done;R++,O=h.next())O=d(p,O.value,y),O!==null&&(f=i(O,f,R),j===null?C=O:j.sibling=O,j=O);return H&&Dt(p,R),C}for(_=r(p,_);!O.done;R++,O=h.next())O=x(_,p,R,O.value,y),O!==null&&(e&&O.alternate!==null&&_.delete(O.key===null?R:O.key),f=i(O,f,R),j===null?C=O:j.sibling=O,j=O);return e&&_.forEach(function(st){return t(p,st)}),H&&Dt(p,R),C}function k(p,f,h,y){if(typeof h=="object"&&h!==null&&h.type===nn&&h.key===null&&(h=h.props.children),typeof h=="object"&&h!==null){switch(h.$$typeof){case Lr:e:{for(var C=h.key,j=f;j!==null;){if(j.key===C){if(C=h.type,C===nn){if(j.tag===7){n(p,j.sibling),f=l(j,h.props.children),f.return=p,p=f;break e}}else if(j.elementType===C||typeof C=="object"&&C!==null&&C.$$typeof===dt&&ou(C)===j.type){n(p,j.sibling),f=l(j,h.props),f.ref=An(p,j,h),f.return=p,p=f;break e}n(p,j);break}else t(p,j);j=j.sibling}h.type===nn?(f=Wt(h.props.children,p.mode,y,h.key),f.return=p,p=f):(y=rl(h.type,h.key,h.props,null,p.mode,y),y.ref=An(p,f,h),y.return=p,p=y)}return o(p);case tn:e:{for(j=h.key;f!==null;){if(f.key===j)if(f.tag===4&&f.stateNode.containerInfo===h.containerInfo&&f.stateNode.implementation===h.implementation){n(p,f.sibling),f=l(f,h.children||[]),f.return=p,p=f;break e}else{n(p,f);break}else t(p,f);f=f.sibling}f=Ei(h,p.mode,y),f.return=p,p=f}return o(p);case dt:return j=h._init,k(p,f,j(h._payload),y)}if(Wn(h))return g(p,f,h,y);if(In(h))return S(p,f,h,y);Br(p,h)}return typeof h=="string"&&h!==""||typeof h=="number"?(h=""+h,f!==null&&f.tag===6?(n(p,f.sibling),f=l(f,h),f.return=p,p=f):(n(p,f),f=ki(h,p.mode,y),f.return=p,p=f),o(p)):n(p,f)}return k}var En=nc(!0),rc=nc(!1),yl=Tt(null),wl=null,fn=null,Go=null;function Xo(){Go=fn=wl=null}function Yo(e){var t=yl.current;W(yl),e._currentValue=t}function eo(e,t,n){for(;e!==null;){var r=e.alternate;if((e.childLanes&t)!==t?(e.childLanes|=t,r!==null&&(r.childLanes|=t)):r!==null&&(r.childLanes&t)!==t&&(r.childLanes|=t),e===n)break;e=e.return}}function yn(e,t){wl=e,Go=fn=null,e=e.dependencies,e!==null&&e.firstContext!==null&&(e.lanes&t&&(ge=!0),e.firstContext=null)}function Ie(e){var t=e._currentValue;if(Go!==e)if(e={context:e,memoizedValue:t,next:null},fn===null){if(wl===null)throw Error(E(308));fn=e,wl.dependencies={lanes:0,firstContext:e}}else fn=fn.next=e;return t}var Bt=null;function Jo(e){Bt===null?Bt=[e]:Bt.push(e)}function lc(e,t,n,r){var l=t.interleaved;return l===null?(n.next=n,Jo(t)):(n.next=l.next,l.next=n),t.interleaved=n,lt(e,r)}function lt(e,t){e.lanes|=t;var n=e.alternate;for(n!==null&&(n.lanes|=t),n=e,e=e.return;e!==null;)e.childLanes|=t,n=e.alternate,n!==null&&(n.childLanes|=t),n=e,e=e.return;return n.tag===3?n.stateNode:null}var pt=!1;function Zo(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function ic(e,t){e=e.updateQueue,t.updateQueue===e&&(t.updateQueue={baseState:e.baseState,firstBaseUpdate:e.firstBaseUpdate,lastBaseUpdate:e.lastBaseUpdate,shared:e.shared,effects:e.effects})}function tt(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function Et(e,t,n){var r=e.updateQueue;if(r===null)return null;if(r=r.shared,M&2){var l=r.pending;return l===null?t.next=t:(t.next=l.next,l.next=t),r.pending=t,lt(e,n)}return l=r.interleaved,l===null?(t.next=t,Jo(r)):(t.next=l.next,l.next=t),r.interleaved=t,lt(e,n)}function Zr(e,t,n){if(t=t.updateQueue,t!==null&&(t=t.shared,(n&4194240)!==0)){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,Mo(e,n)}}function su(e,t){var n=e.updateQueue,r=e.alternate;if(r!==null&&(r=r.updateQueue,n===r)){var l=null,i=null;if(n=n.firstBaseUpdate,n!==null){do{var o={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};i===null?l=i=o:i=i.next=o,n=n.next}while(n!==null);i===null?l=i=t:i=i.next=t}else l=i=t;n={baseState:r.baseState,firstBaseUpdate:l,lastBaseUpdate:i,shared:r.shared,effects:r.effects},e.updateQueue=n;return}e=n.lastBaseUpdate,e===null?n.firstBaseUpdate=t:e.next=t,n.lastBaseUpdate=t}function xl(e,t,n,r){var l=e.updateQueue;pt=!1;var i=l.firstBaseUpdate,o=l.lastBaseUpdate,u=l.shared.pending;if(u!==null){l.shared.pending=null;var s=u,c=s.next;s.next=null,o===null?i=c:o.next=c,o=s;var m=e.alternate;m!==null&&(m=m.updateQueue,u=m.lastBaseUpdate,u!==o&&(u===null?m.firstBaseUpdate=c:u.next=c,m.lastBaseUpdate=s))}if(i!==null){var d=l.baseState;o=0,m=c=s=null,u=i;do{var v=u.lane,x=u.eventTime;if((r&v)===v){m!==null&&(m=m.next={eventTime:x,lane:0,tag:u.tag,payload:u.payload,callback:u.callback,next:null});e:{var g=e,S=u;switch(v=t,x=n,S.tag){case 1:if(g=S.payload,typeof g=="function"){d=g.call(x,d,v);break e}d=g;break e;case 3:g.flags=g.flags&-65537|128;case 0:if(g=S.payload,v=typeof g=="function"?g.call(x,d,v):g,v==null)break e;d=G({},d,v);break e;case 2:pt=!0}}u.callback!==null&&u.lane!==0&&(e.flags|=64,v=l.effects,v===null?l.effects=[u]:v.push(u))}else x={eventTime:x,lane:v,tag:u.tag,payload:u.payload,callback:u.callback,next:null},m===null?(c=m=x,s=d):m=m.next=x,o|=v;if(u=u.next,u===null){if(u=l.shared.pending,u===null)break;v=u,u=v.next,v.next=null,l.lastBaseUpdate=v,l.shared.pending=null}}while(!0);if(m===null&&(s=d),l.baseState=s,l.firstBaseUpdate=c,l.lastBaseUpdate=m,t=l.shared.interleaved,t!==null){l=t;do o|=l.lane,l=l.next;while(l!==t)}else i===null&&(l.shared.lanes=0);Gt|=o,e.lanes=o,e.memoizedState=d}}function uu(e,t,n){if(e=t.effects,t.effects=null,e!==null)for(t=0;tn?n:4,e(!0);var r=gi.transition;gi.transition={};try{e(!1),t()}finally{F=n,gi.transition=r}}function kc(){return Ue().memoizedState}function Cp(e,t,n){var r=Nt(e);if(n={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null},Ec(e))Cc(t,n);else if(n=lc(e,t,n,r),n!==null){var l=pe();We(n,e,r,l),Nc(n,t,r)}}function Np(e,t,n){var r=Nt(e),l={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null};if(Ec(e))Cc(t,l);else{var i=e.alternate;if(e.lanes===0&&(i===null||i.lanes===0)&&(i=t.lastRenderedReducer,i!==null))try{var o=t.lastRenderedState,u=i(o,n);if(l.hasEagerState=!0,l.eagerState=u,He(u,o)){var s=t.interleaved;s===null?(l.next=l,Jo(t)):(l.next=s.next,s.next=l),t.interleaved=l;return}}catch{}finally{}n=lc(e,t,l,r),n!==null&&(l=pe(),We(n,e,r,l),Nc(n,t,r))}}function Ec(e){var t=e.alternate;return e===K||t!==null&&t===K}function Cc(e,t){Zn=kl=!0;var n=e.pending;n===null?t.next=t:(t.next=n.next,n.next=t),e.pending=t}function Nc(e,t,n){if(n&4194240){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,Mo(e,n)}}var El={readContext:Ie,useCallback:ue,useContext:ue,useEffect:ue,useImperativeHandle:ue,useInsertionEffect:ue,useLayoutEffect:ue,useMemo:ue,useReducer:ue,useRef:ue,useState:ue,useDebugValue:ue,useDeferredValue:ue,useTransition:ue,useMutableSource:ue,useSyncExternalStore:ue,useId:ue,unstable_isNewReconciler:!1},jp={readContext:Ie,useCallback:function(e,t){return Ke().memoizedState=[e,t===void 0?null:t],e},useContext:Ie,useEffect:cu,useImperativeHandle:function(e,t,n){return n=n!=null?n.concat([e]):null,br(4194308,4,gc.bind(null,t,e),n)},useLayoutEffect:function(e,t){return br(4194308,4,e,t)},useInsertionEffect:function(e,t){return br(4,2,e,t)},useMemo:function(e,t){var n=Ke();return t=t===void 0?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=Ke();return t=n!==void 0?n(t):t,r.memoizedState=r.baseState=t,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:e,lastRenderedState:t},r.queue=e,e=e.dispatch=Cp.bind(null,K,e),[r.memoizedState,e]},useRef:function(e){var t=Ke();return e={current:e},t.memoizedState=e},useState:au,useDebugValue:is,useDeferredValue:function(e){return Ke().memoizedState=e},useTransition:function(){var e=au(!1),t=e[0];return e=Ep.bind(null,e[1]),Ke().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,n){var r=K,l=Ke();if(H){if(n===void 0)throw Error(E(407));n=n()}else{if(n=t(),re===null)throw Error(E(349));Kt&30||ac(r,t,n)}l.memoizedState=n;var i={value:n,getSnapshot:t};return l.queue=i,cu(fc.bind(null,r,i,e),[e]),r.flags|=2048,vr(9,cc.bind(null,r,i,n,t),void 0,null),n},useId:function(){var e=Ke(),t=re.identifierPrefix;if(H){var n=et,r=be;n=(r&~(1<<32-$e(r)-1)).toString(32)+n,t=":"+t+"R"+n,n=hr++,0<\/script>",e=e.removeChild(e.firstChild)):typeof r.is=="string"?e=o.createElement(n,{is:r.is}):(e=o.createElement(n),n==="select"&&(o=e,r.multiple?o.multiple=!0:r.size&&(o.size=r.size))):e=o.createElementNS(e,n),e[Ge]=t,e[fr]=r,Uc(e,t,!1,!1),t.stateNode=e;e:{switch(o=Mi(n,r),n){case"dialog":$("cancel",e),$("close",e),l=r;break;case"iframe":case"object":case"embed":$("load",e),l=r;break;case"video":case"audio":for(l=0;ljn&&(t.flags|=128,r=!0,Bn(i,!1),t.lanes=4194304)}else{if(!r)if(e=Sl(o),e!==null){if(t.flags|=128,r=!0,n=e.updateQueue,n!==null&&(t.updateQueue=n,t.flags|=4),Bn(i,!0),i.tail===null&&i.tailMode==="hidden"&&!o.alternate&&!H)return ae(t),null}else 2*Z()-i.renderingStartTime>jn&&n!==1073741824&&(t.flags|=128,r=!0,Bn(i,!1),t.lanes=4194304);i.isBackwards?(o.sibling=t.child,t.child=o):(n=i.last,n!==null?n.sibling=o:t.child=o,i.last=o)}return i.tail!==null?(t=i.tail,i.rendering=t,i.tail=t.sibling,i.renderingStartTime=Z(),t.sibling=null,n=Q.current,V(Q,r?n&1|2:n&1),t):(ae(t),null);case 22:case 23:return fs(),r=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==r&&(t.flags|=8192),r&&t.mode&1?Ce&1073741824&&(ae(t),t.subtreeFlags&6&&(t.flags|=8192)):ae(t),null;case 24:return null;case 25:return null}throw Error(E(156,t.tag))}function Ip(e,t){switch(Qo(t),t.tag){case 1:return we(t.type)&&hl(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return Cn(),W(ye),W(fe),es(),e=t.flags,e&65536&&!(e&128)?(t.flags=e&-65537|128,t):null;case 5:return bo(t),null;case 13:if(W(Q),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(E(340));kn()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return W(Q),null;case 4:return Cn(),null;case 10:return Yo(t.type._context),null;case 22:case 23:return fs(),null;case 24:return null;default:return null}}var $r=!1,ce=!1,Up=typeof WeakSet=="function"?WeakSet:Set,L=null;function dn(e,t){var n=e.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(r){X(e,t,r)}else n.current=null}function ao(e,t,n){try{n()}catch(r){X(e,t,r)}}var Su=!1;function Mp(e,t){if(Ki=cl,e=$a(),Wo(e)){if("selectionStart"in e)var n={start:e.selectionStart,end:e.selectionEnd};else e:{n=(n=e.ownerDocument)&&n.defaultView||window;var r=n.getSelection&&n.getSelection();if(r&&r.rangeCount!==0){n=r.anchorNode;var l=r.anchorOffset,i=r.focusNode;r=r.focusOffset;try{n.nodeType,i.nodeType}catch{n=null;break e}var o=0,u=-1,s=-1,c=0,m=0,d=e,v=null;t:for(;;){for(var x;d!==n||l!==0&&d.nodeType!==3||(u=o+l),d!==i||r!==0&&d.nodeType!==3||(s=o+r),d.nodeType===3&&(o+=d.nodeValue.length),(x=d.firstChild)!==null;)v=d,d=x;for(;;){if(d===e)break t;if(v===n&&++c===l&&(u=o),v===i&&++m===r&&(s=o),(x=d.nextSibling)!==null)break;d=v,v=d.parentNode}d=x}n=u===-1||s===-1?null:{start:u,end:s}}else n=null}n=n||{start:0,end:0}}else n=null;for(Gi={focusedElem:e,selectionRange:n},cl=!1,L=t;L!==null;)if(t=L,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,L=e;else for(;L!==null;){t=L;try{var g=t.alternate;if(t.flags&1024)switch(t.tag){case 0:case 11:case 15:break;case 1:if(g!==null){var S=g.memoizedProps,k=g.memoizedState,p=t.stateNode,f=p.getSnapshotBeforeUpdate(t.elementType===t.type?S:Ae(t.type,S),k);p.__reactInternalSnapshotBeforeUpdate=f}break;case 3:var h=t.stateNode.containerInfo;h.nodeType===1?h.textContent="":h.nodeType===9&&h.documentElement&&h.removeChild(h.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(E(163))}}catch(y){X(t,t.return,y)}if(e=t.sibling,e!==null){e.return=t.return,L=e;break}L=t.return}return g=Su,Su=!1,g}function qn(e,t,n){var r=t.updateQueue;if(r=r!==null?r.lastEffect:null,r!==null){var l=r=r.next;do{if((l.tag&e)===e){var i=l.destroy;l.destroy=void 0,i!==void 0&&ao(t,n,i)}l=l.next}while(l!==r)}}function Bl(e,t){if(t=t.updateQueue,t=t!==null?t.lastEffect:null,t!==null){var n=t=t.next;do{if((n.tag&e)===e){var r=n.create;n.destroy=r()}n=n.next}while(n!==t)}}function co(e){var t=e.ref;if(t!==null){var n=e.stateNode;switch(e.tag){case 5:e=n;break;default:e=n}typeof t=="function"?t(e):t.current=e}}function Fc(e){var t=e.alternate;t!==null&&(e.alternate=null,Fc(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[Ge],delete t[fr],delete t[Ji],delete t[yp],delete t[wp])),e.stateNode=null,e.return=null,e.dependencies=null,e.memoizedProps=null,e.memoizedState=null,e.pendingProps=null,e.stateNode=null,e.updateQueue=null}function Ac(e){return e.tag===5||e.tag===3||e.tag===4}function ku(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||Ac(e.return))return null;e=e.return}for(e.sibling.return=e.return,e=e.sibling;e.tag!==5&&e.tag!==6&&e.tag!==18;){if(e.flags&2||e.child===null||e.tag===4)continue e;e.child.return=e,e=e.child}if(!(e.flags&2))return e.stateNode}}function fo(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.nodeType===8?n.parentNode.insertBefore(e,t):n.insertBefore(e,t):(n.nodeType===8?(t=n.parentNode,t.insertBefore(e,n)):(t=n,t.appendChild(e)),n=n._reactRootContainer,n!=null||t.onclick!==null||(t.onclick=pl));else if(r!==4&&(e=e.child,e!==null))for(fo(e,t,n),e=e.sibling;e!==null;)fo(e,t,n),e=e.sibling}function po(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.insertBefore(e,t):n.appendChild(e);else if(r!==4&&(e=e.child,e!==null))for(po(e,t,n),e=e.sibling;e!==null;)po(e,t,n),e=e.sibling}var le=null,Be=!1;function ft(e,t,n){for(n=n.child;n!==null;)Bc(e,t,n),n=n.sibling}function Bc(e,t,n){if(Xe&&typeof Xe.onCommitFiberUnmount=="function")try{Xe.onCommitFiberUnmount(zl,n)}catch{}switch(n.tag){case 5:ce||dn(n,t);case 6:var r=le,l=Be;le=null,ft(e,t,n),le=r,Be=l,le!==null&&(Be?(e=le,n=n.stateNode,e.nodeType===8?e.parentNode.removeChild(n):e.removeChild(n)):le.removeChild(n.stateNode));break;case 18:le!==null&&(Be?(e=le,n=n.stateNode,e.nodeType===8?hi(e.parentNode,n):e.nodeType===1&&hi(e,n),or(e)):hi(le,n.stateNode));break;case 4:r=le,l=Be,le=n.stateNode.containerInfo,Be=!0,ft(e,t,n),le=r,Be=l;break;case 0:case 11:case 14:case 15:if(!ce&&(r=n.updateQueue,r!==null&&(r=r.lastEffect,r!==null))){l=r=r.next;do{var i=l,o=i.destroy;i=i.tag,o!==void 0&&(i&2||i&4)&&ao(n,t,o),l=l.next}while(l!==r)}ft(e,t,n);break;case 1:if(!ce&&(dn(n,t),r=n.stateNode,typeof r.componentWillUnmount=="function"))try{r.props=n.memoizedProps,r.state=n.memoizedState,r.componentWillUnmount()}catch(u){X(n,t,u)}ft(e,t,n);break;case 21:ft(e,t,n);break;case 22:n.mode&1?(ce=(r=ce)||n.memoizedState!==null,ft(e,t,n),ce=r):ft(e,t,n);break;default:ft(e,t,n)}}function Eu(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var n=e.stateNode;n===null&&(n=e.stateNode=new Up),t.forEach(function(r){var l=Qp.bind(null,e,r);n.has(r)||(n.add(r),r.then(l,l))})}}function Fe(e,t){var n=t.deletions;if(n!==null)for(var r=0;rl&&(l=o),r&=~i}if(r=l,r=Z()-r,r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*Fp(r/1960))-r,10e?16:e,gt===null)var r=!1;else{if(e=gt,gt=null,jl=0,M&6)throw Error(E(331));var l=M;for(M|=4,L=e.current;L!==null;){var i=L,o=i.child;if(L.flags&16){var u=i.deletions;if(u!==null){for(var s=0;sZ()-as?$t(e,0):us|=n),xe(e,t)}function Xc(e,t){t===0&&(e.mode&1?(t=Or,Or<<=1,!(Or&130023424)&&(Or=4194304)):t=1);var n=pe();e=lt(e,t),e!==null&&(Sr(e,t,n),xe(e,n))}function Hp(e){var t=e.memoizedState,n=0;t!==null&&(n=t.retryLane),Xc(e,n)}function Qp(e,t){var n=0;switch(e.tag){case 13:var r=e.stateNode,l=e.memoizedState;l!==null&&(n=l.retryLane);break;case 19:r=e.stateNode;break;default:throw Error(E(314))}r!==null&&r.delete(t),Xc(e,n)}var Yc;Yc=function(e,t,n){if(e!==null)if(e.memoizedProps!==t.pendingProps||ye.current)ge=!0;else{if(!(e.lanes&n)&&!(t.flags&128))return ge=!1,zp(e,t,n);ge=!!(e.flags&131072)}else ge=!1,H&&t.flags&1048576&&ba(t,gl,t.index);switch(t.lanes=0,t.tag){case 2:var r=t.type;el(e,t),e=t.pendingProps;var l=Sn(t,fe.current);yn(t,n),l=ns(null,t,r,e,l,n);var i=rs();return t.flags|=1,typeof l=="object"&&l!==null&&typeof l.render=="function"&&l.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,we(r)?(i=!0,ml(t)):i=!1,t.memoizedState=l.state!==null&&l.state!==void 0?l.state:null,Zo(t),l.updater=Al,t.stateNode=l,l._reactInternals=t,no(t,r,e,n),t=io(null,t,r,!0,i,n)):(t.tag=0,H&&i&&Ho(t),de(null,t,l,n),t=t.child),t;case 16:r=t.elementType;e:{switch(el(e,t),e=t.pendingProps,l=r._init,r=l(r._payload),t.type=r,l=t.tag=Gp(r),e=Ae(r,e),l){case 0:t=lo(null,t,r,e,n);break e;case 1:t=yu(null,t,r,e,n);break e;case 11:t=vu(null,t,r,e,n);break e;case 14:t=gu(null,t,r,Ae(r.type,e),n);break e}throw Error(E(306,r,""))}return t;case 0:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:Ae(r,l),lo(e,t,r,l,n);case 1:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:Ae(r,l),yu(e,t,r,l,n);case 3:e:{if(zc(t),e===null)throw Error(E(387));r=t.pendingProps,i=t.memoizedState,l=i.element,ic(e,t),xl(t,r,null,n);var o=t.memoizedState;if(r=o.element,i.isDehydrated)if(i={element:r,isDehydrated:!1,cache:o.cache,pendingSuspenseBoundaries:o.pendingSuspenseBoundaries,transitions:o.transitions},t.updateQueue.baseState=i,t.memoizedState=i,t.flags&256){l=Nn(Error(E(423)),t),t=wu(e,t,r,n,l);break e}else if(r!==l){l=Nn(Error(E(424)),t),t=wu(e,t,r,n,l);break e}else for(Ne=kt(t.stateNode.containerInfo.firstChild),je=t,H=!0,Ve=null,n=rc(t,null,r,n),t.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(kn(),r===l){t=it(e,t,n);break e}de(e,t,r,n)}t=t.child}return t;case 5:return oc(t),e===null&&bi(t),r=t.type,l=t.pendingProps,i=e!==null?e.memoizedProps:null,o=l.children,Xi(r,l)?o=null:i!==null&&Xi(r,i)&&(t.flags|=32),Tc(e,t),de(e,t,o,n),t.child;case 6:return e===null&&bi(t),null;case 13:return Oc(e,t,n);case 4:return qo(t,t.stateNode.containerInfo),r=t.pendingProps,e===null?t.child=En(t,null,r,n):de(e,t,r,n),t.child;case 11:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:Ae(r,l),vu(e,t,r,l,n);case 7:return de(e,t,t.pendingProps,n),t.child;case 8:return de(e,t,t.pendingProps.children,n),t.child;case 12:return de(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,l=t.pendingProps,i=t.memoizedProps,o=l.value,V(yl,r._currentValue),r._currentValue=o,i!==null)if(He(i.value,o)){if(i.children===l.children&&!ye.current){t=it(e,t,n);break e}}else for(i=t.child,i!==null&&(i.return=t);i!==null;){var u=i.dependencies;if(u!==null){o=i.child;for(var s=u.firstContext;s!==null;){if(s.context===r){if(i.tag===1){s=tt(-1,n&-n),s.tag=2;var c=i.updateQueue;if(c!==null){c=c.shared;var m=c.pending;m===null?s.next=s:(s.next=m.next,m.next=s),c.pending=s}}i.lanes|=n,s=i.alternate,s!==null&&(s.lanes|=n),eo(i.return,n,t),u.lanes|=n;break}s=s.next}}else if(i.tag===10)o=i.type===t.type?null:i.child;else if(i.tag===18){if(o=i.return,o===null)throw Error(E(341));o.lanes|=n,u=o.alternate,u!==null&&(u.lanes|=n),eo(o,n,t),o=i.sibling}else o=i.child;if(o!==null)o.return=i;else for(o=i;o!==null;){if(o===t){o=null;break}if(i=o.sibling,i!==null){i.return=o.return,o=i;break}o=o.return}i=o}de(e,t,l.children,n),t=t.child}return t;case 9:return l=t.type,r=t.pendingProps.children,yn(t,n),l=Ie(l),r=r(l),t.flags|=1,de(e,t,r,n),t.child;case 14:return r=t.type,l=Ae(r,t.pendingProps),l=Ae(r.type,l),gu(e,t,r,l,n);case 15:return Lc(e,t,t.type,t.pendingProps,n);case 17:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:Ae(r,l),el(e,t),t.tag=1,we(r)?(e=!0,ml(t)):e=!1,yn(t,n),jc(t,r,l),no(t,r,l,n),io(null,t,r,!0,e,n);case 19:return Ic(e,t,n);case 22:return Rc(e,t,n)}throw Error(E(156,t.tag))};function Jc(e,t){return Ea(e,t)}function Kp(e,t,n,r){this.tag=e,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=t,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=r,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function ze(e,t,n,r){return new Kp(e,t,n,r)}function ps(e){return e=e.prototype,!(!e||!e.isReactComponent)}function Gp(e){if(typeof e=="function")return ps(e)?1:0;if(e!=null){if(e=e.$$typeof,e===zo)return 11;if(e===Oo)return 14}return 2}function jt(e,t){var n=e.alternate;return n===null?(n=ze(e.tag,t,e.key,e.mode),n.elementType=e.elementType,n.type=e.type,n.stateNode=e.stateNode,n.alternate=e,e.alternate=n):(n.pendingProps=t,n.type=e.type,n.flags=0,n.subtreeFlags=0,n.deletions=null),n.flags=e.flags&14680064,n.childLanes=e.childLanes,n.lanes=e.lanes,n.child=e.child,n.memoizedProps=e.memoizedProps,n.memoizedState=e.memoizedState,n.updateQueue=e.updateQueue,t=e.dependencies,n.dependencies=t===null?null:{lanes:t.lanes,firstContext:t.firstContext},n.sibling=e.sibling,n.index=e.index,n.ref=e.ref,n}function rl(e,t,n,r,l,i){var o=2;if(r=e,typeof e=="function")ps(e)&&(o=1);else if(typeof e=="string")o=5;else e:switch(e){case nn:return Wt(n.children,l,i,t);case To:o=8,l|=8;break;case ji:return e=ze(12,n,t,l|2),e.elementType=ji,e.lanes=i,e;case Pi:return e=ze(13,n,t,l),e.elementType=Pi,e.lanes=i,e;case _i:return e=ze(19,n,t,l),e.elementType=_i,e.lanes=i,e;case oa:return $l(n,l,i,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case la:o=10;break e;case ia:o=9;break e;case zo:o=11;break e;case Oo:o=14;break e;case dt:o=16,r=null;break e}throw Error(E(130,e==null?e:typeof e,""))}return t=ze(o,n,t,l),t.elementType=e,t.type=r,t.lanes=i,t}function Wt(e,t,n,r){return e=ze(7,e,r,t),e.lanes=n,e}function $l(e,t,n,r){return e=ze(22,e,r,t),e.elementType=oa,e.lanes=n,e.stateNode={isHidden:!1},e}function ki(e,t,n){return e=ze(6,e,null,t),e.lanes=n,e}function Ei(e,t,n){return t=ze(4,e.children!==null?e.children:[],e.key,t),t.lanes=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function Xp(e,t,n,r,l){this.tag=t,this.containerInfo=e,this.finishedWork=this.pingCache=this.current=this.pendingChildren=null,this.timeoutHandle=-1,this.callbackNode=this.pendingContext=this.context=null,this.callbackPriority=0,this.eventTimes=ri(0),this.expirationTimes=ri(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=ri(0),this.identifierPrefix=r,this.onRecoverableError=l,this.mutableSourceEagerHydrationData=null}function hs(e,t,n,r,l,i,o,u,s){return e=new Xp(e,t,n,u,s),t===1?(t=1,i===!0&&(t|=8)):t=0,i=ze(3,null,null,t),e.current=i,i.stateNode=e,i.memoizedState={element:r,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},Zo(i),e}function Yp(e,t,n){var r=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(ef)}catch(e){console.error(e)}}ef(),ea.exports=_e;var eh=ea.exports,tf,Tu=eh;tf=Tu.createRoot,Tu.hydrateRoot;/** - * @remix-run/router v1.23.2 - * - * Copyright (c) Remix Software Inc. - * - * This source code is licensed under the MIT license found in the - * LICENSE.md file in the root directory of this source tree. - * - * @license MIT - */function yr(){return yr=Object.assign?Object.assign.bind():function(e){for(var t=1;t"u")throw new Error(t)}function ys(e,t){if(!e){typeof console<"u"&&console.warn(t);try{throw new Error(t)}catch{}}}function nh(){return Math.random().toString(36).substr(2,8)}function Ou(e,t){return{usr:e.state,key:e.key,idx:t}}function yo(e,t,n,r){return n===void 0&&(n=null),yr({pathname:typeof e=="string"?e:e.pathname,search:"",hash:""},typeof t=="string"?Tn(t):t,{state:n,key:t&&t.key||r||nh()})}function Ll(e){let{pathname:t="/",search:n="",hash:r=""}=e;return n&&n!=="?"&&(t+=n.charAt(0)==="?"?n:"?"+n),r&&r!=="#"&&(t+=r.charAt(0)==="#"?r:"#"+r),t}function Tn(e){let t={};if(e){let n=e.indexOf("#");n>=0&&(t.hash=e.substr(n),e=e.substr(0,n));let r=e.indexOf("?");r>=0&&(t.search=e.substr(r),e=e.substr(0,r)),e&&(t.pathname=e)}return t}function rh(e,t,n,r){r===void 0&&(r={});let{window:l=document.defaultView,v5Compat:i=!1}=r,o=l.history,u=yt.Pop,s=null,c=m();c==null&&(c=0,o.replaceState(yr({},o.state,{idx:c}),""));function m(){return(o.state||{idx:null}).idx}function d(){u=yt.Pop;let k=m(),p=k==null?null:k-c;c=k,s&&s({action:u,location:S.location,delta:p})}function v(k,p){u=yt.Push;let f=yo(S.location,k,p);c=m()+1;let h=Ou(f,c),y=S.createHref(f);try{o.pushState(h,"",y)}catch(C){if(C instanceof DOMException&&C.name==="DataCloneError")throw C;l.location.assign(y)}i&&s&&s({action:u,location:S.location,delta:1})}function x(k,p){u=yt.Replace;let f=yo(S.location,k,p);c=m();let h=Ou(f,c),y=S.createHref(f);o.replaceState(h,"",y),i&&s&&s({action:u,location:S.location,delta:0})}function g(k){let p=l.location.origin!=="null"?l.location.origin:l.location.href,f=typeof k=="string"?k:Ll(k);return f=f.replace(/ $/,"%20"),Y(p,"No window.location.(origin|href) available to create URL for href: "+f),new URL(f,p)}let S={get action(){return u},get location(){return e(l,o)},listen(k){if(s)throw new Error("A history only accepts one active listener");return l.addEventListener(zu,d),s=k,()=>{l.removeEventListener(zu,d),s=null}},createHref(k){return t(l,k)},createURL:g,encodeLocation(k){let p=g(k);return{pathname:p.pathname,search:p.search,hash:p.hash}},push:v,replace:x,go(k){return o.go(k)}};return S}var Iu;(function(e){e.data="data",e.deferred="deferred",e.redirect="redirect",e.error="error"})(Iu||(Iu={}));function lh(e,t,n){return n===void 0&&(n="/"),ih(e,t,n)}function ih(e,t,n,r){let l=typeof t=="string"?Tn(t):t,i=Pn(l.pathname||"/",n);if(i==null)return null;let o=nf(e);oh(o);let u=null;for(let s=0;u==null&&s{let s={relativePath:u===void 0?i.path||"":u,caseSensitive:i.caseSensitive===!0,childrenIndex:o,route:i};s.relativePath.startsWith("/")&&(Y(s.relativePath.startsWith(r),'Absolute route path "'+s.relativePath+'" nested under path '+('"'+r+'" is not valid. An absolute child route path ')+"must start with the combined path of all its parent routes."),s.relativePath=s.relativePath.slice(r.length));let c=Pt([r,s.relativePath]),m=n.concat(s);i.children&&i.children.length>0&&(Y(i.index!==!0,"Index routes must not have child routes. Please remove "+('all child routes from route path "'+c+'".')),nf(i.children,t,m,c)),!(i.path==null&&!i.index)&&t.push({path:c,score:ph(c,i.index),routesMeta:m})};return e.forEach((i,o)=>{var u;if(i.path===""||!((u=i.path)!=null&&u.includes("?")))l(i,o);else for(let s of rf(i.path))l(i,o,s)}),t}function rf(e){let t=e.split("/");if(t.length===0)return[];let[n,...r]=t,l=n.endsWith("?"),i=n.replace(/\?$/,"");if(r.length===0)return l?[i,""]:[i];let o=rf(r.join("/")),u=[];return u.push(...o.map(s=>s===""?i:[i,s].join("/"))),l&&u.push(...o),u.map(s=>e.startsWith("/")&&s===""?"/":s)}function oh(e){e.sort((t,n)=>t.score!==n.score?n.score-t.score:hh(t.routesMeta.map(r=>r.childrenIndex),n.routesMeta.map(r=>r.childrenIndex)))}const sh=/^:[\w-]+$/,uh=3,ah=2,ch=1,fh=10,dh=-2,Uu=e=>e==="*";function ph(e,t){let n=e.split("/"),r=n.length;return n.some(Uu)&&(r+=dh),t&&(r+=ah),n.filter(l=>!Uu(l)).reduce((l,i)=>l+(sh.test(i)?uh:i===""?ch:fh),r)}function hh(e,t){return e.length===t.length&&e.slice(0,-1).every((r,l)=>r===t[l])?e[e.length-1]-t[t.length-1]:0}function mh(e,t,n){let{routesMeta:r}=e,l={},i="/",o=[];for(let u=0;u{let{paramName:v,isOptional:x}=m;if(v==="*"){let S=u[d]||"";o=i.slice(0,i.length-S.length).replace(/(.)\/+$/,"$1")}const g=u[d];return x&&!g?c[v]=void 0:c[v]=(g||"").replace(/%2F/g,"/"),c},{}),pathname:i,pathnameBase:o,pattern:e}}function vh(e,t,n){t===void 0&&(t=!1),n===void 0&&(n=!0),ys(e==="*"||!e.endsWith("*")||e.endsWith("/*"),'Route path "'+e+'" will be treated as if it were '+('"'+e.replace(/\*$/,"/*")+'" because the `*` character must ')+"always follow a `/` in the pattern. To get rid of this warning, "+('please change the route path to "'+e.replace(/\*$/,"/*")+'".'));let r=[],l="^"+e.replace(/\/*\*?$/,"").replace(/^\/*/,"/").replace(/[\\.*+^${}|()[\]]/g,"\\$&").replace(/\/:([\w-]+)(\?)?/g,(o,u,s)=>(r.push({paramName:u,isOptional:s!=null}),s?"/?([^\\/]+)?":"/([^\\/]+)"));return e.endsWith("*")?(r.push({paramName:"*"}),l+=e==="*"||e==="/*"?"(.*)$":"(?:\\/(.+)|\\/*)$"):n?l+="\\/*$":e!==""&&e!=="/"&&(l+="(?:(?=\\/|$))"),[new RegExp(l,t?void 0:"i"),r]}function gh(e){try{return e.split("/").map(t=>decodeURIComponent(t).replace(/\//g,"%2F")).join("/")}catch(t){return ys(!1,'The URL path "'+e+'" could not be decoded because it is is a malformed URL segment. This is probably due to a bad percent '+("encoding ("+t+").")),e}}function Pn(e,t){if(t==="/")return e;if(!e.toLowerCase().startsWith(t.toLowerCase()))return null;let n=t.endsWith("/")?t.length-1:t.length,r=e.charAt(n);return r&&r!=="/"?null:e.slice(n)||"/"}const yh=/^(?:[a-z][a-z0-9+.-]*:|\/\/)/i,wh=e=>yh.test(e);function xh(e,t){t===void 0&&(t="/");let{pathname:n,search:r="",hash:l=""}=typeof e=="string"?Tn(e):e,i;if(n)if(wh(n))i=n;else{if(n.includes("//")){let o=n;n=n.replace(/\/\/+/g,"/"),ys(!1,"Pathnames cannot have embedded double slashes - normalizing "+(o+" -> "+n))}n.startsWith("/")?i=Mu(n.substring(1),"/"):i=Mu(n,t)}else i=t;return{pathname:i,search:Eh(r),hash:Ch(l)}}function Mu(e,t){let n=t.replace(/\/+$/,"").split("/");return e.split("/").forEach(l=>{l===".."?n.length>1&&n.pop():l!=="."&&n.push(l)}),n.length>1?n.join("/"):"/"}function Ci(e,t,n,r){return"Cannot include a '"+e+"' character in a manually specified "+("`to."+t+"` field ["+JSON.stringify(r)+"]. Please separate it out to the ")+("`to."+n+"` field. Alternatively you may provide the full path as ")+'a string in and the router will parse it for you.'}function Sh(e){return e.filter((t,n)=>n===0||t.route.path&&t.route.path.length>0)}function lf(e,t){let n=Sh(e);return t?n.map((r,l)=>l===n.length-1?r.pathname:r.pathnameBase):n.map(r=>r.pathnameBase)}function of(e,t,n,r){r===void 0&&(r=!1);let l;typeof e=="string"?l=Tn(e):(l=yr({},e),Y(!l.pathname||!l.pathname.includes("?"),Ci("?","pathname","search",l)),Y(!l.pathname||!l.pathname.includes("#"),Ci("#","pathname","hash",l)),Y(!l.search||!l.search.includes("#"),Ci("#","search","hash",l)));let i=e===""||l.pathname==="",o=i?"/":l.pathname,u;if(o==null)u=n;else{let d=t.length-1;if(!r&&o.startsWith("..")){let v=o.split("/");for(;v[0]==="..";)v.shift(),d-=1;l.pathname=v.join("/")}u=d>=0?t[d]:"/"}let s=xh(l,u),c=o&&o!=="/"&&o.endsWith("/"),m=(i||o===".")&&n.endsWith("/");return!s.pathname.endsWith("/")&&(c||m)&&(s.pathname+="/"),s}const Pt=e=>e.join("/").replace(/\/\/+/g,"/"),kh=e=>e.replace(/\/+$/,"").replace(/^\/*/,"/"),Eh=e=>!e||e==="?"?"":e.startsWith("?")?e:"?"+e,Ch=e=>!e||e==="#"?"":e.startsWith("#")?e:"#"+e;function Nh(e){return e!=null&&typeof e.status=="number"&&typeof e.statusText=="string"&&typeof e.internal=="boolean"&&"data"in e}const sf=["post","put","patch","delete"];new Set(sf);const jh=["get",...sf];new Set(jh);/** - * React Router v6.30.3 - * - * Copyright (c) Remix Software Inc. - * - * This source code is licensed under the MIT license found in the - * LICENSE.md file in the root directory of this source tree. - * - * @license MIT - */function wr(){return wr=Object.assign?Object.assign.bind():function(e){for(var t=1;t{u.current=!0}),w.useCallback(function(c,m){if(m===void 0&&(m={}),!u.current)return;if(typeof c=="number"){r.go(c);return}let d=of(c,JSON.parse(o),i,m.relative==="path");e==null&&t!=="/"&&(d.pathname=d.pathname==="/"?t:Pt([t,d.pathname])),(m.replace?r.replace:r.push)(d,m.state,m)},[t,r,o,i,e])}function Lh(){let{matches:e}=w.useContext(It),t=e[e.length-1];return t?t.params:{}}function Yl(e,t){let{relative:n}=t===void 0?{}:t,{future:r}=w.useContext(Ot),{matches:l}=w.useContext(It),{pathname:i}=zn(),o=JSON.stringify(lf(l,r.v7_relativeSplatPath));return w.useMemo(()=>of(e,JSON.parse(o),i,n==="path"),[e,o,i,n])}function Rh(e,t){return Th(e,t)}function Th(e,t,n,r){Nr()||Y(!1);let{navigator:l}=w.useContext(Ot),{matches:i}=w.useContext(It),o=i[i.length-1],u=o?o.params:{};o&&o.pathname;let s=o?o.pathnameBase:"/";o&&o.route;let c=zn(),m;if(t){var d;let k=typeof t=="string"?Tn(t):t;s==="/"||(d=k.pathname)!=null&&d.startsWith(s)||Y(!1),m=k}else m=c;let v=m.pathname||"/",x=v;if(s!=="/"){let k=s.replace(/^\//,"").split("/");x="/"+v.replace(/^\//,"").split("/").slice(k.length).join("/")}let g=lh(e,{pathname:x}),S=Mh(g&&g.map(k=>Object.assign({},k,{params:Object.assign({},u,k.params),pathname:Pt([s,l.encodeLocation?l.encodeLocation(k.pathname).pathname:k.pathname]),pathnameBase:k.pathnameBase==="/"?s:Pt([s,l.encodeLocation?l.encodeLocation(k.pathnameBase).pathname:k.pathnameBase])})),i,n,r);return t&&S?w.createElement(Xl.Provider,{value:{location:wr({pathname:"/",search:"",hash:"",state:null,key:"default"},m),navigationType:yt.Pop}},S):S}function zh(){let e=Bh(),t=Nh(e)?e.status+" "+e.statusText:e instanceof Error?e.message:JSON.stringify(e),n=e instanceof Error?e.stack:null,l={padding:"0.5rem",backgroundColor:"rgba(200,200,200, 0.5)"};return w.createElement(w.Fragment,null,w.createElement("h2",null,"Unexpected Application Error!"),w.createElement("h3",{style:{fontStyle:"italic"}},t),n?w.createElement("pre",{style:l},n):null,null)}const Oh=w.createElement(zh,null);class Ih extends w.Component{constructor(t){super(t),this.state={location:t.location,revalidation:t.revalidation,error:t.error}}static getDerivedStateFromError(t){return{error:t}}static getDerivedStateFromProps(t,n){return n.location!==t.location||n.revalidation!=="idle"&&t.revalidation==="idle"?{error:t.error,location:t.location,revalidation:t.revalidation}:{error:t.error!==void 0?t.error:n.error,location:n.location,revalidation:t.revalidation||n.revalidation}}componentDidCatch(t,n){console.error("React Router caught the following error during render",t,n)}render(){return this.state.error!==void 0?w.createElement(It.Provider,{value:this.props.routeContext},w.createElement(af.Provider,{value:this.state.error,children:this.props.component})):this.props.children}}function Uh(e){let{routeContext:t,match:n,children:r}=e,l=w.useContext(Gl);return l&&l.static&&l.staticContext&&(n.route.errorElement||n.route.ErrorBoundary)&&(l.staticContext._deepestRenderedBoundaryId=n.route.id),w.createElement(It.Provider,{value:t},r)}function Mh(e,t,n,r){var l;if(t===void 0&&(t=[]),n===void 0&&(n=null),r===void 0&&(r=null),e==null){var i;if(!n)return null;if(n.errors)e=n.matches;else if((i=r)!=null&&i.v7_partialHydration&&t.length===0&&!n.initialized&&n.matches.length>0)e=n.matches;else return null}let o=e,u=(l=n)==null?void 0:l.errors;if(u!=null){let m=o.findIndex(d=>d.route.id&&(u==null?void 0:u[d.route.id])!==void 0);m>=0||Y(!1),o=o.slice(0,Math.min(o.length,m+1))}let s=!1,c=-1;if(n&&r&&r.v7_partialHydration)for(let m=0;m=0?o=o.slice(0,c+1):o=[o[0]];break}}}return o.reduceRight((m,d,v)=>{let x,g=!1,S=null,k=null;n&&(x=u&&d.route.id?u[d.route.id]:void 0,S=d.route.errorElement||Oh,s&&(c<0&&v===0?($h("route-fallback"),g=!0,k=null):c===v&&(g=!0,k=d.route.hydrateFallbackElement||null)));let p=t.concat(o.slice(0,v+1)),f=()=>{let h;return x?h=S:g?h=k:d.route.Component?h=w.createElement(d.route.Component,null):d.route.element?h=d.route.element:h=m,w.createElement(Uh,{match:d,routeContext:{outlet:m,matches:p,isDataRoute:n!=null},children:h})};return n&&(d.route.ErrorBoundary||d.route.errorElement||v===0)?w.createElement(Ih,{location:n.location,revalidation:n.revalidation,component:S,error:x,children:f(),routeContext:{outlet:null,matches:p,isDataRoute:!0}}):f()},null)}var df=function(e){return e.UseBlocker="useBlocker",e.UseRevalidator="useRevalidator",e.UseNavigateStable="useNavigate",e}(df||{}),pf=function(e){return e.UseBlocker="useBlocker",e.UseLoaderData="useLoaderData",e.UseActionData="useActionData",e.UseRouteError="useRouteError",e.UseNavigation="useNavigation",e.UseRouteLoaderData="useRouteLoaderData",e.UseMatches="useMatches",e.UseRevalidator="useRevalidator",e.UseNavigateStable="useNavigate",e.UseRouteId="useRouteId",e}(pf||{});function Dh(e){let t=w.useContext(Gl);return t||Y(!1),t}function Fh(e){let t=w.useContext(uf);return t||Y(!1),t}function Ah(e){let t=w.useContext(It);return t||Y(!1),t}function hf(e){let t=Ah(),n=t.matches[t.matches.length-1];return n.route.id||Y(!1),n.route.id}function Bh(){var e;let t=w.useContext(af),n=Fh(),r=hf();return t!==void 0?t:(e=n.errors)==null?void 0:e[r]}function Vh(){let{router:e}=Dh(df.UseNavigateStable),t=hf(pf.UseNavigateStable),n=w.useRef(!1);return cf(()=>{n.current=!0}),w.useCallback(function(l,i){i===void 0&&(i={}),n.current&&(typeof l=="number"?e.navigate(l):e.navigate(l,wr({fromRouteId:t},i)))},[e,t])}const Du={};function $h(e,t,n){Du[e]||(Du[e]=!0)}function Wh(e,t){e==null||e.v7_startTransition,e==null||e.v7_relativeSplatPath}function ll(e){Y(!1)}function Hh(e){let{basename:t="/",children:n=null,location:r,navigationType:l=yt.Pop,navigator:i,static:o=!1,future:u}=e;Nr()&&Y(!1);let s=t.replace(/^\/*/,"/"),c=w.useMemo(()=>({basename:s,navigator:i,static:o,future:wr({v7_relativeSplatPath:!1},u)}),[s,u,i,o]);typeof r=="string"&&(r=Tn(r));let{pathname:m="/",search:d="",hash:v="",state:x=null,key:g="default"}=r,S=w.useMemo(()=>{let k=Pn(m,s);return k==null?null:{location:{pathname:k,search:d,hash:v,state:x,key:g},navigationType:l}},[s,m,d,v,x,g,l]);return S==null?null:w.createElement(Ot.Provider,{value:c},w.createElement(Xl.Provider,{children:n,value:S}))}function Qh(e){let{children:t,location:n}=e;return Rh(xo(t),n)}new Promise(()=>{});function xo(e,t){t===void 0&&(t=[]);let n=[];return w.Children.forEach(e,(r,l)=>{if(!w.isValidElement(r))return;let i=[...t,l];if(r.type===w.Fragment){n.push.apply(n,xo(r.props.children,i));return}r.type!==ll&&Y(!1),!r.props.index||!r.props.children||Y(!1);let o={id:r.props.id||i.join("-"),caseSensitive:r.props.caseSensitive,element:r.props.element,Component:r.props.Component,index:r.props.index,path:r.props.path,loader:r.props.loader,action:r.props.action,errorElement:r.props.errorElement,ErrorBoundary:r.props.ErrorBoundary,hasErrorBoundary:r.props.ErrorBoundary!=null||r.props.errorElement!=null,shouldRevalidate:r.props.shouldRevalidate,handle:r.props.handle,lazy:r.props.lazy};r.props.children&&(o.children=xo(r.props.children,i)),n.push(o)}),n}/** - * React Router DOM v6.30.3 - * - * Copyright (c) Remix Software Inc. - * - * This source code is licensed under the MIT license found in the - * LICENSE.md file in the root directory of this source tree. - * - * @license MIT - */function Rl(){return Rl=Object.assign?Object.assign.bind():function(e){for(var t=1;t=0)&&(n[l]=e[l]);return n}function Kh(e){return!!(e.metaKey||e.altKey||e.ctrlKey||e.shiftKey)}function Gh(e,t){return e.button===0&&(!t||t==="_self")&&!Kh(e)}function So(e){return e===void 0&&(e=""),new URLSearchParams(typeof e=="string"||Array.isArray(e)||e instanceof URLSearchParams?e:Object.keys(e).reduce((t,n)=>{let r=e[n];return t.concat(Array.isArray(r)?r.map(l=>[n,l]):[[n,r]])},[]))}function Xh(e,t){let n=So(e);return t&&t.forEach((r,l)=>{n.has(l)||t.getAll(l).forEach(i=>{n.append(l,i)})}),n}const Yh=["onClick","relative","reloadDocument","replace","state","target","to","preventScrollReset","viewTransition"],Jh=["aria-current","caseSensitive","className","end","style","to","viewTransition","children"],Zh="6";try{window.__reactRouterVersion=Zh}catch{}const qh=w.createContext({isTransitioning:!1}),bh="startTransition",Fu=Wf[bh];function em(e){let{basename:t,children:n,future:r,window:l}=e,i=w.useRef();i.current==null&&(i.current=th({window:l,v5Compat:!0}));let o=i.current,[u,s]=w.useState({action:o.action,location:o.location}),{v7_startTransition:c}=r||{},m=w.useCallback(d=>{c&&Fu?Fu(()=>s(d)):s(d)},[s,c]);return w.useLayoutEffect(()=>o.listen(m),[o,m]),w.useEffect(()=>Wh(r),[r]),w.createElement(Hh,{basename:t,children:n,location:u.location,navigationType:u.action,navigator:o,future:r})}const tm=typeof window<"u"&&typeof window.document<"u"&&typeof window.document.createElement<"u",nm=/^(?:[a-z][a-z0-9+.-]*:|\/\/)/i,Jl=w.forwardRef(function(t,n){let{onClick:r,relative:l,reloadDocument:i,replace:o,state:u,target:s,to:c,preventScrollReset:m,viewTransition:d}=t,v=mf(t,Yh),{basename:x}=w.useContext(Ot),g,S=!1;if(typeof c=="string"&&nm.test(c)&&(g=c,tm))try{let h=new URL(window.location.href),y=c.startsWith("//")?new URL(h.protocol+c):new URL(c),C=Pn(y.pathname,x);y.origin===h.origin&&C!=null?c=C+y.search+y.hash:S=!0}catch{}let k=Ph(c,{relative:l}),p=lm(c,{replace:o,state:u,target:s,preventScrollReset:m,relative:l,viewTransition:d});function f(h){r&&r(h),h.defaultPrevented||p(h)}return w.createElement("a",Rl({},v,{href:g||k,onClick:S||i?r:f,ref:n,target:s}))}),Au=w.forwardRef(function(t,n){let{"aria-current":r="page",caseSensitive:l=!1,className:i="",end:o=!1,style:u,to:s,viewTransition:c,children:m}=t,d=mf(t,Jh),v=Yl(s,{relative:d.relative}),x=zn(),g=w.useContext(uf),{navigator:S,basename:k}=w.useContext(Ot),p=g!=null&&om(v)&&c===!0,f=S.encodeLocation?S.encodeLocation(v).pathname:v.pathname,h=x.pathname,y=g&&g.navigation&&g.navigation.location?g.navigation.location.pathname:null;l||(h=h.toLowerCase(),y=y?y.toLowerCase():null,f=f.toLowerCase()),y&&k&&(y=Pn(y,k)||y);const C=f!=="/"&&f.endsWith("/")?f.length-1:f.length;let j=h===f||!o&&h.startsWith(f)&&h.charAt(C)==="/",_=y!=null&&(y===f||!o&&y.startsWith(f)&&y.charAt(f.length)==="/"),R={isActive:j,isPending:_,isTransitioning:p},A=j?r:void 0,O;typeof i=="function"?O=i(R):O=[i,j?"active":null,_?"pending":null,p?"transitioning":null].filter(Boolean).join(" ");let se=typeof u=="function"?u(R):u;return w.createElement(Jl,Rl({},d,{"aria-current":A,className:O,ref:n,style:se,to:s,viewTransition:c}),typeof m=="function"?m(R):m)});var ko;(function(e){e.UseScrollRestoration="useScrollRestoration",e.UseSubmit="useSubmit",e.UseSubmitFetcher="useSubmitFetcher",e.UseFetcher="useFetcher",e.useViewTransitionState="useViewTransitionState"})(ko||(ko={}));var Bu;(function(e){e.UseFetcher="useFetcher",e.UseFetchers="useFetchers",e.UseScrollRestoration="useScrollRestoration"})(Bu||(Bu={}));function rm(e){let t=w.useContext(Gl);return t||Y(!1),t}function lm(e,t){let{target:n,replace:r,state:l,preventScrollReset:i,relative:o,viewTransition:u}=t===void 0?{}:t,s=ff(),c=zn(),m=Yl(e,{relative:o});return w.useCallback(d=>{if(Gh(d,n)){d.preventDefault();let v=r!==void 0?r:Ll(c)===Ll(m);s(e,{replace:v,state:l,preventScrollReset:i,relative:o,viewTransition:u})}},[c,s,m,r,l,n,e,i,o,u])}function im(e){let t=w.useRef(So(e)),n=w.useRef(!1),r=zn(),l=w.useMemo(()=>Xh(r.search,n.current?null:t.current),[r.search]),i=ff(),o=w.useCallback((u,s)=>{const c=So(typeof u=="function"?u(l):u);n.current=!0,i("?"+c,s)},[i,l]);return[l,o]}function om(e,t){t===void 0&&(t={});let n=w.useContext(qh);n==null&&Y(!1);let{basename:r}=rm(ko.useViewTransitionState),l=Yl(e,{relative:t.relative});if(!n.isTransitioning)return!1;let i=Pn(n.currentLocation.pathname,r)||n.currentLocation.pathname,o=Pn(n.nextLocation.pathname,r)||n.nextLocation.pathname;return wo(l.pathname,o)!=null||wo(l.pathname,i)!=null}const vf=w.createContext(null);function Vu(){try{return localStorage.getItem("authToken")||""}catch{return""}}function Qr(e){try{e?localStorage.setItem("authToken",e):localStorage.removeItem("authToken")}catch{}}function sm({children:e}){const[t,n]=w.useState(Vu),[r,l]=w.useState(null),[i,o]=w.useState(!!Vu()),[u,s]=w.useState(null);w.useEffect(()=>{if(!t){l(null),o(!1),s(null);return}let g=!1;return o(!0),fetch("/api/auth/me",{headers:{Authorization:`Bearer ${t}`}}).then(async S=>{const k=await S.json().catch(()=>({}));if(!S.ok)throw new Error(k.error||"Kon sessie niet verifiëren.");g||(l(k.user||null),s(null))}).catch(()=>{g||(l(null),n(""),Qr(""))}).finally(()=>{g||o(!1)}),()=>{g=!0}},[t]);async function c(g){s(null);const S=await fetch("/api/auth/login",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(g)}),k=await S.json().catch(()=>({}));if(!S.ok)throw new Error(k.error||"Login mislukt.");return n(k.token),Qr(k.token),l(k.user),k.user}async function m(g){s(null);const S=await fetch("/api/auth/register",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(g)}),k=await S.json().catch(()=>({}));if(!S.ok)throw new Error(k.error||"Registratie mislukt.");return n(k.token),Qr(k.token),l(k.user),k.user}function d(){n(""),Qr(""),l(null)}const v=w.useMemo(()=>(g,S={})=>{const k={...S.headers||{},...t?{Authorization:`Bearer ${t}`}:{}};return fetch(g,{...S,headers:k})},[t]),x={user:r,token:t,loading:i,error:u,login:c,register:m,logout:d,authFetch:v};return a.jsx(vf.Provider,{value:x,children:e})}function gf(){const e=w.useContext(vf);if(!e)throw new Error("useAuth moet binnen een AuthProvider gebruikt worden");return e}function um(){const e=({isActive:r})=>r?"nav-link active":"nav-link",{user:t,logout:n}=gf();return a.jsxs("nav",{className:"site-nav",children:[a.jsx(Jl,{className:"nav-logo",to:"/",children:"Siti Plugin Repo"}),a.jsxs("div",{className:"nav-links",children:[a.jsx(Au,{to:"/",end:!0,className:e,children:"Plugins"}),a.jsx(Au,{to:"/licenses",className:e,children:"Licenties"})]}),a.jsx("div",{className:"nav-user",children:t?a.jsxs(a.Fragment,{children:[a.jsxs("span",{className:"nav-user-name",children:["Hallo, ",t.name]}),a.jsx("button",{className:"ghost ghost-small",type:"button",onClick:n,children:"Uitloggen"})]}):a.jsx("span",{className:"nav-user-guest",children:"Niet ingelogd"})})]})}function am(){const[e,t]=w.useState([]),[n,r]=w.useState(!0),[l,i]=w.useState(null),[o,u]=w.useState(null);return w.useEffect(()=>{async function s(){try{const c=await fetch("/api/plugins");if(!c.ok)throw new Error("Kon plugins niet laden");const m=await c.json();t(m.items||[]),u(m.updatedAt)}catch{i("Laden van repository data is mislukt.")}finally{r(!1)}}s()},[]),a.jsxs("div",{className:"page",children:[a.jsxs("header",{className:"hero",children:[a.jsxs("div",{children:[a.jsx("p",{className:"eyebrow",children:"WordPress plugin overzicht"}),a.jsx("h1",{children:"Siti Plugin Repo"}),a.jsx("p",{className:"subtitle",children:"Al je publieke WordPress plugins op één plek."})]}),a.jsx("a",{className:"cta",href:"https://github.com/SitiWeb",target:"_blank",rel:"noreferrer",children:"GitHub SitiWeb"})]}),a.jsxs("section",{className:"grid",children:[n&&a.jsx("div",{className:"state",children:"Bezig met laden…"}),l&&a.jsx("div",{className:"state error",children:l}),!n&&!l&&e.length===0&&a.jsx("div",{className:"state",children:"Geen repositories gevonden."}),e.map(s=>{var g,S;const c=((g=s.manifest)==null?void 0:g.plugin_name)||s.name,m=((S=s.manifest)==null?void 0:S.description)||s.description,d=new URLSearchParams;s.provider&&d.set("provider",s.provider),s.baseUrl&&d.set("baseUrl",s.baseUrl);const v=s.provider==="gitea"?"Gitea":"GitHub",x=`/plugin/${s.fullName}`+(d.toString()?`?${d.toString()}`:"");return a.jsxs("article",{className:"card",children:[a.jsxs("div",{className:"card-header",children:[a.jsx("h2",{children:c}),a.jsx("span",{className:"pill",children:s.fullName})]}),a.jsx("p",{children:m}),a.jsxs("div",{className:"meta",children:[a.jsxs("span",{children:["★ ",s.stars]}),a.jsxs("span",{children:["Forks ",s.forks]}),a.jsxs("span",{children:["Issues ",s.issues]})]}),s.topics.length>0&&a.jsx("div",{className:"topics",children:s.topics.slice(0,4).map(k=>a.jsx("span",{className:"topic",children:k},k))}),a.jsxs("div",{className:"actions",children:[a.jsx(Jl,{className:"link",to:x,children:"Bekijk details →"}),a.jsx("a",{className:"ghost",href:s.repoUrl,target:"_blank",rel:"noreferrer",children:v})]})]},s.fullName)})]}),a.jsx("footer",{className:"footer",children:a.jsxs("span",{children:["Laatste sync: ",o?new Date(o).toLocaleString("nl-NL"):"-"]})})]})}function cm(){const{owner:e,repo:t}=Lh(),[n]=im(),r=(n.get("provider")||"github").toLowerCase(),l=n.get("baseUrl")||"",[i,o]=w.useState(null),[u,s]=w.useState(!0),[c,m]=w.useState(null);w.useEffect(()=>{async function y(){try{const C=new URLSearchParams;r&&C.set("provider",r),l&&C.set("baseUrl",l);const j=C.toString(),_=await fetch(`/api/plugins/${e}/${t}${j.length>0?`?${j}`:""}`);if(!_.ok)throw new Error("Kon details niet laden");const R=await _.json();o(R)}catch{m("Laden van plugin details is mislukt.")}finally{s(!1)}}y()},[e,t,r,l]);const d=i==null?void 0:i.manifest,v=(d==null?void 0:d.plugin_name)||(i==null?void 0:i.name)||t,x=(d==null?void 0:d.description)||(i==null?void 0:i.description),g=(d==null?void 0:d.author)||"-",S=(d==null?void 0:d.version)||"-",k=(i==null?void 0:i.provider)==="gitea"?"Gitea":"GitHub",p=i==null?void 0:i.download,f=w.useMemo(()=>(i==null?void 0:i.releases)||[],[i]),h=w.useMemo(()=>(i==null?void 0:i.commits)||[],[i]);return a.jsxs("div",{className:"page",children:[a.jsxs("header",{className:"detail-hero",children:[a.jsxs("div",{children:[a.jsx("p",{className:"eyebrow",children:"Plugin details"}),a.jsx("h1",{children:v}),a.jsx("p",{className:"subtitle",children:x})]}),a.jsxs("div",{className:"detail-actions",children:[a.jsx(Jl,{className:"ghost",to:"/",children:"← Terug"}),(i==null?void 0:i.repoUrl)&&a.jsx("a",{className:"ghost",href:i.repoUrl,target:"_blank",rel:"noreferrer",children:k}),(p==null?void 0:p.url)&&a.jsxs("a",{className:"cta",href:p.url,target:"_blank",rel:"noreferrer",children:["Download ",p.version]})]})]}),u&&a.jsx("div",{className:"state",children:"Bezig met laden…"}),c&&a.jsx("div",{className:"state error",children:c}),!u&&!c&&i&&a.jsxs("section",{className:"detail-grid",children:[a.jsxs("div",{className:"card",children:[a.jsx("h2",{children:"Manifest"}),a.jsxs("div",{className:"detail-list",children:[a.jsxs("div",{children:[a.jsx("span",{children:"Naam"}),a.jsx("strong",{children:v})]}),a.jsxs("div",{children:[a.jsx("span",{children:"Versie"}),a.jsx("strong",{children:S})]}),a.jsxs("div",{children:[a.jsx("span",{children:"Auteur"}),a.jsx("strong",{children:g})]}),a.jsxs("div",{children:[a.jsx("span",{children:"Repository"}),a.jsx("strong",{children:i.fullName})]})]}),(d==null?void 0:d.author_url)&&a.jsx("a",{className:"link",href:d.author_url,target:"_blank",rel:"noreferrer",children:"Auteur website →"})]}),a.jsxs("div",{className:"card",children:[a.jsx("h2",{children:"Releases"}),f.length===0&&a.jsx("p",{children:"Geen releases gevonden."}),a.jsx("ul",{className:"list",children:f.map(y=>{const C=y.tag||y.name||y.url;return a.jsxs("li",{children:[a.jsxs("div",{children:[a.jsx("a",{href:y.url,target:"_blank",rel:"noreferrer",children:y.name}),a.jsx("span",{children:y.publishedAt?new Date(y.publishedAt).toLocaleDateString("nl-NL"):"-"})]}),y.downloadUrl&&a.jsx("a",{className:"ghost",href:y.downloadUrl,target:"_blank",rel:"noreferrer",children:"Download"})]},C)})})]}),a.jsxs("div",{className:"card",children:[a.jsx("h2",{children:"Recente commits"}),h.length===0&&a.jsx("p",{children:"Geen commits gevonden."}),a.jsx("ul",{className:"list",children:h.map(y=>{var C;return a.jsxs("li",{children:[a.jsx("a",{href:y.url,target:"_blank",rel:"noreferrer",children:((C=y.message)==null?void 0:C.split(` -`)[0])||y.sha.slice(0,7)}),a.jsx("span",{children:y.author||"-"})]},y.sha)})})]})]})]})}const yf="nl-NL";function Eo(e,t=yf){return e?new Date(e).toLocaleString(t):"-"}function fm(e,t=yf){return e?new Date(e).toLocaleDateString(t):"-"}function dm({license:e}){const t=e.hostnames||[],n=e.primaryHostname||"Nog niet gekoppeld";return a.jsxs("article",{className:"card license-card",children:[a.jsxs("div",{className:"license-card-header",children:[a.jsxs("div",{children:[a.jsx("h3",{children:e.pluginName||e.label||"Licentie"}),a.jsx("p",{className:"license-subtitle",children:e.repoFullName||"-"})]}),a.jsx("span",{className:"pill",children:e.key})]}),a.jsxs("div",{className:"detail-list license-detail-list",children:[a.jsxs("div",{children:[a.jsx("span",{children:"Hostname"}),a.jsx("strong",{children:n})]}),a.jsxs("div",{children:[a.jsx("span",{children:"Huidige versie"}),a.jsx("strong",{children:e.lastUsedVersion||"-"})]}),a.jsxs("div",{children:[a.jsx("span",{children:"Laatste release"}),a.jsx("strong",{children:e.pluginVersion||"-"})]}),a.jsxs("div",{children:[a.jsx("span",{children:"Aangemaakt"}),a.jsx("strong",{children:fm(e.createdAt)})]}),a.jsxs("div",{children:[a.jsx("span",{children:"Laatste check"}),a.jsx("strong",{children:Eo(e.lastVersionCheckAt)})]})]}),e.note&&a.jsxs("p",{className:"license-note",children:["Notitie: ",e.note]}),t.length>0&&a.jsxs("div",{className:"host-list",children:[a.jsx("p",{className:"hint",children:"Hostnames"}),a.jsx("ul",{children:t.map(r=>a.jsxs("li",{children:[a.jsxs("div",{children:[a.jsx("strong",{children:r.hostname}),a.jsxs("span",{children:[r.hits||0," checks"]})]}),a.jsx("span",{children:Eo(r.lastSeenAt)})]},`${r.hostname}-${r.firstSeenAt||r.lastSeenAt}`))})]}),a.jsxs("div",{className:"license-links",children:[e.repoUrl&&a.jsx("a",{className:"link",href:e.repoUrl,target:"_blank",rel:"noreferrer",children:"Repository →"}),e.pluginName&&a.jsx("span",{className:"ghost-pill",children:e.pluginName})]})]})}function pm(){var ks;const{user:e,token:t,authFetch:n,login:r,register:l,loading:i}=gf(),[o,u]=w.useState([]),[s,c]=w.useState([]),[m,d]=w.useState([]),[v,x]=w.useState(""),[g,S]=w.useState(""),[k,p]=w.useState(""),[f,h]=w.useState(""),[y,C]=w.useState(!0),[j,_]=w.useState(null),[R,A]=w.useState(!1),[O,se]=w.useState(!1),[st,ut]=w.useState(!1),[jr,Pr]=w.useState(null),[Ut,Se]=w.useState(null),[P,z]=w.useState(null),[T,B]=w.useState(null),[J,Mt]=w.useState(!1),[Me,On]=w.useState(""),[De,Zt]=w.useState(""),[ws,wf]=w.useState(""),[qt,bt]=w.useState({username:"",name:"",email:"",password:"",isAdmin:!1}),at=!!(e&&t);w.useEffect(()=>{let N=!1;async function I(){var D;C(!0),_(null);try{const te=await fetch("/api/plugins"),ke=await te.json().catch(()=>({}));if(!te.ok)throw new Error(ke.error||"Kon plugins niet laden.");if(N)return;c(ke.items||[]);const Ee=(D=ke.items)==null?void 0:D[0];if(Ee){const Zl=Ee.ownerRepo||Ee.fullName;x(Nf=>Nf||Zl)}}catch(te){N||_(te.message||"Kon plugins niet laden.")}finally{N||C(!1)}}return I(),()=>{N=!0}},[]),w.useEffect(()=>{if(!at){d([]),S("");return}e&&!g&&S(String(e.id))},[at,g,e]),w.useEffect(()=>{if(!at||!e)return;if(!e.isAdmin){d([e]);return}let N=!1;async function I(){try{const D=await n("/api/admin/users"),te=await D.json().catch(()=>({}));if(!D.ok)throw new Error(te.error||"Kon gebruikers niet laden.");if(N)return;d(te.items||[]),!g&&(te.items||[]).length>0&&S(String(te.items[0].id))}catch(D){N||Se({variant:"error",message:D.message})}}return I(),()=>{N=!0}},[n,at,g,e]);const ct=w.useCallback(async(N=!0,I)=>{if(!t){u([]),Pr(null),N&&Se({variant:"error",message:"Log in om licenties te beheren."});return}N&&Se(null),ut(!0);try{const D=I||e!=null&&e.isAdmin&&g||(e?String(e.id):"");let te="/api/licenses";e!=null&&e.isAdmin&&D&&(te+=`?userId=${D}`);const ke=await n(te),Ee=await ke.json().catch(()=>({}));if(ke.status===401)throw new Error("Sessie verlopen, log opnieuw in.");if(!ke.ok)throw new Error(Ee.error||"Kon licenties niet laden.");u(Ee.items||[]),Pr(Ee.updatedAt)}catch(D){N&&Se({variant:"error",message:D.message})}finally{ut(!1)}},[n,g,t,e]);w.useEffect(()=>{ct(!1)},[ct]),w.useEffect(()=>{if(!v&&s.length>0){const N=s[0].ownerRepo||s[0].fullName;x(N)}},[s,v]);const Je=w.useMemo(()=>s.find(N=>(N.ownerRepo||N.fullName)===v)||null,[s,v]),xs=w.useMemo(()=>{const N=I=>I?new Date(I).getTime():0;return[...o].sort((I,D)=>N(D.createdAt)-N(I.createdAt))},[o]);async function xf(N){var I;if(N.preventDefault(),Se(null),!at){Se({variant:"error",message:"Log in om een licentie aan te maken."});return}if(!Je){Se({variant:"error",message:"Selecteer een plugin."});return}A(!0);try{const te={...{label:k.trim()||((I=Je.manifest)==null?void 0:I.plugin_name)||Je.name||Je.fullName,note:f.trim()||void 0,repo:{repo:Je.ownerRepo||Je.fullName,provider:Je.provider||"github",baseUrl:Je.baseUrl}},userId:e!=null&&e.isAdmin?Number(g||e.id):void 0},ke=await n("/api/licenses",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(te)}),Ee=await ke.json().catch(()=>({}));if(ke.status===401)throw new Error("Sessie verlopen, log opnieuw in.");if(!ke.ok)throw new Error(Ee.error||"Licentie aanmaken mislukt.");u(Zl=>[Ee,...Zl]),Se({variant:"success",message:"Licentie aangemaakt."}),p(""),h("")}catch(D){Se({variant:"error",message:D.message})}finally{A(!1)}}async function Sf(N){N.preventDefault(),z(null),se(!0);try{const I=await n("/api/admin/users",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(qt)}),D=await I.json().catch(()=>({}));if(!I.ok)throw new Error(D.error||"Gebruiker aanmaken mislukt.");z({variant:"success",message:"Gebruiker aangemaakt."}),bt({username:"",name:"",email:"",password:"",isAdmin:!1}),d(te=>[...te,D.user]),g||S(String(D.user.id))}catch(I){z({variant:"error",message:I.message})}finally{se(!1)}}async function kf(N){if(N.preventDefault(),B(null),!Me.trim()||!De.trim()){B({ok:!1,message:"Vul zowel licentiecode als hostname in."});return}Mt(!0);try{const I=await fetch("/api/licenses/verify",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({key:Me.trim(),hostname:De.trim(),currentVersion:ws.trim()||void 0})}),D=await I.json().catch(()=>({})),te={ok:I.ok,data:D,message:I.ok?null:D.error||"Controle mislukt."};B(te),I.ok&&D.license&&u(ke=>ke.map(Ee=>Ee.key===D.license.key?D.license:Ee))}catch(I){B({ok:!1,message:I.message})}finally{Mt(!1)}}const Ef=w.useCallback(async N=>{await r(N),await ct(!1)},[r,ct]),Cf=w.useCallback(async N=>{await l(N),await ct(!1)},[l,ct]),Ss=y||i&&!!t;return a.jsxs("div",{className:"page",children:[a.jsxs("header",{className:"hero",children:[a.jsxs("div",{children:[a.jsx("p",{className:"eyebrow",children:"Licentiebeheer"}),a.jsx("h1",{children:"Licenties"}),a.jsx("p",{className:"subtitle",children:"Maak licenties voor iedere plugin en beheer welke hostname de licentie daadwerkelijk gebruikt."}),a.jsx("p",{className:"hint",children:"Een licentie is geldig voor één hostname. De eerste hostname die controleert wordt automatisch gekoppeld als licentiehouder."})]}),a.jsx("button",{className:"ghost",type:"button",onClick:()=>ct(),disabled:st||!at,children:st?"Vernieuwen…":"Vernieuw lijst"})]}),a.jsxs("div",{className:"license-meta-bar",children:[a.jsxs("span",{children:["Actieve licenties: ",o.length]}),a.jsxs("span",{children:["Laatste update: ",Eo(jr)]}),e&&a.jsxs("span",{children:["Ingelogd als: ",e.email]}),(e==null?void 0:e.isAdmin)&&m.length>0&&a.jsxs("label",{className:"inline-field",children:[a.jsx("span",{children:"Licenties gebruiker"}),a.jsx("select",{value:g,onChange:N=>{S(N.target.value),ct(!0,N.target.value)},children:m.map(N=>a.jsxs("option",{value:N.id,children:[N.name," (",N.email,")"]},N.id))})]})]}),Ss&&a.jsx("div",{className:"state",children:"Bezig met laden…"}),j&&a.jsx("div",{className:"state error",children:j}),!Ss&&!j&&a.jsxs(a.Fragment,{children:[a.jsxs("section",{className:"license-forms",children:[at?a.jsxs("article",{className:"card",children:[a.jsx("h2",{children:"Nieuwe licentie"}),a.jsx("p",{className:"hint",children:"Kies een plugin en genereer direct een licentiesleutel."}),a.jsxs("form",{className:"form-grid",onSubmit:xf,children:[a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Plugin"}),a.jsx("select",{value:v,onChange:N=>x(N.target.value),disabled:s.length===0,children:s.map(N=>{var D;const I=N.ownerRepo||N.fullName;return a.jsxs("option",{value:I,children:[((D=N.manifest)==null?void 0:D.plugin_name)||N.name," (",N.fullName,")"]},I)})})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Label (optioneel)"}),a.jsx("input",{value:k,onChange:N=>p(N.target.value),placeholder:"Naam of klant"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Notitie"}),a.jsx("textarea",{value:f,onChange:N=>h(N.target.value),placeholder:"Bijv. contactpersoon of extra info",rows:3})]}),(e==null?void 0:e.isAdmin)&&a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Licentie voor gebruiker"}),a.jsx("select",{value:g,onChange:N=>S(N.target.value),children:m.map(N=>a.jsxs("option",{value:N.id,children:[N.name," (",N.email,")"]},N.id))})]}),a.jsx("button",{className:"cta",type:"submit",disabled:R||!Je,children:R?"Aanmaken…":"Licentie aanmaken"})]}),Ut&&a.jsx("div",{className:`state inline ${Ut.variant==="error"?"error":"success"}`,children:Ut.message})]}):a.jsx(hm,{onLogin:Ef,onRegister:Cf}),a.jsxs("article",{className:"card",children:[a.jsx("h2",{children:"Test of valideer"}),a.jsx("p",{className:"hint",children:"Gebruik dit formulier zoals de plugin dat zou doen om de huidige versie en hostname te controleren."}),a.jsxs("form",{className:"form-grid",onSubmit:kf,children:[a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Licentiecode"}),a.jsx("input",{value:Me,onChange:N=>On(N.target.value),placeholder:"SITI-XXXX-XXXX"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Hostname"}),a.jsx("input",{value:De,onChange:N=>Zt(N.target.value),placeholder:"voorbeeld.nl"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Deze site draait versie"}),a.jsx("input",{value:ws,onChange:N=>wf(N.target.value),placeholder:"bijv. 1.9.3"})]}),a.jsx("button",{className:"ghost",type:"submit",disabled:J,children:J?"Controleren…":"Controleer licentie"})]}),((ks=T==null?void 0:T.data)==null?void 0:ks.license)&&a.jsxs("div",{className:`state inline ${T.ok?"success":""}`.trim(),children:[a.jsx("strong",{children:T.ok?"Licentie geldig":"Plugin informatie"}),a.jsx("p",{children:T.data.license.pluginName||"Plugin"}),a.jsxs("p",{children:["Huidige versie:"," ",a.jsx("strong",{children:T.data.license.lastUsedVersion||T.data.license.pluginVersion||"-"})]}),a.jsxs("p",{children:["Laatste release:"," ",a.jsx("strong",{children:T.data.license.pluginVersion||"-"})]}),a.jsxs("p",{children:["Gekoppeld aan:"," ",a.jsx("strong",{children:T.data.license.primaryHostname||"Nog niet gekoppeld"})]}),!T.ok&&a.jsx("p",{className:"hint",children:"Licentie is ongeldig; downloaden blijft geblokkeerd."})]}),T&&!T.ok&&T.message&&a.jsx("div",{className:"state error inline",children:T.message})]})]}),(e==null?void 0:e.isAdmin)&&a.jsx("section",{className:"license-forms",children:a.jsxs("article",{className:"card",children:[a.jsx("h2",{children:"Gebruiker toevoegen"}),a.jsx("p",{className:"hint",children:"Admins kunnen extra gebruikers aanmaken en direct licenties toewijzen."}),a.jsxs("form",{className:"form-grid",onSubmit:Sf,children:[a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Gebruikersnaam"}),a.jsx("input",{value:qt.username,onChange:N=>bt(I=>({...I,username:N.target.value})),placeholder:"gebruikersnaam"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Naam"}),a.jsx("input",{value:qt.name,onChange:N=>bt(I=>({...I,name:N.target.value})),placeholder:"Volledige naam"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"E-mail"}),a.jsx("input",{type:"email",value:qt.email,onChange:N=>bt(I=>({...I,email:N.target.value})),placeholder:"naam@bedrijf.nl"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Wachtwoord"}),a.jsx("input",{type:"password",value:qt.password,onChange:N=>bt(I=>({...I,password:N.target.value})),placeholder:"Minimaal 8 karakters"})]}),a.jsxs("label",{className:"checkbox-field",children:[a.jsx("input",{type:"checkbox",checked:qt.isAdmin,onChange:N=>bt(I=>({...I,isAdmin:N.target.checked}))}),a.jsx("span",{children:"Maak deze gebruiker admin"})]}),a.jsx("button",{className:"cta",type:"submit",disabled:O,children:O?"Bezig…":"Gebruiker aanmaken"})]}),P&&a.jsx("div",{className:`state inline ${P.variant==="error"?"error":"success"}`,children:P.message})]})}),at?a.jsx("section",{className:"license-grid",children:xs.length===0?a.jsx("div",{className:"state",children:"Nog geen licenties aangemaakt."}):xs.map(N=>a.jsx(dm,{license:N},N.id||N.key))}):a.jsx("div",{className:"state",children:"Log in of registreer om licenties te bekijken en te beheren."})]})]})}function hm({onLogin:e,onRegister:t}){const[n,r]=w.useState("login"),[l,i]=w.useState({identifier:"",password:""}),[o,u]=w.useState({username:"",name:"",email:"",password:""}),[s,c]=w.useState(null),[m,d]=w.useState(!1);async function v(x){x.preventDefault(),c(null),d(!0);try{n==="login"?(await e(l),c({variant:"success",message:"Succesvol ingelogd."})):(await t(o),c({variant:"success",message:"Account aangemaakt en ingelogd."}))}catch(g){c({variant:"error",message:g.message||"Actie mislukt."})}finally{d(!1)}}return a.jsxs("article",{className:"card auth-card",children:[a.jsxs("div",{className:"auth-tabs",children:[a.jsx("button",{type:"button",className:n==="login"?"auth-tab active":"auth-tab",onClick:()=>r("login"),disabled:m,children:"Inloggen"}),a.jsx("button",{type:"button",className:n==="register"?"auth-tab active":"auth-tab",onClick:()=>r("register"),disabled:m,children:"Registreren"})]}),a.jsxs("form",{className:"form-grid",onSubmit:v,children:[n==="login"?a.jsxs(a.Fragment,{children:[a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Gebruikersnaam of e-mail"}),a.jsx("input",{value:l.identifier,onChange:x=>i(g=>({...g,identifier:x.target.value})),placeholder:"jouwnaam of mail"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Wachtwoord"}),a.jsx("input",{type:"password",value:l.password,onChange:x=>i(g=>({...g,password:x.target.value})),placeholder:"••••••••"})]})]}):a.jsxs(a.Fragment,{children:[a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Gebruikersnaam"}),a.jsx("input",{value:o.username,onChange:x=>u(g=>({...g,username:x.target.value})),placeholder:"gebruikersnaam"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Naam"}),a.jsx("input",{value:o.name,onChange:x=>u(g=>({...g,name:x.target.value})),placeholder:"Volledige naam"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"E-mailadres"}),a.jsx("input",{type:"email",value:o.email,onChange:x=>u(g=>({...g,email:x.target.value})),placeholder:"naam@bedrijf.nl"})]}),a.jsxs("label",{className:"field",children:[a.jsx("span",{children:"Wachtwoord"}),a.jsx("input",{type:"password",value:o.password,onChange:x=>u(g=>({...g,password:x.target.value})),placeholder:"Minimaal 8 karakters"})]})]}),a.jsx("button",{className:"cta",type:"submit",disabled:m,children:m?"Verwerken…":n==="login"?"Inloggen":"Registreren"})]}),s&&a.jsx("div",{className:`state inline ${s.variant==="error"?"error":"success"}`,children:s.message})]})}function mm(){return a.jsxs("div",{className:"app",children:[a.jsx(um,{}),a.jsxs(Qh,{children:[a.jsx(ll,{path:"/",element:a.jsx(am,{})}),a.jsx(ll,{path:"/plugin/:owner/:repo",element:a.jsx(cm,{})}),a.jsx(ll,{path:"/licenses",element:a.jsx(pm,{})})]})]})}tf(document.getElementById("root")).render(a.jsx(qu.StrictMode,{children:a.jsx(em,{children:a.jsx(sm,{children:a.jsx(mm,{})})})})); diff --git a/dist/assets/index-DDjGuoSe.js b/dist/assets/index-DDjGuoSe.js new file mode 100644 index 0000000..496a568 --- /dev/null +++ b/dist/assets/index-DDjGuoSe.js @@ -0,0 +1,68 @@ +function Pf(e,t){for(var n=0;nr[l]})}}}return Object.freeze(Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}))}(function(){const t=document.createElement("link").relList;if(t&&t.supports&&t.supports("modulepreload"))return;for(const l of document.querySelectorAll('link[rel="modulepreload"]'))r(l);new MutationObserver(l=>{for(const i of l)if(i.type==="childList")for(const o of i.addedNodes)o.tagName==="LINK"&&o.rel==="modulepreload"&&r(o)}).observe(document,{childList:!0,subtree:!0});function n(l){const i={};return l.integrity&&(i.integrity=l.integrity),l.referrerPolicy&&(i.referrerPolicy=l.referrerPolicy),l.crossOrigin==="use-credentials"?i.credentials="include":l.crossOrigin==="anonymous"?i.credentials="omit":i.credentials="same-origin",i}function r(l){if(l.ep)return;l.ep=!0;const i=n(l);fetch(l.href,i)}})();function _f(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var Ha={exports:{}},Tl={},Qa={exports:{}},D={};/** + * @license React + * react.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */var jr=Symbol.for("react.element"),Lf=Symbol.for("react.portal"),Rf=Symbol.for("react.fragment"),Tf=Symbol.for("react.strict_mode"),zf=Symbol.for("react.profiler"),Of=Symbol.for("react.provider"),If=Symbol.for("react.context"),Uf=Symbol.for("react.forward_ref"),Mf=Symbol.for("react.suspense"),Df=Symbol.for("react.memo"),Ff=Symbol.for("react.lazy"),Ns=Symbol.iterator;function Af(e){return e===null||typeof e!="object"?null:(e=Ns&&e[Ns]||e["@@iterator"],typeof e=="function"?e:null)}var Ka={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},Ga=Object.assign,Xa={};function Rn(e,t,n){this.props=e,this.context=t,this.refs=Xa,this.updater=n||Ka}Rn.prototype.isReactComponent={};Rn.prototype.setState=function(e,t){if(typeof e!="object"&&typeof e!="function"&&e!=null)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,e,t,"setState")};Rn.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")};function Ya(){}Ya.prototype=Rn.prototype;function No(e,t,n){this.props=e,this.context=t,this.refs=Xa,this.updater=n||Ka}var Co=No.prototype=new Ya;Co.constructor=No;Ga(Co,Rn.prototype);Co.isPureReactComponent=!0;var Cs=Array.isArray,Ja=Object.prototype.hasOwnProperty,Po={current:null},Za={key:!0,ref:!0,__self:!0,__source:!0};function qa(e,t,n){var r,l={},i=null,o=null;if(t!=null)for(r in t.ref!==void 0&&(o=t.ref),t.key!==void 0&&(i=""+t.key),t)Ja.call(t,r)&&!Za.hasOwnProperty(r)&&(l[r]=t[r]);var a=arguments.length-2;if(a===1)l.children=n;else if(1>>1,b=_[W];if(0>>1;Wl(Un,z))$el(bt,Un)?(_[W]=bt,_[$e]=z,W=$e):(_[W]=Un,_[Ve]=z,W=Ve);else if($el(bt,z))_[W]=bt,_[$e]=z,W=$e;else break e}}return O}function l(_,O){var z=_.sortIndex-O.sortIndex;return z!==0?z:_.id-O.id}if(typeof performance=="object"&&typeof performance.now=="function"){var i=performance;e.unstable_now=function(){return i.now()}}else{var o=Date,a=o.now();e.unstable_now=function(){return o.now()-a}}var s=[],c=[],v=1,h=null,m=3,x=!1,g=!1,w=!1,k=typeof setTimeout=="function"?setTimeout:null,d=typeof clearTimeout=="function"?clearTimeout:null,f=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function p(_){for(var O=n(c);O!==null;){if(O.callback===null)r(c);else if(O.startTime<=_)r(c),O.sortIndex=O.expirationTime,t(s,O);else break;O=n(c)}}function S(_){if(w=!1,p(_),!g)if(n(s)!==null)g=!0,Je(j);else{var O=n(c);O!==null&&Ne(S,O.startTime-_)}}function j(_,O){g=!1,w&&(w=!1,d(R),R=-1),x=!0;var z=m;try{for(p(O),h=n(s);h!==null&&(!(h.expirationTime>O)||_&&!ie());){var W=h.callback;if(typeof W=="function"){h.callback=null,m=h.priorityLevel;var b=W(h.expirationTime<=O);O=e.unstable_now(),typeof b=="function"?h.callback=b:h===n(s)&&r(s),p(O)}else r(s);h=n(s)}if(h!==null)var Ft=!0;else{var Ve=n(c);Ve!==null&&Ne(S,Ve.startTime-O),Ft=!1}return Ft}finally{h=null,m=z,x=!1}}var C=!1,P=null,R=-1,B=5,I=-1;function ie(){return!(e.unstable_now()-I_||125<_?console.error("forceFrameRate takes a positive int between 0 and 125, forcing frame rates higher than 125 fps is not supported"):B=0<_?Math.floor(1e3/_):5},e.unstable_getCurrentPriorityLevel=function(){return m},e.unstable_getFirstCallbackNode=function(){return n(s)},e.unstable_next=function(_){switch(m){case 1:case 2:case 3:var O=3;break;default:O=m}var z=m;m=O;try{return _()}finally{m=z}},e.unstable_pauseExecution=function(){},e.unstable_requestPaint=function(){},e.unstable_runWithPriority=function(_,O){switch(_){case 1:case 2:case 3:case 4:case 5:break;default:_=3}var z=m;m=_;try{return O()}finally{m=z}},e.unstable_scheduleCallback=function(_,O,z){var W=e.unstable_now();switch(typeof z=="object"&&z!==null?(z=z.delay,z=typeof z=="number"&&0W?(_.sortIndex=z,t(c,_),n(s)===null&&_===n(c)&&(w?(d(R),R=-1):w=!0,Ne(S,z-W))):(_.sortIndex=b,t(s,_),g||x||(g=!0,Je(j))),_},e.unstable_shouldYield=ie,e.unstable_wrapCallback=function(_){var O=m;return function(){var z=m;m=O;try{return _.apply(this,arguments)}finally{m=z}}}})(lu);ru.exports=lu;var Zf=ru.exports;/** + * @license React + * react-dom.production.min.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */var qf=y,Te=Zf;function E(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),Ci=Object.prototype.hasOwnProperty,bf=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,_s={},Ls={};function ed(e){return Ci.call(Ls,e)?!0:Ci.call(_s,e)?!1:bf.test(e)?Ls[e]=!0:(_s[e]=!0,!1)}function td(e,t,n,r){if(n!==null&&n.type===0)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return r?!1:n!==null?!n.acceptsBooleans:(e=e.toLowerCase().slice(0,5),e!=="data-"&&e!=="aria-");default:return!1}}function nd(e,t,n,r){if(t===null||typeof t>"u"||td(e,t,n,r))return!0;if(r)return!1;if(n!==null)switch(n.type){case 3:return!t;case 4:return t===!1;case 5:return isNaN(t);case 6:return isNaN(t)||1>t}return!1}function we(e,t,n,r,l,i,o){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=r,this.attributeNamespace=l,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=i,this.removeEmptyString=o}var fe={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){fe[e]=new we(e,0,!1,e,null,!1,!1)});[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];fe[t]=new we(t,1,!1,e[1],null,!1,!1)});["contentEditable","draggable","spellCheck","value"].forEach(function(e){fe[e]=new we(e,2,!1,e.toLowerCase(),null,!1,!1)});["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){fe[e]=new we(e,2,!1,e,null,!1,!1)});"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach(function(e){fe[e]=new we(e,3,!1,e.toLowerCase(),null,!1,!1)});["checked","multiple","muted","selected"].forEach(function(e){fe[e]=new we(e,3,!0,e,null,!1,!1)});["capture","download"].forEach(function(e){fe[e]=new we(e,4,!1,e,null,!1,!1)});["cols","rows","size","span"].forEach(function(e){fe[e]=new we(e,6,!1,e,null,!1,!1)});["rowSpan","start"].forEach(function(e){fe[e]=new we(e,5,!1,e.toLowerCase(),null,!1,!1)});var Lo=/[\-:]([a-z])/g;function Ro(e){return e[1].toUpperCase()}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(e){var t=e.replace(Lo,Ro);fe[t]=new we(t,1,!1,e,null,!1,!1)});"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach(function(e){var t=e.replace(Lo,Ro);fe[t]=new we(t,1,!1,e,"http://www.w3.org/1999/xlink",!1,!1)});["xml:base","xml:lang","xml:space"].forEach(function(e){var t=e.replace(Lo,Ro);fe[t]=new we(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)});["tabIndex","crossOrigin"].forEach(function(e){fe[e]=new we(e,1,!1,e.toLowerCase(),null,!1,!1)});fe.xlinkHref=new we("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1);["src","href","action","formAction"].forEach(function(e){fe[e]=new we(e,1,!1,e.toLowerCase(),null,!0,!0)});function To(e,t,n,r){var l=fe.hasOwnProperty(t)?fe[t]:null;(l!==null?l.type!==0:r||!(2a||l[o]!==i[a]){var s=` +`+l[o].replace(" at new "," at ");return e.displayName&&s.includes("")&&(s=s.replace("",e.displayName)),s}while(1<=o&&0<=a);break}}}finally{ei=!1,Error.prepareStackTrace=n}return(e=e?e.displayName||e.name:"")?Hn(e):""}function rd(e){switch(e.tag){case 5:return Hn(e.type);case 16:return Hn("Lazy");case 13:return Hn("Suspense");case 19:return Hn("SuspenseList");case 0:case 2:case 15:return e=ti(e.type,!1),e;case 11:return e=ti(e.type.render,!1),e;case 1:return e=ti(e.type,!0),e;default:return""}}function Ri(e){if(e==null)return null;if(typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case ln:return"Fragment";case rn:return"Portal";case Pi:return"Profiler";case zo:return"StrictMode";case _i:return"Suspense";case Li:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case su:return(e.displayName||"Context")+".Consumer";case ou:return(e._context.displayName||"Context")+".Provider";case Oo:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case Io:return t=e.displayName||null,t!==null?t:Ri(e.type)||"Memo";case mt:t=e._payload,e=e._init;try{return Ri(e(t))}catch{}}return null}function ld(e){var t=e.type;switch(e.tag){case 24:return"Cache";case 9:return(t.displayName||"Context")+".Consumer";case 10:return(t._context.displayName||"Context")+".Provider";case 18:return"DehydratedFragment";case 11:return e=t.render,e=e.displayName||e.name||"",t.displayName||(e!==""?"ForwardRef("+e+")":"ForwardRef");case 7:return"Fragment";case 5:return t;case 4:return"Portal";case 3:return"Root";case 6:return"Text";case 16:return Ri(t);case 8:return t===zo?"StrictMode":"Mode";case 22:return"Offscreen";case 12:return"Profiler";case 21:return"Scope";case 13:return"Suspense";case 19:return"SuspenseList";case 25:return"TracingMarker";case 1:case 0:case 17:case 2:case 14:case 15:if(typeof t=="function")return t.displayName||t.name||null;if(typeof t=="string")return t}return null}function Tt(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function uu(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function id(e){var t=uu(e)?"checked":"value",n=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),r=""+e[t];if(!e.hasOwnProperty(t)&&typeof n<"u"&&typeof n.get=="function"&&typeof n.set=="function"){var l=n.get,i=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return l.call(this)},set:function(o){r=""+o,i.call(this,o)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(o){r=""+o},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function Tr(e){e._valueTracker||(e._valueTracker=id(e))}function cu(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=uu(e)?e.checked?"true":"false":e.value),e=r,e!==n?(t.setValue(e),!0):!1}function il(e){if(e=e||(typeof document<"u"?document:void 0),typeof e>"u")return null;try{return e.activeElement||e.body}catch{return e.body}}function Ti(e,t){var n=t.checked;return J({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??e._wrapperState.initialChecked})}function Ts(e,t){var n=t.defaultValue==null?"":t.defaultValue,r=t.checked!=null?t.checked:t.defaultChecked;n=Tt(t.value!=null?t.value:n),e._wrapperState={initialChecked:r,initialValue:n,controlled:t.type==="checkbox"||t.type==="radio"?t.checked!=null:t.value!=null}}function fu(e,t){t=t.checked,t!=null&&To(e,"checked",t,!1)}function zi(e,t){fu(e,t);var n=Tt(t.value),r=t.type;if(n!=null)r==="number"?(n===0&&e.value===""||e.value!=n)&&(e.value=""+n):e.value!==""+n&&(e.value=""+n);else if(r==="submit"||r==="reset"){e.removeAttribute("value");return}t.hasOwnProperty("value")?Oi(e,t.type,n):t.hasOwnProperty("defaultValue")&&Oi(e,t.type,Tt(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function zs(e,t,n){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var r=t.type;if(!(r!=="submit"&&r!=="reset"||t.value!==void 0&&t.value!==null))return;t=""+e._wrapperState.initialValue,n||t===e.value||(e.value=t),e.defaultValue=t}n=e.name,n!==""&&(e.name=""),e.defaultChecked=!!e._wrapperState.initialChecked,n!==""&&(e.name=n)}function Oi(e,t,n){(t!=="number"||il(e.ownerDocument)!==e)&&(n==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}var Qn=Array.isArray;function vn(e,t,n,r){if(e=e.options,t){t={};for(var l=0;l"+t.valueOf().toString()+"",t=zr.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function ir(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&n.nodeType===3){n.nodeValue=t;return}}e.textContent=t}var Yn={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},od=["Webkit","ms","Moz","O"];Object.keys(Yn).forEach(function(e){od.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),Yn[t]=Yn[e]})});function mu(e,t,n){return t==null||typeof t=="boolean"||t===""?"":n||typeof t!="number"||t===0||Yn.hasOwnProperty(e)&&Yn[e]?(""+t).trim():t+"px"}function vu(e,t){e=e.style;for(var n in t)if(t.hasOwnProperty(n)){var r=n.indexOf("--")===0,l=mu(n,t[n],r);n==="float"&&(n="cssFloat"),r?e.setProperty(n,l):e[n]=l}}var sd=J({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function Mi(e,t){if(t){if(sd[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(E(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(E(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(E(61))}if(t.style!=null&&typeof t.style!="object")throw Error(E(62))}}function Di(e,t){if(e.indexOf("-")===-1)return typeof t.is=="string";switch(e){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}var Fi=null;function Uo(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var Ai=null,gn=null,yn=null;function Us(e){if(e=Cr(e)){if(typeof Ai!="function")throw Error(E(280));var t=e.stateNode;t&&(t=Ml(t),Ai(e.stateNode,e.type,t))}}function gu(e){gn?yn?yn.push(e):yn=[e]:gn=e}function yu(){if(gn){var e=gn,t=yn;if(yn=gn=null,Us(e),t)for(e=0;e>>=0,e===0?32:31-(yd(e)/wd|0)|0}var Or=64,Ir=4194304;function Kn(e){switch(e&-e){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return e&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return e&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;default:return e}}function ul(e,t){var n=e.pendingLanes;if(n===0)return 0;var r=0,l=e.suspendedLanes,i=e.pingedLanes,o=n&268435455;if(o!==0){var a=o&~l;a!==0?r=Kn(a):(i&=o,i!==0&&(r=Kn(i)))}else o=n&~l,o!==0?r=Kn(o):i!==0&&(r=Kn(i));if(r===0)return 0;if(t!==0&&t!==r&&!(t&l)&&(l=r&-r,i=t&-t,l>=i||l===16&&(i&4194240)!==0))return t;if(r&4&&(r|=n&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=r;0n;n++)t.push(e);return t}function Er(e,t,n){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-Ge(t),e[t]=n}function jd(e,t){var n=e.pendingLanes&~t;e.pendingLanes=t,e.suspendedLanes=0,e.pingedLanes=0,e.expiredLanes&=t,e.mutableReadLanes&=t,e.entangledLanes&=t,t=e.entanglements;var r=e.eventTimes;for(e=e.expirationTimes;0=Zn),Hs=" ",Qs=!1;function Fu(e,t){switch(e){case"keyup":return Zd.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function Au(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var on=!1;function bd(e,t){switch(e){case"compositionend":return Au(t);case"keypress":return t.which!==32?null:(Qs=!0,Hs);case"textInput":return e=t.data,e===Hs&&Qs?null:e;default:return null}}function ep(e,t){if(on)return e==="compositionend"||!Wo&&Fu(e,t)?(e=Mu(),Jr=Bo=wt=null,on=!1,e):null;switch(e){case"paste":return null;case"keypress":if(!(t.ctrlKey||t.altKey||t.metaKey)||t.ctrlKey&&t.altKey){if(t.char&&1=t)return{node:n,offset:t-e};e=r}e:{for(;n;){if(n.nextSibling){n=n.nextSibling;break e}n=n.parentNode}n=void 0}n=Ys(n)}}function Wu(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?Wu(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function Hu(){for(var e=window,t=il();t instanceof e.HTMLIFrameElement;){try{var n=typeof t.contentWindow.location.href=="string"}catch{n=!1}if(n)e=t.contentWindow;else break;t=il(e.document)}return t}function Ho(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t&&(t==="input"&&(e.type==="text"||e.type==="search"||e.type==="tel"||e.type==="url"||e.type==="password")||t==="textarea"||e.contentEditable==="true")}function up(e){var t=Hu(),n=e.focusedElem,r=e.selectionRange;if(t!==n&&n&&n.ownerDocument&&Wu(n.ownerDocument.documentElement,n)){if(r!==null&&Ho(n)){if(t=r.start,e=r.end,e===void 0&&(e=t),"selectionStart"in n)n.selectionStart=t,n.selectionEnd=Math.min(e,n.value.length);else if(e=(t=n.ownerDocument||document)&&t.defaultView||window,e.getSelection){e=e.getSelection();var l=n.textContent.length,i=Math.min(r.start,l);r=r.end===void 0?i:Math.min(r.end,l),!e.extend&&i>r&&(l=r,r=i,i=l),l=Js(n,i);var o=Js(n,r);l&&o&&(e.rangeCount!==1||e.anchorNode!==l.node||e.anchorOffset!==l.offset||e.focusNode!==o.node||e.focusOffset!==o.offset)&&(t=t.createRange(),t.setStart(l.node,l.offset),e.removeAllRanges(),i>r?(e.addRange(t),e.extend(o.node,o.offset)):(t.setEnd(o.node,o.offset),e.addRange(t)))}}for(t=[],e=n;e=e.parentNode;)e.nodeType===1&&t.push({element:e,left:e.scrollLeft,top:e.scrollTop});for(typeof n.focus=="function"&&n.focus(),n=0;n=document.documentMode,sn=null,Qi=null,bn=null,Ki=!1;function Zs(e,t,n){var r=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;Ki||sn==null||sn!==il(r)||(r=sn,"selectionStart"in r&&Ho(r)?r={start:r.selectionStart,end:r.selectionEnd}:(r=(r.ownerDocument&&r.ownerDocument.defaultView||window).getSelection(),r={anchorNode:r.anchorNode,anchorOffset:r.anchorOffset,focusNode:r.focusNode,focusOffset:r.focusOffset}),bn&&fr(bn,r)||(bn=r,r=dl(Qi,"onSelect"),0cn||(e.current=qi[cn],qi[cn]=null,cn--)}function H(e,t){cn++,qi[cn]=e.current,e.current=t}var zt={},me=It(zt),ke=It(!1),Kt=zt;function jn(e,t){var n=e.type.contextTypes;if(!n)return zt;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var l={},i;for(i in n)l[i]=t[i];return r&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=l),l}function je(e){return e=e.childContextTypes,e!=null}function hl(){K(ke),K(me)}function la(e,t,n){if(me.current!==zt)throw Error(E(168));H(me,t),H(ke,n)}function bu(e,t,n){var r=e.stateNode;if(t=t.childContextTypes,typeof r.getChildContext!="function")return n;r=r.getChildContext();for(var l in r)if(!(l in t))throw Error(E(108,ld(e)||"Unknown",l));return J({},n,r)}function ml(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||zt,Kt=me.current,H(me,e),H(ke,ke.current),!0}function ia(e,t,n){var r=e.stateNode;if(!r)throw Error(E(169));n?(e=bu(e,t,Kt),r.__reactInternalMemoizedMergedChildContext=e,K(ke),K(me),H(me,e)):K(ke),H(ke,n)}var rt=null,Dl=!1,mi=!1;function ec(e){rt===null?rt=[e]:rt.push(e)}function Sp(e){Dl=!0,ec(e)}function Ut(){if(!mi&&rt!==null){mi=!0;var e=0,t=V;try{var n=rt;for(V=1;e>=o,l-=o,lt=1<<32-Ge(t)+l|n<R?(B=P,P=null):B=P.sibling;var I=m(d,P,p[R],S);if(I===null){P===null&&(P=B);break}e&&P&&I.alternate===null&&t(d,P),f=i(I,f,R),C===null?j=I:C.sibling=I,C=I,P=B}if(R===p.length)return n(d,P),G&&At(d,R),j;if(P===null){for(;RR?(B=P,P=null):B=P.sibling;var ie=m(d,P,I.value,S);if(ie===null){P===null&&(P=B);break}e&&P&&ie.alternate===null&&t(d,P),f=i(ie,f,R),C===null?j=ie:C.sibling=ie,C=ie,P=B}if(I.done)return n(d,P),G&&At(d,R),j;if(P===null){for(;!I.done;R++,I=p.next())I=h(d,I.value,S),I!==null&&(f=i(I,f,R),C===null?j=I:C.sibling=I,C=I);return G&&At(d,R),j}for(P=r(d,P);!I.done;R++,I=p.next())I=x(P,d,R,I.value,S),I!==null&&(e&&I.alternate!==null&&P.delete(I.key===null?R:I.key),f=i(I,f,R),C===null?j=I:C.sibling=I,C=I);return e&&P.forEach(function(T){return t(d,T)}),G&&At(d,R),j}function k(d,f,p,S){if(typeof p=="object"&&p!==null&&p.type===ln&&p.key===null&&(p=p.props.children),typeof p=="object"&&p!==null){switch(p.$$typeof){case Rr:e:{for(var j=p.key,C=f;C!==null;){if(C.key===j){if(j=p.type,j===ln){if(C.tag===7){n(d,C.sibling),f=l(C,p.props.children),f.return=d,d=f;break e}}else if(C.elementType===j||typeof j=="object"&&j!==null&&j.$$typeof===mt&&aa(j)===C.type){n(d,C.sibling),f=l(C,p.props),f.ref=Vn(d,C,p),f.return=d,d=f;break e}n(d,C);break}else t(d,C);C=C.sibling}p.type===ln?(f=Qt(p.props.children,d.mode,S,p.key),f.return=d,d=f):(S=ll(p.type,p.key,p.props,null,d.mode,S),S.ref=Vn(d,f,p),S.return=d,d=S)}return o(d);case rn:e:{for(C=p.key;f!==null;){if(f.key===C)if(f.tag===4&&f.stateNode.containerInfo===p.containerInfo&&f.stateNode.implementation===p.implementation){n(d,f.sibling),f=l(f,p.children||[]),f.return=d,d=f;break e}else{n(d,f);break}else t(d,f);f=f.sibling}f=ji(p,d.mode,S),f.return=d,d=f}return o(d);case mt:return C=p._init,k(d,f,C(p._payload),S)}if(Qn(p))return g(d,f,p,S);if(Mn(p))return w(d,f,p,S);Vr(d,p)}return typeof p=="string"&&p!==""||typeof p=="number"?(p=""+p,f!==null&&f.tag===6?(n(d,f.sibling),f=l(f,p),f.return=d,d=f):(n(d,f),f=ki(p,d.mode,S),f.return=d,d=f),o(d)):n(d,f)}return k}var Nn=lc(!0),ic=lc(!1),yl=It(null),wl=null,pn=null,Xo=null;function Yo(){Xo=pn=wl=null}function Jo(e){var t=yl.current;K(yl),e._currentValue=t}function to(e,t,n){for(;e!==null;){var r=e.alternate;if((e.childLanes&t)!==t?(e.childLanes|=t,r!==null&&(r.childLanes|=t)):r!==null&&(r.childLanes&t)!==t&&(r.childLanes|=t),e===n)break;e=e.return}}function xn(e,t){wl=e,Xo=pn=null,e=e.dependencies,e!==null&&e.firstContext!==null&&(e.lanes&t&&(Se=!0),e.firstContext=null)}function Ae(e){var t=e._currentValue;if(Xo!==e)if(e={context:e,memoizedValue:t,next:null},pn===null){if(wl===null)throw Error(E(308));pn=e,wl.dependencies={lanes:0,firstContext:e}}else pn=pn.next=e;return t}var $t=null;function Zo(e){$t===null?$t=[e]:$t.push(e)}function oc(e,t,n,r){var l=t.interleaved;return l===null?(n.next=n,Zo(t)):(n.next=l.next,l.next=n),t.interleaved=n,ut(e,r)}function ut(e,t){e.lanes|=t;var n=e.alternate;for(n!==null&&(n.lanes|=t),n=e,e=e.return;e!==null;)e.childLanes|=t,n=e.alternate,n!==null&&(n.childLanes|=t),n=e,e=e.return;return n.tag===3?n.stateNode:null}var vt=!1;function qo(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function sc(e,t){e=e.updateQueue,t.updateQueue===e&&(t.updateQueue={baseState:e.baseState,firstBaseUpdate:e.firstBaseUpdate,lastBaseUpdate:e.lastBaseUpdate,shared:e.shared,effects:e.effects})}function ot(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function Ct(e,t,n){var r=e.updateQueue;if(r===null)return null;if(r=r.shared,F&2){var l=r.pending;return l===null?t.next=t:(t.next=l.next,l.next=t),r.pending=t,ut(e,n)}return l=r.interleaved,l===null?(t.next=t,Zo(r)):(t.next=l.next,l.next=t),r.interleaved=t,ut(e,n)}function qr(e,t,n){if(t=t.updateQueue,t!==null&&(t=t.shared,(n&4194240)!==0)){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,Do(e,n)}}function ua(e,t){var n=e.updateQueue,r=e.alternate;if(r!==null&&(r=r.updateQueue,n===r)){var l=null,i=null;if(n=n.firstBaseUpdate,n!==null){do{var o={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};i===null?l=i=o:i=i.next=o,n=n.next}while(n!==null);i===null?l=i=t:i=i.next=t}else l=i=t;n={baseState:r.baseState,firstBaseUpdate:l,lastBaseUpdate:i,shared:r.shared,effects:r.effects},e.updateQueue=n;return}e=n.lastBaseUpdate,e===null?n.firstBaseUpdate=t:e.next=t,n.lastBaseUpdate=t}function xl(e,t,n,r){var l=e.updateQueue;vt=!1;var i=l.firstBaseUpdate,o=l.lastBaseUpdate,a=l.shared.pending;if(a!==null){l.shared.pending=null;var s=a,c=s.next;s.next=null,o===null?i=c:o.next=c,o=s;var v=e.alternate;v!==null&&(v=v.updateQueue,a=v.lastBaseUpdate,a!==o&&(a===null?v.firstBaseUpdate=c:a.next=c,v.lastBaseUpdate=s))}if(i!==null){var h=l.baseState;o=0,v=c=s=null,a=i;do{var m=a.lane,x=a.eventTime;if((r&m)===m){v!==null&&(v=v.next={eventTime:x,lane:0,tag:a.tag,payload:a.payload,callback:a.callback,next:null});e:{var g=e,w=a;switch(m=t,x=n,w.tag){case 1:if(g=w.payload,typeof g=="function"){h=g.call(x,h,m);break e}h=g;break e;case 3:g.flags=g.flags&-65537|128;case 0:if(g=w.payload,m=typeof g=="function"?g.call(x,h,m):g,m==null)break e;h=J({},h,m);break e;case 2:vt=!0}}a.callback!==null&&a.lane!==0&&(e.flags|=64,m=l.effects,m===null?l.effects=[a]:m.push(a))}else x={eventTime:x,lane:m,tag:a.tag,payload:a.payload,callback:a.callback,next:null},v===null?(c=v=x,s=h):v=v.next=x,o|=m;if(a=a.next,a===null){if(a=l.shared.pending,a===null)break;m=a,a=m.next,m.next=null,l.lastBaseUpdate=m,l.shared.pending=null}}while(!0);if(v===null&&(s=h),l.baseState=s,l.firstBaseUpdate=c,l.lastBaseUpdate=v,t=l.shared.interleaved,t!==null){l=t;do o|=l.lane,l=l.next;while(l!==t)}else i===null&&(l.shared.lanes=0);Yt|=o,e.lanes=o,e.memoizedState=h}}function ca(e,t,n){if(e=t.effects,t.effects=null,e!==null)for(t=0;tn?n:4,e(!0);var r=gi.transition;gi.transition={};try{e(!1),t()}finally{V=n,gi.transition=r}}function Ec(){return Be().memoizedState}function Np(e,t,n){var r=_t(e);if(n={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null},Nc(e))Cc(t,n);else if(n=oc(e,t,n,r),n!==null){var l=ge();Xe(n,e,r,l),Pc(n,t,r)}}function Cp(e,t,n){var r=_t(e),l={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null};if(Nc(e))Cc(t,l);else{var i=e.alternate;if(e.lanes===0&&(i===null||i.lanes===0)&&(i=t.lastRenderedReducer,i!==null))try{var o=t.lastRenderedState,a=i(o,n);if(l.hasEagerState=!0,l.eagerState=a,Ye(a,o)){var s=t.interleaved;s===null?(l.next=l,Zo(t)):(l.next=s.next,s.next=l),t.interleaved=l;return}}catch{}finally{}n=oc(e,t,l,r),n!==null&&(l=ge(),Xe(n,e,r,l),Pc(n,t,r))}}function Nc(e){var t=e.alternate;return e===Y||t!==null&&t===Y}function Cc(e,t){er=kl=!0;var n=e.pending;n===null?t.next=t:(t.next=n.next,n.next=t),e.pending=t}function Pc(e,t,n){if(n&4194240){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,Do(e,n)}}var jl={readContext:Ae,useCallback:de,useContext:de,useEffect:de,useImperativeHandle:de,useInsertionEffect:de,useLayoutEffect:de,useMemo:de,useReducer:de,useRef:de,useState:de,useDebugValue:de,useDeferredValue:de,useTransition:de,useMutableSource:de,useSyncExternalStore:de,useId:de,unstable_isNewReconciler:!1},Pp={readContext:Ae,useCallback:function(e,t){return qe().memoizedState=[e,t===void 0?null:t],e},useContext:Ae,useEffect:da,useImperativeHandle:function(e,t,n){return n=n!=null?n.concat([e]):null,el(4194308,4,wc.bind(null,t,e),n)},useLayoutEffect:function(e,t){return el(4194308,4,e,t)},useInsertionEffect:function(e,t){return el(4,2,e,t)},useMemo:function(e,t){var n=qe();return t=t===void 0?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=qe();return t=n!==void 0?n(t):t,r.memoizedState=r.baseState=t,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:e,lastRenderedState:t},r.queue=e,e=e.dispatch=Np.bind(null,Y,e),[r.memoizedState,e]},useRef:function(e){var t=qe();return e={current:e},t.memoizedState=e},useState:fa,useDebugValue:os,useDeferredValue:function(e){return qe().memoizedState=e},useTransition:function(){var e=fa(!1),t=e[0];return e=Ep.bind(null,e[1]),qe().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,n){var r=Y,l=qe();if(G){if(n===void 0)throw Error(E(407));n=n()}else{if(n=t(),ae===null)throw Error(E(349));Xt&30||fc(r,t,n)}l.memoizedState=n;var i={value:n,getSnapshot:t};return l.queue=i,da(pc.bind(null,r,i,e),[e]),r.flags|=2048,wr(9,dc.bind(null,r,i,n,t),void 0,null),n},useId:function(){var e=qe(),t=ae.identifierPrefix;if(G){var n=it,r=lt;n=(r&~(1<<32-Ge(r)-1)).toString(32)+n,t=":"+t+"R"+n,n=gr++,0<\/script>",e=e.removeChild(e.firstChild)):typeof r.is=="string"?e=o.createElement(n,{is:r.is}):(e=o.createElement(n),n==="select"&&(o=e,r.multiple?o.multiple=!0:r.size&&(o.size=r.size))):e=o.createElementNS(e,n),e[be]=t,e[hr]=r,Dc(e,t,!1,!1),t.stateNode=e;e:{switch(o=Di(n,r),n){case"dialog":Q("cancel",e),Q("close",e),l=r;break;case"iframe":case"object":case"embed":Q("load",e),l=r;break;case"video":case"audio":for(l=0;l_n&&(t.flags|=128,r=!0,$n(i,!1),t.lanes=4194304)}else{if(!r)if(e=Sl(o),e!==null){if(t.flags|=128,r=!0,n=e.updateQueue,n!==null&&(t.updateQueue=n,t.flags|=4),$n(i,!0),i.tail===null&&i.tailMode==="hidden"&&!o.alternate&&!G)return pe(t),null}else 2*te()-i.renderingStartTime>_n&&n!==1073741824&&(t.flags|=128,r=!0,$n(i,!1),t.lanes=4194304);i.isBackwards?(o.sibling=t.child,t.child=o):(n=i.last,n!==null?n.sibling=o:t.child=o,i.last=o)}return i.tail!==null?(t=i.tail,i.rendering=t,i.tail=t.sibling,i.renderingStartTime=te(),t.sibling=null,n=X.current,H(X,r?n&1|2:n&1),t):(pe(t),null);case 22:case 23:return ds(),r=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==r&&(t.flags|=8192),r&&t.mode&1?_e&1073741824&&(pe(t),t.subtreeFlags&6&&(t.flags|=8192)):pe(t),null;case 24:return null;case 25:return null}throw Error(E(156,t.tag))}function Up(e,t){switch(Ko(t),t.tag){case 1:return je(t.type)&&hl(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return Cn(),K(ke),K(me),ts(),e=t.flags,e&65536&&!(e&128)?(t.flags=e&-65537|128,t):null;case 5:return es(t),null;case 13:if(K(X),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(E(340));En()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return K(X),null;case 4:return Cn(),null;case 10:return Jo(t.type._context),null;case 22:case 23:return ds(),null;case 24:return null;default:return null}}var Wr=!1,he=!1,Mp=typeof WeakSet=="function"?WeakSet:Set,L=null;function hn(e,t){var n=e.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(r){Z(e,t,r)}else n.current=null}function co(e,t,n){try{n()}catch(r){Z(e,t,r)}}var ja=!1;function Dp(e,t){if(Gi=cl,e=Hu(),Ho(e)){if("selectionStart"in e)var n={start:e.selectionStart,end:e.selectionEnd};else e:{n=(n=e.ownerDocument)&&n.defaultView||window;var r=n.getSelection&&n.getSelection();if(r&&r.rangeCount!==0){n=r.anchorNode;var l=r.anchorOffset,i=r.focusNode;r=r.focusOffset;try{n.nodeType,i.nodeType}catch{n=null;break e}var o=0,a=-1,s=-1,c=0,v=0,h=e,m=null;t:for(;;){for(var x;h!==n||l!==0&&h.nodeType!==3||(a=o+l),h!==i||r!==0&&h.nodeType!==3||(s=o+r),h.nodeType===3&&(o+=h.nodeValue.length),(x=h.firstChild)!==null;)m=h,h=x;for(;;){if(h===e)break t;if(m===n&&++c===l&&(a=o),m===i&&++v===r&&(s=o),(x=h.nextSibling)!==null)break;h=m,m=h.parentNode}h=x}n=a===-1||s===-1?null:{start:a,end:s}}else n=null}n=n||{start:0,end:0}}else n=null;for(Xi={focusedElem:e,selectionRange:n},cl=!1,L=t;L!==null;)if(t=L,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,L=e;else for(;L!==null;){t=L;try{var g=t.alternate;if(t.flags&1024)switch(t.tag){case 0:case 11:case 15:break;case 1:if(g!==null){var w=g.memoizedProps,k=g.memoizedState,d=t.stateNode,f=d.getSnapshotBeforeUpdate(t.elementType===t.type?w:He(t.type,w),k);d.__reactInternalSnapshotBeforeUpdate=f}break;case 3:var p=t.stateNode.containerInfo;p.nodeType===1?p.textContent="":p.nodeType===9&&p.documentElement&&p.removeChild(p.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(E(163))}}catch(S){Z(t,t.return,S)}if(e=t.sibling,e!==null){e.return=t.return,L=e;break}L=t.return}return g=ja,ja=!1,g}function tr(e,t,n){var r=t.updateQueue;if(r=r!==null?r.lastEffect:null,r!==null){var l=r=r.next;do{if((l.tag&e)===e){var i=l.destroy;l.destroy=void 0,i!==void 0&&co(t,n,i)}l=l.next}while(l!==r)}}function Bl(e,t){if(t=t.updateQueue,t=t!==null?t.lastEffect:null,t!==null){var n=t=t.next;do{if((n.tag&e)===e){var r=n.create;n.destroy=r()}n=n.next}while(n!==t)}}function fo(e){var t=e.ref;if(t!==null){var n=e.stateNode;switch(e.tag){case 5:e=n;break;default:e=n}typeof t=="function"?t(e):t.current=e}}function Bc(e){var t=e.alternate;t!==null&&(e.alternate=null,Bc(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[be],delete t[hr],delete t[Zi],delete t[wp],delete t[xp])),e.stateNode=null,e.return=null,e.dependencies=null,e.memoizedProps=null,e.memoizedState=null,e.pendingProps=null,e.stateNode=null,e.updateQueue=null}function Vc(e){return e.tag===5||e.tag===3||e.tag===4}function Ea(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||Vc(e.return))return null;e=e.return}for(e.sibling.return=e.return,e=e.sibling;e.tag!==5&&e.tag!==6&&e.tag!==18;){if(e.flags&2||e.child===null||e.tag===4)continue e;e.child.return=e,e=e.child}if(!(e.flags&2))return e.stateNode}}function po(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.nodeType===8?n.parentNode.insertBefore(e,t):n.insertBefore(e,t):(n.nodeType===8?(t=n.parentNode,t.insertBefore(e,n)):(t=n,t.appendChild(e)),n=n._reactRootContainer,n!=null||t.onclick!==null||(t.onclick=pl));else if(r!==4&&(e=e.child,e!==null))for(po(e,t,n),e=e.sibling;e!==null;)po(e,t,n),e=e.sibling}function ho(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.insertBefore(e,t):n.appendChild(e);else if(r!==4&&(e=e.child,e!==null))for(ho(e,t,n),e=e.sibling;e!==null;)ho(e,t,n),e=e.sibling}var ue=null,Qe=!1;function ht(e,t,n){for(n=n.child;n!==null;)$c(e,t,n),n=n.sibling}function $c(e,t,n){if(et&&typeof et.onCommitFiberUnmount=="function")try{et.onCommitFiberUnmount(zl,n)}catch{}switch(n.tag){case 5:he||hn(n,t);case 6:var r=ue,l=Qe;ue=null,ht(e,t,n),ue=r,Qe=l,ue!==null&&(Qe?(e=ue,n=n.stateNode,e.nodeType===8?e.parentNode.removeChild(n):e.removeChild(n)):ue.removeChild(n.stateNode));break;case 18:ue!==null&&(Qe?(e=ue,n=n.stateNode,e.nodeType===8?hi(e.parentNode,n):e.nodeType===1&&hi(e,n),ur(e)):hi(ue,n.stateNode));break;case 4:r=ue,l=Qe,ue=n.stateNode.containerInfo,Qe=!0,ht(e,t,n),ue=r,Qe=l;break;case 0:case 11:case 14:case 15:if(!he&&(r=n.updateQueue,r!==null&&(r=r.lastEffect,r!==null))){l=r=r.next;do{var i=l,o=i.destroy;i=i.tag,o!==void 0&&(i&2||i&4)&&co(n,t,o),l=l.next}while(l!==r)}ht(e,t,n);break;case 1:if(!he&&(hn(n,t),r=n.stateNode,typeof r.componentWillUnmount=="function"))try{r.props=n.memoizedProps,r.state=n.memoizedState,r.componentWillUnmount()}catch(a){Z(n,t,a)}ht(e,t,n);break;case 21:ht(e,t,n);break;case 22:n.mode&1?(he=(r=he)||n.memoizedState!==null,ht(e,t,n),he=r):ht(e,t,n);break;default:ht(e,t,n)}}function Na(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var n=e.stateNode;n===null&&(n=e.stateNode=new Mp),t.forEach(function(r){var l=Kp.bind(null,e,r);n.has(r)||(n.add(r),r.then(l,l))})}}function We(e,t){var n=t.deletions;if(n!==null)for(var r=0;rl&&(l=o),r&=~i}if(r=l,r=te()-r,r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*Ap(r/1960))-r,10e?16:e,xt===null)var r=!1;else{if(e=xt,xt=null,Cl=0,F&6)throw Error(E(331));var l=F;for(F|=4,L=e.current;L!==null;){var i=L,o=i.child;if(L.flags&16){var a=i.deletions;if(a!==null){for(var s=0;ste()-cs?Ht(e,0):us|=n),Ee(e,t)}function Jc(e,t){t===0&&(e.mode&1?(t=Ir,Ir<<=1,!(Ir&130023424)&&(Ir=4194304)):t=1);var n=ge();e=ut(e,t),e!==null&&(Er(e,t,n),Ee(e,n))}function Qp(e){var t=e.memoizedState,n=0;t!==null&&(n=t.retryLane),Jc(e,n)}function Kp(e,t){var n=0;switch(e.tag){case 13:var r=e.stateNode,l=e.memoizedState;l!==null&&(n=l.retryLane);break;case 19:r=e.stateNode;break;default:throw Error(E(314))}r!==null&&r.delete(t),Jc(e,n)}var Zc;Zc=function(e,t,n){if(e!==null)if(e.memoizedProps!==t.pendingProps||ke.current)Se=!0;else{if(!(e.lanes&n)&&!(t.flags&128))return Se=!1,Op(e,t,n);Se=!!(e.flags&131072)}else Se=!1,G&&t.flags&1048576&&tc(t,gl,t.index);switch(t.lanes=0,t.tag){case 2:var r=t.type;tl(e,t),e=t.pendingProps;var l=jn(t,me.current);xn(t,n),l=rs(null,t,r,e,l,n);var i=ls();return t.flags|=1,typeof l=="object"&&l!==null&&typeof l.render=="function"&&l.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,je(r)?(i=!0,ml(t)):i=!1,t.memoizedState=l.state!==null&&l.state!==void 0?l.state:null,qo(t),l.updater=Al,t.stateNode=l,l._reactInternals=t,ro(t,r,e,n),t=oo(null,t,r,!0,i,n)):(t.tag=0,G&&i&&Qo(t),ve(null,t,l,n),t=t.child),t;case 16:r=t.elementType;e:{switch(tl(e,t),e=t.pendingProps,l=r._init,r=l(r._payload),t.type=r,l=t.tag=Xp(r),e=He(r,e),l){case 0:t=io(null,t,r,e,n);break e;case 1:t=xa(null,t,r,e,n);break e;case 11:t=ya(null,t,r,e,n);break e;case 14:t=wa(null,t,r,He(r.type,e),n);break e}throw Error(E(306,r,""))}return t;case 0:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:He(r,l),io(e,t,r,l,n);case 1:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:He(r,l),xa(e,t,r,l,n);case 3:e:{if(Ic(t),e===null)throw Error(E(387));r=t.pendingProps,i=t.memoizedState,l=i.element,sc(e,t),xl(t,r,null,n);var o=t.memoizedState;if(r=o.element,i.isDehydrated)if(i={element:r,isDehydrated:!1,cache:o.cache,pendingSuspenseBoundaries:o.pendingSuspenseBoundaries,transitions:o.transitions},t.updateQueue.baseState=i,t.memoizedState=i,t.flags&256){l=Pn(Error(E(423)),t),t=Sa(e,t,r,n,l);break e}else if(r!==l){l=Pn(Error(E(424)),t),t=Sa(e,t,r,n,l);break e}else for(Le=Nt(t.stateNode.containerInfo.firstChild),Re=t,G=!0,Ke=null,n=ic(t,null,r,n),t.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(En(),r===l){t=ct(e,t,n);break e}ve(e,t,r,n)}t=t.child}return t;case 5:return ac(t),e===null&&eo(t),r=t.type,l=t.pendingProps,i=e!==null?e.memoizedProps:null,o=l.children,Yi(r,l)?o=null:i!==null&&Yi(r,i)&&(t.flags|=32),Oc(e,t),ve(e,t,o,n),t.child;case 6:return e===null&&eo(t),null;case 13:return Uc(e,t,n);case 4:return bo(t,t.stateNode.containerInfo),r=t.pendingProps,e===null?t.child=Nn(t,null,r,n):ve(e,t,r,n),t.child;case 11:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:He(r,l),ya(e,t,r,l,n);case 7:return ve(e,t,t.pendingProps,n),t.child;case 8:return ve(e,t,t.pendingProps.children,n),t.child;case 12:return ve(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,l=t.pendingProps,i=t.memoizedProps,o=l.value,H(yl,r._currentValue),r._currentValue=o,i!==null)if(Ye(i.value,o)){if(i.children===l.children&&!ke.current){t=ct(e,t,n);break e}}else for(i=t.child,i!==null&&(i.return=t);i!==null;){var a=i.dependencies;if(a!==null){o=i.child;for(var s=a.firstContext;s!==null;){if(s.context===r){if(i.tag===1){s=ot(-1,n&-n),s.tag=2;var c=i.updateQueue;if(c!==null){c=c.shared;var v=c.pending;v===null?s.next=s:(s.next=v.next,v.next=s),c.pending=s}}i.lanes|=n,s=i.alternate,s!==null&&(s.lanes|=n),to(i.return,n,t),a.lanes|=n;break}s=s.next}}else if(i.tag===10)o=i.type===t.type?null:i.child;else if(i.tag===18){if(o=i.return,o===null)throw Error(E(341));o.lanes|=n,a=o.alternate,a!==null&&(a.lanes|=n),to(o,n,t),o=i.sibling}else o=i.child;if(o!==null)o.return=i;else for(o=i;o!==null;){if(o===t){o=null;break}if(i=o.sibling,i!==null){i.return=o.return,o=i;break}o=o.return}i=o}ve(e,t,l.children,n),t=t.child}return t;case 9:return l=t.type,r=t.pendingProps.children,xn(t,n),l=Ae(l),r=r(l),t.flags|=1,ve(e,t,r,n),t.child;case 14:return r=t.type,l=He(r,t.pendingProps),l=He(r.type,l),wa(e,t,r,l,n);case 15:return Tc(e,t,t.type,t.pendingProps,n);case 17:return r=t.type,l=t.pendingProps,l=t.elementType===r?l:He(r,l),tl(e,t),t.tag=1,je(r)?(e=!0,ml(t)):e=!1,xn(t,n),_c(t,r,l),ro(t,r,l,n),oo(null,t,r,!0,e,n);case 19:return Mc(e,t,n);case 22:return zc(e,t,n)}throw Error(E(156,t.tag))};function qc(e,t){return Nu(e,t)}function Gp(e,t,n,r){this.tag=e,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=t,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=r,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function De(e,t,n,r){return new Gp(e,t,n,r)}function hs(e){return e=e.prototype,!(!e||!e.isReactComponent)}function Xp(e){if(typeof e=="function")return hs(e)?1:0;if(e!=null){if(e=e.$$typeof,e===Oo)return 11;if(e===Io)return 14}return 2}function Lt(e,t){var n=e.alternate;return n===null?(n=De(e.tag,t,e.key,e.mode),n.elementType=e.elementType,n.type=e.type,n.stateNode=e.stateNode,n.alternate=e,e.alternate=n):(n.pendingProps=t,n.type=e.type,n.flags=0,n.subtreeFlags=0,n.deletions=null),n.flags=e.flags&14680064,n.childLanes=e.childLanes,n.lanes=e.lanes,n.child=e.child,n.memoizedProps=e.memoizedProps,n.memoizedState=e.memoizedState,n.updateQueue=e.updateQueue,t=e.dependencies,n.dependencies=t===null?null:{lanes:t.lanes,firstContext:t.firstContext},n.sibling=e.sibling,n.index=e.index,n.ref=e.ref,n}function ll(e,t,n,r,l,i){var o=2;if(r=e,typeof e=="function")hs(e)&&(o=1);else if(typeof e=="string")o=5;else e:switch(e){case ln:return Qt(n.children,l,i,t);case zo:o=8,l|=8;break;case Pi:return e=De(12,n,t,l|2),e.elementType=Pi,e.lanes=i,e;case _i:return e=De(13,n,t,l),e.elementType=_i,e.lanes=i,e;case Li:return e=De(19,n,t,l),e.elementType=Li,e.lanes=i,e;case au:return $l(n,l,i,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case ou:o=10;break e;case su:o=9;break e;case Oo:o=11;break e;case Io:o=14;break e;case mt:o=16,r=null;break e}throw Error(E(130,e==null?e:typeof e,""))}return t=De(o,n,t,l),t.elementType=e,t.type=r,t.lanes=i,t}function Qt(e,t,n,r){return e=De(7,e,r,t),e.lanes=n,e}function $l(e,t,n,r){return e=De(22,e,r,t),e.elementType=au,e.lanes=n,e.stateNode={isHidden:!1},e}function ki(e,t,n){return e=De(6,e,null,t),e.lanes=n,e}function ji(e,t,n){return t=De(4,e.children!==null?e.children:[],e.key,t),t.lanes=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function Yp(e,t,n,r,l){this.tag=t,this.containerInfo=e,this.finishedWork=this.pingCache=this.current=this.pendingChildren=null,this.timeoutHandle=-1,this.callbackNode=this.pendingContext=this.context=null,this.callbackPriority=0,this.eventTimes=ri(0),this.expirationTimes=ri(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=ri(0),this.identifierPrefix=r,this.onRecoverableError=l,this.mutableSourceEagerHydrationData=null}function ms(e,t,n,r,l,i,o,a,s){return e=new Yp(e,t,n,a,s),t===1?(t=1,i===!0&&(t|=8)):t=0,i=De(3,null,null,t),e.current=i,i.stateNode=e,i.memoizedState={element:r,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},qo(i),e}function Jp(e,t,n){var r=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(nf)}catch(e){console.error(e)}}nf(),nu.exports=ze;var th=nu.exports,rf,Oa=th;rf=Oa.createRoot,Oa.hydrateRoot;/** + * @remix-run/router v1.23.2 + * + * Copyright (c) Remix Software Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE.md file in the root directory of this source tree. + * + * @license MIT + */function Sr(){return Sr=Object.assign?Object.assign.bind():function(e){for(var t=1;t"u")throw new Error(t)}function ws(e,t){if(!e){typeof console<"u"&&console.warn(t);try{throw new Error(t)}catch{}}}function rh(){return Math.random().toString(36).substr(2,8)}function Ua(e,t){return{usr:e.state,key:e.key,idx:t}}function wo(e,t,n,r){return n===void 0&&(n=null),Sr({pathname:typeof e=="string"?e:e.pathname,search:"",hash:""},typeof t=="string"?On(t):t,{state:n,key:t&&t.key||r||rh()})}function Ll(e){let{pathname:t="/",search:n="",hash:r=""}=e;return n&&n!=="?"&&(t+=n.charAt(0)==="?"?n:"?"+n),r&&r!=="#"&&(t+=r.charAt(0)==="#"?r:"#"+r),t}function On(e){let t={};if(e){let n=e.indexOf("#");n>=0&&(t.hash=e.substr(n),e=e.substr(0,n));let r=e.indexOf("?");r>=0&&(t.search=e.substr(r),e=e.substr(0,r)),e&&(t.pathname=e)}return t}function lh(e,t,n,r){r===void 0&&(r={});let{window:l=document.defaultView,v5Compat:i=!1}=r,o=l.history,a=St.Pop,s=null,c=v();c==null&&(c=0,o.replaceState(Sr({},o.state,{idx:c}),""));function v(){return(o.state||{idx:null}).idx}function h(){a=St.Pop;let k=v(),d=k==null?null:k-c;c=k,s&&s({action:a,location:w.location,delta:d})}function m(k,d){a=St.Push;let f=wo(w.location,k,d);c=v()+1;let p=Ua(f,c),S=w.createHref(f);try{o.pushState(p,"",S)}catch(j){if(j instanceof DOMException&&j.name==="DataCloneError")throw j;l.location.assign(S)}i&&s&&s({action:a,location:w.location,delta:1})}function x(k,d){a=St.Replace;let f=wo(w.location,k,d);c=v();let p=Ua(f,c),S=w.createHref(f);o.replaceState(p,"",S),i&&s&&s({action:a,location:w.location,delta:0})}function g(k){let d=l.location.origin!=="null"?l.location.origin:l.location.href,f=typeof k=="string"?k:Ll(k);return f=f.replace(/ $/,"%20"),q(d,"No window.location.(origin|href) available to create URL for href: "+f),new URL(f,d)}let w={get action(){return a},get location(){return e(l,o)},listen(k){if(s)throw new Error("A history only accepts one active listener");return l.addEventListener(Ia,h),s=k,()=>{l.removeEventListener(Ia,h),s=null}},createHref(k){return t(l,k)},createURL:g,encodeLocation(k){let d=g(k);return{pathname:d.pathname,search:d.search,hash:d.hash}},push:m,replace:x,go(k){return o.go(k)}};return w}var Ma;(function(e){e.data="data",e.deferred="deferred",e.redirect="redirect",e.error="error"})(Ma||(Ma={}));function ih(e,t,n){return n===void 0&&(n="/"),oh(e,t,n)}function oh(e,t,n,r){let l=typeof t=="string"?On(t):t,i=Ln(l.pathname||"/",n);if(i==null)return null;let o=lf(e);sh(o);let a=null;for(let s=0;a==null&&s{let s={relativePath:a===void 0?i.path||"":a,caseSensitive:i.caseSensitive===!0,childrenIndex:o,route:i};s.relativePath.startsWith("/")&&(q(s.relativePath.startsWith(r),'Absolute route path "'+s.relativePath+'" nested under path '+('"'+r+'" is not valid. An absolute child route path ')+"must start with the combined path of all its parent routes."),s.relativePath=s.relativePath.slice(r.length));let c=Rt([r,s.relativePath]),v=n.concat(s);i.children&&i.children.length>0&&(q(i.index!==!0,"Index routes must not have child routes. Please remove "+('all child routes from route path "'+c+'".')),lf(i.children,t,v,c)),!(i.path==null&&!i.index)&&t.push({path:c,score:hh(c,i.index),routesMeta:v})};return e.forEach((i,o)=>{var a;if(i.path===""||!((a=i.path)!=null&&a.includes("?")))l(i,o);else for(let s of of(i.path))l(i,o,s)}),t}function of(e){let t=e.split("/");if(t.length===0)return[];let[n,...r]=t,l=n.endsWith("?"),i=n.replace(/\?$/,"");if(r.length===0)return l?[i,""]:[i];let o=of(r.join("/")),a=[];return a.push(...o.map(s=>s===""?i:[i,s].join("/"))),l&&a.push(...o),a.map(s=>e.startsWith("/")&&s===""?"/":s)}function sh(e){e.sort((t,n)=>t.score!==n.score?n.score-t.score:mh(t.routesMeta.map(r=>r.childrenIndex),n.routesMeta.map(r=>r.childrenIndex)))}const ah=/^:[\w-]+$/,uh=3,ch=2,fh=1,dh=10,ph=-2,Da=e=>e==="*";function hh(e,t){let n=e.split("/"),r=n.length;return n.some(Da)&&(r+=ph),t&&(r+=ch),n.filter(l=>!Da(l)).reduce((l,i)=>l+(ah.test(i)?uh:i===""?fh:dh),r)}function mh(e,t){return e.length===t.length&&e.slice(0,-1).every((r,l)=>r===t[l])?e[e.length-1]-t[t.length-1]:0}function vh(e,t,n){let{routesMeta:r}=e,l={},i="/",o=[];for(let a=0;a{let{paramName:m,isOptional:x}=v;if(m==="*"){let w=a[h]||"";o=i.slice(0,i.length-w.length).replace(/(.)\/+$/,"$1")}const g=a[h];return x&&!g?c[m]=void 0:c[m]=(g||"").replace(/%2F/g,"/"),c},{}),pathname:i,pathnameBase:o,pattern:e}}function gh(e,t,n){t===void 0&&(t=!1),n===void 0&&(n=!0),ws(e==="*"||!e.endsWith("*")||e.endsWith("/*"),'Route path "'+e+'" will be treated as if it were '+('"'+e.replace(/\*$/,"/*")+'" because the `*` character must ')+"always follow a `/` in the pattern. To get rid of this warning, "+('please change the route path to "'+e.replace(/\*$/,"/*")+'".'));let r=[],l="^"+e.replace(/\/*\*?$/,"").replace(/^\/*/,"/").replace(/[\\.*+^${}|()[\]]/g,"\\$&").replace(/\/:([\w-]+)(\?)?/g,(o,a,s)=>(r.push({paramName:a,isOptional:s!=null}),s?"/?([^\\/]+)?":"/([^\\/]+)"));return e.endsWith("*")?(r.push({paramName:"*"}),l+=e==="*"||e==="/*"?"(.*)$":"(?:\\/(.+)|\\/*)$"):n?l+="\\/*$":e!==""&&e!=="/"&&(l+="(?:(?=\\/|$))"),[new RegExp(l,t?void 0:"i"),r]}function yh(e){try{return e.split("/").map(t=>decodeURIComponent(t).replace(/\//g,"%2F")).join("/")}catch(t){return ws(!1,'The URL path "'+e+'" could not be decoded because it is is a malformed URL segment. This is probably due to a bad percent '+("encoding ("+t+").")),e}}function Ln(e,t){if(t==="/")return e;if(!e.toLowerCase().startsWith(t.toLowerCase()))return null;let n=t.endsWith("/")?t.length-1:t.length,r=e.charAt(n);return r&&r!=="/"?null:e.slice(n)||"/"}const wh=/^(?:[a-z][a-z0-9+.-]*:|\/\/)/i,xh=e=>wh.test(e);function Sh(e,t){t===void 0&&(t="/");let{pathname:n,search:r="",hash:l=""}=typeof e=="string"?On(e):e,i;if(n)if(xh(n))i=n;else{if(n.includes("//")){let o=n;n=n.replace(/\/\/+/g,"/"),ws(!1,"Pathnames cannot have embedded double slashes - normalizing "+(o+" -> "+n))}n.startsWith("/")?i=Fa(n.substring(1),"/"):i=Fa(n,t)}else i=t;return{pathname:i,search:Eh(r),hash:Nh(l)}}function Fa(e,t){let n=t.replace(/\/+$/,"").split("/");return e.split("/").forEach(l=>{l===".."?n.length>1&&n.pop():l!=="."&&n.push(l)}),n.length>1?n.join("/"):"/"}function Ei(e,t,n,r){return"Cannot include a '"+e+"' character in a manually specified "+("`to."+t+"` field ["+JSON.stringify(r)+"]. Please separate it out to the ")+("`to."+n+"` field. Alternatively you may provide the full path as ")+'a string in and the router will parse it for you.'}function kh(e){return e.filter((t,n)=>n===0||t.route.path&&t.route.path.length>0)}function sf(e,t){let n=kh(e);return t?n.map((r,l)=>l===n.length-1?r.pathname:r.pathnameBase):n.map(r=>r.pathnameBase)}function af(e,t,n,r){r===void 0&&(r=!1);let l;typeof e=="string"?l=On(e):(l=Sr({},e),q(!l.pathname||!l.pathname.includes("?"),Ei("?","pathname","search",l)),q(!l.pathname||!l.pathname.includes("#"),Ei("#","pathname","hash",l)),q(!l.search||!l.search.includes("#"),Ei("#","search","hash",l)));let i=e===""||l.pathname==="",o=i?"/":l.pathname,a;if(o==null)a=n;else{let h=t.length-1;if(!r&&o.startsWith("..")){let m=o.split("/");for(;m[0]==="..";)m.shift(),h-=1;l.pathname=m.join("/")}a=h>=0?t[h]:"/"}let s=Sh(l,a),c=o&&o!=="/"&&o.endsWith("/"),v=(i||o===".")&&n.endsWith("/");return!s.pathname.endsWith("/")&&(c||v)&&(s.pathname+="/"),s}const Rt=e=>e.join("/").replace(/\/\/+/g,"/"),jh=e=>e.replace(/\/+$/,"").replace(/^\/*/,"/"),Eh=e=>!e||e==="?"?"":e.startsWith("?")?e:"?"+e,Nh=e=>!e||e==="#"?"":e.startsWith("#")?e:"#"+e;function Ch(e){return e!=null&&typeof e.status=="number"&&typeof e.statusText=="string"&&typeof e.internal=="boolean"&&"data"in e}const uf=["post","put","patch","delete"];new Set(uf);const Ph=["get",...uf];new Set(Ph);/** + * React Router v6.30.3 + * + * Copyright (c) Remix Software Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE.md file in the root directory of this source tree. + * + * @license MIT + */function kr(){return kr=Object.assign?Object.assign.bind():function(e){for(var t=1;t{a.current=!0}),y.useCallback(function(c,v){if(v===void 0&&(v={}),!a.current)return;if(typeof c=="number"){r.go(c);return}let h=af(c,JSON.parse(o),i,v.relative==="path");e==null&&t!=="/"&&(h.pathname=h.pathname==="/"?t:Rt([t,h.pathname])),(v.replace?r.replace:r.push)(h,v.state,v)},[t,r,o,i,e])}function Rh(){let{matches:e}=y.useContext(Dt),t=e[e.length-1];return t?t.params:{}}function Yl(e,t){let{relative:n}=t===void 0?{}:t,{future:r}=y.useContext(Mt),{matches:l}=y.useContext(Dt),{pathname:i}=In(),o=JSON.stringify(sf(l,r.v7_relativeSplatPath));return y.useMemo(()=>af(e,JSON.parse(o),i,n==="path"),[e,o,i,n])}function Th(e,t){return zh(e,t)}function zh(e,t,n,r){_r()||q(!1);let{navigator:l}=y.useContext(Mt),{matches:i}=y.useContext(Dt),o=i[i.length-1],a=o?o.params:{};o&&o.pathname;let s=o?o.pathnameBase:"/";o&&o.route;let c=In(),v;if(t){var h;let k=typeof t=="string"?On(t):t;s==="/"||(h=k.pathname)!=null&&h.startsWith(s)||q(!1),v=k}else v=c;let m=v.pathname||"/",x=m;if(s!=="/"){let k=s.replace(/^\//,"").split("/");x="/"+m.replace(/^\//,"").split("/").slice(k.length).join("/")}let g=ih(e,{pathname:x}),w=Dh(g&&g.map(k=>Object.assign({},k,{params:Object.assign({},a,k.params),pathname:Rt([s,l.encodeLocation?l.encodeLocation(k.pathname).pathname:k.pathname]),pathnameBase:k.pathnameBase==="/"?s:Rt([s,l.encodeLocation?l.encodeLocation(k.pathnameBase).pathname:k.pathnameBase])})),i,n,r);return t&&w?y.createElement(Xl.Provider,{value:{location:kr({pathname:"/",search:"",hash:"",state:null,key:"default"},v),navigationType:St.Pop}},w):w}function Oh(){let e=Vh(),t=Ch(e)?e.status+" "+e.statusText:e instanceof Error?e.message:JSON.stringify(e),n=e instanceof Error?e.stack:null,l={padding:"0.5rem",backgroundColor:"rgba(200,200,200, 0.5)"};return y.createElement(y.Fragment,null,y.createElement("h2",null,"Unexpected Application Error!"),y.createElement("h3",{style:{fontStyle:"italic"}},t),n?y.createElement("pre",{style:l},n):null,null)}const Ih=y.createElement(Oh,null);class Uh extends y.Component{constructor(t){super(t),this.state={location:t.location,revalidation:t.revalidation,error:t.error}}static getDerivedStateFromError(t){return{error:t}}static getDerivedStateFromProps(t,n){return n.location!==t.location||n.revalidation!=="idle"&&t.revalidation==="idle"?{error:t.error,location:t.location,revalidation:t.revalidation}:{error:t.error!==void 0?t.error:n.error,location:n.location,revalidation:t.revalidation||n.revalidation}}componentDidCatch(t,n){console.error("React Router caught the following error during render",t,n)}render(){return this.state.error!==void 0?y.createElement(Dt.Provider,{value:this.props.routeContext},y.createElement(ff.Provider,{value:this.state.error,children:this.props.component})):this.props.children}}function Mh(e){let{routeContext:t,match:n,children:r}=e,l=y.useContext(Gl);return l&&l.static&&l.staticContext&&(n.route.errorElement||n.route.ErrorBoundary)&&(l.staticContext._deepestRenderedBoundaryId=n.route.id),y.createElement(Dt.Provider,{value:t},r)}function Dh(e,t,n,r){var l;if(t===void 0&&(t=[]),n===void 0&&(n=null),r===void 0&&(r=null),e==null){var i;if(!n)return null;if(n.errors)e=n.matches;else if((i=r)!=null&&i.v7_partialHydration&&t.length===0&&!n.initialized&&n.matches.length>0)e=n.matches;else return null}let o=e,a=(l=n)==null?void 0:l.errors;if(a!=null){let v=o.findIndex(h=>h.route.id&&(a==null?void 0:a[h.route.id])!==void 0);v>=0||q(!1),o=o.slice(0,Math.min(o.length,v+1))}let s=!1,c=-1;if(n&&r&&r.v7_partialHydration)for(let v=0;v=0?o=o.slice(0,c+1):o=[o[0]];break}}}return o.reduceRight((v,h,m)=>{let x,g=!1,w=null,k=null;n&&(x=a&&h.route.id?a[h.route.id]:void 0,w=h.route.errorElement||Ih,s&&(c<0&&m===0?(Wh("route-fallback"),g=!0,k=null):c===m&&(g=!0,k=h.route.hydrateFallbackElement||null)));let d=t.concat(o.slice(0,m+1)),f=()=>{let p;return x?p=w:g?p=k:h.route.Component?p=y.createElement(h.route.Component,null):h.route.element?p=h.route.element:p=v,y.createElement(Mh,{match:h,routeContext:{outlet:v,matches:d,isDataRoute:n!=null},children:p})};return n&&(h.route.ErrorBoundary||h.route.errorElement||m===0)?y.createElement(Uh,{location:n.location,revalidation:n.revalidation,component:w,error:x,children:f(),routeContext:{outlet:null,matches:d,isDataRoute:!0}}):f()},null)}var hf=function(e){return e.UseBlocker="useBlocker",e.UseRevalidator="useRevalidator",e.UseNavigateStable="useNavigate",e}(hf||{}),mf=function(e){return e.UseBlocker="useBlocker",e.UseLoaderData="useLoaderData",e.UseActionData="useActionData",e.UseRouteError="useRouteError",e.UseNavigation="useNavigation",e.UseRouteLoaderData="useRouteLoaderData",e.UseMatches="useMatches",e.UseRevalidator="useRevalidator",e.UseNavigateStable="useNavigate",e.UseRouteId="useRouteId",e}(mf||{});function Fh(e){let t=y.useContext(Gl);return t||q(!1),t}function Ah(e){let t=y.useContext(cf);return t||q(!1),t}function Bh(e){let t=y.useContext(Dt);return t||q(!1),t}function vf(e){let t=Bh(),n=t.matches[t.matches.length-1];return n.route.id||q(!1),n.route.id}function Vh(){var e;let t=y.useContext(ff),n=Ah(),r=vf();return t!==void 0?t:(e=n.errors)==null?void 0:e[r]}function $h(){let{router:e}=Fh(hf.UseNavigateStable),t=vf(mf.UseNavigateStable),n=y.useRef(!1);return df(()=>{n.current=!0}),y.useCallback(function(l,i){i===void 0&&(i={}),n.current&&(typeof l=="number"?e.navigate(l):e.navigate(l,kr({fromRouteId:t},i)))},[e,t])}const Aa={};function Wh(e,t,n){Aa[e]||(Aa[e]=!0)}function Hh(e,t){e==null||e.v7_startTransition,e==null||e.v7_relativeSplatPath}function Xn(e){q(!1)}function Qh(e){let{basename:t="/",children:n=null,location:r,navigationType:l=St.Pop,navigator:i,static:o=!1,future:a}=e;_r()&&q(!1);let s=t.replace(/^\/*/,"/"),c=y.useMemo(()=>({basename:s,navigator:i,static:o,future:kr({v7_relativeSplatPath:!1},a)}),[s,a,i,o]);typeof r=="string"&&(r=On(r));let{pathname:v="/",search:h="",hash:m="",state:x=null,key:g="default"}=r,w=y.useMemo(()=>{let k=Ln(v,s);return k==null?null:{location:{pathname:k,search:h,hash:m,state:x,key:g},navigationType:l}},[s,v,h,m,x,g,l]);return w==null?null:y.createElement(Mt.Provider,{value:c},y.createElement(Xl.Provider,{children:n,value:w}))}function Kh(e){let{children:t,location:n}=e;return Th(So(t),n)}new Promise(()=>{});function So(e,t){t===void 0&&(t=[]);let n=[];return y.Children.forEach(e,(r,l)=>{if(!y.isValidElement(r))return;let i=[...t,l];if(r.type===y.Fragment){n.push.apply(n,So(r.props.children,i));return}r.type!==Xn&&q(!1),!r.props.index||!r.props.children||q(!1);let o={id:r.props.id||i.join("-"),caseSensitive:r.props.caseSensitive,element:r.props.element,Component:r.props.Component,index:r.props.index,path:r.props.path,loader:r.props.loader,action:r.props.action,errorElement:r.props.errorElement,ErrorBoundary:r.props.ErrorBoundary,hasErrorBoundary:r.props.ErrorBoundary!=null||r.props.errorElement!=null,shouldRevalidate:r.props.shouldRevalidate,handle:r.props.handle,lazy:r.props.lazy};r.props.children&&(o.children=So(r.props.children,i)),n.push(o)}),n}/** + * React Router DOM v6.30.3 + * + * Copyright (c) Remix Software Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE.md file in the root directory of this source tree. + * + * @license MIT + */function Rl(){return Rl=Object.assign?Object.assign.bind():function(e){for(var t=1;t=0)&&(n[l]=e[l]);return n}function Gh(e){return!!(e.metaKey||e.altKey||e.ctrlKey||e.shiftKey)}function Xh(e,t){return e.button===0&&(!t||t==="_self")&&!Gh(e)}function ko(e){return e===void 0&&(e=""),new URLSearchParams(typeof e=="string"||Array.isArray(e)||e instanceof URLSearchParams?e:Object.keys(e).reduce((t,n)=>{let r=e[n];return t.concat(Array.isArray(r)?r.map(l=>[n,l]):[[n,r]])},[]))}function Yh(e,t){let n=ko(e);return t&&t.forEach((r,l)=>{n.has(l)||t.getAll(l).forEach(i=>{n.append(l,i)})}),n}const Jh=["onClick","relative","reloadDocument","replace","state","target","to","preventScrollReset","viewTransition"],Zh=["aria-current","caseSensitive","className","end","style","to","viewTransition","children"],qh="6";try{window.__reactRouterVersion=qh}catch{}const bh=y.createContext({isTransitioning:!1}),em="startTransition",Ba=Hf[em];function tm(e){let{basename:t,children:n,future:r,window:l}=e,i=y.useRef();i.current==null&&(i.current=nh({window:l,v5Compat:!0}));let o=i.current,[a,s]=y.useState({action:o.action,location:o.location}),{v7_startTransition:c}=r||{},v=y.useCallback(h=>{c&&Ba?Ba(()=>s(h)):s(h)},[s,c]);return y.useLayoutEffect(()=>o.listen(v),[o,v]),y.useEffect(()=>Hh(r),[r]),y.createElement(Qh,{basename:t,children:n,location:a.location,navigationType:a.action,navigator:o,future:r})}const nm=typeof window<"u"&&typeof window.document<"u"&&typeof window.document.createElement<"u",rm=/^(?:[a-z][a-z0-9+.-]*:|\/\/)/i,Jl=y.forwardRef(function(t,n){let{onClick:r,relative:l,reloadDocument:i,replace:o,state:a,target:s,to:c,preventScrollReset:v,viewTransition:h}=t,m=gf(t,Jh),{basename:x}=y.useContext(Mt),g,w=!1;if(typeof c=="string"&&rm.test(c)&&(g=c,nm))try{let p=new URL(window.location.href),S=c.startsWith("//")?new URL(p.protocol+c):new URL(c),j=Ln(S.pathname,x);S.origin===p.origin&&j!=null?c=j+S.search+S.hash:w=!0}catch{}let k=_h(c,{relative:l}),d=im(c,{replace:o,state:a,target:s,preventScrollReset:v,relative:l,viewTransition:h});function f(p){r&&r(p),p.defaultPrevented||d(p)}return y.createElement("a",Rl({},m,{href:g||k,onClick:w||i?r:f,ref:n,target:s}))}),Ni=y.forwardRef(function(t,n){let{"aria-current":r="page",caseSensitive:l=!1,className:i="",end:o=!1,style:a,to:s,viewTransition:c,children:v}=t,h=gf(t,Zh),m=Yl(s,{relative:h.relative}),x=In(),g=y.useContext(cf),{navigator:w,basename:k}=y.useContext(Mt),d=g!=null&&sm(m)&&c===!0,f=w.encodeLocation?w.encodeLocation(m).pathname:m.pathname,p=x.pathname,S=g&&g.navigation&&g.navigation.location?g.navigation.location.pathname:null;l||(p=p.toLowerCase(),S=S?S.toLowerCase():null,f=f.toLowerCase()),S&&k&&(S=Ln(S,k)||S);const j=f!=="/"&&f.endsWith("/")?f.length-1:f.length;let C=p===f||!o&&p.startsWith(f)&&p.charAt(j)==="/",P=S!=null&&(S===f||!o&&S.startsWith(f)&&S.charAt(f.length)==="/"),R={isActive:C,isPending:P,isTransitioning:d},B=C?r:void 0,I;typeof i=="function"?I=i(R):I=[i,C?"active":null,P?"pending":null,d?"transitioning":null].filter(Boolean).join(" ");let ie=typeof a=="function"?a(R):a;return y.createElement(Jl,Rl({},h,{"aria-current":B,className:I,ref:n,style:ie,to:s,viewTransition:c}),typeof v=="function"?v(R):v)});var jo;(function(e){e.UseScrollRestoration="useScrollRestoration",e.UseSubmit="useSubmit",e.UseSubmitFetcher="useSubmitFetcher",e.UseFetcher="useFetcher",e.useViewTransitionState="useViewTransitionState"})(jo||(jo={}));var Va;(function(e){e.UseFetcher="useFetcher",e.UseFetchers="useFetchers",e.UseScrollRestoration="useScrollRestoration"})(Va||(Va={}));function lm(e){let t=y.useContext(Gl);return t||q(!1),t}function im(e,t){let{target:n,replace:r,state:l,preventScrollReset:i,relative:o,viewTransition:a}=t===void 0?{}:t,s=pf(),c=In(),v=Yl(e,{relative:o});return y.useCallback(h=>{if(Xh(h,n)){h.preventDefault();let m=r!==void 0?r:Ll(c)===Ll(v);s(e,{replace:m,state:l,preventScrollReset:i,relative:o,viewTransition:a})}},[c,s,v,r,l,n,e,i,o,a])}function om(e){let t=y.useRef(ko(e)),n=y.useRef(!1),r=In(),l=y.useMemo(()=>Yh(r.search,n.current?null:t.current),[r.search]),i=pf(),o=y.useCallback((a,s)=>{const c=ko(typeof a=="function"?a(l):a);n.current=!0,i("?"+c,s)},[i,l]);return[l,o]}function sm(e,t){t===void 0&&(t={});let n=y.useContext(bh);n==null&&q(!1);let{basename:r}=lm(jo.useViewTransitionState),l=Yl(e,{relative:t.relative});if(!n.isTransitioning)return!1;let i=Ln(n.currentLocation.pathname,r)||n.currentLocation.pathname,o=Ln(n.nextLocation.pathname,r)||n.nextLocation.pathname;return xo(l.pathname,o)!=null||xo(l.pathname,i)!=null}const yf=y.createContext(null);function $a(){try{return localStorage.getItem("authToken")||""}catch{return""}}function Kr(e){try{e?localStorage.setItem("authToken",e):localStorage.removeItem("authToken")}catch{}}function am({children:e}){const[t,n]=y.useState($a),[r,l]=y.useState(null),[i,o]=y.useState(!!$a()),[a,s]=y.useState(null);y.useEffect(()=>{if(!t){l(null),o(!1),s(null);return}let g=!1;return o(!0),fetch("/api/auth/me",{headers:{Authorization:`Bearer ${t}`}}).then(async w=>{const k=await w.json().catch(()=>({}));if(!w.ok)throw new Error(k.error||"Kon sessie niet verifiëren.");g||(l(k.user||null),s(null))}).catch(()=>{g||(l(null),n(""),Kr(""))}).finally(()=>{g||o(!1)}),()=>{g=!0}},[t]);async function c(g){s(null);const w=await fetch("/api/auth/login",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(g)}),k=await w.json().catch(()=>({}));if(!w.ok)throw new Error(k.error||"Login mislukt.");return n(k.token),Kr(k.token),l(k.user),k.user}async function v(g){s(null);const w=await fetch("/api/auth/register",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(g)}),k=await w.json().catch(()=>({}));if(!w.ok)throw new Error(k.error||"Registratie mislukt.");return n(k.token),Kr(k.token),l(k.user),k.user}function h(){n(""),Kr(""),l(null)}const m=y.useMemo(()=>(g,w={})=>{const k={...w.headers||{},...t?{Authorization:`Bearer ${t}`}:{}};return fetch(g,{...w,headers:k})},[t]),x={user:r,token:t,loading:i,error:a,login:c,register:v,logout:h,authFetch:m};return u.jsx(yf.Provider,{value:x,children:e})}function xs(){const e=y.useContext(yf);if(!e)throw new Error("useAuth moet binnen een AuthProvider gebruikt worden");return e}function um(){const e=({isActive:r})=>r?"nav-link active":"nav-link",{user:t,logout:n}=xs();return u.jsxs("nav",{className:"site-nav",children:[u.jsx(Jl,{className:"nav-logo",to:"/",children:"Siti Plugin Repo"}),u.jsxs("div",{className:"nav-links",children:[u.jsx(Ni,{to:"/",end:!0,className:e,children:"Plugins"}),u.jsx(Ni,{to:"/licenses",className:e,children:"Licenties"}),(t==null?void 0:t.isAdmin)&&u.jsx(Ni,{to:"/repos",className:e,children:"Repos"})]}),u.jsx("div",{className:"nav-user",children:t?u.jsxs(u.Fragment,{children:[u.jsxs("span",{className:"nav-user-name",children:["Hallo, ",t.name]}),u.jsx("button",{className:"ghost ghost-small",type:"button",onClick:n,children:"Uitloggen"})]}):u.jsx("span",{className:"nav-user-guest",children:"Niet ingelogd"})})]})}function cm(){const[e,t]=y.useState([]),[n,r]=y.useState(!0),[l,i]=y.useState(null),[o,a]=y.useState(null);return y.useEffect(()=>{async function s(){try{const c=await fetch("/api/plugins");if(!c.ok)throw new Error("Kon plugins niet laden");const v=await c.json();t(v.items||[]),a(v.updatedAt)}catch{i("Laden van repository data is mislukt.")}finally{r(!1)}}s()},[]),u.jsxs("div",{className:"page",children:[u.jsxs("header",{className:"hero",children:[u.jsxs("div",{children:[u.jsx("p",{className:"eyebrow",children:"WordPress plugin overzicht"}),u.jsx("h1",{children:"Siti Plugin Repo"}),u.jsx("p",{className:"subtitle",children:"Al je publieke WordPress plugins op één plek."})]}),u.jsx("a",{className:"cta",href:"https://github.com/SitiWeb",target:"_blank",rel:"noreferrer",children:"GitHub SitiWeb"})]}),u.jsxs("section",{className:"grid",children:[n&&u.jsx("div",{className:"state",children:"Bezig met laden…"}),l&&u.jsx("div",{className:"state error",children:l}),!n&&!l&&e.length===0&&u.jsx("div",{className:"state",children:"Geen repositories gevonden."}),e.map(s=>{var g,w;const c=s.label||((g=s.manifest)==null?void 0:g.plugin_name)||s.name,v=((w=s.manifest)==null?void 0:w.description)||s.description,h=new URLSearchParams;s.provider&&h.set("provider",s.provider),s.baseUrl&&h.set("baseUrl",s.baseUrl),s.repoId&&h.set("repoId",String(s.repoId));const m=s.provider==="gitea"?"Gitea":"GitHub",x=`/plugin/${s.fullName}`+(h.toString()?`?${h.toString()}`:"");return u.jsxs("article",{className:"card",children:[u.jsxs("div",{className:"card-header",children:[u.jsx("h2",{children:c}),u.jsx("span",{className:"pill",children:s.fullName})]}),u.jsx("p",{children:v}),u.jsxs("div",{className:"meta",children:[u.jsxs("span",{children:["★ ",s.stars]}),u.jsxs("span",{children:["Forks ",s.forks]}),u.jsxs("span",{children:["Issues ",s.issues]})]}),s.topics.length>0&&u.jsx("div",{className:"topics",children:s.topics.slice(0,4).map(k=>u.jsx("span",{className:"topic",children:k},k))}),u.jsxs("div",{className:"actions",children:[u.jsx(Jl,{className:"link",to:x,children:"Bekijk details →"}),u.jsx("a",{className:"ghost",href:s.repoUrl,target:"_blank",rel:"noreferrer",children:m})]})]},s.fullName)})]}),u.jsx("footer",{className:"footer",children:u.jsxs("span",{children:["Laatste sync: ",o?new Date(o).toLocaleString("nl-NL"):"-"]})})]})}function fm(){const{owner:e,repo:t}=Rh(),[n]=om(),r=(n.get("provider")||"github").toLowerCase(),l=n.get("baseUrl")||"",i=n.get("repoId")||"",[o,a]=y.useState(null),[s,c]=y.useState(!0),[v,h]=y.useState(null);y.useEffect(()=>{async function j(){try{const C=new URLSearchParams;r&&C.set("provider",r),l&&C.set("baseUrl",l),i&&C.set("repoId",i);const P=C.toString(),R=await fetch(`/api/plugins/${e}/${t}${P.length>0?`?${P}`:""}`);if(!R.ok)throw new Error("Kon details niet laden");const B=await R.json();a(B)}catch{h("Laden van plugin details is mislukt.")}finally{c(!1)}}j()},[e,t,r,l]);const m=o==null?void 0:o.manifest,x=(o==null?void 0:o.label)||(m==null?void 0:m.plugin_name)||(o==null?void 0:o.name)||t,g=(m==null?void 0:m.description)||(o==null?void 0:o.description),w=(m==null?void 0:m.author)||"-",k=(m==null?void 0:m.version)||"-",d=(o==null?void 0:o.provider)==="gitea"?"Gitea":"GitHub",f=o==null?void 0:o.download,p=y.useMemo(()=>(o==null?void 0:o.releases)||[],[o]),S=y.useMemo(()=>(o==null?void 0:o.commits)||[],[o]);return u.jsxs("div",{className:"page",children:[u.jsxs("header",{className:"detail-hero",children:[u.jsxs("div",{children:[u.jsx("p",{className:"eyebrow",children:"Plugin details"}),u.jsx("h1",{children:x}),u.jsx("p",{className:"subtitle",children:g})]}),u.jsxs("div",{className:"detail-actions",children:[u.jsx(Jl,{className:"ghost",to:"/",children:"← Terug"}),(o==null?void 0:o.repoUrl)&&u.jsx("a",{className:"ghost",href:o.repoUrl,target:"_blank",rel:"noreferrer",children:d}),(f==null?void 0:f.url)&&u.jsxs("a",{className:"cta",href:f.url,target:"_blank",rel:"noreferrer",children:["Download ",f.version]})]})]}),s&&u.jsx("div",{className:"state",children:"Bezig met laden…"}),v&&u.jsx("div",{className:"state error",children:v}),!s&&!v&&o&&u.jsxs("section",{className:"detail-grid",children:[u.jsxs("div",{className:"card",children:[u.jsx("h2",{children:"Manifest"}),u.jsxs("div",{className:"detail-list",children:[u.jsxs("div",{children:[u.jsx("span",{children:"Naam"}),u.jsx("strong",{children:x})]}),u.jsxs("div",{children:[u.jsx("span",{children:"Versie"}),u.jsx("strong",{children:k})]}),u.jsxs("div",{children:[u.jsx("span",{children:"Auteur"}),u.jsx("strong",{children:w})]}),u.jsxs("div",{children:[u.jsx("span",{children:"Repository"}),u.jsx("strong",{children:o.fullName})]})]}),(m==null?void 0:m.author_url)&&u.jsx("a",{className:"link",href:m.author_url,target:"_blank",rel:"noreferrer",children:"Auteur website →"})]}),u.jsxs("div",{className:"card",children:[u.jsx("h2",{children:"Releases"}),p.length===0&&u.jsx("p",{children:"Geen releases gevonden."}),u.jsx("ul",{className:"list",children:p.map(j=>{const C=j.tag||j.name||j.url;return u.jsxs("li",{children:[u.jsxs("div",{children:[u.jsx("a",{href:j.url,target:"_blank",rel:"noreferrer",children:j.name}),u.jsx("span",{children:j.publishedAt?new Date(j.publishedAt).toLocaleDateString("nl-NL"):"-"})]}),j.downloadUrl&&u.jsx("a",{className:"ghost",href:j.downloadUrl,target:"_blank",rel:"noreferrer",children:"Download"})]},C)})})]}),u.jsxs("div",{className:"card",children:[u.jsx("h2",{children:"Recente commits"}),S.length===0&&u.jsx("p",{children:"Geen commits gevonden."}),u.jsx("ul",{className:"list",children:S.map(j=>{var C;return u.jsxs("li",{children:[u.jsx("a",{href:j.url,target:"_blank",rel:"noreferrer",children:((C=j.message)==null?void 0:C.split(` +`)[0])||j.sha.slice(0,7)}),u.jsx("span",{children:j.author||"-"})]},j.sha)})})]})]})]})}const wf="nl-NL";function Eo(e,t=wf){return e?new Date(e).toLocaleString(t):"-"}function dm(e,t=wf){return e?new Date(e).toLocaleDateString(t):"-"}function pm({license:e}){const t=e.hostnames||[],n=e.primaryHostname||"Nog niet gekoppeld";return u.jsxs("article",{className:"card license-card",children:[u.jsxs("div",{className:"license-card-header",children:[u.jsxs("div",{children:[u.jsx("h3",{children:e.pluginName||e.label||"Licentie"}),u.jsx("p",{className:"license-subtitle",children:e.repoFullName||"-"})]}),u.jsx("span",{className:"pill",children:e.key})]}),u.jsxs("div",{className:"detail-list license-detail-list",children:[u.jsxs("div",{children:[u.jsx("span",{children:"Hostname"}),u.jsx("strong",{children:n})]}),u.jsxs("div",{children:[u.jsx("span",{children:"Huidige versie"}),u.jsx("strong",{children:e.lastUsedVersion||"-"})]}),u.jsxs("div",{children:[u.jsx("span",{children:"Laatste release"}),u.jsx("strong",{children:e.pluginVersion||"-"})]}),u.jsxs("div",{children:[u.jsx("span",{children:"Aangemaakt"}),u.jsx("strong",{children:dm(e.createdAt)})]}),u.jsxs("div",{children:[u.jsx("span",{children:"Laatste check"}),u.jsx("strong",{children:Eo(e.lastVersionCheckAt)})]})]}),e.note&&u.jsxs("p",{className:"license-note",children:["Notitie: ",e.note]}),t.length>0&&u.jsxs("div",{className:"host-list",children:[u.jsx("p",{className:"hint",children:"Hostnames"}),u.jsx("ul",{children:t.map(r=>u.jsxs("li",{children:[u.jsxs("div",{children:[u.jsx("strong",{children:r.hostname}),u.jsxs("span",{children:[r.hits||0," checks"]})]}),u.jsx("span",{children:Eo(r.lastSeenAt)})]},`${r.hostname}-${r.firstSeenAt||r.lastSeenAt}`))})]}),u.jsxs("div",{className:"license-links",children:[e.repoUrl&&u.jsx("a",{className:"link",href:e.repoUrl,target:"_blank",rel:"noreferrer",children:"Repository →"}),e.pluginName&&u.jsx("span",{className:"ghost-pill",children:e.pluginName})]})]})}function hm(){var Es;const{user:e,token:t,authFetch:n,login:r,register:l,loading:i}=xs(),[o,a]=y.useState([]),[s,c]=y.useState([]),[v,h]=y.useState([]),[m,x]=y.useState(""),[g,w]=y.useState(""),[k,d]=y.useState(""),[f,p]=y.useState(""),[S,j]=y.useState(!0),[C,P]=y.useState(null),[R,B]=y.useState(!1),[I,ie]=y.useState(!1),[T,U]=y.useState(!1),[$,oe]=y.useState(null),[Je,Ne]=y.useState(null),[_,O]=y.useState(null),[z,W]=y.useState(null),[b,Ft]=y.useState(!1),[Ve,Un]=y.useState(""),[$e,bt]=y.useState(""),[Ss,xf]=y.useState(""),[en,tn]=y.useState({username:"",name:"",email:"",password:"",isAdmin:!1}),dt=!!(e&&t);y.useEffect(()=>{let N=!1;async function M(){var A;j(!0),P(null);try{const ee=await fetch("/api/plugins"),Ce=await ee.json().catch(()=>({}));if(!ee.ok)throw new Error(Ce.error||"Kon plugins niet laden.");if(N)return;c(Ce.items||[]);const Pe=(A=Ce.items)==null?void 0:A[0];if(Pe){const Zl=Pe.ownerRepo||Pe.fullName;x(Cf=>Cf||Zl)}}catch(ee){N||P(ee.message||"Kon plugins niet laden.")}finally{N||j(!1)}}return M(),()=>{N=!0}},[]),y.useEffect(()=>{if(!dt){h([]),w("");return}e&&!g&&w(String(e.id))},[dt,g,e]),y.useEffect(()=>{if(!dt||!e)return;if(!e.isAdmin){h([e]);return}let N=!1;async function M(){try{const A=await n("/api/admin/users"),ee=await A.json().catch(()=>({}));if(!A.ok)throw new Error(ee.error||"Kon gebruikers niet laden.");if(N)return;h(ee.items||[]),!g&&(ee.items||[]).length>0&&w(String(ee.items[0].id))}catch(A){N||Ne({variant:"error",message:A.message})}}return M(),()=>{N=!0}},[n,dt,g,e]);const pt=y.useCallback(async(N=!0,M)=>{if(!t){a([]),oe(null),N&&Ne({variant:"error",message:"Log in om licenties te beheren."});return}N&&Ne(null),U(!0);try{const A=M||e!=null&&e.isAdmin&&g||(e?String(e.id):"");let ee="/api/licenses";e!=null&&e.isAdmin&&A&&(ee+=`?userId=${A}`);const Ce=await n(ee),Pe=await Ce.json().catch(()=>({}));if(Ce.status===401)throw new Error("Sessie verlopen, log opnieuw in.");if(!Ce.ok)throw new Error(Pe.error||"Kon licenties niet laden.");a(Pe.items||[]),oe(Pe.updatedAt)}catch(A){N&&Ne({variant:"error",message:A.message})}finally{U(!1)}},[n,g,t,e]);y.useEffect(()=>{pt(!1)},[pt]),y.useEffect(()=>{if(!m&&s.length>0){const N=s[0].ownerRepo||s[0].fullName;x(N)}},[s,m]);const Ie=y.useMemo(()=>s.find(N=>(N.ownerRepo||N.fullName)===m)||null,[s,m]),ks=y.useMemo(()=>{const N=M=>M?new Date(M).getTime():0;return[...o].sort((M,A)=>N(A.createdAt)-N(M.createdAt))},[o]);async function Sf(N){var M;if(N.preventDefault(),Ne(null),!dt){Ne({variant:"error",message:"Log in om een licentie aan te maken."});return}if(!Ie){Ne({variant:"error",message:"Selecteer een plugin."});return}B(!0);try{const A={label:k.trim()||Ie.label||((M=Ie.manifest)==null?void 0:M.plugin_name)||Ie.name||Ie.fullName,note:f.trim()||void 0};Ie.repoId?A.repoId=Ie.repoId:A.repo={repo:Ie.ownerRepo||Ie.fullName,provider:Ie.provider||"github",baseUrl:Ie.baseUrl};const ee={...A,userId:e!=null&&e.isAdmin?Number(g||e.id):void 0},Ce=await n("/api/licenses",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(ee)}),Pe=await Ce.json().catch(()=>({}));if(Ce.status===401)throw new Error("Sessie verlopen, log opnieuw in.");if(!Ce.ok)throw new Error(Pe.error||"Licentie aanmaken mislukt.");a(Zl=>[Pe,...Zl]),Ne({variant:"success",message:"Licentie aangemaakt."}),d(""),p("")}catch(A){Ne({variant:"error",message:A.message})}finally{B(!1)}}async function kf(N){N.preventDefault(),O(null),ie(!0);try{const M=await n("/api/admin/users",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(en)}),A=await M.json().catch(()=>({}));if(!M.ok)throw new Error(A.error||"Gebruiker aanmaken mislukt.");O({variant:"success",message:"Gebruiker aangemaakt."}),tn({username:"",name:"",email:"",password:"",isAdmin:!1}),h(ee=>[...ee,A.user]),g||w(String(A.user.id))}catch(M){O({variant:"error",message:M.message})}finally{ie(!1)}}async function jf(N){if(N.preventDefault(),W(null),!Ve.trim()||!$e.trim()){W({ok:!1,message:"Vul zowel licentiecode als hostname in."});return}Ft(!0);try{const M=await fetch("/api/licenses/verify",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({key:Ve.trim(),hostname:$e.trim(),currentVersion:Ss.trim()||void 0})}),A=await M.json().catch(()=>({})),ee={ok:M.ok,data:A,message:M.ok?null:A.error||"Controle mislukt."};W(ee),M.ok&&A.license&&a(Ce=>Ce.map(Pe=>Pe.key===A.license.key?A.license:Pe))}catch(M){W({ok:!1,message:M.message})}finally{Ft(!1)}}const Ef=y.useCallback(async N=>{await r(N),await pt(!1)},[r,pt]),Nf=y.useCallback(async N=>{await l(N),await pt(!1)},[l,pt]),js=S||i&&!!t;return u.jsxs("div",{className:"page",children:[u.jsxs("header",{className:"hero",children:[u.jsxs("div",{children:[u.jsx("p",{className:"eyebrow",children:"Licentiebeheer"}),u.jsx("h1",{children:"Licenties"}),u.jsx("p",{className:"subtitle",children:"Maak licenties voor iedere plugin en beheer welke hostname de licentie daadwerkelijk gebruikt."}),u.jsx("p",{className:"hint",children:"Een licentie is geldig voor één hostname. De eerste hostname die controleert wordt automatisch gekoppeld als licentiehouder."})]}),u.jsx("button",{className:"ghost",type:"button",onClick:()=>pt(),disabled:T||!dt,children:T?"Vernieuwen…":"Vernieuw lijst"})]}),u.jsxs("div",{className:"license-meta-bar",children:[u.jsxs("span",{children:["Actieve licenties: ",o.length]}),u.jsxs("span",{children:["Laatste update: ",Eo($)]}),e&&u.jsxs("span",{children:["Ingelogd als: ",e.email]}),(e==null?void 0:e.isAdmin)&&v.length>0&&u.jsxs("label",{className:"inline-field",children:[u.jsx("span",{children:"Licenties gebruiker"}),u.jsx("select",{value:g,onChange:N=>{w(N.target.value),pt(!0,N.target.value)},children:v.map(N=>u.jsxs("option",{value:N.id,children:[N.name," (",N.email,")"]},N.id))})]})]}),js&&u.jsx("div",{className:"state",children:"Bezig met laden…"}),C&&u.jsx("div",{className:"state error",children:C}),!js&&!C&&u.jsxs(u.Fragment,{children:[u.jsxs("section",{className:"license-forms",children:[dt?u.jsxs("article",{className:"card",children:[u.jsx("h2",{children:"Nieuwe licentie"}),u.jsx("p",{className:"hint",children:"Kies een plugin en genereer direct een licentiesleutel."}),u.jsxs("form",{className:"form-grid",onSubmit:Sf,children:[u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Plugin"}),u.jsx("select",{value:m,onChange:N=>x(N.target.value),disabled:s.length===0,children:s.map(N=>{var ee;const M=N.ownerRepo||N.fullName,A=N.label||((ee=N.manifest)==null?void 0:ee.plugin_name)||N.name||N.fullName;return u.jsxs("option",{value:M,children:[A," (",N.ownerRepo||N.fullName,")"]},M)})})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Label (optioneel)"}),u.jsx("input",{value:k,onChange:N=>d(N.target.value),placeholder:"Naam of klant"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Notitie"}),u.jsx("textarea",{value:f,onChange:N=>p(N.target.value),placeholder:"Bijv. contactpersoon of extra info",rows:3})]}),(e==null?void 0:e.isAdmin)&&u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Licentie voor gebruiker"}),u.jsx("select",{value:g,onChange:N=>w(N.target.value),children:v.map(N=>u.jsxs("option",{value:N.id,children:[N.name," (",N.email,")"]},N.id))})]}),u.jsx("button",{className:"cta",type:"submit",disabled:R||!Ie,children:R?"Aanmaken…":"Licentie aanmaken"})]}),Je&&u.jsx("div",{className:`state inline ${Je.variant==="error"?"error":"success"}`,children:Je.message})]}):u.jsx(mm,{onLogin:Ef,onRegister:Nf}),u.jsxs("article",{className:"card",children:[u.jsx("h2",{children:"Test of valideer"}),u.jsx("p",{className:"hint",children:"Gebruik dit formulier zoals de plugin dat zou doen om de huidige versie en hostname te controleren."}),u.jsxs("form",{className:"form-grid",onSubmit:jf,children:[u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Licentiecode"}),u.jsx("input",{value:Ve,onChange:N=>Un(N.target.value),placeholder:"SITI-XXXX-XXXX"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Hostname"}),u.jsx("input",{value:$e,onChange:N=>bt(N.target.value),placeholder:"voorbeeld.nl"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Deze site draait versie"}),u.jsx("input",{value:Ss,onChange:N=>xf(N.target.value),placeholder:"bijv. 1.9.3"})]}),u.jsx("button",{className:"ghost",type:"submit",disabled:b,children:b?"Controleren…":"Controleer licentie"})]}),((Es=z==null?void 0:z.data)==null?void 0:Es.license)&&u.jsxs("div",{className:`state inline ${z.ok?"success":""}`.trim(),children:[u.jsx("strong",{children:z.ok?"Licentie geldig":"Plugin informatie"}),u.jsx("p",{children:z.data.license.pluginName||"Plugin"}),u.jsxs("p",{children:["Huidige versie:"," ",u.jsx("strong",{children:z.data.license.lastUsedVersion||z.data.license.pluginVersion||"-"})]}),u.jsxs("p",{children:["Laatste release:"," ",u.jsx("strong",{children:z.data.license.pluginVersion||"-"})]}),u.jsxs("p",{children:["Gekoppeld aan:"," ",u.jsx("strong",{children:z.data.license.primaryHostname||"Nog niet gekoppeld"})]}),!z.ok&&u.jsx("p",{className:"hint",children:"Licentie is ongeldig; downloaden blijft geblokkeerd."})]}),z&&!z.ok&&z.message&&u.jsx("div",{className:"state error inline",children:z.message})]})]}),(e==null?void 0:e.isAdmin)&&u.jsx("section",{className:"license-forms",children:u.jsxs("article",{className:"card",children:[u.jsx("h2",{children:"Gebruiker toevoegen"}),u.jsx("p",{className:"hint",children:"Admins kunnen extra gebruikers aanmaken en direct licenties toewijzen."}),u.jsxs("form",{className:"form-grid",onSubmit:kf,children:[u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Gebruikersnaam"}),u.jsx("input",{value:en.username,onChange:N=>tn(M=>({...M,username:N.target.value})),placeholder:"gebruikersnaam"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Naam"}),u.jsx("input",{value:en.name,onChange:N=>tn(M=>({...M,name:N.target.value})),placeholder:"Volledige naam"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"E-mail"}),u.jsx("input",{type:"email",value:en.email,onChange:N=>tn(M=>({...M,email:N.target.value})),placeholder:"naam@bedrijf.nl"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Wachtwoord"}),u.jsx("input",{type:"password",value:en.password,onChange:N=>tn(M=>({...M,password:N.target.value})),placeholder:"Minimaal 8 karakters"})]}),u.jsxs("label",{className:"checkbox-field",children:[u.jsx("input",{type:"checkbox",checked:en.isAdmin,onChange:N=>tn(M=>({...M,isAdmin:N.target.checked}))}),u.jsx("span",{children:"Maak deze gebruiker admin"})]}),u.jsx("button",{className:"cta",type:"submit",disabled:I,children:I?"Bezig…":"Gebruiker aanmaken"})]}),_&&u.jsx("div",{className:`state inline ${_.variant==="error"?"error":"success"}`,children:_.message})]})}),dt?u.jsx("section",{className:"license-grid",children:ks.length===0?u.jsx("div",{className:"state",children:"Nog geen licenties aangemaakt."}):ks.map(N=>u.jsx(pm,{license:N},N.id||N.key))}):u.jsx("div",{className:"state",children:"Log in of registreer om licenties te bekijken en te beheren."})]})]})}function mm({onLogin:e,onRegister:t}){const[n,r]=y.useState("login"),[l,i]=y.useState({identifier:"",password:""}),[o,a]=y.useState({username:"",name:"",email:"",password:""}),[s,c]=y.useState(null),[v,h]=y.useState(!1);async function m(x){x.preventDefault(),c(null),h(!0);try{n==="login"?(await e(l),c({variant:"success",message:"Succesvol ingelogd."})):(await t(o),c({variant:"success",message:"Account aangemaakt en ingelogd."}))}catch(g){c({variant:"error",message:g.message||"Actie mislukt."})}finally{h(!1)}}return u.jsxs("article",{className:"card auth-card",children:[u.jsxs("div",{className:"auth-tabs",children:[u.jsx("button",{type:"button",className:n==="login"?"auth-tab active":"auth-tab",onClick:()=>r("login"),disabled:v,children:"Inloggen"}),u.jsx("button",{type:"button",className:n==="register"?"auth-tab active":"auth-tab",onClick:()=>r("register"),disabled:v,children:"Registreren"})]}),u.jsxs("form",{className:"form-grid",onSubmit:m,children:[n==="login"?u.jsxs(u.Fragment,{children:[u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Gebruikersnaam of e-mail"}),u.jsx("input",{value:l.identifier,onChange:x=>i(g=>({...g,identifier:x.target.value})),placeholder:"jouwnaam of mail"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Wachtwoord"}),u.jsx("input",{type:"password",value:l.password,onChange:x=>i(g=>({...g,password:x.target.value})),placeholder:"••••••••"})]})]}):u.jsxs(u.Fragment,{children:[u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Gebruikersnaam"}),u.jsx("input",{value:o.username,onChange:x=>a(g=>({...g,username:x.target.value})),placeholder:"gebruikersnaam"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Naam"}),u.jsx("input",{value:o.name,onChange:x=>a(g=>({...g,name:x.target.value})),placeholder:"Volledige naam"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"E-mailadres"}),u.jsx("input",{type:"email",value:o.email,onChange:x=>a(g=>({...g,email:x.target.value})),placeholder:"naam@bedrijf.nl"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Wachtwoord"}),u.jsx("input",{type:"password",value:o.password,onChange:x=>a(g=>({...g,password:x.target.value})),placeholder:"Minimaal 8 karakters"})]})]}),u.jsx("button",{className:"cta",type:"submit",disabled:v,children:v?"Verwerken…":n==="login"?"Inloggen":"Registreren"})]}),s&&u.jsx("div",{className:`state inline ${s.variant==="error"?"error":"success"}`,children:s.message})]})}const Wa=[{value:"github",label:"GitHub"},{value:"gitea",label:"Gitea"}];function vm(){const{user:e,authFetch:t}=xs(),n=!!(e!=null&&e.isAdmin),[r,l]=y.useState([]),[i,o]=y.useState(!0),[a,s]=y.useState(null),[c,v]=y.useState({ownerRepo:"",provider:"github",baseUrl:"",label:""}),[h,m]=y.useState(!1),[x,g]=y.useState(null),[w,k]=y.useState(null),[d,f]=y.useState({ownerRepo:"",provider:"github",baseUrl:"",label:""}),[p,S]=y.useState(null),j=!!(e&&n),C=y.useCallback(async()=>{if(!j){l([]),o(!1);return}o(!0),s(null);try{const T=await t("/api/repos"),U=await T.json().catch(()=>({}));if(!T.ok)throw new Error(U.error||"Kon repos niet laden.");l(U.items||[])}catch(T){s(T.message)}finally{o(!1)}},[t,j]);y.useEffect(()=>{C()},[C]);const P=y.useMemo(()=>[...r].sort((T,U)=>T.ownerRepo.localeCompare(U.ownerRepo)),[r]);if(!e)return u.jsx("div",{className:"page",children:u.jsx("div",{className:"state",children:"Log in om repositories te beheren."})});if(!n)return u.jsx("div",{className:"page",children:u.jsx("div",{className:"state error",children:"Alleen admins kunnen repositories beheren."})});async function R(T){if(T.preventDefault(),!c.ownerRepo.trim()){g({variant:"error",message:"Vul het owner/repo veld in."});return}m(!0),g(null);try{const U=await t("/api/repos",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(c)}),$=await U.json().catch(()=>({}));if(!U.ok)throw new Error($.error||"Repo aanmaken mislukt.");l(oe=>[...oe,$.repo]),v({ownerRepo:"",provider:"github",baseUrl:"",label:""}),g({variant:"success",message:"Repo toegevoegd."})}catch(U){g({variant:"error",message:U.message})}finally{m(!1)}}function B(T){k(T.id),f({ownerRepo:T.ownerRepo||"",provider:T.provider||"github",baseUrl:T.baseUrl||"",label:T.label||""}),g(null)}async function I(T){if(T.preventDefault(),!!w)try{const U=await t(`/api/repos/${w}`,{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify(d)}),$=await U.json().catch(()=>({}));if(!U.ok)throw new Error($.error||"Repo bijwerken mislukt.");l(oe=>oe.map(Je=>Je.id===w?$.repo:Je)),k(null),g({variant:"success",message:"Repo bijgewerkt."})}catch(U){g({variant:"error",message:U.message})}}async function ie(T){if(window.confirm("Weet je zeker dat je deze repo wilt verwijderen?")){S(T),g(null);try{const U=await t(`/api/repos/${T}`,{method:"DELETE"});if(!U.ok){const $=await U.json().catch(()=>({}));throw new Error($.error||"Verwijderen mislukt.")}l($=>$.filter(oe=>oe.id!==T)),w===T&&k(null),g({variant:"success",message:"Repo verwijderd."})}catch(U){g({variant:"error",message:U.message})}finally{S(null)}}}return u.jsxs("div",{className:"page",children:[u.jsx("header",{className:"hero",children:u.jsxs("div",{children:[u.jsx("p",{className:"eyebrow",children:"Repository beheer"}),u.jsx("h1",{children:"Repos"}),u.jsx("p",{className:"subtitle",children:"Voeg nieuwe plugin repositories toe of werk bestaande entries bij."})]})}),u.jsx("section",{className:"license-forms",children:u.jsxs("article",{className:"card",children:[u.jsx("h2",{children:"Nieuwe repo"}),u.jsxs("form",{className:"form-grid",onSubmit:R,children:[u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Owner/Repo"}),u.jsx("input",{value:c.ownerRepo,onChange:T=>v(U=>({...U,ownerRepo:T.target.value})),placeholder:"bijv. roberto/siti-ai-product-content-generator"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Provider"}),u.jsx("select",{value:c.provider,onChange:T=>v(U=>({...U,provider:T.target.value})),children:Wa.map(T=>u.jsx("option",{value:T.value,children:T.label},T.value))})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Base URL (optioneel)"}),u.jsx("input",{value:c.baseUrl,onChange:T=>v(U=>({...U,baseUrl:T.target.value})),placeholder:"Alleen nodig voor Gitea"})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Label (optioneel)"}),u.jsx("input",{value:c.label,onChange:T=>v(U=>({...U,label:T.target.value})),placeholder:"Weergavenaam"})]}),u.jsx("button",{className:"cta",type:"submit",disabled:h,children:h?"Opslaan…":"Repo toevoegen"})]}),x&&u.jsx("div",{className:`state inline ${x.variant==="error"?"error":"success"}`,children:x.message})]})}),i&&u.jsx("div",{className:"state",children:"Bezig met laden…"}),a&&u.jsx("div",{className:"state error",children:a}),!i&&!a&&u.jsxs("section",{className:"grid",children:[P.length===0&&u.jsx("div",{className:"state",children:"Nog geen repositories toegevoegd."}),P.map(T=>{const U=w===T.id;return u.jsxs("article",{className:"card",children:[u.jsxs("div",{className:"card-header",children:[u.jsx("h3",{children:T.label||T.ownerRepo}),u.jsxs("span",{className:"pill",children:["#",T.id]})]}),!U&&u.jsxs(u.Fragment,{children:[u.jsx("p",{children:T.ownerRepo}),u.jsxs("div",{className:"meta",children:[u.jsx("span",{children:T.provider}),u.jsx("span",{children:T.baseUrl||(T.provider==="github"?"github.com":"n.v.t.")})]}),u.jsxs("div",{className:"actions",children:[u.jsx("button",{className:"ghost",type:"button",onClick:()=>B(T),children:"Bewerk"}),u.jsx("button",{className:"ghost",type:"button",onClick:()=>ie(T.id),disabled:p===T.id,children:p===T.id?"Verwijderen…":"Verwijder"})]})]}),U&&u.jsxs("form",{className:"form-grid",onSubmit:I,children:[u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Owner/Repo"}),u.jsx("input",{value:d.ownerRepo,onChange:$=>f(oe=>({...oe,ownerRepo:$.target.value}))})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Provider"}),u.jsx("select",{value:d.provider,onChange:$=>f(oe=>({...oe,provider:$.target.value})),children:Wa.map($=>u.jsx("option",{value:$.value,children:$.label},$.value))})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Base URL"}),u.jsx("input",{value:d.baseUrl,onChange:$=>f(oe=>({...oe,baseUrl:$.target.value}))})]}),u.jsxs("label",{className:"field",children:[u.jsx("span",{children:"Label"}),u.jsx("input",{value:d.label,onChange:$=>f(oe=>({...oe,label:$.target.value}))})]}),u.jsxs("div",{className:"actions",children:[u.jsx("button",{className:"cta",type:"submit",children:"Opslaan"}),u.jsx("button",{className:"ghost",type:"button",onClick:()=>{k(null),f({ownerRepo:"",provider:"github",baseUrl:"",label:""})},children:"Annuleer"})]})]})]},T.id)})]})]})}function gm(){return u.jsxs("div",{className:"app",children:[u.jsx(um,{}),u.jsxs(Kh,{children:[u.jsx(Xn,{path:"/",element:u.jsx(cm,{})}),u.jsx(Xn,{path:"/plugin/:owner/:repo",element:u.jsx(fm,{})}),u.jsx(Xn,{path:"/licenses",element:u.jsx(hm,{})}),u.jsx(Xn,{path:"/repos",element:u.jsx(vm,{})})]})]})}rf(document.getElementById("root")).render(u.jsx(eu.StrictMode,{children:u.jsx(tm,{children:u.jsx(am,{children:u.jsx(gm,{})})})})); diff --git a/dist/index.html b/dist/index.html index 86cbdbe..29a5b38 100644 --- a/dist/index.html +++ b/dist/index.html @@ -5,7 +5,7 @@ Siti Plugin Repo - + diff --git a/server/index.js b/server/index.js index 21163ec..6f3f02d 100644 --- a/server/index.js +++ b/server/index.js @@ -18,6 +18,15 @@ import { listLicensesByUser, touchLicenseHostname } from "./lib/licenseService.js"; +import { + countRepos, + createRepo as createRepoRecord, + deleteRepo as deleteRepoRecord, + findRepoByOwnerRepo, + getRepoById, + listRepos, + updateRepo as updateRepoRecord +} from "./lib/repoService.js"; import { HOST, PATHS, PORT } from "./lib/config.js"; import { ensureSchema } from "./lib/schema.js"; import { authenticateUser, registerUser, adminCreateUser, listUsers, getUserById } from "./lib/userService.js"; @@ -29,6 +38,7 @@ app.use(express.json()); try { await ensureSchema(); + await seedLegacyRepos(); } catch (error) { console.error("Kon database schema niet initialiseren:", error); process.exit(1); @@ -50,12 +60,18 @@ async function resolveRepoMetaFromRequest(body = {}) { return null; } - const provider = (body.provider || body.repoProvider || "github").toLowerCase(); - const baseUrl = body.baseUrl || body.repoBaseUrl || (provider === "github" ? "https://github.com" : null); + const requestedProvider = (body.provider || body.repoProvider || "").toLowerCase() || null; + const requestedBaseUrl = body.baseUrl || body.repoBaseUrl || null; + const ownerRepo = `${owner}/${repository}`; + + const existing = await findRepoByOwnerRepo(ownerRepo, requestedProvider || undefined); + const provider = existing?.provider || requestedProvider || "github"; + const baseUrl = + existing?.baseUrl || requestedBaseUrl || (provider === "github" ? "https://github.com" : null); const repoEntry = normalizeRepoInput( - { repo: `${owner}/${repository}`, provider, baseUrl }, - { repo: `${owner}/${repository}`, provider, baseUrl } + { repo: ownerRepo, provider, baseUrl }, + { repo: ownerRepo, provider, baseUrl } ); if (!repoEntry) { @@ -68,9 +84,10 @@ async function resolveRepoMetaFromRequest(body = {}) { const releases = await fetchReleases(repoEntry).catch(() => []); const latestRelease = releases[0]; const version = manifest?.version || latestRelease?.tag || latestRelease?.name || info.defaultBranch || null; - const pluginName = manifest?.plugin_name || info.name || repository; + const pluginName = manifest?.plugin_name || existing?.label || info.name || repository; return { + repoId: existing?.id || null, repoEntry, pluginName, version @@ -80,6 +97,30 @@ async function resolveRepoMetaFromRequest(body = {}) { } } +async function seedLegacyRepos() { + try { + const repoCount = await countRepos(); + if (repoCount > 0) { + return; + } + const legacy = await readRepos(PATHS.reposFile); + if (!Array.isArray(legacy) || legacy.length === 0) { + return; + } + for (const entry of legacy) { + try { + await createRepoRecord(entry); + } catch (error) { + if (error?.meta !== "DUPLICATE") { + console.warn("Kon legacy repo niet importeren:", error.message); + } + } + } + } catch (error) { + console.warn("Legacy repos importeren mislukt:", error.message); + } +} + app.post("/api/auth/register", async (req, res) => { try { const { username, name, email, password } = req.body || {}; @@ -158,34 +199,136 @@ app.post("/api/admin/users", requireAuth, requireAdmin, async (req, res) => { } }); +function resolveOwnerRepoFromBody(body = {}) { + if (body.ownerRepo) { + return String(body.ownerRepo).trim(); + } + const owner = typeof body.owner === "string" ? body.owner.trim() : ""; + const repo = typeof body.repo === "string" ? body.repo.trim() : ""; + if (owner && repo) { + return `${owner}/${repo}`; + } + return ""; +} + +app.get("/api/repos", requireAuth, requireAdmin, async (_req, res) => { + try { + const repos = await listRepos(); + res.json({ count: repos.length, items: repos }); + } catch (error) { + res.status(500).json({ error: "Kon repos niet laden." }); + } +}); + +app.post("/api/repos", requireAuth, requireAdmin, async (req, res) => { + try { + const ownerRepo = resolveOwnerRepoFromBody(req.body); + if (!ownerRepo) { + return res.status(400).json({ error: "Geef een owner en repo op." }); + } + const provider = (req.body?.provider || "github").toLowerCase(); + const baseUrl = req.body?.baseUrl || null; + const label = req.body?.label || null; + const repo = await createRepoRecord({ + provider, + ownerRepo, + baseUrl, + label + }); + res.status(201).json({ repo }); + } catch (error) { + if (error?.meta === "DUPLICATE") { + return res.status(409).json({ error: error.message }); + } + res.status(500).json({ error: "Kon repo niet opslaan." }); + } +}); + +app.patch("/api/repos/:id", requireAuth, requireAdmin, async (req, res) => { + try { + const repoId = Number(req.params.id); + if (Number.isNaN(repoId)) { + return res.status(400).json({ error: "Ongeldige repo id." }); + } + const ownerRepo = resolveOwnerRepoFromBody(req.body); + const payload = { + provider: req.body?.provider, + ownerRepo: ownerRepo || undefined, + baseUrl: req.body?.baseUrl, + label: req.body?.label + }; + const repo = await updateRepoRecord(repoId, payload); + res.json({ repo }); + } catch (error) { + if (error?.meta === "NOT_FOUND") { + return res.status(404).json({ error: error.message }); + } + if (error?.meta === "DUPLICATE") { + return res.status(409).json({ error: error.message }); + } + res.status(500).json({ error: "Kon repo niet bijwerken." }); + } +}); + +app.delete("/api/repos/:id", requireAuth, requireAdmin, async (req, res) => { + try { + const repoId = Number(req.params.id); + if (Number.isNaN(repoId)) { + return res.status(400).json({ error: "Ongeldige repo id." }); + } + await deleteRepoRecord(repoId); + res.status(204).end(); + } catch (error) { + if (error?.meta === "NOT_FOUND") { + return res.status(404).json({ error: error.message }); + } + if (error?.meta === "IN_USE") { + return res.status(409).json({ error: error.message }); + } + res.status(500).json({ error: "Kon repo niet verwijderen." }); + } +}); + app.get("/api/plugins", async (_req, res) => { try { - const repos = await readRepos(PATHS.reposFile); + const repos = await listRepos(); const results = await Promise.all( repos.map(async (repo) => { + const entry = { + provider: repo.provider, + repo: repo.ownerRepo, + baseUrl: repo.baseUrl + }; try { - const info = await fetchRepo(repo); - const manifest = await fetchManifest(repo, info.defaultBranch || info.default_branch); - return { ...info, manifest }; + const info = await fetchRepo(entry); + const manifest = await fetchManifest(entry, info.defaultBranch || info.default_branch); + return { + ...info, + manifest, + provider: repo.provider, + baseUrl: repo.baseUrl, + repoId: repo.id, + label: repo.label, + ownerRepo: repo.ownerRepo + }; } catch { - const parsed = parseRepoEntry(repo); + const parsed = parseRepoEntry(entry); return { fullName: parsed.ownerRepo, name: parsed.ownerRepo.split("/")[1] || parsed.ownerRepo, description: "Kon gegevens niet ophalen.", - repoUrl: - parsed.provider === "gitea" - ? `${parsed.baseUrl.replace(/\/$/, "")}/${parsed.ownerRepo}` - : `https://github.com/${parsed.ownerRepo}`, + repoUrl: buildRepoUrl({ provider: repo.provider, baseUrl: repo.baseUrl, repo: repo.ownerRepo }), stars: 0, forks: 0, issues: 0, updatedAt: null, topics: [], manifest: null, - provider: parsed.provider, - ownerRepo: parsed.ownerRepo, - baseUrl: parsed.baseUrl + provider: repo.provider, + ownerRepo: repo.ownerRepo, + baseUrl: repo.baseUrl, + repoId: repo.id, + label: repo.label }; } }) @@ -223,9 +366,24 @@ function buildPluginDownloadEndpoint(ownerRepo, { provider, baseUrl, version } = app.get("/api/plugins/:owner/:repo", async (req, res) => { const ownerRepo = `${req.params.owner}/${req.params.repo}`; try { - const provider = (req.query.provider || "github").toLowerCase(); - const baseUrlQuery = req.query.baseUrl || (provider === "github" ? "https://github.com" : ""); - const entry = provider === "github" ? ownerRepo : { provider, repo: ownerRepo, baseUrl: baseUrlQuery }; + const repoIdQuery = Number(req.query.repoId); + let repoRecord = null; + if (!Number.isNaN(repoIdQuery)) { + repoRecord = await getRepoById(repoIdQuery); + } + if (!repoRecord) { + repoRecord = await findRepoByOwnerRepo(ownerRepo); + } + + const provider = (req.query.provider || repoRecord?.provider || "github").toLowerCase(); + const baseUrlQuery = + req.query.baseUrl || repoRecord?.baseUrl || (provider === "github" ? "https://github.com" : ""); + const entry = + repoRecord && repoRecord.ownerRepo + ? { provider: repoRecord.provider, repo: repoRecord.ownerRepo, baseUrl: repoRecord.baseUrl } + : provider === "github" + ? ownerRepo + : { provider, repo: ownerRepo, baseUrl: baseUrlQuery }; const normalizedEntry = normalizeRepoInput(entry, { repo: ownerRepo, provider, baseUrl: baseUrlQuery }); const info = await fetchRepo(entry); @@ -289,6 +447,8 @@ app.get("/api/plugins/:owner/:repo", async (req, res) => { res.json({ ...info, + repoId: repoRecord?.id || null, + label: repoRecord?.label || null, version: resolvedVersion, versionSource, manifest, @@ -379,6 +539,10 @@ app.get("/api/licenses", requireAuth, async (req, res) => { app.post("/api/licenses", requireAuth, async (req, res) => { try { const body = req.body || {}; + const repoId = body.repoId ? Number(body.repoId) : null; + if (body.repoId && Number.isNaN(repoId)) { + return res.status(400).json({ error: "Ongeldig repo id." }); + } const repoInput = typeof body.repo === "object" ? body.repo @@ -392,7 +556,7 @@ app.post("/api/licenses", requireAuth, async (req, res) => { baseUrl: body.baseUrl }) || null; - if (!repoEntry) { + if (!repoId && !repoEntry) { return res.status(400).json({ error: "Kies een plugin om de licentie aan te koppelen." }); } @@ -418,7 +582,8 @@ app.post("/api/licenses", requireAuth, async (req, res) => { const payload = await createLicense(ownerUserId, { label: body.label?.trim(), note: body.note?.trim(), - repo: repoEntry + repo: repoEntry, + repoId: repoId || undefined }); res.status(201).json(payload); } catch (error) { @@ -443,6 +608,7 @@ app.post("/api/licenses/verify", async (req, res) => { pluginVersion: repoMeta.version, repoFullName: repoMeta.repoEntry.repo, repoUrl: buildRepoUrl(repoMeta.repoEntry), + repoId: repoMeta.repoId || null, repo: repoMeta.repoEntry } } diff --git a/server/lib/licenseService.js b/server/lib/licenseService.js index 0a5f631..f5c5e37 100644 --- a/server/lib/licenseService.js +++ b/server/lib/licenseService.js @@ -1,6 +1,7 @@ import crypto from "crypto"; import db from "./db.js"; import { fetchManifest, fetchRepo, normalizeRepoInput } from "./pluginService.js"; +import { getRepoById } from "./repoService.js"; function toIso(value) { return value ? new Date(value).toISOString() : null; @@ -31,12 +32,29 @@ export async function findLicenseByKey(key) { return rows[0] || null; } -export async function createLicense(userId, { label, note, repo }) { - const repoEntry = normalizeRepoInput(repo); - if (!repoEntry) { - const error = new Error("Ongeldige plugin referentie."); - error.meta = "INVALID_REPO"; - throw error; +export async function createLicense(userId, { label, note, repo, repoId }) { + let repoEntry = null; + let repoRow = null; + + if (repoId) { + repoRow = await getRepoById(repoId); + if (!repoRow) { + const error = new Error("Onbekende repository."); + error.meta = "INVALID_REPO"; + throw error; + } + repoEntry = { + repo: repoRow.ownerRepo, + provider: repoRow.provider, + baseUrl: repoRow.baseUrl + }; + } else { + repoEntry = normalizeRepoInput(repo); + if (!repoEntry) { + const error = new Error("Ongeldige plugin referentie."); + error.meta = "INVALID_REPO"; + throw error; + } } let licenseId = null; @@ -47,9 +65,9 @@ export async function createLicense(userId, { label, note, repo }) { await db.query( `INSERT INTO licenses ( id, user_id, license_key, label, note, - repo_provider, repo_name, repo_base_url, + repo_provider, repo_name, repo_base_url, repo_id, created_at, updated_at - ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, NOW(), NOW())`, + ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, NOW(), NOW())`, [ id, userId, @@ -58,7 +76,8 @@ export async function createLicense(userId, { label, note, repo }) { note || null, repoEntry.provider || "github", repoEntry.repo, - repoEntry.baseUrl || (repoEntry.provider === "github" ? "https://github.com" : null) + repoEntry.baseUrl || (repoEntry.provider === "github" ? "https://github.com" : null), + repoRow?.id || null ] ); licenseId = id; @@ -80,11 +99,24 @@ export async function createLicense(userId, { label, note, repo }) { export async function buildLicensePayload(row) { if (!row) return null; - const repoEntry = normalizeRepoInput({ - repo: row.repo_name, - provider: row.repo_provider, - baseUrl: row.repo_base_url - }); + + let repoRow = null; + if (row.repo_id) { + repoRow = await getRepoById(row.repo_id); + } + + const repoEntry = + repoRow && repoRow.ownerRepo + ? { + repo: repoRow.ownerRepo, + provider: repoRow.provider, + baseUrl: repoRow.baseUrl + } + : normalizeRepoInput({ + repo: row.repo_name, + provider: row.repo_provider, + baseUrl: row.repo_base_url + }); const [hostnameRows] = await db.query( `SELECT hostname, normalized, first_seen_at, last_seen_at, hits FROM license_hostnames WHERE license_id = ? ORDER BY first_seen_at ASC`, @@ -112,6 +144,8 @@ export async function buildLicensePayload(row) { primaryHostnameNormalized: row.primary_hostname_normalized, repoFullName: row.repo_name, repoUrl: null, + repoId: repoRow?.id || null, + repoLabel: repoRow?.label || null, pluginName: row.label, pluginVersion: row.last_used_version || null, lastUsedVersion: row.last_used_version, @@ -134,7 +168,9 @@ export async function buildLicensePayload(row) { primaryHostnameNormalized: row.primary_hostname_normalized, repoFullName: info.fullName, repoUrl: info.repoUrl, - pluginName: manifest?.plugin_name || info.name || row.label, + repoId: repoRow?.id || null, + repoLabel: repoRow?.label || null, + pluginName: manifest?.plugin_name || repoRow?.label || info.name || row.label, pluginVersion: manifest?.version || row.last_used_version || null, lastUsedVersion: row.last_used_version, repo: repoEntry, @@ -151,9 +187,14 @@ export async function buildLicensePayload(row) { lastVersionCheckAt: toIso(row.last_version_check_at), primaryHostname: row.primary_hostname, primaryHostnameNormalized: row.primary_hostname_normalized, - repoFullName: row.repo_name, - repoUrl: repoEntry?.baseUrl ? `${repoEntry.baseUrl.replace(/\/$/, "")}/${row.repo_name}` : null, - pluginName: row.label, + repoFullName: repoRow?.ownerRepo || row.repo_name, + repoUrl: + (repoRow?.baseUrl || repoEntry?.baseUrl) + ? `${(repoRow?.baseUrl || repoEntry.baseUrl).replace(/\/$/, "")}/${repoRow?.ownerRepo || row.repo_name}` + : null, + repoId: repoRow?.id || null, + repoLabel: repoRow?.label || null, + pluginName: repoRow?.label || row.label, pluginVersion: row.last_used_version || null, lastUsedVersion: row.last_used_version, repo: repoEntry, diff --git a/server/lib/repoService.js b/server/lib/repoService.js new file mode 100644 index 0000000..2aa14ed --- /dev/null +++ b/server/lib/repoService.js @@ -0,0 +1,141 @@ +import db from "./db.js"; + +function toIso(value) { + return value ? new Date(value).toISOString() : null; +} + +function serializeRepo(row) { + if (!row) return null; + return { + id: row.id, + provider: row.provider, + ownerRepo: row.owner_repo, + baseUrl: row.base_url, + label: row.label, + createdAt: toIso(row.created_at), + updatedAt: toIso(row.updated_at) + }; +} + +export async function countRepos() { + const [[{ count }]] = await db.query(`SELECT COUNT(*) AS count FROM repos`); + return Number(count) || 0; +} + +export async function listRepos() { + const [rows] = await db.query(`SELECT * FROM repos ORDER BY created_at ASC, id ASC`); + return rows.map(serializeRepo); +} + +export async function getRepoById(id) { + if (!id) return null; + const [rows] = await db.query(`SELECT * FROM repos WHERE id = ? LIMIT 1`, [id]); + return serializeRepo(rows[0]); +} + +export async function findRepoByOwnerRepo(ownerRepo, provider = null) { + if (!ownerRepo) return null; + if (provider) { + const [rows] = await db.query( + `SELECT * FROM repos WHERE owner_repo = ? AND provider = ? LIMIT 1`, + [ownerRepo, provider.toLowerCase()] + ); + return serializeRepo(rows[0]); + } + const [rows] = await db.query(`SELECT * FROM repos WHERE owner_repo = ? LIMIT 1`, [ownerRepo]); + return serializeRepo(rows[0]); +} + +export async function createRepo({ provider = "github", ownerRepo, baseUrl = null, label = null }) { + if (!ownerRepo) { + const error = new Error("Repo ontbreekt."); + error.meta = "INVALID_REPO"; + throw error; + } + + const normalizedProvider = String(provider || "github").toLowerCase(); + const trimmedOwnerRepo = ownerRepo.trim(); + const sanitizedBaseUrl = baseUrl ? baseUrl.trim() : null; + const safeLabel = label ? label.trim() : null; + + try { + const [result] = await db.query( + `INSERT INTO repos (provider, owner_repo, base_url, label) + VALUES (?, ?, ?, ?)`, + [normalizedProvider, trimmedOwnerRepo, sanitizedBaseUrl, safeLabel] + ); + return await getRepoById(result.insertId); + } catch (error) { + if (error?.code === "ER_DUP_ENTRY") { + const dup = new Error("Deze repository bestaat al."); + dup.meta = "DUPLICATE"; + throw dup; + } + throw error; + } +} + +export async function updateRepo(id, { provider, ownerRepo, baseUrl, label }) { + const repo = await getRepoById(id); + if (!repo) { + const error = new Error("Repo niet gevonden."); + error.meta = "NOT_FOUND"; + throw error; + } + + const fields = []; + const values = []; + + if (provider) { + fields.push("provider = ?"); + values.push(String(provider).toLowerCase()); + } + if (ownerRepo) { + fields.push("owner_repo = ?"); + values.push(ownerRepo.trim()); + } + if (typeof baseUrl !== "undefined") { + fields.push("base_url = ?"); + values.push(baseUrl ? baseUrl.trim() : null); + } + if (typeof label !== "undefined") { + fields.push("label = ?"); + values.push(label ? label.trim() : null); + } + + if (fields.length === 0) { + return repo; + } + + try { + await db.query(`UPDATE repos SET ${fields.join(", ")}, updated_at = NOW() WHERE id = ?`, [...values, id]); + } catch (error) { + if (error?.code === "ER_DUP_ENTRY") { + const dup = new Error("Deze repository bestaat al."); + dup.meta = "DUPLICATE"; + throw dup; + } + throw error; + } + + return await getRepoById(id); +} + +export async function deleteRepo(id) { + const repo = await getRepoById(id); + if (!repo) { + const error = new Error("Repo niet gevonden."); + error.meta = "NOT_FOUND"; + throw error; + } + + const [[{ count }]] = await db.query(`SELECT COUNT(*) AS count FROM licenses WHERE repo_id = ?`, [id]); + if (Number(count) > 0) { + const error = new Error("Repo is gekoppeld aan bestaande licenties."); + error.meta = "IN_USE"; + throw error; + } + + await db.query(`DELETE FROM repos WHERE id = ? LIMIT 1`, [id]); + return repo; +} diff --git a/server/lib/schema.js b/server/lib/schema.js index 82ad3de..5226b1c 100644 --- a/server/lib/schema.js +++ b/server/lib/schema.js @@ -37,6 +37,7 @@ async function createLicensesTable() { repo_provider VARCHAR(32) NOT NULL, repo_name VARCHAR(255) NOT NULL, repo_base_url VARCHAR(255), + repo_id INT UNSIGNED NULL, created_at DATETIME DEFAULT CURRENT_TIMESTAMP, updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, last_version_check_at DATETIME NULL, @@ -52,6 +53,21 @@ async function createLicensesTable() { "last_used_version", "last_used_version VARCHAR(64) NULL AFTER last_version_check_at" ); + + await ensureColumn( + "licenses", + "repo_id", + "repo_id INT UNSIGNED NULL AFTER repo_base_url" + ); + + await db + .query( + `ALTER TABLE licenses + ADD CONSTRAINT fk_licenses_repo_id + FOREIGN KEY (repo_id) REFERENCES repos(id) + ON DELETE SET NULL` + ) + .catch(() => {}); } async function createLicenseHostnamesTable() { @@ -70,8 +86,24 @@ async function createLicenseHostnamesTable() { `); } +async function createReposTable() { + await db.query(` + CREATE TABLE IF NOT EXISTS repos ( + id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY, + provider VARCHAR(32) NOT NULL DEFAULT 'github', + owner_repo VARCHAR(255) NOT NULL, + base_url VARCHAR(255), + label VARCHAR(255), + created_at DATETIME DEFAULT CURRENT_TIMESTAMP, + updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, + UNIQUE KEY unique_repo_provider (provider, owner_repo) + ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; + `); +} + export async function ensureSchema() { await createUsersTable(); + await createReposTable(); await createLicensesTable(); await createLicenseHostnamesTable(); } diff --git a/src/App.jsx b/src/App.jsx index dee343b..750df34 100644 --- a/src/App.jsx +++ b/src/App.jsx @@ -3,6 +3,7 @@ import SiteNav from "./components/SiteNav.jsx"; import Home from "./pages/Home.jsx"; import PluginDetail from "./pages/PluginDetail.jsx"; import LicenseManager from "./pages/LicenseManager.jsx"; +import RepoManager from "./pages/RepoManager.jsx"; import "./App.css"; export default function App() { @@ -13,6 +14,7 @@ export default function App() { } /> } /> } /> + } /> ); diff --git a/src/components/SiteNav.jsx b/src/components/SiteNav.jsx index d174699..af01ad2 100644 --- a/src/components/SiteNav.jsx +++ b/src/components/SiteNav.jsx @@ -11,6 +11,7 @@ export default function SiteNav() {
Plugins Licenties + {user?.isAdmin && Repos}
{user ? ( diff --git a/src/pages/Home.jsx b/src/pages/Home.jsx index 75f472c..6a0cead 100644 --- a/src/pages/Home.jsx +++ b/src/pages/Home.jsx @@ -47,7 +47,7 @@ export default function Home() {
Geen repositories gevonden.
)} {plugins.map((plugin) => { - const displayName = plugin.manifest?.plugin_name || plugin.name; + const displayName = plugin.label || plugin.manifest?.plugin_name || plugin.name; const description = plugin.manifest?.description || plugin.description; const searchParams = new URLSearchParams(); if (plugin.provider) { @@ -56,6 +56,9 @@ export default function Home() { if (plugin.baseUrl) { searchParams.set("baseUrl", plugin.baseUrl); } + if (plugin.repoId) { + searchParams.set("repoId", String(plugin.repoId)); + } const repoLabel = plugin.provider === "gitea" ? "Gitea" : "GitHub"; const detailUrl = `/plugin/${plugin.fullName}` + (searchParams.toString() ? `?${searchParams.toString()}` : ""); diff --git a/src/pages/LicenseManager.jsx b/src/pages/LicenseManager.jsx index 6b5faff..5881df0 100644 --- a/src/pages/LicenseManager.jsx +++ b/src/pages/LicenseManager.jsx @@ -191,16 +191,21 @@ export default function LicenseManager() { const payload = { label: label.trim() || + selectedPlugin.label || selectedPlugin.manifest?.plugin_name || selectedPlugin.name || selectedPlugin.fullName, - note: note.trim() || undefined, - repo: { + note: note.trim() || undefined + }; + if (selectedPlugin.repoId) { + payload.repoId = selectedPlugin.repoId; + } else { + payload.repo = { repo: selectedPlugin.ownerRepo || selectedPlugin.fullName, provider: selectedPlugin.provider || "github", baseUrl: selectedPlugin.baseUrl - } - }; + }; + } const requestBody = { ...payload, userId: user?.isAdmin ? Number(selectedOwnerId || user.id) : undefined @@ -371,9 +376,14 @@ export default function LicenseManager() { > {plugins.map((plugin) => { const id = plugin.ownerRepo || plugin.fullName; + const optionLabel = + plugin.label || + plugin.manifest?.plugin_name || + plugin.name || + plugin.fullName; return ( ); })} diff --git a/src/pages/PluginDetail.jsx b/src/pages/PluginDetail.jsx index a7ab5b4..bca527d 100644 --- a/src/pages/PluginDetail.jsx +++ b/src/pages/PluginDetail.jsx @@ -6,6 +6,7 @@ export default function PluginDetail() { const [searchParams] = useSearchParams(); const provider = (searchParams.get("provider") || "github").toLowerCase(); const baseUrl = searchParams.get("baseUrl") || ""; + const repoId = searchParams.get("repoId") || ""; const [data, setData] = useState(null); const [loading, setLoading] = useState(true); const [error, setError] = useState(null); @@ -20,6 +21,9 @@ export default function PluginDetail() { if (baseUrl) { query.set("baseUrl", baseUrl); } + if (repoId) { + query.set("repoId", repoId); + } const search = query.toString(); const response = await fetch( `/api/plugins/${owner}/${repo}${search.length > 0 ? `?${search}` : ""}` @@ -40,7 +44,7 @@ export default function PluginDetail() { }, [owner, repo, provider, baseUrl]); const manifest = data?.manifest; - const displayName = manifest?.plugin_name || data?.name || repo; + const displayName = data?.label || manifest?.plugin_name || data?.name || repo; const description = manifest?.description || data?.description; const author = manifest?.author || "-"; const version = manifest?.version || "-"; diff --git a/src/pages/RepoManager.jsx b/src/pages/RepoManager.jsx new file mode 100644 index 0000000..e649089 --- /dev/null +++ b/src/pages/RepoManager.jsx @@ -0,0 +1,339 @@ +import { useCallback, useEffect, useMemo, useState } from "react"; +import { useAuth } from "../context/AuthContext.jsx"; + +const PROVIDERS = [ + { value: "github", label: "GitHub" }, + { value: "gitea", label: "Gitea" } +]; + +export default function RepoManager() { + const { user, authFetch } = useAuth(); + const isAdmin = Boolean(user?.isAdmin); + const [repos, setRepos] = useState([]); + const [loading, setLoading] = useState(true); + const [error, setError] = useState(null); + const [form, setForm] = useState({ + ownerRepo: "", + provider: "github", + baseUrl: "", + label: "" + }); + const [saving, setSaving] = useState(false); + const [actionState, setActionState] = useState(null); + const [editingId, setEditingId] = useState(null); + const [editForm, setEditForm] = useState({ + ownerRepo: "", + provider: "github", + baseUrl: "", + label: "" + }); + const [deletingId, setDeletingId] = useState(null); + + const canManage = Boolean(user && isAdmin); + + const loadRepos = useCallback(async () => { + if (!canManage) { + setRepos([]); + setLoading(false); + return; + } + setLoading(true); + setError(null); + try { + const response = await authFetch("/api/repos"); + const data = await response.json().catch(() => ({})); + if (!response.ok) { + throw new Error(data.error || "Kon repos niet laden."); + } + setRepos(data.items || []); + } catch (err) { + setError(err.message); + } finally { + setLoading(false); + } + }, [authFetch, canManage]); + + useEffect(() => { + loadRepos(); + }, [loadRepos]); + + const sortedRepos = useMemo(() => { + return [...repos].sort((a, b) => a.ownerRepo.localeCompare(b.ownerRepo)); + }, [repos]); + + if (!user) { + return ( +
+
Log in om repositories te beheren.
+
+ ); + } + + if (!isAdmin) { + return ( +
+
Alleen admins kunnen repositories beheren.
+
+ ); + } + + async function handleCreate(event) { + event.preventDefault(); + if (!form.ownerRepo.trim()) { + setActionState({ variant: "error", message: "Vul het owner/repo veld in." }); + return; + } + setSaving(true); + setActionState(null); + try { + const response = await authFetch("/api/repos", { + method: "POST", + headers: { "Content-Type": "application/json" }, + body: JSON.stringify(form) + }); + const data = await response.json().catch(() => ({})); + if (!response.ok) { + throw new Error(data.error || "Repo aanmaken mislukt."); + } + setRepos((prev) => [...prev, data.repo]); + setForm({ + ownerRepo: "", + provider: "github", + baseUrl: "", + label: "" + }); + setActionState({ variant: "success", message: "Repo toegevoegd." }); + } catch (err) { + setActionState({ variant: "error", message: err.message }); + } finally { + setSaving(false); + } + } + + function startEdit(repo) { + setEditingId(repo.id); + setEditForm({ + ownerRepo: repo.ownerRepo || "", + provider: repo.provider || "github", + baseUrl: repo.baseUrl || "", + label: repo.label || "" + }); + setActionState(null); + } + + async function handleUpdate(event) { + event.preventDefault(); + if (!editingId) return; + try { + const response = await authFetch(`/api/repos/${editingId}`, { + method: "PATCH", + headers: { "Content-Type": "application/json" }, + body: JSON.stringify(editForm) + }); + const data = await response.json().catch(() => ({})); + if (!response.ok) { + throw new Error(data.error || "Repo bijwerken mislukt."); + } + setRepos((prev) => prev.map((repo) => (repo.id === editingId ? data.repo : repo))); + setEditingId(null); + setActionState({ variant: "success", message: "Repo bijgewerkt." }); + } catch (err) { + setActionState({ variant: "error", message: err.message }); + } + } + + async function handleDelete(id) { + if (!window.confirm("Weet je zeker dat je deze repo wilt verwijderen?")) { + return; + } + setDeletingId(id); + setActionState(null); + try { + const response = await authFetch(`/api/repos/${id}`, { + method: "DELETE" + }); + if (!response.ok) { + const data = await response.json().catch(() => ({})); + throw new Error(data.error || "Verwijderen mislukt."); + } + setRepos((prev) => prev.filter((repo) => repo.id !== id)); + if (editingId === id) { + setEditingId(null); + } + setActionState({ variant: "success", message: "Repo verwijderd." }); + } catch (err) { + setActionState({ variant: "error", message: err.message }); + } finally { + setDeletingId(null); + } + } + + return ( +
+
+
+

Repository beheer

+

Repos

+

Voeg nieuwe plugin repositories toe of werk bestaande entries bij.

+
+
+ +
+
+

Nieuwe repo

+
+ + + + + +
+ {actionState &&
{actionState.message}
} +
+
+ + {loading &&
Bezig met laden…
} + {error &&
{error}
} + + {!loading && !error && ( +
+ {sortedRepos.length === 0 &&
Nog geen repositories toegevoegd.
} + {sortedRepos.map((repo) => { + const isEditing = editingId === repo.id; + return ( +
+
+

{repo.label || repo.ownerRepo}

+ #{repo.id} +
+ {!isEditing && ( + <> +

{repo.ownerRepo}

+
+ {repo.provider} + {repo.baseUrl || (repo.provider === "github" ? "github.com" : "n.v.t.")} +
+
+ + +
+ + )} + {isEditing && ( +
+ + + + +
+ + +
+
+ )} +
+ ); + })} +
+ )} +
+ ); +}