@weppy/roblox-mcp 2.7.18 → 2.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/dashboard/dist/assets/AssetsPage-BQGliX7Q.css +1 -0
  3. package/dashboard/dist/assets/AssetsPage-yddSUaZg.js +51 -0
  4. package/dashboard/dist/assets/{ChangelogDetailPage-Cado4LDZ.js → ChangelogDetailPage-BiiG5ZpO.js} +1 -1
  5. package/dashboard/dist/assets/ChangelogPage-oIxW8_VE.js +1 -0
  6. package/dashboard/dist/assets/ConfirmModal-CpImpY9c.js +1 -0
  7. package/dashboard/dist/assets/ConnectionPage-zGBwRnwi.js +1 -0
  8. package/dashboard/dist/assets/{GameChangeDetail-BvLY7yg8.js → GameChangeDetail-CghOvUm8.js} +1 -1
  9. package/dashboard/dist/assets/{InfoLabel-LyMkHb1i.js → InfoLabel-Cyz7d4Kc.js} +1 -1
  10. package/dashboard/dist/assets/OverviewPage-B6ZL_JXU.js +1 -0
  11. package/dashboard/dist/assets/PageHeader-2-fusgsY.css +1 -0
  12. package/dashboard/dist/assets/PageHeader-CThGgsAt.js +6 -0
  13. package/dashboard/dist/assets/PlaytestPage-CQqE8m04.js +11 -0
  14. package/dashboard/dist/assets/SettingsPage-DX6vgUTw.js +1 -0
  15. package/dashboard/dist/assets/SettingsPage-d0wOFs8U.css +1 -0
  16. package/dashboard/dist/assets/{StatusBadge-CLJmMG0w.js → StatusBadge-CkLieULy.js} +1 -1
  17. package/dashboard/dist/assets/SyncPage-cfQ-4IDk.js +4 -0
  18. package/dashboard/dist/assets/{Tabs-C9KNjyNX.js → Tabs-BhkhdCvF.js} +1 -1
  19. package/dashboard/dist/assets/ToolsPage-B004HHzX.js +1 -0
  20. package/dashboard/dist/assets/{TooltipText-BPEldl3x.js → TooltipText-H3YSCbob.js} +1 -1
  21. package/dashboard/dist/assets/UiStudioPage-CwURRVO9.js +11 -0
  22. package/dashboard/dist/assets/WhatsNewPage-BIYOEZg3.css +1 -0
  23. package/dashboard/dist/assets/WhatsNewPage-CBUk7WTn.js +1 -0
  24. package/dashboard/dist/assets/index-CjzKb5lS.css +1 -0
  25. package/dashboard/dist/assets/index-DG2RrKOl.js +532 -0
  26. package/dashboard/dist/assets/{sample-requests-Bttgc133.js → sample-requests-D1b5Z8FU.js} +1 -1
  27. package/dashboard/dist/assets/{useLiveUptime-CksXMBr9.js → useLiveUptime-BHqJirBV.js} +1 -1
  28. package/dashboard/dist/index.html +2 -2
  29. package/dist/index.js +96 -91
  30. package/package.json +1 -1
  31. package/roblox-plugin/WeppyRobloxMCP.rbxm +0 -0
  32. package/dashboard/dist/assets/ChangelogPage-DyS8_4IL.js +0 -1
  33. package/dashboard/dist/assets/ConfirmModal-C66ZwIur.js +0 -1
  34. package/dashboard/dist/assets/ConnectionPage-DsGgzpmn.js +0 -1
  35. package/dashboard/dist/assets/OverviewPage-BDkw5pqk.js +0 -1
  36. package/dashboard/dist/assets/PlaytestPage-Chwh5KSd.js +0 -11
  37. package/dashboard/dist/assets/SettingsPage-7nNA3k5H.js +0 -1
  38. package/dashboard/dist/assets/SettingsPage-Du8-FZAO.css +0 -1
  39. package/dashboard/dist/assets/SyncPage-CUP2s1T6.js +0 -4
  40. package/dashboard/dist/assets/ToolsPage-QacrKG2A.js +0 -1
  41. package/dashboard/dist/assets/UiStudioPage-RUjTAi4h.js +0 -16
  42. package/dashboard/dist/assets/WhatsNewPage-CKNhbHAQ.js +0 -1
  43. package/dashboard/dist/assets/WhatsNewPage-D5OncQnl.css +0 -1
  44. package/dashboard/dist/assets/index-CZ4Jn6CC.css +0 -1
  45. package/dashboard/dist/assets/index-VNIYQxwF.js +0 -481
@@ -0,0 +1,532 @@
1
+ const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/OverviewPage-B6ZL_JXU.js","assets/InfoLabel-Cyz7d4Kc.js","assets/PageHeader-CThGgsAt.js","assets/PageHeader-2-fusgsY.css","assets/StatusBadge-CkLieULy.js","assets/StatusBadge-C2zYt5iE.css","assets/TooltipText-H3YSCbob.js","assets/GameChangeDetail-CghOvUm8.js","assets/GameChangeDetail-C1XtdYwk.css","assets/useLiveUptime-BHqJirBV.js","assets/OverviewPage-Dsfl-NRT.css","assets/ConnectionPage-zGBwRnwi.js","assets/ConfirmModal-CpImpY9c.js","assets/ConnectionPage-CNtjimlm.css","assets/SyncPage-cfQ-4IDk.js","assets/SyncPage-COxqxAjv.css","assets/AssetsPage-yddSUaZg.js","assets/AssetsPage-BQGliX7Q.css","assets/ChangelogPage-oIxW8_VE.js","assets/Tabs-BhkhdCvF.js","assets/Tabs-876h0_zB.css","assets/ChangelogPage-DsP0fTsc.css","assets/PlaytestPage-CQqE8m04.js","assets/PlaytestPage-DjjsIkke.css","assets/UiStudioPage-CwURRVO9.js","assets/sample-requests-D1b5Z8FU.js","assets/sample-requests-CygerZZ_.css","assets/UiStudioPage-eSinjpOX.css","assets/ToolsPage-B004HHzX.js","assets/ToolsPage-Bt9vYA7u.css","assets/WhatsNewPage-CBUk7WTn.js","assets/WhatsNewPage-BIYOEZg3.css","assets/ChangelogDetailPage-BiiG5ZpO.js","assets/ChangelogDetailPage-D6Tqz7ut.css","assets/SettingsPage-DX6vgUTw.js","assets/SettingsPage-d0wOFs8U.css"])))=>i.map(i=>d[i]);
2
+ var Th=Object.defineProperty;var jh=(i,n,r)=>n in i?Th(i,n,{enumerable:!0,configurable:!0,writable:!0,value:r}):i[n]=r;var Eo=(i,n,r)=>jh(i,typeof n!="symbol"?n+"":n,r);function gp(i,n){for(var r=0;r<n.length;r++){const d=n[r];if(typeof d!="string"&&!Array.isArray(d)){for(const u in d)if(u!=="default"&&!(u in i)){const p=Object.getOwnPropertyDescriptor(d,u);p&&Object.defineProperty(i,u,p.get?p:{enumerable:!0,get:()=>d[u]})}}}return Object.freeze(Object.defineProperty(i,Symbol.toStringTag,{value:"Module"}))}(function(){const n=document.createElement("link").relList;if(n&&n.supports&&n.supports("modulepreload"))return;for(const u of document.querySelectorAll('link[rel="modulepreload"]'))d(u);new MutationObserver(u=>{for(const p of u)if(p.type==="childList")for(const g of p.addedNodes)g.tagName==="LINK"&&g.rel==="modulepreload"&&d(g)}).observe(document,{childList:!0,subtree:!0});function r(u){const p={};return u.integrity&&(p.integrity=u.integrity),u.referrerPolicy&&(p.referrerPolicy=u.referrerPolicy),u.crossOrigin==="use-credentials"?p.credentials="include":u.crossOrigin==="anonymous"?p.credentials="omit":p.credentials="same-origin",p}function d(u){if(u.ep)return;u.ep=!0;const p=r(u);fetch(u.href,p)}})();function hp(i){return i&&i.__esModule&&Object.prototype.hasOwnProperty.call(i,"default")?i.default:i}var Sl={exports:{}},es={},bl={exports:{}},we={};/**
3
+ * @license React
4
+ * react.production.min.js
5
+ *
6
+ * Copyright (c) Facebook, Inc. and its affiliates.
7
+ *
8
+ * This source code is licensed under the MIT license found in the
9
+ * LICENSE file in the root directory of this source tree.
10
+ */var Cc;function Hh(){if(Cc)return we;Cc=1;var i=Symbol.for("react.element"),n=Symbol.for("react.portal"),r=Symbol.for("react.fragment"),d=Symbol.for("react.strict_mode"),u=Symbol.for("react.profiler"),p=Symbol.for("react.provider"),g=Symbol.for("react.context"),f=Symbol.for("react.forward_ref"),h=Symbol.for("react.suspense"),y=Symbol.for("react.memo"),C=Symbol.for("react.lazy"),b=Symbol.iterator;function D(w){return w===null||typeof w!="object"?null:(w=b&&w[b]||w["@@iterator"],typeof w=="function"?w:null)}var H={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},O=Object.assign,z={};function N(w,U,ge){this.props=w,this.context=U,this.refs=z,this.updater=ge||H}N.prototype.isReactComponent={},N.prototype.setState=function(w,U){if(typeof w!="object"&&typeof w!="function"&&w!=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,w,U,"setState")},N.prototype.forceUpdate=function(w){this.updater.enqueueForceUpdate(this,w,"forceUpdate")};function ie(){}ie.prototype=N.prototype;function F(w,U,ge){this.props=w,this.context=U,this.refs=z,this.updater=ge||H}var X=F.prototype=new ie;X.constructor=F,O(X,N.prototype),X.isPureReactComponent=!0;var Y=Array.isArray,pe=Object.prototype.hasOwnProperty,De={current:null},T={key:!0,ref:!0,__self:!0,__source:!0};function G(w,U,ge){var ye,me={},be=null,Ae=null;if(U!=null)for(ye in U.ref!==void 0&&(Ae=U.ref),U.key!==void 0&&(be=""+U.key),U)pe.call(U,ye)&&!T.hasOwnProperty(ye)&&(me[ye]=U[ye]);var Re=arguments.length-2;if(Re===1)me.children=ge;else if(1<Re){for(var _e=Array(Re),pt=0;pt<Re;pt++)_e[pt]=arguments[pt+2];me.children=_e}if(w&&w.defaultProps)for(ye in Re=w.defaultProps,Re)me[ye]===void 0&&(me[ye]=Re[ye]);return{$$typeof:i,type:w,key:be,ref:Ae,props:me,_owner:De.current}}function Se(w,U){return{$$typeof:i,type:w.type,key:U,ref:w.ref,props:w.props,_owner:w._owner}}function re(w){return typeof w=="object"&&w!==null&&w.$$typeof===i}function ze(w){var U={"=":"=0",":":"=2"};return"$"+w.replace(/[=:]/g,function(ge){return U[ge]})}var Pe=/\/+/g;function Le(w,U){return typeof w=="object"&&w!==null&&w.key!=null?ze(""+w.key):U.toString(36)}function Ce(w,U,ge,ye,me){var be=typeof w;(be==="undefined"||be==="boolean")&&(w=null);var Ae=!1;if(w===null)Ae=!0;else switch(be){case"string":case"number":Ae=!0;break;case"object":switch(w.$$typeof){case i:case n:Ae=!0}}if(Ae)return Ae=w,me=me(Ae),w=ye===""?"."+Le(Ae,0):ye,Y(me)?(ge="",w!=null&&(ge=w.replace(Pe,"$&/")+"/"),Ce(me,U,ge,"",function(pt){return pt})):me!=null&&(re(me)&&(me=Se(me,ge+(!me.key||Ae&&Ae.key===me.key?"":(""+me.key).replace(Pe,"$&/")+"/")+w)),U.push(me)),1;if(Ae=0,ye=ye===""?".":ye+":",Y(w))for(var Re=0;Re<w.length;Re++){be=w[Re];var _e=ye+Le(be,Re);Ae+=Ce(be,U,ge,_e,me)}else if(_e=D(w),typeof _e=="function")for(w=_e.call(w),Re=0;!(be=w.next()).done;)be=be.value,_e=ye+Le(be,Re++),Ae+=Ce(be,U,ge,_e,me);else if(be==="object")throw U=String(w),Error("Objects are not valid as a React child (found: "+(U==="[object Object]"?"object with keys {"+Object.keys(w).join(", ")+"}":U)+"). If you meant to render a collection of children, use an array instead.");return Ae}function Qe(w,U,ge){if(w==null)return w;var ye=[],me=0;return Ce(w,ye,"","",function(be){return U.call(ge,be,me++)}),ye}function tt(w){if(w._status===-1){var U=w._result;U=U(),U.then(function(ge){(w._status===0||w._status===-1)&&(w._status=1,w._result=ge)},function(ge){(w._status===0||w._status===-1)&&(w._status=2,w._result=ge)}),w._status===-1&&(w._status=0,w._result=U)}if(w._status===1)return w._result.default;throw w._result}var Me={current:null},q={transition:null},le={ReactCurrentDispatcher:Me,ReactCurrentBatchConfig:q,ReactCurrentOwner:De};function V(){throw Error("act(...) is not supported in production builds of React.")}return we.Children={map:Qe,forEach:function(w,U,ge){Qe(w,function(){U.apply(this,arguments)},ge)},count:function(w){var U=0;return Qe(w,function(){U++}),U},toArray:function(w){return Qe(w,function(U){return U})||[]},only:function(w){if(!re(w))throw Error("React.Children.only expected to receive a single React element child.");return w}},we.Component=N,we.Fragment=r,we.Profiler=u,we.PureComponent=F,we.StrictMode=d,we.Suspense=h,we.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=le,we.act=V,we.cloneElement=function(w,U,ge){if(w==null)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+w+".");var ye=O({},w.props),me=w.key,be=w.ref,Ae=w._owner;if(U!=null){if(U.ref!==void 0&&(be=U.ref,Ae=De.current),U.key!==void 0&&(me=""+U.key),w.type&&w.type.defaultProps)var Re=w.type.defaultProps;for(_e in U)pe.call(U,_e)&&!T.hasOwnProperty(_e)&&(ye[_e]=U[_e]===void 0&&Re!==void 0?Re[_e]:U[_e])}var _e=arguments.length-2;if(_e===1)ye.children=ge;else if(1<_e){Re=Array(_e);for(var pt=0;pt<_e;pt++)Re[pt]=arguments[pt+2];ye.children=Re}return{$$typeof:i,type:w.type,key:me,ref:be,props:ye,_owner:Ae}},we.createContext=function(w){return w={$$typeof:g,_currentValue:w,_currentValue2:w,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null},w.Provider={$$typeof:p,_context:w},w.Consumer=w},we.createElement=G,we.createFactory=function(w){var U=G.bind(null,w);return U.type=w,U},we.createRef=function(){return{current:null}},we.forwardRef=function(w){return{$$typeof:f,render:w}},we.isValidElement=re,we.lazy=function(w){return{$$typeof:C,_payload:{_status:-1,_result:w},_init:tt}},we.memo=function(w,U){return{$$typeof:y,type:w,compare:U===void 0?null:U}},we.startTransition=function(w){var U=q.transition;q.transition={};try{w()}finally{q.transition=U}},we.unstable_act=V,we.useCallback=function(w,U){return Me.current.useCallback(w,U)},we.useContext=function(w){return Me.current.useContext(w)},we.useDebugValue=function(){},we.useDeferredValue=function(w){return Me.current.useDeferredValue(w)},we.useEffect=function(w,U){return Me.current.useEffect(w,U)},we.useId=function(){return Me.current.useId()},we.useImperativeHandle=function(w,U,ge){return Me.current.useImperativeHandle(w,U,ge)},we.useInsertionEffect=function(w,U){return Me.current.useInsertionEffect(w,U)},we.useLayoutEffect=function(w,U){return Me.current.useLayoutEffect(w,U)},we.useMemo=function(w,U){return Me.current.useMemo(w,U)},we.useReducer=function(w,U,ge){return Me.current.useReducer(w,U,ge)},we.useRef=function(w){return Me.current.useRef(w)},we.useState=function(w){return Me.current.useState(w)},we.useSyncExternalStore=function(w,U,ge){return Me.current.useSyncExternalStore(w,U,ge)},we.useTransition=function(){return Me.current.useTransition()},we.version="18.3.1",we}var wc;function Wl(){return wc||(wc=1,bl.exports=Hh()),bl.exports}/**
11
+ * @license React
12
+ * react-jsx-runtime.production.min.js
13
+ *
14
+ * Copyright (c) Facebook, Inc. and its affiliates.
15
+ *
16
+ * This source code is licensed under the MIT license found in the
17
+ * LICENSE file in the root directory of this source tree.
18
+ */var kc;function Uh(){if(kc)return es;kc=1;var i=Wl(),n=Symbol.for("react.element"),r=Symbol.for("react.fragment"),d=Object.prototype.hasOwnProperty,u=i.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};function g(f,h,y){var C,b={},D=null,H=null;y!==void 0&&(D=""+y),h.key!==void 0&&(D=""+h.key),h.ref!==void 0&&(H=h.ref);for(C in h)d.call(h,C)&&!p.hasOwnProperty(C)&&(b[C]=h[C]);if(f&&f.defaultProps)for(C in h=f.defaultProps,h)b[C]===void 0&&(b[C]=h[C]);return{$$typeof:n,type:f,key:D,ref:H,props:b,_owner:u.current}}return es.Fragment=r,es.jsx=g,es.jsxs=g,es}var xc;function zh(){return xc||(xc=1,Sl.exports=Uh()),Sl.exports}var x=zh(),kn={},Pl={exports:{}},Ht={},Cl={exports:{}},wl={};/**
19
+ * @license React
20
+ * scheduler.production.min.js
21
+ *
22
+ * Copyright (c) Facebook, Inc. and its affiliates.
23
+ *
24
+ * This source code is licensed under the MIT license found in the
25
+ * LICENSE file in the root directory of this source tree.
26
+ */var Ac;function Lh(){return Ac||(Ac=1,(function(i){function n(q,le){var V=q.length;q.push(le);e:for(;0<V;){var w=V-1>>>1,U=q[w];if(0<u(U,le))q[w]=le,q[V]=U,V=w;else break e}}function r(q){return q.length===0?null:q[0]}function d(q){if(q.length===0)return null;var le=q[0],V=q.pop();if(V!==le){q[0]=V;e:for(var w=0,U=q.length,ge=U>>>1;w<ge;){var ye=2*(w+1)-1,me=q[ye],be=ye+1,Ae=q[be];if(0>u(me,V))be<U&&0>u(Ae,me)?(q[w]=Ae,q[be]=V,w=be):(q[w]=me,q[ye]=V,w=ye);else if(be<U&&0>u(Ae,V))q[w]=Ae,q[be]=V,w=be;else break e}}return le}function u(q,le){var V=q.sortIndex-le.sortIndex;return V!==0?V:q.id-le.id}if(typeof performance=="object"&&typeof performance.now=="function"){var p=performance;i.unstable_now=function(){return p.now()}}else{var g=Date,f=g.now();i.unstable_now=function(){return g.now()-f}}var h=[],y=[],C=1,b=null,D=3,H=!1,O=!1,z=!1,N=typeof setTimeout=="function"?setTimeout:null,ie=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 X(q){for(var le=r(y);le!==null;){if(le.callback===null)d(y);else if(le.startTime<=q)d(y),le.sortIndex=le.expirationTime,n(h,le);else break;le=r(y)}}function Y(q){if(z=!1,X(q),!O)if(r(h)!==null)O=!0,tt(pe);else{var le=r(y);le!==null&&Me(Y,le.startTime-q)}}function pe(q,le){O=!1,z&&(z=!1,ie(G),G=-1),H=!0;var V=D;try{for(X(le),b=r(h);b!==null&&(!(b.expirationTime>le)||q&&!ze());){var w=b.callback;if(typeof w=="function"){b.callback=null,D=b.priorityLevel;var U=w(b.expirationTime<=le);le=i.unstable_now(),typeof U=="function"?b.callback=U:b===r(h)&&d(h),X(le)}else d(h);b=r(h)}if(b!==null)var ge=!0;else{var ye=r(y);ye!==null&&Me(Y,ye.startTime-le),ge=!1}return ge}finally{b=null,D=V,H=!1}}var De=!1,T=null,G=-1,Se=5,re=-1;function ze(){return!(i.unstable_now()-re<Se)}function Pe(){if(T!==null){var q=i.unstable_now();re=q;var le=!0;try{le=T(!0,q)}finally{le?Le():(De=!1,T=null)}}else De=!1}var Le;if(typeof F=="function")Le=function(){F(Pe)};else if(typeof MessageChannel<"u"){var Ce=new MessageChannel,Qe=Ce.port2;Ce.port1.onmessage=Pe,Le=function(){Qe.postMessage(null)}}else Le=function(){N(Pe,0)};function tt(q){T=q,De||(De=!0,Le())}function Me(q,le){G=N(function(){q(i.unstable_now())},le)}i.unstable_IdlePriority=5,i.unstable_ImmediatePriority=1,i.unstable_LowPriority=4,i.unstable_NormalPriority=3,i.unstable_Profiling=null,i.unstable_UserBlockingPriority=2,i.unstable_cancelCallback=function(q){q.callback=null},i.unstable_continueExecution=function(){O||H||(O=!0,tt(pe))},i.unstable_forceFrameRate=function(q){0>q||125<q?console.error("forceFrameRate takes a positive int between 0 and 125, forcing frame rates higher than 125 fps is not supported"):Se=0<q?Math.floor(1e3/q):5},i.unstable_getCurrentPriorityLevel=function(){return D},i.unstable_getFirstCallbackNode=function(){return r(h)},i.unstable_next=function(q){switch(D){case 1:case 2:case 3:var le=3;break;default:le=D}var V=D;D=le;try{return q()}finally{D=V}},i.unstable_pauseExecution=function(){},i.unstable_requestPaint=function(){},i.unstable_runWithPriority=function(q,le){switch(q){case 1:case 2:case 3:case 4:case 5:break;default:q=3}var V=D;D=q;try{return le()}finally{D=V}},i.unstable_scheduleCallback=function(q,le,V){var w=i.unstable_now();switch(typeof V=="object"&&V!==null?(V=V.delay,V=typeof V=="number"&&0<V?w+V:w):V=w,q){case 1:var U=-1;break;case 2:U=250;break;case 5:U=1073741823;break;case 4:U=1e4;break;default:U=5e3}return U=V+U,q={id:C++,callback:le,priorityLevel:q,startTime:V,expirationTime:U,sortIndex:-1},V>w?(q.sortIndex=V,n(y,q),r(h)===null&&q===r(y)&&(z?(ie(G),G=-1):z=!0,Me(Y,V-w))):(q.sortIndex=U,n(h,q),O||H||(O=!0,tt(pe))),q},i.unstable_shouldYield=ze,i.unstable_wrapCallback=function(q){var le=D;return function(){var V=D;D=le;try{return q.apply(this,arguments)}finally{D=V}}}})(wl)),wl}var Rc;function Mh(){return Rc||(Rc=1,Cl.exports=Lh()),Cl.exports}/**
27
+ * @license React
28
+ * react-dom.production.min.js
29
+ *
30
+ * Copyright (c) Facebook, Inc. and its affiliates.
31
+ *
32
+ * This source code is licensed under the MIT license found in the
33
+ * LICENSE file in the root directory of this source tree.
34
+ */var Ic;function _h(){if(Ic)return Ht;Ic=1;var i=Wl(),n=Mh();function r(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,o=1;o<arguments.length;o++)t+="&args[]="+encodeURIComponent(arguments[o]);return"Minified React error #"+e+"; visit "+t+" for the full message or use the non-minified dev environment for full errors and additional helpful warnings."}var d=new Set,u={};function p(e,t){g(e,t),g(e+"Capture",t)}function g(e,t){for(u[e]=t,e=0;e<t.length;e++)d.add(t[e])}var f=!(typeof window>"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),h=Object.prototype.hasOwnProperty,y=/^[: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]*$/,C={},b={};function D(e){return h.call(b,e)?!0:h.call(C,e)?!1:y.test(e)?b[e]=!0:(C[e]=!0,!1)}function H(e,t,o,a){if(o!==null&&o.type===0)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return a?!1:o!==null?!o.acceptsBooleans:(e=e.toLowerCase().slice(0,5),e!=="data-"&&e!=="aria-");default:return!1}}function O(e,t,o,a){if(t===null||typeof t>"u"||H(e,t,o,a))return!0;if(a)return!1;if(o!==null)switch(o.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 z(e,t,o,a,s,l,c){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=a,this.attributeNamespace=s,this.mustUseProperty=o,this.propertyName=e,this.type=t,this.sanitizeURL=l,this.removeEmptyString=c}var N={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){N[e]=new z(e,0,!1,e,null,!1,!1)}),[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];N[t]=new z(t,1,!1,e[1],null,!1,!1)}),["contentEditable","draggable","spellCheck","value"].forEach(function(e){N[e]=new z(e,2,!1,e.toLowerCase(),null,!1,!1)}),["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){N[e]=new z(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){N[e]=new z(e,3,!1,e.toLowerCase(),null,!1,!1)}),["checked","multiple","muted","selected"].forEach(function(e){N[e]=new z(e,3,!0,e,null,!1,!1)}),["capture","download"].forEach(function(e){N[e]=new z(e,4,!1,e,null,!1,!1)}),["cols","rows","size","span"].forEach(function(e){N[e]=new z(e,6,!1,e,null,!1,!1)}),["rowSpan","start"].forEach(function(e){N[e]=new z(e,5,!1,e.toLowerCase(),null,!1,!1)});var ie=/[\-:]([a-z])/g;function F(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(ie,F);N[t]=new z(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(ie,F);N[t]=new z(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(ie,F);N[t]=new z(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)}),["tabIndex","crossOrigin"].forEach(function(e){N[e]=new z(e,1,!1,e.toLowerCase(),null,!1,!1)}),N.xlinkHref=new z("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1),["src","href","action","formAction"].forEach(function(e){N[e]=new z(e,1,!1,e.toLowerCase(),null,!0,!0)});function X(e,t,o,a){var s=N.hasOwnProperty(t)?N[t]:null;(s!==null?s.type!==0:a||!(2<t.length)||t[0]!=="o"&&t[0]!=="O"||t[1]!=="n"&&t[1]!=="N")&&(O(t,o,s,a)&&(o=null),a||s===null?D(t)&&(o===null?e.removeAttribute(t):e.setAttribute(t,""+o)):s.mustUseProperty?e[s.propertyName]=o===null?s.type===3?!1:"":o:(t=s.attributeName,a=s.attributeNamespace,o===null?e.removeAttribute(t):(s=s.type,o=s===3||s===4&&o===!0?"":""+o,a?e.setAttributeNS(a,t,o):e.setAttribute(t,o))))}var Y=i.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,pe=Symbol.for("react.element"),De=Symbol.for("react.portal"),T=Symbol.for("react.fragment"),G=Symbol.for("react.strict_mode"),Se=Symbol.for("react.profiler"),re=Symbol.for("react.provider"),ze=Symbol.for("react.context"),Pe=Symbol.for("react.forward_ref"),Le=Symbol.for("react.suspense"),Ce=Symbol.for("react.suspense_list"),Qe=Symbol.for("react.memo"),tt=Symbol.for("react.lazy"),Me=Symbol.for("react.offscreen"),q=Symbol.iterator;function le(e){return e===null||typeof e!="object"?null:(e=q&&e[q]||e["@@iterator"],typeof e=="function"?e:null)}var V=Object.assign,w;function U(e){if(w===void 0)try{throw Error()}catch(o){var t=o.stack.trim().match(/\n( *(at )?)/);w=t&&t[1]||""}return`
35
+ `+w+e}var ge=!1;function ye(e,t){if(!e||ge)return"";ge=!0;var o=Error.prepareStackTrace;Error.prepareStackTrace=void 0;try{if(t)if(t=function(){throw Error()},Object.defineProperty(t.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(t,[])}catch(E){var a=E}Reflect.construct(e,[],t)}else{try{t.call()}catch(E){a=E}e.call(t.prototype)}else{try{throw Error()}catch(E){a=E}e()}}catch(E){if(E&&a&&typeof E.stack=="string"){for(var s=E.stack.split(`
36
+ `),l=a.stack.split(`
37
+ `),c=s.length-1,m=l.length-1;1<=c&&0<=m&&s[c]!==l[m];)m--;for(;1<=c&&0<=m;c--,m--)if(s[c]!==l[m]){if(c!==1||m!==1)do if(c--,m--,0>m||s[c]!==l[m]){var S=`
38
+ `+s[c].replace(" at new "," at ");return e.displayName&&S.includes("<anonymous>")&&(S=S.replace("<anonymous>",e.displayName)),S}while(1<=c&&0<=m);break}}}finally{ge=!1,Error.prepareStackTrace=o}return(e=e?e.displayName||e.name:"")?U(e):""}function me(e){switch(e.tag){case 5:return U(e.type);case 16:return U("Lazy");case 13:return U("Suspense");case 19:return U("SuspenseList");case 0:case 2:case 15:return e=ye(e.type,!1),e;case 11:return e=ye(e.type.render,!1),e;case 1:return e=ye(e.type,!0),e;default:return""}}function be(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 T:return"Fragment";case De:return"Portal";case Se:return"Profiler";case G:return"StrictMode";case Le:return"Suspense";case Ce:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case ze:return(e.displayName||"Context")+".Consumer";case re:return(e._context.displayName||"Context")+".Provider";case Pe:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case Qe:return t=e.displayName||null,t!==null?t:be(e.type)||"Memo";case tt:t=e._payload,e=e._init;try{return be(e(t))}catch{}}return null}function Ae(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 be(t);case 8:return t===G?"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 Re(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function _e(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function pt(e){var t=_e(e)?"checked":"value",o=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),a=""+e[t];if(!e.hasOwnProperty(t)&&typeof o<"u"&&typeof o.get=="function"&&typeof o.set=="function"){var s=o.get,l=o.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return s.call(this)},set:function(c){a=""+c,l.call(this,c)}}),Object.defineProperty(e,t,{enumerable:o.enumerable}),{getValue:function(){return a},setValue:function(c){a=""+c},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function vo(e){e._valueTracker||(e._valueTracker=pt(e))}function it(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var o=t.getValue(),a="";return e&&(a=_e(e)?e.checked?"true":"false":e.value),e=a,e!==o?(t.setValue(e),!0):!1}function he(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 ot(e,t){var o=t.checked;return V({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:o??e._wrapperState.initialChecked})}function ft(e,t){var o=t.defaultValue==null?"":t.defaultValue,a=t.checked!=null?t.checked:t.defaultChecked;o=Re(t.value!=null?t.value:o),e._wrapperState={initialChecked:a,initialValue:o,controlled:t.type==="checkbox"||t.type==="radio"?t.checked!=null:t.value!=null}}function Rt(e,t){t=t.checked,t!=null&&X(e,"checked",t,!1)}function ua(e,t){Rt(e,t);var o=Re(t.value),a=t.type;if(o!=null)a==="number"?(o===0&&e.value===""||e.value!=o)&&(e.value=""+o):e.value!==""+o&&(e.value=""+o);else if(a==="submit"||a==="reset"){e.removeAttribute("value");return}t.hasOwnProperty("value")?La(e,t.type,o):t.hasOwnProperty("defaultValue")&&La(e,t.type,Re(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function gs(e,t,o){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var a=t.type;if(!(a!=="submit"&&a!=="reset"||t.value!==void 0&&t.value!==null))return;t=""+e._wrapperState.initialValue,o||t===e.value||(e.value=t),e.defaultValue=t}o=e.name,o!==""&&(e.name=""),e.defaultChecked=!!e._wrapperState.initialChecked,o!==""&&(e.name=o)}function La(e,t,o){(t!=="number"||he(e.ownerDocument)!==e)&&(o==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+o&&(e.defaultValue=""+o))}var ca=Array.isArray;function zo(e,t,o,a){if(e=e.options,t){t={};for(var s=0;s<o.length;s++)t["$"+o[s]]=!0;for(o=0;o<e.length;o++)s=t.hasOwnProperty("$"+e[o].value),e[o].selected!==s&&(e[o].selected=s),s&&a&&(e[o].defaultSelected=!0)}else{for(o=""+Re(o),t=null,s=0;s<e.length;s++){if(e[s].value===o){e[s].selected=!0,a&&(e[s].defaultSelected=!0);return}t!==null||e[s].disabled||(t=e[s])}t!==null&&(t.selected=!0)}}function hi(e,t){if(t.dangerouslySetInnerHTML!=null)throw Error(r(91));return V({},t,{value:void 0,defaultValue:void 0,children:""+e._wrapperState.initialValue})}function hs(e,t){var o=t.value;if(o==null){if(o=t.children,t=t.defaultValue,o!=null){if(t!=null)throw Error(r(92));if(ca(o)){if(1<o.length)throw Error(r(93));o=o[0]}t=o}t==null&&(t=""),o=t}e._wrapperState={initialValue:Re(o)}}function ro(e,t){var o=Re(t.value),a=Re(t.defaultValue);o!=null&&(o=""+o,o!==e.value&&(e.value=o),t.defaultValue==null&&e.defaultValue!==o&&(e.defaultValue=o)),a!=null&&(e.defaultValue=""+a)}function Lo(e){var t=e.textContent;t===e._wrapperState.initialValue&&t!==""&&t!==null&&(e.value=t)}function mi(e){switch(e){case"svg":return"http://www.w3.org/2000/svg";case"math":return"http://www.w3.org/1998/Math/MathML";default:return"http://www.w3.org/1999/xhtml"}}function pa(e,t){return e==null||e==="http://www.w3.org/1999/xhtml"?mi(t):e==="http://www.w3.org/2000/svg"&&t==="foreignObject"?"http://www.w3.org/1999/xhtml":e}var Lt,qt=(function(e){return typeof MSApp<"u"&&MSApp.execUnsafeLocalFunction?function(t,o,a,s){MSApp.execUnsafeLocalFunction(function(){return e(t,o,a,s)})}:e})(function(e,t){if(e.namespaceURI!=="http://www.w3.org/2000/svg"||"innerHTML"in e)e.innerHTML=t;else{for(Lt=Lt||document.createElement("div"),Lt.innerHTML="<svg>"+t.valueOf().toString()+"</svg>",t=Lt.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function Mo(e,t){if(t){var o=e.firstChild;if(o&&o===e.lastChild&&o.nodeType===3){o.nodeValue=t;return}}e.textContent=t}var lo={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},_n=["Webkit","ms","Moz","O"];Object.keys(lo).forEach(function(e){_n.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),lo[t]=lo[e]})});function $t(e,t,o){return t==null||typeof t=="boolean"||t===""?"":o||typeof t!="number"||t===0||lo.hasOwnProperty(e)&&lo[e]?(""+t).trim():t+"px"}function fi(e,t){e=e.style;for(var o in t)if(t.hasOwnProperty(o)){var a=o.indexOf("--")===0,s=$t(o,t[o],a);o==="float"&&(o="cssFloat"),a?e.setProperty(o,s):e[o]=s}}var ms=V({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 Ma(e,t){if(t){if(ms[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(r(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(r(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(r(61))}if(t.style!=null&&typeof t.style!="object")throw Error(r(62))}}function yi(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 _a=null;function _o(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var Na=null,uo=null,co=null;function fs(e){if(e=Ni(e)){if(typeof Na!="function")throw Error(r(280));var t=e.stateNode;t&&(t=_s(t),Na(e.stateNode,e.type,t))}}function vi(e){uo?co?co.push(e):co=[e]:uo=e}function ys(){if(uo){var e=uo,t=co;if(co=uo=null,fs(e),t)for(e=0;e<t.length;e++)fs(t[e])}}function Si(e,t){return e(t)}function ga(){}var No=!1;function vs(e,t,o){if(No)return e(t,o);No=!0;try{return Si(e,t,o)}finally{No=!1,(uo!==null||co!==null)&&(ga(),ys())}}function ha(e,t){var o=e.stateNode;if(o===null)return null;var a=_s(o);if(a===null)return null;o=a[t];e:switch(t){case"onClick":case"onClickCapture":case"onDoubleClick":case"onDoubleClickCapture":case"onMouseDown":case"onMouseDownCapture":case"onMouseMove":case"onMouseMoveCapture":case"onMouseUp":case"onMouseUpCapture":case"onMouseEnter":(a=!a.disabled)||(e=e.type,a=!(e==="button"||e==="input"||e==="select"||e==="textarea")),e=!a;break e;default:e=!1}if(e)return null;if(o&&typeof o!="function")throw Error(r(231,t,typeof o));return o}var v=!1;if(f)try{var k={};Object.defineProperty(k,"passive",{get:function(){v=!0}}),window.addEventListener("test",k,k),window.removeEventListener("test",k,k)}catch{v=!1}function j(e,t,o,a,s,l,c,m,S){var E=Array.prototype.slice.call(arguments,3);try{t.apply(o,E)}catch(_){this.onError(_)}}var L=!1,K=null,ne=!1,ce=null,ee={onError:function(e){L=!0,K=e}};function oe(e,t,o,a,s,l,c,m,S){L=!1,K=null,j.apply(ee,arguments)}function Q(e,t,o,a,s,l,c,m,S){if(oe.apply(this,arguments),L){if(L){var E=K;L=!1,K=null}else throw Error(r(198));ne||(ne=!0,ce=E)}}function J(e){var t=e,o=e;if(e.alternate)for(;t.return;)t=t.return;else{e=t;do t=e,(t.flags&4098)!==0&&(o=t.return),e=t.return;while(e)}return t.tag===3?o:null}function ve(e){if(e.tag===13){var t=e.memoizedState;if(t===null&&(e=e.alternate,e!==null&&(t=e.memoizedState)),t!==null)return t.dehydrated}return null}function xe(e){if(J(e)!==e)throw Error(r(188))}function dt(e){var t=e.alternate;if(!t){if(t=J(e),t===null)throw Error(r(188));return t!==e?null:e}for(var o=e,a=t;;){var s=o.return;if(s===null)break;var l=s.alternate;if(l===null){if(a=s.return,a!==null){o=a;continue}break}if(s.child===l.child){for(l=s.child;l;){if(l===o)return xe(s),e;if(l===a)return xe(s),t;l=l.sibling}throw Error(r(188))}if(o.return!==a.return)o=s,a=l;else{for(var c=!1,m=s.child;m;){if(m===o){c=!0,o=s,a=l;break}if(m===a){c=!0,a=s,o=l;break}m=m.sibling}if(!c){for(m=l.child;m;){if(m===o){c=!0,o=l,a=s;break}if(m===a){c=!0,a=l,o=s;break}m=m.sibling}if(!c)throw Error(r(189))}}if(o.alternate!==a)throw Error(r(190))}if(o.tag!==3)throw Error(r(188));return o.stateNode.current===o?e:t}function Ne(e){return e=dt(e),e!==null?Ee(e):null}function Ee(e){if(e.tag===5||e.tag===6)return e;for(e=e.child;e!==null;){var t=Ee(e);if(t!==null)return t;e=e.sibling}return null}var Ke=n.unstable_scheduleCallback,So=n.unstable_cancelCallback,ma=n.unstable_shouldYield,Xt=n.unstable_requestPaint,je=n.unstable_now,bi=n.unstable_getCurrentPriorityLevel,bo=n.unstable_ImmediatePriority,po=n.unstable_UserBlockingPriority,Po=n.unstable_NormalPriority,Oa=n.unstable_LowPriority,Ie=n.unstable_IdlePriority,qe=null,yt=null;function fa(e){if(yt&&typeof yt.onCommitFiberRoot=="function")try{yt.onCommitFiberRoot(qe,e,void 0,(e.current.flags&128)===128)}catch{}}var He=Math.clz32?Math.clz32:Nn,Oo=Math.log,Ss=Math.LN2;function Nn(e){return e>>>=0,e===0?32:31-(Oo(e)/Ss|0)|0}var bs=64,Ps=4194304;function Pi(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 Cs(e,t){var o=e.pendingLanes;if(o===0)return 0;var a=0,s=e.suspendedLanes,l=e.pingedLanes,c=o&268435455;if(c!==0){var m=c&~s;m!==0?a=Pi(m):(l&=c,l!==0&&(a=Pi(l)))}else c=o&~s,c!==0?a=Pi(c):l!==0&&(a=Pi(l));if(a===0)return 0;if(t!==0&&t!==a&&(t&s)===0&&(s=a&-a,l=t&-t,s>=l||s===16&&(l&4194240)!==0))return t;if((a&4)!==0&&(a|=o&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=a;0<t;)o=31-He(t),s=1<<o,a|=e[o],t&=~s;return a}function Xp(e,t){switch(e){case 1:case 2:case 4:return t+250;case 8:case 16:case 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 t+5e3;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return-1;case 134217728:case 268435456:case 536870912:case 1073741824:return-1;default:return-1}}function Qp(e,t){for(var o=e.suspendedLanes,a=e.pingedLanes,s=e.expirationTimes,l=e.pendingLanes;0<l;){var c=31-He(l),m=1<<c,S=s[c];S===-1?((m&o)===0||(m&a)!==0)&&(s[c]=Xp(m,t)):S<=t&&(e.expiredLanes|=m),l&=~m}}function On(e){return e=e.pendingLanes&-1073741825,e!==0?e:e&1073741824?1073741824:0}function Jl(){var e=bs;return bs<<=1,(bs&4194240)===0&&(bs=64),e}function Bn(e){for(var t=[],o=0;31>o;o++)t.push(e);return t}function Ci(e,t,o){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-He(t),e[t]=o}function Zp(e,t){var o=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 a=e.eventTimes;for(e=e.expirationTimes;0<o;){var s=31-He(o),l=1<<s;t[s]=0,a[s]=-1,e[s]=-1,o&=~l}}function qn(e,t){var o=e.entangledLanes|=t;for(e=e.entanglements;o;){var a=31-He(o),s=1<<a;s&t|e[a]&t&&(e[a]|=t),o&=~s}}var Oe=0;function ed(e){return e&=-e,1<e?4<e?(e&268435455)!==0?16:536870912:4:1}var td,Wn,od,ad,id,Fn=!1,ws=[],Bo=null,qo=null,Wo=null,wi=new Map,ki=new Map,Fo=[],Jp="mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput copy cut paste click change contextmenu reset submit".split(" ");function sd(e,t){switch(e){case"focusin":case"focusout":Bo=null;break;case"dragenter":case"dragleave":qo=null;break;case"mouseover":case"mouseout":Wo=null;break;case"pointerover":case"pointerout":wi.delete(t.pointerId);break;case"gotpointercapture":case"lostpointercapture":ki.delete(t.pointerId)}}function xi(e,t,o,a,s,l){return e===null||e.nativeEvent!==l?(e={blockedOn:t,domEventName:o,eventSystemFlags:a,nativeEvent:l,targetContainers:[s]},t!==null&&(t=Ni(t),t!==null&&Wn(t)),e):(e.eventSystemFlags|=a,t=e.targetContainers,s!==null&&t.indexOf(s)===-1&&t.push(s),e)}function eg(e,t,o,a,s){switch(t){case"focusin":return Bo=xi(Bo,e,t,o,a,s),!0;case"dragenter":return qo=xi(qo,e,t,o,a,s),!0;case"mouseover":return Wo=xi(Wo,e,t,o,a,s),!0;case"pointerover":var l=s.pointerId;return wi.set(l,xi(wi.get(l)||null,e,t,o,a,s)),!0;case"gotpointercapture":return l=s.pointerId,ki.set(l,xi(ki.get(l)||null,e,t,o,a,s)),!0}return!1}function nd(e){var t=ya(e.target);if(t!==null){var o=J(t);if(o!==null){if(t=o.tag,t===13){if(t=ve(o),t!==null){e.blockedOn=t,id(e.priority,function(){od(o)});return}}else if(t===3&&o.stateNode.current.memoizedState.isDehydrated){e.blockedOn=o.tag===3?o.stateNode.containerInfo:null;return}}}e.blockedOn=null}function ks(e){if(e.blockedOn!==null)return!1;for(var t=e.targetContainers;0<t.length;){var o=Yn(e.domEventName,e.eventSystemFlags,t[0],e.nativeEvent);if(o===null){o=e.nativeEvent;var a=new o.constructor(o.type,o);_a=a,o.target.dispatchEvent(a),_a=null}else return t=Ni(o),t!==null&&Wn(t),e.blockedOn=o,!1;t.shift()}return!0}function rd(e,t,o){ks(e)&&o.delete(t)}function tg(){Fn=!1,Bo!==null&&ks(Bo)&&(Bo=null),qo!==null&&ks(qo)&&(qo=null),Wo!==null&&ks(Wo)&&(Wo=null),wi.forEach(rd),ki.forEach(rd)}function Ai(e,t){e.blockedOn===t&&(e.blockedOn=null,Fn||(Fn=!0,n.unstable_scheduleCallback(n.unstable_NormalPriority,tg)))}function Ri(e){function t(s){return Ai(s,e)}if(0<ws.length){Ai(ws[0],e);for(var o=1;o<ws.length;o++){var a=ws[o];a.blockedOn===e&&(a.blockedOn=null)}}for(Bo!==null&&Ai(Bo,e),qo!==null&&Ai(qo,e),Wo!==null&&Ai(Wo,e),wi.forEach(t),ki.forEach(t),o=0;o<Fo.length;o++)a=Fo[o],a.blockedOn===e&&(a.blockedOn=null);for(;0<Fo.length&&(o=Fo[0],o.blockedOn===null);)nd(o),o.blockedOn===null&&Fo.shift()}var Ba=Y.ReactCurrentBatchConfig,xs=!0;function og(e,t,o,a){var s=Oe,l=Ba.transition;Ba.transition=null;try{Oe=1,Kn(e,t,o,a)}finally{Oe=s,Ba.transition=l}}function ag(e,t,o,a){var s=Oe,l=Ba.transition;Ba.transition=null;try{Oe=4,Kn(e,t,o,a)}finally{Oe=s,Ba.transition=l}}function Kn(e,t,o,a){if(xs){var s=Yn(e,t,o,a);if(s===null)dr(e,t,a,As,o),sd(e,a);else if(eg(s,e,t,o,a))a.stopPropagation();else if(sd(e,a),t&4&&-1<Jp.indexOf(e)){for(;s!==null;){var l=Ni(s);if(l!==null&&td(l),l=Yn(e,t,o,a),l===null&&dr(e,t,a,As,o),l===s)break;s=l}s!==null&&a.stopPropagation()}else dr(e,t,a,null,o)}}var As=null;function Yn(e,t,o,a){if(As=null,e=_o(a),e=ya(e),e!==null)if(t=J(e),t===null)e=null;else if(o=t.tag,o===13){if(e=ve(t),e!==null)return e;e=null}else if(o===3){if(t.stateNode.current.memoizedState.isDehydrated)return t.tag===3?t.stateNode.containerInfo:null;e=null}else t!==e&&(e=null);return As=e,null}function ld(e){switch(e){case"cancel":case"click":case"close":case"contextmenu":case"copy":case"cut":case"auxclick":case"dblclick":case"dragend":case"dragstart":case"drop":case"focusin":case"focusout":case"input":case"invalid":case"keydown":case"keypress":case"keyup":case"mousedown":case"mouseup":case"paste":case"pause":case"play":case"pointercancel":case"pointerdown":case"pointerup":case"ratechange":case"reset":case"resize":case"seeked":case"submit":case"touchcancel":case"touchend":case"touchstart":case"volumechange":case"change":case"selectionchange":case"textInput":case"compositionstart":case"compositionend":case"compositionupdate":case"beforeblur":case"afterblur":case"beforeinput":case"blur":case"fullscreenchange":case"focus":case"hashchange":case"popstate":case"select":case"selectstart":return 1;case"drag":case"dragenter":case"dragexit":case"dragleave":case"dragover":case"mousemove":case"mouseout":case"mouseover":case"pointermove":case"pointerout":case"pointerover":case"scroll":case"toggle":case"touchmove":case"wheel":case"mouseenter":case"mouseleave":case"pointerenter":case"pointerleave":return 4;case"message":switch(bi()){case bo:return 1;case po:return 4;case Po:case Oa:return 16;case Ie:return 536870912;default:return 16}default:return 16}}var Ko=null,Vn=null,Rs=null;function dd(){if(Rs)return Rs;var e,t=Vn,o=t.length,a,s="value"in Ko?Ko.value:Ko.textContent,l=s.length;for(e=0;e<o&&t[e]===s[e];e++);var c=o-e;for(a=1;a<=c&&t[o-a]===s[l-a];a++);return Rs=s.slice(e,1<a?1-a:void 0)}function Is(e){var t=e.keyCode;return"charCode"in e?(e=e.charCode,e===0&&t===13&&(e=13)):e=t,e===10&&(e=13),32<=e||e===13?e:0}function Ds(){return!0}function ud(){return!1}function Mt(e){function t(o,a,s,l,c){this._reactName=o,this._targetInst=s,this.type=a,this.nativeEvent=l,this.target=c,this.currentTarget=null;for(var m in e)e.hasOwnProperty(m)&&(o=e[m],this[m]=o?o(l):l[m]);return this.isDefaultPrevented=(l.defaultPrevented!=null?l.defaultPrevented:l.returnValue===!1)?Ds:ud,this.isPropagationStopped=ud,this}return V(t.prototype,{preventDefault:function(){this.defaultPrevented=!0;var o=this.nativeEvent;o&&(o.preventDefault?o.preventDefault():typeof o.returnValue!="unknown"&&(o.returnValue=!1),this.isDefaultPrevented=Ds)},stopPropagation:function(){var o=this.nativeEvent;o&&(o.stopPropagation?o.stopPropagation():typeof o.cancelBubble!="unknown"&&(o.cancelBubble=!0),this.isPropagationStopped=Ds)},persist:function(){},isPersistent:Ds}),t}var qa={eventPhase:0,bubbles:0,cancelable:0,timeStamp:function(e){return e.timeStamp||Date.now()},defaultPrevented:0,isTrusted:0},Gn=Mt(qa),Ii=V({},qa,{view:0,detail:0}),ig=Mt(Ii),$n,Xn,Di,Es=V({},Ii,{screenX:0,screenY:0,clientX:0,clientY:0,pageX:0,pageY:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,getModifierState:Zn,button:0,buttons:0,relatedTarget:function(e){return e.relatedTarget===void 0?e.fromElement===e.srcElement?e.toElement:e.fromElement:e.relatedTarget},movementX:function(e){return"movementX"in e?e.movementX:(e!==Di&&(Di&&e.type==="mousemove"?($n=e.screenX-Di.screenX,Xn=e.screenY-Di.screenY):Xn=$n=0,Di=e),$n)},movementY:function(e){return"movementY"in e?e.movementY:Xn}}),cd=Mt(Es),sg=V({},Es,{dataTransfer:0}),ng=Mt(sg),rg=V({},Ii,{relatedTarget:0}),Qn=Mt(rg),lg=V({},qa,{animationName:0,elapsedTime:0,pseudoElement:0}),dg=Mt(lg),ug=V({},qa,{clipboardData:function(e){return"clipboardData"in e?e.clipboardData:window.clipboardData}}),cg=Mt(ug),pg=V({},qa,{data:0}),pd=Mt(pg),gg={Esc:"Escape",Spacebar:" ",Left:"ArrowLeft",Up:"ArrowUp",Right:"ArrowRight",Down:"ArrowDown",Del:"Delete",Win:"OS",Menu:"ContextMenu",Apps:"ContextMenu",Scroll:"ScrollLock",MozPrintableKey:"Unidentified"},hg={8:"Backspace",9:"Tab",12:"Clear",13:"Enter",16:"Shift",17:"Control",18:"Alt",19:"Pause",20:"CapsLock",27:"Escape",32:" ",33:"PageUp",34:"PageDown",35:"End",36:"Home",37:"ArrowLeft",38:"ArrowUp",39:"ArrowRight",40:"ArrowDown",45:"Insert",46:"Delete",112:"F1",113:"F2",114:"F3",115:"F4",116:"F5",117:"F6",118:"F7",119:"F8",120:"F9",121:"F10",122:"F11",123:"F12",144:"NumLock",145:"ScrollLock",224:"Meta"},mg={Alt:"altKey",Control:"ctrlKey",Meta:"metaKey",Shift:"shiftKey"};function fg(e){var t=this.nativeEvent;return t.getModifierState?t.getModifierState(e):(e=mg[e])?!!t[e]:!1}function Zn(){return fg}var yg=V({},Ii,{key:function(e){if(e.key){var t=gg[e.key]||e.key;if(t!=="Unidentified")return t}return e.type==="keypress"?(e=Is(e),e===13?"Enter":String.fromCharCode(e)):e.type==="keydown"||e.type==="keyup"?hg[e.keyCode]||"Unidentified":""},code:0,location:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,repeat:0,locale:0,getModifierState:Zn,charCode:function(e){return e.type==="keypress"?Is(e):0},keyCode:function(e){return e.type==="keydown"||e.type==="keyup"?e.keyCode:0},which:function(e){return e.type==="keypress"?Is(e):e.type==="keydown"||e.type==="keyup"?e.keyCode:0}}),vg=Mt(yg),Sg=V({},Es,{pointerId:0,width:0,height:0,pressure:0,tangentialPressure:0,tiltX:0,tiltY:0,twist:0,pointerType:0,isPrimary:0}),gd=Mt(Sg),bg=V({},Ii,{touches:0,targetTouches:0,changedTouches:0,altKey:0,metaKey:0,ctrlKey:0,shiftKey:0,getModifierState:Zn}),Pg=Mt(bg),Cg=V({},qa,{propertyName:0,elapsedTime:0,pseudoElement:0}),wg=Mt(Cg),kg=V({},Es,{deltaX:function(e){return"deltaX"in e?e.deltaX:"wheelDeltaX"in e?-e.wheelDeltaX:0},deltaY:function(e){return"deltaY"in e?e.deltaY:"wheelDeltaY"in e?-e.wheelDeltaY:"wheelDelta"in e?-e.wheelDelta:0},deltaZ:0,deltaMode:0}),xg=Mt(kg),Ag=[9,13,27,32],Jn=f&&"CompositionEvent"in window,Ei=null;f&&"documentMode"in document&&(Ei=document.documentMode);var Rg=f&&"TextEvent"in window&&!Ei,hd=f&&(!Jn||Ei&&8<Ei&&11>=Ei),md=" ",fd=!1;function yd(e,t){switch(e){case"keyup":return Ag.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function vd(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var Wa=!1;function Ig(e,t){switch(e){case"compositionend":return vd(t);case"keypress":return t.which!==32?null:(fd=!0,md);case"textInput":return e=t.data,e===md&&fd?null:e;default:return null}}function Dg(e,t){if(Wa)return e==="compositionend"||!Jn&&yd(e,t)?(e=dd(),Rs=Vn=Ko=null,Wa=!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.char.length)return t.char;if(t.which)return String.fromCharCode(t.which)}return null;case"compositionend":return hd&&t.locale!=="ko"?null:t.data;default:return null}}var Eg={color:!0,date:!0,datetime:!0,"datetime-local":!0,email:!0,month:!0,number:!0,password:!0,range:!0,search:!0,tel:!0,text:!0,time:!0,url:!0,week:!0};function Sd(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t==="input"?!!Eg[e.type]:t==="textarea"}function bd(e,t,o,a){vi(a),t=zs(t,"onChange"),0<t.length&&(o=new Gn("onChange","change",null,o,a),e.push({event:o,listeners:t}))}var Ti=null,ji=null;function Tg(e){_d(e,0)}function Ts(e){var t=Ga(e);if(it(t))return e}function jg(e,t){if(e==="change")return t}var Pd=!1;if(f){var er;if(f){var tr="oninput"in document;if(!tr){var Cd=document.createElement("div");Cd.setAttribute("oninput","return;"),tr=typeof Cd.oninput=="function"}er=tr}else er=!1;Pd=er&&(!document.documentMode||9<document.documentMode)}function wd(){Ti&&(Ti.detachEvent("onpropertychange",kd),ji=Ti=null)}function kd(e){if(e.propertyName==="value"&&Ts(ji)){var t=[];bd(t,ji,e,_o(e)),vs(Tg,t)}}function Hg(e,t,o){e==="focusin"?(wd(),Ti=t,ji=o,Ti.attachEvent("onpropertychange",kd)):e==="focusout"&&wd()}function Ug(e){if(e==="selectionchange"||e==="keyup"||e==="keydown")return Ts(ji)}function zg(e,t){if(e==="click")return Ts(t)}function Lg(e,t){if(e==="input"||e==="change")return Ts(t)}function Mg(e,t){return e===t&&(e!==0||1/e===1/t)||e!==e&&t!==t}var Qt=typeof Object.is=="function"?Object.is:Mg;function Hi(e,t){if(Qt(e,t))return!0;if(typeof e!="object"||e===null||typeof t!="object"||t===null)return!1;var o=Object.keys(e),a=Object.keys(t);if(o.length!==a.length)return!1;for(a=0;a<o.length;a++){var s=o[a];if(!h.call(t,s)||!Qt(e[s],t[s]))return!1}return!0}function xd(e){for(;e&&e.firstChild;)e=e.firstChild;return e}function Ad(e,t){var o=xd(e);e=0;for(var a;o;){if(o.nodeType===3){if(a=e+o.textContent.length,e<=t&&a>=t)return{node:o,offset:t-e};e=a}e:{for(;o;){if(o.nextSibling){o=o.nextSibling;break e}o=o.parentNode}o=void 0}o=xd(o)}}function Rd(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?Rd(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function Id(){for(var e=window,t=he();t instanceof e.HTMLIFrameElement;){try{var o=typeof t.contentWindow.location.href=="string"}catch{o=!1}if(o)e=t.contentWindow;else break;t=he(e.document)}return t}function or(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 _g(e){var t=Id(),o=e.focusedElem,a=e.selectionRange;if(t!==o&&o&&o.ownerDocument&&Rd(o.ownerDocument.documentElement,o)){if(a!==null&&or(o)){if(t=a.start,e=a.end,e===void 0&&(e=t),"selectionStart"in o)o.selectionStart=t,o.selectionEnd=Math.min(e,o.value.length);else if(e=(t=o.ownerDocument||document)&&t.defaultView||window,e.getSelection){e=e.getSelection();var s=o.textContent.length,l=Math.min(a.start,s);a=a.end===void 0?l:Math.min(a.end,s),!e.extend&&l>a&&(s=a,a=l,l=s),s=Ad(o,l);var c=Ad(o,a);s&&c&&(e.rangeCount!==1||e.anchorNode!==s.node||e.anchorOffset!==s.offset||e.focusNode!==c.node||e.focusOffset!==c.offset)&&(t=t.createRange(),t.setStart(s.node,s.offset),e.removeAllRanges(),l>a?(e.addRange(t),e.extend(c.node,c.offset)):(t.setEnd(c.node,c.offset),e.addRange(t)))}}for(t=[],e=o;e=e.parentNode;)e.nodeType===1&&t.push({element:e,left:e.scrollLeft,top:e.scrollTop});for(typeof o.focus=="function"&&o.focus(),o=0;o<t.length;o++)e=t[o],e.element.scrollLeft=e.left,e.element.scrollTop=e.top}}var Ng=f&&"documentMode"in document&&11>=document.documentMode,Fa=null,ar=null,Ui=null,ir=!1;function Dd(e,t,o){var a=o.window===o?o.document:o.nodeType===9?o:o.ownerDocument;ir||Fa==null||Fa!==he(a)||(a=Fa,"selectionStart"in a&&or(a)?a={start:a.selectionStart,end:a.selectionEnd}:(a=(a.ownerDocument&&a.ownerDocument.defaultView||window).getSelection(),a={anchorNode:a.anchorNode,anchorOffset:a.anchorOffset,focusNode:a.focusNode,focusOffset:a.focusOffset}),Ui&&Hi(Ui,a)||(Ui=a,a=zs(ar,"onSelect"),0<a.length&&(t=new Gn("onSelect","select",null,t,o),e.push({event:t,listeners:a}),t.target=Fa)))}function js(e,t){var o={};return o[e.toLowerCase()]=t.toLowerCase(),o["Webkit"+e]="webkit"+t,o["Moz"+e]="moz"+t,o}var Ka={animationend:js("Animation","AnimationEnd"),animationiteration:js("Animation","AnimationIteration"),animationstart:js("Animation","AnimationStart"),transitionend:js("Transition","TransitionEnd")},sr={},Ed={};f&&(Ed=document.createElement("div").style,"AnimationEvent"in window||(delete Ka.animationend.animation,delete Ka.animationiteration.animation,delete Ka.animationstart.animation),"TransitionEvent"in window||delete Ka.transitionend.transition);function Hs(e){if(sr[e])return sr[e];if(!Ka[e])return e;var t=Ka[e],o;for(o in t)if(t.hasOwnProperty(o)&&o in Ed)return sr[e]=t[o];return e}var Td=Hs("animationend"),jd=Hs("animationiteration"),Hd=Hs("animationstart"),Ud=Hs("transitionend"),zd=new Map,Ld="abort auxClick cancel canPlay canPlayThrough click close contextMenu copy cut drag dragEnd dragEnter dragExit dragLeave dragOver dragStart drop durationChange emptied encrypted ended error gotPointerCapture input invalid keyDown keyPress keyUp load loadedData loadedMetadata loadStart lostPointerCapture mouseDown mouseMove mouseOut mouseOver mouseUp paste pause play playing pointerCancel pointerDown pointerMove pointerOut pointerOver pointerUp progress rateChange reset resize seeked seeking stalled submit suspend timeUpdate touchCancel touchEnd touchStart volumeChange scroll toggle touchMove waiting wheel".split(" ");function Yo(e,t){zd.set(e,t),p(t,[e])}for(var nr=0;nr<Ld.length;nr++){var rr=Ld[nr],Og=rr.toLowerCase(),Bg=rr[0].toUpperCase()+rr.slice(1);Yo(Og,"on"+Bg)}Yo(Td,"onAnimationEnd"),Yo(jd,"onAnimationIteration"),Yo(Hd,"onAnimationStart"),Yo("dblclick","onDoubleClick"),Yo("focusin","onFocus"),Yo("focusout","onBlur"),Yo(Ud,"onTransitionEnd"),g("onMouseEnter",["mouseout","mouseover"]),g("onMouseLeave",["mouseout","mouseover"]),g("onPointerEnter",["pointerout","pointerover"]),g("onPointerLeave",["pointerout","pointerover"]),p("onChange","change click focusin focusout input keydown keyup selectionchange".split(" ")),p("onSelect","focusout contextmenu dragend focusin keydown keyup mousedown mouseup selectionchange".split(" ")),p("onBeforeInput",["compositionend","keypress","textInput","paste"]),p("onCompositionEnd","compositionend focusout keydown keypress keyup mousedown".split(" ")),p("onCompositionStart","compositionstart focusout keydown keypress keyup mousedown".split(" ")),p("onCompositionUpdate","compositionupdate focusout keydown keypress keyup mousedown".split(" "));var zi="abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange resize seeked seeking stalled suspend timeupdate volumechange waiting".split(" "),qg=new Set("cancel close invalid load scroll toggle".split(" ").concat(zi));function Md(e,t,o){var a=e.type||"unknown-event";e.currentTarget=o,Q(a,t,void 0,e),e.currentTarget=null}function _d(e,t){t=(t&4)!==0;for(var o=0;o<e.length;o++){var a=e[o],s=a.event;a=a.listeners;e:{var l=void 0;if(t)for(var c=a.length-1;0<=c;c--){var m=a[c],S=m.instance,E=m.currentTarget;if(m=m.listener,S!==l&&s.isPropagationStopped())break e;Md(s,m,E),l=S}else for(c=0;c<a.length;c++){if(m=a[c],S=m.instance,E=m.currentTarget,m=m.listener,S!==l&&s.isPropagationStopped())break e;Md(s,m,E),l=S}}}if(ne)throw e=ce,ne=!1,ce=null,e}function Ye(e,t){var o=t[mr];o===void 0&&(o=t[mr]=new Set);var a=e+"__bubble";o.has(a)||(Nd(t,e,2,!1),o.add(a))}function lr(e,t,o){var a=0;t&&(a|=4),Nd(o,e,a,t)}var Us="_reactListening"+Math.random().toString(36).slice(2);function Li(e){if(!e[Us]){e[Us]=!0,d.forEach(function(o){o!=="selectionchange"&&(qg.has(o)||lr(o,!1,e),lr(o,!0,e))});var t=e.nodeType===9?e:e.ownerDocument;t===null||t[Us]||(t[Us]=!0,lr("selectionchange",!1,t))}}function Nd(e,t,o,a){switch(ld(t)){case 1:var s=og;break;case 4:s=ag;break;default:s=Kn}o=s.bind(null,t,o,e),s=void 0,!v||t!=="touchstart"&&t!=="touchmove"&&t!=="wheel"||(s=!0),a?s!==void 0?e.addEventListener(t,o,{capture:!0,passive:s}):e.addEventListener(t,o,!0):s!==void 0?e.addEventListener(t,o,{passive:s}):e.addEventListener(t,o,!1)}function dr(e,t,o,a,s){var l=a;if((t&1)===0&&(t&2)===0&&a!==null)e:for(;;){if(a===null)return;var c=a.tag;if(c===3||c===4){var m=a.stateNode.containerInfo;if(m===s||m.nodeType===8&&m.parentNode===s)break;if(c===4)for(c=a.return;c!==null;){var S=c.tag;if((S===3||S===4)&&(S=c.stateNode.containerInfo,S===s||S.nodeType===8&&S.parentNode===s))return;c=c.return}for(;m!==null;){if(c=ya(m),c===null)return;if(S=c.tag,S===5||S===6){a=l=c;continue e}m=m.parentNode}}a=a.return}vs(function(){var E=l,_=_o(o),B=[];e:{var M=zd.get(e);if(M!==void 0){var $=Gn,te=e;switch(e){case"keypress":if(Is(o)===0)break e;case"keydown":case"keyup":$=vg;break;case"focusin":te="focus",$=Qn;break;case"focusout":te="blur",$=Qn;break;case"beforeblur":case"afterblur":$=Qn;break;case"click":if(o.button===2)break e;case"auxclick":case"dblclick":case"mousedown":case"mousemove":case"mouseup":case"mouseout":case"mouseover":case"contextmenu":$=cd;break;case"drag":case"dragend":case"dragenter":case"dragexit":case"dragleave":case"dragover":case"dragstart":case"drop":$=ng;break;case"touchcancel":case"touchend":case"touchmove":case"touchstart":$=Pg;break;case Td:case jd:case Hd:$=dg;break;case Ud:$=wg;break;case"scroll":$=ig;break;case"wheel":$=xg;break;case"copy":case"cut":case"paste":$=cg;break;case"gotpointercapture":case"lostpointercapture":case"pointercancel":case"pointerdown":case"pointermove":case"pointerout":case"pointerover":case"pointerup":$=gd}var ae=(t&4)!==0,st=!ae&&e==="scroll",R=ae?M!==null?M+"Capture":null:M;ae=[];for(var P=E,I;P!==null;){I=P;var W=I.stateNode;if(I.tag===5&&W!==null&&(I=W,R!==null&&(W=ha(P,R),W!=null&&ae.push(Mi(P,W,I)))),st)break;P=P.return}0<ae.length&&(M=new $(M,te,null,o,_),B.push({event:M,listeners:ae}))}}if((t&7)===0){e:{if(M=e==="mouseover"||e==="pointerover",$=e==="mouseout"||e==="pointerout",M&&o!==_a&&(te=o.relatedTarget||o.fromElement)&&(ya(te)||te[Co]))break e;if(($||M)&&(M=_.window===_?_:(M=_.ownerDocument)?M.defaultView||M.parentWindow:window,$?(te=o.relatedTarget||o.toElement,$=E,te=te?ya(te):null,te!==null&&(st=J(te),te!==st||te.tag!==5&&te.tag!==6)&&(te=null)):($=null,te=E),$!==te)){if(ae=cd,W="onMouseLeave",R="onMouseEnter",P="mouse",(e==="pointerout"||e==="pointerover")&&(ae=gd,W="onPointerLeave",R="onPointerEnter",P="pointer"),st=$==null?M:Ga($),I=te==null?M:Ga(te),M=new ae(W,P+"leave",$,o,_),M.target=st,M.relatedTarget=I,W=null,ya(_)===E&&(ae=new ae(R,P+"enter",te,o,_),ae.target=I,ae.relatedTarget=st,W=ae),st=W,$&&te)t:{for(ae=$,R=te,P=0,I=ae;I;I=Ya(I))P++;for(I=0,W=R;W;W=Ya(W))I++;for(;0<P-I;)ae=Ya(ae),P--;for(;0<I-P;)R=Ya(R),I--;for(;P--;){if(ae===R||R!==null&&ae===R.alternate)break t;ae=Ya(ae),R=Ya(R)}ae=null}else ae=null;$!==null&&Od(B,M,$,ae,!1),te!==null&&st!==null&&Od(B,st,te,ae,!0)}}e:{if(M=E?Ga(E):window,$=M.nodeName&&M.nodeName.toLowerCase(),$==="select"||$==="input"&&M.type==="file")var se=jg;else if(Sd(M))if(Pd)se=Lg;else{se=Ug;var de=Hg}else($=M.nodeName)&&$.toLowerCase()==="input"&&(M.type==="checkbox"||M.type==="radio")&&(se=zg);if(se&&(se=se(e,E))){bd(B,se,o,_);break e}de&&de(e,M,E),e==="focusout"&&(de=M._wrapperState)&&de.controlled&&M.type==="number"&&La(M,"number",M.value)}switch(de=E?Ga(E):window,e){case"focusin":(Sd(de)||de.contentEditable==="true")&&(Fa=de,ar=E,Ui=null);break;case"focusout":Ui=ar=Fa=null;break;case"mousedown":ir=!0;break;case"contextmenu":case"mouseup":case"dragend":ir=!1,Dd(B,o,_);break;case"selectionchange":if(Ng)break;case"keydown":case"keyup":Dd(B,o,_)}var ue;if(Jn)e:{switch(e){case"compositionstart":var fe="onCompositionStart";break e;case"compositionend":fe="onCompositionEnd";break e;case"compositionupdate":fe="onCompositionUpdate";break e}fe=void 0}else Wa?yd(e,o)&&(fe="onCompositionEnd"):e==="keydown"&&o.keyCode===229&&(fe="onCompositionStart");fe&&(hd&&o.locale!=="ko"&&(Wa||fe!=="onCompositionStart"?fe==="onCompositionEnd"&&Wa&&(ue=dd()):(Ko=_,Vn="value"in Ko?Ko.value:Ko.textContent,Wa=!0)),de=zs(E,fe),0<de.length&&(fe=new pd(fe,e,null,o,_),B.push({event:fe,listeners:de}),ue?fe.data=ue:(ue=vd(o),ue!==null&&(fe.data=ue)))),(ue=Rg?Ig(e,o):Dg(e,o))&&(E=zs(E,"onBeforeInput"),0<E.length&&(_=new pd("onBeforeInput","beforeinput",null,o,_),B.push({event:_,listeners:E}),_.data=ue))}_d(B,t)})}function Mi(e,t,o){return{instance:e,listener:t,currentTarget:o}}function zs(e,t){for(var o=t+"Capture",a=[];e!==null;){var s=e,l=s.stateNode;s.tag===5&&l!==null&&(s=l,l=ha(e,o),l!=null&&a.unshift(Mi(e,l,s)),l=ha(e,t),l!=null&&a.push(Mi(e,l,s))),e=e.return}return a}function Ya(e){if(e===null)return null;do e=e.return;while(e&&e.tag!==5);return e||null}function Od(e,t,o,a,s){for(var l=t._reactName,c=[];o!==null&&o!==a;){var m=o,S=m.alternate,E=m.stateNode;if(S!==null&&S===a)break;m.tag===5&&E!==null&&(m=E,s?(S=ha(o,l),S!=null&&c.unshift(Mi(o,S,m))):s||(S=ha(o,l),S!=null&&c.push(Mi(o,S,m)))),o=o.return}c.length!==0&&e.push({event:t,listeners:c})}var Wg=/\r\n?/g,Fg=/\u0000|\uFFFD/g;function Bd(e){return(typeof e=="string"?e:""+e).replace(Wg,`
39
+ `).replace(Fg,"")}function Ls(e,t,o){if(t=Bd(t),Bd(e)!==t&&o)throw Error(r(425))}function Ms(){}var ur=null,cr=null;function pr(e,t){return e==="textarea"||e==="noscript"||typeof t.children=="string"||typeof t.children=="number"||typeof t.dangerouslySetInnerHTML=="object"&&t.dangerouslySetInnerHTML!==null&&t.dangerouslySetInnerHTML.__html!=null}var gr=typeof setTimeout=="function"?setTimeout:void 0,Kg=typeof clearTimeout=="function"?clearTimeout:void 0,qd=typeof Promise=="function"?Promise:void 0,Yg=typeof queueMicrotask=="function"?queueMicrotask:typeof qd<"u"?function(e){return qd.resolve(null).then(e).catch(Vg)}:gr;function Vg(e){setTimeout(function(){throw e})}function hr(e,t){var o=t,a=0;do{var s=o.nextSibling;if(e.removeChild(o),s&&s.nodeType===8)if(o=s.data,o==="/$"){if(a===0){e.removeChild(s),Ri(t);return}a--}else o!=="$"&&o!=="$?"&&o!=="$!"||a++;o=s}while(o);Ri(t)}function Vo(e){for(;e!=null;e=e.nextSibling){var t=e.nodeType;if(t===1||t===3)break;if(t===8){if(t=e.data,t==="$"||t==="$!"||t==="$?")break;if(t==="/$")return null}}return e}function Wd(e){e=e.previousSibling;for(var t=0;e;){if(e.nodeType===8){var o=e.data;if(o==="$"||o==="$!"||o==="$?"){if(t===0)return e;t--}else o==="/$"&&t++}e=e.previousSibling}return null}var Va=Math.random().toString(36).slice(2),go="__reactFiber$"+Va,_i="__reactProps$"+Va,Co="__reactContainer$"+Va,mr="__reactEvents$"+Va,Gg="__reactListeners$"+Va,$g="__reactHandles$"+Va;function ya(e){var t=e[go];if(t)return t;for(var o=e.parentNode;o;){if(t=o[Co]||o[go]){if(o=t.alternate,t.child!==null||o!==null&&o.child!==null)for(e=Wd(e);e!==null;){if(o=e[go])return o;e=Wd(e)}return t}e=o,o=e.parentNode}return null}function Ni(e){return e=e[go]||e[Co],!e||e.tag!==5&&e.tag!==6&&e.tag!==13&&e.tag!==3?null:e}function Ga(e){if(e.tag===5||e.tag===6)return e.stateNode;throw Error(r(33))}function _s(e){return e[_i]||null}var fr=[],$a=-1;function Go(e){return{current:e}}function Ve(e){0>$a||(e.current=fr[$a],fr[$a]=null,$a--)}function Fe(e,t){$a++,fr[$a]=e.current,e.current=t}var $o={},bt=Go($o),It=Go(!1),va=$o;function Xa(e,t){var o=e.type.contextTypes;if(!o)return $o;var a=e.stateNode;if(a&&a.__reactInternalMemoizedUnmaskedChildContext===t)return a.__reactInternalMemoizedMaskedChildContext;var s={},l;for(l in o)s[l]=t[l];return a&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=s),s}function Dt(e){return e=e.childContextTypes,e!=null}function Ns(){Ve(It),Ve(bt)}function Fd(e,t,o){if(bt.current!==$o)throw Error(r(168));Fe(bt,t),Fe(It,o)}function Kd(e,t,o){var a=e.stateNode;if(t=t.childContextTypes,typeof a.getChildContext!="function")return o;a=a.getChildContext();for(var s in a)if(!(s in t))throw Error(r(108,Ae(e)||"Unknown",s));return V({},o,a)}function Os(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||$o,va=bt.current,Fe(bt,e),Fe(It,It.current),!0}function Yd(e,t,o){var a=e.stateNode;if(!a)throw Error(r(169));o?(e=Kd(e,t,va),a.__reactInternalMemoizedMergedChildContext=e,Ve(It),Ve(bt),Fe(bt,e)):Ve(It),Fe(It,o)}var wo=null,Bs=!1,yr=!1;function Vd(e){wo===null?wo=[e]:wo.push(e)}function Xg(e){Bs=!0,Vd(e)}function Xo(){if(!yr&&wo!==null){yr=!0;var e=0,t=Oe;try{var o=wo;for(Oe=1;e<o.length;e++){var a=o[e];do a=a(!0);while(a!==null)}wo=null,Bs=!1}catch(s){throw wo!==null&&(wo=wo.slice(e+1)),Ke(bo,Xo),s}finally{Oe=t,yr=!1}}return null}var Qa=[],Za=0,qs=null,Ws=0,Wt=[],Ft=0,Sa=null,ko=1,xo="";function ba(e,t){Qa[Za++]=Ws,Qa[Za++]=qs,qs=e,Ws=t}function Gd(e,t,o){Wt[Ft++]=ko,Wt[Ft++]=xo,Wt[Ft++]=Sa,Sa=e;var a=ko;e=xo;var s=32-He(a)-1;a&=~(1<<s),o+=1;var l=32-He(t)+s;if(30<l){var c=s-s%5;l=(a&(1<<c)-1).toString(32),a>>=c,s-=c,ko=1<<32-He(t)+s|o<<s|a,xo=l+e}else ko=1<<l|o<<s|a,xo=e}function vr(e){e.return!==null&&(ba(e,1),Gd(e,1,0))}function Sr(e){for(;e===qs;)qs=Qa[--Za],Qa[Za]=null,Ws=Qa[--Za],Qa[Za]=null;for(;e===Sa;)Sa=Wt[--Ft],Wt[Ft]=null,xo=Wt[--Ft],Wt[Ft]=null,ko=Wt[--Ft],Wt[Ft]=null}var _t=null,Nt=null,Ge=!1,Zt=null;function $d(e,t){var o=Gt(5,null,null,0);o.elementType="DELETED",o.stateNode=t,o.return=e,t=e.deletions,t===null?(e.deletions=[o],e.flags|=16):t.push(o)}function Xd(e,t){switch(e.tag){case 5:var o=e.type;return t=t.nodeType!==1||o.toLowerCase()!==t.nodeName.toLowerCase()?null:t,t!==null?(e.stateNode=t,_t=e,Nt=Vo(t.firstChild),!0):!1;case 6:return t=e.pendingProps===""||t.nodeType!==3?null:t,t!==null?(e.stateNode=t,_t=e,Nt=null,!0):!1;case 13:return t=t.nodeType!==8?null:t,t!==null?(o=Sa!==null?{id:ko,overflow:xo}:null,e.memoizedState={dehydrated:t,treeContext:o,retryLane:1073741824},o=Gt(18,null,null,0),o.stateNode=t,o.return=e,e.child=o,_t=e,Nt=null,!0):!1;default:return!1}}function br(e){return(e.mode&1)!==0&&(e.flags&128)===0}function Pr(e){if(Ge){var t=Nt;if(t){var o=t;if(!Xd(e,t)){if(br(e))throw Error(r(418));t=Vo(o.nextSibling);var a=_t;t&&Xd(e,t)?$d(a,o):(e.flags=e.flags&-4097|2,Ge=!1,_t=e)}}else{if(br(e))throw Error(r(418));e.flags=e.flags&-4097|2,Ge=!1,_t=e}}}function Qd(e){for(e=e.return;e!==null&&e.tag!==5&&e.tag!==3&&e.tag!==13;)e=e.return;_t=e}function Fs(e){if(e!==_t)return!1;if(!Ge)return Qd(e),Ge=!0,!1;var t;if((t=e.tag!==3)&&!(t=e.tag!==5)&&(t=e.type,t=t!=="head"&&t!=="body"&&!pr(e.type,e.memoizedProps)),t&&(t=Nt)){if(br(e))throw Zd(),Error(r(418));for(;t;)$d(e,t),t=Vo(t.nextSibling)}if(Qd(e),e.tag===13){if(e=e.memoizedState,e=e!==null?e.dehydrated:null,!e)throw Error(r(317));e:{for(e=e.nextSibling,t=0;e;){if(e.nodeType===8){var o=e.data;if(o==="/$"){if(t===0){Nt=Vo(e.nextSibling);break e}t--}else o!=="$"&&o!=="$!"&&o!=="$?"||t++}e=e.nextSibling}Nt=null}}else Nt=_t?Vo(e.stateNode.nextSibling):null;return!0}function Zd(){for(var e=Nt;e;)e=Vo(e.nextSibling)}function Ja(){Nt=_t=null,Ge=!1}function Cr(e){Zt===null?Zt=[e]:Zt.push(e)}var Qg=Y.ReactCurrentBatchConfig;function Oi(e,t,o){if(e=o.ref,e!==null&&typeof e!="function"&&typeof e!="object"){if(o._owner){if(o=o._owner,o){if(o.tag!==1)throw Error(r(309));var a=o.stateNode}if(!a)throw Error(r(147,e));var s=a,l=""+e;return t!==null&&t.ref!==null&&typeof t.ref=="function"&&t.ref._stringRef===l?t.ref:(t=function(c){var m=s.refs;c===null?delete m[l]:m[l]=c},t._stringRef=l,t)}if(typeof e!="string")throw Error(r(284));if(!o._owner)throw Error(r(290,e))}return e}function Ks(e,t){throw e=Object.prototype.toString.call(t),Error(r(31,e==="[object Object]"?"object with keys {"+Object.keys(t).join(", ")+"}":e))}function Jd(e){var t=e._init;return t(e._payload)}function eu(e){function t(R,P){if(e){var I=R.deletions;I===null?(R.deletions=[P],R.flags|=16):I.push(P)}}function o(R,P){if(!e)return null;for(;P!==null;)t(R,P),P=P.sibling;return null}function a(R,P){for(R=new Map;P!==null;)P.key!==null?R.set(P.key,P):R.set(P.index,P),P=P.sibling;return R}function s(R,P){return R=ia(R,P),R.index=0,R.sibling=null,R}function l(R,P,I){return R.index=I,e?(I=R.alternate,I!==null?(I=I.index,I<P?(R.flags|=2,P):I):(R.flags|=2,P)):(R.flags|=1048576,P)}function c(R){return e&&R.alternate===null&&(R.flags|=2),R}function m(R,P,I,W){return P===null||P.tag!==6?(P=gl(I,R.mode,W),P.return=R,P):(P=s(P,I),P.return=R,P)}function S(R,P,I,W){var se=I.type;return se===T?_(R,P,I.props.children,W,I.key):P!==null&&(P.elementType===se||typeof se=="object"&&se!==null&&se.$$typeof===tt&&Jd(se)===P.type)?(W=s(P,I.props),W.ref=Oi(R,P,I),W.return=R,W):(W=fn(I.type,I.key,I.props,null,R.mode,W),W.ref=Oi(R,P,I),W.return=R,W)}function E(R,P,I,W){return P===null||P.tag!==4||P.stateNode.containerInfo!==I.containerInfo||P.stateNode.implementation!==I.implementation?(P=hl(I,R.mode,W),P.return=R,P):(P=s(P,I.children||[]),P.return=R,P)}function _(R,P,I,W,se){return P===null||P.tag!==7?(P=Ia(I,R.mode,W,se),P.return=R,P):(P=s(P,I),P.return=R,P)}function B(R,P,I){if(typeof P=="string"&&P!==""||typeof P=="number")return P=gl(""+P,R.mode,I),P.return=R,P;if(typeof P=="object"&&P!==null){switch(P.$$typeof){case pe:return I=fn(P.type,P.key,P.props,null,R.mode,I),I.ref=Oi(R,null,P),I.return=R,I;case De:return P=hl(P,R.mode,I),P.return=R,P;case tt:var W=P._init;return B(R,W(P._payload),I)}if(ca(P)||le(P))return P=Ia(P,R.mode,I,null),P.return=R,P;Ks(R,P)}return null}function M(R,P,I,W){var se=P!==null?P.key:null;if(typeof I=="string"&&I!==""||typeof I=="number")return se!==null?null:m(R,P,""+I,W);if(typeof I=="object"&&I!==null){switch(I.$$typeof){case pe:return I.key===se?S(R,P,I,W):null;case De:return I.key===se?E(R,P,I,W):null;case tt:return se=I._init,M(R,P,se(I._payload),W)}if(ca(I)||le(I))return se!==null?null:_(R,P,I,W,null);Ks(R,I)}return null}function $(R,P,I,W,se){if(typeof W=="string"&&W!==""||typeof W=="number")return R=R.get(I)||null,m(P,R,""+W,se);if(typeof W=="object"&&W!==null){switch(W.$$typeof){case pe:return R=R.get(W.key===null?I:W.key)||null,S(P,R,W,se);case De:return R=R.get(W.key===null?I:W.key)||null,E(P,R,W,se);case tt:var de=W._init;return $(R,P,I,de(W._payload),se)}if(ca(W)||le(W))return R=R.get(I)||null,_(P,R,W,se,null);Ks(P,W)}return null}function te(R,P,I,W){for(var se=null,de=null,ue=P,fe=P=0,mt=null;ue!==null&&fe<I.length;fe++){ue.index>fe?(mt=ue,ue=null):mt=ue.sibling;var Ue=M(R,ue,I[fe],W);if(Ue===null){ue===null&&(ue=mt);break}e&&ue&&Ue.alternate===null&&t(R,ue),P=l(Ue,P,fe),de===null?se=Ue:de.sibling=Ue,de=Ue,ue=mt}if(fe===I.length)return o(R,ue),Ge&&ba(R,fe),se;if(ue===null){for(;fe<I.length;fe++)ue=B(R,I[fe],W),ue!==null&&(P=l(ue,P,fe),de===null?se=ue:de.sibling=ue,de=ue);return Ge&&ba(R,fe),se}for(ue=a(R,ue);fe<I.length;fe++)mt=$(ue,R,fe,I[fe],W),mt!==null&&(e&&mt.alternate!==null&&ue.delete(mt.key===null?fe:mt.key),P=l(mt,P,fe),de===null?se=mt:de.sibling=mt,de=mt);return e&&ue.forEach(function(sa){return t(R,sa)}),Ge&&ba(R,fe),se}function ae(R,P,I,W){var se=le(I);if(typeof se!="function")throw Error(r(150));if(I=se.call(I),I==null)throw Error(r(151));for(var de=se=null,ue=P,fe=P=0,mt=null,Ue=I.next();ue!==null&&!Ue.done;fe++,Ue=I.next()){ue.index>fe?(mt=ue,ue=null):mt=ue.sibling;var sa=M(R,ue,Ue.value,W);if(sa===null){ue===null&&(ue=mt);break}e&&ue&&sa.alternate===null&&t(R,ue),P=l(sa,P,fe),de===null?se=sa:de.sibling=sa,de=sa,ue=mt}if(Ue.done)return o(R,ue),Ge&&ba(R,fe),se;if(ue===null){for(;!Ue.done;fe++,Ue=I.next())Ue=B(R,Ue.value,W),Ue!==null&&(P=l(Ue,P,fe),de===null?se=Ue:de.sibling=Ue,de=Ue);return Ge&&ba(R,fe),se}for(ue=a(R,ue);!Ue.done;fe++,Ue=I.next())Ue=$(ue,R,fe,Ue.value,W),Ue!==null&&(e&&Ue.alternate!==null&&ue.delete(Ue.key===null?fe:Ue.key),P=l(Ue,P,fe),de===null?se=Ue:de.sibling=Ue,de=Ue);return e&&ue.forEach(function(Eh){return t(R,Eh)}),Ge&&ba(R,fe),se}function st(R,P,I,W){if(typeof I=="object"&&I!==null&&I.type===T&&I.key===null&&(I=I.props.children),typeof I=="object"&&I!==null){switch(I.$$typeof){case pe:e:{for(var se=I.key,de=P;de!==null;){if(de.key===se){if(se=I.type,se===T){if(de.tag===7){o(R,de.sibling),P=s(de,I.props.children),P.return=R,R=P;break e}}else if(de.elementType===se||typeof se=="object"&&se!==null&&se.$$typeof===tt&&Jd(se)===de.type){o(R,de.sibling),P=s(de,I.props),P.ref=Oi(R,de,I),P.return=R,R=P;break e}o(R,de);break}else t(R,de);de=de.sibling}I.type===T?(P=Ia(I.props.children,R.mode,W,I.key),P.return=R,R=P):(W=fn(I.type,I.key,I.props,null,R.mode,W),W.ref=Oi(R,P,I),W.return=R,R=W)}return c(R);case De:e:{for(de=I.key;P!==null;){if(P.key===de)if(P.tag===4&&P.stateNode.containerInfo===I.containerInfo&&P.stateNode.implementation===I.implementation){o(R,P.sibling),P=s(P,I.children||[]),P.return=R,R=P;break e}else{o(R,P);break}else t(R,P);P=P.sibling}P=hl(I,R.mode,W),P.return=R,R=P}return c(R);case tt:return de=I._init,st(R,P,de(I._payload),W)}if(ca(I))return te(R,P,I,W);if(le(I))return ae(R,P,I,W);Ks(R,I)}return typeof I=="string"&&I!==""||typeof I=="number"?(I=""+I,P!==null&&P.tag===6?(o(R,P.sibling),P=s(P,I),P.return=R,R=P):(o(R,P),P=gl(I,R.mode,W),P.return=R,R=P),c(R)):o(R,P)}return st}var ei=eu(!0),tu=eu(!1),Ys=Go(null),Vs=null,ti=null,wr=null;function kr(){wr=ti=Vs=null}function xr(e){var t=Ys.current;Ve(Ys),e._currentValue=t}function Ar(e,t,o){for(;e!==null;){var a=e.alternate;if((e.childLanes&t)!==t?(e.childLanes|=t,a!==null&&(a.childLanes|=t)):a!==null&&(a.childLanes&t)!==t&&(a.childLanes|=t),e===o)break;e=e.return}}function oi(e,t){Vs=e,wr=ti=null,e=e.dependencies,e!==null&&e.firstContext!==null&&((e.lanes&t)!==0&&(Et=!0),e.firstContext=null)}function Kt(e){var t=e._currentValue;if(wr!==e)if(e={context:e,memoizedValue:t,next:null},ti===null){if(Vs===null)throw Error(r(308));ti=e,Vs.dependencies={lanes:0,firstContext:e}}else ti=ti.next=e;return t}var Pa=null;function Rr(e){Pa===null?Pa=[e]:Pa.push(e)}function ou(e,t,o,a){var s=t.interleaved;return s===null?(o.next=o,Rr(t)):(o.next=s.next,s.next=o),t.interleaved=o,Ao(e,a)}function Ao(e,t){e.lanes|=t;var o=e.alternate;for(o!==null&&(o.lanes|=t),o=e,e=e.return;e!==null;)e.childLanes|=t,o=e.alternate,o!==null&&(o.childLanes|=t),o=e,e=e.return;return o.tag===3?o.stateNode:null}var Qo=!1;function Ir(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function au(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 Ro(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function Zo(e,t,o){var a=e.updateQueue;if(a===null)return null;if(a=a.shared,(Te&2)!==0){var s=a.pending;return s===null?t.next=t:(t.next=s.next,s.next=t),a.pending=t,Ao(e,o)}return s=a.interleaved,s===null?(t.next=t,Rr(a)):(t.next=s.next,s.next=t),a.interleaved=t,Ao(e,o)}function Gs(e,t,o){if(t=t.updateQueue,t!==null&&(t=t.shared,(o&4194240)!==0)){var a=t.lanes;a&=e.pendingLanes,o|=a,t.lanes=o,qn(e,o)}}function iu(e,t){var o=e.updateQueue,a=e.alternate;if(a!==null&&(a=a.updateQueue,o===a)){var s=null,l=null;if(o=o.firstBaseUpdate,o!==null){do{var c={eventTime:o.eventTime,lane:o.lane,tag:o.tag,payload:o.payload,callback:o.callback,next:null};l===null?s=l=c:l=l.next=c,o=o.next}while(o!==null);l===null?s=l=t:l=l.next=t}else s=l=t;o={baseState:a.baseState,firstBaseUpdate:s,lastBaseUpdate:l,shared:a.shared,effects:a.effects},e.updateQueue=o;return}e=o.lastBaseUpdate,e===null?o.firstBaseUpdate=t:e.next=t,o.lastBaseUpdate=t}function $s(e,t,o,a){var s=e.updateQueue;Qo=!1;var l=s.firstBaseUpdate,c=s.lastBaseUpdate,m=s.shared.pending;if(m!==null){s.shared.pending=null;var S=m,E=S.next;S.next=null,c===null?l=E:c.next=E,c=S;var _=e.alternate;_!==null&&(_=_.updateQueue,m=_.lastBaseUpdate,m!==c&&(m===null?_.firstBaseUpdate=E:m.next=E,_.lastBaseUpdate=S))}if(l!==null){var B=s.baseState;c=0,_=E=S=null,m=l;do{var M=m.lane,$=m.eventTime;if((a&M)===M){_!==null&&(_=_.next={eventTime:$,lane:0,tag:m.tag,payload:m.payload,callback:m.callback,next:null});e:{var te=e,ae=m;switch(M=t,$=o,ae.tag){case 1:if(te=ae.payload,typeof te=="function"){B=te.call($,B,M);break e}B=te;break e;case 3:te.flags=te.flags&-65537|128;case 0:if(te=ae.payload,M=typeof te=="function"?te.call($,B,M):te,M==null)break e;B=V({},B,M);break e;case 2:Qo=!0}}m.callback!==null&&m.lane!==0&&(e.flags|=64,M=s.effects,M===null?s.effects=[m]:M.push(m))}else $={eventTime:$,lane:M,tag:m.tag,payload:m.payload,callback:m.callback,next:null},_===null?(E=_=$,S=B):_=_.next=$,c|=M;if(m=m.next,m===null){if(m=s.shared.pending,m===null)break;M=m,m=M.next,M.next=null,s.lastBaseUpdate=M,s.shared.pending=null}}while(!0);if(_===null&&(S=B),s.baseState=S,s.firstBaseUpdate=E,s.lastBaseUpdate=_,t=s.shared.interleaved,t!==null){s=t;do c|=s.lane,s=s.next;while(s!==t)}else l===null&&(s.shared.lanes=0);ka|=c,e.lanes=c,e.memoizedState=B}}function su(e,t,o){if(e=t.effects,t.effects=null,e!==null)for(t=0;t<e.length;t++){var a=e[t],s=a.callback;if(s!==null){if(a.callback=null,a=o,typeof s!="function")throw Error(r(191,s));s.call(a)}}}var Bi={},ho=Go(Bi),qi=Go(Bi),Wi=Go(Bi);function Ca(e){if(e===Bi)throw Error(r(174));return e}function Dr(e,t){switch(Fe(Wi,t),Fe(qi,e),Fe(ho,Bi),e=t.nodeType,e){case 9:case 11:t=(t=t.documentElement)?t.namespaceURI:pa(null,"");break;default:e=e===8?t.parentNode:t,t=e.namespaceURI||null,e=e.tagName,t=pa(t,e)}Ve(ho),Fe(ho,t)}function ai(){Ve(ho),Ve(qi),Ve(Wi)}function nu(e){Ca(Wi.current);var t=Ca(ho.current),o=pa(t,e.type);t!==o&&(Fe(qi,e),Fe(ho,o))}function Er(e){qi.current===e&&(Ve(ho),Ve(qi))}var Ze=Go(0);function Xs(e){for(var t=e;t!==null;){if(t.tag===13){var o=t.memoizedState;if(o!==null&&(o=o.dehydrated,o===null||o.data==="$?"||o.data==="$!"))return t}else if(t.tag===19&&t.memoizedProps.revealOrder!==void 0){if((t.flags&128)!==0)return t}else if(t.child!==null){t.child.return=t,t=t.child;continue}if(t===e)break;for(;t.sibling===null;){if(t.return===null||t.return===e)return null;t=t.return}t.sibling.return=t.return,t=t.sibling}return null}var Tr=[];function jr(){for(var e=0;e<Tr.length;e++)Tr[e]._workInProgressVersionPrimary=null;Tr.length=0}var Qs=Y.ReactCurrentDispatcher,Hr=Y.ReactCurrentBatchConfig,wa=0,Je=null,ut=null,gt=null,Zs=!1,Fi=!1,Ki=0,Zg=0;function Pt(){throw Error(r(321))}function Ur(e,t){if(t===null)return!1;for(var o=0;o<t.length&&o<e.length;o++)if(!Qt(e[o],t[o]))return!1;return!0}function zr(e,t,o,a,s,l){if(wa=l,Je=t,t.memoizedState=null,t.updateQueue=null,t.lanes=0,Qs.current=e===null||e.memoizedState===null?oh:ah,e=o(a,s),Fi){l=0;do{if(Fi=!1,Ki=0,25<=l)throw Error(r(301));l+=1,gt=ut=null,t.updateQueue=null,Qs.current=ih,e=o(a,s)}while(Fi)}if(Qs.current=tn,t=ut!==null&&ut.next!==null,wa=0,gt=ut=Je=null,Zs=!1,t)throw Error(r(300));return e}function Lr(){var e=Ki!==0;return Ki=0,e}function mo(){var e={memoizedState:null,baseState:null,baseQueue:null,queue:null,next:null};return gt===null?Je.memoizedState=gt=e:gt=gt.next=e,gt}function Yt(){if(ut===null){var e=Je.alternate;e=e!==null?e.memoizedState:null}else e=ut.next;var t=gt===null?Je.memoizedState:gt.next;if(t!==null)gt=t,ut=e;else{if(e===null)throw Error(r(310));ut=e,e={memoizedState:ut.memoizedState,baseState:ut.baseState,baseQueue:ut.baseQueue,queue:ut.queue,next:null},gt===null?Je.memoizedState=gt=e:gt=gt.next=e}return gt}function Yi(e,t){return typeof t=="function"?t(e):t}function Mr(e){var t=Yt(),o=t.queue;if(o===null)throw Error(r(311));o.lastRenderedReducer=e;var a=ut,s=a.baseQueue,l=o.pending;if(l!==null){if(s!==null){var c=s.next;s.next=l.next,l.next=c}a.baseQueue=s=l,o.pending=null}if(s!==null){l=s.next,a=a.baseState;var m=c=null,S=null,E=l;do{var _=E.lane;if((wa&_)===_)S!==null&&(S=S.next={lane:0,action:E.action,hasEagerState:E.hasEagerState,eagerState:E.eagerState,next:null}),a=E.hasEagerState?E.eagerState:e(a,E.action);else{var B={lane:_,action:E.action,hasEagerState:E.hasEagerState,eagerState:E.eagerState,next:null};S===null?(m=S=B,c=a):S=S.next=B,Je.lanes|=_,ka|=_}E=E.next}while(E!==null&&E!==l);S===null?c=a:S.next=m,Qt(a,t.memoizedState)||(Et=!0),t.memoizedState=a,t.baseState=c,t.baseQueue=S,o.lastRenderedState=a}if(e=o.interleaved,e!==null){s=e;do l=s.lane,Je.lanes|=l,ka|=l,s=s.next;while(s!==e)}else s===null&&(o.lanes=0);return[t.memoizedState,o.dispatch]}function _r(e){var t=Yt(),o=t.queue;if(o===null)throw Error(r(311));o.lastRenderedReducer=e;var a=o.dispatch,s=o.pending,l=t.memoizedState;if(s!==null){o.pending=null;var c=s=s.next;do l=e(l,c.action),c=c.next;while(c!==s);Qt(l,t.memoizedState)||(Et=!0),t.memoizedState=l,t.baseQueue===null&&(t.baseState=l),o.lastRenderedState=l}return[l,a]}function ru(){}function lu(e,t){var o=Je,a=Yt(),s=t(),l=!Qt(a.memoizedState,s);if(l&&(a.memoizedState=s,Et=!0),a=a.queue,Nr(cu.bind(null,o,a,e),[e]),a.getSnapshot!==t||l||gt!==null&&gt.memoizedState.tag&1){if(o.flags|=2048,Vi(9,uu.bind(null,o,a,s,t),void 0,null),ht===null)throw Error(r(349));(wa&30)!==0||du(o,t,s)}return s}function du(e,t,o){e.flags|=16384,e={getSnapshot:t,value:o},t=Je.updateQueue,t===null?(t={lastEffect:null,stores:null},Je.updateQueue=t,t.stores=[e]):(o=t.stores,o===null?t.stores=[e]:o.push(e))}function uu(e,t,o,a){t.value=o,t.getSnapshot=a,pu(t)&&gu(e)}function cu(e,t,o){return o(function(){pu(t)&&gu(e)})}function pu(e){var t=e.getSnapshot;e=e.value;try{var o=t();return!Qt(e,o)}catch{return!0}}function gu(e){var t=Ao(e,1);t!==null&&oo(t,e,1,-1)}function hu(e){var t=mo();return typeof e=="function"&&(e=e()),t.memoizedState=t.baseState=e,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:Yi,lastRenderedState:e},t.queue=e,e=e.dispatch=th.bind(null,Je,e),[t.memoizedState,e]}function Vi(e,t,o,a){return e={tag:e,create:t,destroy:o,deps:a,next:null},t=Je.updateQueue,t===null?(t={lastEffect:null,stores:null},Je.updateQueue=t,t.lastEffect=e.next=e):(o=t.lastEffect,o===null?t.lastEffect=e.next=e:(a=o.next,o.next=e,e.next=a,t.lastEffect=e)),e}function mu(){return Yt().memoizedState}function Js(e,t,o,a){var s=mo();Je.flags|=e,s.memoizedState=Vi(1|t,o,void 0,a===void 0?null:a)}function en(e,t,o,a){var s=Yt();a=a===void 0?null:a;var l=void 0;if(ut!==null){var c=ut.memoizedState;if(l=c.destroy,a!==null&&Ur(a,c.deps)){s.memoizedState=Vi(t,o,l,a);return}}Je.flags|=e,s.memoizedState=Vi(1|t,o,l,a)}function fu(e,t){return Js(8390656,8,e,t)}function Nr(e,t){return en(2048,8,e,t)}function yu(e,t){return en(4,2,e,t)}function vu(e,t){return en(4,4,e,t)}function Su(e,t){if(typeof t=="function")return e=e(),t(e),function(){t(null)};if(t!=null)return e=e(),t.current=e,function(){t.current=null}}function bu(e,t,o){return o=o!=null?o.concat([e]):null,en(4,4,Su.bind(null,t,e),o)}function Or(){}function Pu(e,t){var o=Yt();t=t===void 0?null:t;var a=o.memoizedState;return a!==null&&t!==null&&Ur(t,a[1])?a[0]:(o.memoizedState=[e,t],e)}function Cu(e,t){var o=Yt();t=t===void 0?null:t;var a=o.memoizedState;return a!==null&&t!==null&&Ur(t,a[1])?a[0]:(e=e(),o.memoizedState=[e,t],e)}function wu(e,t,o){return(wa&21)===0?(e.baseState&&(e.baseState=!1,Et=!0),e.memoizedState=o):(Qt(o,t)||(o=Jl(),Je.lanes|=o,ka|=o,e.baseState=!0),t)}function Jg(e,t){var o=Oe;Oe=o!==0&&4>o?o:4,e(!0);var a=Hr.transition;Hr.transition={};try{e(!1),t()}finally{Oe=o,Hr.transition=a}}function ku(){return Yt().memoizedState}function eh(e,t,o){var a=oa(e);if(o={lane:a,action:o,hasEagerState:!1,eagerState:null,next:null},xu(e))Au(t,o);else if(o=ou(e,t,o,a),o!==null){var s=At();oo(o,e,a,s),Ru(o,t,a)}}function th(e,t,o){var a=oa(e),s={lane:a,action:o,hasEagerState:!1,eagerState:null,next:null};if(xu(e))Au(t,s);else{var l=e.alternate;if(e.lanes===0&&(l===null||l.lanes===0)&&(l=t.lastRenderedReducer,l!==null))try{var c=t.lastRenderedState,m=l(c,o);if(s.hasEagerState=!0,s.eagerState=m,Qt(m,c)){var S=t.interleaved;S===null?(s.next=s,Rr(t)):(s.next=S.next,S.next=s),t.interleaved=s;return}}catch{}finally{}o=ou(e,t,s,a),o!==null&&(s=At(),oo(o,e,a,s),Ru(o,t,a))}}function xu(e){var t=e.alternate;return e===Je||t!==null&&t===Je}function Au(e,t){Fi=Zs=!0;var o=e.pending;o===null?t.next=t:(t.next=o.next,o.next=t),e.pending=t}function Ru(e,t,o){if((o&4194240)!==0){var a=t.lanes;a&=e.pendingLanes,o|=a,t.lanes=o,qn(e,o)}}var tn={readContext:Kt,useCallback:Pt,useContext:Pt,useEffect:Pt,useImperativeHandle:Pt,useInsertionEffect:Pt,useLayoutEffect:Pt,useMemo:Pt,useReducer:Pt,useRef:Pt,useState:Pt,useDebugValue:Pt,useDeferredValue:Pt,useTransition:Pt,useMutableSource:Pt,useSyncExternalStore:Pt,useId:Pt,unstable_isNewReconciler:!1},oh={readContext:Kt,useCallback:function(e,t){return mo().memoizedState=[e,t===void 0?null:t],e},useContext:Kt,useEffect:fu,useImperativeHandle:function(e,t,o){return o=o!=null?o.concat([e]):null,Js(4194308,4,Su.bind(null,t,e),o)},useLayoutEffect:function(e,t){return Js(4194308,4,e,t)},useInsertionEffect:function(e,t){return Js(4,2,e,t)},useMemo:function(e,t){var o=mo();return t=t===void 0?null:t,e=e(),o.memoizedState=[e,t],e},useReducer:function(e,t,o){var a=mo();return t=o!==void 0?o(t):t,a.memoizedState=a.baseState=t,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:e,lastRenderedState:t},a.queue=e,e=e.dispatch=eh.bind(null,Je,e),[a.memoizedState,e]},useRef:function(e){var t=mo();return e={current:e},t.memoizedState=e},useState:hu,useDebugValue:Or,useDeferredValue:function(e){return mo().memoizedState=e},useTransition:function(){var e=hu(!1),t=e[0];return e=Jg.bind(null,e[1]),mo().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,o){var a=Je,s=mo();if(Ge){if(o===void 0)throw Error(r(407));o=o()}else{if(o=t(),ht===null)throw Error(r(349));(wa&30)!==0||du(a,t,o)}s.memoizedState=o;var l={value:o,getSnapshot:t};return s.queue=l,fu(cu.bind(null,a,l,e),[e]),a.flags|=2048,Vi(9,uu.bind(null,a,l,o,t),void 0,null),o},useId:function(){var e=mo(),t=ht.identifierPrefix;if(Ge){var o=xo,a=ko;o=(a&~(1<<32-He(a)-1)).toString(32)+o,t=":"+t+"R"+o,o=Ki++,0<o&&(t+="H"+o.toString(32)),t+=":"}else o=Zg++,t=":"+t+"r"+o.toString(32)+":";return e.memoizedState=t},unstable_isNewReconciler:!1},ah={readContext:Kt,useCallback:Pu,useContext:Kt,useEffect:Nr,useImperativeHandle:bu,useInsertionEffect:yu,useLayoutEffect:vu,useMemo:Cu,useReducer:Mr,useRef:mu,useState:function(){return Mr(Yi)},useDebugValue:Or,useDeferredValue:function(e){var t=Yt();return wu(t,ut.memoizedState,e)},useTransition:function(){var e=Mr(Yi)[0],t=Yt().memoizedState;return[e,t]},useMutableSource:ru,useSyncExternalStore:lu,useId:ku,unstable_isNewReconciler:!1},ih={readContext:Kt,useCallback:Pu,useContext:Kt,useEffect:Nr,useImperativeHandle:bu,useInsertionEffect:yu,useLayoutEffect:vu,useMemo:Cu,useReducer:_r,useRef:mu,useState:function(){return _r(Yi)},useDebugValue:Or,useDeferredValue:function(e){var t=Yt();return ut===null?t.memoizedState=e:wu(t,ut.memoizedState,e)},useTransition:function(){var e=_r(Yi)[0],t=Yt().memoizedState;return[e,t]},useMutableSource:ru,useSyncExternalStore:lu,useId:ku,unstable_isNewReconciler:!1};function Jt(e,t){if(e&&e.defaultProps){t=V({},t),e=e.defaultProps;for(var o in e)t[o]===void 0&&(t[o]=e[o]);return t}return t}function Br(e,t,o,a){t=e.memoizedState,o=o(a,t),o=o==null?t:V({},t,o),e.memoizedState=o,e.lanes===0&&(e.updateQueue.baseState=o)}var on={isMounted:function(e){return(e=e._reactInternals)?J(e)===e:!1},enqueueSetState:function(e,t,o){e=e._reactInternals;var a=At(),s=oa(e),l=Ro(a,s);l.payload=t,o!=null&&(l.callback=o),t=Zo(e,l,s),t!==null&&(oo(t,e,s,a),Gs(t,e,s))},enqueueReplaceState:function(e,t,o){e=e._reactInternals;var a=At(),s=oa(e),l=Ro(a,s);l.tag=1,l.payload=t,o!=null&&(l.callback=o),t=Zo(e,l,s),t!==null&&(oo(t,e,s,a),Gs(t,e,s))},enqueueForceUpdate:function(e,t){e=e._reactInternals;var o=At(),a=oa(e),s=Ro(o,a);s.tag=2,t!=null&&(s.callback=t),t=Zo(e,s,a),t!==null&&(oo(t,e,a,o),Gs(t,e,a))}};function Iu(e,t,o,a,s,l,c){return e=e.stateNode,typeof e.shouldComponentUpdate=="function"?e.shouldComponentUpdate(a,l,c):t.prototype&&t.prototype.isPureReactComponent?!Hi(o,a)||!Hi(s,l):!0}function Du(e,t,o){var a=!1,s=$o,l=t.contextType;return typeof l=="object"&&l!==null?l=Kt(l):(s=Dt(t)?va:bt.current,a=t.contextTypes,l=(a=a!=null)?Xa(e,s):$o),t=new t(o,l),e.memoizedState=t.state!==null&&t.state!==void 0?t.state:null,t.updater=on,e.stateNode=t,t._reactInternals=e,a&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=s,e.__reactInternalMemoizedMaskedChildContext=l),t}function Eu(e,t,o,a){e=t.state,typeof t.componentWillReceiveProps=="function"&&t.componentWillReceiveProps(o,a),typeof t.UNSAFE_componentWillReceiveProps=="function"&&t.UNSAFE_componentWillReceiveProps(o,a),t.state!==e&&on.enqueueReplaceState(t,t.state,null)}function qr(e,t,o,a){var s=e.stateNode;s.props=o,s.state=e.memoizedState,s.refs={},Ir(e);var l=t.contextType;typeof l=="object"&&l!==null?s.context=Kt(l):(l=Dt(t)?va:bt.current,s.context=Xa(e,l)),s.state=e.memoizedState,l=t.getDerivedStateFromProps,typeof l=="function"&&(Br(e,t,l,o),s.state=e.memoizedState),typeof t.getDerivedStateFromProps=="function"||typeof s.getSnapshotBeforeUpdate=="function"||typeof s.UNSAFE_componentWillMount!="function"&&typeof s.componentWillMount!="function"||(t=s.state,typeof s.componentWillMount=="function"&&s.componentWillMount(),typeof s.UNSAFE_componentWillMount=="function"&&s.UNSAFE_componentWillMount(),t!==s.state&&on.enqueueReplaceState(s,s.state,null),$s(e,o,s,a),s.state=e.memoizedState),typeof s.componentDidMount=="function"&&(e.flags|=4194308)}function ii(e,t){try{var o="",a=t;do o+=me(a),a=a.return;while(a);var s=o}catch(l){s=`
40
+ Error generating stack: `+l.message+`
41
+ `+l.stack}return{value:e,source:t,stack:s,digest:null}}function Wr(e,t,o){return{value:e,source:null,stack:o??null,digest:t??null}}function Fr(e,t){try{console.error(t.value)}catch(o){setTimeout(function(){throw o})}}var sh=typeof WeakMap=="function"?WeakMap:Map;function Tu(e,t,o){o=Ro(-1,o),o.tag=3,o.payload={element:null};var a=t.value;return o.callback=function(){un||(un=!0,sl=a),Fr(e,t)},o}function ju(e,t,o){o=Ro(-1,o),o.tag=3;var a=e.type.getDerivedStateFromError;if(typeof a=="function"){var s=t.value;o.payload=function(){return a(s)},o.callback=function(){Fr(e,t)}}var l=e.stateNode;return l!==null&&typeof l.componentDidCatch=="function"&&(o.callback=function(){Fr(e,t),typeof a!="function"&&(ea===null?ea=new Set([this]):ea.add(this));var c=t.stack;this.componentDidCatch(t.value,{componentStack:c!==null?c:""})}),o}function Hu(e,t,o){var a=e.pingCache;if(a===null){a=e.pingCache=new sh;var s=new Set;a.set(t,s)}else s=a.get(t),s===void 0&&(s=new Set,a.set(t,s));s.has(o)||(s.add(o),e=Sh.bind(null,e,t,o),t.then(e,e))}function Uu(e){do{var t;if((t=e.tag===13)&&(t=e.memoizedState,t=t!==null?t.dehydrated!==null:!0),t)return e;e=e.return}while(e!==null);return null}function zu(e,t,o,a,s){return(e.mode&1)===0?(e===t?e.flags|=65536:(e.flags|=128,o.flags|=131072,o.flags&=-52805,o.tag===1&&(o.alternate===null?o.tag=17:(t=Ro(-1,1),t.tag=2,Zo(o,t,1))),o.lanes|=1),e):(e.flags|=65536,e.lanes=s,e)}var nh=Y.ReactCurrentOwner,Et=!1;function xt(e,t,o,a){t.child=e===null?tu(t,null,o,a):ei(t,e.child,o,a)}function Lu(e,t,o,a,s){o=o.render;var l=t.ref;return oi(t,s),a=zr(e,t,o,a,l,s),o=Lr(),e!==null&&!Et?(t.updateQueue=e.updateQueue,t.flags&=-2053,e.lanes&=~s,Io(e,t,s)):(Ge&&o&&vr(t),t.flags|=1,xt(e,t,a,s),t.child)}function Mu(e,t,o,a,s){if(e===null){var l=o.type;return typeof l=="function"&&!pl(l)&&l.defaultProps===void 0&&o.compare===null&&o.defaultProps===void 0?(t.tag=15,t.type=l,_u(e,t,l,a,s)):(e=fn(o.type,null,a,t,t.mode,s),e.ref=t.ref,e.return=t,t.child=e)}if(l=e.child,(e.lanes&s)===0){var c=l.memoizedProps;if(o=o.compare,o=o!==null?o:Hi,o(c,a)&&e.ref===t.ref)return Io(e,t,s)}return t.flags|=1,e=ia(l,a),e.ref=t.ref,e.return=t,t.child=e}function _u(e,t,o,a,s){if(e!==null){var l=e.memoizedProps;if(Hi(l,a)&&e.ref===t.ref)if(Et=!1,t.pendingProps=a=l,(e.lanes&s)!==0)(e.flags&131072)!==0&&(Et=!0);else return t.lanes=e.lanes,Io(e,t,s)}return Kr(e,t,o,a,s)}function Nu(e,t,o){var a=t.pendingProps,s=a.children,l=e!==null?e.memoizedState:null;if(a.mode==="hidden")if((t.mode&1)===0)t.memoizedState={baseLanes:0,cachePool:null,transitions:null},Fe(ni,Ot),Ot|=o;else{if((o&1073741824)===0)return e=l!==null?l.baseLanes|o:o,t.lanes=t.childLanes=1073741824,t.memoizedState={baseLanes:e,cachePool:null,transitions:null},t.updateQueue=null,Fe(ni,Ot),Ot|=e,null;t.memoizedState={baseLanes:0,cachePool:null,transitions:null},a=l!==null?l.baseLanes:o,Fe(ni,Ot),Ot|=a}else l!==null?(a=l.baseLanes|o,t.memoizedState=null):a=o,Fe(ni,Ot),Ot|=a;return xt(e,t,s,o),t.child}function Ou(e,t){var o=t.ref;(e===null&&o!==null||e!==null&&e.ref!==o)&&(t.flags|=512,t.flags|=2097152)}function Kr(e,t,o,a,s){var l=Dt(o)?va:bt.current;return l=Xa(t,l),oi(t,s),o=zr(e,t,o,a,l,s),a=Lr(),e!==null&&!Et?(t.updateQueue=e.updateQueue,t.flags&=-2053,e.lanes&=~s,Io(e,t,s)):(Ge&&a&&vr(t),t.flags|=1,xt(e,t,o,s),t.child)}function Bu(e,t,o,a,s){if(Dt(o)){var l=!0;Os(t)}else l=!1;if(oi(t,s),t.stateNode===null)sn(e,t),Du(t,o,a),qr(t,o,a,s),a=!0;else if(e===null){var c=t.stateNode,m=t.memoizedProps;c.props=m;var S=c.context,E=o.contextType;typeof E=="object"&&E!==null?E=Kt(E):(E=Dt(o)?va:bt.current,E=Xa(t,E));var _=o.getDerivedStateFromProps,B=typeof _=="function"||typeof c.getSnapshotBeforeUpdate=="function";B||typeof c.UNSAFE_componentWillReceiveProps!="function"&&typeof c.componentWillReceiveProps!="function"||(m!==a||S!==E)&&Eu(t,c,a,E),Qo=!1;var M=t.memoizedState;c.state=M,$s(t,a,c,s),S=t.memoizedState,m!==a||M!==S||It.current||Qo?(typeof _=="function"&&(Br(t,o,_,a),S=t.memoizedState),(m=Qo||Iu(t,o,m,a,M,S,E))?(B||typeof c.UNSAFE_componentWillMount!="function"&&typeof c.componentWillMount!="function"||(typeof c.componentWillMount=="function"&&c.componentWillMount(),typeof c.UNSAFE_componentWillMount=="function"&&c.UNSAFE_componentWillMount()),typeof c.componentDidMount=="function"&&(t.flags|=4194308)):(typeof c.componentDidMount=="function"&&(t.flags|=4194308),t.memoizedProps=a,t.memoizedState=S),c.props=a,c.state=S,c.context=E,a=m):(typeof c.componentDidMount=="function"&&(t.flags|=4194308),a=!1)}else{c=t.stateNode,au(e,t),m=t.memoizedProps,E=t.type===t.elementType?m:Jt(t.type,m),c.props=E,B=t.pendingProps,M=c.context,S=o.contextType,typeof S=="object"&&S!==null?S=Kt(S):(S=Dt(o)?va:bt.current,S=Xa(t,S));var $=o.getDerivedStateFromProps;(_=typeof $=="function"||typeof c.getSnapshotBeforeUpdate=="function")||typeof c.UNSAFE_componentWillReceiveProps!="function"&&typeof c.componentWillReceiveProps!="function"||(m!==B||M!==S)&&Eu(t,c,a,S),Qo=!1,M=t.memoizedState,c.state=M,$s(t,a,c,s);var te=t.memoizedState;m!==B||M!==te||It.current||Qo?(typeof $=="function"&&(Br(t,o,$,a),te=t.memoizedState),(E=Qo||Iu(t,o,E,a,M,te,S)||!1)?(_||typeof c.UNSAFE_componentWillUpdate!="function"&&typeof c.componentWillUpdate!="function"||(typeof c.componentWillUpdate=="function"&&c.componentWillUpdate(a,te,S),typeof c.UNSAFE_componentWillUpdate=="function"&&c.UNSAFE_componentWillUpdate(a,te,S)),typeof c.componentDidUpdate=="function"&&(t.flags|=4),typeof c.getSnapshotBeforeUpdate=="function"&&(t.flags|=1024)):(typeof c.componentDidUpdate!="function"||m===e.memoizedProps&&M===e.memoizedState||(t.flags|=4),typeof c.getSnapshotBeforeUpdate!="function"||m===e.memoizedProps&&M===e.memoizedState||(t.flags|=1024),t.memoizedProps=a,t.memoizedState=te),c.props=a,c.state=te,c.context=S,a=E):(typeof c.componentDidUpdate!="function"||m===e.memoizedProps&&M===e.memoizedState||(t.flags|=4),typeof c.getSnapshotBeforeUpdate!="function"||m===e.memoizedProps&&M===e.memoizedState||(t.flags|=1024),a=!1)}return Yr(e,t,o,a,l,s)}function Yr(e,t,o,a,s,l){Ou(e,t);var c=(t.flags&128)!==0;if(!a&&!c)return s&&Yd(t,o,!1),Io(e,t,l);a=t.stateNode,nh.current=t;var m=c&&typeof o.getDerivedStateFromError!="function"?null:a.render();return t.flags|=1,e!==null&&c?(t.child=ei(t,e.child,null,l),t.child=ei(t,null,m,l)):xt(e,t,m,l),t.memoizedState=a.state,s&&Yd(t,o,!0),t.child}function qu(e){var t=e.stateNode;t.pendingContext?Fd(e,t.pendingContext,t.pendingContext!==t.context):t.context&&Fd(e,t.context,!1),Dr(e,t.containerInfo)}function Wu(e,t,o,a,s){return Ja(),Cr(s),t.flags|=256,xt(e,t,o,a),t.child}var Vr={dehydrated:null,treeContext:null,retryLane:0};function Gr(e){return{baseLanes:e,cachePool:null,transitions:null}}function Fu(e,t,o){var a=t.pendingProps,s=Ze.current,l=!1,c=(t.flags&128)!==0,m;if((m=c)||(m=e!==null&&e.memoizedState===null?!1:(s&2)!==0),m?(l=!0,t.flags&=-129):(e===null||e.memoizedState!==null)&&(s|=1),Fe(Ze,s&1),e===null)return Pr(t),e=t.memoizedState,e!==null&&(e=e.dehydrated,e!==null)?((t.mode&1)===0?t.lanes=1:e.data==="$!"?t.lanes=8:t.lanes=1073741824,null):(c=a.children,e=a.fallback,l?(a=t.mode,l=t.child,c={mode:"hidden",children:c},(a&1)===0&&l!==null?(l.childLanes=0,l.pendingProps=c):l=yn(c,a,0,null),e=Ia(e,a,o,null),l.return=t,e.return=t,l.sibling=e,t.child=l,t.child.memoizedState=Gr(o),t.memoizedState=Vr,e):$r(t,c));if(s=e.memoizedState,s!==null&&(m=s.dehydrated,m!==null))return rh(e,t,c,a,m,s,o);if(l){l=a.fallback,c=t.mode,s=e.child,m=s.sibling;var S={mode:"hidden",children:a.children};return(c&1)===0&&t.child!==s?(a=t.child,a.childLanes=0,a.pendingProps=S,t.deletions=null):(a=ia(s,S),a.subtreeFlags=s.subtreeFlags&14680064),m!==null?l=ia(m,l):(l=Ia(l,c,o,null),l.flags|=2),l.return=t,a.return=t,a.sibling=l,t.child=a,a=l,l=t.child,c=e.child.memoizedState,c=c===null?Gr(o):{baseLanes:c.baseLanes|o,cachePool:null,transitions:c.transitions},l.memoizedState=c,l.childLanes=e.childLanes&~o,t.memoizedState=Vr,a}return l=e.child,e=l.sibling,a=ia(l,{mode:"visible",children:a.children}),(t.mode&1)===0&&(a.lanes=o),a.return=t,a.sibling=null,e!==null&&(o=t.deletions,o===null?(t.deletions=[e],t.flags|=16):o.push(e)),t.child=a,t.memoizedState=null,a}function $r(e,t){return t=yn({mode:"visible",children:t},e.mode,0,null),t.return=e,e.child=t}function an(e,t,o,a){return a!==null&&Cr(a),ei(t,e.child,null,o),e=$r(t,t.pendingProps.children),e.flags|=2,t.memoizedState=null,e}function rh(e,t,o,a,s,l,c){if(o)return t.flags&256?(t.flags&=-257,a=Wr(Error(r(422))),an(e,t,c,a)):t.memoizedState!==null?(t.child=e.child,t.flags|=128,null):(l=a.fallback,s=t.mode,a=yn({mode:"visible",children:a.children},s,0,null),l=Ia(l,s,c,null),l.flags|=2,a.return=t,l.return=t,a.sibling=l,t.child=a,(t.mode&1)!==0&&ei(t,e.child,null,c),t.child.memoizedState=Gr(c),t.memoizedState=Vr,l);if((t.mode&1)===0)return an(e,t,c,null);if(s.data==="$!"){if(a=s.nextSibling&&s.nextSibling.dataset,a)var m=a.dgst;return a=m,l=Error(r(419)),a=Wr(l,a,void 0),an(e,t,c,a)}if(m=(c&e.childLanes)!==0,Et||m){if(a=ht,a!==null){switch(c&-c){case 4:s=2;break;case 16:s=8;break;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:case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:s=32;break;case 536870912:s=268435456;break;default:s=0}s=(s&(a.suspendedLanes|c))!==0?0:s,s!==0&&s!==l.retryLane&&(l.retryLane=s,Ao(e,s),oo(a,e,s,-1))}return cl(),a=Wr(Error(r(421))),an(e,t,c,a)}return s.data==="$?"?(t.flags|=128,t.child=e.child,t=bh.bind(null,e),s._reactRetry=t,null):(e=l.treeContext,Nt=Vo(s.nextSibling),_t=t,Ge=!0,Zt=null,e!==null&&(Wt[Ft++]=ko,Wt[Ft++]=xo,Wt[Ft++]=Sa,ko=e.id,xo=e.overflow,Sa=t),t=$r(t,a.children),t.flags|=4096,t)}function Ku(e,t,o){e.lanes|=t;var a=e.alternate;a!==null&&(a.lanes|=t),Ar(e.return,t,o)}function Xr(e,t,o,a,s){var l=e.memoizedState;l===null?e.memoizedState={isBackwards:t,rendering:null,renderingStartTime:0,last:a,tail:o,tailMode:s}:(l.isBackwards=t,l.rendering=null,l.renderingStartTime=0,l.last=a,l.tail=o,l.tailMode=s)}function Yu(e,t,o){var a=t.pendingProps,s=a.revealOrder,l=a.tail;if(xt(e,t,a.children,o),a=Ze.current,(a&2)!==0)a=a&1|2,t.flags|=128;else{if(e!==null&&(e.flags&128)!==0)e:for(e=t.child;e!==null;){if(e.tag===13)e.memoizedState!==null&&Ku(e,o,t);else if(e.tag===19)Ku(e,o,t);else if(e.child!==null){e.child.return=e,e=e.child;continue}if(e===t)break e;for(;e.sibling===null;){if(e.return===null||e.return===t)break e;e=e.return}e.sibling.return=e.return,e=e.sibling}a&=1}if(Fe(Ze,a),(t.mode&1)===0)t.memoizedState=null;else switch(s){case"forwards":for(o=t.child,s=null;o!==null;)e=o.alternate,e!==null&&Xs(e)===null&&(s=o),o=o.sibling;o=s,o===null?(s=t.child,t.child=null):(s=o.sibling,o.sibling=null),Xr(t,!1,s,o,l);break;case"backwards":for(o=null,s=t.child,t.child=null;s!==null;){if(e=s.alternate,e!==null&&Xs(e)===null){t.child=s;break}e=s.sibling,s.sibling=o,o=s,s=e}Xr(t,!0,o,null,l);break;case"together":Xr(t,!1,null,null,void 0);break;default:t.memoizedState=null}return t.child}function sn(e,t){(t.mode&1)===0&&e!==null&&(e.alternate=null,t.alternate=null,t.flags|=2)}function Io(e,t,o){if(e!==null&&(t.dependencies=e.dependencies),ka|=t.lanes,(o&t.childLanes)===0)return null;if(e!==null&&t.child!==e.child)throw Error(r(153));if(t.child!==null){for(e=t.child,o=ia(e,e.pendingProps),t.child=o,o.return=t;e.sibling!==null;)e=e.sibling,o=o.sibling=ia(e,e.pendingProps),o.return=t;o.sibling=null}return t.child}function lh(e,t,o){switch(t.tag){case 3:qu(t),Ja();break;case 5:nu(t);break;case 1:Dt(t.type)&&Os(t);break;case 4:Dr(t,t.stateNode.containerInfo);break;case 10:var a=t.type._context,s=t.memoizedProps.value;Fe(Ys,a._currentValue),a._currentValue=s;break;case 13:if(a=t.memoizedState,a!==null)return a.dehydrated!==null?(Fe(Ze,Ze.current&1),t.flags|=128,null):(o&t.child.childLanes)!==0?Fu(e,t,o):(Fe(Ze,Ze.current&1),e=Io(e,t,o),e!==null?e.sibling:null);Fe(Ze,Ze.current&1);break;case 19:if(a=(o&t.childLanes)!==0,(e.flags&128)!==0){if(a)return Yu(e,t,o);t.flags|=128}if(s=t.memoizedState,s!==null&&(s.rendering=null,s.tail=null,s.lastEffect=null),Fe(Ze,Ze.current),a)break;return null;case 22:case 23:return t.lanes=0,Nu(e,t,o)}return Io(e,t,o)}var Vu,Qr,Gu,$u;Vu=function(e,t){for(var o=t.child;o!==null;){if(o.tag===5||o.tag===6)e.appendChild(o.stateNode);else if(o.tag!==4&&o.child!==null){o.child.return=o,o=o.child;continue}if(o===t)break;for(;o.sibling===null;){if(o.return===null||o.return===t)return;o=o.return}o.sibling.return=o.return,o=o.sibling}},Qr=function(){},Gu=function(e,t,o,a){var s=e.memoizedProps;if(s!==a){e=t.stateNode,Ca(ho.current);var l=null;switch(o){case"input":s=ot(e,s),a=ot(e,a),l=[];break;case"select":s=V({},s,{value:void 0}),a=V({},a,{value:void 0}),l=[];break;case"textarea":s=hi(e,s),a=hi(e,a),l=[];break;default:typeof s.onClick!="function"&&typeof a.onClick=="function"&&(e.onclick=Ms)}Ma(o,a);var c;o=null;for(E in s)if(!a.hasOwnProperty(E)&&s.hasOwnProperty(E)&&s[E]!=null)if(E==="style"){var m=s[E];for(c in m)m.hasOwnProperty(c)&&(o||(o={}),o[c]="")}else E!=="dangerouslySetInnerHTML"&&E!=="children"&&E!=="suppressContentEditableWarning"&&E!=="suppressHydrationWarning"&&E!=="autoFocus"&&(u.hasOwnProperty(E)?l||(l=[]):(l=l||[]).push(E,null));for(E in a){var S=a[E];if(m=s!=null?s[E]:void 0,a.hasOwnProperty(E)&&S!==m&&(S!=null||m!=null))if(E==="style")if(m){for(c in m)!m.hasOwnProperty(c)||S&&S.hasOwnProperty(c)||(o||(o={}),o[c]="");for(c in S)S.hasOwnProperty(c)&&m[c]!==S[c]&&(o||(o={}),o[c]=S[c])}else o||(l||(l=[]),l.push(E,o)),o=S;else E==="dangerouslySetInnerHTML"?(S=S?S.__html:void 0,m=m?m.__html:void 0,S!=null&&m!==S&&(l=l||[]).push(E,S)):E==="children"?typeof S!="string"&&typeof S!="number"||(l=l||[]).push(E,""+S):E!=="suppressContentEditableWarning"&&E!=="suppressHydrationWarning"&&(u.hasOwnProperty(E)?(S!=null&&E==="onScroll"&&Ye("scroll",e),l||m===S||(l=[])):(l=l||[]).push(E,S))}o&&(l=l||[]).push("style",o);var E=l;(t.updateQueue=E)&&(t.flags|=4)}},$u=function(e,t,o,a){o!==a&&(t.flags|=4)};function Gi(e,t){if(!Ge)switch(e.tailMode){case"hidden":t=e.tail;for(var o=null;t!==null;)t.alternate!==null&&(o=t),t=t.sibling;o===null?e.tail=null:o.sibling=null;break;case"collapsed":o=e.tail;for(var a=null;o!==null;)o.alternate!==null&&(a=o),o=o.sibling;a===null?t||e.tail===null?e.tail=null:e.tail.sibling=null:a.sibling=null}}function Ct(e){var t=e.alternate!==null&&e.alternate.child===e.child,o=0,a=0;if(t)for(var s=e.child;s!==null;)o|=s.lanes|s.childLanes,a|=s.subtreeFlags&14680064,a|=s.flags&14680064,s.return=e,s=s.sibling;else for(s=e.child;s!==null;)o|=s.lanes|s.childLanes,a|=s.subtreeFlags,a|=s.flags,s.return=e,s=s.sibling;return e.subtreeFlags|=a,e.childLanes=o,t}function dh(e,t,o){var a=t.pendingProps;switch(Sr(t),t.tag){case 2:case 16:case 15:case 0:case 11:case 7:case 8:case 12:case 9:case 14:return Ct(t),null;case 1:return Dt(t.type)&&Ns(),Ct(t),null;case 3:return a=t.stateNode,ai(),Ve(It),Ve(bt),jr(),a.pendingContext&&(a.context=a.pendingContext,a.pendingContext=null),(e===null||e.child===null)&&(Fs(t)?t.flags|=4:e===null||e.memoizedState.isDehydrated&&(t.flags&256)===0||(t.flags|=1024,Zt!==null&&(ll(Zt),Zt=null))),Qr(e,t),Ct(t),null;case 5:Er(t);var s=Ca(Wi.current);if(o=t.type,e!==null&&t.stateNode!=null)Gu(e,t,o,a,s),e.ref!==t.ref&&(t.flags|=512,t.flags|=2097152);else{if(!a){if(t.stateNode===null)throw Error(r(166));return Ct(t),null}if(e=Ca(ho.current),Fs(t)){a=t.stateNode,o=t.type;var l=t.memoizedProps;switch(a[go]=t,a[_i]=l,e=(t.mode&1)!==0,o){case"dialog":Ye("cancel",a),Ye("close",a);break;case"iframe":case"object":case"embed":Ye("load",a);break;case"video":case"audio":for(s=0;s<zi.length;s++)Ye(zi[s],a);break;case"source":Ye("error",a);break;case"img":case"image":case"link":Ye("error",a),Ye("load",a);break;case"details":Ye("toggle",a);break;case"input":ft(a,l),Ye("invalid",a);break;case"select":a._wrapperState={wasMultiple:!!l.multiple},Ye("invalid",a);break;case"textarea":hs(a,l),Ye("invalid",a)}Ma(o,l),s=null;for(var c in l)if(l.hasOwnProperty(c)){var m=l[c];c==="children"?typeof m=="string"?a.textContent!==m&&(l.suppressHydrationWarning!==!0&&Ls(a.textContent,m,e),s=["children",m]):typeof m=="number"&&a.textContent!==""+m&&(l.suppressHydrationWarning!==!0&&Ls(a.textContent,m,e),s=["children",""+m]):u.hasOwnProperty(c)&&m!=null&&c==="onScroll"&&Ye("scroll",a)}switch(o){case"input":vo(a),gs(a,l,!0);break;case"textarea":vo(a),Lo(a);break;case"select":case"option":break;default:typeof l.onClick=="function"&&(a.onclick=Ms)}a=s,t.updateQueue=a,a!==null&&(t.flags|=4)}else{c=s.nodeType===9?s:s.ownerDocument,e==="http://www.w3.org/1999/xhtml"&&(e=mi(o)),e==="http://www.w3.org/1999/xhtml"?o==="script"?(e=c.createElement("div"),e.innerHTML="<script><\/script>",e=e.removeChild(e.firstChild)):typeof a.is=="string"?e=c.createElement(o,{is:a.is}):(e=c.createElement(o),o==="select"&&(c=e,a.multiple?c.multiple=!0:a.size&&(c.size=a.size))):e=c.createElementNS(e,o),e[go]=t,e[_i]=a,Vu(e,t,!1,!1),t.stateNode=e;e:{switch(c=yi(o,a),o){case"dialog":Ye("cancel",e),Ye("close",e),s=a;break;case"iframe":case"object":case"embed":Ye("load",e),s=a;break;case"video":case"audio":for(s=0;s<zi.length;s++)Ye(zi[s],e);s=a;break;case"source":Ye("error",e),s=a;break;case"img":case"image":case"link":Ye("error",e),Ye("load",e),s=a;break;case"details":Ye("toggle",e),s=a;break;case"input":ft(e,a),s=ot(e,a),Ye("invalid",e);break;case"option":s=a;break;case"select":e._wrapperState={wasMultiple:!!a.multiple},s=V({},a,{value:void 0}),Ye("invalid",e);break;case"textarea":hs(e,a),s=hi(e,a),Ye("invalid",e);break;default:s=a}Ma(o,s),m=s;for(l in m)if(m.hasOwnProperty(l)){var S=m[l];l==="style"?fi(e,S):l==="dangerouslySetInnerHTML"?(S=S?S.__html:void 0,S!=null&&qt(e,S)):l==="children"?typeof S=="string"?(o!=="textarea"||S!=="")&&Mo(e,S):typeof S=="number"&&Mo(e,""+S):l!=="suppressContentEditableWarning"&&l!=="suppressHydrationWarning"&&l!=="autoFocus"&&(u.hasOwnProperty(l)?S!=null&&l==="onScroll"&&Ye("scroll",e):S!=null&&X(e,l,S,c))}switch(o){case"input":vo(e),gs(e,a,!1);break;case"textarea":vo(e),Lo(e);break;case"option":a.value!=null&&e.setAttribute("value",""+Re(a.value));break;case"select":e.multiple=!!a.multiple,l=a.value,l!=null?zo(e,!!a.multiple,l,!1):a.defaultValue!=null&&zo(e,!!a.multiple,a.defaultValue,!0);break;default:typeof s.onClick=="function"&&(e.onclick=Ms)}switch(o){case"button":case"input":case"select":case"textarea":a=!!a.autoFocus;break e;case"img":a=!0;break e;default:a=!1}}a&&(t.flags|=4)}t.ref!==null&&(t.flags|=512,t.flags|=2097152)}return Ct(t),null;case 6:if(e&&t.stateNode!=null)$u(e,t,e.memoizedProps,a);else{if(typeof a!="string"&&t.stateNode===null)throw Error(r(166));if(o=Ca(Wi.current),Ca(ho.current),Fs(t)){if(a=t.stateNode,o=t.memoizedProps,a[go]=t,(l=a.nodeValue!==o)&&(e=_t,e!==null))switch(e.tag){case 3:Ls(a.nodeValue,o,(e.mode&1)!==0);break;case 5:e.memoizedProps.suppressHydrationWarning!==!0&&Ls(a.nodeValue,o,(e.mode&1)!==0)}l&&(t.flags|=4)}else a=(o.nodeType===9?o:o.ownerDocument).createTextNode(a),a[go]=t,t.stateNode=a}return Ct(t),null;case 13:if(Ve(Ze),a=t.memoizedState,e===null||e.memoizedState!==null&&e.memoizedState.dehydrated!==null){if(Ge&&Nt!==null&&(t.mode&1)!==0&&(t.flags&128)===0)Zd(),Ja(),t.flags|=98560,l=!1;else if(l=Fs(t),a!==null&&a.dehydrated!==null){if(e===null){if(!l)throw Error(r(318));if(l=t.memoizedState,l=l!==null?l.dehydrated:null,!l)throw Error(r(317));l[go]=t}else Ja(),(t.flags&128)===0&&(t.memoizedState=null),t.flags|=4;Ct(t),l=!1}else Zt!==null&&(ll(Zt),Zt=null),l=!0;if(!l)return t.flags&65536?t:null}return(t.flags&128)!==0?(t.lanes=o,t):(a=a!==null,a!==(e!==null&&e.memoizedState!==null)&&a&&(t.child.flags|=8192,(t.mode&1)!==0&&(e===null||(Ze.current&1)!==0?ct===0&&(ct=3):cl())),t.updateQueue!==null&&(t.flags|=4),Ct(t),null);case 4:return ai(),Qr(e,t),e===null&&Li(t.stateNode.containerInfo),Ct(t),null;case 10:return xr(t.type._context),Ct(t),null;case 17:return Dt(t.type)&&Ns(),Ct(t),null;case 19:if(Ve(Ze),l=t.memoizedState,l===null)return Ct(t),null;if(a=(t.flags&128)!==0,c=l.rendering,c===null)if(a)Gi(l,!1);else{if(ct!==0||e!==null&&(e.flags&128)!==0)for(e=t.child;e!==null;){if(c=Xs(e),c!==null){for(t.flags|=128,Gi(l,!1),a=c.updateQueue,a!==null&&(t.updateQueue=a,t.flags|=4),t.subtreeFlags=0,a=o,o=t.child;o!==null;)l=o,e=a,l.flags&=14680066,c=l.alternate,c===null?(l.childLanes=0,l.lanes=e,l.child=null,l.subtreeFlags=0,l.memoizedProps=null,l.memoizedState=null,l.updateQueue=null,l.dependencies=null,l.stateNode=null):(l.childLanes=c.childLanes,l.lanes=c.lanes,l.child=c.child,l.subtreeFlags=0,l.deletions=null,l.memoizedProps=c.memoizedProps,l.memoizedState=c.memoizedState,l.updateQueue=c.updateQueue,l.type=c.type,e=c.dependencies,l.dependencies=e===null?null:{lanes:e.lanes,firstContext:e.firstContext}),o=o.sibling;return Fe(Ze,Ze.current&1|2),t.child}e=e.sibling}l.tail!==null&&je()>ri&&(t.flags|=128,a=!0,Gi(l,!1),t.lanes=4194304)}else{if(!a)if(e=Xs(c),e!==null){if(t.flags|=128,a=!0,o=e.updateQueue,o!==null&&(t.updateQueue=o,t.flags|=4),Gi(l,!0),l.tail===null&&l.tailMode==="hidden"&&!c.alternate&&!Ge)return Ct(t),null}else 2*je()-l.renderingStartTime>ri&&o!==1073741824&&(t.flags|=128,a=!0,Gi(l,!1),t.lanes=4194304);l.isBackwards?(c.sibling=t.child,t.child=c):(o=l.last,o!==null?o.sibling=c:t.child=c,l.last=c)}return l.tail!==null?(t=l.tail,l.rendering=t,l.tail=t.sibling,l.renderingStartTime=je(),t.sibling=null,o=Ze.current,Fe(Ze,a?o&1|2:o&1),t):(Ct(t),null);case 22:case 23:return ul(),a=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==a&&(t.flags|=8192),a&&(t.mode&1)!==0?(Ot&1073741824)!==0&&(Ct(t),t.subtreeFlags&6&&(t.flags|=8192)):Ct(t),null;case 24:return null;case 25:return null}throw Error(r(156,t.tag))}function uh(e,t){switch(Sr(t),t.tag){case 1:return Dt(t.type)&&Ns(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return ai(),Ve(It),Ve(bt),jr(),e=t.flags,(e&65536)!==0&&(e&128)===0?(t.flags=e&-65537|128,t):null;case 5:return Er(t),null;case 13:if(Ve(Ze),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(r(340));Ja()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return Ve(Ze),null;case 4:return ai(),null;case 10:return xr(t.type._context),null;case 22:case 23:return ul(),null;case 24:return null;default:return null}}var nn=!1,wt=!1,ch=typeof WeakSet=="function"?WeakSet:Set,Z=null;function si(e,t){var o=e.ref;if(o!==null)if(typeof o=="function")try{o(null)}catch(a){at(e,t,a)}else o.current=null}function Zr(e,t,o){try{o()}catch(a){at(e,t,a)}}var Xu=!1;function ph(e,t){if(ur=xs,e=Id(),or(e)){if("selectionStart"in e)var o={start:e.selectionStart,end:e.selectionEnd};else e:{o=(o=e.ownerDocument)&&o.defaultView||window;var a=o.getSelection&&o.getSelection();if(a&&a.rangeCount!==0){o=a.anchorNode;var s=a.anchorOffset,l=a.focusNode;a=a.focusOffset;try{o.nodeType,l.nodeType}catch{o=null;break e}var c=0,m=-1,S=-1,E=0,_=0,B=e,M=null;t:for(;;){for(var $;B!==o||s!==0&&B.nodeType!==3||(m=c+s),B!==l||a!==0&&B.nodeType!==3||(S=c+a),B.nodeType===3&&(c+=B.nodeValue.length),($=B.firstChild)!==null;)M=B,B=$;for(;;){if(B===e)break t;if(M===o&&++E===s&&(m=c),M===l&&++_===a&&(S=c),($=B.nextSibling)!==null)break;B=M,M=B.parentNode}B=$}o=m===-1||S===-1?null:{start:m,end:S}}else o=null}o=o||{start:0,end:0}}else o=null;for(cr={focusedElem:e,selectionRange:o},xs=!1,Z=t;Z!==null;)if(t=Z,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,Z=e;else for(;Z!==null;){t=Z;try{var te=t.alternate;if((t.flags&1024)!==0)switch(t.tag){case 0:case 11:case 15:break;case 1:if(te!==null){var ae=te.memoizedProps,st=te.memoizedState,R=t.stateNode,P=R.getSnapshotBeforeUpdate(t.elementType===t.type?ae:Jt(t.type,ae),st);R.__reactInternalSnapshotBeforeUpdate=P}break;case 3:var I=t.stateNode.containerInfo;I.nodeType===1?I.textContent="":I.nodeType===9&&I.documentElement&&I.removeChild(I.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(r(163))}}catch(W){at(t,t.return,W)}if(e=t.sibling,e!==null){e.return=t.return,Z=e;break}Z=t.return}return te=Xu,Xu=!1,te}function $i(e,t,o){var a=t.updateQueue;if(a=a!==null?a.lastEffect:null,a!==null){var s=a=a.next;do{if((s.tag&e)===e){var l=s.destroy;s.destroy=void 0,l!==void 0&&Zr(t,o,l)}s=s.next}while(s!==a)}}function rn(e,t){if(t=t.updateQueue,t=t!==null?t.lastEffect:null,t!==null){var o=t=t.next;do{if((o.tag&e)===e){var a=o.create;o.destroy=a()}o=o.next}while(o!==t)}}function Jr(e){var t=e.ref;if(t!==null){var o=e.stateNode;switch(e.tag){case 5:e=o;break;default:e=o}typeof t=="function"?t(e):t.current=e}}function Qu(e){var t=e.alternate;t!==null&&(e.alternate=null,Qu(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[go],delete t[_i],delete t[mr],delete t[Gg],delete t[$g])),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 Zu(e){return e.tag===5||e.tag===3||e.tag===4}function Ju(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||Zu(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 el(e,t,o){var a=e.tag;if(a===5||a===6)e=e.stateNode,t?o.nodeType===8?o.parentNode.insertBefore(e,t):o.insertBefore(e,t):(o.nodeType===8?(t=o.parentNode,t.insertBefore(e,o)):(t=o,t.appendChild(e)),o=o._reactRootContainer,o!=null||t.onclick!==null||(t.onclick=Ms));else if(a!==4&&(e=e.child,e!==null))for(el(e,t,o),e=e.sibling;e!==null;)el(e,t,o),e=e.sibling}function tl(e,t,o){var a=e.tag;if(a===5||a===6)e=e.stateNode,t?o.insertBefore(e,t):o.appendChild(e);else if(a!==4&&(e=e.child,e!==null))for(tl(e,t,o),e=e.sibling;e!==null;)tl(e,t,o),e=e.sibling}var vt=null,eo=!1;function Jo(e,t,o){for(o=o.child;o!==null;)ec(e,t,o),o=o.sibling}function ec(e,t,o){if(yt&&typeof yt.onCommitFiberUnmount=="function")try{yt.onCommitFiberUnmount(qe,o)}catch{}switch(o.tag){case 5:wt||si(o,t);case 6:var a=vt,s=eo;vt=null,Jo(e,t,o),vt=a,eo=s,vt!==null&&(eo?(e=vt,o=o.stateNode,e.nodeType===8?e.parentNode.removeChild(o):e.removeChild(o)):vt.removeChild(o.stateNode));break;case 18:vt!==null&&(eo?(e=vt,o=o.stateNode,e.nodeType===8?hr(e.parentNode,o):e.nodeType===1&&hr(e,o),Ri(e)):hr(vt,o.stateNode));break;case 4:a=vt,s=eo,vt=o.stateNode.containerInfo,eo=!0,Jo(e,t,o),vt=a,eo=s;break;case 0:case 11:case 14:case 15:if(!wt&&(a=o.updateQueue,a!==null&&(a=a.lastEffect,a!==null))){s=a=a.next;do{var l=s,c=l.destroy;l=l.tag,c!==void 0&&((l&2)!==0||(l&4)!==0)&&Zr(o,t,c),s=s.next}while(s!==a)}Jo(e,t,o);break;case 1:if(!wt&&(si(o,t),a=o.stateNode,typeof a.componentWillUnmount=="function"))try{a.props=o.memoizedProps,a.state=o.memoizedState,a.componentWillUnmount()}catch(m){at(o,t,m)}Jo(e,t,o);break;case 21:Jo(e,t,o);break;case 22:o.mode&1?(wt=(a=wt)||o.memoizedState!==null,Jo(e,t,o),wt=a):Jo(e,t,o);break;default:Jo(e,t,o)}}function tc(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var o=e.stateNode;o===null&&(o=e.stateNode=new ch),t.forEach(function(a){var s=Ph.bind(null,e,a);o.has(a)||(o.add(a),a.then(s,s))})}}function to(e,t){var o=t.deletions;if(o!==null)for(var a=0;a<o.length;a++){var s=o[a];try{var l=e,c=t,m=c;e:for(;m!==null;){switch(m.tag){case 5:vt=m.stateNode,eo=!1;break e;case 3:vt=m.stateNode.containerInfo,eo=!0;break e;case 4:vt=m.stateNode.containerInfo,eo=!0;break e}m=m.return}if(vt===null)throw Error(r(160));ec(l,c,s),vt=null,eo=!1;var S=s.alternate;S!==null&&(S.return=null),s.return=null}catch(E){at(s,t,E)}}if(t.subtreeFlags&12854)for(t=t.child;t!==null;)oc(t,e),t=t.sibling}function oc(e,t){var o=e.alternate,a=e.flags;switch(e.tag){case 0:case 11:case 14:case 15:if(to(t,e),fo(e),a&4){try{$i(3,e,e.return),rn(3,e)}catch(ae){at(e,e.return,ae)}try{$i(5,e,e.return)}catch(ae){at(e,e.return,ae)}}break;case 1:to(t,e),fo(e),a&512&&o!==null&&si(o,o.return);break;case 5:if(to(t,e),fo(e),a&512&&o!==null&&si(o,o.return),e.flags&32){var s=e.stateNode;try{Mo(s,"")}catch(ae){at(e,e.return,ae)}}if(a&4&&(s=e.stateNode,s!=null)){var l=e.memoizedProps,c=o!==null?o.memoizedProps:l,m=e.type,S=e.updateQueue;if(e.updateQueue=null,S!==null)try{m==="input"&&l.type==="radio"&&l.name!=null&&Rt(s,l),yi(m,c);var E=yi(m,l);for(c=0;c<S.length;c+=2){var _=S[c],B=S[c+1];_==="style"?fi(s,B):_==="dangerouslySetInnerHTML"?qt(s,B):_==="children"?Mo(s,B):X(s,_,B,E)}switch(m){case"input":ua(s,l);break;case"textarea":ro(s,l);break;case"select":var M=s._wrapperState.wasMultiple;s._wrapperState.wasMultiple=!!l.multiple;var $=l.value;$!=null?zo(s,!!l.multiple,$,!1):M!==!!l.multiple&&(l.defaultValue!=null?zo(s,!!l.multiple,l.defaultValue,!0):zo(s,!!l.multiple,l.multiple?[]:"",!1))}s[_i]=l}catch(ae){at(e,e.return,ae)}}break;case 6:if(to(t,e),fo(e),a&4){if(e.stateNode===null)throw Error(r(162));s=e.stateNode,l=e.memoizedProps;try{s.nodeValue=l}catch(ae){at(e,e.return,ae)}}break;case 3:if(to(t,e),fo(e),a&4&&o!==null&&o.memoizedState.isDehydrated)try{Ri(t.containerInfo)}catch(ae){at(e,e.return,ae)}break;case 4:to(t,e),fo(e);break;case 13:to(t,e),fo(e),s=e.child,s.flags&8192&&(l=s.memoizedState!==null,s.stateNode.isHidden=l,!l||s.alternate!==null&&s.alternate.memoizedState!==null||(il=je())),a&4&&tc(e);break;case 22:if(_=o!==null&&o.memoizedState!==null,e.mode&1?(wt=(E=wt)||_,to(t,e),wt=E):to(t,e),fo(e),a&8192){if(E=e.memoizedState!==null,(e.stateNode.isHidden=E)&&!_&&(e.mode&1)!==0)for(Z=e,_=e.child;_!==null;){for(B=Z=_;Z!==null;){switch(M=Z,$=M.child,M.tag){case 0:case 11:case 14:case 15:$i(4,M,M.return);break;case 1:si(M,M.return);var te=M.stateNode;if(typeof te.componentWillUnmount=="function"){a=M,o=M.return;try{t=a,te.props=t.memoizedProps,te.state=t.memoizedState,te.componentWillUnmount()}catch(ae){at(a,o,ae)}}break;case 5:si(M,M.return);break;case 22:if(M.memoizedState!==null){sc(B);continue}}$!==null?($.return=M,Z=$):sc(B)}_=_.sibling}e:for(_=null,B=e;;){if(B.tag===5){if(_===null){_=B;try{s=B.stateNode,E?(l=s.style,typeof l.setProperty=="function"?l.setProperty("display","none","important"):l.display="none"):(m=B.stateNode,S=B.memoizedProps.style,c=S!=null&&S.hasOwnProperty("display")?S.display:null,m.style.display=$t("display",c))}catch(ae){at(e,e.return,ae)}}}else if(B.tag===6){if(_===null)try{B.stateNode.nodeValue=E?"":B.memoizedProps}catch(ae){at(e,e.return,ae)}}else if((B.tag!==22&&B.tag!==23||B.memoizedState===null||B===e)&&B.child!==null){B.child.return=B,B=B.child;continue}if(B===e)break e;for(;B.sibling===null;){if(B.return===null||B.return===e)break e;_===B&&(_=null),B=B.return}_===B&&(_=null),B.sibling.return=B.return,B=B.sibling}}break;case 19:to(t,e),fo(e),a&4&&tc(e);break;case 21:break;default:to(t,e),fo(e)}}function fo(e){var t=e.flags;if(t&2){try{e:{for(var o=e.return;o!==null;){if(Zu(o)){var a=o;break e}o=o.return}throw Error(r(160))}switch(a.tag){case 5:var s=a.stateNode;a.flags&32&&(Mo(s,""),a.flags&=-33);var l=Ju(e);tl(e,l,s);break;case 3:case 4:var c=a.stateNode.containerInfo,m=Ju(e);el(e,m,c);break;default:throw Error(r(161))}}catch(S){at(e,e.return,S)}e.flags&=-3}t&4096&&(e.flags&=-4097)}function gh(e,t,o){Z=e,ac(e)}function ac(e,t,o){for(var a=(e.mode&1)!==0;Z!==null;){var s=Z,l=s.child;if(s.tag===22&&a){var c=s.memoizedState!==null||nn;if(!c){var m=s.alternate,S=m!==null&&m.memoizedState!==null||wt;m=nn;var E=wt;if(nn=c,(wt=S)&&!E)for(Z=s;Z!==null;)c=Z,S=c.child,c.tag===22&&c.memoizedState!==null?nc(s):S!==null?(S.return=c,Z=S):nc(s);for(;l!==null;)Z=l,ac(l),l=l.sibling;Z=s,nn=m,wt=E}ic(e)}else(s.subtreeFlags&8772)!==0&&l!==null?(l.return=s,Z=l):ic(e)}}function ic(e){for(;Z!==null;){var t=Z;if((t.flags&8772)!==0){var o=t.alternate;try{if((t.flags&8772)!==0)switch(t.tag){case 0:case 11:case 15:wt||rn(5,t);break;case 1:var a=t.stateNode;if(t.flags&4&&!wt)if(o===null)a.componentDidMount();else{var s=t.elementType===t.type?o.memoizedProps:Jt(t.type,o.memoizedProps);a.componentDidUpdate(s,o.memoizedState,a.__reactInternalSnapshotBeforeUpdate)}var l=t.updateQueue;l!==null&&su(t,l,a);break;case 3:var c=t.updateQueue;if(c!==null){if(o=null,t.child!==null)switch(t.child.tag){case 5:o=t.child.stateNode;break;case 1:o=t.child.stateNode}su(t,c,o)}break;case 5:var m=t.stateNode;if(o===null&&t.flags&4){o=m;var S=t.memoizedProps;switch(t.type){case"button":case"input":case"select":case"textarea":S.autoFocus&&o.focus();break;case"img":S.src&&(o.src=S.src)}}break;case 6:break;case 4:break;case 12:break;case 13:if(t.memoizedState===null){var E=t.alternate;if(E!==null){var _=E.memoizedState;if(_!==null){var B=_.dehydrated;B!==null&&Ri(B)}}}break;case 19:case 17:case 21:case 22:case 23:case 25:break;default:throw Error(r(163))}wt||t.flags&512&&Jr(t)}catch(M){at(t,t.return,M)}}if(t===e){Z=null;break}if(o=t.sibling,o!==null){o.return=t.return,Z=o;break}Z=t.return}}function sc(e){for(;Z!==null;){var t=Z;if(t===e){Z=null;break}var o=t.sibling;if(o!==null){o.return=t.return,Z=o;break}Z=t.return}}function nc(e){for(;Z!==null;){var t=Z;try{switch(t.tag){case 0:case 11:case 15:var o=t.return;try{rn(4,t)}catch(S){at(t,o,S)}break;case 1:var a=t.stateNode;if(typeof a.componentDidMount=="function"){var s=t.return;try{a.componentDidMount()}catch(S){at(t,s,S)}}var l=t.return;try{Jr(t)}catch(S){at(t,l,S)}break;case 5:var c=t.return;try{Jr(t)}catch(S){at(t,c,S)}}}catch(S){at(t,t.return,S)}if(t===e){Z=null;break}var m=t.sibling;if(m!==null){m.return=t.return,Z=m;break}Z=t.return}}var hh=Math.ceil,ln=Y.ReactCurrentDispatcher,ol=Y.ReactCurrentOwner,Vt=Y.ReactCurrentBatchConfig,Te=0,ht=null,rt=null,St=0,Ot=0,ni=Go(0),ct=0,Xi=null,ka=0,dn=0,al=0,Qi=null,Tt=null,il=0,ri=1/0,Do=null,un=!1,sl=null,ea=null,cn=!1,ta=null,pn=0,Zi=0,nl=null,gn=-1,hn=0;function At(){return(Te&6)!==0?je():gn!==-1?gn:gn=je()}function oa(e){return(e.mode&1)===0?1:(Te&2)!==0&&St!==0?St&-St:Qg.transition!==null?(hn===0&&(hn=Jl()),hn):(e=Oe,e!==0||(e=window.event,e=e===void 0?16:ld(e.type)),e)}function oo(e,t,o,a){if(50<Zi)throw Zi=0,nl=null,Error(r(185));Ci(e,o,a),((Te&2)===0||e!==ht)&&(e===ht&&((Te&2)===0&&(dn|=o),ct===4&&aa(e,St)),jt(e,a),o===1&&Te===0&&(t.mode&1)===0&&(ri=je()+500,Bs&&Xo()))}function jt(e,t){var o=e.callbackNode;Qp(e,t);var a=Cs(e,e===ht?St:0);if(a===0)o!==null&&So(o),e.callbackNode=null,e.callbackPriority=0;else if(t=a&-a,e.callbackPriority!==t){if(o!=null&&So(o),t===1)e.tag===0?Xg(lc.bind(null,e)):Vd(lc.bind(null,e)),Yg(function(){(Te&6)===0&&Xo()}),o=null;else{switch(ed(a)){case 1:o=bo;break;case 4:o=po;break;case 16:o=Po;break;case 536870912:o=Ie;break;default:o=Po}o=fc(o,rc.bind(null,e))}e.callbackPriority=t,e.callbackNode=o}}function rc(e,t){if(gn=-1,hn=0,(Te&6)!==0)throw Error(r(327));var o=e.callbackNode;if(li()&&e.callbackNode!==o)return null;var a=Cs(e,e===ht?St:0);if(a===0)return null;if((a&30)!==0||(a&e.expiredLanes)!==0||t)t=mn(e,a);else{t=a;var s=Te;Te|=2;var l=uc();(ht!==e||St!==t)&&(Do=null,ri=je()+500,Aa(e,t));do try{yh();break}catch(m){dc(e,m)}while(!0);kr(),ln.current=l,Te=s,rt!==null?t=0:(ht=null,St=0,t=ct)}if(t!==0){if(t===2&&(s=On(e),s!==0&&(a=s,t=rl(e,s))),t===1)throw o=Xi,Aa(e,0),aa(e,a),jt(e,je()),o;if(t===6)aa(e,a);else{if(s=e.current.alternate,(a&30)===0&&!mh(s)&&(t=mn(e,a),t===2&&(l=On(e),l!==0&&(a=l,t=rl(e,l))),t===1))throw o=Xi,Aa(e,0),aa(e,a),jt(e,je()),o;switch(e.finishedWork=s,e.finishedLanes=a,t){case 0:case 1:throw Error(r(345));case 2:Ra(e,Tt,Do);break;case 3:if(aa(e,a),(a&130023424)===a&&(t=il+500-je(),10<t)){if(Cs(e,0)!==0)break;if(s=e.suspendedLanes,(s&a)!==a){At(),e.pingedLanes|=e.suspendedLanes&s;break}e.timeoutHandle=gr(Ra.bind(null,e,Tt,Do),t);break}Ra(e,Tt,Do);break;case 4:if(aa(e,a),(a&4194240)===a)break;for(t=e.eventTimes,s=-1;0<a;){var c=31-He(a);l=1<<c,c=t[c],c>s&&(s=c),a&=~l}if(a=s,a=je()-a,a=(120>a?120:480>a?480:1080>a?1080:1920>a?1920:3e3>a?3e3:4320>a?4320:1960*hh(a/1960))-a,10<a){e.timeoutHandle=gr(Ra.bind(null,e,Tt,Do),a);break}Ra(e,Tt,Do);break;case 5:Ra(e,Tt,Do);break;default:throw Error(r(329))}}}return jt(e,je()),e.callbackNode===o?rc.bind(null,e):null}function rl(e,t){var o=Qi;return e.current.memoizedState.isDehydrated&&(Aa(e,t).flags|=256),e=mn(e,t),e!==2&&(t=Tt,Tt=o,t!==null&&ll(t)),e}function ll(e){Tt===null?Tt=e:Tt.push.apply(Tt,e)}function mh(e){for(var t=e;;){if(t.flags&16384){var o=t.updateQueue;if(o!==null&&(o=o.stores,o!==null))for(var a=0;a<o.length;a++){var s=o[a],l=s.getSnapshot;s=s.value;try{if(!Qt(l(),s))return!1}catch{return!1}}}if(o=t.child,t.subtreeFlags&16384&&o!==null)o.return=t,t=o;else{if(t===e)break;for(;t.sibling===null;){if(t.return===null||t.return===e)return!0;t=t.return}t.sibling.return=t.return,t=t.sibling}}return!0}function aa(e,t){for(t&=~al,t&=~dn,e.suspendedLanes|=t,e.pingedLanes&=~t,e=e.expirationTimes;0<t;){var o=31-He(t),a=1<<o;e[o]=-1,t&=~a}}function lc(e){if((Te&6)!==0)throw Error(r(327));li();var t=Cs(e,0);if((t&1)===0)return jt(e,je()),null;var o=mn(e,t);if(e.tag!==0&&o===2){var a=On(e);a!==0&&(t=a,o=rl(e,a))}if(o===1)throw o=Xi,Aa(e,0),aa(e,t),jt(e,je()),o;if(o===6)throw Error(r(345));return e.finishedWork=e.current.alternate,e.finishedLanes=t,Ra(e,Tt,Do),jt(e,je()),null}function dl(e,t){var o=Te;Te|=1;try{return e(t)}finally{Te=o,Te===0&&(ri=je()+500,Bs&&Xo())}}function xa(e){ta!==null&&ta.tag===0&&(Te&6)===0&&li();var t=Te;Te|=1;var o=Vt.transition,a=Oe;try{if(Vt.transition=null,Oe=1,e)return e()}finally{Oe=a,Vt.transition=o,Te=t,(Te&6)===0&&Xo()}}function ul(){Ot=ni.current,Ve(ni)}function Aa(e,t){e.finishedWork=null,e.finishedLanes=0;var o=e.timeoutHandle;if(o!==-1&&(e.timeoutHandle=-1,Kg(o)),rt!==null)for(o=rt.return;o!==null;){var a=o;switch(Sr(a),a.tag){case 1:a=a.type.childContextTypes,a!=null&&Ns();break;case 3:ai(),Ve(It),Ve(bt),jr();break;case 5:Er(a);break;case 4:ai();break;case 13:Ve(Ze);break;case 19:Ve(Ze);break;case 10:xr(a.type._context);break;case 22:case 23:ul()}o=o.return}if(ht=e,rt=e=ia(e.current,null),St=Ot=t,ct=0,Xi=null,al=dn=ka=0,Tt=Qi=null,Pa!==null){for(t=0;t<Pa.length;t++)if(o=Pa[t],a=o.interleaved,a!==null){o.interleaved=null;var s=a.next,l=o.pending;if(l!==null){var c=l.next;l.next=s,a.next=c}o.pending=a}Pa=null}return e}function dc(e,t){do{var o=rt;try{if(kr(),Qs.current=tn,Zs){for(var a=Je.memoizedState;a!==null;){var s=a.queue;s!==null&&(s.pending=null),a=a.next}Zs=!1}if(wa=0,gt=ut=Je=null,Fi=!1,Ki=0,ol.current=null,o===null||o.return===null){ct=1,Xi=t,rt=null;break}e:{var l=e,c=o.return,m=o,S=t;if(t=St,m.flags|=32768,S!==null&&typeof S=="object"&&typeof S.then=="function"){var E=S,_=m,B=_.tag;if((_.mode&1)===0&&(B===0||B===11||B===15)){var M=_.alternate;M?(_.updateQueue=M.updateQueue,_.memoizedState=M.memoizedState,_.lanes=M.lanes):(_.updateQueue=null,_.memoizedState=null)}var $=Uu(c);if($!==null){$.flags&=-257,zu($,c,m,l,t),$.mode&1&&Hu(l,E,t),t=$,S=E;var te=t.updateQueue;if(te===null){var ae=new Set;ae.add(S),t.updateQueue=ae}else te.add(S);break e}else{if((t&1)===0){Hu(l,E,t),cl();break e}S=Error(r(426))}}else if(Ge&&m.mode&1){var st=Uu(c);if(st!==null){(st.flags&65536)===0&&(st.flags|=256),zu(st,c,m,l,t),Cr(ii(S,m));break e}}l=S=ii(S,m),ct!==4&&(ct=2),Qi===null?Qi=[l]:Qi.push(l),l=c;do{switch(l.tag){case 3:l.flags|=65536,t&=-t,l.lanes|=t;var R=Tu(l,S,t);iu(l,R);break e;case 1:m=S;var P=l.type,I=l.stateNode;if((l.flags&128)===0&&(typeof P.getDerivedStateFromError=="function"||I!==null&&typeof I.componentDidCatch=="function"&&(ea===null||!ea.has(I)))){l.flags|=65536,t&=-t,l.lanes|=t;var W=ju(l,m,t);iu(l,W);break e}}l=l.return}while(l!==null)}pc(o)}catch(se){t=se,rt===o&&o!==null&&(rt=o=o.return);continue}break}while(!0)}function uc(){var e=ln.current;return ln.current=tn,e===null?tn:e}function cl(){(ct===0||ct===3||ct===2)&&(ct=4),ht===null||(ka&268435455)===0&&(dn&268435455)===0||aa(ht,St)}function mn(e,t){var o=Te;Te|=2;var a=uc();(ht!==e||St!==t)&&(Do=null,Aa(e,t));do try{fh();break}catch(s){dc(e,s)}while(!0);if(kr(),Te=o,ln.current=a,rt!==null)throw Error(r(261));return ht=null,St=0,ct}function fh(){for(;rt!==null;)cc(rt)}function yh(){for(;rt!==null&&!ma();)cc(rt)}function cc(e){var t=mc(e.alternate,e,Ot);e.memoizedProps=e.pendingProps,t===null?pc(e):rt=t,ol.current=null}function pc(e){var t=e;do{var o=t.alternate;if(e=t.return,(t.flags&32768)===0){if(o=dh(o,t,Ot),o!==null){rt=o;return}}else{if(o=uh(o,t),o!==null){o.flags&=32767,rt=o;return}if(e!==null)e.flags|=32768,e.subtreeFlags=0,e.deletions=null;else{ct=6,rt=null;return}}if(t=t.sibling,t!==null){rt=t;return}rt=t=e}while(t!==null);ct===0&&(ct=5)}function Ra(e,t,o){var a=Oe,s=Vt.transition;try{Vt.transition=null,Oe=1,vh(e,t,o,a)}finally{Vt.transition=s,Oe=a}return null}function vh(e,t,o,a){do li();while(ta!==null);if((Te&6)!==0)throw Error(r(327));o=e.finishedWork;var s=e.finishedLanes;if(o===null)return null;if(e.finishedWork=null,e.finishedLanes=0,o===e.current)throw Error(r(177));e.callbackNode=null,e.callbackPriority=0;var l=o.lanes|o.childLanes;if(Zp(e,l),e===ht&&(rt=ht=null,St=0),(o.subtreeFlags&2064)===0&&(o.flags&2064)===0||cn||(cn=!0,fc(Po,function(){return li(),null})),l=(o.flags&15990)!==0,(o.subtreeFlags&15990)!==0||l){l=Vt.transition,Vt.transition=null;var c=Oe;Oe=1;var m=Te;Te|=4,ol.current=null,ph(e,o),oc(o,e),_g(cr),xs=!!ur,cr=ur=null,e.current=o,gh(o),Xt(),Te=m,Oe=c,Vt.transition=l}else e.current=o;if(cn&&(cn=!1,ta=e,pn=s),l=e.pendingLanes,l===0&&(ea=null),fa(o.stateNode),jt(e,je()),t!==null)for(a=e.onRecoverableError,o=0;o<t.length;o++)s=t[o],a(s.value,{componentStack:s.stack,digest:s.digest});if(un)throw un=!1,e=sl,sl=null,e;return(pn&1)!==0&&e.tag!==0&&li(),l=e.pendingLanes,(l&1)!==0?e===nl?Zi++:(Zi=0,nl=e):Zi=0,Xo(),null}function li(){if(ta!==null){var e=ed(pn),t=Vt.transition,o=Oe;try{if(Vt.transition=null,Oe=16>e?16:e,ta===null)var a=!1;else{if(e=ta,ta=null,pn=0,(Te&6)!==0)throw Error(r(331));var s=Te;for(Te|=4,Z=e.current;Z!==null;){var l=Z,c=l.child;if((Z.flags&16)!==0){var m=l.deletions;if(m!==null){for(var S=0;S<m.length;S++){var E=m[S];for(Z=E;Z!==null;){var _=Z;switch(_.tag){case 0:case 11:case 15:$i(8,_,l)}var B=_.child;if(B!==null)B.return=_,Z=B;else for(;Z!==null;){_=Z;var M=_.sibling,$=_.return;if(Qu(_),_===E){Z=null;break}if(M!==null){M.return=$,Z=M;break}Z=$}}}var te=l.alternate;if(te!==null){var ae=te.child;if(ae!==null){te.child=null;do{var st=ae.sibling;ae.sibling=null,ae=st}while(ae!==null)}}Z=l}}if((l.subtreeFlags&2064)!==0&&c!==null)c.return=l,Z=c;else e:for(;Z!==null;){if(l=Z,(l.flags&2048)!==0)switch(l.tag){case 0:case 11:case 15:$i(9,l,l.return)}var R=l.sibling;if(R!==null){R.return=l.return,Z=R;break e}Z=l.return}}var P=e.current;for(Z=P;Z!==null;){c=Z;var I=c.child;if((c.subtreeFlags&2064)!==0&&I!==null)I.return=c,Z=I;else e:for(c=P;Z!==null;){if(m=Z,(m.flags&2048)!==0)try{switch(m.tag){case 0:case 11:case 15:rn(9,m)}}catch(se){at(m,m.return,se)}if(m===c){Z=null;break e}var W=m.sibling;if(W!==null){W.return=m.return,Z=W;break e}Z=m.return}}if(Te=s,Xo(),yt&&typeof yt.onPostCommitFiberRoot=="function")try{yt.onPostCommitFiberRoot(qe,e)}catch{}a=!0}return a}finally{Oe=o,Vt.transition=t}}return!1}function gc(e,t,o){t=ii(o,t),t=Tu(e,t,1),e=Zo(e,t,1),t=At(),e!==null&&(Ci(e,1,t),jt(e,t))}function at(e,t,o){if(e.tag===3)gc(e,e,o);else for(;t!==null;){if(t.tag===3){gc(t,e,o);break}else if(t.tag===1){var a=t.stateNode;if(typeof t.type.getDerivedStateFromError=="function"||typeof a.componentDidCatch=="function"&&(ea===null||!ea.has(a))){e=ii(o,e),e=ju(t,e,1),t=Zo(t,e,1),e=At(),t!==null&&(Ci(t,1,e),jt(t,e));break}}t=t.return}}function Sh(e,t,o){var a=e.pingCache;a!==null&&a.delete(t),t=At(),e.pingedLanes|=e.suspendedLanes&o,ht===e&&(St&o)===o&&(ct===4||ct===3&&(St&130023424)===St&&500>je()-il?Aa(e,0):al|=o),jt(e,t)}function hc(e,t){t===0&&((e.mode&1)===0?t=1:(t=Ps,Ps<<=1,(Ps&130023424)===0&&(Ps=4194304)));var o=At();e=Ao(e,t),e!==null&&(Ci(e,t,o),jt(e,o))}function bh(e){var t=e.memoizedState,o=0;t!==null&&(o=t.retryLane),hc(e,o)}function Ph(e,t){var o=0;switch(e.tag){case 13:var a=e.stateNode,s=e.memoizedState;s!==null&&(o=s.retryLane);break;case 19:a=e.stateNode;break;default:throw Error(r(314))}a!==null&&a.delete(t),hc(e,o)}var mc;mc=function(e,t,o){if(e!==null)if(e.memoizedProps!==t.pendingProps||It.current)Et=!0;else{if((e.lanes&o)===0&&(t.flags&128)===0)return Et=!1,lh(e,t,o);Et=(e.flags&131072)!==0}else Et=!1,Ge&&(t.flags&1048576)!==0&&Gd(t,Ws,t.index);switch(t.lanes=0,t.tag){case 2:var a=t.type;sn(e,t),e=t.pendingProps;var s=Xa(t,bt.current);oi(t,o),s=zr(null,t,a,e,s,o);var l=Lr();return t.flags|=1,typeof s=="object"&&s!==null&&typeof s.render=="function"&&s.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,Dt(a)?(l=!0,Os(t)):l=!1,t.memoizedState=s.state!==null&&s.state!==void 0?s.state:null,Ir(t),s.updater=on,t.stateNode=s,s._reactInternals=t,qr(t,a,e,o),t=Yr(null,t,a,!0,l,o)):(t.tag=0,Ge&&l&&vr(t),xt(null,t,s,o),t=t.child),t;case 16:a=t.elementType;e:{switch(sn(e,t),e=t.pendingProps,s=a._init,a=s(a._payload),t.type=a,s=t.tag=wh(a),e=Jt(a,e),s){case 0:t=Kr(null,t,a,e,o);break e;case 1:t=Bu(null,t,a,e,o);break e;case 11:t=Lu(null,t,a,e,o);break e;case 14:t=Mu(null,t,a,Jt(a.type,e),o);break e}throw Error(r(306,a,""))}return t;case 0:return a=t.type,s=t.pendingProps,s=t.elementType===a?s:Jt(a,s),Kr(e,t,a,s,o);case 1:return a=t.type,s=t.pendingProps,s=t.elementType===a?s:Jt(a,s),Bu(e,t,a,s,o);case 3:e:{if(qu(t),e===null)throw Error(r(387));a=t.pendingProps,l=t.memoizedState,s=l.element,au(e,t),$s(t,a,null,o);var c=t.memoizedState;if(a=c.element,l.isDehydrated)if(l={element:a,isDehydrated:!1,cache:c.cache,pendingSuspenseBoundaries:c.pendingSuspenseBoundaries,transitions:c.transitions},t.updateQueue.baseState=l,t.memoizedState=l,t.flags&256){s=ii(Error(r(423)),t),t=Wu(e,t,a,o,s);break e}else if(a!==s){s=ii(Error(r(424)),t),t=Wu(e,t,a,o,s);break e}else for(Nt=Vo(t.stateNode.containerInfo.firstChild),_t=t,Ge=!0,Zt=null,o=tu(t,null,a,o),t.child=o;o;)o.flags=o.flags&-3|4096,o=o.sibling;else{if(Ja(),a===s){t=Io(e,t,o);break e}xt(e,t,a,o)}t=t.child}return t;case 5:return nu(t),e===null&&Pr(t),a=t.type,s=t.pendingProps,l=e!==null?e.memoizedProps:null,c=s.children,pr(a,s)?c=null:l!==null&&pr(a,l)&&(t.flags|=32),Ou(e,t),xt(e,t,c,o),t.child;case 6:return e===null&&Pr(t),null;case 13:return Fu(e,t,o);case 4:return Dr(t,t.stateNode.containerInfo),a=t.pendingProps,e===null?t.child=ei(t,null,a,o):xt(e,t,a,o),t.child;case 11:return a=t.type,s=t.pendingProps,s=t.elementType===a?s:Jt(a,s),Lu(e,t,a,s,o);case 7:return xt(e,t,t.pendingProps,o),t.child;case 8:return xt(e,t,t.pendingProps.children,o),t.child;case 12:return xt(e,t,t.pendingProps.children,o),t.child;case 10:e:{if(a=t.type._context,s=t.pendingProps,l=t.memoizedProps,c=s.value,Fe(Ys,a._currentValue),a._currentValue=c,l!==null)if(Qt(l.value,c)){if(l.children===s.children&&!It.current){t=Io(e,t,o);break e}}else for(l=t.child,l!==null&&(l.return=t);l!==null;){var m=l.dependencies;if(m!==null){c=l.child;for(var S=m.firstContext;S!==null;){if(S.context===a){if(l.tag===1){S=Ro(-1,o&-o),S.tag=2;var E=l.updateQueue;if(E!==null){E=E.shared;var _=E.pending;_===null?S.next=S:(S.next=_.next,_.next=S),E.pending=S}}l.lanes|=o,S=l.alternate,S!==null&&(S.lanes|=o),Ar(l.return,o,t),m.lanes|=o;break}S=S.next}}else if(l.tag===10)c=l.type===t.type?null:l.child;else if(l.tag===18){if(c=l.return,c===null)throw Error(r(341));c.lanes|=o,m=c.alternate,m!==null&&(m.lanes|=o),Ar(c,o,t),c=l.sibling}else c=l.child;if(c!==null)c.return=l;else for(c=l;c!==null;){if(c===t){c=null;break}if(l=c.sibling,l!==null){l.return=c.return,c=l;break}c=c.return}l=c}xt(e,t,s.children,o),t=t.child}return t;case 9:return s=t.type,a=t.pendingProps.children,oi(t,o),s=Kt(s),a=a(s),t.flags|=1,xt(e,t,a,o),t.child;case 14:return a=t.type,s=Jt(a,t.pendingProps),s=Jt(a.type,s),Mu(e,t,a,s,o);case 15:return _u(e,t,t.type,t.pendingProps,o);case 17:return a=t.type,s=t.pendingProps,s=t.elementType===a?s:Jt(a,s),sn(e,t),t.tag=1,Dt(a)?(e=!0,Os(t)):e=!1,oi(t,o),Du(t,a,s),qr(t,a,s,o),Yr(null,t,a,!0,e,o);case 19:return Yu(e,t,o);case 22:return Nu(e,t,o)}throw Error(r(156,t.tag))};function fc(e,t){return Ke(e,t)}function Ch(e,t,o,a){this.tag=e,this.key=o,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=a,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function Gt(e,t,o,a){return new Ch(e,t,o,a)}function pl(e){return e=e.prototype,!(!e||!e.isReactComponent)}function wh(e){if(typeof e=="function")return pl(e)?1:0;if(e!=null){if(e=e.$$typeof,e===Pe)return 11;if(e===Qe)return 14}return 2}function ia(e,t){var o=e.alternate;return o===null?(o=Gt(e.tag,t,e.key,e.mode),o.elementType=e.elementType,o.type=e.type,o.stateNode=e.stateNode,o.alternate=e,e.alternate=o):(o.pendingProps=t,o.type=e.type,o.flags=0,o.subtreeFlags=0,o.deletions=null),o.flags=e.flags&14680064,o.childLanes=e.childLanes,o.lanes=e.lanes,o.child=e.child,o.memoizedProps=e.memoizedProps,o.memoizedState=e.memoizedState,o.updateQueue=e.updateQueue,t=e.dependencies,o.dependencies=t===null?null:{lanes:t.lanes,firstContext:t.firstContext},o.sibling=e.sibling,o.index=e.index,o.ref=e.ref,o}function fn(e,t,o,a,s,l){var c=2;if(a=e,typeof e=="function")pl(e)&&(c=1);else if(typeof e=="string")c=5;else e:switch(e){case T:return Ia(o.children,s,l,t);case G:c=8,s|=8;break;case Se:return e=Gt(12,o,t,s|2),e.elementType=Se,e.lanes=l,e;case Le:return e=Gt(13,o,t,s),e.elementType=Le,e.lanes=l,e;case Ce:return e=Gt(19,o,t,s),e.elementType=Ce,e.lanes=l,e;case Me:return yn(o,s,l,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case re:c=10;break e;case ze:c=9;break e;case Pe:c=11;break e;case Qe:c=14;break e;case tt:c=16,a=null;break e}throw Error(r(130,e==null?e:typeof e,""))}return t=Gt(c,o,t,s),t.elementType=e,t.type=a,t.lanes=l,t}function Ia(e,t,o,a){return e=Gt(7,e,a,t),e.lanes=o,e}function yn(e,t,o,a){return e=Gt(22,e,a,t),e.elementType=Me,e.lanes=o,e.stateNode={isHidden:!1},e}function gl(e,t,o){return e=Gt(6,e,null,t),e.lanes=o,e}function hl(e,t,o){return t=Gt(4,e.children!==null?e.children:[],e.key,t),t.lanes=o,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function kh(e,t,o,a,s){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=Bn(0),this.expirationTimes=Bn(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=Bn(0),this.identifierPrefix=a,this.onRecoverableError=s,this.mutableSourceEagerHydrationData=null}function ml(e,t,o,a,s,l,c,m,S){return e=new kh(e,t,o,m,S),t===1?(t=1,l===!0&&(t|=8)):t=0,l=Gt(3,null,null,t),e.current=l,l.stateNode=e,l.memoizedState={element:a,isDehydrated:o,cache:null,transitions:null,pendingSuspenseBoundaries:null},Ir(l),e}function xh(e,t,o){var a=3<arguments.length&&arguments[3]!==void 0?arguments[3]:null;return{$$typeof:De,key:a==null?null:""+a,children:e,containerInfo:t,implementation:o}}function yc(e){if(!e)return $o;e=e._reactInternals;e:{if(J(e)!==e||e.tag!==1)throw Error(r(170));var t=e;do{switch(t.tag){case 3:t=t.stateNode.context;break e;case 1:if(Dt(t.type)){t=t.stateNode.__reactInternalMemoizedMergedChildContext;break e}}t=t.return}while(t!==null);throw Error(r(171))}if(e.tag===1){var o=e.type;if(Dt(o))return Kd(e,o,t)}return t}function vc(e,t,o,a,s,l,c,m,S){return e=ml(o,a,!0,e,s,l,c,m,S),e.context=yc(null),o=e.current,a=At(),s=oa(o),l=Ro(a,s),l.callback=t??null,Zo(o,l,s),e.current.lanes=s,Ci(e,s,a),jt(e,a),e}function vn(e,t,o,a){var s=t.current,l=At(),c=oa(s);return o=yc(o),t.context===null?t.context=o:t.pendingContext=o,t=Ro(l,c),t.payload={element:e},a=a===void 0?null:a,a!==null&&(t.callback=a),e=Zo(s,t,c),e!==null&&(oo(e,s,c,l),Gs(e,s,c)),c}function Sn(e){if(e=e.current,!e.child)return null;switch(e.child.tag){case 5:return e.child.stateNode;default:return e.child.stateNode}}function Sc(e,t){if(e=e.memoizedState,e!==null&&e.dehydrated!==null){var o=e.retryLane;e.retryLane=o!==0&&o<t?o:t}}function fl(e,t){Sc(e,t),(e=e.alternate)&&Sc(e,t)}function Ah(){return null}var bc=typeof reportError=="function"?reportError:function(e){console.error(e)};function yl(e){this._internalRoot=e}bn.prototype.render=yl.prototype.render=function(e){var t=this._internalRoot;if(t===null)throw Error(r(409));vn(e,t,null,null)},bn.prototype.unmount=yl.prototype.unmount=function(){var e=this._internalRoot;if(e!==null){this._internalRoot=null;var t=e.containerInfo;xa(function(){vn(null,e,null,null)}),t[Co]=null}};function bn(e){this._internalRoot=e}bn.prototype.unstable_scheduleHydration=function(e){if(e){var t=ad();e={blockedOn:null,target:e,priority:t};for(var o=0;o<Fo.length&&t!==0&&t<Fo[o].priority;o++);Fo.splice(o,0,e),o===0&&nd(e)}};function vl(e){return!(!e||e.nodeType!==1&&e.nodeType!==9&&e.nodeType!==11)}function Pn(e){return!(!e||e.nodeType!==1&&e.nodeType!==9&&e.nodeType!==11&&(e.nodeType!==8||e.nodeValue!==" react-mount-point-unstable "))}function Pc(){}function Rh(e,t,o,a,s){if(s){if(typeof a=="function"){var l=a;a=function(){var E=Sn(c);l.call(E)}}var c=vc(t,a,e,0,null,!1,!1,"",Pc);return e._reactRootContainer=c,e[Co]=c.current,Li(e.nodeType===8?e.parentNode:e),xa(),c}for(;s=e.lastChild;)e.removeChild(s);if(typeof a=="function"){var m=a;a=function(){var E=Sn(S);m.call(E)}}var S=ml(e,0,!1,null,null,!1,!1,"",Pc);return e._reactRootContainer=S,e[Co]=S.current,Li(e.nodeType===8?e.parentNode:e),xa(function(){vn(t,S,o,a)}),S}function Cn(e,t,o,a,s){var l=o._reactRootContainer;if(l){var c=l;if(typeof s=="function"){var m=s;s=function(){var S=Sn(c);m.call(S)}}vn(t,c,e,s)}else c=Rh(o,t,e,s,a);return Sn(c)}td=function(e){switch(e.tag){case 3:var t=e.stateNode;if(t.current.memoizedState.isDehydrated){var o=Pi(t.pendingLanes);o!==0&&(qn(t,o|1),jt(t,je()),(Te&6)===0&&(ri=je()+500,Xo()))}break;case 13:xa(function(){var a=Ao(e,1);if(a!==null){var s=At();oo(a,e,1,s)}}),fl(e,1)}},Wn=function(e){if(e.tag===13){var t=Ao(e,134217728);if(t!==null){var o=At();oo(t,e,134217728,o)}fl(e,134217728)}},od=function(e){if(e.tag===13){var t=oa(e),o=Ao(e,t);if(o!==null){var a=At();oo(o,e,t,a)}fl(e,t)}},ad=function(){return Oe},id=function(e,t){var o=Oe;try{return Oe=e,t()}finally{Oe=o}},Na=function(e,t,o){switch(t){case"input":if(ua(e,o),t=o.name,o.type==="radio"&&t!=null){for(o=e;o.parentNode;)o=o.parentNode;for(o=o.querySelectorAll("input[name="+JSON.stringify(""+t)+'][type="radio"]'),t=0;t<o.length;t++){var a=o[t];if(a!==e&&a.form===e.form){var s=_s(a);if(!s)throw Error(r(90));it(a),ua(a,s)}}}break;case"textarea":ro(e,o);break;case"select":t=o.value,t!=null&&zo(e,!!o.multiple,t,!1)}},Si=dl,ga=xa;var Ih={usingClientEntryPoint:!1,Events:[Ni,Ga,_s,vi,ys,dl]},Ji={findFiberByHostInstance:ya,bundleType:0,version:"18.3.1",rendererPackageName:"react-dom"},Dh={bundleType:Ji.bundleType,version:Ji.version,rendererPackageName:Ji.rendererPackageName,rendererConfig:Ji.rendererConfig,overrideHookState:null,overrideHookStateDeletePath:null,overrideHookStateRenamePath:null,overrideProps:null,overridePropsDeletePath:null,overridePropsRenamePath:null,setErrorHandler:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:Y.ReactCurrentDispatcher,findHostInstanceByFiber:function(e){return e=Ne(e),e===null?null:e.stateNode},findFiberByHostInstance:Ji.findFiberByHostInstance||Ah,findHostInstancesForRefresh:null,scheduleRefresh:null,scheduleRoot:null,setRefreshHandler:null,getCurrentFiber:null,reconcilerVersion:"18.3.1-next-f1338f8080-20240426"};if(typeof __REACT_DEVTOOLS_GLOBAL_HOOK__<"u"){var wn=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(!wn.isDisabled&&wn.supportsFiber)try{qe=wn.inject(Dh),yt=wn}catch{}}return Ht.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=Ih,Ht.createPortal=function(e,t){var o=2<arguments.length&&arguments[2]!==void 0?arguments[2]:null;if(!vl(t))throw Error(r(200));return xh(e,t,null,o)},Ht.createRoot=function(e,t){if(!vl(e))throw Error(r(299));var o=!1,a="",s=bc;return t!=null&&(t.unstable_strictMode===!0&&(o=!0),t.identifierPrefix!==void 0&&(a=t.identifierPrefix),t.onRecoverableError!==void 0&&(s=t.onRecoverableError)),t=ml(e,1,!1,null,null,o,!1,a,s),e[Co]=t.current,Li(e.nodeType===8?e.parentNode:e),new yl(t)},Ht.findDOMNode=function(e){if(e==null)return null;if(e.nodeType===1)return e;var t=e._reactInternals;if(t===void 0)throw typeof e.render=="function"?Error(r(188)):(e=Object.keys(e).join(","),Error(r(268,e)));return e=Ne(t),e=e===null?null:e.stateNode,e},Ht.flushSync=function(e){return xa(e)},Ht.hydrate=function(e,t,o){if(!Pn(t))throw Error(r(200));return Cn(null,e,t,!0,o)},Ht.hydrateRoot=function(e,t,o){if(!vl(e))throw Error(r(405));var a=o!=null&&o.hydratedSources||null,s=!1,l="",c=bc;if(o!=null&&(o.unstable_strictMode===!0&&(s=!0),o.identifierPrefix!==void 0&&(l=o.identifierPrefix),o.onRecoverableError!==void 0&&(c=o.onRecoverableError)),t=vc(t,null,e,1,o??null,s,!1,l,c),e[Co]=t.current,Li(e),a)for(e=0;e<a.length;e++)o=a[e],s=o._getVersion,s=s(o._source),t.mutableSourceEagerHydrationData==null?t.mutableSourceEagerHydrationData=[o,s]:t.mutableSourceEagerHydrationData.push(o,s);return new bn(t)},Ht.render=function(e,t,o){if(!Pn(t))throw Error(r(200));return Cn(null,e,t,!1,o)},Ht.unmountComponentAtNode=function(e){if(!Pn(e))throw Error(r(40));return e._reactRootContainer?(xa(function(){Cn(null,null,e,!1,function(){e._reactRootContainer=null,e[Co]=null})}),!0):!1},Ht.unstable_batchedUpdates=dl,Ht.unstable_renderSubtreeIntoContainer=function(e,t,o,a){if(!Pn(o))throw Error(r(200));if(e==null||e._reactInternals===void 0)throw Error(r(38));return Cn(e,t,o,!1,a)},Ht.version="18.3.1-next-f1338f8080-20240426",Ht}var Dc;function mp(){if(Dc)return Pl.exports;Dc=1;function i(){if(!(typeof __REACT_DEVTOOLS_GLOBAL_HOOK__>"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(i)}catch(n){console.error(n)}}return i(),Pl.exports=_h(),Pl.exports}var Ec;function Nh(){if(Ec)return kn;Ec=1;var i=mp();return kn.createRoot=i.createRoot,kn.hydrateRoot=i.hydrateRoot,kn}var Oh=Nh(),A=Wl();const Bh=hp(A),qh=gp({__proto__:null,default:Bh},[A]);var Un=mp();const Wh=hp(Un),Fh=gp({__proto__:null,default:Wh},[Un]);/**
42
+ * @remix-run/router v1.23.2
43
+ *
44
+ * Copyright (c) Remix Software Inc.
45
+ *
46
+ * This source code is licensed under the MIT license found in the
47
+ * LICENSE.md file in the root directory of this source tree.
48
+ *
49
+ * @license MIT
50
+ */function $e(){return $e=Object.assign?Object.assign.bind():function(i){for(var n=1;n<arguments.length;n++){var r=arguments[n];for(var d in r)Object.prototype.hasOwnProperty.call(r,d)&&(i[d]=r[d])}return i},$e.apply(this,arguments)}var lt;(function(i){i.Pop="POP",i.Push="PUSH",i.Replace="REPLACE"})(lt||(lt={}));const Tc="popstate";function Kh(i){i===void 0&&(i={});function n(u,p){let{pathname:g="/",search:f="",hash:h=""}=Ho(u.location.hash.substr(1));return!g.startsWith("/")&&!g.startsWith(".")&&(g="/"+g),ns("",{pathname:g,search:f,hash:h},p.state&&p.state.usr||null,p.state&&p.state.key||"default")}function r(u,p){let g=u.document.querySelector("base"),f="";if(g&&g.getAttribute("href")){let h=u.location.href,y=h.indexOf("#");f=y===-1?h:h.slice(0,y)}return f+"#"+(typeof p=="string"?p:za(p))}function d(u,p){la(u.pathname.charAt(0)==="/","relative pathnames are not supported in hash history.push("+JSON.stringify(p)+")")}return Vh(n,r,d,i)}function ke(i,n){if(i===!1||i===null||typeof i>"u")throw new Error(n)}function la(i,n){if(!i){typeof console<"u"&&console.warn(n);try{throw new Error(n)}catch{}}}function Yh(){return Math.random().toString(36).substr(2,8)}function jc(i,n){return{usr:i.state,key:i.key,idx:n}}function ns(i,n,r,d){return r===void 0&&(r=null),$e({pathname:typeof i=="string"?i:i.pathname,search:"",hash:""},typeof n=="string"?Ho(n):n,{state:r,key:n&&n.key||d||Yh()})}function za(i){let{pathname:n="/",search:r="",hash:d=""}=i;return r&&r!=="?"&&(n+=r.charAt(0)==="?"?r:"?"+r),d&&d!=="#"&&(n+=d.charAt(0)==="#"?d:"#"+d),n}function Ho(i){let n={};if(i){let r=i.indexOf("#");r>=0&&(n.hash=i.substr(r),i=i.substr(0,r));let d=i.indexOf("?");d>=0&&(n.search=i.substr(d),i=i.substr(0,d)),i&&(n.pathname=i)}return n}function Vh(i,n,r,d){d===void 0&&(d={});let{window:u=document.defaultView,v5Compat:p=!1}=d,g=u.history,f=lt.Pop,h=null,y=C();y==null&&(y=0,g.replaceState($e({},g.state,{idx:y}),""));function C(){return(g.state||{idx:null}).idx}function b(){f=lt.Pop;let N=C(),ie=N==null?null:N-y;y=N,h&&h({action:f,location:z.location,delta:ie})}function D(N,ie){f=lt.Push;let F=ns(z.location,N,ie);r&&r(F,N),y=C()+1;let X=jc(F,y),Y=z.createHref(F);try{g.pushState(X,"",Y)}catch(pe){if(pe instanceof DOMException&&pe.name==="DataCloneError")throw pe;u.location.assign(Y)}p&&h&&h({action:f,location:z.location,delta:1})}function H(N,ie){f=lt.Replace;let F=ns(z.location,N,ie);r&&r(F,N),y=C();let X=jc(F,y),Y=z.createHref(F);g.replaceState(X,"",Y),p&&h&&h({action:f,location:z.location,delta:0})}function O(N){let ie=u.location.origin!=="null"?u.location.origin:u.location.href,F=typeof N=="string"?N:za(N);return F=F.replace(/ $/,"%20"),ke(ie,"No window.location.(origin|href) available to create URL for href: "+F),new URL(F,ie)}let z={get action(){return f},get location(){return i(u,g)},listen(N){if(h)throw new Error("A history only accepts one active listener");return u.addEventListener(Tc,b),h=N,()=>{u.removeEventListener(Tc,b),h=null}},createHref(N){return n(u,N)},createURL:O,encodeLocation(N){let ie=O(N);return{pathname:ie.pathname,search:ie.search,hash:ie.hash}},push:D,replace:H,go(N){return g.go(N)}};return z}var Be;(function(i){i.data="data",i.deferred="deferred",i.redirect="redirect",i.error="error"})(Be||(Be={}));const Gh=new Set(["lazy","caseSensitive","path","id","index","children"]);function $h(i){return i.index===!0}function En(i,n,r,d){return r===void 0&&(r=[]),d===void 0&&(d={}),i.map((u,p)=>{let g=[...r,String(p)],f=typeof u.id=="string"?u.id:g.join("-");if(ke(u.index!==!0||!u.children,"Cannot specify children on an index route"),ke(!d[f],'Found a route id collision on id "'+f+`". Route id's must be globally unique within Data Router usages`),$h(u)){let h=$e({},u,n(u),{id:f});return d[f]=h,h}else{let h=$e({},u,n(u),{id:f,children:void 0});return d[f]=h,u.children&&(h.children=En(u.children,n,g,d)),h}})}function Ea(i,n,r){return r===void 0&&(r="/"),Rn(i,n,r,!1)}function Rn(i,n,r,d){let u=typeof n=="string"?Ho(n):n,p=jo(u.pathname||"/",r);if(p==null)return null;let g=fp(i);Qh(g);let f=null;for(let h=0;f==null&&h<g.length;++h){let y=lm(p);f=nm(g[h],y,d)}return f}function Xh(i,n){let{route:r,pathname:d,params:u}=i;return{id:r.id,pathname:d,params:u,data:n[r.id],handle:r.handle}}function fp(i,n,r,d){n===void 0&&(n=[]),r===void 0&&(r=[]),d===void 0&&(d="");let u=(p,g,f)=>{let h={relativePath:f===void 0?p.path||"":f,caseSensitive:p.caseSensitive===!0,childrenIndex:g,route:p};h.relativePath.startsWith("/")&&(ke(h.relativePath.startsWith(d),'Absolute route path "'+h.relativePath+'" nested under path '+('"'+d+'" is not valid. An absolute child route path ')+"must start with the combined path of all its parent routes."),h.relativePath=h.relativePath.slice(d.length));let y=To([d,h.relativePath]),C=r.concat(h);p.children&&p.children.length>0&&(ke(p.index!==!0,"Index routes must not have child routes. Please remove "+('all child routes from route path "'+y+'".')),fp(p.children,n,C,y)),!(p.path==null&&!p.index)&&n.push({path:y,score:im(y,p.index),routesMeta:C})};return i.forEach((p,g)=>{var f;if(p.path===""||!((f=p.path)!=null&&f.includes("?")))u(p,g);else for(let h of yp(p.path))u(p,g,h)}),n}function yp(i){let n=i.split("/");if(n.length===0)return[];let[r,...d]=n,u=r.endsWith("?"),p=r.replace(/\?$/,"");if(d.length===0)return u?[p,""]:[p];let g=yp(d.join("/")),f=[];return f.push(...g.map(h=>h===""?p:[p,h].join("/"))),u&&f.push(...g),f.map(h=>i.startsWith("/")&&h===""?"/":h)}function Qh(i){i.sort((n,r)=>n.score!==r.score?r.score-n.score:sm(n.routesMeta.map(d=>d.childrenIndex),r.routesMeta.map(d=>d.childrenIndex)))}const Zh=/^:[\w-]+$/,Jh=3,em=2,tm=1,om=10,am=-2,Hc=i=>i==="*";function im(i,n){let r=i.split("/"),d=r.length;return r.some(Hc)&&(d+=am),n&&(d+=em),r.filter(u=>!Hc(u)).reduce((u,p)=>u+(Zh.test(p)?Jh:p===""?tm:om),d)}function sm(i,n){return i.length===n.length&&i.slice(0,-1).every((d,u)=>d===n[u])?i[i.length-1]-n[n.length-1]:0}function nm(i,n,r){r===void 0&&(r=!1);let{routesMeta:d}=i,u={},p="/",g=[];for(let f=0;f<d.length;++f){let h=d[f],y=f===d.length-1,C=p==="/"?n:n.slice(p.length)||"/",b=Tn({path:h.relativePath,caseSensitive:h.caseSensitive,end:y},C),D=h.route;if(!b&&y&&r&&!d[d.length-1].route.index&&(b=Tn({path:h.relativePath,caseSensitive:h.caseSensitive,end:!1},C)),!b)return null;Object.assign(u,b.params),g.push({params:u,pathname:To([p,b.pathname]),pathnameBase:pm(To([p,b.pathnameBase])),route:D}),b.pathnameBase!=="/"&&(p=To([p,b.pathnameBase]))}return g}function Tn(i,n){typeof i=="string"&&(i={path:i,caseSensitive:!1,end:!0});let[r,d]=rm(i.path,i.caseSensitive,i.end),u=n.match(r);if(!u)return null;let p=u[0],g=p.replace(/(.)\/+$/,"$1"),f=u.slice(1);return{params:d.reduce((y,C,b)=>{let{paramName:D,isOptional:H}=C;if(D==="*"){let z=f[b]||"";g=p.slice(0,p.length-z.length).replace(/(.)\/+$/,"$1")}const O=f[b];return H&&!O?y[D]=void 0:y[D]=(O||"").replace(/%2F/g,"/"),y},{}),pathname:p,pathnameBase:g,pattern:i}}function rm(i,n,r){n===void 0&&(n=!1),r===void 0&&(r=!0),la(i==="*"||!i.endsWith("*")||i.endsWith("/*"),'Route path "'+i+'" will be treated as if it were '+('"'+i.replace(/\*$/,"/*")+'" because the `*` character must ')+"always follow a `/` in the pattern. To get rid of this warning, "+('please change the route path to "'+i.replace(/\*$/,"/*")+'".'));let d=[],u="^"+i.replace(/\/*\*?$/,"").replace(/^\/*/,"/").replace(/[\\.*+^${}|()[\]]/g,"\\$&").replace(/\/:([\w-]+)(\?)?/g,(g,f,h)=>(d.push({paramName:f,isOptional:h!=null}),h?"/?([^\\/]+)?":"/([^\\/]+)"));return i.endsWith("*")?(d.push({paramName:"*"}),u+=i==="*"||i==="/*"?"(.*)$":"(?:\\/(.+)|\\/*)$"):r?u+="\\/*$":i!==""&&i!=="/"&&(u+="(?:(?=\\/|$))"),[new RegExp(u,n?void 0:"i"),d]}function lm(i){try{return i.split("/").map(n=>decodeURIComponent(n).replace(/\//g,"%2F")).join("/")}catch(n){return la(!1,'The URL path "'+i+'" could not be decoded because it is is a malformed URL segment. This is probably due to a bad percent '+("encoding ("+n+").")),i}}function jo(i,n){if(n==="/")return i;if(!i.toLowerCase().startsWith(n.toLowerCase()))return null;let r=n.endsWith("/")?n.length-1:n.length,d=i.charAt(r);return d&&d!=="/"?null:i.slice(r)||"/"}const dm=/^(?:[a-z][a-z0-9+.-]*:|\/\/)/i,um=i=>dm.test(i);function cm(i,n){n===void 0&&(n="/");let{pathname:r,search:d="",hash:u=""}=typeof i=="string"?Ho(i):i,p;if(r)if(um(r))p=r;else{if(r.includes("//")){let g=r;r=r.replace(/\/\/+/g,"/"),la(!1,"Pathnames cannot have embedded double slashes - normalizing "+(g+" -> "+r))}r.startsWith("/")?p=Uc(r.substring(1),"/"):p=Uc(r,n)}else p=n;return{pathname:p,search:gm(d),hash:hm(u)}}function Uc(i,n){let r=n.replace(/\/+$/,"").split("/");return i.split("/").forEach(u=>{u===".."?r.length>1&&r.pop():u!=="."&&r.push(u)}),r.length>1?r.join("/"):"/"}function kl(i,n,r,d){return"Cannot include a '"+i+"' character in a manually specified "+("`to."+n+"` field ["+JSON.stringify(d)+"]. Please separate it out to the ")+("`to."+r+"` field. Alternatively you may provide the full path as ")+'a string in <Link to="..."> and the router will parse it for you.'}function vp(i){return i.filter((n,r)=>r===0||n.route.path&&n.route.path.length>0)}function Fl(i,n){let r=vp(i);return n?r.map((d,u)=>u===r.length-1?d.pathname:d.pathnameBase):r.map(d=>d.pathnameBase)}function Kl(i,n,r,d){d===void 0&&(d=!1);let u;typeof i=="string"?u=Ho(i):(u=$e({},i),ke(!u.pathname||!u.pathname.includes("?"),kl("?","pathname","search",u)),ke(!u.pathname||!u.pathname.includes("#"),kl("#","pathname","hash",u)),ke(!u.search||!u.search.includes("#"),kl("#","search","hash",u)));let p=i===""||u.pathname==="",g=p?"/":u.pathname,f;if(g==null)f=r;else{let b=n.length-1;if(!d&&g.startsWith("..")){let D=g.split("/");for(;D[0]==="..";)D.shift(),b-=1;u.pathname=D.join("/")}f=b>=0?n[b]:"/"}let h=cm(u,f),y=g&&g!=="/"&&g.endsWith("/"),C=(p||g===".")&&r.endsWith("/");return!h.pathname.endsWith("/")&&(y||C)&&(h.pathname+="/"),h}const To=i=>i.join("/").replace(/\/\/+/g,"/"),pm=i=>i.replace(/\/+$/,"").replace(/^\/*/,"/"),gm=i=>!i||i==="?"?"":i.startsWith("?")?i:"?"+i,hm=i=>!i||i==="#"?"":i.startsWith("#")?i:"#"+i;class jn{constructor(n,r,d,u){u===void 0&&(u=!1),this.status=n,this.statusText=r||"",this.internal=u,d instanceof Error?(this.data=d.toString(),this.error=d):this.data=d}}function rs(i){return i!=null&&typeof i.status=="number"&&typeof i.statusText=="string"&&typeof i.internal=="boolean"&&"data"in i}const Sp=["post","put","patch","delete"],mm=new Set(Sp),fm=["get",...Sp],ym=new Set(fm),vm=new Set([301,302,303,307,308]),Sm=new Set([307,308]),xl={state:"idle",location:void 0,formMethod:void 0,formAction:void 0,formEncType:void 0,formData:void 0,json:void 0,text:void 0},bm={state:"idle",data:void 0,formMethod:void 0,formAction:void 0,formEncType:void 0,formData:void 0,json:void 0,text:void 0},ts={state:"unblocked",proceed:void 0,reset:void 0,location:void 0},Yl=/^(?:[a-z][a-z0-9+.-]*:|\/\/)/i,Pm=i=>({hasErrorBoundary:!!i.hasErrorBoundary}),bp="remix-router-transitions";function Cm(i){const n=i.window?i.window:typeof window<"u"?window:void 0,r=typeof n<"u"&&typeof n.document<"u"&&typeof n.document.createElement<"u",d=!r;ke(i.routes.length>0,"You must provide a non-empty routes array to createRouter");let u;if(i.mapRouteProperties)u=i.mapRouteProperties;else if(i.detectErrorBoundary){let v=i.detectErrorBoundary;u=k=>({hasErrorBoundary:v(k)})}else u=Pm;let p={},g=En(i.routes,u,void 0,p),f,h=i.basename||"/",y=i.dataStrategy||Am,C=i.patchRoutesOnNavigation,b=$e({v7_fetcherPersist:!1,v7_normalizeFormMethod:!1,v7_partialHydration:!1,v7_prependBasename:!1,v7_relativeSplatPath:!1,v7_skipActionErrorRevalidation:!1},i.future),D=null,H=new Set,O=null,z=null,N=null,ie=i.hydrationData!=null,F=Ea(g,i.history.location,h),X=!1,Y=null;if(F==null&&!C){let v=Ut(404,{pathname:i.history.location.pathname}),{matches:k,route:j}=Kc(g);F=k,Y={[j.id]:v}}F&&!i.hydrationData&&ga(F,g,i.history.location.pathname).active&&(F=null);let pe;if(F)if(F.some(v=>v.route.lazy))pe=!1;else if(!F.some(v=>v.route.loader))pe=!0;else if(b.v7_partialHydration){let v=i.hydrationData?i.hydrationData.loaderData:null,k=i.hydrationData?i.hydrationData.errors:null;if(k){let j=F.findIndex(L=>k[L.route.id]!==void 0);pe=F.slice(0,j+1).every(L=>!Ll(L.route,v,k))}else pe=F.every(j=>!Ll(j.route,v,k))}else pe=i.hydrationData!=null;else if(pe=!1,F=[],b.v7_partialHydration){let v=ga(null,g,i.history.location.pathname);v.active&&v.matches&&(X=!0,F=v.matches)}let De,T={historyAction:i.history.action,location:i.history.location,matches:F,initialized:pe,navigation:xl,restoreScrollPosition:i.hydrationData!=null?!1:null,preventScrollReset:!1,revalidation:"idle",loaderData:i.hydrationData&&i.hydrationData.loaderData||{},actionData:i.hydrationData&&i.hydrationData.actionData||null,errors:i.hydrationData&&i.hydrationData.errors||Y,fetchers:new Map,blockers:new Map},G=lt.Pop,Se=!1,re,ze=!1,Pe=new Map,Le=null,Ce=!1,Qe=!1,tt=[],Me=new Set,q=new Map,le=0,V=-1,w=new Map,U=new Set,ge=new Map,ye=new Map,me=new Set,be=new Map,Ae=new Map,Re;function _e(){if(D=i.history.listen(v=>{let{action:k,location:j,delta:L}=v;if(Re){Re(),Re=void 0;return}la(Ae.size===0||L!=null,"You are trying to use a blocker on a POP navigation to a location that was not created by @remix-run/router. This will fail silently in production. This can happen if you are navigating outside the router via `window.history.pushState`/`window.location.hash` instead of using router navigation APIs. This can also happen if you are using createHashRouter and the user manually changes the URL.");let K=Na({currentLocation:T.location,nextLocation:j,historyAction:k});if(K&&L!=null){let ne=new Promise(ce=>{Re=ce});i.history.go(L*-1),_o(K,{state:"blocked",location:j,proceed(){_o(K,{state:"proceeding",proceed:void 0,reset:void 0,location:j}),ne.then(()=>i.history.go(L))},reset(){let ce=new Map(T.blockers);ce.set(K,ts),it({blockers:ce})}});return}return Rt(k,j)}),r){Om(n,Pe);let v=()=>Bm(n,Pe);n.addEventListener("pagehide",v),Le=()=>n.removeEventListener("pagehide",v)}return T.initialized||Rt(lt.Pop,T.location,{initialHydration:!0}),De}function pt(){D&&D(),Le&&Le(),H.clear(),re&&re.abort(),T.fetchers.forEach((v,k)=>lo(k)),T.blockers.forEach((v,k)=>_a(k))}function vo(v){return H.add(v),()=>H.delete(v)}function it(v,k){k===void 0&&(k={}),T=$e({},T,v);let j=[],L=[];b.v7_fetcherPersist&&T.fetchers.forEach((K,ne)=>{K.state==="idle"&&(me.has(ne)?L.push(ne):j.push(ne))}),me.forEach(K=>{!T.fetchers.has(K)&&!q.has(K)&&L.push(K)}),[...H].forEach(K=>K(T,{deletedFetchers:L,viewTransitionOpts:k.viewTransitionOpts,flushSync:k.flushSync===!0})),b.v7_fetcherPersist?(j.forEach(K=>T.fetchers.delete(K)),L.forEach(K=>lo(K))):L.forEach(K=>me.delete(K))}function he(v,k,j){var L,K;let{flushSync:ne}=j===void 0?{}:j,ce=T.actionData!=null&&T.navigation.formMethod!=null&&so(T.navigation.formMethod)&&T.navigation.state==="loading"&&((L=v.state)==null?void 0:L._isRedirect)!==!0,ee;k.actionData?Object.keys(k.actionData).length>0?ee=k.actionData:ee=null:ce?ee=T.actionData:ee=null;let oe=k.loaderData?Wc(T.loaderData,k.loaderData,k.matches||[],k.errors):T.loaderData,Q=T.blockers;Q.size>0&&(Q=new Map(Q),Q.forEach((xe,dt)=>Q.set(dt,ts)));let J=Se===!0||T.navigation.formMethod!=null&&so(T.navigation.formMethod)&&((K=v.state)==null?void 0:K._isRedirect)!==!0;f&&(g=f,f=void 0),Ce||G===lt.Pop||(G===lt.Push?i.history.push(v,v.state):G===lt.Replace&&i.history.replace(v,v.state));let ve;if(G===lt.Pop){let xe=Pe.get(T.location.pathname);xe&&xe.has(v.pathname)?ve={currentLocation:T.location,nextLocation:v}:Pe.has(v.pathname)&&(ve={currentLocation:v,nextLocation:T.location})}else if(ze){let xe=Pe.get(T.location.pathname);xe?xe.add(v.pathname):(xe=new Set([v.pathname]),Pe.set(T.location.pathname,xe)),ve={currentLocation:T.location,nextLocation:v}}it($e({},k,{actionData:ee,loaderData:oe,historyAction:G,location:v,initialized:!0,navigation:xl,revalidation:"idle",restoreScrollPosition:Si(v,k.matches||T.matches),preventScrollReset:J,blockers:Q}),{viewTransitionOpts:ve,flushSync:ne===!0}),G=lt.Pop,Se=!1,ze=!1,Ce=!1,Qe=!1,tt=[]}async function ot(v,k){if(typeof v=="number"){i.history.go(v);return}let j=zl(T.location,T.matches,h,b.v7_prependBasename,v,b.v7_relativeSplatPath,k==null?void 0:k.fromRouteId,k==null?void 0:k.relative),{path:L,submission:K,error:ne}=zc(b.v7_normalizeFormMethod,!1,j,k),ce=T.location,ee=ns(T.location,L,k&&k.state);ee=$e({},ee,i.history.encodeLocation(ee));let oe=k&&k.replace!=null?k.replace:void 0,Q=lt.Push;oe===!0?Q=lt.Replace:oe===!1||K!=null&&so(K.formMethod)&&K.formAction===T.location.pathname+T.location.search&&(Q=lt.Replace);let J=k&&"preventScrollReset"in k?k.preventScrollReset===!0:void 0,ve=(k&&k.flushSync)===!0,xe=Na({currentLocation:ce,nextLocation:ee,historyAction:Q});if(xe){_o(xe,{state:"blocked",location:ee,proceed(){_o(xe,{state:"proceeding",proceed:void 0,reset:void 0,location:ee}),ot(v,k)},reset(){let dt=new Map(T.blockers);dt.set(xe,ts),it({blockers:dt})}});return}return await Rt(Q,ee,{submission:K,pendingError:ne,preventScrollReset:J,replace:k&&k.replace,enableViewTransition:k&&k.viewTransition,flushSync:ve})}function ft(){if(pa(),it({revalidation:"loading"}),T.navigation.state!=="submitting"){if(T.navigation.state==="idle"){Rt(T.historyAction,T.location,{startUninterruptedRevalidation:!0});return}Rt(G||T.historyAction,T.navigation.location,{overrideNavigation:T.navigation,enableViewTransition:ze===!0})}}async function Rt(v,k,j){re&&re.abort(),re=null,G=v,Ce=(j&&j.startUninterruptedRevalidation)===!0,ys(T.location,T.matches),Se=(j&&j.preventScrollReset)===!0,ze=(j&&j.enableViewTransition)===!0;let L=f||g,K=j&&j.overrideNavigation,ne=j!=null&&j.initialHydration&&T.matches&&T.matches.length>0&&!X?T.matches:Ea(L,k,h),ce=(j&&j.flushSync)===!0;if(ne&&T.initialized&&!Qe&&jm(T.location,k)&&!(j&&j.submission&&so(j.submission.formMethod))){he(k,{matches:ne},{flushSync:ce});return}let ee=ga(ne,L,k.pathname);if(ee.active&&ee.matches&&(ne=ee.matches),!ne){let{error:Ne,notFoundMatches:Ee,route:Ke}=uo(k.pathname);he(k,{matches:Ee,loaderData:{},errors:{[Ke.id]:Ne}},{flushSync:ce});return}re=new AbortController;let oe=di(i.history,k,re.signal,j&&j.submission),Q;if(j&&j.pendingError)Q=[Ta(ne).route.id,{type:Be.error,error:j.pendingError}];else if(j&&j.submission&&so(j.submission.formMethod)){let Ne=await ua(oe,k,j.submission,ne,ee.active,{replace:j.replace,flushSync:ce});if(Ne.shortCircuited)return;if(Ne.pendingActionResult){let[Ee,Ke]=Ne.pendingActionResult;if(Bt(Ke)&&rs(Ke.error)&&Ke.error.status===404){re=null,he(k,{matches:Ne.matches,loaderData:{},errors:{[Ee]:Ke.error}});return}}ne=Ne.matches||ne,Q=Ne.pendingActionResult,K=Al(k,j.submission),ce=!1,ee.active=!1,oe=di(i.history,oe.url,oe.signal)}let{shortCircuited:J,matches:ve,loaderData:xe,errors:dt}=await gs(oe,k,ne,ee.active,K,j&&j.submission,j&&j.fetcherSubmission,j&&j.replace,j&&j.initialHydration===!0,ce,Q);J||(re=null,he(k,$e({matches:ve||ne},Fc(Q),{loaderData:xe,errors:dt})))}async function ua(v,k,j,L,K,ne){ne===void 0&&(ne={}),pa();let ce=_m(k,j);if(it({navigation:ce},{flushSync:ne.flushSync===!0}),K){let Q=await No(L,k.pathname,v.signal);if(Q.type==="aborted")return{shortCircuited:!0};if(Q.type==="error"){let J=Ta(Q.partialMatches).route.id;return{matches:Q.partialMatches,pendingActionResult:[J,{type:Be.error,error:Q.error}]}}else if(Q.matches)L=Q.matches;else{let{notFoundMatches:J,error:ve,route:xe}=uo(k.pathname);return{matches:J,pendingActionResult:[xe.id,{type:Be.error,error:ve}]}}}let ee,oe=ss(L,k);if(!oe.route.action&&!oe.route.lazy)ee={type:Be.error,error:Ut(405,{method:v.method,pathname:k.pathname,routeId:oe.route.id})};else if(ee=(await Lo("action",T,v,[oe],L,null))[oe.route.id],v.signal.aborted)return{shortCircuited:!0};if(ja(ee)){let Q;return ne&&ne.replace!=null?Q=ne.replace:Q=Oc(ee.response.headers.get("Location"),new URL(v.url),h,i.history)===T.location.pathname+T.location.search,await ro(v,ee,!0,{submission:j,replace:Q}),{shortCircuited:!0}}if(ra(ee))throw Ut(400,{type:"defer-action"});if(Bt(ee)){let Q=Ta(L,oe.route.id);return(ne&&ne.replace)!==!0&&(G=lt.Push),{matches:L,pendingActionResult:[Q.route.id,ee]}}return{matches:L,pendingActionResult:[oe.route.id,ee]}}async function gs(v,k,j,L,K,ne,ce,ee,oe,Q,J){let ve=K||Al(k,ne),xe=ne||ce||Vc(ve),dt=!Ce&&(!b.v7_partialHydration||!oe);if(L){if(dt){let qe=La(J);it($e({navigation:ve},qe!==void 0?{actionData:qe}:{}),{flushSync:Q})}let Ie=await No(j,k.pathname,v.signal);if(Ie.type==="aborted")return{shortCircuited:!0};if(Ie.type==="error"){let qe=Ta(Ie.partialMatches).route.id;return{matches:Ie.partialMatches,loaderData:{},errors:{[qe]:Ie.error}}}else if(Ie.matches)j=Ie.matches;else{let{error:qe,notFoundMatches:yt,route:fa}=uo(k.pathname);return{matches:yt,loaderData:{},errors:{[fa.id]:qe}}}}let Ne=f||g,[Ee,Ke]=Mc(i.history,T,j,xe,k,b.v7_partialHydration&&oe===!0,b.v7_skipActionErrorRevalidation,Qe,tt,Me,me,ge,U,Ne,h,J);if(co(Ie=>!(j&&j.some(qe=>qe.route.id===Ie))||Ee&&Ee.some(qe=>qe.route.id===Ie)),V=++le,Ee.length===0&&Ke.length===0){let Ie=ms();return he(k,$e({matches:j,loaderData:{},errors:J&&Bt(J[1])?{[J[0]]:J[1].error}:null},Fc(J),Ie?{fetchers:new Map(T.fetchers)}:{}),{flushSync:Q}),{shortCircuited:!0}}if(dt){let Ie={};if(!L){Ie.navigation=ve;let qe=La(J);qe!==void 0&&(Ie.actionData=qe)}Ke.length>0&&(Ie.fetchers=ca(Ke)),it(Ie,{flushSync:Q})}Ke.forEach(Ie=>{$t(Ie.key),Ie.controller&&q.set(Ie.key,Ie.controller)});let So=()=>Ke.forEach(Ie=>$t(Ie.key));re&&re.signal.addEventListener("abort",So);let{loaderResults:ma,fetcherResults:Xt}=await mi(T,j,Ee,Ke,v);if(v.signal.aborted)return{shortCircuited:!0};re&&re.signal.removeEventListener("abort",So),Ke.forEach(Ie=>q.delete(Ie.key));let je=xn(ma);if(je)return await ro(v,je.result,!0,{replace:ee}),{shortCircuited:!0};if(je=xn(Xt),je)return U.add(je.key),await ro(v,je.result,!0,{replace:ee}),{shortCircuited:!0};let{loaderData:bi,errors:bo}=qc(T,j,ma,J,Ke,Xt,be);be.forEach((Ie,qe)=>{Ie.subscribe(yt=>{(yt||Ie.done)&&be.delete(qe)})}),b.v7_partialHydration&&oe&&T.errors&&(bo=$e({},T.errors,bo));let po=ms(),Po=Ma(V),Oa=po||Po||Ke.length>0;return $e({matches:j,loaderData:bi,errors:bo},Oa?{fetchers:new Map(T.fetchers)}:{})}function La(v){if(v&&!Bt(v[1]))return{[v[0]]:v[1].data};if(T.actionData)return Object.keys(T.actionData).length===0?null:T.actionData}function ca(v){return v.forEach(k=>{let j=T.fetchers.get(k.key),L=os(void 0,j?j.data:void 0);T.fetchers.set(k.key,L)}),new Map(T.fetchers)}function zo(v,k,j,L){if(d)throw new Error("router.fetch() was called during the server render, but it shouldn't be. You are likely calling a useFetcher() method in the body of your component. Try moving it to a useEffect or a callback.");$t(v);let K=(L&&L.flushSync)===!0,ne=f||g,ce=zl(T.location,T.matches,h,b.v7_prependBasename,j,b.v7_relativeSplatPath,k,L==null?void 0:L.relative),ee=Ea(ne,ce,h),oe=ga(ee,ne,ce);if(oe.active&&oe.matches&&(ee=oe.matches),!ee){qt(v,k,Ut(404,{pathname:ce}),{flushSync:K});return}let{path:Q,submission:J,error:ve}=zc(b.v7_normalizeFormMethod,!0,ce,L);if(ve){qt(v,k,ve,{flushSync:K});return}let xe=ss(ee,Q),dt=(L&&L.preventScrollReset)===!0;if(J&&so(J.formMethod)){hi(v,k,Q,xe,ee,oe.active,K,dt,J);return}ge.set(v,{routeId:k,path:Q}),hs(v,k,Q,xe,ee,oe.active,K,dt,J)}async function hi(v,k,j,L,K,ne,ce,ee,oe){pa(),ge.delete(v);function Q(He){if(!He.route.action&&!He.route.lazy){let Oo=Ut(405,{method:oe.formMethod,pathname:j,routeId:k});return qt(v,k,Oo,{flushSync:ce}),!0}return!1}if(!ne&&Q(L))return;let J=T.fetchers.get(v);Lt(v,Nm(oe,J),{flushSync:ce});let ve=new AbortController,xe=di(i.history,j,ve.signal,oe);if(ne){let He=await No(K,new URL(xe.url).pathname,xe.signal,v);if(He.type==="aborted")return;if(He.type==="error"){qt(v,k,He.error,{flushSync:ce});return}else if(He.matches){if(K=He.matches,L=ss(K,j),Q(L))return}else{qt(v,k,Ut(404,{pathname:j}),{flushSync:ce});return}}q.set(v,ve);let dt=le,Ee=(await Lo("action",T,xe,[L],K,v))[L.route.id];if(xe.signal.aborted){q.get(v)===ve&&q.delete(v);return}if(b.v7_fetcherPersist&&me.has(v)){if(ja(Ee)||Bt(Ee)){Lt(v,na(void 0));return}}else{if(ja(Ee))if(q.delete(v),V>dt){Lt(v,na(void 0));return}else return U.add(v),Lt(v,os(oe)),ro(xe,Ee,!1,{fetcherSubmission:oe,preventScrollReset:ee});if(Bt(Ee)){qt(v,k,Ee.error);return}}if(ra(Ee))throw Ut(400,{type:"defer-action"});let Ke=T.navigation.location||T.location,So=di(i.history,Ke,ve.signal),ma=f||g,Xt=T.navigation.state!=="idle"?Ea(ma,T.navigation.location,h):T.matches;ke(Xt,"Didn't find any matches after fetcher action");let je=++le;w.set(v,je);let bi=os(oe,Ee.data);T.fetchers.set(v,bi);let[bo,po]=Mc(i.history,T,Xt,oe,Ke,!1,b.v7_skipActionErrorRevalidation,Qe,tt,Me,me,ge,U,ma,h,[L.route.id,Ee]);po.filter(He=>He.key!==v).forEach(He=>{let Oo=He.key,Ss=T.fetchers.get(Oo),Nn=os(void 0,Ss?Ss.data:void 0);T.fetchers.set(Oo,Nn),$t(Oo),He.controller&&q.set(Oo,He.controller)}),it({fetchers:new Map(T.fetchers)});let Po=()=>po.forEach(He=>$t(He.key));ve.signal.addEventListener("abort",Po);let{loaderResults:Oa,fetcherResults:Ie}=await mi(T,Xt,bo,po,So);if(ve.signal.aborted)return;ve.signal.removeEventListener("abort",Po),w.delete(v),q.delete(v),po.forEach(He=>q.delete(He.key));let qe=xn(Oa);if(qe)return ro(So,qe.result,!1,{preventScrollReset:ee});if(qe=xn(Ie),qe)return U.add(qe.key),ro(So,qe.result,!1,{preventScrollReset:ee});let{loaderData:yt,errors:fa}=qc(T,Xt,Oa,void 0,po,Ie,be);if(T.fetchers.has(v)){let He=na(Ee.data);T.fetchers.set(v,He)}Ma(je),T.navigation.state==="loading"&&je>V?(ke(G,"Expected pending action"),re&&re.abort(),he(T.navigation.location,{matches:Xt,loaderData:yt,errors:fa,fetchers:new Map(T.fetchers)})):(it({errors:fa,loaderData:Wc(T.loaderData,yt,Xt,fa),fetchers:new Map(T.fetchers)}),Qe=!1)}async function hs(v,k,j,L,K,ne,ce,ee,oe){let Q=T.fetchers.get(v);Lt(v,os(oe,Q?Q.data:void 0),{flushSync:ce});let J=new AbortController,ve=di(i.history,j,J.signal);if(ne){let Ee=await No(K,new URL(ve.url).pathname,ve.signal,v);if(Ee.type==="aborted")return;if(Ee.type==="error"){qt(v,k,Ee.error,{flushSync:ce});return}else if(Ee.matches)K=Ee.matches,L=ss(K,j);else{qt(v,k,Ut(404,{pathname:j}),{flushSync:ce});return}}q.set(v,J);let xe=le,Ne=(await Lo("loader",T,ve,[L],K,v))[L.route.id];if(ra(Ne)&&(Ne=await Vl(Ne,ve.signal,!0)||Ne),q.get(v)===J&&q.delete(v),!ve.signal.aborted){if(me.has(v)){Lt(v,na(void 0));return}if(ja(Ne))if(V>xe){Lt(v,na(void 0));return}else{U.add(v),await ro(ve,Ne,!1,{preventScrollReset:ee});return}if(Bt(Ne)){qt(v,k,Ne.error);return}ke(!ra(Ne),"Unhandled fetcher deferred data"),Lt(v,na(Ne.data))}}async function ro(v,k,j,L){let{submission:K,fetcherSubmission:ne,preventScrollReset:ce,replace:ee}=L===void 0?{}:L;k.response.headers.has("X-Remix-Revalidate")&&(Qe=!0);let oe=k.response.headers.get("Location");ke(oe,"Expected a Location header on the redirect Response"),oe=Oc(oe,new URL(v.url),h,i.history);let Q=ns(T.location,oe,{_isRedirect:!0});if(r){let Ee=!1;if(k.response.headers.has("X-Remix-Reload-Document"))Ee=!0;else if(Yl.test(oe)){const Ke=i.history.createURL(oe);Ee=Ke.origin!==n.location.origin||jo(Ke.pathname,h)==null}if(Ee){ee?n.location.replace(oe):n.location.assign(oe);return}}re=null;let J=ee===!0||k.response.headers.has("X-Remix-Replace")?lt.Replace:lt.Push,{formMethod:ve,formAction:xe,formEncType:dt}=T.navigation;!K&&!ne&&ve&&xe&&dt&&(K=Vc(T.navigation));let Ne=K||ne;if(Sm.has(k.response.status)&&Ne&&so(Ne.formMethod))await Rt(J,Q,{submission:$e({},Ne,{formAction:oe}),preventScrollReset:ce||Se,enableViewTransition:j?ze:void 0});else{let Ee=Al(Q,K);await Rt(J,Q,{overrideNavigation:Ee,fetcherSubmission:ne,preventScrollReset:ce||Se,enableViewTransition:j?ze:void 0})}}async function Lo(v,k,j,L,K,ne){let ce,ee={};try{ce=await Rm(y,v,k,j,L,K,ne,p,u)}catch(oe){return L.forEach(Q=>{ee[Q.route.id]={type:Be.error,error:oe}}),ee}for(let[oe,Q]of Object.entries(ce))if(Hm(Q)){let J=Q.result;ee[oe]={type:Be.redirect,response:Em(J,j,oe,K,h,b.v7_relativeSplatPath)}}else ee[oe]=await Dm(Q);return ee}async function mi(v,k,j,L,K){let ne=v.matches,ce=Lo("loader",v,K,j,k,null),ee=Promise.all(L.map(async J=>{if(J.matches&&J.match&&J.controller){let xe=(await Lo("loader",v,di(i.history,J.path,J.controller.signal),[J.match],J.matches,J.key))[J.match.route.id];return{[J.key]:xe}}else return Promise.resolve({[J.key]:{type:Be.error,error:Ut(404,{pathname:J.path})}})})),oe=await ce,Q=(await ee).reduce((J,ve)=>Object.assign(J,ve),{});return await Promise.all([Lm(k,oe,K.signal,ne,v.loaderData),Mm(k,Q,L)]),{loaderResults:oe,fetcherResults:Q}}function pa(){Qe=!0,tt.push(...co()),ge.forEach((v,k)=>{q.has(k)&&Me.add(k),$t(k)})}function Lt(v,k,j){j===void 0&&(j={}),T.fetchers.set(v,k),it({fetchers:new Map(T.fetchers)},{flushSync:(j&&j.flushSync)===!0})}function qt(v,k,j,L){L===void 0&&(L={});let K=Ta(T.matches,k);lo(v),it({errors:{[K.route.id]:j},fetchers:new Map(T.fetchers)},{flushSync:(L&&L.flushSync)===!0})}function Mo(v){return ye.set(v,(ye.get(v)||0)+1),me.has(v)&&me.delete(v),T.fetchers.get(v)||bm}function lo(v){let k=T.fetchers.get(v);q.has(v)&&!(k&&k.state==="loading"&&w.has(v))&&$t(v),ge.delete(v),w.delete(v),U.delete(v),b.v7_fetcherPersist&&me.delete(v),Me.delete(v),T.fetchers.delete(v)}function _n(v){let k=(ye.get(v)||0)-1;k<=0?(ye.delete(v),me.add(v),b.v7_fetcherPersist||lo(v)):ye.set(v,k),it({fetchers:new Map(T.fetchers)})}function $t(v){let k=q.get(v);k&&(k.abort(),q.delete(v))}function fi(v){for(let k of v){let j=Mo(k),L=na(j.data);T.fetchers.set(k,L)}}function ms(){let v=[],k=!1;for(let j of U){let L=T.fetchers.get(j);ke(L,"Expected fetcher: "+j),L.state==="loading"&&(U.delete(j),v.push(j),k=!0)}return fi(v),k}function Ma(v){let k=[];for(let[j,L]of w)if(L<v){let K=T.fetchers.get(j);ke(K,"Expected fetcher: "+j),K.state==="loading"&&($t(j),w.delete(j),k.push(j))}return fi(k),k.length>0}function yi(v,k){let j=T.blockers.get(v)||ts;return Ae.get(v)!==k&&Ae.set(v,k),j}function _a(v){T.blockers.delete(v),Ae.delete(v)}function _o(v,k){let j=T.blockers.get(v)||ts;ke(j.state==="unblocked"&&k.state==="blocked"||j.state==="blocked"&&k.state==="blocked"||j.state==="blocked"&&k.state==="proceeding"||j.state==="blocked"&&k.state==="unblocked"||j.state==="proceeding"&&k.state==="unblocked","Invalid blocker state transition: "+j.state+" -> "+k.state);let L=new Map(T.blockers);L.set(v,k),it({blockers:L})}function Na(v){let{currentLocation:k,nextLocation:j,historyAction:L}=v;if(Ae.size===0)return;Ae.size>1&&la(!1,"A router only supports one blocker at a time");let K=Array.from(Ae.entries()),[ne,ce]=K[K.length-1],ee=T.blockers.get(ne);if(!(ee&&ee.state==="proceeding")&&ce({currentLocation:k,nextLocation:j,historyAction:L}))return ne}function uo(v){let k=Ut(404,{pathname:v}),j=f||g,{matches:L,route:K}=Kc(j);return co(),{notFoundMatches:L,route:K,error:k}}function co(v){let k=[];return be.forEach((j,L)=>{(!v||v(L))&&(j.cancel(),k.push(L),be.delete(L))}),k}function fs(v,k,j){if(O=v,N=k,z=j||null,!ie&&T.navigation===xl){ie=!0;let L=Si(T.location,T.matches);L!=null&&it({restoreScrollPosition:L})}return()=>{O=null,N=null,z=null}}function vi(v,k){return z&&z(v,k.map(L=>Xh(L,T.loaderData)))||v.key}function ys(v,k){if(O&&N){let j=vi(v,k);O[j]=N()}}function Si(v,k){if(O){let j=vi(v,k),L=O[j];if(typeof L=="number")return L}return null}function ga(v,k,j){if(C)if(v){if(Object.keys(v[0].params).length>0)return{active:!0,matches:Rn(k,j,h,!0)}}else return{active:!0,matches:Rn(k,j,h,!0)||[]};return{active:!1,matches:null}}async function No(v,k,j,L){if(!C)return{type:"success",matches:v};let K=v;for(;;){let ne=f==null,ce=f||g,ee=p;try{await C({signal:j,path:k,matches:K,fetcherKey:L,patch:(J,ve)=>{j.aborted||Nc(J,ve,ce,ee,u)}})}catch(J){return{type:"error",error:J,partialMatches:K}}finally{ne&&!j.aborted&&(g=[...g])}if(j.aborted)return{type:"aborted"};let oe=Ea(ce,k,h);if(oe)return{type:"success",matches:oe};let Q=Rn(ce,k,h,!0);if(!Q||K.length===Q.length&&K.every((J,ve)=>J.route.id===Q[ve].route.id))return{type:"success",matches:null};K=Q}}function vs(v){p={},f=En(v,u,void 0,p)}function ha(v,k){let j=f==null;Nc(v,k,f||g,p,u),j&&(g=[...g],it({}))}return De={get basename(){return h},get future(){return b},get state(){return T},get routes(){return g},get window(){return n},initialize:_e,subscribe:vo,enableScrollRestoration:fs,navigate:ot,fetch:zo,revalidate:ft,createHref:v=>i.history.createHref(v),encodeLocation:v=>i.history.encodeLocation(v),getFetcher:Mo,deleteFetcher:_n,dispose:pt,getBlocker:yi,deleteBlocker:_a,patchRoutes:ha,_internalFetchControllers:q,_internalActiveDeferreds:be,_internalSetRoutes:vs},De}function wm(i){return i!=null&&("formData"in i&&i.formData!=null||"body"in i&&i.body!==void 0)}function zl(i,n,r,d,u,p,g,f){let h,y;if(g){h=[];for(let b of n)if(h.push(b),b.route.id===g){y=b;break}}else h=n,y=n[n.length-1];let C=Kl(u||".",Fl(h,p),jo(i.pathname,r)||i.pathname,f==="path");if(u==null&&(C.search=i.search,C.hash=i.hash),(u==null||u===""||u===".")&&y){let b=Gl(C.search);if(y.route.index&&!b)C.search=C.search?C.search.replace(/^\?/,"?index&"):"?index";else if(!y.route.index&&b){let D=new URLSearchParams(C.search),H=D.getAll("index");D.delete("index"),H.filter(z=>z).forEach(z=>D.append("index",z));let O=D.toString();C.search=O?"?"+O:""}}return d&&r!=="/"&&(C.pathname=C.pathname==="/"?r:To([r,C.pathname])),za(C)}function zc(i,n,r,d){if(!d||!wm(d))return{path:r};if(d.formMethod&&!zm(d.formMethod))return{path:r,error:Ut(405,{method:d.formMethod})};let u=()=>({path:r,error:Ut(400,{type:"invalid-body"})}),p=d.formMethod||"get",g=i?p.toUpperCase():p.toLowerCase(),f=wp(r);if(d.body!==void 0){if(d.formEncType==="text/plain"){if(!so(g))return u();let D=typeof d.body=="string"?d.body:d.body instanceof FormData||d.body instanceof URLSearchParams?Array.from(d.body.entries()).reduce((H,O)=>{let[z,N]=O;return""+H+z+"="+N+`
51
+ `},""):String(d.body);return{path:r,submission:{formMethod:g,formAction:f,formEncType:d.formEncType,formData:void 0,json:void 0,text:D}}}else if(d.formEncType==="application/json"){if(!so(g))return u();try{let D=typeof d.body=="string"?JSON.parse(d.body):d.body;return{path:r,submission:{formMethod:g,formAction:f,formEncType:d.formEncType,formData:void 0,json:D,text:void 0}}}catch{return u()}}}ke(typeof FormData=="function","FormData is not available in this environment");let h,y;if(d.formData)h=Ml(d.formData),y=d.formData;else if(d.body instanceof FormData)h=Ml(d.body),y=d.body;else if(d.body instanceof URLSearchParams)h=d.body,y=Bc(h);else if(d.body==null)h=new URLSearchParams,y=new FormData;else try{h=new URLSearchParams(d.body),y=Bc(h)}catch{return u()}let C={formMethod:g,formAction:f,formEncType:d&&d.formEncType||"application/x-www-form-urlencoded",formData:y,json:void 0,text:void 0};if(so(C.formMethod))return{path:r,submission:C};let b=Ho(r);return n&&b.search&&Gl(b.search)&&h.append("index",""),b.search="?"+h,{path:za(b),submission:C}}function Lc(i,n,r){r===void 0&&(r=!1);let d=i.findIndex(u=>u.route.id===n);return d>=0?i.slice(0,r?d+1:d):i}function Mc(i,n,r,d,u,p,g,f,h,y,C,b,D,H,O,z){let N=z?Bt(z[1])?z[1].error:z[1].data:void 0,ie=i.createURL(n.location),F=i.createURL(u),X=r;p&&n.errors?X=Lc(r,Object.keys(n.errors)[0],!0):z&&Bt(z[1])&&(X=Lc(r,z[0]));let Y=z?z[1].statusCode:void 0,pe=g&&Y&&Y>=400,De=X.filter((G,Se)=>{let{route:re}=G;if(re.lazy)return!0;if(re.loader==null)return!1;if(p)return Ll(re,n.loaderData,n.errors);if(km(n.loaderData,n.matches[Se],G)||h.some(Le=>Le===G.route.id))return!0;let ze=n.matches[Se],Pe=G;return _c(G,$e({currentUrl:ie,currentParams:ze.params,nextUrl:F,nextParams:Pe.params},d,{actionResult:N,actionStatus:Y,defaultShouldRevalidate:pe?!1:f||ie.pathname+ie.search===F.pathname+F.search||ie.search!==F.search||Pp(ze,Pe)}))}),T=[];return b.forEach((G,Se)=>{if(p||!r.some(Ce=>Ce.route.id===G.routeId)||C.has(Se))return;let re=Ea(H,G.path,O);if(!re){T.push({key:Se,routeId:G.routeId,path:G.path,matches:null,match:null,controller:null});return}let ze=n.fetchers.get(Se),Pe=ss(re,G.path),Le=!1;D.has(Se)?Le=!1:y.has(Se)?(y.delete(Se),Le=!0):ze&&ze.state!=="idle"&&ze.data===void 0?Le=f:Le=_c(Pe,$e({currentUrl:ie,currentParams:n.matches[n.matches.length-1].params,nextUrl:F,nextParams:r[r.length-1].params},d,{actionResult:N,actionStatus:Y,defaultShouldRevalidate:pe?!1:f})),Le&&T.push({key:Se,routeId:G.routeId,path:G.path,matches:re,match:Pe,controller:new AbortController})}),[De,T]}function Ll(i,n,r){if(i.lazy)return!0;if(!i.loader)return!1;let d=n!=null&&n[i.id]!==void 0,u=r!=null&&r[i.id]!==void 0;return!d&&u?!1:typeof i.loader=="function"&&i.loader.hydrate===!0?!0:!d&&!u}function km(i,n,r){let d=!n||r.route.id!==n.route.id,u=i[r.route.id]===void 0;return d||u}function Pp(i,n){let r=i.route.path;return i.pathname!==n.pathname||r!=null&&r.endsWith("*")&&i.params["*"]!==n.params["*"]}function _c(i,n){if(i.route.shouldRevalidate){let r=i.route.shouldRevalidate(n);if(typeof r=="boolean")return r}return n.defaultShouldRevalidate}function Nc(i,n,r,d,u){var p;let g;if(i){let y=d[i];ke(y,"No route found to patch children into: routeId = "+i),y.children||(y.children=[]),g=y.children}else g=r;let f=n.filter(y=>!g.some(C=>Cp(y,C))),h=En(f,u,[i||"_","patch",String(((p=g)==null?void 0:p.length)||"0")],d);g.push(...h)}function Cp(i,n){return"id"in i&&"id"in n&&i.id===n.id?!0:i.index===n.index&&i.path===n.path&&i.caseSensitive===n.caseSensitive?(!i.children||i.children.length===0)&&(!n.children||n.children.length===0)?!0:i.children.every((r,d)=>{var u;return(u=n.children)==null?void 0:u.some(p=>Cp(r,p))}):!1}async function xm(i,n,r){if(!i.lazy)return;let d=await i.lazy();if(!i.lazy)return;let u=r[i.id];ke(u,"No route found in manifest");let p={};for(let g in d){let h=u[g]!==void 0&&g!=="hasErrorBoundary";la(!h,'Route "'+u.id+'" has a static property "'+g+'" defined but its lazy function is also returning a value for this property. '+('The lazy route property "'+g+'" will be ignored.')),!h&&!Gh.has(g)&&(p[g]=d[g])}Object.assign(u,p),Object.assign(u,$e({},n(u),{lazy:void 0}))}async function Am(i){let{matches:n}=i,r=n.filter(u=>u.shouldLoad);return(await Promise.all(r.map(u=>u.resolve()))).reduce((u,p,g)=>Object.assign(u,{[r[g].route.id]:p}),{})}async function Rm(i,n,r,d,u,p,g,f,h,y){let C=p.map(H=>H.route.lazy?xm(H.route,h,f):void 0),b=p.map((H,O)=>{let z=C[O],N=u.some(F=>F.route.id===H.route.id);return $e({},H,{shouldLoad:N,resolve:async F=>(F&&d.method==="GET"&&(H.route.lazy||H.route.loader)&&(N=!0),N?Im(n,d,H,z,F,y):Promise.resolve({type:Be.data,result:void 0}))})}),D=await i({matches:b,request:d,params:p[0].params,fetcherKey:g,context:y});try{await Promise.all(C)}catch{}return D}async function Im(i,n,r,d,u,p){let g,f,h=y=>{let C,b=new Promise((O,z)=>C=z);f=()=>C(),n.signal.addEventListener("abort",f);let D=O=>typeof y!="function"?Promise.reject(new Error("You cannot call the handler for a route which defines a boolean "+('"'+i+'" [routeId: '+r.route.id+"]"))):y({request:n,params:r.params,context:p},...O!==void 0?[O]:[]),H=(async()=>{try{return{type:"data",result:await(u?u(z=>D(z)):D())}}catch(O){return{type:"error",result:O}}})();return Promise.race([H,b])};try{let y=r.route[i];if(d)if(y){let C,[b]=await Promise.all([h(y).catch(D=>{C=D}),d]);if(C!==void 0)throw C;g=b}else if(await d,y=r.route[i],y)g=await h(y);else if(i==="action"){let C=new URL(n.url),b=C.pathname+C.search;throw Ut(405,{method:n.method,pathname:b,routeId:r.route.id})}else return{type:Be.data,result:void 0};else if(y)g=await h(y);else{let C=new URL(n.url),b=C.pathname+C.search;throw Ut(404,{pathname:b})}ke(g.result!==void 0,"You defined "+(i==="action"?"an action":"a loader")+" for route "+('"'+r.route.id+"\" but didn't return anything from your `"+i+"` ")+"function. Please return a value or `null`.")}catch(y){return{type:Be.error,result:y}}finally{f&&n.signal.removeEventListener("abort",f)}return g}async function Dm(i){let{result:n,type:r}=i;if(kp(n)){let b;try{let D=n.headers.get("Content-Type");D&&/\bapplication\/json\b/.test(D)?n.body==null?b=null:b=await n.json():b=await n.text()}catch(D){return{type:Be.error,error:D}}return r===Be.error?{type:Be.error,error:new jn(n.status,n.statusText,b),statusCode:n.status,headers:n.headers}:{type:Be.data,data:b,statusCode:n.status,headers:n.headers}}if(r===Be.error){if(Yc(n)){var d,u;if(n.data instanceof Error){var p,g;return{type:Be.error,error:n.data,statusCode:(p=n.init)==null?void 0:p.status,headers:(g=n.init)!=null&&g.headers?new Headers(n.init.headers):void 0}}return{type:Be.error,error:new jn(((d=n.init)==null?void 0:d.status)||500,void 0,n.data),statusCode:rs(n)?n.status:void 0,headers:(u=n.init)!=null&&u.headers?new Headers(n.init.headers):void 0}}return{type:Be.error,error:n,statusCode:rs(n)?n.status:void 0}}if(Um(n)){var f,h;return{type:Be.deferred,deferredData:n,statusCode:(f=n.init)==null?void 0:f.status,headers:((h=n.init)==null?void 0:h.headers)&&new Headers(n.init.headers)}}if(Yc(n)){var y,C;return{type:Be.data,data:n.data,statusCode:(y=n.init)==null?void 0:y.status,headers:(C=n.init)!=null&&C.headers?new Headers(n.init.headers):void 0}}return{type:Be.data,data:n}}function Em(i,n,r,d,u,p){let g=i.headers.get("Location");if(ke(g,"Redirects returned/thrown from loaders/actions must have a Location header"),!Yl.test(g)){let f=d.slice(0,d.findIndex(h=>h.route.id===r)+1);g=zl(new URL(n.url),f,u,!0,g,p),i.headers.set("Location",g)}return i}function Oc(i,n,r,d){let u=["about:","blob:","chrome:","chrome-untrusted:","content:","data:","devtools:","file:","filesystem:","javascript:"];if(Yl.test(i)){let p=i,g=p.startsWith("//")?new URL(n.protocol+p):new URL(p);if(u.includes(g.protocol))throw new Error("Invalid redirect location");let f=jo(g.pathname,r)!=null;if(g.origin===n.origin&&f)return g.pathname+g.search+g.hash}try{let p=d.createURL(i);if(u.includes(p.protocol))throw new Error("Invalid redirect location")}catch{}return i}function di(i,n,r,d){let u=i.createURL(wp(n)).toString(),p={signal:r};if(d&&so(d.formMethod)){let{formMethod:g,formEncType:f}=d;p.method=g.toUpperCase(),f==="application/json"?(p.headers=new Headers({"Content-Type":f}),p.body=JSON.stringify(d.json)):f==="text/plain"?p.body=d.text:f==="application/x-www-form-urlencoded"&&d.formData?p.body=Ml(d.formData):p.body=d.formData}return new Request(u,p)}function Ml(i){let n=new URLSearchParams;for(let[r,d]of i.entries())n.append(r,typeof d=="string"?d:d.name);return n}function Bc(i){let n=new FormData;for(let[r,d]of i.entries())n.append(r,d);return n}function Tm(i,n,r,d,u){let p={},g=null,f,h=!1,y={},C=r&&Bt(r[1])?r[1].error:void 0;return i.forEach(b=>{if(!(b.route.id in n))return;let D=b.route.id,H=n[D];if(ke(!ja(H),"Cannot handle redirect results in processLoaderData"),Bt(H)){let O=H.error;C!==void 0&&(O=C,C=void 0),g=g||{};{let z=Ta(i,D);g[z.route.id]==null&&(g[z.route.id]=O)}p[D]=void 0,h||(h=!0,f=rs(H.error)?H.error.status:500),H.headers&&(y[D]=H.headers)}else ra(H)?(d.set(D,H.deferredData),p[D]=H.deferredData.data,H.statusCode!=null&&H.statusCode!==200&&!h&&(f=H.statusCode),H.headers&&(y[D]=H.headers)):(p[D]=H.data,H.statusCode&&H.statusCode!==200&&!h&&(f=H.statusCode),H.headers&&(y[D]=H.headers))}),C!==void 0&&r&&(g={[r[0]]:C},p[r[0]]=void 0),{loaderData:p,errors:g,statusCode:f||200,loaderHeaders:y}}function qc(i,n,r,d,u,p,g){let{loaderData:f,errors:h}=Tm(n,r,d,g);return u.forEach(y=>{let{key:C,match:b,controller:D}=y,H=p[C];if(ke(H,"Did not find corresponding fetcher result"),!(D&&D.signal.aborted))if(Bt(H)){let O=Ta(i.matches,b==null?void 0:b.route.id);h&&h[O.route.id]||(h=$e({},h,{[O.route.id]:H.error})),i.fetchers.delete(C)}else if(ja(H))ke(!1,"Unhandled fetcher revalidation redirect");else if(ra(H))ke(!1,"Unhandled fetcher deferred data");else{let O=na(H.data);i.fetchers.set(C,O)}}),{loaderData:f,errors:h}}function Wc(i,n,r,d){let u=$e({},n);for(let p of r){let g=p.route.id;if(n.hasOwnProperty(g)?n[g]!==void 0&&(u[g]=n[g]):i[g]!==void 0&&p.route.loader&&(u[g]=i[g]),d&&d.hasOwnProperty(g))break}return u}function Fc(i){return i?Bt(i[1])?{actionData:{}}:{actionData:{[i[0]]:i[1].data}}:{}}function Ta(i,n){return(n?i.slice(0,i.findIndex(d=>d.route.id===n)+1):[...i]).reverse().find(d=>d.route.hasErrorBoundary===!0)||i[0]}function Kc(i){let n=i.length===1?i[0]:i.find(r=>r.index||!r.path||r.path==="/")||{id:"__shim-error-route__"};return{matches:[{params:{},pathname:"",pathnameBase:"",route:n}],route:n}}function Ut(i,n){let{pathname:r,routeId:d,method:u,type:p,message:g}=n===void 0?{}:n,f="Unknown Server Error",h="Unknown @remix-run/router error";return i===400?(f="Bad Request",u&&r&&d?h="You made a "+u+' request to "'+r+'" but '+('did not provide a `loader` for route "'+d+'", ')+"so there is no way to handle the request.":p==="defer-action"?h="defer() is not supported in actions":p==="invalid-body"&&(h="Unable to encode submission body")):i===403?(f="Forbidden",h='Route "'+d+'" does not match URL "'+r+'"'):i===404?(f="Not Found",h='No route matches URL "'+r+'"'):i===405&&(f="Method Not Allowed",u&&r&&d?h="You made a "+u.toUpperCase()+' request to "'+r+'" but '+('did not provide an `action` for route "'+d+'", ')+"so there is no way to handle the request.":u&&(h='Invalid request method "'+u.toUpperCase()+'"')),new jn(i||500,f,new Error(h),!0)}function xn(i){let n=Object.entries(i);for(let r=n.length-1;r>=0;r--){let[d,u]=n[r];if(ja(u))return{key:d,result:u}}}function wp(i){let n=typeof i=="string"?Ho(i):i;return za($e({},n,{hash:""}))}function jm(i,n){return i.pathname!==n.pathname||i.search!==n.search?!1:i.hash===""?n.hash!=="":i.hash===n.hash?!0:n.hash!==""}function Hm(i){return kp(i.result)&&vm.has(i.result.status)}function ra(i){return i.type===Be.deferred}function Bt(i){return i.type===Be.error}function ja(i){return(i&&i.type)===Be.redirect}function Yc(i){return typeof i=="object"&&i!=null&&"type"in i&&"data"in i&&"init"in i&&i.type==="DataWithResponseInit"}function Um(i){let n=i;return n&&typeof n=="object"&&typeof n.data=="object"&&typeof n.subscribe=="function"&&typeof n.cancel=="function"&&typeof n.resolveData=="function"}function kp(i){return i!=null&&typeof i.status=="number"&&typeof i.statusText=="string"&&typeof i.headers=="object"&&typeof i.body<"u"}function zm(i){return ym.has(i.toLowerCase())}function so(i){return mm.has(i.toLowerCase())}async function Lm(i,n,r,d,u){let p=Object.entries(n);for(let g=0;g<p.length;g++){let[f,h]=p[g],y=i.find(D=>(D==null?void 0:D.route.id)===f);if(!y)continue;let C=d.find(D=>D.route.id===y.route.id),b=C!=null&&!Pp(C,y)&&(u&&u[y.route.id])!==void 0;ra(h)&&b&&await Vl(h,r,!1).then(D=>{D&&(n[f]=D)})}}async function Mm(i,n,r){for(let d=0;d<r.length;d++){let{key:u,routeId:p,controller:g}=r[d],f=n[u];i.find(y=>(y==null?void 0:y.route.id)===p)&&ra(f)&&(ke(g,"Expected an AbortController for revalidating fetcher deferred result"),await Vl(f,g.signal,!0).then(y=>{y&&(n[u]=y)}))}}async function Vl(i,n,r){if(r===void 0&&(r=!1),!await i.deferredData.resolveData(n)){if(r)try{return{type:Be.data,data:i.deferredData.unwrappedData}}catch(u){return{type:Be.error,error:u}}return{type:Be.data,data:i.deferredData.data}}}function Gl(i){return new URLSearchParams(i).getAll("index").some(n=>n==="")}function ss(i,n){let r=typeof n=="string"?Ho(n).search:n.search;if(i[i.length-1].route.index&&Gl(r||""))return i[i.length-1];let d=vp(i);return d[d.length-1]}function Vc(i){let{formMethod:n,formAction:r,formEncType:d,text:u,formData:p,json:g}=i;if(!(!n||!r||!d)){if(u!=null)return{formMethod:n,formAction:r,formEncType:d,formData:void 0,json:void 0,text:u};if(p!=null)return{formMethod:n,formAction:r,formEncType:d,formData:p,json:void 0,text:void 0};if(g!==void 0)return{formMethod:n,formAction:r,formEncType:d,formData:void 0,json:g,text:void 0}}}function Al(i,n){return n?{state:"loading",location:i,formMethod:n.formMethod,formAction:n.formAction,formEncType:n.formEncType,formData:n.formData,json:n.json,text:n.text}:{state:"loading",location:i,formMethod:void 0,formAction:void 0,formEncType:void 0,formData:void 0,json:void 0,text:void 0}}function _m(i,n){return{state:"submitting",location:i,formMethod:n.formMethod,formAction:n.formAction,formEncType:n.formEncType,formData:n.formData,json:n.json,text:n.text}}function os(i,n){return i?{state:"loading",formMethod:i.formMethod,formAction:i.formAction,formEncType:i.formEncType,formData:i.formData,json:i.json,text:i.text,data:n}:{state:"loading",formMethod:void 0,formAction:void 0,formEncType:void 0,formData:void 0,json:void 0,text:void 0,data:n}}function Nm(i,n){return{state:"submitting",formMethod:i.formMethod,formAction:i.formAction,formEncType:i.formEncType,formData:i.formData,json:i.json,text:i.text,data:n?n.data:void 0}}function na(i){return{state:"idle",formMethod:void 0,formAction:void 0,formEncType:void 0,formData:void 0,json:void 0,text:void 0,data:i}}function Om(i,n){try{let r=i.sessionStorage.getItem(bp);if(r){let d=JSON.parse(r);for(let[u,p]of Object.entries(d||{}))p&&Array.isArray(p)&&n.set(u,new Set(p||[]))}}catch{}}function Bm(i,n){if(n.size>0){let r={};for(let[d,u]of n)r[d]=[...u];try{i.sessionStorage.setItem(bp,JSON.stringify(r))}catch(d){la(!1,"Failed to save applied view transitions in sessionStorage ("+d+").")}}}/**
52
+ * React Router v6.30.3
53
+ *
54
+ * Copyright (c) Remix Software Inc.
55
+ *
56
+ * This source code is licensed under the MIT license found in the
57
+ * LICENSE.md file in the root directory of this source tree.
58
+ *
59
+ * @license MIT
60
+ */function Hn(){return Hn=Object.assign?Object.assign.bind():function(i){for(var n=1;n<arguments.length;n++){var r=arguments[n];for(var d in r)Object.prototype.hasOwnProperty.call(r,d)&&(i[d]=r[d])}return i},Hn.apply(this,arguments)}const ds=A.createContext(null),$l=A.createContext(null),da=A.createContext(null),Xl=A.createContext(null),Uo=A.createContext({outlet:null,matches:[],isDataRoute:!1}),xp=A.createContext(null);function qm(i,n){let{relative:r}=n===void 0?{}:n;us()||ke(!1);let{basename:d,navigator:u}=A.useContext(da),{hash:p,pathname:g,search:f}=zn(i,{relative:r}),h=g;return d!=="/"&&(h=g==="/"?d:To([d,g])),u.createHref({pathname:h,search:f,hash:p})}function us(){return A.useContext(Xl)!=null}function no(){return us()||ke(!1),A.useContext(Xl).location}function Ap(i){A.useContext(da).static||A.useLayoutEffect(i)}function Rp(){let{isDataRoute:i}=A.useContext(Uo);return i?of():Wm()}function Wm(){us()||ke(!1);let i=A.useContext(ds),{basename:n,future:r,navigator:d}=A.useContext(da),{matches:u}=A.useContext(Uo),{pathname:p}=no(),g=JSON.stringify(Fl(u,r.v7_relativeSplatPath)),f=A.useRef(!1);return Ap(()=>{f.current=!0}),A.useCallback(function(y,C){if(C===void 0&&(C={}),!f.current)return;if(typeof y=="number"){d.go(y);return}let b=Kl(y,JSON.parse(g),p,C.relative==="path");i==null&&n!=="/"&&(b.pathname=b.pathname==="/"?n:To([n,b.pathname])),(C.replace?d.replace:d.push)(b,C.state,C)},[n,d,g,p,i])}const Fm=A.createContext(null);function Km(i){let n=A.useContext(Uo).outlet;return n&&A.createElement(Fm.Provider,{value:i},n)}function Db(){let{matches:i}=A.useContext(Uo),n=i[i.length-1];return n?n.params:{}}function zn(i,n){let{relative:r}=n===void 0?{}:n,{future:d}=A.useContext(da),{matches:u}=A.useContext(Uo),{pathname:p}=no(),g=JSON.stringify(Fl(u,d.v7_relativeSplatPath));return A.useMemo(()=>Kl(i,JSON.parse(g),p,r==="path"),[i,g,p,r])}function Ym(i,n,r,d){us()||ke(!1);let{navigator:u}=A.useContext(da),{matches:p}=A.useContext(Uo),g=p[p.length-1],f=g?g.params:{};g&&g.pathname;let h=g?g.pathnameBase:"/";g&&g.route;let y=no(),C;C=y;let b=C.pathname||"/",D=b;if(h!=="/"){let z=h.replace(/^\//,"").split("/");D="/"+b.replace(/^\//,"").split("/").slice(z.length).join("/")}let H=Ea(i,{pathname:D});return Qm(H&&H.map(z=>Object.assign({},z,{params:Object.assign({},f,z.params),pathname:To([h,u.encodeLocation?u.encodeLocation(z.pathname).pathname:z.pathname]),pathnameBase:z.pathnameBase==="/"?h:To([h,u.encodeLocation?u.encodeLocation(z.pathnameBase).pathname:z.pathnameBase])})),p,r,d)}function Vm(){let i=tf(),n=rs(i)?i.status+" "+i.statusText:i instanceof Error?i.message:JSON.stringify(i),r=i instanceof Error?i.stack:null,u={padding:"0.5rem",backgroundColor:"rgba(200,200,200, 0.5)"};return A.createElement(A.Fragment,null,A.createElement("h2",null,"Unexpected Application Error!"),A.createElement("h3",{style:{fontStyle:"italic"}},n),r?A.createElement("pre",{style:u},r):null,null)}const Gm=A.createElement(Vm,null);class $m extends A.Component{constructor(n){super(n),this.state={location:n.location,revalidation:n.revalidation,error:n.error}}static getDerivedStateFromError(n){return{error:n}}static getDerivedStateFromProps(n,r){return r.location!==n.location||r.revalidation!=="idle"&&n.revalidation==="idle"?{error:n.error,location:n.location,revalidation:n.revalidation}:{error:n.error!==void 0?n.error:r.error,location:r.location,revalidation:n.revalidation||r.revalidation}}componentDidCatch(n,r){console.error("React Router caught the following error during render",n,r)}render(){return this.state.error!==void 0?A.createElement(Uo.Provider,{value:this.props.routeContext},A.createElement(xp.Provider,{value:this.state.error,children:this.props.component})):this.props.children}}function Xm(i){let{routeContext:n,match:r,children:d}=i,u=A.useContext(ds);return u&&u.static&&u.staticContext&&(r.route.errorElement||r.route.ErrorBoundary)&&(u.staticContext._deepestRenderedBoundaryId=r.route.id),A.createElement(Uo.Provider,{value:n},d)}function Qm(i,n,r,d){var u;if(n===void 0&&(n=[]),r===void 0&&(r=null),d===void 0&&(d=null),i==null){var p;if(!r)return null;if(r.errors)i=r.matches;else if((p=d)!=null&&p.v7_partialHydration&&n.length===0&&!r.initialized&&r.matches.length>0)i=r.matches;else return null}let g=i,f=(u=r)==null?void 0:u.errors;if(f!=null){let C=g.findIndex(b=>b.route.id&&(f==null?void 0:f[b.route.id])!==void 0);C>=0||ke(!1),g=g.slice(0,Math.min(g.length,C+1))}let h=!1,y=-1;if(r&&d&&d.v7_partialHydration)for(let C=0;C<g.length;C++){let b=g[C];if((b.route.HydrateFallback||b.route.hydrateFallbackElement)&&(y=C),b.route.id){let{loaderData:D,errors:H}=r,O=b.route.loader&&D[b.route.id]===void 0&&(!H||H[b.route.id]===void 0);if(b.route.lazy||O){h=!0,y>=0?g=g.slice(0,y+1):g=[g[0]];break}}}return g.reduceRight((C,b,D)=>{let H,O=!1,z=null,N=null;r&&(H=f&&b.route.id?f[b.route.id]:void 0,z=b.route.errorElement||Gm,h&&(y<0&&D===0?(af("route-fallback"),O=!0,N=null):y===D&&(O=!0,N=b.route.hydrateFallbackElement||null)));let ie=n.concat(g.slice(0,D+1)),F=()=>{let X;return H?X=z:O?X=N:b.route.Component?X=A.createElement(b.route.Component,null):b.route.element?X=b.route.element:X=C,A.createElement(Xm,{match:b,routeContext:{outlet:C,matches:ie,isDataRoute:r!=null},children:X})};return r&&(b.route.ErrorBoundary||b.route.errorElement||D===0)?A.createElement($m,{location:r.location,revalidation:r.revalidation,component:z,error:H,children:F(),routeContext:{outlet:null,matches:ie,isDataRoute:!0}}):F()},null)}var Ip=(function(i){return i.UseBlocker="useBlocker",i.UseRevalidator="useRevalidator",i.UseNavigateStable="useNavigate",i})(Ip||{}),Dp=(function(i){return i.UseBlocker="useBlocker",i.UseLoaderData="useLoaderData",i.UseActionData="useActionData",i.UseRouteError="useRouteError",i.UseNavigation="useNavigation",i.UseRouteLoaderData="useRouteLoaderData",i.UseMatches="useMatches",i.UseRevalidator="useRevalidator",i.UseNavigateStable="useNavigate",i.UseRouteId="useRouteId",i})(Dp||{});function Zm(i){let n=A.useContext(ds);return n||ke(!1),n}function Jm(i){let n=A.useContext($l);return n||ke(!1),n}function ef(i){let n=A.useContext(Uo);return n||ke(!1),n}function Ep(i){let n=ef(),r=n.matches[n.matches.length-1];return r.route.id||ke(!1),r.route.id}function tf(){var i;let n=A.useContext(xp),r=Jm(),d=Ep();return n!==void 0?n:(i=r.errors)==null?void 0:i[d]}function of(){let{router:i}=Zm(Ip.UseNavigateStable),n=Ep(Dp.UseNavigateStable),r=A.useRef(!1);return Ap(()=>{r.current=!0}),A.useCallback(function(u,p){p===void 0&&(p={}),r.current&&(typeof u=="number"?i.navigate(u):i.navigate(u,Hn({fromRouteId:n},p)))},[i,n])}const Gc={};function af(i,n,r){Gc[i]||(Gc[i]=!0)}function sf(i,n){i==null||i.v7_startTransition,(i==null?void 0:i.v7_relativeSplatPath)===void 0&&(!n||n.v7_relativeSplatPath),n&&(n.v7_fetcherPersist,n.v7_normalizeFormMethod,n.v7_partialHydration,n.v7_skipActionErrorRevalidation)}function nf(i){return Km(i.context)}function rf(i){let{basename:n="/",children:r=null,location:d,navigationType:u=lt.Pop,navigator:p,static:g=!1,future:f}=i;us()&&ke(!1);let h=n.replace(/^\/*/,"/"),y=A.useMemo(()=>({basename:h,navigator:p,static:g,future:Hn({v7_relativeSplatPath:!1},f)}),[h,f,p,g]);typeof d=="string"&&(d=Ho(d));let{pathname:C="/",search:b="",hash:D="",state:H=null,key:O="default"}=d,z=A.useMemo(()=>{let N=jo(C,h);return N==null?null:{location:{pathname:N,search:b,hash:D,state:H,key:O},navigationType:u}},[h,C,b,D,H,O,u]);return z==null?null:A.createElement(da.Provider,{value:y},A.createElement(Xl.Provider,{children:r,value:z}))}new Promise(()=>{});function lf(i){let n={hasErrorBoundary:i.ErrorBoundary!=null||i.errorElement!=null};return i.Component&&Object.assign(n,{element:A.createElement(i.Component),Component:void 0}),i.HydrateFallback&&Object.assign(n,{hydrateFallbackElement:A.createElement(i.HydrateFallback),HydrateFallback:void 0}),i.ErrorBoundary&&Object.assign(n,{errorElement:A.createElement(i.ErrorBoundary),ErrorBoundary:void 0}),n}/**
61
+ * React Router DOM v6.30.3
62
+ *
63
+ * Copyright (c) Remix Software Inc.
64
+ *
65
+ * This source code is licensed under the MIT license found in the
66
+ * LICENSE.md file in the root directory of this source tree.
67
+ *
68
+ * @license MIT
69
+ */function pi(){return pi=Object.assign?Object.assign.bind():function(i){for(var n=1;n<arguments.length;n++){var r=arguments[n];for(var d in r)Object.prototype.hasOwnProperty.call(r,d)&&(i[d]=r[d])}return i},pi.apply(this,arguments)}function Tp(i,n){if(i==null)return{};var r={},d=Object.keys(i),u,p;for(p=0;p<d.length;p++)u=d[p],!(n.indexOf(u)>=0)&&(r[u]=i[u]);return r}function df(i){return!!(i.metaKey||i.altKey||i.ctrlKey||i.shiftKey)}function uf(i,n){return i.button===0&&(!n||n==="_self")&&!df(i)}function _l(i){return i===void 0&&(i=""),new URLSearchParams(typeof i=="string"||Array.isArray(i)||i instanceof URLSearchParams?i:Object.keys(i).reduce((n,r)=>{let d=i[r];return n.concat(Array.isArray(d)?d.map(u=>[r,u]):[[r,d]])},[]))}function cf(i,n){let r=_l(i);return n&&n.forEach((d,u)=>{r.has(u)||n.getAll(u).forEach(p=>{r.append(u,p)})}),r}const pf=["onClick","relative","reloadDocument","replace","state","target","to","preventScrollReset","viewTransition"],gf=["aria-current","caseSensitive","className","end","style","to","viewTransition","children"],hf="6";try{window.__reactRouterVersion=hf}catch{}function mf(i,n){return Cm({basename:void 0,future:pi({},void 0,{v7_prependBasename:!0}),history:Kh({window:void 0}),hydrationData:ff(),routes:i,mapRouteProperties:lf,dataStrategy:void 0,patchRoutesOnNavigation:void 0,window:void 0}).initialize()}function ff(){var i;let n=(i=window)==null?void 0:i.__staticRouterHydrationData;return n&&n.errors&&(n=pi({},n,{errors:yf(n.errors)})),n}function yf(i){if(!i)return null;let n=Object.entries(i),r={};for(let[d,u]of n)if(u&&u.__type==="RouteErrorResponse")r[d]=new jn(u.status,u.statusText,u.data,u.internal===!0);else if(u&&u.__type==="Error"){if(u.__subType){let p=window[u.__subType];if(typeof p=="function")try{let g=new p(u.message);g.stack="",r[d]=g}catch{}}if(r[d]==null){let p=new Error(u.message);p.stack="",r[d]=p}}else r[d]=u;return r}const jp=A.createContext({isTransitioning:!1}),vf=A.createContext(new Map),Sf="startTransition",$c=qh[Sf],bf="flushSync",Xc=Fh[bf];function Pf(i){$c?$c(i):i()}function as(i){Xc?Xc(i):i()}class Cf{constructor(){this.status="pending",this.promise=new Promise((n,r)=>{this.resolve=d=>{this.status==="pending"&&(this.status="resolved",n(d))},this.reject=d=>{this.status==="pending"&&(this.status="rejected",r(d))}})}}function wf(i){let{fallbackElement:n,router:r,future:d}=i,[u,p]=A.useState(r.state),[g,f]=A.useState(),[h,y]=A.useState({isTransitioning:!1}),[C,b]=A.useState(),[D,H]=A.useState(),[O,z]=A.useState(),N=A.useRef(new Map),{v7_startTransition:ie}=d||{},F=A.useCallback(G=>{ie?Pf(G):G()},[ie]),X=A.useCallback((G,Se)=>{let{deletedFetchers:re,flushSync:ze,viewTransitionOpts:Pe}=Se;G.fetchers.forEach((Ce,Qe)=>{Ce.data!==void 0&&N.current.set(Qe,Ce.data)}),re.forEach(Ce=>N.current.delete(Ce));let Le=r.window==null||r.window.document==null||typeof r.window.document.startViewTransition!="function";if(!Pe||Le){ze?as(()=>p(G)):F(()=>p(G));return}if(ze){as(()=>{D&&(C&&C.resolve(),D.skipTransition()),y({isTransitioning:!0,flushSync:!0,currentLocation:Pe.currentLocation,nextLocation:Pe.nextLocation})});let Ce=r.window.document.startViewTransition(()=>{as(()=>p(G))});Ce.finished.finally(()=>{as(()=>{b(void 0),H(void 0),f(void 0),y({isTransitioning:!1})})}),as(()=>H(Ce));return}D?(C&&C.resolve(),D.skipTransition(),z({state:G,currentLocation:Pe.currentLocation,nextLocation:Pe.nextLocation})):(f(G),y({isTransitioning:!0,flushSync:!1,currentLocation:Pe.currentLocation,nextLocation:Pe.nextLocation}))},[r.window,D,C,N,F]);A.useLayoutEffect(()=>r.subscribe(X),[r,X]),A.useEffect(()=>{h.isTransitioning&&!h.flushSync&&b(new Cf)},[h]),A.useEffect(()=>{if(C&&g&&r.window){let G=g,Se=C.promise,re=r.window.document.startViewTransition(async()=>{F(()=>p(G)),await Se});re.finished.finally(()=>{b(void 0),H(void 0),f(void 0),y({isTransitioning:!1})}),H(re)}},[F,g,C,r.window]),A.useEffect(()=>{C&&g&&u.location.key===g.location.key&&C.resolve()},[C,D,u.location,g]),A.useEffect(()=>{!h.isTransitioning&&O&&(f(O.state),y({isTransitioning:!0,flushSync:!1,currentLocation:O.currentLocation,nextLocation:O.nextLocation}),z(void 0))},[h.isTransitioning,O]),A.useEffect(()=>{},[]);let Y=A.useMemo(()=>({createHref:r.createHref,encodeLocation:r.encodeLocation,go:G=>r.navigate(G),push:(G,Se,re)=>r.navigate(G,{state:Se,preventScrollReset:re==null?void 0:re.preventScrollReset}),replace:(G,Se,re)=>r.navigate(G,{replace:!0,state:Se,preventScrollReset:re==null?void 0:re.preventScrollReset})}),[r]),pe=r.basename||"/",De=A.useMemo(()=>({router:r,navigator:Y,static:!1,basename:pe}),[r,Y,pe]),T=A.useMemo(()=>({v7_relativeSplatPath:r.future.v7_relativeSplatPath}),[r.future.v7_relativeSplatPath]);return A.useEffect(()=>sf(d,r.future),[d,r.future]),A.createElement(A.Fragment,null,A.createElement(ds.Provider,{value:De},A.createElement($l.Provider,{value:u},A.createElement(vf.Provider,{value:N.current},A.createElement(jp.Provider,{value:h},A.createElement(rf,{basename:pe,location:u.location,navigationType:u.historyAction,navigator:Y,future:T},u.initialized||r.future.v7_partialHydration?A.createElement(kf,{routes:r.routes,future:r.future,state:u}):n))))),null)}const kf=A.memo(xf);function xf(i){let{routes:n,future:r,state:d}=i;return Ym(n,void 0,d,r)}const Af=typeof window<"u"&&typeof window.document<"u"&&typeof window.document.createElement<"u",Rf=/^(?:[a-z][a-z0-9+.-]*:|\/\/)/i,ls=A.forwardRef(function(n,r){let{onClick:d,relative:u,reloadDocument:p,replace:g,state:f,target:h,to:y,preventScrollReset:C,viewTransition:b}=n,D=Tp(n,pf),{basename:H}=A.useContext(da),O,z=!1;if(typeof y=="string"&&Rf.test(y)&&(O=y,Af))try{let X=new URL(window.location.href),Y=y.startsWith("//")?new URL(X.protocol+y):new URL(y),pe=jo(Y.pathname,H);Y.origin===X.origin&&pe!=null?y=pe+Y.search+Y.hash:z=!0}catch{}let N=qm(y,{relative:u}),ie=Ef(y,{replace:g,state:f,target:h,preventScrollReset:C,relative:u,viewTransition:b});function F(X){d&&d(X),X.defaultPrevented||ie(X)}return A.createElement("a",pi({},D,{href:O||N,onClick:z||p?d:F,ref:r,target:h}))}),If=A.forwardRef(function(n,r){let{"aria-current":d="page",caseSensitive:u=!1,className:p="",end:g=!1,style:f,to:h,viewTransition:y,children:C}=n,b=Tp(n,gf),D=zn(h,{relative:b.relative}),H=no(),O=A.useContext($l),{navigator:z,basename:N}=A.useContext(da),ie=O!=null&&Tf(D)&&y===!0,F=z.encodeLocation?z.encodeLocation(D).pathname:D.pathname,X=H.pathname,Y=O&&O.navigation&&O.navigation.location?O.navigation.location.pathname:null;u||(X=X.toLowerCase(),Y=Y?Y.toLowerCase():null,F=F.toLowerCase()),Y&&N&&(Y=jo(Y,N)||Y);const pe=F!=="/"&&F.endsWith("/")?F.length-1:F.length;let De=X===F||!g&&X.startsWith(F)&&X.charAt(pe)==="/",T=Y!=null&&(Y===F||!g&&Y.startsWith(F)&&Y.charAt(F.length)==="/"),G={isActive:De,isPending:T,isTransitioning:ie},Se=De?d:void 0,re;typeof p=="function"?re=p(G):re=[p,De?"active":null,T?"pending":null,ie?"transitioning":null].filter(Boolean).join(" ");let ze=typeof f=="function"?f(G):f;return A.createElement(ls,pi({},b,{"aria-current":Se,className:re,ref:r,style:ze,to:h,viewTransition:y}),typeof C=="function"?C(G):C)});var Nl;(function(i){i.UseScrollRestoration="useScrollRestoration",i.UseSubmit="useSubmit",i.UseSubmitFetcher="useSubmitFetcher",i.UseFetcher="useFetcher",i.useViewTransitionState="useViewTransitionState"})(Nl||(Nl={}));var Qc;(function(i){i.UseFetcher="useFetcher",i.UseFetchers="useFetchers",i.UseScrollRestoration="useScrollRestoration"})(Qc||(Qc={}));function Df(i){let n=A.useContext(ds);return n||ke(!1),n}function Ef(i,n){let{target:r,replace:d,state:u,preventScrollReset:p,relative:g,viewTransition:f}=n===void 0?{}:n,h=Rp(),y=no(),C=zn(i,{relative:g});return A.useCallback(b=>{if(uf(b,r)){b.preventDefault();let D=d!==void 0?d:za(y)===za(C);h(i,{replace:D,state:u,preventScrollReset:p,relative:g,viewTransition:f})}},[y,h,C,d,u,r,i,p,g,f])}function Eb(i){let n=A.useRef(_l(i)),r=A.useRef(!1),d=no(),u=A.useMemo(()=>cf(d.search,r.current?null:n.current),[d.search]),p=Rp(),g=A.useCallback((f,h)=>{const y=_l(typeof f=="function"?f(u):f);r.current=!0,p("?"+y,h)},[p,u]);return[u,g]}function Tf(i,n){n===void 0&&(n={});let r=A.useContext(jp);r==null&&ke(!1);let{basename:d}=Df(Nl.useViewTransitionState),u=zn(i,{relative:n.relative});if(!r.isTransitioning)return!1;let p=jo(r.currentLocation.pathname,d)||r.currentLocation.pathname,g=jo(r.nextLocation.pathname,d)||r.nextLocation.pathname;return Tn(u.pathname,g)!=null||Tn(u.pathname,p)!=null}const jf="modulepreload",Hf=function(i){return"/dashboard/"+i},Zc={},io=function(n,r,d){let u=Promise.resolve();if(r&&r.length>0){let g=function(y){return Promise.all(y.map(C=>Promise.resolve(C).then(b=>({status:"fulfilled",value:b}),b=>({status:"rejected",reason:b}))))};document.getElementsByTagName("link");const f=document.querySelector("meta[property=csp-nonce]"),h=(f==null?void 0:f.nonce)||(f==null?void 0:f.getAttribute("nonce"));u=g(r.map(y=>{if(y=Hf(y),y in Zc)return;Zc[y]=!0;const C=y.endsWith(".css"),b=C?'[rel="stylesheet"]':"";if(document.querySelector(`link[href="${y}"]${b}`))return;const D=document.createElement("link");if(D.rel=C?"stylesheet":jf,C||(D.as="script"),D.crossOrigin="",D.href=y,h&&D.setAttribute("nonce",h),document.head.appendChild(D),C)return new Promise((H,O)=>{D.addEventListener("load",H),D.addEventListener("error",()=>O(new Error(`Unable to preload CSS for ${y}`)))})}))}function p(g){const f=new Event("vite:preloadError",{cancelable:!0});if(f.payload=g,window.dispatchEvent(f),!f.defaultPrevented)throw g}return u.then(g=>{for(const f of g||[])f.status==="rejected"&&p(f.reason);return n().catch(p)})},Ln=window.location.origin,Uf=3e3,zf=5e3;class Lf extends Error{constructor(r,d,u=null,p=null){super(d);Eo(this,"status");Eo(this,"error");Eo(this,"payload");this.name="ApiClientError",this.status=r,this.error=u,this.payload=p}}function Mf(i){var r,d;const n=(d=(r=i.headers)==null?void 0:r.get)==null?void 0:d.call(r,"content-type");return typeof n=="string"&&n.toLowerCase().includes("application/json")}async function _f(i){if(!Mf(i))return null;try{const n=await i.json();if(n&&typeof n=="object")return n}catch{return null}return null}async function is(i){if(i.ok)return;const n=await _f(i),r=typeof(n==null?void 0:n.message)=="string"&&n.message.trim().length>0?n.message:`API ${i.status}: ${i.statusText}`,d=typeof(n==null?void 0:n.error)=="string"?n.error:null;throw new Lf(i.status,r,d,n)}class Nf{constructor(n){Eo(this,"base");this.base=n}async get(n,r){const d=new URL(n,this.base);r&&Object.entries(r).forEach(([p,g])=>d.searchParams.set(p,g));const u=await fetch(d.toString(),{method:"GET"});return await is(u),u.json()}async patch(n,r){const d=new URL(n,this.base),u=await fetch(d.toString(),{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)});return await is(u),u.json()}async put(n,r){const d=new URL(n,this.base),u=await fetch(d.toString(),{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)});return await is(u),u.json()}async post(n,r){const d=new URL(n,this.base),u=await fetch(d.toString(),{method:"POST",headers:r?{"Content-Type":"application/json"}:{},body:r?JSON.stringify(r):void 0});return await is(u),u.json()}async delete(n){const r=new URL(n,this.base),d=await fetch(r.toString(),{method:"DELETE"});return await is(d),d.json()}}const zt=new Nf(Ln);function Of(i){return i.pluginClients&&i.pluginClients.length>0?"studioConnected":(i.connectedClients===0||!i.pluginClients,"serverOnly")}const Hp=A.createContext(null);function Bf({children:i}){const[n,r]=A.useState("disconnected"),[d,u]=A.useState(null),[p,g]=A.useState(null),f=A.useRef(null);return A.useEffect(()=>{let h=!1;async function y(){try{const C=await zt.get("/status");if(h)return;u(C),r(Of(C)),g(null)}catch(C){if(h)return;r("disconnected"),g(C instanceof Error?C.message:String(C))}}return y(),f.current=setInterval(y,zf),()=>{h=!0,f.current&&clearInterval(f.current)}},[]),x.jsx(Hp.Provider,{value:{level:n,status:d,error:p},children:i})}function Mn(){const i=A.useContext(Hp);if(!i)throw new Error("useConnection must be used within a ConnectionProvider");return i}const qf={"sidebar.overview":"Overview","sidebar.changelog":"Changelog","sidebar.connection":"Connection","sidebar.sync":"Sync","sidebar.playtest":"Playtest","sidebar.tools":"Tools","sidebar.settings":"Settings","sidebar.ui_studio":"UI Studio","sidebar.gate.l1":"MCP server connection required","sidebar.gate.l2":"Roblox Studio plugin connection required","header.currentProject":"Current Project","header.unknownProject":"Unknown project","header.projectRoot.label":"Project Root","header.currentProject.loading":"Loading project root...","header.currentProject.unavailable":"Project root unavailable","header.placeNotConnected":"Place not connected","header.currentProject.tooltip":"Currently selected project folder","header.currentProject.loading.tooltip":"Project root information is still loading","header.currentProject.unavailable.tooltip":"Current project root information is unavailable","header.currentProjectSyncRoot.label":"Sync Root","header.currentProjectSyncRoot.loading":"Loading sync root...","header.currentProjectSyncRoot.unavailable":"Sync root unavailable","header.currentProjectSyncRoot.tooltip":"Current sync root folder for the selected project","header.currentProjectSyncRoot.loading.tooltip":"Sync root information is still loading","header.currentProjectSyncRoot.unavailable.tooltip":"Current sync root information is unavailable","header.testFiles.label":"Test Files","header.testFiles.unavailable":"Test files unavailable","header.testFiles.tooltip":"Current playtest files directory for the selected place","header.places.title":"Places","header.places.active":"Active","header.places.inactive":"Inactive","header.places.pluginRequired":"Plugin connection required","header.places.liveRequired":"Plugin connection required for live active place","header.place.tooltip":"Connected Roblox place","header.placeNotConnected.tooltip":"Place not connected","header.changeProjectRoot":"Change Project Root","header.changeProjectRoot.ariaLabel":"Change project root","header.changeProjectRoot.tooltip":"Change the current project root","header.changeProjectRoot.disabledTooltip.l0":"MCP server connection required before project root can be changed","header.changeProjectRoot.disabledTooltip.loading":"Project root information is still loading","header.changeProjectRoot.disabledTooltip.unavailable":"Current project root information is unavailable","header.projectRootModal.initial.title":"Change project root","header.projectRootModal.initial.body.connected":"After you choose a project folder, MCP will switch to the new project root and the current Studio contents will be fully resynced into the new <selected project folder>/weppy-project-sync target.","header.projectRootModal.initial.body.disconnected":"After you choose a project folder, MCP will switch to the new project root and use <selected project folder>/weppy-project-sync as the next sync target.","header.projectRootModal.initial.nextSyncRoot":"New sync target after selection","header.projectRootModal.initial.nextSyncRoot.placeholder":"<selected project folder>/weppy-project-sync","header.projectRootModal.initial.warningStop":"Current sync stops immediately.","header.projectRootModal.initial.warningFreshSync":"The current Studio contents will be used to build a fresh full sync in the new target.","header.projectRootModal.initial.warningNoMove":"Old sync folders are not moved automatically.","header.projectRootModal.initial.warningDeferredSync":"If Studio is not connected, full resync starts the next time the plugin connects.","header.projectRootModal.confirm.title":"Confirm new project root","header.projectRootModal.confirm.body":"Review the selected project folder before applying.","header.projectRootModal.confirm.projectRoot":"Selected project folder","header.projectRootModal.confirm.syncRoot":"New sync target","header.projectRootModal.confirm.warningNoMove":"Existing sync folders are not moved automatically.","header.projectRootModal.pick":"Choose folder","header.projectRootModal.apply":"Apply change","header.projectRootModal.cancel":"Cancel","header.projectRootModal.error":"Failed to change project root","status.online":"Online","status.offline":"Offline","status.idle":"Idle","status.syncing":"Syncing","status.error":"Error","status.initializing":"Initializing","level.l0.title":"Server disconnected","level.l0.message":"WEPPY Dashboard opened but MCP server has stopped or is not responding.","level.l1.title":"Server connected","level.l1.hint":"Check: Is Roblox Studio running? Is the plugin installed?","level.l2.ok":"Studio connected","tier.basic":"Basic","tier.basic.tooltip":"Basic tier with the standard WEPPY Dashboard feature set.","tier.pro":"Pro","tier.pro.tooltip":"Pro tier with the full WEPPY Dashboard feature set.","tier.mixed":"Mixed","tier.upgrade":"View Pro","tier.banner.save":"Save AI tokens with Pro!","tier.tool.query_instances.desc":"Inspect instances, search children and descendants, and inspect class data. Pro adds file tree, project structure, and property or tag search.","tier.tool.mutate_instances.desc":"Create, delete, clone, and move instances. Pro adds tree creation and bulk create, delete, or clone operations.","tier.tool.manage_properties.desc":"Read and set properties, attributes, and tags. Pro adds calculated updates, relative changes, and bulk property operations.","tier.tool.manage_scripts.desc":"Read, write, create, delete, edit, and search script source. Pro adds bulk replacement across scripts.","tier.tool.manage_ui.desc":"Pro only. Create or refine game-style menus, HUDs, buttons, labels, and image panels, then capture screens and review improvement suggestions.","tier.tool.manage_ui.action.design_brief":"Plan UI direction","tier.tool.manage_ui.action.create_tree":"Create new UI","tier.tool.manage_ui.action.update":"Update existing UI","tier.tool.manage_ui.action.delete":"Remove UI","tier.tool.manage_ui.action.preview":"Capture UI screen","tier.tool.manage_ui.action.check":"Review improvement suggestions","tier.tool.manage_lighting.desc":"Pro only. Configure lighting, atmosphere, sky, terrain properties, and time-of-day settings.","tier.tool.manage_selection.desc":"Read, set, and clear the current Studio selection. Pro adds context, details, add or remove, and selection watch support.","tier.tool.manage_camera.desc":"Inspect camera state, focus by path or position, and request suggested views.","tier.tool.manage_tween.desc":"Pro only. Create, play, pause, and cancel tweens for smooth animation.","tier.tool.manage_audio.desc":"Pro only. Play, stop, pause, and resume sounds, and configure the audio listener.","tier.tool.manage_animation.desc":"Pro only. Load, play, and stop animations, and inspect active animation tracks.","tier.tool.manage_physics.desc":"Pro only. Register collision groups, configure group collisions, and inspect available groups.","tier.tool.manage_effects.desc":"Pro only. Emit particles, clear effects, and toggle effect state.","tier.tool.manage_terrain.desc":"Pro only. Fill terrain shapes, clear regions, replace materials, manage terrain colors, read or write voxels, generate terrain, and smooth terrain.","tier.tool.spatial_query.desc":"Pro only. Run raycasts, find ground, validate placement, scan areas, search for flat or spawn positions, analyze walkability, map space, and inspect collisions.","tier.tool.manage_assets.desc":"Pro only. Insert models, inspect asset info, search the creator store, insert free assets or packages, and export assets.","tier.tool.manage_sync.desc":"Pro only. Inspect sync status, configuration, history, directions, and read or write synced files.","tier.tool.workspace_state.desc":"Pro only. Run full sync, capture snapshots, inspect recent changes and viewport state, and manage related metadata.","tier.tool.manage_logs.desc":"Inspect output logs with filtering, incremental polling, buffer clearing, and recent error lookup.","tier.tool.system_info.desc":"Inspect connection status and current tier. Pro adds place info, services, Studio settings, playtest control, and automated tests.","tier.tool.manage_studio.desc":"Pro only. Toggle Studio editor view settings such as UI preview for screenshot and QA workflows; it changes Studio session settings, not game UI objects.","tier.tool.batch_execute.desc":"Pro only. Run multiple commands in a batch, with sequential execution and optional continue-on-error behavior.","tier.tool.execute_luau.desc":"Pro only. Execute arbitrary Luau code inside the Roblox Studio sandbox.","connection.server.title":"Server Status","connection.server.version":"Version","connection.server.version.tooltip":"Installed MCP server version","connection.server.pid":"PID","connection.server.pid.tooltip":"Operating system process identifier","connection.server.uptime":"Uptime","connection.server.uptime.tooltip":"Time elapsed since the MCP server started","connection.server.session":"Session","connection.server.session.tooltip":"Current MCP session identifier","connection.server.exec":"Exec","connection.server.exec.tooltip":"Executable path used to launch the MCP server","connection.reconnect":"Reconnect","connection.checkSettings":"Check Settings","connection.agents.title":"AI Agents","connection.agents.name":"Agent","connection.agents.cwd":"Working Dir","connection.agents.cwd.tooltip":"Current working directory for the connected AI agent","connection.agents.projectRoot":"Project Root","connection.agents.projectRoot.tooltip":"Authoritative project root for sync ownership","connection.agents.projectRoot.unresolved":"Unresolved","connection.agents.connected":"Connected","connection.agents.unknown":"Unknown","connection.agents.none":"No agents connected","connection.plugins.title":"Plugins","connection.plugins.place":"Place","connection.plugins.clientId":"Client ID","connection.plugins.clientId.tooltip":"Unique plugin client identifier for this Studio connection","connection.plugins.lastSeen":"Last Seen","connection.plugins.lastSeen.tooltip":"Most recent heartbeat received from the plugin","connection.plugins.version":"Ver","connection.plugins.version.tooltip":"Installed plugin version reported by Studio","connection.plugins.none":"No plugins connected","connection.log.title":"Connection Log","connection.log.empty":"No events yet","connection.time.secondsAgo":"s ago","connection.time.minutesAgo":"m ago","connection.time.hoursAgo":"h ago","common.loading":"Loading...","common.retry":"Retry","common.reconnecting":"Reconnecting...","common.expand":"Expand","common.collapse":"Collapse","tools.tab.history":"History","tools.tab.statistics":"Statistics","tools.tab.failures":"Failures","tools.col.time":"Time","tools.col.time.tooltip":"When the tool run was recorded.","tools.col.toolAction":"Tool.Action","tools.col.toolAction.tooltip":"Tool name and action that were executed.","tools.col.duration":"Duration","tools.col.duration.tooltip":"How long the tool took to finish.","tools.col.status":"Status","tools.col.status.tooltip":"Outcome of the recorded tool run.","tools.col.tier":"Tier","tools.col.tier.tooltip":"License tier required for the tool or action.","tools.col.tierStats.tooltip":"Basic, Pro, or Mixed summary for the tool statistics row.","tools.col.tool":"Tool","tools.col.tool.tooltip":"Consolidated tool name in the statistics table.","tools.col.calls":"Calls","tools.col.calls.tooltip":"Total number of recorded calls for this tool.","tools.col.ok":"OK","tools.col.ok.tooltip":"Number of direct successful runs.","tools.col.fallback":"FALLBACK","tools.col.fallback.tooltip":"Number of runs that succeeded through fallback execution.","tools.col.unsupported":"UNSUPPORTED","tools.col.unsupported.tooltip":"Number of blocked runs without fallback execution.","tools.col.warn":"WARN","tools.col.warn.tooltip":"Number of expected failures caused by caller input, project state, Roblox policy, or user code.","tools.col.err":"FAILED","tools.col.err.tooltip":"Number of runs that failed.","tools.col.okRate":"OK%","tools.col.okRate.tooltip":"Percentage of calls that finished successfully.","tools.col.avgTime":"Avg Time","tools.col.avgTime.tooltip":"Average execution time across recorded calls.","tools.col.error":"Error","tools.filter.tool":"Tool","tools.filter.all":"All","tools.badge.pro":"PRO","tools.badge.pro.tooltip":"This entry used a Pro-only tool or action.","tools.badge.fallback":"FALLBACK","tools.badge.fallback.tooltip":"The requested Pro action succeeded via a Basic fallback.","tools.badge.unsupported":"UNSUPPORTED","tools.badge.unsupported.tooltip":"The requested Pro action was blocked and no fallback ran.","tools.badge.warn":"WARN","tools.badge.warn.tooltip":"The tool call failed as an expected caller, project, policy, or user-code issue.","tools.badge.err":"FAILED","tools.badge.err.tooltip":"The tool run failed.","tools.status.ok":"OK","tools.status.ok.tooltip":"The tool run completed successfully.","tools.tier.mixed.tooltip":"This tool includes both Basic and Pro actions.","tools.detail.params":"Parameters","tools.detail.params.tooltip":"Input parameters passed to this tool run.","tools.detail.result":"Result","tools.detail.result.tooltip":"Returned result payload for this tool run.","tools.detail.requestedCommand":"Command Sent","tools.detail.executedCommand":"Executed Command","tools.detail.alternatives":"Alternatives","tools.detail.blockedMessage":"Blocked Reason","tools.detail.noFallback":"No Fallback","tools.detail.noFallback.value":"No fallback ran.","tools.detail.warningMessage":"Warning Message","tools.detail.errorMessage":"Error Message","tools.clear.history.title":"Clear history?","tools.clear.history.message":"This permanently removes the current place tools history.","tools.clear.statistics.title":"Clear statistics?","tools.clear.statistics.message":"This permanently resets the current place tool statistics.","tools.detail.error":"Error","tools.page.prev":"Prev","tools.page.prev.tooltip":"Go to the previous page of tool history results.","tools.page.next":"Next","tools.page.next.tooltip":"Go to the next page of tool history results.","tools.empty.history":"No history entries","tools.empty.stats":"No tool statistics","tools.empty.failures":"No failures","tools.summary.total":"Total","tools.summary.calls":"calls","tools.summary.sessions":"Sessions","settings.license.title":"License","settings.license.title.tooltip":"Current license status and subscription tier.","settings.license.status":"Status","settings.license.status.tooltip":"Current license activation state.","settings.license.tier":"Tier","settings.license.tier.tooltip":"Current subscription tier for available WEPPY Dashboard features.","settings.license.key":"Key","settings.license.key.tooltip":"Masked license key currently loaded by the server.","settings.license.keyValue.tooltip":"Masked license key currently loaded by the server.","settings.license.provider":"Provider","settings.license.provider.auto":"auto","settings.license.provider.polar":"polar","settings.license.provider.gumroad":"gumroad","settings.license.provider.tooltip":"License provider used to validate this key.","settings.license.providerValue.tooltip":"License provider used to validate this key.","settings.license.active":"Active","settings.license.active.tooltip":"Current license activation state.","settings.license.status.activeCancelPending.tooltip":"Cancellation is pending, but Pro access remains active until the current billing period ends.","settings.license.inactive":"Inactive","settings.license.inactive.tooltip":"Current license activation state.","settings.license.expired":"Expired","settings.license.expired.tooltip":"Current license activation state.","settings.license.unavailable":"License info unavailable","settings.license.detail.cancelPending":"Cancellation is scheduled. Pro access remains active until the current billing period ends.","settings.license.reset":"Reset License","settings.readOnly":"Read-only","settings.readOnly.tooltip":"This section shows values that cannot be edited from the WEPPY Dashboard.","settings.unavailable":"Settings unavailable","settings.general.title":"General Settings","settings.general.title.tooltip":"Hot settings that apply immediately when changed.","settings.general.liveApply":"Live Apply","settings.general.liveApply.tooltip":"Changes in this section are applied immediately without a separate save button.","settings.general.applied":"Applied","settings.general.logLevel":"Log Level","settings.general.logLevel.tooltip":"Choose how much detail the MCP server writes to logs. Lower to ‘debug’ when tracking down a problem.","settings.general.localHistory":"Tool History Recording","settings.general.localHistory.tooltip":"Save AI tool runs to disk. Required for the Tools and History pages.","settings.general.localStatistics":"Tool Statistics Collection","settings.general.localStatistics.tooltip":"Aggregate tool usage counts. Used by the Overview statistics.","settings.general.contextCapture":"Context Capture","settings.general.contextCapture.tooltip":"Save structured execution context so the Changelog and Playtest views can render it.","settings.general.requestTimeout":"Action Timeout","settings.general.requestTimeout.tooltip":"Maximum time (in ms) to wait for a single tool action before failing.","settings.general.requestTimeout.unit":"ms","settings.general.requestTimeout.unit.tooltip":"Action timeout is measured in milliseconds.","settings.cold.title":"Server Environment","settings.cold.title.tooltip":"Read-only server environment values loaded at startup.","settings.cold.httpPort.tooltip":"Port number used by the MCP WEPPY Dashboard HTTP server.","settings.cold.httpHost.tooltip":"Host interface that the MCP WEPPY Dashboard HTTP server binds to.","settings.cold.dashboardAutoOpen.tooltip":"Controls whether the WEPPY Dashboard opens automatically in the browser when the server starts.","settings.cold.dashboardAutoOpen.value.tooltip":"Current startup behavior for opening the WEPPY Dashboard in a browser.","settings.cold.hint":"Set via environment variables to change these values.","settings.language.title":"Language","settings.language.title.tooltip":"Choose how the WEPPY Dashboard interface text is localized.","settings.language.dashboard":"WEPPY Dashboard Language","settings.language.dashboard.tooltip":"Overrides the WEPPY Dashboard language or follows the system language when set to Auto.","settings.language.auto":"Auto","overview.l0.title":"MCP Server Disconnected","overview.l0.message":"The MCP server is not responding. The WEPPY Dashboard will automatically attempt to reconnect.","overview.l0.step1":"Check that the MCP server process is running","overview.l0.step2":"Restart the MCP server command if needed","overview.l0.reconnecting":"Auto-reconnecting every 3s...","overview.l0.reconnectBtn":"Reconnect","overview.l0.settingsBtn":"Check Settings","overview.l1.pluginGuide":"Roblox Studio plugin is not connected","overview.l1.check1":"Is Roblox Studio running?","overview.l1.check2":"Is the WEPPY Plugin installed?","overview.l1.feedHint":"Changes will appear here once the plugin connects","overview.metric.server":"Server","overview.metric.server.tooltip":"MCP server runtime and process status","overview.metric.plugin":"Plugin","overview.metric.plugin.tooltip":"Roblox Studio plugin connection and version status","overview.metric.agent":"Agent","overview.metric.agent.tooltip":"Connected AI coding agents and their runtime state","overview.metric.agent.instancesUnit":"instances","overview.metric.sync":"Sync","overview.metric.sync.tooltip":"Current Studio to local sync activity","overview.metric.noAgent":"No Agent","overview.meta.version":"Version","overview.meta.version.tooltip":"Installed MCP server version","overview.meta.session":"Session","overview.meta.session.tooltip":"Current MCP session identifier","overview.meta.pid":"PID","overview.meta.pid.tooltip":"Operating system process identifier","overview.meta.uptime":"Uptime","overview.meta.uptime.tooltip":"Time elapsed since the MCP server started","overview.feed.title":"Recent Game Changes","overview.feed.empty":"No recent changes","overview.changelog.title":"Session Change Summary","overview.changelog.entries":"Total","overview.changelog.scripts":"scripts","overview.changelog.instances":"instances","overview.changelog.properties":"properties","overview.changelog.assets":"assets","overview.tier.title":"Tier Usage","changelog.subtitle":"Game Change History","changelog.filter.all":"All","changelog.filter.active":"Active","changelog.filter.completed":"Completed","changelog.empty":"No changelog entries yet","changelog.basic.limit.title":"Basic preview shows the latest 3 sessions","changelog.basic.limit.body":"Full changelog timeline browsing is available with Pro.","changelog.basic.metricLabel":"Visible Changelog / Total","changelog.basic.visible":"visible","changelog.basic.total":"total","changelog.card.active":"Active","changelog.card.active.tooltip":"This session is still receiving new game changes.","changelog.card.completed":"Completed","changelog.card.completed.tooltip":"This session has ended and no more changes are expected.","changelog.card.bootstrapStatus":"Bootstrap","changelog.card.bootstrapStatus.tooltip":"This session only contains the initial sync bootstrap snapshot.","changelog.card.inProgress":"in progress","changelog.card.noChanges":"No changes yet","changelog.card.noChanges.tooltip":"No game changes have been extracted for this session yet.","changelog.card.bootstrapSummary":"Initial sync snapshot","changelog.card.bootstrapSummary.tooltip":"Initial file sync writes are collapsed into a single bootstrap snapshot row.","changelog.card.sessionIntent":"Session intent","changelog.card.scripts":"scripts","changelog.card.scripts.tooltip":"Script changes made in this session.","changelog.card.instances":"instances","changelog.card.instances.tooltip":"Instance create, delete, move, or clone changes in this session.","changelog.card.modified":"modified","changelog.card.created":"created","changelog.card.deleted":"deleted","changelog.card.moved":"moved","changelog.card.propertiesChanged":"properties changed","changelog.card.propertiesChanged.tooltip":"Property value changes recorded for this session.","changelog.card.lightingConfigured":"Lighting configured","changelog.card.lightingConfigured.tooltip":"Lighting or atmosphere settings changed in this session.","changelog.card.terrainConfigured":"Terrain configured","changelog.card.terrainConfigured.tooltip":"Terrain data or terrain settings changed in this session.","changelog.card.assetsInserted":"assets inserted","changelog.card.assetsInserted.tooltip":"Assets inserted into the place during this session.","changelog.category.script":"Scripts","changelog.category.instance":"Instances","changelog.category.property":"Properties","changelog.category.lighting":"Lighting","changelog.category.terrain":"Terrain","changelog.category.asset":"Assets","changelog.detail.changeSummary":"Change Summary","changelog.detail.changeSummary.tooltip":"Counts of extracted game changes grouped by category for this session.","changelog.detail.changeTimeline":"Change Timeline","changelog.detail.changeTimeline.tooltip":"Chronological list of extracted game changes for this session.","changelog.detail.context.title":"Context Summary","changelog.detail.context.tooltip":"Structured execution context captured for this changelog session.","changelog.detail.verification.title":"Verification","changelog.detail.verification.tooltip":"Verification signals linked to this changelog session.","changelog.detail.verification.label":"Result","changelog.detail.verification.status":"Status","changelog.detail.verification.timestamp":"Recorded at","changelog.detail.beforeAfter":"Before & After","changelog.detail.filterCategory":"Category","changelog.detail.filterCategory.tooltip":"Filter the timeline to a single change category.","changelog.detail.confidence.exact":"Exact","changelog.detail.confidence.exact.tooltip":"Both the before and after state were confirmed for this change.","changelog.detail.confidence.partial":"Partial","changelog.detail.confidence.partial.tooltip":"Only part of the before and after state could be confirmed for this change.","changelog.detail.confidence.afterOnly":"After only","changelog.detail.confidence.afterOnly.tooltip":"Only the resulting state after the change could be confirmed.","changelog.detail.confidence.intentOnly":"Intent only","changelog.detail.confidence.intentOnly.tooltip":"Only the requested action was recorded, not the resulting state.","changelog.detail.confidence.unknown":"Unknown","changelog.detail.confidence.unknown.tooltip":"This change could not be confidently classified from the available data.","changelog.detail.noChanges":"No changes in this category","changelog.detail.backToList":"Back to list","changelog.diff.empty":"No diff available","changelog.diff.unified":"Unified","changelog.diff.sideBySide":"Side by Side","changelog.diff.before":"Before","changelog.diff.after":"After","sync.overlay.title":"Roblox Studio plugin required","sync.overlay.message":"Sync status will be available once the Roblox Studio plugin connects.","sync.overlay.check1":"Is Roblox Studio running?","sync.overlay.check2":"Is the WEPPY Plugin installed?","sync.status.title":"Sync Status","sync.status.title.tooltip":"Current Studio and local file sync status for this place.","sync.status.forwardOnly":"Forward Only","sync.status.forwardOnly.tooltip":"Basic tier allows Studio to local forward sync only.","sync.status.place":"Place","sync.status.place.tooltip":"Connected Roblox place name and place ID.","sync.status.path":"Path","sync.status.path.tooltip":"Local filesystem root currently used for sync output.","sync.status.instances":"Instances","sync.status.instances.tooltip":"Total synced Roblox instances tracked in the local mirror.","sync.status.scripts":"Scripts","sync.status.scripts.tooltip":"Total synced script files currently indexed for this place.","sync.status.state":"State","sync.status.state.tooltip":"Current runtime sync state reported by the server.","sync.directions.title":"Sync Directions","sync.directions.title.tooltip":"Per-category sync direction and apply behavior between Local and Studio.","sync.directions.type":"Type","sync.directions.type.tooltip":"Sync category affected by this rule.","sync.directions.direction":"Direction","sync.directions.direction.tooltip":"Whether each category syncs from Studio, to Studio, or both ways.","sync.directions.applyMode":"Apply Mode","sync.directions.applyMode.tooltip":"How incoming sync changes are applied for this category.","sync.directions.cat.scripts":"Scripts","sync.directions.cat.values":"Values","sync.directions.cat.containers":"Containers","sync.directions.cat.data":"Data","sync.directions.cat.services":"Services","sync.directions.endpoint.local":"Local","sync.directions.endpoint.local.tooltip":"Local files on disk are always shown on the left side of the direction rail.","sync.directions.endpoint.studio":"Studio","sync.directions.endpoint.studio.tooltip":"Roblox Studio is always shown on the right side of the direction rail.","sync.directions.mode.manual":"Manual","sync.directions.mode.manual.tooltip":"Applies sync changes only when you trigger them manually.","sync.directions.mode.auto":"Auto","sync.directions.mode.auto.tooltip":"Applies sync changes automatically when updates arrive.","sync.directions.tooltip.forward.body":"Studio changes sync to local files only","sync.directions.tooltip.bidirectional.body":"Two-way sync between Local and Studio","sync.directions.tooltip.reverse.body":"Push local file changes to Studio","sync.directions.tooltip.proRequired":"Pro required in Basic tier","sync.directions.dir.forward":"forward","sync.directions.dir.bidirectional":"bidirectional","sync.directions.dir.reverse":"reverse","sync.log.title":"Sync Log","sync.log.empty":"No sync events yet","sync.log.type.write":"WRITE","sync.log.type.write.tooltip":"A new sync output was written to disk.","sync.log.type.update":"UPDATE","sync.log.type.update.tooltip":"An existing synced file or instance was updated.","sync.log.type.delete":"DELETE","sync.log.type.delete.tooltip":"A synced file or instance was removed.","sync.log.type.idle":"IDLE","sync.log.type.idle.tooltip":"A sync event was recorded without a file mutation.","sync.upgrade.title":"Explore Full Sync with Pro","sync.upgrade.benefit1":"Bidirectional sync — edit files, auto-apply to Studio","sync.upgrade.benefit2":"Reverse sync — push file changes back to Studio","sync.upgrade.benefit3":"Full sync history and detailed change log","sync.upgrade.buy":"View Pro","playtest.status.title":"Playtest Status","playtest.status.title.tooltip":"Current Roblox playtest session state reported by Studio.","playtest.status.mode":"Mode","playtest.status.mode.tooltip":"Studio playtest launch mode for the current session.","playtest.status.mode.value.tooltip":"Specific Roblox Studio playtest mode currently in use.","playtest.status.mode.play":"Play","playtest.status.mode.run":"Run","playtest.status.mode.server":"Server","playtest.status.mode.edit":"Edit","playtest.status.place.tooltip":"Roblox place currently associated with this playtest session.","playtest.status.state.running":"Running","playtest.status.state.running.tooltip":"A Roblox playtest session is currently running.","playtest.status.state.paused":"Paused","playtest.status.state.paused.tooltip":"The current Roblox playtest session is paused.","playtest.status.state.notRunning":"Not Running","playtest.status.state.notRunning.tooltip":"No Roblox playtest session is currently running.","playtest.control.play":"Play","playtest.control.pause":"Pause","playtest.control.resume":"Resume","playtest.control.stop":"Stop","playtest.history.title":"Test History","playtest.history.title.tooltip":"Recorded automated playtest runs for this project.","playtest.history.empty":"No test results yet","playtest.history.mode":"Mode","playtest.history.mode.tooltip":"Playtest mode used for this recorded test run.","playtest.history.status.passed":"Passed","playtest.history.status.failed":"Failed","playtest.history.status.running":"Running","playtest.history.status.unknown":"Unknown","playtest.history.status.tooltip":"Recorded result state for this automated playtest run.","playtest.empty.title":"No playtest results yet","playtest.empty.message":"Test results will appear here after the AI Agent runs a Playtest.","playtest.empty.message.before":"Test results will appear here after the AI Agent runs a Playtest.","playtest.empty.message.after":"","playtest.empty.runTest.tooltip":"Ask the AI Agent to run a Playtest when you need a fresh report.","playtest.report.title":"Selected Report","playtest.report.title.tooltip":"Detailed output for the currently selected automated playtest run.","playtest.report.content":"Report","playtest.report.content.tooltip":"Markdown summary for the selected automated playtest run.","playtest.report.logs":"Logs","playtest.report.logs.tooltip":"Execution logs captured for the selected automated playtest run.","playtest.context.contextId":"Context ID","playtest.context.why":"Why this test ran","playtest.context.expected":"Expected","playtest.context.observed":"Observed","playtest.report.empty":"No report content available","playtest.basic.icon":"🎮","playtest.basic.title":"Playtest is a Pro-only feature","playtest.basic.desc":"Control playtesting from the WEPPY Dashboard, run automated tests, and view detailed test reports.","playtest.basic.benefit1":"One-click play/pause/stop controls","playtest.basic.benefit2":"Automated test execution via AI agent","playtest.basic.benefit3":"Test history with pass/fail tracking","playtest.basic.benefit4":"Detailed markdown test reports","playtest.sample.badge":"Preview of the Pro playtest view","playtest.sample.title":"You are previewing the playtest screen that becomes available after upgrading to Pro.","playtest.sample.message":"This preview uses sample data. Live playtest control, history management, and real reports unlock with Pro.","playtest.sample.clearDisabled":"Available with Pro for live playtest history.","playtest.sample.place":"Arena Preview","playtest.sample.history.name":"Sample Arena Smoke Test","playtest.sample.context.why":"Spawn into the arena, survive the opener, and verify the HUD responds immediately.","playtest.sample.context.expected":"The player spawns safely, the countdown UI appears within one second, and the first wave starts without errors.","playtest.sample.context.observed":"Spawn protection held, the HUD updated on time, and wave one completed with no gameplay regressions.","playtest.sample.report.markdown":`# Sample Arena Smoke Test
70
+
71
+ - Spawn flow: PASS
72
+ - HUD countdown: PASS
73
+ - Wave bootstrap: PASS
74
+
75
+ This is a sample preview. Live playtests and real reports are available with Pro.`,"playtest.sample.report.logs":`[sample] boot playtest preview
76
+ [sample] spawn protection active
77
+ [sample] hud countdown rendered
78
+ [sample] wave one completed
79
+ [sample] preview report finished`,"sidebar.whatsNew":"What's New","sidebar.help.group":"Help & Feedback","sidebar.help.bug":"Report a bug","sidebar.help.bug.tooltip":"Create a local diagnostic bundle, then open a prefilled bug report on GitHub","bugReportDialog.title":"diagnostics.zip can help us investigate","bugReportDialog.subtitle":"WEPPY created a diagnostics zip on your computer. It includes Studio, plugin, Sync, and tool logs that can help us understand what happened.","bugReportDialog.close":"Close","bugReportDialog.loading":"Preparing diagnostics.zip...","bugReportDialog.error":"Could not create the diagnostics bundle. You can still open GitHub without diagnostics.","bugReportDialog.bundle":"Bundle","bugReportDialog.included":"Included","bugReportDialog.included.none":"No log files found","bugReportDialog.optional":"You can submit the bug report without this file, but attaching it usually helps us find the cause faster.","bugReportDialog.attachHow":"To attach it, download or reveal the zip, then add it to the Diagnostics ZIP (optional) upload field on GitHub before you submit.","bugReportDialog.download":"1. Download diagnostics.zip","bugReportDialog.reveal":"Reveal in Finder","bugReportDialog.reveal.opening":"Opening...","bugReportDialog.reveal.opened":"Opened location","bugReportDialog.reveal.failed":"Could not open the file location.","bugReportDialog.openGithub":"2. Open GitHub issue","bugReportDialog.openGithubFallback":"Open GitHub without diagnostics","bugReportDialog.retry":"Try again","bugReportDialog.hint":"The zip can contain local logs and project context. Review it before attaching if you want to share it.","sidebar.help.feature":"Suggest a feature","sidebar.help.feature.tooltip":"Suggest a new feature or improvement on GitHub","sidebar.help.discussions":"Support","sidebar.help.discussions.tooltip":"Ask questions or get install help through GitHub Issues","sidebar.help.troubleshooting":"Troubleshooting","sidebar.help.troubleshooting.tooltip":"Open the official troubleshooting guide on weppyai.com","header.whatsNew":"What's New","header.whatsNew.tooltip":"What's New","upgrade.title":"View Pro","upgrade.tagline":"Check Pro features","upgrade.cta":"View Pro","upgrade.licenseShortcut":"Enter License","upgrade.validUntil":"Until {{date}}","whatsNew.pageTitle":"What's New","whatsNew.pageSubtitle":"Stay up to date with MCP changes","whatsNew.unreadSection":"Unread","whatsNew.allSection":"All Announcements","whatsNew.empty":"No announcements yet","whatsNew.newBadge":"NEW","whatsNew.category.release":"Release","whatsNew.category.notice":"Notice","whatsNew.category.deprecation":"Deprecated","whatsNew.category.tip":"Tip","uiStudio.title":"UI Studio","uiStudio.empty":"No screenshots saved yet. They are created automatically when an AI agent captures the current UI state.","uiStudio.loading":"Loading…","uiStudio.pluginGuide.title":"Roblox Studio plugin is not connected","uiStudio.pluginGuide.message":"UI Studio shows screenshots and change history from the connected Studio place. It will update automatically after Studio and the WEPPY Plugin connect.","uiStudio.pluginGuide.check1":"Is Roblox Studio running?","uiStudio.pluginGuide.check2":"Is the WEPPY Plugin installed and running?","uiStudio.pluginGuide.waiting":"Waiting for plugin connection...","uiStudio.capturedAt":"Captured at","uiStudio.scope":"Scope","uiStudio.target":"Target","uiStudio.briefId":"Brief ID","uiStudio.detailClose":"Close","uiStudio.colCheck":"Check","uiStudio.colPriority":"Priority","uiStudio.colCurrent":"Current","uiStudio.colRecommended":"Recommended","uiStudio.colSuggestion":"Suggestion","uiStudio.priorityHigh":"Review first","uiStudio.priorityLow":"Optional improvement","uiStudio.highPrioritySection":"Review first","uiStudio.lowPrioritySection":"Optional improvements","uiStudio.groupSummary":"items","uiStudio.fixLabel":"Fix","uiStudio.copyFixCommand":"Copy AI instruction","uiStudio.copiedToClipboard":"Copied","uiStudio.fullPath":"Full path","uiStudio.falsePositiveWarning":"This group may contain false positives","uiStudio.noSuggestions":"No current improvement suggestions","uiStudio.sample.badge":"Preview of the Pro UI Studio","uiStudio.sample.title":"You are previewing the UI Studio that unlocks after upgrading to Pro.","uiStudio.sample.message":"This preview uses sample data from a demo inventory UI. Real screenshots, review history, and AI-driven fixes unlock with Pro.","uiStudio.tabs.analysis":"Analysis","uiStudio.tabs.history":"History","uiStudio.analysis.reportsTitle":"Latest Analysis by UI Target","uiStudio.analysis.recentCapturesTitle":"Recent Captures","uiStudio.analysis.detailDialog":"Analysis detail","uiStudio.analysis.targetCountLabel":"Targets analyzed","uiStudio.analysis.captureLabel":"Captures","uiStudio.analysis.verdict.hasSuggestions":"Improvement Suggestions","uiStudio.analysis.verdict.needsFix":"Improvement Suggestions","uiStudio.analysis.verdict.review":"Improvement Suggestions","uiStudio.analysis.verdict.passed":"No Current Suggestions","uiStudio.analysis.verdictLabel":"Improvement Summary","uiStudio.analysis.thresholds":"Review basis","uiStudio.analysis.issueSummary.passed":"No additional improvement suggestions under the current review basis.","uiStudio.history.title":"Change History","uiStudio.history.empty":"No history yet. When an AI agent modifies UI using manage_ui, it will be recorded automatically.","uiStudio.history.loading":"Loading...","uiStudio.history.error":"Error","uiStudio.history.clear":"Clear","uiStudio.history.filter.actions":"Action type","uiStudio.history.filter.actionAll":"All","uiStudio.history.filter.actionCreate":"Create","uiStudio.history.filter.actionUpdate":"Update","uiStudio.history.filter.actionDelete":"Delete","uiStudio.history.filter.period":"Period","uiStudio.history.filter.dateAll":"All","uiStudio.history.filter.today":"Today","uiStudio.history.filter.yesterday":"Yesterday","uiStudio.history.filter.last7Days":"Last 7 days","uiStudio.history.filter.last30Days":"Last 30 days","uiStudio.history.filter.customRange":"Custom range","uiStudio.history.filter.reset":"Reset","uiStudio.history.filter.from":"From","uiStudio.history.filter.to":"To","uiStudio.history.row.affectedPaths":"Paths","uiStudio.history.row.mutations":"Change details","uiStudio.history.row.expand":"▾ Expand","uiStudio.history.row.collapse":"▲ Collapse","uiStudio.history.row.expandDetails":"Show {n} change details","uiStudio.history.row.collapseDetails":"Hide change details","uiStudio.history.row.toggleDetails":"Toggle change details","uiStudio.history.row.mutationsEmpty":"No change details","uiStudio.history.row.toolLabel":"UI changes ({n})","uiStudio.history.row.compare":"Before / After","uiStudio.history.row.noBeforeState":"No before state","uiStudio.history.row.noAfterState":"No after state","uiStudio.history.row.qualityPlan":"Design direction","uiStudio.history.row.designCheck":"Suggestions","uiStudio.history.row.designCheckUnavailable":"Suggestions: unavailable","uiStudio.history.row.designCheckNone":"Suggestions: none","uiStudio.history.selection.deleteSelected":"Delete Selected","uiStudio.history.selection.selectAll":"Select All","uiStudio.history.selection.clearSelection":"Clear Selection","uiStudio.history.confirm.deleteRequestsTitle":"Delete Change Records","uiStudio.history.confirm.deleteRequestsMessage":"The selected change records will be deleted. This action cannot be undone.","uiStudio.history.confirm.clearRequestsTitle":"Clear Change History","uiStudio.history.confirm.clearRequestsMessage":"This clears the current place change history. Studio instances are not affected.","uiStudio.history.confirm.cascadeOption":"Also delete linked screenshots","uiStudio.history.drawer.close":"Close","uiStudio.actions.previewAgain":"Preview Again","uiStudio.actions.deleteSnapshot":"Delete This Screenshot","uiStudio.actions.proRequired":"Available after upgrading to Pro","uiStudio.actions.captureCurrentState":"Capture Current State","uiStudio.actions.checkSuggestionsAgain":"Re-check Suggestions","uiStudio.actions.previewRunning":"Capturing…","uiStudio.actions.previewRunningDetail":"The new screenshot file ID will appear when capture finishes.","uiStudio.actions.previewNeedsSaveCheck":"Capture complete, save needs review","uiStudio.actions.previewSaved":"New screenshot saved","uiStudio.actions.previewComplete":"Capture complete","uiStudio.actions.previewSavedDetail":"Existing screenshots are kept; this was saved as a new file.","uiStudio.actions.previewSavedPathMissing":"A new screenshot ID was returned, but the saved file path could not be confirmed.","uiStudio.actions.previewSnapshotIdMissing":"The new screenshot ID could not be confirmed. Refresh the list to verify whether it was saved.","uiStudio.actions.more":"More","uiStudio.gallery.selection.selectedCount":" selected","uiStudio.confirm.deleteSnapshotTitle":"Delete Screenshot","uiStudio.confirm.deleteSnapshotMessage":"Only this screenshot file will be deleted (the Studio instance is preserved).","uiStudio.confirm.deleteBatchTitle":"Delete Selected Screenshots","uiStudio.confirm.deleteBatchMessage":"The selected screenshots will be deleted. This action cannot be undone.","uiStudio.gallery.selectMode":"Select","uiStudio.gallery.exitSelectMode":"Cancel","uiStudio.gallery.selectAll":"Select All","uiStudio.gallery.clearSelection":"Clear Selection","uiStudio.gallery.deleteSelected":"Delete Selected","common.cancel":"Cancel","common.delete":"Delete","uiStudio.storage.title":"UI Studio Saved Data","uiStudio.storage.usageLabel":"In use","uiStudio.storage.historyBytes":"Change history","uiStudio.storage.snapshotBytes":"Screenshots","uiStudio.storage.requestCount":"Change records","uiStudio.storage.mutationCount":"Change details","uiStudio.storage.snapshotCount":"Screenshots","uiStudio.storage.countSuffix":"","uiStudio.storage.lastRun":"Last auto-cleanup","uiStudio.storage.lastRunNever":"—","uiStudio.storage.lastRunFreed":"freed","uiStudio.storage.lastRunErrors":"Errors","uiStudio.storage.loading":"Loading...","uiStudio.cleanup.policy.title":"Auto-delete Policy","uiStudio.cleanup.policy.modeOff":"Off","uiStudio.cleanup.policy.modeAge":"Age-based","uiStudio.cleanup.policy.modeSize":"Size-based","uiStudio.cleanup.policy.cascade":"Also delete linked screenshots","uiStudio.cleanup.policy.save":"Save Policy","uiStudio.cleanup.policy.runNow":"Run Now","uiStudio.cleanup.policy.proRequired":"Available after upgrading to Pro","uiStudio.cleanup.policy.daysUnit":"d","uiStudio.cleanup.policy.mbUnit":"MB","uiStudio.cleanup.policy.gbUnit":"GB","uiStudio.cleanup.policy.confirm.title":"Confirm Policy","uiStudio.cleanup.policy.confirm.messageStrict":"Applying this policy will immediately delete","uiStudio.cleanup.policy.confirm.requests":" change records","uiStudio.cleanup.policy.confirm.snapshots":" screenshots","uiStudio.cleanup.policy.confirm.freed":"freed — Apply?","uiStudio.cleanup.keepLastNDays":"Keep last {n} days","uiStudio.cleanup.selectedDelete":"Delete Selected…","uiStudio.cleanup.deleteAll":"Delete All…","uiStudio.cleanup.cleanupConfirmTitle":"Confirm Cleanup","uiStudio.cleanup.cleanupConfirmMessage":"All selected items will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.keep7":"Change records and screenshots older than 7 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.keep30":"Change records and screenshots older than 30 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.all":" saved change records and screenshots will be deleted. This action cannot be undone.","uiStudio.cleanup.label":"Manual cleanup","uiStudio.cleanup.studioPreservedNote":"This deletes saved change records and screenshots on disk only; Roblox Studio instances are not affected.","uiStudio.history.sample.bannerBadge":"Preview of the Pro change history","uiStudio.history.sample.bannerTitle":"You are previewing the UI change history that unlocks after upgrading to Pro.","uiStudio.history.sample.bannerMessage":"This preview uses sample data. Real change history, before/after comparison, and batch delete unlock with Pro.","uiStudio.fix.touchTarget.label":"Touch target size","uiStudio.fix.touchTarget.description":"Checks whether controls are large enough to tap comfortably on mobile.","uiStudio.fix.touchTarget.howToFix":"Increase button Size to at least 44x44 px or expand the touch area with UIPadding.","uiStudio.fix.contrast.label":"Text contrast","uiStudio.fix.contrast.description":"Checks whether text and background contrast meet accessibility guidance.","uiStudio.fix.contrast.howToFix":"Use a brighter TextColor3 or darken the BackgroundColor3.","uiStudio.fix.contrast.falsePositive":"Emoji icons may be false positives when their color is fixed.","uiStudio.fix.textScaled.label":"TextScaled usage","uiStudio.fix.textScaled.description":"TextScaled without UITextSizeConstraint can break layouts when text expands.","uiStudio.fix.textScaled.howToFix":"Add a UITextSizeConstraint child to the TextLabel and set MaxTextSize.","uiStudio.fix.safezone.label":"Safe-zone placement","uiStudio.fix.safezone.description":"Checks whether controls stay inside platform safe zones.","uiStudio.fix.safezone.howToFix":"Move Position inside the safe zone or reduce the parent Frame.","uiStudio.fix.minTextSize.label":"Minimum font size","uiStudio.fix.minTextSize.description":"Checks whether text is too small to read comfortably.","uiStudio.fix.minTextSize.howToFix":"Increase TextSize to at least 14 for body text.","uiStudio.sample.history.request1.label":"Initial HUD layout creation","uiStudio.sample.history.request2.label":"Inventory modal design update","uiStudio.sample.history.request3.label":"HUD HealthBar color update","uiStudio.sample.history.request4.label":"Expand Inventory tab button touch targets","uiStudio.sample.history.request5.label":"Remove Settings popup","uiStudio.sample.history.request6.label":"Add HUD minimap component","uiStudio.sample.history.request1.mutation1.diff":"Created Frame + HealthBar + StaminaBar","uiStudio.sample.history.request1.mutation2.diff":"BackgroundColor3 -> Color3.new(0.2,0.8,0.2)","uiStudio.sample.history.request1.mutation3.diff":"BackgroundColor3 -> Color3.new(0.1,0.6,1.0)","uiStudio.sample.history.request1.mutation4.diff":"Set AnchorPoint, Position, and Size","uiStudio.sample.history.request1.mutation5.diff":"Screenshot saved","uiStudio.sample.history.request2.mutation1.diff":"Darkened BackgroundColor3 for better contrast","uiStudio.sample.history.request2.mutation2.diff":"TextColor3 -> Color3.new(1,1,1), TextSize 16 -> 18","uiStudio.sample.history.request2.mutation3.diff":"BorderSizePixel 0 -> 2, set BorderColor3","uiStudio.sample.history.request2.mutation4.diff":"Screenshot saved","uiStudio.sample.history.request3.mutation1.diff":"BackgroundColor3 -> Color3.new(0.9,0.2,0.2) (red tone)","uiStudio.sample.history.request3.mutation2.diff":"Screenshot saved","uiStudio.sample.history.request4.mutation1.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation2.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation3.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation4.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation5.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation6.diff":"Screenshot saved","uiStudio.sample.history.request5.mutation1.diff":"Removed ScreenGui (Settings-only UI)","uiStudio.sample.history.request6.mutation1.diff":"Attempted to create Frame + MapImage + PlayerDot","uiStudio.sample.history.request6.mutation2.diff":"Set Size, Position, and BackgroundTransparency","uiStudio.sample.history.request6.mutation3.diff":"Interrupted by server restart while setting ImageLabel","uiStudio.sample.history.request6.mutation4.diff":"Partial screenshot saved","uiStudio.sample.history.request6.mutation3.error":"server_restart: connection lost","uiStudio.sample.history.request6.mutation4.error":"partial screenshot: missing layers","uiStudio.sample.history.detail.backgroundColor":"Background color","uiStudio.sample.history.detail.anchorPoint":"Anchor","uiStudio.sample.history.detail.position":"Position","uiStudio.sample.history.detail.size":"Size","uiStudio.sample.history.detail.textColor":"Text color","uiStudio.sample.history.detail.textSize":"Text size","uiStudio.sample.history.detail.borderSize":"Border size","uiStudio.sample.history.detail.borderColor":"Border color","settings.dataHistory.title":"Data & History","settings.dataHistory.title.tooltip":"Manage saved dashboard data in one place.","settings.dataHistory.collapse":"Collapse {title}","settings.dataHistory.expand":"Expand {title}","settings.dataHistory.scope":"Current project","settings.dataHistory.scope.tooltip":"Clear actions apply to the current project and active place where applicable.","settings.dataHistory.intro":"Review saved dashboard data, open the related page, or clear stored records from one place.","settings.dataHistory.toolsActivity.title":"Tool activity","settings.dataHistory.toolsActivity.description":"Saved tool runs shown on the Tools page.","settings.dataHistory.toolStats.title":"Tool usage statistics","settings.dataHistory.toolStats.description":"Aggregated tool counts and status totals.","settings.dataHistory.syncLog.title":"Sync log","settings.dataHistory.syncLog.description":"Saved file sync events for the active place.","settings.dataHistory.playtest.title":"Playtest reports","settings.dataHistory.playtest.description":"Saved automated playtest reports and logs.","settings.dataHistory.projectChanges.title":"Project change summary","settings.dataHistory.projectChanges.description":"Saved summaries of project changes.","settings.dataHistory.connectionLog.title":"Connection log","settings.dataHistory.connectionLog.description":"Saved MCP and Studio connection events.","settings.dataHistory.uiStudio.title":"UI Studio history and screenshots","settings.dataHistory.uiStudio.tooltip":"Manage saved UI Studio change records, screenshots, and auto-delete policy.","settings.dataHistory.uiStudio.description":"Saved UI Studio change records, screenshots, and cleanup policy.","settings.dataHistory.uiStudio.clear.title":"Clear UI Studio saved data?","settings.dataHistory.uiStudio.clear.message":"This deletes saved UI Studio change records and screenshots only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.uiStudio.clear.success":"UI Studio saved data cleared.","settings.dataHistory.uiStudio.clear.failed":"Failed to clear UI Studio saved data.","settings.dataHistory.metric.unavailable":"Unavailable","settings.dataHistory.metric.sizeUnavailable":"size unavailable","settings.dataHistory.metric.records":"records","settings.dataHistory.metric.runs":"runs","settings.dataHistory.metric.sessions":"sessions","settings.dataHistory.metric.reports":"reports","settings.dataHistory.open":"Open","settings.dataHistory.clear.title":"Clear saved data?","settings.dataHistory.clear.message":"This deletes saved dashboard records only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.clear.success":"Saved data cleared.","settings.dataHistory.clear.failed":"Failed to clear saved data.","uiStudio.history.sample.tooltip":"Full history is available with Pro","toast.serverConnected":"MCP server connected","toast.serverDisconnected":"MCP server disconnected","toast.pluginConnected":"Plugin connected","toast.pluginDisconnected":"Plugin disconnected","toast.clearSuccess":"Cleared successfully","toast.clearFailed":"Failed to clear data","common.clear":"Clear","settings.license.activate":"Activate License","settings.license.refresh":"Refresh License","settings.license.keyInput":"License Key","settings.license.disconnected":"Disconnected","settings.license.disconnected.tooltip":"Reconnect to the MCP server to manage license actions from WEPPY Dashboard.","settings.license.live.tooltip":"License actions are sent to the MCP server immediately.","settings.license.status.activationRequired":"Activation Required","settings.license.status.activationRequired.tooltip":"Manual license activation is required before WEPPY Dashboard can refresh this status.","settings.license.status.grace":"Grace","settings.license.status.grace.tooltip":"Provider verification is temporarily unavailable, but Pro access remains active during the grace period.","settings.license.status.graceBilling.tooltip":"Pro access is still available during a billing-related grace period.","settings.license.detail.graceBilling":"Pro access remains available during a billing grace period.","settings.license.detail.graceProviderUnavailable":"Provider unavailable. Pro access remains active during grace mode.","settings.license.detail.manualActivation":"Manual activation required to restore Pro access.","settings.license.detail.missingSessionToken":"Refresh is blocked because the current session token is missing.","settings.license.detail.refreshRecommended":"License verification should be refreshed soon.","connection.agents.kill":"Kill","connection.agents.kill.title":"Kill agent?","connection.agents.killed":"Agent killed","connection.agents.killFailed":"Failed to kill agent","connection.agents.lastCommand":"Last Command","connection.agents.lastCommand.tooltip":"Most recent tool call executed by this agent","connection.agents.lastSeen":"Last Seen","connection.agents.lastSeen.tooltip":"Most recent heartbeat or activity from this agent","connection.clear.title":"Clear connection log?","connection.clear.message":"This permanently removes the stored connection log for the current project.","sync.clear.title":"Clear sync log?","sync.clear.message":"This permanently removes the stored sync log for the current place.","playtest.clear.title":"Clear test history?","playtest.clear.message":"This permanently removes the stored playtest reports for the current place.","changelog.clear.title":"Clear changelog?","changelog.clear.message":"This permanently removes the stored changelog for the current place.","sync.status.placePath":"Place Path","sync.status.placePath.tooltip":"Active place directory where explorer files are synced.","tier.progress.label":"Pro / Total","changelog.card.representativeArea":"Representative area","changelog.card.verification":"Verification","uiStudio.tabs.analysis.tooltip":"Browse AI-captured UI screens and quickly find which UIs need improvement.","uiStudio.tabs.history.tooltip":"Every UI change AI made, in order. Compare before and after screens.","uiStudio.title.tooltip":"A central place to review AI-generated UI screens and improvement suggestions.","uiStudio.analysis.reportsTitle.tooltip":"Shows the latest capture and suggestion summary per UI (e.g., Inventory window, Main menu).","uiStudio.analysis.verdict.hasSuggestions.tooltip":"Some improvements were found in this UI. Click the card for details.","uiStudio.analysis.verdict.passed.tooltip":"No improvements suggested under the current review thresholds.","uiStudio.analysis.counts.tooltip":"‘Main’ are key items to review first; ‘Notes’ are nice-to-have refinements.","uiStudio.analysis.thresholds.tooltip":"The threshold set used for this review (default or custom).","uiStudio.analysis.recentCapturesTitle.tooltip":"All recently saved captures in chronological order.","uiStudio.gallery.selectAll.tooltip":"Select every visible capture at once.","uiStudio.gallery.clearSelection.tooltip":"Clear the current selection.","uiStudio.gallery.deleteSelected.tooltip":"Delete only the selected capture files. The actual UI in Roblox Studio is not affected.","uiStudio.gallery.cardCheckbox.tooltip":"Select this capture. Pick multiple to delete them together.","uiStudio.detailClose.tooltip":"Close this detail panel.","uiStudio.actions.captureCurrentState.tooltip":"Save the UI currently shown in Studio as a new capture. Existing captures are kept.","uiStudio.actions.checkSuggestionsAgain.tooltip":"Recompute suggestions for this capture without taking a new screenshot.","uiStudio.actions.more.tooltip":"Open additional actions.","uiStudio.actions.deleteSnapshot.tooltip":"Delete only this capture file. The actual UI in Roblox Studio is not affected.","uiStudio.capturedAt.tooltip":"When this screen was captured.","uiStudio.scope.tooltip":"Capture scope (full screen or a specific UI).","uiStudio.target.tooltip":"Exact path of the captured UI instance.","uiStudio.briefId.tooltip":"Identifier of the design brief that produced this UI.","uiStudio.analysis.verdictLabel.tooltip":"Overall improvement verdict for this capture.","uiStudio.suggestionGroup.tooltip":"Suggestions of the same kind grouped together. Click to expand or collapse.","uiStudio.groupSummary.tooltip":"Number of UI elements matching this group.","uiStudio.colCurrent.tooltip":"The currently applied value.","uiStudio.colRecommended.tooltip":"The recommended value.","uiStudio.copyFixCommand.tooltip":"Copy a prompt that asks the AI to fix this issue.","uiStudio.falsePositiveWarning.tooltip":"This check can produce false positives — verify before applying.","uiStudio.history.filter.actions.tooltip":"Filter records by the kind of change AI made.","uiStudio.history.filter.period.tooltip":"Filter records by time range.","uiStudio.history.filter.from.tooltip":"Start date for the query.","uiStudio.history.filter.to.tooltip":"End date for the query.","uiStudio.history.filter.actionAll.tooltip":"Show every kind of action.","uiStudio.history.filter.actionCreate.tooltip":"Show only actions that created a new UI.","uiStudio.history.filter.actionUpdate.tooltip":"Show only actions that updated an existing UI.","uiStudio.history.filter.actionDelete.tooltip":"Show only actions that deleted a UI.","uiStudio.history.filter.dateAll.tooltip":"Show the full history.","uiStudio.history.filter.today.tooltip":"Show only changes from today.","uiStudio.history.filter.yesterday.tooltip":"Show only changes from yesterday.","uiStudio.history.filter.last7Days.tooltip":"Show changes from the last 7 days.","uiStudio.history.filter.last30Days.tooltip":"Show changes from the last 30 days.","uiStudio.history.filter.customRange.tooltip":"Pick a custom start and end date.","uiStudio.history.filter.reset.tooltip":"Reset all filters to defaults.","uiStudio.history.title.tooltip":"A timeline of every UI change made by AI.","uiStudio.history.clear.tooltip":"Delete every change record for this project. The actual UI in Roblox Studio is not affected.","uiStudio.history.row.compare.tooltip":"Compare the before and after screens. Click to open the full comparison view.","uiStudio.history.row.extraPaths.tooltip":"Number of additional UIs changed in this action.","uiStudio.history.row.noBeforeState.tooltip":"No capture saved before this change.","uiStudio.history.row.noAfterState.tooltip":"No capture saved after this change.","uiStudio.history.row.affectedPaths.tooltip":"Number of UIs affected by this action.","uiStudio.history.row.mutations.tooltip":"Number of detailed changes (e.g., property edits).","uiStudio.history.row.qualityPlan.tooltip":"Brief design direction used for this change.","uiStudio.history.row.designCheck.tooltip":"Post-change Design Check suggestion summary.","uiStudio.history.row.toggleDetails.tooltip":"Show or hide a per-line breakdown of what changed.","uiStudio.compare.before.tooltip":"The screen saved just before AI made the change.","uiStudio.compare.after.tooltip":"The screen saved just after AI made the change.","uiStudio.compare.path.tooltip":"The UI instance path for this screen.","uiStudio.storage.title.tooltip":"Disk usage of UI Studio change records and screenshots.","uiStudio.storage.usageLabel.tooltip":"Disk space currently used by UI Studio for this project.","uiStudio.storage.historyBytes.tooltip":"Space taken by change record data (JSON).","uiStudio.storage.snapshotBytes.tooltip":"Space taken by captured PNG image files.","uiStudio.storage.requestCount.tooltip":"Number of actions where AI changed the UI.","uiStudio.storage.mutationCount.tooltip":"Number of detail changes inside actions (one property edit = 1).","uiStudio.storage.snapshotCount.tooltip":"Number of saved capture image files.","uiStudio.storage.lastRun.tooltip":"When the auto-cleanup policy last ran, and what it removed.","uiStudio.cleanup.label.tooltip":"Manually clean up change records and captures whenever you want.","uiStudio.cleanup.keep7.tooltip":"Delete change records and captures older than 7 days.","uiStudio.cleanup.keep30.tooltip":"Delete change records and captures older than 30 days.","uiStudio.cleanup.deleteAll.tooltip":"Delete every change record and capture for this project. The actual UI in Roblox Studio is not affected.","uiStudio.cleanup.policy.title.tooltip":"Rules that automatically remove old or large captures.","uiStudio.cleanup.policy.modeOff.tooltip":"Turn off auto-cleanup. Data stays until you remove it manually.","uiStudio.cleanup.policy.modeAge.tooltip":"Automatically delete data older than the configured number of days.","uiStudio.cleanup.policy.modeSize.tooltip":"When total usage exceeds the limit, the oldest data is removed first.","uiStudio.cleanup.policy.agePreset.tooltip":"Delete data older than this many days.","uiStudio.cleanup.policy.ageInput.tooltip":"Enter any value between 1 and 365 days.","uiStudio.cleanup.policy.sizePreset.tooltip":"Keep total usage under this size.","uiStudio.cleanup.policy.sizeInput.tooltip":"Enter any value between 50 MB and 10000 MB (10 GB).","uiStudio.cleanup.policy.cascade.tooltip":"Also delete the capture images linked to those records. If off, the images stay.","uiStudio.cleanup.policy.save.tooltip":"Save the current cleanup rule. It runs in the background from then on.","uiStudio.cleanup.policy.runNow.tooltip":"Run the current rule once now, without waiting for the next scheduled run.","settings.license.refresh.tooltip":"Re-fetch the current state from the license server. Useful when a billing change hasn't appeared yet.","settings.license.reset.tooltip":"Remove the currently registered license key. Use this before activating with a different key.","settings.license.activate.tooltip":"Activate Pro features with the entered license key.","tier.upgrade.tooltip":"View Pro features and purchase options.","settings.language.auto.tooltip":"Follow the operating system's language. Falls back to English when not supported.","settings.dataHistory.open.tooltip":"Open the page that shows this item in detail.","settings.dataHistory.clear.tooltip":"Delete only the records saved for this item. Roblox Studio data is not changed.","settings.dataHistory.toggle.tooltip":"Collapse or expand this section.","settings.dataHistory.toolsActivity.metric.tooltip":"Number of saved tool runs and the disk space they use.","settings.dataHistory.toolStats.metric.tooltip":"Aggregated total runs and session counts.","settings.dataHistory.syncLog.metric.tooltip":"Number of saved sync events and the disk space they use.","settings.dataHistory.playtestReports.metric.tooltip":"Number of saved playtest reports and the disk space they use.","settings.dataHistory.projectChanges.metric.tooltip":"Number of saved project change summaries and the disk space they use.","settings.dataHistory.connectionLog.metric.tooltip":"Number of saved connection events and the disk space they use.","settings.dataHistory.uiStudio.metric.tooltip":"UI Studio change record and capture counts, plus total disk usage.","uiStudio.designCheckResultsTitle":"Design Check suggestions","uiStudio.designCheckResultsTitle.tooltip":"All improvement suggestions found in this capture.","uiStudio.actions.designCheckAgain":"Check again","uiStudio.actions.designCheckRunning":"Checking suggestions...","uiStudio.actions.designCheckRunningDetail":"Review first, recommended, and optional item counts will appear when the check finishes.","uiStudio.actions.designCheckComplete":"Suggestion check complete","uiStudio.actions.designCheckNoSnapshotSaved":"This action does not save a new screenshot file.","uiStudio.sample.designCheck.contrast":"Text contrast is below {expected} (current {actual}). Adjust TextColor3 or BackgroundColor3.","uiStudio.sample.designCheck.touchTarget":"Touch target is below {expected} (current {actual}). Increase Size or padding.","uiStudio.sample.designCheck.minTextSize":"TextSize is below {expected} (current {actual}). Increase it for readability.","uiStudio.gallery.priorityHighBadge.tooltip":"Number of suggestions to review first. Click for details.","uiStudio.gallery.priorityMediumBadge.tooltip":"Number of recommended suggestions.","uiStudio.priorityMedium":"Review recommended","uiStudio.mediumPrioritySection":"Review recommended","uiStudio.gallery.priorityLowBadge.tooltip":"Number of optional improvements.","tier.banner.progressLabel":"Pro / Total","uiStudio.error":"Error","uiStudio.analysis.expandChildren":"Show child targets","uiStudio.analysis.openDetail":"Open detail","uiStudio.analysis.childTargets":"Child targets","uiStudio.analysis.childDetailHint":"Open child target detail","uiStudio.compare.before":"Before","uiStudio.compare.after":"After","uiStudio.history.drawer.changeDetails":"Change details","uiStudio.gallery.cardCheckbox":"Select screenshot","sidebar.assets":"Assets","assets.title":"Assets","assets.experimental":"Experimental","assets.subtitle":"Browse local originals, upload to Roblox, and inspect synced usage by place.","assets.scope.label":"Asset scope","assets.scope.place":"Current Place","assets.scope.shared":"Shared","assets.count.shown":"Shown assets: {count}","assets.category.filter":"Category","assets.category.all":"All","assets.category.image":"Images","assets.category.decal":"Decals","assets.category.audio":"Audio","assets.category.mesh":"Meshes","assets.category.model":"Models","assets.category.rbxm":"RBXM","assets.category.video":"Videos","assets.category.animation":"Animations","assets.category.comingSoon":"Coming soon","assets.status.localOnly":"Local only","assets.status.uploading":"Uploading","assets.status.processing":"Processing","assets.status.uploaded":"Uploaded","assets.status.failed":"Failed","assets.status.superseded":"Superseded","assets.rescan":"Rescan","assets.rescan.tooltip":"Scan inbox folders for the current filter.","assets.rescan.chooseCategory":"Choose a category before rescanning.","assets.rbxmGuide.title":"Save RBXM from Studio","assets.rbxmGuide.body":"Select objects in Roblox Studio, then use WEPPY Plugin > Assets to save the selection as a local RBXM asset.","assets.rbxmGuide.thumbnail":"The plugin save flow includes a thumbnail option, and saved RBXM assets appear here for management, upload, and insertion.","assets.exportSelection":"Export Studio selection","assets.exportSelection.tooltip":"Export the current Studio selection as a local .rbxm asset.","assets.exportSelection.chooseCategory":"Choose RBXM before exporting a Studio selection.","assets.upload.open":"Upload","assets.upload.open.tooltip":"Upload this local file to Roblox through Open Cloud.","assets.upload.selectFirst":"Select an asset first.","assets.upload.title":"Upload asset","assets.upload.checkingSettings":"Checking upload settings...","assets.upload.settingsLoadFailed":"Failed to load upload settings.","assets.upload.settingsRequired":"Upload settings required","assets.upload.settingsRequired.apiKey":"Save an Open Cloud API key before uploading.","assets.upload.settingsRequired.toggle":"Enable Open Cloud upload before uploading.","assets.upload.settingsRequired.creator":"Save a default Creator before uploading.","assets.upload.openSettings":"Open Asset Library settings","assets.upload.creator":"Creator","assets.upload.creatorType":"Creator type","assets.upload.creatorId":"Creator ID","assets.upload.envCreatorHelp":"Environment API keys cannot save a default Creator here. Enter the Creator for this upload.","assets.upload.displayNameHelp":"Saved to Roblox as the asset display name.","assets.upload.descriptionHelp":"Saved to Roblox as the asset description.","assets.upload.creatorHelp":"Used by Open Cloud as the owner of the uploaded asset.","assets.upload.creatorTypeHelp":"Sent to Open Cloud as the Creator type.","assets.upload.creatorIdHelp":"Sent to Open Cloud as the User or Group ID that owns the uploaded asset.","assets.upload.submit":"Upload with Roblox Open Cloud","assets.upload.uploading":"Uploading...","assets.upload.noDelete":"WEPPY does not provide Roblox asset deletion.","assets.upload.delay":"Roblox processing and moderation can delay visibility in Studio or Creator Dashboard.","assets.delete.tooltip":"Delete this local Asset Library item.","assets.delete.title":"Delete asset","assets.delete.message":"This removes the local Asset Library files only. Uploaded Roblox assets are not deleted.","assets.creator.user":"User","assets.creator.group":"Group","assets.settings.open":"Open settings","assets.settings.open.tooltip":"Open Roblox upload settings.","assets.settings.title":"Asset Library settings","assets.settings.proOnly":"Roblox upload settings and Open Cloud credential controls are available on Pro.","assets.settings.openCloudToggle":"Roblox Open Cloud uploads","assets.settings.openCloudToggle.help":"Allow WEPPY to upload Asset Library items to Roblox through the selected Open Cloud credential profile.","assets.settings.apiKey":"Open Cloud API Key","assets.settings.apiKeyGuide":"Create a Roblox API key with Assets Read and Write permissions.","assets.settings.creatorHelp":"Use the numeric user ID from a profile URL or group ID from a group URL.","assets.settings.credential.none":"No API key saved","assets.settings.credential.env":"Environment variable","assets.settings.credential.local":"Local encrypted file","assets.settings.registeredApiKey":"Registered API Key","assets.settings.credentialProfile":"Credential Profile","assets.settings.activeProfileBadge":"Active","assets.settings.field.profile":"Profile","assets.settings.field.apiKey":"API Key","assets.settings.field.storage":"Storage","assets.settings.field.validationStatus":"Validation status","assets.settings.field.creators":"Creators","assets.settings.validation.unknown":"Not tested","assets.settings.validation.valid":"Connected","assets.settings.validation.invalid":"Needs attention","assets.settings.profileSelected":"Open Cloud credential profile selected.","assets.settings.useProfile":"Use profile","assets.settings.replaceApiKey":"Replace API Key","assets.settings.profileLabel":"Profile name (optional)","assets.settings.profileLabel.placeholder":"Studio automation key","assets.settings.profileLabel.help":"Optional. If left blank, WEPPY saves this profile as Open Cloud key automatically.","assets.settings.saveApiKey":"Save API Key","assets.settings.testConnection":"Test Connection","assets.settings.removeApiKey":"Unregister API Key","assets.settings.saveCreator":"Save default Creator","assets.settings.saveCreatorPreset":"Save Creator","assets.settings.addCreator":"Add Creator","assets.settings.addCreator.tooltip.ready":"Add another User or Group Creator preset to this profile.","assets.settings.cancelCreator":"Cancel","assets.settings.defaultCreatorBadge":"Default","assets.settings.makeDefaultCreator":"Make default","assets.settings.unregisterCreator":"Unregister Creator","assets.settings.creatorLabel":"Creator label (optional)","assets.settings.creatorLabel.placeholder":"Main studio group","assets.settings.creatorLabel.help":"Optional. If left blank, WEPPY automatically saves a label like User 123 or Group 456.","assets.settings.action.proRequired":"Asset upload settings are available on Pro.","assets.settings.action.busy":"Wait for the current settings action to finish.","assets.settings.saveApiKey.tooltip.ready":"Save this API key to local encrypted storage.","assets.settings.saveApiKey.tooltip.enter":"Enter an Open Cloud API key to save it locally.","assets.settings.testConnection.tooltip.entered":"Test the entered API key before saving it.","assets.settings.testConnection.tooltip.saved":"Test the saved Open Cloud API key.","assets.settings.testConnection.tooltip.enterOrSaved":"Enter an API key or save one before testing the connection.","assets.settings.removeApiKey.tooltip.ready":"Unregister the locally saved Open Cloud API key from WEPPY.","assets.settings.removeApiKey.tooltip.none":"No local Open Cloud API key is saved.","assets.settings.removeApiKey.tooltip.env":"Environment API keys cannot be removed from Dashboard. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY.","assets.settings.unregisterCreator.tooltip.ready":"Unregister this Creator from the selected profile.","assets.settings.unregisterApiKey.title":"Unregister API Key?","assets.settings.unregisterApiKey.message":"Roblox API key is not revoked. WEPPY only removes the local Credential Profile registration on this device.","assets.settings.unregisterCreator.title":"Unregister Creator?","assets.settings.unregisterCreator.message":"Roblox user or group is not deleted. WEPPY only removes this Creator from the selected API Key profile.","assets.settings.saveCreator.tooltip.ready":"Save this Creator as the default owner for uploads.","assets.settings.saveCreator.tooltip.noLocal":"Save a local Open Cloud API key before saving a default Creator.","assets.settings.saveCreator.tooltip.env":"Environment API keys cannot save a default Creator here. Enter Creator details in the upload dialog.","assets.settings.saveCreator.tooltip.enterId":"Enter a user or group ID before saving the default Creator.","assets.settings.apiKeySaved":"Open Cloud API key saved locally.","assets.settings.apiKeyTested":"Open Cloud API key connection tested.","assets.settings.apiKeyRemoved":"Open Cloud API key unregistered from local storage.","assets.settings.envApiKeyStillActive":"Environment variable credential is still active. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY Dashboard.","assets.settings.defaultCreatorSaved":"Open Cloud default Creator saved locally.","assets.settings.creatorUnregistered":"Creator unregistered from this profile.","assets.settings.creatorUnregisterFailed":"Failed to unregister Creator.","assets.settings.saved":"Upload settings saved.","assets.settings.saveFailed":"Failed to save upload settings.","assets.settings.loadFailed":"Failed to load upload settings.","assets.settings.tested":"Connection tested.","assets.settings.testFailed":"Connection test failed.","assets.settings.removed":"API key unregistered.","assets.settings.removeFailed":"Failed to unregister API key.","assets.basic.notice":"Browse, preview, edit metadata, and scan usage on Basic. Roblox upload controls are available on Pro.","assets.proOnly.tooltip":"Roblox upload is available on Pro.","assets.proOnly.upload":"Roblox upload is available on Pro.","assets.empty.title":"No assets yet","assets.empty.body":"Choose a scope, then rescan inbox folders for the current filter.","assets.detail.title":"Asset details","assets.detail.displayName":"Display name","assets.detail.description":"Description","assets.detail.save":"Save metadata","assets.detail.refreshStatus":"Refresh","assets.detail.scanUsage":"Scan usage","assets.detail.localFile":"Local file","assets.detail.fileName":"File","assets.detail.category":"Category","assets.detail.scope":"Scope","assets.detail.mimeType":"Type","assets.detail.size":"Size","assets.detail.dimensions":"Dimensions","assets.detail.duration":"Duration","assets.detail.source":"Source path","assets.detail.sha256":"SHA-256","assets.detail.roblox":"Roblox upload status","assets.detail.status":"Status","assets.detail.assetId":"Asset ID","assets.detail.error":"Error","assets.detail.copyAssetId":"Copy Asset ID","assets.detail.copyUri":"Copy URI","assets.detail.studioUri":"Studio URI","assets.detail.robloxWebUrl":"Creator Dashboard URL","assets.detail.copyStudioUri":"Copy Studio URI","assets.detail.copyWebUrl":"Copy configure URL","assets.detail.openRobloxPage":"Open configure page","assets.detail.robloxWebUrlNotice":"Opening this page requires the Roblox account that owns or can manage the uploaded asset.","assets.detail.uploadHistory":"Upload history","assets.detail.usedInPlace":"Where this asset is used in this Place","assets.detail.noUsage":"No local Sync references found yet.","assets.detail.usageSource":"Checked against","assets.detail.usageSource.localSync":"Local Sync files","assets.detail.usageSource.notScanned":"Not checked yet","assets.detail.lastScanned":"Last checked","assets.detail.lastScannedAt":"Last checked: {time}","assets.detail.lastScanned.never":"No check yet","assets.detail.noUsageUnscanned":"Run Scan usage to search local Sync files for this Roblox Asset ID.","assets.detail.noUsageAfterScan":"No references were found in local Sync files during the last check.","assets.detail.noUsageNoRobloxId":"This asset does not have a Roblox Asset ID yet, so usage cannot be checked. Upload it before scanning usage.","assets.detail.technicalDetails":"Technical details","assets.detail.stableId":"Stable ID","assets.detail.sourceKind":"Source kind","assets.detail.createdAt":"Created","assets.detail.updatedAt":"Updated","assets.detail.operationId":"Operation ID","assets.detail.operationPath":"Operation path","assets.detail.versionId":"Version ID","assets.detail.remotePath":"Remote path","assets.detail.moderationState":"Moderation","assets.detail.line":"line {line}","assets.studio.notConnected":"Connect Roblox Studio before using Studio asset actions.","assets.detail.importRbxm":"Insert into Studio","assets.detail.importRbxm.tooltip":"Insert this local RBXM asset into {target} in the connected Studio place.","assets.detail.generateThumbnail":"Generate thumbnail","assets.detail.generateThumbnail.tooltip":"Create or replace the Asset Library thumbnail from Studio.","assets.detail.rbxmOnly":"Studio import is available for .rbxm assets.","assets.detail.rbxmCategoryOnly":"Studio .rbxm actions support models and animations.","assets.detail.thumbnailRbxmOnly":"Thumbnail generation is available for .rbxm model assets.","assets.detail.thumbnailModelOnly":"Thumbnail generation is available for model .rbxm assets.","assets.detail.rbxm":"RBXM contents","assets.detail.rbxmExportedCount":"Exported roots","assets.detail.rbxmClasses":"Classes","assets.detail.rbxmThumbnail":"Thumbnail","assets.detail.studioInsertTarget":"Studio insert target","assets.detail.rbxmRoots":"Root tree","assets.detail.rbxmReferences":"Asset references","assets.detail.rbxmThumbnailAttempts":"Thumbnail attempts","dashboardHelp.button":"Help","dashboardHelp.pageButton.ariaLabel":"Open page help","dashboardHelp.fieldButton.ariaLabel":"Open field help","dashboardHelp.section.canDo":"What you can do here","dashboardHelp.section.needs":"What you need to use it","dashboardHelp.section.links":"Related links","dashboardHelp.overview.title":"Overview help","dashboardHelp.overview.canDo.1":"Check MCP server, WEPPY Plugin, AI Agent, Sync, and recent game changes in one place.","dashboardHelp.overview.needs.1":"Useful status requires the MCP server. Live Studio status also needs WEPPY Plugin connected to the active place.","dashboardHelp.connection.title":"Connection help","dashboardHelp.connection.canDo.1":"Inspect server process details, connected AI agents, Studio plugin clients, and connection log events.","dashboardHelp.connection.needs.1":"The MCP server must be reachable. Plugin rows appear after Studio sends heartbeats.","dashboardHelp.sync.title":"Sync help","dashboardHelp.sync.canDo.1":"Review Studio to local sync status, direction, apply mode, and sync logs.","dashboardHelp.sync.needs.1":"Sync needs an active place and connected WEPPY Plugin. Two-way and reverse workflows depend on Pro.","dashboardHelp.assets.title":"Assets help","dashboardHelp.assets.canDo.1":"Browse local Asset Library files, switch place/shared scope, filter categories, scan usage, insert RBXM into Studio, and upload local assets to Roblox.","dashboardHelp.assets.needs.1":"Upload needs Pro, the Open Cloud upload toggle, a valid API Key, and a Creator. Browse and preview work on Basic.","dashboardHelp.changelog.title":"Changelog help","dashboardHelp.changelog.canDo.1":"Review real game-change sessions extracted from AI actions and sync events.","dashboardHelp.changelog.needs.1":"Entries are scoped to the active place. Basic shows only the latest preview entries.","dashboardHelp.playtest.title":"Playtest help","dashboardHelp.playtest.canDo.1":"Review Playtest results and reports saved by the AI Agent.","dashboardHelp.playtest.needs.1":"Pro shows real stored reports. Basic shows sample preview data. Live active-place confidence needs WEPPY Plugin connected.","dashboardHelp.uiStudio.title":"UI Studio help","dashboardHelp.uiStudio.canDo.1":"Review AI-created UI analysis, improvement suggestions, captures, and before/after history.","dashboardHelp.uiStudio.needs.1":"Pro shows real UI Studio data. Basic shows a bundled sample. New capture/check actions need WEPPY Plugin connected.","dashboardHelp.tools.title":"Tools help","dashboardHelp.tools.canDo.1":"Inspect tool history, status classification, fallback/unsupported/warn/error details, and usage statistics.","dashboardHelp.tools.needs.1":"History and statistics depend on local recording settings and the active place bucket.","dashboardHelp.settings.title":"Settings help","dashboardHelp.settings.canDo.1":"Manage License, hot settings, saved data cleanup, server environment display, and language.","dashboardHelp.settings.needs.1":"License actions need MCP server connection. Server environment values are read-only here. Asset upload controls live in Assets settings.","dashboardHelp.openCloudApiKey.title":"Open Cloud API Key help","dashboardHelp.openCloudApiKey.canDo.1":"WEPPY uses this key only for Roblox Open Cloud requests.","dashboardHelp.openCloudApiKey.needs.1":"Create a Roblox API key in Creator Hub. Add Assets under Access Permissions, then enable both Read and Write operations.","dashboardHelp.openCloudApiKey.needs.2":"Set the key target to the same User or Group that you use as the upload Creator.","dashboardHelp.openCloudApiKey.needs.3":"The raw key is encrypted on this device. It is not sent to WEPPY servers, and it is not stored in any other external storage, browser storage, telemetry, logs, tool history, or Asset Library metadata.","dashboardHelp.openCloudApiKey.link.apiKeys":"Roblox API keys","dashboardHelp.openCloudApiKey.link.assetsGuide":"Assets API usage guide","dashboardHelp.openCloudApiKey.link.assetsReference":"Assets API reference","dashboardHelp.openCloudCreatorId.title":"Creator ID help","dashboardHelp.openCloudCreatorId.canDo.1":"The default Creator decides which User or Group owns newly uploaded Roblox assets.","dashboardHelp.openCloudCreatorId.needs.1":"For User, sign in to roblox.com, open your profile from your avatar or username, then copy only the number between /users/ and /profile in the browser URL.","dashboardHelp.openCloudCreatorId.needs.2":"For Group, open the Roblox group or community page, then copy only the number after /groups/ or /communities/ in the browser URL.","dashboardHelp.openCloudCreatorId.needs.3":"Paste only the numeric ID in Creator ID. Do not paste the full URL, rbxassetid://, User, or Group text.","dashboardHelp.openCloudCreatorId.link.creatorId":"Creator ID reference","dashboardHelp.openCloudCreatorId.link.userId":"User ID reference","dashboardHelp.openCloudCreatorId.link.groups":"Roblox groups","dashboardHelp.openCloudCreatorId.link.groupsApi":"Groups Cloud API","assets.settings.apiKey.inlineHelp":"WEPPY uses this key only for Roblox Open Cloud requests. The key is encrypted on this device and is not sent to WEPPY servers or stored in any other external storage.","assets.settings.creatorId.inlineHelp":"Default owner for new Roblox assets: your User ID or a Group ID.","common.close":"Close","dashboardHelp.section.currentState":"Check based on current status","dashboardHelp.overview.currentState.serverOnly":"Open Roblox Studio and start WEPPY Plugin so live place data can appear.","dashboardHelp.overview.currentState.default":"If the server disconnects, restart MCP or wait for the automatic reconnect.","dashboardHelp.connection.currentState.1":"If Plugin is missing, open Roblox Studio and run WEPPY Plugin. If AI Agent is missing, reconnect the MCP server from your AI tool.","dashboardHelp.sync.currentState.pluginMissing":"Connect WEPPY Plugin in Studio before using live sync details.","dashboardHelp.sync.currentState.basic":"Activate Pro to use bidirectional or reverse sync.","dashboardHelp.sync.currentState.default":"Use the sync log to diagnose stuck or failed sync activity.","dashboardHelp.assets.currentState.basic":"Activate Pro before uploading to Roblox.","dashboardHelp.assets.currentState.uploadDisabled":"Turn on Open Cloud upload in Assets settings.","dashboardHelp.assets.currentState.noCredential":"Save and test an Open Cloud API Key.","dashboardHelp.assets.currentState.noCreator":"Save a default Creator ID or enter Creator details during upload.","dashboardHelp.assets.currentState.default":"Open an asset detail dialog to start upload or usage scan.","dashboardHelp.changelog.currentState.1":"If the list is empty, ask the AI Agent to make a game change. Clear only deletes saved history records, not Studio objects.","dashboardHelp.playtest.currentState.basic":"Activate Pro to use real Playtest history.","dashboardHelp.playtest.currentState.default":"Ask the AI Agent to run a Playtest when no report is available.","dashboardHelp.uiStudio.currentState.basic":"Activate Pro to use live UI Studio previews.","dashboardHelp.uiStudio.currentState.default":"Ask the AI Agent to capture the UI or recheck improvement suggestions, then copy follow-up requests back to the AI chat.","dashboardHelp.tools.currentState.1":"If no records appear, check Settings > General and confirm history/statistics are enabled. Expand failed rows to inspect input, permission, or connection causes.","dashboardHelp.settings.currentState.1":"Activate a license for Pro features. Change environment values outside WEPPY Dashboard, then restart MCP. Review delete confirmations before clearing saved data.","dashboardHelp.openCloudApiKey.currentState.saved":"Use Test Connection to confirm the saved key still works.","dashboardHelp.openCloudApiKey.currentState.empty":"Create an API key in Roblox Creator Hub, paste it here, then save and test it.","dashboardHelp.openCloudCreatorId.currentState.saved":"Keep this value if new assets should continue using the same owner.","dashboardHelp.openCloudCreatorId.currentState.empty":"Choose User or Group, paste the numeric ID, then save the default Creator.","page.overview.title":"Overview","page.overview.description":"Check server, plugin, agent, sync, and recent game-change status in one place.","page.connection.title":"Connection","page.connection.description":"Inspect MCP server, AI agent, Studio plugin, and connection log status.","page.sync.title":"Sync","page.sync.description":"Monitor Studio to local sync status, direction, apply mode, and recent sync logs.","page.changelog.title":"Changelog","page.changelog.description":"Review game-change sessions captured from AI actions and sync events.","page.playtest.title":"Playtest","page.playtest.description":"Review automated playtest runs, saved reports, and result history.","page.uiStudio.title":"UI Studio","page.uiStudio.description":"Review UI captures, improvement suggestions, and before/after change history.","page.tools.title":"Tools","page.tools.description":"Inspect tool history, outcomes, fallback details, and usage statistics.","page.settings.title":"Settings","page.settings.description":"Manage license, live settings, saved data, server environment, and language.","dashboardHelp.whatsNew.title":"What's New help","dashboardHelp.whatsNew.canDo.1":"Review WEPPY Dashboard, MCP, and Plugin announcements, releases, and change notes.","dashboardHelp.whatsNew.needs.1":"Announcements are bundled locally. Unread state is stored in this browser.","dashboardHelp.whatsNew.currentState.1":"After you visit this page, unread announcements from this visit are marked read when you leave. The top header does not show a duplicate What's New button on this page."},Wf={"sidebar.overview":"개요","sidebar.changelog":"변경 이력","sidebar.connection":"연결","sidebar.sync":"동기화","sidebar.playtest":"플레이테스트","sidebar.tools":"도구","sidebar.settings":"설정","sidebar.ui_studio":"UI 스튜디오","sidebar.gate.l1":"MCP 서버를 연결해야 이 페이지를 사용할 수 있습니다.","sidebar.gate.l2":"Roblox Studio 플러그인을 연결해야 이 페이지를 사용할 수 있습니다.","header.currentProject":"현재 프로젝트","header.unknownProject":"알 수 없는 프로젝트","header.projectRoot.label":"Project Root","header.currentProject.loading":"프로젝트 루트 불러오는 중...","header.currentProject.unavailable":"프로젝트 루트를 불러올 수 없음","header.placeNotConnected":"플레이스 미연결","header.currentProject.tooltip":"현재 선택된 프로젝트 폴더입니다.","header.currentProject.loading.tooltip":"프로젝트 루트 정보를 아직 불러오는 중입니다.","header.currentProject.unavailable.tooltip":"현재 프로젝트 루트 정보를 불러올 수 없습니다.","header.currentProjectSyncRoot.label":"Sync Root","header.currentProjectSyncRoot.loading":"Sync root 불러오는 중...","header.currentProjectSyncRoot.unavailable":"Sync root 정보를 불러올 수 없음","header.currentProjectSyncRoot.tooltip":"선택된 프로젝트의 현재 sync root 폴더입니다.","header.currentProjectSyncRoot.loading.tooltip":"Sync root 정보를 아직 불러오는 중입니다.","header.currentProjectSyncRoot.unavailable.tooltip":"현재 sync root 정보를 불러올 수 없습니다.","header.testFiles.label":"Test Files","header.testFiles.unavailable":"테스트 파일 경로를 확인할 수 없습니다.","header.testFiles.tooltip":"선택된 플레이스의 현재 플레이테스트 파일 경로입니다.","header.places.title":"Places","header.places.active":"Active","header.places.inactive":"Inactive","header.places.pluginRequired":"플러그인 연결 필요","header.places.liveRequired":"실시간 활성 플레이스를 확인하려면 플러그인 연결이 필요합니다.","header.place.tooltip":"연결된 Roblox 플레이스입니다.","header.placeNotConnected.tooltip":"플레이스 미연결","header.changeProjectRoot":"프로젝트 루트 변경","header.changeProjectRoot.ariaLabel":"프로젝트 루트 변경","header.changeProjectRoot.tooltip":"현재 프로젝트 루트를 변경합니다.","header.changeProjectRoot.disabledTooltip.l0":"프로젝트 루트를 변경하려면 먼저 MCP 서버 연결이 필요합니다.","header.changeProjectRoot.disabledTooltip.loading":"프로젝트 루트 정보를 아직 불러오는 중입니다.","header.changeProjectRoot.disabledTooltip.unavailable":"현재 프로젝트 루트 정보를 불러올 수 없습니다.","header.projectRootModal.initial.title":"프로젝트 루트 변경","header.projectRootModal.initial.body.connected":"프로젝트 폴더를 선택하면 MCP 프로젝트 루트가 즉시 변경되고 현재 Studio 내용이 새 <selected project folder>/weppy-project-sync 대상으로 전체 재동기화됩니다.","header.projectRootModal.initial.body.disconnected":"프로젝트 폴더를 선택하면 MCP 프로젝트 루트가 즉시 변경되고 새 <selected project folder>/weppy-project-sync 경로가 다음 sync 대상으로 사용됩니다.","header.projectRootModal.initial.nextSyncRoot":"선택 후 새 sync 대상","header.projectRootModal.initial.nextSyncRoot.placeholder":"<selected project folder>/weppy-project-sync","header.projectRootModal.initial.warningStop":"현재 sync는 즉시 중단됩니다.","header.projectRootModal.initial.warningFreshSync":"현재 Studio 내용을 기준으로 새 대상에 fresh full sync가 다시 생성됩니다.","header.projectRootModal.initial.warningNoMove":"기존 sync 폴더는 자동으로 이동되지 않습니다.","header.projectRootModal.initial.warningDeferredSync":"Studio가 아직 연결되지 않았다면 전체 재동기화는 다음 플러그인 연결 시 시작됩니다.","header.projectRootModal.confirm.title":"새 프로젝트 루트 확인","header.projectRootModal.confirm.body":"적용 전에 선택한 프로젝트 폴더를 다시 확인하세요.","header.projectRootModal.confirm.projectRoot":"선택한 프로젝트 폴더","header.projectRootModal.confirm.syncRoot":"새 sync 대상","header.projectRootModal.confirm.warningNoMove":"기존 sync 폴더는 자동으로 이동되지 않습니다.","header.projectRootModal.pick":"폴더 선택","header.projectRootModal.apply":"변경 적용","header.projectRootModal.cancel":"취소","header.projectRootModal.error":"프로젝트 루트를 변경하지 못했습니다.","status.online":"온라인","status.offline":"오프라인","status.idle":"대기","status.syncing":"동기화 중","status.error":"오류","status.initializing":"초기화 중","level.l0.title":"서버 연결 끊김","level.l0.message":"WEPPY Dashboard가 열린 뒤 서버가 종료되었거나 응답하지 않습니다.","level.l1.title":"서버 연결됨","level.l1.hint":"확인: Studio 실행 중? 플러그인 설치?","level.l2.ok":"Studio 연결됨","tier.basic":"Basic","tier.basic.tooltip":"기본 WEPPY Dashboard 기능을 제공하는 Basic 티어입니다.","tier.pro":"Pro","tier.pro.tooltip":"전체 WEPPY Dashboard 기능을 제공하는 Pro 티어입니다.","tier.mixed":"혼합","tier.upgrade":"Pro 확인하기","tier.banner.save":"Pro로 AI 토큰 절약!","tier.tool.query_instances.desc":"인스턴스 조회, 자식/자손 탐색, 클래스 정보, 이름·클래스 검색. Pro: 파일 트리, 프로젝트 구조, 속성·태그 검색.","tier.tool.mutate_instances.desc":"인스턴스 생성, 삭제, 복제, 이동, 이름변경, 피벗. Pro: 트리 생성, 대량 생성·삭제·복제.","tier.tool.manage_properties.desc":"속성, 어트리뷰트, 태그 조회 및 설정. Pro: 계산·상대값 설정, 대량 조회·설정, 자식 일괄 수정.","tier.tool.manage_scripts.desc":"스크립트 소스 코드 읽기, 쓰기, 생성, 삭제, 줄 편집, 검색. Pro: 스크립트 간 일괄 치환.","tier.tool.manage_ui.desc":"Pro 전용. 게임 스타일의 메뉴, HUD, 버튼, 라벨, 이미지 패널을 생성·개선하고 화면 캡처와 개선 제안을 확인합니다.","tier.tool.manage_ui.action.design_brief":"UI 방향 정리","tier.tool.manage_ui.action.create_tree":"새 UI 만들기","tier.tool.manage_ui.action.update":"기존 UI 수정","tier.tool.manage_ui.action.delete":"UI 삭제","tier.tool.manage_ui.action.preview":"UI 화면 캡처","tier.tool.manage_ui.action.check":"개선 제안 확인","tier.tool.manage_lighting.desc":"Pro 전용. 조명, 대기, 하늘, 터레인 속성, 시간대 환경 설정.","tier.tool.manage_selection.desc":"선택 조회, 설정, 해제. Pro: 컨텍스트, 상세 정보, 항목 추가·제거, 변경 감시.","tier.tool.manage_camera.desc":"카메라 정보 조회, 경로 또는 좌표로 포커스, 추천 뷰 제안.","tier.tool.manage_tween.desc":"Pro 전용. 부드러운 애니메이션을 위한 트윈 생성, 재생, 일시정지, 취소.","tier.tool.manage_audio.desc":"Pro 전용. 사운드 재생, 정지, 일시정지, 재개. 오디오 리스너 설정.","tier.tool.manage_animation.desc":"Pro 전용. 애니메이션 로드, 재생, 정지. 휴머노이드·컨트롤러의 트랙 조회.","tier.tool.manage_physics.desc":"Pro 전용. 물리 충돌 그룹 등록, 그룹 간 충돌 설정, 목록 조회.","tier.tool.manage_effects.desc":"Pro 전용. 파티클 방출, 전체 삭제, 이펙트 활성화 토글.","tier.tool.manage_terrain.desc":"Pro 전용. 도형 채우기, 영역 삭제, 재질 치환, 색상 관리, 복셀 읽기·쓰기, 절차적 생성, 스무딩.","tier.tool.spatial_query.desc":"Pro 전용. 레이캐스트, 지면 찾기, 배치 확인, 영역 스캔, 평지·스폰 위치 탐색, 보행 분석, 공간 맵, 충돌 확인.","tier.tool.manage_assets.desc":"Pro 전용. 모델 삽입, 에셋 정보 조회, 크리에이터 스토어 검색, 무료 모델·패키지 삽입, 내보내기.","tier.tool.manage_sync.desc":"Pro 전용. 동기화 상태, 설정, 히스토리, 방향 설정, 동기화 파일 읽기·쓰기.","tier.tool.workspace_state.desc":"Pro 전용. 전체 동기화, 상태 캡처, 최근 변경, 뷰포트 정보, 메타데이터, 캐시 관리.","tier.tool.manage_logs.desc":"출력 로그 필터링 조회, 증분 폴링, 버퍼 삭제, 최근 오류 조회.","tier.tool.system_info.desc":"연결 상태, 사용 티어 확인. Pro: 플레이스 정보, 서비스 목록, Studio 설정, 플레이테스트 제어, 자동 테스트.","tier.tool.manage_studio.desc":"Pro 전용. 스크린샷과 QA 흐름을 위해 UI 프리뷰 같은 Studio 편집기 보기 설정을 전환합니다. 게임 UI 오브젝트는 변경하지 않습니다.","tier.tool.batch_execute.desc":"Pro 전용. 여러 명령을 한 번에 일괄 실행. 순차 처리하며 오류 시 계속 진행 옵션.","tier.tool.execute_luau.desc":"Pro 전용. Roblox Studio 샌드박스에서 임의 Luau 코드 실행.","connection.server.title":"서버 상태","connection.server.version":"버전","connection.server.version.tooltip":"설치된 MCP 서버 버전입니다.","connection.server.pid":"PID","connection.server.pid.tooltip":"운영체제에서 사용하는 프로세스 식별자입니다.","connection.server.uptime":"가동 시간","connection.server.uptime.tooltip":"MCP 서버가 시작된 뒤 경과한 시간입니다.","connection.server.session":"세션","connection.server.session.tooltip":"현재 MCP 세션 식별자입니다.","connection.server.exec":"실행 파일","connection.server.exec.tooltip":"MCP 서버를 실행한 실행 파일 경로입니다.","connection.reconnect":"수동 재연결","connection.checkSettings":"설정 확인","connection.agents.title":"AI 에이전트","connection.agents.name":"에이전트","connection.agents.cwd":"작업 디렉토리","connection.agents.cwd.tooltip":"연결된 AI 에이전트의 현재 작업 디렉토리입니다.","connection.agents.projectRoot":"프로젝트 루트","connection.agents.projectRoot.tooltip":"Sync ownership을 결정하는 프로젝트 경로","connection.agents.projectRoot.unresolved":"미확인","connection.agents.connected":"연결 시각","connection.agents.unknown":"알 수 없음","connection.agents.none":"연결된 에이전트 없음","connection.plugins.title":"플러그인","connection.plugins.place":"플레이스","connection.plugins.clientId":"클라이언트 ID","connection.plugins.clientId.tooltip":"현재 Studio 연결을 식별하는 플러그인 클라이언트 ID입니다.","connection.plugins.lastSeen":"마지막 확인","connection.plugins.lastSeen.tooltip":"플러그인에서 가장 최근에 수신한 heartbeat 시각입니다.","connection.plugins.version":"버전","connection.plugins.version.tooltip":"Studio가 보고한 설치된 플러그인 버전입니다.","connection.plugins.none":"연결된 플러그인 없음","connection.log.title":"연결 로그","connection.log.empty":"이벤트 없음","connection.time.secondsAgo":"초 전","connection.time.minutesAgo":"분 전","connection.time.hoursAgo":"시간 전","common.loading":"로딩 중...","common.retry":"재시도","common.reconnecting":"재연결 중...","common.expand":"펼치기","common.collapse":"접기","tools.tab.history":"히스토리","tools.tab.statistics":"통계","tools.tab.failures":"실패","tools.col.time":"시간","tools.col.time.tooltip":"도구 실행이 기록된 시각입니다.","tools.col.toolAction":"도구.액션","tools.col.toolAction.tooltip":"실행된 도구 이름과 액션입니다.","tools.col.duration":"소요 시간","tools.col.duration.tooltip":"도구 실행이 완료될 때까지 걸린 시간입니다.","tools.col.status":"상태","tools.col.status.tooltip":"기록된 도구 실행의 결과 상태입니다.","tools.col.tier":"티어","tools.col.tier.tooltip":"도구 또는 액션에 필요한 라이센스 티어입니다.","tools.col.tierStats.tooltip":"도구 통계 행이 Basic, Pro, Mixed 중 어느 집계인지 설명합니다.","tools.col.tool":"도구","tools.col.tool.tooltip":"통계 테이블에 표시되는 통합 도구 이름입니다.","tools.col.calls":"호출 수","tools.col.calls.tooltip":"이 도구에 대해 기록된 총 호출 횟수입니다.","tools.col.ok":"OK","tools.col.ok.tooltip":"직접 성공한 실행 횟수입니다.","tools.col.fallback":"FALLBACK","tools.col.fallback.tooltip":"fallback 실행으로 성공한 횟수입니다.","tools.col.unsupported":"UNSUPPORTED","tools.col.unsupported.tooltip":"fallback 없이 차단된 실행 횟수입니다.","tools.col.warn":"주의","tools.col.warn.tooltip":"입력, 프로젝트 상태, Roblox 정책 또는 사용자 코드 때문에 예상된 실패로 기록된 횟수입니다.","tools.col.err":"실패","tools.col.err.tooltip":"실패로 끝난 실행 횟수입니다.","tools.col.okRate":"성공률","tools.col.okRate.tooltip":"성공적으로 끝난 호출 비율입니다.","tools.col.avgTime":"평균 시간","tools.col.avgTime.tooltip":"기록된 호출들의 평균 실행 시간입니다.","tools.col.error":"오류","tools.filter.tool":"도구","tools.filter.all":"전체","tools.badge.pro":"PRO","tools.badge.pro.tooltip":"이 항목은 Pro 전용 도구 또는 액션을 사용했습니다.","tools.badge.fallback":"FALLBACK","tools.badge.fallback.tooltip":"요청한 Pro 액션이 Basic fallback으로 성공했습니다.","tools.badge.unsupported":"UNSUPPORTED","tools.badge.unsupported.tooltip":"요청한 Pro 액션이 차단되었고 fallback도 실행되지 않았습니다.","tools.badge.warn":"주의","tools.badge.warn.tooltip":"요청, 프로젝트 상태, 정책 또는 사용자 코드 조정이 필요한 예상 실패입니다.","tools.badge.err":"실패","tools.badge.err.tooltip":"도구 실행이 실패로 끝났습니다.","tools.status.ok":"OK","tools.status.ok.tooltip":"도구 실행이 성공적으로 완료되었습니다.","tools.tier.mixed.tooltip":"이 도구에는 Basic 액션과 Pro 액션이 함께 포함됩니다.","tools.detail.params":"파라미터","tools.detail.params.tooltip":"이 도구 실행에 전달된 입력 파라미터입니다.","tools.detail.result":"결과","tools.detail.result.tooltip":"이 도구 실행에서 반환된 결과 페이로드입니다.","tools.detail.requestedCommand":"전송한 명령","tools.detail.executedCommand":"실행된 명령","tools.detail.alternatives":"대안","tools.detail.blockedMessage":"차단 사유","tools.detail.noFallback":"Fallback 없음","tools.detail.noFallback.value":"실행된 fallback이 없습니다.","tools.detail.warningMessage":"주의 메시지","tools.detail.errorMessage":"오류 메시지","tools.clear.history.title":"히스토리를 삭제할까요?","tools.clear.history.message":"현재 place의 도구 히스토리가 영구적으로 삭제됩니다.","tools.clear.statistics.title":"통계를 삭제할까요?","tools.clear.statistics.message":"현재 place의 도구 통계가 영구적으로 초기화됩니다.","tools.detail.error":"오류","tools.page.prev":"이전","tools.page.prev.tooltip":"도구 히스토리의 이전 페이지로 이동합니다.","tools.page.next":"다음","tools.page.next.tooltip":"도구 히스토리의 다음 페이지로 이동합니다.","tools.empty.history":"히스토리 없음","tools.empty.stats":"도구 통계 없음","tools.empty.failures":"실패 없음","tools.summary.total":"합계","tools.summary.calls":"호출","tools.summary.sessions":"세션","settings.license.title":"라이센스","settings.license.title.tooltip":"현재 라이센스 상태와 구독 티어입니다.","settings.license.status":"상태","settings.license.status.tooltip":"현재 라이센스 활성화 상태입니다.","settings.license.tier":"티어","settings.license.tier.tooltip":"WEPPY Dashboard 기능 범위를 결정하는 현재 구독 티어입니다.","settings.license.key":"키","settings.license.key.tooltip":"서버에 현재 로드된 마스킹된 라이센스 키입니다.","settings.license.keyValue.tooltip":"서버에 현재 로드된 마스킹된 라이센스 키입니다.","settings.license.provider":"제공자","settings.license.provider.auto":"auto","settings.license.provider.polar":"polar","settings.license.provider.gumroad":"gumroad","settings.license.provider.tooltip":"이 키를 검증하는 라이센스 제공자입니다.","settings.license.providerValue.tooltip":"이 키를 검증하는 라이센스 제공자입니다.","settings.license.active":"활성","settings.license.active.tooltip":"현재 라이센스 활성화 상태입니다.","settings.license.status.activeCancelPending.tooltip":"해지가 예약되어 있지만 현재 결제 주기가 끝날 때까지 Pro 접근은 유지됩니다.","settings.license.inactive":"비활성","settings.license.inactive.tooltip":"현재 라이센스 활성화 상태입니다.","settings.license.expired":"만료","settings.license.expired.tooltip":"현재 라이센스 활성화 상태입니다.","settings.license.unavailable":"라이센스 정보를 불러올 수 없음","settings.license.detail.cancelPending":"해지가 예약되었습니다. 현재 결제 주기가 끝날 때까지 Pro 접근은 유지됩니다.","settings.license.reset":"라이센스 리셋","settings.readOnly":"읽기 전용","settings.readOnly.tooltip":"이 섹션의 값은 WEPPY Dashboard에서 수정할 수 없습니다.","settings.unavailable":"설정을 불러올 수 없음","settings.general.title":"일반 설정","settings.general.title.tooltip":"변경 즉시 적용되는 Hot 설정입니다.","settings.general.liveApply":"즉시 반영","settings.general.liveApply.tooltip":"이 섹션의 변경은 별도 저장 버튼 없이 바로 적용됩니다.","settings.general.applied":"적용됨","settings.general.logLevel":"로그 레벨","settings.general.logLevel.tooltip":"MCP 서버가 남기는 로그의 자세한 정도를 정합니다. 문제 추적이 필요하면 debug 로 낮추세요.","settings.general.localHistory":"도구 히스토리 기록","settings.general.localHistory.tooltip":"AI 도구 호출 기록을 컴퓨터에 저장합니다. Tools / History 화면에서 보기 위해 필요합니다.","settings.general.localStatistics":"도구 통계 집계","settings.general.localStatistics.tooltip":"도구 사용 횟수를 집계합니다. Overview 화면의 통계에 사용됩니다.","settings.general.contextCapture":"컨텍스트 캡처","settings.general.contextCapture.tooltip":"Changelog와 Playtest 화면에서 보기 좋도록 변경 이력을 구조화해 저장합니다.","settings.general.requestTimeout":"작업 제한 시간","settings.general.requestTimeout.tooltip":"AI 도구 한 번 실행에 대해 기다리는 최대 시간(밀리초)입니다. 시간이 지나면 실패로 처리됩니다.","settings.general.requestTimeout.unit":"ms","settings.general.requestTimeout.unit.tooltip":"작업 제한 시간 단위는 밀리초입니다.","settings.cold.title":"서버 환경변수","settings.cold.title.tooltip":"서버 시작 시 로드되는 읽기 전용 환경변수 값입니다.","settings.cold.httpPort.tooltip":"MCP WEPPY Dashboard HTTP 서버가 사용하는 포트 번호입니다.","settings.cold.httpHost.tooltip":"MCP WEPPY Dashboard HTTP 서버가 바인딩하는 호스트 인터페이스입니다.","settings.cold.dashboardAutoOpen.tooltip":"서버 시작 시 브라우저에서 WEPPY Dashboard를 자동으로 열지 여부를 제어합니다.","settings.cold.dashboardAutoOpen.value.tooltip":"브라우저 자동 열기 현재 시작 동작입니다.","settings.cold.hint":"환경변수로 설정하세요.","settings.language.title":"언어","settings.language.title.tooltip":"WEPPY Dashboard UI 텍스트에 사용할 언어를 선택합니다.","settings.language.dashboard":"WEPPY Dashboard 언어","settings.language.dashboard.tooltip":"Auto일 때는 시스템 언어를 따르고, 아니면 선택한 언어를 강제합니다.","settings.language.auto":"자동","overview.l0.title":"MCP 서버 연결 끊김","overview.l0.message":"MCP 서버가 응답하지 않습니다. WEPPY Dashboard가 자동으로 재연결을 시도합니다.","overview.l0.step1":"MCP 서버 프로세스가 실행 중인지 확인하세요","overview.l0.step2":"필요 시 MCP 서버 명령을 다시 시작하세요","overview.l0.reconnecting":"3초마다 자동 재연결 중...","overview.l0.reconnectBtn":"수동 재연결","overview.l0.settingsBtn":"설정 확인","overview.l1.pluginGuide":"Roblox Studio 플러그인이 연결되지 않았습니다","overview.l1.check1":"Roblox Studio가 실행 중인가요?","overview.l1.check2":"WEPPY Plugin이 설치되어 있나요?","overview.l1.feedHint":"플러그인이 연결되면 변경사항이 표시됩니다","overview.metric.server":"서버","overview.metric.server.tooltip":"MCP 서버의 실행 상태와 프로세스 상태입니다.","overview.metric.plugin":"플러그인","overview.metric.plugin.tooltip":"Roblox Studio 플러그인의 연결 상태와 버전 정보입니다.","overview.metric.agent":"에이전트","overview.metric.agent.tooltip":"연결된 AI 코딩 에이전트와 현재 실행 상태입니다.","overview.metric.agent.instancesUnit":"인스턴스","overview.metric.sync":"동기화","overview.metric.sync.tooltip":"현재 Studio와 로컬 파일 간 동기화 상태입니다.","overview.metric.noAgent":"에이전트 없음","overview.meta.version":"버전","overview.meta.version.tooltip":"설치된 MCP 서버 버전입니다.","overview.meta.session":"세션","overview.meta.session.tooltip":"현재 MCP 세션 식별자입니다.","overview.meta.pid":"PID","overview.meta.pid.tooltip":"운영체제에서 사용하는 프로세스 식별자입니다.","overview.meta.uptime":"가동 시간","overview.meta.uptime.tooltip":"MCP 서버가 시작된 뒤 경과한 시간입니다.","overview.feed.title":"최근 게임 변경","overview.feed.empty":"최근 변경사항 없음","overview.changelog.title":"세션 변경 요약","overview.changelog.entries":"합계","overview.changelog.scripts":"스크립트","overview.changelog.instances":"인스턴스","overview.changelog.properties":"속성","overview.changelog.assets":"에셋","overview.tier.title":"티어 사용 현황","changelog.subtitle":"게임 변경 이력","changelog.filter.all":"전체","changelog.filter.active":"활성","changelog.filter.completed":"완료","changelog.empty":"변경 이력이 없습니다","changelog.basic.limit.title":"Basic 미리보기에서는 최신 3개 세션만 표시됩니다","changelog.basic.limit.body":"Pro에서 이 플레이스의 전체 변경 이력 타임라인을 확인할 수 있습니다.","changelog.basic.metricLabel":"표시 중인 변경 이력 / 전체","changelog.basic.visible":"표시 중","changelog.basic.total":"전체","changelog.card.active":"활성","changelog.card.active.tooltip":"이 세션은 아직 새 게임 변경을 계속 수집 중입니다.","changelog.card.completed":"완료","changelog.card.completed.tooltip":"이 세션은 종료되어 더 이상 새 변경이 추가되지 않습니다.","changelog.card.bootstrapStatus":"초기화","changelog.card.bootstrapStatus.tooltip":"이 세션에는 초기 동기화 기준 기록만 포함됩니다.","changelog.card.inProgress":"진행 중","changelog.card.noChanges":"아직 변경사항 없음","changelog.card.noChanges.tooltip":"이 세션에서는 아직 추출된 게임 변경이 없습니다.","changelog.card.bootstrapSummary":"초기 동기화 기준 기록","changelog.card.bootstrapSummary.tooltip":"초기 파일 동기화 쓰기 작업은 하나의 기준 기록 행으로 축약됩니다.","changelog.card.sessionIntent":"세션 의도","changelog.card.scripts":"스크립트","changelog.card.scripts.tooltip":"이 세션에서 발생한 스크립트 변경입니다.","changelog.card.instances":"인스턴스","changelog.card.instances.tooltip":"이 세션에서 발생한 인스턴스 생성, 삭제, 이동, 복제 변경입니다.","changelog.card.modified":"수정","changelog.card.created":"생성","changelog.card.deleted":"삭제","changelog.card.moved":"이동","changelog.card.propertiesChanged":"속성 변경","changelog.card.propertiesChanged.tooltip":"이 세션에서 기록된 속성 값 변경입니다.","changelog.card.lightingConfigured":"라이팅 설정됨","changelog.card.lightingConfigured.tooltip":"이 세션에서 라이팅 또는 대기 설정이 변경되었습니다.","changelog.card.terrainConfigured":"터레인 설정됨","changelog.card.terrainConfigured.tooltip":"이 세션에서 터레인 데이터 또는 터레인 설정이 변경되었습니다.","changelog.card.assetsInserted":"에셋 삽입","changelog.card.assetsInserted.tooltip":"이 세션 동안 플레이스에 삽입된 에셋입니다.","changelog.category.script":"스크립트","changelog.category.instance":"인스턴스","changelog.category.property":"속성","changelog.category.lighting":"라이팅","changelog.category.terrain":"터레인","changelog.category.asset":"에셋","changelog.detail.changeSummary":"변경 요약","changelog.detail.changeSummary.tooltip":"이 세션에서 추출된 게임 변경 수를 카테고리별로 묶어서 보여줍니다.","changelog.detail.changeTimeline":"변경 타임라인","changelog.detail.changeTimeline.tooltip":"이 세션에서 추출된 게임 변경을 시간순으로 보여줍니다.","changelog.detail.context.title":"컨텍스트 요약","changelog.detail.context.tooltip":"이 체인지로그 세션에 연결된 구조화된 실행 컨텍스트입니다.","changelog.detail.verification.title":"검증","changelog.detail.verification.tooltip":"이 체인지로그 세션에 연결된 검증 신호입니다.","changelog.detail.verification.label":"결과","changelog.detail.verification.status":"상태","changelog.detail.verification.timestamp":"기록 시각","changelog.detail.beforeAfter":"변경 전후 비교","changelog.detail.filterCategory":"카테고리","changelog.detail.filterCategory.tooltip":"타임라인을 하나의 변경 카테고리만 보이도록 필터링합니다.","changelog.detail.confidence.exact":"정확","changelog.detail.confidence.exact.tooltip":"이 변경은 변경 전과 변경 후 상태가 모두 확인되었습니다.","changelog.detail.confidence.partial":"부분 확인","changelog.detail.confidence.partial.tooltip":"이 변경은 변경 전후 상태 중 일부만 확인되었습니다.","changelog.detail.confidence.afterOnly":"결과만 확인","changelog.detail.confidence.afterOnly.tooltip":"이 변경은 적용 후 결과 상태만 확인되었습니다.","changelog.detail.confidence.intentOnly":"의도만 기록","changelog.detail.confidence.intentOnly.tooltip":"요청된 작업 의도만 기록되었고 결과 상태는 확인되지 않았습니다.","changelog.detail.confidence.unknown":"알 수 없음","changelog.detail.confidence.unknown.tooltip":"사용 가능한 데이터만으로는 이 변경을 신뢰도 있게 분류할 수 없습니다.","changelog.detail.noChanges":"이 카테고리에 변경사항 없음","changelog.detail.backToList":"목록으로 돌아가기","changelog.diff.empty":"비교할 내용 없음","changelog.diff.unified":"통합","changelog.diff.sideBySide":"나란히 비교","changelog.diff.before":"변경 전","changelog.diff.after":"변경 후","sync.overlay.title":"Roblox Studio 플러그인이 필요합니다","sync.overlay.message":"Roblox Studio 플러그인이 연결되면 동기화 상태를 확인할 수 있습니다.","sync.overlay.check1":"Roblox Studio가 실행 중인가요?","sync.overlay.check2":"WEPPY Plugin이 설치되어 있나요?","sync.status.title":"동기화 상태","sync.status.title.tooltip":"이 플레이스의 Studio와 로컬 파일 동기화 상태입니다.","sync.status.forwardOnly":"단방향만","sync.status.forwardOnly.tooltip":"Basic 티어에서는 Studio에서 로컬로 가는 단방향 동기화만 사용할 수 있습니다.","sync.status.place":"플레이스","sync.status.place.tooltip":"연결된 Roblox 플레이스 이름과 플레이스 ID입니다.","sync.status.path":"경로","sync.status.path.tooltip":"현재 동기화 출력에 사용하는 로컬 파일 시스템 루트입니다.","sync.status.instances":"인스턴스","sync.status.instances.tooltip":"로컬 미러에 추적 중인 동기화된 Roblox 인스턴스 수입니다.","sync.status.scripts":"스크립트","sync.status.scripts.tooltip":"이 플레이스에 대해 현재 인덱싱된 동기화 스크립트 파일 수입니다.","sync.status.state":"상태","sync.status.state.tooltip":"서버가 보고한 현재 동기화 런타임 상태입니다.","sync.directions.title":"동기화 방향","sync.directions.title.tooltip":"Local과 Studio 사이의 카테고리별 동기화 방향과 적용 방식입니다.","sync.directions.type":"유형","sync.directions.type.tooltip":"이 규칙이 적용되는 동기화 카테고리입니다.","sync.directions.direction":"방향","sync.directions.direction.tooltip":"각 카테고리가 Studio에서만, Studio로만, 또는 양방향으로 동기화되는지 나타냅니다.","sync.directions.applyMode":"적용 모드","sync.directions.applyMode.tooltip":"이 카테고리에 들어오는 동기화 변경을 적용하는 방식입니다.","sync.directions.cat.scripts":"스크립트","sync.directions.cat.values":"값","sync.directions.cat.containers":"컨테이너","sync.directions.cat.data":"데이터","sync.directions.cat.services":"서비스","sync.directions.endpoint.local":"Local","sync.directions.endpoint.local.tooltip":"방향 레일의 왼쪽은 항상 디스크의 로컬 파일을 의미합니다.","sync.directions.endpoint.studio":"Studio","sync.directions.endpoint.studio.tooltip":"방향 레일의 오른쪽은 항상 Roblox Studio를 의미합니다.","sync.directions.mode.manual":"수동","sync.directions.mode.manual.tooltip":"직접 실행할 때만 동기화 변경을 적용합니다.","sync.directions.mode.auto":"자동","sync.directions.mode.auto.tooltip":"업데이트가 들어오면 동기화 변경을 자동으로 적용합니다.","sync.directions.tooltip.forward.body":"Studio 변경 사항을 로컬 파일로만 동기화합니다","sync.directions.tooltip.bidirectional.body":"Local과 Studio 사이에 양방향 동기화를 사용합니다","sync.directions.tooltip.reverse.body":"로컬 파일 변경 사항을 Studio로 푸시합니다","sync.directions.tooltip.proRequired":"Basic 티어에서는 Pro가 필요합니다","sync.directions.dir.forward":"순방향","sync.directions.dir.bidirectional":"양방향","sync.directions.dir.reverse":"역방향","sync.log.title":"동기화 로그","sync.log.empty":"동기화 이벤트 없음","sync.log.type.write":"쓰기","sync.log.type.write.tooltip":"새 동기화 출력이 디스크에 기록되었습니다.","sync.log.type.update":"업데이트","sync.log.type.update.tooltip":"기존 동기화 파일 또는 인스턴스가 갱신되었습니다.","sync.log.type.delete":"삭제","sync.log.type.delete.tooltip":"동기화된 파일 또는 인스턴스가 제거되었습니다.","sync.log.type.idle":"대기","sync.log.type.idle.tooltip":"파일 변경 없이 동기화 이벤트만 기록되었습니다.","sync.upgrade.title":"Pro 동기화 기능 확인하기","sync.upgrade.benefit1":"양방향 동기화 — 파일 편집 시 Studio에 자동 반영","sync.upgrade.benefit2":"역방향 동기화 — 파일 변경을 Studio로 전송","sync.upgrade.benefit3":"전체 동기화 히스토리 및 상세 변경 로그","sync.upgrade.buy":"Pro 확인하기","playtest.status.title":"플레이테스트 상태","playtest.status.title.tooltip":"Studio가 보고한 현재 Roblox 플레이테스트 세션 상태입니다.","playtest.status.mode":"모드","playtest.status.mode.tooltip":"현재 세션에 사용 중인 Studio 플레이테스트 실행 모드입니다.","playtest.status.mode.value.tooltip":"현재 적용 중인 Roblox Studio 플레이테스트 모드의 구체적인 값입니다.","playtest.status.mode.play":"플레이","playtest.status.mode.run":"실행","playtest.status.mode.server":"서버","playtest.status.mode.edit":"편집","playtest.status.place.tooltip":"이 플레이테스트 세션과 연결된 Roblox 플레이스입니다.","playtest.status.state.running":"실행 중","playtest.status.state.running.tooltip":"현재 Roblox 플레이테스트 세션이 실행 중입니다.","playtest.status.state.paused":"일시정지","playtest.status.state.paused.tooltip":"현재 Roblox 플레이테스트 세션이 일시정지 상태입니다.","playtest.status.state.notRunning":"실행 안 함","playtest.status.state.notRunning.tooltip":"현재 실행 중인 Roblox 플레이테스트 세션이 없습니다.","playtest.control.play":"플레이","playtest.control.pause":"일시정지","playtest.control.resume":"재개","playtest.control.stop":"정지","playtest.history.title":"테스트 히스토리","playtest.history.title.tooltip":"이 프로젝트에서 기록된 자동 플레이테스트 실행 이력입니다.","playtest.history.empty":"테스트 결과 없음","playtest.history.mode":"모드","playtest.history.mode.tooltip":"이 기록된 테스트 실행에 사용된 플레이테스트 모드입니다.","playtest.history.status.passed":"성공","playtest.history.status.failed":"실패","playtest.history.status.running":"실행 중","playtest.history.status.unknown":"알 수 없음","playtest.history.status.tooltip":"이 자동 플레이테스트 실행의 기록된 결과 상태입니다.","playtest.empty.title":"아직 플레이테스트 결과가 없습니다","playtest.empty.message":"AI Agent가 Playtest를 실행하면 결과가 여기에 표시됩니다.","playtest.empty.message.before":"AI Agent가 Playtest를 실행하면 결과가 여기에 표시됩니다.","playtest.empty.message.after":"","playtest.empty.runTest.tooltip":"새 리포트가 필요하면 AI Agent에게 Playtest 실행을 요청하세요.","playtest.report.title":"선택된 리포트","playtest.report.title.tooltip":"현재 선택된 자동 플레이테스트 실행의 상세 출력입니다.","playtest.report.content":"리포트","playtest.report.content.tooltip":"선택된 자동 플레이테스트 실행의 마크다운 요약입니다.","playtest.report.logs":"로그","playtest.report.logs.tooltip":"선택된 자동 플레이테스트 실행에서 수집된 실행 로그입니다.","playtest.context.contextId":"컨텍스트 ID","playtest.context.why":"이 테스트를 실행한 이유","playtest.context.expected":"예상 결과","playtest.context.observed":"관찰 결과","playtest.report.empty":"리포트 내용 없음","playtest.basic.icon":"🎮","playtest.basic.title":"플레이테스트는 Pro 전용 기능입니다","playtest.basic.desc":"WEPPY Dashboard에서 플레이테스트를 제어하고, 자동 테스트를 실행하며, 상세한 테스트 리포트를 확인하세요.","playtest.basic.benefit1":"원클릭 플레이/일시정지/정지 제어","playtest.basic.benefit2":"AI 에이전트를 통한 자동 테스트 실행","playtest.basic.benefit3":"성공/실패 추적이 가능한 테스트 히스토리","playtest.basic.benefit4":"상세한 마크다운 테스트 리포트","playtest.sample.badge":"Pro 플레이테스트 화면 미리보기","playtest.sample.title":"현재 보고 있는 화면은 Pro에서 사용할 수 있는 플레이테스트 화면 예시입니다.","playtest.sample.message":"이 미리보기는 샘플 데이터로 구성되어 있습니다. 실시간 플레이테스트 제어, 히스토리 관리, 실제 리포트 저장은 Pro 구매 후 사용할 수 있습니다.","playtest.sample.clearDisabled":"실제 플레이테스트 기록 삭제는 Pro에서 사용할 수 있습니다.","playtest.sample.place":"아레나 미리보기","playtest.sample.history.name":"샘플 아레나 스모크 테스트","playtest.sample.context.why":"아레나에 스폰한 뒤 첫 구간을 버티고 HUD가 즉시 반응하는지 확인합니다.","playtest.sample.context.expected":"플레이어가 안전하게 스폰되고, 1초 안에 카운트다운 UI가 표시되며, 첫 웨이브가 오류 없이 시작되어야 합니다.","playtest.sample.context.observed":"스폰 보호가 정상 동작했고, HUD가 제때 갱신되었으며, 첫 웨이브가 회귀 없이 완료되었습니다.","playtest.sample.report.markdown":`# 샘플 아레나 스모크 테스트
80
+
81
+ - 스폰 흐름: 통과
82
+ - HUD 카운트다운: 통과
83
+ - 웨이브 시작: 통과
84
+
85
+ 이 화면은 샘플 미리보기입니다. 라이브 플레이테스트 실행과 실제 리포트 저장은 Pro에서 사용할 수 있습니다.`,"playtest.sample.report.logs":`[sample] 플레이테스트 미리보기 부팅
86
+ [sample] 스폰 보호 활성화
87
+ [sample] HUD 카운트다운 렌더링
88
+ [sample] 1웨이브 완료
89
+ [sample] 미리보기 리포트 종료`,"sidebar.whatsNew":"새 소식","sidebar.help.group":"도움말 및 피드백","sidebar.help.bug":"버그 신고","sidebar.help.bug.tooltip":"로컬 진단 번들을 만들고 GitHub에 환경 정보가 채워진 버그 리포트 열기","bugReportDialog.title":"diagnostics.zip 첨부는 원인 분석에 도움이 됩니다","bugReportDialog.subtitle":"WEPPY가 이 컴퓨터에 진단 zip 파일을 만들었습니다. 이 파일에는 Studio, 플러그인, Sync, 도구 실행 로그가 들어 있어 문제를 확인하는 데 도움이 됩니다.","bugReportDialog.close":"닫기","bugReportDialog.loading":"diagnostics.zip 준비 중...","bugReportDialog.error":"진단 번들을 만들지 못했습니다. 진단 자료 없이 GitHub를 열 수 있습니다.","bugReportDialog.bundle":"번들","bugReportDialog.included":"포함 항목","bugReportDialog.included.none":"찾은 로그 파일 없음","bugReportDialog.optional":"이 파일 없이도 버그 신고를 제출할 수 있지만, zip을 함께 첨부하면 원인 분석이 더 빨라질 수 있습니다.","bugReportDialog.attachHow":"첨부하려면 zip 파일을 다운로드하거나 Finder/Explorer에서 연 뒤, GitHub 이슈의 Diagnostics ZIP (optional) 업로드 영역에 추가하고 제출하세요.","bugReportDialog.download":"1. diagnostics.zip 다운로드","bugReportDialog.reveal":"Finder에서 보기","bugReportDialog.reveal.opening":"여는 중...","bugReportDialog.reveal.opened":"파일 위치를 열었습니다","bugReportDialog.reveal.failed":"파일 위치를 열지 못했습니다.","bugReportDialog.openGithub":"2. GitHub 이슈 열기","bugReportDialog.openGithubFallback":"진단 자료 없이 GitHub 열기","bugReportDialog.retry":"다시 시도","bugReportDialog.hint":"zip에는 로컬 로그와 프로젝트 맥락이 포함될 수 있습니다. 공유하려는 경우 첨부하기 전에 내용을 확인하세요.","sidebar.help.feature":"기능 제안","sidebar.help.feature.tooltip":"GitHub에서 새 기능 또는 개선 제안하기","sidebar.help.discussions":"지원","sidebar.help.discussions.tooltip":"GitHub Issues에서 질문하거나 설치 도움 받기","sidebar.help.troubleshooting":"문제 해결","sidebar.help.troubleshooting.tooltip":"weppyai.com 공식 문제 해결 가이드 열기","header.whatsNew":"새 소식","header.whatsNew.tooltip":"새 소식","upgrade.title":"Pro 확인하기","upgrade.tagline":"Pro 기능 확인하기","upgrade.cta":"Pro 확인하기","upgrade.licenseShortcut":"라이선스 입력","upgrade.validUntil":"{{date}}까지","whatsNew.pageTitle":"새 소식","whatsNew.pageSubtitle":"MCP의 주요 변경사항을 확인하세요","whatsNew.unreadSection":"안 읽음","whatsNew.allSection":"전체 공지","whatsNew.empty":"공지가 없습니다","whatsNew.newBadge":"NEW","whatsNew.category.release":"릴리스","whatsNew.category.notice":"공지","whatsNew.category.deprecation":"지원 중단","whatsNew.category.tip":"팁","uiStudio.title":"UI 스튜디오","uiStudio.empty":"저장된 화면 캡처가 없습니다. AI 에이전트가 현재 UI 상태를 캡처하면 자동 생성됩니다.","uiStudio.loading":"불러오는 중…","uiStudio.pluginGuide.title":"Roblox Studio 플러그인이 연결되지 않았습니다","uiStudio.pluginGuide.message":"UI Studio는 연결된 Studio place의 화면 캡처와 변경 이력을 표시합니다. Studio와 WEPPY Plugin을 연결하면 자동으로 갱신됩니다.","uiStudio.pluginGuide.check1":"Roblox Studio가 실행 중인가요?","uiStudio.pluginGuide.check2":"WEPPY Plugin이 설치되어 실행 중인가요?","uiStudio.pluginGuide.waiting":"플러그인 연결을 기다리는 중...","uiStudio.capturedAt":"캡처 시각","uiStudio.scope":"범위","uiStudio.target":"대상","uiStudio.briefId":"브리프 ID","uiStudio.detailClose":"닫기","uiStudio.colCheck":"항목","uiStudio.colPriority":"우선순위","uiStudio.colCurrent":"현재","uiStudio.colRecommended":"권장","uiStudio.colSuggestion":"제안","uiStudio.priorityHigh":"우선 검토","uiStudio.priorityLow":"선택 개선","uiStudio.highPrioritySection":"우선 검토","uiStudio.lowPrioritySection":"선택 개선","uiStudio.groupSummary":"개 항목","uiStudio.fixLabel":"조치","uiStudio.copyFixCommand":"AI 지시문으로 복사","uiStudio.copiedToClipboard":"복사됨","uiStudio.fullPath":"전체 경로","uiStudio.falsePositiveWarning":"이 그룹은 오탐 가능성이 있습니다","uiStudio.noSuggestions":"현재 개선 제안 없음","uiStudio.sample.badge":"Pro UI 스튜디오 미리보기","uiStudio.sample.title":"Pro에서 이용 가능한 UI 스튜디오를 미리 보고 있습니다.","uiStudio.sample.message":"이 미리보기는 샘플 데이터입니다. 실제 화면 캡처, 검토 이력, AI 자동 수정 요청은 Pro에서 제공됩니다.","uiStudio.tabs.analysis":"분석","uiStudio.tabs.history":"변경 이력","uiStudio.analysis.reportsTitle":"UI 대상별 최신 분석","uiStudio.analysis.recentCapturesTitle":"최근 캡처","uiStudio.analysis.detailDialog":"분석 상세","uiStudio.analysis.targetCountLabel":"분석 대상","uiStudio.analysis.captureLabel":"캡처","uiStudio.analysis.verdict.hasSuggestions":"개선 제안 있음","uiStudio.analysis.verdict.needsFix":"개선 제안 있음","uiStudio.analysis.verdict.review":"개선 제안 있음","uiStudio.analysis.verdict.passed":"현재 개선 제안 없음","uiStudio.analysis.verdictLabel":"개선 요약","uiStudio.analysis.thresholds":"검토 기준","uiStudio.analysis.issueSummary.passed":"현재 검토 기준에서 추가 개선 제안은 없습니다.","uiStudio.history.title":"변경 이력","uiStudio.history.empty":"아직 변경 이력이 없습니다. AI 에이전트가 manage_ui 로 UI 를 수정하면 자동으로 기록됩니다.","uiStudio.history.loading":"로딩 중...","uiStudio.history.error":"오류","uiStudio.history.clear":"전체 삭제","uiStudio.history.filter.actions":"작업 유형","uiStudio.history.filter.actionAll":"전체","uiStudio.history.filter.actionCreate":"생성","uiStudio.history.filter.actionUpdate":"수정","uiStudio.history.filter.actionDelete":"삭제","uiStudio.history.filter.period":"기간","uiStudio.history.filter.dateAll":"전체","uiStudio.history.filter.today":"오늘","uiStudio.history.filter.yesterday":"어제","uiStudio.history.filter.last7Days":"최근 7일","uiStudio.history.filter.last30Days":"최근 30일","uiStudio.history.filter.customRange":"직접 지정","uiStudio.history.filter.reset":"초기화","uiStudio.history.filter.from":"시작일","uiStudio.history.filter.to":"종료일","uiStudio.history.row.affectedPaths":"경로","uiStudio.history.row.mutations":"변경 상세","uiStudio.history.row.expand":"▾ 펼치기","uiStudio.history.row.collapse":"▲ 닫기","uiStudio.history.row.expandDetails":"변경 상세 {n}건","uiStudio.history.row.collapseDetails":"변경 상세 닫기","uiStudio.history.row.toggleDetails":"변경 상세 토글","uiStudio.history.row.mutationsEmpty":"변경 내역 없음","uiStudio.history.row.toolLabel":"UI 변경 {n}건","uiStudio.history.row.compare":"전후 비교","uiStudio.history.row.noBeforeState":"이전 상태 없음","uiStudio.history.row.noAfterState":"이후 상태 없음","uiStudio.history.row.qualityPlan":"디자인 방향","uiStudio.history.row.designCheck":"개선 제안","uiStudio.history.row.designCheckUnavailable":"개선 제안: 요약 없음","uiStudio.history.row.designCheckNone":"개선 제안: 현재 없음","uiStudio.history.selection.deleteSelected":"선택 삭제","uiStudio.history.selection.selectAll":"모두 선택","uiStudio.history.selection.clearSelection":"선택 해제","uiStudio.history.confirm.deleteRequestsTitle":"변경 기록 삭제","uiStudio.history.confirm.deleteRequestsMessage":"선택한 변경 기록을 삭제합니다. 이 작업은 되돌릴 수 없습니다.","uiStudio.history.confirm.clearRequestsTitle":"변경 이력 삭제","uiStudio.history.confirm.clearRequestsMessage":"현재 place의 변경 이력을 삭제합니다. Studio 인스턴스에는 영향을 주지 않습니다.","uiStudio.history.confirm.cascadeOption":"연결된 화면 캡처도 함께 삭제","uiStudio.history.drawer.close":"닫기","uiStudio.actions.previewAgain":"다시 미리보기","uiStudio.actions.deleteSnapshot":"이 화면 캡처 삭제","uiStudio.actions.proRequired":"Pro에서 사용 가능","uiStudio.actions.captureCurrentState":"현재 상태 캡처","uiStudio.actions.checkSuggestionsAgain":"개선 제안 다시 확인","uiStudio.actions.previewRunning":"캡처 중…","uiStudio.actions.previewRunningDetail":"완료되면 새 화면 캡처 파일 ID를 표시합니다.","uiStudio.actions.previewNeedsSaveCheck":"캡처 완료, 저장 확인 필요","uiStudio.actions.previewSaved":"새 화면 캡처 저장 완료","uiStudio.actions.previewComplete":"캡처 완료","uiStudio.actions.previewSavedDetail":"기존 화면 캡처는 변경하지 않고 새 파일로 저장했습니다.","uiStudio.actions.previewSavedPathMissing":"새 화면 캡처 ID는 받았지만 저장 경로를 확인하지 못했습니다.","uiStudio.actions.previewSnapshotIdMissing":"새 화면 캡처 ID를 확인하지 못했습니다. 목록을 새로고침해 저장 여부를 확인해 주세요.","uiStudio.actions.more":"더 보기","uiStudio.gallery.selection.selectedCount":"개 선택됨","uiStudio.confirm.deleteSnapshotTitle":"화면 캡처 삭제","uiStudio.confirm.deleteSnapshotMessage":"이 화면 캡처 파일만 삭제됩니다 (Studio 인스턴스 보존).","uiStudio.confirm.deleteBatchTitle":"화면 캡처 일괄 삭제","uiStudio.confirm.deleteBatchMessage":"선택한 화면 캡처를 삭제합니다. 이 작업은 되돌릴 수 없습니다.","uiStudio.gallery.selectMode":"선택 모드","uiStudio.gallery.exitSelectMode":"취소","uiStudio.gallery.selectAll":"모두 선택","uiStudio.gallery.clearSelection":"선택 해제","uiStudio.gallery.deleteSelected":"선택 삭제","common.cancel":"취소","common.delete":"삭제","uiStudio.storage.title":"UI Studio 저장 데이터","uiStudio.storage.usageLabel":"사용 중","uiStudio.storage.historyBytes":"변경 이력","uiStudio.storage.snapshotBytes":"화면 캡처","uiStudio.storage.requestCount":"변경 기록","uiStudio.storage.mutationCount":"변경 상세","uiStudio.storage.snapshotCount":"화면 캡처","uiStudio.storage.countSuffix":"개","uiStudio.storage.lastRun":"마지막 자동 정리","uiStudio.storage.lastRunNever":"—","uiStudio.storage.lastRunFreed":"회수","uiStudio.storage.lastRunErrors":"오류","uiStudio.storage.loading":"로딩 중...","uiStudio.cleanup.policy.title":"자동 삭제 정책","uiStudio.cleanup.policy.modeOff":"사용 안 함 (off)","uiStudio.cleanup.policy.modeAge":"기간 기반 (age)","uiStudio.cleanup.policy.modeSize":"용량 기반 (size)","uiStudio.cleanup.policy.cascade":"연결된 화면 캡처도 함께 삭제","uiStudio.cleanup.policy.save":"정책 저장","uiStudio.cleanup.policy.runNow":"지금 정리","uiStudio.cleanup.policy.proRequired":"Pro에서 사용 가능","uiStudio.cleanup.policy.daysUnit":"일","uiStudio.cleanup.policy.mbUnit":"MB","uiStudio.cleanup.policy.gbUnit":"GB","uiStudio.cleanup.policy.confirm.title":"정책 적용 확인","uiStudio.cleanup.policy.confirm.messageStrict":"이 정책으로 즉시","uiStudio.cleanup.policy.confirm.requests":"건","uiStudio.cleanup.policy.confirm.snapshots":"개 화면 캡처","uiStudio.cleanup.policy.confirm.freed":"가 삭제됩니다 — 적용?","uiStudio.cleanup.keepLastNDays":"최근 {n}일만 남기기","uiStudio.cleanup.selectedDelete":"선택 삭제…","uiStudio.cleanup.deleteAll":"전체 삭제…","uiStudio.cleanup.cleanupConfirmTitle":"정리 확인","uiStudio.cleanup.cleanupConfirmMessage":"선택한 항목이 삭제됩니다. 이 작업은 되돌릴 수 없습니다.","uiStudio.cleanup.cleanupConfirmMessage.keep7":"7일 이전 변경 기록과 화면 캡처가 삭제됩니다. 이 작업은 되돌릴 수 없습니다.","uiStudio.cleanup.cleanupConfirmMessage.keep30":"30일 이전 변경 기록과 화면 캡처가 삭제됩니다. 이 작업은 되돌릴 수 없습니다.","uiStudio.cleanup.cleanupConfirmMessage.all":"개의 저장된 변경 기록과 화면 캡처가 삭제됩니다. 이 작업은 되돌릴 수 없습니다.","uiStudio.cleanup.label":"수동 정리","uiStudio.cleanup.studioPreservedNote":"이 작업은 디스크의 저장된 변경 기록과 화면 캡처만 삭제하며, Roblox Studio 인스턴스는 변경되지 않습니다.","uiStudio.history.sample.bannerBadge":"Pro 변경 이력 미리보기","uiStudio.history.sample.bannerTitle":"Pro에서 이용 가능한 UI 변경 이력 화면을 미리 보고 있습니다.","uiStudio.history.sample.bannerMessage":"이 미리보기는 샘플 데이터입니다. 실제 변경 이력, 전후 비교, 일괄 삭제는 Pro에서 제공됩니다.","uiStudio.fix.touchTarget.label":"터치 타겟 크기","uiStudio.fix.touchTarget.description":"모바일에서 손가락으로 누르기 편한 최소 크기를 만족하는지 확인합니다.","uiStudio.fix.touchTarget.howToFix":"버튼 Size를 44x44 px 이상으로 키우거나 UIPadding으로 터치 영역을 확장하세요.","uiStudio.fix.contrast.label":"텍스트 대비","uiStudio.fix.contrast.description":"텍스트와 배경의 명암 비율이 WCAG 접근성 기준을 만족하는지 확인합니다.","uiStudio.fix.contrast.howToFix":"TextColor3를 더 밝은 색(예: #FFFFFF)으로 바꾸거나 BackgroundColor3를 어둡게 조정하세요.","uiStudio.fix.contrast.falsePositive":"이모지 아이콘은 색상이 고정되어 대비 규칙이 오탐하는 경우가 있습니다.","uiStudio.fix.textScaled.label":"TextScaled 사용","uiStudio.fix.textScaled.description":"TextScaled가 켜져 있으나 UITextSizeConstraint가 없으면 언어 확장 시 레이아웃이 깨질 수 있습니다.","uiStudio.fix.textScaled.howToFix":"해당 TextLabel에 UITextSizeConstraint 자식을 추가하고 MaxTextSize를 지정하세요.","uiStudio.fix.safezone.label":"세이프존 배치","uiStudio.fix.safezone.description":"버튼이 플랫폼별 세이프존 안에 있는지 확인합니다.","uiStudio.fix.safezone.howToFix":"Position을 세이프존 안쪽으로 이동하거나 부모 Frame을 축소하세요.","uiStudio.fix.minTextSize.label":"최소 폰트 크기","uiStudio.fix.minTextSize.description":"텍스트가 너무 작아 가독성이 떨어지는지 확인합니다.","uiStudio.fix.minTextSize.howToFix":"본문 기준 TextSize를 14 이상으로 올리세요.","uiStudio.sample.history.request1.label":"HUD 레이아웃 초기 생성","uiStudio.sample.history.request2.label":"Inventory 모달 디자인 업데이트","uiStudio.sample.history.request3.label":"HUD HealthBar 색상 수정","uiStudio.sample.history.request4.label":"Inventory 탭 버튼 터치 타겟 확대","uiStudio.sample.history.request5.label":"Settings 팝업 삭제","uiStudio.sample.history.request6.label":"HUD 미니맵 컴포넌트 추가","uiStudio.sample.history.request1.mutation1.diff":"Frame + HealthBar + StaminaBar 생성","uiStudio.sample.history.request1.mutation2.diff":"BackgroundColor3 -> Color3.new(0.2,0.8,0.2)","uiStudio.sample.history.request1.mutation3.diff":"BackgroundColor3 -> Color3.new(0.1,0.6,1.0)","uiStudio.sample.history.request1.mutation4.diff":"AnchorPoint, Position, Size 설정","uiStudio.sample.history.request1.mutation5.diff":"화면 캡처 저장 완료","uiStudio.sample.history.request2.mutation1.diff":"BackgroundColor3 어둡게 조정 (대비 개선)","uiStudio.sample.history.request2.mutation2.diff":"TextColor3 -> Color3.new(1,1,1), TextSize 16 -> 18","uiStudio.sample.history.request2.mutation3.diff":"BorderSizePixel 0 -> 2, BorderColor3 설정","uiStudio.sample.history.request2.mutation4.diff":"화면 캡처 저장 완료","uiStudio.sample.history.request3.mutation1.diff":"BackgroundColor3 -> Color3.new(0.9,0.2,0.2) (빨간 계열)","uiStudio.sample.history.request3.mutation2.diff":"화면 캡처 저장 완료","uiStudio.sample.history.request4.mutation1.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation2.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation3.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation4.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation5.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation6.diff":"화면 캡처 저장 완료","uiStudio.sample.history.request5.mutation1.diff":"ScreenGui 제거 (Settings 전용 UI)","uiStudio.sample.history.request6.mutation1.diff":"Frame + MapImage + PlayerDot 생성 시도","uiStudio.sample.history.request6.mutation2.diff":"Size, Position, BackgroundTransparency 설정","uiStudio.sample.history.request6.mutation3.diff":"ImageLabel 설정 중 서버 재시작으로 중단","uiStudio.sample.history.request6.mutation4.diff":"불완전 화면 캡처 저장","uiStudio.sample.history.request6.mutation3.error":"server_restart: 연결 끊김","uiStudio.sample.history.request6.mutation4.error":"partial snapshot: 누락된 레이어 있음","uiStudio.sample.history.detail.backgroundColor":"배경색","uiStudio.sample.history.detail.anchorPoint":"앵커","uiStudio.sample.history.detail.position":"위치","uiStudio.sample.history.detail.size":"사이즈","uiStudio.sample.history.detail.textColor":"글자색","uiStudio.sample.history.detail.textSize":"글자 크기","uiStudio.sample.history.detail.borderSize":"테두리 크기","uiStudio.sample.history.detail.borderColor":"테두리색","settings.dataHistory.title":"데이터 및 이력","settings.dataHistory.title.tooltip":"대시보드에 저장된 데이터를 한 곳에서 관리합니다.","settings.dataHistory.collapse":"{title} 접기","settings.dataHistory.expand":"{title} 펼치기","settings.dataHistory.scope":"현재 프로젝트","settings.dataHistory.scope.tooltip":"삭제 작업은 항목에 따라 현재 프로젝트와 활성 place에 적용됩니다.","settings.dataHistory.intro":"저장된 대시보드 데이터를 확인하고, 관련 페이지로 이동하거나, 저장 기록을 한 곳에서 삭제합니다.","settings.dataHistory.toolsActivity.title":"도구 실행 기록","settings.dataHistory.toolsActivity.description":"Tools 페이지에 표시되는 저장된 도구 실행 기록입니다.","settings.dataHistory.toolStats.title":"도구 사용 통계","settings.dataHistory.toolStats.description":"도구 호출 수와 상태별 집계입니다.","settings.dataHistory.syncLog.title":"동기화 로그","settings.dataHistory.syncLog.description":"활성 place의 파일 동기화 이벤트 기록입니다.","settings.dataHistory.playtest.title":"플레이테스트 리포트","settings.dataHistory.playtest.description":"저장된 자동 플레이테스트 리포트와 로그입니다.","settings.dataHistory.projectChanges.title":"프로젝트 변경 요약","settings.dataHistory.projectChanges.description":"저장된 프로젝트 변경 요약입니다.","settings.dataHistory.connectionLog.title":"연결 로그","settings.dataHistory.connectionLog.description":"MCP와 Studio 연결 이벤트 기록입니다.","settings.dataHistory.uiStudio.title":"UI Studio 이력 및 화면 캡처","settings.dataHistory.uiStudio.tooltip":"저장된 UI Studio 변경 기록, 화면 캡처, 자동 삭제 정책을 관리합니다.","settings.dataHistory.uiStudio.description":"저장된 UI Studio 변경 기록, 화면 캡처, 정리 정책입니다.","settings.dataHistory.uiStudio.clear.title":"UI Studio 저장 데이터를 삭제할까요?","settings.dataHistory.uiStudio.clear.message":"저장된 UI Studio 변경 기록과 화면 캡처만 삭제됩니다. Roblox Studio 인스턴스와 프로젝트 오브젝트는 변경되지 않습니다.","settings.dataHistory.uiStudio.clear.success":"UI Studio 저장 데이터를 삭제했습니다.","settings.dataHistory.uiStudio.clear.failed":"UI Studio 저장 데이터를 삭제하지 못했습니다.","settings.dataHistory.metric.unavailable":"확인 불가","settings.dataHistory.metric.sizeUnavailable":"용량 확인 불가","settings.dataHistory.metric.records":"건","settings.dataHistory.metric.runs":"회","settings.dataHistory.metric.sessions":"세션","settings.dataHistory.metric.reports":"개 리포트","settings.dataHistory.open":"열기","settings.dataHistory.clear.title":"저장 데이터를 삭제할까요?","settings.dataHistory.clear.message":"대시보드에 저장된 기록만 삭제됩니다. Roblox Studio 인스턴스와 프로젝트 오브젝트는 변경되지 않습니다.","settings.dataHistory.clear.success":"저장 데이터를 삭제했습니다.","settings.dataHistory.clear.failed":"저장 데이터를 삭제하지 못했습니다.","uiStudio.history.sample.tooltip":"전체 이력은 Pro에서 이용 가능합니다","toast.serverConnected":"MCP 서버 연결됨","toast.serverDisconnected":"MCP 서버 연결 끊김","toast.pluginConnected":"플러그인 연결됨","toast.pluginDisconnected":"플러그인 연결 끊김","toast.clearSuccess":"삭제되었습니다","toast.clearFailed":"삭제하지 못했습니다","common.clear":"비우기","settings.license.activate":"라이센스 활성화","settings.license.refresh":"라이센스 새로고침","settings.license.keyInput":"라이센스 키","settings.license.disconnected":"연결 끊김","settings.license.disconnected.tooltip":"WEPPY Dashboard에서 라이센스를 관리하려면 먼저 MCP 서버에 다시 연결하세요.","settings.license.live.tooltip":"라이센스 작업은 MCP 서버에 즉시 반영됩니다.","settings.license.status.activationRequired":"활성화 필요","settings.license.status.activationRequired.tooltip":"WEPPY Dashboard가 이 상태를 갱신하려면 먼저 수동으로 라이센스를 활성화해야 합니다.","settings.license.status.grace":"유예","settings.license.status.grace.tooltip":"공급자 검증이 일시적으로 불가하지만, 유예 기간 동안 Pro 접근은 유지됩니다.","settings.license.status.graceBilling.tooltip":"결제 관련 유예 기간 동안 Pro 접근은 유지됩니다.","settings.license.detail.graceBilling":"결제 유예 기간 동안 Pro 접근이 유지됩니다.","settings.license.detail.graceProviderUnavailable":"공급자 사용 불가. 유예 모드 동안 Pro 접근은 유지됩니다.","settings.license.detail.manualActivation":"Pro 접근을 복구하려면 수동 활성화가 필요합니다.","settings.license.detail.missingSessionToken":"현재 세션 토큰이 없어 새로고침이 차단되었습니다.","settings.license.detail.refreshRecommended":"라이센스 검증을 곧 새로고침해야 합니다.","connection.agents.kill":"종료","connection.agents.kill.title":"에이전트를 종료할까요?","connection.agents.killed":"에이전트가 종료되었습니다","connection.agents.killFailed":"에이전트를 종료하지 못했습니다","connection.agents.lastCommand":"최근 명령","connection.agents.lastCommand.tooltip":"이 에이전트가 가장 최근에 실행한 도구 호출입니다.","connection.agents.lastSeen":"마지막 활동","connection.agents.lastSeen.tooltip":"이 에이전트의 가장 최근 heartbeat 또는 활동 시각입니다.","connection.clear.title":"연결 로그를 비울까요?","connection.clear.message":"현재 프로젝트에 저장된 연결 로그가 영구적으로 삭제됩니다.","sync.clear.title":"동기화 로그를 비울까요?","sync.clear.message":"현재 플레이스에 저장된 동기화 로그가 영구적으로 삭제됩니다.","playtest.clear.title":"테스트 히스토리를 비울까요?","playtest.clear.message":"현재 플레이스에 저장된 플레이테스트 리포트가 영구적으로 삭제됩니다.","changelog.clear.title":"변경 이력을 비울까요?","changelog.clear.message":"현재 플레이스에 저장된 변경 이력이 영구적으로 삭제됩니다.","sync.status.placePath":"플레이스 경로","sync.status.placePath.tooltip":"Explorer 파일이 동기화되는 현재 플레이스 디렉토리입니다.","tier.progress.label":"Pro / 전체","changelog.card.representativeArea":"대표 영역","changelog.card.verification":"검증","uiStudio.tabs.analysis.tooltip":"AI가 캡처한 화면을 한눈에 보고, 개선이 필요한 UI를 빠르게 찾는 화면입니다.","uiStudio.tabs.history.tooltip":"AI가 UI를 수정한 모든 기록을 시간순으로 보여줍니다. 변경 전·후 화면을 비교할 수 있습니다.","uiStudio.title.tooltip":"AI가 만든 UI 화면을 모아두고 개선 제안을 확인하는 공간입니다.","uiStudio.analysis.reportsTitle.tooltip":"각 UI(예: 인벤토리 창, 메인 메뉴)별로 가장 최근 캡처와 개선 제안 요약을 보여줍니다.","uiStudio.analysis.verdict.hasSuggestions.tooltip":"이 UI에서 더 좋아질 수 있는 부분이 발견됐습니다. 카드를 눌러 상세 내용을 확인하세요.","uiStudio.analysis.verdict.passed.tooltip":"현재 검사 기준에서는 개선할 부분이 발견되지 않았습니다.","uiStudio.analysis.counts.tooltip":"주요는 먼저 검토하면 좋은 핵심 항목, 참고는 다듬으면 좋은 부가 항목입니다.","uiStudio.analysis.thresholds.tooltip":"이 분석에 사용된 기준 세트입니다 (기본값 또는 사용자 정의).","uiStudio.analysis.recentCapturesTitle.tooltip":"최근에 저장된 모든 캡처를 시간순으로 보여줍니다.","uiStudio.gallery.selectAll.tooltip":"현재 보이는 모든 캡처를 한 번에 선택합니다.","uiStudio.gallery.clearSelection.tooltip":"현재 선택된 캡처를 모두 해제합니다.","uiStudio.gallery.deleteSelected.tooltip":"선택한 캡처 파일만 삭제합니다. Studio의 실제 UI는 그대로 유지됩니다.","uiStudio.gallery.cardCheckbox.tooltip":"이 캡처를 선택합니다. 여러 개 선택해 한 번에 삭제할 수 있습니다.","uiStudio.detailClose.tooltip":"이 상세 패널을 닫습니다.","uiStudio.actions.captureCurrentState.tooltip":"지금 Studio에 표시되고 있는 UI를 새 캡처로 저장합니다. 기존 캡처는 그대로 남습니다.","uiStudio.actions.checkSuggestionsAgain.tooltip":"현재 캡처를 새로 캡처하지 않고 개선 제안만 다시 계산합니다.","uiStudio.actions.more.tooltip":"추가 작업 메뉴를 엽니다.","uiStudio.actions.deleteSnapshot.tooltip":"이 캡처 파일만 삭제합니다. Studio의 실제 UI는 변경되지 않습니다.","uiStudio.capturedAt.tooltip":"이 화면이 저장된 시각입니다.","uiStudio.scope.tooltip":"캡처 대상 범위입니다 (예: 화면 전체 또는 특정 UI).","uiStudio.target.tooltip":"캡처된 UI 인스턴스의 정확한 경로입니다.","uiStudio.briefId.tooltip":"이 UI를 만든 디자인 지시서(Design Brief)의 식별자입니다.","uiStudio.analysis.verdictLabel.tooltip":"이 캡처에 대한 전반적인 개선 판정입니다.","uiStudio.suggestionGroup.tooltip":"같은 종류의 개선 제안을 묶어서 보여줍니다. 헤더를 클릭해 펼치거나 접을 수 있습니다.","uiStudio.groupSummary.tooltip":"이 항목에 해당하는 UI 요소의 개수입니다.","uiStudio.colCurrent.tooltip":"현재 적용된 값입니다.","uiStudio.colRecommended.tooltip":"권장하는 값입니다.","uiStudio.copyFixCommand.tooltip":"이 문제를 AI에게 설명해 한 번에 고치게 할 수 있는 지시문을 복사합니다.","uiStudio.falsePositiveWarning.tooltip":"이 검사 항목은 실제로는 문제가 아닐 수도 있으니 직접 확인 후 적용하세요.","uiStudio.history.filter.actions.tooltip":"AI가 수행한 변경 종류로 기록을 거를 수 있습니다.","uiStudio.history.filter.period.tooltip":"기록을 시간 범위로 거를 수 있습니다.","uiStudio.history.filter.from.tooltip":"조회를 시작할 날짜입니다.","uiStudio.history.filter.to.tooltip":"조회를 종료할 날짜입니다.","uiStudio.history.filter.actionAll.tooltip":"모든 종류의 작업을 보여줍니다.","uiStudio.history.filter.actionCreate.tooltip":"새 UI를 만든 작업만 보여줍니다.","uiStudio.history.filter.actionUpdate.tooltip":"기존 UI를 수정한 작업만 보여줍니다.","uiStudio.history.filter.actionDelete.tooltip":"UI를 삭제한 작업만 보여줍니다.","uiStudio.history.filter.dateAll.tooltip":"전체 기간을 봅니다.","uiStudio.history.filter.today.tooltip":"오늘 발생한 변경만 봅니다.","uiStudio.history.filter.yesterday.tooltip":"어제 발생한 변경만 봅니다.","uiStudio.history.filter.last7Days.tooltip":"최근 7일간의 변경만 봅니다.","uiStudio.history.filter.last30Days.tooltip":"최근 30일간의 변경만 봅니다.","uiStudio.history.filter.customRange.tooltip":"직접 시작일과 종료일을 지정합니다.","uiStudio.history.filter.reset.tooltip":"모든 필터를 초기 상태로 되돌립니다.","uiStudio.history.title.tooltip":"AI가 UI를 수정한 모든 작업을 시간순으로 모아둔 곳입니다.","uiStudio.history.clear.tooltip":"현재 프로젝트의 모든 변경 이력을 삭제합니다. Studio의 실제 UI는 영향받지 않습니다.","uiStudio.history.row.compare.tooltip":"변경 전과 후 화면을 나란히 비교해 봅니다. 클릭하면 큰 화면으로 확인할 수 있습니다.","uiStudio.history.row.extraPaths.tooltip":"이 작업으로 함께 변경된 다른 UI의 개수입니다.","uiStudio.history.row.noBeforeState.tooltip":"변경 전 시점의 캡처가 저장되지 않았습니다.","uiStudio.history.row.noAfterState.tooltip":"변경 후 시점의 캡처가 저장되지 않았습니다.","uiStudio.history.row.affectedPaths.tooltip":"이 작업으로 영향을 받은 UI의 개수입니다.","uiStudio.history.row.mutations.tooltip":"속성 변경 등 세부 작업의 개수입니다.","uiStudio.history.row.qualityPlan.tooltip":"이 변경에 사용된 brief 디자인 방향입니다.","uiStudio.history.row.designCheck.tooltip":"변경 이후 Design Check 개선 제안 요약입니다.","uiStudio.history.row.toggleDetails.tooltip":"어떤 속성이 어떻게 바뀌었는지 한 줄씩 자세히 보여줍니다.","uiStudio.compare.before.tooltip":"AI가 변경하기 직전에 저장된 화면입니다.","uiStudio.compare.after.tooltip":"AI가 변경한 직후에 저장된 화면입니다.","uiStudio.compare.path.tooltip":"이 화면의 UI 인스턴스 경로입니다.","uiStudio.storage.title.tooltip":"UI Studio가 디스크에 저장한 변경 이력과 캡처의 사용량을 보여줍니다.","uiStudio.storage.usageLabel.tooltip":"현재 이 프로젝트에서 UI Studio가 사용 중인 디스크 용량입니다.","uiStudio.storage.historyBytes.tooltip":"변경 기록 데이터(JSON)가 차지하는 용량입니다.","uiStudio.storage.snapshotBytes.tooltip":"캡처된 PNG 이미지 파일이 차지하는 용량입니다.","uiStudio.storage.requestCount.tooltip":"AI가 UI를 수정한 작업의 개수입니다.","uiStudio.storage.mutationCount.tooltip":"각 작업 안의 세부 변경 항목 개수입니다 (속성 변경 한 줄 = 1개).","uiStudio.storage.snapshotCount.tooltip":"저장된 캡처 이미지 파일의 개수입니다.","uiStudio.storage.lastRun.tooltip":"자동 삭제 정책이 가장 최근에 실행된 시각과 결과입니다.","uiStudio.cleanup.label.tooltip":"원할 때 직접 변경 이력과 캡처를 정리할 수 있습니다.","uiStudio.cleanup.keep7.tooltip":"지금부터 7일 이전의 변경 이력과 캡처를 모두 삭제합니다.","uiStudio.cleanup.keep30.tooltip":"지금부터 30일 이전의 변경 이력과 캡처를 모두 삭제합니다.","uiStudio.cleanup.deleteAll.tooltip":"이 프로젝트에 저장된 모든 변경 이력과 캡처를 삭제합니다. Studio의 실제 UI는 변경되지 않습니다.","uiStudio.cleanup.policy.title.tooltip":"오래되거나 용량을 차지하는 캡처를 자동으로 정리하는 규칙입니다.","uiStudio.cleanup.policy.modeOff.tooltip":"자동 정리를 끕니다. 직접 정리하기 전까지 모든 데이터가 유지됩니다.","uiStudio.cleanup.policy.modeAge.tooltip":"지정한 일수보다 오래된 데이터를 자동으로 삭제합니다.","uiStudio.cleanup.policy.modeSize.tooltip":"총 사용량이 지정한 크기를 넘으면 오래된 데이터부터 자동으로 삭제합니다.","uiStudio.cleanup.policy.agePreset.tooltip":"이 일수보다 오래된 데이터를 삭제합니다.","uiStudio.cleanup.policy.ageInput.tooltip":"1일에서 365일 사이로 직접 입력할 수 있습니다.","uiStudio.cleanup.policy.sizePreset.tooltip":"총 사용량이 이 크기를 넘지 않도록 유지합니다.","uiStudio.cleanup.policy.sizeInput.tooltip":"50MB에서 10000MB(10GB) 사이로 직접 입력할 수 있습니다.","uiStudio.cleanup.policy.cascade.tooltip":"변경 이력만이 아니라 그 이력에 연결된 캡처 이미지도 함께 삭제합니다. 끄면 이미지는 남깁니다.","uiStudio.cleanup.policy.save.tooltip":"현재 입력한 자동 삭제 규칙을 저장합니다. 저장 후부터 백그라운드에서 적용됩니다.","uiStudio.cleanup.policy.runNow.tooltip":"다음 자동 실행을 기다리지 않고 현재 규칙을 즉시 한 번 실행합니다.","settings.license.refresh.tooltip":"라이센스 서버에서 최신 상태를 다시 가져옵니다. 결제·취소 후 상태가 바로 반영되지 않을 때 사용하세요.","settings.license.reset.tooltip":"현재 등록된 라이센스 키를 제거합니다. 다른 키로 다시 활성화할 때 사용하세요.","settings.license.activate.tooltip":"입력한 라이센스 키로 Pro 기능을 활성화합니다.","tier.upgrade.tooltip":"Pro 기능과 구매 옵션을 확인합니다.","settings.language.auto.tooltip":"운영체제 언어 설정을 따릅니다. 지원되지 않는 언어이면 영어로 표시됩니다.","settings.dataHistory.open.tooltip":"이 항목을 자세히 보는 페이지로 이동합니다.","settings.dataHistory.clear.tooltip":"이 항목에 저장된 기록만 삭제합니다. Studio의 실제 데이터는 변경되지 않습니다.","settings.dataHistory.toggle.tooltip":"이 섹션을 접거나 펼칩니다.","settings.dataHistory.toolsActivity.metric.tooltip":"저장된 도구 실행 기록의 개수와 디스크 사용량입니다.","settings.dataHistory.toolStats.metric.tooltip":"집계된 총 실행 횟수와 세션 수입니다.","settings.dataHistory.syncLog.metric.tooltip":"저장된 동기화 이벤트의 개수와 디스크 사용량입니다.","settings.dataHistory.playtestReports.metric.tooltip":"저장된 플레이테스트 보고서의 개수와 디스크 사용량입니다.","settings.dataHistory.projectChanges.metric.tooltip":"저장된 프로젝트 변경 요약의 개수와 디스크 사용량입니다.","settings.dataHistory.connectionLog.metric.tooltip":"저장된 연결 이벤트의 개수와 디스크 사용량입니다.","settings.dataHistory.uiStudio.metric.tooltip":"저장된 UI Studio 변경 기록·캡처 수와 총 디스크 사용량입니다.","uiStudio.designCheckResultsTitle":"Design Check 제안","uiStudio.designCheckResultsTitle.tooltip":"All improvement suggestions found in this capture.","uiStudio.actions.designCheckAgain":"다시 확인","uiStudio.actions.designCheckRunning":"개선 제안 확인 중...","uiStudio.actions.designCheckRunningDetail":"완료되면 우선 검토/검토 권장/선택 개선 항목 수를 표시합니다.","uiStudio.actions.designCheckComplete":"개선 제안 확인 완료","uiStudio.actions.designCheckNoSnapshotSaved":"이 작업은 화면 캡처 파일을 새로 저장하지 않습니다.","uiStudio.sample.designCheck.contrast":"텍스트 대비 {expected} 미만 (현재 {actual}). TextColor3 또는 BackgroundColor3 조정 필요.","uiStudio.sample.designCheck.touchTarget":"터치 타겟 {expected} 권장 (현재 {actual}). Size 또는 padding을 늘리세요.","uiStudio.sample.designCheck.minTextSize":"TextSize가 {expected} 미만입니다 (현재 {actual}). 가독성 확보를 위해 상향 조정하세요.","uiStudio.gallery.priorityHighBadge.tooltip":"우선 검토 제안 개수입니다. 클릭해서 상세 내용을 확인하세요.","uiStudio.gallery.priorityMediumBadge.tooltip":"검토 권장 제안 개수입니다.","uiStudio.priorityMedium":"검토 권장","uiStudio.mediumPrioritySection":"검토 권장","uiStudio.gallery.priorityLowBadge.tooltip":"선택 개선 제안 개수입니다.","tier.banner.progressLabel":"Pro / 전체","uiStudio.error":"오류","uiStudio.analysis.expandChildren":"하위 대상 보기","uiStudio.analysis.openDetail":"상세 보기","uiStudio.analysis.childTargets":"하위 대상","uiStudio.analysis.childDetailHint":"하위 대상 상세 보기","uiStudio.compare.before":"변경 전","uiStudio.compare.after":"변경 후","uiStudio.history.drawer.changeDetails":"변경 상세","uiStudio.gallery.cardCheckbox":"화면 캡처 선택","sidebar.assets":"에셋","assets.title":"에셋","assets.experimental":"실험 기능","assets.subtitle":"로컬 원본을 확인하고 Roblox에 업로드하며 place별 사용 위치를 점검합니다.","assets.scope.label":"에셋 범위","assets.scope.place":"현재 Place","assets.scope.shared":"공용","assets.count.shown":"표시 중인 에셋: {count}","assets.category.filter":"카테고리","assets.category.all":"전체","assets.category.image":"이미지","assets.category.decal":"데칼","assets.category.audio":"오디오","assets.category.mesh":"메시","assets.category.model":"모델","assets.category.rbxm":"RBXM","assets.category.video":"비디오","assets.category.animation":"애니메이션","assets.category.comingSoon":"추후 지원 예정","assets.status.localOnly":"로컬 전용","assets.status.uploading":"업로드 중","assets.status.processing":"처리 중","assets.status.uploaded":"업로드됨","assets.status.failed":"실패","assets.status.superseded":"대체됨","assets.rescan":"다시 스캔","assets.rescan.tooltip":"현재 필터에 해당하는 inbox 폴더를 스캔합니다.","assets.rescan.chooseCategory":"다시 스캔할 카테고리를 먼저 선택하세요.","assets.rbxmGuide.title":"Studio에서 RBXM 저장","assets.rbxmGuide.body":"Roblox Studio에서 오브젝트를 선택한 뒤 WEPPY Plugin > Assets에서 선택 항목을 로컬 RBXM 에셋으로 저장하세요.","assets.rbxmGuide.thumbnail":"플러그인 저장 흐름에서 썸네일 자동 생성 여부를 선택할 수 있고, 저장된 RBXM 에셋은 여기에서 관리, 업로드, Studio 삽입에 사용할 수 있습니다.","assets.exportSelection":"Studio 선택 내보내기","assets.exportSelection.tooltip":"현재 Studio 선택 항목을 로컬 .rbxm 에셋으로 내보냅니다.","assets.exportSelection.chooseCategory":"Studio 선택 항목을 내보내려면 RBXM 카테고리를 선택하세요.","assets.upload.open":"업로드","assets.upload.open.tooltip":"이 로컬 파일을 Roblox Open Cloud로 업로드합니다.","assets.upload.selectFirst":"에셋을 먼저 선택하세요.","assets.upload.title":"에셋 업로드","assets.upload.checkingSettings":"업로드 설정을 확인하는 중...","assets.upload.settingsLoadFailed":"업로드 설정을 불러오지 못했습니다.","assets.upload.settingsRequired":"업로드 설정 필요","assets.upload.settingsRequired.apiKey":"업로드 전에 Open Cloud API Key를 저장하세요.","assets.upload.settingsRequired.toggle":"업로드 전에 Open Cloud 업로드를 켜세요.","assets.upload.settingsRequired.creator":"업로드 전에 기본 Creator를 저장하세요.","assets.upload.openSettings":"Asset Library 설정 열기","assets.upload.creator":"Creator","assets.upload.creatorType":"Creator 유형","assets.upload.creatorId":"Creator ID","assets.upload.envCreatorHelp":"환경변수 API Key는 여기에서 기본 Creator를 저장할 수 없습니다. 이번 업로드에 사용할 Creator를 입력하세요.","assets.upload.displayNameHelp":"Roblox에 에셋 표시 이름으로 저장됩니다.","assets.upload.descriptionHelp":"Roblox에 에셋 설명으로 저장됩니다.","assets.upload.creatorHelp":"Open Cloud에서 업로드된 에셋의 소유자로 사용됩니다.","assets.upload.creatorTypeHelp":"Open Cloud에 Creator 유형으로 전달됩니다.","assets.upload.creatorIdHelp":"Open Cloud에 업로드된 에셋을 소유할 User 또는 Group ID로 전달됩니다.","assets.upload.submit":"Roblox Open Cloud로 업로드","assets.upload.uploading":"업로드 중...","assets.upload.noDelete":"WEPPY는 Roblox 에셋 삭제 기능을 제공하지 않습니다.","assets.upload.delay":"Roblox 처리와 moderation 때문에 Studio 또는 Creator Dashboard 표시가 지연될 수 있습니다.","assets.delete.tooltip":"이 로컬 Asset Library 항목을 삭제합니다.","assets.delete.title":"에셋 삭제","assets.delete.message":"로컬 Asset Library 파일만 삭제합니다. 업로드된 Roblox 에셋은 삭제되지 않습니다.","assets.creator.user":"사용자","assets.creator.group":"그룹","assets.settings.open":"설정 열기","assets.settings.open.tooltip":"Roblox 업로드 설정을 엽니다.","assets.settings.title":"Asset Library 설정","assets.settings.proOnly":"Roblox 업로드 설정과 Open Cloud credential 관리는 Pro에서 사용할 수 있습니다.","assets.settings.openCloudToggle":"Roblox Open Cloud 업로드 사용","assets.settings.openCloudToggle.help":"선택한 Open Cloud credential profile로 Asset Library 항목을 Roblox에 업로드할 수 있게 합니다.","assets.settings.apiKey":"Open Cloud API Key","assets.settings.apiKeyGuide":"Assets Read와 Write 권한이 포함된 Roblox API key를 생성하세요.","assets.settings.creatorHelp":"프로필 URL의 숫자 사용자 ID 또는 그룹 URL의 숫자 그룹 ID를 사용하세요.","assets.settings.credential.none":"저장된 API key 없음","assets.settings.credential.env":"환경변수","assets.settings.credential.local":"로컬 암호화 파일","assets.settings.registeredApiKey":"등록된 API Key","assets.settings.credentialProfile":"Credential Profile","assets.settings.activeProfileBadge":"사용 중","assets.settings.field.profile":"프로필","assets.settings.field.apiKey":"API Key","assets.settings.field.storage":"저장 위치","assets.settings.field.validationStatus":"검증 상태","assets.settings.field.creators":"Creator 수","assets.settings.validation.unknown":"검증 전","assets.settings.validation.valid":"연결됨","assets.settings.validation.invalid":"확인 필요","assets.settings.profileSelected":"Open Cloud credential profile을 선택했습니다.","assets.settings.useProfile":"프로필 사용","assets.settings.replaceApiKey":"API Key 교체","assets.settings.profileLabel":"프로필 이름 (선택 사항)","assets.settings.profileLabel.placeholder":"Studio 자동화 키","assets.settings.profileLabel.help":"선택 사항입니다. 비워두면 WEPPY가 Open Cloud key 이름을 자동으로 저장합니다.","assets.settings.saveApiKey":"API Key 저장","assets.settings.testConnection":"연결 테스트","assets.settings.removeApiKey":"API Key 등록 해제","assets.settings.saveCreator":"기본 Creator 저장","assets.settings.saveCreatorPreset":"Creator 저장","assets.settings.addCreator":"Creator 추가","assets.settings.addCreator.tooltip.ready":"이 프로필에 다른 User 또는 Group Creator preset을 추가합니다.","assets.settings.cancelCreator":"취소","assets.settings.defaultCreatorBadge":"기본값","assets.settings.makeDefaultCreator":"기본값으로 설정","assets.settings.unregisterCreator":"Creator 등록 해제","assets.settings.creatorLabel":"Creator 라벨 (선택 사항)","assets.settings.creatorLabel.placeholder":"메인 스튜디오 그룹","assets.settings.creatorLabel.help":"선택 사항입니다. 비워두면 WEPPY가 User 123 또는 Group 456 같은 라벨을 자동으로 저장합니다.","assets.settings.action.proRequired":"에셋 업로드 설정은 Pro에서 사용할 수 있습니다.","assets.settings.action.busy":"현재 설정 작업이 끝날 때까지 기다리세요.","assets.settings.saveApiKey.tooltip.ready":"이 API Key를 로컬 암호화 저장소에 저장합니다.","assets.settings.saveApiKey.tooltip.enter":"로컬에 저장할 Open Cloud API Key를 입력하세요.","assets.settings.testConnection.tooltip.entered":"입력한 API Key를 저장하기 전에 테스트합니다.","assets.settings.testConnection.tooltip.saved":"저장된 Open Cloud API Key 연결을 테스트합니다.","assets.settings.testConnection.tooltip.enterOrSaved":"연결을 테스트하려면 API Key를 입력하거나 먼저 저장하세요.","assets.settings.removeApiKey.tooltip.ready":"WEPPY에 로컬 저장된 Open Cloud API Key 등록을 해제합니다.","assets.settings.removeApiKey.tooltip.none":"저장된 로컬 Open Cloud API Key가 없습니다.","assets.settings.removeApiKey.tooltip.env":"환경변수 API Key는 Dashboard에서 제거할 수 없습니다. WEPPY 외부에서 ROBLOX_OPEN_CLOUD_API_KEY를 제거하세요.","assets.settings.unregisterCreator.tooltip.ready":"이 Creator를 선택한 프로필에서 등록 해제합니다.","assets.settings.unregisterApiKey.title":"API Key 등록을 해제할까요?","assets.settings.unregisterApiKey.message":"Roblox API Key 자체는 폐기되지 않습니다. WEPPY가 이 기기에 저장한 Credential Profile 등록 정보만 제거합니다.","assets.settings.unregisterCreator.title":"Creator 등록을 해제할까요?","assets.settings.unregisterCreator.message":"Roblox 사용자나 그룹은 삭제되지 않습니다. 선택한 API Key 프로필의 Creator 목록에서만 해제됩니다.","assets.settings.saveCreator.tooltip.ready":"이 Creator를 업로드 기본 소유자로 저장합니다.","assets.settings.saveCreator.tooltip.noLocal":"기본 Creator를 저장하려면 먼저 로컬 Open Cloud API Key를 저장하세요.","assets.settings.saveCreator.tooltip.env":"환경변수 API Key는 여기에서 기본 Creator를 저장할 수 없습니다. 업로드 창에서 Creator 정보를 입력하세요.","assets.settings.saveCreator.tooltip.enterId":"기본 Creator를 저장하려면 사용자 또는 그룹 ID를 입력하세요.","assets.settings.apiKeySaved":"Open Cloud API Key가 로컬에 저장되었습니다.","assets.settings.apiKeyTested":"Open Cloud API Key 연결을 확인했습니다.","assets.settings.apiKeyRemoved":"로컬 Open Cloud API Key 등록을 해제했습니다.","assets.settings.envApiKeyStillActive":"환경변수 credential이 계속 사용 중입니다. WEPPY 외부에서 ROBLOX_OPEN_CLOUD_API_KEY를 제거하세요.","assets.settings.defaultCreatorSaved":"기본 Creator가 로컬에 저장되었습니다.","assets.settings.creatorUnregistered":"이 프로필에서 Creator 등록을 해제했습니다.","assets.settings.creatorUnregisterFailed":"Creator 등록 해제에 실패했습니다.","assets.settings.saved":"업로드 설정이 저장되었습니다.","assets.settings.saveFailed":"업로드 설정 저장에 실패했습니다.","assets.settings.loadFailed":"업로드 설정을 불러오지 못했습니다.","assets.settings.tested":"연결을 확인했습니다.","assets.settings.testFailed":"연결 테스트에 실패했습니다.","assets.settings.removed":"API key 등록을 해제했습니다.","assets.settings.removeFailed":"API key 등록 해제에 실패했습니다.","assets.basic.notice":"Basic에서는 탐색, 미리보기, 메타데이터 편집, 사용 위치 스캔을 사용할 수 있습니다. Roblox 업로드는 Pro에서 사용할 수 있습니다.","assets.proOnly.tooltip":"Roblox 업로드는 Pro에서 사용할 수 있습니다.","assets.proOnly.upload":"Roblox 업로드는 Pro에서 사용할 수 있습니다.","assets.empty.title":"에셋 없음","assets.empty.body":"범위를 선택한 뒤 현재 필터에 해당하는 inbox 폴더를 다시 스캔하세요.","assets.detail.title":"에셋 상세","assets.detail.displayName":"표시 이름","assets.detail.description":"설명","assets.detail.save":"메타데이터 저장","assets.detail.refreshStatus":"새로고침","assets.detail.scanUsage":"사용 위치 스캔","assets.detail.localFile":"로컬 파일","assets.detail.fileName":"파일","assets.detail.category":"카테고리","assets.detail.scope":"범위","assets.detail.mimeType":"타입","assets.detail.size":"크기","assets.detail.dimensions":"크기(px)","assets.detail.duration":"길이","assets.detail.source":"원본 경로","assets.detail.sha256":"SHA-256","assets.detail.roblox":"Roblox 업로드 상태","assets.detail.status":"상태","assets.detail.assetId":"Asset ID","assets.detail.error":"오류","assets.detail.copyAssetId":"Asset ID 복사","assets.detail.copyUri":"URI 복사","assets.detail.studioUri":"Studio URI","assets.detail.robloxWebUrl":"Creator Dashboard URL","assets.detail.copyStudioUri":"Studio URI 복사","assets.detail.copyWebUrl":"설정 URL 복사","assets.detail.openRobloxPage":"설정 페이지 열기","assets.detail.robloxWebUrlNotice":"이 페이지를 열려면 업로드된 에셋을 소유하거나 관리할 수 있는 Roblox 계정이 필요합니다.","assets.detail.uploadHistory":"업로드 이력","assets.detail.usedInPlace":"현재 Place에서 쓰인 위치","assets.detail.noUsage":"아직 로컬 Sync 파일에서 참조를 찾지 않았습니다.","assets.detail.usageSource":"확인 기준","assets.detail.usageSource.localSync":"로컬 Sync 파일","assets.detail.usageSource.notScanned":"아직 확인하지 않음","assets.detail.lastScanned":"마지막 확인 시각","assets.detail.lastScannedAt":"마지막 확인: {time}","assets.detail.lastScanned.never":"확인 기록 없음","assets.detail.noUsageUnscanned":"사용 위치 스캔을 실행하면 로컬 Sync 파일에서 이 Roblox Asset ID가 쓰인 위치를 찾습니다.","assets.detail.noUsageAfterScan":"마지막 확인에서 로컬 Sync 파일 내 참조를 찾지 못했습니다.","assets.detail.noUsageNoRobloxId":"Roblox Asset ID가 아직 없어 사용 위치를 확인할 수 없습니다. 업로드 후 스캔할 수 있습니다.","assets.detail.technicalDetails":"기술 세부 정보","assets.detail.stableId":"Stable ID","assets.detail.sourceKind":"원본 유형","assets.detail.createdAt":"생성됨","assets.detail.updatedAt":"수정됨","assets.detail.operationId":"Operation ID","assets.detail.operationPath":"Operation 경로","assets.detail.versionId":"Version ID","assets.detail.remotePath":"Remote path","assets.detail.moderationState":"Moderation","assets.detail.line":"{line}번째 줄","assets.studio.notConnected":"Studio 에셋 작업을 사용하려면 Roblox Studio를 연결하세요.","assets.detail.importRbxm":"Studio에 삽입","assets.detail.importRbxm.tooltip":"이 로컬 RBXM 에셋을 연결된 Studio Place의 {target}에 삽입합니다.","assets.detail.generateThumbnail":"썸네일 생성","assets.detail.generateThumbnail.tooltip":"Studio에서 Asset Library 썸네일을 생성하거나 교체합니다.","assets.detail.rbxmOnly":"Studio 가져오기는 .rbxm 에셋에서 사용할 수 있습니다.","assets.detail.rbxmCategoryOnly":"Studio .rbxm 작업은 모델과 애니메이션을 지원합니다.","assets.detail.thumbnailRbxmOnly":"썸네일 생성은 .rbxm 모델 에셋에서 사용할 수 있습니다.","assets.detail.thumbnailModelOnly":"썸네일 생성은 모델 .rbxm 에셋에서 사용할 수 있습니다.","assets.detail.rbxm":"RBXM 내용","assets.detail.rbxmExportedCount":"내보낸 root","assets.detail.rbxmClasses":"클래스","assets.detail.rbxmThumbnail":"썸네일","assets.detail.studioInsertTarget":"Studio 삽입 위치","assets.detail.rbxmRoots":"Root 트리","assets.detail.rbxmReferences":"에셋 참조","assets.detail.rbxmThumbnailAttempts":"썸네일 시도","dashboardHelp.button":"도움말","dashboardHelp.pageButton.ariaLabel":"페이지 도움말 열기","dashboardHelp.fieldButton.ariaLabel":"필드 도움말 열기","dashboardHelp.section.canDo":"여기서 할 수 있는 일","dashboardHelp.section.needs":"사용하려면 필요한 것","dashboardHelp.section.links":"관련 링크","dashboardHelp.overview.title":"개요 도움말","dashboardHelp.overview.canDo.1":"MCP 서버, WEPPY Plugin, AI Agent, Sync, 최근 게임 변경 상태를 한 화면에서 확인할 수 있습니다.","dashboardHelp.overview.needs.1":"상태 확인에는 MCP 서버가 필요합니다. Studio 실시간 상태는 활성 Place에 WEPPY Plugin이 연결되어 있어야 합니다.","dashboardHelp.connection.title":"연결 도움말","dashboardHelp.connection.canDo.1":"서버 프로세스 정보, 연결된 AI Agent, Studio 플러그인 클라이언트, 연결 로그 이벤트를 확인할 수 있습니다.","dashboardHelp.connection.needs.1":"MCP 서버가 응답해야 합니다. Plugin 행은 Studio가 하트비트를 보낸 뒤 표시됩니다.","dashboardHelp.sync.title":"동기화 도움말","dashboardHelp.sync.canDo.1":"Studio와 로컬 파일의 동기화 상태, 방향, 적용 모드, 동기화 로그를 확인할 수 있습니다.","dashboardHelp.sync.needs.1":"Sync에는 활성 Place와 연결된 WEPPY Plugin이 필요합니다. 양방향 및 역방향 워크플로는 Pro에 따라 달라집니다.","dashboardHelp.assets.title":"에셋 도움말","dashboardHelp.assets.canDo.1":"로컬 Asset Library 파일을 탐색하고, 현재 Place/공용 범위를 전환하고, 카테고리로 필터링하고, 사용 위치를 스캔하고, RBXM을 Studio에 삽입하고, 로컬 에셋을 Roblox에 업로드할 수 있습니다.","dashboardHelp.assets.needs.1":"업로드에는 Pro, Open Cloud 업로드 토글, 유효한 API Key, Creator 설정이 필요합니다. 탐색과 미리보기는 Basic에서도 사용할 수 있습니다.","dashboardHelp.changelog.title":"변경 이력 도움말","dashboardHelp.changelog.canDo.1":"AI 작업과 동기화 이벤트에서 추출된 실제 게임 변경 세션을 확인할 수 있습니다.","dashboardHelp.changelog.needs.1":"변경 이력은 현재 Place 기준으로 묶입니다. Basic에서는 최신 미리보기 항목만 표시됩니다.","dashboardHelp.playtest.title":"플레이테스트 도움말","dashboardHelp.playtest.canDo.1":"AI Agent가 실행한 Playtest 결과와 리포트를 확인할 수 있습니다.","dashboardHelp.playtest.needs.1":"Pro에서는 실제 저장 리포트를 표시합니다. Basic에서는 샘플 미리보기 데이터를 표시합니다. 현재 Place와의 정확한 연결 판단에는 WEPPY Plugin 연결이 필요합니다.","dashboardHelp.uiStudio.title":"UI Studio 도움말","dashboardHelp.uiStudio.canDo.1":"AI가 만든 UI 분석, 개선 제안, 캡처, 전후 비교 이력을 확인할 수 있습니다.","dashboardHelp.uiStudio.needs.1":"Pro에서는 실제 UI Studio 데이터를 표시합니다. Basic에서는 포함된 샘플을 표시합니다. 새 캡처/검사 작업에는 WEPPY Plugin 연결이 필요합니다.","dashboardHelp.tools.title":"도구 도움말","dashboardHelp.tools.canDo.1":"도구 실행 기록, 상태 분류, fallback/unsupported/warn/error 상세, 사용 통계를 확인할 수 있습니다.","dashboardHelp.tools.needs.1":"기록과 통계는 로컬 기록 설정과 활성 Place 버킷에 따라 표시됩니다.","dashboardHelp.settings.title":"설정 도움말","dashboardHelp.settings.canDo.1":"License, 빠른 설정, 저장 데이터 정리, 서버 환경 표시, 언어 설정을 관리할 수 있습니다.","dashboardHelp.settings.needs.1":"License 작업에는 MCP 서버 연결이 필요합니다. 서버 환경 값은 여기서 읽기 전용입니다. 에셋 업로드 설정은 Assets 설정에 있습니다.","dashboardHelp.openCloudApiKey.title":"Open Cloud API Key 도움말","dashboardHelp.openCloudApiKey.canDo.1":"WEPPY는 이 키를 Roblox Open Cloud 요청에만 사용합니다.","dashboardHelp.openCloudApiKey.needs.1":"Creator Hub에서 Roblox API Key를 만들 때 Access Permissions에 Assets를 추가하고 Read와 Write operation을 모두 켜세요.","dashboardHelp.openCloudApiKey.needs.2":"Key target은 업로드 Creator로 사용할 User 또는 Group과 같아야 합니다.","dashboardHelp.openCloudApiKey.needs.3":"원본 키는 이 기기에 암호화 저장됩니다. WEPPY 서버나 다른 외부 저장소로 보내거나 저장하지 않습니다. 브라우저 저장소, 텔레메트리, 로그, 도구 기록, Asset Library 메타데이터에도 저장하지 않습니다.","dashboardHelp.openCloudApiKey.link.apiKeys":"Roblox API Keys","dashboardHelp.openCloudApiKey.link.assetsGuide":"Assets API 사용 가이드","dashboardHelp.openCloudApiKey.link.assetsReference":"Assets API 레퍼런스","dashboardHelp.openCloudCreatorId.title":"Creator ID 도움말","dashboardHelp.openCloudCreatorId.canDo.1":"기본 Creator는 새로 업로드되는 Roblox 에셋을 어느 User 또는 Group 소유로 만들지 정합니다.","dashboardHelp.openCloudCreatorId.needs.1":"User를 선택했다면 roblox.com에 로그인한 뒤 아바타나 사용자 이름에서 내 프로필을 열고, 브라우저 URL의 /users/와 /profile 사이 숫자만 복사하세요.","dashboardHelp.openCloudCreatorId.needs.2":"Group을 선택했다면 Roblox 그룹 또는 커뮤니티 페이지를 열고, 브라우저 URL의 /groups/ 또는 /communities/ 뒤 숫자만 복사하세요.","dashboardHelp.openCloudCreatorId.needs.3":"Creator ID에는 숫자 ID만 붙여넣으세요. 전체 URL, rbxassetid://, User, Group 같은 텍스트는 넣지 않습니다.","dashboardHelp.openCloudCreatorId.link.creatorId":"Creator ID 레퍼런스","dashboardHelp.openCloudCreatorId.link.userId":"User ID 레퍼런스","dashboardHelp.openCloudCreatorId.link.groups":"Roblox 그룹","dashboardHelp.openCloudCreatorId.link.groupsApi":"Groups Cloud API","assets.settings.apiKey.inlineHelp":"WEPPY는 이 키를 Roblox Open Cloud 요청에만 사용합니다. 키는 이 기기에만 암호화 저장되며 WEPPY 서버나 다른 외부 저장소로 보내거나 저장하지 않습니다.","assets.settings.creatorId.inlineHelp":"새 Roblox asset의 기본 소유자입니다: 사용자 ID 또는 그룹 ID를 입력하세요.","common.close":"닫기","dashboardHelp.section.currentState":"현재 상태에서 확인할 것","dashboardHelp.overview.currentState.serverOnly":"실시간 Place 데이터가 표시되도록 Roblox Studio를 열고 WEPPY Plugin을 시작하세요.","dashboardHelp.overview.currentState.default":"서버 연결이 끊기면 MCP를 다시 시작하거나 자동 재연결을 기다리세요.","dashboardHelp.connection.currentState.1":"Plugin이 보이지 않으면 Roblox Studio를 열고 WEPPY Plugin을 실행하세요. AI Agent가 보이지 않으면 AI 도구에서 MCP 서버를 다시 연결하세요.","dashboardHelp.sync.currentState.pluginMissing":"실시간 Sync 정보를 보려면 Studio에서 WEPPY Plugin을 연결하세요.","dashboardHelp.sync.currentState.basic":"양방향 또는 역방향 Sync를 사용하려면 Pro를 활성화하세요.","dashboardHelp.sync.currentState.default":"동기화가 멈추거나 실패하면 Sync 로그에서 원인을 확인하세요.","dashboardHelp.assets.currentState.basic":"Roblox 업로드를 사용하려면 먼저 Pro를 활성화하세요.","dashboardHelp.assets.currentState.uploadDisabled":"Assets 설정에서 Open Cloud 업로드를 켜세요.","dashboardHelp.assets.currentState.noCredential":"Open Cloud API Key를 저장하고 연결 테스트를 실행하세요.","dashboardHelp.assets.currentState.noCreator":"기본 Creator ID를 저장하거나 업로드할 때 Creator 정보를 입력하세요.","dashboardHelp.assets.currentState.default":"업로드나 사용 위치 스캔을 시작하려면 에셋 상세 창을 여세요.","dashboardHelp.changelog.currentState.1":"목록이 비어 있으면 AI Agent에게 게임 변경 작업을 요청하세요. 지우기는 저장된 이력 기록만 삭제하며 Studio 오브젝트는 삭제하지 않습니다.","dashboardHelp.playtest.currentState.basic":"실제 Playtest 이력을 사용하려면 Pro를 활성화하세요.","dashboardHelp.playtest.currentState.default":"리포트가 없으면 AI Agent에게 Playtest 실행을 요청하세요.","dashboardHelp.uiStudio.currentState.basic":"실시간 UI Studio 미리보기를 사용하려면 Pro를 활성화하세요.","dashboardHelp.uiStudio.currentState.default":"AI Agent에게 UI 캡처나 개선 제안 확인을 요청한 뒤, 필요한 수정 요청을 AI 채팅으로 복사하세요.","dashboardHelp.tools.currentState.1":"기록이 보이지 않으면 설정 > 일반에서 기록/통계가 켜져 있는지 확인하세요. 실패 행을 펼치면 입력, 권한, 연결 문제를 확인할 수 있습니다.","dashboardHelp.settings.currentState.1":"Pro 기능을 사용하려면 License를 활성화하세요. 환경 값은 WEPPY Dashboard 밖에서 바꾼 뒤 MCP를 다시 시작하세요. 저장 데이터를 삭제하기 전 확인 문구를 꼭 검토하세요.","dashboardHelp.openCloudApiKey.currentState.saved":"저장된 키가 계속 동작하는지 연결 테스트로 확인하세요.","dashboardHelp.openCloudApiKey.currentState.empty":"Roblox Creator Hub에서 API Key를 만든 뒤 여기에 붙여넣고 저장한 다음 연결 테스트를 실행하세요.","dashboardHelp.openCloudCreatorId.currentState.saved":"새 에셋을 같은 소유자로 계속 만들려면 이 값을 유지하세요.","dashboardHelp.openCloudCreatorId.currentState.empty":"User 또는 Group을 선택하고 숫자 ID를 붙여넣은 뒤 기본 Creator를 저장하세요.","page.overview.title":"개요","page.overview.description":"서버, 플러그인, 에이전트, 동기화, 최근 게임 변경 상태를 한곳에서 확인합니다.","page.connection.title":"연결","page.connection.description":"MCP 서버, AI 에이전트, Studio 플러그인, 연결 로그 상태를 확인합니다.","page.sync.title":"동기화","page.sync.description":"Studio와 로컬 파일 동기화 상태, 방향, 적용 모드, 최근 로그를 확인합니다.","page.changelog.title":"변경 이력","page.changelog.description":"AI 작업과 동기화 이벤트에서 기록된 게임 변경 세션을 검토합니다.","page.playtest.title":"플레이테스트","page.playtest.description":"자동 플레이테스트 실행 기록, 저장된 리포트, 결과 이력을 확인합니다.","page.uiStudio.title":"UI 스튜디오","page.uiStudio.description":"UI 캡처, 개선 제안, 변경 전후 이력을 검토합니다.","page.tools.title":"도구","page.tools.description":"도구 실행 이력, 결과 상태, fallback 상세, 사용 통계를 확인합니다.","page.settings.title":"설정","page.settings.description":"라이선스, 실시간 설정, 저장 데이터, 서버 환경, 언어를 관리합니다.","dashboardHelp.whatsNew.title":"새소식 도움말","dashboardHelp.whatsNew.canDo.1":"WEPPY Dashboard, MCP, Plugin 관련 공지, 릴리즈, 변경 안내를 확인합니다.","dashboardHelp.whatsNew.needs.1":"공지 데이터는 로컬에 포함되어 있으며, 미읽음 상태는 이 브라우저에 저장됩니다.","dashboardHelp.whatsNew.currentState.1":"이 페이지를 방문하면 현재 방문 중 미읽음 공지가 페이지를 떠날 때 읽음 처리됩니다. 이 페이지에서는 상단 헤더의 새소식 버튼을 중복 표시하지 않습니다."},Ff={"sidebar.overview":"Resumen","sidebar.changelog":"Historial","sidebar.connection":"Conexión","sidebar.sync":"Sincronización","sidebar.playtest":"Prueba","sidebar.tools":"Herramientas","sidebar.settings":"Configuración","sidebar.ui_studio":"UI Studio","sidebar.gate.l1":"Se requiere conexión con el servidor MCP.","sidebar.gate.l2":"Se requiere conexión con el plugin de Roblox Studio.","header.currentProject":"Proyecto actual","header.unknownProject":"Proyecto desconocido","header.projectRoot.label":"Project Root","header.currentProject.loading":"Cargando raíz del proyecto...","header.currentProject.unavailable":"Raíz del proyecto no disponible","header.placeNotConnected":"Place no conectado","header.currentProject.tooltip":"Carpeta de proyecto seleccionada actualmente.","header.currentProject.loading.tooltip":"La información de la raíz del proyecto todavía se está cargando.","header.currentProject.unavailable.tooltip":"La información actual de la raíz del proyecto no está disponible.","header.currentProjectSyncRoot.label":"Sync Root","header.currentProjectSyncRoot.loading":"Cargando sync root...","header.currentProjectSyncRoot.unavailable":"Sync root no disponible","header.currentProjectSyncRoot.tooltip":"Carpeta sync root actual del proyecto seleccionado.","header.currentProjectSyncRoot.loading.tooltip":"La información de sync root todavía se está cargando.","header.currentProjectSyncRoot.unavailable.tooltip":"La información actual de sync root no está disponible.","header.testFiles.label":"Test Files","header.testFiles.unavailable":"La ruta de archivos de prueba no está disponible.","header.testFiles.tooltip":"Directorio actual de archivos de playtest para el place seleccionado.","header.places.title":"Places","header.places.active":"Active","header.places.inactive":"Inactive","header.places.pluginRequired":"Se requiere conexión del plugin","header.places.liveRequired":"Se requiere conexión del plugin para ver el place activo en tiempo real.","header.place.tooltip":"Place de Roblox conectado.","header.placeNotConnected.tooltip":"Place no conectado","header.changeProjectRoot":"Cambiar raíz del proyecto","header.changeProjectRoot.ariaLabel":"Cambiar raíz del proyecto","header.changeProjectRoot.tooltip":"Cambiar la raíz actual del proyecto.","header.changeProjectRoot.disabledTooltip.l0":"Primero se requiere conexión con el servidor MCP para cambiar la raíz del proyecto.","header.changeProjectRoot.disabledTooltip.loading":"La información de la raíz del proyecto todavía se está cargando.","header.changeProjectRoot.disabledTooltip.unavailable":"La información actual de la raíz del proyecto no está disponible.","header.projectRootModal.initial.title":"Cambiar raíz del proyecto","header.projectRootModal.initial.body.connected":"Después de elegir una carpeta de proyecto, MCP cambiará a la nueva raíz del proyecto y el contenido actual de Studio se resincronizará por completo en el nuevo destino <selected project folder>/weppy-project-sync.","header.projectRootModal.initial.body.disconnected":"Después de elegir una carpeta de proyecto, MCP cambiará a la nueva raíz del proyecto y usará <selected project folder>/weppy-project-sync como el próximo destino de sync.","header.projectRootModal.initial.nextSyncRoot":"Nuevo destino de sync después de la selección","header.projectRootModal.initial.nextSyncRoot.placeholder":"<selected project folder>/weppy-project-sync","header.projectRootModal.initial.warningStop":"El sync actual se detiene de inmediato.","header.projectRootModal.initial.warningFreshSync":"El contenido actual de Studio se usará para crear un fresh full sync en el nuevo destino.","header.projectRootModal.initial.warningNoMove":"Las carpetas de sync anteriores no se mueven automáticamente.","header.projectRootModal.initial.warningDeferredSync":"Si Studio no está conectado, el full resync comenzará la próxima vez que se conecte el plugin.","header.projectRootModal.confirm.title":"Confirmar nueva raíz del proyecto","header.projectRootModal.confirm.body":"Revisa la carpeta seleccionada antes de aplicar el cambio.","header.projectRootModal.confirm.projectRoot":"Carpeta de proyecto seleccionada","header.projectRootModal.confirm.syncRoot":"Nuevo destino de sync","header.projectRootModal.confirm.warningNoMove":"Las carpetas de sync existentes no se mueven automáticamente.","header.projectRootModal.pick":"Elegir carpeta","header.projectRootModal.apply":"Aplicar cambio","header.projectRootModal.cancel":"Cancelar","header.projectRootModal.error":"No se pudo cambiar la raíz del proyecto.","status.online":"En línea","status.offline":"Desconectado","status.idle":"Inactivo","status.syncing":"Sincronizando","status.error":"Error","status.initializing":"Inicializando","level.l0.title":"Servidor desconectado","level.l0.message":"WEPPY Dashboard está abierto pero el servidor MCP se detuvo o no responde.","level.l1.title":"Servidor conectado","level.l1.hint":"Verifica: ¿Roblox Studio está abierto? ¿El plugin está instalado?","level.l2.ok":"Studio conectado","tier.basic":"Basic","tier.basic.tooltip":"Nivel Basic con el conjunto estándar de funciones del WEPPY Dashboard.","tier.pro":"Pro","tier.pro.tooltip":"Nivel Pro con el conjunto completo de funciones del WEPPY Dashboard.","tier.mixed":"Mixto","tier.upgrade":"Ver Pro","tier.banner.save":"¡Ahorra tokens de IA con Pro!","tier.tool.query_instances.desc":"Consulta de instancias, exploración de hijos/descendientes, info de clase, búsqueda por nombre y clase. Pro: árbol de archivos, estructura del proyecto, búsqueda por propiedad y etiqueta.","tier.tool.mutate_instances.desc":"Crear, eliminar, clonar, mover, renombrar y pivotar instancias. Pro: creación de árboles, creación/eliminación/duplicación masiva.","tier.tool.manage_properties.desc":"Consultar y establecer propiedades, atributos y etiquetas. Pro: valores calculados y relativos, consulta/establecimiento masivo, modificación masiva de hijos.","tier.tool.manage_scripts.desc":"Leer, escribir, crear, eliminar, editar líneas y buscar en scripts. Pro: reemplazo masivo entre scripts.","tier.tool.manage_ui.desc":"Solo Pro. Crea o mejora menús, HUDs, botones, etiquetas y paneles de imagen con estilo de juego; luego captura pantallas y revisa sugerencias.","tier.tool.manage_ui.action.design_brief":"Planificar la dirección de UI","tier.tool.manage_ui.action.create_tree":"Crear nueva UI","tier.tool.manage_ui.action.update":"Actualizar UI existente","tier.tool.manage_ui.action.delete":"Eliminar UI","tier.tool.manage_ui.action.preview":"Capturar pantalla de UI","tier.tool.manage_ui.action.check":"Revisar sugerencias de mejora","tier.tool.manage_lighting.desc":"Solo Pro. Configuración de iluminación, atmósfera, cielo, propiedades del terreno y hora del día.","tier.tool.manage_selection.desc":"Consultar, establecer y borrar selección. Pro: contexto, detalles, agregar/quitar elementos, monitorear cambios.","tier.tool.manage_camera.desc":"Info de cámara, enfocar por ruta o coordenadas, vista sugerida.","tier.tool.manage_tween.desc":"Solo Pro. Crear, reproducir, pausar y cancelar tweens para animaciones suaves.","tier.tool.manage_audio.desc":"Solo Pro. Reproducir, detener, pausar y reanudar sonidos. Configurar listener de audio.","tier.tool.manage_animation.desc":"Solo Pro. Cargar, reproducir y detener animaciones. Consultar tracks de humanoide/controlador.","tier.tool.manage_physics.desc":"Solo Pro. Registrar grupos de colisión, configurar colisión entre grupos, listar grupos.","tier.tool.manage_effects.desc":"Solo Pro. Emitir partículas, borrar todas, alternar activación de efectos.","tier.tool.manage_terrain.desc":"Solo Pro. Rellenar formas, borrar regiones, reemplazar materiales, gestionar colores, leer/escribir voxels, generación procedural, suavizado.","tier.tool.spatial_query.desc":"Solo Pro. Raycast, buscar suelo, verificar colocación, escaneo de área, buscar zonas planas y puntos de aparición, análisis de caminabilidad, mapa espacial, detección de colisión.","tier.tool.manage_assets.desc":"Solo Pro. Insertar modelos, consultar info de assets, buscar en tienda de creadores, insertar modelos/paquetes gratuitos, exportar.","tier.tool.manage_sync.desc":"Solo Pro. Estado de sincronización, configuración, historial, dirección, lectura/escritura de archivos sincronizados.","tier.tool.workspace_state.desc":"Solo Pro. Sincronización completa, instantánea, cambios recientes, info de viewport, metadatos, gestión de caché.","tier.tool.manage_logs.desc":"Consulta filtrada de registros, sondeo incremental, borrar buffer, consulta de errores recientes.","tier.tool.system_info.desc":"Estado de conexión, verificación de tier. Pro: info de lugar, lista de servicios, configuración de Studio, control de playtest, pruebas automáticas.","tier.tool.manage_studio.desc":"Solo Pro. Alterna ajustes de vista del editor de Studio, como la vista previa de UI, para capturas y QA; cambia ajustes de la sesión, no objetos de UI del juego.","tier.tool.batch_execute.desc":"Solo Pro. Ejecutar múltiples comandos en lote. Procesamiento secuencial con opción de continuar en caso de error.","tier.tool.execute_luau.desc":"Solo Pro. Ejecutar código Luau arbitrario en el sandbox de Roblox Studio.","connection.server.title":"Estado del servidor","connection.server.version":"Versión","connection.server.version.tooltip":"Versión instalada del servidor MCP.","connection.server.pid":"PID","connection.server.pid.tooltip":"Identificador de proceso del sistema operativo.","connection.server.uptime":"Tiempo activo","connection.server.uptime.tooltip":"Tiempo transcurrido desde que se inició el servidor MCP.","connection.server.session":"Sesión","connection.server.session.tooltip":"Identificador de la sesión MCP actual.","connection.server.exec":"Ejecutable","connection.server.exec.tooltip":"Ruta del ejecutable usado para iniciar el servidor MCP.","connection.reconnect":"Reconectar","connection.checkSettings":"Verificar configuración","connection.agents.title":"Agentes IA","connection.agents.name":"Agente","connection.agents.cwd":"Directorio","connection.agents.cwd.tooltip":"Directorio de trabajo actual del agente de IA conectado.","connection.agents.projectRoot":"Raíz del proyecto","connection.agents.projectRoot.tooltip":"Ruta del proyecto autoritativa para la propiedad de sincronización","connection.agents.projectRoot.unresolved":"Sin resolver","connection.agents.connected":"Conectado","connection.agents.unknown":"Desconocido","connection.agents.none":"Sin agentes conectados","connection.plugins.title":"Plugins","connection.plugins.place":"Place","connection.plugins.clientId":"ID de cliente","connection.plugins.clientId.tooltip":"Identificador único del cliente del plugin para esta conexión de Studio.","connection.plugins.lastSeen":"Última vez","connection.plugins.lastSeen.tooltip":"Heartbeat más reciente recibido desde el plugin.","connection.plugins.version":"Ver","connection.plugins.version.tooltip":"Versión instalada del plugin informada por Studio.","connection.plugins.none":"Sin plugins conectados","connection.log.title":"Registro de conexión","connection.log.empty":"Sin eventos","connection.time.secondsAgo":"s atrás","connection.time.minutesAgo":"min atrás","connection.time.hoursAgo":"h atrás","common.loading":"Cargando...","common.retry":"Reintentar","common.reconnecting":"Reconectando...","common.expand":"Expandir","common.collapse":"Contraer","tools.tab.history":"Historial","tools.tab.statistics":"Estadísticas","tools.tab.failures":"Fallos","tools.col.time":"Hora","tools.col.time.tooltip":"Momento en que se registró la ejecución de la herramienta.","tools.col.toolAction":"Herramienta.Acción","tools.col.toolAction.tooltip":"Nombre de la herramienta y acción que se ejecutó.","tools.col.duration":"Duración","tools.col.duration.tooltip":"Cuánto tardó la herramienta en finalizar.","tools.col.status":"Estado","tools.col.status.tooltip":"Resultado de la ejecución registrada.","tools.col.tier":"Nivel","tools.col.tier.tooltip":"Nivel de licencia requerido para la herramienta o acción.","tools.col.tierStats.tooltip":"Resumen Basic, Pro o Mixed para esta fila de estadísticas de herramientas.","tools.col.tool":"Herramienta","tools.col.tool.tooltip":"Nombre de la herramienta consolidada en la tabla de estadísticas.","tools.col.calls":"Llamadas","tools.col.calls.tooltip":"Número total de llamadas registradas para esta herramienta.","tools.col.ok":"OK","tools.col.ok.tooltip":"Número de ejecuciones exitosas directas.","tools.col.fallback":"FALLBACK","tools.col.fallback.tooltip":"Número de ejecuciones que tuvieron éxito mediante fallback.","tools.col.unsupported":"UNSUPPORTED","tools.col.unsupported.tooltip":"Número de ejecuciones bloqueadas sin fallback.","tools.col.warn":"WARN","tools.col.warn.tooltip":"Número de fallos esperados causados por la entrada, el estado del proyecto, la política de Roblox o el código del usuario.","tools.col.err":"FALLIDO","tools.col.err.tooltip":"Número de ejecuciones que terminaron en fallo.","tools.col.okRate":"% Éxito","tools.col.okRate.tooltip":"Porcentaje de llamadas que terminaron correctamente.","tools.col.avgTime":"Tiempo promedio","tools.col.avgTime.tooltip":"Tiempo promedio de ejecución entre las llamadas registradas.","tools.col.error":"Error","tools.filter.tool":"Herramienta","tools.filter.all":"Todos","tools.badge.pro":"PRO","tools.badge.pro.tooltip":"Esta entrada usó una herramienta o acción exclusiva de Pro.","tools.badge.fallback":"FALLBACK","tools.badge.fallback.tooltip":"La acción Pro solicitada tuvo éxito mediante un fallback Basic.","tools.badge.unsupported":"UNSUPPORTED","tools.badge.unsupported.tooltip":"La acción Pro solicitada fue bloqueada y no se ejecutó ningún fallback.","tools.badge.warn":"WARN","tools.badge.warn.tooltip":"La llamada falló por un problema esperado de entrada, proyecto, política o código de usuario.","tools.badge.err":"FALLIDO","tools.badge.err.tooltip":"La ejecución de la herramienta terminó en fallo.","tools.status.ok":"OK","tools.status.ok.tooltip":"La ejecución de la herramienta finalizó correctamente.","tools.tier.mixed.tooltip":"Esta herramienta incluye acciones Basic y Pro.","tools.detail.params":"Parámetros","tools.detail.params.tooltip":"Parámetros de entrada enviados en esta ejecución.","tools.detail.result":"Resultado","tools.detail.result.tooltip":"Carga útil devuelta por esta ejecución.","tools.detail.requestedCommand":"Comando enviado","tools.detail.executedCommand":"Comando ejecutado","tools.detail.alternatives":"Alternativas","tools.detail.blockedMessage":"Motivo del bloqueo","tools.detail.noFallback":"Sin fallback","tools.detail.noFallback.value":"No se ejecutó ningún fallback.","tools.detail.warningMessage":"Mensaje de advertencia","tools.detail.errorMessage":"Mensaje de error","tools.clear.history.title":"¿Borrar historial?","tools.clear.history.message":"Esto elimina permanentemente el historial de herramientas del place actual.","tools.clear.statistics.title":"¿Borrar estadísticas?","tools.clear.statistics.message":"Esto restablece permanentemente las estadísticas de herramientas del place actual.","tools.detail.error":"Error","tools.page.prev":"Anterior","tools.page.prev.tooltip":"Ir a la página anterior del historial de herramientas.","tools.page.next":"Siguiente","tools.page.next.tooltip":"Ir a la página siguiente del historial de herramientas.","tools.empty.history":"Sin entradas de historial","tools.empty.stats":"Sin estadísticas","tools.empty.failures":"Sin fallos","tools.summary.total":"Total","tools.summary.calls":"llamadas","tools.summary.sessions":"Sesiones","settings.license.title":"Licencia","settings.license.title.tooltip":"Estado actual de la licencia y nivel de suscripción.","settings.license.status":"Estado","settings.license.status.tooltip":"Estado actual de activación de la licencia.","settings.license.tier":"Nivel","settings.license.tier.tooltip":"Nivel de suscripción actual para las funciones disponibles del WEPPY Dashboard.","settings.license.key":"Clave","settings.license.key.tooltip":"Clave de licencia enmascarada cargada actualmente por el servidor.","settings.license.keyValue.tooltip":"Clave de licencia enmascarada cargada actualmente por el servidor.","settings.license.provider":"Proveedor","settings.license.provider.auto":"auto","settings.license.provider.polar":"polar","settings.license.provider.gumroad":"gumroad","settings.license.provider.tooltip":"Proveedor de licencia usado para validar esta clave.","settings.license.providerValue.tooltip":"Proveedor de licencia usado para validar esta clave.","settings.license.active":"Activa","settings.license.active.tooltip":"Estado actual de activación de la licencia.","settings.license.status.activeCancelPending.tooltip":"La cancelación está pendiente, pero el acceso Pro seguirá activo hasta que termine el período de facturación actual.","settings.license.inactive":"Inactiva","settings.license.inactive.tooltip":"Estado actual de activación de la licencia.","settings.license.expired":"Expirada","settings.license.expired.tooltip":"Estado actual de activación de la licencia.","settings.license.unavailable":"Información de licencia no disponible","settings.license.detail.cancelPending":"La cancelación está programada. El acceso Pro seguirá activo hasta que termine el período de facturación actual.","settings.license.reset":"Restablecer licencia","settings.readOnly":"Solo lectura","settings.readOnly.tooltip":"Esta sección muestra valores que no se pueden editar desde el WEPPY Dashboard.","settings.unavailable":"Configuración no disponible","settings.general.title":"Configuración general","settings.general.title.tooltip":"Ajustes calientes que se aplican inmediatamente al cambiarse.","settings.general.liveApply":"Aplicar en vivo","settings.general.liveApply.tooltip":"Los cambios en esta sección se aplican al instante sin un botón de guardar aparte.","settings.general.applied":"Aplicado","settings.general.logLevel":"Nivel de log","settings.general.logLevel.tooltip":"Define cuánto detalle escribe el WEPPY Dashboard en sus registros.","settings.general.localHistory":"Registro de historial","settings.general.localHistory.tooltip":"Guarda el historial local de ejecución de herramientas para las vistas de historial del WEPPY Dashboard.","settings.general.localStatistics":"Recopilación de estadísticas","settings.general.localStatistics.tooltip":"Agrega estadísticas locales de uso para los informes del WEPPY Dashboard.","settings.general.contextCapture":"Context Capture","settings.general.contextCapture.tooltip":"When enabled, the WEPPY Dashboard records structured execution context for changelog and playtest views.","settings.general.requestTimeout":"Tiempo de espera","settings.general.requestTimeout.tooltip":"Tiempo máximo que el WEPPY Dashboard espera una acción antes de marcarla como fallida.","settings.general.requestTimeout.unit":"ms","settings.general.requestTimeout.unit.tooltip":"El tiempo de espera de la acción se mide en milisegundos.","settings.cold.title":"Entorno del servidor","settings.cold.title.tooltip":"Valores de entorno del servidor de solo lectura cargados al iniciar.","settings.cold.httpPort.tooltip":"Número de puerto usado por el servidor HTTP del WEPPY Dashboard MCP.","settings.cold.httpHost.tooltip":"Interfaz de host a la que se enlaza el servidor HTTP del WEPPY Dashboard MCP.","settings.cold.dashboardAutoOpen.tooltip":"Controla si el WEPPY Dashboard se abre automáticamente en el navegador al iniciar el servidor.","settings.cold.dashboardAutoOpen.value.tooltip":"Comportamiento actual de inicio para abrir el WEPPY Dashboard en un navegador.","settings.cold.hint":"Configure mediante variables de entorno.","settings.language.title":"Idioma","settings.language.title.tooltip":"Elige cómo se localiza el texto de la interfaz del WEPPY Dashboard.","settings.language.dashboard":"Idioma del WEPPY Dashboard","settings.language.dashboard.tooltip":"Sobrescribe el idioma del WEPPY Dashboard o usa el idioma del sistema cuando está en Automático.","settings.language.auto":"Automático","overview.l0.title":"Servidor MCP desconectado","overview.l0.message":"El servidor MCP no responde. El WEPPY Dashboard intentará reconectarse automáticamente.","overview.l0.step1":"Verifique que el proceso del servidor MCP esté ejecutándose","overview.l0.step2":"Reinicie el comando del servidor MCP si es necesario","overview.l0.reconnecting":"Reconectando automáticamente cada 3s...","overview.l0.reconnectBtn":"Reconectar","overview.l0.settingsBtn":"Verificar configuración","overview.l1.pluginGuide":"El plugin de Roblox Studio no está conectado","overview.l1.check1":"¿Roblox Studio está abierto?","overview.l1.check2":"¿El WEPPY Plugin está instalado?","overview.l1.feedHint":"Los cambios aparecerán aquí cuando el plugin se conecte","overview.metric.server":"Servidor","overview.metric.server.tooltip":"Estado de ejecución y proceso del servidor MCP.","overview.metric.plugin":"Plugin","overview.metric.plugin.tooltip":"Estado de conexión y versión del plugin de Roblox Studio.","overview.metric.agent":"Agente","overview.metric.agent.tooltip":"Agentes de IA conectados y su estado actual.","overview.metric.agent.instancesUnit":"instancias","overview.metric.sync":"Sincronización","overview.metric.sync.tooltip":"Actividad actual de sincronización entre Studio y archivos locales.","overview.metric.noAgent":"Sin agente","overview.meta.version":"Versión","overview.meta.version.tooltip":"Versión instalada del servidor MCP.","overview.meta.session":"Sesión","overview.meta.session.tooltip":"Identificador de la sesión MCP actual.","overview.meta.pid":"PID","overview.meta.pid.tooltip":"Identificador de proceso del sistema operativo.","overview.meta.uptime":"Tiempo activo","overview.meta.uptime.tooltip":"Tiempo transcurrido desde que se inició el servidor MCP.","overview.feed.title":"Cambios recientes del juego","overview.feed.empty":"Sin cambios recientes","overview.changelog.title":"Resumen de cambios de sesión","overview.changelog.entries":"Total","overview.changelog.scripts":"scripts","overview.changelog.instances":"instancias","overview.changelog.properties":"propiedades","overview.changelog.assets":"assets","overview.tier.title":"Uso por nivel","changelog.subtitle":"Historial de cambios del juego","changelog.filter.all":"Todos","changelog.filter.active":"Activo","changelog.filter.completed":"Completado","changelog.empty":"Sin entradas de historial","changelog.basic.limit.title":"La vista previa Basic muestra solo las 3 sesiones más recientes","changelog.basic.limit.body":"Actualiza a Pro para explorar la línea completa del historial de cambios de este place.","changelog.basic.metricLabel":"Historial visible / Total","changelog.basic.visible":"visibles","changelog.basic.total":"total","changelog.card.active":"Activo","changelog.card.active.tooltip":"Esta sesión todavía sigue recibiendo nuevos cambios del juego.","changelog.card.completed":"Completado","changelog.card.completed.tooltip":"Esta sesión terminó y ya no se esperan más cambios.","changelog.card.bootstrapStatus":"Inicializado","changelog.card.bootstrapStatus.tooltip":"Esta sesión solo contiene la instantánea inicial de bootstrap de sincronización.","changelog.card.inProgress":"en progreso","changelog.card.noChanges":"Sin cambios aún","changelog.card.noChanges.tooltip":"Todavía no se han extraído cambios del juego para esta sesión.","changelog.card.bootstrapSummary":"Instantánea de sincronización inicial","changelog.card.bootstrapSummary.tooltip":"Las escrituras de la sincronización inicial de archivos se agrupan en una sola fila de bootstrap.","changelog.card.sessionIntent":"Session intent","changelog.card.scripts":"scripts","changelog.card.scripts.tooltip":"Cambios de scripts realizados en esta sesión.","changelog.card.instances":"instancias","changelog.card.instances.tooltip":"Cambios de creación, eliminación, movimiento o clonado de instancias en esta sesión.","changelog.card.modified":"modificado","changelog.card.created":"creado","changelog.card.deleted":"eliminado","changelog.card.moved":"movido","changelog.card.propertiesChanged":"propiedades cambiadas","changelog.card.propertiesChanged.tooltip":"Cambios de valores de propiedades registrados para esta sesión.","changelog.card.lightingConfigured":"Iluminación configurada","changelog.card.lightingConfigured.tooltip":"La iluminación o la atmósfera cambiaron en esta sesión.","changelog.card.terrainConfigured":"Terreno configurado","changelog.card.terrainConfigured.tooltip":"Los datos o la configuración del terreno cambiaron en esta sesión.","changelog.card.assetsInserted":"assets insertados","changelog.card.assetsInserted.tooltip":"Assets insertados en el place durante esta sesión.","changelog.category.script":"Scripts","changelog.category.instance":"Instancias","changelog.category.property":"Propiedades","changelog.category.lighting":"Iluminación","changelog.category.terrain":"Terreno","changelog.category.asset":"Assets","changelog.detail.changeSummary":"Resumen de cambios","changelog.detail.changeSummary.tooltip":"Cantidad de cambios del juego extraídos agrupados por categoría para esta sesión.","changelog.detail.changeTimeline":"Línea de tiempo","changelog.detail.changeTimeline.tooltip":"Lista cronológica de cambios del juego extraídos para esta sesión.","changelog.detail.context.title":"Context Summary","changelog.detail.context.tooltip":"Structured execution context captured for this changelog session.","changelog.detail.verification.title":"Verification","changelog.detail.verification.tooltip":"Verification signals linked to this changelog session.","changelog.detail.verification.label":"Result","changelog.detail.verification.status":"Status","changelog.detail.verification.timestamp":"Recorded at","changelog.detail.beforeAfter":"Antes y después","changelog.detail.filterCategory":"Categoría","changelog.detail.filterCategory.tooltip":"Filtra la línea de tiempo a una sola categoría de cambio.","changelog.detail.confidence.exact":"Exacto","changelog.detail.confidence.exact.tooltip":"Se confirmaron tanto el estado anterior como el posterior para este cambio.","changelog.detail.confidence.partial":"Parcial","changelog.detail.confidence.partial.tooltip":"Solo se pudo confirmar parte del estado anterior y posterior para este cambio.","changelog.detail.confidence.afterOnly":"Solo después","changelog.detail.confidence.afterOnly.tooltip":"Solo se pudo confirmar el estado resultante después del cambio.","changelog.detail.confidence.intentOnly":"Solo intención","changelog.detail.confidence.intentOnly.tooltip":"Solo se registró la acción solicitada, no el estado resultante.","changelog.detail.confidence.unknown":"Desconocido","changelog.detail.confidence.unknown.tooltip":"No fue posible clasificar este cambio con confianza usando los datos disponibles.","changelog.detail.noChanges":"Sin cambios en esta categoría","changelog.detail.backToList":"Volver a la lista","changelog.diff.empty":"Sin diferencias disponibles","changelog.diff.unified":"Unificado","changelog.diff.sideBySide":"Lado a lado","changelog.diff.before":"Antes","changelog.diff.after":"Después","sync.overlay.title":"Se requiere el plugin de Roblox Studio","sync.overlay.message":"El estado de sincronización estará disponible cuando el plugin de Roblox Studio se conecte.","sync.overlay.check1":"¿Roblox Studio está abierto?","sync.overlay.check2":"¿El WEPPY Plugin está instalado?","sync.status.title":"Estado de sincronización","sync.status.title.tooltip":"Estado actual de sincronización entre Studio y archivos locales para este place.","sync.status.forwardOnly":"Solo avance","sync.status.forwardOnly.tooltip":"La suscripción Basic solo permite sincronización directa de Studio a local.","sync.status.place":"Place","sync.status.place.tooltip":"Nombre e ID del place de Roblox conectado.","sync.status.path":"Ruta","sync.status.path.tooltip":"Raíz del sistema de archivos local usada actualmente para la sincronización.","sync.status.instances":"Instancias","sync.status.instances.tooltip":"Cantidad total de instancias de Roblox sincronizadas en el espejo local.","sync.status.scripts":"Scripts","sync.status.scripts.tooltip":"Cantidad total de scripts sincronizados e indexados para este place.","sync.status.state":"Estado","sync.status.state.tooltip":"Estado de ejecución de sincronización reportado por el servidor.","sync.directions.title":"Direcciones de sincronización","sync.directions.title.tooltip":"Dirección y modo de aplicación por categoría entre Local y Studio.","sync.directions.type":"Tipo","sync.directions.type.tooltip":"Categoría de sincronización afectada por esta regla.","sync.directions.direction":"Dirección","sync.directions.direction.tooltip":"Indica si cada categoría sincroniza desde Studio, hacia Studio o en ambos sentidos.","sync.directions.applyMode":"Modo de aplicación","sync.directions.applyMode.tooltip":"Cómo se aplican los cambios de sincronización entrantes para esta categoría.","sync.directions.cat.scripts":"Scripts","sync.directions.cat.values":"Valores","sync.directions.cat.containers":"Contenedores","sync.directions.cat.data":"Datos","sync.directions.cat.services":"Servicios","sync.directions.endpoint.local":"Local","sync.directions.endpoint.local.tooltip":"Los archivos locales en disco siempre se muestran a la izquierda del riel de dirección.","sync.directions.endpoint.studio":"Studio","sync.directions.endpoint.studio.tooltip":"Roblox Studio siempre se muestra a la derecha del riel de dirección.","sync.directions.mode.manual":"Manual","sync.directions.mode.manual.tooltip":"Aplica los cambios de sincronización solo cuando los activas manualmente.","sync.directions.mode.auto":"Auto","sync.directions.mode.auto.tooltip":"Aplica los cambios de sincronización automáticamente cuando llegan actualizaciones.","sync.directions.tooltip.forward.body":"Los cambios de Studio se sincronizan solo a los archivos locales","sync.directions.tooltip.bidirectional.body":"Sincronización en ambos sentidos entre Local y Studio","sync.directions.tooltip.reverse.body":"Envía cambios de archivos locales a Studio","sync.directions.tooltip.proRequired":"Se requiere Pro en el plan Basic","sync.directions.dir.forward":"adelante","sync.directions.dir.bidirectional":"bidireccional","sync.directions.dir.reverse":"inverso","sync.log.title":"Registro de sincronización","sync.log.empty":"Sin eventos de sincronización","sync.log.type.write":"ESCRIBIR","sync.log.type.write.tooltip":"Se escribió una nueva salida sincronizada en el disco.","sync.log.type.update":"ACTUALIZAR","sync.log.type.update.tooltip":"Se actualizó un archivo o una instancia ya sincronizada.","sync.log.type.delete":"ELIMINAR","sync.log.type.delete.tooltip":"Se eliminó un archivo o una instancia sincronizada.","sync.log.type.idle":"INACTIVO","sync.log.type.idle.tooltip":"Se registró un evento de sincronización sin modificar archivos.","sync.upgrade.title":"Explora la sincronización completa con Pro","sync.upgrade.benefit1":"Sincronización bidireccional — edita archivos, se aplica automáticamente a Studio","sync.upgrade.benefit2":"Sincronización inversa — envía cambios de archivos a Studio","sync.upgrade.benefit3":"Historial completo de sincronización y registro detallado de cambios","sync.upgrade.buy":"Ver Pro","playtest.status.title":"Estado de prueba","playtest.status.title.tooltip":"Estado actual de la sesión de playtest de Roblox informado por Studio.","playtest.status.mode":"Modo","playtest.status.mode.tooltip":"Modo de inicio de playtest de Studio usado por la sesión actual.","playtest.status.mode.value.tooltip":"Modo específico de playtest de Roblox Studio que se está usando ahora.","playtest.status.mode.play":"Jugar","playtest.status.mode.run":"Ejecutar","playtest.status.mode.server":"Servidor","playtest.status.mode.edit":"Editar","playtest.status.place.tooltip":"Place de Roblox asociado actualmente con esta sesión de playtest.","playtest.status.state.running":"En ejecución","playtest.status.state.running.tooltip":"Actualmente hay una sesión de playtest de Roblox en ejecución.","playtest.status.state.paused":"Pausado","playtest.status.state.paused.tooltip":"La sesión actual de playtest de Roblox está en pausa.","playtest.status.state.notRunning":"Sin ejecutar","playtest.status.state.notRunning.tooltip":"Actualmente no hay ninguna sesión de playtest de Roblox en ejecución.","playtest.control.play":"Jugar","playtest.control.pause":"Pausar","playtest.control.resume":"Reanudar","playtest.control.stop":"Detener","playtest.history.title":"Historial de pruebas","playtest.history.title.tooltip":"Ejecuciones automatizadas de playtest registradas para este proyecto.","playtest.history.empty":"Sin resultados de prueba","playtest.history.mode":"Modo","playtest.history.mode.tooltip":"Modo de playtest usado en esta ejecución de prueba registrada.","playtest.history.status.passed":"Aprobado","playtest.history.status.failed":"Fallido","playtest.history.status.running":"En ejecución","playtest.history.status.unknown":"Desconocido","playtest.history.status.tooltip":"Estado de resultado registrado para esta ejecución automatizada de playtest.","playtest.empty.title":"Sin resultados de prueba aún","playtest.empty.message":"Los resultados aparecerán aquí después de que el agente de IA ejecute un Playtest.","playtest.empty.message.before":"Los resultados aparecerán aquí después de que el agente de IA ejecute un Playtest.","playtest.empty.message.after":"","playtest.empty.runTest.tooltip":"Ask the AI Agent to run a Playtest when you need a fresh report.","playtest.report.title":"Reporte seleccionado","playtest.report.title.tooltip":"Salida detallada de la ejecución automatizada de playtest seleccionada actualmente.","playtest.report.content":"Reporte","playtest.report.content.tooltip":"Resumen en Markdown de la ejecución automatizada de playtest seleccionada.","playtest.report.logs":"Registros","playtest.report.logs.tooltip":"Registros de ejecución capturados para la ejecución automatizada de playtest seleccionada.","playtest.context.contextId":"Context ID","playtest.context.why":"Why this test ran","playtest.context.expected":"Expected","playtest.context.observed":"Observed","playtest.report.empty":"Sin contenido de reporte","playtest.basic.icon":"🎮","playtest.basic.title":"Playtest es una función exclusiva de Pro","playtest.basic.desc":"Controla las pruebas desde el WEPPY Dashboard, ejecuta pruebas automatizadas y visualiza reportes detallados.","playtest.basic.benefit1":"Controles de jugar/pausar/detener con un clic","playtest.basic.benefit2":"Ejecución de pruebas automatizadas vía agente IA","playtest.basic.benefit3":"Historial de pruebas con seguimiento de éxito/fallo","playtest.basic.benefit4":"Reportes de prueba detallados en markdown","playtest.sample.badge":"Vista previa de la pantalla Pro de playtest","playtest.sample.title":"Estás viendo una vista previa de la pantalla de playtest disponible después de actualizar a Pro.","playtest.sample.message":"Esta vista previa usa datos de ejemplo. El control de playtest en vivo, la gestión del historial y los reportes reales se desbloquean con Pro.","playtest.sample.clearDisabled":"Actualiza a Pro para borrar el historial real de playtest.","playtest.sample.place":"Vista previa de Arena","playtest.sample.history.name":"Prueba de humo de Arena de ejemplo","playtest.sample.context.why":"Entrar a la arena, sobrevivir a la apertura y verificar que el HUD responda de inmediato.","playtest.sample.context.expected":"El jugador aparece de forma segura, la cuenta regresiva del HUD aparece en un segundo y la primera ola inicia sin errores.","playtest.sample.context.observed":"La protección de aparición funcionó, el HUD se actualizó a tiempo y la primera ola terminó sin regresiones.","playtest.sample.report.markdown":`# Prueba de humo de Arena de ejemplo
90
+
91
+ - Flujo de aparición: PASS
92
+ - Cuenta regresiva del HUD: PASS
93
+ - Inicio de la ola: PASS
94
+
95
+ Esta es una vista de muestra. Actualiza a Pro para ejecutar playtests reales y guardar reportes reales.`,"playtest.sample.report.logs":`[sample] iniciar vista previa de playtest
96
+ [sample] protección de aparición activa
97
+ [sample] cuenta regresiva del hud renderizada
98
+ [sample] primera ola completada
99
+ [sample] reporte de muestra finalizado`,"sidebar.whatsNew":"Novedades","sidebar.help.group":"Ayuda y comentarios","sidebar.help.bug":"Reportar un error","sidebar.help.bug.tooltip":"Crear un paquete de diagnostico local y abrir un reporte de error precargado en GitHub","bugReportDialog.title":"diagnostics.zip puede ayudarnos a investigar","bugReportDialog.subtitle":"WEPPY creó un zip de diagnóstico en este equipo. Incluye registros de Studio, plugin, Sync y herramientas que pueden ayudarnos a entender qué pasó.","bugReportDialog.close":"Close","bugReportDialog.loading":"Preparing diagnostics.zip...","bugReportDialog.error":"Could not create the diagnostics bundle. You can still open GitHub without diagnostics.","bugReportDialog.bundle":"Bundle","bugReportDialog.included":"Included","bugReportDialog.included.none":"No log files found","bugReportDialog.optional":"Puedes enviar el reporte sin este archivo, pero adjuntarlo suele ayudarnos a encontrar la causa más rápido.","bugReportDialog.attachHow":"Para adjuntarlo, descarga o muestra el zip y luego añádelo al campo Diagnostics ZIP (optional) del issue de GitHub antes de enviarlo.","bugReportDialog.download":"1. Descargar diagnostics.zip","bugReportDialog.reveal":"Reveal in Finder","bugReportDialog.reveal.opening":"Opening...","bugReportDialog.reveal.opened":"Opened location","bugReportDialog.reveal.failed":"Could not open the file location.","bugReportDialog.openGithub":"2. Abrir issue de GitHub","bugReportDialog.openGithubFallback":"Open GitHub without diagnostics","bugReportDialog.retry":"Try again","bugReportDialog.hint":"El zip puede contener registros locales y contexto del proyecto. Revísalo antes de adjuntarlo si quieres compartirlo.","sidebar.help.feature":"Proponer una función","sidebar.help.feature.tooltip":"Proponer una nueva función o mejora en GitHub","sidebar.help.discussions":"Soporte","sidebar.help.discussions.tooltip":"Hacer preguntas o pedir ayuda de instalacion en GitHub Issues","sidebar.help.troubleshooting":"Solución de problemas","sidebar.help.troubleshooting.tooltip":"Abrir la guía oficial de solución de problemas en weppyai.com","header.whatsNew":"Novedades","header.whatsNew.tooltip":"Novedades","upgrade.title":"Ver Pro","upgrade.tagline":"Consulta las funciones Pro","upgrade.cta":"Ver Pro","upgrade.licenseShortcut":"Ingresar licencia","upgrade.validUntil":"Until {{date}}","whatsNew.pageTitle":"Novedades","whatsNew.pageSubtitle":"Mantente al día con los cambios de MCP","whatsNew.unreadSection":"Sin leer","whatsNew.allSection":"Todos los anuncios","whatsNew.empty":"Aún no hay anuncios","whatsNew.newBadge":"NUEVO","whatsNew.category.release":"Versión","whatsNew.category.notice":"Aviso","whatsNew.category.deprecation":"Obsoleto","whatsNew.category.tip":"Consejo","uiStudio.title":"UI Studio","uiStudio.empty":"Aún no hay capturas guardadas. Se crean automáticamente cuando un agente de IA captura el estado actual de la UI.","uiStudio.loading":"Loading…","uiStudio.pluginGuide.title":"El plugin de Roblox Studio no está conectado","uiStudio.pluginGuide.message":"UI Studio muestra capturas e historial de cambios del place de Studio conectado. Se actualizará automáticamente cuando Studio y WEPPY Plugin se conecten.","uiStudio.pluginGuide.check1":"¿Roblox Studio está abierto?","uiStudio.pluginGuide.check2":"¿WEPPY Plugin está instalado y en ejecución?","uiStudio.pluginGuide.waiting":"Esperando la conexión del plugin...","uiStudio.capturedAt":"Captured at","uiStudio.scope":"Scope","uiStudio.target":"Target","uiStudio.briefId":"Brief ID","uiStudio.detailClose":"Close","uiStudio.colCheck":"Check","uiStudio.colPriority":"Priority","uiStudio.colCurrent":"Current","uiStudio.colRecommended":"Recommended","uiStudio.colSuggestion":"Suggestion","uiStudio.priorityHigh":"Revisar primero","uiStudio.priorityLow":"Mejora opcional","uiStudio.highPrioritySection":"Revisar primero","uiStudio.lowPrioritySection":"Mejoras opcionales","uiStudio.groupSummary":"items","uiStudio.fixLabel":"Fix","uiStudio.copyFixCommand":"Copy AI instruction","uiStudio.copiedToClipboard":"Copied","uiStudio.fullPath":"Full path","uiStudio.falsePositiveWarning":"This group may contain false positives","uiStudio.noSuggestions":"No current improvement suggestions","uiStudio.sample.badge":"Preview of the Pro UI Studio","uiStudio.sample.title":"You are previewing the UI Studio that unlocks after upgrading to Pro.","uiStudio.sample.message":"This preview uses sample data from a demo inventory UI. Real screenshots, review history, and AI-driven fixes unlock with Pro.","uiStudio.tabs.analysis":"Análisis","uiStudio.tabs.history":"Historial","uiStudio.analysis.reportsTitle":"Último análisis por destino de UI","uiStudio.analysis.recentCapturesTitle":"Capturas recientes","uiStudio.analysis.detailDialog":"Detalle del análisis","uiStudio.analysis.targetCountLabel":"Destinos analizados","uiStudio.analysis.captureLabel":"Capturas","uiStudio.analysis.verdict.hasSuggestions":"Sugerencias de mejora","uiStudio.analysis.verdict.needsFix":"Sugerencias de mejora","uiStudio.analysis.verdict.review":"Sugerencias de mejora","uiStudio.analysis.verdict.passed":"Sin sugerencias actuales","uiStudio.analysis.verdictLabel":"Resumen de mejoras","uiStudio.analysis.thresholds":"Base de revisión","uiStudio.analysis.issueSummary.passed":"No hay sugerencias adicionales con la base de revisión actual.","uiStudio.history.title":"Historial de cambios","uiStudio.history.empty":"Aún no hay historial. Cuando un agente de IA modifique la UI con manage_ui, se registrará automáticamente.","uiStudio.history.loading":"Cargando...","uiStudio.history.error":"Error","uiStudio.history.clear":"Borrar todo","uiStudio.history.filter.actions":"Tipo de acción","uiStudio.history.filter.actionAll":"Todo","uiStudio.history.filter.actionCreate":"Crear","uiStudio.history.filter.actionUpdate":"Actualizar","uiStudio.history.filter.actionDelete":"Eliminar","uiStudio.history.filter.period":"Período","uiStudio.history.filter.dateAll":"Todo","uiStudio.history.filter.today":"Hoy","uiStudio.history.filter.yesterday":"Ayer","uiStudio.history.filter.last7Days":"Últimos 7 días","uiStudio.history.filter.last30Days":"Últimos 30 días","uiStudio.history.filter.customRange":"Rango personalizado","uiStudio.history.filter.reset":"Restablecer","uiStudio.history.filter.from":"Desde","uiStudio.history.filter.to":"Hasta","uiStudio.history.row.affectedPaths":"Rutas","uiStudio.history.row.mutations":"Detalles de cambios","uiStudio.history.row.expand":"▾ Expandir","uiStudio.history.row.collapse":"▲ Contraer","uiStudio.history.row.expandDetails":"Mostrar {n} cambios","uiStudio.history.row.collapseDetails":"Ocultar cambios","uiStudio.history.row.toggleDetails":"Alternar detalles de cambios","uiStudio.history.row.mutationsEmpty":"Sin detalles de cambios","uiStudio.history.row.toolLabel":"Cambios de UI ({n})","uiStudio.history.row.compare":"Antes / Después","uiStudio.history.row.noBeforeState":"Sin estado anterior","uiStudio.history.row.noAfterState":"Sin estado posterior","uiStudio.history.row.qualityPlan":"Dirección de diseño","uiStudio.history.row.designCheck":"Sugerencias","uiStudio.history.row.designCheckUnavailable":"Sugerencias: no disponibles","uiStudio.history.row.designCheckNone":"Sugerencias: ninguna","uiStudio.history.selection.deleteSelected":"Eliminar seleccionados","uiStudio.history.selection.selectAll":"Seleccionar todo","uiStudio.history.selection.clearSelection":"Limpiar selección","uiStudio.history.confirm.deleteRequestsTitle":"Eliminar registros de cambios","uiStudio.history.confirm.deleteRequestsMessage":"Los registros de cambios seleccionados se eliminarán. Esta acción no se puede deshacer.","uiStudio.history.confirm.clearRequestsTitle":"Borrar historial de cambios","uiStudio.history.confirm.clearRequestsMessage":"Esto borra el historial de cambios del place actual. Las instancias de Studio no se ven afectadas.","uiStudio.history.confirm.cascadeOption":"También eliminar capturas vinculadas","uiStudio.history.drawer.close":"Cerrar","uiStudio.actions.previewAgain":"Vista previa de nuevo","uiStudio.actions.deleteSnapshot":"Eliminar esta captura","uiStudio.actions.proRequired":"Disponible tras actualizar a Pro","uiStudio.actions.captureCurrentState":"Capturar estado actual","uiStudio.actions.checkSuggestionsAgain":"Volver a revisar sugerencias","uiStudio.actions.previewRunning":"Capturando…","uiStudio.actions.previewRunningDetail":"El ID del nuevo archivo de captura aparecerá al finalizar.","uiStudio.actions.previewNeedsSaveCheck":"Captura completada, revisa el guardado","uiStudio.actions.previewSaved":"Nueva captura de pantalla guardada","uiStudio.actions.previewComplete":"Captura completada","uiStudio.actions.previewSavedDetail":"Las capturas existentes se mantienen; esta se guardó como un archivo nuevo.","uiStudio.actions.previewSavedPathMissing":"Se recibió un nuevo ID de captura, pero no se pudo confirmar la ruta del archivo guardado.","uiStudio.actions.previewSnapshotIdMissing":"No se pudo confirmar el nuevo ID de captura. Actualiza la lista para verificar si se guardó.","uiStudio.actions.more":"Más","uiStudio.gallery.selection.selectedCount":" seleccionados","uiStudio.confirm.deleteSnapshotTitle":"Eliminar captura","uiStudio.confirm.deleteSnapshotMessage":"Solo se eliminará este archivo de captura (la instancia de Studio se conserva).","uiStudio.confirm.deleteBatchTitle":"Eliminar capturas seleccionadas","uiStudio.confirm.deleteBatchMessage":"Se eliminarán las capturas seleccionadas. Esta acción no se puede deshacer.","uiStudio.gallery.selectMode":"Seleccionar","uiStudio.gallery.exitSelectMode":"Cancelar","uiStudio.gallery.selectAll":"Seleccionar todo","uiStudio.gallery.clearSelection":"Deseleccionar","uiStudio.gallery.deleteSelected":"Eliminar selección","common.cancel":"Cancelar","common.delete":"Eliminar","uiStudio.storage.title":"Datos guardados de UI Studio","uiStudio.storage.usageLabel":"En uso","uiStudio.storage.historyBytes":"Historial","uiStudio.storage.snapshotBytes":"Capturas de pantalla","uiStudio.storage.requestCount":"Registros de cambios","uiStudio.storage.mutationCount":"Detalles de cambios","uiStudio.storage.snapshotCount":"Capturas de pantalla","uiStudio.storage.countSuffix":"","uiStudio.storage.lastRun":"Última limpieza automática","uiStudio.storage.lastRunNever":"—","uiStudio.storage.lastRunFreed":"liberado","uiStudio.storage.lastRunErrors":"Errores","uiStudio.storage.loading":"Cargando...","uiStudio.cleanup.policy.title":"Política de eliminación automática","uiStudio.cleanup.policy.modeOff":"Desactivado","uiStudio.cleanup.policy.modeAge":"Por antigüedad","uiStudio.cleanup.policy.modeSize":"Por tamaño","uiStudio.cleanup.policy.cascade":"También eliminar capturas vinculadas","uiStudio.cleanup.policy.save":"Guardar política","uiStudio.cleanup.policy.runNow":"Ejecutar ahora","uiStudio.cleanup.policy.proRequired":"Disponible después de actualizar a Pro","uiStudio.cleanup.policy.daysUnit":"d","uiStudio.cleanup.policy.mbUnit":"MB","uiStudio.cleanup.policy.gbUnit":"GB","uiStudio.cleanup.policy.confirm.title":"Confirmar política","uiStudio.cleanup.policy.confirm.messageStrict":"Al aplicar esta política se eliminarán inmediatamente","uiStudio.cleanup.policy.confirm.requests":" registros de cambios","uiStudio.cleanup.policy.confirm.snapshots":" capturas","uiStudio.cleanup.policy.confirm.freed":"liberado — ¿Aplicar?","uiStudio.cleanup.keepLastNDays":"Conservar últimos {n} días","uiStudio.cleanup.selectedDelete":"Eliminar selección…","uiStudio.cleanup.deleteAll":"Eliminar todo…","uiStudio.cleanup.cleanupConfirmTitle":"Confirmar limpieza","uiStudio.cleanup.cleanupConfirmMessage":"Los elementos seleccionados serán eliminados. Esta acción no se puede deshacer.","uiStudio.cleanup.cleanupConfirmMessage.keep7":"Change records and screenshots older than 7 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.keep30":"Change records and screenshots older than 30 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.all":" saved change records and screenshots will be deleted. This action cannot be undone.","uiStudio.cleanup.label":"Limpieza manual","uiStudio.cleanup.studioPreservedNote":"Esta acción elimina únicamente los archivos de historial y capturas en disco; las instancias de Roblox Studio no se ven afectadas.","uiStudio.history.sample.bannerBadge":"Vista previa del historial de cambios Pro","uiStudio.history.sample.bannerTitle":"Vista previa del historial de cambios Pro","uiStudio.history.sample.bannerMessage":"Esta vista previa usa datos de ejemplo. El historial real de registros de cambios, la comparación antes/después y la eliminación masiva se desbloquean con Pro.","uiStudio.fix.touchTarget.label":"Touch target size","uiStudio.fix.touchTarget.description":"Checks whether controls are large enough to tap comfortably on mobile.","uiStudio.fix.touchTarget.howToFix":"Increase button Size to at least 44x44 px or expand the touch area with UIPadding.","uiStudio.fix.contrast.label":"Text contrast","uiStudio.fix.contrast.description":"Checks whether text and background contrast meet accessibility guidance.","uiStudio.fix.contrast.howToFix":"Use a brighter TextColor3 or darken the BackgroundColor3.","uiStudio.fix.contrast.falsePositive":"Emoji icons may be false positives when their color is fixed.","uiStudio.fix.textScaled.label":"TextScaled usage","uiStudio.fix.textScaled.description":"TextScaled without UITextSizeConstraint can break layouts when text expands.","uiStudio.fix.textScaled.howToFix":"Add a UITextSizeConstraint child to the TextLabel and set MaxTextSize.","uiStudio.fix.safezone.label":"Safe-zone placement","uiStudio.fix.safezone.description":"Checks whether controls stay inside platform safe zones.","uiStudio.fix.safezone.howToFix":"Move Position inside the safe zone or reduce the parent Frame.","uiStudio.fix.minTextSize.label":"Minimum font size","uiStudio.fix.minTextSize.description":"Checks whether text is too small to read comfortably.","uiStudio.fix.minTextSize.howToFix":"Increase TextSize to at least 14 for body text.","uiStudio.sample.history.request1.label":"Initial HUD layout creation","uiStudio.sample.history.request2.label":"Inventory modal design update","uiStudio.sample.history.request3.label":"HUD HealthBar color update","uiStudio.sample.history.request4.label":"Expand Inventory tab button touch targets","uiStudio.sample.history.request5.label":"Remove Settings popup","uiStudio.sample.history.request6.label":"Add HUD minimap component","uiStudio.sample.history.request1.mutation1.diff":"Created Frame + HealthBar + StaminaBar","uiStudio.sample.history.request1.mutation2.diff":"BackgroundColor3 -> Color3.new(0.2,0.8,0.2)","uiStudio.sample.history.request1.mutation3.diff":"BackgroundColor3 -> Color3.new(0.1,0.6,1.0)","uiStudio.sample.history.request1.mutation4.diff":"Set AnchorPoint, Position, and Size","uiStudio.sample.history.request1.mutation5.diff":"Screenshot saved","uiStudio.sample.history.request2.mutation1.diff":"Darkened BackgroundColor3 for better contrast","uiStudio.sample.history.request2.mutation2.diff":"TextColor3 -> Color3.new(1,1,1), TextSize 16 -> 18","uiStudio.sample.history.request2.mutation3.diff":"BorderSizePixel 0 -> 2, set BorderColor3","uiStudio.sample.history.request2.mutation4.diff":"Screenshot saved","uiStudio.sample.history.request3.mutation1.diff":"BackgroundColor3 -> Color3.new(0.9,0.2,0.2) (red tone)","uiStudio.sample.history.request3.mutation2.diff":"Screenshot saved","uiStudio.sample.history.request4.mutation1.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation2.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation3.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation4.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation5.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation6.diff":"Screenshot saved","uiStudio.sample.history.request5.mutation1.diff":"Removed ScreenGui (Settings-only UI)","uiStudio.sample.history.request6.mutation1.diff":"Attempted to create Frame + MapImage + PlayerDot","uiStudio.sample.history.request6.mutation2.diff":"Set Size, Position, and BackgroundTransparency","uiStudio.sample.history.request6.mutation3.diff":"Interrupted by server restart while setting ImageLabel","uiStudio.sample.history.request6.mutation4.diff":"Partial screenshot saved","uiStudio.sample.history.request6.mutation3.error":"server_restart: connection lost","uiStudio.sample.history.request6.mutation4.error":"partial screenshot: missing layers","uiStudio.sample.history.detail.backgroundColor":"Background color","uiStudio.sample.history.detail.anchorPoint":"Anchor","uiStudio.sample.history.detail.position":"Position","uiStudio.sample.history.detail.size":"Size","uiStudio.sample.history.detail.textColor":"Text color","uiStudio.sample.history.detail.textSize":"Text size","uiStudio.sample.history.detail.borderSize":"Border size","uiStudio.sample.history.detail.borderColor":"Border color","uiStudio.history.sample.tooltip":"Actualiza a Pro para desbloquear el historial completo","settings.dataHistory.title":"Data & History","settings.dataHistory.title.tooltip":"Manage saved dashboard data in one place.","settings.dataHistory.collapse":"Collapse {title}","settings.dataHistory.expand":"Expand {title}","settings.dataHistory.scope":"Current project","settings.dataHistory.scope.tooltip":"Clear actions apply to the current project and active place where applicable.","settings.dataHistory.intro":"Review saved dashboard data, open the related page, or clear stored records from one place.","settings.dataHistory.toolsActivity.title":"Tool activity","settings.dataHistory.toolsActivity.description":"Saved tool runs shown on the Tools page.","settings.dataHistory.toolStats.title":"Tool usage statistics","settings.dataHistory.toolStats.description":"Aggregated tool counts and status totals.","settings.dataHistory.syncLog.title":"Sync log","settings.dataHistory.syncLog.description":"Saved file sync events for the active place.","settings.dataHistory.playtest.title":"Playtest reports","settings.dataHistory.playtest.description":"Saved automated playtest reports and logs.","settings.dataHistory.projectChanges.title":"Project change summary","settings.dataHistory.projectChanges.description":"Saved summaries of project changes.","settings.dataHistory.connectionLog.title":"Connection log","settings.dataHistory.connectionLog.description":"Saved MCP and Studio connection events.","settings.dataHistory.uiStudio.title":"UI Studio history and screenshots","settings.dataHistory.uiStudio.tooltip":"Manage saved UI Studio change records, screenshots, and auto-delete policy.","settings.dataHistory.uiStudio.description":"Saved UI Studio change records, screenshots, and cleanup policy.","settings.dataHistory.uiStudio.clear.title":"Clear UI Studio saved data?","settings.dataHistory.uiStudio.clear.message":"This deletes saved UI Studio change records and screenshots only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.uiStudio.clear.success":"UI Studio saved data cleared.","settings.dataHistory.uiStudio.clear.failed":"Failed to clear UI Studio saved data.","settings.dataHistory.metric.unavailable":"Unavailable","settings.dataHistory.metric.sizeUnavailable":"size unavailable","settings.dataHistory.metric.records":"records","settings.dataHistory.metric.runs":"runs","settings.dataHistory.metric.sessions":"sessions","settings.dataHistory.metric.reports":"reports","settings.dataHistory.open":"Open","settings.dataHistory.clear.title":"Clear saved data?","settings.dataHistory.clear.message":"This deletes saved dashboard records only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.clear.success":"Saved data cleared.","settings.dataHistory.clear.failed":"Failed to clear saved data.","toast.serverConnected":"Servidor MCP conectado","toast.serverDisconnected":"Servidor MCP desconectado","toast.pluginConnected":"Plugin conectado","toast.pluginDisconnected":"Plugin desconectado","toast.clearSuccess":"Borrado correctamente","toast.clearFailed":"No se pudo borrar los datos","common.clear":"Borrar","settings.license.activate":"Activar licencia","settings.license.refresh":"Actualizar licencia","settings.license.keyInput":"Clave de licencia","settings.license.disconnected":"Desconectado","settings.license.disconnected.tooltip":"Reconéctese al servidor MCP para gestionar la licencia desde WEPPY Dashboard.","settings.license.live.tooltip":"Las acciones de licencia se envían inmediatamente al servidor MCP.","settings.license.status.activationRequired":"Activación requerida","settings.license.status.activationRequired.tooltip":"Se requiere activación manual de la licencia antes de que WEPPY Dashboard pueda actualizar este estado.","settings.license.status.grace":"Período de gracia","settings.license.status.grace.tooltip":"La verificación del proveedor no está disponible temporalmente, pero el acceso Pro permanece activo durante el período de gracia.","settings.license.status.graceBilling.tooltip":"El acceso Pro sigue disponible durante un período de gracia relacionado con la facturación.","settings.license.detail.graceBilling":"El acceso Pro sigue disponible durante el período de gracia de facturación.","settings.license.detail.graceProviderUnavailable":"Proveedor no disponible. El acceso Pro sigue activo en modo de gracia.","settings.license.detail.manualActivation":"Se requiere activación manual para restaurar el acceso Pro.","settings.license.detail.missingSessionToken":"La actualización está bloqueada porque falta el token de sesión actual.","settings.license.detail.refreshRecommended":"Pronto se debe actualizar la verificación de licencia.","connection.agents.kill":"Terminar","connection.agents.kill.title":"¿Terminar el agente?","connection.agents.killed":"Agente terminado","connection.agents.killFailed":"No se pudo terminar el agente","connection.agents.lastCommand":"Último comando","connection.agents.lastCommand.tooltip":"Llamada de herramienta más reciente ejecutada por este agente.","connection.agents.lastSeen":"Visto por última vez","connection.agents.lastSeen.tooltip":"Heartbeat o actividad más reciente de este agente.","connection.clear.title":"¿Borrar el registro de conexión?","connection.clear.message":"Esto elimina permanentemente el registro de conexión almacenado del proyecto actual.","sync.clear.title":"¿Borrar el registro de sincronización?","sync.clear.message":"Esto elimina permanentemente el registro de sincronización almacenado del place actual.","playtest.clear.title":"¿Borrar el historial de pruebas?","playtest.clear.message":"Esto elimina permanentemente los informes de playtest almacenados del place actual.","changelog.clear.title":"¿Borrar el changelog?","changelog.clear.message":"Esto elimina permanentemente el changelog almacenado del place actual.","sync.status.placePath":"Ruta del place","sync.status.placePath.tooltip":"Directorio del place activo donde se sincronizan los archivos del explorador.","tier.progress.label":"Pro / Total","changelog.card.representativeArea":"Área representativa","changelog.card.verification":"Verificación","uiStudio.tabs.analysis.tooltip":"Browse AI-captured UI screens and quickly find which UIs need improvement.","uiStudio.tabs.history.tooltip":"Every UI change AI made, in order. Compare before and after screens.","uiStudio.title.tooltip":"A central place to review AI-generated UI screens and improvement suggestions.","uiStudio.analysis.reportsTitle.tooltip":"Shows the latest capture and suggestion summary per UI (e.g., Inventory window, Main menu).","uiStudio.analysis.verdict.hasSuggestions.tooltip":"Some improvements were found in this UI. Click the card for details.","uiStudio.analysis.verdict.passed.tooltip":"No improvements suggested under the current review thresholds.","uiStudio.analysis.counts.tooltip":"‘Main’ are key items to review first; ‘Notes’ are nice-to-have refinements.","uiStudio.analysis.thresholds.tooltip":"The threshold set used for this review (default or custom).","uiStudio.analysis.recentCapturesTitle.tooltip":"All recently saved captures in chronological order.","uiStudio.gallery.selectAll.tooltip":"Select every visible capture at once.","uiStudio.gallery.clearSelection.tooltip":"Clear the current selection.","uiStudio.gallery.deleteSelected.tooltip":"Delete only the selected capture files. The actual UI in Roblox Studio is not affected.","uiStudio.gallery.cardCheckbox.tooltip":"Select this capture. Pick multiple to delete them together.","uiStudio.detailClose.tooltip":"Close this detail panel.","uiStudio.actions.captureCurrentState.tooltip":"Save the UI currently shown in Studio as a new capture. Existing captures are kept.","uiStudio.actions.checkSuggestionsAgain.tooltip":"Recompute suggestions for this capture without taking a new screenshot.","uiStudio.actions.more.tooltip":"Open additional actions.","uiStudio.actions.deleteSnapshot.tooltip":"Delete only this capture file. The actual UI in Roblox Studio is not affected.","uiStudio.capturedAt.tooltip":"When this screen was captured.","uiStudio.scope.tooltip":"Capture scope (full screen or a specific UI).","uiStudio.target.tooltip":"Exact path of the captured UI instance.","uiStudio.briefId.tooltip":"Identifier of the design brief that produced this UI.","uiStudio.analysis.verdictLabel.tooltip":"Overall improvement verdict for this capture.","uiStudio.suggestionGroup.tooltip":"Suggestions of the same kind grouped together. Click to expand or collapse.","uiStudio.groupSummary.tooltip":"Number of UI elements matching this group.","uiStudio.colCurrent.tooltip":"The currently applied value.","uiStudio.colRecommended.tooltip":"The recommended value.","uiStudio.copyFixCommand.tooltip":"Copy a prompt that asks the AI to fix this issue.","uiStudio.falsePositiveWarning.tooltip":"This check can produce false positives — verify before applying.","uiStudio.history.filter.actions.tooltip":"Filter records by the kind of change AI made.","uiStudio.history.filter.period.tooltip":"Filter records by time range.","uiStudio.history.filter.from.tooltip":"Start date for the query.","uiStudio.history.filter.to.tooltip":"End date for the query.","uiStudio.history.filter.actionAll.tooltip":"Show every kind of action.","uiStudio.history.filter.actionCreate.tooltip":"Show only actions that created a new UI.","uiStudio.history.filter.actionUpdate.tooltip":"Show only actions that updated an existing UI.","uiStudio.history.filter.actionDelete.tooltip":"Show only actions that deleted a UI.","uiStudio.history.filter.dateAll.tooltip":"Show the full history.","uiStudio.history.filter.today.tooltip":"Show only changes from today.","uiStudio.history.filter.yesterday.tooltip":"Show only changes from yesterday.","uiStudio.history.filter.last7Days.tooltip":"Show changes from the last 7 days.","uiStudio.history.filter.last30Days.tooltip":"Show changes from the last 30 days.","uiStudio.history.filter.customRange.tooltip":"Pick a custom start and end date.","uiStudio.history.filter.reset.tooltip":"Reset all filters to defaults.","uiStudio.history.title.tooltip":"A timeline of every UI change made by AI.","uiStudio.history.clear.tooltip":"Delete every change record for this project. The actual UI in Roblox Studio is not affected.","uiStudio.history.row.compare.tooltip":"Compare the before and after screens. Click to open the full comparison view.","uiStudio.history.row.extraPaths.tooltip":"Number of additional UIs changed in this action.","uiStudio.history.row.noBeforeState.tooltip":"No capture saved before this change.","uiStudio.history.row.noAfterState.tooltip":"No capture saved after this change.","uiStudio.history.row.affectedPaths.tooltip":"Number of UIs affected by this action.","uiStudio.history.row.mutations.tooltip":"Number of detailed changes (e.g., property edits).","uiStudio.history.row.qualityPlan.tooltip":"Dirección de diseño del brief usada para este cambio.","uiStudio.history.row.designCheck.tooltip":"Resumen de sugerencias de Design Check después del cambio.","uiStudio.history.row.toggleDetails.tooltip":"Show or hide a per-line breakdown of what changed.","uiStudio.compare.before.tooltip":"The screen saved just before AI made the change.","uiStudio.compare.after.tooltip":"The screen saved just after AI made the change.","uiStudio.compare.path.tooltip":"The UI instance path for this screen.","uiStudio.storage.title.tooltip":"Disk usage of UI Studio change records and screenshots.","uiStudio.storage.usageLabel.tooltip":"Disk space currently used by UI Studio for this project.","uiStudio.storage.historyBytes.tooltip":"Space taken by change record data (JSON).","uiStudio.storage.snapshotBytes.tooltip":"Space taken by captured PNG image files.","uiStudio.storage.requestCount.tooltip":"Number of actions where AI changed the UI.","uiStudio.storage.mutationCount.tooltip":"Number of detail changes inside actions (one property edit = 1).","uiStudio.storage.snapshotCount.tooltip":"Number of saved capture image files.","uiStudio.storage.lastRun.tooltip":"When the auto-cleanup policy last ran, and what it removed.","uiStudio.cleanup.label.tooltip":"Manually clean up change records and captures whenever you want.","uiStudio.cleanup.keep7.tooltip":"Delete change records and captures older than 7 days.","uiStudio.cleanup.keep30.tooltip":"Delete change records and captures older than 30 days.","uiStudio.cleanup.deleteAll.tooltip":"Delete every change record and capture for this project. The actual UI in Roblox Studio is not affected.","uiStudio.cleanup.policy.title.tooltip":"Rules that automatically remove old or large captures.","uiStudio.cleanup.policy.modeOff.tooltip":"Turn off auto-cleanup. Data stays until you remove it manually.","uiStudio.cleanup.policy.modeAge.tooltip":"Automatically delete data older than the configured number of days.","uiStudio.cleanup.policy.modeSize.tooltip":"When total usage exceeds the limit, the oldest data is removed first.","uiStudio.cleanup.policy.agePreset.tooltip":"Delete data older than this many days.","uiStudio.cleanup.policy.ageInput.tooltip":"Enter any value between 1 and 365 days.","uiStudio.cleanup.policy.sizePreset.tooltip":"Keep total usage under this size.","uiStudio.cleanup.policy.sizeInput.tooltip":"Enter any value between 50 MB and 10000 MB (10 GB).","uiStudio.cleanup.policy.cascade.tooltip":"Also delete the capture images linked to those records. If off, the images stay.","uiStudio.cleanup.policy.save.tooltip":"Save the current cleanup rule. It runs in the background from then on.","uiStudio.cleanup.policy.runNow.tooltip":"Run the current rule once now, without waiting for the next scheduled run.","settings.license.refresh.tooltip":"Re-fetch the current state from the license server. Useful when a billing change hasn't appeared yet.","settings.license.reset.tooltip":"Remove the currently registered license key. Use this before activating with a different key.","settings.license.activate.tooltip":"Activate Pro features with the entered license key.","tier.upgrade.tooltip":"Ver funciones Pro y opciones de compra.","settings.language.auto.tooltip":"Follow the operating system's language. Falls back to English when not supported.","settings.dataHistory.open.tooltip":"Open the page that shows this item in detail.","settings.dataHistory.clear.tooltip":"Delete only the records saved for this item. Roblox Studio data is not changed.","settings.dataHistory.toggle.tooltip":"Collapse or expand this section.","settings.dataHistory.toolsActivity.metric.tooltip":"Number of saved tool runs and the disk space they use.","settings.dataHistory.toolStats.metric.tooltip":"Aggregated total runs and session counts.","settings.dataHistory.syncLog.metric.tooltip":"Number of saved sync events and the disk space they use.","settings.dataHistory.playtestReports.metric.tooltip":"Number of saved playtest reports and the disk space they use.","settings.dataHistory.projectChanges.metric.tooltip":"Number of saved project change summaries and the disk space they use.","settings.dataHistory.connectionLog.metric.tooltip":"Number of saved connection events and the disk space they use.","settings.dataHistory.uiStudio.metric.tooltip":"UI Studio change record and capture counts, plus total disk usage.","uiStudio.designCheckResultsTitle":"Sugerencias de Design Check","uiStudio.designCheckResultsTitle.tooltip":"All improvement suggestions found in this capture.","uiStudio.actions.designCheckAgain":"Revisar de nuevo","uiStudio.actions.designCheckRunning":"Revisando sugerencias...","uiStudio.actions.designCheckRunningDetail":"Al finalizar se mostrarán los elementos para revisar primero, recomendados y opcionales.","uiStudio.actions.designCheckComplete":"Revisión de sugerencias completada","uiStudio.actions.designCheckNoSnapshotSaved":"Esta acción no guarda un nuevo archivo de captura.","uiStudio.sample.designCheck.contrast":"Text contrast is below {expected} (current {actual}). Adjust TextColor3 or BackgroundColor3.","uiStudio.sample.designCheck.touchTarget":"Touch target is below {expected} (current {actual}). Increase Size or padding.","uiStudio.sample.designCheck.minTextSize":"TextSize is below {expected} (current {actual}). Increase it for readability.","uiStudio.gallery.priorityHighBadge.tooltip":"Número de sugerencias para revisar primero. Haz clic para ver detalles.","uiStudio.gallery.priorityMediumBadge.tooltip":"Número de sugerencias recomendadas.","uiStudio.priorityMedium":"Revisión recomendada","uiStudio.mediumPrioritySection":"Revisión recomendada","uiStudio.gallery.priorityLowBadge.tooltip":"Número de mejoras opcionales.","tier.banner.progressLabel":"Pro / Total","uiStudio.error":"Error","uiStudio.analysis.expandChildren":"Mostrar objetivos secundarios","uiStudio.analysis.openDetail":"Abrir detalle","uiStudio.analysis.childTargets":"Objetivos secundarios","uiStudio.analysis.childDetailHint":"Abrir detalle del objetivo secundario","uiStudio.compare.before":"Antes","uiStudio.compare.after":"Después","uiStudio.history.drawer.changeDetails":"Detalles del cambio","uiStudio.gallery.cardCheckbox":"Seleccionar captura","sidebar.assets":"Assets","assets.title":"Assets","assets.experimental":"Experimental","assets.subtitle":"Browse local originals, upload to Roblox, and inspect synced usage by place.","assets.scope.label":"Asset scope","assets.scope.place":"Current Place","assets.scope.shared":"Shared","assets.count.shown":"Shown assets: {count}","assets.category.filter":"Category","assets.category.all":"All","assets.category.image":"Images","assets.category.decal":"Decals","assets.category.audio":"Audio","assets.category.mesh":"Meshes","assets.category.model":"Models","assets.category.rbxm":"RBXM","assets.category.video":"Videos","assets.category.animation":"Animations","assets.category.comingSoon":"Coming soon","assets.status.localOnly":"Local only","assets.status.uploading":"Uploading","assets.status.processing":"Processing","assets.status.uploaded":"Uploaded","assets.status.failed":"Failed","assets.status.superseded":"Superseded","assets.rescan":"Rescan","assets.rescan.tooltip":"Scan the selected inbox folder.","assets.rescan.chooseCategory":"Choose a category before rescanning.","assets.rbxmGuide.title":"Save RBXM from Studio","assets.rbxmGuide.body":"Select objects in Roblox Studio, then use WEPPY Plugin > Assets to save the selection as a local RBXM asset.","assets.rbxmGuide.thumbnail":"The plugin save flow includes a thumbnail option, and saved RBXM assets appear here for management, upload, and insertion.","assets.exportSelection":"Export Studio selection","assets.exportSelection.tooltip":"Export the current Studio selection as a local .rbxm asset.","assets.exportSelection.chooseCategory":"Choose RBXM before exporting a Studio selection.","assets.upload.open":"Upload","assets.upload.open.tooltip":"Upload this local file to Roblox through Open Cloud.","assets.upload.selectFirst":"Select an asset first.","assets.upload.title":"Upload asset","assets.upload.checkingSettings":"Checking upload settings...","assets.upload.settingsLoadFailed":"Failed to load upload settings.","assets.upload.settingsRequired":"Upload settings required","assets.upload.settingsRequired.apiKey":"Save an Open Cloud API key before uploading.","assets.upload.settingsRequired.toggle":"Enable Open Cloud upload before uploading.","assets.upload.settingsRequired.creator":"Save a default Creator before uploading.","assets.upload.openSettings":"Open Asset Library settings","assets.upload.creator":"Creator","assets.upload.creatorType":"Creator type","assets.upload.creatorId":"Creator ID","assets.upload.envCreatorHelp":"Environment API keys cannot save a default Creator here. Enter the Creator for this upload.","assets.upload.displayNameHelp":"Saved to Roblox as the asset display name.","assets.upload.descriptionHelp":"Saved to Roblox as the asset description.","assets.upload.creatorHelp":"Used by Open Cloud as the owner of the uploaded asset.","assets.upload.creatorTypeHelp":"Sent to Open Cloud as the Creator type.","assets.upload.creatorIdHelp":"Sent to Open Cloud as the User or Group ID that owns the uploaded asset.","assets.upload.submit":"Upload with Roblox Open Cloud","assets.upload.uploading":"Uploading...","assets.upload.noDelete":"WEPPY does not provide Roblox asset deletion.","assets.upload.delay":"Roblox processing and moderation can delay visibility in Studio or Creator Dashboard.","assets.delete.tooltip":"Delete this local Asset Library item.","assets.delete.title":"Delete asset","assets.delete.message":"This removes the local Asset Library files only. Uploaded Roblox assets are not deleted.","assets.creator.user":"User","assets.creator.group":"Group","assets.settings.open":"Open settings","assets.settings.open.tooltip":"Open Roblox upload settings.","assets.settings.title":"Asset Library settings","assets.settings.proOnly":"Roblox upload settings and Open Cloud credential controls are available on Pro.","assets.settings.openCloudToggle":"Open Cloud upload","assets.settings.openCloudToggle.help":"Controls whether server-side Open Cloud upload mutations can run.","assets.settings.apiKey":"Open Cloud API Key","assets.settings.apiKeyGuide":"Create a Roblox API key with Assets Read and Write permissions.","assets.settings.creatorHelp":"Use the numeric user ID from a profile URL or group ID from a group URL.","assets.settings.credential.none":"No API key saved","assets.settings.credential.env":"Environment variable","assets.settings.credential.local":"Local encrypted file","assets.settings.registeredApiKey":"Registered API Key","assets.settings.credentialProfile":"Credential Profile","assets.settings.activeProfileBadge":"Active","assets.settings.field.profile":"Profile","assets.settings.field.apiKey":"API Key","assets.settings.field.storage":"Storage","assets.settings.field.validationStatus":"Validation status","assets.settings.field.creators":"Creators","assets.settings.validation.unknown":"Not tested","assets.settings.validation.valid":"Connected","assets.settings.validation.invalid":"Needs attention","assets.settings.profileSelected":"Open Cloud credential profile selected.","assets.settings.useProfile":"Use profile","assets.settings.replaceApiKey":"Replace API Key","assets.settings.profileLabel":"Profile name (optional)","assets.settings.profileLabel.placeholder":"Studio automation key","assets.settings.profileLabel.help":"Optional. If left blank, WEPPY saves this profile as Open Cloud key automatically.","assets.settings.saveApiKey":"Save API Key","assets.settings.testConnection":"Test Connection","assets.settings.removeApiKey":"Unregister API Key","assets.settings.saveCreator":"Save default Creator","assets.settings.saveCreatorPreset":"Save Creator","assets.settings.addCreator":"Add Creator","assets.settings.addCreator.tooltip.ready":"Add another User or Group Creator preset to this profile.","assets.settings.cancelCreator":"Cancel","assets.settings.defaultCreatorBadge":"Default","assets.settings.makeDefaultCreator":"Make default","assets.settings.unregisterCreator":"Unregister Creator","assets.settings.creatorLabel":"Creator label (optional)","assets.settings.creatorLabel.placeholder":"Main studio group","assets.settings.creatorLabel.help":"Optional. If left blank, WEPPY automatically saves a label like User 123 or Group 456.","assets.settings.action.proRequired":"Asset upload settings are available on Pro.","assets.settings.action.busy":"Wait for the current settings action to finish.","assets.settings.saveApiKey.tooltip.ready":"Save this API key to local encrypted storage.","assets.settings.saveApiKey.tooltip.enter":"Enter an Open Cloud API key to save it locally.","assets.settings.testConnection.tooltip.entered":"Test the entered API key before saving it.","assets.settings.testConnection.tooltip.saved":"Test the saved Open Cloud API key.","assets.settings.testConnection.tooltip.enterOrSaved":"Enter an API key or save one before testing the connection.","assets.settings.removeApiKey.tooltip.ready":"Unregister the locally saved Open Cloud API key from WEPPY.","assets.settings.removeApiKey.tooltip.none":"No local Open Cloud API key is saved.","assets.settings.removeApiKey.tooltip.env":"Environment API keys cannot be removed from Dashboard. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY.","assets.settings.unregisterCreator.tooltip.ready":"Unregister this Creator from the selected profile.","assets.settings.unregisterApiKey.title":"Unregister API Key?","assets.settings.unregisterApiKey.message":"Roblox API key is not revoked. WEPPY only removes the local Credential Profile registration on this device.","assets.settings.unregisterCreator.title":"Unregister Creator?","assets.settings.unregisterCreator.message":"Roblox user or group is not deleted. WEPPY only removes this Creator from the selected API Key profile.","assets.settings.saveCreator.tooltip.ready":"Save this Creator as the default owner for uploads.","assets.settings.saveCreator.tooltip.noLocal":"Save a local Open Cloud API key before saving a default Creator.","assets.settings.saveCreator.tooltip.env":"Environment API keys cannot save a default Creator here. Enter Creator details in the upload dialog.","assets.settings.saveCreator.tooltip.enterId":"Enter a user or group ID before saving the default Creator.","assets.settings.apiKeySaved":"Open Cloud API key saved locally.","assets.settings.apiKeyTested":"Open Cloud API key connection tested.","assets.settings.apiKeyRemoved":"Open Cloud API key unregistered from local storage.","assets.settings.envApiKeyStillActive":"Environment variable credential is still active. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY Dashboard.","assets.settings.defaultCreatorSaved":"Open Cloud default Creator saved locally.","assets.settings.creatorUnregistered":"Creator unregistered from this profile.","assets.settings.creatorUnregisterFailed":"Failed to unregister Creator.","assets.settings.saved":"Upload settings saved.","assets.settings.saveFailed":"Failed to save upload settings.","assets.settings.loadFailed":"Failed to load upload settings.","assets.settings.tested":"Connection tested.","assets.settings.testFailed":"Connection test failed.","assets.settings.removed":"API key unregistered.","assets.settings.removeFailed":"Failed to unregister API key.","assets.basic.notice":"Browse, preview, edit metadata, and scan usage on Basic. Roblox upload controls are available on Pro.","assets.proOnly.tooltip":"Roblox upload is available on Pro.","assets.proOnly.upload":"Roblox upload is available on Pro.","assets.empty.title":"No assets yet","assets.empty.body":"Choose a scope and category, then rescan that inbox folder.","assets.detail.title":"Asset details","assets.detail.displayName":"Display name","assets.detail.description":"Description","assets.detail.save":"Save metadata","assets.detail.refreshStatus":"Refresh","assets.detail.scanUsage":"Scan usage","assets.detail.localFile":"Local file","assets.detail.fileName":"File","assets.detail.category":"Category","assets.detail.scope":"Scope","assets.detail.mimeType":"Type","assets.detail.size":"Size","assets.detail.dimensions":"Dimensions","assets.detail.duration":"Duration","assets.detail.source":"Source path","assets.detail.sha256":"SHA-256","assets.detail.roblox":"Roblox upload status","assets.detail.status":"Status","assets.detail.assetId":"Asset ID","assets.detail.error":"Error","assets.detail.copyAssetId":"Copy Asset ID","assets.detail.copyUri":"Copy URI","assets.detail.studioUri":"Studio URI","assets.detail.robloxWebUrl":"Creator Dashboard URL","assets.detail.copyStudioUri":"Copy Studio URI","assets.detail.copyWebUrl":"Copy configure URL","assets.detail.openRobloxPage":"Open configure page","assets.detail.robloxWebUrlNotice":"Opening this page requires the Roblox account that owns or can manage the uploaded asset.","assets.detail.uploadHistory":"Upload history","assets.detail.usedInPlace":"Where this asset is used in this Place","assets.detail.noUsage":"No local Sync references found yet.","assets.detail.usageSource":"Checked against","assets.detail.usageSource.localSync":"Local Sync files","assets.detail.usageSource.notScanned":"Not checked yet","assets.detail.lastScanned":"Last checked","assets.detail.lastScannedAt":"Last checked: {time}","assets.detail.lastScanned.never":"No check yet","assets.detail.noUsageUnscanned":"Run Scan usage to search local Sync files for this Roblox Asset ID.","assets.detail.noUsageAfterScan":"No references were found in local Sync files during the last check.","assets.detail.noUsageNoRobloxId":"This asset does not have a Roblox Asset ID yet, so usage cannot be checked. Upload it before scanning usage.","assets.detail.technicalDetails":"Technical details","assets.detail.stableId":"Stable ID","assets.detail.sourceKind":"Source kind","assets.detail.createdAt":"Created","assets.detail.updatedAt":"Updated","assets.detail.operationId":"Operation ID","assets.detail.operationPath":"Operation path","assets.detail.versionId":"Version ID","assets.detail.remotePath":"Remote path","assets.detail.moderationState":"Moderation","assets.detail.line":"line {line}","assets.studio.notConnected":"Connect Roblox Studio before using Studio asset actions.","assets.detail.importRbxm":"Insert into Studio","assets.detail.importRbxm.tooltip":"Insert this local RBXM asset into {target} in the connected Studio place.","assets.detail.generateThumbnail":"Generate thumbnail","assets.detail.generateThumbnail.tooltip":"Create or replace the Asset Library thumbnail from Studio.","assets.detail.rbxmOnly":"Studio import is available for .rbxm assets.","assets.detail.rbxmCategoryOnly":"Studio .rbxm actions support models and animations.","assets.detail.thumbnailRbxmOnly":"Thumbnail generation is available for .rbxm model assets.","assets.detail.thumbnailModelOnly":"Thumbnail generation is available for model .rbxm assets.","assets.detail.rbxm":"RBXM contents","assets.detail.rbxmExportedCount":"Exported roots","assets.detail.rbxmClasses":"Classes","assets.detail.rbxmThumbnail":"Thumbnail","assets.detail.studioInsertTarget":"Studio insert target","assets.detail.rbxmRoots":"Root tree","assets.detail.rbxmReferences":"Asset references","assets.detail.rbxmThumbnailAttempts":"Thumbnail attempts","dashboardHelp.button":"Help","dashboardHelp.pageButton.ariaLabel":"Open page help","dashboardHelp.fieldButton.ariaLabel":"Open field help","dashboardHelp.section.canDo":"What you can do here","dashboardHelp.section.needs":"What you need to use it","dashboardHelp.section.links":"Related links","dashboardHelp.overview.title":"Overview help","dashboardHelp.overview.canDo.1":"Check MCP server, WEPPY Plugin, AI Agent, Sync, and recent game changes in one place.","dashboardHelp.overview.needs.1":"Useful status requires the MCP server. Live Studio status also needs WEPPY Plugin connected to the active place.","dashboardHelp.connection.title":"Connection help","dashboardHelp.connection.canDo.1":"Inspect server process details, connected AI agents, Studio plugin clients, and connection log events.","dashboardHelp.connection.needs.1":"The MCP server must be reachable. Plugin rows appear after Studio sends heartbeats.","dashboardHelp.sync.title":"Sync help","dashboardHelp.sync.canDo.1":"Review Studio to local sync status, direction, apply mode, and sync logs.","dashboardHelp.sync.needs.1":"Sync needs an active place and connected WEPPY Plugin. Two-way and reverse workflows depend on Pro.","dashboardHelp.assets.title":"Assets help","dashboardHelp.assets.canDo.1":"Browse local Asset Library files, switch place/shared scope, filter categories, scan usage, insert RBXM into Studio, and upload local assets to Roblox.","dashboardHelp.assets.needs.1":"Upload needs Pro, the Open Cloud upload toggle, a valid API Key, and a Creator. Browse and preview work on Basic.","dashboardHelp.changelog.title":"Changelog help","dashboardHelp.changelog.canDo.1":"Review real game-change sessions extracted from AI actions and sync events.","dashboardHelp.changelog.needs.1":"Entries are scoped to the active place. Basic shows only the latest preview entries.","dashboardHelp.playtest.title":"Playtest help","dashboardHelp.playtest.canDo.1":"Review Playtest results and reports saved by the AI Agent.","dashboardHelp.playtest.needs.1":"Pro shows real stored reports. Basic shows sample preview data. Live active-place confidence needs WEPPY Plugin connected.","dashboardHelp.uiStudio.title":"UI Studio help","dashboardHelp.uiStudio.canDo.1":"Review AI-created UI analysis, improvement suggestions, captures, and before/after history.","dashboardHelp.uiStudio.needs.1":"Pro shows real UI Studio data. Basic shows a bundled sample. New capture/check actions need WEPPY Plugin connected.","dashboardHelp.tools.title":"Tools help","dashboardHelp.tools.canDo.1":"Inspect tool history, status classification, fallback/unsupported/warn/error details, and usage statistics.","dashboardHelp.tools.needs.1":"History and statistics depend on local recording settings and the active place bucket.","dashboardHelp.settings.title":"Settings help","dashboardHelp.settings.canDo.1":"Manage License, hot settings, saved data cleanup, server environment display, and language.","dashboardHelp.settings.needs.1":"License actions need MCP server connection. Server environment values are read-only here. Asset upload controls live in Assets settings.","dashboardHelp.openCloudApiKey.title":"Open Cloud API Key help","dashboardHelp.openCloudApiKey.canDo.1":"WEPPY uses this key only for Roblox Open Cloud requests.","dashboardHelp.openCloudApiKey.needs.1":"Create a Roblox API key in Creator Hub. Add Assets under Access Permissions, then enable both Read and Write operations.","dashboardHelp.openCloudApiKey.needs.2":"Set the key target to the same User or Group that you use as the upload Creator.","dashboardHelp.openCloudApiKey.needs.3":"The raw key is encrypted on this device. It is not sent to WEPPY servers, and it is not stored in any other external storage, browser storage, telemetry, logs, tool history, or Asset Library metadata.","dashboardHelp.openCloudApiKey.link.apiKeys":"Roblox API keys","dashboardHelp.openCloudApiKey.link.assetsGuide":"Assets API usage guide","dashboardHelp.openCloudApiKey.link.assetsReference":"Assets API reference","dashboardHelp.openCloudCreatorId.title":"Creator ID help","dashboardHelp.openCloudCreatorId.canDo.1":"The default Creator decides which User or Group owns newly uploaded Roblox assets.","dashboardHelp.openCloudCreatorId.needs.1":"For User, sign in to roblox.com, open your profile from your avatar or username, then copy only the number between /users/ and /profile in the browser URL.","dashboardHelp.openCloudCreatorId.needs.2":"For Group, open the Roblox group or community page, then copy only the number after /groups/ or /communities/ in the browser URL.","dashboardHelp.openCloudCreatorId.needs.3":"Paste only the numeric ID in Creator ID. Do not paste the full URL, rbxassetid://, User, or Group text.","dashboardHelp.openCloudCreatorId.link.creatorId":"Creator ID reference","dashboardHelp.openCloudCreatorId.link.userId":"User ID reference","dashboardHelp.openCloudCreatorId.link.groups":"Roblox groups","dashboardHelp.openCloudCreatorId.link.groupsApi":"Groups Cloud API","assets.settings.apiKey.inlineHelp":"WEPPY uses this key only for Roblox Open Cloud requests. The key is encrypted on this device and is not sent to WEPPY servers or stored in any other external storage.","assets.settings.creatorId.inlineHelp":"Default owner for new Roblox assets: your User ID or a Group ID.","common.close":"Cerrar","dashboardHelp.section.currentState":"Check based on current status","dashboardHelp.overview.currentState.serverOnly":"Open Roblox Studio and start WEPPY Plugin so live place data can appear.","dashboardHelp.overview.currentState.default":"If the server disconnects, restart MCP or wait for the automatic reconnect.","dashboardHelp.connection.currentState.1":"If Plugin is missing, open Roblox Studio and run WEPPY Plugin. If AI Agent is missing, reconnect the MCP server from your AI tool.","dashboardHelp.sync.currentState.pluginMissing":"Connect WEPPY Plugin in Studio before using live sync details.","dashboardHelp.sync.currentState.basic":"Activate Pro to use bidirectional or reverse sync.","dashboardHelp.sync.currentState.default":"Use the sync log to diagnose stuck or failed sync activity.","dashboardHelp.assets.currentState.basic":"Activate Pro before uploading to Roblox.","dashboardHelp.assets.currentState.uploadDisabled":"Turn on Open Cloud upload in Assets settings.","dashboardHelp.assets.currentState.noCredential":"Save and test an Open Cloud API Key.","dashboardHelp.assets.currentState.noCreator":"Save a default Creator ID or enter Creator details during upload.","dashboardHelp.assets.currentState.default":"Open an asset detail dialog to start upload or usage scan.","dashboardHelp.changelog.currentState.1":"If the list is empty, ask the AI Agent to make a game change. Clear only deletes saved history records, not Studio objects.","dashboardHelp.playtest.currentState.basic":"Activate Pro to use real Playtest history.","dashboardHelp.playtest.currentState.default":"Ask the AI Agent to run a Playtest when no report is available.","dashboardHelp.uiStudio.currentState.basic":"Activate Pro to use live UI Studio previews.","dashboardHelp.uiStudio.currentState.default":"Ask the AI Agent to capture the UI or recheck improvement suggestions, then copy follow-up requests back to the AI chat.","dashboardHelp.tools.currentState.1":"If no records appear, check Settings > General and confirm history/statistics are enabled. Expand failed rows to inspect input, permission, or connection causes.","dashboardHelp.settings.currentState.1":"Activate a license for Pro features. Change environment values outside WEPPY Dashboard, then restart MCP. Review delete confirmations before clearing saved data.","dashboardHelp.openCloudApiKey.currentState.saved":"Use Test Connection to confirm the saved key still works.","dashboardHelp.openCloudApiKey.currentState.empty":"Create an API key in Roblox Creator Hub, paste it here, then save and test it.","dashboardHelp.openCloudCreatorId.currentState.saved":"Keep this value if new assets should continue using the same owner.","dashboardHelp.openCloudCreatorId.currentState.empty":"Choose User or Group, paste the numeric ID, then save the default Creator.","page.overview.title":"Overview","page.overview.description":"Check server, plugin, agent, sync, and recent game-change status in one place.","page.connection.title":"Connection","page.connection.description":"Inspect MCP server, AI agent, Studio plugin, and connection log status.","page.sync.title":"Sync","page.sync.description":"Monitor Studio to local sync status, direction, apply mode, and recent sync logs.","page.changelog.title":"Changelog","page.changelog.description":"Review game-change sessions captured from AI actions and sync events.","page.playtest.title":"Playtest","page.playtest.description":"Review automated playtest runs, saved reports, and result history.","page.uiStudio.title":"UI Studio","page.uiStudio.description":"Review UI captures, improvement suggestions, and before/after change history.","page.tools.title":"Tools","page.tools.description":"Inspect tool history, outcomes, fallback details, and usage statistics.","page.settings.title":"Settings","page.settings.description":"Manage license, live settings, saved data, server environment, and language.","dashboardHelp.whatsNew.title":"What's New help","dashboardHelp.whatsNew.canDo.1":"Review WEPPY Dashboard, MCP, and Plugin announcements, releases, and change notes.","dashboardHelp.whatsNew.needs.1":"Announcements are bundled locally. Unread state is stored in this browser.","dashboardHelp.whatsNew.currentState.1":"After you visit this page, unread announcements from this visit are marked read when you leave. The top header does not show a duplicate What's New button on this page."},Kf={"sidebar.overview":"Visão Geral","sidebar.changelog":"Histórico","sidebar.connection":"Conexão","sidebar.sync":"Sincronização","sidebar.playtest":"Teste","sidebar.tools":"Ferramentas","sidebar.settings":"Configurações","sidebar.ui_studio":"UI Studio","sidebar.gate.l1":"É necessária conexão com o servidor MCP.","sidebar.gate.l2":"É necessária conexão com o plugin do Roblox Studio.","header.currentProject":"Projeto atual","header.unknownProject":"Projeto desconhecido","header.projectRoot.label":"Project Root","header.currentProject.loading":"Carregando raiz do projeto...","header.currentProject.unavailable":"Raiz do projeto indisponível","header.placeNotConnected":"Place não conectado","header.currentProject.tooltip":"Pasta do projeto atualmente selecionada.","header.currentProject.loading.tooltip":"As informações da raiz do projeto ainda estão carregando.","header.currentProject.unavailable.tooltip":"As informações atuais da raiz do projeto estão indisponíveis.","header.currentProjectSyncRoot.label":"Sync Root","header.currentProjectSyncRoot.loading":"Carregando sync root...","header.currentProjectSyncRoot.unavailable":"Sync root indisponível","header.currentProjectSyncRoot.tooltip":"Pasta sync root atual do projeto selecionado.","header.currentProjectSyncRoot.loading.tooltip":"As informações de sync root ainda estão carregando.","header.currentProjectSyncRoot.unavailable.tooltip":"As informações atuais de sync root estão indisponíveis.","header.testFiles.label":"Test Files","header.testFiles.unavailable":"O caminho dos arquivos de teste está indisponível.","header.testFiles.tooltip":"Diretório atual dos arquivos de playtest para o place selecionado.","header.places.title":"Places","header.places.active":"Active","header.places.inactive":"Inactive","header.places.pluginRequired":"Conexão do plugin necessária","header.places.liveRequired":"A conexão do plugin é necessária para ver o place ativo em tempo real.","header.place.tooltip":"Place do Roblox conectado.","header.placeNotConnected.tooltip":"Place não conectado","header.changeProjectRoot":"Alterar raiz do projeto","header.changeProjectRoot.ariaLabel":"Alterar raiz do projeto","header.changeProjectRoot.tooltip":"Altere a raiz atual do projeto.","header.changeProjectRoot.disabledTooltip.l0":"A conexão com o servidor MCP é necessária primeiro para alterar a raiz do projeto.","header.changeProjectRoot.disabledTooltip.loading":"As informações da raiz do projeto ainda estão carregando.","header.changeProjectRoot.disabledTooltip.unavailable":"As informações atuais da raiz do projeto estão indisponíveis.","header.projectRootModal.initial.title":"Alterar raiz do projeto","header.projectRootModal.initial.body.connected":"Depois que você escolher uma pasta de projeto, o MCP mudará para a nova raiz do projeto e o conteúdo atual do Studio será totalmente resincronizado para o novo destino <selected project folder>/weppy-project-sync.","header.projectRootModal.initial.body.disconnected":"Depois que você escolher uma pasta de projeto, o MCP mudará para a nova raiz do projeto e usará <selected project folder>/weppy-project-sync como o próximo destino de sync.","header.projectRootModal.initial.nextSyncRoot":"Novo destino de sync após a seleção","header.projectRootModal.initial.nextSyncRoot.placeholder":"<selected project folder>/weppy-project-sync","header.projectRootModal.initial.warningStop":"O sync atual é interrompido imediatamente.","header.projectRootModal.initial.warningFreshSync":"O conteúdo atual do Studio será usado para criar um fresh full sync no novo destino.","header.projectRootModal.initial.warningNoMove":"Pastas de sync antigas não são movidas automaticamente.","header.projectRootModal.initial.warningDeferredSync":"Se o Studio não estiver conectado, o full resync começará na próxima conexão do plugin.","header.projectRootModal.confirm.title":"Confirmar nova raiz do projeto","header.projectRootModal.confirm.body":"Revise a pasta selecionada antes de aplicar a mudança.","header.projectRootModal.confirm.projectRoot":"Pasta de projeto selecionada","header.projectRootModal.confirm.syncRoot":"Novo destino do sync","header.projectRootModal.confirm.warningNoMove":"Pastas de sync existentes não são movidas automaticamente.","header.projectRootModal.pick":"Escolher pasta","header.projectRootModal.apply":"Aplicar alteração","header.projectRootModal.cancel":"Cancelar","header.projectRootModal.error":"Não foi possível alterar a raiz do projeto.","status.online":"Online","status.offline":"Offline","status.idle":"Ocioso","status.syncing":"Sincronizando","status.error":"Erro","status.initializing":"Inicializando","level.l0.title":"Servidor desconectado","level.l0.message":"O WEPPY Dashboard está aberto mas o servidor MCP parou ou não está respondendo.","level.l1.title":"Servidor conectado","level.l1.hint":"Verifique: O Roblox Studio está aberto? O plugin está instalado?","level.l2.ok":"Studio conectado","tier.basic":"Basic","tier.basic.tooltip":"Tier Basic com o conjunto padrão de recursos do WEPPY Dashboard.","tier.pro":"Pro","tier.pro.tooltip":"Tier Pro com o conjunto completo de recursos do WEPPY Dashboard.","tier.mixed":"Misto","tier.upgrade":"Ver Pro","tier.banner.save":"Economize tokens de IA com Pro!","tier.tool.query_instances.desc":"Consulta de instâncias, exploração de filhos/descendentes, info de classe, busca por nome e classe. Pro: árvore de arquivos, estrutura do projeto, busca por propriedade e tag.","tier.tool.mutate_instances.desc":"Criar, excluir, clonar, mover, renomear e pivotar instâncias. Pro: criação de árvores, criação/exclusão/duplicação em massa.","tier.tool.manage_properties.desc":"Consultar e definir propriedades, atributos e tags. Pro: valores calculados e relativos, consulta/definição em massa, modificação em massa de filhos.","tier.tool.manage_scripts.desc":"Ler, escrever, criar, excluir, editar linhas e buscar em scripts. Pro: substituição em massa entre scripts.","tier.tool.manage_ui.desc":"Somente Pro. Crie ou refine menus, HUDs, botões, labels e painéis de imagem com estilo de jogo; depois capture telas e revise sugestões.","tier.tool.manage_ui.action.design_brief":"Planejar direção da UI","tier.tool.manage_ui.action.create_tree":"Criar nova UI","tier.tool.manage_ui.action.update":"Atualizar UI existente","tier.tool.manage_ui.action.delete":"Remover UI","tier.tool.manage_ui.action.preview":"Capturar tela da UI","tier.tool.manage_ui.action.check":"Revisar sugestões de melhoria","tier.tool.manage_lighting.desc":"Somente Pro. Configuração de iluminação, atmosfera, céu, propriedades do terreno e hora do dia.","tier.tool.manage_selection.desc":"Consultar, definir e limpar seleção. Pro: contexto, detalhes, adicionar/remover itens, monitorar mudanças.","tier.tool.manage_camera.desc":"Info da câmera, focar por caminho ou coordenadas, visualização sugerida.","tier.tool.manage_tween.desc":"Somente Pro. Criar, reproduzir, pausar e cancelar tweens para animações suaves.","tier.tool.manage_audio.desc":"Somente Pro. Reproduzir, parar, pausar e retomar sons. Configurar listener de áudio.","tier.tool.manage_animation.desc":"Somente Pro. Carregar, reproduzir e parar animações. Consultar tracks de humanoide/controlador.","tier.tool.manage_physics.desc":"Somente Pro. Registrar grupos de colisão, configurar colisão entre grupos, listar grupos.","tier.tool.manage_effects.desc":"Somente Pro. Emitir partículas, limpar todas, alternar ativação de efeitos.","tier.tool.manage_terrain.desc":"Somente Pro. Preencher formas, limpar regiões, substituir materiais, gerenciar cores, ler/escrever voxels, geração procedural, suavização.","tier.tool.spatial_query.desc":"Somente Pro. Raycast, encontrar chão, verificar posicionamento, varredura de área, encontrar áreas planas e pontos de spawn, análise de caminhabilidade, mapa espacial, detecção de colisão.","tier.tool.manage_assets.desc":"Somente Pro. Inserir modelos, consultar info de assets, buscar na loja de criadores, inserir modelos/pacotes gratuitos, exportar.","tier.tool.manage_sync.desc":"Somente Pro. Estado de sincronização, configuração, histórico, direção, leitura/escrita de arquivos sincronizados.","tier.tool.workspace_state.desc":"Somente Pro. Sincronização completa, snapshot, mudanças recentes, info de viewport, metadados, gerenciamento de cache.","tier.tool.manage_logs.desc":"Consulta filtrada de logs, sondagem incremental, limpar buffer, consulta de erros recentes.","tier.tool.system_info.desc":"Estado de conexão, verificação de tier. Pro: info do lugar, lista de serviços, configurações do Studio, controle de playtest, testes automáticos.","tier.tool.manage_studio.desc":"Somente Pro. Alterna ajustes de visualização do editor do Studio, como preview de UI, para capturas e QA; altera a sessão do Studio, não objetos de UI do jogo.","tier.tool.batch_execute.desc":"Somente Pro. Executar múltiplos comandos em lote. Processamento sequencial com opção de continuar em caso de erro.","tier.tool.execute_luau.desc":"Somente Pro. Executar código Luau arbitrário no sandbox do Roblox Studio.","connection.server.title":"Status do servidor","connection.server.version":"Versão","connection.server.version.tooltip":"Versão instalada do servidor MCP.","connection.server.pid":"PID","connection.server.pid.tooltip":"Identificador de processo do sistema operacional.","connection.server.uptime":"Tempo ativo","connection.server.uptime.tooltip":"Tempo decorrido desde que o servidor MCP foi iniciado.","connection.server.session":"Sessão","connection.server.session.tooltip":"Identificador da sessão MCP atual.","connection.server.exec":"Executável","connection.server.exec.tooltip":"Caminho do executável usado para iniciar o servidor MCP.","connection.reconnect":"Reconectar","connection.checkSettings":"Verificar configurações","connection.agents.title":"Agentes IA","connection.agents.name":"Agente","connection.agents.cwd":"Diretório","connection.agents.cwd.tooltip":"Diretório de trabalho atual do agente de IA conectado.","connection.agents.projectRoot":"Raiz do Projeto","connection.agents.projectRoot.tooltip":"Caminho do projeto autoritativo para propriedade de sincronização","connection.agents.projectRoot.unresolved":"Não resolvido","connection.agents.connected":"Conectado","connection.agents.unknown":"Desconhecido","connection.agents.none":"Nenhum agente conectado","connection.plugins.title":"Plugins","connection.plugins.place":"Place","connection.plugins.clientId":"ID do cliente","connection.plugins.clientId.tooltip":"Identificador único do cliente do plugin para esta conexão do Studio.","connection.plugins.lastSeen":"Última vez","connection.plugins.lastSeen.tooltip":"Heartbeat mais recente recebido do plugin.","connection.plugins.version":"Ver","connection.plugins.version.tooltip":"Versão instalada do plugin reportada pelo Studio.","connection.plugins.none":"Nenhum plugin conectado","connection.log.title":"Log de conexão","connection.log.empty":"Nenhum evento","connection.time.secondsAgo":"s atrás","connection.time.minutesAgo":"min atrás","connection.time.hoursAgo":"h atrás","common.loading":"Carregando...","common.retry":"Tentar novamente","common.reconnecting":"Reconectando...","common.expand":"Expandir","common.collapse":"Recolher","tools.tab.history":"Histórico","tools.tab.statistics":"Estatísticas","tools.tab.failures":"Falhas","tools.col.time":"Hora","tools.col.time.tooltip":"Momento em que a execução da ferramenta foi registrada.","tools.col.toolAction":"Ferramenta.Ação","tools.col.toolAction.tooltip":"Nome da ferramenta e ação executada.","tools.col.duration":"Duração","tools.col.duration.tooltip":"Quanto tempo a ferramenta levou para terminar.","tools.col.status":"Status","tools.col.status.tooltip":"Resultado da execução registrada da ferramenta.","tools.col.tier":"Nível","tools.col.tier.tooltip":"Nível de licença exigido para a ferramenta ou ação.","tools.col.tierStats.tooltip":"Resumo Basic, Pro ou Mixed para esta linha de estatísticas da ferramenta.","tools.col.tool":"Ferramenta","tools.col.tool.tooltip":"Nome da ferramenta consolidada na tabela de estatísticas.","tools.col.calls":"Chamadas","tools.col.calls.tooltip":"Número total de chamadas registradas para esta ferramenta.","tools.col.ok":"OK","tools.col.ok.tooltip":"Número de execuções bem-sucedidas diretas.","tools.col.fallback":"FALLBACK","tools.col.fallback.tooltip":"Número de execuções que tiveram sucesso por fallback.","tools.col.unsupported":"UNSUPPORTED","tools.col.unsupported.tooltip":"Número de execuções bloqueadas sem fallback.","tools.col.warn":"WARN","tools.col.warn.tooltip":"Número de falhas esperadas causadas por entrada, estado do projeto, política do Roblox ou código do usuário.","tools.col.err":"FALHOU","tools.col.err.tooltip":"Número de execuções que terminaram em falha.","tools.col.okRate":"% Sucesso","tools.col.okRate.tooltip":"Percentual de chamadas que terminaram com sucesso.","tools.col.avgTime":"Tempo médio","tools.col.avgTime.tooltip":"Tempo médio de execução entre as chamadas registradas.","tools.col.error":"Erro","tools.filter.tool":"Ferramenta","tools.filter.all":"Todos","tools.badge.pro":"PRO","tools.badge.pro.tooltip":"Esta entrada usou uma ferramenta ou ação exclusiva do Pro.","tools.badge.fallback":"FALLBACK","tools.badge.fallback.tooltip":"A ação Pro solicitada teve sucesso por meio de um fallback Basic.","tools.badge.unsupported":"UNSUPPORTED","tools.badge.unsupported.tooltip":"A ação Pro solicitada foi bloqueada e nenhum fallback foi executado.","tools.badge.warn":"WARN","tools.badge.warn.tooltip":"A chamada falhou por um problema esperado de entrada, projeto, política ou código de usuário.","tools.badge.err":"FALHOU","tools.badge.err.tooltip":"A execução da ferramenta falhou.","tools.status.ok":"OK","tools.status.ok.tooltip":"A execução da ferramenta terminou com sucesso.","tools.tier.mixed.tooltip":"Esta ferramenta inclui ações Basic e Pro.","tools.detail.params":"Parâmetros","tools.detail.params.tooltip":"Parâmetros de entrada enviados nesta execução da ferramenta.","tools.detail.result":"Resultado","tools.detail.result.tooltip":"Payload de resultado retornado por esta execução da ferramenta.","tools.detail.requestedCommand":"Comando enviado","tools.detail.executedCommand":"Comando executado","tools.detail.alternatives":"Alternativas","tools.detail.blockedMessage":"Motivo do bloqueio","tools.detail.noFallback":"Sem fallback","tools.detail.noFallback.value":"Nenhum fallback foi executado.","tools.detail.warningMessage":"Mensagem de aviso","tools.detail.errorMessage":"Mensagem de erro","tools.clear.history.title":"Limpar histórico?","tools.clear.history.message":"Isso remove permanentemente o histórico de ferramentas do place atual.","tools.clear.statistics.title":"Limpar estatísticas?","tools.clear.statistics.message":"Isso redefine permanentemente as estatísticas de ferramentas do place atual.","tools.detail.error":"Erro","tools.page.prev":"Anterior","tools.page.prev.tooltip":"Ir para a página anterior do histórico de ferramentas.","tools.page.next":"Próximo","tools.page.next.tooltip":"Ir para a próxima página do histórico de ferramentas.","tools.empty.history":"Nenhuma entrada no histórico","tools.empty.stats":"Sem estatísticas","tools.empty.failures":"Sem falhas","tools.summary.total":"Total","tools.summary.calls":"chamadas","tools.summary.sessions":"Sessões","settings.license.title":"Licença","settings.license.title.tooltip":"Status atual da licença e nível de assinatura.","settings.license.status":"Status","settings.license.status.tooltip":"Estado atual de ativação da licença.","settings.license.tier":"Nível","settings.license.tier.tooltip":"Nível de assinatura atual para os recursos disponíveis do WEPPY Dashboard.","settings.license.key":"Chave","settings.license.key.tooltip":"Chave de licença mascarada atualmente carregada pelo servidor.","settings.license.keyValue.tooltip":"Chave de licença mascarada atualmente carregada pelo servidor.","settings.license.provider":"Provedor","settings.license.provider.auto":"auto","settings.license.provider.polar":"polar","settings.license.provider.gumroad":"gumroad","settings.license.provider.tooltip":"Provedor de licença usado para validar esta chave.","settings.license.providerValue.tooltip":"Provedor de licença usado para validar esta chave.","settings.license.active":"Ativa","settings.license.active.tooltip":"Estado atual de ativação da licença.","settings.license.status.activeCancelPending.tooltip":"O cancelamento está pendente, mas o acesso Pro permanece ativo até o fim do ciclo de cobrança atual.","settings.license.inactive":"Inativa","settings.license.inactive.tooltip":"Estado atual de ativação da licença.","settings.license.expired":"Expirada","settings.license.expired.tooltip":"Estado atual de ativação da licença.","settings.license.unavailable":"Informações de licença indisponíveis","settings.license.detail.cancelPending":"O cancelamento foi agendado. O acesso Pro permanece ativo até o fim do ciclo de cobrança atual.","settings.license.reset":"Redefinir licença","settings.readOnly":"Somente leitura","settings.readOnly.tooltip":"Esta seção mostra valores que não podem ser editados pelo WEPPY Dashboard.","settings.unavailable":"Configurações indisponíveis","settings.general.title":"Configurações gerais","settings.general.title.tooltip":"Configurações quentes que são aplicadas imediatamente ao mudar.","settings.general.liveApply":"Aplicar ao vivo","settings.general.liveApply.tooltip":"As mudanças nesta seção são aplicadas imediatamente sem um botão separado de salvar.","settings.general.applied":"Aplicado","settings.general.logLevel":"Nível de log","settings.general.logLevel.tooltip":"Define quanto detalhe o WEPPY Dashboard escreve nos logs.","settings.general.localHistory":"Registro de histórico","settings.general.localHistory.tooltip":"Armazena o histórico local de execução de ferramentas para as telas de histórico do WEPPY Dashboard.","settings.general.localStatistics":"Coleta de estatísticas","settings.general.localStatistics.tooltip":"Agrega estatísticas locais de uso para os relatórios do WEPPY Dashboard.","settings.general.contextCapture":"Context Capture","settings.general.contextCapture.tooltip":"When enabled, the WEPPY Dashboard records structured execution context for changelog and playtest views.","settings.general.requestTimeout":"Tempo limite","settings.general.requestTimeout.tooltip":"Tempo máximo que o WEPPY Dashboard espera uma ação antes de falhar.","settings.general.requestTimeout.unit":"ms","settings.general.requestTimeout.unit.tooltip":"O tempo limite da ação é medido em milissegundos.","settings.cold.title":"Ambiente do servidor","settings.cold.title.tooltip":"Valores de ambiente do servidor somente leitura carregados na inicialização.","settings.cold.httpPort.tooltip":"Número da porta usada pelo servidor HTTP do WEPPY Dashboard MCP.","settings.cold.httpHost.tooltip":"Interface de host à qual o servidor HTTP do WEPPY Dashboard MCP se vincula.","settings.cold.dashboardAutoOpen.tooltip":"Controla se o WEPPY Dashboard abre automaticamente no navegador quando o servidor inicia.","settings.cold.dashboardAutoOpen.value.tooltip":"Comportamento atual de inicialização para abrir o WEPPY Dashboard no navegador.","settings.cold.hint":"Configure via variáveis de ambiente.","settings.language.title":"Idioma","settings.language.title.tooltip":"Escolha como o texto da interface do WEPPY Dashboard é localizado.","settings.language.dashboard":"Idioma do WEPPY Dashboard","settings.language.dashboard.tooltip":"Substitui o idioma do WEPPY Dashboard ou segue o idioma do sistema quando definido como Automático.","settings.language.auto":"Automático","overview.l0.title":"Servidor MCP desconectado","overview.l0.message":"O servidor MCP não está respondendo. O WEPPY Dashboard tentará reconectar automaticamente.","overview.l0.step1":"Verifique se o processo do servidor MCP está em execução","overview.l0.step2":"Reinicie o comando do servidor MCP se necessário","overview.l0.reconnecting":"Reconectando automaticamente a cada 3s...","overview.l0.reconnectBtn":"Reconectar","overview.l0.settingsBtn":"Verificar configurações","overview.l1.pluginGuide":"O plugin do Roblox Studio não está conectado","overview.l1.check1":"O Roblox Studio está aberto?","overview.l1.check2":"O WEPPY Plugin está instalado?","overview.l1.feedHint":"As alterações aparecerão aqui quando o plugin se conectar","overview.metric.server":"Servidor","overview.metric.server.tooltip":"Status de execução e processo do servidor MCP.","overview.metric.plugin":"Plugin","overview.metric.plugin.tooltip":"Status de conexão e versão do plugin do Roblox Studio.","overview.metric.agent":"Agente","overview.metric.agent.tooltip":"Agentes de IA conectados e seu estado atual.","overview.metric.agent.instancesUnit":"instâncias","overview.metric.sync":"Sincronização","overview.metric.sync.tooltip":"Atividade atual de sincronização entre Studio e arquivos locais.","overview.metric.noAgent":"Sem agente","overview.meta.version":"Versão","overview.meta.version.tooltip":"Versão instalada do servidor MCP.","overview.meta.session":"Sessão","overview.meta.session.tooltip":"Identificador da sessão MCP atual.","overview.meta.pid":"PID","overview.meta.pid.tooltip":"Identificador de processo do sistema operacional.","overview.meta.uptime":"Tempo ativo","overview.meta.uptime.tooltip":"Tempo decorrido desde que o servidor MCP foi iniciado.","overview.feed.title":"Alterações recentes do jogo","overview.feed.empty":"Sem alterações recentes","overview.changelog.title":"Resumo de alterações da sessão","overview.changelog.entries":"Total","overview.changelog.scripts":"scripts","overview.changelog.instances":"instâncias","overview.changelog.properties":"propriedades","overview.changelog.assets":"assets","overview.tier.title":"Uso por nível","changelog.subtitle":"Histórico de alterações do jogo","changelog.filter.all":"Todos","changelog.filter.active":"Ativo","changelog.filter.completed":"Concluído","changelog.empty":"Nenhuma entrada no histórico","changelog.basic.limit.title":"A prévia Basic mostra apenas as 3 sessões mais recentes","changelog.basic.limit.body":"Faça upgrade para Pro para navegar pela linha do tempo completa do changelog deste place.","changelog.basic.metricLabel":"Changelog visível / Total","changelog.basic.visible":"visíveis","changelog.basic.total":"total","changelog.card.active":"Ativo","changelog.card.active.tooltip":"Esta sessão ainda está recebendo novas alterações do jogo.","changelog.card.completed":"Concluído","changelog.card.completed.tooltip":"Esta sessão terminou e não deve receber mais alterações.","changelog.card.bootstrapStatus":"Inicialização","changelog.card.bootstrapStatus.tooltip":"Esta sessão contém apenas o snapshot inicial de bootstrap da sincronização.","changelog.card.inProgress":"em andamento","changelog.card.noChanges":"Sem alterações ainda","changelog.card.noChanges.tooltip":"Ainda não foram extraídas alterações do jogo para esta sessão.","changelog.card.bootstrapSummary":"Snapshot de sincronização inicial","changelog.card.bootstrapSummary.tooltip":"As gravações da sincronização inicial de arquivos são condensadas em uma única linha de snapshot bootstrap.","changelog.card.sessionIntent":"Session intent","changelog.card.scripts":"scripts","changelog.card.scripts.tooltip":"Alterações de script feitas nesta sessão.","changelog.card.instances":"instâncias","changelog.card.instances.tooltip":"Alterações de criação, exclusão, movimentação ou clonagem de instâncias nesta sessão.","changelog.card.modified":"modificado","changelog.card.created":"criado","changelog.card.deleted":"excluído","changelog.card.moved":"movido","changelog.card.propertiesChanged":"propriedades alteradas","changelog.card.propertiesChanged.tooltip":"Alterações de valores de propriedades registradas para esta sessão.","changelog.card.lightingConfigured":"Iluminação configurada","changelog.card.lightingConfigured.tooltip":"A iluminação ou a atmosfera foram alteradas nesta sessão.","changelog.card.terrainConfigured":"Terreno configurado","changelog.card.terrainConfigured.tooltip":"Os dados ou as configurações de terreno foram alterados nesta sessão.","changelog.card.assetsInserted":"assets inseridos","changelog.card.assetsInserted.tooltip":"Assets inseridos no place durante esta sessão.","changelog.category.script":"Scripts","changelog.category.instance":"Instâncias","changelog.category.property":"Propriedades","changelog.category.lighting":"Iluminação","changelog.category.terrain":"Terreno","changelog.category.asset":"Assets","changelog.detail.changeSummary":"Resumo de alterações","changelog.detail.changeSummary.tooltip":"Contagem de alterações do jogo extraídas e agrupadas por categoria nesta sessão.","changelog.detail.changeTimeline":"Linha do tempo","changelog.detail.changeTimeline.tooltip":"Lista cronológica das alterações do jogo extraídas para esta sessão.","changelog.detail.context.title":"Context Summary","changelog.detail.context.tooltip":"Structured execution context captured for this changelog session.","changelog.detail.verification.title":"Verification","changelog.detail.verification.tooltip":"Verification signals linked to this changelog session.","changelog.detail.verification.label":"Result","changelog.detail.verification.status":"Status","changelog.detail.verification.timestamp":"Recorded at","changelog.detail.beforeAfter":"Antes e depois","changelog.detail.filterCategory":"Categoria","changelog.detail.filterCategory.tooltip":"Filtra a linha do tempo para uma única categoria de alteração.","changelog.detail.confidence.exact":"Exato","changelog.detail.confidence.exact.tooltip":"Os estados antes e depois desta alteração foram confirmados.","changelog.detail.confidence.partial":"Parcial","changelog.detail.confidence.partial.tooltip":"Apenas parte dos estados antes e depois desta alteração pôde ser confirmada.","changelog.detail.confidence.afterOnly":"Somente depois","changelog.detail.confidence.afterOnly.tooltip":"Apenas o estado resultante após a alteração pôde ser confirmado.","changelog.detail.confidence.intentOnly":"Somente intenção","changelog.detail.confidence.intentOnly.tooltip":"Apenas a ação solicitada foi registrada, não o estado resultante.","changelog.detail.confidence.unknown":"Desconhecido","changelog.detail.confidence.unknown.tooltip":"Não foi possível classificar esta alteração com confiança a partir dos dados disponíveis.","changelog.detail.noChanges":"Sem alterações nesta categoria","changelog.detail.backToList":"Voltar à lista","changelog.diff.empty":"Sem diferenças disponíveis","changelog.diff.unified":"Unificado","changelog.diff.sideBySide":"Lado a lado","changelog.diff.before":"Antes","changelog.diff.after":"Depois","sync.overlay.title":"Plugin do Roblox Studio necessário","sync.overlay.message":"O status de sincronização estará disponível quando o plugin do Roblox Studio se conectar.","sync.overlay.check1":"O Roblox Studio está aberto?","sync.overlay.check2":"O WEPPY Plugin está instalado?","sync.status.title":"Status de sincronização","sync.status.title.tooltip":"Status atual de sincronização entre o Studio e os arquivos locais deste place.","sync.status.forwardOnly":"Somente avanço","sync.status.forwardOnly.tooltip":"O tier Basic permite apenas sincronização direta do Studio para o local.","sync.status.place":"Place","sync.status.place.tooltip":"Nome e ID do place do Roblox atualmente conectado.","sync.status.path":"Caminho","sync.status.path.tooltip":"Raiz do sistema de arquivos local usada atualmente para a saída de sincronização.","sync.status.instances":"Instâncias","sync.status.instances.tooltip":"Total de instâncias do Roblox sincronizadas no espelho local.","sync.status.scripts":"Scripts","sync.status.scripts.tooltip":"Total de arquivos de script atualmente indexados para este place.","sync.status.state":"Estado","sync.status.state.tooltip":"Estado atual de execução da sincronização informado pelo servidor.","sync.directions.title":"Direções de sincronização","sync.directions.title.tooltip":"Direção e modo de aplicação por categoria entre Local e Studio.","sync.directions.type":"Tipo","sync.directions.type.tooltip":"Categoria de sincronização afetada por esta regra.","sync.directions.direction":"Direção","sync.directions.direction.tooltip":"Indica se cada categoria sincroniza do Studio, para o Studio ou nos dois sentidos.","sync.directions.applyMode":"Modo de aplicação","sync.directions.applyMode.tooltip":"Como as mudanças de sincronização recebidas são aplicadas nesta categoria.","sync.directions.cat.scripts":"Scripts","sync.directions.cat.values":"Valores","sync.directions.cat.containers":"Contêineres","sync.directions.cat.data":"Dados","sync.directions.cat.services":"Serviços","sync.directions.endpoint.local":"Local","sync.directions.endpoint.local.tooltip":"Os arquivos locais em disco sempre aparecem no lado esquerdo da régua de direção.","sync.directions.endpoint.studio":"Studio","sync.directions.endpoint.studio.tooltip":"O Roblox Studio sempre aparece no lado direito da régua de direção.","sync.directions.mode.manual":"Manual","sync.directions.mode.manual.tooltip":"Aplica as mudanças de sincronização apenas quando você dispara manualmente.","sync.directions.mode.auto":"Auto","sync.directions.mode.auto.tooltip":"Aplica as mudanças de sincronização automaticamente quando chegam atualizações.","sync.directions.tooltip.forward.body":"As mudanças do Studio sincronizam apenas para os arquivos locais","sync.directions.tooltip.bidirectional.body":"Sincronização de mão dupla entre Local e Studio","sync.directions.tooltip.reverse.body":"Envia mudanças dos arquivos locais para o Studio","sync.directions.tooltip.proRequired":"Pro é necessário no tier Basic","sync.directions.dir.forward":"adiante","sync.directions.dir.bidirectional":"bidirecional","sync.directions.dir.reverse":"reverso","sync.log.title":"Log de sincronização","sync.log.empty":"Sem eventos de sincronização","sync.log.type.write":"ESCREVER","sync.log.type.write.tooltip":"Uma nova saída de sincronização foi gravada no disco.","sync.log.type.update":"ATUALIZAR","sync.log.type.update.tooltip":"Um arquivo ou uma instância já sincronizada foi atualizada.","sync.log.type.delete":"EXCLUIR","sync.log.type.delete.tooltip":"Um arquivo ou uma instância sincronizada foi removida.","sync.log.type.idle":"OCIOSO","sync.log.type.idle.tooltip":"Um evento de sincronização foi registrado sem alterar arquivos.","sync.upgrade.title":"Veja a sincronização completa com Pro","sync.upgrade.benefit1":"Sincronização bidirecional — edite arquivos, aplicação automática no Studio","sync.upgrade.benefit2":"Sincronização reversa — envie alterações de arquivos para o Studio","sync.upgrade.benefit3":"Histórico completo de sincronização e registro detalhado de alterações","sync.upgrade.buy":"Ver Pro","playtest.status.title":"Status de teste","playtest.status.title.tooltip":"Estado atual da sessão de playtest do Roblox informado pelo Studio.","playtest.status.mode":"Modo","playtest.status.mode.tooltip":"Modo de inicialização do playtest do Studio para a sessão atual.","playtest.status.mode.value.tooltip":"Modo específico de playtest do Roblox Studio atualmente em uso.","playtest.status.mode.play":"Jogar","playtest.status.mode.run":"Executar","playtest.status.mode.server":"Servidor","playtest.status.mode.edit":"Editar","playtest.status.place.tooltip":"Place do Roblox atualmente associado a esta sessão de playtest.","playtest.status.state.running":"Executando","playtest.status.state.running.tooltip":"Uma sessão de playtest do Roblox está em execução no momento.","playtest.status.state.paused":"Pausado","playtest.status.state.paused.tooltip":"A sessão atual de playtest do Roblox está pausada.","playtest.status.state.notRunning":"Não está em execução","playtest.status.state.notRunning.tooltip":"Nenhuma sessão de playtest do Roblox está em execução no momento.","playtest.control.play":"Jogar","playtest.control.pause":"Pausar","playtest.control.resume":"Retomar","playtest.control.stop":"Parar","playtest.history.title":"Histórico de testes","playtest.history.title.tooltip":"Execuções automatizadas de playtest registradas para este projeto.","playtest.history.empty":"Sem resultados de teste","playtest.history.mode":"Modo","playtest.history.mode.tooltip":"Modo de playtest usado nesta execução de teste registrada.","playtest.history.status.passed":"Aprovado","playtest.history.status.failed":"Falhou","playtest.history.status.running":"Executando","playtest.history.status.unknown":"Desconhecido","playtest.history.status.tooltip":"Estado de resultado registrado para esta execução automatizada de playtest.","playtest.empty.title":"Sem resultados de teste ainda","playtest.empty.message":"Os resultados aparecerão aqui depois que o agente de IA executar um Playtest.","playtest.empty.message.before":"Os resultados aparecerão aqui depois que o agente de IA executar um Playtest.","playtest.empty.message.after":"","playtest.empty.runTest.tooltip":"Ask the AI Agent to run a Playtest when you need a fresh report.","playtest.report.title":"Relatório selecionado","playtest.report.title.tooltip":"Saída detalhada da execução automatizada de playtest atualmente selecionada.","playtest.report.content":"Relatório","playtest.report.content.tooltip":"Resumo em Markdown da execução automatizada de playtest selecionada.","playtest.report.logs":"Logs","playtest.report.logs.tooltip":"Logs de execução capturados para a execução automatizada de playtest selecionada.","playtest.context.contextId":"Context ID","playtest.context.why":"Why this test ran","playtest.context.expected":"Expected","playtest.context.observed":"Observed","playtest.report.empty":"Sem conteúdo de relatório","playtest.basic.icon":"🎮","playtest.basic.title":"Playtest é uma função exclusiva do Pro","playtest.basic.desc":"Controle os testes pelo WEPPY Dashboard, execute testes automatizados e visualize relatórios detalhados.","playtest.basic.benefit1":"Controles de jogar/pausar/parar com um clique","playtest.basic.benefit2":"Execução de testes automatizados via agente IA","playtest.basic.benefit3":"Histórico de testes com rastreamento de sucesso/falha","playtest.basic.benefit4":"Relatórios de teste detalhados em markdown","playtest.sample.badge":"Prévia da tela de playtest Pro","playtest.sample.title":"Você está vendo uma prévia da tela de playtest disponível após o upgrade para Pro.","playtest.sample.message":"Esta prévia usa dados de exemplo. Controle de playtest ao vivo, gerenciamento de histórico e relatórios reais são liberados com Pro.","playtest.sample.clearDisabled":"Faça upgrade para Pro para limpar o histórico real de playtest.","playtest.sample.place":"Prévia da Arena","playtest.sample.history.name":"Teste de fumaça da Arena de exemplo","playtest.sample.context.why":"Entrar na arena, sobreviver à abertura e verificar se o HUD responde imediatamente.","playtest.sample.context.expected":"O jogador surge com segurança, a contagem regressiva do HUD aparece em um segundo e a primeira onda começa sem erros.","playtest.sample.context.observed":"A proteção de spawn funcionou, o HUD atualizou no tempo certo e a primeira onda terminou sem regressões.","playtest.sample.report.markdown":`# Teste de fumaça da Arena de exemplo
100
+
101
+ - Fluxo de spawn: PASS
102
+ - Contagem do HUD: PASS
103
+ - Início da onda: PASS
104
+
105
+ Isto é uma prévia de amostra. Faça upgrade para Pro para executar playtests ao vivo e salvar relatórios reais.`,"playtest.sample.report.logs":`[sample] iniciar prévia de playtest
106
+ [sample] proteção de spawn ativa
107
+ [sample] contagem do hud renderizada
108
+ [sample] primeira onda concluída
109
+ [sample] relatório de amostra finalizado`,"sidebar.whatsNew":"Novidades","sidebar.help.group":"Ajuda e feedback","sidebar.help.bug":"Reportar um bug","sidebar.help.bug.tooltip":"Criar um pacote de diagnostico local e abrir um relatorio de bug preenchido no GitHub","bugReportDialog.title":"diagnostics.zip pode ajudar na investigação","bugReportDialog.subtitle":"O WEPPY criou um zip de diagnóstico neste computador. Ele inclui logs do Studio, plugin, Sync e ferramentas que podem ajudar a entender o que aconteceu.","bugReportDialog.close":"Close","bugReportDialog.loading":"Preparing diagnostics.zip...","bugReportDialog.error":"Could not create the diagnostics bundle. You can still open GitHub without diagnostics.","bugReportDialog.bundle":"Bundle","bugReportDialog.included":"Included","bugReportDialog.included.none":"No log files found","bugReportDialog.optional":"Você pode enviar o bug report sem este arquivo, mas anexar o zip geralmente ajuda a encontrar a causa mais rápido.","bugReportDialog.attachHow":"Para anexar, baixe ou revele o zip e adicione-o ao campo Diagnostics ZIP (optional) da issue do GitHub antes de enviar.","bugReportDialog.download":"1. Baixar diagnostics.zip","bugReportDialog.reveal":"Reveal in Finder","bugReportDialog.reveal.opening":"Opening...","bugReportDialog.reveal.opened":"Opened location","bugReportDialog.reveal.failed":"Could not open the file location.","bugReportDialog.openGithub":"2. Abrir issue no GitHub","bugReportDialog.openGithubFallback":"Open GitHub without diagnostics","bugReportDialog.retry":"Try again","bugReportDialog.hint":"O zip pode conter logs locais e contexto do projeto. Revise-o antes de anexar se quiser compartilhar.","sidebar.help.feature":"Sugerir um recurso","sidebar.help.feature.tooltip":"Sugerir um novo recurso ou melhoria no GitHub","sidebar.help.discussions":"Suporte","sidebar.help.discussions.tooltip":"Fazer perguntas ou pedir ajuda de instalacao no GitHub Issues","sidebar.help.troubleshooting":"Solução de problemas","sidebar.help.troubleshooting.tooltip":"Abrir o guia oficial de solução de problemas no weppyai.com","header.whatsNew":"Novidades","header.whatsNew.tooltip":"Novidades","upgrade.title":"Ver Pro","upgrade.tagline":"Confira os recursos Pro","upgrade.cta":"Ver Pro","upgrade.licenseShortcut":"Inserir licença","upgrade.validUntil":"Until {{date}}","whatsNew.pageTitle":"Novidades","whatsNew.pageSubtitle":"Fique por dentro das mudanças do MCP","whatsNew.unreadSection":"Não lidos","whatsNew.allSection":"Todos os anúncios","whatsNew.empty":"Nenhum anúncio ainda","whatsNew.newBadge":"NOVO","whatsNew.category.release":"Versão","whatsNew.category.notice":"Aviso","whatsNew.category.deprecation":"Descontinuado","whatsNew.category.tip":"Dica","uiStudio.title":"UI Studio","uiStudio.empty":"Ainda não há capturas de tela salvas. Elas são criadas automaticamente quando um agente de IA captura o estado atual da UI.","uiStudio.loading":"Loading…","uiStudio.pluginGuide.title":"O plugin do Roblox Studio não está conectado","uiStudio.pluginGuide.message":"O UI Studio mostra capturas de tela e histórico de alterações do place do Studio conectado. Ele será atualizado automaticamente quando o Studio e o WEPPY Plugin se conectarem.","uiStudio.pluginGuide.check1":"O Roblox Studio está em execução?","uiStudio.pluginGuide.check2":"O WEPPY Plugin está instalado e em execução?","uiStudio.pluginGuide.waiting":"Aguardando conexão do plugin...","uiStudio.capturedAt":"Captured at","uiStudio.scope":"Scope","uiStudio.target":"Target","uiStudio.briefId":"Brief ID","uiStudio.detailClose":"Close","uiStudio.colCheck":"Check","uiStudio.colPriority":"Priority","uiStudio.colCurrent":"Current","uiStudio.colRecommended":"Recommended","uiStudio.colSuggestion":"Suggestion","uiStudio.priorityHigh":"Revisar primeiro","uiStudio.priorityLow":"Melhoria opcional","uiStudio.highPrioritySection":"Revisar primeiro","uiStudio.lowPrioritySection":"Melhorias opcionais","uiStudio.groupSummary":"items","uiStudio.fixLabel":"Fix","uiStudio.copyFixCommand":"Copy AI instruction","uiStudio.copiedToClipboard":"Copied","uiStudio.fullPath":"Full path","uiStudio.falsePositiveWarning":"This group may contain false positives","uiStudio.noSuggestions":"No current improvement suggestions","uiStudio.sample.badge":"Preview of the Pro UI Studio","uiStudio.sample.title":"You are previewing the UI Studio that unlocks after upgrading to Pro.","uiStudio.sample.message":"This preview uses sample data from a demo inventory UI. Real screenshots, review history, and AI-driven fixes unlock with Pro.","uiStudio.tabs.analysis":"Análise","uiStudio.tabs.history":"Histórico","uiStudio.analysis.reportsTitle":"Última análise por destino de UI","uiStudio.analysis.recentCapturesTitle":"Capturas recentes","uiStudio.analysis.detailDialog":"Detalhes da análise","uiStudio.analysis.targetCountLabel":"Destinos analisados","uiStudio.analysis.captureLabel":"Capturas","uiStudio.analysis.verdict.hasSuggestions":"Sugestões de melhoria","uiStudio.analysis.verdict.needsFix":"Sugestões de melhoria","uiStudio.analysis.verdict.review":"Sugestões de melhoria","uiStudio.analysis.verdict.passed":"Sem sugestões atuais","uiStudio.analysis.verdictLabel":"Resumo de melhorias","uiStudio.analysis.thresholds":"Base de revisão","uiStudio.analysis.issueSummary.passed":"Não há sugestões adicionais com a base de revisão atual.","uiStudio.history.title":"Histórico de Alterações","uiStudio.history.empty":"Ainda não há histórico de alterações. Quando um agente de IA modificar a UI com manage_ui, será registrado automaticamente.","uiStudio.history.loading":"Carregando...","uiStudio.history.error":"Erro","uiStudio.history.clear":"Limpar tudo","uiStudio.history.filter.actions":"Tipo de ação","uiStudio.history.filter.actionAll":"Tudo","uiStudio.history.filter.actionCreate":"Criar","uiStudio.history.filter.actionUpdate":"Atualizar","uiStudio.history.filter.actionDelete":"Excluir","uiStudio.history.filter.period":"Período","uiStudio.history.filter.dateAll":"Tudo","uiStudio.history.filter.today":"Hoje","uiStudio.history.filter.yesterday":"Ontem","uiStudio.history.filter.last7Days":"Últimos 7 dias","uiStudio.history.filter.last30Days":"Últimos 30 dias","uiStudio.history.filter.customRange":"Intervalo personalizado","uiStudio.history.filter.reset":"Redefinir","uiStudio.history.filter.from":"De","uiStudio.history.filter.to":"Até","uiStudio.history.row.affectedPaths":"Caminhos","uiStudio.history.row.mutations":"Detalhes de alterações","uiStudio.history.row.expand":"▾ Expandir","uiStudio.history.row.collapse":"▲ Recolher","uiStudio.history.row.expandDetails":"Mostrar {n} alterações","uiStudio.history.row.collapseDetails":"Ocultar alterações","uiStudio.history.row.toggleDetails":"Alternar detalhes das alterações","uiStudio.history.row.mutationsEmpty":"Sem detalhes de alterações","uiStudio.history.row.toolLabel":"Alterações de UI ({n})","uiStudio.history.row.compare":"Antes / Depois","uiStudio.history.row.noBeforeState":"Sem estado anterior","uiStudio.history.row.noAfterState":"Sem estado posterior","uiStudio.history.row.qualityPlan":"Direção de design","uiStudio.history.row.designCheck":"Sugestões","uiStudio.history.row.designCheckUnavailable":"Sugestões: indisponível","uiStudio.history.row.designCheckNone":"Sugestões: nenhuma","uiStudio.history.selection.deleteSelected":"Excluir selecionados","uiStudio.history.selection.selectAll":"Selecionar tudo","uiStudio.history.selection.clearSelection":"Limpar seleção","uiStudio.history.confirm.deleteRequestsTitle":"Excluir registros de alterações","uiStudio.history.confirm.deleteRequestsMessage":"Os registros de alterações selecionados serão excluídos. Esta ação não pode ser desfeita.","uiStudio.history.confirm.clearRequestsTitle":"Limpar Histórico de Alterações","uiStudio.history.confirm.clearRequestsMessage":"Isso limpa o histórico de alterações do place atual. As instâncias do Studio não são afetadas.","uiStudio.history.confirm.cascadeOption":"Também excluir capturas vinculadas","uiStudio.history.drawer.close":"Fechar","uiStudio.actions.previewAgain":"Pré-visualizar Novamente","uiStudio.actions.deleteSnapshot":"Excluir Esta Captura de Tela","uiStudio.actions.proRequired":"Disponível após atualizar para o Pro","uiStudio.actions.captureCurrentState":"Capturar estado atual","uiStudio.actions.checkSuggestionsAgain":"Reverificar sugestões","uiStudio.actions.previewRunning":"Capturando…","uiStudio.actions.previewRunningDetail":"O ID do novo arquivo de captura de tela aparecerá ao finalizar.","uiStudio.actions.previewNeedsSaveCheck":"Captura concluída, verifique o salvamento","uiStudio.actions.previewSaved":"Nova captura de tela salva","uiStudio.actions.previewComplete":"Captura concluída","uiStudio.actions.previewSavedDetail":"As capturas existentes foram mantidas; esta foi salva como um novo arquivo.","uiStudio.actions.previewSavedPathMissing":"Um novo ID de captura foi retornado, mas o caminho do arquivo salvo não pôde ser confirmado.","uiStudio.actions.previewSnapshotIdMissing":"Não foi possível confirmar o novo ID da captura. Atualize a lista para verificar se ela foi salva.","uiStudio.actions.more":"Mais","uiStudio.gallery.selection.selectedCount":" selecionado(s)","uiStudio.confirm.deleteSnapshotTitle":"Excluir Captura de Tela","uiStudio.confirm.deleteSnapshotMessage":"Apenas este arquivo de captura de tela será excluído (a instância do Studio é preservada).","uiStudio.confirm.deleteBatchTitle":"Excluir Captura de Telas Selecionados","uiStudio.confirm.deleteBatchMessage":"As capturas de tela selecionadas serão excluídas. Esta ação não pode ser desfeita.","uiStudio.gallery.selectMode":"Selecionar","uiStudio.gallery.exitSelectMode":"Cancelar","uiStudio.gallery.selectAll":"Selecionar Tudo","uiStudio.gallery.clearSelection":"Limpar Seleção","uiStudio.gallery.deleteSelected":"Excluir Seleção","common.cancel":"Cancelar","common.delete":"Excluir","uiStudio.storage.title":"Dados salvos do UI Studio","uiStudio.storage.usageLabel":"Em uso","uiStudio.storage.historyBytes":"Histórico","uiStudio.storage.snapshotBytes":"Capturas de tela","uiStudio.storage.requestCount":"Registros de alterações","uiStudio.storage.mutationCount":"Detalhes de alterações","uiStudio.storage.snapshotCount":"Capturas de tela","uiStudio.storage.countSuffix":"","uiStudio.storage.lastRun":"Última limpeza automática","uiStudio.storage.lastRunNever":"—","uiStudio.storage.lastRunFreed":"liberado","uiStudio.storage.lastRunErrors":"Erros","uiStudio.storage.loading":"Carregando...","uiStudio.cleanup.policy.title":"Política de exclusão automática","uiStudio.cleanup.policy.modeOff":"Desativado","uiStudio.cleanup.policy.modeAge":"Por idade","uiStudio.cleanup.policy.modeSize":"Por tamanho","uiStudio.cleanup.policy.cascade":"Também excluir capturas de tela vinculadas","uiStudio.cleanup.policy.save":"Salvar política","uiStudio.cleanup.policy.runNow":"Executar agora","uiStudio.cleanup.policy.proRequired":"Disponível após atualizar para Pro","uiStudio.cleanup.policy.daysUnit":"d","uiStudio.cleanup.policy.mbUnit":"MB","uiStudio.cleanup.policy.gbUnit":"GB","uiStudio.cleanup.policy.confirm.title":"Confirmar política","uiStudio.cleanup.policy.confirm.messageStrict":"Ao aplicar esta política serão excluídos imediatamente","uiStudio.cleanup.policy.confirm.requests":" registros de alterações","uiStudio.cleanup.policy.confirm.snapshots":" capturas de tela","uiStudio.cleanup.policy.confirm.freed":"liberado — Aplicar?","uiStudio.cleanup.keepLastNDays":"Manter últimos {n} dias","uiStudio.cleanup.selectedDelete":"Excluir seleção…","uiStudio.cleanup.deleteAll":"Excluir tudo…","uiStudio.cleanup.cleanupConfirmTitle":"Confirmar limpeza","uiStudio.cleanup.cleanupConfirmMessage":"Os itens selecionados serão excluídos. Esta ação não pode ser desfeita.","uiStudio.cleanup.cleanupConfirmMessage.keep7":"Change records and screenshots older than 7 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.keep30":"Change records and screenshots older than 30 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.all":" saved change records and screenshots will be deleted. This action cannot be undone.","uiStudio.cleanup.label":"Limpeza manual","uiStudio.cleanup.studioPreservedNote":"Esta ação exclui apenas os arquivos de histórico e capturas de tela no disco; as instâncias do Roblox Studio não são afetadas.","uiStudio.history.sample.bannerBadge":"Prévia do histórico de alterações Pro","uiStudio.history.sample.bannerTitle":"Prévia do histórico de alterações Pro","uiStudio.history.sample.bannerMessage":"Esta prévia usa dados de exemplo. O histórico real de alterações, a comparação antes/depois e a exclusão em lote são desbloqueados com o Pro.","uiStudio.fix.touchTarget.label":"Touch target size","uiStudio.fix.touchTarget.description":"Checks whether controls are large enough to tap comfortably on mobile.","uiStudio.fix.touchTarget.howToFix":"Increase button Size to at least 44x44 px or expand the touch area with UIPadding.","uiStudio.fix.contrast.label":"Text contrast","uiStudio.fix.contrast.description":"Checks whether text and background contrast meet accessibility guidance.","uiStudio.fix.contrast.howToFix":"Use a brighter TextColor3 or darken the BackgroundColor3.","uiStudio.fix.contrast.falsePositive":"Emoji icons may be false positives when their color is fixed.","uiStudio.fix.textScaled.label":"TextScaled usage","uiStudio.fix.textScaled.description":"TextScaled without UITextSizeConstraint can break layouts when text expands.","uiStudio.fix.textScaled.howToFix":"Add a UITextSizeConstraint child to the TextLabel and set MaxTextSize.","uiStudio.fix.safezone.label":"Safe-zone placement","uiStudio.fix.safezone.description":"Checks whether controls stay inside platform safe zones.","uiStudio.fix.safezone.howToFix":"Move Position inside the safe zone or reduce the parent Frame.","uiStudio.fix.minTextSize.label":"Minimum font size","uiStudio.fix.minTextSize.description":"Checks whether text is too small to read comfortably.","uiStudio.fix.minTextSize.howToFix":"Increase TextSize to at least 14 for body text.","uiStudio.sample.history.request1.label":"Initial HUD layout creation","uiStudio.sample.history.request2.label":"Inventory modal design update","uiStudio.sample.history.request3.label":"HUD HealthBar color update","uiStudio.sample.history.request4.label":"Expand Inventory tab button touch targets","uiStudio.sample.history.request5.label":"Remove Settings popup","uiStudio.sample.history.request6.label":"Add HUD minimap component","uiStudio.sample.history.request1.mutation1.diff":"Created Frame + HealthBar + StaminaBar","uiStudio.sample.history.request1.mutation2.diff":"BackgroundColor3 -> Color3.new(0.2,0.8,0.2)","uiStudio.sample.history.request1.mutation3.diff":"BackgroundColor3 -> Color3.new(0.1,0.6,1.0)","uiStudio.sample.history.request1.mutation4.diff":"Set AnchorPoint, Position, and Size","uiStudio.sample.history.request1.mutation5.diff":"Screenshot saved","uiStudio.sample.history.request2.mutation1.diff":"Darkened BackgroundColor3 for better contrast","uiStudio.sample.history.request2.mutation2.diff":"TextColor3 -> Color3.new(1,1,1), TextSize 16 -> 18","uiStudio.sample.history.request2.mutation3.diff":"BorderSizePixel 0 -> 2, set BorderColor3","uiStudio.sample.history.request2.mutation4.diff":"Screenshot saved","uiStudio.sample.history.request3.mutation1.diff":"BackgroundColor3 -> Color3.new(0.9,0.2,0.2) (red tone)","uiStudio.sample.history.request3.mutation2.diff":"Screenshot saved","uiStudio.sample.history.request4.mutation1.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation2.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation3.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation4.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation5.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation6.diff":"Screenshot saved","uiStudio.sample.history.request5.mutation1.diff":"Removed ScreenGui (Settings-only UI)","uiStudio.sample.history.request6.mutation1.diff":"Attempted to create Frame + MapImage + PlayerDot","uiStudio.sample.history.request6.mutation2.diff":"Set Size, Position, and BackgroundTransparency","uiStudio.sample.history.request6.mutation3.diff":"Interrupted by server restart while setting ImageLabel","uiStudio.sample.history.request6.mutation4.diff":"Partial screenshot saved","uiStudio.sample.history.request6.mutation3.error":"server_restart: connection lost","uiStudio.sample.history.request6.mutation4.error":"partial screenshot: missing layers","uiStudio.sample.history.detail.backgroundColor":"Background color","uiStudio.sample.history.detail.anchorPoint":"Anchor","uiStudio.sample.history.detail.position":"Position","uiStudio.sample.history.detail.size":"Size","uiStudio.sample.history.detail.textColor":"Text color","uiStudio.sample.history.detail.textSize":"Text size","uiStudio.sample.history.detail.borderSize":"Border size","uiStudio.sample.history.detail.borderColor":"Border color","uiStudio.history.sample.tooltip":"Atualize para Pro para desbloquear o histórico completo","settings.dataHistory.title":"Data & History","settings.dataHistory.title.tooltip":"Manage saved dashboard data in one place.","settings.dataHistory.collapse":"Collapse {title}","settings.dataHistory.expand":"Expand {title}","settings.dataHistory.scope":"Current project","settings.dataHistory.scope.tooltip":"Clear actions apply to the current project and active place where applicable.","settings.dataHistory.intro":"Review saved dashboard data, open the related page, or clear stored records from one place.","settings.dataHistory.toolsActivity.title":"Tool activity","settings.dataHistory.toolsActivity.description":"Saved tool runs shown on the Tools page.","settings.dataHistory.toolStats.title":"Tool usage statistics","settings.dataHistory.toolStats.description":"Aggregated tool counts and status totals.","settings.dataHistory.syncLog.title":"Sync log","settings.dataHistory.syncLog.description":"Saved file sync events for the active place.","settings.dataHistory.playtest.title":"Playtest reports","settings.dataHistory.playtest.description":"Saved automated playtest reports and logs.","settings.dataHistory.projectChanges.title":"Project change summary","settings.dataHistory.projectChanges.description":"Saved summaries of project changes.","settings.dataHistory.connectionLog.title":"Connection log","settings.dataHistory.connectionLog.description":"Saved MCP and Studio connection events.","settings.dataHistory.uiStudio.title":"UI Studio history and screenshots","settings.dataHistory.uiStudio.tooltip":"Manage saved UI Studio change records, screenshots, and auto-delete policy.","settings.dataHistory.uiStudio.description":"Saved UI Studio change records, screenshots, and cleanup policy.","settings.dataHistory.uiStudio.clear.title":"Clear UI Studio saved data?","settings.dataHistory.uiStudio.clear.message":"This deletes saved UI Studio change records and screenshots only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.uiStudio.clear.success":"UI Studio saved data cleared.","settings.dataHistory.uiStudio.clear.failed":"Failed to clear UI Studio saved data.","settings.dataHistory.metric.unavailable":"Unavailable","settings.dataHistory.metric.sizeUnavailable":"size unavailable","settings.dataHistory.metric.records":"records","settings.dataHistory.metric.runs":"runs","settings.dataHistory.metric.sessions":"sessions","settings.dataHistory.metric.reports":"reports","settings.dataHistory.open":"Open","settings.dataHistory.clear.title":"Clear saved data?","settings.dataHistory.clear.message":"This deletes saved dashboard records only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.clear.success":"Saved data cleared.","settings.dataHistory.clear.failed":"Failed to clear saved data.","toast.serverConnected":"Servidor MCP conectado","toast.serverDisconnected":"Servidor MCP desconectado","toast.pluginConnected":"Plugin conectado","toast.pluginDisconnected":"Plugin desconectado","toast.clearSuccess":"Limpado com sucesso","toast.clearFailed":"Falha ao limpar os dados","common.clear":"Limpar","settings.license.activate":"Ativar licença","settings.license.refresh":"Atualizar licença","settings.license.keyInput":"Chave de licença","settings.license.disconnected":"Desconectado","settings.license.disconnected.tooltip":"Reconecte ao servidor MCP para gerenciar a licença pelo WEPPY Dashboard.","settings.license.live.tooltip":"As ações de licença são enviadas imediatamente ao servidor MCP.","settings.license.status.activationRequired":"Ativação necessária","settings.license.status.activationRequired.tooltip":"É necessária ativação manual da licença antes que o WEPPY Dashboard possa atualizar este status.","settings.license.status.grace":"Tolerância","settings.license.status.grace.tooltip":"A verificação do provedor está temporariamente indisponível, mas o acesso Pro permanece ativo durante o período de tolerância.","settings.license.status.graceBilling.tooltip":"O acesso Pro continua disponível durante um período de tolerância relacionado à cobrança.","settings.license.detail.graceBilling":"O acesso Pro continua disponível durante um período de tolerância de cobrança.","settings.license.detail.graceProviderUnavailable":"Provedor indisponível. O acesso Pro continua ativo no modo de tolerância.","settings.license.detail.manualActivation":"Ativação manual necessária para restaurar o acesso Pro.","settings.license.detail.missingSessionToken":"A atualização está bloqueada porque o token de sessão atual está ausente.","settings.license.detail.refreshRecommended":"A verificação de licença deve ser atualizada em breve.","connection.agents.kill":"Encerrar","connection.agents.kill.title":"Encerrar agente?","connection.agents.killed":"Agente encerrado","connection.agents.killFailed":"Falha ao encerrar o agente","connection.agents.lastCommand":"Último comando","connection.agents.lastCommand.tooltip":"Chamada de ferramenta mais recente executada por este agente.","connection.agents.lastSeen":"Visto por último","connection.agents.lastSeen.tooltip":"Heartbeat ou atividade mais recente deste agente.","connection.clear.title":"Limpar o log de conexão?","connection.clear.message":"Isso remove permanentemente o log de conexão armazenado do projeto atual.","sync.clear.title":"Limpar o log de sincronização?","sync.clear.message":"Isso remove permanentemente o log de sincronização armazenado do place atual.","playtest.clear.title":"Limpar o histórico de testes?","playtest.clear.message":"Isso remove permanentemente os relatórios de playtest armazenados do place atual.","changelog.clear.title":"Limpar o changelog?","changelog.clear.message":"Isso remove permanentemente o changelog armazenado do place atual.","sync.status.placePath":"Caminho do place","sync.status.placePath.tooltip":"Diretório do place ativo onde os arquivos do explorer são sincronizados.","tier.progress.label":"Pro / Total","changelog.card.representativeArea":"Área representativa","changelog.card.verification":"Verificação","uiStudio.tabs.analysis.tooltip":"Browse AI-captured UI screens and quickly find which UIs need improvement.","uiStudio.tabs.history.tooltip":"Every UI change AI made, in order. Compare before and after screens.","uiStudio.title.tooltip":"A central place to review AI-generated UI screens and improvement suggestions.","uiStudio.analysis.reportsTitle.tooltip":"Shows the latest capture and suggestion summary per UI (e.g., Inventory window, Main menu).","uiStudio.analysis.verdict.hasSuggestions.tooltip":"Some improvements were found in this UI. Click the card for details.","uiStudio.analysis.verdict.passed.tooltip":"No improvements suggested under the current review thresholds.","uiStudio.analysis.counts.tooltip":"‘Main’ are key items to review first; ‘Notes’ are nice-to-have refinements.","uiStudio.analysis.thresholds.tooltip":"The threshold set used for this review (default or custom).","uiStudio.analysis.recentCapturesTitle.tooltip":"All recently saved captures in chronological order.","uiStudio.gallery.selectAll.tooltip":"Select every visible capture at once.","uiStudio.gallery.clearSelection.tooltip":"Clear the current selection.","uiStudio.gallery.deleteSelected.tooltip":"Delete only the selected capture files. The actual UI in Roblox Studio is not affected.","uiStudio.gallery.cardCheckbox.tooltip":"Select this capture. Pick multiple to delete them together.","uiStudio.detailClose.tooltip":"Close this detail panel.","uiStudio.actions.captureCurrentState.tooltip":"Save the UI currently shown in Studio as a new capture. Existing captures are kept.","uiStudio.actions.checkSuggestionsAgain.tooltip":"Recompute suggestions for this capture without taking a new screenshot.","uiStudio.actions.more.tooltip":"Open additional actions.","uiStudio.actions.deleteSnapshot.tooltip":"Delete only this capture file. The actual UI in Roblox Studio is not affected.","uiStudio.capturedAt.tooltip":"When this screen was captured.","uiStudio.scope.tooltip":"Capture scope (full screen or a specific UI).","uiStudio.target.tooltip":"Exact path of the captured UI instance.","uiStudio.briefId.tooltip":"Identifier of the design brief that produced this UI.","uiStudio.analysis.verdictLabel.tooltip":"Overall improvement verdict for this capture.","uiStudio.suggestionGroup.tooltip":"Suggestions of the same kind grouped together. Click to expand or collapse.","uiStudio.groupSummary.tooltip":"Number of UI elements matching this group.","uiStudio.colCurrent.tooltip":"The currently applied value.","uiStudio.colRecommended.tooltip":"The recommended value.","uiStudio.copyFixCommand.tooltip":"Copy a prompt that asks the AI to fix this issue.","uiStudio.falsePositiveWarning.tooltip":"This check can produce false positives — verify before applying.","uiStudio.history.filter.actions.tooltip":"Filter records by the kind of change AI made.","uiStudio.history.filter.period.tooltip":"Filter records by time range.","uiStudio.history.filter.from.tooltip":"Start date for the query.","uiStudio.history.filter.to.tooltip":"End date for the query.","uiStudio.history.filter.actionAll.tooltip":"Show every kind of action.","uiStudio.history.filter.actionCreate.tooltip":"Show only actions that created a new UI.","uiStudio.history.filter.actionUpdate.tooltip":"Show only actions that updated an existing UI.","uiStudio.history.filter.actionDelete.tooltip":"Show only actions that deleted a UI.","uiStudio.history.filter.dateAll.tooltip":"Show the full history.","uiStudio.history.filter.today.tooltip":"Show only changes from today.","uiStudio.history.filter.yesterday.tooltip":"Show only changes from yesterday.","uiStudio.history.filter.last7Days.tooltip":"Show changes from the last 7 days.","uiStudio.history.filter.last30Days.tooltip":"Show changes from the last 30 days.","uiStudio.history.filter.customRange.tooltip":"Pick a custom start and end date.","uiStudio.history.filter.reset.tooltip":"Reset all filters to defaults.","uiStudio.history.title.tooltip":"A timeline of every UI change made by AI.","uiStudio.history.clear.tooltip":"Delete every change record for this project. The actual UI in Roblox Studio is not affected.","uiStudio.history.row.compare.tooltip":"Compare the before and after screens. Click to open the full comparison view.","uiStudio.history.row.extraPaths.tooltip":"Number of additional UIs changed in this action.","uiStudio.history.row.noBeforeState.tooltip":"No capture saved before this change.","uiStudio.history.row.noAfterState.tooltip":"No capture saved after this change.","uiStudio.history.row.affectedPaths.tooltip":"Number of UIs affected by this action.","uiStudio.history.row.mutations.tooltip":"Number of detailed changes (e.g., property edits).","uiStudio.history.row.qualityPlan.tooltip":"Direção de design do briefing usada nesta alteração.","uiStudio.history.row.designCheck.tooltip":"Resumo das sugestões do Design Check após a alteração.","uiStudio.history.row.toggleDetails.tooltip":"Show or hide a per-line breakdown of what changed.","uiStudio.compare.before.tooltip":"The screen saved just before AI made the change.","uiStudio.compare.after.tooltip":"The screen saved just after AI made the change.","uiStudio.compare.path.tooltip":"The UI instance path for this screen.","uiStudio.storage.title.tooltip":"Disk usage of UI Studio change records and screenshots.","uiStudio.storage.usageLabel.tooltip":"Disk space currently used by UI Studio for this project.","uiStudio.storage.historyBytes.tooltip":"Space taken by change record data (JSON).","uiStudio.storage.snapshotBytes.tooltip":"Space taken by captured PNG image files.","uiStudio.storage.requestCount.tooltip":"Number of actions where AI changed the UI.","uiStudio.storage.mutationCount.tooltip":"Number of detail changes inside actions (one property edit = 1).","uiStudio.storage.snapshotCount.tooltip":"Number of saved capture image files.","uiStudio.storage.lastRun.tooltip":"When the auto-cleanup policy last ran, and what it removed.","uiStudio.cleanup.label.tooltip":"Manually clean up change records and captures whenever you want.","uiStudio.cleanup.keep7.tooltip":"Delete change records and captures older than 7 days.","uiStudio.cleanup.keep30.tooltip":"Delete change records and captures older than 30 days.","uiStudio.cleanup.deleteAll.tooltip":"Delete every change record and capture for this project. The actual UI in Roblox Studio is not affected.","uiStudio.cleanup.policy.title.tooltip":"Rules that automatically remove old or large captures.","uiStudio.cleanup.policy.modeOff.tooltip":"Turn off auto-cleanup. Data stays until you remove it manually.","uiStudio.cleanup.policy.modeAge.tooltip":"Automatically delete data older than the configured number of days.","uiStudio.cleanup.policy.modeSize.tooltip":"When total usage exceeds the limit, the oldest data is removed first.","uiStudio.cleanup.policy.agePreset.tooltip":"Delete data older than this many days.","uiStudio.cleanup.policy.ageInput.tooltip":"Enter any value between 1 and 365 days.","uiStudio.cleanup.policy.sizePreset.tooltip":"Keep total usage under this size.","uiStudio.cleanup.policy.sizeInput.tooltip":"Enter any value between 50 MB and 10000 MB (10 GB).","uiStudio.cleanup.policy.cascade.tooltip":"Also delete the capture images linked to those records. If off, the images stay.","uiStudio.cleanup.policy.save.tooltip":"Save the current cleanup rule. It runs in the background from then on.","uiStudio.cleanup.policy.runNow.tooltip":"Run the current rule once now, without waiting for the next scheduled run.","settings.license.refresh.tooltip":"Re-fetch the current state from the license server. Useful when a billing change hasn't appeared yet.","settings.license.reset.tooltip":"Remove the currently registered license key. Use this before activating with a different key.","settings.license.activate.tooltip":"Activate Pro features with the entered license key.","tier.upgrade.tooltip":"Veja recursos Pro e opções de compra.","settings.language.auto.tooltip":"Follow the operating system's language. Falls back to English when not supported.","settings.dataHistory.open.tooltip":"Open the page that shows this item in detail.","settings.dataHistory.clear.tooltip":"Delete only the records saved for this item. Roblox Studio data is not changed.","settings.dataHistory.toggle.tooltip":"Collapse or expand this section.","settings.dataHistory.toolsActivity.metric.tooltip":"Number of saved tool runs and the disk space they use.","settings.dataHistory.toolStats.metric.tooltip":"Aggregated total runs and session counts.","settings.dataHistory.syncLog.metric.tooltip":"Number of saved sync events and the disk space they use.","settings.dataHistory.playtestReports.metric.tooltip":"Number of saved playtest reports and the disk space they use.","settings.dataHistory.projectChanges.metric.tooltip":"Number of saved project change summaries and the disk space they use.","settings.dataHistory.connectionLog.metric.tooltip":"Number of saved connection events and the disk space they use.","settings.dataHistory.uiStudio.metric.tooltip":"UI Studio change record and capture counts, plus total disk usage.","uiStudio.designCheckResultsTitle":"Sugestões do Design Check","uiStudio.designCheckResultsTitle.tooltip":"All improvement suggestions found in this capture.","uiStudio.actions.designCheckAgain":"Verificar novamente","uiStudio.actions.designCheckRunning":"Verificando sugestões...","uiStudio.actions.designCheckRunningDetail":"Ao finalizar, serão exibidos itens para revisar primeiro, recomendados e opcionais.","uiStudio.actions.designCheckComplete":"Verificação de sugestões concluída","uiStudio.actions.designCheckNoSnapshotSaved":"Esta ação não salva um novo arquivo de captura de tela.","uiStudio.sample.designCheck.contrast":"Text contrast is below {expected} (current {actual}). Adjust TextColor3 or BackgroundColor3.","uiStudio.sample.designCheck.touchTarget":"Touch target is below {expected} (current {actual}). Increase Size or padding.","uiStudio.sample.designCheck.minTextSize":"TextSize is below {expected} (current {actual}). Increase it for readability.","uiStudio.gallery.priorityHighBadge.tooltip":"Número de sugestões para revisar primeiro. Clique para ver detalhes.","uiStudio.gallery.priorityMediumBadge.tooltip":"Número de sugestões recomendadas.","uiStudio.priorityMedium":"Revisão recomendada","uiStudio.mediumPrioritySection":"Revisão recomendada","uiStudio.gallery.priorityLowBadge.tooltip":"Número de melhorias opcionais.","tier.banner.progressLabel":"Pro / Total","uiStudio.error":"Erro","uiStudio.analysis.expandChildren":"Mostrar alvos filhos","uiStudio.analysis.openDetail":"Abrir detalhe","uiStudio.analysis.childTargets":"Alvos filhos","uiStudio.analysis.childDetailHint":"Abrir detalhe do alvo filho","uiStudio.compare.before":"Antes","uiStudio.compare.after":"Depois","uiStudio.history.drawer.changeDetails":"Detalhes da alteração","uiStudio.gallery.cardCheckbox":"Selecionar captura","sidebar.assets":"Assets","assets.title":"Assets","assets.experimental":"Experimental","assets.subtitle":"Browse local originals, upload to Roblox, and inspect synced usage by place.","assets.scope.label":"Asset scope","assets.scope.place":"Current Place","assets.scope.shared":"Shared","assets.count.shown":"Shown assets: {count}","assets.category.filter":"Category","assets.category.all":"All","assets.category.image":"Images","assets.category.decal":"Decals","assets.category.audio":"Audio","assets.category.mesh":"Meshes","assets.category.model":"Models","assets.category.rbxm":"RBXM","assets.category.video":"Videos","assets.category.animation":"Animations","assets.category.comingSoon":"Coming soon","assets.status.localOnly":"Local only","assets.status.uploading":"Uploading","assets.status.processing":"Processing","assets.status.uploaded":"Uploaded","assets.status.failed":"Failed","assets.status.superseded":"Superseded","assets.rescan":"Rescan","assets.rescan.tooltip":"Scan the selected inbox folder.","assets.rescan.chooseCategory":"Choose a category before rescanning.","assets.rbxmGuide.title":"Save RBXM from Studio","assets.rbxmGuide.body":"Select objects in Roblox Studio, then use WEPPY Plugin > Assets to save the selection as a local RBXM asset.","assets.rbxmGuide.thumbnail":"The plugin save flow includes a thumbnail option, and saved RBXM assets appear here for management, upload, and insertion.","assets.exportSelection":"Export Studio selection","assets.exportSelection.tooltip":"Export the current Studio selection as a local .rbxm asset.","assets.exportSelection.chooseCategory":"Choose RBXM before exporting a Studio selection.","assets.upload.open":"Upload","assets.upload.open.tooltip":"Upload this local file to Roblox through Open Cloud.","assets.upload.selectFirst":"Select an asset first.","assets.upload.title":"Upload asset","assets.upload.checkingSettings":"Checking upload settings...","assets.upload.settingsLoadFailed":"Failed to load upload settings.","assets.upload.settingsRequired":"Upload settings required","assets.upload.settingsRequired.apiKey":"Save an Open Cloud API key before uploading.","assets.upload.settingsRequired.toggle":"Enable Open Cloud upload before uploading.","assets.upload.settingsRequired.creator":"Save a default Creator before uploading.","assets.upload.openSettings":"Open Asset Library settings","assets.upload.creator":"Creator","assets.upload.creatorType":"Creator type","assets.upload.creatorId":"Creator ID","assets.upload.envCreatorHelp":"Environment API keys cannot save a default Creator here. Enter the Creator for this upload.","assets.upload.displayNameHelp":"Saved to Roblox as the asset display name.","assets.upload.descriptionHelp":"Saved to Roblox as the asset description.","assets.upload.creatorHelp":"Used by Open Cloud as the owner of the uploaded asset.","assets.upload.creatorTypeHelp":"Sent to Open Cloud as the Creator type.","assets.upload.creatorIdHelp":"Sent to Open Cloud as the User or Group ID that owns the uploaded asset.","assets.upload.submit":"Upload with Roblox Open Cloud","assets.upload.uploading":"Uploading...","assets.upload.noDelete":"WEPPY does not provide Roblox asset deletion.","assets.upload.delay":"Roblox processing and moderation can delay visibility in Studio or Creator Dashboard.","assets.delete.tooltip":"Delete this local Asset Library item.","assets.delete.title":"Delete asset","assets.delete.message":"This removes the local Asset Library files only. Uploaded Roblox assets are not deleted.","assets.creator.user":"User","assets.creator.group":"Group","assets.settings.open":"Open settings","assets.settings.open.tooltip":"Open Roblox upload settings.","assets.settings.title":"Asset Library settings","assets.settings.proOnly":"Roblox upload settings and Open Cloud credential controls are available on Pro.","assets.settings.openCloudToggle":"Open Cloud upload","assets.settings.openCloudToggle.help":"Controls whether server-side Open Cloud upload mutations can run.","assets.settings.apiKey":"Open Cloud API Key","assets.settings.apiKeyGuide":"Create a Roblox API key with Assets Read and Write permissions.","assets.settings.creatorHelp":"Use the numeric user ID from a profile URL or group ID from a group URL.","assets.settings.credential.none":"No API key saved","assets.settings.credential.env":"Environment variable","assets.settings.credential.local":"Local encrypted file","assets.settings.registeredApiKey":"Registered API Key","assets.settings.credentialProfile":"Credential Profile","assets.settings.activeProfileBadge":"Active","assets.settings.field.profile":"Profile","assets.settings.field.apiKey":"API Key","assets.settings.field.storage":"Storage","assets.settings.field.validationStatus":"Validation status","assets.settings.field.creators":"Creators","assets.settings.validation.unknown":"Not tested","assets.settings.validation.valid":"Connected","assets.settings.validation.invalid":"Needs attention","assets.settings.profileSelected":"Open Cloud credential profile selected.","assets.settings.useProfile":"Use profile","assets.settings.replaceApiKey":"Replace API Key","assets.settings.profileLabel":"Profile name (optional)","assets.settings.profileLabel.placeholder":"Studio automation key","assets.settings.profileLabel.help":"Optional. If left blank, WEPPY saves this profile as Open Cloud key automatically.","assets.settings.saveApiKey":"Save API Key","assets.settings.testConnection":"Test Connection","assets.settings.removeApiKey":"Unregister API Key","assets.settings.saveCreator":"Save default Creator","assets.settings.saveCreatorPreset":"Save Creator","assets.settings.addCreator":"Add Creator","assets.settings.addCreator.tooltip.ready":"Add another User or Group Creator preset to this profile.","assets.settings.cancelCreator":"Cancel","assets.settings.defaultCreatorBadge":"Default","assets.settings.makeDefaultCreator":"Make default","assets.settings.unregisterCreator":"Unregister Creator","assets.settings.creatorLabel":"Creator label (optional)","assets.settings.creatorLabel.placeholder":"Main studio group","assets.settings.creatorLabel.help":"Optional. If left blank, WEPPY automatically saves a label like User 123 or Group 456.","assets.settings.action.proRequired":"Asset upload settings are available on Pro.","assets.settings.action.busy":"Wait for the current settings action to finish.","assets.settings.saveApiKey.tooltip.ready":"Save this API key to local encrypted storage.","assets.settings.saveApiKey.tooltip.enter":"Enter an Open Cloud API key to save it locally.","assets.settings.testConnection.tooltip.entered":"Test the entered API key before saving it.","assets.settings.testConnection.tooltip.saved":"Test the saved Open Cloud API key.","assets.settings.testConnection.tooltip.enterOrSaved":"Enter an API key or save one before testing the connection.","assets.settings.removeApiKey.tooltip.ready":"Unregister the locally saved Open Cloud API key from WEPPY.","assets.settings.removeApiKey.tooltip.none":"No local Open Cloud API key is saved.","assets.settings.removeApiKey.tooltip.env":"Environment API keys cannot be removed from Dashboard. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY.","assets.settings.unregisterCreator.tooltip.ready":"Unregister this Creator from the selected profile.","assets.settings.unregisterApiKey.title":"Unregister API Key?","assets.settings.unregisterApiKey.message":"Roblox API key is not revoked. WEPPY only removes the local Credential Profile registration on this device.","assets.settings.unregisterCreator.title":"Unregister Creator?","assets.settings.unregisterCreator.message":"Roblox user or group is not deleted. WEPPY only removes this Creator from the selected API Key profile.","assets.settings.saveCreator.tooltip.ready":"Save this Creator as the default owner for uploads.","assets.settings.saveCreator.tooltip.noLocal":"Save a local Open Cloud API key before saving a default Creator.","assets.settings.saveCreator.tooltip.env":"Environment API keys cannot save a default Creator here. Enter Creator details in the upload dialog.","assets.settings.saveCreator.tooltip.enterId":"Enter a user or group ID before saving the default Creator.","assets.settings.apiKeySaved":"Open Cloud API key saved locally.","assets.settings.apiKeyTested":"Open Cloud API key connection tested.","assets.settings.apiKeyRemoved":"Open Cloud API key unregistered from local storage.","assets.settings.envApiKeyStillActive":"Environment variable credential is still active. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY Dashboard.","assets.settings.defaultCreatorSaved":"Open Cloud default Creator saved locally.","assets.settings.creatorUnregistered":"Creator unregistered from this profile.","assets.settings.creatorUnregisterFailed":"Failed to unregister Creator.","assets.settings.saved":"Upload settings saved.","assets.settings.saveFailed":"Failed to save upload settings.","assets.settings.loadFailed":"Failed to load upload settings.","assets.settings.tested":"Connection tested.","assets.settings.testFailed":"Connection test failed.","assets.settings.removed":"API key unregistered.","assets.settings.removeFailed":"Failed to unregister API key.","assets.basic.notice":"Browse, preview, edit metadata, and scan usage on Basic. Roblox upload controls are available on Pro.","assets.proOnly.tooltip":"Roblox upload is available on Pro.","assets.proOnly.upload":"Roblox upload is available on Pro.","assets.empty.title":"No assets yet","assets.empty.body":"Choose a scope and category, then rescan that inbox folder.","assets.detail.title":"Asset details","assets.detail.displayName":"Display name","assets.detail.description":"Description","assets.detail.save":"Save metadata","assets.detail.refreshStatus":"Refresh","assets.detail.scanUsage":"Scan usage","assets.detail.localFile":"Local file","assets.detail.fileName":"File","assets.detail.category":"Category","assets.detail.scope":"Scope","assets.detail.mimeType":"Type","assets.detail.size":"Size","assets.detail.dimensions":"Dimensions","assets.detail.duration":"Duration","assets.detail.source":"Source path","assets.detail.sha256":"SHA-256","assets.detail.roblox":"Roblox upload status","assets.detail.status":"Status","assets.detail.assetId":"Asset ID","assets.detail.error":"Error","assets.detail.copyAssetId":"Copy Asset ID","assets.detail.copyUri":"Copy URI","assets.detail.studioUri":"Studio URI","assets.detail.robloxWebUrl":"Creator Dashboard URL","assets.detail.copyStudioUri":"Copy Studio URI","assets.detail.copyWebUrl":"Copy configure URL","assets.detail.openRobloxPage":"Open configure page","assets.detail.robloxWebUrlNotice":"Opening this page requires the Roblox account that owns or can manage the uploaded asset.","assets.detail.uploadHistory":"Upload history","assets.detail.usedInPlace":"Where this asset is used in this Place","assets.detail.noUsage":"No local Sync references found yet.","assets.detail.usageSource":"Checked against","assets.detail.usageSource.localSync":"Local Sync files","assets.detail.usageSource.notScanned":"Not checked yet","assets.detail.lastScanned":"Last checked","assets.detail.lastScannedAt":"Last checked: {time}","assets.detail.lastScanned.never":"No check yet","assets.detail.noUsageUnscanned":"Run Scan usage to search local Sync files for this Roblox Asset ID.","assets.detail.noUsageAfterScan":"No references were found in local Sync files during the last check.","assets.detail.noUsageNoRobloxId":"This asset does not have a Roblox Asset ID yet, so usage cannot be checked. Upload it before scanning usage.","assets.detail.technicalDetails":"Technical details","assets.detail.stableId":"Stable ID","assets.detail.sourceKind":"Source kind","assets.detail.createdAt":"Created","assets.detail.updatedAt":"Updated","assets.detail.operationId":"Operation ID","assets.detail.operationPath":"Operation path","assets.detail.versionId":"Version ID","assets.detail.remotePath":"Remote path","assets.detail.moderationState":"Moderation","assets.detail.line":"line {line}","assets.studio.notConnected":"Connect Roblox Studio before using Studio asset actions.","assets.detail.importRbxm":"Insert into Studio","assets.detail.importRbxm.tooltip":"Insert this local RBXM asset into {target} in the connected Studio place.","assets.detail.generateThumbnail":"Generate thumbnail","assets.detail.generateThumbnail.tooltip":"Create or replace the Asset Library thumbnail from Studio.","assets.detail.rbxmOnly":"Studio import is available for .rbxm assets.","assets.detail.rbxmCategoryOnly":"Studio .rbxm actions support models and animations.","assets.detail.thumbnailRbxmOnly":"Thumbnail generation is available for .rbxm model assets.","assets.detail.thumbnailModelOnly":"Thumbnail generation is available for model .rbxm assets.","assets.detail.rbxm":"RBXM contents","assets.detail.rbxmExportedCount":"Exported roots","assets.detail.rbxmClasses":"Classes","assets.detail.rbxmThumbnail":"Thumbnail","assets.detail.studioInsertTarget":"Studio insert target","assets.detail.rbxmRoots":"Root tree","assets.detail.rbxmReferences":"Asset references","assets.detail.rbxmThumbnailAttempts":"Thumbnail attempts","dashboardHelp.button":"Help","dashboardHelp.pageButton.ariaLabel":"Open page help","dashboardHelp.fieldButton.ariaLabel":"Open field help","dashboardHelp.section.canDo":"What you can do here","dashboardHelp.section.needs":"What you need to use it","dashboardHelp.section.links":"Related links","dashboardHelp.overview.title":"Overview help","dashboardHelp.overview.canDo.1":"Check MCP server, WEPPY Plugin, AI Agent, Sync, and recent game changes in one place.","dashboardHelp.overview.needs.1":"Useful status requires the MCP server. Live Studio status also needs WEPPY Plugin connected to the active place.","dashboardHelp.connection.title":"Connection help","dashboardHelp.connection.canDo.1":"Inspect server process details, connected AI agents, Studio plugin clients, and connection log events.","dashboardHelp.connection.needs.1":"The MCP server must be reachable. Plugin rows appear after Studio sends heartbeats.","dashboardHelp.sync.title":"Sync help","dashboardHelp.sync.canDo.1":"Review Studio to local sync status, direction, apply mode, and sync logs.","dashboardHelp.sync.needs.1":"Sync needs an active place and connected WEPPY Plugin. Two-way and reverse workflows depend on Pro.","dashboardHelp.assets.title":"Assets help","dashboardHelp.assets.canDo.1":"Browse local Asset Library files, switch place/shared scope, filter categories, scan usage, insert RBXM into Studio, and upload local assets to Roblox.","dashboardHelp.assets.needs.1":"Upload needs Pro, the Open Cloud upload toggle, a valid API Key, and a Creator. Browse and preview work on Basic.","dashboardHelp.changelog.title":"Changelog help","dashboardHelp.changelog.canDo.1":"Review real game-change sessions extracted from AI actions and sync events.","dashboardHelp.changelog.needs.1":"Entries are scoped to the active place. Basic shows only the latest preview entries.","dashboardHelp.playtest.title":"Playtest help","dashboardHelp.playtest.canDo.1":"Review Playtest results and reports saved by the AI Agent.","dashboardHelp.playtest.needs.1":"Pro shows real stored reports. Basic shows sample preview data. Live active-place confidence needs WEPPY Plugin connected.","dashboardHelp.uiStudio.title":"UI Studio help","dashboardHelp.uiStudio.canDo.1":"Review AI-created UI analysis, improvement suggestions, captures, and before/after history.","dashboardHelp.uiStudio.needs.1":"Pro shows real UI Studio data. Basic shows a bundled sample. New capture/check actions need WEPPY Plugin connected.","dashboardHelp.tools.title":"Tools help","dashboardHelp.tools.canDo.1":"Inspect tool history, status classification, fallback/unsupported/warn/error details, and usage statistics.","dashboardHelp.tools.needs.1":"History and statistics depend on local recording settings and the active place bucket.","dashboardHelp.settings.title":"Settings help","dashboardHelp.settings.canDo.1":"Manage License, hot settings, saved data cleanup, server environment display, and language.","dashboardHelp.settings.needs.1":"License actions need MCP server connection. Server environment values are read-only here. Asset upload controls live in Assets settings.","dashboardHelp.openCloudApiKey.title":"Open Cloud API Key help","dashboardHelp.openCloudApiKey.canDo.1":"WEPPY uses this key only for Roblox Open Cloud requests.","dashboardHelp.openCloudApiKey.needs.1":"Create a Roblox API key in Creator Hub. Add Assets under Access Permissions, then enable both Read and Write operations.","dashboardHelp.openCloudApiKey.needs.2":"Set the key target to the same User or Group that you use as the upload Creator.","dashboardHelp.openCloudApiKey.needs.3":"The raw key is encrypted on this device. It is not sent to WEPPY servers, and it is not stored in any other external storage, browser storage, telemetry, logs, tool history, or Asset Library metadata.","dashboardHelp.openCloudApiKey.link.apiKeys":"Roblox API keys","dashboardHelp.openCloudApiKey.link.assetsGuide":"Assets API usage guide","dashboardHelp.openCloudApiKey.link.assetsReference":"Assets API reference","dashboardHelp.openCloudCreatorId.title":"Creator ID help","dashboardHelp.openCloudCreatorId.canDo.1":"The default Creator decides which User or Group owns newly uploaded Roblox assets.","dashboardHelp.openCloudCreatorId.needs.1":"For User, sign in to roblox.com, open your profile from your avatar or username, then copy only the number between /users/ and /profile in the browser URL.","dashboardHelp.openCloudCreatorId.needs.2":"For Group, open the Roblox group or community page, then copy only the number after /groups/ or /communities/ in the browser URL.","dashboardHelp.openCloudCreatorId.needs.3":"Paste only the numeric ID in Creator ID. Do not paste the full URL, rbxassetid://, User, or Group text.","dashboardHelp.openCloudCreatorId.link.creatorId":"Creator ID reference","dashboardHelp.openCloudCreatorId.link.userId":"User ID reference","dashboardHelp.openCloudCreatorId.link.groups":"Roblox groups","dashboardHelp.openCloudCreatorId.link.groupsApi":"Groups Cloud API","assets.settings.apiKey.inlineHelp":"WEPPY uses this key only for Roblox Open Cloud requests. The key is encrypted on this device and is not sent to WEPPY servers or stored in any other external storage.","assets.settings.creatorId.inlineHelp":"Default owner for new Roblox assets: your User ID or a Group ID.","common.close":"Fechar","dashboardHelp.section.currentState":"Check based on current status","dashboardHelp.overview.currentState.serverOnly":"Open Roblox Studio and start WEPPY Plugin so live place data can appear.","dashboardHelp.overview.currentState.default":"If the server disconnects, restart MCP or wait for the automatic reconnect.","dashboardHelp.connection.currentState.1":"If Plugin is missing, open Roblox Studio and run WEPPY Plugin. If AI Agent is missing, reconnect the MCP server from your AI tool.","dashboardHelp.sync.currentState.pluginMissing":"Connect WEPPY Plugin in Studio before using live sync details.","dashboardHelp.sync.currentState.basic":"Activate Pro to use bidirectional or reverse sync.","dashboardHelp.sync.currentState.default":"Use the sync log to diagnose stuck or failed sync activity.","dashboardHelp.assets.currentState.basic":"Activate Pro before uploading to Roblox.","dashboardHelp.assets.currentState.uploadDisabled":"Turn on Open Cloud upload in Assets settings.","dashboardHelp.assets.currentState.noCredential":"Save and test an Open Cloud API Key.","dashboardHelp.assets.currentState.noCreator":"Save a default Creator ID or enter Creator details during upload.","dashboardHelp.assets.currentState.default":"Open an asset detail dialog to start upload or usage scan.","dashboardHelp.changelog.currentState.1":"If the list is empty, ask the AI Agent to make a game change. Clear only deletes saved history records, not Studio objects.","dashboardHelp.playtest.currentState.basic":"Activate Pro to use real Playtest history.","dashboardHelp.playtest.currentState.default":"Ask the AI Agent to run a Playtest when no report is available.","dashboardHelp.uiStudio.currentState.basic":"Activate Pro to use live UI Studio previews.","dashboardHelp.uiStudio.currentState.default":"Ask the AI Agent to capture the UI or recheck improvement suggestions, then copy follow-up requests back to the AI chat.","dashboardHelp.tools.currentState.1":"If no records appear, check Settings > General and confirm history/statistics are enabled. Expand failed rows to inspect input, permission, or connection causes.","dashboardHelp.settings.currentState.1":"Activate a license for Pro features. Change environment values outside WEPPY Dashboard, then restart MCP. Review delete confirmations before clearing saved data.","dashboardHelp.openCloudApiKey.currentState.saved":"Use Test Connection to confirm the saved key still works.","dashboardHelp.openCloudApiKey.currentState.empty":"Create an API key in Roblox Creator Hub, paste it here, then save and test it.","dashboardHelp.openCloudCreatorId.currentState.saved":"Keep this value if new assets should continue using the same owner.","dashboardHelp.openCloudCreatorId.currentState.empty":"Choose User or Group, paste the numeric ID, then save the default Creator.","page.overview.title":"Overview","page.overview.description":"Check server, plugin, agent, sync, and recent game-change status in one place.","page.connection.title":"Connection","page.connection.description":"Inspect MCP server, AI agent, Studio plugin, and connection log status.","page.sync.title":"Sync","page.sync.description":"Monitor Studio to local sync status, direction, apply mode, and recent sync logs.","page.changelog.title":"Changelog","page.changelog.description":"Review game-change sessions captured from AI actions and sync events.","page.playtest.title":"Playtest","page.playtest.description":"Review automated playtest runs, saved reports, and result history.","page.uiStudio.title":"UI Studio","page.uiStudio.description":"Review UI captures, improvement suggestions, and before/after change history.","page.tools.title":"Tools","page.tools.description":"Inspect tool history, outcomes, fallback details, and usage statistics.","page.settings.title":"Settings","page.settings.description":"Manage license, live settings, saved data, server environment, and language.","dashboardHelp.whatsNew.title":"What's New help","dashboardHelp.whatsNew.canDo.1":"Review WEPPY Dashboard, MCP, and Plugin announcements, releases, and change notes.","dashboardHelp.whatsNew.needs.1":"Announcements are bundled locally. Unread state is stored in this browser.","dashboardHelp.whatsNew.currentState.1":"After you visit this page, unread announcements from this visit are marked read when you leave. The top header does not show a duplicate What's New button on this page."},Yf={"sidebar.overview":"概要","sidebar.changelog":"変更履歴","sidebar.connection":"接続","sidebar.sync":"同期","sidebar.playtest":"プレイテスト","sidebar.tools":"ツール","sidebar.settings":"設定","sidebar.ui_studio":"UI Studio","sidebar.gate.l1":"MCP サーバーへの接続が必要です。","sidebar.gate.l2":"Roblox Studio プラグインへの接続が必要です。","header.currentProject":"現在のプロジェクト","header.unknownProject":"不明なプロジェクト","header.projectRoot.label":"Project Root","header.currentProject.loading":"プロジェクトルートを読み込み中...","header.currentProject.unavailable":"プロジェクトルートを読み込めません","header.placeNotConnected":"プレイス未接続","header.currentProject.tooltip":"現在選択されているプロジェクトフォルダです。","header.currentProject.loading.tooltip":"プロジェクトルート情報をまだ読み込み中です。","header.currentProject.unavailable.tooltip":"現在のプロジェクトルート情報を読み込めません。","header.currentProjectSyncRoot.label":"Sync Root","header.currentProjectSyncRoot.loading":"Sync root を読み込み中...","header.currentProjectSyncRoot.unavailable":"Sync root 情報を読み込めません","header.currentProjectSyncRoot.tooltip":"選択中のプロジェクトに対応する現在の sync root フォルダです。","header.currentProjectSyncRoot.loading.tooltip":"Sync root 情報をまだ読み込み中です。","header.currentProjectSyncRoot.unavailable.tooltip":"現在の sync root 情報を読み込めません。","header.testFiles.label":"Test Files","header.testFiles.unavailable":"テストファイルのパスを確認できません。","header.testFiles.tooltip":"選択した place の現在の playtest ファイルディレクトリです。","header.places.title":"Places","header.places.active":"Active","header.places.inactive":"Inactive","header.places.pluginRequired":"プラグイン接続が必要です","header.places.liveRequired":"現在の active place を確認するにはプラグイン接続が必要です。","header.place.tooltip":"接続中の Roblox プレイスです。","header.placeNotConnected.tooltip":"プレイス未接続","header.changeProjectRoot":"プロジェクトルートを変更","header.changeProjectRoot.ariaLabel":"プロジェクトルートを変更","header.changeProjectRoot.tooltip":"現在の project root を変更します。","header.changeProjectRoot.disabledTooltip.l0":"プロジェクトルートを変更するには、まず MCP サーバー接続が必要です。","header.changeProjectRoot.disabledTooltip.loading":"プロジェクトルート情報をまだ読み込み中です。","header.changeProjectRoot.disabledTooltip.unavailable":"現在のプロジェクトルート情報を読み込めません。","header.projectRootModal.initial.title":"プロジェクトルートを変更","header.projectRootModal.initial.body.connected":"プロジェクトフォルダを選択すると、MCP は新しい project root に切り替わり、現在の Studio 内容が新しい <selected project folder>/weppy-project-sync にフル再同期されます。","header.projectRootModal.initial.body.disconnected":"プロジェクトフォルダを選択すると、MCP は新しい project root に切り替わり、<selected project folder>/weppy-project-sync を次の sync 対象として使用します。","header.projectRootModal.initial.nextSyncRoot":"選択後の新しい sync 先","header.projectRootModal.initial.nextSyncRoot.placeholder":"<selected project folder>/weppy-project-sync","header.projectRootModal.initial.warningStop":"現在の sync は直ちに停止します。","header.projectRootModal.initial.warningFreshSync":"現在の Studio 内容を基準に、新しい対象へ fresh full sync が作成されます。","header.projectRootModal.initial.warningNoMove":"既存の sync フォルダは自動では移動されません。","header.projectRootModal.initial.warningDeferredSync":"Studio が未接続の場合、full resync は次回 plugin 接続時に開始されます。","header.projectRootModal.confirm.title":"新しいプロジェクトルートを確認","header.projectRootModal.confirm.body":"適用前に選択したプロジェクトフォルダを確認してください。","header.projectRootModal.confirm.projectRoot":"選択したプロジェクトフォルダ","header.projectRootModal.confirm.syncRoot":"新しい sync 先","header.projectRootModal.confirm.warningNoMove":"既存の sync フォルダは自動では移動されません。","header.projectRootModal.pick":"フォルダを選択","header.projectRootModal.apply":"変更を適用","header.projectRootModal.cancel":"キャンセル","header.projectRootModal.error":"プロジェクトルートを変更できませんでした。","status.online":"オンライン","status.offline":"オフライン","status.idle":"待機中","status.syncing":"同期中","status.error":"エラー","status.initializing":"初期化中","level.l0.title":"サーバー切断","level.l0.message":"WEPPY Dashboard は開いていますが、MCPサーバーが停止したか応答していません。","level.l1.title":"サーバー接続済み","level.l1.hint":"確認: Roblox Studioは実行中?プラグインはインストール済み?","level.l2.ok":"Studio接続済み","tier.basic":"Basic","tier.basic.tooltip":"標準のWEPPY Dashboard機能を提供するBasicティアです。","tier.pro":"Pro","tier.pro.tooltip":"すべてのWEPPY Dashboard機能を提供するProティアです。","tier.mixed":"混合","tier.upgrade":"Proを確認","tier.banner.save":"ProでAIトークンを節約!","tier.tool.query_instances.desc":"インスタンス照会、子孫探索、クラス情報、名前・クラス検索。Pro: ファイルツリー、プロジェクト構造、プロパティ・タグ検索。","tier.tool.mutate_instances.desc":"インスタンスの作成、削除、複製、移動、名前変更、ピボット。Pro: ツリー作成、一括作成・削除・複製。","tier.tool.manage_properties.desc":"プロパティ、属性、タグの取得・設定。Pro: 計算・相対値設定、一括取得・設定、子の一括変更。","tier.tool.manage_scripts.desc":"スクリプトソースの読取・書込・作成・削除・行編集・検索。Pro: スクリプト間一括置換。","tier.tool.manage_ui.desc":"Pro専用。ゲームらしいメニュー、HUD、ボタン、ラベル、画像パネルを作成・改善し、画面キャプチャと改善提案を確認します。","tier.tool.manage_ui.action.design_brief":"UIの方向性を整理","tier.tool.manage_ui.action.create_tree":"新しいUIを作成","tier.tool.manage_ui.action.update":"既存UIを更新","tier.tool.manage_ui.action.delete":"UIを削除","tier.tool.manage_ui.action.preview":"UI画面をキャプチャ","tier.tool.manage_ui.action.check":"改善提案を確認","tier.tool.manage_lighting.desc":"Pro専用。照明、大気、空、テレイン属性、時間帯の環境設定。","tier.tool.manage_selection.desc":"選択の取得、設定、解除。Pro: コンテキスト、詳細、項目の追加・削除、変更監視。","tier.tool.manage_camera.desc":"カメラ情報取得、パスまたは座標でフォーカス、推奨ビュー提案。","tier.tool.manage_tween.desc":"Pro専用。滑らかなアニメーションのためのトゥイーン作成、再生、一時停止、キャンセル。","tier.tool.manage_audio.desc":"Pro専用。サウンドの再生、停止、一時停止、再開。オーディオリスナー設定。","tier.tool.manage_animation.desc":"Pro専用。アニメーションのロード、再生、停止。ヒューマノイド・コントローラーのトラック照会。","tier.tool.manage_physics.desc":"Pro専用。物理衝突グループの登録、グループ間衝突設定、一覧照会。","tier.tool.manage_effects.desc":"Pro専用。パーティクル放出、全消去、エフェクト有効化トグル。","tier.tool.manage_terrain.desc":"Pro専用。図形充填、領域消去、マテリアル置換、色管理、ボクセル読書、手続き生成、スムージング。","tier.tool.spatial_query.desc":"Pro専用。レイキャスト、地面検索、配置確認、領域スキャン、平地・スポーン位置探索、歩行分析、空間マップ、衝突確認。","tier.tool.manage_assets.desc":"Pro専用。モデル挿入、アセット情報照会、クリエイターストア検索、無料モデル・パッケージ挿入、エクスポート。","tier.tool.manage_sync.desc":"Pro専用。同期状態、設定、履歴、方向設定、同期ファイル読書。","tier.tool.workspace_state.desc":"Pro専用。フル同期、スナップショット、最近の変更、ビューポート情報、メタデータ、キャッシュ管理。","tier.tool.manage_logs.desc":"出力ログのフィルタリング照会、増分ポーリング、バッファ消去、最近のエラー照会。","tier.tool.system_info.desc":"接続状態、使用ティア確認。Pro: プレイス情報、サービス一覧、Studio設定、プレイテスト制御、自動テスト。","tier.tool.manage_studio.desc":"Pro専用。スクリーンショットやQAのためにUIプレビューなどStudioエディタの表示設定を切り替えます。ゲーム内UIオブジェクトは変更しません。","tier.tool.batch_execute.desc":"Pro専用。複数コマンドを一括実行。順次処理、エラー時続行オプション。","tier.tool.execute_luau.desc":"Pro専用。Roblox Studioサンドボックスで任意のLuauコードを実行。","connection.server.title":"サーバーステータス","connection.server.version":"バージョン","connection.server.version.tooltip":"インストールされているMCPサーバーのバージョンです。","connection.server.pid":"PID","connection.server.pid.tooltip":"OSが使用するプロセス識別子です。","connection.server.uptime":"稼働時間","connection.server.uptime.tooltip":"MCPサーバーの起動後に経過した時間です。","connection.server.session":"セッション","connection.server.session.tooltip":"現在のMCPセッション識別子です。","connection.server.exec":"実行ファイル","connection.server.exec.tooltip":"MCPサーバーを起動した実行ファイルのパスです。","connection.reconnect":"再接続","connection.checkSettings":"設定を確認","connection.agents.title":"AIエージェント","connection.agents.name":"エージェント","connection.agents.cwd":"作業ディレクトリ","connection.agents.cwd.tooltip":"接続中のAIエージェントの現在の作業ディレクトリです。","connection.agents.projectRoot":"プロジェクトルート","connection.agents.projectRoot.tooltip":"同期オーナーシップの権威あるプロジェクトパス","connection.agents.projectRoot.unresolved":"未解決","connection.agents.connected":"接続時刻","connection.agents.unknown":"不明","connection.agents.none":"接続中のエージェントなし","connection.plugins.title":"プラグイン","connection.plugins.place":"プレイス","connection.plugins.clientId":"クライアントID","connection.plugins.clientId.tooltip":"このStudio接続を識別するプラグインクライアントIDです。","connection.plugins.lastSeen":"最終確認","connection.plugins.lastSeen.tooltip":"プラグインから最後に受信したハートビート時刻です。","connection.plugins.version":"バージョン","connection.plugins.version.tooltip":"Studioが報告したインストール済みプラグインのバージョンです。","connection.plugins.none":"接続中のプラグインなし","connection.log.title":"接続ログ","connection.log.empty":"イベントなし","connection.time.secondsAgo":"秒前","connection.time.minutesAgo":"分前","connection.time.hoursAgo":"時間前","common.loading":"読み込み中...","common.retry":"再試行","common.reconnecting":"再接続中...","common.expand":"展開","common.collapse":"折りたたむ","tools.tab.history":"履歴","tools.tab.statistics":"統計","tools.tab.failures":"失敗","tools.col.time":"時刻","tools.col.time.tooltip":"ツール実行が記録された時刻です。","tools.col.toolAction":"ツール.アクション","tools.col.toolAction.tooltip":"実行されたツール名とアクションです。","tools.col.duration":"所要時間","tools.col.duration.tooltip":"ツール完了までにかかった時間です。","tools.col.status":"ステータス","tools.col.status.tooltip":"記録されたツール実行の結果です。","tools.col.tier":"ティア","tools.col.tier.tooltip":"そのツールまたはアクションに必要なライセンスティアです。","tools.col.tierStats.tooltip":"ツール統計行がBasic、Pro、Mixedのどれに当たるかを示します。","tools.col.tool":"ツール","tools.col.tool.tooltip":"統計テーブルに表示される統合ツール名です。","tools.col.calls":"呼び出し数","tools.col.calls.tooltip":"このツールで記録された総呼び出し回数です。","tools.col.ok":"OK","tools.col.ok.tooltip":"直接成功した実行回数です。","tools.col.fallback":"FALLBACK","tools.col.fallback.tooltip":"fallback 実行で成功した回数です。","tools.col.unsupported":"UNSUPPORTED","tools.col.unsupported.tooltip":"fallback なしでブロックされた実行回数です。","tools.col.warn":"WARN","tools.col.warn.tooltip":"入力、プロジェクト状態、Roblox ポリシー、ユーザーコードに起因する想定内の失敗回数です。","tools.col.err":"失敗","tools.col.err.tooltip":"失敗で終了した実行回数です。","tools.col.okRate":"成功率","tools.col.okRate.tooltip":"正常に完了した呼び出しの割合です。","tools.col.avgTime":"平均時間","tools.col.avgTime.tooltip":"記録された呼び出し全体の平均実行時間です。","tools.col.error":"エラー","tools.filter.tool":"ツール","tools.filter.all":"すべて","tools.badge.pro":"PRO","tools.badge.pro.tooltip":"この項目はPro専用のツールまたはアクションを使用しました。","tools.badge.fallback":"FALLBACK","tools.badge.fallback.tooltip":"要求したProアクションがBasic fallbackで成功しました。","tools.badge.unsupported":"UNSUPPORTED","tools.badge.unsupported.tooltip":"要求したProアクションはブロックされ、fallbackも実行されませんでした。","tools.badge.warn":"WARN","tools.badge.warn.tooltip":"入力、プロジェクト状態、ポリシー、ユーザーコードに起因する想定内の失敗です。","tools.badge.err":"失敗","tools.badge.err.tooltip":"ツール実行が失敗で終了しました。","tools.status.ok":"OK","tools.status.ok.tooltip":"ツール実行が正常に完了しました。","tools.tier.mixed.tooltip":"このツールにはBasicとProのアクションが両方含まれます。","tools.detail.params":"パラメータ","tools.detail.params.tooltip":"このツール実行に渡された入力パラメータです。","tools.detail.result":"結果","tools.detail.result.tooltip":"このツール実行から返された結果ペイロードです。","tools.detail.requestedCommand":"送信したコマンド","tools.detail.executedCommand":"実行コマンド","tools.detail.alternatives":"代替候補","tools.detail.blockedMessage":"ブロック理由","tools.detail.noFallback":"Fallback なし","tools.detail.noFallback.value":"実行された fallback はありません。","tools.detail.warningMessage":"警告メッセージ","tools.detail.errorMessage":"エラーメッセージ","tools.clear.history.title":"履歴を削除しますか?","tools.clear.history.message":"現在の place のツール履歴を完全に削除します。","tools.clear.statistics.title":"統計を削除しますか?","tools.clear.statistics.message":"現在の place のツール統計を完全にリセットします。","tools.detail.error":"エラー","tools.page.prev":"前へ","tools.page.prev.tooltip":"ツール履歴の前のページへ移動します。","tools.page.next":"次へ","tools.page.next.tooltip":"ツール履歴の次のページへ移動します。","tools.empty.history":"履歴なし","tools.empty.stats":"ツール統計なし","tools.empty.failures":"失敗なし","tools.summary.total":"合計","tools.summary.calls":"呼び出し","tools.summary.sessions":"セッション","settings.license.title":"ライセンス","settings.license.title.tooltip":"現在のライセンス状態とサブスクリプションティアです。","settings.license.status":"ステータス","settings.license.status.tooltip":"現在のライセンス有効化状態です。","settings.license.tier":"ティア","settings.license.tier.tooltip":"利用できるWEPPY Dashboard機能を決める現在のサブスクリプションティアです。","settings.license.key":"キー","settings.license.key.tooltip":"現在サーバーに読み込まれているマスク済みライセンスキーです。","settings.license.keyValue.tooltip":"現在サーバーに読み込まれているマスク済みライセンスキーです。","settings.license.provider":"プロバイダー","settings.license.provider.auto":"auto","settings.license.provider.polar":"polar","settings.license.provider.gumroad":"gumroad","settings.license.provider.tooltip":"このキーを検証するライセンスプロバイダーです。","settings.license.providerValue.tooltip":"このキーを検証するライセンスプロバイダーです。","settings.license.active":"有効","settings.license.active.tooltip":"現在のライセンス有効化状態です。","settings.license.status.activeCancelPending.tooltip":"解約は予約済みですが、現在の請求期間が終了するまでは Pro アクセスが維持されます。","settings.license.inactive":"無効","settings.license.inactive.tooltip":"現在のライセンス有効化状態です。","settings.license.expired":"期限切れ","settings.license.expired.tooltip":"現在のライセンス有効化状態です。","settings.license.unavailable":"ライセンス情報を取得できません","settings.license.detail.cancelPending":"解約が予約されました。現在の請求期間が終了するまでは Pro アクセスが維持されます。","settings.license.reset":"ライセンスをリセット","settings.readOnly":"読み取り専用","settings.readOnly.tooltip":"このセクションの値はWEPPY Dashboardから編集できません。","settings.unavailable":"設定を取得できません","settings.general.title":"一般設定","settings.general.title.tooltip":"変更すると即時反映されるHot設定です。","settings.general.liveApply":"即時反映","settings.general.liveApply.tooltip":"このセクションの変更は別の保存ボタンなしですぐ適用されます。","settings.general.applied":"適用済み","settings.general.logLevel":"ログレベル","settings.general.logLevel.tooltip":"WEPPY Dashboardログに出力する詳細度を設定します。","settings.general.localHistory":"ツール履歴記録","settings.general.localHistory.tooltip":"WEPPY Dashboard履歴画面用にローカルのツール実行履歴を保存します。","settings.general.localStatistics":"ツール統計収集","settings.general.localStatistics.tooltip":"WEPPY Dashboard表示用にローカル利用統計を集計します。","settings.general.contextCapture":"Context Capture","settings.general.contextCapture.tooltip":"When enabled, the WEPPY Dashboard records structured execution context for changelog and playtest views.","settings.general.requestTimeout":"操作タイムアウト","settings.general.requestTimeout.tooltip":"操作を失敗扱いにするまでWEPPY Dashboardが待機する最大時間です。","settings.general.requestTimeout.unit":"ms","settings.general.requestTimeout.unit.tooltip":"操作タイムアウトの単位はミリ秒です。","settings.cold.title":"サーバー環境変数","settings.cold.title.tooltip":"サーバー起動時に読み込まれる読み取り専用の環境変数です。","settings.cold.httpPort.tooltip":"MCPWEPPY DashboardHTTPサーバーが使用するポート番号です。","settings.cold.httpHost.tooltip":"MCPWEPPY DashboardHTTPサーバーがバインドするホストインターフェースです。","settings.cold.dashboardAutoOpen.tooltip":"サーバー起動時にブラウザーでWEPPY Dashboardを自動で開くかどうかを制御します。","settings.cold.dashboardAutoOpen.value.tooltip":"ブラウザー自動起動の現在の起動動作です。","settings.cold.hint":"環境変数で設定してください。","settings.language.title":"言語","settings.language.title.tooltip":"WEPPY DashboardUIテキストの表示言語を選択します。","settings.language.dashboard":"WEPPY Dashboard言語","settings.language.dashboard.tooltip":"Autoではシステム言語を使い、それ以外では選択した言語を強制します。","settings.language.auto":"自動","overview.l0.title":"MCPサーバー切断","overview.l0.message":"MCPサーバーが応答していません。WEPPY Dashboardが自動的に再接続を試みます。","overview.l0.step1":"MCPサーバープロセスが実行中か確認してください","overview.l0.step2":"必要に応じてMCPサーバーコマンドを再起動してください","overview.l0.reconnecting":"3秒ごとに自動再接続中...","overview.l0.reconnectBtn":"再接続","overview.l0.settingsBtn":"設定を確認","overview.l1.pluginGuide":"Roblox Studioプラグインが接続されていません","overview.l1.check1":"Roblox Studioは実行中ですか?","overview.l1.check2":"WEPPY Pluginはインストール済みですか?","overview.l1.feedHint":"プラグインが接続されると変更がここに表示されます","overview.metric.server":"サーバー","overview.metric.server.tooltip":"MCPサーバーの実行状態とプロセス状態です。","overview.metric.plugin":"プラグイン","overview.metric.plugin.tooltip":"Roblox Studioプラグインの接続状態とバージョン情報です。","overview.metric.agent":"エージェント","overview.metric.agent.tooltip":"接続中のAIコーディングエージェントと現在の実行状態です。","overview.metric.agent.instancesUnit":"インスタンス","overview.metric.sync":"同期","overview.metric.sync.tooltip":"現在のStudioとローカルファイル間の同期状態です。","overview.metric.noAgent":"エージェントなし","overview.meta.version":"バージョン","overview.meta.version.tooltip":"インストールされているMCPサーバーのバージョンです。","overview.meta.session":"セッション","overview.meta.session.tooltip":"現在のMCPセッション識別子です。","overview.meta.pid":"PID","overview.meta.pid.tooltip":"OSが使用するプロセス識別子です。","overview.meta.uptime":"稼働時間","overview.meta.uptime.tooltip":"MCPサーバーの起動後に経過した時間です。","overview.feed.title":"最近のゲーム変更","overview.feed.empty":"最近の変更なし","overview.changelog.title":"セッション変更サマリー","overview.changelog.entries":"合計","overview.changelog.scripts":"スクリプト","overview.changelog.instances":"インスタンス","overview.changelog.properties":"プロパティ","overview.changelog.assets":"アセット","overview.tier.title":"ティア使用状況","changelog.subtitle":"ゲーム変更履歴","changelog.filter.all":"すべて","changelog.filter.active":"アクティブ","changelog.filter.completed":"完了","changelog.empty":"変更履歴がありません","changelog.basic.limit.title":"Basicプレビューでは最新3セッションのみ表示されます","changelog.basic.limit.body":"Proにアップグレードすると、このプレイスの完全な変更履歴タイムラインを確認できます。","changelog.basic.metricLabel":"表示中の変更履歴 / 全体","changelog.basic.visible":"表示中","changelog.basic.total":"全体","changelog.card.active":"アクティブ","changelog.card.active.tooltip":"このセッションはまだ新しいゲーム変更を受信しています。","changelog.card.completed":"完了","changelog.card.completed.tooltip":"このセッションは終了しており、これ以上変更は追加されません。","changelog.card.bootstrapStatus":"初期化","changelog.card.bootstrapStatus.tooltip":"このセッションには初期同期ブートストラップのスナップショットのみが含まれます。","changelog.card.inProgress":"進行中","changelog.card.noChanges":"変更なし","changelog.card.noChanges.tooltip":"このセッションではまだ抽出されたゲーム変更がありません。","changelog.card.bootstrapSummary":"初期同期スナップショット","changelog.card.bootstrapSummary.tooltip":"初期ファイル同期の書き込みは 1 件のブートストラップスナップショット行にまとめられます。","changelog.card.sessionIntent":"Session intent","changelog.card.scripts":"スクリプト","changelog.card.scripts.tooltip":"このセッションで発生したスクリプト変更です。","changelog.card.instances":"インスタンス","changelog.card.instances.tooltip":"このセッションで発生したインスタンスの作成、削除、移動、複製です。","changelog.card.modified":"変更","changelog.card.created":"作成","changelog.card.deleted":"削除","changelog.card.moved":"移動","changelog.card.propertiesChanged":"プロパティ変更","changelog.card.propertiesChanged.tooltip":"このセッションで記録されたプロパティ値の変更です。","changelog.card.lightingConfigured":"ライティング設定済み","changelog.card.lightingConfigured.tooltip":"このセッションでライティングまたは大気設定が変更されました。","changelog.card.terrainConfigured":"テレイン設定済み","changelog.card.terrainConfigured.tooltip":"このセッションでテレインデータまたはテレイン設定が変更されました。","changelog.card.assetsInserted":"アセット挿入","changelog.card.assetsInserted.tooltip":"このセッション中にプレイスへ挿入されたアセットです。","changelog.category.script":"スクリプト","changelog.category.instance":"インスタンス","changelog.category.property":"プロパティ","changelog.category.lighting":"ライティング","changelog.category.terrain":"テレイン","changelog.category.asset":"アセット","changelog.detail.changeSummary":"変更サマリー","changelog.detail.changeSummary.tooltip":"このセッションで抽出されたゲーム変更数をカテゴリ別に表示します。","changelog.detail.changeTimeline":"変更タイムライン","changelog.detail.changeTimeline.tooltip":"このセッションで抽出されたゲーム変更を時系列で表示します。","changelog.detail.context.title":"Context Summary","changelog.detail.context.tooltip":"Structured execution context captured for this changelog session.","changelog.detail.verification.title":"Verification","changelog.detail.verification.tooltip":"Verification signals linked to this changelog session.","changelog.detail.verification.label":"Result","changelog.detail.verification.status":"Status","changelog.detail.verification.timestamp":"Recorded at","changelog.detail.beforeAfter":"変更前後の比較","changelog.detail.filterCategory":"カテゴリ","changelog.detail.filterCategory.tooltip":"タイムラインを 1 つの変更カテゴリに絞り込みます。","changelog.detail.confidence.exact":"正確","changelog.detail.confidence.exact.tooltip":"この変更は変更前と変更後の状態が両方確認されています。","changelog.detail.confidence.partial":"部分確認","changelog.detail.confidence.partial.tooltip":"この変更は変更前後の状態の一部のみ確認されています。","changelog.detail.confidence.afterOnly":"結果のみ確認","changelog.detail.confidence.afterOnly.tooltip":"この変更は適用後の結果状態のみ確認されています。","changelog.detail.confidence.intentOnly":"意図のみ記録","changelog.detail.confidence.intentOnly.tooltip":"要求された操作意図のみが記録され、結果状態は確認されていません。","changelog.detail.confidence.unknown":"不明","changelog.detail.confidence.unknown.tooltip":"利用可能なデータだけではこの変更を確実に分類できませんでした。","changelog.detail.noChanges":"このカテゴリに変更なし","changelog.detail.backToList":"一覧に戻る","changelog.diff.empty":"差分なし","changelog.diff.unified":"統合","changelog.diff.sideBySide":"並列比較","changelog.diff.before":"変更前","changelog.diff.after":"変更後","sync.overlay.title":"Roblox Studioプラグインが必要です","sync.overlay.message":"Roblox Studioプラグインが接続されると同期状態を確認できます。","sync.overlay.check1":"Roblox Studioは実行中ですか?","sync.overlay.check2":"WEPPY Pluginはインストール済みですか?","sync.status.title":"同期ステータス","sync.status.title.tooltip":"このプレイスのStudioとローカルファイルの同期状態です。","sync.status.forwardOnly":"順方向のみ","sync.status.forwardOnly.tooltip":"BasicティアではStudioからローカルへの順方向同期のみ利用できます。","sync.status.place":"プレイス","sync.status.place.tooltip":"接続中のRobloxプレイス名とプレイスIDです。","sync.status.path":"パス","sync.status.path.tooltip":"現在同期出力に使っているローカルファイルシステムのルートです。","sync.status.instances":"インスタンス","sync.status.instances.tooltip":"ローカルミラーで追跡中の同期済みRobloxインスタンス総数です。","sync.status.scripts":"スクリプト","sync.status.scripts.tooltip":"このプレイスで現在インデックスされている同期スクリプトファイル数です。","sync.status.state":"状態","sync.status.state.tooltip":"サーバーが報告した現在の同期ランタイム状態です。","sync.directions.title":"同期方向","sync.directions.title.tooltip":"LocalとStudioの間のカテゴリ別同期方向と適用方法です。","sync.directions.type":"タイプ","sync.directions.type.tooltip":"このルールが適用される同期カテゴリです。","sync.directions.direction":"方向","sync.directions.direction.tooltip":"各カテゴリがStudioから、Studioへ、または双方向で同期されるかを示します。","sync.directions.applyMode":"適用モード","sync.directions.applyMode.tooltip":"このカテゴリに届く同期変更の適用方法です。","sync.directions.cat.scripts":"スクリプト","sync.directions.cat.values":"値","sync.directions.cat.containers":"コンテナ","sync.directions.cat.data":"データ","sync.directions.cat.services":"サービス","sync.directions.endpoint.local":"Local","sync.directions.endpoint.local.tooltip":"方向レールの左側は常にディスク上のローカルファイルです。","sync.directions.endpoint.studio":"Studio","sync.directions.endpoint.studio.tooltip":"方向レールの右側は常にRoblox Studioです。","sync.directions.mode.manual":"手動","sync.directions.mode.manual.tooltip":"手動で実行したときだけ同期変更を適用します。","sync.directions.mode.auto":"自動","sync.directions.mode.auto.tooltip":"更新を受け取ると同期変更を自動で適用します。","sync.directions.tooltip.forward.body":"Studioの変更をローカルファイルのみに同期します","sync.directions.tooltip.bidirectional.body":"LocalとStudioの間で双方向同期を行います","sync.directions.tooltip.reverse.body":"ローカルファイルの変更をStudioへ反映します","sync.directions.tooltip.proRequired":"BasicティアではProが必要です","sync.directions.dir.forward":"順方向","sync.directions.dir.bidirectional":"双方向","sync.directions.dir.reverse":"逆方向","sync.log.title":"同期ログ","sync.log.empty":"同期イベントなし","sync.log.type.write":"書き込み","sync.log.type.write.tooltip":"新しい同期出力がディスクに書き込まれました。","sync.log.type.update":"更新","sync.log.type.update.tooltip":"既存の同期ファイルまたはインスタンスが更新されました。","sync.log.type.delete":"削除","sync.log.type.delete.tooltip":"同期済みファイルまたはインスタンスが削除されました。","sync.log.type.idle":"待機","sync.log.type.idle.tooltip":"ファイル変更なしで同期イベントのみ記録されました。","sync.upgrade.title":"Proの完全同期機能を確認","sync.upgrade.benefit1":"双方向同期 — ファイルを編集するとStudioに自動反映","sync.upgrade.benefit2":"逆方向同期 — ファイルの変更をStudioに送信","sync.upgrade.benefit3":"完全な同期履歴と詳細な変更ログ","sync.upgrade.buy":"Proを確認","playtest.status.title":"プレイテストステータス","playtest.status.title.tooltip":"Studio が報告した現在の Roblox プレイテストセッション状態です。","playtest.status.mode":"モード","playtest.status.mode.tooltip":"現在のセッションで使われている Studio プレイテスト起動モードです。","playtest.status.mode.value.tooltip":"現在使用中の Roblox Studio プレイテストモードの具体的な値です。","playtest.status.mode.play":"プレイ","playtest.status.mode.run":"実行","playtest.status.mode.server":"サーバー","playtest.status.mode.edit":"編集","playtest.status.place.tooltip":"このプレイテストセッションに関連付けられた Roblox プレイスです。","playtest.status.state.running":"実行中","playtest.status.state.running.tooltip":"現在 Roblox プレイテストセッションが実行中です。","playtest.status.state.paused":"一時停止","playtest.status.state.paused.tooltip":"現在の Roblox プレイテストセッションは一時停止中です。","playtest.status.state.notRunning":"未実行","playtest.status.state.notRunning.tooltip":"現在実行中の Roblox プレイテストセッションはありません。","playtest.control.play":"プレイ","playtest.control.pause":"一時停止","playtest.control.resume":"再開","playtest.control.stop":"停止","playtest.history.title":"テスト履歴","playtest.history.title.tooltip":"このプロジェクトで記録された自動プレイテスト実行履歴です。","playtest.history.empty":"テスト結果なし","playtest.history.mode":"モード","playtest.history.mode.tooltip":"この記録済みテスト実行で使われたプレイテストモードです。","playtest.history.status.passed":"成功","playtest.history.status.failed":"失敗","playtest.history.status.running":"実行中","playtest.history.status.unknown":"不明","playtest.history.status.tooltip":"この自動プレイテスト実行で記録された結果状態です。","playtest.empty.title":"プレイテスト結果がありません","playtest.empty.message":"AIエージェントがPlaytestを実行すると、結果がここに表示されます。","playtest.empty.message.before":"AIエージェントがPlaytestを実行すると、結果がここに表示されます。","playtest.empty.message.after":"","playtest.empty.runTest.tooltip":"Ask the AI Agent to run a Playtest when you need a fresh report.","playtest.report.title":"選択されたレポート","playtest.report.title.tooltip":"現在選択されている自動プレイテスト実行の詳細出力です。","playtest.report.content":"レポート","playtest.report.content.tooltip":"選択された自動プレイテスト実行の Markdown 要約です。","playtest.report.logs":"ログ","playtest.report.logs.tooltip":"選択された自動プレイテスト実行で収集された実行ログです。","playtest.context.contextId":"Context ID","playtest.context.why":"Why this test ran","playtest.context.expected":"Expected","playtest.context.observed":"Observed","playtest.report.empty":"レポート内容なし","playtest.basic.icon":"🎮","playtest.basic.title":"プレイテストはPro専用機能です","playtest.basic.desc":"WEPPY Dashboardからプレイテストを制御し、自動テストを実行し、詳細なテストレポートを確認できます。","playtest.basic.benefit1":"ワンクリックのプレイ/一時停止/停止コントロール","playtest.basic.benefit2":"AIエージェントによる自動テスト実行","playtest.basic.benefit3":"成功/失敗追跡付きテスト履歴","playtest.basic.benefit4":"詳細なマークダウンテストレポート","playtest.sample.badge":"Proプレイテスト画面のプレビュー","playtest.sample.title":"現在表示しているのは、Proにアップグレード後に利用できるプレイテスト画面のプレビューです。","playtest.sample.message":"このプレビューはサンプルデータを使用しています。ライブのプレイテスト操作、履歴管理、実際のレポート保存はPro購入後に利用できます。","playtest.sample.clearDisabled":"実際のプレイテスト履歴の削除はProで利用できます。","playtest.sample.place":"アリーナプレビュー","playtest.sample.history.name":"サンプルアリーナスモークテスト","playtest.sample.context.why":"アリーナにスポーンし、開始直後を生き残り、HUDがすぐ反応するか確認します。","playtest.sample.context.expected":"プレイヤーが安全にスポーンし、1秒以内にカウントダウンUIが表示され、最初のウェーブがエラーなく始まること。","playtest.sample.context.observed":"スポーン保護が正常に動作し、HUDは時間どおり更新され、最初のウェーブは回帰なく完了しました。","playtest.sample.report.markdown":`# サンプルアリーナスモークテスト
110
+
111
+ - スポーンフロー: PASS
112
+ - HUDカウントダウン: PASS
113
+ - ウェーブ開始: PASS
114
+
115
+ これはサンプルプレビューです。Proにアップグレードすると、ライブのプレイテスト実行と実際のレポート保存ができます。`,"playtest.sample.report.logs":`[sample] プレイテストプレビュー起動
116
+ [sample] スポーン保護有効
117
+ [sample] hudカウントダウン描画
118
+ [sample] 第1ウェーブ完了
119
+ [sample] プレビュー報告終了`,"sidebar.whatsNew":"新着情報","sidebar.help.group":"ヘルプとフィードバック","sidebar.help.bug":"バグを報告","sidebar.help.bug.tooltip":"ローカル診断バンドルを作成してから、環境情報を事前入力した GitHub のバグ報告を開く","bugReportDialog.title":"diagnostics.zip は原因調査に役立ちます","bugReportDialog.subtitle":"WEPPY がこのコンピューターに診断 zip を作成しました。Studio、プラグイン、Sync、ツール実行ログが含まれ、問題の確認に役立ちます。","bugReportDialog.close":"Close","bugReportDialog.loading":"Preparing diagnostics.zip...","bugReportDialog.error":"Could not create the diagnostics bundle. You can still open GitHub without diagnostics.","bugReportDialog.bundle":"Bundle","bugReportDialog.included":"Included","bugReportDialog.included.none":"No log files found","bugReportDialog.optional":"このファイルがなくてもバグ報告は送信できますが、zip を添付すると原因を早く確認しやすくなります。","bugReportDialog.attachHow":"添付するには zip をダウンロードするか Finder/Explorer で開き、送信前に GitHub issue の Diagnostics ZIP (optional) アップロード欄へ追加してください。","bugReportDialog.download":"1. diagnostics.zip をダウンロード","bugReportDialog.reveal":"Reveal in Finder","bugReportDialog.reveal.opening":"Opening...","bugReportDialog.reveal.opened":"Opened location","bugReportDialog.reveal.failed":"Could not open the file location.","bugReportDialog.openGithub":"2. GitHub issue を開く","bugReportDialog.openGithubFallback":"Open GitHub without diagnostics","bugReportDialog.retry":"Try again","bugReportDialog.hint":"zip にはローカルログやプロジェクト情報が含まれることがあります。共有する場合は添付前に内容を確認してください。","sidebar.help.feature":"機能を提案","sidebar.help.feature.tooltip":"GitHub で新機能や改善を提案する","sidebar.help.discussions":"サポート","sidebar.help.discussions.tooltip":"GitHub Issues で質問やインストールの相談をする","sidebar.help.troubleshooting":"トラブルシューティング","sidebar.help.troubleshooting.tooltip":"weppyai.com の公式トラブルシューティングガイドを開く","header.whatsNew":"新着情報","header.whatsNew.tooltip":"新着情報","upgrade.title":"Proを確認","upgrade.tagline":"Pro機能を確認","upgrade.cta":"Proを確認","upgrade.licenseShortcut":"ライセンスを入力","upgrade.validUntil":"Until {{date}}","whatsNew.pageTitle":"新着情報","whatsNew.pageSubtitle":"MCPの最新変更をチェック","whatsNew.unreadSection":"未読","whatsNew.allSection":"すべてのお知らせ","whatsNew.empty":"お知らせはまだありません","whatsNew.newBadge":"NEW","whatsNew.category.release":"リリース","whatsNew.category.notice":"お知らせ","whatsNew.category.deprecation":"非推奨","whatsNew.category.tip":"ヒント","uiStudio.title":"UI Studio","uiStudio.empty":"保存されたスクリーンショットはまだありません。AIエージェントが現在のUI状態をキャプチャすると自動作成されます。","uiStudio.loading":"Loading…","uiStudio.pluginGuide.title":"Roblox Studio プラグインが接続されていません","uiStudio.pluginGuide.message":"UI Studio は、接続された Studio place のスクリーンショットと変更履歴を表示します。Studio と WEPPY Plugin が接続されると自動的に更新されます。","uiStudio.pluginGuide.check1":"Roblox Studio は起動していますか?","uiStudio.pluginGuide.check2":"WEPPY Plugin はインストールされ、実行されていますか?","uiStudio.pluginGuide.waiting":"プラグイン接続を待機中...","uiStudio.capturedAt":"Captured at","uiStudio.scope":"Scope","uiStudio.target":"Target","uiStudio.briefId":"Brief ID","uiStudio.detailClose":"Close","uiStudio.colCheck":"Check","uiStudio.colPriority":"Priority","uiStudio.colCurrent":"Current","uiStudio.colRecommended":"Recommended","uiStudio.colSuggestion":"Suggestion","uiStudio.priorityHigh":"優先確認","uiStudio.priorityLow":"任意改善","uiStudio.highPrioritySection":"優先確認","uiStudio.lowPrioritySection":"任意改善","uiStudio.groupSummary":"items","uiStudio.fixLabel":"Fix","uiStudio.copyFixCommand":"Copy AI instruction","uiStudio.copiedToClipboard":"Copied","uiStudio.fullPath":"Full path","uiStudio.falsePositiveWarning":"This group may contain false positives","uiStudio.noSuggestions":"No current improvement suggestions","uiStudio.sample.badge":"Preview of the Pro UI Studio","uiStudio.sample.title":"You are previewing the UI Studio that unlocks after upgrading to Pro.","uiStudio.sample.message":"This preview uses sample data from a demo inventory UI. Real screenshots, review history, and AI-driven fixes unlock with Pro.","uiStudio.tabs.analysis":"分析","uiStudio.tabs.history":"変更履歴","uiStudio.analysis.reportsTitle":"UI 対象別の最新分析","uiStudio.analysis.recentCapturesTitle":"最近のキャプチャ","uiStudio.analysis.detailDialog":"分析詳細","uiStudio.analysis.targetCountLabel":"分析対象","uiStudio.analysis.captureLabel":"キャプチャ","uiStudio.analysis.verdict.hasSuggestions":"改善提案あり","uiStudio.analysis.verdict.needsFix":"改善提案あり","uiStudio.analysis.verdict.review":"改善提案あり","uiStudio.analysis.verdict.passed":"現在の改善提案なし","uiStudio.analysis.verdictLabel":"改善サマリー","uiStudio.analysis.thresholds":"レビュー基準","uiStudio.analysis.issueSummary.passed":"現在のレビュー基準では、追加の改善提案はありません。","uiStudio.history.title":"変更履歴","uiStudio.history.empty":"まだ変更履歴がありません。AIエージェントがmanage_uiでUIを変更すると自動的に記録されます。","uiStudio.history.loading":"読み込み中...","uiStudio.history.error":"エラー","uiStudio.history.clear":"すべて削除","uiStudio.history.filter.actions":"アクション種別","uiStudio.history.filter.actionAll":"すべて","uiStudio.history.filter.actionCreate":"作成","uiStudio.history.filter.actionUpdate":"更新","uiStudio.history.filter.actionDelete":"削除","uiStudio.history.filter.period":"期間","uiStudio.history.filter.dateAll":"すべて","uiStudio.history.filter.today":"今日","uiStudio.history.filter.yesterday":"昨日","uiStudio.history.filter.last7Days":"過去 7 日","uiStudio.history.filter.last30Days":"過去 30 日","uiStudio.history.filter.customRange":"範囲指定","uiStudio.history.filter.reset":"リセット","uiStudio.history.filter.from":"開始","uiStudio.history.filter.to":"終了","uiStudio.history.row.affectedPaths":"パス","uiStudio.history.row.mutations":"変更詳細","uiStudio.history.row.expand":"▾ 展開","uiStudio.history.row.collapse":"▲ 閉じる","uiStudio.history.row.expandDetails":"変更詳細 {n} 件","uiStudio.history.row.collapseDetails":"変更詳細を閉じる","uiStudio.history.row.toggleDetails":"変更詳細を切り替え","uiStudio.history.row.mutationsEmpty":"変更詳細なし","uiStudio.history.row.toolLabel":"UI変更({n}件)","uiStudio.history.row.compare":"前後比較","uiStudio.history.row.noBeforeState":"変更前なし","uiStudio.history.row.noAfterState":"変更後なし","uiStudio.history.row.qualityPlan":"デザイン方針","uiStudio.history.row.designCheck":"改善提案","uiStudio.history.row.designCheckUnavailable":"改善提案: 要約なし","uiStudio.history.row.designCheckNone":"改善提案: 現在なし","uiStudio.history.selection.deleteSelected":"選択を削除","uiStudio.history.selection.selectAll":"すべて選択","uiStudio.history.selection.clearSelection":"選択解除","uiStudio.history.confirm.deleteRequestsTitle":"変更記録を削除","uiStudio.history.confirm.deleteRequestsMessage":"選択した変更記録を削除します。この操作は元に戻せません。","uiStudio.history.confirm.clearRequestsTitle":"変更履歴を削除","uiStudio.history.confirm.clearRequestsMessage":"現在の place の変更履歴を削除します。Studio インスタンスには影響しません。","uiStudio.history.confirm.cascadeOption":"リンクされたスクリーンショットも削除","uiStudio.history.drawer.close":"閉じる","uiStudio.actions.previewAgain":"再プレビュー","uiStudio.actions.deleteSnapshot":"このスクリーンショットを削除","uiStudio.actions.proRequired":"Proにアップグレード後に利用可能","uiStudio.actions.captureCurrentState":"現在の状態をキャプチャ","uiStudio.actions.checkSuggestionsAgain":"提案を再確認","uiStudio.actions.previewRunning":"キャプチャ中…","uiStudio.actions.previewRunningDetail":"完了すると新しいスクリーンショットファイル ID が表示されます。","uiStudio.actions.previewNeedsSaveCheck":"キャプチャ完了、保存確認が必要","uiStudio.actions.previewSaved":"新しいスクリーンショットを保存しました","uiStudio.actions.previewComplete":"キャプチャ完了","uiStudio.actions.previewSavedDetail":"既存のスクリーンショットは変更せず、新しいファイルとして保存しました。","uiStudio.actions.previewSavedPathMissing":"新しいスクリーンショット ID は返されましたが、保存先パスを確認できませんでした。","uiStudio.actions.previewSnapshotIdMissing":"新しいスクリーンショット ID を確認できませんでした。リストを更新して保存状況を確認してください。","uiStudio.actions.more":"その他","uiStudio.gallery.selection.selectedCount":" 件選択中","uiStudio.confirm.deleteSnapshotTitle":"スクリーンショットを削除","uiStudio.confirm.deleteSnapshotMessage":"このスクリーンショットファイルのみ削除されます(Studioインスタンスは保持されます)。","uiStudio.confirm.deleteBatchTitle":"スクリーンショットを一括削除","uiStudio.confirm.deleteBatchMessage":"選択したスクリーンショットを削除します。この操作は元に戻せません。","uiStudio.gallery.selectMode":"選択","uiStudio.gallery.exitSelectMode":"キャンセル","uiStudio.gallery.selectAll":"すべて選択","uiStudio.gallery.clearSelection":"選択解除","uiStudio.gallery.deleteSelected":"選択削除","common.cancel":"キャンセル","common.delete":"削除","uiStudio.storage.title":"UI Studioの保存データ","uiStudio.storage.usageLabel":"使用中","uiStudio.storage.historyBytes":"履歴","uiStudio.storage.snapshotBytes":"スクリーンショット","uiStudio.storage.requestCount":"変更記録","uiStudio.storage.mutationCount":"変更詳細","uiStudio.storage.snapshotCount":"スクリーンショット","uiStudio.storage.countSuffix":"件","uiStudio.storage.lastRun":"最後の自動クリーンアップ","uiStudio.storage.lastRunNever":"—","uiStudio.storage.lastRunFreed":"解放","uiStudio.storage.lastRunErrors":"エラー","uiStudio.storage.loading":"読み込み中...","uiStudio.cleanup.policy.title":"自動削除ポリシー","uiStudio.cleanup.policy.modeOff":"無効","uiStudio.cleanup.policy.modeAge":"期間ベース","uiStudio.cleanup.policy.modeSize":"サイズベース","uiStudio.cleanup.policy.cascade":"リンクされたスクリーンショットも削除","uiStudio.cleanup.policy.save":"ポリシーを保存","uiStudio.cleanup.policy.runNow":"今すぐ実行","uiStudio.cleanup.policy.proRequired":"Proにアップグレード後に利用可能","uiStudio.cleanup.policy.daysUnit":"日","uiStudio.cleanup.policy.mbUnit":"MB","uiStudio.cleanup.policy.gbUnit":"GB","uiStudio.cleanup.policy.confirm.title":"ポリシーの確認","uiStudio.cleanup.policy.confirm.messageStrict":"このポリシーを適用すると直ちに削除されます","uiStudio.cleanup.policy.confirm.requests":" 件","uiStudio.cleanup.policy.confirm.snapshots":" スクリーンショット","uiStudio.cleanup.policy.confirm.freed":"解放 — 適用しますか?","uiStudio.cleanup.keepLastNDays":"直近{n}日間のみ保持","uiStudio.cleanup.selectedDelete":"選択削除…","uiStudio.cleanup.deleteAll":"全て削除…","uiStudio.cleanup.cleanupConfirmTitle":"クリーンアップの確認","uiStudio.cleanup.cleanupConfirmMessage":"選択したアイテムが削除されます。この操作は元に戻せません。","uiStudio.cleanup.cleanupConfirmMessage.keep7":"Change records and screenshots older than 7 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.keep30":"Change records and screenshots older than 30 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.all":" saved change records and screenshots will be deleted. This action cannot be undone.","uiStudio.cleanup.label":"手動クリーンアップ","uiStudio.cleanup.studioPreservedNote":"この操作はディスク上の履歴・スクリーンショットファイルのみを削除します。Roblox Studio のインスタンスには影響しません。","uiStudio.history.sample.bannerBadge":"Pro 変更履歴プレビュー","uiStudio.history.sample.bannerTitle":"Pro変更履歴のプレビュー","uiStudio.history.sample.bannerMessage":"このプレビューはサンプルデータを使用しています。実際のリクエスト履歴、前後比較、一括削除はProでご利用いただけます。","uiStudio.fix.touchTarget.label":"Touch target size","uiStudio.fix.touchTarget.description":"Checks whether controls are large enough to tap comfortably on mobile.","uiStudio.fix.touchTarget.howToFix":"Increase button Size to at least 44x44 px or expand the touch area with UIPadding.","uiStudio.fix.contrast.label":"Text contrast","uiStudio.fix.contrast.description":"Checks whether text and background contrast meet accessibility guidance.","uiStudio.fix.contrast.howToFix":"Use a brighter TextColor3 or darken the BackgroundColor3.","uiStudio.fix.contrast.falsePositive":"Emoji icons may be false positives when their color is fixed.","uiStudio.fix.textScaled.label":"TextScaled usage","uiStudio.fix.textScaled.description":"TextScaled without UITextSizeConstraint can break layouts when text expands.","uiStudio.fix.textScaled.howToFix":"Add a UITextSizeConstraint child to the TextLabel and set MaxTextSize.","uiStudio.fix.safezone.label":"Safe-zone placement","uiStudio.fix.safezone.description":"Checks whether controls stay inside platform safe zones.","uiStudio.fix.safezone.howToFix":"Move Position inside the safe zone or reduce the parent Frame.","uiStudio.fix.minTextSize.label":"Minimum font size","uiStudio.fix.minTextSize.description":"Checks whether text is too small to read comfortably.","uiStudio.fix.minTextSize.howToFix":"Increase TextSize to at least 14 for body text.","uiStudio.sample.history.request1.label":"Initial HUD layout creation","uiStudio.sample.history.request2.label":"Inventory modal design update","uiStudio.sample.history.request3.label":"HUD HealthBar color update","uiStudio.sample.history.request4.label":"Expand Inventory tab button touch targets","uiStudio.sample.history.request5.label":"Remove Settings popup","uiStudio.sample.history.request6.label":"Add HUD minimap component","uiStudio.sample.history.request1.mutation1.diff":"Created Frame + HealthBar + StaminaBar","uiStudio.sample.history.request1.mutation2.diff":"BackgroundColor3 -> Color3.new(0.2,0.8,0.2)","uiStudio.sample.history.request1.mutation3.diff":"BackgroundColor3 -> Color3.new(0.1,0.6,1.0)","uiStudio.sample.history.request1.mutation4.diff":"Set AnchorPoint, Position, and Size","uiStudio.sample.history.request1.mutation5.diff":"Screenshot saved","uiStudio.sample.history.request2.mutation1.diff":"Darkened BackgroundColor3 for better contrast","uiStudio.sample.history.request2.mutation2.diff":"TextColor3 -> Color3.new(1,1,1), TextSize 16 -> 18","uiStudio.sample.history.request2.mutation3.diff":"BorderSizePixel 0 -> 2, set BorderColor3","uiStudio.sample.history.request2.mutation4.diff":"Screenshot saved","uiStudio.sample.history.request3.mutation1.diff":"BackgroundColor3 -> Color3.new(0.9,0.2,0.2) (red tone)","uiStudio.sample.history.request3.mutation2.diff":"Screenshot saved","uiStudio.sample.history.request4.mutation1.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation2.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation3.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation4.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation5.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation6.diff":"Screenshot saved","uiStudio.sample.history.request5.mutation1.diff":"Removed ScreenGui (Settings-only UI)","uiStudio.sample.history.request6.mutation1.diff":"Attempted to create Frame + MapImage + PlayerDot","uiStudio.sample.history.request6.mutation2.diff":"Set Size, Position, and BackgroundTransparency","uiStudio.sample.history.request6.mutation3.diff":"Interrupted by server restart while setting ImageLabel","uiStudio.sample.history.request6.mutation4.diff":"Partial screenshot saved","uiStudio.sample.history.request6.mutation3.error":"server_restart: connection lost","uiStudio.sample.history.request6.mutation4.error":"partial screenshot: missing layers","uiStudio.sample.history.detail.backgroundColor":"Background color","uiStudio.sample.history.detail.anchorPoint":"Anchor","uiStudio.sample.history.detail.position":"Position","uiStudio.sample.history.detail.size":"Size","uiStudio.sample.history.detail.textColor":"Text color","uiStudio.sample.history.detail.textSize":"Text size","uiStudio.sample.history.detail.borderSize":"Border size","uiStudio.sample.history.detail.borderColor":"Border color","uiStudio.history.sample.tooltip":"全履歴はProにアップグレード後にご利用いただけます","settings.dataHistory.title":"Data & History","settings.dataHistory.title.tooltip":"Manage saved dashboard data in one place.","settings.dataHistory.collapse":"Collapse {title}","settings.dataHistory.expand":"Expand {title}","settings.dataHistory.scope":"Current project","settings.dataHistory.scope.tooltip":"Clear actions apply to the current project and active place where applicable.","settings.dataHistory.intro":"Review saved dashboard data, open the related page, or clear stored records from one place.","settings.dataHistory.toolsActivity.title":"Tool activity","settings.dataHistory.toolsActivity.description":"Saved tool runs shown on the Tools page.","settings.dataHistory.toolStats.title":"Tool usage statistics","settings.dataHistory.toolStats.description":"Aggregated tool counts and status totals.","settings.dataHistory.syncLog.title":"Sync log","settings.dataHistory.syncLog.description":"Saved file sync events for the active place.","settings.dataHistory.playtest.title":"Playtest reports","settings.dataHistory.playtest.description":"Saved automated playtest reports and logs.","settings.dataHistory.projectChanges.title":"Project change summary","settings.dataHistory.projectChanges.description":"Saved summaries of project changes.","settings.dataHistory.connectionLog.title":"Connection log","settings.dataHistory.connectionLog.description":"Saved MCP and Studio connection events.","settings.dataHistory.uiStudio.title":"UI Studio history and screenshots","settings.dataHistory.uiStudio.tooltip":"Manage saved UI Studio change records, screenshots, and auto-delete policy.","settings.dataHistory.uiStudio.description":"Saved UI Studio change records, screenshots, and cleanup policy.","settings.dataHistory.uiStudio.clear.title":"Clear UI Studio saved data?","settings.dataHistory.uiStudio.clear.message":"This deletes saved UI Studio change records and screenshots only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.uiStudio.clear.success":"UI Studio saved data cleared.","settings.dataHistory.uiStudio.clear.failed":"Failed to clear UI Studio saved data.","settings.dataHistory.metric.unavailable":"Unavailable","settings.dataHistory.metric.sizeUnavailable":"size unavailable","settings.dataHistory.metric.records":"records","settings.dataHistory.metric.runs":"runs","settings.dataHistory.metric.sessions":"sessions","settings.dataHistory.metric.reports":"reports","settings.dataHistory.open":"Open","settings.dataHistory.clear.title":"Clear saved data?","settings.dataHistory.clear.message":"This deletes saved dashboard records only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.clear.success":"Saved data cleared.","settings.dataHistory.clear.failed":"Failed to clear saved data.","toast.serverConnected":"MCP サーバーに接続しました","toast.serverDisconnected":"MCP サーバーから切断されました","toast.pluginConnected":"プラグインに接続しました","toast.pluginDisconnected":"プラグインから切断されました","toast.clearSuccess":"削除しました","toast.clearFailed":"削除に失敗しました","common.clear":"クリア","settings.license.activate":"ライセンスを有効化","settings.license.refresh":"ライセンスを更新","settings.license.keyInput":"ライセンスキー","settings.license.disconnected":"切断","settings.license.disconnected.tooltip":"WEPPY Dashboard からライセンス操作を行うには、MCP サーバーに再接続してください。","settings.license.live.tooltip":"ライセンス操作は MCP サーバーに即時反映されます。","settings.license.status.activationRequired":"有効化が必要","settings.license.status.activationRequired.tooltip":"WEPPY Dashboard がこの状態を更新するには、ライセンスを手動で有効化する必要があります。","settings.license.status.grace":"猶予","settings.license.status.grace.tooltip":"プロバイダー検証が一時的に利用できませんが、猶予期間中は Pro アクセスが維持されます。","settings.license.status.graceBilling.tooltip":"請求関連の猶予期間中も Pro アクセスは利用できます。","settings.license.detail.graceBilling":"請求の猶予期間中も Pro アクセスは利用できます。","settings.license.detail.graceProviderUnavailable":"プロバイダーが利用できません。猶予モードの間も Pro アクセスは維持されます。","settings.license.detail.manualActivation":"Pro アクセスを復元するには手動での有効化が必要です。","settings.license.detail.missingSessionToken":"現在のセッショントークンが存在しないため、更新がブロックされています。","settings.license.detail.refreshRecommended":"ライセンス検証を近いうちに更新してください。","connection.agents.kill":"強制終了","connection.agents.kill.title":"エージェントを強制終了しますか?","connection.agents.killed":"エージェントを強制終了しました","connection.agents.killFailed":"エージェントの強制終了に失敗しました","connection.agents.lastCommand":"最終コマンド","connection.agents.lastCommand.tooltip":"このエージェントが最後に実行したツール呼び出しです。","connection.agents.lastSeen":"最終確認","connection.agents.lastSeen.tooltip":"このエージェントから最後に受信したハートビートまたは活動時刻です。","connection.clear.title":"接続ログをクリアしますか?","connection.clear.message":"現在のプロジェクトに保存された接続ログが完全に削除されます。","sync.clear.title":"同期ログをクリアしますか?","sync.clear.message":"現在のプレイスに保存された同期ログが完全に削除されます。","playtest.clear.title":"テスト履歴をクリアしますか?","playtest.clear.message":"現在のプレイスに保存されたプレイテストレポートが完全に削除されます。","changelog.clear.title":"変更ログをクリアしますか?","changelog.clear.message":"現在のプレイスに保存された変更ログが完全に削除されます。","sync.status.placePath":"プレイスパス","sync.status.placePath.tooltip":"Explorer ファイルが同期される現在のプレイスディレクトリです。","tier.progress.label":"Pro / 全体","changelog.card.representativeArea":"代表領域","changelog.card.verification":"検証","uiStudio.tabs.analysis.tooltip":"Browse AI-captured UI screens and quickly find which UIs need improvement.","uiStudio.tabs.history.tooltip":"Every UI change AI made, in order. Compare before and after screens.","uiStudio.title.tooltip":"A central place to review AI-generated UI screens and improvement suggestions.","uiStudio.analysis.reportsTitle.tooltip":"Shows the latest capture and suggestion summary per UI (e.g., Inventory window, Main menu).","uiStudio.analysis.verdict.hasSuggestions.tooltip":"Some improvements were found in this UI. Click the card for details.","uiStudio.analysis.verdict.passed.tooltip":"No improvements suggested under the current review thresholds.","uiStudio.analysis.counts.tooltip":"‘Main’ are key items to review first; ‘Notes’ are nice-to-have refinements.","uiStudio.analysis.thresholds.tooltip":"The threshold set used for this review (default or custom).","uiStudio.analysis.recentCapturesTitle.tooltip":"All recently saved captures in chronological order.","uiStudio.gallery.selectAll.tooltip":"Select every visible capture at once.","uiStudio.gallery.clearSelection.tooltip":"Clear the current selection.","uiStudio.gallery.deleteSelected.tooltip":"Delete only the selected capture files. The actual UI in Roblox Studio is not affected.","uiStudio.gallery.cardCheckbox.tooltip":"Select this capture. Pick multiple to delete them together.","uiStudio.detailClose.tooltip":"Close this detail panel.","uiStudio.actions.captureCurrentState.tooltip":"Save the UI currently shown in Studio as a new capture. Existing captures are kept.","uiStudio.actions.checkSuggestionsAgain.tooltip":"Recompute suggestions for this capture without taking a new screenshot.","uiStudio.actions.more.tooltip":"Open additional actions.","uiStudio.actions.deleteSnapshot.tooltip":"Delete only this capture file. The actual UI in Roblox Studio is not affected.","uiStudio.capturedAt.tooltip":"When this screen was captured.","uiStudio.scope.tooltip":"Capture scope (full screen or a specific UI).","uiStudio.target.tooltip":"Exact path of the captured UI instance.","uiStudio.briefId.tooltip":"Identifier of the design brief that produced this UI.","uiStudio.analysis.verdictLabel.tooltip":"Overall improvement verdict for this capture.","uiStudio.suggestionGroup.tooltip":"Suggestions of the same kind grouped together. Click to expand or collapse.","uiStudio.groupSummary.tooltip":"Number of UI elements matching this group.","uiStudio.colCurrent.tooltip":"The currently applied value.","uiStudio.colRecommended.tooltip":"The recommended value.","uiStudio.copyFixCommand.tooltip":"Copy a prompt that asks the AI to fix this issue.","uiStudio.falsePositiveWarning.tooltip":"This check can produce false positives — verify before applying.","uiStudio.history.filter.actions.tooltip":"Filter records by the kind of change AI made.","uiStudio.history.filter.period.tooltip":"Filter records by time range.","uiStudio.history.filter.from.tooltip":"Start date for the query.","uiStudio.history.filter.to.tooltip":"End date for the query.","uiStudio.history.filter.actionAll.tooltip":"Show every kind of action.","uiStudio.history.filter.actionCreate.tooltip":"Show only actions that created a new UI.","uiStudio.history.filter.actionUpdate.tooltip":"Show only actions that updated an existing UI.","uiStudio.history.filter.actionDelete.tooltip":"Show only actions that deleted a UI.","uiStudio.history.filter.dateAll.tooltip":"Show the full history.","uiStudio.history.filter.today.tooltip":"Show only changes from today.","uiStudio.history.filter.yesterday.tooltip":"Show only changes from yesterday.","uiStudio.history.filter.last7Days.tooltip":"Show changes from the last 7 days.","uiStudio.history.filter.last30Days.tooltip":"Show changes from the last 30 days.","uiStudio.history.filter.customRange.tooltip":"Pick a custom start and end date.","uiStudio.history.filter.reset.tooltip":"Reset all filters to defaults.","uiStudio.history.title.tooltip":"A timeline of every UI change made by AI.","uiStudio.history.clear.tooltip":"Delete every change record for this project. The actual UI in Roblox Studio is not affected.","uiStudio.history.row.compare.tooltip":"Compare the before and after screens. Click to open the full comparison view.","uiStudio.history.row.extraPaths.tooltip":"Number of additional UIs changed in this action.","uiStudio.history.row.noBeforeState.tooltip":"No capture saved before this change.","uiStudio.history.row.noAfterState.tooltip":"No capture saved after this change.","uiStudio.history.row.affectedPaths.tooltip":"Number of UIs affected by this action.","uiStudio.history.row.mutations.tooltip":"Number of detailed changes (e.g., property edits).","uiStudio.history.row.qualityPlan.tooltip":"この変更で使用したブリーフのデザイン方針です。","uiStudio.history.row.designCheck.tooltip":"変更後のDesign Check改善提案の要約です。","uiStudio.history.row.toggleDetails.tooltip":"Show or hide a per-line breakdown of what changed.","uiStudio.compare.before.tooltip":"The screen saved just before AI made the change.","uiStudio.compare.after.tooltip":"The screen saved just after AI made the change.","uiStudio.compare.path.tooltip":"The UI instance path for this screen.","uiStudio.storage.title.tooltip":"Disk usage of UI Studio change records and screenshots.","uiStudio.storage.usageLabel.tooltip":"Disk space currently used by UI Studio for this project.","uiStudio.storage.historyBytes.tooltip":"Space taken by change record data (JSON).","uiStudio.storage.snapshotBytes.tooltip":"Space taken by captured PNG image files.","uiStudio.storage.requestCount.tooltip":"Number of actions where AI changed the UI.","uiStudio.storage.mutationCount.tooltip":"Number of detail changes inside actions (one property edit = 1).","uiStudio.storage.snapshotCount.tooltip":"Number of saved capture image files.","uiStudio.storage.lastRun.tooltip":"When the auto-cleanup policy last ran, and what it removed.","uiStudio.cleanup.label.tooltip":"Manually clean up change records and captures whenever you want.","uiStudio.cleanup.keep7.tooltip":"Delete change records and captures older than 7 days.","uiStudio.cleanup.keep30.tooltip":"Delete change records and captures older than 30 days.","uiStudio.cleanup.deleteAll.tooltip":"Delete every change record and capture for this project. The actual UI in Roblox Studio is not affected.","uiStudio.cleanup.policy.title.tooltip":"Rules that automatically remove old or large captures.","uiStudio.cleanup.policy.modeOff.tooltip":"Turn off auto-cleanup. Data stays until you remove it manually.","uiStudio.cleanup.policy.modeAge.tooltip":"Automatically delete data older than the configured number of days.","uiStudio.cleanup.policy.modeSize.tooltip":"When total usage exceeds the limit, the oldest data is removed first.","uiStudio.cleanup.policy.agePreset.tooltip":"Delete data older than this many days.","uiStudio.cleanup.policy.ageInput.tooltip":"Enter any value between 1 and 365 days.","uiStudio.cleanup.policy.sizePreset.tooltip":"Keep total usage under this size.","uiStudio.cleanup.policy.sizeInput.tooltip":"Enter any value between 50 MB and 10000 MB (10 GB).","uiStudio.cleanup.policy.cascade.tooltip":"Also delete the capture images linked to those records. If off, the images stay.","uiStudio.cleanup.policy.save.tooltip":"Save the current cleanup rule. It runs in the background from then on.","uiStudio.cleanup.policy.runNow.tooltip":"Run the current rule once now, without waiting for the next scheduled run.","settings.license.refresh.tooltip":"Re-fetch the current state from the license server. Useful when a billing change hasn't appeared yet.","settings.license.reset.tooltip":"Remove the currently registered license key. Use this before activating with a different key.","settings.license.activate.tooltip":"Activate Pro features with the entered license key.","tier.upgrade.tooltip":"Pro機能と購入オプションを確認します。","settings.language.auto.tooltip":"Follow the operating system's language. Falls back to English when not supported.","settings.dataHistory.open.tooltip":"Open the page that shows this item in detail.","settings.dataHistory.clear.tooltip":"Delete only the records saved for this item. Roblox Studio data is not changed.","settings.dataHistory.toggle.tooltip":"Collapse or expand this section.","settings.dataHistory.toolsActivity.metric.tooltip":"Number of saved tool runs and the disk space they use.","settings.dataHistory.toolStats.metric.tooltip":"Aggregated total runs and session counts.","settings.dataHistory.syncLog.metric.tooltip":"Number of saved sync events and the disk space they use.","settings.dataHistory.playtestReports.metric.tooltip":"Number of saved playtest reports and the disk space they use.","settings.dataHistory.projectChanges.metric.tooltip":"Number of saved project change summaries and the disk space they use.","settings.dataHistory.connectionLog.metric.tooltip":"Number of saved connection events and the disk space they use.","settings.dataHistory.uiStudio.metric.tooltip":"UI Studio change record and capture counts, plus total disk usage.","uiStudio.designCheckResultsTitle":"Design Check の提案","uiStudio.designCheckResultsTitle.tooltip":"All improvement suggestions found in this capture.","uiStudio.actions.designCheckAgain":"もう一度確認","uiStudio.actions.designCheckRunning":"提案を確認中...","uiStudio.actions.designCheckRunningDetail":"完了すると優先確認、確認推奨、任意改善の件数が表示されます。","uiStudio.actions.designCheckComplete":"提案の確認が完了しました","uiStudio.actions.designCheckNoSnapshotSaved":"この操作では新しいスクリーンショットファイルは保存されません。","uiStudio.sample.designCheck.contrast":"Text contrast is below {expected} (current {actual}). Adjust TextColor3 or BackgroundColor3.","uiStudio.sample.designCheck.touchTarget":"Touch target is below {expected} (current {actual}). Increase Size or padding.","uiStudio.sample.designCheck.minTextSize":"TextSize is below {expected} (current {actual}). Increase it for readability.","uiStudio.gallery.priorityHighBadge.tooltip":"優先確認する提案の数です。クリックして詳細を確認します。","uiStudio.gallery.priorityMediumBadge.tooltip":"確認推奨の提案数です。","uiStudio.priorityMedium":"確認推奨","uiStudio.mediumPrioritySection":"確認推奨","uiStudio.gallery.priorityLowBadge.tooltip":"任意改善の提案数です。","tier.banner.progressLabel":"Pro / Total","uiStudio.error":"エラー","uiStudio.analysis.expandChildren":"子ターゲットを表示","uiStudio.analysis.openDetail":"詳細を開く","uiStudio.analysis.childTargets":"子ターゲット","uiStudio.analysis.childDetailHint":"子ターゲットの詳細を開く","uiStudio.compare.before":"変更前","uiStudio.compare.after":"変更後","uiStudio.history.drawer.changeDetails":"変更詳細","uiStudio.gallery.cardCheckbox":"スクリーンショットを選択","sidebar.assets":"Assets","assets.title":"Assets","assets.experimental":"Experimental","assets.subtitle":"Browse local originals, upload to Roblox, and inspect synced usage by place.","assets.scope.label":"Asset scope","assets.scope.place":"Current Place","assets.scope.shared":"Shared","assets.count.shown":"Shown assets: {count}","assets.category.filter":"Category","assets.category.all":"All","assets.category.image":"Images","assets.category.decal":"Decals","assets.category.audio":"Audio","assets.category.mesh":"Meshes","assets.category.model":"Models","assets.category.rbxm":"RBXM","assets.category.video":"Videos","assets.category.animation":"Animations","assets.category.comingSoon":"Coming soon","assets.status.localOnly":"Local only","assets.status.uploading":"Uploading","assets.status.processing":"Processing","assets.status.uploaded":"Uploaded","assets.status.failed":"Failed","assets.status.superseded":"Superseded","assets.rescan":"Rescan","assets.rescan.tooltip":"Scan the selected inbox folder.","assets.rescan.chooseCategory":"Choose a category before rescanning.","assets.rbxmGuide.title":"Save RBXM from Studio","assets.rbxmGuide.body":"Select objects in Roblox Studio, then use WEPPY Plugin > Assets to save the selection as a local RBXM asset.","assets.rbxmGuide.thumbnail":"The plugin save flow includes a thumbnail option, and saved RBXM assets appear here for management, upload, and insertion.","assets.exportSelection":"Export Studio selection","assets.exportSelection.tooltip":"Export the current Studio selection as a local .rbxm asset.","assets.exportSelection.chooseCategory":"Choose RBXM before exporting a Studio selection.","assets.upload.open":"Upload","assets.upload.open.tooltip":"Upload this local file to Roblox through Open Cloud.","assets.upload.selectFirst":"Select an asset first.","assets.upload.title":"Upload asset","assets.upload.checkingSettings":"Checking upload settings...","assets.upload.settingsLoadFailed":"Failed to load upload settings.","assets.upload.settingsRequired":"Upload settings required","assets.upload.settingsRequired.apiKey":"Save an Open Cloud API key before uploading.","assets.upload.settingsRequired.toggle":"Enable Open Cloud upload before uploading.","assets.upload.settingsRequired.creator":"Save a default Creator before uploading.","assets.upload.openSettings":"Open Asset Library settings","assets.upload.creator":"Creator","assets.upload.creatorType":"Creator type","assets.upload.creatorId":"Creator ID","assets.upload.envCreatorHelp":"Environment API keys cannot save a default Creator here. Enter the Creator for this upload.","assets.upload.displayNameHelp":"Saved to Roblox as the asset display name.","assets.upload.descriptionHelp":"Saved to Roblox as the asset description.","assets.upload.creatorHelp":"Used by Open Cloud as the owner of the uploaded asset.","assets.upload.creatorTypeHelp":"Sent to Open Cloud as the Creator type.","assets.upload.creatorIdHelp":"Sent to Open Cloud as the User or Group ID that owns the uploaded asset.","assets.upload.submit":"Upload with Roblox Open Cloud","assets.upload.uploading":"Uploading...","assets.upload.noDelete":"WEPPY does not provide Roblox asset deletion.","assets.upload.delay":"Roblox processing and moderation can delay visibility in Studio or Creator Dashboard.","assets.delete.tooltip":"Delete this local Asset Library item.","assets.delete.title":"Delete asset","assets.delete.message":"This removes the local Asset Library files only. Uploaded Roblox assets are not deleted.","assets.creator.user":"User","assets.creator.group":"Group","assets.settings.open":"Open settings","assets.settings.open.tooltip":"Open Roblox upload settings.","assets.settings.title":"Asset Library settings","assets.settings.proOnly":"Roblox upload settings and Open Cloud credential controls are available on Pro.","assets.settings.openCloudToggle":"Open Cloud upload","assets.settings.openCloudToggle.help":"Controls whether server-side Open Cloud upload mutations can run.","assets.settings.apiKey":"Open Cloud API Key","assets.settings.apiKeyGuide":"Create a Roblox API key with Assets Read and Write permissions.","assets.settings.creatorHelp":"Use the numeric user ID from a profile URL or group ID from a group URL.","assets.settings.credential.none":"No API key saved","assets.settings.credential.env":"Environment variable","assets.settings.credential.local":"Local encrypted file","assets.settings.registeredApiKey":"Registered API Key","assets.settings.credentialProfile":"Credential Profile","assets.settings.activeProfileBadge":"Active","assets.settings.field.profile":"Profile","assets.settings.field.apiKey":"API Key","assets.settings.field.storage":"Storage","assets.settings.field.validationStatus":"Validation status","assets.settings.field.creators":"Creators","assets.settings.validation.unknown":"Not tested","assets.settings.validation.valid":"Connected","assets.settings.validation.invalid":"Needs attention","assets.settings.profileSelected":"Open Cloud credential profile selected.","assets.settings.useProfile":"Use profile","assets.settings.replaceApiKey":"Replace API Key","assets.settings.profileLabel":"Profile name (optional)","assets.settings.profileLabel.placeholder":"Studio automation key","assets.settings.profileLabel.help":"Optional. If left blank, WEPPY saves this profile as Open Cloud key automatically.","assets.settings.saveApiKey":"Save API Key","assets.settings.testConnection":"Test Connection","assets.settings.removeApiKey":"Unregister API Key","assets.settings.saveCreator":"Save default Creator","assets.settings.saveCreatorPreset":"Save Creator","assets.settings.addCreator":"Add Creator","assets.settings.addCreator.tooltip.ready":"Add another User or Group Creator preset to this profile.","assets.settings.cancelCreator":"Cancel","assets.settings.defaultCreatorBadge":"Default","assets.settings.makeDefaultCreator":"Make default","assets.settings.unregisterCreator":"Unregister Creator","assets.settings.creatorLabel":"Creator label (optional)","assets.settings.creatorLabel.placeholder":"Main studio group","assets.settings.creatorLabel.help":"Optional. If left blank, WEPPY automatically saves a label like User 123 or Group 456.","assets.settings.action.proRequired":"Asset upload settings are available on Pro.","assets.settings.action.busy":"Wait for the current settings action to finish.","assets.settings.saveApiKey.tooltip.ready":"Save this API key to local encrypted storage.","assets.settings.saveApiKey.tooltip.enter":"Enter an Open Cloud API key to save it locally.","assets.settings.testConnection.tooltip.entered":"Test the entered API key before saving it.","assets.settings.testConnection.tooltip.saved":"Test the saved Open Cloud API key.","assets.settings.testConnection.tooltip.enterOrSaved":"Enter an API key or save one before testing the connection.","assets.settings.removeApiKey.tooltip.ready":"Unregister the locally saved Open Cloud API key from WEPPY.","assets.settings.removeApiKey.tooltip.none":"No local Open Cloud API key is saved.","assets.settings.removeApiKey.tooltip.env":"Environment API keys cannot be removed from Dashboard. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY.","assets.settings.unregisterCreator.tooltip.ready":"Unregister this Creator from the selected profile.","assets.settings.unregisterApiKey.title":"Unregister API Key?","assets.settings.unregisterApiKey.message":"Roblox API key is not revoked. WEPPY only removes the local Credential Profile registration on this device.","assets.settings.unregisterCreator.title":"Unregister Creator?","assets.settings.unregisterCreator.message":"Roblox user or group is not deleted. WEPPY only removes this Creator from the selected API Key profile.","assets.settings.saveCreator.tooltip.ready":"Save this Creator as the default owner for uploads.","assets.settings.saveCreator.tooltip.noLocal":"Save a local Open Cloud API key before saving a default Creator.","assets.settings.saveCreator.tooltip.env":"Environment API keys cannot save a default Creator here. Enter Creator details in the upload dialog.","assets.settings.saveCreator.tooltip.enterId":"Enter a user or group ID before saving the default Creator.","assets.settings.apiKeySaved":"Open Cloud API key saved locally.","assets.settings.apiKeyTested":"Open Cloud API key connection tested.","assets.settings.apiKeyRemoved":"Open Cloud API key unregistered from local storage.","assets.settings.envApiKeyStillActive":"Environment variable credential is still active. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY Dashboard.","assets.settings.defaultCreatorSaved":"Open Cloud default Creator saved locally.","assets.settings.creatorUnregistered":"Creator unregistered from this profile.","assets.settings.creatorUnregisterFailed":"Failed to unregister Creator.","assets.settings.saved":"Upload settings saved.","assets.settings.saveFailed":"Failed to save upload settings.","assets.settings.loadFailed":"Failed to load upload settings.","assets.settings.tested":"Connection tested.","assets.settings.testFailed":"Connection test failed.","assets.settings.removed":"API key unregistered.","assets.settings.removeFailed":"Failed to unregister API key.","assets.basic.notice":"Browse, preview, edit metadata, and scan usage on Basic. Roblox upload controls are available on Pro.","assets.proOnly.tooltip":"Roblox upload is available on Pro.","assets.proOnly.upload":"Roblox upload is available on Pro.","assets.empty.title":"No assets yet","assets.empty.body":"Choose a scope and category, then rescan that inbox folder.","assets.detail.title":"Asset details","assets.detail.displayName":"Display name","assets.detail.description":"Description","assets.detail.save":"Save metadata","assets.detail.refreshStatus":"Refresh","assets.detail.scanUsage":"Scan usage","assets.detail.localFile":"Local file","assets.detail.fileName":"File","assets.detail.category":"Category","assets.detail.scope":"Scope","assets.detail.mimeType":"Type","assets.detail.size":"Size","assets.detail.dimensions":"Dimensions","assets.detail.duration":"Duration","assets.detail.source":"Source path","assets.detail.sha256":"SHA-256","assets.detail.roblox":"Roblox upload status","assets.detail.status":"Status","assets.detail.assetId":"Asset ID","assets.detail.error":"Error","assets.detail.copyAssetId":"Copy Asset ID","assets.detail.copyUri":"Copy URI","assets.detail.studioUri":"Studio URI","assets.detail.robloxWebUrl":"Creator Dashboard URL","assets.detail.copyStudioUri":"Copy Studio URI","assets.detail.copyWebUrl":"Copy configure URL","assets.detail.openRobloxPage":"Open configure page","assets.detail.robloxWebUrlNotice":"Opening this page requires the Roblox account that owns or can manage the uploaded asset.","assets.detail.uploadHistory":"Upload history","assets.detail.usedInPlace":"Where this asset is used in this Place","assets.detail.noUsage":"No local Sync references found yet.","assets.detail.usageSource":"Checked against","assets.detail.usageSource.localSync":"Local Sync files","assets.detail.usageSource.notScanned":"Not checked yet","assets.detail.lastScanned":"Last checked","assets.detail.lastScannedAt":"Last checked: {time}","assets.detail.lastScanned.never":"No check yet","assets.detail.noUsageUnscanned":"Run Scan usage to search local Sync files for this Roblox Asset ID.","assets.detail.noUsageAfterScan":"No references were found in local Sync files during the last check.","assets.detail.noUsageNoRobloxId":"This asset does not have a Roblox Asset ID yet, so usage cannot be checked. Upload it before scanning usage.","assets.detail.technicalDetails":"Technical details","assets.detail.stableId":"Stable ID","assets.detail.sourceKind":"Source kind","assets.detail.createdAt":"Created","assets.detail.updatedAt":"Updated","assets.detail.operationId":"Operation ID","assets.detail.operationPath":"Operation path","assets.detail.versionId":"Version ID","assets.detail.remotePath":"Remote path","assets.detail.moderationState":"Moderation","assets.detail.line":"line {line}","assets.studio.notConnected":"Connect Roblox Studio before using Studio asset actions.","assets.detail.importRbxm":"Insert into Studio","assets.detail.importRbxm.tooltip":"Insert this local RBXM asset into {target} in the connected Studio place.","assets.detail.generateThumbnail":"Generate thumbnail","assets.detail.generateThumbnail.tooltip":"Create or replace the Asset Library thumbnail from Studio.","assets.detail.rbxmOnly":"Studio import is available for .rbxm assets.","assets.detail.rbxmCategoryOnly":"Studio .rbxm actions support models and animations.","assets.detail.thumbnailRbxmOnly":"Thumbnail generation is available for .rbxm model assets.","assets.detail.thumbnailModelOnly":"Thumbnail generation is available for model .rbxm assets.","assets.detail.rbxm":"RBXM contents","assets.detail.rbxmExportedCount":"Exported roots","assets.detail.rbxmClasses":"Classes","assets.detail.rbxmThumbnail":"Thumbnail","assets.detail.studioInsertTarget":"Studio insert target","assets.detail.rbxmRoots":"Root tree","assets.detail.rbxmReferences":"Asset references","assets.detail.rbxmThumbnailAttempts":"Thumbnail attempts","dashboardHelp.button":"Help","dashboardHelp.pageButton.ariaLabel":"Open page help","dashboardHelp.fieldButton.ariaLabel":"Open field help","dashboardHelp.section.canDo":"What you can do here","dashboardHelp.section.needs":"What you need to use it","dashboardHelp.section.links":"Related links","dashboardHelp.overview.title":"Overview help","dashboardHelp.overview.canDo.1":"Check MCP server, WEPPY Plugin, AI Agent, Sync, and recent game changes in one place.","dashboardHelp.overview.needs.1":"Useful status requires the MCP server. Live Studio status also needs WEPPY Plugin connected to the active place.","dashboardHelp.connection.title":"Connection help","dashboardHelp.connection.canDo.1":"Inspect server process details, connected AI agents, Studio plugin clients, and connection log events.","dashboardHelp.connection.needs.1":"The MCP server must be reachable. Plugin rows appear after Studio sends heartbeats.","dashboardHelp.sync.title":"Sync help","dashboardHelp.sync.canDo.1":"Review Studio to local sync status, direction, apply mode, and sync logs.","dashboardHelp.sync.needs.1":"Sync needs an active place and connected WEPPY Plugin. Two-way and reverse workflows depend on Pro.","dashboardHelp.assets.title":"Assets help","dashboardHelp.assets.canDo.1":"Browse local Asset Library files, switch place/shared scope, filter categories, scan usage, insert RBXM into Studio, and upload local assets to Roblox.","dashboardHelp.assets.needs.1":"Upload needs Pro, the Open Cloud upload toggle, a valid API Key, and a Creator. Browse and preview work on Basic.","dashboardHelp.changelog.title":"Changelog help","dashboardHelp.changelog.canDo.1":"Review real game-change sessions extracted from AI actions and sync events.","dashboardHelp.changelog.needs.1":"Entries are scoped to the active place. Basic shows only the latest preview entries.","dashboardHelp.playtest.title":"Playtest help","dashboardHelp.playtest.canDo.1":"Review Playtest results and reports saved by the AI Agent.","dashboardHelp.playtest.needs.1":"Pro shows real stored reports. Basic shows sample preview data. Live active-place confidence needs WEPPY Plugin connected.","dashboardHelp.uiStudio.title":"UI Studio help","dashboardHelp.uiStudio.canDo.1":"Review AI-created UI analysis, improvement suggestions, captures, and before/after history.","dashboardHelp.uiStudio.needs.1":"Pro shows real UI Studio data. Basic shows a bundled sample. New capture/check actions need WEPPY Plugin connected.","dashboardHelp.tools.title":"Tools help","dashboardHelp.tools.canDo.1":"Inspect tool history, status classification, fallback/unsupported/warn/error details, and usage statistics.","dashboardHelp.tools.needs.1":"History and statistics depend on local recording settings and the active place bucket.","dashboardHelp.settings.title":"Settings help","dashboardHelp.settings.canDo.1":"Manage License, hot settings, saved data cleanup, server environment display, and language.","dashboardHelp.settings.needs.1":"License actions need MCP server connection. Server environment values are read-only here. Asset upload controls live in Assets settings.","dashboardHelp.openCloudApiKey.title":"Open Cloud API Key help","dashboardHelp.openCloudApiKey.canDo.1":"WEPPY uses this key only for Roblox Open Cloud requests.","dashboardHelp.openCloudApiKey.needs.1":"Create a Roblox API key in Creator Hub. Add Assets under Access Permissions, then enable both Read and Write operations.","dashboardHelp.openCloudApiKey.needs.2":"Set the key target to the same User or Group that you use as the upload Creator.","dashboardHelp.openCloudApiKey.needs.3":"The raw key is encrypted on this device. It is not sent to WEPPY servers, and it is not stored in any other external storage, browser storage, telemetry, logs, tool history, or Asset Library metadata.","dashboardHelp.openCloudApiKey.link.apiKeys":"Roblox API keys","dashboardHelp.openCloudApiKey.link.assetsGuide":"Assets API usage guide","dashboardHelp.openCloudApiKey.link.assetsReference":"Assets API reference","dashboardHelp.openCloudCreatorId.title":"Creator ID help","dashboardHelp.openCloudCreatorId.canDo.1":"The default Creator decides which User or Group owns newly uploaded Roblox assets.","dashboardHelp.openCloudCreatorId.needs.1":"For User, sign in to roblox.com, open your profile from your avatar or username, then copy only the number between /users/ and /profile in the browser URL.","dashboardHelp.openCloudCreatorId.needs.2":"For Group, open the Roblox group or community page, then copy only the number after /groups/ or /communities/ in the browser URL.","dashboardHelp.openCloudCreatorId.needs.3":"Paste only the numeric ID in Creator ID. Do not paste the full URL, rbxassetid://, User, or Group text.","dashboardHelp.openCloudCreatorId.link.creatorId":"Creator ID reference","dashboardHelp.openCloudCreatorId.link.userId":"User ID reference","dashboardHelp.openCloudCreatorId.link.groups":"Roblox groups","dashboardHelp.openCloudCreatorId.link.groupsApi":"Groups Cloud API","assets.settings.apiKey.inlineHelp":"WEPPY uses this key only for Roblox Open Cloud requests. The key is encrypted on this device and is not sent to WEPPY servers or stored in any other external storage.","assets.settings.creatorId.inlineHelp":"Default owner for new Roblox assets: your User ID or a Group ID.","common.close":"閉じる","dashboardHelp.section.currentState":"Check based on current status","dashboardHelp.overview.currentState.serverOnly":"Open Roblox Studio and start WEPPY Plugin so live place data can appear.","dashboardHelp.overview.currentState.default":"If the server disconnects, restart MCP or wait for the automatic reconnect.","dashboardHelp.connection.currentState.1":"If Plugin is missing, open Roblox Studio and run WEPPY Plugin. If AI Agent is missing, reconnect the MCP server from your AI tool.","dashboardHelp.sync.currentState.pluginMissing":"Connect WEPPY Plugin in Studio before using live sync details.","dashboardHelp.sync.currentState.basic":"Activate Pro to use bidirectional or reverse sync.","dashboardHelp.sync.currentState.default":"Use the sync log to diagnose stuck or failed sync activity.","dashboardHelp.assets.currentState.basic":"Activate Pro before uploading to Roblox.","dashboardHelp.assets.currentState.uploadDisabled":"Turn on Open Cloud upload in Assets settings.","dashboardHelp.assets.currentState.noCredential":"Save and test an Open Cloud API Key.","dashboardHelp.assets.currentState.noCreator":"Save a default Creator ID or enter Creator details during upload.","dashboardHelp.assets.currentState.default":"Open an asset detail dialog to start upload or usage scan.","dashboardHelp.changelog.currentState.1":"If the list is empty, ask the AI Agent to make a game change. Clear only deletes saved history records, not Studio objects.","dashboardHelp.playtest.currentState.basic":"Activate Pro to use real Playtest history.","dashboardHelp.playtest.currentState.default":"Ask the AI Agent to run a Playtest when no report is available.","dashboardHelp.uiStudio.currentState.basic":"Activate Pro to use live UI Studio previews.","dashboardHelp.uiStudio.currentState.default":"Ask the AI Agent to capture the UI or recheck improvement suggestions, then copy follow-up requests back to the AI chat.","dashboardHelp.tools.currentState.1":"If no records appear, check Settings > General and confirm history/statistics are enabled. Expand failed rows to inspect input, permission, or connection causes.","dashboardHelp.settings.currentState.1":"Activate a license for Pro features. Change environment values outside WEPPY Dashboard, then restart MCP. Review delete confirmations before clearing saved data.","dashboardHelp.openCloudApiKey.currentState.saved":"Use Test Connection to confirm the saved key still works.","dashboardHelp.openCloudApiKey.currentState.empty":"Create an API key in Roblox Creator Hub, paste it here, then save and test it.","dashboardHelp.openCloudCreatorId.currentState.saved":"Keep this value if new assets should continue using the same owner.","dashboardHelp.openCloudCreatorId.currentState.empty":"Choose User or Group, paste the numeric ID, then save the default Creator.","page.overview.title":"Overview","page.overview.description":"Check server, plugin, agent, sync, and recent game-change status in one place.","page.connection.title":"Connection","page.connection.description":"Inspect MCP server, AI agent, Studio plugin, and connection log status.","page.sync.title":"Sync","page.sync.description":"Monitor Studio to local sync status, direction, apply mode, and recent sync logs.","page.changelog.title":"Changelog","page.changelog.description":"Review game-change sessions captured from AI actions and sync events.","page.playtest.title":"Playtest","page.playtest.description":"Review automated playtest runs, saved reports, and result history.","page.uiStudio.title":"UI Studio","page.uiStudio.description":"Review UI captures, improvement suggestions, and before/after change history.","page.tools.title":"Tools","page.tools.description":"Inspect tool history, outcomes, fallback details, and usage statistics.","page.settings.title":"Settings","page.settings.description":"Manage license, live settings, saved data, server environment, and language.","dashboardHelp.whatsNew.title":"What's New help","dashboardHelp.whatsNew.canDo.1":"Review WEPPY Dashboard, MCP, and Plugin announcements, releases, and change notes.","dashboardHelp.whatsNew.needs.1":"Announcements are bundled locally. Unread state is stored in this browser.","dashboardHelp.whatsNew.currentState.1":"After you visit this page, unread announcements from this visit are marked read when you leave. The top header does not show a duplicate What's New button on this page."},Vf={"sidebar.overview":"Ringkasan","sidebar.changelog":"Riwayat","sidebar.connection":"Koneksi","sidebar.sync":"Sinkronisasi","sidebar.playtest":"Playtest","sidebar.tools":"Alat","sidebar.settings":"Pengaturan","sidebar.ui_studio":"UI Studio","sidebar.gate.l1":"Koneksi server MCP diperlukan.","sidebar.gate.l2":"Koneksi plugin Roblox Studio diperlukan.","header.currentProject":"Proyek saat ini","header.unknownProject":"Proyek tidak dikenal","header.projectRoot.label":"Project Root","header.currentProject.loading":"Memuat project root...","header.currentProject.unavailable":"Project root tidak tersedia","header.placeNotConnected":"Place belum terhubung","header.currentProject.tooltip":"Folder proyek yang sedang dipilih.","header.currentProject.loading.tooltip":"Informasi project root masih dimuat.","header.currentProject.unavailable.tooltip":"Informasi project root saat ini tidak tersedia.","header.currentProjectSyncRoot.label":"Sync Root","header.currentProjectSyncRoot.loading":"Memuat sync root...","header.currentProjectSyncRoot.unavailable":"Sync root tidak tersedia","header.currentProjectSyncRoot.tooltip":"Folder sync root saat ini untuk proyek yang dipilih.","header.currentProjectSyncRoot.loading.tooltip":"Informasi sync root masih dimuat.","header.currentProjectSyncRoot.unavailable.tooltip":"Informasi sync root saat ini tidak tersedia.","header.testFiles.label":"Test Files","header.testFiles.unavailable":"Path file test tidak tersedia.","header.testFiles.tooltip":"Direktori file playtest saat ini untuk place yang dipilih.","header.places.title":"Places","header.places.active":"Active","header.places.inactive":"Inactive","header.places.pluginRequired":"Koneksi plugin diperlukan","header.places.liveRequired":"Koneksi plugin diperlukan untuk melihat place aktif secara live.","header.place.tooltip":"Place Roblox yang terhubung.","header.placeNotConnected.tooltip":"Place belum terhubung","header.changeProjectRoot":"Ubah project root","header.changeProjectRoot.ariaLabel":"Ubah project root","header.changeProjectRoot.tooltip":"Ubah project root saat ini.","header.changeProjectRoot.disabledTooltip.l0":"Koneksi server MCP diperlukan terlebih dahulu sebelum project root bisa diubah.","header.changeProjectRoot.disabledTooltip.loading":"Informasi project root masih dimuat.","header.changeProjectRoot.disabledTooltip.unavailable":"Informasi project root saat ini tidak tersedia.","header.projectRootModal.initial.title":"Ubah project root","header.projectRootModal.initial.body.connected":"Setelah Anda memilih folder proyek, MCP akan beralih ke project root baru dan konten Studio saat ini akan disinkronkan ulang sepenuhnya ke target baru <selected project folder>/weppy-project-sync.","header.projectRootModal.initial.body.disconnected":"Setelah Anda memilih folder proyek, MCP akan beralih ke project root baru dan menggunakan <selected project folder>/weppy-project-sync sebagai target sync berikutnya.","header.projectRootModal.initial.nextSyncRoot":"Target sync baru setelah pemilihan","header.projectRootModal.initial.nextSyncRoot.placeholder":"<selected project folder>/weppy-project-sync","header.projectRootModal.initial.warningStop":"Sync saat ini berhenti seketika.","header.projectRootModal.initial.warningFreshSync":"Konten Studio saat ini akan digunakan untuk membuat fresh full sync di target baru.","header.projectRootModal.initial.warningNoMove":"Folder sync lama tidak dipindahkan secara otomatis.","header.projectRootModal.initial.warningDeferredSync":"Jika Studio belum terhubung, full resync akan dimulai saat plugin terhubung berikutnya.","header.projectRootModal.confirm.title":"Konfirmasi project root baru","header.projectRootModal.confirm.body":"Tinjau folder proyek yang dipilih sebelum menerapkan perubahan.","header.projectRootModal.confirm.projectRoot":"Folder proyek yang dipilih","header.projectRootModal.confirm.syncRoot":"Target sync baru","header.projectRootModal.confirm.warningNoMove":"Folder sync yang ada tidak dipindahkan secara otomatis.","header.projectRootModal.pick":"Pilih folder","header.projectRootModal.apply":"Terapkan perubahan","header.projectRootModal.cancel":"Batal","header.projectRootModal.error":"Gagal mengubah project root.","status.online":"Online","status.offline":"Offline","status.idle":"Menunggu","status.syncing":"Menyinkronkan","status.error":"Error","status.initializing":"Menginisialisasi","level.l0.title":"Server terputus","level.l0.message":"WEPPY Dashboard terbuka tetapi server MCP telah berhenti atau tidak merespons.","level.l1.title":"Server terhubung","level.l1.hint":"Periksa: Apakah Roblox Studio berjalan? Apakah plugin terinstal?","level.l2.ok":"Studio terhubung","tier.basic":"Basic","tier.basic.tooltip":"Tier Basic dengan kumpulan fitur WEPPY Dashboard standar.","tier.pro":"Pro","tier.pro.tooltip":"Tier Pro dengan kumpulan fitur WEPPY Dashboard lengkap.","tier.mixed":"Campuran","tier.upgrade":"Lihat Pro","tier.banner.save":"Hemat token AI dengan Pro!","tier.tool.query_instances.desc":"Kueri instance, jelajahi anak/keturunan, info kelas, cari berdasarkan nama dan kelas. Pro: pohon file, struktur proyek, pencarian berdasarkan properti dan tag.","tier.tool.mutate_instances.desc":"Buat, hapus, klon, pindah, ganti nama, dan pivot instance. Pro: pembuatan pohon, pembuatan/penghapusan/duplikasi massal.","tier.tool.manage_properties.desc":"Lihat dan atur properti, atribut, dan tag. Pro: nilai kalkulasi dan relatif, lihat/atur massal, modifikasi massal anak.","tier.tool.manage_scripts.desc":"Baca, tulis, buat, hapus, edit baris, dan cari di script. Pro: penggantian massal antar script.","tier.tool.manage_ui.desc":"Khusus Pro. Buat atau perbaiki menu, HUD, tombol, label, dan panel gambar bergaya game, lalu tangkap layar dan tinjau saran peningkatan.","tier.tool.manage_ui.action.design_brief":"Rencanakan arah UI","tier.tool.manage_ui.action.create_tree":"Buat UI baru","tier.tool.manage_ui.action.update":"Perbarui UI yang ada","tier.tool.manage_ui.action.delete":"Hapus UI","tier.tool.manage_ui.action.preview":"Tangkap layar UI","tier.tool.manage_ui.action.check":"Tinjau saran peningkatan","tier.tool.manage_lighting.desc":"Khusus Pro. Pengaturan pencahayaan, atmosfer, langit, properti terrain, dan waktu.","tier.tool.manage_selection.desc":"Lihat, atur, dan hapus seleksi. Pro: konteks, detail, tambah/hapus item, pantau perubahan.","tier.tool.manage_camera.desc":"Info kamera, fokus berdasarkan jalur atau koordinat, saran tampilan.","tier.tool.manage_tween.desc":"Khusus Pro. Buat, putar, jeda, dan batalkan tween untuk animasi halus.","tier.tool.manage_audio.desc":"Khusus Pro. Putar, hentikan, jeda, dan lanjutkan suara. Atur listener audio.","tier.tool.manage_animation.desc":"Khusus Pro. Muat, putar, dan hentikan animasi. Lihat track humanoid/pengontrol.","tier.tool.manage_physics.desc":"Khusus Pro. Daftarkan grup tabrakan, atur tabrakan antar grup, daftar grup.","tier.tool.manage_effects.desc":"Khusus Pro. Pancarkan partikel, hapus semua, aktifkan/nonaktifkan efek.","tier.tool.manage_terrain.desc":"Khusus Pro. Isi bentuk, hapus wilayah, ganti material, kelola warna, baca/tulis voxel, pembuatan prosedural, pemulusan.","tier.tool.spatial_query.desc":"Khusus Pro. Raycast, cari tanah, periksa penempatan, pindai area, cari area datar dan titik spawn, analisis kemampuan jalan, peta spasial, deteksi tabrakan.","tier.tool.manage_assets.desc":"Khusus Pro. Sisipkan model, lihat info aset, cari di toko kreator, sisipkan model/paket gratis, ekspor.","tier.tool.manage_sync.desc":"Khusus Pro. Status sinkronisasi, konfigurasi, riwayat, arah, baca/tulis file tersinkronisasi.","tier.tool.workspace_state.desc":"Khusus Pro. Sinkronisasi penuh, tangkapan layar, perubahan terbaru, info viewport, metadata, manajemen cache.","tier.tool.manage_logs.desc":"Kueri log terfilter, polling inkremental, hapus buffer, kueri error terbaru.","tier.tool.system_info.desc":"Status koneksi, verifikasi tier. Pro: info tempat, daftar layanan, pengaturan Studio, kontrol playtest, pengujian otomatis.","tier.tool.manage_studio.desc":"Khusus Pro. Alihkan pengaturan tampilan editor Studio seperti preview UI untuk screenshot dan QA; ini mengubah sesi Studio, bukan objek UI game.","tier.tool.batch_execute.desc":"Khusus Pro. Eksekusi beberapa perintah sekaligus. Pemrosesan berurutan dengan opsi lanjut saat error.","tier.tool.execute_luau.desc":"Khusus Pro. Jalankan kode Luau di sandbox Roblox Studio.","connection.server.title":"Status Server","connection.server.version":"Versi","connection.server.version.tooltip":"Versi server MCP yang terpasang.","connection.server.pid":"PID","connection.server.pid.tooltip":"Pengenal proses dari sistem operasi.","connection.server.uptime":"Waktu aktif","connection.server.uptime.tooltip":"Waktu yang berlalu sejak server MCP dimulai.","connection.server.session":"Sesi","connection.server.session.tooltip":"Pengenal sesi MCP saat ini.","connection.server.exec":"Eksekutabel","connection.server.exec.tooltip":"Path eksekutabel yang digunakan untuk menjalankan server MCP.","connection.reconnect":"Hubungkan ulang","connection.checkSettings":"Periksa pengaturan","connection.agents.title":"Agen AI","connection.agents.name":"Agen","connection.agents.cwd":"Direktori kerja","connection.agents.cwd.tooltip":"Direktori kerja saat ini milik agen AI yang terhubung.","connection.agents.projectRoot":"Root Proyek","connection.agents.projectRoot.tooltip":"Jalur proyek otoritatif untuk kepemilikan sinkronisasi","connection.agents.projectRoot.unresolved":"Belum terselesaikan","connection.agents.connected":"Terhubung","connection.agents.unknown":"Tidak diketahui","connection.agents.none":"Tidak ada agen terhubung","connection.plugins.title":"Plugin","connection.plugins.place":"Place","connection.plugins.clientId":"ID Klien","connection.plugins.clientId.tooltip":"Pengenal unik klien plugin untuk koneksi Studio ini.","connection.plugins.lastSeen":"Terakhir terlihat","connection.plugins.lastSeen.tooltip":"Heartbeat terbaru yang diterima dari plugin.","connection.plugins.version":"Versi","connection.plugins.version.tooltip":"Versi plugin terpasang yang dilaporkan oleh Studio.","connection.plugins.none":"Tidak ada plugin terhubung","connection.log.title":"Log Koneksi","connection.log.empty":"Belum ada event","connection.time.secondsAgo":"dtk lalu","connection.time.minutesAgo":"mnt lalu","connection.time.hoursAgo":"jam lalu","common.loading":"Memuat...","common.retry":"Coba lagi","common.reconnecting":"Menghubungkan ulang...","common.expand":"Perluas","common.collapse":"Ciutkan","tools.tab.history":"Riwayat","tools.tab.statistics":"Statistik","tools.tab.failures":"Kegagalan","tools.col.time":"Waktu","tools.col.time.tooltip":"Waktu ketika eksekusi alat dicatat.","tools.col.toolAction":"Alat.Aksi","tools.col.toolAction.tooltip":"Nama alat dan aksi yang dijalankan.","tools.col.duration":"Durasi","tools.col.duration.tooltip":"Berapa lama alat menyelesaikan eksekusi.","tools.col.status":"Status","tools.col.status.tooltip":"Hasil dari eksekusi alat yang tercatat.","tools.col.tier":"Tier","tools.col.tier.tooltip":"Tier lisensi yang dibutuhkan untuk alat atau aksi ini.","tools.col.tierStats.tooltip":"Ringkasan Basic, Pro, atau Mixed untuk baris statistik alat ini.","tools.col.tool":"Alat","tools.col.tool.tooltip":"Nama alat konsolidasi pada tabel statistik.","tools.col.calls":"Panggilan","tools.col.calls.tooltip":"Jumlah total panggilan yang tercatat untuk alat ini.","tools.col.ok":"OK","tools.col.ok.tooltip":"Jumlah eksekusi sukses langsung.","tools.col.fallback":"FALLBACK","tools.col.fallback.tooltip":"Jumlah eksekusi yang berhasil melalui fallback.","tools.col.unsupported":"UNSUPPORTED","tools.col.unsupported.tooltip":"Jumlah eksekusi yang diblokir tanpa fallback.","tools.col.warn":"WARN","tools.col.warn.tooltip":"Jumlah kegagalan yang diperkirakan karena input, status proyek, kebijakan Roblox, atau kode pengguna.","tools.col.err":"GAGAL","tools.col.err.tooltip":"Jumlah eksekusi yang berakhir gagal.","tools.col.okRate":"% Sukses","tools.col.okRate.tooltip":"Persentase panggilan yang selesai dengan sukses.","tools.col.avgTime":"Waktu rata-rata","tools.col.avgTime.tooltip":"Rata-rata waktu eksekusi dari panggilan yang tercatat.","tools.col.error":"Error","tools.filter.tool":"Alat","tools.filter.all":"Semua","tools.badge.pro":"PRO","tools.badge.pro.tooltip":"Entri ini menggunakan alat atau aksi khusus Pro.","tools.badge.fallback":"FALLBACK","tools.badge.fallback.tooltip":"Aksi Pro yang diminta berhasil melalui fallback Basic.","tools.badge.unsupported":"UNSUPPORTED","tools.badge.unsupported.tooltip":"Aksi Pro yang diminta diblokir dan tidak ada fallback yang dijalankan.","tools.badge.warn":"WARN","tools.badge.warn.tooltip":"Panggilan alat gagal karena masalah input, proyek, kebijakan, atau kode pengguna yang diperkirakan.","tools.badge.err":"GAGAL","tools.badge.err.tooltip":"Eksekusi alat berakhir gagal.","tools.status.ok":"OK","tools.status.ok.tooltip":"Eksekusi alat selesai dengan sukses.","tools.tier.mixed.tooltip":"Alat ini memiliki campuran aksi Basic dan Pro.","tools.detail.params":"Parameter","tools.detail.params.tooltip":"Parameter input yang dikirim pada eksekusi alat ini.","tools.detail.result":"Hasil","tools.detail.result.tooltip":"Payload hasil yang dikembalikan dari eksekusi alat ini.","tools.detail.requestedCommand":"Perintah dikirim","tools.detail.executedCommand":"Perintah dijalankan","tools.detail.alternatives":"Alternatif","tools.detail.blockedMessage":"Alasan diblokir","tools.detail.noFallback":"Tanpa fallback","tools.detail.noFallback.value":"Tidak ada fallback yang dijalankan.","tools.detail.warningMessage":"Pesan peringatan","tools.detail.errorMessage":"Pesan error","tools.clear.history.title":"Hapus riwayat?","tools.clear.history.message":"Tindakan ini akan menghapus permanen riwayat alat untuk place saat ini.","tools.clear.statistics.title":"Hapus statistik?","tools.clear.statistics.message":"Tindakan ini akan mereset permanen statistik alat untuk place saat ini.","tools.detail.error":"Error","tools.page.prev":"Sebelumnya","tools.page.prev.tooltip":"Pindah ke halaman sebelumnya pada riwayat alat.","tools.page.next":"Selanjutnya","tools.page.next.tooltip":"Pindah ke halaman berikutnya pada riwayat alat.","tools.empty.history":"Tidak ada entri riwayat","tools.empty.stats":"Tidak ada statistik alat","tools.empty.failures":"Tidak ada kegagalan","tools.summary.total":"Total","tools.summary.calls":"panggilan","tools.summary.sessions":"Sesi","settings.license.title":"Lisensi","settings.license.title.tooltip":"Status lisensi dan tier langganan saat ini.","settings.license.status":"Status","settings.license.status.tooltip":"Status aktivasi lisensi saat ini.","settings.license.tier":"Tier","settings.license.tier.tooltip":"Tier langganan saat ini untuk fitur WEPPY Dashboard yang tersedia.","settings.license.key":"Kunci","settings.license.key.tooltip":"Kunci lisensi tersamarkan yang saat ini dimuat oleh server.","settings.license.keyValue.tooltip":"Kunci lisensi tersamarkan yang saat ini dimuat oleh server.","settings.license.provider":"Penyedia","settings.license.provider.auto":"auto","settings.license.provider.polar":"polar","settings.license.provider.gumroad":"gumroad","settings.license.provider.tooltip":"Penyedia lisensi yang digunakan untuk memvalidasi kunci ini.","settings.license.providerValue.tooltip":"Penyedia lisensi yang digunakan untuk memvalidasi kunci ini.","settings.license.active":"Aktif","settings.license.active.tooltip":"Status aktivasi lisensi saat ini.","settings.license.status.activeCancelPending.tooltip":"Pembatalan sedang menunggu, tetapi akses Pro tetap aktif hingga periode penagihan saat ini berakhir.","settings.license.inactive":"Tidak aktif","settings.license.inactive.tooltip":"Status aktivasi lisensi saat ini.","settings.license.expired":"Kedaluwarsa","settings.license.expired.tooltip":"Status aktivasi lisensi saat ini.","settings.license.unavailable":"Info lisensi tidak tersedia","settings.license.detail.cancelPending":"Pembatalan telah dijadwalkan. Akses Pro tetap aktif hingga periode penagihan saat ini berakhir.","settings.license.reset":"Reset Lisensi","settings.readOnly":"Hanya baca","settings.readOnly.tooltip":"Bagian ini menampilkan nilai yang tidak bisa diedit dari WEPPY Dashboard.","settings.unavailable":"Pengaturan tidak tersedia","settings.general.title":"Pengaturan umum","settings.general.title.tooltip":"Pengaturan panas yang langsung diterapkan saat diubah.","settings.general.liveApply":"Terapkan langsung","settings.general.liveApply.tooltip":"Perubahan di bagian ini langsung diterapkan tanpa tombol simpan terpisah.","settings.general.applied":"Diterapkan","settings.general.logLevel":"Level log","settings.general.logLevel.tooltip":"Menetapkan seberapa detail WEPPY Dashboard menulis lognya.","settings.general.localHistory":"Perekaman riwayat alat","settings.general.localHistory.tooltip":"Menyimpan riwayat eksekusi alat lokal untuk tampilan riwayat WEPPY Dashboard.","settings.general.localStatistics":"Pengumpulan statistik alat","settings.general.localStatistics.tooltip":"Mengumpulkan statistik penggunaan lokal untuk pelaporan WEPPY Dashboard.","settings.general.contextCapture":"Context Capture","settings.general.contextCapture.tooltip":"When enabled, the WEPPY Dashboard records structured execution context for changelog and playtest views.","settings.general.requestTimeout":"Batas waktu tindakan","settings.general.requestTimeout.tooltip":"Waktu maksimum WEPPY Dashboard menunggu tindakan sebelum dianggap gagal.","settings.general.requestTimeout.unit":"ms","settings.general.requestTimeout.unit.tooltip":"Batas waktu tindakan diukur dalam milidetik.","settings.cold.title":"Lingkungan server","settings.cold.title.tooltip":"Nilai lingkungan server hanya-baca yang dimuat saat startup.","settings.cold.httpPort.tooltip":"Nomor port yang digunakan oleh server HTTP WEPPY Dashboard MCP.","settings.cold.httpHost.tooltip":"Antarmuka host yang diikat oleh server HTTP WEPPY Dashboard MCP.","settings.cold.dashboardAutoOpen.tooltip":"Mengontrol apakah WEPPY Dashboard terbuka otomatis di browser saat server dimulai.","settings.cold.dashboardAutoOpen.value.tooltip":"Perilaku startup saat ini untuk membuka WEPPY Dashboard di browser.","settings.cold.hint":"Atur melalui variabel lingkungan.","settings.language.title":"Bahasa","settings.language.title.tooltip":"Pilih cara teks antarmuka WEPPY Dashboard dilokalkan.","settings.language.dashboard":"Bahasa WEPPY Dashboard","settings.language.dashboard.tooltip":"Mengganti bahasa WEPPY Dashboard atau mengikuti bahasa sistem saat disetel ke Otomatis.","settings.language.auto":"Otomatis","overview.l0.title":"Server MCP terputus","overview.l0.message":"Server MCP tidak merespons. WEPPY Dashboard akan mencoba menghubungkan ulang secara otomatis.","overview.l0.step1":"Periksa apakah proses server MCP sedang berjalan","overview.l0.step2":"Mulai ulang perintah server MCP jika diperlukan","overview.l0.reconnecting":"Menghubungkan ulang otomatis setiap 3 detik...","overview.l0.reconnectBtn":"Hubungkan ulang","overview.l0.settingsBtn":"Periksa pengaturan","overview.l1.pluginGuide":"Plugin Roblox Studio tidak terhubung","overview.l1.check1":"Apakah Roblox Studio sedang berjalan?","overview.l1.check2":"Apakah WEPPY Plugin sudah terinstal?","overview.l1.feedHint":"Perubahan akan muncul di sini setelah plugin terhubung","overview.metric.server":"Server","overview.metric.server.tooltip":"Status runtime dan proses server MCP.","overview.metric.plugin":"Plugin","overview.metric.plugin.tooltip":"Status koneksi dan versi plugin Roblox Studio.","overview.metric.agent":"Agen","overview.metric.agent.tooltip":"Agen coding AI yang terhubung dan status runtime-nya.","overview.metric.agent.instancesUnit":"instansi","overview.metric.sync":"Sinkronisasi","overview.metric.sync.tooltip":"Aktivitas sinkronisasi saat ini antara Studio dan file lokal.","overview.metric.noAgent":"Tidak ada agen","overview.meta.version":"Versi","overview.meta.version.tooltip":"Versi server MCP yang terpasang.","overview.meta.session":"Sesi","overview.meta.session.tooltip":"Pengenal sesi MCP saat ini.","overview.meta.pid":"PID","overview.meta.pid.tooltip":"Pengenal proses dari sistem operasi.","overview.meta.uptime":"Waktu aktif","overview.meta.uptime.tooltip":"Waktu yang berlalu sejak server MCP dimulai.","overview.feed.title":"Perubahan game terbaru","overview.feed.empty":"Tidak ada perubahan terbaru","overview.changelog.title":"Ringkasan perubahan sesi","overview.changelog.entries":"Total","overview.changelog.scripts":"skrip","overview.changelog.instances":"instansi","overview.changelog.properties":"properti","overview.changelog.assets":"aset","overview.tier.title":"Penggunaan tier","changelog.subtitle":"Riwayat perubahan game","changelog.filter.all":"Semua","changelog.filter.active":"Aktif","changelog.filter.completed":"Selesai","changelog.empty":"Belum ada entri riwayat","changelog.basic.limit.title":"Pratinjau Basic hanya menampilkan 3 sesi terbaru","changelog.basic.limit.body":"Upgrade ke Pro untuk melihat timeline changelog lengkap untuk place ini.","changelog.basic.metricLabel":"Changelog terlihat / Total","changelog.basic.visible":"terlihat","changelog.basic.total":"total","changelog.card.active":"Aktif","changelog.card.active.tooltip":"Sesi ini masih menerima perubahan game baru.","changelog.card.completed":"Selesai","changelog.card.completed.tooltip":"Sesi ini sudah berakhir dan tidak ada perubahan baru yang diharapkan.","changelog.card.bootstrapStatus":"Inisialisasi","changelog.card.bootstrapStatus.tooltip":"Sesi ini hanya berisi tangkapan layar bootstrap sinkronisasi awal.","changelog.card.inProgress":"sedang berlangsung","changelog.card.noChanges":"Belum ada perubahan","changelog.card.noChanges.tooltip":"Belum ada perubahan game yang diekstrak untuk sesi ini.","changelog.card.bootstrapSummary":"Snapshot sinkronisasi awal","changelog.card.bootstrapSummary.tooltip":"Penulisan sinkronisasi file awal diringkas menjadi satu baris tangkapan layar bootstrap.","changelog.card.sessionIntent":"Session intent","changelog.card.scripts":"skrip","changelog.card.scripts.tooltip":"Perubahan skrip yang terjadi di sesi ini.","changelog.card.instances":"instansi","changelog.card.instances.tooltip":"Perubahan pembuatan, penghapusan, pemindahan, atau kloning instansi di sesi ini.","changelog.card.modified":"diubah","changelog.card.created":"dibuat","changelog.card.deleted":"dihapus","changelog.card.moved":"dipindahkan","changelog.card.propertiesChanged":"properti diubah","changelog.card.propertiesChanged.tooltip":"Perubahan nilai properti yang tercatat untuk sesi ini.","changelog.card.lightingConfigured":"Pencahayaan dikonfigurasi","changelog.card.lightingConfigured.tooltip":"Pencahayaan atau pengaturan atmosfer berubah di sesi ini.","changelog.card.terrainConfigured":"Terrain dikonfigurasi","changelog.card.terrainConfigured.tooltip":"Data terrain atau pengaturan terrain berubah di sesi ini.","changelog.card.assetsInserted":"aset disisipkan","changelog.card.assetsInserted.tooltip":"Aset yang dimasukkan ke place selama sesi ini.","changelog.category.script":"Skrip","changelog.category.instance":"Instansi","changelog.category.property":"Properti","changelog.category.lighting":"Pencahayaan","changelog.category.terrain":"Terrain","changelog.category.asset":"Aset","changelog.detail.changeSummary":"Ringkasan perubahan","changelog.detail.changeSummary.tooltip":"Jumlah perubahan game yang diekstrak dan dikelompokkan per kategori untuk sesi ini.","changelog.detail.changeTimeline":"Timeline perubahan","changelog.detail.changeTimeline.tooltip":"Daftar kronologis perubahan game yang diekstrak untuk sesi ini.","changelog.detail.context.title":"Context Summary","changelog.detail.context.tooltip":"Structured execution context captured for this changelog session.","changelog.detail.verification.title":"Verification","changelog.detail.verification.tooltip":"Verification signals linked to this changelog session.","changelog.detail.verification.label":"Result","changelog.detail.verification.status":"Status","changelog.detail.verification.timestamp":"Recorded at","changelog.detail.beforeAfter":"Sebelum & Sesudah","changelog.detail.filterCategory":"Kategori","changelog.detail.filterCategory.tooltip":"Filter timeline ke satu kategori perubahan.","changelog.detail.confidence.exact":"Tepat","changelog.detail.confidence.exact.tooltip":"Status sebelum dan sesudah perubahan ini sama-sama terkonfirmasi.","changelog.detail.confidence.partial":"Parsial","changelog.detail.confidence.partial.tooltip":"Hanya sebagian status sebelum dan sesudah perubahan ini yang bisa dikonfirmasi.","changelog.detail.confidence.afterOnly":"Hanya sesudah","changelog.detail.confidence.afterOnly.tooltip":"Hanya status hasil setelah perubahan yang bisa dikonfirmasi.","changelog.detail.confidence.intentOnly":"Hanya niat","changelog.detail.confidence.intentOnly.tooltip":"Hanya aksi yang diminta yang tercatat, bukan status hasilnya.","changelog.detail.confidence.unknown":"Tidak diketahui","changelog.detail.confidence.unknown.tooltip":"Perubahan ini tidak dapat diklasifikasikan dengan yakin dari data yang tersedia.","changelog.detail.noChanges":"Tidak ada perubahan di kategori ini","changelog.detail.backToList":"Kembali ke daftar","changelog.diff.empty":"Tidak ada perbedaan","changelog.diff.unified":"Terpadu","changelog.diff.sideBySide":"Berdampingan","changelog.diff.before":"Sebelum","changelog.diff.after":"Sesudah","sync.overlay.title":"Plugin Roblox Studio diperlukan","sync.overlay.message":"Status sinkronisasi akan tersedia setelah plugin Roblox Studio terhubung.","sync.overlay.check1":"Apakah Roblox Studio sedang berjalan?","sync.overlay.check2":"Apakah WEPPY Plugin sudah terinstal?","sync.status.title":"Status sinkronisasi","sync.status.title.tooltip":"Status sinkronisasi Studio dan file lokal untuk place ini.","sync.status.forwardOnly":"Hanya maju","sync.status.forwardOnly.tooltip":"Tier Basic hanya mengizinkan sinkronisasi maju dari Studio ke lokal.","sync.status.place":"Place","sync.status.place.tooltip":"Nama place Roblox yang terhubung beserta ID place-nya.","sync.status.path":"Path","sync.status.path.tooltip":"Root sistem file lokal yang saat ini dipakai untuk output sinkronisasi.","sync.status.instances":"Instansi","sync.status.instances.tooltip":"Jumlah total instance Roblox yang disinkronkan di mirror lokal.","sync.status.scripts":"Skrip","sync.status.scripts.tooltip":"Jumlah total file skrip yang saat ini diindeks untuk place ini.","sync.status.state":"Status","sync.status.state.tooltip":"Status runtime sinkronisasi saat ini yang dilaporkan server.","sync.directions.title":"Arah sinkronisasi","sync.directions.title.tooltip":"Arah sinkronisasi per kategori dan cara penerapannya antara Local dan Studio.","sync.directions.type":"Tipe","sync.directions.type.tooltip":"Kategori sinkronisasi yang dipengaruhi aturan ini.","sync.directions.direction":"Arah","sync.directions.direction.tooltip":"Menunjukkan apakah tiap kategori sinkron dari Studio, ke Studio, atau dua arah.","sync.directions.applyMode":"Mode penerapan","sync.directions.applyMode.tooltip":"Cara perubahan sinkronisasi masuk diterapkan untuk kategori ini.","sync.directions.cat.scripts":"Skrip","sync.directions.cat.values":"Nilai","sync.directions.cat.containers":"Kontainer","sync.directions.cat.data":"Data","sync.directions.cat.services":"Layanan","sync.directions.endpoint.local":"Local","sync.directions.endpoint.local.tooltip":"File lokal di disk selalu ditampilkan di sisi kiri rel arah.","sync.directions.endpoint.studio":"Studio","sync.directions.endpoint.studio.tooltip":"Roblox Studio selalu ditampilkan di sisi kanan rel arah.","sync.directions.mode.manual":"Manual","sync.directions.mode.manual.tooltip":"Menerapkan perubahan sinkronisasi hanya saat Anda memicunya secara manual.","sync.directions.mode.auto":"Otomatis","sync.directions.mode.auto.tooltip":"Menerapkan perubahan sinkronisasi otomatis saat pembaruan datang.","sync.directions.tooltip.forward.body":"Perubahan dari Studio hanya disinkronkan ke file lokal","sync.directions.tooltip.bidirectional.body":"Sinkronisasi dua arah antara Local dan Studio","sync.directions.tooltip.reverse.body":"Dorong perubahan file lokal ke Studio","sync.directions.tooltip.proRequired":"Pro diperlukan pada tier Basic","sync.directions.dir.forward":"maju","sync.directions.dir.bidirectional":"dua arah","sync.directions.dir.reverse":"mundur","sync.log.title":"Log sinkronisasi","sync.log.empty":"Tidak ada event sinkronisasi","sync.log.type.write":"TULIS","sync.log.type.write.tooltip":"Output sinkronisasi baru ditulis ke disk.","sync.log.type.update":"PERBARUI","sync.log.type.update.tooltip":"File atau instance yang sudah tersinkron diperbarui.","sync.log.type.delete":"HAPUS","sync.log.type.delete.tooltip":"File atau instance tersinkron telah dihapus.","sync.log.type.idle":"IDLE","sync.log.type.idle.tooltip":"Event sinkronisasi dicatat tanpa perubahan file.","sync.upgrade.title":"Lihat sinkronisasi penuh dengan Pro","sync.upgrade.benefit1":"Sinkronisasi dua arah — edit file, otomatis diterapkan ke Studio","sync.upgrade.benefit2":"Sinkronisasi mundur — kirim perubahan file ke Studio","sync.upgrade.benefit3":"Riwayat sinkronisasi lengkap dan log perubahan detail","sync.upgrade.buy":"Lihat Pro","playtest.status.title":"Status playtest","playtest.status.title.tooltip":"Status sesi playtest Roblox saat ini yang dilaporkan oleh Studio.","playtest.status.mode":"Mode","playtest.status.mode.tooltip":"Mode peluncuran playtest Studio untuk sesi saat ini.","playtest.status.mode.value.tooltip":"Mode playtest Roblox Studio spesifik yang sedang dipakai saat ini.","playtest.status.mode.play":"Main","playtest.status.mode.run":"Jalankan","playtest.status.mode.server":"Server","playtest.status.mode.edit":"Edit","playtest.status.place.tooltip":"Place Roblox yang saat ini terkait dengan sesi playtest ini.","playtest.status.state.running":"Berjalan","playtest.status.state.running.tooltip":"Sesi playtest Roblox saat ini sedang berjalan.","playtest.status.state.paused":"Dijeda","playtest.status.state.paused.tooltip":"Sesi playtest Roblox saat ini sedang dijeda.","playtest.status.state.notRunning":"Tidak berjalan","playtest.status.state.notRunning.tooltip":"Saat ini tidak ada sesi playtest Roblox yang sedang berjalan.","playtest.control.play":"Main","playtest.control.pause":"Jeda","playtest.control.resume":"Lanjutkan","playtest.control.stop":"Berhenti","playtest.history.title":"Riwayat tes","playtest.history.title.tooltip":"Riwayat eksekusi playtest otomatis yang tercatat untuk proyek ini.","playtest.history.empty":"Belum ada hasil tes","playtest.history.mode":"Mode","playtest.history.mode.tooltip":"Mode playtest yang digunakan pada eksekusi tes yang tercatat ini.","playtest.history.status.passed":"Berhasil","playtest.history.status.failed":"Gagal","playtest.history.status.running":"Berjalan","playtest.history.status.unknown":"Tidak diketahui","playtest.history.status.tooltip":"Status hasil yang tercatat untuk eksekusi playtest otomatis ini.","playtest.empty.title":"Belum ada hasil playtest","playtest.empty.message":"Hasil akan muncul di sini setelah agen AI menjalankan Playtest.","playtest.empty.message.before":"Hasil akan muncul di sini setelah agen AI menjalankan Playtest.","playtest.empty.message.after":"","playtest.empty.runTest.tooltip":"Ask the AI Agent to run a Playtest when you need a fresh report.","playtest.report.title":"Laporan terpilih","playtest.report.title.tooltip":"Output detail untuk eksekusi playtest otomatis yang sedang dipilih.","playtest.report.content":"Laporan","playtest.report.content.tooltip":"Ringkasan Markdown untuk eksekusi playtest otomatis yang dipilih.","playtest.report.logs":"Log","playtest.report.logs.tooltip":"Log eksekusi yang ditangkap untuk eksekusi playtest otomatis yang dipilih.","playtest.context.contextId":"Context ID","playtest.context.why":"Why this test ran","playtest.context.expected":"Expected","playtest.context.observed":"Observed","playtest.report.empty":"Tidak ada konten laporan","playtest.basic.icon":"🎮","playtest.basic.title":"Playtest adalah fitur khusus Pro","playtest.basic.desc":"Kontrol playtest dari WEPPY Dashboard, jalankan tes otomatis, dan lihat laporan tes detail.","playtest.basic.benefit1":"Kontrol main/jeda/berhenti sekali klik","playtest.basic.benefit2":"Eksekusi tes otomatis via agen AI","playtest.basic.benefit3":"Riwayat tes dengan pelacakan berhasil/gagal","playtest.basic.benefit4":"Laporan tes detail dalam markdown","playtest.sample.badge":"Pratinjau tampilan playtest Pro","playtest.sample.title":"Anda sedang melihat pratinjau layar playtest yang tersedia setelah upgrade ke Pro.","playtest.sample.message":"Pratinjau ini menggunakan data sampel. Kontrol playtest langsung, pengelolaan riwayat, dan laporan nyata tersedia setelah upgrade ke Pro.","playtest.sample.clearDisabled":"Upgrade ke Pro untuk menghapus riwayat playtest nyata.","playtest.sample.place":"Pratinjau Arena","playtest.sample.history.name":"Sample Arena Smoke Test","playtest.sample.context.why":"Masuk ke arena, bertahan pada fase awal, dan pastikan HUD merespons segera.","playtest.sample.context.expected":"Pemain spawn dengan aman, UI hitung mundur muncul dalam satu detik, dan wave pertama dimulai tanpa error.","playtest.sample.context.observed":"Proteksi spawn bekerja, HUD diperbarui tepat waktu, dan wave pertama selesai tanpa regresi.","playtest.sample.report.markdown":`# Sample Arena Smoke Test
120
+
121
+ - Alur spawn: PASS
122
+ - Hitung mundur HUD: PASS
123
+ - Awal wave: PASS
124
+
125
+ Ini adalah pratinjau sampel. Upgrade ke Pro untuk menjalankan playtest langsung dan menyimpan laporan nyata.`,"playtest.sample.report.logs":`[sample] boot pratinjau playtest
126
+ [sample] proteksi spawn aktif
127
+ [sample] hitung mundur hud dirender
128
+ [sample] wave pertama selesai
129
+ [sample] laporan pratinjau selesai`,"sidebar.whatsNew":"Yang Baru","sidebar.help.group":"Bantuan & Umpan Balik","sidebar.help.bug":"Laporkan bug","sidebar.help.bug.tooltip":"Buat paket diagnostik lokal, lalu buka laporan bug GitHub yang sudah terisi","bugReportDialog.title":"diagnostics.zip dapat membantu investigasi","bugReportDialog.subtitle":"WEPPY membuat zip diagnostik di komputer ini. File ini berisi log Studio, plugin, Sync, dan tool yang dapat membantu kami memahami masalahnya.","bugReportDialog.close":"Close","bugReportDialog.loading":"Preparing diagnostics.zip...","bugReportDialog.error":"Could not create the diagnostics bundle. You can still open GitHub without diagnostics.","bugReportDialog.bundle":"Bundle","bugReportDialog.included":"Included","bugReportDialog.included.none":"No log files found","bugReportDialog.optional":"Kamu tetap bisa mengirim laporan bug tanpa file ini, tetapi melampirkan zip biasanya membantu kami menemukan penyebabnya lebih cepat.","bugReportDialog.attachHow":"Untuk melampirkannya, unduh atau tampilkan zip, lalu tambahkan ke kolom Diagnostics ZIP (optional) di issue GitHub sebelum dikirim.","bugReportDialog.download":"1. Unduh diagnostics.zip","bugReportDialog.reveal":"Reveal in Finder","bugReportDialog.reveal.opening":"Opening...","bugReportDialog.reveal.opened":"Opened location","bugReportDialog.reveal.failed":"Could not open the file location.","bugReportDialog.openGithub":"2. Buka issue GitHub","bugReportDialog.openGithubFallback":"Open GitHub without diagnostics","bugReportDialog.retry":"Try again","bugReportDialog.hint":"Zip dapat berisi log lokal dan konteks proyek. Tinjau sebelum melampirkannya jika ingin dibagikan.","sidebar.help.feature":"Sarankan fitur baru","sidebar.help.feature.tooltip":"Sarankan fitur baru atau peningkatan di GitHub","sidebar.help.discussions":"Dukungan","sidebar.help.discussions.tooltip":"Ajukan pertanyaan atau minta bantuan instalasi lewat GitHub Issues","sidebar.help.troubleshooting":"Pemecahan masalah","sidebar.help.troubleshooting.tooltip":"Buka panduan pemecahan masalah resmi di weppyai.com","header.whatsNew":"Yang Baru","header.whatsNew.tooltip":"Yang Baru","upgrade.title":"Lihat Pro","upgrade.tagline":"Lihat fitur Pro","upgrade.cta":"Lihat Pro","upgrade.licenseShortcut":"Masukkan lisensi","upgrade.validUntil":"Until {{date}}","whatsNew.pageTitle":"Yang Baru","whatsNew.pageSubtitle":"Tetap update dengan perubahan MCP","whatsNew.unreadSection":"Belum Dibaca","whatsNew.allSection":"Semua Pengumuman","whatsNew.empty":"Belum ada pengumuman","whatsNew.newBadge":"BARU","whatsNew.category.release":"Rilis","whatsNew.category.notice":"Pemberitahuan","whatsNew.category.deprecation":"Tidak Digunakan","whatsNew.category.tip":"Tips","uiStudio.title":"UI Studio","uiStudio.empty":"Belum ada tangkapan layar tersimpan. Ini dibuat otomatis saat agen AI menangkap status UI saat ini.","uiStudio.loading":"Loading…","uiStudio.pluginGuide.title":"Plugin Roblox Studio belum terhubung","uiStudio.pluginGuide.message":"UI Studio menampilkan tangkapan layar dan riwayat perubahan dari place Studio yang terhubung. Ini akan diperbarui otomatis setelah Studio dan WEPPY Plugin terhubung.","uiStudio.pluginGuide.check1":"Apakah Roblox Studio sedang berjalan?","uiStudio.pluginGuide.check2":"Apakah WEPPY Plugin terpasang dan berjalan?","uiStudio.pluginGuide.waiting":"Menunggu koneksi plugin...","uiStudio.capturedAt":"Captured at","uiStudio.scope":"Scope","uiStudio.target":"Target","uiStudio.briefId":"Brief ID","uiStudio.detailClose":"Close","uiStudio.colCheck":"Check","uiStudio.colPriority":"Priority","uiStudio.colCurrent":"Current","uiStudio.colRecommended":"Recommended","uiStudio.colSuggestion":"Suggestion","uiStudio.priorityHigh":"Tinjau dahulu","uiStudio.priorityLow":"Peningkatan opsional","uiStudio.highPrioritySection":"Tinjau dahulu","uiStudio.lowPrioritySection":"Peningkatan opsional","uiStudio.groupSummary":"items","uiStudio.fixLabel":"Fix","uiStudio.copyFixCommand":"Copy AI instruction","uiStudio.copiedToClipboard":"Copied","uiStudio.fullPath":"Full path","uiStudio.falsePositiveWarning":"This group may contain false positives","uiStudio.noSuggestions":"No current improvement suggestions","uiStudio.sample.badge":"Preview of the Pro UI Studio","uiStudio.sample.title":"You are previewing the UI Studio that unlocks after upgrading to Pro.","uiStudio.sample.message":"This preview uses sample data from a demo inventory UI. Real screenshots, review history, and AI-driven fixes unlock with Pro.","uiStudio.tabs.analysis":"Analisis","uiStudio.tabs.history":"Riwayat","uiStudio.analysis.reportsTitle":"Analisis Terbaru per Target UI","uiStudio.analysis.recentCapturesTitle":"Tangkapan Terbaru","uiStudio.analysis.detailDialog":"Detail analisis","uiStudio.analysis.targetCountLabel":"Target dianalisis","uiStudio.analysis.captureLabel":"Tangkapan","uiStudio.analysis.verdict.hasSuggestions":"Saran Perbaikan","uiStudio.analysis.verdict.needsFix":"Saran Perbaikan","uiStudio.analysis.verdict.review":"Saran Perbaikan","uiStudio.analysis.verdict.passed":"Tidak Ada Saran Saat Ini","uiStudio.analysis.verdictLabel":"Ringkasan Perbaikan","uiStudio.analysis.thresholds":"Basis Tinjauan","uiStudio.analysis.issueSummary.passed":"Tidak ada saran perbaikan tambahan pada basis tinjauan saat ini.","uiStudio.history.title":"Riwayat Perubahan","uiStudio.history.empty":"Belum ada riwayat perubahan. Ketika agen AI memodifikasi UI menggunakan manage_ui, akan dicatat secara otomatis.","uiStudio.history.loading":"Memuat...","uiStudio.history.error":"Kesalahan","uiStudio.history.clear":"Hapus Semua","uiStudio.history.filter.actions":"Jenis aksi","uiStudio.history.filter.actionAll":"Semua","uiStudio.history.filter.actionCreate":"Buat","uiStudio.history.filter.actionUpdate":"Perbarui","uiStudio.history.filter.actionDelete":"Hapus","uiStudio.history.filter.period":"Periode","uiStudio.history.filter.dateAll":"Semua","uiStudio.history.filter.today":"Hari Ini","uiStudio.history.filter.yesterday":"Kemarin","uiStudio.history.filter.last7Days":"7 Hari Terakhir","uiStudio.history.filter.last30Days":"30 Hari Terakhir","uiStudio.history.filter.customRange":"Rentang Kustom","uiStudio.history.filter.reset":"Setel Ulang","uiStudio.history.filter.from":"Dari","uiStudio.history.filter.to":"Hingga","uiStudio.history.row.affectedPaths":"Jalur","uiStudio.history.row.mutations":"Detail perubahan","uiStudio.history.row.expand":"▾ Perluas","uiStudio.history.row.collapse":"▲ Tutup","uiStudio.history.row.expandDetails":"Tampilkan {n} detail perubahan","uiStudio.history.row.collapseDetails":"Sembunyikan detail perubahan","uiStudio.history.row.toggleDetails":"Alihkan detail perubahan","uiStudio.history.row.mutationsEmpty":"Tidak ada detail perubahan","uiStudio.history.row.toolLabel":"Perubahan UI ({n})","uiStudio.history.row.compare":"Sebelum / Sesudah","uiStudio.history.row.noBeforeState":"Tidak ada status sebelumnya","uiStudio.history.row.noAfterState":"Tidak ada status sesudahnya","uiStudio.history.row.qualityPlan":"Arah desain","uiStudio.history.row.designCheck":"Saran","uiStudio.history.row.designCheckUnavailable":"Saran: tidak tersedia","uiStudio.history.row.designCheckNone":"Saran: tidak ada","uiStudio.history.selection.deleteSelected":"Hapus yang dipilih","uiStudio.history.selection.selectAll":"Pilih semua","uiStudio.history.selection.clearSelection":"Hapus pilihan","uiStudio.history.confirm.deleteRequestsTitle":"Hapus catatan perubahan","uiStudio.history.confirm.deleteRequestsMessage":"Catatan perubahan yang dipilih akan dihapus. Tindakan ini tidak dapat dibatalkan.","uiStudio.history.confirm.clearRequestsTitle":"Hapus Riwayat Perubahan","uiStudio.history.confirm.clearRequestsMessage":"Ini menghapus riwayat perubahan place saat ini. Instance Studio tidak terpengaruh.","uiStudio.history.confirm.cascadeOption":"Juga hapus tangkapan layar terkait","uiStudio.history.drawer.close":"Tutup","uiStudio.actions.previewAgain":"Pratinjau Lagi","uiStudio.actions.deleteSnapshot":"Hapus Tangkapan Layar Ini","uiStudio.actions.proRequired":"Tersedia setelah upgrade ke Pro","uiStudio.actions.captureCurrentState":"Tangkap Keadaan Saat Ini","uiStudio.actions.checkSuggestionsAgain":"Periksa Ulang Saran","uiStudio.actions.previewRunning":"Menangkap…","uiStudio.actions.previewRunningDetail":"ID file tangkapan layar baru akan muncul setelah penangkapan selesai.","uiStudio.actions.previewNeedsSaveCheck":"Tangkapan selesai, penyimpanan perlu diperiksa","uiStudio.actions.previewSaved":"Tangkapan layar baru disimpan","uiStudio.actions.previewComplete":"Tangkapan selesai","uiStudio.actions.previewSavedDetail":"Tangkapan yang ada tetap dipertahankan; ini disimpan sebagai file baru.","uiStudio.actions.previewSavedPathMissing":"ID tangkapan baru diterima, tetapi jalur file tersimpan tidak dapat dikonfirmasi.","uiStudio.actions.previewSnapshotIdMissing":"ID tangkapan baru tidak dapat dikonfirmasi. Segarkan daftar untuk memastikan apakah sudah tersimpan.","uiStudio.actions.more":"Lainnya","uiStudio.gallery.selection.selectedCount":" dipilih","uiStudio.confirm.deleteSnapshotTitle":"Hapus Tangkapan Layar","uiStudio.confirm.deleteSnapshotMessage":"Hanya file tangkapan layar ini yang dihapus (instans Studio tetap disimpan).","uiStudio.confirm.deleteBatchTitle":"Hapus Tangkapan Layar Terpilih","uiStudio.confirm.deleteBatchMessage":"Tangkapan layar yang dipilih akan dihapus. Tindakan ini tidak dapat dibatalkan.","uiStudio.gallery.selectMode":"Pilih","uiStudio.gallery.exitSelectMode":"Batal","uiStudio.gallery.selectAll":"Pilih Semua","uiStudio.gallery.clearSelection":"Batalkan Pilihan","uiStudio.gallery.deleteSelected":"Hapus Pilihan","common.cancel":"Batal","common.delete":"Hapus","uiStudio.storage.title":"Data tersimpan UI Studio","uiStudio.storage.usageLabel":"Digunakan","uiStudio.storage.historyBytes":"Riwayat","uiStudio.storage.snapshotBytes":"Tangkapan layar","uiStudio.storage.requestCount":"Catatan perubahan","uiStudio.storage.mutationCount":"Detail perubahan","uiStudio.storage.snapshotCount":"Tangkapan layar","uiStudio.storage.countSuffix":"","uiStudio.storage.lastRun":"Pembersihan otomatis terakhir","uiStudio.storage.lastRunNever":"—","uiStudio.storage.lastRunFreed":"dibebaskan","uiStudio.storage.lastRunErrors":"Kesalahan","uiStudio.storage.loading":"Memuat...","uiStudio.cleanup.policy.title":"Kebijakan hapus otomatis","uiStudio.cleanup.policy.modeOff":"Nonaktif","uiStudio.cleanup.policy.modeAge":"Berbasis usia","uiStudio.cleanup.policy.modeSize":"Berbasis ukuran","uiStudio.cleanup.policy.cascade":"Juga hapus tangkapan layar terkait","uiStudio.cleanup.policy.save":"Simpan kebijakan","uiStudio.cleanup.policy.runNow":"Jalankan sekarang","uiStudio.cleanup.policy.proRequired":"Tersedia setelah upgrade ke Pro","uiStudio.cleanup.policy.daysUnit":"h","uiStudio.cleanup.policy.mbUnit":"MB","uiStudio.cleanup.policy.gbUnit":"GB","uiStudio.cleanup.policy.confirm.title":"Konfirmasi kebijakan","uiStudio.cleanup.policy.confirm.messageStrict":"Menerapkan kebijakan ini akan segera menghapus","uiStudio.cleanup.policy.confirm.requests":" catatan perubahan","uiStudio.cleanup.policy.confirm.snapshots":" tangkapan layar","uiStudio.cleanup.policy.confirm.freed":"dibebaskan — Terapkan?","uiStudio.cleanup.keepLastNDays":"Simpan {n} hari terakhir","uiStudio.cleanup.selectedDelete":"Hapus pilihan…","uiStudio.cleanup.deleteAll":"Hapus semua…","uiStudio.cleanup.cleanupConfirmTitle":"Konfirmasi pembersihan","uiStudio.cleanup.cleanupConfirmMessage":"Item yang dipilih akan dihapus. Tindakan ini tidak dapat dibatalkan.","uiStudio.cleanup.cleanupConfirmMessage.keep7":"Change records and screenshots older than 7 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.keep30":"Change records and screenshots older than 30 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.all":" saved change records and screenshots will be deleted. This action cannot be undone.","uiStudio.cleanup.label":"Pembersihan manual","uiStudio.cleanup.studioPreservedNote":"Tindakan ini hanya menghapus file riwayat dan tangkapan layar di disk; instans Roblox Studio tidak terpengaruh.","uiStudio.history.sample.bannerBadge":"Pratinjau riwayat perubahan Pro","uiStudio.history.sample.bannerTitle":"Pratinjau riwayat perubahan Pro","uiStudio.history.sample.bannerMessage":"Pratinjau ini menggunakan data sampel. Riwayat perubahan nyata, perbandingan sebelum/sesudah, dan penghapusan massal tersedia di Pro.","uiStudio.fix.touchTarget.label":"Touch target size","uiStudio.fix.touchTarget.description":"Checks whether controls are large enough to tap comfortably on mobile.","uiStudio.fix.touchTarget.howToFix":"Increase button Size to at least 44x44 px or expand the touch area with UIPadding.","uiStudio.fix.contrast.label":"Text contrast","uiStudio.fix.contrast.description":"Checks whether text and background contrast meet accessibility guidance.","uiStudio.fix.contrast.howToFix":"Use a brighter TextColor3 or darken the BackgroundColor3.","uiStudio.fix.contrast.falsePositive":"Emoji icons may be false positives when their color is fixed.","uiStudio.fix.textScaled.label":"TextScaled usage","uiStudio.fix.textScaled.description":"TextScaled without UITextSizeConstraint can break layouts when text expands.","uiStudio.fix.textScaled.howToFix":"Add a UITextSizeConstraint child to the TextLabel and set MaxTextSize.","uiStudio.fix.safezone.label":"Safe-zone placement","uiStudio.fix.safezone.description":"Checks whether controls stay inside platform safe zones.","uiStudio.fix.safezone.howToFix":"Move Position inside the safe zone or reduce the parent Frame.","uiStudio.fix.minTextSize.label":"Minimum font size","uiStudio.fix.minTextSize.description":"Checks whether text is too small to read comfortably.","uiStudio.fix.minTextSize.howToFix":"Increase TextSize to at least 14 for body text.","uiStudio.sample.history.request1.label":"Initial HUD layout creation","uiStudio.sample.history.request2.label":"Inventory modal design update","uiStudio.sample.history.request3.label":"HUD HealthBar color update","uiStudio.sample.history.request4.label":"Expand Inventory tab button touch targets","uiStudio.sample.history.request5.label":"Remove Settings popup","uiStudio.sample.history.request6.label":"Add HUD minimap component","uiStudio.sample.history.request1.mutation1.diff":"Created Frame + HealthBar + StaminaBar","uiStudio.sample.history.request1.mutation2.diff":"BackgroundColor3 -> Color3.new(0.2,0.8,0.2)","uiStudio.sample.history.request1.mutation3.diff":"BackgroundColor3 -> Color3.new(0.1,0.6,1.0)","uiStudio.sample.history.request1.mutation4.diff":"Set AnchorPoint, Position, and Size","uiStudio.sample.history.request1.mutation5.diff":"Screenshot saved","uiStudio.sample.history.request2.mutation1.diff":"Darkened BackgroundColor3 for better contrast","uiStudio.sample.history.request2.mutation2.diff":"TextColor3 -> Color3.new(1,1,1), TextSize 16 -> 18","uiStudio.sample.history.request2.mutation3.diff":"BorderSizePixel 0 -> 2, set BorderColor3","uiStudio.sample.history.request2.mutation4.diff":"Screenshot saved","uiStudio.sample.history.request3.mutation1.diff":"BackgroundColor3 -> Color3.new(0.9,0.2,0.2) (red tone)","uiStudio.sample.history.request3.mutation2.diff":"Screenshot saved","uiStudio.sample.history.request4.mutation1.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation2.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation3.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation4.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation5.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation6.diff":"Screenshot saved","uiStudio.sample.history.request5.mutation1.diff":"Removed ScreenGui (Settings-only UI)","uiStudio.sample.history.request6.mutation1.diff":"Attempted to create Frame + MapImage + PlayerDot","uiStudio.sample.history.request6.mutation2.diff":"Set Size, Position, and BackgroundTransparency","uiStudio.sample.history.request6.mutation3.diff":"Interrupted by server restart while setting ImageLabel","uiStudio.sample.history.request6.mutation4.diff":"Partial screenshot saved","uiStudio.sample.history.request6.mutation3.error":"server_restart: connection lost","uiStudio.sample.history.request6.mutation4.error":"partial screenshot: missing layers","uiStudio.sample.history.detail.backgroundColor":"Background color","uiStudio.sample.history.detail.anchorPoint":"Anchor","uiStudio.sample.history.detail.position":"Position","uiStudio.sample.history.detail.size":"Size","uiStudio.sample.history.detail.textColor":"Text color","uiStudio.sample.history.detail.textSize":"Text size","uiStudio.sample.history.detail.borderSize":"Border size","uiStudio.sample.history.detail.borderColor":"Border color","uiStudio.history.sample.tooltip":"Upgrade ke Pro untuk membuka riwayat lengkap","settings.dataHistory.title":"Data & History","settings.dataHistory.title.tooltip":"Manage saved dashboard data in one place.","settings.dataHistory.collapse":"Collapse {title}","settings.dataHistory.expand":"Expand {title}","settings.dataHistory.scope":"Current project","settings.dataHistory.scope.tooltip":"Clear actions apply to the current project and active place where applicable.","settings.dataHistory.intro":"Review saved dashboard data, open the related page, or clear stored records from one place.","settings.dataHistory.toolsActivity.title":"Tool activity","settings.dataHistory.toolsActivity.description":"Saved tool runs shown on the Tools page.","settings.dataHistory.toolStats.title":"Tool usage statistics","settings.dataHistory.toolStats.description":"Aggregated tool counts and status totals.","settings.dataHistory.syncLog.title":"Sync log","settings.dataHistory.syncLog.description":"Saved file sync events for the active place.","settings.dataHistory.playtest.title":"Playtest reports","settings.dataHistory.playtest.description":"Saved automated playtest reports and logs.","settings.dataHistory.projectChanges.title":"Project change summary","settings.dataHistory.projectChanges.description":"Saved summaries of project changes.","settings.dataHistory.connectionLog.title":"Connection log","settings.dataHistory.connectionLog.description":"Saved MCP and Studio connection events.","settings.dataHistory.uiStudio.title":"UI Studio history and screenshots","settings.dataHistory.uiStudio.tooltip":"Manage saved UI Studio change records, screenshots, and auto-delete policy.","settings.dataHistory.uiStudio.description":"Saved UI Studio change records, screenshots, and cleanup policy.","settings.dataHistory.uiStudio.clear.title":"Clear UI Studio saved data?","settings.dataHistory.uiStudio.clear.message":"This deletes saved UI Studio change records and screenshots only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.uiStudio.clear.success":"UI Studio saved data cleared.","settings.dataHistory.uiStudio.clear.failed":"Failed to clear UI Studio saved data.","settings.dataHistory.metric.unavailable":"Unavailable","settings.dataHistory.metric.sizeUnavailable":"size unavailable","settings.dataHistory.metric.records":"records","settings.dataHistory.metric.runs":"runs","settings.dataHistory.metric.sessions":"sessions","settings.dataHistory.metric.reports":"reports","settings.dataHistory.open":"Open","settings.dataHistory.clear.title":"Clear saved data?","settings.dataHistory.clear.message":"This deletes saved dashboard records only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.clear.success":"Saved data cleared.","settings.dataHistory.clear.failed":"Failed to clear saved data.","toast.serverConnected":"Server MCP terhubung","toast.serverDisconnected":"Server MCP terputus","toast.pluginConnected":"Plugin terhubung","toast.pluginDisconnected":"Plugin terputus","toast.clearSuccess":"Berhasil dihapus","toast.clearFailed":"Gagal menghapus data","common.clear":"Hapus","settings.license.activate":"Aktifkan lisensi","settings.license.refresh":"Segarkan lisensi","settings.license.keyInput":"Kunci lisensi","settings.license.disconnected":"Terputus","settings.license.disconnected.tooltip":"Sambungkan ulang ke server MCP untuk mengelola lisensi dari WEPPY Dashboard.","settings.license.live.tooltip":"Tindakan lisensi langsung dikirim ke server MCP.","settings.license.status.activationRequired":"Aktivasi Diperlukan","settings.license.status.activationRequired.tooltip":"Aktivasi lisensi manual diperlukan sebelum WEPPY Dashboard dapat menyegarkan status ini.","settings.license.status.grace":"Masa Tenggang","settings.license.status.grace.tooltip":"Verifikasi penyedia sementara tidak tersedia, tetapi akses Pro tetap aktif selama masa tenggang.","settings.license.status.graceBilling.tooltip":"Akses Pro tetap tersedia selama masa tenggang terkait penagihan.","settings.license.detail.graceBilling":"Akses Pro tetap tersedia selama masa tenggang penagihan.","settings.license.detail.graceProviderUnavailable":"Penyedia tidak tersedia. Akses Pro tetap aktif selama mode tenggang.","settings.license.detail.manualActivation":"Aktivasi manual diperlukan untuk memulihkan akses Pro.","settings.license.detail.missingSessionToken":"Penyegaran diblokir karena token sesi saat ini tidak ada.","settings.license.detail.refreshRecommended":"Verifikasi lisensi harus segera disegarkan.","connection.agents.kill":"Hentikan","connection.agents.kill.title":"Hentikan agen?","connection.agents.killed":"Agen dihentikan","connection.agents.killFailed":"Gagal menghentikan agen","connection.agents.lastCommand":"Perintah Terakhir","connection.agents.lastCommand.tooltip":"Panggilan alat terbaru yang dijalankan oleh agen ini.","connection.agents.lastSeen":"Terakhir Terlihat","connection.agents.lastSeen.tooltip":"Heartbeat atau aktivitas terbaru dari agen ini.","connection.clear.title":"Hapus log koneksi?","connection.clear.message":"Tindakan ini menghapus secara permanen log koneksi yang tersimpan untuk proyek saat ini.","sync.clear.title":"Hapus log sinkronisasi?","sync.clear.message":"Tindakan ini menghapus secara permanen log sinkronisasi yang tersimpan untuk place saat ini.","playtest.clear.title":"Hapus riwayat tes?","playtest.clear.message":"Tindakan ini menghapus secara permanen laporan playtest yang tersimpan untuk place saat ini.","changelog.clear.title":"Hapus changelog?","changelog.clear.message":"Tindakan ini menghapus secara permanen changelog yang tersimpan untuk place saat ini.","sync.status.placePath":"Jalur Place","sync.status.placePath.tooltip":"Direktori place aktif tempat berkas explorer disinkronkan.","tier.progress.label":"Pro / Total","changelog.card.representativeArea":"Area representatif","changelog.card.verification":"Verifikasi","uiStudio.tabs.analysis.tooltip":"Browse AI-captured UI screens and quickly find which UIs need improvement.","uiStudio.tabs.history.tooltip":"Every UI change AI made, in order. Compare before and after screens.","uiStudio.title.tooltip":"A central place to review AI-generated UI screens and improvement suggestions.","uiStudio.analysis.reportsTitle.tooltip":"Shows the latest capture and suggestion summary per UI (e.g., Inventory window, Main menu).","uiStudio.analysis.verdict.hasSuggestions.tooltip":"Some improvements were found in this UI. Click the card for details.","uiStudio.analysis.verdict.passed.tooltip":"No improvements suggested under the current review thresholds.","uiStudio.analysis.counts.tooltip":"‘Main’ are key items to review first; ‘Notes’ are nice-to-have refinements.","uiStudio.analysis.thresholds.tooltip":"The threshold set used for this review (default or custom).","uiStudio.analysis.recentCapturesTitle.tooltip":"All recently saved captures in chronological order.","uiStudio.gallery.selectAll.tooltip":"Select every visible capture at once.","uiStudio.gallery.clearSelection.tooltip":"Clear the current selection.","uiStudio.gallery.deleteSelected.tooltip":"Delete only the selected capture files. The actual UI in Roblox Studio is not affected.","uiStudio.gallery.cardCheckbox.tooltip":"Select this capture. Pick multiple to delete them together.","uiStudio.detailClose.tooltip":"Close this detail panel.","uiStudio.actions.captureCurrentState.tooltip":"Save the UI currently shown in Studio as a new capture. Existing captures are kept.","uiStudio.actions.checkSuggestionsAgain.tooltip":"Recompute suggestions for this capture without taking a new screenshot.","uiStudio.actions.more.tooltip":"Open additional actions.","uiStudio.actions.deleteSnapshot.tooltip":"Delete only this capture file. The actual UI in Roblox Studio is not affected.","uiStudio.capturedAt.tooltip":"When this screen was captured.","uiStudio.scope.tooltip":"Capture scope (full screen or a specific UI).","uiStudio.target.tooltip":"Exact path of the captured UI instance.","uiStudio.briefId.tooltip":"Identifier of the design brief that produced this UI.","uiStudio.analysis.verdictLabel.tooltip":"Overall improvement verdict for this capture.","uiStudio.suggestionGroup.tooltip":"Suggestions of the same kind grouped together. Click to expand or collapse.","uiStudio.groupSummary.tooltip":"Number of UI elements matching this group.","uiStudio.colCurrent.tooltip":"The currently applied value.","uiStudio.colRecommended.tooltip":"The recommended value.","uiStudio.copyFixCommand.tooltip":"Copy a prompt that asks the AI to fix this issue.","uiStudio.falsePositiveWarning.tooltip":"This check can produce false positives — verify before applying.","uiStudio.history.filter.actions.tooltip":"Filter records by the kind of change AI made.","uiStudio.history.filter.period.tooltip":"Filter records by time range.","uiStudio.history.filter.from.tooltip":"Start date for the query.","uiStudio.history.filter.to.tooltip":"End date for the query.","uiStudio.history.filter.actionAll.tooltip":"Show every kind of action.","uiStudio.history.filter.actionCreate.tooltip":"Show only actions that created a new UI.","uiStudio.history.filter.actionUpdate.tooltip":"Show only actions that updated an existing UI.","uiStudio.history.filter.actionDelete.tooltip":"Show only actions that deleted a UI.","uiStudio.history.filter.dateAll.tooltip":"Show the full history.","uiStudio.history.filter.today.tooltip":"Show only changes from today.","uiStudio.history.filter.yesterday.tooltip":"Show only changes from yesterday.","uiStudio.history.filter.last7Days.tooltip":"Show changes from the last 7 days.","uiStudio.history.filter.last30Days.tooltip":"Show changes from the last 30 days.","uiStudio.history.filter.customRange.tooltip":"Pick a custom start and end date.","uiStudio.history.filter.reset.tooltip":"Reset all filters to defaults.","uiStudio.history.title.tooltip":"A timeline of every UI change made by AI.","uiStudio.history.clear.tooltip":"Delete every change record for this project. The actual UI in Roblox Studio is not affected.","uiStudio.history.row.compare.tooltip":"Compare the before and after screens. Click to open the full comparison view.","uiStudio.history.row.extraPaths.tooltip":"Number of additional UIs changed in this action.","uiStudio.history.row.noBeforeState.tooltip":"No capture saved before this change.","uiStudio.history.row.noAfterState.tooltip":"No capture saved after this change.","uiStudio.history.row.affectedPaths.tooltip":"Number of UIs affected by this action.","uiStudio.history.row.mutations.tooltip":"Number of detailed changes (e.g., property edits).","uiStudio.history.row.qualityPlan.tooltip":"Arah desain brief yang digunakan untuk perubahan ini.","uiStudio.history.row.designCheck.tooltip":"Ringkasan saran Design Check setelah perubahan.","uiStudio.history.row.toggleDetails.tooltip":"Show or hide a per-line breakdown of what changed.","uiStudio.compare.before.tooltip":"The screen saved just before AI made the change.","uiStudio.compare.after.tooltip":"The screen saved just after AI made the change.","uiStudio.compare.path.tooltip":"The UI instance path for this screen.","uiStudio.storage.title.tooltip":"Disk usage of UI Studio change records and screenshots.","uiStudio.storage.usageLabel.tooltip":"Disk space currently used by UI Studio for this project.","uiStudio.storage.historyBytes.tooltip":"Space taken by change record data (JSON).","uiStudio.storage.snapshotBytes.tooltip":"Space taken by captured PNG image files.","uiStudio.storage.requestCount.tooltip":"Number of actions where AI changed the UI.","uiStudio.storage.mutationCount.tooltip":"Number of detail changes inside actions (one property edit = 1).","uiStudio.storage.snapshotCount.tooltip":"Number of saved capture image files.","uiStudio.storage.lastRun.tooltip":"When the auto-cleanup policy last ran, and what it removed.","uiStudio.cleanup.label.tooltip":"Manually clean up change records and captures whenever you want.","uiStudio.cleanup.keep7.tooltip":"Delete change records and captures older than 7 days.","uiStudio.cleanup.keep30.tooltip":"Delete change records and captures older than 30 days.","uiStudio.cleanup.deleteAll.tooltip":"Delete every change record and capture for this project. The actual UI in Roblox Studio is not affected.","uiStudio.cleanup.policy.title.tooltip":"Rules that automatically remove old or large captures.","uiStudio.cleanup.policy.modeOff.tooltip":"Turn off auto-cleanup. Data stays until you remove it manually.","uiStudio.cleanup.policy.modeAge.tooltip":"Automatically delete data older than the configured number of days.","uiStudio.cleanup.policy.modeSize.tooltip":"When total usage exceeds the limit, the oldest data is removed first.","uiStudio.cleanup.policy.agePreset.tooltip":"Delete data older than this many days.","uiStudio.cleanup.policy.ageInput.tooltip":"Enter any value between 1 and 365 days.","uiStudio.cleanup.policy.sizePreset.tooltip":"Keep total usage under this size.","uiStudio.cleanup.policy.sizeInput.tooltip":"Enter any value between 50 MB and 10000 MB (10 GB).","uiStudio.cleanup.policy.cascade.tooltip":"Also delete the capture images linked to those records. If off, the images stay.","uiStudio.cleanup.policy.save.tooltip":"Save the current cleanup rule. It runs in the background from then on.","uiStudio.cleanup.policy.runNow.tooltip":"Run the current rule once now, without waiting for the next scheduled run.","settings.license.refresh.tooltip":"Re-fetch the current state from the license server. Useful when a billing change hasn't appeared yet.","settings.license.reset.tooltip":"Remove the currently registered license key. Use this before activating with a different key.","settings.license.activate.tooltip":"Activate Pro features with the entered license key.","tier.upgrade.tooltip":"Lihat fitur Pro dan opsi pembelian.","settings.language.auto.tooltip":"Follow the operating system's language. Falls back to English when not supported.","settings.dataHistory.open.tooltip":"Open the page that shows this item in detail.","settings.dataHistory.clear.tooltip":"Delete only the records saved for this item. Roblox Studio data is not changed.","settings.dataHistory.toggle.tooltip":"Collapse or expand this section.","settings.dataHistory.toolsActivity.metric.tooltip":"Number of saved tool runs and the disk space they use.","settings.dataHistory.toolStats.metric.tooltip":"Aggregated total runs and session counts.","settings.dataHistory.syncLog.metric.tooltip":"Number of saved sync events and the disk space they use.","settings.dataHistory.playtestReports.metric.tooltip":"Number of saved playtest reports and the disk space they use.","settings.dataHistory.projectChanges.metric.tooltip":"Number of saved project change summaries and the disk space they use.","settings.dataHistory.connectionLog.metric.tooltip":"Number of saved connection events and the disk space they use.","settings.dataHistory.uiStudio.metric.tooltip":"UI Studio change record and capture counts, plus total disk usage.","uiStudio.designCheckResultsTitle":"Saran Design Check","uiStudio.designCheckResultsTitle.tooltip":"All improvement suggestions found in this capture.","uiStudio.actions.designCheckAgain":"Periksa lagi","uiStudio.actions.designCheckRunning":"Memeriksa saran...","uiStudio.actions.designCheckRunningDetail":"Jumlah item tinjau dahulu, disarankan, dan opsional akan ditampilkan setelah selesai.","uiStudio.actions.designCheckComplete":"Pemeriksaan saran selesai","uiStudio.actions.designCheckNoSnapshotSaved":"Tindakan ini tidak menyimpan file tangkapan layar baru.","uiStudio.sample.designCheck.contrast":"Text contrast is below {expected} (current {actual}). Adjust TextColor3 or BackgroundColor3.","uiStudio.sample.designCheck.touchTarget":"Touch target is below {expected} (current {actual}). Increase Size or padding.","uiStudio.sample.designCheck.minTextSize":"TextSize is below {expected} (current {actual}). Increase it for readability.","uiStudio.gallery.priorityHighBadge.tooltip":"Jumlah saran yang perlu ditinjau dahulu. Klik untuk detail.","uiStudio.gallery.priorityMediumBadge.tooltip":"Jumlah saran yang direkomendasikan.","uiStudio.priorityMedium":"Disarankan ditinjau","uiStudio.mediumPrioritySection":"Disarankan ditinjau","uiStudio.gallery.priorityLowBadge.tooltip":"Jumlah peningkatan opsional.","tier.banner.progressLabel":"Pro / Total","uiStudio.error":"Error","uiStudio.analysis.expandChildren":"Tampilkan target turunan","uiStudio.analysis.openDetail":"Buka detail","uiStudio.analysis.childTargets":"Target turunan","uiStudio.analysis.childDetailHint":"Buka detail target turunan","uiStudio.compare.before":"Sebelum","uiStudio.compare.after":"Sesudah","uiStudio.history.drawer.changeDetails":"Detail perubahan","uiStudio.gallery.cardCheckbox":"Pilih tangkapan layar","sidebar.assets":"Assets","assets.title":"Assets","assets.experimental":"Experimental","assets.subtitle":"Browse local originals, upload to Roblox, and inspect synced usage by place.","assets.scope.label":"Asset scope","assets.scope.place":"Current Place","assets.scope.shared":"Shared","assets.count.shown":"Shown assets: {count}","assets.category.filter":"Category","assets.category.all":"All","assets.category.image":"Images","assets.category.decal":"Decals","assets.category.audio":"Audio","assets.category.mesh":"Meshes","assets.category.model":"Models","assets.category.rbxm":"RBXM","assets.category.video":"Videos","assets.category.animation":"Animations","assets.category.comingSoon":"Coming soon","assets.status.localOnly":"Local only","assets.status.uploading":"Uploading","assets.status.processing":"Processing","assets.status.uploaded":"Uploaded","assets.status.failed":"Failed","assets.status.superseded":"Superseded","assets.rescan":"Rescan","assets.rescan.tooltip":"Scan the selected inbox folder.","assets.rescan.chooseCategory":"Choose a category before rescanning.","assets.rbxmGuide.title":"Save RBXM from Studio","assets.rbxmGuide.body":"Select objects in Roblox Studio, then use WEPPY Plugin > Assets to save the selection as a local RBXM asset.","assets.rbxmGuide.thumbnail":"The plugin save flow includes a thumbnail option, and saved RBXM assets appear here for management, upload, and insertion.","assets.exportSelection":"Export Studio selection","assets.exportSelection.tooltip":"Export the current Studio selection as a local .rbxm asset.","assets.exportSelection.chooseCategory":"Choose RBXM before exporting a Studio selection.","assets.upload.open":"Upload","assets.upload.open.tooltip":"Upload this local file to Roblox through Open Cloud.","assets.upload.selectFirst":"Select an asset first.","assets.upload.title":"Upload asset","assets.upload.checkingSettings":"Checking upload settings...","assets.upload.settingsLoadFailed":"Failed to load upload settings.","assets.upload.settingsRequired":"Upload settings required","assets.upload.settingsRequired.apiKey":"Save an Open Cloud API key before uploading.","assets.upload.settingsRequired.toggle":"Enable Open Cloud upload before uploading.","assets.upload.settingsRequired.creator":"Save a default Creator before uploading.","assets.upload.openSettings":"Open Asset Library settings","assets.upload.creator":"Creator","assets.upload.creatorType":"Creator type","assets.upload.creatorId":"Creator ID","assets.upload.envCreatorHelp":"Environment API keys cannot save a default Creator here. Enter the Creator for this upload.","assets.upload.displayNameHelp":"Saved to Roblox as the asset display name.","assets.upload.descriptionHelp":"Saved to Roblox as the asset description.","assets.upload.creatorHelp":"Used by Open Cloud as the owner of the uploaded asset.","assets.upload.creatorTypeHelp":"Sent to Open Cloud as the Creator type.","assets.upload.creatorIdHelp":"Sent to Open Cloud as the User or Group ID that owns the uploaded asset.","assets.upload.submit":"Upload with Roblox Open Cloud","assets.upload.uploading":"Uploading...","assets.upload.noDelete":"WEPPY does not provide Roblox asset deletion.","assets.upload.delay":"Roblox processing and moderation can delay visibility in Studio or Creator Dashboard.","assets.delete.tooltip":"Delete this local Asset Library item.","assets.delete.title":"Delete asset","assets.delete.message":"This removes the local Asset Library files only. Uploaded Roblox assets are not deleted.","assets.creator.user":"User","assets.creator.group":"Group","assets.settings.open":"Open settings","assets.settings.open.tooltip":"Open Roblox upload settings.","assets.settings.title":"Asset Library settings","assets.settings.proOnly":"Roblox upload settings and Open Cloud credential controls are available on Pro.","assets.settings.openCloudToggle":"Open Cloud upload","assets.settings.openCloudToggle.help":"Controls whether server-side Open Cloud upload mutations can run.","assets.settings.apiKey":"Open Cloud API Key","assets.settings.apiKeyGuide":"Create a Roblox API key with Assets Read and Write permissions.","assets.settings.creatorHelp":"Use the numeric user ID from a profile URL or group ID from a group URL.","assets.settings.credential.none":"No API key saved","assets.settings.credential.env":"Environment variable","assets.settings.credential.local":"Local encrypted file","assets.settings.registeredApiKey":"Registered API Key","assets.settings.credentialProfile":"Credential Profile","assets.settings.activeProfileBadge":"Active","assets.settings.field.profile":"Profile","assets.settings.field.apiKey":"API Key","assets.settings.field.storage":"Storage","assets.settings.field.validationStatus":"Validation status","assets.settings.field.creators":"Creators","assets.settings.validation.unknown":"Not tested","assets.settings.validation.valid":"Connected","assets.settings.validation.invalid":"Needs attention","assets.settings.profileSelected":"Open Cloud credential profile selected.","assets.settings.useProfile":"Use profile","assets.settings.replaceApiKey":"Replace API Key","assets.settings.profileLabel":"Profile name (optional)","assets.settings.profileLabel.placeholder":"Studio automation key","assets.settings.profileLabel.help":"Optional. If left blank, WEPPY saves this profile as Open Cloud key automatically.","assets.settings.saveApiKey":"Save API Key","assets.settings.testConnection":"Test Connection","assets.settings.removeApiKey":"Unregister API Key","assets.settings.saveCreator":"Save default Creator","assets.settings.saveCreatorPreset":"Save Creator","assets.settings.addCreator":"Add Creator","assets.settings.addCreator.tooltip.ready":"Add another User or Group Creator preset to this profile.","assets.settings.cancelCreator":"Cancel","assets.settings.defaultCreatorBadge":"Default","assets.settings.makeDefaultCreator":"Make default","assets.settings.unregisterCreator":"Unregister Creator","assets.settings.creatorLabel":"Creator label (optional)","assets.settings.creatorLabel.placeholder":"Main studio group","assets.settings.creatorLabel.help":"Optional. If left blank, WEPPY automatically saves a label like User 123 or Group 456.","assets.settings.action.proRequired":"Asset upload settings are available on Pro.","assets.settings.action.busy":"Wait for the current settings action to finish.","assets.settings.saveApiKey.tooltip.ready":"Save this API key to local encrypted storage.","assets.settings.saveApiKey.tooltip.enter":"Enter an Open Cloud API key to save it locally.","assets.settings.testConnection.tooltip.entered":"Test the entered API key before saving it.","assets.settings.testConnection.tooltip.saved":"Test the saved Open Cloud API key.","assets.settings.testConnection.tooltip.enterOrSaved":"Enter an API key or save one before testing the connection.","assets.settings.removeApiKey.tooltip.ready":"Unregister the locally saved Open Cloud API key from WEPPY.","assets.settings.removeApiKey.tooltip.none":"No local Open Cloud API key is saved.","assets.settings.removeApiKey.tooltip.env":"Environment API keys cannot be removed from Dashboard. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY.","assets.settings.unregisterCreator.tooltip.ready":"Unregister this Creator from the selected profile.","assets.settings.unregisterApiKey.title":"Unregister API Key?","assets.settings.unregisterApiKey.message":"Roblox API key is not revoked. WEPPY only removes the local Credential Profile registration on this device.","assets.settings.unregisterCreator.title":"Unregister Creator?","assets.settings.unregisterCreator.message":"Roblox user or group is not deleted. WEPPY only removes this Creator from the selected API Key profile.","assets.settings.saveCreator.tooltip.ready":"Save this Creator as the default owner for uploads.","assets.settings.saveCreator.tooltip.noLocal":"Save a local Open Cloud API key before saving a default Creator.","assets.settings.saveCreator.tooltip.env":"Environment API keys cannot save a default Creator here. Enter Creator details in the upload dialog.","assets.settings.saveCreator.tooltip.enterId":"Enter a user or group ID before saving the default Creator.","assets.settings.apiKeySaved":"Open Cloud API key saved locally.","assets.settings.apiKeyTested":"Open Cloud API key connection tested.","assets.settings.apiKeyRemoved":"Open Cloud API key unregistered from local storage.","assets.settings.envApiKeyStillActive":"Environment variable credential is still active. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY Dashboard.","assets.settings.defaultCreatorSaved":"Open Cloud default Creator saved locally.","assets.settings.creatorUnregistered":"Creator unregistered from this profile.","assets.settings.creatorUnregisterFailed":"Failed to unregister Creator.","assets.settings.saved":"Upload settings saved.","assets.settings.saveFailed":"Failed to save upload settings.","assets.settings.loadFailed":"Failed to load upload settings.","assets.settings.tested":"Connection tested.","assets.settings.testFailed":"Connection test failed.","assets.settings.removed":"API key unregistered.","assets.settings.removeFailed":"Failed to unregister API key.","assets.basic.notice":"Browse, preview, edit metadata, and scan usage on Basic. Roblox upload controls are available on Pro.","assets.proOnly.tooltip":"Roblox upload is available on Pro.","assets.proOnly.upload":"Roblox upload is available on Pro.","assets.empty.title":"No assets yet","assets.empty.body":"Choose a scope and category, then rescan that inbox folder.","assets.detail.title":"Asset details","assets.detail.displayName":"Display name","assets.detail.description":"Description","assets.detail.save":"Save metadata","assets.detail.refreshStatus":"Refresh","assets.detail.scanUsage":"Scan usage","assets.detail.localFile":"Local file","assets.detail.fileName":"File","assets.detail.category":"Category","assets.detail.scope":"Scope","assets.detail.mimeType":"Type","assets.detail.size":"Size","assets.detail.dimensions":"Dimensions","assets.detail.duration":"Duration","assets.detail.source":"Source path","assets.detail.sha256":"SHA-256","assets.detail.roblox":"Roblox upload status","assets.detail.status":"Status","assets.detail.assetId":"Asset ID","assets.detail.error":"Error","assets.detail.copyAssetId":"Copy Asset ID","assets.detail.copyUri":"Copy URI","assets.detail.studioUri":"Studio URI","assets.detail.robloxWebUrl":"Creator Dashboard URL","assets.detail.copyStudioUri":"Copy Studio URI","assets.detail.copyWebUrl":"Copy configure URL","assets.detail.openRobloxPage":"Open configure page","assets.detail.robloxWebUrlNotice":"Opening this page requires the Roblox account that owns or can manage the uploaded asset.","assets.detail.uploadHistory":"Upload history","assets.detail.usedInPlace":"Where this asset is used in this Place","assets.detail.noUsage":"No local Sync references found yet.","assets.detail.usageSource":"Checked against","assets.detail.usageSource.localSync":"Local Sync files","assets.detail.usageSource.notScanned":"Not checked yet","assets.detail.lastScanned":"Last checked","assets.detail.lastScannedAt":"Last checked: {time}","assets.detail.lastScanned.never":"No check yet","assets.detail.noUsageUnscanned":"Run Scan usage to search local Sync files for this Roblox Asset ID.","assets.detail.noUsageAfterScan":"No references were found in local Sync files during the last check.","assets.detail.noUsageNoRobloxId":"This asset does not have a Roblox Asset ID yet, so usage cannot be checked. Upload it before scanning usage.","assets.detail.technicalDetails":"Technical details","assets.detail.stableId":"Stable ID","assets.detail.sourceKind":"Source kind","assets.detail.createdAt":"Created","assets.detail.updatedAt":"Updated","assets.detail.operationId":"Operation ID","assets.detail.operationPath":"Operation path","assets.detail.versionId":"Version ID","assets.detail.remotePath":"Remote path","assets.detail.moderationState":"Moderation","assets.detail.line":"line {line}","assets.studio.notConnected":"Connect Roblox Studio before using Studio asset actions.","assets.detail.importRbxm":"Insert into Studio","assets.detail.importRbxm.tooltip":"Insert this local RBXM asset into {target} in the connected Studio place.","assets.detail.generateThumbnail":"Generate thumbnail","assets.detail.generateThumbnail.tooltip":"Create or replace the Asset Library thumbnail from Studio.","assets.detail.rbxmOnly":"Studio import is available for .rbxm assets.","assets.detail.rbxmCategoryOnly":"Studio .rbxm actions support models and animations.","assets.detail.thumbnailRbxmOnly":"Thumbnail generation is available for .rbxm model assets.","assets.detail.thumbnailModelOnly":"Thumbnail generation is available for model .rbxm assets.","assets.detail.rbxm":"RBXM contents","assets.detail.rbxmExportedCount":"Exported roots","assets.detail.rbxmClasses":"Classes","assets.detail.rbxmThumbnail":"Thumbnail","assets.detail.studioInsertTarget":"Studio insert target","assets.detail.rbxmRoots":"Root tree","assets.detail.rbxmReferences":"Asset references","assets.detail.rbxmThumbnailAttempts":"Thumbnail attempts","dashboardHelp.button":"Help","dashboardHelp.pageButton.ariaLabel":"Open page help","dashboardHelp.fieldButton.ariaLabel":"Open field help","dashboardHelp.section.canDo":"What you can do here","dashboardHelp.section.needs":"What you need to use it","dashboardHelp.section.links":"Related links","dashboardHelp.overview.title":"Overview help","dashboardHelp.overview.canDo.1":"Check MCP server, WEPPY Plugin, AI Agent, Sync, and recent game changes in one place.","dashboardHelp.overview.needs.1":"Useful status requires the MCP server. Live Studio status also needs WEPPY Plugin connected to the active place.","dashboardHelp.connection.title":"Connection help","dashboardHelp.connection.canDo.1":"Inspect server process details, connected AI agents, Studio plugin clients, and connection log events.","dashboardHelp.connection.needs.1":"The MCP server must be reachable. Plugin rows appear after Studio sends heartbeats.","dashboardHelp.sync.title":"Sync help","dashboardHelp.sync.canDo.1":"Review Studio to local sync status, direction, apply mode, and sync logs.","dashboardHelp.sync.needs.1":"Sync needs an active place and connected WEPPY Plugin. Two-way and reverse workflows depend on Pro.","dashboardHelp.assets.title":"Assets help","dashboardHelp.assets.canDo.1":"Browse local Asset Library files, switch place/shared scope, filter categories, scan usage, insert RBXM into Studio, and upload local assets to Roblox.","dashboardHelp.assets.needs.1":"Upload needs Pro, the Open Cloud upload toggle, a valid API Key, and a Creator. Browse and preview work on Basic.","dashboardHelp.changelog.title":"Changelog help","dashboardHelp.changelog.canDo.1":"Review real game-change sessions extracted from AI actions and sync events.","dashboardHelp.changelog.needs.1":"Entries are scoped to the active place. Basic shows only the latest preview entries.","dashboardHelp.playtest.title":"Playtest help","dashboardHelp.playtest.canDo.1":"Review Playtest results and reports saved by the AI Agent.","dashboardHelp.playtest.needs.1":"Pro shows real stored reports. Basic shows sample preview data. Live active-place confidence needs WEPPY Plugin connected.","dashboardHelp.uiStudio.title":"UI Studio help","dashboardHelp.uiStudio.canDo.1":"Review AI-created UI analysis, improvement suggestions, captures, and before/after history.","dashboardHelp.uiStudio.needs.1":"Pro shows real UI Studio data. Basic shows a bundled sample. New capture/check actions need WEPPY Plugin connected.","dashboardHelp.tools.title":"Tools help","dashboardHelp.tools.canDo.1":"Inspect tool history, status classification, fallback/unsupported/warn/error details, and usage statistics.","dashboardHelp.tools.needs.1":"History and statistics depend on local recording settings and the active place bucket.","dashboardHelp.settings.title":"Settings help","dashboardHelp.settings.canDo.1":"Manage License, hot settings, saved data cleanup, server environment display, and language.","dashboardHelp.settings.needs.1":"License actions need MCP server connection. Server environment values are read-only here. Asset upload controls live in Assets settings.","dashboardHelp.openCloudApiKey.title":"Open Cloud API Key help","dashboardHelp.openCloudApiKey.canDo.1":"WEPPY uses this key only for Roblox Open Cloud requests.","dashboardHelp.openCloudApiKey.needs.1":"Create a Roblox API key in Creator Hub. Add Assets under Access Permissions, then enable both Read and Write operations.","dashboardHelp.openCloudApiKey.needs.2":"Set the key target to the same User or Group that you use as the upload Creator.","dashboardHelp.openCloudApiKey.needs.3":"The raw key is encrypted on this device. It is not sent to WEPPY servers, and it is not stored in any other external storage, browser storage, telemetry, logs, tool history, or Asset Library metadata.","dashboardHelp.openCloudApiKey.link.apiKeys":"Roblox API keys","dashboardHelp.openCloudApiKey.link.assetsGuide":"Assets API usage guide","dashboardHelp.openCloudApiKey.link.assetsReference":"Assets API reference","dashboardHelp.openCloudCreatorId.title":"Creator ID help","dashboardHelp.openCloudCreatorId.canDo.1":"The default Creator decides which User or Group owns newly uploaded Roblox assets.","dashboardHelp.openCloudCreatorId.needs.1":"For User, sign in to roblox.com, open your profile from your avatar or username, then copy only the number between /users/ and /profile in the browser URL.","dashboardHelp.openCloudCreatorId.needs.2":"For Group, open the Roblox group or community page, then copy only the number after /groups/ or /communities/ in the browser URL.","dashboardHelp.openCloudCreatorId.needs.3":"Paste only the numeric ID in Creator ID. Do not paste the full URL, rbxassetid://, User, or Group text.","dashboardHelp.openCloudCreatorId.link.creatorId":"Creator ID reference","dashboardHelp.openCloudCreatorId.link.userId":"User ID reference","dashboardHelp.openCloudCreatorId.link.groups":"Roblox groups","dashboardHelp.openCloudCreatorId.link.groupsApi":"Groups Cloud API","assets.settings.apiKey.inlineHelp":"WEPPY uses this key only for Roblox Open Cloud requests. The key is encrypted on this device and is not sent to WEPPY servers or stored in any other external storage.","assets.settings.creatorId.inlineHelp":"Default owner for new Roblox assets: your User ID or a Group ID.","common.close":"Tutup","dashboardHelp.section.currentState":"Check based on current status","dashboardHelp.overview.currentState.serverOnly":"Open Roblox Studio and start WEPPY Plugin so live place data can appear.","dashboardHelp.overview.currentState.default":"If the server disconnects, restart MCP or wait for the automatic reconnect.","dashboardHelp.connection.currentState.1":"If Plugin is missing, open Roblox Studio and run WEPPY Plugin. If AI Agent is missing, reconnect the MCP server from your AI tool.","dashboardHelp.sync.currentState.pluginMissing":"Connect WEPPY Plugin in Studio before using live sync details.","dashboardHelp.sync.currentState.basic":"Activate Pro to use bidirectional or reverse sync.","dashboardHelp.sync.currentState.default":"Use the sync log to diagnose stuck or failed sync activity.","dashboardHelp.assets.currentState.basic":"Activate Pro before uploading to Roblox.","dashboardHelp.assets.currentState.uploadDisabled":"Turn on Open Cloud upload in Assets settings.","dashboardHelp.assets.currentState.noCredential":"Save and test an Open Cloud API Key.","dashboardHelp.assets.currentState.noCreator":"Save a default Creator ID or enter Creator details during upload.","dashboardHelp.assets.currentState.default":"Open an asset detail dialog to start upload or usage scan.","dashboardHelp.changelog.currentState.1":"If the list is empty, ask the AI Agent to make a game change. Clear only deletes saved history records, not Studio objects.","dashboardHelp.playtest.currentState.basic":"Activate Pro to use real Playtest history.","dashboardHelp.playtest.currentState.default":"Ask the AI Agent to run a Playtest when no report is available.","dashboardHelp.uiStudio.currentState.basic":"Activate Pro to use live UI Studio previews.","dashboardHelp.uiStudio.currentState.default":"Ask the AI Agent to capture the UI or recheck improvement suggestions, then copy follow-up requests back to the AI chat.","dashboardHelp.tools.currentState.1":"If no records appear, check Settings > General and confirm history/statistics are enabled. Expand failed rows to inspect input, permission, or connection causes.","dashboardHelp.settings.currentState.1":"Activate a license for Pro features. Change environment values outside WEPPY Dashboard, then restart MCP. Review delete confirmations before clearing saved data.","dashboardHelp.openCloudApiKey.currentState.saved":"Use Test Connection to confirm the saved key still works.","dashboardHelp.openCloudApiKey.currentState.empty":"Create an API key in Roblox Creator Hub, paste it here, then save and test it.","dashboardHelp.openCloudCreatorId.currentState.saved":"Keep this value if new assets should continue using the same owner.","dashboardHelp.openCloudCreatorId.currentState.empty":"Choose User or Group, paste the numeric ID, then save the default Creator.","page.overview.title":"Overview","page.overview.description":"Check server, plugin, agent, sync, and recent game-change status in one place.","page.connection.title":"Connection","page.connection.description":"Inspect MCP server, AI agent, Studio plugin, and connection log status.","page.sync.title":"Sync","page.sync.description":"Monitor Studio to local sync status, direction, apply mode, and recent sync logs.","page.changelog.title":"Changelog","page.changelog.description":"Review game-change sessions captured from AI actions and sync events.","page.playtest.title":"Playtest","page.playtest.description":"Review automated playtest runs, saved reports, and result history.","page.uiStudio.title":"UI Studio","page.uiStudio.description":"Review UI captures, improvement suggestions, and before/after change history.","page.tools.title":"Tools","page.tools.description":"Inspect tool history, outcomes, fallback details, and usage statistics.","page.settings.title":"Settings","page.settings.description":"Manage license, live settings, saved data, server environment, and language.","dashboardHelp.whatsNew.title":"What's New help","dashboardHelp.whatsNew.canDo.1":"Review WEPPY Dashboard, MCP, and Plugin announcements, releases, and change notes.","dashboardHelp.whatsNew.needs.1":"Announcements are bundled locally. Unread state is stored in this browser.","dashboardHelp.whatsNew.currentState.1":"After you visit this page, unread announcements from this visit are marked read when you leave. The top header does not show a duplicate What's New button on this page."},Gf={"sidebar.overview":"Übersicht","sidebar.changelog":"Änderungsprotokoll","sidebar.connection":"Verbindung","sidebar.sync":"Sync","sidebar.playtest":"Playtest","sidebar.tools":"Tools","sidebar.settings":"Einstellungen","sidebar.ui_studio":"UI Studio","sidebar.gate.l1":"MCP-Server-Verbindung erforderlich","sidebar.gate.l2":"Roblox Studio Plugin-Verbindung erforderlich","header.currentProject":"Aktuelles Projekt","header.unknownProject":"Unbekanntes Projekt","header.projectRoot.label":"Projektstamm","header.currentProject.loading":"Lade Projektstamm...","header.currentProject.unavailable":"Projektstamm nicht verfügbar","header.placeNotConnected":"Place nicht verbunden","header.currentProject.tooltip":"Aktuell ausgewählter Projektordner","header.currentProject.loading.tooltip":"Projektstamm-Informationen werden noch geladen","header.currentProject.unavailable.tooltip":"Aktuelle Projektstamm-Informationen sind nicht verfügbar","header.currentProjectSyncRoot.label":"Sync-Stamm","header.currentProjectSyncRoot.loading":"Lade Sync-Stamm...","header.currentProjectSyncRoot.unavailable":"Sync-Stamm nicht verfügbar","header.currentProjectSyncRoot.tooltip":"Aktueller Sync-Stamm-Ordner für das ausgewählte Projekt","header.currentProjectSyncRoot.loading.tooltip":"Sync-Stamm-Informationen werden noch geladen","header.currentProjectSyncRoot.unavailable.tooltip":"Aktuelle Sync-Stamm-Informationen sind nicht verfügbar","header.testFiles.label":"Testdateien","header.testFiles.unavailable":"Testdateien nicht verfügbar","header.testFiles.tooltip":"Aktuelles Playtest-Dateiverzeichnis für den ausgewählten Place","header.places.title":"Places","header.places.active":"Aktiv","header.places.inactive":"Inaktiv","header.places.pluginRequired":"Plugin-Verbindung erforderlich","header.places.liveRequired":"Plugin-Verbindung für Live Active Place erforderlich","header.place.tooltip":"Verbundener Roblox Place","header.placeNotConnected.tooltip":"Place nicht verbunden","header.changeProjectRoot":"Projektstamm ändern","header.changeProjectRoot.ariaLabel":"Projektstamm ändern","header.changeProjectRoot.tooltip":"Den aktuellen Projektstamm ändern","header.changeProjectRoot.disabledTooltip.l0":"MCP-Server-Verbindung erforderlich, bevor der Projektstamm geändert werden kann","header.changeProjectRoot.disabledTooltip.loading":"Projektstamm-Informationen werden noch geladen","header.changeProjectRoot.disabledTooltip.unavailable":"Aktuelle Projektstamm-Informationen sind nicht verfügbar","header.projectRootModal.initial.title":"Projektstamm ändern","header.projectRootModal.initial.body.connected":"Nachdem Sie einen Projektordner ausgewählt haben, wechselt MCP zum neuen Projektstamm und der aktuelle Studio-Inhalt wird vollständig in das neue <ausgewählter Projektordner>/weppy-project-sync-Ziel resynced.","header.projectRootModal.initial.body.disconnected":"Nachdem Sie einen Projektordner ausgewählt haben, wechselt MCP zum neuen Projektstamm und verwendet <ausgewählter Projektordner>/weppy-project-sync als nächstes Sync-Ziel.","header.projectRootModal.initial.nextSyncRoot":"Neues Sync-Ziel nach Auswahl","header.projectRootModal.initial.nextSyncRoot.placeholder":"<ausgewählter Projektordner>/weppy-project-sync","header.projectRootModal.initial.warningStop":"Aktueller Sync wird sofort gestoppt.","header.projectRootModal.initial.warningFreshSync":"Der aktuelle Studio-Inhalt wird verwendet, um einen neuen Full-Sync im neuen Ziel zu erstellen.","header.projectRootModal.initial.warningNoMove":"Alte Sync-Ordner werden nicht automatisch verschoben.","header.projectRootModal.initial.warningDeferredSync":"Wenn Studio nicht verbunden ist, startet der Full Resync beim nächsten Verbinden des Plugins.","header.projectRootModal.confirm.title":"Neuen Projektstamm bestätigen","header.projectRootModal.confirm.body":"Überprüfen Sie den ausgewählten Projektordner, bevor Sie ihn anwenden.","header.projectRootModal.confirm.projectRoot":"Ausgewählter Projektordner","header.projectRootModal.confirm.syncRoot":"Neues Sync-Ziel","header.projectRootModal.confirm.warningNoMove":"Bestehende Sync-Ordner werden nicht automatisch verschoben.","header.projectRootModal.pick":"Ordner auswählen","header.projectRootModal.apply":"Änderung anwenden","header.projectRootModal.cancel":"Abbrechen","header.projectRootModal.error":"Projektstamm-Änderung fehlgeschlagen","status.online":"Online","status.offline":"Offline","status.idle":"Inaktiv","status.syncing":"Synchronisiere","status.error":"Fehler","status.initializing":"Initialisiere","level.l0.title":"Server getrennt","level.l0.message":"WEPPY Dashboard wurde geöffnet, aber der MCP-Server wurde gestoppt oder antwortet nicht.","level.l1.title":"Server verbunden","level.l1.hint":"Prüfen: Läuft Roblox Studio? Ist das Plugin installiert?","level.l2.ok":"Studio verbunden","tier.basic":"Basic","tier.basic.tooltip":"Basic-Tier mit dem Standard-Funktionsumfang des WEPPY Dashboards.","tier.pro":"Pro","tier.pro.tooltip":"Pro-Tier mit dem vollständigen Funktionsumfang des WEPPY Dashboards.","tier.mixed":"Gemischt","tier.upgrade":"Pro ansehen","tier.banner.save":"Sparen Sie KI-Token mit Pro!","tier.tool.query_instances.desc":"Inspizieren Sie Instanzen, durchsuchen Sie Children und Descendants und prüfen Sie Klasseninformationen. Pro fügt File Tree, Projektstruktur sowie Eigenschafts- oder Tag-Suche hinzu.","tier.tool.mutate_instances.desc":"Erstellen, löschen, klonen und verschieben Sie Instanzen. Pro fügt Tree-Erstellung und Massenerstellung, -löschung oder -klonierung hinzu.","tier.tool.manage_properties.desc":"Lesen und setzen Sie Eigenschaften, Attribute und Tags. Pro fügt berechnete Updates, relative Änderungen und Massen-Eigenschaftsoperationen hinzu.","tier.tool.manage_scripts.desc":"Lesen, schreiben, erstellen, löschen, bearbeiten und durchsuchen Sie Skript-Quelltext. Pro fügt Massenersetzung über mehrere Skripte hinzu.","tier.tool.manage_ui.desc":"Nur Pro. Spieltypische Menüs, HUDs, Buttons, Labels und Bildpanels erstellen oder verfeinern, dann Screenshots aufnehmen und Verbesserungsvorschläge prüfen.","tier.tool.manage_ui.action.design_brief":"UI-Richtung planen","tier.tool.manage_ui.action.create_tree":"Neue UI erstellen","tier.tool.manage_ui.action.update":"Bestehende UI aktualisieren","tier.tool.manage_ui.action.delete":"UI entfernen","tier.tool.manage_ui.action.preview":"UI-Bildschirm aufnehmen","tier.tool.manage_ui.action.check":"Verbesserungsvorschläge prüfen","tier.tool.manage_lighting.desc":"Nur Pro. Konfigurieren Sie Beleuchtung, Atmosphäre, Himmel, Terrain-Eigenschaften und Tageszeit-Einstellungen.","tier.tool.manage_selection.desc":"Lesen, setzen und löschen Sie die aktuelle Studio-Auswahl. Pro fügt Kontext, Details, Hinzufügen oder Entfernen sowie Auswahl-Watch-Unterstützung hinzu.","tier.tool.manage_camera.desc":"Inspizieren Sie Kamerastatus, fokussieren Sie nach Pfad oder Position und fordern Sie vorgeschlagene Ansichten an.","tier.tool.manage_tween.desc":"Nur Pro. Erstellen, abspielen, pausieren und abbrechen von Tweens für sanfte Animationen.","tier.tool.manage_audio.desc":"Nur Pro. Sounds abspielen, stoppen, pausieren und fortsetzen sowie den Audio-Listener konfigurieren.","tier.tool.manage_animation.desc":"Nur Pro. Animationen laden, abspielen und stoppen sowie aktive Animationstracks inspizieren.","tier.tool.manage_physics.desc":"Nur Pro. Kollisionsgruppen registrieren, Gruppenkollisionen konfigurieren und verfügbare Gruppen inspizieren.","tier.tool.manage_effects.desc":"Nur Pro. Partikel emittieren, Effekte löschen und Effektstatus umschalten.","tier.tool.manage_terrain.desc":"Nur Pro. Terrain-Formen füllen, Regionen löschen, Materialien ersetzen, Terrain-Farben verwalten, Voxel lesen oder schreiben, Terrain generieren und Terrain glätten.","tier.tool.spatial_query.desc":"Nur Pro. Raycasts ausführen, Boden finden, Platzierung validieren, Bereiche scannen, nach flachen oder Spawn-Positionen suchen, Begehbarkeit analysieren, Raum kartieren und Kollisionen inspizieren.","tier.tool.manage_assets.desc":"Nur Pro. Modelle einfügen, Asset-Informationen inspizieren, im Creator Store suchen, freie Assets oder Pakete einfügen und Assets exportieren.","tier.tool.manage_sync.desc":"Nur Pro. Sync-Status, -Konfiguration, -Verlauf, -Richtungen inspizieren und synchronisierte Dateien lesen oder schreiben.","tier.tool.workspace_state.desc":"Nur Pro. Full Sync ausführen, Screenshots erfassen, kürzliche Änderungen und Viewport-Status inspizieren und zugehörige Metadaten verwalten.","tier.tool.manage_logs.desc":"Inspizieren Sie Output-Logs mit Filterung, inkrementellem Polling, Buffer-Löschung und kürzlicher Fehlersuche.","tier.tool.system_info.desc":"Verbindungsstatus und aktuellen Tier inspizieren. Pro fügt Place-Info, Services, Studio-Einstellungen, Playtest-Steuerung und automatisierte Tests hinzu.","tier.tool.manage_studio.desc":"Nur Pro. Studio-Editor-Ansichtseinstellungen wie UI Preview für Screenshots und QA umschalten; es ändert Studio-Sitzungseinstellungen, nicht die UI-Objekte des Spiels.","tier.tool.batch_execute.desc":"Nur Pro. Mehrere Befehle in einem Batch ausführen, mit sequentieller Ausführung und optionalem Continue-on-Error-Verhalten.","tier.tool.execute_luau.desc":"Nur Pro. Beliebigen Luau-Code in der Roblox Studio Sandbox ausführen.","connection.server.title":"Serverstatus","connection.server.version":"Version","connection.server.version.tooltip":"Installierte MCP-Server-Version","connection.server.pid":"PID","connection.server.pid.tooltip":"Betriebssystem-Prozesskennung","connection.server.uptime":"Uptime","connection.server.uptime.tooltip":"Verstrichene Zeit seit dem Start des MCP-Servers","connection.server.session":"Session","connection.server.session.tooltip":"Aktuelle MCP-Session-Kennung","connection.server.exec":"Exec","connection.server.exec.tooltip":"Ausführungspfad zum Starten des MCP-Servers","connection.reconnect":"Erneut verbinden","connection.checkSettings":"Einstellungen prüfen","connection.agents.title":"KI-Agenten","connection.agents.name":"Agent","connection.agents.cwd":"Arbeitsverzeichnis","connection.agents.cwd.tooltip":"Aktuelles Arbeitsverzeichnis für den verbundenen KI-Agent","connection.agents.projectRoot":"Projektstamm","connection.agents.projectRoot.tooltip":"Maßgeblicher Projektstamm für die Sync-Eigentümerschaft","connection.agents.projectRoot.unresolved":"Nicht aufgelöst","connection.agents.connected":"Verbunden","connection.agents.unknown":"Unbekannt","connection.agents.none":"Keine Agenten verbunden","connection.plugins.title":"Plugins","connection.plugins.place":"Place","connection.plugins.clientId":"Client-ID","connection.plugins.clientId.tooltip":"Eindeutige Plugin-Client-Kennung für diese Studio-Verbindung","connection.plugins.lastSeen":"Zuletzt gesehen","connection.plugins.lastSeen.tooltip":"Zuletzt empfangener Heartbeat vom Plugin","connection.plugins.version":"Ver","connection.plugins.version.tooltip":"Vom Studio gemeldete installierte Plugin-Version","connection.plugins.none":"Keine Plugins verbunden","connection.log.title":"Verbindungsprotokoll","connection.log.empty":"Noch keine Ereignisse","connection.time.secondsAgo":"s","connection.time.minutesAgo":"min","connection.time.hoursAgo":"Std","common.loading":"Lade...","common.retry":"Wiederholen","common.reconnecting":"Verbinde erneut...","common.expand":"Ausklappen","common.collapse":"Einklappen","tools.tab.history":"Verlauf","tools.tab.statistics":"Statistik","tools.tab.failures":"Fehler","tools.col.time":"Zeit","tools.col.time.tooltip":"Wann der Tool-Lauf aufgezeichnet wurde.","tools.col.toolAction":"Tool.Action","tools.col.toolAction.tooltip":"Name des Tools und ausgeführte Action.","tools.col.duration":"Dauer","tools.col.duration.tooltip":"Wie lange das Tool zum Beenden brauchte.","tools.col.status":"Status","tools.col.status.tooltip":"Ergebnis des aufgezeichneten Tool-Laufs.","tools.col.tier":"Tier","tools.col.tier.tooltip":"Erforderlicher Lizenz-Tier für das Tool oder die Action.","tools.col.tierStats.tooltip":"Basic-, Pro- oder Mixed-Zusammenfassung für die Statistikzeile.","tools.col.tool":"Tool","tools.col.tool.tooltip":"Konsolidierter Tool-Name in der Statistiktabelle.","tools.col.calls":"Aufrufe","tools.col.calls.tooltip":"Gesamtzahl der aufgezeichneten Aufrufe für dieses Tool.","tools.col.ok":"OK","tools.col.ok.tooltip":"Anzahl direkt erfolgreicher Läufe.","tools.col.fallback":"FALLBACK","tools.col.fallback.tooltip":"Anzahl der Läufe, die durch Fallback-Ausführung erfolgreich waren.","tools.col.unsupported":"UNSUPPORTED","tools.col.unsupported.tooltip":"Anzahl blockierter Läufe ohne Fallback-Ausführung.","tools.col.warn":"WARN","tools.col.warn.tooltip":"Anzahl erwarteter Fehler durch Eingabe, Projektstatus, Roblox-Richtlinie oder Benutzercode.","tools.col.err":"FAILED","tools.col.err.tooltip":"Anzahl fehlgeschlagener Läufe.","tools.col.okRate":"OK%","tools.col.okRate.tooltip":"Prozentsatz der erfolgreich abgeschlossenen Aufrufe.","tools.col.avgTime":"Durchschnittszeit","tools.col.avgTime.tooltip":"Durchschnittliche Ausführungszeit über alle aufgezeichneten Aufrufe.","tools.col.error":"Fehler","tools.filter.tool":"Tool","tools.filter.all":"Alle","tools.badge.pro":"PRO","tools.badge.pro.tooltip":"Dieser Eintrag verwendete ein Pro-exklusives Tool oder eine Action.","tools.badge.fallback":"FALLBACK","tools.badge.fallback.tooltip":"Die angeforderte Pro-Action wurde über einen Basic-Fallback erfolgreich ausgeführt.","tools.badge.unsupported":"UNSUPPORTED","tools.badge.unsupported.tooltip":"Die angeforderte Pro-Action wurde blockiert und kein Fallback wurde ausgeführt.","tools.badge.warn":"WARN","tools.badge.warn.tooltip":"Der Tool-Aufruf ist wegen eines erwarteten Eingabe-, Projekt-, Richtlinien- oder Benutzercode-Problems fehlgeschlagen.","tools.badge.err":"FAILED","tools.badge.err.tooltip":"Der Tool-Lauf ist fehlgeschlagen.","tools.status.ok":"OK","tools.status.ok.tooltip":"Der Tool-Lauf wurde erfolgreich abgeschlossen.","tools.tier.mixed.tooltip":"Dieses Tool enthält sowohl Basic- als auch Pro-Actions.","tools.detail.params":"Parameter","tools.detail.params.tooltip":"Eingabeparameter, die an diesen Tool-Lauf übergeben wurden.","tools.detail.result":"Ergebnis","tools.detail.result.tooltip":"Zurückgegebenes Ergebnis-Payload für diesen Tool-Lauf.","tools.detail.requestedCommand":"Gesendeter Befehl","tools.detail.executedCommand":"Ausgeführter Befehl","tools.detail.alternatives":"Alternativen","tools.detail.blockedMessage":"Blockierungsgrund","tools.detail.noFallback":"Kein Fallback","tools.detail.noFallback.value":"Kein Fallback ausgeführt.","tools.detail.warningMessage":"Warnmeldung","tools.detail.errorMessage":"Fehlermeldung","tools.clear.history.title":"Verlauf löschen?","tools.clear.history.message":"Dies entfernt den aktuellen Place-Tools-Verlauf dauerhaft.","tools.clear.statistics.title":"Statistik löschen?","tools.clear.statistics.message":"Dies setzt die aktuelle Place-Tool-Statistik dauerhaft zurück.","tools.detail.error":"Fehler","tools.page.prev":"Zurück","tools.page.prev.tooltip":"Zur vorherigen Seite der Tool-Verlaufsergebnisse.","tools.page.next":"Weiter","tools.page.next.tooltip":"Zur nächsten Seite der Tool-Verlaufsergebnisse.","tools.empty.history":"Keine Verlaufseinträge","tools.empty.stats":"Keine Tool-Statistik","tools.empty.failures":"Keine Fehler","tools.summary.total":"Gesamt","tools.summary.calls":"Aufrufe","tools.summary.sessions":"Sessions","settings.license.title":"Lizenz","settings.license.title.tooltip":"Aktueller Lizenzstatus und Abonnement-Tier.","settings.license.status":"Status","settings.license.status.tooltip":"Aktueller Lizenz-Aktivierungsstatus.","settings.license.tier":"Tier","settings.license.tier.tooltip":"Aktueller Abonnement-Tier für verfügbare WEPPY Dashboard-Funktionen.","settings.license.key":"Schlüssel","settings.license.key.tooltip":"Maskierter Lizenzschlüssel, der derzeit vom Server geladen ist.","settings.license.keyValue.tooltip":"Maskierter Lizenzschlüssel, der derzeit vom Server geladen ist.","settings.license.provider":"Anbieter","settings.license.provider.auto":"auto","settings.license.provider.polar":"polar","settings.license.provider.gumroad":"gumroad","settings.license.provider.tooltip":"Lizenzanbieter zur Validierung dieses Schlüssels.","settings.license.providerValue.tooltip":"Lizenzanbieter zur Validierung dieses Schlüssels.","settings.license.active":"Aktiv","settings.license.active.tooltip":"Aktueller Lizenz-Aktivierungsstatus.","settings.license.status.activeCancelPending.tooltip":"Kündigung steht aus, aber Pro-Zugang bleibt bis zum Ende der aktuellen Abrechnungsperiode aktiv.","settings.license.inactive":"Inaktiv","settings.license.inactive.tooltip":"Aktueller Lizenz-Aktivierungsstatus.","settings.license.expired":"Abgelaufen","settings.license.expired.tooltip":"Aktueller Lizenz-Aktivierungsstatus.","settings.license.unavailable":"Lizenzinformationen nicht verfügbar","settings.license.detail.cancelPending":"Kündigung ist geplant. Pro-Zugang bleibt bis zum Ende der aktuellen Abrechnungsperiode aktiv.","settings.license.reset":"Lizenz zurücksetzen","settings.readOnly":"Schreibgeschützt","settings.readOnly.tooltip":"Dieser Abschnitt zeigt Werte, die nicht über das WEPPY Dashboard bearbeitet werden können.","settings.unavailable":"Einstellungen nicht verfügbar","settings.general.title":"Allgemeine Einstellungen","settings.general.title.tooltip":"Hot-Settings, die sofort beim Ändern angewendet werden.","settings.general.liveApply":"Live anwenden","settings.general.liveApply.tooltip":"Änderungen in diesem Abschnitt werden sofort ohne separate Speichern-Schaltfläche angewendet.","settings.general.applied":"Angewendet","settings.general.logLevel":"Log-Level","settings.general.logLevel.tooltip":"Legt fest, wie detailliert das WEPPY Dashboard in seine Logs schreibt.","settings.general.localHistory":"Tool-Verlaufsaufzeichnung","settings.general.localHistory.tooltip":"Speichert lokalen Tool-Ausführungsverlauf für die WEPPY Dashboard-Verlaufsansichten.","settings.general.localStatistics":"Tool-Statistiksammlung","settings.general.localStatistics.tooltip":"Aggregiert lokale Nutzungsstatistiken für WEPPY Dashboard-Berichte.","settings.general.contextCapture":"Kontext-Erfassung","settings.general.contextCapture.tooltip":"Wenn aktiviert, zeichnet das WEPPY Dashboard strukturierte Ausführungskontexte für Changelog- und Playtest-Ansichten auf.","settings.general.requestTimeout":"Aktions-Timeout","settings.general.requestTimeout.tooltip":"Maximale Wartezeit des WEPPY Dashboards auf eine Aktion, bevor sie fehlschlägt.","settings.general.requestTimeout.unit":"ms","settings.general.requestTimeout.unit.tooltip":"Aktions-Timeout wird in Millisekunden gemessen.","settings.cold.title":"Server-Umgebung","settings.cold.title.tooltip":"Schreibgeschützte Server-Umgebungswerte, die beim Start geladen werden.","settings.cold.httpPort.tooltip":"Portnummer, die vom MCP WEPPY Dashboard HTTP-Server verwendet wird.","settings.cold.httpHost.tooltip":"Host-Schnittstelle, an die sich der MCP WEPPY Dashboard HTTP-Server bindet.","settings.cold.dashboardAutoOpen.tooltip":"Steuert, ob das WEPPY Dashboard beim Start des Servers automatisch im Browser geöffnet wird.","settings.cold.dashboardAutoOpen.value.tooltip":"Aktuelles Startverhalten zum Öffnen des WEPPY Dashboards in einem Browser.","settings.cold.hint":"Über Umgebungsvariablen setzen, um diese Werte zu ändern.","settings.language.title":"Sprache","settings.language.title.tooltip":"Wählen Sie, wie der WEPPY Dashboard-Oberflächentext lokalisiert wird.","settings.language.dashboard":"WEPPY Dashboard-Sprache","settings.language.dashboard.tooltip":"Überschreibt die WEPPY Dashboard-Sprache oder folgt der Systemsprache, wenn auf Auto eingestellt.","settings.language.auto":"Auto","overview.l0.title":"MCP-Server getrennt","overview.l0.message":"Der MCP-Server antwortet nicht. Das WEPPY Dashboard versucht automatisch, die Verbindung wiederherzustellen.","overview.l0.step1":"Prüfen Sie, ob der MCP-Server-Prozess läuft","overview.l0.step2":"Starten Sie den MCP-Server-Befehl bei Bedarf neu","overview.l0.reconnecting":"Automatische Wiederverbindung alle 3s...","overview.l0.reconnectBtn":"Erneut verbinden","overview.l0.settingsBtn":"Einstellungen prüfen","overview.l1.pluginGuide":"Roblox Studio Plugin ist nicht verbunden","overview.l1.check1":"Läuft Roblox Studio?","overview.l1.check2":"Ist das WEPPY Plugin installiert?","overview.l1.feedHint":"Änderungen erscheinen hier, sobald das Plugin verbunden ist","overview.metric.server":"Server","overview.metric.server.tooltip":"MCP-Server-Laufzeit und Prozessstatus","overview.metric.plugin":"Plugin","overview.metric.plugin.tooltip":"Roblox Studio Plugin-Verbindungs- und Versionsstatus","overview.metric.agent":"Agent","overview.metric.agent.tooltip":"Verbundene KI-Coding-Agenten und ihr Laufzeitstatus","overview.metric.agent.instancesUnit":"Instanzen","overview.metric.sync":"Sync","overview.metric.sync.tooltip":"Aktuelle Studio-zu-Lokal-Sync-Aktivität","overview.metric.noAgent":"Kein Agent","overview.meta.version":"Version","overview.meta.version.tooltip":"Installierte MCP-Server-Version","overview.meta.session":"Session","overview.meta.session.tooltip":"Aktuelle MCP-Session-Kennung","overview.meta.pid":"PID","overview.meta.pid.tooltip":"Betriebssystem-Prozesskennung","overview.meta.uptime":"Uptime","overview.meta.uptime.tooltip":"Verstrichene Zeit seit dem Start des MCP-Servers","overview.feed.title":"Letzte Spieländerungen","overview.feed.empty":"Keine kürzlichen Änderungen","overview.changelog.title":"Session-Änderungszusammenfassung","overview.changelog.entries":"Gesamt","overview.changelog.scripts":"Skripte","overview.changelog.instances":"Instanzen","overview.changelog.properties":"Eigenschaften","overview.changelog.assets":"Assets","overview.tier.title":"Tier-Nutzung","changelog.subtitle":"Spieländerungsverlauf","changelog.filter.all":"Alle","changelog.filter.active":"Aktiv","changelog.filter.completed":"Abgeschlossen","changelog.empty":"Noch keine Changelog-Einträge","changelog.basic.limit.title":"Basic-Vorschau zeigt die letzten 3 Sessions","changelog.basic.limit.body":"Upgraden Sie auf Pro, um die vollständige Changelog-Timeline für diesen Place zu durchsuchen.","changelog.basic.metricLabel":"Sichtbares Changelog / Gesamt","changelog.basic.visible":"sichtbar","changelog.basic.total":"gesamt","changelog.card.active":"Aktiv","changelog.card.active.tooltip":"Diese Session empfängt noch neue Spieländerungen.","changelog.card.completed":"Abgeschlossen","changelog.card.completed.tooltip":"Diese Session ist beendet und es werden keine weiteren Änderungen erwartet.","changelog.card.bootstrapStatus":"Bootstrap","changelog.card.bootstrapStatus.tooltip":"Diese Session enthält nur den anfänglichen Sync-Bootstrap-Snapshot.","changelog.card.inProgress":"in Bearbeitung","changelog.card.noChanges":"Noch keine Änderungen","changelog.card.noChanges.tooltip":"Für diese Session wurden noch keine Spieländerungen extrahiert.","changelog.card.bootstrapSummary":"Anfänglicher Sync-Snapshot","changelog.card.bootstrapSummary.tooltip":"Anfängliche Datei-Sync-Schreibvorgänge werden zu einer einzigen Bootstrap-Snapshot-Zeile zusammengefasst.","changelog.card.sessionIntent":"Session-Absicht","changelog.card.scripts":"Skripte","changelog.card.scripts.tooltip":"In dieser Session vorgenommene Skript-Änderungen.","changelog.card.instances":"Instanzen","changelog.card.instances.tooltip":"Instanz-Erstellungs-, Lösch-, Verschiebe- oder Klonänderungen in dieser Session.","changelog.card.modified":"geändert","changelog.card.created":"erstellt","changelog.card.deleted":"gelöscht","changelog.card.moved":"verschoben","changelog.card.propertiesChanged":"Eigenschaften geändert","changelog.card.propertiesChanged.tooltip":"Für diese Session aufgezeichnete Eigenschaftswertänderungen.","changelog.card.lightingConfigured":"Beleuchtung konfiguriert","changelog.card.lightingConfigured.tooltip":"Beleuchtungs- oder Atmosphäreneinstellungen wurden in dieser Session geändert.","changelog.card.terrainConfigured":"Terrain konfiguriert","changelog.card.terrainConfigured.tooltip":"Terrain-Daten oder Terrain-Einstellungen wurden in dieser Session geändert.","changelog.card.assetsInserted":"Assets eingefügt","changelog.card.assetsInserted.tooltip":"In dieser Session in den Place eingefügte Assets.","changelog.category.script":"Skripte","changelog.category.instance":"Instanzen","changelog.category.property":"Eigenschaften","changelog.category.lighting":"Beleuchtung","changelog.category.terrain":"Terrain","changelog.category.asset":"Assets","changelog.detail.changeSummary":"Änderungszusammenfassung","changelog.detail.changeSummary.tooltip":"Anzahl der extrahierten Spieländerungen, gruppiert nach Kategorie für diese Session.","changelog.detail.changeTimeline":"Änderungs-Timeline","changelog.detail.changeTimeline.tooltip":"Chronologische Liste der extrahierten Spieländerungen für diese Session.","changelog.detail.context.title":"Kontextzusammenfassung","changelog.detail.context.tooltip":"Strukturierter Ausführungskontext, der für diese Changelog-Session erfasst wurde.","changelog.detail.verification.title":"Verifikation","changelog.detail.verification.tooltip":"Mit dieser Changelog-Session verknüpfte Verifikationssignale.","changelog.detail.verification.label":"Ergebnis","changelog.detail.verification.status":"Status","changelog.detail.verification.timestamp":"Aufgezeichnet am","changelog.detail.beforeAfter":"Vorher & Nachher","changelog.detail.filterCategory":"Kategorie","changelog.detail.filterCategory.tooltip":"Filtert die Timeline nach einer einzigen Änderungskategorie.","changelog.detail.confidence.exact":"Exakt","changelog.detail.confidence.exact.tooltip":"Sowohl der Vorher- als auch der Nachher-Zustand wurden für diese Änderung bestätigt.","changelog.detail.confidence.partial":"Teilweise","changelog.detail.confidence.partial.tooltip":"Nur ein Teil des Vorher- und Nachher-Zustands konnte für diese Änderung bestätigt werden.","changelog.detail.confidence.afterOnly":"Nur nachher","changelog.detail.confidence.afterOnly.tooltip":"Nur der resultierende Zustand nach der Änderung konnte bestätigt werden.","changelog.detail.confidence.intentOnly":"Nur Absicht","changelog.detail.confidence.intentOnly.tooltip":"Nur die angeforderte Aktion wurde aufgezeichnet, nicht der resultierende Zustand.","changelog.detail.confidence.unknown":"Unbekannt","changelog.detail.confidence.unknown.tooltip":"Diese Änderung konnte aus den verfügbaren Daten nicht zuverlässig klassifiziert werden.","changelog.detail.noChanges":"Keine Änderungen in dieser Kategorie","changelog.detail.backToList":"Zurück zur Liste","changelog.diff.empty":"Kein Diff verfügbar","changelog.diff.unified":"Vereinheitlicht","changelog.diff.sideBySide":"Nebeneinander","changelog.diff.before":"Vorher","changelog.diff.after":"Nachher","sync.overlay.title":"Roblox Studio Plugin erforderlich","sync.overlay.message":"Sync-Status ist verfügbar, sobald das Roblox Studio Plugin verbunden ist.","sync.overlay.check1":"Läuft Roblox Studio?","sync.overlay.check2":"Ist das WEPPY Plugin installiert?","sync.status.title":"Sync-Status","sync.status.title.tooltip":"Aktueller Studio- und lokaler Datei-Sync-Status für diesen Place.","sync.status.forwardOnly":"Nur vorwärts","sync.status.forwardOnly.tooltip":"Basic-Tier erlaubt nur Studio-zu-Lokal-Vorwärts-Sync.","sync.status.place":"Place","sync.status.place.tooltip":"Verbundener Roblox Place-Name und Place-ID.","sync.status.path":"Pfad","sync.status.path.tooltip":"Lokaler Dateisystem-Stamm, der derzeit für die Sync-Ausgabe verwendet wird.","sync.status.instances":"Instanzen","sync.status.instances.tooltip":"Gesamtzahl synchronisierter Roblox-Instanzen, die im lokalen Spiegel verfolgt werden.","sync.status.scripts":"Skripte","sync.status.scripts.tooltip":"Gesamtzahl synchronisierter Skript-Dateien, die derzeit für diesen Place indiziert sind.","sync.status.state":"Status","sync.status.state.tooltip":"Aktueller Laufzeit-Sync-Status, der vom Server gemeldet wird.","sync.directions.title":"Sync-Richtungen","sync.directions.title.tooltip":"Sync-Richtung pro Kategorie und Apply-Verhalten zwischen Lokal und Studio.","sync.directions.type":"Typ","sync.directions.type.tooltip":"Sync-Kategorie, die von dieser Regel betroffen ist.","sync.directions.direction":"Richtung","sync.directions.direction.tooltip":"Ob jede Kategorie von Studio, zu Studio oder in beide Richtungen synchronisiert.","sync.directions.applyMode":"Apply-Modus","sync.directions.applyMode.tooltip":"Wie eingehende Sync-Änderungen für diese Kategorie angewendet werden.","sync.directions.cat.scripts":"Skripte","sync.directions.cat.values":"Werte","sync.directions.cat.containers":"Container","sync.directions.cat.data":"Daten","sync.directions.cat.services":"Services","sync.directions.endpoint.local":"Lokal","sync.directions.endpoint.local.tooltip":"Lokale Dateien auf der Festplatte werden immer auf der linken Seite der Richtungsschiene angezeigt.","sync.directions.endpoint.studio":"Studio","sync.directions.endpoint.studio.tooltip":"Roblox Studio wird immer auf der rechten Seite der Richtungsschiene angezeigt.","sync.directions.mode.manual":"Manuell","sync.directions.mode.manual.tooltip":"Wendet Sync-Änderungen nur an, wenn Sie sie manuell auslösen.","sync.directions.mode.auto":"Auto","sync.directions.mode.auto.tooltip":"Wendet Sync-Änderungen automatisch an, wenn Updates eintreffen.","sync.directions.tooltip.forward.body":"Studio-Änderungen werden nur in lokale Dateien synchronisiert","sync.directions.tooltip.bidirectional.body":"Zwei-Wege-Sync zwischen Lokal und Studio","sync.directions.tooltip.reverse.body":"Lokale Dateiänderungen zu Studio pushen","sync.directions.tooltip.proRequired":"Pro im Basic-Tier erforderlich","sync.directions.dir.forward":"vorwärts","sync.directions.dir.bidirectional":"bidirektional","sync.directions.dir.reverse":"reverse","sync.log.title":"Sync-Protokoll","sync.log.empty":"Noch keine Sync-Ereignisse","sync.log.type.write":"WRITE","sync.log.type.write.tooltip":"Eine neue Sync-Ausgabe wurde auf die Festplatte geschrieben.","sync.log.type.update":"UPDATE","sync.log.type.update.tooltip":"Eine bestehende synchronisierte Datei oder Instanz wurde aktualisiert.","sync.log.type.delete":"DELETE","sync.log.type.delete.tooltip":"Eine synchronisierte Datei oder Instanz wurde entfernt.","sync.log.type.idle":"IDLE","sync.log.type.idle.tooltip":"Ein Sync-Ereignis wurde ohne Dateimutation aufgezeichnet.","sync.upgrade.title":"Vollständigen Sync mit Pro ansehen","sync.upgrade.benefit1":"Bidirektionaler Sync — Dateien bearbeiten, automatisch auf Studio anwenden","sync.upgrade.benefit2":"Reverse-Sync — Dateiänderungen zurück zu Studio pushen","sync.upgrade.benefit3":"Vollständiger Sync-Verlauf und detailliertes Änderungsprotokoll","sync.upgrade.buy":"Pro ansehen","playtest.status.title":"Playtest-Status","playtest.status.title.tooltip":"Aktueller Roblox Playtest-Sessionstatus, der von Studio gemeldet wird.","playtest.status.mode":"Modus","playtest.status.mode.tooltip":"Studio-Playtest-Startmodus für die aktuelle Session.","playtest.status.mode.value.tooltip":"Spezifischer Roblox Studio Playtest-Modus, der derzeit verwendet wird.","playtest.status.mode.play":"Play","playtest.status.mode.run":"Run","playtest.status.mode.server":"Server","playtest.status.mode.edit":"Edit","playtest.status.place.tooltip":"Roblox Place, der derzeit mit dieser Playtest-Session verknüpft ist.","playtest.status.state.running":"Läuft","playtest.status.state.running.tooltip":"Eine Roblox Playtest-Session läuft derzeit.","playtest.status.state.paused":"Pausiert","playtest.status.state.paused.tooltip":"Die aktuelle Roblox Playtest-Session ist pausiert.","playtest.status.state.notRunning":"Läuft nicht","playtest.status.state.notRunning.tooltip":"Es läuft derzeit keine Roblox Playtest-Session.","playtest.control.play":"Play","playtest.control.pause":"Pause","playtest.control.resume":"Resume","playtest.control.stop":"Stop","playtest.history.title":"Testverlauf","playtest.history.title.tooltip":"Aufgezeichnete automatisierte Playtest-Läufe für dieses Projekt.","playtest.history.empty":"Noch keine Testergebnisse","playtest.history.mode":"Modus","playtest.history.mode.tooltip":"Playtest-Modus, der für diesen aufgezeichneten Testlauf verwendet wurde.","playtest.history.status.passed":"Bestanden","playtest.history.status.failed":"Fehlgeschlagen","playtest.history.status.running":"Läuft","playtest.history.status.unknown":"Unbekannt","playtest.history.status.tooltip":"Aufgezeichneter Ergebnisstatus für diesen automatisierten Playtest-Lauf.","playtest.empty.title":"Noch keine Playtest-Ergebnisse","playtest.empty.message":"Testergebnisse erscheinen hier, nachdem der KI-Agent einen Playtest ausgeführt hat.","playtest.empty.message.before":"Testergebnisse erscheinen hier, nachdem der KI-Agent einen Playtest ausgeführt hat.","playtest.empty.message.after":"","playtest.empty.runTest.tooltip":"Ask the AI Agent to run a Playtest when you need a fresh report.","playtest.report.title":"Ausgewählter Bericht","playtest.report.title.tooltip":"Detaillierte Ausgabe für den derzeit ausgewählten automatisierten Playtest-Lauf.","playtest.report.content":"Bericht","playtest.report.content.tooltip":"Markdown-Zusammenfassung für den ausgewählten automatisierten Playtest-Lauf.","playtest.report.logs":"Logs","playtest.report.logs.tooltip":"Ausführungs-Logs, die für den ausgewählten automatisierten Playtest-Lauf erfasst wurden.","playtest.context.contextId":"Kontext-ID","playtest.context.why":"Warum dieser Test ausgeführt wurde","playtest.context.expected":"Erwartet","playtest.context.observed":"Beobachtet","playtest.report.empty":"Kein Berichtsinhalt verfügbar","playtest.basic.icon":"🎮","playtest.basic.title":"Playtest ist eine Pro-exklusive Funktion","playtest.basic.desc":"Steuern Sie Playtesting vom WEPPY Dashboard aus, führen Sie automatisierte Tests aus und sehen Sie detaillierte Testberichte.","playtest.basic.benefit1":"Ein-Klick-Play/Pause/Stop-Steuerung","playtest.basic.benefit2":"Automatisierte Testausführung über KI-Agent","playtest.basic.benefit3":"Testverlauf mit Bestanden/Fehlgeschlagen-Verfolgung","playtest.basic.benefit4":"Detaillierte Markdown-Testberichte","playtest.sample.badge":"Vorschau der Pro-Playtest-Ansicht","playtest.sample.title":"Sie sehen eine Vorschau des Playtest-Bildschirms, der nach dem Upgrade auf Pro verfügbar wird.","playtest.sample.message":"Diese Vorschau verwendet Beispieldaten. Live-Playtest-Steuerung, Verlaufsverwaltung und echte Berichte werden mit Pro freigeschaltet.","playtest.sample.clearDisabled":"Upgraden Sie auf Pro, um den Live-Playtest-Verlauf zu löschen.","playtest.sample.place":"Arena-Vorschau","playtest.sample.history.name":"Beispiel-Arena-Smoke-Test","playtest.sample.context.why":"In die Arena spawnen, den Eröffnungsangriff überleben und prüfen, ob das HUD sofort reagiert.","playtest.sample.context.expected":"Der Spieler spawnt sicher, die Countdown-UI erscheint innerhalb einer Sekunde und die erste Welle startet ohne Fehler.","playtest.sample.context.observed":"Spawn-Schutz hielt, das HUD wurde rechtzeitig aktualisiert und Welle eins wurde ohne Gameplay-Regressionen abgeschlossen.","playtest.sample.report.markdown":`# Beispiel-Arena-Smoke-Test
130
+
131
+ - Spawn-Ablauf: BESTANDEN
132
+ - HUD-Countdown: BESTANDEN
133
+ - Wellen-Bootstrap: BESTANDEN
134
+
135
+ Dies ist eine Beispielvorschau. Upgraden Sie auf Pro, um Live-Playtests auszuführen und echte Berichte zu speichern.`,"playtest.sample.report.logs":`[sample] boot playtest preview
136
+ [sample] spawn protection active
137
+ [sample] hud countdown rendered
138
+ [sample] wave one completed
139
+ [sample] preview report finished`,"sidebar.whatsNew":"Neuigkeiten","sidebar.help.group":"Hilfe & Feedback","sidebar.help.bug":"Fehler melden","sidebar.help.bug.tooltip":"Lokales Diagnosepaket erstellen und einen vorausgefuellten Fehlerbericht auf GitHub oeffnen","bugReportDialog.title":"diagnostics.zip kann bei der Fehlersuche helfen","bugReportDialog.subtitle":"WEPPY hat auf diesem Computer eine Diagnose-Zip erstellt. Sie enthält Studio-, Plugin-, Sync- und Tool-Logs, die uns helfen können zu verstehen, was passiert ist.","bugReportDialog.close":"Close","bugReportDialog.loading":"Preparing diagnostics.zip...","bugReportDialog.error":"Could not create the diagnostics bundle. You can still open GitHub without diagnostics.","bugReportDialog.bundle":"Bundle","bugReportDialog.included":"Included","bugReportDialog.included.none":"No log files found","bugReportDialog.optional":"Du kannst den Bug Report auch ohne diese Datei senden, aber mit der Zip finden wir die Ursache meist schneller.","bugReportDialog.attachHow":"Lade die Zip herunter oder öffne ihren Speicherort und füge sie vor dem Absenden im Feld Diagnostics ZIP (optional) des GitHub-Issues hinzu.","bugReportDialog.download":"1. diagnostics.zip herunterladen","bugReportDialog.reveal":"Reveal in Finder","bugReportDialog.reveal.opening":"Opening...","bugReportDialog.reveal.opened":"Opened location","bugReportDialog.reveal.failed":"Could not open the file location.","bugReportDialog.openGithub":"2. GitHub-Issue öffnen","bugReportDialog.openGithubFallback":"Open GitHub without diagnostics","bugReportDialog.retry":"Try again","bugReportDialog.hint":"Die Zip kann lokale Logs und Projektkontext enthalten. Prüfe sie vor dem Anhängen, wenn du sie teilen möchtest.","sidebar.help.feature":"Feature vorschlagen","sidebar.help.feature.tooltip":"Neues Feature oder Verbesserung auf GitHub vorschlagen","sidebar.help.discussions":"Support","sidebar.help.discussions.tooltip":"Fragen stellen oder Installationshilfe uber GitHub Issues erhalten","sidebar.help.troubleshooting":"Fehlerbehebung","sidebar.help.troubleshooting.tooltip":"Offiziellen Troubleshooting-Leitfaden auf weppyai.com öffnen","header.whatsNew":"Neuigkeiten","header.whatsNew.tooltip":"Neuigkeiten","upgrade.title":"Pro ansehen","upgrade.tagline":"Pro-Funktionen ansehen","upgrade.cta":"Pro ansehen","upgrade.licenseShortcut":"Lizenz eingeben","upgrade.validUntil":"Until {{date}}","whatsNew.pageTitle":"Neuigkeiten","whatsNew.pageSubtitle":"Bleiben Sie über MCP-Änderungen auf dem Laufenden","whatsNew.unreadSection":"Ungelesen","whatsNew.allSection":"Alle Ankündigungen","whatsNew.empty":"Noch keine Ankündigungen","whatsNew.newBadge":"NEU","whatsNew.category.release":"Release","whatsNew.category.notice":"Hinweis","whatsNew.category.deprecation":"Veraltet","whatsNew.category.tip":"Tipp","uiStudio.title":"UI Studio","uiStudio.empty":"Noch keine Screenshots gespeichert. Sie werden automatisch erstellt, wenn ein KI-Agent den aktuellen UI-Zustand erfasst.","uiStudio.loading":"Loading…","uiStudio.pluginGuide.title":"Roblox Studio Plugin ist nicht verbunden","uiStudio.pluginGuide.message":"UI Studio zeigt Screenshots und Änderungsverlauf aus dem verbundenen Studio-Place. Es wird automatisch aktualisiert, sobald Studio und das WEPPY Plugin verbunden sind.","uiStudio.pluginGuide.check1":"Läuft Roblox Studio?","uiStudio.pluginGuide.check2":"Ist das WEPPY Plugin installiert und aktiv?","uiStudio.pluginGuide.waiting":"Warten auf Plugin-Verbindung...","uiStudio.capturedAt":"Captured at","uiStudio.scope":"Scope","uiStudio.target":"Target","uiStudio.briefId":"Brief ID","uiStudio.detailClose":"Close","uiStudio.colCheck":"Check","uiStudio.colPriority":"Priority","uiStudio.colCurrent":"Current","uiStudio.colRecommended":"Recommended","uiStudio.colSuggestion":"Suggestion","uiStudio.priorityHigh":"Zuerst prüfen","uiStudio.priorityLow":"Optionale Verbesserung","uiStudio.highPrioritySection":"Zuerst prüfen","uiStudio.lowPrioritySection":"Optionale Verbesserungen","uiStudio.groupSummary":"items","uiStudio.fixLabel":"Fix","uiStudio.copyFixCommand":"Copy AI instruction","uiStudio.copiedToClipboard":"Copied","uiStudio.fullPath":"Full path","uiStudio.falsePositiveWarning":"This group may contain false positives","uiStudio.noSuggestions":"No current improvement suggestions","uiStudio.sample.badge":"Preview of the Pro UI Studio","uiStudio.sample.title":"You are previewing the UI Studio that unlocks after upgrading to Pro.","uiStudio.sample.message":"This preview uses sample data from a demo inventory UI. Real screenshots, review history, and AI-driven fixes unlock with Pro.","uiStudio.tabs.analysis":"Analyse","uiStudio.tabs.history":"Verlauf","uiStudio.analysis.reportsTitle":"Neueste Analyse nach UI-Ziel","uiStudio.analysis.recentCapturesTitle":"Letzte Aufnahmen","uiStudio.analysis.detailDialog":"Analysedetails","uiStudio.analysis.targetCountLabel":"Analysierte Ziele","uiStudio.analysis.captureLabel":"Aufnahmen","uiStudio.analysis.verdict.hasSuggestions":"Verbesserungsvorschläge","uiStudio.analysis.verdict.needsFix":"Verbesserungsvorschläge","uiStudio.analysis.verdict.review":"Verbesserungsvorschläge","uiStudio.analysis.verdict.passed":"Keine aktuellen Vorschläge","uiStudio.analysis.verdictLabel":"Verbesserungsübersicht","uiStudio.analysis.thresholds":"Prüfgrundlage","uiStudio.analysis.issueSummary.passed":"Auf der aktuellen Prüfgrundlage gibt es keine weiteren Verbesserungsvorschläge.","uiStudio.history.title":"Änderungsverlauf","uiStudio.history.empty":"Noch kein Verlauf vorhanden. Wenn ein KI-Agent die UI mit manage_ui ändert, wird es automatisch aufgezeichnet.","uiStudio.history.loading":"Wird geladen...","uiStudio.history.error":"Fehler","uiStudio.history.clear":"Alles löschen","uiStudio.history.filter.actions":"Aktionstyp","uiStudio.history.filter.actionAll":"Alle","uiStudio.history.filter.actionCreate":"Erstellen","uiStudio.history.filter.actionUpdate":"Aktualisieren","uiStudio.history.filter.actionDelete":"Löschen","uiStudio.history.filter.period":"Zeitraum","uiStudio.history.filter.dateAll":"Alle","uiStudio.history.filter.today":"Heute","uiStudio.history.filter.yesterday":"Gestern","uiStudio.history.filter.last7Days":"Letzte 7 Tage","uiStudio.history.filter.last30Days":"Letzte 30 Tage","uiStudio.history.filter.customRange":"Eigener Zeitraum","uiStudio.history.filter.reset":"Zurücksetzen","uiStudio.history.filter.from":"Von","uiStudio.history.filter.to":"Bis","uiStudio.history.row.affectedPaths":"Pfade","uiStudio.history.row.mutations":"Änderungsdetails","uiStudio.history.row.expand":"▾ Erweitern","uiStudio.history.row.collapse":"▲ Einklappen","uiStudio.history.row.expandDetails":"{n} Änderungen anzeigen","uiStudio.history.row.collapseDetails":"Änderungen ausblenden","uiStudio.history.row.toggleDetails":"Änderungsdetails umschalten","uiStudio.history.row.mutationsEmpty":"Keine Änderungsdetails","uiStudio.history.row.toolLabel":"UI-Änderungen ({n})","uiStudio.history.row.compare":"Vorher / Nachher","uiStudio.history.row.noBeforeState":"Kein Vorher-Zustand","uiStudio.history.row.noAfterState":"Kein Nachher-Zustand","uiStudio.history.row.qualityPlan":"Designrichtung","uiStudio.history.row.designCheck":"Vorschläge","uiStudio.history.row.designCheckUnavailable":"Vorschläge: nicht verfügbar","uiStudio.history.row.designCheckNone":"Vorschläge: keine","uiStudio.history.selection.deleteSelected":"Ausgewählte löschen","uiStudio.history.selection.selectAll":"Alle auswählen","uiStudio.history.selection.clearSelection":"Auswahl aufheben","uiStudio.history.confirm.deleteRequestsTitle":"Änderungsprotokolle löschen","uiStudio.history.confirm.deleteRequestsMessage":"Die ausgewählten Änderungsprotokolle werden gelöscht. Diese Aktion kann nicht rückgängig gemacht werden.","uiStudio.history.confirm.clearRequestsTitle":"Änderungsverlauf löschen","uiStudio.history.confirm.clearRequestsMessage":"Der Änderungsverlauf des aktuellen Place wird gelöscht. Studio-Instanzen sind nicht betroffen.","uiStudio.history.confirm.cascadeOption":"Verknüpfte Screenshots ebenfalls löschen","uiStudio.history.drawer.close":"Schließen","uiStudio.actions.previewAgain":"Erneut vorschau","uiStudio.actions.deleteSnapshot":"Diesen Screenshot löschen","uiStudio.actions.proRequired":"Nach Pro-Upgrade verfügbar","uiStudio.actions.captureCurrentState":"Aktuellen Zustand erfassen","uiStudio.actions.checkSuggestionsAgain":"Vorschläge erneut prüfen","uiStudio.actions.previewRunning":"Wird erfasst…","uiStudio.actions.previewRunningDetail":"Nach Abschluss wird die neue Screenshot-Datei-ID angezeigt.","uiStudio.actions.previewNeedsSaveCheck":"Erfassung abgeschlossen, Speicherung prüfen","uiStudio.actions.previewSaved":"Neuer Screenshot gespeichert","uiStudio.actions.previewComplete":"Erfassung abgeschlossen","uiStudio.actions.previewSavedDetail":"Vorhandene Screenshots bleiben erhalten; dies wurde als neue Datei gespeichert.","uiStudio.actions.previewSavedPathMissing":"Eine neue Screenshot-ID wurde zurückgegeben, aber der Speicherpfad konnte nicht bestätigt werden.","uiStudio.actions.previewSnapshotIdMissing":"Die neue Screenshot-ID konnte nicht bestätigt werden. Aktualisiere die Liste, um zu prüfen, ob sie gespeichert wurde.","uiStudio.actions.more":"Mehr","uiStudio.gallery.selection.selectedCount":" ausgewählt","uiStudio.confirm.deleteSnapshotTitle":"Screenshot löschen","uiStudio.confirm.deleteSnapshotMessage":"Nur diese Screenshot-Datei wird gelöscht (Studio-Instanz bleibt erhalten).","uiStudio.confirm.deleteBatchTitle":"Ausgewählte Screenshots löschen","uiStudio.confirm.deleteBatchMessage":"Die ausgewählten Screenshots werden gelöscht. Diese Aktion kann nicht rückgängig gemacht werden.","uiStudio.gallery.selectMode":"Auswählen","uiStudio.gallery.exitSelectMode":"Abbrechen","uiStudio.gallery.selectAll":"Alle auswählen","uiStudio.gallery.clearSelection":"Auswahl aufheben","uiStudio.gallery.deleteSelected":"Auswahl löschen","common.cancel":"Abbrechen","common.delete":"Löschen","uiStudio.storage.title":"Gespeicherte UI Studio-Daten","uiStudio.storage.usageLabel":"In Verwendung","uiStudio.storage.historyBytes":"Verlauf","uiStudio.storage.snapshotBytes":"Screenshots","uiStudio.storage.requestCount":"Änderungsprotokolle","uiStudio.storage.mutationCount":"Änderungsdetails","uiStudio.storage.snapshotCount":"Screenshots","uiStudio.storage.countSuffix":"","uiStudio.storage.lastRun":"Letzte automatische Bereinigung","uiStudio.storage.lastRunNever":"—","uiStudio.storage.lastRunFreed":"freigegeben","uiStudio.storage.lastRunErrors":"Fehler","uiStudio.storage.loading":"Lädt...","uiStudio.cleanup.policy.title":"Richtlinie zur automatischen Löschung","uiStudio.cleanup.policy.modeOff":"Deaktiviert","uiStudio.cleanup.policy.modeAge":"Altersbasiert","uiStudio.cleanup.policy.modeSize":"Größenbasiert","uiStudio.cleanup.policy.cascade":"Auch verknüpfte Screenshots löschen","uiStudio.cleanup.policy.save":"Richtlinie speichern","uiStudio.cleanup.policy.runNow":"Jetzt ausführen","uiStudio.cleanup.policy.proRequired":"Nach dem Upgrade auf Pro verfügbar","uiStudio.cleanup.policy.daysUnit":"T","uiStudio.cleanup.policy.mbUnit":"MB","uiStudio.cleanup.policy.gbUnit":"GB","uiStudio.cleanup.policy.confirm.title":"Richtlinie bestätigen","uiStudio.cleanup.policy.confirm.messageStrict":"Diese Richtlinie wird sofort löschen","uiStudio.cleanup.policy.confirm.requests":" Änderungsprotokolle","uiStudio.cleanup.policy.confirm.snapshots":" Screenshots","uiStudio.cleanup.policy.confirm.freed":"freigegeben — Anwenden?","uiStudio.cleanup.keepLastNDays":"Nur letzte {n} Tage behalten","uiStudio.cleanup.selectedDelete":"Auswahl löschen…","uiStudio.cleanup.deleteAll":"Alles löschen…","uiStudio.cleanup.cleanupConfirmTitle":"Bereinigung bestätigen","uiStudio.cleanup.cleanupConfirmMessage":"Die ausgewählten Elemente werden gelöscht. Diese Aktion kann nicht rückgängig gemacht werden.","uiStudio.cleanup.cleanupConfirmMessage.keep7":"Change records and screenshots older than 7 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.keep30":"Change records and screenshots older than 30 days will be deleted. This action cannot be undone.","uiStudio.cleanup.cleanupConfirmMessage.all":" saved change records and screenshots will be deleted. This action cannot be undone.","uiStudio.cleanup.label":"Manuelle Bereinigung","uiStudio.cleanup.studioPreservedNote":"Diese Aktion löscht nur Verlaufs- und Screenshot-Dateien auf dem Datenträger; Roblox Studio-Instanzen sind nicht betroffen.","uiStudio.history.sample.bannerBadge":"Vorschau des Pro-Änderungsverlaufs","uiStudio.history.sample.bannerTitle":"Vorschau des Pro-Änderungsverlaufs","uiStudio.history.sample.bannerMessage":"Diese Vorschau verwendet Beispieldaten. Echter Anfrageverlauf, Vorher/Nachher-Vergleich und Massenlöschung sind in Pro verfügbar.","uiStudio.fix.touchTarget.label":"Touch target size","uiStudio.fix.touchTarget.description":"Checks whether controls are large enough to tap comfortably on mobile.","uiStudio.fix.touchTarget.howToFix":"Increase button Size to at least 44x44 px or expand the touch area with UIPadding.","uiStudio.fix.contrast.label":"Text contrast","uiStudio.fix.contrast.description":"Checks whether text and background contrast meet accessibility guidance.","uiStudio.fix.contrast.howToFix":"Use a brighter TextColor3 or darken the BackgroundColor3.","uiStudio.fix.contrast.falsePositive":"Emoji icons may be false positives when their color is fixed.","uiStudio.fix.textScaled.label":"TextScaled usage","uiStudio.fix.textScaled.description":"TextScaled without UITextSizeConstraint can break layouts when text expands.","uiStudio.fix.textScaled.howToFix":"Add a UITextSizeConstraint child to the TextLabel and set MaxTextSize.","uiStudio.fix.safezone.label":"Safe-zone placement","uiStudio.fix.safezone.description":"Checks whether controls stay inside platform safe zones.","uiStudio.fix.safezone.howToFix":"Move Position inside the safe zone or reduce the parent Frame.","uiStudio.fix.minTextSize.label":"Minimum font size","uiStudio.fix.minTextSize.description":"Checks whether text is too small to read comfortably.","uiStudio.fix.minTextSize.howToFix":"Increase TextSize to at least 14 for body text.","uiStudio.sample.history.request1.label":"Initial HUD layout creation","uiStudio.sample.history.request2.label":"Inventory modal design update","uiStudio.sample.history.request3.label":"HUD HealthBar color update","uiStudio.sample.history.request4.label":"Expand Inventory tab button touch targets","uiStudio.sample.history.request5.label":"Remove Settings popup","uiStudio.sample.history.request6.label":"Add HUD minimap component","uiStudio.sample.history.request1.mutation1.diff":"Created Frame + HealthBar + StaminaBar","uiStudio.sample.history.request1.mutation2.diff":"BackgroundColor3 -> Color3.new(0.2,0.8,0.2)","uiStudio.sample.history.request1.mutation3.diff":"BackgroundColor3 -> Color3.new(0.1,0.6,1.0)","uiStudio.sample.history.request1.mutation4.diff":"Set AnchorPoint, Position, and Size","uiStudio.sample.history.request1.mutation5.diff":"Screenshot saved","uiStudio.sample.history.request2.mutation1.diff":"Darkened BackgroundColor3 for better contrast","uiStudio.sample.history.request2.mutation2.diff":"TextColor3 -> Color3.new(1,1,1), TextSize 16 -> 18","uiStudio.sample.history.request2.mutation3.diff":"BorderSizePixel 0 -> 2, set BorderColor3","uiStudio.sample.history.request2.mutation4.diff":"Screenshot saved","uiStudio.sample.history.request3.mutation1.diff":"BackgroundColor3 -> Color3.new(0.9,0.2,0.2) (red tone)","uiStudio.sample.history.request3.mutation2.diff":"Screenshot saved","uiStudio.sample.history.request4.mutation1.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation2.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation3.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation4.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation5.diff":"Size {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation6.diff":"Screenshot saved","uiStudio.sample.history.request5.mutation1.diff":"Removed ScreenGui (Settings-only UI)","uiStudio.sample.history.request6.mutation1.diff":"Attempted to create Frame + MapImage + PlayerDot","uiStudio.sample.history.request6.mutation2.diff":"Set Size, Position, and BackgroundTransparency","uiStudio.sample.history.request6.mutation3.diff":"Interrupted by server restart while setting ImageLabel","uiStudio.sample.history.request6.mutation4.diff":"Partial screenshot saved","uiStudio.sample.history.request6.mutation3.error":"server_restart: connection lost","uiStudio.sample.history.request6.mutation4.error":"partial screenshot: missing layers","uiStudio.sample.history.detail.backgroundColor":"Background color","uiStudio.sample.history.detail.anchorPoint":"Anchor","uiStudio.sample.history.detail.position":"Position","uiStudio.sample.history.detail.size":"Size","uiStudio.sample.history.detail.textColor":"Text color","uiStudio.sample.history.detail.textSize":"Text size","uiStudio.sample.history.detail.borderSize":"Border size","uiStudio.sample.history.detail.borderColor":"Border color","uiStudio.history.sample.tooltip":"Auf Pro upgraden, um den vollständigen Verlauf freizuschalten","settings.dataHistory.title":"Data & History","settings.dataHistory.title.tooltip":"Manage saved dashboard data in one place.","settings.dataHistory.collapse":"Collapse {title}","settings.dataHistory.expand":"Expand {title}","settings.dataHistory.scope":"Current project","settings.dataHistory.scope.tooltip":"Clear actions apply to the current project and active place where applicable.","settings.dataHistory.intro":"Review saved dashboard data, open the related page, or clear stored records from one place.","settings.dataHistory.toolsActivity.title":"Tool activity","settings.dataHistory.toolsActivity.description":"Saved tool runs shown on the Tools page.","settings.dataHistory.toolStats.title":"Tool usage statistics","settings.dataHistory.toolStats.description":"Aggregated tool counts and status totals.","settings.dataHistory.syncLog.title":"Sync log","settings.dataHistory.syncLog.description":"Saved file sync events for the active place.","settings.dataHistory.playtest.title":"Playtest reports","settings.dataHistory.playtest.description":"Saved automated playtest reports and logs.","settings.dataHistory.projectChanges.title":"Project change summary","settings.dataHistory.projectChanges.description":"Saved summaries of project changes.","settings.dataHistory.connectionLog.title":"Connection log","settings.dataHistory.connectionLog.description":"Saved MCP and Studio connection events.","settings.dataHistory.uiStudio.title":"UI Studio history and screenshots","settings.dataHistory.uiStudio.tooltip":"Manage saved UI Studio change records, screenshots, and auto-delete policy.","settings.dataHistory.uiStudio.description":"Saved UI Studio change records, screenshots, and cleanup policy.","settings.dataHistory.uiStudio.clear.title":"Clear UI Studio saved data?","settings.dataHistory.uiStudio.clear.message":"This deletes saved UI Studio change records and screenshots only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.uiStudio.clear.success":"UI Studio saved data cleared.","settings.dataHistory.uiStudio.clear.failed":"Failed to clear UI Studio saved data.","settings.dataHistory.metric.unavailable":"Unavailable","settings.dataHistory.metric.sizeUnavailable":"size unavailable","settings.dataHistory.metric.records":"records","settings.dataHistory.metric.runs":"runs","settings.dataHistory.metric.sessions":"sessions","settings.dataHistory.metric.reports":"reports","settings.dataHistory.open":"Open","settings.dataHistory.clear.title":"Clear saved data?","settings.dataHistory.clear.message":"This deletes saved dashboard records only. Roblox Studio instances and project objects are not changed.","settings.dataHistory.clear.success":"Saved data cleared.","settings.dataHistory.clear.failed":"Failed to clear saved data.","toast.serverConnected":"MCP-Server verbunden","toast.serverDisconnected":"MCP-Server getrennt","toast.pluginConnected":"Plugin verbunden","toast.pluginDisconnected":"Plugin getrennt","toast.clearSuccess":"Erfolgreich geleert","toast.clearFailed":"Daten konnten nicht geleert werden","common.clear":"Leeren","settings.license.activate":"Lizenz aktivieren","settings.license.refresh":"Lizenz aktualisieren","settings.license.keyInput":"Lizenzschlüssel","settings.license.disconnected":"Getrennt","settings.license.disconnected.tooltip":"Verbinden Sie sich erneut mit dem MCP-Server, um Lizenzaktionen über das WEPPY Dashboard zu verwalten.","settings.license.live.tooltip":"Lizenzaktionen werden sofort an den MCP-Server gesendet.","settings.license.status.activationRequired":"Aktivierung erforderlich","settings.license.status.activationRequired.tooltip":"Eine manuelle Lizenzaktivierung ist erforderlich, bevor das WEPPY Dashboard diesen Status aktualisieren kann.","settings.license.status.grace":"Karenzzeit","settings.license.status.grace.tooltip":"Die Anbieterprüfung ist vorübergehend nicht verfügbar, der Pro-Zugriff bleibt während der Karenzzeit aktiv.","settings.license.status.graceBilling.tooltip":"Während einer abrechnungsbedingten Karenzzeit bleibt der Pro-Zugriff verfügbar.","settings.license.detail.graceBilling":"Der Pro-Zugriff bleibt während einer Abrechnungs-Karenzzeit verfügbar.","settings.license.detail.graceProviderUnavailable":"Anbieter nicht verfügbar. Der Pro-Zugriff bleibt im Karenzmodus aktiv.","settings.license.detail.manualActivation":"Manuelle Aktivierung erforderlich, um den Pro-Zugriff wiederherzustellen.","settings.license.detail.missingSessionToken":"Die Aktualisierung ist blockiert, da das aktuelle Session-Token fehlt.","settings.license.detail.refreshRecommended":"Die Lizenzprüfung sollte bald aktualisiert werden.","connection.agents.kill":"Beenden","connection.agents.kill.title":"Agent beenden?","connection.agents.killed":"Agent beendet","connection.agents.killFailed":"Agent konnte nicht beendet werden","connection.agents.lastCommand":"Letzter Befehl","connection.agents.lastCommand.tooltip":"Der zuletzt von diesem Agenten ausgeführte Tool-Aufruf","connection.agents.lastSeen":"Zuletzt aktiv","connection.agents.lastSeen.tooltip":"Der letzte Heartbeat oder die letzte Aktivität dieses Agenten","connection.clear.title":"Verbindungsprotokoll leeren?","connection.clear.message":"Dadurch wird das gespeicherte Verbindungsprotokoll des aktuellen Projekts dauerhaft entfernt.","sync.clear.title":"Synchronisierungsprotokoll leeren?","sync.clear.message":"Dadurch wird das gespeicherte Synchronisierungsprotokoll des aktuellen Place dauerhaft entfernt.","playtest.clear.title":"Testverlauf leeren?","playtest.clear.message":"Dadurch werden die gespeicherten Playtest-Berichte des aktuellen Place dauerhaft entfernt.","changelog.clear.title":"Änderungsprotokoll leeren?","changelog.clear.message":"Dadurch wird das gespeicherte Änderungsprotokoll des aktuellen Place dauerhaft entfernt.","sync.status.placePath":"Place-Pfad","sync.status.placePath.tooltip":"Aktives Place-Verzeichnis, in das Explorer-Dateien synchronisiert werden.","tier.progress.label":"Pro / Gesamt","changelog.card.representativeArea":"Repräsentativer Bereich","changelog.card.verification":"Überprüfung","uiStudio.designCheckResultsTitle":"Design-Check-Vorschläge","uiStudio.actions.designCheckAgain":"Erneut prüfen","uiStudio.actions.designCheckRunning":"Vorschläge werden geprüft...","uiStudio.actions.designCheckRunningDetail":"Nach Abschluss werden zuerst zu prüfende, empfohlene und optionale Elemente angezeigt.","uiStudio.actions.designCheckComplete":"Vorschlagsprüfung abgeschlossen","uiStudio.actions.designCheckNoSnapshotSaved":"Diese Aktion speichert keine neue Screenshot-Datei.","uiStudio.sample.designCheck.contrast":"Text contrast is below {expected} (current {actual}). Adjust TextColor3 or BackgroundColor3.","uiStudio.sample.designCheck.touchTarget":"Touch target is below {expected} (current {actual}). Increase Size or padding.","uiStudio.sample.designCheck.minTextSize":"TextSize is below {expected} (current {actual}). Increase it for readability.","uiStudio.designCheckResultsTitle.tooltip":"All improvement suggestions found in this capture.","uiStudio.priorityMedium":"Prüfung empfohlen","uiStudio.mediumPrioritySection":"Prüfung empfohlen","uiStudio.history.row.qualityPlan.tooltip":"Für diese Änderung verwendete Brief-Designrichtung.","uiStudio.history.row.designCheck.tooltip":"Zusammenfassung der Design-Check-Vorschläge nach der Änderung.","uiStudio.gallery.priorityHighBadge.tooltip":"Anzahl der zuerst zu prüfenden Vorschläge. Für Details klicken.","uiStudio.gallery.priorityMediumBadge.tooltip":"Anzahl der empfohlenen Vorschläge.","uiStudio.gallery.priorityLowBadge.tooltip":"Anzahl der optionalen Verbesserungen.","settings.dataHistory.clear.tooltip":"Nur die für diesen Eintrag gespeicherten Daten löschen. Roblox-Studio-Daten werden nicht geändert.","settings.dataHistory.connectionLog.metric.tooltip":"Anzahl gespeicherter Verbindungsereignisse und belegter Speicherplatz.","settings.dataHistory.open.tooltip":"Die Seite öffnen, die diesen Eintrag im Detail zeigt.","settings.dataHistory.playtestReports.metric.tooltip":"Anzahl gespeicherter Playtest-Berichte und belegter Speicherplatz.","settings.dataHistory.projectChanges.metric.tooltip":"Anzahl gespeicherter Projektänderungs-Zusammenfassungen und belegter Speicherplatz.","settings.dataHistory.syncLog.metric.tooltip":"Anzahl gespeicherter Sync-Ereignisse und belegter Speicherplatz.","settings.dataHistory.toggle.tooltip":"Diesen Abschnitt ein- oder ausklappen.","settings.dataHistory.toolStats.metric.tooltip":"Aggregierte Gesamtaufrufe und Sitzungszahlen.","settings.dataHistory.toolsActivity.metric.tooltip":"Anzahl gespeicherter Tool-Ausführungen und belegter Speicherplatz.","settings.dataHistory.uiStudio.metric.tooltip":"UI-Studio-Änderungsdatensätze, Capture-Anzahlen und gesamte Speichernutzung.","settings.language.auto.tooltip":"Die Sprache des Betriebssystems verwenden. Fällt auf Englisch zurück, wenn sie nicht unterstützt wird.","settings.license.activate.tooltip":"Pro-Funktionen mit dem eingegebenen Lizenzschlüssel aktivieren.","settings.license.refresh.tooltip":"Den aktuellen Status erneut vom Lizenzserver abrufen. Nützlich, wenn eine Abrechnungsänderung noch nicht sichtbar ist.","settings.license.reset.tooltip":"Den aktuell registrierten Lizenzschlüssel entfernen. Vor dem Aktivieren mit einem anderen Schlüssel verwenden.","tier.upgrade.tooltip":"Pro-Funktionen und Kaufoptionen ansehen.","uiStudio.actions.captureCurrentState.tooltip":"Den aktuellen Zustand dieses UI-Ziels als neuen Screenshot erfassen.","uiStudio.actions.checkSuggestionsAgain.tooltip":"Die Design-Check-Vorschläge für dieses UI-Ziel erneut prüfen.","uiStudio.actions.deleteSnapshot.tooltip":"Nur diese gespeicherte Screenshot-Datei löschen. Roblox Studio wird nicht geändert.","uiStudio.actions.more.tooltip":"Weitere Aktionen für diesen Screenshot anzeigen.","uiStudio.analysis.counts.tooltip":"Zeigt, wie viele Vorschläge als zuerst prüfen, empfohlen oder optional markiert sind.","uiStudio.analysis.recentCapturesTitle.tooltip":"Die zuletzt gespeicherten Screenshots für UI-Studio-Analyse und Debugging.","uiStudio.analysis.reportsTitle.tooltip":"Der neueste Analysebericht je UI-Ziel.","uiStudio.analysis.thresholds.tooltip":"Der für diese Prüfung verwendete Schwellenwertsatz (Standard oder benutzerdefiniert).","uiStudio.analysis.verdict.hasSuggestions.tooltip":"In diesem UI wurden Verbesserungen gefunden. Karte anklicken, um Details zu sehen.","uiStudio.analysis.verdict.passed.tooltip":"Unter den aktuellen Prüfschwellen werden keine Verbesserungen vorgeschlagen.","uiStudio.analysis.verdictLabel.tooltip":"Gesamtbewertung der Verbesserungen für diesen Capture.","uiStudio.briefId.tooltip":"Kennung des Design-Briefs, der dieses UI erzeugt hat.","uiStudio.capturedAt.tooltip":"Zeitpunkt, zu dem dieser Screenshot gespeichert wurde.","uiStudio.cleanup.deleteAll.tooltip":"Alle Änderungsdatensätze und Captures für dieses Projekt löschen. Das tatsächliche UI in Roblox Studio bleibt unverändert.","uiStudio.cleanup.keep30.tooltip":"Änderungsdatensätze und Captures löschen, die älter als 30 Tage sind.","uiStudio.cleanup.keep7.tooltip":"Änderungsdatensätze und Captures löschen, die älter als 7 Tage sind.","uiStudio.cleanup.label.tooltip":"Änderungsdatensätze und Captures jederzeit manuell bereinigen.","uiStudio.cleanup.policy.ageInput.tooltip":"Einen beliebigen Wert zwischen 1 und 365 Tagen eingeben.","uiStudio.cleanup.policy.agePreset.tooltip":"Daten löschen, die älter als diese Anzahl von Tagen sind.","uiStudio.cleanup.policy.cascade.tooltip":"Auch die Capture-Bilder löschen, die mit diesen Datensätzen verknüpft sind. Wenn aus, bleiben die Bilder erhalten.","uiStudio.cleanup.policy.modeAge.tooltip":"Daten automatisch löschen, die älter als die konfigurierte Anzahl von Tagen sind.","uiStudio.cleanup.policy.modeOff.tooltip":"Automatische Bereinigung ausschalten. Daten bleiben erhalten, bis du sie manuell entfernst.","uiStudio.cleanup.policy.modeSize.tooltip":"Wenn die Gesamtnutzung das Limit überschreitet, werden die ältesten Daten zuerst entfernt.","uiStudio.cleanup.policy.runNow.tooltip":"Die aktuelle Regel sofort einmal ausführen, ohne auf den nächsten geplanten Lauf zu warten.","uiStudio.cleanup.policy.save.tooltip":"Die aktuelle Bereinigungsregel speichern. Danach läuft sie im Hintergrund.","uiStudio.cleanup.policy.sizeInput.tooltip":"Einen beliebigen Wert zwischen 50 MB und 10000 MB (10 GB) eingeben.","uiStudio.cleanup.policy.sizePreset.tooltip":"Die Gesamtnutzung unter dieser Größe halten.","uiStudio.cleanup.policy.title.tooltip":"Regeln, die alte oder große Captures automatisch entfernen.","uiStudio.colCurrent.tooltip":"Der aktuell angewendete Wert.","uiStudio.colRecommended.tooltip":"Der empfohlene Wert.","uiStudio.compare.after.tooltip":"Der Bildschirm, der direkt nach der KI-Änderung gespeichert wurde.","uiStudio.compare.before.tooltip":"Der Bildschirm, der direkt vor der KI-Änderung gespeichert wurde.","uiStudio.compare.path.tooltip":"Der UI-Instanzpfad für diesen Bildschirm.","uiStudio.copyFixCommand.tooltip":"Eine Eingabeaufforderung kopieren, die die KI bittet, dieses Problem zu beheben.","uiStudio.detailClose.tooltip":"Detailansicht schließen.","uiStudio.falsePositiveWarning.tooltip":"Diese Prüfung kann Fehlalarme erzeugen — vor dem Anwenden überprüfen.","uiStudio.gallery.cardCheckbox.tooltip":"Diesen Capture auswählen. Wähle mehrere aus, um sie zusammen zu löschen.","uiStudio.gallery.clearSelection.tooltip":"Die aktuelle Capture-Auswahl aufheben.","uiStudio.gallery.deleteSelected.tooltip":"Die ausgewählten Screenshot-Dateien löschen. Roblox Studio bleibt unverändert.","uiStudio.gallery.selectAll.tooltip":"Alle aktuell sichtbaren Captures auswählen.","uiStudio.groupSummary.tooltip":"Anzahl der UI-Elemente, die zu dieser Gruppe passen.","uiStudio.history.clear.tooltip":"Alle Änderungsdatensätze für dieses Projekt löschen. Das tatsächliche UI in Roblox Studio bleibt unverändert.","uiStudio.history.filter.actionAll.tooltip":"Alle Aktionsarten anzeigen.","uiStudio.history.filter.actionCreate.tooltip":"Nur Aktionen anzeigen, die ein neues UI erstellt haben.","uiStudio.history.filter.actionDelete.tooltip":"Nur Aktionen anzeigen, die ein UI gelöscht haben.","uiStudio.history.filter.actionUpdate.tooltip":"Nur Aktionen anzeigen, die ein bestehendes UI aktualisiert haben.","uiStudio.history.filter.actions.tooltip":"Datensätze nach der Art der KI-Änderung filtern.","uiStudio.history.filter.customRange.tooltip":"Ein benutzerdefiniertes Start- und Enddatum wählen.","uiStudio.history.filter.dateAll.tooltip":"Den gesamten Verlauf anzeigen.","uiStudio.history.filter.from.tooltip":"Startdatum für die Abfrage.","uiStudio.history.filter.last30Days.tooltip":"Änderungen der letzten 30 Tage anzeigen.","uiStudio.history.filter.last7Days.tooltip":"Änderungen der letzten 7 Tage anzeigen.","uiStudio.history.filter.period.tooltip":"Datensätze nach Zeitraum filtern.","uiStudio.history.filter.reset.tooltip":"Alle Filter auf Standardwerte zurücksetzen.","uiStudio.history.filter.to.tooltip":"Enddatum für die Abfrage.","uiStudio.history.filter.today.tooltip":"Nur heutige Änderungen anzeigen.","uiStudio.history.filter.yesterday.tooltip":"Nur gestrige Änderungen anzeigen.","uiStudio.history.row.affectedPaths.tooltip":"Anzahl der UIs, die von dieser Aktion betroffen sind.","uiStudio.history.row.compare.tooltip":"Vorher- und Nachher-Bildschirm vergleichen. Zum Öffnen der vollständigen Vergleichsansicht klicken.","uiStudio.history.row.extraPaths.tooltip":"Anzahl zusätzlicher UIs, die in dieser Aktion geändert wurden.","uiStudio.history.row.mutations.tooltip":"Anzahl detaillierter Änderungen (z. B. Eigenschaftsänderungen).","uiStudio.history.row.noAfterState.tooltip":"Nach dieser Änderung wurde kein Capture gespeichert.","uiStudio.history.row.noBeforeState.tooltip":"Vor dieser Änderung wurde kein Capture gespeichert.","uiStudio.history.row.toggleDetails.tooltip":"Eine zeilenweise Aufschlüsselung der Änderungen ein- oder ausblenden.","uiStudio.history.title.tooltip":"Eine Zeitleiste aller UI-Änderungen, die von KI vorgenommen wurden.","uiStudio.scope.tooltip":"Capture-Bereich (voller Bildschirm oder ein bestimmtes UI).","uiStudio.storage.historyBytes.tooltip":"Speicherplatz für Änderungsdatensätze (JSON).","uiStudio.storage.lastRun.tooltip":"Wann die automatische Bereinigungsregel zuletzt lief und was entfernt wurde.","uiStudio.storage.mutationCount.tooltip":"Anzahl detaillierter Änderungen innerhalb von Aktionen (eine Eigenschaftsänderung = 1).","uiStudio.storage.requestCount.tooltip":"Anzahl der Aktionen, bei denen die KI das UI geändert hat.","uiStudio.storage.snapshotBytes.tooltip":"Speicherplatz für erfasste PNG-Bilddateien.","uiStudio.storage.snapshotCount.tooltip":"Anzahl gespeicherter Capture-Bilddateien.","uiStudio.storage.title.tooltip":"Speichernutzung von UI-Studio-Änderungsdatensätzen und Screenshots.","uiStudio.storage.usageLabel.tooltip":"Speicherplatz, den UI Studio aktuell für dieses Projekt verwendet.","uiStudio.suggestionGroup.tooltip":"Vorschläge derselben Art, gruppiert angezeigt. Zum Ein- oder Ausklappen klicken.","uiStudio.tabs.analysis.tooltip":"Neueste UI-Captures und Design-Check-Vorschläge überprüfen.","uiStudio.tabs.history.tooltip":"Von KI vorgenommene UI-Änderungen mit Vorher-/Nachher-Captures prüfen.","uiStudio.target.tooltip":"Exakter Pfad der erfassten UI-Instanz.","uiStudio.title.tooltip":"UI-Studio-Captures und Designvorschläge für Roblox-UI.","tier.banner.progressLabel":"Pro / Gesamt","uiStudio.error":"Fehler","uiStudio.analysis.expandChildren":"Unterziele anzeigen","uiStudio.analysis.openDetail":"Detail öffnen","uiStudio.analysis.childTargets":"Unterziele","uiStudio.analysis.childDetailHint":"Details zum Unterziel öffnen","uiStudio.compare.before":"Vorher","uiStudio.compare.after":"Nachher","uiStudio.history.drawer.changeDetails":"Änderungsdetails","uiStudio.gallery.cardCheckbox":"Screenshot auswählen","sidebar.assets":"Assets","assets.title":"Assets","assets.experimental":"Experimental","assets.subtitle":"Browse local originals, upload to Roblox, and inspect synced usage by place.","assets.scope.label":"Asset scope","assets.scope.place":"Current Place","assets.scope.shared":"Shared","assets.count.shown":"Shown assets: {count}","assets.category.filter":"Category","assets.category.all":"All","assets.category.image":"Images","assets.category.decal":"Decals","assets.category.audio":"Audio","assets.category.mesh":"Meshes","assets.category.model":"Models","assets.category.rbxm":"RBXM","assets.category.video":"Videos","assets.category.animation":"Animations","assets.category.comingSoon":"Coming soon","assets.status.localOnly":"Local only","assets.status.uploading":"Uploading","assets.status.processing":"Processing","assets.status.uploaded":"Uploaded","assets.status.failed":"Failed","assets.status.superseded":"Superseded","assets.rescan":"Rescan","assets.rescan.tooltip":"Scan the selected inbox folder.","assets.rescan.chooseCategory":"Choose a category before rescanning.","assets.rbxmGuide.title":"Save RBXM from Studio","assets.rbxmGuide.body":"Select objects in Roblox Studio, then use WEPPY Plugin > Assets to save the selection as a local RBXM asset.","assets.rbxmGuide.thumbnail":"The plugin save flow includes a thumbnail option, and saved RBXM assets appear here for management, upload, and insertion.","assets.exportSelection":"Export Studio selection","assets.exportSelection.tooltip":"Export the current Studio selection as a local .rbxm asset.","assets.exportSelection.chooseCategory":"Choose RBXM before exporting a Studio selection.","assets.upload.open":"Upload","assets.upload.open.tooltip":"Upload this local file to Roblox through Open Cloud.","assets.upload.selectFirst":"Select an asset first.","assets.upload.title":"Upload asset","assets.upload.checkingSettings":"Checking upload settings...","assets.upload.settingsLoadFailed":"Failed to load upload settings.","assets.upload.settingsRequired":"Upload settings required","assets.upload.settingsRequired.apiKey":"Save an Open Cloud API key before uploading.","assets.upload.settingsRequired.toggle":"Enable Open Cloud upload before uploading.","assets.upload.settingsRequired.creator":"Save a default Creator before uploading.","assets.upload.openSettings":"Open Asset Library settings","assets.upload.creator":"Creator","assets.upload.creatorType":"Creator type","assets.upload.creatorId":"Creator ID","assets.upload.envCreatorHelp":"Environment API keys cannot save a default Creator here. Enter the Creator for this upload.","assets.upload.displayNameHelp":"Saved to Roblox as the asset display name.","assets.upload.descriptionHelp":"Saved to Roblox as the asset description.","assets.upload.creatorHelp":"Used by Open Cloud as the owner of the uploaded asset.","assets.upload.creatorTypeHelp":"Sent to Open Cloud as the Creator type.","assets.upload.creatorIdHelp":"Sent to Open Cloud as the User or Group ID that owns the uploaded asset.","assets.upload.submit":"Upload with Roblox Open Cloud","assets.upload.uploading":"Uploading...","assets.upload.noDelete":"WEPPY does not provide Roblox asset deletion.","assets.upload.delay":"Roblox processing and moderation can delay visibility in Studio or Creator Dashboard.","assets.delete.tooltip":"Delete this local Asset Library item.","assets.delete.title":"Delete asset","assets.delete.message":"This removes the local Asset Library files only. Uploaded Roblox assets are not deleted.","assets.creator.user":"User","assets.creator.group":"Group","assets.settings.open":"Open settings","assets.settings.open.tooltip":"Open Roblox upload settings.","assets.settings.title":"Asset Library settings","assets.settings.proOnly":"Roblox upload settings and Open Cloud credential controls are available on Pro.","assets.settings.openCloudToggle":"Open Cloud upload","assets.settings.openCloudToggle.help":"Controls whether server-side Open Cloud upload mutations can run.","assets.settings.apiKey":"Open Cloud API Key","assets.settings.apiKeyGuide":"Create a Roblox API key with Assets Read and Write permissions.","assets.settings.creatorHelp":"Use the numeric user ID from a profile URL or group ID from a group URL.","assets.settings.credential.none":"No API key saved","assets.settings.credential.env":"Environment variable","assets.settings.credential.local":"Local encrypted file","assets.settings.registeredApiKey":"Registered API Key","assets.settings.credentialProfile":"Credential Profile","assets.settings.activeProfileBadge":"Active","assets.settings.field.profile":"Profile","assets.settings.field.apiKey":"API Key","assets.settings.field.storage":"Storage","assets.settings.field.validationStatus":"Validation status","assets.settings.field.creators":"Creators","assets.settings.validation.unknown":"Not tested","assets.settings.validation.valid":"Connected","assets.settings.validation.invalid":"Needs attention","assets.settings.profileSelected":"Open Cloud credential profile selected.","assets.settings.useProfile":"Use profile","assets.settings.replaceApiKey":"Replace API Key","assets.settings.profileLabel":"Profile name (optional)","assets.settings.profileLabel.placeholder":"Studio automation key","assets.settings.profileLabel.help":"Optional. If left blank, WEPPY saves this profile as Open Cloud key automatically.","assets.settings.saveApiKey":"Save API Key","assets.settings.testConnection":"Test Connection","assets.settings.removeApiKey":"Unregister API Key","assets.settings.saveCreator":"Save default Creator","assets.settings.saveCreatorPreset":"Save Creator","assets.settings.addCreator":"Add Creator","assets.settings.addCreator.tooltip.ready":"Add another User or Group Creator preset to this profile.","assets.settings.cancelCreator":"Cancel","assets.settings.defaultCreatorBadge":"Default","assets.settings.makeDefaultCreator":"Make default","assets.settings.unregisterCreator":"Unregister Creator","assets.settings.creatorLabel":"Creator label (optional)","assets.settings.creatorLabel.placeholder":"Main studio group","assets.settings.creatorLabel.help":"Optional. If left blank, WEPPY automatically saves a label like User 123 or Group 456.","assets.settings.action.proRequired":"Asset upload settings are available on Pro.","assets.settings.action.busy":"Wait for the current settings action to finish.","assets.settings.saveApiKey.tooltip.ready":"Save this API key to local encrypted storage.","assets.settings.saveApiKey.tooltip.enter":"Enter an Open Cloud API key to save it locally.","assets.settings.testConnection.tooltip.entered":"Test the entered API key before saving it.","assets.settings.testConnection.tooltip.saved":"Test the saved Open Cloud API key.","assets.settings.testConnection.tooltip.enterOrSaved":"Enter an API key or save one before testing the connection.","assets.settings.removeApiKey.tooltip.ready":"Unregister the locally saved Open Cloud API key from WEPPY.","assets.settings.removeApiKey.tooltip.none":"No local Open Cloud API key is saved.","assets.settings.removeApiKey.tooltip.env":"Environment API keys cannot be removed from Dashboard. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY.","assets.settings.unregisterCreator.tooltip.ready":"Unregister this Creator from the selected profile.","assets.settings.unregisterApiKey.title":"Unregister API Key?","assets.settings.unregisterApiKey.message":"Roblox API key is not revoked. WEPPY only removes the local Credential Profile registration on this device.","assets.settings.unregisterCreator.title":"Unregister Creator?","assets.settings.unregisterCreator.message":"Roblox user or group is not deleted. WEPPY only removes this Creator from the selected API Key profile.","assets.settings.saveCreator.tooltip.ready":"Save this Creator as the default owner for uploads.","assets.settings.saveCreator.tooltip.noLocal":"Save a local Open Cloud API key before saving a default Creator.","assets.settings.saveCreator.tooltip.env":"Environment API keys cannot save a default Creator here. Enter Creator details in the upload dialog.","assets.settings.saveCreator.tooltip.enterId":"Enter a user or group ID before saving the default Creator.","assets.settings.apiKeySaved":"Open Cloud API key saved locally.","assets.settings.apiKeyTested":"Open Cloud API key connection tested.","assets.settings.apiKeyRemoved":"Open Cloud API key unregistered from local storage.","assets.settings.envApiKeyStillActive":"Environment variable credential is still active. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY Dashboard.","assets.settings.defaultCreatorSaved":"Open Cloud default Creator saved locally.","assets.settings.creatorUnregistered":"Creator unregistered from this profile.","assets.settings.creatorUnregisterFailed":"Failed to unregister Creator.","assets.settings.saved":"Upload settings saved.","assets.settings.saveFailed":"Failed to save upload settings.","assets.settings.loadFailed":"Failed to load upload settings.","assets.settings.tested":"Connection tested.","assets.settings.testFailed":"Connection test failed.","assets.settings.removed":"API key unregistered.","assets.settings.removeFailed":"Failed to unregister API key.","assets.basic.notice":"Browse, preview, edit metadata, and scan usage on Basic. Roblox upload controls are available on Pro.","assets.proOnly.tooltip":"Roblox upload is available on Pro.","assets.proOnly.upload":"Roblox upload is available on Pro.","assets.empty.title":"No assets yet","assets.empty.body":"Choose a scope and category, then rescan that inbox folder.","assets.detail.title":"Asset details","assets.detail.displayName":"Display name","assets.detail.description":"Description","assets.detail.save":"Save metadata","assets.detail.refreshStatus":"Refresh","assets.detail.scanUsage":"Scan usage","assets.detail.localFile":"Local file","assets.detail.fileName":"File","assets.detail.category":"Category","assets.detail.scope":"Scope","assets.detail.mimeType":"Type","assets.detail.size":"Size","assets.detail.dimensions":"Dimensions","assets.detail.duration":"Duration","assets.detail.source":"Source path","assets.detail.sha256":"SHA-256","assets.detail.roblox":"Roblox upload status","assets.detail.status":"Status","assets.detail.assetId":"Asset ID","assets.detail.error":"Error","assets.detail.copyAssetId":"Copy Asset ID","assets.detail.copyUri":"Copy URI","assets.detail.studioUri":"Studio URI","assets.detail.robloxWebUrl":"Creator Dashboard URL","assets.detail.copyStudioUri":"Copy Studio URI","assets.detail.copyWebUrl":"Copy configure URL","assets.detail.openRobloxPage":"Open configure page","assets.detail.robloxWebUrlNotice":"Opening this page requires the Roblox account that owns or can manage the uploaded asset.","assets.detail.uploadHistory":"Upload history","assets.detail.usedInPlace":"Where this asset is used in this Place","assets.detail.noUsage":"No local Sync references found yet.","assets.detail.usageSource":"Checked against","assets.detail.usageSource.localSync":"Local Sync files","assets.detail.usageSource.notScanned":"Not checked yet","assets.detail.lastScanned":"Last checked","assets.detail.lastScannedAt":"Last checked: {time}","assets.detail.lastScanned.never":"No check yet","assets.detail.noUsageUnscanned":"Run Scan usage to search local Sync files for this Roblox Asset ID.","assets.detail.noUsageAfterScan":"No references were found in local Sync files during the last check.","assets.detail.noUsageNoRobloxId":"This asset does not have a Roblox Asset ID yet, so usage cannot be checked. Upload it before scanning usage.","assets.detail.technicalDetails":"Technical details","assets.detail.stableId":"Stable ID","assets.detail.sourceKind":"Source kind","assets.detail.createdAt":"Created","assets.detail.updatedAt":"Updated","assets.detail.operationId":"Operation ID","assets.detail.operationPath":"Operation path","assets.detail.versionId":"Version ID","assets.detail.remotePath":"Remote path","assets.detail.moderationState":"Moderation","assets.detail.line":"line {line}","assets.studio.notConnected":"Connect Roblox Studio before using Studio asset actions.","assets.detail.importRbxm":"Insert into Studio","assets.detail.importRbxm.tooltip":"Insert this local RBXM asset into {target} in the connected Studio place.","assets.detail.generateThumbnail":"Generate thumbnail","assets.detail.generateThumbnail.tooltip":"Create or replace the Asset Library thumbnail from Studio.","assets.detail.rbxmOnly":"Studio import is available for .rbxm assets.","assets.detail.rbxmCategoryOnly":"Studio .rbxm actions support models and animations.","assets.detail.thumbnailRbxmOnly":"Thumbnail generation is available for .rbxm model assets.","assets.detail.thumbnailModelOnly":"Thumbnail generation is available for model .rbxm assets.","assets.detail.rbxm":"RBXM contents","assets.detail.rbxmExportedCount":"Exported roots","assets.detail.rbxmClasses":"Classes","assets.detail.rbxmThumbnail":"Thumbnail","assets.detail.studioInsertTarget":"Studio insert target","assets.detail.rbxmRoots":"Root tree","assets.detail.rbxmReferences":"Asset references","assets.detail.rbxmThumbnailAttempts":"Thumbnail attempts","dashboardHelp.button":"Help","dashboardHelp.pageButton.ariaLabel":"Open page help","dashboardHelp.fieldButton.ariaLabel":"Open field help","dashboardHelp.section.canDo":"What you can do here","dashboardHelp.section.needs":"What you need to use it","dashboardHelp.section.links":"Related links","dashboardHelp.overview.title":"Overview help","dashboardHelp.overview.canDo.1":"Check MCP server, WEPPY Plugin, AI Agent, Sync, and recent game changes in one place.","dashboardHelp.overview.needs.1":"Useful status requires the MCP server. Live Studio status also needs WEPPY Plugin connected to the active place.","dashboardHelp.connection.title":"Connection help","dashboardHelp.connection.canDo.1":"Inspect server process details, connected AI agents, Studio plugin clients, and connection log events.","dashboardHelp.connection.needs.1":"The MCP server must be reachable. Plugin rows appear after Studio sends heartbeats.","dashboardHelp.sync.title":"Sync help","dashboardHelp.sync.canDo.1":"Review Studio to local sync status, direction, apply mode, and sync logs.","dashboardHelp.sync.needs.1":"Sync needs an active place and connected WEPPY Plugin. Two-way and reverse workflows depend on Pro.","dashboardHelp.assets.title":"Assets help","dashboardHelp.assets.canDo.1":"Browse local Asset Library files, switch place/shared scope, filter categories, scan usage, insert RBXM into Studio, and upload local assets to Roblox.","dashboardHelp.assets.needs.1":"Upload needs Pro, the Open Cloud upload toggle, a valid API Key, and a Creator. Browse and preview work on Basic.","dashboardHelp.changelog.title":"Changelog help","dashboardHelp.changelog.canDo.1":"Review real game-change sessions extracted from AI actions and sync events.","dashboardHelp.changelog.needs.1":"Entries are scoped to the active place. Basic shows only the latest preview entries.","dashboardHelp.playtest.title":"Playtest help","dashboardHelp.playtest.canDo.1":"Review Playtest results and reports saved by the AI Agent.","dashboardHelp.playtest.needs.1":"Pro shows real stored reports. Basic shows sample preview data. Live active-place confidence needs WEPPY Plugin connected.","dashboardHelp.uiStudio.title":"UI Studio help","dashboardHelp.uiStudio.canDo.1":"Review AI-created UI analysis, improvement suggestions, captures, and before/after history.","dashboardHelp.uiStudio.needs.1":"Pro shows real UI Studio data. Basic shows a bundled sample. New capture/check actions need WEPPY Plugin connected.","dashboardHelp.tools.title":"Tools help","dashboardHelp.tools.canDo.1":"Inspect tool history, status classification, fallback/unsupported/warn/error details, and usage statistics.","dashboardHelp.tools.needs.1":"History and statistics depend on local recording settings and the active place bucket.","dashboardHelp.settings.title":"Settings help","dashboardHelp.settings.canDo.1":"Manage License, hot settings, saved data cleanup, server environment display, and language.","dashboardHelp.settings.needs.1":"License actions need MCP server connection. Server environment values are read-only here. Asset upload controls live in Assets settings.","dashboardHelp.openCloudApiKey.title":"Open Cloud API Key help","dashboardHelp.openCloudApiKey.canDo.1":"WEPPY uses this key only for Roblox Open Cloud requests.","dashboardHelp.openCloudApiKey.needs.1":"Create a Roblox API key in Creator Hub. Add Assets under Access Permissions, then enable both Read and Write operations.","dashboardHelp.openCloudApiKey.needs.2":"Set the key target to the same User or Group that you use as the upload Creator.","dashboardHelp.openCloudApiKey.needs.3":"The raw key is encrypted on this device. It is not sent to WEPPY servers, and it is not stored in any other external storage, browser storage, telemetry, logs, tool history, or Asset Library metadata.","dashboardHelp.openCloudApiKey.link.apiKeys":"Roblox API keys","dashboardHelp.openCloudApiKey.link.assetsGuide":"Assets API usage guide","dashboardHelp.openCloudApiKey.link.assetsReference":"Assets API reference","dashboardHelp.openCloudCreatorId.title":"Creator ID help","dashboardHelp.openCloudCreatorId.canDo.1":"The default Creator decides which User or Group owns newly uploaded Roblox assets.","dashboardHelp.openCloudCreatorId.needs.1":"For User, sign in to roblox.com, open your profile from your avatar or username, then copy only the number between /users/ and /profile in the browser URL.","dashboardHelp.openCloudCreatorId.needs.2":"For Group, open the Roblox group or community page, then copy only the number after /groups/ or /communities/ in the browser URL.","dashboardHelp.openCloudCreatorId.needs.3":"Paste only the numeric ID in Creator ID. Do not paste the full URL, rbxassetid://, User, or Group text.","dashboardHelp.openCloudCreatorId.link.creatorId":"Creator ID reference","dashboardHelp.openCloudCreatorId.link.userId":"User ID reference","dashboardHelp.openCloudCreatorId.link.groups":"Roblox groups","dashboardHelp.openCloudCreatorId.link.groupsApi":"Groups Cloud API","assets.settings.apiKey.inlineHelp":"WEPPY uses this key only for Roblox Open Cloud requests. The key is encrypted on this device and is not sent to WEPPY servers or stored in any other external storage.","assets.settings.creatorId.inlineHelp":"Default owner for new Roblox assets: your User ID or a Group ID.","common.close":"Schließen","dashboardHelp.section.currentState":"Check based on current status","dashboardHelp.overview.currentState.serverOnly":"Open Roblox Studio and start WEPPY Plugin so live place data can appear.","dashboardHelp.overview.currentState.default":"If the server disconnects, restart MCP or wait for the automatic reconnect.","dashboardHelp.connection.currentState.1":"If Plugin is missing, open Roblox Studio and run WEPPY Plugin. If AI Agent is missing, reconnect the MCP server from your AI tool.","dashboardHelp.sync.currentState.pluginMissing":"Connect WEPPY Plugin in Studio before using live sync details.","dashboardHelp.sync.currentState.basic":"Activate Pro to use bidirectional or reverse sync.","dashboardHelp.sync.currentState.default":"Use the sync log to diagnose stuck or failed sync activity.","dashboardHelp.assets.currentState.basic":"Activate Pro before uploading to Roblox.","dashboardHelp.assets.currentState.uploadDisabled":"Turn on Open Cloud upload in Assets settings.","dashboardHelp.assets.currentState.noCredential":"Save and test an Open Cloud API Key.","dashboardHelp.assets.currentState.noCreator":"Save a default Creator ID or enter Creator details during upload.","dashboardHelp.assets.currentState.default":"Open an asset detail dialog to start upload or usage scan.","dashboardHelp.changelog.currentState.1":"If the list is empty, ask the AI Agent to make a game change. Clear only deletes saved history records, not Studio objects.","dashboardHelp.playtest.currentState.basic":"Activate Pro to use real Playtest history.","dashboardHelp.playtest.currentState.default":"Ask the AI Agent to run a Playtest when no report is available.","dashboardHelp.uiStudio.currentState.basic":"Activate Pro to use live UI Studio previews.","dashboardHelp.uiStudio.currentState.default":"Ask the AI Agent to capture the UI or recheck improvement suggestions, then copy follow-up requests back to the AI chat.","dashboardHelp.tools.currentState.1":"If no records appear, check Settings > General and confirm history/statistics are enabled. Expand failed rows to inspect input, permission, or connection causes.","dashboardHelp.settings.currentState.1":"Activate a license for Pro features. Change environment values outside WEPPY Dashboard, then restart MCP. Review delete confirmations before clearing saved data.","dashboardHelp.openCloudApiKey.currentState.saved":"Use Test Connection to confirm the saved key still works.","dashboardHelp.openCloudApiKey.currentState.empty":"Create an API key in Roblox Creator Hub, paste it here, then save and test it.","dashboardHelp.openCloudCreatorId.currentState.saved":"Keep this value if new assets should continue using the same owner.","dashboardHelp.openCloudCreatorId.currentState.empty":"Choose User or Group, paste the numeric ID, then save the default Creator.","page.overview.title":"Overview","page.overview.description":"Check server, plugin, agent, sync, and recent game-change status in one place.","page.connection.title":"Connection","page.connection.description":"Inspect MCP server, AI agent, Studio plugin, and connection log status.","page.sync.title":"Sync","page.sync.description":"Monitor Studio to local sync status, direction, apply mode, and recent sync logs.","page.changelog.title":"Changelog","page.changelog.description":"Review game-change sessions captured from AI actions and sync events.","page.playtest.title":"Playtest","page.playtest.description":"Review automated playtest runs, saved reports, and result history.","page.uiStudio.title":"UI Studio","page.uiStudio.description":"Review UI captures, improvement suggestions, and before/after change history.","page.tools.title":"Tools","page.tools.description":"Inspect tool history, outcomes, fallback details, and usage statistics.","page.settings.title":"Settings","page.settings.description":"Manage license, live settings, saved data, server environment, and language.","dashboardHelp.whatsNew.title":"What's New help","dashboardHelp.whatsNew.canDo.1":"Review WEPPY Dashboard, MCP, and Plugin announcements, releases, and change notes.","dashboardHelp.whatsNew.needs.1":"Announcements are bundled locally. Unread state is stored in this browser.","dashboardHelp.whatsNew.currentState.1":"After you visit this page, unread announcements from this visit are marked read when you leave. The top header does not show a duplicate What's New button on this page."},$f={"sidebar.overview":"Aperçu","sidebar.changelog":"Journal des modifications","sidebar.connection":"Connexion","sidebar.sync":"Synchroniser","sidebar.playtest":"Test de jeu","sidebar.tools":"Outils","sidebar.settings":"Paramètres","sidebar.ui_studio":"UI Studio","sidebar.gate.l1":"Connexion au serveur MCP requise","sidebar.gate.l2":"Connexion au plugin Roblox Studio requise","header.currentProject":"Projet actuel","header.unknownProject":"Projet inconnu","header.projectRoot.label":"Racine du projet","header.currentProject.loading":"Chargement de la racine du projet...","header.currentProject.unavailable":"Racine Project indisponible","header.placeNotConnected":"Lieu non connecté","header.currentProject.tooltip":"Dossier de projet actuellement sélectionné","header.currentProject.loading.tooltip":"Les informations racine de Project sont toujours en cours de chargement","header.currentProject.unavailable.tooltip":"Les informations sur la racine du projet actuel ne sont pas disponibles","header.currentProjectSyncRoot.label":"Synchroniser la racine","header.currentProjectSyncRoot.loading":"Chargement de la racine de synchronisation...","header.currentProjectSyncRoot.unavailable":"Racine de synchronisation indisponible","header.currentProjectSyncRoot.tooltip":"Dossier racine de synchronisation actuel pour le projet sélectionné","header.currentProjectSyncRoot.loading.tooltip":"Les informations sur la racine de synchronisation sont toujours en cours de chargement","header.currentProjectSyncRoot.unavailable.tooltip":"Les informations actuelles sur la racine de synchronisation ne sont pas disponibles","header.testFiles.label":"Fichiers de test","header.testFiles.unavailable":"Fichiers de test indisponibles","header.testFiles.tooltip":"Répertoire actuel des fichiers de test de lecture pour l'endroit sélectionné","header.places.title":"Lieux","header.places.active":"Actif","header.places.inactive":"Inactif","header.places.pluginRequired":"Connexion plug-in requise","header.places.liveRequired":"Connexion plug-in requise pour le lieu actif en direct","header.place.tooltip":"Lieu Roblox connecté","header.placeNotConnected.tooltip":"Lieu non connecté","header.changeProjectRoot":"Changer la racine du projet Project","header.changeProjectRoot.ariaLabel":"Changer la racine du projet","header.changeProjectRoot.tooltip":"Changer la racine actuelle du projet","header.changeProjectRoot.disabledTooltip.l0":"Connexion au serveur MCP requise avant que la racine du projet puisse être modifiée","header.changeProjectRoot.disabledTooltip.loading":"Les informations racine de Project sont toujours en cours de chargement","header.changeProjectRoot.disabledTooltip.unavailable":"Les informations sur la racine du projet actuel ne sont pas disponibles","header.projectRootModal.initial.title":"Changer la racine du projet","header.projectRootModal.initial.body.connected":"Après avoir choisi un dossier de projet, MCP basculera vers la nouvelle racine du projet et le contenu actuel du Studio sera entièrement resynchronisé dans la nouvelle cible <dossier de projet sélectionné>/weppy-project-sync.","header.projectRootModal.initial.body.disconnected":"Après avoir choisi un dossier de projet, MCP basculera vers la nouvelle racine du projet et utilisera <dossier de projet sélectionné>/weppy-project-sync comme prochaine cible de synchronisation.","header.projectRootModal.initial.nextSyncRoot":"Nouvelle cible de synchronisation après sélection","header.projectRootModal.initial.nextSyncRoot.placeholder":"<dossier de projet sélectionné>/weppy-project-sync","header.projectRootModal.initial.warningStop":"La synchronisation actuelle s'arrête immédiatement.","header.projectRootModal.initial.warningFreshSync":"Le contenu actuel du Studio sera utilisé pour créer une nouvelle synchronisation complète dans la nouvelle cible.","header.projectRootModal.initial.warningNoMove":"Les anciens dossiers de synchronisation ne sont pas déplacés automatiquement.","header.projectRootModal.initial.warningDeferredSync":"Si Studio n'est pas connecté, la resynchronisation complète démarre à la prochaine connexion du plugin.","header.projectRootModal.confirm.title":"Confirmer la nouvelle racine du projet","header.projectRootModal.confirm.body":"Examinez le dossier de projet sélectionné avant de postuler.","header.projectRootModal.confirm.projectRoot":"Dossier de projet sélectionné","header.projectRootModal.confirm.syncRoot":"Nouvelle cible de synchronisation","header.projectRootModal.confirm.warningNoMove":"Les dossiers de synchronisation existants ne sont pas déplacés automatiquement.","header.projectRootModal.pick":"Choisir un dossier","header.projectRootModal.apply":"Appliquer le changement","header.projectRootModal.cancel":"Annuler","header.projectRootModal.error":"Échec de la modification de la racine du projet","status.online":"En ligne","status.offline":"Hors ligne","status.idle":"Inactif","status.syncing":"Synchronisation","status.error":"Erreur","status.initializing":"Initialisation","level.l0.title":"Serveur déconnecté","level.l0.message":"WEPPY Dashboard ouvert mais le serveur MCP s'est arrêté ou ne répond pas.","level.l1.title":"Serveur connecté","level.l1.hint":"Vérifiez : Roblox Studio est-il en cours d'exécution ? Le plugin est-il installé ?","level.l2.ok":"Studio connecté","tier.basic":"Basic","tier.basic.tooltip":"Niveau Basic avec l'ensemble de fonctionnalités standard WEPPY Dashboard.","tier.pro":"Pro","tier.pro.tooltip":"Niveau Pro avec l'ensemble complet de fonctionnalités WEPPY Dashboard.","tier.mixed":"Mixte","tier.upgrade":"Voir Pro","tier.banner.save":"Enregistrez les jetons IA avec Pro !","tier.tool.query_instances.desc":"Inspectez les instances, recherchez les enfants et les descendants et inspectez les données de classe. Pro ajoute une arborescence de fichiers, une structure de projet et une recherche de propriétés ou de balises.","tier.tool.mutate_instances.desc":"Créez, supprimez, clonez et déplacez des instances. Pro ajoute la création d'arborescence et les opérations de création, de suppression ou de clonage en masse.","tier.tool.manage_properties.desc":"Lisez et définissez les propriétés, les attributs et les balises. Pro ajoute des mises à jour calculées, des modifications relatives et des opérations de propriété en masse.","tier.tool.manage_scripts.desc":"Lisez, écrivez, créez, supprimez, modifiez et recherchez la source du script. Pro ajoute un remplacement groupé entre les scripts.","tier.tool.manage_ui.desc":"Pro uniquement. Créez ou affinez des menus de style jeu, des HUD, des boutons, des étiquettes et des panneaux d'images, puis capturez des écrans et examinez les suggestions d'amélioration.","tier.tool.manage_ui.action.design_brief":"Planifier l'orientation de l'interface utilisateur","tier.tool.manage_ui.action.create_tree":"Créer une nouvelle interface utilisateur","tier.tool.manage_ui.action.update":"Mettre à jour l'interface utilisateur existante","tier.tool.manage_ui.action.delete":"Supprimer l'interface utilisateur","tier.tool.manage_ui.action.preview":"Capturer l'écran de l'interface utilisateur","tier.tool.manage_ui.action.check":"Examiner les suggestions d'amélioration","tier.tool.manage_lighting.desc":"Pro uniquement. Configurez l'éclairage, l'atmosphère, le ciel, les propriétés du terrain et les paramètres d'heure.","tier.tool.manage_selection.desc":"Lisez, définissez et effacez la sélection actuelle de Studio. Pro ajoute le contexte, les détails, l'ajout ou la suppression et la prise en charge de la surveillance de la sélection.","tier.tool.manage_camera.desc":"Inspectez l’état de la caméra, faites la mise au point par chemin ou position et demandez des suggestions de vues.","tier.tool.manage_tween.desc":"Pro uniquement. Créez, lisez, mettez en pause et annulez des interpolations pour une animation fluide.","tier.tool.manage_audio.desc":"Pro uniquement. Jouez, arrêtez, mettez en pause et reprenez les sons, et configurez l'écouteur audio.","tier.tool.manage_animation.desc":"Pro uniquement. Chargez, lisez et arrêtez des animations, et inspectez les pistes d'animation actives.","tier.tool.manage_physics.desc":"Pro uniquement. Enregistrez les groupes de collision, configurez les collisions de groupe et inspectez les groupes disponibles.","tier.tool.manage_effects.desc":"Pro uniquement. Émettez des particules, supprimez les effets et basculez l'état de l'effet.","tier.tool.manage_terrain.desc":"Pro uniquement. Remplissez les formes du terrain, effacez les régions, remplacez les matériaux, gérez les couleurs du terrain, lisez ou écrivez des voxels, générez du terrain et lissez le terrain.","tier.tool.spatial_query.desc":"Pro uniquement. Exécutez des raycasts, trouvez le terrain, validez le placement, scannez des zones, recherchez des positions plates ou d'apparition, analysez la possibilité de marcher, cartographiez l'espace et inspectez les collisions.","tier.tool.manage_assets.desc":"Pro uniquement. Insérez des modèles, inspectez les informations sur les actifs, recherchez dans la boutique du créateur, insérez des actifs ou des packages gratuits et exportez des actifs.","tier.tool.manage_sync.desc":"Pro uniquement. Inspectez l’état de synchronisation, la configuration, l’historique, les instructions et lisez ou écrivez les fichiers synchronisés.","tier.tool.workspace_state.desc":"Pro uniquement. Exécutez une synchronisation complète, capturez des instantanés, inspectez les modifications récentes et l'état de la fenêtre d'affichage, et gérez les métadonnées associées.","tier.tool.manage_logs.desc":"Inspectez les journaux de sortie avec filtrage, interrogation incrémentielle, effacement de la mémoire tampon et recherche d'erreurs récentes.","tier.tool.system_info.desc":"Inspectez l’état de la connexion et le niveau actuel. Pro ajoute des informations sur le lieu, des services, des paramètres de Studio, un contrôle de test de jeu et des tests automatisés.","tier.tool.manage_studio.desc":"Pro uniquement. Basculez les paramètres d'affichage de l'éditeur Studio tels que l'aperçu de l'interface utilisateur pour les flux de capture d'écran et d'assurance qualité ; il modifie les paramètres de session Studio, pas les objets de l'interface utilisateur du jeu.","tier.tool.batch_execute.desc":"Pro uniquement. Exécutez plusieurs commandes par lots, avec une exécution séquentielle et un comportement facultatif de poursuite en cas d'erreur.","tier.tool.execute_luau.desc":"Pro uniquement. Exécutez du code Luau arbitraire dans le bac à sable Roblox Studio.","connection.server.title":"État du serveur","connection.server.version":"Version","connection.server.version.tooltip":"Version du serveur MCP installée","connection.server.pid":"PID","connection.server.pid.tooltip":"Identificateur de processus du système d'exploitation","connection.server.uptime":"Temps de disponibilité","connection.server.uptime.tooltip":"Temps écoulé depuis le démarrage du serveur MCP","connection.server.session":"Session","connection.server.session.tooltip":"Identifiant de session MCP actuel","connection.server.exec":"Exécutif","connection.server.exec.tooltip":"Chemin de l'exécutable utilisé pour lancer le serveur MCP","connection.reconnect":"Reconnecter","connection.checkSettings":"Vérifier les paramètres","connection.agents.title":"Agents IA","connection.agents.name":"Agent","connection.agents.cwd":"Directeur de travail","connection.agents.cwd.tooltip":"Répertoire de travail actuel pour l'agent AI connecté","connection.agents.projectRoot":"Racine du projet","connection.agents.projectRoot.tooltip":"Racine de projet faisant autorité pour la propriété de synchronisation","connection.agents.projectRoot.unresolved":"Non résolu","connection.agents.connected":"Connecté","connection.agents.unknown":"Inconnu","connection.agents.none":"Aucun agent connecté","connection.plugins.title":"Plugins","connection.plugins.place":"Lieu","connection.plugins.clientId":"Identifiant client","connection.plugins.clientId.tooltip":"Identifiant unique du client du plugin pour cette connexion Studio","connection.plugins.lastSeen":"Vu pour la dernière fois","connection.plugins.lastSeen.tooltip":"Battement de cœur le plus récent reçu du plugin","connection.plugins.version":"Ver","connection.plugins.version.tooltip":"Version du plugin installé signalée par Studio","connection.plugins.none":"Aucun plugin connecté","connection.log.title":"Journal de connexion","connection.log.empty":"Aucun événement pour l'instant","connection.time.secondsAgo":"il y a","connection.time.minutesAgo":"il y a m","connection.time.hoursAgo":"il y a h","common.loading":"Chargement...","common.retry":"Réessayer","common.reconnecting":"Reconnexion...","common.expand":"Développer","common.collapse":"Effondrement","tools.tab.history":"Histoire","tools.tab.statistics":"Statistiques","tools.tab.failures":"Échecs","tools.col.time":"Temps","tools.col.time.tooltip":"Date à laquelle l'exécution de l'outil a été enregistrée.","tools.col.toolAction":"Outil.Action","tools.col.toolAction.tooltip":"Nom de l’outil et action exécutée.","tools.col.duration":"Durée","tools.col.duration.tooltip":"Combien de temps l'outil a mis pour terminer.","tools.col.status":"Statut","tools.col.status.tooltip":"Résultat de l'exécution de l'outil enregistrée.","tools.col.tier":"Étage","tools.col.tier.tooltip":"Niveau de licence requis pour l’outil ou l’action.","tools.col.tierStats.tooltip":"Basic, Pro ou résumé mixte pour la ligne de statistiques de l'outil.","tools.col.tool":"Outil","tools.col.tool.tooltip":"Nom de l'outil consolidé dans le tableau des statistiques.","tools.col.calls":"Appels","tools.col.calls.tooltip":"Nombre total d'appels enregistrés pour cet outil.","tools.col.ok":"OK","tools.col.ok.tooltip":"Nombre d'exécutions directes réussies.","tools.col.fallback":"FALLBACK","tools.col.fallback.tooltip":"Nombre d'exécutions réussies grâce à une exécution de secours.","tools.col.unsupported":"UNSUPPORTED","tools.col.unsupported.tooltip":"Nombre d'exécutions bloquées sans exécution de secours.","tools.col.warn":"WARN","tools.col.warn.tooltip":"Nombre d'échecs attendus provoqués par l'entrée de l'appelant, l'état du projet, la stratégie Roblox ou le code utilisateur.","tools.col.err":"FAILED","tools.col.err.tooltip":"Nombre d'exécutions ayant échoué.","tools.col.okRate":"D'ACCORD%","tools.col.okRate.tooltip":"Pourcentage d'appels terminés avec succès.","tools.col.avgTime":"Temps moyen","tools.col.avgTime.tooltip":"Temps d'exécution moyen sur les appels enregistrés.","tools.col.error":"Erreur","tools.filter.tool":"Outil","tools.filter.all":"Tous","tools.badge.pro":"PRO","tools.badge.pro.tooltip":"Cette entrée utilisait un outil ou une action uniquement Pro.","tools.badge.fallback":"FALLBACK","tools.badge.fallback.tooltip":"L'action Pro demandée a réussi via un repli Basic.","tools.badge.unsupported":"UNSUPPORTED","tools.badge.unsupported.tooltip":"L'action Pro demandée a été bloquée et aucune solution de secours n'a été exécutée.","tools.badge.warn":"WARN","tools.badge.warn.tooltip":"L’appel de l’outil a échoué en raison d’un problème attendu d’appelant, de projet, de stratégie ou de code utilisateur.","tools.badge.err":"FAILED","tools.badge.err.tooltip":"L’exécution de l’outil a échoué.","tools.status.ok":"OK","tools.status.ok.tooltip":"L’exécution de l’outil s’est terminée avec succès.","tools.tier.mixed.tooltip":"Cet outil comprend à la fois les actions Basic et Pro.","tools.detail.params":"Paramètres","tools.detail.params.tooltip":"Paramètres d’entrée transmis à cette exécution d’outil.","tools.detail.result":"Résultat","tools.detail.result.tooltip":"Charge utile du résultat renvoyé pour cette exécution de cet outil.","tools.detail.requestedCommand":"Commande envoyée","tools.detail.executedCommand":"Commande exécutée","tools.detail.alternatives":"Alternatives","tools.detail.blockedMessage":"Raison du blocage","tools.detail.noFallback":"Pas de solution de repli","tools.detail.noFallback.value":"Aucune solution de secours n'a été exécutée.","tools.detail.warningMessage":"Message d'avertissement","tools.detail.errorMessage":"Message d'erreur","tools.clear.history.title":"Effacer l'historique ?","tools.clear.history.message":"Cela supprime définitivement l’historique actuel des outils de lieu.","tools.clear.statistics.title":"Des statistiques claires ?","tools.clear.statistics.message":"Cela réinitialise définitivement les statistiques actuelles de l'outil de placement.","tools.detail.error":"Erreur","tools.page.prev":"Précédent","tools.page.prev.tooltip":"Accédez à la page précédente des résultats de l’historique des outils.","tools.page.next":"Suivant","tools.page.next.tooltip":"Accédez à la page suivante des résultats de l’historique des outils.","tools.empty.history":"Aucune entrée dans l'historique","tools.empty.stats":"Aucune statistique sur les outils","tools.empty.failures":"Aucun échec","tools.summary.total":"Total","tools.summary.calls":"appels","tools.summary.sessions":"Séances","settings.license.title":"Licence","settings.license.title.tooltip":"Statut actuel de la licence et niveau d'abonnement.","settings.license.status":"Statut","settings.license.status.tooltip":"État d'activation actuel de la licence.","settings.license.tier":"Étage","settings.license.tier.tooltip":"Niveau d'abonnement actuel pour les fonctionnalités WEPPY Dashboard disponibles.","settings.license.key":"Clé","settings.license.key.tooltip":"Clé de licence masquée actuellement chargée par le serveur.","settings.license.keyValue.tooltip":"Clé de licence masquée actuellement chargée par le serveur.","settings.license.provider":"Provider","settings.license.provider.auto":"auto","settings.license.provider.polar":"polar","settings.license.provider.gumroad":"gumroad","settings.license.provider.tooltip":"Fournisseur de licence utilisé pour valider cette clé.","settings.license.providerValue.tooltip":"Fournisseur de licence utilisé pour valider cette clé.","settings.license.active":"Actif","settings.license.active.tooltip":"État d'activation actuel de la licence.","settings.license.status.activeCancelPending.tooltip":"L'annulation est en attente, mais l'accès Pro reste actif jusqu'à la fin de la période de facturation en cours.","settings.license.inactive":"Inactif","settings.license.inactive.tooltip":"État d'activation actuel de la licence.","settings.license.expired":"Expiré","settings.license.expired.tooltip":"État d'activation actuel de la licence.","settings.license.unavailable":"Informations de licence indisponibles","settings.license.detail.cancelPending":"L'annulation est programmée. L'accès Pro reste actif jusqu'à la fin de la période de facturation en cours.","settings.license.reset":"Réinitialiser la licence","settings.readOnly":"Lecture seule","settings.readOnly.tooltip":"Cette section affiche les valeurs qui ne peuvent pas être modifiées à partir du WEPPY Dashboard.","settings.unavailable":"Paramètres indisponibles","settings.general.title":"Paramètres généraux","settings.general.title.tooltip":"Paramètres chauds qui s’appliquent immédiatement lorsqu’ils sont modifiés.","settings.general.liveApply":"Postuler en direct","settings.general.liveApply.tooltip":"Les modifications apportées à cette section sont appliquées immédiatement sans bouton de sauvegarde séparé.","settings.general.applied":"Appliqué","settings.general.logLevel":"Niveau de journalisation","settings.general.logLevel.tooltip":"Choisissez la quantité de détails que le serveur MCP écrit dans les journaux. Réduisez à « debug » lors de la recherche d’un problème.","settings.general.localHistory":"Enregistrement de l'historique des outils","settings.general.localHistory.tooltip":"Enregistrez les exécutions de l’outil AI sur le disque. Obligatoire pour les pages Outils et Historique.","settings.general.localStatistics":"Collecte de statistiques sur les outils","settings.general.localStatistics.tooltip":"Comptes agrégés d’utilisation des outils. Utilisé par les statistiques de présentation.","settings.general.contextCapture":"Capture de contexte","settings.general.contextCapture.tooltip":"Enregistrez le contexte d'exécution structuré afin que les vues Changelog et Playtest puissent le restituer.","settings.general.requestTimeout":"Expiration du délai d'action","settings.general.requestTimeout.tooltip":"Temps maximum (en ms) d'attente pour une seule action de l'outil avant d'échouer.","settings.general.requestTimeout.unit":"MS","settings.general.requestTimeout.unit.tooltip":"Le délai d’expiration de l’action est mesuré en millisecondes.","settings.cold.title":"Environnement serveur","settings.cold.title.tooltip":"Valeurs d'environnement de serveur en lecture seule chargées au démarrage.","settings.cold.httpPort.tooltip":"Numéro de port utilisé par le serveur HTTP MCP WEPPY Dashboard.","settings.cold.httpHost.tooltip":"Interface hôte à laquelle le serveur HTTP MCP WEPPY Dashboard se lie.","settings.cold.dashboardAutoOpen.tooltip":"Contrôle si le WEPPY Dashboard s'ouvre automatiquement dans le navigateur au démarrage du serveur.","settings.cold.dashboardAutoOpen.value.tooltip":"Comportement de démarrage actuel pour l'ouverture du WEPPY Dashboard dans un navigateur.","settings.cold.hint":"Définissez via des variables d’environnement pour modifier ces valeurs.","settings.language.title":"Langue","settings.language.title.tooltip":"Choisissez comment le texte de l'interface WEPPY Dashboard est localisé.","settings.language.dashboard":"WEPPY Dashboard Langue","settings.language.dashboard.tooltip":"Remplace la langue WEPPY Dashboard ou suit la langue du système lorsqu'elle est définie sur Auto.","settings.language.auto":"Auto","overview.l0.title":"Serveur MCP déconnecté","overview.l0.message":"Le serveur MCP ne répond pas. Le WEPPY Dashboard tentera automatiquement de se reconnecter.","overview.l0.step1":"Vérifiez que le processus serveur MCP est en cours d'exécution","overview.l0.step2":"Redémarrez la commande du serveur MCP si nécessaire","overview.l0.reconnecting":"Reconnexion automatique toutes les 3 secondes...","overview.l0.reconnectBtn":"Reconnecter","overview.l0.settingsBtn":"Vérifier les paramètres","overview.l1.pluginGuide":"Le plugin Roblox Studio n'est pas connecté","overview.l1.check1":"Roblox Studio est-il en cours d'exécution ?","overview.l1.check2":"Le WEPPY Plugin est-il installé ?","overview.l1.feedHint":"Les modifications apparaîtront ici une fois le plugin connecté","overview.metric.server":"Serveur","overview.metric.server.tooltip":"État d'exécution du serveur MCP et état du processus","overview.metric.plugin":"Plugin","overview.metric.plugin.tooltip":"Connexion du plugin Roblox Studio et état de la version","overview.metric.agent":"Agent","overview.metric.agent.tooltip":"Agents de codage IA connectés et leur état d'exécution","overview.metric.agent.instancesUnit":"cas","overview.metric.sync":"Synchroniser","overview.metric.sync.tooltip":"Activité actuelle de synchronisation entre Studio et local","overview.metric.noAgent":"Aucun agent","overview.meta.version":"Version","overview.meta.version.tooltip":"Version du serveur MCP installée","overview.meta.session":"Session","overview.meta.session.tooltip":"Identifiant de session MCP actuel","overview.meta.pid":"PID","overview.meta.pid.tooltip":"Identificateur de processus du système d'exploitation","overview.meta.uptime":"Temps de disponibilité","overview.meta.uptime.tooltip":"Temps écoulé depuis le démarrage du serveur MCP","overview.feed.title":"Modifications récentes du jeu","overview.feed.empty":"Aucun changement récent","overview.changelog.title":"Résumé des modifications de session","overview.changelog.entries":"Total","overview.changelog.scripts":"scripts","overview.changelog.instances":"cas","overview.changelog.properties":"propriétés","overview.changelog.assets":"actifs","overview.tier.title":"Utilisation du niveau","changelog.subtitle":"Historique des changements de jeu","changelog.filter.all":"Tous","changelog.filter.active":"Actif","changelog.filter.completed":"Complété","changelog.empty":"Aucune entrée du journal des modifications pour l'instant","changelog.basic.limit.title":"L'aperçu Basic affiche les 3 dernières sessions","changelog.basic.limit.body":"Passez à Pro pour parcourir la chronologie complète du journal des modifications pour ce lieu.","changelog.basic.metricLabel":"Journal des modifications visible / Total","changelog.basic.visible":"visible","changelog.basic.total":"total","changelog.card.active":"Actif","changelog.card.active.tooltip":"Cette session reçoit toujours de nouveaux changements de jeu.","changelog.card.completed":"Complété","changelog.card.completed.tooltip":"Cette session est terminée et aucun autre changement n'est attendu.","changelog.card.bootstrapStatus":"Amorçage","changelog.card.bootstrapStatus.tooltip":"Cette session contient uniquement l'instantané d'amorçage de synchronisation initial.","changelog.card.inProgress":"en cours","changelog.card.noChanges":"Aucun changement pour l'instant","changelog.card.noChanges.tooltip":"Aucun changement de jeu n'a encore été extrait pour cette session.","changelog.card.bootstrapSummary":"Instantané de synchronisation initial","changelog.card.bootstrapSummary.tooltip":"Les écritures initiales de synchronisation de fichiers sont regroupées en une seule ligne d'instantané d'amorçage.","changelog.card.sessionIntent":"Intention de session","changelog.card.scripts":"scripts","changelog.card.scripts.tooltip":"Modifications du script apportées au cours de cette session.","changelog.card.instances":"cas","changelog.card.instances.tooltip":"Instance créer, supprimer, déplacer ou cloner les modifications dans cette session.","changelog.card.modified":"modifié","changelog.card.created":"créé","changelog.card.deleted":"supprimé","changelog.card.moved":"déplacé","changelog.card.propertiesChanged":"propriétés modifiées","changelog.card.propertiesChanged.tooltip":"Modifications de la valeur Property enregistrées pour cette session.","changelog.card.lightingConfigured":"Éclairage configuré","changelog.card.lightingConfigured.tooltip":"Les paramètres d'éclairage ou d'ambiance ont été modifiés au cours de cette session.","changelog.card.terrainConfigured":"Terrain configuré","changelog.card.terrainConfigured.tooltip":"Les données de terrain ou les paramètres de terrain ont été modifiés au cours de cette session.","changelog.card.assetsInserted":"éléments insérés","changelog.card.assetsInserted.tooltip":"Actifs insérés dans le lieu lors de cette séance.","changelog.category.script":"Scripts","changelog.category.instance":"Instances","changelog.category.property":"Properties","changelog.category.lighting":"Éclairage","changelog.category.terrain":"Terrain","changelog.category.asset":"Actifs","changelog.detail.changeSummary":"Résumé des modifications","changelog.detail.changeSummary.tooltip":"Nombre de modifications de jeu extraites regroupées par catégorie pour cette session.","changelog.detail.changeTimeline":"Modifier la chronologie","changelog.detail.changeTimeline.tooltip":"Liste chronologique des modifications de jeu extraites pour cette session.","changelog.detail.context.title":"Résumé du contexte","changelog.detail.context.tooltip":"Contexte d'exécution structuré capturé pour cette session de journal des modifications.","changelog.detail.verification.title":"Vérification","changelog.detail.verification.tooltip":"Signaux de vérification liés à cette session de changelog.","changelog.detail.verification.label":"Résultat","changelog.detail.verification.status":"Statut","changelog.detail.verification.timestamp":"Enregistré à","changelog.detail.beforeAfter":"Avant et après","changelog.detail.filterCategory":"Catégorie","changelog.detail.filterCategory.tooltip":"Filtrez la chronologie sur une seule catégorie de changement.","changelog.detail.confidence.exact":"Exact","changelog.detail.confidence.exact.tooltip":"Les états avant et après ont été confirmés pour ce changement.","changelog.detail.confidence.partial":"Partiel","changelog.detail.confidence.partial.tooltip":"Seule une partie de l’état avant et après a pu être confirmée pour ce changement.","changelog.detail.confidence.afterOnly":"Après seulement","changelog.detail.confidence.afterOnly.tooltip":"Seul l'état résultant après le changement a pu être confirmé.","changelog.detail.confidence.intentOnly":"Intention uniquement","changelog.detail.confidence.intentOnly.tooltip":"Seule l'action demandée a été enregistrée, pas l'état résultant.","changelog.detail.confidence.unknown":"Inconnu","changelog.detail.confidence.unknown.tooltip":"Ce changement n’a pas pu être classé avec certitude à partir des données disponibles.","changelog.detail.noChanges":"Aucun changement dans cette catégorie","changelog.detail.backToList":"Retour à la liste","changelog.diff.empty":"Aucune différence disponible","changelog.diff.unified":"Unifié","changelog.diff.sideBySide":"Côte à côte","changelog.diff.before":"Avant","changelog.diff.after":"Après","sync.overlay.title":"Plugin Roblox Studio requis","sync.overlay.message":"L'état de synchronisation sera disponible une fois le plugin Roblox Studio connecté.","sync.overlay.check1":"Roblox Studio est-il en cours d'exécution ?","sync.overlay.check2":"Le WEPPY Plugin est-il installé ?","sync.status.title":"Statut de synchronisation","sync.status.title.tooltip":"État actuel de synchronisation du Studio et des fichiers locaux pour cet emplacement.","sync.status.forwardOnly":"Transférer uniquement","sync.status.forwardOnly.tooltip":"Le niveau Basic permet à Studio d'effectuer une synchronisation directe locale uniquement.","sync.status.place":"Lieu","sync.status.place.tooltip":"Nom et identifiant du lieu Roblox connecté.","sync.status.path":"Chemin","sync.status.path.tooltip":"Racine du système de fichiers local actuellement utilisée pour la sortie de synchronisation.","sync.status.instances":"Instances","sync.status.instances.tooltip":"Nombre total d'instances Roblox synchronisées suivies dans le miroir local.","sync.status.scripts":"Scripts","sync.status.scripts.tooltip":"Nombre total de fichiers de script synchronisés actuellement indexés pour cet emplacement.","sync.status.state":"État","sync.status.state.tooltip":"État de synchronisation d'exécution actuel signalé par le serveur.","sync.directions.title":"Instructions de synchronisation","sync.directions.title.tooltip":"Direction de synchronisation par catégorie et application du comportement entre Local et Studio.","sync.directions.type":"Taper","sync.directions.type.tooltip":"Catégorie de synchronisation affectée par cette règle.","sync.directions.direction":"Direction","sync.directions.direction.tooltip":"Indique si chaque catégorie est synchronisée de Studio vers Studio ou dans les deux sens.","sync.directions.applyMode":"Mode Appliquer","sync.directions.applyMode.tooltip":"Comment les modifications de synchronisation entrantes sont appliquées pour cette catégorie.","sync.directions.cat.scripts":"Scripts","sync.directions.cat.values":"Valeurs","sync.directions.cat.containers":"Conteneurs","sync.directions.cat.data":"Données","sync.directions.cat.services":"Services","sync.directions.endpoint.local":"Locale","sync.directions.endpoint.local.tooltip":"Les fichiers locaux sur le disque sont toujours affichés sur le côté gauche du rail de direction.","sync.directions.endpoint.studio":"Studio","sync.directions.endpoint.studio.tooltip":"Roblox Studio est toujours affiché sur le côté droit du rail de direction.","sync.directions.mode.manual":"Manuel","sync.directions.mode.manual.tooltip":"Applique les modifications de synchronisation uniquement lorsque vous les déclenchez manuellement.","sync.directions.mode.auto":"Auto","sync.directions.mode.auto.tooltip":"Applique automatiquement les modifications de synchronisation lorsque les mises à jour arrivent.","sync.directions.tooltip.forward.body":"Les modifications de Studio sont synchronisées uniquement avec les fichiers locaux","sync.directions.tooltip.bidirectional.body":"Synchronisation bidirectionnelle entre Local et Studio","sync.directions.tooltip.reverse.body":"Transférer les modifications des fichiers locaux vers Studio","sync.directions.tooltip.proRequired":"Pro requis au niveau Basic","sync.directions.dir.forward":"avant","sync.directions.dir.bidirectional":"bidirectionnel","sync.directions.dir.reverse":"inverse","sync.log.title":"Journal de synchronisation","sync.log.empty":"Aucun événement de synchronisation pour l'instant","sync.log.type.write":"WRITE","sync.log.type.write.tooltip":"Une nouvelle sortie de synchronisation a été écrite sur le disque.","sync.log.type.update":"UPDATE","sync.log.type.update.tooltip":"Un fichier ou une instance synchronisée existante a été mise à jour.","sync.log.type.delete":"DELETE","sync.log.type.delete.tooltip":"Un fichier ou une instance synchronisé a été supprimé.","sync.log.type.idle":"IDLE","sync.log.type.idle.tooltip":"Un événement de synchronisation a été enregistré sans mutation de fichier.","sync.upgrade.title":"Découvrir la synchronisation complète avec Pro","sync.upgrade.benefit1":"Synchronisation bidirectionnelle : modifiez des fichiers, appliquez-les automatiquement à Studio","sync.upgrade.benefit2":"Synchronisation inversée : renvoyer les modifications de fichiers vers Studio","sync.upgrade.benefit3":"Historique de synchronisation complet et journal des modifications détaillé","sync.upgrade.buy":"Voir Pro","playtest.status.title":"Statut du test de jeu","playtest.status.title.tooltip":"État actuel de la session de test de jeu Roblox signalé par Studio.","playtest.status.mode":"Mode","playtest.status.mode.tooltip":"Mode de lancement du playtest Studio pour la session en cours.","playtest.status.mode.value.tooltip":"Mode de test de jeu Roblox Studio spécifique actuellement utilisé.","playtest.status.mode.play":"Jouer","playtest.status.mode.run":"Courir","playtest.status.mode.server":"Serveur","playtest.status.mode.edit":"Modifier","playtest.status.place.tooltip":"Lieu Roblox actuellement associé à cette session de playtest.","playtest.status.state.running":"En cours d'exécution","playtest.status.state.running.tooltip":"Une session de test de jeu Roblox est actuellement en cours.","playtest.status.state.paused":"En pause","playtest.status.state.paused.tooltip":"La session de test de jeu Roblox en cours est suspendue.","playtest.status.state.notRunning":"Ne fonctionne pas","playtest.status.state.notRunning.tooltip":"Aucune session de test de jeu Roblox n'est actuellement en cours.","playtest.control.play":"Jouer","playtest.control.pause":"Pause","playtest.control.resume":"CV","playtest.control.stop":"Arrêt","playtest.history.title":"Historique des tests","playtest.history.title.tooltip":"Exécutions de tests de jeu automatisés enregistrés pour ce projet.","playtest.history.empty":"Aucun résultat de test pour l'instant","playtest.history.mode":"Mode","playtest.history.mode.tooltip":"Mode Playtest utilisé pour ce test enregistré.","playtest.history.status.passed":"Passé","playtest.history.status.failed":"Échoué","playtest.history.status.running":"En cours d'exécution","playtest.history.status.unknown":"Inconnu","playtest.history.status.tooltip":"État des résultats enregistrés pour cette exécution de test de jeu automatisé.","playtest.empty.title":"Aucun résultat de test de jeu pour l'instant","playtest.empty.message":"Les résultats apparaîtront ici après l’exécution d’un Playtest par l’agent IA.","playtest.empty.message.before":"Les résultats apparaîtront ici après l’exécution d’un Playtest par l’agent IA.","playtest.empty.message.after":"","playtest.empty.runTest.tooltip":"Ask the AI Agent to run a Playtest when you need a fresh report.","playtest.report.title":"Rapport sélectionné","playtest.report.title.tooltip":"Sortie détaillée pour l’exécution de test de jeu automatisé actuellement sélectionnée.","playtest.report.content":"Rapport","playtest.report.content.tooltip":"Résumé de la démarque pour l'exécution du test de jeu automatisé sélectionné.","playtest.report.logs":"Journaux","playtest.report.logs.tooltip":"Journaux d'exécution capturés pour l'exécution du test de lecture automatisé sélectionné.","playtest.context.contextId":"ID de contexte","playtest.context.why":"Pourquoi ce test a été exécuté","playtest.context.expected":"Attendu","playtest.context.observed":"Observé","playtest.report.empty":"Aucun contenu de rapport disponible","playtest.basic.icon":"🎮","playtest.basic.title":"Playtest est une fonctionnalité réservée à Pro","playtest.basic.desc":"Contrôlez les tests de jeu à partir de WEPPY Dashboard, exécutez des tests automatisés et consultez des rapports de test détaillés.","playtest.basic.benefit1":"Commandes de lecture/pause/arrêt en un clic","playtest.basic.benefit2":"Exécution de tests automatisés via un agent IA","playtest.basic.benefit3":"Historique des tests avec suivi des réussites/échecs","playtest.basic.benefit4":"Rapports de tests de démarque détaillés","playtest.sample.badge":"Aperçu de la vue du playtest Pro","playtest.sample.title":"Vous prévisualisez l'écran de test de jeu qui devient disponible après la mise à niveau vers Pro.","playtest.sample.message":"Cet aperçu utilise des exemples de données. Le contrôle des tests de jeu en direct, la gestion de l'historique et les rapports réels sont débloqués avec Pro.","playtest.sample.clearDisabled":"Passez à Pro pour effacer l'historique des tests de jeu en direct.","playtest.sample.place":"Aperçu de l'arène","playtest.sample.history.name":"Exemple de test de fumée dans une arène","playtest.sample.context.why":"Apparaissez dans l'arène, survivez à l'ouverture et vérifiez que le HUD répond immédiatement.","playtest.sample.context.expected":"Le joueur apparaît en toute sécurité, l'interface utilisateur du compte à rebours apparaît en une seconde et la première vague démarre sans erreur.","playtest.sample.context.observed":"Protection contre l'apparition maintenue, le HUD mis à jour à temps et la première vague terminée sans régression de gameplay.","playtest.sample.report.markdown":`# Exemple de test de fumée d'arène
140
+
141
+ - Flux d'apparition : PASS
142
+ - Compte à rebours HUD : PASS
143
+ - Bootstrap de vague : PASS
144
+
145
+ Ceci est un exemple d’aperçu. Passez à Pro pour exécuter des tests de jeu en direct et enregistrer de vrais rapports.`,"playtest.sample.report.logs":`[exemple] aperçu du test de démarrage
146
+ [exemple] protection contre l'apparition active
147
+ [exemple] compte à rebours hud rendu
148
+ [exemple] première vague terminée
149
+ [exemple] rapport d'aperçu terminé`,"sidebar.whatsNew":"Quoi de neuf","sidebar.help.group":"Aide et commentaires","sidebar.help.bug":"Signaler un bug","sidebar.help.bug.tooltip":"Créer un bundle de diagnostic local, puis ouvrir un rapport de bug pré-rempli sur GitHub","bugReportDialog.title":"diagnostics.zip peut nous aider à analyser le problème","bugReportDialog.subtitle":"WEPPY a créé un zip de diagnostic sur cet ordinateur. Il contient des logs Studio, plugin, Sync et outils qui peuvent nous aider à comprendre ce qui s’est passé.","bugReportDialog.close":"Close","bugReportDialog.loading":"Preparing diagnostics.zip...","bugReportDialog.error":"Could not create the diagnostics bundle. You can still open GitHub without diagnostics.","bugReportDialog.bundle":"Bundle","bugReportDialog.included":"Included","bugReportDialog.included.none":"No log files found","bugReportDialog.optional":"Vous pouvez envoyer le rapport sans ce fichier, mais joindre le zip nous aide souvent à trouver la cause plus vite.","bugReportDialog.attachHow":"Pour le joindre, téléchargez ou affichez le zip, puis ajoutez-le au champ Diagnostics ZIP (optional) de l’issue GitHub avant de l’envoyer.","bugReportDialog.download":"1. Télécharger diagnostics.zip","bugReportDialog.reveal":"Reveal in Finder","bugReportDialog.reveal.opening":"Opening...","bugReportDialog.reveal.opened":"Opened location","bugReportDialog.reveal.failed":"Could not open the file location.","bugReportDialog.openGithub":"2. Ouvrir l’issue GitHub","bugReportDialog.openGithubFallback":"Open GitHub without diagnostics","bugReportDialog.retry":"Try again","bugReportDialog.hint":"Le zip peut contenir des logs locaux et du contexte de projet. Vérifiez-le avant de le joindre si vous voulez le partager.","sidebar.help.feature":"Suggérer une fonctionnalité","sidebar.help.feature.tooltip":"Suggérer une nouvelle fonctionnalité ou une amélioration sur GitHub","sidebar.help.discussions":"Assistance","sidebar.help.discussions.tooltip":"Posez des questions ou demandez de l'aide d'installation via GitHub Issues","sidebar.help.troubleshooting":"Dépannage","sidebar.help.troubleshooting.tooltip":"Ouvrez le guide de dépannage officiel sur weppyai.com","header.whatsNew":"Quoi de neuf","header.whatsNew.tooltip":"Quoi de neuf","upgrade.title":"Voir Pro","upgrade.tagline":"Découvrir les fonctions Pro","upgrade.cta":"Voir Pro","upgrade.licenseShortcut":"Saisir la licence","upgrade.validUntil":"Jusqu'au {{date}}","whatsNew.pageTitle":"Quoi de neuf","whatsNew.pageSubtitle":"Restez informé des modifications apportées à MCP","whatsNew.unreadSection":"Non lu","whatsNew.allSection":"Toutes les annonces","whatsNew.empty":"Aucune annonce pour l'instant","whatsNew.newBadge":"NEW","whatsNew.category.release":"Libérer","whatsNew.category.notice":"Avis","whatsNew.category.deprecation":"Obsolète","whatsNew.category.tip":"Conseil","uiStudio.title":"UI Studio","uiStudio.empty":"Aucune capture d'écran enregistrée pour l'instant. Ils sont créés automatiquement lorsqu'un agent IA capture l'état actuel de l'interface utilisateur.","uiStudio.loading":"Chargement…","uiStudio.pluginGuide.title":"Le plugin Roblox Studio n'est pas connecté","uiStudio.pluginGuide.message":"UI Studio affiche des captures d'écran et l'historique des modifications à partir du lieu Studio connecté. Il sera mis à jour automatiquement après la connexion de Studio et de WEPPY Plugin.","uiStudio.pluginGuide.check1":"Roblox Studio est-il en cours d'exécution ?","uiStudio.pluginGuide.check2":"Le WEPPY Plugin est-il installé et en cours d'exécution ?","uiStudio.pluginGuide.waiting":"En attente de connexion au plugin...","uiStudio.capturedAt":"Capturé à","uiStudio.scope":"Portée","uiStudio.target":"Cible","uiStudio.briefId":"Brève pièce d'identité","uiStudio.detailClose":"Fermer","uiStudio.colCheck":"Vérifier","uiStudio.colPriority":"Priorité","uiStudio.colCurrent":"Actuel","uiStudio.colRecommended":"Recommandé","uiStudio.colSuggestion":"Suggestion","uiStudio.priorityHigh":"Examinez d'abord","uiStudio.priorityLow":"Amélioration facultative","uiStudio.highPrioritySection":"Examinez d'abord","uiStudio.lowPrioritySection":"Améliorations facultatives","uiStudio.groupSummary":"articles","uiStudio.fixLabel":"Réparer","uiStudio.copyFixCommand":"Copier l'instruction IA","uiStudio.copiedToClipboard":"Copié","uiStudio.fullPath":"Chemin complet","uiStudio.falsePositiveWarning":"Ce groupe peut contenir des faux positifs","uiStudio.noSuggestions":"Aucune suggestion d'amélioration actuelle","uiStudio.sample.badge":"Aperçu du Pro UI Studio","uiStudio.sample.title":"Vous prévisualisez le UI Studio qui se déverrouille après la mise à niveau vers Pro.","uiStudio.sample.message":"Cet aperçu utilise des exemples de données provenant d’une interface utilisateur d’inventaire de démonstration. De vraies captures d'écran, un historique des révisions et des correctifs basés sur l'IA sont déverrouillés avec Pro.","uiStudio.tabs.analysis":"Analyse","uiStudio.tabs.history":"Histoire","uiStudio.analysis.reportsTitle":"Dernière analyse par cible d'interface utilisateur","uiStudio.analysis.recentCapturesTitle":"Captures récentes","uiStudio.analysis.detailDialog":"Détail de l'analyse","uiStudio.analysis.targetCountLabel":"Cibles analysées","uiStudio.analysis.captureLabel":"Captures","uiStudio.analysis.verdict.hasSuggestions":"Suggestions d'amélioration","uiStudio.analysis.verdict.needsFix":"Suggestions d'amélioration","uiStudio.analysis.verdict.review":"Suggestions d'amélioration","uiStudio.analysis.verdict.passed":"Aucune suggestion actuelle","uiStudio.analysis.verdictLabel":"Résumé des améliorations","uiStudio.analysis.thresholds":"Base de révision","uiStudio.analysis.issueSummary.passed":"Aucune suggestion d’amélioration supplémentaire dans le cadre de l’examen actuel.","uiStudio.history.title":"Historique des modifications","uiStudio.history.empty":"Pas d'historique pour l'instant. Lorsqu'un agent IA modifie l'interface utilisateur à l'aide de manage_ui, cela sera automatiquement enregistré.","uiStudio.history.loading":"Chargement...","uiStudio.history.error":"Erreur","uiStudio.history.clear":"Clair","uiStudio.history.filter.actions":"Type d'action","uiStudio.history.filter.actionAll":"Tous","uiStudio.history.filter.actionCreate":"Créer","uiStudio.history.filter.actionUpdate":"Mise à jour","uiStudio.history.filter.actionDelete":"Supprimer","uiStudio.history.filter.period":"Période","uiStudio.history.filter.dateAll":"Tous","uiStudio.history.filter.today":"Aujourd'hui","uiStudio.history.filter.yesterday":"Hier","uiStudio.history.filter.last7Days":"7 derniers jours","uiStudio.history.filter.last30Days":"30 derniers jours","uiStudio.history.filter.customRange":"Gamme personnalisée","uiStudio.history.filter.reset":"Réinitialiser","uiStudio.history.filter.from":"Depuis","uiStudio.history.filter.to":"À","uiStudio.history.row.affectedPaths":"Chemins","uiStudio.history.row.mutations":"Modifier les détails","uiStudio.history.row.expand":"▾ Développer","uiStudio.history.row.collapse":"▲ Réduire","uiStudio.history.row.expandDetails":"Afficher les détails de la modification {n}","uiStudio.history.row.collapseDetails":"Masquer les détails des modifications","uiStudio.history.row.toggleDetails":"Toggle modifier les détails","uiStudio.history.row.mutationsEmpty":"Aucun détail de changement","uiStudio.history.row.toolLabel":"Modifications de l'interface utilisateur ({n})","uiStudio.history.row.compare":"Avant/Après","uiStudio.history.row.noBeforeState":"Non avant l'état","uiStudio.history.row.noAfterState":"Non après l'état","uiStudio.history.row.qualityPlan":"Direction de la conception","uiStudio.history.row.designCheck":"Suggestions","uiStudio.history.row.designCheckUnavailable":"Suggestions: indisponible","uiStudio.history.row.designCheckNone":"Suggestions : aucune","uiStudio.history.selection.deleteSelected":"Supprimer la sélection","uiStudio.history.selection.selectAll":"Sélectionner tout","uiStudio.history.selection.clearSelection":"Effacer la sélection","uiStudio.history.confirm.deleteRequestsTitle":"Supprimer les enregistrements de modifications","uiStudio.history.confirm.deleteRequestsMessage":"Les enregistrements de modifications sélectionnés seront supprimés. Cette action ne peut pas être annulée.","uiStudio.history.confirm.clearRequestsTitle":"Effacer l'historique des modifications","uiStudio.history.confirm.clearRequestsMessage":"Cela efface l’historique actuel des changements de lieu. Les instances Studio ne sont pas affectées.","uiStudio.history.confirm.cascadeOption":"Supprimez également les captures d'écran liées","uiStudio.history.drawer.close":"Fermer","uiStudio.actions.previewAgain":"Aperçu à nouveau","uiStudio.actions.deleteSnapshot":"Supprimer cette capture d'écran","uiStudio.actions.proRequired":"Disponible après la mise à niveau vers Pro","uiStudio.actions.captureCurrentState":"Capturer l'état actuel","uiStudio.actions.checkSuggestionsAgain":"Revérifiez les suggestions","uiStudio.actions.previewRunning":"Capturer…","uiStudio.actions.previewRunningDetail":"Le nouvel ID de fichier de capture d'écran apparaîtra une fois la capture terminée.","uiStudio.actions.previewNeedsSaveCheck":"Capture terminée, la sauvegarde doit être révisée","uiStudio.actions.previewSaved":"Nouvelle capture d'écran enregistrée","uiStudio.actions.previewComplete":"Capture terminée","uiStudio.actions.previewSavedDetail":"Les captures d'écran existantes sont conservées ; cela a été enregistré en tant que nouveau fichier.","uiStudio.actions.previewSavedPathMissing":"Un nouvel ID de capture d'écran a été renvoyé, mais le chemin du fichier enregistré n'a pas pu être confirmé.","uiStudio.actions.previewSnapshotIdMissing":"Le nouvel ID de capture d'écran n'a pas pu être confirmé. Actualisez la liste pour vérifier si elle a été enregistrée.","uiStudio.actions.more":"Plus","uiStudio.gallery.selection.selectedCount":"choisi","uiStudio.confirm.deleteSnapshotTitle":"Supprimer la capture d'écran","uiStudio.confirm.deleteSnapshotMessage":"Seul ce fichier de capture d'écran sera supprimé (l'instance Studio est conservée).","uiStudio.confirm.deleteBatchTitle":"Supprimer les captures d'écran sélectionnées","uiStudio.confirm.deleteBatchMessage":"Les captures d'écran sélectionnées seront supprimées. Cette action ne peut pas être annulée.","uiStudio.gallery.selectMode":"Sélectionner","uiStudio.gallery.exitSelectMode":"Annuler","uiStudio.gallery.selectAll":"Sélectionner tout","uiStudio.gallery.clearSelection":"Effacer la sélection","uiStudio.gallery.deleteSelected":"Supprimer la sélection","common.cancel":"Annuler","common.delete":"Supprimer","uiStudio.storage.title":"UI Studio Données enregistrées","uiStudio.storage.usageLabel":"Utilisé","uiStudio.storage.historyBytes":"Changer l'historique","uiStudio.storage.snapshotBytes":"Captures d'écran","uiStudio.storage.requestCount":"Modifier les enregistrements","uiStudio.storage.mutationCount":"Modifier les détails","uiStudio.storage.snapshotCount":"Captures d'écran","uiStudio.storage.countSuffix":"","uiStudio.storage.lastRun":"Dernier nettoyage automatique","uiStudio.storage.lastRunNever":"—","uiStudio.storage.lastRunFreed":"libéré","uiStudio.storage.lastRunErrors":"Erreurs","uiStudio.storage.loading":"Chargement...","uiStudio.cleanup.policy.title":"Politique de suppression automatique","uiStudio.cleanup.policy.modeOff":"Désactivé","uiStudio.cleanup.policy.modeAge":"Basé sur l'âge","uiStudio.cleanup.policy.modeSize":"Basé sur la taille","uiStudio.cleanup.policy.cascade":"Supprimez également les captures d'écran liées","uiStudio.cleanup.policy.save":"Enregistrer la politique","uiStudio.cleanup.policy.runNow":"Courez maintenant","uiStudio.cleanup.policy.proRequired":"Disponible après la mise à niveau vers Pro","uiStudio.cleanup.policy.daysUnit":"d","uiStudio.cleanup.policy.mbUnit":"MB","uiStudio.cleanup.policy.gbUnit":"GB","uiStudio.cleanup.policy.confirm.title":"Confirmer la politique","uiStudio.cleanup.policy.confirm.messageStrict":"L'application de cette politique entraînera la suppression immédiate","uiStudio.cleanup.policy.confirm.requests":"modifier les enregistrements","uiStudio.cleanup.policy.confirm.snapshots":"captures d'écran","uiStudio.cleanup.policy.confirm.freed":"libéré — Postuler ?","uiStudio.cleanup.keepLastNDays":"Conserver les {n} derniers jours","uiStudio.cleanup.selectedDelete":"Supprimer la sélection…","uiStudio.cleanup.deleteAll":"Supprimer tout…","uiStudio.cleanup.cleanupConfirmTitle":"Confirmer le nettoyage","uiStudio.cleanup.cleanupConfirmMessage":"Tous les éléments sélectionnés seront supprimés. Cette action ne peut pas être annulée.","uiStudio.cleanup.cleanupConfirmMessage.keep7":"Les enregistrements de modifications et les captures d'écran datant de plus de 7 jours seront supprimés. Cette action ne peut pas être annulée.","uiStudio.cleanup.cleanupConfirmMessage.keep30":"Les enregistrements de modifications et les captures d'écran datant de plus de 30 jours seront supprimés. Cette action ne peut pas être annulée.","uiStudio.cleanup.cleanupConfirmMessage.all":"Les enregistrements de modifications enregistrées et les captures d'écran seront supprimés. Cette action ne peut pas être annulée.","uiStudio.cleanup.label":"Nettoyage manuel","uiStudio.cleanup.studioPreservedNote":"Cela supprime uniquement les enregistrements de modifications enregistrées et les captures d'écran sur le disque ; Les instances Roblox Studio ne sont pas affectées.","uiStudio.history.sample.bannerBadge":"Aperçu de l'historique des modifications Pro","uiStudio.history.sample.bannerTitle":"Vous prévisualisez l'historique des modifications de l'interface utilisateur qui se déverrouille après la mise à niveau vers Pro.","uiStudio.history.sample.bannerMessage":"Cet aperçu utilise des exemples de données. Historique réel des modifications, comparaison avant/après et déverrouillage de suppression par lots avec Pro.","uiStudio.fix.touchTarget.label":"Taille de la cible tactile","uiStudio.fix.touchTarget.description":"Vérifie si les commandes sont suffisamment grandes pour appuyer confortablement sur mobile.","uiStudio.fix.touchTarget.howToFix":"Augmentez la taille du bouton à au moins 44 x 44 px ou agrandissez la zone tactile avec UIPadding.","uiStudio.fix.contrast.label":"Contraste du texte","uiStudio.fix.contrast.description":"Vérifie si le contraste du texte et de l’arrière-plan respecte les directives d’accessibilité.","uiStudio.fix.contrast.howToFix":"Utilisez un TextColor3 plus clair ou assombrissez le BackgroundColor3.","uiStudio.fix.contrast.falsePositive":"Les icônes Emoji peuvent être des faux positifs lorsque leur couleur est corrigée.","uiStudio.fix.textScaled.label":"Utilisation à l'échelle du texte","uiStudio.fix.textScaled.description":"TextScaled sans UITextSizeConstraint peut interrompre les mises en page lorsque le texte se développe.","uiStudio.fix.textScaled.howToFix":"Ajoutez un enfant UITextSizeConstraint au TextLabel et définissez MaxTextSize.","uiStudio.fix.safezone.label":"Placement en zone de sécurité","uiStudio.fix.safezone.description":"Vérifie si les contrôles restent à l’intérieur des zones de sécurité de la plate-forme.","uiStudio.fix.safezone.howToFix":"Déplacez la position à l’intérieur de la zone de sécurité ou réduisez le cadre parent.","uiStudio.fix.minTextSize.label":"Taille de police minimale","uiStudio.fix.minTextSize.description":"Vérifie si le texte est trop petit pour être lu confortablement.","uiStudio.fix.minTextSize.howToFix":"Augmentez TextSize à au moins 14 pour le corps du texte.","uiStudio.sample.history.request1.label":"Création initiale de la disposition du HUD","uiStudio.sample.history.request2.label":"Mise à jour de la conception modale de l'inventaire","uiStudio.sample.history.request3.label":"Mise à jour des couleurs du HUD HealthBar","uiStudio.sample.history.request4.label":"Cibles tactiles du bouton de l'onglet Développer l'inventaire","uiStudio.sample.history.request5.label":"Fenêtre contextuelle Supprimer les paramètres","uiStudio.sample.history.request6.label":"Ajouter un composant de mini-carte HUD","uiStudio.sample.history.request1.mutation1.diff":"Cadre créé + HealthBar + StaminaBar","uiStudio.sample.history.request1.mutation2.diff":"BackgroundColor3 -> Color3.new(0.2,0.8,0.2)","uiStudio.sample.history.request1.mutation3.diff":"BackgroundColor3 -> Color3.new(0.1,0.6,1.0)","uiStudio.sample.history.request1.mutation4.diff":"Définir le point d'ancrage, la position et la taille","uiStudio.sample.history.request1.mutation5.diff":"Capture d'écran enregistrée","uiStudio.sample.history.request2.mutation1.diff":"Darkened BackgroundColor3 pour un meilleur contraste","uiStudio.sample.history.request2.mutation2.diff":"TextColor3 -> Color3.new(1,1,1), TextSize 16 -> 18","uiStudio.sample.history.request2.mutation3.diff":"BorderSizePixel 0 -> 2, définissez BorderColor3","uiStudio.sample.history.request2.mutation4.diff":"Capture d'écran enregistrée","uiStudio.sample.history.request3.mutation1.diff":"BackgroundColor3 -> Color3.new(0.9,0.2,0.2) (ton rouge)","uiStudio.sample.history.request3.mutation2.diff":"Capture d'écran enregistrée","uiStudio.sample.history.request4.mutation1.diff":"Taille {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation2.diff":"Taille {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation3.diff":"Taille {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation4.diff":"Taille {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation5.diff":"Taille {0,64},{0,32} -> {0,64},{0,44}","uiStudio.sample.history.request4.mutation6.diff":"Capture d'écran enregistrée","uiStudio.sample.history.request5.mutation1.diff":"ScreenGui supprimé (interface utilisateur réservée aux paramètres uniquement)","uiStudio.sample.history.request6.mutation1.diff":"Tentative de création de Frame + MapImage + PlayerDot","uiStudio.sample.history.request6.mutation2.diff":"Définir la taille, la position et la transparence de l'arrière-plan","uiStudio.sample.history.request6.mutation3.diff":"Interrompu par le redémarrage du serveur lors de la configuration d'ImageLabel","uiStudio.sample.history.request6.mutation4.diff":"Capture d'écran partielle enregistrée","uiStudio.sample.history.request6.mutation3.error":"server_restart : connexion perdue","uiStudio.sample.history.request6.mutation4.error":"capture d'écran partielle : couches manquantes","uiStudio.sample.history.detail.backgroundColor":"Couleur de fond","uiStudio.sample.history.detail.anchorPoint":"Ancre","uiStudio.sample.history.detail.position":"Position","uiStudio.sample.history.detail.size":"Taille","uiStudio.sample.history.detail.textColor":"Couleur du texte","uiStudio.sample.history.detail.textSize":"Taille du texte","uiStudio.sample.history.detail.borderSize":"Taille de la bordure","uiStudio.sample.history.detail.borderColor":"Couleur de la bordure","settings.dataHistory.title":"Données et historique","settings.dataHistory.title.tooltip":"Gérez les données enregistrées du tableau de bord en un seul endroit.","settings.dataHistory.collapse":"Réduire {title}","settings.dataHistory.expand":"Développez {title}","settings.dataHistory.scope":"Projet actuel","settings.dataHistory.scope.tooltip":"Des actions claires s’appliquent au projet en cours et au lieu actif le cas échéant.","settings.dataHistory.intro":"Consultez les données enregistrées du tableau de bord, ouvrez la page associée ou effacez les enregistrements stockés à partir d'un seul endroit.","settings.dataHistory.toolsActivity.title":"Activité de l'outil","settings.dataHistory.toolsActivity.description":"Exécutions d'outils enregistrées affichées sur la page Outils.","settings.dataHistory.toolStats.title":"Statistiques d'utilisation des outils","settings.dataHistory.toolStats.description":"Nombre d’outils agrégés et totaux d’état.","settings.dataHistory.syncLog.title":"Journal de synchronisation","settings.dataHistory.syncLog.description":"Événements de synchronisation de fichiers enregistrés pour le lieu actif.","settings.dataHistory.playtest.title":"Rapports de tests de jeu","settings.dataHistory.playtest.description":"Rapports et journaux de tests de jeu automatisés enregistrés.","settings.dataHistory.projectChanges.title":"Prorésumé des modifications du projet","settings.dataHistory.projectChanges.description":"Résumés enregistrés des modifications du projet.","settings.dataHistory.connectionLog.title":"Journal de connexion","settings.dataHistory.connectionLog.description":"Enregistrement des événements de connexion MCP et Studio.","settings.dataHistory.uiStudio.title":"Historique et captures d'écran de UI Studio","settings.dataHistory.uiStudio.tooltip":"Gérez les enregistrements de modifications UI Studio enregistrés, les captures d'écran et la politique de suppression automatique.","settings.dataHistory.uiStudio.description":"Enregistrements de modifications, captures d'écran et politique de nettoyage UI Studio enregistrés.","settings.dataHistory.uiStudio.clear.title":"Effacer les données enregistrées UI Studio ?","settings.dataHistory.uiStudio.clear.message":"Cela supprime uniquement les enregistrements de modifications et les captures d'écran UI Studio enregistrés. Les instances Roblox Studio et les objets de projet ne sont pas modifiés.","settings.dataHistory.uiStudio.clear.success":"Les données enregistrées par UI Studio ont été effacées.","settings.dataHistory.uiStudio.clear.failed":"Échec de la suppression des données enregistrées UI Studio.","settings.dataHistory.metric.unavailable":"Indisponible","settings.dataHistory.metric.sizeUnavailable":"taille indisponible","settings.dataHistory.metric.records":"enregistrements","settings.dataHistory.metric.runs":"court","settings.dataHistory.metric.sessions":"séances","settings.dataHistory.metric.reports":"rapports","settings.dataHistory.open":"Ouvrir","settings.dataHistory.clear.title":"Effacer les données enregistrées ?","settings.dataHistory.clear.message":"Cela supprime uniquement les enregistrements de tableau de bord enregistrés. Les instances Roblox Studio et les objets de projet ne sont pas modifiés.","settings.dataHistory.clear.success":"Données enregistrées effacées.","settings.dataHistory.clear.failed":"Échec de la suppression des données enregistrées.","uiStudio.history.sample.tooltip":"Passez à Pro pour débloquer l'historique complet","toast.serverConnected":"Serveur MCP connecté","toast.serverDisconnected":"Serveur MCP déconnecté","toast.pluginConnected":"Plugin connecté","toast.pluginDisconnected":"Plugin déconnecté","toast.clearSuccess":"Effacé avec succès","toast.clearFailed":"Échec de la suppression des données","common.clear":"Clair","settings.license.activate":"Activer la licence","settings.license.refresh":"Actualiser la licence","settings.license.keyInput":"Clé de licence","settings.license.disconnected":"Déconnecté","settings.license.disconnected.tooltip":"Reconnectez-vous au serveur MCP pour gérer les actions de licence à partir de WEPPY Dashboard.","settings.license.live.tooltip":"Les actions de licence sont immédiatement envoyées au serveur MCP.","settings.license.status.activationRequired":"Activation requise","settings.license.status.activationRequired.tooltip":"L'activation manuelle de la licence est requise avant que WEPPY Dashboard puisse actualiser ce statut.","settings.license.status.grace":"Grâce","settings.license.status.grace.tooltip":"La vérification Provider est temporairement indisponible, mais l'accès Pro reste actif pendant la période de grâce.","settings.license.status.graceBilling.tooltip":"L'accès Pro est toujours disponible pendant une période de grâce liée à la facturation.","settings.license.detail.graceBilling":"L'accès Pro reste disponible pendant une période de grâce de facturation.","settings.license.detail.graceProviderUnavailable":"Provider indisponible. L'accès Pro reste actif pendant le mode grâce.","settings.license.detail.manualActivation":"Activation manuelle requise pour restaurer l'accès à Pro.","settings.license.detail.missingSessionToken":"L'actualisation est bloquée car le jeton de session en cours est manquant.","settings.license.detail.refreshRecommended":"La vérification des licences devrait être actualisée prochainement.","connection.agents.kill":"Tuer","connection.agents.kill.title":"Tuer l'agent ?","connection.agents.killed":"Agent tué","connection.agents.killFailed":"Impossible de tuer l'agent","connection.agents.lastCommand":"Dernière commande","connection.agents.lastCommand.tooltip":"Appel d'outil le plus récent exécuté par cet agent","connection.agents.lastSeen":"Vu pour la dernière fois","connection.agents.lastSeen.tooltip":"Battement de cœur ou activité la plus récente de cet agent","connection.clear.title":"Effacer le journal de connexion ?","connection.clear.message":"Cela supprime définitivement le journal de connexion stocké pour le projet en cours.","sync.clear.title":"Effacer le journal de synchronisation ?","sync.clear.message":"Cela supprime définitivement le journal de synchronisation stocké pour le lieu actuel.","playtest.clear.title":"Effacer l'historique des tests ?","playtest.clear.message":"Cela supprime définitivement les rapports de test de jeu stockés pour le lieu actuel.","changelog.clear.title":"Effacer le journal des modifications ?","changelog.clear.message":"Cela supprime définitivement le journal des modifications stocké pour le lieu actuel.","sync.status.placePath":"Placer le chemin","sync.status.placePath.tooltip":"Répertoire de lieu actif où les fichiers de l'explorateur sont synchronisés.","tier.progress.label":"Pro / Total","changelog.card.representativeArea":"Zone représentative","changelog.card.verification":"Vérification","uiStudio.tabs.analysis.tooltip":"Parcourez les écrans d’interface utilisateur capturés par l’IA et trouvez rapidement quelles interfaces utilisateur doivent être améliorées.","uiStudio.tabs.history.tooltip":"Chaque changement d'interface utilisateur effectué par l'IA, dans l'ordre. Comparez les écrans avant et après.","uiStudio.title.tooltip":"Un endroit central pour examiner les écrans d’interface utilisateur générés par l’IA et les suggestions d’amélioration.","uiStudio.analysis.reportsTitle.tooltip":"Affiche le dernier résumé de capture et de suggestion par interface utilisateur (par exemple, fenêtre d'inventaire, menu principal).","uiStudio.analysis.verdict.hasSuggestions.tooltip":"Certaines améliorations ont été trouvées dans cette interface utilisateur. Cliquez sur la carte pour plus de détails.","uiStudio.analysis.verdict.passed.tooltip":"Aucune amélioration suggérée en vertu des seuils d'examen actuels.","uiStudio.analysis.counts.tooltip":"« Principal » sont les éléments clés à examiner en premier ; Les « notes » sont des raffinements agréables à avoir.","uiStudio.analysis.thresholds.tooltip":"Ensemble de seuils utilisé pour cet examen (par défaut ou personnalisé).","uiStudio.analysis.recentCapturesTitle.tooltip":"Toutes les captures récemment enregistrées par ordre chronologique.","uiStudio.gallery.selectAll.tooltip":"Sélectionnez toutes les captures visibles à la fois.","uiStudio.gallery.clearSelection.tooltip":"Effacez la sélection actuelle.","uiStudio.gallery.deleteSelected.tooltip":"Supprimez uniquement les fichiers de capture sélectionnés. L'interface utilisateur réelle dans Roblox Studio n'est pas affectée.","uiStudio.gallery.cardCheckbox.tooltip":"Sélectionnez cette capture. Choisissez-en plusieurs pour les supprimer ensemble.","uiStudio.detailClose.tooltip":"Fermez ce panneau de détails.","uiStudio.actions.captureCurrentState.tooltip":"Enregistrez l'interface utilisateur actuellement affichée dans Studio en tant que nouvelle capture. Les captures existantes sont conservées.","uiStudio.actions.checkSuggestionsAgain.tooltip":"Recalculez les suggestions pour cette capture sans prendre une nouvelle capture d'écran.","uiStudio.actions.more.tooltip":"Ouvrez des actions supplémentaires.","uiStudio.actions.deleteSnapshot.tooltip":"Supprimez uniquement ce fichier de capture. L'interface utilisateur réelle dans Roblox Studio n'est pas affectée.","uiStudio.capturedAt.tooltip":"Quand cet écran a été capturé.","uiStudio.scope.tooltip":"Portée de capture (plein écran ou interface utilisateur spécifique).","uiStudio.target.tooltip":"Chemin exact de l’instance d’interface utilisateur capturée.","uiStudio.briefId.tooltip":"Identifiant du cahier des charges qui a produit cette interface utilisateur.","uiStudio.analysis.verdictLabel.tooltip":"Verdict d'amélioration globale pour cette capture.","uiStudio.suggestionGroup.tooltip":"Suggestions du même genre regroupées. Cliquez pour agrandir ou réduire.","uiStudio.groupSummary.tooltip":"Nombre d'éléments d'interface utilisateur correspondant à ce groupe.","uiStudio.colCurrent.tooltip":"La valeur actuellement appliquée.","uiStudio.colRecommended.tooltip":"La valeur recommandée.","uiStudio.copyFixCommand.tooltip":"Copiez une invite demandant à l'IA de résoudre ce problème.","uiStudio.falsePositiveWarning.tooltip":"Cette vérification peut produire des faux positifs – vérifiez avant de postuler.","uiStudio.history.filter.actions.tooltip":"Filtrez les enregistrements en fonction du type de modification apportée par l'IA.","uiStudio.history.filter.period.tooltip":"Filtrer les enregistrements par plage horaire.","uiStudio.history.filter.from.tooltip":"Date de début de la requête.","uiStudio.history.filter.to.tooltip":"Date de fin de la requête.","uiStudio.history.filter.actionAll.tooltip":"Montrez tout type d'action.","uiStudio.history.filter.actionCreate.tooltip":"Afficher uniquement les actions qui ont créé une nouvelle interface utilisateur.","uiStudio.history.filter.actionUpdate.tooltip":"Afficher uniquement les actions qui ont mis à jour une interface utilisateur existante.","uiStudio.history.filter.actionDelete.tooltip":"Afficher uniquement les actions qui ont supprimé une interface utilisateur.","uiStudio.history.filter.dateAll.tooltip":"Afficher l'historique complet.","uiStudio.history.filter.today.tooltip":"Afficher uniquement les modifications apportées à aujourd'hui.","uiStudio.history.filter.yesterday.tooltip":"Afficher uniquement les modifications d'hier.","uiStudio.history.filter.last7Days.tooltip":"Afficher les modifications des 7 derniers jours.","uiStudio.history.filter.last30Days.tooltip":"Afficher les modifications des 30 derniers jours.","uiStudio.history.filter.customRange.tooltip":"Choisissez une date de début et de fin personnalisée.","uiStudio.history.filter.reset.tooltip":"Réinitialisez tous les filtres aux valeurs par défaut.","uiStudio.history.title.tooltip":"Une chronologie de chaque modification de l'interface utilisateur effectuée par l'IA.","uiStudio.history.clear.tooltip":"Supprimez tous les enregistrements de modifications pour ce projet. L'interface utilisateur réelle dans Roblox Studio n'est pas affectée.","uiStudio.history.row.compare.tooltip":"Comparez les écrans avant et après. Cliquez pour ouvrir la vue de comparaison complète.","uiStudio.history.row.extraPaths.tooltip":"Nombre d'interfaces utilisateur supplémentaires modifiées dans cette action.","uiStudio.history.row.noBeforeState.tooltip":"Aucune capture enregistrée avant ce changement.","uiStudio.history.row.noAfterState.tooltip":"Aucune capture enregistrée après ce changement.","uiStudio.history.row.affectedPaths.tooltip":"Nombre d'interfaces utilisateur affectées par cette action.","uiStudio.history.row.mutations.tooltip":"Nombre de modifications détaillées (par exemple, modifications de propriétés).","uiStudio.history.row.qualityPlan.tooltip":"Brève direction de conception utilisée pour ce changement.","uiStudio.history.row.designCheck.tooltip":"Résumé des suggestions de contrôle de conception après modification.","uiStudio.history.row.toggleDetails.tooltip":"Afficher ou masquer une ventilation par ligne de ce qui a changé.","uiStudio.compare.before.tooltip":"L'écran a été enregistré juste avant que l'IA n'effectue la modification.","uiStudio.compare.after.tooltip":"L'écran a été enregistré juste après que l'IA ait effectué la modification.","uiStudio.compare.path.tooltip":"Chemin d'accès à l'instance d'interface utilisateur pour cet écran.","uiStudio.storage.title.tooltip":"Utilisation du disque des enregistrements de modifications et des captures d'écran de UI Studio.","uiStudio.storage.usageLabel.tooltip":"Espace disque actuellement utilisé par UI Studio pour ce projet.","uiStudio.storage.historyBytes.tooltip":"Espace occupé par les données d'enregistrement de modification (JSON).","uiStudio.storage.snapshotBytes.tooltip":"Espace occupé par les fichiers image PNG capturés.","uiStudio.storage.requestCount.tooltip":"Nombre d'actions où l'IA a modifié l'interface utilisateur.","uiStudio.storage.mutationCount.tooltip":"Nombre de modifications détaillées dans les actions (une modification de propriété = 1).","uiStudio.storage.snapshotCount.tooltip":"Nombre de fichiers d'images de capture enregistrés.","uiStudio.storage.lastRun.tooltip":"Quand la stratégie de nettoyage automatique a été exécutée pour la dernière fois et ce qu’elle a supprimé.","uiStudio.cleanup.label.tooltip":"Nettoyez manuellement les enregistrements et les captures de modifications quand vous le souhaitez.","uiStudio.cleanup.keep7.tooltip":"Supprimez les enregistrements de modifications et les captures datant de plus de 7 jours.","uiStudio.cleanup.keep30.tooltip":"Supprimez les enregistrements de modifications et les captures datant de plus de 30 jours.","uiStudio.cleanup.deleteAll.tooltip":"Supprimez chaque enregistrement de modification et capture pour ce projet. L'interface utilisateur réelle dans Roblox Studio n'est pas affectée.","uiStudio.cleanup.policy.title.tooltip":"Règles qui suppriment automatiquement les captures anciennes ou volumineuses.","uiStudio.cleanup.policy.modeOff.tooltip":"Désactivez le nettoyage automatique. Les données restent jusqu'à ce que vous les supprimiez manuellement.","uiStudio.cleanup.policy.modeAge.tooltip":"Supprimez automatiquement les données antérieures au nombre de jours configuré.","uiStudio.cleanup.policy.modeSize.tooltip":"Lorsque l'utilisation totale dépasse la limite, les données les plus anciennes sont supprimées en premier.","uiStudio.cleanup.policy.agePreset.tooltip":"Supprimez les données datant de plus de plusieurs jours.","uiStudio.cleanup.policy.ageInput.tooltip":"Entrez n'importe quelle valeur comprise entre 1 et 365 jours.","uiStudio.cleanup.policy.sizePreset.tooltip":"Gardez l’utilisation totale en dessous de cette taille.","uiStudio.cleanup.policy.sizeInput.tooltip":"Saisissez n'importe quelle valeur comprise entre 50 Mo et 10 000 Mo (10 Go).","uiStudio.cleanup.policy.cascade.tooltip":"Supprimez également les images de capture liées à ces enregistrements. Si cette option est désactivée, les images restent.","uiStudio.cleanup.policy.save.tooltip":"Enregistrez la règle de nettoyage actuelle. Il fonctionne désormais en arrière-plan.","uiStudio.cleanup.policy.runNow.tooltip":"Exécutez la règle actuelle une fois maintenant, sans attendre la prochaine exécution planifiée.","settings.license.refresh.tooltip":"Récupérez à nouveau l'état actuel à partir du serveur de licences. Utile lorsqu'un changement de facturation n'est pas encore apparu.","settings.license.reset.tooltip":"Supprimez la clé de licence actuellement enregistrée. Utilisez-le avant d'activer avec une clé différente.","settings.license.activate.tooltip":"Activez les fonctionnalités Pro avec la clé de licence saisie.","tier.upgrade.tooltip":"Voir les fonctions Pro et les options d’achat.","settings.language.auto.tooltip":"Suivez la langue du système d'exploitation. Revient à l'anglais lorsqu'il n'est pas pris en charge.","settings.dataHistory.open.tooltip":"Ouvrez la page qui montre cet élément en détail.","settings.dataHistory.clear.tooltip":"Supprimez uniquement les enregistrements enregistrés pour cet élément. Les données Roblox Studio ne sont pas modifiées.","settings.dataHistory.toggle.tooltip":"Réduisez ou développez cette section.","settings.dataHistory.toolsActivity.metric.tooltip":"Nombre d'exécutions d'outils enregistrées et espace disque qu'elles utilisent.","settings.dataHistory.toolStats.metric.tooltip":"Nombre total d'exécutions et de sessions agrégées.","settings.dataHistory.syncLog.metric.tooltip":"Nombre d'événements de synchronisation enregistrés et espace disque qu'ils utilisent.","settings.dataHistory.playtestReports.metric.tooltip":"Nombre de rapports de tests de jeu enregistrés et espace disque qu'ils utilisent.","settings.dataHistory.projectChanges.metric.tooltip":"Nombre de résumés de modifications de projet enregistrés et espace disque qu'ils utilisent.","settings.dataHistory.connectionLog.metric.tooltip":"Nombre d'événements de connexion enregistrés et espace disque qu'ils utilisent.","settings.dataHistory.uiStudio.metric.tooltip":"UI Studio modifie le nombre d'enregistrements et de captures, ainsi que l'utilisation totale du disque.","uiStudio.designCheckResultsTitle":"Suggestions de contrôle de conception","uiStudio.designCheckResultsTitle.tooltip":"Toutes les suggestions d'amélioration trouvées dans cette capture.","uiStudio.actions.designCheckAgain":"Revérifier","uiStudio.actions.designCheckRunning":"Vérification des suggestions...","uiStudio.actions.designCheckRunningDetail":"Les décomptes d’articles examinés en premier, recommandés et facultatifs apparaîtront une fois la vérification terminée.","uiStudio.actions.designCheckComplete":"Vérification des suggestions terminée","uiStudio.actions.designCheckNoSnapshotSaved":"Cette action n'enregistre pas un nouveau fichier de capture d'écran.","uiStudio.sample.designCheck.contrast":"Le contraste du texte est inférieur à {expected} (actuel {actual}). Ajustez TextColor3 ou BackgroundColor3.","uiStudio.sample.designCheck.touchTarget":"La cible tactile est inférieure à {expected} (actuel {actual}). Augmentez la taille ou le rembourrage.","uiStudio.sample.designCheck.minTextSize":"TextSize est inférieur à {expected} (actuel {actual}). Augmentez-le pour plus de lisibilité.","uiStudio.gallery.priorityHighBadge.tooltip":"Nombre de suggestions à examiner en premier. Cliquez pour plus de détails.","uiStudio.gallery.priorityMediumBadge.tooltip":"Nombre de suggestions recommandées.","uiStudio.priorityMedium":"Examen recommandé","uiStudio.mediumPrioritySection":"Examen recommandé","uiStudio.gallery.priorityLowBadge.tooltip":"Nombre d'améliorations facultatives.","tier.banner.progressLabel":"Pro / Total","uiStudio.error":"Erreur","uiStudio.analysis.expandChildren":"Afficher les cibles enfants","uiStudio.analysis.openDetail":"Détail ouvert","uiStudio.analysis.childTargets":"Enfants cibles","uiStudio.analysis.childDetailHint":"Ouvrir les détails de la cible enfant","uiStudio.compare.before":"Avant","uiStudio.compare.after":"Après","uiStudio.history.drawer.changeDetails":"Modifier les détails","uiStudio.gallery.cardCheckbox":"Sélectionnez une capture d'écran","sidebar.assets":"Assets","assets.title":"Assets","assets.experimental":"Experimental","assets.subtitle":"Browse local originals, upload to Roblox, and inspect synced usage by place.","assets.scope.label":"Asset scope","assets.scope.place":"Current Place","assets.scope.shared":"Shared","assets.count.shown":"Shown assets: {count}","assets.category.filter":"Category","assets.category.all":"All","assets.category.image":"Images","assets.category.decal":"Decals","assets.category.audio":"Audio","assets.category.mesh":"Meshes","assets.category.model":"Models","assets.category.rbxm":"RBXM","assets.category.video":"Videos","assets.category.animation":"Animations","assets.category.comingSoon":"Coming soon","assets.status.localOnly":"Local only","assets.status.uploading":"Uploading","assets.status.processing":"Processing","assets.status.uploaded":"Uploaded","assets.status.failed":"Failed","assets.status.superseded":"Superseded","assets.rescan":"Rescan","assets.rescan.tooltip":"Scan the selected inbox folder.","assets.rescan.chooseCategory":"Choose a category before rescanning.","assets.rbxmGuide.title":"Save RBXM from Studio","assets.rbxmGuide.body":"Select objects in Roblox Studio, then use WEPPY Plugin > Assets to save the selection as a local RBXM asset.","assets.rbxmGuide.thumbnail":"The plugin save flow includes a thumbnail option, and saved RBXM assets appear here for management, upload, and insertion.","assets.exportSelection":"Export Studio selection","assets.exportSelection.tooltip":"Export the current Studio selection as a local .rbxm asset.","assets.exportSelection.chooseCategory":"Choose RBXM before exporting a Studio selection.","assets.upload.open":"Upload","assets.upload.open.tooltip":"Upload this local file to Roblox through Open Cloud.","assets.upload.selectFirst":"Select an asset first.","assets.upload.title":"Upload asset","assets.upload.checkingSettings":"Checking upload settings...","assets.upload.settingsLoadFailed":"Failed to load upload settings.","assets.upload.settingsRequired":"Upload settings required","assets.upload.settingsRequired.apiKey":"Save an Open Cloud API key before uploading.","assets.upload.settingsRequired.toggle":"Enable Open Cloud upload before uploading.","assets.upload.settingsRequired.creator":"Save a default Creator before uploading.","assets.upload.openSettings":"Open Asset Library settings","assets.upload.creator":"Creator","assets.upload.creatorType":"Creator type","assets.upload.creatorId":"Creator ID","assets.upload.envCreatorHelp":"Environment API keys cannot save a default Creator here. Enter the Creator for this upload.","assets.upload.displayNameHelp":"Saved to Roblox as the asset display name.","assets.upload.descriptionHelp":"Saved to Roblox as the asset description.","assets.upload.creatorHelp":"Used by Open Cloud as the owner of the uploaded asset.","assets.upload.creatorTypeHelp":"Sent to Open Cloud as the Creator type.","assets.upload.creatorIdHelp":"Sent to Open Cloud as the User or Group ID that owns the uploaded asset.","assets.upload.submit":"Upload with Roblox Open Cloud","assets.upload.uploading":"Uploading...","assets.upload.noDelete":"WEPPY does not provide Roblox asset deletion.","assets.upload.delay":"Roblox processing and moderation can delay visibility in Studio or Creator Dashboard.","assets.delete.tooltip":"Delete this local Asset Library item.","assets.delete.title":"Delete asset","assets.delete.message":"This removes the local Asset Library files only. Uploaded Roblox assets are not deleted.","assets.creator.user":"User","assets.creator.group":"Group","assets.settings.open":"Open settings","assets.settings.open.tooltip":"Open Roblox upload settings.","assets.settings.title":"Asset Library settings","assets.settings.proOnly":"Roblox upload settings and Open Cloud credential controls are available on Pro.","assets.settings.openCloudToggle":"Open Cloud upload","assets.settings.openCloudToggle.help":"Controls whether server-side Open Cloud upload mutations can run.","assets.settings.apiKey":"Open Cloud API Key","assets.settings.apiKeyGuide":"Create a Roblox API key with Assets Read and Write permissions.","assets.settings.creatorHelp":"Use the numeric user ID from a profile URL or group ID from a group URL.","assets.settings.credential.none":"No API key saved","assets.settings.credential.env":"Environment variable","assets.settings.credential.local":"Local encrypted file","assets.settings.registeredApiKey":"Registered API Key","assets.settings.credentialProfile":"Credential Profile","assets.settings.activeProfileBadge":"Active","assets.settings.field.profile":"Profile","assets.settings.field.apiKey":"API Key","assets.settings.field.storage":"Storage","assets.settings.field.validationStatus":"Validation status","assets.settings.field.creators":"Creators","assets.settings.validation.unknown":"Not tested","assets.settings.validation.valid":"Connected","assets.settings.validation.invalid":"Needs attention","assets.settings.profileSelected":"Open Cloud credential profile selected.","assets.settings.useProfile":"Use profile","assets.settings.replaceApiKey":"Replace API Key","assets.settings.profileLabel":"Profile name (optional)","assets.settings.profileLabel.placeholder":"Studio automation key","assets.settings.profileLabel.help":"Optional. If left blank, WEPPY saves this profile as Open Cloud key automatically.","assets.settings.saveApiKey":"Save API Key","assets.settings.testConnection":"Test Connection","assets.settings.removeApiKey":"Unregister API Key","assets.settings.saveCreator":"Save default Creator","assets.settings.saveCreatorPreset":"Save Creator","assets.settings.addCreator":"Add Creator","assets.settings.addCreator.tooltip.ready":"Add another User or Group Creator preset to this profile.","assets.settings.cancelCreator":"Cancel","assets.settings.defaultCreatorBadge":"Default","assets.settings.makeDefaultCreator":"Make default","assets.settings.unregisterCreator":"Unregister Creator","assets.settings.creatorLabel":"Creator label (optional)","assets.settings.creatorLabel.placeholder":"Main studio group","assets.settings.creatorLabel.help":"Optional. If left blank, WEPPY automatically saves a label like User 123 or Group 456.","assets.settings.action.proRequired":"Asset upload settings are available on Pro.","assets.settings.action.busy":"Wait for the current settings action to finish.","assets.settings.saveApiKey.tooltip.ready":"Save this API key to local encrypted storage.","assets.settings.saveApiKey.tooltip.enter":"Enter an Open Cloud API key to save it locally.","assets.settings.testConnection.tooltip.entered":"Test the entered API key before saving it.","assets.settings.testConnection.tooltip.saved":"Test the saved Open Cloud API key.","assets.settings.testConnection.tooltip.enterOrSaved":"Enter an API key or save one before testing the connection.","assets.settings.removeApiKey.tooltip.ready":"Unregister the locally saved Open Cloud API key from WEPPY.","assets.settings.removeApiKey.tooltip.none":"No local Open Cloud API key is saved.","assets.settings.removeApiKey.tooltip.env":"Environment API keys cannot be removed from Dashboard. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY.","assets.settings.unregisterCreator.tooltip.ready":"Unregister this Creator from the selected profile.","assets.settings.unregisterApiKey.title":"Unregister API Key?","assets.settings.unregisterApiKey.message":"Roblox API key is not revoked. WEPPY only removes the local Credential Profile registration on this device.","assets.settings.unregisterCreator.title":"Unregister Creator?","assets.settings.unregisterCreator.message":"Roblox user or group is not deleted. WEPPY only removes this Creator from the selected API Key profile.","assets.settings.saveCreator.tooltip.ready":"Save this Creator as the default owner for uploads.","assets.settings.saveCreator.tooltip.noLocal":"Save a local Open Cloud API key before saving a default Creator.","assets.settings.saveCreator.tooltip.env":"Environment API keys cannot save a default Creator here. Enter Creator details in the upload dialog.","assets.settings.saveCreator.tooltip.enterId":"Enter a user or group ID before saving the default Creator.","assets.settings.apiKeySaved":"Open Cloud API key saved locally.","assets.settings.apiKeyTested":"Open Cloud API key connection tested.","assets.settings.apiKeyRemoved":"Open Cloud API key unregistered from local storage.","assets.settings.envApiKeyStillActive":"Environment variable credential is still active. Remove ROBLOX_OPEN_CLOUD_API_KEY outside WEPPY Dashboard.","assets.settings.defaultCreatorSaved":"Open Cloud default Creator saved locally.","assets.settings.creatorUnregistered":"Creator unregistered from this profile.","assets.settings.creatorUnregisterFailed":"Failed to unregister Creator.","assets.settings.saved":"Upload settings saved.","assets.settings.saveFailed":"Failed to save upload settings.","assets.settings.loadFailed":"Failed to load upload settings.","assets.settings.tested":"Connection tested.","assets.settings.testFailed":"Connection test failed.","assets.settings.removed":"API key unregistered.","assets.settings.removeFailed":"Failed to unregister API key.","assets.basic.notice":"Browse, preview, edit metadata, and scan usage on Basic. Roblox upload controls are available on Pro.","assets.proOnly.tooltip":"Roblox upload is available on Pro.","assets.proOnly.upload":"Roblox upload is available on Pro.","assets.empty.title":"No assets yet","assets.empty.body":"Choose a scope and category, then rescan that inbox folder.","assets.detail.title":"Asset details","assets.detail.displayName":"Display name","assets.detail.description":"Description","assets.detail.save":"Save metadata","assets.detail.refreshStatus":"Refresh","assets.detail.scanUsage":"Scan usage","assets.detail.localFile":"Local file","assets.detail.fileName":"File","assets.detail.category":"Category","assets.detail.scope":"Scope","assets.detail.mimeType":"Type","assets.detail.size":"Size","assets.detail.dimensions":"Dimensions","assets.detail.duration":"Duration","assets.detail.source":"Source path","assets.detail.sha256":"SHA-256","assets.detail.roblox":"Roblox upload status","assets.detail.status":"Status","assets.detail.assetId":"Asset ID","assets.detail.error":"Error","assets.detail.copyAssetId":"Copy Asset ID","assets.detail.copyUri":"Copy URI","assets.detail.studioUri":"Studio URI","assets.detail.robloxWebUrl":"Creator Dashboard URL","assets.detail.copyStudioUri":"Copy Studio URI","assets.detail.copyWebUrl":"Copy configure URL","assets.detail.openRobloxPage":"Open configure page","assets.detail.robloxWebUrlNotice":"Opening this page requires the Roblox account that owns or can manage the uploaded asset.","assets.detail.uploadHistory":"Upload history","assets.detail.usedInPlace":"Where this asset is used in this Place","assets.detail.noUsage":"No local Sync references found yet.","assets.detail.usageSource":"Checked against","assets.detail.usageSource.localSync":"Local Sync files","assets.detail.usageSource.notScanned":"Not checked yet","assets.detail.lastScanned":"Last checked","assets.detail.lastScannedAt":"Last checked: {time}","assets.detail.lastScanned.never":"No check yet","assets.detail.noUsageUnscanned":"Run Scan usage to search local Sync files for this Roblox Asset ID.","assets.detail.noUsageAfterScan":"No references were found in local Sync files during the last check.","assets.detail.noUsageNoRobloxId":"This asset does not have a Roblox Asset ID yet, so usage cannot be checked. Upload it before scanning usage.","assets.detail.technicalDetails":"Technical details","assets.detail.stableId":"Stable ID","assets.detail.sourceKind":"Source kind","assets.detail.createdAt":"Created","assets.detail.updatedAt":"Updated","assets.detail.operationId":"Operation ID","assets.detail.operationPath":"Operation path","assets.detail.versionId":"Version ID","assets.detail.remotePath":"Remote path","assets.detail.moderationState":"Moderation","assets.detail.line":"line {line}","assets.studio.notConnected":"Connect Roblox Studio before using Studio asset actions.","assets.detail.importRbxm":"Insert into Studio","assets.detail.importRbxm.tooltip":"Insert this local RBXM asset into {target} in the connected Studio place.","assets.detail.generateThumbnail":"Generate thumbnail","assets.detail.generateThumbnail.tooltip":"Create or replace the Asset Library thumbnail from Studio.","assets.detail.rbxmOnly":"Studio import is available for .rbxm assets.","assets.detail.rbxmCategoryOnly":"Studio .rbxm actions support models and animations.","assets.detail.thumbnailRbxmOnly":"Thumbnail generation is available for .rbxm model assets.","assets.detail.thumbnailModelOnly":"Thumbnail generation is available for model .rbxm assets.","assets.detail.rbxm":"RBXM contents","assets.detail.rbxmExportedCount":"Exported roots","assets.detail.rbxmClasses":"Classes","assets.detail.rbxmThumbnail":"Thumbnail","assets.detail.studioInsertTarget":"Studio insert target","assets.detail.rbxmRoots":"Root tree","assets.detail.rbxmReferences":"Asset references","assets.detail.rbxmThumbnailAttempts":"Thumbnail attempts","dashboardHelp.button":"Help","dashboardHelp.pageButton.ariaLabel":"Open page help","dashboardHelp.fieldButton.ariaLabel":"Open field help","dashboardHelp.section.canDo":"What you can do here","dashboardHelp.section.needs":"What you need to use it","dashboardHelp.section.links":"Related links","dashboardHelp.overview.title":"Overview help","dashboardHelp.overview.canDo.1":"Check MCP server, WEPPY Plugin, AI Agent, Sync, and recent game changes in one place.","dashboardHelp.overview.needs.1":"Useful status requires the MCP server. Live Studio status also needs WEPPY Plugin connected to the active place.","dashboardHelp.connection.title":"Connection help","dashboardHelp.connection.canDo.1":"Inspect server process details, connected AI agents, Studio plugin clients, and connection log events.","dashboardHelp.connection.needs.1":"The MCP server must be reachable. Plugin rows appear after Studio sends heartbeats.","dashboardHelp.sync.title":"Sync help","dashboardHelp.sync.canDo.1":"Review Studio to local sync status, direction, apply mode, and sync logs.","dashboardHelp.sync.needs.1":"Sync needs an active place and connected WEPPY Plugin. Two-way and reverse workflows depend on Pro.","dashboardHelp.assets.title":"Assets help","dashboardHelp.assets.canDo.1":"Browse local Asset Library files, switch place/shared scope, filter categories, scan usage, insert RBXM into Studio, and upload local assets to Roblox.","dashboardHelp.assets.needs.1":"Upload needs Pro, the Open Cloud upload toggle, a valid API Key, and a Creator. Browse and preview work on Basic.","dashboardHelp.changelog.title":"Changelog help","dashboardHelp.changelog.canDo.1":"Review real game-change sessions extracted from AI actions and sync events.","dashboardHelp.changelog.needs.1":"Entries are scoped to the active place. Basic shows only the latest preview entries.","dashboardHelp.playtest.title":"Playtest help","dashboardHelp.playtest.canDo.1":"Review Playtest results and reports saved by the AI Agent.","dashboardHelp.playtest.needs.1":"Pro shows real stored reports. Basic shows sample preview data. Live active-place confidence needs WEPPY Plugin connected.","dashboardHelp.uiStudio.title":"UI Studio help","dashboardHelp.uiStudio.canDo.1":"Review AI-created UI analysis, improvement suggestions, captures, and before/after history.","dashboardHelp.uiStudio.needs.1":"Pro shows real UI Studio data. Basic shows a bundled sample. New capture/check actions need WEPPY Plugin connected.","dashboardHelp.tools.title":"Tools help","dashboardHelp.tools.canDo.1":"Inspect tool history, status classification, fallback/unsupported/warn/error details, and usage statistics.","dashboardHelp.tools.needs.1":"History and statistics depend on local recording settings and the active place bucket.","dashboardHelp.settings.title":"Settings help","dashboardHelp.settings.canDo.1":"Manage License, hot settings, saved data cleanup, server environment display, and language.","dashboardHelp.settings.needs.1":"License actions need MCP server connection. Server environment values are read-only here. Asset upload controls live in Assets settings.","dashboardHelp.openCloudApiKey.title":"Open Cloud API Key help","dashboardHelp.openCloudApiKey.canDo.1":"WEPPY uses this key only for Roblox Open Cloud requests.","dashboardHelp.openCloudApiKey.needs.1":"Create a Roblox API key in Creator Hub. Add Assets under Access Permissions, then enable both Read and Write operations.","dashboardHelp.openCloudApiKey.needs.2":"Set the key target to the same User or Group that you use as the upload Creator.","dashboardHelp.openCloudApiKey.needs.3":"The raw key is encrypted on this device. It is not sent to WEPPY servers, and it is not stored in any other external storage, browser storage, telemetry, logs, tool history, or Asset Library metadata.","dashboardHelp.openCloudApiKey.link.apiKeys":"Roblox API keys","dashboardHelp.openCloudApiKey.link.assetsGuide":"Assets API usage guide","dashboardHelp.openCloudApiKey.link.assetsReference":"Assets API reference","dashboardHelp.openCloudCreatorId.title":"Creator ID help","dashboardHelp.openCloudCreatorId.canDo.1":"The default Creator decides which User or Group owns newly uploaded Roblox assets.","dashboardHelp.openCloudCreatorId.needs.1":"For User, sign in to roblox.com, open your profile from your avatar or username, then copy only the number between /users/ and /profile in the browser URL.","dashboardHelp.openCloudCreatorId.needs.2":"For Group, open the Roblox group or community page, then copy only the number after /groups/ or /communities/ in the browser URL.","dashboardHelp.openCloudCreatorId.needs.3":"Paste only the numeric ID in Creator ID. Do not paste the full URL, rbxassetid://, User, or Group text.","dashboardHelp.openCloudCreatorId.link.creatorId":"Creator ID reference","dashboardHelp.openCloudCreatorId.link.userId":"User ID reference","dashboardHelp.openCloudCreatorId.link.groups":"Roblox groups","dashboardHelp.openCloudCreatorId.link.groupsApi":"Groups Cloud API","assets.settings.apiKey.inlineHelp":"WEPPY uses this key only for Roblox Open Cloud requests. The key is encrypted on this device and is not sent to WEPPY servers or stored in any other external storage.","assets.settings.creatorId.inlineHelp":"Default owner for new Roblox assets: your User ID or a Group ID.","common.close":"Fermer","dashboardHelp.section.currentState":"Check based on current status","dashboardHelp.overview.currentState.serverOnly":"Open Roblox Studio and start WEPPY Plugin so live place data can appear.","dashboardHelp.overview.currentState.default":"If the server disconnects, restart MCP or wait for the automatic reconnect.","dashboardHelp.connection.currentState.1":"If Plugin is missing, open Roblox Studio and run WEPPY Plugin. If AI Agent is missing, reconnect the MCP server from your AI tool.","dashboardHelp.sync.currentState.pluginMissing":"Connect WEPPY Plugin in Studio before using live sync details.","dashboardHelp.sync.currentState.basic":"Activate Pro to use bidirectional or reverse sync.","dashboardHelp.sync.currentState.default":"Use the sync log to diagnose stuck or failed sync activity.","dashboardHelp.assets.currentState.basic":"Activate Pro before uploading to Roblox.","dashboardHelp.assets.currentState.uploadDisabled":"Turn on Open Cloud upload in Assets settings.","dashboardHelp.assets.currentState.noCredential":"Save and test an Open Cloud API Key.","dashboardHelp.assets.currentState.noCreator":"Save a default Creator ID or enter Creator details during upload.","dashboardHelp.assets.currentState.default":"Open an asset detail dialog to start upload or usage scan.","dashboardHelp.changelog.currentState.1":"If the list is empty, ask the AI Agent to make a game change. Clear only deletes saved history records, not Studio objects.","dashboardHelp.playtest.currentState.basic":"Activate Pro to use real Playtest history.","dashboardHelp.playtest.currentState.default":"Ask the AI Agent to run a Playtest when no report is available.","dashboardHelp.uiStudio.currentState.basic":"Activate Pro to use live UI Studio previews.","dashboardHelp.uiStudio.currentState.default":"Ask the AI Agent to capture the UI or recheck improvement suggestions, then copy follow-up requests back to the AI chat.","dashboardHelp.tools.currentState.1":"If no records appear, check Settings > General and confirm history/statistics are enabled. Expand failed rows to inspect input, permission, or connection causes.","dashboardHelp.settings.currentState.1":"Activate a license for Pro features. Change environment values outside WEPPY Dashboard, then restart MCP. Review delete confirmations before clearing saved data.","dashboardHelp.openCloudApiKey.currentState.saved":"Use Test Connection to confirm the saved key still works.","dashboardHelp.openCloudApiKey.currentState.empty":"Create an API key in Roblox Creator Hub, paste it here, then save and test it.","dashboardHelp.openCloudCreatorId.currentState.saved":"Keep this value if new assets should continue using the same owner.","dashboardHelp.openCloudCreatorId.currentState.empty":"Choose User or Group, paste the numeric ID, then save the default Creator.","page.overview.title":"Overview","page.overview.description":"Check server, plugin, agent, sync, and recent game-change status in one place.","page.connection.title":"Connection","page.connection.description":"Inspect MCP server, AI agent, Studio plugin, and connection log status.","page.sync.title":"Sync","page.sync.description":"Monitor Studio to local sync status, direction, apply mode, and recent sync logs.","page.changelog.title":"Changelog","page.changelog.description":"Review game-change sessions captured from AI actions and sync events.","page.playtest.title":"Playtest","page.playtest.description":"Review automated playtest runs, saved reports, and result history.","page.uiStudio.title":"UI Studio","page.uiStudio.description":"Review UI captures, improvement suggestions, and before/after change history.","page.tools.title":"Tools","page.tools.description":"Inspect tool history, outcomes, fallback details, and usage statistics.","page.settings.title":"Settings","page.settings.description":"Manage license, live settings, saved data, server environment, and language.","dashboardHelp.whatsNew.title":"What's New help","dashboardHelp.whatsNew.canDo.1":"Review WEPPY Dashboard, MCP, and Plugin announcements, releases, and change notes.","dashboardHelp.whatsNew.needs.1":"Announcements are bundled locally. Unread state is stored in this browser.","dashboardHelp.whatsNew.currentState.1":"After you visit this page, unread announcements from this visit are marked read when you leave. The top header does not show a duplicate What's New button on this page."},Xf=["en","ko","es","pt-br","ja","id","de","fr-fr"],Ua="auto",Rl={en:qf,ko:Wf,es:Ff,"pt-br":Kf,ja:Yf,id:Vf,de:Gf,"fr-fr":$f},In="dashboard-locale";function Ol(i){return Xf.includes(i)}function Qf(){const n=((typeof navigator<"u"?navigator.language:"en")??"en").toLowerCase();return n==="ko"||n.startsWith("ko-")?"ko":n==="pt-br"?"pt-br":n==="ja"||n.startsWith("ja-")?"ja":n==="es"||n.startsWith("es-")?"es":n==="id"||n.startsWith("id-")?"id":n==="de"||n.startsWith("de-")?"de":n==="fr"||n.startsWith("fr-")?"fr-fr":"en"}function Jc(){if(typeof localStorage<"u"){const i=localStorage.getItem(In);if(i===Ua)return Ua;if(i&&Ol(i))return i}return Ua}function ep(i){return i===Ua?Qf():i}const Up=A.createContext(null);function Zf({children:i}){const[n,r]=A.useState(Jc),[d,u]=A.useState(()=>ep(Jc())),p=A.useCallback((f,h)=>{const y=Rl[d]??Rl.en??{};if(f in y)return y[f];const C=Rl.en;return C&&f in C?C[f]:h!==void 0?h:f},[d]),g=A.useCallback(f=>{typeof localStorage<"u"&&(f===Ua?localStorage.removeItem(In):Ol(f)?localStorage.setItem(In,f):localStorage.setItem(In,"en"));const h=f===Ua?Ua:Ol(f)?f:"en";r(h),u(ep(h))},[]);return A.createElement(Up.Provider,{value:{locale:d,selectedLocale:n,t:p,setLocale:g}},i)}function yo(){const i=A.useContext(Up);if(!i)throw new Error("useLocale must be used within a LocaleProvider");return i}const Jf="_container_6jg7e_2",ey="_toast_6jg7e_14",ty="_slideIn_6jg7e_1",oy="_success_6jg7e_39",ay="_info_6jg7e_44",iy="_warning_6jg7e_49",sy="_error_6jg7e_54",Il={container:Jf,toast:ey,slideIn:ty,success:oy,info:ay,warning:iy,error:sy},zp=A.createContext(null),ny=3e3;function ry({children:i}){const[n,r]=A.useState([]),d=A.useRef(0),u=A.useCallback((p,g="info")=>{const f=d.current++;r(h=>[...h,{id:f,message:p,type:g}]),setTimeout(()=>{r(h=>h.filter(y=>y.id!==f))},ny)},[]);return x.jsxs(zp.Provider,{value:{show:u},children:[i,x.jsx("div",{className:Il.container,children:n.map(p=>x.jsx("div",{className:`${Il.toast} ${Il[p.type]}`,children:p.message},p.id))})]})}function Lp(){const i=A.useContext(zp);return i||{show:()=>{}}}function ly(){const{level:i}=Mn(),{show:n}=Lp(),{t:r}=yo(),d=A.useRef(null);return A.useEffect(()=>{const u=d.current;d.current=i,u!==null&&u!==i&&(u==="disconnected"&&i==="serverOnly"?n(r("toast.serverConnected","MCP 서버 연결됨"),"success"):u==="serverOnly"&&i==="studioConnected"?n(r("toast.pluginConnected","플러그인 연결됨"),"success"):(u==="serverOnly"||u==="studioConnected")&&i==="disconnected"?n(r("toast.serverDisconnected","MCP 서버 연결 끊김"),"error"):u==="studioConnected"&&i==="serverOnly"&&n(r("toast.pluginDisconnected","플러그인 연결 끊김"),"warning"))},[i,n,r]),null}const dy="_wrapper_x0nim_2",uy="_tooltip_x0nim_11",cy="_tooltipVisible_x0nim_30",Dl={wrapper:dy,tooltip:uy,tooltipVisible:cy},ui=8,An=6;function Ha({text:i,children:n}){const r=A.useRef(null),d=A.useRef(null),[u,p]=A.useState(!1),[g,f]=A.useState("top"),[h,y]=A.useState("center"),[C,b]=A.useState(null),D=i.trim(),H=A.useCallback(()=>{const ie=r.current,F=d.current;if(!ie||!F)return;const X=ie.getBoundingClientRect(),Y=F.getBoundingClientRect(),pe=window.innerWidth,De=window.innerHeight;let T="top";X.top-Y.height-An<ui&&X.bottom+Y.height+An<=De-ui&&(T="bottom");let G="center";const Se=X.left+X.width/2,re=Y.width/2;Se-re<ui?G="left":Se+re>pe-ui&&(G="right");const ze=T==="top"?X.top-Y.height-An:X.bottom+An;let Pe;G==="left"?Pe=X.left:G==="right"?Pe=X.right-Y.width:Pe=Se-re,Pe=Math.max(ui,Math.min(Pe,pe-Y.width-ui)),f(T),y(G),b({top:ze,left:Pe})},[]);if(A.useLayoutEffect(()=>{u&&H()},[u,H]),A.useEffect(()=>{if(!u)return;const ie=()=>H();return window.addEventListener("scroll",ie,!0),window.addEventListener("resize",ie),()=>{window.removeEventListener("scroll",ie,!0),window.removeEventListener("resize",ie)}},[u,H]),!D)return x.jsx(x.Fragment,{children:n});const O=()=>p(!0),z=()=>p(!1),N=x.jsx("span",{ref:d,className:[Dl.tooltip,u?Dl.tooltipVisible:""].filter(Boolean).join(" "),"data-placement":h,"data-vertical":g,style:C?{top:C.top,left:C.left}:{top:-9999,left:-9999,visibility:"hidden"},children:D});return x.jsxs(x.Fragment,{children:[x.jsx("span",{ref:r,className:Dl.wrapper,title:D,onMouseEnter:O,onMouseLeave:z,onFocus:O,onBlur:z,children:n}),typeof document<"u"?Un.createPortal(N,document.body):null]})}function py(i){return i==="auto"||i==="polar"||i==="gumroad"?i:void 0}function gy(i){if(!i||typeof i!="object")return!1;const n=i.status;return(i.tier==="basic"||i.tier==="pro")&&(n==="active"||n==="grace"||n==="invalid"||n==="revoked"||n==="unlicensed"||n==="unknown")}function Mp(i){return i&&typeof i=="object"&&"data"in i&&i.data?i.data:i}function _p(i){if(!i||typeof i!="object")return null;if(gy(i))return i;const n=i;if(typeof n.canUsePro!="boolean"||typeof n.status!="string"||n.status!=="active"&&n.status!=="grace"&&n.status!=="invalid"&&n.status!=="revoked"&&n.status!=="unlicensed"&&n.status!=="unknown")return null;const r=py(n.provider);return{tier:n.canUsePro?"pro":"basic",status:n.status,...typeof n.statusDetail=="string"?{statusDetail:n.statusDetail}:{},...typeof n.maskedKey=="string"?{maskedKey:n.maskedKey}:{},...r?{provider:r}:{},refreshRequired:n.refreshRequired===!0,...typeof n.refreshBlockedReason=="string"?{refreshBlockedReason:n.refreshBlockedReason}:{}}}async function Np(i="auto"){const n=await zt.get("/api/dashboard/license/status",{provider:i});return _p(Mp(n))}function Ql(i){const n=Mp(i),r=n,d=_p(n),u=typeof(r==null?void 0:r.reasonCode)=="string"?r.reasonCode:void 0;return{ok:(r==null?void 0:r.ok)===!0,license:d?{...d,refreshRequired:d.refreshRequired||u==="missing_session_token",refreshBlockedReason:d.refreshBlockedReason??(u==="missing_session_token"?"missing_session_token":void 0)}:null,message:typeof(r==null?void 0:r.message)=="string"?r.message:null,reasonCode:u,recoverable:(r==null?void 0:r.recoverable)===!0}}async function Tb(i){const n=i.provider??"auto",r=await zt.post("/api/dashboard/license/activate",{provider:n,licenseKey:i.licenseKey,clientType:"dashboard"});return Ql(r)}async function jb(i={}){const n=i.provider??"auto",r=await zt.post("/api/dashboard/license/refresh",{provider:n,clientType:"dashboard"});return Ql(r)}async function Hb(i={}){const n=i.provider??"auto",r=await zt.post("/api/dashboard/license/reset",{provider:n,clientType:"dashboard"});return Ql(r)}class Op{constructor(n){Eo(this,"source",null);Eo(this,"handlers",new Map);Eo(this,"reconnectTimer",null);Eo(this,"url");this.url=n??`${Ln}/api/dashboard/events`}connect(){this.disconnect(),this.source=new EventSource(this.url),this.source.onopen=()=>{this.reconnectTimer&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=null)},this.source.onerror=()=>{var r;(r=this.source)==null||r.close(),this.source=null,this.scheduleReconnect()};const n=["connection","sync","command","game_change","mcp_status","license"];for(const r of n)this.source.addEventListener(r,d=>{var p;const u=JSON.parse(d.data);(p=this.handlers.get(r))==null||p.forEach(g=>g(u))})}on(n,r){return this.handlers.has(n)||this.handlers.set(n,new Set),this.handlers.get(n).add(r),()=>{var d;return(d=this.handlers.get(n))==null?void 0:d.delete(r)}}disconnect(){var n;(n=this.source)==null||n.close(),this.source=null,this.reconnectTimer&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=null)}get connected(){var n;return((n=this.source)==null?void 0:n.readyState)===EventSource.OPEN}scheduleReconnect(){this.reconnectTimer||(this.reconnectTimer=setTimeout(()=>{this.reconnectTimer=null,this.connect()},Uf))}}/**
150
+ * @license lucide-react v1.8.0 - ISC
151
+ *
152
+ * This source code is licensed under the ISC license.
153
+ * See the LICENSE file in the root directory of this source tree.
154
+ */const Bp=(...i)=>i.filter((n,r,d)=>!!n&&n.trim()!==""&&d.indexOf(n)===r).join(" ").trim();/**
155
+ * @license lucide-react v1.8.0 - ISC
156
+ *
157
+ * This source code is licensed under the ISC license.
158
+ * See the LICENSE file in the root directory of this source tree.
159
+ */const hy=i=>i.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase();/**
160
+ * @license lucide-react v1.8.0 - ISC
161
+ *
162
+ * This source code is licensed under the ISC license.
163
+ * See the LICENSE file in the root directory of this source tree.
164
+ */const my=i=>i.replace(/^([A-Z])|[\s-_]+(\w)/g,(n,r,d)=>d?d.toUpperCase():r.toLowerCase());/**
165
+ * @license lucide-react v1.8.0 - ISC
166
+ *
167
+ * This source code is licensed under the ISC license.
168
+ * See the LICENSE file in the root directory of this source tree.
169
+ */const tp=i=>{const n=my(i);return n.charAt(0).toUpperCase()+n.slice(1)};/**
170
+ * @license lucide-react v1.8.0 - ISC
171
+ *
172
+ * This source code is licensed under the ISC license.
173
+ * See the LICENSE file in the root directory of this source tree.
174
+ */var El={xmlns:"http://www.w3.org/2000/svg",width:24,height:24,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeLinejoin:"round"};/**
175
+ * @license lucide-react v1.8.0 - ISC
176
+ *
177
+ * This source code is licensed under the ISC license.
178
+ * See the LICENSE file in the root directory of this source tree.
179
+ */const fy=i=>{for(const n in i)if(n.startsWith("aria-")||n==="role"||n==="title")return!0;return!1},yy=A.createContext({}),vy=()=>A.useContext(yy),Sy=A.forwardRef(({color:i,size:n,strokeWidth:r,absoluteStrokeWidth:d,className:u="",children:p,iconNode:g,...f},h)=>{const{size:y=24,strokeWidth:C=2,absoluteStrokeWidth:b=!1,color:D="currentColor",className:H=""}=vy()??{},O=d??b?Number(r??C)*24/Number(n??y):r??C;return A.createElement("svg",{ref:h,...El,width:n??y??El.width,height:n??y??El.height,stroke:i??D,strokeWidth:O,className:Bp("lucide",H,u),...!p&&!fy(f)&&{"aria-hidden":"true"},...f},[...g.map(([z,N])=>A.createElement(z,N)),...Array.isArray(p)?p:[p]])});/**
180
+ * @license lucide-react v1.8.0 - ISC
181
+ *
182
+ * This source code is licensed under the ISC license.
183
+ * See the LICENSE file in the root directory of this source tree.
184
+ */const Xe=(i,n)=>{const r=A.forwardRef(({className:d,...u},p)=>A.createElement(Sy,{ref:p,iconNode:n,className:Bp(`lucide-${hy(tp(i))}`,`lucide-${i}`,d),...u}));return r.displayName=tp(i),r};/**
185
+ * @license lucide-react v1.8.0 - ISC
186
+ *
187
+ * This source code is licensed under the ISC license.
188
+ * See the LICENSE file in the root directory of this source tree.
189
+ */const by=[["path",{d:"M10.268 21a2 2 0 0 0 3.464 0",key:"vwvbt9"}],["path",{d:"M3.262 15.326A1 1 0 0 0 4 17h16a1 1 0 0 0 .74-1.673C19.41 13.956 18 12.499 18 8A6 6 0 0 0 6 8c0 4.499-1.411 5.956-2.738 7.326",key:"11g9vi"}]],Py=Xe("bell",by);/**
190
+ * @license lucide-react v1.8.0 - ISC
191
+ *
192
+ * This source code is licensed under the ISC license.
193
+ * See the LICENSE file in the root directory of this source tree.
194
+ */const Cy=[["path",{d:"M12 7v14",key:"1akyts"}],["path",{d:"M3 18a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h5a4 4 0 0 1 4 4 4 4 0 0 1 4-4h5a1 1 0 0 1 1 1v13a1 1 0 0 1-1 1h-6a3 3 0 0 0-3 3 3 3 0 0 0-3-3z",key:"ruj8y"}]],wy=Xe("book-open",Cy);/**
195
+ * @license lucide-react v1.8.0 - ISC
196
+ *
197
+ * This source code is licensed under the ISC license.
198
+ * See the LICENSE file in the root directory of this source tree.
199
+ */const ky=[["path",{d:"M12 20v-9",key:"1qisl0"}],["path",{d:"M14 7a4 4 0 0 1 4 4v3a6 6 0 0 1-12 0v-3a4 4 0 0 1 4-4z",key:"uouzyp"}],["path",{d:"M14.12 3.88 16 2",key:"qol33r"}],["path",{d:"M21 21a4 4 0 0 0-3.81-4",key:"1b0z45"}],["path",{d:"M21 5a4 4 0 0 1-3.55 3.97",key:"5cxbf6"}],["path",{d:"M22 13h-4",key:"1jl80f"}],["path",{d:"M3 21a4 4 0 0 1 3.81-4",key:"1fjd4g"}],["path",{d:"M3 5a4 4 0 0 0 3.55 3.97",key:"1d7oge"}],["path",{d:"M6 13H2",key:"82j7cp"}],["path",{d:"m8 2 1.88 1.88",key:"fmnt4t"}],["path",{d:"M9 7.13V6a3 3 0 1 1 6 0v1.13",key:"1vgav8"}]],xy=Xe("bug",ky);/**
200
+ * @license lucide-react v1.8.0 - ISC
201
+ *
202
+ * This source code is licensed under the ISC license.
203
+ * See the LICENSE file in the root directory of this source tree.
204
+ */const Ay=[["path",{d:"M2.7 10.3a2.41 2.41 0 0 0 0 3.41l7.59 7.59a2.41 2.41 0 0 0 3.41 0l7.59-7.59a2.41 2.41 0 0 0 0-3.41l-7.59-7.59a2.41 2.41 0 0 0-3.41 0Z",key:"1f1r0c"}]],Ry=Xe("diamond",Ay);/**
205
+ * @license lucide-react v1.8.0 - ISC
206
+ *
207
+ * This source code is licensed under the ISC license.
208
+ * See the LICENSE file in the root directory of this source tree.
209
+ */const Iy=[["path",{d:"M12 15V3",key:"m9g1x1"}],["path",{d:"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4",key:"ih7n3h"}],["path",{d:"m7 10 5 5 5-5",key:"brsn70"}]],Dy=Xe("download",Iy);/**
210
+ * @license lucide-react v1.8.0 - ISC
211
+ *
212
+ * This source code is licensed under the ISC license.
213
+ * See the LICENSE file in the root directory of this source tree.
214
+ */const Ey=[["path",{d:"M15 3h6v6",key:"1q9fwt"}],["path",{d:"M10 14 21 3",key:"gplh6r"}],["path",{d:"M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6",key:"a6xqqp"}]],qp=Xe("external-link",Ey);/**
215
+ * @license lucide-react v1.8.0 - ISC
216
+ *
217
+ * This source code is licensed under the ISC license.
218
+ * See the LICENSE file in the root directory of this source tree.
219
+ */const Ty=[["path",{d:"M13.659 22H18a2 2 0 0 0 2-2V8a2.4 2.4 0 0 0-.706-1.706l-3.588-3.588A2.4 2.4 0 0 0 14 2H6a2 2 0 0 0-2 2v11.5",key:"4pqfef"}],["path",{d:"M14 2v5a1 1 0 0 0 1 1h5",key:"wfsgrz"}],["path",{d:"M8 12v-1",key:"1ej8lb"}],["path",{d:"M8 18v-2",key:"qcmpov"}],["path",{d:"M8 7V6",key:"1nbb54"}],["circle",{cx:"8",cy:"20",r:"2",key:"ckkr5m"}]],jy=Xe("file-archive",Ty);/**
220
+ * @license lucide-react v1.8.0 - ISC
221
+ *
222
+ * This source code is licensed under the ISC license.
223
+ * See the LICENSE file in the root directory of this source tree.
224
+ */const Hy=[["path",{d:"m6 14 1.5-2.9A2 2 0 0 1 9.24 10H20a2 2 0 0 1 1.94 2.5l-1.54 6a2 2 0 0 1-1.95 1.5H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h3.9a2 2 0 0 1 1.69.9l.81 1.2a2 2 0 0 0 1.67.9H18a2 2 0 0 1 2 2v2",key:"usdka0"}]],op=Xe("folder-open",Hy);/**
225
+ * @license lucide-react v1.8.0 - ISC
226
+ *
227
+ * This source code is licensed under the ISC license.
228
+ * See the LICENSE file in the root directory of this source tree.
229
+ */const Uy=[["path",{d:"M20 20a2 2 0 0 0 2-2V8a2 2 0 0 0-2-2h-7.9a2 2 0 0 1-1.69-.9L9.6 3.9A2 2 0 0 0 7.93 3H4a2 2 0 0 0-2 2v13a2 2 0 0 0 2 2Z",key:"1kt360"}]],zy=Xe("folder",Uy);/**
230
+ * @license lucide-react v1.8.0 - ISC
231
+ *
232
+ * This source code is licensed under the ISC license.
233
+ * See the LICENSE file in the root directory of this source tree.
234
+ */const Ly=[["line",{x1:"6",x2:"10",y1:"11",y2:"11",key:"1gktln"}],["line",{x1:"8",x2:"8",y1:"9",y2:"13",key:"qnk9ow"}],["line",{x1:"15",x2:"15.01",y1:"12",y2:"12",key:"krot7o"}],["line",{x1:"18",x2:"18.01",y1:"10",y2:"10",key:"1lcuu1"}],["path",{d:"M17.32 5H6.68a4 4 0 0 0-3.978 3.59c-.006.052-.01.101-.017.152C2.604 9.416 2 14.456 2 16a3 3 0 0 0 3 3c1 0 1.5-.5 2-1l1.414-1.414A2 2 0 0 1 9.828 16h4.344a2 2 0 0 1 1.414.586L17 18c.5.5 1 1 2 1a3 3 0 0 0 3-3c0-1.545-.604-6.584-.685-7.258-.007-.05-.011-.1-.017-.151A4 4 0 0 0 17.32 5z",key:"mfqc10"}]],My=Xe("gamepad-2",Ly);/**
235
+ * @license lucide-react v1.8.0 - ISC
236
+ *
237
+ * This source code is licensed under the ISC license.
238
+ * See the LICENSE file in the root directory of this source tree.
239
+ */const _y=[["path",{d:"M3 12a9 9 0 1 0 9-9 9.75 9.75 0 0 0-6.74 2.74L3 8",key:"1357e3"}],["path",{d:"M3 3v5h5",key:"1xhq8a"}],["path",{d:"M12 7v5l4 2",key:"1fdv2h"}]],Ny=Xe("history",_y);/**
240
+ * @license lucide-react v1.8.0 - ISC
241
+ *
242
+ * This source code is licensed under the ISC license.
243
+ * See the LICENSE file in the root directory of this source tree.
244
+ */const Oy=[["rect",{width:"18",height:"18",x:"3",y:"3",rx:"2",ry:"2",key:"1m3agn"}],["circle",{cx:"9",cy:"9",r:"2",key:"af1f0g"}],["path",{d:"m21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21",key:"1xmnt7"}]],By=Xe("image",Oy);/**
245
+ * @license lucide-react v1.8.0 - ISC
246
+ *
247
+ * This source code is licensed under the ISC license.
248
+ * See the LICENSE file in the root directory of this source tree.
249
+ */const qy=[["path",{d:"M2.586 17.414A2 2 0 0 0 2 18.828V21a1 1 0 0 0 1 1h3a1 1 0 0 0 1-1v-1a1 1 0 0 1 1-1h1a1 1 0 0 0 1-1v-1a1 1 0 0 1 1-1h.172a2 2 0 0 0 1.414-.586l.814-.814a6.5 6.5 0 1 0-4-4z",key:"1s6t7t"}],["circle",{cx:"16.5",cy:"7.5",r:".5",fill:"currentColor",key:"w0ekpg"}]],ap=Xe("key-round",qy);/**
250
+ * @license lucide-react v1.8.0 - ISC
251
+ *
252
+ * This source code is licensed under the ISC license.
253
+ * See the LICENSE file in the root directory of this source tree.
254
+ */const Wy=[["rect",{width:"7",height:"9",x:"3",y:"3",rx:"1",key:"10lvy0"}],["rect",{width:"7",height:"5",x:"14",y:"3",rx:"1",key:"16une8"}],["rect",{width:"7",height:"9",x:"14",y:"12",rx:"1",key:"1hutg5"}],["rect",{width:"7",height:"5",x:"3",y:"16",rx:"1",key:"ldoo1y"}]],Fy=Xe("layout-dashboard",Wy);/**
255
+ * @license lucide-react v1.8.0 - ISC
256
+ *
257
+ * This source code is licensed under the ISC license.
258
+ * See the LICENSE file in the root directory of this source tree.
259
+ */const Ky=[["path",{d:"M15 14c.2-1 .7-1.7 1.5-2.5 1-.9 1.5-2.2 1.5-3.5A6 6 0 0 0 6 8c0 1 .2 2.2 1.5 3.5.7.7 1.3 1.5 1.5 2.5",key:"1gvzjb"}],["path",{d:"M9 18h6",key:"x1upvd"}],["path",{d:"M10 22h4",key:"ceow96"}]],Yy=Xe("lightbulb",Ky);/**
260
+ * @license lucide-react v1.8.0 - ISC
261
+ *
262
+ * This source code is licensed under the ISC license.
263
+ * See the LICENSE file in the root directory of this source tree.
264
+ */const Vy=[["path",{d:"M21 12a9 9 0 1 1-6.219-8.56",key:"13zald"}]],Gy=Xe("loader-circle",Vy);/**
265
+ * @license lucide-react v1.8.0 - ISC
266
+ *
267
+ * This source code is licensed under the ISC license.
268
+ * See the LICENSE file in the root directory of this source tree.
269
+ */const $y=[["path",{d:"M16 10a2 2 0 0 1-2 2H6.828a2 2 0 0 0-1.414.586l-2.202 2.202A.71.71 0 0 1 2 14.286V4a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2z",key:"1n2ejm"}],["path",{d:"M20 9a2 2 0 0 1 2 2v10.286a.71.71 0 0 1-1.212.502l-2.202-2.202A2 2 0 0 0 17.172 19H10a2 2 0 0 1-2-2v-1",key:"1qfcsi"}]],Xy=Xe("messages-square",$y);/**
270
+ * @license lucide-react v1.8.0 - ISC
271
+ *
272
+ * This source code is licensed under the ISC license.
273
+ * See the LICENSE file in the root directory of this source tree.
274
+ */const Qy=[["path",{d:"M11 21.73a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73z",key:"1a0edw"}],["path",{d:"M12 22V12",key:"d0xqtd"}],["polyline",{points:"3.29 7 12 12 20.71 7",key:"ousv84"}],["path",{d:"m7.5 4.27 9 5.15",key:"1c824w"}]],Zy=Xe("package",Qy);/**
275
+ * @license lucide-react v1.8.0 - ISC
276
+ *
277
+ * This source code is licensed under the ISC license.
278
+ * See the LICENSE file in the root directory of this source tree.
279
+ */const Jy=[["path",{d:"M12 22v-5",key:"1ega77"}],["path",{d:"M15 8V2",key:"18g5xt"}],["path",{d:"M17 8a1 1 0 0 1 1 1v4a4 4 0 0 1-4 4h-4a4 4 0 0 1-4-4V9a1 1 0 0 1 1-1z",key:"1xoxul"}],["path",{d:"M9 8V2",key:"14iosj"}]],ev=Xe("plug",Jy);/**
280
+ * @license lucide-react v1.8.0 - ISC
281
+ *
282
+ * This source code is licensed under the ISC license.
283
+ * See the LICENSE file in the root directory of this source tree.
284
+ */const tv=[["path",{d:"M3 12a9 9 0 0 1 9-9 9.75 9.75 0 0 1 6.74 2.74L21 8",key:"v9h5vc"}],["path",{d:"M21 3v5h-5",key:"1q7to0"}],["path",{d:"M21 12a9 9 0 0 1-9 9 9.75 9.75 0 0 1-6.74-2.74L3 16",key:"3uifl3"}],["path",{d:"M8 16H3v5",key:"1cv678"}]],Wp=Xe("refresh-cw",tv);/**
285
+ * @license lucide-react v1.8.0 - ISC
286
+ *
287
+ * This source code is licensed under the ISC license.
288
+ * See the LICENSE file in the root directory of this source tree.
289
+ */const ov=[["path",{d:"M9.671 4.136a2.34 2.34 0 0 1 4.659 0 2.34 2.34 0 0 0 3.319 1.915 2.34 2.34 0 0 1 2.33 4.033 2.34 2.34 0 0 0 0 3.831 2.34 2.34 0 0 1-2.33 4.033 2.34 2.34 0 0 0-3.319 1.915 2.34 2.34 0 0 1-4.659 0 2.34 2.34 0 0 0-3.32-1.915 2.34 2.34 0 0 1-2.33-4.033 2.34 2.34 0 0 0 0-3.831A2.34 2.34 0 0 1 6.35 6.051a2.34 2.34 0 0 0 3.319-1.915",key:"1i5ecw"}],["circle",{cx:"12",cy:"12",r:"3",key:"1v7zrd"}]],av=Xe("settings",ov);/**
290
+ * @license lucide-react v1.8.0 - ISC
291
+ *
292
+ * This source code is licensed under the ISC license.
293
+ * See the LICENSE file in the root directory of this source tree.
294
+ */const iv=[["path",{d:"M11.017 2.814a1 1 0 0 1 1.966 0l1.051 5.558a2 2 0 0 0 1.594 1.594l5.558 1.051a1 1 0 0 1 0 1.966l-5.558 1.051a2 2 0 0 0-1.594 1.594l-1.051 5.558a1 1 0 0 1-1.966 0l-1.051-5.558a2 2 0 0 0-1.594-1.594l-5.558-1.051a1 1 0 0 1 0-1.966l5.558-1.051a2 2 0 0 0 1.594-1.594z",key:"1s2grr"}],["path",{d:"M20 2v4",key:"1rf3ol"}],["path",{d:"M22 4h-4",key:"gwowj6"}],["circle",{cx:"4",cy:"20",r:"2",key:"6kqj1y"}]],ip=Xe("sparkles",iv);/**
295
+ * @license lucide-react v1.8.0 - ISC
296
+ *
297
+ * This source code is licensed under the ISC license.
298
+ * See the LICENSE file in the root directory of this source tree.
299
+ */const sv=[["path",{d:"M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.106-3.105c.32-.322.863-.22.983.218a6 6 0 0 1-8.259 7.057l-7.91 7.91a1 1 0 0 1-2.999-3l7.91-7.91a6 6 0 0 1 7.057-8.259c.438.12.54.662.219.984z",key:"1ngwbx"}]],nv=Xe("wrench",sv);/**
300
+ * @license lucide-react v1.8.0 - ISC
301
+ *
302
+ * This source code is licensed under the ISC license.
303
+ * See the LICENSE file in the root directory of this source tree.
304
+ */const rv=[["path",{d:"M18 6 6 18",key:"1bl5f8"}],["path",{d:"m6 6 12 12",key:"d8bk6v"}]],lv=Xe("x",rv),Fp=[{labelKey:"sidebar.overview",route:"/",icon:Fy,minLevel:"disconnected",lazy:()=>io(()=>import("./OverviewPage-B6ZL_JXU.js"),__vite__mapDeps([0,1,2,3,4,5,6,7,8,9,10]))},{labelKey:"sidebar.connection",route:"/connection",icon:ev,minLevel:"disconnected",lazy:()=>io(()=>import("./ConnectionPage-zGBwRnwi.js"),__vite__mapDeps([11,1,2,3,4,5,6,12,9,13]))},{labelKey:"sidebar.sync",route:"/sync",icon:Wp,minLevel:"serverOnly",lazy:()=>io(()=>import("./SyncPage-cfQ-4IDk.js"),__vite__mapDeps([14,2,3,1,6,12,4,5,15]))},{labelKey:"sidebar.assets",route:"/assets",icon:Zy,minLevel:"serverOnly",lazy:()=>io(()=>import("./AssetsPage-yddSUaZg.js"),__vite__mapDeps([16,12,2,3,6,17]))},{labelKey:"sidebar.changelog",route:"/changelog",icon:Ny,minLevel:"serverOnly",lazy:()=>io(()=>import("./ChangelogPage-oIxW8_VE.js"),__vite__mapDeps([18,2,3,12,6,19,20,21]))},{labelKey:"sidebar.playtest",route:"/playtest",icon:My,minLevel:"serverOnly",lazy:()=>io(()=>import("./PlaytestPage-CQqE8m04.js"),__vite__mapDeps([22,2,3,1,6,12,23]))},{labelKey:"sidebar.ui_studio",route:"/ui-studio",icon:By,minLevel:"serverOnly",lazy:()=>io(()=>import("./UiStudioPage-CwURRVO9.js"),__vite__mapDeps([24,1,6,25,26,19,20,2,3,27]))},{labelKey:"sidebar.tools",route:"/tools",icon:nv,minLevel:"serverOnly",lazy:()=>io(()=>import("./ToolsPage-B004HHzX.js"),__vite__mapDeps([28,2,3,6,12,19,20,29]))}],Kp=[{labelKey:"sidebar.whatsNew",route:"/whats-new",icon:Py,minLevel:"disconnected",lazy:()=>io(()=>import("./WhatsNewPage-CBUk7WTn.js"),__vite__mapDeps([30,2,3,31]))}],Tl="https://github.com/hope1026/weppy-roblox-mcp",dv="https://weppyai.com";function Bl(i){return i?/Mac OS X|Macintosh/i.test(i)?"macOS":/Windows NT/i.test(i)?"Windows":/Linux/i.test(i)?"Linux":"":""}function uv(i){var C,b,D,H,O;const n=Bl(typeof navigator<"u"?navigator.userAgent:""),r=i.status,d=(r==null?void 0:r.version)??"",u=((b=(C=r==null?void 0:r.pluginClients)==null?void 0:C[0])==null?void 0:b.pluginVersion)??"",p=((H=(D=r==null?void 0:r.pluginClients)==null?void 0:D[0])==null?void 0:H.studioVersion)??"",g=d||u||p?[d?`MCP ${d}`:"",u?`Plugin ${u}`:"",p?`Studio ${p}`:""].filter(Boolean).join(" / "):"",f=((O=r==null?void 0:r.aiClientNames)==null?void 0:O[0])??"",h=(r==null?void 0:r.nodeVersion)??"",y=new URLSearchParams;return y.set("template","bug_report.yml"),n&&y.set("os",n),h&&y.set("node",h),f&&y.set("ai-client",f),g&&y.set("plugin-version",g),y.toString()}const cv=[{id:"bug",labelKey:"sidebar.help.bug",tooltipKey:"sidebar.help.bug.tooltip",icon:xy,buildUrl:i=>`${Tl}/issues/new?${uv(i)}`},{id:"feature",labelKey:"sidebar.help.feature",tooltipKey:"sidebar.help.feature.tooltip",icon:Yy,buildUrl:()=>`${Tl}/issues/new?template=feature_request.yml`},{id:"discussions",labelKey:"sidebar.help.discussions",tooltipKey:"sidebar.help.discussions.tooltip",icon:Xy,buildUrl:()=>`${Tl}/issues/new?template=install_help.yml`},{id:"troubleshooting",labelKey:"sidebar.help.troubleshooting",tooltipKey:"sidebar.help.troubleshooting.tooltip",icon:wy,buildUrl:i=>`${dv}/${i.locale}/docs/troubleshooting/`}];function pv(){const[i,n]=A.useState("basic"),[r,d]=A.useState(0),[u,p]=A.useState(0),[g,f]=A.useState(0),[h,y]=A.useState(!0);A.useEffect(()=>{let b=!1;async function D(){try{return await Np("auto")}catch{return null}}async function H(){var N,ie;try{const[F,X]=await Promise.all([D(),zt.get("/api/dashboard/tool-stats").catch(()=>null)]);if(b)return;if(F!=null&&F.tier&&n(F.tier),X!=null&&X.tierSummary){const Y=((N=X.tierSummary.basic)==null?void 0:N.totalCalls)??0,pe=((ie=X.tierSummary.pro)==null?void 0:ie.totalCalls)??0;f(Y),p(pe),d(Y+pe)}}catch{}finally{b||y(!1)}}H();const O=new Op;O.connect();const z=O.on("license",()=>{D().then(N=>{!b&&(N!=null&&N.tier)&&n(N.tier)})});return()=>{b=!0,z(),O.disconnect()}},[]);const C=r>0?u/r*100:0;return{tier:i,proUsagePercent:C,totalCalls:r,proCalls:u,basicCalls:g,loading:h}}const gv="https://weppyai.com/plans/";function Da(i){const n=new URLSearchParams({utm_source:"weppy_dashboard",utm_medium:"app",utm_campaign:"pro_upgrade",utm_content:i});return`${gv}?${n.toString()}`}const hv={sidebarUpgrade:Da("sidebar_upgrade"),settingsLicense:Da("settings_license"),sync:Da("sync_tier_panel"),changelog:Da("changelog_limit_notice"),playtest:Da("playtest_sample_banner"),uiStudioAnalysis:Da("ui_studio_analysis_banner"),uiStudioHistory:Da("ui_studio_history_banner")},mv=5e3,fv=5;function yv(i){return i.replace(/^\//,"").split("/")[0]||"overview"}function vv(i,n){const r=new URLSearchParams(n);if(i==="ui-studio")return r.get("tab")==="history"?"ui_studio_history":"ui_studio_analysis";if(i==="tools")return"tools_history";if(i==="changelog")return"changelog_all"}function cs(i,n){const r=yv(i);if(n===void 0)return r;const d=vv(r,n);return d?{page:r,tab:d}:{page:r}}let gi=[],sp=null;function Yp(){if(gi.length===0)return;const i=gi.splice(0),n=`${Ln}/api/dashboard/analytics`,r=JSON.stringify({events:i});fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:r}).catch(()=>{})}function Sv(){sp||(sp=setInterval(Yp,mv))}function np(i){gi.push(i),Sv(),gi.length>=fv&&Yp()}typeof window<"u"&&window.addEventListener("beforeunload",()=>{if(gi.length===0)return;const i=`${Ln}/api/dashboard/analytics`,n=JSON.stringify({events:gi.splice(0)});navigator.sendBeacon(i,new Blob([n],{type:"application/json"}))});function ps(){const i=A.useCallback((r,d)=>{np({name:r,params:d})},[]),n=A.useCallback(r=>{np({name:"dashboard_page_view",params:{...typeof r=="string"?{page:r}:r}})},[]);return{trackEvent:i,trackPageView:n}}const bv="_widget_1q1ab_1",Pv="_header_1q1ab_12",Cv="_sparkle_1q1ab_18",wv="_title_1q1ab_23",kv="_actions_1q1ab_31",xv="_cta_1q1ab_37",Av="_licenseCta_1q1ab_38",Rv="_collapsedGroup_1q1ab_70",Iv="_collapsed_1q1ab_70",Dv="_collapsedSecondary_1q1ab_91",ao={widget:bv,header:Pv,sparkle:Cv,title:wv,actions:kv,cta:xv,licenseCta:Av,collapsedGroup:Rv,collapsed:Iv,collapsedSecondary:Dv};function Ev({collapsed:i=!1}){const{tier:n}=pv(),{t:r}=yo(),{trackEvent:d}=ps(),{pathname:u,search:p}=no();if(n==="pro")return null;const g=hv.sidebarUpgrade,f="/settings?section=license",h=cs(u,p),y=()=>{d("dashboard_click_event",{click_target:"upgrade_cta",placement:"sidebar_upgrade",...h})},C=()=>{d("dashboard_click_event",{click_target:"license_shortcut",placement:"sidebar_license",...h})};return i?x.jsxs("div",{className:ao.collapsedGroup,children:[x.jsx("a",{href:g,target:"_blank",rel:"noopener noreferrer",className:ao.collapsed,title:r("upgrade.title","View Pro"),"aria-label":r("upgrade.title","View Pro"),onClick:y,children:x.jsx(ip,{size:18,strokeWidth:1.75})}),x.jsx(ls,{to:f,className:`${ao.collapsed} ${ao.collapsedSecondary}`,title:r("upgrade.licenseShortcut","Enter License"),"aria-label":r("upgrade.licenseShortcut","Enter License"),onClick:C,children:x.jsx(ap,{size:18,strokeWidth:1.75})})]}):x.jsxs("div",{className:ao.widget,children:[x.jsxs("div",{className:ao.header,children:[x.jsx(ip,{size:16,strokeWidth:1.75,className:ao.sparkle}),x.jsx("span",{className:ao.title,children:r("upgrade.tagline","Check Pro features")})]}),x.jsxs("div",{className:ao.actions,children:[x.jsxs("a",{href:g,target:"_blank",rel:"noopener noreferrer",className:ao.cta,onClick:y,children:[r("upgrade.cta","View Pro")," →"]}),x.jsxs(ls,{to:f,className:ao.licenseCta,onClick:C,children:[x.jsx(ap,{size:14,strokeWidth:1.75,"aria-hidden":"true",focusable:"false"}),x.jsx("span",{children:r("upgrade.licenseShortcut","Enter License")})]})]})]})}const Tv="_backdrop_1r5ey_1",jv="_dialog_1r5ey_11",Hv="_header_1r5ey_21",Uv="_titleBlock_1r5ey_30",zv="_title_1r5ey_30",Lv="_subtitle_1r5ey_42",Mv="_closeButton_1r5ey_49",_v="_body_1r5ey_67",Nv="_statusBox_1r5ey_73",Ov="_errorBox_1r5ey_74",Bv="_spin_1r5ey_92",qv="_bundleBlock_1r5ey_102",Wv="_label_1r5ey_107",Fv="_bundleName_1r5ey_115",Kv="_guidanceBox_1r5ey_127",Yv="_includedList_1r5ey_143",Vv="_includedItem_1r5ey_152",Gv="_actions_1r5ey_163",$v="_button_1r5ey_169",Xv="_primaryLink_1r5ey_170",Qv="_hint_1r5ey_206",We={backdrop:Tv,dialog:jv,header:Hv,titleBlock:Uv,title:zv,subtitle:Lv,closeButton:Mv,body:_v,statusBox:Nv,errorBox:Ov,spin:Bv,bundleBlock:qv,label:Wv,bundleName:Fv,guidanceBox:Kv,includedList:Yv,includedItem:Vv,actions:Gv,button:$v,primaryLink:Xv,hint:Qv};function jl(){return typeof navigator<"u"?navigator.userAgent:""}function Zv(i){window.open(i,"_blank","noopener,noreferrer")}function Jv({open:i,fallbackHref:n,onClose:r}){const{locale:d,t:u}=yo(),p=A.useId(),[g,f]=A.useState(!1),[h,y]=A.useState(null),[C,b]=A.useState(null),[D,H]=A.useState("idle");if(A.useEffect(()=>{if(!i)return;let Y=!1;const pe=jl();return f(!0),y(null),b(null),H("idle"),zt.post("/api/dashboard/support/bug-report",{os:Bl(pe),userAgent:pe,locale:d}).then(De=>{Y||(y(De),f(!1))}).catch(()=>{Y||(b(u("bugReportDialog.error","Could not create the diagnostics bundle. You can still open GitHub without diagnostics.")),f(!1))}),()=>{Y=!0}},[i,d]),A.useEffect(()=>{if(!i||g)return;function Y(pe){pe.key==="Escape"&&r()}return window.addEventListener("keydown",Y),()=>window.removeEventListener("keydown",Y)},[i,g,r]),!i)return null;async function O(){if(h)try{H("opening"),await zt.post("/api/dashboard/support/bug-report/reveal",{bundleName:h.bundleName}),H("opened")}catch{H("failed")}}const z=h!==null,N=(h==null?void 0:h.issueUrl)??n,ie=(h==null?void 0:h.includedFiles)??[],F=D==="opening"?u("bugReportDialog.reveal.opening","Opening..."):D==="opened"?u("bugReportDialog.reveal.opened","Opened location"):u("bugReportDialog.reveal","Reveal in Finder"),X=x.jsx("div",{className:We.backdrop,onClick:g?void 0:r,children:x.jsxs("section",{className:We.dialog,role:"dialog","aria-modal":"true","aria-labelledby":p,onClick:Y=>Y.stopPropagation(),children:[x.jsxs("div",{className:We.header,children:[x.jsxs("div",{className:We.titleBlock,children:[x.jsx("h2",{id:p,className:We.title,children:u("bugReportDialog.title","diagnostics.zip can help us investigate")}),x.jsx("p",{className:We.subtitle,children:u("bugReportDialog.subtitle","WEPPY created a diagnostics zip on your computer. It includes Studio, plugin, Sync, and tool logs that can help us understand what happened.")})]}),x.jsx("button",{type:"button",className:We.closeButton,"aria-label":u("bugReportDialog.close","Close"),onClick:r,disabled:g,children:x.jsx(lv,{size:16,strokeWidth:1.75,"aria-hidden":"true"})})]}),x.jsxs("div",{className:We.body,children:[g&&x.jsxs("div",{className:We.statusBox,role:"status",children:[x.jsx(Gy,{className:We.spin,size:18,strokeWidth:1.75,"aria-hidden":"true"}),x.jsx("span",{children:u("bugReportDialog.loading","Preparing diagnostics.zip...")})]}),C&&x.jsxs("div",{className:We.errorBox,role:"alert",children:[x.jsx(jy,{size:18,strokeWidth:1.75,"aria-hidden":"true"}),x.jsx("span",{children:C})]}),z&&x.jsxs(x.Fragment,{children:[x.jsxs("div",{className:We.guidanceBox,children:[x.jsx("p",{children:u("bugReportDialog.optional","You can submit the bug report without this file, but attaching it usually helps us find the cause faster.")}),x.jsx("p",{children:u("bugReportDialog.attachHow","To attach it, download or reveal the zip, then add it to the Diagnostics ZIP (optional) upload field on GitHub before you submit.")})]}),x.jsxs("div",{className:We.bundleBlock,children:[x.jsx("span",{className:We.label,children:u("bugReportDialog.bundle","Bundle")}),x.jsx("code",{className:We.bundleName,children:h.bundleName})]}),x.jsxs("div",{className:We.bundleBlock,children:[x.jsx("span",{className:We.label,children:u("bugReportDialog.included","Included")}),x.jsx("ul",{className:We.includedList,children:ie.length>0?ie.map(Y=>x.jsx("li",{className:We.includedItem,children:Y.label},`${Y.label}:${Y.archivePath??Y.path}`)):x.jsx("li",{className:We.includedItem,children:u("bugReportDialog.included.none","No log files found")})})]}),D==="failed"&&x.jsxs("div",{className:We.errorBox,role:"alert",children:[x.jsx(op,{size:18,strokeWidth:1.75,"aria-hidden":"true"}),x.jsx("span",{children:u("bugReportDialog.reveal.failed","Could not open the file location.")})]})]}),x.jsxs("div",{className:We.actions,children:[z&&x.jsxs(x.Fragment,{children:[x.jsxs("a",{className:We.primaryLink,href:h.downloadUrl,download:h.bundleName,children:[x.jsx(Dy,{size:16,strokeWidth:1.75,"aria-hidden":"true"}),u("bugReportDialog.download","1. Download diagnostics.zip")]}),x.jsxs("button",{type:"button",className:We.button,onClick:()=>void O(),disabled:D==="opening",children:[x.jsx(op,{size:16,strokeWidth:1.75,"aria-hidden":"true"}),F]})]}),C&&!z&&x.jsxs("button",{type:"button",className:We.button,onClick:()=>{b(null),f(!0),zt.post("/api/dashboard/support/bug-report",{os:Bl(jl()),userAgent:jl(),locale:d}).then(Y=>{y(Y),f(!1)}).catch(()=>{b(u("bugReportDialog.error","Could not create the diagnostics bundle. You can still open GitHub without diagnostics.")),f(!1)})},children:[x.jsx(Wp,{size:16,strokeWidth:1.75,"aria-hidden":"true"}),u("bugReportDialog.retry","Try again")]}),x.jsxs("button",{type:"button",className:We.button,onClick:()=>Zv(N),disabled:g,children:[x.jsx(qp,{size:16,strokeWidth:1.75,"aria-hidden":"true"}),z?u("bugReportDialog.openGithub","2. Open GitHub issue"):u("bugReportDialog.openGithubFallback","Open GitHub without diagnostics")]})]}),x.jsx("p",{className:We.hint,children:u("bugReportDialog.hint","The zip can contain local logs and project context. Review it before attaching if you want to share it.")})]})]})});return typeof document>"u"?X:Un.createPortal(X,document.body)}const eS="_sidebar_1ei54_2",tS="_brand_1ei54_17",oS="_brandIcon_1ei54_28",aS="_brandText_1ei54_33",iS="_brandTextPro_1ei54_44",sS="_nav_1ei54_50",nS="_spacer_1ei54_57",rS="_navLink_1ei54_63",lS="_active_1ei54_84",dS="_disabled_1ei54_91",uS="_icon_1ei54_102",cS="_label_1ei54_113",pS="_secondaryDivider_1ei54_120",gS="_secondaryNav_1ei54_127",hS="_helpDivider_1ei54_134",mS="_helpGroupTitle_1ei54_141",fS="_helpNav_1ei54_152",yS="_externalIcon_1ei54_159",nt={sidebar:eS,brand:tS,brandIcon:oS,brandText:aS,brandTextPro:iS,nav:sS,spacer:nS,navLink:rS,active:lS,disabled:dS,icon:uS,label:cS,secondaryDivider:pS,secondaryNav:gS,helpDivider:hS,helpGroupTitle:mS,helpNav:fS,externalIcon:yS},vS={bug:"sidebar_help_bug",feature:"sidebar_help_feature",discussions:"sidebar_help_community",troubleshooting:"sidebar_help_troubleshooting"};function SS(){const[i,n]=A.useState(!1);return A.useEffect(()=>{if(typeof window>"u"||!window.matchMedia)return;const r=window.matchMedia("(max-width: 768px)"),d=()=>n(r.matches);return d(),r.addEventListener("change",d),()=>r.removeEventListener("change",d)},[]),i}const rp={disconnected:0,serverOnly:1,studioConnected:2};function bS(i,n){return rp[i]>=rp[n]}function PS(i,n){return i==="serverOnly"?n("sidebar.gate.l1","MCP server connection required"):i==="studioConnected"?n("sidebar.gate.l2","Roblox Studio plugin connection required"):""}function lp({item:i}){const{level:n}=Mn(),{t:r}=yo(),d=bS(n,i.minLevel),u=i.icon,p=x.jsxs(If,{to:i.route,end:i.route==="/",className:({isActive:g})=>[nt.navLink,g?nt.active:"",d?"":nt.disabled].filter(Boolean).join(" "),onClick:g=>{d||g.preventDefault()},children:[x.jsx("span",{className:nt.icon,children:x.jsx(u,{size:18,strokeWidth:1.75,"aria-hidden":"true",focusable:"false"})}),x.jsx("span",{className:nt.label,children:r(i.labelKey)})]});return d?p:x.jsx(Ha,{text:PS(i.minLevel,r),children:p})}function CS({item:i,ctx:n}){const{t:r}=yo(),{trackEvent:d}=ps(),{pathname:u,search:p}=no(),g=i.icon,f=i.buildUrl(n),h=r(i.tooltipKey,""),y=cs(u,p),[C,b]=A.useState(!1),D=x.jsxs("a",{href:f,target:"_blank",rel:"noopener noreferrer",className:nt.navLink,"data-testid":`sidebar-help-${i.id}`,onClick:O=>{d("dashboard_click_event",{click_target:vS[i.id],placement:"sidebar_help",...y}),i.id==="bug"&&(O.preventDefault(),b(!0))},children:[x.jsx("span",{className:nt.icon,children:x.jsx(g,{size:18,strokeWidth:1.75,"aria-hidden":"true",focusable:"false"})}),x.jsx("span",{className:nt.label,children:r(i.labelKey)}),x.jsx("span",{className:nt.externalIcon,"aria-hidden":"true",children:x.jsx(qp,{size:12,strokeWidth:1.75})})]}),H=h?x.jsx(Ha,{text:h,children:D}):D;return x.jsxs(x.Fragment,{children:[H,i.id==="bug"&&x.jsx(Jv,{open:C,fallbackHref:f,onClose:()=>b(!1)})]})}function wS(){const[i,n]=A.useState("basic"),r=SS(),{status:d}=Mn(),{locale:u,t:p}=yo(),g={locale:u,status:d};return A.useEffect(()=>{let f=!1;async function h(){try{const b=await Np("auto");!f&&(b!=null&&b.tier)&&n(b.tier)}catch{f||n("basic")}}h();const y=new Op;y.connect();const C=y.on("license",()=>{h()});return()=>{f=!0,C(),y.disconnect()}},[]),x.jsxs("aside",{className:nt.sidebar,children:[x.jsxs("div",{className:nt.brand,children:[x.jsx("span",{className:nt.brandIcon,children:x.jsx(Ry,{size:18,strokeWidth:1.75,"aria-hidden":"true",focusable:"false"})}),x.jsx("span",{"data-testid":"sidebar-brand-text",className:[nt.brandText,i==="pro"?nt.brandTextPro:""].filter(Boolean).join(" "),children:"WEPPY"})]}),x.jsx("nav",{className:nt.nav,children:Fp.map(f=>x.jsx(lp,{item:f},f.route))}),x.jsx("div",{className:nt.secondaryDivider}),x.jsx("nav",{className:nt.secondaryNav,children:Kp.map(f=>x.jsx(lp,{item:f},f.route))}),x.jsx("div",{className:nt.helpDivider,"aria-hidden":"true"}),x.jsx("div",{className:nt.helpGroupTitle,"aria-label":p("sidebar.help.group"),children:p("sidebar.help.group")}),x.jsx("nav",{className:nt.helpNav,"aria-label":p("sidebar.help.group"),children:cv.map(f=>x.jsx(CS,{item:f,ctx:g},f.id))}),x.jsx("div",{className:nt.spacer}),x.jsx(Ev,{collapsed:r})]})}async function kS(){return zt.get("/api/dashboard/place-summary")}async function xS(){return zt.get("/api/dashboard/sync-root")}async function AS(){return zt.post("/api/dashboard/sync-root/pick")}async function RS(i){return zt.patch("/api/dashboard/sync-root",{projectRoot:i})}const IS=[{id:"2026-06-15-playtest-studio-actions",date:"2026-06-15",title:{en:"Playtest controls moved to Studio actions, with fewer Stop retries",ko:"Playtest 액션이 Studio 제어로 정리되고 Stop 재시도가 줄었습니다",es:"Los controles de Playtest pasan a acciones Studio, con menos reintentos de Stop","pt-br":"Controles de Playtest agora ficam em ações Studio, com menos tentativas de Stop",ja:"Playtest操作をStudioアクションへ整理し、Stopの再試行を減らしました",id:"Kontrol Playtest dipindahkan ke aksi Studio, dengan lebih sedikit percobaan ulang Stop",de:"Playtest-Steuerung liegt jetzt bei Studio-Aktionen, mit weniger Stop-Wiederholungen","fr-fr":"Les contrôles Playtest passent aux actions Studio, avec moins de relances Stop"},body:{en:`Playtest start, stop, pause, resume, status, and automated test runs are now documented under Studio actions. AI agents and direct MCP integrations should use manage_studio.play_start, manage_studio.play_stop, manage_studio.play_pause, manage_studio.play_resume, manage_studio.play_status, and manage_studio.run_test. system_info stays focused on read-only status and diagnostics.
305
+
306
+ Play Stop has also been fixed for cases where Roblox Studio creates more than one plugin connection after Play starts. WEPPY no longer relies on only one connection for Stop, and cleanup checks whether Studio returned to Edit mode when confirmation is needed. This reduces cases where the AI asks Studio to stop but the test keeps running until you retry.
307
+
308
+ No manual migration is required. If you maintain custom prompts or direct MCP calls, update them to the manage_studio.play_* and manage_studio.run_test actions.`,ko:`Playtest 시작, 정지, 일시정지, 재개, 상태 확인, 자동 테스트 실행이 Studio 제어 액션 기준으로 정리되었습니다. AI Agent와 직접 MCP 연동에서는 manage_studio.play_start, manage_studio.play_stop, manage_studio.play_pause, manage_studio.play_resume, manage_studio.play_status, manage_studio.run_test를 사용해 주세요. system_info는 읽기 전용 상태와 진단 역할에 집중합니다.
309
+
310
+ Play 시작 후 Roblox Studio가 플러그인 연결을 여러 개 만드는 경우에도 Stop 요청이 정상 동작하도록 수정하였습니다. WEPPY는 Stop 요청을 한 연결에만 맡기지 않고 필요한 경우 active plugin connection에도 보내며, 정리 단계에서는 Studio가 Edit 모드로 돌아왔는지 확인합니다. 이로 인해 AI가 Stop을 요청했는데 테스트가 계속 남아 있어 다시 시도해야 하는 상황이 줄어듭니다.
311
+
312
+ 수동 마이그레이션은 필요 없습니다. 커스텀 프롬프트나 직접 MCP 호출을 관리 중이라면 manage_studio.play_* 및 manage_studio.run_test 기준으로 갱신해 주세요.`,es:`El inicio, la detención, la pausa, la reanudación, el estado y las pruebas automáticas de Playtest ahora se documentan como acciones Studio. Los agentes de IA y las integraciones MCP directas deben usar manage_studio.play_start, manage_studio.play_stop, manage_studio.play_pause, manage_studio.play_resume, manage_studio.play_status y manage_studio.run_test. system_info queda enfocado en estado de solo lectura y diagnóstico.
313
+
314
+ También se corrigió Play Stop para los casos en que Roblox Studio crea más de una conexión del plugin después de iniciar Play. WEPPY ya no depende de una sola conexión para Stop, y durante la limpieza comprueba si Studio volvió al modo Edit cuando hace falta confirmación. Esto reduce los casos en los que la IA pide detener Studio pero la prueba sigue ejecutándose hasta que lo intentas de nuevo.
315
+
316
+ No se requiere migración manual. Si mantienes prompts personalizados o llamadas MCP directas, actualízalos a las acciones manage_studio.play_* y manage_studio.run_test.`,"pt-br":`Iniciar, parar, pausar, retomar, consultar status e executar testes automáticos de Playtest agora ficam documentados como ações Studio. Agentes de IA e integrações MCP diretas devem usar manage_studio.play_start, manage_studio.play_stop, manage_studio.play_pause, manage_studio.play_resume, manage_studio.play_status e manage_studio.run_test. system_info fica focado em status somente leitura e diagnósticos.
317
+
318
+ O Play Stop também foi corrigido para casos em que o Roblox Studio cria mais de uma conexão do plugin depois que o Play começa. O WEPPY não depende mais de uma única conexão para Stop, e a limpeza verifica se o Studio voltou ao modo Edit quando essa confirmação é necessária. Isso reduz casos em que a IA pede para parar o Studio, mas o teste continua rodando até você tentar de novo.
319
+
320
+ Nenhuma migração manual é necessária. Se você mantém prompts personalizados ou chamadas MCP diretas, atualize para as ações manage_studio.play_* e manage_studio.run_test.`,ja:`Playtestの開始、停止、一時停止、再開、状態確認、自動テスト実行は、Studioアクションとして整理されました。AI Agentや直接MCP連携では、manage_studio.play_start、manage_studio.play_stop、manage_studio.play_pause、manage_studio.play_resume、manage_studio.play_status、manage_studio.run_testを使用してください。system_infoは読み取り専用の状態確認と診断に集中します。
321
+
322
+ Play開始後にRoblox Studioが複数のプラグイン接続を作る場合でも、Play Stopが正常に動作するよう修正しました。WEPPYはStopを1つの接続だけに任せず、必要に応じてactive plugin connectionにも送ります。クリーンアップでは、確認が必要な場合にStudioがEditモードへ戻ったかを確認します。これにより、AIがStopを要求したのにテストが残り、もう一度試す必要があるケースが減ります。
323
+
324
+ 手動移行は不要です。カスタムプロンプトや直接MCP呼び出しを管理している場合は、manage_studio.play_*およびmanage_studio.run_testのアクションに更新してください。`,id:`Memulai, menghentikan, menjeda, melanjutkan, memeriksa status, dan menjalankan tes otomatis Playtest kini didokumentasikan sebagai aksi Studio. AI Agent dan integrasi MCP langsung sebaiknya memakai manage_studio.play_start, manage_studio.play_stop, manage_studio.play_pause, manage_studio.play_resume, manage_studio.play_status, dan manage_studio.run_test. system_info tetap berfokus pada status baca-saja dan diagnostik.
325
+
326
+ Play Stop juga diperbaiki untuk kasus ketika Roblox Studio membuat lebih dari satu koneksi plugin setelah Play dimulai. WEPPY tidak lagi bergantung pada satu koneksi saja untuk Stop, dan proses cleanup memeriksa apakah Studio sudah kembali ke mode Edit saat konfirmasi dibutuhkan. Ini mengurangi kasus ketika AI meminta Studio berhenti tetapi tes tetap berjalan sampai Anda mencoba lagi.
327
+
328
+ Tidak ada migrasi manual yang diperlukan. Jika Anda mengelola prompt kustom atau panggilan MCP langsung, perbarui ke aksi manage_studio.play_* dan manage_studio.run_test.`,de:`Playtest starten, stoppen, pausieren, fortsetzen, Status abfragen und automatische Tests ausführen ist jetzt als Studio-Aktionen dokumentiert. KI-Agenten und direkte MCP-Integrationen sollten manage_studio.play_start, manage_studio.play_stop, manage_studio.play_pause, manage_studio.play_resume, manage_studio.play_status und manage_studio.run_test verwenden. system_info bleibt auf schreibgeschützten Status und Diagnose ausgerichtet.
329
+
330
+ Play Stop wurde außerdem für Fälle korrigiert, in denen Roblox Studio nach dem Start von Play mehr als eine Plugin-Verbindung erstellt. WEPPY verlässt sich bei Stop nicht mehr nur auf eine Verbindung, und die Bereinigung prüft bei Bedarf, ob Studio wieder im Edit-Modus ist. Dadurch gibt es weniger Fälle, in denen die KI Studio stoppen möchte, der Test aber weiterläuft, bis Sie es erneut versuchen.
331
+
332
+ Eine manuelle Migration ist nicht erforderlich. Wenn Sie eigene Prompts oder direkte MCP-Aufrufe pflegen, aktualisieren Sie sie auf die Aktionen manage_studio.play_* und manage_studio.run_test.`,"fr-fr":`Le démarrage, l'arrêt, la pause, la reprise, le statut et les tests automatiques Playtest sont maintenant documentés comme des actions Studio. Les agents IA et les intégrations MCP directes doivent utiliser manage_studio.play_start, manage_studio.play_stop, manage_studio.play_pause, manage_studio.play_resume, manage_studio.play_status et manage_studio.run_test. system_info reste centré sur le statut en lecture seule et le diagnostic.
333
+
334
+ Play Stop a aussi été corrigé pour les cas où Roblox Studio crée plusieurs connexions du plugin après le démarrage de Play. WEPPY ne s'appuie plus sur une seule connexion pour Stop, et le nettoyage vérifie si Studio est revenu en mode Edit lorsqu'une confirmation est nécessaire. Cela réduit les cas où l'IA demande à Studio de s'arrêter, mais où le test continue jusqu'à une nouvelle tentative.
335
+
336
+ Aucune migration manuelle n'est requise. Si vous maintenez des prompts personnalisés ou des appels MCP directs, mettez-les à jour vers les actions manage_studio.play_* et manage_studio.run_test.`},severity:"info",category:"release",version:"2.8.1"},{id:"2026-06-14-assets-library-experimental",date:"2026-06-14",title:{en:"Experimental Assets: use AI-generated images and Studio RBXM files in your game",ko:"Assets 실험 기능: AI가 만든 이미지와 Studio RBXM을 게임에 넣을 수 있습니다",es:"Assets experimental: usa imágenes generadas por IA y archivos RBXM de Studio en tu juego","pt-br":"Assets experimental: use imagens geradas por IA e arquivos RBXM do Studio no seu jogo",ja:"Assets実験機能:AI生成画像とStudioのRBXMをゲームに追加できます",id:"Assets eksperimental: gunakan gambar buatan AI dan file RBXM Studio di game Anda",de:"Experimentelle Assets: KI-generierte Bilder und Studio-RBXM-Dateien im Spiel verwenden","fr-fr":"Assets expérimental : utilisez des images générées par IA et des fichiers RBXM Studio dans votre jeu"},body:{en:`The Dashboard now includes an experimental Assets page. This first version supports Images, Decals, and RBXM.
337
+
338
+ With image-capable AI agents such as Codex Desktop and Antigravity, you can generate an image, save it into the local Asset Library, upload it to Roblox through Open Cloud, and use the resulting Roblox Asset ID or rbxassetid:// URI in your game.
339
+
340
+ You can also export selected objects from Roblox Studio as RBXM files through the WEPPY Plugin Assets tab. Saved RBXM files appear in the Dashboard and can be inserted back into the connected Studio place.
341
+
342
+ Roblox uploads require a Roblox Open Cloud API key and Creator ID. The API key is encrypted on your computer. WEPPY does not store it in an external service or send it to a separate WEPPY server; the local MCP server only uses it for Roblox Open Cloud upload requests.
343
+
344
+ Assets is still experimental. More categories will be added over time.`,ko:`Dashboard에 Assets 페이지가 실험 기능으로 추가되었습니다. 이번 버전에서는 Images, Decals, RBXM을 먼저 사용할 수 있습니다.
345
+
346
+ Codex Desktop, Antigravity처럼 이미지 생성이 가능한 AI Agent에서 이미지를 만든 뒤, 그 파일을 로컬 Asset Library에 저장하고 Roblox Open Cloud로 업로드할 수 있습니다. 업로드가 끝나면 Roblox Asset ID와 rbxassetid:// URI를 확인하고 게임 안에서 사용할 수 있습니다.
347
+
348
+ Roblox Studio에서 선택한 오브젝트는 WEPPY Plugin의 Assets 탭에서 RBXM 파일로 저장할 수 있습니다. 저장된 RBXM은 Dashboard에서 확인한 뒤 연결된 Studio place에 다시 삽입할 수 있습니다.
349
+
350
+ 에셋 업로드에는 Roblox Open Cloud API Key와 Creator ID가 필요합니다. API Key는 사용자의 컴퓨터에 암호화되어 저장됩니다. WEPPY는 이 키를 외부 저장소나 별도 WEPPY 서버에 저장하지 않으며, 업로드할 때 로컬 MCP 서버가 Roblox Open Cloud 요청에만 사용합니다.
351
+
352
+ Assets는 아직 실험 기능입니다. 다른 카테고리는 차차 추가할 예정입니다.`,es:`El Dashboard ahora incluye una página Assets experimental. Esta primera versión admite Images, Decals y RBXM.
353
+
354
+ Con agentes de IA que pueden generar imágenes, como Codex Desktop y Antigravity, puedes crear una imagen, guardarla en la Asset Library local, subirla a Roblox mediante Open Cloud y usar el Roblox Asset ID o URI rbxassetid:// resultante en tu juego.
355
+
356
+ También puedes exportar objetos seleccionados de Roblox Studio como archivos RBXM desde la pestaña Assets del WEPPY Plugin. Los archivos RBXM guardados aparecen en el Dashboard y se pueden insertar de nuevo en el lugar de Studio conectado.
357
+
358
+ Las subidas a Roblox requieren una API key de Roblox Open Cloud y un Creator ID. La API key se cifra en tu computadora. WEPPY no la guarda en un servicio externo ni la envía a un servidor WEPPY separado; el servidor MCP local solo la usa para solicitudes de subida a Roblox Open Cloud.
359
+
360
+ Assets todavía es experimental. Se agregarán más categorías con el tiempo.`,"pt-br":`O Dashboard agora inclui uma página Assets experimental. Esta primeira versão oferece suporte a Images, Decals e RBXM.
361
+
362
+ Com agentes de IA que conseguem gerar imagens, como Codex Desktop e Antigravity, você pode criar uma imagem, salvá-la na Asset Library local, enviá-la ao Roblox pelo Open Cloud e usar o Roblox Asset ID ou URI rbxassetid:// resultante no seu jogo.
363
+
364
+ Você também pode exportar objetos selecionados do Roblox Studio como arquivos RBXM pela aba Assets do WEPPY Plugin. Os arquivos RBXM salvos aparecem no Dashboard e podem ser inseridos de volta no place do Studio conectado.
365
+
366
+ Uploads para Roblox exigem uma API key do Roblox Open Cloud e um Creator ID. A API key é criptografada no seu computador. O WEPPY não a salva em um serviço externo nem a envia para um servidor WEPPY separado; o servidor MCP local só a usa em solicitações de upload ao Roblox Open Cloud.
367
+
368
+ Assets ainda é experimental. Mais categorias serão adicionadas com o tempo.`,ja:`Dashboardに実験機能としてAssetsページが追加されました。最初のバージョンではImages、Decals、RBXMに対応しています。
369
+
370
+ Codex DesktopやAntigravityのように画像生成ができるAI Agentを使うと、画像を生成し、ローカルAsset Libraryに保存し、Roblox Open Cloudでアップロードして、返されたRoblox Asset IDまたはrbxassetid:// URIをゲーム内で使用できます。
371
+
372
+ Roblox Studioで選択したオブジェクトは、WEPPY PluginのAssetsタブからRBXMファイルとして書き出すこともできます。保存されたRBXMファイルはDashboardに表示され、接続中のStudio placeへ再挿入できます。
373
+
374
+ Robloxへのアップロードには、Roblox Open Cloud API KeyとCreator IDが必要です。API Keyはお使いのコンピューター上で暗号化して保存されます。WEPPYはこのキーを外部サービスに保存したり、別のWEPPYサーバーへ送信したりしません。ローカルMCPサーバーがRoblox Open Cloudへのアップロード要求にのみ使用します。
375
+
376
+ Assetsはまだ実験機能です。他のカテゴリーは順次追加予定です。`,id:`Dashboard kini memiliki halaman Assets eksperimental. Versi pertama ini mendukung Images, Decals, dan RBXM.
377
+
378
+ Dengan AI Agent yang dapat membuat gambar, seperti Codex Desktop dan Antigravity, Anda bisa membuat gambar, menyimpannya ke Asset Library lokal, mengunggahnya ke Roblox melalui Open Cloud, lalu memakai Roblox Asset ID atau URI rbxassetid:// yang dihasilkan di game Anda.
379
+
380
+ Anda juga bisa mengekspor objek yang dipilih di Roblox Studio sebagai file RBXM melalui tab Assets di WEPPY Plugin. File RBXM yang disimpan akan muncul di Dashboard dan dapat dimasukkan kembali ke Studio place yang terhubung.
381
+
382
+ Upload ke Roblox memerlukan Roblox Open Cloud API key dan Creator ID. API key dienkripsi di komputer Anda. WEPPY tidak menyimpannya di layanan eksternal atau mengirimkannya ke server WEPPY terpisah; server MCP lokal hanya menggunakannya untuk permintaan upload ke Roblox Open Cloud.
383
+
384
+ Assets masih eksperimental. Kategori lain akan ditambahkan secara bertahap.`,de:`Das Dashboard enthält jetzt eine experimentelle Assets-Seite. Diese erste Version unterstützt Images, Decals und RBXM.
385
+
386
+ Mit KI-Agenten, die Bilder erzeugen können, etwa Codex Desktop und Antigravity, können Sie ein Bild erstellen, es in der lokalen Asset Library speichern, über Roblox Open Cloud hochladen und die zurückgegebene Roblox Asset ID oder rbxassetid:// URI in Ihrem Spiel verwenden.
387
+
388
+ Sie können außerdem ausgewählte Objekte aus Roblox Studio über den Assets-Tab des WEPPY Plugin als RBXM-Dateien exportieren. Gespeicherte RBXM-Dateien erscheinen im Dashboard und können wieder in den verbundenen Studio-Place eingefügt werden.
389
+
390
+ Roblox-Uploads benötigen einen Roblox Open Cloud API Key und eine Creator ID. Der API Key wird auf Ihrem Computer verschlüsselt gespeichert. WEPPY speichert ihn nicht in einem externen Dienst und sendet ihn nicht an einen separaten WEPPY-Server; der lokale MCP-Server verwendet ihn nur für Upload-Anfragen an Roblox Open Cloud.
391
+
392
+ Assets ist noch experimentell. Weitere Kategorien werden nach und nach ergänzt.`,"fr-fr":`Le Dashboard inclut maintenant une page Assets expérimentale. Cette première version prend en charge Images, Decals et RBXM.
393
+
394
+ Avec des agents IA capables de générer des images, comme Codex Desktop et Antigravity, vous pouvez créer une image, l'enregistrer dans l'Asset Library locale, l'envoyer à Roblox via Open Cloud, puis utiliser le Roblox Asset ID ou l'URI rbxassetid:// obtenu dans votre jeu.
395
+
396
+ Vous pouvez aussi exporter des objets sélectionnés dans Roblox Studio en fichiers RBXM depuis l'onglet Assets du WEPPY Plugin. Les fichiers RBXM enregistrés apparaissent dans le Dashboard et peuvent être réinsérés dans la place Studio connectée.
397
+
398
+ Les uploads Roblox nécessitent une API key Roblox Open Cloud et un Creator ID. L'API key est chiffrée sur votre ordinateur. WEPPY ne l'enregistre pas dans un service externe et ne l'envoie pas à un serveur WEPPY séparé ; le serveur MCP local l'utilise uniquement pour les demandes d'upload Roblox Open Cloud.
399
+
400
+ Assets est encore expérimental. D'autres catégories seront ajoutées progressivement.`},severity:"info",category:"release"},{id:"2026-05-24-polar-payment",date:"2026-05-24",title:{en:"WEPPY Roblox AI Toolkit Pro checkout now uses Polar",ko:"WEPPY Roblox AI Toolkit Pro 기본 결제 방식이 Polar로 변경되었습니다",es:"El checkout de WEPPY Roblox AI Toolkit Pro ahora usa Polar","pt-br":"O checkout do WEPPY Roblox AI Toolkit Pro agora usa Polar",ja:"WEPPY Roblox AI Toolkit Proの標準決済がPolarに変わりました",id:"Checkout WEPPY Roblox AI Toolkit Pro kini menggunakan Polar",de:"Der Checkout von WEPPY Roblox AI Toolkit Pro verwendet jetzt Polar","fr-fr":"Le checkout de WEPPY Roblox AI Toolkit Pro utilise maintenant Polar"},body:{en:`The default checkout provider for WEPPY Roblox AI Toolkit Pro has changed from Gumroad to Polar.
401
+
402
+ If you already purchased through Gumroad, you can keep using your current Gumroad license. You do not need to buy Pro again or move your payment method.
403
+
404
+ If you cancel your Gumroad payment and later want to subscribe again, the new payment link will take you to Polar.
405
+
406
+ We are sorry for any confusion or extra work caused by this change. We will continue keeping existing Gumroad purchases usable.`,ko:`WEPPY Roblox AI Toolkit Pro의 기본 결제 방식이 Gumroad에서 Polar로 변경되었습니다.
407
+
408
+ 기존에 Gumroad에서 구매하신 분들은 현재 사용 중인 Gumroad 라이선스를 그대로 계속 사용할 수 있습니다. 별도로 다시 구매하거나 결제 방식을 옮기실 필요는 없습니다.
409
+
410
+ 다만 Gumroad 결제를 취소한 뒤 다시 결제하려는 경우에는 새 결제 링크가 Polar로 안내됩니다.
411
+
412
+ 결제 방식 변경으로 혼란이나 번거로움을 드려 죄송합니다. 기존 Gumroad 구매자분들도 불편 없이 계속 사용할 수 있도록 유지하겠습니다.`,es:`El proveedor de checkout predeterminado de WEPPY Roblox AI Toolkit Pro cambió de Gumroad a Polar.
413
+
414
+ Si ya compraste a través de Gumroad, puedes seguir usando tu licencia actual de Gumroad. No tienes que volver a comprar Pro ni mover tu método de pago.
415
+
416
+ Si cancelas tu pago de Gumroad y más adelante quieres suscribirte de nuevo, el nuevo enlace de pago te llevará a Polar.
417
+
418
+ Sentimos cualquier confusión o trabajo extra causado por este cambio. Seguiremos manteniendo utilizables las compras existentes de Gumroad.`,"pt-br":`O provedor de checkout padrão do WEPPY Roblox AI Toolkit Pro mudou de Gumroad para Polar.
419
+
420
+ Se você já comprou pelo Gumroad, pode continuar usando sua licença atual do Gumroad. Não é preciso comprar o Pro novamente nem mover sua forma de pagamento.
421
+
422
+ Se você cancelar seu pagamento no Gumroad e depois quiser assinar novamente, o novo link de pagamento levará você para o Polar.
423
+
424
+ Pedimos desculpas por qualquer confusão ou trabalho extra causado por essa mudança. Vamos continuar mantendo as compras existentes do Gumroad utilizáveis.`,ja:`WEPPY Roblox AI Toolkit Proの標準決済プロバイダーがGumroadからPolarに変わりました。
425
+
426
+ すでにGumroadで購入済みの方は、現在のGumroadライセンスをそのまま使い続けられます。Proを再購入したり、支払い方法を移行したりする必要はありません。
427
+
428
+ ただし、Gumroadの支払いをキャンセルしたあとで再度購読したい場合、新しい決済リンクはPolarに案内されます。
429
+
430
+ この変更により混乱やお手数をおかけして申し訳ありません。既存のGumroad購入者の方も引き続き利用できるよう維持します。`,id:`Provider checkout default untuk WEPPY Roblox AI Toolkit Pro berubah dari Gumroad ke Polar.
431
+
432
+ Jika Anda sudah membeli melalui Gumroad, Anda tetap bisa memakai lisensi Gumroad yang sedang digunakan. Anda tidak perlu membeli Pro lagi atau memindahkan metode pembayaran.
433
+
434
+ Namun, jika Anda membatalkan pembayaran Gumroad lalu ingin berlangganan lagi nanti, link pembayaran baru akan mengarah ke Polar.
435
+
436
+ Maaf atas kebingungan atau langkah tambahan yang ditimbulkan oleh perubahan ini. Kami akan tetap menjaga agar pembelian Gumroad yang sudah ada dapat terus digunakan.`,de:`Der Standard-Checkout-Anbieter für WEPPY Roblox AI Toolkit Pro wurde von Gumroad auf Polar umgestellt.
437
+
438
+ Wenn Sie bereits über Gumroad gekauft haben, können Sie Ihre aktuelle Gumroad-Lizenz weiter verwenden. Sie müssen Pro nicht erneut kaufen und Ihre Zahlungsmethode nicht umstellen.
439
+
440
+ Wenn Sie Ihre Gumroad-Zahlung kündigen und später erneut abonnieren möchten, führt der neue Zahlungslink zu Polar.
441
+
442
+ Wir entschuldigen uns für mögliche Verwirrung oder zusätzlichen Aufwand durch diese Änderung. Bestehende Gumroad-Käufe bleiben weiterhin nutzbar.`,"fr-fr":`Le fournisseur de checkout par défaut de WEPPY Roblox AI Toolkit Pro est passé de Gumroad à Polar.
443
+
444
+ Si vous avez déjà acheté via Gumroad, vous pouvez continuer à utiliser votre licence Gumroad actuelle. Vous n'avez pas besoin de racheter Pro ni de changer de moyen de paiement.
445
+
446
+ Si vous annulez votre paiement Gumroad et souhaitez vous réabonner plus tard, le nouveau lien de paiement vous dirigera vers Polar.
447
+
448
+ Nous sommes désolés pour toute confusion ou démarche supplémentaire causée par ce changement. Les achats Gumroad existants resteront utilisables.`},severity:"info",category:"notice",links:[{url:{en:"https://weppyai.com/en/plans/",ko:"https://weppyai.com/ko/plans/",es:"https://weppyai.com/es/plans/","pt-br":"https://weppyai.com/pt-br/plans/",ja:"https://weppyai.com/ja/plans/",id:"https://weppyai.com/id/plans/",de:"https://weppyai.com/de/plans/","fr-fr":"https://weppyai.com/fr-fr/plans/"},label:{en:"Plans page",ko:"요금제 페이지",es:"Página de planes","pt-br":"Página de planos",ja:"プランページ",id:"Halaman paket",de:"Tarifseite","fr-fr":"Page des forfaits"}}]},{id:"2026-05-16-ai-agent-plugin",date:"2026-05-16",title:{en:"WEPPY AI Agent Plugin is now available for Claude Code and Codex",ko:"Claude Code와 Codex용 WEPPY AI Agent Plugin을 추가했습니다",es:"WEPPY AI Agent Plugin ya está disponible para Claude Code y Codex","pt-br":"WEPPY AI Agent Plugin já está disponível para Claude Code e Codex",ja:"Claude CodeとCodex向けのWEPPY AI Agent Pluginを追加しました",id:"WEPPY AI Agent Plugin kini tersedia untuk Claude Code dan Codex",de:"WEPPY AI Agent Plugin ist jetzt für Claude Code und Codex verfügbar","fr-fr":"WEPPY AI Agent Plugin est maintenant disponible pour Claude Code et Codex"},body:{en:`WEPPY AI Agent Plugin is now available for Claude Code and Codex. You can still use WEPPY by registering only the MCP server, but the plugin also gives the agent WEPPY-specific skills so it can handle Roblox Studio work with better context.
449
+
450
+ The plugin includes two skill guides: one for Roblox Studio MCP work such as choosing Studio actions, UI Studio, Playtest, and logs, and one for Roblox Sync such as Studio-local Sync, bidirectional Sync, conflict handling, and Roblox Explorer context.
451
+
452
+ For now, AI Agent Plugin support is limited to Claude Code and Codex. Other agents will be supported as they add plugin installation support.
453
+
454
+ If you already use Claude Code or Codex, run the install command again from the Install page, or follow the manual setup guide for your agent below.`,ko:`Claude Code와 Codex에서 사용할 수 있는 WEPPY AI Agent Plugin을 추가했습니다. 기존처럼 MCP 서버만 등록해도 WEPPY를 사용할 수 있지만, 이번 plugin은 agent가 Roblox Studio 작업을 더 정확히 다룰 수 있도록 WEPPY 전용 스킬을 함께 제공합니다.
455
+
456
+ 포함된 스킬은 두 가지입니다. 하나는 Studio 액션 선택, UI Studio, Playtest, 로그 확인을 다루는 Roblox Studio MCP 작업 가이드이고, 다른 하나는 Studio-local Sync, 양방향 Sync, 충돌 처리, Roblox Explorer 문맥을 다루는 Roblox Sync 가이드입니다.
457
+
458
+ 현재 AI Agent Plugin은 Claude Code와 Codex만 지원합니다. 다른 Agent는 해당 Agent에서 플러그인 설치 기능을 제공하는 대로 지원할 예정입니다.
459
+
460
+ Claude Code나 Codex 사용자라면 Install 페이지를 참고해 설치 커맨드를 한 번 더 실행하거나, 아래 Agent별 설치 가이드를 참고해 수동 설치할 수 있습니다.`,es:`WEPPY AI Agent Plugin ya está disponible para Claude Code y Codex. Puedes seguir usando WEPPY registrando solo el servidor MCP, pero el plugin también entrega al agente skills específicas de WEPPY para que trabaje con Roblox Studio con mejor contexto.
461
+
462
+ Incluye dos guías de skills: una para trabajo MCP en Roblox Studio, como elegir acciones de Studio, UI Studio, Playtest y revisar logs; y otra para Roblox Sync, como Studio-local Sync, Sync bidireccional, manejo de conflictos y contexto de Roblox Explorer.
463
+
464
+ Por ahora, AI Agent Plugin solo es compatible con Claude Code y Codex. Otros agentes se admitirán cuando incorporen instalación de plugins.
465
+
466
+ Si ya usas Claude Code o Codex, vuelve a ejecutar el comando desde la página Install, o sigue la guía manual de tu agente abajo.`,"pt-br":`WEPPY AI Agent Plugin já está disponível para Claude Code e Codex. Você ainda pode usar o WEPPY registrando apenas o servidor MCP, mas o plugin também entrega skills específicas do WEPPY ao agente para que ele trabalhe com Roblox Studio com mais contexto.
467
+
468
+ O plugin inclui duas guias de skills: uma para trabalho MCP no Roblox Studio, como escolher ações do Studio, UI Studio, Playtest e conferir logs; e outra para Roblox Sync, como Studio-local Sync, Sync bidirecional, resolução de conflitos e contexto do Roblox Explorer.
469
+
470
+ Por enquanto, o AI Agent Plugin é compatível apenas com Claude Code e Codex. Outros agentes serão atendidos quando oferecerem instalação de plugins.
471
+
472
+ Se você já usa Claude Code ou Codex, execute novamente o comando na página Install ou siga abaixo a guia manual do seu agente.`,ja:`Claude CodeとCodexで使えるWEPPY AI Agent Pluginを追加しました。これまで通りMCPサーバーを登録するだけでもWEPPYは使えますが、このpluginはエージェントにWEPPY専用のスキルを渡し、Roblox Studioでの作業をより正確な文脈で扱えるようにします。
473
+
474
+ 含まれるスキルは2つです。1つはStudioアクションの選択、UI Studio、Playtest、ログ確認を扱うRoblox Studio MCP作業ガイドです。もう1つはStudio-local Sync、双方向Sync、競合処理、Roblox Explorerの文脈を扱うRoblox Syncガイドです。
475
+
476
+ 現在、AI Agent PluginはClaude CodeとCodexのみ対応しています。他のAgentは、それぞれのAgentでpluginインストール機能が提供され次第対応する予定です。
477
+
478
+ Claude CodeまたはCodexを使っている場合は、Installページのコマンドをもう一度実行するか、下のAgent別セットアップガイドに従って手動でインストールできます。`,id:`WEPPY AI Agent Plugin kini tersedia untuk Claude Code dan Codex. Anda tetap bisa memakai WEPPY hanya dengan mendaftarkan MCP server, tetapi plugin ini juga memberi agent skill khusus WEPPY agar pekerjaan Roblox Studio ditangani dengan konteks yang lebih tepat.
479
+
480
+ Plugin ini berisi dua panduan skill: panduan kerja Roblox Studio MCP untuk memilih aksi Studio, UI Studio, Playtest, dan memeriksa log; serta panduan Roblox Sync untuk Studio-local Sync, Sync dua arah, penanganan konflik, dan konteks Roblox Explorer.
481
+
482
+ Saat ini AI Agent Plugin hanya mendukung Claude Code dan Codex. Agent lain akan didukung ketika masing-masing agent menyediakan fitur instalasi plugin.
483
+
484
+ Jika Anda menggunakan Claude Code atau Codex, jalankan kembali perintah dari halaman Install, atau ikuti panduan manual per agent di bawah.`,de:`WEPPY AI Agent Plugin ist jetzt für Claude Code und Codex verfügbar. Sie können WEPPY weiterhin nur über die MCP-Serverregistrierung verwenden, aber das Plugin gibt dem Agent zusätzlich WEPPY-spezifische Skills, damit er Roblox Studio-Aufgaben mit besserem Kontext bearbeiten kann.
485
+
486
+ Das Plugin enthält zwei Skill-Guides: einen für Roblox Studio MCP-Arbeit wie Studio-Aktionen auswählen, UI Studio, Playtest und Logs prüfen, und einen für Roblox Sync wie Studio-local Sync, bidirektionalen Sync, Konfliktbehandlung und Roblox Explorer-Kontext.
487
+
488
+ Aktuell unterstützt AI Agent Plugin nur Claude Code und Codex. Weitere Agents werden unterstützt, sobald sie Plugin-Installation anbieten.
489
+
490
+ Wenn Sie Claude Code oder Codex verwenden, führen Sie den Installationsbefehl auf der Install-Seite erneut aus oder folgen Sie unten dem manuellen Setup-Guide für Ihren Agent.`,"fr-fr":`WEPPY AI Agent Plugin est maintenant disponible pour Claude Code et Codex. Vous pouvez toujours utiliser WEPPY en enregistrant seulement le serveur MCP, mais le plugin fournit aussi à l'agent des skills propres à WEPPY pour mieux traiter le travail dans Roblox Studio.
491
+
492
+ Le plugin inclut deux guides de skills : un guide pour le travail Roblox Studio MCP, comme le choix des actions Studio, UI Studio, Playtest et la lecture des logs ; et un guide Roblox Sync pour Studio-local Sync, Sync bidirectionnel, la gestion des conflits et le contexte Roblox Explorer.
493
+
494
+ Pour l'instant, AI Agent Plugin prend seulement en charge Claude Code et Codex. Les autres agents seront pris en charge lorsqu'ils proposeront l'installation de plugins.
495
+
496
+ Si vous utilisez Claude Code ou Codex, relancez la commande depuis la page Install, ou suivez ci-dessous le guide manuel correspondant à votre agent.`},severity:"info",category:"release",links:[{url:{en:"https://weppyai.com/en/install/",ko:"https://weppyai.com/ko/install/",es:"https://weppyai.com/es/install/","pt-br":"https://weppyai.com/pt-br/install/",ja:"https://weppyai.com/ja/install/",id:"https://weppyai.com/id/install/",de:"https://weppyai.com/de/install/","fr-fr":"https://weppyai.com/fr-fr/install/"},label:{en:"Install page",ko:"Install 페이지",es:"Página Install","pt-br":"Página Install",ja:"Installページ",id:"Halaman Install",de:"Install-Seite","fr-fr":"Page Install"}},{url:{en:"https://weppyai.com/en/docs/agents/claude-code/",ko:"https://weppyai.com/ko/docs/agents/claude-code/",es:"https://weppyai.com/es/docs/agents/claude-code/","pt-br":"https://weppyai.com/pt-br/docs/agents/claude-code/",ja:"https://weppyai.com/ja/docs/agents/claude-code/",id:"https://weppyai.com/id/docs/agents/claude-code/",de:"https://weppyai.com/de/docs/agents/claude-code/","fr-fr":"https://weppyai.com/fr-fr/docs/agents/claude-code/"},label:{en:"Claude Code guide",ko:"Claude Code 설치 가이드",es:"Guía de Claude Code","pt-br":"Guia do Claude Code",ja:"Claude Codeセットアップガイド",id:"Panduan Claude Code",de:"Claude Code Guide","fr-fr":"Guide Claude Code"}},{url:{en:"https://weppyai.com/en/docs/agents/codex-cli/",ko:"https://weppyai.com/ko/docs/agents/codex-cli/",es:"https://weppyai.com/es/docs/agents/codex-cli/","pt-br":"https://weppyai.com/pt-br/docs/agents/codex-cli/",ja:"https://weppyai.com/ja/docs/agents/codex-cli/",id:"https://weppyai.com/id/docs/agents/codex-cli/",de:"https://weppyai.com/de/docs/agents/codex-cli/","fr-fr":"https://weppyai.com/fr-fr/docs/agents/codex-cli/"},label:{en:"Codex CLI guide",ko:"Codex CLI 설치 가이드",es:"Guía de Codex CLI","pt-br":"Guia do Codex CLI",ja:"Codex CLIセットアップガイド",id:"Panduan Codex CLI",de:"Codex CLI Guide","fr-fr":"Guide Codex CLI"}},{url:{en:"https://weppyai.com/en/docs/agents/codex-app/",ko:"https://weppyai.com/ko/docs/agents/codex-app/",es:"https://weppyai.com/es/docs/agents/codex-app/","pt-br":"https://weppyai.com/pt-br/docs/agents/codex-app/",ja:"https://weppyai.com/ja/docs/agents/codex-app/",id:"https://weppyai.com/id/docs/agents/codex-app/",de:"https://weppyai.com/de/docs/agents/codex-app/","fr-fr":"https://weppyai.com/fr-fr/docs/agents/codex-app/"},label:{en:"Codex App guide",ko:"Codex App 설치 가이드",es:"Guía de Codex App","pt-br":"Guia do Codex App",ja:"Codex Appセットアップガイド",id:"Panduan Codex App",de:"Codex App Guide","fr-fr":"Guide Codex App"}}]},{id:"2026-05-04-ui-studio",date:"2026-05-04",title:{en:"UI Studio — helping AI build polished in-game UI",ko:"UI Studio — AI가 완성도 있는 인게임 UI를 만들 수 있도록 지원합니다",es:"UI Studio — apoyo para que la IA cree una UI en el juego con buen acabado","pt-br":"UI Studio — apoio para a IA criar UI no jogo com bom acabamento",ja:"UI Studio — AIが完成度の高いゲーム内UIを作れるようサポート",id:"UI Studio — mendukung AI membangun UI dalam game yang rapi"},body:{en:`WEPPY now ships UI Studio — AI agents can build and edit Roblox in-game UI (screen elements like ScreenGui, Frame, TextLabel) directly.
497
+
498
+ When the AI starts a new UI, it first asks guided questions to capture the purpose, the screen, and the target devices, then composes the UI tree. As work progresses, the AI can capture the current screen to verify the result, and it inspects items such as touch target size, text contrast, and safe zones to surface improvement suggestions — so the polish of the output naturally improves.
499
+
500
+ The inspection results, captured screens, and suggested improvements are all viewable directly on the UI Studio page in the dashboard.
501
+
502
+ Just ask as usual: "Build me a UI."`,ko:`AI 에이전트가 Roblox 인게임 UI(ScreenGui · Frame · TextLabel 같은 화면 요소)를 직접 만들고 수정할 수 있는 UI Studio가 추가되었습니다.
503
+
504
+ 새 UI를 만들기 시작하면 AI가 먼저 목적·화면·타겟 디바이스 같은 요구사항을 가이드 질문으로 정리한 뒤 UI 트리를 구성합니다. 작업 중에는 현재 화면을 캡처해 결과를 직접 확인할 수 있고, 터치 타겟 크기·텍스트 대비·세이프존 같은 항목을 점검해 AI에게 개선 포인트를 제안하므로 결과물의 완성도가 자연스럽게 올라갑니다.
505
+
506
+ 점검 결과와 캡처된 화면, 제안된 개선 포인트는 대시보드의 UI Studio 페이지에서 직접 확인하실 수 있습니다.
507
+
508
+ 평소처럼 "UI 만들어줘" 하고 요청하시면 됩니다.`,es:`Se añadió UI Studio: los agentes de IA pueden crear y editar la UI en el juego de Roblox (elementos de pantalla como ScreenGui, Frame y TextLabel) directamente.
509
+
510
+ Al iniciar una UI nueva, la IA primero ordena los requisitos —propósito, pantalla y dispositivos objetivo— mediante preguntas guiadas y luego compone el árbol de UI. Durante el trabajo se puede capturar la pantalla actual para verificar el resultado, y se inspeccionan aspectos como el tamaño de los objetivos táctiles, el contraste del texto y las zonas seguras para sugerir mejoras a la IA, por lo que el acabado del resultado mejora de forma natural.
511
+
512
+ Los resultados de la inspección, las pantallas capturadas y las mejoras sugeridas se pueden consultar directamente en la página UI Studio del dashboard.
513
+
514
+ Pide como siempre: «Hazme una UI».`,"pt-br":`O UI Studio foi adicionado: agentes de IA podem criar e editar a UI no jogo do Roblox (elementos de tela como ScreenGui, Frame e TextLabel) diretamente.
515
+
516
+ Ao iniciar uma UI nova, a IA primeiro organiza os requisitos — objetivo, tela e dispositivos-alvo — por meio de perguntas guiadas e, em seguida, monta a árvore de UI. Durante o trabalho é possível capturar a tela atual para verificar o resultado, e itens como tamanho de alvos de toque, contraste de texto e safe zones são inspecionados para sugerir melhorias à IA, então o acabamento do resultado melhora de forma natural.
517
+
518
+ Os resultados da inspeção, as telas capturadas e as melhorias sugeridas podem ser consultados diretamente na página UI Studio do dashboard.
519
+
520
+ Peça como de costume: "Crie uma UI para mim".`,ja:`AIエージェントがRobloxのゲーム内UI(ScreenGui・Frame・TextLabelなどの画面要素)を直接作成・編集できるUI Studioが追加されました。
521
+
522
+ 新しいUIを作り始めると、AIはまず目的・画面・対象デバイスといった要件をガイド付きの質問で整理してから、UIツリーを組み立てます。作業中は現在の画面をキャプチャして結果を確認でき、タッチターゲットのサイズ・テキストのコントラスト・セーフゾーンなどの項目を点検してAIに改善のヒントを提案するため、成果物の完成度が自然と高まります。
523
+
524
+ 点検結果やキャプチャされた画面、提案された改善ポイントは、ダッシュボードのUI Studioページから直接確認できます。
525
+
526
+ いつものように「UIを作って」とお願いするだけでOKです。`,id:`UI Studio kini hadir: agen AI dapat membuat dan mengedit UI dalam game Roblox (elemen layar seperti ScreenGui, Frame, dan TextLabel) secara langsung.
527
+
528
+ Saat memulai UI baru, AI lebih dulu merapikan kebutuhan — tujuan, layar, dan perangkat target — melalui pertanyaan terpandu, lalu menyusun pohon UI. Selama pengerjaan, layar saat ini dapat ditangkap untuk memeriksa hasilnya, dan hal-hal seperti ukuran target sentuh, kontras teks, serta safe zone diperiksa untuk diusulkan perbaikan kepada AI, sehingga kerapian hasilnya meningkat secara alami.
529
+
530
+ Hasil pemeriksaan, layar yang ditangkap, dan saran perbaikan dapat dilihat langsung di halaman UI Studio pada dashboard.
531
+
532
+ Minta seperti biasa: "Buatkan UI."`},severity:"info",category:"release"}],Zl="weppy-dashboard.whatsNew.readIds";function Vp(){try{const i=localStorage.getItem(Zl);if(!i)return new Set;const n=JSON.parse(i);return Array.isArray(n)?new Set(n.filter(r=>typeof r=="string")):new Set}catch{return new Set}}function DS(i){try{localStorage.setItem(Zl,JSON.stringify([...i]))}catch{}}let ci=Vp(),Gp=ci;const ql=new Set;function $p(){Gp=new Set(ci);for(const i of ql)i()}const Hl={subscribe(i){return ql.add(i),()=>{ql.delete(i)}},getSnapshot(){return Gp},markRead(i){let n=!1;for(const r of i)ci.has(r)||(ci.add(r),n=!0);n&&(DS(ci),$p())}};typeof window<"u"&&window.addEventListener("storage",i=>{i.key===Zl&&(ci=Vp(),$p())});function ES(){const i=A.useSyncExternalStore(Hl.subscribe,Hl.getSnapshot),n=IS.filter(r=>!i.has(r.id)).length;return{readSet:i,unreadCount:n,markRead:Hl.markRead}}const TS="_header_4psrj_2",jS="_row1_4psrj_17",HS="_projectIdentity_4psrj_25",US="_folderIcon_4psrj_34",zS="_projectName_4psrj_39",LS="_placeChips_4psrj_51",MS="_metaActions_4psrj_58",_S="_placeChip_4psrj_51",NS="_placeChipStatic_4psrj_81",OS="_placeChipMuted_4psrj_82",BS="_placeChipActive_4psrj_86",qS="_placeChipInactive_4psrj_93",WS="_placeChipId_4psrj_104",FS="_placeDot_4psrj_119",KS="_placeChipName_4psrj_127",YS="_row2_4psrj_135",VS="_pathGroup_4psrj_142",GS="_projectPath_4psrj_150",$S="_changeButton_4psrj_160",XS="_iconButton_4psrj_193",et={header:TS,row1:jS,projectIdentity:HS,folderIcon:US,projectName:zS,placeChips:LS,metaActions:MS,placeChip:_S,placeChipStatic:NS,placeChipMuted:OS,placeChipActive:BS,placeChipInactive:qS,placeChipId:WS,placeDot:FS,placeChipName:KS,row2:YS,pathGroup:VS,projectPath:GS,changeButton:$S,iconButton:XS},QS="_bellWrapper_tae21_2",ZS="_unreadDot_tae21_8",dp={bellWrapper:QS,unreadDot:ZS};function JS(){const{t:i}=yo(),{unreadCount:n}=ES(),{trackEvent:r}=ps(),{pathname:d,search:u}=no(),p=cs(d,u),g=n>0?`${i("header.whatsNew","What's New")} (${n})`:i("header.whatsNew","What's New");return x.jsx(Ha,{text:i("header.whatsNew.tooltip","What's New"),children:x.jsxs("span",{className:dp.bellWrapper,children:[x.jsx(ls,{to:"/whats-new","aria-label":g,className:et.iconButton,onClick:()=>r("dashboard_click_event",{click_target:"top_header_notification_bell",placement:"top_header",...p}),children:"🔔"}),n>0&&x.jsx("span",{className:dp.unreadDot,"data-testid":"unread-dot","aria-hidden":"true"})]})})}const eb="_backdrop_1ozbv_1",tb="_modal_1ozbv_12",ob="_title_1ozbv_23",ab="_message_1ozbv_30",ib="_actions_1ozbv_37",sb="_cancelButton_1ozbv_44",nb="_confirmButton_1ozbv_45",rb="_pathBlock_1ozbv_75",lb="_pathLabel_1ozbv_80",db="_pathCode_1ozbv_86",ub="_bodyGrid_1ozbv_98",cb="_warningList_1ozbv_104",pb="_errorMessage_1ozbv_111",kt={backdrop:eb,modal:tb,title:ob,message:ab,actions:ib,cancelButton:sb,confirmButton:nb,pathBlock:rb,pathLabel:lb,pathCode:db,bodyGrid:ub,warningList:cb,errorMessage:pb};function Ul(i,n){return x.jsxs("div",{className:kt.pathBlock,children:[x.jsx("span",{className:kt.pathLabel,children:i}),x.jsx("code",{className:kt.pathCode,children:n})]})}function gb(i){const r=/^[A-Z]:\\/i.test(i)||i.includes("\\")?"\\":"/";return`${i.replace(/[\\/]+$/,"")}${r}weppy-project-sync`}function hb({open:i,step:n,selectedProjectRoot:r,studioConnected:d,loading:u=!1,errorMessage:p=null,onClose:g,onPick:f,onApply:h}){const{t:y}=yo();if(!i)return null;const C=r?gb(r):"";return x.jsx("div",{className:kt.backdrop,onClick:u?void 0:g,role:"presentation",children:x.jsxs("div",{className:kt.modal,onClick:b=>b.stopPropagation(),role:"dialog","aria-modal":"true","aria-labelledby":"project-root-change-modal-title",children:[x.jsx("h2",{id:"project-root-change-modal-title",className:kt.title,children:n==="initial"?y("header.projectRootModal.initial.title","Change project root"):y("header.projectRootModal.confirm.title","Confirm new project root")}),x.jsx("p",{className:kt.message,children:n==="initial"?d?y("header.projectRootModal.initial.body.connected","MCP will switch to the new project root and resync current Studio contents into the new target."):y("header.projectRootModal.initial.body.disconnected","MCP will switch to the new project root and use the new folder as the next sync target."):y("header.projectRootModal.confirm.body","Review the selected project folder before applying.")}),x.jsxs("div",{className:kt.bodyGrid,children:[n==="initial"?x.jsxs(x.Fragment,{children:[Ul(y("header.projectRootModal.initial.nextSyncRoot","New sync target after selection"),y("header.projectRootModal.initial.nextSyncRoot.placeholder","<selected project folder>/weppy-project-sync")),x.jsxs("ul",{className:kt.warningList,children:[d?x.jsxs(x.Fragment,{children:[x.jsx("li",{children:y("header.projectRootModal.initial.warningStop","Current sync stops immediately.")}),x.jsx("li",{children:y("header.projectRootModal.initial.warningFreshSync","The current Studio contents will be used to build a fresh full sync in the new target.")})]}):x.jsx("li",{children:y("header.projectRootModal.initial.warningDeferredSync","If Studio is not connected, full resync starts the next time the plugin connects.")}),x.jsx("li",{children:y("header.projectRootModal.initial.warningNoMove","Old sync folders are not moved automatically.")})]})]}):x.jsxs(x.Fragment,{children:[Ul(y("header.projectRootModal.confirm.projectRoot","Selected project folder"),r??""),Ul(y("header.projectRootModal.confirm.syncRoot","New sync target"),C),x.jsx("p",{className:kt.message,children:y("header.projectRootModal.confirm.warningNoMove","Existing sync folders are not moved automatically.")})]}),p?x.jsx("p",{className:`${kt.message} ${kt.errorMessage}`,children:p}):null]}),x.jsxs("div",{className:kt.actions,children:[x.jsx("button",{className:kt.cancelButton,onClick:g,disabled:u,children:y("header.projectRootModal.cancel","Cancel")}),n==="initial"?x.jsx("button",{className:kt.confirmButton,onClick:f,disabled:u,children:u?"...":y("header.projectRootModal.pick","Choose folder")}):x.jsx("button",{className:kt.confirmButton,onClick:h,disabled:u||!r,children:u?"...":y("header.projectRootModal.apply","Apply change")})]})]})})}function up(i){if(!i)return"";const n=i.split(/[\\/]/).filter(Boolean);return n[n.length-1]??""}function mb(i){var d,u;const n=((d=i==null?void 0:i.mcpInstances)==null?void 0:d.filter(p=>!p.isServer&&p.aiClientName))??[];if(n.length===0){const p=((u=i==null?void 0:i.mcpInstances)==null?void 0:u.find(g=>!!g.aiClientName))??null;return(p==null?void 0:p.projectRoot)??(p==null?void 0:p.cwd)??null}n.sort((p,g)=>(g.lastCommandAt??g.connectedAt)-(p.lastCommandAt??p.connectedAt));const r=n[0];return r.projectRoot??r.cwd??null}function fb(i,n,r){return i??n??r}function yb(i){const n=i.replace(/^\//,"").split("/")[0];return n===""||n==="overview"}function vb(i){return i.replace(/^\//,"").split("/")[0]==="whats-new"}function cp(i,n){if(i&&typeof i=="object"&&"message"in i&&typeof i.message=="string"){const r=i.message.trim();if(r.length>0)return r}return n}function Sb(){var _e,pt,vo,it;const{pathname:i,search:n}=no(),{level:r,status:d}=Mn(),{t:u}=yo(),{trackEvent:p}=ps(),{show:g}=Lp(),[f,h]=A.useState(null),[y,C]=A.useState(null),[b,D]=A.useState(null),[H,O]=A.useState(!1),[z,N]=A.useState(null),[ie,F]=A.useState(null),[X,Y]=A.useState(!1),[pe,De]=A.useState(!1),[T,G]=A.useState(null),Se=u("header.placeNotConnected","Place not connected"),re=yb(i),ze=vb(i),Pe=cs(i,n);A.useEffect(()=>{let he=!1;async function ot(){if(r==="disconnected"){h(null);return}try{const ft=await zt.get("/connection-info");he||h(ft)}catch{he||h(null)}}return ot(),()=>{he=!0}},[r,d==null?void 0:d.sessionId,d==null?void 0:d.connectedClients]),A.useEffect(()=>{let he=!1;async function ot(){if(r==="disconnected"){C(null),O(!1);return}C(null),O(!1);try{const ft=await xS();he||(C(ft),O(!1))}catch{he||(C(null),O(!0))}}return ot(),()=>{he=!0}},[re,r,d==null?void 0:d.sessionId,d==null?void 0:d.connectedClients]),A.useEffect(()=>{let he=!1;async function ot(){if(r==="disconnected"){D(null);return}try{const ft=await kS();he||D(ft)}catch{he||D(null)}}return ot(),()=>{he=!0}},[r,d==null?void 0:d.sessionId,d==null?void 0:d.connectedClients]);const Le=mb(f)??"",Ce=r==="disconnected"?"blocked":y?"ready":H?"error":"loading",Qe=Ce==="ready"?(y==null?void 0:y.projectRoot)??"":Ce==="loading"?u("header.currentProject.loading","Loading project root..."):u("header.currentProject.unavailable","Project root unavailable"),tt=Ce==="ready"?(y==null?void 0:y.projectRoot)??"":re?"":Le,Me=re||Ce==="ready"?Ce==="ready"?up(tt)||u("header.unknownProject","Unknown project"):Ce==="loading"?u("header.currentProject.loading","Loading project root..."):u("header.currentProject.unavailable","Project root unavailable"):up(tt)||u("header.unknownProject","Unknown project"),q=fb((pt=(_e=d==null?void 0:d.pluginClients)==null?void 0:_e[0])==null?void 0:pt.placeName,(it=(vo=d==null?void 0:d.pluginClients)==null?void 0:vo[0])==null?void 0:it.projectName,Se),le=q===Se?u("header.placeNotConnected.tooltip","Place not connected"):u("header.place.tooltip","Connected Roblox place"),V=b!=null&&b.pluginConnected?b.activePlaceId:(b==null?void 0:b.lastActivePlaceId)??null,w=[...(b==null?void 0:b.places)??[]].sort((he,ot)=>{const ft=he.placeId===V,Rt=ot.placeId===V;return ft!==Rt?ft?-1:1:he.isConnected!==ot.isConnected?he.isConnected?-1:1:he.placeName.localeCompare(ot.placeName)}),U=re?Ce==="loading"?u("header.currentProject.loading.tooltip","Project root information is still loading"):Ce==="error"?u("header.currentProject.unavailable.tooltip","Current project root information is unavailable"):u("header.currentProject.tooltip","Currently selected project folder"):u("header.currentProject.tooltip","Currently selected project folder"),ge=r==="disconnected"||Ce!=="ready",ye=r==="disconnected"?u("header.changeProjectRoot.disabledTooltip.l0","MCP server connection required before project root can be changed"):Ce==="loading"?u("header.changeProjectRoot.disabledTooltip.loading","Project root information is still loading"):Ce==="error"?u("header.changeProjectRoot.disabledTooltip.unavailable","Current project root information is unavailable"):u("header.changeProjectRoot.tooltip","Change the current project root"),me=(he=!1)=>{!he&&(X||pe)||(N(null),F(null),G(null))},be=()=>{ge||(p("dashboard_click_event",{click_target:"project_root_change",placement:"top_header",...Pe}),G(null),F(null),N("initial"))},Ae=async()=>{Y(!0),G(null);try{const he=await AS();if(he.cancelled||!he.projectRoot){me(!0);return}F(he.projectRoot),N("confirm")}catch(he){G(cp(he,u("header.projectRootModal.error","Failed to change project root")))}finally{Y(!1)}},Re=async()=>{if(ie){De(!0),G(null);try{const he=await RS(ie);C(he),O(!1),me(!0)}catch(he){const ot=cp(he,u("header.projectRootModal.error","Failed to change project root"));G(ot),g(ot,"error")}finally{De(!1)}}};return x.jsxs(x.Fragment,{children:[x.jsxs("header",{className:et.header,children:[x.jsxs("div",{className:et.row1,children:[x.jsxs("div",{className:et.projectIdentity,children:[x.jsx(zy,{size:18,strokeWidth:1.75,"aria-hidden":"true",focusable:"false",className:et.folderIcon}),x.jsx(Ha,{text:U,children:x.jsx("h1",{className:et.projectName,children:Me})}),x.jsx("div",{className:et.placeChips,children:w.length===0?x.jsx(Ha,{text:le,children:x.jsx("span",{className:`${et.placeChip} ${et.placeChipMuted}`,children:x.jsx("span",{className:et.placeChipName,children:q})})}):w.map(he=>{const ot=he.placeId===V,ft=!!(b!=null&&b.pluginConnected)&&he.isConnected,Rt=ft?u("header.places.active","Active"):u("header.places.inactive","Inactive"),ua=[et.placeChip,et.placeChipStatic,ot&&ft?et.placeChipActive:et.placeChipInactive].filter(Boolean).join(" ");return x.jsxs("span",{className:ua,title:`${he.placeName} · ${he.placeId} (${Rt})`,children:[ot&&ft?x.jsx("span",{className:et.placeDot,"aria-hidden":"true"}):null,x.jsx("span",{className:et.placeChipName,children:he.placeName}),x.jsx("span",{className:et.placeChipId,children:he.placeId})]},`${he.placeId}:${he.placeDirName}`)})})]}),x.jsxs("div",{className:et.metaActions,children:[!ze&&x.jsx(JS,{}),x.jsx(Ha,{text:u("sidebar.settings","Settings"),children:x.jsx(ls,{to:"/settings","aria-label":u("sidebar.settings","Settings"),className:et.iconButton,onClick:()=>p("dashboard_click_event",{click_target:"top_header_settings",placement:"top_header",...Pe}),children:x.jsx(av,{size:18,strokeWidth:1.75,"aria-hidden":"true",focusable:"false"})})})]})]}),x.jsx("div",{className:et.row2,children:x.jsxs("div",{className:et.pathGroup,children:[x.jsx("span",{className:et.projectPath,title:Qe,children:Qe}),x.jsx(Ha,{text:ye,children:x.jsx("span",{children:x.jsx("button",{type:"button",className:et.changeButton,onClick:be,disabled:ge,children:u("header.changeProjectRoot","Change Project Root")})})})]})})]}),x.jsx(hb,{open:z!==null,step:z??"initial",selectedProjectRoot:ie,studioConnected:r==="studioConnected",loading:X||pe,errorMessage:T,onClose:me,onPick:Ae,onApply:Re})]})}const bb="_layout_ya8ln_2",Pb="_mainShell_ya8ln_8",Cb="_content_ya8ln_17",wb="_loading_ya8ln_25",Dn={layout:bb,mainShell:Pb,content:Cb,loading:wb};function kb(){const{pathname:i,search:n}=no(),{trackPageView:r}=ps();return A.useEffect(()=>{r(cs(i,n))},[i,n,r]),null}function xb(){const{t:i}=yo();return x.jsx("div",{className:Dn.loading,children:i("common.loading","Loading...")})}function Ab(){return x.jsx(Zf,{children:x.jsx(ry,{children:x.jsxs(Bf,{children:[x.jsx(ly,{}),x.jsx(kb,{}),x.jsxs("div",{className:Dn.layout,children:[x.jsx(wS,{}),x.jsxs("div",{className:Dn.mainShell,children:[x.jsx(Sb,{}),x.jsx("main",{className:Dn.content,children:x.jsx(A.Suspense,{fallback:x.jsx(xb,{}),children:x.jsx(nf,{})})})]})]})]})})})}function pp(i){return i.route==="/"?{index:!0,lazy:i.lazy}:{path:i.route.slice(1),lazy:i.lazy}}const Rb=mf([{path:"/",element:x.jsx(Ab,{}),children:[...Fp.map(pp),...Kp.map(pp),{path:"changelog/:id",lazy:()=>io(()=>import("./ChangelogDetailPage-BiiG5ZpO.js"),__vite__mapDeps([32,1,7,8,6,33]))},{path:"settings",lazy:()=>io(()=>import("./SettingsPage-DX6vgUTw.js"),__vite__mapDeps([34,2,3,1,6,12,25,26,35]))}]}]);Oh.createRoot(document.getElementById("root")).render(x.jsx(wf,{router:Rb}));export{Ua as A,IS as B,Un as C,Op as D,qp as E,By as I,Zy as P,Wp as R,Xf as S,hv as T,lv as X,zt as a,Db as b,Rp as c,Mn as d,Tb as e,Np as f,jb as g,Hb as h,ps as i,x as j,kS as k,no as l,pv as m,Lp as n,cs as o,Ha as p,Xe as q,A as r,Ln as s,Dy as t,yo as u,av as v,Lf as w,Eb as x,kt as y,ES as z};