const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["./SqlEditor-BZP69oik.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 s of r)if(s.type==="childList")for(const l of s.addedNodes)l.tagName==="LINK"&&l.rel==="modulepreload"&&n(l)}).observe(document,{childList:!0,subtree:!0});function E(r){const s={};return r.integrity&&(s.integrity=r.integrity),r.referrerPolicy&&(s.referrerPolicy=r.referrerPolicy),r.crossOrigin==="use-credentials"?s.credentials="include":r.crossOrigin==="anonymous"?s.credentials="omit":s.credentials="same-origin",s}function n(r){if(r.ep)return;r.ep=!0;const s=E(r);fetch(r.href,s)}})();var yS=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function QR(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var ZR={exports:{}},Vs={},qR={exports:{}},Ne={};/** * @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 Ur=Symbol.for("react.element"),GS=Symbol.for("react.portal"),gS=Symbol.for("react.fragment"),HS=Symbol.for("react.strict_mode"),vS=Symbol.for("react.profiler"),BS=Symbol.for("react.provider"),FS=Symbol.for("react.context"),YS=Symbol.for("react.forward_ref"),wS=Symbol.for("react.suspense"),VS=Symbol.for("react.memo"),bS=Symbol.for("react.lazy"),ta=Symbol.iterator;function WS(e){return e===null||typeof e!="object"?null:(e=ta&&e[ta]||e["@@iterator"],typeof e=="function"?e:null)}var ei={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},ti=Object.assign,Ei={};function Gn(e,t,E){this.props=e,this.context=t,this.refs=Ei,this.updater=E||ei}Gn.prototype.isReactComponent={};Gn.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")};Gn.prototype.forceUpdate=function(e){this.updater.enqueueForceUpdate(this,e,"forceUpdate")};function ni(){}ni.prototype=Gn.prototype;function Eo(e,t,E){this.props=e,this.context=t,this.refs=Ei,this.updater=E||ei}var no=Eo.prototype=new ni;no.constructor=Eo;ti(no,Gn.prototype);no.isPureReactComponent=!0;var Ea=Array.isArray,ri=Object.prototype.hasOwnProperty,ro={current:null},si={key:!0,ref:!0,__self:!0,__source:!0};function Ti(e,t,E){var n,r={},s=null,l=null;if(t!=null)for(n in t.ref!==void 0&&(l=t.ref),t.key!==void 0&&(s=""+t.key),t)ri.call(t,n)&&!si.hasOwnProperty(n)&&(r[n]=t[n]);var o=arguments.length-2;if(o===1)r.children=E;else if(1>>1,Re=X[Ee];if(0>>1;Eer(Me,te))Ver(be,Me)?(X[Ee]=be,X[Ve]=te,Ee=Ve):(X[Ee]=Me,X[Ye]=te,Ee=Ye);else if(Ver(be,te))X[Ee]=be,X[Ve]=te,Ee=Ve;else break e}}return ee}function r(X,ee){var te=X.sortIndex-ee.sortIndex;return te!==0?te:X.id-ee.id}if(typeof performance=="object"&&typeof performance.now=="function"){var s=performance;e.unstable_now=function(){return s.now()}}else{var l=Date,o=l.now();e.unstable_now=function(){return l.now()-o}}var a=[],R=[],A=1,N=null,i=3,O=!1,C=!1,u=!1,D=typeof setTimeout=="function"?setTimeout:null,I=typeof clearTimeout=="function"?clearTimeout:null,S=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function c(X){for(var ee=E(R);ee!==null;){if(ee.callback===null)n(R);else if(ee.startTime<=X)n(R),ee.sortIndex=ee.expirationTime,t(a,ee);else break;ee=E(R)}}function L(X){if(u=!1,c(X),!C)if(E(a)!==null)C=!0,me(B);else{var ee=E(R);ee!==null&&le(L,ee.startTime-X)}}function B(X,ee){C=!1,u&&(u=!1,I(y),y=-1),O=!0;var te=i;try{for(c(ee),N=E(a);N!==null&&(!(N.expirationTime>ee)||X&&!oe());){var Ee=N.callback;if(typeof Ee=="function"){N.callback=null,i=N.priorityLevel;var Re=Ee(N.expirationTime<=ee);ee=e.unstable_now(),typeof Re=="function"?N.callback=Re:N===E(a)&&n(a),c(ee)}else n(a);N=E(a)}if(N!==null)var Fe=!0;else{var Ye=E(R);Ye!==null&&le(L,Ye.startTime-ee),Fe=!1}return Fe}finally{N=null,i=te,O=!1}}var p=!1,P=null,y=-1,Y=5,K=-1;function oe(){return!(e.unstable_now()-KX||125Ee?(X.sortIndex=te,t(R,X),E(a)===null&&X===E(R)&&(u?(I(y),y=-1):u=!0,le(L,te-Ee))):(X.sortIndex=Re,t(a,X),C||O||(C=!0,me(B))),X},e.unstable_shouldYield=oe,e.unstable_wrapCallback=function(X){var ee=i;return function(){var te=i;i=ee;try{return X.apply(this,arguments)}finally{i=te}}}})(ii);Ri.exports=ii;var tN=Ri.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 EN=f,pt=tN;function V(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,E=1;E"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),ol=Object.prototype.hasOwnProperty,nN=/^[: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]*$/,ra={},sa={};function rN(e){return ol.call(sa,e)?!0:ol.call(ra,e)?!1:nN.test(e)?sa[e]=!0:(ra[e]=!0,!1)}function sN(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 TN(e,t,E,n){if(t===null||typeof t>"u"||sN(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 At(e,t,E,n,r,s,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=s,this.removeEmptyString=l}var tt={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){tt[e]=new At(e,0,!1,e,null,!1,!1)});[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];tt[t]=new At(t,1,!1,e[1],null,!1,!1)});["contentEditable","draggable","spellCheck","value"].forEach(function(e){tt[e]=new At(e,2,!1,e.toLowerCase(),null,!1,!1)});["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){tt[e]=new At(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){tt[e]=new At(e,3,!1,e.toLowerCase(),null,!1,!1)});["checked","multiple","muted","selected"].forEach(function(e){tt[e]=new At(e,3,!0,e,null,!1,!1)});["capture","download"].forEach(function(e){tt[e]=new At(e,4,!1,e,null,!1,!1)});["cols","rows","size","span"].forEach(function(e){tt[e]=new At(e,6,!1,e,null,!1,!1)});["rowSpan","start"].forEach(function(e){tt[e]=new At(e,5,!1,e.toLowerCase(),null,!1,!1)});var To=/[\-:]([a-z])/g;function lo(e){return e[1].toUpperCase()}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(e){var t=e.replace(To,lo);tt[t]=new At(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(To,lo);tt[t]=new At(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(To,lo);tt[t]=new At(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)});["tabIndex","crossOrigin"].forEach(function(e){tt[e]=new At(e,1,!1,e.toLowerCase(),null,!1,!1)});tt.xlinkHref=new At("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1);["src","href","action","formAction"].forEach(function(e){tt[e]=new At(e,1,!1,e.toLowerCase(),null,!0,!0)});function oo(e,t,E,n){var r=tt.hasOwnProperty(t)?tt[t]:null;(r!==null?r.type!==0:n||!(2o||r[l]!==s[o]){var a=` `+r[l].replace(" at new "," at ");return e.displayName&&a.includes("")&&(a=a.replace("",e.displayName)),a}while(1<=l&&0<=o);break}}}finally{iT=!1,Error.prepareStackTrace=E}return(e=e?e.displayName||e.name:"")?Qn(e):""}function lN(e){switch(e.tag){case 5:return Qn(e.type);case 16:return Qn("Lazy");case 13:return Qn("Suspense");case 19:return Qn("SuspenseList");case 0:case 2:case 15:return e=AT(e.type,!1),e;case 11:return e=AT(e.type.render,!1),e;case 1:return e=AT(e.type,!0),e;default:return""}}function Al(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 Tn:return"Fragment";case sn:return"Portal";case al:return"Profiler";case ao:return"StrictMode";case Rl:return"Suspense";case il:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case Ni:return(e.displayName||"Context")+".Consumer";case Si:return(e._context.displayName||"Context")+".Provider";case Ro:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case io:return t=e.displayName||null,t!==null?t:Al(e.type)||"Memo";case uE:t=e._payload,e=e._init;try{return Al(e(t))}catch{}}return null}function oN(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 Al(t);case 8:return t===ao?"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 GE(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function Oi(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function aN(e){var t=Oi(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,s=E.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return r.call(this)},set:function(l){n=""+l,s.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 Br(e){e._valueTracker||(e._valueTracker=aN(e))}function ui(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var E=t.getValue(),n="";return e&&(n=Oi(e)?e.checked?"true":"false":e.value),e=n,e!==E?(t.setValue(e),!0):!1}function Ss(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 Sl(e,t){var E=t.checked;return Ge({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:E??e._wrapperState.initialChecked})}function la(e,t){var E=t.defaultValue==null?"":t.defaultValue,n=t.checked!=null?t.checked:t.defaultChecked;E=GE(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 ci(e,t){t=t.checked,t!=null&&oo(e,"checked",t,!1)}function Nl(e,t){ci(e,t);var E=GE(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")?Il(e,t.type,E):t.hasOwnProperty("defaultValue")&&Il(e,t.type,GE(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function oa(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 Il(e,t,E){(t!=="number"||Ss(e.ownerDocument)!==e)&&(E==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+E&&(e.defaultValue=""+E))}var Zn=Array.isArray;function cn(e,t,E,n){if(e=e.options,t){t={};for(var r=0;r"+t.valueOf().toString()+"",t=Fr.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function Ar(e,t){if(t){var E=e.firstChild;if(E&&E===e.lastChild&&E.nodeType===3){E.nodeValue=t;return}}e.textContent=t}var tr={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},RN=["Webkit","ms","Moz","O"];Object.keys(tr).forEach(function(e){RN.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),tr[t]=tr[e]})});function di(e,t,E){return t==null||typeof t=="boolean"||t===""?"":E||typeof t!="number"||t===0||tr.hasOwnProperty(e)&&tr[e]?(""+t).trim():t+"px"}function Di(e,t){e=e.style;for(var E in t)if(t.hasOwnProperty(E)){var n=E.indexOf("--")===0,r=di(E,t[E],n);E==="float"&&(E="cssFloat"),n?e.setProperty(E,r):e[E]=r}}var iN=Ge({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 cl(e,t){if(t){if(iN[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(V(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(V(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(V(61))}if(t.style!=null&&typeof t.style!="object")throw Error(V(62))}}function Cl(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 Ll=null;function Ao(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var _l=null,Cn=null,Ln=null;function ia(e){if(e=yr(e)){if(typeof _l!="function")throw Error(V(280));var t=e.stateNode;t&&(t=$s(t),_l(e.stateNode,e.type,t))}}function Pi(e){Cn?Ln?Ln.push(e):Ln=[e]:Cn=e}function pi(){if(Cn){var e=Cn,t=Ln;if(Ln=Cn=null,ia(e),t)for(e=0;e>>=0,e===0?32:31-(dN(e)/DN|0)|0}var Yr=64,wr=4194304;function qn(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 us(e,t){var E=e.pendingLanes;if(E===0)return 0;var n=0,r=e.suspendedLanes,s=e.pingedLanes,l=E&268435455;if(l!==0){var o=l&~r;o!==0?n=qn(o):(s&=l,s!==0&&(n=qn(s)))}else l=E&~r,l!==0?n=qn(l):s!==0&&(n=qn(s));if(n===0)return 0;if(t!==0&&t!==n&&!(t&r)&&(r=n&-n,s=t&-t,r>=s||r===16&&(s&4194240)!==0))return t;if(n&4&&(n|=E&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=n;0E;E++)t.push(e);return t}function hr(e,t,E){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-wt(t),e[t]=E}function mN(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=nr),La=" ",_a=!1;function Ki(e,t){switch(e){case"keyup":return tI.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function $i(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var ln=!1;function nI(e,t){switch(e){case"compositionend":return $i(t);case"keypress":return t.which!==32?null:(_a=!0,La);case"textInput":return e=t.data,e===La&&_a?null:e;default:return null}}function rI(e,t){if(ln)return e==="compositionend"||!Lo&&Ki(e,t)?(e=Wi(),ts=uo=dE=null,ln=!1,e):null;switch(e){case"paste":return null;case"keypress":if(!(t.ctrlKey||t.altKey||t.metaKey)||t.ctrlKey&&t.altKey){if(t.char&&1=t)return{node:E,offset:t-e};e=n}e:{for(;E;){if(E.nextSibling){E=E.nextSibling;break e}E=E.parentNode}E=void 0}E=pa(E)}}function zi(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?zi(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function Qi(){for(var e=window,t=Ss();t instanceof e.HTMLIFrameElement;){try{var E=typeof t.contentWindow.location.href=="string"}catch{E=!1}if(E)e=t.contentWindow;else break;t=Ss(e.document)}return t}function _o(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 SI(e){var t=Qi(),E=e.focusedElem,n=e.selectionRange;if(t!==E&&E&&E.ownerDocument&&zi(E.ownerDocument.documentElement,E)){if(n!==null&&_o(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,s=Math.min(n.start,r);n=n.end===void 0?s:Math.min(n.end,r),!e.extend&&s>n&&(r=n,n=s,s=r),r=fa(E,s);var l=fa(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(),s>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=document.documentMode,on=null,ml=null,sr=null,Ml=!1;function ma(e,t,E){var n=E.window===E?E.document:E.nodeType===9?E:E.ownerDocument;Ml||on==null||on!==Ss(n)||(n=on,"selectionStart"in n&&_o(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}),sr&&cr(sr,n)||(sr=n,n=Ls(ml,"onSelect"),0An||(e.current=gl[An],gl[An]=null,An--)}function Pe(e,t){An++,gl[An]=e.current,e.current=t}var gE={},Tt=vE(gE),ut=vE(!1),$E=gE;function pn(e,t){var E=e.type.contextTypes;if(!E)return gE;var n=e.stateNode;if(n&&n.__reactInternalMemoizedUnmaskedChildContext===t)return n.__reactInternalMemoizedMaskedChildContext;var r={},s;for(s in E)r[s]=t[s];return n&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=r),r}function ct(e){return e=e.childContextTypes,e!=null}function ds(){fe(ut),fe(Tt)}function ga(e,t,E){if(Tt.current!==gE)throw Error(V(168));Pe(Tt,t),Pe(ut,E)}function TA(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(V(108,oN(e)||"Unknown",r));return Ge({},E,n)}function Ds(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||gE,$E=Tt.current,Pe(Tt,e),Pe(ut,ut.current),!0}function Ha(e,t,E){var n=e.stateNode;if(!n)throw Error(V(169));E?(e=TA(e,t,$E),n.__reactInternalMemoizedMergedChildContext=e,fe(ut),fe(Tt),Pe(Tt,e)):fe(ut),Pe(ut,E)}var tE=null,js=!1,fT=!1;function lA(e){tE===null?tE=[e]:tE.push(e)}function pI(e){js=!0,lA(e)}function BE(){if(!fT&&tE!==null){fT=!0;var e=0,t=De;try{var E=tE;for(De=1;e>=l,r-=l,EE=1<<32-wt(t)+r|E<y?(Y=P,P=null):Y=P.sibling;var K=i(I,P,c[y],L);if(K===null){P===null&&(P=Y);break}e&&P&&K.alternate===null&&t(I,P),S=s(K,S,y),p===null?B=K:p.sibling=K,p=K,P=Y}if(y===c.length)return E(I,P),Ue&&YE(I,y),B;if(P===null){for(;yy?(Y=P,P=null):Y=P.sibling;var oe=i(I,P,K.value,L);if(oe===null){P===null&&(P=Y);break}e&&P&&oe.alternate===null&&t(I,P),S=s(oe,S,y),p===null?B=oe:p.sibling=oe,p=oe,P=Y}if(K.done)return E(I,P),Ue&&YE(I,y),B;if(P===null){for(;!K.done;y++,K=c.next())K=N(I,K.value,L),K!==null&&(S=s(K,S,y),p===null?B=K:p.sibling=K,p=K);return Ue&&YE(I,y),B}for(P=n(I,P);!K.done;y++,K=c.next())K=O(P,I,y,K.value,L),K!==null&&(e&&K.alternate!==null&&P.delete(K.key===null?y:K.key),S=s(K,S,y),p===null?B=K:p.sibling=K,p=K);return e&&P.forEach(function(_e){return t(I,_e)}),Ue&&YE(I,y),B}function D(I,S,c,L){if(typeof c=="object"&&c!==null&&c.type===Tn&&c.key===null&&(c=c.props.children),typeof c=="object"&&c!==null){switch(c.$$typeof){case vr:e:{for(var B=c.key,p=S;p!==null;){if(p.key===B){if(B=c.type,B===Tn){if(p.tag===7){E(I,p.sibling),S=r(p,c.props.children),S.return=I,I=S;break e}}else if(p.elementType===B||typeof B=="object"&&B!==null&&B.$$typeof===uE&&Fa(B)===p.type){E(I,p.sibling),S=r(p,c.props),S.ref=$n(I,p,c),S.return=I,I=S;break e}E(I,p);break}else t(I,p);p=p.sibling}c.type===Tn?(S=KE(c.props.children,I.mode,L,c.key),S.return=I,I=S):(L=as(c.type,c.key,c.props,null,I.mode,L),L.ref=$n(I,S,c),L.return=I,I=L)}return l(I);case sn:e:{for(p=c.key;S!==null;){if(S.key===p)if(S.tag===4&&S.stateNode.containerInfo===c.containerInfo&&S.stateNode.implementation===c.implementation){E(I,S.sibling),S=r(S,c.children||[]),S.return=I,I=S;break e}else{E(I,S);break}else t(I,S);S=S.sibling}S=gT(c,I.mode,L),S.return=I,I=S}return l(I);case uE:return p=c._init,D(I,S,p(c._payload),L)}if(Zn(c))return C(I,S,c,L);if(Vn(c))return u(I,S,c,L);jr(I,c)}return typeof c=="string"&&c!==""||typeof c=="number"?(c=""+c,S!==null&&S.tag===6?(E(I,S.sibling),S=r(S,c),S.return=I,I=S):(E(I,S),S=GT(c,I.mode,L),S.return=I,I=S),l(I)):E(I,S)}return D}var mn=iA(!0),AA=iA(!1),fs=vE(null),ms=null,In=null,fo=null;function mo(){fo=In=ms=null}function Mo(e){var t=fs.current;fe(fs),e._currentValue=t}function Bl(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 dn(e,t){ms=e,fo=In=null,e=e.dependencies,e!==null&&e.firstContext!==null&&(e.lanes&t&&(Ot=!0),e.firstContext=null)}function gt(e){var t=e._currentValue;if(fo!==e)if(e={context:e,memoizedValue:t,next:null},In===null){if(ms===null)throw Error(V(308));In=e,ms.dependencies={lanes:0,firstContext:e}}else In=In.next=e;return t}var bE=null;function Uo(e){bE===null?bE=[e]:bE.push(e)}function SA(e,t,E,n){var r=t.interleaved;return r===null?(E.next=E,Uo(t)):(E.next=r.next,r.next=E),t.interleaved=E,lE(e,n)}function lE(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 cE=!1;function ho(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function NA(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 rE(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function ME(e,t,E){var n=e.updateQueue;if(n===null)return null;if(n=n.shared,ce&2){var r=n.pending;return r===null?t.next=t:(t.next=r.next,r.next=t),n.pending=t,lE(e,E)}return r=n.interleaved,r===null?(t.next=t,Uo(n)):(t.next=r.next,r.next=t),n.interleaved=t,lE(e,E)}function ns(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,No(e,E)}}function Ya(e,t){var E=e.updateQueue,n=e.alternate;if(n!==null&&(n=n.updateQueue,E===n)){var r=null,s=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};s===null?r=s=l:s=s.next=l,E=E.next}while(E!==null);s===null?r=s=t:s=s.next=t}else r=s=t;E={baseState:n.baseState,firstBaseUpdate:r,lastBaseUpdate:s,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 Ms(e,t,E,n){var r=e.updateQueue;cE=!1;var s=r.firstBaseUpdate,l=r.lastBaseUpdate,o=r.shared.pending;if(o!==null){r.shared.pending=null;var a=o,R=a.next;a.next=null,l===null?s=R:l.next=R,l=a;var A=e.alternate;A!==null&&(A=A.updateQueue,o=A.lastBaseUpdate,o!==l&&(o===null?A.firstBaseUpdate=R:o.next=R,A.lastBaseUpdate=a))}if(s!==null){var N=r.baseState;l=0,A=R=a=null,o=s;do{var i=o.lane,O=o.eventTime;if((n&i)===i){A!==null&&(A=A.next={eventTime:O,lane:0,tag:o.tag,payload:o.payload,callback:o.callback,next:null});e:{var C=e,u=o;switch(i=t,O=E,u.tag){case 1:if(C=u.payload,typeof C=="function"){N=C.call(O,N,i);break e}N=C;break e;case 3:C.flags=C.flags&-65537|128;case 0:if(C=u.payload,i=typeof C=="function"?C.call(O,N,i):C,i==null)break e;N=Ge({},N,i);break e;case 2:cE=!0}}o.callback!==null&&o.lane!==0&&(e.flags|=64,i=r.effects,i===null?r.effects=[o]:i.push(o))}else O={eventTime:O,lane:i,tag:o.tag,payload:o.payload,callback:o.callback,next:null},A===null?(R=A=O,a=N):A=A.next=O,l|=i;if(o=o.next,o===null){if(o=r.shared.pending,o===null)break;i=o,o=i.next,i.next=null,r.lastBaseUpdate=i,r.shared.pending=null}}while(!0);if(A===null&&(a=N),r.baseState=a,r.firstBaseUpdate=R,r.lastBaseUpdate=A,t=r.shared.interleaved,t!==null){r=t;do l|=r.lane,r=r.next;while(r!==t)}else s===null&&(r.shared.lanes=0);JE|=l,e.lanes=l,e.memoizedState=N}}function wa(e,t,E){if(e=t.effects,t.effects=null,e!==null)for(t=0;tE?E:4,e(!0);var n=MT.transition;MT.transition={};try{e(!1),t()}finally{De=E,MT.transition=n}}function xA(){return Ht().memoizedState}function UI(e,t,E){var n=hE(e);if(E={lane:n,action:E,hasEagerState:!1,eagerState:null,next:null},yA(e))GA(t,E);else if(E=SA(e,t,E,n),E!==null){var r=Rt();Vt(E,e,n,r),gA(E,t,n)}}function hI(e,t,E){var n=hE(e),r={lane:n,action:E,hasEagerState:!1,eagerState:null,next:null};if(yA(e))GA(t,r);else{var s=e.alternate;if(e.lanes===0&&(s===null||s.lanes===0)&&(s=t.lastRenderedReducer,s!==null))try{var l=t.lastRenderedState,o=s(l,E);if(r.hasEagerState=!0,r.eagerState=o,Wt(o,l)){var a=t.interleaved;a===null?(r.next=r,Uo(t)):(r.next=a.next,a.next=r),t.interleaved=r;return}}catch{}finally{}E=SA(e,t,r,n),E!==null&&(r=Rt(),Vt(E,e,n,r),gA(E,t,n))}}function yA(e){var t=e.alternate;return e===ye||t!==null&&t===ye}function GA(e,t){Tr=hs=!0;var E=e.pending;E===null?t.next=t:(t.next=E.next,E.next=t),e.pending=t}function gA(e,t,E){if(E&4194240){var n=t.lanes;n&=e.pendingLanes,E|=n,t.lanes=E,No(e,E)}}var xs={readContext:gt,useCallback:nt,useContext:nt,useEffect:nt,useImperativeHandle:nt,useInsertionEffect:nt,useLayoutEffect:nt,useMemo:nt,useReducer:nt,useRef:nt,useState:nt,useDebugValue:nt,useDeferredValue:nt,useTransition:nt,useMutableSource:nt,useSyncExternalStore:nt,useId:nt,unstable_isNewReconciler:!1},xI={readContext:gt,useCallback:function(e,t){return Kt().memoizedState=[e,t===void 0?null:t],e},useContext:gt,useEffect:ba,useImperativeHandle:function(e,t,E){return E=E!=null?E.concat([e]):null,ss(4194308,4,fA.bind(null,t,e),E)},useLayoutEffect:function(e,t){return ss(4194308,4,e,t)},useInsertionEffect:function(e,t){return ss(4,2,e,t)},useMemo:function(e,t){var E=Kt();return t=t===void 0?null:t,e=e(),E.memoizedState=[e,t],e},useReducer:function(e,t,E){var n=Kt();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=UI.bind(null,ye,e),[n.memoizedState,e]},useRef:function(e){var t=Kt();return e={current:e},t.memoizedState=e},useState:Va,useDebugValue:Fo,useDeferredValue:function(e){return Kt().memoizedState=e},useTransition:function(){var e=Va(!1),t=e[0];return e=MI.bind(null,e[1]),Kt().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,E){var n=ye,r=Kt();if(Ue){if(E===void 0)throw Error(V(407));E=E()}else{if(E=t(),Je===null)throw Error(V(349));kE&30||cA(n,t,E)}r.memoizedState=E;var s={value:E,getSnapshot:t};return r.queue=s,ba(LA.bind(null,n,s,e),[e]),n.flags|=2048,fr(9,CA.bind(null,n,s,E,t),void 0,null),E},useId:function(){var e=Kt(),t=Je.identifierPrefix;if(Ue){var E=nE,n=EE;E=(n&~(1<<32-wt(n)-1)).toString(32)+E,t=":"+t+"R"+E,E=Pr++,0<\/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[$t]=t,e[_r]=n,XA(e,t,!1,!1),t.stateNode=e;e:{switch(l=Cl(E,n),E){case"dialog":pe("cancel",e),pe("close",e),r=n;break;case"iframe":case"object":case"embed":pe("load",e),r=n;break;case"video":case"audio":for(r=0;rhn&&(t.flags|=128,n=!0,jn(s,!1),t.lanes=4194304)}else{if(!n)if(e=Us(l),e!==null){if(t.flags|=128,n=!0,E=e.updateQueue,E!==null&&(t.updateQueue=E,t.flags|=4),jn(s,!0),s.tail===null&&s.tailMode==="hidden"&&!l.alternate&&!Ue)return rt(t),null}else 2*Be()-s.renderingStartTime>hn&&E!==1073741824&&(t.flags|=128,n=!0,jn(s,!1),t.lanes=4194304);s.isBackwards?(l.sibling=t.child,t.child=l):(E=s.last,E!==null?E.sibling=l:t.child=l,s.last=l)}return s.tail!==null?(t=s.tail,s.rendering=t,s.tail=t.sibling,s.renderingStartTime=Be(),t.sibling=null,E=xe.current,Pe(xe,n?E&1|2:E&1),t):(rt(t),null);case 22:case 23:return Xo(),n=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==n&&(t.flags|=8192),n&&t.mode&1?dt&1073741824&&(rt(t),t.subtreeFlags&6&&(t.flags|=8192)):rt(t),null;case 24:return null;case 25:return null}throw Error(V(156,t.tag))}function YI(e,t){switch(Po(t),t.tag){case 1:return ct(t.type)&&ds(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return Mn(),fe(ut),fe(Tt),Go(),e=t.flags,e&65536&&!(e&128)?(t.flags=e&-65537|128,t):null;case 5:return yo(t),null;case 13:if(fe(xe),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(V(340));fn()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return fe(xe),null;case 4:return Mn(),null;case 10:return Mo(t.type._context),null;case 22:case 23:return Xo(),null;case 24:return null;default:return null}}var Jr=!1,st=!1,wI=typeof WeakSet=="function"?WeakSet:Set,k=null;function On(e,t){var E=e.ref;if(E!==null)if(typeof E=="function")try{E(null)}catch(n){ge(e,t,n)}else E.current=null}function $l(e,t,E){try{E()}catch(n){ge(e,t,n)}}var qa=!1;function VI(e,t){if(Ul=cs,e=Qi(),_o(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,s=n.focusNode;n=n.focusOffset;try{E.nodeType,s.nodeType}catch{E=null;break e}var l=0,o=-1,a=-1,R=0,A=0,N=e,i=null;t:for(;;){for(var O;N!==E||r!==0&&N.nodeType!==3||(o=l+r),N!==s||n!==0&&N.nodeType!==3||(a=l+n),N.nodeType===3&&(l+=N.nodeValue.length),(O=N.firstChild)!==null;)i=N,N=O;for(;;){if(N===e)break t;if(i===E&&++R===r&&(o=l),i===s&&++A===n&&(a=l),(O=N.nextSibling)!==null)break;N=i,i=N.parentNode}N=O}E=o===-1||a===-1?null:{start:o,end:a}}else E=null}E=E||{start:0,end:0}}else E=null;for(hl={focusedElem:e,selectionRange:E},cs=!1,k=t;k!==null;)if(t=k,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,k=e;else for(;k!==null;){t=k;try{var C=t.alternate;if(t.flags&1024)switch(t.tag){case 0:case 11:case 15:break;case 1:if(C!==null){var u=C.memoizedProps,D=C.memoizedState,I=t.stateNode,S=I.getSnapshotBeforeUpdate(t.elementType===t.type?u:Bt(t.type,u),D);I.__reactInternalSnapshotBeforeUpdate=S}break;case 3:var c=t.stateNode.containerInfo;c.nodeType===1?c.textContent="":c.nodeType===9&&c.documentElement&&c.removeChild(c.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(V(163))}}catch(L){ge(t,t.return,L)}if(e=t.sibling,e!==null){e.return=t.return,k=e;break}k=t.return}return C=qa,qa=!1,C}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 s=r.destroy;r.destroy=void 0,s!==void 0&&$l(t,E,s)}r=r.next}while(r!==n)}}function zs(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 jl(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 jA(e){var t=e.alternate;t!==null&&(e.alternate=null,jA(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[$t],delete t[_r],delete t[Gl],delete t[DI],delete t[PI])),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 kA(e){return e.tag===5||e.tag===3||e.tag===4}function eR(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||kA(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 kl(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=_s));else if(n!==4&&(e=e.child,e!==null))for(kl(e,t,E),e=e.sibling;e!==null;)kl(e,t,E),e=e.sibling}function Jl(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(Jl(e,t,E),e=e.sibling;e!==null;)Jl(e,t,E),e=e.sibling}var qe=null,Ft=!1;function OE(e,t,E){for(E=E.child;E!==null;)JA(e,t,E),E=E.sibling}function JA(e,t,E){if(jt&&typeof jt.onCommitFiberUnmount=="function")try{jt.onCommitFiberUnmount(bs,E)}catch{}switch(E.tag){case 5:st||On(E,t);case 6:var n=qe,r=Ft;qe=null,OE(e,t,E),qe=n,Ft=r,qe!==null&&(Ft?(e=qe,E=E.stateNode,e.nodeType===8?e.parentNode.removeChild(E):e.removeChild(E)):qe.removeChild(E.stateNode));break;case 18:qe!==null&&(Ft?(e=qe,E=E.stateNode,e.nodeType===8?pT(e.parentNode,E):e.nodeType===1&&pT(e,E),Or(e)):pT(qe,E.stateNode));break;case 4:n=qe,r=Ft,qe=E.stateNode.containerInfo,Ft=!0,OE(e,t,E),qe=n,Ft=r;break;case 0:case 11:case 14:case 15:if(!st&&(n=E.updateQueue,n!==null&&(n=n.lastEffect,n!==null))){r=n=n.next;do{var s=r,l=s.destroy;s=s.tag,l!==void 0&&(s&2||s&4)&&$l(E,t,l),r=r.next}while(r!==n)}OE(e,t,E);break;case 1:if(!st&&(On(E,t),n=E.stateNode,typeof n.componentWillUnmount=="function"))try{n.props=E.memoizedProps,n.state=E.memoizedState,n.componentWillUnmount()}catch(o){ge(E,t,o)}OE(e,t,E);break;case 21:OE(e,t,E);break;case 22:E.mode&1?(st=(n=st)||E.memoizedState!==null,OE(e,t,E),st=n):OE(e,t,E);break;default:OE(e,t,E)}}function tR(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var E=e.stateNode;E===null&&(E=e.stateNode=new wI),t.forEach(function(n){var r=zI.bind(null,e,n);E.has(n)||(E.add(n),n.then(r,r))})}}function vt(e,t){var E=t.deletions;if(E!==null)for(var n=0;nr&&(r=l),n&=~s}if(n=r,n=Be()-n,n=(120>n?120:480>n?480:1080>n?1080:1920>n?1920:3e3>n?3e3:4320>n?4320:1960*WI(n/1960))-n,10e?16:e,DE===null)var n=!1;else{if(e=DE,DE=null,gs=0,ce&6)throw Error(V(331));var r=ce;for(ce|=4,k=e.current;k!==null;){var s=k,l=s.child;if(k.flags&16){var o=s.deletions;if(o!==null){for(var a=0;aBe()-bo?XE(e,0):Vo|=E),Ct(e,t)}function nS(e,t){t===0&&(e.mode&1?(t=wr,wr<<=1,!(wr&130023424)&&(wr=4194304)):t=1);var E=Rt();e=lE(e,t),e!==null&&(hr(e,t,E),Ct(e,E))}function JI(e){var t=e.memoizedState,E=0;t!==null&&(E=t.retryLane),nS(e,E)}function zI(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(V(314))}n!==null&&n.delete(t),nS(e,E)}var rS;rS=function(e,t,E){if(e!==null)if(e.memoizedProps!==t.pendingProps||ut.current)Ot=!0;else{if(!(e.lanes&E)&&!(t.flags&128))return Ot=!1,BI(e,t,E);Ot=!!(e.flags&131072)}else Ot=!1,Ue&&t.flags&1048576&&oA(t,ps,t.index);switch(t.lanes=0,t.tag){case 2:var n=t.type;Ts(e,t),e=t.pendingProps;var r=pn(t,Tt.current);dn(t,E),r=Ho(null,t,n,e,r,E);var s=vo();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,ct(n)?(s=!0,Ds(t)):s=!1,t.memoizedState=r.state!==null&&r.state!==void 0?r.state:null,ho(t),r.updater=Js,t.stateNode=r,r._reactInternals=t,Yl(t,n,e,E),t=bl(null,t,n,!0,s,E)):(t.tag=0,Ue&&s&&Do(t),at(null,t,r,E),t=t.child),t;case 16:n=t.elementType;e:{switch(Ts(e,t),e=t.pendingProps,r=n._init,n=r(n._payload),t.type=n,r=t.tag=ZI(n),e=Bt(n,e),r){case 0:t=Vl(null,t,n,e,E);break e;case 1:t=za(null,t,n,e,E);break e;case 11:t=ka(null,t,n,e,E);break e;case 14:t=Ja(null,t,n,Bt(n.type,e),E);break e}throw Error(V(306,n,""))}return t;case 0:return n=t.type,r=t.pendingProps,r=t.elementType===n?r:Bt(n,r),Vl(e,t,n,r,E);case 1:return n=t.type,r=t.pendingProps,r=t.elementType===n?r:Bt(n,r),za(e,t,n,r,E);case 3:e:{if(VA(t),e===null)throw Error(V(387));n=t.pendingProps,s=t.memoizedState,r=s.element,NA(e,t),Ms(t,n,null,E);var l=t.memoizedState;if(n=l.element,s.isDehydrated)if(s={element:n,isDehydrated:!1,cache:l.cache,pendingSuspenseBoundaries:l.pendingSuspenseBoundaries,transitions:l.transitions},t.updateQueue.baseState=s,t.memoizedState=s,t.flags&256){r=Un(Error(V(423)),t),t=Qa(e,t,n,E,r);break e}else if(n!==r){r=Un(Error(V(424)),t),t=Qa(e,t,n,E,r);break e}else for(Dt=mE(t.stateNode.containerInfo.firstChild),Pt=t,Ue=!0,Yt=null,E=AA(t,null,n,E),t.child=E;E;)E.flags=E.flags&-3|4096,E=E.sibling;else{if(fn(),n===r){t=oE(e,t,E);break e}at(e,t,n,E)}t=t.child}return t;case 5:return IA(t),e===null&&vl(t),n=t.type,r=t.pendingProps,s=e!==null?e.memoizedProps:null,l=r.children,xl(n,r)?l=null:s!==null&&xl(n,s)&&(t.flags|=32),wA(e,t),at(e,t,l,E),t.child;case 6:return e===null&&vl(t),null;case 13:return bA(e,t,E);case 4:return xo(t,t.stateNode.containerInfo),n=t.pendingProps,e===null?t.child=mn(t,null,n,E):at(e,t,n,E),t.child;case 11:return n=t.type,r=t.pendingProps,r=t.elementType===n?r:Bt(n,r),ka(e,t,n,r,E);case 7:return at(e,t,t.pendingProps,E),t.child;case 8:return at(e,t,t.pendingProps.children,E),t.child;case 12:return at(e,t,t.pendingProps.children,E),t.child;case 10:e:{if(n=t.type._context,r=t.pendingProps,s=t.memoizedProps,l=r.value,Pe(fs,n._currentValue),n._currentValue=l,s!==null)if(Wt(s.value,l)){if(s.children===r.children&&!ut.current){t=oE(e,t,E);break e}}else for(s=t.child,s!==null&&(s.return=t);s!==null;){var o=s.dependencies;if(o!==null){l=s.child;for(var a=o.firstContext;a!==null;){if(a.context===n){if(s.tag===1){a=rE(-1,E&-E),a.tag=2;var R=s.updateQueue;if(R!==null){R=R.shared;var A=R.pending;A===null?a.next=a:(a.next=A.next,A.next=a),R.pending=a}}s.lanes|=E,a=s.alternate,a!==null&&(a.lanes|=E),Bl(s.return,E,t),o.lanes|=E;break}a=a.next}}else if(s.tag===10)l=s.type===t.type?null:s.child;else if(s.tag===18){if(l=s.return,l===null)throw Error(V(341));l.lanes|=E,o=l.alternate,o!==null&&(o.lanes|=E),Bl(l,E,t),l=s.sibling}else l=s.child;if(l!==null)l.return=s;else for(l=s;l!==null;){if(l===t){l=null;break}if(s=l.sibling,s!==null){s.return=l.return,l=s;break}l=l.return}s=l}at(e,t,r.children,E),t=t.child}return t;case 9:return r=t.type,n=t.pendingProps.children,dn(t,E),r=gt(r),n=n(r),t.flags|=1,at(e,t,n,E),t.child;case 14:return n=t.type,r=Bt(n,t.pendingProps),r=Bt(n.type,r),Ja(e,t,n,r,E);case 15:return FA(e,t,t.type,t.pendingProps,E);case 17:return n=t.type,r=t.pendingProps,r=t.elementType===n?r:Bt(n,r),Ts(e,t),t.tag=1,ct(n)?(e=!0,Ds(t)):e=!1,dn(t,E),HA(t,n,r),Yl(t,n,r,E),bl(null,t,n,!0,e,E);case 19:return WA(e,t,E);case 22:return YA(e,t,E)}throw Error(V(156,t.tag))};function sS(e,t){return yi(e,t)}function QI(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 yt(e,t,E,n){return new QI(e,t,E,n)}function $o(e){return e=e.prototype,!(!e||!e.isReactComponent)}function ZI(e){if(typeof e=="function")return $o(e)?1:0;if(e!=null){if(e=e.$$typeof,e===Ro)return 11;if(e===io)return 14}return 2}function xE(e,t){var E=e.alternate;return E===null?(E=yt(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 as(e,t,E,n,r,s){var l=2;if(n=e,typeof e=="function")$o(e)&&(l=1);else if(typeof e=="string")l=5;else e:switch(e){case Tn:return KE(E.children,r,s,t);case ao:l=8,r|=8;break;case al:return e=yt(12,E,t,r|2),e.elementType=al,e.lanes=s,e;case Rl:return e=yt(13,E,t,r),e.elementType=Rl,e.lanes=s,e;case il:return e=yt(19,E,t,r),e.elementType=il,e.lanes=s,e;case Ii:return Zs(E,r,s,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case Si:l=10;break e;case Ni:l=9;break e;case Ro:l=11;break e;case io:l=14;break e;case uE:l=16,n=null;break e}throw Error(V(130,e==null?e:typeof e,""))}return t=yt(l,E,t,r),t.elementType=e,t.type=n,t.lanes=s,t}function KE(e,t,E,n){return e=yt(7,e,n,t),e.lanes=E,e}function Zs(e,t,E,n){return e=yt(22,e,n,t),e.elementType=Ii,e.lanes=E,e.stateNode={isHidden:!1},e}function GT(e,t,E){return e=yt(6,e,null,t),e.lanes=E,e}function gT(e,t,E){return t=yt(4,e.children!==null?e.children:[],e.key,t),t.lanes=E,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function qI(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=NT(0),this.expirationTimes=NT(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=NT(0),this.identifierPrefix=n,this.onRecoverableError=r,this.mutableSourceEagerHydrationData=null}function jo(e,t,E,n,r,s,l,o,a){return e=new qI(e,t,E,o,a),t===1?(t=1,s===!0&&(t|=8)):t=0,s=yt(3,null,null,t),e.current=s,s.stateNode=e,s.memoizedState={element:n,isDehydrated:E,cache:null,transitions:null,pendingSuspenseBoundaries:null},ho(s),e}function eO(e,t,E){var n=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(aS)}catch(e){console.error(e)}}aS(),ai.exports=ft;var sO=ai.exports,aR=sO;ll.createRoot=aR.createRoot,ll.hydrateRoot=aR.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 TO={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 lO=e=>e.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase().trim(),ae=(e,t)=>{const E=f.forwardRef(({color:n="currentColor",size:r=24,strokeWidth:s=2,absoluteStrokeWidth:l,className:o="",children:a,...R},A)=>f.createElement("svg",{ref:A,...TO,width:r,height:r,stroke:n,strokeWidth:l?Number(s)*24/Number(r):s,className:["lucide",`lucide-${lO(e)}`,o].join(" "),...R},[...t.map(([N,i])=>f.createElement(N,i)),...Array.isArray(a)?a:[a]]));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 oO=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 aO=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 RO=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 iO=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 Bs=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 RS=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 xn=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 AO=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 nT=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 vn=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 iS=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 SO=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 Fs=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 AS=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 RR=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 NO=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 Ys=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 iR=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 IO=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 OO=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 Qo=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 uO=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 cO=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 Mr=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 CO=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 SS=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 LO=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 _O=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 dO=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 AR=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 Bn=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 eo=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 DO=ae("RotateCcw",[["path",{d:"M3 12a9 9 0 1 0 9-9 9.75 9.75 0 0 0-6.74 2.74L3 8",key:"1357e3"}],["path",{d:"M3 3v5h5",key:"1xhq8a"}]]);/** * @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 Zo=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 NS=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 IS=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 PO=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 OS=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 Fn=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 yE=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 pO=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 fO=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 RE=ae("X",[["path",{d:"M18 6 6 18",key:"1bl5f8"}],["path",{d:"m6 6 12 12",key:"d8bk6v"}]]),Se=()=>typeof window<"u"&&window.electronAPI?window.electronAPI:null,se={minimize:async()=>{const e=Se();e&&await e.minimize()},maximize:async()=>{const e=Se();e&&await e.maximize()},close:async()=>{const e=Se();e&&await e.close()},testConnection:async e=>{const t=Se();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=Se();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=Se();if(t)try{await t.disconnect(e)}catch(E){console.error("Disconnect error:",E)}},query:async(e,t)=>{const E=Se();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=Se();if(!t)return[];try{return await t.getDatabases(e)}catch(E){return console.error("getDatabases error:",E),[]}},getTables:async(e,t)=>{const E=Se();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=Se();if(!n)return[];try{return await n.getColumns(e,t,E)}catch(r){return console.error("getColumns error:",r),[]}},getTableData:async(e,t,E,n,r)=>{const s=Se();if(!s)return{data:[],total:0};try{const l=await s.getTableData(e,t,E,n||1,r||100),o=l.columns||[];return{data:(l.rows||[]).map(R=>{const A={};return o.forEach((N,i)=>{A[N.name]=R[i]}),A}),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 s=Se();if(!s)return{success:!1,error:"Electron API 不可用"};try{const l=await s.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=Se();if(!r)return{success:!1,error:"Electron API 不可用"};try{const s=await r.deleteRow(e,t,E,n);return{success:s.success,error:s.success?void 0:s.message}}catch(s){return{success:!1,error:s.toString()}}},createDatabase:async(e,t,E="utf8mb4",n="utf8mb4_general_ci")=>{const r=Se();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.createDatabase(e,t,E,n)}catch(s){return{success:!1,message:s.toString()}}},dropDatabase:async(e,t)=>{const E=Se();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=Se();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.createTable(e,t,E,n)}catch(s){return{success:!1,message:s.toString()}}},dropTable:async(e,t,E)=>{const n=Se();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=Se();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=Se();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.renameTable(e,t,E,n)}catch(s){return{success:!1,message:s.toString()}}},duplicateTable:async(e,t,E,n,r=!1)=>{const s=Se();if(!s)return{success:!1,message:"Electron API 不可用"};try{return await s.duplicateTable(e,t,E,n,r)}catch(l){return{success:!1,message:l.toString()}}},addColumn:async(e,t,E,n)=>{const r=Se();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.addColumn(e,t,E,n)}catch(s){return{success:!1,message:s.toString()}}},modifyColumn:async(e,t,E,n,r)=>{const s=Se();if(!s)return{success:!1,message:"Electron API 不可用"};try{return await s.modifyColumn(e,t,E,n,r)}catch(l){return{success:!1,message:l.toString()}}},dropColumn:async(e,t,E,n)=>{const r=Se();if(!r)return{success:!1,message:"Electron API 不可用"};try{return await r.dropColumn(e,t,E,n)}catch(s){return{success:!1,message:s.toString()}}},getTableInfo:async(e,t,E)=>{const n=Se();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=Se();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=Se();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=Se();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=Se();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=Se();if(t)try{await t.saveConnections(e)}catch(E){console.error("saveConnections error:",E)}},loadConnections:async()=>{const e=Se();if(!e)return[];try{return await e.loadConnections()}catch(t){return console.error("loadConnections error:",t),[]}},exportConnections:async(e,t)=>{const E=Se();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):MO(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=Se();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=mO(E.content):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=Se();if(!e)return null;try{return await e.openFile()}catch(t){return{path:"",content:"",name:"",error:t.toString()}}},saveFile:async(e,t)=>{const E=Se();if(!E)return null;try{return await E.saveFile(e,t)}catch(n){return{path:"",name:"",error:n.toString()}}},selectFile:async e=>{const t=Se();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=Se();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 se.getTables(e,t);let s=`-- Database: ${t} -- Backup Time: ${new Date().toISOString()} `;for(const l of r){if(l.isView)continue;const o=await se.query(e,`SELECT * FROM \`${l.name}\``);if(o.rows&&o.rows.length>0){for(const a of o.rows){const R=a.map(A=>A===null?"NULL":typeof A=="string"?`'${A.replace(/'/g,"''")}'`:A).join(", ");s+=`INSERT INTO \`${l.name}\` VALUES (${R}); `}s+=` `}}return await E.writeFile(n,s),{success:!0,path:n}}catch(n){return{success:!1,error:n.toString()}}},exportTable:async(e,t,E,n)=>{const r=Se();if(!r)return{success:!1,error:"Electron API 不可用"};try{const s=n==="excel"?"xlsx":n,l=await r.saveDialog({filters:[{name:n.toUpperCase(),extensions:[s]}],defaultPath:`${E}.${s}`});if(!l)return{cancelled:!0};const o=await se.query(e,`SELECT * FROM \`${E}\``);let a;if(n==="csv"){const R=o.columns.join(","),A=o.rows.map(N=>N.map(i=>i===null?"":typeof i=="string"?`"${i.replace(/"/g,'""')}"`:i).join(",")).join(` `);a=`${R} ${A}`}else if(n==="sql")a=o.rows.map(R=>{const A=R.map(N=>N===null?"NULL":typeof N=="string"?`'${N.replace(/'/g,"''")}'`:N).join(", ");return`INSERT INTO \`${E}\` VALUES (${A});`}).join(` `);else{const R=o.columns.join(","),A=o.rows.map(N=>N.map(i=>i===null?"":typeof i=="string"?`"${i.replace(/"/g,'""')}"`:i).join(",")).join(` `);a=`${R} ${A}`}return await r.writeFile(l,a),{success:!0,path:l}}catch(s){return{success:!1,error:s.toString()}}}};function mO(e){const t=[],E=/]*\/>/g;let n;for(;(n=E.exec(e))!==null;){const r={},s=/(\w+)="([^"]*)"/g;let l;for(;(l=s.exec(n[0]))!==null;)r[l[1]]=l[2];r.ConnectionName&&t.push({id:crypto.randomUUID(),name:r.ConnectionName,type:(r.ConnType||"mysql").toLowerCase(),host:r.Host||"localhost",port:parseInt(r.Port)||3306,username:r.UserName||"",password:r.Password||"",database:r.Database||""})}return t}function MO(e){let t=` `;for(const E of e)t+=` `;return t+="",t}const UO=f.memo(function(){const[t,E]=f.useState(!1),n=async()=>{await se.maximize(),E(!t)};return T.jsxs("div",{className:"h-9 bg-metro-dark flex items-center justify-between drag select-none border-b border-metro-border/30 relative",children:[T.jsx("div",{className:"absolute inset-x-0 top-0 h-px bg-gradient-to-r from-transparent via-white/5 to-transparent"}),T.jsxs("div",{className:"flex items-center h-full px-4 no-drag gap-2.5",children:[T.jsxs("div",{className:"relative",children:[T.jsx(vn,{size:16,className:"text-accent-blue"}),T.jsx("div",{className:"absolute inset-0 bg-accent-blue/20 blur-md -z-10"})]}),T.jsx("span",{className:"text-sm font-semibold tracking-wide text-white/90",children:"EasySQL"}),T.jsx("span",{className:"text-[10px] text-white/30 font-medium ml-1",children:"v2.0"})]}),T.jsxs("div",{className:"flex h-full no-drag",children:[T.jsx("button",{onClick:()=>se.minimize(),className:"w-12 h-full flex items-center justify-center hover:bg-white/10 transition-colors duration-150 group",title:"最小化",children:T.jsx(CO,{size:16,className:"text-white/60 group-hover:text-white/90"})}),T.jsx("button",{onClick:n,className:"w-12 h-full flex items-center justify-center hover:bg-white/10 transition-colors duration-150 group",title:t?"还原":"最大化",children:t?T.jsx(nT,{size:11,className:"text-white/60 group-hover:text-white/90"}):T.jsx(OS,{size:11,className:"text-white/60 group-hover:text-white/90"})}),T.jsx("button",{onClick:()=>se.close(),className:"w-12 h-full flex items-center justify-center hover:bg-accent-red transition-colors duration-150 group",title:"关闭",children:T.jsx(RE,{size:16,className:"text-white/60 group-hover:text-white"})})]})]})}),_E={mysql:{name:"MySQL",icon:"🐬",color:"#00758f",port:3306,supported:!0},postgres:{name:"PostgreSQL",icon:"🐘",color:"#336791",port:5432,supported:!0},sqlite:{name:"SQLite",icon:"💾",color:"#003b57",port:0,supported:!0},mongodb:{name:"MongoDB",icon:"🍃",color:"#47a248",port:27017,supported:!0},redis:{name:"Redis",icon:"⚡",color:"#dc382d",port:6379,supported:!0},sqlserver:{name:"SQL Server",icon:"📊",color:"#cc2927",port:1433,supported:!0},oracle:{name:"Oracle",icon:"🔶",color:"#f80000",port:1521,supported:!1},mariadb:{name:"MariaDB",icon:"🦭",color:"#c0765a",port:3306,supported:!0},snowflake:{name:"Snowflake",icon:"❄️",color:"#29b5e8",port:443,supported:!1}},hO=f.memo(function({tables:t,db:E,connectionId:n,expandedDbs:r,setExpandedDbs:s,onOpenTable:l,onContextMenu:o}){const a=t.filter(u=>!u.isView),R=t.filter(u=>u.isView),A=`${E}_tables`,N=`${E}_views`,i=r.has(A),O=r.has(N),C=u=>{s(D=>{const I=new Set(D);return I.has(u)?I.delete(u):I.add(u),I})};return f.useEffect(()=>{a.length>0&&s(u=>new Set(u).add(A))},[a.length,A,s]),t.length===0?T.jsx("div",{className:"px-3 py-2 text-xs text-text-disabled",children:"无表"}):T.jsxs("div",{className:"py-0.5",children:[a.length>0&&T.jsxs("div",{children:[T.jsxs("div",{className:"flex items-center gap-1.5 px-2 py-1 text-xs text-text-secondary hover:bg-metro-hover hover:text-white cursor-pointer transition-colors rounded-sm",onClick:()=>C(A),children:[T.jsx("span",{className:"text-text-tertiary",children:i?T.jsx(Bs,{size:12}):T.jsx(xn,{size:12})}),T.jsx("span",{className:"text-accent-orange",children:i?T.jsx(Ys,{size:12}):T.jsx(iR,{size:12})}),T.jsx("span",{className:"flex-1",children:"表"}),T.jsx("span",{className:"text-text-disabled",children:a.length})]}),i&&T.jsx("div",{className:"ml-3 border-l border-metro-border/30",children:a.map(u=>T.jsxs("div",{className:"flex items-center gap-2 px-3 py-1.5 text-xs text-text-secondary hover:bg-metro-hover hover:text-white cursor-pointer transition-colors rounded-sm mx-0.5",title:u.name,onClick:()=>l(n,E,u.name),onContextMenu:D=>o(D,u.name),children:[T.jsx(Fn,{size:12,className:"text-accent-orange flex-shrink-0"}),T.jsx("span",{className:"truncate",children:u.name})]},u.name))})]}),R.length>0&&T.jsxs("div",{children:[T.jsxs("div",{className:"flex items-center gap-1.5 px-2 py-1 text-xs text-text-secondary hover:bg-metro-hover hover:text-white cursor-pointer transition-colors rounded-sm",onClick:()=>C(N),children:[T.jsx("span",{className:"text-text-tertiary",children:O?T.jsx(Bs,{size:12}):T.jsx(xn,{size:12})}),T.jsx("span",{className:"text-accent-purple",children:O?T.jsx(Ys,{size:12}):T.jsx(iR,{size:12})}),T.jsx("span",{className:"flex-1",children:"视图"}),T.jsx("span",{className:"text-text-disabled",children:R.length})]}),O&&T.jsx("div",{className:"ml-3 border-l border-metro-border/30",children:R.map(u=>T.jsxs("div",{className:"flex items-center gap-2 px-3 py-1.5 text-xs text-text-secondary hover:bg-metro-hover hover:text-white cursor-pointer transition-colors rounded-sm mx-0.5",title:`${u.name} (视图)`,onClick:()=>l(n,E,u.name),onContextMenu:D=>o(D,u.name),children:[T.jsx(SO,{size:12,className:"text-accent-purple flex-shrink-0"}),T.jsx("span",{className:"truncate flex-1",children:u.name})]},u.name))})]})]})});function HT(e,t,E=200,n=180){const r=window.innerHeight,s=window.innerWidth;let l=e,o=t;return t+E>r-10&&(o=Math.max(10,t-E)),e+n>s-10&&(l=Math.max(10,e-n)),{x:l,y:o}}function xO({connections:e,activeConnection:t,connectedIds:E,databasesMap:n,tablesMap:r,selectedDatabase:s,loadingDbSet:l,onNewConnection:o,onSelectConnection:a,onConnect:R,onDisconnect:A,onEditConnection:N,onDeleteConnection:i,onDeleteConnections:O,onSelectDatabase:C,onOpenTable:u,onBackupDatabase:D,onExportTable:I,onExportConnections:S,onImportConnections:c,onCreateDatabase:L,onDropDatabase:B,onCreateTable:p,onDropTable:P,onTruncateTable:y,onRenameTable:Y,onDuplicateTable:K,onRefreshTables:oe,onDesignTable:_e}){const[F,He]=f.useState(null),[Ie,me]=f.useState(null),[le,X]=f.useState(null),[ee,te]=f.useState(new Set),[Ee,Re]=f.useState(!1),[Fe,Ye]=f.useState(new Set),[Me,Ve]=f.useState(""),[be,ze]=f.useState(!1),Et=f.useRef(null),iE=f.useRef(null),[Mt,Oe]=f.useState(!1);f.useEffect(()=>{s&&te(j=>new Set(j).add(s))},[s]);const Ce=f.useCallback(j=>{(j.ctrlKey||j.metaKey)&&j.key==="f"&&Mt&&(j.preventDefault(),j.stopPropagation(),ze(!0),setTimeout(()=>Et.current?.focus(),50)),j.key==="Escape"&&be&&(ze(!1),Ve(""))},[Mt,be]);f.useEffect(()=>{const j=iE.current;if(j)return j.addEventListener("keydown",Ce),()=>j.removeEventListener("keydown",Ce)},[Ce]);const Lt=j=>{const Qe=r.get(j)||[];return Me?Qe.filter(ve=>ve.name.toLowerCase().includes(Me.toLowerCase())):Qe},Jt=j=>Me?(r.get(j)||[]).some(ve=>ve.name.toLowerCase().includes(Me.toLowerCase())):!1,zt=j=>j.filter(Qe=>{if(!Me)return!0;const ve=Me.toLowerCase();return!!(Qe.toLowerCase().includes(ve)||Jt(Qe))});return f.useEffect(()=>{Me&&n.forEach(j=>{j.forEach(Qe=>{Jt(Qe)&&te(ve=>new Set(ve).add(Qe))})})},[Me,n,r]),T.jsxs(T.Fragment,{children:[T.jsxs("div",{ref:iE,className:"w-72 bg-metro-bg flex flex-col border-r border-metro-border/50 h-full select-none",tabIndex:0,onFocus:()=>Oe(!0),onBlur:j=>{j.currentTarget.contains(j.relatedTarget)||Oe(!1)},onMouseEnter:()=>Oe(!0),onMouseLeave:()=>Oe(!1),children:[T.jsxs("div",{className:"p-3 flex-shrink-0 space-y-2",children:[T.jsxs("button",{onClick:o,className:`w-full h-10 bg-accent-blue hover:bg-accent-blue-hover flex items-center justify-center gap-2 text-sm font-medium transition-all duration-150 shadow-metro`,children:[T.jsx(Bn,{size:18,strokeWidth:2.5}),T.jsx("span",{children:"新建连接"})]}),T.jsxs("div",{className:"flex gap-2",children:[T.jsxs("button",{onClick:c,className:`flex-1 h-8 bg-metro-surface hover:bg-metro-hover flex items-center justify-center gap-1.5 text-xs text-text-secondary transition-all duration-150`,title:"导入连接 (支持 JSON 和 Navicat NCX 格式)",children:[T.jsx(fO,{size:14}),T.jsx("span",{children:"导入"})]}),T.jsxs("div",{className:"relative group flex-1",children:[T.jsxs("button",{className:`w-full h-8 bg-metro-surface hover:bg-metro-hover flex items-center justify-center gap-1.5 text-xs text-text-secondary transition-all duration-150`,title:"导出连接",children:[T.jsx(iS,{size:14}),T.jsx("span",{children:"导出"})]}),T.jsxs("div",{className:`absolute left-0 right-0 top-full mt-1 bg-metro-card border border-metro-border shadow-metro-lg opacity-0 invisible group-hover:opacity-100 group-hover:visible transition-all z-50`,children:[T.jsxs("button",{onClick:()=>S?.("json"),className:"w-full px-3 py-2 text-left text-xs hover:bg-metro-hover flex items-center gap-2",children:[T.jsx(Fs,{size:12,className:"text-accent-blue"}),"导出为 JSON"]}),T.jsxs("button",{onClick:()=>S?.("ncx"),className:"w-full px-3 py-2 text-left text-xs hover:bg-metro-hover flex items-center gap-2",children:[T.jsx(RR,{size:12,className:"text-accent-orange"}),"导出为 Navicat (.ncx)"]})]})]})]})]}),T.jsx("div",{className:"px-3 pb-2 flex-shrink-0",children:T.jsxs("div",{className:"relative",children:[T.jsx(NS,{size:14,className:"absolute left-3 top-1/2 -translate-y-1/2 text-text-disabled"}),T.jsx("input",{ref:Et,type:"text",value:Me,onChange:j=>Ve(j.target.value),placeholder:s?"搜索表名... (Ctrl+F)":"搜索数据库... (Ctrl+F)",className:`w-full h-8 pl-9 pr-8 bg-metro-surface text-sm text-white placeholder-text-disabled border border-transparent focus:border-accent-blue transition-all rounded-sm`}),Me&&T.jsx("button",{onClick:()=>Ve(""),className:"absolute right-2 top-1/2 -translate-y-1/2 text-text-disabled hover:text-white transition-colors",children:T.jsx(RE,{size:14})})]})}),T.jsxs("div",{className:"flex-1 overflow-y-auto min-h-0",children:[T.jsxs("div",{className:"px-3 py-1.5 text-xs font-medium text-text-tertiary uppercase tracking-wider flex items-center justify-between",children:[T.jsxs("span",{children:["连接 (",e.length,")"]}),e.length>0&&T.jsx("button",{onClick:()=>{Re(!Ee),Ee&&Ye(new Set)},className:`p-1 rounded-sm transition-colors ${Ee?"bg-accent-blue text-white":"hover:bg-metro-hover"}`,title:Ee?"退出多选":"批量管理",children:Ee?T.jsx(iO,{size:12}):T.jsx(OS,{size:12})})]}),Ee&&Fe.size>0&&T.jsxs("div",{className:"px-3 pb-2 flex items-center gap-2",children:[T.jsxs("span",{className:"text-xs text-text-tertiary",children:["已选 ",Fe.size," 项"]}),T.jsxs("button",{onClick:()=>{confirm(`确定删除选中的 ${Fe.size} 个连接吗?`)&&(O?.([...Fe]),Ye(new Set),Re(!1))},className:"px-2 py-1 text-xs bg-accent-red/20 text-accent-red hover:bg-accent-red/30 rounded-sm transition-colors flex items-center gap-1",children:[T.jsx(yE,{size:12}),"删除"]}),T.jsx("button",{onClick:()=>Ye(new Set),className:"px-2 py-1 text-xs bg-metro-surface hover:bg-metro-hover rounded-sm transition-colors",children:"取消"})]}),e.length===0?T.jsx("div",{className:"px-3 py-6 text-center text-text-disabled text-sm",children:"暂无连接"}):T.jsx("div",{className:"px-2 space-y-0.5",children:e.map(j=>{const Qe=_E[j.type],ve=E.has(j.id),AE=t===j.id,St=Fe.has(j.id),lt=ee.has(j.id),Qt=n.get(j.id)||[],SE=lt&&ve&&Qt.length>0;return T.jsxs("div",{children:[T.jsxs("div",{className:`group flex items-center gap-2 px-2 py-2 cursor-pointer transition-all duration-150 rounded-sm ${St?"bg-metro-hover ring-1 ring-text-tertiary":""} ${AE&&!St?"bg-metro-hover":"hover:bg-metro-hover"} text-text-secondary hover:text-white`,onClick:()=>{Ee?Ye(ue=>{const m=new Set(ue);return m.has(j.id)?m.delete(j.id):m.add(j.id),m}):(a(j.id),ve&&te(ue=>{const m=new Set(ue);return m.has(j.id)?m.delete(j.id):m.add(j.id),m}))},onDoubleClick:async()=>{!Ee&&!ve&&(R(j),te(ue=>new Set(ue).add(j.id)))},onContextMenu:ue=>{ue.preventDefault();const m=HT(ue.clientX,ue.clientY,180);He({x:m.x,y:m.y,conn:j})},children:[T.jsx("span",{className:"w-4 flex-shrink-0 flex items-center justify-center",children:Ee?T.jsx("span",{className:`w-4 h-4 rounded-sm border flex items-center justify-center ${St?"bg-accent-blue border-accent-blue":"border-text-tertiary"}`,children:St&&T.jsx("span",{className:"text-white text-xs",children:"✓"})}):T.jsx("span",{className:`${ve?"text-text-tertiary":"opacity-0"}`,children:lt?T.jsx(Bs,{size:14}):T.jsx(xn,{size:14})})}),T.jsx("span",{className:"text-lg flex-shrink-0",children:Qe?.icon}),T.jsx("span",{className:"flex-1 text-sm truncate font-medium",children:j.name}),T.jsx("span",{className:`w-2.5 h-2.5 rounded-full flex-shrink-0 transition-all ${ve?"bg-[#00ff00] shadow-[0_0_8px_#00ff00,0_0_12px_#00ff00]":"bg-text-disabled/40"}`,title:ve?"已连接":"未连接"})]}),SE&<&&T.jsx("div",{className:"ml-4 border-l border-metro-border/50 mt-0.5",children:zt(Qt).map(ue=>{const m=s===ue,w=ee.has(ue),J=Lt(ue),Te=l.has(ue);return T.jsxs("div",{children:[T.jsxs("div",{className:`flex items-center gap-1.5 px-2 py-1.5 cursor-pointer text-sm transition-all duration-150 rounded-sm ml-1 ${m?"bg-metro-hover text-white font-medium":"text-text-secondary hover:bg-metro-hover hover:text-white"}`,onClick:()=>{!ee.has(ue)&&C(ue,j.id),te(ne=>{const ie=new Set(ne);return ie.has(ue)?ie.delete(ue):ie.add(ue),ie})},onContextMenu:b=>{b.preventDefault();const ne=HT(b.clientX,b.clientY,200);me({x:ne.x,y:ne.y,db:ue,connectionId:j.id})},children:[T.jsx("span",{className:`flex-shrink-0 ${m?"text-white/70":"text-text-tertiary"}`,children:w?T.jsx(Bs,{size:14}):T.jsx(xn,{size:14})}),T.jsx(vn,{size:14,className:`flex-shrink-0 ${m?"text-white":"text-accent-blue"}`}),T.jsx("span",{className:"flex-1 truncate",children:ue})]}),w&&T.jsx("div",{className:"ml-4 mt-0.5",children:Te?T.jsxs("div",{className:"flex items-center gap-2 px-3 py-2 text-xs text-text-tertiary",children:[T.jsx(Mr,{size:12,className:"animate-spin"}),"加载中..."]}):T.jsx(hO,{tables:J,db:ue,connectionId:j.id,expandedDbs:ee,setExpandedDbs:te,onOpenTable:u,onContextMenu:(b,ne)=>{b.preventDefault();const ie=HT(b.clientX,b.clientY,280);X({x:ie.x,y:ie.y,db:ue,table:ne,connectionId:j.id})}})})]},ue)})})]},j.id)})})]})]}),F&&T.jsxs(T.Fragment,{children:[T.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>He(null)}),T.jsxs("div",{className:"fixed z-50 bg-metro-card border border-metro-border py-1.5 min-w-[160px] shadow-metro-lg animate-fade-in",style:{left:F.x,top:F.y},children:[E.has(F.conn.id)?T.jsxs(T.Fragment,{children:[T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{A(F.conn.id),He(null)},children:[T.jsx("span",{className:"w-4 h-4 rounded-full border-2 border-accent-red"}),"断开连接"]}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{L?.(F.conn.id),He(null)},children:[T.jsx(AR,{size:14,className:"text-accent-green"}),"新建数据库"]}),T.jsx("div",{className:"my-1 border-t border-metro-border"})]}):T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{R(F.conn),He(null)},children:[T.jsx("span",{className:"w-4 h-4 rounded-full border-2 border-accent-green"}),"连接"]}),T.jsx("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover transition-colors",onClick:()=>{N(F.conn),He(null)},children:"编辑"}),T.jsx("div",{className:"my-1 border-t border-metro-border"}),T.jsx("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover text-accent-red transition-colors",onClick:()=>{i(F.conn.id),He(null)},children:"删除"})]})]}),Ie&&T.jsxs(T.Fragment,{children:[T.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>me(null)}),T.jsxs("div",{className:"fixed z-50 bg-metro-card border border-metro-border py-1.5 min-w-[180px] shadow-metro-lg animate-fade-in",style:{left:Ie.x,top:Ie.y},children:[T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{p?.(Ie.connectionId,Ie.db),me(null)},children:[T.jsx(AR,{size:14,className:"text-accent-green"}),"新建表"]}),T.jsx("div",{className:"my-1 border-t border-metro-border"}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{oe?.(Ie.connectionId,Ie.db),me(null)},children:[T.jsx(eo,{size:14,className:"text-text-secondary"}),"刷新"]}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{D?.(Ie.db),me(null)},children:[T.jsx(OO,{size:14,className:"text-accent-blue"}),"备份数据库"]}),T.jsx("div",{className:"my-1 border-t border-metro-border"}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 text-accent-red transition-colors",onClick:()=>{confirm(`确定要删除数据库 "${Ie.db}" 吗?此操作不可恢复!`)&&B?.(Ie.connectionId,Ie.db),me(null)},children:[T.jsx(yE,{size:14}),"删除数据库"]})]})]}),le&&T.jsxs(T.Fragment,{children:[T.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>X(null)}),T.jsxs("div",{className:"fixed z-50 bg-metro-card border border-metro-border py-1.5 min-w-[180px] shadow-metro-lg animate-fade-in",style:{left:le.x,top:le.y},children:[T.jsx("div",{className:"px-4 py-1.5 text-xs text-text-disabled border-b border-metro-border mb-1",children:le.table}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{u(le.connectionId,le.db,le.table),X(null)},children:[T.jsx(Fn,{size:14,className:"text-accent-orange"}),"打开表"]}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{_e?.(le.connectionId,le.db,le.table),X(null)},children:[T.jsx(IS,{size:14,className:"text-accent-teal"}),"设计表"]}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{Y?.(le.connectionId,le.db,le.table),X(null)},children:[T.jsx(SS,{size:14,className:"text-accent-blue"}),"重命名"]}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{K?.(le.connectionId,le.db,le.table),X(null)},children:[T.jsx(nT,{size:14,className:"text-accent-purple"}),"复制表"]}),T.jsx("div",{className:"my-1 border-t border-metro-border"}),T.jsx("div",{className:"px-4 py-1.5 text-xs text-text-disabled",children:"导出"}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{I?.(le.db,le.table,"excel"),X(null)},children:[T.jsx(AS,{size:14,className:"text-accent-green"}),"导出 Excel"]}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{I?.(le.db,le.table,"sql"),X(null)},children:[T.jsx(Fs,{size:14,className:"text-accent-orange"}),"导出 SQL"]}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 transition-colors",onClick:()=>{I?.(le.db,le.table,"csv"),X(null)},children:[T.jsx(RR,{size:14,className:"text-accent-blue"}),"导出 CSV"]}),T.jsx("div",{className:"my-1 border-t border-metro-border"}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 text-accent-orange transition-colors",onClick:()=>{confirm(`确定要清空表 "${le.table}" 的所有数据吗?此操作不可恢复!`)&&y?.(le.connectionId,le.db,le.table),X(null)},children:[T.jsx(eo,{size:14}),"清空表"]}),T.jsxs("button",{className:"w-full px-4 py-2 text-left text-sm hover:bg-metro-hover flex items-center gap-3 text-accent-red transition-colors",onClick:()=>{confirm(`确定要删除表 "${le.table}" 吗?此操作不可恢复!`)&&P?.(le.connectionId,le.db,le.table),X(null)},children:[T.jsx(yE,{size:14}),"删除表"]})]})]})]})}const yO="modulepreload",GO=function(e,t){return new URL(e,t).href},SR={},gO=function(t,E,n){let r=Promise.resolve();if(E&&E.length>0){const l=document.getElementsByTagName("link"),o=document.querySelector("meta[property=csp-nonce]"),a=o?.nonce||o?.getAttribute("nonce");r=Promise.allSettled(E.map(R=>{if(R=GO(R,n),R in SR)return;SR[R]=!0;const A=R.endsWith(".css"),N=A?'[rel="stylesheet"]':"";if(!!n)for(let C=l.length-1;C>=0;C--){const u=l[C];if(u.href===R&&(!A||u.rel==="stylesheet"))return}else if(document.querySelector(`link[href="${R}"]${N}`))return;const O=document.createElement("link");if(O.rel=A?"stylesheet":yO,A||(O.as="script"),O.crossOrigin="",O.href=R,a&&O.setAttribute("nonce",a),document.head.appendChild(O),A)return new Promise((C,u)=>{O.addEventListener("load",C),O.addEventListener("error",()=>u(new Error(`Unable to preload CSS for ${R}`)))})}))}function s(l){const o=new Event("vite:preloadError",{cancelable:!0});if(o.payload=l,window.dispatchEvent(o),!o.defaultPrevented)throw l}return r.then(l=>{for(const o of l||[])o.status==="rejected"&&s(o.reason);return t().catch(s)})},U=e=>e.flatMap(HO),HO=e=>Rs(BO(e)).map(vO),vO=e=>e.replace(/ +/g," ").trim(),BO=e=>({type:"mandatory_block",items:qo(e,0)[0]}),qo=(e,t,E)=>{const n=[];for(;e[t];){const[r,s]=FO(e,t);if(n.push(r),t=s,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]},FO=(e,t)=>{const E=[];for(;;){const[n,r]=YO(e,t);if(n)E.push(n),t=r;else break}return E.length===1?[E[0],t]:[{type:"concatenation",items:E},t]},YO=(e,t)=>{if(e[t]==="{")return wO(e,t+1);if(e[t]==="[")return VO(e,t+1);{let E="";for(;e[t]&&/[A-Za-z0-9_ ]/.test(e[t]);)E+=e[t],t++;return[E,t]}},wO=(e,t)=>{const[E,n]=qo(e,t,"}");return[{type:"mandatory_block",items:E},n]},VO=(e,t)=>{const[E,n]=qo(e,t,"]");return[{type:"optional_block",items:E},n]},Rs=e=>{if(typeof e=="string")return[e];if(e.type==="concatenation")return e.items.map(Rs).reduce(bO,[""]);if(e.type==="mandatory_block")return e.items.flatMap(Rs);if(e.type==="optional_block")return["",...e.items.flatMap(Rs)];throw new Error(`Unknown node type: ${e}`)},bO=(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 uS=e=>({type:v.EOF,raw:"«EOF»",text:"«EOF»",start:e}),yn=uS(1/0),nn=e=>t=>t.type===e.type&&t.text===e.text,QE={ARRAY:nn({text:"ARRAY",type:v.RESERVED_DATA_TYPE}),BY:nn({text:"BY",type:v.RESERVED_KEYWORD}),SET:nn({text:"SET",type:v.RESERVED_CLAUSE}),STRUCT:nn({text:"STRUCT",type:v.RESERVED_DATA_TYPE}),WINDOW:nn({text:"WINDOW",type:v.RESERVED_CLAUSE}),VALUES:nn({text:"VALUES",type:v.RESERVED_CLAUSE})},cS=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,WO=e=>e===v.AND||e===v.OR||e===v.XOR,XO=["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"],KO=["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"],$O=["ARRAY","BOOL","BYTES","DATE","DATETIME","GEOGRAPHY","INTERVAL","INT64","INT","SMALLINT","INTEGER","BIGINT","TINYINT","BYTEINT","NUMERIC","DECIMAL","BIGNUMERIC","BIGDECIMAL","FLOAT64","STRING","STRUCT","TIME","TIMEZONE"],jO=U(["SELECT [ALL | DISTINCT] [AS STRUCT | AS VALUE]"]),kO=U(["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"]),NR=U(["CREATE [OR REPLACE] [TEMP|TEMPORARY|SNAPSHOT|EXTERNAL] TABLE [IF NOT EXISTS]"]),vT=U(["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"]),JO=U(["UNION {ALL | DISTINCT}","EXCEPT DISTINCT","INTERSECT DISTINCT"]),zO=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN"]),QO=U(["TABLESAMPLE SYSTEM","ANY TYPE","ALL COLUMNS","NOT DETERMINISTIC","{ROWS | RANGE} BETWEEN","IS [NOT] DISTINCT FROM"]),ZO=U([]),qO={name:"bigquery",tokenizerOptions:{reservedSelect:jO,reservedClauses:[...kO,...vT,...NR],reservedSetOperations:JO,reservedJoins:zO,reservedKeywordPhrases:QO,reservedDataTypePhrases:ZO,reservedKeywords:KO,reservedDataTypes:$O,reservedFunctionNames:XO,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:eu},formatOptions:{onelineClauses:[...NR,...vT],tabularOnelineClauses:vT}};function eu(e){return tu(Eu(e))}function tu(e){let t=yn;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 Eu(e){var t;const E=[];for(let n=0;nt=>t.type===v.IDENTIFIER||t.type===v.COMMA?t[e]+" ":t[e];function nu(e,t){let E=0;for(let n=t;n"?E--:r.text===">>"&&(E-=2),E===0)return n}return e.length-1}const ru=["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"],su=["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"],Tu=["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"],lu=U(["SELECT [ALL | DISTINCT]"]),ou=U(["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"]),uR=U(["CREATE [GLOBAL TEMPORARY | EXTERNAL] TABLE [IF NOT EXISTS]"]),BT=U(["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"]),au=U(["UNION [ALL]","EXCEPT [ALL]","INTERSECT [ALL]"]),Ru=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN"]),iu=U(["ON DELETE","ON UPDATE","SET NULL","{ROWS | RANGE} BETWEEN"]),Au=U([]),Su={name:"db2",tokenizerOptions:{reservedSelect:lu,reservedClauses:[...ou,...uR,...BT],reservedSetOperations:au,reservedJoins:Ru,reservedKeywordPhrases:iu,reservedDataTypePhrases:Au,reservedKeywords:su,reservedDataTypes:Tu,reservedFunctionNames:ru,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:[...uR,...BT],tabularOnelineClauses:BT}},Nu=["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"],Iu=["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"],Ou=["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"],uu=U(["SELECT [ALL | DISTINCT]"]),cu=U(["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"]),cR=U(["CREATE [OR REPLACE] TABLE"]),FT=U(["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}"]),Cu=U(["UNION [ALL]","EXCEPT [ALL]","INTERSECT [ALL]"]),Lu=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","[LEFT | RIGHT] EXCEPTION JOIN","{INNER | CROSS} JOIN"]),_u=U(["ON DELETE","ON UPDATE","SET NULL","{ROWS | RANGE} BETWEEN"]),du=U([]),Du={name:"db2i",tokenizerOptions:{reservedSelect:uu,reservedClauses:[...cu,...cR,...FT],reservedSetOperations:Cu,reservedJoins:Lu,reservedKeywordPhrases:_u,reservedDataTypePhrases:du,reservedKeywords:Iu,reservedDataTypes:Ou,reservedFunctionNames:Nu,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:[...cR,...FT],tabularOnelineClauses:FT}},Pu=["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"],pu=["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"],fu=["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"],mu=U(["SELECT [ALL | DISTINCT]"]),Mu=U(["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"]),CR=U(["CREATE [OR REPLACE] [TEMPORARY | TEMP] TABLE [IF NOT EXISTS]"]),YT=U(["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]"]),Uu=U(["UNION [ALL | BY NAME]","EXCEPT [ALL]","INTERSECT [ALL]"]),hu=U(["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"]),xu=U(["{ROWS | RANGE | GROUPS} BETWEEN","SIMILAR TO","IS [NOT] DISTINCT FROM"]),yu=U(["TIMESTAMP WITH TIME ZONE"]),Gu={name:"duckdb",tokenizerOptions:{reservedSelect:mu,reservedClauses:[...Mu,...CR,...YT],reservedSetOperations:Uu,reservedJoins:hu,reservedKeywordPhrases:xu,reservedDataTypePhrases:yu,supportsXor:!0,reservedKeywords:pu,reservedDataTypes:fu,reservedFunctionNames:Pu,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:[...CR,...YT],tabularOnelineClauses:YT}},gu=["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"],Hu=["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"],vu=["ARRAY","BIGINT","BINARY","BOOLEAN","CHAR","DATE","DECIMAL","DOUBLE","FLOAT","INT","INTEGER","INTERVAL","MAP","NUMERIC","PRECISION","SMALLINT","STRUCT","TIMESTAMP","VARCHAR"],Bu=U(["SELECT [ALL | DISTINCT]"]),Fu=U(["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"]),LR=U(["CREATE [TEMPORARY] [EXTERNAL] TABLE [IF NOT EXISTS]"]),wT=U(["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"]),Yu=U(["UNION [ALL | DISTINCT]"]),wu=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","LEFT SEMI JOIN"]),Vu=U(["{ROWS | RANGE} BETWEEN"]),bu=U([]),Wu={name:"hive",tokenizerOptions:{reservedSelect:Bu,reservedClauses:[...Fu,...LR,...wT],reservedSetOperations:Yu,reservedJoins:wu,reservedKeywordPhrases:Vu,reservedDataTypePhrases:bu,reservedKeywords:Hu,reservedDataTypes:vu,reservedFunctionNames:gu,extraParens:["[]"],stringTypes:['""-bs',"''-bs"],identTypes:["``"],variableTypes:[{quote:"{}",prefixes:["$"],requirePrefix:!0}],operators:["%","~","^","|","&","<=>","==","!","||"]},formatOptions:{onelineClauses:[...LR,...wT],tabularOnelineClauses:wT}};function rT(e){return e.map((t,E)=>{const n=e[E+1]||yn;if(QE.SET(t)&&n.text==="(")return Object.assign(Object.assign({},t),{type:v.RESERVED_FUNCTION_NAME});const r=e[E-1]||yn;return QE.VALUES(t)&&r.text==="="?Object.assign(Object.assign({},t),{type:v.RESERVED_FUNCTION_NAME}):t})}const Xu=["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"],Ku=["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"],$u=["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"],ju=U(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),ku=U(["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"]),_R=U(["CREATE [OR REPLACE] [TEMPORARY] TABLE [IF NOT EXISTS]"]),VT=U(["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"]),Ju=U(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]","MINUS [ALL | DISTINCT]"]),zu=U(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),Qu=U(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),Zu=U([]),qu={name:"mariadb",tokenizerOptions:{reservedSelect:ju,reservedClauses:[...ku,..._R,...VT],reservedSetOperations:Ju,reservedJoins:zu,reservedKeywordPhrases:Qu,reservedDataTypePhrases:Zu,supportsXor:!0,reservedKeywords:Xu,reservedDataTypes:Ku,reservedFunctionNames:$u,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:rT},formatOptions:{onelineClauses:[..._R,...VT],tabularOnelineClauses:VT}},ec=["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"],tc=["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"],Ec=["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"],nc=U(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),rc=U(["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"]),dR=U(["CREATE [TEMPORARY] TABLE [IF NOT EXISTS]"]),bT=U(["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"]),sc=U(["UNION [ALL | DISTINCT]"]),Tc=U(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),lc=U(["ON {UPDATE | DELETE} [SET NULL]","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),oc=U([]),ac={name:"mysql",tokenizerOptions:{reservedSelect:nc,reservedClauses:[...rc,...dR,...bT],reservedSetOperations:sc,reservedJoins:Tc,reservedKeywordPhrases:lc,reservedDataTypePhrases:oc,supportsXor:!0,reservedKeywords:ec,reservedDataTypes:tc,reservedFunctionNames:Ec,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:rT},formatOptions:{onelineClauses:[...dR,...bT],tabularOnelineClauses:bT}},Rc=["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"],ic=["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"],Ac=["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"],Sc=U(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),Nc=U(["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"]),DR=U(["CREATE [TEMPORARY] TABLE [IF NOT EXISTS]"]),WT=U(["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"]),Ic=U(["UNION [ALL | DISTINCT]"]),Oc=U(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),uc=U(["ON {UPDATE | DELETE} [SET NULL]","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),cc=U([]),Cc={name:"tidb",tokenizerOptions:{reservedSelect:Sc,reservedClauses:[...Nc,...DR,...WT],reservedSetOperations:Ic,reservedJoins:Oc,reservedKeywordPhrases:uc,reservedDataTypePhrases:cc,supportsXor:!0,reservedKeywords:Rc,reservedDataTypes:ic,reservedFunctionNames:Ac,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:rT},formatOptions:{onelineClauses:[...DR,...WT],tabularOnelineClauses:WT}},Lc=["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"],_c=["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"],dc=[],Dc=U(["SELECT [ALL | DISTINCT]"]),Pc=U(["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"]),PR=U(["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"]),pc=U(["UNION [ALL]","EXCEPT [ALL]","INTERSECT [ALL]"]),fc=U(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","INNER JOIN"]),mc=U(["{ROWS | RANGE | GROUPS} BETWEEN"]),Mc=U([]),Uc={name:"n1ql",tokenizerOptions:{reservedSelect:Dc,reservedClauses:[...Pc,...PR],reservedSetOperations:pc,reservedJoins:fc,reservedKeywordPhrases:mc,reservedDataTypePhrases:Mc,supportsXor:!0,reservedKeywords:_c,reservedDataTypes:dc,reservedFunctionNames:Lc,stringTypes:['""-bs',"''-bs"],identTypes:["``"],extraParens:["[]","{}"],paramTypes:{positional:!0,numbered:["$"],named:["$"]},lineCommentTypes:["#","--"],operators:["%","==",":","||"]},formatOptions:{onelineClauses:PR}},hc=["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"],xc=["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"],yc=["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"],Gc=U(["SELECT [ALL | DISTINCT | UNIQUE]"]),gc=U(["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"]),pR=U(["CREATE [GLOBAL TEMPORARY | PRIVATE TEMPORARY | SHARDED | DUPLICATED | IMMUTABLE BLOCKCHAIN | BLOCKCHAIN | IMMUTABLE] TABLE"]),XT=U(["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"]),Hc=U(["UNION [ALL]","MINUS","INTERSECT"]),vc=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN","{CROSS | OUTER} APPLY"]),Bc=U(["ON {UPDATE | DELETE} [SET NULL]","ON COMMIT","{ROWS | RANGE} BETWEEN"]),Fc=U([]),Yc={name:"plsql",tokenizerOptions:{reservedSelect:Gc,reservedClauses:[...gc,...pR,...XT],reservedSetOperations:Hc,reservedJoins:vc,reservedKeywordPhrases:Bc,reservedDataTypePhrases:Fc,supportsXor:!0,reservedKeywords:hc,reservedDataTypes:xc,reservedFunctionNames:yc,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:wc},formatOptions:{alwaysDenseOperators:["@"],onelineClauses:[...pR,...XT],tabularOnelineClauses:XT}};function wc(e){let t=yn;return e.map(E=>QE.SET(E)&&QE.BY(t)?Object.assign(Object.assign({},E),{type:v.RESERVED_KEYWORD}):(cS(E.type)&&(t=E),E))}const Vc=["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"],bc=["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"],Wc=["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"],Xc=U(["SELECT [ALL | DISTINCT]"]),Kc=U(["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"]),fR=U(["CREATE [GLOBAL | LOCAL] [TEMPORARY | TEMP | UNLOGGED] TABLE [IF NOT EXISTS]"]),KT=U(["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"]),$c=U(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),jc=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),kc=U(["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"]),Jc=U(["[TIMESTAMP | TIME] {WITH | WITHOUT} TIME ZONE"]),zc={name:"postgresql",tokenizerOptions:{reservedSelect:Xc,reservedClauses:[...Kc,...fR,...KT],reservedSetOperations:$c,reservedJoins:jc,reservedKeywordPhrases:kc,reservedDataTypePhrases:Jc,reservedKeywords:bc,reservedDataTypes:Wc,reservedFunctionNames:Vc,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:[...fR,...KT],tabularOnelineClauses:KT}},Qc=["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"],Zc=["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"],qc=["ARRAY","BIGINT","BPCHAR","CHAR","CHARACTER VARYING","CHARACTER","DECIMAL","INT","INT2","INT4","INT8","INTEGER","NCHAR","NUMERIC","NVARCHAR","SMALLINT","TEXT","VARBYTE","VARCHAR"],eC=U(["SELECT [ALL | DISTINCT]"]),tC=U(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY","HAVING","QUALIFY","PARTITION BY","ORDER BY","LIMIT","OFFSET","INSERT INTO","VALUES","SET"]),mR=U(["CREATE [TEMPORARY | TEMP | LOCAL TEMPORARY | LOCAL TEMP] TABLE [IF NOT EXISTS]"]),$T=U(["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"]),EC=U(["UNION [ALL]","EXCEPT","INTERSECT","MINUS"]),nC=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),rC=U(["NULL AS","DATA CATALOG","HIVE METASTORE","{ROWS | RANGE} BETWEEN"]),sC=U([]),TC={name:"redshift",tokenizerOptions:{reservedSelect:eC,reservedClauses:[...tC,...mR,...$T],reservedSetOperations:EC,reservedJoins:nC,reservedKeywordPhrases:rC,reservedDataTypePhrases:sC,reservedKeywords:Zc,reservedDataTypes:qc,reservedFunctionNames:Qc,extraParens:["[]"],stringTypes:["''-qq"],identTypes:['""-qq'],identChars:{first:"#"},paramTypes:{numbered:["$"]},operators:["^","%","@","|/","||/","&","|","~","<<",">>","||","::"]},formatOptions:{alwaysDenseOperators:["::"],onelineClauses:[...mR,...$T],tabularOnelineClauses:$T}},lC=["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"],oC=["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"],aC=["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"],RC=U(["SELECT [ALL | DISTINCT]"]),iC=U(["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"]),MR=U(["CREATE [EXTERNAL] TABLE [IF NOT EXISTS]"]),jT=U(["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"]),AC=U(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),SC=U(["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"]),NC=U(["ON DELETE","ON UPDATE","CURRENT ROW","{ROWS | RANGE} BETWEEN"]),IC=U([]),OC={name:"spark",tokenizerOptions:{reservedSelect:RC,reservedClauses:[...iC,...MR,...jT],reservedSetOperations:AC,reservedJoins:SC,reservedKeywordPhrases:NC,reservedDataTypePhrases:IC,supportsXor:!0,reservedKeywords:lC,reservedDataTypes:oC,reservedFunctionNames:aC,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:uC},formatOptions:{onelineClauses:[...MR,...jT],tabularOnelineClauses:jT}};function uC(e){return e.map((t,E)=>{const n=e[E-1]||yn,r=e[E+1]||yn;return QE.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 cC=["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"],CC=["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"],LC=["ANY","ARRAY","BLOB","CHARACTER","DECIMAL","INT","INTEGER","NATIVE CHARACTER","NCHAR","NUMERIC","NVARCHAR","REAL","TEXT","VARCHAR","VARYING CHARACTER"],_C=U(["SELECT [ALL | DISTINCT]"]),dC=U(["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"]),UR=U(["CREATE [TEMPORARY | TEMP] TABLE [IF NOT EXISTS]"]),kT=U(["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"]),DC=U(["UNION [ALL]","EXCEPT","INTERSECT"]),PC=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),pC=U(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","{ROWS | RANGE | GROUPS} BETWEEN","DO UPDATE"]),fC=U([]),mC={name:"sqlite",tokenizerOptions:{reservedSelect:_C,reservedClauses:[...dC,...UR,...kT],reservedSetOperations:DC,reservedJoins:PC,reservedKeywordPhrases:pC,reservedDataTypePhrases:fC,reservedKeywords:CC,reservedDataTypes:LC,reservedFunctionNames:cC,stringTypes:["''-qq",{quote:"''-raw",prefixes:["X"],requirePrefix:!0}],identTypes:['""-qq',"``","[]"],paramTypes:{positional:!0,numbered:["?"],named:[":","@","$"]},operators:["%","~","&","|","<<",">>","==","->","->>","||"]},formatOptions:{onelineClauses:[...UR,...kT],tabularOnelineClauses:kT}},MC=["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"],UC=["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"],hC=["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"],xC=U(["SELECT [ALL | DISTINCT]"]),yC=U(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY [ALL | DISTINCT]","HAVING","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","FETCH {FIRST | NEXT}","INSERT INTO","VALUES","SET"]),hR=U(["CREATE [GLOBAL TEMPORARY | LOCAL TEMPORARY] TABLE"]),JT=U(["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"]),GC=U(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),gC=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),HC=U(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","{ROWS | RANGE} BETWEEN"]),vC=U([]),BC={name:"sql",tokenizerOptions:{reservedSelect:xC,reservedClauses:[...yC,...hR,...JT],reservedSetOperations:GC,reservedJoins:gC,reservedKeywordPhrases:HC,reservedDataTypePhrases:vC,reservedKeywords:UC,reservedDataTypes:hC,reservedFunctionNames:MC,stringTypes:[{quote:"''-qq-bs",prefixes:["N","U&"]},{quote:"''-raw",prefixes:["X"],requirePrefix:!0}],identTypes:['""-qq',"``"],paramTypes:{positional:!0},operators:["||"]},formatOptions:{onelineClauses:[...hR,...JT],tabularOnelineClauses:JT}},FC=["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"],YC=["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"],wC=["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"],VC=U(["SELECT [ALL | DISTINCT]"]),bC=U(["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"]),xR=U(["CREATE TABLE [IF NOT EXISTS]"]),zT=U(["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"]),WC=U(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),XC=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),KC=U(["{ROWS | RANGE | GROUPS} BETWEEN","IS [NOT] DISTINCT FROM"]),$C=U([]),jC={name:"trino",tokenizerOptions:{reservedSelect:VC,reservedClauses:[...bC,...xR,...zT],reservedSetOperations:WC,reservedJoins:XC,reservedKeywordPhrases:KC,reservedDataTypePhrases:$C,reservedKeywords:YC,reservedDataTypes:wC,reservedFunctionNames:FC,extraParens:["[]","{}"],stringTypes:[{quote:"''-qq",prefixes:["U&"]},{quote:"''-raw",prefixes:["X"],requirePrefix:!0}],identTypes:['""-qq'],paramTypes:{positional:!0},operators:["%","->","=>",":","||","|","^","$"]},formatOptions:{onelineClauses:[...xR,...zT],tabularOnelineClauses:zT}},kC=["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"],JC=["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"],zC=["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"],QC=U(["SELECT [ALL | DISTINCT]"]),ZC=U(["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"]),yR=U(["CREATE TABLE"]),QT=U(["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"]),qC=U(["UNION [ALL]","EXCEPT","INTERSECT"]),eL=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","{CROSS | OUTER} APPLY"]),tL=U(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","{ROWS | RANGE} BETWEEN"]),EL=U([]),nL={name:"transactsql",tokenizerOptions:{reservedSelect:QC,reservedClauses:[...ZC,...yR,...QT],reservedSetOperations:qC,reservedJoins:eL,reservedKeywordPhrases:tL,reservedDataTypePhrases:EL,reservedKeywords:JC,reservedDataTypes:zC,reservedFunctionNames:kC,nestedBlockComments:!0,stringTypes:[{quote:"''-qq",prefixes:["N"]},"{}"],identTypes:['""-qq',"[]"],identChars:{first:"#@",rest:"#@$"},paramTypes:{named:["@"],quoted:["@"]},operators:["%","&","|","^","~","!<","!>","+=","-=","*=","/=","%=","|=","&=","^=","::",":"],propertyAccessOperators:[".."]},formatOptions:{alwaysDenseOperators:["::"],onelineClauses:[...yR,...QT],tabularOnelineClauses:QT}},rL=["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"],sL=["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"],TL=["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"],lL=U(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),oL=U(["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"]),GR=U(["CREATE [ROWSTORE] [REFERENCE | TEMPORARY | GLOBAL TEMPORARY] TABLE [IF NOT EXISTS]"]),ZT=U(["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"]),aL=U(["UNION [ALL | DISTINCT]","EXCEPT","INTERSECT","MINUS"]),RL=U(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),iL=U(["ON DELETE","ON UPDATE","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),AL=U([]),SL={name:"singlestoredb",tokenizerOptions:{reservedSelect:lL,reservedClauses:[...oL,...GR,...ZT],reservedSetOperations:aL,reservedJoins:RL,reservedKeywordPhrases:iL,reservedDataTypePhrases:AL,reservedKeywords:rL,reservedDataTypes:sL,reservedFunctionNames:TL,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:rT},formatOptions:{alwaysDenseOperators:["::","::$","::%"],onelineClauses:[...GR,...ZT],tabularOnelineClauses:ZT}},NL=["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"],IL=["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"],OL=["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"],uL=U(["SELECT [ALL | DISTINCT]"]),cL=U(["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"]),gR=U(["CREATE [OR REPLACE] [VOLATILE] TABLE [IF NOT EXISTS]","CREATE [OR REPLACE] [LOCAL | GLOBAL] {TEMP|TEMPORARY} TABLE [IF NOT EXISTS]"]),qT=U(["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"]),CL=U(["UNION [ALL]","MINUS","EXCEPT","INTERSECT"]),LL=U(["[INNER] JOIN","[NATURAL] {LEFT | RIGHT | FULL} [OUTER] JOIN","{CROSS | NATURAL} JOIN"]),_L=U(["{ROWS | RANGE} BETWEEN","ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]"]),dL=U([]),DL={name:"snowflake",tokenizerOptions:{reservedSelect:uL,reservedClauses:[...cL,...gR,...qT],reservedSetOperations:CL,reservedJoins:LL,reservedKeywordPhrases:_L,reservedDataTypePhrases:dL,reservedKeywords:IL,reservedDataTypes:OL,reservedFunctionNames:NL,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:[...gR,...qT],tabularOnelineClauses:qT}},PL=Object.freeze(Object.defineProperty({__proto__:null,bigquery:qO,db2:Su,db2i:Du,duckdb:Gu,hive:Wu,mariadb:qu,mysql:ac,n1ql:Uc,plsql:Yc,postgresql:zc,redshift:TC,singlestoredb:SL,snowflake:DL,spark:OC,sql:BC,sqlite:mC,tidb:Cc,transactsql:nL,trino:jC},Symbol.toStringTag,{value:"Module"})),Rr=e=>e[e.length-1],CS=e=>e.sort((t,E)=>E.length-t.length||t.localeCompare(E)),is=e=>e.replace(/\s+/gu," "),el=e=>/\n/.test(e),bt=e=>e.replace(/[.*+?^${}()|[\]\\]/gu,"\\$&"),HR=/\s+/uy,en=e=>new RegExp(`(?:${e})`,"uy"),pL=e=>e.split("").map(t=>/ /gu.test(t)?"\\s+":`[${t.toUpperCase()}${t.toLowerCase()}]`).join(""),fL=e=>e+"(?:-"+e+")*",mL=({prefixes:e,requirePrefix:t})=>`(?:${e.map(pL).join("|")}${t?"":"|"})`,ML=e=>new RegExp(`(?:${e.map(bt).join("|")}).*?(?=\r |\r| |$)`,"uy"),vR=(e,t=[])=>{const E=e==="open"?0:1,n=["()",...t].map(r=>r[E]);return en(n.map(bt).join("|"))},BR=e=>en(`${CS(e).map(bt).join("|")}`),UL=({rest:e,dashes:t})=>e||t?`(?![${e||""}${t?"-":""}])`:"",qt=(e,t={})=>{if(e.length===0)return/^\b$/u;const E=UL(t),n=CS(e).map(bt).join("|").replace(/ /gu,"\\s+");return new RegExp(`(?:${n})${E}\\b`,"iuy")},tl=(e,t)=>{if(!e.length)return;const E=e.map(bt).join("|");return en(`(?:${E})(?:${t})`)},hL=()=>{const e={"<":">","[":"]","(":")","{":"}"},t="{left}(?:(?!{right}').)*?{right}",E=Object.entries(e).map(([l,o])=>t.replace(/{left}/g,bt(l)).replace(/{right}/g,bt(o))),n=bt(Object.keys(e).join(""));return`[Qq]'(?:${String.raw`(?[^\s${n}])(?:(?!\k').)*?\k`}|${E.join("|")})'`},FR={"``":"(?:`[^`]*`)+","[]":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`(?\$\w*\$)[\s\S]*?\k`,"'''..'''":String.raw`'''[^\\]*?(?:\\.[^\\]*?)*?'''`,'""".."""':String.raw`"""[^\\]*?(?:\\.[^\\]*?)*?"""`,"{}":String.raw`(?:\{[^\}]*\})`,"q''":hL()},LS=e=>typeof e=="string"?FR[e]:"regex"in e?e.regex:mL(e)+FR[e.quote],xL=e=>en(e.map(t=>"regex"in t?t.regex:LS(t)).join("|")),_S=e=>e.map(LS).join("|"),YR=e=>en(_S(e)),yL=(e={})=>en(dS(e)),dS=({first:e,rest:t,dashes:E,allowFirstCharNumber:n}={})=>{const r="\\p{Alphabetic}\\p{Mark}_",s="\\p{Decimal_Number}",l=bt(e??""),o=bt(t??""),a=n?`[${r}${s}${l}][${r}${s}${o}]*`:`[${r}${l}][${r}${s}${o}]*`;return E?fL(a):a};function DS(e,t){const E=e.slice(0,t).split(/\n/);return{line:E.length,col:E[E.length-1].length+1}}class GL{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.index0;)if(n=this.matchSection(wR,t))E+=n,r++;else if(n=this.matchSection(HL,t))E+=n,r--;else if(n=this.matchSection(gL,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 BL{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 GL(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 vL:/(\/\*[^]*?\*\/)/uy},{type:v.LINE_COMMENT,regex:ML((E=t.lineCommentTypes)!==null&&E!==void 0?E:["--"])},{type:v.QUOTED_IDENTIFIER,regex:YR(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:qt((n=t.reservedKeywordPhrases)!==null&&n!==void 0?n:[],t.identChars),text:We},{type:v.RESERVED_DATA_TYPE_PHRASE,regex:qt((r=t.reservedDataTypePhrases)!==null&&r!==void 0?r:[],t.identChars),text:We},{type:v.CASE,regex:/CASE\b/iuy,text:We},{type:v.END,regex:/END\b/iuy,text:We},{type:v.BETWEEN,regex:/BETWEEN\b/iuy,text:We},{type:v.LIMIT,regex:t.reservedClauses.includes("LIMIT")?/LIMIT\b/iuy:void 0,text:We},{type:v.RESERVED_CLAUSE,regex:qt(t.reservedClauses,t.identChars),text:We},{type:v.RESERVED_SELECT,regex:qt(t.reservedSelect,t.identChars),text:We},{type:v.RESERVED_SET_OPERATION,regex:qt(t.reservedSetOperations,t.identChars),text:We},{type:v.WHEN,regex:/WHEN\b/iuy,text:We},{type:v.ELSE,regex:/ELSE\b/iuy,text:We},{type:v.THEN,regex:/THEN\b/iuy,text:We},{type:v.RESERVED_JOIN,regex:qt(t.reservedJoins,t.identChars),text:We},{type:v.AND,regex:/AND\b/iuy,text:We},{type:v.OR,regex:/OR\b/iuy,text:We},{type:v.XOR,regex:t.supportsXor?/XOR\b/iuy:void 0,text:We},...t.operatorKeyword?[{type:v.OPERATOR,regex:/OPERATOR *\([^)]+\)/iuy}]:[],{type:v.RESERVED_FUNCTION_NAME,regex:qt(t.reservedFunctionNames,t.identChars),text:We},{type:v.RESERVED_DATA_TYPE,regex:qt(t.reservedDataTypes,t.identChars),text:We},{type:v.RESERVED_KEYWORD,regex:qt(t.reservedKeywords,t.identChars),text:We}])}buildRulesAfterParams(t){var E,n;return this.validRules([{type:v.VARIABLE,regex:t.variableTypes?xL(t.variableTypes):void 0},{type:v.STRING,regex:YR(t.stringTypes)},{type:v.IDENTIFIER,regex:yL(t.identChars)},{type:v.DELIMITER,regex:/[;]/uy},{type:v.COMMA,regex:/[,]/y},{type:v.OPEN_PAREN,regex:vR("open",t.extraParens)},{type:v.CLOSE_PAREN,regex:vR("close",t.extraParens)},{type:v.OPERATOR,regex:BR(["+","-","/",">","<","=","<>","<=",">=","!=",...(E=t.operators)!==null&&E!==void 0?E:[]])},{type:v.ASTERISK,regex:/[*]/uy},{type:v.PROPERTY_ACCESS_OPERATOR,regex:BR([".",...(n=t.propertyAccessOperators)!==null&&n!==void 0?n:[]])}])}buildParamRules(t,E){var n,r,s,l,o;const a={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||((s=t.paramTypes)===null||s===void 0?void 0:s.numbered)||[],positional:typeof E?.positional=="boolean"?E.positional:(l=t.paramTypes)===null||l===void 0?void 0:l.positional,custom:E?.custom||((o=t.paramTypes)===null||o===void 0?void 0:o.custom)||[]};return this.validRules([{type:v.NAMED_PARAMETER,regex:tl(a.named,dS(t.paramChars||t.identChars)),key:R=>R.slice(1)},{type:v.QUOTED_PARAMETER,regex:tl(a.quoted,_S(t.identTypes)),key:R=>(({tokenKey:A,quoteChar:N})=>A.replace(new RegExp(bt("\\"+N),"gu"),N))({tokenKey:R.slice(2,-1),quoteChar:R.slice(-1)})},{type:v.NUMBERED_PARAMETER,regex:tl(a.numbered,"[0-9]+"),key:R=>R.slice(1)},{type:v.POSITIONAL_PARAMETER,regex:a.positional?/[?]/y:void 0},...a.custom.map(R=>{var A;return{type:v.CUSTOM_PARAMETER,regex:en(R.regex),key:(A=R.key)!==null&&A!==void 0?A:N=>N}})])}validRules(t){return t.filter(E=>!!E.regex)}}const We=e=>is(e.toUpperCase()),VR=new Map,FL=e=>{let t=VR.get(e);return t||(t=YL(e),VR.set(e,t)),t},YL=e=>({tokenizer:new BL(e.tokenizerOptions,e.name),formatOptions:wL(e.formatOptions)}),wL=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 VL(e){return e.indentStyle==="tabularLeft"||e.indentStyle==="tabularRight"?" ".repeat(10):e.useTabs?" ":" ".repeat(e.tabWidth)}function rn(e){return e.indentStyle==="tabularLeft"||e.indentStyle==="tabularRight"}class bL{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 PS={exports:{}};(function(e){(function(t,E){e.exports?e.exports=E():t.nearley=E()})(yS,function(){function t(R,A,N){return this.id=++t.highestId,this.name=R,this.symbols=A,this.postprocess=N,this}t.highestId=0,t.prototype.toString=function(R){var A=typeof R>"u"?this.symbols.map(a).join(" "):this.symbols.slice(0,R).map(a).join(" ")+" ● "+this.symbols.slice(R).map(a).join(" ");return this.name+" → "+A};function E(R,A,N,i){this.rule=R,this.dot=A,this.reference=N,this.data=[],this.wantedBy=i,this.isComplete=this.dot===R.symbols.length}E.prototype.toString=function(){return"{"+this.rule.toString(this.dot)+"}, from: "+(this.reference||0)},E.prototype.nextState=function(R){var A=new E(this.rule,this.dot+1,this.reference,this.wantedBy);return A.left=this,A.right=R,A.isComplete&&(A.data=A.build(),A.right=void 0),A},E.prototype.build=function(){var R=[],A=this;do R.push(A.right.data),A=A.left;while(A.left);return R.reverse(),R},E.prototype.finish=function(){this.rule.postprocess&&(this.data=this.rule.postprocess(this.data,this.reference,l.fail))};function n(R,A){this.grammar=R,this.index=A,this.states=[],this.wants={},this.scannable=[],this.completed={}}n.prototype.process=function(R){for(var A=this.states,N=this.wants,i=this.completed,O=0;O0&&A.push(" ^ "+i+" more lines identical to this"),i=0,A.push(" "+u)),N=u}},l.prototype.getSymbolDisplay=function(R){return o(R)},l.prototype.buildFirstStateStack=function(R,A){if(A.indexOf(R)!==-1)return null;if(R.wantedBy.length===0)return[R];var N=R.wantedBy[0],i=[R].concat(A),O=this.buildFirstStateStack(N,i);return O===null?null:[R].concat(O)},l.prototype.save=function(){var R=this.table[this.current];return R.lexerState=this.lexerState,R},l.prototype.restore=function(R){var A=R.index;this.current=A,this.table[A]=R,this.table.splice(A+1),this.lexerState=R.lexerState,this.results=this.finish()},l.prototype.rewind=function(R){if(!this.options.keepHistory)throw new Error("set option `keepHistory` to enable rewinding");this.restore(this.table[R])},l.prototype.finish=function(){var R=[],A=this.grammar.start,N=this.table[this.table.length-1];return N.states.forEach(function(i){i.rule.name===A&&i.dot===i.rule.symbols.length&&i.reference===0&&i.data!==l.fail&&R.push(i)}),R.map(function(i){return i.data})};function o(R){var A=typeof R;if(A==="string")return R;if(A==="object"){if(R.literal)return JSON.stringify(R.literal);if(R instanceof RegExp)return"character matching "+R;if(R.type)return R.type+" token";if(R.test)return"token matching "+String(R.test);throw new Error("Unknown symbol type: "+R)}}function a(R){var A=typeof R;if(A==="string")return R;if(A==="object"){if(R.literal)return JSON.stringify(R.literal);if(R instanceof RegExp)return R.toString();if(R.type)return"%"+R.type;if(R.test)return"<"+String(R.test)+">";throw new Error("Unknown symbol type: "+R)}}return{Parser:l,Grammar:r,Rule:t}})})(PS);var WL=PS.exports;const XL=QR(WL);function KL(e){return e.map($L).map(jL).map(kL).map(JL).map(zL)}const $L=(e,t,E)=>{if(cS(e.type)){const n=QL(E,t);if(n&&n.type===v.PROPERTY_ACCESS_OPERATOR)return Object.assign(Object.assign({},e),{type:v.IDENTIFIER,text:e.raw});const r=Yn(E,t);if(r&&r.type===v.PROPERTY_ACCESS_OPERATOR)return Object.assign(Object.assign({},e),{type:v.IDENTIFIER,text:e.raw})}return e},jL=(e,t,E)=>{if(e.type===v.RESERVED_FUNCTION_NAME){const n=Yn(E,t);if(!n||!pS(n))return Object.assign(Object.assign({},e),{type:v.IDENTIFIER,text:e.raw})}return e},kL=(e,t,E)=>{if(e.type===v.RESERVED_DATA_TYPE){const n=Yn(E,t);if(n&&pS(n))return Object.assign(Object.assign({},e),{type:v.RESERVED_PARAMETERIZED_DATA_TYPE})}return e},JL=(e,t,E)=>{if(e.type===v.IDENTIFIER){const n=Yn(E,t);if(n&&fS(n))return Object.assign(Object.assign({},e),{type:v.ARRAY_IDENTIFIER})}return e},zL=(e,t,E)=>{if(e.type===v.RESERVED_DATA_TYPE){const n=Yn(E,t);if(n&&fS(n))return Object.assign(Object.assign({},e),{type:v.ARRAY_KEYWORD})}return e},QL=(e,t)=>Yn(e,t,-1),Yn=(e,t,E=1)=>{let n=1;for(;e[t+n*E]&&ZL(e[t+n*E]);)n++;return e[t+n*E]},pS=e=>e.type===v.OPEN_PAREN&&e.text==="(",fS=e=>e.type===v.OPEN_PAREN&&e.text==="[",ZL=e=>e.type===v.BLOCK_COMMENT||e.type===v.LINE_COMMENT;class mS{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}=DS(this.input,t.start);return`Parse error at token: ${t.text} at line ${E} column ${n}`}has(t){return t in v}}var Z;(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"})(Z=Z||(Z={}));function El(e){return e[0]}const re=new mS(e=>[]),FE=([[e]])=>e,$e=e=>({type:Z.keyword,tokenType:e.type,text:e.text,raw:e.raw}),bR=e=>({type:Z.data_type,text:e.text,raw:e.raw}),je=(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),qL=(e,{leading:t,trailing:E})=>{if(t?.length){const[n,...r]=e;e=[je(n,{leading:t}),...r]}if(E?.length){const n=e.slice(0,-1),r=e[e.length-1];e=[...n,je(r,{trailing:E})]}return e},e_={Lexer:re,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:[re.has("DELIMITER")?{type:"DELIMITER"}:DELIMITER]},{name:"statement$subexpression$1",symbols:[re.has("EOF")?{type:"EOF"}:EOF]},{name:"statement",symbols:["expressions_or_clauses","statement$subexpression$1"],postprocess:([e,[t]])=>({type:Z.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:FE},{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:[re.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:El},{name:"limit_clause$ebnf$1",symbols:[],postprocess:()=>null},{name:"limit_clause",symbols:[re.has("LIMIT")?{type:"LIMIT"}:LIMIT,"_","expression_chain_","limit_clause$ebnf$1"],postprocess:([e,t,E,n])=>{if(n){const[r,s]=n;return{type:Z.limit_clause,limitKw:je($e(e),{trailing:t}),offset:E,count:s}}else return{type:Z.limit_clause,limitKw:je($e(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:[re.has("RESERVED_SELECT")?{type:"RESERVED_SELECT"}:RESERVED_SELECT,"select_clause$subexpression$1"],postprocess:([e,[t,E]])=>({type:Z.clause,nameKw:$e(e),children:[t,...E]})},{name:"select_clause",symbols:[re.has("RESERVED_SELECT")?{type:"RESERVED_SELECT"}:RESERVED_SELECT],postprocess:([e])=>({type:Z.clause,nameKw:$e(e),children:[]})},{name:"all_columns_asterisk",symbols:[re.has("ASTERISK")?{type:"ASTERISK"}:ASTERISK],postprocess:()=>({type:Z.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:[re.has("RESERVED_CLAUSE")?{type:"RESERVED_CLAUSE"}:RESERVED_CLAUSE,"other_clause$ebnf$1"],postprocess:([e,t])=>({type:Z.clause,nameKw:$e(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:[re.has("RESERVED_SET_OPERATION")?{type:"RESERVED_SET_OPERATION"}:RESERVED_SET_OPERATION,"set_operation$ebnf$1"],postprocess:([e,t])=>({type:Z.set_operation,nameKw:$e(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:El},{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])=>je(e,{trailing:t})},{name:"_expression_with_comments",symbols:["_","expression"],postprocess:([e,t])=>je(t,{leading:e})},{name:"_andless_expression_with_comments",symbols:["_","andless_expression"],postprocess:([e,t])=>je(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:FE},{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:FE},{name:"expression$subexpression$1",symbols:["andless_expression"]},{name:"expression$subexpression$1",symbols:["logic_operator"]},{name:"expression",symbols:["expression$subexpression$1"],postprocess:FE},{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:FE},{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:FE},{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:FE},{name:"array_subscript",symbols:[re.has("ARRAY_IDENTIFIER")?{type:"ARRAY_IDENTIFIER"}:ARRAY_IDENTIFIER,"_","square_brackets"],postprocess:([e,t,E])=>({type:Z.array_subscript,array:je({type:Z.identifier,quoted:!1,text:e.text},{trailing:t}),parenthesis:E})},{name:"array_subscript",symbols:[re.has("ARRAY_KEYWORD")?{type:"ARRAY_KEYWORD"}:ARRAY_KEYWORD,"_","square_brackets"],postprocess:([e,t,E])=>({type:Z.array_subscript,array:je($e(e),{trailing:t}),parenthesis:E})},{name:"function_call",symbols:[re.has("RESERVED_FUNCTION_NAME")?{type:"RESERVED_FUNCTION_NAME"}:RESERVED_FUNCTION_NAME,"_","parenthesis"],postprocess:([e,t,E])=>({type:Z.function_call,nameKw:je($e(e),{trailing:t}),parenthesis:E})},{name:"parenthesis",symbols:[{literal:"("},"expressions_or_clauses",{literal:")"}],postprocess:([e,t,E])=>({type:Z.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:Z.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:Z.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","_",re.has("PROPERTY_ACCESS_OPERATOR")?{type:"PROPERTY_ACCESS_OPERATOR"}:PROPERTY_ACCESS_OPERATOR,"_","property_access$subexpression$1"],postprocess:([e,t,E,n,[r]])=>({type:Z.property_access,object:je(e,{trailing:t}),operator:E.text,property:je(r,{leading:n})})},{name:"between_predicate",symbols:[re.has("BETWEEN")?{type:"BETWEEN"}:BETWEEN,"_","andless_expression_chain","_",re.has("AND")?{type:"AND"}:AND,"_","andless_expression"],postprocess:([e,t,E,n,r,s,l])=>({type:Z.between_predicate,betweenKw:$e(e),expr1:qL(E,{leading:t,trailing:n}),andKw:$e(r),expr2:[je(l,{leading:s})]})},{name:"case_expression$ebnf$1",symbols:["expression_chain_"],postprocess:El},{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:[re.has("CASE")?{type:"CASE"}:CASE,"_","case_expression$ebnf$1","case_expression$ebnf$2",re.has("END")?{type:"END"}:END],postprocess:([e,t,E,n,r])=>({type:Z.case_expression,caseKw:je($e(e),{trailing:t}),endKw:$e(r),expr:E||[],clauses:n})},{name:"case_clause",symbols:[re.has("WHEN")?{type:"WHEN"}:WHEN,"_","expression_chain_",re.has("THEN")?{type:"THEN"}:THEN,"_","expression_chain_"],postprocess:([e,t,E,n,r,s])=>({type:Z.case_when,whenKw:je($e(e),{trailing:t}),thenKw:je($e(n),{trailing:r}),condition:E,result:s})},{name:"case_clause",symbols:[re.has("ELSE")?{type:"ELSE"}:ELSE,"_","expression_chain_"],postprocess:([e,t,E])=>({type:Z.case_else,elseKw:je($e(e),{trailing:t}),result:E})},{name:"comma$subexpression$1",symbols:[re.has("COMMA")?{type:"COMMA"}:COMMA]},{name:"comma",symbols:["comma$subexpression$1"],postprocess:([[e]])=>({type:Z.comma})},{name:"asterisk$subexpression$1",symbols:[re.has("ASTERISK")?{type:"ASTERISK"}:ASTERISK]},{name:"asterisk",symbols:["asterisk$subexpression$1"],postprocess:([[e]])=>({type:Z.operator,text:e.text})},{name:"operator$subexpression$1",symbols:[re.has("OPERATOR")?{type:"OPERATOR"}:OPERATOR]},{name:"operator",symbols:["operator$subexpression$1"],postprocess:([[e]])=>({type:Z.operator,text:e.text})},{name:"identifier$subexpression$1",symbols:[re.has("IDENTIFIER")?{type:"IDENTIFIER"}:IDENTIFIER]},{name:"identifier$subexpression$1",symbols:[re.has("QUOTED_IDENTIFIER")?{type:"QUOTED_IDENTIFIER"}:QUOTED_IDENTIFIER]},{name:"identifier$subexpression$1",symbols:[re.has("VARIABLE")?{type:"VARIABLE"}:VARIABLE]},{name:"identifier",symbols:["identifier$subexpression$1"],postprocess:([[e]])=>({type:Z.identifier,quoted:e.type!=="IDENTIFIER",text:e.text})},{name:"parameter$subexpression$1",symbols:[re.has("NAMED_PARAMETER")?{type:"NAMED_PARAMETER"}:NAMED_PARAMETER]},{name:"parameter$subexpression$1",symbols:[re.has("QUOTED_PARAMETER")?{type:"QUOTED_PARAMETER"}:QUOTED_PARAMETER]},{name:"parameter$subexpression$1",symbols:[re.has("NUMBERED_PARAMETER")?{type:"NUMBERED_PARAMETER"}:NUMBERED_PARAMETER]},{name:"parameter$subexpression$1",symbols:[re.has("POSITIONAL_PARAMETER")?{type:"POSITIONAL_PARAMETER"}:POSITIONAL_PARAMETER]},{name:"parameter$subexpression$1",symbols:[re.has("CUSTOM_PARAMETER")?{type:"CUSTOM_PARAMETER"}:CUSTOM_PARAMETER]},{name:"parameter",symbols:["parameter$subexpression$1"],postprocess:([[e]])=>({type:Z.parameter,key:e.key,text:e.text})},{name:"literal$subexpression$1",symbols:[re.has("NUMBER")?{type:"NUMBER"}:NUMBER]},{name:"literal$subexpression$1",symbols:[re.has("STRING")?{type:"STRING"}:STRING]},{name:"literal",symbols:["literal$subexpression$1"],postprocess:([[e]])=>({type:Z.literal,text:e.text})},{name:"keyword$subexpression$1",symbols:[re.has("RESERVED_KEYWORD")?{type:"RESERVED_KEYWORD"}:RESERVED_KEYWORD]},{name:"keyword$subexpression$1",symbols:[re.has("RESERVED_KEYWORD_PHRASE")?{type:"RESERVED_KEYWORD_PHRASE"}:RESERVED_KEYWORD_PHRASE]},{name:"keyword$subexpression$1",symbols:[re.has("RESERVED_JOIN")?{type:"RESERVED_JOIN"}:RESERVED_JOIN]},{name:"keyword",symbols:["keyword$subexpression$1"],postprocess:([[e]])=>$e(e)},{name:"data_type$subexpression$1",symbols:[re.has("RESERVED_DATA_TYPE")?{type:"RESERVED_DATA_TYPE"}:RESERVED_DATA_TYPE]},{name:"data_type$subexpression$1",symbols:[re.has("RESERVED_DATA_TYPE_PHRASE")?{type:"RESERVED_DATA_TYPE_PHRASE"}:RESERVED_DATA_TYPE_PHRASE]},{name:"data_type",symbols:["data_type$subexpression$1"],postprocess:([[e]])=>bR(e)},{name:"data_type",symbols:[re.has("RESERVED_PARAMETERIZED_DATA_TYPE")?{type:"RESERVED_PARAMETERIZED_DATA_TYPE"}:RESERVED_PARAMETERIZED_DATA_TYPE,"_","parenthesis"],postprocess:([e,t,E])=>({type:Z.parameterized_data_type,dataType:je(bR(e),{trailing:t}),parenthesis:E})},{name:"logic_operator$subexpression$1",symbols:[re.has("AND")?{type:"AND"}:AND]},{name:"logic_operator$subexpression$1",symbols:[re.has("OR")?{type:"OR"}:OR]},{name:"logic_operator$subexpression$1",symbols:[re.has("XOR")?{type:"XOR"}:XOR]},{name:"logic_operator",symbols:["logic_operator$subexpression$1"],postprocess:([[e]])=>$e(e)},{name:"other_keyword$subexpression$1",symbols:[re.has("WHEN")?{type:"WHEN"}:WHEN]},{name:"other_keyword$subexpression$1",symbols:[re.has("THEN")?{type:"THEN"}:THEN]},{name:"other_keyword$subexpression$1",symbols:[re.has("ELSE")?{type:"ELSE"}:ELSE]},{name:"other_keyword$subexpression$1",symbols:[re.has("END")?{type:"END"}:END]},{name:"other_keyword",symbols:["other_keyword$subexpression$1"],postprocess:([[e]])=>$e(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:[re.has("LINE_COMMENT")?{type:"LINE_COMMENT"}:LINE_COMMENT],postprocess:([e])=>({type:Z.line_comment,text:e.text,precedingWhitespace:e.precedingWhitespace})},{name:"comment",symbols:[re.has("BLOCK_COMMENT")?{type:"BLOCK_COMMENT"}:BLOCK_COMMENT],postprocess:([e])=>({type:Z.block_comment,text:e.text,precedingWhitespace:e.precedingWhitespace})},{name:"comment",symbols:[re.has("DISABLE_COMMENT")?{type:"DISABLE_COMMENT"}:DISABLE_COMMENT],postprocess:([e])=>({type:Z.disable_comment,text:e.text,precedingWhitespace:e.precedingWhitespace})}],ParserStart:"main"},{Parser:t_,Grammar:E_}=XL;function n_(e){let t={};const E=new mS(r=>[...KL(e.tokenize(r,t)),uS(r.length)]),n=new t_(E_.fromCompiled(e_),{lexer:E});return{parse:(r,s)=>{t=s;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 g;(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"})(g=g||(g={}));class MS{constructor(t){this.indentation=t,this.items=[]}add(...t){for(const E of t)switch(E){case g.SPACE:this.items.push(g.SPACE);break;case g.NO_SPACE:this.trimHorizontalWhitespace();break;case g.NO_NEWLINE:this.trimWhitespace();break;case g.NEWLINE:this.trimHorizontalWhitespace(),this.addNewline(g.NEWLINE);break;case g.MANDATORY_NEWLINE:this.trimHorizontalWhitespace(),this.addNewline(g.MANDATORY_NEWLINE);break;case g.INDENT:this.addIndentation();break;case g.SINGLE_INDENT:this.items.push(g.SINGLE_INDENT);break;default:this.items.push(E)}}trimHorizontalWhitespace(){for(;r_(Rr(this.items));)this.items.pop()}trimWhitespace(){for(;s_(Rr(this.items));)this.items.pop()}addNewline(t){if(this.items.length>0)switch(Rr(this.items)){case g.NEWLINE:this.items.pop(),this.items.push(t);break;case g.MANDATORY_NEWLINE:break;default:this.items.push(t);break}}addIndentation(){for(let t=0;tthis.itemToString(t)).join("")}getLayoutItems(){return this.items}itemToString(t){switch(t){case g.SPACE:return" ";case g.NEWLINE:case g.MANDATORY_NEWLINE:return` `;case g.SINGLE_INDENT:return this.indentation.getSingleIndent();default:return t}}}const r_=e=>e===g.SPACE||e===g.SINGLE_INDENT,s_=e=>e===g.SPACE||e===g.SINGLE_INDENT||e===g.NEWLINE;function WR(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 XR(e){return WO(e)||e===v.RESERVED_CLAUSE||e===v.RESERVED_SELECT||e===v.RESERVED_SET_OPERATION||e===v.RESERVED_JOIN||e===v.LIMIT}const nl="top-level",T_="block-level";class US{constructor(t){this.indent=t,this.indentTypes=[]}getSingleIndent(){return this.indent}getLevel(){return this.indentTypes.length}increaseTopLevel(){this.indentTypes.push(nl)}increaseBlockLevel(){this.indentTypes.push(T_)}decreaseTopLevel(){this.indentTypes.length>0&&Rr(this.indentTypes)===nl&&this.indentTypes.pop()}decreaseBlockLevel(){for(;this.indentTypes.length>0&&this.indentTypes.pop()===nl;);}}class l_ extends MS{constructor(t){super(new US("")),this.expressionWidth=t,this.length=0,this.trailingSpace=!1}add(...t){if(t.forEach(E=>this.addToLength(E)),this.length>this.expressionWidth)throw new to;super.add(...t)}addToLength(t){if(typeof t=="string")this.length+=t.length,this.trailingSpace=!1;else{if(t===g.MANDATORY_NEWLINE||t===g.NEWLINE)throw new to;t===g.INDENT||t===g.SINGLE_INDENT||t===g.SPACE?this.trailingSpace||(this.length++,this.trailingSpace=!0):(t===g.NO_NEWLINE||t===g.NO_SPACE)&&this.trailingSpace&&(this.trailingSpace=!1,this.length--)}}}class to extends Error{}class ws{constructor({cfg:t,dialectCfg:E,params:n,layout:r,inline:s=!1}){this.inline=!1,this.nodes=[],this.index=-1,this.cfg=t,this.dialectCfg=E,this.inline=s,this.params=n,this.layout=r}format(t){for(this.nodes=t,this.index=0;this.index{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 Z.data_type:E=this.showDataType(t.array);break;case Z.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(g.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(g.NO_SPACE,t.closeParen,g.SPACE)):(this.layout.add(t.openParen,g.NEWLINE),rn(this.cfg)?(this.layout.add(g.INDENT),this.layout=this.formatSubExpression(t.children)):(this.layout.indentation.increaseBlockLevel(),this.layout.add(g.INDENT),this.layout=this.formatSubExpression(t.children),this.layout.indentation.decreaseBlockLevel()),this.layout.add(g.NEWLINE,g.INDENT,t.closeParen,g.SPACE))}formatBetweenPredicate(t){this.layout.add(this.showKw(t.betweenKw),g.SPACE),this.layout=this.formatSubExpression(t.expr1),this.layout.add(g.NO_SPACE,g.SPACE,this.showNonTabularKw(t.andKw),g.SPACE),this.layout=this.formatSubExpression(t.expr2),this.layout.add(g.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(g.NEWLINE,g.INDENT),this.formatNode(t.endKw)}formatCaseWhen(t){this.layout.add(g.NEWLINE,g.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(g.NEWLINE,g.INDENT),this.formatNode(t.elseKw),this.layout=this.formatSubExpression(t.result)}formatClause(t){this.isOnelineClause(t)?this.formatClauseInOnelineStyle(t):rn(this.cfg)?this.formatClauseInTabularStyle(t):this.formatClauseInIndentedStyle(t)}isOnelineClause(t){return rn(this.cfg)?this.dialectCfg.tabularOnelineClauses[t.nameKw.text]:this.dialectCfg.onelineClauses[t.nameKw.text]}formatClauseInIndentedStyle(t){this.layout.add(g.NEWLINE,g.INDENT,this.showKw(t.nameKw),g.NEWLINE),this.layout.indentation.increaseTopLevel(),this.layout.add(g.INDENT),this.layout=this.formatSubExpression(t.children),this.layout.indentation.decreaseTopLevel()}formatClauseInOnelineStyle(t){this.layout.add(g.NEWLINE,g.INDENT,this.showKw(t.nameKw),g.SPACE),this.layout=this.formatSubExpression(t.children)}formatClauseInTabularStyle(t){this.layout.add(g.NEWLINE,g.INDENT,this.showKw(t.nameKw),g.SPACE),this.layout.indentation.increaseTopLevel(),this.layout=this.formatSubExpression(t.children),this.layout.indentation.decreaseTopLevel()}formatSetOperation(t){this.layout.add(g.NEWLINE,g.INDENT,this.showKw(t.nameKw),g.NEWLINE),this.layout.add(g.INDENT),this.layout=this.formatSubExpression(t.children)}formatLimitClause(t){this.withComments(t.limitKw,()=>{this.layout.add(g.NEWLINE,g.INDENT,this.showKw(t.limitKw))}),this.layout.indentation.increaseTopLevel(),rn(this.cfg)?this.layout.add(g.SPACE):this.layout.add(g.NEWLINE,g.INDENT),t.offset?(this.layout=this.formatSubExpression(t.offset),this.layout.add(g.NO_SPACE,",",g.SPACE),this.layout=this.formatSubExpression(t.count)):this.layout=this.formatSubExpression(t.count),this.layout.indentation.decreaseTopLevel()}formatAllColumnsAsterisk(t){this.layout.add("*",g.SPACE)}formatLiteral(t){this.layout.add(t.text,g.SPACE)}formatIdentifier(t){this.layout.add(this.showIdentifier(t),g.SPACE)}formatParameter(t){this.layout.add(this.params.get(t),g.SPACE)}formatOperator({text:t}){this.cfg.denseOperators||this.dialectCfg.alwaysDenseOperators.includes(t)?this.layout.add(g.NO_SPACE,t):t===":"?this.layout.add(g.NO_SPACE,t,g.SPACE):this.layout.add(t,g.SPACE)}formatComma(t){this.inline?this.layout.add(g.NO_SPACE,",",g.SPACE):this.layout.add(g.NO_SPACE,",",g.NEWLINE,g.INDENT)}withComments(t,E){this.formatComments(t.leadingComments),E(),this.formatComments(t.trailingComments)}formatComments(t){t&&t.forEach(E=>{E.type===Z.line_comment?this.formatLineComment(E):this.formatBlockComment(E)})}formatLineComment(t){el(t.precedingWhitespace||"")?this.layout.add(g.NEWLINE,g.INDENT,t.text,g.MANDATORY_NEWLINE,g.INDENT):this.layout.getLayoutItems().length>0?this.layout.add(g.NO_NEWLINE,g.SPACE,t.text,g.MANDATORY_NEWLINE,g.INDENT):this.layout.add(t.text,g.MANDATORY_NEWLINE,g.INDENT)}formatBlockComment(t){t.type===Z.block_comment&&this.isMultilineBlockComment(t)?(this.splitBlockComment(t.text).forEach(E=>{this.layout.add(g.NEWLINE,g.INDENT,E)}),this.layout.add(g.NEWLINE,g.INDENT)):this.layout.add(t.text,g.SPACE)}isMultilineBlockComment(t){return el(t.text)||el(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(Rr(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 ws({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 ws({cfg:this.cfg,dialectCfg:this.dialectCfg,params:this.params,layout:new l_(this.cfg.expressionWidth),inline:!0}).format(t)}catch(n){if(n instanceof to){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){rn(this.cfg)?(this.layout.indentation.decreaseTopLevel(),this.layout.add(g.NEWLINE,g.INDENT,this.showKw(t),g.SPACE),this.layout.indentation.increaseTopLevel()):this.layout.add(g.NEWLINE,g.INDENT,this.showKw(t),g.SPACE)}formatKeyword(t){this.layout.add(this.showKw(t),g.SPACE)}formatLogicalOperator(t){this.cfg.logicalOperatorNewline==="before"?rn(this.cfg)?(this.layout.indentation.decreaseTopLevel(),this.layout.add(g.NEWLINE,g.INDENT,this.showKw(t),g.SPACE),this.layout.indentation.increaseTopLevel()):this.layout.add(g.NEWLINE,g.INDENT,this.showKw(t),g.SPACE):this.layout.add(this.showKw(t),g.NEWLINE,g.INDENT)}formatDataType(t){this.layout.add(this.showDataType(t),g.SPACE)}showKw(t){return XR(t.tokenType)?WR(this.showNonTabularKw(t),this.cfg.indentStyle):this.showNonTabularKw(t)}showNonTabularKw(t){switch(this.cfg.keywordCase){case"preserve":return is(t.raw);case"upper":return t.text;case"lower":return t.text.toLowerCase()}}showFunctionKw(t){return XR(t.tokenType)?WR(this.showNonTabularFunctionKw(t),this.cfg.indentStyle):this.showNonTabularFunctionKw(t)}showNonTabularFunctionKw(t){switch(this.cfg.functionCase){case"preserve":return is(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 is(t.raw);case"upper":return t.text;case"lower":return t.text.toLowerCase()}}}class o_{constructor(t,E){this.dialect=t,this.cfg=E,this.params=new bL(this.cfg.params)}format(t){const E=this.parse(t);return this.formatAst(E).trimEnd()}parse(t){return n_(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 ws({cfg:this.cfg,dialectCfg:this.dialect.formatOptions,params:this.params,layout:new MS(new US(VL(this.cfg)))}).format(t.children);return t.hasSemicolon&&(this.cfg.newlineBeforeSemicolon?E.add(g.NEWLINE,";"):E.add(g.NO_NEWLINE,";")),E.toString()}}class As extends Error{}function a_(e){const t=["multilineLists","newlineBeforeOpenParen","newlineBeforeCloseParen","aliasAs","commaPosition","tabulateAlias"];for(const E of t)if(E in e)throw new As(`${E} config is no more supported.`);if(e.expressionWidth<=0)throw new As(`expressionWidth config must be positive number. Received ${e.expressionWidth} instead.`);if(e.params&&!R_(e.params)&&console.warn('WARNING: All "params" option values should be strings.'),e.paramTypes&&!i_(e.paramTypes))throw new As("Empty regex given in custom paramTypes. That would result in matching infinite amount of parameters.");return e}function R_(e){return(e instanceof Array?e:Object.values(e)).every(E=>typeof E=="string")}function i_(e){return e.custom&&Array.isArray(e.custom)?e.custom.every(t=>t.regex!==""):!0}var A_=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{if(typeof t.language=="string"&&!S_.includes(t.language))throw new As(`Unsupported SQL dialect: ${t.language}`);const E=hS[t.language||"sql"];return O_(e,Object.assign(Object.assign({},t),{dialect:PL[E]}))},O_=(e,t)=>{var{dialect:E}=t,n=A_(t,["dialect"]);if(typeof e!="string")throw new Error("Invalid query argument. Expected string, instead got "+typeof e);const r=a_(Object.assign(Object.assign({},N_),n));return new o_(FL(E),r).format(e)},Jn=new Map,KR=(e,t)=>{if(e==null)return"";const E=`${e}-${t}`;if(Jn.has(E))return Jn.get(E);const n=String(e),r=(t||"").toLowerCase(),s=r.includes("datetime")||r.includes("timestamp"),l=r.includes("date")&&!s,o=/^(\d{4})-(\d{2})-(\d{2})[T ](\d{2}):(\d{2}):(\d{2})/,a=/^(\d{4})-(\d{2})-(\d{2})$/;let R=n;const A=n.match(o),N=n.match(a);if(s||A){if(A){const[,i,O,C,u,D,I]=A;R=`${i}/${O}/${C} ${u}:${D}:${I}`}}else if((l||N)&&N){const[,i,O,C]=N;R=`${i}/${O}/${C}`}return Jn.size>1e4&&Jn.clear(),Jn.set(E,R),R},rl=e=>{if(!e)return 0;let t=0;for(let E=0;E255?14:8;return t},xS=f.memo(function({columns:t,data:E,showColumnInfo:n=!1,editable:r=!1,primaryKeyColumn:s,onCellChange:l,onDeleteRow:o,onDeleteRows:a,onRefresh:R,modifiedCells:A,rowHeight:N=28,overscan:i=20}){const[O,C]=f.useState(new Set),u=f.useRef(null),D=f.useRef(0),I=f.useRef(0),[,S]=f.useState(0),[c,L]=f.useState(0),[B,p]=f.useState(null),[P,y]=f.useState(""),[Y,K]=f.useState(null),oe=f.useRef(null),[_e,F]=f.useState(""),[He,Ie]=f.useState(!1),[me,le]=f.useState(0),X=f.useRef(null),[ee,te]=f.useState(!1),[Ee,Re]=f.useState(new Set),[Fe,Ye]=f.useState(null),[Me,Ve]=f.useState(!1),[be,ze]=f.useState(null),Et=f.useMemo(()=>{const G=new Set;return Ee.forEach(x=>{const W=x.indexOf("-");W>0&&G.add(parseInt(x.substring(0,W)))}),G},[Ee]),iE=f.useMemo(()=>t.some(G=>G.comment),[t]),Mt=n?iE?58:44:28,Oe=r?48:0,Ce=f.useMemo(()=>[...t].sort((G,x)=>{const W=O.has(G.name)?0:1,Ae=O.has(x.name)?0:1;return W-Ae}),[t,O]),Lt=f.useMemo(()=>{const G={};for(const H of Ce){let z=rl(H.name)+24+20;n&&H.type&&(z=Math.max(z,rl(H.type)+24));let de=0;const ot=Math.min(E.length,100);for(let Le=0;Le{const G={};let x=Oe;for(const W of Ce)O.has(W.name)&&(G[W.name]=x,x+=Lt[W.name]||100);return G},[Ce,O,Lt,Oe]),zt=f.useMemo(()=>{if(!_e)return new Set;const G=new Set,x=_e.toLowerCase();for(let W=0;W[...zt],[zt]),Qe=f.useMemo(()=>{const G=D.current,x=Math.max(0,Math.floor(G/N)-i),W=Math.ceil(c/N),Ae=Math.min(E.length-1,x+W+i*2);return{startIndex:x,endIndex:Ae,totalHeight:E.length*N,offsetY:x*N}},[E.length,D.current,c,N,i]),ve=f.useMemo(()=>Oe+Ce.reduce((G,x)=>G+(Lt[x.name]||100),0),[Ce,Lt,Oe]);f.useEffect(()=>{const G=u.current;if(!G)return;const x=()=>L(G.clientHeight-Mt);let W=null;const Ae=()=>{W||(W=requestAnimationFrame(()=>{D.current=G.scrollTop,I.current=G.scrollLeft,S(z=>z+1),W=null}))};x(),G.addEventListener("scroll",Ae,{passive:!0});const H=new ResizeObserver(x);return H.observe(G),()=>{G.removeEventListener("scroll",Ae),H.disconnect(),W&&cancelAnimationFrame(W)}},[Mt]);const AE=f.useCallback(G=>{C(x=>{const W=new Set(x);return W.has(G)?W.delete(G):W.add(G),W})},[]),St=f.useCallback(G=>Ce.findIndex(x=>x.name===G),[Ce]),lt=f.useCallback((G,x)=>{const W=new Set,Ae=Math.min(G.row,x.row),H=Math.max(G.row,x.row),z=Math.min(St(G.col),St(x.col)),de=Math.max(St(G.col),St(x.col));for(let ot=Ae;ot<=H;ot++)for(let Le=z;Le<=de;Le++)Ce[Le]&&W.add(`${ot}-${Ce[Le].name}`);return W},[Ce,St]),Qt=f.useCallback((G,x,W)=>{if(W.button!==0)return;const Ae=`${G}-${x}`;W.shiftKey&&be?Re(lt(be,{row:G,col:x})):W.ctrlKey||W.metaKey?(Re(H=>{const z=new Set(H);return z.has(Ae)?z.delete(Ae):z.add(Ae),z}),ze({row:G,col:x})):(Re(new Set([Ae])),Ye({row:G,col:x}),ze({row:G,col:x}),Ve(!0))},[be,lt]),SE=f.useCallback((G,x)=>{Me&&Fe&&Re(lt(Fe,{row:G,col:x}))},[Me,Fe,lt]);f.useEffect(()=>{const G=()=>Ve(!1);return window.addEventListener("mouseup",G),()=>window.removeEventListener("mouseup",G)},[]);const ue=f.useCallback(G=>{if(j.length===0)return;const x=j[G];if(!x)return;const W=x.indexOf("-"),Ae=parseInt(x.substring(0,W)),H=x.substring(W+1),z=u.current;z&&(z.scrollTop=Math.max(0,Ae*N-c/2)),Re(new Set([x])),ze({row:Ae,col:H})},[j,N,c]),m=f.useCallback(()=>{if(j.length===0)return;const G=(me+1)%j.length;le(G),ue(G)},[me,j.length,ue]),w=f.useCallback(()=>{if(j.length===0)return;const G=(me-1+j.length)%j.length;le(G),ue(G)},[me,j.length,ue]);f.useEffect(()=>{const G=x=>{(x.ctrlKey||x.metaKey)&&x.key==="f"&&ee&&(x.preventDefault(),Ie(!0),setTimeout(()=>X.current?.focus(),50)),x.key==="Escape"&&He&&(Ie(!1),F(""))};return window.addEventListener("keydown",G),()=>window.removeEventListener("keydown",G)},[ee,He]);const J=f.useCallback(()=>{if(Ee.size===E.length*Ce.length)Re(new Set);else{const G=new Set;for(let x=0;x{Re(new Set),ze(null),p(null)},[]),{startIndex:b,endIndex:ne,totalHeight:ie,offsetY:_t}=Qe,NE=I.current;return T.jsxs("div",{className:"navi-table-container",tabIndex:0,onFocus:()=>te(!0),onBlur:G=>{G.currentTarget.contains(G.relatedTarget)||te(!1)},onMouseEnter:()=>te(!0),children:[He&&T.jsxs("div",{className:"navi-search-bar",children:[T.jsx(NS,{size:14,className:"text-gray-400"}),T.jsx("input",{ref:X,type:"text",value:_e,onChange:G=>F(G.target.value),placeholder:"搜索数据... (Enter 下一个)",className:"navi-search-input",onKeyDown:G=>{G.key==="Enter"&&!G.shiftKey?(G.preventDefault(),m()):G.key==="Enter"&&G.shiftKey&&(G.preventDefault(),w())}}),_e&&T.jsx("span",{className:"text-xs text-gray-500",children:j.length>0?`${me+1}/${j.length}`:"0/0"}),T.jsx("button",{onClick:w,disabled:j.length===0,className:"navi-search-btn",children:T.jsx(RS,{size:16})}),T.jsx("button",{onClick:m,disabled:j.length===0,className:"navi-search-btn",children:T.jsx(xn,{size:16})}),T.jsx("button",{onClick:()=>{Ie(!1),F("")},className:"navi-search-btn",children:T.jsx(RE,{size:16})})]}),T.jsxs("div",{ref:u,className:"navi-scroll-container",onClick:G=>{(G.target===G.currentTarget||G.target.classList.contains("navi-body"))&&Te()},children:[T.jsxs("div",{className:"navi-header",style:{minWidth:ve},children:[r&&T.jsx("div",{className:"navi-row-number-header",style:{width:Oe},onClick:J,children:"#"}),Ce.map(G=>{const x=O.has(G.name),W=Lt[G.name]||100;return T.jsx("div",{onClick:()=>AE(G.name),className:`navi-header-cell ${x?"pinned":""}`,style:{width:W,minWidth:W,position:x?"sticky":"relative",left:x?Jt[G.name]:"auto",boxShadow:x&&NE>0?"2px 0 4px rgba(0,0,0,0.3)":"none",height:Mt},title:x?`取消固定 ${G.name}`:`固定 ${G.name}`,children:T.jsxs("div",{className:"navi-header-content",children:[T.jsxs("div",{className:"navi-header-row",children:[T.jsx("span",{className:"navi-col-name",children:G.name}),n&&G.key==="PRI"&&T.jsx(Qo,{size:10,className:"text-amber-500"}),T.jsx("span",{className:`navi-pin-icon ${x?"active":""}`,children:x?T.jsx(_O,{size:10}):T.jsx(LO,{size:10})})]}),n&&G.type&&T.jsx("div",{className:"navi-col-type",children:G.type}),n&&G.comment&&T.jsx("div",{className:"navi-col-comment",title:G.comment,children:G.comment})]})},G.name)})]}),T.jsx("div",{className:"navi-body",style:{height:Math.max(ie,c),minWidth:ve},onClick:G=>{G.target===G.currentTarget&&Te()},children:T.jsx("div",{className:"navi-rows-container",style:{transform:`translateY(${_t}px)`},children:Array.from({length:ne-b+1},(G,x)=>{const W=b+x,Ae=E[W];if(!Ae)return null;const H=Et.has(W);return T.jsxs("div",{className:`navi-row ${H?"selected":""}`,style:{height:N},onContextMenu:z=>{if(r){if(z.preventDefault(),Et.size===0){const de=Ce[0]?.name;de&&(Re(new Set([`${W}-${de}`])),ze({row:W,col:de}))}K({x:z.clientX,y:z.clientY,row:W,col:""})}},children:[r&&T.jsx("div",{className:`navi-row-number ${H?"selected":""}`,style:{width:Oe,height:N},onClick:z=>{const de=new Set;for(const ot of Ce)de.add(`${W}-${ot.name}`);z.ctrlKey||z.metaKey?Re(ot=>{const Le=new Set(ot);return de.forEach(he=>{Le.has(he)?Le.delete(he):Le.add(he)}),Le}):(Re(de),ze({row:W,col:Ce[0]?.name||""}))},children:W+1}),Ce.map(z=>{const de=O.has(z.name),ot=Lt[z.name]||100,Le=Ae[z.name],he=`${W}-${z.name}`,wn=B?.row===W&&B?.col===z.name,sT=Ee.has(he),gr=be?.row===W&&be?.col===z.name,TT=A?.has(he),lT=zt.has(he),oT=j[me]===he;let tn=null;Le!=null&&(tn=typeof Le=="object"?JSON.stringify(Le):KR(Le,z.type||""));let Zt="transparent";return oT?Zt="#665500":lT?Zt="rgba(255, 200, 0, 0.15)":gr?Zt="#264f78":sT?Zt="rgba(38, 79, 120, 0.5)":TT?Zt="rgba(249, 115, 22, 0.15)":de&&(Zt="#1e2d3d"),T.jsx("div",{className:"navi-cell",style:{background:Zt,position:de?"sticky":"relative",left:de?Jt[z.name]:"auto",width:ot,minWidth:ot,maxWidth:ot,height:N,boxShadow:de&&NE>0?"2px 0 4px rgba(0,0,0,0.3)":"none",outline:gr?"1px solid #007acc":"none",outlineOffset:"-1px",zIndex:de?10:1},onMouseDown:d=>Qt(W,z.name,d),onMouseEnter:()=>SE(W,z.name),onDoubleClick:()=>{r&&(p({row:W,col:z.name}),y(Le===null?"":String(Le)),setTimeout(()=>oe.current?.focus(),0))},onContextMenu:d=>{d.preventDefault(),d.stopPropagation(),Ee.has(he)||(Re(new Set([he])),ze({row:W,col:z.name})),K({x:d.clientX,y:d.clientY,row:W,col:z.name})},title:tn||"",children:wn?T.jsx("input",{ref:oe,type:"text",value:P,onChange:d=>y(d.target.value),onBlur:()=>{P!==(Le===null?"":String(Le))&&l?.(W,z.name,P===""?null:P),p(null)},onKeyDown:d=>{d.key==="Enter"?(P!==(Le===null?"":String(Le))&&l?.(W,z.name,P===""?null:P),p(null)):d.key==="Escape"&&p(null)},onClick:d=>d.stopPropagation(),onMouseDown:d=>d.stopPropagation(),className:"navi-cell-input",autoFocus:!0}):Le===null?T.jsx("span",{className:"navi-null",children:"NULL"}):Le===""?T.jsx("span",{className:"navi-empty"}):typeof Le=="object"?T.jsx("span",{className:"navi-json",children:tn}):T.jsx("span",{className:"navi-value",children:tn})},z.name)})]},W)})})}),E.length===0&&T.jsx("div",{className:"navi-empty",children:"暂无数据"})]}),Y&&T.jsxs(T.Fragment,{children:[T.jsx("div",{className:"fixed inset-0 z-40",onClick:()=>{K(null),Re(new Set)}}),T.jsxs("div",{className:"navi-context-menu",style:{left:Math.min(Y.x,window.innerWidth-200),top:Math.min(Y.y,window.innerHeight-300)},children:[Ee.size>0&&T.jsxs("div",{className:"navi-context-info",children:["已选 ",Ee.size," 格 · ",Et.size," 行"]}),T.jsxs("button",{className:"navi-context-item",onClick:async()=>{const G=[...Ee][0];if(G){const x=G.indexOf("-"),W=parseInt(G.substring(0,x)),Ae=G.substring(x+1),H=E[W]?.[Ae];H!=null&&await navigator.clipboard.writeText(String(H))}K(null)},children:[T.jsx(nT,{size:13}),T.jsx("span",{children:"复制"}),T.jsx("span",{className:"navi-shortcut",children:"Ctrl+C"})]}),r&&T.jsxs(T.Fragment,{children:[T.jsxs("button",{className:"navi-context-item",onClick:async()=>{if(Y.col&&Ee.size===1){const G=await navigator.clipboard.readText();l?.(Y.row,Y.col,G)}K(null)},children:[T.jsx(AO,{size:13}),T.jsx("span",{children:"粘贴"}),T.jsx("span",{className:"navi-shortcut",children:"Ctrl+V"})]}),T.jsx("div",{className:"navi-context-divider"}),T.jsxs("button",{className:"navi-context-item warning",onClick:()=>{Ee.forEach(G=>{const x=G.indexOf("-"),W=parseInt(G.substring(0,x)),Ae=G.substring(x+1);l?.(W,Ae,null)}),K(null)},children:[T.jsx(NO,{size:13}),T.jsxs("span",{children:["设为 ",T.jsx("span",{className:"font-mono",children:"NULL"})]}),Ee.size>1&&T.jsxs("span",{className:"navi-shortcut",children:[Ee.size,"格"]})]}),T.jsxs("button",{className:"navi-context-item",onClick:()=>{Ee.forEach(G=>{const x=G.indexOf("-"),W=parseInt(G.substring(0,x)),Ae=G.substring(x+1);l?.(W,Ae,"")}),K(null)},children:[T.jsx(pO,{size:13}),T.jsx("span",{children:"设为空字符串"}),Ee.size>1&&T.jsxs("span",{className:"navi-shortcut",children:[Ee.size,"格"]})]}),T.jsx("div",{className:"navi-context-divider"}),T.jsxs("button",{className:"navi-context-item danger",onClick:()=>{if(Et.size>1){const G=[...Et].sort((x,W)=>W-x);a?a(G):G.forEach(x=>o?.(x))}else o?.(Y.row);K(null),Re(new Set)},children:[T.jsx(yE,{size:13}),Et.size>1?`删除 ${Et.size} 行`:"删除此行"]})]}),T.jsx("div",{className:"navi-context-divider"}),T.jsxs("button",{className:"navi-context-item success",onClick:()=>{R?.(),K(null),Re(new Set)},children:[T.jsx(eo,{size:13}),T.jsx("span",{children:"刷新数据"}),T.jsx("span",{className:"navi-shortcut",children:"F5"})]})]})]})]})}),u_=f.lazy(()=>gO(()=>import("./SqlEditor-BZP69oik.js").then(e=>e.S),__vite__mapDeps([0,1]),import.meta.url)),c_=f.memo(()=>T.jsx("div",{className:"h-full flex items-center justify-center bg-metro-dark",children:T.jsxs("div",{className:"flex flex-col items-center gap-3",children:[T.jsx(Mr,{className:"w-8 h-8 animate-spin text-accent-blue"}),T.jsx("span",{className:"text-sm text-text-tertiary",children:"加载编辑器..."})]})})),C_=f.memo(function({tabs:t,activeTab:E,databases:n,tables:r,columns:s,onTabChange:l,onCloseTab:o,onNewQuery:a,onRunQuery:R,onUpdateSql:A,onUpdateTabTitle:N,onLoadTablePage:i,onChangeTablePageSize:O,onNewConnectionWithType:C,onUpdateTableCell:u,onDeleteTableRow:D,onDeleteTableRows:I,onSaveTableChanges:S,onDiscardTableChanges:c,onRefreshTable:L,loadingTables:B}){f.useEffect(()=>{const Y=K=>{if(K.ctrlKey&&K.key==="w"&&(K.preventDefault(),E!=="welcome"&&o(E)),K.ctrlKey&&K.key==="s"){const oe=t.find(_e=>_e.id===E);oe&&"tableName"in oe&&oe.pendingChanges?.size>0&&(K.preventDefault(),S?.(E))}};return window.addEventListener("keydown",Y),()=>window.removeEventListener("keydown",Y)},[E,t,o,S]);const p=t.find(Y=>Y.id===E),P=Y=>"tableName"in Y?Y.tableName:Y.title,y=Y=>"tableName"in Y?T.jsx(Fn,{size:12,className:"text-accent-orange"}):null;return T.jsxs("div",{className:"flex-1 flex flex-col bg-metro-dark",children:[T.jsxs("div",{className:"h-10 bg-metro-bg flex items-stretch px-1 border-b border-metro-border/50 overflow-x-auto",children:[T.jsxs("button",{onClick:()=>l("welcome"),className:`px-5 text-sm flex items-center transition-all duration-150 shrink-0 relative ${E==="welcome"?"bg-metro-dark text-white font-medium":"text-text-secondary hover:text-white hover:bg-metro-hover"}`,children:["主页",E==="welcome"&&T.jsx("span",{className:"absolute bottom-0 left-0 right-0 h-0.5 bg-accent-blue"})]}),t.map(Y=>T.jsxs("div",{className:`px-4 flex items-center gap-2 text-sm group transition-all duration-150 shrink-0 relative ${E===Y.id?"bg-metro-dark text-white font-medium":"text-text-secondary hover:text-white hover:bg-metro-hover"}`,children:[T.jsxs("button",{onClick:()=>l(Y.id),className:"flex items-center gap-2",children:[y(Y),T.jsx("span",{className:"max-w-[120px] truncate",children:P(Y)})]}),T.jsx("button",{onClick:()=>o(Y.id),className:"opacity-0 group-hover:opacity-100 hover:text-accent-red p-0.5 rounded-sm hover:bg-white/10 transition-all",children:T.jsx(RE,{size:14})}),E===Y.id&&T.jsx("span",{className:"absolute bottom-0 left-0 right-0 h-0.5 bg-accent-blue"})]},Y.id)),T.jsx("button",{onClick:a,className:"w-10 flex items-center justify-center text-text-tertiary hover:text-white hover:bg-metro-hover shrink-0 transition-colors",title:"新建查询 (Ctrl+Q)",children:T.jsx(Bn,{size:18})})]}),T.jsx("div",{className:"flex-1 min-h-0",children:E==="welcome"?T.jsx(L_,{onNewQuery:a,onNewConnectionWithType:C}):p?"tableName"in p?T.jsx(__,{tab:p,isLoading:B?.has(p.id),onLoadPage:Y=>i(p.id,Y),onChangePageSize:Y=>O?.(p.id,Y),onCellChange:(Y,K,oe)=>u?.(p.id,Y,K,oe),onDeleteRow:Y=>D?.(p.id,Y),onDeleteRows:Y=>I?.(p.id,Y),onSave:()=>S?.(p.id),onDiscard:()=>c?.(p.id),onRefresh:()=>L?.(p.id)}):T.jsx(d_,{tab:p,databases:n,tables:r,columns:s,onRun:Y=>R(p.id,Y),onUpdateSql:Y=>A(p.id,Y),onUpdateTitle:Y=>N(p.id,Y)}):null})]})}),L_=f.memo(function({onNewQuery:t,onNewConnectionWithType:E}){return T.jsxs("div",{className:"h-full flex flex-col items-center justify-center bg-gradient-to-b from-metro-dark via-metro-dark to-metro-bg relative overflow-hidden",children:[T.jsxs("div",{className:"absolute inset-0 pointer-events-none",children:[T.jsx("div",{className:"absolute top-1/4 left-1/4 w-96 h-96 bg-accent-blue/5 rounded-full blur-3xl"}),T.jsx("div",{className:"absolute bottom-1/4 right-1/4 w-64 h-64 bg-accent-purple/5 rounded-full blur-3xl"})]}),T.jsxs("div",{className:"flex items-center gap-4 mb-3 relative z-10",children:[T.jsx("div",{className:"p-3 bg-gradient-to-br from-accent-blue/20 to-accent-blue/5 rounded-lg",children:T.jsx(vn,{size:48,className:"text-accent-blue"})}),T.jsx("h1",{className:"text-5xl font-light tracking-tight text-white",children:"EasySQL"})]}),T.jsx("p",{className:"text-text-tertiary mb-10 text-lg relative z-10",children:"简洁高效的数据库管理工具"}),T.jsx("button",{onClick:t,className:`px-10 py-3.5 bg-accent-blue hover:bg-accent-blue-hover text-base font-medium transition-all duration-200 shadow-metro hover:shadow-metro-lg relative z-10 hover:translate-y-[-2px]`,children:"开始查询"}),T.jsx("p",{className:"mt-14 text-text-disabled text-sm tracking-wide relative z-10",children:"快速创建数据库连接"}),T.jsx("div",{className:"mt-5 grid grid-cols-5 gap-2 relative z-10",children:Object.entries(_E).slice(0,5).map(([n,r])=>T.jsxs("button",{onClick:()=>r.supported&&E?.(n),className:`metro-tile w-24 h-24 flex flex-col items-center justify-center shadow-metro relative ${r.supported?"cursor-pointer":"cursor-not-allowed"}`,style:{backgroundColor:r.color,opacity:r.supported?1:.4,filter:r.supported?"none":"grayscale(50%)"},title:r.supported?`创建 ${r.name} 连接`:`${r.name} - 即将支持`,disabled:!r.supported,children:[T.jsx("span",{className:"text-3xl mb-2",children:r.icon}),T.jsx("span",{className:"text-xs font-medium text-white/90",children:r.name}),!r.supported&&T.jsx("span",{className:"absolute bottom-1 text-[10px] text-white/60",children:"即将支持"})]},n))}),T.jsx("div",{className:"grid grid-cols-4 gap-2 mt-2 relative z-10",children:Object.entries(_E).slice(5,9).map(([n,r])=>T.jsxs("button",{onClick:()=>r.supported&&E?.(n),className:`metro-tile w-24 h-24 flex flex-col items-center justify-center shadow-metro relative ${r.supported?"cursor-pointer":"cursor-not-allowed"}`,style:{backgroundColor:r.color,opacity:r.supported?1:.4,filter:r.supported?"none":"grayscale(50%)"},title:r.supported?`创建 ${r.name} 连接`:`${r.name} - 即将支持`,disabled:!r.supported,children:[T.jsx("span",{className:"text-3xl mb-2",children:r.icon}),T.jsx("span",{className:"text-xs font-medium text-white/90",children:r.name}),!r.supported&&T.jsx("span",{className:"absolute bottom-1 text-[10px] text-white/60",children:"即将支持"})]},n))})]})}),__=f.memo(function({tab:t,isLoading:E,onLoadPage:n,onChangePageSize:r,onCellChange:s,onDeleteRow:l,onDeleteRows:o,onSave:a,onDiscard:R,onRefresh:A}){const N=Math.ceil(t.total/t.pageSize),i=(t.pendingChanges?.size||0)>0||(t.deletedRows?.size||0)>0,O=t.columns.find(I=>I.key==="PRI")?.name||t.columns[0]?.name,C=new Set;t.pendingChanges?.forEach((I,S)=>{const c=parseInt(S);Object.keys(I).forEach(L=>{C.add(`${c}-${L}`)})});const u=t.data.filter((I,S)=>!t.deletedRows?.has(S)),D=t.data.map((I,S)=>S).filter(I=>!t.deletedRows?.has(I));return T.jsxs("div",{style:{height:"100%",display:"flex",flexDirection:"column"},children:[T.jsxs("div",{className:"bg-metro-bg border-b border-metro-border/50 flex items-center justify-between px-3 gap-2",style:{flexShrink:0,height:36},children:[T.jsxs("div",{className:"flex items-center gap-2 min-w-0",children:[T.jsx(Fn,{size:16,className:"text-accent-orange flex-shrink-0"}),T.jsx("span",{className:"font-medium text-white text-sm truncate",children:t.tableName}),T.jsxs("span",{className:"text-text-tertiary text-xs flex-shrink-0",children:["(",t.total.toLocaleString(),"行)"]}),E&&T.jsxs("div",{className:"flex items-center gap-1.5 text-accent-blue text-xs flex-shrink-0",children:[T.jsx(Mr,{size:12,className:"animate-spin"}),"加载中..."]})]}),i&&T.jsxs("div",{className:"flex items-center gap-2 flex-shrink-0",children:[T.jsxs("span",{className:"text-xs text-accent-orange font-medium px-1.5 py-0.5 bg-accent-orange/10 rounded",children:[(t.pendingChanges?.size||0)+(t.deletedRows?.size||0),"项"]}),T.jsxs("button",{onClick:a,className:"h-6 px-2 bg-accent-green hover:bg-accent-green-hover flex items-center gap-1 text-xs font-medium transition-all",title:"保存修改 (Ctrl+S)",children:[T.jsx(Zo,{size:11}),"保存"]}),T.jsxs("button",{onClick:R,className:"h-6 px-2 bg-metro-surface hover:bg-metro-hover flex items-center gap-1 text-xs transition-all border border-metro-border",children:[T.jsx(DO,{size:11}),"放弃"]})]}),T.jsxs("div",{className:"flex items-center gap-1 flex-shrink-0",children:[T.jsx("button",{onClick:()=>n(t.page-1),disabled:t.page<=1||E,className:"p-0.5 hover:bg-metro-hover disabled:opacity-30 disabled:cursor-not-allowed transition-colors",children:T.jsx(RS,{size:16})}),T.jsxs("span",{className:"text-xs whitespace-nowrap min-w-[70px] text-center",children:[T.jsx("span",{className:"text-accent-blue font-medium",children:t.page}),"/",N,"页"]}),T.jsx("button",{onClick:()=>n(t.page+1),disabled:t.page>=N||E,className:"p-0.5 hover:bg-metro-hover disabled:opacity-30 disabled:cursor-not-allowed transition-colors",children:T.jsx(xn,{size:16})}),T.jsxs("select",{value:t.pageSize,onChange:I=>r?.(parseInt(I.target.value)),disabled:E,className:"h-6 px-1 text-xs bg-metro-surface border border-metro-border text-white rounded cursor-pointer hover:border-text-tertiary focus:border-accent-blue outline-none disabled:opacity-50",title:"每页条数",children:[T.jsx("option",{value:100,children:"100"}),T.jsx("option",{value:500,children:"500"}),T.jsx("option",{value:1e3,children:"1000"}),T.jsx("option",{value:2e3,children:"2000"}),T.jsx("option",{value:5e3,children:"5000"})]})]})]}),T.jsxs("div",{style:{flex:1,position:"relative",overflow:"hidden"},children:[E&&T.jsx("div",{className:"absolute inset-0 bg-metro-dark/80 flex items-center justify-center z-50",children:T.jsxs("div",{className:"flex flex-col items-center gap-3",children:[T.jsx(Mr,{size:32,className:"animate-spin text-accent-blue"}),T.jsx("span",{className:"text-sm text-text-secondary",children:"加载数据中..."})]})}),T.jsx("div",{style:{position:"absolute",top:0,left:0,right:0,bottom:0},children:T.jsx(xS,{columns:t.columns,data:u,showColumnInfo:!0,editable:!0,primaryKeyColumn:O,modifiedCells:C,onCellChange:(I,S,c)=>{const L=D[I];s?.(L,S,c)},onDeleteRow:I=>{const S=D[I];l?.(S)},onDeleteRows:I=>{const S=I.map(c=>D[c]);o?.(S)},onRefresh:A})})]})]})}),d_=f.memo(function({tab:t,databases:E,tables:n,columns:r,onRun:s,onUpdateSql:l,onUpdateTitle:o}){const[a,R]=f.useState(t.sql),[A,N]=f.useState(null),[i,O]=f.useState(!1),C=f.useCallback(()=>{s(a),l(a)},[a,s,l]),u=f.useCallback(async()=>{const P=await se.openFile();P&&!P.error&&(R(P.content),N(P.path),l(P.content),o?.(P.name))},[l,o]),D=f.useCallback(async()=>{const P=await se.saveFile(A,a);P&&!P.error&&(N(P.path),o?.(P.name))},[A,a,o]),I=f.useCallback(()=>{try{const P=I_(a,{language:"mysql",tabWidth:2,keywordCase:"upper",linesBetweenQueries:2});R(P),l(P)}catch(P){console.error("SQL 格式化失败:",P)}},[a,l]),S=f.useCallback(P=>{for(const[,y]of r){const Y=y.find(K=>K.name===P||K.name.toLowerCase()===P.toLowerCase());if(Y)return Y}},[r]),c=f.useCallback(async()=>{if(!t.results||t.results.rows.length===0)return;const P=window.electronAPI;if(!P)return;const y=await P.saveDialog({filters:[{name:"CSV",extensions:["csv"]}],defaultPath:`query_results_${Date.now()}.csv`});if(!y)return;const K=t.results.columns.join(","),oe=t.results.rows.map(_e=>_e.map(F=>F===null?"":typeof F=="string"?`"${F.replace(/"/g,'""')}"`:String(F)).join(",")).join(` `);await P.writeFile(y,`${K} ${oe}`)},[t.results]),L=f.useCallback(async()=>{if(!t.results||t.results.rows.length===0)return;const P=window.electronAPI;if(!P)return;const y=await P.saveDialog({filters:[{name:"SQL",extensions:["sql"]}],defaultPath:`query_results_${Date.now()}.sql`});if(!y)return;const Y="table_name",K=t.results.columns,oe=t.results.rows;let _e=`-- 导出时间: ${new Date().toLocaleString()} `;_e+=`-- 共 ${oe.length} 条记录 `,oe.forEach(F=>{const He=F.map(Ie=>Ie===null?"NULL":typeof Ie=="number"?Ie:`'${String(Ie).replace(/'/g,"''")}'`).join(", ");_e+=`INSERT INTO \`${Y}\` (\`${K.join("`, `")}\`) VALUES (${He}); `}),await P.writeFile(y,_e)},[t.results]),B=t.results?.rows.map(P=>{const y={};return t.results?.columns.forEach((Y,K)=>{y[Y]=P[K]}),y})||[],p=t.results?.columns.map(P=>{const y=S(P);return{name:P,type:y?.type,key:y?.key,comment:y?.comment}})||[];return T.jsxs("div",{style:{height:"100%",display:"flex",flexDirection:"column"},children:[T.jsxs("div",{style:{height:"200px",flexShrink:0,display:"flex",flexDirection:"column",borderBottom:"1px solid #5d5d5d"},children:[T.jsxs("div",{className:"h-10 bg-metro-bg flex items-center px-2 gap-2",style:{flexShrink:0},children:[T.jsxs("button",{onClick:C,className:"h-7 px-4 bg-accent-green hover:bg-accent-green/90 flex items-center gap-1.5 text-sm transition-colors",title:"执行 SQL (Ctrl+Enter)",children:[T.jsx(dO,{size:14,fill:"currentColor"}),"执行"]}),T.jsx("div",{className:"w-px h-5 bg-white/20 mx-1"}),T.jsxs("button",{onClick:u,className:"h-7 px-3 bg-metro-surface hover:bg-metro-surface/80 flex items-center gap-1.5 text-sm transition-colors",title:"打开 SQL 文件 (Ctrl+O)",children:[T.jsx(Ys,{size:14}),"打开"]}),T.jsxs("button",{onClick:D,className:"h-7 px-3 bg-metro-surface hover:bg-metro-surface/80 flex items-center gap-1.5 text-sm transition-colors",title:"保存 SQL 文件 (Ctrl+S)",children:[T.jsx(Zo,{size:14}),"保存"]}),T.jsxs("button",{onClick:I,className:"h-7 px-3 bg-metro-surface hover:bg-metro-surface/80 flex items-center gap-1.5 text-sm transition-colors",title:"格式化 SQL (Ctrl+Shift+F)",children:[T.jsx(oO,{size:14}),"格式化"]}),T.jsx("div",{className:"w-px h-5 bg-white/20 mx-1"}),T.jsxs("div",{className:"relative",children:[T.jsxs("button",{onClick:()=>O(!i),className:"h-7 px-3 bg-metro-surface hover:bg-metro-surface/80 flex items-center gap-1.5 text-sm transition-colors disabled:opacity-40",title:"导出结果",disabled:!t.results||t.results.rows.length===0,children:[T.jsx(iS,{size:14}),"导出"]}),i&&T.jsxs(T.Fragment,{children:[T.jsx("div",{className:"fixed inset-0",onClick:()=>O(!1)}),T.jsxs("div",{className:"absolute top-full left-0 mt-1 bg-metro-surface border border-metro-border rounded shadow-lg z-50 min-w-[140px] animate-fade-in",children:[T.jsxs("button",{onClick:()=>{c(),O(!1)},className:"w-full px-3 py-2 text-left text-sm hover:bg-accent-blue/20 flex items-center gap-2",children:[T.jsx(AS,{size:14,className:"text-accent-green"}),"导出 CSV"]}),T.jsxs("button",{onClick:()=>{L(),O(!1)},className:"w-full px-3 py-2 text-left text-sm hover:bg-accent-blue/20 flex items-center gap-2",children:[T.jsx(Fs,{size:14,className:"text-accent-orange"}),"导出 SQL"]})]})]})]}),T.jsxs("span",{className:"text-xs text-white/40 ml-auto",children:[A&&T.jsx("span",{className:"mr-3 text-accent-blue",children:A.split(/[/\\]/).pop()}),"Ctrl+Enter 执行 | Ctrl+S 保存"]})]}),T.jsx("div",{style:{flex:1,minHeight:0},children:T.jsx(f.Suspense,{fallback:T.jsx(c_,{}),children:T.jsx(u_,{value:a,onChange:R,onRun:C,onSave:D,onOpen:u,onFormat:I,databases:E,tables:n,columns:r})})})]}),T.jsxs("div",{style:{flex:1,display:"flex",flexDirection:"column",minHeight:0},children:[T.jsx("div",{className:"h-9 bg-metro-bg flex items-center px-3 border-b border-metro-border",style:{flexShrink:0},children:T.jsxs("span",{className:"text-sm text-white/60",children:["结果",t.results&&T.jsxs("span",{className:"ml-2 text-white/40",children:["(",t.results.rows.length.toLocaleString()," 行)"]})]})}),T.jsx("div",{style:{flex:1,position:"relative",overflow:"hidden"},children:T.jsx("div",{style:{position:"absolute",top:0,left:0,right:0,bottom:0},children:t.results?T.jsx(xS,{columns:p,data:B,showColumnInfo:!0,onRefresh:()=>s(a)}):T.jsx("div",{className:"h-full flex items-center justify-center text-white/30",children:T.jsxs("div",{className:"flex flex-col items-center gap-2",children:[T.jsx(vn,{size:32,className:"text-white/20"}),T.jsx("span",{children:"执行查询以查看结果"})]})})})})]})]})});function D_({connection:e,defaultType:t,onSave:E,onClose:n}){const r=t||"mysql",s=_E[r]?.port||3306,[l,o]=f.useState({id:"",name:"",type:r,host:"localhost",port:s,username:"",password:"",database:"",sshEnabled:!1,sshHost:"",sshPort:22,sshUser:"",sshPassword:"",sshKey:""}),[a,R]=f.useState(!1),[A,N]=f.useState(null);f.useEffect(()=>{if(e)o(e);else{const u=t||"mysql",D=_E[u]?.port||3306;o(I=>({...I,id:`conn-${Date.now()}`,type:u,port:D,name:_E[u]?.name||""}))}},[e,t]);const i=u=>{const D=_E[u];o(I=>({...I,type:u,port:D?.port||I.port}))},O=async()=>{R(!0),N(null);const u=await se.testConnection(l);N({text:u?.message||"测试失败",type:u?.success?"success":"error"}),R(!1)},C=()=>{if(!l.name.trim()){N({text:"请输入连接名称",type:"error"});return}E(l)};return T.jsxs("div",{className:"fixed inset-0 z-50 flex items-center justify-center animate-fade-in",children:[T.jsx("div",{className:"absolute inset-0 bg-black/70 backdrop-blur-sm",onClick:n}),T.jsxs("div",{className:"relative w-[560px] max-h-[90vh] bg-metro-bg flex flex-col overflow-hidden shadow-metro-xl animate-slide-up",children:[T.jsxs("div",{className:"h-14 bg-accent-blue flex items-center justify-between px-5",children:[T.jsx("span",{className:"font-semibold text-lg",children:e?"编辑连接":"新建连接"}),T.jsx("button",{onClick:n,className:"p-1.5 hover:bg-white/20 transition-colors rounded-sm",children:T.jsx(RE,{size:20})})]}),T.jsxs("div",{className:"flex-1 overflow-y-auto p-5 space-y-5",children:[T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:"连接名称"}),T.jsx("input",{type:"text",value:l.name,onChange:u=>o(D=>({...D,name:u.target.value})),placeholder:"输入名称",className:`w-full h-10 px-4 bg-metro-surface border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-3 font-medium",children:"数据库类型"}),T.jsx("div",{className:"grid grid-cols-3 gap-2",children:Object.entries(_E).map(([u,D])=>T.jsxs("button",{onClick:()=>D.supported&&i(u),className:`h-16 flex items-center gap-3 px-4 transition-all metro-tile relative ${D.supported?"":"cursor-not-allowed"} ${l.type===u&&D.supported?"ring-2 ring-white ring-inset shadow-metro-lg":D.supported?"opacity-60 hover:opacity-100":""}`,style:{backgroundColor:D.color,opacity:D.supported?l.type===u?1:.6:.3,filter:D.supported?"none":"grayscale(60%)"},disabled:!D.supported,title:D.supported?D.name:`${D.name} - 即将支持`,children:[T.jsx("span",{className:"text-2xl",children:D.icon}),T.jsxs("div",{className:"flex flex-col items-start",children:[T.jsx("span",{className:"text-sm font-medium",children:D.name}),!D.supported&&T.jsx("span",{className:"text-[10px] text-white/60",children:"即将支持"})]})]},u))})]}),l.type==="sqlite"?T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:"数据库文件"}),T.jsxs("div",{className:"flex gap-2",children:[T.jsx("input",{type:"text",value:l.database,onChange:u=>o(D=>({...D,database:u.target.value})),placeholder:"选择或输入 .db 文件路径",className:`flex-1 h-10 px-4 bg-metro-surface border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`}),T.jsxs("button",{onClick:async()=>{const u=await se.selectFile(["db","sqlite","sqlite3"]);u?.path&&o(D=>({...D,database:u.path}))},className:"h-10 px-4 bg-metro-surface hover:bg-metro-hover flex items-center gap-2 text-sm transition-colors rounded-sm",children:[T.jsx(Ys,{size:16}),"浏览"]})]}),T.jsx("p",{className:"text-xs text-text-disabled mt-2",children:"如果文件不存在,将创建新的数据库"})]}):T.jsxs(T.Fragment,{children:[T.jsxs("div",{className:"grid grid-cols-4 gap-4",children:[T.jsxs("div",{className:"col-span-3",children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:"主机"}),T.jsx("input",{type:"text",value:l.host,onChange:u=>o(D=>({...D,host:u.target.value})),placeholder:"localhost",className:`w-full h-10 px-4 bg-metro-surface border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:"端口"}),T.jsx("input",{type:"number",value:l.port,onChange:u=>o(D=>({...D,port:parseInt(u.target.value)||0})),className:`w-full h-10 px-4 bg-metro-surface border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]})]}),l.type==="redis"?T.jsxs("div",{children:[T.jsxs("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:["密码 ",T.jsx("span",{className:"text-text-disabled font-normal",children:"(可选)"})]}),T.jsx("input",{type:"password",value:l.password,onChange:u=>o(D=>({...D,password:u.target.value})),placeholder:"无密码时留空",className:`w-full h-10 px-4 bg-metro-surface border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]}):T.jsxs("div",{className:"grid grid-cols-2 gap-4",children:[T.jsxs("div",{children:[T.jsxs("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:["用户名 ",l.type==="mongodb"&&T.jsx("span",{className:"text-text-disabled font-normal",children:"(可选)"})]}),T.jsx("input",{type:"text",value:l.username,onChange:u=>o(D=>({...D,username:u.target.value})),placeholder:l.type==="mongodb"?"无认证时留空":"root",className:`w-full h-10 px-4 bg-metro-surface border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]}),T.jsxs("div",{children:[T.jsxs("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:["密码 ",l.type==="mongodb"&&T.jsx("span",{className:"text-text-disabled font-normal",children:"(可选)"})]}),T.jsx("input",{type:"password",value:l.password,onChange:u=>o(D=>({...D,password:u.target.value})),placeholder:l.type==="mongodb"?"无认证时留空":"",className:`w-full h-10 px-4 bg-metro-surface border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]})]}),T.jsxs("div",{children:[T.jsxs("label",{className:"block text-sm text-text-secondary mb-2 font-medium",children:["数据库 ",T.jsx("span",{className:"text-text-disabled font-normal",children:"(可选)"})]}),T.jsx("input",{type:"text",value:l.database,onChange:u=>o(D=>({...D,database:u.target.value})),placeholder:l.type==="mongodb"?"默认 admin":"留空表示连接所有数据库",className:`w-full h-10 px-4 bg-metro-surface border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]})]}),T.jsxs("div",{className:"pt-4 border-t border-metro-border",children:[T.jsxs("label",{className:"flex items-center gap-3 cursor-pointer group",children:[T.jsx("input",{type:"checkbox",checked:l.sshEnabled,onChange:u=>o(D=>({...D,sshEnabled:u.target.checked})),className:"w-5 h-5 accent-accent-blue cursor-pointer"}),T.jsx(PO,{size:18,className:l.sshEnabled?"text-accent-green":"text-text-disabled"}),T.jsx("span",{className:"text-sm font-medium group-hover:text-white transition-colors",children:"SSH 隧道连接"})]}),l.sshEnabled&&T.jsxs("div",{className:"mt-4 p-4 bg-metro-surface rounded-sm space-y-4 border-l-2 border-accent-green",children:[T.jsxs("div",{className:"grid grid-cols-4 gap-3",children:[T.jsxs("div",{className:"col-span-3",children:[T.jsx("label",{className:"block text-xs text-text-tertiary mb-1.5",children:"SSH 主机"}),T.jsx("input",{type:"text",value:l.sshHost,onChange:u=>o(D=>({...D,sshHost:u.target.value})),className:`w-full h-9 px-3 bg-metro-bg border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-xs text-text-tertiary mb-1.5",children:"端口"}),T.jsx("input",{type:"number",value:l.sshPort,onChange:u=>o(D=>({...D,sshPort:parseInt(u.target.value)||22})),className:`w-full h-9 px-3 bg-metro-bg border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]})]}),T.jsxs("div",{className:"grid grid-cols-2 gap-3",children:[T.jsxs("div",{children:[T.jsx("label",{className:"block text-xs text-text-tertiary mb-1.5",children:"SSH 用户名"}),T.jsx("input",{type:"text",value:l.sshUser,onChange:u=>o(D=>({...D,sshUser:u.target.value})),className:`w-full h-9 px-3 bg-metro-bg border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-xs text-text-tertiary mb-1.5",children:"SSH 密码"}),T.jsx("input",{type:"password",value:l.sshPassword,onChange:u=>o(D=>({...D,sshPassword:u.target.value})),className:`w-full h-9 px-3 bg-metro-bg border-2 border-transparent \r focus:border-accent-blue text-sm transition-all rounded-sm`})]})]})]})]}),A&&T.jsx("div",{className:`p-4 text-sm rounded-sm ${A.type==="success"?"bg-accent-green/20 text-accent-green border-l-2 border-accent-green":"bg-accent-red/20 text-accent-red border-l-2 border-accent-red"}`,children:A.text})]}),T.jsxs("div",{className:"h-16 bg-metro-surface flex items-center justify-end gap-3 px-5 border-t border-metro-border/50",children:[T.jsxs("button",{onClick:O,disabled:a,className:`h-10 px-5 bg-transparent border border-text-tertiary hover:border-white hover:bg-white/5\r text-sm transition-all disabled:opacity-50 flex items-center gap-2 rounded-sm`,children:[a&&T.jsx(Mr,{size:14,className:"animate-spin"}),"测试连接"]}),T.jsx("button",{onClick:C,className:"h-10 px-8 bg-accent-blue hover:bg-accent-blue-hover text-sm font-medium transition-all shadow-metro rounded-sm",children:"保存"}),T.jsx("button",{onClick:n,className:"h-10 px-5 bg-metro-hover hover:bg-metro-border text-sm transition-all rounded-sm",children:"取消"})]})]})]})}const sl=[{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 P_({isOpen:e,onClose:t,onSubmit:E}){const[n,r]=f.useState(""),[s,l]=f.useState("utf8mb4"),[o,a]=f.useState("utf8mb4_general_ci");if(!e)return null;const A=sl.find(O=>O.name===s)?.collations||[],N=O=>{l(O);const C=sl.find(u=>u.name===O);C&&C.collations.length>0&&a(C.collations[0])},i=O=>{O.preventDefault(),n.trim()&&(E(n.trim(),s,o),r(""),l("utf8mb4"),a("utf8mb4_general_ci"))};return T.jsx("div",{className:"fixed inset-0 z-50 flex items-center justify-center bg-black/60",children:T.jsxs("div",{className:"bg-metro-card border border-metro-border w-[420px] shadow-metro-lg animate-fade-in",children:[T.jsxs("div",{className:"flex items-center justify-between px-4 py-3 border-b border-metro-border bg-metro-surface",children:[T.jsxs("div",{className:"flex items-center gap-2",children:[T.jsx(vn,{size:18,className:"text-accent-blue"}),T.jsx("span",{className:"font-medium",children:"新建数据库"})]}),T.jsx("button",{onClick:t,className:"p-1 hover:bg-metro-hover rounded-sm transition-colors",children:T.jsx(RE,{size:16})})]}),T.jsxs("form",{onSubmit:i,className:"p-4 space-y-4",children:[T.jsxs("div",{children:[T.jsxs("label",{className:"block text-sm text-text-secondary mb-1.5",children:["数据库名称 ",T.jsx("span",{className:"text-accent-red",children:"*"})]}),T.jsx("input",{type:"text",value:n,onChange:O=>r(O.target.value),placeholder:"输入数据库名称",className:`w-full h-9 px-3 bg-metro-surface border border-metro-border text-sm\r focus:border-accent-blue focus:outline-none transition-colors`,autoFocus:!0})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-1.5",children:"字符集"}),T.jsx("select",{value:s,onChange:O=>N(O.target.value),className:`w-full h-9 px-3 bg-metro-surface border border-metro-border text-sm\r focus:border-accent-blue focus:outline-none transition-colors`,children:sl.map(O=>T.jsx("option",{value:O.name,children:O.name},O.name))})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-1.5",children:"排序规则"}),T.jsx("select",{value:o,onChange:O=>a(O.target.value),className:`w-full h-9 px-3 bg-metro-surface border border-metro-border text-sm\r focus:border-accent-blue focus:outline-none transition-colors`,children:A.map(O=>T.jsx("option",{value:O,children:O},O))})]}),T.jsxs("div",{className:"flex justify-end gap-2 pt-2",children:[T.jsx("button",{type:"button",onClick:t,className:"px-4 py-2 text-sm bg-metro-surface hover:bg-metro-hover transition-colors",children:"取消"}),T.jsx("button",{type:"submit",disabled:!n.trim(),className:`px-4 py-2 text-sm bg-accent-blue hover:bg-accent-blue-hover disabled:opacity-50 \r disabled:cursor-not-allowed transition-colors`,children:"创建"})]})]})]})})}const p_=[{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"]}],Tl={name:"",type:"INT",length:"",nullable:!0,primaryKey:!1,autoIncrement:!1,defaultValue:"",comment:""};function f_({isOpen:e,database:t,onClose:E,onSubmit:n}){const[r,s]=f.useState(""),[l,o]=f.useState([{...Tl,id:crypto.randomUUID(),name:"id",primaryKey:!0,autoIncrement:!0,nullable:!1}]);if(!e)return null;const a=()=>{o([...l,{...Tl,id:crypto.randomUUID()}])},R=C=>{l.length>1&&o(l.filter(u=>u.id!==C))},A=(C,u,D)=>{o(l.map(I=>{if(I.id!==C)return I;const S={...I,[u]:D};return u==="primaryKey"&&D&&(S.nullable=!1),u==="autoIncrement"&&D&&(S.primaryKey=!0,S.nullable=!1),S}))},N=(C,u)=>{const D=u==="up"?C-1:C+1;if(D<0||D>=l.length)return;const I=[...l],S=I[C];I[C]=I[D],I[D]=S,o(I)},i=C=>{C.preventDefault(),r.trim()&&l.some(u=>u.name.trim())&&(n(r.trim(),l.filter(u=>u.name.trim())),s(""),o([{...Tl,id:crypto.randomUUID(),name:"id",primaryKey:!0,autoIncrement:!0,nullable:!1}]))},O=C=>["VARCHAR","CHAR","DECIMAL","FLOAT","DOUBLE","BINARY","VARBINARY"].includes(C);return T.jsx("div",{className:"fixed inset-0 z-50 flex items-center justify-center bg-black/60",children:T.jsxs("div",{className:"bg-metro-card border border-metro-border w-[800px] max-h-[85vh] flex flex-col shadow-metro-lg animate-fade-in",children:[T.jsxs("div",{className:"flex items-center justify-between px-4 py-3 border-b border-metro-border bg-metro-surface flex-shrink-0",children:[T.jsxs("div",{className:"flex items-center gap-2",children:[T.jsx(Fn,{size:18,className:"text-accent-orange"}),T.jsxs("span",{className:"font-medium",children:["新建表 - ",t]})]}),T.jsx("button",{onClick:E,className:"p-1 hover:bg-metro-hover rounded-sm transition-colors",children:T.jsx(RE,{size:16})})]}),T.jsxs("form",{onSubmit:i,className:"flex-1 flex flex-col min-h-0",children:[T.jsxs("div",{className:"p-4 border-b border-metro-border flex-shrink-0",children:[T.jsxs("label",{className:"block text-sm text-text-secondary mb-1.5",children:["表名称 ",T.jsx("span",{className:"text-accent-red",children:"*"})]}),T.jsx("input",{type:"text",value:r,onChange:C=>s(C.target.value),placeholder:"输入表名称",className:`w-64 h-9 px-3 bg-metro-surface border border-metro-border text-sm\r focus:border-accent-blue focus:outline-none transition-colors`,autoFocus:!0})]}),T.jsxs("div",{className:"flex-1 overflow-auto p-4",children:[T.jsxs("div",{className:"flex items-center justify-between mb-3",children:[T.jsx("span",{className:"text-sm text-text-secondary",children:"字段定义"}),T.jsxs("button",{type:"button",onClick:a,className:"flex items-center gap-1.5 px-3 py-1.5 text-xs bg-accent-blue hover:bg-accent-blue-hover transition-colors",children:[T.jsx(Bn,{size:14}),"添加字段"]})]}),T.jsxs("div",{className:"flex items-center gap-2 px-2 py-2 bg-metro-surface text-xs text-text-secondary border-b border-metro-border",children:[T.jsx("div",{className:"w-8"}),T.jsx("div",{className:"w-32",children:"字段名"}),T.jsx("div",{className:"w-28",children:"类型"}),T.jsx("div",{className:"w-16",children:"长度"}),T.jsx("div",{className:"w-12 text-center",children:"主键"}),T.jsx("div",{className:"w-12 text-center",children:"自增"}),T.jsx("div",{className:"w-12 text-center",children:"可空"}),T.jsx("div",{className:"w-24",children:"默认值"}),T.jsx("div",{className:"flex-1",children:"备注"}),T.jsx("div",{className:"w-16"})]}),T.jsx("div",{className:"space-y-0.5",children:l.map((C,u)=>T.jsxs("div",{className:"flex items-center gap-2 px-2 py-1.5 hover:bg-metro-hover/50 group",children:[T.jsxs("div",{className:"w-8 flex flex-col gap-0.5",children:[T.jsx("button",{type:"button",onClick:()=>N(u,"up"),disabled:u===0,className:"p-0.5 hover:bg-metro-hover disabled:opacity-30 rounded-sm",children:T.jsx(RO,{size:10})}),T.jsx("button",{type:"button",onClick:()=>N(u,"down"),disabled:u===l.length-1,className:"p-0.5 hover:bg-metro-hover disabled:opacity-30 rounded-sm",children:T.jsx(aO,{size:10})})]}),T.jsx("input",{type:"text",value:C.name,onChange:D=>A(C.id,"name",D.target.value),placeholder:"字段名",className:`w-32 h-7 px-2 bg-metro-surface border border-metro-border text-xs\r focus:border-accent-blue focus:outline-none transition-colors`}),T.jsx("select",{value:C.type,onChange:D=>A(C.id,"type",D.target.value),className:`w-28 h-7 px-2 bg-metro-surface border border-metro-border text-xs\r focus:border-accent-blue focus:outline-none transition-colors`,children:p_.map(D=>T.jsx("optgroup",{label:D.group,children:D.types.map(I=>T.jsx("option",{value:I,children:I},I))},D.group))}),T.jsx("input",{type:"text",value:C.length,onChange:D=>A(C.id,"length",D.target.value),placeholder:O(C.type)?"长度":"-",disabled:!O(C.type),className:`w-16 h-7 px-2 bg-metro-surface border border-metro-border text-xs\r focus:border-accent-blue focus:outline-none transition-colors\r disabled:opacity-50 disabled:cursor-not-allowed`}),T.jsx("div",{className:"w-12 flex justify-center",children:T.jsx("button",{type:"button",onClick:()=>A(C.id,"primaryKey",!C.primaryKey),className:`p-1 rounded-sm transition-colors ${C.primaryKey?"bg-accent-orange text-white":"hover:bg-metro-hover"}`,children:T.jsx(Qo,{size:12})})}),T.jsx("div",{className:"w-12 flex justify-center",children:T.jsx("input",{type:"checkbox",checked:C.autoIncrement,onChange:D=>A(C.id,"autoIncrement",D.target.checked),className:"w-4 h-4 accent-accent-blue"})}),T.jsx("div",{className:"w-12 flex justify-center",children:T.jsx("input",{type:"checkbox",checked:C.nullable,onChange:D=>A(C.id,"nullable",D.target.checked),disabled:C.primaryKey,className:"w-4 h-4 accent-accent-blue disabled:opacity-50"})}),T.jsx("input",{type:"text",value:C.defaultValue,onChange:D=>A(C.id,"defaultValue",D.target.value),placeholder:"默认值",className:`w-24 h-7 px-2 bg-metro-surface border border-metro-border text-xs\r focus:border-accent-blue focus:outline-none transition-colors`}),T.jsx("input",{type:"text",value:C.comment,onChange:D=>A(C.id,"comment",D.target.value),placeholder:"备注",className:`flex-1 h-7 px-2 bg-metro-surface border border-metro-border text-xs\r focus:border-accent-blue focus:outline-none transition-colors`}),T.jsx("div",{className:"w-16 flex justify-end",children:T.jsx("button",{type:"button",onClick:()=>R(C.id),disabled:l.length===1,className:`p-1.5 text-text-disabled hover:text-accent-red hover:bg-metro-hover \r rounded-sm transition-colors disabled:opacity-30 disabled:cursor-not-allowed`,children:T.jsx(yE,{size:14})})})]},C.id))})]}),T.jsxs("div",{className:"flex justify-end gap-2 p-4 border-t border-metro-border flex-shrink-0",children:[T.jsx("button",{type:"button",onClick:E,className:"px-4 py-2 text-sm bg-metro-surface hover:bg-metro-hover transition-colors",children:"取消"}),T.jsx("button",{type:"submit",disabled:!r.trim()||!l.some(C=>C.name.trim()),className:`px-4 py-2 text-sm bg-accent-blue hover:bg-accent-blue-hover disabled:opacity-50 \r disabled:cursor-not-allowed transition-colors`,children:"创建"})]})]})]})})}function $R({isOpen:e,title:t,label:E,placeholder:n,defaultValue:r="",confirmText:s="确定",onClose:l,onSubmit:o,icon:a,showDataOption:R,onSubmitWithData:A}){const[N,i]=f.useState(r),[O,C]=f.useState(!1);if(f.useEffect(()=>{i(r)},[r,e]),!e)return null;const u=D=>{D.preventDefault(),N.trim()&&(R&&A?A(N.trim(),O):o(N.trim()))};return T.jsx("div",{className:"fixed inset-0 z-50 flex items-center justify-center bg-black/60",children:T.jsxs("div",{className:"bg-metro-card border border-metro-border w-[380px] shadow-metro-lg animate-fade-in",children:[T.jsxs("div",{className:"flex items-center justify-between px-4 py-3 border-b border-metro-border bg-metro-surface",children:[T.jsxs("div",{className:"flex items-center gap-2",children:[a,T.jsx("span",{className:"font-medium",children:t})]}),T.jsx("button",{onClick:l,className:"p-1 hover:bg-metro-hover rounded-sm transition-colors",children:T.jsx(RE,{size:16})})]}),T.jsxs("form",{onSubmit:u,className:"p-4 space-y-4",children:[T.jsxs("div",{children:[T.jsxs("label",{className:"block text-sm text-text-secondary mb-1.5",children:[E," ",T.jsx("span",{className:"text-accent-red",children:"*"})]}),T.jsx("input",{type:"text",value:N,onChange:D=>i(D.target.value),placeholder:n,className:`w-full h-9 px-3 bg-metro-surface border border-metro-border text-sm\r focus:border-accent-blue focus:outline-none transition-colors`,autoFocus:!0})]}),R&&T.jsxs("div",{className:"flex items-center gap-2",children:[T.jsx("input",{type:"checkbox",id:"withData",checked:O,onChange:D=>C(D.target.checked),className:"w-4 h-4 accent-accent-blue"}),T.jsx("label",{htmlFor:"withData",className:"text-sm text-text-secondary cursor-pointer",children:"同时复制表数据"})]}),T.jsxs("div",{className:"flex justify-end gap-2 pt-2",children:[T.jsx("button",{type:"button",onClick:l,className:"px-4 py-2 text-sm bg-metro-surface hover:bg-metro-hover transition-colors",children:"取消"}),T.jsx("button",{type:"submit",disabled:!N.trim(),className:`px-4 py-2 text-sm bg-accent-blue hover:bg-accent-blue-hover disabled:opacity-50 \r disabled:cursor-not-allowed transition-colors`,children:s})]})]})]})})}const zn={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"]}]},m_=["InnoDB","MyISAM","Memory","CSV","Archive","Blackhole","Federated","NDB"],M_=["utf8mb4","utf8mb3","utf8","latin1","gbk","gb2312","big5","ascii","binary"],jR={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"]},U_=["DEFAULT","DYNAMIC","FIXED","COMPRESSED","REDUNDANT","COMPACT"];function xt({value:e,options:t,onChange:E,placeholder:n="选择...",className:r="",disabled:s=!1}){const[l,o]=f.useState(!1),[a,R]=f.useState(""),A=f.useRef(null),N=t.filter(O=>O.label.toLowerCase().includes(a.toLowerCase())||O.value.toLowerCase().includes(a.toLowerCase())),i=t.find(O=>O.value===e);return f.useEffect(()=>{const O=C=>{A.current&&!A.current.contains(C.target)&&(o(!1),R(""))};return document.addEventListener("mousedown",O),()=>document.removeEventListener("mousedown",O)},[]),T.jsxs("div",{ref:A,className:`relative flex items-center justify-between cursor-pointer ${r}`,onClick:O=>{O.stopPropagation(),s||o(!l)},children:[T.jsx("span",{className:`text-xs ${i?"text-text-primary":"text-text-secondary"} ${s?"opacity-50":""}`,children:i?.label||n}),T.jsx("span",{className:"text-text-secondary text-[10px]",children:"▼"}),l&&T.jsxs("div",{className:"absolute z-50 top-full left-0 w-full min-w-[120px] mt-0.5 bg-metro-surface border border-metro-border shadow-lg max-h-48 overflow-hidden flex flex-col",children:[T.jsx("input",{type:"text",value:a,onChange:O=>R(O.target.value),onClick:O=>O.stopPropagation(),placeholder:"搜索...",className:"w-full h-7 px-2 bg-metro-hover border-b border-metro-border text-xs focus:outline-none",autoFocus:!0}),T.jsx("div",{className:"overflow-auto flex-1",children:N.length===0?T.jsx("div",{className:"px-2 py-1.5 text-xs text-text-secondary",children:"无匹配项"}):N.map(O=>T.jsx("div",{onClick:C=>{C.stopPropagation(),E(O.value),o(!1),R("")},className:`px-2 py-1.5 text-xs cursor-pointer hover:bg-metro-hover ${O.value===e?"bg-accent-blue/20 text-accent-blue":""}`,children:O.label},O.value))})]})]})}function h_({values:e,options:t,onChange:E,placeholder:n="选择...",className:r=""}){const[s,l]=f.useState(!1),[o,a]=f.useState(""),R=f.useRef(null),A=t.filter(i=>i.label.toLowerCase().includes(o.toLowerCase()));f.useEffect(()=>{const i=O=>{R.current&&!R.current.contains(O.target)&&(l(!1),a(""))};return document.addEventListener("mousedown",i),()=>document.removeEventListener("mousedown",i)},[]);const N=i=>{e.includes(i)?E(e.filter(O=>O!==i)):E([...e,i])};return T.jsxs("div",{ref:R,className:`relative ${r}`,children:[T.jsx("div",{onClick:i=>{i.stopPropagation(),l(!s)},className:`w-full min-h-[28px] px-2 py-1 bg-transparent border border-transparent hover:border-metro-border \r text-xs flex items-center gap-1 flex-wrap cursor-pointer`,children:e.length===0?T.jsx("span",{className:"text-text-secondary",children:n}):e.map(i=>T.jsx("span",{className:"bg-accent-blue/20 text-accent-blue px-1.5 py-0.5 rounded text-[10px]",children:i},i))}),s&&T.jsxs("div",{className:"absolute z-50 top-full left-0 w-full min-w-[150px] mt-0.5 bg-metro-surface border border-metro-border shadow-lg max-h-48 overflow-hidden flex flex-col",children:[T.jsx("input",{type:"text",value:o,onChange:i=>a(i.target.value),onClick:i=>i.stopPropagation(),placeholder:"搜索...",className:"w-full h-7 px-2 bg-metro-hover border-b border-metro-border text-xs focus:outline-none",autoFocus:!0}),T.jsx("div",{className:"overflow-auto flex-1",children:A.length===0?T.jsx("div",{className:"px-2 py-1.5 text-xs text-text-secondary",children:"无匹配项"}):A.map(i=>T.jsxs("div",{onClick:O=>{O.stopPropagation(),N(i.value)},className:`px-2 py-1.5 text-xs cursor-pointer hover:bg-metro-hover flex items-center gap-2 ${e.includes(i.value)?"bg-accent-blue/10":""}`,children:[T.jsx("input",{type:"checkbox",checked:e.includes(i.value),onChange:()=>{},className:"w-3 h-3 accent-accent-blue"}),i.label]},i.value))})]})]})}const kR={name:"",type:"INT",length:"",decimals:"",nullable:!0,primaryKey:!1,autoIncrement:!1,unsigned:!1,zerofill:!1,defaultValue:"",comment:"",isVirtual:!1,virtualExpression:""},x_={name:"",columns:[],type:"NORMAL",method:"BTREE",comment:""},y_={name:"",columns:[],refSchema:"",refTable:"",refColumns:[],onDelete:"NO ACTION",onUpdate:"NO ACTION"},JR={engine:"InnoDB",charset:"utf8mb4",collation:"utf8mb4_general_ci",comment:"",autoIncrement:"",rowFormat:"DEFAULT"};function G_({isOpen:e,mode:t,database:E,tableName:n,connectionId:r,dbType:s,onClose:l,onSave:o,onGetTableInfo:a,onGetDatabases:R,onGetTables:A,onGetColumns:N}){const[i,O]=f.useState("columns"),[C,u]=f.useState(n||""),[D,I]=f.useState([]),[S,c]=f.useState([]),[L,B]=f.useState([]),[p,P]=f.useState(JR),[y,Y]=f.useState(null),[K,oe]=f.useState(!1),[_e,F]=f.useState(!1),[He,Ie]=f.useState(""),[me,le]=f.useState(null),[X,ee]=f.useState(null),[te,Ee]=f.useState(null);f.useEffect(()=>{e&&t==="edit"&&a?(u(n||""),Ie(""),Re()):e&&t==="create"&&(I([{...kR,id:crypto.randomUUID(),name:"id",primaryKey:!0,autoIncrement:!0,nullable:!1,_isNew:!0}]),c([]),B([]),P(JR),Y(null),u(""),Ie(""),oe(!1))},[e,t,n]);const Re=async()=>{if(!a){oe(!1);return}oe(!0);try{const m=await a();m&&m.columns?I(m.columns.map(w=>({...w,_original:{...w}}))):I([]),m&&m.indexes?c(m.indexes.map(w=>({...w,_original:{...w}}))):c([]),m&&m.foreignKeys?B(m.foreignKeys.map(w=>({...w,_original:{...w}}))):B([]),m&&m.options?(P(m.options),Y(m.options)):Y(null)}catch(m){console.error("Load table info error:",m),Ie(m.message||"加载表信息失败")}finally{oe(!1)}},Fe=f.useMemo(()=>{const m=s.toLowerCase();return m==="mysql"||m==="mariadb"?zn.mysql:m==="postgres"||m==="postgresql"?zn.postgres:m==="sqlserver"?zn.sqlserver:m==="sqlite"?zn.sqlite:zn.mysql},[s]),Ye=m=>{const w=m.toUpperCase();return["VARCHAR","CHAR","DECIMAL","NUMERIC","FLOAT","DOUBLE","BINARY","VARBINARY","BIT"].includes(w)},Me=m=>{const w=m.toUpperCase();return["DECIMAL","NUMERIC","FLOAT","DOUBLE"].includes(w)},Ve=m=>{const w=m.toUpperCase();return["TINYINT","SMALLINT","MEDIUMINT","INT","INTEGER","BIGINT","FLOAT","DOUBLE","DECIMAL"].includes(w)},be=()=>{const m={...kR,id:crypto.randomUUID(),_isNew:!0};I([...D,m]),le(m.id)},ze=m=>{const w=D.find(J=>J.id===m);w&&(w._isNew?I(D.filter(J=>J.id!==m)):I(D.map(J=>J.id===m?{...J,_isDeleted:!0}:J)))},Et=(m,w,J)=>{I(D.map(Te=>{if(Te.id!==m)return Te;const b={...Te,[w]:J};return w==="primaryKey"&&J&&(b.nullable=!1),w==="autoIncrement"&&J&&(b.primaryKey=!0,b.nullable=!1),b}))},iE=(m,w)=>{const J=D.filter(ie=>!ie._isDeleted),Te=w==="up"?m-1:m+1;if(Te<0||Te>=J.length)return;const b=[...J],ne=b[m];b[m]=b[Te],b[Te]=ne,I([...b,...D.filter(ie=>ie._isDeleted)])},Mt=()=>{const m={...x_,id:crypto.randomUUID(),_isNew:!0};c([...S,m]),ee(m.id)},Oe=m=>{const w=S.find(J=>J.id===m);w&&(w._isNew?c(S.filter(J=>J.id!==m)):c(S.map(J=>J.id===m?{...J,_isDeleted:!0}:J)))},Ce=(m,w)=>m.length===0||!m.some(b=>b)?"":`${w==="UNIQUE"?"uk":w==="FULLTEXT"?"ft":"idx"}_${C||"table"}_${m.filter(b=>b).join("_")}`,Lt=(m,w,J)=>{c(S.map(Te=>{if(Te.id!==m)return Te;const b={...Te,[w]:J};if(w==="columns"&&Array.isArray(J)&&J.length>0&&J.some(ne=>ne)){const ne=Ce(J,Te.type);(!Te.name||Te.name.startsWith("idx_")||Te.name.startsWith("uk_")||Te.name.startsWith("ft_"))&&(b.name=ne)}if(w==="type"&&Te.columns.length>0&&Te.columns.some(ne=>ne)){const ne=Ce(Te.columns,J);(!Te.name||Te.name.startsWith("idx_")||Te.name.startsWith("uk_")||Te.name.startsWith("ft_"))&&(b.name=ne)}return b}))},Jt=m=>m.length===0||!m[0]?"":`fk_${C||"table"}_${m.filter(J=>J).join("_")}`,zt=()=>{const m={...y_,id:crypto.randomUUID(),_isNew:!0};B([...L,m]),Ee(m.id)},j=m=>{const w=L.find(J=>J.id===m);w&&(w._isNew?B(L.filter(J=>J.id!==m)):B(L.map(J=>J.id===m?{...J,_isDeleted:!0}:J)))},Qe=(m,w,J)=>{B(L.map(Te=>{if(Te.id!==m)return Te;const b={...Te,[w]:J};if(w==="columns"&&Array.isArray(J)&&J.length>0&&J[0]){const ne=Jt(J);(!Te.name||Te.name.startsWith("fk_"))&&(b.name=ne)}return b}))},ve=m=>{if(!m._original)return!1;const w=m._original;return m.name!==w.name||m.type!==w.type||m.length!==w.length||m.decimals!==w.decimals||m.nullable!==w.nullable||m.defaultValue!==w.defaultValue||m.comment!==w.comment||m.unsigned!==w.unsigned||m.autoIncrement!==w.autoIncrement},AE=f.useMemo(()=>{const m=s.toLowerCase(),w=b=>m==="mysql"||m==="mariadb"?`\`${b}\``:m==="postgres"||m==="postgresql"?`"${b}"`:m==="sqlserver"?`[${b}]`:`"${b}"`,J=b=>{let ne=b.type.toUpperCase();return b.length&&(b.decimals&&Me(b.type)?ne+=`(${b.length},${b.decimals})`:ne+=`(${b.length})`),ne},Te=(b,ne=!1)=>{let ie=`${w(b.name)} ${J(b)}`;if(Ve(b.type)&&b.unsigned&&(m==="mysql"||m==="mariadb")&&(ie+=" UNSIGNED"),b.zerofill&&(m==="mysql"||m==="mariadb")&&(ie+=" ZEROFILL"),b.nullable||(ie+=" NOT NULL"),b.autoIncrement&&(m==="mysql"||m==="mariadb"?ie+=" AUTO_INCREMENT":m==="sqlserver"&&(ie+=" IDENTITY(1,1)")),b.defaultValue!==void 0&&b.defaultValue!==""){const _t=b.defaultValue;_t.toUpperCase()==="NULL"?ie+=" DEFAULT NULL":_t.toUpperCase()==="CURRENT_TIMESTAMP"||_t.toUpperCase().startsWith("NOW")?ie+=` DEFAULT ${_t}`:ie+=` DEFAULT '${_t}'`}return b.comment&&(m==="mysql"||m==="mariadb")&&(ie+=` COMMENT '${b.comment.replace(/'/g,"''")}'`),ie};if(t==="create"){const b=D.filter(x=>!x._isDeleted&&x.name);if(!C||b.length===0)return"-- 请填写表名和至少一个字段";const ne=b.map(x=>" "+Te(x,!0)),ie=b.filter(x=>x.primaryKey);ie.length>0&&ne.push(` PRIMARY KEY (${ie.map(x=>w(x.name)).join(", ")})`);const _t=S.filter(x=>!x._isDeleted&&x.name&&x.columns.length>0&&x.columns.some(W=>W));for(const x of _t){let W=" ";x.type==="UNIQUE"?W+="UNIQUE ":x.type==="FULLTEXT"?W+="FULLTEXT ":x.type==="SPATIAL"&&(W+="SPATIAL "),W+=`INDEX ${w(x.name)} (${x.columns.map(Ae=>w(Ae)).join(", ")})`,x.method&&x.method!=="BTREE"&&(m==="mysql"||m==="mariadb")&&(W+=` USING ${x.method}`),ne.push(W)}const NE=L.filter(x=>!x._isDeleted&&x.name&&x.columns.length>0&&x.columns[0]&&x.refTable&&x.refColumns.length>0&&x.refColumns[0]);for(const x of NE){let W=` CONSTRAINT ${w(x.name)} FOREIGN KEY (${x.columns.map(Ae=>w(Ae)).join(", ")}) `;W+=`REFERENCES ${x.refSchema?w(x.refSchema)+".":""}${w(x.refTable)} (${x.refColumns.map(Ae=>w(Ae)).join(", ")})`,x.onDelete!=="NO ACTION"&&(W+=` ON DELETE ${x.onDelete}`),x.onUpdate!=="NO ACTION"&&(W+=` ON UPDATE ${x.onUpdate}`),ne.push(W)}let G=`CREATE TABLE ${w(E)}.${w(C)} ( ${ne.join(`, `)} )`;if(m==="mysql"||m==="mariadb"){const x=[];p.engine&&x.push(`ENGINE=${p.engine}`),p.charset&&x.push(`DEFAULT CHARSET=${p.charset}`),p.collation&&x.push(`COLLATE=${p.collation}`),p.rowFormat&&p.rowFormat!=="DEFAULT"&&x.push(`ROW_FORMAT=${p.rowFormat}`),p.comment&&x.push(`COMMENT='${p.comment.replace(/'/g,"''")}'`),p.autoIncrement&&x.push(`AUTO_INCREMENT=${p.autoIncrement}`),x.length>0&&(G+=` `+x.join(` `))}return G+";"}else{const b=[],ne=`${w(E)}.${w(C)}`,ie=D.filter(H=>H._isDeleted&&H._original);for(const H of ie)b.push(`ALTER TABLE ${ne} DROP COLUMN ${w(H.name)};`);const _t=D.filter(H=>H._isNew&&!H._isDeleted&&H.name);for(const H of _t)b.push(`ALTER TABLE ${ne} ADD COLUMN ${Te(H)};`);const NE=D.filter(H=>!H._isNew&&!H._isDeleted&&H._original&&ve(H));for(const H of NE)m==="mysql"||m==="mariadb"?b.push(`ALTER TABLE ${ne} CHANGE COLUMN ${w(H._original.name)} ${Te(H)};`):m==="postgres"||m==="postgresql"?(H._original.name!==H.name&&b.push(`ALTER TABLE ${ne} RENAME COLUMN ${w(H._original.name)} TO ${w(H.name)};`),b.push(`ALTER TABLE ${ne} ALTER COLUMN ${w(H.name)} TYPE ${J(H)};`),H.nullable!==H._original.nullable&&b.push(`ALTER TABLE ${ne} ALTER COLUMN ${w(H.name)} ${H.nullable?"DROP":"SET"} NOT NULL;`)):m==="sqlserver"&&(H._original.name!==H.name&&b.push(`EXEC sp_rename '${C}.${H._original.name}', '${H.name}', 'COLUMN';`),b.push(`ALTER TABLE ${ne} ALTER COLUMN ${w(H.name)} ${J(H)}${H.nullable?"":" NOT NULL"};`));const G=S.filter(H=>H._isDeleted&&H._original);for(const H of G)m==="mysql"||m==="mariadb"?b.push(`ALTER TABLE ${ne} DROP INDEX ${w(H.name)};`):m==="postgres"||m==="postgresql"?b.push(`DROP INDEX ${w(H.name)};`):m==="sqlserver"&&b.push(`DROP INDEX ${w(H.name)} ON ${ne};`);const x=S.filter(H=>H._isNew&&!H._isDeleted&&H.name&&H.columns.length>0&&H.columns.some(z=>z));for(const H of x){let z="";m==="mysql"||m==="mariadb"?(z=`ALTER TABLE ${ne} ADD `,H.type==="UNIQUE"?z+="UNIQUE ":H.type==="FULLTEXT"?z+="FULLTEXT ":H.type==="SPATIAL"&&(z+="SPATIAL "),z+=`INDEX ${w(H.name)} (${H.columns.map(de=>w(de)).join(", ")})`,H.method&&H.method!=="BTREE"&&(z+=` USING ${H.method}`)):z=`CREATE ${H.type==="UNIQUE"?"UNIQUE ":""}INDEX ${w(H.name)} ON ${ne} (${H.columns.map(de=>w(de)).join(", ")})`,b.push(z+";")}const W=L.filter(H=>H._isDeleted&&H._original);for(const H of W)m==="mysql"||m==="mariadb"?b.push(`ALTER TABLE ${ne} DROP FOREIGN KEY ${w(H.name)};`):b.push(`ALTER TABLE ${ne} DROP CONSTRAINT ${w(H.name)};`);const Ae=L.filter(H=>H._isNew&&!H._isDeleted&&H.name&&H.columns.length>0&&H.columns[0]&&H.refTable&&H.refColumns.length>0&&H.refColumns[0]);for(const H of Ae){let z=`ALTER TABLE ${ne} ADD CONSTRAINT ${w(H.name)} FOREIGN KEY (${H.columns.map(de=>w(de)).join(", ")}) `;z+=`REFERENCES ${H.refSchema?w(H.refSchema)+".":""}${w(H.refTable)} (${H.refColumns.map(de=>w(de)).join(", ")})`,H.onDelete!=="NO ACTION"&&(z+=` ON DELETE ${H.onDelete}`),H.onUpdate!=="NO ACTION"&&(z+=` ON UPDATE ${H.onUpdate}`),b.push(z+";")}if(m==="mysql"||m==="mariadb"){const H=y||{comment:"",engine:"",charset:""};if(p.comment!==H.comment&&(p.comment?b.push(`ALTER TABLE ${ne} COMMENT='${p.comment.replace(/'/g,"''")}';`):b.push(`ALTER TABLE ${ne} COMMENT='';`)),p.engine&&p.engine!==H.engine&&b.push(`ALTER TABLE ${ne} ENGINE=${p.engine};`),p.charset&&p.charset!==H.charset){let z=`ALTER TABLE ${ne} CONVERT TO CHARACTER SET ${p.charset}`;p.collation&&(z+=` COLLATE ${p.collation}`),b.push(z+";")}}return b.length>0?b.join(` `):"-- 没有需要执行的修改"}},[t,C,D,S,L,p,y,E,s]),St=async()=>{if(!C){Ie("请输入表名");return}if(D.filter(w=>!w._isDeleted&&w.name).length===0){Ie("请至少添加一个字段");return}F(!0),Ie("");try{const w=await o(AE);if(!w.success)Ie(w.message);else if(t==="edit"&&a)try{const J=await a();if(J){const Te=J.columns.map(ie=>({...ie,id:crypto.randomUUID(),_original:{...ie,id:crypto.randomUUID()}})),b=J.indexes.map(ie=>({...ie,id:crypto.randomUUID(),_original:{...ie,id:crypto.randomUUID()}})),ne=J.foreignKeys.map(ie=>({...ie,id:crypto.randomUUID(),_original:{...ie,id:crypto.randomUUID()}}));I(Te),c(b),B(ne),J.options&&(P(J.options),Y(J.options))}}catch{}else l()}catch(w){Ie(w.message||"保存失败")}finally{F(!1)}};if(!e)return null;const lt=D.filter(m=>!m._isDeleted),Qt=S.filter(m=>!m._isDeleted),SE=L.filter(m=>!m._isDeleted),ue=[{id:"columns",label:"字段",icon:cO,count:lt.length},{id:"indexes",label:"索引",icon:vn,count:Qt.length},{id:"foreignKeys",label:"外键",icon:uO,count:SE.length},{id:"options",label:"选项",icon:IS},{id:"sql",label:"SQL 预览",icon:Fs}];return T.jsx("div",{className:"fixed inset-0 z-50 flex items-center justify-center bg-black/60",children:T.jsxs("div",{className:"bg-metro-card border border-metro-border w-[1100px] h-[700px] flex flex-col shadow-metro-lg animate-fade-in",children:[T.jsxs("div",{className:"flex items-center justify-between px-4 py-3 border-b border-metro-border bg-metro-surface flex-shrink-0",children:[T.jsxs("div",{className:"flex items-center gap-3",children:[T.jsx(Fn,{size:18,className:"text-accent-teal"}),T.jsxs("span",{className:"font-medium",children:[t==="create"?"新建表":"编辑表"," - ",E]}),t==="edit"&&n&&T.jsxs("span",{className:"text-text-secondary",children:["(",n,")"]})]}),T.jsxs("div",{className:"flex items-center gap-2",children:[T.jsxs("button",{onClick:St,disabled:_e,className:`flex items-center gap-1.5 px-3 py-1.5 text-sm bg-accent-blue hover:bg-accent-blue-hover \r disabled:opacity-50 transition-colors`,children:[T.jsx(Zo,{size:14}),_e?"保存中...":"保存"]}),T.jsx("button",{onClick:l,className:"p-1.5 hover:bg-metro-hover rounded-sm transition-colors",children:T.jsx(RE,{size:16})})]})]}),T.jsxs("div",{className:"border-b border-metro-border bg-metro-surface/50 flex-shrink-0",children:[T.jsxs("div",{className:"flex items-center gap-6 px-4 py-2 border-b border-metro-border/50",children:[T.jsxs("div",{className:"flex items-center gap-2",children:[T.jsx("span",{className:"text-sm text-text-secondary w-12",children:"表名:"}),T.jsx("input",{type:"text",value:C,onChange:m=>u(m.target.value),placeholder:"输入表名",disabled:t==="edit",className:`w-48 h-8 px-3 bg-metro-surface border border-metro-border text-sm\r focus:border-accent-blue focus:outline-none transition-colors\r disabled:opacity-60 disabled:cursor-not-allowed`})]}),T.jsxs("div",{className:"flex items-center gap-2 flex-1",children:[T.jsx("span",{className:"text-sm text-text-secondary w-12",children:"注释:"}),T.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-metro-surface border border-metro-border text-sm\r focus:border-accent-blue focus:outline-none transition-colors`})]})]}),T.jsx("div",{className:"flex px-4",children:ue.map(m=>T.jsxs("button",{onClick:()=>O(m.id),className:`flex items-center gap-1.5 px-4 py-2 text-sm border-b-2 transition-colors ${i===m.id?"border-accent-blue text-accent-blue":"border-transparent text-text-secondary hover:text-text-primary"}`,children:[T.jsx(m.icon,{size:14}),m.label,"count"in m&&m.count!==void 0&&T.jsx("span",{className:"ml-1 text-xs bg-metro-hover px-1.5 rounded",children:m.count})]},m.id))})]}),He&&T.jsx("div",{className:"px-4 py-2 bg-accent-red/20 border-b border-accent-red/30 text-sm text-accent-red flex-shrink-0",children:He}),T.jsx("div",{className:"flex-1 overflow-hidden",children:K?T.jsx("div",{className:"flex items-center justify-center h-full text-text-secondary",children:"加载中..."}):T.jsxs(T.Fragment,{children:[i==="columns"&&T.jsx(g_,{columns:lt,dataTypes:Fe,dbType:s,selectedId:me,onSelect:le,onAdd:be,onRemove:ze,onUpdate:Et,onMove:iE,needsLength:Ye,needsDecimals:Me,supportsUnsigned:Ve}),i==="indexes"&&T.jsx(v_,{indexes:Qt,columns:lt,selectedId:X,onSelect:ee,onAdd:Mt,onRemove:Oe,onUpdate:Lt,dbType:s}),i==="foreignKeys"&&T.jsx(B_,{foreignKeys:SE,columns:lt,selectedId:te,onSelect:Ee,onAdd:zt,onRemove:j,onUpdate:Qe,onGetDatabases:R,onGetTables:A,onGetColumns:N,currentDatabase:E}),i==="options"&&T.jsx(F_,{options:p,dbType:s,onChange:P}),i==="sql"&&T.jsx(Y_,{sql:AE})]})})]})})}function g_({columns:e,dataTypes:t,dbType:E,selectedId:n,onSelect:r,onAdd:s,onRemove:l,onUpdate:o,onMove:a,needsLength:R,needsDecimals:A,supportsUnsigned:N}){const i=E.toLowerCase()==="mysql"||E.toLowerCase()==="mariadb",[O,C]=f.useState(null),[u,D]=f.useState(null),I=(L,B)=>{C(B),L.dataTransfer.effectAllowed="move"},S=(L,B)=>{L.preventDefault(),O!==null&&O!==B&&D(B)},c=()=>{if(O!==null&&u!==null&&O!==u)if(uu;L--)a(L,"up");else for(let L=O;LT.jsxs("tr",{onDragOver:p=>S(p,B),onClick:()=>r(L.id),className:`border-b border-metro-border/50 cursor-pointer transition-colors ${n===L.id?"bg-accent-blue/20":"hover:bg-metro-hover/50"} ${L._isNew?"bg-accent-green/10":""} ${u===B?"border-t-2 border-t-accent-blue":""}`,children:[T.jsx("td",{draggable:!0,onDragStart:p=>I(p,B),onDragEnd:c,className:"px-1 py-1.5 text-center cursor-grab active:cursor-grabbing",children:T.jsx(IO,{size:14,className:"text-text-secondary mx-auto"})}),T.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:T.jsx("input",{type:"text",value:L.name,onChange:p=>o(L.id,"name",p.target.value),onFocus:()=>r(L.id),placeholder:"字段名",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-metro-border \r focus:border-accent-blue focus:bg-metro-surface focus:outline-none text-xs\r selection:bg-accent-blue selection:text-white`})}),T.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:T.jsx("select",{value:L.type,onChange:p=>o(L.id,"type",p.target.value),onFocus:()=>r(L.id),className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-metro-border \r focus:border-accent-blue focus:bg-metro-surface focus:outline-none text-xs`,children:t.map(p=>T.jsx("optgroup",{label:p.group,children:p.types.map(P=>T.jsx("option",{value:P,children:P},P))},p.group))})}),T.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:T.jsx("input",{type:"text",value:L.length,onChange:p=>o(L.id,"length",p.target.value),onFocus:()=>r(L.id),disabled:!R(L.type),placeholder:R(L.type)?"":"-",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-metro-border \r focus:border-accent-blue focus:bg-metro-surface focus:outline-none text-xs\r disabled:opacity-40 disabled:cursor-not-allowed selection:bg-accent-blue selection:text-white`})}),T.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:T.jsx("input",{type:"text",value:L.decimals,onChange:p=>o(L.id,"decimals",p.target.value),onFocus:()=>r(L.id),disabled:!A(L.type),placeholder:A(L.type)?"":"-",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-metro-border \r focus:border-accent-blue focus:bg-metro-surface focus:outline-none text-xs\r disabled:opacity-40 disabled:cursor-not-allowed selection:bg-accent-blue selection:text-white`})}),T.jsx("td",{className:"px-3 py-1.5 text-center",onClick:p=>p.stopPropagation(),children:T.jsx("input",{type:"checkbox",checked:!L.nullable,onChange:p=>{r(L.id),o(L.id,"nullable",!p.target.checked)},disabled:L.primaryKey,className:"w-4 h-4 accent-accent-blue disabled:opacity-50"})}),i&&T.jsx("td",{className:"px-3 py-1.5 text-center",onClick:p=>p.stopPropagation(),children:T.jsx("input",{type:"checkbox",checked:L.unsigned,onChange:p=>{r(L.id),o(L.id,"unsigned",p.target.checked)},disabled:!N(L.type),className:"w-4 h-4 accent-accent-blue disabled:opacity-50"})}),T.jsxs("td",{className:"px-3 py-1.5 text-center",onClick:p=>p.stopPropagation(),children:[T.jsx("button",{onClick:()=>{r(L.id),o(L.id,"primaryKey",!L.primaryKey)},className:`p-1 rounded-sm transition-colors ${L.primaryKey?"bg-accent-orange text-white":"hover:bg-metro-hover"}`,title:L.primaryKey?"主键":"设为主键",children:T.jsx(Qo,{size:12})}),L.autoIncrement&&T.jsx("span",{className:"ml-1 text-xs text-accent-blue",title:"自增",children:"A"})]}),T.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:T.jsx("input",{type:"text",value:L.defaultValue,onChange:p=>o(L.id,"defaultValue",p.target.value),onFocus:()=>r(L.id),placeholder:"",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-metro-border \r focus:border-accent-blue focus:bg-metro-surface focus:outline-none text-xs\r selection:bg-accent-blue selection:text-white`})}),T.jsx("td",{className:"px-3 py-1.5",onClick:p=>p.stopPropagation(),children:T.jsx("input",{type:"text",value:L.comment,onChange:p=>o(L.id,"comment",p.target.value),onFocus:()=>r(L.id),placeholder:"",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-metro-border \r focus:border-accent-blue focus:bg-metro-surface focus:outline-none text-xs\r selection:bg-accent-blue selection:text-white`})}),T.jsx("td",{className:"px-2 py-1.5 text-center",onClick:p=>p.stopPropagation(),children:T.jsx("button",{onClick:()=>{r(L.id),e.length>1&&l(L.id)},disabled:e.length<=1,className:`p-1 text-text-secondary hover:text-accent-red hover:bg-accent-red/10 rounded transition-colors\r disabled:opacity-30 disabled:cursor-not-allowed disabled:hover:text-text-secondary disabled:hover:bg-transparent`,title:"删除字段",children:T.jsx(yE,{size:14})})})]},L.id))})]})}),n&&T.jsx(H_,{column:e.find(L=>L.id===n),onUpdate:(L,B)=>o(n,L,B),isMysql:i})]})}function H_({column:e,onUpdate:t,isMysql:E}){return T.jsx("div",{className:"border-t border-metro-border bg-metro-surface/50 px-4 py-3 flex-shrink-0",children:T.jsxs("div",{className:"grid grid-cols-4 gap-4 text-sm",children:[T.jsxs("label",{className:"flex items-center gap-2",children:[T.jsx("input",{type:"checkbox",checked:e.autoIncrement,onChange:n=>t("autoIncrement",n.target.checked),className:"w-4 h-4 accent-accent-blue"}),T.jsx("span",{children:"自动递增"})]}),E&&T.jsxs(T.Fragment,{children:[T.jsxs("label",{className:"flex items-center gap-2",children:[T.jsx("input",{type:"checkbox",checked:e.zerofill,onChange:n=>t("zerofill",n.target.checked),className:"w-4 h-4 accent-accent-blue"}),T.jsx("span",{children:"填充零"})]}),T.jsxs("label",{className:"flex items-center gap-2",children:[T.jsx("input",{type:"checkbox",checked:e.isVirtual,onChange:n=>t("isVirtual",n.target.checked),className:"w-4 h-4 accent-accent-blue"}),T.jsx("span",{children:"虚拟"})]})]})]})})}function v_({indexes:e,columns:t,selectedId:E,onSelect:n,onAdd:r,onRemove:s,onUpdate:l,dbType:o}){const a=o.toLowerCase()==="mysql"||o.toLowerCase()==="mariadb",R=t.filter(i=>i.name).map(i=>({label:i.name,value:i.name})),A=[{label:"NORMAL",value:"NORMAL"},{label:"UNIQUE",value:"UNIQUE"},...a?[{label:"FULLTEXT",value:"FULLTEXT"},{label:"SPATIAL",value:"SPATIAL"}]:[]],N=[{label:"BTREE",value:"BTREE"},{label:"HASH",value:"HASH"}];return T.jsxs("div",{className:"h-full flex flex-col",children:[T.jsx("div",{className:"flex items-center gap-2 px-4 py-2 border-b border-metro-border bg-metro-surface/30 flex-shrink-0",children:T.jsxs("button",{onClick:r,className:"flex items-center gap-1.5 px-3 py-1.5 text-xs bg-accent-green hover:bg-accent-green/80 transition-colors",children:[T.jsx(Bn,{size:14}),"添加索引"]})}),T.jsxs("div",{className:"flex-1 overflow-auto",children:[T.jsxs("table",{className:"w-full text-sm",children:[T.jsx("thead",{className:"bg-metro-surface sticky top-0",children:T.jsxs("tr",{className:"border-b border-metro-border",children:[T.jsx("th",{className:"w-40 px-3 py-2 text-left font-medium",children:"名称"}),T.jsx("th",{className:"w-64 px-3 py-2 text-left font-medium",children:"字段"}),T.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"索引类型"}),a&&T.jsx("th",{className:"w-24 px-3 py-2 text-left font-medium",children:"索引方法"}),T.jsx("th",{className:"px-3 py-2 text-left font-medium",children:"注释"}),T.jsx("th",{className:"w-16 px-3 py-2 text-center font-medium",children:"操作"})]})}),T.jsx("tbody",{children:e.map(i=>T.jsxs("tr",{onClick:()=>n(i.id),className:`border-b border-metro-border/50 cursor-pointer transition-colors ${E===i.id?"bg-accent-blue/20":"hover:bg-metro-hover/50"} ${i._isNew?"bg-accent-green/10":""}`,children:[T.jsx("td",{className:"px-3 py-1.5",children:T.jsx("input",{type:"text",value:i.name,onChange:O=>l(i.id,"name",O.target.value),onClick:O=>O.stopPropagation(),placeholder:"索引名",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-metro-border \r focus:border-accent-blue focus:bg-metro-surface focus:outline-none text-xs`})}),T.jsx("td",{className:"px-3 py-1.5",onClick:O=>O.stopPropagation(),children:T.jsx(h_,{values:i.columns,options:R,onChange:O=>l(i.id,"columns",O),placeholder:"选择字段..."})}),T.jsx("td",{className:"px-3 py-1.5",onClick:O=>O.stopPropagation(),children:T.jsx(xt,{value:i.type,options:A,onChange:O=>l(i.id,"type",O),placeholder:"索引类型"})}),a&&T.jsx("td",{className:"px-3 py-1.5",onClick:O=>O.stopPropagation(),children:T.jsx(xt,{value:i.method,options:N,onChange:O=>l(i.id,"method",O),placeholder:"索引方法"})}),T.jsx("td",{className:"px-3 py-1.5",children:T.jsx("input",{type:"text",value:i.comment,onChange:O=>l(i.id,"comment",O.target.value),onClick:O=>O.stopPropagation(),placeholder:"",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-metro-border \r focus:border-accent-blue focus:bg-metro-surface focus:outline-none text-xs`})}),T.jsx("td",{className:"px-3 py-1.5 text-center",children:T.jsx("button",{onClick:O=>{O.stopPropagation(),s(i.id)},className:"p-1 text-text-secondary hover:text-accent-red hover:bg-accent-red/10 rounded transition-colors",title:"删除索引",children:T.jsx(yE,{size:14})})})]},i.id))})]}),e.length===0&&T.jsx("div",{className:"text-center py-8 text-text-secondary text-sm",children:'暂无索引,点击"添加索引"创建'})]})]})}function B_({foreignKeys:e,columns:t,selectedId:E,onSelect:n,onAdd:r,onRemove:s,onUpdate:l,onGetDatabases:o,onGetTables:a,onGetColumns:R,currentDatabase:A}){const[N,i]=f.useState([A]),[O,C]=f.useState({}),[u,D]=f.useState({});f.useEffect(()=>{o&&o().then(P=>i(P))},[]);const I=async(P,y)=>{if(!a)return;const Y=await a(y);C(K=>({...K,[P]:Y}))},S=async(P,y,Y)=>{if(!R)return;const K=await R(y,Y);D(oe=>({...oe,[P]:K}))},c=["CASCADE","SET NULL","NO ACTION","RESTRICT","SET DEFAULT"],L=t.filter(P=>P.name).map(P=>({label:P.name,value:P.name})),B=N.map(P=>({label:P,value:P})),p=c.map(P=>({label:P,value:P}));return T.jsxs("div",{className:"h-full flex flex-col",children:[T.jsx("div",{className:"flex items-center gap-2 px-4 py-2 border-b border-metro-border bg-metro-surface/30 flex-shrink-0",children:T.jsxs("button",{onClick:r,className:"flex items-center gap-1.5 px-3 py-1.5 text-xs bg-accent-green hover:bg-accent-green/80 transition-colors",children:[T.jsx(Bn,{size:14}),"添加外键"]})}),T.jsxs("div",{className:"flex-1 overflow-auto",children:[T.jsxs("table",{className:"w-full text-sm",children:[T.jsx("thead",{className:"bg-metro-surface sticky top-0",children:T.jsxs("tr",{className:"border-b border-metro-border",children:[T.jsx("th",{className:"w-36 px-3 py-2 text-left font-medium",children:"名称"}),T.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"字段"}),T.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"被引用的模式"}),T.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"被引用的表"}),T.jsx("th",{className:"w-28 px-3 py-2 text-left font-medium",children:"被引用的字段"}),T.jsx("th",{className:"w-24 px-3 py-2 text-left font-medium",children:"删除时"}),T.jsx("th",{className:"w-24 px-3 py-2 text-left font-medium",children:"更新时"}),T.jsx("th",{className:"w-16 px-3 py-2 text-center font-medium",children:"操作"})]})}),T.jsx("tbody",{children:e.map(P=>T.jsxs("tr",{onClick:()=>n(P.id),className:`border-b border-metro-border/50 cursor-pointer transition-colors ${E===P.id?"bg-accent-blue/20":"hover:bg-metro-hover/50"} ${P._isNew?"bg-accent-green/10":""}`,children:[T.jsx("td",{className:"px-3 py-1.5",children:T.jsx("input",{type:"text",value:P.name,onChange:y=>l(P.id,"name",y.target.value),onClick:y=>y.stopPropagation(),placeholder:"外键名",className:`w-full h-7 px-2 bg-transparent border border-transparent hover:border-metro-border \r focus:border-accent-blue focus:bg-metro-surface focus:outline-none text-xs`})}),T.jsx("td",{className:"px-3 py-1.5",onClick:y=>y.stopPropagation(),children:T.jsx(xt,{value:P.columns[0]||"",options:L,onChange:y=>l(P.id,"columns",[y]),placeholder:"选择字段"})}),T.jsx("td",{className:"px-3 py-1.5",onClick:y=>y.stopPropagation(),children:T.jsx(xt,{value:P.refSchema||A,options:B,onChange:y=>{l(P.id,"refSchema",y),I(P.id,y)},placeholder:"选择模式"})}),T.jsxs("td",{className:"px-3 py-1.5",onClick:y=>y.stopPropagation(),children:[T.jsx(xt,{value:P.refTable,options:(O[P.id]||[]).map(y=>({label:y,value:y})),onChange:y=>{l(P.id,"refTable",y),S(P.id,P.refSchema||A,y)},placeholder:"选择表"}),!O[P.id]&&T.jsx("button",{onClick:()=>I(P.id,P.refSchema||A),className:"text-[10px] text-accent-blue hover:underline mt-0.5",children:"加载表列表"})]}),T.jsxs("td",{className:"px-3 py-1.5",onClick:y=>y.stopPropagation(),children:[T.jsx(xt,{value:P.refColumns[0]||"",options:(u[P.id]||[]).map(y=>({label:y,value:y})),onChange:y=>l(P.id,"refColumns",[y]),placeholder:"选择字段"}),P.refTable&&!u[P.id]&&T.jsx("button",{onClick:()=>S(P.id,P.refSchema||A,P.refTable),className:"text-[10px] text-accent-blue hover:underline mt-0.5",children:"加载字段"})]}),T.jsx("td",{className:"px-3 py-1.5",onClick:y=>y.stopPropagation(),children:T.jsx(xt,{value:P.onDelete,options:p,onChange:y=>l(P.id,"onDelete",y)})}),T.jsx("td",{className:"px-3 py-1.5",onClick:y=>y.stopPropagation(),children:T.jsx(xt,{value:P.onUpdate,options:p,onChange:y=>l(P.id,"onUpdate",y)})}),T.jsx("td",{className:"px-3 py-1.5 text-center",children:T.jsx("button",{onClick:y=>{y.stopPropagation(),s(P.id)},className:"p-1 text-text-secondary hover:text-accent-red hover:bg-accent-red/10 rounded transition-colors",title:"删除外键",children:T.jsx(yE,{size:14})})})]},P.id))})]}),e.length===0&&T.jsx("div",{className:"text-center py-8 text-text-secondary text-sm",children:'暂无外键,点击"添加外键"创建'})]})]})}function F_({options:e,dbType:t,onChange:E}){const n=t.toLowerCase()==="mysql"||t.toLowerCase()==="mariadb",r=m_.map(a=>({label:a,value:a})),s=U_.map(a=>({label:a,value:a})),l=M_.map(a=>({label:a,value:a})),o=(jR[e.charset]||[]).map(a=>({label:a,value:a}));return n?T.jsx("div",{className:"p-4 space-y-4",children:T.jsxs("div",{className:"grid grid-cols-2 gap-4",children:[T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-1.5",children:"数据库引擎"}),T.jsx(xt,{value:e.engine,options:r,onChange:a=>E({...e,engine:a}),placeholder:"选择引擎",className:"h-9 bg-metro-surface border border-metro-border px-2"})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-1.5",children:"行格式"}),T.jsx(xt,{value:e.rowFormat,options:s,onChange:a=>E({...e,rowFormat:a}),placeholder:"选择行格式",className:"h-9 bg-metro-surface border border-metro-border px-2"})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-1.5",children:"字符集"}),T.jsx(xt,{value:e.charset,options:l,onChange:a=>{const R=jR[a]||[];E({...e,charset:a,collation:R[0]||""})},placeholder:"选择字符集",className:"h-9 bg-metro-surface border border-metro-border px-2"})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-1.5",children:"排序规则"}),T.jsx(xt,{value:e.collation,options:o,onChange:a=>E({...e,collation:a}),placeholder:"选择排序规则",className:"h-9 bg-metro-surface border border-metro-border px-2"})]}),T.jsxs("div",{children:[T.jsx("label",{className:"block text-sm text-text-secondary mb-1.5",children:"自增值"}),T.jsx("input",{type:"text",value:e.autoIncrement,onChange:a=>E({...e,autoIncrement:a.target.value}),placeholder:"默认",className:`w-full h-9 px-3 bg-metro-surface border border-metro-border text-sm\r focus:border-accent-blue focus:outline-none transition-colors`})]})]})}):T.jsx("div",{className:"p-4 text-text-secondary text-sm",children:"表选项仅适用于 MySQL / MariaDB"})}function Y_({sql:e}){const[t,E]=f.useState(!1),n=async()=>{await navigator.clipboard.writeText(e),E(!0),setTimeout(()=>E(!1),2e3)};return T.jsxs("div",{className:"h-full flex flex-col",children:[T.jsxs("div",{className:"flex items-center justify-between px-4 py-2 border-b border-metro-border bg-metro-surface/30 flex-shrink-0",children:[T.jsx("span",{className:"text-sm text-text-secondary",children:"将要执行的 SQL 语句"}),T.jsx("button",{onClick:n,className:"flex items-center gap-1.5 px-3 py-1.5 text-xs bg-metro-surface hover:bg-metro-hover border border-metro-border transition-colors",children:t?"已复制":"复制"})]}),T.jsx("div",{className:"flex-1 overflow-auto p-4",children:T.jsx("pre",{className:"text-sm font-mono text-accent-teal whitespace-pre-wrap break-all",children:e})})]})}function zR(e,t){const E=f.useRef(),n=f.useRef(e);return f.useEffect(()=>{n.current=e},[e]),f.useCallback((...r)=>{E.current&&clearTimeout(E.current),E.current=setTimeout(()=>{n.current(...r)},t)},[t])}function w_(){const[e,t]=f.useState([]),[E,n]=f.useState(null),[r,s]=f.useState(new Set),[l,o]=f.useState(new Map),[a,R]=f.useState(null),[A,N]=f.useState(new Map),[i,O]=f.useState(new Set),[C,u]=f.useState(new Set),[D,I]=f.useState(new Map),[S,c]=f.useState(!1),[L,B]=f.useState(null),[p,P]=f.useState(void 0),[y,Y]=f.useState([]),[K,oe]=f.useState("welcome"),[_e,F]=f.useState({text:"就绪",type:"success"}),[He,Ie]=f.useState(!1),[me,le]=f.useState(null),[X,ee]=f.useState(!1),[te,Ee]=f.useState(null),[Re,Fe]=f.useState(!1),[Ye,Me]=f.useState(null),[Ve,be]=f.useState(!1),[ze,Et]=f.useState(null),[iE,Mt]=f.useState(!1),[Oe,Ce]=f.useState(null);f.useEffect(()=>{se.loadConnections().then(d=>{d&&t(d)})},[]);const Lt=zR(d=>{se.saveConnections(d)},500);f.useEffect(()=>{e.length>0&&Lt(e)},[e,Lt]),f.useEffect(()=>{const d=_=>{if((_.ctrlKey||_.metaKey)&&_.key==="q"){_.preventDefault();const M=`query-${Date.now()}`,h={id:M,title:"查询",sql:"",results:null};Y($=>[...$,h]),oe(M)}};return window.addEventListener("keydown",d),()=>window.removeEventListener("keydown",d)},[]);const Jt=d=>{t(L?_=>_.map(M=>M.id===d.id?d:M):_=>[..._,d]),c(!1)},zt=async d=>{F({text:`正在连接 ${d.name}...`,type:"info"});const _=await se.connect(d);if(_?.success){s(h=>new Set(h).add(d.id)),n(d.id),F({text:`已连接: ${d.name}`,type:"success"});const M=await se.getDatabases(d.id);o(h=>new Map(h).set(d.id,M||[]))}else F({text:_?.message||"连接失败",type:"error"})},j=async d=>{await se.disconnect(d),s(_=>{const M=new Set(_);return M.delete(d),M}),o(_=>{const M=new Map(_);return M.delete(d),M}),N(_=>{const M=new Map(_);for(const h of M.keys())h.startsWith(`${d}:`)&&M.delete(h);return M}),E===d&&(n(null),R(null))},Qe=async d=>{if(n(d),r.has(d)&&!l.has(d)){F({text:"正在加载数据库列表...",type:"info"});try{const _=await se.getDatabases(d);o(M=>new Map(M).set(d,_||[])),F({text:`${_?.length||0} 个数据库`,type:"success"})}catch(_){F({text:_.message,type:"error"})}}},ve=f.useCallback(async(d,_)=>{if(A.has(d)){R(d);return}R(d),O(M=>new Set(M).add(d)),F({text:`正在加载 ${d} 的表...`,type:"info"});try{const M=await se.getTables(_,d);if(N(h=>{const $=new Map(h);return $.set(d,M||[]),$}),O(h=>{const $=new Set(h);return $.delete(d),$}),M&&M.length>0){const h=M.map(async Q=>{const q=await se.getColumns(_,d,Q.name);return{name:Q.name,cols:q||[]}}),$=await Promise.all(h);I(Q=>{const q=new Map(Q);return $.forEach(({name:Ze,cols:Nt})=>{Nt.length>0&&q.set(Ze,Nt)}),q})}F({text:`${d}: ${M?.length||0} 个表`,type:"success"})}catch(M){O(h=>{const $=new Set(h);return $.delete(d),$}),F({text:M.message,type:"error"})}},[A]),AE=d=>{const _=`query-${Date.now()}`,M={id:_,title:"查询",sql:"",results:null};Y(h=>[...h,M]),oe(_)},St=async(d,_,M)=>{const h=y.find(q=>"tableName"in q&&q.tableName===M&&q.database===_&&q.connectionId===d);if(h){oe(h.id);return}const $=`table-${Date.now()}`,Q={id:$,type:"table",tableName:M,database:_,connectionId:d,columns:[],data:[],total:0,page:1,pageSize:1e3,originalData:[],pendingChanges:new Map,deletedRows:new Set};Y(q=>[...q,Q]),oe($),u(q=>new Set(q).add($)),F({text:`正在加载 ${M}...`,type:"info"});try{const q=await se.getTableData(d,_,M,1,1e3),Ze=q?.columns||[];Y(Nt=>Nt.map(IE=>IE.id===$?{...IE,columns:Ze,data:q?.data||[],total:q?.total||0,originalData:q?.data||[]}:IE)),F({text:`${M}: ${q?.total||0} 行`,type:"success"})}catch(q){F({text:q.message,type:"error"}),Y(Ze=>Ze.filter(Nt=>Nt.id!==$)),oe("welcome")}finally{u(q=>{const Ze=new Set(q);return Ze.delete($),Ze})}},lt=async(d,_)=>{const M=y.find(h=>h.id===d);if(!(!M||!("tableName"in M))){u(h=>new Set(h).add(d)),F({text:`加载第 ${_} 页...`,type:"info"});try{const h=await se.getTableData(M.connectionId,M.database,M.tableName,_,M.pageSize);Y($=>$.map(Q=>Q.id===d&&"tableName"in Q?{...Q,data:h?.data||[],page:_,originalData:h?.data||[],pendingChanges:new Map,deletedRows:new Set}:Q)),F({text:`${M.tableName}: 第 ${_} 页`,type:"success"})}catch(h){F({text:h.message,type:"error"})}finally{u(h=>{const $=new Set(h);return $.delete(d),$})}}},Qt=async(d,_)=>{const M=y.find(h=>h.id===d);if(!(!M||!("tableName"in M))){u(h=>new Set(h).add(d)),F({text:`切换为每页 ${_} 条...`,type:"info"});try{const h=await se.getTableData(M.connectionId,M.database,M.tableName,1,_);Y($=>$.map(Q=>Q.id===d&&"tableName"in Q?{...Q,data:h?.data||[],page:1,pageSize:_,originalData:h?.data||[],pendingChanges:new Map,deletedRows:new Set}:Q)),F({text:`${M.tableName}: 每页 ${_} 条`,type:"success"})}catch(h){F({text:h.message,type:"error"})}finally{u(h=>{const $=new Set(h);return $.delete(d),$})}}},SE=(d,_,M,h)=>{Y($=>$.map(Q=>{if(Q.id!==d||!("tableName"in Q))return Q;const q=Q,Ze=[...q.data];Ze[_]={...Ze[_],[M]:h};const Nt=new Map(q.pendingChanges||new Map),IE=Nt.get(String(_))||{};return IE[M]=h,Nt.set(String(_),IE),{...q,data:Ze,pendingChanges:Nt}}))},ue=(d,_)=>{Y(M=>M.map(h=>{if(h.id!==d||!("tableName"in h))return h;const $=h,Q=new Set($.deletedRows||new Set);return Q.add(_),{...$,deletedRows:Q}}))},m=(d,_)=>{Y(M=>M.map(h=>{if(h.id!==d||!("tableName"in h))return h;const $=h,Q=new Set($.deletedRows||new Set);return _.forEach(q=>Q.add(q)),{...$,deletedRows:Q}}))},w=async d=>{const _=y.find(h=>h.id===d);if(!_||!("tableName"in _))return;const M=_.columns.find(h=>h.key==="PRI")?.name||_.columns[0]?.name;if(!M){F({text:"无法确定主键列",type:"error"});return}F({text:"保存中...",type:"info"});try{if(_.pendingChanges)for(const[Q,q]of _.pendingChanges){const Ze=parseInt(Q),IE=(_.originalData?.[Ze]||_.data[Ze])[M],ea=await se.updateRow(_.connectionId,_.database,_.tableName,{column:M,value:IE},q);if(ea?.error){F({text:`保存失败: ${ea.error}`,type:"error"});return}}if(_.deletedRows)for(const Q of _.deletedRows){const Ze=(_.originalData?.[Q]||_.data[Q])[M],Nt=await se.deleteRow(_.connectionId,_.database,_.tableName,{column:M,value:Ze});if(Nt?.error){F({text:`删除失败: ${Nt.error}`,type:"error"});return}}const h=await se.getTableData(_.connectionId,_.database,_.tableName,_.page,_.pageSize),$=await se.getTableData(_.connectionId,_.database,_.tableName,1,1);Y(Q=>Q.map(q=>q.id===d&&"tableName"in q?{...q,data:h?.data||[],total:$?.total||_.total,originalData:h?.data||[],pendingChanges:new Map,deletedRows:new Set}:q)),F({text:"保存成功",type:"success"})}catch(h){F({text:`保存失败: ${h.message}`,type:"error"})}},J=d=>{Y(_=>_.map(M=>{if(M.id!==d||!("tableName"in M))return M;const h=M;return{...h,data:h.originalData||h.data,pendingChanges:new Map,deletedRows:new Set}})),F({text:"已放弃修改",type:"warning"})},Te=async d=>{const _=y.find(M=>M.id===d);if(!(!_||!("tableName"in _))){u(M=>new Set(M).add(d)),F({text:`刷新 ${_.tableName}...`,type:"info"});try{const M=await se.getTableData(_.connectionId,_.database,_.tableName,_.page,_.pageSize),h=await se.getTableData(_.connectionId,_.database,_.tableName,1,1);Y($=>$.map(Q=>Q.id===d&&"tableName"in Q?{...Q,data:M?.data||[],total:h?.total||_.total,originalData:M?.data||[],pendingChanges:new Map,deletedRows:new Set}:Q)),F({text:`${_.tableName}: ${h?.total||0} 行`,type:"success"})}catch(M){F({text:M.message,type:"error"})}finally{u(M=>{const h=new Set(M);return h.delete(d),h})}}},b=zR(async(d,_)=>{if(!E){F({text:"请先连接数据库",type:"warning"});return}F({text:"执行中...",type:"info"});const M=Date.now(),h=await se.query(E,_),$=((Date.now()-M)/1e3).toFixed(2);h?.error?F({text:h.error,type:"error"}):(Y(Q=>Q.map(q=>q.id===d?{...q,results:h,sql:_}:q)),F({text:`${h?.rows?.length||0} 行 (${$}s)`,type:"success"}))},300),ne=async d=>{if(!E){F({text:"请先连接数据库",type:"warning"});return}F({text:`正在备份 ${d}...`,type:"info"});const _=await se.backupDatabase(E,d);_?.error?F({text:`备份失败: ${_.error}`,type:"error"}):_?.cancelled?F({text:"备份已取消",type:"warning"}):_?.success&&F({text:`备份成功: ${_.path}`,type:"success"})},ie=async(d,_,M)=>{if(!E){F({text:"请先连接数据库",type:"warning"});return}F({text:`正在导出 ${_}...`,type:"info"});const h=await se.exportTable(E,d,_,M);h?.error?F({text:`导出失败: ${h.error}`,type:"error"}):h?.cancelled?F({text:"导出已取消",type:"warning"}):h?.success&&F({text:`导出成功: ${h.path}`,type:"success"})},_t=d=>{le(d),Ie(!0)},NE=async(d,_,M)=>{if(!me)return;Ie(!1),F({text:`正在创建数据库 ${d}...`,type:"info"});const h=await se.createDatabase(me,d,_,M);if(h?.success){F({text:`数据库 ${d} 创建成功`,type:"success"});const $=await se.getDatabases(me);o(Q=>new Map(Q).set(me,$||[]))}else F({text:h?.message||"创建失败",type:"error"});le(null)},G=async(d,_)=>{F({text:`正在删除数据库 ${_}...`,type:"info"});const M=await se.dropDatabase(d,_);if(M?.success){F({text:`数据库 ${_} 已删除`,type:"success"});const h=await se.getDatabases(d);o($=>new Map($).set(d,h||[])),N($=>{const Q=new Map($);return Q.delete(_),Q}),a===_&&R(null)}else F({text:M?.message||"删除失败",type:"error"})},x=(d,_)=>{sT(d,_)},W=async(d,_)=>{if(!te)return;const{connectionId:M,database:h}=te;ee(!1),F({text:`正在创建表 ${d}...`,type:"info"});const $=_.map(q=>({name:q.name,type:q.length?`${q.type}(${q.length})`:q.type,nullable:q.nullable,primaryKey:q.primaryKey,autoIncrement:q.autoIncrement,defaultValue:q.defaultValue,comment:q.comment})),Q=await se.createTable(M,h,d,$);Q?.success?(F({text:`表 ${d} 创建成功`,type:"success"}),he(M,h)):F({text:Q?.message||"创建失败",type:"error"}),Ee(null)},Ae=async(d,_,M)=>{F({text:`正在删除表 ${M}...`,type:"info"});const h=await se.dropTable(d,_,M);h?.success?(F({text:`表 ${M} 已删除`,type:"success"}),he(d,_),Y($=>$.filter(Q=>!("tableName"in Q)||Q.tableName!==M||Q.database!==_))):F({text:h?.message||"删除失败",type:"error"})},H=async(d,_,M)=>{F({text:`正在清空表 ${M}...`,type:"info"});const h=await se.truncateTable(d,_,M);if(h?.success){F({text:`表 ${M} 已清空`,type:"success"});const $=y.find(Q=>"tableName"in Q&&Q.tableName===M&&Q.database===_);$&&Te($.id)}else F({text:h?.message||"清空失败",type:"error"})},z=(d,_,M)=>{Me({connectionId:d,database:_,table:M}),Fe(!0)},de=async d=>{if(!Ye)return;const{connectionId:_,database:M,table:h}=Ye;Fe(!1),F({text:`正在重命名表 ${h} -> ${d}...`,type:"info"});const $=await se.renameTable(_,M,h,d);$?.success?(F({text:`表已重命名为 ${d}`,type:"success"}),he(_,M),Y(Q=>Q.map(q=>"tableName"in q&&q.tableName===h&&q.database===M?{...q,tableName:d}:q))):F({text:$?.message||"重命名失败",type:"error"}),Me(null)},ot=(d,_,M)=>{Et({connectionId:d,database:_,table:M}),be(!0)},Le=async(d,_)=>{if(!ze)return;const{connectionId:M,database:h,table:$}=ze;be(!1),F({text:`正在复制表 ${$} -> ${d}...`,type:"info"});const Q=await se.duplicateTable(M,h,$,d,_);Q?.success?(F({text:`表已复制为 ${d}`,type:"success"}),he(M,h)):F({text:Q?.message||"复制失败",type:"error"}),Et(null)},he=async(d,_)=>{O(M=>new Set(M).add(_)),F({text:`刷新 ${_} 表列表...`,type:"info"});try{const M=await se.getTables(d,_);N(h=>{const $=new Map(h);return $.set(_,M||[]),$}),F({text:`${_}: ${M?.length||0} 个表`,type:"success"})}catch(M){F({text:M.message,type:"error"})}finally{O(M=>{const h=new Set(M);return h.delete(_),h})}},wn=(d,_,M)=>{Ce({mode:"edit",connectionId:d,database:_,tableName:M}),Mt(!0)},sT=(d,_)=>{Ce({mode:"create",connectionId:d,database:_}),Mt(!0)},gr=async d=>{if(!Oe)return{success:!1,message:"无效的操作"};const{connectionId:_,database:M}=Oe;F({text:"正在保存表结构...",type:"info"});const h=await se.executeMultiSQL(_,d);return h?.success?(F({text:"表结构保存成功",type:"success"}),he(_,M),{success:!0,message:"保存成功"}):(F({text:h?.message||"保存失败",type:"error"}),{success:!1,message:h?.message||"保存失败"})},TT=f.useCallback(async()=>{if(!Oe||Oe.mode!=="edit"||!Oe.tableName)return{columns:[],indexes:[],foreignKeys:[],options:{}};const{connectionId:d,database:_,tableName:M}=Oe;return await se.getTableInfo(d,_,M)},[Oe]),lT=async()=>Oe?await se.getDatabases(Oe.connectionId):[],oT=async d=>Oe?(await se.getTables(Oe.connectionId,d)).map(M=>M.name):[],tn=async(d,_)=>Oe?await se.getColumnNames(Oe.connectionId,d,_):[],Zt=d=>e.find(M=>M.id===d)?.type||"mysql";return T.jsxs("div",{className:"h-screen flex flex-col bg-metro-dark overflow-hidden",children:[T.jsx(UO,{}),T.jsxs("div",{className:"flex-1 flex overflow-hidden",children:[T.jsx(xO,{connections:e,activeConnection:E,connectedIds:r,databasesMap:l,tablesMap:A,selectedDatabase:a,loadingDbSet:i,onNewConnection:()=>{B(null),P(void 0),c(!0)},onSelectConnection:Qe,onConnect:zt,onDisconnect:j,onEditConnection:d=>{B(d),c(!0)},onDeleteConnection:d=>t(_=>_.filter(M=>M.id!==d)),onDeleteConnections:d=>{d.forEach(_=>{r.has(_)&&se.disconnect(_)}),s(_=>{const M=new Set(_);return d.forEach(h=>M.delete(h)),M}),t(_=>_.filter(M=>!d.includes(M.id))),F({text:`已删除 ${d.length} 个连接`,type:"success"})},onSelectDatabase:ve,onOpenTable:St,onBackupDatabase:ne,onExportTable:ie,onCreateDatabase:_t,onDropDatabase:G,onCreateTable:x,onDropTable:Ae,onTruncateTable:H,onRenameTable:z,onDuplicateTable:ot,onRefreshTables:he,onDesignTable:wn,onExportConnections:async d=>{const _=await se.exportConnections(e,d);_?.success?F({text:`已导出 ${_.count} 个连接到 ${_.path}`,type:"success"}):_?.error&&F({text:_.error,type:"error"})},onImportConnections:async()=>{const d=await se.importConnections();if(d?.success&&d.connections){const _=new Set(e.map(h=>h.name)),M=d.connections.map(h=>{let $=h.name,Q=1;for(;_.has($);)$=`${h.name} (${Q++})`;return _.add($),{...h,name:$}});t(h=>[...h,...M]),F({text:`已从 ${d.source} 导入 ${d.count} 个连接`,type:"success"})}else d?.error&&F({text:d.error,type:"error"})}}),T.jsx(C_,{tabs:y,activeTab:K,databases:E?l.get(E)||[]:[],tables:a?A.get(a)||[]:[],columns:D,onTabChange:oe,onCloseTab:d=>{Y(_=>{const M=_.filter(h=>h.id!==d);if(K===d){const h=_.findIndex($=>$.id===d);if(M.length>0){const $=Math.min(h,M.length-1);oe(M[$].id)}else oe("welcome")}return M})},onNewQuery:()=>AE(),onRunQuery:b,onUpdateSql:(d,_)=>Y(M=>M.map(h=>h.id===d&&!("tableName"in h)?{...h,sql:_}:h)),onUpdateTabTitle:(d,_)=>Y(M=>M.map(h=>h.id===d&&!("tableName"in h)?{...h,title:_}:h)),onLoadTablePage:lt,onChangeTablePageSize:Qt,onUpdateTableCell:SE,onDeleteTableRow:ue,onDeleteTableRows:m,onSaveTableChanges:w,onDiscardTableChanges:J,onRefreshTable:Te,loadingTables:C,onNewConnectionWithType:d=>{B(null),P(d),c(!0)}})]}),T.jsxs("div",{className:"h-6 bg-metro-bg flex items-center px-3 text-xs border-t border-metro-border",children:[T.jsxs("div",{className:`flex items-center gap-2 ${_e.type==="success"?"text-accent-green":_e.type==="error"?"text-accent-red":_e.type==="warning"?"text-accent-orange":"text-white/60"}`,children:[T.jsx("span",{className:"w-2 h-2 rounded-full bg-current"}),_e.text]}),T.jsx("span",{className:"ml-auto text-white/40",children:"EasySQL"})]}),S&&T.jsx(D_,{connection:L,defaultType:p,onSave:Jt,onClose:()=>{c(!1),P(void 0)}}),T.jsx(P_,{isOpen:He,onClose:()=>{Ie(!1),le(null)},onSubmit:NE}),T.jsx(f_,{isOpen:X,database:te?.database||"",onClose:()=>{ee(!1),Ee(null)},onSubmit:W}),T.jsx($R,{isOpen:Re,title:"重命名表",label:"新表名",placeholder:"输入新的表名",defaultValue:Ye?.table||"",confirmText:"重命名",icon:T.jsx(SS,{size:18,className:"text-accent-blue"}),onClose:()=>{Fe(!1),Me(null)},onSubmit:de}),T.jsx($R,{isOpen:Ve,title:"复制表",label:"新表名",placeholder:"输入新的表名",defaultValue:ze?.table?`${ze.table}_copy`:"",confirmText:"复制",icon:T.jsx(nT,{size:18,className:"text-accent-purple"}),showDataOption:!0,onClose:()=>{be(!1),Et(null)},onSubmit:d=>Le(d,!1),onSubmitWithData:Le}),iE&&Oe&&T.jsx(G_,{isOpen:!0,mode:Oe.mode,database:Oe.database,tableName:Oe.tableName,connectionId:Oe.connectionId,dbType:Zt(Oe.connectionId),onClose:()=>{Mt(!1),Ce(null)},onSave:gr,onGetTableInfo:Oe.mode==="edit"?TT:void 0,onGetDatabases:lT,onGetTables:oT,onGetColumns:tn})]})}ll.createRoot(document.getElementById("root")).render(T.jsx(kS.StrictMode,{children:T.jsx(w_,{})}));export{kS as W,gO as _,T as j,f as r};