@duckcodeailabs/dql-cli 0.3.0 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/dql-notebook/assets/index-C7bfa1Fe.js +477 -0
- package/dist/assets/dql-notebook/index.html +1 -1
- package/dist/assets/templates/dql.config.reference.json +154 -0
- package/dist/assets/templates/ecommerce/dql.config.json +5 -0
- package/dist/assets/templates/ecommerce/semantic-layer/cubes/customers_cube.yaml +49 -0
- package/dist/assets/templates/ecommerce/semantic-layer/cubes/orders_cube.yaml +70 -0
- package/dist/assets/templates/ecommerce/semantic-layer/dimensions/channel.yaml +5 -1
- package/dist/assets/templates/ecommerce/semantic-layer/dimensions/order_date.yaml +9 -0
- package/dist/assets/templates/ecommerce/semantic-layer/dimensions/region.yaml +9 -0
- package/dist/assets/templates/ecommerce/semantic-layer/dimensions/segment.yaml +8 -0
- package/dist/assets/templates/ecommerce/semantic-layer/hierarchies/customer_geo.yaml +18 -0
- package/dist/assets/templates/ecommerce/semantic-layer/metrics/avg_order_value.yaml +10 -0
- package/dist/assets/templates/ecommerce/semantic-layer/metrics/gmv.yaml +7 -1
- package/dist/assets/templates/ecommerce/semantic-layer/metrics/gross_margin.yaml +10 -0
- package/dist/assets/templates/ecommerce/semantic-layer/metrics/order_count.yaml +10 -0
- package/dist/assets/templates/saas/dql.config.json +5 -0
- package/dist/assets/templates/saas/semantic-layer/dimensions/owner_segment.yaml +8 -0
- package/dist/assets/templates/saas/semantic-layer/dimensions/plan_tier.yaml +8 -0
- package/dist/assets/templates/saas/semantic-layer/dimensions/risk_bucket.yaml +9 -0
- package/dist/assets/templates/saas/semantic-layer/dimensions/status.yaml +8 -0
- package/dist/assets/templates/saas/semantic-layer/hierarchies/account_segments.yaml +18 -0
- package/dist/assets/templates/saas/semantic-layer/metrics/account_count.yaml +10 -0
- package/dist/assets/templates/saas/semantic-layer/metrics/expansion_mrr.yaml +11 -0
- package/dist/assets/templates/saas/semantic-layer/metrics/mrr.yaml +7 -1
- package/dist/assets/templates/starter/dql.config.json +5 -0
- package/dist/assets/templates/starter/notebooks/semantic_layer_tutorial.dqlnb +60 -0
- package/dist/assets/templates/starter/semantic-layer/cubes/revenue_cube.yaml +77 -0
- package/dist/assets/templates/starter/semantic-layer/dimensions/segment_tier.yaml +1 -1
- package/dist/assets/templates/starter/semantic-layer/metrics/revenue.yaml +1 -1
- package/dist/assets/templates/taxi/dql.config.json +5 -0
- package/dist/assets/templates/taxi/semantic-layer/dimensions/airport_flag.yaml +8 -0
- package/dist/assets/templates/taxi/semantic-layer/dimensions/dropoff_borough.yaml +9 -0
- package/dist/assets/templates/taxi/semantic-layer/dimensions/payment_type.yaml +8 -0
- package/dist/assets/templates/taxi/semantic-layer/dimensions/pickup_borough.yaml +9 -0
- package/dist/assets/templates/taxi/semantic-layer/dimensions/pickup_date.yaml +9 -0
- package/dist/assets/templates/taxi/semantic-layer/hierarchies/trip_route.yaml +14 -0
- package/dist/assets/templates/taxi/semantic-layer/metrics/avg_trip_miles.yaml +10 -0
- package/dist/assets/templates/taxi/semantic-layer/metrics/total_fare.yaml +10 -0
- package/dist/assets/templates/taxi/semantic-layer/metrics/total_tips.yaml +10 -0
- package/dist/assets/templates/taxi/semantic-layer/metrics/trip_count.yaml +10 -0
- package/dist/commands/doctor.d.ts.map +1 -1
- package/dist/commands/doctor.js +36 -0
- package/dist/commands/doctor.js.map +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +8 -2
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/semantic.d.ts +10 -0
- package/dist/commands/semantic.d.ts.map +1 -0
- package/dist/commands/semantic.js +242 -0
- package/dist/commands/semantic.js.map +1 -0
- package/dist/index.js +6 -1
- package/dist/index.js.map +1 -1
- package/dist/local-runtime.d.ts +2 -0
- package/dist/local-runtime.d.ts.map +1 -1
- package/dist/local-runtime.js +106 -18
- package/dist/local-runtime.js.map +1 -1
- package/dist/package.json +44 -0
- package/package.json +15 -14
- package/LICENSE +0 -123
- package/dist/assets/dql-notebook/assets/index-_N_gerXe.js +0 -353
|
@@ -0,0 +1,477 @@
|
|
|
1
|
+
import{r as Gt,a as NT,g as yt}from"./react-CRB3T2We.js";import{S as pE,g as Bt,E as Q,s as lT,a as w,b as LT,c as CT,P as cT,d as _T,e as dT,F as DT,f as uT,h as gt,V as PT,D as ME,R as pT,i as MT,C as Te,j as Ht,k as K,r as UT,l as hT,m as fT,t as mT,n as xT,o as GT,p as yT,q as BT,u as gT,v as HT,w as Me,x as FT,y as bT,z as YT,A as vT,B as VT,G as WT,H as XT,I as wT,J as KT,K as $T,L as kT}from"./codemirror-CCrEt63p.js";(function(){const e=document.createElement("link").relList;if(e&&e.supports&&e.supports("modulepreload"))return;for(const T of document.querySelectorAll('link[rel="modulepreload"]'))r(T);new MutationObserver(T=>{for(const s of T)if(s.type==="childList")for(const R of s.addedNodes)R.tagName==="LINK"&&R.rel==="modulepreload"&&r(R)}).observe(document,{childList:!0,subtree:!0});function t(T){const s={};return T.integrity&&(s.integrity=T.integrity),T.referrerPolicy&&(s.referrerPolicy=T.referrerPolicy),T.crossOrigin==="use-credentials"?s.credentials="include":T.crossOrigin==="anonymous"?s.credentials="omit":s.credentials="same-origin",s}function r(T){if(T.ep)return;T.ep=!0;const s=t(T);fetch(T.href,s)}})();var We={exports:{}},Ce={};/**
|
|
2
|
+
* @license React
|
|
3
|
+
* react-jsx-runtime.production.min.js
|
|
4
|
+
*
|
|
5
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
6
|
+
*
|
|
7
|
+
* This source code is licensed under the MIT license found in the
|
|
8
|
+
* LICENSE file in the root directory of this source tree.
|
|
9
|
+
*/var HE;function jT(){if(HE)return Ce;HE=1;var E=Gt(),e=Symbol.for("react.element"),t=Symbol.for("react.fragment"),r=Object.prototype.hasOwnProperty,T=E.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,s={key:!0,ref:!0,__self:!0,__source:!0};function R(A,a,o){var S,i={},I=null,O=null;o!==void 0&&(I=""+o),a.key!==void 0&&(I=""+a.key),a.ref!==void 0&&(O=a.ref);for(S in a)r.call(a,S)&&!s.hasOwnProperty(S)&&(i[S]=a[S]);if(A&&A.defaultProps)for(S in a=A.defaultProps,a)i[S]===void 0&&(i[S]=a[S]);return{$$typeof:e,type:A,key:I,ref:O,props:i,_owner:T.current}}return Ce.Fragment=t,Ce.jsx=R,Ce.jsxs=R,Ce}var FE;function JT(){return FE||(FE=1,We.exports=jT()),We.exports}var n=JT(),Ue={},bE;function QT(){if(bE)return Ue;bE=1;var E=NT();return Ue.createRoot=E.createRoot,Ue.hydrateRoot=E.hydrateRoot,Ue}var ZT=QT(),l=Gt();const Be=yt(l),qT={themeMode:"dark",sidebarPanel:"files",sidebarOpen:!0,files:[],filesLoading:!1,activeFile:null,cells:[],notebookTitle:"",notebookDirty:!1,schemaTables:[],schemaLoading:!1,semanticLayer:{available:!1,provider:null,metrics:[],dimensions:[],hierarchies:[],loading:!1},devPanelOpen:!1,devPanelTab:"logs",queryLog:[],newNotebookModalOpen:!1,executionCounter:0,savingFile:!1};function zT(E,e){switch(e.type){case"SET_THEME":return{...E,themeMode:e.mode};case"SET_SIDEBAR_PANEL":return{...E,sidebarPanel:e.panel,sidebarOpen:e.panel!==null};case"TOGGLE_SIDEBAR":return{...E,sidebarOpen:!E.sidebarOpen};case"SET_FILES":return{...E,files:e.files};case"SET_FILES_LOADING":return{...E,filesLoading:e.loading};case"OPEN_FILE":return{...E,activeFile:e.file,cells:e.cells,notebookTitle:e.title,notebookDirty:!1};case"SET_CELLS":return{...E,cells:e.cells,notebookDirty:!0};case"ADD_CELL":{if(!e.afterId)return{...E,cells:[...E.cells,e.cell],notebookDirty:!0};const t=E.cells.findIndex(T=>T.id===e.afterId);if(t===-1)return{...E,cells:[...E.cells,e.cell],notebookDirty:!0};const r=[...E.cells];return r.splice(t+1,0,e.cell),{...E,cells:r,notebookDirty:!0}}case"UPDATE_CELL":{const t=E.cells.map(T=>T.id===e.id?{...T,...e.updates}:T),r=e.updates.executionCount!==void 0?E.executionCounter+1:E.executionCounter;return{...E,cells:t,notebookDirty:!0,executionCounter:r}}case"DELETE_CELL":return{...E,cells:E.cells.filter(t=>t.id!==e.id),notebookDirty:!0};case"MOVE_CELL":{const t=E.cells.findIndex(T=>T.id===e.id);if(t===-1)return E;const r=[...E.cells];return e.direction==="up"&&t>0?[r[t-1],r[t]]=[r[t],r[t-1]]:e.direction==="down"&&t<r.length-1&&([r[t],r[t+1]]=[r[t+1],r[t]]),{...E,cells:r,notebookDirty:!0}}case"SET_SCHEMA":return{...E,schemaTables:e.tables};case"SET_SCHEMA_LOADING":return{...E,schemaLoading:e.loading};case"TOGGLE_SCHEMA_TABLE":return{...E,schemaTables:E.schemaTables.map(t=>t.name===e.tableName?{...t,expanded:!t.expanded}:t)};case"TOGGLE_DEV_PANEL":return{...E,devPanelOpen:!E.devPanelOpen};case"SET_DEV_PANEL_TAB":return{...E,devPanelTab:e.tab};case"APPEND_QUERY_LOG":return{...E,queryLog:[...E.queryLog,e.entry]};case"OPEN_NEW_NOTEBOOK_MODAL":return{...E,newNotebookModalOpen:!0};case"CLOSE_NEW_NOTEBOOK_MODAL":return{...E,newNotebookModalOpen:!1};case"SET_NOTEBOOK_DIRTY":return{...E,notebookDirty:e.dirty};case"SET_SAVING":return{...E,savingFile:e.saving};case"FILE_ADDED":return{...E,files:[...E.files,e.file]};case"SET_TABLE_COLUMNS":return{...E,schemaTables:E.schemaTables.map(t=>t.name===e.tableName?{...t,columns:e.columns}:t)};case"SET_PARAM_VALUE":return{...E,cells:E.cells.map(t=>t.id===e.id?{...t,paramValue:e.value}:t),notebookDirty:!0};case"SET_SEMANTIC_LAYER":return{...E,semanticLayer:{...e.layer,loading:!1}};case"SET_SEMANTIC_LOADING":return{...E,semanticLayer:{...E.semanticLayer,loading:e.loading}};default:return E}}const Ft=l.createContext(null);function er({children:E}){const[e,t]=l.useReducer(zT,qT);return n.jsx(Ft.Provider,{value:{state:e,dispatch:t},children:E})}function y(){const E=l.useContext(Ft);if(!E)throw new Error("useNotebook must be used within NotebookProvider");return E}function ee(){return`cell_${Date.now()}_${Math.random().toString(36).slice(2,8)}`}function j(E,e=""){const t={id:ee(),type:E,content:e,status:"idle"};return E==="param"&&(t.content="",t.paramConfig={paramType:"text",label:"Parameter",defaultValue:"",options:[]}),t}const Er={appBg:"#0d1117",sidebarBg:"#161b22",activityBarBg:"#0d1117",headerBg:"#161b22",headerBorder:"#21262d",cellBg:"#161b22",cellBorder:"#30363d",cellBorderActive:"#388bfd",cellBorderRunning:"#56d364",textPrimary:"#e6edf3",textSecondary:"#8b949e",textMuted:"#484f58",editorBg:"#0d1117",editorBorder:"#30363d",tableBorder:"#30363d",tableHeaderBg:"#1c2128",tableRowHover:"#21262d",accent:"#388bfd",accentHover:"#58a6ff",success:"#56d364",error:"#f85149",warning:"#e3b341",btnBg:"#21262d",btnBorder:"#30363d",btnHover:"#30363d",sidebarItemHover:"#21262d",sidebarItemActive:"#1f2d3d",scrollbarThumb:"#30363d",modalBg:"#161b22",modalOverlay:"rgba(0,0,0,0.7)",inputBg:"#0d1117",inputBorder:"#30363d",pillBg:"#21262d",font:"Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif",fontMono:"'JetBrains Mono', 'Fira Code', Consolas, monospace",fontSerif:"Georgia, 'Times New Roman', serif"},tr={appBg:"#ffffff",sidebarBg:"#f6f8fa",activityBarBg:"#eff1f3",headerBg:"#ffffff",headerBorder:"#d0d7de",cellBg:"#ffffff",cellBorder:"#d0d7de",cellBorderActive:"#0969da",cellBorderRunning:"#1f883d",textPrimary:"#1f2328",textSecondary:"#57606a",textMuted:"#8c959f",editorBg:"#f6f8fa",editorBorder:"#d0d7de",tableBorder:"#d0d7de",tableHeaderBg:"#f6f8fa",tableRowHover:"#f6f8fa",accent:"#0969da",accentHover:"#0550ae",success:"#1f883d",error:"#cf222e",warning:"#9a6700",btnBg:"#f6f8fa",btnBorder:"#d0d7de",btnHover:"#eaeef2",sidebarItemHover:"#eaeef2",sidebarItemActive:"#dbeafe",scrollbarThumb:"#d0d7de",modalBg:"#ffffff",modalOverlay:"rgba(0,0,0,0.4)",inputBg:"#ffffff",inputBorder:"#d0d7de",pillBg:"#eaeef2",font:"Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif",fontMono:"'JetBrains Mono', 'Fira Code', Consolas, monospace",fontSerif:"Georgia, 'Times New Roman', serif"},G={dark:Er,light:tr};function te({title:E,active:e,onClick:t,children:r,t:T}){const[s,R]=l.useState(!1);return n.jsx("button",{title:E,onClick:t,onMouseEnter:()=>R(!0),onMouseLeave:()=>R(!1),style:{width:32,height:32,display:"flex",alignItems:"center",justifyContent:"center",background:"transparent",border:"none",borderLeft:e?`2px solid ${T.accent}`:"2px solid transparent",cursor:"pointer",color:e?T.textPrimary:s?T.textSecondary:T.textMuted,transition:"color 0.15s, border-color 0.15s",padding:0,flexShrink:0},children:r})}function Tr(){return n.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M1.75 1A1.75 1.75 0 0 0 0 2.75v10.5C0 14.216.784 15 1.75 15h12.5A1.75 1.75 0 0 0 16 13.25v-8.5A1.75 1.75 0 0 0 14.25 3H7.5a.25.25 0 0 1-.2-.1l-.9-1.2C6.07 1.26 5.55 1 5 1H1.75Z"})})}function rr(){return n.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M8 0C3.58 0 0 1.567 0 3.5v9C0 14.433 3.58 16 8 16s8-1.567 8-3.5v-9C16 1.567 12.42 0 8 0ZM1.5 7.784V5.716C3.05 6.51 5.404 7 8 7s4.95-.49 6.5-1.284v2.068C12.95 8.578 10.596 9 8 9s-4.95-.422-6.5-1.216ZM8 1.5c3.17 0 5.854 1.116 6.357 2.5H1.643C2.146 2.616 4.83 1.5 8 1.5Zm0 13c-3.17 0-5.854-1.116-6.357-2.5h12.714C13.854 13.384 11.17 14.5 8 14.5Zm6.5-3.284C12.95 11.01 10.596 11.5 8 11.5s-4.95-.49-6.5-1.284V8.216C3.05 9.01 5.404 9.5 8 9.5s4.95-.49 6.5-1.284v2.5Z"})})}function nr(){return n.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M8 1.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm6.5-2a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0Zm-2 4.5a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0Zm5 0a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0Z"})})}function sr(){return n.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M2 2h12a1 1 0 0 1 0 2H2a1 1 0 0 1 0-2Zm0 4h8a1 1 0 0 1 0 2H2a1 1 0 0 1 0-2Zm0 4h10a1 1 0 0 1 0 2H2a1 1 0 0 1 0-2Z"})})}function Rr(){return n.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M1 2.75C1 1.784 1.784 1 2.75 1h2.5C6.216 1 7 1.784 7 2.75v2.5C7 6.216 6.216 7 5.25 7h-2.5C1.784 7 1 6.216 1 5.25Zm1.75-.25a.25.25 0 0 0-.25.25v2.5c0 .138.112.25.25.25h2.5A.25.25 0 0 0 6 5.25v-2.5A.25.25 0 0 0 5.25 2.5ZM9 2.75C9 1.784 9.784 1 10.75 1h2.5C14.216 1 15 1.784 15 2.75v2.5C15 6.216 14.216 7 13.25 7h-2.5C9.784 7 9 6.216 9 5.25Zm1.75-.25a.25.25 0 0 0-.25.25v2.5c0 .138.112.25.25.25h2.5a.25.25 0 0 0 .25-.25v-2.5a.25.25 0 0 0-.25-.25ZM1 10.75C1 9.784 1.784 9 2.75 9h2.5C6.216 9 7 9.784 7 10.75v2.5C7 14.216 6.216 15 5.25 15h-2.5C1.784 15 1 14.216 1 13.25Zm1.75-.25a.25.25 0 0 0-.25.25v2.5c0 .138.112.25.25.25h2.5a.25.25 0 0 0 .25-.25v-2.5a.25.25 0 0 0-.25-.25ZM13 9.75a.75.75 0 0 1 .75.75v1.75H15.5a.75.75 0 0 1 0 1.5h-1.75V15.5a.75.75 0 0 1-1.5 0v-1.75H10.5a.75.75 0 0 1 0-1.5h1.75V10.5A.75.75 0 0 1 13 9.75Z"})})}function Ar(){return n.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M0 1.75A.75.75 0 0 1 .75 1h4.253c1.227 0 2.317.59 3 1.501A3.743 3.743 0 0 1 11.006 1h4.245a.75.75 0 0 1 .75.75v10.5a.75.75 0 0 1-.75.75h-4.507a2.25 2.25 0 0 0-1.591.659l-.622.621a.75.75 0 0 1-1.06 0l-.622-.621A2.25 2.25 0 0 0 5.258 13H.75a.75.75 0 0 1-.75-.75Zm7.251 10.324.004-5.073-.002-2.253A2.25 2.25 0 0 0 5.003 2.5H1.5v9h3.757a3.75 3.75 0 0 1 1.994.574ZM8.755 4.75l-.004 7.322a3.752 3.752 0 0 1 1.992-.572H14.5v-9h-3.495a2.25 2.25 0 0 0-2.25 2.25Z"})})}function or(){return n.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.92 6.085h.001a.749.749 0 1 1-1.342-.67C6.03 4.26 6.88 3.75 8 3.75c1.463 0 2.5 1.008 2.5 2.25 0 1.133-.67 1.8-1.4 2.25-.487.3-.6.47-.6.75V9.5a.75.75 0 0 1-1.5 0v-.5c0-.833.585-1.33 1.1-1.65.387-.24.9-.597.9-1.35 0-.65-.53-1.25-1.5-1.25-.74 0-1.163.353-1.58.835ZM8 12a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z"})})}function Sr(){return n.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M8 0a8.2 8.2 0 0 1 .701.031C9.444.095 9.99.645 10.16 1.29l.288 1.107c.018.066.079.158.212.224.231.114.454.243.668.386.123.082.233.09.299.071l1.103-.303c.644-.176 1.392.021 1.82.63.27.385.506.792.704 1.218.315.675.111 1.422-.364 1.891l-.814.806c-.049.048-.098.147-.088.294.016.257.016.515 0 .772-.01.147.038.246.088.294l.814.806c.475.469.679 1.216.364 1.891a7.977 7.977 0 0 1-.704 1.217c-.428.61-1.176.807-1.82.63l-1.103-.303c-.066-.019-.176-.011-.299.071a5.909 5.909 0 0 1-.668.386c-.133.066-.194.158-.211.224l-.29 1.106c-.168.646-.715 1.196-1.458 1.26a8.006 8.006 0 0 1-1.402 0c-.743-.064-1.289-.614-1.458-1.26l-.289-1.106c-.018-.066-.079-.158-.212-.224a5.738 5.738 0 0 1-.668-.386c-.123-.082-.233-.09-.299-.071l-1.103.303c-.644.176-1.392-.021-1.82-.63a8.12 8.12 0 0 1-.704-1.218c-.315-.675-.111-1.422.363-1.891l.815-.806c.05-.048.098-.147.088-.294a6.214 6.214 0 0 1 0-.772c.01-.147-.038-.246-.088-.294l-.815-.806C.635 6.045.431 5.298.746 4.623a7.92 7.92 0 0 1 .704-1.217c.428-.61 1.176-.807 1.82-.63l1.103.303c.066.019.176.011.299-.071.214-.143.437-.272.668-.386.133-.066.194-.158.211-.224l.29-1.106C6.009.645 6.556.095 7.299.03 7.53.01 7.764 0 8 0Zm-.571 1.525c-.036.003-.108.036-.137.146l-.289 1.105c-.147.561-.549.967-.998 1.189-.173.086-.34.183-.5.29-.417.278-.97.423-1.529.27l-1.103-.303c-.109-.03-.175.016-.195.045-.22.312-.412.644-.573.99-.014.031-.021.11.059.19l.815.806c.411.406.562.957.53 1.456a4.709 4.709 0 0 0 0 .582c.032.499-.119 1.05-.53 1.456l-.815.806c-.081.08-.073.159-.059.19.162.346.353.677.573.989.02.03.085.076.195.046l1.102-.303c.56-.153 1.113-.008 1.53.27.161.107.328.204.501.29.447.222.85.629.997 1.189l.289 1.105c.029.109.101.143.137.146a6.6 6.6 0 0 0 1.142 0c.036-.003.108-.036.137-.146l.289-1.105c.147-.561.549-.967.998-1.189.173-.086.34-.183.5-.29.417-.278.97-.423 1.529-.27l1.103.303c.109.029.175-.016.195-.045.22-.313.411-.644.573-.99.014-.031.021-.11-.059-.19l-.815-.806c-.411-.406-.562-.957-.53-1.456a4.709 4.709 0 0 0 0-.582c-.032-.499.119-1.05.53-1.456l.815-.806c.081-.08.073-.159.059-.19a6.464 6.464 0 0 0-.573-.989c-.02-.03-.085-.076-.195-.046l-1.102.303c-.56.153-1.113.008-1.53-.27a4.44 4.44 0 0 0-.501-.29c-.447-.222-.85-.629-.997-1.189l-.289-1.105c-.029-.11-.101-.143-.137-.147a6.6 6.6 0 0 0-1.142 0ZM8 5.5a2.5 2.5 0 1 1 0 5 2.5 2.5 0 0 1 0-5ZM8 7a1 1 0 1 0 0 2 1 1 0 0 0 0-2Z"})})}function ir(){const{state:E,dispatch:e}=y(),t=G[E.themeMode];function r(T){E.sidebarPanel===T&&E.sidebarOpen?e({type:"TOGGLE_SIDEBAR"}):e({type:"SET_SIDEBAR_PANEL",panel:T})}return n.jsxs("div",{style:{width:32,flexShrink:0,background:t.activityBarBg,borderRight:`1px solid ${t.headerBorder}`,display:"flex",flexDirection:"column",alignItems:"center",paddingTop:8,paddingBottom:8,gap:2,userSelect:"none"},children:[n.jsx(te,{title:"Files",active:E.sidebarPanel==="files"&&E.sidebarOpen,onClick:()=>r("files"),t,children:n.jsx(Tr,{})}),n.jsx(te,{title:"Schema",active:E.sidebarPanel==="schema"&&E.sidebarOpen,onClick:()=>r("schema"),t,children:n.jsx(rr,{})}),n.jsx(te,{title:"Semantic Layer",active:E.sidebarPanel==="semantic"&&E.sidebarOpen,onClick:()=>r("semantic"),t,children:n.jsx(nr,{})}),n.jsx(te,{title:"Outline",active:E.sidebarPanel==="outline"&&E.sidebarOpen,onClick:()=>r("outline"),t,children:n.jsx(sr,{})}),n.jsx(te,{title:"Connection",active:E.sidebarPanel==="connection"&&E.sidebarOpen,onClick:()=>r("connection"),t,children:n.jsx(Rr,{})}),n.jsx(te,{title:"Reference",active:E.sidebarPanel==="reference"&&E.sidebarOpen,onClick:()=>r("reference"),t,children:n.jsx(Ar,{})}),n.jsx("div",{style:{flex:1}}),n.jsx(te,{title:"Help & Reference",active:E.sidebarPanel==="reference"&&E.sidebarOpen,onClick:()=>r("reference"),t,children:n.jsx(or,{})}),n.jsx(te,{title:"Settings",active:!1,onClick:()=>{},t,children:n.jsx(Sr,{})})]})}const Xe={notebooks:"Notebooks",workbooks:"Workbooks",blocks:"Blocks",dashboards:"Dashboards"};function ar({type:E}){switch(E){case"notebook":return n.jsx("svg",{width:"13",height:"13",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M0 1.75A.75.75 0 0 1 .75 1h4.253c1.227 0 2.317.59 3 1.501A3.743 3.743 0 0 1 11.006 1h4.245a.75.75 0 0 1 .75.75v10.5a.75.75 0 0 1-.75.75h-4.507a2.25 2.25 0 0 0-1.591.659l-.622.621a.75.75 0 0 1-1.063 0L7.597 13.66A2.25 2.25 0 0 0 6.007 13H.75a.75.75 0 0 1-.75-.75Zm7.251 10.324.004-5.073-.002-2.253A2.25 2.25 0 0 0 5.003 2.5H1.5v9h4.507c.656 0 1.287.169 1.744.324Zm1.499.004c.457-.155 1.088-.324 1.744-.324H15v-9h-3.495a2.25 2.25 0 0 0-2.252 2.247l-.002 9.077Z"})});case"workbook":return n.jsx("svg",{width:"13",height:"13",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M2 1.75C2 .784 2.784 0 3.75 0h8.5C13.216 0 14 .784 14 1.75v12.5A1.75 1.75 0 0 1 12.25 16h-8.5A1.75 1.75 0 0 1 2 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25Zm2 3.5a.75.75 0 0 1 .75-.75h3a.75.75 0 0 1 0 1.5h-3a.75.75 0 0 1-.75-.75ZM6.5 7.25a.75.75 0 0 0 0 1.5h3a.75.75 0 0 0 0-1.5Zm-.75 3.5a.75.75 0 0 1 .75-.75h3a.75.75 0 0 1 0 1.5h-3a.75.75 0 0 1-.75-.75Z"})});case"block":return n.jsx("svg",{width:"13",height:"13",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M10.5 0l5.25 4-5.25 4V6H9.25A1.75 1.75 0 0 0 7.5 7.75v2.5A1.75 1.75 0 0 0 9.25 12h1.25v8H9v-6.5A3.25 3.25 0 0 1 5.75 10h-2A3.25 3.25 0 0 1 .5 6.75v-2.5A3.25 3.25 0 0 1 3.75 1h2A3.25 3.25 0 0 1 9 4.5V6h1.5V0z"})});default:return n.jsx("svg",{width:"13",height:"13",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M.24 2.375C.24 1.064 1.225.001 2.409.001h6.451a1.17 1.17 0 0 1 .828.344l3.311 3.312a1.17 1.17 0 0 1 .344.828v9.14c0 1.31-.985 2.374-2.169 2.374H2.41C1.225 16 .24 14.937.24 13.625Zm2.169-1a.846.846 0 0 0-.844.86v11.39c0 .47.38.86.844.86h8.774a.847.847 0 0 0 .844-.86V5.157L8.688 1.373H2.41Z"})})}}function Ir({expanded:E}){return n.jsx("svg",{width:"13",height:"13",viewBox:"0 0 16 16",fill:"currentColor",children:E?n.jsx("path",{d:"M1.75 2.5a.25.25 0 0 0-.25.25v10.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25V4.25a.25.25 0 0 0-.25-.25H7.5A1.75 1.75 0 0 1 5.75 2.5h-4ZM0 2.75C0 1.784.784 1 1.75 1h4c.966 0 1.75.784 1.75 1.75H14.25c.966 0 1.75.784 1.75 1.75v8.5A1.75 1.75 0 0 1 14.25 14H1.75A1.75 1.75 0 0 1 0 12.25Z"}):n.jsx("path",{d:"M1.75 2.5a.25.25 0 0 0-.25.25v10.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25V4.25a.25.25 0 0 0-.25-.25H7.5A1.75 1.75 0 0 1 5.75 2.5h-4ZM0 2.75C0 1.784.784 1 1.75 1h4c.966 0 1.75.784 1.75 1.75H14.25c.966 0 1.75.784 1.75 1.75v8.5A1.75 1.75 0 0 1 14.25 14H1.75A1.75 1.75 0 0 1 0 12.25Z"})})}function Or(E){return E.name.replace(/\.(dqlnb|dql)$/,"")}function Nr({onOpenFile:E}){const{state:e,dispatch:t}=y(),r=G[e.themeMode],[T,s]=l.useState({notebooks:!0,workbooks:!0,blocks:!1,dashboards:!1}),[R,A]=l.useState(!1),a={notebooks:[],workbooks:[],blocks:[],dashboards:[]};for(const S of e.files){const i=S.folder.toLowerCase();i in a&&a[i].push(S)}const o=S=>{s(i=>({...i,[S]:!i[S]}))};return n.jsxs("div",{style:{flex:1,overflow:"auto",padding:"8px 0",display:"flex",flexDirection:"column",gap:0},children:[n.jsx("div",{style:{padding:"0 8px 8px"},children:n.jsxs("button",{onClick:()=>t({type:"OPEN_NEW_NOTEBOOK_MODAL"}),onMouseEnter:()=>A(!0),onMouseLeave:()=>A(!1),style:{width:"100%",height:30,background:"transparent",border:`1px dashed ${R?r.accent:r.cellBorder}`,borderRadius:6,color:R?r.accent:r.textSecondary,cursor:"pointer",fontSize:12,fontFamily:r.font,fontWeight:500,display:"flex",alignItems:"center",justifyContent:"center",gap:6,transition:"border-color 0.15s, color 0.15s"},children:[n.jsx("span",{style:{fontSize:16,lineHeight:1},children:"+"}),"New Notebook"]})}),e.filesLoading&&n.jsx("div",{style:{padding:"8px 14px",color:r.textMuted,fontSize:12,fontFamily:r.font},children:"Loading files…"}),Object.keys(Xe).map(S=>{const i=a[S],I=T[S];return n.jsxs("div",{children:[n.jsx(lr,{label:Xe[S],count:i.length,expanded:I,onToggle:()=>o(S),t:r}),I&&n.jsx("div",{children:i.length===0?n.jsxs("div",{style:{padding:"4px 14px 4px 32px",fontSize:12,color:r.textMuted,fontFamily:r.font,fontStyle:"italic"},children:["No ",Xe[S].toLowerCase()]}):i.map(O=>{var c;return n.jsx(Lr,{file:O,active:((c=e.activeFile)==null?void 0:c.path)===O.path,onClick:()=>E(O),t:r},O.path)})})]},S)})]})}function lr({label:E,count:e,expanded:t,onToggle:r,t:T}){const[s,R]=l.useState(!1);return n.jsxs("button",{onClick:r,onMouseEnter:()=>R(!0),onMouseLeave:()=>R(!1),style:{width:"100%",display:"flex",alignItems:"center",gap:6,padding:"3px 8px 3px 10px",background:s?T.sidebarItemHover:"transparent",border:"none",cursor:"pointer",color:T.textSecondary,fontSize:11,fontWeight:600,fontFamily:T.font,letterSpacing:"0.04em",textTransform:"uppercase",textAlign:"left",transition:"background 0.1s"},children:[n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 10 10",fill:"currentColor",style:{transform:t?"rotate(90deg)":"rotate(0deg)",transition:"transform 0.15s",flexShrink:0},children:n.jsx("path",{d:"M3 2l4 3-4 3V2Z"})}),n.jsx(Ir,{expanded:t}),n.jsx("span",{style:{flex:1},children:E}),e>0&&n.jsx("span",{style:{background:T.pillBg,color:T.textMuted,borderRadius:10,padding:"0 5px",fontSize:10,fontWeight:500},children:e})]})}function Lr({file:E,active:e,onClick:t,t:r}){const[T,s]=l.useState(!1);return n.jsxs("button",{onClick:t,onMouseEnter:()=>s(!0),onMouseLeave:()=>s(!1),style:{width:"100%",display:"flex",alignItems:"center",gap:6,padding:"4px 8px 4px 26px",background:e?r.sidebarItemActive:T?r.sidebarItemHover:"transparent",border:"none",borderLeft:e?`2px solid ${r.accent}`:"2px solid transparent",cursor:"pointer",color:e||T?r.textPrimary:r.textSecondary,fontSize:13,fontFamily:r.font,textAlign:"left",transition:"background 0.1s, color 0.1s",overflow:"hidden"},children:[n.jsx("span",{style:{flexShrink:0,color:e?r.accent:r.textMuted},children:n.jsx(ar,{type:E.type})}),n.jsx("span",{style:{overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",flex:1},children:Or(E)}),E.isNew&&n.jsx("span",{style:{fontSize:9,fontWeight:600,color:r.accent,background:r.sidebarItemActive,borderRadius:4,padding:"1px 4px",flexShrink:0},children:"NEW"})]})}const Cr=window.location.origin;async function k(E,e){const t=await fetch(`${Cr}${E}`,{headers:{"Content-Type":"application/json"},...e});if(!t.ok){const r=await t.text().catch(()=>t.statusText);throw new Error(r||`HTTP ${t.status}`)}if(t.status!==204)return t.json()}const V={async listNotebooks(){try{return await k("/api/notebooks")}catch{return[]}},async readNotebook(E){return k(`/api/notebook-content?path=${encodeURIComponent(E)}`)},async createNotebook(E,e){return k("/api/notebooks",{method:"POST",body:JSON.stringify({name:E,template:e})})},async saveNotebook(E,e){return k("/api/notebook-content",{method:"PUT",body:JSON.stringify({path:E,content:e})})},async executeQuery(E){var r;const e=await k("/api/query",{method:"POST",body:JSON.stringify({sql:E})});return{columns:Array.isArray(e==null?void 0:e.columns)?e.columns.map(T=>typeof T=="string"?T:typeof(T==null?void 0:T.name)=="string"?T.name:String(T)):[],rows:Array.isArray(e==null?void 0:e.rows)?e.rows:[],rowCount:(e==null?void 0:e.rowCount)??((r=e==null?void 0:e.rows)==null?void 0:r.length)??0,executionTime:(e==null?void 0:e.executionTime)??(e==null?void 0:e.executionTimeMs)??0}},async getSchema(){try{return await k("/api/schema")}catch{return[]}},async getConnections(){try{return await k("/api/connections")}catch{return{default:"unknown",connections:{}}}},async testConnection(){try{return await k("/api/test-connection",{method:"POST",body:JSON.stringify({})})}catch(E){return{ok:!1,message:E.message??"Connection failed"}}},async getSemanticLayer(){try{return await k("/api/semantic-layer")}catch{return{available:!1,provider:null,metrics:[],dimensions:[],hierarchies:[]}}},async composeQuery(E,e){try{return await k("/api/semantic-query",{method:"POST",body:JSON.stringify({metrics:E,dimensions:e})})}catch(t){return{error:t.message??"Failed to compose query"}}},async describeTable(E){const t=`DESCRIBE SELECT * FROM read_csv_auto('${E.replace(/'/g,"''")}') LIMIT 0`;try{return(await k("/api/query",{method:"POST",body:JSON.stringify({sql:t})})).rows.map(T=>({name:String(T.column_name??T.Field??""),type:String(T.column_type??T.Type??"")}))}catch{return[]}}},cr={varchar:"#388bfd",text:"#388bfd",string:"#388bfd",char:"#388bfd",integer:"#56d364",int:"#56d364",bigint:"#56d364",smallint:"#56d364",float:"#56d364",double:"#56d364",decimal:"#56d364",numeric:"#56d364",real:"#56d364",date:"#e3b341",timestamp:"#e3b341",datetime:"#e3b341",time:"#e3b341",boolean:"#f778ba",bool:"#f778ba",json:"#79c0ff",jsonb:"#79c0ff",uuid:"#d2a8ff",bytea:"#ffa657",binary:"#ffa657"};function YE(E,e){const t=E.toLowerCase().split("(")[0].trim();return cr[t]??e}function _r({t:E}){return n.jsxs("div",{style:{padding:"8px 12px",display:"flex",flexDirection:"column",gap:8},children:[[1,2,3].map(e=>n.jsx("div",{style:{height:28,borderRadius:4,background:E.pillBg,opacity:.6,animation:"pulse 1.5s ease-in-out infinite"}},e)),n.jsx("style",{children:"@keyframes pulse { 0%,100%{opacity:.6} 50%{opacity:.3} }"})]})}function dr(){const{state:E,dispatch:e}=y(),t=G[E.themeMode],[r,T]=l.useState(!1),s=async()=>{e({type:"SET_SCHEMA_LOADING",loading:!0});try{const R=await V.getSchema();e({type:"SET_SCHEMA",tables:R})}catch(R){console.error("Schema refresh failed:",R)}finally{e({type:"SET_SCHEMA_LOADING",loading:!1})}};return n.jsxs("div",{style:{flex:1,overflow:"auto",display:"flex",flexDirection:"column"},children:[n.jsxs("div",{style:{padding:"8px 10px",display:"flex",alignItems:"center",gap:6,borderBottom:`1px solid ${t.headerBorder}`},children:[n.jsxs("span",{style:{flex:1,fontSize:11,color:t.textMuted,fontFamily:t.font},children:[E.schemaTables.length," tables"]}),n.jsxs("button",{onClick:s,onMouseEnter:()=>T(!0),onMouseLeave:()=>T(!1),title:"Refresh schema",style:{background:r?t.btnHover:"transparent",border:`1px solid ${r?t.btnBorder:"transparent"}`,borderRadius:4,cursor:"pointer",color:r?t.textSecondary:t.textMuted,fontSize:11,fontFamily:t.font,padding:"2px 6px",display:"flex",alignItems:"center",gap:4,transition:"all 0.15s"},children:[n.jsx("svg",{width:"11",height:"11",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M1.705 8.005a.75.75 0 0 1 .834.656 5.5 5.5 0 0 0 9.592 2.97l-1.204-1.204a.25.25 0 0 1 .177-.427h3.646a.25.25 0 0 1 .25.25v3.646a.25.25 0 0 1-.427.177l-1.38-1.38A7.002 7.002 0 0 1 1.05 8.84a.75.75 0 0 1 .656-.834ZM8 2.5a5.487 5.487 0 0 0-4.131 1.869l1.204 1.204A.25.25 0 0 1 4.896 6H1.25A.25.25 0 0 1 1 5.75V2.104a.25.25 0 0 1 .427-.177l1.38 1.38A7.002 7.002 0 0 1 14.95 7.16a.75.75 0 0 1-1.49.178A5.5 5.5 0 0 0 8 2.5Z"})}),"Refresh"]})]}),E.schemaLoading?n.jsx(_r,{t}):E.schemaTables.length===0?n.jsxs("div",{style:{padding:"24px 14px",color:t.textMuted,fontSize:12,fontFamily:t.font,textAlign:"center",fontStyle:"italic"},children:["No tables found.",n.jsx("br",{}),"Connect a data source to explore schema."]}):n.jsx("div",{style:{overflow:"auto",flex:1},children:E.schemaTables.map(R=>n.jsx(Dr,{table:R,t},R.name))})]})}function Dr({table:E,t:e}){const{dispatch:t}=y(),[r,T]=l.useState(!1),[s,R]=l.useState(!1),A=async()=>{if(t({type:"TOGGLE_SCHEMA_TABLE",tableName:E.name}),!E.expanded&&E.columns.length===0){R(!0);try{const a=await V.describeTable(E.path);a.length>0&&t({type:"SET_TABLE_COLUMNS",tableName:E.name,columns:a})}catch(a){console.error("describeTable failed:",a)}finally{R(!1)}}};return n.jsxs("div",{children:[n.jsxs("button",{onMouseEnter:()=>T(!0),onMouseLeave:()=>T(!1),onClick:A,style:{width:"100%",display:"flex",alignItems:"center",gap:6,padding:"5px 10px",background:r?e.sidebarItemHover:"transparent",border:"none",cursor:"pointer",color:e.textPrimary,fontSize:12,fontFamily:e.font,fontWeight:500,textAlign:"left",transition:"background 0.1s"},children:[n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 10 10",fill:"currentColor",style:{transform:E.expanded?"rotate(90deg)":"rotate(0deg)",transition:"transform 0.15s",flexShrink:0,color:e.textMuted},children:n.jsx("path",{d:"M3 2l4 3-4 3V2Z"})}),n.jsx("svg",{width:"13",height:"13",viewBox:"0 0 16 16",fill:"currentColor",style:{color:e.accent,flexShrink:0},children:n.jsx("path",{d:"M0 1.75C0 .784.784 0 1.75 0h12.5C15.216 0 16 .784 16 1.75v1.5A1.75 1.75 0 0 1 14.25 5H1.75A1.75 1.75 0 0 1 0 3.25Zm1.75-.25a.25.25 0 0 0-.25.25v1.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-1.5a.25.25 0 0 0-.25-.25Zm-1.75 6C0 6.784.784 6 1.75 6h12.5c.966 0 1.75.784 1.75 1.75v1.5A1.75 1.75 0 0 1 14.25 11H1.75A1.75 1.75 0 0 1 0 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v1.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-1.5a.25.25 0 0 0-.25-.25Zm-1.75 6c0-.966.784-1.75 1.75-1.75h12.5c.966 0 1.75.784 1.75 1.75v1.5A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v1.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-1.5a.25.25 0 0 0-.25-.25Z"})}),n.jsx("span",{style:{flex:1,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:E.name}),E.columns.length>0&&n.jsx("span",{style:{fontSize:10,color:e.textMuted,background:e.pillBg,borderRadius:8,padding:"1px 5px",flexShrink:0},children:E.columns.length})]}),E.expanded&&n.jsx("div",{style:{paddingLeft:26},children:s?n.jsx("div",{style:{padding:"4px 10px",fontSize:11,color:e.textMuted,fontFamily:e.font,fontStyle:"italic"},children:"..."}):E.columns.length===0?n.jsx("div",{style:{padding:"4px 10px",fontSize:11,color:e.textMuted,fontFamily:e.font,fontStyle:"italic"},children:"No columns"}):E.columns.map(a=>n.jsx(ur,{col:a,t:e},a.name))})]})}function ur({col:E,t:e}){const[t,r]=l.useState(!1);return n.jsxs("div",{onMouseEnter:()=>r(!0),onMouseLeave:()=>r(!1),style:{display:"flex",alignItems:"center",gap:8,padding:"3px 10px 3px 8px",background:t?e.sidebarItemHover:"transparent",cursor:"default",transition:"background 0.1s"},children:[n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 16 16",fill:"currentColor",style:{color:e.textMuted,flexShrink:0},children:n.jsx("path",{d:"M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm7-3.25v2.992l2.028.812a.75.75 0 0 1-.557 1.392l-2.5-1A.751.751 0 0 1 7 8.25v-3.5a.75.75 0 0 1 1.5 0Z"})}),n.jsx("span",{style:{flex:1,fontSize:11,fontFamily:e.fontMono,color:e.textSecondary,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:E.name}),n.jsx("span",{style:{fontSize:10,fontFamily:e.fontMono,color:YE(E.type,e.accent),background:`${YE(E.type,e.accent)}18`,borderRadius:4,padding:"1px 5px",flexShrink:0},children:E.type.toLowerCase()})]})}function Pr(E){if(E.type==="markdown"){const e=E.content.match(/^#{1,6}\s+(.+)$/m);if(e)return e[1];const t=E.content.split(`
|
|
10
|
+
`).find(r=>r.trim());return(t==null?void 0:t.trim())||null}return E.name?E.name:null}function bt(E){if(E.type!=="markdown")return 0;const e=E.content.match(/^(#{1,6})\s/m);return e?e[1].length:0}function pr({cell:E,t:e}){if(E.type==="markdown")return n.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",style:{color:e.textMuted,flexShrink:0},children:[n.jsx("path",{d:"M14.85 3H7.39L6.74.translateX(.5.25C6.45.11 6.23 0 6 0H1.75A1.75 1.75 0 0 0 0 1.75v12.5C0 15.216.784 16 1.75 16h12.5A1.75 1.75 0 0 0 16 14.25V4.75A1.75 1.75 0 0 0 14.25 3ZM1.5 1.75a.25.25 0 0 1 .25-.25H6l.5 1.5H1.5Z"}),n.jsx("path",{d:"M2 2h12v12H2z",fill:"none",stroke:"currentColor",strokeWidth:"1.5"})]});const t=E.type==="sql"?e.accent:e.warning;return n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",style:{color:t,flexShrink:0},children:n.jsx("path",{d:"M0 5.75C0 4.784.784 4 1.75 4h12.5c.966 0 1.75.784 1.75 1.75v4.5A1.75 1.75 0 0 1 14.25 12H1.75A1.75 1.75 0 0 1 0 10.25Zm1.75-.25a.25.25 0 0 0-.25.25v4.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-4.5a.25.25 0 0 0-.25-.25Z"})})}function Mr({onNavigate:E}){const{state:e}=y(),t=G[e.themeMode];if(!e.activeFile)return n.jsx("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",padding:20,textAlign:"center"},children:n.jsxs("div",{children:[n.jsx("svg",{width:"32",height:"32",viewBox:"0 0 16 16",fill:"currentColor",style:{color:t.textMuted,marginBottom:8},children:n.jsx("path",{d:"M0 1.75C0 .784.784 0 1.75 0h12.5C15.216 0 16 .784 16 1.75v12.5A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25ZM1.75 1.5a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25ZM3.5 6.25a.75.75 0 0 1 .75-.75h7a.75.75 0 0 1 0 1.5h-7a.75.75 0 0 1-.75-.75Zm.75 2.25h4a.75.75 0 0 1 0 1.5h-4a.75.75 0 0 1 0-1.5Z"})}),n.jsx("div",{style:{fontSize:12,color:t.textMuted,fontFamily:t.font,lineHeight:1.5},children:"Open a notebook to see its outline."})]})});const r=e.cells.map(T=>({cell:T,label:Pr(T)})).filter(T=>T.label!==null);return r.length===0?n.jsxs("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",padding:20,color:t.textMuted,fontSize:12,fontFamily:t.font,fontStyle:"italic",textAlign:"center"},children:["No named cells or headings yet.",n.jsx("br",{}),"Name your cells or add markdown headings."]}):n.jsx("div",{style:{flex:1,overflow:"auto",padding:"6px 0"},children:r.map(({cell:T,label:s})=>{const R=bt(T),A=T.type==="markdown"?Math.max(0,(R-1)*12):0;return n.jsx(Ur,{cell:T,label:s,indent:A,onClick:()=>E(T.id),t},T.id)})})}function Ur({cell:E,label:e,indent:t,onClick:r,t:T}){const[s,R]=l.useState(!1);return n.jsxs("button",{onClick:r,onMouseEnter:()=>R(!0),onMouseLeave:()=>R(!1),style:{width:"100%",display:"flex",alignItems:"center",gap:6,padding:`4px 10px 4px ${14+t}px`,background:s?T.sidebarItemHover:"transparent",border:"none",cursor:"pointer",color:s?T.textPrimary:T.textSecondary,fontSize:12,fontFamily:E.type==="markdown"?T.font:T.fontMono,textAlign:"left",transition:"background 0.1s, color 0.1s",overflow:"hidden"},children:[n.jsx(pr,{cell:E,t:T}),n.jsx("span",{style:{overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",flex:1,fontWeight:E.type==="markdown"&&bt(E)===1?600:400},children:e})]})}const hr={duckdb:"DuckDB",file:"Local File / DuckDB",postgres:"PostgreSQL",bigquery:"BigQuery",snowflake:"Snowflake",sqlite:"SQLite",mysql:"MySQL",mssql:"SQL Server",redshift:"Amazon Redshift",databricks:"Databricks",clickhouse:"ClickHouse",athena:"Amazon Athena",trino:"Trino",fabric:"Microsoft Fabric"},fr={duckdb:"#f4bc00",file:"#f4bc00",postgres:"#336791",bigquery:"#4285f4",snowflake:"#29b5e8",sqlite:"#003b57",mysql:"#00758f",mssql:"#cc2927",redshift:"#8c4fff",databricks:"#ff3621",clickhouse:"#ffcc00",athena:"#ff9900",trino:"#dd00a1",fabric:"#0078d4"};function mr(){const{state:E}=y(),e=G[E.themeMode],[t,r]=l.useState(null),[T,s]=l.useState(!1),[R,A]=l.useState(null);l.useEffect(()=>{V.getConnections().then(r)},[]);const a=async()=>{s(!0),A(null);const O=await V.testConnection();A(O),s(!1)},o={fontSize:10,fontWeight:600,letterSpacing:"0.07em",textTransform:"uppercase",color:e.textMuted,fontFamily:e.font,marginBottom:6},S={background:e.cellBg,border:`1px solid ${e.cellBorder}`,borderRadius:7,padding:"10px 12px",marginBottom:10},i=(t==null?void 0:t.connections)??{},I=(t==null?void 0:t.default)??"";return n.jsxs("div",{style:{flex:1,overflow:"auto",padding:"12px 12px 20px"},children:[n.jsx("div",{style:o,children:"Active Connection"}),t===null?n.jsx("div",{style:{fontSize:12,color:e.textMuted,fontFamily:e.font},children:"Loading…"}):Object.entries(i).map(([O,c])=>{const _=(c==null?void 0:c.driver)??(c==null?void 0:c.type)??"unknown",d=O===I||Object.keys(i).length===1,u=fr[_]??e.accent;return n.jsxs("div",{style:{...S,borderLeft:d?`3px solid ${u}`:`1px solid ${e.cellBorder}`},children:[n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8,marginBottom:6},children:[n.jsx("span",{style:{fontSize:10,fontWeight:700,fontFamily:e.fontMono,color:u,background:`${u}18`,border:`1px solid ${u}40`,borderRadius:4,padding:"1px 6px",letterSpacing:"0.05em",textTransform:"uppercase"},children:hr[_]??_}),d&&n.jsx("span",{style:{fontSize:10,color:e.textMuted,fontFamily:e.font},children:"default"})]}),n.jsx("div",{style:{display:"flex",flexDirection:"column",gap:3},children:Object.entries(c??{}).filter(([D])=>D!=="driver"&&D!=="type").map(([D,f])=>n.jsxs("div",{style:{display:"flex",gap:6,alignItems:"baseline"},children:[n.jsx("span",{style:{fontSize:11,color:e.textMuted,fontFamily:e.fontMono,minWidth:70,flexShrink:0},children:D}),n.jsx("span",{style:{fontSize:11,color:e.textSecondary,fontFamily:e.fontMono,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:D.toLowerCase().includes("password")?"••••••••":String(f)})]},D))})]},O)}),n.jsx("button",{onClick:a,disabled:T,style:{width:"100%",padding:"7px 0",borderRadius:6,border:`1px solid ${e.btnBorder}`,background:e.btnBg,color:e.textSecondary,fontSize:12,fontFamily:e.font,fontWeight:500,cursor:T?"not-allowed":"pointer",marginBottom:8,opacity:T?.7:1,transition:"all 0.15s"},children:T?"Testing…":"Test Connection"}),R&&n.jsxs("div",{style:{fontSize:12,fontFamily:e.font,color:R.ok?e.success:e.error,background:R.ok?`${e.success}12`:`${e.error}12`,border:`1px solid ${R.ok?e.success:e.error}40`,borderRadius:6,padding:"7px 10px",marginBottom:12},children:[R.ok?"✓ ":"✗ ",R.message]}),n.jsx("div",{style:{...o,marginTop:4},children:"Change Connection"}),n.jsxs("div",{style:{...S,fontSize:12,fontFamily:e.font,color:e.textSecondary,lineHeight:1.6},children:["Edit ",n.jsx("code",{style:{fontFamily:e.fontMono,color:e.accent,fontSize:11},children:"dql.config.json"})," in your project root to add or switch connections. Supported drivers:",n.jsx("div",{style:{display:"flex",flexDirection:"column",gap:4,marginTop:8},children:[{driver:"duckdb / file",desc:"Local CSV, Parquet, DuckDB"},{driver:"postgres",desc:"PostgreSQL / Supabase / RDS"},{driver:"bigquery",desc:"Google BigQuery"},{driver:"snowflake",desc:"Snowflake"},{driver:"mysql",desc:"MySQL / MariaDB / PlanetScale"},{driver:"mssql",desc:"SQL Server / Azure SQL"},{driver:"redshift",desc:"Amazon Redshift"},{driver:"databricks",desc:"Databricks SQL"},{driver:"clickhouse",desc:"ClickHouse"},{driver:"athena",desc:"Amazon Athena"},{driver:"trino",desc:"Trino / Starburst"},{driver:"fabric",desc:"Microsoft Fabric"}].map(({driver:O,desc:c})=>n.jsxs("div",{style:{display:"flex",gap:8,alignItems:"baseline"},children:[n.jsx("code",{style:{fontSize:10,fontFamily:e.fontMono,color:e.textMuted,minWidth:80,flexShrink:0},children:O}),n.jsx("span",{style:{fontSize:11,color:e.textMuted},children:c})]},O))})]}),n.jsx("div",{style:{...o,marginTop:4},children:"Example Config"}),n.jsx("pre",{style:{background:e.cellBg,border:`1px solid ${e.cellBorder}`,borderRadius:7,padding:"10px 12px",fontSize:11,fontFamily:e.fontMono,color:e.textSecondary,overflow:"auto",lineHeight:1.6,margin:0},children:`{
|
|
11
|
+
"connections": {
|
|
12
|
+
"default": {
|
|
13
|
+
"driver": "duckdb",
|
|
14
|
+
"path": ":memory:"
|
|
15
|
+
},
|
|
16
|
+
"prod": {
|
|
17
|
+
"driver": "postgres",
|
|
18
|
+
"host": "localhost",
|
|
19
|
+
"port": 5432,
|
|
20
|
+
"database": "analytics",
|
|
21
|
+
"user": "analyst",
|
|
22
|
+
"password": "..."
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}`})]})}function q({title:E,defaultOpen:e=!1,children:t,t:r}){const[T,s]=l.useState(e),[R,A]=l.useState(!1);return n.jsxs("div",{style:{borderBottom:`1px solid ${r.headerBorder}`},children:[n.jsxs("button",{onClick:()=>s(a=>!a),onMouseEnter:()=>A(!0),onMouseLeave:()=>A(!1),style:{width:"100%",padding:"7px 12px",display:"flex",alignItems:"center",gap:6,background:R?r.sidebarItemHover:"transparent",border:"none",cursor:"pointer",textAlign:"left",transition:"background 0.1s"},children:[n.jsx("span",{style:{fontSize:9,color:r.textMuted,display:"inline-block",transition:"transform 0.15s",transform:T?"rotate(90deg)":"rotate(0deg)",lineHeight:1},children:"▶"}),n.jsx("span",{style:{fontSize:11,fontWeight:600,fontFamily:r.font,color:r.textSecondary,letterSpacing:"0.04em"},children:E})]}),T&&n.jsx("div",{style:{padding:"4px 12px 10px"},children:t})]})}function xr({code:E,t:e}){const[t,r]=l.useState(!1);async function T(){try{await navigator.clipboard.writeText(E)}catch{const s=document.createElement("textarea");s.value=E,document.body.appendChild(s),s.select(),document.execCommand("copy"),document.body.removeChild(s)}r(!0),setTimeout(()=>r(!1),1500)}return n.jsx("button",{onClick:T,title:"Copy to clipboard",style:{position:"absolute",top:6,right:6,padding:"2px 6px",fontSize:10,fontFamily:e.font,background:t?`${e.success}20`:e.btnBg,border:`1px solid ${t?e.success+"50":e.btnBorder}`,borderRadius:4,cursor:"pointer",color:t?e.success:e.textMuted,transition:"all 0.15s"},children:t?"✓":"Copy"})}function v({code:E,t:e}){return n.jsxs("div",{style:{position:"relative",marginTop:6},children:[n.jsx("pre",{style:{margin:0,padding:"8px 10px",paddingRight:52,background:e.editorBg,border:`1px solid ${e.cellBorder}`,borderRadius:6,fontFamily:e.fontMono,fontSize:11,color:e.textPrimary,lineHeight:1.6,whiteSpace:"pre",overflowX:"auto"},children:E}),n.jsx(xr,{code:E,t:e})]})}function vE({rows:E,t:e}){return n.jsx("table",{style:{width:"100%",borderCollapse:"collapse",fontSize:11,fontFamily:e.font,marginTop:6},children:n.jsx("tbody",{children:E.map(([t,r],T)=>n.jsxs("tr",{style:{borderBottom:`1px solid ${e.tableBorder}`},children:[n.jsx("td",{style:{padding:"5px 6px 5px 0",fontFamily:e.fontMono,fontSize:11,color:e.accent,whiteSpace:"nowrap",verticalAlign:"top",width:"45%"},children:t}),n.jsx("td",{style:{padding:"5px 0",color:e.textSecondary,verticalAlign:"top",lineHeight:1.5},children:r})]},T))})})}const Gr=`block "Revenue by Channel" {
|
|
26
|
+
domain = "revenue"
|
|
27
|
+
type = "custom"
|
|
28
|
+
description = "Revenue grouped by sales channel"
|
|
29
|
+
owner = "data-team"
|
|
30
|
+
tags = ["revenue"]
|
|
31
|
+
|
|
32
|
+
params {
|
|
33
|
+
period = "current_quarter"
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
query = """
|
|
37
|
+
SELECT channel,
|
|
38
|
+
SUM(order_total) AS revenue
|
|
39
|
+
FROM read_csv_auto('data/orders.csv')
|
|
40
|
+
WHERE fiscal_period = \${period}
|
|
41
|
+
GROUP BY channel
|
|
42
|
+
ORDER BY revenue DESC
|
|
43
|
+
"""
|
|
44
|
+
|
|
45
|
+
visualization {
|
|
46
|
+
chart = "bar"
|
|
47
|
+
x = channel
|
|
48
|
+
y = revenue
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
tests {
|
|
52
|
+
assert row_count > 0
|
|
53
|
+
}
|
|
54
|
+
}`,yr=`# semantic-layer/metrics/total_revenue.yaml
|
|
55
|
+
name: total_revenue
|
|
56
|
+
label: Total Revenue
|
|
57
|
+
description: Sum of all recognized revenue.
|
|
58
|
+
domain: finance
|
|
59
|
+
sql: SUM(amount)
|
|
60
|
+
type: sum # sum|count|count_distinct|avg|min|max|custom
|
|
61
|
+
table: fct_revenue
|
|
62
|
+
tags:
|
|
63
|
+
- revenue
|
|
64
|
+
- kpi`,Br=`# semantic-layer/dimensions/segment.yaml
|
|
65
|
+
name: segment
|
|
66
|
+
label: Customer Segment
|
|
67
|
+
description: Customer segment tier.
|
|
68
|
+
sql: segment_tier
|
|
69
|
+
type: string # string|number|date|boolean
|
|
70
|
+
table: fct_revenue`,gr=`# semantic-layer/hierarchies/time.yaml
|
|
71
|
+
name: fiscal_time
|
|
72
|
+
label: Fiscal Time
|
|
73
|
+
description: Drill from year to quarter.
|
|
74
|
+
domain: finance
|
|
75
|
+
levels:
|
|
76
|
+
- name: fiscal_year
|
|
77
|
+
dimension: fiscal_year
|
|
78
|
+
order: 1
|
|
79
|
+
- name: fiscal_quarter
|
|
80
|
+
dimension: fiscal_quarter
|
|
81
|
+
order: 2
|
|
82
|
+
defaultRollup: sum`,Hr=`# semantic-layer/cubes/revenue_cube.yaml
|
|
83
|
+
name: revenue
|
|
84
|
+
label: Revenue Cube
|
|
85
|
+
table: fct_revenue
|
|
86
|
+
domain: finance
|
|
87
|
+
|
|
88
|
+
measures:
|
|
89
|
+
- name: total_revenue
|
|
90
|
+
sql: SUM(amount)
|
|
91
|
+
type: sum
|
|
92
|
+
- name: deal_count
|
|
93
|
+
sql: COUNT(*)
|
|
94
|
+
type: count
|
|
95
|
+
|
|
96
|
+
dimensions:
|
|
97
|
+
- name: segment_tier
|
|
98
|
+
sql: segment_tier
|
|
99
|
+
type: string
|
|
100
|
+
|
|
101
|
+
time_dimensions:
|
|
102
|
+
- name: recognized_at
|
|
103
|
+
sql: recognized_at
|
|
104
|
+
primary_time: true
|
|
105
|
+
granularities: [day, month, quarter, year]
|
|
106
|
+
|
|
107
|
+
joins:
|
|
108
|
+
- name: customers
|
|
109
|
+
type: left
|
|
110
|
+
sql: "\${left}.customer_id = \${right}.id"`,Fr=`{
|
|
111
|
+
"semanticLayer": {
|
|
112
|
+
"provider": "dql"
|
|
113
|
+
}
|
|
114
|
+
}`,br=`{
|
|
115
|
+
"semanticLayer": {
|
|
116
|
+
"provider": "dbt",
|
|
117
|
+
"projectPath": "/path/to/your/dbt-project"
|
|
118
|
+
}
|
|
119
|
+
}`,Yr=`{
|
|
120
|
+
"semanticLayer": {
|
|
121
|
+
"provider": "cubejs",
|
|
122
|
+
"projectPath": "/path/to/your/cube-project"
|
|
123
|
+
}
|
|
124
|
+
}`,vr=`{
|
|
125
|
+
"defaultConnection": {
|
|
126
|
+
"driver": "file",
|
|
127
|
+
"filepath": ":memory:"
|
|
128
|
+
}
|
|
129
|
+
}`,Vr=`{
|
|
130
|
+
"defaultConnection": {
|
|
131
|
+
"driver": "snowflake",
|
|
132
|
+
"account": "acme.snowflakecomputing.com",
|
|
133
|
+
"username": "your_user",
|
|
134
|
+
"password": "\${SNOWFLAKE_PASSWORD}",
|
|
135
|
+
"database": "ANALYTICS",
|
|
136
|
+
"schema": "PUBLIC",
|
|
137
|
+
"warehouse": "COMPUTE_WH",
|
|
138
|
+
"role": "ANALYST"
|
|
139
|
+
}
|
|
140
|
+
}`,Wr=`{
|
|
141
|
+
"defaultConnection": {
|
|
142
|
+
"driver": "bigquery",
|
|
143
|
+
"project": "your-gcp-project-id",
|
|
144
|
+
"dataset": "analytics",
|
|
145
|
+
"keyFilename": "./service-account.json"
|
|
146
|
+
}
|
|
147
|
+
}`,Xr=`{
|
|
148
|
+
"defaultConnection": {
|
|
149
|
+
"driver": "postgres",
|
|
150
|
+
"host": "localhost",
|
|
151
|
+
"port": 5432,
|
|
152
|
+
"database": "analytics",
|
|
153
|
+
"username": "your_user",
|
|
154
|
+
"password": "\${POSTGRES_PASSWORD}"
|
|
155
|
+
}
|
|
156
|
+
}`,wr=`-- Simple import (uses block's default params)
|
|
157
|
+
@import "./blocks/revenue_by_channel.dql"
|
|
158
|
+
|
|
159
|
+
-- Import with custom params (override block defaults)
|
|
160
|
+
@import "./blocks/revenue_by_channel.dql" with period = "Q4_2024"
|
|
161
|
+
|
|
162
|
+
-- Import with multiple params
|
|
163
|
+
@import "./blocks/pipeline_health.dql" with
|
|
164
|
+
stage = "Closed Won",
|
|
165
|
+
region = "EMEA"`;function Kr({themeMode:E}){const e=G[E];return n.jsxs("div",{style:{flex:1,overflowY:"auto",fontFamily:e.font},children:[n.jsx(q,{title:"SQL Essentials",defaultOpen:!0,t:e,children:n.jsx(v,{t:e,code:`-- Basic select
|
|
166
|
+
SELECT col1, col2
|
|
167
|
+
FROM table_name
|
|
168
|
+
WHERE condition
|
|
169
|
+
ORDER BY col1 DESC
|
|
170
|
+
LIMIT 100
|
|
171
|
+
|
|
172
|
+
-- GROUP BY
|
|
173
|
+
SELECT col, COUNT(*), SUM(val)
|
|
174
|
+
FROM table_name
|
|
175
|
+
GROUP BY col
|
|
176
|
+
|
|
177
|
+
-- JOIN
|
|
178
|
+
SELECT a.*, b.col
|
|
179
|
+
FROM table_a AS a
|
|
180
|
+
JOIN table_b AS b ON a.id = b.id
|
|
181
|
+
|
|
182
|
+
-- CTE (WITH)
|
|
183
|
+
WITH cte AS (
|
|
184
|
+
SELECT * FROM table_name WHERE val > 0
|
|
185
|
+
)
|
|
186
|
+
SELECT * FROM cte
|
|
187
|
+
|
|
188
|
+
-- Window function
|
|
189
|
+
SELECT *,
|
|
190
|
+
ROW_NUMBER() OVER (
|
|
191
|
+
PARTITION BY group_col
|
|
192
|
+
ORDER BY val DESC
|
|
193
|
+
) AS rank
|
|
194
|
+
FROM table_name`})}),n.jsx(q,{title:"DuckDB Functions",defaultOpen:!1,t:e,children:n.jsx(vE,{t:e,rows:[["read_csv_auto(path)","Auto-detect CSV schema and load"],["read_parquet(path)","Load a Parquet file"],["strftime(date, fmt)","Format date as string (e.g. '%Y-%m')"],["date_trunc(part, date)","Truncate date to part ('month', 'year'…)"],["CURRENT_DATE","Today's date"],["epoch_ms(ts)","Convert epoch milliseconds to timestamp"],["array_agg(col)","Aggregate column values into an array"],["string_agg(col, sep)","Concatenate values with separator"]]})}),n.jsx(q,{title:"DQL Block Structure",defaultOpen:!0,t:e,children:n.jsx(v,{t:e,code:Gr})}),n.jsxs(q,{title:"DQL Chart Types",defaultOpen:!1,t:e,children:[n.jsx(vE,{t:e,rows:[["table","Tabular data grid (default)"],["bar","Bar chart — use x and y fields"],["line","Line chart — use x (date) and y (value)"],["pie","Pie/donut chart — use x (label) and y (value)"],["kpi","Single big-number KPI card (dql preview)"]]}),n.jsxs("div",{style:{marginTop:8,fontSize:11,color:e.textMuted,fontFamily:e.font,lineHeight:1.6},children:["Set chart type inside the"," ",n.jsx("code",{style:{fontFamily:e.fontMono,color:e.accent,fontSize:11},children:'visualization { chart = "pie"; x = label_col; y = value_col }'})," ","block."]})]}),n.jsxs(q,{title:"Block Imports (@import)",defaultOpen:!1,t:e,children:[n.jsxs("div",{style:{fontSize:12,color:e.textSecondary,lineHeight:1.7,fontFamily:e.font,marginBottom:6},children:["Reference a ",n.jsx("code",{style:{fontFamily:e.fontMono,color:e.accent,fontSize:11},children:".dql"})," block file instead of copying its SQL. Run the cell to execute the block's query."]}),n.jsx(v,{t:e,code:wr}),n.jsxs("div",{style:{marginTop:8,fontSize:11,color:e.textMuted,fontFamily:e.font,lineHeight:1.6},children:["Parameters override the block's ",n.jsx("code",{style:{fontFamily:e.fontMono,color:e.accent,fontSize:11},children:"params { }"})," defaults. The block's ",n.jsx("code",{style:{fontFamily:e.fontMono,color:e.accent,fontSize:11},children:"visualization"})," config is applied automatically."]})]}),n.jsxs(q,{title:"Semantic Layer",defaultOpen:!1,t:e,children:[n.jsxs("div",{style:{fontSize:12,color:e.textSecondary,lineHeight:1.7,fontFamily:e.font,marginBottom:8},children:["Define reusable metrics, dimensions, and hierarchies in YAML. They appear in the"," ",n.jsx("strong",{style:{color:e.textPrimary},children:"Semantic Layer"})," sidebar panel."]}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"10px 0 4px",letterSpacing:"0.03em"},children:"Directory Structure"}),n.jsx(v,{t:e,code:`my-project/
|
|
195
|
+
├── dql.config.json
|
|
196
|
+
└── semantic-layer/
|
|
197
|
+
├── metrics/ ← one YAML per metric
|
|
198
|
+
├── dimensions/ ← one YAML per dimension
|
|
199
|
+
├── hierarchies/ ← optional drill paths
|
|
200
|
+
└── cubes/ ← optional (groups all into one)`}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"12px 0 4px",letterSpacing:"0.03em"},children:"Metric YAML"}),n.jsx(v,{t:e,code:yr}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"12px 0 4px",letterSpacing:"0.03em"},children:"Dimension YAML"}),n.jsx(v,{t:e,code:Br}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"12px 0 4px",letterSpacing:"0.03em"},children:"Hierarchy YAML"}),n.jsx(v,{t:e,code:gr}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"12px 0 4px",letterSpacing:"0.03em"},children:"Cube YAML (advanced — multi-table with joins)"}),n.jsx(v,{t:e,code:Hr})]}),n.jsxs(q,{title:"Semantic Layer Providers",defaultOpen:!1,t:e,children:[n.jsxs("div",{style:{fontSize:12,color:e.textSecondary,lineHeight:1.7,fontFamily:e.font,marginBottom:8},children:["Add to your ",n.jsx("code",{style:{fontFamily:e.fontMono,color:e.accent,fontSize:11},children:"dql.config.json"})," to connect a semantic layer provider."]}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"10px 0 4px",letterSpacing:"0.03em"},children:"DQL Native (YAML files in semantic-layer/)"}),n.jsx(v,{t:e,code:Fr}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"12px 0 4px",letterSpacing:"0.03em"},children:"dbt (reads models/**/*.yml)"}),n.jsx(v,{t:e,code:br}),n.jsxs("div",{style:{marginTop:4,fontSize:11,color:e.textMuted,fontFamily:e.font,lineHeight:1.5},children:["Point to your dbt project root (directory with ",n.jsx("code",{style:{fontFamily:e.fontMono,fontSize:10},children:"dbt_project.yml"}),"). Reads ",n.jsx("code",{style:{fontFamily:e.fontMono,fontSize:10},children:"semantic_models"})," and"," ",n.jsx("code",{style:{fontFamily:e.fontMono,fontSize:10},children:"metrics"})," blocks (dbt 1.6+)."]}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"12px 0 4px",letterSpacing:"0.03em"},children:"Cube.js (reads model/ or schema/)"}),n.jsx(v,{t:e,code:Yr}),n.jsxs("div",{style:{marginTop:4,fontSize:11,color:e.textMuted,fontFamily:e.font,lineHeight:1.5},children:["Point to your Cube.js project root. Reads"," ",n.jsx("code",{style:{fontFamily:e.fontMono,fontSize:10},children:"cubes:"})," blocks from YAML schema files."]})]}),n.jsxs(q,{title:"Connection Setup",defaultOpen:!1,t:e,children:[n.jsxs("div",{style:{fontSize:12,color:e.textSecondary,lineHeight:1.7,fontFamily:e.font,marginBottom:8},children:["Configure ",n.jsx("code",{style:{fontFamily:e.fontMono,color:e.accent,fontSize:11},children:"defaultConnection"})," in"," ",n.jsx("code",{style:{fontFamily:e.fontMono,color:e.accent,fontSize:11},children:"dql.config.json"}),"."]}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"10px 0 4px",letterSpacing:"0.03em"},children:"DuckDB (in-memory — default)"}),n.jsx(v,{t:e,code:vr}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"12px 0 4px",letterSpacing:"0.03em"},children:"Snowflake"}),n.jsx(v,{t:e,code:Vr}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"12px 0 4px",letterSpacing:"0.03em"},children:"BigQuery"}),n.jsx(v,{t:e,code:Wr}),n.jsx("div",{style:{fontSize:11,fontWeight:600,color:e.textSecondary,fontFamily:e.font,margin:"12px 0 4px",letterSpacing:"0.03em"},children:"PostgreSQL"}),n.jsx(v,{t:e,code:Xr}),n.jsxs("div",{style:{marginTop:8,fontSize:11,color:e.textMuted,fontFamily:e.font,lineHeight:1.5},children:["Use ",n.jsxs("code",{style:{fontFamily:e.fontMono,fontSize:10},children:["$","${ENV_VAR}"]})," syntax for secrets. Run ",n.jsx("code",{style:{fontFamily:e.fontMono,fontSize:10},children:"dql doctor"})," to verify your connection."]})]}),n.jsxs(q,{title:"Variable References",defaultOpen:!1,t:e,children:[n.jsxs("div",{style:{fontSize:12,color:e.textSecondary,lineHeight:1.7,fontFamily:e.font,marginBottom:8},children:["Use"," ",n.jsx("code",{style:{fontFamily:e.fontMono,color:e.accent,fontSize:11},children:"{{cell_name}}"})," ","to reference other cells:",n.jsxs("ul",{style:{margin:"6px 0 0",paddingLeft:18},children:[n.jsxs("li",{children:[n.jsx("strong",{children:"Param cell"})," → substituted as a SQL literal value"]}),n.jsxs("li",{children:[n.jsx("strong",{children:"SQL cell"})," → injected as a CTE"]})]})]}),n.jsx(v,{t:e,code:`-- Param cell named "start_date" holds '2024-01-01'
|
|
201
|
+
SELECT *
|
|
202
|
+
FROM read_csv_auto('data/sales.csv')
|
|
203
|
+
WHERE date >= {{start_date}}
|
|
204
|
+
|
|
205
|
+
-- SQL cell named "base_query" used as CTE
|
|
206
|
+
SELECT segment, SUM(revenue) AS total
|
|
207
|
+
FROM {{base_query}}
|
|
208
|
+
GROUP BY segment`})]})]})}const Yt={sum:"#56d364",count:"#388bfd",count_distinct:"#388bfd",avg:"#e3b341",min:"#f778ba",max:"#f778ba",custom:"#d2a8ff"};function $r(){return n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M8 1a7 7 0 1 0 0 14A7 7 0 0 0 8 1Zm0 1.5a5.5 5.5 0 1 1 0 11 5.5 5.5 0 0 1 0-11Zm0 2a.75.75 0 0 1 .75.75v2h2a.75.75 0 0 1 0 1.5h-2v2a.75.75 0 0 1-1.5 0v-2h-2a.75.75 0 0 1 0-1.5h2v-2A.75.75 0 0 1 8 4.5Z"})})}function kr(){return n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M1 2.75C1 1.784 1.784 1 2.75 1h10.5c.966 0 1.75.784 1.75 1.75v10.5A1.75 1.75 0 0 1 13.25 15H2.75A1.75 1.75 0 0 1 1 13.25Zm1.75-.25a.25.25 0 0 0-.25.25v10.5c0 .138.112.25.25.25h10.5a.25.25 0 0 0 .25-.25V2.75a.25.25 0 0 0-.25-.25ZM8 4a.75.75 0 0 1 .75.75v6.5a.75.75 0 0 1-1.5 0v-6.5A.75.75 0 0 1 8 4Zm-3 3a.75.75 0 0 1 .75.75v3.5a.75.75 0 0 1-1.5 0v-3.5A.75.75 0 0 1 5 7Zm6-1a.75.75 0 0 1 .75.75v4.5a.75.75 0 0 1-1.5 0v-4.5A.75.75 0 0 1 11 6Z"})})}function jr(){return n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M8 1a1 1 0 0 1 1 1v2.586l2.293-2.293a1 1 0 0 1 1.414 1.414L10.414 6H13a1 1 0 1 1 0 2h-2.586l2.293 2.293a1 1 0 0 1-1.414 1.414L9 9.414V12a1 1 0 1 1-2 0V9.414l-2.293 2.293a1 1 0 0 1-1.414-1.414L5.586 8H3a1 1 0 0 1 0-2h2.586L3.293 3.707a1 1 0 0 1 1.414-1.414L7 4.586V2a1 1 0 0 1 1-1Z"})})}function we({label:E,count:e,expanded:t,onToggle:r,t:T}){const[s,R]=l.useState(!1);return n.jsxs("button",{onClick:r,onMouseEnter:()=>R(!0),onMouseLeave:()=>R(!1),style:{width:"100%",display:"flex",alignItems:"center",gap:6,padding:"3px 8px 3px 10px",background:s?T.sidebarItemHover:"transparent",border:"none",cursor:"pointer",color:T.textSecondary,fontSize:11,fontWeight:600,fontFamily:T.font,letterSpacing:"0.04em",textTransform:"uppercase",textAlign:"left",transition:"background 0.1s"},children:[n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 10 10",fill:"currentColor",style:{transform:t?"rotate(90deg)":"rotate(0deg)",transition:"transform 0.15s",flexShrink:0},children:n.jsx("path",{d:"M3 2l4 3-4 3V2Z"})}),n.jsx("span",{style:{flex:1},children:E}),e>0&&n.jsx("span",{style:{background:T.pillBg,color:T.textMuted,borderRadius:10,padding:"0 5px",fontSize:10,fontWeight:500},children:e})]})}function Jr({metric:E,t:e}){const[t,r]=l.useState(!1),[T,s]=l.useState(!1),R=Yt[E.type]??e.accent;return n.jsxs("div",{children:[n.jsxs("button",{onClick:()=>s(!T),onMouseEnter:()=>r(!0),onMouseLeave:()=>r(!1),style:{width:"100%",display:"flex",alignItems:"center",gap:6,padding:"4px 8px 4px 22px",background:t?e.sidebarItemHover:"transparent",border:"none",cursor:"pointer",color:e.textPrimary,fontSize:12,fontFamily:e.font,textAlign:"left",transition:"background 0.1s"},children:[n.jsx("span",{style:{color:R,flexShrink:0},children:n.jsx($r,{})}),n.jsx("span",{style:{flex:1,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:E.label||E.name}),n.jsx("span",{style:{fontSize:9,fontFamily:e.fontMono,color:R,background:`${R}18`,borderRadius:4,padding:"1px 4px",flexShrink:0},children:E.type})]}),T&&n.jsxs("div",{style:{padding:"2px 8px 6px 40px",fontSize:11,color:e.textMuted,fontFamily:e.font,lineHeight:1.5},children:[E.description&&n.jsx("div",{children:E.description}),n.jsxs("div",{style:{fontFamily:e.fontMono,fontSize:10,color:e.textSecondary,marginTop:2},children:["table: ",E.table]}),E.domain&&n.jsxs("div",{style:{fontFamily:e.fontMono,fontSize:10,color:e.textSecondary},children:["domain: ",E.domain]}),E.tags.length>0&&n.jsx("div",{style:{display:"flex",gap:3,flexWrap:"wrap",marginTop:3},children:E.tags.map(A=>n.jsx("span",{style:{fontSize:9,background:e.pillBg,color:e.textMuted,borderRadius:3,padding:"1px 4px"},children:A},A))})]})]})}function Qr({dimension:E,t:e}){const[t,r]=l.useState(!1),T=E.type==="date"?"#e3b341":E.type==="number"?"#56d364":"#388bfd";return n.jsxs("div",{onMouseEnter:()=>r(!0),onMouseLeave:()=>r(!1),style:{display:"flex",alignItems:"center",gap:6,padding:"4px 8px 4px 22px",background:t?e.sidebarItemHover:"transparent",cursor:"default",transition:"background 0.1s"},children:[n.jsx("span",{style:{color:e.textMuted,flexShrink:0},children:n.jsx(kr,{})}),n.jsx("span",{style:{flex:1,fontSize:12,fontFamily:e.font,color:e.textSecondary,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},title:E.description,children:E.label||E.name}),n.jsx("span",{style:{fontSize:9,fontFamily:e.fontMono,color:T,background:`${T}18`,borderRadius:4,padding:"1px 4px",flexShrink:0},children:E.type})]})}function Zr({hierarchy:E,t:e}){const[t,r]=l.useState(!1),[T,s]=l.useState(!1);return n.jsxs("div",{children:[n.jsxs("button",{onClick:()=>s(!T),onMouseEnter:()=>r(!0),onMouseLeave:()=>r(!1),style:{width:"100%",display:"flex",alignItems:"center",gap:6,padding:"4px 8px 4px 22px",background:t?e.sidebarItemHover:"transparent",border:"none",cursor:"pointer",color:e.textSecondary,fontSize:12,fontFamily:e.font,textAlign:"left",transition:"background 0.1s"},children:[n.jsx("span",{style:{color:"#d2a8ff",flexShrink:0},children:n.jsx(jr,{})}),n.jsx("span",{style:{flex:1,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:E.label||E.name}),n.jsx("span",{style:{fontSize:10,color:e.textMuted,background:e.pillBg,borderRadius:8,padding:"1px 5px",flexShrink:0},children:E.levels.length})]}),T&&n.jsx("div",{style:{paddingLeft:40},children:E.levels.map((R,A)=>n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:4,padding:"2px 0",fontSize:11,fontFamily:e.fontMono,color:e.textMuted},children:[n.jsxs("span",{style:{color:e.textMuted,fontSize:9},children:[A+1,"."]}),R.label||R.name]},R.name))})]})}function qr({t:E,metrics:e,dimensions:t}){const[r,T]=l.useState(!1),[s,R]=l.useState(new Set),[A,a]=l.useState(new Set),[o,S]=l.useState(null),[i,I]=l.useState(null),[O,c]=l.useState(!1),[_,d]=l.useState(!1),u=h=>{R(Y=>{const b=new Set(Y);return b.has(h)?b.delete(h):b.add(h),b}),S(null)},D=h=>{a(Y=>{const b=new Set(Y);return b.has(h)?b.delete(h):b.add(h),b}),S(null)},f=async()=>{if(s.size!==0){c(!0),I(null);try{const h=await V.composeQuery(Array.from(s),Array.from(A));"error"in h?I(h.error):S(h.sql)}catch(h){I(h.message??"Failed to compose")}finally{c(!1)}}},p=()=>{o&&(navigator.clipboard.writeText(o),d(!0),setTimeout(()=>d(!1),1500))},m=h=>({width:14,height:14,borderRadius:3,border:`1.5px solid ${h?E.accent:E.cellBorder}`,background:h?E.accent:"transparent",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0,transition:"all 0.15s"});return n.jsxs("div",{style:{borderBottom:`1px solid ${E.headerBorder}`},children:[n.jsxs("button",{onClick:()=>T(!r),style:{width:"100%",display:"flex",alignItems:"center",gap:6,padding:"6px 10px",background:r?`${E.accent}10`:"transparent",border:"none",cursor:"pointer",color:E.accent,fontSize:11,fontWeight:600,fontFamily:E.font,textAlign:"left"},children:[n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M8 1.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm6.5-2a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0Zm-2 4.5a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0Zm5 0a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0Z"})}),"Compose Query",n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 10 10",fill:"currentColor",style:{marginLeft:"auto",transform:r?"rotate(90deg)":"rotate(0deg)",transition:"transform 0.15s"},children:n.jsx("path",{d:"M3 2l4 3-4 3V2Z"})})]}),r&&n.jsxs("div",{style:{padding:"6px 10px 10px",fontSize:11,fontFamily:E.font},children:[n.jsx("div",{style:{fontSize:10,fontWeight:600,color:E.textSecondary,marginBottom:4,textTransform:"uppercase",letterSpacing:"0.04em"},children:"Select Metrics"}),n.jsx("div",{style:{maxHeight:120,overflowY:"auto",marginBottom:8},children:e.map(h=>n.jsxs("label",{style:{display:"flex",alignItems:"center",gap:6,padding:"2px 0",cursor:"pointer",color:E.textPrimary,fontSize:11},onClick:()=>u(h.name),children:[n.jsx("div",{style:m(s.has(h.name)),children:s.has(h.name)&&n.jsx("svg",{width:"8",height:"8",viewBox:"0 0 10 10",fill:"#fff",children:n.jsx("path",{d:"M8.5 2.5L4 7 1.5 4.5",stroke:"#fff",strokeWidth:"1.5",fill:"none"})})}),n.jsx("span",{style:{overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:h.label||h.name}),n.jsx("span",{style:{fontSize:9,color:Yt[h.type]??E.accent,marginLeft:"auto",flexShrink:0},children:h.type})]},h.name))}),n.jsx("div",{style:{fontSize:10,fontWeight:600,color:E.textSecondary,marginBottom:4,textTransform:"uppercase",letterSpacing:"0.04em"},children:"Select Dimensions (optional)"}),n.jsx("div",{style:{maxHeight:120,overflowY:"auto",marginBottom:8},children:t.map(h=>n.jsxs("label",{style:{display:"flex",alignItems:"center",gap:6,padding:"2px 0",cursor:"pointer",color:E.textPrimary,fontSize:11},onClick:()=>D(h.name),children:[n.jsx("div",{style:m(A.has(h.name)),children:A.has(h.name)&&n.jsx("svg",{width:"8",height:"8",viewBox:"0 0 10 10",fill:"#fff",children:n.jsx("path",{d:"M8.5 2.5L4 7 1.5 4.5",stroke:"#fff",strokeWidth:"1.5",fill:"none"})})}),n.jsx("span",{style:{overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:h.label||h.name})]},h.name))}),n.jsx("button",{onClick:f,disabled:s.size===0||O,style:{width:"100%",padding:"5px 12px",background:s.size===0?E.pillBg:E.accent,color:s.size===0?E.textMuted:"#fff",border:"none",borderRadius:5,cursor:s.size===0?"not-allowed":"pointer",fontSize:11,fontWeight:600,fontFamily:E.font,opacity:O?.7:1},children:O?"Composing...":`Compose SQL (${s.size} metric${s.size!==1?"s":""})`}),i&&n.jsx("div",{style:{marginTop:6,padding:"4px 8px",background:"#f8514922",border:"1px solid #f8514944",borderRadius:4,fontSize:10,color:"#f85149"},children:i}),o&&n.jsxs("div",{style:{marginTop:8},children:[n.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:4},children:[n.jsx("span",{style:{fontSize:10,fontWeight:600,color:E.textSecondary,textTransform:"uppercase",letterSpacing:"0.04em"},children:"Generated SQL"}),n.jsx("button",{onClick:p,style:{background:"transparent",border:`1px solid ${E.cellBorder}`,borderRadius:3,color:_?"#56d364":E.textMuted,cursor:"pointer",fontSize:9,fontFamily:E.font,padding:"1px 6px"},children:_?"Copied!":"Copy"})]}),n.jsx("pre",{style:{margin:0,padding:"6px 8px",background:E.editorBg,border:`1px solid ${E.cellBorder}`,borderRadius:4,fontFamily:E.fontMono,fontSize:10,color:E.textSecondary,lineHeight:1.5,whiteSpace:"pre-wrap",wordBreak:"break-all",maxHeight:200,overflowY:"auto"},children:o})]})]})]})}function zr(){const{state:E,dispatch:e}=y(),t=G[E.themeMode],[r,T]=l.useState(""),[s,R]=l.useState(!1),[A,a]=l.useState({metrics:!0,dimensions:!0,hierarchies:!1}),o=E.semanticLayer,S=async()=>{e({type:"SET_SEMANTIC_LOADING",loading:!0});try{const p=await V.getSemanticLayer();e({type:"SET_SEMANTIC_LAYER",layer:p})}catch(p){console.error("Semantic layer refresh failed:",p)}finally{e({type:"SET_SEMANTIC_LOADING",loading:!1})}};l.useEffect(()=>{o.metrics.length===0&&!o.loading&&S()},[]);const i=r.toLowerCase(),I=l.useMemo(()=>i?o.metrics.filter(p=>p.name.toLowerCase().includes(i)||p.label.toLowerCase().includes(i)||p.description.toLowerCase().includes(i)||p.tags.some(m=>m.toLowerCase().includes(i))):o.metrics,[o.metrics,i]),O=l.useMemo(()=>i?o.dimensions.filter(p=>p.name.toLowerCase().includes(i)||p.label.toLowerCase().includes(i)||p.description.toLowerCase().includes(i)):o.dimensions,[o.dimensions,i]),c=l.useMemo(()=>i?o.hierarchies.filter(p=>p.name.toLowerCase().includes(i)||p.label.toLowerCase().includes(i)):o.hierarchies,[o.hierarchies,i]),_=p=>{a(m=>({...m,[p]:!m[p]}))},d={background:t.pillBg,padding:"1px 4px",borderRadius:3,fontSize:10,fontFamily:t.fontMono},u={fontSize:11,fontWeight:600,color:t.textPrimary,fontFamily:t.font,marginBottom:4},D={fontSize:11,color:t.textMuted,fontFamily:t.font,lineHeight:1.6,marginBottom:2},f={margin:"4px 0 0",padding:"6px 8px",background:t.editorBg,border:`1px solid ${t.cellBorder}`,borderRadius:4,fontFamily:t.fontMono,fontSize:10,color:t.textSecondary,lineHeight:1.5,whiteSpace:"pre",overflowX:"auto"};return!o.available&&!o.loading?n.jsxs("div",{style:{flex:1,overflowY:"auto",padding:"12px 14px",fontFamily:t.font},children:[n.jsxs("div",{style:{textAlign:"center",marginBottom:14},children:[n.jsx("svg",{width:"28",height:"28",viewBox:"0 0 16 16",fill:t.accent,style:{opacity:.7},children:n.jsx("path",{d:"M8 1.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm6.5-2a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0Zm-2 4.5a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0Zm5 0a1.5 1.5 0 1 1 3 0 1.5 1.5 0 0 1-3 0Z"})}),n.jsx("div",{style:{fontSize:12,fontWeight:600,color:t.textPrimary,marginTop:6},children:"Set Up Semantic Layer"}),n.jsx("div",{style:{fontSize:11,color:t.textMuted,marginTop:2,lineHeight:1.5},children:"Choose a provider below, then click Retry."})]}),n.jsxs("div",{style:{marginBottom:12},children:[n.jsx("div",{style:u,children:"Step 1: Pick a provider"}),n.jsxs("div",{style:D,children:["Add ",n.jsx("code",{style:d,children:"semanticLayer"})," to your ",n.jsx("code",{style:d,children:"dql.config.json"}),":"]}),n.jsx("div",{style:{fontSize:10,fontWeight:600,color:t.accent,marginTop:8,letterSpacing:"0.03em"},children:"A) DQL Native — write YAML files directly"}),n.jsx("pre",{style:f,children:`"semanticLayer": {
|
|
209
|
+
"provider": "dql"
|
|
210
|
+
}`}),n.jsx("div",{style:{fontSize:10,fontWeight:600,color:t.accent,marginTop:8,letterSpacing:"0.03em"},children:"B) dbt — point to your dbt project"}),n.jsx("pre",{style:f,children:`"semanticLayer": {
|
|
211
|
+
"provider": "dbt",
|
|
212
|
+
"projectPath": "/path/to/dbt-project"
|
|
213
|
+
}`}),n.jsx("div",{style:{fontSize:10,fontWeight:600,color:t.accent,marginTop:8,letterSpacing:"0.03em"},children:"C) Cube.js — point to your Cube project"}),n.jsx("pre",{style:f,children:`"semanticLayer": {
|
|
214
|
+
"provider": "cubejs",
|
|
215
|
+
"projectPath": "/path/to/cube-project"
|
|
216
|
+
}`})]}),n.jsxs("div",{style:{marginBottom:12},children:[n.jsx("div",{style:u,children:"Step 2: Add definitions (DQL native only)"}),n.jsx("div",{style:D,children:"Create YAML files in your project:"}),n.jsx("pre",{style:f,children:`semantic-layer/
|
|
217
|
+
metrics/total_revenue.yaml
|
|
218
|
+
dimensions/segment.yaml
|
|
219
|
+
hierarchies/time.yaml (optional)
|
|
220
|
+
cubes/revenue_cube.yaml (optional)`}),n.jsx("div",{style:{...D,marginTop:6},children:"Minimal metric example:"}),n.jsx("pre",{style:f,children:`name: total_revenue
|
|
221
|
+
label: Total Revenue
|
|
222
|
+
sql: SUM(amount)
|
|
223
|
+
type: sum
|
|
224
|
+
table: fct_revenue`})]}),n.jsxs("div",{style:{marginBottom:14},children:[n.jsx("div",{style:u,children:"Step 3: Restart & refresh"}),n.jsxs("div",{style:D,children:["Restart ",n.jsx("code",{style:d,children:"dql notebook"}),", then click Retry below."]})]}),n.jsxs("div",{style:{display:"flex",gap:8,justifyContent:"center"},children:[n.jsx("button",{onClick:S,style:{background:t.accent,border:"none",borderRadius:6,color:"#fff",cursor:"pointer",fontSize:11,fontWeight:600,fontFamily:t.font,padding:"6px 16px"},children:"Retry"}),n.jsx("button",{onClick:()=>e({type:"SET_SIDEBAR_PANEL",panel:"reference"}),style:{background:"transparent",border:`1px solid ${t.cellBorder}`,borderRadius:6,color:t.textSecondary,cursor:"pointer",fontSize:11,fontFamily:t.font,padding:"6px 12px"},children:"Full Reference"})]})]}):n.jsxs("div",{style:{flex:1,overflow:"auto",display:"flex",flexDirection:"column"},children:[n.jsxs("div",{style:{padding:"8px 10px",display:"flex",alignItems:"center",gap:6,borderBottom:`1px solid ${t.headerBorder}`},children:[o.provider&&n.jsx("span",{style:{fontSize:9,fontWeight:600,color:t.accent,background:`${t.accent}18`,borderRadius:4,padding:"1px 5px",textTransform:"uppercase",letterSpacing:"0.04em"},children:o.provider}),n.jsxs("span",{style:{flex:1,fontSize:11,color:t.textMuted,fontFamily:t.font},children:[o.metrics.length," metrics"]}),n.jsx("button",{onClick:S,onMouseEnter:()=>R(!0),onMouseLeave:()=>R(!1),title:"Refresh semantic layer",style:{background:s?t.btnHover:"transparent",border:`1px solid ${s?t.btnBorder:"transparent"}`,borderRadius:4,cursor:"pointer",color:s?t.textSecondary:t.textMuted,fontSize:11,fontFamily:t.font,padding:"2px 6px",display:"flex",alignItems:"center",gap:4,transition:"all 0.15s"},children:n.jsx("svg",{width:"11",height:"11",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M1.705 8.005a.75.75 0 0 1 .834.656 5.5 5.5 0 0 0 9.592 2.97l-1.204-1.204a.25.25 0 0 1 .177-.427h3.646a.25.25 0 0 1 .25.25v3.646a.25.25 0 0 1-.427.177l-1.38-1.38A7.002 7.002 0 0 1 1.05 8.84a.75.75 0 0 1 .656-.834ZM8 2.5a5.487 5.487 0 0 0-4.131 1.869l1.204 1.204A.25.25 0 0 1 4.896 6H1.25A.25.25 0 0 1 1 5.75V2.104a.25.25 0 0 1 .427-.177l1.38 1.38A7.002 7.002 0 0 1 14.95 7.16a.75.75 0 0 1-1.49.178A5.5 5.5 0 0 0 8 2.5Z"})})})]}),n.jsx(qr,{t,metrics:o.metrics,dimensions:o.dimensions}),n.jsx("div",{style:{padding:"6px 8px",borderBottom:`1px solid ${t.headerBorder}`},children:n.jsx("input",{type:"text",placeholder:"Search metrics, dimensions...",value:r,onChange:p=>T(p.target.value),style:{width:"100%",padding:"4px 8px",background:t.cellBg,border:`1px solid ${t.cellBorder}`,borderRadius:4,color:t.textPrimary,fontSize:11,fontFamily:t.font,outline:"none"}})}),o.loading?n.jsxs("div",{style:{padding:"8px 12px",display:"flex",flexDirection:"column",gap:8},children:[[1,2,3].map(p=>n.jsx("div",{style:{height:28,borderRadius:4,background:t.pillBg,opacity:.6,animation:"pulse 1.5s ease-in-out infinite"}},p)),n.jsx("style",{children:"@keyframes pulse { 0%,100%{opacity:.6} 50%{opacity:.3} }"})]}):n.jsxs("div",{style:{overflow:"auto",flex:1},children:[n.jsx(we,{label:"Metrics",count:I.length,expanded:A.metrics,onToggle:()=>_("metrics"),t}),A.metrics&&n.jsx("div",{children:I.length===0?n.jsx("div",{style:{padding:"4px 14px 4px 32px",fontSize:12,color:t.textMuted,fontFamily:t.font,fontStyle:"italic"},children:i?"No matching metrics":"No metrics defined"}):I.map(p=>n.jsx(Jr,{metric:p,t},p.name))}),n.jsx(we,{label:"Dimensions",count:O.length,expanded:A.dimensions,onToggle:()=>_("dimensions"),t}),A.dimensions&&n.jsx("div",{children:O.length===0?n.jsx("div",{style:{padding:"4px 14px 4px 32px",fontSize:12,color:t.textMuted,fontFamily:t.font,fontStyle:"italic"},children:i?"No matching dimensions":"No dimensions defined"}):O.map(p=>n.jsx(Qr,{dimension:p,t},p.name))}),o.hierarchies.length>0&&n.jsxs(n.Fragment,{children:[n.jsx(we,{label:"Hierarchies",count:c.length,expanded:A.hierarchies,onToggle:()=>_("hierarchies"),t}),A.hierarchies&&n.jsx("div",{children:c.map(p=>n.jsx(Zr,{hierarchy:p,t},p.name))})]})]})]})}const en={files:"Explorer",schema:"Schema",semantic:"Semantic Layer",outline:"Outline",connection:"Connection",reference:"Quick Reference"};function En({onOpenFile:E,onNavigateToCell:e}){const{state:t,dispatch:r}=y(),T=G[t.themeMode],[s,R]=l.useState(!1),A=t.sidebarPanel;return n.jsxs("div",{style:{width:240,flexShrink:0,background:T.sidebarBg,borderRight:`1px solid ${T.headerBorder}`,display:"flex",flexDirection:"column",overflow:"hidden"},children:[n.jsxs("div",{style:{height:36,flexShrink:0,display:"flex",alignItems:"center",justifyContent:"space-between",padding:"0 10px 0 14px",borderBottom:`1px solid ${T.headerBorder}`},children:[n.jsx("span",{style:{fontSize:11,fontWeight:600,letterSpacing:"0.06em",textTransform:"uppercase",color:T.textSecondary,fontFamily:T.font},children:en[A??""]??""}),n.jsx("button",{title:"Collapse sidebar",onClick:()=>r({type:"TOGGLE_SIDEBAR"}),onMouseEnter:()=>R(!0),onMouseLeave:()=>R(!1),style:{background:"transparent",border:"none",cursor:"pointer",color:s?T.textPrimary:T.textMuted,padding:"2px 4px",borderRadius:4,fontSize:14,lineHeight:1,transition:"color 0.15s",display:"flex",alignItems:"center"},children:"‹"})]}),n.jsxs("div",{style:{flex:1,overflow:"hidden",display:"flex",flexDirection:"column"},children:[A==="files"&&n.jsx(Nr,{onOpenFile:E}),A==="schema"&&n.jsx(dr,{}),A==="semantic"&&n.jsx(zr,{}),A==="outline"&&n.jsx(Mr,{onNavigate:e}),A==="connection"&&n.jsx(mr,{}),A==="reference"&&n.jsx(Kr,{themeMode:t.themeMode})]})]})}function tn(E){try{const e=E.match(/workbook\s+"([^"]+)"/i),t=e?e[1]:"Untitled Workbook",r=[],T=/page\s+"([^"]+)"\s*\{([\s\S]*?)\}/gi;let s;for(;(s=T.exec(E))!==null;){const R=s[1],A=s[2].trim();r.push({id:ee(),type:"markdown",content:`# ${R}`,status:"idle"}),A&&r.push({id:ee(),type:"dql",name:R.toLowerCase().replace(/\s+/g,"_"),content:A,status:"idle"})}return r.length===0&&r.push({id:ee(),type:"dql",content:E.trim(),status:"idle"}),{title:t,cells:r}}catch{return{title:"Untitled Workbook",cells:[{id:ee(),type:"dql",content:E.trim(),status:"idle"}]}}}function Tn(E){var e;try{const t=JSON.parse(E),r=t.title||((e=t.metadata)==null?void 0:e.title)||"Untitled",T=(t.cells||[]).map(s=>({id:s.id||ee(),type:s.type||"sql",content:s.content??s.source??"",name:s.name||s.title,status:"idle",...s.paramConfig?{paramConfig:s.paramConfig}:{},...s.paramValue!==void 0?{paramValue:s.paramValue}:{},...s.chartConfig?{chartConfig:s.chartConfig}:{}}));return{title:r,cells:T}}catch{return{title:"Untitled",cells:[{id:ee(),type:"sql",content:E,status:"idle"}]}}}function rn(E,e,t){const r={version:1,title:E,metadata:{...t,modifiedAt:new Date().toISOString(),createdAt:new Date().toISOString()},cells:e.map(T=>({id:T.id,type:T.type,content:T.content,...T.name?{name:T.name}:{},...T.paramConfig?{paramConfig:T.paramConfig}:{},...T.paramValue!==void 0?{paramValue:T.paramValue}:{},...T.chartConfig?{chartConfig:T.chartConfig}:{}}))};return JSON.stringify(r,null,2)}function nn(E,e){return E.endsWith(".dql")?tn(e):Tn(e)}function sn(E,e){if(!e.columns.length||!e.rows.length)return`${E} AS (SELECT 1 WHERE 1=0)`;const t=e.columns,T=e.rows.slice(0,5e3).map(R=>`(${t.map(a=>{const o=R[a];return o==null?"NULL":typeof o=="number"?String(o):typeof o=="boolean"?o?"TRUE":"FALSE":`'${String(o).replace(/'/g,"''")}'`}).join(", ")})`).join(`,
|
|
225
|
+
`),s=t.map(R=>`"${R.replace(/"/g,'""')}"`).join(", ");return`${E} AS (
|
|
226
|
+
SELECT * FROM (VALUES
|
|
227
|
+
${T}
|
|
228
|
+
) AS _t(${s})
|
|
229
|
+
)`}function Rn(E,e){if(e==="number"){const t=Number(E);return isNaN(t)?`'${E.replace(/'/g,"''")}'`:String(t)}return`'${E.replace(/'/g,"''")}'`}function An(){const{state:E}=y();return{substituteVariables:l.useCallback(t=>{var S;const r=/\{\{([a-zA-Z_][a-zA-Z0-9_]*)\}\}/g,T=[...t.matchAll(r)];if(T.length===0)return{sql:t,substituted:[]};const s=[],R=[];let A=t;const a=new Map,o=new Map;for(const i of E.cells){const I=(S=i.name)==null?void 0:S.trim();I&&(i.type==="param"?a.set(I,i):i.status==="success"&&i.result&&o.set(I,i.result))}for(const i of T){const I=i[1];if(a.has(I)){const O=a.get(I),c=O.paramConfig,_=O.paramValue??(c==null?void 0:c.defaultValue)??"",d=(c==null?void 0:c.paramType)??"text",u=Rn(_,d);A=A.replace(i[0],u),s.push(I)}else o.has(I)&&(R.push(sn(I,o.get(I))),A=A.replace(i[0],`"${I}"`),s.push(I))}if(R.length===0&&s.length===0)return{sql:t,substituted:[]};if(R.length>0){const i=A.trimStart();/^WITH\s+/i.test(i)?A=A.replace(/^(\s*WITH\s+)/i,`$1${R.join(`,
|
|
230
|
+
`)},
|
|
231
|
+
`):A=`WITH ${R.join(`,
|
|
232
|
+
`)}
|
|
233
|
+
${A}`}return{sql:A,substituted:s}},[E.cells])}}function on(E){const e=UE(E);return e?e.path:null}function UE(E){if(E.type!=="dql")return null;const t=E.content.trim().match(/^@import\s+["']([^"']+\.dql)["'](?:\s+with\s+([\s\S]+))?$/i);if(!t)return null;const r=t[1],T={};if(t[2])for(const s of t[2].split(",")){const R=s.indexOf("=");if(R<0)continue;const A=s.slice(0,R).trim();let a=s.slice(R+1).trim();a=a.replace(/^["']|["']$/g,""),A&&(T[A]=a)}return{path:r,params:T}}function VE(E){const e=E.match(/visualization\s*\{([^}]+)\}/is);if(!e)return;const t=e[1],r=s=>{var R;return(R=t.match(new RegExp(`\\b${s}\\s*=\\s*["']?([\\w-]+)["']?`,"i")))==null?void 0:R[1]},T=r("chart");if(T)return{chart:T,x:r("x"),y:r("y"),color:r("color"),title:r("title")}}function Sn(E){var r;const e=E.match(/params\s*\{([^}]+)\}/is);if(!e)return{};const t={};for(const T of e[1].matchAll(/(\w+)\s*(?::\s*(\w+)\s*)?=\s*["']([^"']*)["']/g)){const s=T[1],R=(r=T[2])==null?void 0:r.toLowerCase(),A=R==="number"?"number":R==="date"?"date":"text";t[s]={value:T[3],type:A}}return t}function an(E,e,t,r){const T=[],s=E.replace(/\$\{(\w+)\}/g,(R,A)=>{var S;const a=e[A];if(a===void 0)return T.push(A),R;const o=((S=t[A])==null?void 0:S.type)??"text";if(o==="number"){const i=Number(a);return isNaN(i)?`'${a.replace(/'/g,"''")}'`:String(i)}return o==="date"?`DATE '${a.replace(/'/g,"''")}'`:`'${a.replace(/'/g,"''")}'`});if(T.length>0){const R=r?` in block ${r}`:"";throw new Error(`Missing required parameter(s): ${T.join(", ")}${R}`)}return s}function In(E){return vt(E.trim())}function On(E){if(E.type==="markdown"||E.type==="param")return null;if(E.type==="sql")return E.content.trim()||null;const e=E.content.trim();return e?/^@import\s+/i.test(e)?"__IMPORT__":vt(e):null}function vt(E){const e=E.match(/query\s*=\s*"""([\s\S]*?)"""/i);if(e)return e[1].trim()||null;const t=E.match(/"""([\s\S]*?)"""/);if(t)return t[1].trim()||null;if(/^\s*(dashboard|workbook)\s+"/i.test(E))return null;const r=E.match(/\b(SELECT|WITH|INSERT|UPDATE|DELETE|CREATE|DROP|ALTER|SHOW|DESCRIBE|EXPLAIN)\b([\s\S]*)/i);if(r){let T=r[0];const s=T.search(/\b(visualization|tests|block)\s*\{/i);return s>0&&(T=T.slice(0,s)),T=Nn(T),T.trim()||null}return null}function Nn(E){let e=0;for(let t=0;t<E.length;t++){const r=E[t];if(r==="("){e++;continue}if(r===")"){e>0&&e--;continue}if(r==="'"||r==='"'){for(t++;t<E.length&&E[t]!==r;)E[t]==="\\"&&t++,t++;continue}if(r===","&&e===0){let T=t+1;for(;T<E.length&&/\s/.test(E[T]);)T++;if(T<E.length&&/[a-zA-Z_]/.test(E[T])){for(;T<E.length&&/[a-zA-Z0-9_]/.test(E[T]);)T++;let s=T;for(;s<E.length&&/\s/.test(E[s]);)s++;if(s<E.length&&E[s]==="="&&E[s+1]!=="=")return E.slice(0,t)}}}return E}function hE(){const{state:E,dispatch:e}=y(),{substituteVariables:t}=An(),r=l.useCallback(async R=>{const A=E.cells.find(i=>i.id===R);if(!A)return;let a=On(A);if(!a)return;if(a==="__IMPORT__"){const i=UE(A);try{const{content:I}=await V.readNotebook(i.path);if(a=In(I),!a)throw new Error(`No executable SQL found in block: ${i.path}`);const O=Sn(I),c={};for(const[u,D]of Object.entries(O))c[u]=D.value;const _={...c,...i.params};(Object.keys(_).length>0||/\$\{\w+\}/.test(a))&&(a=an(a,_,O,i.path));const d=VE(I);d&&e({type:"UPDATE_CELL",id:R,updates:{chartConfig:d}})}catch(I){const O=I instanceof Error?I.message:String(I);e({type:"UPDATE_CELL",id:R,updates:{status:"error",error:O,executionCount:(A.executionCount??0)+1}});return}}if(A.type==="dql"&&a!=="__IMPORT__"){const i=VE(A.content);i&&JSON.stringify(i)!==JSON.stringify(A.chartConfig)&&e({type:"UPDATE_CELL",id:R,updates:{chartConfig:i}})}const{sql:o}=t(a),S=Date.now();e({type:"UPDATE_CELL",id:R,updates:{status:"running",error:void 0,result:void 0}});try{const i=await V.executeQuery(o),I=Date.now()-S,O=(A.executionCount??0)+1;e({type:"UPDATE_CELL",id:R,updates:{status:"success",result:{...i,executionTime:i.executionTime??I,rowCount:i.rowCount??i.rows.length},executionCount:O}}),e({type:"APPEND_QUERY_LOG",entry:{id:ee(),cellName:A.name??A.id,rows:i.rowCount??i.rows.length,time:i.executionTime??I,ts:new Date}}),setTimeout(()=>{e({type:"UPDATE_CELL",id:R,updates:{status:"idle"}})},2e3)}catch(i){const I=Date.now()-S,O=i instanceof Error?i.message:String(i);e({type:"UPDATE_CELL",id:R,updates:{status:"error",error:O,executionCount:(A.executionCount??0)+1}}),e({type:"APPEND_QUERY_LOG",entry:{id:ee(),cellName:A.name??A.id,rows:0,time:I,ts:new Date,error:O}})}},[E.cells,e]),T=l.useCallback(async()=>{for(const R of E.cells)R.type!=="markdown"&&await r(R.id)},[E.cells,r]),s=l.useCallback(async R=>{if(!R)return;const A=`{{${R}}}`;for(const a of E.cells)a.type==="markdown"||a.type==="param"||a.content.includes(A)&&await r(a.id)},[E.cells,r]);return{executeCell:r,executeAll:T,executeDependents:s}}function W(E){return E.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}function ln(E){return typeof E=="number"?Math.abs(E)>=1e6?`${(E/1e6).toFixed(1)}M`:Math.abs(E)>=1e3?`${(E/1e3).toFixed(1)}K`:Number.isInteger(E)?String(E):E.toFixed(2):""}function Ln(E){const e=E.split(`
|
|
234
|
+
`),t=[];let r=!1,T=!1;for(const s of e){const R=s;if(R.startsWith("```")){T&&(t.push("</ul>"),T=!1),r?(t.push("</code></pre>"),r=!1):(t.push("<pre><code>"),r=!0);continue}if(r){t.push(W(R));continue}if(R.startsWith("### ")){T&&(t.push("</ul>"),T=!1),t.push(`<h3>${W(R.slice(4))}</h3>`);continue}if(R.startsWith("## ")){T&&(t.push("</ul>"),T=!1),t.push(`<h2>${W(R.slice(3))}</h2>`);continue}if(R.startsWith("# ")){T&&(t.push("</ul>"),T=!1),t.push(`<h1>${W(R.slice(2))}</h1>`);continue}if(R.startsWith("> ")){T&&(t.push("</ul>"),T=!1),t.push(`<blockquote><p>${W(R.slice(2))}</p></blockquote>`);continue}if(R.startsWith("- ")||R.startsWith("* ")){T||(t.push("<ul>"),T=!0),t.push(`<li>${WE(R.slice(2))}</li>`);continue}if(T&&(t.push("</ul>"),T=!1),R.trim()===""){t.push("<br>");continue}t.push(`<p>${WE(R)}</p>`)}return T&&t.push("</ul>"),r&&t.push("</code></pre>"),t.join(`
|
|
235
|
+
`)}function WE(E){return W(E).replace(/\*\*(.+?)\*\*/g,"<strong>$1</strong>").replace(/\*(.+?)\*/g,"<em>$1</em>").replace(/`(.+?)`/g,"<code>$1</code>")}function Cn(E){const{columns:e,rows:t}=E,r=t.slice(0,200),T=t.length>200,s=e.map(A=>`<th>${W(A)}</th>`).join(""),R=r.map(A=>`<tr>${e.map(o=>{const S=A[o],i=typeof S=="number",I=S==null?"—":String(S);return`<td${i?' class="num"':""}>${W(I)}</td>`}).join("")}</tr>`).join("");return`
|
|
236
|
+
<div class="table-wrap">
|
|
237
|
+
<table>
|
|
238
|
+
<thead><tr>${s}</tr></thead>
|
|
239
|
+
<tbody>${R}</tbody>
|
|
240
|
+
</table>
|
|
241
|
+
${T?`<p class="truncated">Showing first 200 of ${t.length.toLocaleString()} rows</p>`:""}
|
|
242
|
+
</div>`}function cn(E){const{columns:e,rows:t}=E;if(e.length<2||t.length===0)return null;const r=e.find(s=>typeof t[0][s]=="number"),T=e.find(s=>s!==r);return!r||!T?null:{labelCol:T,valueCol:r}}function _n(E){const e=cn(E);if(!e)return null;const t=E.rows.slice(0,20).map(S=>({label:String(S[e.labelCol]??""),value:Number(S[e.valueCol]??0)})),r=Math.max(...t.map(S=>S.value),1),T=28,s=6,R=140,A=440,a=t.length*(T+s)+40,o=t.map((S,i)=>{const I=i*(T+s)+20,O=Math.max(S.value/r*A,2);return`
|
|
243
|
+
<text x="${R-6}" y="${I+T/2+4}" text-anchor="end" font-size="11" fill="#8b949e">${W(S.label.slice(0,20))}</text>
|
|
244
|
+
<rect x="${R}" y="${I}" width="${O}" height="${T}" rx="3" fill="#388bfd" />
|
|
245
|
+
<text x="${R+O+5}" y="${I+T/2+4}" font-size="11" fill="#e6edf3">${ln(S.value)}</text>`}).join("");return`<svg xmlns="http://www.w3.org/2000/svg" width="${R+A+80}" height="${a}" style="max-width:100%">${o}</svg>`}function dn(E,e){const t=e.map(r=>{if(r.type==="markdown")return`<section class="cell md-cell">${Ln(r.content)}</section>`;const T=r.name?`<div class="cell-header"><span class="cell-type">${r.type.toUpperCase()}</span><span class="cell-name">${W(r.name)}</span></div>`:`<div class="cell-header"><span class="cell-type">${r.type.toUpperCase()}</span></div>`,s=`<pre class="cell-code"><code>${W(r.content)}</code></pre>`;let R="";if(r.result&&r.result.rows.length>0){const A=_n(r.result),a=Cn(r.result);R=`<div class="cell-output">${`<div class="output-meta">${r.result.rows.length.toLocaleString()} rows${r.result.executionTime?` · ${r.result.executionTime}ms`:""}</div>`}${A??""}${A?"":a}</div>`}else r.error&&(R=`<div class="cell-error">⚠ ${W(r.error)}</div>`);return`<section class="cell sql-cell">${T}${s}${R}</section>`}).join(`
|
|
246
|
+
`);return`<!DOCTYPE html>
|
|
247
|
+
<html lang="en">
|
|
248
|
+
<head>
|
|
249
|
+
<meta charset="UTF-8">
|
|
250
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
251
|
+
<title>${W(E)}</title>
|
|
252
|
+
<style>
|
|
253
|
+
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
|
|
254
|
+
body {
|
|
255
|
+
font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
|
|
256
|
+
background: #0d1117; color: #e6edf3;
|
|
257
|
+
line-height: 1.6; padding: 0;
|
|
258
|
+
}
|
|
259
|
+
.page-header {
|
|
260
|
+
background: #161b22; border-bottom: 1px solid #21262d;
|
|
261
|
+
padding: 16px 32px; display: flex; align-items: center; gap: 12px;
|
|
262
|
+
}
|
|
263
|
+
.logo {
|
|
264
|
+
width: 28px; height: 28px; border-radius: 6px;
|
|
265
|
+
background: linear-gradient(135deg, #388bfd, #1f6feb);
|
|
266
|
+
display: flex; align-items: center; justify-content: center;
|
|
267
|
+
font-size: 10px; font-weight: 700; color: #fff;
|
|
268
|
+
font-family: monospace; letter-spacing: -0.5px; flex-shrink: 0;
|
|
269
|
+
}
|
|
270
|
+
.page-title { font-size: 18px; font-weight: 600; color: #e6edf3; }
|
|
271
|
+
.page-meta { font-size: 12px; color: #8b949e; margin-left: auto; }
|
|
272
|
+
.content { max-width: 900px; margin: 0 auto; padding: 32px 24px; display: flex; flex-direction: column; gap: 24px; }
|
|
273
|
+
.cell { border-radius: 8px; overflow: hidden; }
|
|
274
|
+
.md-cell { padding: 4px 0; }
|
|
275
|
+
.md-cell h1 { font-size: 26px; font-weight: 700; color: #e6edf3; margin: 0 0 12px; }
|
|
276
|
+
.md-cell h2 { font-size: 20px; font-weight: 600; color: #e6edf3; margin: 20px 0 10px; }
|
|
277
|
+
.md-cell h3 { font-size: 16px; font-weight: 600; color: #e6edf3; margin: 16px 0 8px; }
|
|
278
|
+
.md-cell p { color: #c9d1d9; margin-bottom: 8px; }
|
|
279
|
+
.md-cell ul { padding-left: 20px; color: #c9d1d9; margin-bottom: 8px; }
|
|
280
|
+
.md-cell code { background: #21262d; padding: 2px 6px; border-radius: 4px; font-family: monospace; font-size: 13px; }
|
|
281
|
+
.md-cell pre { background: #161b22; border: 1px solid #30363d; border-radius: 6px; padding: 14px; overflow-x: auto; margin-bottom: 8px; }
|
|
282
|
+
.md-cell pre code { background: none; padding: 0; }
|
|
283
|
+
.md-cell blockquote { border-left: 3px solid #388bfd; padding-left: 14px; color: #8b949e; }
|
|
284
|
+
.sql-cell { background: #161b22; border: 1px solid #30363d; }
|
|
285
|
+
.cell-header { display: flex; align-items: center; gap: 8px; padding: 8px 14px; border-bottom: 1px solid #21262d; background: #1c2128; }
|
|
286
|
+
.cell-type { font-size: 10px; font-weight: 600; letter-spacing: 0.05em; color: #8b949e; background: #21262d; padding: 2px 6px; border-radius: 4px; font-family: monospace; }
|
|
287
|
+
.cell-name { font-size: 12px; color: #388bfd; font-family: monospace; }
|
|
288
|
+
.cell-code { background: #0d1117; padding: 14px; font-size: 12px; font-family: 'JetBrains Mono', monospace; color: #c9d1d9; overflow-x: auto; border-bottom: 1px solid #21262d; line-height: 1.55; white-space: pre; }
|
|
289
|
+
.cell-output { padding: 14px; }
|
|
290
|
+
.output-meta { font-size: 11px; color: #8b949e; margin-bottom: 10px; }
|
|
291
|
+
.table-wrap { overflow-x: auto; }
|
|
292
|
+
table { width: 100%; border-collapse: collapse; font-size: 12px; }
|
|
293
|
+
th { background: #1c2128; color: #8b949e; font-weight: 600; text-align: left; padding: 7px 12px; border-bottom: 1px solid #30363d; white-space: nowrap; }
|
|
294
|
+
td { padding: 6px 12px; border-bottom: 1px solid #21262d; color: #e6edf3; }
|
|
295
|
+
td.num { text-align: right; font-family: monospace; }
|
|
296
|
+
tr:last-child td { border-bottom: none; }
|
|
297
|
+
.truncated { font-size: 11px; color: #8b949e; margin-top: 8px; }
|
|
298
|
+
.cell-error { padding: 12px 14px; background: #3d1a1a; border-top: 1px solid #f85149; color: #f85149; font-size: 13px; }
|
|
299
|
+
.exported-by { text-align: center; color: #484f58; font-size: 11px; padding: 40px 0 24px; }
|
|
300
|
+
</style>
|
|
301
|
+
</head>
|
|
302
|
+
<body>
|
|
303
|
+
<div class="page-header">
|
|
304
|
+
<div class="logo">DQL</div>
|
|
305
|
+
<span class="page-title">${W(E)}</span>
|
|
306
|
+
<span class="page-meta">Exported ${new Date().toLocaleDateString("en-US",{year:"numeric",month:"long",day:"numeric"})}</span>
|
|
307
|
+
</div>
|
|
308
|
+
<div class="content">
|
|
309
|
+
${t}
|
|
310
|
+
</div>
|
|
311
|
+
<p class="exported-by">Built with DQL Notebook</p>
|
|
312
|
+
</body>
|
|
313
|
+
</html>`}function Dn(E,e){const t=dn(E,e),r=new Blob([t],{type:"text/html;charset=utf-8"}),T=URL.createObjectURL(r),s=document.createElement("a");s.href=T,s.download=`${E.toLowerCase().replace(/[^a-z0-9]+/g,"-")}-dashboard.html`,document.body.appendChild(s),s.click(),document.body.removeChild(s),URL.revokeObjectURL(T)}function un(E,e){var s,R;const t=[];t.push(`workbook "${E}" {`);let r=0,T=0;for(const A of e)if(A.type!=="param"){if(A.type==="markdown"){T++;const a=`Markdown ${T}`;t.push(""),t.push(` page "${a}" {`);const o=A.content.split(`
|
|
314
|
+
`);for(const S of o)t.push(` // ${S}`);t.push(" }")}else if(A.type==="sql"){r++;const a=((s=A.name)==null?void 0:s.trim())||`Query ${r}`;t.push(""),t.push(` page "${a}" {`);const S=A.content.trim().split(`
|
|
315
|
+
`).map(i=>` ${i}`).join(`
|
|
316
|
+
`);t.push(" chart.table("),t.push(S+","),t.push(` title = "${a}"`),t.push(" )"),t.push(" }")}else if(A.type==="dql"){r++;const a=((R=A.name)==null?void 0:R.trim())||`Query ${r}`;t.push(""),t.push(` page "${a}" {`);const o=A.content.trim().split(`
|
|
317
|
+
`);for(const S of o)t.push(` ${S}`);t.push(" }")}}return t.push("}"),t.join(`
|
|
318
|
+
`)}function Pn(E,e){const t=un(E,e),r=new Blob([t],{type:"text/plain;charset=utf-8"}),T=URL.createObjectURL(r),s=document.createElement("a"),R=E.replace(/[^a-zA-Z0-9_-]/g,"_")+".dql";s.href=T,s.download=R,document.body.appendChild(s),s.click(),document.body.removeChild(s),URL.revokeObjectURL(T)}function pn({t:E}){return n.jsx("div",{style:{width:28,height:28,borderRadius:6,background:"linear-gradient(135deg, #388bfd 0%, #1f6feb 100%)",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},children:n.jsx("span",{style:{color:"#ffffff",fontSize:10,fontWeight:700,fontFamily:E.fontMono,letterSpacing:"-0.5px"},children:"DQL"})})}function Mn(){const{state:E,dispatch:e}=y(),t=G[E.themeMode],{executeAll:r}=hE(),[T,s]=l.useState(!1),[R,A]=l.useState(""),[a,o]=l.useState(!1),[S,i]=l.useState(!1),[I,O]=l.useState(!1),[c,_]=l.useState(!1),[d,u]=l.useState(!1),[D,f]=l.useState(!1),p=l.useRef(null),m=l.useRef(null);l.useEffect(()=>{T&&m.current&&(m.current.focus(),m.current.select())},[T]),l.useEffect(()=>{if(!D)return;function B(Re){p.current&&!p.current.contains(Re.target)&&f(!1)}return document.addEventListener("mousedown",B),()=>document.removeEventListener("mousedown",B)},[D]);const h=()=>{A(E.notebookTitle),s(!0)},Y=()=>{s(!1),R.trim()&&R!==E.notebookTitle&&e({type:"SET_NOTEBOOK_DIRTY",dirty:!0})},b=l.useCallback(async()=>{if(E.activeFile){e({type:"SET_SAVING",saving:!0});try{const B=rn(E.notebookTitle,E.cells);await V.saveNotebook(E.activeFile.path,B),e({type:"SET_NOTEBOOK_DIRTY",dirty:!1}),o(!0),setTimeout(()=>o(!1),2e3)}catch(B){console.error("Save failed:",B)}finally{e({type:"SET_SAVING",saving:!1})}}},[E.activeFile,E.notebookTitle,E.cells,e]),Ee=()=>{e({type:"SET_THEME",mode:E.themeMode==="dark"?"light":"dark"})},Z={height:28,padding:"0 10px",borderRadius:6,border:`1px solid ${t.btnBorder}`,cursor:"pointer",fontSize:12,fontWeight:500,fontFamily:t.font,display:"flex",alignItems:"center",gap:4,transition:"background 0.15s, color 0.15s",whiteSpace:"nowrap"};return n.jsxs("div",{style:{height:48,flexShrink:0,background:t.headerBg,borderBottom:`1px solid ${t.headerBorder}`,display:"flex",alignItems:"center",padding:"0 12px",gap:8,userSelect:"none"},children:[n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8,minWidth:0},children:[n.jsx(pn,{t}),n.jsx("div",{style:{width:1,height:20,background:t.headerBorder,flexShrink:0}}),E.activeFile?T?n.jsx("input",{ref:m,value:R,onChange:B=>A(B.target.value),onBlur:Y,onKeyDown:B=>{B.key==="Enter"&&Y(),B.key==="Escape"&&s(!1)},style:{background:"transparent",border:`1px solid ${t.cellBorderActive}`,borderRadius:4,color:t.textPrimary,fontSize:13,fontWeight:500,fontFamily:t.font,padding:"2px 6px",outline:"none",minWidth:120,maxWidth:320}}):n.jsxs("span",{onClick:h,title:"Click to rename",style:{color:t.textPrimary,fontSize:13,fontWeight:500,fontFamily:t.font,cursor:"text",maxWidth:320,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",padding:"2px 4px",borderRadius:4,border:"1px solid transparent"},children:[E.notebookTitle||"Untitled",E.notebookDirty&&n.jsx("span",{style:{color:t.textMuted,marginLeft:4},children:"●"})]}):n.jsx("span",{style:{color:t.textSecondary,fontSize:13,fontFamily:t.font,padding:"2px 4px"},children:"DQL Notebook"})]}),n.jsx("div",{style:{flex:1}}),n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:6},children:[n.jsxs("button",{onClick:r,disabled:!E.activeFile,onMouseEnter:()=>i(!0),onMouseLeave:()=>i(!1),style:{...Z,background:(S&&E.activeFile,t.accent),color:"#ffffff",border:`1px solid ${t.accent}`,opacity:E.activeFile?S?.9:1:.4},children:[n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 10 10",fill:"currentColor",children:n.jsx("path",{d:"M1.5 1.5l7 3.5-7 3.5V1.5Z"})}),"Run All"]}),n.jsx("div",{style:{width:1,height:20,background:t.headerBorder}}),n.jsx("button",{onClick:Ee,onMouseEnter:()=>_(!0),onMouseLeave:()=>_(!1),title:E.themeMode==="dark"?"Switch to light mode":"Switch to dark mode",style:{...Z,background:c?t.btnHover:t.btnBg,color:t.textSecondary,padding:"0 8px",fontSize:14},children:E.themeMode==="dark"?"☀":"☾"}),n.jsx("button",{onClick:b,disabled:!E.activeFile||E.savingFile,onMouseEnter:()=>O(!0),onMouseLeave:()=>O(!1),style:{...Z,background:I&&E.activeFile?t.btnHover:t.btnBg,color:a?t.success:t.textSecondary,opacity:E.activeFile?1:.4},children:E.savingFile?n.jsxs(n.Fragment,{children:[n.jsx(Un,{}),"Saving…"]}):a?n.jsx(n.Fragment,{children:"✓ Saved"}):n.jsx(n.Fragment,{children:"Save"})}),n.jsx("div",{style:{width:1,height:20,background:t.headerBorder}}),n.jsxs("div",{ref:p,style:{position:"relative"},children:[n.jsxs("button",{onClick:()=>{E.activeFile&&f(B=>!B)},disabled:!E.activeFile,onMouseEnter:()=>u(!0),onMouseLeave:()=>u(!1),title:"Export options",style:{...Z,background:(d||D)&&E.activeFile?t.btnHover:t.btnBg,color:t.textSecondary,opacity:E.activeFile?1:.4},children:[n.jsxs("svg",{width:"11",height:"11",viewBox:"0 0 16 16",fill:"currentColor",children:[n.jsx("path",{d:"M2.75 14A1.75 1.75 0 0 1 1 12.25v-2.5a.75.75 0 0 1 1.5 0v2.5c0 .138.112.25.25.25h10.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 14Z"}),n.jsx("path",{d:"M7.25 7.689V2a.75.75 0 0 1 1.5 0v5.689l1.97-1.97a.749.749 0 1 1 1.06 1.06l-3.25 3.25a.749.749 0 0 1-1.06 0L4.22 6.779a.749.749 0 1 1 1.06-1.06l1.97 1.97Z"})]}),"Export",n.jsx("svg",{width:"8",height:"8",viewBox:"0 0 8 8",fill:"currentColor",style:{marginLeft:1},children:n.jsx("path",{d:"M1 2.5l3 3 3-3",stroke:"currentColor",fill:"none",strokeWidth:"1.2",strokeLinecap:"round"})})]}),D&&n.jsxs("div",{style:{position:"absolute",top:32,right:0,zIndex:200,background:t.modalBg,border:`1px solid ${t.cellBorder}`,borderRadius:8,boxShadow:"0 8px 24px rgba(0,0,0,0.3)",padding:4,minWidth:160,display:"flex",flexDirection:"column",gap:2},children:[n.jsx(XE,{label:"Export HTML",description:"Standalone dashboard",t,onClick:()=>{Dn(E.notebookTitle||"dashboard",E.cells),f(!1)}}),n.jsx(XE,{label:"Export .dql",description:"DQL workbook file",t,onClick:()=>{Pn(E.notebookTitle||"notebook",E.cells),f(!1)}})]})]})]})]})}function XE({label:E,description:e,t,onClick:r}){const[T,s]=l.useState(!1);return n.jsxs("button",{onClick:r,onMouseEnter:()=>s(!0),onMouseLeave:()=>s(!1),style:{background:T?t.btnHover:"transparent",border:"none",borderRadius:5,cursor:"pointer",padding:"6px 10px",textAlign:"left",display:"flex",flexDirection:"column",gap:1,transition:"background 0.12s"},children:[n.jsx("span",{style:{fontSize:12,fontWeight:500,color:t.textPrimary,fontFamily:t.font},children:E}),n.jsx("span",{style:{fontSize:10,color:t.textMuted,fontFamily:t.font},children:e})]})}function Un(){return n.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",style:{animation:"spin 0.8s linear infinite"},children:[n.jsx("style",{children:"@keyframes spin { to { transform: rotate(360deg); } }"}),n.jsx("circle",{cx:"6",cy:"6",r:"4.5",stroke:"currentColor",strokeWidth:"1.5",strokeDasharray:"14 7"})]})}function hn(E){return E.toTimeString().slice(0,8)}function fn(E){return E<1e3?`${E}ms`:`${(E/1e3).toFixed(2)}s`}function mn(){const{state:E,dispatch:e}=y(),t=G[E.themeMode],[r,T]=l.useState(!1),s=E.queryLog.filter(A=>A.error),R=A=>e({type:"SET_DEV_PANEL_TAB",tab:A});return n.jsxs("div",{style:{height:E.devPanelOpen?180:0,flexShrink:0,background:t.sidebarBg,borderTop:`1px solid ${t.headerBorder}`,display:"flex",flexDirection:"column",overflow:"hidden",transition:"height 0.2s ease",position:"relative"},children:[E.devPanelOpen&&n.jsxs(n.Fragment,{children:[n.jsxs("div",{style:{height:32,flexShrink:0,display:"flex",alignItems:"center",borderBottom:`1px solid ${t.headerBorder}`,padding:"0 8px",gap:2},children:[["logs","errors"].map(A=>n.jsx(xn,{label:A==="errors"?`Errors${s.length>0?` (${s.length})`:""}`:`Logs (${E.queryLog.length})`,active:E.devPanelTab===A,onClick:()=>R(A),t},A)),n.jsx("div",{style:{flex:1}}),n.jsx("button",{onClick:()=>e({type:"SET_CELLS",cells:E.cells}),title:"Clear logs",style:{background:"transparent",border:"none",cursor:"pointer",color:t.textMuted,fontSize:11,fontFamily:t.font,padding:"2px 6px",borderRadius:4},children:"Clear"})]}),n.jsxs("div",{style:{flex:1,overflow:"auto",padding:"4px 0"},children:[E.devPanelTab==="logs"&&(E.queryLog.length===0?n.jsx(wE,{t,message:"No queries executed yet."}):[...E.queryLog].reverse().map(A=>n.jsx(KE,{entry:A,t},A.id))),E.devPanelTab==="errors"&&(s.length===0?n.jsx(wE,{t,message:"No errors."}):[...s].reverse().map(A=>n.jsx(KE,{entry:A,t},A.id)))]})]}),n.jsxs("button",{onClick:()=>e({type:"TOGGLE_DEV_PANEL"}),onMouseEnter:()=>T(!0),onMouseLeave:()=>T(!1),title:E.devPanelOpen?"Close panel":"Open dev panel",style:{position:"absolute",bottom:E.devPanelOpen?4:-28,right:8,height:22,padding:"0 8px",borderRadius:"4px 4px 0 0",border:`1px solid ${t.headerBorder}`,borderBottom:E.devPanelOpen?`1px solid ${t.sidebarBg}`:void 0,background:r?t.btnHover:t.sidebarBg,color:t.textMuted,cursor:"pointer",fontSize:11,fontFamily:t.font,display:"flex",alignItems:"center",gap:4,transition:"background 0.15s, bottom 0.2s ease",zIndex:10},children:[n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 10 10",fill:"currentColor",children:n.jsx("path",{d:E.devPanelOpen?"M1 7l4-4 4 4":"M1 3l4 4 4-4",strokeWidth:"1.5",stroke:"currentColor",fill:"none"})}),"Dev"]})]})}function xn({label:E,active:e,onClick:t,t:r}){const[T,s]=l.useState(!1);return n.jsx("button",{onClick:t,onMouseEnter:()=>s(!0),onMouseLeave:()=>s(!1),style:{background:"transparent",border:"none",borderBottom:e?`2px solid ${r.accent}`:"2px solid transparent",cursor:"pointer",color:e?r.textPrimary:T?r.textSecondary:r.textMuted,fontSize:12,fontFamily:r.font,fontWeight:e?500:400,padding:"4px 8px",height:32,transition:"color 0.15s"},children:E})}function wE({t:E,message:e}){return n.jsx("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",height:"100%",color:E.textMuted,fontSize:12,fontFamily:E.font,fontStyle:"italic"},children:e})}function KE({entry:E,t:e}){return n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:12,padding:"3px 12px",fontSize:11,fontFamily:e.fontMono,color:E.error?e.error:e.textSecondary,borderLeft:E.error?`2px solid ${e.error}`:"2px solid transparent"},children:[n.jsx("span",{style:{color:e.textMuted,flexShrink:0},children:hn(E.ts)}),n.jsx("span",{style:{flexShrink:0,color:e.textPrimary,maxWidth:160,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:E.cellName}),E.error?n.jsx("span",{style:{color:e.error,flex:1,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:E.error}):n.jsxs(n.Fragment,{children:[n.jsxs("span",{style:{color:e.textMuted},children:[E.rows.toLocaleString()," rows"]}),n.jsx("span",{style:{color:e.textMuted},children:fn(E.time)})]})]})}function Gn({onOpenFile:E}){const{state:e,dispatch:t}=y(),r=G[e.themeMode],T=e.files.slice(0,3);return n.jsx("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",background:r.appBg,padding:40,overflow:"auto"},children:n.jsxs("div",{style:{maxWidth:720,width:"100%",display:"flex",flexDirection:"column",alignItems:"center",gap:48},children:[n.jsxs("div",{style:{textAlign:"center",display:"flex",flexDirection:"column",alignItems:"center",gap:16},children:[n.jsx("div",{style:{width:72,height:72,borderRadius:16,background:"linear-gradient(135deg, #388bfd 0%, #1f6feb 60%, #0d419d 100%)",display:"flex",alignItems:"center",justifyContent:"center",boxShadow:"0 8px 32px rgba(56,139,253,0.3)"},children:n.jsx("span",{style:{color:"#fff",fontSize:26,fontWeight:800,fontFamily:r.fontMono,letterSpacing:"-1px"},children:"DQL"})}),n.jsxs("div",{children:[n.jsx("h1",{style:{fontSize:32,fontWeight:700,color:r.textPrimary,fontFamily:r.font,marginBottom:8,letterSpacing:"-0.5px"},children:"DQL Notebook"}),n.jsx("p",{style:{fontSize:15,color:r.textSecondary,fontFamily:r.font,letterSpacing:"0.02em"},children:"Analytics as Code"})]})]}),n.jsxs("div",{style:{display:"grid",gridTemplateColumns:"repeat(3, 1fr)",gap:16,width:"100%"},children:[n.jsx($E,{title:"New Notebook",description:"Start a fresh analysis with an empty notebook.",icon:n.jsx(gn,{}),accent:r.accent,onClick:()=>t({type:"OPEN_NEW_NOTEBOOK_MODAL"}),t:r}),n.jsx(yn,{recentFiles:T,onOpenFile:E,t:r}),n.jsx($E,{title:"Browse Examples",description:"Explore sample notebooks and DQL workbooks.",icon:n.jsx(Fn,{}),accent:r.success,onClick:()=>{const s=e.files.find(R=>R.folder.toLowerCase()==="notebooks");s&&E(s)},t:r})]}),n.jsxs("div",{style:{width:"100%",borderRadius:10,border:`1px solid ${r.cellBorder}`,padding:"16px 20px",background:r.cellBg},children:[n.jsx("div",{style:{fontSize:11,fontWeight:600,letterSpacing:"0.08em",textTransform:"uppercase",color:r.textMuted,fontFamily:r.font,marginBottom:12},children:"Quick Tips"}),n.jsx("div",{style:{display:"grid",gridTemplateColumns:"repeat(2, 1fr)",gap:8},children:[["Shift + Enter","Run cell"],["Click +","Add a new cell"],["Double-click MD cell","Edit markdown"],["Header title","Click to rename notebook"]].map(([s,R])=>n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8},children:[n.jsx("kbd",{style:{background:r.pillBg,border:`1px solid ${r.cellBorder}`,borderRadius:4,padding:"2px 6px",fontSize:11,fontFamily:r.fontMono,color:r.textSecondary,whiteSpace:"nowrap"},children:s}),n.jsx("span",{style:{fontSize:12,color:r.textMuted,fontFamily:r.font},children:R})]},s))})]})]})})}function $E({title:E,description:e,icon:t,accent:r,onClick:T,t:s}){const[R,A]=l.useState(!1);return n.jsxs("button",{onClick:T,onMouseEnter:()=>A(!0),onMouseLeave:()=>A(!1),style:{background:R?s.cellBg:"transparent",border:`1px solid ${R?r:s.cellBorder}`,borderRadius:10,padding:"20px 16px",cursor:"pointer",textAlign:"left",display:"flex",flexDirection:"column",gap:10,transition:"border-color 0.2s, background 0.2s, box-shadow 0.2s",boxShadow:R?`0 0 0 1px ${r}30, 0 4px 16px rgba(0,0,0,0.15)`:"none"},children:[n.jsx("div",{style:{width:36,height:36,borderRadius:8,background:`${r}18`,display:"flex",alignItems:"center",justifyContent:"center",color:r},children:t}),n.jsxs("div",{children:[n.jsx("div",{style:{fontSize:13,fontWeight:600,color:s.textPrimary,fontFamily:s.font,marginBottom:4},children:E}),n.jsx("div",{style:{fontSize:12,color:s.textSecondary,fontFamily:s.font,lineHeight:1.5},children:e})]})]})}function yn({recentFiles:E,onOpenFile:e,t}){const[r,T]=l.useState(!1);return n.jsxs("div",{onMouseEnter:()=>T(!0),onMouseLeave:()=>T(!1),style:{background:r?t.cellBg:"transparent",border:`1px solid ${r?t.textMuted:t.cellBorder}`,borderRadius:10,padding:"20px 16px",textAlign:"left",display:"flex",flexDirection:"column",gap:10,transition:"border-color 0.2s, background 0.2s"},children:[n.jsx("div",{style:{width:36,height:36,borderRadius:8,background:`${t.warning}18`,display:"flex",alignItems:"center",justifyContent:"center",color:t.warning},children:n.jsx(Hn,{})}),n.jsxs("div",{children:[n.jsx("div",{style:{fontSize:13,fontWeight:600,color:t.textPrimary,fontFamily:t.font,marginBottom:8},children:"Open Recent"}),E.length===0?n.jsx("div",{style:{fontSize:12,color:t.textMuted,fontFamily:t.font,fontStyle:"italic"},children:"No recent files."}):n.jsx("div",{style:{display:"flex",flexDirection:"column",gap:4},children:E.map(s=>n.jsx(Bn,{file:s,onClick:()=>e(s),t},s.path))})]})]})}function Bn({file:E,onClick:e,t}){const[r,T]=l.useState(!1);return n.jsx("button",{onClick:e,onMouseEnter:()=>T(!0),onMouseLeave:()=>T(!1),style:{background:"transparent",border:"none",cursor:"pointer",color:r?t.accent:t.textSecondary,fontSize:12,fontFamily:t.font,textAlign:"left",padding:"2px 0",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",transition:"color 0.15s"},children:E.name.replace(/\.(dqlnb|dql)$/,"")})}function gn(){return n.jsx("svg",{width:"18",height:"18",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M2 1.75C2 .784 2.784 0 3.75 0h6.586c.464 0 .909.184 1.237.513l2.914 2.914c.329.328.513.773.513 1.237v9.586A1.75 1.75 0 0 1 13.25 16h-9.5A1.75 1.75 0 0 1 2 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h9.5a.25.25 0 0 0 .25-.25V6h-2.75A1.75 1.75 0 0 1 8.75 4.25V1.5ZM8.75 5.5h2.836L10.25 3.664V4.25c0 .138.112.25.25.25H8.75Zm.5 3.25a.75.75 0 0 1 .75.75v.75h.75a.75.75 0 0 1 0 1.5H10v.75a.75.75 0 0 1-1.5 0V11.5H7.75a.75.75 0 0 1 0-1.5H8.5V9.5a.75.75 0 0 1 .75-.75Z"})})}function Hn(){return n.jsx("svg",{width:"18",height:"18",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm7-3.25v2.992l2.028.812a.75.75 0 0 1-.557 1.392l-2.5-1A.751.751 0 0 1 7 8.25v-3.5a.75.75 0 0 1 1.5 0Z"})})}function Fn(){return n.jsx("svg",{width:"18",height:"18",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M.24 2.375C.24 1.064 1.225.001 2.409.001h6.451a1.17 1.17 0 0 1 .828.344l3.311 3.312a1.17 1.17 0 0 1 .344.828v9.14c0 1.31-.985 2.374-2.169 2.374H2.41C1.225 16 .24 14.937.24 13.625ZM2.41 1.376a.846.846 0 0 0-.844.86v11.39c0 .47.38.86.844.86h8.774a.847.847 0 0 0 .844-.86V5.157L8.688 1.373H2.41Z"})})}const kE=typeof String.prototype.normalize=="function"?E=>E.normalize("NFKD"):E=>E;class De{constructor(e,t,r=0,T=e.length,s,R){this.test=R,this.value={from:0,to:0},this.done=!1,this.matches=[],this.buffer="",this.bufferPos=0,this.iter=e.iterRange(r,T),this.bufferStart=r,this.normalize=s?A=>s(kE(A)):kE,this.query=this.normalize(t)}peek(){if(this.bufferPos==this.buffer.length){if(this.bufferStart+=this.buffer.length,this.iter.next(),this.iter.done)return-1;this.bufferPos=0,this.buffer=this.iter.value}return _T(this.buffer,this.bufferPos)}next(){for(;this.matches.length;)this.matches.pop();return this.nextOverlapping()}nextOverlapping(){for(;;){let e=this.peek();if(e<0)return this.done=!0,this;let t=MT(e),r=this.bufferStart+this.bufferPos;this.bufferPos+=dT(e);let T=this.normalize(t);if(T.length)for(let s=0,R=r;;s++){let A=T.charCodeAt(s),a=this.match(A,R,this.bufferPos+this.bufferStart);if(s==T.length-1){if(a)return this.value=a,this;break}R==r&&s<t.length&&t.charCodeAt(s)==A&&R++}}}match(e,t,r){let T=null;for(let s=0;s<this.matches.length;s+=2){let R=this.matches[s],A=!1;this.query.charCodeAt(R)==e&&(R==this.query.length-1?T={from:this.matches[s+1],to:r}:(this.matches[s]++,A=!0)),A||(this.matches.splice(s,2),s-=2)}return this.query.charCodeAt(0)==e&&(this.query.length==1?T={from:t,to:r}:this.matches.push(1,t)),T&&this.test&&!this.test(T.from,T.to,this.buffer,this.bufferStart)&&(T=null),T}}typeof Symbol<"u"&&(De.prototype[Symbol.iterator]=function(){return this});const Vt={from:-1,to:-1,match:/.*/.exec("")},fE="gm"+(/x/.unicode==null?"":"u");class Wt{constructor(e,t,r,T=0,s=e.length){if(this.text=e,this.to=s,this.curLine="",this.done=!1,this.value=Vt,/\\[sWDnr]|\n|\r|\[\^/.test(t))return new Xt(e,t,r,T,s);this.re=new RegExp(t,fE+(r!=null&&r.ignoreCase?"i":"")),this.test=r==null?void 0:r.test,this.iter=e.iter();let R=e.lineAt(T);this.curLineStart=R.from,this.matchPos=ge(e,T),this.getLine(this.curLineStart)}getLine(e){this.iter.next(e),this.iter.lineBreak?this.curLine="":(this.curLine=this.iter.value,this.curLineStart+this.curLine.length>this.to&&(this.curLine=this.curLine.slice(0,this.to-this.curLineStart)),this.iter.next())}nextLine(){this.curLineStart=this.curLineStart+this.curLine.length+1,this.curLineStart>this.to?this.curLine="":this.getLine(0)}next(){for(let e=this.matchPos-this.curLineStart;;){this.re.lastIndex=e;let t=this.matchPos<=this.to&&this.re.exec(this.curLine);if(t){let r=this.curLineStart+t.index,T=r+t[0].length;if(this.matchPos=ge(this.text,T+(r==T?1:0)),r==this.curLineStart+this.curLine.length&&this.nextLine(),(r<T||r>this.value.to)&&(!this.test||this.test(r,T,t)))return this.value={from:r,to:T,match:t},this;e=this.matchPos-this.curLineStart}else if(this.curLineStart+this.curLine.length<this.to)this.nextLine(),e=0;else return this.done=!0,this}}}const Ke=new WeakMap;class le{constructor(e,t){this.from=e,this.text=t}get to(){return this.from+this.text.length}static get(e,t,r){let T=Ke.get(e);if(!T||T.from>=r||T.to<=t){let A=new le(t,e.sliceString(t,r));return Ke.set(e,A),A}if(T.from==t&&T.to==r)return T;let{text:s,from:R}=T;return R>t&&(s=e.sliceString(t,R)+s,R=t),T.to<r&&(s+=e.sliceString(T.to,r)),Ke.set(e,new le(R,s)),new le(t,s.slice(t-R,r-R))}}class Xt{constructor(e,t,r,T,s){this.text=e,this.to=s,this.done=!1,this.value=Vt,this.matchPos=ge(e,T),this.re=new RegExp(t,fE+(r!=null&&r.ignoreCase?"i":"")),this.test=r==null?void 0:r.test,this.flat=le.get(e,T,this.chunkEnd(T+5e3))}chunkEnd(e){return e>=this.to?this.to:this.text.lineAt(e).to}next(){for(;;){let e=this.re.lastIndex=this.matchPos-this.flat.from,t=this.re.exec(this.flat.text);if(t&&!t[0]&&t.index==e&&(this.re.lastIndex=e+1,t=this.re.exec(this.flat.text)),t){let r=this.flat.from+t.index,T=r+t[0].length;if((this.flat.to>=this.to||t.index+t[0].length<=this.flat.text.length-10)&&(!this.test||this.test(r,T,t)))return this.value={from:r,to:T,match:t},this.matchPos=ge(this.text,T+(r==T?1:0)),this}if(this.flat.to==this.to)return this.done=!0,this;this.flat=le.get(this.text,this.flat.from,this.chunkEnd(this.flat.from+this.flat.text.length*2))}}}typeof Symbol<"u"&&(Wt.prototype[Symbol.iterator]=Xt.prototype[Symbol.iterator]=function(){return this});function bn(E){try{return new RegExp(E,fE),!0}catch{return!1}}function ge(E,e){if(e>=E.length)return e;let t=E.lineAt(e),r;for(;e<t.to&&(r=t.text.charCodeAt(e-t.from))>=56320&&r<57344;)e++;return e}const Yn=E=>{let{state:e}=E,t=String(e.doc.lineAt(E.state.selection.main.head).number),{close:r,result:T}=lT(E,{label:e.phrase("Go to line"),input:{type:"text",name:"line",value:t},focus:!0,submitLabel:e.phrase("go")});return T.then(s=>{let R=s&&/^([+-])?(\d+)?(:\d+)?(%)?$/.exec(s.elements.line.value);if(!R){E.dispatch({effects:r});return}let A=e.doc.lineAt(e.selection.main.head),[,a,o,S,i]=R,I=S?+S.slice(1):0,O=o?+o:A.number;if(o&&i){let d=O/100;a&&(d=d*(a=="-"?-1:1)+A.number/e.doc.lines),O=Math.round(e.doc.lines*d)}else o&&a&&(O=O*(a=="-"?-1:1)+A.number);let c=e.doc.line(Math.max(1,Math.min(e.doc.lines,O))),_=Q.cursor(c.from+Math.max(0,Math.min(I,c.length)));E.dispatch({effects:[r,w.scrollIntoView(_.from,{y:"center"})],selection:_})}),!0},vn=({state:E,dispatch:e})=>{let{selection:t}=E,r=Q.create(t.ranges.map(T=>E.wordAt(T.head)||Q.cursor(T.head)),t.mainIndex);return r.eq(t)?!1:(e(E.update({selection:r})),!0)};function Vn(E,e){let{main:t,ranges:r}=E.selection,T=E.wordAt(t.head),s=T&&T.from==t.from&&T.to==t.to;for(let R=!1,A=new De(E.doc,e,r[r.length-1].to);;)if(A.next(),A.done){if(R)return null;A=new De(E.doc,e,0,Math.max(0,r[r.length-1].from-1)),R=!0}else{if(R&&r.some(a=>a.from==A.value.from))continue;if(s){let a=E.wordAt(A.value.from);if(!a||a.from!=A.value.from||a.to!=A.value.to)continue}return A.value}}const Wn=({state:E,dispatch:e})=>{let{ranges:t}=E.selection;if(t.some(s=>s.from===s.to))return vn({state:E,dispatch:e});let r=E.sliceDoc(t[0].from,t[0].to);if(E.selection.ranges.some(s=>E.sliceDoc(s.from,s.to)!=r))return!1;let T=Vn(E,r);return T?(e(E.update({selection:E.selection.addRange(Q.range(T.from,T.to),!1),effects:w.scrollIntoView(T.to)})),!0):!1},Se=DT.define({combine(E){return uT(E,{top:!1,caseSensitive:!1,literal:!1,regexp:!1,wholeWord:!1,createPanel:e=>new Ts(e),scrollToMatch:e=>w.scrollIntoView(e)})}});function Xn(E){return E?[Se.of(E),dE]:dE}class wt{constructor(e){this.search=e.search,this.caseSensitive=!!e.caseSensitive,this.literal=!!e.literal,this.regexp=!!e.regexp,this.replace=e.replace||"",this.valid=!!this.search&&(!this.regexp||bn(this.search)),this.unquoted=this.unquote(this.search),this.wholeWord=!!e.wholeWord,this.test=e.test}unquote(e){return this.literal?e:e.replace(/\\([nrt\\])/g,(t,r)=>r=="n"?`
|
|
319
|
+
`:r=="r"?"\r":r=="t"?" ":"\\")}eq(e){return this.search==e.search&&this.replace==e.replace&&this.caseSensitive==e.caseSensitive&&this.regexp==e.regexp&&this.wholeWord==e.wholeWord&&this.test==e.test}create(){return this.regexp?new Jn(this):new $n(this)}getCursor(e,t=0,r){let T=e.doc?e:gt.create({doc:e});return r==null&&(r=T.doc.length),this.regexp?Ne(this,T,t,r):Oe(this,T,t,r)}}class Kt{constructor(e){this.spec=e}}function wn(E,e,t){return(r,T,s,R)=>{if(t&&!t(r,T,s,R))return!1;let A=r>=R&&T<=R+s.length?s.slice(r-R,T-R):e.doc.sliceString(r,T);return E(A,e,r,T)}}function Oe(E,e,t,r){let T;return E.wholeWord&&(T=Kn(e.doc,e.charCategorizer(e.selection.main.head))),E.test&&(T=wn(E.test,e,T)),new De(e.doc,E.unquoted,t,r,E.caseSensitive?void 0:s=>s.toLowerCase(),T)}function Kn(E,e){return(t,r,T,s)=>((s>t||s+T.length<r)&&(s=Math.max(0,t-2),T=E.sliceString(s,Math.min(E.length,r+2))),(e(He(T,t-s))!=Te.Word||e(Fe(T,t-s))!=Te.Word)&&(e(Fe(T,r-s))!=Te.Word||e(He(T,r-s))!=Te.Word))}class $n extends Kt{constructor(e){super(e)}nextMatch(e,t,r){let T=Oe(this.spec,e,r,e.doc.length).nextOverlapping();if(T.done){let s=Math.min(e.doc.length,t+this.spec.unquoted.length);T=Oe(this.spec,e,0,s).nextOverlapping()}return T.done||T.value.from==t&&T.value.to==r?null:T.value}prevMatchInRange(e,t,r){for(let T=r;;){let s=Math.max(t,T-1e4-this.spec.unquoted.length),R=Oe(this.spec,e,s,T),A=null;for(;!R.nextOverlapping().done;)A=R.value;if(A)return A;if(s==t)return null;T-=1e4}}prevMatch(e,t,r){let T=this.prevMatchInRange(e,0,t);return T||(T=this.prevMatchInRange(e,Math.max(0,r-this.spec.unquoted.length),e.doc.length)),T&&(T.from!=t||T.to!=r)?T:null}getReplacement(e){return this.spec.unquote(this.spec.replace)}matchAll(e,t){let r=Oe(this.spec,e,0,e.doc.length),T=[];for(;!r.next().done;){if(T.length>=t)return null;T.push(r.value)}return T}highlight(e,t,r,T){let s=Oe(this.spec,e,Math.max(0,t-this.spec.unquoted.length),Math.min(r+this.spec.unquoted.length,e.doc.length));for(;!s.next().done;)T(s.value.from,s.value.to)}}function kn(E,e,t){return(r,T,s)=>(!t||t(r,T,s))&&E(s[0],e,r,T)}function Ne(E,e,t,r){let T;return E.wholeWord&&(T=jn(e.charCategorizer(e.selection.main.head))),E.test&&(T=kn(E.test,e,T)),new Wt(e.doc,E.search,{ignoreCase:!E.caseSensitive,test:T},t,r)}function He(E,e){return E.slice(Ht(E,e,!1),e)}function Fe(E,e){return E.slice(e,Ht(E,e))}function jn(E){return(e,t,r)=>!r[0].length||(E(He(r.input,r.index))!=Te.Word||E(Fe(r.input,r.index))!=Te.Word)&&(E(Fe(r.input,r.index+r[0].length))!=Te.Word||E(He(r.input,r.index+r[0].length))!=Te.Word)}class Jn extends Kt{nextMatch(e,t,r){let T=Ne(this.spec,e,r,e.doc.length).next();return T.done&&(T=Ne(this.spec,e,0,t).next()),T.done?null:T.value}prevMatchInRange(e,t,r){for(let T=1;;T++){let s=Math.max(t,r-T*1e4),R=Ne(this.spec,e,s,r),A=null;for(;!R.next().done;)A=R.value;if(A&&(s==t||A.from>s+10))return A;if(s==t)return null}}prevMatch(e,t,r){return this.prevMatchInRange(e,0,t)||this.prevMatchInRange(e,r,e.doc.length)}getReplacement(e){return this.spec.unquote(this.spec.replace).replace(/\$([$&]|\d+)/g,(t,r)=>{if(r=="&")return e.match[0];if(r=="$")return"$";for(let T=r.length;T>0;T--){let s=+r.slice(0,T);if(s>0&&s<e.match.length)return e.match[s]+r.slice(T)}return t})}matchAll(e,t){let r=Ne(this.spec,e,0,e.doc.length),T=[];for(;!r.next().done;){if(T.length>=t)return null;T.push(r.value)}return T}highlight(e,t,r,T){let s=Ne(this.spec,e,Math.max(0,t-250),Math.min(r+250,e.doc.length));for(;!s.next().done;)T(s.value.from,s.value.to)}}const ue=pE.define(),mE=pE.define(),re=LT.define({create(E){return new $e(_E(E).create(),null)},update(E,e){for(let t of e.effects)t.is(ue)?E=new $e(t.value.create(),E.panel):t.is(mE)&&(E=new $e(E.query,t.value?xE:null));return E},provide:E=>CT.from(E,e=>e.panel)});class $e{constructor(e,t){this.query=e,this.panel=t}}const Qn=ME.mark({class:"cm-searchMatch"}),Zn=ME.mark({class:"cm-searchMatch cm-searchMatch-selected"}),qn=PT.fromClass(class{constructor(E){this.view=E,this.decorations=this.highlight(E.state.field(re))}update(E){let e=E.state.field(re);(e!=E.startState.field(re)||E.docChanged||E.selectionSet||E.viewportChanged)&&(this.decorations=this.highlight(e))}highlight({query:E,panel:e}){if(!e||!E.spec.valid)return ME.none;let{view:t}=this,r=new pT;for(let T=0,s=t.visibleRanges,R=s.length;T<R;T++){let{from:A,to:a}=s[T];for(;T<R-1&&a>s[T+1].from-500;)a=s[++T].to;E.highlight(t.state,A,a,(o,S)=>{let i=t.state.selection.ranges.some(I=>I.from==o&&I.to==S);r.add(o,S,i?Zn:Qn)})}return r.finish()}},{decorations:E=>E.decorations});function pe(E){return e=>{let t=e.state.field(re,!1);return t&&t.query.spec.valid?E(e,t):jt(e)}}const be=pe((E,{query:e})=>{let{to:t}=E.state.selection.main,r=e.nextMatch(E.state,t,t);if(!r)return!1;let T=Q.single(r.from,r.to),s=E.state.facet(Se);return E.dispatch({selection:T,effects:[GE(E,r),s.scrollToMatch(T.main,E)],userEvent:"select.search"}),kt(E),!0}),Ye=pe((E,{query:e})=>{let{state:t}=E,{from:r}=t.selection.main,T=e.prevMatch(t,r,r);if(!T)return!1;let s=Q.single(T.from,T.to),R=E.state.facet(Se);return E.dispatch({selection:s,effects:[GE(E,T),R.scrollToMatch(s.main,E)],userEvent:"select.search"}),kt(E),!0}),zn=pe((E,{query:e})=>{let t=e.matchAll(E.state,1e3);return!t||!t.length?!1:(E.dispatch({selection:Q.create(t.map(r=>Q.range(r.from,r.to))),userEvent:"select.search.matches"}),!0)}),es=({state:E,dispatch:e})=>{let t=E.selection;if(t.ranges.length>1||t.main.empty)return!1;let{from:r,to:T}=t.main,s=[],R=0;for(let A=new De(E.doc,E.sliceDoc(r,T));!A.next().done;){if(s.length>1e3)return!1;A.value.from==r&&(R=s.length),s.push(Q.range(A.value.from,A.value.to))}return e(E.update({selection:Q.create(s,R),userEvent:"select.search.matches"})),!0},jE=pe((E,{query:e})=>{let{state:t}=E,{from:r,to:T}=t.selection.main;if(t.readOnly)return!1;let s=e.nextMatch(t,r,r);if(!s)return!1;let R=s,A=[],a,o,S=[];R.from==r&&R.to==T&&(o=t.toText(e.getReplacement(R)),A.push({from:R.from,to:R.to,insert:o}),R=e.nextMatch(t,R.from,R.to),S.push(w.announce.of(t.phrase("replaced match on line $",t.doc.lineAt(r).number)+".")));let i=E.state.changes(A);return R&&(a=Q.single(R.from,R.to).map(i),S.push(GE(E,R)),S.push(t.facet(Se).scrollToMatch(a.main,E))),E.dispatch({changes:i,selection:a,effects:S,userEvent:"input.replace"}),!0}),Es=pe((E,{query:e})=>{if(E.state.readOnly)return!1;let t=e.matchAll(E.state,1e9).map(T=>{let{from:s,to:R}=T;return{from:s,to:R,insert:e.getReplacement(T)}});if(!t.length)return!1;let r=E.state.phrase("replaced $ matches",t.length)+".";return E.dispatch({changes:t,effects:w.announce.of(r),userEvent:"input.replace.all"}),!0});function xE(E){return E.state.facet(Se).createPanel(E)}function _E(E,e){var t,r,T,s,R;let A=E.selection.main,a=A.empty||A.to>A.from+100?"":E.sliceDoc(A.from,A.to);if(e&&!a)return e;let o=E.facet(Se);return new wt({search:((t=e==null?void 0:e.literal)!==null&&t!==void 0?t:o.literal)?a:a.replace(/\n/g,"\\n"),caseSensitive:(r=e==null?void 0:e.caseSensitive)!==null&&r!==void 0?r:o.caseSensitive,literal:(T=e==null?void 0:e.literal)!==null&&T!==void 0?T:o.literal,regexp:(s=e==null?void 0:e.regexp)!==null&&s!==void 0?s:o.regexp,wholeWord:(R=e==null?void 0:e.wholeWord)!==null&&R!==void 0?R:o.wholeWord})}function $t(E){let e=Bt(E,xE);return e&&e.dom.querySelector("[main-field]")}function kt(E){let e=$t(E);e&&e==E.root.activeElement&&e.select()}const jt=E=>{let e=E.state.field(re,!1);if(e&&e.panel){let t=$t(E);if(t&&t!=E.root.activeElement){let r=_E(E.state,e.query.spec);r.valid&&E.dispatch({effects:ue.of(r)}),t.focus(),t.select()}}else E.dispatch({effects:[mE.of(!0),e?ue.of(_E(E.state,e.query.spec)):pE.appendConfig.of(dE)]});return!0},Jt=E=>{let e=E.state.field(re,!1);if(!e||!e.panel)return!1;let t=Bt(E,xE);return t&&t.dom.contains(E.root.activeElement)&&E.focus(),E.dispatch({effects:mE.of(!1)}),!0},ts=[{key:"Mod-f",run:jt,scope:"editor search-panel"},{key:"F3",run:be,shift:Ye,scope:"editor search-panel",preventDefault:!0},{key:"Mod-g",run:be,shift:Ye,scope:"editor search-panel",preventDefault:!0},{key:"Escape",run:Jt,scope:"editor search-panel"},{key:"Mod-Shift-l",run:es},{key:"Mod-Alt-g",run:Yn},{key:"Mod-d",run:Wn,preventDefault:!0}];class Ts{constructor(e){this.view=e;let t=this.query=e.state.field(re).query.spec;this.commit=this.commit.bind(this),this.searchField=K("input",{value:t.search,placeholder:X(e,"Find"),"aria-label":X(e,"Find"),class:"cm-textfield",name:"search",form:"","main-field":"true",onchange:this.commit,onkeyup:this.commit}),this.replaceField=K("input",{value:t.replace,placeholder:X(e,"Replace"),"aria-label":X(e,"Replace"),class:"cm-textfield",name:"replace",form:"",onchange:this.commit,onkeyup:this.commit}),this.caseField=K("input",{type:"checkbox",name:"case",form:"",checked:t.caseSensitive,onchange:this.commit}),this.reField=K("input",{type:"checkbox",name:"re",form:"",checked:t.regexp,onchange:this.commit}),this.wordField=K("input",{type:"checkbox",name:"word",form:"",checked:t.wholeWord,onchange:this.commit});function r(T,s,R){return K("button",{class:"cm-button",name:T,onclick:s,type:"button"},R)}this.dom=K("div",{onkeydown:T=>this.keydown(T),class:"cm-search"},[this.searchField,r("next",()=>be(e),[X(e,"next")]),r("prev",()=>Ye(e),[X(e,"previous")]),r("select",()=>zn(e),[X(e,"all")]),K("label",null,[this.caseField,X(e,"match case")]),K("label",null,[this.reField,X(e,"regexp")]),K("label",null,[this.wordField,X(e,"by word")]),...e.state.readOnly?[]:[K("br"),this.replaceField,r("replace",()=>jE(e),[X(e,"replace")]),r("replaceAll",()=>Es(e),[X(e,"replace all")])],K("button",{name:"close",onclick:()=>Jt(e),"aria-label":X(e,"close"),type:"button"},["×"])])}commit(){let e=new wt({search:this.searchField.value,caseSensitive:this.caseField.checked,regexp:this.reField.checked,wholeWord:this.wordField.checked,replace:this.replaceField.value});e.eq(this.query)||(this.query=e,this.view.dispatch({effects:ue.of(e)}))}keydown(e){UT(this.view,e,"search-panel")?e.preventDefault():e.keyCode==13&&e.target==this.searchField?(e.preventDefault(),(e.shiftKey?Ye:be)(this.view)):e.keyCode==13&&e.target==this.replaceField&&(e.preventDefault(),jE(this.view))}update(e){for(let t of e.transactions)for(let r of t.effects)r.is(ue)&&!r.value.eq(this.query)&&this.setQuery(r.value)}setQuery(e){this.query=e,this.searchField.value=e.search,this.replaceField.value=e.replace,this.caseField.checked=e.caseSensitive,this.reField.checked=e.regexp,this.wordField.checked=e.wholeWord}mount(){this.searchField.select()}get pos(){return 80}get top(){return this.view.state.facet(Se).top}}function X(E,e){return E.state.phrase(e)}const he=30,fe=/[\s\.,:;?!]/;function GE(E,{from:e,to:t}){let r=E.state.doc.lineAt(e),T=E.state.doc.lineAt(t).to,s=Math.max(r.from,e-he),R=Math.min(T,t+he),A=E.state.sliceDoc(s,R);if(s!=r.from){for(let a=0;a<he;a++)if(!fe.test(A[a+1])&&fe.test(A[a])){A=A.slice(a);break}}if(R!=T){for(let a=A.length-1;a>A.length-he;a--)if(!fe.test(A[a-1])&&fe.test(A[a])){A=A.slice(0,a);break}}return w.announce.of(`${E.state.phrase("current match")}. ${A} ${E.state.phrase("on line")} ${r.number}.`)}const rs=w.baseTheme({".cm-panel.cm-search":{padding:"2px 6px 4px",position:"relative","& [name=close]":{position:"absolute",top:"0",right:"4px",backgroundColor:"inherit",border:"none",font:"inherit",padding:0,margin:0},"& input, & button, & label":{margin:".2em .6em .2em 0"},"& input[type=checkbox]":{marginRight:".2em"},"& label":{fontSize:"80%",whiteSpace:"pre"}},"&light .cm-searchMatch":{backgroundColor:"#ffff0054"},"&dark .cm-searchMatch":{backgroundColor:"#00ffff8a"},"&light .cm-searchMatch-selected":{backgroundColor:"#ff6a0054"},"&dark .cm-searchMatch-selected":{backgroundColor:"#ff00ff8a"}}),dE=[re,cT.low(qn),rs],ns=w.theme({"&":{background:"#f6f8fa",color:"#1f2328"},".cm-content":{caretColor:"#1f2328"},".cm-cursor":{borderLeftColor:"#1f2328"},".cm-selectionBackground":{background:"#b3d4fc"},"&.cm-focused .cm-selectionBackground":{background:"#b3d4fc"},".cm-gutters":{background:"#f0f2f5",color:"#8c959f",border:"none",borderRight:"1px solid #d0d7de"},".cm-activeLineGutter":{background:"#e8f0fe"},".cm-activeLine":{background:"#eaf0fb"},".cm-matchingBracket":{background:"#c8e6c9",outline:"1px solid #66bb6a"},".cm-foldPlaceholder":{background:"#eaeef2",border:"1px solid #d0d7de",color:"#57606a",borderRadius:3,padding:"0 4px"},".cm-tooltip":{background:"#ffffff",border:"1px solid #d0d7de",borderRadius:6,boxShadow:"0 4px 12px rgba(0,0,0,0.12)"},".cm-tooltip.cm-tooltip-autocomplete":{"& > ul > li":{padding:"3px 8px"},"& > ul > li[aria-selected]":{background:"#dbeafe",color:"#0550ae"}},".cm-searchMatch":{background:"#fff3b0",outline:"1px solid #f5c518"},".cm-searchMatch.cm-searchMatch-selected":{background:"#f5c518"},".cm-panels":{background:"#f0f2f5",borderTop:"1px solid #d0d7de"},".cm-panel":{padding:"6px 8px"},".cm-panel input":{background:"#fff",border:"1px solid #d0d7de",borderRadius:4,padding:"2px 6px",fontSize:12},".cm-panel button":{background:"#f6f8fa",border:"1px solid #d0d7de",borderRadius:4,padding:"2px 8px",cursor:"pointer",fontSize:12,marginLeft:4}},{dark:!1}),ss=w.theme({".cm-panels":{background:"#161b22",borderTop:"1px solid #30363d"},".cm-panel input":{background:"#0d1117",border:"1px solid #30363d",color:"#e6edf3",borderRadius:4,padding:"2px 6px",fontSize:12},".cm-panel button":{background:"#21262d",border:"1px solid #30363d",color:"#e6edf3",borderRadius:4,padding:"2px 8px",cursor:"pointer",fontSize:12,marginLeft:4},".cm-tooltip":{background:"#1c2128",border:"1px solid #30363d",borderRadius:6,boxShadow:"0 4px 12px rgba(0,0,0,0.4)"},".cm-tooltip.cm-tooltip-autocomplete":{"& > ul > li[aria-selected]":{background:"#1f3858",color:"#58a6ff"}},".cm-matchingBracket":{background:"#1f3858",outline:"1px solid #388bfd"},".cm-searchMatch":{background:"#3d3000",outline:"1px solid #e3b341"},".cm-searchMatch.cm-searchMatch-selected":{background:"#6a4e00"}},{dark:!0});function Qt({value:E,onChange:e,onRun:t,themeMode:r,autoFocus:T,schema:s}){const R=G[r],A=l.useRef(null),a=l.useRef(null),o=l.useRef(t),S=l.useRef(e),i=l.useRef(new hT);return o.current=t,S.current=e,l.useEffect(()=>{if(!A.current)return;const I=fT.of([{key:"Shift-Enter",run:()=>(o.current(),!0)},{key:"Ctrl-Enter",mac:"Cmd-Enter",run:()=>(o.current(),!0)},{key:"Ctrl-/",mac:"Cmd-/",run:mT},xT,...GT,...yT,...BT,...ts,...gT,...HT]),O=w.updateListener.of(f=>{f.docChanged&&S.current(f.state.doc.toString())}),c=w.theme({"&":{background:R.editorBg,fontFamily:R.fontMono,fontSize:"13px",minHeight:"80px",maxHeight:"480px"},".cm-scroller":{overflow:"auto",fontFamily:"inherit"},".cm-content":{padding:"10px 0",minHeight:"80px"},".cm-focused":{outline:"none"},".cm-editor":{border:"none"},".cm-gutters":{minWidth:40},".cm-foldGutter":{cursor:"pointer"}}),_=s?Me({schema:s,upperCaseKeywords:!1}):Me({upperCaseKeywords:!1}),d=[I,O,c,i.current.of(_),bT({closeOnBlur:!1}),YT(),vT(),VT(),WT(),XT(),wT(),KT(),w.lineWrapping,Xn({top:!0}),...r==="dark"?[FT,ss]:[ns,$T(kT)]],u=gt.create({doc:E,extensions:d}),D=new w({state:u,parent:A.current});return a.current=D,T&&D.focus(),()=>{D.destroy(),a.current=null}},[r]),l.useEffect(()=>{const I=a.current;if(!I)return;const O=s?Me({schema:s,upperCaseKeywords:!1}):Me({upperCaseKeywords:!1});I.dispatch({effects:i.current.reconfigure(O)})},[s]),l.useEffect(()=>{const I=a.current;if(!I)return;const O=I.state.doc.toString();O!==E&&I.dispatch({changes:{from:0,to:O.length,insert:E}})},[E]),n.jsx("div",{ref:A,style:{background:R.editorBg,minHeight:80}})}Qt.displayName="SQLCellEditor";function Rs(E,e){const t=E.split(`
|
|
320
|
+
`),r=[];let T=0;for(;T<t.length;){const s=t[T],R=s.match(/^(#{1,6})\s+(.+)$/);if(R){const A=R[1].length,a=R[2],S=[28,22,18,16,14,13][A-1];r.push(n.jsx("div",{style:{fontSize:S,fontWeight:A<=2?700:600,color:e.textPrimary,fontFamily:e.font,lineHeight:1.3,marginBottom:A===1?12:8,marginTop:T>0?A===1?16:10:0,borderBottom:A===1?`1px solid ${e.cellBorder}`:void 0,paddingBottom:A===1?8:void 0},children:ce(a,e)},T)),T++;continue}if(/^[-*_]{3,}$/.test(s.trim())){r.push(n.jsx("hr",{style:{border:"none",borderTop:`1px solid ${e.cellBorder}`,margin:"12px 0"}},T)),T++;continue}if(s.startsWith("> ")){r.push(n.jsx("div",{style:{borderLeft:`3px solid ${e.textMuted}`,paddingLeft:12,marginLeft:4,color:e.textSecondary,fontStyle:"italic",fontFamily:e.fontSerif,fontSize:14},children:ce(s.slice(2),e)},T)),T++;continue}if(s.startsWith("```")){const A=[];for(T++;T<t.length&&!t[T].startsWith("```");)A.push(t[T]),T++;r.push(n.jsx("pre",{style:{background:e.editorBg,border:`1px solid ${e.cellBorder}`,borderRadius:6,padding:"10px 12px",fontSize:12,fontFamily:e.fontMono,color:e.textPrimary,overflow:"auto",margin:"8px 0",lineHeight:1.6},children:A.join(`
|
|
321
|
+
`)},T)),T++;continue}if(/^[-*+]\s/.test(s)){const A=[];for(;T<t.length&&/^[-*+]\s/.test(t[T]);)A.push(t[T].replace(/^[-*+]\s/,"")),T++;r.push(n.jsx("ul",{style:{paddingLeft:20,marginBottom:8,color:e.textSecondary},children:A.map((a,o)=>n.jsx("li",{style:{fontSize:14,fontFamily:e.font,lineHeight:1.6,marginBottom:2},children:ce(a,e)},o))},T));continue}if(/^\d+\.\s/.test(s)){const A=[];for(;T<t.length&&/^\d+\.\s/.test(t[T]);)A.push(t[T].replace(/^\d+\.\s/,"")),T++;r.push(n.jsx("ol",{style:{paddingLeft:20,marginBottom:8,color:e.textSecondary},children:A.map((a,o)=>n.jsx("li",{style:{fontSize:14,fontFamily:e.font,lineHeight:1.6,marginBottom:2},children:ce(a,e)},o))},T));continue}if(!s.trim()){r.push(n.jsx("div",{style:{height:8}},T)),T++;continue}r.push(n.jsx("p",{style:{fontSize:14,lineHeight:1.7,fontFamily:e.fontSerif,color:e.textSecondary,marginBottom:6},children:ce(s,e)},T)),T++}return r}function ce(E,e){const t=[];let r=E,T=0;for(;r.length>0;){const s=r.match(/\*{3}(.+?)\*{3}/),R=r.match(/\*{2}(.+?)\*{2}/),A=r.match(/\*(.+?)\*/),a=r.match(/`(.+?)`/),o=r.match(/\[(.+?)\]\((.+?)\)/),S=[s?{match:s,type:"boldItalic"}:null,R?{match:R,type:"bold"}:null,A?{match:A,type:"italic"}:null,a?{match:a,type:"code"}:null,o?{match:o,type:"link"}:null].filter(Boolean);if(S.length===0){t.push(n.jsx(Be.Fragment,{children:r},T++));break}const i=S.reduce((O,c)=>(O.match.index??0)<(c.match.index??0)?O:c),I=i.match.index??0;switch(I>0&&t.push(n.jsx(Be.Fragment,{children:r.slice(0,I)},T++)),i.type){case"boldItalic":t.push(n.jsx("strong",{style:{fontStyle:"italic"},children:i.match[1]},T++));break;case"bold":t.push(n.jsx("strong",{children:i.match[1]},T++));break;case"italic":t.push(n.jsx("em",{children:i.match[1]},T++));break;case"code":t.push(n.jsx("code",{style:{background:e.editorBg,border:`1px solid ${e.cellBorder}`,borderRadius:4,padding:"1px 5px",fontSize:"0.9em",fontFamily:e.fontMono,color:e.accent},children:i.match[1]},T++));break;case"link":t.push(n.jsx("a",{href:i.match[2],target:"_blank",rel:"noopener noreferrer",style:{color:e.accent,textDecoration:"underline"},children:i.match[1]},T++));break}r=r.slice(I+i.match[0].length)}return n.jsx(n.Fragment,{children:t})}function As({value:E,onChange:e,onRun:t,themeMode:r}){const T=G[r],[s,R]=l.useState(!1),A=l.useRef(null);l.useEffect(()=>{if(s&&A.current){A.current.focus();const i=A.current;i.style.height="auto",i.style.height=`${Math.max(i.scrollHeight,80)}px`}},[s]);const a=()=>{R(!1)},o=i=>{if(i.key==="Escape"&&R(!1),i.key==="Enter"&&i.shiftKey&&(i.preventDefault(),R(!1),t==null||t()),i.key==="Tab"){i.preventDefault();const I=i.currentTarget,O=I.selectionStart,c=I.selectionEnd,_=E.slice(0,O)+" "+E.slice(c);e(_),requestAnimationFrame(()=>{I.selectionStart=I.selectionEnd=O+2})}},S=i=>{e(i.target.value);const I=i.target;I.style.height="auto",I.style.height=`${Math.max(I.scrollHeight,80)}px`};return s?n.jsx("textarea",{ref:A,value:E,onChange:S,onBlur:a,onKeyDown:o,placeholder:"Write markdown here...",spellCheck:!1,style:{display:"block",width:"100%",minHeight:80,padding:"12px 16px",background:T.editorBg,color:T.textPrimary,border:"none",outline:"none",resize:"none",fontFamily:T.fontMono,fontSize:13,lineHeight:"20px",borderRadius:0,caretColor:T.accent}}):E.trim()?n.jsx("div",{onDoubleClick:()=>R(!0),title:"Double-click to edit",style:{padding:"12px 16px",cursor:"text",minHeight:48},children:Rs(E,T)}):n.jsx("div",{onDoubleClick:()=>R(!0),style:{padding:"12px 16px",color:T.textMuted,fontFamily:T.font,fontSize:13,fontStyle:"italic",cursor:"text",minHeight:48,display:"flex",alignItems:"center"},children:"Double-click to add markdown..."})}function os({cell:E,themeMode:e,onApplyParam:t}){const{dispatch:r}=y(),T=G[e],[s,R]=l.useState(!1),A=E.paramConfig??{paramType:"text",label:"Parameter",defaultValue:"",options:[]},a=E.paramValue??A.defaultValue,o=O=>{r({type:"UPDATE_CELL",id:E.id,updates:{paramConfig:{...A,...O}}})},S=O=>{r({type:"SET_PARAM_VALUE",id:E.id,value:O})},i=(A.options??[]).map(O=>O.trim()).filter(Boolean),I=E.name?`{{${E.name}}}`:null;return n.jsxs("div",{style:{background:T.cellBg,border:`1px solid ${T.cellBorder}`,borderLeft:"3px solid #e3b341",borderRadius:8,overflow:"hidden"},children:[s&&n.jsxs("div",{style:{background:T.tableHeaderBg,borderBottom:`1px solid ${T.cellBorder}`,padding:"12px 14px",display:"flex",flexDirection:"column",gap:10},children:[n.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:2},children:[n.jsx("span",{style:{fontSize:11,fontWeight:600,letterSpacing:"0.06em",color:"#e3b341",fontFamily:T.fontMono,textTransform:"uppercase"},children:"Configure Parameter"}),n.jsx("button",{onClick:()=>R(!1),title:"Done",style:{background:"#e3b341",border:"none",borderRadius:5,cursor:"pointer",color:"#000",fontSize:11,fontWeight:700,fontFamily:T.font,padding:"3px 10px",display:"flex",alignItems:"center",gap:4},children:"✓ Done"})]}),n.jsxs("div",{style:{display:"flex",gap:10,flexWrap:"wrap"},children:[n.jsxs("label",{style:{display:"flex",flexDirection:"column",gap:3,flex:"1 1 120px"},children:[n.jsx("span",{style:{fontSize:10,color:T.textMuted,fontFamily:T.font},children:"Variable name"}),n.jsx("input",{value:E.name??"",onChange:O=>r({type:"UPDATE_CELL",id:E.id,updates:{name:O.target.value||void 0}}),placeholder:"e.g. start_date",style:{background:T.inputBg,border:`1px solid ${T.inputBorder}`,borderRadius:4,color:T.textPrimary,fontSize:12,fontFamily:T.fontMono,padding:"4px 7px",outline:"none"}})]}),n.jsxs("label",{style:{display:"flex",flexDirection:"column",gap:3,flex:"1 1 120px"},children:[n.jsx("span",{style:{fontSize:10,color:T.textMuted,fontFamily:T.font},children:"Display label"}),n.jsx("input",{value:A.label,onChange:O=>o({label:O.target.value}),placeholder:"e.g. Start Date",style:{background:T.inputBg,border:`1px solid ${T.inputBorder}`,borderRadius:4,color:T.textPrimary,fontSize:12,fontFamily:T.font,padding:"4px 7px",outline:"none"}})]}),n.jsxs("label",{style:{display:"flex",flexDirection:"column",gap:3,flex:"1 1 100px"},children:[n.jsx("span",{style:{fontSize:10,color:T.textMuted,fontFamily:T.font},children:"Type"}),n.jsxs("select",{value:A.paramType,onChange:O=>o({paramType:O.target.value}),style:{background:T.inputBg,border:`1px solid ${T.inputBorder}`,borderRadius:4,color:T.textPrimary,fontSize:12,fontFamily:T.font,padding:"4px 7px",outline:"none"},children:[n.jsx("option",{value:"text",children:"Text"}),n.jsx("option",{value:"number",children:"Number"}),n.jsx("option",{value:"date",children:"Date"}),n.jsx("option",{value:"select",children:"Select"})]})]}),n.jsxs("label",{style:{display:"flex",flexDirection:"column",gap:3,flex:"1 1 120px"},children:[n.jsx("span",{style:{fontSize:10,color:T.textMuted,fontFamily:T.font},children:"Default value"}),n.jsx("input",{type:A.paramType==="number"?"number":A.paramType==="date"?"date":"text",value:A.defaultValue,onChange:O=>o({defaultValue:O.target.value}),style:{background:T.inputBg,border:`1px solid ${T.inputBorder}`,borderRadius:4,color:T.textPrimary,fontSize:12,fontFamily:T.font,padding:"4px 7px",outline:"none"}})]})]}),A.paramType==="select"&&n.jsxs("label",{style:{display:"flex",flexDirection:"column",gap:3},children:[n.jsx("span",{style:{fontSize:10,color:T.textMuted,fontFamily:T.font},children:"Options (one per line)"}),n.jsx("textarea",{value:(A.options??[]).join(`
|
|
322
|
+
`),onChange:O=>o({options:O.target.value.split(`
|
|
323
|
+
`)}),rows:4,placeholder:`Option A
|
|
324
|
+
Option B
|
|
325
|
+
Option C`,style:{background:T.inputBg,border:`1px solid ${T.inputBorder}`,borderRadius:4,color:T.textPrimary,fontSize:12,fontFamily:T.fontMono,padding:"5px 7px",outline:"none",resize:"vertical"}})]})]}),n.jsxs("div",{style:{padding:"12px 14px",display:"flex",alignItems:"center",gap:12,flexWrap:"wrap"},children:[n.jsx("button",{onClick:()=>R(O=>!O),title:s?"Close config":"Configure parameter",style:{background:s?"#e3b34118":"transparent",border:`1px solid ${s?"#e3b341":T.cellBorder}`,borderRadius:5,cursor:"pointer",color:s?"#e3b341":T.textMuted,width:26,height:26,display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0,transition:"all 0.15s"},children:s?n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.749.749 0 1 1 1.06-1.06L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"})}):n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M8 0a8.2 8.2 0 0 1 .701.031C9.444.095 9.99.645 10.16 1.29l.288 1.107c.018.066.079.158.212.224.231.114.454.243.668.386.123.082.233.09.299.071l1.103-.303c.644-.176 1.392.021 1.82.63.27.385.506.792.704 1.218.315.675.111 1.422-.364 1.891l-.814.806c-.049.048-.098.147-.088.294.016.257.016.515 0 .772-.01.147.038.246.088.294l.814.806c.475.469.679 1.216.364 1.891a7.977 7.977 0 0 1-.704 1.217c-.428.61-1.176.807-1.82.63l-1.102-.302c-.067-.019-.177-.011-.3.071a5.909 5.909 0 0 1-.668.386c-.133.066-.194.158-.211.224l-.29 1.106c-.168.646-.715 1.196-1.458 1.26a8.006 8.006 0 0 1-1.402 0c-.743-.064-1.289-.614-1.458-1.26l-.289-1.106c-.018-.066-.079-.158-.212-.224a5.738 5.738 0 0 1-.668-.386c-.123-.082-.233-.09-.299-.071l-1.103.303c-.644.176-1.392-.021-1.82-.63a8.12 8.12 0 0 1-.704-1.218c-.315-.675-.111-1.422.363-1.891l.815-.806c.05-.048.098-.147.088-.294a6.214 6.214 0 0 1 0-.772c.01-.147-.038-.246-.088-.294l-.815-.806C.635 6.045.431 5.298.746 4.623a7.92 7.92 0 0 1 .704-1.217c.428-.61 1.176-.807 1.82-.63l1.102.302c.067.019.177.011.3-.071.214-.143.437-.272.668-.386.133-.066.194-.158.211-.224l.29-1.106C6.009.645 6.556.095 7.299.03 7.53.01 7.764 0 8 0Zm-.571 1.525c-.036.003-.108.036-.137.146l-.289 1.105c-.147.561-.549.967-.998 1.189-.173.086-.34.183-.5.29-.417.278-.97.423-1.529.27l-1.103-.303c-.109-.03-.175.016-.195.045-.22.312-.412.644-.573.99-.014.031-.021.11.059.19l.815.806c.411.406.562.957.53 1.456a4.709 4.709 0 0 0 0 .582c.032.499-.119 1.05-.53 1.456l-.815.806c-.081.08-.073.159-.059.19.162.346.353.677.573.989.02.03.085.076.195.046l1.102-.303c.56-.153 1.113-.008 1.53.27.161.107.328.204.501.29.447.222.85.629.997 1.189l.289 1.105c.029.109.101.143.137.146a6.6 6.6 0 0 0 1.142 0c.036-.003.108-.036.137-.146l.289-1.105c.147-.561.549-.967.998-1.189.173-.086.34-.183.5-.29.417-.278.97-.423 1.529-.27l1.103.303c.109.029.175-.016.195-.045.22-.313.411-.644.573-.99.014-.031.021-.11-.059-.19l-.815-.806c-.411-.406-.562-.957-.53-1.456a4.709 4.709 0 0 0 0-.582c-.032-.499.119-1.05.53-1.456l.815-.806c.081-.08.073-.159.059-.19a6.464 6.464 0 0 0-.573-.989c-.02-.03-.085-.076-.195-.046l-1.102.303c-.56.153-1.113.008-1.53-.27a4.44 4.44 0 0 0-.501-.29c-.447-.222-.85-.629-.997-1.189l-.289-1.105c-.029-.11-.101-.143-.137-.146a6.6 6.6 0 0 0-1.142 0ZM8 5.5a2.5 2.5 0 1 1 0 5 2.5 2.5 0 0 1 0-5ZM8 7a1 1 0 1 0 0 2 1 1 0 0 0 0-2Z"})})}),n.jsx("span",{style:{fontSize:13,fontWeight:500,fontFamily:T.font,color:T.textSecondary,flexShrink:0},children:A.label}),n.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:3},children:[A.paramType==="select"?n.jsx("select",{value:a,onChange:O=>S(O.target.value),style:{background:T.inputBg,border:`1px solid ${T.inputBorder}`,borderRadius:5,color:T.textPrimary,fontSize:13,fontFamily:T.font,padding:"5px 10px",outline:"none",minWidth:160},children:i.length===0?n.jsx("option",{value:"",children:"— no options configured —"}):i.map(O=>n.jsx("option",{value:O,children:O},O))}):n.jsx("input",{type:A.paramType,value:a,onChange:O=>S(O.target.value),style:{background:T.inputBg,border:`1px solid ${T.inputBorder}`,borderRadius:5,color:T.textPrimary,fontSize:13,fontFamily:A.paramType==="number"?T.fontMono:T.font,padding:"5px 10px",outline:"none",minWidth:160}}),I&&n.jsx("span",{style:{fontSize:10,fontFamily:T.fontMono,color:"#e3b341",opacity:.8},children:I})]}),a&&n.jsx("span",{style:{fontSize:12,fontFamily:T.fontMono,color:T.textPrimary,background:"#e3b34118",border:"1px solid #e3b34140",borderRadius:4,padding:"2px 8px",flexShrink:0},children:a}),E.name&&t&&n.jsx("button",{onClick:()=>t(E.name),title:`Re-run cells that use {{${E.name}}}`,style:{background:"#e3b341",border:"none",borderRadius:5,cursor:"pointer",color:"#000",fontSize:11,fontWeight:600,fontFamily:T.font,padding:"4px 12px",flexShrink:0,transition:"opacity 0.15s"},children:"Apply"})]})]})}const Ss=[{id:"select-all",label:"Select all rows",description:"Read all rows from a CSV file with a row limit",category:"SQL",code:"SELECT * FROM read_csv_auto('data/filename.csv') LIMIT 100"},{id:"group-by",label:"Group and aggregate",description:"Group rows and compute count + sum",category:"SQL",code:`SELECT
|
|
326
|
+
category,
|
|
327
|
+
COUNT(*) AS count,
|
|
328
|
+
SUM(amount) AS total
|
|
329
|
+
FROM read_csv_auto('data/filename.csv')
|
|
330
|
+
GROUP BY category
|
|
331
|
+
ORDER BY total DESC`},{id:"filter-date",label:"Filter by date range",description:"Filter rows between two dates",category:"SQL",code:`SELECT *
|
|
332
|
+
FROM read_csv_auto('data/filename.csv')
|
|
333
|
+
WHERE date_column >= '2024-01-01'
|
|
334
|
+
AND date_column < '2025-01-01'`},{id:"window-rank",label:"Window function: rank",description:"Rank rows within groups using ROW_NUMBER()",category:"SQL",code:`SELECT
|
|
335
|
+
*,
|
|
336
|
+
ROW_NUMBER() OVER (PARTITION BY category ORDER BY amount DESC) AS rank
|
|
337
|
+
FROM read_csv_auto('data/filename.csv')`},{id:"cte",label:"CTE (WITH clause)",description:"Define a named subquery with WITH",category:"SQL",code:`WITH base AS (
|
|
338
|
+
SELECT *
|
|
339
|
+
FROM read_csv_auto('data/filename.csv')
|
|
340
|
+
WHERE amount > 0
|
|
341
|
+
)
|
|
342
|
+
SELECT
|
|
343
|
+
category,
|
|
344
|
+
SUM(amount) AS total
|
|
345
|
+
FROM base
|
|
346
|
+
GROUP BY category`},{id:"join",label:"Join two tables",description:"Join two CSV files on a shared key",category:"SQL",code:`SELECT a.*, b.name
|
|
347
|
+
FROM read_csv_auto('data/table_a.csv') AS a
|
|
348
|
+
JOIN read_csv_auto('data/table_b.csv') AS b
|
|
349
|
+
ON a.id = b.id`},{id:"pivot",label:"Pivot / unpivot",description:"Pivot a column into multiple columns",category:"SQL",code:`SELECT *
|
|
350
|
+
FROM (
|
|
351
|
+
SELECT category, quarter, amount
|
|
352
|
+
FROM read_csv_auto('data/filename.csv')
|
|
353
|
+
) PIVOT (SUM(amount) FOR quarter IN ('Q1', 'Q2', 'Q3', 'Q4'))`},{id:"dql-block",label:"DQL block (basic)",description:"Minimal DQL block with a table visualization",category:"DQL",code:`block "My Block" {
|
|
354
|
+
domain = "analytics"
|
|
355
|
+
type = "custom"
|
|
356
|
+
description = "Describe what this block does"
|
|
357
|
+
owner = "data-team"
|
|
358
|
+
tags = ["analytics"]
|
|
359
|
+
|
|
360
|
+
query = """
|
|
361
|
+
SELECT *
|
|
362
|
+
FROM read_csv_auto('data/filename.csv')
|
|
363
|
+
LIMIT 100
|
|
364
|
+
"""
|
|
365
|
+
|
|
366
|
+
visualization {
|
|
367
|
+
chart = "table"
|
|
368
|
+
}
|
|
369
|
+
}`},{id:"dql-block-bar",label:"DQL block with bar chart",description:"DQL block with params, bar chart, and a test assertion",category:"DQL",code:`block "Revenue by Segment" {
|
|
370
|
+
domain = "revenue"
|
|
371
|
+
type = "custom"
|
|
372
|
+
description = "Revenue grouped by segment"
|
|
373
|
+
owner = "data-team"
|
|
374
|
+
tags = ["revenue"]
|
|
375
|
+
|
|
376
|
+
params {
|
|
377
|
+
period = "current_quarter"
|
|
378
|
+
}
|
|
379
|
+
|
|
380
|
+
query = """
|
|
381
|
+
SELECT
|
|
382
|
+
segment_tier AS segment,
|
|
383
|
+
SUM(amount) AS revenue
|
|
384
|
+
FROM read_csv_auto('data/revenue.csv')
|
|
385
|
+
WHERE fiscal_period = \${period}
|
|
386
|
+
GROUP BY segment_tier
|
|
387
|
+
ORDER BY revenue DESC
|
|
388
|
+
"""
|
|
389
|
+
|
|
390
|
+
visualization {
|
|
391
|
+
chart = "bar"
|
|
392
|
+
x = segment
|
|
393
|
+
y = revenue
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
tests {
|
|
397
|
+
assert row_count > 0
|
|
398
|
+
}
|
|
399
|
+
}`},{id:"dql-import",label:"@import block (simple)",description:"Reference a block file by path — runs the block's SQL without copying it",category:"DQL",code:'@import "./blocks/my_block.dql"'},{id:"dql-import-params",label:"@import block with params",description:"Import a block and override its default parameter values",category:"DQL",code:'@import "./blocks/my_block.dql" with period = "Q4_2024", segment = "Enterprise"'},{id:"revenue-by-segment",label:"Revenue by segment",description:"Aggregate revenue totals, deal count, and average deal size per segment",category:"Analysis",code:`SELECT
|
|
400
|
+
segment_tier,
|
|
401
|
+
SUM(amount) AS total_revenue,
|
|
402
|
+
COUNT(*) AS deals,
|
|
403
|
+
ROUND(AVG(amount), 0) AS avg_deal
|
|
404
|
+
FROM read_csv_auto('data/revenue.csv')
|
|
405
|
+
GROUP BY segment_tier
|
|
406
|
+
ORDER BY total_revenue DESC`},{id:"quarterly-trend",label:"Quarterly trend",description:"Revenue totals grouped by fiscal year and quarter",category:"Analysis",code:`SELECT
|
|
407
|
+
fiscal_year || ' ' || fiscal_quarter AS period,
|
|
408
|
+
SUM(amount) AS revenue
|
|
409
|
+
FROM read_csv_auto('data/revenue.csv')
|
|
410
|
+
GROUP BY fiscal_year, fiscal_quarter
|
|
411
|
+
ORDER BY fiscal_year, fiscal_quarter`}];function is({onInsert:E,themeMode:e,cellType:t}){const r=G[e],[T,s]=l.useState(!1),[R,A]=l.useState(null),a=l.useRef(null),o=Ss.filter(I=>t==="dql"?I.category==="DQL":I.category==="SQL"||I.category==="Analysis"),S=Array.from(new Set(o.map(I=>I.category)));l.useEffect(()=>{if(!T)return;function I(O){a.current&&!a.current.contains(O.target)&&s(!1)}return document.addEventListener("mousedown",I),()=>document.removeEventListener("mousedown",I)},[T]);function i(I){E(I),s(!1)}return n.jsxs("div",{ref:a,style:{position:"relative",display:"inline-block"},children:[n.jsxs("button",{title:"Insert template snippet",onClick:()=>s(I=>!I),style:{height:22,padding:"0 8px",fontSize:10,fontFamily:r.font,fontWeight:600,letterSpacing:"0.04em",color:T?r.accent:r.textMuted,background:T?`${r.accent}15`:"transparent",border:`1px solid ${T?r.accent+"50":r.btnBorder}`,borderRadius:4,cursor:"pointer",display:"flex",alignItems:"center",gap:4,transition:"all 0.15s",whiteSpace:"nowrap"},children:[n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M2 2.5A2.5 2.5 0 0 1 4.5 0h8.75a.75.75 0 0 1 .75.75v12.5a.75.75 0 0 1-.75.75h-2.5a.75.75 0 0 1 0-1.5h1.75v-2h-8a1 1 0 0 0-.714 1.7.75.75 0 1 1-1.072 1.05A2.495 2.495 0 0 1 2 11.5Zm10.5-1h-8a1 1 0 0 0-1 1v6.708A2.486 2.486 0 0 1 4.5 9h8ZM5 12.25a.25.25 0 0 1 .25-.25h3.5a.25.25 0 0 1 .25.25v3.25a.25.25 0 0 1-.4.2l-1.45-1.087a.249.249 0 0 0-.3 0L5.4 15.7a.25.25 0 0 1-.4-.2Z"})}),"Templates"]}),T&&n.jsx("div",{style:{position:"absolute",top:"calc(100% + 4px)",left:0,zIndex:300,width:300,maxHeight:360,overflowY:"auto",background:r.modalBg,border:`1px solid ${r.cellBorder}`,borderRadius:8,boxShadow:"0 8px 24px rgba(0,0,0,0.3)",padding:"6px 0"},children:S.map(I=>n.jsxs("div",{children:[n.jsx("div",{style:{padding:"6px 12px 4px",fontSize:10,fontWeight:700,fontFamily:r.font,letterSpacing:"0.08em",textTransform:"uppercase",color:r.textMuted},children:I}),o.filter(O=>O.category===I).map(O=>n.jsxs("button",{onMouseEnter:()=>A(O.id),onMouseLeave:()=>A(null),onClick:()=>i(O.code),style:{width:"100%",padding:"7px 12px",textAlign:"left",background:R===O.id?r.sidebarItemHover:"transparent",border:"none",cursor:"pointer",display:"flex",flexDirection:"column",gap:2,transition:"background 0.1s"},children:[n.jsx("span",{style:{fontSize:12,fontWeight:600,fontFamily:r.font,color:r.textPrimary,lineHeight:1.4},children:O.label}),n.jsx("span",{style:{fontSize:11,fontFamily:r.font,color:r.textMuted,lineHeight:1.4},children:O.description})]},O.id))]},I))})]})}const ke=500;function as(E){return typeof E=="number"?!0:typeof E=="string"?!isNaN(Number(E))&&E.trim()!=="":!1}function Is(E){return E==null?"":typeof E=="object"?JSON.stringify(E):String(E)}function Zt({result:E,themeMode:e}){const t=G[e],[r,T]=l.useState(null),s=E.rows.slice(0,ke),R=E.rows.length>ke;return E.columns.length===0?n.jsx("div",{style:{padding:"12px 16px",color:t.textMuted,fontSize:12,fontFamily:t.font,fontStyle:"italic"},children:"Query executed successfully. No columns to display."}):n.jsxs("div",{style:{maxHeight:400,overflow:"auto",position:"relative"},children:[n.jsxs("table",{style:{width:"100%",borderCollapse:"collapse",tableLayout:"auto",fontSize:12,fontFamily:t.fontMono},children:[n.jsx("thead",{children:n.jsx("tr",{children:E.columns.map(A=>n.jsx("th",{style:{background:t.tableHeaderBg,color:t.textSecondary,fontWeight:600,fontSize:11,textAlign:"left",padding:"6px 12px",borderBottom:`1px solid ${t.tableBorder}`,borderRight:`1px solid ${t.tableBorder}`,minWidth:80,maxWidth:300,whiteSpace:"nowrap",position:"sticky",top:0,zIndex:1,fontFamily:t.font,letterSpacing:"0.03em",overflow:"hidden",textOverflow:"ellipsis"},children:A},A))})}),n.jsx("tbody",{children:s.map((A,a)=>n.jsx("tr",{onMouseEnter:()=>T(a),onMouseLeave:()=>T(null),style:{background:r===a?t.tableRowHover:"transparent",transition:"background 0.1s"},children:E.columns.map(o=>{const S=A[o],i=S==null,I=as(S);return n.jsx("td",{style:{padding:"5px 12px",borderBottom:`1px solid ${t.tableBorder}`,borderRight:`1px solid ${t.tableBorder}`,color:i?t.textMuted:t.textPrimary,fontStyle:i?"italic":"normal",textAlign:I?"right":"left",whiteSpace:"nowrap",maxWidth:300,overflow:"hidden",textOverflow:"ellipsis"},children:i?"—":Is(S)},o)})},a))})]}),R&&n.jsxs("div",{style:{padding:"8px 12px",color:t.textMuted,fontSize:11,fontFamily:t.font,borderTop:`1px solid ${t.tableBorder}`,background:t.tableHeaderBg,fontStyle:"italic"},children:["Showing ",ke.toLocaleString()," of ",E.rows.length.toLocaleString()," rows"]})]})}const Os=/date|time|at|day|month|year/i,yE=/^(label|name|category)$/i,BE=/^(value|count|total|revenue|amount)$/i;function DE(E){return typeof E=="number"?!0:typeof E=="string"?E.trim()!==""&&!isNaN(Number(E)):!1}function Ns(E){return typeof E=="string"||typeof E=="number"}function uE(E,e){if(e!=null&&e.chart){const t=e.chart.toLowerCase();if(t==="bar"||t==="line"||t==="pie"||t==="kpi")return t;if(t==="table")return"table"}return ls(E)}function ls(E){const{columns:e,rows:t}=E;if(e.length<2||t.length===0)return"table";const r=e[0],T=e[1],s=t.slice(0,5),R=s.every(S=>DE(S[T])),A=s.every(S=>Ns(S[r]));if(Os.test(r)&&R&&A)return"line";const a=e.find(S=>yE.test(S)),o=e.find(S=>BE.test(S));return a&&o&&s.every(i=>DE(i[o]))||e.length===2&&A&&R?"bar":"table"}function Pe(E){return Math.abs(E)>=1e6?`${(E/1e6).toFixed(1)}M`:Math.abs(E)>=1e3?`${(E/1e3).toFixed(1)}K`:E.toLocaleString(void 0,{maximumFractionDigits:2})}const je=20;function Ls({result:E,themeMode:e}){const t=G[e],[r,T]=l.useState(null),s=E.columns.find(d=>yE.test(d))??E.columns[0],R=E.columns.find(d=>BE.test(d))??E.columns[1],A=E.rows.slice(0,je).map(d=>({label:String(d[s]??""),value:Number(d[R]??0)})),a=E.rows.length>je,o=Math.max(...A.map(d=>d.value),1),S=28,i=120,I=60,O=6,c=12,_=A.length*(S+O)+c*2;return n.jsxs("div",{style:{padding:"8px 0"},children:[n.jsx("svg",{width:"100%",height:_,style:{display:"block",overflow:"visible"},viewBox:`0 0 600 ${_}`,preserveAspectRatio:"xMidYMid meet",children:A.map((d,u)=>{const D=c+u*(S+O),f=600-i-I-24,p=Math.max(d.value/o*f,2),m=r===u;return n.jsxs("g",{onMouseEnter:()=>T(u),onMouseLeave:()=>T(null),style:{cursor:"default"},children:[n.jsx("text",{x:i-8,y:D+S/2+4,textAnchor:"end",fontSize:11,fontFamily:t.font,fill:t.textSecondary,children:d.label.length>16?d.label.slice(0,15)+"…":d.label}),n.jsx("rect",{x:i,y:D,width:p,height:S,rx:3,fill:m?t.accentHover:t.accent,style:{transition:"fill 0.15s"}}),n.jsx("text",{x:i+p+6,y:D+S/2+4,textAnchor:"start",fontSize:11,fontFamily:t.fontMono,fill:t.textMuted,children:Pe(d.value)})]},u)})}),a&&n.jsxs("div",{style:{fontSize:11,color:t.textMuted,fontFamily:t.font,fontStyle:"italic",padding:"4px 12px"},children:["Showing ",je," of ",E.rows.length," rows"]})]})}function Cs(E){const e=new Date(E);if(!isNaN(e.getTime())){if(/^\d{4}-\d{2}-\d{2}/.test(E))return e.toLocaleDateString("en-US",{month:"short",day:"numeric"});if(/^\d{4}-\d{2}$/.test(E))return e.toLocaleDateString("en-US",{year:"numeric",month:"short"})}return String(E).length>8?String(E).slice(0,8):String(E)}function cs({result:E,themeMode:e}){const t=G[e],[r,T]=l.useState(null),s=E.columns[0],R=E.columns[1],A=E.rows.map(x=>({label:String(x[s]??""),value:Number(x[R]??0)}));if(A.length<2)return null;const a=560,o=200,S=52,i=16,I=16,O=36,c=a-S-i,_=o-I-O,d=Math.min(...A.map(x=>x.value)),D=Math.max(...A.map(x=>x.value))-d||1,f=c/(A.length-1),p=x=>S+x*f,m=x=>I+_-(x-d)/D*_,h=A.map((x,M)=>({x:p(M),y:m(x.value)})),Y=h.reduce((x,M,$)=>{if($===0)return`M ${M.x},${M.y}`;const Ae=h[$-1],iT=Ae.x+(M.x-Ae.x)/2,aT=Ae.y,IT=Ae.x+(M.x-Ae.x)/2,OT=M.y;return`${x} C ${iT},${aT} ${IT},${OT} ${M.x},${M.y}`},""),b=`${Y} L ${h[h.length-1].x},${I+_} L ${S},${I+_} Z`,Ee=5,Z=Array.from({length:Ee+1},(x,M)=>{const $=d+D*M/Ee,Ae=m($);return{val:$,y:Ae}}),B=Math.ceil(A.length/8),Re=A.filter((x,M)=>M%B===0||M===A.length-1);return n.jsx("div",{style:{position:"relative",padding:"8px 0"},children:n.jsxs("svg",{width:"100%",height:o,viewBox:`0 0 ${a} ${o}`,preserveAspectRatio:"xMidYMid meet",style:{display:"block",overflow:"visible"},onMouseLeave:()=>T(null),children:[Z.map((x,M)=>n.jsxs("g",{children:[n.jsx("line",{x1:S,y1:x.y,x2:S+c,y2:x.y,stroke:t.tableBorder,strokeWidth:.5}),n.jsx("text",{x:S-6,y:x.y+4,textAnchor:"end",fontSize:10,fontFamily:t.fontMono,fill:t.textMuted,children:Pe(x.val)})]},M)),n.jsx("path",{d:b,fill:t.accent,opacity:.15}),n.jsx("path",{d:Y,fill:"none",stroke:t.accent,strokeWidth:2,strokeLinejoin:"round"}),h.map((x,M)=>n.jsx("circle",{cx:x.x,cy:x.y,r:3,fill:t.accent,style:{cursor:"crosshair"},onMouseEnter:()=>T({x:x.x,y:x.y,label:A[M].label,value:A[M].value})},M)),Re.map((x,M)=>{const $=A.indexOf(x);return n.jsx("text",{x:p($),y:I+_+16,textAnchor:"middle",fontSize:10,fontFamily:t.font,fill:t.textMuted,children:Cs(x.label)},M)}),n.jsx("line",{x1:S,y1:I,x2:S,y2:I+_,stroke:t.tableBorder,strokeWidth:1}),n.jsx("line",{x1:S,y1:I+_,x2:S+c,y2:I+_,stroke:t.tableBorder,strokeWidth:1}),r&&n.jsxs("g",{children:[n.jsx("rect",{x:r.x+8,y:r.y-20,width:90,height:32,rx:4,fill:t.cellBg,stroke:t.cellBorder,strokeWidth:1}),n.jsx("text",{x:r.x+13,y:r.y-8,fontSize:10,fontFamily:t.font,fill:t.textSecondary,children:r.label.length>10?r.label.slice(0,10)+"…":r.label}),n.jsx("text",{x:r.x+13,y:r.y+6,fontSize:11,fontFamily:t.fontMono,fill:t.textPrimary,fontWeight:600,children:Pe(r.value)})]})]})})}const _s=12,JE=["#388bfd","#56d364","#e3b341","#f78166","#a371f7","#39c5cf","#ffa657","#ff7b72","#89d185","#d2a8ff","#58a6ff","#3fb950"];function ds({result:E,themeMode:e,chartConfig:t}){const r=G[e],[T,s]=l.useState(null),R=(t!=null&&t.x?E.columns.find(u=>u===t.x):void 0)??E.columns.find(u=>yE.test(u))??E.columns[0],A=(t!=null&&t.y?E.columns.find(u=>u===t.y):void 0)??E.columns.find(u=>BE.test(u))??E.columns[1],a=E.rows.slice(0,_s).map(u=>({label:String(u[R]??""),value:Math.abs(Number(u[A]??0))})),o=a.reduce((u,D)=>u+D.value,0)||1,S=90,i=90,I=70,O=40,c=[];let _=-Math.PI/2;a.forEach((u,D)=>{const f=u.value/o*2*Math.PI,p=_,m=_+f,h=S+I*Math.cos(p),Y=i+I*Math.sin(p),b=S+I*Math.cos(m),Ee=i+I*Math.sin(m),Z=S+O*Math.cos(p),B=i+O*Math.sin(p),Re=S+O*Math.cos(m),x=i+O*Math.sin(m),M=f>Math.PI?1:0,$=[`M ${h} ${Y}`,`A ${I} ${I} 0 ${M} 1 ${b} ${Ee}`,`L ${Re} ${x}`,`A ${O} ${O} 0 ${M} 0 ${Z} ${B}`,"Z"].join(" ");c.push({path:$,color:JE[D%JE.length],label:u.label,value:u.value,pct:u.value/o*100}),_=m});const d=T!==null?c[T]:null;return n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:16,padding:"8px 12px",flexWrap:"wrap"},children:[n.jsxs("svg",{width:180,height:180,style:{flexShrink:0},onMouseLeave:()=>s(null),children:[c.map((u,D)=>n.jsx("path",{d:u.path,fill:u.color,opacity:T===null||T===D?1:.55,style:{cursor:"pointer",transition:"opacity 0.15s"},onMouseEnter:()=>s(D)},D)),n.jsx("text",{x:S,y:i-5,textAnchor:"middle",fontSize:11,fontFamily:r.fontMono,fill:r.textSecondary,children:Pe(d?d.value:o)}),n.jsx("text",{x:S,y:i+9,textAnchor:"middle",fontSize:9,fontFamily:r.font,fill:r.textMuted,children:d?`${d.pct.toFixed(1)}%`:"total"})]}),n.jsx("div",{style:{display:"flex",flexDirection:"column",gap:4,maxHeight:180,overflowY:"auto",flex:1},children:c.map((u,D)=>n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:6,cursor:"default",opacity:T===null||T===D?1:.5},onMouseEnter:()=>s(D),onMouseLeave:()=>s(null),children:[n.jsx("div",{style:{width:10,height:10,borderRadius:2,background:u.color,flexShrink:0}}),n.jsx("span",{style:{fontSize:11,fontFamily:r.font,color:r.textSecondary,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:u.label}),n.jsxs("span",{style:{fontSize:11,fontFamily:r.fontMono,color:r.textMuted,marginLeft:"auto",flexShrink:0},children:[u.pct.toFixed(1),"%"]})]},D))})]})}function Ds({result:E,themeMode:e,chartConfig:t}){const r=G[e],T=E.rows[0];if(!T)return null;const s=t!=null&&t.y&&E.columns.includes(t.y)?t.y:E.columns.find(S=>DE(T[S]))??E.columns[0],R=T[s],A=Number(R),a=isNaN(A)?String(R):A.toLocaleString(void 0,{maximumFractionDigits:2}),o=(t==null?void 0:t.title)??(t!=null&&t.x&&T[t.x]?String(T[t.x]):s);return n.jsxs("div",{style:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",padding:"32px 24px",gap:8},children:[n.jsx("span",{style:{fontSize:40,fontWeight:700,fontFamily:r.fontMono,color:r.accent,lineHeight:1.1},children:a}),n.jsx("span",{style:{fontSize:13,fontFamily:r.font,color:r.textMuted,textTransform:"uppercase",letterSpacing:"0.08em",fontWeight:500},children:o})]})}function us({result:E,themeMode:e,chartConfig:t}){const r=G[e],T=uE(E,t),s=T!=="table",[R,A]=l.useState(s?"chart":"table"),a=t!=null&&t.x&&E.columns.includes(t.x)?t.x:void 0,o=t!=null&&t.y&&E.columns.includes(t.y)?t.y:void 0,S=a||o?Ps(E,a,o):E,i=[];t!=null&&t.x&&!E.columns.includes(t.x)&&i.push(`Column '${t.x}' not found in results — using auto-detection.`),t!=null&&t.y&&!E.columns.includes(t.y)&&i.push(`Column '${t.y}' not found in results — using auto-detection.`);const I=T==="line"?"Line":T==="pie"?"Pie":T==="kpi"?"KPI":"Bar";return T==="kpi"?n.jsxs("div",{children:[i.length>0&&n.jsx(QE,{warnings:i,t:r}),n.jsx(Ds,{result:E,themeMode:e,chartConfig:t})]}):n.jsxs("div",{children:[i.length>0&&n.jsx(QE,{warnings:i,t:r}),s&&n.jsxs("div",{style:{display:"flex",justifyContent:"flex-end",alignItems:"center",padding:"4px 12px",gap:4,borderBottom:`1px solid ${r.cellBorder}`,background:`${r.tableHeaderBg}60`},children:[n.jsx("span",{style:{fontSize:10,color:r.textMuted,fontFamily:r.font,marginRight:4},children:"View:"}),["chart","table"].map(O=>n.jsx("button",{onClick:()=>A(O),style:{padding:"2px 8px",fontSize:10,fontFamily:r.font,borderRadius:4,border:`1px solid ${R===O?r.accent:r.btnBorder}`,background:R===O?`${r.accent}20`:"transparent",color:R===O?r.accent:r.textMuted,cursor:"pointer",transition:"all 0.15s",textTransform:"capitalize"},children:O==="chart"?I:"Table"},O))]}),R==="table"||!s?n.jsx(Zt,{result:E,themeMode:e}):T==="line"?n.jsx(cs,{result:S,themeMode:e}):T==="pie"?n.jsx(ds,{result:E,themeMode:e,chartConfig:t}):n.jsx(Ls,{result:S,themeMode:e})]})}function QE({warnings:E,t:e}){return n.jsx("div",{style:{padding:"4px 12px",background:"#e3b34115",borderBottom:"1px solid #e3b34130",display:"flex",flexDirection:"column",gap:2},children:E.map((t,r)=>n.jsx("span",{style:{fontSize:11,color:"#e3b341",fontFamily:e.font},children:t},r))})}function Ps(E,e,t){const r=E.columns,T=[];e&&r.includes(e)&&T.push(e),t&&r.includes(t)&&T.push(t);for(const s of r)T.includes(s)||T.push(s);return T.join(",")===r.join(",")?E:{...E,columns:T,rows:E.rows.map(s=>{const R={};for(const A of T)R[A]=s[A];return R})}}function ps(E){let e=E;try{const o=JSON.parse(E);o&&typeof o.error=="string"&&(e=o.error)}catch{}e=e.replace(/^DuckDB query failed:\s*/i,"").trim();let t="Error";/Parser Error/i.test(e)?t="Syntax Error":/Binder Error/i.test(e)?t="Reference Error":/Conversion Error/i.test(e)?t="Type Error":/Invalid Input Error/i.test(e)?t="Input Error":/IO Error/i.test(e)?t="File Error":/Constraint Error/i.test(e)&&(t="Constraint Error");let r;const T=e.match(/LINE\s+(\d+):/i)??e.match(/\bline\s+(\d+)\b/i);T&&(r=parseInt(T[1],10));let s;const R=e.match(/at or near "([^"]+)"/i);R?s=R[1]:/at end of input/i.test(e)&&(s="end of input");let A;t==="Syntax Error"?s==='"""'||e.includes('"""')?A="Triple-quoted strings are DQL block syntax. Use a DQL cell for block syntax, or plain SQL in a SQL cell.":s==="end of input"||/at end of input/i.test(e)?A="Query is incomplete — check for unclosed parentheses, missing keywords, or a dangling comma.":(s===")"||s==="(")&&(A="Mismatched parentheses — check that every opening ( has a closing )."):t==="Reference Error"?/column.*not found|Referenced column/i.test(e)?A="Column not found — check the column name in the Schema panel (left sidebar).":/table.*not found|Table.*does not exist/i.test(e)&&(A="Table not found — make sure the file path is correct and the file exists in your data/ folder."):t==="Input Error"?/No files found/i.test(e)&&(A="File not found — use read_csv_auto('./data/filename.csv'). Open the Schema panel (left sidebar) to see all files available in your data/ folder."):t==="File Error"?A="File could not be read — use read_csv_auto('./data/filename.csv'). Open the Schema panel to browse available data files.":t==="Type Error"&&(A="Type mismatch — you may be comparing or casting incompatible types (e.g. text vs number).");const a=e.replace(/^(Parser Error|Binder Error|Conversion Error|Invalid Input Error|IO Error|Constraint Error):\s*/i,"").trim();return{type:t,message:a,line:r,near:s,hint:A}}function Ms(E,e){const t=E.length,r=e.length,T=Array.from({length:t+1},(s,R)=>Array.from({length:r+1},(A,a)=>R===0?a:a===0?R:0));for(let s=1;s<=t;s++)for(let R=1;R<=r;R++)T[s][R]=E[s-1]===e[R-1]?T[s-1][R-1]:1+Math.min(T[s-1][R],T[s][R-1],T[s-1][R-1]);return T[t][r]}function ZE(E,e){const t=E.toLowerCase();let r=null,T=4;for(const s of e){const R=Ms(t,s.toLowerCase());R<T&&(T=R,r=s)}return r}function Us({message:E,themeMode:e,onFix:t,schemaTables:r}){const T=G[e],s=ps(E);let R=null;if(r&&r.length>0&&s.type==="Reference Error"){const a=/column.*not found|Referenced column/i.test(s.message),o=/table.*not found|Table.*does not exist/i.test(s.message);if(a&&s.near){const S=r.flatMap(I=>I.columns.map(O=>O.name)),i=ZE(s.near,S);i&&(R=`Did you mean column "${i}"?`)}else if(o&&s.near){const S=ZE(s.near,r.map(i=>i.name));S&&(R=`Did you mean table "${S}"?`)}}const A=t&&(s.type==="Syntax Error"||s.near===")"||s.near==="("||s.near==="end of input");return n.jsxs("div",{style:{padding:"12px 14px",background:`${T.error}10`,borderLeft:`3px solid ${T.error}`,display:"flex",flexDirection:"column",gap:8},children:[n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8,flexWrap:"wrap"},children:[n.jsx("div",{style:{flexShrink:0,color:T.error,display:"flex",alignItems:"center"},children:n.jsx("svg",{width:"14",height:"14",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M4.47.22A.749.749 0 0 1 5 0h6c.199 0 .389.079.53.22l4.25 4.25c.141.14.22.331.22.53v6a.749.749 0 0 1-.22.53l-4.25 4.25A.749.749 0 0 1 11 16H5a.749.749 0 0 1-.53-.22L.22 11.53A.749.749 0 0 1 0 11V5c0-.199.079-.389.22-.53Zm.84 1.28L1.5 5.31v5.38l3.81 3.81h5.38l3.81-3.81V5.31L10.69 1.5ZM8 4a.75.75 0 0 1 .75.75v3.5a.75.75 0 0 1-1.5 0v-3.5A.75.75 0 0 1 8 4Zm0 8a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z"})})}),n.jsx("span",{style:{fontSize:10,fontWeight:700,fontFamily:T.fontMono,letterSpacing:"0.06em",textTransform:"uppercase",color:T.error,background:`${T.error}18`,border:`1px solid ${T.error}40`,borderRadius:4,padding:"1px 7px",flexShrink:0},children:s.type}),s.line!==void 0&&n.jsxs("span",{style:{fontSize:10,fontWeight:600,fontFamily:T.fontMono,color:T.textSecondary,background:`${T.textMuted}18`,border:`1px solid ${T.textMuted}30`,borderRadius:4,padding:"1px 7px",flexShrink:0},children:["Line ",s.line]}),s.near&&n.jsxs("span",{style:{fontSize:11,fontFamily:T.fontMono,color:T.textSecondary,flexShrink:0},children:["near ",n.jsxs("span",{style:{color:T.error},children:["“",s.near,"”"]})]})]}),n.jsx("pre",{style:{margin:0,fontFamily:T.fontMono,fontSize:12,color:T.error,lineHeight:1.6,whiteSpace:"pre-wrap",wordBreak:"break-word"},children:s.message}),R&&n.jsxs("div",{style:{fontSize:12,fontFamily:T.font,color:T.textSecondary,display:"flex",alignItems:"center",gap:6},children:[n.jsx("span",{style:{color:T.accent},children:"→"}),R]}),s.hint&&n.jsxs("div",{style:{marginTop:2,padding:"8px 12px",background:`${T.warning}12`,border:`1px solid ${T.warning}40`,borderRadius:6,display:"flex",alignItems:"flex-start",gap:8},children:[n.jsx("span",{style:{flexShrink:0,fontSize:13,lineHeight:1.5},children:"💡"}),n.jsx("span",{style:{fontSize:12,fontFamily:T.font,color:T.warning,lineHeight:1.6},children:s.hint})]}),A&&n.jsxs("button",{onClick:t,style:{alignSelf:"flex-start",marginTop:2,padding:"5px 12px",background:`${T.accent}15`,border:`1px solid ${T.accent}50`,borderRadius:6,color:T.accent,fontSize:12,fontFamily:T.font,fontWeight:500,cursor:"pointer",display:"flex",alignItems:"center",gap:6,transition:"all 0.15s"},onMouseEnter:a=>{a.currentTarget.style.background=`${T.accent}25`},onMouseLeave:a=>{a.currentTarget.style.background=`${T.accent}15`},children:[n.jsx("svg",{width:"11",height:"11",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M11.013 1.427a1.75 1.75 0 0 1 2.474 0l1.086 1.086a1.75 1.75 0 0 1 0 2.474l-8.61 8.61c-.21.21-.47.364-.756.445l-3.251.93a.75.75 0 0 1-.927-.928l.929-3.25c.081-.286.235-.547.445-.758l8.61-8.61Zm.176 4.823L9.75 4.81l-6.286 6.287a.253.253 0 0 0-.064.108l-.558 1.953 1.953-.558a.253.253 0 0 0 .108-.064Zm1.238-3.763a.25.25 0 0 0-.354 0L10.811 3.75l1.439 1.44 1.263-1.263a.25.25 0 0 0 0-.354Z"})}),"Format & Run"]})]})}const N=E=>E.flatMap(hs),hs=E=>me(ms(E)).map(fs),fs=E=>E.replace(/ +/g," ").trim(),ms=E=>({type:"mandatory_block",items:gE(E,0)[0]}),gE=(E,e,t)=>{const r=[];for(;E[e];){const[T,s]=xs(E,e);if(r.push(T),e=s,E[e]==="|")e++;else if(E[e]==="}"||E[e]==="]"){if(t!==E[e])throw new Error(`Unbalanced parenthesis in: ${E}`);return e++,[r,e]}else if(e===E.length){if(t)throw new Error(`Unbalanced parenthesis in: ${E}`);return[r,e]}else throw new Error(`Unexpected "${E[e]}"`)}return[r,e]},xs=(E,e)=>{const t=[];for(;;){const[r,T]=Gs(E,e);if(r)t.push(r),e=T;else break}return t.length===1?[t[0],e]:[{type:"concatenation",items:t},e]},Gs=(E,e)=>{if(E[e]==="{")return ys(E,e+1);if(E[e]==="[")return Bs(E,e+1);{let t="";for(;E[e]&&/[A-Za-z0-9_ ]/.test(E[e]);)t+=E[e],e++;return[t,e]}},ys=(E,e)=>{const[t,r]=gE(E,e,"}");return[{type:"mandatory_block",items:t},r]},Bs=(E,e)=>{const[t,r]=gE(E,e,"]");return[{type:"optional_block",items:t},r]},me=E=>{if(typeof E=="string")return[E];if(E.type==="concatenation")return E.items.map(me).reduce(gs,[""]);if(E.type==="mandatory_block")return E.items.flatMap(me);if(E.type==="optional_block")return["",...E.items.flatMap(me)];throw new Error(`Unknown node type: ${E}`)},gs=(E,e)=>{const t=[];for(const r of E)for(const T of e)t.push(r+T);return t};var C;(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"})(C=C||(C={}));const qt=E=>({type:C.EOF,raw:"«EOF»",text:"«EOF»",start:E}),ne=qt(1/0),ae=E=>e=>e.type===E.type&&e.text===E.text,se={ARRAY:ae({text:"ARRAY",type:C.RESERVED_DATA_TYPE}),BY:ae({text:"BY",type:C.RESERVED_KEYWORD}),SET:ae({text:"SET",type:C.RESERVED_CLAUSE}),STRUCT:ae({text:"STRUCT",type:C.RESERVED_DATA_TYPE}),WINDOW:ae({text:"WINDOW",type:C.RESERVED_CLAUSE}),VALUES:ae({text:"VALUES",type:C.RESERVED_CLAUSE})},zt=E=>E===C.RESERVED_DATA_TYPE||E===C.RESERVED_KEYWORD||E===C.RESERVED_FUNCTION_NAME||E===C.RESERVED_KEYWORD_PHRASE||E===C.RESERVED_DATA_TYPE_PHRASE||E===C.RESERVED_CLAUSE||E===C.RESERVED_SELECT||E===C.RESERVED_SET_OPERATION||E===C.RESERVED_JOIN||E===C.ARRAY_KEYWORD||E===C.CASE||E===C.END||E===C.WHEN||E===C.ELSE||E===C.THEN||E===C.LIMIT||E===C.BETWEEN||E===C.AND||E===C.OR||E===C.XOR,Hs=E=>E===C.AND||E===C.OR||E===C.XOR,Fs=["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"],bs=["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"],Ys=["ARRAY","BOOL","BYTES","DATE","DATETIME","GEOGRAPHY","INTERVAL","INT64","INT","SMALLINT","INTEGER","BIGINT","TINYINT","BYTEINT","NUMERIC","DECIMAL","BIGNUMERIC","BIGDECIMAL","FLOAT64","STRING","STRUCT","TIME","TIMEZONE"],vs=N(["SELECT [ALL | DISTINCT] [AS STRUCT | AS VALUE]"]),Vs=N(["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"]),qE=N(["CREATE [OR REPLACE] [TEMP|TEMPORARY|SNAPSHOT|EXTERNAL] TABLE [IF NOT EXISTS]"]),Je=N(["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"]),Ws=N(["UNION {ALL | DISTINCT}","EXCEPT DISTINCT","INTERSECT DISTINCT"]),Xs=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN"]),ws=N(["TABLESAMPLE SYSTEM","ANY TYPE","ALL COLUMNS","NOT DETERMINISTIC","{ROWS | RANGE} BETWEEN","IS [NOT] DISTINCT FROM"]),Ks=N([]),$s={name:"bigquery",tokenizerOptions:{reservedSelect:vs,reservedClauses:[...Vs,...Je,...qE],reservedSetOperations:Ws,reservedJoins:Xs,reservedKeywordPhrases:ws,reservedDataTypePhrases:Ks,reservedKeywords:bs,reservedDataTypes:Ys,reservedFunctionNames:Fs,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:ks},formatOptions:{onelineClauses:[...qE,...Je],tabularOnelineClauses:Je}};function ks(E){return js(Js(E))}function js(E){let e=ne;return E.map(t=>t.text==="OFFSET"&&e.text==="["?(e=t,Object.assign(Object.assign({},t),{type:C.RESERVED_FUNCTION_NAME})):(e=t,t))}function Js(E){var e;const t=[];for(let r=0;r<E.length;r++){const T=E[r];if((se.ARRAY(T)||se.STRUCT(T))&&((e=E[r+1])===null||e===void 0?void 0:e.text)==="<"){const s=Qs(E,r+1),R=E.slice(r,s+1);t.push({type:C.IDENTIFIER,raw:R.map(zE("raw")).join(""),text:R.map(zE("text")).join(""),start:T.start}),r=s}else t.push(T)}return t}const zE=E=>e=>e.type===C.IDENTIFIER||e.type===C.COMMA?e[E]+" ":e[E];function Qs(E,e){let t=0;for(let r=e;r<E.length;r++){const T=E[r];if(T.text==="<"?t++:T.text===">"?t--:T.text===">>"&&(t-=2),t===0)return r}return E.length-1}const Zs=["BIT_AND","BIT_OR","BIT_XOR","BLAKE3","CAST","CHARACTER_LENGTH","CHAR_LENGTH","COVAR_POP","COVAR_SAMP","CRC32","CRC32IEEE","CRC64","DATE","DATE_DIFF","DATE_FORMAT","DATE_TRUNC","DAY","DAYOFMONTH","DAYOFWEEK","DAYOFYEAR","FORMAT_BYTES","FQDN","FROM_BASE64","FROM_DAYS","FROM_UNIXTIME","HOUR","INET6_ATON","INET6_NTOA","INET_ATON","INET_NTOA","IPv4CIDRToRange","IPv4NumToString","IPv4NumToStringClassC","IPv4StringToNum","IPv4StringToNumOrDefault","IPv4StringToNumOrNull","IPv4ToIPv6","IPv6CIDRToRange","IPv6NumToString","IPv6StringToNum","IPv6StringToNumOrDefault","IPv6StringToNumOrNull","JSONAllPaths","JSONAllPathsWithTypes","JSONArrayLength","JSONDynamicPaths","JSONDynamicPathsWithTypes","JSONExtract","JSONExtractArrayRaw","JSONExtractArrayRawCaseInsensitive","JSONExtractBool","JSONExtractBoolCaseInsensitive","JSONExtractCaseInsensitive","JSONExtractFloat","JSONExtractFloatCaseInsensitive","JSONExtractInt","JSONExtractIntCaseInsensitive","JSONExtractKeys","JSONExtractKeysAndValues","JSONExtractKeysAndValuesCaseInsensitive","JSONExtractKeysAndValuesRaw","JSONExtractKeysAndValuesRawCaseInsensitive","JSONExtractKeysCaseInsensitive","JSONExtractRaw","JSONExtractRawCaseInsensitive","JSONExtractString","JSONExtractStringCaseInsensitive","JSONExtractUInt","JSONExtractUIntCaseInsensitive","JSONHas","JSONKey","JSONLength","JSONMergePatch","JSONSharedDataPaths","JSONSharedDataPathsWithTypes","JSONType","JSON_ARRAY_LENGTH","JSON_EXISTS","JSON_QUERY","JSON_VALUE","L1Distance","L1Norm","L1Normalize","L2Distance","L2Norm","L2Normalize","L2SquaredDistance","L2SquaredNorm","LAST_DAY","LinfDistance","LinfNorm","LinfNormalize","LpDistance","LpNorm","LpNormalize","MACNumToString","MACStringToNum","MACStringToOUI","MAP_FROM_ARRAYS","MD4","MD5","MILLISECOND","MINUTE","MONTH","OCTET_LENGTH","QUARTER","REGEXP_EXTRACT","REGEXP_MATCHES","REGEXP_REPLACE","RIPEMD160","SCHEMA","SECOND","SHA1","SHA224","SHA256","SHA384","SHA512","SHA512_256","STD","STDDEV_POP","STDDEV_SAMP","ST_LineFromWKB","ST_MLineFromWKB","ST_MPolyFromWKB","ST_PointFromWKB","ST_PolyFromWKB","SUBSTRING_INDEX","SVG","TIMESTAMP_DIFF","TO_BASE64","TO_DAYS","TO_UNIXTIME","ULIDStringToDateTime","URLHash","URLHierarchy","URLPathHierarchy","UTCTimestamp","UTC_timestamp","UUIDNumToString","UUIDStringToNum","UUIDToNum","UUIDv7ToDateTime","VAR_POP","VAR_SAMP","YEAR","YYYYMMDDToDate","YYYYMMDDToDate32","YYYYMMDDhhmmssToDateTime","YYYYMMDDhhmmssToDateTime64","_CAST","__actionName","__bitBoolMaskAnd","__bitBoolMaskOr","__bitSwapLastTwo","__bitWrapperFunc","__getScalar","__patchPartitionID","__scalarSubqueryResult","abs","accurateCast","accurateCastOrDefault","accurateCastOrNull","acos","acosh","addDate","addDays","addHours","addInterval","addMicroseconds","addMilliseconds","addMinutes","addMonths","addNanoseconds","addQuarters","addSeconds","addTupleOfIntervals","addWeeks","addYears","addressToLine","addressToLineWithInlines","addressToSymbol","aes_decrypt_mysql","aes_encrypt_mysql","age","aggThrow","alphaTokens","analysisOfVariance","anova","any","anyHeavy","anyLast","anyLastRespectNulls","anyLast_respect_nulls","anyRespectNulls","anyValueRespectNulls","any_respect_nulls","any_value","any_value_respect_nulls","appendTrailingCharIfAbsent","approx_top_count","approx_top_k","approx_top_sum","argMax","argMin","array","arrayAUC","arrayAUCPR","arrayAll","arrayAvg","arrayCompact","arrayConcat","arrayCount","arrayCumSum","arrayCumSumNonNegative","arrayDifference","arrayDistinct","arrayDotProduct","arrayElement","arrayElementOrNull","arrayEnumerate","arrayEnumerateDense","arrayEnumerateDenseRanked","arrayEnumerateUniq","arrayEnumerateUniqRanked","arrayExists","arrayFill","arrayFilter","arrayFirst","arrayFirstIndex","arrayFirstOrNull","arrayFlatten","arrayFold","arrayIntersect","arrayJaccardIndex","arrayJoin","arrayLast","arrayLastIndex","arrayLastOrNull","arrayLevenshteinDistance","arrayLevenshteinDistanceWeighted","arrayMap","arrayMax","arrayMin","arrayNormalizedGini","arrayPRAUC","arrayPartialReverseSort","arrayPartialShuffle","arrayPartialSort","arrayPopBack","arrayPopFront","arrayProduct","arrayPushBack","arrayPushFront","arrayROCAUC","arrayRandomSample","arrayReduce","arrayReduceInRanges","arrayResize","arrayReverse","arrayReverseFill","arrayReverseSort","arrayReverseSplit","arrayRotateLeft","arrayRotateRight","arrayShiftLeft","arrayShiftRight","arrayShingles","arrayShuffle","arraySimilarity","arraySlice","arraySort","arraySplit","arrayStringConcat","arraySum","arraySymmetricDifference","arrayUnion","arrayUniq","arrayWithConstant","arrayZip","arrayZipUnaligned","array_agg","array_concat_agg","ascii","asin","asinh","assumeNotNull","atan","atan2","atanh","authenticatedUser","avg","avgWeighted","bar","base32Decode","base32Encode","base58Decode","base58Encode","base64Decode","base64Encode","base64URLDecode","base64URLEncode","basename","bech32Decode","bech32Encode","bin","bitAnd","bitCount","bitHammingDistance","bitNot","bitOr","bitPositionsToArray","bitRotateLeft","bitRotateRight","bitShiftLeft","bitShiftRight","bitSlice","bitTest","bitTestAll","bitTestAny","bitXor","bitmapAnd","bitmapAndCardinality","bitmapAndnot","bitmapAndnotCardinality","bitmapBuild","bitmapCardinality","bitmapContains","bitmapHasAll","bitmapHasAny","bitmapMax","bitmapMin","bitmapOr","bitmapOrCardinality","bitmapSubsetInRange","bitmapSubsetLimit","bitmapToArray","bitmapTransform","bitmapXor","bitmapXorCardinality","bitmaskToArray","bitmaskToList","blockNumber","blockSerializedSize","blockSize","boundingRatio","buildId","byteHammingDistance","byteSize","byteSlice","byteSwap","caseWithExpr","caseWithExpression","caseWithoutExpr","caseWithoutExpression","catboostEvaluate","categoricalInformationValue","cbrt","ceil","ceiling","changeDay","changeHour","changeMinute","changeMonth","changeSecond","changeYear","char","cityHash64","clamp","coalesce","colorOKLCHToSRGB","colorSRGBToOKLCH","compareSubstrings","concat","concatAssumeInjective","concatWithSeparator","concatWithSeparatorAssumeInjective","concat_ws","connectionId","connection_id","contingency","convertCharset","corr","corrMatrix","corrStable","cos","cosh","cosineDistance","count","countDigits","countEqual","countMatches","countMatchesCaseInsensitive","countSubstrings","countSubstringsCaseInsensitive","countSubstringsCaseInsensitiveUTF8","covarPop","covarPopMatrix","covarPopStable","covarSamp","covarSampMatrix","covarSampStable","cramersV","cramersVBiasCorrected","curdate","currentDatabase","currentProfiles","currentQueryID","currentRoles","currentSchemas","currentUser","current_database","current_date","current_query_id","current_schemas","current_timestamp","current_user","cutFragment","cutIPv6","cutQueryString","cutQueryStringAndFragment","cutToFirstSignificantSubdomain","cutToFirstSignificantSubdomainCustom","cutToFirstSignificantSubdomainCustomRFC","cutToFirstSignificantSubdomainCustomWithWWW","cutToFirstSignificantSubdomainCustomWithWWWRFC","cutToFirstSignificantSubdomainRFC","cutToFirstSignificantSubdomainWithWWW","cutToFirstSignificantSubdomainWithWWWRFC","cutURLParameter","cutWWW","damerauLevenshteinDistance","dateDiff","dateName","dateTime64ToSnowflake","dateTime64ToSnowflakeID","dateTimeToSnowflake","dateTimeToSnowflakeID","dateTimeToUUIDv7","dateTrunc","date_bin","date_diff","decodeHTMLComponent","decodeURLComponent","decodeURLFormComponent","decodeXMLComponent","decrypt","defaultProfiles","defaultRoles","defaultValueOfArgumentType","defaultValueOfTypeName","degrees","deltaSum","deltaSumTimestamp","demangle","denseRank","dense_rank","detectCharset","detectLanguage","detectLanguageMixed","detectLanguageUnknown","detectProgrammingLanguage","detectTonality","dictGet","dictGetAll","dictGetChildren","dictGetDate","dictGetDateOrDefault","dictGetDateTime","dictGetDateTimeOrDefault","dictGetDescendants","dictGetFloat32","dictGetFloat32OrDefault","dictGetFloat64","dictGetFloat64OrDefault","dictGetHierarchy","dictGetIPv4","dictGetIPv4OrDefault","dictGetIPv6","dictGetIPv6OrDefault","dictGetInt16","dictGetInt16OrDefault","dictGetInt32","dictGetInt32OrDefault","dictGetInt64","dictGetInt64OrDefault","dictGetInt8","dictGetInt8OrDefault","dictGetOrDefault","dictGetOrNull","dictGetString","dictGetStringOrDefault","dictGetUInt16","dictGetUInt16OrDefault","dictGetUInt32","dictGetUInt32OrDefault","dictGetUInt64","dictGetUInt64OrDefault","dictGetUInt8","dictGetUInt8OrDefault","dictGetUUID","dictGetUUIDOrDefault","dictHas","dictIsIn","displayName","distanceL1","distanceL2","distanceL2Squared","distanceLinf","distanceLp","distinctDynamicTypes","distinctJSONPaths","distinctJSONPathsAndTypes","divide","divideDecimal","divideOrNull","domain","domainRFC","domainWithoutWWW","domainWithoutWWWRFC","dotProduct","dumpColumnStructure","dynamicElement","dynamicType","e","editDistance","editDistanceUTF8","empty","emptyArrayDate","emptyArrayDateTime","emptyArrayFloat32","emptyArrayFloat64","emptyArrayInt16","emptyArrayInt32","emptyArrayInt64","emptyArrayInt8","emptyArrayString","emptyArrayToSingle","emptyArrayUInt16","emptyArrayUInt32","emptyArrayUInt64","emptyArrayUInt8","enabledProfiles","enabledRoles","encodeURLComponent","encodeURLFormComponent","encodeXMLComponent","encrypt","endsWith","endsWithUTF8","entropy","equals","erf","erfc","errorCodeToName","estimateCompressionRatio","evalMLMethod","exp","exp10","exp2","exponentialMovingAverage","exponentialTimeDecayedAvg","exponentialTimeDecayedCount","exponentialTimeDecayedMax","exponentialTimeDecayedSum","extract","extractAll","extractAllGroups","extractAllGroupsHorizontal","extractAllGroupsVertical","extractGroups","extractKeyValuePairs","extractKeyValuePairsWithEscaping","extractTextFromHTML","extractURLParameter","extractURLParameterNames","extractURLParameters","factorial","farmFingerprint64","farmHash64","file","filesystemAvailable","filesystemCapacity","filesystemUnreserved","finalizeAggregation","financialInternalRateOfReturn","financialInternalRateOfReturnExtended","financialNetPresentValue","financialNetPresentValueExtended","firstLine","firstSignificantSubdomain","firstSignificantSubdomainCustom","firstSignificantSubdomainCustomRFC","firstSignificantSubdomainRFC","firstValueRespectNulls","first_value","first_value_respect_nulls","flameGraph","flatten","flattenTuple","floor","formatDateTime","formatDateTimeInJodaSyntax","formatQuery","formatQueryOrNull","formatQuerySingleLine","formatQuerySingleLineOrNull","formatReadableDecimalSize","formatReadableQuantity","formatReadableSize","formatReadableTimeDelta","formatRow","formatRowNoNewline","fragment","fromDaysSinceYearZero","fromDaysSinceYearZero32","fromModifiedJulianDay","fromModifiedJulianDayOrNull","fromUTCTimestamp","fromUnixTimestamp","fromUnixTimestamp64Micro","fromUnixTimestamp64Milli","fromUnixTimestamp64Nano","fromUnixTimestamp64Second","fromUnixTimestampInJodaSyntax","from_utc_timestamp","fullHostName","fuzzBits","gccMurmurHash","gcd","generateRandomStructure","generateSerialID","generateSnowflakeID","generateULID","generateUUIDv4","generateUUIDv7","geoDistance","geoToH3","geoToS2","geohashDecode","geohashEncode","geohashesInBox","getClientHTTPHeader","getMacro","getMaxTableNameLengthForDatabase","getMergeTreeSetting","getOSKernelVersion","getServerPort","getServerSetting","getSetting","getSettingOrDefault","getSizeOfEnumType","getSubcolumn","getTypeSerializationStreams","globalIn","globalInIgnoreSet","globalNotIn","globalNotInIgnoreSet","globalNotNullIn","globalNotNullInIgnoreSet","globalNullIn","globalNullInIgnoreSet","globalVariable","greatCircleAngle","greatCircleDistance","greater","greaterOrEquals","greatest","groupArray","groupArrayInsertAt","groupArrayIntersect","groupArrayLast","groupArrayMovingAvg","groupArrayMovingSum","groupArraySample","groupArraySorted","groupBitAnd","groupBitOr","groupBitXor","groupBitmap","groupBitmapAnd","groupBitmapOr","groupBitmapXor","groupConcat","groupNumericIndexedVector","groupUniqArray","group_concat","h3CellAreaM2","h3CellAreaRads2","h3Distance","h3EdgeAngle","h3EdgeLengthKm","h3EdgeLengthM","h3ExactEdgeLengthKm","h3ExactEdgeLengthM","h3ExactEdgeLengthRads","h3GetBaseCell","h3GetDestinationIndexFromUnidirectionalEdge","h3GetFaces","h3GetIndexesFromUnidirectionalEdge","h3GetOriginIndexFromUnidirectionalEdge","h3GetPentagonIndexes","h3GetRes0Indexes","h3GetResolution","h3GetUnidirectionalEdge","h3GetUnidirectionalEdgeBoundary","h3GetUnidirectionalEdgesFromHexagon","h3HexAreaKm2","h3HexAreaM2","h3HexRing","h3IndexesAreNeighbors","h3IsPentagon","h3IsResClassIII","h3IsValid","h3Line","h3NumHexagons","h3PointDistKm","h3PointDistM","h3PointDistRads","h3ToCenterChild","h3ToChildren","h3ToGeo","h3ToGeoBoundary","h3ToParent","h3ToString","h3UnidirectionalEdgeIsValid","h3kRing","halfMD5","has","hasAll","hasAny","hasColumnInTable","hasSubsequence","hasSubsequenceCaseInsensitive","hasSubsequenceCaseInsensitiveUTF8","hasSubsequenceUTF8","hasSubstr","hasThreadFuzzer","hasToken","hasTokenCaseInsensitive","hasTokenCaseInsensitiveOrNull","hasTokenOrNull","hex","hilbertDecode","hilbertEncode","histogram","hiveHash","hop","hopEnd","hopStart","hostName","hostname","hypot","icebergBucket","icebergHash","icebergTruncate","identity","idnaDecode","idnaEncode","if","ifNotFinite","ifNull","ignore","inIgnoreSet","indexHint","indexOf","indexOfAssumeSorted","initcap","initcapUTF8","initialQueryID","initialQueryStartTime","initial_query_id","initial_query_start_time","initializeAggregation","instr","intDiv","intDivOrNull","intDivOrZero","intExp10","intExp2","intHash32","intHash64","intervalLengthSum","isConstant","isDecimalOverflow","isDynamicElementInSharedData","isFinite","isIPAddressInRange","isIPv4String","isIPv6String","isInfinite","isMergeTreePartCoveredBy","isNaN","isNotDistinctFrom","isNotNull","isNull","isNullable","isValidJSON","isValidUTF8","isZeroOrNull","jaroSimilarity","jaroWinklerSimilarity","javaHash","javaHashUTF16LE","joinGet","joinGetOrNull","jsonMergePatch","jumpConsistentHash","kafkaMurmurHash","keccak256","kolmogorovSmirnovTest","kostikConsistentHash","kql_array_sort_asc","kql_array_sort_desc","kurtPop","kurtSamp","lag","lagInFrame","largestTriangleThreeBuckets","lastValueRespectNulls","last_value","last_value_respect_nulls","lcase","lcm","lead","leadInFrame","least","left","leftPad","leftPadUTF8","leftUTF8","lemmatize","length","lengthUTF8","less","lessOrEquals","levenshteinDistance","levenshteinDistanceUTF8","lgamma","ln","locate","log","log10","log1p","log2","logTrace","lowCardinalityIndices","lowCardinalityKeys","lower","lowerUTF8","lpad","ltrim","lttb","makeDate","makeDate32","makeDateTime","makeDateTime64","mannWhitneyUTest","map","mapAdd","mapAll","mapApply","mapConcat","mapContains","mapContainsKey","mapContainsKeyLike","mapContainsValue","mapContainsValueLike","mapExists","mapExtractKeyLike","mapExtractValueLike","mapFilter","mapFromArrays","mapFromString","mapKeys","mapPartialReverseSort","mapPartialSort","mapPopulateSeries","mapReverseSort","mapSort","mapSubtract","mapUpdate","mapValues","match","materialize","max","max2","maxIntersections","maxIntersectionsPosition","maxMappedArrays","meanZTest","median","medianBFloat16","medianBFloat16Weighted","medianDD","medianDeterministic","medianExact","medianExactHigh","medianExactLow","medianExactWeighted","medianExactWeightedInterpolated","medianGK","medianInterpolatedWeighted","medianTDigest","medianTDigestWeighted","medianTiming","medianTimingWeighted","mergeTreePartInfo","metroHash64","mid","min","min2","minMappedArrays","minSampleSizeContinous","minSampleSizeContinuous","minSampleSizeConversion","minus","mismatches","mod","modOrNull","modulo","moduloLegacy","moduloOrNull","moduloOrZero","monthName","mortonDecode","mortonEncode","multiFuzzyMatchAllIndices","multiFuzzyMatchAny","multiFuzzyMatchAnyIndex","multiIf","multiMatchAllIndices","multiMatchAny","multiMatchAnyIndex","multiSearchAllPositions","multiSearchAllPositionsCaseInsensitive","multiSearchAllPositionsCaseInsensitiveUTF8","multiSearchAllPositionsUTF8","multiSearchAny","multiSearchAnyCaseInsensitive","multiSearchAnyCaseInsensitiveUTF8","multiSearchAnyUTF8","multiSearchFirstIndex","multiSearchFirstIndexCaseInsensitive","multiSearchFirstIndexCaseInsensitiveUTF8","multiSearchFirstIndexUTF8","multiSearchFirstPosition","multiSearchFirstPositionCaseInsensitive","multiSearchFirstPositionCaseInsensitiveUTF8","multiSearchFirstPositionUTF8","multiply","multiplyDecimal","murmurHash2_32","murmurHash2_64","murmurHash3_128","murmurHash3_32","murmurHash3_64","negate","neighbor","nested","netloc","ngramDistance","ngramDistanceCaseInsensitive","ngramDistanceCaseInsensitiveUTF8","ngramDistanceUTF8","ngramMinHash","ngramMinHashArg","ngramMinHashArgCaseInsensitive","ngramMinHashArgCaseInsensitiveUTF8","ngramMinHashArgUTF8","ngramMinHashCaseInsensitive","ngramMinHashCaseInsensitiveUTF8","ngramMinHashUTF8","ngramSearch","ngramSearchCaseInsensitive","ngramSearchCaseInsensitiveUTF8","ngramSearchUTF8","ngramSimHash","ngramSimHashCaseInsensitive","ngramSimHashCaseInsensitiveUTF8","ngramSimHashUTF8","ngrams","nonNegativeDerivative","normL1","normL2","normL2Squared","normLinf","normLp","normalizeL1","normalizeL2","normalizeLinf","normalizeLp","normalizeQuery","normalizeQueryKeepNames","normalizeUTF8NFC","normalizeUTF8NFD","normalizeUTF8NFKC","normalizeUTF8NFKD","normalizedQueryHash","normalizedQueryHashKeepNames","notEmpty","notEquals","notILike","notIn","notInIgnoreSet","notLike","notNullIn","notNullInIgnoreSet","nothing","nothingNull","nothingUInt64","now","now64","nowInBlock","nowInBlock64","nth_value","ntile","nullIf","nullIn","nullInIgnoreSet","numbers","numericIndexedVectorAllValueSum","numericIndexedVectorBuild","numericIndexedVectorCardinality","numericIndexedVectorGetValue","numericIndexedVectorPointwiseAdd","numericIndexedVectorPointwiseDivide","numericIndexedVectorPointwiseEqual","numericIndexedVectorPointwiseGreater","numericIndexedVectorPointwiseGreaterEqual","numericIndexedVectorPointwiseLess","numericIndexedVectorPointwiseLessEqual","numericIndexedVectorPointwiseMultiply","numericIndexedVectorPointwiseNotEqual","numericIndexedVectorPointwiseSubtract","numericIndexedVectorShortDebugString","numericIndexedVectorToMap","overlay","overlayUTF8","parseDateTime","parseDateTime32BestEffort","parseDateTime32BestEffortOrNull","parseDateTime32BestEffortOrZero","parseDateTime64","parseDateTime64BestEffort","parseDateTime64BestEffortOrNull","parseDateTime64BestEffortOrZero","parseDateTime64BestEffortUS","parseDateTime64BestEffortUSOrNull","parseDateTime64BestEffortUSOrZero","parseDateTime64InJodaSyntax","parseDateTime64InJodaSyntaxOrNull","parseDateTime64InJodaSyntaxOrZero","parseDateTime64OrNull","parseDateTime64OrZero","parseDateTimeBestEffort","parseDateTimeBestEffortOrNull","parseDateTimeBestEffortOrZero","parseDateTimeBestEffortUS","parseDateTimeBestEffortUSOrNull","parseDateTimeBestEffortUSOrZero","parseDateTimeInJodaSyntax","parseDateTimeInJodaSyntaxOrNull","parseDateTimeInJodaSyntaxOrZero","parseDateTimeOrNull","parseDateTimeOrZero","parseReadableSize","parseReadableSizeOrNull","parseReadableSizeOrZero","parseTimeDelta","partitionID","partitionId","path","pathFull","percentRank","percent_rank","pi","plus","pmod","pmodOrNull","pointInEllipses","pointInPolygon","polygonAreaCartesian","polygonAreaSpherical","polygonConvexHullCartesian","polygonPerimeterCartesian","polygonPerimeterSpherical","polygonsDistanceCartesian","polygonsDistanceSpherical","polygonsEqualsCartesian","polygonsIntersectCartesian","polygonsIntersectSpherical","polygonsIntersectionCartesian","polygonsIntersectionSpherical","polygonsSymDifferenceCartesian","polygonsSymDifferenceSpherical","polygonsUnionCartesian","polygonsUnionSpherical","polygonsWithinCartesian","polygonsWithinSpherical","port","portRFC","position","positionCaseInsensitive","positionCaseInsensitiveUTF8","positionUTF8","positiveModulo","positiveModuloOrNull","positive_modulo","positive_modulo_or_null","pow","power","printf","proportionsZTest","protocol","punycodeDecode","punycodeEncode","quantile","quantileBFloat16","quantileBFloat16Weighted","quantileDD","quantileDeterministic","quantileExact","quantileExactExclusive","quantileExactHigh","quantileExactInclusive","quantileExactLow","quantileExactWeighted","quantileExactWeightedInterpolated","quantileGK","quantileInterpolatedWeighted","quantileTDigest","quantileTDigestWeighted","quantileTiming","quantileTimingWeighted","quantiles","quantilesBFloat16","quantilesBFloat16Weighted","quantilesDD","quantilesDeterministic","quantilesExact","quantilesExactExclusive","quantilesExactHigh","quantilesExactInclusive","quantilesExactLow","quantilesExactWeighted","quantilesExactWeightedInterpolated","quantilesGK","quantilesInterpolatedWeighted","quantilesTDigest","quantilesTDigestWeighted","quantilesTiming","quantilesTimingWeighted","queryID","queryString","queryStringAndFragment","query_id","radians","rand","rand32","rand64","randBernoulli","randBinomial","randCanonical","randChiSquared","randConstant","randExponential","randFisherF","randLogNormal","randNegativeBinomial","randNormal","randPoisson","randStudentT","randUniform","randomFixedString","randomPrintableASCII","randomString","randomStringUTF8","rank","rankCorr","readWKBLineString","readWKBMultiLineString","readWKBMultiPolygon","readWKBPoint","readWKBPolygon","readWKTLineString","readWKTMultiLineString","readWKTMultiPolygon","readWKTPoint","readWKTPolygon","readWKTRing","regexpExtract","regexpQuoteMeta","regionHierarchy","regionIn","regionToArea","regionToCity","regionToContinent","regionToCountry","regionToDistrict","regionToName","regionToPopulation","regionToTopContinent","reinterpret","reinterpretAsDate","reinterpretAsDateTime","reinterpretAsFixedString","reinterpretAsFloat32","reinterpretAsFloat64","reinterpretAsInt128","reinterpretAsInt16","reinterpretAsInt256","reinterpretAsInt32","reinterpretAsInt64","reinterpretAsInt8","reinterpretAsString","reinterpretAsUInt128","reinterpretAsUInt16","reinterpretAsUInt256","reinterpretAsUInt32","reinterpretAsUInt64","reinterpretAsUInt8","reinterpretAsUUID","repeat","replace","replaceAll","replaceOne","replaceRegexpAll","replaceRegexpOne","replicate","retention","reverse","reverseUTF8","revision","right","rightPad","rightPadUTF8","rightUTF8","round","roundAge","roundBankers","roundDown","roundDuration","roundToExp2","rowNumberInAllBlocks","rowNumberInBlock","row_number","rpad","rtrim","runningAccumulate","runningConcurrency","runningDifference","runningDifferenceStartingWithFirstValue","s2CapContains","s2CapUnion","s2CellsIntersect","s2GetNeighbors","s2RectAdd","s2RectContains","s2RectIntersection","s2RectUnion","s2ToGeo","scalarProduct","searchAll","searchAny","sequenceCount","sequenceMatch","sequenceMatchEvents","sequenceNextNode","seriesDecomposeSTL","seriesOutliersDetectTukey","seriesPeriodDetectFFT","serverTimeZone","serverTimezone","serverUUID","shardCount","shardNum","showCertificate","sigmoid","sign","simpleJSONExtractBool","simpleJSONExtractFloat","simpleJSONExtractInt","simpleJSONExtractRaw","simpleJSONExtractString","simpleJSONExtractUInt","simpleJSONHas","simpleLinearRegression","sin","singleValueOrNull","sinh","sipHash128","sipHash128Keyed","sipHash128Reference","sipHash128ReferenceKeyed","sipHash64","sipHash64Keyed","skewPop","skewSamp","sleep","sleepEachRow","snowflakeIDToDateTime","snowflakeIDToDateTime64","snowflakeToDateTime","snowflakeToDateTime64","soundex","space","sparkBar","sparkbar","sparseGrams","sparseGramsHashes","sparseGramsHashesUTF8","sparseGramsUTF8","splitByAlpha","splitByChar","splitByNonAlpha","splitByRegexp","splitByString","splitByWhitespace","sqid","sqidDecode","sqidEncode","sqrt","startsWith","startsWithUTF8","stddevPop","stddevPopStable","stddevSamp","stddevSampStable","stem","stochasticLinearRegression","stochasticLogisticRegression","str_to_date","str_to_map","stringBytesEntropy","stringBytesUniq","stringJaccardIndex","stringJaccardIndexUTF8","stringToH3","structureToCapnProtoSchema","structureToProtobufSchema","studentTTest","subBitmap","subDate","substr","substring","substringIndex","substringIndexUTF8","substringUTF8","subtractDays","subtractHours","subtractInterval","subtractMicroseconds","subtractMilliseconds","subtractMinutes","subtractMonths","subtractNanoseconds","subtractQuarters","subtractSeconds","subtractTupleOfIntervals","subtractWeeks","subtractYears","sum","sumCount","sumKahan","sumMapFiltered","sumMapFilteredWithOverflow","sumMapWithOverflow","sumMappedArrays","sumWithOverflow","svg","synonyms","tan","tanh","tcpPort","tgamma","theilsU","throwIf","tid","timeDiff","timeSeriesDeltaToGrid","timeSeriesDerivToGrid","timeSeriesFromGrid","timeSeriesGroupArray","timeSeriesIdToTags","timeSeriesIdToTagsGroup","timeSeriesIdeltaToGrid","timeSeriesInstantDeltaToGrid","timeSeriesInstantRateToGrid","timeSeriesIrateToGrid","timeSeriesLastToGrid","timeSeriesLastTwoSamples","timeSeriesPredictLinearToGrid","timeSeriesRange","timeSeriesRateToGrid","timeSeriesResampleToGridWithStaleness","timeSeriesStoreTags","timeSeriesTagsGroupToTags","timeSlot","timeSlots","timeZone","timeZoneOf","timeZoneOffset","time_bucket","timestamp","timestampDiff","timestamp_diff","timezone","timezoneOf","timezoneOffset","toBFloat16","toBFloat16OrNull","toBFloat16OrZero","toBool","toColumnTypeName","toDate","toDate32","toDate32OrDefault","toDate32OrNull","toDate32OrZero","toDateOrDefault","toDateOrNull","toDateOrZero","toDateTime","toDateTime32","toDateTime64","toDateTime64OrDefault","toDateTime64OrNull","toDateTime64OrZero","toDateTimeOrDefault","toDateTimeOrNull","toDateTimeOrZero","toDayOfMonth","toDayOfWeek","toDayOfYear","toDaysSinceYearZero","toDecimal128","toDecimal128OrDefault","toDecimal128OrNull","toDecimal128OrZero","toDecimal256","toDecimal256OrDefault","toDecimal256OrNull","toDecimal256OrZero","toDecimal32","toDecimal32OrDefault","toDecimal32OrNull","toDecimal32OrZero","toDecimal64","toDecimal64OrDefault","toDecimal64OrNull","toDecimal64OrZero","toDecimalString","toFixedString","toFloat32","toFloat32OrDefault","toFloat32OrNull","toFloat32OrZero","toFloat64","toFloat64OrDefault","toFloat64OrNull","toFloat64OrZero","toHour","toIPv4","toIPv4OrDefault","toIPv4OrNull","toIPv4OrZero","toIPv6","toIPv6OrDefault","toIPv6OrNull","toIPv6OrZero","toISOWeek","toISOYear","toInt128","toInt128OrDefault","toInt128OrNull","toInt128OrZero","toInt16","toInt16OrDefault","toInt16OrNull","toInt16OrZero","toInt256","toInt256OrDefault","toInt256OrNull","toInt256OrZero","toInt32","toInt32OrDefault","toInt32OrNull","toInt32OrZero","toInt64","toInt64OrDefault","toInt64OrNull","toInt64OrZero","toInt8","toInt8OrDefault","toInt8OrNull","toInt8OrZero","toInterval","toIntervalDay","toIntervalHour","toIntervalMicrosecond","toIntervalMillisecond","toIntervalMinute","toIntervalMonth","toIntervalNanosecond","toIntervalQuarter","toIntervalSecond","toIntervalWeek","toIntervalYear","toJSONString","toLastDayOfMonth","toLastDayOfWeek","toLowCardinality","toMillisecond","toMinute","toModifiedJulianDay","toModifiedJulianDayOrNull","toMonday","toMonth","toMonthNumSinceEpoch","toNullable","toQuarter","toRelativeDayNum","toRelativeHourNum","toRelativeMinuteNum","toRelativeMonthNum","toRelativeQuarterNum","toRelativeSecondNum","toRelativeWeekNum","toRelativeYearNum","toSecond","toStartOfDay","toStartOfFifteenMinutes","toStartOfFiveMinute","toStartOfFiveMinutes","toStartOfHour","toStartOfISOYear","toStartOfInterval","toStartOfMicrosecond","toStartOfMillisecond","toStartOfMinute","toStartOfMonth","toStartOfNanosecond","toStartOfQuarter","toStartOfSecond","toStartOfTenMinutes","toStartOfWeek","toStartOfYear","toString","toStringCutToZero","toTime","toTime64","toTime64OrNull","toTime64OrZero","toTimeOrNull","toTimeOrZero","toTimeWithFixedDate","toTimeZone","toTimezone","toTypeName","toUInt128","toUInt128OrDefault","toUInt128OrNull","toUInt128OrZero","toUInt16","toUInt16OrDefault","toUInt16OrNull","toUInt16OrZero","toUInt256","toUInt256OrDefault","toUInt256OrNull","toUInt256OrZero","toUInt32","toUInt32OrDefault","toUInt32OrNull","toUInt32OrZero","toUInt64","toUInt64OrDefault","toUInt64OrNull","toUInt64OrZero","toUInt8","toUInt8OrDefault","toUInt8OrNull","toUInt8OrZero","toUTCTimestamp","toUUID","toUUIDOrDefault","toUUIDOrNull","toUUIDOrZero","toUnixTimestamp","toUnixTimestamp64Micro","toUnixTimestamp64Milli","toUnixTimestamp64Nano","toUnixTimestamp64Second","toValidUTF8","toWeek","toYYYYMM","toYYYYMMDD","toYYYYMMDDhhmmss","toYear","toYearNumSinceEpoch","toYearWeek","to_utc_timestamp","today","tokens","topK","topKWeighted","topLevelDomain","topLevelDomainRFC","transactionID","transactionLatestSnapshot","transactionOldestSnapshot","transform","translate","translateUTF8","trim","trimBoth","trimLeft","trimRight","trunc","tryBase32Decode","tryBase58Decode","tryBase64Decode","tryBase64URLDecode","tryDecrypt","tryIdnaEncode","tryPunycodeDecode","tumble","tumbleEnd","tumbleStart","tuple","tupleConcat","tupleDivide","tupleDivideByNumber","tupleElement","tupleHammingDistance","tupleIntDiv","tupleIntDivByNumber","tupleIntDivOrZero","tupleIntDivOrZeroByNumber","tupleMinus","tupleModulo","tupleModuloByNumber","tupleMultiply","tupleMultiplyByNumber","tupleNames","tupleNegate","tuplePlus","tupleToNameValuePairs","ucase","unbin","unhex","uniq","uniqCombined","uniqCombined64","uniqExact","uniqHLL12","uniqTheta","uniqThetaIntersect","uniqThetaNot","uniqThetaUnion","uniqUpTo","upper","upperUTF8","uptime","user","validateNestedArraySizes","varPop","varPopStable","varSamp","varSampStable","variantElement","variantType","vectorDifference","vectorSum","version","visibleWidth","visitParamExtractBool","visitParamExtractFloat","visitParamExtractInt","visitParamExtractRaw","visitParamExtractString","visitParamExtractUInt","visitParamHas","week","welchTTest","widthBucket","width_bucket","windowFunnel","windowID","wkb","wkt","wordShingleMinHash","wordShingleMinHashArg","wordShingleMinHashArgCaseInsensitive","wordShingleMinHashArgCaseInsensitiveUTF8","wordShingleMinHashArgUTF8","wordShingleMinHashCaseInsensitive","wordShingleMinHashCaseInsensitiveUTF8","wordShingleMinHashUTF8","wordShingleSimHash","wordShingleSimHashCaseInsensitive","wordShingleSimHashCaseInsensitiveUTF8","wordShingleSimHashUTF8","wyHash64","xor","xxHash32","xxHash64","xxh3","yandexConsistentHash","yearweek","yesterday","zookeeperSessionUptime","MergeTree","ReplacingMergeTree","SummingMergeTree","AggregatingMergeTree","CollapsingMergeTree","VersionedCollapsingMergeTree","GraphiteMergeTree","CoalescingMergeTree","Atomic","Shared","Lazy","Replicated","PostgreSQL","MySQL","SQLite","MaterializedPostgreSQL","DataLakeCatalog"],qs=["ACCESS","ACTION","ADD","ADMIN","AFTER","ALGORITHM","ALIAS","ALL","ALLOWED_LATENESS","ALTER","AND","ANTI","APPEND","APPLY","AS","ASC","ASCENDING","ASOF","ASSUME","AST","ASYNC","ATTACH","AUTO_INCREMENT","AZURE","BACKUP","BAGEXPANSION","BASE_BACKUP","BCRYPT_HASH","BCRYPT_PASSWORD","BEGIN","BETWEEN","BIDIRECTIONAL","BOTH","BY","CACHE","CACHES","CASCADE","CASE","CHANGE","CHANGEABLE_IN_READONLY","CHANGED","CHARACTER","CHECK","CLEANUP","CLEAR","CLUSTER","CLUSTERS","CLUSTER_HOST_IDS","CN","CODEC","COLLATE","COLLECTION","COLUMN","COLUMNS","COMMENT","COMMIT","COMPRESSION","CONST","CONSTRAINT","CREATE","CROSS","CUBE","CURRENT","D","DATA","DATABASE","DATABASES","DAYS","DD","DDL","DEDUPLICATE","DEFAULT","DEFINER","DELAY","DELETE","DELETED","DEPENDS","DESC","DESCENDING","DESCRIBE","DETACH","DETACHED","DICTIONARIES","DICTIONARY","DISK","DISTINCT","DIV","DOUBLE_SHA1_HASH","DOUBLE_SHA1_PASSWORD","DROP","ELSE","ENABLED","END","ENFORCED","ENGINE","ENGINES","EPHEMERAL","ESTIMATE","EVENT","EVENTS","EVERY","EXCEPT","EXCHANGE","EXISTS","EXPLAIN","EXPRESSION","EXTENDED","EXTERNAL","FAKE","FALSE","FETCH","FIELDS","FILESYSTEM","FILL","FILTER","FINAL","FIRST","FOLLOWING","FOR","FOREIGN","FORMAT","FREEZE","FROM","FULL","FULLTEXT","FUNCTION","FUNCTIONS","GLOBAL","GRANT","GRANTEES","GRANTS","GRANULARITY","GROUP","GROUPING","GROUPS","H","HASH","HAVING","HDFS","HH","HIERARCHICAL","HOST","HOURS","HTTP","IDENTIFIED","ILIKE","IN","INDEX","INDEXES","INDICES","INFILE","INHERIT","INJECTIVE","INNER","INSERT","INTERPOLATE","INTERSECT","INTERVAL","INTO","INVISIBLE","INVOKER","IP","IS","IS_OBJECT_ID","JOIN","JWT","KERBEROS","KEY","KEYED","KEYS","KILL","KIND","LARGE","LAST","LAYOUT","LDAP","LEADING","LEVEL","LIFETIME","LIGHTWEIGHT","LIKE","LIMIT","LIMITS","LINEAR","LIST","LIVE","LOCAL","M","MASK","MATERIALIZED","MCS","MEMORY","MERGES","METRICS","MI","MICROSECOND","MICROSECONDS","MILLISECONDS","MINUTES","MM","MODIFY","MONTHS","MOVE","MS","MUTATION","N","NAME","NAMED","NANOSECOND","NANOSECONDS","NEXT","NO","NONE","NOT","NO_PASSWORD","NS","NULL","NULLS","OBJECT","OFFSET","ON","ONLY","OPTIMIZE","OPTION","OR","ORDER","OUTER","OUTFILE","OVER","OVERRIDABLE","OVERRIDE","PART","PARTIAL","PARTITION","PARTITIONS","PART_MOVE_TO_SHARD","PASTE","PERIODIC","PERMANENTLY","PERMISSIVE","PERSISTENT","PIPELINE","PLAINTEXT_PASSWORD","PLAN","POLICY","POPULATE","PRECEDING","PRECISION","PREWHERE","PRIMARY","PRIVILEGES","PROCESSLIST","PROFILE","PROJECTION","PROTOBUF","PULL","Q","QQ","QUALIFY","QUARTERS","QUERY","QUOTA","RANDOMIZE","RANDOMIZED","RANGE","READONLY","REALM","RECOMPRESS","RECURSIVE","REFERENCES","REFRESH","REGEXP","REMOVE","RENAME","RESET","RESPECT","RESTORE","RESTRICT","RESTRICTIVE","RESUME","REVOKE","ROLE","ROLES","ROLLBACK","ROLLUP","ROW","ROWS","S","S3","SALT","SAMPLE","SAN","SCHEME","SECONDS","SECURITY","SELECT","SEMI","SEQUENTIAL","SERVER","SET","SETS","SETTING","SETTINGS","SHA256_HASH","SHA256_PASSWORD","SHARD","SHOW","SIGNED","SIMPLE","SNAPSHOT","SOURCE","SPATIAL","SQL","SQL_TSI_DAY","SQL_TSI_HOUR","SQL_TSI_MICROSECOND","SQL_TSI_MILLISECOND","SQL_TSI_MINUTE","SQL_TSI_MONTH","SQL_TSI_NANOSECOND","SQL_TSI_QUARTER","SQL_TSI_SECOND","SQL_TSI_WEEK","SQL_TSI_YEAR","SS","SSH_KEY","SSL_CERTIFICATE","STALENESS","START","STATISTICS","STDOUT","STEP","STORAGE","STRICT","STRICTLY_ASCENDING","SUBPARTITION","SUBPARTITIONS","SUSPEND","SYNC","SYNTAX","SYSTEM","TABLE","TABLES","TAGS","TEMPORARY","TEST","THAN","THEN","TIES","TIME","TO","TOP","TOTALS","TRACKING","TRAILING","TRANSACTION","TREE","TRIGGER","TRUE","TRUNCATE","TTL","TYPE","TYPEOF","UNBOUNDED","UNDROP","UNFREEZE","UNION","UNIQUE","UNSET","UNSIGNED","UNTIL","UPDATE","URL","USE","USING","UUID","VALID","VALUES","VARYING","VIEW","VISIBLE","VOLUME","WATCH","WATERMARK","WEEKS","WHEN","WHERE","WINDOW","WITH","WITH_ITEMINDEX","WK","WRITABLE","WW","YEARS","YY","YYYY","ZKPATH"],zs=["AGGREGATEFUNCTION","ARRAY","BFLOAT16","BIGINT","BIGINT SIGNED","BIGINT UNSIGNED","BINARY","BINARY LARGE OBJECT","BINARY VARYING","BIT","BLOB","BYTE","BYTEA","BOOL","CHAR","CHAR LARGE OBJECT","CHAR VARYING","CHARACTER","CHARACTER LARGE OBJECT","CHARACTER VARYING","CLOB","DEC","DOUBLE","DOUBLE PRECISION","DATE","DATE32","DATETIME","DATETIME32","DATETIME64","DECIMAL","DECIMAL128","DECIMAL256","DECIMAL32","DECIMAL64","DYNAMIC","ENUM","ENUM","ENUM16","ENUM8","FIXED","FLOAT","FIXEDSTRING","FLOAT32","FLOAT64","GEOMETRY","INET4","INET6","INT","INT SIGNED","INT UNSIGNED","INT1","INT1 SIGNED","INT1 UNSIGNED","INTEGER","INTEGER SIGNED","INTEGER UNSIGNED","IPV4","IPV6","INT128","INT16","INT256","INT32","INT64","INT8","INTERVALDAY","INTERVALHOUR","INTERVALMICROSECOND","INTERVALMILLISECOND","INTERVALMINUTE","INTERVALMONTH","INTERVALNANOSECOND","INTERVALQUARTER","INTERVALSECOND","INTERVALWEEK","INTERVALYEAR","JSON","LONGBLOB","LONGTEXT","LINESTRING","LOWCARDINALITY","MEDIUMBLOB","MEDIUMINT","MEDIUMINT SIGNED","MEDIUMINT UNSIGNED","MEDIUMTEXT","MAP","MULTILINESTRING","MULTIPOLYGON","NATIONAL CHAR","NATIONAL CHAR VARYING","NATIONAL CHARACTER","NATIONAL CHARACTER LARGE OBJECT","NATIONAL CHARACTER VARYING","NCHAR","NCHAR LARGE OBJECT","NCHAR VARYING","NUMERIC","NVARCHAR","NESTED","NOTHING","NULLABLE","OBJECT","POINT","POLYGON","REAL","RING","SET","SIGNED","SINGLE","SMALLINT","SMALLINT SIGNED","SMALLINT UNSIGNED","SIMPLEAGGREGATEFUNCTION","STRING","TEXT","TIMESTAMP","TINYBLOB","TINYINT","TINYINT SIGNED","TINYINT UNSIGNED","TINYTEXT","TIME","TIME64","TUPLE","UINT128","UINT16","UINT256","UINT32","UINT64","UINT8","UNSIGNED","UUID","VARBINARY","VARCHAR","VARCHAR2","VARIANT","YEAR","BOOL","BOOLEAN"],eR=N(["SELECT [DISTINCT]","MODIFY QUERY SELECT [DISTINCT]"]),ER=N(["SET","WITH","FROM","SAMPLE","PREWHERE","WHERE","GROUP BY","HAVING","QUALIFY","ORDER BY","LIMIT","SETTINGS","INTO OUTFILE","FORMAT","WINDOW","PARTITION BY","INSERT INTO","VALUES","DEPENDS ON","MOVE {USER | ROLE | QUOTA | SETTINGS PROFILE | ROW POLICY}","GRANT","REVOKE","CHECK GRANT","SET [DEFAULT] ROLE [NONE | ALL | ALL EXCEPT]","DEDUPLICATE BY","MODIFY STATISTICS","TYPE","ALTER USER [IF EXISTS]","ALTER [ROW] POLICY [IF EXISTS]","DROP {USER | ROLE | QUOTA | PROFILE | SETTINGS PROFILE | ROW POLICY | POLICY} [IF EXISTS]"]),et=N(["CREATE [OR REPLACE] [TEMPORARY] TABLE [IF NOT EXISTS]"]),Qe=N(["ALL EXCEPT","ON CLUSTER","UPDATE","SYSTEM RELOAD {DICTIONARIES | DICTIONARY | FUNCTIONS | FUNCTION | ASYNCHRONOUS METRICS}","SYSTEM DROP {DNS CACHE | MARK CACHE | ICEBERG METADATA CACHE | TEXT INDEX DICTIONARY CACHE | TEXT INDEX HEADER CACHE | TEXT INDEX POSTINGS CACHE | REPLICA | DATABASE REPLICA | UNCOMPRESSED CACHE | COMPILED EXPRESSION CACHE | QUERY CONDITION CACHE | QUERY CACHE | FORMAT SCHEMA CACHE | FILESYSTEM CACHE}","SYSTEM FLUSH LOGS","SYSTEM RELOAD {CONFIG | USERS}","SYSTEM SHUTDOWN","SYSTEM KILL","SYSTEM FLUSH DISTRIBUTED","SYSTEM START DISTRIBUTED SENDS","SYSTEM {STOP | START} {LISTEN | MERGES | TTL MERGES | MOVES | FETCHES | REPLICATED SENDS | REPLICATION QUEUES | PULLING REPLICATION LOG}","SYSTEM {SYNC | RESTART | RESTORE} REPLICA","SYSTEM {SYNC | RESTORE} DATABASE REPLICA","SYSTEM RESTART REPLICAS","SYSTEM UNFREEZE","SYSTEM WAIT LOADING PARTS","SYSTEM {LOAD | UNLOAD} PRIMARY KEY","SYSTEM {STOP | START} [REPLICATED] VIEW","SYSTEM {STOP | START} VIEWS","SYSTEM {REFRESH | CANCEL | WAIT} VIEW","WITH NAME","SHOW [CREATE] {TABLE | TEMPORARY TABLE | DICTIONARY | VIEW | DATABASE}","SHOW DATABASES [[NOT] {LIKE | ILIKE}]","SHOW [FULL] [TEMPORARY] TABLES [FROM | IN]","SHOW [EXTENDED] [FULL] COLUMNS {FROM | IN}","ATTACH {TABLE | DICTIONARY | DATABASE} [IF NOT EXISTS]","DETACH {TABLE | DICTIONARY | DATABASE} [IF EXISTS]","PERMANENTLY","SYNC","DROP {DICTIONARY | DATABASE | PROFILE | VIEW | FUNCTION | NAMED COLLECTION} [IF EXISTS]","DROP [TEMPORARY] TABLE [IF EXISTS] [IF EMPTY]","RENAME TO","EXISTS [TEMPORARY] {TABLE | DICTIONARY | DATABASE}","KILL QUERY","OPTIMIZE TABLE","RENAME {TABLE | DICTIONARY | DATABASE}","EXCHANGE {TABLES | DICTIONARIES}","TRUNCATE TABLE [IF EXISTS]","EXECUTE AS","USE","TO","UNDROP TABLE","CREATE {DATABASE | NAMED COLLECTION} [IF NOT EXISTS]","CREATE [OR REPLACE] {VIEW | DICTIONARY} [IF NOT EXISTS]","CREATE MATERIALIZED VIEW [IF NOT EXISTS]","CREATE FUNCTION","CREATE {USER | ROLE | QUOTA | SETTINGS PROFILE} [IF NOT EXISTS | OR REPLACE]","CREATE [ROW] POLICY [IF NOT EXISTS | OR REPLACE]","REPLACE [TEMPORARY] TABLE [IF NOT EXISTS]","ALTER {ROLE | QUOTA | SETTINGS PROFILE} [IF EXISTS]","ALTER [TEMPORARY] TABLE","ALTER NAMED COLLECTION [IF EXISTS]","GRANTEES","NOT IDENTIFIED","RESET AUTHENTICATION METHODS TO NEW","{IDENTIFIED | ADD IDENTIFIED} [WITH | BY]","[ADD | DROP] HOST {LOCAL | NAME | REGEXP | IP | LIKE}","VALID UNTIL","DROP [ALL] {PROFILES | SETTINGS}","{ADD | MODIFY} SETTINGS","ADD PROFILES","APPLY DELETED MASK","IN PARTITION","{ADD | DROP | RENAME | CLEAR | COMMENT | MODIFY | ALTER | MATERIALIZE} COLUMN","{DETACH | DROP | ATTACH | FETCH | MOVE} {PART | PARTITION}","DROP DETACHED {PART | PARTITION}","{FORGET | REPLACE} PARTITION","CLEAR COLUMN","{FREEZE | UNFREEZE} [PARTITION]","CLEAR INDEX","TO {DISK | VOLUME}","[DELETE | REWRITE PARTS] IN PARTITION","{MODIFY | RESET} SETTING","DELETE WHERE","MODIFY ORDER BY","{MODIFY | REMOVE} SAMPLE BY","{ADD | MATERIALIZE | CLEAR} INDEX [IF NOT EXISTS]","DROP INDEX [IF EXISTS]","GRANULARITY","AFTER","FIRST","ADD CONSTRAINT [IF NOT EXISTS]","DROP CONSTRAINT [IF EXISTS]","MODIFY TTL","REMOVE TTL","ADD STATISTICS [IF NOT EXISTS]","{DROP | CLEAR} STATISTICS [IF EXISTS]","MATERIALIZE STATISTICS [ALL | IF EXISTS]","KEYED BY","NOT KEYED","FOR [RANDOMIZED] INTERVAL","AS {PERMISSIVE | RESTRICTIVE}","FOR SELECT","ADD PROJECTION [IF NOT EXISTS]","{DROP | MATERIALIZE | CLEAR} PROJECTION [IF EXISTS]","REFRESH {EVERY | AFTER}","RANDOMIZE FOR","APPEND","APPEND TO","DELETE FROM","EXPLAIN [AST | SYNTAX | QUERY TREE | PLAN | PIPELINE | ESTIMATE | TABLE OVERRIDE]","GRANT ON CLUSTER","GRANT CURRENT GRANTS","WITH GRANT OPTION","REVOKE ON CLUSTER","ADMIN OPTION FOR","CHECK TABLE","PARTITION ID","{DESC | DESCRIBE} TABLE"]),tR=N(["UNION [ALL | DISTINCT]","PARALLEL WITH"]),TR=N(["[GLOBAL] [INNER|LEFT|RIGHT|FULL|CROSS] [OUTER|SEMI|ANTI|ANY|ALL|ASOF] JOIN","[LEFT] ARRAY JOIN"]),rR=N(["{ROWS | RANGE} BETWEEN","ALTER MATERIALIZE STATISTICS"]),nR={name:"clickhouse",tokenizerOptions:{reservedSelect:eR,reservedClauses:[...ER,...et,...Qe],reservedSetOperations:tR,reservedJoins:TR,reservedKeywordPhrases:rR,reservedKeywords:qs,reservedDataTypes:zs,reservedFunctionNames:Zs,extraParens:["[]","{}"],lineCommentTypes:["#","--"],nestedBlockComments:!1,underscoresInNumbers:!0,stringTypes:["$$","''-qq-bs"],identTypes:['""-qq-bs',"``"],paramTypes:{custom:[{regex:String.raw`\{[^:']+:[^}]+\}`,key:E=>{const e=/\{([^:]+):/.exec(E);return e?e[1].trim():E}}]},operators:["%","||","?",":","==","<=>","->"],postProcess:sR},formatOptions:{onelineClauses:[...et,...Qe],tabularOnelineClauses:Qe}};function sR(E){return E.map((e,t)=>{const r=E[t+1]||ne,T=E[t-1]||ne;return e.type===C.RESERVED_SELECT&&(r.type===C.COMMA||T.type===C.RESERVED_CLAUSE||T.type===C.COMMA)?Object.assign(Object.assign({},e),{type:C.RESERVED_KEYWORD}):se.SET(e)&&r.type===C.OPEN_PAREN?Object.assign(Object.assign({},e),{type:C.RESERVED_FUNCTION_NAME}):e})}const RR=["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"],AR=["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"],oR=["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"],SR=N(["SELECT [ALL | DISTINCT]"]),iR=N(["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"]),Et=N(["CREATE [GLOBAL TEMPORARY | EXTERNAL] TABLE [IF NOT EXISTS]"]),Ze=N(["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"]),aR=N(["UNION [ALL]","EXCEPT [ALL]","INTERSECT [ALL]"]),IR=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN"]),NR=N(["ON DELETE","ON UPDATE","SET NULL","{ROWS | RANGE} BETWEEN"]),lR=N([]),LR={name:"db2",tokenizerOptions:{reservedSelect:SR,reservedClauses:[...iR,...Et,...Ze],reservedSetOperations:aR,reservedJoins:IR,reservedKeywordPhrases:NR,reservedDataTypePhrases:lR,reservedKeywords:AR,reservedDataTypes:oR,reservedFunctionNames:RR,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:[...Et,...Ze],tabularOnelineClauses:Ze}},CR=["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"],cR=["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"],_R=["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"],dR=N(["SELECT [ALL | DISTINCT]"]),DR=N(["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"]),tt=N(["CREATE [OR REPLACE] TABLE"]),qe=N(["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}"]),uR=N(["UNION [ALL]","EXCEPT [ALL]","INTERSECT [ALL]"]),PR=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","[LEFT | RIGHT] EXCEPTION JOIN","{INNER | CROSS} JOIN"]),pR=N(["ON DELETE","ON UPDATE","SET NULL","{ROWS | RANGE} BETWEEN"]),MR=N([]),UR={name:"db2i",tokenizerOptions:{reservedSelect:dR,reservedClauses:[...DR,...tt,...qe],reservedSetOperations:uR,reservedJoins:PR,reservedKeywordPhrases:pR,reservedDataTypePhrases:MR,reservedKeywords:cR,reservedDataTypes:_R,reservedFunctionNames:CR,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:[...tt,...qe],tabularOnelineClauses:qe}},hR=["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"],fR=["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"],mR=["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"],xR=N(["SELECT [ALL | DISTINCT]"]),GR=N(["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"]),Tt=N(["CREATE [OR REPLACE] [TEMPORARY | TEMP] TABLE [IF NOT EXISTS]"]),ze=N(["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]"]),yR=N(["UNION [ALL | BY NAME]","EXCEPT [ALL]","INTERSECT [ALL]"]),BR=N(["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"]),gR=N(["{ROWS | RANGE | GROUPS} BETWEEN","SIMILAR TO","IS [NOT] DISTINCT FROM"]),HR=N(["TIMESTAMP WITH TIME ZONE"]),FR={name:"duckdb",tokenizerOptions:{reservedSelect:xR,reservedClauses:[...GR,...Tt,...ze],reservedSetOperations:yR,reservedJoins:BR,reservedKeywordPhrases:gR,reservedDataTypePhrases:HR,supportsXor:!0,reservedKeywords:fR,reservedDataTypes:mR,reservedFunctionNames:hR,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:[...Tt,...ze],tabularOnelineClauses:ze}},bR=["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"],YR=["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"],vR=["ARRAY","BIGINT","BINARY","BOOLEAN","CHAR","DATE","DECIMAL","DOUBLE","FLOAT","INT","INTEGER","INTERVAL","MAP","NUMERIC","PRECISION","SMALLINT","STRUCT","TIMESTAMP","VARCHAR"],VR=N(["SELECT [ALL | DISTINCT]"]),WR=N(["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"]),rt=N(["CREATE [TEMPORARY] [EXTERNAL] TABLE [IF NOT EXISTS]"]),eE=N(["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"]),XR=N(["UNION [ALL | DISTINCT]"]),wR=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","LEFT SEMI JOIN"]),KR=N(["{ROWS | RANGE} BETWEEN"]),$R=N([]),kR={name:"hive",tokenizerOptions:{reservedSelect:VR,reservedClauses:[...WR,...rt,...eE],reservedSetOperations:XR,reservedJoins:wR,reservedKeywordPhrases:KR,reservedDataTypePhrases:$R,reservedKeywords:YR,reservedDataTypes:vR,reservedFunctionNames:bR,extraParens:["[]"],stringTypes:['""-bs',"''-bs"],identTypes:["``"],variableTypes:[{quote:"{}",prefixes:["$"],requirePrefix:!0}],operators:["%","~","^","|","&","<=>","==","!","||"]},formatOptions:{onelineClauses:[...rt,...eE],tabularOnelineClauses:eE}};function Ve(E){return E.map((e,t)=>{const r=E[t+1]||ne;if(se.SET(e)&&r.text==="(")return Object.assign(Object.assign({},e),{type:C.RESERVED_FUNCTION_NAME});const T=E[t-1]||ne;return se.VALUES(e)&&T.text==="="?Object.assign(Object.assign({},e),{type:C.RESERVED_FUNCTION_NAME}):e})}const jR=["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"],JR=["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"],QR=["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"],ZR=N(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),qR=N(["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"]),nt=N(["CREATE [OR REPLACE] [TEMPORARY] TABLE [IF NOT EXISTS]"]),EE=N(["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"]),zR=N(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]","MINUS [ALL | DISTINCT]"]),eA=N(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),EA=N(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),tA=N([]),TA={name:"mariadb",tokenizerOptions:{reservedSelect:ZR,reservedClauses:[...qR,...nt,...EE],reservedSetOperations:zR,reservedJoins:eA,reservedKeywordPhrases:EA,reservedDataTypePhrases:tA,supportsXor:!0,reservedKeywords:jR,reservedDataTypes:JR,reservedFunctionNames:QR,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:Ve},formatOptions:{onelineClauses:[...nt,...EE],tabularOnelineClauses:EE}},rA=["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"],nA=["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"],sA=["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","MICROSECOND","MID","MIN","MINUTE","MOD","MONTH","MONTHNAME","MULTILINESTRING","MULTIPOINT","MULTIPOLYGON","NAME_CONST","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"],RA=N(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),AA=N(["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"]),st=N(["CREATE [TEMPORARY] TABLE [IF NOT EXISTS]"]),tE=N(["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"]),oA=N(["UNION [ALL | DISTINCT]"]),SA=N(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),iA=N(["ON {UPDATE | DELETE} [SET NULL]","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),aA=N([]),IA={name:"mysql",tokenizerOptions:{reservedSelect:RA,reservedClauses:[...AA,...st,...tE],reservedSetOperations:oA,reservedJoins:SA,reservedKeywordPhrases:iA,reservedDataTypePhrases:aA,supportsXor:!0,reservedKeywords:rA,reservedDataTypes:nA,reservedFunctionNames:sA,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:Ve},formatOptions:{onelineClauses:[...st,...tE],tabularOnelineClauses:tE}},OA=["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"],NA=["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"],lA=["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"],LA=N(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),CA=N(["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"]),Rt=N(["CREATE [TEMPORARY] TABLE [IF NOT EXISTS]"]),TE=N(["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"]),cA=N(["UNION [ALL | DISTINCT]"]),_A=N(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),dA=N(["ON {UPDATE | DELETE} [SET NULL]","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),DA=N([]),uA={name:"tidb",tokenizerOptions:{reservedSelect:LA,reservedClauses:[...CA,...Rt,...TE],reservedSetOperations:cA,reservedJoins:_A,reservedKeywordPhrases:dA,reservedDataTypePhrases:DA,supportsXor:!0,reservedKeywords:OA,reservedDataTypes:NA,reservedFunctionNames:lA,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:Ve},formatOptions:{onelineClauses:[...Rt,...TE],tabularOnelineClauses:TE}},PA=["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"],pA=["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"],MA=[],UA=N(["SELECT [ALL | DISTINCT]"]),hA=N(["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"]),At=N(["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"]),fA=N(["UNION [ALL]","EXCEPT [ALL]","INTERSECT [ALL]"]),mA=N(["JOIN","{LEFT | RIGHT} [OUTER] JOIN","INNER JOIN"]),xA=N(["{ROWS | RANGE | GROUPS} BETWEEN"]),GA=N([]),yA={name:"n1ql",tokenizerOptions:{reservedSelect:UA,reservedClauses:[...hA,...At],reservedSetOperations:fA,reservedJoins:mA,reservedKeywordPhrases:xA,reservedDataTypePhrases:GA,supportsXor:!0,reservedKeywords:pA,reservedDataTypes:MA,reservedFunctionNames:PA,stringTypes:['""-bs',"''-bs"],identTypes:["``"],extraParens:["[]","{}"],paramTypes:{positional:!0,numbered:["$"],named:["$"]},lineCommentTypes:["#","--"],operators:["%","==",":","||"]},formatOptions:{onelineClauses:At}},BA=["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"],gA=["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"],HA=["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"],FA=N(["SELECT [ALL | DISTINCT | UNIQUE]"]),bA=N(["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"]),ot=N(["CREATE [GLOBAL TEMPORARY | PRIVATE TEMPORARY | SHARDED | DUPLICATED | IMMUTABLE BLOCKCHAIN | BLOCKCHAIN | IMMUTABLE] TABLE"]),rE=N(["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"]),YA=N(["UNION [ALL]","MINUS","INTERSECT"]),vA=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN","{CROSS | OUTER} APPLY"]),VA=N(["ON {UPDATE | DELETE} [SET NULL]","ON COMMIT","{ROWS | RANGE} BETWEEN"]),WA=N([]),XA={name:"plsql",tokenizerOptions:{reservedSelect:FA,reservedClauses:[...bA,...ot,...rE],reservedSetOperations:YA,reservedJoins:vA,reservedKeywordPhrases:VA,reservedDataTypePhrases:WA,supportsXor:!0,reservedKeywords:BA,reservedDataTypes:gA,reservedFunctionNames:HA,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:wA},formatOptions:{alwaysDenseOperators:["@"],onelineClauses:[...ot,...rE],tabularOnelineClauses:rE}};function wA(E){let e=ne;return E.map(t=>se.SET(t)&&se.BY(e)?Object.assign(Object.assign({},t),{type:C.RESERVED_KEYWORD}):(zt(t.type)&&(e=t),t))}const KA=["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"],$A=["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"],kA=["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"],jA=N(["SELECT [ALL | DISTINCT]"]),JA=N(["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"]),St=N(["CREATE [GLOBAL | LOCAL] [TEMPORARY | TEMP | UNLOGGED] TABLE [IF NOT EXISTS]"]),nE=N(["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"]),QA=N(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),ZA=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),qA=N(["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"]),zA=N(["[TIMESTAMP | TIME] {WITH | WITHOUT} TIME ZONE"]),eo={name:"postgresql",tokenizerOptions:{reservedSelect:jA,reservedClauses:[...JA,...St,...nE],reservedSetOperations:QA,reservedJoins:ZA,reservedKeywordPhrases:qA,reservedDataTypePhrases:zA,reservedKeywords:$A,reservedDataTypes:kA,reservedFunctionNames:KA,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:[...St,...nE],tabularOnelineClauses:nE}},Eo=["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"],to=["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"],To=["ARRAY","BIGINT","BPCHAR","CHAR","CHARACTER VARYING","CHARACTER","DECIMAL","INT","INT2","INT4","INT8","INTEGER","NCHAR","NUMERIC","NVARCHAR","SMALLINT","TEXT","VARBYTE","VARCHAR"],ro=N(["SELECT [ALL | DISTINCT]"]),no=N(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY","HAVING","QUALIFY","PARTITION BY","ORDER BY","LIMIT","OFFSET","INSERT INTO","VALUES","SET"]),it=N(["CREATE [TEMPORARY | TEMP | LOCAL TEMPORARY | LOCAL TEMP] TABLE [IF NOT EXISTS]"]),sE=N(["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"]),so=N(["UNION [ALL]","EXCEPT","INTERSECT","MINUS"]),Ro=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),Ao=N(["NULL AS","DATA CATALOG","HIVE METASTORE","{ROWS | RANGE} BETWEEN"]),oo=N([]),So={name:"redshift",tokenizerOptions:{reservedSelect:ro,reservedClauses:[...no,...it,...sE],reservedSetOperations:so,reservedJoins:Ro,reservedKeywordPhrases:Ao,reservedDataTypePhrases:oo,reservedKeywords:to,reservedDataTypes:To,reservedFunctionNames:Eo,extraParens:["[]"],stringTypes:["''-qq"],identTypes:['""-qq'],identChars:{first:"#"},paramTypes:{numbered:["$"]},operators:["^","%","@","|/","||/","&","|","~","<<",">>","||","::"]},formatOptions:{alwaysDenseOperators:["::"],onelineClauses:[...it,...sE],tabularOnelineClauses:sE}},io=["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"],ao=["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"],Io=["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"],Oo=N(["SELECT [ALL | DISTINCT]"]),No=N(["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"]),at=N(["CREATE [EXTERNAL] TABLE [IF NOT EXISTS]"]),RE=N(["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"]),lo=N(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),Lo=N(["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"]),Co=N(["ON DELETE","ON UPDATE","CURRENT ROW","{ROWS | RANGE} BETWEEN"]),co=N([]),_o={name:"spark",tokenizerOptions:{reservedSelect:Oo,reservedClauses:[...No,...at,...RE],reservedSetOperations:lo,reservedJoins:Lo,reservedKeywordPhrases:Co,reservedDataTypePhrases:co,supportsXor:!0,reservedKeywords:io,reservedDataTypes:ao,reservedFunctionNames:Io,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:Do},formatOptions:{onelineClauses:[...at,...RE],tabularOnelineClauses:RE}};function Do(E){return E.map((e,t)=>{const r=E[t-1]||ne,T=E[t+1]||ne;return se.WINDOW(e)&&T.type===C.OPEN_PAREN?Object.assign(Object.assign({},e),{type:C.RESERVED_FUNCTION_NAME}):e.text==="ITEMS"&&e.type===C.RESERVED_KEYWORD&&!(r.text==="COLLECTION"&&T.text==="TERMINATED")?Object.assign(Object.assign({},e),{type:C.IDENTIFIER,text:e.raw}):e})}const uo=["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"],Po=["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"],po=["ANY","ARRAY","BLOB","CHARACTER","DECIMAL","INT","INTEGER","NATIVE CHARACTER","NCHAR","NUMERIC","NVARCHAR","REAL","TEXT","VARCHAR","VARYING CHARACTER"],Mo=N(["SELECT [ALL | DISTINCT]"]),Uo=N(["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"]),It=N(["CREATE [TEMPORARY | TEMP] TABLE [IF NOT EXISTS]"]),AE=N(["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"]),ho=N(["UNION [ALL]","EXCEPT","INTERSECT"]),fo=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),mo=N(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","{ROWS | RANGE | GROUPS} BETWEEN","DO UPDATE"]),xo=N([]),Go={name:"sqlite",tokenizerOptions:{reservedSelect:Mo,reservedClauses:[...Uo,...It,...AE],reservedSetOperations:ho,reservedJoins:fo,reservedKeywordPhrases:mo,reservedDataTypePhrases:xo,reservedKeywords:Po,reservedDataTypes:po,reservedFunctionNames:uo,stringTypes:["''-qq",{quote:"''-raw",prefixes:["X"],requirePrefix:!0}],identTypes:['""-qq',"``","[]"],paramTypes:{positional:!0,numbered:["?"],named:[":","@","$"]},operators:["%","~","&","|","<<",">>","==","->","->>","||"]},formatOptions:{onelineClauses:[...It,...AE],tabularOnelineClauses:AE}},yo=["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"],Bo=["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"],go=["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"],Ho=N(["SELECT [ALL | DISTINCT]"]),Fo=N(["WITH [RECURSIVE]","FROM","WHERE","GROUP BY [ALL | DISTINCT]","HAVING","WINDOW","PARTITION BY","ORDER BY","LIMIT","OFFSET","FETCH {FIRST | NEXT}","INSERT INTO","VALUES","SET"]),Ot=N(["CREATE [GLOBAL TEMPORARY | LOCAL TEMPORARY] TABLE"]),oE=N(["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"]),bo=N(["UNION [ALL | DISTINCT]","EXCEPT [ALL | DISTINCT]","INTERSECT [ALL | DISTINCT]"]),Yo=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),vo=N(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","{ROWS | RANGE} BETWEEN"]),Vo=N([]),Wo={name:"sql",tokenizerOptions:{reservedSelect:Ho,reservedClauses:[...Fo,...Ot,...oE],reservedSetOperations:bo,reservedJoins:Yo,reservedKeywordPhrases:vo,reservedDataTypePhrases:Vo,reservedKeywords:Bo,reservedDataTypes:go,reservedFunctionNames:yo,stringTypes:[{quote:"''-qq-bs",prefixes:["N","U&"]},{quote:"''-raw",prefixes:["X"],requirePrefix:!0}],identTypes:['""-qq',"``"],paramTypes:{positional:!0},operators:["||"]},formatOptions:{onelineClauses:[...Ot,...oE],tabularOnelineClauses:oE}},Xo=["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"],wo=["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"],Ko=["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"],$o=N(["SELECT [ALL | DISTINCT]"]),ko=N(["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"]),Nt=N(["CREATE TABLE [IF NOT EXISTS]"]),SE=N(["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"]),jo=N(["UNION [ALL | DISTINCT] [CORRESPONDING]","EXCEPT [ALL | DISTINCT] [CORRESPONDING]","INTERSECT [ALL | DISTINCT] [CORRESPONDING]"]),Jo=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL [INNER] JOIN","NATURAL {LEFT | RIGHT | FULL} [OUTER] JOIN"]),Qo=N(["{ROWS | RANGE | GROUPS} BETWEEN","IS [NOT] DISTINCT FROM"]),Zo=N([]),qo={name:"trino",tokenizerOptions:{reservedSelect:$o,reservedClauses:[...ko,...Nt,...SE],reservedSetOperations:jo,reservedJoins:Jo,reservedKeywordPhrases:Qo,reservedDataTypePhrases:Zo,reservedKeywords:wo,reservedDataTypes:Ko,reservedFunctionNames:Xo,extraParens:["[]","{}"],stringTypes:[{quote:"''-qq",prefixes:["U&"]},{quote:"''-raw",prefixes:["X"],requirePrefix:!0}],identTypes:['""-qq'],paramTypes:{positional:!0},operators:["%","->","=>",":","||","|","^","$"]},formatOptions:{onelineClauses:[...Nt,...SE],tabularOnelineClauses:SE}},zo=["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"],eS=["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"],ES=["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"],tS=N(["SELECT [ALL | DISTINCT]"]),TS=N(["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"]),lt=N(["CREATE TABLE"]),iE=N(["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"]),rS=N(["UNION [ALL]","EXCEPT","INTERSECT"]),nS=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","{CROSS | OUTER} APPLY"]),sS=N(["ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]","{ROWS | RANGE} BETWEEN"]),RS=N([]),AS={name:"transactsql",tokenizerOptions:{reservedSelect:tS,reservedClauses:[...TS,...lt,...iE],reservedSetOperations:rS,reservedJoins:nS,reservedKeywordPhrases:sS,reservedDataTypePhrases:RS,reservedKeywords:eS,reservedDataTypes:ES,reservedFunctionNames:zo,nestedBlockComments:!0,stringTypes:[{quote:"''-qq",prefixes:["N"]},"{}"],identTypes:['""-qq',"[]"],identChars:{first:"#@",rest:"#@$"},paramTypes:{named:["@"],quoted:["@"]},operators:["%","&","|","^","~","!<","!>","+=","-=","*=","/=","%=","|=","&=","^=","::",":"],propertyAccessOperators:[".."]},formatOptions:{alwaysDenseOperators:["::"],onelineClauses:[...lt,...iE],tabularOnelineClauses:iE}},oS=["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"],SS=["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"],iS=["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"],aS=N(["SELECT [ALL | DISTINCT | DISTINCTROW]"]),IS=N(["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"]),Lt=N(["CREATE [ROWSTORE] [REFERENCE | TEMPORARY | GLOBAL TEMPORARY] TABLE [IF NOT EXISTS]"]),aE=N(["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"]),OS=N(["UNION [ALL | DISTINCT]","EXCEPT","INTERSECT","MINUS"]),NS=N(["JOIN","{LEFT | RIGHT | FULL} [OUTER] JOIN","{INNER | CROSS} JOIN","NATURAL {LEFT | RIGHT} [OUTER] JOIN","STRAIGHT_JOIN"]),lS=N(["ON DELETE","ON UPDATE","CHARACTER SET","{ROWS | RANGE} BETWEEN","IDENTIFIED BY"]),LS=N([]),CS={name:"singlestoredb",tokenizerOptions:{reservedSelect:aS,reservedClauses:[...IS,...Lt,...aE],reservedSetOperations:OS,reservedJoins:NS,reservedKeywordPhrases:lS,reservedDataTypePhrases:LS,reservedKeywords:oS,reservedDataTypes:SS,reservedFunctionNames:iS,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:Ve},formatOptions:{alwaysDenseOperators:["::","::$","::%"],onelineClauses:[...Lt,...aE],tabularOnelineClauses:aE}},cS=["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"],_S=["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"],dS=["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"],DS=N(["SELECT [ALL | DISTINCT]"]),uS=N(["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"]),Ct=N(["CREATE [OR REPLACE] [VOLATILE] TABLE [IF NOT EXISTS]","CREATE [OR REPLACE] [LOCAL | GLOBAL] {TEMP|TEMPORARY} TABLE [IF NOT EXISTS]"]),IE=N(["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"]),PS=N(["UNION [ALL]","MINUS","EXCEPT","INTERSECT"]),pS=N(["[INNER] JOIN","[NATURAL] {LEFT | RIGHT | FULL} [OUTER] JOIN","{CROSS | NATURAL} JOIN"]),MS=N(["{ROWS | RANGE} BETWEEN","ON {UPDATE | DELETE} [SET NULL | SET DEFAULT]"]),US=N([]),hS={name:"snowflake",tokenizerOptions:{reservedSelect:DS,reservedClauses:[...uS,...Ct,...IE],reservedSetOperations:PS,reservedJoins:pS,reservedKeywordPhrases:MS,reservedDataTypePhrases:US,reservedKeywords:_S,reservedDataTypes:dS,reservedFunctionNames:cS,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:[...Ct,...IE],tabularOnelineClauses:IE}},fS=Object.freeze(Object.defineProperty({__proto__:null,bigquery:$s,clickhouse:nR,db2:LR,db2i:UR,duckdb:FR,hive:kR,mariadb:TA,mysql:IA,n1ql:yA,plsql:XA,postgresql:eo,redshift:So,singlestoredb:CS,snowflake:hS,spark:_o,sql:Wo,sqlite:Go,tidb:uA,transactsql:AS,trino:qo},Symbol.toStringTag,{value:"Module"})),de=E=>E[E.length-1],eT=E=>E.sort((e,t)=>t.length-e.length||e.localeCompare(t)),xe=E=>E.replace(/\s+/gu," "),OE=E=>/\n/.test(E),J=E=>E.replace(/[.*+?^${}()|[\]\\]/gu,"\\$&"),ct=/\s+/uy,ie=E=>new RegExp(`(?:${E})`,"uy"),mS=E=>E.split("").map(e=>/ /gu.test(e)?"\\s+":`[${e.toUpperCase()}${e.toLowerCase()}]`).join(""),xS=E=>E+"(?:-"+E+")*",GS=({prefixes:E,requirePrefix:e})=>`(?:${E.map(mS).join("|")}${e?"":"|"})`,yS=E=>new RegExp(`(?:${E.map(J).join("|")}).*?(?=\r
|
|
412
|
+
|\r|
|
|
413
|
+
|$)`,"uy"),_t=(E,e=[])=>{const t=E==="open"?0:1,r=["()",...e].map(T=>T[t]);return ie(r.map(J).join("|"))},dt=E=>ie(`${eT(E).map(J).join("|")}`),BS=({rest:E,dashes:e})=>E||e?`(?![${E||""}${e?"-":""}])`:"",z=(E,e={})=>{if(E.length===0)return/^\b$/u;const t=BS(e),r=eT(E).map(J).join("|").replace(/ /gu,"\\s+");return new RegExp(`(?:${r})${t}\\b`,"iuy")},NE=(E,e)=>{if(!E.length)return;const t=E.map(J).join("|");return ie(`(?:${t})(?:${e})`)},gS=()=>{const E={"<":">","[":"]","(":")","{":"}"},e="{left}(?:(?!{right}').)*?{right}",t=Object.entries(E).map(([R,A])=>e.replace(/{left}/g,J(R)).replace(/{right}/g,J(A))),r=J(Object.keys(E).join(""));return`[Qq]'(?:${String.raw`(?<tag>[^\s${r}])(?:(?!\k<tag>').)*?\k<tag>`}|${t.join("|")})'`},Dt={"``":"(?:`[^`]*`)+","[]":String.raw`(?:\[[^\]]*\])(?:\][^\]]*\])*`,'""-qq':String.raw`(?:"[^"]*")+`,'""-bs':String.raw`(?:"[^"\\]*(?:\\.[^"\\]*)*")`,'""-qq-bs':String.raw`(?:"[^"\\]*(?:\\.[^"\\]*)*")+`,'""-raw':String.raw`(?:"[^"]*")`,"''-qq":String.raw`(?:'[^']*')+`,"''-bs":String.raw`(?:'[^'\\]*(?:\\.[^'\\]*)*')`,"''-qq-bs":String.raw`(?:'[^'\\]*(?:\\.[^'\\]*)*')+`,"''-raw":String.raw`(?:'[^']*')`,$$:String.raw`(?<tag>\$\w*\$)[\s\S]*?\k<tag>`,"'''..'''":String.raw`'''[^\\]*?(?:\\.[^\\]*?)*?'''`,'""".."""':String.raw`"""[^\\]*?(?:\\.[^\\]*?)*?"""`,"{}":String.raw`(?:\{[^\}]*\})`,"q''":gS()},ET=E=>typeof E=="string"?Dt[E]:"regex"in E?E.regex:GS(E)+Dt[E.quote],HS=E=>ie(E.map(e=>"regex"in e?e.regex:ET(e)).join("|")),tT=E=>E.map(ET).join("|"),ut=E=>ie(tT(E)),FS=(E={})=>ie(TT(E)),TT=({first:E,rest:e,dashes:t,allowFirstCharNumber:r}={})=>{const T="\\p{Alphabetic}\\p{Mark}_",s="\\p{Decimal_Number}",R=J(E??""),A=J(e??""),a=r?`[${T}${s}${R}][${T}${s}${A}]*`:`[${T}${R}][${T}${s}${A}]*`;return t?xS(a):a};function rT(E,e){const t=E.slice(0,e).split(/\n/);return{line:t.length,col:t[t.length-1].length+1}}class bS{constructor(e,t){this.rules=e,this.dialectName=t,this.input="",this.index=0}tokenize(e){this.input=e,this.index=0;const t=[];let r;for(;this.index<this.input.length;){const T=this.getWhitespace();if(this.index<this.input.length){if(r=this.getNextToken(),!r)throw this.createParseError();t.push(Object.assign(Object.assign({},r),{precedingWhitespace:T}))}}return t}createParseError(){const e=this.input.slice(this.index,this.index+10),{line:t,col:r}=rT(this.input,this.index);return new Error(`Parse error: Unexpected "${e}" at line ${t} column ${r}.
|
|
414
|
+
${this.dialectInfo()}`)}dialectInfo(){return this.dialectName==="sql"?`This likely happens because you're using the default "sql" dialect.
|
|
415
|
+
If possible, please select a more specific dialect (like sqlite, postgresql, etc).`:`SQL dialect used: "${this.dialectName}".`}getWhitespace(){ct.lastIndex=this.index;const e=ct.exec(this.input);if(e)return this.index+=e[0].length,e[0]}getNextToken(){for(const e of this.rules){const t=this.match(e);if(t)return t}}match(e){e.regex.lastIndex=this.index;const t=e.regex.exec(this.input);if(t){const r=t[0],T={type:e.type,raw:r,text:e.text?e.text(r):r,start:this.index};return e.key&&(T.key=e.key(r)),this.index+=r.length,T}}}const Pt=/\/\*/uy,YS=/[\s\S]/uy,vS=/\*\//uy;class VS{constructor(){this.lastIndex=0}exec(e){let t="",r,T=0;if(r=this.matchSection(Pt,e))t+=r,T++;else return null;for(;T>0;)if(r=this.matchSection(Pt,e))t+=r,T++;else if(r=this.matchSection(vS,e))t+=r,T--;else if(r=this.matchSection(YS,e))t+=r;else return null;return[t]}matchSection(e,t){e.lastIndex=this.lastIndex;const r=e.exec(t);return r&&(this.lastIndex+=r[0].length),r?r[0]:null}}class WS{constructor(e,t){this.cfg=e,this.dialectName=t,this.rulesBeforeParams=this.buildRulesBeforeParams(e),this.rulesAfterParams=this.buildRulesAfterParams(e)}tokenize(e,t){const r=[...this.rulesBeforeParams,...this.buildParamRules(this.cfg,t),...this.rulesAfterParams],T=new bS(r,this.dialectName).tokenize(e);return this.cfg.postProcess?this.cfg.postProcess(T):T}buildRulesBeforeParams(e){var t,r,T;return this.validRules([{type:C.DISABLE_COMMENT,regex:/(\/\* *sql-formatter-disable *\*\/[\s\S]*?(?:\/\* *sql-formatter-enable *\*\/|$))/uy},{type:C.BLOCK_COMMENT,regex:e.nestedBlockComments?new VS:/(\/\*[^]*?\*\/)/uy},{type:C.LINE_COMMENT,regex:yS((t=e.lineCommentTypes)!==null&&t!==void 0?t:["--"])},{type:C.QUOTED_IDENTIFIER,regex:ut(e.identTypes)},{type:C.NUMBER,regex:e.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:C.RESERVED_KEYWORD_PHRASE,regex:z((r=e.reservedKeywordPhrases)!==null&&r!==void 0?r:[],e.identChars),text:g},{type:C.RESERVED_DATA_TYPE_PHRASE,regex:z((T=e.reservedDataTypePhrases)!==null&&T!==void 0?T:[],e.identChars),text:g},{type:C.CASE,regex:/CASE\b/iuy,text:g},{type:C.END,regex:/END\b/iuy,text:g},{type:C.BETWEEN,regex:/BETWEEN\b/iuy,text:g},{type:C.LIMIT,regex:e.reservedClauses.includes("LIMIT")?/LIMIT\b/iuy:void 0,text:g},{type:C.RESERVED_CLAUSE,regex:z(e.reservedClauses,e.identChars),text:g},{type:C.RESERVED_SELECT,regex:z(e.reservedSelect,e.identChars),text:g},{type:C.RESERVED_SET_OPERATION,regex:z(e.reservedSetOperations,e.identChars),text:g},{type:C.WHEN,regex:/WHEN\b/iuy,text:g},{type:C.ELSE,regex:/ELSE\b/iuy,text:g},{type:C.THEN,regex:/THEN\b/iuy,text:g},{type:C.RESERVED_JOIN,regex:z(e.reservedJoins,e.identChars),text:g},{type:C.AND,regex:/AND\b/iuy,text:g},{type:C.OR,regex:/OR\b/iuy,text:g},{type:C.XOR,regex:e.supportsXor?/XOR\b/iuy:void 0,text:g},...e.operatorKeyword?[{type:C.OPERATOR,regex:/OPERATOR *\([^)]+\)/iuy}]:[],{type:C.RESERVED_FUNCTION_NAME,regex:z(e.reservedFunctionNames,e.identChars),text:g},{type:C.RESERVED_DATA_TYPE,regex:z(e.reservedDataTypes,e.identChars),text:g},{type:C.RESERVED_KEYWORD,regex:z(e.reservedKeywords,e.identChars),text:g}])}buildRulesAfterParams(e){var t,r;return this.validRules([{type:C.VARIABLE,regex:e.variableTypes?HS(e.variableTypes):void 0},{type:C.STRING,regex:ut(e.stringTypes)},{type:C.IDENTIFIER,regex:FS(e.identChars)},{type:C.DELIMITER,regex:/[;]/uy},{type:C.COMMA,regex:/[,]/y},{type:C.OPEN_PAREN,regex:_t("open",e.extraParens)},{type:C.CLOSE_PAREN,regex:_t("close",e.extraParens)},{type:C.OPERATOR,regex:dt(["+","-","/",">","<","=","<>","<=",">=","!=",...(t=e.operators)!==null&&t!==void 0?t:[]])},{type:C.ASTERISK,regex:/[*]/uy},{type:C.PROPERTY_ACCESS_OPERATOR,regex:dt([".",...(r=e.propertyAccessOperators)!==null&&r!==void 0?r:[]])}])}buildParamRules(e,t){var r,T,s,R,A;const a={named:(t==null?void 0:t.named)||((r=e.paramTypes)===null||r===void 0?void 0:r.named)||[],quoted:(t==null?void 0:t.quoted)||((T=e.paramTypes)===null||T===void 0?void 0:T.quoted)||[],numbered:(t==null?void 0:t.numbered)||((s=e.paramTypes)===null||s===void 0?void 0:s.numbered)||[],positional:typeof(t==null?void 0:t.positional)=="boolean"?t.positional:(R=e.paramTypes)===null||R===void 0?void 0:R.positional,custom:(t==null?void 0:t.custom)||((A=e.paramTypes)===null||A===void 0?void 0:A.custom)||[]};return this.validRules([{type:C.NAMED_PARAMETER,regex:NE(a.named,TT(e.paramChars||e.identChars)),key:o=>o.slice(1)},{type:C.QUOTED_PARAMETER,regex:NE(a.quoted,tT(e.identTypes)),key:o=>(({tokenKey:S,quoteChar:i})=>S.replace(new RegExp(J("\\"+i),"gu"),i))({tokenKey:o.slice(2,-1),quoteChar:o.slice(-1)})},{type:C.NUMBERED_PARAMETER,regex:NE(a.numbered,"[0-9]+"),key:o=>o.slice(1)},{type:C.POSITIONAL_PARAMETER,regex:a.positional?/[?]/y:void 0},...a.custom.map(o=>{var S;return{type:C.CUSTOM_PARAMETER,regex:ie(o.regex),key:(S=o.key)!==null&&S!==void 0?S:(i=>i)}})])}validRules(e){return e.filter(t=>!!t.regex)}}const g=E=>xe(E.toUpperCase()),pt=new Map,XS=E=>{let e=pt.get(E);return e||(e=wS(E),pt.set(E,e)),e},wS=E=>({tokenizer:new WS(E.tokenizerOptions,E.name),formatOptions:KS(E.formatOptions)}),KS=E=>{var e;return{alwaysDenseOperators:E.alwaysDenseOperators||[],onelineClauses:Object.fromEntries(E.onelineClauses.map(t=>[t,!0])),tabularOnelineClauses:Object.fromEntries(((e=E.tabularOnelineClauses)!==null&&e!==void 0?e:E.onelineClauses).map(t=>[t,!0]))}};function $S(E){return E.indentStyle==="tabularLeft"||E.indentStyle==="tabularRight"?" ".repeat(10):E.useTabs?" ":" ".repeat(E.tabWidth)}function Ie(E){return E.indentStyle==="tabularLeft"||E.indentStyle==="tabularRight"}class kS{constructor(e){this.params=e,this.index=0}get({key:e,text:t}){return this.params?e?this.params[e]:this.params[this.index++]:t}getPositionalParameterIndex(){return this.index}setPositionalParameterIndex(e){this.index=e}}var Ge={exports:{}},jS=Ge.exports,Mt;function JS(){return Mt||(Mt=1,(function(E){(function(e,t){E.exports?E.exports=t():e.nearley=t()})(jS,function(){function e(o,S,i){return this.id=++e.highestId,this.name=o,this.symbols=S,this.postprocess=i,this}e.highestId=0,e.prototype.toString=function(o){var S=typeof o>"u"?this.symbols.map(a).join(" "):this.symbols.slice(0,o).map(a).join(" ")+" ● "+this.symbols.slice(o).map(a).join(" ");return this.name+" → "+S};function t(o,S,i,I){this.rule=o,this.dot=S,this.reference=i,this.data=[],this.wantedBy=I,this.isComplete=this.dot===o.symbols.length}t.prototype.toString=function(){return"{"+this.rule.toString(this.dot)+"}, from: "+(this.reference||0)},t.prototype.nextState=function(o){var S=new t(this.rule,this.dot+1,this.reference,this.wantedBy);return S.left=this,S.right=o,S.isComplete&&(S.data=S.build(),S.right=void 0),S},t.prototype.build=function(){var o=[],S=this;do o.push(S.right.data),S=S.left;while(S.left);return o.reverse(),o},t.prototype.finish=function(){this.rule.postprocess&&(this.data=this.rule.postprocess(this.data,this.reference,R.fail))};function r(o,S){this.grammar=o,this.index=S,this.states=[],this.wants={},this.scannable=[],this.completed={}}r.prototype.process=function(o){for(var S=this.states,i=this.wants,I=this.completed,O=0;O<S.length;O++){var c=S[O];if(c.isComplete){if(c.finish(),c.data!==R.fail){for(var _=c.wantedBy,d=_.length;d--;){var u=_[d];this.complete(u,c)}if(c.reference===this.index){var D=c.rule.name;(this.completed[D]=this.completed[D]||[]).push(c)}}}else{var D=c.rule.symbols[c.dot];if(typeof D!="string"){this.scannable.push(c);continue}if(i[D]){if(i[D].push(c),I.hasOwnProperty(D))for(var f=I[D],d=0;d<f.length;d++){var p=f[d];this.complete(c,p)}}else i[D]=[c],this.predict(D)}}},r.prototype.predict=function(o){for(var S=this.grammar.byName[o]||[],i=0;i<S.length;i++){var I=S[i],O=this.wants[o],c=new t(I,0,this.index,O);this.states.push(c)}},r.prototype.complete=function(o,S){var i=o.nextState(S);this.states.push(i)};function T(o,S){this.rules=o,this.start=S||this.rules[0].name;var i=this.byName={};this.rules.forEach(function(I){i.hasOwnProperty(I.name)||(i[I.name]=[]),i[I.name].push(I)})}T.fromCompiled=function(I,S){var i=I.Lexer;I.ParserStart&&(S=I.ParserStart,I=I.ParserRules);var I=I.map(function(c){return new e(c.name,c.symbols,c.postprocess)}),O=new T(I,S);return O.lexer=i,O};function s(){this.reset("")}s.prototype.reset=function(o,S){this.buffer=o,this.index=0,this.line=S?S.line:1,this.lastLineBreak=S?-S.col:0},s.prototype.next=function(){if(this.index<this.buffer.length){var o=this.buffer[this.index++];return o===`
|
|
416
|
+
`&&(this.line+=1,this.lastLineBreak=this.index),{value:o}}},s.prototype.save=function(){return{line:this.line,col:this.index-this.lastLineBreak}},s.prototype.formatError=function(o,S){var i=this.buffer;if(typeof i=="string"){var I=i.split(`
|
|
417
|
+
`).slice(Math.max(0,this.line-5),this.line),O=i.indexOf(`
|
|
418
|
+
`,this.index);O===-1&&(O=i.length);var c=this.index-this.lastLineBreak,_=String(this.line).length;return S+=" at line "+this.line+" col "+c+`:
|
|
419
|
+
|
|
420
|
+
`,S+=I.map(function(u,D){return d(this.line-I.length+D+1,_)+" "+u},this).join(`
|
|
421
|
+
`),S+=`
|
|
422
|
+
`+d("",_+c)+`^
|
|
423
|
+
`,S}else return S+" at index "+(this.index-1);function d(u,D){var f=String(u);return Array(D-f.length+1).join(" ")+f}};function R(o,S,i){if(o instanceof T)var I=o,i=S;else var I=T.fromCompiled(o,S);this.grammar=I,this.options={keepHistory:!1,lexer:I.lexer||new s};for(var O in i||{})this.options[O]=i[O];this.lexer=this.options.lexer,this.lexerState=void 0;var c=new r(I,0);this.table=[c],c.wants[I.start]=[],c.predict(I.start),c.process(),this.current=0}R.fail={},R.prototype.feed=function(o){var S=this.lexer;S.reset(o,this.lexerState);for(var i;;){try{if(i=S.next(),!i)break}catch(Y){var _=new r(this.grammar,this.current+1);this.table.push(_);var I=new Error(this.reportLexerError(Y));throw I.offset=this.current,I.token=Y.token,I}var O=this.table[this.current];this.options.keepHistory||delete this.table[this.current-1];var c=this.current+1,_=new r(this.grammar,c);this.table.push(_);for(var d=i.text!==void 0?i.text:i.value,u=S.constructor===s?i.value:i,D=O.scannable,f=D.length;f--;){var p=D[f],m=p.rule.symbols[p.dot];if(m.test?m.test(u):m.type?m.type===i.type:m.literal===d){var h=p.nextState({data:u,token:i,isToken:!0,reference:c-1});_.states.push(h)}}if(_.process(),_.states.length===0){var I=new Error(this.reportError(i));throw I.offset=this.current,I.token=i,I}this.options.keepHistory&&(O.lexerState=S.save()),this.current++}return O&&(this.lexerState=S.save()),this.results=this.finish(),this},R.prototype.reportLexerError=function(o){var S,i,I=o.token;return I?(S="input "+JSON.stringify(I.text[0])+" (lexer error)",i=this.lexer.formatError(I,"Syntax error")):(S="input (lexer error)",i=o.message),this.reportErrorCommon(i,S)},R.prototype.reportError=function(o){var S=(o.type?o.type+" token: ":"")+JSON.stringify(o.value!==void 0?o.value:o),i=this.lexer.formatError(o,"Syntax error");return this.reportErrorCommon(i,S)},R.prototype.reportErrorCommon=function(o,S){var i=[];i.push(o);var I=this.table.length-2,O=this.table[I],c=O.states.filter(function(d){var u=d.rule.symbols[d.dot];return u&&typeof u!="string"});if(c.length===0)i.push("Unexpected "+S+`. I did not expect any more input. Here is the state of my parse table:
|
|
424
|
+
`),this.displayStateStack(O.states,i);else{i.push("Unexpected "+S+`. Instead, I was expecting to see one of the following:
|
|
425
|
+
`);var _=c.map(function(d){return this.buildFirstStateStack(d,[])||[d]},this);_.forEach(function(d){var u=d[0],D=u.rule.symbols[u.dot],f=this.getSymbolDisplay(D);i.push("A "+f+" based on:"),this.displayStateStack(d,i)},this)}return i.push(""),i.join(`
|
|
426
|
+
`)},R.prototype.displayStateStack=function(o,S){for(var i,I=0,O=0;O<o.length;O++){var c=o[O],_=c.rule.toString(c.dot);_===i?I++:(I>0&&S.push(" ^ "+I+" more lines identical to this"),I=0,S.push(" "+_)),i=_}},R.prototype.getSymbolDisplay=function(o){return A(o)},R.prototype.buildFirstStateStack=function(o,S){if(S.indexOf(o)!==-1)return null;if(o.wantedBy.length===0)return[o];var i=o.wantedBy[0],I=[o].concat(S),O=this.buildFirstStateStack(i,I);return O===null?null:[o].concat(O)},R.prototype.save=function(){var o=this.table[this.current];return o.lexerState=this.lexerState,o},R.prototype.restore=function(o){var S=o.index;this.current=S,this.table[S]=o,this.table.splice(S+1),this.lexerState=o.lexerState,this.results=this.finish()},R.prototype.rewind=function(o){if(!this.options.keepHistory)throw new Error("set option `keepHistory` to enable rewinding");this.restore(this.table[o])},R.prototype.finish=function(){var o=[],S=this.grammar.start,i=this.table[this.table.length-1];return i.states.forEach(function(I){I.rule.name===S&&I.dot===I.rule.symbols.length&&I.reference===0&&I.data!==R.fail&&o.push(I)}),o.map(function(I){return I.data})};function A(o){var S=typeof o;if(S==="string")return o;if(S==="object"){if(o.literal)return JSON.stringify(o.literal);if(o instanceof RegExp)return"character matching "+o;if(o.type)return o.type+" token";if(o.test)return"token matching "+String(o.test);throw new Error("Unknown symbol type: "+o)}}function a(o){var S=typeof o;if(S==="string")return o;if(S==="object"){if(o.literal)return JSON.stringify(o.literal);if(o instanceof RegExp)return o.toString();if(o.type)return"%"+o.type;if(o.test)return"<"+String(o.test)+">";throw new Error("Unknown symbol type: "+o)}}return{Parser:R,Grammar:T,Rule:e}})})(Ge)),Ge.exports}var QS=JS();const ZS=yt(QS);function qS(E){return E.map(zS).map(ei).map(Ei).map(ti).map(Ti)}const zS=(E,e,t)=>{if(zt(E.type)){const r=ri(t,e);if(r&&r.type===C.PROPERTY_ACCESS_OPERATOR)return Object.assign(Object.assign({},E),{type:C.IDENTIFIER,text:E.raw});const T=Le(t,e);if(T&&T.type===C.PROPERTY_ACCESS_OPERATOR)return Object.assign(Object.assign({},E),{type:C.IDENTIFIER,text:E.raw})}return E},ei=(E,e,t)=>{if(E.type===C.RESERVED_FUNCTION_NAME){const r=Le(t,e);if(!r||!nT(r))return Object.assign(Object.assign({},E),{type:C.IDENTIFIER,text:E.raw})}return E},Ei=(E,e,t)=>{if(E.type===C.RESERVED_DATA_TYPE){const r=Le(t,e);if(r&&nT(r))return Object.assign(Object.assign({},E),{type:C.RESERVED_PARAMETERIZED_DATA_TYPE})}return E},ti=(E,e,t)=>{if(E.type===C.IDENTIFIER){const r=Le(t,e);if(r&&sT(r))return Object.assign(Object.assign({},E),{type:C.ARRAY_IDENTIFIER})}return E},Ti=(E,e,t)=>{if(E.type===C.RESERVED_DATA_TYPE){const r=Le(t,e);if(r&&sT(r))return Object.assign(Object.assign({},E),{type:C.ARRAY_KEYWORD})}return E},ri=(E,e)=>Le(E,e,-1),Le=(E,e,t=1)=>{let r=1;for(;E[e+r*t]&&ni(E[e+r*t]);)r++;return E[e+r*t]},nT=E=>E.type===C.OPEN_PAREN&&E.text==="(",sT=E=>E.type===C.OPEN_PAREN&&E.text==="[",ni=E=>E.type===C.BLOCK_COMMENT||E.type===C.LINE_COMMENT;class RT{constructor(e){this.tokenize=e,this.index=0,this.tokens=[],this.input=""}reset(e,t){this.input=e,this.index=0,this.tokens=this.tokenize(e)}next(){return this.tokens[this.index++]}save(){}formatError(e){const{line:t,col:r}=rT(this.input,e.start);return`Parse error at token: ${e.text} at line ${t} column ${r}`}has(e){return e in C}}var P;(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"})(P=P||(P={}));function lE(E){return E[0]}const U=new RT(E=>[]),oe=([[E]])=>E,H=E=>({type:P.keyword,tokenType:E.type,text:E.text,raw:E.raw}),Ut=E=>({type:P.data_type,text:E.text,raw:E.raw}),F=(E,{leading:e,trailing:t})=>(e!=null&&e.length&&(E=Object.assign(Object.assign({},E),{leadingComments:e})),t!=null&&t.length&&(E=Object.assign(Object.assign({},E),{trailingComments:t})),E),si=(E,{leading:e,trailing:t})=>{if(e!=null&&e.length){const[r,...T]=E;E=[F(r,{leading:e}),...T]}if(t!=null&&t.length){const r=E.slice(0,-1),T=E[E.length-1];E=[...r,F(T,{trailing:t})]}return E},Ri={Lexer:U,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 e=E[E.length-1];return e&&!e.hasSemicolon?e.children.length>0?E:E.slice(0,-1):E}},{name:"statement$subexpression$1",symbols:[U.has("DELIMITER")?{type:"DELIMITER"}:DELIMITER]},{name:"statement$subexpression$1",symbols:[U.has("EOF")?{type:"EOF"}:EOF]},{name:"statement",symbols:["expressions_or_clauses","statement$subexpression$1"],postprocess:([E,[e]])=>({type:P.statement,children:E,hasSemicolon:e.type===C.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,e])=>[...E,...e]},{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:oe},{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:[U.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:lE},{name:"limit_clause$ebnf$1",symbols:[],postprocess:()=>null},{name:"limit_clause",symbols:[U.has("LIMIT")?{type:"LIMIT"}:LIMIT,"_","expression_chain_","limit_clause$ebnf$1"],postprocess:([E,e,t,r])=>{if(r){const[T,s]=r;return{type:P.limit_clause,limitKw:F(H(E),{trailing:e}),offset:t,count:s}}else return{type:P.limit_clause,limitKw:F(H(E),{trailing:e}),count:t}}},{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:[U.has("RESERVED_SELECT")?{type:"RESERVED_SELECT"}:RESERVED_SELECT,"select_clause$subexpression$1"],postprocess:([E,[e,t]])=>({type:P.clause,nameKw:H(E),children:[e,...t]})},{name:"select_clause",symbols:[U.has("RESERVED_SELECT")?{type:"RESERVED_SELECT"}:RESERVED_SELECT],postprocess:([E])=>({type:P.clause,nameKw:H(E),children:[]})},{name:"all_columns_asterisk",symbols:[U.has("ASTERISK")?{type:"ASTERISK"}:ASTERISK],postprocess:()=>({type:P.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:[U.has("RESERVED_CLAUSE")?{type:"RESERVED_CLAUSE"}:RESERVED_CLAUSE,"other_clause$ebnf$1"],postprocess:([E,e])=>({type:P.clause,nameKw:H(E),children:e})},{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:[U.has("RESERVED_SET_OPERATION")?{type:"RESERVED_SET_OPERATION"}:RESERVED_SET_OPERATION,"set_operation$ebnf$1"],postprocess:([E,e])=>({type:P.set_operation,nameKw:H(E),children:e})},{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:lE},{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,e])=>[E,...e]},{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,e])=>[E,...e]},{name:"expression_with_comments_",symbols:["expression","_"],postprocess:([E,e])=>F(E,{trailing:e})},{name:"_expression_with_comments",symbols:["_","expression"],postprocess:([E,e])=>F(e,{leading:E})},{name:"_andless_expression_with_comments",symbols:["_","andless_expression"],postprocess:([E,e])=>F(e,{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:oe},{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:oe},{name:"expression$subexpression$1",symbols:["andless_expression"]},{name:"expression$subexpression$1",symbols:["logic_operator"]},{name:"expression",symbols:["expression$subexpression$1"],postprocess:oe},{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:oe},{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:oe},{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:oe},{name:"array_subscript",symbols:[U.has("ARRAY_IDENTIFIER")?{type:"ARRAY_IDENTIFIER"}:ARRAY_IDENTIFIER,"_","square_brackets"],postprocess:([E,e,t])=>({type:P.array_subscript,array:F({type:P.identifier,quoted:!1,text:E.text},{trailing:e}),parenthesis:t})},{name:"array_subscript",symbols:[U.has("ARRAY_KEYWORD")?{type:"ARRAY_KEYWORD"}:ARRAY_KEYWORD,"_","square_brackets"],postprocess:([E,e,t])=>({type:P.array_subscript,array:F(H(E),{trailing:e}),parenthesis:t})},{name:"function_call",symbols:[U.has("RESERVED_FUNCTION_NAME")?{type:"RESERVED_FUNCTION_NAME"}:RESERVED_FUNCTION_NAME,"_","parenthesis"],postprocess:([E,e,t])=>({type:P.function_call,nameKw:F(H(E),{trailing:e}),parenthesis:t})},{name:"parenthesis",symbols:[{literal:"("},"expressions_or_clauses",{literal:")"}],postprocess:([E,e,t])=>({type:P.parenthesis,children:e,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,e,t])=>({type:P.parenthesis,children:e,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,e,t])=>({type:P.parenthesis,children:e,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","_",U.has("PROPERTY_ACCESS_OPERATOR")?{type:"PROPERTY_ACCESS_OPERATOR"}:PROPERTY_ACCESS_OPERATOR,"_","property_access$subexpression$1"],postprocess:([E,e,t,r,[T]])=>({type:P.property_access,object:F(E,{trailing:e}),operator:t.text,property:F(T,{leading:r})})},{name:"between_predicate",symbols:[U.has("BETWEEN")?{type:"BETWEEN"}:BETWEEN,"_","andless_expression_chain","_",U.has("AND")?{type:"AND"}:AND,"_","andless_expression"],postprocess:([E,e,t,r,T,s,R])=>({type:P.between_predicate,betweenKw:H(E),expr1:si(t,{leading:e,trailing:r}),andKw:H(T),expr2:[F(R,{leading:s})]})},{name:"case_expression$ebnf$1",symbols:["expression_chain_"],postprocess:lE},{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:[U.has("CASE")?{type:"CASE"}:CASE,"_","case_expression$ebnf$1","case_expression$ebnf$2",U.has("END")?{type:"END"}:END],postprocess:([E,e,t,r,T])=>({type:P.case_expression,caseKw:F(H(E),{trailing:e}),endKw:H(T),expr:t||[],clauses:r})},{name:"case_clause",symbols:[U.has("WHEN")?{type:"WHEN"}:WHEN,"_","expression_chain_",U.has("THEN")?{type:"THEN"}:THEN,"_","expression_chain_"],postprocess:([E,e,t,r,T,s])=>({type:P.case_when,whenKw:F(H(E),{trailing:e}),thenKw:F(H(r),{trailing:T}),condition:t,result:s})},{name:"case_clause",symbols:[U.has("ELSE")?{type:"ELSE"}:ELSE,"_","expression_chain_"],postprocess:([E,e,t])=>({type:P.case_else,elseKw:F(H(E),{trailing:e}),result:t})},{name:"comma$subexpression$1",symbols:[U.has("COMMA")?{type:"COMMA"}:COMMA]},{name:"comma",symbols:["comma$subexpression$1"],postprocess:([[E]])=>({type:P.comma})},{name:"asterisk$subexpression$1",symbols:[U.has("ASTERISK")?{type:"ASTERISK"}:ASTERISK]},{name:"asterisk",symbols:["asterisk$subexpression$1"],postprocess:([[E]])=>({type:P.operator,text:E.text})},{name:"operator$subexpression$1",symbols:[U.has("OPERATOR")?{type:"OPERATOR"}:OPERATOR]},{name:"operator",symbols:["operator$subexpression$1"],postprocess:([[E]])=>({type:P.operator,text:E.text})},{name:"identifier$subexpression$1",symbols:[U.has("IDENTIFIER")?{type:"IDENTIFIER"}:IDENTIFIER]},{name:"identifier$subexpression$1",symbols:[U.has("QUOTED_IDENTIFIER")?{type:"QUOTED_IDENTIFIER"}:QUOTED_IDENTIFIER]},{name:"identifier$subexpression$1",symbols:[U.has("VARIABLE")?{type:"VARIABLE"}:VARIABLE]},{name:"identifier",symbols:["identifier$subexpression$1"],postprocess:([[E]])=>({type:P.identifier,quoted:E.type!=="IDENTIFIER",text:E.text})},{name:"parameter$subexpression$1",symbols:[U.has("NAMED_PARAMETER")?{type:"NAMED_PARAMETER"}:NAMED_PARAMETER]},{name:"parameter$subexpression$1",symbols:[U.has("QUOTED_PARAMETER")?{type:"QUOTED_PARAMETER"}:QUOTED_PARAMETER]},{name:"parameter$subexpression$1",symbols:[U.has("NUMBERED_PARAMETER")?{type:"NUMBERED_PARAMETER"}:NUMBERED_PARAMETER]},{name:"parameter$subexpression$1",symbols:[U.has("POSITIONAL_PARAMETER")?{type:"POSITIONAL_PARAMETER"}:POSITIONAL_PARAMETER]},{name:"parameter$subexpression$1",symbols:[U.has("CUSTOM_PARAMETER")?{type:"CUSTOM_PARAMETER"}:CUSTOM_PARAMETER]},{name:"parameter",symbols:["parameter$subexpression$1"],postprocess:([[E]])=>({type:P.parameter,key:E.key,text:E.text})},{name:"literal$subexpression$1",symbols:[U.has("NUMBER")?{type:"NUMBER"}:NUMBER]},{name:"literal$subexpression$1",symbols:[U.has("STRING")?{type:"STRING"}:STRING]},{name:"literal",symbols:["literal$subexpression$1"],postprocess:([[E]])=>({type:P.literal,text:E.text})},{name:"keyword$subexpression$1",symbols:[U.has("RESERVED_KEYWORD")?{type:"RESERVED_KEYWORD"}:RESERVED_KEYWORD]},{name:"keyword$subexpression$1",symbols:[U.has("RESERVED_KEYWORD_PHRASE")?{type:"RESERVED_KEYWORD_PHRASE"}:RESERVED_KEYWORD_PHRASE]},{name:"keyword$subexpression$1",symbols:[U.has("RESERVED_JOIN")?{type:"RESERVED_JOIN"}:RESERVED_JOIN]},{name:"keyword",symbols:["keyword$subexpression$1"],postprocess:([[E]])=>H(E)},{name:"data_type$subexpression$1",symbols:[U.has("RESERVED_DATA_TYPE")?{type:"RESERVED_DATA_TYPE"}:RESERVED_DATA_TYPE]},{name:"data_type$subexpression$1",symbols:[U.has("RESERVED_DATA_TYPE_PHRASE")?{type:"RESERVED_DATA_TYPE_PHRASE"}:RESERVED_DATA_TYPE_PHRASE]},{name:"data_type",symbols:["data_type$subexpression$1"],postprocess:([[E]])=>Ut(E)},{name:"data_type",symbols:[U.has("RESERVED_PARAMETERIZED_DATA_TYPE")?{type:"RESERVED_PARAMETERIZED_DATA_TYPE"}:RESERVED_PARAMETERIZED_DATA_TYPE,"_","parenthesis"],postprocess:([E,e,t])=>({type:P.parameterized_data_type,dataType:F(Ut(E),{trailing:e}),parenthesis:t})},{name:"logic_operator$subexpression$1",symbols:[U.has("AND")?{type:"AND"}:AND]},{name:"logic_operator$subexpression$1",symbols:[U.has("OR")?{type:"OR"}:OR]},{name:"logic_operator$subexpression$1",symbols:[U.has("XOR")?{type:"XOR"}:XOR]},{name:"logic_operator",symbols:["logic_operator$subexpression$1"],postprocess:([[E]])=>H(E)},{name:"other_keyword$subexpression$1",symbols:[U.has("WHEN")?{type:"WHEN"}:WHEN]},{name:"other_keyword$subexpression$1",symbols:[U.has("THEN")?{type:"THEN"}:THEN]},{name:"other_keyword$subexpression$1",symbols:[U.has("ELSE")?{type:"ELSE"}:ELSE]},{name:"other_keyword$subexpression$1",symbols:[U.has("END")?{type:"END"}:END]},{name:"other_keyword",symbols:["other_keyword$subexpression$1"],postprocess:([[E]])=>H(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:[U.has("LINE_COMMENT")?{type:"LINE_COMMENT"}:LINE_COMMENT],postprocess:([E])=>({type:P.line_comment,text:E.text,precedingWhitespace:E.precedingWhitespace})},{name:"comment",symbols:[U.has("BLOCK_COMMENT")?{type:"BLOCK_COMMENT"}:BLOCK_COMMENT],postprocess:([E])=>({type:P.block_comment,text:E.text,precedingWhitespace:E.precedingWhitespace})},{name:"comment",symbols:[U.has("DISABLE_COMMENT")?{type:"DISABLE_COMMENT"}:DISABLE_COMMENT],postprocess:([E])=>({type:P.disable_comment,text:E.text,precedingWhitespace:E.precedingWhitespace})}],ParserStart:"main"},{Parser:Ai,Grammar:oi}=ZS;function Si(E){let e={};const t=new RT(T=>[...qS(E.tokenize(T,e)),qt(T.length)]),r=new Ai(oi.fromCompiled(Ri),{lexer:t});return{parse:(T,s)=>{e=s;const{results:R}=r.feed(T);if(R.length===1)return R[0];throw R.length===0?new Error("Parse error: Invalid SQL"):new Error(`Parse error: Ambiguous grammar
|
|
427
|
+
${JSON.stringify(R,void 0,2)}`)}}}var L;(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"})(L=L||(L={}));class AT{constructor(e){this.indentation=e,this.items=[]}add(...e){for(const t of e)switch(t){case L.SPACE:this.items.push(L.SPACE);break;case L.NO_SPACE:this.trimHorizontalWhitespace();break;case L.NO_NEWLINE:this.trimWhitespace();break;case L.NEWLINE:this.trimHorizontalWhitespace(),this.addNewline(L.NEWLINE);break;case L.MANDATORY_NEWLINE:this.trimHorizontalWhitespace(),this.addNewline(L.MANDATORY_NEWLINE);break;case L.INDENT:this.addIndentation();break;case L.SINGLE_INDENT:this.items.push(L.SINGLE_INDENT);break;default:this.items.push(t)}}trimHorizontalWhitespace(){for(;ii(de(this.items));)this.items.pop()}trimWhitespace(){for(;ai(de(this.items));)this.items.pop()}addNewline(e){if(this.items.length>0)switch(de(this.items)){case L.NEWLINE:this.items.pop(),this.items.push(e);break;case L.MANDATORY_NEWLINE:break;default:this.items.push(e);break}}addIndentation(){for(let e=0;e<this.indentation.getLevel();e++)this.items.push(L.SINGLE_INDENT)}toString(){return this.items.map(e=>this.itemToString(e)).join("")}getLayoutItems(){return this.items}itemToString(e){switch(e){case L.SPACE:return" ";case L.NEWLINE:case L.MANDATORY_NEWLINE:return`
|
|
428
|
+
`;case L.SINGLE_INDENT:return this.indentation.getSingleIndent();default:return e}}}const ii=E=>E===L.SPACE||E===L.SINGLE_INDENT,ai=E=>E===L.SPACE||E===L.SINGLE_INDENT||E===L.NEWLINE;function ht(E,e){if(e==="standard")return E;let t=[];return E.length>=10&&E.includes(" ")&&([E,...t]=E.split(" ")),e==="tabularLeft"?E=E.padEnd(9," "):E=E.padStart(9," "),E+["",...t].join(" ")}function ft(E){return Hs(E)||E===C.RESERVED_CLAUSE||E===C.RESERVED_SELECT||E===C.RESERVED_SET_OPERATION||E===C.RESERVED_JOIN||E===C.LIMIT}const LE="top-level",Ii="block-level";class oT{constructor(e){this.indent=e,this.indentTypes=[]}getSingleIndent(){return this.indent}getLevel(){return this.indentTypes.length}increaseTopLevel(){this.indentTypes.push(LE)}increaseBlockLevel(){this.indentTypes.push(Ii)}decreaseTopLevel(){this.indentTypes.length>0&&de(this.indentTypes)===LE&&this.indentTypes.pop()}decreaseBlockLevel(){for(;this.indentTypes.length>0&&this.indentTypes.pop()===LE;);}}class Oi extends AT{constructor(e){super(new oT("")),this.expressionWidth=e,this.length=0,this.trailingSpace=!1}add(...e){if(e.forEach(t=>this.addToLength(t)),this.length>this.expressionWidth)throw new PE;super.add(...e)}addToLength(e){if(typeof e=="string")this.length+=e.length,this.trailingSpace=!1;else{if(e===L.MANDATORY_NEWLINE||e===L.NEWLINE)throw new PE;e===L.INDENT||e===L.SINGLE_INDENT||e===L.SPACE?this.trailingSpace||(this.length++,this.trailingSpace=!0):(e===L.NO_NEWLINE||e===L.NO_SPACE)&&this.trailingSpace&&(this.trailingSpace=!1,this.length--)}}}class PE extends Error{}class ve{constructor({cfg:e,dialectCfg:t,params:r,layout:T,inline:s=!1}){this.inline=!1,this.nodes=[],this.index=-1,this.cfg=e,this.dialectCfg=t,this.inline=s,this.params=r,this.layout=T}format(e){for(this.nodes=e,this.index=0;this.index<this.nodes.length;this.index++)this.formatNode(this.nodes[this.index]);return this.layout}formatNode(e){this.formatComments(e.leadingComments),this.formatNodeWithoutComments(e),this.formatComments(e.trailingComments)}formatNodeWithoutComments(e){switch(e.type){case P.function_call:return this.formatFunctionCall(e);case P.parameterized_data_type:return this.formatParameterizedDataType(e);case P.array_subscript:return this.formatArraySubscript(e);case P.property_access:return this.formatPropertyAccess(e);case P.parenthesis:return this.formatParenthesis(e);case P.between_predicate:return this.formatBetweenPredicate(e);case P.case_expression:return this.formatCaseExpression(e);case P.case_when:return this.formatCaseWhen(e);case P.case_else:return this.formatCaseElse(e);case P.clause:return this.formatClause(e);case P.set_operation:return this.formatSetOperation(e);case P.limit_clause:return this.formatLimitClause(e);case P.all_columns_asterisk:return this.formatAllColumnsAsterisk(e);case P.literal:return this.formatLiteral(e);case P.identifier:return this.formatIdentifier(e);case P.parameter:return this.formatParameter(e);case P.operator:return this.formatOperator(e);case P.comma:return this.formatComma(e);case P.line_comment:return this.formatLineComment(e);case P.block_comment:return this.formatBlockComment(e);case P.disable_comment:return this.formatBlockComment(e);case P.data_type:return this.formatDataType(e);case P.keyword:return this.formatKeywordNode(e)}}formatFunctionCall(e){this.withComments(e.nameKw,()=>{this.layout.add(this.showFunctionKw(e.nameKw))}),this.formatNode(e.parenthesis)}formatParameterizedDataType(e){this.withComments(e.dataType,()=>{this.layout.add(this.showDataType(e.dataType))}),this.formatNode(e.parenthesis)}formatArraySubscript(e){let t;switch(e.array.type){case P.data_type:t=this.showDataType(e.array);break;case P.keyword:t=this.showKw(e.array);break;default:t=this.showIdentifier(e.array);break}this.withComments(e.array,()=>{this.layout.add(t)}),this.formatNode(e.parenthesis)}formatPropertyAccess(e){this.formatNode(e.object),this.layout.add(L.NO_SPACE,e.operator),this.formatNode(e.property)}formatParenthesis(e){const t=this.formatInlineExpression(e.children);t?(this.layout.add(e.openParen),this.layout.add(...t.getLayoutItems()),this.layout.add(L.NO_SPACE,e.closeParen,L.SPACE)):(this.layout.add(e.openParen,L.NEWLINE),Ie(this.cfg)?(this.layout.add(L.INDENT),this.layout=this.formatSubExpression(e.children)):(this.layout.indentation.increaseBlockLevel(),this.layout.add(L.INDENT),this.layout=this.formatSubExpression(e.children),this.layout.indentation.decreaseBlockLevel()),this.layout.add(L.NEWLINE,L.INDENT,e.closeParen,L.SPACE))}formatBetweenPredicate(e){this.layout.add(this.showKw(e.betweenKw),L.SPACE),this.layout=this.formatSubExpression(e.expr1),this.layout.add(L.NO_SPACE,L.SPACE,this.showNonTabularKw(e.andKw),L.SPACE),this.layout=this.formatSubExpression(e.expr2),this.layout.add(L.SPACE)}formatCaseExpression(e){this.formatNode(e.caseKw),this.layout.indentation.increaseBlockLevel(),this.layout=this.formatSubExpression(e.expr),this.layout=this.formatSubExpression(e.clauses),this.layout.indentation.decreaseBlockLevel(),this.layout.add(L.NEWLINE,L.INDENT),this.formatNode(e.endKw)}formatCaseWhen(e){this.layout.add(L.NEWLINE,L.INDENT),this.formatNode(e.whenKw),this.layout=this.formatSubExpression(e.condition),this.formatNode(e.thenKw),this.layout=this.formatSubExpression(e.result)}formatCaseElse(e){this.layout.add(L.NEWLINE,L.INDENT),this.formatNode(e.elseKw),this.layout=this.formatSubExpression(e.result)}formatClause(e){this.isOnelineClause(e)?this.formatClauseInOnelineStyle(e):Ie(this.cfg)?this.formatClauseInTabularStyle(e):this.formatClauseInIndentedStyle(e)}isOnelineClause(e){return Ie(this.cfg)?this.dialectCfg.tabularOnelineClauses[e.nameKw.text]:this.dialectCfg.onelineClauses[e.nameKw.text]}formatClauseInIndentedStyle(e){this.layout.add(L.NEWLINE,L.INDENT,this.showKw(e.nameKw),L.NEWLINE),this.layout.indentation.increaseTopLevel(),this.layout.add(L.INDENT),this.layout=this.formatSubExpression(e.children),this.layout.indentation.decreaseTopLevel()}formatClauseInOnelineStyle(e){this.layout.add(L.NEWLINE,L.INDENT,this.showKw(e.nameKw),L.SPACE),this.layout=this.formatSubExpression(e.children)}formatClauseInTabularStyle(e){this.layout.add(L.NEWLINE,L.INDENT,this.showKw(e.nameKw),L.SPACE),this.layout.indentation.increaseTopLevel(),this.layout=this.formatSubExpression(e.children),this.layout.indentation.decreaseTopLevel()}formatSetOperation(e){this.layout.add(L.NEWLINE,L.INDENT,this.showKw(e.nameKw),L.NEWLINE),this.layout.add(L.INDENT),this.layout=this.formatSubExpression(e.children)}formatLimitClause(e){this.withComments(e.limitKw,()=>{this.layout.add(L.NEWLINE,L.INDENT,this.showKw(e.limitKw))}),this.layout.indentation.increaseTopLevel(),Ie(this.cfg)?this.layout.add(L.SPACE):this.layout.add(L.NEWLINE,L.INDENT),e.offset?(this.layout=this.formatSubExpression(e.offset),this.layout.add(L.NO_SPACE,",",L.SPACE),this.layout=this.formatSubExpression(e.count)):this.layout=this.formatSubExpression(e.count),this.layout.indentation.decreaseTopLevel()}formatAllColumnsAsterisk(e){this.layout.add("*",L.SPACE)}formatLiteral(e){this.layout.add(e.text,L.SPACE)}formatIdentifier(e){this.layout.add(this.showIdentifier(e),L.SPACE)}formatParameter(e){this.layout.add(this.params.get(e),L.SPACE)}formatOperator({text:e}){this.cfg.denseOperators||this.dialectCfg.alwaysDenseOperators.includes(e)?this.layout.add(L.NO_SPACE,e):e===":"?this.layout.add(L.NO_SPACE,e,L.SPACE):this.layout.add(e,L.SPACE)}formatComma(e){this.inline?this.layout.add(L.NO_SPACE,",",L.SPACE):this.layout.add(L.NO_SPACE,",",L.NEWLINE,L.INDENT)}withComments(e,t){this.formatComments(e.leadingComments),t(),this.formatComments(e.trailingComments)}formatComments(e){e&&e.forEach(t=>{t.type===P.line_comment?this.formatLineComment(t):this.formatBlockComment(t)})}formatLineComment(e){OE(e.precedingWhitespace||"")?this.layout.add(L.NEWLINE,L.INDENT,e.text,L.MANDATORY_NEWLINE,L.INDENT):this.layout.getLayoutItems().length>0?this.layout.add(L.NO_NEWLINE,L.SPACE,e.text,L.MANDATORY_NEWLINE,L.INDENT):this.layout.add(e.text,L.MANDATORY_NEWLINE,L.INDENT)}formatBlockComment(e){e.type===P.block_comment&&this.isMultilineBlockComment(e)?(this.splitBlockComment(e.text).forEach(t=>{this.layout.add(L.NEWLINE,L.INDENT,t)}),this.layout.add(L.NEWLINE,L.INDENT)):this.layout.add(e.text,L.SPACE)}isMultilineBlockComment(e){return OE(e.text)||OE(e.precedingWhitespace||"")}isDocComment(e){const t=e.split(/\n/);return/^\/\*\*?$/.test(t[0])&&t.slice(1,t.length-1).every(r=>/^\s*\*/.test(r))&&/^\s*\*\/$/.test(de(t))}splitBlockComment(e){return this.isDocComment(e)?e.split(/\n/).map(t=>/^\s*\*/.test(t)?" "+t.replace(/^\s*/,""):t):e.split(/\n/).map(t=>t.replace(/^\s*/,""))}formatSubExpression(e){return new ve({cfg:this.cfg,dialectCfg:this.dialectCfg,params:this.params,layout:this.layout,inline:this.inline}).format(e)}formatInlineExpression(e){const t=this.params.getPositionalParameterIndex();try{return new ve({cfg:this.cfg,dialectCfg:this.dialectCfg,params:this.params,layout:new Oi(this.cfg.expressionWidth),inline:!0}).format(e)}catch(r){if(r instanceof PE){this.params.setPositionalParameterIndex(t);return}else throw r}}formatKeywordNode(e){switch(e.tokenType){case C.RESERVED_JOIN:return this.formatJoin(e);case C.AND:case C.OR:case C.XOR:return this.formatLogicalOperator(e);default:return this.formatKeyword(e)}}formatJoin(e){Ie(this.cfg)?(this.layout.indentation.decreaseTopLevel(),this.layout.add(L.NEWLINE,L.INDENT,this.showKw(e),L.SPACE),this.layout.indentation.increaseTopLevel()):this.layout.add(L.NEWLINE,L.INDENT,this.showKw(e),L.SPACE)}formatKeyword(e){this.layout.add(this.showKw(e),L.SPACE)}formatLogicalOperator(e){this.cfg.logicalOperatorNewline==="before"?Ie(this.cfg)?(this.layout.indentation.decreaseTopLevel(),this.layout.add(L.NEWLINE,L.INDENT,this.showKw(e),L.SPACE),this.layout.indentation.increaseTopLevel()):this.layout.add(L.NEWLINE,L.INDENT,this.showKw(e),L.SPACE):this.layout.add(this.showKw(e),L.NEWLINE,L.INDENT)}formatDataType(e){this.layout.add(this.showDataType(e),L.SPACE)}showKw(e){return ft(e.tokenType)?ht(this.showNonTabularKw(e),this.cfg.indentStyle):this.showNonTabularKw(e)}showNonTabularKw(e){switch(this.cfg.keywordCase){case"preserve":return xe(e.raw);case"upper":return e.text;case"lower":return e.text.toLowerCase()}}showFunctionKw(e){return ft(e.tokenType)?ht(this.showNonTabularFunctionKw(e),this.cfg.indentStyle):this.showNonTabularFunctionKw(e)}showNonTabularFunctionKw(e){switch(this.cfg.functionCase){case"preserve":return xe(e.raw);case"upper":return e.text;case"lower":return e.text.toLowerCase()}}showIdentifier(e){if(e.quoted)return e.text;switch(this.cfg.identifierCase){case"preserve":return e.text;case"upper":return e.text.toUpperCase();case"lower":return e.text.toLowerCase()}}showDataType(e){switch(this.cfg.dataTypeCase){case"preserve":return xe(e.raw);case"upper":return e.text;case"lower":return e.text.toLowerCase()}}}class Ni{constructor(e,t){this.dialect=e,this.cfg=t,this.params=new kS(this.cfg.params)}format(e){const t=this.parse(e);return this.formatAst(t).trimEnd()}parse(e){return Si(this.dialect.tokenizer).parse(e,this.cfg.paramTypes||{})}formatAst(e){return e.map(t=>this.formatStatement(t)).join(`
|
|
429
|
+
`.repeat(this.cfg.linesBetweenQueries+1))}formatStatement(e){const t=new ve({cfg:this.cfg,dialectCfg:this.dialect.formatOptions,params:this.params,layout:new AT(new oT($S(this.cfg)))}).format(e.children);return e.hasSemicolon&&(this.cfg.newlineBeforeSemicolon?t.add(L.NEWLINE,";"):t.add(L.NO_NEWLINE,";")),t.toString()}}class ye extends Error{}function li(E){const e=["multilineLists","newlineBeforeOpenParen","newlineBeforeCloseParen","aliasAs","commaPosition","tabulateAlias"];for(const t of e)if(t in E)throw new ye(`${t} config is no more supported.`);if(E.expressionWidth<=0)throw new ye(`expressionWidth config must be positive number. Received ${E.expressionWidth} instead.`);if(E.params&&!Li(E.params)&&console.warn('WARNING: All "params" option values should be strings.'),E.paramTypes&&!Ci(E.paramTypes))throw new ye("Empty regex given in custom paramTypes. That would result in matching infinite amount of parameters.");return E}function Li(E){return(E instanceof Array?E:Object.values(E)).every(t=>typeof t=="string")}function Ci(E){return E.custom&&Array.isArray(E.custom)?E.custom.every(e=>e.regex!==""):!0}var ci=function(E,e){var t={};for(var r in E)Object.prototype.hasOwnProperty.call(E,r)&&e.indexOf(r)<0&&(t[r]=E[r]);if(E!=null&&typeof Object.getOwnPropertySymbols=="function")for(var T=0,r=Object.getOwnPropertySymbols(E);T<r.length;T++)e.indexOf(r[T])<0&&Object.prototype.propertyIsEnumerable.call(E,r[T])&&(t[r[T]]=E[r[T]]);return t};const ST={bigquery:"bigquery",clickhouse:"clickhouse",db2:"db2",db2i:"db2i",duckdb:"duckdb",hive:"hive",mariadb:"mariadb",mysql:"mysql",n1ql:"n1ql",plsql:"plsql",postgresql:"postgresql",redshift:"redshift",spark:"spark",sqlite:"sqlite",sql:"sql",tidb:"tidb",trino:"trino",transactsql:"transactsql",tsql:"transactsql",singlestoredb:"singlestoredb",snowflake:"snowflake"},_i=Object.keys(ST),di={tabWidth:2,useTabs:!1,keywordCase:"preserve",identifierCase:"preserve",dataTypeCase:"preserve",functionCase:"preserve",indentStyle:"standard",logicalOperatorNewline:"before",expressionWidth:50,linesBetweenQueries:1,denseOperators:!1,newlineBeforeSemicolon:!1},Di=(E,e={})=>{if(typeof e.language=="string"&&!_i.includes(e.language))throw new ye(`Unsupported SQL dialect: ${e.language}`);const t=ST[e.language||"sql"];return ui(E,Object.assign(Object.assign({},e),{dialect:fS[t]}))},ui=(E,e)=>{var{dialect:t}=e,r=ci(e,["dialect"]);if(typeof E!="string")throw new Error("Invalid query argument. Expected string, instead got "+typeof E);const T=li(Object.assign(Object.assign({},di),r));return new Ni(XS(t),T).format(E)},Pi={sql:"SQL",markdown:"MD",dql:"DQL",param:"PARAM"},CE={sql:"#388bfd",markdown:"#56d364",dql:"#e3b341",param:"#e3b341"};function pi(E,e){switch(E.status){case"running":return e.cellBorderRunning;case"success":return e.success;case"error":return e.error;default:return e.cellBorder}}function Mi({cell:E,t:e}){let t="",r=e.textMuted;return E.status==="running"?(t="[*]",r=e.cellBorderRunning):E.status==="error"?(t="[!]",r=e.error):E.executionCount!==void 0?(t=`[${E.executionCount}]`,r=e.textMuted):(t="[ ]",r=e.textMuted),n.jsx("div",{style:{width:40,display:"flex",alignItems:"flex-start",justifyContent:"center",paddingTop:12,flexShrink:0},children:n.jsx("span",{style:{fontFamily:e.fontMono,fontSize:11,color:r,lineHeight:1.4,userSelect:"none",transition:"color 0.2s"},children:t})})}function Ui({cell:E,index:e}){const{state:t,dispatch:r}=y(),T=G[t.themeMode],{executeCell:s,executeDependents:R}=hE(),[A,a]=l.useState(!1),[o,S]=l.useState(!1),[i,I]=l.useState(E.name??""),[O,c]=l.useState(!0),[_,d]=l.useState("table"),u=pi(E,T),D=E.type!=="markdown"&&E.type!=="param",f=l.useMemo(()=>t.schemaTables.length>0?Object.fromEntries(t.schemaTables.map(M=>[M.name,M.columns.map($=>$.name)])):void 0,[t.schemaTables]);if(E.type==="param")return n.jsxs("div",{onMouseEnter:()=>a(!0),onMouseLeave:()=>a(!1),style:{display:"flex",gap:0,marginBottom:2},children:[n.jsx("div",{style:{width:40,flexShrink:0}}),n.jsx("div",{style:{flex:1,minWidth:0},children:n.jsx(os,{cell:E,themeMode:t.themeMode,onApplyParam:R})})]});l.useEffect(()=>{if(E.status==="success"&&E.result){const M=uE(E.result,E.chartConfig);d(M!=="table"?"chart":"table")}},[E.status,E.result,E.chartConfig]);const p=l.useCallback(()=>{D&&s(E.id)},[E.id,s,D]),m=l.useCallback(M=>{r({type:"UPDATE_CELL",id:E.id,updates:{content:M}})},[E.id,r]),h=l.useCallback(()=>{if(E.content.trim())try{const M=Di(E.content,{language:"sql",tabWidth:2,keywordCase:"upper",linesBetweenQueries:1});r({type:"UPDATE_CELL",id:E.id,updates:{content:M}})}catch{}},[E.content,E.id,r]),Y=l.useCallback(()=>{h(),setTimeout(()=>s(E.id),80)},[h,s,E.id]),b=()=>{r({type:"DELETE_CELL",id:E.id})},Ee=()=>{r({type:"MOVE_CELL",id:E.id,direction:"up"})},Z=()=>{r({type:"MOVE_CELL",id:E.id,direction:"down"})},B=()=>{S(!1),r({type:"UPDATE_CELL",id:E.id,updates:{name:i.trim()||void 0}})},Re=(E.result||E.error)&&E.type!=="markdown",x=E.result?uE(E.result,E.chartConfig)!=="table":!1;return n.jsxs("div",{onMouseEnter:()=>a(!0),onMouseLeave:()=>a(!1),style:{display:"flex",gap:0,marginBottom:2},children:[n.jsx(Mi,{cell:E,t:T}),n.jsxs("div",{style:{flex:1,minWidth:0,borderRadius:8,border:`1px solid ${A||E.status!=="idle"?u:T.cellBorder}`,borderLeft:`2px solid ${u}`,background:T.cellBg,overflow:"hidden",transition:"border-color 0.2s"},children:[n.jsxs("div",{style:{height:32,display:"flex",alignItems:"center",padding:"0 8px 0 10px",gap:8,borderBottom:`1px solid ${T.cellBorder}`,background:`${T.tableHeaderBg}80`},children:[n.jsx("span",{style:{fontSize:10,fontWeight:700,fontFamily:T.fontMono,letterSpacing:"0.08em",color:CE[E.type]??T.accent,background:`${CE[E.type]??T.accent}18`,border:`1px solid ${CE[E.type]??T.accent}40`,borderRadius:4,padding:"1px 6px",flexShrink:0,textTransform:"uppercase"},children:Pi[E.type]}),A&&(E.type==="sql"||E.type==="dql")&&n.jsx(is,{themeMode:t.themeMode,cellType:E.type,onInsert:M=>m(M)}),A&&(E.type==="sql"||E.type==="dql")&&n.jsx("button",{title:"Format SQL (clean up whitespace & keywords)",onClick:h,style:{background:"transparent",border:`1px solid ${T.btnBorder}`,borderRadius:4,color:T.textMuted,fontSize:10,fontFamily:T.font,fontWeight:600,letterSpacing:"0.04em",padding:"1px 7px",cursor:"pointer",transition:"color 0.15s, border-color 0.15s"},onMouseEnter:M=>{M.currentTarget.style.color=T.textSecondary,M.currentTarget.style.borderColor=T.accent},onMouseLeave:M=>{M.currentTarget.style.color=T.textMuted,M.currentTarget.style.borderColor=T.btnBorder},children:"Format"}),o?n.jsx("input",{autoFocus:!0,value:i,onChange:M=>I(M.target.value),onBlur:B,onKeyDown:M=>{M.key==="Enter"&&B(),M.key==="Escape"&&S(!1)},style:{background:"transparent",border:`1px solid ${T.cellBorderActive}`,borderRadius:4,color:T.textSecondary,fontSize:12,fontFamily:T.fontMono,padding:"1px 6px",outline:"none",width:140}}):E.name&&n.jsx("span",{onClick:()=>{I(E.name??""),S(!0)},title:"Click to rename",style:{color:T.textSecondary,fontSize:12,fontFamily:T.fontMono,cursor:"text",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",maxWidth:200},children:E.name}),n.jsx("div",{style:{flex:1}}),A&&n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:2},children:[!E.name&&!o&&n.jsx(_e,{title:"Name this cell",onClick:()=>{I(""),S(!0)},t:T,children:n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M11.013 1.427a1.75 1.75 0 0 1 2.474 0l1.086 1.086a1.75 1.75 0 0 1 0 2.474l-8.61 8.61c-.21.21-.47.364-.756.445l-3.251.93a.75.75 0 0 1-.927-.928l.929-3.25c.081-.286.235-.547.445-.758l8.61-8.61Zm.176 4.823L9.75 4.81l-6.286 6.287a.253.253 0 0 0-.064.108l-.558 1.953 1.953-.558a.253.253 0 0 0 .108-.064Zm1.238-3.763a.25.25 0 0 0-.354 0L10.811 3.75l1.439 1.44 1.263-1.263a.25.25 0 0 0 0-.354Z"})})}),D&&n.jsx(_e,{title:"Run cell (Shift+Enter)",onClick:p,t:T,accent:!0,children:n.jsx("svg",{width:"11",height:"11",viewBox:"0 0 10 10",fill:"currentColor",children:n.jsx("path",{d:"M1.5 1.5l7 3.5-7 3.5V1.5Z"})})}),n.jsx(_e,{title:"Move up",onClick:Ee,t:T,children:n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M3.47 7.78a.75.75 0 0 1 0-1.06l4.25-4.25a.75.75 0 0 1 1.06 0l4.25 4.25a.75.75 0 0 1-1.06 1.06L8.75 4.81v7.44a.75.75 0 0 1-1.5 0V4.81L4.53 7.78a.75.75 0 0 1-1.06 0Z"})})}),n.jsx(_e,{title:"Move down",onClick:Z,t:T,children:n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M12.53 8.22a.75.75 0 0 1 0 1.06l-4.25 4.25a.75.75 0 0 1-1.06 0L2.97 9.28a.75.75 0 0 1 1.06-1.06l2.72 2.97V3.75a.75.75 0 0 1 1.5 0v7.44l2.72-2.97a.75.75 0 0 1 1.06 0Z"})})}),n.jsx(_e,{title:"Delete cell",onClick:b,t:T,danger:!0,children:n.jsx("svg",{width:"12",height:"12",viewBox:"0 0 16 16",fill:"currentColor",children:n.jsx("path",{d:"M11 1.75V3h2.25a.75.75 0 0 1 0 1.5H2.75a.75.75 0 0 1 0-1.5H5V1.75C5 .784 5.784 0 6.75 0h2.5C10.216 0 11 .784 11 1.75ZM4.496 6.675l.66 6.6a.25.25 0 0 0 .249.225h5.19a.25.25 0 0 0 .249-.225l.66-6.6a.75.75 0 0 1 1.492.149l-.66 6.6A1.748 1.748 0 0 1 10.595 15h-5.19a1.75 1.75 0 0 1-1.741-1.575l-.66-6.6a.75.75 0 1 1 1.492-.15ZM6.5 1.75V3h3V1.75a.25.25 0 0 0-.25-.25h-2.5a.25.25 0 0 0-.25.25Z"})})})]})]}),E.type==="markdown"?n.jsx(As,{value:E.content,onChange:m,themeMode:t.themeMode}):on(E)?n.jsx(hi,{cell:E,onChange:m,t:T}):n.jsx(Qt,{value:E.content,onChange:m,onRun:p,themeMode:t.themeMode,schema:f}),Re&&n.jsxs("div",{style:{borderTop:`1px solid ${T.cellBorder}`},children:[n.jsxs("div",{style:{height:28,display:"flex",alignItems:"center",padding:"0 12px",gap:10,borderBottom:E.result&&O?`1px solid ${T.cellBorder}`:"none",background:`${T.tableHeaderBg}60`},children:[E.result&&n.jsxs("span",{style:{fontSize:11,fontFamily:T.font,color:T.textMuted},children:[(E.result.rowCount??E.result.rows.length).toLocaleString()," rows",E.result.executionTime!==void 0&&n.jsxs(n.Fragment,{children:[" · ",E.result.executionTime<1e3?`${E.result.executionTime}ms`:`${(E.result.executionTime/1e3).toFixed(2)}s`]})]}),E.error&&n.jsx("span",{style:{fontSize:11,fontFamily:T.font,color:T.error},children:"Error"}),n.jsx("div",{style:{flex:1}}),E.result&&x&&O&&n.jsx("div",{style:{display:"flex",alignItems:"center",gap:3},children:["chart","table"].map(M=>n.jsx("button",{onClick:()=>d(M),style:{padding:"1px 7px",fontSize:10,fontFamily:T.font,borderRadius:3,border:`1px solid ${_===M?T.accent:T.btnBorder}`,background:_===M?`${T.accent}20`:"transparent",color:_===M?T.accent:T.textMuted,cursor:"pointer",transition:"all 0.15s",textTransform:"capitalize"},children:M==="chart"?"Chart":"Table"},M))}),n.jsxs("button",{onClick:()=>c(M=>!M),style:{background:"transparent",border:"none",cursor:"pointer",color:T.textMuted,fontSize:11,fontFamily:T.font,padding:"2px 4px",display:"flex",alignItems:"center",gap:4},children:[n.jsx("svg",{width:"10",height:"10",viewBox:"0 0 10 10",fill:"currentColor",style:{transform:O?"rotate(0deg)":"rotate(-90deg)",transition:"transform 0.15s"},children:n.jsx("path",{d:"M1 3l4 4 4-4",stroke:"currentColor",fill:"none",strokeWidth:"1.5"})}),O?"Hide":"Show"]})]}),O&&n.jsxs(n.Fragment,{children:[E.error&&n.jsx(Us,{message:E.error,themeMode:t.themeMode,onFix:D?Y:void 0,schemaTables:t.schemaTables}),E.result&&!E.error&&(_==="chart"&&x?n.jsx(us,{result:E.result,themeMode:t.themeMode,chartConfig:E.chartConfig}):n.jsx(Zt,{result:E.result,themeMode:t.themeMode}))]})]})]})]})}function hi({cell:E,onChange:e,t}){const r=UE(E),T=r.path,s=r.params,[R,A]=l.useState(!1),[a,o]=l.useState(E.content);if(R)return n.jsx("div",{style:{padding:"8px 12px"},children:n.jsx("input",{autoFocus:!0,value:a,onChange:i=>o(i.target.value),onBlur:()=>{e(a),A(!1)},onKeyDown:i=>{i.key==="Enter"&&(e(a),A(!1)),i.key==="Escape"&&A(!1)},style:{width:"100%",background:t.editorBg,border:`1px solid ${t.cellBorderActive}`,borderRadius:4,color:t.textSecondary,fontSize:12,fontFamily:t.fontMono,padding:"4px 8px",outline:"none"}})});const S=T.split("/").pop()??T;return n.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8,padding:"8px 12px",cursor:"default"},children:[n.jsx("svg",{width:"14",height:"14",viewBox:"0 0 16 16",fill:t.accent,style:{flexShrink:0},children:n.jsx("path",{d:"M2 1.75C2 .784 2.784 0 3.75 0h6.586c.464 0 .909.184 1.237.513l2.914 2.914c.329.328.513.773.513 1.237v9.586A1.75 1.75 0 0 1 13.25 16h-9.5A1.75 1.75 0 0 1 2 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h9.5a.25.25 0 0 0 .25-.25V6h-2.75A1.75 1.75 0 0 1 9 4.25V1.5Zm6.75.062V4.25c0 .138.112.25.25.25h2.688Z"})}),n.jsx("span",{style:{fontFamily:t.fontMono,fontSize:12,color:t.accent,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},title:T,children:S}),T!==S&&n.jsxs("span",{style:{fontSize:11,color:t.textMuted,fontFamily:t.font},children:["· ",T]}),Object.keys(s).length>0&&n.jsx("span",{style:{display:"flex",gap:4,flexWrap:"wrap",marginLeft:4},children:Object.entries(s).map(([i,I])=>n.jsxs("span",{style:{fontSize:10,fontFamily:t.fontMono,background:`${t.accent}18`,color:t.accent,border:`1px solid ${t.accent}30`,borderRadius:3,padding:"0 5px"},children:[i,'="',I,'"']},i))}),n.jsx("button",{onClick:()=>{o(E.content),A(!0)},title:"Edit block path",style:{background:"transparent",border:"none",cursor:"pointer",color:t.textMuted,padding:"2px 4px",fontSize:11,fontFamily:t.font,marginLeft:"auto"},children:"edit"})]})}function _e({title:E,onClick:e,children:t,t:r,accent:T,danger:s}){const[R,A]=l.useState(!1);return n.jsx("button",{title:E,onClick:e,onMouseEnter:()=>A(!0),onMouseLeave:()=>A(!1),style:{width:24,height:24,display:"flex",alignItems:"center",justifyContent:"center",background:R?s?`${r.error}18`:T?`${r.accent}18`:r.btnHover:"transparent",border:"none",borderRadius:4,cursor:"pointer",color:R?s?r.error:T?r.accent:r.textSecondary:r.textMuted,transition:"all 0.15s",padding:0},children:t})}const fi=[{type:"sql",label:"SQL",color:"#388bfd"},{type:"markdown",label:"Markdown",color:"#56d364"},{type:"dql",label:"DQL",color:"#e3b341"},{type:"param",label:"Param",color:"#e3b341"}];function cE({afterId:E}){const{state:e,dispatch:t}=y(),r=G[e.themeMode],[T,s]=l.useState(!1),[R,A]=l.useState(!1),a=l.useRef(null);l.useEffect(()=>{if(!R)return;function S(i){a.current&&!a.current.contains(i.target)&&A(!1)}return document.addEventListener("mousedown",S),()=>document.removeEventListener("mousedown",S)},[R]);const o=S=>{const i=j(S);t({type:"ADD_CELL",cell:i,afterId:E}),A(!1)};return n.jsxs("div",{ref:a,onMouseEnter:()=>s(!0),onMouseLeave:()=>{s(!1)},style:{position:"relative",height:28,display:"flex",alignItems:"center",justifyContent:"center",cursor:"default"},children:[n.jsx("div",{style:{position:"absolute",left:0,right:0,height:1,background:T||R?r.cellBorderActive:"transparent",transition:"background 0.15s"}}),(T||R)&&n.jsxs("button",{onClick:()=>A(S=>!S),style:{position:"relative",zIndex:2,height:22,padding:"0 10px",borderRadius:11,border:`1px solid ${r.cellBorderActive}`,background:`${r.accent}18`,color:r.accent,cursor:"pointer",fontSize:12,fontFamily:r.font,fontWeight:500,display:"flex",alignItems:"center",gap:4,transition:"background 0.15s"},children:[n.jsx("span",{style:{fontSize:14,lineHeight:1,marginTop:-1},children:"+"}),"Add cell"]}),R&&n.jsx("div",{style:{position:"absolute",top:26,left:"50%",transform:"translateX(-50%)",zIndex:100,background:r.modalBg,border:`1px solid ${r.cellBorder}`,borderRadius:8,boxShadow:"0 8px 24px rgba(0,0,0,0.3)",padding:4,display:"flex",gap:4},children:fi.map(({type:S,label:i,color:I})=>n.jsx(mi,{label:i,color:I,onClick:()=>o(S),t:r},S))})]})}function mi({label:E,color:e,onClick:t,t:r}){const[T,s]=l.useState(!1);return n.jsx("button",{onClick:t,onMouseEnter:()=>s(!0),onMouseLeave:()=>s(!1),style:{background:T?`${e}18`:"transparent",border:`1px solid ${T?e:r.cellBorder}`,borderRadius:6,cursor:"pointer",color:T?e:r.textSecondary,fontSize:11,fontFamily:r.fontMono,fontWeight:600,padding:"4px 10px",letterSpacing:"0.04em",transition:"all 0.15s",whiteSpace:"nowrap"},children:E})}function xi({registerCellRef:E}){const{state:e,dispatch:t}=y(),{executeCell:r}=hE(),T=G[e.themeMode],[s,R]=l.useState(null),A=l.useRef(0);return l.useCallback(a=>{R(a)},[]),l.useEffect(()=>{function a(o){var O;if(!s)return;const S=o.target;if(S.tagName==="TEXTAREA"||S.tagName==="INPUT"||S.isContentEditable||S.closest(".cm-editor")){R(null);return}const i=e.cells,I=i.findIndex(c=>c.id===s);if(I!==-1)switch(o.key){case"a":{o.preventDefault();const c=j("sql");if(I===0)t({type:"ADD_CELL",cell:c,afterId:i[0].id}),t({type:"MOVE_CELL",id:c.id,direction:"up"});else{const _=i[I-1].id;t({type:"ADD_CELL",cell:c,afterId:_})}R(c.id);break}case"b":{o.preventDefault();const c=j("sql");t({type:"ADD_CELL",cell:c,afterId:s}),R(c.id);break}case"d":{o.preventDefault();const c=Date.now();if(c-A.current<=500){if(t({type:"DELETE_CELL",id:s}),i.length>1){const _=I>0?I-1:1;R(((O=i[_])==null?void 0:O.id)??null)}else R(null);A.current=0}else A.current=c;break}case"Enter":{if(o.shiftKey){o.preventDefault();const c=i[I];c&&c.type!=="markdown"&&r(c.id)}break}}}return document.addEventListener("keydown",a),()=>document.removeEventListener("keydown",a)},[s,e.cells,t,r]),l.useEffect(()=>{function a(o){o.target.closest("[data-cell-id]")||R(null)}return document.addEventListener("mousedown",a),()=>document.removeEventListener("mousedown",a)},[]),e.cells.length===0?n.jsxs("div",{style:{maxWidth:1200,margin:"0 auto",padding:"0 24px",display:"flex",flexDirection:"column"},children:[n.jsx(cE,{}),n.jsx(Gi,{t:T})]}):n.jsxs("div",{style:{maxWidth:1200,margin:"0 auto",padding:"0 24px",display:"flex",flexDirection:"column"},children:[n.jsx(cE,{afterId:void 0}),e.cells.map((a,o)=>n.jsxs(Be.Fragment,{children:[n.jsx("div",{ref:S=>E(a.id,S),"data-cell-id":a.id,onClick:S=>{const i=S.target;!i.closest(".cm-editor")&&!i.closest("textarea")&&!i.closest("input")&&R(a.id)},style:{outline:s===a.id?`2px solid ${T.accent}40`:"none",outlineOffset:2,borderRadius:10,transition:"outline 0.1s"},children:n.jsx(Ui,{cell:a,index:o})}),n.jsx(cE,{afterId:a.id})]},a.id))]})}function Gi({t:E}){return n.jsxs("div",{style:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",padding:"48px 0",gap:12,color:E.textMuted},children:[n.jsx("svg",{width:"40",height:"40",viewBox:"0 0 16 16",fill:"currentColor",style:{opacity:.3},children:n.jsx("path",{d:"M2 1.75C2 .784 2.784 0 3.75 0h6.586c.464 0 .909.184 1.237.513l2.914 2.914c.329.328.513.773.513 1.237v9.586A1.75 1.75 0 0 1 13.25 16h-9.5A1.75 1.75 0 0 1 2 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h9.5a.25.25 0 0 0 .25-.25V6h-2.75A1.75 1.75 0 0 1 8.75 4.25V1.5ZM8.75 5.5h2.836L10.25 3.664V4.25c0 .138.112.25.25.25H8.75Z"})}),n.jsx("span",{style:{fontSize:13,fontFamily:E.font},children:"Empty notebook. Click + to add your first cell."})]})}function yi({onOpenFile:E,registerCellRef:e}){const{state:t}=y(),r=G[t.themeMode];return t.activeFile?n.jsxs("div",{style:{flex:1,display:"flex",flexDirection:"column",overflow:"hidden",background:r.appBg},children:[n.jsx(Bi,{t:r}),n.jsx("div",{style:{flex:1,overflow:"auto",padding:"24px 0 40px"},children:n.jsx(xi,{registerCellRef:e})})]}):n.jsx(Gn,{onOpenFile:E})}function Bi({t:E}){const{state:e}=y(),t=e.cells.length;return n.jsxs("div",{style:{height:32,flexShrink:0,borderBottom:`1px solid ${E.headerBorder}`,background:E.cellBg,display:"flex",alignItems:"center",padding:"0 16px",gap:12},children:[n.jsx(gi,{t:E}),n.jsx("div",{style:{flex:1}}),n.jsxs("span",{style:{fontSize:11,color:E.textMuted,fontFamily:E.font,display:"flex",alignItems:"center",gap:12},children:[n.jsxs("span",{children:[t," ",t===1?"cell":"cells"]}),e.notebookDirty&&n.jsx("span",{style:{color:E.warning},children:"● unsaved"})]})]})}function gi({t:E}){const{state:e}=y();if(!e.activeFile)return null;const t=e.activeFile.path.split("/").filter(Boolean);return n.jsx("div",{style:{display:"flex",alignItems:"center",gap:4,fontSize:12,fontFamily:E.fontMono,color:E.textMuted,overflow:"hidden"},children:t.map((r,T)=>n.jsxs(Be.Fragment,{children:[T>0&&n.jsx("span",{style:{color:E.textMuted,opacity:.5},children:"/"}),n.jsx("span",{style:{color:T===t.length-1?E.textSecondary:E.textMuted,fontWeight:T===t.length-1?500:400,whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis",maxWidth:T===t.length-1?200:100},children:r})]},T))})}const mt={blank:"Blank",revenue:"Revenue Analysis",pipeline:"Pipeline Health"},Hi={blank:"Start with an empty notebook.",revenue:"Pre-built queries for revenue metrics and trends.",pipeline:"Templates for data pipeline health monitoring."};function xt(E){return E.toLowerCase().replace(/[^a-z0-9\-_\s]/g,"").replace(/\s+/g,"-").replace(/-+/g,"-").slice(0,64)}function Fi(E){return E.trim()?/^[a-zA-Z0-9\-_ ]+$/.test(E)?null:"Only letters, numbers, hyphens, underscores, and spaces allowed.":"Name is required."}function bi(E){switch(E){case"revenue":return[j("markdown",`# Revenue Analysis
|
|
430
|
+
|
|
431
|
+
This notebook analyzes revenue metrics and trends over time.`),{...j("sql",`SELECT
|
|
432
|
+
DATE_TRUNC('month', order_date) AS month,
|
|
433
|
+
SUM(amount) AS revenue
|
|
434
|
+
FROM orders
|
|
435
|
+
GROUP BY 1
|
|
436
|
+
ORDER BY 1`),name:"monthly_revenue"},{...j("sql",`SELECT
|
|
437
|
+
product_category,
|
|
438
|
+
SUM(amount) AS total_revenue,
|
|
439
|
+
COUNT(*) AS orders
|
|
440
|
+
FROM orders
|
|
441
|
+
GROUP BY 1
|
|
442
|
+
ORDER BY 2 DESC`),name:"revenue_by_category"}];case"pipeline":return[j("markdown",`# Pipeline Health
|
|
443
|
+
|
|
444
|
+
Monitor data pipeline performance, SLA compliance, and error rates.`),{...j("sql",`SELECT
|
|
445
|
+
pipeline_name,
|
|
446
|
+
COUNT(*) AS runs,
|
|
447
|
+
AVG(duration_seconds) AS avg_duration,
|
|
448
|
+
SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) AS failures
|
|
449
|
+
FROM pipeline_runs
|
|
450
|
+
GROUP BY 1
|
|
451
|
+
ORDER BY 4 DESC`),name:"pipeline_summary"},{...j("sql",`SELECT
|
|
452
|
+
*
|
|
453
|
+
FROM pipeline_runs
|
|
454
|
+
WHERE status = 'failed'
|
|
455
|
+
AND run_date >= CURRENT_DATE - INTERVAL '7 days'
|
|
456
|
+
ORDER BY run_date DESC`),name:"recent_failures"}];default:return[j("sql")]}}function Yi({onFileOpened:E}){const{state:e,dispatch:t}=y(),r=G[e.themeMode],[T,s]=l.useState(""),[R,A]=l.useState("blank"),[a,o]=l.useState(null),[S,i]=l.useState(!1),I=l.useRef(null);l.useEffect(()=>{var _;(_=I.current)==null||_.focus()},[]),l.useEffect(()=>{const _=d=>{d.key==="Escape"&&t({type:"CLOSE_NEW_NOTEBOOK_MODAL"})};return document.addEventListener("keydown",_),()=>document.removeEventListener("keydown",_)},[t]);const O=async()=>{const _=Fi(T);if(_){o(_);return}i(!0),o(null);const d=xt(T),u=bi(R);try{const D=await V.createNotebook(d,R),f={name:`${d}.dqlnb`,path:D.path,type:"notebook",folder:"notebooks",isNew:!0};t({type:"FILE_ADDED",file:f}),t({type:"OPEN_FILE",file:f,cells:u,title:T.trim()}),t({type:"CLOSE_NEW_NOTEBOOK_MODAL"}),E(f)}catch{const D=`notebooks/${d}.dqlnb`,f={name:`${d}.dqlnb`,path:D,type:"notebook",folder:"notebooks",isNew:!0};t({type:"FILE_ADDED",file:f}),t({type:"OPEN_FILE",file:f,cells:u,title:T.trim()}),t({type:"CLOSE_NEW_NOTEBOOK_MODAL"}),E(f)}finally{i(!1)}},c=_=>{_.target===_.currentTarget&&t({type:"CLOSE_NEW_NOTEBOOK_MODAL"})};return n.jsx("div",{onClick:c,style:{position:"fixed",inset:0,background:r.modalOverlay,display:"flex",alignItems:"center",justifyContent:"center",zIndex:1e3,backdropFilter:"blur(4px)"},children:n.jsxs("div",{style:{background:r.modalBg,border:`1px solid ${r.cellBorder}`,borderRadius:12,width:480,maxWidth:"calc(100vw - 48px)",boxShadow:"0 20px 60px rgba(0,0,0,0.5)",overflow:"hidden"},children:[n.jsxs("div",{style:{padding:"20px 24px 0",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[n.jsx("h2",{style:{fontSize:16,fontWeight:600,color:r.textPrimary,fontFamily:r.font,margin:0},children:"New Notebook"}),n.jsx("button",{onClick:()=>t({type:"CLOSE_NEW_NOTEBOOK_MODAL"}),style:{background:"transparent",border:"none",cursor:"pointer",color:r.textMuted,fontSize:18,lineHeight:1,padding:"2px 4px",borderRadius:4},children:"×"})]}),n.jsxs("div",{style:{padding:"20px 24px 24px",display:"flex",flexDirection:"column",gap:20},children:[n.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:6},children:[n.jsx("label",{style:{fontSize:12,fontWeight:500,color:r.textSecondary,fontFamily:r.font},children:"Name"}),n.jsx("input",{ref:I,value:T,onChange:_=>{s(_.target.value),o(null)},onKeyDown:_=>{_.key==="Enter"&&O()},placeholder:"my-analysis",style:{background:r.inputBg,border:`1px solid ${a?r.error:r.inputBorder}`,borderRadius:6,color:r.textPrimary,fontSize:13,fontFamily:r.font,padding:"8px 12px",outline:"none",transition:"border-color 0.15s"}}),a&&n.jsx("span",{style:{fontSize:11,color:r.error,fontFamily:r.font},children:a}),T&&!a&&n.jsxs("span",{style:{fontSize:11,color:r.textMuted,fontFamily:r.fontMono},children:["File: ",xt(T),".dqlnb"]})]}),n.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:6},children:[n.jsx("label",{style:{fontSize:12,fontWeight:500,color:r.textSecondary,fontFamily:r.font},children:"Template"}),n.jsx("div",{style:{display:"flex",flexDirection:"column",gap:8},children:Object.keys(mt).map(_=>n.jsx(vi,{value:_,selected:R===_,onSelect:()=>A(_),label:mt[_],description:Hi[_],t:r},_))})]})]}),n.jsxs("div",{style:{padding:"14px 24px",borderTop:`1px solid ${r.cellBorder}`,display:"flex",justifyContent:"flex-end",gap:10},children:[n.jsx("button",{onClick:()=>t({type:"CLOSE_NEW_NOTEBOOK_MODAL"}),style:{background:r.btnBg,border:`1px solid ${r.btnBorder}`,borderRadius:6,color:r.textSecondary,cursor:"pointer",fontSize:13,fontFamily:r.font,fontWeight:500,padding:"7px 16px"},children:"Cancel"}),n.jsx("button",{onClick:O,disabled:S||!T.trim(),style:{background:r.accent,border:`1px solid ${r.accent}`,borderRadius:6,color:"#ffffff",cursor:S||!T.trim()?"not-allowed":"pointer",fontSize:13,fontFamily:r.font,fontWeight:500,padding:"7px 20px",opacity:S||!T.trim()?.6:1,display:"flex",alignItems:"center",gap:6},children:S?"Creating…":"Create Notebook"})]})]})})}function vi({value:E,selected:e,onSelect:t,label:r,description:T,t:s}){const[R,A]=l.useState(!1);return n.jsxs("div",{onClick:t,onMouseEnter:()=>A(!0),onMouseLeave:()=>A(!1),style:{display:"flex",alignItems:"flex-start",gap:10,padding:"10px 12px",borderRadius:8,border:`1px solid ${e?s.cellBorderActive:R?s.textMuted:s.inputBorder}`,background:e?`${s.cellBorderActive}10`:R?s.sidebarItemHover:"transparent",cursor:"pointer",transition:"all 0.15s"},children:[n.jsx("div",{style:{width:16,height:16,borderRadius:8,border:`2px solid ${e?s.accent:s.textMuted}`,display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0,marginTop:1,transition:"border-color 0.15s"},children:e&&n.jsx("div",{style:{width:8,height:8,borderRadius:4,background:s.accent}})}),n.jsxs("div",{children:[n.jsx("div",{style:{fontSize:13,fontWeight:500,color:s.textPrimary,fontFamily:s.font,marginBottom:2},children:r}),n.jsx("div",{style:{fontSize:12,color:s.textSecondary,fontFamily:s.font},children:T})]})]})}function Vi(){const{state:E,dispatch:e}=y(),t=G[E.themeMode],r=l.useRef({}),T=l.useCallback(async A=>{try{const{content:a}=await V.readNotebook(A.path),{title:o,cells:S}=nn(A.path,a);e({type:"OPEN_FILE",file:A,cells:S,title:o}),E.sidebarPanel!=="files"&&e({type:"SET_SIDEBAR_PANEL",panel:"files"})}catch(a){console.error("Failed to open file:",a),e({type:"OPEN_FILE",file:A,cells:[j("sql")],title:A.name})}},[e,E.sidebarPanel]),s=l.useCallback(A=>{const a=r.current[A];a&&a.scrollIntoView({behavior:"smooth",block:"start"})},[]),R=l.useCallback((A,a)=>{a?r.current[A]=a:delete r.current[A]},[]);return n.jsxs("div",{style:{display:"flex",flexDirection:"column",height:"100vh",width:"100vw",background:t.appBg,fontFamily:t.font,color:t.textPrimary,overflow:"hidden"},children:[n.jsx(Mn,{}),n.jsxs("div",{style:{flex:1,display:"flex",overflow:"hidden"},children:[n.jsx(ir,{}),E.sidebarOpen&&n.jsx(En,{onOpenFile:T,onNavigateToCell:s}),n.jsxs("div",{style:{flex:1,display:"flex",flexDirection:"column",overflow:"hidden",minWidth:0},children:[n.jsx(yi,{onOpenFile:T,registerCellRef:R}),n.jsx(mn,{})]})]}),E.newNotebookModalOpen&&n.jsx(Yi,{onFileOpened:T})]})}function Wi(){const{state:E,dispatch:e}=y(),t=l.useRef(null),r=l.useRef(null);l.useEffect(()=>{var T;t.current=((T=E.activeFile)==null?void 0:T.path)??null},[E.activeFile]),l.useEffect(()=>{if(typeof EventSource>"u")return;const T=()=>{const s=new EventSource(`${window.location.origin}/api/watch`);r.current=s,s.addEventListener("change",R=>{try{const A=JSON.parse(R.data);(A.type==="file-added"||A.type==="file-deleted")&&V.listNotebooks().then(a=>{e({type:"SET_FILES",files:a})}),A.type==="file-changed"&&V.listNotebooks().then(a=>{e({type:"SET_FILES",files:a})})}catch{}}),s.addEventListener("error",()=>{s.close(),setTimeout(T,5e3)})};return T(),()=>{var s;(s=r.current)==null||s.close(),r.current=null}},[e])}function Xi(){const{state:E,dispatch:e}=y(),t=G[E.themeMode];return l.useEffect(()=>{const r="dql-global-styles";let T=document.getElementById(r);T||(T=document.createElement("style"),T.id=r,document.head.appendChild(T)),T.textContent=`
|
|
457
|
+
* { margin: 0; padding: 0; box-sizing: border-box; }
|
|
458
|
+
body {
|
|
459
|
+
font-family: ${t.font};
|
|
460
|
+
overflow: hidden;
|
|
461
|
+
background: ${t.appBg};
|
|
462
|
+
color: ${t.textPrimary};
|
|
463
|
+
}
|
|
464
|
+
::-webkit-scrollbar { width: 6px; height: 6px; }
|
|
465
|
+
::-webkit-scrollbar-track { background: transparent; }
|
|
466
|
+
::-webkit-scrollbar-thumb {
|
|
467
|
+
background: ${t.scrollbarThumb};
|
|
468
|
+
border-radius: 3px;
|
|
469
|
+
}
|
|
470
|
+
::-webkit-scrollbar-thumb:hover {
|
|
471
|
+
background: ${t.textMuted};
|
|
472
|
+
}
|
|
473
|
+
::selection {
|
|
474
|
+
background: ${t.accent}40;
|
|
475
|
+
color: ${t.textPrimary};
|
|
476
|
+
}
|
|
477
|
+
`},[t]),l.useEffect(()=>{e({type:"SET_FILES_LOADING",loading:!0}),V.listNotebooks().then(r=>{e({type:"SET_FILES",files:r}),e({type:"SET_FILES_LOADING",loading:!1})})},[e]),l.useEffect(()=>{e({type:"SET_SCHEMA_LOADING",loading:!0}),V.getSchema().then(r=>{e({type:"SET_SCHEMA",tables:r}),e({type:"SET_SCHEMA_LOADING",loading:!1})})},[e]),Wi(),n.jsx(Vi,{})}function wi(){return n.jsx(er,{children:n.jsx(Xi,{})})}ZT.createRoot(document.getElementById("root")).render(n.jsx(wi,{}));
|