454 lines
577 KiB
JavaScript
454 lines
577 KiB
JavaScript
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["./SqlEditor-Da5-w0EM.js","./SqlEditor-ClHlk_C4.css"])))=>i.map(i=>d[i]);
|
||
(function(){const t=document.createElement("link").relList;if(t&&t.supports&&t.supports("modulepreload"))return;for(const r of document.querySelectorAll('link[rel="modulepreload"]'))n(r);new MutationObserver(r=>{for(const T of r)if(T.type==="childList")for(const l of T.addedNodes)l.tagName==="LINK"&&l.rel==="modulepreload"&&n(l)}).observe(document,{childList:!0,subtree:!0});function E(r){const T={};return r.integrity&&(T.integrity=r.integrity),r.referrerPolicy&&(T.referrerPolicy=r.referrerPolicy),r.crossOrigin==="use-credentials"?T.credentials="include":r.crossOrigin==="anonymous"?T.credentials="omit":T.credentials="same-origin",T}function n(r){if(r.ep)return;r.ep=!0;const T=E(r);fetch(r.href,T)}})();var qS=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function IR(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var uR={exports:{}},tT={},cR={exports:{}},Pe={};/**
|
||
* @license React
|
||
* react.production.min.js
|
||
*
|
||
* Copyright (c) Facebook, Inc. and its affiliates.
|
||
*
|
||
* This source code is licensed under the MIT license found in the
|
||
* LICENSE file in the root directory of this source tree.
|
||
*/var Wr=Symbol.for("react.element"),eN=Symbol.for("react.portal"),tN=Symbol.for("react.fragment"),EN=Symbol.for("react.strict_mode"),nN=Symbol.for("react.profiler"),rN=Symbol.for("react.provider"),sN=Symbol.for("react.context"),TN=Symbol.for("react.forward_ref"),lN=Symbol.for("react.suspense"),aN=Symbol.for("react.memo"),oN=Symbol.for("react.lazy"),co=Symbol.iterator;function iN(e){return e===null||typeof e!="object"?null:(e=co&&e[co]||e["@@iterator"],typeof e=="function"?e:null)}var CR={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},dR=Object.assign,LR={};function Kn(e,t,E){this.props=e,this.context=t,this.refs=LR,this.updater=E||CR}Kn.prototype.isReactComponent={};Kn.prototype.setState=function(e,t){if(typeof e!="object"&&typeof e!="function"&&e!=null)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,e,t,"setState")};Kn.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")};function _R(){}_R.prototype=Kn.prototype;function La(e,t,E){this.props=e,this.context=t,this.refs=LR,this.updater=E||CR}var _a=La.prototype=new _R;_a.constructor=La;dR(_a,Kn.prototype);_a.isPureReactComponent=!0;var Co=Array.isArray,fR=Object.prototype.hasOwnProperty,fa={current:null},pR={key:!0,ref:!0,__self:!0,__source:!0};function mR(e,t,E){var n,r={},T=null,l=null;if(t!=null)for(n in t.ref!==void 0&&(l=t.ref),t.key!==void 0&&(T=""+t.key),t)fR.call(t,n)&&!pR.hasOwnProperty(n)&&(r[n]=t[n]);var a=arguments.length-2;if(a===1)r.children=E;else if(1<a){for(var i=Array(a),o=0;o<a;o++)i[o]=arguments[o+2];r.children=i}if(e&&e.defaultProps)for(n in a=e.defaultProps,a)r[n]===void 0&&(r[n]=a[n]);return{$$typeof:Wr,type:e,key:T,ref:l,props:r,_owner:fa.current}}function RN(e,t){return{$$typeof:Wr,type:e.type,key:t,ref:e.ref,props:e.props,_owner:e._owner}}function pa(e){return typeof e=="object"&&e!==null&&e.$$typeof===Wr}function AN(e){var t={"=":"=0",":":"=2"};return"$"+e.replace(/[=:]/g,function(E){return t[E]})}var Lo=/\/+/g;function mT(e,t){return typeof e=="object"&&e!==null&&e.key!=null?AN(""+e.key):t.toString(36)}function Ns(e,t,E,n,r){var T=typeof e;(T==="undefined"||T==="boolean")&&(e=null);var l=!1;if(e===null)l=!0;else switch(T){case"string":case"number":l=!0;break;case"object":switch(e.$$typeof){case Wr:case eN:l=!0}}if(l)return l=e,r=r(l),e=n===""?"."+mT(l,0):n,Co(r)?(E="",e!=null&&(E=e.replace(Lo,"$&/")+"/"),Ns(r,t,E,"",function(o){return o})):r!=null&&(pa(r)&&(r=RN(r,E+(!r.key||l&&l.key===r.key?"":(""+r.key).replace(Lo,"$&/")+"/")+e)),t.push(r)),1;if(l=0,n=n===""?".":n+":",Co(e))for(var a=0;a<e.length;a++){T=e[a];var i=n+mT(T,a);l+=Ns(T,t,E,i,r)}else if(i=iN(e),typeof i=="function")for(e=i.call(e),a=0;!(T=e.next()).done;)T=T.value,i=n+mT(T,a++),l+=Ns(T,t,E,i,r);else if(T==="object")throw t=String(e),Error("Objects are not valid as a React child (found: "+(t==="[object Object]"?"object with keys {"+Object.keys(e).join(", ")+"}":t)+"). If you meant to render a collection of children, use an array instead.");return l}function zr(e,t,E){if(e==null)return e;var n=[],r=0;return Ns(e,n,"","",function(T){return t.call(E,T,r++)}),n}function SN(e){if(e._status===-1){var t=e._result;t=t(),t.then(function(E){(e._status===0||e._status===-1)&&(e._status=1,e._result=E)},function(E){(e._status===0||e._status===-1)&&(e._status=2,e._result=E)}),e._status===-1&&(e._status=0,e._result=t)}if(e._status===1)return e._result.default;throw e._result}var ft={current:null},Is={transition:null},NN={ReactCurrentDispatcher:ft,ReactCurrentBatchConfig:Is,ReactCurrentOwner:fa};function DR(){throw Error("act(...) is not supported in production builds of React.")}Pe.Children={map:zr,forEach:function(e,t,E){zr(e,function(){t.apply(this,arguments)},E)},count:function(e){var t=0;return zr(e,function(){t++}),t},toArray:function(e){return zr(e,function(t){return t})||[]},only:function(e){if(!pa(e))throw Error("React.Children.only expected to receive a single React element child.");return e}};Pe.Component=Kn;Pe.Fragment=tN;Pe.Profiler=nN;Pe.PureComponent=La;Pe.StrictMode=EN;Pe.Suspense=lN;Pe.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=NN;Pe.act=DR;Pe.cloneElement=function(e,t,E){if(e==null)throw Error("React.cloneElement(...): The argument must be a React element, but you passed "+e+".");var n=dR({},e.props),r=e.key,T=e.ref,l=e._owner;if(t!=null){if(t.ref!==void 0&&(T=t.ref,l=fa.current),t.key!==void 0&&(r=""+t.key),e.type&&e.type.defaultProps)var a=e.type.defaultProps;for(i in t)fR.call(t,i)&&!pR.hasOwnProperty(i)&&(n[i]=t[i]===void 0&&a!==void 0?a[i]:t[i])}var i=arguments.length-2;if(i===1)n.children=E;else if(1<i){a=Array(i);for(var o=0;o<i;o++)a[o]=arguments[o+2];n.children=a}return{$$typeof:Wr,type:e.type,key:r,ref:T,props:n,_owner:l}};Pe.createContext=function(e){return e={$$typeof:sN,_currentValue:e,_currentValue2:e,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null},e.Provider={$$typeof:rN,_context:e},e.Consumer=e};Pe.createElement=mR;Pe.createFactory=function(e){var t=mR.bind(null,e);return t.type=e,t};Pe.createRef=function(){return{current:null}};Pe.forwardRef=function(e){return{$$typeof:TN,render:e}};Pe.isValidElement=pa;Pe.lazy=function(e){return{$$typeof:oN,_payload:{_status:-1,_result:e},_init:SN}};Pe.memo=function(e,t){return{$$typeof:aN,type:e,compare:t===void 0?null:t}};Pe.startTransition=function(e){var t=Is.transition;Is.transition={};try{e()}finally{Is.transition=t}};Pe.unstable_act=DR;Pe.useCallback=function(e,t){return ft.current.useCallback(e,t)};Pe.useContext=function(e){return ft.current.useContext(e)};Pe.useDebugValue=function(){};Pe.useDeferredValue=function(e){return ft.current.useDeferredValue(e)};Pe.useEffect=function(e,t){return ft.current.useEffect(e,t)};Pe.useId=function(){return ft.current.useId()};Pe.useImperativeHandle=function(e,t,E){return ft.current.useImperativeHandle(e,t,E)};Pe.useInsertionEffect=function(e,t){return ft.current.useInsertionEffect(e,t)};Pe.useLayoutEffect=function(e,t){return ft.current.useLayoutEffect(e,t)};Pe.useMemo=function(e,t){return ft.current.useMemo(e,t)};Pe.useReducer=function(e,t,E){return ft.current.useReducer(e,t,E)};Pe.useRef=function(e){return ft.current.useRef(e)};Pe.useState=function(e){return ft.current.useState(e)};Pe.useSyncExternalStore=function(e,t,E){return ft.current.useSyncExternalStore(e,t,E)};Pe.useTransition=function(){return ft.current.useTransition()};Pe.version="18.3.1";cR.exports=Pe;var u=cR.exports;const IN=IR(u);/**
|
||
* @license React
|
||
* react-jsx-runtime.production.min.js
|
||
*
|
||
* Copyright (c) Facebook, Inc. and its affiliates.
|
||
*
|
||
* This source code is licensed under the MIT license found in the
|
||
* LICENSE file in the root directory of this source tree.
|
||
*/var uN=u,ON=Symbol.for("react.element"),cN=Symbol.for("react.fragment"),CN=Object.prototype.hasOwnProperty,dN=uN.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,LN={key:!0,ref:!0,__self:!0,__source:!0};function PR(e,t,E){var n,r={},T=null,l=null;E!==void 0&&(T=""+E),t.key!==void 0&&(T=""+t.key),t.ref!==void 0&&(l=t.ref);for(n in t)CN.call(t,n)&&!LN.hasOwnProperty(n)&&(r[n]=t[n]);if(e&&e.defaultProps)for(n in t=e.defaultProps,t)r[n]===void 0&&(r[n]=t[n]);return{$$typeof:ON,type:e,key:T,ref:l,props:r,_owner:dN.current}}tT.Fragment=cN;tT.jsx=PR;tT.jsxs=PR;uR.exports=tT;var s=uR.exports,fl={},hR={exports:{}},Bt={},MR={exports:{}},UR={};/**
|
||
* @license React
|
||
* scheduler.production.min.js
|
||
*
|
||
* Copyright (c) Facebook, Inc. and its affiliates.
|
||
*
|
||
* This source code is licensed under the MIT license found in the
|
||
* LICENSE file in the root directory of this source tree.
|
||
*/(function(e){function t(b,U){var J=b.length;b.push(U);e:for(;0<J;){var Ee=J-1>>>1,ce=b[Ee];if(0<r(ce,U))b[Ee]=U,b[J]=ce,J=Ee;else break e}}function E(b){return b.length===0?null:b[0]}function n(b){if(b.length===0)return null;var U=b[0],J=b.pop();if(J!==U){b[0]=J;e:for(var Ee=0,ce=b.length,ye=ce>>>1;Ee<ye;){var me=2*(Ee+1)-1,De=b[me],Ne=me+1,se=b[Ne];if(0>r(De,J))Ne<ce&&0>r(se,De)?(b[Ee]=se,b[Ne]=J,Ee=Ne):(b[Ee]=De,b[me]=J,Ee=me);else if(Ne<ce&&0>r(se,J))b[Ee]=se,b[Ne]=J,Ee=Ne;else break e}}return U}function r(b,U){var J=b.sortIndex-U.sortIndex;return J!==0?J:b.id-U.id}if(typeof performance=="object"&&typeof performance.now=="function"){var T=performance;e.unstable_now=function(){return T.now()}}else{var l=Date,a=l.now();e.unstable_now=function(){return l.now()-a}}var i=[],o=[],S=1,N=null,R=3,O=!1,L=!1,_=!1,H=typeof setTimeout=="function"?setTimeout:null,c=typeof clearTimeout=="function"?clearTimeout:null,A=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function I(b){for(var U=E(o);U!==null;){if(U.callback===null)n(o);else if(U.startTime<=b)n(o),U.sortIndex=U.expirationTime,t(i,U);else break;U=E(o)}}function C(b){if(_=!1,I(b),!L)if(E(i)!==null)L=!0,j(M);else{var U=E(o);U!==null&&ee(C,U.startTime-b)}}function M(b,U){L=!1,_&&(_=!1,c(D),D=-1),O=!0;var J=R;try{for(I(U),N=E(i);N!==null&&(!(N.expirationTime>U)||b&&!ne());){var Ee=N.callback;if(typeof Ee=="function"){N.callback=null,R=N.priorityLevel;var ce=Ee(N.expirationTime<=U);U=e.unstable_now(),typeof ce=="function"?N.callback=ce:N===E(i)&&n(i),I(U)}else n(i);N=E(i)}if(N!==null)var ye=!0;else{var me=E(o);me!==null&&ee(C,me.startTime-U),ye=!1}return ye}finally{N=null,R=J,O=!1}}var p=!1,P=null,D=-1,Z=5,Y=-1;function ne(){return!(e.unstable_now()-Y<Z)}function xe(){if(P!==null){var b=e.unstable_now();Y=b;var U=!0;try{U=P(!0,b)}finally{U?Se():(p=!1,P=null)}}else p=!1}var Se;if(typeof A=="function")Se=function(){A(xe)};else if(typeof MessageChannel<"u"){var he=new MessageChannel,B=he.port2;he.port1.onmessage=xe,Se=function(){B.postMessage(null)}}else Se=function(){H(xe,0)};function j(b){P=b,p||(p=!0,Se())}function ee(b,U){D=H(function(){b(e.unstable_now())},U)}e.unstable_IdlePriority=5,e.unstable_ImmediatePriority=1,e.unstable_LowPriority=4,e.unstable_NormalPriority=3,e.unstable_Profiling=null,e.unstable_UserBlockingPriority=2,e.unstable_cancelCallback=function(b){b.callback=null},e.unstable_continueExecution=function(){L||O||(L=!0,j(M))},e.unstable_forceFrameRate=function(b){0>b||125<b?console.error("forceFrameRate takes a positive int between 0 and 125, forcing frame rates higher than 125 fps is not supported"):Z=0<b?Math.floor(1e3/b):5},e.unstable_getCurrentPriorityLevel=function(){return R},e.unstable_getFirstCallbackNode=function(){return E(i)},e.unstable_next=function(b){switch(R){case 1:case 2:case 3:var U=3;break;default:U=R}var J=R;R=U;try{return b()}finally{R=J}},e.unstable_pauseExecution=function(){},e.unstable_requestPaint=function(){},e.unstable_runWithPriority=function(b,U){switch(b){case 1:case 2:case 3:case 4:case 5:break;default:b=3}var J=R;R=b;try{return U()}finally{R=J}},e.unstable_scheduleCallback=function(b,U,J){var Ee=e.unstable_now();switch(typeof J=="object"&&J!==null?(J=J.delay,J=typeof J=="number"&&0<J?Ee+J:Ee):J=Ee,b){case 1:var ce=-1;break;case 2:ce=250;break;case 5:ce=1073741823;break;case 4:ce=1e4;break;default:ce=5e3}return ce=J+ce,b={id:S++,callback:U,priorityLevel:b,startTime:J,expirationTime:ce,sortIndex:-1},J>Ee?(b.sortIndex=J,t(o,b),E(i)===null&&b===E(o)&&(_?(c(D),D=-1):_=!0,ee(C,J-Ee))):(b.sortIndex=ce,t(i,b),L||O||(L=!0,j(M))),b},e.unstable_shouldYield=ne,e.unstable_wrapCallback=function(b){var U=R;return function(){var J=R;R=U;try{return b.apply(this,arguments)}finally{R=J}}}})(UR);MR.exports=UR;var _N=MR.exports;/**
|
||
* @license React
|
||
* react-dom.production.min.js
|
||
*
|
||
* Copyright (c) Facebook, Inc. and its affiliates.
|
||
*
|
||
* This source code is licensed under the MIT license found in the
|
||
* LICENSE file in the root directory of this source tree.
|
||
*/var fN=u,Ht=_N;function z(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,E=1;E<arguments.length;E++)t+="&args[]="+encodeURIComponent(arguments[E]);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 xR=new Set,mr={};function Sn(e,t){Yn(e,t),Yn(e+"Capture",t)}function Yn(e,t){for(mr[e]=t,e=0;e<t.length;e++)xR.add(t[e])}var OE=!(typeof window>"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),pl=Object.prototype.hasOwnProperty,pN=/^[: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]*$/,_o={},fo={};function mN(e){return pl.call(fo,e)?!0:pl.call(_o,e)?!1:pN.test(e)?fo[e]=!0:(_o[e]=!0,!1)}function DN(e,t,E,n){if(E!==null&&E.type===0)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return n?!1:E!==null?!E.acceptsBooleans:(e=e.toLowerCase().slice(0,5),e!=="data-"&&e!=="aria-");default:return!1}}function PN(e,t,E,n){if(t===null||typeof t>"u"||DN(e,t,E,n))return!0;if(n)return!1;if(E!==null)switch(E.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 pt(e,t,E,n,r,T,l){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=n,this.attributeNamespace=r,this.mustUseProperty=E,this.propertyName=e,this.type=t,this.sanitizeURL=T,this.removeEmptyString=l}var St={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){St[e]=new pt(e,0,!1,e,null,!1,!1)});[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];St[t]=new pt(t,1,!1,e[1],null,!1,!1)});["contentEditable","draggable","spellCheck","value"].forEach(function(e){St[e]=new pt(e,2,!1,e.toLowerCase(),null,!1,!1)});["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){St[e]=new pt(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){St[e]=new pt(e,3,!1,e.toLowerCase(),null,!1,!1)});["checked","multiple","muted","selected"].forEach(function(e){St[e]=new pt(e,3,!0,e,null,!1,!1)});["capture","download"].forEach(function(e){St[e]=new pt(e,4,!1,e,null,!1,!1)});["cols","rows","size","span"].forEach(function(e){St[e]=new pt(e,6,!1,e,null,!1,!1)});["rowSpan","start"].forEach(function(e){St[e]=new pt(e,5,!1,e.toLowerCase(),null,!1,!1)});var ma=/[\-:]([a-z])/g;function Da(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(ma,Da);St[t]=new pt(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(ma,Da);St[t]=new pt(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(ma,Da);St[t]=new pt(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)});["tabIndex","crossOrigin"].forEach(function(e){St[e]=new pt(e,1,!1,e.toLowerCase(),null,!1,!1)});St.xlinkHref=new pt("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1);["src","href","action","formAction"].forEach(function(e){St[e]=new pt(e,1,!1,e.toLowerCase(),null,!0,!0)});function Pa(e,t,E,n){var r=St.hasOwnProperty(t)?St[t]:null;(r!==null?r.type!==0:n||!(2<t.length)||t[0]!=="o"&&t[0]!=="O"||t[1]!=="n"&&t[1]!=="N")&&(PN(t,E,r,n)&&(E=null),n||r===null?mN(t)&&(E===null?e.removeAttribute(t):e.setAttribute(t,""+E)):r.mustUseProperty?e[r.propertyName]=E===null?r.type===3?!1:"":E:(t=r.attributeName,n=r.attributeNamespace,E===null?e.removeAttribute(t):(r=r.type,E=r===3||r===4&&E===!0?"":""+E,n?e.setAttributeNS(n,t,E):e.setAttribute(t,E))))}var _E=fN.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,Qr=Symbol.for("react.element"),dn=Symbol.for("react.portal"),Ln=Symbol.for("react.fragment"),ha=Symbol.for("react.strict_mode"),ml=Symbol.for("react.profiler"),yR=Symbol.for("react.provider"),gR=Symbol.for("react.context"),Ma=Symbol.for("react.forward_ref"),Dl=Symbol.for("react.suspense"),Pl=Symbol.for("react.suspense_list"),Ua=Symbol.for("react.memo"),PE=Symbol.for("react.lazy"),GR=Symbol.for("react.offscreen"),po=Symbol.iterator;function Er(e){return e===null||typeof e!="object"?null:(e=po&&e[po]||e["@@iterator"],typeof e=="function"?e:null)}var ze=Object.assign,DT;function Rr(e){if(DT===void 0)try{throw Error()}catch(E){var t=E.stack.trim().match(/\n( *(at )?)/);DT=t&&t[1]||""}return`
|
||
`+DT+e}var PT=!1;function hT(e,t){if(!e||PT)return"";PT=!0;var E=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(o){var n=o}Reflect.construct(e,[],t)}else{try{t.call()}catch(o){n=o}e.call(t.prototype)}else{try{throw Error()}catch(o){n=o}e()}}catch(o){if(o&&n&&typeof o.stack=="string"){for(var r=o.stack.split(`
|
||
`),T=n.stack.split(`
|
||
`),l=r.length-1,a=T.length-1;1<=l&&0<=a&&r[l]!==T[a];)a--;for(;1<=l&&0<=a;l--,a--)if(r[l]!==T[a]){if(l!==1||a!==1)do if(l--,a--,0>a||r[l]!==T[a]){var i=`
|
||
`+r[l].replace(" at new "," at ");return e.displayName&&i.includes("<anonymous>")&&(i=i.replace("<anonymous>",e.displayName)),i}while(1<=l&&0<=a);break}}}finally{PT=!1,Error.prepareStackTrace=E}return(e=e?e.displayName||e.name:"")?Rr(e):""}function hN(e){switch(e.tag){case 5:return Rr(e.type);case 16:return Rr("Lazy");case 13:return Rr("Suspense");case 19:return Rr("SuspenseList");case 0:case 2:case 15:return e=hT(e.type,!1),e;case 11:return e=hT(e.type.render,!1),e;case 1:return e=hT(e.type,!0),e;default:return""}}function hl(e){if(e==null)return null;if(typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case Ln:return"Fragment";case dn:return"Portal";case ml:return"Profiler";case ha:return"StrictMode";case Dl:return"Suspense";case Pl:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case gR:return(e.displayName||"Context")+".Consumer";case yR:return(e._context.displayName||"Context")+".Provider";case Ma:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case Ua:return t=e.displayName||null,t!==null?t:hl(e.type)||"Memo";case PE:t=e._payload,e=e._init;try{return hl(e(t))}catch{}}return null}function MN(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 hl(t);case 8:return t===ha?"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 bE(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function vR(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function UN(e){var t=vR(e)?"checked":"value",E=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),n=""+e[t];if(!e.hasOwnProperty(t)&&typeof E<"u"&&typeof E.get=="function"&&typeof E.set=="function"){var r=E.get,T=E.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return r.call(this)},set:function(l){n=""+l,T.call(this,l)}}),Object.defineProperty(e,t,{enumerable:E.enumerable}),{getValue:function(){return n},setValue:function(l){n=""+l},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function Zr(e){e._valueTracker||(e._valueTracker=UN(e))}function HR(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var E=t.getValue(),n="";return e&&(n=vR(e)?e.checked?"true":"false":e.value),e=n,e!==E?(t.setValue(e),!0):!1}function Ms(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 Ml(e,t){var E=t.checked;return ze({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:E??e._wrapperState.initialChecked})}function mo(e,t){var E=t.defaultValue==null?"":t.defaultValue,n=t.checked!=null?t.checked:t.defaultChecked;E=bE(t.value!=null?t.value:E),e._wrapperState={initialChecked:n,initialValue:E,controlled:t.type==="checkbox"||t.type==="radio"?t.checked!=null:t.value!=null}}function BR(e,t){t=t.checked,t!=null&&Pa(e,"checked",t,!1)}function Ul(e,t){BR(e,t);var E=bE(t.value),n=t.type;if(E!=null)n==="number"?(E===0&&e.value===""||e.value!=E)&&(e.value=""+E):e.value!==""+E&&(e.value=""+E);else if(n==="submit"||n==="reset"){e.removeAttribute("value");return}t.hasOwnProperty("value")?xl(e,t.type,E):t.hasOwnProperty("defaultValue")&&xl(e,t.type,bE(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function Do(e,t,E){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var n=t.type;if(!(n!=="submit"&&n!=="reset"||t.value!==void 0&&t.value!==null))return;t=""+e._wrapperState.initialValue,E||t===e.value||(e.value=t),e.defaultValue=t}E=e.name,E!==""&&(e.name=""),e.defaultChecked=!!e._wrapperState.initialChecked,E!==""&&(e.name=E)}function xl(e,t,E){(t!=="number"||Ms(e.ownerDocument)!==e)&&(E==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+E&&(e.defaultValue=""+E))}var Ar=Array.isArray;function yn(e,t,E,n){if(e=e.options,t){t={};for(var r=0;r<E.length;r++)t["$"+E[r]]=!0;for(E=0;E<e.length;E++)r=t.hasOwnProperty("$"+e[E].value),e[E].selected!==r&&(e[E].selected=r),r&&n&&(e[E].defaultSelected=!0)}else{for(E=""+bE(E),t=null,r=0;r<e.length;r++){if(e[r].value===E){e[r].selected=!0,n&&(e[r].defaultSelected=!0);return}t!==null||e[r].disabled||(t=e[r])}t!==null&&(t.selected=!0)}}function yl(e,t){if(t.dangerouslySetInnerHTML!=null)throw Error(z(91));return ze({},t,{value:void 0,defaultValue:void 0,children:""+e._wrapperState.initialValue})}function Po(e,t){var E=t.value;if(E==null){if(E=t.children,t=t.defaultValue,E!=null){if(t!=null)throw Error(z(92));if(Ar(E)){if(1<E.length)throw Error(z(93));E=E[0]}t=E}t==null&&(t=""),E=t}e._wrapperState={initialValue:bE(E)}}function FR(e,t){var E=bE(t.value),n=bE(t.defaultValue);E!=null&&(E=""+E,E!==e.value&&(e.value=E),t.defaultValue==null&&e.defaultValue!==E&&(e.defaultValue=E)),n!=null&&(e.defaultValue=""+n)}function ho(e){var t=e.textContent;t===e._wrapperState.initialValue&&t!==""&&t!==null&&(e.value=t)}function YR(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 gl(e,t){return e==null||e==="http://www.w3.org/1999/xhtml"?YR(t):e==="http://www.w3.org/2000/svg"&&t==="foreignObject"?"http://www.w3.org/1999/xhtml":e}var qr,wR=function(e){return typeof MSApp<"u"&&MSApp.execUnsafeLocalFunction?function(t,E,n,r){MSApp.execUnsafeLocalFunction(function(){return e(t,E,n,r)})}:e}(function(e,t){if(e.namespaceURI!=="http://www.w3.org/2000/svg"||"innerHTML"in e)e.innerHTML=t;else{for(qr=qr||document.createElement("div"),qr.innerHTML="<svg>"+t.valueOf().toString()+"</svg>",t=qr.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function Dr(e,t){if(t){var E=e.firstChild;if(E&&E===e.lastChild&&E.nodeType===3){E.nodeValue=t;return}}e.textContent=t}var Ir={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},xN=["Webkit","ms","Moz","O"];Object.keys(Ir).forEach(function(e){xN.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),Ir[t]=Ir[e]})});function bR(e,t,E){return t==null||typeof t=="boolean"||t===""?"":E||typeof t!="number"||t===0||Ir.hasOwnProperty(e)&&Ir[e]?(""+t).trim():t+"px"}function VR(e,t){e=e.style;for(var E in t)if(t.hasOwnProperty(E)){var n=E.indexOf("--")===0,r=bR(E,t[E],n);E==="float"&&(E="cssFloat"),n?e.setProperty(E,r):e[E]=r}}var yN=ze({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 Gl(e,t){if(t){if(yN[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(z(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(z(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(z(61))}if(t.style!=null&&typeof t.style!="object")throw Error(z(62))}}function vl(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 Hl=null;function xa(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var Bl=null,gn=null,Gn=null;function Mo(e){if(e=kr(e)){if(typeof Bl!="function")throw Error(z(280));var t=e.stateNode;t&&(t=TT(t),Bl(e.stateNode,e.type,t))}}function WR(e){gn?Gn?Gn.push(e):Gn=[e]:gn=e}function XR(){if(gn){var e=gn,t=Gn;if(Gn=gn=null,Mo(e),t)for(e=0;e<t.length;e++)Mo(t[e])}}function jR(e,t){return e(t)}function kR(){}var MT=!1;function KR(e,t,E){if(MT)return e(t,E);MT=!0;try{return jR(e,t,E)}finally{MT=!1,(gn!==null||Gn!==null)&&(kR(),XR())}}function Pr(e,t){var E=e.stateNode;if(E===null)return null;var n=TT(E);if(n===null)return null;E=n[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":(n=!n.disabled)||(e=e.type,n=!(e==="button"||e==="input"||e==="select"||e==="textarea")),e=!n;break e;default:e=!1}if(e)return null;if(E&&typeof E!="function")throw Error(z(231,t,typeof E));return E}var Fl=!1;if(OE)try{var nr={};Object.defineProperty(nr,"passive",{get:function(){Fl=!0}}),window.addEventListener("test",nr,nr),window.removeEventListener("test",nr,nr)}catch{Fl=!1}function gN(e,t,E,n,r,T,l,a,i){var o=Array.prototype.slice.call(arguments,3);try{t.apply(E,o)}catch(S){this.onError(S)}}var ur=!1,Us=null,xs=!1,Yl=null,GN={onError:function(e){ur=!0,Us=e}};function vN(e,t,E,n,r,T,l,a,i){ur=!1,Us=null,gN.apply(GN,arguments)}function HN(e,t,E,n,r,T,l,a,i){if(vN.apply(this,arguments),ur){if(ur){var o=Us;ur=!1,Us=null}else throw Error(z(198));xs||(xs=!0,Yl=o)}}function Nn(e){var t=e,E=e;if(e.alternate)for(;t.return;)t=t.return;else{e=t;do t=e,t.flags&4098&&(E=t.return),e=t.return;while(e)}return t.tag===3?E:null}function $R(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 Uo(e){if(Nn(e)!==e)throw Error(z(188))}function BN(e){var t=e.alternate;if(!t){if(t=Nn(e),t===null)throw Error(z(188));return t!==e?null:e}for(var E=e,n=t;;){var r=E.return;if(r===null)break;var T=r.alternate;if(T===null){if(n=r.return,n!==null){E=n;continue}break}if(r.child===T.child){for(T=r.child;T;){if(T===E)return Uo(r),e;if(T===n)return Uo(r),t;T=T.sibling}throw Error(z(188))}if(E.return!==n.return)E=r,n=T;else{for(var l=!1,a=r.child;a;){if(a===E){l=!0,E=r,n=T;break}if(a===n){l=!0,n=r,E=T;break}a=a.sibling}if(!l){for(a=T.child;a;){if(a===E){l=!0,E=T,n=r;break}if(a===n){l=!0,n=T,E=r;break}a=a.sibling}if(!l)throw Error(z(189))}}if(E.alternate!==n)throw Error(z(190))}if(E.tag!==3)throw Error(z(188));return E.stateNode.current===E?e:t}function JR(e){return e=BN(e),e!==null?zR(e):null}function zR(e){if(e.tag===5||e.tag===6)return e;for(e=e.child;e!==null;){var t=zR(e);if(t!==null)return t;e=e.sibling}return null}var QR=Ht.unstable_scheduleCallback,xo=Ht.unstable_cancelCallback,FN=Ht.unstable_shouldYield,YN=Ht.unstable_requestPaint,tt=Ht.unstable_now,wN=Ht.unstable_getCurrentPriorityLevel,ya=Ht.unstable_ImmediatePriority,ZR=Ht.unstable_UserBlockingPriority,ys=Ht.unstable_NormalPriority,bN=Ht.unstable_LowPriority,qR=Ht.unstable_IdlePriority,ET=null,TE=null;function VN(e){if(TE&&typeof TE.onCommitFiberRoot=="function")try{TE.onCommitFiberRoot(ET,e,void 0,(e.current.flags&128)===128)}catch{}}var Qt=Math.clz32?Math.clz32:jN,WN=Math.log,XN=Math.LN2;function jN(e){return e>>>=0,e===0?32:31-(WN(e)/XN|0)|0}var es=64,ts=4194304;function Sr(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 gs(e,t){var E=e.pendingLanes;if(E===0)return 0;var n=0,r=e.suspendedLanes,T=e.pingedLanes,l=E&268435455;if(l!==0){var a=l&~r;a!==0?n=Sr(a):(T&=l,T!==0&&(n=Sr(T)))}else l=E&~r,l!==0?n=Sr(l):T!==0&&(n=Sr(T));if(n===0)return 0;if(t!==0&&t!==n&&!(t&r)&&(r=n&-n,T=t&-t,r>=T||r===16&&(T&4194240)!==0))return t;if(n&4&&(n|=E&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=n;0<t;)E=31-Qt(t),r=1<<E,n|=e[E],t&=~r;return n}function kN(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 KN(e,t){for(var E=e.suspendedLanes,n=e.pingedLanes,r=e.expirationTimes,T=e.pendingLanes;0<T;){var l=31-Qt(T),a=1<<l,i=r[l];i===-1?(!(a&E)||a&n)&&(r[l]=kN(a,t)):i<=t&&(e.expiredLanes|=a),T&=~a}}function wl(e){return e=e.pendingLanes&-1073741825,e!==0?e:e&1073741824?1073741824:0}function eA(){var e=es;return es<<=1,!(es&4194240)&&(es=64),e}function UT(e){for(var t=[],E=0;31>E;E++)t.push(e);return t}function Xr(e,t,E){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-Qt(t),e[t]=E}function $N(e,t){var E=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 n=e.eventTimes;for(e=e.expirationTimes;0<E;){var r=31-Qt(E),T=1<<r;t[r]=0,n[r]=-1,e[r]=-1,E&=~T}}function ga(e,t){var E=e.entangledLanes|=t;for(e=e.entanglements;E;){var n=31-Qt(E),r=1<<n;r&t|e[n]&t&&(e[n]|=t),E&=~r}}var He=0;function tA(e){return e&=-e,1<e?4<e?e&268435455?16:536870912:4:1}var EA,Ga,nA,rA,sA,bl=!1,Es=[],gE=null,GE=null,vE=null,hr=new Map,Mr=new Map,ME=[],JN="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 yo(e,t){switch(e){case"focusin":case"focusout":gE=null;break;case"dragenter":case"dragleave":GE=null;break;case"mouseover":case"mouseout":vE=null;break;case"pointerover":case"pointerout":hr.delete(t.pointerId);break;case"gotpointercapture":case"lostpointercapture":Mr.delete(t.pointerId)}}function rr(e,t,E,n,r,T){return e===null||e.nativeEvent!==T?(e={blockedOn:t,domEventName:E,eventSystemFlags:n,nativeEvent:T,targetContainers:[r]},t!==null&&(t=kr(t),t!==null&&Ga(t)),e):(e.eventSystemFlags|=n,t=e.targetContainers,r!==null&&t.indexOf(r)===-1&&t.push(r),e)}function zN(e,t,E,n,r){switch(t){case"focusin":return gE=rr(gE,e,t,E,n,r),!0;case"dragenter":return GE=rr(GE,e,t,E,n,r),!0;case"mouseover":return vE=rr(vE,e,t,E,n,r),!0;case"pointerover":var T=r.pointerId;return hr.set(T,rr(hr.get(T)||null,e,t,E,n,r)),!0;case"gotpointercapture":return T=r.pointerId,Mr.set(T,rr(Mr.get(T)||null,e,t,E,n,r)),!0}return!1}function TA(e){var t=tn(e.target);if(t!==null){var E=Nn(t);if(E!==null){if(t=E.tag,t===13){if(t=$R(E),t!==null){e.blockedOn=t,sA(e.priority,function(){nA(E)});return}}else if(t===3&&E.stateNode.current.memoizedState.isDehydrated){e.blockedOn=E.tag===3?E.stateNode.containerInfo:null;return}}}e.blockedOn=null}function us(e){if(e.blockedOn!==null)return!1;for(var t=e.targetContainers;0<t.length;){var E=Vl(e.domEventName,e.eventSystemFlags,t[0],e.nativeEvent);if(E===null){E=e.nativeEvent;var n=new E.constructor(E.type,E);Hl=n,E.target.dispatchEvent(n),Hl=null}else return t=kr(E),t!==null&&Ga(t),e.blockedOn=E,!1;t.shift()}return!0}function go(e,t,E){us(e)&&E.delete(t)}function QN(){bl=!1,gE!==null&&us(gE)&&(gE=null),GE!==null&&us(GE)&&(GE=null),vE!==null&&us(vE)&&(vE=null),hr.forEach(go),Mr.forEach(go)}function sr(e,t){e.blockedOn===t&&(e.blockedOn=null,bl||(bl=!0,Ht.unstable_scheduleCallback(Ht.unstable_NormalPriority,QN)))}function Ur(e){function t(r){return sr(r,e)}if(0<Es.length){sr(Es[0],e);for(var E=1;E<Es.length;E++){var n=Es[E];n.blockedOn===e&&(n.blockedOn=null)}}for(gE!==null&&sr(gE,e),GE!==null&&sr(GE,e),vE!==null&&sr(vE,e),hr.forEach(t),Mr.forEach(t),E=0;E<ME.length;E++)n=ME[E],n.blockedOn===e&&(n.blockedOn=null);for(;0<ME.length&&(E=ME[0],E.blockedOn===null);)TA(E),E.blockedOn===null&&ME.shift()}var vn=_E.ReactCurrentBatchConfig,Gs=!0;function ZN(e,t,E,n){var r=He,T=vn.transition;vn.transition=null;try{He=1,va(e,t,E,n)}finally{He=r,vn.transition=T}}function qN(e,t,E,n){var r=He,T=vn.transition;vn.transition=null;try{He=4,va(e,t,E,n)}finally{He=r,vn.transition=T}}function va(e,t,E,n){if(Gs){var r=Vl(e,t,E,n);if(r===null)wT(e,t,n,vs,E),yo(e,n);else if(zN(r,e,t,E,n))n.stopPropagation();else if(yo(e,n),t&4&&-1<JN.indexOf(e)){for(;r!==null;){var T=kr(r);if(T!==null&&EA(T),T=Vl(e,t,E,n),T===null&&wT(e,t,n,vs,E),T===r)break;r=T}r!==null&&n.stopPropagation()}else wT(e,t,n,null,E)}}var vs=null;function Vl(e,t,E,n){if(vs=null,e=xa(n),e=tn(e),e!==null)if(t=Nn(e),t===null)e=null;else if(E=t.tag,E===13){if(e=$R(t),e!==null)return e;e=null}else if(E===3){if(t.stateNode.current.memoizedState.isDehydrated)return t.tag===3?t.stateNode.containerInfo:null;e=null}else t!==e&&(e=null);return vs=e,null}function lA(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(wN()){case ya:return 1;case ZR:return 4;case ys:case bN:return 16;case qR:return 536870912;default:return 16}default:return 16}}var xE=null,Ha=null,Os=null;function aA(){if(Os)return Os;var e,t=Ha,E=t.length,n,r="value"in xE?xE.value:xE.textContent,T=r.length;for(e=0;e<E&&t[e]===r[e];e++);var l=E-e;for(n=1;n<=l&&t[E-n]===r[T-n];n++);return Os=r.slice(e,1<n?1-n:void 0)}function cs(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 ns(){return!0}function Go(){return!1}function Ft(e){function t(E,n,r,T,l){this._reactName=E,this._targetInst=r,this.type=n,this.nativeEvent=T,this.target=l,this.currentTarget=null;for(var a in e)e.hasOwnProperty(a)&&(E=e[a],this[a]=E?E(T):T[a]);return this.isDefaultPrevented=(T.defaultPrevented!=null?T.defaultPrevented:T.returnValue===!1)?ns:Go,this.isPropagationStopped=Go,this}return ze(t.prototype,{preventDefault:function(){this.defaultPrevented=!0;var E=this.nativeEvent;E&&(E.preventDefault?E.preventDefault():typeof E.returnValue!="unknown"&&(E.returnValue=!1),this.isDefaultPrevented=ns)},stopPropagation:function(){var E=this.nativeEvent;E&&(E.stopPropagation?E.stopPropagation():typeof E.cancelBubble!="unknown"&&(E.cancelBubble=!0),this.isPropagationStopped=ns)},persist:function(){},isPersistent:ns}),t}var $n={eventPhase:0,bubbles:0,cancelable:0,timeStamp:function(e){return e.timeStamp||Date.now()},defaultPrevented:0,isTrusted:0},Ba=Ft($n),jr=ze({},$n,{view:0,detail:0}),eI=Ft(jr),xT,yT,Tr,nT=ze({},jr,{screenX:0,screenY:0,clientX:0,clientY:0,pageX:0,pageY:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,getModifierState:Fa,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!==Tr&&(Tr&&e.type==="mousemove"?(xT=e.screenX-Tr.screenX,yT=e.screenY-Tr.screenY):yT=xT=0,Tr=e),xT)},movementY:function(e){return"movementY"in e?e.movementY:yT}}),vo=Ft(nT),tI=ze({},nT,{dataTransfer:0}),EI=Ft(tI),nI=ze({},jr,{relatedTarget:0}),gT=Ft(nI),rI=ze({},$n,{animationName:0,elapsedTime:0,pseudoElement:0}),sI=Ft(rI),TI=ze({},$n,{clipboardData:function(e){return"clipboardData"in e?e.clipboardData:window.clipboardData}}),lI=Ft(TI),aI=ze({},$n,{data:0}),Ho=Ft(aI),oI={Esc:"Escape",Spacebar:" ",Left:"ArrowLeft",Up:"ArrowUp",Right:"ArrowRight",Down:"ArrowDown",Del:"Delete",Win:"OS",Menu:"ContextMenu",Apps:"ContextMenu",Scroll:"ScrollLock",MozPrintableKey:"Unidentified"},iI={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"},RI={Alt:"altKey",Control:"ctrlKey",Meta:"metaKey",Shift:"shiftKey"};function AI(e){var t=this.nativeEvent;return t.getModifierState?t.getModifierState(e):(e=RI[e])?!!t[e]:!1}function Fa(){return AI}var SI=ze({},jr,{key:function(e){if(e.key){var t=oI[e.key]||e.key;if(t!=="Unidentified")return t}return e.type==="keypress"?(e=cs(e),e===13?"Enter":String.fromCharCode(e)):e.type==="keydown"||e.type==="keyup"?iI[e.keyCode]||"Unidentified":""},code:0,location:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,repeat:0,locale:0,getModifierState:Fa,charCode:function(e){return e.type==="keypress"?cs(e):0},keyCode:function(e){return e.type==="keydown"||e.type==="keyup"?e.keyCode:0},which:function(e){return e.type==="keypress"?cs(e):e.type==="keydown"||e.type==="keyup"?e.keyCode:0}}),NI=Ft(SI),II=ze({},nT,{pointerId:0,width:0,height:0,pressure:0,tangentialPressure:0,tiltX:0,tiltY:0,twist:0,pointerType:0,isPrimary:0}),Bo=Ft(II),uI=ze({},jr,{touches:0,targetTouches:0,changedTouches:0,altKey:0,metaKey:0,ctrlKey:0,shiftKey:0,getModifierState:Fa}),OI=Ft(uI),cI=ze({},$n,{propertyName:0,elapsedTime:0,pseudoElement:0}),CI=Ft(cI),dI=ze({},nT,{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}),LI=Ft(dI),_I=[9,13,27,32],Ya=OE&&"CompositionEvent"in window,Or=null;OE&&"documentMode"in document&&(Or=document.documentMode);var fI=OE&&"TextEvent"in window&&!Or,oA=OE&&(!Ya||Or&&8<Or&&11>=Or),Fo=" ",Yo=!1;function iA(e,t){switch(e){case"keyup":return _I.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function RA(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var _n=!1;function pI(e,t){switch(e){case"compositionend":return RA(t);case"keypress":return t.which!==32?null:(Yo=!0,Fo);case"textInput":return e=t.data,e===Fo&&Yo?null:e;default:return null}}function mI(e,t){if(_n)return e==="compositionend"||!Ya&&iA(e,t)?(e=aA(),Os=Ha=xE=null,_n=!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 oA&&t.locale!=="ko"?null:t.data;default:return null}}var DI={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 wo(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t==="input"?!!DI[e.type]:t==="textarea"}function AA(e,t,E,n){WR(n),t=Hs(t,"onChange"),0<t.length&&(E=new Ba("onChange","change",null,E,n),e.push({event:E,listeners:t}))}var cr=null,xr=null;function PI(e){fA(e,0)}function rT(e){var t=mn(e);if(HR(t))return e}function hI(e,t){if(e==="change")return t}var SA=!1;if(OE){var GT;if(OE){var vT="oninput"in document;if(!vT){var bo=document.createElement("div");bo.setAttribute("oninput","return;"),vT=typeof bo.oninput=="function"}GT=vT}else GT=!1;SA=GT&&(!document.documentMode||9<document.documentMode)}function Vo(){cr&&(cr.detachEvent("onpropertychange",NA),xr=cr=null)}function NA(e){if(e.propertyName==="value"&&rT(xr)){var t=[];AA(t,xr,e,xa(e)),KR(PI,t)}}function MI(e,t,E){e==="focusin"?(Vo(),cr=t,xr=E,cr.attachEvent("onpropertychange",NA)):e==="focusout"&&Vo()}function UI(e){if(e==="selectionchange"||e==="keyup"||e==="keydown")return rT(xr)}function xI(e,t){if(e==="click")return rT(t)}function yI(e,t){if(e==="input"||e==="change")return rT(t)}function gI(e,t){return e===t&&(e!==0||1/e===1/t)||e!==e&&t!==t}var eE=typeof Object.is=="function"?Object.is:gI;function yr(e,t){if(eE(e,t))return!0;if(typeof e!="object"||e===null||typeof t!="object"||t===null)return!1;var E=Object.keys(e),n=Object.keys(t);if(E.length!==n.length)return!1;for(n=0;n<E.length;n++){var r=E[n];if(!pl.call(t,r)||!eE(e[r],t[r]))return!1}return!0}function Wo(e){for(;e&&e.firstChild;)e=e.firstChild;return e}function Xo(e,t){var E=Wo(e);e=0;for(var n;E;){if(E.nodeType===3){if(n=e+E.textContent.length,e<=t&&n>=t)return{node:E,offset:t-e};e=n}e:{for(;E;){if(E.nextSibling){E=E.nextSibling;break e}E=E.parentNode}E=void 0}E=Wo(E)}}function IA(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?IA(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function uA(){for(var e=window,t=Ms();t instanceof e.HTMLIFrameElement;){try{var E=typeof t.contentWindow.location.href=="string"}catch{E=!1}if(E)e=t.contentWindow;else break;t=Ms(e.document)}return t}function wa(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 GI(e){var t=uA(),E=e.focusedElem,n=e.selectionRange;if(t!==E&&E&&E.ownerDocument&&IA(E.ownerDocument.documentElement,E)){if(n!==null&&wa(E)){if(t=n.start,e=n.end,e===void 0&&(e=t),"selectionStart"in E)E.selectionStart=t,E.selectionEnd=Math.min(e,E.value.length);else if(e=(t=E.ownerDocument||document)&&t.defaultView||window,e.getSelection){e=e.getSelection();var r=E.textContent.length,T=Math.min(n.start,r);n=n.end===void 0?T:Math.min(n.end,r),!e.extend&&T>n&&(r=n,n=T,T=r),r=Xo(E,T);var l=Xo(E,n);r&&l&&(e.rangeCount!==1||e.anchorNode!==r.node||e.anchorOffset!==r.offset||e.focusNode!==l.node||e.focusOffset!==l.offset)&&(t=t.createRange(),t.setStart(r.node,r.offset),e.removeAllRanges(),T>n?(e.addRange(t),e.extend(l.node,l.offset)):(t.setEnd(l.node,l.offset),e.addRange(t)))}}for(t=[],e=E;e=e.parentNode;)e.nodeType===1&&t.push({element:e,left:e.scrollLeft,top:e.scrollTop});for(typeof E.focus=="function"&&E.focus(),E=0;E<t.length;E++)e=t[E],e.element.scrollLeft=e.left,e.element.scrollTop=e.top}}var vI=OE&&"documentMode"in document&&11>=document.documentMode,fn=null,Wl=null,Cr=null,Xl=!1;function jo(e,t,E){var n=E.window===E?E.document:E.nodeType===9?E:E.ownerDocument;Xl||fn==null||fn!==Ms(n)||(n=fn,"selectionStart"in n&&wa(n)?n={start:n.selectionStart,end:n.selectionEnd}:(n=(n.ownerDocument&&n.ownerDocument.defaultView||window).getSelection(),n={anchorNode:n.anchorNode,anchorOffset:n.anchorOffset,focusNode:n.focusNode,focusOffset:n.focusOffset}),Cr&&yr(Cr,n)||(Cr=n,n=Hs(Wl,"onSelect"),0<n.length&&(t=new Ba("onSelect","select",null,t,E),e.push({event:t,listeners:n}),t.target=fn)))}function rs(e,t){var E={};return E[e.toLowerCase()]=t.toLowerCase(),E["Webkit"+e]="webkit"+t,E["Moz"+e]="moz"+t,E}var pn={animationend:rs("Animation","AnimationEnd"),animationiteration:rs("Animation","AnimationIteration"),animationstart:rs("Animation","AnimationStart"),transitionend:rs("Transition","TransitionEnd")},HT={},OA={};OE&&(OA=document.createElement("div").style,"AnimationEvent"in window||(delete pn.animationend.animation,delete pn.animationiteration.animation,delete pn.animationstart.animation),"TransitionEvent"in window||delete pn.transitionend.transition);function sT(e){if(HT[e])return HT[e];if(!pn[e])return e;var t=pn[e],E;for(E in t)if(t.hasOwnProperty(E)&&E in OA)return HT[e]=t[E];return e}var cA=sT("animationend"),CA=sT("animationiteration"),dA=sT("animationstart"),LA=sT("transitionend"),_A=new Map,ko="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 XE(e,t){_A.set(e,t),Sn(t,[e])}for(var BT=0;BT<ko.length;BT++){var FT=ko[BT],HI=FT.toLowerCase(),BI=FT[0].toUpperCase()+FT.slice(1);XE(HI,"on"+BI)}XE(cA,"onAnimationEnd");XE(CA,"onAnimationIteration");XE(dA,"onAnimationStart");XE("dblclick","onDoubleClick");XE("focusin","onFocus");XE("focusout","onBlur");XE(LA,"onTransitionEnd");Yn("onMouseEnter",["mouseout","mouseover"]);Yn("onMouseLeave",["mouseout","mouseover"]);Yn("onPointerEnter",["pointerout","pointerover"]);Yn("onPointerLeave",["pointerout","pointerover"]);Sn("onChange","change click focusin focusout input keydown keyup selectionchange".split(" "));Sn("onSelect","focusout contextmenu dragend focusin keydown keyup mousedown mouseup selectionchange".split(" "));Sn("onBeforeInput",["compositionend","keypress","textInput","paste"]);Sn("onCompositionEnd","compositionend focusout keydown keypress keyup mousedown".split(" "));Sn("onCompositionStart","compositionstart focusout keydown keypress keyup mousedown".split(" "));Sn("onCompositionUpdate","compositionupdate focusout keydown keypress keyup mousedown".split(" "));var Nr="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(" "),FI=new Set("cancel close invalid load scroll toggle".split(" ").concat(Nr));function Ko(e,t,E){var n=e.type||"unknown-event";e.currentTarget=E,HN(n,t,void 0,e),e.currentTarget=null}function fA(e,t){t=(t&4)!==0;for(var E=0;E<e.length;E++){var n=e[E],r=n.event;n=n.listeners;e:{var T=void 0;if(t)for(var l=n.length-1;0<=l;l--){var a=n[l],i=a.instance,o=a.currentTarget;if(a=a.listener,i!==T&&r.isPropagationStopped())break e;Ko(r,a,o),T=i}else for(l=0;l<n.length;l++){if(a=n[l],i=a.instance,o=a.currentTarget,a=a.listener,i!==T&&r.isPropagationStopped())break e;Ko(r,a,o),T=i}}}if(xs)throw e=Yl,xs=!1,Yl=null,e}function be(e,t){var E=t[Jl];E===void 0&&(E=t[Jl]=new Set);var n=e+"__bubble";E.has(n)||(pA(t,e,2,!1),E.add(n))}function YT(e,t,E){var n=0;t&&(n|=4),pA(E,e,n,t)}var ss="_reactListening"+Math.random().toString(36).slice(2);function gr(e){if(!e[ss]){e[ss]=!0,xR.forEach(function(E){E!=="selectionchange"&&(FI.has(E)||YT(E,!1,e),YT(E,!0,e))});var t=e.nodeType===9?e:e.ownerDocument;t===null||t[ss]||(t[ss]=!0,YT("selectionchange",!1,t))}}function pA(e,t,E,n){switch(lA(t)){case 1:var r=ZN;break;case 4:r=qN;break;default:r=va}E=r.bind(null,t,E,e),r=void 0,!Fl||t!=="touchstart"&&t!=="touchmove"&&t!=="wheel"||(r=!0),n?r!==void 0?e.addEventListener(t,E,{capture:!0,passive:r}):e.addEventListener(t,E,!0):r!==void 0?e.addEventListener(t,E,{passive:r}):e.addEventListener(t,E,!1)}function wT(e,t,E,n,r){var T=n;if(!(t&1)&&!(t&2)&&n!==null)e:for(;;){if(n===null)return;var l=n.tag;if(l===3||l===4){var a=n.stateNode.containerInfo;if(a===r||a.nodeType===8&&a.parentNode===r)break;if(l===4)for(l=n.return;l!==null;){var i=l.tag;if((i===3||i===4)&&(i=l.stateNode.containerInfo,i===r||i.nodeType===8&&i.parentNode===r))return;l=l.return}for(;a!==null;){if(l=tn(a),l===null)return;if(i=l.tag,i===5||i===6){n=T=l;continue e}a=a.parentNode}}n=n.return}KR(function(){var o=T,S=xa(E),N=[];e:{var R=_A.get(e);if(R!==void 0){var O=Ba,L=e;switch(e){case"keypress":if(cs(E)===0)break e;case"keydown":case"keyup":O=NI;break;case"focusin":L="focus",O=gT;break;case"focusout":L="blur",O=gT;break;case"beforeblur":case"afterblur":O=gT;break;case"click":if(E.button===2)break e;case"auxclick":case"dblclick":case"mousedown":case"mousemove":case"mouseup":case"mouseout":case"mouseover":case"contextmenu":O=vo;break;case"drag":case"dragend":case"dragenter":case"dragexit":case"dragleave":case"dragover":case"dragstart":case"drop":O=EI;break;case"touchcancel":case"touchend":case"touchmove":case"touchstart":O=OI;break;case cA:case CA:case dA:O=sI;break;case LA:O=CI;break;case"scroll":O=eI;break;case"wheel":O=LI;break;case"copy":case"cut":case"paste":O=lI;break;case"gotpointercapture":case"lostpointercapture":case"pointercancel":case"pointerdown":case"pointermove":case"pointerout":case"pointerover":case"pointerup":O=Bo}var _=(t&4)!==0,H=!_&&e==="scroll",c=_?R!==null?R+"Capture":null:R;_=[];for(var A=o,I;A!==null;){I=A;var C=I.stateNode;if(I.tag===5&&C!==null&&(I=C,c!==null&&(C=Pr(A,c),C!=null&&_.push(Gr(A,C,I)))),H)break;A=A.return}0<_.length&&(R=new O(R,L,null,E,S),N.push({event:R,listeners:_}))}}if(!(t&7)){e:{if(R=e==="mouseover"||e==="pointerover",O=e==="mouseout"||e==="pointerout",R&&E!==Hl&&(L=E.relatedTarget||E.fromElement)&&(tn(L)||L[cE]))break e;if((O||R)&&(R=S.window===S?S:(R=S.ownerDocument)?R.defaultView||R.parentWindow:window,O?(L=E.relatedTarget||E.toElement,O=o,L=L?tn(L):null,L!==null&&(H=Nn(L),L!==H||L.tag!==5&&L.tag!==6)&&(L=null)):(O=null,L=o),O!==L)){if(_=vo,C="onMouseLeave",c="onMouseEnter",A="mouse",(e==="pointerout"||e==="pointerover")&&(_=Bo,C="onPointerLeave",c="onPointerEnter",A="pointer"),H=O==null?R:mn(O),I=L==null?R:mn(L),R=new _(C,A+"leave",O,E,S),R.target=H,R.relatedTarget=I,C=null,tn(S)===o&&(_=new _(c,A+"enter",L,E,S),_.target=I,_.relatedTarget=H,C=_),H=C,O&&L)t:{for(_=O,c=L,A=0,I=_;I;I=On(I))A++;for(I=0,C=c;C;C=On(C))I++;for(;0<A-I;)_=On(_),A--;for(;0<I-A;)c=On(c),I--;for(;A--;){if(_===c||c!==null&&_===c.alternate)break t;_=On(_),c=On(c)}_=null}else _=null;O!==null&&$o(N,R,O,_,!1),L!==null&&H!==null&&$o(N,H,L,_,!0)}}e:{if(R=o?mn(o):window,O=R.nodeName&&R.nodeName.toLowerCase(),O==="select"||O==="input"&&R.type==="file")var M=hI;else if(wo(R))if(SA)M=yI;else{M=UI;var p=MI}else(O=R.nodeName)&&O.toLowerCase()==="input"&&(R.type==="checkbox"||R.type==="radio")&&(M=xI);if(M&&(M=M(e,o))){AA(N,M,E,S);break e}p&&p(e,R,o),e==="focusout"&&(p=R._wrapperState)&&p.controlled&&R.type==="number"&&xl(R,"number",R.value)}switch(p=o?mn(o):window,e){case"focusin":(wo(p)||p.contentEditable==="true")&&(fn=p,Wl=o,Cr=null);break;case"focusout":Cr=Wl=fn=null;break;case"mousedown":Xl=!0;break;case"contextmenu":case"mouseup":case"dragend":Xl=!1,jo(N,E,S);break;case"selectionchange":if(vI)break;case"keydown":case"keyup":jo(N,E,S)}var P;if(Ya)e:{switch(e){case"compositionstart":var D="onCompositionStart";break e;case"compositionend":D="onCompositionEnd";break e;case"compositionupdate":D="onCompositionUpdate";break e}D=void 0}else _n?iA(e,E)&&(D="onCompositionEnd"):e==="keydown"&&E.keyCode===229&&(D="onCompositionStart");D&&(oA&&E.locale!=="ko"&&(_n||D!=="onCompositionStart"?D==="onCompositionEnd"&&_n&&(P=aA()):(xE=S,Ha="value"in xE?xE.value:xE.textContent,_n=!0)),p=Hs(o,D),0<p.length&&(D=new Ho(D,e,null,E,S),N.push({event:D,listeners:p}),P?D.data=P:(P=RA(E),P!==null&&(D.data=P)))),(P=fI?pI(e,E):mI(e,E))&&(o=Hs(o,"onBeforeInput"),0<o.length&&(S=new Ho("onBeforeInput","beforeinput",null,E,S),N.push({event:S,listeners:o}),S.data=P))}fA(N,t)})}function Gr(e,t,E){return{instance:e,listener:t,currentTarget:E}}function Hs(e,t){for(var E=t+"Capture",n=[];e!==null;){var r=e,T=r.stateNode;r.tag===5&&T!==null&&(r=T,T=Pr(e,E),T!=null&&n.unshift(Gr(e,T,r)),T=Pr(e,t),T!=null&&n.push(Gr(e,T,r))),e=e.return}return n}function On(e){if(e===null)return null;do e=e.return;while(e&&e.tag!==5);return e||null}function $o(e,t,E,n,r){for(var T=t._reactName,l=[];E!==null&&E!==n;){var a=E,i=a.alternate,o=a.stateNode;if(i!==null&&i===n)break;a.tag===5&&o!==null&&(a=o,r?(i=Pr(E,T),i!=null&&l.unshift(Gr(E,i,a))):r||(i=Pr(E,T),i!=null&&l.push(Gr(E,i,a)))),E=E.return}l.length!==0&&e.push({event:t,listeners:l})}var YI=/\r\n?/g,wI=/\u0000|\uFFFD/g;function Jo(e){return(typeof e=="string"?e:""+e).replace(YI,`
|
||
`).replace(wI,"")}function Ts(e,t,E){if(t=Jo(t),Jo(e)!==t&&E)throw Error(z(425))}function Bs(){}var jl=null,kl=null;function Kl(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 $l=typeof setTimeout=="function"?setTimeout:void 0,bI=typeof clearTimeout=="function"?clearTimeout:void 0,zo=typeof Promise=="function"?Promise:void 0,VI=typeof queueMicrotask=="function"?queueMicrotask:typeof zo<"u"?function(e){return zo.resolve(null).then(e).catch(WI)}:$l;function WI(e){setTimeout(function(){throw e})}function bT(e,t){var E=t,n=0;do{var r=E.nextSibling;if(e.removeChild(E),r&&r.nodeType===8)if(E=r.data,E==="/$"){if(n===0){e.removeChild(r),Ur(t);return}n--}else E!=="$"&&E!=="$?"&&E!=="$!"||n++;E=r}while(E);Ur(t)}function HE(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 Qo(e){e=e.previousSibling;for(var t=0;e;){if(e.nodeType===8){var E=e.data;if(E==="$"||E==="$!"||E==="$?"){if(t===0)return e;t--}else E==="/$"&&t++}e=e.previousSibling}return null}var Jn=Math.random().toString(36).slice(2),sE="__reactFiber$"+Jn,vr="__reactProps$"+Jn,cE="__reactContainer$"+Jn,Jl="__reactEvents$"+Jn,XI="__reactListeners$"+Jn,jI="__reactHandles$"+Jn;function tn(e){var t=e[sE];if(t)return t;for(var E=e.parentNode;E;){if(t=E[cE]||E[sE]){if(E=t.alternate,t.child!==null||E!==null&&E.child!==null)for(e=Qo(e);e!==null;){if(E=e[sE])return E;e=Qo(e)}return t}e=E,E=e.parentNode}return null}function kr(e){return e=e[sE]||e[cE],!e||e.tag!==5&&e.tag!==6&&e.tag!==13&&e.tag!==3?null:e}function mn(e){if(e.tag===5||e.tag===6)return e.stateNode;throw Error(z(33))}function TT(e){return e[vr]||null}var zl=[],Dn=-1;function jE(e){return{current:e}}function Ve(e){0>Dn||(e.current=zl[Dn],zl[Dn]=null,Dn--)}function Fe(e,t){Dn++,zl[Dn]=e.current,e.current=t}var VE={},Ct=jE(VE),Pt=jE(!1),Tn=VE;function wn(e,t){var E=e.type.contextTypes;if(!E)return VE;var n=e.stateNode;if(n&&n.__reactInternalMemoizedUnmaskedChildContext===t)return n.__reactInternalMemoizedMaskedChildContext;var r={},T;for(T in E)r[T]=t[T];return n&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=r),r}function ht(e){return e=e.childContextTypes,e!=null}function Fs(){Ve(Pt),Ve(Ct)}function Zo(e,t,E){if(Ct.current!==VE)throw Error(z(168));Fe(Ct,t),Fe(Pt,E)}function mA(e,t,E){var n=e.stateNode;if(t=t.childContextTypes,typeof n.getChildContext!="function")return E;n=n.getChildContext();for(var r in n)if(!(r in t))throw Error(z(108,MN(e)||"Unknown",r));return ze({},E,n)}function Ys(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||VE,Tn=Ct.current,Fe(Ct,e),Fe(Pt,Pt.current),!0}function qo(e,t,E){var n=e.stateNode;if(!n)throw Error(z(169));E?(e=mA(e,t,Tn),n.__reactInternalMemoizedMergedChildContext=e,Ve(Pt),Ve(Ct),Fe(Ct,e)):Ve(Pt),Fe(Pt,E)}var AE=null,lT=!1,VT=!1;function DA(e){AE===null?AE=[e]:AE.push(e)}function kI(e){lT=!0,DA(e)}function kE(){if(!VT&&AE!==null){VT=!0;var e=0,t=He;try{var E=AE;for(He=1;e<E.length;e++){var n=E[e];do n=n(!0);while(n!==null)}AE=null,lT=!1}catch(r){throw AE!==null&&(AE=AE.slice(e+1)),QR(ya,kE),r}finally{He=t,VT=!1}}return null}var Pn=[],hn=0,ws=null,bs=0,wt=[],bt=0,ln=null,SE=1,NE="";function ZE(e,t){Pn[hn++]=bs,Pn[hn++]=ws,ws=e,bs=t}function PA(e,t,E){wt[bt++]=SE,wt[bt++]=NE,wt[bt++]=ln,ln=e;var n=SE;e=NE;var r=32-Qt(n)-1;n&=~(1<<r),E+=1;var T=32-Qt(t)+r;if(30<T){var l=r-r%5;T=(n&(1<<l)-1).toString(32),n>>=l,r-=l,SE=1<<32-Qt(t)+r|E<<r|n,NE=T+e}else SE=1<<T|E<<r|n,NE=e}function ba(e){e.return!==null&&(ZE(e,1),PA(e,1,0))}function Va(e){for(;e===ws;)ws=Pn[--hn],Pn[hn]=null,bs=Pn[--hn],Pn[hn]=null;for(;e===ln;)ln=wt[--bt],wt[bt]=null,NE=wt[--bt],wt[bt]=null,SE=wt[--bt],wt[bt]=null}var vt=null,gt=null,ke=!1,zt=null;function hA(e,t){var E=Wt(5,null,null,0);E.elementType="DELETED",E.stateNode=t,E.return=e,t=e.deletions,t===null?(e.deletions=[E],e.flags|=16):t.push(E)}function ei(e,t){switch(e.tag){case 5:var E=e.type;return t=t.nodeType!==1||E.toLowerCase()!==t.nodeName.toLowerCase()?null:t,t!==null?(e.stateNode=t,vt=e,gt=HE(t.firstChild),!0):!1;case 6:return t=e.pendingProps===""||t.nodeType!==3?null:t,t!==null?(e.stateNode=t,vt=e,gt=null,!0):!1;case 13:return t=t.nodeType!==8?null:t,t!==null?(E=ln!==null?{id:SE,overflow:NE}:null,e.memoizedState={dehydrated:t,treeContext:E,retryLane:1073741824},E=Wt(18,null,null,0),E.stateNode=t,E.return=e,e.child=E,vt=e,gt=null,!0):!1;default:return!1}}function Ql(e){return(e.mode&1)!==0&&(e.flags&128)===0}function Zl(e){if(ke){var t=gt;if(t){var E=t;if(!ei(e,t)){if(Ql(e))throw Error(z(418));t=HE(E.nextSibling);var n=vt;t&&ei(e,t)?hA(n,E):(e.flags=e.flags&-4097|2,ke=!1,vt=e)}}else{if(Ql(e))throw Error(z(418));e.flags=e.flags&-4097|2,ke=!1,vt=e}}}function ti(e){for(e=e.return;e!==null&&e.tag!==5&&e.tag!==3&&e.tag!==13;)e=e.return;vt=e}function ls(e){if(e!==vt)return!1;if(!ke)return ti(e),ke=!0,!1;var t;if((t=e.tag!==3)&&!(t=e.tag!==5)&&(t=e.type,t=t!=="head"&&t!=="body"&&!Kl(e.type,e.memoizedProps)),t&&(t=gt)){if(Ql(e))throw MA(),Error(z(418));for(;t;)hA(e,t),t=HE(t.nextSibling)}if(ti(e),e.tag===13){if(e=e.memoizedState,e=e!==null?e.dehydrated:null,!e)throw Error(z(317));e:{for(e=e.nextSibling,t=0;e;){if(e.nodeType===8){var E=e.data;if(E==="/$"){if(t===0){gt=HE(e.nextSibling);break e}t--}else E!=="$"&&E!=="$!"&&E!=="$?"||t++}e=e.nextSibling}gt=null}}else gt=vt?HE(e.stateNode.nextSibling):null;return!0}function MA(){for(var e=gt;e;)e=HE(e.nextSibling)}function bn(){gt=vt=null,ke=!1}function Wa(e){zt===null?zt=[e]:zt.push(e)}var KI=_E.ReactCurrentBatchConfig;function lr(e,t,E){if(e=E.ref,e!==null&&typeof e!="function"&&typeof e!="object"){if(E._owner){if(E=E._owner,E){if(E.tag!==1)throw Error(z(309));var n=E.stateNode}if(!n)throw Error(z(147,e));var r=n,T=""+e;return t!==null&&t.ref!==null&&typeof t.ref=="function"&&t.ref._stringRef===T?t.ref:(t=function(l){var a=r.refs;l===null?delete a[T]:a[T]=l},t._stringRef=T,t)}if(typeof e!="string")throw Error(z(284));if(!E._owner)throw Error(z(290,e))}return e}function as(e,t){throw e=Object.prototype.toString.call(t),Error(z(31,e==="[object Object]"?"object with keys {"+Object.keys(t).join(", ")+"}":e))}function Ei(e){var t=e._init;return t(e._payload)}function UA(e){function t(c,A){if(e){var I=c.deletions;I===null?(c.deletions=[A],c.flags|=16):I.push(A)}}function E(c,A){if(!e)return null;for(;A!==null;)t(c,A),A=A.sibling;return null}function n(c,A){for(c=new Map;A!==null;)A.key!==null?c.set(A.key,A):c.set(A.index,A),A=A.sibling;return c}function r(c,A){return c=wE(c,A),c.index=0,c.sibling=null,c}function T(c,A,I){return c.index=I,e?(I=c.alternate,I!==null?(I=I.index,I<A?(c.flags|=2,A):I):(c.flags|=2,A)):(c.flags|=1048576,A)}function l(c){return e&&c.alternate===null&&(c.flags|=2),c}function a(c,A,I,C){return A===null||A.tag!==6?(A=JT(I,c.mode,C),A.return=c,A):(A=r(A,I),A.return=c,A)}function i(c,A,I,C){var M=I.type;return M===Ln?S(c,A,I.props.children,C,I.key):A!==null&&(A.elementType===M||typeof M=="object"&&M!==null&&M.$$typeof===PE&&Ei(M)===A.type)?(C=r(A,I.props),C.ref=lr(c,A,I),C.return=c,C):(C=ms(I.type,I.key,I.props,null,c.mode,C),C.ref=lr(c,A,I),C.return=c,C)}function o(c,A,I,C){return A===null||A.tag!==4||A.stateNode.containerInfo!==I.containerInfo||A.stateNode.implementation!==I.implementation?(A=zT(I,c.mode,C),A.return=c,A):(A=r(A,I.children||[]),A.return=c,A)}function S(c,A,I,C,M){return A===null||A.tag!==7?(A=sn(I,c.mode,C,M),A.return=c,A):(A=r(A,I),A.return=c,A)}function N(c,A,I){if(typeof A=="string"&&A!==""||typeof A=="number")return A=JT(""+A,c.mode,I),A.return=c,A;if(typeof A=="object"&&A!==null){switch(A.$$typeof){case Qr:return I=ms(A.type,A.key,A.props,null,c.mode,I),I.ref=lr(c,null,A),I.return=c,I;case dn:return A=zT(A,c.mode,I),A.return=c,A;case PE:var C=A._init;return N(c,C(A._payload),I)}if(Ar(A)||Er(A))return A=sn(A,c.mode,I,null),A.return=c,A;as(c,A)}return null}function R(c,A,I,C){var M=A!==null?A.key:null;if(typeof I=="string"&&I!==""||typeof I=="number")return M!==null?null:a(c,A,""+I,C);if(typeof I=="object"&&I!==null){switch(I.$$typeof){case Qr:return I.key===M?i(c,A,I,C):null;case dn:return I.key===M?o(c,A,I,C):null;case PE:return M=I._init,R(c,A,M(I._payload),C)}if(Ar(I)||Er(I))return M!==null?null:S(c,A,I,C,null);as(c,I)}return null}function O(c,A,I,C,M){if(typeof C=="string"&&C!==""||typeof C=="number")return c=c.get(I)||null,a(A,c,""+C,M);if(typeof C=="object"&&C!==null){switch(C.$$typeof){case Qr:return c=c.get(C.key===null?I:C.key)||null,i(A,c,C,M);case dn:return c=c.get(C.key===null?I:C.key)||null,o(A,c,C,M);case PE:var p=C._init;return O(c,A,I,p(C._payload),M)}if(Ar(C)||Er(C))return c=c.get(I)||null,S(A,c,C,M,null);as(A,C)}return null}function L(c,A,I,C){for(var M=null,p=null,P=A,D=A=0,Z=null;P!==null&&D<I.length;D++){P.index>D?(Z=P,P=null):Z=P.sibling;var Y=R(c,P,I[D],C);if(Y===null){P===null&&(P=Z);break}e&&P&&Y.alternate===null&&t(c,P),A=T(Y,A,D),p===null?M=Y:p.sibling=Y,p=Y,P=Z}if(D===I.length)return E(c,P),ke&&ZE(c,D),M;if(P===null){for(;D<I.length;D++)P=N(c,I[D],C),P!==null&&(A=T(P,A,D),p===null?M=P:p.sibling=P,p=P);return ke&&ZE(c,D),M}for(P=n(c,P);D<I.length;D++)Z=O(P,c,D,I[D],C),Z!==null&&(e&&Z.alternate!==null&&P.delete(Z.key===null?D:Z.key),A=T(Z,A,D),p===null?M=Z:p.sibling=Z,p=Z);return e&&P.forEach(function(ne){return t(c,ne)}),ke&&ZE(c,D),M}function _(c,A,I,C){var M=Er(I);if(typeof M!="function")throw Error(z(150));if(I=M.call(I),I==null)throw Error(z(151));for(var p=M=null,P=A,D=A=0,Z=null,Y=I.next();P!==null&&!Y.done;D++,Y=I.next()){P.index>D?(Z=P,P=null):Z=P.sibling;var ne=R(c,P,Y.value,C);if(ne===null){P===null&&(P=Z);break}e&&P&&ne.alternate===null&&t(c,P),A=T(ne,A,D),p===null?M=ne:p.sibling=ne,p=ne,P=Z}if(Y.done)return E(c,P),ke&&ZE(c,D),M;if(P===null){for(;!Y.done;D++,Y=I.next())Y=N(c,Y.value,C),Y!==null&&(A=T(Y,A,D),p===null?M=Y:p.sibling=Y,p=Y);return ke&&ZE(c,D),M}for(P=n(c,P);!Y.done;D++,Y=I.next())Y=O(P,c,D,Y.value,C),Y!==null&&(e&&Y.alternate!==null&&P.delete(Y.key===null?D:Y.key),A=T(Y,A,D),p===null?M=Y:p.sibling=Y,p=Y);return e&&P.forEach(function(xe){return t(c,xe)}),ke&&ZE(c,D),M}function H(c,A,I,C){if(typeof I=="object"&&I!==null&&I.type===Ln&&I.key===null&&(I=I.props.children),typeof I=="object"&&I!==null){switch(I.$$typeof){case Qr:e:{for(var M=I.key,p=A;p!==null;){if(p.key===M){if(M=I.type,M===Ln){if(p.tag===7){E(c,p.sibling),A=r(p,I.props.children),A.return=c,c=A;break e}}else if(p.elementType===M||typeof M=="object"&&M!==null&&M.$$typeof===PE&&Ei(M)===p.type){E(c,p.sibling),A=r(p,I.props),A.ref=lr(c,p,I),A.return=c,c=A;break e}E(c,p);break}else t(c,p);p=p.sibling}I.type===Ln?(A=sn(I.props.children,c.mode,C,I.key),A.return=c,c=A):(C=ms(I.type,I.key,I.props,null,c.mode,C),C.ref=lr(c,A,I),C.return=c,c=C)}return l(c);case dn:e:{for(p=I.key;A!==null;){if(A.key===p)if(A.tag===4&&A.stateNode.containerInfo===I.containerInfo&&A.stateNode.implementation===I.implementation){E(c,A.sibling),A=r(A,I.children||[]),A.return=c,c=A;break e}else{E(c,A);break}else t(c,A);A=A.sibling}A=zT(I,c.mode,C),A.return=c,c=A}return l(c);case PE:return p=I._init,H(c,A,p(I._payload),C)}if(Ar(I))return L(c,A,I,C);if(Er(I))return _(c,A,I,C);as(c,I)}return typeof I=="string"&&I!==""||typeof I=="number"?(I=""+I,A!==null&&A.tag===6?(E(c,A.sibling),A=r(A,I),A.return=c,c=A):(E(c,A),A=JT(I,c.mode,C),A.return=c,c=A),l(c)):E(c,A)}return H}var Vn=UA(!0),xA=UA(!1),Vs=jE(null),Ws=null,Mn=null,Xa=null;function ja(){Xa=Mn=Ws=null}function ka(e){var t=Vs.current;Ve(Vs),e._currentValue=t}function ql(e,t,E){for(;e!==null;){var n=e.alternate;if((e.childLanes&t)!==t?(e.childLanes|=t,n!==null&&(n.childLanes|=t)):n!==null&&(n.childLanes&t)!==t&&(n.childLanes|=t),e===E)break;e=e.return}}function Hn(e,t){Ws=e,Xa=Mn=null,e=e.dependencies,e!==null&&e.firstContext!==null&&(e.lanes&t&&(Dt=!0),e.firstContext=null)}function jt(e){var t=e._currentValue;if(Xa!==e)if(e={context:e,memoizedValue:t,next:null},Mn===null){if(Ws===null)throw Error(z(308));Mn=e,Ws.dependencies={lanes:0,firstContext:e}}else Mn=Mn.next=e;return t}var En=null;function Ka(e){En===null?En=[e]:En.push(e)}function yA(e,t,E,n){var r=t.interleaved;return r===null?(E.next=E,Ka(t)):(E.next=r.next,r.next=E),t.interleaved=E,CE(e,n)}function CE(e,t){e.lanes|=t;var E=e.alternate;for(E!==null&&(E.lanes|=t),E=e,e=e.return;e!==null;)e.childLanes|=t,E=e.alternate,E!==null&&(E.childLanes|=t),E=e,e=e.return;return E.tag===3?E.stateNode:null}var hE=!1;function $a(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function gA(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 uE(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function BE(e,t,E){var n=e.updateQueue;if(n===null)return null;if(n=n.shared,Ue&2){var r=n.pending;return r===null?t.next=t:(t.next=r.next,r.next=t),n.pending=t,CE(e,E)}return r=n.interleaved,r===null?(t.next=t,Ka(n)):(t.next=r.next,r.next=t),n.interleaved=t,CE(e,E)}function Cs(e,t,E){if(t=t.updateQueue,t!==null&&(t=t.shared,(E&4194240)!==0)){var n=t.lanes;n&=e.pendingLanes,E|=n,t.lanes=E,ga(e,E)}}function ni(e,t){var E=e.updateQueue,n=e.alternate;if(n!==null&&(n=n.updateQueue,E===n)){var r=null,T=null;if(E=E.firstBaseUpdate,E!==null){do{var l={eventTime:E.eventTime,lane:E.lane,tag:E.tag,payload:E.payload,callback:E.callback,next:null};T===null?r=T=l:T=T.next=l,E=E.next}while(E!==null);T===null?r=T=t:T=T.next=t}else r=T=t;E={baseState:n.baseState,firstBaseUpdate:r,lastBaseUpdate:T,shared:n.shared,effects:n.effects},e.updateQueue=E;return}e=E.lastBaseUpdate,e===null?E.firstBaseUpdate=t:e.next=t,E.lastBaseUpdate=t}function Xs(e,t,E,n){var r=e.updateQueue;hE=!1;var T=r.firstBaseUpdate,l=r.lastBaseUpdate,a=r.shared.pending;if(a!==null){r.shared.pending=null;var i=a,o=i.next;i.next=null,l===null?T=o:l.next=o,l=i;var S=e.alternate;S!==null&&(S=S.updateQueue,a=S.lastBaseUpdate,a!==l&&(a===null?S.firstBaseUpdate=o:a.next=o,S.lastBaseUpdate=i))}if(T!==null){var N=r.baseState;l=0,S=o=i=null,a=T;do{var R=a.lane,O=a.eventTime;if((n&R)===R){S!==null&&(S=S.next={eventTime:O,lane:0,tag:a.tag,payload:a.payload,callback:a.callback,next:null});e:{var L=e,_=a;switch(R=t,O=E,_.tag){case 1:if(L=_.payload,typeof L=="function"){N=L.call(O,N,R);break e}N=L;break e;case 3:L.flags=L.flags&-65537|128;case 0:if(L=_.payload,R=typeof L=="function"?L.call(O,N,R):L,R==null)break e;N=ze({},N,R);break e;case 2:hE=!0}}a.callback!==null&&a.lane!==0&&(e.flags|=64,R=r.effects,R===null?r.effects=[a]:R.push(a))}else O={eventTime:O,lane:R,tag:a.tag,payload:a.payload,callback:a.callback,next:null},S===null?(o=S=O,i=N):S=S.next=O,l|=R;if(a=a.next,a===null){if(a=r.shared.pending,a===null)break;R=a,a=R.next,R.next=null,r.lastBaseUpdate=R,r.shared.pending=null}}while(!0);if(S===null&&(i=N),r.baseState=i,r.firstBaseUpdate=o,r.lastBaseUpdate=S,t=r.shared.interleaved,t!==null){r=t;do l|=r.lane,r=r.next;while(r!==t)}else T===null&&(r.shared.lanes=0);on|=l,e.lanes=l,e.memoizedState=N}}function ri(e,t,E){if(e=t.effects,t.effects=null,e!==null)for(t=0;t<e.length;t++){var n=e[t],r=n.callback;if(r!==null){if(n.callback=null,n=E,typeof r!="function")throw Error(z(191,r));r.call(n)}}}var Kr={},lE=jE(Kr),Hr=jE(Kr),Br=jE(Kr);function nn(e){if(e===Kr)throw Error(z(174));return e}function Ja(e,t){switch(Fe(Br,t),Fe(Hr,e),Fe(lE,Kr),e=t.nodeType,e){case 9:case 11:t=(t=t.documentElement)?t.namespaceURI:gl(null,"");break;default:e=e===8?t.parentNode:t,t=e.namespaceURI||null,e=e.tagName,t=gl(t,e)}Ve(lE),Fe(lE,t)}function Wn(){Ve(lE),Ve(Hr),Ve(Br)}function GA(e){nn(Br.current);var t=nn(lE.current),E=gl(t,e.type);t!==E&&(Fe(Hr,e),Fe(lE,E))}function za(e){Hr.current===e&&(Ve(lE),Ve(Hr))}var $e=jE(0);function js(e){for(var t=e;t!==null;){if(t.tag===13){var E=t.memoizedState;if(E!==null&&(E=E.dehydrated,E===null||E.data==="$?"||E.data==="$!"))return t}else if(t.tag===19&&t.memoizedProps.revealOrder!==void 0){if(t.flags&128)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 WT=[];function Qa(){for(var e=0;e<WT.length;e++)WT[e]._workInProgressVersionPrimary=null;WT.length=0}var ds=_E.ReactCurrentDispatcher,XT=_E.ReactCurrentBatchConfig,an=0,Je=null,st=null,ot=null,ks=!1,dr=!1,Fr=0,$I=0;function ut(){throw Error(z(321))}function Za(e,t){if(t===null)return!1;for(var E=0;E<t.length&&E<e.length;E++)if(!eE(e[E],t[E]))return!1;return!0}function qa(e,t,E,n,r,T){if(an=T,Je=t,t.memoizedState=null,t.updateQueue=null,t.lanes=0,ds.current=e===null||e.memoizedState===null?ZI:qI,e=E(n,r),dr){T=0;do{if(dr=!1,Fr=0,25<=T)throw Error(z(301));T+=1,ot=st=null,t.updateQueue=null,ds.current=eu,e=E(n,r)}while(dr)}if(ds.current=Ks,t=st!==null&&st.next!==null,an=0,ot=st=Je=null,ks=!1,t)throw Error(z(300));return e}function eo(){var e=Fr!==0;return Fr=0,e}function nE(){var e={memoizedState:null,baseState:null,baseQueue:null,queue:null,next:null};return ot===null?Je.memoizedState=ot=e:ot=ot.next=e,ot}function kt(){if(st===null){var e=Je.alternate;e=e!==null?e.memoizedState:null}else e=st.next;var t=ot===null?Je.memoizedState:ot.next;if(t!==null)ot=t,st=e;else{if(e===null)throw Error(z(310));st=e,e={memoizedState:st.memoizedState,baseState:st.baseState,baseQueue:st.baseQueue,queue:st.queue,next:null},ot===null?Je.memoizedState=ot=e:ot=ot.next=e}return ot}function Yr(e,t){return typeof t=="function"?t(e):t}function jT(e){var t=kt(),E=t.queue;if(E===null)throw Error(z(311));E.lastRenderedReducer=e;var n=st,r=n.baseQueue,T=E.pending;if(T!==null){if(r!==null){var l=r.next;r.next=T.next,T.next=l}n.baseQueue=r=T,E.pending=null}if(r!==null){T=r.next,n=n.baseState;var a=l=null,i=null,o=T;do{var S=o.lane;if((an&S)===S)i!==null&&(i=i.next={lane:0,action:o.action,hasEagerState:o.hasEagerState,eagerState:o.eagerState,next:null}),n=o.hasEagerState?o.eagerState:e(n,o.action);else{var N={lane:S,action:o.action,hasEagerState:o.hasEagerState,eagerState:o.eagerState,next:null};i===null?(a=i=N,l=n):i=i.next=N,Je.lanes|=S,on|=S}o=o.next}while(o!==null&&o!==T);i===null?l=n:i.next=a,eE(n,t.memoizedState)||(Dt=!0),t.memoizedState=n,t.baseState=l,t.baseQueue=i,E.lastRenderedState=n}if(e=E.interleaved,e!==null){r=e;do T=r.lane,Je.lanes|=T,on|=T,r=r.next;while(r!==e)}else r===null&&(E.lanes=0);return[t.memoizedState,E.dispatch]}function kT(e){var t=kt(),E=t.queue;if(E===null)throw Error(z(311));E.lastRenderedReducer=e;var n=E.dispatch,r=E.pending,T=t.memoizedState;if(r!==null){E.pending=null;var l=r=r.next;do T=e(T,l.action),l=l.next;while(l!==r);eE(T,t.memoizedState)||(Dt=!0),t.memoizedState=T,t.baseQueue===null&&(t.baseState=T),E.lastRenderedState=T}return[T,n]}function vA(){}function HA(e,t){var E=Je,n=kt(),r=t(),T=!eE(n.memoizedState,r);if(T&&(n.memoizedState=r,Dt=!0),n=n.queue,to(YA.bind(null,E,n,e),[e]),n.getSnapshot!==t||T||ot!==null&&ot.memoizedState.tag&1){if(E.flags|=2048,wr(9,FA.bind(null,E,n,r,t),void 0,null),it===null)throw Error(z(349));an&30||BA(E,t,r)}return r}function BA(e,t,E){e.flags|=16384,e={getSnapshot:t,value:E},t=Je.updateQueue,t===null?(t={lastEffect:null,stores:null},Je.updateQueue=t,t.stores=[e]):(E=t.stores,E===null?t.stores=[e]:E.push(e))}function FA(e,t,E,n){t.value=E,t.getSnapshot=n,wA(t)&&bA(e)}function YA(e,t,E){return E(function(){wA(t)&&bA(e)})}function wA(e){var t=e.getSnapshot;e=e.value;try{var E=t();return!eE(e,E)}catch{return!0}}function bA(e){var t=CE(e,1);t!==null&&Zt(t,e,1,-1)}function si(e){var t=nE();return typeof e=="function"&&(e=e()),t.memoizedState=t.baseState=e,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:Yr,lastRenderedState:e},t.queue=e,e=e.dispatch=QI.bind(null,Je,e),[t.memoizedState,e]}function wr(e,t,E,n){return e={tag:e,create:t,destroy:E,deps:n,next:null},t=Je.updateQueue,t===null?(t={lastEffect:null,stores:null},Je.updateQueue=t,t.lastEffect=e.next=e):(E=t.lastEffect,E===null?t.lastEffect=e.next=e:(n=E.next,E.next=e,e.next=n,t.lastEffect=e)),e}function VA(){return kt().memoizedState}function Ls(e,t,E,n){var r=nE();Je.flags|=e,r.memoizedState=wr(1|t,E,void 0,n===void 0?null:n)}function aT(e,t,E,n){var r=kt();n=n===void 0?null:n;var T=void 0;if(st!==null){var l=st.memoizedState;if(T=l.destroy,n!==null&&Za(n,l.deps)){r.memoizedState=wr(t,E,T,n);return}}Je.flags|=e,r.memoizedState=wr(1|t,E,T,n)}function Ti(e,t){return Ls(8390656,8,e,t)}function to(e,t){return aT(2048,8,e,t)}function WA(e,t){return aT(4,2,e,t)}function XA(e,t){return aT(4,4,e,t)}function jA(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 kA(e,t,E){return E=E!=null?E.concat([e]):null,aT(4,4,jA.bind(null,t,e),E)}function Eo(){}function KA(e,t){var E=kt();t=t===void 0?null:t;var n=E.memoizedState;return n!==null&&t!==null&&Za(t,n[1])?n[0]:(E.memoizedState=[e,t],e)}function $A(e,t){var E=kt();t=t===void 0?null:t;var n=E.memoizedState;return n!==null&&t!==null&&Za(t,n[1])?n[0]:(e=e(),E.memoizedState=[e,t],e)}function JA(e,t,E){return an&21?(eE(E,t)||(E=eA(),Je.lanes|=E,on|=E,e.baseState=!0),t):(e.baseState&&(e.baseState=!1,Dt=!0),e.memoizedState=E)}function JI(e,t){var E=He;He=E!==0&&4>E?E:4,e(!0);var n=XT.transition;XT.transition={};try{e(!1),t()}finally{He=E,XT.transition=n}}function zA(){return kt().memoizedState}function zI(e,t,E){var n=YE(e);if(E={lane:n,action:E,hasEagerState:!1,eagerState:null,next:null},QA(e))ZA(t,E);else if(E=yA(e,t,E,n),E!==null){var r=_t();Zt(E,e,n,r),qA(E,t,n)}}function QI(e,t,E){var n=YE(e),r={lane:n,action:E,hasEagerState:!1,eagerState:null,next:null};if(QA(e))ZA(t,r);else{var T=e.alternate;if(e.lanes===0&&(T===null||T.lanes===0)&&(T=t.lastRenderedReducer,T!==null))try{var l=t.lastRenderedState,a=T(l,E);if(r.hasEagerState=!0,r.eagerState=a,eE(a,l)){var i=t.interleaved;i===null?(r.next=r,Ka(t)):(r.next=i.next,i.next=r),t.interleaved=r;return}}catch{}finally{}E=yA(e,t,r,n),E!==null&&(r=_t(),Zt(E,e,n,r),qA(E,t,n))}}function QA(e){var t=e.alternate;return e===Je||t!==null&&t===Je}function ZA(e,t){dr=ks=!0;var E=e.pending;E===null?t.next=t:(t.next=E.next,E.next=t),e.pending=t}function qA(e,t,E){if(E&4194240){var n=t.lanes;n&=e.pendingLanes,E|=n,t.lanes=E,ga(e,E)}}var Ks={readContext:jt,useCallback:ut,useContext:ut,useEffect:ut,useImperativeHandle:ut,useInsertionEffect:ut,useLayoutEffect:ut,useMemo:ut,useReducer:ut,useRef:ut,useState:ut,useDebugValue:ut,useDeferredValue:ut,useTransition:ut,useMutableSource:ut,useSyncExternalStore:ut,useId:ut,unstable_isNewReconciler:!1},ZI={readContext:jt,useCallback:function(e,t){return nE().memoizedState=[e,t===void 0?null:t],e},useContext:jt,useEffect:Ti,useImperativeHandle:function(e,t,E){return E=E!=null?E.concat([e]):null,Ls(4194308,4,jA.bind(null,t,e),E)},useLayoutEffect:function(e,t){return Ls(4194308,4,e,t)},useInsertionEffect:function(e,t){return Ls(4,2,e,t)},useMemo:function(e,t){var E=nE();return t=t===void 0?null:t,e=e(),E.memoizedState=[e,t],e},useReducer:function(e,t,E){var n=nE();return t=E!==void 0?E(t):t,n.memoizedState=n.baseState=t,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:e,lastRenderedState:t},n.queue=e,e=e.dispatch=zI.bind(null,Je,e),[n.memoizedState,e]},useRef:function(e){var t=nE();return e={current:e},t.memoizedState=e},useState:si,useDebugValue:Eo,useDeferredValue:function(e){return nE().memoizedState=e},useTransition:function(){var e=si(!1),t=e[0];return e=JI.bind(null,e[1]),nE().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,E){var n=Je,r=nE();if(ke){if(E===void 0)throw Error(z(407));E=E()}else{if(E=t(),it===null)throw Error(z(349));an&30||BA(n,t,E)}r.memoizedState=E;var T={value:E,getSnapshot:t};return r.queue=T,Ti(YA.bind(null,n,T,e),[e]),n.flags|=2048,wr(9,FA.bind(null,n,T,E,t),void 0,null),E},useId:function(){var e=nE(),t=it.identifierPrefix;if(ke){var E=NE,n=SE;E=(n&~(1<<32-Qt(n)-1)).toString(32)+E,t=":"+t+"R"+E,E=Fr++,0<E&&(t+="H"+E.toString(32)),t+=":"}else E=$I++,t=":"+t+"r"+E.toString(32)+":";return e.memoizedState=t},unstable_isNewReconciler:!1},qI={readContext:jt,useCallback:KA,useContext:jt,useEffect:to,useImperativeHandle:kA,useInsertionEffect:WA,useLayoutEffect:XA,useMemo:$A,useReducer:jT,useRef:VA,useState:function(){return jT(Yr)},useDebugValue:Eo,useDeferredValue:function(e){var t=kt();return JA(t,st.memoizedState,e)},useTransition:function(){var e=jT(Yr)[0],t=kt().memoizedState;return[e,t]},useMutableSource:vA,useSyncExternalStore:HA,useId:zA,unstable_isNewReconciler:!1},eu={readContext:jt,useCallback:KA,useContext:jt,useEffect:to,useImperativeHandle:kA,useInsertionEffect:WA,useLayoutEffect:XA,useMemo:$A,useReducer:kT,useRef:VA,useState:function(){return kT(Yr)},useDebugValue:Eo,useDeferredValue:function(e){var t=kt();return st===null?t.memoizedState=e:JA(t,st.memoizedState,e)},useTransition:function(){var e=kT(Yr)[0],t=kt().memoizedState;return[e,t]},useMutableSource:vA,useSyncExternalStore:HA,useId:zA,unstable_isNewReconciler:!1};function $t(e,t){if(e&&e.defaultProps){t=ze({},t),e=e.defaultProps;for(var E in e)t[E]===void 0&&(t[E]=e[E]);return t}return t}function ea(e,t,E,n){t=e.memoizedState,E=E(n,t),E=E==null?t:ze({},t,E),e.memoizedState=E,e.lanes===0&&(e.updateQueue.baseState=E)}var oT={isMounted:function(e){return(e=e._reactInternals)?Nn(e)===e:!1},enqueueSetState:function(e,t,E){e=e._reactInternals;var n=_t(),r=YE(e),T=uE(n,r);T.payload=t,E!=null&&(T.callback=E),t=BE(e,T,r),t!==null&&(Zt(t,e,r,n),Cs(t,e,r))},enqueueReplaceState:function(e,t,E){e=e._reactInternals;var n=_t(),r=YE(e),T=uE(n,r);T.tag=1,T.payload=t,E!=null&&(T.callback=E),t=BE(e,T,r),t!==null&&(Zt(t,e,r,n),Cs(t,e,r))},enqueueForceUpdate:function(e,t){e=e._reactInternals;var E=_t(),n=YE(e),r=uE(E,n);r.tag=2,t!=null&&(r.callback=t),t=BE(e,r,n),t!==null&&(Zt(t,e,n,E),Cs(t,e,n))}};function li(e,t,E,n,r,T,l){return e=e.stateNode,typeof e.shouldComponentUpdate=="function"?e.shouldComponentUpdate(n,T,l):t.prototype&&t.prototype.isPureReactComponent?!yr(E,n)||!yr(r,T):!0}function eS(e,t,E){var n=!1,r=VE,T=t.contextType;return typeof T=="object"&&T!==null?T=jt(T):(r=ht(t)?Tn:Ct.current,n=t.contextTypes,T=(n=n!=null)?wn(e,r):VE),t=new t(E,T),e.memoizedState=t.state!==null&&t.state!==void 0?t.state:null,t.updater=oT,e.stateNode=t,t._reactInternals=e,n&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=r,e.__reactInternalMemoizedMaskedChildContext=T),t}function ai(e,t,E,n){e=t.state,typeof t.componentWillReceiveProps=="function"&&t.componentWillReceiveProps(E,n),typeof t.UNSAFE_componentWillReceiveProps=="function"&&t.UNSAFE_componentWillReceiveProps(E,n),t.state!==e&&oT.enqueueReplaceState(t,t.state,null)}function ta(e,t,E,n){var r=e.stateNode;r.props=E,r.state=e.memoizedState,r.refs={},$a(e);var T=t.contextType;typeof T=="object"&&T!==null?r.context=jt(T):(T=ht(t)?Tn:Ct.current,r.context=wn(e,T)),r.state=e.memoizedState,T=t.getDerivedStateFromProps,typeof T=="function"&&(ea(e,t,T,E),r.state=e.memoizedState),typeof t.getDerivedStateFromProps=="function"||typeof r.getSnapshotBeforeUpdate=="function"||typeof r.UNSAFE_componentWillMount!="function"&&typeof r.componentWillMount!="function"||(t=r.state,typeof r.componentWillMount=="function"&&r.componentWillMount(),typeof r.UNSAFE_componentWillMount=="function"&&r.UNSAFE_componentWillMount(),t!==r.state&&oT.enqueueReplaceState(r,r.state,null),Xs(e,E,r,n),r.state=e.memoizedState),typeof r.componentDidMount=="function"&&(e.flags|=4194308)}function Xn(e,t){try{var E="",n=t;do E+=hN(n),n=n.return;while(n);var r=E}catch(T){r=`
|
||
Error generating stack: `+T.message+`
|
||
`+T.stack}return{value:e,source:t,stack:r,digest:null}}function KT(e,t,E){return{value:e,source:null,stack:E??null,digest:t??null}}function Ea(e,t){try{console.error(t.value)}catch(E){setTimeout(function(){throw E})}}var tu=typeof WeakMap=="function"?WeakMap:Map;function tS(e,t,E){E=uE(-1,E),E.tag=3,E.payload={element:null};var n=t.value;return E.callback=function(){Js||(Js=!0,Aa=n),Ea(e,t)},E}function ES(e,t,E){E=uE(-1,E),E.tag=3;var n=e.type.getDerivedStateFromError;if(typeof n=="function"){var r=t.value;E.payload=function(){return n(r)},E.callback=function(){Ea(e,t)}}var T=e.stateNode;return T!==null&&typeof T.componentDidCatch=="function"&&(E.callback=function(){Ea(e,t),typeof n!="function"&&(FE===null?FE=new Set([this]):FE.add(this));var l=t.stack;this.componentDidCatch(t.value,{componentStack:l!==null?l:""})}),E}function oi(e,t,E){var n=e.pingCache;if(n===null){n=e.pingCache=new tu;var r=new Set;n.set(t,r)}else r=n.get(t),r===void 0&&(r=new Set,n.set(t,r));r.has(E)||(r.add(E),e=Iu.bind(null,e,t,E),t.then(e,e))}function ii(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 Ri(e,t,E,n,r){return e.mode&1?(e.flags|=65536,e.lanes=r,e):(e===t?e.flags|=65536:(e.flags|=128,E.flags|=131072,E.flags&=-52805,E.tag===1&&(E.alternate===null?E.tag=17:(t=uE(-1,1),t.tag=2,BE(E,t,1))),E.lanes|=1),e)}var Eu=_E.ReactCurrentOwner,Dt=!1;function Lt(e,t,E,n){t.child=e===null?xA(t,null,E,n):Vn(t,e.child,E,n)}function Ai(e,t,E,n,r){E=E.render;var T=t.ref;return Hn(t,r),n=qa(e,t,E,n,T,r),E=eo(),e!==null&&!Dt?(t.updateQueue=e.updateQueue,t.flags&=-2053,e.lanes&=~r,dE(e,t,r)):(ke&&E&&ba(t),t.flags|=1,Lt(e,t,n,r),t.child)}function Si(e,t,E,n,r){if(e===null){var T=E.type;return typeof T=="function"&&!io(T)&&T.defaultProps===void 0&&E.compare===null&&E.defaultProps===void 0?(t.tag=15,t.type=T,nS(e,t,T,n,r)):(e=ms(E.type,null,n,t,t.mode,r),e.ref=t.ref,e.return=t,t.child=e)}if(T=e.child,!(e.lanes&r)){var l=T.memoizedProps;if(E=E.compare,E=E!==null?E:yr,E(l,n)&&e.ref===t.ref)return dE(e,t,r)}return t.flags|=1,e=wE(T,n),e.ref=t.ref,e.return=t,t.child=e}function nS(e,t,E,n,r){if(e!==null){var T=e.memoizedProps;if(yr(T,n)&&e.ref===t.ref)if(Dt=!1,t.pendingProps=n=T,(e.lanes&r)!==0)e.flags&131072&&(Dt=!0);else return t.lanes=e.lanes,dE(e,t,r)}return na(e,t,E,n,r)}function rS(e,t,E){var n=t.pendingProps,r=n.children,T=e!==null?e.memoizedState:null;if(n.mode==="hidden")if(!(t.mode&1))t.memoizedState={baseLanes:0,cachePool:null,transitions:null},Fe(xn,yt),yt|=E;else{if(!(E&1073741824))return e=T!==null?T.baseLanes|E:E,t.lanes=t.childLanes=1073741824,t.memoizedState={baseLanes:e,cachePool:null,transitions:null},t.updateQueue=null,Fe(xn,yt),yt|=e,null;t.memoizedState={baseLanes:0,cachePool:null,transitions:null},n=T!==null?T.baseLanes:E,Fe(xn,yt),yt|=n}else T!==null?(n=T.baseLanes|E,t.memoizedState=null):n=E,Fe(xn,yt),yt|=n;return Lt(e,t,r,E),t.child}function sS(e,t){var E=t.ref;(e===null&&E!==null||e!==null&&e.ref!==E)&&(t.flags|=512,t.flags|=2097152)}function na(e,t,E,n,r){var T=ht(E)?Tn:Ct.current;return T=wn(t,T),Hn(t,r),E=qa(e,t,E,n,T,r),n=eo(),e!==null&&!Dt?(t.updateQueue=e.updateQueue,t.flags&=-2053,e.lanes&=~r,dE(e,t,r)):(ke&&n&&ba(t),t.flags|=1,Lt(e,t,E,r),t.child)}function Ni(e,t,E,n,r){if(ht(E)){var T=!0;Ys(t)}else T=!1;if(Hn(t,r),t.stateNode===null)_s(e,t),eS(t,E,n),ta(t,E,n,r),n=!0;else if(e===null){var l=t.stateNode,a=t.memoizedProps;l.props=a;var i=l.context,o=E.contextType;typeof o=="object"&&o!==null?o=jt(o):(o=ht(E)?Tn:Ct.current,o=wn(t,o));var S=E.getDerivedStateFromProps,N=typeof S=="function"||typeof l.getSnapshotBeforeUpdate=="function";N||typeof l.UNSAFE_componentWillReceiveProps!="function"&&typeof l.componentWillReceiveProps!="function"||(a!==n||i!==o)&&ai(t,l,n,o),hE=!1;var R=t.memoizedState;l.state=R,Xs(t,n,l,r),i=t.memoizedState,a!==n||R!==i||Pt.current||hE?(typeof S=="function"&&(ea(t,E,S,n),i=t.memoizedState),(a=hE||li(t,E,a,n,R,i,o))?(N||typeof l.UNSAFE_componentWillMount!="function"&&typeof l.componentWillMount!="function"||(typeof l.componentWillMount=="function"&&l.componentWillMount(),typeof l.UNSAFE_componentWillMount=="function"&&l.UNSAFE_componentWillMount()),typeof l.componentDidMount=="function"&&(t.flags|=4194308)):(typeof l.componentDidMount=="function"&&(t.flags|=4194308),t.memoizedProps=n,t.memoizedState=i),l.props=n,l.state=i,l.context=o,n=a):(typeof l.componentDidMount=="function"&&(t.flags|=4194308),n=!1)}else{l=t.stateNode,gA(e,t),a=t.memoizedProps,o=t.type===t.elementType?a:$t(t.type,a),l.props=o,N=t.pendingProps,R=l.context,i=E.contextType,typeof i=="object"&&i!==null?i=jt(i):(i=ht(E)?Tn:Ct.current,i=wn(t,i));var O=E.getDerivedStateFromProps;(S=typeof O=="function"||typeof l.getSnapshotBeforeUpdate=="function")||typeof l.UNSAFE_componentWillReceiveProps!="function"&&typeof l.componentWillReceiveProps!="function"||(a!==N||R!==i)&&ai(t,l,n,i),hE=!1,R=t.memoizedState,l.state=R,Xs(t,n,l,r);var L=t.memoizedState;a!==N||R!==L||Pt.current||hE?(typeof O=="function"&&(ea(t,E,O,n),L=t.memoizedState),(o=hE||li(t,E,o,n,R,L,i)||!1)?(S||typeof l.UNSAFE_componentWillUpdate!="function"&&typeof l.componentWillUpdate!="function"||(typeof l.componentWillUpdate=="function"&&l.componentWillUpdate(n,L,i),typeof l.UNSAFE_componentWillUpdate=="function"&&l.UNSAFE_componentWillUpdate(n,L,i)),typeof l.componentDidUpdate=="function"&&(t.flags|=4),typeof l.getSnapshotBeforeUpdate=="function"&&(t.flags|=1024)):(typeof l.componentDidUpdate!="function"||a===e.memoizedProps&&R===e.memoizedState||(t.flags|=4),typeof l.getSnapshotBeforeUpdate!="function"||a===e.memoizedProps&&R===e.memoizedState||(t.flags|=1024),t.memoizedProps=n,t.memoizedState=L),l.props=n,l.state=L,l.context=i,n=o):(typeof l.componentDidUpdate!="function"||a===e.memoizedProps&&R===e.memoizedState||(t.flags|=4),typeof l.getSnapshotBeforeUpdate!="function"||a===e.memoizedProps&&R===e.memoizedState||(t.flags|=1024),n=!1)}return ra(e,t,E,n,T,r)}function ra(e,t,E,n,r,T){sS(e,t);var l=(t.flags&128)!==0;if(!n&&!l)return r&&qo(t,E,!1),dE(e,t,T);n=t.stateNode,Eu.current=t;var a=l&&typeof E.getDerivedStateFromError!="function"?null:n.render();return t.flags|=1,e!==null&&l?(t.child=Vn(t,e.child,null,T),t.child=Vn(t,null,a,T)):Lt(e,t,a,T),t.memoizedState=n.state,r&&qo(t,E,!0),t.child}function TS(e){var t=e.stateNode;t.pendingContext?Zo(e,t.pendingContext,t.pendingContext!==t.context):t.context&&Zo(e,t.context,!1),Ja(e,t.containerInfo)}function Ii(e,t,E,n,r){return bn(),Wa(r),t.flags|=256,Lt(e,t,E,n),t.child}var sa={dehydrated:null,treeContext:null,retryLane:0};function Ta(e){return{baseLanes:e,cachePool:null,transitions:null}}function lS(e,t,E){var n=t.pendingProps,r=$e.current,T=!1,l=(t.flags&128)!==0,a;if((a=l)||(a=e!==null&&e.memoizedState===null?!1:(r&2)!==0),a?(T=!0,t.flags&=-129):(e===null||e.memoizedState!==null)&&(r|=1),Fe($e,r&1),e===null)return Zl(t),e=t.memoizedState,e!==null&&(e=e.dehydrated,e!==null)?(t.mode&1?e.data==="$!"?t.lanes=8:t.lanes=1073741824:t.lanes=1,null):(l=n.children,e=n.fallback,T?(n=t.mode,T=t.child,l={mode:"hidden",children:l},!(n&1)&&T!==null?(T.childLanes=0,T.pendingProps=l):T=AT(l,n,0,null),e=sn(e,n,E,null),T.return=t,e.return=t,T.sibling=e,t.child=T,t.child.memoizedState=Ta(E),t.memoizedState=sa,e):no(t,l));if(r=e.memoizedState,r!==null&&(a=r.dehydrated,a!==null))return nu(e,t,l,n,a,r,E);if(T){T=n.fallback,l=t.mode,r=e.child,a=r.sibling;var i={mode:"hidden",children:n.children};return!(l&1)&&t.child!==r?(n=t.child,n.childLanes=0,n.pendingProps=i,t.deletions=null):(n=wE(r,i),n.subtreeFlags=r.subtreeFlags&14680064),a!==null?T=wE(a,T):(T=sn(T,l,E,null),T.flags|=2),T.return=t,n.return=t,n.sibling=T,t.child=n,n=T,T=t.child,l=e.child.memoizedState,l=l===null?Ta(E):{baseLanes:l.baseLanes|E,cachePool:null,transitions:l.transitions},T.memoizedState=l,T.childLanes=e.childLanes&~E,t.memoizedState=sa,n}return T=e.child,e=T.sibling,n=wE(T,{mode:"visible",children:n.children}),!(t.mode&1)&&(n.lanes=E),n.return=t,n.sibling=null,e!==null&&(E=t.deletions,E===null?(t.deletions=[e],t.flags|=16):E.push(e)),t.child=n,t.memoizedState=null,n}function no(e,t){return t=AT({mode:"visible",children:t},e.mode,0,null),t.return=e,e.child=t}function os(e,t,E,n){return n!==null&&Wa(n),Vn(t,e.child,null,E),e=no(t,t.pendingProps.children),e.flags|=2,t.memoizedState=null,e}function nu(e,t,E,n,r,T,l){if(E)return t.flags&256?(t.flags&=-257,n=KT(Error(z(422))),os(e,t,l,n)):t.memoizedState!==null?(t.child=e.child,t.flags|=128,null):(T=n.fallback,r=t.mode,n=AT({mode:"visible",children:n.children},r,0,null),T=sn(T,r,l,null),T.flags|=2,n.return=t,T.return=t,n.sibling=T,t.child=n,t.mode&1&&Vn(t,e.child,null,l),t.child.memoizedState=Ta(l),t.memoizedState=sa,T);if(!(t.mode&1))return os(e,t,l,null);if(r.data==="$!"){if(n=r.nextSibling&&r.nextSibling.dataset,n)var a=n.dgst;return n=a,T=Error(z(419)),n=KT(T,n,void 0),os(e,t,l,n)}if(a=(l&e.childLanes)!==0,Dt||a){if(n=it,n!==null){switch(l&-l){case 4:r=2;break;case 16:r=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:r=32;break;case 536870912:r=268435456;break;default:r=0}r=r&(n.suspendedLanes|l)?0:r,r!==0&&r!==T.retryLane&&(T.retryLane=r,CE(e,r),Zt(n,e,r,-1))}return oo(),n=KT(Error(z(421))),os(e,t,l,n)}return r.data==="$?"?(t.flags|=128,t.child=e.child,t=uu.bind(null,e),r._reactRetry=t,null):(e=T.treeContext,gt=HE(r.nextSibling),vt=t,ke=!0,zt=null,e!==null&&(wt[bt++]=SE,wt[bt++]=NE,wt[bt++]=ln,SE=e.id,NE=e.overflow,ln=t),t=no(t,n.children),t.flags|=4096,t)}function ui(e,t,E){e.lanes|=t;var n=e.alternate;n!==null&&(n.lanes|=t),ql(e.return,t,E)}function $T(e,t,E,n,r){var T=e.memoizedState;T===null?e.memoizedState={isBackwards:t,rendering:null,renderingStartTime:0,last:n,tail:E,tailMode:r}:(T.isBackwards=t,T.rendering=null,T.renderingStartTime=0,T.last=n,T.tail=E,T.tailMode=r)}function aS(e,t,E){var n=t.pendingProps,r=n.revealOrder,T=n.tail;if(Lt(e,t,n.children,E),n=$e.current,n&2)n=n&1|2,t.flags|=128;else{if(e!==null&&e.flags&128)e:for(e=t.child;e!==null;){if(e.tag===13)e.memoizedState!==null&&ui(e,E,t);else if(e.tag===19)ui(e,E,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}n&=1}if(Fe($e,n),!(t.mode&1))t.memoizedState=null;else switch(r){case"forwards":for(E=t.child,r=null;E!==null;)e=E.alternate,e!==null&&js(e)===null&&(r=E),E=E.sibling;E=r,E===null?(r=t.child,t.child=null):(r=E.sibling,E.sibling=null),$T(t,!1,r,E,T);break;case"backwards":for(E=null,r=t.child,t.child=null;r!==null;){if(e=r.alternate,e!==null&&js(e)===null){t.child=r;break}e=r.sibling,r.sibling=E,E=r,r=e}$T(t,!0,E,null,T);break;case"together":$T(t,!1,null,null,void 0);break;default:t.memoizedState=null}return t.child}function _s(e,t){!(t.mode&1)&&e!==null&&(e.alternate=null,t.alternate=null,t.flags|=2)}function dE(e,t,E){if(e!==null&&(t.dependencies=e.dependencies),on|=t.lanes,!(E&t.childLanes))return null;if(e!==null&&t.child!==e.child)throw Error(z(153));if(t.child!==null){for(e=t.child,E=wE(e,e.pendingProps),t.child=E,E.return=t;e.sibling!==null;)e=e.sibling,E=E.sibling=wE(e,e.pendingProps),E.return=t;E.sibling=null}return t.child}function ru(e,t,E){switch(t.tag){case 3:TS(t),bn();break;case 5:GA(t);break;case 1:ht(t.type)&&Ys(t);break;case 4:Ja(t,t.stateNode.containerInfo);break;case 10:var n=t.type._context,r=t.memoizedProps.value;Fe(Vs,n._currentValue),n._currentValue=r;break;case 13:if(n=t.memoizedState,n!==null)return n.dehydrated!==null?(Fe($e,$e.current&1),t.flags|=128,null):E&t.child.childLanes?lS(e,t,E):(Fe($e,$e.current&1),e=dE(e,t,E),e!==null?e.sibling:null);Fe($e,$e.current&1);break;case 19:if(n=(E&t.childLanes)!==0,e.flags&128){if(n)return aS(e,t,E);t.flags|=128}if(r=t.memoizedState,r!==null&&(r.rendering=null,r.tail=null,r.lastEffect=null),Fe($e,$e.current),n)break;return null;case 22:case 23:return t.lanes=0,rS(e,t,E)}return dE(e,t,E)}var oS,la,iS,RS;oS=function(e,t){for(var E=t.child;E!==null;){if(E.tag===5||E.tag===6)e.appendChild(E.stateNode);else if(E.tag!==4&&E.child!==null){E.child.return=E,E=E.child;continue}if(E===t)break;for(;E.sibling===null;){if(E.return===null||E.return===t)return;E=E.return}E.sibling.return=E.return,E=E.sibling}};la=function(){};iS=function(e,t,E,n){var r=e.memoizedProps;if(r!==n){e=t.stateNode,nn(lE.current);var T=null;switch(E){case"input":r=Ml(e,r),n=Ml(e,n),T=[];break;case"select":r=ze({},r,{value:void 0}),n=ze({},n,{value:void 0}),T=[];break;case"textarea":r=yl(e,r),n=yl(e,n),T=[];break;default:typeof r.onClick!="function"&&typeof n.onClick=="function"&&(e.onclick=Bs)}Gl(E,n);var l;E=null;for(o in r)if(!n.hasOwnProperty(o)&&r.hasOwnProperty(o)&&r[o]!=null)if(o==="style"){var a=r[o];for(l in a)a.hasOwnProperty(l)&&(E||(E={}),E[l]="")}else o!=="dangerouslySetInnerHTML"&&o!=="children"&&o!=="suppressContentEditableWarning"&&o!=="suppressHydrationWarning"&&o!=="autoFocus"&&(mr.hasOwnProperty(o)?T||(T=[]):(T=T||[]).push(o,null));for(o in n){var i=n[o];if(a=r?.[o],n.hasOwnProperty(o)&&i!==a&&(i!=null||a!=null))if(o==="style")if(a){for(l in a)!a.hasOwnProperty(l)||i&&i.hasOwnProperty(l)||(E||(E={}),E[l]="");for(l in i)i.hasOwnProperty(l)&&a[l]!==i[l]&&(E||(E={}),E[l]=i[l])}else E||(T||(T=[]),T.push(o,E)),E=i;else o==="dangerouslySetInnerHTML"?(i=i?i.__html:void 0,a=a?a.__html:void 0,i!=null&&a!==i&&(T=T||[]).push(o,i)):o==="children"?typeof i!="string"&&typeof i!="number"||(T=T||[]).push(o,""+i):o!=="suppressContentEditableWarning"&&o!=="suppressHydrationWarning"&&(mr.hasOwnProperty(o)?(i!=null&&o==="onScroll"&&be("scroll",e),T||a===i||(T=[])):(T=T||[]).push(o,i))}E&&(T=T||[]).push("style",E);var o=T;(t.updateQueue=o)&&(t.flags|=4)}};RS=function(e,t,E,n){E!==n&&(t.flags|=4)};function ar(e,t){if(!ke)switch(e.tailMode){case"hidden":t=e.tail;for(var E=null;t!==null;)t.alternate!==null&&(E=t),t=t.sibling;E===null?e.tail=null:E.sibling=null;break;case"collapsed":E=e.tail;for(var n=null;E!==null;)E.alternate!==null&&(n=E),E=E.sibling;n===null?t||e.tail===null?e.tail=null:e.tail.sibling=null:n.sibling=null}}function Ot(e){var t=e.alternate!==null&&e.alternate.child===e.child,E=0,n=0;if(t)for(var r=e.child;r!==null;)E|=r.lanes|r.childLanes,n|=r.subtreeFlags&14680064,n|=r.flags&14680064,r.return=e,r=r.sibling;else for(r=e.child;r!==null;)E|=r.lanes|r.childLanes,n|=r.subtreeFlags,n|=r.flags,r.return=e,r=r.sibling;return e.subtreeFlags|=n,e.childLanes=E,t}function su(e,t,E){var n=t.pendingProps;switch(Va(t),t.tag){case 2:case 16:case 15:case 0:case 11:case 7:case 8:case 12:case 9:case 14:return Ot(t),null;case 1:return ht(t.type)&&Fs(),Ot(t),null;case 3:return n=t.stateNode,Wn(),Ve(Pt),Ve(Ct),Qa(),n.pendingContext&&(n.context=n.pendingContext,n.pendingContext=null),(e===null||e.child===null)&&(ls(t)?t.flags|=4:e===null||e.memoizedState.isDehydrated&&!(t.flags&256)||(t.flags|=1024,zt!==null&&(Ia(zt),zt=null))),la(e,t),Ot(t),null;case 5:za(t);var r=nn(Br.current);if(E=t.type,e!==null&&t.stateNode!=null)iS(e,t,E,n,r),e.ref!==t.ref&&(t.flags|=512,t.flags|=2097152);else{if(!n){if(t.stateNode===null)throw Error(z(166));return Ot(t),null}if(e=nn(lE.current),ls(t)){n=t.stateNode,E=t.type;var T=t.memoizedProps;switch(n[sE]=t,n[vr]=T,e=(t.mode&1)!==0,E){case"dialog":be("cancel",n),be("close",n);break;case"iframe":case"object":case"embed":be("load",n);break;case"video":case"audio":for(r=0;r<Nr.length;r++)be(Nr[r],n);break;case"source":be("error",n);break;case"img":case"image":case"link":be("error",n),be("load",n);break;case"details":be("toggle",n);break;case"input":mo(n,T),be("invalid",n);break;case"select":n._wrapperState={wasMultiple:!!T.multiple},be("invalid",n);break;case"textarea":Po(n,T),be("invalid",n)}Gl(E,T),r=null;for(var l in T)if(T.hasOwnProperty(l)){var a=T[l];l==="children"?typeof a=="string"?n.textContent!==a&&(T.suppressHydrationWarning!==!0&&Ts(n.textContent,a,e),r=["children",a]):typeof a=="number"&&n.textContent!==""+a&&(T.suppressHydrationWarning!==!0&&Ts(n.textContent,a,e),r=["children",""+a]):mr.hasOwnProperty(l)&&a!=null&&l==="onScroll"&&be("scroll",n)}switch(E){case"input":Zr(n),Do(n,T,!0);break;case"textarea":Zr(n),ho(n);break;case"select":case"option":break;default:typeof T.onClick=="function"&&(n.onclick=Bs)}n=r,t.updateQueue=n,n!==null&&(t.flags|=4)}else{l=r.nodeType===9?r:r.ownerDocument,e==="http://www.w3.org/1999/xhtml"&&(e=YR(E)),e==="http://www.w3.org/1999/xhtml"?E==="script"?(e=l.createElement("div"),e.innerHTML="<script><\/script>",e=e.removeChild(e.firstChild)):typeof n.is=="string"?e=l.createElement(E,{is:n.is}):(e=l.createElement(E),E==="select"&&(l=e,n.multiple?l.multiple=!0:n.size&&(l.size=n.size))):e=l.createElementNS(e,E),e[sE]=t,e[vr]=n,oS(e,t,!1,!1),t.stateNode=e;e:{switch(l=vl(E,n),E){case"dialog":be("cancel",e),be("close",e),r=n;break;case"iframe":case"object":case"embed":be("load",e),r=n;break;case"video":case"audio":for(r=0;r<Nr.length;r++)be(Nr[r],e);r=n;break;case"source":be("error",e),r=n;break;case"img":case"image":case"link":be("error",e),be("load",e),r=n;break;case"details":be("toggle",e),r=n;break;case"input":mo(e,n),r=Ml(e,n),be("invalid",e);break;case"option":r=n;break;case"select":e._wrapperState={wasMultiple:!!n.multiple},r=ze({},n,{value:void 0}),be("invalid",e);break;case"textarea":Po(e,n),r=yl(e,n),be("invalid",e);break;default:r=n}Gl(E,r),a=r;for(T in a)if(a.hasOwnProperty(T)){var i=a[T];T==="style"?VR(e,i):T==="dangerouslySetInnerHTML"?(i=i?i.__html:void 0,i!=null&&wR(e,i)):T==="children"?typeof i=="string"?(E!=="textarea"||i!=="")&&Dr(e,i):typeof i=="number"&&Dr(e,""+i):T!=="suppressContentEditableWarning"&&T!=="suppressHydrationWarning"&&T!=="autoFocus"&&(mr.hasOwnProperty(T)?i!=null&&T==="onScroll"&&be("scroll",e):i!=null&&Pa(e,T,i,l))}switch(E){case"input":Zr(e),Do(e,n,!1);break;case"textarea":Zr(e),ho(e);break;case"option":n.value!=null&&e.setAttribute("value",""+bE(n.value));break;case"select":e.multiple=!!n.multiple,T=n.value,T!=null?yn(e,!!n.multiple,T,!1):n.defaultValue!=null&&yn(e,!!n.multiple,n.defaultValue,!0);break;default:typeof r.onClick=="function"&&(e.onclick=Bs)}switch(E){case"button":case"input":case"select":case"textarea":n=!!n.autoFocus;break e;case"img":n=!0;break e;default:n=!1}}n&&(t.flags|=4)}t.ref!==null&&(t.flags|=512,t.flags|=2097152)}return Ot(t),null;case 6:if(e&&t.stateNode!=null)RS(e,t,e.memoizedProps,n);else{if(typeof n!="string"&&t.stateNode===null)throw Error(z(166));if(E=nn(Br.current),nn(lE.current),ls(t)){if(n=t.stateNode,E=t.memoizedProps,n[sE]=t,(T=n.nodeValue!==E)&&(e=vt,e!==null))switch(e.tag){case 3:Ts(n.nodeValue,E,(e.mode&1)!==0);break;case 5:e.memoizedProps.suppressHydrationWarning!==!0&&Ts(n.nodeValue,E,(e.mode&1)!==0)}T&&(t.flags|=4)}else n=(E.nodeType===9?E:E.ownerDocument).createTextNode(n),n[sE]=t,t.stateNode=n}return Ot(t),null;case 13:if(Ve($e),n=t.memoizedState,e===null||e.memoizedState!==null&&e.memoizedState.dehydrated!==null){if(ke&>!==null&&t.mode&1&&!(t.flags&128))MA(),bn(),t.flags|=98560,T=!1;else if(T=ls(t),n!==null&&n.dehydrated!==null){if(e===null){if(!T)throw Error(z(318));if(T=t.memoizedState,T=T!==null?T.dehydrated:null,!T)throw Error(z(317));T[sE]=t}else bn(),!(t.flags&128)&&(t.memoizedState=null),t.flags|=4;Ot(t),T=!1}else zt!==null&&(Ia(zt),zt=null),T=!0;if(!T)return t.flags&65536?t:null}return t.flags&128?(t.lanes=E,t):(n=n!==null,n!==(e!==null&&e.memoizedState!==null)&&n&&(t.child.flags|=8192,t.mode&1&&(e===null||$e.current&1?Tt===0&&(Tt=3):oo())),t.updateQueue!==null&&(t.flags|=4),Ot(t),null);case 4:return Wn(),la(e,t),e===null&&gr(t.stateNode.containerInfo),Ot(t),null;case 10:return ka(t.type._context),Ot(t),null;case 17:return ht(t.type)&&Fs(),Ot(t),null;case 19:if(Ve($e),T=t.memoizedState,T===null)return Ot(t),null;if(n=(t.flags&128)!==0,l=T.rendering,l===null)if(n)ar(T,!1);else{if(Tt!==0||e!==null&&e.flags&128)for(e=t.child;e!==null;){if(l=js(e),l!==null){for(t.flags|=128,ar(T,!1),n=l.updateQueue,n!==null&&(t.updateQueue=n,t.flags|=4),t.subtreeFlags=0,n=E,E=t.child;E!==null;)T=E,e=n,T.flags&=14680066,l=T.alternate,l===null?(T.childLanes=0,T.lanes=e,T.child=null,T.subtreeFlags=0,T.memoizedProps=null,T.memoizedState=null,T.updateQueue=null,T.dependencies=null,T.stateNode=null):(T.childLanes=l.childLanes,T.lanes=l.lanes,T.child=l.child,T.subtreeFlags=0,T.deletions=null,T.memoizedProps=l.memoizedProps,T.memoizedState=l.memoizedState,T.updateQueue=l.updateQueue,T.type=l.type,e=l.dependencies,T.dependencies=e===null?null:{lanes:e.lanes,firstContext:e.firstContext}),E=E.sibling;return Fe($e,$e.current&1|2),t.child}e=e.sibling}T.tail!==null&&tt()>jn&&(t.flags|=128,n=!0,ar(T,!1),t.lanes=4194304)}else{if(!n)if(e=js(l),e!==null){if(t.flags|=128,n=!0,E=e.updateQueue,E!==null&&(t.updateQueue=E,t.flags|=4),ar(T,!0),T.tail===null&&T.tailMode==="hidden"&&!l.alternate&&!ke)return Ot(t),null}else 2*tt()-T.renderingStartTime>jn&&E!==1073741824&&(t.flags|=128,n=!0,ar(T,!1),t.lanes=4194304);T.isBackwards?(l.sibling=t.child,t.child=l):(E=T.last,E!==null?E.sibling=l:t.child=l,T.last=l)}return T.tail!==null?(t=T.tail,T.rendering=t,T.tail=t.sibling,T.renderingStartTime=tt(),t.sibling=null,E=$e.current,Fe($e,n?E&1|2:E&1),t):(Ot(t),null);case 22:case 23:return ao(),n=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==n&&(t.flags|=8192),n&&t.mode&1?yt&1073741824&&(Ot(t),t.subtreeFlags&6&&(t.flags|=8192)):Ot(t),null;case 24:return null;case 25:return null}throw Error(z(156,t.tag))}function Tu(e,t){switch(Va(t),t.tag){case 1:return ht(t.type)&&Fs(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return Wn(),Ve(Pt),Ve(Ct),Qa(),e=t.flags,e&65536&&!(e&128)?(t.flags=e&-65537|128,t):null;case 5:return za(t),null;case 13:if(Ve($e),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(z(340));bn()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return Ve($e),null;case 4:return Wn(),null;case 10:return ka(t.type._context),null;case 22:case 23:return ao(),null;case 24:return null;default:return null}}var is=!1,ct=!1,lu=typeof WeakSet=="function"?WeakSet:Set,re=null;function Un(e,t){var E=e.ref;if(E!==null)if(typeof E=="function")try{E(null)}catch(n){et(e,t,n)}else E.current=null}function aa(e,t,E){try{E()}catch(n){et(e,t,n)}}var Oi=!1;function au(e,t){if(jl=Gs,e=uA(),wa(e)){if("selectionStart"in e)var E={start:e.selectionStart,end:e.selectionEnd};else e:{E=(E=e.ownerDocument)&&E.defaultView||window;var n=E.getSelection&&E.getSelection();if(n&&n.rangeCount!==0){E=n.anchorNode;var r=n.anchorOffset,T=n.focusNode;n=n.focusOffset;try{E.nodeType,T.nodeType}catch{E=null;break e}var l=0,a=-1,i=-1,o=0,S=0,N=e,R=null;t:for(;;){for(var O;N!==E||r!==0&&N.nodeType!==3||(a=l+r),N!==T||n!==0&&N.nodeType!==3||(i=l+n),N.nodeType===3&&(l+=N.nodeValue.length),(O=N.firstChild)!==null;)R=N,N=O;for(;;){if(N===e)break t;if(R===E&&++o===r&&(a=l),R===T&&++S===n&&(i=l),(O=N.nextSibling)!==null)break;N=R,R=N.parentNode}N=O}E=a===-1||i===-1?null:{start:a,end:i}}else E=null}E=E||{start:0,end:0}}else E=null;for(kl={focusedElem:e,selectionRange:E},Gs=!1,re=t;re!==null;)if(t=re,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,re=e;else for(;re!==null;){t=re;try{var L=t.alternate;if(t.flags&1024)switch(t.tag){case 0:case 11:case 15:break;case 1:if(L!==null){var _=L.memoizedProps,H=L.memoizedState,c=t.stateNode,A=c.getSnapshotBeforeUpdate(t.elementType===t.type?_:$t(t.type,_),H);c.__reactInternalSnapshotBeforeUpdate=A}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(z(163))}}catch(C){et(t,t.return,C)}if(e=t.sibling,e!==null){e.return=t.return,re=e;break}re=t.return}return L=Oi,Oi=!1,L}function Lr(e,t,E){var n=t.updateQueue;if(n=n!==null?n.lastEffect:null,n!==null){var r=n=n.next;do{if((r.tag&e)===e){var T=r.destroy;r.destroy=void 0,T!==void 0&&aa(t,E,T)}r=r.next}while(r!==n)}}function iT(e,t){if(t=t.updateQueue,t=t!==null?t.lastEffect:null,t!==null){var E=t=t.next;do{if((E.tag&e)===e){var n=E.create;E.destroy=n()}E=E.next}while(E!==t)}}function oa(e){var t=e.ref;if(t!==null){var E=e.stateNode;switch(e.tag){case 5:e=E;break;default:e=E}typeof t=="function"?t(e):t.current=e}}function AS(e){var t=e.alternate;t!==null&&(e.alternate=null,AS(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[sE],delete t[vr],delete t[Jl],delete t[XI],delete t[jI])),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 SS(e){return e.tag===5||e.tag===3||e.tag===4}function ci(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||SS(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 ia(e,t,E){var n=e.tag;if(n===5||n===6)e=e.stateNode,t?E.nodeType===8?E.parentNode.insertBefore(e,t):E.insertBefore(e,t):(E.nodeType===8?(t=E.parentNode,t.insertBefore(e,E)):(t=E,t.appendChild(e)),E=E._reactRootContainer,E!=null||t.onclick!==null||(t.onclick=Bs));else if(n!==4&&(e=e.child,e!==null))for(ia(e,t,E),e=e.sibling;e!==null;)ia(e,t,E),e=e.sibling}function Ra(e,t,E){var n=e.tag;if(n===5||n===6)e=e.stateNode,t?E.insertBefore(e,t):E.appendChild(e);else if(n!==4&&(e=e.child,e!==null))for(Ra(e,t,E),e=e.sibling;e!==null;)Ra(e,t,E),e=e.sibling}var Rt=null,Jt=!1;function DE(e,t,E){for(E=E.child;E!==null;)NS(e,t,E),E=E.sibling}function NS(e,t,E){if(TE&&typeof TE.onCommitFiberUnmount=="function")try{TE.onCommitFiberUnmount(ET,E)}catch{}switch(E.tag){case 5:ct||Un(E,t);case 6:var n=Rt,r=Jt;Rt=null,DE(e,t,E),Rt=n,Jt=r,Rt!==null&&(Jt?(e=Rt,E=E.stateNode,e.nodeType===8?e.parentNode.removeChild(E):e.removeChild(E)):Rt.removeChild(E.stateNode));break;case 18:Rt!==null&&(Jt?(e=Rt,E=E.stateNode,e.nodeType===8?bT(e.parentNode,E):e.nodeType===1&&bT(e,E),Ur(e)):bT(Rt,E.stateNode));break;case 4:n=Rt,r=Jt,Rt=E.stateNode.containerInfo,Jt=!0,DE(e,t,E),Rt=n,Jt=r;break;case 0:case 11:case 14:case 15:if(!ct&&(n=E.updateQueue,n!==null&&(n=n.lastEffect,n!==null))){r=n=n.next;do{var T=r,l=T.destroy;T=T.tag,l!==void 0&&(T&2||T&4)&&aa(E,t,l),r=r.next}while(r!==n)}DE(e,t,E);break;case 1:if(!ct&&(Un(E,t),n=E.stateNode,typeof n.componentWillUnmount=="function"))try{n.props=E.memoizedProps,n.state=E.memoizedState,n.componentWillUnmount()}catch(a){et(E,t,a)}DE(e,t,E);break;case 21:DE(e,t,E);break;case 22:E.mode&1?(ct=(n=ct)||E.memoizedState!==null,DE(e,t,E),ct=n):DE(e,t,E);break;default:DE(e,t,E)}}function Ci(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var E=e.stateNode;E===null&&(E=e.stateNode=new lu),t.forEach(function(n){var r=Ou.bind(null,e,n);E.has(n)||(E.add(n),n.then(r,r))})}}function Kt(e,t){var E=t.deletions;if(E!==null)for(var n=0;n<E.length;n++){var r=E[n];try{var T=e,l=t,a=l;e:for(;a!==null;){switch(a.tag){case 5:Rt=a.stateNode,Jt=!1;break e;case 3:Rt=a.stateNode.containerInfo,Jt=!0;break e;case 4:Rt=a.stateNode.containerInfo,Jt=!0;break e}a=a.return}if(Rt===null)throw Error(z(160));NS(T,l,r),Rt=null,Jt=!1;var i=r.alternate;i!==null&&(i.return=null),r.return=null}catch(o){et(r,t,o)}}if(t.subtreeFlags&12854)for(t=t.child;t!==null;)IS(t,e),t=t.sibling}function IS(e,t){var E=e.alternate,n=e.flags;switch(e.tag){case 0:case 11:case 14:case 15:if(Kt(t,e),EE(e),n&4){try{Lr(3,e,e.return),iT(3,e)}catch(_){et(e,e.return,_)}try{Lr(5,e,e.return)}catch(_){et(e,e.return,_)}}break;case 1:Kt(t,e),EE(e),n&512&&E!==null&&Un(E,E.return);break;case 5:if(Kt(t,e),EE(e),n&512&&E!==null&&Un(E,E.return),e.flags&32){var r=e.stateNode;try{Dr(r,"")}catch(_){et(e,e.return,_)}}if(n&4&&(r=e.stateNode,r!=null)){var T=e.memoizedProps,l=E!==null?E.memoizedProps:T,a=e.type,i=e.updateQueue;if(e.updateQueue=null,i!==null)try{a==="input"&&T.type==="radio"&&T.name!=null&&BR(r,T),vl(a,l);var o=vl(a,T);for(l=0;l<i.length;l+=2){var S=i[l],N=i[l+1];S==="style"?VR(r,N):S==="dangerouslySetInnerHTML"?wR(r,N):S==="children"?Dr(r,N):Pa(r,S,N,o)}switch(a){case"input":Ul(r,T);break;case"textarea":FR(r,T);break;case"select":var R=r._wrapperState.wasMultiple;r._wrapperState.wasMultiple=!!T.multiple;var O=T.value;O!=null?yn(r,!!T.multiple,O,!1):R!==!!T.multiple&&(T.defaultValue!=null?yn(r,!!T.multiple,T.defaultValue,!0):yn(r,!!T.multiple,T.multiple?[]:"",!1))}r[vr]=T}catch(_){et(e,e.return,_)}}break;case 6:if(Kt(t,e),EE(e),n&4){if(e.stateNode===null)throw Error(z(162));r=e.stateNode,T=e.memoizedProps;try{r.nodeValue=T}catch(_){et(e,e.return,_)}}break;case 3:if(Kt(t,e),EE(e),n&4&&E!==null&&E.memoizedState.isDehydrated)try{Ur(t.containerInfo)}catch(_){et(e,e.return,_)}break;case 4:Kt(t,e),EE(e);break;case 13:Kt(t,e),EE(e),r=e.child,r.flags&8192&&(T=r.memoizedState!==null,r.stateNode.isHidden=T,!T||r.alternate!==null&&r.alternate.memoizedState!==null||(To=tt())),n&4&&Ci(e);break;case 22:if(S=E!==null&&E.memoizedState!==null,e.mode&1?(ct=(o=ct)||S,Kt(t,e),ct=o):Kt(t,e),EE(e),n&8192){if(o=e.memoizedState!==null,(e.stateNode.isHidden=o)&&!S&&e.mode&1)for(re=e,S=e.child;S!==null;){for(N=re=S;re!==null;){switch(R=re,O=R.child,R.tag){case 0:case 11:case 14:case 15:Lr(4,R,R.return);break;case 1:Un(R,R.return);var L=R.stateNode;if(typeof L.componentWillUnmount=="function"){n=R,E=R.return;try{t=n,L.props=t.memoizedProps,L.state=t.memoizedState,L.componentWillUnmount()}catch(_){et(n,E,_)}}break;case 5:Un(R,R.return);break;case 22:if(R.memoizedState!==null){Li(N);continue}}O!==null?(O.return=R,re=O):Li(N)}S=S.sibling}e:for(S=null,N=e;;){if(N.tag===5){if(S===null){S=N;try{r=N.stateNode,o?(T=r.style,typeof T.setProperty=="function"?T.setProperty("display","none","important"):T.display="none"):(a=N.stateNode,i=N.memoizedProps.style,l=i!=null&&i.hasOwnProperty("display")?i.display:null,a.style.display=bR("display",l))}catch(_){et(e,e.return,_)}}}else if(N.tag===6){if(S===null)try{N.stateNode.nodeValue=o?"":N.memoizedProps}catch(_){et(e,e.return,_)}}else if((N.tag!==22&&N.tag!==23||N.memoizedState===null||N===e)&&N.child!==null){N.child.return=N,N=N.child;continue}if(N===e)break e;for(;N.sibling===null;){if(N.return===null||N.return===e)break e;S===N&&(S=null),N=N.return}S===N&&(S=null),N.sibling.return=N.return,N=N.sibling}}break;case 19:Kt(t,e),EE(e),n&4&&Ci(e);break;case 21:break;default:Kt(t,e),EE(e)}}function EE(e){var t=e.flags;if(t&2){try{e:{for(var E=e.return;E!==null;){if(SS(E)){var n=E;break e}E=E.return}throw Error(z(160))}switch(n.tag){case 5:var r=n.stateNode;n.flags&32&&(Dr(r,""),n.flags&=-33);var T=ci(e);Ra(e,T,r);break;case 3:case 4:var l=n.stateNode.containerInfo,a=ci(e);ia(e,a,l);break;default:throw Error(z(161))}}catch(i){et(e,e.return,i)}e.flags&=-3}t&4096&&(e.flags&=-4097)}function ou(e,t,E){re=e,uS(e)}function uS(e,t,E){for(var n=(e.mode&1)!==0;re!==null;){var r=re,T=r.child;if(r.tag===22&&n){var l=r.memoizedState!==null||is;if(!l){var a=r.alternate,i=a!==null&&a.memoizedState!==null||ct;a=is;var o=ct;if(is=l,(ct=i)&&!o)for(re=r;re!==null;)l=re,i=l.child,l.tag===22&&l.memoizedState!==null?_i(r):i!==null?(i.return=l,re=i):_i(r);for(;T!==null;)re=T,uS(T),T=T.sibling;re=r,is=a,ct=o}di(e)}else r.subtreeFlags&8772&&T!==null?(T.return=r,re=T):di(e)}}function di(e){for(;re!==null;){var t=re;if(t.flags&8772){var E=t.alternate;try{if(t.flags&8772)switch(t.tag){case 0:case 11:case 15:ct||iT(5,t);break;case 1:var n=t.stateNode;if(t.flags&4&&!ct)if(E===null)n.componentDidMount();else{var r=t.elementType===t.type?E.memoizedProps:$t(t.type,E.memoizedProps);n.componentDidUpdate(r,E.memoizedState,n.__reactInternalSnapshotBeforeUpdate)}var T=t.updateQueue;T!==null&&ri(t,T,n);break;case 3:var l=t.updateQueue;if(l!==null){if(E=null,t.child!==null)switch(t.child.tag){case 5:E=t.child.stateNode;break;case 1:E=t.child.stateNode}ri(t,l,E)}break;case 5:var a=t.stateNode;if(E===null&&t.flags&4){E=a;var i=t.memoizedProps;switch(t.type){case"button":case"input":case"select":case"textarea":i.autoFocus&&E.focus();break;case"img":i.src&&(E.src=i.src)}}break;case 6:break;case 4:break;case 12:break;case 13:if(t.memoizedState===null){var o=t.alternate;if(o!==null){var S=o.memoizedState;if(S!==null){var N=S.dehydrated;N!==null&&Ur(N)}}}break;case 19:case 17:case 21:case 22:case 23:case 25:break;default:throw Error(z(163))}ct||t.flags&512&&oa(t)}catch(R){et(t,t.return,R)}}if(t===e){re=null;break}if(E=t.sibling,E!==null){E.return=t.return,re=E;break}re=t.return}}function Li(e){for(;re!==null;){var t=re;if(t===e){re=null;break}var E=t.sibling;if(E!==null){E.return=t.return,re=E;break}re=t.return}}function _i(e){for(;re!==null;){var t=re;try{switch(t.tag){case 0:case 11:case 15:var E=t.return;try{iT(4,t)}catch(i){et(t,E,i)}break;case 1:var n=t.stateNode;if(typeof n.componentDidMount=="function"){var r=t.return;try{n.componentDidMount()}catch(i){et(t,r,i)}}var T=t.return;try{oa(t)}catch(i){et(t,T,i)}break;case 5:var l=t.return;try{oa(t)}catch(i){et(t,l,i)}}}catch(i){et(t,t.return,i)}if(t===e){re=null;break}var a=t.sibling;if(a!==null){a.return=t.return,re=a;break}re=t.return}}var iu=Math.ceil,$s=_E.ReactCurrentDispatcher,ro=_E.ReactCurrentOwner,Xt=_E.ReactCurrentBatchConfig,Ue=0,it=null,nt=null,At=0,yt=0,xn=jE(0),Tt=0,br=null,on=0,RT=0,so=0,_r=null,mt=null,To=0,jn=1/0,RE=null,Js=!1,Aa=null,FE=null,Rs=!1,yE=null,zs=0,fr=0,Sa=null,fs=-1,ps=0;function _t(){return Ue&6?tt():fs!==-1?fs:fs=tt()}function YE(e){return e.mode&1?Ue&2&&At!==0?At&-At:KI.transition!==null?(ps===0&&(ps=eA()),ps):(e=He,e!==0||(e=window.event,e=e===void 0?16:lA(e.type)),e):1}function Zt(e,t,E,n){if(50<fr)throw fr=0,Sa=null,Error(z(185));Xr(e,E,n),(!(Ue&2)||e!==it)&&(e===it&&(!(Ue&2)&&(RT|=E),Tt===4&&UE(e,At)),Mt(e,n),E===1&&Ue===0&&!(t.mode&1)&&(jn=tt()+500,lT&&kE()))}function Mt(e,t){var E=e.callbackNode;KN(e,t);var n=gs(e,e===it?At:0);if(n===0)E!==null&&xo(E),e.callbackNode=null,e.callbackPriority=0;else if(t=n&-n,e.callbackPriority!==t){if(E!=null&&xo(E),t===1)e.tag===0?kI(fi.bind(null,e)):DA(fi.bind(null,e)),VI(function(){!(Ue&6)&&kE()}),E=null;else{switch(tA(n)){case 1:E=ya;break;case 4:E=ZR;break;case 16:E=ys;break;case 536870912:E=qR;break;default:E=ys}E=pS(E,OS.bind(null,e))}e.callbackPriority=t,e.callbackNode=E}}function OS(e,t){if(fs=-1,ps=0,Ue&6)throw Error(z(327));var E=e.callbackNode;if(Bn()&&e.callbackNode!==E)return null;var n=gs(e,e===it?At:0);if(n===0)return null;if(n&30||n&e.expiredLanes||t)t=Qs(e,n);else{t=n;var r=Ue;Ue|=2;var T=CS();(it!==e||At!==t)&&(RE=null,jn=tt()+500,rn(e,t));do try{Su();break}catch(a){cS(e,a)}while(!0);ja(),$s.current=T,Ue=r,nt!==null?t=0:(it=null,At=0,t=Tt)}if(t!==0){if(t===2&&(r=wl(e),r!==0&&(n=r,t=Na(e,r))),t===1)throw E=br,rn(e,0),UE(e,n),Mt(e,tt()),E;if(t===6)UE(e,n);else{if(r=e.current.alternate,!(n&30)&&!Ru(r)&&(t=Qs(e,n),t===2&&(T=wl(e),T!==0&&(n=T,t=Na(e,T))),t===1))throw E=br,rn(e,0),UE(e,n),Mt(e,tt()),E;switch(e.finishedWork=r,e.finishedLanes=n,t){case 0:case 1:throw Error(z(345));case 2:qE(e,mt,RE);break;case 3:if(UE(e,n),(n&130023424)===n&&(t=To+500-tt(),10<t)){if(gs(e,0)!==0)break;if(r=e.suspendedLanes,(r&n)!==n){_t(),e.pingedLanes|=e.suspendedLanes&r;break}e.timeoutHandle=$l(qE.bind(null,e,mt,RE),t);break}qE(e,mt,RE);break;case 4:if(UE(e,n),(n&4194240)===n)break;for(t=e.eventTimes,r=-1;0<n;){var l=31-Qt(n);T=1<<l,l=t[l],l>r&&(r=l),n&=~T}if(n=r,n=tt()-n,n=(120>n?120:480>n?480:1080>n?1080:1920>n?1920:3e3>n?3e3:4320>n?4320:1960*iu(n/1960))-n,10<n){e.timeoutHandle=$l(qE.bind(null,e,mt,RE),n);break}qE(e,mt,RE);break;case 5:qE(e,mt,RE);break;default:throw Error(z(329))}}}return Mt(e,tt()),e.callbackNode===E?OS.bind(null,e):null}function Na(e,t){var E=_r;return e.current.memoizedState.isDehydrated&&(rn(e,t).flags|=256),e=Qs(e,t),e!==2&&(t=mt,mt=E,t!==null&&Ia(t)),e}function Ia(e){mt===null?mt=e:mt.push.apply(mt,e)}function Ru(e){for(var t=e;;){if(t.flags&16384){var E=t.updateQueue;if(E!==null&&(E=E.stores,E!==null))for(var n=0;n<E.length;n++){var r=E[n],T=r.getSnapshot;r=r.value;try{if(!eE(T(),r))return!1}catch{return!1}}}if(E=t.child,t.subtreeFlags&16384&&E!==null)E.return=t,t=E;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 UE(e,t){for(t&=~so,t&=~RT,e.suspendedLanes|=t,e.pingedLanes&=~t,e=e.expirationTimes;0<t;){var E=31-Qt(t),n=1<<E;e[E]=-1,t&=~n}}function fi(e){if(Ue&6)throw Error(z(327));Bn();var t=gs(e,0);if(!(t&1))return Mt(e,tt()),null;var E=Qs(e,t);if(e.tag!==0&&E===2){var n=wl(e);n!==0&&(t=n,E=Na(e,n))}if(E===1)throw E=br,rn(e,0),UE(e,t),Mt(e,tt()),E;if(E===6)throw Error(z(345));return e.finishedWork=e.current.alternate,e.finishedLanes=t,qE(e,mt,RE),Mt(e,tt()),null}function lo(e,t){var E=Ue;Ue|=1;try{return e(t)}finally{Ue=E,Ue===0&&(jn=tt()+500,lT&&kE())}}function Rn(e){yE!==null&&yE.tag===0&&!(Ue&6)&&Bn();var t=Ue;Ue|=1;var E=Xt.transition,n=He;try{if(Xt.transition=null,He=1,e)return e()}finally{He=n,Xt.transition=E,Ue=t,!(Ue&6)&&kE()}}function ao(){yt=xn.current,Ve(xn)}function rn(e,t){e.finishedWork=null,e.finishedLanes=0;var E=e.timeoutHandle;if(E!==-1&&(e.timeoutHandle=-1,bI(E)),nt!==null)for(E=nt.return;E!==null;){var n=E;switch(Va(n),n.tag){case 1:n=n.type.childContextTypes,n!=null&&Fs();break;case 3:Wn(),Ve(Pt),Ve(Ct),Qa();break;case 5:za(n);break;case 4:Wn();break;case 13:Ve($e);break;case 19:Ve($e);break;case 10:ka(n.type._context);break;case 22:case 23:ao()}E=E.return}if(it=e,nt=e=wE(e.current,null),At=yt=t,Tt=0,br=null,so=RT=on=0,mt=_r=null,En!==null){for(t=0;t<En.length;t++)if(E=En[t],n=E.interleaved,n!==null){E.interleaved=null;var r=n.next,T=E.pending;if(T!==null){var l=T.next;T.next=r,n.next=l}E.pending=n}En=null}return e}function cS(e,t){do{var E=nt;try{if(ja(),ds.current=Ks,ks){for(var n=Je.memoizedState;n!==null;){var r=n.queue;r!==null&&(r.pending=null),n=n.next}ks=!1}if(an=0,ot=st=Je=null,dr=!1,Fr=0,ro.current=null,E===null||E.return===null){Tt=1,br=t,nt=null;break}e:{var T=e,l=E.return,a=E,i=t;if(t=At,a.flags|=32768,i!==null&&typeof i=="object"&&typeof i.then=="function"){var o=i,S=a,N=S.tag;if(!(S.mode&1)&&(N===0||N===11||N===15)){var R=S.alternate;R?(S.updateQueue=R.updateQueue,S.memoizedState=R.memoizedState,S.lanes=R.lanes):(S.updateQueue=null,S.memoizedState=null)}var O=ii(l);if(O!==null){O.flags&=-257,Ri(O,l,a,T,t),O.mode&1&&oi(T,o,t),t=O,i=o;var L=t.updateQueue;if(L===null){var _=new Set;_.add(i),t.updateQueue=_}else L.add(i);break e}else{if(!(t&1)){oi(T,o,t),oo();break e}i=Error(z(426))}}else if(ke&&a.mode&1){var H=ii(l);if(H!==null){!(H.flags&65536)&&(H.flags|=256),Ri(H,l,a,T,t),Wa(Xn(i,a));break e}}T=i=Xn(i,a),Tt!==4&&(Tt=2),_r===null?_r=[T]:_r.push(T),T=l;do{switch(T.tag){case 3:T.flags|=65536,t&=-t,T.lanes|=t;var c=tS(T,i,t);ni(T,c);break e;case 1:a=i;var A=T.type,I=T.stateNode;if(!(T.flags&128)&&(typeof A.getDerivedStateFromError=="function"||I!==null&&typeof I.componentDidCatch=="function"&&(FE===null||!FE.has(I)))){T.flags|=65536,t&=-t,T.lanes|=t;var C=ES(T,a,t);ni(T,C);break e}}T=T.return}while(T!==null)}LS(E)}catch(M){t=M,nt===E&&E!==null&&(nt=E=E.return);continue}break}while(!0)}function CS(){var e=$s.current;return $s.current=Ks,e===null?Ks:e}function oo(){(Tt===0||Tt===3||Tt===2)&&(Tt=4),it===null||!(on&268435455)&&!(RT&268435455)||UE(it,At)}function Qs(e,t){var E=Ue;Ue|=2;var n=CS();(it!==e||At!==t)&&(RE=null,rn(e,t));do try{Au();break}catch(r){cS(e,r)}while(!0);if(ja(),Ue=E,$s.current=n,nt!==null)throw Error(z(261));return it=null,At=0,Tt}function Au(){for(;nt!==null;)dS(nt)}function Su(){for(;nt!==null&&!FN();)dS(nt)}function dS(e){var t=fS(e.alternate,e,yt);e.memoizedProps=e.pendingProps,t===null?LS(e):nt=t,ro.current=null}function LS(e){var t=e;do{var E=t.alternate;if(e=t.return,t.flags&32768){if(E=Tu(E,t),E!==null){E.flags&=32767,nt=E;return}if(e!==null)e.flags|=32768,e.subtreeFlags=0,e.deletions=null;else{Tt=6,nt=null;return}}else if(E=su(E,t,yt),E!==null){nt=E;return}if(t=t.sibling,t!==null){nt=t;return}nt=t=e}while(t!==null);Tt===0&&(Tt=5)}function qE(e,t,E){var n=He,r=Xt.transition;try{Xt.transition=null,He=1,Nu(e,t,E,n)}finally{Xt.transition=r,He=n}return null}function Nu(e,t,E,n){do Bn();while(yE!==null);if(Ue&6)throw Error(z(327));E=e.finishedWork;var r=e.finishedLanes;if(E===null)return null;if(e.finishedWork=null,e.finishedLanes=0,E===e.current)throw Error(z(177));e.callbackNode=null,e.callbackPriority=0;var T=E.lanes|E.childLanes;if($N(e,T),e===it&&(nt=it=null,At=0),!(E.subtreeFlags&2064)&&!(E.flags&2064)||Rs||(Rs=!0,pS(ys,function(){return Bn(),null})),T=(E.flags&15990)!==0,E.subtreeFlags&15990||T){T=Xt.transition,Xt.transition=null;var l=He;He=1;var a=Ue;Ue|=4,ro.current=null,au(e,E),IS(E,e),GI(kl),Gs=!!jl,kl=jl=null,e.current=E,ou(E),YN(),Ue=a,He=l,Xt.transition=T}else e.current=E;if(Rs&&(Rs=!1,yE=e,zs=r),T=e.pendingLanes,T===0&&(FE=null),VN(E.stateNode),Mt(e,tt()),t!==null)for(n=e.onRecoverableError,E=0;E<t.length;E++)r=t[E],n(r.value,{componentStack:r.stack,digest:r.digest});if(Js)throw Js=!1,e=Aa,Aa=null,e;return zs&1&&e.tag!==0&&Bn(),T=e.pendingLanes,T&1?e===Sa?fr++:(fr=0,Sa=e):fr=0,kE(),null}function Bn(){if(yE!==null){var e=tA(zs),t=Xt.transition,E=He;try{if(Xt.transition=null,He=16>e?16:e,yE===null)var n=!1;else{if(e=yE,yE=null,zs=0,Ue&6)throw Error(z(331));var r=Ue;for(Ue|=4,re=e.current;re!==null;){var T=re,l=T.child;if(re.flags&16){var a=T.deletions;if(a!==null){for(var i=0;i<a.length;i++){var o=a[i];for(re=o;re!==null;){var S=re;switch(S.tag){case 0:case 11:case 15:Lr(8,S,T)}var N=S.child;if(N!==null)N.return=S,re=N;else for(;re!==null;){S=re;var R=S.sibling,O=S.return;if(AS(S),S===o){re=null;break}if(R!==null){R.return=O,re=R;break}re=O}}}var L=T.alternate;if(L!==null){var _=L.child;if(_!==null){L.child=null;do{var H=_.sibling;_.sibling=null,_=H}while(_!==null)}}re=T}}if(T.subtreeFlags&2064&&l!==null)l.return=T,re=l;else e:for(;re!==null;){if(T=re,T.flags&2048)switch(T.tag){case 0:case 11:case 15:Lr(9,T,T.return)}var c=T.sibling;if(c!==null){c.return=T.return,re=c;break e}re=T.return}}var A=e.current;for(re=A;re!==null;){l=re;var I=l.child;if(l.subtreeFlags&2064&&I!==null)I.return=l,re=I;else e:for(l=A;re!==null;){if(a=re,a.flags&2048)try{switch(a.tag){case 0:case 11:case 15:iT(9,a)}}catch(M){et(a,a.return,M)}if(a===l){re=null;break e}var C=a.sibling;if(C!==null){C.return=a.return,re=C;break e}re=a.return}}if(Ue=r,kE(),TE&&typeof TE.onPostCommitFiberRoot=="function")try{TE.onPostCommitFiberRoot(ET,e)}catch{}n=!0}return n}finally{He=E,Xt.transition=t}}return!1}function pi(e,t,E){t=Xn(E,t),t=tS(e,t,1),e=BE(e,t,1),t=_t(),e!==null&&(Xr(e,1,t),Mt(e,t))}function et(e,t,E){if(e.tag===3)pi(e,e,E);else for(;t!==null;){if(t.tag===3){pi(t,e,E);break}else if(t.tag===1){var n=t.stateNode;if(typeof t.type.getDerivedStateFromError=="function"||typeof n.componentDidCatch=="function"&&(FE===null||!FE.has(n))){e=Xn(E,e),e=ES(t,e,1),t=BE(t,e,1),e=_t(),t!==null&&(Xr(t,1,e),Mt(t,e));break}}t=t.return}}function Iu(e,t,E){var n=e.pingCache;n!==null&&n.delete(t),t=_t(),e.pingedLanes|=e.suspendedLanes&E,it===e&&(At&E)===E&&(Tt===4||Tt===3&&(At&130023424)===At&&500>tt()-To?rn(e,0):so|=E),Mt(e,t)}function _S(e,t){t===0&&(e.mode&1?(t=ts,ts<<=1,!(ts&130023424)&&(ts=4194304)):t=1);var E=_t();e=CE(e,t),e!==null&&(Xr(e,t,E),Mt(e,E))}function uu(e){var t=e.memoizedState,E=0;t!==null&&(E=t.retryLane),_S(e,E)}function Ou(e,t){var E=0;switch(e.tag){case 13:var n=e.stateNode,r=e.memoizedState;r!==null&&(E=r.retryLane);break;case 19:n=e.stateNode;break;default:throw Error(z(314))}n!==null&&n.delete(t),_S(e,E)}var fS;fS=function(e,t,E){if(e!==null)if(e.memoizedProps!==t.pendingProps||Pt.current)Dt=!0;else{if(!(e.lanes&E)&&!(t.flags&128))return Dt=!1,ru(e,t,E);Dt=!!(e.flags&131072)}else Dt=!1,ke&&t.flags&1048576&&PA(t,bs,t.index);switch(t.lanes=0,t.tag){case 2:var n=t.type;_s(e,t),e=t.pendingProps;var r=wn(t,Ct.current);Hn(t,E),r=qa(null,t,n,e,r,E);var T=eo();return t.flags|=1,typeof r=="object"&&r!==null&&typeof r.render=="function"&&r.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,ht(n)?(T=!0,Ys(t)):T=!1,t.memoizedState=r.state!==null&&r.state!==void 0?r.state:null,$a(t),r.updater=oT,t.stateNode=r,r._reactInternals=t,ta(t,n,e,E),t=ra(null,t,n,!0,T,E)):(t.tag=0,ke&&T&&ba(t),Lt(null,t,r,E),t=t.child),t;case 16:n=t.elementType;e:{switch(_s(e,t),e=t.pendingProps,r=n._init,n=r(n._payload),t.type=n,r=t.tag=Cu(n),e=$t(n,e),r){case 0:t=na(null,t,n,e,E);break e;case 1:t=Ni(null,t,n,e,E);break e;case 11:t=Ai(null,t,n,e,E);break e;case 14:t=Si(null,t,n,$t(n.type,e),E);break e}throw Error(z(306,n,""))}return t;case 0:return n=t.type,r=t.pendingProps,r=t.elementType===n?r:$t(n,r),na(e,t,n,r,E);case 1:return n=t.type,r=t.pendingProps,r=t.elementType===n?r:$t(n,r),Ni(e,t,n,r,E);case 3:e:{if(TS(t),e===null)throw Error(z(387));n=t.pendingProps,T=t.memoizedState,r=T.element,gA(e,t),Xs(t,n,null,E);var l=t.memoizedState;if(n=l.element,T.isDehydrated)if(T={element:n,isDehydrated:!1,cache:l.cache,pendingSuspenseBoundaries:l.pendingSuspenseBoundaries,transitions:l.transitions},t.updateQueue.baseState=T,t.memoizedState=T,t.flags&256){r=Xn(Error(z(423)),t),t=Ii(e,t,n,E,r);break e}else if(n!==r){r=Xn(Error(z(424)),t),t=Ii(e,t,n,E,r);break e}else for(gt=HE(t.stateNode.containerInfo.firstChild),vt=t,ke=!0,zt=null,E=xA(t,null,n,E),t.child=E;E;)E.flags=E.flags&-3|4096,E=E.sibling;else{if(bn(),n===r){t=dE(e,t,E);break e}Lt(e,t,n,E)}t=t.child}return t;case 5:return GA(t),e===null&&Zl(t),n=t.type,r=t.pendingProps,T=e!==null?e.memoizedProps:null,l=r.children,Kl(n,r)?l=null:T!==null&&Kl(n,T)&&(t.flags|=32),sS(e,t),Lt(e,t,l,E),t.child;case 6:return e===null&&Zl(t),null;case 13:return lS(e,t,E);case 4:return Ja(t,t.stateNode.containerInfo),n=t.pendingProps,e===null?t.child=Vn(t,null,n,E):Lt(e,t,n,E),t.child;case 11:return n=t.type,r=t.pendingProps,r=t.elementType===n?r:$t(n,r),Ai(e,t,n,r,E);case 7:return Lt(e,t,t.pendingProps,E),t.child;case 8:return Lt(e,t,t.pendingProps.children,E),t.child;case 12:return Lt(e,t,t.pendingProps.children,E),t.child;case 10:e:{if(n=t.type._context,r=t.pendingProps,T=t.memoizedProps,l=r.value,Fe(Vs,n._currentValue),n._currentValue=l,T!==null)if(eE(T.value,l)){if(T.children===r.children&&!Pt.current){t=dE(e,t,E);break e}}else for(T=t.child,T!==null&&(T.return=t);T!==null;){var a=T.dependencies;if(a!==null){l=T.child;for(var i=a.firstContext;i!==null;){if(i.context===n){if(T.tag===1){i=uE(-1,E&-E),i.tag=2;var o=T.updateQueue;if(o!==null){o=o.shared;var S=o.pending;S===null?i.next=i:(i.next=S.next,S.next=i),o.pending=i}}T.lanes|=E,i=T.alternate,i!==null&&(i.lanes|=E),ql(T.return,E,t),a.lanes|=E;break}i=i.next}}else if(T.tag===10)l=T.type===t.type?null:T.child;else if(T.tag===18){if(l=T.return,l===null)throw Error(z(341));l.lanes|=E,a=l.alternate,a!==null&&(a.lanes|=E),ql(l,E,t),l=T.sibling}else l=T.child;if(l!==null)l.return=T;else for(l=T;l!==null;){if(l===t){l=null;break}if(T=l.sibling,T!==null){T.return=l.return,l=T;break}l=l.return}T=l}Lt(e,t,r.children,E),t=t.child}return t;case 9:return r=t.type,n=t.pendingProps.children,Hn(t,E),r=jt(r),n=n(r),t.flags|=1,Lt(e,t,n,E),t.child;case 14:return n=t.type,r=$t(n,t.pendingProps),r=$t(n.type,r),Si(e,t,n,r,E);case 15:return nS(e,t,t.type,t.pendingProps,E);case 17:return n=t.type,r=t.pendingProps,r=t.elementType===n?r:$t(n,r),_s(e,t),t.tag=1,ht(n)?(e=!0,Ys(t)):e=!1,Hn(t,E),eS(t,n,r),ta(t,n,r,E),ra(null,t,n,!0,e,E);case 19:return aS(e,t,E);case 22:return rS(e,t,E)}throw Error(z(156,t.tag))};function pS(e,t){return QR(e,t)}function cu(e,t,E,n){this.tag=e,this.key=E,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=n,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function Wt(e,t,E,n){return new cu(e,t,E,n)}function io(e){return e=e.prototype,!(!e||!e.isReactComponent)}function Cu(e){if(typeof e=="function")return io(e)?1:0;if(e!=null){if(e=e.$$typeof,e===Ma)return 11;if(e===Ua)return 14}return 2}function wE(e,t){var E=e.alternate;return E===null?(E=Wt(e.tag,t,e.key,e.mode),E.elementType=e.elementType,E.type=e.type,E.stateNode=e.stateNode,E.alternate=e,e.alternate=E):(E.pendingProps=t,E.type=e.type,E.flags=0,E.subtreeFlags=0,E.deletions=null),E.flags=e.flags&14680064,E.childLanes=e.childLanes,E.lanes=e.lanes,E.child=e.child,E.memoizedProps=e.memoizedProps,E.memoizedState=e.memoizedState,E.updateQueue=e.updateQueue,t=e.dependencies,E.dependencies=t===null?null:{lanes:t.lanes,firstContext:t.firstContext},E.sibling=e.sibling,E.index=e.index,E.ref=e.ref,E}function ms(e,t,E,n,r,T){var l=2;if(n=e,typeof e=="function")io(e)&&(l=1);else if(typeof e=="string")l=5;else e:switch(e){case Ln:return sn(E.children,r,T,t);case ha:l=8,r|=8;break;case ml:return e=Wt(12,E,t,r|2),e.elementType=ml,e.lanes=T,e;case Dl:return e=Wt(13,E,t,r),e.elementType=Dl,e.lanes=T,e;case Pl:return e=Wt(19,E,t,r),e.elementType=Pl,e.lanes=T,e;case GR:return AT(E,r,T,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case yR:l=10;break e;case gR:l=9;break e;case Ma:l=11;break e;case Ua:l=14;break e;case PE:l=16,n=null;break e}throw Error(z(130,e==null?e:typeof e,""))}return t=Wt(l,E,t,r),t.elementType=e,t.type=n,t.lanes=T,t}function sn(e,t,E,n){return e=Wt(7,e,n,t),e.lanes=E,e}function AT(e,t,E,n){return e=Wt(22,e,n,t),e.elementType=GR,e.lanes=E,e.stateNode={isHidden:!1},e}function JT(e,t,E){return e=Wt(6,e,null,t),e.lanes=E,e}function zT(e,t,E){return t=Wt(4,e.children!==null?e.children:[],e.key,t),t.lanes=E,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function du(e,t,E,n,r){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=UT(0),this.expirationTimes=UT(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=UT(0),this.identifierPrefix=n,this.onRecoverableError=r,this.mutableSourceEagerHydrationData=null}function Ro(e,t,E,n,r,T,l,a,i){return e=new du(e,t,E,a,i),t===1?(t=1,T===!0&&(t|=8)):t=0,T=Wt(3,null,null,t),e.current=T,T.stateNode=e,T.memoizedState={element:n,isDehydrated:E,cache:null,transitions:null,pendingSuspenseBoundaries:null},$a(T),e}function Lu(e,t,E){var n=3<arguments.length&&arguments[3]!==void 0?arguments[3]:null;return{$$typeof:dn,key:n==null?null:""+n,children:e,containerInfo:t,implementation:E}}function mS(e){if(!e)return VE;e=e._reactInternals;e:{if(Nn(e)!==e||e.tag!==1)throw Error(z(170));var t=e;do{switch(t.tag){case 3:t=t.stateNode.context;break e;case 1:if(ht(t.type)){t=t.stateNode.__reactInternalMemoizedMergedChildContext;break e}}t=t.return}while(t!==null);throw Error(z(171))}if(e.tag===1){var E=e.type;if(ht(E))return mA(e,E,t)}return t}function DS(e,t,E,n,r,T,l,a,i){return e=Ro(E,n,!0,e,r,T,l,a,i),e.context=mS(null),E=e.current,n=_t(),r=YE(E),T=uE(n,r),T.callback=t??null,BE(E,T,r),e.current.lanes=r,Xr(e,r,n),Mt(e,n),e}function ST(e,t,E,n){var r=t.current,T=_t(),l=YE(r);return E=mS(E),t.context===null?t.context=E:t.pendingContext=E,t=uE(T,l),t.payload={element:e},n=n===void 0?null:n,n!==null&&(t.callback=n),e=BE(r,t,l),e!==null&&(Zt(e,r,l,T),Cs(e,r,l)),l}function Zs(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 mi(e,t){if(e=e.memoizedState,e!==null&&e.dehydrated!==null){var E=e.retryLane;e.retryLane=E!==0&&E<t?E:t}}function Ao(e,t){mi(e,t),(e=e.alternate)&&mi(e,t)}function _u(){return null}var PS=typeof reportError=="function"?reportError:function(e){console.error(e)};function So(e){this._internalRoot=e}NT.prototype.render=So.prototype.render=function(e){var t=this._internalRoot;if(t===null)throw Error(z(409));ST(e,t,null,null)};NT.prototype.unmount=So.prototype.unmount=function(){var e=this._internalRoot;if(e!==null){this._internalRoot=null;var t=e.containerInfo;Rn(function(){ST(null,e,null,null)}),t[cE]=null}};function NT(e){this._internalRoot=e}NT.prototype.unstable_scheduleHydration=function(e){if(e){var t=rA();e={blockedOn:null,target:e,priority:t};for(var E=0;E<ME.length&&t!==0&&t<ME[E].priority;E++);ME.splice(E,0,e),E===0&&TA(e)}};function No(e){return!(!e||e.nodeType!==1&&e.nodeType!==9&&e.nodeType!==11)}function IT(e){return!(!e||e.nodeType!==1&&e.nodeType!==9&&e.nodeType!==11&&(e.nodeType!==8||e.nodeValue!==" react-mount-point-unstable "))}function Di(){}function fu(e,t,E,n,r){if(r){if(typeof n=="function"){var T=n;n=function(){var o=Zs(l);T.call(o)}}var l=DS(t,n,e,0,null,!1,!1,"",Di);return e._reactRootContainer=l,e[cE]=l.current,gr(e.nodeType===8?e.parentNode:e),Rn(),l}for(;r=e.lastChild;)e.removeChild(r);if(typeof n=="function"){var a=n;n=function(){var o=Zs(i);a.call(o)}}var i=Ro(e,0,!1,null,null,!1,!1,"",Di);return e._reactRootContainer=i,e[cE]=i.current,gr(e.nodeType===8?e.parentNode:e),Rn(function(){ST(t,i,E,n)}),i}function uT(e,t,E,n,r){var T=E._reactRootContainer;if(T){var l=T;if(typeof r=="function"){var a=r;r=function(){var i=Zs(l);a.call(i)}}ST(t,l,e,r)}else l=fu(E,t,e,r,n);return Zs(l)}EA=function(e){switch(e.tag){case 3:var t=e.stateNode;if(t.current.memoizedState.isDehydrated){var E=Sr(t.pendingLanes);E!==0&&(ga(t,E|1),Mt(t,tt()),!(Ue&6)&&(jn=tt()+500,kE()))}break;case 13:Rn(function(){var n=CE(e,1);if(n!==null){var r=_t();Zt(n,e,1,r)}}),Ao(e,1)}};Ga=function(e){if(e.tag===13){var t=CE(e,134217728);if(t!==null){var E=_t();Zt(t,e,134217728,E)}Ao(e,134217728)}};nA=function(e){if(e.tag===13){var t=YE(e),E=CE(e,t);if(E!==null){var n=_t();Zt(E,e,t,n)}Ao(e,t)}};rA=function(){return He};sA=function(e,t){var E=He;try{return He=e,t()}finally{He=E}};Bl=function(e,t,E){switch(t){case"input":if(Ul(e,E),t=E.name,E.type==="radio"&&t!=null){for(E=e;E.parentNode;)E=E.parentNode;for(E=E.querySelectorAll("input[name="+JSON.stringify(""+t)+'][type="radio"]'),t=0;t<E.length;t++){var n=E[t];if(n!==e&&n.form===e.form){var r=TT(n);if(!r)throw Error(z(90));HR(n),Ul(n,r)}}}break;case"textarea":FR(e,E);break;case"select":t=E.value,t!=null&&yn(e,!!E.multiple,t,!1)}};jR=lo;kR=Rn;var pu={usingClientEntryPoint:!1,Events:[kr,mn,TT,WR,XR,lo]},or={findFiberByHostInstance:tn,bundleType:0,version:"18.3.1",rendererPackageName:"react-dom"},mu={bundleType:or.bundleType,version:or.version,rendererPackageName:or.rendererPackageName,rendererConfig:or.rendererConfig,overrideHookState:null,overrideHookStateDeletePath:null,overrideHookStateRenamePath:null,overrideProps:null,overridePropsDeletePath:null,overridePropsRenamePath:null,setErrorHandler:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:_E.ReactCurrentDispatcher,findHostInstanceByFiber:function(e){return e=JR(e),e===null?null:e.stateNode},findFiberByHostInstance:or.findFiberByHostInstance||_u,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 As=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(!As.isDisabled&&As.supportsFiber)try{ET=As.inject(mu),TE=As}catch{}}Bt.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=pu;Bt.createPortal=function(e,t){var E=2<arguments.length&&arguments[2]!==void 0?arguments[2]:null;if(!No(t))throw Error(z(200));return Lu(e,t,null,E)};Bt.createRoot=function(e,t){if(!No(e))throw Error(z(299));var E=!1,n="",r=PS;return t!=null&&(t.unstable_strictMode===!0&&(E=!0),t.identifierPrefix!==void 0&&(n=t.identifierPrefix),t.onRecoverableError!==void 0&&(r=t.onRecoverableError)),t=Ro(e,1,!1,null,null,E,!1,n,r),e[cE]=t.current,gr(e.nodeType===8?e.parentNode:e),new So(t)};Bt.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(z(188)):(e=Object.keys(e).join(","),Error(z(268,e)));return e=JR(t),e=e===null?null:e.stateNode,e};Bt.flushSync=function(e){return Rn(e)};Bt.hydrate=function(e,t,E){if(!IT(t))throw Error(z(200));return uT(null,e,t,!0,E)};Bt.hydrateRoot=function(e,t,E){if(!No(e))throw Error(z(405));var n=E!=null&&E.hydratedSources||null,r=!1,T="",l=PS;if(E!=null&&(E.unstable_strictMode===!0&&(r=!0),E.identifierPrefix!==void 0&&(T=E.identifierPrefix),E.onRecoverableError!==void 0&&(l=E.onRecoverableError)),t=DS(t,null,e,1,E??null,r,!1,T,l),e[cE]=t.current,gr(e),n)for(e=0;e<n.length;e++)E=n[e],r=E._getVersion,r=r(E._source),t.mutableSourceEagerHydrationData==null?t.mutableSourceEagerHydrationData=[E,r]:t.mutableSourceEagerHydrationData.push(E,r);return new NT(t)};Bt.render=function(e,t,E){if(!IT(t))throw Error(z(200));return uT(null,e,t,!1,E)};Bt.unmountComponentAtNode=function(e){if(!IT(e))throw Error(z(40));return e._reactRootContainer?(Rn(function(){uT(null,null,e,!1,function(){e._reactRootContainer=null,e[cE]=null})}),!0):!1};Bt.unstable_batchedUpdates=lo;Bt.unstable_renderSubtreeIntoContainer=function(e,t,E,n){if(!IT(E))throw Error(z(200));if(e==null||e._reactInternals===void 0)throw Error(z(38));return uT(e,t,E,!1,n)};Bt.version="18.3.1-next-f1338f8080-20240426";function hS(){if(!(typeof __REACT_DEVTOOLS_GLOBAL_HOOK__>"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(hS)}catch(e){console.error(e)}}hS(),hR.exports=Bt;var Du=hR.exports,Pi=Du;fl.createRoot=Pi.createRoot,fl.hydrateRoot=Pi.hydrateRoot;/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/var Pu={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"};/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const hu=e=>e.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase().trim(),Ae=(e,t)=>{const E=u.forwardRef(({color:n="currentColor",size:r=24,strokeWidth:T=2,absoluteStrokeWidth:l,className:a="",children:i,...o},S)=>u.createElement("svg",{ref:S,...Pu,width:r,height:r,stroke:n,strokeWidth:l?Number(T)*24/Number(r):T,className:["lucide",`lucide-${hu(e)}`,a].join(" "),...o},[...t.map(([N,R])=>u.createElement(N,R)),...Array.isArray(i)?i:[i]]));return E.displayName=`${e}`,E};/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const MS=Ae("AlertCircle",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["line",{x1:"12",x2:"12",y1:"8",y2:"12",key:"1pkeuh"}],["line",{x1:"12",x2:"12.01",y1:"16",y2:"16",key:"4dfq90"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Mu=Ae("AlignLeft",[["line",{x1:"21",x2:"3",y1:"6",y2:"6",key:"1fp77t"}],["line",{x1:"15",x2:"3",y1:"12",y2:"12",key:"v6grx8"}],["line",{x1:"17",x2:"3",y1:"18",y2:"18",key:"1awlsn"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Uu=Ae("ArrowDown",[["path",{d:"M12 5v14",key:"s699le"}],["path",{d:"m19 12-7 7-7-7",key:"1idqje"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const xu=Ae("ArrowUp",[["path",{d:"m5 12 7-7 7 7",key:"hav0vg"}],["path",{d:"M12 19V5",key:"x0mq9r"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const hi=Ae("Calendar",[["rect",{width:"18",height:"18",x:"3",y:"4",rx:"2",ry:"2",key:"eu3xkr"}],["line",{x1:"16",x2:"16",y1:"2",y2:"6",key:"m3sa8f"}],["line",{x1:"8",x2:"8",y1:"2",y2:"6",key:"18kwsl"}],["line",{x1:"3",x2:"21",y1:"10",y2:"10",key:"xt86sb"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const yu=Ae("CheckCircle",[["path",{d:"M22 11.08V12a10 10 0 1 1-5.93-9.14",key:"g774vq"}],["path",{d:"m9 11 3 3L22 4",key:"1pflzl"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const gu=Ae("CheckSquare",[["path",{d:"m9 11 3 3L22 4",key:"1pflzl"}],["path",{d:"M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11",key:"1jnkn4"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const aE=Ae("Check",[["path",{d:"M20 6 9 17l-5-5",key:"1gmf2c"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const LE=Ae("ChevronDown",[["path",{d:"m6 9 6 6 6-6",key:"qrunsl"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Io=Ae("ChevronLeft",[["path",{d:"m15 18-6-6 6-6",key:"1wnfg3"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const WE=Ae("ChevronRight",[["path",{d:"m9 18 6-6-6-6",key:"mthhwq"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Gu=Ae("ClipboardPaste",[["path",{d:"M15 2H9a1 1 0 0 0-1 1v2c0 .6.4 1 1 1h6c.6 0 1-.4 1-1V3c0-.6-.4-1-1-1Z",key:"1pp7kr"}],["path",{d:"M8 4H6a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2M16 4h2a2 2 0 0 1 2 2v2M11 14h10",key:"2ik1ml"}],["path",{d:"m17 10 4 4-4 4",key:"vp2hj1"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const US=Ae("Copy",[["rect",{width:"14",height:"14",x:"8",y:"8",rx:"2",ry:"2",key:"17jyea"}],["path",{d:"M4 16c-1.1 0-2-.9-2-2V4c0-1.1.9-2 2-2h10c1.1 0 2 .9 2 2",key:"zix9uf"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Gt=Ae("Database",[["ellipse",{cx:"12",cy:"5",rx:"9",ry:"3",key:"msslwz"}],["path",{d:"M3 5V19A9 3 0 0 0 21 19V5",key:"1wlel7"}],["path",{d:"M3 12A9 3 0 0 0 21 12",key:"mv7ke4"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const xS=Ae("Download",[["path",{d:"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4",key:"ih7n3h"}],["polyline",{points:"7 10 12 15 17 10",key:"2ggqvy"}],["line",{x1:"12",x2:"12",y1:"15",y2:"3",key:"1vk2je"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const vu=Ae("Eye",[["path",{d:"M2 12s3-7 10-7 10 7 10 7-3 7-10 7-10-7-10-7Z",key:"rwhkz3"}],["circle",{cx:"12",cy:"12",r:"3",key:"1v7zrd"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const qs=Ae("FileCode",[["path",{d:"M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z",key:"1nnpy2"}],["polyline",{points:"14 2 14 8 20 8",key:"1ew0cm"}],["path",{d:"m10 13-2 2 2 2",key:"17smn8"}],["path",{d:"m14 17 2-2-2-2",key:"14mezr"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const yS=Ae("FileSpreadsheet",[["path",{d:"M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z",key:"1nnpy2"}],["polyline",{points:"14 2 14 8 20 8",key:"1ew0cm"}],["path",{d:"M8 13h2",key:"yr2amv"}],["path",{d:"M8 17h2",key:"2yhykz"}],["path",{d:"M14 13h2",key:"un5t4a"}],["path",{d:"M14 17h2",key:"10kma7"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const ua=Ae("FileText",[["path",{d:"M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z",key:"1nnpy2"}],["polyline",{points:"14 2 14 8 20 8",key:"1ew0cm"}],["line",{x1:"16",x2:"8",y1:"13",y2:"13",key:"14keom"}],["line",{x1:"16",x2:"8",y1:"17",y2:"17",key:"17nazh"}],["line",{x1:"10",x2:"8",y1:"9",y2:"9",key:"1a5vjj"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Hu=Ae("FileX",[["path",{d:"M14.5 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7.5L14.5 2z",key:"1nnpy2"}],["polyline",{points:"14 2 14 8 20 8",key:"1ew0cm"}],["line",{x1:"9.5",x2:"14.5",y1:"12.5",y2:"17.5",key:"izs6du"}],["line",{x1:"14.5",x2:"9.5",y1:"12.5",y2:"17.5",key:"1lehlj"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Oa=Ae("FolderOpen",[["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"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const ca=Ae("Folder",[["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"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Bu=Ae("Globe",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"M12 2a14.5 14.5 0 0 0 0 20 14.5 14.5 0 0 0 0-20",key:"13o1zl"}],["path",{d:"M2 12h20",key:"9i4pu4"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Fu=Ae("GripVertical",[["circle",{cx:"9",cy:"12",r:"1",key:"1vctgf"}],["circle",{cx:"9",cy:"5",r:"1",key:"hp0tcf"}],["circle",{cx:"9",cy:"19",r:"1",key:"fkjjf6"}],["circle",{cx:"15",cy:"12",r:"1",key:"1tmaij"}],["circle",{cx:"15",cy:"5",r:"1",key:"19l28e"}],["circle",{cx:"15",cy:"19",r:"1",key:"f4zoj3"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Yu=Ae("HardDrive",[["line",{x1:"22",x2:"2",y1:"12",y2:"12",key:"1y58io"}],["path",{d:"M5.45 5.11 2 12v6a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-6l-3.45-6.89A2 2 0 0 0 16.76 4H7.24a2 2 0 0 0-1.79 1.11z",key:"oot6mr"}],["line",{x1:"6",x2:"6.01",y1:"16",y2:"16",key:"sgf278"}],["line",{x1:"10",x2:"10.01",y1:"16",y2:"16",key:"1l4acy"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const OT=Ae("Key",[["circle",{cx:"7.5",cy:"15.5",r:"5.5",key:"yqb3hr"}],["path",{d:"m21 2-9.6 9.6",key:"1j0ho8"}],["path",{d:"m15.5 7.5 3 3L22 7l-3-3",key:"1rn1fs"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const wu=Ae("Link2",[["path",{d:"M9 17H7A5 5 0 0 1 7 7h2",key:"8i5ue5"}],["path",{d:"M15 7h2a5 5 0 1 1 0 10h-2",key:"1b9ql8"}],["line",{x1:"8",x2:"16",y1:"12",y2:"12",key:"1jonct"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const bu=Ae("List",[["line",{x1:"8",x2:"21",y1:"6",y2:"6",key:"7ey8pc"}],["line",{x1:"8",x2:"21",y1:"12",y2:"12",key:"rjfblc"}],["line",{x1:"8",x2:"21",y1:"18",y2:"18",key:"c3b1m8"}],["line",{x1:"3",x2:"3.01",y1:"6",y2:"6",key:"1g7gq3"}],["line",{x1:"3",x2:"3.01",y1:"12",y2:"12",key:"1pjlvk"}],["line",{x1:"3",x2:"3.01",y1:"18",y2:"18",key:"28t2mc"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Fn=Ae("Loader2",[["path",{d:"M21 12a9 9 0 1 1-6.219-8.56",key:"13zald"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Vu=Ae("Maximize2",[["polyline",{points:"15 3 21 3 21 9",key:"mznyad"}],["polyline",{points:"9 21 3 21 3 15",key:"1avn1i"}],["line",{x1:"21",x2:"14",y1:"3",y2:"10",key:"ota7mn"}],["line",{x1:"3",x2:"10",y1:"21",y2:"14",key:"1atl0r"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Wu=Ae("Minimize2",[["polyline",{points:"4 14 10 14 10 20",key:"11kfnr"}],["polyline",{points:"20 10 14 10 14 4",key:"rlmsce"}],["line",{x1:"14",x2:"21",y1:"10",y2:"3",key:"o5lafz"}],["line",{x1:"3",x2:"10",y1:"21",y2:"14",key:"1atl0r"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const gS=Ae("Minus",[["path",{d:"M5 12h14",key:"1ays0h"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Mi=Ae("PenLine",[["path",{d:"M12 20h9",key:"t2du7b"}],["path",{d:"M16.5 3.5a2.12 2.12 0 0 1 3 3L7 19l-4 1 1-4Z",key:"ymcmye"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Xu=Ae("PinOff",[["line",{x1:"2",x2:"22",y1:"2",y2:"22",key:"a6p6uj"}],["line",{x1:"12",x2:"12",y1:"17",y2:"22",key:"1jrz49"}],["path",{d:"M9 9v1.76a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24V17h12",key:"13x2n8"}],["path",{d:"M15 9.34V6h1a2 2 0 0 0 0-4H7.89",key:"reo3ki"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const ju=Ae("Pin",[["line",{x1:"12",x2:"12",y1:"17",y2:"22",key:"1jrz49"}],["path",{d:"M5 17h14v-1.76a2 2 0 0 0-1.11-1.79l-1.78-.9A2 2 0 0 1 15 10.76V6h1a2 2 0 0 0 0-4H8a2 2 0 0 0 0 4h1v4.76a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24Z",key:"13yl11"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const ku=Ae("Play",[["polygon",{points:"5 3 19 12 5 21 5 3",key:"191637"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Ui=Ae("PlusCircle",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"M8 12h8",key:"1wcyev"}],["path",{d:"M12 8v8",key:"napkw2"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const In=Ae("Plus",[["path",{d:"M5 12h14",key:"1ays0h"}],["path",{d:"M12 5v14",key:"s699le"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Vr=Ae("RefreshCw",[["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"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const GS=Ae("Save",[["path",{d:"M19 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11l5 5v11a2 2 0 0 1-2 2z",key:"1owoqh"}],["polyline",{points:"17 21 17 13 7 13 7 21",key:"1md35c"}],["polyline",{points:"7 3 7 8 15 8",key:"8nz8an"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const cT=Ae("Search",[["circle",{cx:"11",cy:"11",r:"8",key:"4ej97u"}],["path",{d:"m21 21-4.3-4.3",key:"1qie3q"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Ca=Ae("Server",[["rect",{width:"20",height:"8",x:"2",y:"2",rx:"2",ry:"2",key:"ngkwjq"}],["rect",{width:"20",height:"8",x:"2",y:"14",rx:"2",ry:"2",key:"iecqi9"}],["line",{x1:"6",x2:"6.01",y1:"6",y2:"6",key:"16zg32"}],["line",{x1:"6",x2:"6.01",y1:"18",y2:"18",key:"nzw8ys"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const uo=Ae("Settings",[["path",{d:"M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.51a2 2 0 0 1-1 1.74l-.15.09a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.39a2 2 0 0 0-.73-2.73l-.15-.08a2 2 0 0 1-1-1.74v-.5a2 2 0 0 1 1-1.74l.15-.09a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2z",key:"1qme2f"}],["circle",{cx:"12",cy:"12",r:"3",key:"1v7zrd"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Ku=Ae("Shield",[["path",{d:"M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10",key:"1irkt0"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const $u=Ae("Square",[["rect",{width:"18",height:"18",x:"3",y:"3",rx:"2",key:"afitv7"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const zn=Ae("Table2",[["path",{d:"M9 3H5a2 2 0 0 0-2 2v4m6-6h10a2 2 0 0 1 2 2v4M9 3v18m0 0h10a2 2 0 0 0 2-2V9M9 21H5a2 2 0 0 1-2-2V9m0 0h18",key:"gugj83"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const IE=Ae("Trash2",[["path",{d:"M3 6h18",key:"d0wm0j"}],["path",{d:"M19 6v14c0 1-1 2-2 2H7c-1 0-2-1-2-2V6",key:"4alrt4"}],["path",{d:"M8 6V4c0-1 1-2 2-2h4c1 0 2 1 2 2v2",key:"v07s0e"}],["line",{x1:"10",x2:"10",y1:"11",y2:"17",key:"1uufr5"}],["line",{x1:"14",x2:"14",y1:"11",y2:"17",key:"xtxkd"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Ju=Ae("Type",[["polyline",{points:"4 7 4 4 20 4 20 7",key:"1nosan"}],["line",{x1:"9",x2:"15",y1:"20",y2:"20",key:"swin9y"}],["line",{x1:"12",x2:"12",y1:"4",y2:"20",key:"1tx1rr"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const zu=Ae("Upload",[["path",{d:"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4",key:"ih7n3h"}],["polyline",{points:"17 8 12 3 7 8",key:"t8dd8p"}],["line",{x1:"12",x2:"12",y1:"3",y2:"15",key:"widbto"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const xi=Ae("User",[["path",{d:"M19 21v-2a4 4 0 0 0-4-4H9a4 4 0 0 0-4 4v2",key:"975kel"}],["circle",{cx:"12",cy:"7",r:"4",key:"17ys0d"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Qu=Ae("XCircle",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"m15 9-6 6",key:"1uzhvr"}],["path",{d:"m9 9 6 6",key:"z0biqf"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const tE=Ae("X",[["path",{d:"M18 6 6 18",key:"1bl5f8"}],["path",{d:"m6 6 12 12",key:"d8bk6v"}]]);/**
|
||
* @license lucide-react v0.294.0 - ISC
|
||
*
|
||
* This source code is licensed under the ISC license.
|
||
* See the LICENSE file in the root directory of this source tree.
|
||
*/const Zu=Ae("Zap",[["polygon",{points:"13 2 3 14 12 14 11 22 21 10 12 10 13 2",key:"45s27k"}]]),de=()=>typeof window<"u"&&window.electronAPI?window.electronAPI:null,Le={minimize:async()=>{const e=de();e&&await e.minimize()},maximize:async()=>{const e=de();e&&await e.maximize()},close:async()=>{const e=de();e&&await e.close()},testConnection:async e=>{const t=de();if(!t)return{success:!1,message:"Electron API 不可用"};try{return await t.testConnection(e)}catch(E){return{success:!1,message:E.toString()}}},connect:async e=>{const t=de();if(!t)return{success:!1,message:"Electron API 不可用"};try{return await t.connect(e)}catch(E){return{success:!1,message:E.toString()}}},disconnect:async e=>{const t=de();if(t)try{await t.disconnect(e)}catch(E){console.error("Disconnect error:",E)}},query:async(e,t)=>{const E=de();if(!E)return{columns:[],rows:[],error:"Electron API 不可用"};try{const n=await E.query(e,t);return{columns:n.columns,rows:n.rows,error:n.error}}catch(n){return{columns:[],rows:[],error:n.toString()}}},executeQuery:async(e,t)=>{const E=de();if(!E)return{columns:[],rows:[],error:"Electron API 不可用"};try{const n=await E.query(e,t);return{columns:n.columns,rows:n.rows,error:n.error}}catch(n){return{columns:[],rows:[],error:n.toString()}}},getDatabases:async e=>{const t=de();if(!t)return[];try{return await t.getDatabases(e)}catch(E){return console.error("getDatabases error:",E),[]}},getTables:async(e,t)=>{const E=de();if(!E)return[];try{return await E.getTables(e,t)}catch(n){return console.error("getTables error:",n),[]}},getColumns:async(e,t,E)=>{const n=de();if(!n)return[];try{return await n.getColumns(e,t,E)}catch(r){return console.error("getColumns error:",r),[]}},getTableColumns:async(e,t,E)=>{const n=de();if(!n)return[];try{return await n.getColumns(e,t,E)}catch(r){return console.error("getTableColumns error:",r),[]}},getTableData:async(e,t,E,n,r)=>{const T=de();if(!T)return{data:[],total:0};try{const l=await T.getTableData(e,t,E,n||1,r||100),a=l.columns||[];return{data:(l.rows||[]).map(o=>{const S={};return a.forEach((N,R)=>{S[N.name]=o[R]}),S}),total:l.total,columns:l.columns}}catch(l){return console.error("getTableData error:",l),{data:[],total:0}}},updateRow:async(e,t,E,n,r)=>{const T=de();if(!T)return{success:!1,error:"Electron API 不可用"};try{const l=await T.updateRow(e,t,E,n,r);return{success:l.success,error:l.success?void 0:l.message}}catch(l){return{success:!1,error:l.toString()}}},deleteRow:async(e,t,E,n)=>{const r=de();if(!r)return{success:!1,error:"Electron API 不可用"};try{const T=await r.deleteRow(e,t,E,n);return{success:T.success,error:T.success?void 0:T.message}}catch(T){return{success:!1,error:T.toString()}}},insertRow:async(e,t,E,n,r)=>{const T=de();if(!T)return{success:!1,error:"Electron API 不可用"};try{const l=await T.insertRow(e,t,E,n,r);return{success:l.success,error:l.success?void 0:l.message,insertId:l.insertId}}catch(l){return{success:!1,error:l.toString()}}},updateTableRow:async(e,t,E,n,r,T)=>{const l=de();if(!l)return{success:!1,error:"Electron API 不可用"};try{const a=await l.updateRow(e,t,E,{column:n,value:r},T);return{success:a.success,error:a.success?void 0:a.message}}catch(a){return{success:!1,error:a.toString()}}},insertTableRow:async(e,t,E,n)=>{const r=Object.keys(n),T=Object.values(n),l=de();if(!l)return{success:!1,error:"Electron API 不可用"};try{const a=await l.insertRow(e,t,E,r,T);return{success:a.success,error:a.success?void 0:a.message,insertId:a.insertId}}catch(a){return{success:!1,error:a.toString()}}},deleteTableRow:async(e,t,E,n,r)=>{const T=de();if(!T)return{success:!1,error:"Electron API 不可用"};try{const l=await T.deleteRow(e,t,E,{column:n,value:r});return{success:l.success,error:l.success?void 0:l.message}}catch(l){return{success:!1,error:l.toString()}}},createDatabase:async(e,t,E="utf8mb4",n="utf8mb4_general_ci")=>{const r=de();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.createDatabase(e,t,E,n)}catch(T){return{success:!1,message:T.toString()}}},dropDatabase:async(e,t)=>{const E=de();if(!E)return{success:!1,message:"Electron API 不可用"};try{return await E.dropDatabase(e,t)}catch(n){return{success:!1,message:n.toString()}}},createTable:async(e,t,E,n)=>{const r=de();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.createTable(e,t,E,n)}catch(T){return{success:!1,message:T.toString()}}},dropTable:async(e,t,E)=>{const n=de();if(!n)return{success:!1,message:"Electron API 不可用"};try{return await n.dropTable(e,t,E)}catch(r){return{success:!1,message:r.toString()}}},truncateTable:async(e,t,E)=>{const n=de();if(!n)return{success:!1,message:"Electron API 不可用"};try{return await n.truncateTable(e,t,E)}catch(r){return{success:!1,message:r.toString()}}},renameTable:async(e,t,E,n)=>{const r=de();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.renameTable(e,t,E,n)}catch(T){return{success:!1,message:T.toString()}}},duplicateTable:async(e,t,E,n,r=!1)=>{const T=de();if(!T)return{success:!1,message:"Electron API 不可用"};try{return await T.duplicateTable(e,t,E,n,r)}catch(l){return{success:!1,message:l.toString()}}},addColumn:async(e,t,E,n)=>{const r=de();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.addColumn(e,t,E,n)}catch(T){return{success:!1,message:T.toString()}}},modifyColumn:async(e,t,E,n,r)=>{const T=de();if(!T)return{success:!1,message:"Electron API 不可用"};try{return await T.modifyColumn(e,t,E,n,r)}catch(l){return{success:!1,message:l.toString()}}},dropColumn:async(e,t,E,n)=>{const r=de();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.dropColumn(e,t,E,n)}catch(T){return{success:!1,message:T.toString()}}},getTableInfo:async(e,t,E)=>{const n=de();if(!n)return{columns:[],indexes:[],foreignKeys:[],options:{}};try{return await n.getTableInfo(e,t,E)}catch(r){return console.error("getTableInfo error:",r),{columns:[],indexes:[],foreignKeys:[],options:{}}}},getIndexes:async(e,t,E)=>{const n=de();if(!n)return[];try{return await n.getIndexes(e,t,E)}catch(r){return console.error("getIndexes error:",r),[]}},getForeignKeys:async(e,t,E)=>{const n=de();if(!n)return[];try{return await n.getForeignKeys(e,t,E)}catch(r){return console.error("getForeignKeys error:",r),[]}},getColumnNames:async(e,t,E)=>{const n=de();if(!n)return[];try{return await n.getColumnNames(e,t,E)}catch(r){return console.error("getColumnNames error:",r),[]}},executeMultiSQL:async(e,t)=>{const E=de();if(!E)return{success:!1,message:"Electron API 不可用"};try{return await E.executeMultiSQL(e,t)}catch(n){return{success:!1,message:n.toString()}}},saveConnections:async e=>{const t=de();if(t)try{await t.saveConnections(e)}catch(E){console.error("saveConnections error:",E)}},loadConnections:async()=>{const e=de();if(!e)return[];try{return await e.loadConnections()}catch(t){return console.error("loadConnections error:",t),[]}},exportConnections:async(e,t)=>{const E=de();if(!E)return{success:!1,error:"Electron API 不可用"};try{const n=await E.saveDialog({filters:[{name:t==="json"?"JSON":"Navicat NCX",extensions:[t==="json"?"json":"ncx"]}]});if(!n)return{cancelled:!0};const r=t==="json"?JSON.stringify(e,null,2):eO(e);return await E.writeFile(n,r),{success:!0,path:n,count:e.length}}catch(n){return{success:!1,error:n.toString()}}},importConnections:async()=>{const e=de();if(!e)return{success:!1,error:"Electron API 不可用"};try{const t=await e.selectFile(["json","ncx"]);if(!t)return{cancelled:!0};const E=await e.readFile(t);if(!E.success||!E.content)return{success:!1,error:E.error||"读取文件失败"};const n=t.toLowerCase().endsWith(".ncx");let r;return n?r=await qu(E.content,e):r=JSON.parse(E.content),{success:!0,connections:r,count:r.length,source:n?"Navicat":"JSON"}}catch(t){return{success:!1,error:t.toString()}}},openFile:async()=>{const e=de();if(!e)return null;try{return await e.openFile()}catch(t){return{path:"",content:"",name:"",error:t.toString()}}},saveFile:async(e,t)=>{const E=de();if(!E)return null;try{return await E.saveFile(e,t)}catch(n){return{path:"",name:"",error:n.toString()}}},selectFile:async e=>{const t=de();if(!t)return null;try{const E=await t.selectFile(e);return E?{path:E}:null}catch{return null}},backupDatabase:async(e,t)=>{const E=de();if(!E)return{success:!1,error:"Electron API 不可用"};try{const n=await E.saveDialog({filters:[{name:"SQL 文件",extensions:["sql"]}],defaultPath:`${t}_backup.sql`});if(!n)return{cancelled:!0};const r=await Le.getTables(e,t);let T=`-- Database: ${t}
|
||
-- Backup Time: ${new Date().toISOString()}
|
||
|
||
`;for(const l of r){if(l.isView)continue;const a=await Le.query(e,`SELECT * FROM \`${l.name}\``);if(a.rows&&a.rows.length>0){for(const i of a.rows){const o=i.map(S=>S===null?"NULL":typeof S=="string"?`'${S.replace(/'/g,"''")}'`:S).join(", ");T+=`INSERT INTO \`${l.name}\` VALUES (${o});
|
||
`}T+=`
|
||
`}}return await E.writeFile(n,T),{success:!0,path:n}}catch(n){return{success:!1,error:n.toString()}}},exportTable:async(e,t,E,n)=>{const r=de();if(!r)return{success:!1,error:"Electron API 不可用"};try{const T=n==="excel"?"xlsx":n,l=await r.saveDialog({filters:[{name:n.toUpperCase(),extensions:[T]}],defaultPath:`${E}.${T}`});if(!l)return{cancelled:!0};const a=await Le.query(e,`SELECT * FROM \`${E}\``);let i;if(n==="csv"){const o=a.columns.join(","),S=a.rows.map(N=>N.map(R=>R===null?"":typeof R=="string"?`"${R.replace(/"/g,'""')}"`:R).join(",")).join(`
|
||
`);i=`${o}
|
||
${S}`}else if(n==="sql")i=a.rows.map(o=>{const S=o.map(N=>N===null?"NULL":typeof N=="string"?`'${N.replace(/'/g,"''")}'`:N).join(", ");return`INSERT INTO \`${E}\` VALUES (${S});`}).join(`
|
||
`);else{const o=a.columns.join(","),S=a.rows.map(N=>N.map(R=>R===null?"":typeof R=="string"?`"${R.replace(/"/g,'""')}"`:R).join(",")).join(`
|
||
`);i=`${o}
|
||
${S}`}return await r.writeFile(l,i),{success:!0,path:l}}catch(T){return{success:!1,error:T.toString()}}}};async function qu(e,t){const E=[],n=/<Connection\s+([^>]*?)\/>/gi,r=/<Connection\s+([^>]*?)>/gi,T=R=>{const O={},L=/(\w+)\s*=\s*"([^"]*)"/g;let _;for(;(_=L.exec(R))!==null;)O[_[1]]=_[2];return O},l=async R=>{const O=R.ConnectionName||R.Name||R.connection_name||"";if(!O)return null;let L=(R.ConnType||R.Type||R.conn_type||"mysql").toLowerCase();L==="postgresql"&&(L="postgres"),(L==="sql server"||L==="mssql")&&(L="sqlserver");const _=R.Password||R.password||"";let H="";if(_&&/^[0-9A-Fa-f]+$/.test(_)&&_.length>=16)try{const c=parseInt(R.Version||R.version||"12")||12;H=await t.decryptNavicatPassword(_,c),console.log(`密码解密成功: ${O} (版本: ${c})`)}catch(c){console.warn(`密码解密失败: ${O}`,c),H=_}else H=_;return{id:crypto.randomUUID(),name:O,type:L,host:R.Host||R.host||R.Server||"localhost",port:parseInt(R.Port||R.port||"3306")||3306,username:R.UserName||R.Username||R.User||R.user||"",password:H,database:R.Database||R.database||R.InitialDatabase||""}},a=[];let i;for(;(i=n.exec(e))!==null;)a.push(i[1]);for(;(i=r.exec(e))!==null;)a.push(i[1]);const o=a.map(async R=>{const O=T(R);return await l(O)}),S=await Promise.all(o);for(const R of S)R&&E.push(R);return E.filter((R,O,L)=>O===L.findIndex(_=>_.name===R.name))}function eO(e){let t=`<?xml version="1.0" encoding="UTF-8"?>
|
||
<Connections>
|
||
`;for(const E of e)t+=` <Connection ConnectionName="${E.name}" ConnType="${E.type}" `,t+=`Host="${E.host}" Port="${E.port}" `,t+=`UserName="${E.username}" Password="${E.password}" `,t+=`Database="${E.database||""}" />
|
||
`;return t+="</Connections>",t}const tO=u.memo(function(){const[t,E]=u.useState(!1),n=async()=>{await Le.maximize(),E(!t)};return s.jsxs("div",{className:"h-10 bg-white flex items-center justify-between drag select-none border-b border-border-default",children:[s.jsxs("div",{className:"flex items-center h-full px-4 no-drag gap-2.5",children:[s.jsx("div",{className:"w-7 h-7 rounded-lg bg-primary-500 flex items-center justify-center",children:s.jsx(Gt,{size:15,className:"text-white"})}),s.jsx("span",{className:"text-sm font-semibold text-text-primary",children:"EasySQL"}),s.jsxs("span",{className:"text-[10px] font-medium px-1.5 py-0.5 rounded bg-primary-50 text-primary-600",children:["v","2.0.1"]})]}),s.jsxs("div",{className:"flex h-full no-drag",children:[s.jsx("button",{onClick:()=>Le.minimize(),className:"w-11 h-full flex items-center justify-center hover:bg-light-hover transition-colors",title:"最小化",children:s.jsx(gS,{size:15,className:"text-text-tertiary"})}),s.jsx("button",{onClick:n,className:"w-11 h-full flex items-center justify-center hover:bg-light-hover transition-colors",title:t?"还原":"最大化",children:t?s.jsx(Wu,{size:13,className:"text-text-tertiary"}):s.jsx(Vu,{size:13,className:"text-text-tertiary"})}),s.jsx("button",{onClick:()=>Le.close(),className:"w-11 h-full flex items-center justify-center hover:bg-danger-500 hover:text-white transition-colors group",title:"关闭",children:s.jsx(tE,{size:15,className:"text-text-tertiary group-hover:text-white"})})]})]})}),rE={mysql:{name:"MySQL",icon:"🐬",color:"#00758f",defaultPort:3306,supported:!0,needsHost:!0,needsAuth:!0,needsFile:!1},postgres:{name:"PostgreSQL",icon:"🐘",color:"#336791",defaultPort:5432,supported:!0,needsHost:!0,needsAuth:!0,needsFile:!1},sqlite:{name:"SQLite",icon:"💾",color:"#003b57",defaultPort:0,supported:!0,needsHost:!1,needsAuth:!1,needsFile:!0},mongodb:{name:"MongoDB",icon:"🍃",color:"#47a248",defaultPort:27017,supported:!0,needsHost:!0,needsAuth:!0,needsFile:!1},redis:{name:"Redis",icon:"⚡",color:"#dc382d",defaultPort:6379,supported:!0,needsHost:!0,needsAuth:!0,needsFile:!1},sqlserver:{name:"SQL Server",icon:"📊",color:"#cc2927",defaultPort:1433,supported:!0,needsHost:!0,needsAuth:!0,needsFile:!1},oracle:{name:"Oracle",icon:"🔶",color:"#f80000",defaultPort:1521,supported:!1,needsHost:!0,needsAuth:!0,needsFile:!1},mariadb:{name:"MariaDB",icon:"🦭",color:"#c0765a",defaultPort:3306,supported:!0,needsHost:!0,needsAuth:!0,needsFile:!1},snowflake:{name:"Snowflake",icon:"❄️",color:"#29b5e8",defaultPort:443,supported:!1,needsHost:!0,needsAuth:!0,needsFile:!1}},EO=u.memo(function({tables:t,db:E,connectionId:n,expandedDbs:r,setExpandedDbs:T,onOpenTable:l,onContextMenu:a}){const i=t.filter(_=>!_.isView),o=t.filter(_=>_.isView),S=`${E}_tables`,N=`${E}_views`,R=r.has(S),O=r.has(N),L=_=>{T(H=>{const c=new Set(H);return c.has(_)?c.delete(_):c.add(_),c})};return u.useEffect(()=>{i.length>0&&T(_=>new Set(_).add(S))},[i.length,S,T]),t.length===0?s.jsx("div",{className:"px-4 py-3 text-xs text-text-muted",children:"暂无表"}):s.jsxs("div",{className:"py-1",children:[i.length>0&&s.jsxs("div",{children:[s.jsxs("div",{className:"flex items-center gap-2 px-3 py-1.5 mx-2 text-xs text-text-secondary hover:bg-light-hover cursor-pointer transition-colors rounded-lg",onClick:()=>L(S),children:[s.jsx("span",{className:"text-text-muted",children:R?s.jsx(LE,{size:12}):s.jsx(WE,{size:12})}),s.jsx("span",{className:"text-warning-500",children:R?s.jsx(Oa,{size:13}):s.jsx(ca,{size:13})}),s.jsx("span",{className:"flex-1 font-medium",children:"表"}),s.jsx("span",{className:"text-text-muted text-[10px] bg-light-elevated px-1.5 py-0.5 rounded-full",children:i.length})]}),R&&s.jsx("div",{className:"ml-4 pl-2 border-l border-border-light",children:i.map(_=>s.jsxs("div",{className:"flex items-center gap-2 px-2 py-1.5 mr-1 text-text-secondary hover:bg-light-hover cursor-pointer transition-colors rounded-lg group",onClick:()=>l(n,E,_.name),onContextMenu:H=>a(H,_.name),title:_.name,children:[s.jsx(zn,{size:14,className:"text-warning-500 flex-shrink-0"}),s.jsx("span",{className:"truncate font-mono text-[13px] flex-1 min-w-0",children:_.name})]},_.name))})]}),o.length>0&&s.jsxs("div",{className:"mt-1",children:[s.jsxs("div",{className:"flex items-center gap-2 px-3 py-1.5 mx-2 text-xs text-text-secondary hover:bg-light-hover cursor-pointer transition-colors rounded-lg",onClick:()=>L(N),children:[s.jsx("span",{className:"text-text-muted",children:O?s.jsx(LE,{size:12}):s.jsx(WE,{size:12})}),s.jsx("span",{className:"text-info-500",children:O?s.jsx(Oa,{size:13}):s.jsx(ca,{size:13})}),s.jsx("span",{className:"flex-1 font-medium",children:"视图"}),s.jsx("span",{className:"text-text-muted text-[10px] bg-light-elevated px-1.5 py-0.5 rounded-full",children:o.length})]}),O&&s.jsx("div",{className:"ml-4 pl-2 border-l border-border-light",children:o.map(_=>s.jsxs("div",{className:"flex items-center gap-2 px-2 py-1.5 mr-1 text-text-secondary hover:bg-light-hover cursor-pointer transition-colors rounded-lg group",onClick:()=>l(n,E,_.name),onContextMenu:H=>a(H,_.name),title:_.name,children:[s.jsx(vu,{size:14,className:"text-info-500 flex-shrink-0"}),s.jsx("span",{className:"truncate font-mono text-[13px] flex-1 min-w-0",children:_.name})]},_.name))})]})]})});function QT(e,t,E=200,n=200){const r=window.innerHeight,T=window.innerWidth;let l=e,a=t;return t+E>r-10&&(a=Math.max(10,t-E)),e+n>T-10&&(l=Math.max(10,e-n)),{x:l,y:a}}function nO({connections:e,activeConnection:t,connectedIds:E,databasesMap:n,tablesMap:r,selectedDatabase:T,loadingDbSet:l,loadingConnectionsSet:a,onNewConnection:i,onSelectConnection:o,onConnect:S,onDisconnect:N,onEditConnection:R,onDeleteConnection:O,onDeleteConnections:L,onSelectDatabase:_,onOpenTable:H,onBackupDatabase:c,onExportTable:A,onExportConnections:I,onImportConnections:C,onCreateDatabase:M,onDropDatabase:p,onCreateTable:P,onDropTable:D,onTruncateTable:Z,onRenameTable:Y,onDuplicateTable:ne,onRefreshTables:xe,onDesignTable:Se,onFetchDatabases:he}){const[B,j]=u.useState(null),[ee,b]=u.useState(null),[U,J]=u.useState(null),[Ee,ce]=u.useState(new Set),[ye,me]=u.useState(!1),[De,Ne]=u.useState(new Set),[se,We]=u.useState(""),Xe=u.useRef(null),W=u.useRef(null),[Qe,Te]=u.useState(!1),Ke=u.useRef(new Set);u.useEffect(()=>{T&&ce(y=>new Set(y).add(T))},[T]),u.useEffect(()=>{const y=Ke.current;E.forEach(le=>{y.has(le)||ce(Ce=>new Set(Ce).add(le))}),Ke.current=new Set(E)},[E]);const Ye=u.useCallback(y=>{(y.ctrlKey||y.metaKey)&&y.key==="f"&&Qe&&(y.preventDefault(),y.stopPropagation(),setTimeout(()=>Xe.current?.focus(),50)),y.key==="Escape"&&se&&We("")},[Qe,se]);u.useEffect(()=>{const y=W.current;if(y)return y.addEventListener("keydown",Ye),()=>y.removeEventListener("keydown",Ye)},[Ye]);const Q=y=>{const le=r.get(y)||[];return se?le.filter(Ce=>Ce.name.toLowerCase().includes(se.toLowerCase())):le},Oe=y=>se?(r.get(y)||[]).some(Ce=>Ce.name.toLowerCase().includes(se.toLowerCase())):!1,pe=y=>y.filter(le=>{if(!se)return!0;const Ce=se.toLowerCase();return!!(le.toLowerCase().includes(Ce)||Oe(le))});return u.useEffect(()=>{se&&n.forEach(y=>{y.forEach(le=>{Oe(le)&&ce(Ce=>new Set(Ce).add(le))})})},[se,n,r]),s.jsxs(s.Fragment,{children:[s.jsxs("div",{ref:W,className:"w-80 bg-light-surface flex flex-col h-full select-none border-r border-border-default",tabIndex:0,onFocus:()=>Te(!0),onBlur:y=>{y.currentTarget.contains(y.relatedTarget)||Te(!1)},onMouseEnter:()=>Te(!0),onMouseLeave:()=>Te(!1),children:[s.jsxs("div",{className:"p-3 flex-shrink-0 space-y-2",children:[s.jsxs("button",{onClick:i,className:`w-full h-9 bg-primary-500 hover:bg-primary-600 text-white
|
||
flex items-center justify-center gap-2 text-sm font-medium
|
||
transition-all rounded-lg shadow-btn hover:shadow-btn-hover`,children:[s.jsx(In,{size:16,strokeWidth:2.5}),s.jsx("span",{children:"新建连接"})]}),s.jsxs("div",{className:"flex gap-2",children:[s.jsxs("button",{onClick:C,className:`flex-1 h-8 bg-white hover:bg-light-hover border border-border-default
|
||
flex items-center justify-center gap-1.5 text-xs text-text-secondary
|
||
transition-colors rounded-lg`,children:[s.jsx(zu,{size:13}),s.jsx("span",{children:"导入"})]}),s.jsxs("div",{className:"relative group flex-1",children:[s.jsxs("button",{className:`w-full h-8 bg-white hover:bg-light-hover border border-border-default
|
||
flex items-center justify-center gap-1.5 text-xs text-text-secondary
|
||
transition-colors rounded-lg`,children:[s.jsx(xS,{size:13}),s.jsx("span",{children:"导出"})]}),s.jsxs("div",{className:`absolute left-0 right-0 top-full mt-1 bg-white border border-border-default
|
||
rounded-lg shadow-lg opacity-0 invisible group-hover:opacity-100 group-hover:visible
|
||
transition-all z-50 overflow-hidden`,children:[s.jsxs("button",{onClick:()=>I?.("json"),className:"w-full px-3 py-2 text-left text-xs hover:bg-light-hover flex items-center gap-2 text-text-primary",children:[s.jsx(qs,{size:12,className:"text-primary-500"}),"导出 JSON"]}),s.jsxs("button",{onClick:()=>I?.("ncx"),className:"w-full px-3 py-2 text-left text-xs hover:bg-light-hover flex items-center gap-2 text-text-primary",children:[s.jsx(ua,{size:12,className:"text-warning-500"}),"导出 Navicat"]})]})]})]})]}),s.jsx("div",{className:"px-3 pb-2 flex-shrink-0",children:s.jsxs("div",{className:"relative",children:[s.jsx(cT,{size:14,className:"absolute left-3 top-1/2 -translate-y-1/2 text-text-muted"}),s.jsx("input",{ref:Xe,type:"text",value:se,onChange:y=>We(y.target.value),placeholder:"搜索...",className:`w-full h-8 pl-9 pr-8 bg-white text-sm text-text-primary placeholder-text-muted
|
||
border border-border-default focus:border-primary-500 transition-all rounded-lg`}),se&&s.jsx("button",{onClick:()=>We(""),className:"absolute right-2 top-1/2 -translate-y-1/2 text-text-muted hover:text-text-secondary p-0.5",children:s.jsx(tE,{size:14})})]})}),s.jsxs("div",{className:"flex-1 overflow-y-auto min-h-0 scrollbar-thin",children:[s.jsxs("div",{className:"px-3 py-2 flex items-center justify-between",children:[s.jsxs("span",{className:"text-[10px] font-semibold text-text-muted uppercase tracking-wider",children:["连接 · ",e.length]}),e.length>0&&s.jsx("button",{onClick:()=>{me(!ye),ye&&Ne(new Set)},className:`p-1 rounded transition-colors ${ye?"bg-primary-500 text-white":"hover:bg-light-hover text-text-muted"}`,children:ye?s.jsx(gu,{size:12}):s.jsx($u,{size:12})})]}),ye&&De.size>0&&s.jsxs("div",{className:"px-3 pb-2 flex items-center gap-2 animate-fade-in",children:[s.jsxs("span",{className:"text-xs text-text-tertiary",children:["已选 ",De.size," 项"]}),s.jsxs("button",{onClick:()=>{confirm(`确定删除 ${De.size} 个连接?`)&&(L?.([...De]),Ne(new Set),me(!1))},className:"px-2 py-1 text-xs bg-danger-50 text-danger-600 hover:bg-danger-100 rounded-md flex items-center gap-1",children:[s.jsx(IE,{size:11}),"删除"]})]}),e.length===0?s.jsxs("div",{className:"px-3 py-8 text-center",children:[s.jsx("div",{className:"w-12 h-12 mx-auto mb-3 rounded-xl bg-light-elevated flex items-center justify-center",children:s.jsx(Gt,{size:24,className:"text-text-muted"})}),s.jsx("p",{className:"text-text-muted text-sm",children:"暂无连接"}),s.jsx("p",{className:"text-text-disabled text-xs mt-1",children:"点击上方按钮创建"})]}):s.jsx("div",{className:"px-2 pb-3 space-y-0.5",children:e.map(y=>{const le=rE[y.type],Ce=E.has(y.id),ge=t===y.id,je=De.has(y.id),Be=Ee.has(y.id),Ze=n.get(y.id)||[];return Be&&Ce&&Ze.length>0,s.jsxs("div",{children:[s.jsxs("div",{className:`group flex items-center gap-2 px-2.5 py-2 cursor-pointer transition-all rounded-lg
|
||
${je?"bg-primary-50 ring-1 ring-primary-200":""}
|
||
${ge&&!je?"bg-light-hover":"hover:bg-light-hover"}`,onClick:()=>{if(ye)Ne(fe=>{const m=new Set(fe);return m.has(y.id)?m.delete(y.id):m.add(y.id),m});else if(o(y.id),Ce){const fe=!Ee.has(y.id);ce(m=>{const F=new Set(m);return F.has(y.id)?F.delete(y.id):F.add(y.id),F}),fe&&Ze.length===0&&he&&he(y.id)}},onDoubleClick:async()=>{!ye&&!Ce&&(await S(y),ce(fe=>new Set(fe).add(y.id)))},onContextMenu:fe=>{fe.preventDefault();const m=QT(fe.clientX,fe.clientY,200);j({x:m.x,y:m.y,conn:y})},children:[s.jsx("span",{className:"w-4 flex-shrink-0 flex items-center justify-center",children:ye?s.jsx("span",{className:`w-4 h-4 rounded border-2 flex items-center justify-center text-[10px]
|
||
${je?"bg-primary-500 border-primary-500 text-white":"border-border-strong"}`,children:je&&"✓"}):s.jsx("span",{className:Ce?"text-text-muted":"opacity-0",children:Be?s.jsx(LE,{size:14}):s.jsx(WE,{size:14})})}),s.jsx("span",{className:"text-lg flex-shrink-0",children:le?.icon}),s.jsx("span",{className:"flex-1 text-sm truncate font-medium text-text-primary",children:y.name}),s.jsx("span",{className:`status-dot flex-shrink-0 ${Ce?"connected":"disconnected"}`})]}),Be&&Ce&&s.jsx("div",{className:"ml-5 mt-0.5 pl-3 border-l border-border-light animate-slide-down",children:a?.has(y.id)?s.jsxs("div",{className:"px-2.5 py-2 text-sm text-text-muted flex items-center gap-2",children:[s.jsx("span",{className:"w-3 h-3 border-2 border-primary-400 border-t-transparent rounded-full animate-spin"}),"加载数据库..."]}):Ze.length===0?s.jsx("div",{className:"px-2.5 py-2 text-sm text-text-muted",children:"无数据库或无权限"}):pe(Ze).map(fe=>{const m=T===fe,F=Ee.has(fe),q=Q(fe),_e=l.has(fe);return s.jsxs("div",{children:[s.jsxs("div",{className:`flex items-center gap-2 px-2.5 py-1.5 cursor-pointer text-sm transition-all rounded-lg mx-1
|
||
${m?"bg-primary-50 text-primary-700":"text-text-secondary hover:bg-light-hover"}`,onClick:()=>{!Ee.has(fe)&&_(fe,y.id),ce(ie=>{const Re=new Set(ie);return Re.has(fe)?Re.delete(fe):Re.add(fe),Re})},onContextMenu:k=>{k.preventDefault();const ie=QT(k.clientX,k.clientY,220);b({x:ie.x,y:ie.y,db:fe,connectionId:y.id})},children:[s.jsx("span",{className:"text-text-muted",children:F?s.jsx(LE,{size:14}):s.jsx(WE,{size:14})}),s.jsx(Gt,{size:14,className:m?"text-primary-500":"text-teal-500"}),s.jsx("span",{className:"flex-1 truncate",children:fe})]}),F&&s.jsx("div",{className:"ml-4 mt-0.5",children:_e?s.jsxs("div",{className:"flex items-center gap-2 px-3 py-2 text-xs text-text-muted",children:[s.jsx(Fn,{size:12,className:"animate-spin text-primary-500"}),"加载中..."]}):s.jsx(EO,{tables:q,db:fe,connectionId:y.id,expandedDbs:Ee,setExpandedDbs:ce,onOpenTable:H,onContextMenu:(k,ie)=>{k.preventDefault();const Re=QT(k.clientX,k.clientY,320);J({x:Re.x,y:Re.y,db:fe,table:ie,connectionId:y.id})}})})]},fe)})})]},y.id)})})]})]}),B&&s.jsxs(s.Fragment,{children:[s.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>j(null)}),s.jsxs("div",{className:"fixed z-50 bg-white border border-border-default py-1.5 min-w-[180px] rounded-xl shadow-modal menu",style:{left:B.x,top:B.y},children:[E.has(B.conn.id)?s.jsxs(s.Fragment,{children:[s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{N(B.conn.id),j(null)},children:[s.jsx("span",{className:"w-3 h-3 rounded-full border-2 border-danger-500"}),"断开连接"]}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{M?.(B.conn.id),j(null)},children:[s.jsx(Ui,{size:14,className:"text-success-500"}),"新建数据库"]}),s.jsx("div",{className:"my-1.5 mx-2 border-t border-border-light"})]}):s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{S(B.conn),ce(y=>new Set(y).add(B.conn.id)),j(null)},children:[s.jsx("span",{className:"w-3 h-3 rounded-full border-2 border-success-500"}),"连接"]}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{R(B.conn),j(null)},children:[s.jsx(Mi,{size:14,className:"text-text-muted"}),"编辑"]}),s.jsx("div",{className:"my-1.5 mx-2 border-t border-border-light"}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-danger-50 text-danger-600 flex items-center gap-3",onClick:()=>{O(B.conn.id),j(null)},children:[s.jsx(IE,{size:14}),"删除"]})]})]}),ee&&s.jsxs(s.Fragment,{children:[s.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>b(null)}),s.jsxs("div",{className:"fixed z-50 bg-white border border-border-default py-1.5 min-w-[180px] rounded-xl shadow-modal menu",style:{left:ee.x,top:ee.y},children:[s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{P?.(ee.connectionId,ee.db),b(null)},children:[s.jsx(Ui,{size:14,className:"text-success-500"}),"新建表"]}),s.jsx("div",{className:"my-1.5 mx-2 border-t border-border-light"}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{xe?.(ee.connectionId,ee.db),b(null)},children:[s.jsx(Vr,{size:14,className:"text-text-muted"}),"刷新"]}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{c?.(ee.db),b(null)},children:[s.jsx(Yu,{size:14,className:"text-primary-500"}),"备份"]}),s.jsx("div",{className:"my-1.5 mx-2 border-t border-border-light"}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-danger-50 text-danger-600 flex items-center gap-3",onClick:()=>{confirm(`确定删除数据库 "${ee.db}"?`)&&p?.(ee.connectionId,ee.db),b(null)},children:[s.jsx(IE,{size:14}),"删除数据库"]})]})]}),U&&s.jsxs(s.Fragment,{children:[s.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>J(null)}),s.jsxs("div",{className:"fixed z-50 bg-white border border-border-default py-1.5 min-w-[180px] rounded-xl shadow-modal menu",style:{left:U.x,top:U.y},children:[s.jsx("div",{className:"px-3 py-1.5 text-xs text-text-muted border-b border-border-light mb-1 font-mono",children:U.table}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{H(U.connectionId,U.db,U.table),J(null)},children:[s.jsx(zn,{size:14,className:"text-warning-500"}),"打开表"]}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{Se?.(U.connectionId,U.db,U.table),J(null)},children:[s.jsx(uo,{size:14,className:"text-teal-500"}),"设计表"]}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{Y?.(U.connectionId,U.db,U.table),J(null)},children:[s.jsx(Mi,{size:14,className:"text-primary-500"}),"重命名"]}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{ne?.(U.connectionId,U.db,U.table),J(null)},children:[s.jsx(US,{size:14,className:"text-info-500"}),"复制表"]}),s.jsx("div",{className:"my-1.5 mx-2 border-t border-border-light"}),s.jsx("div",{className:"px-3 py-1 text-[10px] text-text-muted uppercase",children:"导出"}),s.jsxs("button",{className:"w-full px-3 py-1.5 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{A?.(U.db,U.table,"excel"),J(null)},children:[s.jsx(yS,{size:14,className:"text-success-500"}),"Excel"]}),s.jsxs("button",{className:"w-full px-3 py-1.5 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{A?.(U.db,U.table,"sql"),J(null)},children:[s.jsx(qs,{size:14,className:"text-warning-500"}),"SQL"]}),s.jsxs("button",{className:"w-full px-3 py-1.5 text-left text-sm hover:bg-light-hover flex items-center gap-3 text-text-secondary",onClick:()=>{A?.(U.db,U.table,"csv"),J(null)},children:[s.jsx(ua,{size:14,className:"text-primary-500"}),"CSV"]}),s.jsx("div",{className:"my-1.5 mx-2 border-t border-border-light"}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-warning-50 text-warning-600 flex items-center gap-3",onClick:()=>{confirm(`确定清空表 "${U.table}"?`)&&Z?.(U.connectionId,U.db,U.table),J(null)},children:[s.jsx(Vr,{size:14}),"清空表"]}),s.jsxs("button",{className:"w-full px-3 py-2 text-left text-sm hover:bg-danger-50 text-danger-600 flex items-center gap-3",onClick:()=>{confirm(`确定删除表 "${U.table}"?`)&&D?.(U.connectionId,U.db,U.table),J(null)},children:[s.jsx(IE,{size:14}),"删除表"]})]})]})]})}const rO="modulepreload",sO=function(e,t){return new URL(e,t).href},yi={},TO=function(t,E,n){let r=Promise.resolve();if(E&&E.length>0){const l=document.getElementsByTagName("link"),a=document.querySelector("meta[property=csp-nonce]"),i=a?.nonce||a?.getAttribute("nonce");r=Promise.allSettled(E.map(o=>{if(o=sO(o,n),o in yi)return;yi[o]=!0;const S=o.endsWith(".css"),N=S?'[rel="stylesheet"]':"";if(!!n)for(let L=l.length-1;L>=0;L--){const _=l[L];if(_.href===o&&(!S||_.rel==="stylesheet"))return}else if(document.querySelector(`link[href="${o}"]${N}`))return;const O=document.createElement("link");if(O.rel=S?"stylesheet":rO,S||(O.as="script"),O.crossOrigin="",O.href=o,i&&O.setAttribute("nonce",i),document.head.appendChild(O),S)return new Promise((L,_)=>{O.addEventListener("load",L),O.addEventListener("error",()=>_(new Error(`Unable to preload CSS for ${o}`)))})}))}function T(l){const a=new Event("vite:preloadError",{cancelable:!0});if(a.payload=l,window.dispatchEvent(a),!a.defaultPrevented)throw l}return r.then(l=>{for(const a of l||[])a.status==="rejected"&&T(a.reason);return t().catch(T)})},x=e=>e.flatMap(lO),lO=e=>Ds(oO(e)).map(aO),aO=e=>e.replace(/ +/g," ").trim(),oO=e=>({type:"mandatory_block",items:Oo(e,0)[0]}),Oo=(e,t,E)=>{const n=[];for(;e[t];){const[r,T]=iO(e,t);if(n.push(r),t=T,e[t]==="|")t++;else if(e[t]==="}"||e[t]==="]"){if(E!==e[t])throw new Error(`Unbalanced parenthesis in: ${e}`);return t++,[n,t]}else if(t===e.length){if(E)throw new Error(`Unbalanced parenthesis in: ${e}`);return[n,t]}else throw new Error(`Unexpected "${e[t]}"`)}return[n,t]},iO=(e,t)=>{const E=[];for(;;){const[n,r]=RO(e,t);if(n)E.push(n),t=r;else break}return E.length===1?[E[0],t]:[{type:"concatenation",items:E},t]},RO=(e,t)=>{if(e[t]==="{")return AO(e,t+1);if(e[t]==="[")return SO(e,t+1);{let E="";for(;e[t]&&/[A-Za-z0-9_ ]/.test(e[t]);)E+=e[t],t++;return[E,t]}},AO=(e,t)=>{const[E,n]=Oo(e,t,"}");return[{type:"mandatory_block",items:E},n]},SO=(e,t)=>{const[E,n]=Oo(e,t,"]");return[{type:"optional_block",items:E},n]},Ds=e=>{if(typeof e=="string")return[e];if(e.type==="concatenation")return e.items.map(Ds).reduce(NO,[""]);if(e.type==="mandatory_block")return e.items.flatMap(Ds);if(e.type==="optional_block")return["",...e.items.flatMap(Ds)];throw new Error(`Unknown node type: ${e}`)},NO=(e,t)=>{const E=[];for(const n of e)for(const r of t)E.push(n+r);return E};var V;(function(e){e.QUOTED_IDENTIFIER="QUOTED_IDENTIFIER",e.IDENTIFIER="IDENTIFIER",e.STRING="STRING",e.VARIABLE="VARIABLE",e.RESERVED_DATA_TYPE="RESERVED_DATA_TYPE",e.RESERVED_PARAMETERIZED_DATA_TYPE="RESERVED_PARAMETERIZED_DATA_TYPE",e.RESERVED_KEYWORD="RESERVED_KEYWORD",e.RESERVED_FUNCTION_NAME="RESERVED_FUNCTION_NAME",e.RESERVED_KEYWORD_PHRASE="RESERVED_KEYWORD_PHRASE",e.RESERVED_DATA_TYPE_PHRASE="RESERVED_DATA_TYPE_PHRASE",e.RESERVED_SET_OPERATION="RESERVED_SET_OPERATION",e.RESERVED_CLAUSE="RESERVED_CLAUSE",e.RESERVED_SELECT="RESERVED_SELECT",e.RESERVED_JOIN="RESERVED_JOIN",e.ARRAY_IDENTIFIER="ARRAY_IDENTIFIER",e.ARRAY_KEYWORD="ARRAY_KEYWORD",e.CASE="CASE",e.END="END",e.WHEN="WHEN",e.ELSE="ELSE",e.THEN="THEN",e.LIMIT="LIMIT",e.BETWEEN="BETWEEN",e.AND="AND",e.OR="OR",e.XOR="XOR",e.OPERATOR="OPERATOR",e.COMMA="COMMA",e.ASTERISK="ASTERISK",e.PROPERTY_ACCESS_OPERATOR="PROPERTY_ACCESS_OPERATOR",e.OPEN_PAREN="OPEN_PAREN",e.CLOSE_PAREN="CLOSE_PAREN",e.LINE_COMMENT="LINE_COMMENT",e.BLOCK_COMMENT="BLOCK_COMMENT",e.DISABLE_COMMENT="DISABLE_COMMENT",e.NUMBER="NUMBER",e.NAMED_PARAMETER="NAMED_PARAMETER",e.QUOTED_PARAMETER="QUOTED_PARAMETER",e.NUMBERED_PARAMETER="NUMBERED_PARAMETER",e.POSITIONAL_PARAMETER="POSITIONAL_PARAMETER",e.CUSTOM_PARAMETER="CUSTOM_PARAMETER",e.DELIMITER="DELIMITER",e.EOF="EOF"})(V=V||(V={}));const vS=e=>({type:V.EOF,raw:"«EOF»",text:"«EOF»",start:e}),kn=vS(1/0),cn=e=>t=>t.type===e.type&&t.text===e.text,An={ARRAY:cn({text:"ARRAY",type:V.RESERVED_DATA_TYPE}),BY:cn({text:"BY",type:V.RESERVED_KEYWORD}),SET:cn({text:"SET",type:V.RESERVED_CLAUSE}),STRUCT:cn({text:"STRUCT",type:V.RESERVED_DATA_TYPE}),WINDOW:cn({text:"WINDOW",type:V.RESERVED_CLAUSE}),VALUES:cn({text:"VALUES",type:V.RESERVED_CLAUSE})},HS=e=>e===V.RESERVED_DATA_TYPE||e===V.RESERVED_KEYWORD||e===V.RESERVED_FUNCTION_NAME||e===V.RESERVED_KEYWORD_PHRASE||e===V.RESERVED_DATA_TYPE_PHRASE||e===V.RESERVED_CLAUSE||e===V.RESERVED_SELECT||e===V.RESERVED_SET_OPERATION||e===V.RESERVED_JOIN||e===V.ARRAY_KEYWORD||e===V.CASE||e===V.END||e===V.WHEN||e===V.ELSE||e===V.THEN||e===V.LIMIT||e===V.BETWEEN||e===V.AND||e===V.OR||e===V.XOR,IO=e=>e===V.AND||e===V.OR||e===V.XOR,uO=["KEYS.NEW_KEYSET","KEYS.ADD_KEY_FROM_RAW_BYTES","AEAD.DECRYPT_BYTES","AEAD.DECRYPT_STRING","AEAD.ENCRYPT","KEYS.KEYSET_CHAIN","KEYS.KEYSET_FROM_JSON","KEYS.KEYSET_TO_JSON","KEYS.ROTATE_KEYSET","KEYS.KEYSET_LENGTH","ANY_VALUE","ARRAY_AGG","AVG","CORR","COUNT","COUNTIF","COVAR_POP","COVAR_SAMP","MAX","MIN","ST_CLUSTERDBSCAN","STDDEV_POP","STDDEV_SAMP","STRING_AGG","SUM","VAR_POP","VAR_SAMP","ANY_VALUE","ARRAY_AGG","ARRAY_CONCAT_AGG","AVG","BIT_AND","BIT_OR","BIT_XOR","COUNT","COUNTIF","LOGICAL_AND","LOGICAL_OR","MAX","MIN","STRING_AGG","SUM","APPROX_COUNT_DISTINCT","APPROX_QUANTILES","APPROX_TOP_COUNT","APPROX_TOP_SUM","ARRAY_CONCAT","ARRAY_LENGTH","ARRAY_TO_STRING","GENERATE_ARRAY","GENERATE_DATE_ARRAY","GENERATE_TIMESTAMP_ARRAY","ARRAY_REVERSE","OFFSET","SAFE_OFFSET","ORDINAL","SAFE_ORDINAL","BIT_COUNT","PARSE_BIGNUMERIC","PARSE_NUMERIC","SAFE_CAST","CURRENT_DATE","EXTRACT","DATE","DATE_ADD","DATE_SUB","DATE_DIFF","DATE_TRUNC","DATE_FROM_UNIX_DATE","FORMAT_DATE","LAST_DAY","PARSE_DATE","UNIX_DATE","CURRENT_DATETIME","DATETIME","EXTRACT","DATETIME_ADD","DATETIME_SUB","DATETIME_DIFF","DATETIME_TRUNC","FORMAT_DATETIME","LAST_DAY","PARSE_DATETIME","ERROR","EXTERNAL_QUERY","S2_CELLIDFROMPOINT","S2_COVERINGCELLIDS","ST_ANGLE","ST_AREA","ST_ASBINARY","ST_ASGEOJSON","ST_ASTEXT","ST_AZIMUTH","ST_BOUNDARY","ST_BOUNDINGBOX","ST_BUFFER","ST_BUFFERWITHTOLERANCE","ST_CENTROID","ST_CENTROID_AGG","ST_CLOSESTPOINT","ST_CLUSTERDBSCAN","ST_CONTAINS","ST_CONVEXHULL","ST_COVEREDBY","ST_COVERS","ST_DIFFERENCE","ST_DIMENSION","ST_DISJOINT","ST_DISTANCE","ST_DUMP","ST_DWITHIN","ST_ENDPOINT","ST_EQUALS","ST_EXTENT","ST_EXTERIORRING","ST_GEOGFROM","ST_GEOGFROMGEOJSON","ST_GEOGFROMTEXT","ST_GEOGFROMWKB","ST_GEOGPOINT","ST_GEOGPOINTFROMGEOHASH","ST_GEOHASH","ST_GEOMETRYTYPE","ST_INTERIORRINGS","ST_INTERSECTION","ST_INTERSECTS","ST_INTERSECTSBOX","ST_ISCOLLECTION","ST_ISEMPTY","ST_LENGTH","ST_MAKELINE","ST_MAKEPOLYGON","ST_MAKEPOLYGONORIENTED","ST_MAXDISTANCE","ST_NPOINTS","ST_NUMGEOMETRIES","ST_NUMPOINTS","ST_PERIMETER","ST_POINTN","ST_SIMPLIFY","ST_SNAPTOGRID","ST_STARTPOINT","ST_TOUCHES","ST_UNION","ST_UNION_AGG","ST_WITHIN","ST_X","ST_Y","FARM_FINGERPRINT","MD5","SHA1","SHA256","SHA512","HLL_COUNT.INIT","HLL_COUNT.MERGE","HLL_COUNT.MERGE_PARTIAL","HLL_COUNT.EXTRACT","MAKE_INTERVAL","EXTRACT","JUSTIFY_DAYS","JUSTIFY_HOURS","JUSTIFY_INTERVAL","JSON_EXTRACT","JSON_QUERY","JSON_EXTRACT_SCALAR","JSON_VALUE","JSON_EXTRACT_ARRAY","JSON_QUERY_ARRAY","JSON_EXTRACT_STRING_ARRAY","JSON_VALUE_ARRAY","TO_JSON_STRING","ABS","SIGN","IS_INF","IS_NAN","IEEE_DIVIDE","RAND","SQRT","POW","POWER","EXP","LN","LOG","LOG10","GREATEST","LEAST","DIV","SAFE_DIVIDE","SAFE_MULTIPLY","SAFE_NEGATE","SAFE_ADD","SAFE_SUBTRACT","MOD","ROUND","TRUNC","CEIL","CEILING","FLOOR","COS","COSH","ACOS","ACOSH","SIN","SINH","ASIN","ASINH","TAN","TANH","ATAN","ATANH","ATAN2","RANGE_BUCKET","FIRST_VALUE","LAST_VALUE","NTH_VALUE","LEAD","LAG","PERCENTILE_CONT","PERCENTILE_DISC","NET.IP_FROM_STRING","NET.SAFE_IP_FROM_STRING","NET.IP_TO_STRING","NET.IP_NET_MASK","NET.IP_TRUNC","NET.IPV4_FROM_INT64","NET.IPV4_TO_INT64","NET.HOST","NET.PUBLIC_SUFFIX","NET.REG_DOMAIN","RANK","DENSE_RANK","PERCENT_RANK","CUME_DIST","NTILE","ROW_NUMBER","SESSION_USER","CORR","COVAR_POP","COVAR_SAMP","STDDEV_POP","STDDEV_SAMP","STDDEV","VAR_POP","VAR_SAMP","VARIANCE","ASCII","BYTE_LENGTH","CHAR_LENGTH","CHARACTER_LENGTH","CHR","CODE_POINTS_TO_BYTES","CODE_POINTS_TO_STRING","CONCAT","CONTAINS_SUBSTR","ENDS_WITH","FORMAT","FROM_BASE32","FROM_BASE64","FROM_HEX","INITCAP","INSTR","LEFT","LENGTH","LPAD","LOWER","LTRIM","NORMALIZE","NORMALIZE_AND_CASEFOLD","OCTET_LENGTH","REGEXP_CONTAINS","REGEXP_EXTRACT","REGEXP_EXTRACT_ALL","REGEXP_INSTR","REGEXP_REPLACE","REGEXP_SUBSTR","REPLACE","REPEAT","REVERSE","RIGHT","RPAD","RTRIM","SAFE_CONVERT_BYTES_TO_STRING","SOUNDEX","SPLIT","STARTS_WITH","STRPOS","SUBSTR","SUBSTRING","TO_BASE32","TO_BASE64","TO_CODE_POINTS","TO_HEX","TRANSLATE","TRIM","UNICODE","UPPER","CURRENT_TIME","TIME","EXTRACT","TIME_ADD","TIME_SUB","TIME_DIFF","TIME_TRUNC","FORMAT_TIME","PARSE_TIME","CURRENT_TIMESTAMP","EXTRACT","STRING","TIMESTAMP","TIMESTAMP_ADD","TIMESTAMP_SUB","TIMESTAMP_DIFF","TIMESTAMP_TRUNC","FORMAT_TIMESTAMP","PARSE_TIMESTAMP","TIMESTAMP_SECONDS","TIMESTAMP_MILLIS","TIMESTAMP_MICROS","UNIX_SECONDS","UNIX_MILLIS","UNIX_MICROS","GENERATE_UUID","COALESCE","IF","IFNULL","NULLIF","AVG","BIT_AND","BIT_OR","BIT_XOR","CORR","COUNT","COVAR_POP","COVAR_SAMP","EXACT_COUNT_DISTINCT","FIRST","GROUP_CONCAT","GROUP_CONCAT_UNQUOTED","LAST","MAX","MIN","NEST","NTH","QUANTILES","STDDEV","STDDEV_POP","STDDEV_SAMP","SUM","TOP","UNIQUE","VARIANCE","VAR_POP","VAR_SAMP","BIT_COUNT","BOOLEAN","BYTES","CAST","FLOAT","HEX_STRING","INTEGER","STRING","COALESCE","GREATEST","IFNULL","IS_INF","IS_NAN","IS_EXPLICITLY_DEFINED","LEAST","NVL","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP","DATE","DATE_ADD","DATEDIFF","DAY","DAYOFWEEK","DAYOFYEAR","FORMAT_UTC_USEC","HOUR","MINUTE","MONTH","MSEC_TO_TIMESTAMP","NOW","PARSE_UTC_USEC","QUARTER","SEC_TO_TIMESTAMP","SECOND","STRFTIME_UTC_USEC","TIME","TIMESTAMP","TIMESTAMP_TO_MSEC","TIMESTAMP_TO_SEC","TIMESTAMP_TO_USEC","USEC_TO_TIMESTAMP","UTC_USEC_TO_DAY","UTC_USEC_TO_HOUR","UTC_USEC_TO_MONTH","UTC_USEC_TO_WEEK","UTC_USEC_TO_YEAR","WEEK","YEAR","FORMAT_IP","PARSE_IP","FORMAT_PACKED_IP","PARSE_PACKED_IP","JSON_EXTRACT","JSON_EXTRACT_SCALAR","ABS","ACOS","ACOSH","ASIN","ASINH","ATAN","ATANH","ATAN2","CEIL","COS","COSH","DEGREES","EXP","FLOOR","LN","LOG","LOG2","LOG10","PI","POW","RADIANS","RAND","ROUND","SIN","SINH","SQRT","TAN","TANH","REGEXP_MATCH","REGEXP_EXTRACT","REGEXP_REPLACE","CONCAT","INSTR","LEFT","LENGTH","LOWER","LPAD","LTRIM","REPLACE","RIGHT","RPAD","RTRIM","SPLIT","SUBSTR","UPPER","TABLE_DATE_RANGE","TABLE_DATE_RANGE_STRICT","TABLE_QUERY","HOST","DOMAIN","TLD","AVG","COUNT","MAX","MIN","STDDEV","SUM","CUME_DIST","DENSE_RANK","FIRST_VALUE","LAG","LAST_VALUE","LEAD","NTH_VALUE","NTILE","PERCENT_RANK","PERCENTILE_CONT","PERCENTILE_DISC","RANK","RATIO_TO_REPORT","ROW_NUMBER","CURRENT_USER","EVERY","FROM_BASE64","HASH","FARM_FINGERPRINT","IF","POSITION","SHA1","SOME","TO_BASE64","BQ.JOBS.CANCEL","BQ.REFRESH_MATERIALIZED_VIEW","OPTIONS","PIVOT","UNPIVOT"],OO=["ALL","AND","ANY","AS","ASC","ASSERT_ROWS_MODIFIED","AT","BETWEEN","BY","CASE","CAST","COLLATE","CONTAINS","CREATE","CROSS","CUBE","CURRENT","DEFAULT","DEFINE","DESC","DISTINCT","ELSE","END","ENUM","ESCAPE","EXCEPT","EXCLUDE","EXISTS","EXTRACT","FALSE","FETCH","FOLLOWING","FOR","FROM","FULL","GROUP","GROUPING","GROUPS","HASH","HAVING","IF","IGNORE","IN","INNER","INTERSECT","INTO","IS","JOIN","LATERAL","LEFT","LIMIT","LOOKUP","MERGE","NATURAL","NEW","NO","NOT","NULL","NULLS","OF","ON","OR","ORDER","OUTER","OVER","PARTITION","PRECEDING","PROTO","RANGE","RECURSIVE","RESPECT","RIGHT","ROLLUP","ROWS","SELECT","SET","SOME","TABLE","TABLESAMPLE","THEN","TO","TREAT","TRUE","UNBOUNDED","UNION","UNNEST","USING","WHEN","WHERE","WINDOW","WITH","WITHIN","SAFE","LIKE","COPY","CLONE","IN","OUT","INOUT","RETURNS","LANGUAGE","CASCADE","RESTRICT","DETERMINISTIC"],cO=["ARRAY","BOOL","BYTES","DATE","DATETIME","GEOGRAPHY","INTERVAL","INT64","INT","SMALLINT","INTEGER","BIGINT","TINYINT","BYTEINT","NUMERIC","DECIMAL","BIGNUMERIC","BIGDECIMAL","FLOAT64","STRING","STRUCT","TIME","TIMEZONE"],CO=x(["SELECT [ALL | DISTINCT] [AS STRUCT | AS VALUE]"]),dO=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY","HAVING","QUALIFY","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","OMIT RECORD IF","INSERT [INTO]","VALUES","SET","MERGE [INTO]","WHEN [NOT] MATCHED [BY SOURCE | BY TARGET] [THEN]","UPDATE SET","CLUSTER BY","FOR SYSTEM_TIME AS OF","WITH CONNECTION","WITH PARTITION COLUMNS","REMOTE WITH CONNECTION"]),gi=x(["CREATE [OR REPLACE] [TEMP|TEMPORARY|SNAPSHOT|EXTERNAL] TABLE [IF NOT EXISTS]"]),ZT=x(["CREATE [OR REPLACE] [MATERIALIZED] VIEW [IF NOT EXISTS]","UPDATE","DELETE [FROM]","DROP [SNAPSHOT | EXTERNAL] TABLE [IF EXISTS]","ALTER TABLE [IF EXISTS]","ADD COLUMN [IF NOT EXISTS]","DROP COLUMN [IF EXISTS]","RENAME TO","ALTER COLUMN [IF EXISTS]","SET DEFAULT COLLATE","SET OPTIONS","DROP NOT NULL","SET DATA TYPE","ALTER SCHEMA [IF EXISTS]","ALTER [MATERIALIZED] VIEW [IF EXISTS]","ALTER BI_CAPACITY","TRUNCATE TABLE","CREATE SCHEMA [IF NOT EXISTS]","DEFAULT COLLATE","CREATE [OR REPLACE] [TEMP|TEMPORARY|TABLE] FUNCTION [IF NOT EXISTS]","CREATE [OR REPLACE] PROCEDURE [IF NOT EXISTS]","CREATE [OR REPLACE] ROW ACCESS POLICY [IF NOT EXISTS]","GRANT TO","FILTER USING","CREATE CAPACITY","AS JSON","CREATE RESERVATION","CREATE ASSIGNMENT","CREATE SEARCH INDEX [IF NOT EXISTS]","DROP SCHEMA [IF EXISTS]","DROP [MATERIALIZED] VIEW [IF EXISTS]","DROP [TABLE] FUNCTION [IF EXISTS]","DROP PROCEDURE [IF EXISTS]","DROP ROW ACCESS POLICY","DROP ALL ROW ACCESS POLICIES","DROP CAPACITY [IF EXISTS]","DROP RESERVATION [IF EXISTS]","DROP ASSIGNMENT [IF EXISTS]","DROP SEARCH INDEX [IF EXISTS]","DROP [IF EXISTS]","GRANT","REVOKE","DECLARE","EXECUTE IMMEDIATE","LOOP","END LOOP","REPEAT","END REPEAT","WHILE","END WHILE","BREAK","LEAVE","CONTINUE","ITERATE","FOR","END FOR","BEGIN","BEGIN TRANSACTION","COMMIT TRANSACTION","ROLLBACK TRANSACTION","RAISE","RETURN","CALL","ASSERT","EXPORT DATA"]),LO=x(["UNION {ALL | DISTINCT}","EXCEPT DISTINCT","INTERSECT DISTINCT"]),_O=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN"]),fO=x(["TABLESAMPLE SYSTEM","ANY TYPE","ALL COLUMNS","NOT DETERMINISTIC","{ROWS | RANGE} BETWEEN","IS [NOT] DISTINCT FROM"]),pO=x([]),mO={name:"bigquery",tokenizerOptions:{reservedSelect:CO,reservedClauses:[...dO,...ZT,...gi],reservedSetOperations:LO,reservedJoins:_O,reservedKeywordPhrases:fO,reservedDataTypePhrases:pO,reservedKeywords:OO,reservedDataTypes:cO,reservedFunctionNames:uO,extraParens:["[]"],stringTypes:[{quote:'""".."""',prefixes:["R","B","RB","BR"]},{quote:"'''..'''",prefixes:["R","B","RB","BR"]},'""-bs',"''-bs",{quote:'""-raw',prefixes:["R","B","RB","BR"],requirePrefix:!0},{quote:"''-raw",prefixes:["R","B","RB","BR"],requirePrefix:!0}],identTypes:["``"],identChars:{dashes:!0},paramTypes:{positional:!0,named:["@"],quoted:["@"]},variableTypes:[{regex:String.raw`@@\w+`}],lineCommentTypes:["--","#"],operators:["&","|","^","~",">>","<<","||","=>"],postProcess:DO},formatOptions:{onelineClauses:[...gi,...ZT],tabularOnelineClauses:ZT}};function DO(e){return PO(hO(e))}function PO(e){let t=kn;return e.map(E=>E.text==="OFFSET"&&t.text==="["?(t=E,Object.assign(Object.assign({},E),{type:V.RESERVED_FUNCTION_NAME})):(t=E,E))}function hO(e){var t;const E=[];for(let n=0;n<e.length;n++){const r=e[n];if((An.ARRAY(r)||An.STRUCT(r))&&((t=e[n+1])===null||t===void 0?void 0:t.text)==="<"){const T=MO(e,n+1),l=e.slice(n,T+1);E.push({type:V.IDENTIFIER,raw:l.map(Gi("raw")).join(""),text:l.map(Gi("text")).join(""),start:r.start}),n=T}else E.push(r)}return E}const Gi=e=>t=>t.type===V.IDENTIFIER||t.type===V.COMMA?t[e]+" ":t[e];function MO(e,t){let E=0;for(let n=t;n<e.length;n++){const r=e[n];if(r.text==="<"?E++:r.text===">"?E--:r.text===">>"&&(E-=2),E===0)return n}return e.length-1}const UO=["ARRAY_AGG","AVG","CORRELATION","COUNT","COUNT_BIG","COVARIANCE","COVARIANCE_SAMP","CUME_DIST","GROUPING","LISTAGG","MAX","MEDIAN","MIN","PERCENTILE_CONT","PERCENTILE_DISC","PERCENT_RANK","REGR_AVGX","REGR_AVGY","REGR_COUNT","REGR_INTERCEPT","REGR_ICPT","REGR_R2","REGR_SLOPE","REGR_SXX","REGR_SXY","REGR_SYY","STDDEV","STDDEV_SAMP","SUM","VARIANCE","VARIANCE_SAMP","XMLAGG","XMLGROUP","ABS","ABSVAL","ACOS","ADD_DAYS","ADD_HOURS","ADD_MINUTES","ADD_MONTHS","ADD_SECONDS","ADD_YEARS","AGE","ARRAY_DELETE","ARRAY_FIRST","ARRAY_LAST","ARRAY_NEXT","ARRAY_PRIOR","ASCII","ASCII_STR","ASIN","ATAN","ATAN2","ATANH","BITAND","BITANDNOT","BITOR","BITXOR","BITNOT","BPCHAR","BSON_TO_JSON","BTRIM","CARDINALITY","CEILING","CEIL","CHARACTER_LENGTH","CHR","COALESCE","COLLATION_KEY","COLLATION_KEY_BIT","COMPARE_DECFLOAT","CONCAT","COS","COSH","COT","CURSOR_ROWCOUNT","DATAPARTITIONNUM","DATE_PART","DATE_TRUNC","DAY","DAYNAME","DAYOFMONTH","DAYOFWEEK","DAYOFWEEK_ISO","DAYOFYEAR","DAYS","DAYS_BETWEEN","DAYS_TO_END_OF_MONTH","DBPARTITIONNUM","DECFLOAT","DECFLOAT_FORMAT","DECODE","DECRYPT_BIN","DECRYPT_CHAR","DEGREES","DEREF","DIFFERENCE","DIGITS","DOUBLE_PRECISION","EMPTY_BLOB","EMPTY_CLOB","EMPTY_DBCLOB","EMPTY_NCLOB","ENCRYPT","EVENT_MON_STATE","EXP","EXTRACT","FIRST_DAY","FLOOR","FROM_UTC_TIMESTAMP","GENERATE_UNIQUE","GETHINT","GREATEST","HASH","HASH4","HASH8","HASHEDVALUE","HEX","HEXTORAW","HOUR","HOURS_BETWEEN","IDENTITY_VAL_LOCAL","IFNULL","INITCAP","INSERT","INSTR","INSTR2","INSTR4","INSTRB","INTNAND","INTNOR","INTNXOR","INTNNOT","ISNULL","JSON_ARRAY","JSON_OBJECT","JSON_QUERY","JSON_TO_BSON","JSON_VALUE","JULIAN_DAY","LAST_DAY","LCASE","LEAST","LEFT","LENGTH","LENGTH2","LENGTH4","LENGTHB","LN","LOCATE","LOCATE_IN_STRING","LOG10","LONG_VARCHAR","LONG_VARGRAPHIC","LOWER","LPAD","LTRIM","MAX","MAX_CARDINALITY","MICROSECOND","MIDNIGHT_SECONDS","MIN","MINUTE","MINUTES_BETWEEN","MOD","MONTH","MONTHNAME","MONTHS_BETWEEN","MULTIPLY_ALT","NEXT_DAY","NEXT_MONTH","NEXT_QUARTER","NEXT_WEEK","NEXT_YEAR","NORMALIZE_DECFLOAT","NOW","NULLIF","NVL","NVL2","OCTET_LENGTH","OVERLAY","PARAMETER","POSITION","POSSTR","POW","POWER","QUANTIZE","QUARTER","QUOTE_IDENT","QUOTE_LITERAL","RADIANS","RAISE_ERROR","RAND","RANDOM","RAWTOHEX","REC2XML","REGEXP_COUNT","REGEXP_EXTRACT","REGEXP_INSTR","REGEXP_LIKE","REGEXP_MATCH_COUNT","REGEXP_REPLACE","REGEXP_SUBSTR","REPEAT","REPLACE","RID","RID_BIT","RIGHT","ROUND","ROUND_TIMESTAMP","RPAD","RTRIM","SECLABEL","SECLABEL_BY_NAME","SECLABEL_TO_CHAR","SECOND","SECONDS_BETWEEN","SIGN","SIN","SINH","SOUNDEX","SPACE","SQRT","STRIP","STRLEFT","STRPOS","STRRIGHT","SUBSTR","SUBSTR2","SUBSTR4","SUBSTRB","SUBSTRING","TABLE_NAME","TABLE_SCHEMA","TAN","TANH","THIS_MONTH","THIS_QUARTER","THIS_WEEK","THIS_YEAR","TIMESTAMP_FORMAT","TIMESTAMP_ISO","TIMESTAMPDIFF","TIMEZONE","TO_CHAR","TO_CLOB","TO_DATE","TO_HEX","TO_MULTI_BYTE","TO_NCHAR","TO_NCLOB","TO_NUMBER","TO_SINGLE_BYTE","TO_TIMESTAMP","TO_UTC_TIMESTAMP","TOTALORDER","TRANSLATE","TRIM","TRIM_ARRAY","TRUNC_TIMESTAMP","TRUNCATE","TRUNC","TYPE_ID","TYPE_NAME","TYPE_SCHEMA","UCASE","UNICODE_STR","UPPER","VALUE","VARCHAR_BIT_FORMAT","VARCHAR_FORMAT","VARCHAR_FORMAT_BIT","VERIFY_GROUP_FOR_USER","VERIFY_ROLE_FOR_USER","VERIFY_TRUSTED_CONTEXT_ROLE_FOR_USER","WEEK","WEEK_ISO","WEEKS_BETWEEN","WIDTH_BUCKET","XMLATTRIBUTES","XMLCOMMENT","XMLCONCAT","XMLDOCUMENT","XMLELEMENT","XMLFOREST","XMLNAMESPACES","XMLPARSE","XMLPI","XMLQUERY","XMLROW","XMLSERIALIZE","XMLTEXT","XMLVALIDATE","XMLXSROBJECTID","XSLTRANSFORM","YEAR","YEARS_BETWEEN","YMD_BETWEEN","BASE_TABLE","JSON_TABLE","UNNEST","XMLTABLE","RANK","DENSE_RANK","NTILE","LAG","LEAD","ROW_NUMBER","FIRST_VALUE","LAST_VALUE","NTH_VALUE","RATIO_TO_REPORT","CAST"],xO=["ACTIVATE","ADD","AFTER","ALIAS","ALL","ALLOCATE","ALLOW","ALTER","AND","ANY","AS","ASENSITIVE","ASSOCIATE","ASUTIME","AT","ATTRIBUTES","AUDIT","AUTHORIZATION","AUX","AUXILIARY","BEFORE","BEGIN","BETWEEN","BINARY","BUFFERPOOL","BY","CACHE","CALL","CALLED","CAPTURE","CARDINALITY","CASCADED","CASE","CAST","CHECK","CLONE","CLOSE","CLUSTER","COLLECTION","COLLID","COLUMN","COMMENT","COMMIT","CONCAT","CONDITION","CONNECT","CONNECTION","CONSTRAINT","CONTAINS","CONTINUE","COUNT","COUNT_BIG","CREATE","CROSS","CURRENT","CURRENT_DATE","CURRENT_LC_CTYPE","CURRENT_PATH","CURRENT_SCHEMA","CURRENT_SERVER","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_TIMEZONE","CURRENT_USER","CURSOR","CYCLE","DATA","DATABASE","DATAPARTITIONNAME","DATAPARTITIONNUM","DAY","DAYS","DB2GENERAL","DB2GENRL","DB2SQL","DBINFO","DBPARTITIONNAME","DBPARTITIONNUM","DEALLOCATE","DECLARE","DEFAULT","DEFAULTS","DEFINITION","DELETE","DENSERANK","DENSE_RANK","DESCRIBE","DESCRIPTOR","DETERMINISTIC","DIAGNOSTICS","DISABLE","DISALLOW","DISCONNECT","DISTINCT","DO","DOCUMENT","DROP","DSSIZE","DYNAMIC","EACH","EDITPROC","ELSE","ELSEIF","ENABLE","ENCODING","ENCRYPTION","END","END-EXEC","ENDING","ERASE","ESCAPE","EVERY","EXCEPT","EXCEPTION","EXCLUDING","EXCLUSIVE","EXECUTE","EXISTS","EXIT","EXPLAIN","EXTENDED","EXTERNAL","EXTRACT","FENCED","FETCH","FIELDPROC","FILE","FINAL","FIRST1","FOR","FOREIGN","FREE","FROM","FULL","FUNCTION","GENERAL","GENERATED","GET","GLOBAL","GO","GOTO","GRANT","GRAPHIC","GROUP","HANDLER","HASH","HASHED_VALUE","HAVING","HINT","HOLD","HOUR","HOURS","IDENTITY","IF","IMMEDIATE","IMPORT","IN","INCLUDING","INCLUSIVE","INCREMENT","INDEX","INDICATOR","INDICATORS","INF","INFINITY","INHERIT","INNER","INOUT","INSENSITIVE","INSERT","INTEGRITY","INTERSECT","INTO","IS","ISNULL","ISOBID","ISOLATION","ITERATE","JAR","JAVA","JOIN","KEEP","KEY","LABEL","LANGUAGE","LAST3","LATERAL","LC_CTYPE","LEAVE","LEFT","LIKE","LIMIT","LINKTYPE","LOCAL","LOCALDATE","LOCALE","LOCALTIME","LOCALTIMESTAMP","LOCATOR","LOCATORS","LOCK","LOCKMAX","LOCKSIZE","LOOP","MAINTAINED","MATERIALIZED","MAXVALUE","MICROSECOND","MICROSECONDS","MINUTE","MINUTES","MINVALUE","MODE","MODIFIES","MONTH","MONTHS","NAN","NEW","NEW_TABLE","NEXTVAL","NO","NOCACHE","NOCYCLE","NODENAME","NODENUMBER","NOMAXVALUE","NOMINVALUE","NONE","NOORDER","NORMALIZED","NOT2","NOTNULL","NULL","NULLS","NUMPARTS","OBID","OF","OFF","OFFSET","OLD","OLD_TABLE","ON","OPEN","OPTIMIZATION","OPTIMIZE","OPTION","OR","ORDER","OUT","OUTER","OVER","OVERRIDING","PACKAGE","PADDED","PAGESIZE","PARAMETER","PART","PARTITION","PARTITIONED","PARTITIONING","PARTITIONS","PASSWORD","PATH","PERCENT","PIECESIZE","PLAN","POSITION","PRECISION","PREPARE","PREVVAL","PRIMARY","PRIQTY","PRIVILEGES","PROCEDURE","PROGRAM","PSID","PUBLIC","QUERY","QUERYNO","RANGE","RANK","READ","READS","RECOVERY","REFERENCES","REFERENCING","REFRESH","RELEASE","RENAME","REPEAT","RESET","RESIGNAL","RESTART","RESTRICT","RESULT","RESULT_SET_LOCATOR","RETURN","RETURNS","REVOKE","RIGHT","ROLE","ROLLBACK","ROUND_CEILING","ROUND_DOWN","ROUND_FLOOR","ROUND_HALF_DOWN","ROUND_HALF_EVEN","ROUND_HALF_UP","ROUND_UP","ROUTINE","ROW","ROWNUMBER","ROWS","ROWSET","ROW_NUMBER","RRN","RUN","SAVEPOINT","SCHEMA","SCRATCHPAD","SCROLL","SEARCH","SECOND","SECONDS","SECQTY","SECURITY","SELECT","SENSITIVE","SEQUENCE","SESSION","SESSION_USER","SET","SIGNAL","SIMPLE","SNAN","SOME","SOURCE","SPECIFIC","SQL","SQLID","STACKED","STANDARD","START","STARTING","STATEMENT","STATIC","STATMENT","STAY","STOGROUP","STORES","STYLE","SUBSTRING","SUMMARY","SYNONYM","SYSFUN","SYSIBM","SYSPROC","SYSTEM","SYSTEM_USER","TABLE","TABLESPACE","THEN","TO","TRANSACTION","TRIGGER","TRIM","TRUNCATE","TYPE","UNDO","UNION","UNIQUE","UNTIL","UPDATE","USAGE","USER","USING","VALIDPROC","VALUE","VALUES","VARIABLE","VARIANT","VCAT","VERSION","VIEW","VOLATILE","VOLUMES","WHEN","WHENEVER","WHERE","WHILE","WITH","WITHOUT","WLM","WRITE","XMLELEMENT","XMLEXISTS","XMLNAMESPACES","YEAR","YEARS"],yO=["ARRAY","BIGINT","BINARY","BLOB","BOOLEAN","CCSID","CHAR","CHARACTER","CLOB","DATE","DATETIME","DBCLOB","DEC","DECIMAL","DOUBLE","DOUBLE PRECISION","FLOAT","FLOAT4","FLOAT8","GRAPHIC","INT","INT2","INT4","INT8","INTEGER","INTERVAL","LONG VARCHAR","LONG VARGRAPHIC","NCHAR","NCHR","NCLOB","NVARCHAR","NUMERIC","SMALLINT","REAL","TIME","TIMESTAMP","VARBINARY","VARCHAR","VARGRAPHIC"],gO=x(["SELECT [ALL | DISTINCT]"]),GO=x(["WITH","FROM","WHERE","GROUP BY","HAVING","PARTITION BY","ORDER BY [INPUT SEQUENCE]","LIMIT","OFFSET","FETCH NEXT","FOR UPDATE [OF]","FOR {READ | FETCH} ONLY","FOR {RR | CS | UR | RS} [USE AND KEEP {SHARE | UPDATE | EXCLUSIVE} LOCKS]","WAIT FOR OUTCOME","SKIP LOCKED DATA","INTO","INSERT INTO","VALUES","SET","MERGE INTO","WHEN [NOT] MATCHED [THEN]","UPDATE SET","INSERT"]),vi=x(["CREATE [GLOBAL TEMPORARY | EXTERNAL] TABLE [IF NOT EXISTS]"]),qT=x(["CREATE [OR REPLACE] VIEW","UPDATE","WHERE CURRENT OF","WITH {RR | RS | CS | UR}","DELETE FROM","DROP TABLE [IF EXISTS]","ALTER TABLE","ADD [COLUMN]","DROP [COLUMN]","RENAME COLUMN","ALTER [COLUMN]","SET DATA TYPE","SET NOT NULL","DROP {DEFAULT | GENERATED | NOT NULL}","TRUNCATE [TABLE]","ALLOCATE","ALTER AUDIT POLICY","ALTER BUFFERPOOL","ALTER DATABASE PARTITION GROUP","ALTER DATABASE","ALTER EVENT MONITOR","ALTER FUNCTION","ALTER HISTOGRAM TEMPLATE","ALTER INDEX","ALTER MASK","ALTER METHOD","ALTER MODULE","ALTER NICKNAME","ALTER PACKAGE","ALTER PERMISSION","ALTER PROCEDURE","ALTER SCHEMA","ALTER SECURITY LABEL COMPONENT","ALTER SECURITY POLICY","ALTER SEQUENCE","ALTER SERVER","ALTER SERVICE CLASS","ALTER STOGROUP","ALTER TABLESPACE","ALTER THRESHOLD","ALTER TRIGGER","ALTER TRUSTED CONTEXT","ALTER TYPE","ALTER USAGE LIST","ALTER USER MAPPING","ALTER VIEW","ALTER WORK ACTION SET","ALTER WORK CLASS SET","ALTER WORKLOAD","ALTER WRAPPER","ALTER XSROBJECT","ALTER STOGROUP","ALTER TABLESPACE","ALTER TRIGGER","ALTER TRUSTED CONTEXT","ALTER VIEW","ASSOCIATE [RESULT SET] {LOCATOR | LOCATORS}","AUDIT","BEGIN DECLARE SECTION","CALL","CLOSE","COMMENT ON","COMMIT [WORK]","CONNECT","CREATE [OR REPLACE] [PUBLIC] ALIAS","CREATE AUDIT POLICY","CREATE BUFFERPOOL","CREATE DATABASE PARTITION GROUP","CREATE EVENT MONITOR","CREATE [OR REPLACE] FUNCTION","CREATE FUNCTION MAPPING","CREATE HISTOGRAM TEMPLATE","CREATE [UNIQUE] INDEX","CREATE INDEX EXTENSION","CREATE [OR REPLACE] MASK","CREATE [SPECIFIC] METHOD","CREATE [OR REPLACE] MODULE","CREATE [OR REPLACE] NICKNAME","CREATE [OR REPLACE] PERMISSION","CREATE [OR REPLACE] PROCEDURE","CREATE ROLE","CREATE SCHEMA","CREATE SECURITY LABEL [COMPONENT]","CREATE SECURITY POLICY","CREATE [OR REPLACE] SEQUENCE","CREATE SERVICE CLASS","CREATE SERVER","CREATE STOGROUP","CREATE SYNONYM","CREATE [LARGE | REGULAR | {SYSTEM | USER} TEMPORARY] TABLESPACE","CREATE THRESHOLD","CREATE {TRANSFORM | TRANSFORMS} FOR","CREATE [OR REPLACE] TRIGGER","CREATE TRUSTED CONTEXT","CREATE [OR REPLACE] TYPE","CREATE TYPE MAPPING","CREATE USAGE LIST","CREATE USER MAPPING FOR","CREATE [OR REPLACE] VARIABLE","CREATE WORK ACTION SET","CREATE WORK CLASS SET","CREATE WORKLOAD","CREATE WRAPPER","DECLARE","DECLARE GLOBAL TEMPORARY TABLE","DESCRIBE [INPUT | OUTPUT]","DISCONNECT","DROP [PUBLIC] ALIAS","DROP AUDIT POLICY","DROP BUFFERPOOL","DROP DATABASE PARTITION GROUP","DROP EVENT MONITOR","DROP [SPECIFIC] FUNCTION","DROP FUNCTION MAPPING","DROP HISTOGRAM TEMPLATE","DROP INDEX [EXTENSION]","DROP MASK","DROP [SPECIFIC] METHOD","DROP MODULE","DROP NICKNAME","DROP PACKAGE","DROP PERMISSION","DROP [SPECIFIC] PROCEDURE","DROP ROLE","DROP SCHEMA","DROP SECURITY LABEL [COMPONENT]","DROP SECURITY POLICY","DROP SEQUENCE","DROP SERVER","DROP SERVICE CLASS","DROP STOGROUP","DROP TABLE HIERARCHY","DROP {TABLESPACE | TABLESPACES}","DROP {TRANSFORM | TRANSFORMS}","DROP THRESHOLD","DROP TRIGGER","DROP TRUSTED CONTEXT","DROP TYPE [MAPPING]","DROP USAGE LIST","DROP USER MAPPING FOR","DROP VARIABLE","DROP VIEW [HIERARCHY]","DROP WORK {ACTION | CLASS} SET","DROP WORKLOAD","DROP WRAPPER","DROP XSROBJECT","END DECLARE SECTION","EXECUTE [IMMEDIATE]","EXPLAIN {PLAN [SECTION] | ALL}","FETCH [FROM]","FLUSH {BUFFERPOOL | BUFFERPOOLS} ALL","FLUSH EVENT MONITOR","FLUSH FEDERATED CACHE","FLUSH OPTIMIZATION PROFILE CACHE","FLUSH PACKAGE CACHE [DYNAMIC]","FLUSH AUTHENTICATION CACHE [FOR ALL]","FREE LOCATOR","GET DIAGNOSTICS","GOTO","GRANT","INCLUDE","ITERATE","LEAVE","LOCK TABLE","LOOP","OPEN","PIPE","PREPARE","REFRESH TABLE","RELEASE","RELEASE [TO] SAVEPOINT","RENAME [TABLE | INDEX | STOGROUP | TABLESPACE]","REPEAT","RESIGNAL","RETURN","REVOKE","ROLLBACK [WORK] [TO SAVEPOINT]","SAVEPOINT","SET COMPILATION ENVIRONMENT","SET CONNECTION","SET CURRENT","SET ENCRYPTION PASSWORD","SET EVENT MONITOR STATE","SET INTEGRITY","SET PASSTHRU","SET PATH","SET ROLE","SET SCHEMA","SET SERVER OPTION","SET {SESSION AUTHORIZATION | SESSION_USER}","SET USAGE LIST","SIGNAL","TRANSFER OWNERSHIP OF","WHENEVER {NOT FOUND | SQLERROR | SQLWARNING}","WHILE"]),vO=x(["UNION [ALL]","EXCEPT [ALL]","INTERSECT [ALL]"]),HO=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN"]),BO=x(["ON DELETE","ON UPDATE","SET NULL","{ROWS | RANGE} BETWEEN"]),FO=x([]),YO={name:"db2",tokenizerOptions:{reservedSelect:gO,reservedClauses:[...GO,...vi,...qT],reservedSetOperations:vO,reservedJoins:HO,reservedKeywordPhrases:BO,reservedDataTypePhrases:FO,reservedKeywords:xO,reservedDataTypes:yO,reservedFunctionNames:UO,extraParens:["[]"],stringTypes:[{quote:"''-qq",prefixes:["G","N","U&"]},{quote:"''-raw",prefixes:["X","BX","GX","UX"],requirePrefix:!0}],identTypes:['""-qq'],identChars:{first:"@#$",rest:"@#$"},paramTypes:{positional:!0,named:[":"]},paramChars:{first:"@#$",rest:"@#$"},operators:["**","%","|","&","^","~","¬=","¬>","¬<","!>","!<","^=","^>","^<","||","->","=>"]},formatOptions:{onelineClauses:[...vi,...qT],tabularOnelineClauses:qT}},wO=["ARRAY_AGG","AVG","CORR","CORRELATION","COUNT","COUNT_BIG","COVAR_POP","COVARIANCE","COVAR","COVAR_SAMP","COVARIANCE_SAMP","EVERY","GROUPING","JSON_ARRAYAGG","JSON_OBJECTAGG","LISTAGG","MAX","MEDIAN","MIN","PERCENTILE_CONT","PERCENTILE_DISC","REGR_AVGX","REGR_AVGY","REGR_COUNT","REGR_INTERCEPT","REGR_R2","REGR_SLOPE","REGR_SXX","REGR_SXY","REGR_SYY","SOME","STDDEV_POP","STDDEV","STDDEV_SAMP","SUM","VAR_POP","VARIANCE","VAR","VAR_SAMP","VARIANCE_SAMP","XMLAGG","XMLGROUP","ABS","ABSVAL","ACOS","ADD_DAYS","ADD_HOURS","ADD_MINUTES","ADD_MONTHS","ADD_SECONDS","ADD_YEARS","ANTILOG","ARRAY_MAX_CARDINALITY","ARRAY_TRIM","ASCII","ASIN","ATAN","ATAN2","ATANH","BASE64_DECODE","BASE64_ENCODE","BIT_LENGTH","BITAND","BITANDNOT","BITNOT","BITOR","BITXOR","BSON_TO_JSON","CARDINALITY","CEIL","CEILING","CHAR_LENGTH","CHARACTER_LENGTH","CHR","COALESCE","COMPARE_DECFLOAT","CONCAT","CONTAINS","COS","COSH","COT","CURDATE","CURTIME","DATABASE","DATAPARTITIONNAME","DATAPARTITIONNUM","DAY","DAYNAME","DAYOFMONTH","DAYOFWEEK_ISO","DAYOFWEEK","DAYOFYEAR","DAYS","DBPARTITIONNAME","DBPARTITIONNUM","DECFLOAT_FORMAT","DECFLOAT_SORTKEY","DECRYPT_BINARY","DECRYPT_BIT","DECRYPT_CHAR","DECRYPT_DB","DEGREES","DIFFERENCE","DIGITS","DLCOMMENT","DLLINKTYPE","DLURLCOMPLETE","DLURLPATH","DLURLPATHONLY","DLURLSCHEME","DLURLSERVER","DLVALUE","DOUBLE_PRECISION","DOUBLE","ENCRPYT","ENCRYPT_AES","ENCRYPT_AES256","ENCRYPT_RC2","ENCRYPT_TDES","EXP","EXTRACT","FIRST_DAY","FLOOR","GENERATE_UNIQUE","GET_BLOB_FROM_FILE","GET_CLOB_FROM_FILE","GET_DBCLOB_FROM_FILE","GET_XML_FILE","GETHINT","GREATEST","HASH_MD5","HASH_ROW","HASH_SHA1","HASH_SHA256","HASH_SHA512","HASH_VALUES","HASHED_VALUE","HEX","HEXTORAW","HOUR","HTML_ENTITY_DECODE","HTML_ENTITY_ENCODE","HTTP_DELETE_BLOB","HTTP_DELETE","HTTP_GET_BLOB","HTTP_GET","HTTP_PATCH_BLOB","HTTP_PATCH","HTTP_POST_BLOB","HTTP_POST","HTTP_PUT_BLOB","HTTP_PUT","IDENTITY_VAL_LOCAL","IFNULL","INSERT","INSTR","INTERPRET","ISFALSE","ISNOTFALSE","ISNOTTRUE","ISTRUE","JSON_ARRAY","JSON_OBJECT","JSON_QUERY","JSON_TO_BSON","JSON_UPDATE","JSON_VALUE","JULIAN_DAY","LAND","LAST_DAY","LCASE","LEAST","LEFT","LENGTH","LN","LNOT","LOCATE_IN_STRING","LOCATE","LOG10","LOR","LOWER","LPAD","LTRIM","MAX_CARDINALITY","MAX","MICROSECOND","MIDNIGHT_SECONDS","MIN","MINUTE","MOD","MONTH","MONTHNAME","MONTHS_BETWEEN","MQREAD","MQREADCLOB","MQRECEIVE","MQRECEIVECLOB","MQSEND","MULTIPLY_ALT","NEXT_DAY","NORMALIZE_DECFLOAT","NOW","NULLIF","NVL","OCTET_LENGTH","OVERLAY","PI","POSITION","POSSTR","POW","POWER","QUANTIZE","QUARTER","RADIANS","RAISE_ERROR","RANDOM","RAND","REGEXP_COUNT","REGEXP_INSTR","REGEXP_REPLACE","REGEXP_SUBSTR","REPEAT","REPLACE","RID","RIGHT","ROUND_TIMESTAMP","ROUND","RPAD","RRN","RTRIM","SCORE","SECOND","SIGN","SIN","SINH","SOUNDEX","SPACE","SQRT","STRIP","STRLEFT","STRPOS","STRRIGHT","SUBSTR","SUBSTRING","TABLE_NAME","TABLE_SCHEMA","TAN","TANH","TIMESTAMP_FORMAT","TIMESTAMP_ISO","TIMESTAMPDIFF_BIG","TIMESTAMPDIFF","TO_CHAR","TO_CLOB","TO_DATE","TO_NUMBER","TO_TIMESTAMP","TOTALORDER","TRANSLATE","TRIM_ARRAY","TRIM","TRUNC_TIMESTAMP","TRUNC","TRUNCATE","UCASE","UPPER","URL_DECODE","URL_ENCODE","VALUE","VARBINARY_FORMAT","VARCHAR_BIT_FORMAT","VARCHAR_FORMAT_BINARY","VARCHAR_FORMAT","VERIFY_GROUP_FOR_USER","WEEK_ISO","WEEK","WRAP","XMLATTRIBUTES","XMLCOMMENT","XMLCONCAT","XMLDOCUMENT","XMLELEMENT","XMLFOREST","XMLNAMESPACES","XMLPARSE","XMLPI","XMLROW","XMLSERIALIZE","XMLTEXT","XMLVALIDATE","XOR","XSLTRANSFORM","YEAR","ZONED","BASE_TABLE","HTTP_DELETE_BLOB_VERBOSE","HTTP_DELETE_VERBOSE","HTTP_GET_BLOB_VERBOSE","HTTP_GET_VERBOSE","HTTP_PATCH_BLOB_VERBOSE","HTTP_PATCH_VERBOSE","HTTP_POST_BLOB_VERBOSE","HTTP_POST_VERBOSE","HTTP_PUT_BLOB_VERBOSE","HTTP_PUT_VERBOSE","JSON_TABLE","MQREADALL","MQREADALLCLOB","MQRECEIVEALL","MQRECEIVEALLCLOB","XMLTABLE","UNPACK","CUME_DIST","DENSE_RANK","FIRST_VALUE","LAG","LAST_VALUE","LEAD","NTH_VALUE","NTILE","PERCENT_RANK","RANK","RATIO_TO_REPORT","ROW_NUMBER","CAST"],bO=["ABSENT","ACCORDING","ACCTNG","ACTION","ACTIVATE","ADD","ALIAS","ALL","ALLOCATE","ALLOW","ALTER","AND","ANY","APPEND","APPLNAME","ARRAY","ARRAY_AGG","ARRAY_TRIM","AS","ASC","ASENSITIVE","ASSOCIATE","ATOMIC","ATTACH","ATTRIBUTES","AUTHORIZATION","AUTONOMOUS","BEFORE","BEGIN","BETWEEN","BIND","BSON","BUFFERPOOL","BY","CACHE","CALL","CALLED","CARDINALITY","CASE","CAST","CHECK","CL","CLOSE","CLUSTER","COLLECT","COLLECTION","COLUMN","COMMENT","COMMIT","COMPACT","COMPARISONS","COMPRESS","CONCAT","CONCURRENT","CONDITION","CONNECT","CONNECT_BY_ROOT","CONNECTION","CONSTANT","CONSTRAINT","CONTAINS","CONTENT","CONTINUE","COPY","COUNT","COUNT_BIG","CREATE","CREATEIN","CROSS","CUBE","CUME_DIST","CURRENT","CURRENT_DATE","CURRENT_PATH","CURRENT_SCHEMA","CURRENT_SERVER","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_TIMEZONE","CURRENT_USER","CURSOR","CYCLE","DATABASE","DATAPARTITIONNAME","DATAPARTITIONNUM","DAY","DAYS","DB2GENERAL","DB2GENRL","DB2SQL","DBINFO","DBPARTITIONNAME","DBPARTITIONNUM","DEACTIVATE","DEALLOCATE","DECLARE","DEFAULT","DEFAULTS","DEFER","DEFINE","DEFINITION","DELETE","DELETING","DENSE_RANK","DENSERANK","DESC","DESCRIBE","DESCRIPTOR","DETACH","DETERMINISTIC","DIAGNOSTICS","DISABLE","DISALLOW","DISCONNECT","DISTINCT","DO","DOCUMENT","DROP","DYNAMIC","EACH","ELSE","ELSEIF","EMPTY","ENABLE","ENCODING","ENCRYPTION","END","END-EXEC","ENDING","ENFORCED","ERROR","ESCAPE","EVERY","EXCEPT","EXCEPTION","EXCLUDING","EXCLUSIVE","EXECUTE","EXISTS","EXIT","EXTEND","EXTERNAL","EXTRACT","FALSE","FENCED","FETCH","FIELDPROC","FILE","FINAL","FIRST_VALUE","FOR","FOREIGN","FORMAT","FREE","FREEPAGE","FROM","FULL","FUNCTION","GBPCACHE","GENERAL","GENERATED","GET","GLOBAL","GO","GOTO","GRANT","GROUP","HANDLER","HASH","HASH_ROW","HASHED_VALUE","HAVING","HINT","HOLD","HOUR","HOURS","IDENTITY","IF","IGNORE","IMMEDIATE","IMPLICITLY","IN","INCLUDE","INCLUDING","INCLUSIVE","INCREMENT","INDEX","INDEXBP","INDICATOR","INF","INFINITY","INHERIT","INLINE","INNER","INOUT","INSENSITIVE","INSERT","INSERTING","INTEGRITY","INTERPRET","INTERSECT","INTO","IS","ISNULL","ISOLATION","ITERATE","JAVA","JOIN","JSON","JSON_ARRAY","JSON_ARRAYAGG","JSON_EXISTS","JSON_OBJECT","JSON_OBJECTAGG","JSON_QUERY","JSON_TABLE","JSON_VALUE","KEEP","KEY","KEYS","LABEL","LAG","LANGUAGE","LAST_VALUE","LATERAL","LEAD","LEAVE","LEFT","LEVEL2","LIKE","LIMIT","LINKTYPE","LISTAGG","LOCAL","LOCALDATE","LOCALTIME","LOCALTIMESTAMP","LOCATION","LOCATOR","LOCK","LOCKSIZE","LOG","LOGGED","LOOP","MAINTAINED","MASK","MATCHED","MATERIALIZED","MAXVALUE","MERGE","MICROSECOND","MICROSECONDS","MINPCTUSED","MINUTE","MINUTES","MINVALUE","MIRROR","MIXED","MODE","MODIFIES","MONTH","MONTHS","NAMESPACE","NAN","NATIONAL","NCHAR","NCLOB","NESTED","NEW","NEW_TABLE","NEXTVAL","NO","NOCACHE","NOCYCLE","NODENAME","NODENUMBER","NOMAXVALUE","NOMINVALUE","NONE","NOORDER","NORMALIZED","NOT","NOTNULL","NTH_VALUE","NTILE","NULL","NULLS","NVARCHAR","OBID","OBJECT","OF","OFF","OFFSET","OLD","OLD_TABLE","OMIT","ON","ONLY","OPEN","OPTIMIZE","OPTION","OR","ORDER","ORDINALITY","ORGANIZE","OUT","OUTER","OVER","OVERLAY","OVERRIDING","PACKAGE","PADDED","PAGE","PAGESIZE","PARAMETER","PART","PARTITION","PARTITIONED","PARTITIONING","PARTITIONS","PASSING","PASSWORD","PATH","PCTFREE","PERCENT_RANK","PERCENTILE_CONT","PERCENTILE_DISC","PERIOD","PERMISSION","PIECESIZE","PIPE","PLAN","POSITION","PREPARE","PREVVAL","PRIMARY","PRIOR","PRIQTY","PRIVILEGES","PROCEDURE","PROGRAM","PROGRAMID","QUERY","RANGE","RANK","RATIO_TO_REPORT","RCDFMT","READ","READS","RECOVERY","REFERENCES","REFERENCING","REFRESH","REGEXP_LIKE","RELEASE","RENAME","REPEAT","RESET","RESIGNAL","RESTART","RESULT","RESULT_SET_LOCATOR","RETURN","RETURNING","RETURNS","REVOKE","RID","RIGHT","ROLLBACK","ROLLUP","ROUTINE","ROW","ROW_NUMBER","ROWNUMBER","ROWS","RRN","RUN","SAVEPOINT","SBCS","SCALAR","SCHEMA","SCRATCHPAD","SCROLL","SEARCH","SECOND","SECONDS","SECQTY","SECURED","SELECT","SENSITIVE","SEQUENCE","SESSION","SESSION_USER","SET","SIGNAL","SIMPLE","SKIP","SNAN","SOME","SOURCE","SPECIFIC","SQL","SQLID","SQLIND_DEFAULT","SQLIND_UNASSIGNED","STACKED","START","STARTING","STATEMENT","STATIC","STOGROUP","SUBSTRING","SUMMARY","SYNONYM","SYSTEM_TIME","SYSTEM_USER","TABLE","TABLESPACE","TABLESPACES","TAG","THEN","THREADSAFE","TO","TRANSACTION","TRANSFER","TRIGGER","TRIM","TRIM_ARRAY","TRUE","TRUNCATE","TRY_CAST","TYPE","UNDO","UNION","UNIQUE","UNIT","UNKNOWN","UNNEST","UNTIL","UPDATE","UPDATING","URI","USAGE","USE","USER","USERID","USING","VALUE","VALUES","VARIABLE","VARIANT","VCAT","VERSION","VERSIONING","VIEW","VOLATILE","WAIT","WHEN","WHENEVER","WHERE","WHILE","WITH","WITHIN","WITHOUT","WRAPPED","WRAPPER","WRITE","WRKSTNNAME","XMLAGG","XMLATTRIBUTES","XMLCAST","XMLCOMMENT","XMLCONCAT","XMLDOCUMENT","XMLELEMENT","XMLFOREST","XMLGROUP","XMLNAMESPACES","XMLPARSE","XMLPI","XMLROW","XMLSERIALIZE","XMLTABLE","XMLTEXT","XMLVALIDATE","XSLTRANSFORM","XSROBJECT","YEAR","YEARS","YES","ZONE"],VO=["ARRAY","BIGINT","BINARY","BIT","BLOB","BOOLEAN","CCSID","CHAR","CHARACTER","CLOB","DATA","DATALINK","DATE","DBCLOB","DECFLOAT","DECIMAL","DEC","DOUBLE","DOUBLE PRECISION","FLOAT","GRAPHIC","INT","INTEGER","LONG","NUMERIC","REAL","ROWID","SMALLINT","TIME","TIMESTAMP","VARBINARY","VARCHAR","VARGRAPHIC","XML"],WO=x(["SELECT [ALL | DISTINCT]"]),XO=x(["WITH [RECURSIVE]","INTO","FROM","WHERE","GROUP BY","HAVING","PARTITION BY","ORDER [SIBLINGS] BY [INPUT SEQUENCE]","LIMIT","OFFSET","FETCH {FIRST | NEXT}","FOR UPDATE [OF]","FOR READ ONLY","OPTIMIZE FOR","INSERT INTO","VALUES","SET","MERGE INTO","WHEN [NOT] MATCHED [THEN]","UPDATE SET","DELETE","INSERT","FOR SYSTEM NAME"]),Hi=x(["CREATE [OR REPLACE] TABLE"]),el=x(["CREATE [OR REPLACE] [RECURSIVE] VIEW","UPDATE","WHERE CURRENT OF","WITH {NC | RR | RS | CS | UR}","DELETE FROM","DROP TABLE","ALTER TABLE","ADD [COLUMN]","ALTER [COLUMN]","DROP [COLUMN]","SET DATA TYPE","SET {GENERATED ALWAYS | GENERATED BY DEFAULT}","SET NOT NULL","SET {NOT HIDDEN | IMPLICITLY HIDDEN}","SET FIELDPROC","DROP {DEFAULT | NOT NULL | GENERATED | IDENTITY | ROW CHANGE TIMESTAMP | FIELDPROC}","TRUNCATE [TABLE]","SET [CURRENT] SCHEMA","SET CURRENT_SCHEMA","ALLOCATE CURSOR","ALLOCATE [SQL] DESCRIPTOR [LOCAL | GLOBAL] SQL","ALTER [SPECIFIC] {FUNCTION | PROCEDURE}","ALTER {MASK | PERMISSION | SEQUENCE | TRIGGER}","ASSOCIATE [RESULT SET] {LOCATOR | LOCATORS}","BEGIN DECLARE SECTION","CALL","CLOSE","COMMENT ON {ALIAS | COLUMN | CONSTRAINT | INDEX | MASK | PACKAGE | PARAMETER | PERMISSION | SEQUENCE | TABLE | TRIGGER | VARIABLE | XSROBJECT}","COMMENT ON [SPECIFIC] {FUNCTION | PROCEDURE | ROUTINE}","COMMENT ON PARAMETER SPECIFIC {FUNCTION | PROCEDURE | ROUTINE}","COMMENT ON [TABLE FUNCTION] RETURN COLUMN","COMMENT ON [TABLE FUNCTION] RETURN COLUMN SPECIFIC [PROCEDURE | ROUTINE]","COMMIT [WORK] [HOLD]","CONNECT [TO | RESET] USER","CREATE [OR REPLACE] {ALIAS | FUNCTION | MASK | PERMISSION | PROCEDURE | SEQUENCE | TRIGGER | VARIABLE}","CREATE [ENCODED VECTOR] INDEX","CREATE UNIQUE [WHERE NOT NULL] INDEX","CREATE SCHEMA","CREATE TYPE","DEALLOCATE [SQL] DESCRIPTOR [LOCAL | GLOBAL]","DECLARE CURSOR","DECLARE GLOBAL TEMPORARY TABLE","DECLARE","DESCRIBE CURSOR","DESCRIBE INPUT","DESCRIBE [OUTPUT]","DESCRIBE {PROCEDURE | ROUTINE}","DESCRIBE TABLE","DISCONNECT ALL [SQL]","DISCONNECT [CURRENT]","DROP {ALIAS | INDEX | MASK | PACKAGE | PERMISSION | SCHEMA | SEQUENCE | TABLE | TYPE | VARIABLE | XSROBJECT} [IF EXISTS]","DROP [SPECIFIC] {FUNCTION | PROCEDURE | ROUTINE} [IF EXISTS]","END DECLARE SECTION","EXECUTE [IMMEDIATE]","FREE LOCATOR","GET [SQL] DESCRIPTOR [LOCAL | GLOBAL]","GET [CURRENT | STACKED] DIAGNOSTICS","GRANT {ALL [PRIVILEGES] | ALTER | EXECUTE} ON {FUNCTION | PROCEDURE | ROUTINE | PACKAGE | SCHEMA | SEQUENCE | TABLE | TYPE | VARIABLE | XSROBJECT}","HOLD LOCATOR","INCLUDE","LABEL ON {ALIAS | COLUMN | CONSTRAINT | INDEX | MASK | PACKAGE | PERMISSION | SEQUENCE | TABLE | TRIGGER | VARIABLE | XSROBJECT}","LABEL ON [SPECIFIC] {FUNCTION | PROCEDURE | ROUTINE}","LOCK TABLE","OPEN","PREPARE","REFRESH TABLE","RELEASE","RELEASE [TO] SAVEPOINT","RENAME [TABLE | INDEX] TO","REVOKE {ALL [PRIVILEGES] | ALTER | EXECUTE} ON {FUNCTION | PROCEDURE | ROUTINE | PACKAGE | SCHEMA | SEQUENCE | TABLE | TYPE | VARIABLE | XSROBJECT}","ROLLBACK [WORK] [HOLD | TO SAVEPOINT]","SAVEPOINT","SET CONNECTION","SET CURRENT {DEBUG MODE | DECFLOAT ROUNDING MODE | DEGREE | IMPLICIT XMLPARSE OPTION | TEMPORAL SYSTEM_TIME}","SET [SQL] DESCRIPTOR [LOCAL | GLOBAL]","SET ENCRYPTION PASSWORD","SET OPTION","SET {[CURRENT [FUNCTION]] PATH | CURRENT_PATH}","SET RESULT SETS [WITH RETURN [TO CALLER | TO CLIENT]]","SET SESSION AUTHORIZATION","SET SESSION_USER","SET TRANSACTION","SIGNAL SQLSTATE [VALUE]","TAG","TRANSFER OWNERSHIP OF","WHENEVER {NOT FOUND | SQLERROR | SQLWARNING}"]),jO=x(["UNION [ALL]","EXCEPT [ALL]","INTERSECT [ALL]"]),kO=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","[LEFT | RIGHT] EXCEPTION JOIN","{INNER | CROSS} JOIN"]),KO=x(["ON DELETE","ON UPDATE","SET NULL","{ROWS | RANGE} BETWEEN"]),$O=x([]),JO={name:"db2i",tokenizerOptions:{reservedSelect:WO,reservedClauses:[...XO,...Hi,...el],reservedSetOperations:jO,reservedJoins:kO,reservedKeywordPhrases:KO,reservedDataTypePhrases:$O,reservedKeywords:bO,reservedDataTypes:VO,reservedFunctionNames:wO,nestedBlockComments:!0,extraParens:["[]"],stringTypes:[{quote:"''-qq",prefixes:["G","N"]},{quote:"''-raw",prefixes:["X","BX","GX","UX"],requirePrefix:!0}],identTypes:['""-qq'],identChars:{first:"@#$",rest:"@#$"},paramTypes:{positional:!0,named:[":"]},paramChars:{first:"@#$",rest:"@#$"},operators:["**","¬=","¬>","¬<","!>","!<","||","=>"]},formatOptions:{onelineClauses:[...Hi,...el],tabularOnelineClauses:el}},zO=["ABS","ACOS","ADD","ADD_PARQUET_KEY","AGE","AGGREGATE","ALIAS","ALL_PROFILING_OUTPUT","ANY_VALUE","APPLY","APPROX_COUNT_DISTINCT","APPROX_QUANTILE","ARBITRARY","ARGMAX","ARGMIN","ARG_MAX","ARG_MAX_NULL","ARG_MIN","ARG_MIN_NULL","ARRAY_AGG","ARRAY_AGGR","ARRAY_AGGREGATE","ARRAY_APPEND","ARRAY_APPLY","ARRAY_CAT","ARRAY_CONCAT","ARRAY_CONTAINS","ARRAY_COSINE_SIMILARITY","ARRAY_CROSS_PRODUCT","ARRAY_DISTANCE","ARRAY_DISTINCT","ARRAY_DOT_PRODUCT","ARRAY_EXTRACT","ARRAY_FILTER","ARRAY_GRADE_UP","ARRAY_HAS","ARRAY_HAS_ALL","ARRAY_HAS_ANY","ARRAY_INDEXOF","ARRAY_INNER_PRODUCT","ARRAY_INTERSECT","ARRAY_LENGTH","ARRAY_POP_BACK","ARRAY_POP_FRONT","ARRAY_POSITION","ARRAY_PREPEND","ARRAY_PUSH_BACK","ARRAY_PUSH_FRONT","ARRAY_REDUCE","ARRAY_RESIZE","ARRAY_REVERSE","ARRAY_REVERSE_SORT","ARRAY_SELECT","ARRAY_SLICE","ARRAY_SORT","ARRAY_TO_JSON","ARRAY_TO_STRING","ARRAY_TRANSFORM","ARRAY_UNIQUE","ARRAY_VALUE","ARRAY_WHERE","ARRAY_ZIP","ARROW_SCAN","ARROW_SCAN_DUMB","ASCII","ASIN","ATAN","ATAN2","AVG","BASE64","BIN","BITSTRING","BITSTRING_AGG","BIT_AND","BIT_COUNT","BIT_LENGTH","BIT_OR","BIT_POSITION","BIT_XOR","BOOL_AND","BOOL_OR","CARDINALITY","CBRT","CEIL","CEILING","CENTURY","CHECKPOINT","CHR","COLLATIONS","COL_DESCRIPTION","COMBINE","CONCAT","CONCAT_WS","CONSTANT_OR_NULL","CONTAINS","COPY_DATABASE","CORR","COS","COT","COUNT","COUNT_IF","COUNT_STAR","COVAR_POP","COVAR_SAMP","CREATE_SORT_KEY","CURRENT_CATALOG","CURRENT_DATABASE","CURRENT_DATE","CURRENT_LOCALTIME","CURRENT_LOCALTIMESTAMP","CURRENT_QUERY","CURRENT_ROLE","CURRENT_SCHEMA","CURRENT_SCHEMAS","CURRENT_SETTING","CURRENT_USER","CURRVAL","DAMERAU_LEVENSHTEIN","DATABASE_LIST","DATABASE_SIZE","DATEDIFF","DATEPART","DATESUB","DATETRUNC","DATE_ADD","DATE_DIFF","DATE_PART","DATE_SUB","DATE_TRUNC","DAY","DAYNAME","DAYOFMONTH","DAYOFWEEK","DAYOFYEAR","DECADE","DECODE","DEGREES","DISABLE_CHECKPOINT_ON_SHUTDOWN","DISABLE_OBJECT_CACHE","DISABLE_OPTIMIZER","DISABLE_PRINT_PROGRESS_BAR","DISABLE_PROFILE","DISABLE_PROFILING","DISABLE_PROGRESS_BAR","DISABLE_VERIFICATION","DISABLE_VERIFY_EXTERNAL","DISABLE_VERIFY_FETCH_ROW","DISABLE_VERIFY_PARALLELISM","DISABLE_VERIFY_SERIALIZER","DIVIDE","DUCKDB_COLUMNS","DUCKDB_CONSTRAINTS","DUCKDB_DATABASES","DUCKDB_DEPENDENCIES","DUCKDB_EXTENSIONS","DUCKDB_FUNCTIONS","DUCKDB_INDEXES","DUCKDB_KEYWORDS","DUCKDB_MEMORY","DUCKDB_OPTIMIZERS","DUCKDB_SCHEMAS","DUCKDB_SECRETS","DUCKDB_SEQUENCES","DUCKDB_SETTINGS","DUCKDB_TABLES","DUCKDB_TEMPORARY_FILES","DUCKDB_TYPES","DUCKDB_VIEWS","EDIT","EDITDIST3","ELEMENT_AT","ENABLE_CHECKPOINT_ON_SHUTDOWN","ENABLE_OBJECT_CACHE","ENABLE_OPTIMIZER","ENABLE_PRINT_PROGRESS_BAR","ENABLE_PROFILE","ENABLE_PROFILING","ENABLE_PROGRESS_BAR","ENABLE_VERIFICATION","ENCODE","ENDS_WITH","ENTROPY","ENUM_CODE","ENUM_FIRST","ENUM_LAST","ENUM_RANGE","ENUM_RANGE_BOUNDARY","EPOCH","EPOCH_MS","EPOCH_NS","EPOCH_US","ERA","ERROR","EVEN","EXP","FACTORIAL","FAVG","FDIV","FILTER","FINALIZE","FIRST","FLATTEN","FLOOR","FMOD","FORCE_CHECKPOINT","FORMAT","FORMATREADABLEDECIMALSIZE","FORMATREADABLESIZE","FORMAT_BYTES","FORMAT_PG_TYPE","FORMAT_TYPE","FROM_BASE64","FROM_BINARY","FROM_HEX","FROM_JSON","FROM_JSON_STRICT","FSUM","FUNCTIONS","GAMMA","GCD","GENERATE_SERIES","GENERATE_SUBSCRIPTS","GEN_RANDOM_UUID","GEOMEAN","GEOMETRIC_MEAN","GETENV","GET_BIT","GET_BLOCK_SIZE","GET_CURRENT_TIME","GET_CURRENT_TIMESTAMP","GLOB","GRADE_UP","GREATEST","GREATEST_COMMON_DIVISOR","GROUP_CONCAT","HAMMING","HASH","HAS_ANY_COLUMN_PRIVILEGE","HAS_COLUMN_PRIVILEGE","HAS_DATABASE_PRIVILEGE","HAS_FOREIGN_DATA_WRAPPER_PRIVILEGE","HAS_FUNCTION_PRIVILEGE","HAS_LANGUAGE_PRIVILEGE","HAS_SCHEMA_PRIVILEGE","HAS_SEQUENCE_PRIVILEGE","HAS_SERVER_PRIVILEGE","HAS_TABLESPACE_PRIVILEGE","HAS_TABLE_PRIVILEGE","HEX","HISTOGRAM","HOUR","ICU_CALENDAR_NAMES","ICU_SORT_KEY","ILIKE_ESCAPE","IMPORT_DATABASE","INDEX_SCAN","INET_CLIENT_ADDR","INET_CLIENT_PORT","INET_SERVER_ADDR","INET_SERVER_PORT","INSTR","IN_SEARCH_PATH","ISFINITE","ISINF","ISNAN","ISODOW","ISOYEAR","JACCARD","JARO_SIMILARITY","JARO_WINKLER_SIMILARITY","JSON_ARRAY","JSON_ARRAY_LENGTH","JSON_CONTAINS","JSON_DESERIALIZE_SQL","JSON_EXECUTE_SERIALIZED_SQL","JSON_EXTRACT","JSON_EXTRACT_PATH","JSON_EXTRACT_PATH_TEXT","JSON_EXTRACT_STRING","JSON_GROUP_ARRAY","JSON_GROUP_OBJECT","JSON_GROUP_STRUCTURE","JSON_KEYS","JSON_MERGE_PATCH","JSON_OBJECT","JSON_QUOTE","JSON_SERIALIZE_PLAN","JSON_SERIALIZE_SQL","JSON_STRUCTURE","JSON_TRANSFORM","JSON_TRANSFORM_STRICT","JSON_TYPE","JSON_VALID","JULIAN","KAHAN_SUM","KURTOSIS","KURTOSIS_POP","LAST","LAST_DAY","LCASE","LCM","LEAST","LEAST_COMMON_MULTIPLE","LEFT","LEFT_GRAPHEME","LEN","LENGTH","LENGTH_GRAPHEME","LEVENSHTEIN","LGAMMA","LIKE_ESCAPE","LIST","LISTAGG","LIST_AGGR","LIST_AGGREGATE","LIST_ANY_VALUE","LIST_APPEND","LIST_APPLY","LIST_APPROX_COUNT_DISTINCT","LIST_AVG","LIST_BIT_AND","LIST_BIT_OR","LIST_BIT_XOR","LIST_BOOL_AND","LIST_BOOL_OR","LIST_CAT","LIST_CONCAT","LIST_CONTAINS","LIST_COSINE_SIMILARITY","LIST_COUNT","LIST_DISTANCE","LIST_DISTINCT","LIST_DOT_PRODUCT","LIST_ELEMENT","LIST_ENTROPY","LIST_EXTRACT","LIST_FILTER","LIST_FIRST","LIST_GRADE_UP","LIST_HAS","LIST_HAS_ALL","LIST_HAS_ANY","LIST_HISTOGRAM","LIST_INDEXOF","LIST_INNER_PRODUCT","LIST_INTERSECT","LIST_KURTOSIS","LIST_KURTOSIS_POP","LIST_LAST","LIST_MAD","LIST_MAX","LIST_MEDIAN","LIST_MIN","LIST_MODE","LIST_PACK","LIST_POSITION","LIST_PREPEND","LIST_PRODUCT","LIST_REDUCE","LIST_RESIZE","LIST_REVERSE","LIST_REVERSE_SORT","LIST_SELECT","LIST_SEM","LIST_SKEWNESS","LIST_SLICE","LIST_SORT","LIST_STDDEV_POP","LIST_STDDEV_SAMP","LIST_STRING_AGG","LIST_SUM","LIST_TRANSFORM","LIST_UNIQUE","LIST_VALUE","LIST_VAR_POP","LIST_VAR_SAMP","LIST_WHERE","LIST_ZIP","LN","LOG","LOG10","LOG2","LOWER","LPAD","LSMODE","LTRIM","MAD","MAKE_DATE","MAKE_TIME","MAKE_TIMESTAMP","MAKE_TIMESTAMPTZ","MAP","MAP_CONCAT","MAP_ENTRIES","MAP_EXTRACT","MAP_FROM_ENTRIES","MAP_KEYS","MAP_VALUES","MAX","MAX_BY","MD5","MD5_NUMBER","MD5_NUMBER_LOWER","MD5_NUMBER_UPPER","MEAN","MEDIAN","METADATA_INFO","MICROSECOND","MILLENNIUM","MILLISECOND","MIN","MINUTE","MIN_BY","MISMATCHES","MOD","MODE","MONTH","MONTHNAME","MULTIPLY","NEXTAFTER","NEXTVAL","NFC_NORMALIZE","NOT_ILIKE_ESCAPE","NOT_LIKE_ESCAPE","NOW","NULLIF","OBJ_DESCRIPTION","OCTET_LENGTH","ORD","PARQUET_FILE_METADATA","PARQUET_KV_METADATA","PARQUET_METADATA","PARQUET_SCAN","PARQUET_SCHEMA","PARSE_DIRNAME","PARSE_DIRPATH","PARSE_FILENAME","PARSE_PATH","PG_COLLATION_IS_VISIBLE","PG_CONF_LOAD_TIME","PG_CONVERSION_IS_VISIBLE","PG_FUNCTION_IS_VISIBLE","PG_GET_CONSTRAINTDEF","PG_GET_EXPR","PG_GET_VIEWDEF","PG_HAS_ROLE","PG_IS_OTHER_TEMP_SCHEMA","PG_MY_TEMP_SCHEMA","PG_OPCLASS_IS_VISIBLE","PG_OPERATOR_IS_VISIBLE","PG_OPFAMILY_IS_VISIBLE","PG_POSTMASTER_START_TIME","PG_SIZE_PRETTY","PG_TABLE_IS_VISIBLE","PG_TIMEZONE_NAMES","PG_TS_CONFIG_IS_VISIBLE","PG_TS_DICT_IS_VISIBLE","PG_TS_PARSER_IS_VISIBLE","PG_TS_TEMPLATE_IS_VISIBLE","PG_TYPEOF","PG_TYPE_IS_VISIBLE","PI","PLATFORM","POSITION","POW","POWER","PRAGMA_COLLATIONS","PRAGMA_DATABASE_SIZE","PRAGMA_METADATA_INFO","PRAGMA_PLATFORM","PRAGMA_SHOW","PRAGMA_STORAGE_INFO","PRAGMA_TABLE_INFO","PRAGMA_USER_AGENT","PRAGMA_VERSION","PREFIX","PRINTF","PRODUCT","QUANTILE","QUANTILE_CONT","QUANTILE_DISC","QUARTER","RADIANS","RANDOM","RANGE","READFILE","READ_BLOB","READ_CSV","READ_CSV_AUTO","READ_JSON","READ_JSON_AUTO","READ_JSON_OBJECTS","READ_JSON_OBJECTS_AUTO","READ_NDJSON","READ_NDJSON_AUTO","READ_NDJSON_OBJECTS","READ_PARQUET","READ_TEXT","REDUCE","REGEXP_ESCAPE","REGEXP_EXTRACT","REGEXP_EXTRACT_ALL","REGEXP_FULL_MATCH","REGEXP_MATCHES","REGEXP_REPLACE","REGEXP_SPLIT_TO_ARRAY","REGEXP_SPLIT_TO_TABLE","REGR_AVGX","REGR_AVGY","REGR_COUNT","REGR_INTERCEPT","REGR_R2","REGR_SLOPE","REGR_SXX","REGR_SXY","REGR_SYY","REPEAT","REPEAT_ROW","REPLACE","RESERVOIR_QUANTILE","REVERSE","RIGHT","RIGHT_GRAPHEME","ROUND","ROUNDBANKERS","ROUND_EVEN","ROW","ROW_TO_JSON","RPAD","RTRIM","SECOND","SEM","SEQ_SCAN","SESSION_USER","SETSEED","SET_BIT","SHA256","SHA3","SHELL_ADD_SCHEMA","SHELL_ESCAPE_CRNL","SHELL_IDQUOTE","SHELL_MODULE_SCHEMA","SHELL_PUTSNL","SHOBJ_DESCRIPTION","SHOW","SHOW_DATABASES","SHOW_TABLES","SHOW_TABLES_EXPANDED","SIGN","SIGNBIT","SIN","SKEWNESS","SNIFF_CSV","SPLIT","SPLIT_PART","SQL_AUTO_COMPLETE","SQRT","STARTS_WITH","STATS","STDDEV","STDDEV_POP","STDDEV_SAMP","STORAGE_INFO","STRFTIME","STRING_AGG","STRING_SPLIT","STRING_SPLIT_REGEX","STRING_TO_ARRAY","STRIP_ACCENTS","STRLEN","STRPOS","STRPTIME","STRUCT_EXTRACT","STRUCT_INSERT","STRUCT_PACK","STR_SPLIT","STR_SPLIT_REGEX","SUBSTR","SUBSTRING","SUBSTRING_GRAPHEME","SUBTRACT","SUFFIX","SUM","SUMKAHAN","SUMMARY","SUM_NO_OVERFLOW","TABLE_INFO","TAN","TEST_ALL_TYPES","TEST_VECTOR_TYPES","TIMEZONE","TIMEZONE_HOUR","TIMEZONE_MINUTE","TIME_BUCKET","TODAY","TO_BASE","TO_BASE64","TO_BINARY","TO_CENTURIES","TO_DAYS","TO_DECADES","TO_HEX","TO_HOURS","TO_JSON","TO_MICROSECONDS","TO_MILLENNIA","TO_MILLISECONDS","TO_MINUTES","TO_MONTHS","TO_SECONDS","TO_TIMESTAMP","TO_WEEKS","TO_YEARS","TRANSACTION_TIMESTAMP","TRANSLATE","TRIM","TRUNC","TRY_STRPTIME","TXID_CURRENT","TYPEOF","UCASE","UNBIN","UNHEX","UNICODE","UNION_EXTRACT","UNION_TAG","UNION_VALUE","UNNEST","UNPIVOT_LIST","UPPER","USER","USER_AGENT","UUID","VARIANCE","VAR_POP","VAR_SAMP","VECTOR_TYPE","VERIFY_EXTERNAL","VERIFY_FETCH_ROW","VERIFY_PARALLELISM","VERIFY_SERIALIZER","VERSION","WEEK","WEEKDAY","WEEKOFYEAR","WHICH_SECRET","WRITEFILE","XOR","YEAR","YEARWEEK","CAST","COALESCE","RANK","ROW_NUMBER"],QO=["ALL","ANALYSE","ANALYZE","AND","ANY","AS","ASC","ATTACH","ASYMMETRIC","BOTH","CASE","CAST","CHECK","COLLATE","COLUMN","CONSTRAINT","CREATE","DEFAULT","DEFERRABLE","DESC","DESCRIBE","DETACH","DISTINCT","DO","ELSE","END","EXCEPT","FALSE","FETCH","FOR","FOREIGN","FROM","GRANT","GROUP","HAVING","IN","INITIALLY","INTERSECT","INTO","IS","LATERAL","LEADING","LIMIT","NOT","NULL","OFFSET","ON","ONLY","OR","ORDER","PIVOT","PIVOT_LONGER","PIVOT_WIDER","PLACING","PRIMARY","REFERENCES","RETURNING","SELECT","SHOW","SOME","SUMMARIZE","SYMMETRIC","TABLE","THEN","TO","TRAILING","TRUE","UNION","UNIQUE","UNPIVOT","USING","VARIADIC","WHEN","WHERE","WINDOW","WITH"],ZO=["ARRAY","BIGINT","BINARY","BIT","BITSTRING","BLOB","BOOL","BOOLEAN","BPCHAR","BYTEA","CHAR","DATE","DATETIME","DEC","DECIMAL","DOUBLE","ENUM","FLOAT","FLOAT4","FLOAT8","GUID","HUGEINT","INET","INT","INT1","INT128","INT16","INT2","INT32","INT4","INT64","INT8","INTEGER","INTEGRAL","INTERVAL","JSON","LIST","LOGICAL","LONG","MAP","NUMERIC","NVARCHAR","OID","REAL","ROW","SHORT","SIGNED","SMALLINT","STRING","STRUCT","TEXT","TIME","TIMESTAMP_MS","TIMESTAMP_NS","TIMESTAMP_S","TIMESTAMP_US","TIMESTAMP","TIMESTAMPTZ","TIMETZ","TINYINT","UBIGINT","UHUGEINT","UINT128","UINT16","UINT32","UINT64","UINT8","UINTEGER","UNION","USMALLINT","UTINYINT","UUID","VARBINARY","VARCHAR"],qO=x(["SELECT [ALL | DISTINCT]"]),ec=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY [ALL]","HAVING","WINDOW","PARTITION BY","ORDER BY [ALL]","LIMIT","OFFSET","USING SAMPLE","QUALIFY","INSERT [OR REPLACE] INTO","VALUES","DEFAULT VALUES","SET","RETURNING"]),Bi=x(["CREATE [OR REPLACE] [TEMPORARY | TEMP] TABLE [IF NOT EXISTS]"]),tl=x(["UPDATE","ON CONFLICT","DELETE FROM","DROP TABLE [IF EXISTS]","TRUNCATE","ALTER TABLE","ADD [COLUMN] [IF NOT EXISTS]","ADD PRIMARY KEY","DROP [COLUMN] [IF EXISTS]","ALTER [COLUMN]","RENAME [COLUMN]","RENAME TO","SET [DATA] TYPE","{SET | DROP} DEFAULT","{SET | DROP} NOT NULL","CREATE [OR REPLACE] [TEMPORARY | TEMP] {MACRO | FUNCTION}","DROP MACRO [TABLE] [IF EXISTS]","DROP FUNCTION [IF EXISTS]","CREATE [UNIQUE] INDEX [IF NOT EXISTS]","DROP INDEX [IF EXISTS]","CREATE [OR REPLACE] SCHEMA [IF NOT EXISTS]","DROP SCHEMA [IF EXISTS]","CREATE [OR REPLACE] [PERSISTENT | TEMPORARY] SECRET [IF NOT EXISTS]","DROP [PERSISTENT | TEMPORARY] SECRET [IF EXISTS]","CREATE [OR REPLACE] [TEMPORARY | TEMP] SEQUENCE","DROP SEQUENCE [IF EXISTS]","CREATE [OR REPLACE] [TEMPORARY | TEMP] VIEW [IF NOT EXISTS]","DROP VIEW [IF EXISTS]","ALTER VIEW","CREATE TYPE","DROP TYPE [IF EXISTS]","ANALYZE","ATTACH [DATABASE] [IF NOT EXISTS]","DETACH [DATABASE] [IF EXISTS]","CALL","[FORCE] CHECKPOINT","COMMENT ON [TABLE | COLUMN | VIEW | INDEX | SEQUENCE | TYPE | MACRO | MACRO TABLE]","COPY [FROM DATABASE]","DESCRIBE","EXPORT DATABASE","IMPORT DATABASE","INSTALL","LOAD","PIVOT","PIVOT_WIDER","UNPIVOT","EXPLAIN [ANALYZE]","SET {LOCAL | SESSION | GLOBAL}","RESET [LOCAL | SESSION | GLOBAL]","{SET | RESET} VARIABLE","SUMMARIZE","BEGIN TRANSACTION","ROLLBACK","COMMIT","ABORT","USE","VACUUM [ANALYZE]","PREPARE","EXECUTE","DEALLOCATE [PREPARE]"]),tc=x(["UNION [ALL | BY NAME]","EXCEPT [ALL]","INTERSECT [ALL]"]),Ec=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","{NATURAL | ASOF} [INNER] JOIN","{NATURAL | ASOF} {LEFT | RIGHT | FULL} [OUTER] JOIN","POSITIONAL JOIN","ANTI JOIN","SEMI JOIN"]),nc=x(["{ROWS | RANGE | GROUPS} BETWEEN","SIMILAR TO","IS [NOT] DISTINCT FROM"]),rc=x(["TIMESTAMP WITH TIME ZONE"]),sc={name:"duckdb",tokenizerOptions:{reservedSelect:qO,reservedClauses:[...ec,...Bi,...tl],reservedSetOperations:tc,reservedJoins:Ec,reservedKeywordPhrases:nc,reservedDataTypePhrases:rc,supportsXor:!0,reservedKeywords:QO,reservedDataTypes:ZO,reservedFunctionNames:zO,nestedBlockComments:!0,extraParens:["[]","{}"],underscoresInNumbers:!0,stringTypes:["$$","''-qq",{quote:"''-qq-bs",prefixes:["E"],requirePrefix:!0},{quote:"''-raw",prefixes:["B","X"],requirePrefix:!0}],identTypes:['""-qq'],identChars:{rest:"$"},paramTypes:{positional:!0,numbered:["$"],quoted:["$"]},operators:["//","%","**","^","!","&","|","~","<<",">>","::","==","->","->>",":",":=","=>","~~","!~~","~~*","!~~*","~~~","~","!~","~*","!~*","^@","||",">>=","<<="]},formatOptions:{alwaysDenseOperators:["::"],onelineClauses:[...Bi,...tl],tabularOnelineClauses:tl}},Tc=["ABS","ACOS","ASIN","ATAN","BIN","BROUND","CBRT","CEIL","CEILING","CONV","COS","DEGREES","EXP","FACTORIAL","FLOOR","GREATEST","HEX","LEAST","LN","LOG","LOG10","LOG2","NEGATIVE","PI","PMOD","POSITIVE","POW","POWER","RADIANS","RAND","ROUND","SHIFTLEFT","SHIFTRIGHT","SHIFTRIGHTUNSIGNED","SIGN","SIN","SQRT","TAN","UNHEX","WIDTH_BUCKET","ARRAY_CONTAINS","MAP_KEYS","MAP_VALUES","SIZE","SORT_ARRAY","BINARY","CAST","ADD_MONTHS","DATE","DATE_ADD","DATE_FORMAT","DATE_SUB","DATEDIFF","DAY","DAYNAME","DAYOFMONTH","DAYOFYEAR","EXTRACT","FROM_UNIXTIME","FROM_UTC_TIMESTAMP","HOUR","LAST_DAY","MINUTE","MONTH","MONTHS_BETWEEN","NEXT_DAY","QUARTER","SECOND","TIMESTAMP","TO_DATE","TO_UTC_TIMESTAMP","TRUNC","UNIX_TIMESTAMP","WEEKOFYEAR","YEAR","ASSERT_TRUE","COALESCE","IF","ISNOTNULL","ISNULL","NULLIF","NVL","ASCII","BASE64","CHARACTER_LENGTH","CHR","CONCAT","CONCAT_WS","CONTEXT_NGRAMS","DECODE","ELT","ENCODE","FIELD","FIND_IN_SET","FORMAT_NUMBER","GET_JSON_OBJECT","IN_FILE","INITCAP","INSTR","LCASE","LENGTH","LEVENSHTEIN","LOCATE","LOWER","LPAD","LTRIM","NGRAMS","OCTET_LENGTH","PARSE_URL","PRINTF","QUOTE","REGEXP_EXTRACT","REGEXP_REPLACE","REPEAT","REVERSE","RPAD","RTRIM","SENTENCES","SOUNDEX","SPACE","SPLIT","STR_TO_MAP","SUBSTR","SUBSTRING","TRANSLATE","TRIM","UCASE","UNBASE64","UPPER","MASK","MASK_FIRST_N","MASK_HASH","MASK_LAST_N","MASK_SHOW_FIRST_N","MASK_SHOW_LAST_N","AES_DECRYPT","AES_ENCRYPT","CRC32","CURRENT_DATABASE","CURRENT_USER","HASH","JAVA_METHOD","LOGGED_IN_USER","MD5","REFLECT","SHA","SHA1","SHA2","SURROGATE_KEY","VERSION","AVG","COLLECT_LIST","COLLECT_SET","CORR","COUNT","COVAR_POP","COVAR_SAMP","HISTOGRAM_NUMERIC","MAX","MIN","NTILE","PERCENTILE","PERCENTILE_APPROX","REGR_AVGX","REGR_AVGY","REGR_COUNT","REGR_INTERCEPT","REGR_R2","REGR_SLOPE","REGR_SXX","REGR_SXY","REGR_SYY","STDDEV_POP","STDDEV_SAMP","SUM","VAR_POP","VAR_SAMP","VARIANCE","EXPLODE","INLINE","JSON_TUPLE","PARSE_URL_TUPLE","POSEXPLODE","STACK","LEAD","LAG","FIRST_VALUE","LAST_VALUE","RANK","ROW_NUMBER","DENSE_RANK","CUME_DIST","PERCENT_RANK","NTILE"],lc=["ADD","ADMIN","AFTER","ANALYZE","ARCHIVE","ASC","BEFORE","BUCKET","BUCKETS","CASCADE","CHANGE","CLUSTER","CLUSTERED","CLUSTERSTATUS","COLLECTION","COLUMNS","COMMENT","COMPACT","COMPACTIONS","COMPUTE","CONCATENATE","CONTINUE","DATA","DATABASES","DATETIME","DAY","DBPROPERTIES","DEFERRED","DEFINED","DELIMITED","DEPENDENCY","DESC","DIRECTORIES","DIRECTORY","DISABLE","DISTRIBUTE","ELEM_TYPE","ENABLE","ESCAPED","EXCLUSIVE","EXPLAIN","EXPORT","FIELDS","FILE","FILEFORMAT","FIRST","FORMAT","FORMATTED","FUNCTIONS","HOLD_DDLTIME","HOUR","IDXPROPERTIES","IGNORE","INDEX","INDEXES","INPATH","INPUTDRIVER","INPUTFORMAT","ITEMS","JAR","KEYS","KEY_TYPE","LIMIT","LINES","LOAD","LOCATION","LOCK","LOCKS","LOGICAL","LONG","MAPJOIN","MATERIALIZED","METADATA","MINUS","MINUTE","MONTH","MSCK","NOSCAN","NO_DROP","OFFLINE","OPTION","OUTPUTDRIVER","OUTPUTFORMAT","OVERWRITE","OWNER","PARTITIONED","PARTITIONS","PLUS","PRETTY","PRINCIPALS","PROTECTION","PURGE","READ","READONLY","REBUILD","RECORDREADER","RECORDWRITER","RELOAD","RENAME","REPAIR","REPLACE","REPLICATION","RESTRICT","REWRITE","ROLE","ROLES","SCHEMA","SCHEMAS","SECOND","SEMI","SERDE","SERDEPROPERTIES","SERVER","SETS","SHARED","SHOW","SHOW_DATABASE","SKEWED","SORT","SORTED","SSL","STATISTICS","STORED","STREAMTABLE","STRING","TABLES","TBLPROPERTIES","TEMPORARY","TERMINATED","TINYINT","TOUCH","TRANSACTIONS","UNARCHIVE","UNDO","UNIONTYPE","UNLOCK","UNSET","UNSIGNED","URI","USE","UTC","UTCTIMESTAMP","VALUE_TYPE","VIEW","WHILE","YEAR","AUTOCOMMIT","ISOLATION","LEVEL","OFFSET","SNAPSHOT","TRANSACTION","WORK","WRITE","ABORT","KEY","LAST","NORELY","NOVALIDATE","NULLS","RELY","VALIDATE","DETAIL","DOW","EXPRESSION","OPERATOR","QUARTER","SUMMARY","VECTORIZATION","WEEK","YEARS","MONTHS","WEEKS","DAYS","HOURS","MINUTES","SECONDS","TIMESTAMPTZ","ZONE","ALL","ALTER","AND","AS","AUTHORIZATION","BETWEEN","BOTH","BY","CASE","CAST","COLUMN","CONF","CREATE","CROSS","CUBE","CURRENT","CURRENT_DATE","CURRENT_TIMESTAMP","CURSOR","DATABASE","DELETE","DESCRIBE","DISTINCT","DROP","ELSE","END","EXCHANGE","EXISTS","EXTENDED","EXTERNAL","FALSE","FETCH","FOLLOWING","FOR","FROM","FULL","FUNCTION","GRANT","GROUP","GROUPING","HAVING","IF","IMPORT","IN","INNER","INSERT","INTERSECT","INTO","IS","JOIN","LATERAL","LEFT","LESS","LIKE","LOCAL","MACRO","MORE","NONE","NOT","NULL","OF","ON","OR","ORDER","OUT","OUTER","OVER","PARTIALSCAN","PARTITION","PERCENT","PRECEDING","PRESERVE","PROCEDURE","RANGE","READS","REDUCE","REVOKE","RIGHT","ROLLUP","ROW","ROWS","SELECT","SET","TABLE","TABLESAMPLE","THEN","TO","TRANSFORM","TRIGGER","TRUE","TRUNCATE","UNBOUNDED","UNION","UNIQUEJOIN","UPDATE","USER","USING","UTC_TMESTAMP","VALUES","WHEN","WHERE","WINDOW","WITH","COMMIT","ONLY","REGEXP","RLIKE","ROLLBACK","START","CACHE","CONSTRAINT","FOREIGN","PRIMARY","REFERENCES","DAYOFWEEK","EXTRACT","FLOOR","VIEWS","TIME","SYNC","TEXTFILE","SEQUENCEFILE","ORC","CSV","TSV","PARQUET","AVRO","RCFILE","JSONFILE","INPUTFORMAT","OUTPUTFORMAT"],ac=["ARRAY","BIGINT","BINARY","BOOLEAN","CHAR","DATE","DECIMAL","DOUBLE","FLOAT","INT","INTEGER","INTERVAL","MAP","NUMERIC","PRECISION","SMALLINT","STRUCT","TIMESTAMP","VARCHAR"],oc=x(["SELECT [ALL | DISTINCT]"]),ic=x(["WITH","FROM","WHERE","GROUP BY","HAVING","WINDOW","PARTITION BY","ORDER BY","SORT BY","CLUSTER BY","DISTRIBUTE BY","LIMIT","INSERT INTO [TABLE]","VALUES","SET","MERGE INTO","WHEN [NOT] MATCHED [THEN]","UPDATE SET","INSERT [VALUES]","INSERT OVERWRITE [LOCAL] DIRECTORY","LOAD DATA [LOCAL] INPATH","[OVERWRITE] INTO TABLE"]),Fi=x(["CREATE [TEMPORARY] [EXTERNAL] TABLE [IF NOT EXISTS]"]),El=x(["CREATE [MATERIALIZED] VIEW [IF NOT EXISTS]","UPDATE","DELETE FROM","DROP TABLE [IF EXISTS]","ALTER TABLE","RENAME TO","TRUNCATE [TABLE]","ALTER","CREATE","USE","DESCRIBE","DROP","FETCH","SHOW","STORED AS","STORED BY","ROW FORMAT"]),Rc=x(["UNION [ALL | DISTINCT]"]),Ac=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","LEFT SEMI JOIN"]),Sc=x(["{ROWS | RANGE} BETWEEN"]),Nc=x([]),Ic={name:"hive",tokenizerOptions:{reservedSelect:oc,reservedClauses:[...ic,...Fi,...El],reservedSetOperations:Rc,reservedJoins:Ac,reservedKeywordPhrases:Sc,reservedDataTypePhrases:Nc,reservedKeywords:lc,reservedDataTypes:ac,reservedFunctionNames:Tc,extraParens:["[]"],stringTypes:['""-bs',"''-bs"],identTypes:["``"],variableTypes:[{quote:"{}",prefixes:["$"],requirePrefix:!0}],operators:["%","~","^","|","&","<=>","==","!","||"]},formatOptions:{onelineClauses:[...Fi,...El],tabularOnelineClauses:El}};function CT(e){return e.map((t,E)=>{const n=e[E+1]||kn;if(An.SET(t)&&n.text==="(")return Object.assign(Object.assign({},t),{type:V.RESERVED_FUNCTION_NAME});const r=e[E-1]||kn;return An.VALUES(t)&&r.text==="="?Object.assign(Object.assign({},t),{type:V.RESERVED_FUNCTION_NAME}):t})}const uc=["ACCESSIBLE","ADD","ALL","ALTER","ANALYZE","AND","AS","ASC","ASENSITIVE","BEFORE","BETWEEN","BOTH","BY","CALL","CASCADE","CASE","CHANGE","CHECK","COLLATE","COLUMN","CONDITION","CONSTRAINT","CONTINUE","CONVERT","CREATE","CROSS","CURRENT_DATE","CURRENT_ROLE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","CURSOR","DATABASE","DATABASES","DAY_HOUR","DAY_MICROSECOND","DAY_MINUTE","DAY_SECOND","DECLARE","DEFAULT","DELAYED","DELETE","DELETE_DOMAIN_ID","DESC","DESCRIBE","DETERMINISTIC","DISTINCT","DISTINCTROW","DIV","DO_DOMAIN_IDS","DROP","DUAL","EACH","ELSE","ELSEIF","ENCLOSED","ESCAPED","EXCEPT","EXISTS","EXIT","EXPLAIN","FALSE","FETCH","FOR","FORCE","FOREIGN","FROM","FULLTEXT","GENERAL","GRANT","GROUP","HAVING","HIGH_PRIORITY","HOUR_MICROSECOND","HOUR_MINUTE","HOUR_SECOND","IF","IGNORE","IGNORE_DOMAIN_IDS","IGNORE_SERVER_IDS","IN","INDEX","INFILE","INNER","INOUT","INSENSITIVE","INSERT","INTERSECT","INTERVAL","INTO","IS","ITERATE","JOIN","KEY","KEYS","KILL","LEADING","LEAVE","LEFT","LIKE","LIMIT","LINEAR","LINES","LOAD","LOCALTIME","LOCALTIMESTAMP","LOCK","LOOP","LOW_PRIORITY","MASTER_HEARTBEAT_PERIOD","MASTER_SSL_VERIFY_SERVER_CERT","MATCH","MAXVALUE","MINUTE_MICROSECOND","MINUTE_SECOND","MOD","MODIFIES","NATURAL","NOT","NO_WRITE_TO_BINLOG","NULL","OFFSET","ON","OPTIMIZE","OPTION","OPTIONALLY","OR","ORDER","OUT","OUTER","OUTFILE","OVER","PAGE_CHECKSUM","PARSE_VCOL_EXPR","PARTITION","POSITION","PRIMARY","PROCEDURE","PURGE","RANGE","READ","READS","READ_WRITE","RECURSIVE","REF_SYSTEM_ID","REFERENCES","REGEXP","RELEASE","RENAME","REPEAT","REPLACE","REQUIRE","RESIGNAL","RESTRICT","RETURN","RETURNING","REVOKE","RIGHT","RLIKE","ROW_NUMBER","ROWS","SCHEMA","SCHEMAS","SECOND_MICROSECOND","SELECT","SENSITIVE","SEPARATOR","SET","SHOW","SIGNAL","SLOW","SPATIAL","SPECIFIC","SQL","SQLEXCEPTION","SQLSTATE","SQLWARNING","SQL_BIG_RESULT","SQL_CALC_FOUND_ROWS","SQL_SMALL_RESULT","SSL","STARTING","STATS_AUTO_RECALC","STATS_PERSISTENT","STATS_SAMPLE_PAGES","STRAIGHT_JOIN","TABLE","TERMINATED","THEN","TO","TRAILING","TRIGGER","TRUE","UNDO","UNION","UNIQUE","UNLOCK","UNSIGNED","UPDATE","USAGE","USE","USING","UTC_DATE","UTC_TIME","UTC_TIMESTAMP","VALUES","WHEN","WHERE","WHILE","WINDOW","WITH","WRITE","XOR","YEAR_MONTH","ZEROFILL"],Oc=["BIGINT","BINARY","BIT","BLOB","CHAR BYTE","CHAR","CHARACTER","DATETIME","DEC","DECIMAL","DOUBLE PRECISION","DOUBLE","ENUM","FIXED","FLOAT","FLOAT4","FLOAT8","INT","INT1","INT2","INT3","INT4","INT8","INTEGER","LONG","LONGBLOB","LONGTEXT","MEDIUMBLOB","MEDIUMINT","MEDIUMTEXT","MIDDLEINT","NATIONAL CHAR","NATIONAL VARCHAR","NUMERIC","PRECISION","REAL","SMALLINT","TEXT","TIMESTAMP","TINYBLOB","TINYINT","TINYTEXT","VARBINARY","VARCHAR","VARCHARACTER","VARYING","YEAR"],cc=["ADDDATE","ADD_MONTHS","BIT_AND","BIT_OR","BIT_XOR","CAST","COUNT","CUME_DIST","CURDATE","CURTIME","DATE_ADD","DATE_SUB","DATE_FORMAT","DECODE","DENSE_RANK","EXTRACT","FIRST_VALUE","GROUP_CONCAT","JSON_ARRAYAGG","JSON_OBJECTAGG","LAG","LEAD","MAX","MEDIAN","MID","MIN","NOW","NTH_VALUE","NTILE","POSITION","PERCENT_RANK","PERCENTILE_CONT","PERCENTILE_DISC","RANK","ROW_NUMBER","SESSION_USER","STD","STDDEV","STDDEV_POP","STDDEV_SAMP","SUBDATE","SUBSTR","SUBSTRING","SUM","SYSTEM_USER","TRIM","TRIM_ORACLE","VARIANCE","VAR_POP","VAR_SAMP","ABS","ACOS","ADDTIME","AES_DECRYPT","AES_ENCRYPT","ASIN","ATAN","ATAN2","BENCHMARK","BIN","BINLOG_GTID_POS","BIT_COUNT","BIT_LENGTH","CEIL","CEILING","CHARACTER_LENGTH","CHAR_LENGTH","CHR","COERCIBILITY","COLUMN_CHECK","COLUMN_EXISTS","COLUMN_LIST","COLUMN_JSON","COMPRESS","CONCAT","CONCAT_OPERATOR_ORACLE","CONCAT_WS","CONNECTION_ID","CONV","CONVERT_TZ","COS","COT","CRC32","DATEDIFF","DAYNAME","DAYOFMONTH","DAYOFWEEK","DAYOFYEAR","DEGREES","DECODE_HISTOGRAM","DECODE_ORACLE","DES_DECRYPT","DES_ENCRYPT","ELT","ENCODE","ENCRYPT","EXP","EXPORT_SET","EXTRACTVALUE","FIELD","FIND_IN_SET","FLOOR","FORMAT","FOUND_ROWS","FROM_BASE64","FROM_DAYS","FROM_UNIXTIME","GET_LOCK","GREATEST","HEX","IFNULL","INSTR","ISNULL","IS_FREE_LOCK","IS_USED_LOCK","JSON_ARRAY","JSON_ARRAY_APPEND","JSON_ARRAY_INSERT","JSON_COMPACT","JSON_CONTAINS","JSON_CONTAINS_PATH","JSON_DEPTH","JSON_DETAILED","JSON_EXISTS","JSON_EXTRACT","JSON_INSERT","JSON_KEYS","JSON_LENGTH","JSON_LOOSE","JSON_MERGE","JSON_MERGE_PATCH","JSON_MERGE_PRESERVE","JSON_QUERY","JSON_QUOTE","JSON_OBJECT","JSON_REMOVE","JSON_REPLACE","JSON_SET","JSON_SEARCH","JSON_TYPE","JSON_UNQUOTE","JSON_VALID","JSON_VALUE","LAST_DAY","LAST_INSERT_ID","LCASE","LEAST","LENGTH","LENGTHB","LN","LOAD_FILE","LOCATE","LOG","LOG10","LOG2","LOWER","LPAD","LPAD_ORACLE","LTRIM","LTRIM_ORACLE","MAKEDATE","MAKETIME","MAKE_SET","MASTER_GTID_WAIT","MASTER_POS_WAIT","MD5","MONTHNAME","NAME_CONST","NVL","NVL2","OCT","OCTET_LENGTH","ORD","PERIOD_ADD","PERIOD_DIFF","PI","POW","POWER","QUOTE","REGEXP_INSTR","REGEXP_REPLACE","REGEXP_SUBSTR","RADIANS","RAND","RELEASE_ALL_LOCKS","RELEASE_LOCK","REPLACE_ORACLE","REVERSE","ROUND","RPAD","RPAD_ORACLE","RTRIM","RTRIM_ORACLE","SEC_TO_TIME","SHA","SHA1","SHA2","SIGN","SIN","SLEEP","SOUNDEX","SPACE","SQRT","STRCMP","STR_TO_DATE","SUBSTR_ORACLE","SUBSTRING_INDEX","SUBTIME","SYS_GUID","TAN","TIMEDIFF","TIME_FORMAT","TIME_TO_SEC","TO_BASE64","TO_CHAR","TO_DAYS","TO_SECONDS","UCASE","UNCOMPRESS","UNCOMPRESSED_LENGTH","UNHEX","UNIX_TIMESTAMP","UPDATEXML","UPPER","UUID","UUID_SHORT","VERSION","WEEKDAY","WEEKOFYEAR","WSREP_LAST_WRITTEN_GTID","WSREP_LAST_SEEN_GTID","WSREP_SYNC_WAIT_UPTO_GTID","YEARWEEK","COALESCE","NULLIF"],Cc=x(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),dc=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY","HAVING","PARTITION BY","ORDER BY","LIMIT","OFFSET","FETCH {FIRST | NEXT}","INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO]","REPLACE [LOW_PRIORITY | DELAYED] [INTO]","VALUES","ON DUPLICATE KEY UPDATE","SET","RETURNING"]),Yi=x(["CREATE [OR REPLACE] [TEMPORARY] TABLE [IF NOT EXISTS]"]),nl=x(["CREATE [OR REPLACE] [SQL SECURITY DEFINER | SQL SECURITY INVOKER] VIEW [IF NOT EXISTS]","UPDATE [LOW_PRIORITY] [IGNORE]","DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM","DROP [TEMPORARY] TABLE [IF EXISTS]","ALTER [ONLINE] [IGNORE] TABLE [IF EXISTS]","ADD [COLUMN] [IF NOT EXISTS]","{CHANGE | MODIFY} [COLUMN] [IF EXISTS]","DROP [COLUMN] [IF EXISTS]","RENAME [TO]","RENAME COLUMN","ALTER [COLUMN]","{SET | DROP} DEFAULT","SET {VISIBLE | INVISIBLE}","TRUNCATE [TABLE]","ALTER DATABASE","ALTER DATABASE COMMENT","ALTER EVENT","ALTER FUNCTION","ALTER PROCEDURE","ALTER SCHEMA","ALTER SCHEMA COMMENT","ALTER SEQUENCE","ALTER SERVER","ALTER USER","ALTER VIEW","ANALYZE","ANALYZE TABLE","BACKUP LOCK","BACKUP STAGE","BACKUP UNLOCK","BEGIN","BINLOG","CACHE INDEX","CALL","CHANGE MASTER TO","CHECK TABLE","CHECK VIEW","CHECKSUM TABLE","COMMIT","CREATE AGGREGATE FUNCTION","CREATE DATABASE","CREATE EVENT","CREATE FUNCTION","CREATE INDEX","CREATE PROCEDURE","CREATE ROLE","CREATE SEQUENCE","CREATE SERVER","CREATE SPATIAL INDEX","CREATE TRIGGER","CREATE UNIQUE INDEX","CREATE USER","DEALLOCATE PREPARE","DESCRIBE","DROP DATABASE","DROP EVENT","DROP FUNCTION","DROP INDEX","DROP PREPARE","DROP PROCEDURE","DROP ROLE","DROP SEQUENCE","DROP SERVER","DROP TRIGGER","DROP USER","DROP VIEW","EXECUTE","EXPLAIN","FLUSH","GET DIAGNOSTICS","GET DIAGNOSTICS CONDITION","GRANT","HANDLER","HELP","INSTALL PLUGIN","INSTALL SONAME","KILL","LOAD DATA INFILE","LOAD INDEX INTO CACHE","LOAD XML INFILE","LOCK TABLE","OPTIMIZE TABLE","PREPARE","PURGE BINARY LOGS","PURGE MASTER LOGS","RELEASE SAVEPOINT","RENAME TABLE","RENAME USER","REPAIR TABLE","REPAIR VIEW","RESET MASTER","RESET QUERY CACHE","RESET REPLICA","RESET SLAVE","RESIGNAL","REVOKE","ROLLBACK","SAVEPOINT","SET CHARACTER SET","SET DEFAULT ROLE","SET GLOBAL TRANSACTION","SET NAMES","SET PASSWORD","SET ROLE","SET STATEMENT","SET TRANSACTION","SHOW","SHOW ALL REPLICAS STATUS","SHOW ALL SLAVES STATUS","SHOW AUTHORS","SHOW BINARY LOGS","SHOW BINLOG EVENTS","SHOW BINLOG STATUS","SHOW CHARACTER SET","SHOW CLIENT_STATISTICS","SHOW COLLATION","SHOW COLUMNS","SHOW CONTRIBUTORS","SHOW CREATE DATABASE","SHOW CREATE EVENT","SHOW CREATE FUNCTION","SHOW CREATE PACKAGE","SHOW CREATE PACKAGE BODY","SHOW CREATE PROCEDURE","SHOW CREATE SEQUENCE","SHOW CREATE TABLE","SHOW CREATE TRIGGER","SHOW CREATE USER","SHOW CREATE VIEW","SHOW DATABASES","SHOW ENGINE","SHOW ENGINE INNODB STATUS","SHOW ENGINES","SHOW ERRORS","SHOW EVENTS","SHOW EXPLAIN","SHOW FUNCTION CODE","SHOW FUNCTION STATUS","SHOW GRANTS","SHOW INDEX","SHOW INDEXES","SHOW INDEX_STATISTICS","SHOW KEYS","SHOW LOCALES","SHOW MASTER LOGS","SHOW MASTER STATUS","SHOW OPEN TABLES","SHOW PACKAGE BODY CODE","SHOW PACKAGE BODY STATUS","SHOW PACKAGE STATUS","SHOW PLUGINS","SHOW PLUGINS SONAME","SHOW PRIVILEGES","SHOW PROCEDURE CODE","SHOW PROCEDURE STATUS","SHOW PROCESSLIST","SHOW PROFILE","SHOW PROFILES","SHOW QUERY_RESPONSE_TIME","SHOW RELAYLOG EVENTS","SHOW REPLICA","SHOW REPLICA HOSTS","SHOW REPLICA STATUS","SHOW SCHEMAS","SHOW SLAVE","SHOW SLAVE HOSTS","SHOW SLAVE STATUS","SHOW STATUS","SHOW STORAGE ENGINES","SHOW TABLE STATUS","SHOW TABLES","SHOW TRIGGERS","SHOW USER_STATISTICS","SHOW VARIABLES","SHOW WARNINGS","SHOW WSREP_MEMBERSHIP","SHOW WSREP_STATUS","SHUTDOWN","SIGNAL","START ALL REPLICAS","START ALL SLAVES","START REPLICA","START SLAVE","START TRANSACTION","STOP ALL REPLICAS","STOP ALL SLAVES","STOP REPLICA","STOP SLAVE","UNINSTALL PLUGIN","UNINSTALL SONAME","UNLOCK TABLE","USE","XA BEGIN","XA COMMIT","XA END","XA PREPARE","XA RECOVER","XA ROLLBACK","XA START"]),Lc=x(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]","MINUS [ALL | DISTINCT]"]),_c=x(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),fc=x(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),pc=x([]),mc={name:"mariadb",tokenizerOptions:{reservedSelect:Cc,reservedClauses:[...dc,...Yi,...nl],reservedSetOperations:Lc,reservedJoins:_c,reservedKeywordPhrases:fc,reservedDataTypePhrases:pc,supportsXor:!0,reservedKeywords:uc,reservedDataTypes:Oc,reservedFunctionNames:cc,stringTypes:['""-qq-bs',"''-qq-bs",{quote:"''-raw",prefixes:["B","X"],requirePrefix:!0}],identTypes:["``"],identChars:{first:"$",rest:"$",allowFirstCharNumber:!0},variableTypes:[{regex:"@@?[A-Za-z0-9_.$]+"},{quote:'""-qq-bs',prefixes:["@"],requirePrefix:!0},{quote:"''-qq-bs",prefixes:["@"],requirePrefix:!0},{quote:"``",prefixes:["@"],requirePrefix:!0}],paramTypes:{positional:!0},lineCommentTypes:["--","#"],operators:["%",":=","&","|","^","~","<<",">>","<=>","&&","||","!","*.*"],postProcess:CT},formatOptions:{onelineClauses:[...Yi,...nl],tabularOnelineClauses:nl}},Dc=["ACCESSIBLE","ADD","ALL","ALTER","ANALYZE","AND","AS","ASC","ASENSITIVE","BEFORE","BETWEEN","BOTH","BY","CALL","CASCADE","CASE","CHANGE","CHECK","COLLATE","COLUMN","CONDITION","CONSTRAINT","CONTINUE","CONVERT","CREATE","CROSS","CUBE","CUME_DIST","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","CURSOR","DATABASE","DATABASES","DAY_HOUR","DAY_MICROSECOND","DAY_MINUTE","DAY_SECOND","DECLARE","DEFAULT","DELAYED","DELETE","DENSE_RANK","DESC","DESCRIBE","DETERMINISTIC","DISTINCT","DISTINCTROW","DIV","DROP","DUAL","EACH","ELSE","ELSEIF","EMPTY","ENCLOSED","ESCAPED","EXCEPT","EXISTS","EXIT","EXPLAIN","FALSE","FETCH","FIRST_VALUE","FOR","FORCE","FOREIGN","FROM","FULLTEXT","FUNCTION","GENERATED","GET","GRANT","GROUP","GROUPING","GROUPS","HAVING","HIGH_PRIORITY","HOUR_MICROSECOND","HOUR_MINUTE","HOUR_SECOND","IF","IGNORE","IN","INDEX","INFILE","INNER","INOUT","INSENSITIVE","INSERT","IN","INTERSECT","INTERVAL","INTO","IO_AFTER_GTIDS","IO_BEFORE_GTIDS","IS","ITERATE","JOIN","JSON_TABLE","KEY","KEYS","KILL","LAG","LAST_VALUE","LATERAL","LEAD","LEADING","LEAVE","LEFT","LIKE","LIMIT","LINEAR","LINES","LOAD","LOCALTIME","LOCALTIMESTAMP","LOCK","LONG","LOOP","LOW_PRIORITY","MASTER_BIND","MASTER_SSL_VERIFY_SERVER_CERT","MATCH","MAXVALUE","MINUTE_MICROSECOND","MINUTE_SECOND","MOD","MODIFIES","NATURAL","NOT","NO_WRITE_TO_BINLOG","NTH_VALUE","NTILE","NULL","OF","ON","OPTIMIZE","OPTIMIZER_COSTS","OPTION","OPTIONALLY","OR","ORDER","OUT","OUTER","OUTFILE","OVER","PARTITION","PERCENT_RANK","PRIMARY","PROCEDURE","PURGE","RANGE","RANK","READ","READS","READ_WRITE","RECURSIVE","REFERENCES","REGEXP","RELEASE","RENAME","REPEAT","REPLACE","REQUIRE","RESIGNAL","RESTRICT","RETURN","REVOKE","RIGHT","RLIKE","ROW","ROWS","ROW_NUMBER","SCHEMA","SCHEMAS","SECOND_MICROSECOND","SELECT","SENSITIVE","SEPARATOR","SET","SHOW","SIGNAL","SPATIAL","SPECIFIC","SQL","SQLEXCEPTION","SQLSTATE","SQLWARNING","SQL_BIG_RESULT","SQL_CALC_FOUND_ROWS","SQL_SMALL_RESULT","SSL","STARTING","STORED","STRAIGHT_JOIN","SYSTEM","TABLE","TERMINATED","THEN","TO","TRAILING","TRIGGER","TRUE","UNDO","UNION","UNIQUE","UNLOCK","UNSIGNED","UPDATE","USAGE","USE","USING","UTC_DATE","UTC_TIME","UTC_TIMESTAMP","VALUES","VIRTUAL","WHEN","WHERE","WHILE","WINDOW","WITH","WRITE","XOR","YEAR_MONTH","ZEROFILL"],Pc=["BIGINT","BINARY","BIT","BLOB","BOOL","BOOLEAN","CHAR","CHARACTER","DATE","DATETIME","DEC","DECIMAL","DOUBLE PRECISION","DOUBLE","ENUM","FIXED","FLOAT","FLOAT4","FLOAT8","INT","INT1","INT2","INT3","INT4","INT8","INTEGER","LONGBLOB","LONGTEXT","MEDIUMBLOB","MEDIUMINT","MEDIUMTEXT","MIDDLEINT","NATIONAL CHAR","NATIONAL VARCHAR","NUMERIC","PRECISION","REAL","SMALLINT","TEXT","TIME","TIMESTAMP","TINYBLOB","TINYINT","TINYTEXT","VARBINARY","VARCHAR","VARCHARACTER","VARYING","YEAR"],hc=["ABS","ACOS","ADDDATE","ADDTIME","AES_DECRYPT","AES_ENCRYPT","ANY_VALUE","ASCII","ASIN","ATAN","ATAN2","AVG","BENCHMARK","BIN","BIN_TO_UUID","BINARY","BIT_AND","BIT_COUNT","BIT_LENGTH","BIT_OR","BIT_XOR","CAN_ACCESS_COLUMN","CAN_ACCESS_DATABASE","CAN_ACCESS_TABLE","CAN_ACCESS_USER","CAN_ACCESS_VIEW","CAST","CEIL","CEILING","CHAR","CHAR_LENGTH","CHARACTER_LENGTH","CHARSET","COALESCE","COERCIBILITY","COLLATION","COMPRESS","CONCAT","CONCAT_WS","CONNECTION_ID","CONV","CONVERT","CONVERT_TZ","COS","COT","COUNT","CRC32","CUME_DIST","CURDATE","CURRENT_DATE","CURRENT_ROLE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","CURTIME","DATABASE","DATE","DATE_ADD","DATE_FORMAT","DATE_SUB","DATEDIFF","DAY","DAYNAME","DAYOFMONTH","DAYOFWEEK","DAYOFYEAR","DEFAULT","DEGREES","DENSE_RANK","DIV","ELT","EXP","EXPORT_SET","EXTRACT","EXTRACTVALUE","FIELD","FIND_IN_SET","FIRST_VALUE","FLOOR","FORMAT","FORMAT_BYTES","FORMAT_PICO_TIME","FOUND_ROWS","FROM_BASE64","FROM_DAYS","FROM_UNIXTIME","GEOMCOLLECTION","GEOMETRYCOLLECTION","GET_DD_COLUMN_PRIVILEGES","GET_DD_CREATE_OPTIONS","GET_DD_INDEX_SUB_PART_LENGTH","GET_FORMAT","GET_LOCK","GREATEST","GROUP_CONCAT","GROUPING","GTID_SUBSET","GTID_SUBTRACT","HEX","HOUR","ICU_VERSION","IF","IFNULL","INET_ATON","INET_NTOA","INET6_ATON","INET6_NTOA","INSERT","INSTR","INTERNAL_AUTO_INCREMENT","INTERNAL_AVG_ROW_LENGTH","INTERNAL_CHECK_TIME","INTERNAL_CHECKSUM","INTERNAL_DATA_FREE","INTERNAL_DATA_LENGTH","INTERNAL_DD_CHAR_LENGTH","INTERNAL_GET_COMMENT_OR_ERROR","INTERNAL_GET_ENABLED_ROLE_JSON","INTERNAL_GET_HOSTNAME","INTERNAL_GET_USERNAME","INTERNAL_GET_VIEW_WARNING_OR_ERROR","INTERNAL_INDEX_COLUMN_CARDINALITY","INTERNAL_INDEX_LENGTH","INTERNAL_IS_ENABLED_ROLE","INTERNAL_IS_MANDATORY_ROLE","INTERNAL_KEYS_DISABLED","INTERNAL_MAX_DATA_LENGTH","INTERNAL_TABLE_ROWS","INTERNAL_UPDATE_TIME","INTERVAL","IS","IS_FREE_LOCK","IS_IPV4","IS_IPV4_COMPAT","IS_IPV4_MAPPED","IS_IPV6","IS NOT","IS NOT NULL","IS NULL","IS_USED_LOCK","IS_UUID","ISNULL","JSON_ARRAY","JSON_ARRAY_APPEND","JSON_ARRAY_INSERT","JSON_ARRAYAGG","JSON_CONTAINS","JSON_CONTAINS_PATH","JSON_DEPTH","JSON_EXTRACT","JSON_INSERT","JSON_KEYS","JSON_LENGTH","JSON_MERGE","JSON_MERGE_PATCH","JSON_MERGE_PRESERVE","JSON_OBJECT","JSON_OBJECTAGG","JSON_OVERLAPS","JSON_PRETTY","JSON_QUOTE","JSON_REMOVE","JSON_REPLACE","JSON_SCHEMA_VALID","JSON_SCHEMA_VALIDATION_REPORT","JSON_SEARCH","JSON_SET","JSON_STORAGE_FREE","JSON_STORAGE_SIZE","JSON_TABLE","JSON_TYPE","JSON_UNQUOTE","JSON_VALID","JSON_VALUE","LAG","LAST_DAY","LAST_INSERT_ID","LAST_VALUE","LCASE","LEAD","LEAST","LEFT","LENGTH","LIKE","LINESTRING","LN","LOAD_FILE","LOCALTIME","LOCALTIMESTAMP","LOCATE","LOG","LOG10","LOG2","LOWER","LPAD","LTRIM","MAKE_SET","MAKEDATE","MAKETIME","MASTER_POS_WAIT","MATCH","MAX","MBRCONTAINS","MBRCOVEREDBY","MBRCOVERS","MBRDISJOINT","MBREQUALS","MBRINTERSECTS","MBROVERLAPS","MBRTOUCHES","MBRWITHIN","MD5","MEMBER OF","MICROSECOND","MID","MIN","MINUTE","MOD","MONTH","MONTHNAME","MULTILINESTRING","MULTIPOINT","MULTIPOLYGON","NAME_CONST","NOT","NOT IN","NOT LIKE","NOT REGEXP","NOW","NTH_VALUE","NTILE","NULLIF","OCT","OCTET_LENGTH","ORD","PERCENT_RANK","PERIOD_ADD","PERIOD_DIFF","PI","POINT","POLYGON","POSITION","POW","POWER","PS_CURRENT_THREAD_ID","PS_THREAD_ID","QUARTER","QUOTE","RADIANS","RAND","RANDOM_BYTES","RANK","REGEXP","REGEXP_INSTR","REGEXP_LIKE","REGEXP_REPLACE","REGEXP_SUBSTR","RELEASE_ALL_LOCKS","RELEASE_LOCK","REPEAT","REPLACE","REVERSE","RIGHT","RLIKE","ROLES_GRAPHML","ROUND","ROW_COUNT","ROW_NUMBER","RPAD","RTRIM","SCHEMA","SEC_TO_TIME","SECOND","SESSION_USER","SHA1","SHA2","SIGN","SIN","SLEEP","SOUNDEX","SOUNDS LIKE","SOURCE_POS_WAIT","SPACE","SQRT","ST_AREA","ST_ASBINARY","ST_ASGEOJSON","ST_ASTEXT","ST_BUFFER","ST_BUFFER_STRATEGY","ST_CENTROID","ST_COLLECT","ST_CONTAINS","ST_CONVEXHULL","ST_CROSSES","ST_DIFFERENCE","ST_DIMENSION","ST_DISJOINT","ST_DISTANCE","ST_DISTANCE_SPHERE","ST_ENDPOINT","ST_ENVELOPE","ST_EQUALS","ST_EXTERIORRING","ST_FRECHETDISTANCE","ST_GEOHASH","ST_GEOMCOLLFROMTEXT","ST_GEOMCOLLFROMWKB","ST_GEOMETRYN","ST_GEOMETRYTYPE","ST_GEOMFROMGEOJSON","ST_GEOMFROMTEXT","ST_GEOMFROMWKB","ST_HAUSDORFFDISTANCE","ST_INTERIORRINGN","ST_INTERSECTION","ST_INTERSECTS","ST_ISCLOSED","ST_ISEMPTY","ST_ISSIMPLE","ST_ISVALID","ST_LATFROMGEOHASH","ST_LATITUDE","ST_LENGTH","ST_LINEFROMTEXT","ST_LINEFROMWKB","ST_LINEINTERPOLATEPOINT","ST_LINEINTERPOLATEPOINTS","ST_LONGFROMGEOHASH","ST_LONGITUDE","ST_MAKEENVELOPE","ST_MLINEFROMTEXT","ST_MLINEFROMWKB","ST_MPOINTFROMTEXT","ST_MPOINTFROMWKB","ST_MPOLYFROMTEXT","ST_MPOLYFROMWKB","ST_NUMGEOMETRIES","ST_NUMINTERIORRING","ST_NUMPOINTS","ST_OVERLAPS","ST_POINTATDISTANCE","ST_POINTFROMGEOHASH","ST_POINTFROMTEXT","ST_POINTFROMWKB","ST_POINTN","ST_POLYFROMTEXT","ST_POLYFROMWKB","ST_SIMPLIFY","ST_SRID","ST_STARTPOINT","ST_SWAPXY","ST_SYMDIFFERENCE","ST_TOUCHES","ST_TRANSFORM","ST_UNION","ST_VALIDATE","ST_WITHIN","ST_X","ST_Y","STATEMENT_DIGEST","STATEMENT_DIGEST_TEXT","STD","STDDEV","STDDEV_POP","STDDEV_SAMP","STR_TO_DATE","STRCMP","SUBDATE","SUBSTR","SUBSTRING","SUBSTRING_INDEX","SUBTIME","SUM","SYSDATE","SYSTEM_USER","TAN","TIME","TIME_FORMAT","TIME_TO_SEC","TIMEDIFF","TIMESTAMP","TIMESTAMPADD","TIMESTAMPDIFF","TO_BASE64","TO_DAYS","TO_SECONDS","TRIM","TRUNCATE","UCASE","UNCOMPRESS","UNCOMPRESSED_LENGTH","UNHEX","UNIX_TIMESTAMP","UPDATEXML","UPPER","UTC_DATE","UTC_TIME","UTC_TIMESTAMP","UUID","UUID_SHORT","UUID_TO_BIN","VALIDATE_PASSWORD_STRENGTH","VALUES","VAR_POP","VAR_SAMP","VARIANCE","VERSION","WAIT_FOR_EXECUTED_GTID_SET","WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS","WEEK","WEEKDAY","WEEKOFYEAR","WEIGHT_STRING","YEAR","YEARWEEK"],Mc=x(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),Uc=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY","HAVING","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO]","REPLACE [LOW_PRIORITY | DELAYED] [INTO]","VALUES","ON DUPLICATE KEY UPDATE","SET"]),wi=x(["CREATE [TEMPORARY] TABLE [IF NOT EXISTS]"]),rl=x(["CREATE [OR REPLACE] [SQL SECURITY DEFINER | SQL SECURITY INVOKER] VIEW [IF NOT EXISTS]","UPDATE [LOW_PRIORITY] [IGNORE]","DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM","DROP [TEMPORARY] TABLE [IF EXISTS]","ALTER TABLE","ADD [COLUMN]","{CHANGE | MODIFY} [COLUMN]","DROP [COLUMN]","RENAME [TO | AS]","RENAME COLUMN","ALTER [COLUMN]","{SET | DROP} DEFAULT","TRUNCATE [TABLE]","ALTER DATABASE","ALTER EVENT","ALTER FUNCTION","ALTER INSTANCE","ALTER LOGFILE GROUP","ALTER PROCEDURE","ALTER RESOURCE GROUP","ALTER SERVER","ALTER TABLESPACE","ALTER USER","ALTER VIEW","ANALYZE TABLE","BINLOG","CACHE INDEX","CALL","CHANGE MASTER TO","CHANGE REPLICATION FILTER","CHANGE REPLICATION SOURCE TO","CHECK TABLE","CHECKSUM TABLE","CLONE","COMMIT","CREATE DATABASE","CREATE EVENT","CREATE FUNCTION","CREATE FUNCTION","CREATE INDEX","CREATE LOGFILE GROUP","CREATE PROCEDURE","CREATE RESOURCE GROUP","CREATE ROLE","CREATE SERVER","CREATE SPATIAL REFERENCE SYSTEM","CREATE TABLESPACE","CREATE TRIGGER","CREATE USER","DEALLOCATE PREPARE","DESCRIBE","DROP DATABASE","DROP EVENT","DROP FUNCTION","DROP FUNCTION","DROP INDEX","DROP LOGFILE GROUP","DROP PROCEDURE","DROP RESOURCE GROUP","DROP ROLE","DROP SERVER","DROP SPATIAL REFERENCE SYSTEM","DROP TABLESPACE","DROP TRIGGER","DROP USER","DROP VIEW","EXECUTE","EXPLAIN","FLUSH","GRANT","HANDLER","HELP","IMPORT TABLE","INSTALL COMPONENT","INSTALL PLUGIN","KILL","LOAD DATA","LOAD INDEX INTO CACHE","LOAD XML","LOCK INSTANCE FOR BACKUP","LOCK TABLES","MASTER_POS_WAIT","OPTIMIZE TABLE","PREPARE","PURGE BINARY LOGS","RELEASE SAVEPOINT","RENAME TABLE","RENAME USER","REPAIR TABLE","RESET","RESET MASTER","RESET PERSIST","RESET REPLICA","RESET SLAVE","RESTART","REVOKE","ROLLBACK","ROLLBACK TO SAVEPOINT","SAVEPOINT","SET CHARACTER SET","SET DEFAULT ROLE","SET NAMES","SET PASSWORD","SET RESOURCE GROUP","SET ROLE","SET TRANSACTION","SHOW","SHOW BINARY LOGS","SHOW BINLOG EVENTS","SHOW CHARACTER SET","SHOW COLLATION","SHOW COLUMNS","SHOW CREATE DATABASE","SHOW CREATE EVENT","SHOW CREATE FUNCTION","SHOW CREATE PROCEDURE","SHOW CREATE TABLE","SHOW CREATE TRIGGER","SHOW CREATE USER","SHOW CREATE VIEW","SHOW DATABASES","SHOW ENGINE","SHOW ENGINES","SHOW ERRORS","SHOW EVENTS","SHOW FUNCTION CODE","SHOW FUNCTION STATUS","SHOW GRANTS","SHOW INDEX","SHOW MASTER STATUS","SHOW OPEN TABLES","SHOW PLUGINS","SHOW PRIVILEGES","SHOW PROCEDURE CODE","SHOW PROCEDURE STATUS","SHOW PROCESSLIST","SHOW PROFILE","SHOW PROFILES","SHOW RELAYLOG EVENTS","SHOW REPLICA STATUS","SHOW REPLICAS","SHOW SLAVE","SHOW SLAVE HOSTS","SHOW STATUS","SHOW TABLE STATUS","SHOW TABLES","SHOW TRIGGERS","SHOW VARIABLES","SHOW WARNINGS","SHUTDOWN","SOURCE_POS_WAIT","START GROUP_REPLICATION","START REPLICA","START SLAVE","START TRANSACTION","STOP GROUP_REPLICATION","STOP REPLICA","STOP SLAVE","TABLE","UNINSTALL COMPONENT","UNINSTALL PLUGIN","UNLOCK INSTANCE","UNLOCK TABLES","USE","XA","ITERATE","LEAVE","LOOP","REPEAT","RETURN","WHILE"]),xc=x(["UNION [ALL | DISTINCT]"]),yc=x(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),gc=x(["ON {UPDATE | DELETE} [SET NULL]","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),Gc=x([]),vc={name:"mysql",tokenizerOptions:{reservedSelect:Mc,reservedClauses:[...Uc,...wi,...rl],reservedSetOperations:xc,reservedJoins:yc,reservedKeywordPhrases:gc,reservedDataTypePhrases:Gc,supportsXor:!0,reservedKeywords:Dc,reservedDataTypes:Pc,reservedFunctionNames:hc,stringTypes:['""-qq-bs',{quote:"''-qq-bs",prefixes:["N"]},{quote:"''-raw",prefixes:["B","X"],requirePrefix:!0}],identTypes:["``"],identChars:{first:"$",rest:"$",allowFirstCharNumber:!0},variableTypes:[{regex:"@@?[A-Za-z0-9_.$]+"},{quote:'""-qq-bs',prefixes:["@"],requirePrefix:!0},{quote:"''-qq-bs",prefixes:["@"],requirePrefix:!0},{quote:"``",prefixes:["@"],requirePrefix:!0}],paramTypes:{positional:!0},lineCommentTypes:["--","#"],operators:["%",":=","&","|","^","~","<<",">>","<=>","->","->>","&&","||","!","*.*"],postProcess:CT},formatOptions:{onelineClauses:[...wi,...rl],tabularOnelineClauses:rl}},Hc=["ADD","ALL","ALTER","ANALYZE","AND","ARRAY","AS","ASC","BETWEEN","BOTH","BY","CALL","CASCADE","CASE","CHANGE","CHECK","COLLATE","COLUMN","CONSTRAINT","CONTINUE","CONVERT","CREATE","CROSS","CURRENT_DATE","CURRENT_ROLE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","CURSOR","DATABASE","DATABASES","DAY_HOUR","DAY_MICROSECOND","DAY_MINUTE","DAY_SECOND","DEFAULT","DELAYED","DELETE","DESC","DESCRIBE","DISTINCT","DISTINCTROW","DIV","DOUBLE","DROP","DUAL","ELSE","ELSEIF","ENCLOSED","ESCAPED","EXCEPT","EXISTS","EXIT","EXPLAIN","FALSE","FETCH","FOR","FORCE","FOREIGN","FROM","FULLTEXT","GENERATED","GRANT","GROUP","GROUPS","HAVING","HIGH_PRIORITY","HOUR_MICROSECOND","HOUR_MINUTE","HOUR_SECOND","IF","IGNORE","ILIKE","IN","INDEX","INFILE","INNER","INOUT","INSERT","INTERSECT","INTERVAL","INTO","IS","ITERATE","JOIN","KEY","KEYS","KILL","LEADING","LEAVE","LEFT","LIKE","LIMIT","LINEAR","LINES","LOAD","LOCALTIME","LOCALTIMESTAMP","LOCK","LONG","LOW_PRIORITY","MATCH","MAXVALUE","MINUTE_MICROSECOND","MINUTE_SECOND","MOD","NATURAL","NOT","NO_WRITE_TO_BINLOG","NULL","OF","ON","OPTIMIZE","OPTION","OPTIONALLY","OR","ORDER","OUT","OUTER","OUTFILE","OVER","PARTITION","PRIMARY","PROCEDURE","RANGE","READ","RECURSIVE","REFERENCES","REGEXP","RELEASE","RENAME","REPEAT","REPLACE","REQUIRE","RESTRICT","REVOKE","RIGHT","RLIKE","ROW","ROWS","SECOND_MICROSECOND","SELECT","SET","SHOW","SPATIAL","SQL","SQLEXCEPTION","SQLSTATE","SQLWARNING","SQL_BIG_RESULT","SQL_CALC_FOUND_ROWS","SQL_SMALL_RESULT","SSL","STARTING","STATS_EXTENDED","STORED","STRAIGHT_JOIN","TABLE","TABLESAMPLE","TERMINATED","THEN","TO","TRAILING","TRIGGER","TRUE","TiDB_CURRENT_TSO","UNION","UNIQUE","UNLOCK","UNSIGNED","UNTIL","UPDATE","USAGE","USE","USING","UTC_DATE","UTC_TIME","UTC_TIMESTAMP","VALUES","VIRTUAL","WHEN","WHERE","WHILE","WINDOW","WITH","WRITE","XOR","YEAR_MONTH","ZEROFILL"],Bc=["BIGINT","BINARY","BIT","BLOB","BOOL","BOOLEAN","CHAR","CHARACTER","DATE","DATETIME","DEC","DECIMAL","DOUBLE PRECISION","DOUBLE","ENUM","FIXED","INT","INT1","INT2","INT3","INT4","INT8","INTEGER","LONGBLOB","LONGTEXT","MEDIUMBLOB","MEDIUMINT","MIDDLEINT","NATIONAL CHAR","NATIONAL VARCHAR","NUMERIC","PRECISION","SMALLINT","TEXT","TIME","TIMESTAMP","TINYBLOB","TINYINT","TINYTEXT","VARBINARY","VARCHAR","VARCHARACTER","VARYING","YEAR"],Fc=["ABS","ACOS","ADDDATE","ADDTIME","AES_DECRYPT","AES_ENCRYPT","ANY_VALUE","ASCII","ASIN","ATAN","ATAN2","AVG","BENCHMARK","BIN","BIN_TO_UUID","BIT_AND","BIT_COUNT","BIT_LENGTH","BIT_OR","BIT_XOR","BITAND","BITNEG","BITOR","BITXOR","CASE","CAST","CEIL","CEILING","CHAR_FUNC","CHAR_LENGTH","CHARACTER_LENGTH","CHARSET","COALESCE","COERCIBILITY","COLLATION","COMPRESS","CONCAT","CONCAT_WS","CONNECTION_ID","CONV","CONVERT","CONVERT_TZ","COS","COT","COUNT","CRC32","CUME_DIST","CURDATE","CURRENT_DATE","CURRENT_RESOURCE_GROUP","CURRENT_ROLE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","CURTIME","DATABASE","DATE","DATE_ADD","DATE_FORMAT","DATE_SUB","DATEDIFF","DAY","DAYNAME","DAYOFMONTH","DAYOFWEEK","DAYOFYEAR","DECODE","DEFAULT_FUNC","DEGREES","DENSE_RANK","DES_DECRYPT","DES_ENCRYPT","DIV","ELT","ENCODE","ENCRYPT","EQ","EXP","EXPORT_SET","EXTRACT","FIELD","FIND_IN_SET","FIRST_VALUE","FLOOR","FORMAT","FORMAT_BYTES","FORMAT_NANO_TIME","FOUND_ROWS","FROM_BASE64","FROM_DAYS","FROM_UNIXTIME","GE","GET_FORMAT","GET_LOCK","GETPARAM","GREATEST","GROUP_CONCAT","GROUPING","GT","HEX","HOUR","IF","IFNULL","ILIKE","INET6_ATON","INET6_NTOA","INET_ATON","INET_NTOA","INSERT_FUNC","INSTR","INTDIV","INTERVAL","IS_FREE_LOCK","IS_IPV4","IS_IPV4_COMPAT","IS_IPV4_MAPPED","IS_IPV6","IS_USED_LOCK","IS_UUID","ISFALSE","ISNULL","ISTRUE","JSON_ARRAY","JSON_ARRAYAGG","JSON_ARRAY_APPEND","JSON_ARRAY_INSERT","JSON_CONTAINS","JSON_CONTAINS_PATH","JSON_DEPTH","JSON_EXTRACT","JSON_INSERT","JSON_KEYS","JSON_LENGTH","JSON_MEMBEROF","JSON_MERGE","JSON_MERGE_PATCH","JSON_MERGE_PRESERVE","JSON_OBJECT","JSON_OBJECTAGG","JSON_OVERLAPS","JSON_PRETTY","JSON_QUOTE","JSON_REMOVE","JSON_REPLACE","JSON_SEARCH","JSON_SET","JSON_STORAGE_FREE","JSON_STORAGE_SIZE","JSON_TYPE","JSON_UNQUOTE","JSON_VALID","LAG","LAST_DAY","LAST_INSERT_ID","LAST_VALUE","LASTVAL","LCASE","LE","LEAD","LEAST","LEFT","LEFTSHIFT","LENGTH","LIKE","LN","LOAD_FILE","LOCALTIME","LOCALTIMESTAMP","LOCATE","LOG","LOG10","LOG2","LOWER","LPAD","LT","LTRIM","MAKE_SET","MAKEDATE","MAKETIME","MASTER_POS_WAIT","MAX","MD5","MICROSECOND","MID","MIN","MINUS","MINUTE","MOD","MONTH","MONTHNAME","MUL","NAME_CONST","NE","NEXTVAL","NOT","NOW","NTH_VALUE","NTILE","NULLEQ","OCT","OCTET_LENGTH","OLD_PASSWORD","ORD","PASSWORD_FUNC","PERCENT_RANK","PERIOD_ADD","PERIOD_DIFF","PI","PLUS","POSITION","POW","POWER","QUARTER","QUOTE","RADIANS","RAND","RANDOM_BYTES","RANK","REGEXP","REGEXP_INSTR","REGEXP_LIKE","REGEXP_REPLACE","REGEXP_SUBSTR","RELEASE_ALL_LOCKS","RELEASE_LOCK","REPEAT","REPLACE","REVERSE","RIGHT","RIGHTSHIFT","ROUND","ROW_COUNT","ROW_NUMBER","RPAD","RTRIM","SCHEMA","SEC_TO_TIME","SECOND","SESSION_USER","SETVAL","SETVAR","SHA","SHA1","SHA2","SIGN","SIN","SLEEP","SM3","SPACE","SQRT","STD","STDDEV","STDDEV_POP","STDDEV_SAMP","STR_TO_DATE","STRCMP","SUBDATE","SUBSTR","SUBSTRING","SUBSTRING_INDEX","SUBTIME","SUM","SYSDATE","SYSTEM_USER","TAN","TIDB_BOUNDED_STALENESS","TIDB_CURRENT_TSO","TIDB_DECODE_BINARY_PLAN","TIDB_DECODE_KEY","TIDB_DECODE_PLAN","TIDB_DECODE_SQL_DIGESTS","TIDB_ENCODE_SQL_DIGEST","TIDB_IS_DDL_OWNER","TIDB_PARSE_TSO","TIDB_PARSE_TSO_LOGICAL","TIDB_ROW_CHECKSUM","TIDB_SHARD","TIDB_VERSION","TIME","TIME_FORMAT","TIME_TO_SEC","TIMEDIFF","TIMESTAMP","TIMESTAMPADD","TIMESTAMPDIFF","TO_BASE64","TO_DAYS","TO_SECONDS","TRANSLATE","TRIM","TRUNCATE","UCASE","UNARYMINUS","UNCOMPRESS","UNCOMPRESSED_LENGTH","UNHEX","UNIX_TIMESTAMP","UPPER","UTC_DATE","UTC_TIME","UTC_TIMESTAMP","UUID","UUID_SHORT","UUID_TO_BIN","VALIDATE_PASSWORD_STRENGTH","VAR_POP","VAR_SAMP","VARIANCE","VERSION","VITESS_HASH","WEEK","WEEKDAY","WEEKOFYEAR","WEIGHT_STRING","YEAR","YEARWEEK"],Yc=x(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),wc=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY","HAVING","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO]","REPLACE [LOW_PRIORITY | DELAYED] [INTO]","VALUES","ON DUPLICATE KEY UPDATE","SET"]),bi=x(["CREATE [TEMPORARY] TABLE [IF NOT EXISTS]"]),sl=x(["CREATE [OR REPLACE] [SQL SECURITY DEFINER | SQL SECURITY INVOKER] VIEW [IF NOT EXISTS]","UPDATE [LOW_PRIORITY] [IGNORE]","DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM","DROP [TEMPORARY] TABLE [IF EXISTS]","ALTER TABLE","ADD [COLUMN]","{CHANGE | MODIFY} [COLUMN]","DROP [COLUMN]","RENAME [TO | AS]","RENAME COLUMN","ALTER [COLUMN]","{SET | DROP} DEFAULT","TRUNCATE [TABLE]","ALTER DATABASE","ALTER INSTANCE","ALTER RESOURCE GROUP","ALTER SEQUENCE","ALTER USER","ALTER VIEW","ANALYZE TABLE","CHECK TABLE","CHECKSUM TABLE","COMMIT","CREATE DATABASE","CREATE INDEX","CREATE RESOURCE GROUP","CREATE ROLE","CREATE SEQUENCE","CREATE USER","DEALLOCATE PREPARE","DESCRIBE","DROP DATABASE","DROP INDEX","DROP RESOURCE GROUP","DROP ROLE","DROP TABLESPACE","DROP USER","DROP VIEW","EXPLAIN","FLUSH","GRANT","IMPORT TABLE","INSTALL COMPONENT","INSTALL PLUGIN","KILL","LOAD DATA","LOCK INSTANCE FOR BACKUP","LOCK TABLES","OPTIMIZE TABLE","PREPARE","RELEASE SAVEPOINT","RENAME TABLE","RENAME USER","REPAIR TABLE","RESET","REVOKE","ROLLBACK","ROLLBACK TO SAVEPOINT","SAVEPOINT","SET CHARACTER SET","SET DEFAULT ROLE","SET NAMES","SET PASSWORD","SET RESOURCE GROUP","SET ROLE","SET TRANSACTION","SHOW","SHOW BINARY LOGS","SHOW BINLOG EVENTS","SHOW CHARACTER SET","SHOW COLLATION","SHOW COLUMNS","SHOW CREATE DATABASE","SHOW CREATE TABLE","SHOW CREATE USER","SHOW CREATE VIEW","SHOW DATABASES","SHOW ENGINE","SHOW ENGINES","SHOW ERRORS","SHOW EVENTS","SHOW GRANTS","SHOW INDEX","SHOW MASTER STATUS","SHOW OPEN TABLES","SHOW PLUGINS","SHOW PRIVILEGES","SHOW PROCESSLIST","SHOW PROFILE","SHOW PROFILES","SHOW STATUS","SHOW TABLE STATUS","SHOW TABLES","SHOW TRIGGERS","SHOW VARIABLES","SHOW WARNINGS","TABLE","UNINSTALL COMPONENT","UNINSTALL PLUGIN","UNLOCK INSTANCE","UNLOCK TABLES","USE"]),bc=x(["UNION [ALL | DISTINCT]"]),Vc=x(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),Wc=x(["ON {UPDATE | DELETE} [SET NULL]","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),Xc=x([]),jc={name:"tidb",tokenizerOptions:{reservedSelect:Yc,reservedClauses:[...wc,...bi,...sl],reservedSetOperations:bc,reservedJoins:Vc,reservedKeywordPhrases:Wc,reservedDataTypePhrases:Xc,supportsXor:!0,reservedKeywords:Hc,reservedDataTypes:Bc,reservedFunctionNames:Fc,stringTypes:['""-qq-bs',{quote:"''-qq-bs",prefixes:["N"]},{quote:"''-raw",prefixes:["B","X"],requirePrefix:!0}],identTypes:["``"],identChars:{first:"$",rest:"$",allowFirstCharNumber:!0},variableTypes:[{regex:"@@?[A-Za-z0-9_.$]+"},{quote:'""-qq-bs',prefixes:["@"],requirePrefix:!0},{quote:"''-qq-bs",prefixes:["@"],requirePrefix:!0},{quote:"``",prefixes:["@"],requirePrefix:!0}],paramTypes:{positional:!0},lineCommentTypes:["--","#"],operators:["%",":=","&","|","^","~","<<",">>","<=>","->","->>","&&","||","!","*.*"],postProcess:CT},formatOptions:{onelineClauses:[...bi,...sl],tabularOnelineClauses:sl}},kc=["ABORT","ABS","ACOS","ADVISOR","ARRAY_AGG","ARRAY_AGG","ARRAY_APPEND","ARRAY_AVG","ARRAY_BINARY_SEARCH","ARRAY_CONCAT","ARRAY_CONTAINS","ARRAY_COUNT","ARRAY_DISTINCT","ARRAY_EXCEPT","ARRAY_FLATTEN","ARRAY_IFNULL","ARRAY_INSERT","ARRAY_INTERSECT","ARRAY_LENGTH","ARRAY_MAX","ARRAY_MIN","ARRAY_MOVE","ARRAY_POSITION","ARRAY_PREPEND","ARRAY_PUT","ARRAY_RANGE","ARRAY_REMOVE","ARRAY_REPEAT","ARRAY_REPLACE","ARRAY_REVERSE","ARRAY_SORT","ARRAY_STAR","ARRAY_SUM","ARRAY_SYMDIFF","ARRAY_SYMDIFF1","ARRAY_SYMDIFFN","ARRAY_UNION","ASIN","ATAN","ATAN2","AVG","BASE64","BASE64_DECODE","BASE64_ENCODE","BITAND ","BITCLEAR ","BITNOT ","BITOR ","BITSET ","BITSHIFT ","BITTEST ","BITXOR ","CEIL","CLOCK_LOCAL","CLOCK_MILLIS","CLOCK_STR","CLOCK_TZ","CLOCK_UTC","COALESCE","CONCAT","CONCAT2","CONTAINS","CONTAINS_TOKEN","CONTAINS_TOKEN_LIKE","CONTAINS_TOKEN_REGEXP","COS","COUNT","COUNT","COUNTN","CUME_DIST","CURL","DATE_ADD_MILLIS","DATE_ADD_STR","DATE_DIFF_MILLIS","DATE_DIFF_STR","DATE_FORMAT_STR","DATE_PART_MILLIS","DATE_PART_STR","DATE_RANGE_MILLIS","DATE_RANGE_STR","DATE_TRUNC_MILLIS","DATE_TRUNC_STR","DECODE","DECODE_JSON","DEGREES","DENSE_RANK","DURATION_TO_STR","ENCODED_SIZE","ENCODE_JSON","EXP","FIRST_VALUE","FLOOR","GREATEST","HAS_TOKEN","IFINF","IFMISSING","IFMISSINGORNULL","IFNAN","IFNANORINF","IFNULL","INITCAP","ISARRAY","ISATOM","ISBITSET","ISBOOLEAN","ISNUMBER","ISOBJECT","ISSTRING","LAG","LAST_VALUE","LEAD","LEAST","LENGTH","LN","LOG","LOWER","LTRIM","MAX","MEAN","MEDIAN","META","MILLIS","MILLIS_TO_LOCAL","MILLIS_TO_STR","MILLIS_TO_TZ","MILLIS_TO_UTC","MILLIS_TO_ZONE_NAME","MIN","MISSINGIF","NANIF","NEGINFIF","NOW_LOCAL","NOW_MILLIS","NOW_STR","NOW_TZ","NOW_UTC","NTH_VALUE","NTILE","NULLIF","NVL","NVL2","OBJECT_ADD","OBJECT_CONCAT","OBJECT_INNER_PAIRS","OBJECT_INNER_VALUES","OBJECT_LENGTH","OBJECT_NAMES","OBJECT_PAIRS","OBJECT_PUT","OBJECT_REMOVE","OBJECT_RENAME","OBJECT_REPLACE","OBJECT_UNWRAP","OBJECT_VALUES","PAIRS","PERCENT_RANK","PI","POLY_LENGTH","POSINFIF","POSITION","POWER","RADIANS","RANDOM","RANK","RATIO_TO_REPORT","REGEXP_CONTAINS","REGEXP_LIKE","REGEXP_MATCHES","REGEXP_POSITION","REGEXP_REPLACE","REGEXP_SPLIT","REGEX_CONTAINS","REGEX_LIKE","REGEX_MATCHES","REGEX_POSITION","REGEX_REPLACE","REGEX_SPLIT","REPEAT","REPLACE","REVERSE","ROUND","ROW_NUMBER","RTRIM","SEARCH","SEARCH_META","SEARCH_SCORE","SIGN","SIN","SPLIT","SQRT","STDDEV","STDDEV_POP","STDDEV_SAMP","STR_TO_DURATION","STR_TO_MILLIS","STR_TO_TZ","STR_TO_UTC","STR_TO_ZONE_NAME","SUBSTR","SUFFIXES","SUM","TAN","TITLE","TOARRAY","TOATOM","TOBOOLEAN","TOKENS","TOKENS","TONUMBER","TOOBJECT","TOSTRING","TRIM","TRUNC","UPPER","UUID","VARIANCE","VARIANCE_POP","VARIANCE_SAMP","VAR_POP","VAR_SAMP","WEEKDAY_MILLIS","WEEKDAY_STR","CAST"],Kc=["ADVISE","ALL","ALTER","ANALYZE","AND","ANY","ARRAY","AS","ASC","AT","BEGIN","BETWEEN","BINARY","BOOLEAN","BREAK","BUCKET","BUILD","BY","CALL","CASE","CAST","CLUSTER","COLLATE","COLLECTION","COMMIT","COMMITTED","CONNECT","CONTINUE","CORRELATED","COVER","CREATE","CURRENT","DATABASE","DATASET","DATASTORE","DECLARE","DECREMENT","DELETE","DERIVED","DESC","DESCRIBE","DISTINCT","DO","DROP","EACH","ELEMENT","ELSE","END","EVERY","EXCEPT","EXCLUDE","EXECUTE","EXISTS","EXPLAIN","FALSE","FETCH","FILTER","FIRST","FLATTEN","FLUSH","FOLLOWING","FOR","FORCE","FROM","FTS","FUNCTION","GOLANG","GRANT","GROUP","GROUPS","GSI","HASH","HAVING","IF","IGNORE","ILIKE","IN","INCLUDE","INCREMENT","INDEX","INFER","INLINE","INNER","INSERT","INTERSECT","INTO","IS","ISOLATION","JAVASCRIPT","JOIN","KEY","KEYS","KEYSPACE","KNOWN","LANGUAGE","LAST","LEFT","LET","LETTING","LEVEL","LIKE","LIMIT","LSM","MAP","MAPPING","MATCHED","MATERIALIZED","MERGE","MINUS","MISSING","NAMESPACE","NEST","NL","NO","NOT","NTH_VALUE","NULL","NULLS","NUMBER","OBJECT","OFFSET","ON","OPTION","OPTIONS","OR","ORDER","OTHERS","OUTER","OVER","PARSE","PARTITION","PASSWORD","PATH","POOL","PRECEDING","PREPARE","PRIMARY","PRIVATE","PRIVILEGE","PROBE","PROCEDURE","PUBLIC","RANGE","RAW","REALM","REDUCE","RENAME","RESPECT","RETURN","RETURNING","REVOKE","RIGHT","ROLE","ROLLBACK","ROW","ROWS","SATISFIES","SAVEPOINT","SCHEMA","SCOPE","SELECT","SELF","SEMI","SET","SHOW","SOME","START","STATISTICS","STRING","SYSTEM","THEN","TIES","TO","TRAN","TRANSACTION","TRIGGER","TRUE","TRUNCATE","UNBOUNDED","UNDER","UNION","UNIQUE","UNKNOWN","UNNEST","UNSET","UPDATE","UPSERT","USE","USER","USING","VALIDATE","VALUE","VALUED","VALUES","VIA","VIEW","WHEN","WHERE","WHILE","WINDOW","WITH","WITHIN","WORK","XOR"],$c=[],Jc=x(["SELECT [ALL | DISTINCT]"]),zc=x(["WITH","FROM","WHERE","GROUP BY","HAVING","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","INSERT INTO","VALUES","SET","MERGE INTO","WHEN [NOT] MATCHED THEN","UPDATE SET","INSERT","NEST","UNNEST","RETURNING"]),Vi=x(["UPDATE","DELETE FROM","SET SCHEMA","ADVISE","ALTER INDEX","BEGIN TRANSACTION","BUILD INDEX","COMMIT TRANSACTION","CREATE COLLECTION","CREATE FUNCTION","CREATE INDEX","CREATE PRIMARY INDEX","CREATE SCOPE","DROP COLLECTION","DROP FUNCTION","DROP INDEX","DROP PRIMARY INDEX","DROP SCOPE","EXECUTE","EXECUTE FUNCTION","EXPLAIN","GRANT","INFER","PREPARE","REVOKE","ROLLBACK TRANSACTION","SAVEPOINT","SET TRANSACTION","UPDATE STATISTICS","UPSERT","LET","SET CURRENT SCHEMA","SHOW","USE [PRIMARY] KEYS"]),Qc=x(["UNION [ALL]","EXCEPT [ALL]","INTERSECT [ALL]"]),Zc=x(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","INNER JOIN"]),qc=x(["{ROWS | RANGE | GROUPS} BETWEEN"]),eC=x([]),tC={name:"n1ql",tokenizerOptions:{reservedSelect:Jc,reservedClauses:[...zc,...Vi],reservedSetOperations:Qc,reservedJoins:Zc,reservedKeywordPhrases:qc,reservedDataTypePhrases:eC,supportsXor:!0,reservedKeywords:Kc,reservedDataTypes:$c,reservedFunctionNames:kc,stringTypes:['""-bs',"''-bs"],identTypes:["``"],extraParens:["[]","{}"],paramTypes:{positional:!0,numbered:["$"],named:["$"]},lineCommentTypes:["#","--"],operators:["%","==",":","||"]},formatOptions:{onelineClauses:Vi}},EC=["ADD","AGENT","AGGREGATE","ALL","ALTER","AND","ANY","ARROW","AS","ASC","AT","ATTRIBUTE","AUTHID","AVG","BEGIN","BETWEEN","BLOCK","BODY","BOTH","BOUND","BULK","BY","BYTE","CALL","CALLING","CASCADE","CASE","CHARSET","CHARSETFORM","CHARSETID","CHECK","CLOSE","CLUSTER","CLUSTERS","COLAUTH","COLLECT","COLUMNS","COMMENT","COMMIT","COMMITTED","COMPILED","COMPRESS","CONNECT","CONSTANT","CONSTRUCTOR","CONTEXT","CONVERT","COUNT","CRASH","CREATE","CURRENT","CURSOR","CUSTOMDATUM","DANGLING","DATA","DAY","DECLARE","DEFAULT","DEFINE","DELETE","DESC","DETERMINISTIC","DISTINCT","DROP","DURATION","ELEMENT","ELSE","ELSIF","EMPTY","END","ESCAPE","EXCEPT","EXCEPTION","EXCEPTIONS","EXCLUSIVE","EXECUTE","EXISTS","EXIT","EXTERNAL","FETCH","FINAL","FIXED","FOR","FORALL","FORCE","FORM","FROM","FUNCTION","GENERAL","GOTO","GRANT","GROUP","HASH","HAVING","HEAP","HIDDEN","HOUR","IDENTIFIED","IF","IMMEDIATE","IN","INCLUDING","INDEX","INDEXES","INDICATOR","INDICES","INFINITE","INSERT","INSTANTIABLE","INTERFACE","INTERSECT","INTERVAL","INTO","INVALIDATE","IS","ISOLATION","JAVA","LANGUAGE","LARGE","LEADING","LENGTH","LEVEL","LIBRARY","LIKE","LIKE2","LIKE4","LIKEC","LIMIT","LIMITED","LOCAL","LOCK","LOOP","MAP","MAX","MAXLEN","MEMBER","MERGE","MIN","MINUS","MINUTE","MOD","MODE","MODIFY","MONTH","MULTISET","NAME","NAN","NATIONAL","NATIVE","NEW","NOCOMPRESS","NOCOPY","NOT","NOWAIT","NULL","OBJECT","OCICOLL","OCIDATE","OCIDATETIME","OCIDURATION","OCIINTERVAL","OCILOBLOCATOR","OCINUMBER","OCIRAW","OCIREF","OCIREFCURSOR","OCIROWID","OCISTRING","OCITYPE","OF","ON","ONLY","OPAQUE","OPEN","OPERATOR","OPTION","OR","ORACLE","ORADATA","ORDER","OVERLAPS","ORGANIZATION","ORLANY","ORLVARY","OTHERS","OUT","OVERRIDING","PACKAGE","PARALLEL_ENABLE","PARAMETER","PARAMETERS","PARTITION","PASCAL","PIPE","PIPELINED","PRAGMA","PRIOR","PRIVATE","PROCEDURE","PUBLIC","RAISE","RANGE","READ","RECORD","REF","REFERENCE","REM","REMAINDER","RENAME","RESOURCE","RESULT","RETURN","RETURNING","REVERSE","REVOKE","ROLLBACK","ROW","SAMPLE","SAVE","SAVEPOINT","SB1","SB2","SB4","SECOND","SEGMENT","SELECT","SELF","SEPARATE","SEQUENCE","SERIALIZABLE","SET","SHARE","SHORT","SIZE","SIZE_T","SOME","SPARSE","SQL","SQLCODE","SQLDATA","SQLNAME","SQLSTATE","STANDARD","START","STATIC","STDDEV","STORED","STRING","STRUCT","STYLE","SUBMULTISET","SUBPARTITION","SUBSTITUTABLE","SUBTYPE","SUM","SYNONYM","TABAUTH","TABLE","TDO","THE","THEN","TIME","TIMEZONE_ABBR","TIMEZONE_HOUR","TIMEZONE_MINUTE","TIMEZONE_REGION","TO","TRAILING","TRANSAC","TRANSACTIONAL","TRUSTED","TYPE","UB1","UB2","UB4","UNDER","UNION","UNIQUE","UNSIGNED","UNTRUSTED","UPDATE","USE","USING","VALIST","VALUE","VALUES","VARIABLE","VARIANCE","VARRAY","VIEW","VIEWS","VOID","WHEN","WHERE","WHILE","WITH","WORK","WRAPPED","WRITE","YEAR","ZONE"],nC=["ARRAY","BFILE_BASE","BINARY","BLOB_BASE","CHAR VARYING","CHAR_BASE","CHAR","CHARACTER VARYING","CHARACTER","CLOB_BASE","DATE_BASE","DATE","DECIMAL","DOUBLE","FLOAT","INT","INTERVAL DAY","INTERVAL YEAR","LONG","NATIONAL CHAR VARYING","NATIONAL CHAR","NATIONAL CHARACTER VARYING","NATIONAL CHARACTER","NCHAR VARYING","NCHAR","NCHAR","NUMBER_BASE","NUMBER","NUMBERIC","NVARCHAR","PRECISION","RAW","TIMESTAMP","UROWID","VARCHAR","VARCHAR2"],rC=["ABS","ACOS","ASIN","ATAN","ATAN2","BITAND","CEIL","COS","COSH","EXP","FLOOR","LN","LOG","MOD","NANVL","POWER","REMAINDER","ROUND","SIGN","SIN","SINH","SQRT","TAN","TANH","TRUNC","WIDTH_BUCKET","CHR","CONCAT","INITCAP","LOWER","LPAD","LTRIM","NLS_INITCAP","NLS_LOWER","NLSSORT","NLS_UPPER","REGEXP_REPLACE","REGEXP_SUBSTR","REPLACE","RPAD","RTRIM","SOUNDEX","SUBSTR","TRANSLATE","TREAT","TRIM","UPPER","NLS_CHARSET_DECL_LEN","NLS_CHARSET_ID","NLS_CHARSET_NAME","ASCII","INSTR","LENGTH","REGEXP_INSTR","ADD_MONTHS","CURRENT_DATE","CURRENT_TIMESTAMP","DBTIMEZONE","EXTRACT","FROM_TZ","LAST_DAY","LOCALTIMESTAMP","MONTHS_BETWEEN","NEW_TIME","NEXT_DAY","NUMTODSINTERVAL","NUMTOYMINTERVAL","ROUND","SESSIONTIMEZONE","SYS_EXTRACT_UTC","SYSDATE","SYSTIMESTAMP","TO_CHAR","TO_TIMESTAMP","TO_TIMESTAMP_TZ","TO_DSINTERVAL","TO_YMINTERVAL","TRUNC","TZ_OFFSET","GREATEST","LEAST","ASCIISTR","BIN_TO_NUM","CAST","CHARTOROWID","COMPOSE","CONVERT","DECOMPOSE","HEXTORAW","NUMTODSINTERVAL","NUMTOYMINTERVAL","RAWTOHEX","RAWTONHEX","ROWIDTOCHAR","ROWIDTONCHAR","SCN_TO_TIMESTAMP","TIMESTAMP_TO_SCN","TO_BINARY_DOUBLE","TO_BINARY_FLOAT","TO_CHAR","TO_CLOB","TO_DATE","TO_DSINTERVAL","TO_LOB","TO_MULTI_BYTE","TO_NCHAR","TO_NCLOB","TO_NUMBER","TO_DSINTERVAL","TO_SINGLE_BYTE","TO_TIMESTAMP","TO_TIMESTAMP_TZ","TO_YMINTERVAL","TO_YMINTERVAL","TRANSLATE","UNISTR","BFILENAME","EMPTY_BLOB,","EMPTY_CLOB","CARDINALITY","COLLECT","POWERMULTISET","POWERMULTISET_BY_CARDINALITY","SET","SYS_CONNECT_BY_PATH","CLUSTER_ID","CLUSTER_PROBABILITY","CLUSTER_SET","FEATURE_ID","FEATURE_SET","FEATURE_VALUE","PREDICTION","PREDICTION_COST","PREDICTION_DETAILS","PREDICTION_PROBABILITY","PREDICTION_SET","APPENDCHILDXML","DELETEXML","DEPTH","EXTRACT","EXISTSNODE","EXTRACTVALUE","INSERTCHILDXML","INSERTXMLBEFORE","PATH","SYS_DBURIGEN","SYS_XMLAGG","SYS_XMLGEN","UPDATEXML","XMLAGG","XMLCDATA","XMLCOLATTVAL","XMLCOMMENT","XMLCONCAT","XMLFOREST","XMLPARSE","XMLPI","XMLQUERY","XMLROOT","XMLSEQUENCE","XMLSERIALIZE","XMLTABLE","XMLTRANSFORM","DECODE","DUMP","ORA_HASH","VSIZE","COALESCE","LNNVL","NULLIF","NVL","NVL2","SYS_CONTEXT","SYS_GUID","SYS_TYPEID","UID","USER","USERENV","AVG","COLLECT","CORR","CORR_S","CORR_K","COUNT","COVAR_POP","COVAR_SAMP","CUME_DIST","DENSE_RANK","FIRST","GROUP_ID","GROUPING","GROUPING_ID","LAST","MAX","MEDIAN","MIN","PERCENTILE_CONT","PERCENTILE_DISC","PERCENT_RANK","RANK","REGR_SLOPE","REGR_INTERCEPT","REGR_COUNT","REGR_R2","REGR_AVGX","REGR_AVGY","REGR_SXX","REGR_SYY","REGR_SXY","STATS_BINOMIAL_TEST","STATS_CROSSTAB","STATS_F_TEST","STATS_KS_TEST","STATS_MODE","STATS_MW_TEST","STATS_ONE_WAY_ANOVA","STATS_T_TEST_ONE","STATS_T_TEST_PAIRED","STATS_T_TEST_INDEP","STATS_T_TEST_INDEPU","STATS_WSR_TEST","STDDEV","STDDEV_POP","STDDEV_SAMP","SUM","VAR_POP","VAR_SAMP","VARIANCE","FIRST_VALUE","LAG","LAST_VALUE","LEAD","NTILE","RATIO_TO_REPORT","ROW_NUMBER","DEREF","MAKE_REF","REF","REFTOHEX","VALUE","CV","ITERATION_NUMBER","PRESENTNNV","PRESENTV","PREVIOUS"],sC=x(["SELECT [ALL | DISTINCT | UNIQUE]"]),TC=x(["WITH","FROM","WHERE","GROUP BY","HAVING","PARTITION BY","ORDER [SIBLINGS] BY","OFFSET","FETCH {FIRST | NEXT}","FOR UPDATE [OF]","INSERT [INTO | ALL INTO]","VALUES","SET","MERGE [INTO]","WHEN [NOT] MATCHED [THEN]","UPDATE SET","RETURNING"]),Wi=x(["CREATE [GLOBAL TEMPORARY | PRIVATE TEMPORARY | SHARDED | DUPLICATED | IMMUTABLE BLOCKCHAIN | BLOCKCHAIN | IMMUTABLE] TABLE"]),Tl=x(["CREATE [OR REPLACE] [NO FORCE | FORCE] [EDITIONING | EDITIONABLE | EDITIONABLE EDITIONING | NONEDITIONABLE] VIEW","CREATE MATERIALIZED VIEW","UPDATE [ONLY]","DELETE FROM [ONLY]","DROP TABLE","ALTER TABLE","ADD","DROP {COLUMN | UNUSED COLUMNS | COLUMNS CONTINUE}","MODIFY","RENAME TO","RENAME COLUMN","TRUNCATE TABLE","SET SCHEMA","BEGIN","CONNECT BY","DECLARE","EXCEPT","EXCEPTION","LOOP","START WITH"]),lC=x(["UNION [ALL]","MINUS","INTERSECT"]),aC=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN","{CROSS | OUTER} APPLY"]),oC=x(["ON {UPDATE | DELETE} [SET NULL]","ON COMMIT","{ROWS | RANGE} BETWEEN"]),iC=x([]),RC={name:"plsql",tokenizerOptions:{reservedSelect:sC,reservedClauses:[...TC,...Wi,...Tl],reservedSetOperations:lC,reservedJoins:aC,reservedKeywordPhrases:oC,reservedDataTypePhrases:iC,supportsXor:!0,reservedKeywords:EC,reservedDataTypes:nC,reservedFunctionNames:rC,stringTypes:[{quote:"''-qq",prefixes:["N"]},{quote:"q''",prefixes:["N"]}],identTypes:['""-qq'],identChars:{rest:"$#"},variableTypes:[{regex:"&{1,2}[A-Za-z][A-Za-z0-9_$#]*"}],paramTypes:{numbered:[":"],named:[":"]},operators:["**",":=","%","~=","^=",">>","<<","=>","@","||"],postProcess:AC},formatOptions:{alwaysDenseOperators:["@"],onelineClauses:[...Wi,...Tl],tabularOnelineClauses:Tl}};function AC(e){let t=kn;return e.map(E=>An.SET(E)&&An.BY(t)?Object.assign(Object.assign({},E),{type:V.RESERVED_KEYWORD}):(HS(E.type)&&(t=E),E))}const SC=["ABS","ACOS","ACOSD","ACOSH","ASIN","ASIND","ASINH","ATAN","ATAN2","ATAN2D","ATAND","ATANH","CBRT","CEIL","CEILING","COS","COSD","COSH","COT","COTD","DEGREES","DIV","EXP","FACTORIAL","FLOOR","GCD","LCM","LN","LOG","LOG10","MIN_SCALE","MOD","PI","POWER","RADIANS","RANDOM","ROUND","SCALE","SETSEED","SIGN","SIN","SIND","SINH","SQRT","TAN","TAND","TANH","TRIM_SCALE","TRUNC","WIDTH_BUCKET","ABS","ASCII","BIT_LENGTH","BTRIM","CHARACTER_LENGTH","CHAR_LENGTH","CHR","CONCAT","CONCAT_WS","FORMAT","INITCAP","LEFT","LENGTH","LOWER","LPAD","LTRIM","MD5","NORMALIZE","OCTET_LENGTH","OVERLAY","PARSE_IDENT","PG_CLIENT_ENCODING","POSITION","QUOTE_IDENT","QUOTE_LITERAL","QUOTE_NULLABLE","REGEXP_MATCH","REGEXP_MATCHES","REGEXP_REPLACE","REGEXP_SPLIT_TO_ARRAY","REGEXP_SPLIT_TO_TABLE","REPEAT","REPLACE","REVERSE","RIGHT","RPAD","RTRIM","SPLIT_PART","SPRINTF","STARTS_WITH","STRING_AGG","STRING_TO_ARRAY","STRING_TO_TABLE","STRPOS","SUBSTR","SUBSTRING","TO_ASCII","TO_HEX","TRANSLATE","TRIM","UNISTR","UPPER","BIT_COUNT","BIT_LENGTH","BTRIM","CONVERT","CONVERT_FROM","CONVERT_TO","DECODE","ENCODE","GET_BIT","GET_BYTE","LENGTH","LTRIM","MD5","OCTET_LENGTH","OVERLAY","POSITION","RTRIM","SET_BIT","SET_BYTE","SHA224","SHA256","SHA384","SHA512","STRING_AGG","SUBSTR","SUBSTRING","TRIM","BIT_COUNT","BIT_LENGTH","GET_BIT","LENGTH","OCTET_LENGTH","OVERLAY","POSITION","SET_BIT","SUBSTRING","REGEXP_MATCH","REGEXP_MATCHES","REGEXP_REPLACE","REGEXP_SPLIT_TO_ARRAY","REGEXP_SPLIT_TO_TABLE","TO_CHAR","TO_DATE","TO_NUMBER","TO_TIMESTAMP","CLOCK_TIMESTAMP","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP","DATE_BIN","DATE_PART","DATE_TRUNC","EXTRACT","ISFINITE","JUSTIFY_DAYS","JUSTIFY_HOURS","JUSTIFY_INTERVAL","LOCALTIME","LOCALTIMESTAMP","MAKE_DATE","MAKE_INTERVAL","MAKE_TIME","MAKE_TIMESTAMP","MAKE_TIMESTAMPTZ","NOW","PG_SLEEP","PG_SLEEP_FOR","PG_SLEEP_UNTIL","STATEMENT_TIMESTAMP","TIMEOFDAY","TO_TIMESTAMP","TRANSACTION_TIMESTAMP","ENUM_FIRST","ENUM_LAST","ENUM_RANGE","AREA","BOUND_BOX","BOX","CENTER","CIRCLE","DIAGONAL","DIAMETER","HEIGHT","ISCLOSED","ISOPEN","LENGTH","LINE","LSEG","NPOINTS","PATH","PCLOSE","POINT","POLYGON","POPEN","RADIUS","SLOPE","WIDTH","ABBREV","BROADCAST","FAMILY","HOST","HOSTMASK","INET_MERGE","INET_SAME_FAMILY","MACADDR8_SET7BIT","MASKLEN","NETMASK","NETWORK","SET_MASKLEN","TRUNC","ARRAY_TO_TSVECTOR","GET_CURRENT_TS_CONFIG","JSONB_TO_TSVECTOR","JSON_TO_TSVECTOR","LENGTH","NUMNODE","PHRASETO_TSQUERY","PLAINTO_TSQUERY","QUERYTREE","SETWEIGHT","STRIP","TO_TSQUERY","TO_TSVECTOR","TSQUERY_PHRASE","TSVECTOR_TO_ARRAY","TS_DEBUG","TS_DELETE","TS_FILTER","TS_HEADLINE","TS_LEXIZE","TS_PARSE","TS_RANK","TS_RANK_CD","TS_REWRITE","TS_STAT","TS_TOKEN_TYPE","WEBSEARCH_TO_TSQUERY","GEN_RANDOM_UUID","UUIDV4","UUIDV7","UUID_EXTRACT_TIMESTAMP","UUID_EXTRACT_VERSION","CURSOR_TO_XML","CURSOR_TO_XMLSCHEMA","DATABASE_TO_XML","DATABASE_TO_XMLSCHEMA","DATABASE_TO_XML_AND_XMLSCHEMA","NEXTVAL","QUERY_TO_XML","QUERY_TO_XMLSCHEMA","QUERY_TO_XML_AND_XMLSCHEMA","SCHEMA_TO_XML","SCHEMA_TO_XMLSCHEMA","SCHEMA_TO_XML_AND_XMLSCHEMA","STRING","TABLE_TO_XML","TABLE_TO_XMLSCHEMA","TABLE_TO_XML_AND_XMLSCHEMA","XMLAGG","XMLCOMMENT","XMLCONCAT","XMLELEMENT","XMLEXISTS","XMLFOREST","XMLPARSE","XMLPI","XMLROOT","XMLSERIALIZE","XMLTABLE","XML_IS_WELL_FORMED","XML_IS_WELL_FORMED_CONTENT","XML_IS_WELL_FORMED_DOCUMENT","XPATH","XPATH_EXISTS","ARRAY_TO_JSON","JSONB_AGG","JSONB_ARRAY_ELEMENTS","JSONB_ARRAY_ELEMENTS_TEXT","JSONB_ARRAY_LENGTH","JSONB_BUILD_ARRAY","JSONB_BUILD_OBJECT","JSONB_EACH","JSONB_EACH_TEXT","JSONB_EXTRACT_PATH","JSONB_EXTRACT_PATH_TEXT","JSONB_INSERT","JSONB_OBJECT","JSONB_OBJECT_AGG","JSONB_OBJECT_KEYS","JSONB_PATH_EXISTS","JSONB_PATH_EXISTS_TZ","JSONB_PATH_MATCH","JSONB_PATH_MATCH_TZ","JSONB_PATH_QUERY","JSONB_PATH_QUERY_ARRAY","JSONB_PATH_QUERY_ARRAY_TZ","JSONB_PATH_QUERY_FIRST","JSONB_PATH_QUERY_FIRST_TZ","JSONB_PATH_QUERY_TZ","JSONB_POPULATE_RECORD","JSONB_POPULATE_RECORDSET","JSONB_PRETTY","JSONB_SET","JSONB_SET_LAX","JSONB_STRIP_NULLS","JSONB_TO_RECORD","JSONB_TO_RECORDSET","JSONB_TYPEOF","JSON_AGG","JSON_ARRAY_ELEMENTS","JSON_ARRAY_ELEMENTS_TEXT","JSON_ARRAY_LENGTH","JSON_BUILD_ARRAY","JSON_BUILD_OBJECT","JSON_EACH","JSON_EACH_TEXT","JSON_EXTRACT_PATH","JSON_EXTRACT_PATH_TEXT","JSON_OBJECT","JSON_OBJECT_AGG","JSON_OBJECT_KEYS","JSON_POPULATE_RECORD","JSON_POPULATE_RECORDSET","JSON_STRIP_NULLS","JSON_TO_RECORD","JSON_TO_RECORDSET","JSON_TYPEOF","ROW_TO_JSON","TO_JSON","TO_JSONB","TO_TIMESTAMP","CURRVAL","LASTVAL","NEXTVAL","SETVAL","COALESCE","GREATEST","LEAST","NULLIF","ARRAY_AGG","ARRAY_APPEND","ARRAY_CAT","ARRAY_DIMS","ARRAY_FILL","ARRAY_LENGTH","ARRAY_LOWER","ARRAY_NDIMS","ARRAY_POSITION","ARRAY_POSITIONS","ARRAY_PREPEND","ARRAY_REMOVE","ARRAY_REPLACE","ARRAY_TO_STRING","ARRAY_UPPER","CARDINALITY","STRING_TO_ARRAY","TRIM_ARRAY","UNNEST","ISEMPTY","LOWER","LOWER_INC","LOWER_INF","MULTIRANGE","RANGE_MERGE","UPPER","UPPER_INC","UPPER_INF","ARRAY_AGG","AVG","BIT_AND","BIT_OR","BIT_XOR","BOOL_AND","BOOL_OR","COALESCE","CORR","COUNT","COVAR_POP","COVAR_SAMP","CUME_DIST","DENSE_RANK","EVERY","GROUPING","JSONB_AGG","JSONB_OBJECT_AGG","JSON_AGG","JSON_OBJECT_AGG","MAX","MIN","MODE","PERCENTILE_CONT","PERCENTILE_DISC","PERCENT_RANK","RANGE_AGG","RANGE_INTERSECT_AGG","RANK","REGR_AVGX","REGR_AVGY","REGR_COUNT","REGR_INTERCEPT","REGR_R2","REGR_SLOPE","REGR_SXX","REGR_SXY","REGR_SYY","STDDEV","STDDEV_POP","STDDEV_SAMP","STRING_AGG","SUM","TO_JSON","TO_JSONB","VARIANCE","VAR_POP","VAR_SAMP","XMLAGG","CUME_DIST","DENSE_RANK","FIRST_VALUE","LAG","LAST_VALUE","LEAD","NTH_VALUE","NTILE","PERCENT_RANK","RANK","ROW_NUMBER","GENERATE_SERIES","GENERATE_SUBSCRIPTS","ACLDEFAULT","ACLEXPLODE","COL_DESCRIPTION","CURRENT_CATALOG","CURRENT_DATABASE","CURRENT_QUERY","CURRENT_ROLE","CURRENT_SCHEMA","CURRENT_SCHEMAS","CURRENT_USER","FORMAT_TYPE","HAS_ANY_COLUMN_PRIVILEGE","HAS_COLUMN_PRIVILEGE","HAS_DATABASE_PRIVILEGE","HAS_FOREIGN_DATA_WRAPPER_PRIVILEGE","HAS_FUNCTION_PRIVILEGE","HAS_LANGUAGE_PRIVILEGE","HAS_SCHEMA_PRIVILEGE","HAS_SEQUENCE_PRIVILEGE","HAS_SERVER_PRIVILEGE","HAS_TABLESPACE_PRIVILEGE","HAS_TABLE_PRIVILEGE","HAS_TYPE_PRIVILEGE","INET_CLIENT_ADDR","INET_CLIENT_PORT","INET_SERVER_ADDR","INET_SERVER_PORT","MAKEACLITEM","OBJ_DESCRIPTION","PG_BACKEND_PID","PG_BLOCKING_PIDS","PG_COLLATION_IS_VISIBLE","PG_CONF_LOAD_TIME","PG_CONTROL_CHECKPOINT","PG_CONTROL_INIT","PG_CONTROL_SYSTEM","PG_CONVERSION_IS_VISIBLE","PG_CURRENT_LOGFILE","PG_CURRENT_SNAPSHOT","PG_CURRENT_XACT_ID","PG_CURRENT_XACT_ID_IF_ASSIGNED","PG_DESCRIBE_OBJECT","PG_FUNCTION_IS_VISIBLE","PG_GET_CATALOG_FOREIGN_KEYS","PG_GET_CONSTRAINTDEF","PG_GET_EXPR","PG_GET_FUNCTIONDEF","PG_GET_FUNCTION_ARGUMENTS","PG_GET_FUNCTION_IDENTITY_ARGUMENTS","PG_GET_FUNCTION_RESULT","PG_GET_INDEXDEF","PG_GET_KEYWORDS","PG_GET_OBJECT_ADDRESS","PG_GET_OWNED_SEQUENCE","PG_GET_RULEDEF","PG_GET_SERIAL_SEQUENCE","PG_GET_STATISTICSOBJDEF","PG_GET_TRIGGERDEF","PG_GET_USERBYID","PG_GET_VIEWDEF","PG_HAS_ROLE","PG_IDENTIFY_OBJECT","PG_IDENTIFY_OBJECT_AS_ADDRESS","PG_INDEXAM_HAS_PROPERTY","PG_INDEX_COLUMN_HAS_PROPERTY","PG_INDEX_HAS_PROPERTY","PG_IS_OTHER_TEMP_SCHEMA","PG_JIT_AVAILABLE","PG_LAST_COMMITTED_XACT","PG_LISTENING_CHANNELS","PG_MY_TEMP_SCHEMA","PG_NOTIFICATION_QUEUE_USAGE","PG_OPCLASS_IS_VISIBLE","PG_OPERATOR_IS_VISIBLE","PG_OPFAMILY_IS_VISIBLE","PG_OPTIONS_TO_TABLE","PG_POSTMASTER_START_TIME","PG_SAFE_SNAPSHOT_BLOCKING_PIDS","PG_SNAPSHOT_XIP","PG_SNAPSHOT_XMAX","PG_SNAPSHOT_XMIN","PG_STATISTICS_OBJ_IS_VISIBLE","PG_TABLESPACE_DATABASES","PG_TABLESPACE_LOCATION","PG_TABLE_IS_VISIBLE","PG_TRIGGER_DEPTH","PG_TS_CONFIG_IS_VISIBLE","PG_TS_DICT_IS_VISIBLE","PG_TS_PARSER_IS_VISIBLE","PG_TS_TEMPLATE_IS_VISIBLE","PG_TYPEOF","PG_TYPE_IS_VISIBLE","PG_VISIBLE_IN_SNAPSHOT","PG_XACT_COMMIT_TIMESTAMP","PG_XACT_COMMIT_TIMESTAMP_ORIGIN","PG_XACT_STATUS","PQSERVERVERSION","ROW_SECURITY_ACTIVE","SESSION_USER","SHOBJ_DESCRIPTION","TO_REGCLASS","TO_REGCOLLATION","TO_REGNAMESPACE","TO_REGOPER","TO_REGOPERATOR","TO_REGPROC","TO_REGPROCEDURE","TO_REGROLE","TO_REGTYPE","TXID_CURRENT","TXID_CURRENT_IF_ASSIGNED","TXID_CURRENT_SNAPSHOT","TXID_SNAPSHOT_XIP","TXID_SNAPSHOT_XMAX","TXID_SNAPSHOT_XMIN","TXID_STATUS","TXID_VISIBLE_IN_SNAPSHOT","USER","VERSION","BRIN_DESUMMARIZE_RANGE","BRIN_SUMMARIZE_NEW_VALUES","BRIN_SUMMARIZE_RANGE","CONVERT_FROM","CURRENT_SETTING","GIN_CLEAN_PENDING_LIST","PG_ADVISORY_LOCK","PG_ADVISORY_LOCK_SHARED","PG_ADVISORY_UNLOCK","PG_ADVISORY_UNLOCK_ALL","PG_ADVISORY_UNLOCK_SHARED","PG_ADVISORY_XACT_LOCK","PG_ADVISORY_XACT_LOCK_SHARED","PG_BACKUP_START_TIME","PG_CANCEL_BACKEND","PG_COLLATION_ACTUAL_VERSION","PG_COLUMN_COMPRESSION","PG_COLUMN_SIZE","PG_COPY_LOGICAL_REPLICATION_SLOT","PG_COPY_PHYSICAL_REPLICATION_SLOT","PG_CREATE_LOGICAL_REPLICATION_SLOT","PG_CREATE_PHYSICAL_REPLICATION_SLOT","PG_CREATE_RESTORE_POINT","PG_CURRENT_WAL_FLUSH_LSN","PG_CURRENT_WAL_INSERT_LSN","PG_CURRENT_WAL_LSN","PG_DATABASE_SIZE","PG_DROP_REPLICATION_SLOT","PG_EXPORT_SNAPSHOT","PG_FILENODE_RELATION","PG_GET_WAL_REPLAY_PAUSE_STATE","PG_IMPORT_SYSTEM_COLLATIONS","PG_INDEXES_SIZE","PG_IS_IN_BACKUP","PG_IS_IN_RECOVERY","PG_IS_WAL_REPLAY_PAUSED","PG_LAST_WAL_RECEIVE_LSN","PG_LAST_WAL_REPLAY_LSN","PG_LAST_XACT_REPLAY_TIMESTAMP","PG_LOGICAL_EMIT_MESSAGE","PG_LOGICAL_SLOT_GET_BINARY_CHANGES","PG_LOGICAL_SLOT_GET_CHANGES","PG_LOGICAL_SLOT_PEEK_BINARY_CHANGES","PG_LOGICAL_SLOT_PEEK_CHANGES","PG_LOG_BACKEND_MEMORY_CONTEXTS","PG_LS_ARCHIVE_STATUSDIR","PG_LS_DIR","PG_LS_LOGDIR","PG_LS_TMPDIR","PG_LS_WALDIR","PG_PARTITION_ANCESTORS","PG_PARTITION_ROOT","PG_PARTITION_TREE","PG_PROMOTE","PG_READ_BINARY_FILE","PG_READ_FILE","PG_RELATION_FILENODE","PG_RELATION_FILEPATH","PG_RELATION_SIZE","PG_RELOAD_CONF","PG_REPLICATION_ORIGIN_ADVANCE","PG_REPLICATION_ORIGIN_CREATE","PG_REPLICATION_ORIGIN_DROP","PG_REPLICATION_ORIGIN_OID","PG_REPLICATION_ORIGIN_PROGRESS","PG_REPLICATION_ORIGIN_SESSION_IS_SETUP","PG_REPLICATION_ORIGIN_SESSION_PROGRESS","PG_REPLICATION_ORIGIN_SESSION_RESET","PG_REPLICATION_ORIGIN_SESSION_SETUP","PG_REPLICATION_ORIGIN_XACT_RESET","PG_REPLICATION_ORIGIN_XACT_SETUP","PG_REPLICATION_SLOT_ADVANCE","PG_ROTATE_LOGFILE","PG_SIZE_BYTES","PG_SIZE_PRETTY","PG_START_BACKUP","PG_STAT_FILE","PG_STOP_BACKUP","PG_SWITCH_WAL","PG_TABLESPACE_SIZE","PG_TABLE_SIZE","PG_TERMINATE_BACKEND","PG_TOTAL_RELATION_SIZE","PG_TRY_ADVISORY_LOCK","PG_TRY_ADVISORY_LOCK_SHARED","PG_TRY_ADVISORY_XACT_LOCK","PG_TRY_ADVISORY_XACT_LOCK_SHARED","PG_WALFILE_NAME","PG_WALFILE_NAME_OFFSET","PG_WAL_LSN_DIFF","PG_WAL_REPLAY_PAUSE","PG_WAL_REPLAY_RESUME","SET_CONFIG","SUPPRESS_REDUNDANT_UPDATES_TRIGGER","TSVECTOR_UPDATE_TRIGGER","TSVECTOR_UPDATE_TRIGGER_COLUMN","PG_EVENT_TRIGGER_DDL_COMMANDS","PG_EVENT_TRIGGER_DROPPED_OBJECTS","PG_EVENT_TRIGGER_TABLE_REWRITE_OID","PG_EVENT_TRIGGER_TABLE_REWRITE_REASON","PG_GET_OBJECT_ADDRESS","PG_MCV_LIST_ITEMS","CAST"],NC=["ALL","ANALYSE","ANALYZE","AND","ANY","AS","ASC","ASYMMETRIC","AUTHORIZATION","BETWEEN","BINARY","BOTH","CASE","CAST","CHECK","COLLATE","COLLATION","COLUMN","CONCURRENTLY","CONSTRAINT","CREATE","CROSS","CURRENT_CATALOG","CURRENT_DATE","CURRENT_ROLE","CURRENT_SCHEMA","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","DAY","DEFAULT","DEFERRABLE","DESC","DISTINCT","DO","ELSE","END","EXCEPT","EXISTS","FALSE","FETCH","FILTER","FOR","FOREIGN","FREEZE","FROM","FULL","GRANT","GROUP","HAVING","HOUR","ILIKE","IN","INITIALLY","INNER","INOUT","INTERSECT","INTO","IS","ISNULL","JOIN","LATERAL","LEADING","LEFT","LIKE","LIMIT","LOCALTIME","LOCALTIMESTAMP","MINUTE","MONTH","NATURAL","NOT","NOTNULL","NULL","NULLIF","OFFSET","ON","ONLY","OR","ORDER","OUT","OUTER","OVER","OVERLAPS","PLACING","PRIMARY","REFERENCES","RETURNING","RIGHT","ROW","SECOND","SELECT","SESSION_USER","SIMILAR","SOME","SYMMETRIC","TABLE","TABLESAMPLE","THEN","TO","TRAILING","TRUE","UNION","UNIQUE","USER","USING","VALUES","VARIADIC","VERBOSE","WHEN","WHERE","WINDOW","WITH","WITHIN","WITHOUT","YEAR"],IC=["ARRAY","BIGINT","BIT","BIT VARYING","BOOL","BOOLEAN","CHAR","CHARACTER","CHARACTER VARYING","DECIMAL","DEC","DOUBLE","ENUM","FLOAT","INT","INTEGER","INTERVAL","NCHAR","NUMERIC","JSON","JSONB","PRECISION","REAL","SMALLINT","TEXT","TIME","TIMESTAMP","TIMESTAMPTZ","UUID","VARCHAR","XML","ZONE"],uC=x(["SELECT [ALL | DISTINCT]"]),OC=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY [ALL | DISTINCT]","HAVING","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","FETCH {FIRST | NEXT}","FOR {UPDATE | NO KEY UPDATE | SHARE | KEY SHARE} [OF]","INSERT INTO","VALUES","DEFAULT VALUES","SET","RETURNING"]),Xi=x(["CREATE [GLOBAL | LOCAL] [TEMPORARY | TEMP | UNLOGGED] TABLE [IF NOT EXISTS]"]),ll=x(["CREATE [OR REPLACE] [TEMP | TEMPORARY] [RECURSIVE] VIEW","CREATE [MATERIALIZED] VIEW [IF NOT EXISTS]","UPDATE [ONLY]","WHERE CURRENT OF","ON CONFLICT","DELETE FROM [ONLY]","DROP TABLE [IF EXISTS]","ALTER TABLE [IF EXISTS] [ONLY]","ALTER TABLE ALL IN TABLESPACE","RENAME [COLUMN]","RENAME TO","ADD [COLUMN] [IF NOT EXISTS]","DROP [COLUMN] [IF EXISTS]","ALTER [COLUMN]","SET DATA TYPE","{SET | DROP} DEFAULT","{SET | DROP} NOT NULL","TRUNCATE [TABLE] [ONLY]","SET SCHEMA","AFTER","ABORT","ALTER AGGREGATE","ALTER COLLATION","ALTER CONVERSION","ALTER DATABASE","ALTER DEFAULT PRIVILEGES","ALTER DOMAIN","ALTER EVENT TRIGGER","ALTER EXTENSION","ALTER FOREIGN DATA WRAPPER","ALTER FOREIGN TABLE","ALTER FUNCTION","ALTER GROUP","ALTER INDEX","ALTER LANGUAGE","ALTER LARGE OBJECT","ALTER MATERIALIZED VIEW","ALTER OPERATOR","ALTER OPERATOR CLASS","ALTER OPERATOR FAMILY","ALTER POLICY","ALTER PROCEDURE","ALTER PUBLICATION","ALTER ROLE","ALTER ROUTINE","ALTER RULE","ALTER SCHEMA","ALTER SEQUENCE","ALTER SERVER","ALTER STATISTICS","ALTER SUBSCRIPTION","ALTER SYSTEM","ALTER TABLESPACE","ALTER TEXT SEARCH CONFIGURATION","ALTER TEXT SEARCH DICTIONARY","ALTER TEXT SEARCH PARSER","ALTER TEXT SEARCH TEMPLATE","ALTER TRIGGER","ALTER TYPE","ALTER USER","ALTER USER MAPPING","ALTER VIEW","ANALYZE","BEGIN","CALL","CHECKPOINT","CLOSE","CLUSTER","COMMENT ON","COMMIT","COMMIT PREPARED","COPY","CREATE ACCESS METHOD","CREATE [OR REPLACE] AGGREGATE","CREATE CAST","CREATE COLLATION","CREATE [DEFAULT] CONVERSION","CREATE DATABASE","CREATE DOMAIN","CREATE EVENT TRIGGER","CREATE EXTENSION","CREATE FOREIGN DATA WRAPPER","CREATE FOREIGN TABLE","CREATE [OR REPLACE] FUNCTION","CREATE GROUP","CREATE [UNIQUE] INDEX","CREATE [OR REPLACE] [TRUSTED] [PROCEDURAL] LANGUAGE","CREATE OPERATOR","CREATE OPERATOR CLASS","CREATE OPERATOR FAMILY","CREATE POLICY","CREATE [OR REPLACE] PROCEDURE","CREATE PUBLICATION","CREATE ROLE","CREATE [OR REPLACE] RULE","CREATE SCHEMA [AUTHORIZATION]","CREATE [TEMPORARY | TEMP | UNLOGGED] SEQUENCE","CREATE SERVER","CREATE STATISTICS","CREATE SUBSCRIPTION","CREATE TABLESPACE","CREATE TEXT SEARCH CONFIGURATION","CREATE TEXT SEARCH DICTIONARY","CREATE TEXT SEARCH PARSER","CREATE TEXT SEARCH TEMPLATE","CREATE [OR REPLACE] TRANSFORM","CREATE [OR REPLACE] [CONSTRAINT] TRIGGER","CREATE TYPE","CREATE USER","CREATE USER MAPPING","DEALLOCATE","DECLARE","DISCARD","DROP ACCESS METHOD","DROP AGGREGATE","DROP CAST","DROP COLLATION","DROP CONVERSION","DROP DATABASE","DROP DOMAIN","DROP EVENT TRIGGER","DROP EXTENSION","DROP FOREIGN DATA WRAPPER","DROP FOREIGN TABLE","DROP FUNCTION","DROP GROUP","DROP IDENTITY","DROP INDEX","DROP LANGUAGE","DROP MATERIALIZED VIEW [IF EXISTS]","DROP OPERATOR","DROP OPERATOR CLASS","DROP OPERATOR FAMILY","DROP OWNED","DROP POLICY","DROP PROCEDURE","DROP PUBLICATION","DROP ROLE","DROP ROUTINE","DROP RULE","DROP SCHEMA","DROP SEQUENCE","DROP SERVER","DROP STATISTICS","DROP SUBSCRIPTION","DROP TABLESPACE","DROP TEXT SEARCH CONFIGURATION","DROP TEXT SEARCH DICTIONARY","DROP TEXT SEARCH PARSER","DROP TEXT SEARCH TEMPLATE","DROP TRANSFORM","DROP TRIGGER","DROP TYPE","DROP USER","DROP USER MAPPING","DROP VIEW","EXECUTE","EXPLAIN","FETCH","GRANT","IMPORT FOREIGN SCHEMA","LISTEN","LOAD","LOCK","MOVE","NOTIFY","OVERRIDING SYSTEM VALUE","PREPARE","PREPARE TRANSACTION","REASSIGN OWNED","REFRESH MATERIALIZED VIEW","REINDEX","RELEASE SAVEPOINT","RESET [ALL|ROLE|SESSION AUTHORIZATION]","REVOKE","ROLLBACK","ROLLBACK PREPARED","ROLLBACK TO SAVEPOINT","SAVEPOINT","SECURITY LABEL","SELECT INTO","SET CONSTRAINTS","SET ROLE","SET SESSION AUTHORIZATION","SET TRANSACTION","SHOW","START TRANSACTION","UNLISTEN","VACUUM"]),cC=x(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),CC=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),dC=x(["PRIMARY KEY","GENERATED {ALWAYS | BY DEFAULT} AS IDENTITY","ON {UPDATE | DELETE} [NO ACTION | RESTRICT | CASCADE | SET NULL | SET DEFAULT]","DO {NOTHING | UPDATE}","AS MATERIALIZED","{ROWS | RANGE | GROUPS} BETWEEN","IS [NOT] DISTINCT FROM","NULLS {FIRST | LAST}","WITH ORDINALITY"]),LC=x(["[TIMESTAMP | TIME] {WITH | WITHOUT} TIME ZONE"]),_C={name:"postgresql",tokenizerOptions:{reservedSelect:uC,reservedClauses:[...OC,...Xi,...ll],reservedSetOperations:cC,reservedJoins:CC,reservedKeywordPhrases:dC,reservedDataTypePhrases:LC,reservedKeywords:NC,reservedDataTypes:IC,reservedFunctionNames:SC,nestedBlockComments:!0,extraParens:["[]"],underscoresInNumbers:!0,stringTypes:["$$",{quote:"''-qq",prefixes:["U&"]},{quote:"''-qq-bs",prefixes:["E"],requirePrefix:!0},{quote:"''-raw",prefixes:["B","X"],requirePrefix:!0}],identTypes:[{quote:'""-qq',prefixes:["U&"]}],identChars:{rest:"$"},paramTypes:{numbered:["$"]},operators:["%","^","|/","||/","@",":=","&","|","#","~","<<",">>","~>~","~<~","~>=~","~<=~","@-@","@@","##","<->","&&","&<","&>","<<|","&<|","|>>","|&>","<^","^>","?#","?-","?|","?-|","?||","@>","<@","~=","?","@?","?&","->","->>","#>","#>>","#-","=>",">>=","<<=","~~","~~*","!~~","!~~*","~","~*","!~","!~*","-|-","||","@@@","!!","^@","<%","%>","<<%","%>>","<<->","<->>","<<<->","<->>>","::",":","<#>","<=>","<+>","<~>","<%>"],operatorKeyword:!0},formatOptions:{alwaysDenseOperators:["::",":"],onelineClauses:[...Xi,...ll],tabularOnelineClauses:ll}},fC=["ANY_VALUE","APPROXIMATE PERCENTILE_DISC","AVG","COUNT","LISTAGG","MAX","MEDIAN","MIN","PERCENTILE_CONT","STDDEV_SAMP","STDDEV_POP","SUM","VAR_SAMP","VAR_POP","array_concat","array_flatten","get_array_length","split_to_array","subarray","BIT_AND","BIT_OR","BOOL_AND","BOOL_OR","COALESCE","DECODE","GREATEST","LEAST","NVL","NVL2","NULLIF","ADD_MONTHS","AT TIME ZONE","CONVERT_TIMEZONE","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP","DATE_CMP","DATE_CMP_TIMESTAMP","DATE_CMP_TIMESTAMPTZ","DATE_PART_YEAR","DATEADD","DATEDIFF","DATE_PART","DATE_TRUNC","EXTRACT","GETDATE","INTERVAL_CMP","LAST_DAY","MONTHS_BETWEEN","NEXT_DAY","SYSDATE","TIMEOFDAY","TIMESTAMP_CMP","TIMESTAMP_CMP_DATE","TIMESTAMP_CMP_TIMESTAMPTZ","TIMESTAMPTZ_CMP","TIMESTAMPTZ_CMP_DATE","TIMESTAMPTZ_CMP_TIMESTAMP","TIMEZONE","TO_TIMESTAMP","TRUNC","AddBBox","DropBBox","GeometryType","ST_AddPoint","ST_Angle","ST_Area","ST_AsBinary","ST_AsEWKB","ST_AsEWKT","ST_AsGeoJSON","ST_AsText","ST_Azimuth","ST_Boundary","ST_Collect","ST_Contains","ST_ContainsProperly","ST_ConvexHull","ST_CoveredBy","ST_Covers","ST_Crosses","ST_Dimension","ST_Disjoint","ST_Distance","ST_DistanceSphere","ST_DWithin","ST_EndPoint","ST_Envelope","ST_Equals","ST_ExteriorRing","ST_Force2D","ST_Force3D","ST_Force3DM","ST_Force3DZ","ST_Force4D","ST_GeometryN","ST_GeometryType","ST_GeomFromEWKB","ST_GeomFromEWKT","ST_GeomFromText","ST_GeomFromWKB","ST_InteriorRingN","ST_Intersects","ST_IsPolygonCCW","ST_IsPolygonCW","ST_IsClosed","ST_IsCollection","ST_IsEmpty","ST_IsSimple","ST_IsValid","ST_Length","ST_LengthSphere","ST_Length2D","ST_LineFromMultiPoint","ST_LineInterpolatePoint","ST_M","ST_MakeEnvelope","ST_MakeLine","ST_MakePoint","ST_MakePolygon","ST_MemSize","ST_MMax","ST_MMin","ST_Multi","ST_NDims","ST_NPoints","ST_NRings","ST_NumGeometries","ST_NumInteriorRings","ST_NumPoints","ST_Perimeter","ST_Perimeter2D","ST_Point","ST_PointN","ST_Points","ST_Polygon","ST_RemovePoint","ST_Reverse","ST_SetPoint","ST_SetSRID","ST_Simplify","ST_SRID","ST_StartPoint","ST_Touches","ST_Within","ST_X","ST_XMax","ST_XMin","ST_Y","ST_YMax","ST_YMin","ST_Z","ST_ZMax","ST_ZMin","SupportsBBox","CHECKSUM","FUNC_SHA1","FNV_HASH","MD5","SHA","SHA1","SHA2","HLL","HLL_CREATE_SKETCH","HLL_CARDINALITY","HLL_COMBINE","IS_VALID_JSON","IS_VALID_JSON_ARRAY","JSON_ARRAY_LENGTH","JSON_EXTRACT_ARRAY_ELEMENT_TEXT","JSON_EXTRACT_PATH_TEXT","JSON_PARSE","JSON_SERIALIZE","ABS","ACOS","ASIN","ATAN","ATAN2","CBRT","CEILING","CEIL","COS","COT","DEGREES","DEXP","DLOG1","DLOG10","EXP","FLOOR","LN","LOG","MOD","PI","POWER","RADIANS","RANDOM","ROUND","SIN","SIGN","SQRT","TAN","TO_HEX","TRUNC","EXPLAIN_MODEL","ASCII","BPCHARCMP","BTRIM","BTTEXT_PATTERN_CMP","CHAR_LENGTH","CHARACTER_LENGTH","CHARINDEX","CHR","COLLATE","CONCAT","CRC32","DIFFERENCE","INITCAP","LEFT","RIGHT","LEN","LENGTH","LOWER","LPAD","RPAD","LTRIM","OCTETINDEX","OCTET_LENGTH","POSITION","QUOTE_IDENT","QUOTE_LITERAL","REGEXP_COUNT","REGEXP_INSTR","REGEXP_REPLACE","REGEXP_SUBSTR","REPEAT","REPLACE","REPLICATE","REVERSE","RTRIM","SOUNDEX","SPLIT_PART","STRPOS","STRTOL","SUBSTRING","TEXTLEN","TRANSLATE","TRIM","UPPER","decimal_precision","decimal_scale","is_array","is_bigint","is_boolean","is_char","is_decimal","is_float","is_integer","is_object","is_scalar","is_smallint","is_varchar","json_typeof","AVG","COUNT","CUME_DIST","DENSE_RANK","FIRST_VALUE","LAST_VALUE","LAG","LEAD","LISTAGG","MAX","MEDIAN","MIN","NTH_VALUE","NTILE","PERCENT_RANK","PERCENTILE_CONT","PERCENTILE_DISC","RANK","RATIO_TO_REPORT","ROW_NUMBER","STDDEV_SAMP","STDDEV_POP","SUM","VAR_SAMP","VAR_POP","CAST","CONVERT","TO_CHAR","TO_DATE","TO_NUMBER","TEXT_TO_INT_ALT","TEXT_TO_NUMERIC_ALT","CHANGE_QUERY_PRIORITY","CHANGE_SESSION_PRIORITY","CHANGE_USER_PRIORITY","CURRENT_SETTING","PG_CANCEL_BACKEND","PG_TERMINATE_BACKEND","REBOOT_CLUSTER","SET_CONFIG","CURRENT_AWS_ACCOUNT","CURRENT_DATABASE","CURRENT_NAMESPACE","CURRENT_SCHEMA","CURRENT_SCHEMAS","CURRENT_USER","CURRENT_USER_ID","HAS_ASSUMEROLE_PRIVILEGE","HAS_DATABASE_PRIVILEGE","HAS_SCHEMA_PRIVILEGE","HAS_TABLE_PRIVILEGE","PG_BACKEND_PID","PG_GET_COLS","PG_GET_GRANTEE_BY_IAM_ROLE","PG_GET_IAM_ROLE_BY_USER","PG_GET_LATE_BINDING_VIEW_COLS","PG_LAST_COPY_COUNT","PG_LAST_COPY_ID","PG_LAST_UNLOAD_ID","PG_LAST_QUERY_ID","PG_LAST_UNLOAD_COUNT","SESSION_USER","SLICE_NUM","USER","VERSION"],pC=["AES128","AES256","ALL","ALLOWOVERWRITE","ANY","AS","ASC","AUTHORIZATION","BACKUP","BETWEEN","BINARY","BOTH","CHECK","COLUMN","CONSTRAINT","CREATE","CROSS","DEFAULT","DEFERRABLE","DEFLATE","DEFRAG","DESC","DISABLE","DISTINCT","DO","ENABLE","ENCODE","ENCRYPT","ENCRYPTION","EXPLICIT","FALSE","FOR","FOREIGN","FREEZE","FROM","FULL","GLOBALDICT256","GLOBALDICT64K","GROUP","IDENTITY","IGNORE","ILIKE","IN","INITIALLY","INNER","INTO","IS","ISNULL","LANGUAGE","LEADING","LIKE","LIMIT","LOCALTIME","LOCALTIMESTAMP","LUN","LUNS","MINUS","NATURAL","NEW","NOT","NOTNULL","NULL","NULLS","OFF","OFFLINE","OFFSET","OID","OLD","ON","ONLY","OPEN","ORDER","OUTER","OVERLAPS","PARALLEL","PARTITION","PERCENT","PERMISSIONS","PLACING","PRIMARY","RECOVER","REFERENCES","REJECTLOG","RESORT","RESPECT","RESTORE","SIMILAR","SNAPSHOT","SOME","SYSTEM","TABLE","TAG","TDES","THEN","TIMESTAMP","TO","TOP","TRAILING","TRUE","UNIQUE","USING","VERBOSE","WALLET","WITHOUT","ACCEPTANYDATE","ACCEPTINVCHARS","BLANKSASNULL","DATEFORMAT","EMPTYASNULL","ENCODING","ESCAPE","EXPLICIT_IDS","FILLRECORD","IGNOREBLANKLINES","IGNOREHEADER","REMOVEQUOTES","ROUNDEC","TIMEFORMAT","TRIMBLANKS","TRUNCATECOLUMNS","COMPROWS","COMPUPDATE","MAXERROR","NOLOAD","STATUPDATE","FORMAT","CSV","DELIMITER","FIXEDWIDTH","SHAPEFILE","AVRO","JSON","PARQUET","ORC","ACCESS_KEY_ID","CREDENTIALS","ENCRYPTED","IAM_ROLE","MASTER_SYMMETRIC_KEY","SECRET_ACCESS_KEY","SESSION_TOKEN","BZIP2","GZIP","LZOP","ZSTD","MANIFEST","READRATIO","REGION","SSH","RAW","AZ64","BYTEDICT","DELTA","DELTA32K","LZO","MOSTLY8","MOSTLY16","MOSTLY32","RUNLENGTH","TEXT255","TEXT32K","CATALOG_ROLE","SECRET_ARN","EXTERNAL","AUTO","EVEN","KEY","PREDICATE","COMPRESSION"],mC=["ARRAY","BIGINT","BPCHAR","CHAR","CHARACTER VARYING","CHARACTER","DECIMAL","INT","INT2","INT4","INT8","INTEGER","NCHAR","NUMERIC","NVARCHAR","SMALLINT","TEXT","VARBYTE","VARCHAR"],DC=x(["SELECT [ALL | DISTINCT]"]),PC=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY","HAVING","QUALIFY","PARTITION BY","ORDER BY","LIMIT","OFFSET","INSERT INTO","VALUES","SET"]),ji=x(["CREATE [TEMPORARY | TEMP | LOCAL TEMPORARY | LOCAL TEMP] TABLE [IF NOT EXISTS]"]),al=x(["CREATE [OR REPLACE | MATERIALIZED] VIEW","UPDATE","DELETE [FROM]","DROP TABLE [IF EXISTS]","ALTER TABLE","ALTER TABLE APPEND","ADD [COLUMN]","DROP [COLUMN]","RENAME TO","RENAME COLUMN","ALTER COLUMN","TYPE","ENCODE","TRUNCATE [TABLE]","ABORT","ALTER DATABASE","ALTER DATASHARE","ALTER DEFAULT PRIVILEGES","ALTER GROUP","ALTER MATERIALIZED VIEW","ALTER PROCEDURE","ALTER SCHEMA","ALTER USER","ANALYSE","ANALYZE","ANALYSE COMPRESSION","ANALYZE COMPRESSION","BEGIN","CALL","CANCEL","CLOSE","COMMIT","COPY","CREATE DATABASE","CREATE DATASHARE","CREATE EXTERNAL FUNCTION","CREATE EXTERNAL SCHEMA","CREATE EXTERNAL TABLE","CREATE FUNCTION","CREATE GROUP","CREATE LIBRARY","CREATE MODEL","CREATE PROCEDURE","CREATE SCHEMA","CREATE USER","DEALLOCATE","DECLARE","DESC DATASHARE","DROP DATABASE","DROP DATASHARE","DROP FUNCTION","DROP GROUP","DROP LIBRARY","DROP MODEL","DROP MATERIALIZED VIEW","DROP PROCEDURE","DROP SCHEMA","DROP USER","DROP VIEW","DROP","EXECUTE","EXPLAIN","FETCH","GRANT","LOCK","PREPARE","REFRESH MATERIALIZED VIEW","RESET","REVOKE","ROLLBACK","SELECT INTO","SET SESSION AUTHORIZATION","SET SESSION CHARACTERISTICS","SHOW","SHOW EXTERNAL TABLE","SHOW MODEL","SHOW DATASHARES","SHOW PROCEDURE","SHOW TABLE","SHOW VIEW","START TRANSACTION","UNLOAD","VACUUM"]),hC=x(["UNION [ALL]","EXCEPT","INTERSECT","MINUS"]),MC=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),UC=x(["NULL AS","DATA CATALOG","HIVE METASTORE","{ROWS | RANGE} BETWEEN"]),xC=x([]),yC={name:"redshift",tokenizerOptions:{reservedSelect:DC,reservedClauses:[...PC,...ji,...al],reservedSetOperations:hC,reservedJoins:MC,reservedKeywordPhrases:UC,reservedDataTypePhrases:xC,reservedKeywords:pC,reservedDataTypes:mC,reservedFunctionNames:fC,extraParens:["[]"],stringTypes:["''-qq"],identTypes:['""-qq'],identChars:{first:"#"},paramTypes:{numbered:["$"]},operators:["^","%","@","|/","||/","&","|","~","<<",">>","||","::"]},formatOptions:{alwaysDenseOperators:["::"],onelineClauses:[...ji,...al],tabularOnelineClauses:al}},gC=["ADD","AFTER","ALL","ALTER","ANALYZE","AND","ANTI","ANY","ARCHIVE","AS","ASC","AT","AUTHORIZATION","BETWEEN","BOTH","BUCKET","BUCKETS","BY","CACHE","CASCADE","CAST","CHANGE","CHECK","CLEAR","CLUSTER","CLUSTERED","CODEGEN","COLLATE","COLLECTION","COLUMN","COLUMNS","COMMENT","COMMIT","COMPACT","COMPACTIONS","COMPUTE","CONCATENATE","CONSTRAINT","COST","CREATE","CROSS","CUBE","CURRENT","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","DATA","DATABASE","DATABASES","DAY","DBPROPERTIES","DEFINED","DELETE","DELIMITED","DESC","DESCRIBE","DFS","DIRECTORIES","DIRECTORY","DISTINCT","DISTRIBUTE","DIV","DROP","ESCAPE","ESCAPED","EXCEPT","EXCHANGE","EXISTS","EXPORT","EXTENDED","EXTERNAL","EXTRACT","FALSE","FETCH","FIELDS","FILTER","FILEFORMAT","FIRST","FIRST_VALUE","FOLLOWING","FOR","FOREIGN","FORMAT","FORMATTED","FULL","FUNCTION","FUNCTIONS","GLOBAL","GRANT","GROUP","GROUPING","HOUR","IF","IGNORE","IMPORT","IN","INDEX","INDEXES","INNER","INPATH","INPUTFORMAT","INTERSECT","INTO","IS","ITEMS","KEYS","LAST","LAST_VALUE","LATERAL","LAZY","LEADING","LEFT","LIKE","LINES","LIST","LOCAL","LOCATION","LOCK","LOCKS","LOGICAL","MACRO","MATCHED","MERGE","MINUTE","MONTH","MSCK","NAMESPACE","NAMESPACES","NATURAL","NO","NOT","NULL","NULLS","OF","ONLY","OPTION","OPTIONS","OR","ORDER","OUT","OUTER","OUTPUTFORMAT","OVER","OVERLAPS","OVERLAY","OVERWRITE","OWNER","PARTITION","PARTITIONED","PARTITIONS","PERCENT","PLACING","POSITION","PRECEDING","PRIMARY","PRINCIPALS","PROPERTIES","PURGE","QUERY","RANGE","RECORDREADER","RECORDWRITER","RECOVER","REDUCE","REFERENCES","RENAME","REPAIR","REPLACE","RESPECT","RESTRICT","REVOKE","RIGHT","RLIKE","ROLE","ROLES","ROLLBACK","ROLLUP","ROW","ROWS","SCHEMA","SECOND","SELECT","SEMI","SEPARATED","SERDE","SERDEPROPERTIES","SESSION_USER","SETS","SHOW","SKEWED","SOME","SORT","SORTED","START","STATISTICS","STORED","STRATIFY","SUBSTR","SUBSTRING","TABLE","TABLES","TBLPROPERTIES","TEMPORARY","TERMINATED","THEN","TO","TOUCH","TRAILING","TRANSACTION","TRANSACTIONS","TRIM","TRUE","TRUNCATE","UNARCHIVE","UNBOUNDED","UNCACHE","UNIQUE","UNKNOWN","UNLOCK","UNSET","USE","USER","USING","VIEW","WINDOW","YEAR","ANALYSE","ARRAY_ZIP","COALESCE","CONTAINS","CONVERT","DAYS","DAY_HOUR","DAY_MINUTE","DAY_SECOND","DECODE","DEFAULT","DISTINCTROW","ENCODE","EXPLODE","EXPLODE_OUTER","FIXED","GREATEST","GROUP_CONCAT","HOURS","HOUR_MINUTE","HOUR_SECOND","IFNULL","LEAST","LEVEL","MINUTE_SECOND","NULLIF","OFFSET","ON","OPTIMIZE","REGEXP","SEPARATOR","SIZE","TYPE","TYPES","UNSIGNED","VARIABLES","YEAR_MONTH"],GC=["ARRAY","BIGINT","BINARY","BOOLEAN","BYTE","CHAR","DATE","DEC","DECIMAL","DOUBLE","FLOAT","INT","INTEGER","INTERVAL","LONG","MAP","NUMERIC","REAL","SHORT","SMALLINT","STRING","STRUCT","TIMESTAMP_LTZ","TIMESTAMP_NTZ","TIMESTAMP","TINYINT","VARCHAR"],vC=["APPROX_COUNT_DISTINCT","APPROX_PERCENTILE","AVG","BIT_AND","BIT_OR","BIT_XOR","BOOL_AND","BOOL_OR","COLLECT_LIST","COLLECT_SET","CORR","COUNT","COUNT","COUNT","COUNT_IF","COUNT_MIN_SKETCH","COVAR_POP","COVAR_SAMP","EVERY","FIRST","FIRST_VALUE","GROUPING","GROUPING_ID","KURTOSIS","LAST","LAST_VALUE","MAX","MAX_BY","MEAN","MIN","MIN_BY","PERCENTILE","PERCENTILE","PERCENTILE_APPROX","SKEWNESS","STD","STDDEV","STDDEV_POP","STDDEV_SAMP","SUM","VAR_POP","VAR_SAMP","VARIANCE","CUME_DIST","DENSE_RANK","LAG","LEAD","NTH_VALUE","NTILE","PERCENT_RANK","RANK","ROW_NUMBER","ARRAY","ARRAY_CONTAINS","ARRAY_DISTINCT","ARRAY_EXCEPT","ARRAY_INTERSECT","ARRAY_JOIN","ARRAY_MAX","ARRAY_MIN","ARRAY_POSITION","ARRAY_REMOVE","ARRAY_REPEAT","ARRAY_UNION","ARRAYS_OVERLAP","ARRAYS_ZIP","FLATTEN","SEQUENCE","SHUFFLE","SLICE","SORT_ARRAY","ELEMENT_AT","ELEMENT_AT","MAP_CONCAT","MAP_ENTRIES","MAP_FROM_ARRAYS","MAP_FROM_ENTRIES","MAP_KEYS","MAP_VALUES","STR_TO_MAP","ADD_MONTHS","CURRENT_DATE","CURRENT_DATE","CURRENT_TIMESTAMP","CURRENT_TIMESTAMP","CURRENT_TIMEZONE","DATE_ADD","DATE_FORMAT","DATE_FROM_UNIX_DATE","DATE_PART","DATE_SUB","DATE_TRUNC","DATEDIFF","DAY","DAYOFMONTH","DAYOFWEEK","DAYOFYEAR","EXTRACT","FROM_UNIXTIME","FROM_UTC_TIMESTAMP","HOUR","LAST_DAY","MAKE_DATE","MAKE_DT_INTERVAL","MAKE_INTERVAL","MAKE_TIMESTAMP","MAKE_YM_INTERVAL","MINUTE","MONTH","MONTHS_BETWEEN","NEXT_DAY","NOW","QUARTER","SECOND","SESSION_WINDOW","TIMESTAMP_MICROS","TIMESTAMP_MILLIS","TIMESTAMP_SECONDS","TO_DATE","TO_TIMESTAMP","TO_UNIX_TIMESTAMP","TO_UTC_TIMESTAMP","TRUNC","UNIX_DATE","UNIX_MICROS","UNIX_MILLIS","UNIX_SECONDS","UNIX_TIMESTAMP","WEEKDAY","WEEKOFYEAR","WINDOW","YEAR","FROM_JSON","GET_JSON_OBJECT","JSON_ARRAY_LENGTH","JSON_OBJECT_KEYS","JSON_TUPLE","SCHEMA_OF_JSON","TO_JSON","ABS","ACOS","ACOSH","AGGREGATE","ARRAY_SORT","ASCII","ASIN","ASINH","ASSERT_TRUE","ATAN","ATAN2","ATANH","BASE64","BIN","BIT_COUNT","BIT_GET","BIT_LENGTH","BROUND","BTRIM","CARDINALITY","CBRT","CEIL","CEILING","CHAR_LENGTH","CHARACTER_LENGTH","CHR","CONCAT","CONCAT_WS","CONV","COS","COSH","COT","CRC32","CURRENT_CATALOG","CURRENT_DATABASE","CURRENT_USER","DEGREES","ELT","EXP","EXPM1","FACTORIAL","FIND_IN_SET","FLOOR","FORALL","FORMAT_NUMBER","FORMAT_STRING","FROM_CSV","GETBIT","HASH","HEX","HYPOT","INITCAP","INLINE","INLINE_OUTER","INPUT_FILE_BLOCK_LENGTH","INPUT_FILE_BLOCK_START","INPUT_FILE_NAME","INSTR","ISNAN","ISNOTNULL","ISNULL","JAVA_METHOD","LCASE","LEFT","LENGTH","LEVENSHTEIN","LN","LOCATE","LOG","LOG10","LOG1P","LOG2","LOWER","LPAD","LTRIM","MAP_FILTER","MAP_ZIP_WITH","MD5","MOD","MONOTONICALLY_INCREASING_ID","NAMED_STRUCT","NANVL","NEGATIVE","NVL","NVL2","OCTET_LENGTH","OVERLAY","PARSE_URL","PI","PMOD","POSEXPLODE","POSEXPLODE_OUTER","POSITION","POSITIVE","POW","POWER","PRINTF","RADIANS","RAISE_ERROR","RAND","RANDN","RANDOM","REFLECT","REGEXP_EXTRACT","REGEXP_EXTRACT_ALL","REGEXP_LIKE","REGEXP_REPLACE","REPEAT","REPLACE","REVERSE","RIGHT","RINT","ROUND","RPAD","RTRIM","SCHEMA_OF_CSV","SENTENCES","SHA","SHA1","SHA2","SHIFTLEFT","SHIFTRIGHT","SHIFTRIGHTUNSIGNED","SIGN","SIGNUM","SIN","SINH","SOUNDEX","SPACE","SPARK_PARTITION_ID","SPLIT","SQRT","STACK","SUBSTR","SUBSTRING","SUBSTRING_INDEX","TAN","TANH","TO_CSV","TRANSFORM_KEYS","TRANSFORM_VALUES","TRANSLATE","TRIM","TRY_ADD","TRY_DIVIDE","TYPEOF","UCASE","UNBASE64","UNHEX","UPPER","UUID","VERSION","WIDTH_BUCKET","XPATH","XPATH_BOOLEAN","XPATH_DOUBLE","XPATH_FLOAT","XPATH_INT","XPATH_LONG","XPATH_NUMBER","XPATH_SHORT","XPATH_STRING","XXHASH64","ZIP_WITH","CAST","COALESCE","NULLIF"],HC=x(["SELECT [ALL | DISTINCT]"]),BC=x(["WITH","FROM","WHERE","GROUP BY","HAVING","WINDOW","PARTITION BY","ORDER BY","SORT BY","CLUSTER BY","DISTRIBUTE BY","LIMIT","INSERT [INTO | OVERWRITE] [TABLE]","VALUES","INSERT OVERWRITE [LOCAL] DIRECTORY","LOAD DATA [LOCAL] INPATH","[OVERWRITE] INTO TABLE"]),ki=x(["CREATE [EXTERNAL] TABLE [IF NOT EXISTS]"]),ol=x(["CREATE [OR REPLACE] [GLOBAL TEMPORARY | TEMPORARY] VIEW [IF NOT EXISTS]","DROP TABLE [IF EXISTS]","ALTER TABLE","ADD COLUMNS","DROP {COLUMN | COLUMNS}","RENAME TO","RENAME COLUMN","ALTER COLUMN","TRUNCATE TABLE","LATERAL VIEW","ALTER DATABASE","ALTER VIEW","CREATE DATABASE","CREATE FUNCTION","DROP DATABASE","DROP FUNCTION","DROP VIEW","REPAIR TABLE","USE DATABASE","TABLESAMPLE","PIVOT","TRANSFORM","EXPLAIN","ADD FILE","ADD JAR","ANALYZE TABLE","CACHE TABLE","CLEAR CACHE","DESCRIBE DATABASE","DESCRIBE FUNCTION","DESCRIBE QUERY","DESCRIBE TABLE","LIST FILE","LIST JAR","REFRESH","REFRESH TABLE","REFRESH FUNCTION","RESET","SHOW COLUMNS","SHOW CREATE TABLE","SHOW DATABASES","SHOW FUNCTIONS","SHOW PARTITIONS","SHOW TABLE EXTENDED","SHOW TABLES","SHOW TBLPROPERTIES","SHOW VIEWS","UNCACHE TABLE"]),FC=x(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),YC=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN","[LEFT] {ANTI | SEMI} JOIN","NATURAL [LEFT] {ANTI | SEMI} JOIN"]),wC=x(["ON DELETE","ON UPDATE","CURRENT ROW","{ROWS | RANGE} BETWEEN"]),bC=x([]),VC={name:"spark",tokenizerOptions:{reservedSelect:HC,reservedClauses:[...BC,...ki,...ol],reservedSetOperations:FC,reservedJoins:YC,reservedKeywordPhrases:wC,reservedDataTypePhrases:bC,supportsXor:!0,reservedKeywords:gC,reservedDataTypes:GC,reservedFunctionNames:vC,extraParens:["[]"],stringTypes:["''-bs",'""-bs',{quote:"''-raw",prefixes:["R","X"],requirePrefix:!0},{quote:'""-raw',prefixes:["R","X"],requirePrefix:!0}],identTypes:["``"],identChars:{allowFirstCharNumber:!0},variableTypes:[{quote:"{}",prefixes:["$"],requirePrefix:!0}],operators:["%","~","^","|","&","<=>","==","!","||","->"],postProcess:WC},formatOptions:{onelineClauses:[...ki,...ol],tabularOnelineClauses:ol}};function WC(e){return e.map((t,E)=>{const n=e[E-1]||kn,r=e[E+1]||kn;return An.WINDOW(t)&&r.type===V.OPEN_PAREN?Object.assign(Object.assign({},t),{type:V.RESERVED_FUNCTION_NAME}):t.text==="ITEMS"&&t.type===V.RESERVED_KEYWORD&&!(n.text==="COLLECTION"&&r.text==="TERMINATED")?Object.assign(Object.assign({},t),{type:V.IDENTIFIER,text:t.raw}):t})}const XC=["ABS","CHANGES","CHAR","COALESCE","FORMAT","GLOB","HEX","IFNULL","IIF","INSTR","LAST_INSERT_ROWID","LENGTH","LIKE","LIKELIHOOD","LIKELY","LOAD_EXTENSION","LOWER","LTRIM","NULLIF","PRINTF","QUOTE","RANDOM","RANDOMBLOB","REPLACE","ROUND","RTRIM","SIGN","SOUNDEX","SQLITE_COMPILEOPTION_GET","SQLITE_COMPILEOPTION_USED","SQLITE_OFFSET","SQLITE_SOURCE_ID","SQLITE_VERSION","SUBSTR","SUBSTRING","TOTAL_CHANGES","TRIM","TYPEOF","UNICODE","UNLIKELY","UPPER","ZEROBLOB","AVG","COUNT","GROUP_CONCAT","MAX","MIN","SUM","TOTAL","DATE","TIME","DATETIME","JULIANDAY","UNIXEPOCH","STRFTIME","row_number","rank","dense_rank","percent_rank","cume_dist","ntile","lag","lead","first_value","last_value","nth_value","ACOS","ACOSH","ASIN","ASINH","ATAN","ATAN2","ATANH","CEIL","CEILING","COS","COSH","DEGREES","EXP","FLOOR","LN","LOG","LOG","LOG10","LOG2","MOD","PI","POW","POWER","RADIANS","SIN","SINH","SQRT","TAN","TANH","TRUNC","JSON","JSON_ARRAY","JSON_ARRAY_LENGTH","JSON_ARRAY_LENGTH","JSON_EXTRACT","JSON_INSERT","JSON_OBJECT","JSON_PATCH","JSON_REMOVE","JSON_REPLACE","JSON_SET","JSON_TYPE","JSON_TYPE","JSON_VALID","JSON_QUOTE","JSON_GROUP_ARRAY","JSON_GROUP_OBJECT","JSON_EACH","JSON_TREE","CAST"],jC=["ABORT","ACTION","ADD","AFTER","ALL","ALTER","AND","ARE","ALWAYS","ANALYZE","AS","ASC","ATTACH","AUTOINCREMENT","BEFORE","BEGIN","BETWEEN","BY","CASCADE","CASE","CAST","CHECK","COLLATE","COLUMN","COMMIT","CONFLICT","CONSTRAINT","CREATE","CROSS","CURRENT","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP","DATABASE","DEFAULT","DEFERRABLE","DEFERRED","DELETE","DESC","DETACH","DISTINCT","DO","DROP","EACH","ELSE","END","ESCAPE","EXCEPT","EXCLUDE","EXCLUSIVE","EXISTS","EXPLAIN","FAIL","FILTER","FIRST","FOLLOWING","FOR","FOREIGN","FROM","FULL","GENERATED","GLOB","GROUP","HAVING","IF","IGNORE","IMMEDIATE","IN","INDEX","INDEXED","INITIALLY","INNER","INSERT","INSTEAD","INTERSECT","INTO","IS","ISNULL","JOIN","KEY","LAST","LEFT","LIKE","LIMIT","MATCH","MATERIALIZED","NATURAL","NO","NOT","NOTHING","NOTNULL","NULL","NULLS","OF","OFFSET","ON","ONLY","OPEN","OR","ORDER","OTHERS","OUTER","OVER","PARTITION","PLAN","PRAGMA","PRECEDING","PRIMARY","QUERY","RAISE","RANGE","RECURSIVE","REFERENCES","REGEXP","REINDEX","RELEASE","RENAME","REPLACE","RESTRICT","RETURNING","RIGHT","ROLLBACK","ROW","ROWS","SAVEPOINT","SELECT","SET","TABLE","TEMP","TEMPORARY","THEN","TIES","TO","TRANSACTION","TRIGGER","UNBOUNDED","UNION","UNIQUE","UPDATE","USING","VACUUM","VALUES","VIEW","VIRTUAL","WHEN","WHERE","WINDOW","WITH","WITHOUT"],kC=["ANY","ARRAY","BLOB","CHARACTER","DECIMAL","INT","INTEGER","NATIVE CHARACTER","NCHAR","NUMERIC","NVARCHAR","REAL","TEXT","VARCHAR","VARYING CHARACTER"],KC=x(["SELECT [ALL | DISTINCT]"]),$C=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY","HAVING","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","INSERT [OR ABORT | OR FAIL | OR IGNORE | OR REPLACE | OR ROLLBACK] INTO","REPLACE INTO","VALUES","SET","RETURNING"]),Ki=x(["CREATE [TEMPORARY | TEMP] TABLE [IF NOT EXISTS]"]),il=x(["CREATE [TEMPORARY | TEMP] VIEW [IF NOT EXISTS]","UPDATE [OR ABORT | OR FAIL | OR IGNORE | OR REPLACE | OR ROLLBACK]","ON CONFLICT","DELETE FROM","DROP TABLE [IF EXISTS]","ALTER TABLE","ADD [COLUMN]","DROP [COLUMN]","RENAME [COLUMN]","RENAME TO","SET SCHEMA"]),JC=x(["UNION [ALL]","EXCEPT","INTERSECT"]),zC=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),QC=x(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","{ROWS | RANGE | GROUPS} BETWEEN","DO UPDATE"]),ZC=x([]),qC={name:"sqlite",tokenizerOptions:{reservedSelect:KC,reservedClauses:[...$C,...Ki,...il],reservedSetOperations:JC,reservedJoins:zC,reservedKeywordPhrases:QC,reservedDataTypePhrases:ZC,reservedKeywords:jC,reservedDataTypes:kC,reservedFunctionNames:XC,stringTypes:["''-qq",{quote:"''-raw",prefixes:["X"],requirePrefix:!0}],identTypes:['""-qq',"``","[]"],paramTypes:{positional:!0,numbered:["?"],named:[":","@","$"]},operators:["%","~","&","|","<<",">>","==","->","->>","||"]},formatOptions:{onelineClauses:[...Ki,...il],tabularOnelineClauses:il}},ed=["GROUPING","RANK","DENSE_RANK","PERCENT_RANK","CUME_DIST","ROW_NUMBER","POSITION","OCCURRENCES_REGEX","POSITION_REGEX","EXTRACT","CHAR_LENGTH","CHARACTER_LENGTH","OCTET_LENGTH","CARDINALITY","ABS","MOD","LN","EXP","POWER","SQRT","FLOOR","CEIL","CEILING","WIDTH_BUCKET","SUBSTRING","SUBSTRING_REGEX","UPPER","LOWER","CONVERT","TRANSLATE","TRANSLATE_REGEX","TRIM","OVERLAY","NORMALIZE","SPECIFICTYPE","CURRENT_DATE","CURRENT_TIME","LOCALTIME","CURRENT_TIMESTAMP","LOCALTIMESTAMP","COUNT","AVG","MAX","MIN","SUM","STDDEV_POP","STDDEV_SAMP","VAR_SAMP","VAR_POP","COLLECT","FUSION","INTERSECTION","COVAR_POP","COVAR_SAMP","CORR","REGR_SLOPE","REGR_INTERCEPT","REGR_COUNT","REGR_R2","REGR_AVGX","REGR_AVGY","REGR_SXX","REGR_SYY","REGR_SXY","PERCENTILE_CONT","PERCENTILE_DISC","CAST","COALESCE","NULLIF","ROUND","SIN","COS","TAN","ASIN","ACOS","ATAN"],td=["ALL","ALLOCATE","ALTER","ANY","ARE","AS","ASC","ASENSITIVE","ASYMMETRIC","AT","ATOMIC","AUTHORIZATION","BEGIN","BETWEEN","BOTH","BY","CALL","CALLED","CASCADED","CAST","CHECK","CLOSE","COALESCE","COLLATE","COLUMN","COMMIT","CONDITION","CONNECT","CONSTRAINT","CORRESPONDING","CREATE","CROSS","CUBE","CURRENT","CURRENT_CATALOG","CURRENT_DEFAULT_TRANSFORM_GROUP","CURRENT_PATH","CURRENT_ROLE","CURRENT_SCHEMA","CURRENT_TRANSFORM_GROUP_FOR_TYPE","CURRENT_USER","CURSOR","CYCLE","DEALLOCATE","DAY","DECLARE","DEFAULT","DELETE","DEREF","DESC","DESCRIBE","DETERMINISTIC","DISCONNECT","DISTINCT","DROP","DYNAMIC","EACH","ELEMENT","END-EXEC","ESCAPE","EVERY","EXCEPT","EXEC","EXECUTE","EXISTS","EXTERNAL","FALSE","FETCH","FILTER","FOR","FOREIGN","FREE","FROM","FULL","FUNCTION","GET","GLOBAL","GRANT","GROUP","HAVING","HOLD","HOUR","IDENTITY","IN","INDICATOR","INNER","INOUT","INSENSITIVE","INSERT","INTERSECT","INTO","IS","LANGUAGE","LARGE","LATERAL","LEADING","LEFT","LIKE","LIKE_REGEX","LOCAL","MATCH","MEMBER","MERGE","METHOD","MINUTE","MODIFIES","MODULE","MONTH","NATURAL","NEW","NO","NONE","NOT","NULL","NULLIF","OF","OLD","ON","ONLY","OPEN","ORDER","OUT","OUTER","OVER","OVERLAPS","PARAMETER","PARTITION","PRECISION","PREPARE","PRIMARY","PROCEDURE","RANGE","READS","REAL","RECURSIVE","REF","REFERENCES","REFERENCING","RELEASE","RESULT","RETURN","RETURNS","REVOKE","RIGHT","ROLLBACK","ROLLUP","ROW","ROWS","SAVEPOINT","SCOPE","SCROLL","SEARCH","SECOND","SELECT","SENSITIVE","SESSION_USER","SET","SIMILAR","SOME","SPECIFIC","SQL","SQLEXCEPTION","SQLSTATE","SQLWARNING","START","STATIC","SUBMULTISET","SYMMETRIC","SYSTEM","SYSTEM_USER","TABLE","TABLESAMPLE","THEN","TIMEZONE_HOUR","TIMEZONE_MINUTE","TO","TRAILING","TRANSLATION","TREAT","TRIGGER","TRUE","UESCAPE","UNION","UNIQUE","UNKNOWN","UNNEST","UPDATE","USER","USING","VALUE","VALUES","WHENEVER","WINDOW","WITHIN","WITHOUT","YEAR"],Ed=["ARRAY","BIGINT","BINARY LARGE OBJECT","BINARY VARYING","BINARY","BLOB","BOOLEAN","CHAR LARGE OBJECT","CHAR VARYING","CHAR","CHARACTER LARGE OBJECT","CHARACTER VARYING","CHARACTER","CLOB","DATE","DEC","DECIMAL","DOUBLE","FLOAT","INT","INTEGER","INTERVAL","MULTISET","NATIONAL CHAR VARYING","NATIONAL CHAR","NATIONAL CHARACTER LARGE OBJECT","NATIONAL CHARACTER VARYING","NATIONAL CHARACTER","NCHAR LARGE OBJECT","NCHAR VARYING","NCHAR","NCLOB","NUMERIC","SMALLINT","TIME","TIMESTAMP","VARBINARY","VARCHAR"],nd=x(["SELECT [ALL | DISTINCT]"]),rd=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY [ALL | DISTINCT]","HAVING","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","FETCH {FIRST | NEXT}","INSERT INTO","VALUES","SET"]),$i=x(["CREATE [GLOBAL TEMPORARY | LOCAL TEMPORARY] TABLE"]),Rl=x(["CREATE [RECURSIVE] VIEW","UPDATE","WHERE CURRENT OF","DELETE FROM","DROP TABLE","ALTER TABLE","ADD COLUMN","DROP [COLUMN]","RENAME COLUMN","RENAME TO","ALTER [COLUMN]","{SET | DROP} DEFAULT","ADD SCOPE","DROP SCOPE {CASCADE | RESTRICT}","RESTART WITH","TRUNCATE TABLE","SET SCHEMA"]),sd=x(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),Td=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),ld=x(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","{ROWS | RANGE} BETWEEN"]),ad=x([]),od={name:"sql",tokenizerOptions:{reservedSelect:nd,reservedClauses:[...rd,...$i,...Rl],reservedSetOperations:sd,reservedJoins:Td,reservedKeywordPhrases:ld,reservedDataTypePhrases:ad,reservedKeywords:td,reservedDataTypes:Ed,reservedFunctionNames:ed,stringTypes:[{quote:"''-qq-bs",prefixes:["N","U&"]},{quote:"''-raw",prefixes:["X"],requirePrefix:!0}],identTypes:['""-qq',"``"],paramTypes:{positional:!0},operators:["||"]},formatOptions:{onelineClauses:[...$i,...Rl],tabularOnelineClauses:Rl}},id=["ABS","ACOS","ALL_MATCH","ANY_MATCH","APPROX_DISTINCT","APPROX_MOST_FREQUENT","APPROX_PERCENTILE","APPROX_SET","ARBITRARY","ARRAYS_OVERLAP","ARRAY_AGG","ARRAY_DISTINCT","ARRAY_EXCEPT","ARRAY_INTERSECT","ARRAY_JOIN","ARRAY_MAX","ARRAY_MIN","ARRAY_POSITION","ARRAY_REMOVE","ARRAY_SORT","ARRAY_UNION","ASIN","ATAN","ATAN2","AT_TIMEZONE","AVG","BAR","BETA_CDF","BING_TILE","BING_TILES_AROUND","BING_TILE_AT","BING_TILE_COORDINATES","BING_TILE_POLYGON","BING_TILE_QUADKEY","BING_TILE_ZOOM_LEVEL","BITWISE_AND","BITWISE_AND_AGG","BITWISE_LEFT_SHIFT","BITWISE_NOT","BITWISE_OR","BITWISE_OR_AGG","BITWISE_RIGHT_SHIFT","BITWISE_RIGHT_SHIFT_ARITHMETIC","BITWISE_XOR","BIT_COUNT","BOOL_AND","BOOL_OR","CARDINALITY","CAST","CBRT","CEIL","CEILING","CHAR2HEXINT","CHECKSUM","CHR","CLASSIFY","COALESCE","CODEPOINT","COLOR","COMBINATIONS","CONCAT","CONCAT_WS","CONTAINS","CONTAINS_SEQUENCE","CONVEX_HULL_AGG","CORR","COS","COSH","COSINE_SIMILARITY","COUNT","COUNT_IF","COVAR_POP","COVAR_SAMP","CRC32","CUME_DIST","CURRENT_CATALOG","CURRENT_DATE","CURRENT_GROUPS","CURRENT_SCHEMA","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_TIMEZONE","CURRENT_USER","DATE","DATE_ADD","DATE_DIFF","DATE_FORMAT","DATE_PARSE","DATE_TRUNC","DAY","DAY_OF_MONTH","DAY_OF_WEEK","DAY_OF_YEAR","DEGREES","DENSE_RANK","DOW","DOY","E","ELEMENT_AT","EMPTY_APPROX_SET","EVALUATE_CLASSIFIER_PREDICTIONS","EVERY","EXP","EXTRACT","FEATURES","FILTER","FIRST_VALUE","FLATTEN","FLOOR","FORMAT","FORMAT_DATETIME","FORMAT_NUMBER","FROM_BASE","FROM_BASE32","FROM_BASE64","FROM_BASE64URL","FROM_BIG_ENDIAN_32","FROM_BIG_ENDIAN_64","FROM_ENCODED_POLYLINE","FROM_GEOJSON_GEOMETRY","FROM_HEX","FROM_IEEE754_32","FROM_IEEE754_64","FROM_ISO8601_DATE","FROM_ISO8601_TIMESTAMP","FROM_ISO8601_TIMESTAMP_NANOS","FROM_UNIXTIME","FROM_UNIXTIME_NANOS","FROM_UTF8","GEOMETRIC_MEAN","GEOMETRY_FROM_HADOOP_SHAPE","GEOMETRY_INVALID_REASON","GEOMETRY_NEAREST_POINTS","GEOMETRY_TO_BING_TILES","GEOMETRY_UNION","GEOMETRY_UNION_AGG","GREATEST","GREAT_CIRCLE_DISTANCE","HAMMING_DISTANCE","HASH_COUNTS","HISTOGRAM","HMAC_MD5","HMAC_SHA1","HMAC_SHA256","HMAC_SHA512","HOUR","HUMAN_READABLE_SECONDS","IF","INDEX","INFINITY","INTERSECTION_CARDINALITY","INVERSE_BETA_CDF","INVERSE_NORMAL_CDF","IS_FINITE","IS_INFINITE","IS_JSON_SCALAR","IS_NAN","JACCARD_INDEX","JSON_ARRAY_CONTAINS","JSON_ARRAY_GET","JSON_ARRAY_LENGTH","JSON_EXISTS","JSON_EXTRACT","JSON_EXTRACT_SCALAR","JSON_FORMAT","JSON_PARSE","JSON_QUERY","JSON_SIZE","JSON_VALUE","KURTOSIS","LAG","LAST_DAY_OF_MONTH","LAST_VALUE","LEAD","LEARN_CLASSIFIER","LEARN_LIBSVM_CLASSIFIER","LEARN_LIBSVM_REGRESSOR","LEARN_REGRESSOR","LEAST","LENGTH","LEVENSHTEIN_DISTANCE","LINE_INTERPOLATE_POINT","LINE_INTERPOLATE_POINTS","LINE_LOCATE_POINT","LISTAGG","LN","LOCALTIME","LOCALTIMESTAMP","LOG","LOG10","LOG2","LOWER","LPAD","LTRIM","LUHN_CHECK","MAKE_SET_DIGEST","MAP","MAP_AGG","MAP_CONCAT","MAP_ENTRIES","MAP_FILTER","MAP_FROM_ENTRIES","MAP_KEYS","MAP_UNION","MAP_VALUES","MAP_ZIP_WITH","MAX","MAX_BY","MD5","MERGE","MERGE_SET_DIGEST","MILLISECOND","MIN","MINUTE","MIN_BY","MOD","MONTH","MULTIMAP_AGG","MULTIMAP_FROM_ENTRIES","MURMUR3","NAN","NGRAMS","NONE_MATCH","NORMALIZE","NORMAL_CDF","NOW","NTH_VALUE","NTILE","NULLIF","NUMERIC_HISTOGRAM","OBJECTID","OBJECTID_TIMESTAMP","PARSE_DATA_SIZE","PARSE_DATETIME","PARSE_DURATION","PERCENT_RANK","PI","POSITION","POW","POWER","QDIGEST_AGG","QUARTER","RADIANS","RAND","RANDOM","RANK","REDUCE","REDUCE_AGG","REGEXP_COUNT","REGEXP_EXTRACT","REGEXP_EXTRACT_ALL","REGEXP_LIKE","REGEXP_POSITION","REGEXP_REPLACE","REGEXP_SPLIT","REGRESS","REGR_INTERCEPT","REGR_SLOPE","RENDER","REPEAT","REPLACE","REVERSE","RGB","ROUND","ROW_NUMBER","RPAD","RTRIM","SECOND","SEQUENCE","SHA1","SHA256","SHA512","SHUFFLE","SIGN","SIMPLIFY_GEOMETRY","SIN","SKEWNESS","SLICE","SOUNDEX","SPATIAL_PARTITIONING","SPATIAL_PARTITIONS","SPLIT","SPLIT_PART","SPLIT_TO_MAP","SPLIT_TO_MULTIMAP","SPOOKY_HASH_V2_32","SPOOKY_HASH_V2_64","SQRT","STARTS_WITH","STDDEV","STDDEV_POP","STDDEV_SAMP","STRPOS","ST_AREA","ST_ASBINARY","ST_ASTEXT","ST_BOUNDARY","ST_BUFFER","ST_CENTROID","ST_CONTAINS","ST_CONVEXHULL","ST_COORDDIM","ST_CROSSES","ST_DIFFERENCE","ST_DIMENSION","ST_DISJOINT","ST_DISTANCE","ST_ENDPOINT","ST_ENVELOPE","ST_ENVELOPEASPTS","ST_EQUALS","ST_EXTERIORRING","ST_GEOMETRIES","ST_GEOMETRYFROMTEXT","ST_GEOMETRYN","ST_GEOMETRYTYPE","ST_GEOMFROMBINARY","ST_INTERIORRINGN","ST_INTERIORRINGS","ST_INTERSECTION","ST_INTERSECTS","ST_ISCLOSED","ST_ISEMPTY","ST_ISRING","ST_ISSIMPLE","ST_ISVALID","ST_LENGTH","ST_LINEFROMTEXT","ST_LINESTRING","ST_MULTIPOINT","ST_NUMGEOMETRIES","ST_NUMINTERIORRING","ST_NUMPOINTS","ST_OVERLAPS","ST_POINT","ST_POINTN","ST_POINTS","ST_POLYGON","ST_RELATE","ST_STARTPOINT","ST_SYMDIFFERENCE","ST_TOUCHES","ST_UNION","ST_WITHIN","ST_X","ST_XMAX","ST_XMIN","ST_Y","ST_YMAX","ST_YMIN","SUBSTR","SUBSTRING","SUM","TAN","TANH","TDIGEST_AGG","TIMESTAMP_OBJECTID","TIMEZONE_HOUR","TIMEZONE_MINUTE","TO_BASE","TO_BASE32","TO_BASE64","TO_BASE64URL","TO_BIG_ENDIAN_32","TO_BIG_ENDIAN_64","TO_CHAR","TO_DATE","TO_ENCODED_POLYLINE","TO_GEOJSON_GEOMETRY","TO_GEOMETRY","TO_HEX","TO_IEEE754_32","TO_IEEE754_64","TO_ISO8601","TO_MILLISECONDS","TO_SPHERICAL_GEOGRAPHY","TO_TIMESTAMP","TO_UNIXTIME","TO_UTF8","TRANSFORM","TRANSFORM_KEYS","TRANSFORM_VALUES","TRANSLATE","TRIM","TRIM_ARRAY","TRUNCATE","TRY","TRY_CAST","TYPEOF","UPPER","URL_DECODE","URL_ENCODE","URL_EXTRACT_FRAGMENT","URL_EXTRACT_HOST","URL_EXTRACT_PARAMETER","URL_EXTRACT_PATH","URL_EXTRACT_PORT","URL_EXTRACT_PROTOCOL","URL_EXTRACT_QUERY","UUID","VALUES_AT_QUANTILES","VALUE_AT_QUANTILE","VARIANCE","VAR_POP","VAR_SAMP","VERSION","WEEK","WEEK_OF_YEAR","WIDTH_BUCKET","WILSON_INTERVAL_LOWER","WILSON_INTERVAL_UPPER","WITH_TIMEZONE","WORD_STEM","XXHASH64","YEAR","YEAR_OF_WEEK","YOW","ZIP","ZIP_WITH","CLASSIFIER","FIRST","LAST","MATCH_NUMBER","NEXT","PERMUTE","PREV"],Rd=["ABSENT","ADD","ADMIN","AFTER","ALL","ALTER","ANALYZE","AND","ANY","AS","ASC","AT","AUTHORIZATION","BERNOULLI","BETWEEN","BOTH","BY","CALL","CASCADE","CASE","CATALOGS","COLUMN","COLUMNS","COMMENT","COMMIT","COMMITTED","CONDITIONAL","CONSTRAINT","COPARTITION","CREATE","CROSS","CUBE","CURRENT","CURRENT_PATH","CURRENT_ROLE","DATA","DEALLOCATE","DEFAULT","DEFINE","DEFINER","DELETE","DENY","DESC","DESCRIBE","DESCRIPTOR","DISTINCT","DISTRIBUTED","DOUBLE","DROP","ELSE","EMPTY","ENCODING","END","ERROR","ESCAPE","EXCEPT","EXCLUDING","EXECUTE","EXISTS","EXPLAIN","FALSE","FETCH","FINAL","FIRST","FOLLOWING","FOR","FROM","FULL","FUNCTIONS","GRANT","GRANTED","GRANTS","GRAPHVIZ","GROUP","GROUPING","GROUPS","HAVING","IGNORE","IN","INCLUDING","INITIAL","INNER","INPUT","INSERT","INTERSECT","INTERVAL","INTO","INVOKER","IO","IS","ISOLATION","JOIN","JSON","JSON_ARRAY","JSON_OBJECT","KEEP","KEY","KEYS","LAST","LATERAL","LEADING","LEFT","LEVEL","LIKE","LIMIT","LOCAL","LOGICAL","MATCH","MATCHED","MATCHES","MATCH_RECOGNIZE","MATERIALIZED","MEASURES","NATURAL","NEXT","NFC","NFD","NFKC","NFKD","NO","NONE","NOT","NULL","NULLS","OBJECT","OF","OFFSET","OMIT","ON","ONE","ONLY","OPTION","OR","ORDER","ORDINALITY","OUTER","OUTPUT","OVER","OVERFLOW","PARTITION","PARTITIONS","PASSING","PAST","PATH","PATTERN","PER","PERMUTE","PRECEDING","PRECISION","PREPARE","PRIVILEGES","PROPERTIES","PRUNE","QUOTES","RANGE","READ","RECURSIVE","REFRESH","RENAME","REPEATABLE","RESET","RESPECT","RESTRICT","RETURNING","REVOKE","RIGHT","ROLE","ROLES","ROLLBACK","ROLLUP","ROW","ROWS","RUNNING","SCALAR","SCHEMA","SCHEMAS","SECURITY","SEEK","SELECT","SERIALIZABLE","SESSION","SET","SETS","SHOW","SKIP","SOME","START","STATS","STRING","SUBSET","SYSTEM","TABLE","TABLES","TABLESAMPLE","TEXT","THEN","TIES","TIME","TIMESTAMP","TO","TRAILING","TRANSACTION","TRUE","TYPE","UESCAPE","UNBOUNDED","UNCOMMITTED","UNCONDITIONAL","UNION","UNIQUE","UNKNOWN","UNMATCHED","UNNEST","UPDATE","USE","USER","USING","UTF16","UTF32","UTF8","VALIDATE","VALUE","VALUES","VERBOSE","VIEW","WHEN","WHERE","WINDOW","WITH","WITHIN","WITHOUT","WORK","WRAPPER","WRITE","ZONE"],Ad=["BIGINT","INT","INTEGER","SMALLINT","TINYINT","BOOLEAN","DATE","DECIMAL","REAL","DOUBLE","HYPERLOGLOG","QDIGEST","TDIGEST","P4HYPERLOGLOG","INTERVAL","TIMESTAMP","TIME","VARBINARY","VARCHAR","CHAR","ROW","ARRAY","MAP","JSON","JSON2016","IPADDRESS","GEOMETRY","UUID","SETDIGEST","JONIREGEXP","RE2JREGEXP","LIKEPATTERN","COLOR","CODEPOINTS","FUNCTION","JSONPATH"],Sd=x(["SELECT [ALL | DISTINCT]"]),Nd=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY [ALL | DISTINCT]","HAVING","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","FETCH {FIRST | NEXT}","INSERT INTO","VALUES","SET","MATCH_RECOGNIZE","MEASURES","ONE ROW PER MATCH","ALL ROWS PER MATCH","AFTER MATCH","PATTERN","SUBSET","DEFINE"]),Ji=x(["CREATE TABLE [IF NOT EXISTS]"]),Al=x(["CREATE [OR REPLACE] [MATERIALIZED] VIEW","UPDATE","DELETE FROM","DROP TABLE [IF EXISTS]","ALTER TABLE [IF EXISTS]","ADD COLUMN [IF NOT EXISTS]","DROP COLUMN [IF EXISTS]","RENAME COLUMN [IF EXISTS]","RENAME TO","SET AUTHORIZATION [USER | ROLE]","SET PROPERTIES","EXECUTE","TRUNCATE TABLE","ALTER SCHEMA","ALTER MATERIALIZED VIEW","ALTER VIEW","CREATE SCHEMA","CREATE ROLE","DROP SCHEMA","DROP MATERIALIZED VIEW","DROP VIEW","DROP ROLE","EXPLAIN","ANALYZE","EXPLAIN ANALYZE","EXPLAIN ANALYZE VERBOSE","USE","DESCRIBE INPUT","DESCRIBE OUTPUT","REFRESH MATERIALIZED VIEW","RESET SESSION","SET SESSION","SET PATH","SET TIME ZONE","SHOW GRANTS","SHOW CREATE TABLE","SHOW CREATE SCHEMA","SHOW CREATE VIEW","SHOW CREATE MATERIALIZED VIEW","SHOW TABLES","SHOW SCHEMAS","SHOW CATALOGS","SHOW COLUMNS","SHOW STATS FOR","SHOW ROLES","SHOW CURRENT ROLES","SHOW ROLE GRANTS","SHOW FUNCTIONS","SHOW SESSION"]),Id=x(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),ud=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),Od=x(["{ROWS | RANGE | GROUPS} BETWEEN","IS [NOT] DISTINCT FROM"]),cd=x([]),Cd={name:"trino",tokenizerOptions:{reservedSelect:Sd,reservedClauses:[...Nd,...Ji,...Al],reservedSetOperations:Id,reservedJoins:ud,reservedKeywordPhrases:Od,reservedDataTypePhrases:cd,reservedKeywords:Rd,reservedDataTypes:Ad,reservedFunctionNames:id,extraParens:["[]","{}"],stringTypes:[{quote:"''-qq",prefixes:["U&"]},{quote:"''-raw",prefixes:["X"],requirePrefix:!0}],identTypes:['""-qq'],paramTypes:{positional:!0},operators:["%","->","=>",":","||","|","^","$"]},formatOptions:{onelineClauses:[...Ji,...Al],tabularOnelineClauses:Al}},dd=["APPROX_COUNT_DISTINCT","AVG","CHECKSUM_AGG","COUNT","COUNT_BIG","GROUPING","GROUPING_ID","MAX","MIN","STDEV","STDEVP","SUM","VAR","VARP","CUME_DIST","FIRST_VALUE","LAG","LAST_VALUE","LEAD","PERCENTILE_CONT","PERCENTILE_DISC","PERCENT_RANK","Collation - COLLATIONPROPERTY","Collation - TERTIARY_WEIGHTS","@@DBTS","@@LANGID","@@LANGUAGE","@@LOCK_TIMEOUT","@@MAX_CONNECTIONS","@@MAX_PRECISION","@@NESTLEVEL","@@OPTIONS","@@REMSERVER","@@SERVERNAME","@@SERVICENAME","@@SPID","@@TEXTSIZE","@@VERSION","CAST","CONVERT","PARSE","TRY_CAST","TRY_CONVERT","TRY_PARSE","ASYMKEY_ID","ASYMKEYPROPERTY","CERTPROPERTY","CERT_ID","CRYPT_GEN_RANDOM","DECRYPTBYASYMKEY","DECRYPTBYCERT","DECRYPTBYKEY","DECRYPTBYKEYAUTOASYMKEY","DECRYPTBYKEYAUTOCERT","DECRYPTBYPASSPHRASE","ENCRYPTBYASYMKEY","ENCRYPTBYCERT","ENCRYPTBYKEY","ENCRYPTBYPASSPHRASE","HASHBYTES","IS_OBJECTSIGNED","KEY_GUID","KEY_ID","KEY_NAME","SIGNBYASYMKEY","SIGNBYCERT","SYMKEYPROPERTY","VERIFYSIGNEDBYCERT","VERIFYSIGNEDBYASYMKEY","@@CURSOR_ROWS","@@FETCH_STATUS","CURSOR_STATUS","DATALENGTH","IDENT_CURRENT","IDENT_INCR","IDENT_SEED","IDENTITY","SQL_VARIANT_PROPERTY","@@DATEFIRST","CURRENT_TIMESTAMP","CURRENT_TIMEZONE","CURRENT_TIMEZONE_ID","DATEADD","DATEDIFF","DATEDIFF_BIG","DATEFROMPARTS","DATENAME","DATEPART","DATETIME2FROMPARTS","DATETIMEFROMPARTS","DATETIMEOFFSETFROMPARTS","DAY","EOMONTH","GETDATE","GETUTCDATE","ISDATE","MONTH","SMALLDATETIMEFROMPARTS","SWITCHOFFSET","SYSDATETIME","SYSDATETIMEOFFSET","SYSUTCDATETIME","TIMEFROMPARTS","TODATETIMEOFFSET","YEAR","JSON","ISJSON","JSON_VALUE","JSON_QUERY","JSON_MODIFY","ABS","ACOS","ASIN","ATAN","ATN2","CEILING","COS","COT","DEGREES","EXP","FLOOR","LOG","LOG10","PI","POWER","RADIANS","RAND","ROUND","SIGN","SIN","SQRT","SQUARE","TAN","CHOOSE","GREATEST","IIF","LEAST","@@PROCID","APP_NAME","APPLOCK_MODE","APPLOCK_TEST","ASSEMBLYPROPERTY","COL_LENGTH","COL_NAME","COLUMNPROPERTY","DATABASEPROPERTYEX","DB_ID","DB_NAME","FILE_ID","FILE_IDEX","FILE_NAME","FILEGROUP_ID","FILEGROUP_NAME","FILEGROUPPROPERTY","FILEPROPERTY","FILEPROPERTYEX","FULLTEXTCATALOGPROPERTY","FULLTEXTSERVICEPROPERTY","INDEX_COL","INDEXKEY_PROPERTY","INDEXPROPERTY","NEXT VALUE FOR","OBJECT_DEFINITION","OBJECT_ID","OBJECT_NAME","OBJECT_SCHEMA_NAME","OBJECTPROPERTY","OBJECTPROPERTYEX","ORIGINAL_DB_NAME","PARSENAME","SCHEMA_ID","SCHEMA_NAME","SCOPE_IDENTITY","SERVERPROPERTY","STATS_DATE","TYPE_ID","TYPE_NAME","TYPEPROPERTY","DENSE_RANK","NTILE","RANK","ROW_NUMBER","PUBLISHINGSERVERNAME","CERTENCODED","CERTPRIVATEKEY","CURRENT_USER","DATABASE_PRINCIPAL_ID","HAS_DBACCESS","HAS_PERMS_BY_NAME","IS_MEMBER","IS_ROLEMEMBER","IS_SRVROLEMEMBER","LOGINPROPERTY","ORIGINAL_LOGIN","PERMISSIONS","PWDENCRYPT","PWDCOMPARE","SESSION_USER","SESSIONPROPERTY","SUSER_ID","SUSER_NAME","SUSER_SID","SUSER_SNAME","SYSTEM_USER","USER","USER_ID","USER_NAME","ASCII","CHARINDEX","CONCAT","CONCAT_WS","DIFFERENCE","FORMAT","LEFT","LEN","LOWER","LTRIM","PATINDEX","QUOTENAME","REPLACE","REPLICATE","REVERSE","RIGHT","RTRIM","SOUNDEX","SPACE","STR","STRING_AGG","STRING_ESCAPE","STUFF","SUBSTRING","TRANSLATE","TRIM","UNICODE","UPPER","$PARTITION","@@ERROR","@@IDENTITY","@@PACK_RECEIVED","@@ROWCOUNT","@@TRANCOUNT","BINARY_CHECKSUM","CHECKSUM","COMPRESS","CONNECTIONPROPERTY","CONTEXT_INFO","CURRENT_REQUEST_ID","CURRENT_TRANSACTION_ID","DECOMPRESS","ERROR_LINE","ERROR_MESSAGE","ERROR_NUMBER","ERROR_PROCEDURE","ERROR_SEVERITY","ERROR_STATE","FORMATMESSAGE","GET_FILESTREAM_TRANSACTION_CONTEXT","GETANSINULL","HOST_ID","HOST_NAME","ISNULL","ISNUMERIC","MIN_ACTIVE_ROWVERSION","NEWID","NEWSEQUENTIALID","ROWCOUNT_BIG","SESSION_CONTEXT","XACT_STATE","@@CONNECTIONS","@@CPU_BUSY","@@IDLE","@@IO_BUSY","@@PACK_SENT","@@PACKET_ERRORS","@@TIMETICKS","@@TOTAL_ERRORS","@@TOTAL_READ","@@TOTAL_WRITE","TEXTPTR","TEXTVALID","COLUMNS_UPDATED","EVENTDATA","TRIGGER_NESTLEVEL","UPDATE","COALESCE","NULLIF"],Ld=["ADD","ALL","ALTER","AND","ANY","AS","ASC","AUTHORIZATION","BACKUP","BEGIN","BETWEEN","BREAK","BROWSE","BULK","BY","CASCADE","CHECK","CHECKPOINT","CLOSE","CLUSTERED","COALESCE","COLLATE","COLUMN","COMMIT","COMPUTE","CONSTRAINT","CONTAINS","CONTAINSTABLE","CONTINUE","CONVERT","CREATE","CROSS","CURRENT","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","CURSOR","DATABASE","DBCC","DEALLOCATE","DECLARE","DEFAULT","DELETE","DENY","DESC","DISK","DISTINCT","DISTRIBUTED","DROP","DUMP","ERRLVL","ESCAPE","EXEC","EXECUTE","EXISTS","EXIT","EXTERNAL","FETCH","FILE","FILLFACTOR","FOR","FOREIGN","FREETEXT","FREETEXTTABLE","FROM","FULL","FUNCTION","GOTO","GRANT","GROUP","HAVING","HOLDLOCK","IDENTITY","IDENTITYCOL","IDENTITY_INSERT","IF","IN","INDEX","INNER","INSERT","INTERSECT","INTO","IS","JOIN","KEY","KILL","LEFT","LIKE","LINENO","LOAD","MERGE","NOCHECK","NONCLUSTERED","NOT","NULL","NULLIF","OF","OFF","OFFSETS","ON","OPEN","OPENDATASOURCE","OPENQUERY","OPENROWSET","OPENXML","OPTION","OR","ORDER","OUTER","OVER","PERCENT","PIVOT","PLAN","PRIMARY","PRINT","PROC","PROCEDURE","PUBLIC","RAISERROR","READ","READTEXT","RECONFIGURE","REFERENCES","REPLICATION","RESTORE","RESTRICT","RETURN","REVERT","REVOKE","RIGHT","ROLLBACK","ROWCOUNT","ROWGUIDCOL","RULE","SAVE","SCHEMA","SECURITYAUDIT","SELECT","SEMANTICKEYPHRASETABLE","SEMANTICSIMILARITYDETAILSTABLE","SEMANTICSIMILARITYTABLE","SESSION_USER","SET","SETUSER","SHUTDOWN","SOME","STATISTICS","SYSTEM_USER","TABLE","TABLESAMPLE","TEXTSIZE","THEN","TO","TOP","TRAN","TRANSACTION","TRIGGER","TRUNCATE","TRY_CONVERT","TSEQUAL","UNION","UNIQUE","UNPIVOT","UPDATE","UPDATETEXT","USE","USER","VALUES","VIEW","WAITFOR","WHERE","WHILE","WITH","WITHIN GROUP","WRITETEXT","$ACTION"],_d=["BINARY","BIT","CHAR","CHAR","CHARACTER","DATE","DATETIME2","DATETIMEOFFSET","DEC","DECIMAL","DOUBLE","FLOAT","INT","INTEGER","NATIONAL","NCHAR","NUMERIC","NVARCHAR","PRECISION","REAL","SMALLINT","TIME","TIMESTAMP","VARBINARY","VARCHAR"],fd=x(["SELECT [ALL | DISTINCT]"]),pd=x(["WITH","INTO","FROM","WHERE","GROUP BY","HAVING","WINDOW","PARTITION BY","ORDER BY","OFFSET","FETCH {FIRST | NEXT}","FOR {BROWSE | XML | JSON}","OPTION","INSERT [INTO]","VALUES","SET","MERGE [INTO]","WHEN [NOT] MATCHED [BY TARGET | BY SOURCE] [THEN]","UPDATE SET"]),zi=x(["CREATE TABLE"]),Sl=x(["CREATE [OR ALTER] [MATERIALIZED] VIEW","UPDATE","WHERE CURRENT OF","DELETE [FROM]","DROP TABLE [IF EXISTS]","ALTER TABLE","ADD","DROP COLUMN [IF EXISTS]","ALTER COLUMN","TRUNCATE TABLE","CREATE [UNIQUE] [CLUSTERED] INDEX","CREATE DATABASE","ALTER DATABASE","DROP DATABASE [IF EXISTS]","CREATE [OR ALTER] [PARTITION] {FUNCTION | PROCEDURE | PROC}","ALTER [PARTITION] {FUNCTION | PROCEDURE | PROC}","DROP [PARTITION] {FUNCTION | PROCEDURE | PROC} [IF EXISTS]","GO","USE","ADD SENSITIVITY CLASSIFICATION","ADD SIGNATURE","AGGREGATE","ANSI_DEFAULTS","ANSI_NULLS","ANSI_NULL_DFLT_OFF","ANSI_NULL_DFLT_ON","ANSI_PADDING","ANSI_WARNINGS","APPLICATION ROLE","ARITHABORT","ARITHIGNORE","ASSEMBLY","ASYMMETRIC KEY","AUTHORIZATION","AVAILABILITY GROUP","BACKUP","BACKUP CERTIFICATE","BACKUP MASTER KEY","BACKUP SERVICE MASTER KEY","BEGIN CONVERSATION TIMER","BEGIN DIALOG CONVERSATION","BROKER PRIORITY","BULK INSERT","CERTIFICATE","CLOSE MASTER KEY","CLOSE SYMMETRIC KEY","COLUMN ENCRYPTION KEY","COLUMN MASTER KEY","COLUMNSTORE INDEX","CONCAT_NULL_YIELDS_NULL","CONTEXT_INFO","CONTRACT","CREDENTIAL","CRYPTOGRAPHIC PROVIDER","CURSOR_CLOSE_ON_COMMIT","DATABASE","DATABASE AUDIT SPECIFICATION","DATABASE ENCRYPTION KEY","DATABASE HADR","DATABASE SCOPED CONFIGURATION","DATABASE SCOPED CREDENTIAL","DATABASE SET","DATEFIRST","DATEFORMAT","DEADLOCK_PRIORITY","DENY","DENY XML","DISABLE TRIGGER","ENABLE TRIGGER","END CONVERSATION","ENDPOINT","EVENT NOTIFICATION","EVENT SESSION","EXECUTE AS","EXTERNAL DATA SOURCE","EXTERNAL FILE FORMAT","EXTERNAL LANGUAGE","EXTERNAL LIBRARY","EXTERNAL RESOURCE POOL","EXTERNAL TABLE","FIPS_FLAGGER","FMTONLY","FORCEPLAN","FULLTEXT CATALOG","FULLTEXT INDEX","FULLTEXT STOPLIST","GET CONVERSATION GROUP","GET_TRANSMISSION_STATUS","GRANT","GRANT XML","IDENTITY_INSERT","IMPLICIT_TRANSACTIONS","INDEX","LANGUAGE","LOCK_TIMEOUT","LOGIN","MASTER KEY","MESSAGE TYPE","MOVE CONVERSATION","NOCOUNT","NOEXEC","NUMERIC_ROUNDABORT","OFFSETS","OPEN MASTER KEY","OPEN SYMMETRIC KEY","PARSEONLY","PARTITION SCHEME","QUERY_GOVERNOR_COST_LIMIT","QUEUE","QUOTED_IDENTIFIER","RECEIVE","REMOTE SERVICE BINDING","REMOTE_PROC_TRANSACTIONS","RESOURCE GOVERNOR","RESOURCE POOL","RESTORE","RESTORE FILELISTONLY","RESTORE HEADERONLY","RESTORE LABELONLY","RESTORE MASTER KEY","RESTORE REWINDONLY","RESTORE SERVICE MASTER KEY","RESTORE VERIFYONLY","REVERT","REVOKE","REVOKE XML","ROLE","ROUTE","ROWCOUNT","RULE","SCHEMA","SEARCH PROPERTY LIST","SECURITY POLICY","SELECTIVE XML INDEX","SEND","SENSITIVITY CLASSIFICATION","SEQUENCE","SERVER AUDIT","SERVER AUDIT SPECIFICATION","SERVER CONFIGURATION","SERVER ROLE","SERVICE","SERVICE MASTER KEY","SETUSER","SHOWPLAN_ALL","SHOWPLAN_TEXT","SHOWPLAN_XML","SIGNATURE","SPATIAL INDEX","STATISTICS","STATISTICS IO","STATISTICS PROFILE","STATISTICS TIME","STATISTICS XML","SYMMETRIC KEY","SYNONYM","TABLE","TABLE IDENTITY","TEXTSIZE","TRANSACTION ISOLATION LEVEL","TRIGGER","TYPE","UPDATE STATISTICS","USER","WORKLOAD GROUP","XACT_ABORT","XML INDEX","XML SCHEMA COLLECTION"]),md=x(["UNION [ALL]","EXCEPT","INTERSECT"]),Dd=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","{CROSS | OUTER} APPLY"]),Pd=x(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","{ROWS | RANGE} BETWEEN"]),hd=x([]),Md={name:"transactsql",tokenizerOptions:{reservedSelect:fd,reservedClauses:[...pd,...zi,...Sl],reservedSetOperations:md,reservedJoins:Dd,reservedKeywordPhrases:Pd,reservedDataTypePhrases:hd,reservedKeywords:Ld,reservedDataTypes:_d,reservedFunctionNames:dd,nestedBlockComments:!0,stringTypes:[{quote:"''-qq",prefixes:["N"]},"{}"],identTypes:['""-qq',"[]"],identChars:{first:"#@",rest:"#@$"},paramTypes:{named:["@"],quoted:["@"]},operators:["%","&","|","^","~","!<","!>","+=","-=","*=","/=","%=","|=","&=","^=","::",":"],propertyAccessOperators:[".."]},formatOptions:{alwaysDenseOperators:["::"],onelineClauses:[...zi,...Sl],tabularOnelineClauses:Sl}},Ud=["ADD","ALL","ALTER","ANALYZE","AND","AS","ASC","ASENSITIVE","BEFORE","BETWEEN","_BINARY","BOTH","BY","CALL","CASCADE","CASE","CHANGE","CHECK","COLLATE","COLUMN","CONDITION","CONSTRAINT","CONTINUE","CONVERT","CREATE","CROSS","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","CURSOR","DATABASE","DATABASES","DAY_HOUR","DAY_MICROSECOND","DAY_MINUTE","DAY_SECOND","DECLARE","DEFAULT","DELAYED","DELETE","DESC","DESCRIBE","DETERMINISTIC","DISTINCT","DISTINCTROW","DIV","DROP","DUAL","EACH","ELSE","ELSEIF","ENCLOSED","ESCAPED","EXCEPT","EXISTS","EXIT","EXPLAIN","EXTRA_JOIN","FALSE","FETCH","FOR","FORCE","FORCE_COMPILED_MODE","FORCE_INTERPRETER_MODE","FOREIGN","FROM","FULL","FULLTEXT","GRANT","GROUP","HAVING","HEARTBEAT_NO_LOGGING","HIGH_PRIORITY","HOUR_MICROSECOND","HOUR_MINUTE","HOUR_SECOND","IF","IGNORE","IN","INDEX","INFILE","INNER","INOUT","INSENSITIVE","INSERT","IN","_INTERNAL_DYNAMIC_TYPECAST","INTERSECT","INTERVAL","INTO","ITERATE","JOIN","KEY","KEYS","KILL","LEADING","LEAVE","LEFT","LIKE","LIMIT","LINES","LOAD","LOCALTIME","LOCALTIMESTAMP","LOCK","LOOP","LOW_PRIORITY","MATCH","MAXVALUE","MINUS","MINUTE_MICROSECOND","MINUTE_SECOND","MOD","MODIFIES","NATURAL","NO_QUERY_REWRITE","NOT","NO_WRITE_TO_BINLOG","NO_QUERY_REWRITE","NULL","ON","OPTIMIZE","OPTION","OPTIONALLY","OR","ORDER","OUT","OUTER","OUTFILE","OVER","PRIMARY","PROCEDURE","PURGE","RANGE","READ","READS","REFERENCES","REGEXP","RELEASE","RENAME","REPEAT","REPLACE","REQUIRE","RESTRICT","RETURN","REVOKE","RIGHT","RIGHT_ANTI_JOIN","RIGHT_SEMI_JOIN","RIGHT_STRAIGHT_JOIN","RLIKE","SCHEMA","SCHEMAS","SECOND_MICROSECOND","SELECT","SEMI_JOIN","SENSITIVE","SEPARATOR","SET","SHOW","SIGNAL","SPATIAL","SPECIFIC","SQL","SQL_BIG_RESULT","SQL_BUFFER_RESULT","SQL_CACHE","SQL_CALC_FOUND_ROWS","SQLEXCEPTION","SQL_NO_CACHE","SQL_NO_LOGGING","SQL_SMALL_RESULT","SQLSTATE","SQLWARNING","STRAIGHT_JOIN","TABLE","TERMINATED","THEN","TO","TRAILING","TRIGGER","TRUE","UNBOUNDED","UNDO","UNION","UNIQUE","UNLOCK","UPDATE","USAGE","USE","USING","UTC_DATE","UTC_TIME","UTC_TIMESTAMP","_UTF8","VALUES","WHEN","WHERE","WHILE","WINDOW","WITH","WITHIN","WRITE","XOR","YEAR_MONTH","ZEROFILL"],xd=["BIGINT","BINARY","BIT","BLOB","CHAR","CHARACTER","DATETIME","DEC","DECIMAL","DOUBLE PRECISION","DOUBLE","ENUM","FIXED","FLOAT","FLOAT4","FLOAT8","INT","INT1","INT2","INT3","INT4","INT8","INTEGER","LONG","LONGBLOB","LONGTEXT","MEDIUMBLOB","MEDIUMINT","MEDIUMTEXT","MIDDLEINT","NATIONAL CHAR","NATIONAL VARCHAR","NUMERIC","PRECISION","REAL","SMALLINT","TEXT","TIME","TIMESTAMP","TINYBLOB","TINYINT","TINYTEXT","UNSIGNED","VARBINARY","VARCHAR","VARCHARACTER","YEAR"],yd=["ABS","ACOS","ADDDATE","ADDTIME","AES_DECRYPT","AES_ENCRYPT","ANY_VALUE","APPROX_COUNT_DISTINCT","APPROX_COUNT_DISTINCT_ACCUMULATE","APPROX_COUNT_DISTINCT_COMBINE","APPROX_COUNT_DISTINCT_ESTIMATE","APPROX_GEOGRAPHY_INTERSECTS","APPROX_PERCENTILE","ASCII","ASIN","ATAN","ATAN2","AVG","BIN","BINARY","BIT_AND","BIT_COUNT","BIT_OR","BIT_XOR","CAST","CEIL","CEILING","CHAR","CHARACTER_LENGTH","CHAR_LENGTH","CHARSET","COALESCE","COERCIBILITY","COLLATION","COLLECT","CONCAT","CONCAT_WS","CONNECTION_ID","CONV","CONVERT","CONVERT_TZ","COS","COT","COUNT","CUME_DIST","CURDATE","CURRENT_DATE","CURRENT_ROLE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","CURTIME","DATABASE","DATE","DATE_ADD","DATEDIFF","DATE_FORMAT","DATE_SUB","DATE_TRUNC","DAY","DAYNAME","DAYOFMONTH","DAYOFWEEK","DAYOFYEAR","DECODE","DEFAULT","DEGREES","DENSE_RANK","DIV","DOT_PRODUCT","ELT","EUCLIDEAN_DISTANCE","EXP","EXTRACT","FIELD","FIRST","FIRST_VALUE","FLOOR","FORMAT","FOUND_ROWS","FROM_BASE64","FROM_DAYS","FROM_UNIXTIME","GEOGRAPHY_AREA","GEOGRAPHY_CONTAINS","GEOGRAPHY_DISTANCE","GEOGRAPHY_INTERSECTS","GEOGRAPHY_LATITUDE","GEOGRAPHY_LENGTH","GEOGRAPHY_LONGITUDE","GEOGRAPHY_POINT","GEOGRAPHY_WITHIN_DISTANCE","GEOMETRY_AREA","GEOMETRY_CONTAINS","GEOMETRY_DISTANCE","GEOMETRY_FILTER","GEOMETRY_INTERSECTS","GEOMETRY_LENGTH","GEOMETRY_POINT","GEOMETRY_WITHIN_DISTANCE","GEOMETRY_X","GEOMETRY_Y","GREATEST","GROUPING","GROUP_CONCAT","HEX","HIGHLIGHT","HOUR","ICU_VERSION","IF","IFNULL","INET_ATON","INET_NTOA","INET6_ATON","INET6_NTOA","INITCAP","INSERT","INSTR","INTERVAL","IS","IS NULL","JSON_AGG","JSON_ARRAY_CONTAINS_DOUBLE","JSON_ARRAY_CONTAINS_JSON","JSON_ARRAY_CONTAINS_STRING","JSON_ARRAY_PUSH_DOUBLE","JSON_ARRAY_PUSH_JSON","JSON_ARRAY_PUSH_STRING","JSON_DELETE_KEY","JSON_EXTRACT_DOUBLE","JSON_EXTRACT_JSON","JSON_EXTRACT_STRING","JSON_EXTRACT_BIGINT","JSON_GET_TYPE","JSON_LENGTH","JSON_SET_DOUBLE","JSON_SET_JSON","JSON_SET_STRING","JSON_SPLICE_DOUBLE","JSON_SPLICE_JSON","JSON_SPLICE_STRING","LAG","LAST_DAY","LAST_VALUE","LCASE","LEAD","LEAST","LEFT","LENGTH","LIKE","LN","LOCALTIME","LOCALTIMESTAMP","LOCATE","LOG","LOG10","LOG2","LPAD","LTRIM","MATCH","MAX","MD5","MEDIAN","MICROSECOND","MIN","MINUTE","MOD","MONTH","MONTHNAME","MONTHS_BETWEEN","NOT","NOW","NTH_VALUE","NTILE","NULLIF","OCTET_LENGTH","PERCENT_RANK","PERCENTILE_CONT","PERCENTILE_DISC","PI","PIVOT","POSITION","POW","POWER","QUARTER","QUOTE","RADIANS","RAND","RANK","REGEXP","REPEAT","REPLACE","REVERSE","RIGHT","RLIKE","ROUND","ROW_COUNT","ROW_NUMBER","RPAD","RTRIM","SCALAR","SCHEMA","SEC_TO_TIME","SHA1","SHA2","SIGMOID","SIGN","SIN","SLEEP","SPLIT","SOUNDEX","SOUNDS LIKE","SOURCE_POS_WAIT","SPACE","SQRT","STDDEV","STDDEV_POP","STDDEV_SAMP","STR_TO_DATE","SUBDATE","SUBSTR","SUBSTRING","SUBSTRING_INDEX","SUM","SYS_GUID","TAN","TIME","TIMEDIFF","TIME_BUCKET","TIME_FORMAT","TIMESTAMP","TIMESTAMPADD","TIMESTAMPDIFF","TIME_TO_SEC","TO_BASE64","TO_CHAR","TO_DAYS","TO_JSON","TO_NUMBER","TO_SECONDS","TO_TIMESTAMP","TRIM","TRUNC","TRUNCATE","UCASE","UNHEX","UNIX_TIMESTAMP","UPDATEXML","UPPER","UTC_DATE","UTC_TIME","UTC_TIMESTAMP","UUID","VALUES","VARIANCE","VAR_POP","VAR_SAMP","VECTOR_SUB","VERSION","WEEK","WEEKDAY","WEEKOFYEAR","YEAR"],gd=x(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),Gd=x(["WITH","FROM","WHERE","GROUP BY","HAVING","PARTITION BY","ORDER BY","LIMIT","OFFSET","INSERT [IGNORE] [INTO]","VALUES","REPLACE [INTO]","ON DUPLICATE KEY UPDATE","SET","CREATE [OR REPLACE] [TEMPORARY] PROCEDURE [IF NOT EXISTS]","CREATE [OR REPLACE] [EXTERNAL] FUNCTION"]),Qi=x(["CREATE [ROWSTORE] [REFERENCE | TEMPORARY | GLOBAL TEMPORARY] TABLE [IF NOT EXISTS]"]),Nl=x(["CREATE VIEW","UPDATE","DELETE [FROM]","DROP [TEMPORARY] TABLE [IF EXISTS]","ALTER [ONLINE] TABLE","ADD [COLUMN]","ADD [UNIQUE] {INDEX | KEY}","DROP [COLUMN]","MODIFY [COLUMN]","CHANGE","RENAME [TO | AS]","TRUNCATE [TABLE]","ADD AGGREGATOR","ADD LEAF","AGGREGATOR SET AS MASTER","ALTER DATABASE","ALTER PIPELINE","ALTER RESOURCE POOL","ALTER USER","ALTER VIEW","ANALYZE TABLE","ATTACH DATABASE","ATTACH LEAF","ATTACH LEAF ALL","BACKUP DATABASE","BINLOG","BOOTSTRAP AGGREGATOR","CACHE INDEX","CALL","CHANGE","CHANGE MASTER TO","CHANGE REPLICATION FILTER","CHANGE REPLICATION SOURCE TO","CHECK BLOB CHECKSUM","CHECK TABLE","CHECKSUM TABLE","CLEAR ORPHAN DATABASES","CLONE","COMMIT","CREATE DATABASE","CREATE GROUP","CREATE INDEX","CREATE LINK","CREATE MILESTONE","CREATE PIPELINE","CREATE RESOURCE POOL","CREATE ROLE","CREATE USER","DEALLOCATE PREPARE","DESCRIBE","DETACH DATABASE","DETACH PIPELINE","DROP DATABASE","DROP FUNCTION","DROP INDEX","DROP LINK","DROP PIPELINE","DROP PROCEDURE","DROP RESOURCE POOL","DROP ROLE","DROP USER","DROP VIEW","EXECUTE","EXPLAIN","FLUSH","FORCE","GRANT","HANDLER","HELP","KILL CONNECTION","KILLALL QUERIES","LOAD DATA","LOAD INDEX INTO CACHE","LOAD XML","LOCK INSTANCE FOR BACKUP","LOCK TABLES","MASTER_POS_WAIT","OPTIMIZE TABLE","PREPARE","PURGE BINARY LOGS","REBALANCE PARTITIONS","RELEASE SAVEPOINT","REMOVE AGGREGATOR","REMOVE LEAF","REPAIR TABLE","REPLACE","REPLICATE DATABASE","RESET","RESET MASTER","RESET PERSIST","RESET REPLICA","RESET SLAVE","RESTART","RESTORE DATABASE","RESTORE REDUNDANCY","REVOKE","ROLLBACK","ROLLBACK TO SAVEPOINT","SAVEPOINT","SET CHARACTER SET","SET DEFAULT ROLE","SET NAMES","SET PASSWORD","SET RESOURCE GROUP","SET ROLE","SET TRANSACTION","SHOW","SHOW CHARACTER SET","SHOW COLLATION","SHOW COLUMNS","SHOW CREATE DATABASE","SHOW CREATE FUNCTION","SHOW CREATE PIPELINE","SHOW CREATE PROCEDURE","SHOW CREATE TABLE","SHOW CREATE USER","SHOW CREATE VIEW","SHOW DATABASES","SHOW ENGINE","SHOW ENGINES","SHOW ERRORS","SHOW FUNCTION CODE","SHOW FUNCTION STATUS","SHOW GRANTS","SHOW INDEX","SHOW MASTER STATUS","SHOW OPEN TABLES","SHOW PLUGINS","SHOW PRIVILEGES","SHOW PROCEDURE CODE","SHOW PROCEDURE STATUS","SHOW PROCESSLIST","SHOW PROFILE","SHOW PROFILES","SHOW RELAYLOG EVENTS","SHOW REPLICA STATUS","SHOW REPLICAS","SHOW SLAVE","SHOW SLAVE HOSTS","SHOW STATUS","SHOW TABLE STATUS","SHOW TABLES","SHOW VARIABLES","SHOW WARNINGS","SHUTDOWN","SNAPSHOT DATABASE","SOURCE_POS_WAIT","START GROUP_REPLICATION","START PIPELINE","START REPLICA","START SLAVE","START TRANSACTION","STOP GROUP_REPLICATION","STOP PIPELINE","STOP REPLICA","STOP REPLICATING","STOP SLAVE","TEST PIPELINE","UNLOCK INSTANCE","UNLOCK TABLES","USE","XA","ITERATE","LEAVE","LOOP","REPEAT","RETURN","WHILE"]),vd=x(["UNION [ALL | DISTINCT]","EXCEPT","INTERSECT","MINUS"]),Hd=x(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),Bd=x(["ON DELETE","ON UPDATE","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),Fd=x([]),Yd={name:"singlestoredb",tokenizerOptions:{reservedSelect:gd,reservedClauses:[...Gd,...Qi,...Nl],reservedSetOperations:vd,reservedJoins:Hd,reservedKeywordPhrases:Bd,reservedDataTypePhrases:Fd,reservedKeywords:Ud,reservedDataTypes:xd,reservedFunctionNames:yd,stringTypes:['""-qq-bs',"''-qq-bs",{quote:"''-raw",prefixes:["B","X"],requirePrefix:!0}],identTypes:["``"],identChars:{first:"$",rest:"$",allowFirstCharNumber:!0},variableTypes:[{regex:"@@?[A-Za-z0-9_$]+"},{quote:"``",prefixes:["@"],requirePrefix:!0}],lineCommentTypes:["--","#"],operators:[":=","&","|","^","~","<<",">>","<=>","&&","||","::","::$","::%",":>","!:>","*.*"],postProcess:CT},formatOptions:{alwaysDenseOperators:["::","::$","::%"],onelineClauses:[...Qi,...Nl],tabularOnelineClauses:Nl}},wd=["ABS","ACOS","ACOSH","ADD_MONTHS","ALL_USER_NAMES","ANY_VALUE","APPROX_COUNT_DISTINCT","APPROX_PERCENTILE","APPROX_PERCENTILE_ACCUMULATE","APPROX_PERCENTILE_COMBINE","APPROX_PERCENTILE_ESTIMATE","APPROX_TOP_K","APPROX_TOP_K_ACCUMULATE","APPROX_TOP_K_COMBINE","APPROX_TOP_K_ESTIMATE","APPROXIMATE_JACCARD_INDEX","APPROXIMATE_SIMILARITY","ARRAY_AGG","ARRAY_APPEND","ARRAY_CAT","ARRAY_COMPACT","ARRAY_CONSTRUCT","ARRAY_CONSTRUCT_COMPACT","ARRAY_CONTAINS","ARRAY_INSERT","ARRAY_INTERSECTION","ARRAY_POSITION","ARRAY_PREPEND","ARRAY_SIZE","ARRAY_SLICE","ARRAY_TO_STRING","ARRAY_UNION_AGG","ARRAY_UNIQUE_AGG","ARRAYS_OVERLAP","AS_ARRAY","AS_BINARY","AS_BOOLEAN","AS_CHAR","AS_VARCHAR","AS_DATE","AS_DECIMAL","AS_NUMBER","AS_DOUBLE","AS_REAL","AS_INTEGER","AS_OBJECT","AS_TIME","AS_TIMESTAMP_LTZ","AS_TIMESTAMP_NTZ","AS_TIMESTAMP_TZ","ASCII","ASIN","ASINH","ATAN","ATAN2","ATANH","AUTO_REFRESH_REGISTRATION_HISTORY","AUTOMATIC_CLUSTERING_HISTORY","AVG","BASE64_DECODE_BINARY","BASE64_DECODE_STRING","BASE64_ENCODE","BIT_LENGTH","BITAND","BITAND_AGG","BITMAP_BIT_POSITION","BITMAP_BUCKET_NUMBER","BITMAP_CONSTRUCT_AGG","BITMAP_COUNT","BITMAP_OR_AGG","BITNOT","BITOR","BITOR_AGG","BITSHIFTLEFT","BITSHIFTRIGHT","BITXOR","BITXOR_AGG","BOOLAND","BOOLAND_AGG","BOOLNOT","BOOLOR","BOOLOR_AGG","BOOLXOR","BOOLXOR_AGG","BUILD_SCOPED_FILE_URL","BUILD_STAGE_FILE_URL","CASE","CAST","CBRT","CEIL","CHARINDEX","CHECK_JSON","CHECK_XML","CHR","CHAR","COALESCE","COLLATE","COLLATION","COMPLETE_TASK_GRAPHS","COMPRESS","CONCAT","CONCAT_WS","CONDITIONAL_CHANGE_EVENT","CONDITIONAL_TRUE_EVENT","CONTAINS","CONVERT_TIMEZONE","COPY_HISTORY","CORR","COS","COSH","COT","COUNT","COUNT_IF","COVAR_POP","COVAR_SAMP","CUME_DIST","CURRENT_ACCOUNT","CURRENT_AVAILABLE_ROLES","CURRENT_CLIENT","CURRENT_DATABASE","CURRENT_DATE","CURRENT_IP_ADDRESS","CURRENT_REGION","CURRENT_ROLE","CURRENT_SCHEMA","CURRENT_SCHEMAS","CURRENT_SECONDARY_ROLES","CURRENT_SESSION","CURRENT_STATEMENT","CURRENT_TASK_GRAPHS","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_TRANSACTION","CURRENT_USER","CURRENT_VERSION","CURRENT_WAREHOUSE","DATA_TRANSFER_HISTORY","DATABASE_REFRESH_HISTORY","DATABASE_REFRESH_PROGRESS","DATABASE_REFRESH_PROGRESS_BY_JOB","DATABASE_STORAGE_USAGE_HISTORY","DATE_FROM_PARTS","DATE_PART","DATE_TRUNC","DATEADD","DATEDIFF","DAYNAME","DECODE","DECOMPRESS_BINARY","DECOMPRESS_STRING","DECRYPT","DECRYPT_RAW","DEGREES","DENSE_RANK","DIV0","EDITDISTANCE","ENCRYPT","ENCRYPT_RAW","ENDSWITH","EQUAL_NULL","EXP","EXPLAIN_JSON","EXTERNAL_FUNCTIONS_HISTORY","EXTERNAL_TABLE_FILES","EXTERNAL_TABLE_FILE_REGISTRATION_HISTORY","EXTRACT","EXTRACT_SEMANTIC_CATEGORIES","FACTORIAL","FILTER","FIRST_VALUE","FLATTEN","FLOOR","GENERATE_COLUMN_DESCRIPTION","GENERATOR","GET","GET_ABSOLUTE_PATH","GET_DDL","GET_IGNORE_CASE","GET_OBJECT_REFERENCES","GET_PATH","GET_PRESIGNED_URL","GET_RELATIVE_PATH","GET_STAGE_LOCATION","GETBIT","GREATEST","GREATEST_IGNORE_NULLS","GROUPING","GROUPING_ID","HASH","HASH_AGG","HAVERSINE","HEX_DECODE_BINARY","HEX_DECODE_STRING","HEX_ENCODE","HLL","HLL_ACCUMULATE","HLL_COMBINE","HLL_ESTIMATE","HLL_EXPORT","HLL_IMPORT","HOUR","MINUTE","SECOND","IDENTIFIER","IFF","IFNULL","ILIKE","ILIKE ANY","INFER_SCHEMA","INITCAP","INSERT","INVOKER_ROLE","INVOKER_SHARE","IS_ARRAY","IS_BINARY","IS_BOOLEAN","IS_CHAR","IS_VARCHAR","IS_DATE","IS_DATE_VALUE","IS_DECIMAL","IS_DOUBLE","IS_REAL","IS_GRANTED_TO_INVOKER_ROLE","IS_INTEGER","IS_NULL_VALUE","IS_OBJECT","IS_ROLE_IN_SESSION","IS_TIME","IS_TIMESTAMP_LTZ","IS_TIMESTAMP_NTZ","IS_TIMESTAMP_TZ","JAROWINKLER_SIMILARITY","JSON_EXTRACT_PATH_TEXT","KURTOSIS","LAG","LAST_DAY","LAST_QUERY_ID","LAST_TRANSACTION","LAST_VALUE","LEAD","LEAST","LEFT","LENGTH","LEN","LIKE","LIKE ALL","LIKE ANY","LISTAGG","LN","LOCALTIME","LOCALTIMESTAMP","LOG","LOGIN_HISTORY","LOGIN_HISTORY_BY_USER","LOWER","LPAD","LTRIM","MATERIALIZED_VIEW_REFRESH_HISTORY","MD5","MD5_HEX","MD5_BINARY","MD5_NUMBER — Obsoleted","MD5_NUMBER_LOWER64","MD5_NUMBER_UPPER64","MEDIAN","MIN","MAX","MINHASH","MINHASH_COMBINE","MOD","MODE","MONTHNAME","MONTHS_BETWEEN","NEXT_DAY","NORMAL","NTH_VALUE","NTILE","NULLIF","NULLIFZERO","NVL","NVL2","OBJECT_AGG","OBJECT_CONSTRUCT","OBJECT_CONSTRUCT_KEEP_NULL","OBJECT_DELETE","OBJECT_INSERT","OBJECT_KEYS","OBJECT_PICK","OCTET_LENGTH","PARSE_IP","PARSE_JSON","PARSE_URL","PARSE_XML","PERCENT_RANK","PERCENTILE_CONT","PERCENTILE_DISC","PI","PIPE_USAGE_HISTORY","POLICY_CONTEXT","POLICY_REFERENCES","POSITION","POW","POWER","PREVIOUS_DAY","QUERY_ACCELERATION_HISTORY","QUERY_HISTORY","QUERY_HISTORY_BY_SESSION","QUERY_HISTORY_BY_USER","QUERY_HISTORY_BY_WAREHOUSE","RADIANS","RANDOM","RANDSTR","RANK","RATIO_TO_REPORT","REGEXP","REGEXP_COUNT","REGEXP_INSTR","REGEXP_LIKE","REGEXP_REPLACE","REGEXP_SUBSTR","REGEXP_SUBSTR_ALL","REGR_AVGX","REGR_AVGY","REGR_COUNT","REGR_INTERCEPT","REGR_R2","REGR_SLOPE","REGR_SXX","REGR_SXY","REGR_SYY","REGR_VALX","REGR_VALY","REPEAT","REPLACE","REPLICATION_GROUP_REFRESH_HISTORY","REPLICATION_GROUP_REFRESH_PROGRESS","REPLICATION_GROUP_REFRESH_PROGRESS_BY_JOB","REPLICATION_GROUP_USAGE_HISTORY","REPLICATION_USAGE_HISTORY","REST_EVENT_HISTORY","RESULT_SCAN","REVERSE","RIGHT","RLIKE","ROUND","ROW_NUMBER","RPAD","RTRIM","RTRIMMED_LENGTH","SEARCH_OPTIMIZATION_HISTORY","SEQ1","SEQ2","SEQ4","SEQ8","SERVERLESS_TASK_HISTORY","SHA1","SHA1_HEX","SHA1_BINARY","SHA2","SHA2_HEX","SHA2_BINARY","SIGN","SIN","SINH","SKEW","SOUNDEX","SPACE","SPLIT","SPLIT_PART","SPLIT_TO_TABLE","SQRT","SQUARE","ST_AREA","ST_ASEWKB","ST_ASEWKT","ST_ASGEOJSON","ST_ASWKB","ST_ASBINARY","ST_ASWKT","ST_ASTEXT","ST_AZIMUTH","ST_CENTROID","ST_COLLECT","ST_CONTAINS","ST_COVEREDBY","ST_COVERS","ST_DIFFERENCE","ST_DIMENSION","ST_DISJOINT","ST_DISTANCE","ST_DWITHIN","ST_ENDPOINT","ST_ENVELOPE","ST_GEOGFROMGEOHASH","ST_GEOGPOINTFROMGEOHASH","ST_GEOGRAPHYFROMWKB","ST_GEOGRAPHYFROMWKT","ST_GEOHASH","ST_GEOMETRYFROMWKB","ST_GEOMETRYFROMWKT","ST_HAUSDORFFDISTANCE","ST_INTERSECTION","ST_INTERSECTS","ST_LENGTH","ST_MAKEGEOMPOINT","ST_GEOM_POINT","ST_MAKELINE","ST_MAKEPOINT","ST_POINT","ST_MAKEPOLYGON","ST_POLYGON","ST_NPOINTS","ST_NUMPOINTS","ST_PERIMETER","ST_POINTN","ST_SETSRID","ST_SIMPLIFY","ST_SRID","ST_STARTPOINT","ST_SYMDIFFERENCE","ST_UNION","ST_WITHIN","ST_X","ST_XMAX","ST_XMIN","ST_Y","ST_YMAX","ST_YMIN","STAGE_DIRECTORY_FILE_REGISTRATION_HISTORY","STAGE_STORAGE_USAGE_HISTORY","STARTSWITH","STDDEV","STDDEV_POP","STDDEV_SAMP","STRIP_NULL_VALUE","STRTOK","STRTOK_SPLIT_TO_TABLE","STRTOK_TO_ARRAY","SUBSTR","SUBSTRING","SUM","SYSDATE","SYSTEM$ABORT_SESSION","SYSTEM$ABORT_TRANSACTION","SYSTEM$AUTHORIZE_PRIVATELINK","SYSTEM$AUTHORIZE_STAGE_PRIVATELINK_ACCESS","SYSTEM$BEHAVIOR_CHANGE_BUNDLE_STATUS","SYSTEM$CANCEL_ALL_QUERIES","SYSTEM$CANCEL_QUERY","SYSTEM$CLUSTERING_DEPTH","SYSTEM$CLUSTERING_INFORMATION","SYSTEM$CLUSTERING_RATIO ","SYSTEM$CURRENT_USER_TASK_NAME","SYSTEM$DATABASE_REFRESH_HISTORY ","SYSTEM$DATABASE_REFRESH_PROGRESS","SYSTEM$DATABASE_REFRESH_PROGRESS_BY_JOB ","SYSTEM$DISABLE_BEHAVIOR_CHANGE_BUNDLE","SYSTEM$DISABLE_DATABASE_REPLICATION","SYSTEM$ENABLE_BEHAVIOR_CHANGE_BUNDLE","SYSTEM$ESTIMATE_QUERY_ACCELERATION","SYSTEM$ESTIMATE_SEARCH_OPTIMIZATION_COSTS","SYSTEM$EXPLAIN_JSON_TO_TEXT","SYSTEM$EXPLAIN_PLAN_JSON","SYSTEM$EXTERNAL_TABLE_PIPE_STATUS","SYSTEM$GENERATE_SAML_CSR","SYSTEM$GENERATE_SCIM_ACCESS_TOKEN","SYSTEM$GET_AWS_SNS_IAM_POLICY","SYSTEM$GET_PREDECESSOR_RETURN_VALUE","SYSTEM$GET_PRIVATELINK","SYSTEM$GET_PRIVATELINK_AUTHORIZED_ENDPOINTS","SYSTEM$GET_PRIVATELINK_CONFIG","SYSTEM$GET_SNOWFLAKE_PLATFORM_INFO","SYSTEM$GET_TAG","SYSTEM$GET_TAG_ALLOWED_VALUES","SYSTEM$GET_TAG_ON_CURRENT_COLUMN","SYSTEM$GET_TAG_ON_CURRENT_TABLE","SYSTEM$GLOBAL_ACCOUNT_SET_PARAMETER","SYSTEM$LAST_CHANGE_COMMIT_TIME","SYSTEM$LINK_ACCOUNT_OBJECTS_BY_NAME","SYSTEM$MIGRATE_SAML_IDP_REGISTRATION","SYSTEM$PIPE_FORCE_RESUME","SYSTEM$PIPE_STATUS","SYSTEM$REVOKE_PRIVATELINK","SYSTEM$REVOKE_STAGE_PRIVATELINK_ACCESS","SYSTEM$SET_RETURN_VALUE","SYSTEM$SHOW_OAUTH_CLIENT_SECRETS","SYSTEM$STREAM_GET_TABLE_TIMESTAMP","SYSTEM$STREAM_HAS_DATA","SYSTEM$TASK_DEPENDENTS_ENABLE","SYSTEM$TYPEOF","SYSTEM$USER_TASK_CANCEL_ONGOING_EXECUTIONS","SYSTEM$VERIFY_EXTERNAL_OAUTH_TOKEN","SYSTEM$WAIT","SYSTEM$WHITELIST","SYSTEM$WHITELIST_PRIVATELINK","TAG_REFERENCES","TAG_REFERENCES_ALL_COLUMNS","TAG_REFERENCES_WITH_LINEAGE","TAN","TANH","TASK_DEPENDENTS","TASK_HISTORY","TIME_FROM_PARTS","TIME_SLICE","TIMEADD","TIMEDIFF","TIMESTAMP_FROM_PARTS","TIMESTAMPADD","TIMESTAMPDIFF","TO_ARRAY","TO_BINARY","TO_BOOLEAN","TO_CHAR","TO_VARCHAR","TO_DATE","DATE","TO_DECIMAL","TO_NUMBER","TO_NUMERIC","TO_DOUBLE","TO_GEOGRAPHY","TO_GEOMETRY","TO_JSON","TO_OBJECT","TO_TIME","TIME","TO_TIMESTAMP","TO_TIMESTAMP_LTZ","TO_TIMESTAMP_NTZ","TO_TIMESTAMP_TZ","TO_VARIANT","TO_XML","TRANSLATE","TRIM","TRUNCATE","TRUNC","TRUNC","TRY_BASE64_DECODE_BINARY","TRY_BASE64_DECODE_STRING","TRY_CAST","TRY_HEX_DECODE_BINARY","TRY_HEX_DECODE_STRING","TRY_PARSE_JSON","TRY_TO_BINARY","TRY_TO_BOOLEAN","TRY_TO_DATE","TRY_TO_DECIMAL","TRY_TO_NUMBER","TRY_TO_NUMERIC","TRY_TO_DOUBLE","TRY_TO_GEOGRAPHY","TRY_TO_GEOMETRY","TRY_TO_TIME","TRY_TO_TIMESTAMP","TRY_TO_TIMESTAMP_LTZ","TRY_TO_TIMESTAMP_NTZ","TRY_TO_TIMESTAMP_TZ","TYPEOF","UNICODE","UNIFORM","UPPER","UUID_STRING","VALIDATE","VALIDATE_PIPE_LOAD","VAR_POP","VAR_SAMP","VARIANCE","VARIANCE_SAMP","VARIANCE_POP","WAREHOUSE_LOAD_HISTORY","WAREHOUSE_METERING_HISTORY","WIDTH_BUCKET","XMLGET","YEAR","YEAROFWEEK","YEAROFWEEKISO","DAY","DAYOFMONTH","DAYOFWEEK","DAYOFWEEKISO","DAYOFYEAR","WEEK","WEEK","WEEKOFYEAR","WEEKISO","MONTH","QUARTER","ZEROIFNULL","ZIPF"],bd=["ACCOUNT","ALL","ALTER","AND","ANY","AS","BETWEEN","BY","CASE","CAST","CHECK","COLUMN","CONNECT","CONNECTION","CONSTRAINT","CREATE","CROSS","CURRENT","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP","CURRENT_USER","DATABASE","DELETE","DISTINCT","DROP","ELSE","EXISTS","FALSE","FOLLOWING","FOR","FROM","FULL","GRANT","GROUP","GSCLUSTER","HAVING","ILIKE","IN","INCREMENT","INNER","INSERT","INTERSECT","INTO","IS","ISSUE","JOIN","LATERAL","LEFT","LIKE","LOCALTIME","LOCALTIMESTAMP","MINUS","NATURAL","NOT","NULL","OF","ON","OR","ORDER","ORGANIZATION","QUALIFY","REGEXP","REVOKE","RIGHT","RLIKE","ROW","ROWS","SAMPLE","SCHEMA","SELECT","SET","SOME","START","TABLE","TABLESAMPLE","THEN","TO","TRIGGER","TRUE","TRY_CAST","UNION","UNIQUE","UPDATE","USING","VALUES","VIEW","WHEN","WHENEVER","WHERE","WITH","COMMENT"],Vd=["NUMBER","DECIMAL","NUMERIC","INT","INTEGER","BIGINT","SMALLINT","TINYINT","BYTEINT","FLOAT","FLOAT4","FLOAT8","DOUBLE","DOUBLE PRECISION","REAL","VARCHAR","CHAR","CHARACTER","STRING","TEXT","BINARY","VARBINARY","BOOLEAN","DATE","DATETIME","TIME","TIMESTAMP","TIMESTAMP_LTZ","TIMESTAMP_NTZ","TIMESTAMP","TIMESTAMP_TZ","VARIANT","OBJECT","ARRAY","GEOGRAPHY","GEOMETRY"],Wd=x(["SELECT [ALL | DISTINCT]"]),Xd=x(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY","HAVING","PARTITION BY","ORDER BY","QUALIFY","LIMIT","OFFSET","FETCH [FIRST | NEXT]","INSERT [OVERWRITE] [ALL INTO | INTO | ALL | FIRST]","{THEN | ELSE} INTO","VALUES","SET","CLUSTER BY","[WITH] {MASKING POLICY | TAG | ROW ACCESS POLICY}","COPY GRANTS","USING TEMPLATE","MERGE INTO","WHEN MATCHED [AND]","THEN {UPDATE SET | DELETE}","WHEN NOT MATCHED THEN INSERT"]),Zi=x(["CREATE [OR REPLACE] [VOLATILE] TABLE [IF NOT EXISTS]","CREATE [OR REPLACE] [LOCAL | GLOBAL] {TEMP|TEMPORARY} TABLE [IF NOT EXISTS]"]),Il=x(["CREATE [OR REPLACE] [SECURE] [RECURSIVE] VIEW [IF NOT EXISTS]","UPDATE","DELETE FROM","DROP TABLE [IF EXISTS]","ALTER TABLE [IF EXISTS]","RENAME TO","SWAP WITH","[SUSPEND | RESUME] RECLUSTER","DROP CLUSTERING KEY","ADD [COLUMN]","RENAME COLUMN","{ALTER | MODIFY} [COLUMN]","DROP [COLUMN]","{ADD | ALTER | MODIFY | DROP} [CONSTRAINT]","RENAME CONSTRAINT","{ADD | DROP} SEARCH OPTIMIZATION","{SET | UNSET} TAG","{ADD | DROP} ROW ACCESS POLICY","DROP ALL ROW ACCESS POLICIES","{SET | DROP} DEFAULT","{SET | DROP} NOT NULL","SET DATA TYPE","UNSET COMMENT","{SET | UNSET} MASKING POLICY","TRUNCATE [TABLE] [IF EXISTS]","ALTER ACCOUNT","ALTER API INTEGRATION","ALTER CONNECTION","ALTER DATABASE","ALTER EXTERNAL TABLE","ALTER FAILOVER GROUP","ALTER FILE FORMAT","ALTER FUNCTION","ALTER INTEGRATION","ALTER MASKING POLICY","ALTER MATERIALIZED VIEW","ALTER NETWORK POLICY","ALTER NOTIFICATION INTEGRATION","ALTER PIPE","ALTER PROCEDURE","ALTER REPLICATION GROUP","ALTER RESOURCE MONITOR","ALTER ROLE","ALTER ROW ACCESS POLICY","ALTER SCHEMA","ALTER SECURITY INTEGRATION","ALTER SEQUENCE","ALTER SESSION","ALTER SESSION POLICY","ALTER SHARE","ALTER STAGE","ALTER STORAGE INTEGRATION","ALTER STREAM","ALTER TAG","ALTER TASK","ALTER USER","ALTER VIEW","ALTER WAREHOUSE","BEGIN","CALL","COMMIT","COPY INTO","CREATE ACCOUNT","CREATE API INTEGRATION","CREATE CONNECTION","CREATE DATABASE","CREATE EXTERNAL FUNCTION","CREATE EXTERNAL TABLE","CREATE FAILOVER GROUP","CREATE FILE FORMAT","CREATE FUNCTION","CREATE INTEGRATION","CREATE MANAGED ACCOUNT","CREATE MASKING POLICY","CREATE MATERIALIZED VIEW","CREATE NETWORK POLICY","CREATE NOTIFICATION INTEGRATION","CREATE PIPE","CREATE PROCEDURE","CREATE REPLICATION GROUP","CREATE RESOURCE MONITOR","CREATE ROLE","CREATE ROW ACCESS POLICY","CREATE SCHEMA","CREATE SECURITY INTEGRATION","CREATE SEQUENCE","CREATE SESSION POLICY","CREATE SHARE","CREATE STAGE","CREATE STORAGE INTEGRATION","CREATE STREAM","CREATE TAG","CREATE TASK","CREATE USER","CREATE WAREHOUSE","DELETE","DESCRIBE DATABASE","DESCRIBE EXTERNAL TABLE","DESCRIBE FILE FORMAT","DESCRIBE FUNCTION","DESCRIBE INTEGRATION","DESCRIBE MASKING POLICY","DESCRIBE MATERIALIZED VIEW","DESCRIBE NETWORK POLICY","DESCRIBE PIPE","DESCRIBE PROCEDURE","DESCRIBE RESULT","DESCRIBE ROW ACCESS POLICY","DESCRIBE SCHEMA","DESCRIBE SEQUENCE","DESCRIBE SESSION POLICY","DESCRIBE SHARE","DESCRIBE STAGE","DESCRIBE STREAM","DESCRIBE TABLE","DESCRIBE TASK","DESCRIBE TRANSACTION","DESCRIBE USER","DESCRIBE VIEW","DESCRIBE WAREHOUSE","DROP CONNECTION","DROP DATABASE","DROP EXTERNAL TABLE","DROP FAILOVER GROUP","DROP FILE FORMAT","DROP FUNCTION","DROP INTEGRATION","DROP MANAGED ACCOUNT","DROP MASKING POLICY","DROP MATERIALIZED VIEW","DROP NETWORK POLICY","DROP PIPE","DROP PROCEDURE","DROP REPLICATION GROUP","DROP RESOURCE MONITOR","DROP ROLE","DROP ROW ACCESS POLICY","DROP SCHEMA","DROP SEQUENCE","DROP SESSION POLICY","DROP SHARE","DROP STAGE","DROP STREAM","DROP TAG","DROP TASK","DROP USER","DROP VIEW","DROP WAREHOUSE","EXECUTE IMMEDIATE","EXECUTE TASK","EXPLAIN","GET","GRANT OWNERSHIP","GRANT ROLE","INSERT","LIST","MERGE","PUT","REMOVE","REVOKE ROLE","ROLLBACK","SHOW COLUMNS","SHOW CONNECTIONS","SHOW DATABASES","SHOW DATABASES IN FAILOVER GROUP","SHOW DATABASES IN REPLICATION GROUP","SHOW DELEGATED AUTHORIZATIONS","SHOW EXTERNAL FUNCTIONS","SHOW EXTERNAL TABLES","SHOW FAILOVER GROUPS","SHOW FILE FORMATS","SHOW FUNCTIONS","SHOW GLOBAL ACCOUNTS","SHOW GRANTS","SHOW INTEGRATIONS","SHOW LOCKS","SHOW MANAGED ACCOUNTS","SHOW MASKING POLICIES","SHOW MATERIALIZED VIEWS","SHOW NETWORK POLICIES","SHOW OBJECTS","SHOW ORGANIZATION ACCOUNTS","SHOW PARAMETERS","SHOW PIPES","SHOW PRIMARY KEYS","SHOW PROCEDURES","SHOW REGIONS","SHOW REPLICATION ACCOUNTS","SHOW REPLICATION DATABASES","SHOW REPLICATION GROUPS","SHOW RESOURCE MONITORS","SHOW ROLES","SHOW ROW ACCESS POLICIES","SHOW SCHEMAS","SHOW SEQUENCES","SHOW SESSION POLICIES","SHOW SHARES","SHOW SHARES IN FAILOVER GROUP","SHOW SHARES IN REPLICATION GROUP","SHOW STAGES","SHOW STREAMS","SHOW TABLES","SHOW TAGS","SHOW TASKS","SHOW TRANSACTIONS","SHOW USER FUNCTIONS","SHOW USERS","SHOW VARIABLES","SHOW VIEWS","SHOW WAREHOUSES","TRUNCATE MATERIALIZED VIEW","UNDROP DATABASE","UNDROP SCHEMA","UNDROP TABLE","UNDROP TAG","UNSET","USE DATABASE","USE ROLE","USE SCHEMA","USE SECONDARY ROLES","USE WAREHOUSE"]),jd=x(["UNION [ALL]","MINUS","EXCEPT","INTERSECT"]),kd=x(["[INNER] JOIN","[NATURAL] {LEFT | RIGHT | FULL} [OUTER] JOIN","{CROSS | NATURAL} JOIN"]),Kd=x(["{ROWS | RANGE} BETWEEN","ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]"]),$d=x([]),Jd={name:"snowflake",tokenizerOptions:{reservedSelect:Wd,reservedClauses:[...Xd,...Zi,...Il],reservedSetOperations:jd,reservedJoins:kd,reservedKeywordPhrases:Kd,reservedDataTypePhrases:$d,reservedKeywords:bd,reservedDataTypes:Vd,reservedFunctionNames:wd,stringTypes:["$$","''-qq-bs"],identTypes:['""-qq'],variableTypes:[{regex:"[$][1-9]\\d*"},{regex:"[$][_a-zA-Z][_a-zA-Z0-9$]*"}],extraParens:["[]"],identChars:{rest:"$"},lineCommentTypes:["--","//"],operators:["%","::","||","=>",":=","->"],propertyAccessOperators:[":"]},formatOptions:{alwaysDenseOperators:["::"],onelineClauses:[...Zi,...Il],tabularOnelineClauses:Il}},zd=Object.freeze(Object.defineProperty({__proto__:null,bigquery:mO,db2:YO,db2i:JO,duckdb:sc,hive:Ic,mariadb:mc,mysql:vc,n1ql:tC,plsql:RC,postgresql:_C,redshift:yC,singlestoredb:Yd,snowflake:Jd,spark:VC,sql:od,sqlite:qC,tidb:jc,transactsql:Md,trino:Cd},Symbol.toStringTag,{value:"Module"})),pr=e=>e[e.length-1],BS=e=>e.sort((t,E)=>E.length-t.length||t.localeCompare(E)),Ps=e=>e.replace(/\s+/gu," "),ul=e=>/\n/.test(e),qt=e=>e.replace(/[.*+?^${}()|[\]\\]/gu,"\\$&"),qi=/\s+/uy,un=e=>new RegExp(`(?:${e})`,"uy"),Qd=e=>e.split("").map(t=>/ /gu.test(t)?"\\s+":`[${t.toUpperCase()}${t.toLowerCase()}]`).join(""),Zd=e=>e+"(?:-"+e+")*",qd=({prefixes:e,requirePrefix:t})=>`(?:${e.map(Qd).join("|")}${t?"":"|"})`,eL=e=>new RegExp(`(?:${e.map(qt).join("|")}).*?(?=\r
|
||
|\r|
|
||
|$)`,"uy"),eR=(e,t=[])=>{const E=e==="open"?0:1,n=["()",...t].map(r=>r[E]);return un(n.map(qt).join("|"))},tR=e=>un(`${BS(e).map(qt).join("|")}`),tL=({rest:e,dashes:t})=>e||t?`(?![${e||""}${t?"-":""}])`:"",iE=(e,t={})=>{if(e.length===0)return/^\b$/u;const E=tL(t),n=BS(e).map(qt).join("|").replace(/ /gu,"\\s+");return new RegExp(`(?:${n})${E}\\b`,"iuy")},Ol=(e,t)=>{if(!e.length)return;const E=e.map(qt).join("|");return un(`(?:${E})(?:${t})`)},EL=()=>{const e={"<":">","[":"]","(":")","{":"}"},t="{left}(?:(?!{right}').)*?{right}",E=Object.entries(e).map(([l,a])=>t.replace(/{left}/g,qt(l)).replace(/{right}/g,qt(a))),n=qt(Object.keys(e).join(""));return`[Qq]'(?:${String.raw`(?<tag>[^\s${n}])(?:(?!\k<tag>').)*?\k<tag>`}|${E.join("|")})'`},ER={"``":"(?:`[^`]*`)+","[]":String.raw`(?:\[[^\]]*\])(?:\][^\]]*\])*`,'""-qq':String.raw`(?:"[^"]*")+`,'""-bs':String.raw`(?:"[^"\\]*(?:\\.[^"\\]*)*")`,'""-qq-bs':String.raw`(?:"[^"\\]*(?:\\.[^"\\]*)*")+`,'""-raw':String.raw`(?:"[^"]*")`,"''-qq":String.raw`(?:'[^']*')+`,"''-bs":String.raw`(?:'[^'\\]*(?:\\.[^'\\]*)*')`,"''-qq-bs":String.raw`(?:'[^'\\]*(?:\\.[^'\\]*)*')+`,"''-raw":String.raw`(?:'[^']*')`,$$:String.raw`(?<tag>\$\w*\$)[\s\S]*?\k<tag>`,"'''..'''":String.raw`'''[^\\]*?(?:\\.[^\\]*?)*?'''`,'""".."""':String.raw`"""[^\\]*?(?:\\.[^\\]*?)*?"""`,"{}":String.raw`(?:\{[^\}]*\})`,"q''":EL()},FS=e=>typeof e=="string"?ER[e]:"regex"in e?e.regex:qd(e)+ER[e.quote],nL=e=>un(e.map(t=>"regex"in t?t.regex:FS(t)).join("|")),YS=e=>e.map(FS).join("|"),nR=e=>un(YS(e)),rL=(e={})=>un(wS(e)),wS=({first:e,rest:t,dashes:E,allowFirstCharNumber:n}={})=>{const r="\\p{Alphabetic}\\p{Mark}_",T="\\p{Decimal_Number}",l=qt(e??""),a=qt(t??""),i=n?`[${r}${T}${l}][${r}${T}${a}]*`:`[${r}${l}][${r}${T}${a}]*`;return E?Zd(i):i};function bS(e,t){const E=e.slice(0,t).split(/\n/);return{line:E.length,col:E[E.length-1].length+1}}class sL{constructor(t,E){this.rules=t,this.dialectName=E,this.input="",this.index=0}tokenize(t){this.input=t,this.index=0;const E=[];let n;for(;this.index<this.input.length;){const r=this.getWhitespace();if(this.index<this.input.length){if(n=this.getNextToken(),!n)throw this.createParseError();E.push(Object.assign(Object.assign({},n),{precedingWhitespace:r}))}}return E}createParseError(){const t=this.input.slice(this.index,this.index+10),{line:E,col:n}=bS(this.input,this.index);return new Error(`Parse error: Unexpected "${t}" at line ${E} column ${n}.
|
||
${this.dialectInfo()}`)}dialectInfo(){return this.dialectName==="sql"?`This likely happens because you're using the default "sql" dialect.
|
||
If possible, please select a more specific dialect (like sqlite, postgresql, etc).`:`SQL dialect used: "${this.dialectName}".`}getWhitespace(){qi.lastIndex=this.index;const t=qi.exec(this.input);if(t)return this.index+=t[0].length,t[0]}getNextToken(){for(const t of this.rules){const E=this.match(t);if(E)return E}}match(t){t.regex.lastIndex=this.index;const E=t.regex.exec(this.input);if(E){const n=E[0],r={type:t.type,raw:n,text:t.text?t.text(n):n,start:this.index};return t.key&&(r.key=t.key(n)),this.index+=n.length,r}}}const rR=/\/\*/uy,TL=/[\s\S]/uy,lL=/\*\//uy;class aL{constructor(){this.lastIndex=0}exec(t){let E="",n,r=0;if(n=this.matchSection(rR,t))E+=n,r++;else return null;for(;r>0;)if(n=this.matchSection(rR,t))E+=n,r++;else if(n=this.matchSection(lL,t))E+=n,r--;else if(n=this.matchSection(TL,t))E+=n;else return null;return[E]}matchSection(t,E){t.lastIndex=this.lastIndex;const n=t.exec(E);return n&&(this.lastIndex+=n[0].length),n?n[0]:null}}class oL{constructor(t,E){this.cfg=t,this.dialectName=E,this.rulesBeforeParams=this.buildRulesBeforeParams(t),this.rulesAfterParams=this.buildRulesAfterParams(t)}tokenize(t,E){const n=[...this.rulesBeforeParams,...this.buildParamRules(this.cfg,E),...this.rulesAfterParams],r=new sL(n,this.dialectName).tokenize(t);return this.cfg.postProcess?this.cfg.postProcess(r):r}buildRulesBeforeParams(t){var E,n,r;return this.validRules([{type:V.DISABLE_COMMENT,regex:/(\/\* *sql-formatter-disable *\*\/[\s\S]*?(?:\/\* *sql-formatter-enable *\*\/|$))/uy},{type:V.BLOCK_COMMENT,regex:t.nestedBlockComments?new aL:/(\/\*[^]*?\*\/)/uy},{type:V.LINE_COMMENT,regex:eL((E=t.lineCommentTypes)!==null&&E!==void 0?E:["--"])},{type:V.QUOTED_IDENTIFIER,regex:nR(t.identTypes)},{type:V.NUMBER,regex:t.underscoresInNumbers?/(?:0x[0-9a-fA-F_]+|0b[01_]+|(?:-\s*)?(?:[0-9_]*\.[0-9_]+|[0-9_]+(?:\.[0-9_]*)?)(?:[eE][-+]?[0-9_]+(?:\.[0-9_]+)?)?)(?![\w\p{Alphabetic}])/uy:/(?:0x[0-9a-fA-F]+|0b[01]+|(?:-\s*)?(?:[0-9]*\.[0-9]+|[0-9]+(?:\.[0-9]*)?)(?:[eE][-+]?[0-9]+(?:\.[0-9]+)?)?)(?![\w\p{Alphabetic}])/uy},{type:V.RESERVED_KEYWORD_PHRASE,regex:iE((n=t.reservedKeywordPhrases)!==null&&n!==void 0?n:[],t.identChars),text:rt},{type:V.RESERVED_DATA_TYPE_PHRASE,regex:iE((r=t.reservedDataTypePhrases)!==null&&r!==void 0?r:[],t.identChars),text:rt},{type:V.CASE,regex:/CASE\b/iuy,text:rt},{type:V.END,regex:/END\b/iuy,text:rt},{type:V.BETWEEN,regex:/BETWEEN\b/iuy,text:rt},{type:V.LIMIT,regex:t.reservedClauses.includes("LIMIT")?/LIMIT\b/iuy:void 0,text:rt},{type:V.RESERVED_CLAUSE,regex:iE(t.reservedClauses,t.identChars),text:rt},{type:V.RESERVED_SELECT,regex:iE(t.reservedSelect,t.identChars),text:rt},{type:V.RESERVED_SET_OPERATION,regex:iE(t.reservedSetOperations,t.identChars),text:rt},{type:V.WHEN,regex:/WHEN\b/iuy,text:rt},{type:V.ELSE,regex:/ELSE\b/iuy,text:rt},{type:V.THEN,regex:/THEN\b/iuy,text:rt},{type:V.RESERVED_JOIN,regex:iE(t.reservedJoins,t.identChars),text:rt},{type:V.AND,regex:/AND\b/iuy,text:rt},{type:V.OR,regex:/OR\b/iuy,text:rt},{type:V.XOR,regex:t.supportsXor?/XOR\b/iuy:void 0,text:rt},...t.operatorKeyword?[{type:V.OPERATOR,regex:/OPERATOR *\([^)]+\)/iuy}]:[],{type:V.RESERVED_FUNCTION_NAME,regex:iE(t.reservedFunctionNames,t.identChars),text:rt},{type:V.RESERVED_DATA_TYPE,regex:iE(t.reservedDataTypes,t.identChars),text:rt},{type:V.RESERVED_KEYWORD,regex:iE(t.reservedKeywords,t.identChars),text:rt}])}buildRulesAfterParams(t){var E,n;return this.validRules([{type:V.VARIABLE,regex:t.variableTypes?nL(t.variableTypes):void 0},{type:V.STRING,regex:nR(t.stringTypes)},{type:V.IDENTIFIER,regex:rL(t.identChars)},{type:V.DELIMITER,regex:/[;]/uy},{type:V.COMMA,regex:/[,]/y},{type:V.OPEN_PAREN,regex:eR("open",t.extraParens)},{type:V.CLOSE_PAREN,regex:eR("close",t.extraParens)},{type:V.OPERATOR,regex:tR(["+","-","/",">","<","=","<>","<=",">=","!=",...(E=t.operators)!==null&&E!==void 0?E:[]])},{type:V.ASTERISK,regex:/[*]/uy},{type:V.PROPERTY_ACCESS_OPERATOR,regex:tR([".",...(n=t.propertyAccessOperators)!==null&&n!==void 0?n:[]])}])}buildParamRules(t,E){var n,r,T,l,a;const i={named:E?.named||((n=t.paramTypes)===null||n===void 0?void 0:n.named)||[],quoted:E?.quoted||((r=t.paramTypes)===null||r===void 0?void 0:r.quoted)||[],numbered:E?.numbered||((T=t.paramTypes)===null||T===void 0?void 0:T.numbered)||[],positional:typeof E?.positional=="boolean"?E.positional:(l=t.paramTypes)===null||l===void 0?void 0:l.positional,custom:E?.custom||((a=t.paramTypes)===null||a===void 0?void 0:a.custom)||[]};return this.validRules([{type:V.NAMED_PARAMETER,regex:Ol(i.named,wS(t.paramChars||t.identChars)),key:o=>o.slice(1)},{type:V.QUOTED_PARAMETER,regex:Ol(i.quoted,YS(t.identTypes)),key:o=>(({tokenKey:S,quoteChar:N})=>S.replace(new RegExp(qt("\\"+N),"gu"),N))({tokenKey:o.slice(2,-1),quoteChar:o.slice(-1)})},{type:V.NUMBERED_PARAMETER,regex:Ol(i.numbered,"[0-9]+"),key:o=>o.slice(1)},{type:V.POSITIONAL_PARAMETER,regex:i.positional?/[?]/y:void 0},...i.custom.map(o=>{var S;return{type:V.CUSTOM_PARAMETER,regex:un(o.regex),key:(S=o.key)!==null&&S!==void 0?S:N=>N}})])}validRules(t){return t.filter(E=>!!E.regex)}}const rt=e=>Ps(e.toUpperCase()),sR=new Map,iL=e=>{let t=sR.get(e);return t||(t=RL(e),sR.set(e,t)),t},RL=e=>({tokenizer:new oL(e.tokenizerOptions,e.name),formatOptions:AL(e.formatOptions)}),AL=e=>{var t;return{alwaysDenseOperators:e.alwaysDenseOperators||[],onelineClauses:Object.fromEntries(e.onelineClauses.map(E=>[E,!0])),tabularOnelineClauses:Object.fromEntries(((t=e.tabularOnelineClauses)!==null&&t!==void 0?t:e.onelineClauses).map(E=>[E,!0]))}};function SL(e){return e.indentStyle==="tabularLeft"||e.indentStyle==="tabularRight"?" ".repeat(10):e.useTabs?" ":" ".repeat(e.tabWidth)}function Cn(e){return e.indentStyle==="tabularLeft"||e.indentStyle==="tabularRight"}class NL{constructor(t){this.params=t,this.index=0}get({key:t,text:E}){return this.params?t?this.params[t]:this.params[this.index++]:E}getPositionalParameterIndex(){return this.index}setPositionalParameterIndex(t){this.index=t}}var VS={exports:{}};(function(e){(function(t,E){e.exports?e.exports=E():t.nearley=E()})(qS,function(){function t(o,S,N){return this.id=++t.highestId,this.name=o,this.symbols=S,this.postprocess=N,this}t.highestId=0,t.prototype.toString=function(o){var S=typeof o>"u"?this.symbols.map(i).join(" "):this.symbols.slice(0,o).map(i).join(" ")+" ● "+this.symbols.slice(o).map(i).join(" ");return this.name+" → "+S};function E(o,S,N,R){this.rule=o,this.dot=S,this.reference=N,this.data=[],this.wantedBy=R,this.isComplete=this.dot===o.symbols.length}E.prototype.toString=function(){return"{"+this.rule.toString(this.dot)+"}, from: "+(this.reference||0)},E.prototype.nextState=function(o){var S=new E(this.rule,this.dot+1,this.reference,this.wantedBy);return S.left=this,S.right=o,S.isComplete&&(S.data=S.build(),S.right=void 0),S},E.prototype.build=function(){var o=[],S=this;do o.push(S.right.data),S=S.left;while(S.left);return o.reverse(),o},E.prototype.finish=function(){this.rule.postprocess&&(this.data=this.rule.postprocess(this.data,this.reference,l.fail))};function n(o,S){this.grammar=o,this.index=S,this.states=[],this.wants={},this.scannable=[],this.completed={}}n.prototype.process=function(o){for(var S=this.states,N=this.wants,R=this.completed,O=0;O<S.length;O++){var L=S[O];if(L.isComplete){if(L.finish(),L.data!==l.fail){for(var _=L.wantedBy,H=_.length;H--;){var c=_[H];this.complete(c,L)}if(L.reference===this.index){var A=L.rule.name;(this.completed[A]=this.completed[A]||[]).push(L)}}}else{var A=L.rule.symbols[L.dot];if(typeof A!="string"){this.scannable.push(L);continue}if(N[A]){if(N[A].push(L),R.hasOwnProperty(A))for(var I=R[A],H=0;H<I.length;H++){var C=I[H];this.complete(L,C)}}else N[A]=[L],this.predict(A)}}},n.prototype.predict=function(o){for(var S=this.grammar.byName[o]||[],N=0;N<S.length;N++){var R=S[N],O=this.wants[o],L=new E(R,0,this.index,O);this.states.push(L)}},n.prototype.complete=function(o,S){var N=o.nextState(S);this.states.push(N)};function r(o,S){this.rules=o,this.start=S||this.rules[0].name;var N=this.byName={};this.rules.forEach(function(R){N.hasOwnProperty(R.name)||(N[R.name]=[]),N[R.name].push(R)})}r.fromCompiled=function(R,S){var N=R.Lexer;R.ParserStart&&(S=R.ParserStart,R=R.ParserRules);var R=R.map(function(L){return new t(L.name,L.symbols,L.postprocess)}),O=new r(R,S);return O.lexer=N,O};function T(){this.reset("")}T.prototype.reset=function(o,S){this.buffer=o,this.index=0,this.line=S?S.line:1,this.lastLineBreak=S?-S.col:0},T.prototype.next=function(){if(this.index<this.buffer.length){var o=this.buffer[this.index++];return o===`
|
||
`&&(this.line+=1,this.lastLineBreak=this.index),{value:o}}},T.prototype.save=function(){return{line:this.line,col:this.index-this.lastLineBreak}},T.prototype.formatError=function(o,S){var N=this.buffer;if(typeof N=="string"){var R=N.split(`
|
||
`).slice(Math.max(0,this.line-5),this.line),O=N.indexOf(`
|
||
`,this.index);O===-1&&(O=N.length);var L=this.index-this.lastLineBreak,_=String(this.line).length;return S+=" at line "+this.line+" col "+L+`:
|
||
|
||
`,S+=R.map(function(c,A){return H(this.line-R.length+A+1,_)+" "+c},this).join(`
|
||
`),S+=`
|
||
`+H("",_+L)+`^
|
||
`,S}else return S+" at index "+(this.index-1);function H(c,A){var I=String(c);return Array(A-I.length+1).join(" ")+I}};function l(o,S,N){if(o instanceof r)var R=o,N=S;else var R=r.fromCompiled(o,S);this.grammar=R,this.options={keepHistory:!1,lexer:R.lexer||new T};for(var O in N||{})this.options[O]=N[O];this.lexer=this.options.lexer,this.lexerState=void 0;var L=new n(R,0);this.table=[L],L.wants[R.start]=[],L.predict(R.start),L.process(),this.current=0}l.fail={},l.prototype.feed=function(o){var S=this.lexer;S.reset(o,this.lexerState);for(var N;;){try{if(N=S.next(),!N)break}catch(P){var _=new n(this.grammar,this.current+1);this.table.push(_);var R=new Error(this.reportLexerError(P));throw R.offset=this.current,R.token=P.token,R}var O=this.table[this.current];this.options.keepHistory||delete this.table[this.current-1];var L=this.current+1,_=new n(this.grammar,L);this.table.push(_);for(var H=N.text!==void 0?N.text:N.value,c=S.constructor===T?N.value:N,A=O.scannable,I=A.length;I--;){var C=A[I],M=C.rule.symbols[C.dot];if(M.test?M.test(c):M.type?M.type===N.type:M.literal===H){var p=C.nextState({data:c,token:N,isToken:!0,reference:L-1});_.states.push(p)}}if(_.process(),_.states.length===0){var R=new Error(this.reportError(N));throw R.offset=this.current,R.token=N,R}this.options.keepHistory&&(O.lexerState=S.save()),this.current++}return O&&(this.lexerState=S.save()),this.results=this.finish(),this},l.prototype.reportLexerError=function(o){var S,N,R=o.token;return R?(S="input "+JSON.stringify(R.text[0])+" (lexer error)",N=this.lexer.formatError(R,"Syntax error")):(S="input (lexer error)",N=o.message),this.reportErrorCommon(N,S)},l.prototype.reportError=function(o){var S=(o.type?o.type+" token: ":"")+JSON.stringify(o.value!==void 0?o.value:o),N=this.lexer.formatError(o,"Syntax error");return this.reportErrorCommon(N,S)},l.prototype.reportErrorCommon=function(o,S){var N=[];N.push(o);var R=this.table.length-2,O=this.table[R],L=O.states.filter(function(H){var c=H.rule.symbols[H.dot];return c&&typeof c!="string"});if(L.length===0)N.push("Unexpected "+S+`. I did not expect any more input. Here is the state of my parse table:
|
||
`),this.displayStateStack(O.states,N);else{N.push("Unexpected "+S+`. Instead, I was expecting to see one of the following:
|
||
`);var _=L.map(function(H){return this.buildFirstStateStack(H,[])||[H]},this);_.forEach(function(H){var c=H[0],A=c.rule.symbols[c.dot],I=this.getSymbolDisplay(A);N.push("A "+I+" based on:"),this.displayStateStack(H,N)},this)}return N.push(""),N.join(`
|
||
`)},l.prototype.displayStateStack=function(o,S){for(var N,R=0,O=0;O<o.length;O++){var L=o[O],_=L.rule.toString(L.dot);_===N?R++:(R>0&&S.push(" ^ "+R+" more lines identical to this"),R=0,S.push(" "+_)),N=_}},l.prototype.getSymbolDisplay=function(o){return a(o)},l.prototype.buildFirstStateStack=function(o,S){if(S.indexOf(o)!==-1)return null;if(o.wantedBy.length===0)return[o];var N=o.wantedBy[0],R=[o].concat(S),O=this.buildFirstStateStack(N,R);return O===null?null:[o].concat(O)},l.prototype.save=function(){var o=this.table[this.current];return o.lexerState=this.lexerState,o},l.prototype.restore=function(o){var S=o.index;this.current=S,this.table[S]=o,this.table.splice(S+1),this.lexerState=o.lexerState,this.results=this.finish()},l.prototype.rewind=function(o){if(!this.options.keepHistory)throw new Error("set option `keepHistory` to enable rewinding");this.restore(this.table[o])},l.prototype.finish=function(){var o=[],S=this.grammar.start,N=this.table[this.table.length-1];return N.states.forEach(function(R){R.rule.name===S&&R.dot===R.rule.symbols.length&&R.reference===0&&R.data!==l.fail&&o.push(R)}),o.map(function(R){return R.data})};function a(o){var S=typeof o;if(S==="string")return o;if(S==="object"){if(o.literal)return JSON.stringify(o.literal);if(o instanceof RegExp)return"character matching "+o;if(o.type)return o.type+" token";if(o.test)return"token matching "+String(o.test);throw new Error("Unknown symbol type: "+o)}}function i(o){var S=typeof o;if(S==="string")return o;if(S==="object"){if(o.literal)return JSON.stringify(o.literal);if(o instanceof RegExp)return o.toString();if(o.type)return"%"+o.type;if(o.test)return"<"+String(o.test)+">";throw new Error("Unknown symbol type: "+o)}}return{Parser:l,Grammar:r,Rule:t}})})(VS);var IL=VS.exports;const uL=IR(IL);function OL(e){return e.map(cL).map(CL).map(dL).map(LL).map(_L)}const cL=(e,t,E)=>{if(HS(e.type)){const n=fL(E,t);if(n&&n.type===V.PROPERTY_ACCESS_OPERATOR)return Object.assign(Object.assign({},e),{type:V.IDENTIFIER,text:e.raw});const r=Qn(E,t);if(r&&r.type===V.PROPERTY_ACCESS_OPERATOR)return Object.assign(Object.assign({},e),{type:V.IDENTIFIER,text:e.raw})}return e},CL=(e,t,E)=>{if(e.type===V.RESERVED_FUNCTION_NAME){const n=Qn(E,t);if(!n||!WS(n))return Object.assign(Object.assign({},e),{type:V.IDENTIFIER,text:e.raw})}return e},dL=(e,t,E)=>{if(e.type===V.RESERVED_DATA_TYPE){const n=Qn(E,t);if(n&&WS(n))return Object.assign(Object.assign({},e),{type:V.RESERVED_PARAMETERIZED_DATA_TYPE})}return e},LL=(e,t,E)=>{if(e.type===V.IDENTIFIER){const n=Qn(E,t);if(n&&XS(n))return Object.assign(Object.assign({},e),{type:V.ARRAY_IDENTIFIER})}return e},_L=(e,t,E)=>{if(e.type===V.RESERVED_DATA_TYPE){const n=Qn(E,t);if(n&&XS(n))return Object.assign(Object.assign({},e),{type:V.ARRAY_KEYWORD})}return e},fL=(e,t)=>Qn(e,t,-1),Qn=(e,t,E=1)=>{let n=1;for(;e[t+n*E]&&pL(e[t+n*E]);)n++;return e[t+n*E]},WS=e=>e.type===V.OPEN_PAREN&&e.text==="(",XS=e=>e.type===V.OPEN_PAREN&&e.text==="[",pL=e=>e.type===V.BLOCK_COMMENT||e.type===V.LINE_COMMENT;class jS{constructor(t){this.tokenize=t,this.index=0,this.tokens=[],this.input=""}reset(t,E){this.input=t,this.index=0,this.tokens=this.tokenize(t)}next(){return this.tokens[this.index++]}save(){}formatError(t){const{line:E,col:n}=bS(this.input,t.start);return`Parse error at token: ${t.text} at line ${E} column ${n}`}has(t){return t in V}}var ae;(function(e){e.statement="statement",e.clause="clause",e.set_operation="set_operation",e.function_call="function_call",e.parameterized_data_type="parameterized_data_type",e.array_subscript="array_subscript",e.property_access="property_access",e.parenthesis="parenthesis",e.between_predicate="between_predicate",e.case_expression="case_expression",e.case_when="case_when",e.case_else="case_else",e.limit_clause="limit_clause",e.all_columns_asterisk="all_columns_asterisk",e.literal="literal",e.identifier="identifier",e.keyword="keyword",e.data_type="data_type",e.parameter="parameter",e.operator="operator",e.comma="comma",e.line_comment="line_comment",e.block_comment="block_comment",e.disable_comment="disable_comment"})(ae=ae||(ae={}));function cl(e){return e[0]}const ue=new jS(e=>[]),QE=([[e]])=>e,lt=e=>({type:ae.keyword,tokenType:e.type,text:e.text,raw:e.raw}),TR=e=>({type:ae.data_type,text:e.text,raw:e.raw}),at=(e,{leading:t,trailing:E})=>(t?.length&&(e=Object.assign(Object.assign({},e),{leadingComments:t})),E?.length&&(e=Object.assign(Object.assign({},e),{trailingComments:E})),e),mL=(e,{leading:t,trailing:E})=>{if(t?.length){const[n,...r]=e;e=[at(n,{leading:t}),...r]}if(E?.length){const n=e.slice(0,-1),r=e[e.length-1];e=[...n,at(r,{trailing:E})]}return e},DL={Lexer:ue,ParserRules:[{name:"main$ebnf$1",symbols:[]},{name:"main$ebnf$1",symbols:["main$ebnf$1","statement"],postprocess:e=>e[0].concat([e[1]])},{name:"main",symbols:["main$ebnf$1"],postprocess:([e])=>{const t=e[e.length-1];return t&&!t.hasSemicolon?t.children.length>0?e:e.slice(0,-1):e}},{name:"statement$subexpression$1",symbols:[ue.has("DELIMITER")?{type:"DELIMITER"}:DELIMITER]},{name:"statement$subexpression$1",symbols:[ue.has("EOF")?{type:"EOF"}:EOF]},{name:"statement",symbols:["expressions_or_clauses","statement$subexpression$1"],postprocess:([e,[t]])=>({type:ae.statement,children:e,hasSemicolon:t.type===V.DELIMITER})},{name:"expressions_or_clauses$ebnf$1",symbols:[]},{name:"expressions_or_clauses$ebnf$1",symbols:["expressions_or_clauses$ebnf$1","free_form_sql"],postprocess:e=>e[0].concat([e[1]])},{name:"expressions_or_clauses$ebnf$2",symbols:[]},{name:"expressions_or_clauses$ebnf$2",symbols:["expressions_or_clauses$ebnf$2","clause"],postprocess:e=>e[0].concat([e[1]])},{name:"expressions_or_clauses",symbols:["expressions_or_clauses$ebnf$1","expressions_or_clauses$ebnf$2"],postprocess:([e,t])=>[...e,...t]},{name:"clause$subexpression$1",symbols:["limit_clause"]},{name:"clause$subexpression$1",symbols:["select_clause"]},{name:"clause$subexpression$1",symbols:["other_clause"]},{name:"clause$subexpression$1",symbols:["set_operation"]},{name:"clause",symbols:["clause$subexpression$1"],postprocess:QE},{name:"limit_clause$ebnf$1$subexpression$1$ebnf$1",symbols:["free_form_sql"]},{name:"limit_clause$ebnf$1$subexpression$1$ebnf$1",symbols:["limit_clause$ebnf$1$subexpression$1$ebnf$1","free_form_sql"],postprocess:e=>e[0].concat([e[1]])},{name:"limit_clause$ebnf$1$subexpression$1",symbols:[ue.has("COMMA")?{type:"COMMA"}:COMMA,"limit_clause$ebnf$1$subexpression$1$ebnf$1"]},{name:"limit_clause$ebnf$1",symbols:["limit_clause$ebnf$1$subexpression$1"],postprocess:cl},{name:"limit_clause$ebnf$1",symbols:[],postprocess:()=>null},{name:"limit_clause",symbols:[ue.has("LIMIT")?{type:"LIMIT"}:LIMIT,"_","expression_chain_","limit_clause$ebnf$1"],postprocess:([e,t,E,n])=>{if(n){const[r,T]=n;return{type:ae.limit_clause,limitKw:at(lt(e),{trailing:t}),offset:E,count:T}}else return{type:ae.limit_clause,limitKw:at(lt(e),{trailing:t}),count:E}}},{name:"select_clause$subexpression$1$ebnf$1",symbols:[]},{name:"select_clause$subexpression$1$ebnf$1",symbols:["select_clause$subexpression$1$ebnf$1","free_form_sql"],postprocess:e=>e[0].concat([e[1]])},{name:"select_clause$subexpression$1",symbols:["all_columns_asterisk","select_clause$subexpression$1$ebnf$1"]},{name:"select_clause$subexpression$1$ebnf$2",symbols:[]},{name:"select_clause$subexpression$1$ebnf$2",symbols:["select_clause$subexpression$1$ebnf$2","free_form_sql"],postprocess:e=>e[0].concat([e[1]])},{name:"select_clause$subexpression$1",symbols:["asteriskless_free_form_sql","select_clause$subexpression$1$ebnf$2"]},{name:"select_clause",symbols:[ue.has("RESERVED_SELECT")?{type:"RESERVED_SELECT"}:RESERVED_SELECT,"select_clause$subexpression$1"],postprocess:([e,[t,E]])=>({type:ae.clause,nameKw:lt(e),children:[t,...E]})},{name:"select_clause",symbols:[ue.has("RESERVED_SELECT")?{type:"RESERVED_SELECT"}:RESERVED_SELECT],postprocess:([e])=>({type:ae.clause,nameKw:lt(e),children:[]})},{name:"all_columns_asterisk",symbols:[ue.has("ASTERISK")?{type:"ASTERISK"}:ASTERISK],postprocess:()=>({type:ae.all_columns_asterisk})},{name:"other_clause$ebnf$1",symbols:[]},{name:"other_clause$ebnf$1",symbols:["other_clause$ebnf$1","free_form_sql"],postprocess:e=>e[0].concat([e[1]])},{name:"other_clause",symbols:[ue.has("RESERVED_CLAUSE")?{type:"RESERVED_CLAUSE"}:RESERVED_CLAUSE,"other_clause$ebnf$1"],postprocess:([e,t])=>({type:ae.clause,nameKw:lt(e),children:t})},{name:"set_operation$ebnf$1",symbols:[]},{name:"set_operation$ebnf$1",symbols:["set_operation$ebnf$1","free_form_sql"],postprocess:e=>e[0].concat([e[1]])},{name:"set_operation",symbols:[ue.has("RESERVED_SET_OPERATION")?{type:"RESERVED_SET_OPERATION"}:RESERVED_SET_OPERATION,"set_operation$ebnf$1"],postprocess:([e,t])=>({type:ae.set_operation,nameKw:lt(e),children:t})},{name:"expression_chain_$ebnf$1",symbols:["expression_with_comments_"]},{name:"expression_chain_$ebnf$1",symbols:["expression_chain_$ebnf$1","expression_with_comments_"],postprocess:e=>e[0].concat([e[1]])},{name:"expression_chain_",symbols:["expression_chain_$ebnf$1"],postprocess:cl},{name:"expression_chain$ebnf$1",symbols:[]},{name:"expression_chain$ebnf$1",symbols:["expression_chain$ebnf$1","_expression_with_comments"],postprocess:e=>e[0].concat([e[1]])},{name:"expression_chain",symbols:["expression","expression_chain$ebnf$1"],postprocess:([e,t])=>[e,...t]},{name:"andless_expression_chain$ebnf$1",symbols:[]},{name:"andless_expression_chain$ebnf$1",symbols:["andless_expression_chain$ebnf$1","_andless_expression_with_comments"],postprocess:e=>e[0].concat([e[1]])},{name:"andless_expression_chain",symbols:["andless_expression","andless_expression_chain$ebnf$1"],postprocess:([e,t])=>[e,...t]},{name:"expression_with_comments_",symbols:["expression","_"],postprocess:([e,t])=>at(e,{trailing:t})},{name:"_expression_with_comments",symbols:["_","expression"],postprocess:([e,t])=>at(t,{leading:e})},{name:"_andless_expression_with_comments",symbols:["_","andless_expression"],postprocess:([e,t])=>at(t,{leading:e})},{name:"free_form_sql$subexpression$1",symbols:["asteriskless_free_form_sql"]},{name:"free_form_sql$subexpression$1",symbols:["asterisk"]},{name:"free_form_sql",symbols:["free_form_sql$subexpression$1"],postprocess:QE},{name:"asteriskless_free_form_sql$subexpression$1",symbols:["asteriskless_andless_expression"]},{name:"asteriskless_free_form_sql$subexpression$1",symbols:["logic_operator"]},{name:"asteriskless_free_form_sql$subexpression$1",symbols:["comma"]},{name:"asteriskless_free_form_sql$subexpression$1",symbols:["comment"]},{name:"asteriskless_free_form_sql$subexpression$1",symbols:["other_keyword"]},{name:"asteriskless_free_form_sql",symbols:["asteriskless_free_form_sql$subexpression$1"],postprocess:QE},{name:"expression$subexpression$1",symbols:["andless_expression"]},{name:"expression$subexpression$1",symbols:["logic_operator"]},{name:"expression",symbols:["expression$subexpression$1"],postprocess:QE},{name:"andless_expression$subexpression$1",symbols:["asteriskless_andless_expression"]},{name:"andless_expression$subexpression$1",symbols:["asterisk"]},{name:"andless_expression",symbols:["andless_expression$subexpression$1"],postprocess:QE},{name:"asteriskless_andless_expression$subexpression$1",symbols:["atomic_expression"]},{name:"asteriskless_andless_expression$subexpression$1",symbols:["between_predicate"]},{name:"asteriskless_andless_expression$subexpression$1",symbols:["case_expression"]},{name:"asteriskless_andless_expression",symbols:["asteriskless_andless_expression$subexpression$1"],postprocess:QE},{name:"atomic_expression$subexpression$1",symbols:["array_subscript"]},{name:"atomic_expression$subexpression$1",symbols:["function_call"]},{name:"atomic_expression$subexpression$1",symbols:["property_access"]},{name:"atomic_expression$subexpression$1",symbols:["parenthesis"]},{name:"atomic_expression$subexpression$1",symbols:["curly_braces"]},{name:"atomic_expression$subexpression$1",symbols:["square_brackets"]},{name:"atomic_expression$subexpression$1",symbols:["operator"]},{name:"atomic_expression$subexpression$1",symbols:["identifier"]},{name:"atomic_expression$subexpression$1",symbols:["parameter"]},{name:"atomic_expression$subexpression$1",symbols:["literal"]},{name:"atomic_expression$subexpression$1",symbols:["data_type"]},{name:"atomic_expression$subexpression$1",symbols:["keyword"]},{name:"atomic_expression",symbols:["atomic_expression$subexpression$1"],postprocess:QE},{name:"array_subscript",symbols:[ue.has("ARRAY_IDENTIFIER")?{type:"ARRAY_IDENTIFIER"}:ARRAY_IDENTIFIER,"_","square_brackets"],postprocess:([e,t,E])=>({type:ae.array_subscript,array:at({type:ae.identifier,quoted:!1,text:e.text},{trailing:t}),parenthesis:E})},{name:"array_subscript",symbols:[ue.has("ARRAY_KEYWORD")?{type:"ARRAY_KEYWORD"}:ARRAY_KEYWORD,"_","square_brackets"],postprocess:([e,t,E])=>({type:ae.array_subscript,array:at(lt(e),{trailing:t}),parenthesis:E})},{name:"function_call",symbols:[ue.has("RESERVED_FUNCTION_NAME")?{type:"RESERVED_FUNCTION_NAME"}:RESERVED_FUNCTION_NAME,"_","parenthesis"],postprocess:([e,t,E])=>({type:ae.function_call,nameKw:at(lt(e),{trailing:t}),parenthesis:E})},{name:"parenthesis",symbols:[{literal:"("},"expressions_or_clauses",{literal:")"}],postprocess:([e,t,E])=>({type:ae.parenthesis,children:t,openParen:"(",closeParen:")"})},{name:"curly_braces$ebnf$1",symbols:[]},{name:"curly_braces$ebnf$1",symbols:["curly_braces$ebnf$1","free_form_sql"],postprocess:e=>e[0].concat([e[1]])},{name:"curly_braces",symbols:[{literal:"{"},"curly_braces$ebnf$1",{literal:"}"}],postprocess:([e,t,E])=>({type:ae.parenthesis,children:t,openParen:"{",closeParen:"}"})},{name:"square_brackets$ebnf$1",symbols:[]},{name:"square_brackets$ebnf$1",symbols:["square_brackets$ebnf$1","free_form_sql"],postprocess:e=>e[0].concat([e[1]])},{name:"square_brackets",symbols:[{literal:"["},"square_brackets$ebnf$1",{literal:"]"}],postprocess:([e,t,E])=>({type:ae.parenthesis,children:t,openParen:"[",closeParen:"]"})},{name:"property_access$subexpression$1",symbols:["identifier"]},{name:"property_access$subexpression$1",symbols:["array_subscript"]},{name:"property_access$subexpression$1",symbols:["all_columns_asterisk"]},{name:"property_access$subexpression$1",symbols:["parameter"]},{name:"property_access",symbols:["atomic_expression","_",ue.has("PROPERTY_ACCESS_OPERATOR")?{type:"PROPERTY_ACCESS_OPERATOR"}:PROPERTY_ACCESS_OPERATOR,"_","property_access$subexpression$1"],postprocess:([e,t,E,n,[r]])=>({type:ae.property_access,object:at(e,{trailing:t}),operator:E.text,property:at(r,{leading:n})})},{name:"between_predicate",symbols:[ue.has("BETWEEN")?{type:"BETWEEN"}:BETWEEN,"_","andless_expression_chain","_",ue.has("AND")?{type:"AND"}:AND,"_","andless_expression"],postprocess:([e,t,E,n,r,T,l])=>({type:ae.between_predicate,betweenKw:lt(e),expr1:mL(E,{leading:t,trailing:n}),andKw:lt(r),expr2:[at(l,{leading:T})]})},{name:"case_expression$ebnf$1",symbols:["expression_chain_"],postprocess:cl},{name:"case_expression$ebnf$1",symbols:[],postprocess:()=>null},{name:"case_expression$ebnf$2",symbols:[]},{name:"case_expression$ebnf$2",symbols:["case_expression$ebnf$2","case_clause"],postprocess:e=>e[0].concat([e[1]])},{name:"case_expression",symbols:[ue.has("CASE")?{type:"CASE"}:CASE,"_","case_expression$ebnf$1","case_expression$ebnf$2",ue.has("END")?{type:"END"}:END],postprocess:([e,t,E,n,r])=>({type:ae.case_expression,caseKw:at(lt(e),{trailing:t}),endKw:lt(r),expr:E||[],clauses:n})},{name:"case_clause",symbols:[ue.has("WHEN")?{type:"WHEN"}:WHEN,"_","expression_chain_",ue.has("THEN")?{type:"THEN"}:THEN,"_","expression_chain_"],postprocess:([e,t,E,n,r,T])=>({type:ae.case_when,whenKw:at(lt(e),{trailing:t}),thenKw:at(lt(n),{trailing:r}),condition:E,result:T})},{name:"case_clause",symbols:[ue.has("ELSE")?{type:"ELSE"}:ELSE,"_","expression_chain_"],postprocess:([e,t,E])=>({type:ae.case_else,elseKw:at(lt(e),{trailing:t}),result:E})},{name:"comma$subexpression$1",symbols:[ue.has("COMMA")?{type:"COMMA"}:COMMA]},{name:"comma",symbols:["comma$subexpression$1"],postprocess:([[e]])=>({type:ae.comma})},{name:"asterisk$subexpression$1",symbols:[ue.has("ASTERISK")?{type:"ASTERISK"}:ASTERISK]},{name:"asterisk",symbols:["asterisk$subexpression$1"],postprocess:([[e]])=>({type:ae.operator,text:e.text})},{name:"operator$subexpression$1",symbols:[ue.has("OPERATOR")?{type:"OPERATOR"}:OPERATOR]},{name:"operator",symbols:["operator$subexpression$1"],postprocess:([[e]])=>({type:ae.operator,text:e.text})},{name:"identifier$subexpression$1",symbols:[ue.has("IDENTIFIER")?{type:"IDENTIFIER"}:IDENTIFIER]},{name:"identifier$subexpression$1",symbols:[ue.has("QUOTED_IDENTIFIER")?{type:"QUOTED_IDENTIFIER"}:QUOTED_IDENTIFIER]},{name:"identifier$subexpression$1",symbols:[ue.has("VARIABLE")?{type:"VARIABLE"}:VARIABLE]},{name:"identifier",symbols:["identifier$subexpression$1"],postprocess:([[e]])=>({type:ae.identifier,quoted:e.type!=="IDENTIFIER",text:e.text})},{name:"parameter$subexpression$1",symbols:[ue.has("NAMED_PARAMETER")?{type:"NAMED_PARAMETER"}:NAMED_PARAMETER]},{name:"parameter$subexpression$1",symbols:[ue.has("QUOTED_PARAMETER")?{type:"QUOTED_PARAMETER"}:QUOTED_PARAMETER]},{name:"parameter$subexpression$1",symbols:[ue.has("NUMBERED_PARAMETER")?{type:"NUMBERED_PARAMETER"}:NUMBERED_PARAMETER]},{name:"parameter$subexpression$1",symbols:[ue.has("POSITIONAL_PARAMETER")?{type:"POSITIONAL_PARAMETER"}:POSITIONAL_PARAMETER]},{name:"parameter$subexpression$1",symbols:[ue.has("CUSTOM_PARAMETER")?{type:"CUSTOM_PARAMETER"}:CUSTOM_PARAMETER]},{name:"parameter",symbols:["parameter$subexpression$1"],postprocess:([[e]])=>({type:ae.parameter,key:e.key,text:e.text})},{name:"literal$subexpression$1",symbols:[ue.has("NUMBER")?{type:"NUMBER"}:NUMBER]},{name:"literal$subexpression$1",symbols:[ue.has("STRING")?{type:"STRING"}:STRING]},{name:"literal",symbols:["literal$subexpression$1"],postprocess:([[e]])=>({type:ae.literal,text:e.text})},{name:"keyword$subexpression$1",symbols:[ue.has("RESERVED_KEYWORD")?{type:"RESERVED_KEYWORD"}:RESERVED_KEYWORD]},{name:"keyword$subexpression$1",symbols:[ue.has("RESERVED_KEYWORD_PHRASE")?{type:"RESERVED_KEYWORD_PHRASE"}:RESERVED_KEYWORD_PHRASE]},{name:"keyword$subexpression$1",symbols:[ue.has("RESERVED_JOIN")?{type:"RESERVED_JOIN"}:RESERVED_JOIN]},{name:"keyword",symbols:["keyword$subexpression$1"],postprocess:([[e]])=>lt(e)},{name:"data_type$subexpression$1",symbols:[ue.has("RESERVED_DATA_TYPE")?{type:"RESERVED_DATA_TYPE"}:RESERVED_DATA_TYPE]},{name:"data_type$subexpression$1",symbols:[ue.has("RESERVED_DATA_TYPE_PHRASE")?{type:"RESERVED_DATA_TYPE_PHRASE"}:RESERVED_DATA_TYPE_PHRASE]},{name:"data_type",symbols:["data_type$subexpression$1"],postprocess:([[e]])=>TR(e)},{name:"data_type",symbols:[ue.has("RESERVED_PARAMETERIZED_DATA_TYPE")?{type:"RESERVED_PARAMETERIZED_DATA_TYPE"}:RESERVED_PARAMETERIZED_DATA_TYPE,"_","parenthesis"],postprocess:([e,t,E])=>({type:ae.parameterized_data_type,dataType:at(TR(e),{trailing:t}),parenthesis:E})},{name:"logic_operator$subexpression$1",symbols:[ue.has("AND")?{type:"AND"}:AND]},{name:"logic_operator$subexpression$1",symbols:[ue.has("OR")?{type:"OR"}:OR]},{name:"logic_operator$subexpression$1",symbols:[ue.has("XOR")?{type:"XOR"}:XOR]},{name:"logic_operator",symbols:["logic_operator$subexpression$1"],postprocess:([[e]])=>lt(e)},{name:"other_keyword$subexpression$1",symbols:[ue.has("WHEN")?{type:"WHEN"}:WHEN]},{name:"other_keyword$subexpression$1",symbols:[ue.has("THEN")?{type:"THEN"}:THEN]},{name:"other_keyword$subexpression$1",symbols:[ue.has("ELSE")?{type:"ELSE"}:ELSE]},{name:"other_keyword$subexpression$1",symbols:[ue.has("END")?{type:"END"}:END]},{name:"other_keyword",symbols:["other_keyword$subexpression$1"],postprocess:([[e]])=>lt(e)},{name:"_$ebnf$1",symbols:[]},{name:"_$ebnf$1",symbols:["_$ebnf$1","comment"],postprocess:e=>e[0].concat([e[1]])},{name:"_",symbols:["_$ebnf$1"],postprocess:([e])=>e},{name:"comment",symbols:[ue.has("LINE_COMMENT")?{type:"LINE_COMMENT"}:LINE_COMMENT],postprocess:([e])=>({type:ae.line_comment,text:e.text,precedingWhitespace:e.precedingWhitespace})},{name:"comment",symbols:[ue.has("BLOCK_COMMENT")?{type:"BLOCK_COMMENT"}:BLOCK_COMMENT],postprocess:([e])=>({type:ae.block_comment,text:e.text,precedingWhitespace:e.precedingWhitespace})},{name:"comment",symbols:[ue.has("DISABLE_COMMENT")?{type:"DISABLE_COMMENT"}:DISABLE_COMMENT],postprocess:([e])=>({type:ae.disable_comment,text:e.text,precedingWhitespace:e.precedingWhitespace})}],ParserStart:"main"},{Parser:PL,Grammar:hL}=uL;function ML(e){let t={};const E=new jS(r=>[...OL(e.tokenize(r,t)),vS(r.length)]),n=new PL(hL.fromCompiled(DL),{lexer:E});return{parse:(r,T)=>{t=T;const{results:l}=n.feed(r);if(l.length===1)return l[0];throw l.length===0?new Error("Parse error: Invalid SQL"):new Error(`Parse error: Ambiguous grammar
|
||
${JSON.stringify(l,void 0,2)}`)}}}var w;(function(e){e[e.SPACE=0]="SPACE",e[e.NO_SPACE=1]="NO_SPACE",e[e.NO_NEWLINE=2]="NO_NEWLINE",e[e.NEWLINE=3]="NEWLINE",e[e.MANDATORY_NEWLINE=4]="MANDATORY_NEWLINE",e[e.INDENT=5]="INDENT",e[e.SINGLE_INDENT=6]="SINGLE_INDENT"})(w=w||(w={}));class kS{constructor(t){this.indentation=t,this.items=[]}add(...t){for(const E of t)switch(E){case w.SPACE:this.items.push(w.SPACE);break;case w.NO_SPACE:this.trimHorizontalWhitespace();break;case w.NO_NEWLINE:this.trimWhitespace();break;case w.NEWLINE:this.trimHorizontalWhitespace(),this.addNewline(w.NEWLINE);break;case w.MANDATORY_NEWLINE:this.trimHorizontalWhitespace(),this.addNewline(w.MANDATORY_NEWLINE);break;case w.INDENT:this.addIndentation();break;case w.SINGLE_INDENT:this.items.push(w.SINGLE_INDENT);break;default:this.items.push(E)}}trimHorizontalWhitespace(){for(;UL(pr(this.items));)this.items.pop()}trimWhitespace(){for(;xL(pr(this.items));)this.items.pop()}addNewline(t){if(this.items.length>0)switch(pr(this.items)){case w.NEWLINE:this.items.pop(),this.items.push(t);break;case w.MANDATORY_NEWLINE:break;default:this.items.push(t);break}}addIndentation(){for(let t=0;t<this.indentation.getLevel();t++)this.items.push(w.SINGLE_INDENT)}toString(){return this.items.map(t=>this.itemToString(t)).join("")}getLayoutItems(){return this.items}itemToString(t){switch(t){case w.SPACE:return" ";case w.NEWLINE:case w.MANDATORY_NEWLINE:return`
|
||
`;case w.SINGLE_INDENT:return this.indentation.getSingleIndent();default:return t}}}const UL=e=>e===w.SPACE||e===w.SINGLE_INDENT,xL=e=>e===w.SPACE||e===w.SINGLE_INDENT||e===w.NEWLINE;function lR(e,t){if(t==="standard")return e;let E=[];return e.length>=10&&e.includes(" ")&&([e,...E]=e.split(" ")),t==="tabularLeft"?e=e.padEnd(9," "):e=e.padStart(9," "),e+["",...E].join(" ")}function aR(e){return IO(e)||e===V.RESERVED_CLAUSE||e===V.RESERVED_SELECT||e===V.RESERVED_SET_OPERATION||e===V.RESERVED_JOIN||e===V.LIMIT}const Cl="top-level",yL="block-level";class KS{constructor(t){this.indent=t,this.indentTypes=[]}getSingleIndent(){return this.indent}getLevel(){return this.indentTypes.length}increaseTopLevel(){this.indentTypes.push(Cl)}increaseBlockLevel(){this.indentTypes.push(yL)}decreaseTopLevel(){this.indentTypes.length>0&&pr(this.indentTypes)===Cl&&this.indentTypes.pop()}decreaseBlockLevel(){for(;this.indentTypes.length>0&&this.indentTypes.pop()===Cl;);}}class gL extends kS{constructor(t){super(new KS("")),this.expressionWidth=t,this.length=0,this.trailingSpace=!1}add(...t){if(t.forEach(E=>this.addToLength(E)),this.length>this.expressionWidth)throw new da;super.add(...t)}addToLength(t){if(typeof t=="string")this.length+=t.length,this.trailingSpace=!1;else{if(t===w.MANDATORY_NEWLINE||t===w.NEWLINE)throw new da;t===w.INDENT||t===w.SINGLE_INDENT||t===w.SPACE?this.trailingSpace||(this.length++,this.trailingSpace=!0):(t===w.NO_NEWLINE||t===w.NO_SPACE)&&this.trailingSpace&&(this.trailingSpace=!1,this.length--)}}}class da extends Error{}class eT{constructor({cfg:t,dialectCfg:E,params:n,layout:r,inline:T=!1}){this.inline=!1,this.nodes=[],this.index=-1,this.cfg=t,this.dialectCfg=E,this.inline=T,this.params=n,this.layout=r}format(t){for(this.nodes=t,this.index=0;this.index<this.nodes.length;this.index++)this.formatNode(this.nodes[this.index]);return this.layout}formatNode(t){this.formatComments(t.leadingComments),this.formatNodeWithoutComments(t),this.formatComments(t.trailingComments)}formatNodeWithoutComments(t){switch(t.type){case ae.function_call:return this.formatFunctionCall(t);case ae.parameterized_data_type:return this.formatParameterizedDataType(t);case ae.array_subscript:return this.formatArraySubscript(t);case ae.property_access:return this.formatPropertyAccess(t);case ae.parenthesis:return this.formatParenthesis(t);case ae.between_predicate:return this.formatBetweenPredicate(t);case ae.case_expression:return this.formatCaseExpression(t);case ae.case_when:return this.formatCaseWhen(t);case ae.case_else:return this.formatCaseElse(t);case ae.clause:return this.formatClause(t);case ae.set_operation:return this.formatSetOperation(t);case ae.limit_clause:return this.formatLimitClause(t);case ae.all_columns_asterisk:return this.formatAllColumnsAsterisk(t);case ae.literal:return this.formatLiteral(t);case ae.identifier:return this.formatIdentifier(t);case ae.parameter:return this.formatParameter(t);case ae.operator:return this.formatOperator(t);case ae.comma:return this.formatComma(t);case ae.line_comment:return this.formatLineComment(t);case ae.block_comment:return this.formatBlockComment(t);case ae.disable_comment:return this.formatBlockComment(t);case ae.data_type:return this.formatDataType(t);case ae.keyword:return this.formatKeywordNode(t)}}formatFunctionCall(t){this.withComments(t.nameKw,()=>{this.layout.add(this.showFunctionKw(t.nameKw))}),this.formatNode(t.parenthesis)}formatParameterizedDataType(t){this.withComments(t.dataType,()=>{this.layout.add(this.showDataType(t.dataType))}),this.formatNode(t.parenthesis)}formatArraySubscript(t){let E;switch(t.array.type){case ae.data_type:E=this.showDataType(t.array);break;case ae.keyword:E=this.showKw(t.array);break;default:E=this.showIdentifier(t.array);break}this.withComments(t.array,()=>{this.layout.add(E)}),this.formatNode(t.parenthesis)}formatPropertyAccess(t){this.formatNode(t.object),this.layout.add(w.NO_SPACE,t.operator),this.formatNode(t.property)}formatParenthesis(t){const E=this.formatInlineExpression(t.children);E?(this.layout.add(t.openParen),this.layout.add(...E.getLayoutItems()),this.layout.add(w.NO_SPACE,t.closeParen,w.SPACE)):(this.layout.add(t.openParen,w.NEWLINE),Cn(this.cfg)?(this.layout.add(w.INDENT),this.layout=this.formatSubExpression(t.children)):(this.layout.indentation.increaseBlockLevel(),this.layout.add(w.INDENT),this.layout=this.formatSubExpression(t.children),this.layout.indentation.decreaseBlockLevel()),this.layout.add(w.NEWLINE,w.INDENT,t.closeParen,w.SPACE))}formatBetweenPredicate(t){this.layout.add(this.showKw(t.betweenKw),w.SPACE),this.layout=this.formatSubExpression(t.expr1),this.layout.add(w.NO_SPACE,w.SPACE,this.showNonTabularKw(t.andKw),w.SPACE),this.layout=this.formatSubExpression(t.expr2),this.layout.add(w.SPACE)}formatCaseExpression(t){this.formatNode(t.caseKw),this.layout.indentation.increaseBlockLevel(),this.layout=this.formatSubExpression(t.expr),this.layout=this.formatSubExpression(t.clauses),this.layout.indentation.decreaseBlockLevel(),this.layout.add(w.NEWLINE,w.INDENT),this.formatNode(t.endKw)}formatCaseWhen(t){this.layout.add(w.NEWLINE,w.INDENT),this.formatNode(t.whenKw),this.layout=this.formatSubExpression(t.condition),this.formatNode(t.thenKw),this.layout=this.formatSubExpression(t.result)}formatCaseElse(t){this.layout.add(w.NEWLINE,w.INDENT),this.formatNode(t.elseKw),this.layout=this.formatSubExpression(t.result)}formatClause(t){this.isOnelineClause(t)?this.formatClauseInOnelineStyle(t):Cn(this.cfg)?this.formatClauseInTabularStyle(t):this.formatClauseInIndentedStyle(t)}isOnelineClause(t){return Cn(this.cfg)?this.dialectCfg.tabularOnelineClauses[t.nameKw.text]:this.dialectCfg.onelineClauses[t.nameKw.text]}formatClauseInIndentedStyle(t){this.layout.add(w.NEWLINE,w.INDENT,this.showKw(t.nameKw),w.NEWLINE),this.layout.indentation.increaseTopLevel(),this.layout.add(w.INDENT),this.layout=this.formatSubExpression(t.children),this.layout.indentation.decreaseTopLevel()}formatClauseInOnelineStyle(t){this.layout.add(w.NEWLINE,w.INDENT,this.showKw(t.nameKw),w.SPACE),this.layout=this.formatSubExpression(t.children)}formatClauseInTabularStyle(t){this.layout.add(w.NEWLINE,w.INDENT,this.showKw(t.nameKw),w.SPACE),this.layout.indentation.increaseTopLevel(),this.layout=this.formatSubExpression(t.children),this.layout.indentation.decreaseTopLevel()}formatSetOperation(t){this.layout.add(w.NEWLINE,w.INDENT,this.showKw(t.nameKw),w.NEWLINE),this.layout.add(w.INDENT),this.layout=this.formatSubExpression(t.children)}formatLimitClause(t){this.withComments(t.limitKw,()=>{this.layout.add(w.NEWLINE,w.INDENT,this.showKw(t.limitKw))}),this.layout.indentation.increaseTopLevel(),Cn(this.cfg)?this.layout.add(w.SPACE):this.layout.add(w.NEWLINE,w.INDENT),t.offset?(this.layout=this.formatSubExpression(t.offset),this.layout.add(w.NO_SPACE,",",w.SPACE),this.layout=this.formatSubExpression(t.count)):this.layout=this.formatSubExpression(t.count),this.layout.indentation.decreaseTopLevel()}formatAllColumnsAsterisk(t){this.layout.add("*",w.SPACE)}formatLiteral(t){this.layout.add(t.text,w.SPACE)}formatIdentifier(t){this.layout.add(this.showIdentifier(t),w.SPACE)}formatParameter(t){this.layout.add(this.params.get(t),w.SPACE)}formatOperator({text:t}){this.cfg.denseOperators||this.dialectCfg.alwaysDenseOperators.includes(t)?this.layout.add(w.NO_SPACE,t):t===":"?this.layout.add(w.NO_SPACE,t,w.SPACE):this.layout.add(t,w.SPACE)}formatComma(t){this.inline?this.layout.add(w.NO_SPACE,",",w.SPACE):this.layout.add(w.NO_SPACE,",",w.NEWLINE,w.INDENT)}withComments(t,E){this.formatComments(t.leadingComments),E(),this.formatComments(t.trailingComments)}formatComments(t){t&&t.forEach(E=>{E.type===ae.line_comment?this.formatLineComment(E):this.formatBlockComment(E)})}formatLineComment(t){ul(t.precedingWhitespace||"")?this.layout.add(w.NEWLINE,w.INDENT,t.text,w.MANDATORY_NEWLINE,w.INDENT):this.layout.getLayoutItems().length>0?this.layout.add(w.NO_NEWLINE,w.SPACE,t.text,w.MANDATORY_NEWLINE,w.INDENT):this.layout.add(t.text,w.MANDATORY_NEWLINE,w.INDENT)}formatBlockComment(t){t.type===ae.block_comment&&this.isMultilineBlockComment(t)?(this.splitBlockComment(t.text).forEach(E=>{this.layout.add(w.NEWLINE,w.INDENT,E)}),this.layout.add(w.NEWLINE,w.INDENT)):this.layout.add(t.text,w.SPACE)}isMultilineBlockComment(t){return ul(t.text)||ul(t.precedingWhitespace||"")}isDocComment(t){const E=t.split(/\n/);return/^\/\*\*?$/.test(E[0])&&E.slice(1,E.length-1).every(n=>/^\s*\*/.test(n))&&/^\s*\*\/$/.test(pr(E))}splitBlockComment(t){return this.isDocComment(t)?t.split(/\n/).map(E=>/^\s*\*/.test(E)?" "+E.replace(/^\s*/,""):E):t.split(/\n/).map(E=>E.replace(/^\s*/,""))}formatSubExpression(t){return new eT({cfg:this.cfg,dialectCfg:this.dialectCfg,params:this.params,layout:this.layout,inline:this.inline}).format(t)}formatInlineExpression(t){const E=this.params.getPositionalParameterIndex();try{return new eT({cfg:this.cfg,dialectCfg:this.dialectCfg,params:this.params,layout:new gL(this.cfg.expressionWidth),inline:!0}).format(t)}catch(n){if(n instanceof da){this.params.setPositionalParameterIndex(E);return}else throw n}}formatKeywordNode(t){switch(t.tokenType){case V.RESERVED_JOIN:return this.formatJoin(t);case V.AND:case V.OR:case V.XOR:return this.formatLogicalOperator(t);default:return this.formatKeyword(t)}}formatJoin(t){Cn(this.cfg)?(this.layout.indentation.decreaseTopLevel(),this.layout.add(w.NEWLINE,w.INDENT,this.showKw(t),w.SPACE),this.layout.indentation.increaseTopLevel()):this.layout.add(w.NEWLINE,w.INDENT,this.showKw(t),w.SPACE)}formatKeyword(t){this.layout.add(this.showKw(t),w.SPACE)}formatLogicalOperator(t){this.cfg.logicalOperatorNewline==="before"?Cn(this.cfg)?(this.layout.indentation.decreaseTopLevel(),this.layout.add(w.NEWLINE,w.INDENT,this.showKw(t),w.SPACE),this.layout.indentation.increaseTopLevel()):this.layout.add(w.NEWLINE,w.INDENT,this.showKw(t),w.SPACE):this.layout.add(this.showKw(t),w.NEWLINE,w.INDENT)}formatDataType(t){this.layout.add(this.showDataType(t),w.SPACE)}showKw(t){return aR(t.tokenType)?lR(this.showNonTabularKw(t),this.cfg.indentStyle):this.showNonTabularKw(t)}showNonTabularKw(t){switch(this.cfg.keywordCase){case"preserve":return Ps(t.raw);case"upper":return t.text;case"lower":return t.text.toLowerCase()}}showFunctionKw(t){return aR(t.tokenType)?lR(this.showNonTabularFunctionKw(t),this.cfg.indentStyle):this.showNonTabularFunctionKw(t)}showNonTabularFunctionKw(t){switch(this.cfg.functionCase){case"preserve":return Ps(t.raw);case"upper":return t.text;case"lower":return t.text.toLowerCase()}}showIdentifier(t){if(t.quoted)return t.text;switch(this.cfg.identifierCase){case"preserve":return t.text;case"upper":return t.text.toUpperCase();case"lower":return t.text.toLowerCase()}}showDataType(t){switch(this.cfg.dataTypeCase){case"preserve":return Ps(t.raw);case"upper":return t.text;case"lower":return t.text.toLowerCase()}}}class GL{constructor(t,E){this.dialect=t,this.cfg=E,this.params=new NL(this.cfg.params)}format(t){const E=this.parse(t);return this.formatAst(E).trimEnd()}parse(t){return ML(this.dialect.tokenizer).parse(t,this.cfg.paramTypes||{})}formatAst(t){return t.map(E=>this.formatStatement(E)).join(`
|
||
`.repeat(this.cfg.linesBetweenQueries+1))}formatStatement(t){const E=new eT({cfg:this.cfg,dialectCfg:this.dialect.formatOptions,params:this.params,layout:new kS(new KS(SL(this.cfg)))}).format(t.children);return t.hasSemicolon&&(this.cfg.newlineBeforeSemicolon?E.add(w.NEWLINE,";"):E.add(w.NO_NEWLINE,";")),E.toString()}}class hs extends Error{}function vL(e){const t=["multilineLists","newlineBeforeOpenParen","newlineBeforeCloseParen","aliasAs","commaPosition","tabulateAlias"];for(const E of t)if(E in e)throw new hs(`${E} config is no more supported.`);if(e.expressionWidth<=0)throw new hs(`expressionWidth config must be positive number. Received ${e.expressionWidth} instead.`);if(e.params&&!HL(e.params)&&console.warn('WARNING: All "params" option values should be strings.'),e.paramTypes&&!BL(e.paramTypes))throw new hs("Empty regex given in custom paramTypes. That would result in matching infinite amount of parameters.");return e}function HL(e){return(e instanceof Array?e:Object.values(e)).every(E=>typeof E=="string")}function BL(e){return e.custom&&Array.isArray(e.custom)?e.custom.every(t=>t.regex!==""):!0}var FL=function(e,t){var E={};for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&t.indexOf(n)<0&&(E[n]=e[n]);if(e!=null&&typeof Object.getOwnPropertySymbols=="function")for(var r=0,n=Object.getOwnPropertySymbols(e);r<n.length;r++)t.indexOf(n[r])<0&&Object.prototype.propertyIsEnumerable.call(e,n[r])&&(E[n[r]]=e[n[r]]);return E};const $S={bigquery:"bigquery",db2:"db2",db2i:"db2i",duckdb:"duckdb",hive:"hive",mariadb:"mariadb",mysql:"mysql",n1ql:"n1ql",plsql:"plsql",postgresql:"postgresql",redshift:"redshift",spark:"spark",sqlite:"sqlite",sql:"sql",tidb:"tidb",trino:"trino",transactsql:"transactsql",tsql:"transactsql",singlestoredb:"singlestoredb",snowflake:"snowflake"},YL=Object.keys($S),wL={tabWidth:2,useTabs:!1,keywordCase:"preserve",identifierCase:"preserve",dataTypeCase:"preserve",functionCase:"preserve",indentStyle:"standard",logicalOperatorNewline:"before",expressionWidth:50,linesBetweenQueries:1,denseOperators:!1,newlineBeforeSemicolon:!1},bL=(e,t={})=>{if(typeof t.language=="string"&&!YL.includes(t.language))throw new hs(`Unsupported SQL dialect: ${t.language}`);const E=$S[t.language||"sql"];return VL(e,Object.assign(Object.assign({},t),{dialect:zd[E]}))},VL=(e,t)=>{var{dialect:E}=t,n=FL(t,["dialect"]);if(typeof e!="string")throw new Error("Invalid query argument. Expected string, instead got "+typeof e);const r=vL(Object.assign(Object.assign({},wL),n));return new GL(iL(E),r).format(e)},JS=e=>{const t=(e||"").toLowerCase();return t.includes("datetime")||t.includes("timestamp")},WL=e=>{const t=(e||"").toLowerCase();return t.includes("date")&&!JS(t)},XL=e=>{const t=(e||"").toLowerCase();return t==="time"||t.startsWith("time(")},en=e=>JS(e)?"datetime-local":WL(e)?"date":XL(e)?"time":"text",oR=(e,t)=>{if(e===""||e.trim()==="")return null;let E=e.trim();if(t==="datetime-local"){E=E.replace("T"," ").replace(/\//g,"-");const n=E.split(" ");return n.length===2&&n[1].split(":").length===2&&(E=`${n[0]} ${n[1]}:00`),E}return t==="date"?E.replace(/\//g,"-"):E},Ss=(e,t)=>{if(e==null)return"";const E=en(t),n=String(e);if(E==="datetime-local"){const r=n.match(/(\d{4})[-/](\d{2})[-/](\d{2})[T ](\d{2}):(\d{2}):?(\d{2})?/);if(r){const[,T,l,a,i,o,S="00"]=r;return`${T}/${l}/${a} ${i}:${o}:${S}`}}if(E==="date"){const r=n.match(/(\d{4})[-/](\d{2})[-/](\d{2})/);if(r){const[,T,l,a]=r;return`${T}/${l}/${a}`}}if(E==="time"){const r=n.match(/(\d{2}):(\d{2}):?(\d{2})?/);if(r){const[,T,l,a="00"]=r;return`${T}:${l}:${a}`}}return n},iR=(e,t)=>{if(!e||e.trim()==="")return"";const E=e.trim();if(t==="time"){const O=E.match(/^(\d{1,2}):(\d{1,2}):?(\d{1,2})?$/);if(O){const[,_,H,c="0"]=O;return`${_.padStart(2,"0")}:${H.padStart(2,"0")}:${c.padStart(2,"0")}`}const L=E.match(/^(\d{2})(\d{2})(\d{2})?$/);if(L){const[,_,H,c="00"]=L;return`${_}:${H}:${c}`}return E}let n="",r="";const T=E.match(/^(.+?)[T\s](\d{1,2}:\d{1,2}(?::\d{1,2})?)$/);T?(n=T[1],r=T[2]):(n=E,r="");let l="",a="",i="";const o=n.match(/^(\d{4})[-/.年](\d{1,2})[-/.月](\d{1,2})日?$/);o&&([,l,a,i]=o);const S=n.match(/^(\d{4})(\d{2})(\d{2})$/);S&&([,l,a,i]=S);const N=n.match(/^(\d{1,2})[-/.](\d{1,2})[-/.](\d{4})$/);if(N){const[,O,L,_]=N;l=_,parseInt(O)>12?(i=O,a=L):(a=O,i=L)}if(!l||!a||!i)return E;const R=`${l}/${a.padStart(2,"0")}/${i.padStart(2,"0")}`;if(t==="date")return R;if(r){const O=r.match(/^(\d{1,2}):(\d{1,2}):?(\d{1,2})?$/);if(O){const[,L,_,H="0"]=O;return`${R} ${L.padStart(2,"0")}:${_.padStart(2,"0")}:${H.padStart(2,"0")}`}}return t==="datetime-local"?`${R} 00:00:00`:R},RR=(e,t)=>{if(e==null)return"";const E=String(e),n=(t||"").toLowerCase(),r=n.includes("datetime")||n.includes("timestamp"),T=n.includes("date")&&!r,l=n==="time"||n.startsWith("time("),a=/^(\d{4})[-/](\d{2})[-/](\d{2})[T ](\d{2}):(\d{2}):?(\d{2})?/,i=/^(\d{4})[-/](\d{2})[-/](\d{2})$/,o=/^(\d{2}):(\d{2}):?(\d{2})?$/,S=E.match(a),N=E.match(i),R=E.match(o);if(l&&R){const[,O,L,_="00"]=R;return`${O}:${L}:${_}`}if((r||S)&&S){const[,O,L,_,H,c,A="00"]=S;return`${O}/${L}/${_} ${H}:${c}:${A}`}if((T||N)&&N){const[,O,L,_]=N;return`${O}/${L}/${_}`}return E},jL=["周一","周二","周三","周四","周五","周六","周日"];function kL({value:e,type:t,onChange:E,onClose:n,position:r}){const l=(()=>{const B=new Date;if(!e)return{year:B.getFullYear(),month:B.getMonth(),day:B.getDate(),hour:B.getHours(),minute:B.getMinutes(),second:B.getSeconds()};if(t==="time"){const j=e.match(/(\d{1,2}):(\d{1,2}):?(\d{1,2})?/);if(j)return{year:B.getFullYear(),month:B.getMonth(),day:B.getDate(),hour:parseInt(j[1]),minute:parseInt(j[2]),second:parseInt(j[3]||"0")}}else{const j=e.match(/(\d{4})[-/](\d{1,2})[-/](\d{1,2})(?:[T ](\d{1,2}):(\d{1,2}):?(\d{1,2})?)?/);if(j)return{year:parseInt(j[1]),month:parseInt(j[2])-1,day:parseInt(j[3]),hour:parseInt(j[4]||"0"),minute:parseInt(j[5]||"0"),second:parseInt(j[6]||"0")}}return{year:B.getFullYear(),month:B.getMonth(),day:B.getDate(),hour:0,minute:0,second:0}})(),[a,i]=u.useState(l.year),[o,S]=u.useState(l.month),[N,R]=u.useState({year:l.year,month:l.month,day:l.day}),[O,L]=u.useState({hour:l.hour,minute:l.minute,second:l.second}),_=u.useRef(null),H=(B,j)=>{const ee=b=>b.toString().padStart(2,"0");return t==="time"?`${ee(j.hour)}:${ee(j.minute)}:${ee(j.second)}`:t==="date"?`${B.year}/${ee(B.month+1)}/${ee(B.day)}`:`${B.year}/${ee(B.month+1)}/${ee(B.day)} ${ee(j.hour)}:${ee(j.minute)}:${ee(j.second)}`},c=(B,j)=>new Date(B,j+1,0).getDate(),A=(B,j)=>{const ee=new Date(B,j,1).getDay();return ee===0?6:ee-1},I=()=>{const B=c(a,o),j=A(a,o),ee=c(a,o-1),b=[];for(let Ee=j-1;Ee>=0;Ee--)b.push({day:ee-Ee,isCurrentMonth:!1,isToday:!1});const U=new Date;for(let Ee=1;Ee<=B;Ee++){const ce=a===U.getFullYear()&&o===U.getMonth()&&Ee===U.getDate();b.push({day:Ee,isCurrentMonth:!0,isToday:ce})}const J=42-b.length;for(let Ee=1;Ee<=J;Ee++)b.push({day:Ee,isCurrentMonth:!1,isToday:!1});return b},C=()=>{o===0?(i(a-1),S(11)):S(o-1)},M=()=>{o===11?(i(a+1),S(0)):S(o+1)},p=(B,j)=>{if(j){const ee={year:a,month:o,day:B};R(ee),E(H(ee,O))}},P=(B,j)=>{const b=Math.max(0,Math.min(B==="hour"?23:59,j)),U={...O,[B]:b};L(U),E(H(N,U))},D=()=>{const B=new Date,j={year:B.getFullYear(),month:B.getMonth(),day:B.getDate()},ee=t!=="date"?{hour:B.getHours(),minute:B.getMinutes(),second:B.getSeconds()}:O;i(B.getFullYear()),S(B.getMonth()),R(j),t!=="date"&&L(ee),E(H(j,ee))},Z=(B,j)=>j&&N.year===a&&N.month===o&&N.day===B,Y=I(),ne=({value:B,onChange:j,max:ee,label:b})=>{const[U,J]=u.useState(B.toString().padStart(2,"0"));u.useEffect(()=>{J(B.toString().padStart(2,"0"))},[B]);const Ee=De=>{De.preventDefault();const Ne=De.deltaY>0?-1:1,se=B+Ne;se>=0&&se<=ee?j(se):se<0?j(ee):j(0)},ce=De=>{const Ne=De.target.value.replace(/\D/g,"").slice(0,2);J(Ne)},ye=()=>{const De=parseInt(U)||0,Ne=Math.max(0,Math.min(ee,De));J(Ne.toString().padStart(2,"0")),j(Ne)},me=De=>{De.key==="ArrowUp"?(De.preventDefault(),j(B>=ee?0:B+1)):De.key==="ArrowDown"?(De.preventDefault(),j(B<=0?ee:B-1)):De.key==="Enter"&&ye()};return s.jsxs("div",{className:"flex flex-col items-center",children:[s.jsx("input",{type:"text",value:U,onChange:ce,onBlur:ye,onKeyDown:me,onWheel:Ee,className:`w-10 h-7 text-center text-sm font-medium bg-primary-500 text-white rounded \r
|
||
border-0 outline-none focus:ring-2 focus:ring-primary-300`}),s.jsx("span",{className:"text-[10px] text-text-tertiary mt-0.5",children:b})]})},Se=(()=>{const B=t==="time"?140:220,j=t==="time"?80:320;let ee=r.top,b=r.left;return r.top+j>window.innerHeight-20&&(ee=r.top-j-40),b+B>window.innerWidth-20&&(b=window.innerWidth-B-20),b<20&&(b=20),ee<20&&(ee=20),{top:ee,left:b}})(),he=B=>B.toString().padStart(2,"0");return s.jsxs("div",{ref:_,className:"fixed bg-white rounded-lg shadow-xl border border-primary-200 overflow-hidden",style:{top:Se.top,left:Se.left,zIndex:99999,animation:"fadeIn 0.1s ease-out"},onClick:B=>B.stopPropagation(),children:[t!=="date"&&t==="time"&&s.jsx("div",{className:"p-3 bg-primary-500",children:s.jsxs("div",{className:"flex items-center gap-1 justify-center",children:[s.jsx(ne,{value:O.hour,onChange:B=>P("hour",B),max:23,label:""}),s.jsx("span",{className:"text-white font-bold text-lg",children:":"}),s.jsx(ne,{value:O.minute,onChange:B=>P("minute",B),max:59,label:""}),s.jsx("span",{className:"text-white font-bold text-lg",children:":"}),s.jsx(ne,{value:O.second,onChange:B=>P("second",B),max:59,label:""})]})}),t!=="time"&&s.jsxs("div",{className:"p-2",style:{width:220},children:[s.jsxs("div",{className:"flex items-center justify-between mb-2",children:[s.jsx("button",{onClick:C,className:"w-6 h-6 flex items-center justify-center rounded hover:bg-light-hover text-text-tertiary hover:text-text-primary",children:s.jsx(Io,{size:14})}),s.jsxs("span",{className:"text-xs font-semibold text-text-primary",children:[a,"年",o+1,"月"]}),s.jsx("button",{onClick:M,className:"w-6 h-6 flex items-center justify-center rounded hover:bg-light-hover text-text-tertiary hover:text-text-primary",children:s.jsx(WE,{size:14})})]}),s.jsx("div",{className:"grid grid-cols-7 gap-0 mb-1",children:jL.map(B=>s.jsx("div",{className:"h-5 flex items-center justify-center text-[10px] font-medium text-primary-600",children:B},B))}),s.jsx("div",{className:"grid grid-cols-7 gap-0",children:Y.map((B,j)=>s.jsx("div",{onClick:()=>p(B.day,B.isCurrentMonth),className:`h-6 flex items-center justify-center text-xs cursor-pointer transition-all
|
||
${B.isCurrentMonth?"text-text-primary":"text-text-muted"}
|
||
${B.isToday&&!Z(B.day,B.isCurrentMonth)?"bg-gray-100 text-primary-600 font-medium":""}
|
||
${Z(B.day,B.isCurrentMonth)?"bg-primary-500 text-white font-medium rounded":B.isCurrentMonth?"hover:bg-light-hover":""}`,children:B.day},j))}),t==="datetime-local"&&s.jsx("div",{className:"mt-2 pt-2 border-t border-border-light",children:s.jsxs("div",{className:"flex items-center justify-center gap-1 bg-primary-500 rounded p-1.5",children:[s.jsx(ne,{value:O.hour,onChange:B=>P("hour",B),max:23,label:""}),s.jsx("span",{className:"text-white font-bold",children:":"}),s.jsx(ne,{value:O.minute,onChange:B=>P("minute",B),max:59,label:""}),s.jsx("span",{className:"text-white font-bold",children:":"}),s.jsx(ne,{value:O.second,onChange:B=>P("second",B),max:59,label:""})]})})]}),s.jsxs("div",{className:"px-2 py-1.5 bg-light-surface border-t border-border-light flex items-center justify-between text-[10px]",children:[s.jsx("span",{className:"text-text-secondary font-mono",children:t==="time"?`${he(O.hour)}:${he(O.minute)}:${he(O.second)}`:`今天: ${new Date().getFullYear()}/${he(new Date().getMonth()+1)}/${he(new Date().getDate())}`}),s.jsx("div",{className:"flex gap-1",children:s.jsx("button",{onClick:D,className:"px-1.5 py-0.5 text-primary-600 hover:bg-primary-50 rounded",children:t==="time"?"现在":"今天"})})]})]})}const dl=e=>{if(!e)return 0;let t=0;for(let E=0;E<e.length;E++)t+=e.charCodeAt(E)>255?14:8;return t},zS=u.memo(function({columns:t,data:E,showColumnInfo:n=!1,editable:r=!1,primaryKeyColumn:T,onCellChange:l,onDeleteRow:a,onDeleteRows:i,onRefresh:o,onSave:S,onAddRow:N,onBatchUpdate:R,modifiedCells:O,rowHeight:L=28,overscan:_=20}){const[H,c]=u.useState(new Set),A=u.useRef(null),I=u.useRef(0),C=u.useRef(0),[,M]=u.useState(0),[p,P]=u.useState(0),[D,Z]=u.useState(null),[Y,ne]=u.useState(""),[xe,Se]=u.useState(null),[he,B]=u.useState(null),j=u.useRef(null),[ee,b]=u.useState(""),[U,J]=u.useState(!1),[Ee,ce]=u.useState(0),ye=u.useRef(null),[me,De]=u.useState(!1),[Ne,se]=u.useState(new Set),[We,Xe]=u.useState(null),[W,Qe]=u.useState(!1),[Te,Ke]=u.useState(null),Ye=u.useMemo(()=>{const G=new Set;return Ne.forEach(g=>{const X=g.indexOf("-");X>0&&G.add(parseInt(g.substring(0,X)))}),G},[Ne]),Q=u.useMemo(()=>t.some(G=>G.comment),[t]),Oe=n?Q?58:44:28,pe=r?48:0,y=u.useMemo(()=>[...t].sort((G,g)=>{const X=H.has(G.name)?0:1,Ie=H.has(g.name)?0:1;return X-Ie}),[t,H]),[le,Ce]=u.useState({}),[ge,je]=u.useState(null),Be=u.useRef(0),Ze=u.useRef(0);u.useEffect(()=>{const G={};for(const f of y){if(le[f.name]){G[f.name]=le[f.name];continue}let d=dl(f.name)+24+20;n&&f.type&&(d=Math.max(d,dl(f.type)+24));let v=0;const h=Math.min(E.length,100);for(let K=0;K<h;K++){const te=E[K]?.[f.name];if(te!=null){const Ge=typeof te=="object"?JSON.stringify(te):RR(te,f.type||"");v=Math.max(v,dl(Ge))}}G[f.name]=Math.min(350,Math.max(70,Math.ceil(Math.max(d,v+24))))}Ce(G)},[y.map(G=>G.name).join(","),n]);const fe=u.useCallback((G,g)=>{g.preventDefault(),g.stopPropagation(),je(G),Be.current=g.clientX,Ze.current=le[G]||100},[le]);u.useEffect(()=>{if(!ge)return;document.body.style.cursor="col-resize",document.body.style.userSelect="none";const G=X=>{const Ie=X.clientX-Be.current,f=Math.max(50,Math.min(600,Ze.current+Ie));Ce(d=>({...d,[ge]:f}))},g=()=>{je(null),document.body.style.cursor="",document.body.style.userSelect=""};return document.addEventListener("mousemove",G),document.addEventListener("mouseup",g),()=>{document.removeEventListener("mousemove",G),document.removeEventListener("mouseup",g),document.body.style.cursor="",document.body.style.userSelect=""}},[ge]);const m=u.useMemo(()=>{const G={};let g=pe;for(const X of y)H.has(X.name)&&(G[X.name]=g,g+=le[X.name]||100);return G},[y,H,le,pe]),F=u.useMemo(()=>{if(!ee)return new Set;const G=new Set,g=ee.toLowerCase();for(let X=0;X<E.length;X++){const Ie=E[X];for(const f of y){const d=Ie[f.name];d!=null&&String(d).toLowerCase().includes(g)&&G.add(`${X}-${f.name}`)}}return G},[ee,E,y]),q=u.useMemo(()=>[...F],[F]),_e=u.useMemo(()=>{const G=I.current,g=Math.max(0,Math.floor(G/L)-_),X=Math.ceil(p/L),Ie=Math.min(E.length-1,g+X+_*2);return{startIndex:g,endIndex:Ie,totalHeight:E.length*L,offsetY:g*L}},[E.length,I.current,p,L,_]),k=u.useMemo(()=>pe+y.reduce((G,g)=>G+(le[g.name]||100),0),[y,le,pe]);u.useEffect(()=>{const G=A.current;if(!G)return;const g=()=>P(G.clientHeight-Oe);let X=null;const Ie=()=>{X||(X=requestAnimationFrame(()=>{I.current=G.scrollTop,C.current=G.scrollLeft,M(d=>d+1),X=null}))};g(),G.addEventListener("scroll",Ie,{passive:!0});const f=new ResizeObserver(g);return f.observe(G),()=>{G.removeEventListener("scroll",Ie),f.disconnect(),X&&cancelAnimationFrame(X)}},[Oe]);const ie=u.useCallback(G=>{c(g=>{const X=new Set(g);return X.has(G)?X.delete(G):X.add(G),X})},[]),Re=u.useCallback(G=>y.findIndex(g=>g.name===G),[y]),Et=u.useCallback((G,g)=>{const X=new Set,Ie=Math.min(G.row,g.row),f=Math.max(G.row,g.row),d=Math.min(Re(G.col),Re(g.col)),v=Math.max(Re(G.col),Re(g.col));for(let h=Ie;h<=f;h++)for(let K=d;K<=v;K++)y[K]&&X.add(`${h}-${y[K].name}`);return X},[y,Re]),KE=u.useCallback((G,g,X)=>{if(X.button!==0)return;De(!0),A.current?.focus();const Ie=`${G}-${g}`;X.shiftKey&&Te?se(Et(Te,{row:G,col:g})):X.ctrlKey||X.metaKey?(se(f=>{const d=new Set(f);return d.has(Ie)?d.delete(Ie):d.add(Ie),d}),Ke({row:G,col:g})):(se(new Set([Ie])),Xe({row:G,col:g}),Ke({row:G,col:g}),Qe(!0))},[Te,Et]),fE=u.useCallback((G,g)=>{W&&We&&se(Et(We,{row:G,col:g}))},[W,We,Et]),oe=u.useRef(!1);u.useEffect(()=>{const G=()=>{W&&Ne.size>1&&(oe.current=!0,setTimeout(()=>{oe.current=!1},50)),Qe(!1)};return window.addEventListener("mouseup",G),()=>window.removeEventListener("mouseup",G)},[W,Ne.size]);const qe=u.useCallback(G=>{if(q.length===0)return;const g=q[G];if(!g)return;const X=g.indexOf("-"),Ie=parseInt(g.substring(0,X)),f=g.substring(X+1),d=A.current;d&&(d.scrollTop=Math.max(0,Ie*L-p/2)),se(new Set([g])),Ke({row:Ie,col:f})},[q,L,p]),Yt=u.useCallback(()=>{if(q.length===0)return;const G=(Ee+1)%q.length;ce(G),qe(G)},[Ee,q.length,qe]),$=u.useCallback(()=>{if(q.length===0)return;const G=(Ee-1+q.length)%q.length;ce(G),qe(G)},[Ee,q.length,qe]),we=u.useCallback((G,g,X="next")=>{const Ie=Re(g);let f=G,d=X==="next"?Ie+1:Ie-1;X==="next"?d>=y.length&&(d=0,f=G+1,f>=E.length&&(f=E.length-1,d=y.length-1)):d<0&&(d=y.length-1,f=G-1,f<0&&(f=0,d=0));const v=y[d]?.name;if(v){Ke({row:f,col:v}),se(new Set([`${f}-${v}`]));const h=A.current;if(h){const K=f*L,te=h.scrollTop,Ge=te+p;K<te?h.scrollTop=K:K+L>Ge&&(h.scrollTop=K-p+L)}}return{row:f,col:y[d]?.name}},[Re,y,E.length,L,p]),Ut=u.useCallback(async()=>{if(Ne.size===0)return;const G=[...Ne],g=new Set,X=new Set;G.forEach(h=>{const K=h.indexOf("-"),te=parseInt(h.substring(0,K)),Ge=h.substring(K+1);g.add(te),X.add(Re(Ge))});const Ie=[...g].sort((h,K)=>h-K),f=[...X].sort((h,K)=>h-K),d=[];for(const h of Ie){const K=E[h];if(!K)continue;const te=[];for(const Ge of f){const Me=y[Ge];if(!Me)continue;const Nt=`${h}-${Me.name}`;if(Ne.has(Nt)){const dt=K[Me.name];te.push(dt==null?"":String(dt))}else te.push("")}d.push(te.join(" "))}const v=d.join(`
|
||
`);try{if(navigator.clipboard&&navigator.clipboard.writeText)await navigator.clipboard.writeText(v);else{const h=document.createElement("textarea");h.value=v,h.style.position="fixed",h.style.left="-9999px",h.style.top="-9999px",document.body.appendChild(h),h.focus(),h.select(),document.execCommand("copy"),document.body.removeChild(h)}}catch{const K=document.createElement("textarea");K.value=v,K.style.position="fixed",K.style.left="-9999px",K.style.top="-9999px",document.body.appendChild(K),K.focus(),K.select();try{document.execCommand("copy")}catch(te){console.error("复制失败:",te)}document.body.removeChild(K)}return{rows:Ie.length,cols:f.length}},[Ne,E,y,Re]),$E=u.useCallback(async()=>{if(!Te||!r)return;let G="";try{navigator.clipboard&&navigator.clipboard.readText&&(G=await navigator.clipboard.readText())}catch(h){console.error("读取剪贴板失败:",h);return}if(!G)return;const g=G.split(`
|
||
`).map(h=>h.split(" "));if(g.length===0)return;const X=Te.row,Ie=Re(Te.col),f=[];let d=0;for(let h=0;h<g.length;h++){const K=X+h,te=g[h];K>=E.length&&d++;for(let Ge=0;Ge<te.length;Ge++){const Me=Ie+Ge;if(Me>=y.length)continue;const Nt=y[Me],dt=te[Ge];f.push({rowIndex:K,colName:Nt.name,value:dt===""?null:dt})}}for(let h=0;h<d;h++)N?.();R&&f.length>0?setTimeout(()=>{R(f)},d>0?50:0):setTimeout(()=>{f.forEach(({rowIndex:h,colName:K,value:te})=>{l?.(h,K,te)})},d>0?50:0);const v=new Set;for(let h=0;h<g.length;h++)for(let K=0;K<g[h].length;K++){const te=Ie+K;te>=y.length||v.add(`${X+h}-${y[te].name}`)}return se(v),{rows:g.length,cols:g[0]?.length||0,newRows:d}},[Te,r,E,y,Re,N,R,l]);u.useEffect(()=>{const G=g=>{if((g.ctrlKey||g.metaKey)&&g.key==="f"&&me&&(g.preventDefault(),J(!0),setTimeout(()=>ye.current?.focus(),50)),g.key==="Escape"&&U&&(J(!1),b("")),(g.ctrlKey||g.metaKey)&&g.key==="s"&&me&&r&&(g.preventDefault(),S?.()),(g.ctrlKey||g.metaKey)&&g.key==="c"&&me&&!D&&Ne.size>0&&(g.preventDefault(),Ut()),(g.ctrlKey||g.metaKey)&&g.key==="v"&&me&&!D&&r&&Te&&(g.preventDefault(),$E()),g.key==="F5"&&me&&(g.preventDefault(),o?.()),g.key==="Tab"&&me&&!D&&Te&&(g.preventDefault(),we(Te.row,Te.col,g.shiftKey?"prev":"next")),me&&!D&&Te){if(g.key==="ArrowRight")g.preventDefault(),we(Te.row,Te.col,"next");else if(g.key==="ArrowLeft")g.preventDefault(),we(Te.row,Te.col,"prev");else if(g.key==="ArrowDown"){g.preventDefault();const X=Math.min(Te.row+1,E.length-1);Ke({row:X,col:Te.col}),se(new Set([`${X}-${Te.col}`]))}else if(g.key==="ArrowUp"){g.preventDefault();const X=Math.max(Te.row-1,0);Ke({row:X,col:Te.col}),se(new Set([`${X}-${Te.col}`]))}}if(g.key==="Enter"&&me&&!D&&Te&&r){g.preventDefault();const X=E[Te.row]?.[Te.col],Ie=y.find(d=>d.name===Te.col),f=en(Ie?.type||"");if(Z({row:Te.row,col:Te.col}),ne(Ss(X,Ie?.type||"")),f!=="text"){const d=A.current?.querySelector(`[data-row="${Te.row}"][data-col="${Te.col}"]`);if(d){const v=d.getBoundingClientRect();B({top:v.bottom+4,left:v.left})}}setTimeout(()=>j.current?.focus(),0)}if((g.key==="Delete"||g.key==="Backspace")&&me&&!D&&Te&&r&&(g.preventDefault(),l?.(Te.row,Te.col,null)),me&&!D&&Te&&r&&g.key.length===1&&!g.ctrlKey&&!g.metaKey&&!g.altKey){const X=y.find(f=>f.name===Te.col),Ie=en(X?.type||"");if(g.preventDefault(),Z({row:Te.row,col:Te.col}),ne(g.key),Ie!=="text"){const f=A.current?.querySelector(`[data-row="${Te.row}"][data-col="${Te.col}"]`);if(f){const d=f.getBoundingClientRect();B({top:d.bottom+4,left:d.left})}}setTimeout(()=>{const f=j.current;f&&(f.focus(),f.setSelectionRange(f.value.length,f.value.length))},0)}};return window.addEventListener("keydown",G),()=>window.removeEventListener("keydown",G)},[me,U,r,S,o,D,Te,we,E,l,Ne,Ut,$E]);const dT=u.useCallback(()=>{if(Ne.size===E.length*y.length)se(new Set);else{const G=new Set;for(let g=0;g<E.length;g++)for(const X of y)G.add(`${g}-${X.name}`);se(G)}},[E.length,y,Ne.size]),Zn=u.useCallback(()=>{se(new Set),Ke(null),Z(null)},[]),{startIndex:$r,endIndex:LT,totalHeight:_T,offsetY:fT}=_e,Jr=C.current;return s.jsxs("div",{className:"navi-table-container",tabIndex:0,onFocus:()=>De(!0),onBlur:G=>{G.currentTarget.contains(G.relatedTarget)||De(!1)},onMouseEnter:()=>De(!0),children:[U&&s.jsxs("div",{className:"navi-search-bar",children:[s.jsx(cT,{size:14,className:"text-gray-400"}),s.jsx("input",{ref:ye,type:"text",value:ee,onChange:G=>b(G.target.value),placeholder:"搜索数据... (Enter 下一个)",className:"navi-search-input",onKeyDown:G=>{G.key==="Enter"&&!G.shiftKey?(G.preventDefault(),Yt()):G.key==="Enter"&&G.shiftKey&&(G.preventDefault(),$())}}),ee&&s.jsx("span",{className:"text-xs text-gray-500",children:q.length>0?`${Ee+1}/${q.length}`:"0/0"}),s.jsx("button",{onClick:$,disabled:q.length===0,className:"navi-search-btn",children:s.jsx(Io,{size:16})}),s.jsx("button",{onClick:Yt,disabled:q.length===0,className:"navi-search-btn",children:s.jsx(WE,{size:16})}),s.jsx("button",{onClick:()=>{J(!1),b("")},className:"navi-search-btn",children:s.jsx(tE,{size:16})})]}),s.jsxs("div",{ref:A,className:"navi-scroll-container",onClick:G=>{oe.current||(G.target===G.currentTarget||G.target.classList.contains("navi-body"))&&Zn()},children:[s.jsxs("div",{className:"navi-header",style:{minWidth:k},children:[r&&s.jsx("div",{className:"navi-row-number-header",style:{width:pe},onClick:dT,children:"#"}),y.map(G=>{const g=H.has(G.name),X=le[G.name]||100;return s.jsxs("div",{className:`navi-header-cell ${g?"pinned":""} ${ge===G.name?"resizing":""}`,style:{width:X,minWidth:X,position:g?"sticky":"relative",left:g?m[G.name]:"auto",boxShadow:g&&Jr>0?"2px 0 4px rgba(0,0,0,0.05)":"none",height:Oe},title:g?`取消固定 ${G.name}`:`固定 ${G.name}`,children:[s.jsxs("div",{className:"navi-header-content",onClick:()=>ie(G.name),children:[s.jsxs("div",{className:"navi-header-row",children:[s.jsx("span",{className:"navi-col-name",children:G.name}),n&&G.key==="PRI"&&s.jsx(OT,{size:10,className:"text-amber-500"}),s.jsx("span",{className:`navi-pin-icon ${g?"active":""}`,children:g?s.jsx(ju,{size:10}):s.jsx(Xu,{size:10})})]}),n&&G.type&&s.jsx("div",{className:"navi-col-type",children:G.type}),n&&G.comment&&s.jsx("div",{className:"navi-col-comment",title:G.comment,children:G.comment})]}),s.jsx("div",{className:"navi-resize-handle",onMouseDown:Ie=>fe(G.name,Ie)})]},G.name)})]}),s.jsxs("div",{className:"navi-body",style:{height:Math.max(_T,p),minWidth:k},onClick:G=>{oe.current||G.target===G.currentTarget&&Zn()},children:[s.jsx("div",{className:"navi-rows-container",style:{transform:`translateY(${fT}px)`},children:Array.from({length:LT-$r+1},(G,g)=>{const X=$r+g,Ie=E[X];if(!Ie)return null;const f=Ye.has(X);return s.jsxs("div",{className:`navi-row ${f?"selected":""}`,style:{height:L},onContextMenu:d=>{if(r){if(d.preventDefault(),Ye.size===0){const v=y[0]?.name;v&&(se(new Set([`${X}-${v}`])),Ke({row:X,col:v}))}Se({x:d.clientX,y:d.clientY,row:X,col:""})}},children:[r&&s.jsx("div",{className:`navi-row-number ${f?"selected":""}`,style:{width:pe,height:L},onClick:d=>{const v=new Set;for(const h of y)v.add(`${X}-${h.name}`);d.ctrlKey||d.metaKey?se(h=>{const K=new Set(h);return v.forEach(te=>{K.has(te)?K.delete(te):K.add(te)}),K}):(se(v),Ke({row:X,col:y[0]?.name||""}))},children:X+1}),y.map(d=>{const v=H.has(d.name),h=le[d.name]||100,K=Ie[d.name],te=`${X}-${d.name}`,Ge=D?.row===X&&D?.col===d.name,Me=Ne.has(te),Nt=Te?.row===X&&Te?.col===d.name,dt=O?.has(te),pE=F.has(te),qn=q[Ee]===te;let er=null;K!=null&&(er=typeof K=="object"?JSON.stringify(K):RR(K,d.type||""));let JE="transparent";return qn?JE="#fef08a":pE?JE="rgba(250, 204, 21, 0.2)":Nt?JE="rgba(59, 130, 246, 0.15)":Me?JE="rgba(59, 130, 246, 0.1)":dt?JE="rgba(249, 115, 22, 0.1)":v&&(JE="#f8fafc"),s.jsx("div",{"data-row":X,"data-col":d.name,className:"navi-cell",style:{background:JE,position:v?"sticky":"relative",left:v?m[d.name]:"auto",width:h,minWidth:h,maxWidth:h,height:L,boxShadow:v&&Jr>0?"2px 0 4px rgba(0,0,0,0.05)":"none",outline:Nt&&!Ge?"2px solid #3b82f6":"none",outlineOffset:"-1px",zIndex:v?10:1},onMouseDown:It=>KE(X,d.name,It),onMouseEnter:()=>fE(X,d.name),onDoubleClick:It=>{if(r){const pT=en(d.type||"");if(Z({row:X,col:d.name}),ne(Ss(K,d.type||"")),pT!=="text"){const oE=It.currentTarget.getBoundingClientRect();B({top:oE.bottom+4,left:oE.left})}else B(null);setTimeout(()=>j.current?.focus(),0)}},onContextMenu:It=>{It.preventDefault(),It.stopPropagation(),Ne.has(te)||(se(new Set([te])),Ke({row:X,col:d.name})),Se({x:It.clientX,y:It.clientY,row:X,col:d.name})},title:er||"",children:Ge?(()=>{const It=en(d.type||""),pT=Ss(K,d.type||""),oE=()=>{const ve=oR(Y,It);Y!==pT&&l?.(X,d.name,ve)};return It!=="text"?s.jsxs("div",{className:"navi-date-cell-edit",children:[s.jsx(hi,{size:12,className:"navi-date-icon"}),s.jsx("input",{ref:j,type:"text",value:Y,onChange:ve=>ne(ve.target.value),onBlur:()=>{if(!he){const ve=iR(Y,It);ve!==Y&&ne(ve),oE(),Z(null)}},onKeyDown:ve=>{if(ve.key==="Enter"){const zE=iR(Y,It);ne(zE),oE(),Z(null),B(null);const xt=Math.min(X+1,E.length-1);Ke({row:xt,col:d.name}),se(new Set([`${xt}-${d.name}`]))}else ve.key==="Escape"&&(Z(null),B(null))},onClick:ve=>ve.stopPropagation(),onMouseDown:ve=>ve.stopPropagation(),placeholder:It==="date"?"YYYY/MM/DD":It==="time"?"HH:MM:SS":"YYYY/MM/DD HH:MM:SS",className:"navi-date-input-field",autoFocus:!0})]}):s.jsx("input",{ref:j,type:"text",value:Y,onChange:ve=>ne(ve.target.value),onBlur:()=>{oE(),Z(null)},onKeyDown:ve=>{if(ve.key==="Enter"){oE(),Z(null);const zE=Math.min(X+1,E.length-1);Ke({row:zE,col:d.name}),se(new Set([`${zE}-${d.name}`]))}else if(ve.key==="Tab"){ve.preventDefault(),oE();const zE=Re(d.name);let xt=X,mE=ve.shiftKey?zE-1:zE+1;ve.shiftKey?mE<0&&(mE=y.length-1,xt=X-1,xt<0&&(xt=0,mE=0)):mE>=y.length&&(mE=0,xt=X+1,xt>=E.length&&(xt=E.length-1,mE=y.length-1));const tr=y[mE]?.name;if(tr){const QS=y[mE],ZS=E[xt]?.[tr];Z({row:xt,col:tr}),ne(Ss(ZS,QS?.type||"")),Ke({row:xt,col:tr}),se(new Set([`${xt}-${tr}`])),setTimeout(()=>j.current?.focus(),0)}}else ve.key==="Escape"?Z(null):(ve.ctrlKey||ve.metaKey)&&ve.key==="s"&&(ve.preventDefault(),oE(),Z(null),S?.())},onClick:ve=>ve.stopPropagation(),onMouseDown:ve=>ve.stopPropagation(),className:"navi-cell-input",autoFocus:!0})})():K===null?s.jsx("span",{className:"navi-null",children:"NULL"}):K===""?s.jsx("span",{className:"navi-empty"}):typeof K=="object"?s.jsx("span",{className:"navi-json",children:er}):en(d.type||"")!=="text"?s.jsxs("span",{className:"navi-date-cell",children:[s.jsx(hi,{size:12,className:"navi-date-icon"}),s.jsx("span",{className:"navi-date-text",children:er})]}):s.jsx("span",{className:"navi-value",children:er})},d.name)})]},X)})}),(()=>{const G=E.length*L,g=Math.max(0,Math.ceil((p-G)/L));return g<=0?null:Array.from({length:g},(X,Ie)=>s.jsxs("div",{className:"navi-row empty-row",style:{height:L},onClick:()=>{oe.current||Zn()},children:[r&&s.jsx("div",{className:"navi-row-number empty",style:{width:pe,height:L}}),y.map(f=>{const d=H.has(f.name),v=le[f.name]||100;return s.jsx("div",{className:"navi-cell empty",style:{position:d?"sticky":"relative",left:d?m[f.name]:"auto",width:v,minWidth:v,maxWidth:v,height:L,zIndex:d?10:1}},f.name)})]},`empty-${Ie}`))})()]}),E.length===0&&s.jsx("div",{className:"navi-empty",children:"暂无数据"})]}),xe&&s.jsxs(s.Fragment,{children:[s.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>{Se(null),se(new Set)}}),s.jsxs("div",{className:"navi-context-menu",style:{left:Math.min(xe.x,window.innerWidth-200),top:Math.min(xe.y,window.innerHeight-300)},children:[Ne.size>0&&s.jsxs("div",{className:"navi-context-info",children:["已选 ",Ne.size," 格 · ",Ye.size," 行"]}),s.jsxs("button",{className:"navi-context-item",onClick:async()=>{await Ut(),Se(null)},children:[s.jsx(US,{size:13}),s.jsx("span",{children:"复制"}),s.jsx("span",{className:"navi-shortcut",children:"Ctrl+C"})]}),r&&s.jsxs(s.Fragment,{children:[s.jsxs("button",{className:"navi-context-item",onClick:async()=>{await $E(),Se(null)},children:[s.jsx(Gu,{size:13}),s.jsx("span",{children:"粘贴"}),s.jsx("span",{className:"navi-shortcut",children:"Ctrl+V"})]}),s.jsx("div",{className:"navi-context-divider"}),s.jsxs("button",{className:"navi-context-item warning",onClick:()=>{Ne.forEach(G=>{const g=G.indexOf("-"),X=parseInt(G.substring(0,g)),Ie=G.substring(g+1);l?.(X,Ie,null)}),Se(null)},children:[s.jsx(Hu,{size:13}),s.jsxs("span",{children:["设为 ",s.jsx("span",{className:"font-mono",children:"NULL"})]}),Ne.size>1&&s.jsxs("span",{className:"navi-shortcut",children:[Ne.size,"格"]})]}),s.jsxs("button",{className:"navi-context-item",onClick:()=>{Ne.forEach(G=>{const g=G.indexOf("-"),X=parseInt(G.substring(0,g)),Ie=G.substring(g+1);l?.(X,Ie,"")}),Se(null)},children:[s.jsx(Ju,{size:13}),s.jsx("span",{children:"设为空字符串"}),Ne.size>1&&s.jsxs("span",{className:"navi-shortcut",children:[Ne.size,"格"]})]}),s.jsx("div",{className:"navi-context-divider"}),s.jsxs("button",{className:"navi-context-item danger",onClick:()=>{if(Ye.size>1){const G=[...Ye].sort((g,X)=>X-g);i?i(G):G.forEach(g=>a?.(g))}else a?.(xe.row);Se(null),se(new Set)},children:[s.jsx(IE,{size:13}),Ye.size>1?`删除 ${Ye.size} 行`:"删除此行"]})]}),s.jsx("div",{className:"navi-context-divider"}),s.jsxs("button",{className:"navi-context-item success",onClick:()=>{o?.(),Se(null),se(new Set)},children:[s.jsx(Vr,{size:13}),s.jsx("span",{children:"刷新数据"}),s.jsx("span",{className:"navi-shortcut",children:"F5"})]})]})]}),D&&he&&(()=>{const G=y.find(X=>X.name===D.col),g=en(G?.type||"");return g==="text"?null:s.jsxs(s.Fragment,{children:[s.jsx("div",{className:"fixed inset-0 z-[9998]",onClick:()=>{Z(null),B(null)}}),s.jsx(kL,{value:Y,type:g,position:he,onChange:X=>{ne(X);const Ie=oR(X,g);l&&D&&l(D.row,D.col,Ie)},onClose:()=>{Z(null),B(null)}})]})})()]})}),KL=u.lazy(()=>TO(()=>import("./SqlEditor-Da5-w0EM.js").then(e=>e.S),__vite__mapDeps([0,1]),import.meta.url)),$L=u.memo(()=>s.jsx("div",{className:"h-full flex items-center justify-center bg-light-surface",children:s.jsxs("div",{className:"flex flex-col items-center gap-3",children:[s.jsx(Fn,{className:"w-6 h-6 animate-spin text-primary-500"}),s.jsx("span",{className:"text-sm text-text-tertiary",children:"加载编辑器..."})]})})),JL=u.memo(function({tabs:t,activeTab:E,activeConnection:n,selectedDatabase:r,connections:T,connectedIds:l,databasesMap:a,databases:i,tables:o,columns:S,onTabChange:N,onCloseTab:R,onNewQuery:O,onRunQuery:L,onUpdateSql:_,onUpdateTabTitle:H,onLoadTablePage:c,onChangeTablePageSize:A,onNewConnectionWithType:I,onUpdateTableCell:C,onDeleteTableRow:M,onDeleteTableRows:p,onSaveTableChanges:P,onDiscardTableChanges:D,onRefreshTable:Z,onAddTableRow:Y,onUpdateNewRow:ne,onDeleteNewRow:xe,onSelectConnection:Se,onSelectDatabase:he,loadingTables:B}){u.useEffect(()=>{const U=J=>{if(J.ctrlKey&&J.key==="w"&&(J.preventDefault(),E!=="welcome"&&R(E)),J.ctrlKey&&J.key==="s"){const Ee=t.find(ce=>ce.id===E);Ee&&"tableName"in Ee&&Ee.pendingChanges?.size>0&&(J.preventDefault(),P?.(E))}};return window.addEventListener("keydown",U),()=>window.removeEventListener("keydown",U)},[E,t,R,P]);const j=t.find(U=>U.id===E),ee=U=>"tableName"in U?U.tableName:U.title,b=U=>"tableName"in U?s.jsx(zn,{size:13,className:"text-warning-500"}):null;return s.jsxs("div",{className:"flex-1 flex flex-col bg-white",children:[s.jsxs("div",{className:"h-10 bg-light-surface flex items-stretch px-1 border-b border-border-default overflow-x-auto scrollbar-thin",children:[s.jsxs("button",{onClick:()=>N("welcome"),className:`px-4 text-sm flex items-center gap-1.5 transition-all shrink-0 relative
|
||
${E==="welcome"?"text-text-primary font-medium":"text-text-tertiary hover:text-text-secondary hover:bg-light-hover"}`,children:[s.jsx(Gt,{size:14,className:E==="welcome"?"text-primary-500":""}),"主页",E==="welcome"&&s.jsx("span",{className:"tab-indicator"})]}),s.jsx("div",{className:"w-px h-5 bg-border-light self-center mx-1"}),t.map(U=>s.jsxs("div",{className:`px-3 flex items-center gap-2 text-sm group transition-all shrink-0 relative cursor-pointer
|
||
${E===U.id?"text-text-primary font-medium":"text-text-tertiary hover:text-text-secondary hover:bg-light-hover"}`,onClick:()=>N(U.id),children:[b(U),s.jsx("span",{className:"max-w-[120px] truncate",children:ee(U)}),s.jsx("button",{onClick:J=>{J.stopPropagation(),R(U.id)},className:"opacity-0 group-hover:opacity-100 hover:text-danger-500 p-0.5 rounded transition-all",children:s.jsx(tE,{size:13})}),E===U.id&&s.jsx("span",{className:"tab-indicator"})]},U.id)),s.jsx("button",{onClick:O,className:"w-9 flex items-center justify-center text-text-muted hover:text-primary-500 hover:bg-light-hover shrink-0 transition-colors rounded-lg mx-1 my-1",title:"新建查询",children:s.jsx(In,{size:16})})]}),s.jsx("div",{className:"flex-1 min-h-0",children:E==="welcome"?s.jsx(zL,{onNewQuery:O,onNewConnectionWithType:I}):j?"tableName"in j?s.jsx(QL,{tab:j,isLoading:B?.has(j.id),onLoadPage:U=>c(j.id,U),onChangePageSize:U=>A?.(j.id,U),onCellChange:(U,J,Ee)=>C?.(j.id,U,J,Ee),onDeleteRow:U=>M?.(j.id,U),onDeleteRows:U=>p?.(j.id,U),onSave:()=>P?.(j.id),onDiscard:()=>D?.(j.id),onRefresh:()=>Z?.(j.id),onAddRow:()=>Y?.(j.id),onUpdateNewRow:(U,J,Ee)=>ne?.(j.id,U,J,Ee),onDeleteNewRow:U=>xe?.(j.id,U)}):s.jsx(ZL,{tab:j,connectionId:n,selectedDatabase:r,connections:T,connectedIds:l,databasesMap:a,databases:i,tables:o,columns:S,onRun:U=>L(j.id,U),onUpdateSql:U=>_(j.id,U),onUpdateTitle:U=>H(j.id,U),onSelectConnection:Se,onSelectDatabase:he}):null})]})}),zL=u.memo(function({onNewQuery:t,onNewConnectionWithType:E}){return s.jsxs("div",{className:"h-full flex flex-col items-center justify-center bg-gradient-to-b from-white via-light-surface to-light-elevated",children:[s.jsx("div",{className:"flex items-center gap-4 mb-4",children:s.jsx("div",{className:"w-16 h-16 rounded-2xl bg-primary-500 flex items-center justify-center shadow-btn",children:s.jsx(Gt,{size:32,className:"text-white"})})}),s.jsx("h1",{className:"text-4xl font-bold text-text-primary mb-2",children:"EasySQL"}),s.jsx("p",{className:"text-text-tertiary text-lg mb-8",children:"简洁高效的数据库管理工具"}),s.jsxs("button",{onClick:t,className:`px-8 py-3 bg-primary-500 hover:bg-primary-600 text-white text-base font-medium \r
|
||
rounded-xl shadow-btn hover:shadow-btn-hover transition-all flex items-center gap-2`,children:[s.jsx(Zu,{size:18}),"开始查询"]}),s.jsxs("div",{className:"flex items-center gap-6 mt-6 text-xs text-text-muted",children:[s.jsxs("span",{className:"flex items-center gap-2",children:[s.jsx("kbd",{className:"px-2 py-1 bg-light-elevated rounded border border-border-default font-mono",children:"Ctrl+Q"}),"新建查询"]}),s.jsxs("span",{className:"flex items-center gap-2",children:[s.jsx("kbd",{className:"px-2 py-1 bg-light-elevated rounded border border-border-default font-mono",children:"Ctrl+Enter"}),"执行"]})]}),s.jsxs("div",{className:"mt-12",children:[s.jsx("p",{className:"text-center text-text-muted text-sm mb-4 font-medium",children:"支持的数据库"}),s.jsx("div",{className:"flex gap-3 justify-center mb-3",children:Object.entries(rE).slice(0,5).map(([n,r])=>s.jsxs("button",{onClick:()=>r.supported&&E?.(n),className:`db-tile w-20 h-20 flex flex-col items-center justify-center
|
||
${r.supported?"":"cursor-not-allowed opacity-40"}`,style:{background:r.color},title:r.supported?`创建 ${r.name} 连接`:`${r.name} - 即将支持`,disabled:!r.supported,children:[s.jsx("span",{className:"text-3xl mb-1",children:r.icon}),s.jsx("span",{className:"text-[10px] font-medium text-white/90",children:r.name})]},n))}),s.jsx("div",{className:"flex gap-3 justify-center",children:Object.entries(rE).slice(5,9).map(([n,r])=>s.jsxs("button",{onClick:()=>r.supported&&E?.(n),className:`db-tile w-20 h-20 flex flex-col items-center justify-center
|
||
${r.supported?"":"cursor-not-allowed opacity-40"}`,style:{background:r.color},title:r.supported?`创建 ${r.name} 连接`:`${r.name} - 即将支持`,disabled:!r.supported,children:[s.jsx("span",{className:"text-3xl mb-1",children:r.icon}),s.jsx("span",{className:"text-[10px] font-medium text-white/90",children:r.name})]},n))})]})]})}),QL=u.memo(function({tab:t,isLoading:E,onLoadPage:n,onChangePageSize:r,onCellChange:T,onDeleteRow:l,onDeleteRows:a,onSave:i,onDiscard:o,onRefresh:S,onAddRow:N,onUpdateNewRow:R,onDeleteNewRow:O}){const L=Math.ceil(t.total/t.pageSize),_=(t.pendingChanges?.size||0)>0||(t.deletedRows?.size||0)>0||(t.newRows?.length||0)>0,H=t.columns.find(D=>D.key==="PRI")?.name||t.columns[0]?.name,c=new Set;t.pendingChanges?.forEach((D,Z)=>{const Y=parseInt(Z);Object.keys(D).forEach(ne=>{c.add(`${Y}-${ne}`)})});const A=t.newRows?.length||0,I=t.data||[],C=I.filter((D,Z)=>!t.deletedRows?.has(Z)).length;if(A>0)for(let D=0;D<A;D++){const Z=C+D;t.columns.forEach(Y=>{c.add(`${Z}-${Y.name}`)})}const M=[...I.filter((D,Z)=>!t.deletedRows?.has(Z)),...t.newRows||[]],p=I.map((D,Z)=>Z).filter(D=>!t.deletedRows?.has(D)),P=(t.pendingChanges?.size||0)+(t.deletedRows?.size||0)+(t.newRows?.length||0);return s.jsxs("div",{style:{height:"100%",display:"flex",flexDirection:"column"},children:[s.jsxs("div",{className:"bg-light-surface border-b border-border-default flex items-center justify-between px-4 gap-3",style:{flexShrink:0,height:44},children:[s.jsxs("div",{className:"flex items-center gap-3",children:[s.jsxs("div",{className:"flex items-center gap-2 px-3 py-1.5 bg-white rounded-lg border border-border-default",children:[s.jsx(zn,{size:15,className:"text-warning-500"}),s.jsx("span",{className:"font-medium text-text-primary text-sm",children:t.tableName})]}),s.jsxs("span",{className:"text-text-muted text-xs",children:[t.total.toLocaleString()," 行"]}),E&&s.jsxs("div",{className:"flex items-center gap-1.5 text-primary-500 text-xs",children:[s.jsx(Fn,{size:13,className:"animate-spin"}),"加载中..."]})]}),_&&s.jsxs("div",{className:"px-2.5 py-1 bg-warning-50 text-warning-600 text-xs font-medium rounded-md border border-warning-200",children:[P," 项待保存"]}),s.jsxs("div",{className:"flex items-center gap-1.5",children:[s.jsx("button",{onClick:()=>n(t.page-1),disabled:t.page<=1||E,className:"p-1 hover:bg-light-hover disabled:opacity-30 rounded transition-colors text-text-primary",children:s.jsx(Io,{size:16})}),s.jsxs("span",{className:"text-xs min-w-[70px] text-center text-text-primary",children:[s.jsx("span",{className:"text-primary-600 font-medium",children:t.page})," / ",L]}),s.jsx("button",{onClick:()=>n(t.page+1),disabled:t.page>=L||E,className:"p-1 hover:bg-light-hover disabled:opacity-30 rounded transition-colors text-text-primary",children:s.jsx(WE,{size:16})}),s.jsxs("select",{value:t.pageSize,onChange:D=>r?.(parseInt(D.target.value)),disabled:E,className:"h-7 px-2 text-xs bg-white border border-border-default rounded cursor-pointer text-text-primary",children:[s.jsx("option",{value:100,children:"100"}),s.jsx("option",{value:500,children:"500"}),s.jsx("option",{value:1e3,children:"1000"}),s.jsx("option",{value:2e3,children:"2000"})]})]})]}),s.jsx("div",{style:{flex:1,position:"relative",overflow:"hidden"},children:E&&t.columns.length===0?s.jsx("div",{className:"absolute inset-0 flex flex-col items-center justify-center bg-light-bg",children:s.jsxs("div",{className:"flex flex-col items-center gap-4",children:[s.jsx("div",{className:"w-12 h-12 rounded-full bg-primary-100 flex items-center justify-center",children:s.jsx(Fn,{size:24,className:"animate-spin text-primary-500"})}),s.jsxs("div",{className:"text-center",children:[s.jsx("div",{className:"text-sm font-medium text-text-primary mb-1",children:"正在加载表数据"}),s.jsx("div",{className:"text-xs text-text-muted",children:t.tableName})]})]})}):s.jsxs(s.Fragment,{children:[E&&s.jsx("div",{className:"loading-overlay",children:s.jsxs("div",{className:"flex flex-col items-center gap-3",children:[s.jsx(Fn,{size:28,className:"animate-spin text-primary-500"}),s.jsx("span",{className:"text-sm text-text-secondary",children:"加载数据中..."})]})}),s.jsx("div",{style:{position:"absolute",top:0,left:0,right:0,bottom:0},children:s.jsx(zS,{columns:t.columns,data:M,showColumnInfo:!0,editable:!0,primaryKeyColumn:H,modifiedCells:c,onCellChange:(D,Z,Y)=>{D>=C?R?.(D-C,Z,Y):T?.(p[D],Z,Y)},onDeleteRow:D=>{D>=C?O?.(D-C):l?.(p[D])},onDeleteRows:D=>{const Z=[],Y=[];D.forEach(ne=>{ne>=C?Y.push(ne-C):Z.push(p[ne])}),Z.length>0&&a?.(Z),Y.sort((ne,xe)=>xe-ne).forEach(ne=>O?.(ne))},onRefresh:S,onSave:i,onAddRow:N,onBatchUpdate:D=>{D.forEach(({rowIndex:Z,colName:Y,value:ne})=>{if(Z>=C)R?.(Z-C,Y,ne);else{const xe=p[Z];xe!==void 0&&T?.(xe,Y,ne)}})}})})]})}),s.jsxs("div",{className:"bg-light-surface border-t border-border-default flex items-center px-3 gap-1",style:{flexShrink:0,height:36},children:[s.jsxs("div",{className:"flex items-center gap-0.5",children:[s.jsx("button",{onClick:N,disabled:E,className:"w-7 h-7 flex items-center justify-center hover:bg-light-hover disabled:opacity-40 rounded text-text-tertiary hover:text-success-500",children:s.jsx(In,{size:15})}),s.jsx("button",{onClick:()=>A>0&&O?.(A-1),disabled:E||A===0,className:"w-7 h-7 flex items-center justify-center hover:bg-light-hover disabled:opacity-40 rounded text-text-tertiary hover:text-danger-500",children:s.jsx(gS,{size:15})}),s.jsx("div",{className:"w-px h-4 bg-border-default mx-1"}),s.jsx("button",{onClick:i,disabled:E||!_,className:`w-7 h-7 flex items-center justify-center rounded ${_?"hover:bg-success-50 text-success-500":"text-text-disabled"}`,children:s.jsx(aE,{size:15})}),s.jsx("button",{onClick:o,disabled:E||!_,className:`w-7 h-7 flex items-center justify-center rounded ${_?"hover:bg-danger-50 text-danger-500":"text-text-disabled"}`,children:s.jsx(tE,{size:15})}),s.jsx("button",{onClick:S,disabled:E,className:"w-7 h-7 flex items-center justify-center hover:bg-light-hover disabled:opacity-40 rounded text-text-tertiary",children:s.jsx(Vr,{size:13})})]}),s.jsx("div",{className:"flex-1 text-center text-xs text-text-muted",children:_?`${t.pendingChanges?.size||0} 修改 · ${t.deletedRows?.size||0} 删除 · ${A} 新增`:`共 ${M.length} 行`}),s.jsxs("div",{className:"text-xs text-text-disabled font-mono",children:["SELECT * FROM `",t.tableName,"` LIMIT ",t.pageSize]})]})]})}),ZL=u.memo(function({tab:t,connectionId:E,selectedDatabase:n,connections:r,connectedIds:T,databasesMap:l,databases:a,tables:i,columns:o,onRun:S,onUpdateSql:N,onUpdateTitle:R,onSelectConnection:O,onSelectDatabase:L}){const[_,H]=u.useState(!1),[c,A]=u.useState(!1),I=r.find(Q=>Q.id===E),C=E?l.get(E)||[]:[],[M,p]=u.useState(t.sql),[P,D]=u.useState(null),[Z,Y]=u.useState(!1),[ne,xe]=u.useState(!1),[Se,he]=u.useState([]),[B,j]=u.useState([]),[ee,b]=u.useState(new Set),[U,J]=u.useState(new Set);u.useEffect(()=>{if(t.results){const Q=t.results.rows.map(Oe=>{const pe={};return t.results?.columns.forEach((y,le)=>{pe[y]=Oe[le]}),pe});he(Q),j(JSON.parse(JSON.stringify(Q))),b(new Set),J(new Set)}else he([]),j([]),b(new Set),J(new Set)},[t.results]);const Ee=u.useCallback(Q=>{const Oe=Q.match(/\bFROM\s+[`"]?(\w+)[`"]?(?:\s*\.\s*[`"]?(\w+)[`"]?)?/i);return Oe?Oe[2]||Oe[1]:null},[]),ce=u.useCallback(Q=>{const Oe=Q.match(/\bFROM\s+[`"]?(\w+)[`"]?\s*\.\s*[`"]?(\w+)[`"]?/i);return Oe?Oe[1]:null},[]),ye=u.useCallback(async()=>{if(!E||ee.size===0&&U.size===0)return;const Q=Ee(M);if(!Q){alert("无法从SQL中解析表名,只支持简单的 SELECT ... FROM table_name 格式");return}const Oe=ce(M)||n;if(!Oe){alert("无法确定数据库,请先选择数据库");return}let y=(o.get(`${Oe}.${Q}`)||o.get(Q)||[]).find(le=>le.key==="PRI")?.name;if(!y&&t.results?.columns.length&&(y=t.results.columns[0]),!y){alert("无法确定主键列,无法保存修改");return}xe(!0);try{let le=0,Ce=0,ge=0,je=0;if(U.size>0)for(const Ze of U){const fe=B[Ze];if(!fe)continue;const m=fe[y];if(m==null){je++;continue}const F=await Le.deleteRow(E,Oe,Q,{column:y,value:m});F.success?ge++:(je++,console.error("删除失败:",F.error))}if(ee.size>0){const Ze=new Map;ee.forEach(fe=>{const m=fe.indexOf("-"),F=parseInt(fe.substring(0,m)),q=fe.substring(m+1);Ze.has(F)||Ze.set(F,{}),Ze.get(F)[q]=Se[F]?.[q]});for(const[fe,m]of Ze){let F=fe;const q=[...U].sort((Re,Et)=>Re-Et);for(const Re of q)Re<=F&&F++;const _e=B[F];if(!_e)continue;const k=_e[y];if(k==null){Ce++;continue}const ie=await Le.updateRow(E,Oe,Q,{column:y,value:k},m);ie.success?le++:(Ce++,console.error("更新失败:",ie.error))}}const Be=[];ge>0&&Be.push(`删除 ${ge} 行`),le>0&&Be.push(`更新 ${le} 行`),je>0&&Be.push(`删除失败 ${je} 行`),Ce>0&&Be.push(`更新失败 ${Ce} 行`),ge>0||le>0?(j(JSON.parse(JSON.stringify(Se))),b(new Set),J(new Set),alert(`操作完成:${Be.join(",")}`)):(je>0||Ce>0)&&alert(`操作失败:${Be.join(",")}`)}catch(le){alert("保存失败: "+le.message)}finally{xe(!1)}},[E,n,M,ee,U,Se,B,o,t.results,Ee,ce]),me=u.useCallback(()=>{S(M),N(M)},[M,S,N]),De=u.useCallback(async()=>{const Q=await Le.openFile();Q&&!Q.error&&(p(Q.content),D(Q.path),N(Q.content),R?.(Q.name))},[N,R]),Ne=u.useCallback(async()=>{const Q=await Le.saveFile(P,M);Q&&!Q.error&&(D(Q.path),R?.(Q.name))},[P,M,R]),se=u.useCallback(()=>{try{const Q=bL(M,{language:"mysql",tabWidth:2,keywordCase:"upper",linesBetweenQueries:2});p(Q),N(Q)}catch(Q){console.error("SQL 格式化失败:",Q)}},[M,N]),We=u.useCallback(Q=>{for(const[,Oe]of o){const pe=Oe.find(y=>y.name===Q||y.name.toLowerCase()===Q.toLowerCase());if(pe)return pe}},[o]),Xe=u.useCallback(async()=>{if(!t.results||Se.length===0)return;const Q=window.electronAPI;if(!Q)return;const Oe=await Q.saveDialog({filters:[{name:"CSV",extensions:["csv"]}],defaultPath:`query_${Date.now()}.csv`});if(!Oe)return;const pe=t.results.columns.join(","),y=Se.map(le=>t.results.columns.map(Ce=>{const ge=le[Ce];return ge===null?"":typeof ge=="string"?`"${ge.replace(/"/g,'""')}"`:String(ge)}).join(",")).join(`
|
||
`);await Q.writeFile(Oe,`${pe}
|
||
${y}`)},[t.results,Se]),W=u.useCallback(async()=>{if(!t.results||Se.length===0)return;const Q=window.electronAPI;if(!Q)return;const Oe=await Q.saveDialog({filters:[{name:"SQL",extensions:["sql"]}],defaultPath:`query_${Date.now()}.sql`});if(!Oe)return;let pe=`-- ${new Date().toLocaleString()}
|
||
-- ${Se.length} 条
|
||
|
||
`;Se.forEach(y=>{const le=t.results.columns.map(Ce=>{const ge=y[Ce];return ge===null?"NULL":typeof ge=="number"?ge:`'${String(ge).replace(/'/g,"''")}'`}).join(", ");pe+=`INSERT INTO table_name (\`${t.results.columns.join("`, `")}\`) VALUES (${le});
|
||
`}),await Q.writeFile(Oe,pe)},[t.results,Se]),Qe=u.useCallback((Q,Oe,pe)=>{he(y=>{const le=[...y];return le[Q]&&(le[Q]={...le[Q],[Oe]:pe}),le}),b(y=>new Set(y).add(`${Q}-${Oe}`))},[]),Te=u.useCallback(Q=>{J(Oe=>new Set(Oe).add(Q)),he(Oe=>Oe.filter((pe,y)=>y!==Q)),b(Oe=>{const pe=new Set;return Oe.forEach(y=>{const le=y.indexOf("-"),Ce=parseInt(y.substring(0,le)),ge=y.substring(le+1);Ce<Q?pe.add(y):Ce>Q&&pe.add(`${Ce-1}-${ge}`)}),pe})},[]),Ke=u.useCallback(Q=>{const Oe=[...Q].sort((pe,y)=>y-pe);J(pe=>{const y=new Set(pe);return Oe.forEach(le=>y.add(le)),y}),he(pe=>pe.filter((y,le)=>!Q.includes(le))),b(pe=>{const y=new Set(Q),le=new Set;return pe.forEach(Ce=>{const ge=Ce.indexOf("-"),je=parseInt(Ce.substring(0,ge)),Be=Ce.substring(ge+1);if(!y.has(je)){let Ze=je;for(const fe of Oe)fe<je&&Ze--;le.add(`${Ze}-${Be}`)}}),le})},[]),Ye=t.results?.columns.map(Q=>{const Oe=We(Q);return{name:Q,type:Oe?.type,key:Oe?.key,comment:Oe?.comment}})||[];return s.jsxs("div",{style:{height:"100%",display:"flex",flexDirection:"column"},children:[s.jsxs("div",{style:{height:"200px",flexShrink:0,display:"flex",flexDirection:"column",borderBottom:"1px solid #e2e8f0"},children:[s.jsxs("div",{className:"h-11 bg-light-surface flex items-center px-3 gap-2",style:{flexShrink:0},children:[s.jsxs("div",{className:"relative",children:[s.jsxs("button",{onClick:()=>H(!_),className:"h-8 px-3 bg-white hover:bg-light-hover border border-border-default flex items-center gap-2 text-sm text-text-primary rounded-lg transition-colors min-w-[140px]",children:[s.jsx(Ca,{size:14,className:"text-primary-500"}),s.jsx("span",{className:"truncate max-w-[100px]",children:I?.name||"选择连接"}),s.jsx(LE,{size:14,className:"text-text-muted ml-auto"})]}),_&&s.jsxs(s.Fragment,{children:[s.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>H(!1)}),s.jsx("div",{className:"absolute top-full left-0 mt-1 bg-white border border-border-default rounded-lg shadow-lg z-50 min-w-[180px] py-1 max-h-[300px] overflow-auto",children:r.filter(Q=>T.has(Q.id)).length===0?s.jsx("div",{className:"px-3 py-2 text-sm text-text-muted",children:"暂无已连接的数据库"}):r.filter(Q=>T.has(Q.id)).map(Q=>s.jsxs("button",{onClick:()=>{O?.(Q.id),H(!1)},className:`w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-2 ${Q.id===E?"bg-primary-50 text-primary-600":"text-text-primary"}`,children:[s.jsx(Ca,{size:14,className:Q.id===E?"text-primary-500":"text-text-muted"}),s.jsx("span",{className:"truncate",children:Q.name}),Q.id===E&&s.jsx(aE,{size:14,className:"ml-auto text-primary-500"})]},Q.id))})]})]}),s.jsxs("div",{className:"relative",children:[s.jsxs("button",{onClick:()=>E&&A(!c),disabled:!E,className:"h-8 px-3 bg-white hover:bg-light-hover border border-border-default flex items-center gap-2 text-sm text-text-primary rounded-lg transition-colors min-w-[140px] disabled:opacity-50 disabled:cursor-not-allowed",children:[s.jsx(Gt,{size:14,className:"text-teal-500"}),s.jsx("span",{className:"truncate max-w-[100px]",children:n||"选择数据库"}),s.jsx(LE,{size:14,className:"text-text-muted ml-auto"})]}),c&&E&&s.jsxs(s.Fragment,{children:[s.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>A(!1)}),s.jsx("div",{className:"absolute top-full left-0 mt-1 bg-white border border-border-default rounded-lg shadow-lg z-50 min-w-[180px] py-1 max-h-[300px] overflow-auto",children:C.length===0?s.jsx("div",{className:"px-3 py-2 text-sm text-text-muted",children:"暂无数据库"}):C.map(Q=>s.jsxs("button",{onClick:()=>{L?.(Q,E),A(!1)},className:`w-full px-3 py-2 text-left text-sm hover:bg-light-hover flex items-center gap-2 ${Q===n?"bg-primary-50 text-primary-600":"text-text-primary"}`,children:[s.jsx(Gt,{size:14,className:Q===n?"text-teal-500":"text-text-muted"}),s.jsx("span",{className:"truncate",children:Q}),Q===n&&s.jsx(aE,{size:14,className:"ml-auto text-primary-500"})]},Q))})]})]}),s.jsx("div",{className:"w-px h-5 bg-border-default mx-1"}),s.jsxs("button",{onClick:me,className:"h-8 px-4 bg-success-500 hover:bg-success-600 text-white flex items-center gap-1.5 text-sm font-medium rounded-lg shadow-sm transition-all",children:[s.jsx(ku,{size:13,fill:"currentColor"}),"执行"]}),s.jsx("div",{className:"w-px h-5 bg-border-default mx-1"}),s.jsxs("button",{onClick:De,className:"h-8 px-3 bg-white hover:bg-light-hover border border-border-default flex items-center gap-1.5 text-sm text-text-primary rounded-lg transition-colors",children:[s.jsx(Oa,{size:14}),"打开"]}),s.jsxs("button",{onClick:Ne,className:"h-8 px-3 bg-white hover:bg-light-hover border border-border-default flex items-center gap-1.5 text-sm text-text-primary rounded-lg transition-colors",children:[s.jsx(GS,{size:14}),"保存"]}),s.jsxs("button",{onClick:se,className:"h-8 px-3 bg-white hover:bg-light-hover border border-border-default flex items-center gap-1.5 text-sm text-text-primary rounded-lg transition-colors",children:[s.jsx(Mu,{size:14}),"格式化"]}),s.jsx("div",{className:"w-px h-5 bg-border-default mx-1"}),s.jsxs("div",{className:"relative",children:[s.jsxs("button",{onClick:()=>Y(!Z),disabled:!t.results||t.results.rows.length===0,className:"h-8 px-3 bg-white hover:bg-light-hover border border-border-default flex items-center gap-1.5 text-sm text-text-primary rounded-lg transition-colors disabled:opacity-40",children:[s.jsx(xS,{size:14}),"导出"]}),Z&&s.jsxs(s.Fragment,{children:[s.jsx("div",{className:"fixed inset-0",onClick:()=>Y(!1)}),s.jsxs("div",{className:"absolute top-full left-0 mt-1 bg-white border border-border-default rounded-lg shadow-lg z-50 min-w-[120px] py-1 menu",children:[s.jsxs("button",{onClick:()=>{Xe(),Y(!1)},className:"w-full px-3 py-2 text-left text-sm text-text-primary hover:bg-light-hover flex items-center gap-2",children:[s.jsx(yS,{size:14,className:"text-success-500"})," CSV"]}),s.jsxs("button",{onClick:()=>{W(),Y(!1)},className:"w-full px-3 py-2 text-left text-sm text-text-primary hover:bg-light-hover flex items-center gap-2",children:[s.jsx(qs,{size:14,className:"text-warning-500"})," SQL"]})]})]})]}),s.jsxs("span",{className:"text-xs text-text-muted ml-auto",children:[P&&s.jsx("span",{className:"mr-3 text-primary-500 font-mono",children:P.split(/[/\\]/).pop()}),s.jsx("kbd",{className:"px-1.5 py-0.5 bg-light-elevated rounded text-[10px] border border-border-light",children:"Ctrl+Enter"})," 执行"]})]}),s.jsx("div",{style:{flex:1,minHeight:0},children:s.jsx(u.Suspense,{fallback:s.jsx($L,{}),children:s.jsx(KL,{value:M,onChange:p,onRun:me,onSave:Ne,onOpen:De,onFormat:se,databases:a,tables:i,columns:o})})})]}),s.jsxs("div",{style:{flex:1,display:"flex",flexDirection:"column",minHeight:0},children:[s.jsx("div",{className:"h-9 bg-light-surface flex items-center px-4 border-b border-border-default",style:{flexShrink:0},children:s.jsxs("span",{className:"text-sm text-text-secondary flex items-center gap-2",children:[s.jsx(Gt,{size:14,className:"text-primary-500"}),"结果",t.results&&s.jsxs("span",{className:"text-text-muted text-xs ml-2",children:["(",Se.length.toLocaleString()," 行)",ee.size>0&&s.jsxs("span",{className:"text-warning-500 ml-2",children:["· ",ee.size," 已修改"]}),U.size>0&&s.jsxs("span",{className:"text-danger-500 ml-2",children:["· ",U.size," 待删除"]})]})]})}),s.jsxs("div",{style:{flex:1,position:"relative",overflow:"hidden"},children:[s.jsx("div",{style:{position:"absolute",top:0,left:0,right:0,bottom:t.results?32:0},children:t.results?s.jsx(zS,{columns:Ye,data:Se,showColumnInfo:!0,editable:!0,onRefresh:()=>S(M),onCellChange:Qe,onDeleteRow:Te,onDeleteRows:Ke,modifiedCells:ee}):s.jsx("div",{className:"h-full flex items-center justify-center",children:s.jsxs("div",{className:"flex flex-col items-center gap-3",children:[s.jsx("div",{className:"w-12 h-12 rounded-xl bg-light-elevated flex items-center justify-center",children:s.jsx(Gt,{size:24,className:"text-text-disabled"})}),s.jsx("span",{className:"text-text-muted",children:"执行查询以查看结果"})]})})}),t.results&&s.jsxs("div",{className:"absolute bottom-0 left-0 right-0 h-8 bg-light-surface border-t border-border-default flex items-center px-3 gap-1",children:[s.jsxs("div",{className:"flex items-center gap-1",children:[s.jsx("button",{onClick:ye,disabled:ee.size===0&&U.size===0||ne||!E,className:`w-7 h-7 flex items-center justify-center rounded ${(ee.size>0||U.size>0)&&E?"hover:bg-success-50 text-success-500":"text-text-disabled"}`,title:E?"保存修改到数据库":"未连接数据库",children:ne?s.jsx(Fn,{size:15,className:"animate-spin"}):s.jsx(aE,{size:15})}),s.jsx("button",{onClick:()=>{he(JSON.parse(JSON.stringify(B))),b(new Set),J(new Set)},disabled:ee.size===0&&U.size===0||ne,className:`w-7 h-7 flex items-center justify-center rounded ${ee.size>0||U.size>0?"hover:bg-danger-50 text-danger-500":"text-text-disabled"}`,title:"放弃修改",children:s.jsx(tE,{size:15})}),s.jsx("button",{onClick:()=>S(M),disabled:ne,className:"w-7 h-7 flex items-center justify-center hover:bg-light-hover rounded text-text-tertiary disabled:opacity-40",title:"刷新数据 (重新执行查询)",children:s.jsx(Vr,{size:13})})]}),s.jsx("div",{className:"flex-1 text-center text-xs text-text-muted",children:ne?"保存中...":ee.size>0||U.size>0?`${ee.size>0?`${ee.size} 项修改`:""}${ee.size>0&&U.size>0?" · ":""}${U.size>0?`${U.size} 行删除`:""}`:`共 ${Se.length} 行`}),s.jsx("div",{className:"text-xs text-text-disabled font-mono truncate max-w-[300px]",title:M,children:M.length>50?M.substring(0,50)+"...":M})]})]})]})]})});function qL({isOpen:e,editingConnection:t,initialType:E,onClose:n,onSave:r}){const[T,l]=u.useState(t?.type||E||"mysql"),[a,i]=u.useState(t?.name||""),[o,S]=u.useState(t?.host||"localhost"),[N,R]=u.useState(t?.port||rE[T].defaultPort),[O,L]=u.useState(t?.username||""),[_,H]=u.useState(t?.password||""),[c,A]=u.useState(t?.database||""),[I,C]=u.useState(t?.file||""),[M,p]=u.useState(t?.ssh?.enabled||!1),[P,D]=u.useState(t?.ssh?.host||""),[Z,Y]=u.useState(t?.ssh?.port||22),[ne,xe]=u.useState(t?.ssh?.username||""),[Se,he]=u.useState(t?.ssh?.password||""),[B,j]=u.useState(t?.ssh?.privateKeyPath||""),[ee,b]=u.useState(!1),[U,J]=u.useState(null),Ee=u.useRef(null);u.useEffect(()=>{if(e){const W=setTimeout(()=>Ee.current?.focus(),100);return()=>clearTimeout(W)}},[e]),u.useEffect(()=>{if(t)l(t.type),i(t.name),S(t.host||"localhost"),R(t.port||rE[t.type].defaultPort),L(t.username||""),H(t.password||""),A(t.database||""),C(t.file||""),p(t.ssh?.enabled||!1),D(t.ssh?.host||""),Y(t.ssh?.port||22),xe(t.ssh?.username||""),he(t.ssh?.password||""),j(t.ssh?.privateKeyPath||"");else{const W=E||"mysql";l(W),i(""),S("localhost"),R(rE[W].defaultPort),L(""),H(""),A(""),C(""),p(!1),D(""),Y(22),xe(""),he(""),j("")}J(null)},[t,e,E]);const ce=W=>{l(W),R(rE[W].defaultPort),J(null)},ye=async()=>{try{const W=me(),Qe=await Le.testConnection(W);Qe.success?J({type:"success",text:"连接成功!"}):J({type:"error",text:Qe.error||"连接失败"})}catch(W){J({type:"error",text:"测试失败:"+W.message})}setTimeout(()=>J(null),3e3)},me=()=>{const W=rE[T];return{...t?.id?{id:t.id}:{},type:T,name:a||`${W.name} 连接`,host:W.needsHost?o:void 0,port:W.needsHost?N:void 0,username:W.needsAuth?O:void 0,password:W.needsAuth?_:void 0,database:c||void 0,file:W.needsFile?I:void 0,ssh:M&&W.needsHost?{enabled:!0,host:P,port:Z,username:ne,password:Se||void 0,privateKeyPath:B||void 0}:void 0}},De=()=>{if(!a.trim()){J({type:"error",text:"请输入连接名称"}),setTimeout(()=>J(null),3e3);return}r(me()),n()},Ne=async()=>{const W=await Le.selectFile([{name:"SQLite",extensions:["db","sqlite","sqlite3"]}]);W&&C(W)},se=async()=>{const W=await Le.selectFile([{name:"PEM",extensions:["pem","key","ppk"]}]);W&&j(W)};if(!e)return null;const We=rE[T],Xe=!!t;return s.jsx("div",{className:"fixed inset-0 bg-black/30 flex items-center justify-center z-50 animate-fade-in backdrop-blur-sm",children:s.jsxs("div",{className:"w-[520px] max-h-[90vh] bg-white flex flex-col overflow-hidden rounded-2xl shadow-modal animate-scale-in",onClick:W=>W.stopPropagation(),children:[s.jsxs("div",{className:"h-14 flex items-center justify-between px-5 border-b border-border-default",children:[s.jsxs("div",{className:"flex items-center gap-3",children:[s.jsx("div",{className:"w-9 h-9 rounded-xl flex items-center justify-center",style:{backgroundColor:We.color+"15"},children:s.jsx("span",{className:"text-xl",children:We.icon})}),s.jsxs("div",{children:[s.jsx("h2",{className:"text-base font-semibold text-text-primary",children:Xe?"编辑连接":"新建连接"}),s.jsx("p",{className:"text-xs text-text-muted",children:We.name})]})]}),s.jsx("button",{onClick:n,className:"p-2 hover:bg-light-hover rounded-lg transition-colors",children:s.jsx(tE,{size:18,className:"text-text-tertiary"})})]}),s.jsx("div",{className:"flex-1 overflow-y-auto scrollbar-thin",children:s.jsxs("div",{className:"p-5 space-y-5",children:[s.jsxs("div",{children:[s.jsx("label",{className:"block text-xs font-medium text-text-secondary mb-2",children:"数据库类型"}),s.jsx("div",{className:"flex flex-wrap gap-2",children:Object.entries(rE).filter(([,W])=>W.supported).map(([W,Qe])=>s.jsxs("button",{onClick:()=>ce(W),className:`flex items-center gap-2 px-3 py-2 rounded-lg border text-sm transition-all
|
||
${T===W?"border-primary-500 bg-primary-50 text-primary-700 shadow-focus":"border-border-default hover:border-border-strong text-text-primary hover:bg-light-hover"}`,children:[s.jsx("span",{className:"text-lg",children:Qe.icon}),s.jsx("span",{className:"font-medium",children:Qe.name})]},W))})]}),s.jsxs("div",{children:[s.jsxs("label",{className:"block text-xs font-medium text-text-secondary mb-2",children:[s.jsx(xi,{size:12,className:"inline mr-1"}),"连接名称"]}),s.jsx("input",{ref:Ee,type:"text",value:a,onChange:W=>i(W.target.value),placeholder:`我的${We.name}连接`,className:"w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg focus:border-primary-500 focus:shadow-focus transition-all"})]}),We.needsFile&&s.jsxs("div",{children:[s.jsxs("label",{className:"block text-xs font-medium text-text-secondary mb-2",children:[s.jsx(ua,{size:12,className:"inline mr-1"}),"数据库文件"]}),s.jsxs("div",{className:"flex gap-2",children:[s.jsx("input",{type:"text",value:I,onChange:W=>C(W.target.value),placeholder:"选择或输入 .db 文件路径",className:"flex-1 h-10 px-3 bg-light-surface border border-border-default rounded-lg focus:border-primary-500 focus:shadow-focus transition-all"}),s.jsxs("button",{onClick:Ne,className:"h-10 px-4 bg-white hover:bg-light-hover border border-border-default rounded-lg text-sm text-text-primary transition-colors flex items-center gap-1.5",children:[s.jsx(ca,{size:14}),"浏览"]})]})]}),We.needsHost&&s.jsxs("div",{className:"grid grid-cols-3 gap-3",children:[s.jsxs("div",{className:"col-span-2",children:[s.jsxs("label",{className:"block text-xs font-medium text-text-secondary mb-2",children:[s.jsx(Bu,{size:12,className:"inline mr-1"}),"主机"]}),s.jsx("input",{type:"text",value:o,onChange:W=>S(W.target.value),placeholder:"localhost",className:"w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg focus:border-primary-500 focus:shadow-focus transition-all"})]}),s.jsxs("div",{children:[s.jsxs("label",{className:"block text-xs font-medium text-text-secondary mb-2",children:[s.jsx(Ca,{size:12,className:"inline mr-1"}),"端口"]}),s.jsx("input",{type:"number",value:N,onChange:W=>R(parseInt(W.target.value)||0),className:"w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg focus:border-primary-500 focus:shadow-focus transition-all"})]})]}),We.needsAuth&&s.jsxs("div",{className:"grid grid-cols-2 gap-3",children:[s.jsxs("div",{children:[s.jsxs("label",{className:"block text-xs font-medium text-text-secondary mb-2",children:[s.jsx(xi,{size:12,className:"inline mr-1"}),"用户名"]}),s.jsx("input",{type:"text",value:O,onChange:W=>L(W.target.value),placeholder:"root",className:"w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg focus:border-primary-500 focus:shadow-focus transition-all"})]}),s.jsxs("div",{children:[s.jsxs("label",{className:"block text-xs font-medium text-text-secondary mb-2",children:[s.jsx(OT,{size:12,className:"inline mr-1"}),"密码"]}),s.jsx("input",{type:"password",value:_,onChange:W=>H(W.target.value),placeholder:"••••••••",className:"w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg focus:border-primary-500 focus:shadow-focus transition-all"})]})]}),We.needsHost&&s.jsxs("div",{children:[s.jsxs("label",{className:"block text-xs font-medium text-text-secondary mb-2",children:[s.jsx(Gt,{size:12,className:"inline mr-1"}),"默认数据库",s.jsx("span",{className:"text-text-muted font-normal ml-1",children:"(可选)"})]}),s.jsx("input",{type:"text",value:c,onChange:W=>A(W.target.value),placeholder:"连接后自动选择的数据库",className:"w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg focus:border-primary-500 focus:shadow-focus transition-all"})]}),We.needsHost&&s.jsxs("div",{className:"border border-border-default rounded-xl overflow-hidden",children:[s.jsxs("button",{onClick:()=>b(!ee),className:"w-full flex items-center justify-between px-4 py-3 hover:bg-light-hover transition-colors",children:[s.jsxs("div",{className:"flex items-center gap-2",children:[s.jsx(Ku,{size:14,className:"text-teal-500"}),s.jsx("span",{className:"text-sm font-medium text-text-primary",children:"SSH 隧道"})]}),ee?s.jsx(LE,{size:16,className:"text-text-tertiary"}):s.jsx(WE,{size:16,className:"text-text-tertiary"})]}),ee&&s.jsxs("div",{className:"px-4 pb-4 pt-2 border-t border-border-light bg-light-surface space-y-3",children:[s.jsxs("label",{className:"flex items-center gap-3 cursor-pointer",children:[s.jsx("input",{type:"checkbox",checked:M,onChange:W=>p(W.target.checked),className:"w-4 h-4 rounded border-border-strong text-primary-500 focus:ring-primary-500"}),s.jsx("span",{className:"text-sm text-text-secondary",children:"启用 SSH 隧道"})]}),M&&s.jsxs("div",{className:"space-y-3 mt-3",children:[s.jsxs("div",{className:"grid grid-cols-3 gap-2",children:[s.jsxs("div",{className:"col-span-2",children:[s.jsx("label",{className:"block text-xs text-text-muted mb-1",children:"SSH 主机"}),s.jsx("input",{type:"text",value:P,onChange:W=>D(W.target.value),className:"w-full h-9 px-3 bg-white border border-border-default rounded-lg text-sm focus:border-primary-500 focus:shadow-focus"})]}),s.jsxs("div",{children:[s.jsx("label",{className:"block text-xs text-text-muted mb-1",children:"端口"}),s.jsx("input",{type:"number",value:Z,onChange:W=>Y(parseInt(W.target.value)||22),className:"w-full h-9 px-3 bg-white border border-border-default rounded-lg text-sm focus:border-primary-500 focus:shadow-focus"})]})]}),s.jsxs("div",{className:"grid grid-cols-2 gap-2",children:[s.jsxs("div",{children:[s.jsx("label",{className:"block text-xs text-text-muted mb-1",children:"用户名"}),s.jsx("input",{type:"text",value:ne,onChange:W=>xe(W.target.value),className:"w-full h-9 px-3 bg-white border border-border-default rounded-lg text-sm focus:border-primary-500 focus:shadow-focus"})]}),s.jsxs("div",{children:[s.jsx("label",{className:"block text-xs text-text-muted mb-1",children:"密码"}),s.jsx("input",{type:"password",value:Se,onChange:W=>he(W.target.value),className:"w-full h-9 px-3 bg-white border border-border-default rounded-lg text-sm focus:border-primary-500 focus:shadow-focus"})]})]}),s.jsxs("div",{children:[s.jsxs("label",{className:"block text-xs text-text-muted mb-1",children:["私钥文件 ",s.jsx("span",{className:"text-text-disabled",children:"(可选)"})]}),s.jsxs("div",{className:"flex gap-2",children:[s.jsx("input",{type:"text",value:B,onChange:W=>j(W.target.value),placeholder:"~/.ssh/id_rsa",className:"flex-1 h-9 px-3 bg-white border border-border-default rounded-lg text-sm focus:border-primary-500 focus:shadow-focus"}),s.jsx("button",{onClick:se,className:"h-9 px-3 bg-white hover:bg-light-hover border border-border-default rounded-lg text-sm",children:"浏览"})]})]})]})]})]}),U&&s.jsxs("div",{className:`flex items-center gap-2 px-4 py-3 rounded-lg animate-slide-up
|
||
${U.type==="success"?"bg-success-50 text-success-600 border border-success-200":"bg-danger-50 text-danger-600 border border-danger-200"}`,children:[U.type==="success"?s.jsx(aE,{size:16}):s.jsx(MS,{size:16}),s.jsx("span",{className:"text-sm",children:U.text})]})]})}),s.jsxs("div",{className:"h-16 flex items-center justify-end gap-3 px-5 border-t border-border-default bg-light-surface",children:[s.jsx("button",{onClick:ye,className:"h-9 px-4 bg-white hover:bg-light-hover border border-border-default rounded-lg text-sm font-medium text-text-primary transition-colors",children:"测试连接"}),s.jsx("button",{onClick:n,className:"h-9 px-4 bg-white hover:bg-light-hover border border-border-default rounded-lg text-sm font-medium text-text-primary transition-colors",children:"取消"}),s.jsx("button",{onClick:De,className:"h-9 px-5 bg-primary-500 hover:bg-primary-600 text-white rounded-lg text-sm font-medium shadow-btn hover:shadow-btn-hover transition-all",children:Xe?"保存":"创建"})]})]})})}const Ll=[{name:"utf8mb4",collations:["utf8mb4_general_ci","utf8mb4_unicode_ci","utf8mb4_bin","utf8mb4_0900_ai_ci"]},{name:"utf8",collations:["utf8_general_ci","utf8_unicode_ci","utf8_bin"]},{name:"latin1",collations:["latin1_swedish_ci","latin1_general_ci","latin1_bin"]},{name:"gbk",collations:["gbk_chinese_ci","gbk_bin"]},{name:"gb2312",collations:["gb2312_chinese_ci","gb2312_bin"]}];function e_({isOpen:e,connectionId:t,onClose:E,onCreated:n}){const[r,T]=u.useState(""),[l,a]=u.useState("utf8mb4"),[i,o]=u.useState("utf8mb4_general_ci"),[S,N]=u.useState(!1),[R,O]=u.useState("");if(u.useEffect(()=>{e&&(T(""),a("utf8mb4"),o("utf8mb4_general_ci"),O(""))},[e]),!e)return null;const _=Ll.find(A=>A.name===l)?.collations||[],H=A=>{a(A);const I=Ll.find(C=>C.name===A);I&&I.collations.length>0&&o(I.collations[0])},c=async A=>{if(A.preventDefault(),!(!r.trim()||!t)){N(!0),O("");try{await Le.createDatabase(t,r.trim(),l,i),n(),E()}catch(I){O(I.message)}finally{N(!1)}}};return s.jsxs("div",{className:"fixed inset-0 z-50 flex items-center justify-center animate-fade-in",children:[s.jsx("div",{className:"absolute inset-0 bg-black/20 backdrop-blur-sm",onClick:E}),s.jsxs("div",{className:"relative bg-white w-[420px] rounded-2xl shadow-modal animate-scale-in overflow-hidden",children:[s.jsxs("div",{className:"flex items-center justify-between px-5 py-4 border-b border-border-default",children:[s.jsxs("div",{className:"flex items-center gap-3",children:[s.jsx("div",{className:"w-9 h-9 rounded-xl bg-teal-50 flex items-center justify-center",children:s.jsx(Gt,{size:18,className:"text-teal-500"})}),s.jsxs("div",{children:[s.jsx("h2",{className:"font-semibold text-text-primary",children:"新建数据库"}),s.jsx("p",{className:"text-xs text-text-muted",children:"创建新的数据库"})]})]}),s.jsx("button",{onClick:E,className:"p-1.5 hover:bg-light-hover rounded-lg transition-colors",children:s.jsx(tE,{size:16,className:"text-text-tertiary"})})]}),s.jsxs("form",{onSubmit:c,className:"p-5 space-y-4",children:[s.jsxs("div",{children:[s.jsxs("label",{className:"flex items-center gap-2 text-sm text-text-secondary mb-2 font-medium",children:[s.jsx(Gt,{size:14,className:"text-primary-500"}),"数据库名称 ",s.jsx("span",{className:"text-danger-500",children:"*"})]}),s.jsx("input",{type:"text",value:r,onChange:A=>T(A.target.value),placeholder:"输入数据库名称",className:`w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg\r
|
||
focus:border-primary-500 focus:shadow-focus text-sm transition-all`,autoFocus:!0})]}),s.jsxs("div",{children:[s.jsxs("label",{className:"flex items-center gap-2 text-sm text-text-secondary mb-2 font-medium",children:[s.jsx(uo,{size:14,className:"text-info-500"}),"字符集"]}),s.jsx("select",{value:l,onChange:A=>H(A.target.value),className:`w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg\r
|
||
focus:border-primary-500 text-sm transition-all cursor-pointer`,children:Ll.map(A=>s.jsx("option",{value:A.name,children:A.name},A.name))})]}),s.jsxs("div",{children:[s.jsx("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:"排序规则"}),s.jsx("select",{value:i,onChange:A=>o(A.target.value),className:`w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg\r
|
||
focus:border-primary-500 text-sm transition-all cursor-pointer`,children:_.map(A=>s.jsx("option",{value:A,children:A},A))})]}),R&&s.jsx("div",{className:"px-3 py-2 bg-danger-50 text-danger-600 text-sm rounded-lg border border-danger-200",children:R}),s.jsxs("div",{className:"flex justify-end gap-2 pt-2",children:[s.jsx("button",{type:"button",onClick:E,className:`px-4 py-2 text-sm bg-light-elevated hover:bg-light-muted border border-border-default\r
|
||
rounded-lg transition-colors text-text-secondary`,children:"取消"}),s.jsx("button",{type:"submit",disabled:!r.trim()||S,className:`px-4 py-2 text-sm bg-primary-500 hover:bg-primary-600 text-white\r
|
||
disabled:opacity-50 disabled:cursor-not-allowed \r
|
||
rounded-lg transition-all font-medium shadow-btn hover:shadow-btn-hover`,children:S?"创建中...":"创建数据库"})]})]})]})]})}const t_=[{group:"整数",types:["INT","TINYINT","SMALLINT","MEDIUMINT","BIGINT"]},{group:"小数",types:["DECIMAL","FLOAT","DOUBLE"]},{group:"字符串",types:["VARCHAR","CHAR","TEXT","MEDIUMTEXT","LONGTEXT"]},{group:"日期时间",types:["DATETIME","DATE","TIME","TIMESTAMP","YEAR"]},{group:"二进制",types:["BLOB","MEDIUMBLOB","LONGBLOB","BINARY","VARBINARY"]},{group:"其他",types:["JSON","ENUM","SET","BOOLEAN"]}],_l={name:"",type:"INT",length:"",nullable:!0,primaryKey:!1,autoIncrement:!1,defaultValue:"",comment:""};function E_({isOpen:e,connectionId:t,database:E,onClose:n,onCreated:r}){const[T,l]=u.useState(""),[a,i]=u.useState([{..._l,id:crypto.randomUUID(),name:"id",primaryKey:!0,autoIncrement:!0,nullable:!1}]),[o,S]=u.useState(!1),[N,R]=u.useState("");if(u.useEffect(()=>{e&&(l(""),i([{..._l,id:crypto.randomUUID(),name:"id",primaryKey:!0,autoIncrement:!0,nullable:!1}]),R(""))},[e]),!e)return null;const O=()=>{i([...a,{..._l,id:crypto.randomUUID()}])},L=I=>{a.length>1&&i(a.filter(C=>C.id!==I))},_=(I,C,M)=>{i(a.map(p=>{if(p.id!==I)return p;const P={...p,[C]:M};return C==="primaryKey"&&M&&(P.nullable=!1),C==="autoIncrement"&&M&&(P.primaryKey=!0,P.nullable=!1),P}))},H=(I,C)=>{const M=C==="up"?I-1:I+1;if(M<0||M>=a.length)return;const p=[...a],P=p[I];p[I]=p[M],p[M]=P,i(p)},c=async I=>{if(I.preventDefault(),!(!T.trim()||!a.some(C=>C.name.trim())||!t||!E)){S(!0),R("");try{await Le.createTable(t,E,T.trim(),a.filter(C=>C.name.trim())),r(),n()}catch(C){R(C.message)}finally{S(!1)}}},A=I=>["VARCHAR","CHAR","DECIMAL","FLOAT","DOUBLE","BINARY","VARBINARY"].includes(I);return s.jsxs("div",{className:"fixed inset-0 z-50 flex items-center justify-center animate-fade-in",children:[s.jsx("div",{className:"absolute inset-0 bg-black/20 backdrop-blur-sm",onClick:n}),s.jsxs("div",{className:"relative bg-white w-[850px] max-h-[85vh] flex flex-col rounded-2xl shadow-modal animate-scale-in overflow-hidden",children:[s.jsxs("div",{className:"flex items-center justify-between px-5 py-4 border-b border-border-default flex-shrink-0",children:[s.jsxs("div",{className:"flex items-center gap-3",children:[s.jsx("div",{className:"w-9 h-9 rounded-xl bg-warning-50 flex items-center justify-center",children:s.jsx(zn,{size:18,className:"text-warning-500"})}),s.jsxs("div",{children:[s.jsx("h2",{className:"font-semibold text-text-primary",children:"新建表"}),s.jsxs("p",{className:"text-xs text-text-muted",children:["数据库: ",s.jsx("span",{className:"text-teal-600 font-mono",children:E})]})]})]}),s.jsx("button",{onClick:n,className:"p-1.5 hover:bg-light-hover rounded-lg transition-colors",children:s.jsx(tE,{size:16,className:"text-text-tertiary"})})]}),s.jsxs("form",{onSubmit:c,className:"flex-1 flex flex-col min-h-0",children:[s.jsxs("div",{className:"p-5 border-b border-border-default flex-shrink-0",children:[s.jsxs("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:["表名称 ",s.jsx("span",{className:"text-danger-500",children:"*"})]}),s.jsx("input",{type:"text",value:T,onChange:I=>l(I.target.value),placeholder:"输入表名称",className:`w-64 h-10 px-3 bg-light-surface border border-border-default rounded-lg\r
|
||
focus:border-primary-500 focus:shadow-focus text-sm transition-all`,autoFocus:!0})]}),s.jsxs("div",{className:"flex-1 overflow-auto p-5 scrollbar-thin",children:[s.jsxs("div",{className:"flex items-center justify-between mb-4",children:[s.jsx("span",{className:"text-sm text-text-secondary font-medium",children:"字段定义"}),s.jsxs("button",{type:"button",onClick:O,className:`flex items-center gap-1.5 px-3 py-1.5 text-xs bg-primary-500 hover:bg-primary-600 text-white\r
|
||
rounded-lg transition-colors font-medium`,children:[s.jsx(In,{size:14}),"添加字段"]})]}),s.jsxs("div",{className:"flex items-center gap-2 px-3 py-2 bg-light-surface text-xs text-text-muted border-b border-border-default rounded-t-lg font-medium",children:[s.jsx("div",{className:"w-8"}),s.jsx("div",{className:"w-28",children:"字段名"}),s.jsx("div",{className:"w-24",children:"类型"}),s.jsx("div",{className:"w-14",children:"长度"}),s.jsx("div",{className:"w-10 text-center",children:"主键"}),s.jsx("div",{className:"w-10 text-center",children:"自增"}),s.jsx("div",{className:"w-10 text-center",children:"可空"}),s.jsx("div",{className:"w-20",children:"默认值"}),s.jsx("div",{className:"flex-1",children:"备注"}),s.jsx("div",{className:"w-10"})]}),s.jsx("div",{className:"border border-t-0 border-border-default rounded-b-lg overflow-hidden",children:a.map((I,C)=>s.jsxs("div",{className:"flex items-center gap-2 px-3 py-2 hover:bg-light-hover group transition-colors border-b border-border-light last:border-b-0",children:[s.jsxs("div",{className:"w-8 flex flex-col gap-0.5",children:[s.jsx("button",{type:"button",onClick:()=>H(C,"up"),disabled:C===0,className:"p-0.5 hover:bg-light-elevated disabled:opacity-30 rounded transition-colors",children:s.jsx(xu,{size:10,className:"text-text-muted"})}),s.jsx("button",{type:"button",onClick:()=>H(C,"down"),disabled:C===a.length-1,className:"p-0.5 hover:bg-light-elevated disabled:opacity-30 rounded transition-colors",children:s.jsx(Uu,{size:10,className:"text-text-muted"})})]}),s.jsx("input",{type:"text",value:I.name,onChange:M=>_(I.id,"name",M.target.value),placeholder:"字段名",className:`w-28 h-8 px-2 bg-white border border-border-default rounded text-xs\r
|
||
focus:border-primary-500 focus:outline-none transition-colors font-mono`}),s.jsx("select",{value:I.type,onChange:M=>_(I.id,"type",M.target.value),className:`w-24 h-8 px-2 bg-white border border-border-default rounded text-xs\r
|
||
focus:border-primary-500 focus:outline-none transition-colors cursor-pointer`,children:t_.map(M=>s.jsx("optgroup",{label:M.group,children:M.types.map(p=>s.jsx("option",{value:p,children:p},p))},M.group))}),s.jsx("input",{type:"text",value:I.length,onChange:M=>_(I.id,"length",M.target.value),placeholder:A(I.type)?"长度":"-",disabled:!A(I.type),className:`w-14 h-8 px-2 bg-white border border-border-default rounded text-xs text-center\r
|
||
focus:border-primary-500 focus:outline-none transition-colors\r
|
||
disabled:opacity-40 disabled:bg-light-surface disabled:cursor-not-allowed font-mono`}),s.jsx("div",{className:"w-10 flex justify-center",children:s.jsx("button",{type:"button",onClick:()=>_(I.id,"primaryKey",!I.primaryKey),className:`p-1.5 rounded transition-all ${I.primaryKey?"bg-warning-500 text-white":"hover:bg-light-elevated text-text-muted"}`,children:s.jsx(OT,{size:12})})}),s.jsx("div",{className:"w-10 flex justify-center",children:s.jsxs("label",{className:"cursor-pointer",children:[s.jsx("div",{className:`w-4 h-4 rounded border-2 flex items-center justify-center transition-all
|
||
${I.autoIncrement?"bg-primary-500 border-primary-500":"border-border-strong hover:border-primary-300"}`,children:I.autoIncrement&&s.jsx(aE,{size:10,className:"text-white"})}),s.jsx("input",{type:"checkbox",checked:I.autoIncrement,onChange:M=>_(I.id,"autoIncrement",M.target.checked),className:"sr-only"})]})}),s.jsx("div",{className:"w-10 flex justify-center",children:s.jsxs("label",{className:`cursor-pointer ${I.primaryKey?"opacity-40 cursor-not-allowed":""}`,children:[s.jsx("div",{className:`w-4 h-4 rounded border-2 flex items-center justify-center transition-all
|
||
${I.nullable?"bg-success-500 border-success-500":"border-border-strong hover:border-success-300"}`,children:I.nullable&&s.jsx(aE,{size:10,className:"text-white"})}),s.jsx("input",{type:"checkbox",checked:I.nullable,onChange:M=>_(I.id,"nullable",M.target.checked),disabled:I.primaryKey,className:"sr-only"})]})}),s.jsx("input",{type:"text",value:I.defaultValue,onChange:M=>_(I.id,"defaultValue",M.target.value),placeholder:"默认值",className:`w-20 h-8 px-2 bg-white border border-border-default rounded text-xs\r
|
||
focus:border-primary-500 focus:outline-none transition-colors`}),s.jsx("input",{type:"text",value:I.comment,onChange:M=>_(I.id,"comment",M.target.value),placeholder:"备注",className:`flex-1 h-8 px-2 bg-white border border-border-default rounded text-xs\r
|
||
focus:border-primary-500 focus:outline-none transition-colors`}),s.jsx("div",{className:"w-10 flex justify-center",children:s.jsx("button",{type:"button",onClick:()=>L(I.id),disabled:a.length===1,className:`p-1.5 text-text-muted hover:text-danger-500 hover:bg-danger-50 \r
|
||
rounded transition-all disabled:opacity-30 disabled:cursor-not-allowed`,children:s.jsx(IE,{size:14})})})]},I.id))})]}),N&&s.jsx("div",{className:"mx-5 mb-3 px-3 py-2 bg-danger-50 text-danger-600 text-sm rounded-lg border border-danger-200",children:N}),s.jsxs("div",{className:"flex justify-end gap-2 p-5 border-t border-border-default flex-shrink-0",children:[s.jsx("button",{type:"button",onClick:n,className:`px-4 py-2 text-sm bg-light-elevated hover:bg-light-muted border border-border-default\r
|
||
rounded-lg transition-colors text-text-secondary`,children:"取消"}),s.jsx("button",{type:"submit",disabled:!T.trim()||!a.some(I=>I.name.trim())||o,className:`px-4 py-2 text-sm bg-primary-500 hover:bg-primary-600 text-white\r
|
||
disabled:opacity-50 disabled:cursor-not-allowed \r
|
||
rounded-lg transition-all font-medium shadow-btn hover:shadow-btn-hover`,children:o?"创建中...":"创建表"})]})]})]})]})}const ir={mysql:[{group:"整数",types:["TINYINT","SMALLINT","MEDIUMINT","INT","BIGINT"]},{group:"小数",types:["DECIMAL","FLOAT","DOUBLE"]},{group:"字符串",types:["CHAR","VARCHAR","TINYTEXT","TEXT","MEDIUMTEXT","LONGTEXT"]},{group:"日期时间",types:["DATE","TIME","DATETIME","TIMESTAMP","YEAR"]},{group:"二进制",types:["BINARY","VARBINARY","TINYBLOB","BLOB","MEDIUMBLOB","LONGBLOB"]},{group:"其他",types:["JSON","ENUM","SET","BOOLEAN","BIT"]}],postgres:[{group:"整数",types:["SMALLINT","INTEGER","BIGINT","SERIAL","BIGSERIAL"]},{group:"小数",types:["DECIMAL","NUMERIC","REAL","DOUBLE PRECISION"]},{group:"字符串",types:["CHAR","VARCHAR","TEXT"]},{group:"日期时间",types:["DATE","TIME","TIMESTAMP","TIMESTAMPTZ","INTERVAL"]},{group:"布尔",types:["BOOLEAN"]},{group:"其他",types:["JSON","JSONB","UUID","BYTEA","ARRAY"]}],sqlserver:[{group:"整数",types:["TINYINT","SMALLINT","INT","BIGINT"]},{group:"小数",types:["DECIMAL","NUMERIC","FLOAT","REAL","MONEY"]},{group:"字符串",types:["CHAR","VARCHAR","NCHAR","NVARCHAR","TEXT","NTEXT"]},{group:"日期时间",types:["DATE","TIME","DATETIME","DATETIME2","DATETIMEOFFSET"]},{group:"二进制",types:["BINARY","VARBINARY","IMAGE"]},{group:"其他",types:["BIT","UNIQUEIDENTIFIER","XML"]}],sqlite:[{group:"基本",types:["INTEGER","REAL","TEXT","BLOB","NUMERIC"]}]},n_=["InnoDB","MyISAM","Memory","CSV","Archive","Blackhole","Federated","NDB"],r_=["utf8mb4","utf8mb3","utf8","latin1","gbk","gb2312","big5","ascii","binary"],AR={utf8mb4:["utf8mb4_general_ci","utf8mb4_unicode_ci","utf8mb4_bin","utf8mb4_0900_ai_ci"],utf8:["utf8_general_ci","utf8_unicode_ci","utf8_bin"],latin1:["latin1_swedish_ci","latin1_general_ci","latin1_bin"],gbk:["gbk_chinese_ci","gbk_bin"]},s_=["DEFAULT","DYNAMIC","FIXED","COMPRESSED","REDUNDANT","COMPACT"];function Vt({value:e,options:t,onChange:E,placeholder:n="选择...",className:r="",disabled:T=!1}){const[l,a]=u.useState(!1),[i,o]=u.useState(""),S=u.useRef(null),N=t.filter(O=>O.label.toLowerCase().includes(i.toLowerCase())||O.value.toLowerCase().includes(i.toLowerCase())),R=t.find(O=>O.value===e);return u.useEffect(()=>{const O=L=>{S.current&&!S.current.contains(L.target)&&(a(!1),o(""))};return document.addEventListener("mousedown",O),()=>document.removeEventListener("mousedown",O)},[]),s.jsxs("div",{ref:S,className:`relative flex items-center justify-between cursor-pointer rounded-lg transition-all duration-200 ${r} ${T?"opacity-50 cursor-not-allowed":"hover:bg-light-hover"}`,onClick:O=>{O.stopPropagation(),T||a(!l)},children:[s.jsx("span",{className:`text-sm font-medium ${R?"text-text-primary":"text-text-muted"}`,children:R?.label||n}),s.jsx(LE,{size:14,className:`text-text-tertiary ml-2 transition-transform duration-200 ${l?"rotate-180":""}`}),l&&s.jsxs("div",{className:`absolute z-50 top-full left-0 w-full min-w-[160px] mt-1.5 bg-white border border-border-default \r
|
||
shadow-xl rounded-xl overflow-hidden flex flex-col animate-in fade-in slide-in-from-top-2 duration-200`,style:{maxHeight:"280px"},children:[s.jsx("div",{className:"p-2.5 border-b border-border-light bg-gradient-to-b from-light-surface to-white",children:s.jsxs("div",{className:"relative",children:[s.jsx(cT,{size:14,className:"absolute left-3 top-1/2 -translate-y-1/2 text-text-tertiary"}),s.jsx("input",{type:"text",value:i,onChange:O=>o(O.target.value),onClick:O=>O.stopPropagation(),placeholder:"搜索...",className:`w-full h-9 pl-9 pr-3 bg-white border border-border-default rounded-lg text-sm text-text-primary \r
|
||
focus:outline-none focus:border-primary-400 focus:ring-2 focus:ring-primary-100 transition-all`,autoFocus:!0})]})}),s.jsx("div",{className:"overflow-auto flex-1 py-1.5",style:{maxHeight:"220px"},children:N.length===0?s.jsxs("div",{className:"px-4 py-6 text-sm text-text-muted text-center",children:[s.jsx("div",{className:"text-2xl mb-2",children:"🔍"}),"无匹配项"]}):N.map(O=>s.jsxs("div",{onClick:L=>{L.stopPropagation(),E(O.value),a(!1),o("")},className:`px-3 py-2 text-sm cursor-pointer flex items-center gap-2.5 mx-1.5 rounded-lg transition-all duration-150
|
||
${O.value===e?"bg-primary-50 text-primary-700 font-medium":"text-text-primary hover:bg-light-hover"}`,children:[O.value===e&&s.jsx(aE,{size:14,className:"text-primary-500",strokeWidth:2.5}),s.jsx("span",{className:O.value===e?"":"ml-5",children:O.label})]},O.value))})]})]})}function T_({values:e,options:t,onChange:E,placeholder:n="选择...",className:r=""}){const[T,l]=u.useState(!1),[a,i]=u.useState(""),[o,S]=u.useState(e),N=u.useRef(null),R=t.filter(A=>A.label.toLowerCase().includes(a.toLowerCase()));u.useEffect(()=>{T&&S(e)},[T,e]),u.useEffect(()=>{const A=I=>{N.current&&!N.current.contains(I.target)&&(l(!1),i(""))};return document.addEventListener("mousedown",A),()=>document.removeEventListener("mousedown",A)},[]);const O=A=>{o.includes(A)?S(o.filter(I=>I!==A)):S([...o,A])},L=()=>{E(o),l(!1),i("")},_=()=>{S(e),l(!1),i("")},H=()=>{S(R.map(A=>A.value))},c=()=>{S([])};return s.jsxs("div",{ref:N,className:`relative ${r}`,children:[s.jsxs("div",{onClick:A=>{A.stopPropagation(),l(!T)},className:`w-full min-h-[36px] px-3 py-1.5 bg-white/50 border border-border-light hover:border-primary-300 rounded-lg\r
|
||
text-sm flex items-center gap-1.5 flex-wrap cursor-pointer transition-all duration-200\r
|
||
hover:shadow-sm hover:bg-white`,children:[e.length===0?s.jsx("span",{className:"text-text-muted",children:n}):e.map(A=>s.jsx("span",{className:`bg-gradient-to-r from-primary-100 to-primary-50 text-primary-700 px-2.5 py-1 rounded-md text-xs font-medium\r
|
||
border border-primary-200/50 shadow-sm`,children:A},A)),s.jsx(LE,{size:14,className:`ml-auto text-text-tertiary transition-transform duration-200 ${T?"rotate-180":""}`})]}),T&&s.jsxs("div",{className:`absolute z-50 top-full left-0 w-full min-w-[200px] mt-1.5 bg-white border border-border-default \r
|
||
shadow-xl rounded-xl overflow-hidden flex flex-col animate-in fade-in slide-in-from-top-2 duration-200`,style:{maxHeight:"320px"},children:[s.jsx("div",{className:"p-2.5 border-b border-border-light bg-gradient-to-b from-light-surface to-white",children:s.jsxs("div",{className:"relative",children:[s.jsx(cT,{size:14,className:"absolute left-3 top-1/2 -translate-y-1/2 text-text-tertiary"}),s.jsx("input",{type:"text",value:a,onChange:A=>i(A.target.value),onClick:A=>A.stopPropagation(),placeholder:"搜索字段...",className:`w-full h-9 pl-9 pr-3 bg-white border border-border-default rounded-lg text-sm text-text-primary \r
|
||
focus:outline-none focus:border-primary-400 focus:ring-2 focus:ring-primary-100 transition-all`,autoFocus:!0})]})}),s.jsxs("div",{className:"px-2.5 py-2 border-b border-border-light flex items-center gap-2 bg-light-surface/50",children:[s.jsx("button",{onClick:A=>{A.stopPropagation(),H()},className:"text-xs text-primary-600 hover:text-primary-700 font-medium px-2 py-1 rounded hover:bg-primary-50 transition-colors",children:"全选"}),s.jsx("span",{className:"text-border-default",children:"|"}),s.jsx("button",{onClick:A=>{A.stopPropagation(),c()},className:"text-xs text-text-tertiary hover:text-text-secondary font-medium px-2 py-1 rounded hover:bg-light-hover transition-colors",children:"清空"}),s.jsxs("span",{className:"ml-auto text-xs text-text-muted",children:["已选 ",s.jsx("span",{className:"text-primary-600 font-medium",children:o.length})," 项"]})]}),s.jsx("div",{className:"overflow-auto flex-1 py-1.5",style:{maxHeight:"180px"},children:R.length===0?s.jsxs("div",{className:"px-4 py-6 text-sm text-text-muted text-center",children:[s.jsx("div",{className:"text-2xl mb-2",children:"🔍"}),"无匹配字段"]}):R.map(A=>s.jsxs("div",{onClick:I=>{I.stopPropagation(),O(A.value)},className:`px-3 py-2 text-sm cursor-pointer flex items-center gap-3 mx-1.5 rounded-lg transition-all duration-150
|
||
${o.includes(A.value)?"bg-primary-50 text-primary-700 hover:bg-primary-100":"text-text-primary hover:bg-light-hover"}`,children:[s.jsx("div",{className:`w-5 h-5 rounded-md border-2 flex items-center justify-center transition-all duration-150
|
||
${o.includes(A.value)?"bg-primary-500 border-primary-500":"border-border-default bg-white"}`,children:o.includes(A.value)&&s.jsx(aE,{size:12,className:"text-white",strokeWidth:3})}),s.jsx("span",{className:"font-medium",children:A.label})]},A.value))}),s.jsxs("div",{className:"px-3 py-2.5 border-t border-border-light bg-gradient-to-t from-light-surface to-white flex items-center justify-end gap-2",children:[s.jsx("button",{onClick:A=>{A.stopPropagation(),_()},className:`px-4 py-1.5 text-sm text-text-secondary hover:text-text-primary font-medium rounded-lg \r
|
||
hover:bg-light-hover transition-all duration-150`,children:"取消"}),s.jsx("button",{onClick:A=>{A.stopPropagation(),L()},className:`px-4 py-1.5 text-sm text-white font-medium rounded-lg bg-gradient-to-r from-primary-500 to-primary-600\r
|
||
hover:from-primary-600 hover:to-primary-700 shadow-sm hover:shadow-md transition-all duration-150`,children:"确认"})]})]})]})}const SR={name:"",type:"INT",length:"",decimals:"",nullable:!0,primaryKey:!1,autoIncrement:!1,unsigned:!1,zerofill:!1,defaultValue:"",comment:"",isVirtual:!1,virtualExpression:""},l_={name:"",columns:[],type:"NORMAL",method:"BTREE",comment:""},a_={name:"",columns:[],refSchema:"",refTable:"",refColumns:[],onDelete:"NO ACTION",onUpdate:"NO ACTION"},NR={engine:"InnoDB",charset:"utf8mb4",collation:"utf8mb4_general_ci",comment:"",autoIncrement:"",rowFormat:"DEFAULT"};function o_({isOpen:e,mode:t,database:E,tableName:n,connectionId:r,dbType:T,onClose:l,onSave:a,onGetTableInfo:i,onGetDatabases:o,onGetTables:S,onGetColumns:N}){const[R,O]=u.useState("columns"),[L,_]=u.useState(n||""),[H,c]=u.useState([]),[A,I]=u.useState([]),[C,M]=u.useState([]),[p,P]=u.useState(NR),[D,Z]=u.useState(null),[Y,ne]=u.useState(!1),[xe,Se]=u.useState(!1),[he,B]=u.useState(""),[j,ee]=u.useState(null),[b,U]=u.useState(null),[J,Ee]=u.useState(null);u.useEffect(()=>{e&&t==="edit"&&i?(_(n||""),B(""),ce()):e&&t==="create"&&(c([{...SR,id:crypto.randomUUID(),name:"id",primaryKey:!0,autoIncrement:!0,nullable:!1,_isNew:!0}]),I([]),M([]),P(NR),Z(null),_(""),B(""),ne(!1))},[e,t,n]);const ce=async()=>{if(!i){ne(!1);return}ne(!0);try{const m=await i();m&&m.columns?c(m.columns.map(F=>({...F,_original:{...F}}))):c([]),m&&m.indexes?I(m.indexes.map(F=>({...F,_original:{...F}}))):I([]),m&&m.foreignKeys?M(m.foreignKeys.map(F=>({...F,_original:{...F}}))):M([]),m&&m.options?(P(m.options),Z(m.options)):Z(null)}catch(m){console.error("Load table info error:",m),B(m.message||"加载表信息失败")}finally{ne(!1)}},ye=u.useMemo(()=>{const m=T.toLowerCase();return m==="mysql"||m==="mariadb"?ir.mysql:m==="postgres"||m==="postgresql"?ir.postgres:m==="sqlserver"?ir.sqlserver:m==="sqlite"?ir.sqlite:ir.mysql},[T]),me=m=>{const F=m.toUpperCase();return["VARCHAR","CHAR","DECIMAL","NUMERIC","FLOAT","DOUBLE","BINARY","VARBINARY","BIT"].includes(F)},De=m=>{const F=m.toUpperCase();return["DECIMAL","NUMERIC","FLOAT","DOUBLE"].includes(F)},Ne=m=>{const F=m.toUpperCase();return["TINYINT","SMALLINT","MEDIUMINT","INT","INTEGER","BIGINT","FLOAT","DOUBLE","DECIMAL"].includes(F)},se=()=>{const m={...SR,id:crypto.randomUUID(),_isNew:!0};c([...H,m]),ee(m.id)},We=m=>{const F=H.find(q=>q.id===m);F&&(F._isNew?c(H.filter(q=>q.id!==m)):c(H.map(q=>q.id===m?{...q,_isDeleted:!0}:q)))},Xe=(m,F,q)=>{c(H.map(_e=>{if(_e.id!==m)return _e;const k={..._e,[F]:q};return F==="primaryKey"&&q&&(k.nullable=!1),F==="autoIncrement"&&q&&(k.primaryKey=!0,k.nullable=!1),k}))},W=(m,F)=>{const q=H.filter(Re=>!Re._isDeleted),_e=F==="up"?m-1:m+1;if(_e<0||_e>=q.length)return;const k=[...q],ie=k[m];k[m]=k[_e],k[_e]=ie,c([...k,...H.filter(Re=>Re._isDeleted)])},Qe=()=>{const m={...l_,id:crypto.randomUUID(),_isNew:!0};I([...A,m]),U(m.id)},Te=m=>{const F=A.find(q=>q.id===m);F&&(F._isNew?I(A.filter(q=>q.id!==m)):I(A.map(q=>q.id===m?{...q,_isDeleted:!0}:q)))},Ke=(m,F)=>m.length===0||!m.some(k=>k)?"":`${F==="UNIQUE"?"uk":F==="FULLTEXT"?"ft":"idx"}_${L||"table"}_${m.filter(k=>k).join("_")}`,Ye=(m,F,q)=>{I(A.map(_e=>{if(_e.id!==m)return _e;const k={..._e,[F]:q};if(F==="columns"&&Array.isArray(q)&&q.length>0&&q.some(ie=>ie)){const ie=Ke(q,_e.type);(!_e.name||_e.name.startsWith("idx_")||_e.name.startsWith("uk_")||_e.name.startsWith("ft_"))&&(k.name=ie)}if(F==="type"&&_e.columns.length>0&&_e.columns.some(ie=>ie)){const ie=Ke(_e.columns,q);(!_e.name||_e.name.startsWith("idx_")||_e.name.startsWith("uk_")||_e.name.startsWith("ft_"))&&(k.name=ie)}return k}))},Q=m=>m.length===0||!m[0]?"":`fk_${L||"table"}_${m.filter(q=>q).join("_")}`,Oe=()=>{const m={...a_,id:crypto.randomUUID(),_isNew:!0};M([...C,m]),Ee(m.id)},pe=m=>{const F=C.find(q=>q.id===m);F&&(F._isNew?M(C.filter(q=>q.id!==m)):M(C.map(q=>q.id===m?{...q,_isDeleted:!0}:q)))},y=(m,F,q)=>{M(_e=>_e.map(k=>{if(k.id!==m)return k;if(typeof F=="object")return{...k,...F};const ie={...k,[F]:q};if(F==="columns"&&Array.isArray(q)&&q.length>0&&q[0]){const Re=Q(q);(!k.name||k.name.startsWith("fk_"))&&(ie.name=Re)}return ie}))},le=m=>{if(!m._original)return!1;const F=m._original;return m.name!==F.name||m.type!==F.type||m.length!==F.length||m.decimals!==F.decimals||m.nullable!==F.nullable||m.defaultValue!==F.defaultValue||m.comment!==F.comment||m.unsigned!==F.unsigned||m.autoIncrement!==F.autoIncrement},Ce=u.useMemo(()=>{const m=T.toLowerCase(),F=k=>m==="mysql"||m==="mariadb"?`\`${k}\``:m==="postgres"||m==="postgresql"?`"${k}"`:m==="sqlserver"?`[${k}]`:`"${k}"`,q=k=>{let ie=k.type.toUpperCase();return k.length&&(k.decimals&&De(k.type)?ie+=`(${k.length},${k.decimals})`:ie+=`(${k.length})`),ie},_e=(k,ie=!1)=>{let Re=`${F(k.name)} ${q(k)}`;if(Ne(k.type)&&k.unsigned&&(m==="mysql"||m==="mariadb")&&(Re+=" UNSIGNED"),k.zerofill&&(m==="mysql"||m==="mariadb")&&(Re+=" ZEROFILL"),k.nullable||(Re+=" NOT NULL"),k.autoIncrement&&(m==="mysql"||m==="mariadb"?Re+=" AUTO_INCREMENT":m==="sqlserver"&&(Re+=" IDENTITY(1,1)")),k.defaultValue!==void 0&&k.defaultValue!==""){const Et=k.defaultValue;Et.toUpperCase()==="NULL"?Re+=" DEFAULT NULL":Et.toUpperCase()==="CURRENT_TIMESTAMP"||Et.toUpperCase().startsWith("NOW")?Re+=` DEFAULT ${Et}`:Re+=` DEFAULT '${Et}'`}return k.comment&&(m==="mysql"||m==="mariadb")&&(Re+=` COMMENT '${k.comment.replace(/'/g,"''")}'`),Re};if(t==="create"){const k=H.filter(oe=>!oe._isDeleted&&oe.name);if(!L||k.length===0)return"-- 请填写表名和至少一个字段";const ie=k.map(oe=>" "+_e(oe,!0)),Re=k.filter(oe=>oe.primaryKey);Re.length>0&&ie.push(` PRIMARY KEY (${Re.map(oe=>F(oe.name)).join(", ")})`);const Et=A.filter(oe=>!oe._isDeleted&&oe.name&&oe.columns.length>0&&oe.columns.some(qe=>qe));for(const oe of Et){let qe=" ";oe.type==="UNIQUE"?qe+="UNIQUE ":oe.type==="FULLTEXT"?qe+="FULLTEXT ":oe.type==="SPATIAL"&&(qe+="SPATIAL "),qe+=`INDEX ${F(oe.name)} (${oe.columns.map(Yt=>F(Yt)).join(", ")})`,oe.method&&oe.method!=="BTREE"&&(m==="mysql"||m==="mariadb")&&(qe+=` USING ${oe.method}`),ie.push(qe)}const KE=C.filter(oe=>!oe._isDeleted&&oe.name&&oe.columns.length>0&&oe.columns[0]&&oe.refTable&&oe.refColumns.length>0&&oe.refColumns[0]);for(const oe of KE){let qe=` CONSTRAINT ${F(oe.name)} FOREIGN KEY (${oe.columns.map(Yt=>F(Yt)).join(", ")}) `;qe+=`REFERENCES ${oe.refSchema?F(oe.refSchema)+".":""}${F(oe.refTable)} (${oe.refColumns.map(Yt=>F(Yt)).join(", ")})`,oe.onDelete!=="NO ACTION"&&(qe+=` ON DELETE ${oe.onDelete}`),oe.onUpdate!=="NO ACTION"&&(qe+=` ON UPDATE ${oe.onUpdate}`),ie.push(qe)}let fE=`CREATE TABLE ${F(E)}.${F(L)} (
|
||
${ie.join(`,
|
||
`)}
|
||
)`;if(m==="mysql"||m==="mariadb"){const oe=[];p.engine&&oe.push(`ENGINE=${p.engine}`),p.charset&&oe.push(`DEFAULT CHARSET=${p.charset}`),p.collation&&oe.push(`COLLATE=${p.collation}`),p.rowFormat&&p.rowFormat!=="DEFAULT"&&oe.push(`ROW_FORMAT=${p.rowFormat}`),p.comment&&oe.push(`COMMENT='${p.comment.replace(/'/g,"''")}'`),p.autoIncrement&&oe.push(`AUTO_INCREMENT=${p.autoIncrement}`),oe.length>0&&(fE+=`
|
||
`+oe.join(`
|
||
`))}return fE+";"}else{const k=[],ie=`${F(E)}.${F(L)}`,Re=H.filter($=>$._isDeleted&&$._original);for(const $ of Re)k.push(`ALTER TABLE ${ie} DROP COLUMN ${F($.name)};`);const Et=H.filter($=>$._isNew&&!$._isDeleted&&$.name);for(const $ of Et)k.push(`ALTER TABLE ${ie} ADD COLUMN ${_e($)};`);const KE=H.filter($=>!$._isNew&&!$._isDeleted&&$._original&&le($));for(const $ of KE)m==="mysql"||m==="mariadb"?k.push(`ALTER TABLE ${ie}
|
||
CHANGE COLUMN ${F($._original.name)} ${_e($)};`):m==="postgres"||m==="postgresql"?($._original.name!==$.name&&k.push(`ALTER TABLE ${ie} RENAME COLUMN ${F($._original.name)} TO ${F($.name)};`),k.push(`ALTER TABLE ${ie} ALTER COLUMN ${F($.name)} TYPE ${q($)};`),$.nullable!==$._original.nullable&&k.push(`ALTER TABLE ${ie} ALTER COLUMN ${F($.name)} ${$.nullable?"DROP":"SET"} NOT NULL;`)):m==="sqlserver"&&($._original.name!==$.name&&k.push(`EXEC sp_rename '${L}.${$._original.name}', '${$.name}', 'COLUMN';`),k.push(`ALTER TABLE ${ie} ALTER COLUMN ${F($.name)} ${q($)}${$.nullable?"":" NOT NULL"};`));const fE=A.filter($=>$._isDeleted&&$._original);for(const $ of fE)m==="mysql"||m==="mariadb"?k.push(`ALTER TABLE ${ie} DROP INDEX ${F($.name)};`):m==="postgres"||m==="postgresql"?k.push(`DROP INDEX ${F($.name)};`):m==="sqlserver"&&k.push(`DROP INDEX ${F($.name)} ON ${ie};`);const oe=A.filter($=>$._isNew&&!$._isDeleted&&$.name&&$.columns.length>0&&$.columns.some(we=>we));for(const $ of oe){let we="";m==="mysql"||m==="mariadb"?(we=`ALTER TABLE ${ie} ADD `,$.type==="UNIQUE"?we+="UNIQUE ":$.type==="FULLTEXT"?we+="FULLTEXT ":$.type==="SPATIAL"&&(we+="SPATIAL "),we+=`INDEX ${F($.name)} (${$.columns.map(Ut=>F(Ut)).join(", ")})`,$.method&&$.method!=="BTREE"&&(we+=` USING ${$.method}`)):we=`CREATE ${$.type==="UNIQUE"?"UNIQUE ":""}INDEX ${F($.name)} ON ${ie} (${$.columns.map(Ut=>F(Ut)).join(", ")})`,k.push(we+";")}const qe=C.filter($=>$._isDeleted&&$._original);for(const $ of qe)m==="mysql"||m==="mariadb"?k.push(`ALTER TABLE ${ie} DROP FOREIGN KEY ${F($.name)};`):k.push(`ALTER TABLE ${ie} DROP CONSTRAINT ${F($.name)};`);const Yt=C.filter($=>$._isNew&&!$._isDeleted&&$.name&&$.columns.length>0&&$.columns[0]&&$.refTable&&$.refColumns.length>0&&$.refColumns[0]);for(const $ of Yt){let we=`ALTER TABLE ${ie} ADD CONSTRAINT ${F($.name)} FOREIGN KEY (${$.columns.map(Ut=>F(Ut)).join(", ")}) `;we+=`REFERENCES ${$.refSchema?F($.refSchema)+".":""}${F($.refTable)} (${$.refColumns.map(Ut=>F(Ut)).join(", ")})`,$.onDelete!=="NO ACTION"&&(we+=` ON DELETE ${$.onDelete}`),$.onUpdate!=="NO ACTION"&&(we+=` ON UPDATE ${$.onUpdate}`),k.push(we+";")}if(m==="mysql"||m==="mariadb"){const $=D||{comment:"",engine:"",charset:""};if(p.comment!==$.comment&&(p.comment?k.push(`ALTER TABLE ${ie} COMMENT='${p.comment.replace(/'/g,"''")}';`):k.push(`ALTER TABLE ${ie} COMMENT='';`)),p.engine&&p.engine!==$.engine&&k.push(`ALTER TABLE ${ie} ENGINE=${p.engine};`),p.charset&&p.charset!==$.charset){let we=`ALTER TABLE ${ie} CONVERT TO CHARACTER SET ${p.charset}`;p.collation&&(we+=` COLLATE ${p.collation}`),k.push(we+";")}}return k.length>0?k.join(`
|
||
|
||
`):"-- 没有需要执行的修改"}},[t,L,H,A,C,p,D,E,T]),ge=async()=>{if(!L){B("请输入表名");return}if(H.filter(F=>!F._isDeleted&&F.name).length===0){B("请至少添加一个字段");return}Se(!0),B("");try{const F=await a(Ce);if(!F.success)B(F.message);else if(t==="edit"&&i)try{const q=await i();if(q){const _e=q.columns.map(Re=>({...Re,id:crypto.randomUUID(),_original:{...Re,id:crypto.randomUUID()}})),k=q.indexes.map(Re=>({...Re,id:crypto.randomUUID(),_original:{...Re,id:crypto.randomUUID()}})),ie=q.foreignKeys.map(Re=>({...Re,id:crypto.randomUUID(),_original:{...Re,id:crypto.randomUUID()}}));c(_e),I(k),M(ie),q.options&&(P(q.options),Z(q.options))}}catch{}else l()}catch(F){B(F.message||"保存失败")}finally{Se(!1)}};if(!e)return null;const je=H.filter(m=>!m._isDeleted),Be=A.filter(m=>!m._isDeleted),Ze=C.filter(m=>!m._isDeleted),fe=[{id:"columns",label:"字段",icon:bu,count:je.length},{id:"indexes",label:"索引",icon:Gt,count:Be.length},{id:"foreignKeys",label:"外键",icon:wu,count:Ze.length},{id:"options",label:"选项",icon:uo},{id:"sql",label:"SQL 预览",icon:qs}];return s.jsx("div",{className:"fixed inset-0 z-50 flex items-center justify-center bg-black/40",children:s.jsxs("div",{className:"bg-white border border-border-default w-[1100px] h-[700px] flex flex-col shadow-modal rounded-xl animate-fade-in",children:[s.jsxs("div",{className:"flex items-center justify-between px-5 py-3.5 border-b border-border-default bg-white flex-shrink-0 rounded-t-xl",children:[s.jsxs("div",{className:"flex items-center gap-3",children:[s.jsx("div",{className:"w-8 h-8 rounded-lg bg-teal-50 flex items-center justify-center",children:s.jsx(zn,{size:18,className:"text-teal-500"})}),s.jsxs("span",{className:"font-semibold text-text-primary",children:[t==="create"?"新建表":"编辑表"," - ",E]}),t==="edit"&&n&&s.jsxs("span",{className:"text-text-secondary font-normal",children:["(",n,")"]})]}),s.jsxs("div",{className:"flex items-center gap-2",children:[s.jsxs("button",{onClick:ge,disabled:xe,className:`flex items-center gap-1.5 px-3 py-1.5 text-sm bg-primary-500 hover:bg-primary-600 text-white rounded-lg\r
|
||
disabled:opacity-50 transition-colors`,children:[s.jsx(GS,{size:14}),xe?"保存中...":"保存"]}),s.jsx("button",{onClick:l,className:"p-2 hover:bg-light-hover rounded-lg transition-colors text-text-secondary hover:text-text-primary",children:s.jsx(tE,{size:18})})]})]}),s.jsxs("div",{className:"border-b border-border-default bg-white/50 flex-shrink-0",children:[s.jsxs("div",{className:"flex items-center gap-6 px-4 py-2 border-b border-border-default/50",children:[s.jsxs("div",{className:"flex items-center gap-2",children:[s.jsx("span",{className:"text-sm text-text-secondary w-12",children:"表名:"}),s.jsx("input",{type:"text",value:L,onChange:m=>_(m.target.value),placeholder:"输入表名",disabled:t==="edit",className:`w-48 h-8 px-3 bg-white border border-border-default text-sm rounded-lg text-text-primary\r
|
||
focus:border-primary-500 focus:outline-none transition-colors\r
|
||
disabled:opacity-60 disabled:cursor-not-allowed`})]}),s.jsxs("div",{className:"flex items-center gap-2 flex-1",children:[s.jsx("span",{className:"text-sm text-text-secondary w-12",children:"注释:"}),s.jsx("input",{type:"text",value:p.comment,onChange:m=>P({...p,comment:m.target.value}),placeholder:"表注释",className:`flex-1 max-w-md h-8 px-3 bg-white border border-border-default text-sm rounded-lg text-text-primary\r
|
||
focus:border-primary-500 focus:outline-none transition-colors`})]})]}),s.jsx("div",{className:"flex px-5",children:fe.map(m=>s.jsxs("button",{onClick:()=>O(m.id),className:`flex items-center gap-2 px-4 py-2.5 text-sm border-b-2 transition-colors font-medium
|
||
${R===m.id?"border-primary-500 text-primary-600":"border-transparent text-text-secondary hover:text-text-primary"}`,children:[s.jsx(m.icon,{size:15}),m.label,"count"in m&&m.count!==void 0&&s.jsx("span",{className:`ml-1 text-xs px-1.5 py-0.5 rounded-full ${R===m.id?"bg-primary-100 text-primary-600":"bg-light-muted text-text-secondary"}`,children:m.count})]},m.id))})]}),he&&s.jsx("div",{className:"px-4 py-2 bg-danger-500/20 border-b border-danger-500/30 text-sm text-danger-500 flex-shrink-0",children:he}),s.jsx("div",{className:"flex-1 overflow-hidden bg-light-bg",children:Y?s.jsx("div",{className:"flex items-center justify-center h-full text-text-secondary",children:"加载中..."}):s.jsxs(s.Fragment,{children:[R==="columns"&&s.jsx(i_,{columns:je,dataTypes:ye,dbType:T,selectedId:j,onSelect:ee,onAdd:se,onRemove:We,onUpdate:Xe,onMove:W,needsLength:me,needsDecimals:De,supportsUnsigned:Ne}),R==="indexes"&&s.jsx(A_,{indexes:Be,columns:je,selectedId:b,onSelect:U,onAdd:Qe,onRemove:Te,onUpdate:Ye,dbType:T}),R==="foreignKeys"&&s.jsx(S_,{foreignKeys:Ze,columns:je,selectedId:J,onSelect:Ee,onAdd:Oe,onRemove:pe,onUpdate:y,onGetDatabases:o,onGetTables:S,onGetColumns:N,currentDatabase:E}),R==="options"&&s.jsx(N_,{options:p,dbType:T,onChange:P}),R==="sql"&&s.jsx(I_,{sql:Ce})]})})]})})}function i_({columns:e,dataTypes:t,dbType:E,selectedId:n,onSelect:r,onAdd:T,onRemove:l,onUpdate:a,onMove:i,needsLength:o,needsDecimals:S,supportsUnsigned:N}){const R=E.toLowerCase()==="mysql"||E.toLowerCase()==="mariadb",[O,L]=u.useState(null),[_,H]=u.useState(null),c=(C,M)=>{L(M),C.dataTransfer.effectAllowed="move"},A=(C,M)=>{C.preventDefault(),O!==null&&O!==M&&H(M)},I=()=>{if(O!==null&&_!==null&&O!==_)if(_<O)for(let C=O;C>_;C--)i(C,"up");else for(let C=O;C<_;C++)i(C,"down");L(null),H(null)};return s.jsxs("div",{className:"h-full flex flex-col",children:[s.jsx("div",{className:"flex items-center gap-2 px-4 py-2 border-b border-border-default bg-white/30 flex-shrink-0",children:s.jsxs("button",{onClick:T,className:"flex items-center gap-1.5 px-3 py-1.5 text-xs bg-success-500 hover:bg-success-600 text-white rounded-lg transition-colors",children:[s.jsx(In,{size:14}),"添加字段"]})}),s.jsx("div",{className:"flex-1 overflow-auto",children:s.jsxs("table",{className:"w-full text-sm",children:[s.jsx("thead",{className:"bg-white sticky top-0",children:s.jsxs("tr",{className:"border-b border-border-default text-text-primary",children:[s.jsx("th",{className:"w-8 px-1 py-2"}),s.jsx("th",{className:"w-36 px-3 py-2 text-left font-medium",children:"名称"}),s.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"类型"}),s.jsx("th",{className:"w-16 px-3 py-2 text-left font-medium",children:"长度"}),s.jsx("th",{className:"w-16 px-3 py-2 text-left font-medium",children:"小数点"}),s.jsx("th",{className:"w-16 px-3 py-2 text-center font-medium",children:"不是 null"}),R&&s.jsx("th",{className:"w-16 px-3 py-2 text-center font-medium",children:"无符号"}),s.jsx("th",{className:"w-14 px-3 py-2 text-center font-medium",children:"键"}),s.jsx("th",{className:"w-36 px-3 py-2 text-left font-medium",children:"默认值"}),s.jsx("th",{className:"px-3 py-2 text-left font-medium",children:"注释"}),s.jsx("th",{className:"w-12 px-2 py-2 text-center font-medium",children:"操作"})]})}),s.jsx("tbody",{children:e.map((C,M)=>s.jsxs("tr",{onDragOver:p=>A(p,M),onClick:()=>r(C.id),className:`border-b border-border-default/50 cursor-pointer transition-colors
|
||
${n===C.id?"bg-primary-500/20":"hover:bg-light-hover/50"}
|
||
${C._isNew?"bg-success-50":""}
|
||
${_===M?"border-t-2 border-t-primary-500":""}`,children:[s.jsx("td",{draggable:!0,onDragStart:p=>c(p,M),onDragEnd:I,className:"px-1 py-1.5 text-center cursor-grab active:cursor-grabbing",children:s.jsx(Fu,{size:14,className:"text-text-secondary mx-auto"})}),s.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:s.jsx("input",{type:"text",value:C.name,onChange:p=>a(C.id,"name",p.target.value),onFocus:()=>r(C.id),placeholder:"字段名",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-border-default \r
|
||
focus:border-primary-500 focus:bg-white focus:outline-none text-xs text-text-primary\r
|
||
selection:bg-primary-500 selection:text-white`})}),s.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:s.jsx("select",{value:C.type,onChange:p=>a(C.id,"type",p.target.value),onFocus:()=>r(C.id),className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-border-default \r
|
||
focus:border-primary-500 focus:bg-white focus:outline-none text-xs text-text-primary`,children:t.map(p=>s.jsx("optgroup",{label:p.group,children:p.types.map(P=>s.jsx("option",{value:P,children:P},P))},p.group))})}),s.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:s.jsx("input",{type:"text",value:C.length,onChange:p=>a(C.id,"length",p.target.value),onFocus:()=>r(C.id),disabled:!o(C.type),placeholder:o(C.type)?"":"-",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-border-default \r
|
||
focus:border-primary-500 focus:bg-white focus:outline-none text-xs text-text-primary\r
|
||
disabled:opacity-40 disabled:cursor-not-allowed selection:bg-primary-500 selection:text-white`})}),s.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:s.jsx("input",{type:"text",value:C.decimals,onChange:p=>a(C.id,"decimals",p.target.value),onFocus:()=>r(C.id),disabled:!S(C.type),placeholder:S(C.type)?"":"-",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-border-default \r
|
||
focus:border-primary-500 focus:bg-white focus:outline-none text-xs text-text-primary\r
|
||
disabled:opacity-40 disabled:cursor-not-allowed selection:bg-primary-500 selection:text-white`})}),s.jsx("td",{className:"px-3 py-1.5 text-center",onClick:p=>p.stopPropagation(),children:s.jsx("input",{type:"checkbox",checked:!C.nullable,onChange:p=>{r(C.id),a(C.id,"nullable",!p.target.checked)},disabled:C.primaryKey,className:"w-4 h-4 accent-blue-500 disabled:opacity-50"})}),R&&s.jsx("td",{className:"px-3 py-1.5 text-center",onClick:p=>p.stopPropagation(),children:s.jsx("input",{type:"checkbox",checked:C.unsigned,onChange:p=>{r(C.id),a(C.id,"unsigned",p.target.checked)},disabled:!N(C.type),className:"w-4 h-4 accent-blue-500 disabled:opacity-50"})}),s.jsxs("td",{className:"px-3 py-1.5 text-center",onClick:p=>p.stopPropagation(),children:[s.jsx("button",{onClick:()=>{r(C.id),a(C.id,"primaryKey",!C.primaryKey)},className:`p-1.5 rounded transition-colors ${C.primaryKey?"bg-warning-500 text-white":"text-text-muted hover:bg-light-hover hover:text-warning-500"}`,title:C.primaryKey?"主键":"设为主键",children:s.jsx(OT,{size:14})}),C.autoIncrement&&s.jsx("span",{className:"ml-1 text-xs text-primary-500",title:"自增",children:"A"})]}),s.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:s.jsx("input",{type:"text",value:C.defaultValue,onChange:p=>a(C.id,"defaultValue",p.target.value),onFocus:()=>r(C.id),placeholder:"",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-border-default \r
|
||
focus:border-primary-500 focus:bg-white focus:outline-none text-xs text-text-primary\r
|
||
selection:bg-primary-500 selection:text-white`})}),s.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:s.jsx("input",{type:"text",value:C.comment,onChange:p=>a(C.id,"comment",p.target.value),onFocus:()=>r(C.id),placeholder:"",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-border-default \r
|
||
focus:border-primary-500 focus:bg-white focus:outline-none text-xs text-text-primary\r
|
||
selection:bg-primary-500 selection:text-white`})}),s.jsx("td",{className:"px-2 py-1.5 text-center",onClick:p=>p.stopPropagation(),children:s.jsx("button",{onClick:()=>{r(C.id),e.length>1&&l(C.id)},disabled:e.length<=1,className:`p-1 text-text-secondary hover:text-danger-500 hover:bg-danger-500/10 rounded transition-colors\r
|
||
disabled:opacity-30 disabled:cursor-not-allowed disabled:hover:text-text-secondary disabled:hover:bg-transparent`,title:"删除字段",children:s.jsx(IE,{size:14})})})]},C.id))})]})}),n&&s.jsx(R_,{column:e.find(C=>C.id===n),onUpdate:(C,M)=>a(n,C,M),isMysql:R})]})}function R_({column:e,onUpdate:t,isMysql:E}){return s.jsx("div",{className:"border-t border-border-default bg-white px-5 py-3.5 flex-shrink-0",children:s.jsxs("div",{className:"grid grid-cols-4 gap-4 text-sm",children:[s.jsxs("label",{className:"flex items-center gap-2 text-text-primary cursor-pointer",children:[s.jsx("input",{type:"checkbox",checked:e.autoIncrement,onChange:n=>t("autoIncrement",n.target.checked),className:"w-4 h-4 accent-blue-500 rounded"}),s.jsx("span",{children:"自动递增"})]}),E&&s.jsxs(s.Fragment,{children:[s.jsxs("label",{className:"flex items-center gap-2 text-text-primary cursor-pointer",children:[s.jsx("input",{type:"checkbox",checked:e.zerofill,onChange:n=>t("zerofill",n.target.checked),className:"w-4 h-4 accent-blue-500 rounded"}),s.jsx("span",{children:"填充零"})]}),s.jsxs("label",{className:"flex items-center gap-2 text-text-primary cursor-pointer",children:[s.jsx("input",{type:"checkbox",checked:e.isVirtual,onChange:n=>t("isVirtual",n.target.checked),className:"w-4 h-4 accent-blue-500 rounded"}),s.jsx("span",{children:"虚拟"})]})]})]})})}function A_({indexes:e,columns:t,selectedId:E,onSelect:n,onAdd:r,onRemove:T,onUpdate:l,dbType:a}){const i=a.toLowerCase()==="mysql"||a.toLowerCase()==="mariadb",o=t.filter(R=>R.name).map(R=>({label:R.name,value:R.name})),S=[{label:"NORMAL",value:"NORMAL"},{label:"UNIQUE",value:"UNIQUE"},...i?[{label:"FULLTEXT",value:"FULLTEXT"},{label:"SPATIAL",value:"SPATIAL"}]:[]],N=[{label:"BTREE",value:"BTREE"},{label:"HASH",value:"HASH"}];return s.jsxs("div",{className:"h-full flex flex-col",children:[s.jsx("div",{className:"flex items-center gap-2 px-4 py-2 border-b border-border-default bg-white/30 flex-shrink-0",children:s.jsxs("button",{onClick:r,className:"flex items-center gap-1.5 px-3 py-1.5 text-xs bg-success-500 hover:bg-success-600 text-white rounded-lg transition-colors",children:[s.jsx(In,{size:14}),"添加索引"]})}),s.jsxs("div",{className:"flex-1 overflow-auto",children:[s.jsxs("table",{className:"w-full text-sm",children:[s.jsx("thead",{className:"bg-white sticky top-0",children:s.jsxs("tr",{className:"border-b border-border-default text-text-primary",children:[s.jsx("th",{className:"w-40 px-3 py-2 text-left font-medium",children:"名称"}),s.jsx("th",{className:"w-64 px-3 py-2 text-left font-medium",children:"字段"}),s.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"索引类型"}),i&&s.jsx("th",{className:"w-24 px-3 py-2 text-left font-medium",children:"索引方法"}),s.jsx("th",{className:"px-3 py-2 text-left font-medium",children:"注释"}),s.jsx("th",{className:"w-16 px-3 py-2 text-center font-medium",children:"操作"})]})}),s.jsx("tbody",{children:e.map(R=>s.jsxs("tr",{onClick:()=>n(R.id),className:`border-b border-border-default/50 cursor-pointer transition-colors
|
||
${E===R.id?"bg-primary-500/20":"hover:bg-light-hover/50"}
|
||
${R._isNew?"bg-success-50":""}`,children:[s.jsx("td",{className:"px-3 py-1.5",children:s.jsx("input",{type:"text",value:R.name,onChange:O=>l(R.id,"name",O.target.value),onClick:O=>O.stopPropagation(),placeholder:"索引名",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-border-default \r
|
||
focus:border-primary-500 focus:bg-white focus:outline-none text-xs text-text-primary`})}),s.jsx("td",{className:"px-3 py-1.5",onClick:O=>O.stopPropagation(),children:s.jsx(T_,{values:R.columns,options:o,onChange:O=>l(R.id,"columns",O),placeholder:"选择字段..."})}),s.jsx("td",{className:"px-3 py-1.5",onClick:O=>O.stopPropagation(),children:s.jsx(Vt,{value:R.type,options:S,onChange:O=>l(R.id,"type",O),placeholder:"索引类型"})}),i&&s.jsx("td",{className:"px-3 py-1.5",onClick:O=>O.stopPropagation(),children:s.jsx(Vt,{value:R.method,options:N,onChange:O=>l(R.id,"method",O),placeholder:"索引方法"})}),s.jsx("td",{className:"px-3 py-1.5",children:s.jsx("input",{type:"text",value:R.comment,onChange:O=>l(R.id,"comment",O.target.value),onClick:O=>O.stopPropagation(),placeholder:"",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-border-default \r
|
||
focus:border-primary-500 focus:bg-white focus:outline-none text-xs text-text-primary`})}),s.jsx("td",{className:"px-3 py-1.5 text-center",children:s.jsx("button",{onClick:O=>{O.stopPropagation(),T(R.id)},className:"p-1 text-text-secondary hover:text-danger-500 hover:bg-danger-500/10 rounded transition-colors",title:"删除索引",children:s.jsx(IE,{size:14})})})]},R.id))})]}),e.length===0&&s.jsx("div",{className:"text-center py-8 text-text-secondary text-sm",children:'暂无索引,点击"添加索引"创建'})]})]})}function S_({foreignKeys:e,columns:t,selectedId:E,onSelect:n,onAdd:r,onRemove:T,onUpdate:l,onGetDatabases:a,onGetTables:i,onGetColumns:o,currentDatabase:S}){const[N,R]=u.useState([S]),[O,L]=u.useState({}),[_,H]=u.useState({});u.useEffect(()=>{a&&a().then(P=>R(P))},[]),u.useEffect(()=>{e.forEach(P=>{if(!O[P.id]&&i){const D=P.refSchema||S;i(D).then(Z=>{L(Y=>({...Y,[P.id]:Z}))})}})},[e.length,S]);const c=async(P,D)=>{if(!i)return;const Z=await i(D);L(Y=>({...Y,[P]:Z}))},A=async(P,D,Z)=>{if(!o)return;const Y=await o(D,Z);H(ne=>({...ne,[P]:Y}))},I=["CASCADE","SET NULL","NO ACTION","RESTRICT","SET DEFAULT"],C=t.filter(P=>P.name).map(P=>({label:P.name,value:P.name})),M=N.map(P=>({label:P,value:P})),p=I.map(P=>({label:P,value:P}));return s.jsxs("div",{className:"h-full flex flex-col",children:[s.jsx("div",{className:"flex items-center gap-2 px-4 py-2 border-b border-border-default bg-white/30 flex-shrink-0",children:s.jsxs("button",{onClick:r,className:"flex items-center gap-1.5 px-3 py-1.5 text-xs bg-success-500 hover:bg-success-600 text-white rounded-lg transition-colors",children:[s.jsx(In,{size:14}),"添加外键"]})}),s.jsxs("div",{className:"flex-1 overflow-auto",children:[s.jsxs("table",{className:"w-full text-sm",children:[s.jsx("thead",{className:"bg-white sticky top-0",children:s.jsxs("tr",{className:"border-b border-border-default text-text-primary",children:[s.jsx("th",{className:"w-36 px-3 py-2 text-left font-medium",children:"名称"}),s.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"字段"}),s.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"被引用的数据库"}),s.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"被引用的表"}),s.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"被引用的字段"}),s.jsx("th",{className:"w-24 px-3 py-2 text-left font-medium",children:"删除时"}),s.jsx("th",{className:"w-24 px-3 py-2 text-left font-medium",children:"更新时"}),s.jsx("th",{className:"w-16 px-3 py-2 text-center font-medium",children:"操作"})]})}),s.jsx("tbody",{children:e.map(P=>s.jsxs("tr",{onClick:()=>n(P.id),className:`border-b border-border-default/50 cursor-pointer transition-colors
|
||
${E===P.id?"bg-primary-500/20":"hover:bg-light-hover/50"}
|
||
${P._isNew?"bg-success-50":""}`,children:[s.jsx("td",{className:"px-3 py-1.5",children:s.jsx("input",{type:"text",value:P.name,onChange:D=>l(P.id,"name",D.target.value),onClick:D=>D.stopPropagation(),placeholder:"外键名",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-border-default \r
|
||
focus:border-primary-500 focus:bg-white focus:outline-none text-xs text-text-primary`})}),s.jsx("td",{className:"px-3 py-1.5",onClick:D=>D.stopPropagation(),children:s.jsx(Vt,{value:P.columns[0]||"",options:C,onChange:D=>l(P.id,"columns",[D]),placeholder:"选择字段"})}),s.jsx("td",{className:"px-3 py-1.5",onClick:D=>D.stopPropagation(),children:s.jsx(Vt,{value:P.refSchema||S,options:M,onChange:D=>{l(P.id,{refSchema:D,refTable:"",refColumns:[]}),c(P.id,D)},placeholder:"选择数据库"})}),s.jsx("td",{className:"px-3 py-1.5",onClick:D=>D.stopPropagation(),children:s.jsx(Vt,{value:P.refTable,options:(O[P.id]||[]).map(D=>({label:D,value:D})),onChange:D=>{l(P.id,"refTable",D),A(P.id,P.refSchema||S,D)},placeholder:O[P.id]?"选择表":"请先选择数据库",disabled:!O[P.id]})}),s.jsx("td",{className:"px-3 py-1.5",onClick:D=>D.stopPropagation(),children:s.jsx(Vt,{value:P.refColumns[0]||"",options:(_[P.id]||[]).map(D=>({label:D,value:D})),onChange:D=>l(P.id,"refColumns",[D]),placeholder:_[P.id]?"选择字段":"请先选择表",disabled:!P.refTable||!_[P.id]})}),s.jsx("td",{className:"px-3 py-1.5",onClick:D=>D.stopPropagation(),children:s.jsx(Vt,{value:P.onDelete,options:p,onChange:D=>l(P.id,"onDelete",D)})}),s.jsx("td",{className:"px-3 py-1.5",onClick:D=>D.stopPropagation(),children:s.jsx(Vt,{value:P.onUpdate,options:p,onChange:D=>l(P.id,"onUpdate",D)})}),s.jsx("td",{className:"px-3 py-1.5 text-center",children:s.jsx("button",{onClick:D=>{D.stopPropagation(),T(P.id)},className:"p-1 text-text-secondary hover:text-danger-500 hover:bg-danger-500/10 rounded transition-colors",title:"删除外键",children:s.jsx(IE,{size:14})})})]},P.id))})]}),e.length===0&&s.jsx("div",{className:"text-center py-8 text-text-secondary text-sm",children:'暂无外键,点击"添加外键"创建'})]})]})}function N_({options:e,dbType:t,onChange:E}){const n=t.toLowerCase()==="mysql"||t.toLowerCase()==="mariadb",r=n_.map(i=>({label:i,value:i})),T=s_.map(i=>({label:i,value:i})),l=r_.map(i=>({label:i,value:i})),a=(AR[e.charset]||[]).map(i=>({label:i,value:i}));return n?s.jsx("div",{className:"p-6 space-y-5",children:s.jsxs("div",{className:"grid grid-cols-2 gap-5",children:[s.jsxs("div",{children:[s.jsx("label",{className:"block text-sm text-text-primary font-medium mb-2",children:"数据库引擎"}),s.jsx(Vt,{value:e.engine,options:r,onChange:i=>E({...e,engine:i}),placeholder:"选择引擎",className:"h-10 bg-white border border-border-default rounded-lg px-3"})]}),s.jsxs("div",{children:[s.jsx("label",{className:"block text-sm text-text-primary font-medium mb-2",children:"行格式"}),s.jsx(Vt,{value:e.rowFormat,options:T,onChange:i=>E({...e,rowFormat:i}),placeholder:"选择行格式",className:"h-10 bg-white border border-border-default rounded-lg px-3"})]}),s.jsxs("div",{children:[s.jsx("label",{className:"block text-sm text-text-primary font-medium mb-2",children:"字符集"}),s.jsx(Vt,{value:e.charset,options:l,onChange:i=>{const o=AR[i]||[];E({...e,charset:i,collation:o[0]||""})},placeholder:"选择字符集",className:"h-10 bg-white border border-border-default rounded-lg px-3"})]}),s.jsxs("div",{children:[s.jsx("label",{className:"block text-sm text-text-primary font-medium mb-2",children:"排序规则"}),s.jsx(Vt,{value:e.collation,options:a,onChange:i=>E({...e,collation:i}),placeholder:"选择排序规则",className:"h-10 bg-white border border-border-default rounded-lg px-3"})]}),s.jsxs("div",{children:[s.jsx("label",{className:"block text-sm text-text-primary font-medium mb-2",children:"自增值"}),s.jsx("input",{type:"text",value:e.autoIncrement,onChange:i=>E({...e,autoIncrement:i.target.value}),placeholder:"默认",className:`w-full h-10 px-3 bg-white border border-border-default text-sm text-text-primary rounded-lg\r
|
||
focus:border-primary-500 focus:outline-none transition-colors`})]})]})}):s.jsx("div",{className:"p-4 text-text-secondary text-sm",children:"表选项仅适用于 MySQL / MariaDB"})}function I_({sql:e}){const[t,E]=u.useState(!1),n=async()=>{await navigator.clipboard.writeText(e),E(!0),setTimeout(()=>E(!1),2e3)};return s.jsxs("div",{className:"h-full flex flex-col",children:[s.jsxs("div",{className:"flex items-center justify-between px-5 py-3 border-b border-border-default bg-white flex-shrink-0",children:[s.jsx("span",{className:"text-sm text-text-primary font-medium",children:"将要执行的 SQL 语句"}),s.jsx("button",{onClick:n,className:"flex items-center gap-1.5 px-3 py-1.5 text-xs text-text-primary bg-white hover:bg-light-hover border border-border-default rounded-lg transition-colors",children:t?"✓ 已复制":"复制"})]}),s.jsx("div",{className:"flex-1 overflow-auto p-5 bg-slate-50",children:s.jsx("pre",{className:"text-sm font-mono text-primary-600 whitespace-pre-wrap break-all leading-relaxed",children:e})})]})}function u_({isOpen:e,title:t,label:E,placeholder:n,defaultValue:r="",confirmText:T="确定",onClose:l,onConfirm:a,icon:i,showDataOption:o,onConfirmWithData:S}){const[N,R]=u.useState(r),[O,L]=u.useState(!1);if(u.useEffect(()=>{R(r)},[r,e]),!e)return null;const _=H=>{H.preventDefault(),N.trim()&&(o&&S?S(N.trim(),O):a(N.trim()))};return s.jsxs("div",{className:"fixed inset-0 z-50 flex items-center justify-center animate-fade-in",children:[s.jsx("div",{className:"absolute inset-0 bg-black/20 backdrop-blur-sm",onClick:l}),s.jsxs("div",{className:"relative bg-white w-[380px] rounded-2xl shadow-modal animate-scale-in overflow-hidden",children:[s.jsxs("div",{className:"flex items-center justify-between px-5 py-4 border-b border-border-default",children:[s.jsxs("div",{className:"flex items-center gap-3",children:[i&&s.jsx("div",{className:"w-8 h-8 rounded-lg bg-light-elevated flex items-center justify-center",children:i}),s.jsx("span",{className:"font-semibold text-text-primary",children:t})]}),s.jsx("button",{onClick:l,className:"p-1.5 hover:bg-light-hover rounded-lg transition-colors",children:s.jsx(tE,{size:16,className:"text-text-tertiary"})})]}),s.jsxs("form",{onSubmit:_,className:"p-5 space-y-4",children:[s.jsxs("div",{children:[s.jsxs("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:[E," ",s.jsx("span",{className:"text-danger-500",children:"*"})]}),s.jsx("input",{type:"text",value:N,onChange:H=>R(H.target.value),placeholder:n,className:`w-full h-10 px-3 bg-light-surface border border-border-default rounded-lg\r
|
||
focus:border-primary-500 focus:shadow-focus text-sm transition-all`,autoFocus:!0})]}),o&&s.jsxs("label",{className:"flex items-center gap-3 cursor-pointer group",children:[s.jsx("div",{className:`w-5 h-5 rounded border-2 flex items-center justify-center transition-all
|
||
${O?"bg-primary-500 border-primary-500":"border-border-strong group-hover:border-primary-300"}`,children:O&&s.jsx(aE,{size:12,className:"text-white"})}),s.jsx("input",{type:"checkbox",checked:O,onChange:H=>L(H.target.checked),className:"sr-only"}),s.jsx("span",{className:"text-sm text-text-secondary",children:"同时复制表数据"})]}),s.jsxs("div",{className:"flex justify-end gap-2 pt-2",children:[s.jsx("button",{type:"button",onClick:l,className:`px-4 py-2 text-sm bg-light-elevated hover:bg-light-muted border border-border-default\r
|
||
rounded-lg transition-colors text-text-secondary`,children:"取消"}),s.jsx("button",{type:"submit",disabled:!N.trim(),className:`px-4 py-2 text-sm bg-primary-500 hover:bg-primary-600 text-white\r
|
||
disabled:opacity-50 disabled:cursor-not-allowed \r
|
||
rounded-lg transition-all font-medium shadow-btn hover:shadow-btn-hover`,children:T})]})]})]})]})}function O_(){const[e,t]=u.useState([]),[E,n]=u.useState(new Set);u.useEffect(()=>{(async()=>{try{const i=await Le.loadConnections();i&&Array.isArray(i)&&t(i)}catch(i){console.error("加载连接失败:",i)}})()},[]);const r=u.useCallback(a=>{const i={...a,id:`conn-${Date.now()}`};t(o=>{const S=[...o,i];return Le.saveConnections(S),S})},[]),T=u.useCallback(a=>{t(i=>{const o=i.filter(S=>S.id!==a);return Le.saveConnections(o),o})},[]),l=u.useCallback(a=>{t(i=>{const o=i.map(S=>S.id===a.id?a:S);return Le.saveConnections(o),o})},[]);return{connections:e,setConnections:t,connectedIds:E,setConnectedIds:n,addConnection:r,deleteConnection:T,updateConnection:l}}function c_(e){const[t,E]=u.useState(new Map),[n,r]=u.useState(new Set),[T,l]=u.useState(new Set),a=u.useCallback(async i=>{l(o=>new Set(o).add(i));try{const o=await Le.getDatabases(i);console.log("获取到数据库列表:",i,o),E(S=>new Map(S).set(i,o||[])),(!o||o.length===0)&&e("info","未发现数据库或无权限访问")}catch(o){console.error("获取数据库列表失败:",o),e("error","获取数据库列表失败: "+o.message),E(S=>new Map(S).set(i,[]))}finally{l(o=>{const S=new Set(o);return S.delete(i),S})}},[e]);return{databasesMap:t,setDatabasesMap:E,loadingDbSet:n,setLoadingDbSet:r,loadingConnectionsSet:T,fetchDatabases:a}}function C_(e){const[t,E]=u.useState(new Map),[n,r]=u.useState(new Map),T=u.useCallback(async(a,i)=>{try{const o=await Le.getTables(a,i);E(S=>new Map(S).set(i,o))}catch{e("error","获取表列表失败")}},[e]),l=u.useCallback(async(a,i,o)=>{try{const S=await Le.getTableColumns(a,i,o);r(N=>new Map(N).set(o,S))}catch{}},[]);return{tablesMap:t,setTablesMap:E,columnsMap:n,setColumnsMap:r,fetchTables:T,fetchColumns:l}}function d_(){const[e,t]=u.useState([]),[E,n]=u.useState("welcome"),[r,T]=u.useState(new Set);return{tabs:e,setTabs:t,activeTab:E,setActiveTab:n,loadingTables:r,setLoadingTables:T}}function L_(e,t,E){return{runQuery:u.useCallback(async(r,T,l)=>{try{const a=await Le.executeQuery(T,l);t(i=>i.map(o=>o.id===r&&!("tableName"in o)?{...o,results:a}:o))}catch(a){E("error","查询失败:"+a.message)}},[t,E])}}function __(e,t,E){const n=u.useCallback(async()=>{try{const T=await Le.importConnections();if(T.cancelled)return;if(!T.success){E("error",T.error||"导入失败");return}T.connections&&T.connections.length>0?t(l=>{const a=new Map(l.map(R=>[R.name,R]));let i=0,o=0;for(const R of T.connections){const O=a.get(R.name);O?(a.set(R.name,{...R,id:O.id}),i++):(a.set(R.name,R),o++)}const S=Array.from(a.values());Le.saveConnections(S);const N=[];return o>0&&N.push(`新增 ${o} 个`),i>0&&N.push(`覆盖 ${i} 个`),E("success",`已从 ${T.source||"文件"} 导入连接:${N.join(",")}`),S}):E("info","文件中没有找到连接信息")}catch(T){E("error","导入失败:"+T.message)}},[t,E]),r=u.useCallback(async T=>{try{await Le.exportConnections(e,T),E("success","导出成功")}catch(l){E("error","导出失败:"+l.message)}},[e,E]);return{importConnections:n,exportConnections:r}}function f_(){const[e,t]=u.useState(null),[E,n]=u.useState(null),[r,T]=u.useState(!1),[l,a]=u.useState(null),[i,o]=u.useState(),[S,N]=u.useState(!1),[R,O]=u.useState(null),[L,_]=u.useState(!1),[H,c]=u.useState(null),[A,I]=u.useState(!1),[C,M]=u.useState(null),[p,P]=u.useState(null),[D,Z]=u.useState(null),Y=u.useCallback((f,d)=>{Z({type:f,message:d}),setTimeout(()=>Z(null),3e3)},[]),{connections:ne,setConnections:xe,connectedIds:Se,setConnectedIds:he,addConnection:B,deleteConnection:j,updateConnection:ee}=O_(),{databasesMap:b,setDatabasesMap:U,loadingDbSet:J,setLoadingDbSet:Ee,loadingConnectionsSet:ce,fetchDatabases:ye}=c_(Y),{tablesMap:me,setTablesMap:De,columnsMap:Ne,fetchTables:se,fetchColumns:We}=C_(Y),{tabs:Xe,setTabs:W,activeTab:Qe,setActiveTab:Te,loadingTables:Ke,setLoadingTables:Ye}=d_(),{runQuery:Q}=L_(Xe,W,Y),{importConnections:Oe,exportConnections:pe}=__(ne,xe,Y),y=u.useCallback(async f=>{if(!Se.has(f.id))try{const d=await Le.connect(f);if(!d.success){Y("error","连接失败:"+d.message);return}he(v=>new Set(v).add(f.id)),t(f.id),await ye(f.id),Y("success",`已连接到 ${f.name}`)}catch(d){Y("error","连接失败:"+d.message)}},[Se,he,ye,Y]),le=u.useCallback(async f=>{try{await Le.disconnect(f),he(d=>{const v=new Set(d);return v.delete(f),v}),U(d=>{const v=new Map(d);return v.delete(f),v}),W(d=>{const v=d.filter(h=>!("connectionId"in h&&h.connectionId===f));return Qe&&!v.find(h=>h.id===Qe)&&Te(v.length>0?v[0].id:"welcome"),v}),e===f&&t(null),Y("info","连接已断开")}catch(d){Y("error","断开失败:"+d.message)}},[e,Qe,he,U,W,Te,Y]),Ce=u.useCallback(async(f,d)=>{n(f),t(d),Ee(v=>new Set(v).add(f));try{await se(d,f);const v=me.get(f)||[];await Promise.all(v.map(h=>We(d,f,h.name)))}finally{Ee(v=>{const h=new Set(v);return h.delete(f),h})}},[se,We,me,Ee]),ge=u.useCallback(f=>{f!==e&&n(null),t(f)},[e]),je=u.useCallback(async(f,d,v)=>{const h=Xe.find(Me=>"tableName"in Me&&Me.tableName===v&&Me.database===d&&Me.connectionId===f);if(h){Te(h.id);return}const K=`table-${Date.now()}`,te=100,Ge={id:K,tableName:v,database:d,connectionId:f,columns:[],data:[],total:0,page:1,pageSize:te,pendingChanges:new Map,deletedRows:new Set,newRows:[]};W(Me=>[...Me,Ge]),Te(K),Ye(Me=>new Set(Me).add(K));try{const Me=await Le.getTableColumns(f,d,v),{data:Nt,total:dt}=await Le.getTableData(f,d,v,1,te);W(pE=>pE.map(qn=>qn.id===K?{...qn,columns:Me,data:Nt||[],total:dt}:qn))}catch(Me){Y("error","打开表失败:"+Me.message),W(Nt=>Nt.filter(dt=>dt.id!==K)),Te("welcome")}finally{Ye(Me=>{const Nt=new Set(Me);return Nt.delete(K),Nt})}},[Xe,W,Te,Ye,Y]),Be=u.useCallback(async(f,d)=>{const v=Xe.find(h=>h.id===f);if(!(!v||!("tableName"in v))){Ye(h=>new Set(h).add(f));try{const{data:h,total:K}=await Le.getTableData(v.connectionId,v.database,v.tableName,d,v.pageSize);W(te=>te.map(Ge=>Ge.id===f?{...Ge,data:h||[],total:K,page:d,pendingChanges:new Map,deletedRows:new Set,newRows:[]}:Ge))}catch{Y("error","加载数据失败")}finally{Ye(h=>{const K=new Set(h);return K.delete(f),K})}}},[Xe,W,Ye,Y]),Ze=u.useCallback((f,d,v,h)=>{W(K=>K.map(te=>{if(te.id!==f||!("tableName"in te))return te;const Ge=te,Me=new Map(Ge.pendingChanges),Nt=String(d),dt=Me.get(Nt)||{};dt[v]=h,Me.set(Nt,dt);const pE=[...Ge.data];return pE[d]&&(pE[d]={...pE[d],[v]:h}),{...te,data:pE,pendingChanges:Me}}))},[W]),fe=u.useCallback((f,d)=>{W(v=>v.map(h=>{if(h.id!==f||!("tableName"in h))return h;const K=h,te=new Set(K.deletedRows);return te.add(d),{...h,deletedRows:te}}))},[W]),m=u.useCallback((f,d)=>{W(v=>v.map(h=>{if(h.id!==f||!("tableName"in h))return h;const K=h,te=new Set(K.deletedRows);return d.forEach(Ge=>te.add(Ge)),{...h,deletedRows:te}}))},[W]),F=u.useCallback(async f=>{const d=Xe.find(h=>h.id===f);if(!d||!("tableName"in d))return;const v=d.columns.find(h=>h.key==="PRI")?.name||d.columns[0]?.name;if(!v){Y("error","无法确定主键");return}Ye(h=>new Set(h).add(f));try{for(const[h,K]of d.pendingChanges){const te=parseInt(h),Ge=d.data[te];if(!Ge)continue;const Me=Ge[v];await Le.updateTableRow(d.connectionId,d.database,d.tableName,v,Me,K)}for(const h of d.deletedRows){const K=d.data[h];if(!K)continue;const te=K[v];await Le.deleteTableRow(d.connectionId,d.database,d.tableName,v,te)}for(const h of d.newRows||[]){const K={};d.columns.forEach(te=>{h[te.name]!==void 0&&h[te.name]!==null&&h[te.name]!==""&&(K[te.name]=h[te.name])}),Object.keys(K).length>0&&await Le.insertTableRow(d.connectionId,d.database,d.tableName,K)}Y("success","保存成功"),await Be(f,d.page)}catch(h){Y("error","保存失败:"+h.message)}finally{Ye(h=>{const K=new Set(h);return K.delete(f),K})}},[Xe,Be,Ye,Y]),q=u.useCallback(f=>{W(d=>d.map(v=>v.id===f?{...v,pendingChanges:new Map,deletedRows:new Set,newRows:[]}:v))},[W]),_e=u.useCallback(async f=>{const d=Xe.find(v=>v.id===f);!d||!("tableName"in d)||await Be(f,d.page)},[Xe,Be]),k=u.useCallback(f=>{W(d=>d.map(v=>{if(v.id!==f||!("tableName"in v))return v;const h=v,K={};return h.columns.forEach(te=>{K[te.name]=null}),{...v,newRows:[...h.newRows||[],K]}}))},[W]),ie=u.useCallback((f,d,v,h)=>{W(K=>K.map(te=>{if(te.id!==f||!("tableName"in te))return te;const Me=[...te.newRows||[]];return Me[d]&&(Me[d]={...Me[d],[v]:h}),{...te,newRows:Me}}))},[W]),Re=u.useCallback((f,d)=>{W(v=>v.map(h=>{if(h.id!==f||!("tableName"in h))return h;const te=[...h.newRows||[]];return te.splice(d,1),{...h,newRows:te}}))},[W]),Et=u.useCallback(()=>{const f={id:`query-${Date.now()}`,title:`查询 ${Xe.filter(d=>!("tableName"in d)).length+1}`,sql:"",connectionId:e||void 0,results:null};W(d=>[...d,f]),Te(f.id)},[Xe,W,Te,e]),KE=u.useCallback(async(f,d)=>{if(!e){Y("error","请先连接数据库");return}await Q(f,e,d)},[e,Q,Y]),fE=u.useCallback((f,d)=>{W(v=>v.map(h=>h.id===f?{...h,sql:d}:h))},[W]),oe=u.useCallback((f,d)=>{W(v=>v.map(h=>h.id===f?{...h,title:d}:h))},[W]),qe=u.useCallback(f=>{W(d=>{const v=d.filter(h=>h.id!==f);return Qe===f&&Te(v.length>0?v[v.length-1].id:"welcome"),v})},[Qe,W,Te]),Yt=u.useCallback(f=>{Te(f)},[Te]),$=u.useCallback(async(f,d)=>{W(v=>v.map(h=>h.id===f?{...h,pageSize:d}:h)),await Be(f,1)},[W,Be]),we=u.useCallback(f=>{o(f),a(null),T(!0)},[]),Ut=u.useCallback(f=>{f.id?ee(f):B(f)},[B,ee]),$E=u.useCallback(async f=>{Se.has(f)&&await le(f),j(f)},[Se,le,j]),dT=u.useCallback(async f=>{for(const d of f)await $E(d)},[$E]),Zn=u.useCallback(f=>{a(f),o(void 0),T(!0)},[]),$r=u.useCallback(f=>{O(f),N(!0)},[]),LT=u.useCallback(async(f,d)=>{try{await Le.dropDatabase(f,d),Y("success",`数据库 ${d} 已删除`),await ye(f)}catch(v){Y("error","删除失败:"+v.message)}},[ye,Y]),_T=u.useCallback((f,d)=>{M({connectionId:f,database:d,mode:"create"}),I(!0)},[]),fT=u.useCallback(async(f,d,v)=>{try{await Le.dropTable(f,d,v),Y("success",`表 ${v} 已删除`),await se(f,d)}catch(h){Y("error","删除失败:"+h.message)}},[se,Y]),Jr=u.useCallback(async(f,d,v)=>{try{await Le.truncateTable(f,d,v),Y("success",`表 ${v} 已清空`)}catch(h){Y("error","清空失败:"+h.message)}},[Y]),G=u.useCallback((f,d,v)=>{P({isOpen:!0,title:"重命名表",label:"新表名",defaultValue:v,onConfirm:async h=>{if(h&&h!==v)try{await Le.renameTable(f,d,v,h),Y("success",`表已重命名为 ${h}`),await se(f,d)}catch(K){Y("error","重命名失败:"+K.message)}P(null)}})},[se,Y]),g=u.useCallback((f,d,v)=>{P({isOpen:!0,title:"复制表",label:"新表名",defaultValue:`${v}_copy`,onConfirm:async h=>{if(h)try{await Le.duplicateTable(f,d,v,h),Y("success",`表已复制为 ${h}`),await se(f,d)}catch(K){Y("error","复制失败:"+K.message)}P(null)}})},[se,Y]),X=u.useCallback(async(f,d)=>{await se(f,d),Y("success","已刷新")},[se,Y]),Ie=u.useCallback((f,d,v)=>{M({connectionId:f,database:d,tableName:v,mode:"edit"}),I(!0)},[]);return u.useEffect(()=>{const f=d=>{d.ctrlKey&&d.key==="q"&&(d.preventDefault(),Et())};return window.addEventListener("keydown",f),()=>window.removeEventListener("keydown",f)},[Et]),s.jsxs("div",{className:"h-screen flex flex-col bg-white overflow-hidden font-sans",children:[s.jsx(tO,{}),s.jsxs("div",{className:"flex-1 flex min-h-0",children:[s.jsx(nO,{connections:ne,activeConnection:e,connectedIds:Se,databasesMap:b,tablesMap:me,selectedDatabase:E,loadingDbSet:J,loadingConnectionsSet:ce,onNewConnection:()=>{a(null),o(void 0),T(!0)},onSelectConnection:t,onConnect:y,onDisconnect:le,onEditConnection:Zn,onDeleteConnection:$E,onDeleteConnections:dT,onSelectDatabase:Ce,onOpenTable:je,onExportConnections:pe,onImportConnections:Oe,onCreateDatabase:$r,onDropDatabase:LT,onCreateTable:_T,onDropTable:fT,onTruncateTable:Jr,onRenameTable:G,onDuplicateTable:g,onRefreshTables:X,onDesignTable:Ie,onFetchDatabases:ye}),s.jsx(JL,{tabs:Xe,activeTab:Qe,activeConnection:e,selectedDatabase:E,connections:ne,connectedIds:Se,databasesMap:b,databases:b.get(e||"")||[],tables:me.get(E||"")||[],columns:Ne,onTabChange:Yt,onCloseTab:qe,onNewQuery:Et,onRunQuery:KE,onUpdateSql:fE,onUpdateTabTitle:oe,onLoadTablePage:Be,onChangeTablePageSize:$,onNewConnectionWithType:we,onUpdateTableCell:Ze,onDeleteTableRow:fe,onDeleteTableRows:m,onSaveTableChanges:F,onDiscardTableChanges:q,onRefreshTable:_e,onAddTableRow:k,onUpdateNewRow:ie,onDeleteNewRow:Re,onSelectConnection:ge,onSelectDatabase:Ce,loadingTables:Ke})]}),s.jsxs("div",{className:"h-6 bg-light-surface flex items-center px-3 text-xs border-t border-border-default text-text-tertiary",children:[s.jsx("span",{className:`w-2 h-2 rounded-full mr-2 ${Se.size>0?"bg-success-500":"bg-text-disabled"}`}),s.jsx("span",{children:Se.size>0?`${Se.size} 个连接`:"未连接"}),s.jsxs("span",{className:"ml-auto font-mono text-text-muted",children:["EasySQL v","2.0.1"]})]}),D&&s.jsxs("div",{className:`fixed bottom-12 right-4 px-4 py-3 rounded-xl shadow-lg flex items-center gap-2 animate-slide-up z-50
|
||
${D.type==="success"?"bg-white text-success-600 border border-success-200":D.type==="error"?"bg-white text-danger-600 border border-danger-200":"bg-white text-primary-600 border border-primary-200"}`,children:[D.type==="success"&&s.jsx(yu,{size:16}),D.type==="error"&&s.jsx(Qu,{size:16}),D.type==="info"&&s.jsx(MS,{size:16}),s.jsx("span",{className:"text-sm",children:D.message})]}),s.jsx(qL,{isOpen:r,editingConnection:l,initialType:i,onClose:()=>{T(!1),a(null),o(void 0)},onSave:Ut}),s.jsx(e_,{isOpen:S,connectionId:R,onClose:()=>{N(!1),O(null)},onCreated:async()=>{R&&await ye(R)}}),s.jsx(E_,{isOpen:L,connectionId:H?.connectionId||null,database:H?.database||null,onClose:()=>{_(!1),c(null)},onCreated:async()=>{H&&await se(H.connectionId,H.database)}}),A&&C&&s.jsx(o_,{isOpen:A,mode:C.mode,database:C.database,tableName:C.tableName,connectionId:C.connectionId,dbType:ne.find(f=>f.id===C.connectionId)?.type||"mysql",onClose:()=>{I(!1),M(null)},onSave:async f=>{try{return await Le.executeQuery(C.connectionId,f),await se(C.connectionId,C.database),Y("success",C.mode==="create"?"表创建成功":"表结构已更新"),{success:!0,message:""}}catch(d){return{success:!1,message:d.message||"操作失败"}}},onGetTableInfo:C.mode==="edit"?async()=>({columns:(await Le.getTableColumns(C.connectionId,C.database,C.tableName)).map((d,v)=>({id:`col-${v}`,name:d.name,type:d.type.split("(")[0].toUpperCase(),length:d.type.match(/\((\d+)/)?.[1]||"",decimals:d.type.match(/,(\d+)\)/)?.[1]||"",nullable:d.nullable,primaryKey:d.key==="PRI",autoIncrement:d.extra?.includes("auto_increment")||!1,unsigned:d.type.includes("unsigned"),zerofill:d.type.includes("zerofill"),defaultValue:d.default||"",comment:d.comment||"",isVirtual:!1,virtualExpression:""})),indexes:[],foreignKeys:[],options:{engine:"InnoDB",charset:"utf8mb4",collation:"utf8mb4_general_ci",comment:"",autoIncrement:"",rowFormat:""}}):void 0,onGetDatabases:async()=>b.get(C.connectionId)||[],onGetTables:async f=>{const d=me.get(f);if(d&&d.length>0)return d.map(v=>v.name);try{const v=await Le.getTables(C.connectionId,f);return De(h=>new Map(h).set(f,v)),v.map(h=>h.name||h)}catch(v){return console.error("Failed to load tables:",v),[]}},onGetColumns:async(f,d)=>(await Le.getTableColumns(C.connectionId,f,d)).map(h=>h.name)}),p&&s.jsx(u_,{isOpen:p.isOpen,title:p.title,label:p.label,defaultValue:p.defaultValue,onClose:()=>P(null),onConfirm:p.onConfirm})]})}fl.createRoot(document.getElementById("root")).render(s.jsx(IN.StrictMode,{children:s.jsx(f_,{})}));export{IN as W,TO as _,s as j,u as r};
|