@bygd/nc-report-ui 0.1.26 → 0.1.28
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/default/cjs/index.cjs +1 -1
- package/dist/default/esm/index.js +349 -90
- package/package.json +4 -3
- package/dist/default/iife/index.js +0 -257
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("@material-ui/core/Paper"),a=require("@material-ui/core/styles"),r=require("@material-ui/core"),n=require("react-google-charts"),l=require("numeral"),o=require("axios"),i=require("@material-ui/core/Typography"),s=require("nunjucks"),d=require("@material-ui/core/FormControl"),c=require("@material-ui/core/Select"),u=require("@material-ui/core/MenuItem"),f=require("react-intersection-observer"),m=require("@mui/material"),p=require("@mui/icons-material/CheckBoxOutlineBlank"),g=require("@mui/icons-material/CheckBox"),h=require("@mui/material/Box"),y=require("@mui/material/MenuItem"),x=require("@mui/material/FormControl"),b=require("@mui/material/Select"),E=require("eventemitter3"),v=require("@material-ui/core/Grid"),w=require("@material-ui/core/Container"),S=require("@mui/x-data-grid"),C=require("@mui/icons-material/Add"),k=require("@mui/icons-material/Edit"),T=require("@mui/icons-material/ContentCopy"),R=require("@mui/icons-material/Delete"),D=require("@mui/icons-material/PlayArrow"),B=require("@mui/icons-material/ArrowBack"),z=require("@mui/icons-material/Save"),P=require("@mui/icons-material/Download"),F=require("@dnd-kit/core"),M=require("@dnd-kit/sortable"),q=require("@dnd-kit/utilities"),I=require("@mui/icons-material/DragIndicator"),$=require("@mui/icons-material/ArrowUpward"),j=require("@mui/icons-material/ArrowDownward"),O=require("@mui/icons-material/Sort"),A=require("@mui/icons-material/Check"),_=require("@mui/icons-material/Close"),W=require("@mui/icons-material/RestartAlt"),N=require("@mui/icons-material/PlaylistAdd"),K=require("@mui/icons-material/FilterAlt"),U=require("@mui/x-date-pickers/LocalizationProvider"),L=require("@mui/x-date-pickers/DatePicker"),Y=require("@mui/x-date-pickers/AdapterDayjs"),G=require("dayjs"),H=require("@mui/material/styles");function V(e){return e&&e.__esModule?e:{default:e}}function Z(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach(function(a){if("default"!==a){var r=Object.getOwnPropertyDescriptor(e,a);Object.defineProperty(t,a,r.get?r:{enumerable:!0,get:function(){return e[a]}})}}),t.default=e,Object.freeze(t)}var J=Z(e),Q=V(t),X=V(l),ee=V(o),te=V(i),ae=V(s),re=V(d),ne=V(c),le=V(u),oe=V(p),ie=V(g),se=V(h),de=V(y),ce=V(x),ue=V(b),fe=V(E),me=V(v),pe=V(w),ge=V(C),he=V(k),ye=V(T),xe=V(R),be=V(D),Ee=V(B),ve=V(z),we=V(P),Se=V(I),Ce=V($),ke=V(j),Te=V(O),Re=V(A),De=V(_),Be=V(W),ze=V(N),Pe=V(K),Fe=V(G);function Me(){return Me=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var a=arguments[t];for(var r in a)({}).hasOwnProperty.call(a,r)&&(e[r]=a[r])}return e},Me.apply(null,arguments)}const qe=a.makeStyles(e=>({root:{width:"100%","& > * + *":{marginTop:e.spacing(2)}}}));function Ie(e){const t=qe();return J.default.createElement("div",Me({className:t.root},e),J.default.createElement(r.CircularProgress,{style:{color:"rgb(70, 134, 128)"},size:25}))}function $e(e,t,a="array"){const r=e.columns,n=[...t.doc.metrics,...t.doc.dimensions].reduce((e,t)=>(e[t.name]=t,e),{});return e=>{const t="array"===a?[]:{};return r.reduce((t,r)=>{const l=e[r.name],o=n[r.name];let i=l;return i="timestamp"===o.type?new Date(l):o.format?o.format&&o.prefix?{v:+l,f:o.prefix+" "+X.default(l).format(o.format)}:o.format?{v:+l,f:X.default(l).format(o.format)}:l:l,"array"===a?t.push(i):t[r.name]=i?.f||i,t},t)}}const je="https://report-api.netcapital.pro",Oe=ee.default.create({baseURL:je,headers:{"Content-Type":"application/json"}}),Ae={},_e=()=>{const e=Object.keys(Ae);return e.length>0?e[0]:null},We={setBaseUrl(e){Oe.defaults.baseURL=e||je},setToken(e){e&&(Oe.defaults.headers.common.Authorization=`Bearer ${e}`)},loadDashboardMeta:async({dashboardId:e})=>{const{data:t}=await Oe.get(`/dashboard-meta/${e}`);return Ae[e]={dashboards:t.dashboards||{},charts:t.charts||{},reports:t.reports||{},reportMetadata:t.reportMetadata||{},dateRanges:t.dateRanges||[]},Ae[e]},getDashboard:async({id:e,dashboardId:t})=>{const a=t||_e();if(a&&Ae[a]?.dashboards?.[e])return Ae[a].dashboards[e];const{data:r}=await Oe.get(`/entity/dashboards/${e}`);return r},getChart:async({id:e,dashboardId:t})=>{const a=t||_e();if(a&&Ae[a]?.charts?.[e])return Ae[a].charts[e];const{data:r}=await Oe.get(`/entity/charts/${e}`);return r},getReport:async({id:e,dashboardId:t})=>{const a=t||_e();if(a&&Ae[a]?.reports?.[e])return Ae[a].reports[e];const{data:r}=await Oe.get(`/entity/reports/${e}`);return r},getProviders:async()=>{const{data:e}=await Oe.get("/entity/providers");return e},getReportSchema:async({id:e,dashboardId:t,query:a={}})=>{const r=t||_e();if(r&&Ae[r]?.reportMetadata?.[e])return Ae[r].reportMetadata[e];const{data:n}=await Oe.post(`/reports/${e}/metadata`,a);return n},runReport:async({id:e,query:t={}})=>{const{data:a}=await Oe.post(`/reports/${e}/run`,t);return a},runAdHocReport:async({report:e})=>{const{data:t}=await Oe.post("/report-build/run",e);return t},downloadAdHocReport:async({report:e,filename:t})=>{const a=await Oe.post("/report-build/run?download=csv",e,{responseType:"blob"}),r=window.URL.createObjectURL(new Blob([a.data])),n=document.createElement("a");n.href=r;let l=t||"report.csv";if(!t){const e=a.headers["content-disposition"];if(e){const t=e.match(/filename="?(.+)"?/i);t&&t[1]&&(l=t[1])}}n.setAttribute("download",l),document.body.appendChild(n),n.click(),n.remove(),window.URL.revokeObjectURL(r)},getDateRanges:async({dashboardId:e}={})=>{const t=e||_e();if(t&&Ae[t]?.dateRanges)return Ae[t].dateRanges;const{data:a}=await Oe.get("/globals/date-ranges");return a},getReportDefinitions:async()=>{const{data:e}=await Oe.get("/report-definitions");return e},getReportDefinition:async({id:e})=>{const{data:t}=await Oe.get(`/report-definitions/${e}`);return t},createReportDefinition:async({reportDefinition:e})=>{const{data:t}=await Oe.post("/report-definitions",e);return t},updateReportDefinition:async({id:e,reportDefinition:t})=>{const{data:a}=await Oe.put(`/report-definitions/${e}`,t);return a},deleteReportDefinition:async({id:e})=>{const{data:t}=await Oe.delete(`/report-definitions/${e}`);return t}},Ne=a.makeStyles(e=>({headerRow:{fontFamily:e.typography.fontFamily,fontSize:e.typography.fontSize},tableRow:{fontFamily:e.typography.fontFamily,fontSize:e.typography.fontSize},oddTableRow:{fontFamily:e.typography.fontFamily,fontSize:e.typography.fontSize},headerCell:{backgroundColor:"white",padding:"4px !important"}})),Ke={none:"YYYY-MM-dd",day:"MMM dd",week:"MMM dd",month:"YYYY MMM",year:"YYYY"};const Ue={GoogleChart:function({chart:t,source:a,view:r,report:l,schema:o,dashboard:i,query:s}){const[d,c]=J.default.useState([]),u=Ne(),[f,m]=J.default.useState([]);e.useEffect(()=>{(async()=>{const e=await We.getDateRanges();m(e)})()},[]);const p=e.useMemo(()=>{const e="YYYY-MM-dd",t=s?.date_range?.name,a=f.find(e=>e.name===t);if(!a)return e;return Ke[a?.granularity]||e},[f,s]);return J.default.useEffect(()=>{if(!(t&&r&&a&&l&&o))return;let e=[];e.push(function(e,t){const a=[...t.doc.metrics,...t.doc.dimensions];return e.columns.reduce((e,t)=>{const r=a.find(e=>e.name===t.name)||t;return e.push(r.title||r.name),e},[])}(r,o));const n=$e(r,o);a?.forEach(t=>{const a=n(t);e.push(a)}),a?.length?c(e):c()},[t,a,r,l,o]),d?J.default.createElement("div",{style:{}},J.default.createElement(n.Chart,Me({width:t?.doc.size?.width||"100%",chartType:t?.doc.chart?.type,data:d,options:(e=>{const a=["#468682","#ff686b","#6c757d","#FFD700","#073b4c"];if("Table"===t?.doc.chart?.type)return{...t?.doc.chart?.options,cssClassNames:u};if("AreaChart"===t?.doc.chart?.type){const r=t?.doc.chart?.options?.hAxis||{},n={...{ticks:e.slice(1).map(e=>e[0]),format:p},...r};return{...t?.doc.chart?.options,hAxis:n,focusTarget:"category",colors:a}}return{...t?.doc.chart?.options,colors:a}})(d)},t?.doc.chart?.props))):J.default.createElement("div",null)},LabelChart:function({chart:e,source:t,view:a,report:r,schema:n}){const[l,o]=J.default.useState([]),[i,s]=J.default.useState(),[d,c]=J.default.useState();return J.default.useEffect(()=>{if(!(e&&a&&t&&r&&n))return;let l=[];const i=$e(a,n);t.forEach(e=>l.push(i(e))),o(l);const d=e?.doc?.chart?.options||{},u=d?.index||0;if(l.length>0&&s(l[0][u]),d.subText?.format){ae.default.configure({autoescape:!1});const e=$e(a,n,"object")(t[0]),r=ae.default.renderString(d.subText?.format,e);c(r)}},[e,t,a,r,n]),J.default.createElement("div",{style:{display:"flex",justifyContent:"center",alignContent:"center",height:"100%",flexDirection:"column"}},J.default.createElement(te.default,{variant:"h6"},i?.f||i),J.default.createElement(te.default,{variant:"caption"},d))}};function Le(e,t){return void 0!==Ue[e]?J.default.createElement(Ue[e],t):J.default.createElement(Ie,t)}const Ye=J.createElement(oe.default,{fontSize:"small"}),Ge=J.createElement(ie.default,{fontSize:"small"});function He({items:t,selectedKeys:a,defaultSelectedKeys:r,onChange:n,inputValue:l,defaultInputValue:o,onInputChange:i,debounceMs:s=300,label:d,placeholder:c,loading:u,disabled:f,size:p="small",error:g,helperText:h,limitTags:y=3,disableClearable:x,id:b,textFieldProps:E}){const v=e.useMemo(()=>Array.isArray(t)?t:[],[t]),w=Array.isArray(a),[S,C]=e.useState(Array.isArray(r)?r:[]),k=w?a:S,T=e.useMemo(()=>{const e=new Map;for(const t of v)e.set(t&&t.key,t);return e},[v]),R=e.useMemo(()=>(Array.isArray(k)?k:[]).map(e=>T.get(e)).filter(Boolean),[k,T]),D="string"==typeof l,[B,z]=e.useState("string"==typeof o?o:""),P=D?l:B,F=function(t,a=300){const r=e.useRef(t),n=e.useRef(null);return r.current=t,e.useEffect(()=>()=>{n.current&&window.clearTimeout(n.current)},[]),J.useCallback((...e)=>{r.current&&(n.current&&window.clearTimeout(n.current),n.current=window.setTimeout(()=>{r.current&&r.current(...e)},a))},[a])}(e=>{i&&i(e)},s),M=R;return J.createElement(m.FormControl,{fullWidth:!0,error:g,disabled:f},J.createElement(m.Autocomplete,{openOnFocus:!0,forcePopupIcon:!0,id:b,multiple:!0,disableCloseOnSelect:!0,options:v,value:M,inputValue:P,getOptionLabel:e=>e&&"object"==typeof e?e.value??"":"",isOptionEqualToValue:(e,t)=>e&&t&&e.key===t.key,loading:u,limitTags:y,disableClearable:x,onChange:(e,t)=>{const a=Array.isArray(t)?t.map(e=>e&&e.key):[];w||C(a),n&&n(a,Array.isArray(t)?t:[])},onInputChange:(e,t,a)=>{D||z(t??""),"input"===a?F(t??""):"clear"===a&&F("")},renderOption:(e,t,{selected:a})=>J.createElement("li",Me({},e,{key:t&&t.key||Math.random().toString(36)}),J.createElement(m.Checkbox,{icon:Ye,checkedIcon:Ge,style:{marginRight:8},checked:!!a}),t&&t.value),renderTags:(e,t)=>(Array.isArray(e)?e:[]).map((e,a)=>J.createElement(m.Chip,Me({},t({index:a}),{key:e&&e.key||a,label:e&&e.value||""}))),renderInput:e=>J.createElement(m.TextField,Me({},e,{label:d,placeholder:c,InputProps:{...e.InputProps,endAdornment:J.createElement(J.Fragment,null,u?J.createElement(m.CircularProgress,{size:18}):null,e.InputProps.endAdornment)},size:p},E))}),h?J.createElement(m.FormHelperText,null,h):null)}const Ve=({filter:t,channel:a,query:r})=>{const[n,l]=e.useState([]),[o,i]=e.useState([]),[s,d]=e.useState(!1),[c,u]=e.useState("");return e.useEffect(()=>{i(r?.filter?.[t?.filter]||[])},[r]),e.useEffect(()=>{(async()=>{d(!0);const e=await async function(e,t){return t?.source?(await We.runReport({id:t.source})).map(e=>({key:e[t.field],value:e[t.field]})):[]}(0,t);l(e),d(!1)})()},[c]),J.default.createElement("div",{style:{display:"flex"}},J.default.createElement("div",{style:{maxWidth:640,minWidth:200}},J.default.createElement(He,{id:t?.title,label:t?.title,placeholder:"Type to search…",items:n,selectedKeys:o,onChange:(e,r)=>{i(e),a.emit("filterChanged",t,{[t.filter]:e})},onInputChange:e=>{u(e)},loading:s,debounceMs:300,helperText:o.length?`${o.length} selected`:""})))},Ze=e=>e?.replace(/([a-z])([A-Z])/g,"$1 $2")?.replace(/_/g," ")?.replace(/-/g," ").replace(/\b\w/g,e=>e.toUpperCase());function Je({items:e,value:t,onChange:a,sx:r={width:"100%"},disabled:n=!1,label:l}){const o=e.some(e=>e.key===t)?t:"";return J.default.createElement(se.default,{sx:r},J.default.createElement(ce.default,{fullWidth:!0,size:"small"},J.default.createElement(ue.default,{value:o,onChange:a,disabled:n,displayEmpty:!0,MenuProps:{style:{maxHeight:300}},sx:{height:"40px",borderRadius:"8px",fontFamily:"system-ui",backgroundColor:"white","& .MuiSelect-select":{display:"flex",alignItems:"center",padding:"8px 12px"},"& fieldset":{borderColor:"rgba(0,0,0,0.23)"},"&:hover fieldset":{borderColor:"rgb(70, 134, 128) !important"},"&.Mui-focused fieldset":{borderColor:"rgb(70, 134, 128) !important"}}},J.default.createElement(de.default,{value:"",disabled:!0,sx:{color:"rgba(37, 37, 37, 0.58)"}},Ze(l)),e.map(e=>{const{key:t,value:a,disabled:r}=e;return J.default.createElement(de.default,{key:t,value:t,disabled:r,sx:{fontFamily:"system-ui",minHeight:"36px"}},Ze(a))}))))}const Qe=({filter:t,channel:a,query:r})=>{const[n,l]=e.useState([]),[o,i]=e.useState("");return e.useEffect(()=>{i(r?.date_range?.name)},[r]),e.useEffect(()=>{(async()=>{const e=(await We.getDateRanges()).filter(e=>!(t.allowedOptions.length>0)||t.allowedOptions.some(t=>t===e.name)).map(e=>({key:e.name,value:e.title}));l(e)})()},[]),J.default.createElement("div",{style:{minWidth:"200px",maxWidth:"640px"}},J.default.createElement(Je,{items:n,value:o,label:t?.title,onChange:(e,r)=>{const n=e.target.value;i(n),a.emit("filterChanged",t,{date_range:{name:n}})}}))},Xe=({filters:e=[],channel:t,query:a})=>J.default.createElement("div",{style:{display:"flex",flexWrap:"wrap",gap:"8px"}},e.map(e=>"multi-select"===e.type?J.default.createElement(Ve,{key:e.title,channel:t,filter:e,query:a}):"date-range"===e.type?J.default.createElement(Qe,{key:e.title,channel:t,filter:e,query:a}):null));var et=e=>J.default.useRef(e||new fe.default).current,tt=e=>{const t=J.default.useState({}),a=J.default.useCallback((a,r)=>{let n={...t.current,...r};for(var l in t.current=n,n)"date_range"===l||n[l].length||delete n[l];e?.emit("mergedFilterChanged",{value:n})},[e]);J.default.useEffect(()=>(e?.on("filterChanged",a),()=>{e?.off("filterChanged",a)}),[e])},at=({id:e,cache:t,dashboard:a,channel:r,...n})=>{const[l,o]=J.default.useState(),[i,s]=J.default.useState(),[d,c]=J.default.useState(),[u,m]=J.default.useState(),[p,g]=J.default.useState(Le()),[h,y]=J.default.useState(),[x,b]=J.default.useState(0),[E,v]=J.default.useState(!1),[w,S]=J.default.useState(),[C,k]=J.default.useState(!1),T=J.default.useRef({value:n?.filter}),[R,D]=J.default.useState({}),{ref:B,inView:z,entry:P}=f.useInView({threshold:.1,delay:1e3}),F=et(r);tt(F);const M=J.default.useCallback(e=>{const t=e.target.value;b(t),y(l.doc.view[t])},[l]);J.default.useEffect(()=>{e&&(async()=>{const a=e,r=t?.[a]||await We.getChart({id:a}),l=r.doc.source?.id,i=l?t?.[l]||await We.getReport({id:l}):void 0,d=t?.[`schema_${l}`]||n?.schema||await We.getReportSchema({id:l}),u=r.doc?.view?.[0];b(0),s(i),o(r),y(u),c(d),k(!0)})().catch(e=>{console.error(e.message)})},[e]),J.default.useEffect(()=>{l&&u&&(!l?.doc?.source?.id||i)&&d&&(async()=>{g(Le(l.doc.chart?.component,{view:h,source:u,chart:l,report:i,schema:d,dashboard:a,query:R}))})().catch(e=>{console.error(e.message)})},[l,u,h,i,d]);const q=e=>{const t={...i?.doc.query.filter||{},...n?.filter,...e?.value},a=t.date_range||i?.doc.query.date_range;if(delete t.date_range,k(!1),S(),v(!0),"context"===l?.doc?.source?.type)return m({filter:t}),void v(!1);const r={filter:t,date_range:a,parameters:n?.params};D(r),We.runReport({id:i.id,query:r}).then(e=>{m(l.doc.source.reverse?e.reverse():e)}).catch(e=>{m([])}).finally(()=>{v(!1)})},I=e=>{T.current=e,z?q(e):(S(e),k(!0))};return J.default.useEffect(()=>(F?.on("mergedFilterChanged",I),()=>{F?.off("mergedFilterChanged",I)}),[F,i,l,z]),J.default.useEffect(()=>{z&&C&&q(w)},[z,C]),J.default.useEffect(()=>{k(!0)},[n.params]),J.default.createElement(Q.default,{ref:B,elevation:0,style:{borderRadius:12,padding:20,border:"1px solid #e5e5e5",background:"#fff",display:"flex",flexDirection:"column",gap:"12px",height:"100%"}},l&&J.default.createElement("div",{style:{display:"flex",alignItems:"center",lineHeight:0}},J.default.createElement(te.default,{variant:"subtitle2",style:{fontWeight:600,color:"#252525"}},n?.title||l.doc.name," ")),E?J.default.createElement(Ie,{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100%",width:"100%"}}):J.default.createElement(J.default.Fragment,null,J.default.createElement("div",{style:{display:"flex"}},J.default.createElement("div",{style:{flexGrow:1}}),J.default.createElement("div",null,l?.doc?.view?.length>1&&J.default.createElement(re.default,null,J.default.createElement(ne.default,{labelId:"date-range-select-label",id:"date-range-select",value:x,onChange:M,style:{fontSize:"12px"},disableUnderline:!0},l.doc.view.map((e,t)=>J.default.createElement(le.default,{key:t,value:t},e.title)))))),J.default.createElement("div",{style:{position:"relative",flexGrow:a?void 0:1,display:"flex",flexDirection:"column"}},J.default.createElement(Xe,{filters:l?.doc?.filters,channel:F,query:R}),p)))};const rt=e.createContext(void 0),nt=({defaultParameters:t={},defaultApi:a={},children:r})=>{const n={base_currency:"EUR",...t},[l,o]=e.useState(n),[i,s]=e.useState(a);e.useEffect(()=>{const e={base_currency:"EUR",...t};o(e)},[t]),e.useEffect(()=>{s(a)},[a]);const d={parameters:l,setParameters:e=>{const t={base_currency:"EUR",...e};o(t)},api:i,setApi:s,setReportingContext:({parameters:e,api:t})=>{if(void 0!==e){const t={base_currency:"EUR",...e};o(t)}void 0!==t&&s(t)}};return J.default.createElement(rt.Provider,{value:d},r)},lt=()=>e.useContext(rt);const ot=e.createContext(),it=({children:t})=>{const[a,r]=e.useState({open:!1,message:"",severity:"info",duration:6e3}),n=(e,t="info",a=6e3)=>{r({open:!0,message:e,severity:t,duration:a})},l=(e,t)=>{"clickaway"!==t&&r(e=>({...e,open:!1}))},o={success:(e,t)=>n(e,"success",t),error:(e,t)=>n(e,"error",t),warning:(e,t)=>n(e,"warning",t),info:(e,t)=>n(e,"info",t)};return J.default.createElement(ot.Provider,{value:o},t,J.default.createElement(m.Snackbar,{open:a.open,autoHideDuration:a.duration,onClose:l,anchorOrigin:{vertical:"top",horizontal:"right"}},J.default.createElement(m.Alert,{onClose:l,severity:a.severity,variant:"filled",sx:{width:"100%"}},a.message)))},st=()=>{const t=e.useContext(ot);if(!t)throw new Error("useNotify must be used within a NotifyProvider");return t},dt=({open:e,title:t="Confirm Action",message:a,onConfirm:r,onCancel:n,confirmText:l="Confirm",cancelText:o="Cancel",confirmColor:i="error"})=>J.default.createElement(m.Dialog,{open:e,onClose:n,"aria-labelledby":"confirm-dialog-title","aria-describedby":"confirm-dialog-description"},J.default.createElement(m.DialogTitle,{id:"confirm-dialog-title"},t),J.default.createElement(m.DialogContent,null,J.default.createElement(m.DialogContentText,{id:"confirm-dialog-description"},a)),J.default.createElement(m.DialogActions,null,J.default.createElement(m.Button,{onClick:n,variant:"outlined"},o),J.default.createElement(m.Button,{onClick:r,variant:"contained",color:i,autoFocus:!0},l))),ct=({onSelectReport:t,onAddNew:a,onCloneReport:r,onRunReport:n,refreshTrigger:l})=>{const o=st(),[i,s]=e.useState([]),[d,c]=e.useState(!0),[u,f]=e.useState(null),[p,g]=e.useState(!1),[h,y]=e.useState(null);e.useEffect(()=>{x()},[l]);const x=async()=>{try{c(!0),f(null);const e=await We.getReportDefinitions();s(e)}catch(e){console.error("Error loading report definitions:",e);const t="Failed to load report definitions: "+(e.message||"Unknown error");f(t),o.error(t)}finally{c(!1)}},b=[{field:"title",headerName:"Title",flex:1,minWidth:200},{field:"provider",headerName:"Provider",flex:1,minWidth:200},{field:"actions",headerName:"Actions",width:200,sortable:!1,filterable:!1,disableColumnMenu:!0,renderCell:e=>J.default.createElement(m.Box,{sx:{display:"flex",gap:1}},J.default.createElement(m.Tooltip,{title:"Run"},J.default.createElement(m.IconButton,{size:"small",color:"success",onClick:t=>{return a=e.row.id,t.stopPropagation(),void n(a);var a}},J.default.createElement(be.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:"Edit"},J.default.createElement(m.IconButton,{size:"small",color:"primary",onClick:a=>{return r=e.row.id,a.stopPropagation(),void t(r);var r}},J.default.createElement(he.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:"Clone"},J.default.createElement(m.IconButton,{size:"small",onClick:t=>(async(e,t)=>{t.stopPropagation();try{const t=await We.getReportDefinition({id:e}),a={...t,title:`${t.title} (Copy)`};r(a)}catch(e){console.error("Error cloning report:",e),o.error("Failed to clone report: "+(e.message||"Unknown error"))}})(e.row.id,t)},J.default.createElement(ye.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:"Delete"},J.default.createElement(m.IconButton,{size:"small",color:"error",onClick:t=>((e,t)=>{t.stopPropagation();const a=i.find(t=>t.id===e);y(a),g(!0)})(e.row.id,t)},J.default.createElement(xe.default,{fontSize:"small"}))))}],E=i.map(e=>({id:e.id,title:e.title,provider:e.provider}));return d?J.default.createElement(m.Box,{display:"flex",justifyContent:"center",alignItems:"center",minHeight:400},J.default.createElement(m.CircularProgress,null)):u?J.default.createElement(m.Box,{display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",minHeight:400,gap:2},J.default.createElement(m.Typography,{variant:"body1",color:"error"},u),J.default.createElement(m.Button,{variant:"contained",onClick:x},"Retry")):J.default.createElement(m.Box,{sx:{p:3,display:"flex",flexDirection:"column",fontFamily:"system-ui"}},J.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center",mb:2,fontFamily:"system-ui"}},J.default.createElement(m.Button,{variant:"contained",sx:{backgroundColor:" rgb(70, 134, 128)",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none"},startIcon:J.default.createElement(ge.default,null),onClick:a},"Add New Report")),J.default.createElement(m.Box,{sx:{flex:1,width:"100%",borderRadius:"0.5rem",overflow:"hidden",fontFamily:"system-ui"}},J.default.createElement(S.DataGrid,{rows:E,columns:b,pageSize:10,rowsPerPageOptions:[10,25,50],disableSelectionOnClick:!0,onRowClick:e=>{t(e.row.id)},sx:{height:"100%",borderRadius:"0.5rem",overflow:"hidden",fontFamily:"system-ui","& .MuiDataGrid-columnHeaders":{backgroundColor:"#ffff"},"& .MuiDataGrid-columnHeaderTitle":{fontWeight:"600 !important",fontSize:"0.875rem !important"},"& .MuiDataGrid-columnHeader:first-of-type":{borderTopLeftRadius:"0.5rem"},"& .MuiDataGrid-columnHeader:last-of-type":{borderTopRightRadius:"0.5rem"},"& .MuiDataGrid-row":{cursor:"pointer",fontSize:"0.875rem !important"},"& .MuiDataGrid-row:hover":{backgroundColor:"#f6f5f5ff"}}})),J.default.createElement(dt,{open:p,title:"Delete Report Definition",message:h?`Are you sure you want to delete "${h.title}"? This action cannot be undone.`:"",onConfirm:async()=>{if(h)try{await We.deleteReportDefinition({id:h.id}),o.success(`Report "${h.title}" deleted successfully!`),g(!1),y(null),x()}catch(e){console.error("Error deleting report:",e),o.error("Failed to delete report: "+(e.response?.data?.message||e.message||"Unknown error")),g(!1),y(null)}},onCancel:()=>{g(!1),y(null)},confirmText:"Delete",cancelText:"Cancel",confirmColor:"error"}))},ut=({providersData:t,rootProvider:a,onSelectionChange:r,existingDimensions:n=[],existingMetrics:l=[],existingFilters:o={}})=>{const[i,s]=e.useState([]);e.useEffect(()=>{s([]),r&&r([])},[a]);const d=e=>{if(!t||!e)return[];const a=t[e];if(!a||!a.relations||0===a.relations.length)return[];const r=(()=>{const e=new Map,t=t=>{if(t.relations&&t.providerPath)for(let a=0;a<t.relations.length;a++){const r=t.relations[a],n=t.providerPath[a];r.type&&(e.has(n)||e.set(n,new Set),e.get(n).add(r.name))}};return n.forEach(t),l.forEach(t),Object.values(o).forEach(t),e})().get(e);return a.relations.filter(e=>t[e.target]).map(e=>{let t=!1,a=null;if(!!e.type&&r&&r.size>0){if(!r.has(e.name)&&r.size>0){t=!0;a=`Cannot select: '${Array.from(r)[0]}' is already in use`}}return{key:e.name,value:e.name,targetKey:e.target,disabled:t,disabledReason:a}})},c=(e,t)=>{const n=t.target.value,l=0===e?a:i[e-1].targetKey,o=d(l).find(e=>e.key===n);if(!o)return;const c=i.slice(0,e);c.push({providerKey:n,relationName:n,targetKey:o.targetKey}),s(c),console.log("Selection chain:",c),r&&r(c)};return J.default.createElement(m.Box,null,i.length>0&&J.default.createElement(m.Box,{sx:{marginBottom:2}},J.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",gap:1.5,flexWrap:"wrap"}},J.default.createElement(m.Chip,{label:Ze(a),size:"medium",variant:"outlined",sx:{fontWeight:600,borderColor:"rgb(70, 134, 128)",color:"rgb(70, 134, 128)",backgroundColor:"white",height:"32px",fontFamily:"system-ui"}}),i.map((e,t)=>J.default.createElement(J.default.Fragment,{key:t},J.default.createElement(m.Typography,{variant:"body2",sx:{color:"#9e9e9e",fontWeight:"bold"}},"→"),J.default.createElement(m.Chip,{label:Ze(e.targetKey),size:"medium",onDelete:()=>(e=>{const t=i.slice(0,e);s(t),r&&r(t)})(t),sx:{fontWeight:500,backgroundColor:"rgb(70, 134, 128)",color:"white",height:"32px",fontFamily:"system-ui","& .MuiChip-deleteIcon":{color:"rgba(255, 255, 255, 0.7)","&:hover":{color:"white"}}}}))))),J.default.createElement("div",{style:{display:"flex",flexWrap:"wrap",alignItems:"flex-start",gap:"16px"}},(()=>{if(!t||!a)return null;const e=[],r=d(a);r.length>0&&e.push(J.default.createElement("div",{key:"level-0",style:{marginRight:"16px"}},J.default.createElement(Je,{items:r,value:i[0]?.providerKey||"",label:`Related to ${a}`,onChange:e=>c(0,e),sx:{width:"300px"}})));for(let t=0;t<i.length;t++){const a=i[t],r=d(a.targetKey);if(r.length>0){const n=i[t+1];e.push(J.default.createElement("div",{key:`level-${t+1}`,style:{marginRight:"16px"}},J.default.createElement(Je,{items:r,value:n?.providerKey||"",label:`Related to ${a.targetKey}`,onChange:e=>c(t+1,e),sx:{width:"300px"}})))}}return e})()))},ft=({id:t,label:a,fullLabel:r,onDelete:n,onMoveUp:l,onMoveDown:o,isFirst:i,isLast:s,sortOrder:d,onSortOrderChange:c,fullPath:u,defaultTitle:f,customTitle:p,onUpdateTitle:g,onResetTitle:h})=>{const[y,x]=e.useState(!1),[b,E]=e.useState(""),v=e.useRef(null),w=e.useRef(null),{attributes:C,listeners:k,setNodeRef:T,transform:R,transition:D,isDragging:B}=M.useSortable({id:t}),z={transform:q.CSS.Transform.toString(R),transition:D,opacity:B?.5:1,display:"flex",alignItems:"center",width:"100%"};e.useEffect(()=>{y&&v.current&&(v.current.focus(),v.current.select())},[y]),e.useEffect(()=>{const e=e=>{y&&w.current&&!w.current.contains(e.target)&&F()};if(y)return document.addEventListener("mousedown",e),()=>{document.removeEventListener("mousedown",e)}},[y]);const P=()=>{const e=b.trim();""!==e?(g(u,e),x(!1)):F()},F=()=>{x(!1),E("")},I=p||a,$=!!p;return J.default.createElement("div",Me({ref:T,style:z},C),J.default.createElement(m.Box,{ref:w,sx:{display:"flex",alignItems:"center",width:"100%",gap:1,backgroundColor:"white",border:"1px solid #e0e0e0",borderRadius:2,padding:1,transition:"transform 0.2s ease, box-shadow 0.2s ease","&:hover .hover-icons":{opacity:1}}},J.default.createElement(m.Box,Me({},k,{sx:{display:"flex",alignItems:"center",cursor:"grab","&:active":{cursor:"grabbing"}}}),J.default.createElement(Se.default,{sx:{cursor:"grab",color:"rgba(110, 110, 110, 0.62)"}})),y?J.default.createElement(J.default.Fragment,null,J.default.createElement(m.TextField,{inputRef:v,value:b,onChange:e=>E(e.target.value),onKeyDown:e=>{"Enter"===e.key?P():"Escape"===e.key&&F()},size:"small",sx:{minWidth:"200px",maxWidth:"400px"}}),J.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:1}},J.default.createElement(m.Tooltip,{title:"Save",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:P,color:"primary","aria-label":"save title"},J.default.createElement(Re.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:"Cancel",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:F,"aria-label":"cancel edit"},J.default.createElement(De.default,{fontSize:"small"}))),$&&J.default.createElement(m.Tooltip,{title:"Reset to default",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:()=>{h(u),x(!1),E("")},color:"warning","aria-label":"reset title"},J.default.createElement(Be.default,{fontSize:"small"})))),J.default.createElement(m.Box,{sx:{flex:1}})):J.default.createElement(J.default.Fragment,null,J.default.createElement(m.Box,{sx:{minWidth:0}},J.default.createElement(m.Tooltip,{title:r||I,arrow:!0,placement:"top"},J.default.createElement(m.Typography,{variant:"h6",sx:{fontWeight:$?600:500,fontStyle:$?"italic":"normal",color:"#1a1a1a",fontSize:"14px",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"}},I))),J.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},J.default.createElement(m.Tooltip,{title:"Edit title",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:()=>{E(p||f),x(!0)},"aria-label":"edit title"},J.default.createElement(he.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:null===d?"No sort":"asc"===d?"Ascending":"Descending",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:()=>{c(null===d?"asc":"asc"===d?"desc":null)},"aria-label":"toggle sort order",color:d?"primary":"default"},"asc"===d?J.default.createElement(Ce.default,{fontSize:"small"}):"desc"===d?J.default.createElement(ke.default,{fontSize:"small"}):J.default.createElement(Te.default,{fontSize:"small",sx:{opacity:.3}}))),J.default.createElement(m.Tooltip,{title:"Delete",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:n,"aria-label":"delete",sx:{color:"#ef5350"}},J.default.createElement(S.GridDeleteIcon,{fontSize:"small"})))),J.default.createElement(m.Box,{sx:{flex:1}}),J.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},J.default.createElement(m.IconButton,{size:"small",onClick:l,disabled:i,"aria-label":"move up"},J.default.createElement(Ce.default,{fontSize:"small"})),J.default.createElement(m.IconButton,{size:"small",onClick:o,disabled:s,"aria-label":"move down"},J.default.createElement(ke.default,{fontSize:"small"}))))))},mt=({providersData:t,rootProvider:a,savedDimensions:r=[],onSaveDimension:n,onRemoveDimension:l,onReorderDimensions:o,titleOverrides:i={},onUpdateTitle:s,onResetTitle:d,existingMetrics:c=[],existingFilters:u={}})=>{const[f,p]=e.useState(!1),[g,h]=e.useState([]),[y,x]=e.useState(""),b=F.useSensors(F.useSensor(F.PointerSensor),F.useSensor(F.KeyboardSensor,{coordinateGetter:M.sortableKeyboardCoordinates})),E=()=>{const e=a?0===g.length?a:g[g.length-1].targetKey:null;if(!e||!t||!t[e])return[];const n=t[e];if(!n.dimensions)return[];const l=[t[a].default_alias];let o=a;g.forEach(e=>{const a=t[o];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&l.push(t.alias)}o=e.targetKey});const i=new Set(r.map(e=>e.fullPath)),s=[];return Object.keys(n.dimensions).forEach(t=>{const a=n.dimensions[t];Object.keys(a).forEach(r=>{const n=a[r],o=`${l.join("_")}.${r}`,d=i.has(o);s.push({key:`${e}_${t}.${r}`,value:n.title||r,dimensionKey:r,alias:t,dimension:n,disabled:d})})}),s},v=()=>{p(!1),h([]),x("")},w=e=>{const t=[a];return e.relationNames&&e.relationNames.length>0&&t.push(...e.relationNames),t.join(" → ")};return J.default.createElement("div",null,J.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-start",mb:2}},!f&&J.default.createElement(m.Button,{variant:"contained",startIcon:J.default.createElement(S.GridAddIcon,null),onClick:()=>{p(!0),h([]),x("")},sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",textTransform:"none",backgroundColor:"rgb(70, 134, 128)",boxShadow:"none","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Add Dimension")),f&&J.default.createElement(m.Paper,{elevation:0,sx:{p:3,mb:3,border:"1px solid #e0e0e0",borderRadius:"12px",backgroundColor:"white",boxShadow:"0px 2px 4px rgba(0,0,0,0.02)",fontFamily:"system-ui"}},J.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Provider Path"),J.default.createElement(m.Box,{sx:{mb:3}},J.default.createElement(ut,{providersData:t,rootProvider:a,onSelectionChange:h,existingDimensions:r,existingMetrics:c,existingFilters:u})),J.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Dimension"),J.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",gap:2,mb:3}},J.default.createElement(Je,{items:E(),value:y,label:"Choose Dimension",onChange:e=>{x(e.target.value)},sx:{width:"400px",fontFamily:"system-ui"}}),J.default.createElement(m.Tooltip,{title:"Add all available dimensions",arrow:!0,placement:"top"},J.default.createElement("span",null,J.default.createElement(m.IconButton,{onClick:()=>{const e=E().filter(e=>!e.disabled);if(0===e.length)return;const r=[],l=[a],o=[];let i=a;g.forEach(e=>{const a=t[i];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(r.push(t),o.push(t.name))}l.push(e.targetKey),i=e.targetKey});const s=[t[a].default_alias];r.forEach(e=>{s.push(e.alias)}),e.forEach(e=>{const t=`${s.join("_")}.${e.dimensionKey}`,a={dimension:e.dimension,relations:r,providerPath:l,relationNames:o,dimensionKey:e.dimensionKey,dimensionTitle:e.value,fullPath:t};n(a)}),v()},disabled:0===E().filter(e=>!e.disabled).length,"aria-label":"add all dimensions",sx:{color:"rgb(70, 134, 128)",border:"1px solid #e0e0e0",borderRadius:"8px",padding:"8px","&:hover":{backgroundColor:"#f5f5f5"},"&.Mui-disabled":{opacity:.5}}},J.default.createElement(ze.default,null))))),J.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-end",gap:2,mt:3}},J.default.createElement(m.Button,{variant:"outlined",onClick:v,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",borderColor:"#e0e0e0",color:"rgb(37, 37, 37)",textTransform:"none","&:hover":{backgroundColor:"#f5f5f5",borderColor:"#d0d0d0"}}},"Cancel"),J.default.createElement(m.Button,{variant:"contained",onClick:()=>{if(!y)return;const e=E().find(e=>e.key===y);if(!e)return;const r=[],l=[a],o=[];let i=a;g.forEach(e=>{const a=t[i];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(r.push(t),o.push(t.name))}l.push(e.targetKey),i=e.targetKey});const s=[t[a].default_alias];r.forEach(e=>{s.push(e.alias)});const d=`${s.join("_")}.${e.dimensionKey}`,c={dimension:e.dimension,relations:r,providerPath:l,relationNames:o,dimensionKey:e.dimensionKey,dimensionTitle:e.value,fullPath:d};n(c),v()},disabled:!y,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",textTransform:"none",backgroundColor:"rgb(70, 134, 128)","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Save Dimension"))),r.length>0&&J.default.createElement(m.Box,{sx:{marginTop:0}},J.default.createElement(m.Typography,{variant:"h6",sx:{fontSize:"16px",fontWeight:600,marginTop:2,color:"rgb(37, 37, 37)"}},"Saved Dimensions"),J.default.createElement(m.Typography,{sx:{fontSize:"13px",color:"#666",marginBottom:2}},"Drag to reorder or use arrows"),J.default.createElement(F.DndContext,{sensors:b,collisionDetection:F.closestCenter,onDragEnd:e=>{const{active:t,over:a}=e;if(a&&t.id!==a.id){const e=r.findIndex((e,a)=>a===t.id),n=r.findIndex((e,t)=>t===a.id),l=M.arrayMove(r,e,n);o(l)}}},J.default.createElement(M.SortableContext,{items:r.map((e,t)=>t),strategy:M.verticalListSortingStrategy},J.default.createElement(m.Box,{sx:{display:"flex",flexDirection:"column",gap:1}},r.map((e,t)=>J.default.createElement(ft,{key:t,id:t,label:e.dimensionTitle,fullLabel:`${w(e)} → ${e.dimensionTitle} (${e.fullPath})`,onDelete:()=>l(t),onMoveUp:()=>(e=>{if(e>0){const t=M.arrayMove(r,e,e-1);o(t)}})(t),onMoveDown:()=>(e=>{if(e<r.length-1){const t=M.arrayMove(r,e,e+1);o(t)}})(t),isFirst:0===t,isLast:t===r.length-1,sortOrder:e.sortOrder||null,onSortOrderChange:e=>((e,t)=>{const a=[...r];a[e]={...a[e],sortOrder:t},o(a)})(t,e),fullPath:e.fullPath,defaultTitle:e.dimensionTitle,customTitle:i[e.fullPath],onUpdateTitle:s,onResetTitle:d})))))))},pt=({id:t,label:a,fullLabel:r,onDelete:n,onMoveUp:l,onMoveDown:o,isFirst:i,isLast:s,fullPath:d,defaultTitle:c,customTitle:u,onUpdateTitle:f,onResetTitle:p})=>{const[g,h]=e.useState(!1),[y,x]=e.useState(""),b=e.useRef(null),E=e.useRef(null),{attributes:v,listeners:w,setNodeRef:C,transform:k,transition:T,isDragging:R}=M.useSortable({id:t}),D={transform:q.CSS.Transform.toString(k),transition:T,opacity:R?.5:1,display:"flex",alignItems:"center",width:"100%"};e.useEffect(()=>{g&&b.current&&(b.current.focus(),b.current.select())},[g]),e.useEffect(()=>{const e=e=>{g&&E.current&&!E.current.contains(e.target)&&z()};if(g)return document.addEventListener("mousedown",e),()=>{document.removeEventListener("mousedown",e)}},[g]);const B=()=>{const e=y.trim();""!==e?(f(d,e),h(!1)):z()},z=()=>{h(!1),x("")},P=u||a,F=!!u;return J.default.createElement("div",Me({ref:C,style:D},v),J.default.createElement(m.Box,{ref:E,sx:{display:"flex",alignItems:"center",width:"100%",gap:1,backgroundColor:"white",border:"1px solid #e0e0e0",borderRadius:2,padding:1,transition:"transform 0.2s ease, box-shadow 0.2s ease","&:hover .hover-icons":{opacity:1}}},J.default.createElement(m.Box,Me({},w,{sx:{display:"flex",alignItems:"center",cursor:"grab","&:active":{cursor:"grabbing"}}}),J.default.createElement(Se.default,{sx:{cursor:"grab",color:"rgba(110, 110, 110, 0.62)"}})),g?J.default.createElement(J.default.Fragment,null,J.default.createElement(m.TextField,{inputRef:b,value:y,onChange:e=>x(e.target.value),onKeyDown:e=>{"Enter"===e.key?B():"Escape"===e.key&&z()},size:"small",sx:{minWidth:"200px",maxWidth:"400px"}}),J.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:1}},J.default.createElement(m.Tooltip,{title:"Save",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:B,color:"primary","aria-label":"save title"},J.default.createElement(Re.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:"Cancel",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:z,"aria-label":"cancel edit"},J.default.createElement(De.default,{fontSize:"small"}))),F&&J.default.createElement(m.Tooltip,{title:"Reset to default",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:()=>{p(d),h(!1),x("")},color:"warning","aria-label":"reset title"},J.default.createElement(Be.default,{fontSize:"small"})))),J.default.createElement(m.Box,{sx:{flex:1}})):J.default.createElement(J.default.Fragment,null,J.default.createElement(m.Box,{sx:{minWidth:0}},J.default.createElement(m.Tooltip,{title:r||P,arrow:!0,placement:"top"},J.default.createElement(m.Typography,{variant:"h6",sx:{fontWeight:F?600:500,fontStyle:F?"italic":"normal",color:"#1a1a1a",fontSize:"14px",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"}},P))),J.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},J.default.createElement(m.Tooltip,{title:"Edit title",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:()=>{x(u||c),h(!0)},"aria-label":"edit title"},J.default.createElement(he.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:"Delete",arrow:!0,placement:"top"},J.default.createElement(m.IconButton,{size:"small",onClick:n,"aria-label":"delete",sx:{color:"#ef5350"}},J.default.createElement(S.GridDeleteIcon,{fontSize:"small"})))),J.default.createElement(m.Box,{sx:{flex:1}}),J.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},J.default.createElement(m.IconButton,{size:"small",onClick:l,disabled:i,"aria-label":"move up"},J.default.createElement(Ce.default,{fontSize:"small"})),J.default.createElement(m.IconButton,{size:"small",onClick:o,disabled:s,"aria-label":"move down"},J.default.createElement(ke.default,{fontSize:"small"}))))))},gt=({providersData:t,rootProvider:a,savedMetrics:r=[],onSaveMetric:n,onRemoveMetric:l,onReorderMetrics:o,titleOverrides:i={},onUpdateTitle:s,onResetTitle:d,existingDimensions:c=[],existingFilters:u={}})=>{const[f,p]=e.useState(!1),[g,h]=e.useState([]),[y,x]=e.useState(""),b=F.useSensors(F.useSensor(F.PointerSensor),F.useSensor(F.KeyboardSensor,{coordinateGetter:M.sortableKeyboardCoordinates})),E=()=>{const e=a?0===g.length?a:g[g.length-1].targetKey:null;if(!e||!t||!t[e])return[];const n=t[e];if(!n.metrics)return[];const l=[t[a].default_alias];let o=a;g.forEach(e=>{const a=t[o];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&l.push(t.alias)}o=e.targetKey});const i=new Set(r.map(e=>e.fullPath)),s=n.metrics.map((t,a)=>{const r=`${l.join("_")}.${t.name}`,n=i.has(r);return{key:`${e}_${t.name}_${a}`,value:t.title||t.name,metricName:t.name,metric:t,disabled:n}});return s},v=()=>{p(!1),h([]),x("")},w=e=>{const t=[a];return e.relationNames&&e.relationNames.length>0&&t.push(...e.relationNames),t.join(" → ")};return J.default.createElement("div",null,J.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-start",mb:2}},!f&&J.default.createElement(m.Button,{variant:"contained",startIcon:J.default.createElement(S.GridAddIcon,null),onClick:()=>{p(!0),h([]),x("")},sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",textTransform:"none",backgroundColor:"rgb(70, 134, 128)",boxShadow:"none","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Add Metric")),f&&J.default.createElement(m.Paper,{elevation:0,sx:{p:3,mb:3,border:"1px solid #e0e0e0",borderRadius:"12px",backgroundColor:"white",boxShadow:"0px 2px 4px rgba(0,0,0,0.02)",fontFamily:"system-ui"}},J.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Provider Path"),J.default.createElement(m.Box,{sx:{mb:3}},J.default.createElement(ut,{providersData:t,rootProvider:a,onSelectionChange:h,existingDimensions:c,existingMetrics:r,existingFilters:u})),J.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Metric"),J.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",gap:2,mb:3}},J.default.createElement(Je,{items:E(),value:y,label:"Choose Metric",onChange:e=>{x(e.target.value)},sx:{width:"400px",fontFamily:"system-ui"}}),J.default.createElement(m.Tooltip,{title:"Add all available metrics",arrow:!0,placement:"top"},J.default.createElement("span",null,J.default.createElement(m.IconButton,{onClick:()=>{const e=E().filter(e=>!e.disabled);if(0===e.length)return;const r=[],l=[a],o=[];let i=a;g.forEach(e=>{const a=t[i];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(r.push(t),o.push(t.name))}l.push(e.targetKey),i=e.targetKey});const s=[t[a].default_alias];r.forEach(e=>{s.push(e.alias)}),e.forEach(e=>{const t=`${s.join("_")}.${e.metricName}`,a={metric:e.metric,relations:r,providerPath:l,relationNames:o,metricName:e.metricName,metricTitle:e.value,fullPath:t};n(a)}),v()},disabled:0===E().filter(e=>!e.disabled).length,"aria-label":"add all metrics",sx:{color:"rgb(70, 134, 128)",border:"1px solid #e0e0e0",borderRadius:"8px",padding:"8px","&:hover":{backgroundColor:"#f5f5f5"},"&.Mui-disabled":{opacity:.5}}},J.default.createElement(ze.default,null))))),J.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-end",gap:2,mt:3}},J.default.createElement(m.Button,{variant:"outlined",onClick:v,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",borderColor:"#e0e0e0",color:"rgb(37, 37, 37)",textTransform:"none","&:hover":{backgroundColor:"#f5f5f5",borderColor:"#d0d0d0"}}},"Cancel"),J.default.createElement(m.Button,{variant:"contained",onClick:()=>{if(!y)return;const e=E().find(e=>e.key===y);if(!e)return;const r=[],l=[a],o=[];let i=a;g.forEach(e=>{const a=t[i];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(r.push(t),o.push(t.name))}l.push(e.targetKey),i=e.targetKey});const s=[t[a].default_alias];r.forEach(e=>{s.push(e.alias)});const d=`${s.join("_")}.${e.metricName}`,c={metric:e.metric,relations:r,providerPath:l,relationNames:o,metricName:e.metricName,metricTitle:e.value,fullPath:d};n(c),v()},disabled:!y,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",textTransform:"none",backgroundColor:"rgb(70, 134, 128)","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Save Metric"))),r.length>0&&J.default.createElement(m.Box,{sx:{marginTop:0}},J.default.createElement(m.Typography,{variant:"h6",sx:{fontSize:"16px",fontWeight:600,marginBottom:1,color:"rgb(37, 37, 37)"}},"Saved Metrics"),J.default.createElement(F.DndContext,{sensors:b,collisionDetection:F.closestCenter,onDragEnd:e=>{const{active:t,over:a}=e;if(a&&t.id!==a.id){const e=r.findIndex((e,a)=>a===t.id),n=r.findIndex((e,t)=>t===a.id),l=M.arrayMove(r,e,n);o(l)}}},J.default.createElement(M.SortableContext,{items:r.map((e,t)=>t),strategy:M.verticalListSortingStrategy},J.default.createElement(m.Box,{sx:{display:"flex",flexDirection:"column",gap:1}},r.map((e,t)=>J.default.createElement(pt,{key:t,id:t,label:e.metricTitle,fullLabel:`${w(e)} → ${e.metricTitle} (${e.fullPath})`,onDelete:()=>l(t),onMoveUp:()=>(e=>{if(e>0){const t=M.arrayMove(r,e,e-1);o(t)}})(t),onMoveDown:()=>(e=>{if(e<r.length-1){const t=M.arrayMove(r,e,e+1);o(t)}})(t),isFirst:0===t,isLast:t===r.length-1,fullPath:e.fullPath,defaultTitle:e.metricTitle,customTitle:i[e.fullPath],onUpdateTitle:s,onResetTitle:d})))))))},ht=({providersData:t,rootProvider:a,savedFilters:r={},onSaveFilter:n,onRemoveFilter:l,existingDimensions:o=[],existingMetrics:i=[],titleOverrides:s={},onUpdateTitle:d,onResetTitle:c})=>{const u=lt(),[f,p]=e.useState(!1),[g,h]=e.useState([]),[y,x]=e.useState(""),[b,E]=e.useState([]),[v,w]=e.useState([]),[C,k]=e.useState(!1),[T,R]=e.useState(null),[D,B]=e.useState(null),[z,P]=e.useState(null),[F,M]=e.useState(null),[q,I]=e.useState("");e.useEffect(()=>{x(""),E([]),w([]),B(null),P(null)},[g]);const $=e=>e&&("date"===e.type||"timestamp"===e.type),j=()=>{const e=a?0===g.length?a:g[g.length-1].targetKey:null;if(!e||!t||!t[e])return[];const r=t[e];if(!r.dimensions)return[];const n=[];return Object.keys(r.dimensions).forEach(t=>{const a=r.dimensions[t];Object.keys(a).forEach(r=>{const l=a[r];(e=>!!e.column&&/^[a-zA-Z0-9_.]+$/.test(e.column))(l)&&n.push({key:`${e}_${t}.${r}`,value:l.title||r,dimensionKey:r,alias:t,dimension:l})})}),n},O=()=>{p(!1),h([]),x(""),E([]),w([]),B(null),P(null),R(null)},A=()=>{R(null),E([]),w([]),B(null),P(null)},_=e=>{const t=q.trim();""!==t?(d(e,t),M(null),I("")):W()},W=()=>{M(null),I("")},N=async e=>{k(!0);try{const t={provider:a,doc:{query:{dimensions:[e],metrics:[],order_by:[{name:e}]}},parameters:u?.parameters||{base_currency:"EUR"}};console.log("Fetching filter values with payload:",t);const r=await We.runAdHocReport({report:t});console.log("Filter values results:",r);const n=(Array.isArray(r)?r:r.data||[]).map(t=>{let a=t[e];if(void 0===a){a=t[e.replace(/\./g,"_")]}if(void 0===a){const e=Object.keys(t);e.length>0&&(a=t[e[0]])}return{key:String(a),value:String(a)}});console.log("Transformed distinct values:",n),E(n)}catch(e){console.error("Error fetching filter values:",e),E([])}finally{k(!1)}},K=e=>{const t=[a];return e.relationNames&&e.relationNames.length>0&&t.push(...e.relationNames),t.join(" → ")},G=Object.entries(r);return J.default.createElement("div",null,J.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-start",mb:2}},!f&&J.default.createElement(m.Button,{variant:"contained",startIcon:J.default.createElement(S.GridAddIcon,null),onClick:()=>{p(!0),h([]),x(""),E([]),w([]),B(null),P(null),R(null)},sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",textTransform:"none",backgroundColor:"rgb(70, 134, 128)",boxShadow:"none","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Add Filter")),f&&J.default.createElement(m.Paper,{elevation:0,sx:{p:3,mb:3,border:"1px solid #e0e0e0",borderRadius:"12px",backgroundColor:"white",boxShadow:"0px 2px 4px rgba(0,0,0,0.02)",fontFamily:"system-ui"}},J.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Provider Path"),J.default.createElement(m.Box,{sx:{mb:3}},J.default.createElement(ut,{providersData:t,rootProvider:a,onSelectionChange:h,existingDimensions:o,existingMetrics:i,existingFilters:r})),J.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Dimension for Filter"),J.default.createElement(m.Box,{sx:{mb:3}},J.default.createElement(Je,{items:j(),value:y,label:"Choose Dimension",onChange:e=>{const r=e.target.value;if(x(r),w([]),B(null),P(null),r){const e=j().find(e=>e.key===r);if(e){if(!$(e.dimension)){const r=[];let n=a;g.forEach(e=>{const a=t[n];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&r.push(t)}n=e.targetKey});const l=[t[a].default_alias];r.forEach(e=>{l.push(e.alias)});const o=`${l.join("_")}.${e.dimensionKey}`;N(o)}}}else E([])},sx:{width:"400px",fontFamily:"system-ui"}})),y&&(()=>{const e=j().find(e=>e.key===y),t=e&&$(e.dimension);return J.default.createElement(J.default.Fragment,null,J.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,mt:3,color:"rgb(37, 37, 37)"}},t?"Select Date Range":"Select Filter Values"),t?J.default.createElement(U.LocalizationProvider,{dateAdapter:Y.AdapterDayjs},J.default.createElement(m.Box,{sx:{display:"flex",gap:2,width:"400px"}},J.default.createElement(L.DatePicker,{label:"From Date",value:D,onChange:e=>B(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}),J.default.createElement(L.DatePicker,{label:"To Date",value:z,onChange:e=>P(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}))):J.default.createElement(m.Box,{sx:{width:"400px"}},J.default.createElement(He,{items:b,selectedKeys:v,onChange:e=>w(e),label:"Choose Values",placeholder:"Select one or more values...",loading:C,helperText:v.length>0?`${v.length} value(s) selected`:"Select at least one value"})))})(),J.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-end",gap:2,mt:3}},J.default.createElement(m.Button,{variant:"outlined",onClick:O,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",borderColor:"#e0e0e0",color:"rgb(37, 37, 37)",textTransform:"none","&:hover":{backgroundColor:"#f5f5f5",borderColor:"#d0d0d0"}}},"Cancel"),J.default.createElement(m.Button,{variant:"contained",onClick:()=>{const e=j().find(e=>e.key===y);if(!e)return;const r=$(e.dimension);if(r){if(!D&&!z)return}else if(0===v.length)return;if(!y)return;const l=[],o=[a],i=[];let s=a;g.forEach(e=>{const a=t[s];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(l.push(t),i.push(t.name))}o.push(e.targetKey),s=e.targetKey});const d=[t[a].default_alias];l.forEach(e=>{d.push(e.alias)});const c=`${d.join("_")}.${e.dimensionKey}`;let u;r?(u={},D&&(u.gte=D.format("YYYY-MM-DD")),z&&(u.lte=z.format("YYYY-MM-DD"))):u=v;const f={dimension:e.dimension,relations:l,providerPath:o,relationNames:i,dimensionKey:e.dimensionKey,dimensionTitle:e.value,fullPath:c,values:u};n(c,f),O()},disabled:(()=>{if(!y)return!0;const e=j().find(e=>e.key===y);if(!e)return!0;return $(e.dimension)?!D&&!z:0===v.length})(),sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",textTransform:"none",backgroundColor:"rgb(70, 134, 128)","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Save Filter"))),G.length>0&&J.default.createElement(m.Box,{sx:{marginTop:0}},J.default.createElement(m.Typography,{variant:"h6",sx:{fontSize:"16px",fontWeight:600,marginBottom:1,color:"rgb(37, 37, 37)"}},"Saved Filters"),J.default.createElement(m.Box,{sx:{display:"flex",flexDirection:"column",gap:1}},G.map(([e,t])=>{const a=$(t.dimension),o=T===e,i=F===e;let d,u;a&&t.values&&"object"==typeof t.values&&!Array.isArray(t.values)?u=t.values.gte&&t.values.lte?`${t.values.gte} to ${t.values.lte}`:t.values.gte?`From ${t.values.gte}`:t.values.lte?`Until ${t.values.lte}`:"No dates":(d=t.values?.length||0,u=t.values?.join(", ")||"No values");const f=s[e]||t.dimensionTitle,g=!!s[e];return J.default.createElement(m.Box,{key:e},J.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",width:"100%",gap:1,backgroundColor:"white",border:"1px solid #e0e0e0",borderRadius:2,padding:2,transition:"box-shadow 0.2s ease","&:hover .hover-icons":{opacity:1}}},i?J.default.createElement(J.default.Fragment,null,J.default.createElement(m.TextField,{value:q,onChange:e=>I(e.target.value),onKeyDown:t=>((e,t)=>{"Enter"===e.key?_(t):"Escape"===e.key&&W()})(t,e),size:"small",autoFocus:!0,placeholder:"Enter custom title",sx:{flex:1}}),J.default.createElement(m.Box,{sx:{display:"flex",gap:.5}},J.default.createElement(m.Tooltip,{title:"Save",arrow:!0},J.default.createElement(m.IconButton,{size:"small",onClick:()=>_(e),color:"primary"},J.default.createElement(Re.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:"Cancel",arrow:!0},J.default.createElement(m.IconButton,{size:"small",onClick:W},J.default.createElement(De.default,{fontSize:"small"}))),g&&J.default.createElement(m.Tooltip,{title:"Reset to default",arrow:!0},J.default.createElement(m.IconButton,{size:"small",onClick:()=>(e=>{c(e),M(null),I("")})(e),color:"warning"},J.default.createElement(Be.default,{fontSize:"small"}))))):J.default.createElement(J.default.Fragment,null,J.default.createElement(m.Box,{sx:{flex:1,minWidth:0}},J.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",gap:1}},J.default.createElement(m.Typography,{variant:"h6",sx:{fontWeight:g?600:500,fontStyle:g?"italic":"normal",color:"#1a1a1a",fontSize:"14px"}},f),J.default.createElement(m.Tooltip,{title:J.default.createElement("div",null,J.default.createElement("div",null,J.default.createElement("strong",null,"Path:")," ",K(t)," → ",t.dimensionTitle),J.default.createElement("div",null,J.default.createElement("strong",null,"Full Path:")," ",e),J.default.createElement("div",null,J.default.createElement("strong",null,a?"Date Range":`Values (${d})`,":")," ",u)),arrow:!0,placement:"top"},J.default.createElement(m.Chip,{size:"small",label:a?u:`${d} values`,color:"default",variant:"outlined",sx:{marginLeft:1,height:"20px",fontSize:"14px"}})))),J.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},J.default.createElement(m.Tooltip,{title:"Rename filter",arrow:!0},J.default.createElement(m.IconButton,{size:"small",onClick:()=>((e,t)=>{M(e),I(s[e]||t||"")})(e,t.dimensionTitle),disabled:o},J.default.createElement(he.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:"Edit filter values",arrow:!0},J.default.createElement(m.IconButton,{size:"small",onClick:()=>(async(e,t)=>{p(!1),R(e),$(t.dimension)?t.values&&"object"==typeof t.values&&!Array.isArray(t.values)&&(B(t.values.gte?Fe.default(t.values.gte):null),P(t.values.lte?Fe.default(t.values.lte):null)):(w(t.values||[]),await N(e))})(e,t),disabled:o},J.default.createElement(Pe.default,{fontSize:"small"}))),J.default.createElement(m.Tooltip,{title:"Remove filter",arrow:!0},J.default.createElement(m.IconButton,{size:"small",onClick:()=>l(e),sx:{color:"#ef5350"}},J.default.createElement(S.GridDeleteIcon,{fontSize:"small"})))))),o&&J.default.createElement(m.Paper,{elevation:0,sx:{p:2,mt:1,ml:2,border:"1px solid #e0e0e0",borderRadius:"8px",backgroundColor:"#fafafa"}},J.default.createElement(m.Typography,{variant:"subtitle2",sx:{marginBottom:1.5,fontWeight:600}},"Edit ",a?"Date Range":"Values"," for: ",t.dimensionTitle),a?J.default.createElement(U.LocalizationProvider,{dateAdapter:Y.AdapterDayjs},J.default.createElement(m.Box,{sx:{display:"flex",gap:2,width:"400px",marginBottom:2}},J.default.createElement(L.DatePicker,{label:"From Date",value:D,onChange:e=>B(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}),J.default.createElement(L.DatePicker,{label:"To Date",value:z,onChange:e=>P(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}))):J.default.createElement(m.Box,{sx:{width:"400px",marginBottom:2}},J.default.createElement(He,{items:b,selectedKeys:v,onChange:e=>w(e),label:"Choose Values",placeholder:"Select one or more values...",loading:C,helperText:v.length>0?`${v.length} value(s) selected`:"Select at least one value"})),J.default.createElement(m.Box,{sx:{display:"flex",gap:1,justifyContent:"flex-end"}},J.default.createElement(m.Button,{variant:"outlined",size:"small",onClick:A,sx:{textTransform:"none",borderRadius:"6px"}},"Cancel"),J.default.createElement(m.Button,{variant:"contained",size:"small",onClick:()=>(e=>{const t=r[e];if($(t.dimension)){if(!D&&!z)return;const a={};D&&(a.gte=D.format("YYYY-MM-DD")),z&&(a.lte=z.format("YYYY-MM-DD"));const r={...t,values:a};n(e,r)}else{if(0===v.length)return;const a={...t,values:v};n(e,a)}R(null),E([]),w([]),B(null),P(null)})(e),disabled:a?!D&&!z:0===v.length,sx:{textTransform:"none",borderRadius:"6px",backgroundColor:"rgb(70, 134, 128)",boxShadow:"none","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Save Changes"))))}))))},yt=({reportData:t,dimensions:a,metrics:r,loading:n,onPageChange:l,totalRows:o=0,titleOverrides:i={dimensions:{},metrics:{}}})=>{const[s,d]=e.useState({page:0,pageSize:50}),c=J.default.useMemo(()=>{const e=[];return a.forEach(t=>{let a,r;if(t.relations&&t.relations.length>0){const e=t.fullPath.split("."),r=e[0],n=e[1],l=r.split("_");l.shift();const o=l.join("_");a=o?`${o}_${n}`:n}else a=t.fullPath.replace(".","_");r=i.dimensions[t.fullPath]||t.dimensionTitle||a,e.push({field:a,headerName:r,flex:1,minWidth:150})}),r.forEach(t=>{const a=t.metric;let r,n;if(t.relations&&t.relations.length>0){const e=t.fullPath.split("."),a=e[0],n=e[1],l=a.split("_");l.shift();const o=l.join("_");r=o?`${o}_${n}`:n}else r=t.metricName;n=i.metrics[t.fullPath]||t.metricTitle||r,e.push({field:r,headerName:n,flex:1,minWidth:150,type:"integer"===a?.type||"currency"===a?.type?"number":"string",valueFormatter:e=>{if(null==e)return"";if(a?.format){const t=X.default(e).format(a.format);return a?.prefix?`${a.prefix} ${t}`:t}return e}})}),e},[a,r,i]),u=J.default.useMemo(()=>t&&Array.isArray(t)?t.map((e,t)=>({id:t,...e})):[],[t]);return n?J.default.createElement(m.Box,{display:"flex",justifyContent:"center",alignItems:"center",minHeight:400},J.default.createElement(m.CircularProgress,null)):t&&0!==t.length?J.default.createElement(m.Box,{sx:{height:600,width:"100%"}},J.default.createElement(S.DataGrid,{rows:u,columns:c,paginationModel:s,onPaginationModelChange:e=>{d(e),l&&e.page!==s.page&&l(e.page,e.pageSize)},pageSizeOptions:[10,25,50,100],paginationMode:"server",rowCount:o||u.length,loading:n,disableRowSelectionOnClick:!0,sx:{"& .MuiDataGrid-cell":{padding:"8px"},"& .MuiDataGrid-columnHeader":{backgroundColor:"#f5f5f5",fontWeight:"bold"}}})):J.default.createElement(m.Box,{display:"flex",justifyContent:"center",alignItems:"center",minHeight:400},J.default.createElement(m.Typography,{variant:"body1",color:"textSecondary"},"No data available. Run a report to see results."))};function xt({children:e,value:t,index:a}){return J.default.createElement("div",{role:"tabpanel",hidden:t!==a,id:`report-tabpanel-${a}`,"aria-labelledby":`report-tab-${a}`},t===a&&J.default.createElement(m.Box,{sx:{py:3}},e))}const bt=({reportDefinitionId:t,cloneData:a,autoRun:r,onBackToList:n})=>{const l=st(),o=lt(),[i,s]=e.useState(null),[d,c]=e.useState(""),[u,f]=e.useState(""),[p,g]=e.useState({dimensions:[],metrics:[],filters:{}}),[h,y]=e.useState({dimensions:{},metrics:{},filters:{}}),[x,b]=e.useState(null),[E,v]=e.useState(!1),[w,S]=e.useState(0),[C,k]=e.useState(0),[T,R]=e.useState(50),[D,B]=e.useState(0),[z,P]=e.useState(!1),[F,M]=e.useState(!1);e.useEffect(()=>{(async()=>{const e=await We.getProviders();console.log({providers:e}),s(e)})()},[]),e.useEffect(()=>{t&&i&&$(t)},[t,i]),e.useEffect(()=>{a&&i&&j(a)},[a,i]),e.useEffect(()=>{r&&F&&d&&p.dimensions.length>0&&_()},[r,F]);const q=(e,t,a)=>{try{const[r,n]=e.split("."),l=r.split("_");let o=a;const i=[],s=[a],d=[];for(let e=1;e<l.length;e++){const a=l[e],r=t[o];if(!r||!r.relations)return console.warn(`Provider ${o} not found or has no relations`),null;const n=r.relations.find(e=>e.alias===a);if(!n)return console.warn(`Relation with alias ${a} not found in provider ${o}`),null;i.push(n),d.push(n.name),o=n.target,s.push(o)}const c=t[o];if(!c)return console.warn(`Final provider ${o} not found`),null;const u=c.default_alias;if(!c.dimensions||!c.dimensions[u])return console.warn(`Dimensions not found for alias ${u} in provider ${o}`),null;const f=c.dimensions[u][n];return f?{dimension:f,relations:i,providerPath:s,relationNames:d,dimensionKey:n,dimensionTitle:f.title||n,fullPath:e}:(console.warn(`Dimension ${n} not found in provider ${o}, alias ${u}`),null)}catch(t){return console.warn(`Error reconstructing dimension from path ${e}:`,t),null}},I=(e,t,a)=>{try{const[r,n]=e.split("."),l=r.split("_");let o=a;const i=[],s=[a],d=[];for(let e=1;e<l.length;e++){const a=l[e],r=t[o];if(!r||!r.relations)return console.warn(`Provider ${o} not found or has no relations`),null;const n=r.relations.find(e=>e.alias===a);if(!n)return console.warn(`Relation with alias ${a} not found in provider ${o}`),null;i.push(n),d.push(n.name),o=n.target,s.push(o)}const c=t[o];if(!c)return console.warn(`Final provider ${o} not found`),null;if(!c.metrics)return console.warn(`Metrics not found in provider ${o}`),null;const u=c.metrics.find(e=>e.name===n);return u?{metric:u,relations:i,providerPath:s,relationNames:d,metricName:n,metricTitle:u.title||n,fullPath:e}:(console.warn(`Metric ${n} not found in provider ${o}`),null)}catch(t){return console.warn(`Error reconstructing metric from path ${e}:`,t),null}},$=async e=>{try{console.log("Loading report definition:",e);const t=await We.getReportDefinition({id:e});console.log("Loaded report definition:",t),c(t.provider),f(t.title||"");const a=[],r={};if(t.definition?.doc?.query?.order_by)for(const e of t.definition.doc.query.order_by)!0===e.desc?r[e.name]="desc":r[e.name]="asc";if(t.definition?.doc?.query?.dimensions)for(const e of t.definition.doc.query.dimensions){const n=q(e,i,t.provider);n&&(n.sortOrder=r[e]||null,a.push(n))}const n=[];if(t.definition?.doc?.query?.metrics)for(const e of t.definition.doc.query.metrics){const a=I(e,i,t.provider);a&&n.push(a)}const l={dimensions:{},metrics:{},filters:{}};t.definition?.doc?.query?.titles&&(t.definition.doc.query.titles.dimensions&&(l.dimensions=t.definition.doc.query.titles.dimensions),t.definition.doc.query.titles.metrics&&(l.metrics=t.definition.doc.query.titles.metrics),t.definition.doc.query.titles.filters&&(l.filters=t.definition.doc.query.titles.filters));const o={};if(t.definition?.doc?.query?.filter){const e=t.definition.doc.query.filter;(e.and||e.or||[]).forEach(e=>{const[a,r]=Object.entries(e)[0],n=q(a,i,t.provider);n&&(o[a]={...n,values:r})})}g({dimensions:a,metrics:n,filters:o}),y(l),M(!0),console.log("Reconstructed report:",{dimensions:a,metrics:n,filters:o,titleOverrides:l})}catch(e){console.error("Error loading report definition:",e),l.error("Error loading report definition: "+(e.message||"Unknown error"))}},j=e=>{try{console.log("Loading cloned report:",e),c(e.provider),f(e.title||"");const t=[],a={};if(e.definition?.doc?.query?.order_by)for(const t of e.definition.doc.query.order_by)!0===t.desc?a[t.name]="desc":a[t.name]="asc";if(e.definition?.doc?.query?.dimensions)for(const r of e.definition.doc.query.dimensions){const n=q(r,i,e.provider);n&&(n.sortOrder=a[r]||null,t.push(n))}const r=[];if(e.definition?.doc?.query?.metrics)for(const t of e.definition.doc.query.metrics){const a=I(t,i,e.provider);a&&r.push(a)}const n={dimensions:{},metrics:{},filters:{}};e.definition?.doc?.query?.titles&&(e.definition.doc.query.titles.dimensions&&(n.dimensions=e.definition.doc.query.titles.dimensions),e.definition.doc.query.titles.metrics&&(n.metrics=e.definition.doc.query.titles.metrics),e.definition.doc.query.titles.filters&&(n.filters=e.definition.doc.query.titles.filters));const l={};if(e.definition?.doc?.query?.filter){const t=e.definition.doc.query.filter;(t.and||t.or||[]).forEach(t=>{const[a,r]=Object.entries(t)[0],n=q(a,i,e.provider);n&&(l[a]={...n,values:r})})}g({dimensions:t,metrics:r,filters:l}),y(n),console.log("Loaded cloned report:",{dimensions:t,metrics:r,filters:l,titleOverrides:n})}catch(e){console.error("Error loading cloned report:",e),l.error("Error loading cloned report: "+(e.message||"Unknown error"))}},O=(e=0,t=50)=>{const a=p.dimensions.map(e=>{const t={name:e.fullPath};return"desc"===e.sortOrder&&(t.desc=!0),t}),r=[];p.filters&&Object.keys(p.filters).length>0&&Object.entries(p.filters).forEach(([e,t])=>{t.values&&(Array.isArray(t.values)?t.values.length>0&&r.push({[e]:t.values}):"object"==typeof t.values&&r.push({[e]:t.values}))});const n=r.length>0?{and:r}:null,l={};Object.keys(h.dimensions).length>0&&(l.dimensions=h.dimensions),Object.keys(h.metrics).length>0&&(l.metrics=h.metrics),Object.keys(h.filters).length>0&&(l.filters=h.filters);const i={dimensions:p.dimensions.map(e=>e.fullPath),metrics:p.metrics.map(e=>e.fullPath),order_by:a,limit:t,offset:e*t};Object.keys(l).length>0&&(i.titles=l),n&&(i.filter=n);return{provider:d,doc:{query:i},parameters:o?.parameters||{base_currency:"EUR"}}},A=async(e,t)=>{try{v(!0);const a=O(e,t);console.log("Running report with:",a);const r=await We.runAdHocReport({report:a});console.log("Report result:",r),b(r),r&&r.length<t?S(e*t+r.length):S((e+2)*t)}catch(e){console.error("Error running report:",e),l.error("Error running report: "+(e.message||"Unknown error")),b(null)}finally{v(!1)}},_=async()=>{k(0),await A(0,T),B(3)},W=d,N=d&&u.trim()&&(p.dimensions.length>0||p.metrics.length>0);return J.default.createElement(m.Box,{sx:{p:3,fontFamily:"system-ui"}},J.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,backgroundColor:"transparent",fontFamily:"system-ui"}},J.default.createElement("h1",null,t?"Edit Report":"Create New Report"),n&&J.default.createElement(m.Button,{variant:"outlined",startIcon:J.default.createElement(Ee.default,null),onClick:n},"Back to List")),J.default.createElement(m.Box,{sx:{mt:2,p:3,backgroundColor:"white",borderRadius:"12px",border:"1px solid #e0e0e0",fontFamily:"system-ui",display:"flex",flexDirection:"column",gap:3,boxShadow:"0px 2px 4px rgba(0,0,0,0.02)"}},J.default.createElement(m.Box,{sx:{display:"flex",gap:4,alignItems:"flex-start",flexWrap:"wrap"}},J.default.createElement("div",null,J.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1,color:"rgb(37, 37, 37)"}},"Report Title"),J.default.createElement(m.TextField,{value:u,onChange:e=>f(e.target.value),placeholder:"Enter report title",sx:{width:"400px",fontFamily:"system-ui","& .MuiOutlinedInput-root":{backgroundColor:"white",borderRadius:"8px"}},size:"small"})),J.default.createElement("div",null,J.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1,color:"rgb(37, 37, 37)"}},"Select Root Provider"),J.default.createElement(Je,{items:i?Object.keys(i).filter(e=>!0===i[e].base).map(e=>({key:e,value:i[e].name||e})):[],value:d,onChange:e=>{c(e.target.value),g({dimensions:[],metrics:[],filters:{}}),y({dimensions:{},metrics:{},filters:{}}),console.log("Selected root provider:",e.target.value)},sx:{width:"300px",fontFamily:"system-ui"},disabled:!!t}))),J.default.createElement(m.Box,{sx:{display:"flex",gap:2,alignItems:"center"}},J.default.createElement(m.Button,{variant:"contained",onClick:_,disabled:!W,startIcon:J.default.createElement(be.default,null),sx:{height:"40px",fontFamily:"system-ui",borderRadius:"8px",boxShadow:"none",textTransform:"none",backgroundColor:"rgb(70, 134, 128)",fontWeight:500,padding:"0 20px","&:hover":{backgroundColor:"rgb(46, 102, 98)",boxShadow:"none"}}},"Run Report"),J.default.createElement(m.Button,{variant:"outlined",startIcon:J.default.createElement(we.default,null),onClick:async()=>{try{v(!0);const e=O();console.log("Downloading report with:",e);const t=(new Date).toISOString().split("T")[0],a=`${(u||"report").replace(/[^a-z0-9]/gi,"_").toLowerCase()}_${t}.csv`;await We.downloadAdHocReport({report:e,filename:a}),l.success("Report downloaded successfully!")}catch(e){console.error("Error downloading report:",e),l.error("Error downloading report: "+(e.message||"Unknown error"))}finally{v(!1)}},disabled:!W||E,sx:{height:"40px",fontFamily:"system-ui",borderRadius:"8px",boxShadow:"none",textTransform:"none",color:"#9c27b0",borderColor:"#e1bee7",fontWeight:500,padding:"0 20px","&:hover":{borderColor:"#9c27b0",backgroundColor:"rgba(156, 39, 176, 0.04)"}}},"Download CSV"),J.default.createElement(m.Button,{variant:"outlined",startIcon:J.default.createElement(ve.default,null),onClick:async()=>{if(d)if(u.trim())if(0!==p.dimensions.length||0!==p.metrics.length)try{P(!0);const e=p.dimensions.map(e=>{const t={name:e.fullPath};return"desc"===e.sortOrder&&(t.desc=!0),t}),a={};Object.keys(h.dimensions).length>0&&(a.dimensions=h.dimensions),Object.keys(h.metrics).length>0&&(a.metrics=h.metrics),Object.keys(h.filters).length>0&&(a.filters=h.filters);const r={dimensions:p.dimensions.map(e=>e.fullPath),metrics:p.metrics.map(e=>e.fullPath),order_by:e};if(Object.keys(a).length>0&&(r.titles=a),Object.keys(p.filters).length>0){const e=[];Object.entries(p.filters).forEach(([t,a])=>{a.values&&(Array.isArray(a.values)?a.values.length>0&&e.push({[t]:a.values}):"object"==typeof a.values&&e.push({[t]:a.values}))}),e.length>0&&(r.filter={and:e})}const o={query:r},i={provider:d,title:u.trim(),definition:{provider:d,doc:o,parameters:{base_currency:"EUR"}}};console.log("Saving report definition:",i),t?(await We.updateReportDefinition({id:t,reportDefinition:i}),l.success("Report definition updated successfully!")):(await We.createReportDefinition({reportDefinition:i}),l.success("Report definition created successfully!")),n&&n()}catch(e){console.error("Error saving report definition:",e),l.error("Error saving report definition: "+(e.message||"Unknown error"))}finally{P(!1)}else l.warning("Please add at least one dimension or metric");else l.warning("Please enter a report title");else l.warning("Please select a provider first")},disabled:!N||z,sx:{height:"40px",fontFamily:"system-ui",borderRadius:"8px",boxShadow:"none",textTransform:"none",color:"#2e7d32",borderColor:"#a5d6a7",fontWeight:500,padding:"0 20px","&:hover":{borderColor:"#2e7d32",backgroundColor:"rgba(46, 125, 50, 0.04)"}}},z?"Saving...":t?"Update Report":"Save Report"))),d&&J.default.createElement(m.Box,{sx:{mt:2,fontFamily:"system-ui",backgroundColor:"white",px:3,py:2,borderRadius:"8px"}},J.default.createElement(m.Box,{sx:{borderBottom:1,borderColor:"rgba(70, 134, 127, 0.27)"}},J.default.createElement(m.Tabs,{value:D,onChange:(e,t)=>{B(t)},"aria-label":"report builder tabs",sx:{"& .MuiTabs-indicator":{display:"flex",justifyContent:"center",backgroundColor:"rgb(70, 134, 128)"},"& .MuiTabs-indicatorSpan":{backgroundColor:"rgb(70, 134, 128)"}}},J.default.createElement(m.Tab,{label:J.default.createElement(m.Badge,{badgeContent:p.dimensions.length,sx:{"& .MuiBadge-badge":{backgroundColor:"rgb(70, 134, 128)",color:"#fff"}}},J.default.createElement("span",{style:{marginRight:p.dimensions.length>0?"12px":"0"}},"Dimensions")),id:"report-tab-0","aria-controls":"report-tabpanel-0",sx:{height:"41px",fontFamily:"system-ui",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none",color:"rgb(37, 37, 37)","&.Mui-selected":{color:"rgb(70, 134, 128)"}}}),J.default.createElement(m.Tab,{label:J.default.createElement(m.Badge,{badgeContent:p.metrics.length,sx:{"& .MuiBadge-badge":{backgroundColor:"rgb(70, 134, 128)",color:"#fff"}}},J.default.createElement("span",{style:{marginRight:p.metrics.length>0?"12px":"0"}},"Metrics")),id:"report-tab-1","aria-controls":"report-tabpanel-1",sx:{height:"41px",fontFamily:"system-ui",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none",color:"rgb(37, 37, 37)","&.Mui-selected":{color:"rgb(70, 134, 128)"}}}),J.default.createElement(m.Tab,{label:J.default.createElement(m.Badge,{badgeContent:Object.keys(p.filters).length,sx:{"& .MuiBadge-badge":{backgroundColor:"rgb(70, 134, 128)",color:"#fff"}}},J.default.createElement("span",{style:{marginRight:Object.keys(p.filters).length>0?"12px":"0"}},"Filters")),id:"report-tab-2","aria-controls":"report-tabpanel-2",sx:{height:"41px",fontFamily:"system-ui",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none",color:"rgb(37, 37, 37)","&.Mui-selected":{color:"rgb(70, 134, 128)"}}}),J.default.createElement(m.Tab,{label:x?"Results":"Results (Run report first)",id:"report-tab-3","aria-controls":"report-tabpanel-3",disabled:!x,sx:{height:"41px",fontFamily:"system-ui",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none",color:"rgb(37, 37, 37)","&.Mui-selected":{color:"rgb(70, 134, 128)"}}}))),J.default.createElement(xt,{value:D,index:0},J.default.createElement(mt,{providersData:i,rootProvider:d,savedDimensions:p.dimensions,onSaveDimension:e=>{g(t=>{const a={...t,dimensions:[...t.dimensions,e]};return console.log("Dimension saved:",e),console.log("Complete report:",a),a})},onRemoveDimension:e=>{g(t=>({...t,dimensions:t.dimensions.filter((t,a)=>a!==e)}))},onReorderDimensions:e=>{g(t=>({...t,dimensions:e}))},titleOverrides:h.dimensions,onUpdateTitle:(e,t)=>{y(a=>({...a,dimensions:{...a.dimensions,[e]:t}}))},onResetTitle:e=>{y(t=>{const a={...t.dimensions};return delete a[e],{...t,dimensions:a}})},existingMetrics:p.metrics,existingFilters:p.filters})),J.default.createElement(xt,{value:D,index:1},J.default.createElement(gt,{providersData:i,rootProvider:d,savedMetrics:p.metrics,onSaveMetric:e=>{g(t=>{const a={...t,metrics:[...t.metrics,e]};return console.log("Metric saved:",e),console.log("Complete report:",a),a})},onRemoveMetric:e=>{g(t=>({...t,metrics:t.metrics.filter((t,a)=>a!==e)}))},onReorderMetrics:e=>{g(t=>({...t,metrics:e}))},titleOverrides:h.metrics,onUpdateTitle:(e,t)=>{y(a=>({...a,metrics:{...a.metrics,[e]:t}}))},onResetTitle:e=>{y(t=>{const a={...t.metrics};return delete a[e],{...t,metrics:a}})},existingDimensions:p.dimensions,existingFilters:p.filters})),J.default.createElement(xt,{value:D,index:2},J.default.createElement(ht,{providersData:i,rootProvider:d,savedFilters:p.filters,existingDimensions:p.dimensions,existingMetrics:p.metrics,onSaveFilter:(e,t)=>{g(a=>{const r={...a,filters:{...a.filters,[e]:t}};return console.log("Filter saved:",{fullPath:e,filterData:t}),console.log("Complete report:",r),r})},onRemoveFilter:e=>{g(t=>{const a={...t.filters};return delete a[e],{...t,filters:a}})},titleOverrides:h.filters,onUpdateTitle:(e,t)=>{y(a=>({...a,filters:{...a.filters,[e]:t}}))},onResetTitle:e=>{y(t=>{const a={...t.filters};return delete a[e],{...t,filters:a}})}})),J.default.createElement(xt,{value:D,index:3},x&&J.default.createElement(yt,{reportData:x,dimensions:p.dimensions,metrics:p.metrics,loading:E,onPageChange:async(e,t)=>{k(e),t!==T&&R(t),await A(e,t)},totalRows:w,titleOverrides:h}))))},Et=()=>{const[t,a]=e.useState("list"),[r,n]=e.useState(null),[l,o]=e.useState(null),[i,s]=e.useState(!1),[d,c]=e.useState(0),u=e=>{n(e),o(null),s(!1),a("builder")},f=()=>{n(null),o(null),s(!1),a("builder")},m=e=>{n(e),o(null),s(!0),a("builder")},p=e=>{n(null),o(e),s(!1),a("builder")};return"list"===t?J.default.createElement(ct,{onSelectReport:u,onAddNew:f,onCloneReport:p,onRunReport:m,refreshTrigger:d}):J.default.createElement(bt,{reportDefinitionId:r,cloneData:l,autoRun:i,onBackToList:()=>{n(null),o(null),s(!1),a("list"),c(e=>e+1)}})};var vt={Chart:at,Dashboard:function({id:t="sample_dashboard",api:a,params:r}){const n=lt(),l=a||n?.api||{},o=r||n?.parameters||{},[i,s]=J.default.useState(),[d]=J.default.useState(),[c,u]=J.default.useState([]),f=J.default.useRef({}),m=et();tt(m),console.log({rows:c},{dashboard:i},{schema:d},{params:o}),e.useEffect(()=>{We.setBaseUrl(l.base_url),We.setToken(l.token)},[l]);const p=async e=>{const t=e?.doc?.rows||[],a=[];for(let e=0;e<t.length;e++){const r=t[e];r.columns?.forEach(e=>{if(e.override?.filter?.length){const t={};e.override.filter.forEach(e=>{e.hasOwnProperty("value")&&(t[e.field]=[e.value])}),e.filter=t}}),a.push(r)}u(a)};return J.default.useEffect(()=>{t&&(async()=>{We.setBaseUrl(l.base_url),We.setToken(l.token),await We.loadDashboardMeta({dashboardId:t});const e=await We.getDashboard({id:t});f.current[e?.id]=e,s(e),await p(e)})().catch(e=>console.error(e.message))},[t]),J.default.createElement(pe.default,{maxWidth:!1,disableGutters:!0},J.default.createElement(me.default,{container:!0,spacing:3},c?.map((e,t)=>{const a=(e=>0===e?12:12/e)(e.columns.length);return J.default.createElement(J.default.Fragment,{key:t},1===t?J.default.createElement(me.default,{item:!0,xs:12},J.default.createElement(me.default,{container:!0,spacing:3},e.columns.map((e,t)=>J.default.createElement(me.default,{key:t,item:!0,xs:12,md:a},J.default.createElement(at,{api:l,cache:f.current,id:e.id,dashboard:i,schema:d,title:e.title,filter:e.filter,params:o}))))):e.columns.map((e,t)=>J.default.createElement(me.default,{key:t,item:!0,xs:12,md:a},J.default.createElement(at,{api:l,cache:f.current,id:e.id,dashboard:i,schema:d,title:e.title,filter:e.filter,params:o}))))})))},ReportApp:({params:t,api:a})=>(We._initialized||(We.setBaseUrl(a.base_url),We.setToken(a.token),We._initialized=!0),e.useEffect(()=>{We.setBaseUrl(a.base_url),We.setToken(a.token)},[a]),J.default.createElement(it,null,J.default.createElement(nt,{defaultParameters:t,defaultApi:a},J.default.createElement(H.ThemeProvider,{theme:H.createTheme({palette:{primary:{main:"rgb(70, 134, 128)"}},components:{MuiButton:{styleOverrides:{root:{borderRadius:8,textTransform:"none",boxShadow:"none","&:hover":{boxShadow:"none"}}}},MuiTooltip:{styleOverrides:{tooltip:{fontSize:"0.875rem",backgroundColor:"rgba(97, 97, 97, 0.95)",maxWidth:500},arrow:{color:"rgba(97, 97, 97, 0.95)"}},defaultProps:{arrow:!0,enterDelay:300,leaveDelay:200}},MuiPopper:{defaultProps:{style:{zIndex:1500}}}}})},J.default.createElement(Et,null)))))};exports.default=vt;
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("@material-ui/core/Paper"),a=require("@material-ui/core/styles"),r=require("@material-ui/core"),n=require("react-google-charts"),l=require("numeral"),o=require("axios"),i=require("@material-ui/core/Typography"),s=require("nunjucks"),d=require("@material-ui/core/FormControl"),c=require("@material-ui/core/Select"),u=require("@material-ui/core/MenuItem"),f=require("react-intersection-observer"),m=require("@mui/material"),p=require("@mui/icons-material/CheckBoxOutlineBlank"),g=require("@mui/icons-material/CheckBox"),h=require("@mui/material/Box"),y=require("@mui/material/MenuItem"),x=require("@mui/material/FormControl"),b=require("@mui/material/Select"),E=require("eventemitter3"),v=require("@material-ui/core/Grid"),w=require("@material-ui/core/Container"),S=require("@mui/x-data-grid"),C=require("@mui/icons-material/Add"),k=require("@mui/icons-material/Edit"),T=require("@mui/icons-material/ContentCopy"),R=require("@mui/icons-material/Delete"),D=require("@mui/icons-material/PlayArrow"),B=require("@mui/icons-material/Restore"),P=require("@mui/icons-material/ArrowBack"),z=require("@mui/icons-material/Save"),F=require("@mui/icons-material/Download"),M=require("@dnd-kit/core"),I=require("@dnd-kit/sortable"),q=require("@dnd-kit/utilities"),$=require("@mui/icons-material/DragIndicator"),A=require("@mui/icons-material/ArrowUpward"),O=require("@mui/icons-material/ArrowDownward"),j=require("@mui/icons-material/Sort"),_=require("@mui/icons-material/Check"),W=require("@mui/icons-material/Close"),N=require("@mui/icons-material/RestartAlt"),K=require("@mui/icons-material/PlaylistAdd"),U=require("@mui/icons-material/FilterAlt"),Y=require("@mui/icons-material/InfoOutlined"),L=require("@mui/x-date-pickers/LocalizationProvider"),G=require("@mui/x-date-pickers/DatePicker"),H=require("@mui/x-date-pickers/AdapterDayjs"),V=require("dayjs"),Z=require("@mui/material/styles");function J(e){return e&&e.__esModule?e:{default:e}}function Q(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach(function(a){if("default"!==a){var r=Object.getOwnPropertyDescriptor(e,a);Object.defineProperty(t,a,r.get?r:{enumerable:!0,get:function(){return e[a]}})}}),t.default=e,Object.freeze(t)}var X=Q(e),ee=J(t),te=J(l),ae=J(o),re=J(i),ne=J(s),le=J(d),oe=J(c),ie=J(u),se=J(p),de=J(g),ce=J(h),ue=J(y),fe=J(x),me=J(b),pe=J(E),ge=J(v),he=J(w),ye=J(C),xe=J(k),be=J(T),Ee=J(R),ve=J(D),we=J(B),Se=J(P),Ce=J(z),ke=J(F),Te=J($),Re=J(A),De=J(O),Be=J(j),Pe=J(_),ze=J(W),Fe=J(N),Me=J(K),Ie=J(U),qe=J(Y),$e=J(V);function Ae(){return Ae=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var a=arguments[t];for(var r in a)({}).hasOwnProperty.call(a,r)&&(e[r]=a[r])}return e},Ae.apply(null,arguments)}const Oe=a.makeStyles(e=>({root:{width:"100%","& > * + *":{marginTop:e.spacing(2)}}}));function je(e){const t=Oe();return X.default.createElement("div",Ae({className:t.root},e),X.default.createElement(r.CircularProgress,{style:{color:"rgb(70, 134, 128)"},size:25}))}function _e(e,t,a="array"){const r=e.columns,n=[...t.doc.metrics,...t.doc.dimensions].reduce((e,t)=>(e[t.name]=t,e),{});return e=>{const t="array"===a?[]:{};return r.reduce((t,r)=>{const l=e[r.name],o=n[r.name];let i=l;return i="timestamp"===o.type?new Date(l):o.format?o.format&&o.prefix?{v:+l,f:o.prefix+" "+te.default(l).format(o.format)}:o.format?{v:+l,f:te.default(l).format(o.format)}:l:l,"array"===a?t.push(i):t[r.name]=i?.f||i,t},t)}}const We="https://report-api.netcapital.pro",Ne=ae.default.create({baseURL:We,headers:{"Content-Type":"application/json"}}),Ke={},Ue=()=>{const e=Object.keys(Ke);return e.length>0?e[0]:null},Ye={setBaseUrl(e){Ne.defaults.baseURL=e||We},setToken(e){e&&(Ne.defaults.headers.common.Authorization=`Bearer ${e}`)},loadDashboardMeta:async({dashboardId:e})=>{const{data:t}=await Ne.get(`/dashboard-meta/${e}`);return Ke[e]={dashboards:t.dashboards||{},charts:t.charts||{},reports:t.reports||{},reportMetadata:t.reportMetadata||{},dateRanges:t.dateRanges||[]},Ke[e]},getDashboard:async({id:e,dashboardId:t})=>{const a=t||Ue();if(a&&Ke[a]?.dashboards?.[e])return Ke[a].dashboards[e];const{data:r}=await Ne.get(`/entity/dashboards/${e}`);return r},getChart:async({id:e,dashboardId:t})=>{const a=t||Ue();if(a&&Ke[a]?.charts?.[e])return Ke[a].charts[e];const{data:r}=await Ne.get(`/entity/charts/${e}`);return r},getReport:async({id:e,dashboardId:t})=>{const a=t||Ue();if(a&&Ke[a]?.reports?.[e])return Ke[a].reports[e];const{data:r}=await Ne.get(`/entity/reports/${e}`);return r},getProviders:async()=>{const{data:e}=await Ne.get("/entity/providers");return e},getReportSchema:async({id:e,dashboardId:t,query:a={}})=>{const r=t||Ue();if(r&&Ke[r]?.reportMetadata?.[e])return Ke[r].reportMetadata[e];const{data:n}=await Ne.post(`/reports/${e}/metadata`,a);return n},runReport:async({id:e,query:t={}})=>{const{data:a}=await Ne.post(`/reports/${e}/run`,t);return a},runAdHocReport:async({report:e})=>{const{data:t}=await Ne.post("/report-build/run",e);return t},downloadAdHocReport:async({report:e,filename:t})=>{const a=await Ne.post("/report-build/run?download=csv",e,{responseType:"blob"}),r=window.URL.createObjectURL(new Blob([a.data])),n=document.createElement("a");n.href=r;let l=t||"report.csv";if(!t){const e=a.headers["content-disposition"];if(e){const t=e.match(/filename="?(.+)"?/i);t&&t[1]&&(l=t[1])}}n.setAttribute("download",l),document.body.appendChild(n),n.click(),n.remove(),window.URL.revokeObjectURL(r)},getDateRanges:async({dashboardId:e}={})=>{const t=e||Ue();if(t&&Ke[t]?.dateRanges)return Ke[t].dateRanges;const{data:a}=await Ne.get("/globals/date-ranges");return a},getReportDefinitions:async()=>{const{data:e}=await Ne.get("/report-definitions");return e},getReportDefinition:async({id:e})=>{const{data:t}=await Ne.get(`/report-definitions/${e}`);return t},createReportDefinition:async({reportDefinition:e})=>{const{data:t}=await Ne.post("/report-definitions",e);return t},updateReportDefinition:async({id:e,reportDefinition:t})=>{const{data:a}=await Ne.put(`/report-definitions/${e}`,t);return a},deleteReportDefinition:async({id:e})=>{const{data:t}=await Ne.delete(`/report-definitions/${e}`);return t}},Le=a.makeStyles(e=>({headerRow:{fontFamily:e.typography.fontFamily,fontSize:e.typography.fontSize},tableRow:{fontFamily:e.typography.fontFamily,fontSize:e.typography.fontSize},oddTableRow:{fontFamily:e.typography.fontFamily,fontSize:e.typography.fontSize},headerCell:{backgroundColor:"white",padding:"4px !important"}})),Ge={none:"YYYY-MM-dd",day:"MMM dd",week:"MMM dd",month:"YYYY MMM",year:"YYYY"};const He={GoogleChart:function({chart:t,source:a,view:r,report:l,schema:o,dashboard:i,query:s}){const[d,c]=X.default.useState([]),u=Le(),[f,m]=X.default.useState([]);e.useEffect(()=>{(async()=>{const e=await Ye.getDateRanges();m(e)})()},[]);const p=e.useMemo(()=>{const e="YYYY-MM-dd",t=s?.date_range?.name,a=f.find(e=>e.name===t);if(!a)return e;return Ge[a?.granularity]||e},[f,s]);return X.default.useEffect(()=>{if(!(t&&r&&a&&l&&o))return;let e=[];e.push(function(e,t){const a=[...t.doc.metrics,...t.doc.dimensions];return e.columns.reduce((e,t)=>{const r=a.find(e=>e.name===t.name)||t;return e.push(r.title||r.name),e},[])}(r,o));const n=_e(r,o);a?.forEach(t=>{const a=n(t);e.push(a)}),a?.length?c(e):c()},[t,a,r,l,o]),d?X.default.createElement("div",{style:{}},X.default.createElement(n.Chart,Ae({width:t?.doc.size?.width||"100%",chartType:t?.doc.chart?.type,data:d,options:(e=>{const a=["#468682","#ff686b","#6c757d","#FFD700","#073b4c"];if("Table"===t?.doc.chart?.type)return{...t?.doc.chart?.options,cssClassNames:u};if("AreaChart"===t?.doc.chart?.type){const r=t?.doc.chart?.options?.hAxis||{},n={...{ticks:e.slice(1).map(e=>e[0]),format:p},...r};return{...t?.doc.chart?.options,hAxis:n,focusTarget:"category",colors:a}}return{...t?.doc.chart?.options,colors:a}})(d)},t?.doc.chart?.props))):X.default.createElement("div",null)},LabelChart:function({chart:e,source:t,view:a,report:r,schema:n}){const[l,o]=X.default.useState([]),[i,s]=X.default.useState(),[d,c]=X.default.useState();return X.default.useEffect(()=>{if(!(e&&a&&t&&r&&n))return;let l=[];const i=_e(a,n);t.forEach(e=>l.push(i(e))),o(l);const d=e?.doc?.chart?.options||{},u=d?.index||0;if(l.length>0&&s(l[0][u]),d.subText?.format){ne.default.configure({autoescape:!1});const e=_e(a,n,"object")(t[0]),r=ne.default.renderString(d.subText?.format,e);c(r)}},[e,t,a,r,n]),X.default.createElement("div",{style:{display:"flex",justifyContent:"center",alignContent:"center",height:"100%",flexDirection:"column"}},X.default.createElement(re.default,{variant:"h6"},i?.f||i),X.default.createElement(re.default,{variant:"caption"},d))}};function Ve(e,t){return void 0!==He[e]?X.default.createElement(He[e],t):X.default.createElement(je,t)}const Ze=X.createElement(se.default,{fontSize:"small"}),Je=X.createElement(de.default,{fontSize:"small"});function Qe({items:t,selectedKeys:a,defaultSelectedKeys:r,onChange:n,inputValue:l,defaultInputValue:o,onInputChange:i,debounceMs:s=300,label:d,placeholder:c,loading:u,disabled:f,size:p="small",error:g,helperText:h,limitTags:y=3,disableClearable:x,id:b,textFieldProps:E}){const v=e.useMemo(()=>Array.isArray(t)?t:[],[t]),w=Array.isArray(a),[S,C]=e.useState(Array.isArray(r)?r:[]),k=w?a:S,T=e.useMemo(()=>{const e=new Map;for(const t of v)e.set(t&&t.key,t);return e},[v]),R=e.useMemo(()=>(Array.isArray(k)?k:[]).map(e=>T.get(e)).filter(Boolean),[k,T]),D="string"==typeof l,[B,P]=e.useState("string"==typeof o?o:""),z=D?l:B,F=function(t,a=300){const r=e.useRef(t),n=e.useRef(null);return r.current=t,e.useEffect(()=>()=>{n.current&&window.clearTimeout(n.current)},[]),X.useCallback((...e)=>{r.current&&(n.current&&window.clearTimeout(n.current),n.current=window.setTimeout(()=>{r.current&&r.current(...e)},a))},[a])}(e=>{i&&i(e)},s),M=R;return X.createElement(m.FormControl,{fullWidth:!0,error:g,disabled:f},X.createElement(m.Autocomplete,{openOnFocus:!0,forcePopupIcon:!0,id:b,multiple:!0,disableCloseOnSelect:!0,options:v,value:M,inputValue:z,getOptionLabel:e=>e&&"object"==typeof e?e.value??"":"",isOptionEqualToValue:(e,t)=>e&&t&&e.key===t.key,loading:u,limitTags:y,disableClearable:x,onChange:(e,t)=>{const a=Array.isArray(t)?t.map(e=>e&&e.key):[];w||C(a),n&&n(a,Array.isArray(t)?t:[])},onInputChange:(e,t,a)=>{D||P(t??""),"input"===a?F(t??""):"clear"===a&&F("")},renderOption:(e,t,{selected:a})=>X.createElement("li",Ae({},e,{key:t&&t.key||Math.random().toString(36)}),X.createElement(m.Checkbox,{icon:Ze,checkedIcon:Je,style:{marginRight:8},checked:!!a}),t&&t.value),renderTags:(e,t)=>(Array.isArray(e)?e:[]).map((e,a)=>X.createElement(m.Chip,Ae({},t({index:a}),{key:e&&e.key||a,label:e&&e.value||""}))),renderInput:e=>X.createElement(m.TextField,Ae({},e,{label:d,placeholder:c,InputProps:{...e.InputProps,endAdornment:X.createElement(X.Fragment,null,u?X.createElement(m.CircularProgress,{size:18}):null,e.InputProps.endAdornment)},size:p},E))}),h?X.createElement(m.FormHelperText,null,h):null)}const Xe=({filter:t,channel:a,query:r})=>{const[n,l]=e.useState([]),[o,i]=e.useState([]),[s,d]=e.useState(!1),[c,u]=e.useState("");return e.useEffect(()=>{i(r?.filter?.[t?.filter]||[])},[r]),e.useEffect(()=>{(async()=>{d(!0);const e=await async function(e,t){return t?.source?(await Ye.runReport({id:t.source})).map(e=>({key:e[t.field],value:e[t.field]})):[]}(0,t);l(e),d(!1)})()},[c]),X.default.createElement("div",{style:{display:"flex"}},X.default.createElement("div",{style:{maxWidth:640,minWidth:200}},X.default.createElement(Qe,{id:t?.title,label:t?.title,placeholder:"Type to search…",items:n,selectedKeys:o,onChange:(e,r)=>{i(e),a.emit("filterChanged",t,{[t.filter]:e})},onInputChange:e=>{u(e)},loading:s,debounceMs:300,helperText:o.length?`${o.length} selected`:""})))},et=e=>e?.replace(/([a-z])([A-Z])/g,"$1 $2")?.replace(/_/g," ")?.replace(/-/g," ").replace(/\b\w/g,e=>e.toUpperCase());function tt({items:e,value:t,onChange:a,sx:r={width:"100%"},disabled:n=!1,label:l}){const o=e.some(e=>e.key===t)?t:"";return X.default.createElement(ce.default,{sx:r},X.default.createElement(fe.default,{fullWidth:!0,size:"small"},X.default.createElement(me.default,{value:o,onChange:a,disabled:n,displayEmpty:!0,MenuProps:{style:{maxHeight:300}},sx:{height:"40px",borderRadius:"8px",fontFamily:"system-ui",backgroundColor:"white","& .MuiSelect-select":{display:"flex",alignItems:"center",padding:"8px 12px"},"& fieldset":{borderColor:"rgba(0,0,0,0.23)"},"&:hover fieldset":{borderColor:"rgb(70, 134, 128) !important"},"&.Mui-focused fieldset":{borderColor:"rgb(70, 134, 128) !important"}}},X.default.createElement(ue.default,{value:"",disabled:!0,sx:{color:"rgba(37, 37, 37, 0.58)"}},et(l)),e.map(e=>{const{key:t,value:a,disabled:r}=e;return X.default.createElement(ue.default,{key:t,value:t,disabled:r,sx:{fontFamily:"system-ui",minHeight:"36px"}},et(a))}))))}const at=({filter:t,channel:a,query:r})=>{const[n,l]=e.useState([]),[o,i]=e.useState("");return e.useEffect(()=>{i(r?.date_range?.name)},[r]),e.useEffect(()=>{(async()=>{const e=(await Ye.getDateRanges()).filter(e=>!(t.allowedOptions.length>0)||t.allowedOptions.some(t=>t===e.name)).map(e=>({key:e.name,value:e.title}));l(e)})()},[]),X.default.createElement("div",{style:{minWidth:"200px",maxWidth:"640px"}},X.default.createElement(tt,{items:n,value:o,label:t?.title,onChange:(e,r)=>{const n=e.target.value;i(n),a.emit("filterChanged",t,{date_range:{name:n}})}}))},rt=({filters:e=[],channel:t,query:a})=>X.default.createElement("div",{style:{display:"flex",flexWrap:"wrap",gap:"8px"}},e.map(e=>"multi-select"===e.type?X.default.createElement(Xe,{key:e.title,channel:t,filter:e,query:a}):"date-range"===e.type?X.default.createElement(at,{key:e.title,channel:t,filter:e,query:a}):null));var nt=e=>X.default.useRef(e||new pe.default).current,lt=e=>{const t=X.default.useState({}),a=X.default.useCallback((a,r)=>{let n={...t.current,...r};for(var l in t.current=n,n)"date_range"===l||n[l].length||delete n[l];e?.emit("mergedFilterChanged",{value:n})},[e]);X.default.useEffect(()=>(e?.on("filterChanged",a),()=>{e?.off("filterChanged",a)}),[e])},ot=({id:e,cache:t,dashboard:a,channel:r,...n})=>{const[l,o]=X.default.useState(),[i,s]=X.default.useState(),[d,c]=X.default.useState(),[u,m]=X.default.useState(),[p,g]=X.default.useState(Ve()),[h,y]=X.default.useState(),[x,b]=X.default.useState(0),[E,v]=X.default.useState(!1),[w,S]=X.default.useState(),[C,k]=X.default.useState(!1),T=X.default.useRef({value:n?.filter}),[R,D]=X.default.useState({}),{ref:B,inView:P,entry:z}=f.useInView({threshold:.1,delay:1e3}),F=nt(r);lt(F);const M=X.default.useCallback(e=>{const t=e.target.value;b(t),y(l.doc.view[t])},[l]);X.default.useEffect(()=>{e&&(async()=>{const a=e,r=t?.[a]||await Ye.getChart({id:a}),l=r.doc.source?.id,i=l?t?.[l]||await Ye.getReport({id:l}):void 0,d=t?.[`schema_${l}`]||n?.schema||await Ye.getReportSchema({id:l}),u=r.doc?.view?.[0];b(0),s(i),o(r),y(u),c(d),k(!0)})().catch(e=>{console.error(e.message)})},[e]),X.default.useEffect(()=>{l&&u&&(!l?.doc?.source?.id||i)&&d&&(async()=>{g(Ve(l.doc.chart?.component,{view:h,source:u,chart:l,report:i,schema:d,dashboard:a,query:R}))})().catch(e=>{console.error(e.message)})},[l,u,h,i,d]);const I=e=>{const t={...i?.doc.query.filter||{},...n?.filter,...e?.value},a=t.date_range||i?.doc.query.date_range;if(delete t.date_range,k(!1),S(),v(!0),"context"===l?.doc?.source?.type)return m({filter:t}),void v(!1);const r={filter:t,date_range:a,parameters:n?.params};D(r),Ye.runReport({id:i.id,query:r}).then(e=>{m(l.doc.source.reverse?e.reverse():e)}).catch(e=>{m([])}).finally(()=>{v(!1)})},q=e=>{T.current=e,P?I(e):(S(e),k(!0))};return X.default.useEffect(()=>(F?.on("mergedFilterChanged",q),()=>{F?.off("mergedFilterChanged",q)}),[F,i,l,P]),X.default.useEffect(()=>{P&&C&&I(w)},[P,C]),X.default.useEffect(()=>{k(!0)},[n.params]),X.default.createElement(ee.default,{ref:B,elevation:0,style:{borderRadius:12,padding:20,border:"1px solid #e5e5e5",background:"#fff",display:"flex",flexDirection:"column",gap:"12px",height:"100%"}},l&&X.default.createElement("div",{style:{display:"flex",alignItems:"center",lineHeight:0}},X.default.createElement(re.default,{variant:"subtitle2",style:{fontWeight:600,color:"#252525"}},n?.title||l.doc.name," ")),E?X.default.createElement(je,{style:{display:"flex",justifyContent:"center",alignItems:"center",height:"100%",width:"100%"}}):X.default.createElement(X.default.Fragment,null,X.default.createElement("div",{style:{display:"flex"}},X.default.createElement("div",{style:{flexGrow:1}}),X.default.createElement("div",null,l?.doc?.view?.length>1&&X.default.createElement(le.default,null,X.default.createElement(oe.default,{labelId:"date-range-select-label",id:"date-range-select",value:x,onChange:M,style:{fontSize:"12px"},disableUnderline:!0},l.doc.view.map((e,t)=>X.default.createElement(ie.default,{key:t,value:t},e.title)))))),X.default.createElement("div",{style:{position:"relative",flexGrow:a?void 0:1,display:"flex",flexDirection:"column"}},X.default.createElement(rt,{filters:l?.doc?.filters,channel:F,query:R}),p)))};const it=e.createContext(void 0),st=({defaultParameters:t={},defaultApi:a={},children:r})=>{const n={base_currency:"EUR",...t},[l,o]=e.useState(n),[i,s]=e.useState(a);e.useEffect(()=>{const e={base_currency:"EUR",...t};o(e)},[t]),e.useEffect(()=>{s(a)},[a]);const d={parameters:l,setParameters:e=>{const t={base_currency:"EUR",...e};o(t)},api:i,setApi:s,setReportingContext:({parameters:e,api:t})=>{if(void 0!==e){const t={base_currency:"EUR",...e};o(t)}void 0!==t&&s(t)}};return X.default.createElement(it.Provider,{value:d},r)},dt=()=>e.useContext(it);const ct=e.createContext(),ut=({children:t})=>{const[a,r]=e.useState({open:!1,message:"",severity:"info",duration:6e3}),n=(e,t="info",a=6e3)=>{r({open:!0,message:e,severity:t,duration:a})},l=(e,t)=>{"clickaway"!==t&&r(e=>({...e,open:!1}))},o={success:(e,t)=>n(e,"success",t),error:(e,t)=>n(e,"error",t),warning:(e,t)=>n(e,"warning",t),info:(e,t)=>n(e,"info",t)};return X.default.createElement(ct.Provider,{value:o},t,X.default.createElement(m.Snackbar,{open:a.open,autoHideDuration:a.duration,onClose:l,anchorOrigin:{vertical:"top",horizontal:"right"}},X.default.createElement(m.Alert,{onClose:l,severity:a.severity,variant:"filled",sx:{width:"100%"}},a.message)))},ft=()=>{const t=e.useContext(ct);if(!t)throw new Error("useNotify must be used within a NotifyProvider");return t},mt=({open:e,title:t="Confirm Action",message:a,onConfirm:r,onCancel:n,confirmText:l="Confirm",cancelText:o="Cancel",confirmColor:i="error"})=>X.default.createElement(m.Dialog,{open:e,onClose:n,"aria-labelledby":"confirm-dialog-title","aria-describedby":"confirm-dialog-description"},X.default.createElement(m.DialogTitle,{id:"confirm-dialog-title"},t),X.default.createElement(m.DialogContent,null,X.default.createElement(m.DialogContentText,{id:"confirm-dialog-description"},a)),X.default.createElement(m.DialogActions,null,X.default.createElement(m.Button,{onClick:n,variant:"outlined"},o),X.default.createElement(m.Button,{onClick:r,variant:"contained",color:i,autoFocus:!0},l))),pt=({onSelectReport:t,onAddNew:a,onCloneReport:r,onRunReport:n,refreshTrigger:l})=>{const o=ft(),[i,s]=e.useState([]),[d,c]=e.useState(!0),[u,f]=e.useState(null),[p,g]=e.useState(!1),[h,y]=e.useState(null);e.useEffect(()=>{x()},[l]);const x=async()=>{try{c(!0),f(null);const e=await Ye.getReportDefinitions();s(e)}catch(e){console.error("Error loading report definitions:",e);const t="Failed to load report definitions: "+(e.message||"Unknown error");f(t),o.error(t)}finally{c(!1)}},b=(e,t)=>{t.stopPropagation();const a=i.find(t=>t.id===e);y(a),g(!0)},E=[{field:"title",headerName:"Title",flex:1,minWidth:200},{field:"provider",headerName:"Provider",flex:1,minWidth:200},{field:"source",headerName:"Source",flex:1,minWidth:150},{field:"actions",headerName:"Actions",width:200,sortable:!1,filterable:!1,disableColumnMenu:!0,renderCell:e=>{const a="user-override"===e.row.source;return X.default.createElement(m.Box,{sx:{display:"flex",gap:1}},X.default.createElement(m.Tooltip,{title:"Run"},X.default.createElement(m.IconButton,{size:"small",color:"success",onClick:t=>{return a=e.row.id,t.stopPropagation(),void n(a);var a}},X.default.createElement(ve.default,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:"Edit"},X.default.createElement(m.IconButton,{size:"small",color:"primary",onClick:a=>{return r=e.row.id,a.stopPropagation(),void t(r);var r}},X.default.createElement(xe.default,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:"Clone"},X.default.createElement(m.IconButton,{size:"small",onClick:t=>(async(e,t)=>{t.stopPropagation();try{const t=await Ye.getReportDefinition({id:e}),a={...t,title:`${t.title} (Copy)`};r(a)}catch(e){console.error("Error cloning report:",e),o.error("Failed to clone report: "+(e.message||"Unknown error"))}})(e.row.id,t)},X.default.createElement(be.default,{fontSize:"small"}))),a?X.default.createElement(m.Tooltip,{title:"Revert to the system report"},X.default.createElement(m.IconButton,{size:"small",color:"warning",onClick:t=>b(e.row.id,t)},X.default.createElement(we.default,{fontSize:"small"}))):X.default.createElement(m.Tooltip,{title:"Delete"},X.default.createElement(m.IconButton,{size:"small",color:"error",onClick:t=>b(e.row.id,t)},X.default.createElement(Ee.default,{fontSize:"small"}))))}}],v=i.map(e=>({id:e.id,title:e.title,provider:e.provider,source:e.source}));return d?X.default.createElement(m.Box,{display:"flex",justifyContent:"center",alignItems:"center",minHeight:400},X.default.createElement(m.CircularProgress,null)):u?X.default.createElement(m.Box,{display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",minHeight:400,gap:2},X.default.createElement(m.Typography,{variant:"body1",color:"error"},u),X.default.createElement(m.Button,{variant:"contained",onClick:x},"Retry")):X.default.createElement(m.Box,{sx:{p:3,display:"flex",flexDirection:"column",fontFamily:"system-ui"}},X.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-end",alignItems:"center",mb:2,fontFamily:"system-ui"}},X.default.createElement(m.Button,{variant:"contained",sx:{backgroundColor:" rgb(70, 134, 128)",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none"},startIcon:X.default.createElement(ye.default,null),onClick:a},"Add New Report")),X.default.createElement(m.Box,{sx:{flex:1,width:"100%",borderRadius:"0.5rem",overflow:"hidden",fontFamily:"system-ui"}},X.default.createElement(S.DataGrid,{rows:v,columns:E,pageSize:10,rowsPerPageOptions:[10,25,50],disableSelectionOnClick:!0,onRowClick:e=>{t(e.row.id)},sx:{height:"100%",borderRadius:"0.5rem",overflow:"hidden",fontFamily:"system-ui","& .MuiDataGrid-columnHeaders":{backgroundColor:"#ffff"},"& .MuiDataGrid-columnHeaderTitle":{fontWeight:"600 !important",fontSize:"0.875rem !important"},"& .MuiDataGrid-columnHeader:first-of-type":{borderTopLeftRadius:"0.5rem"},"& .MuiDataGrid-columnHeader:last-of-type":{borderTopRightRadius:"0.5rem"},"& .MuiDataGrid-row":{cursor:"pointer",fontSize:"0.875rem !important"},"& .MuiDataGrid-row:hover":{backgroundColor:"#f6f5f5ff"}}})),X.default.createElement(mt,{open:p,title:"user-override"===h?.source?"Revert Report Definition":"Delete Report Definition",message:h?"user-override"===h.source?`Are you sure you want to revert "${h.title}" to the system version? Your custom changes will be lost.`:`Are you sure you want to delete "${h.title}"? This action cannot be undone.`:"",onConfirm:async()=>{if(!h)return;const e="user-override"===h.source,t=e?"reverted":"deleted";try{await Ye.deleteReportDefinition({id:h.id}),o.success(e?`Report "${h.title}" reverted to system version successfully!`:`Report "${h.title}" deleted successfully!`),g(!1),y(null),x()}catch(e){console.error(`Error ${t} report:`,e),o.error(`Failed to ${t.toLowerCase()} report: `+(e.response?.data?.message||e.message||"Unknown error")),g(!1),y(null)}},onCancel:()=>{g(!1),y(null)},confirmText:"user-override"===h?.source?"Revert":"Delete",cancelText:"Cancel",confirmColor:"user-override"===h?.source?"warning":"error"}))},gt=({providersData:t,rootProvider:a,onSelectionChange:r,existingDimensions:n=[],existingMetrics:l=[],existingFilters:o={}})=>{const[i,s]=e.useState([]);e.useEffect(()=>{s([]),r&&r([])},[a]);const d=e=>{if(!t||!e)return[];const a=t[e];if(!a||!a.relations||0===a.relations.length)return[];const r=(()=>{const e=new Map,t=t=>{if(t.relations&&t.providerPath)for(let a=0;a<t.relations.length;a++){const r=t.relations[a],n=t.providerPath[a];r.type&&(e.has(n)||e.set(n,new Set),e.get(n).add(r.name))}};return n.forEach(t),l.forEach(t),Object.values(o).forEach(t),e})().get(e);return a.relations.filter(e=>t[e.target]).map(e=>{let t=!1,a=null;if(!!e.type&&r&&r.size>0){if(!r.has(e.name)&&r.size>0){t=!0;a=`Cannot select: '${Array.from(r)[0]}' is already in use`}}return{key:e.name,value:e.name,targetKey:e.target,disabled:t,disabledReason:a}})},c=(e,t)=>{const n=t.target.value,l=0===e?a:i[e-1].targetKey,o=d(l).find(e=>e.key===n);if(!o)return;const c=i.slice(0,e);c.push({providerKey:n,relationName:n,targetKey:o.targetKey}),s(c),console.log("Selection chain:",c),r&&r(c)};return X.default.createElement(m.Box,null,i.length>0&&X.default.createElement(m.Box,{sx:{marginBottom:2}},X.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",gap:1.5,flexWrap:"wrap"}},X.default.createElement(m.Chip,{label:et(a),size:"medium",variant:"outlined",sx:{fontWeight:600,borderColor:"rgb(70, 134, 128)",color:"rgb(70, 134, 128)",backgroundColor:"white",height:"32px",fontFamily:"system-ui"}}),i.map((e,t)=>X.default.createElement(X.default.Fragment,{key:t},X.default.createElement(m.Typography,{variant:"body2",sx:{color:"#9e9e9e",fontWeight:"bold"}},"→"),X.default.createElement(m.Chip,{label:et(e.targetKey),size:"medium",onDelete:()=>(e=>{const t=i.slice(0,e);s(t),r&&r(t)})(t),sx:{fontWeight:500,backgroundColor:"rgb(70, 134, 128)",color:"white",height:"32px",fontFamily:"system-ui","& .MuiChip-deleteIcon":{color:"rgba(255, 255, 255, 0.7)","&:hover":{color:"white"}}}}))))),X.default.createElement("div",{style:{display:"flex",flexWrap:"wrap",alignItems:"flex-start",gap:"16px"}},(()=>{if(!t||!a)return null;const e=[],r=d(a);r.length>0&&e.push(X.default.createElement("div",{key:"level-0",style:{marginRight:"16px"}},X.default.createElement(tt,{items:r,value:i[0]?.providerKey||"",label:`Related to ${a}`,onChange:e=>c(0,e),sx:{width:"300px"}})));for(let t=0;t<i.length;t++){const a=i[t],r=d(a.targetKey);if(r.length>0){const n=i[t+1];e.push(X.default.createElement("div",{key:`level-${t+1}`,style:{marginRight:"16px"}},X.default.createElement(tt,{items:r,value:n?.providerKey||"",label:`Related to ${a.targetKey}`,onChange:e=>c(t+1,e),sx:{width:"300px"}})))}}return e})()))},ht=({id:t,label:a,fullLabel:r,onDelete:n,onMoveUp:l,onMoveDown:o,isFirst:i,isLast:s,sortOrder:d,onSortOrderChange:c,fullPath:u,defaultTitle:f,customTitle:p,onUpdateTitle:g,onResetTitle:h})=>{const[y,x]=e.useState(!1),[b,E]=e.useState(""),v=e.useRef(null),w=e.useRef(null),{attributes:C,listeners:k,setNodeRef:T,transform:R,transition:D,isDragging:B}=I.useSortable({id:t}),P={transform:q.CSS.Transform.toString(R),transition:D,opacity:B?.5:1,display:"flex",alignItems:"center",width:"100%"};e.useEffect(()=>{y&&v.current&&(v.current.focus(),v.current.select())},[y]),e.useEffect(()=>{const e=e=>{y&&w.current&&!w.current.contains(e.target)&&F()};if(y)return document.addEventListener("mousedown",e),()=>{document.removeEventListener("mousedown",e)}},[y]);const z=()=>{const e=b.trim();""!==e?(g(u,e),x(!1)):F()},F=()=>{x(!1),E("")},M=p||a,$=!!p;return X.default.createElement("div",Ae({ref:T,style:P},C),X.default.createElement(m.Box,{ref:w,sx:{display:"flex",alignItems:"center",width:"100%",gap:1,backgroundColor:"white",border:"1px solid #e0e0e0",borderRadius:2,padding:1,transition:"transform 0.2s ease, box-shadow 0.2s ease","&:hover .hover-icons":{opacity:1}}},X.default.createElement(m.Box,Ae({},k,{sx:{display:"flex",alignItems:"center",cursor:"grab","&:active":{cursor:"grabbing"}}}),X.default.createElement(Te.default,{sx:{cursor:"grab",color:"rgba(110, 110, 110, 0.62)"}})),y?X.default.createElement(X.default.Fragment,null,X.default.createElement(m.TextField,{inputRef:v,value:b,onChange:e=>E(e.target.value),onKeyDown:e=>{"Enter"===e.key?z():"Escape"===e.key&&F()},size:"small",sx:{minWidth:"200px",maxWidth:"400px"}}),X.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:1}},X.default.createElement(m.Tooltip,{title:"Save",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:z,color:"primary","aria-label":"save title"},X.default.createElement(Pe.default,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:"Cancel",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:F,"aria-label":"cancel edit"},X.default.createElement(ze.default,{fontSize:"small"}))),$&&X.default.createElement(m.Tooltip,{title:"Reset to default",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:()=>{h(u),x(!1),E("")},color:"warning","aria-label":"reset title"},X.default.createElement(Fe.default,{fontSize:"small"})))),X.default.createElement(m.Box,{sx:{flex:1}})):X.default.createElement(X.default.Fragment,null,X.default.createElement(m.Box,{sx:{minWidth:0}},X.default.createElement(m.Tooltip,{title:r||M,arrow:!0,placement:"top"},X.default.createElement(m.Typography,{variant:"h6",sx:{fontWeight:$?600:500,fontStyle:$?"italic":"normal",color:"#1a1a1a",fontSize:"14px",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"}},M))),X.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},X.default.createElement(m.Tooltip,{title:"Edit title",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:()=>{E(p||f),x(!0)},"aria-label":"edit title"},X.default.createElement(xe.default,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:null===d?"No sort":"asc"===d?"Ascending":"Descending",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:()=>{c(null===d?"asc":"asc"===d?"desc":null)},"aria-label":"toggle sort order",color:d?"primary":"default"},"asc"===d?X.default.createElement(Re.default,{fontSize:"small"}):"desc"===d?X.default.createElement(De.default,{fontSize:"small"}):X.default.createElement(Be.default,{fontSize:"small",sx:{opacity:.3}}))),X.default.createElement(m.Tooltip,{title:"Delete",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:n,"aria-label":"delete",sx:{color:"#ef5350"}},X.default.createElement(S.GridDeleteIcon,{fontSize:"small"})))),X.default.createElement(m.Box,{sx:{flex:1}}),X.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},X.default.createElement(m.IconButton,{size:"small",onClick:l,disabled:i,"aria-label":"move up"},X.default.createElement(Re.default,{fontSize:"small"})),X.default.createElement(m.IconButton,{size:"small",onClick:o,disabled:s,"aria-label":"move down"},X.default.createElement(De.default,{fontSize:"small"}))))))},yt=({providersData:t,rootProvider:a,savedDimensions:r=[],onSaveDimension:n,onRemoveDimension:l,onReorderDimensions:o,titleOverrides:i={},onUpdateTitle:s,onResetTitle:d,existingMetrics:c=[],existingFilters:u={}})=>{const[f,p]=e.useState(!1),[g,h]=e.useState([]),[y,x]=e.useState(""),b=M.useSensors(M.useSensor(M.PointerSensor),M.useSensor(M.KeyboardSensor,{coordinateGetter:I.sortableKeyboardCoordinates})),E=()=>{const e=a?0===g.length?a:g[g.length-1].targetKey:null;if(!e||!t||!t[e])return[];const n=t[e];if(!n.dimensions)return[];const l=[t[a].default_alias];let o=a;g.forEach(e=>{const a=t[o];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&l.push(t.alias)}o=e.targetKey});const i=new Set(r.map(e=>e.fullPath)),s=[];return Object.keys(n.dimensions).forEach(t=>{const a=n.dimensions[t];Object.keys(a).forEach(r=>{const n=a[r],o=`${l.join("_")}.${r}`,d=i.has(o);s.push({key:`${e}_${t}.${r}`,value:n.title||r,dimensionKey:r,alias:t,dimension:n,disabled:d})})}),s},v=()=>{p(!1),h([]),x("")},w=e=>{const t=[a];return e.relationNames&&e.relationNames.length>0&&t.push(...e.relationNames),t.join(" → ")};return X.default.createElement("div",null,X.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-start",mb:2}},!f&&X.default.createElement(m.Button,{variant:"contained",startIcon:X.default.createElement(S.GridAddIcon,null),onClick:()=>{p(!0),h([]),x("")},sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",textTransform:"none",backgroundColor:"rgb(70, 134, 128)",boxShadow:"none","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Add Dimension")),f&&X.default.createElement(m.Paper,{elevation:0,sx:{p:3,mb:3,border:"1px solid #e0e0e0",borderRadius:"12px",backgroundColor:"white",boxShadow:"0px 2px 4px rgba(0,0,0,0.02)",fontFamily:"system-ui"}},X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Provider Path"),X.default.createElement(m.Box,{sx:{mb:3}},X.default.createElement(gt,{providersData:t,rootProvider:a,onSelectionChange:h,existingDimensions:r,existingMetrics:c,existingFilters:u})),X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Dimension"),X.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",gap:2,mb:3}},X.default.createElement(tt,{items:E(),value:y,label:"Choose Dimension",onChange:e=>{x(e.target.value)},sx:{width:"400px",fontFamily:"system-ui"}}),X.default.createElement(m.Tooltip,{title:"Add all available dimensions",arrow:!0,placement:"top"},X.default.createElement("span",null,X.default.createElement(m.IconButton,{onClick:()=>{const e=E().filter(e=>!e.disabled);if(0===e.length)return;const r=[],l=[a],o=[];let i=a;g.forEach(e=>{const a=t[i];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(r.push(t),o.push(t.name))}l.push(e.targetKey),i=e.targetKey});const s=[t[a].default_alias];r.forEach(e=>{s.push(e.alias)}),e.forEach(e=>{const t=`${s.join("_")}.${e.dimensionKey}`,a={dimension:e.dimension,relations:r,providerPath:l,relationNames:o,dimensionKey:e.dimensionKey,dimensionTitle:e.value,fullPath:t};n(a)}),v()},disabled:0===E().filter(e=>!e.disabled).length,"aria-label":"add all dimensions",sx:{color:"rgb(70, 134, 128)",border:"1px solid #e0e0e0",borderRadius:"8px",padding:"8px","&:hover":{backgroundColor:"#f5f5f5"},"&.Mui-disabled":{opacity:.5}}},X.default.createElement(Me.default,null))))),X.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-end",gap:2,mt:3}},X.default.createElement(m.Button,{variant:"outlined",onClick:v,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",borderColor:"#e0e0e0",color:"rgb(37, 37, 37)",textTransform:"none","&:hover":{backgroundColor:"#f5f5f5",borderColor:"#d0d0d0"}}},"Cancel"),X.default.createElement(m.Button,{variant:"contained",onClick:()=>{if(!y)return;const e=E().find(e=>e.key===y);if(!e)return;const r=[],l=[a],o=[];let i=a;g.forEach(e=>{const a=t[i];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(r.push(t),o.push(t.name))}l.push(e.targetKey),i=e.targetKey});const s=[t[a].default_alias];r.forEach(e=>{s.push(e.alias)});const d=`${s.join("_")}.${e.dimensionKey}`,c={dimension:e.dimension,relations:r,providerPath:l,relationNames:o,dimensionKey:e.dimensionKey,dimensionTitle:e.value,fullPath:d};n(c),v()},disabled:!y,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",textTransform:"none",backgroundColor:"rgb(70, 134, 128)","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Save Dimension"))),r.length>0&&X.default.createElement(m.Box,{sx:{marginTop:0}},X.default.createElement(m.Typography,{variant:"h6",sx:{fontSize:"16px",fontWeight:600,marginTop:2,color:"rgb(37, 37, 37)"}},"Saved Dimensions"),X.default.createElement(m.Typography,{sx:{fontSize:"13px",color:"#666",marginBottom:2}},"Drag to reorder or use arrows"),X.default.createElement(M.DndContext,{sensors:b,collisionDetection:M.closestCenter,onDragEnd:e=>{const{active:t,over:a}=e;if(a&&t.id!==a.id){const e=r.findIndex((e,a)=>a===t.id),n=r.findIndex((e,t)=>t===a.id),l=I.arrayMove(r,e,n);o(l)}}},X.default.createElement(I.SortableContext,{items:r.map((e,t)=>t),strategy:I.verticalListSortingStrategy},X.default.createElement(m.Box,{sx:{display:"flex",flexDirection:"column",gap:1}},r.map((e,t)=>X.default.createElement(ht,{key:t,id:t,label:e.dimensionTitle,fullLabel:`${w(e)} → ${e.dimensionTitle} (${e.fullPath})`,onDelete:()=>l(t),onMoveUp:()=>(e=>{if(e>0){const t=I.arrayMove(r,e,e-1);o(t)}})(t),onMoveDown:()=>(e=>{if(e<r.length-1){const t=I.arrayMove(r,e,e+1);o(t)}})(t),isFirst:0===t,isLast:t===r.length-1,sortOrder:e.sortOrder||null,onSortOrderChange:e=>((e,t)=>{const a=[...r];a[e]={...a[e],sortOrder:t},o(a)})(t,e),fullPath:e.fullPath,defaultTitle:e.dimensionTitle,customTitle:i[e.fullPath],onUpdateTitle:s,onResetTitle:d})))))))},xt=({id:t,label:a,fullLabel:r,onDelete:n,onMoveUp:l,onMoveDown:o,isFirst:i,isLast:s,fullPath:d,defaultTitle:c,customTitle:u,onUpdateTitle:f,onResetTitle:p})=>{const[g,h]=e.useState(!1),[y,x]=e.useState(""),b=e.useRef(null),E=e.useRef(null),{attributes:v,listeners:w,setNodeRef:C,transform:k,transition:T,isDragging:R}=I.useSortable({id:t}),D={transform:q.CSS.Transform.toString(k),transition:T,opacity:R?.5:1,display:"flex",alignItems:"center",width:"100%"};e.useEffect(()=>{g&&b.current&&(b.current.focus(),b.current.select())},[g]),e.useEffect(()=>{const e=e=>{g&&E.current&&!E.current.contains(e.target)&&P()};if(g)return document.addEventListener("mousedown",e),()=>{document.removeEventListener("mousedown",e)}},[g]);const B=()=>{const e=y.trim();""!==e?(f(d,e),h(!1)):P()},P=()=>{h(!1),x("")},z=u||a,F=!!u;return X.default.createElement("div",Ae({ref:C,style:D},v),X.default.createElement(m.Box,{ref:E,sx:{display:"flex",alignItems:"center",width:"100%",gap:1,backgroundColor:"white",border:"1px solid #e0e0e0",borderRadius:2,padding:1,transition:"transform 0.2s ease, box-shadow 0.2s ease","&:hover .hover-icons":{opacity:1}}},X.default.createElement(m.Box,Ae({},w,{sx:{display:"flex",alignItems:"center",cursor:"grab","&:active":{cursor:"grabbing"}}}),X.default.createElement(Te.default,{sx:{cursor:"grab",color:"rgba(110, 110, 110, 0.62)"}})),g?X.default.createElement(X.default.Fragment,null,X.default.createElement(m.TextField,{inputRef:b,value:y,onChange:e=>x(e.target.value),onKeyDown:e=>{"Enter"===e.key?B():"Escape"===e.key&&P()},size:"small",sx:{minWidth:"200px",maxWidth:"400px"}}),X.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:1}},X.default.createElement(m.Tooltip,{title:"Save",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:B,color:"primary","aria-label":"save title"},X.default.createElement(Pe.default,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:"Cancel",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:P,"aria-label":"cancel edit"},X.default.createElement(ze.default,{fontSize:"small"}))),F&&X.default.createElement(m.Tooltip,{title:"Reset to default",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:()=>{p(d),h(!1),x("")},color:"warning","aria-label":"reset title"},X.default.createElement(Fe.default,{fontSize:"small"})))),X.default.createElement(m.Box,{sx:{flex:1}})):X.default.createElement(X.default.Fragment,null,X.default.createElement(m.Box,{sx:{minWidth:0}},X.default.createElement(m.Tooltip,{title:r||z,arrow:!0,placement:"top"},X.default.createElement(m.Typography,{variant:"h6",sx:{fontWeight:F?600:500,fontStyle:F?"italic":"normal",color:"#1a1a1a",fontSize:"14px",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"}},z))),X.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},X.default.createElement(m.Tooltip,{title:"Edit title",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:()=>{x(u||c),h(!0)},"aria-label":"edit title"},X.default.createElement(xe.default,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:"Delete",arrow:!0,placement:"top"},X.default.createElement(m.IconButton,{size:"small",onClick:n,"aria-label":"delete",sx:{color:"#ef5350"}},X.default.createElement(S.GridDeleteIcon,{fontSize:"small"})))),X.default.createElement(m.Box,{sx:{flex:1}}),X.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},X.default.createElement(m.IconButton,{size:"small",onClick:l,disabled:i,"aria-label":"move up"},X.default.createElement(Re.default,{fontSize:"small"})),X.default.createElement(m.IconButton,{size:"small",onClick:o,disabled:s,"aria-label":"move down"},X.default.createElement(De.default,{fontSize:"small"}))))))},bt=({providersData:t,rootProvider:a,savedMetrics:r=[],onSaveMetric:n,onRemoveMetric:l,onReorderMetrics:o,titleOverrides:i={},onUpdateTitle:s,onResetTitle:d,existingDimensions:c=[],existingFilters:u={}})=>{const[f,p]=e.useState(!1),[g,h]=e.useState([]),[y,x]=e.useState(""),b=M.useSensors(M.useSensor(M.PointerSensor),M.useSensor(M.KeyboardSensor,{coordinateGetter:I.sortableKeyboardCoordinates})),E=()=>{const e=a?0===g.length?a:g[g.length-1].targetKey:null;if(!e||!t||!t[e])return[];const n=t[e];if(!n.metrics)return[];const l=[t[a].default_alias];let o=a;g.forEach(e=>{const a=t[o];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&l.push(t.alias)}o=e.targetKey});const i=new Set(r.map(e=>e.fullPath)),s=n.metrics.map((t,a)=>{const r=`${l.join("_")}.${t.name}`,n=i.has(r);return{key:`${e}_${t.name}_${a}`,value:t.title||t.name,metricName:t.name,metric:t,disabled:n}});return s},v=()=>{p(!1),h([]),x("")},w=e=>{const t=[a];return e.relationNames&&e.relationNames.length>0&&t.push(...e.relationNames),t.join(" → ")};return X.default.createElement("div",null,X.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-start",mb:2}},!f&&X.default.createElement(m.Button,{variant:"contained",startIcon:X.default.createElement(S.GridAddIcon,null),onClick:()=>{p(!0),h([]),x("")},sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",textTransform:"none",backgroundColor:"rgb(70, 134, 128)",boxShadow:"none","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Add Metric")),f&&X.default.createElement(m.Paper,{elevation:0,sx:{p:3,mb:3,border:"1px solid #e0e0e0",borderRadius:"12px",backgroundColor:"white",boxShadow:"0px 2px 4px rgba(0,0,0,0.02)",fontFamily:"system-ui"}},X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Provider Path"),X.default.createElement(m.Box,{sx:{mb:3}},X.default.createElement(gt,{providersData:t,rootProvider:a,onSelectionChange:h,existingDimensions:c,existingMetrics:r,existingFilters:u})),X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Metric"),X.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",gap:2,mb:3}},X.default.createElement(tt,{items:E(),value:y,label:"Choose Metric",onChange:e=>{x(e.target.value)},sx:{width:"400px",fontFamily:"system-ui"}}),X.default.createElement(m.Tooltip,{title:"Add all available metrics",arrow:!0,placement:"top"},X.default.createElement("span",null,X.default.createElement(m.IconButton,{onClick:()=>{const e=E().filter(e=>!e.disabled);if(0===e.length)return;const r=[],l=[a],o=[];let i=a;g.forEach(e=>{const a=t[i];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(r.push(t),o.push(t.name))}l.push(e.targetKey),i=e.targetKey});const s=[t[a].default_alias];r.forEach(e=>{s.push(e.alias)}),e.forEach(e=>{const t=`${s.join("_")}.${e.metricName}`,a={metric:e.metric,relations:r,providerPath:l,relationNames:o,metricName:e.metricName,metricTitle:e.value,fullPath:t};n(a)}),v()},disabled:0===E().filter(e=>!e.disabled).length,"aria-label":"add all metrics",sx:{color:"rgb(70, 134, 128)",border:"1px solid #e0e0e0",borderRadius:"8px",padding:"8px","&:hover":{backgroundColor:"#f5f5f5"},"&.Mui-disabled":{opacity:.5}}},X.default.createElement(Me.default,null))))),X.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-end",gap:2,mt:3}},X.default.createElement(m.Button,{variant:"outlined",onClick:v,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",borderColor:"#e0e0e0",color:"rgb(37, 37, 37)",textTransform:"none","&:hover":{backgroundColor:"#f5f5f5",borderColor:"#d0d0d0"}}},"Cancel"),X.default.createElement(m.Button,{variant:"contained",onClick:()=>{if(!y)return;const e=E().find(e=>e.key===y);if(!e)return;const r=[],l=[a],o=[];let i=a;g.forEach(e=>{const a=t[i];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(r.push(t),o.push(t.name))}l.push(e.targetKey),i=e.targetKey});const s=[t[a].default_alias];r.forEach(e=>{s.push(e.alias)});const d=`${s.join("_")}.${e.metricName}`,c={metric:e.metric,relations:r,providerPath:l,relationNames:o,metricName:e.metricName,metricTitle:e.value,fullPath:d};n(c),v()},disabled:!y,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",textTransform:"none",backgroundColor:"rgb(70, 134, 128)","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Save Metric"))),r.length>0&&X.default.createElement(m.Box,{sx:{marginTop:0}},X.default.createElement(m.Typography,{variant:"h6",sx:{fontSize:"16px",fontWeight:600,marginBottom:1,color:"rgb(37, 37, 37)"}},"Saved Metrics"),X.default.createElement(M.DndContext,{sensors:b,collisionDetection:M.closestCenter,onDragEnd:e=>{const{active:t,over:a}=e;if(a&&t.id!==a.id){const e=r.findIndex((e,a)=>a===t.id),n=r.findIndex((e,t)=>t===a.id),l=I.arrayMove(r,e,n);o(l)}}},X.default.createElement(I.SortableContext,{items:r.map((e,t)=>t),strategy:I.verticalListSortingStrategy},X.default.createElement(m.Box,{sx:{display:"flex",flexDirection:"column",gap:1}},r.map((e,t)=>X.default.createElement(xt,{key:t,id:t,label:e.metricTitle,fullLabel:`${w(e)} → ${e.metricTitle} (${e.fullPath})`,onDelete:()=>l(t),onMoveUp:()=>(e=>{if(e>0){const t=I.arrayMove(r,e,e-1);o(t)}})(t),onMoveDown:()=>(e=>{if(e<r.length-1){const t=I.arrayMove(r,e,e+1);o(t)}})(t),isFirst:0===t,isLast:t===r.length-1,fullPath:e.fullPath,defaultTitle:e.metricTitle,customTitle:i[e.fullPath],onUpdateTitle:s,onResetTitle:d})))))))},Et=({providersData:t,rootProvider:a,savedFilters:r={},onSaveFilter:n,onRemoveFilter:l,existingDimensions:o=[],existingMetrics:i=[],titleOverrides:s={},dimensionTitleOverrides:d={},onUpdateTitle:c,onResetTitle:u})=>{const f=dt(),[p,g]=e.useState(!1),[h,y]=e.useState(!1),[x,b]=e.useState([]),[E,v]=e.useState(""),[w,C]=e.useState(""),[k,T]=e.useState([]),[R,D]=e.useState([]),[B,P]=e.useState(!1),[z,F]=e.useState(null),[M,I]=e.useState(null),[q,$]=e.useState(null),[A,O]=e.useState(null),[j,_]=e.useState("");e.useEffect(()=>{v(""),T([]),D([]),I(null),$(null)},[x]);const W=e=>e&&("date"===e.type||"timestamp"===e.type),N=()=>{const e=a?0===x.length?a:x[x.length-1].targetKey:null;if(!e||!t||!t[e])return[];const r=t[e];if(!r.dimensions)return[];const n=[];return Object.keys(r.dimensions).forEach(t=>{const a=r.dimensions[t];Object.keys(a).forEach(r=>{const l=a[r];l.column&&n.push({key:`${e}_${t}.${r}`,value:l.title||r,dimensionKey:r,alias:t,dimension:l})})}),n},K=()=>{g(!1),y(!1),b([]),v(""),C(""),T([]),D([]),I(null),$(null),F(null)},U=()=>{F(null),T([]),D([]),I(null),$(null)},Y=e=>{const t=j.trim();""!==t?(c(e,t),O(null),_("")):V()},V=()=>{O(null),_("")},Z=async e=>{P(!0);try{const t={provider:a,doc:{query:{dimensions:[e],metrics:[],order_by:[{name:e}]}},parameters:f?.parameters||{base_currency:"EUR"}};console.log("Fetching filter values with payload:",t);const r=await Ye.runAdHocReport({report:t});console.log("Filter values results:",r);const n=(Array.isArray(r)?r:r.data||[]).map(t=>{let a=t[e];if(void 0===a){a=t[e.replace(/\./g,"_")]}if(void 0===a){const e=Object.keys(t);e.length>0&&(a=t[e[0]])}return{key:String(a),value:String(a)}});console.log("Transformed distinct values:",n),T(n)}catch(e){console.error("Error fetching filter values:",e),T([])}finally{P(!1)}},J=e=>{const t=[a];return e.relationNames&&e.relationNames.length>0&&t.push(...e.relationNames),t.join(" → ")},Q=Object.entries(r);return X.default.createElement("div",null,X.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-start",gap:2,mb:2}},!p&&!h&&X.default.createElement(X.default.Fragment,null,o.length>0&&X.default.createElement(m.Button,{variant:"contained",startIcon:X.default.createElement(Ie.default,null),onClick:()=>{y(!0),g(!1),C(""),T([]),D([]),I(null),$(null),F(null)},sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",textTransform:"none",backgroundColor:"rgb(70, 134, 128)",boxShadow:"none","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Add Filter"),X.default.createElement(m.Button,{variant:"outlined",startIcon:X.default.createElement(S.GridAddIcon,null),onClick:()=>{g(!0),y(!1),b([]),v(""),C(""),T([]),D([]),I(null),$(null),F(null)},sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",textTransform:"none",borderColor:"rgb(70, 134, 128)",color:"rgb(70, 134, 128)",boxShadow:"none","&:hover":{backgroundColor:"rgba(70, 134, 128, 0.04)",borderColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Add Advanced Filter"))),p&&X.default.createElement(m.Paper,{elevation:0,sx:{p:3,mb:3,border:"1px solid #e0e0e0",borderRadius:"12px",backgroundColor:"white",boxShadow:"0px 2px 4px rgba(0,0,0,0.02)",fontFamily:"system-ui"}},X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Provider Path"),X.default.createElement(m.Box,{sx:{mb:3}},X.default.createElement(gt,{providersData:t,rootProvider:a,onSelectionChange:b,existingDimensions:o,existingMetrics:i,existingFilters:r})),X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Dimension for Filter"),X.default.createElement(m.Box,{sx:{mb:3}},X.default.createElement(tt,{items:N(),value:E,label:"Choose Dimension",onChange:e=>{const r=e.target.value;if(v(r),D([]),I(null),$(null),r){const e=N().find(e=>e.key===r);if(e){if(!W(e.dimension)){const r=[];let n=a;x.forEach(e=>{const a=t[n];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&r.push(t)}n=e.targetKey});const l=[t[a].default_alias];r.forEach(e=>{l.push(e.alias)});const o=`${l.join("_")}.${e.dimensionKey}`;Z(o)}}}else T([])},sx:{width:"400px",fontFamily:"system-ui"}})),E&&(()=>{const e=N().find(e=>e.key===E),t=e&&W(e.dimension);return X.default.createElement(X.default.Fragment,null,X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,mt:3,color:"rgb(37, 37, 37)"}},t?"Select Date Range":"Select Filter Values"),t?X.default.createElement(L.LocalizationProvider,{dateAdapter:H.AdapterDayjs},X.default.createElement(m.Box,{sx:{display:"flex",gap:2,width:"400px"}},X.default.createElement(G.DatePicker,{label:"From Date",value:M,onChange:e=>I(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}),X.default.createElement(G.DatePicker,{label:"To Date",value:q,onChange:e=>$(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}))):X.default.createElement(m.Box,{sx:{width:"400px"}},X.default.createElement(Qe,{items:k,selectedKeys:R,onChange:e=>D(e),label:"Choose Values",placeholder:"Select one or more values...",loading:B,helperText:R.length>0?`${R.length} value(s) selected`:"Select at least one value"})))})(),X.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-end",gap:2,mt:3}},X.default.createElement(m.Button,{variant:"outlined",onClick:K,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",borderColor:"#e0e0e0",color:"rgb(37, 37, 37)",textTransform:"none","&:hover":{backgroundColor:"#f5f5f5",borderColor:"#d0d0d0"}}},"Cancel"),X.default.createElement(m.Button,{variant:"contained",onClick:()=>{const e=N().find(e=>e.key===E);if(!e)return;const r=W(e.dimension);if(r){if(!M&&!q)return}else if(0===R.length)return;if(!E)return;const l=[],o=[a],i=[];let s=a;x.forEach(e=>{const a=t[s];if(a&&a.relations){const t=a.relations.find(t=>t.name===e.relationName);t&&(l.push(t),i.push(t.name))}o.push(e.targetKey),s=e.targetKey});const d=[t[a].default_alias];l.forEach(e=>{d.push(e.alias)});const c=`${d.join("_")}.${e.dimensionKey}`;let u;r?(u={},M&&(u.gte=M.format("YYYY-MM-DD")),q&&(u.lte=q.format("YYYY-MM-DD"))):u=R;const f={dimension:e.dimension,relations:l,providerPath:o,relationNames:i,dimensionKey:e.dimensionKey,dimensionTitle:e.value,fullPath:c,values:u};n(c,f),K()},disabled:(()=>{if(!E)return!0;const e=N().find(e=>e.key===E);if(!e)return!0;return W(e.dimension)?!M&&!q:0===R.length})(),sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",textTransform:"none",backgroundColor:"rgb(70, 134, 128)","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Save Filter"))),h&&X.default.createElement(m.Paper,{elevation:0,sx:{p:3,mb:3,border:"1px solid #e0e0e0",borderRadius:"12px",backgroundColor:"white",boxShadow:"0px 2px 4px rgba(0,0,0,0.02)",fontFamily:"system-ui"}},X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,color:"rgb(37, 37, 37)"}},"Select Dimension from Report"),X.default.createElement(m.Box,{sx:{mb:3}},X.default.createElement(tt,{items:o.map(e=>({key:e.fullPath,value:d[e.fullPath]||e.dimensionTitle})),value:w,label:"Choose Dimension",onChange:e=>{const t=e.target.value;if(C(t),D([]),I(null),$(null),t){const e=o.find(e=>e.fullPath===t);if(e){W(e.dimension)||Z(t)}}else T([])},sx:{width:"400px",fontFamily:"system-ui"}})),w&&(()=>{const e=o.find(e=>e.fullPath===w),t=e&&W(e.dimension);return X.default.createElement(X.default.Fragment,null,X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1.5,mt:3,color:"rgb(37, 37, 37)"}},t?"Select Date Range":"Select Filter Values"),t?X.default.createElement(L.LocalizationProvider,{dateAdapter:H.AdapterDayjs},X.default.createElement(m.Box,{sx:{display:"flex",gap:2,width:"400px"}},X.default.createElement(G.DatePicker,{label:"From Date",value:M,onChange:e=>I(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}),X.default.createElement(G.DatePicker,{label:"To Date",value:q,onChange:e=>$(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}))):X.default.createElement(m.Box,{sx:{width:"400px"}},X.default.createElement(Qe,{items:k,selectedKeys:R,onChange:e=>D(e),label:"Choose Values",placeholder:"Select one or more values...",loading:B,helperText:R.length>0?`${R.length} value(s) selected`:"Select at least one value"})))})(),X.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"flex-end",gap:2,mt:3}},X.default.createElement(m.Button,{variant:"outlined",onClick:K,sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",borderColor:"#e0e0e0",color:"rgb(37, 37, 37)",textTransform:"none","&:hover":{backgroundColor:"#f5f5f5",borderColor:"#d0d0d0"}}},"Cancel"),X.default.createElement(m.Button,{variant:"contained",onClick:()=>{if(!w)return;const e=o.find(e=>e.fullPath===w);if(!e)return;const t=W(e.dimension);if(t){if(!M&&!q)return}else if(0===R.length)return;let a;t?(a={},M&&(a.gte=M.format("YYYY-MM-DD")),q&&(a.lte=q.format("YYYY-MM-DD"))):a=R;const r={dimension:e.dimension,relations:e.relations,providerPath:e.providerPath,relationNames:e.relationNames,dimensionKey:e.dimensionKey,dimensionTitle:e.dimensionTitle,fullPath:e.fullPath,values:a};n(e.fullPath,r),K()},disabled:(()=>{if(!w)return!0;const e=o.find(e=>e.fullPath===w);if(!e)return!0;return W(e.dimension)?!M&&!q:0===R.length})(),sx:{height:"40px",fontFamily:"system-ui",fontSize:"14px",fontWeight:500,borderRadius:"8px",boxShadow:"none",textTransform:"none",backgroundColor:"rgb(70, 134, 128)","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Save Filter"))),Q.length>0&&X.default.createElement(m.Box,{sx:{marginTop:0}},X.default.createElement(m.Typography,{variant:"h6",sx:{fontSize:"16px",fontWeight:600,marginBottom:1,color:"rgb(37, 37, 37)"}},"Saved Filters"),X.default.createElement(m.Box,{sx:{display:"flex",flexDirection:"column",gap:1}},Q.map(([e,t])=>{const a=W(t.dimension),o=z===e,i=A===e;let c,f;a&&t.values&&"object"==typeof t.values&&!Array.isArray(t.values)?f=t.values.gte&&t.values.lte?`${t.values.gte} to ${t.values.lte}`:t.values.gte?`From ${t.values.gte}`:t.values.lte?`Until ${t.values.lte}`:"No dates":(c=t.values?.length||0,f=t.values?.join(", ")||"No values");const p=s[e]||d[e]||t.dimensionTitle,h=!!s[e];return X.default.createElement(m.Box,{key:e},X.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",width:"100%",gap:1,backgroundColor:"white",border:"1px solid #e0e0e0",borderRadius:2,padding:2,boxSizing:"border-box",transition:"box-shadow 0.2s ease","&:hover .hover-icons":{opacity:1}}},i?X.default.createElement(X.default.Fragment,null,X.default.createElement(m.TextField,{value:j,onChange:e=>_(e.target.value),onKeyDown:t=>((e,t)=>{"Enter"===e.key?Y(t):"Escape"===e.key&&V()})(t,e),size:"small",autoFocus:!0,placeholder:"Enter custom title",sx:{flex:1}}),X.default.createElement(m.Box,{sx:{display:"flex",gap:.5}},X.default.createElement(m.Tooltip,{title:"Save",arrow:!0},X.default.createElement(m.IconButton,{size:"small",onClick:()=>Y(e),color:"primary"},X.default.createElement(Pe.default,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:"Cancel",arrow:!0},X.default.createElement(m.IconButton,{size:"small",onClick:V},X.default.createElement(ze.default,{fontSize:"small"}))),h&&X.default.createElement(m.Tooltip,{title:"Reset to default",arrow:!0},X.default.createElement(m.IconButton,{size:"small",onClick:()=>(e=>{u(e),O(null),_("")})(e),color:"warning"},X.default.createElement(Fe.default,{fontSize:"small"}))))):X.default.createElement(X.default.Fragment,null,X.default.createElement(m.Box,{sx:{display:"flex",alignItems:"center",gap:1,flex:1,minWidth:0}},X.default.createElement(m.Typography,{variant:"h6",sx:{fontWeight:h?600:500,fontStyle:h?"italic":"normal",color:"#1a1a1a",fontSize:"14px"}},p),X.default.createElement(m.Box,{className:"hover-icons",sx:{display:"flex",gap:.5,opacity:0,transition:"opacity 0.2s"}},X.default.createElement(m.Tooltip,{title:"Rename filter",arrow:!0},X.default.createElement(m.IconButton,{size:"small",onClick:()=>((e,t)=>{O(e),_(s[e]||t||"")})(e,d[e]||t.dimensionTitle),disabled:o},X.default.createElement(xe.default,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:"Edit filter values",arrow:!0},X.default.createElement(m.IconButton,{size:"small",onClick:()=>(async(e,t)=>{g(!1),F(e),W(t.dimension)?t.values&&"object"==typeof t.values&&!Array.isArray(t.values)&&(I(t.values.gte?$e.default(t.values.gte):null),$(t.values.lte?$e.default(t.values.lte):null)):(D(t.values||[]),await Z(e))})(e,t),disabled:o},X.default.createElement(Ie.default,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:"Remove filter",arrow:!0},X.default.createElement(m.IconButton,{size:"small",onClick:()=>l(e),sx:{color:"#ef5350"}},X.default.createElement(S.GridDeleteIcon,{fontSize:"small"}))),X.default.createElement(m.Tooltip,{title:X.default.createElement("div",null,X.default.createElement("div",null,X.default.createElement("strong",null,"Path:")," ",J(t)," → ",d[e]||t.dimensionTitle),X.default.createElement("div",null,X.default.createElement("strong",null,"Full Path:")," ",e),X.default.createElement("div",null,X.default.createElement("strong",null,a?"Date Range":`Values (${c})`,":")," ",f)),arrow:!0,placement:"right"},X.default.createElement(m.IconButton,{size:"small",disabled:o},X.default.createElement(qe.default,{fontSize:"small",sx:{color:"#757575"}}))))))),o&&X.default.createElement(m.Paper,{elevation:0,sx:{p:2,mt:1,ml:2,border:"1px solid #e0e0e0",borderRadius:"8px",backgroundColor:"#fafafa"}},X.default.createElement(m.Typography,{variant:"subtitle2",sx:{marginBottom:1.5,fontWeight:600}},"Edit ",a?"Date Range":"Values"," for: ",d[e]||t.dimensionTitle),a?X.default.createElement(L.LocalizationProvider,{dateAdapter:H.AdapterDayjs},X.default.createElement(m.Box,{sx:{display:"flex",gap:2,width:"400px",marginBottom:2}},X.default.createElement(G.DatePicker,{label:"From Date",value:M,onChange:e=>I(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}),X.default.createElement(G.DatePicker,{label:"To Date",value:q,onChange:e=>$(e),slotProps:{textField:{size:"small",fullWidth:!0},field:{clearable:!0}}}))):X.default.createElement(m.Box,{sx:{width:"400px",marginBottom:2}},X.default.createElement(Qe,{items:k,selectedKeys:R,onChange:e=>D(e),label:"Choose Values",placeholder:"Select one or more values...",loading:B,helperText:R.length>0?`${R.length} value(s) selected`:"Select at least one value"})),X.default.createElement(m.Box,{sx:{display:"flex",gap:1,justifyContent:"flex-end"}},X.default.createElement(m.Button,{variant:"outlined",size:"small",onClick:U,sx:{textTransform:"none",borderRadius:"6px"}},"Cancel"),X.default.createElement(m.Button,{variant:"contained",size:"small",onClick:()=>(e=>{const t=r[e];if(W(t.dimension)){if(!M&&!q)return;const a={};M&&(a.gte=M.format("YYYY-MM-DD")),q&&(a.lte=q.format("YYYY-MM-DD"));const r={...t,values:a};n(e,r)}else{if(0===R.length)return;const a={...t,values:R};n(e,a)}F(null),T([]),D([]),I(null),$(null)})(e),disabled:a?!M&&!q:0===R.length,sx:{textTransform:"none",borderRadius:"6px",backgroundColor:"rgb(70, 134, 128)",boxShadow:"none","&:hover":{backgroundColor:"rgb(50, 114, 108)",boxShadow:"none"}}},"Save Changes"))))}))))},vt=({reportData:t,dimensions:a,metrics:r,loading:n,onPageChange:l,totalRows:o=0,titleOverrides:i={dimensions:{},metrics:{}}})=>{const[s,d]=e.useState({page:0,pageSize:50}),c=X.default.useMemo(()=>{const e=[];return a.forEach(t=>{let a,r;if(t.relations&&t.relations.length>0){const e=t.fullPath.split("."),r=e[0],n=e[1],l=r.split("_");l.shift();const o=l.join("_");a=o?`${o}_${n}`:n}else a=t.fullPath.replace(".","_");r=i.dimensions[t.fullPath]||t.dimensionTitle||a,e.push({field:a,headerName:r,flex:1,minWidth:150})}),r.forEach(t=>{const a=t.metric;let r,n;if(t.relations&&t.relations.length>0){const e=t.fullPath.split("."),a=e[0],n=e[1],l=a.split("_");l.shift();const o=l.join("_");r=o?`${o}_${n}`:n}else r=t.metricName;n=i.metrics[t.fullPath]||t.metricTitle||r,e.push({field:r,headerName:n,flex:1,minWidth:150,type:"integer"===a?.type||"currency"===a?.type?"number":"string",valueFormatter:e=>{if(null==e)return"";if(a?.format){const t=te.default(e).format(a.format);return a?.prefix?`${a.prefix} ${t}`:t}return e}})}),e},[a,r,i]),u=X.default.useMemo(()=>t&&Array.isArray(t)?t.map((e,t)=>({id:t,...e})):[],[t]);return n?X.default.createElement(m.Box,{display:"flex",justifyContent:"center",alignItems:"center",minHeight:400},X.default.createElement(m.CircularProgress,null)):t&&0!==t.length?X.default.createElement(m.Box,{sx:{height:600,width:"100%"}},X.default.createElement(S.DataGrid,{rows:u,columns:c,paginationModel:s,onPaginationModelChange:e=>{d(e),l&&e.page!==s.page&&l(e.page,e.pageSize)},pageSizeOptions:[10,25,50,100],paginationMode:"server",rowCount:o||u.length,loading:n,disableRowSelectionOnClick:!0,sx:{"& .MuiDataGrid-cell":{padding:"8px"},"& .MuiDataGrid-columnHeader":{backgroundColor:"#f5f5f5",fontWeight:"bold"}}})):X.default.createElement(m.Box,{display:"flex",justifyContent:"center",alignItems:"center",minHeight:400},X.default.createElement(m.Typography,{variant:"body1",color:"textSecondary"},"No data available. Run a report to see results."))};function wt({children:e,value:t,index:a}){return X.default.createElement("div",{role:"tabpanel",hidden:t!==a,id:`report-tabpanel-${a}`,"aria-labelledby":`report-tab-${a}`},t===a&&X.default.createElement(m.Box,{sx:{py:3}},e))}const St=({reportDefinitionId:t,cloneData:a,autoRun:r,onBackToList:n})=>{const l=ft(),o=dt(),[i,s]=e.useState(null),[d,c]=e.useState(""),[u,f]=e.useState(""),[p,g]=e.useState({dimensions:[],metrics:[],filters:{}}),[h,y]=e.useState({dimensions:{},metrics:{},filters:{}}),[x,b]=e.useState(null),[E,v]=e.useState(!1),[w,S]=e.useState(0),[C,k]=e.useState(0),[T,R]=e.useState(50),[D,B]=e.useState(0),[P,z]=e.useState(!1),[F,M]=e.useState(!1);e.useEffect(()=>{(async()=>{const e=await Ye.getProviders();console.log({providers:e}),s(e)})()},[]),e.useEffect(()=>{t&&i&&$(t)},[t,i]),e.useEffect(()=>{a&&i&&A(a)},[a,i]),e.useEffect(()=>{r&&F&&d&&p.dimensions.length>0&&_()},[r,F]);const I=(e,t,a)=>{try{const[r,n]=e.split("."),l=r.split("_");let o=a;const i=[],s=[a],d=[];for(let e=1;e<l.length;e++){const a=l[e],r=t[o];if(!r||!r.relations)return console.warn(`Provider ${o} not found or has no relations`),null;const n=r.relations.find(e=>e.alias===a);if(!n)return console.warn(`Relation with alias ${a} not found in provider ${o}`),null;i.push(n),d.push(n.name),o=n.target,s.push(o)}const c=t[o];if(!c)return console.warn(`Final provider ${o} not found`),null;const u=c.default_alias;if(!c.dimensions||!c.dimensions[u])return console.warn(`Dimensions not found for alias ${u} in provider ${o}`),null;const f=c.dimensions[u][n];return f?{dimension:f,relations:i,providerPath:s,relationNames:d,dimensionKey:n,dimensionTitle:f.title||n,fullPath:e}:(console.warn(`Dimension ${n} not found in provider ${o}, alias ${u}`),null)}catch(t){return console.warn(`Error reconstructing dimension from path ${e}:`,t),null}},q=(e,t,a)=>{try{const[r,n]=e.split("."),l=r.split("_");let o=a;const i=[],s=[a],d=[];for(let e=1;e<l.length;e++){const a=l[e],r=t[o];if(!r||!r.relations)return console.warn(`Provider ${o} not found or has no relations`),null;const n=r.relations.find(e=>e.alias===a);if(!n)return console.warn(`Relation with alias ${a} not found in provider ${o}`),null;i.push(n),d.push(n.name),o=n.target,s.push(o)}const c=t[o];if(!c)return console.warn(`Final provider ${o} not found`),null;if(!c.metrics)return console.warn(`Metrics not found in provider ${o}`),null;const u=c.metrics.find(e=>e.name===n);return u?{metric:u,relations:i,providerPath:s,relationNames:d,metricName:n,metricTitle:u.title||n,fullPath:e}:(console.warn(`Metric ${n} not found in provider ${o}`),null)}catch(t){return console.warn(`Error reconstructing metric from path ${e}:`,t),null}},$=async e=>{try{console.log("Loading report definition:",e);const t=await Ye.getReportDefinition({id:e});console.log("Loaded report definition:",t),c(t.provider),f(t.title||"");const a=[],r={};if(t.definition?.doc?.query?.order_by)for(const e of t.definition.doc.query.order_by)!0===e.desc?r[e.name]="desc":r[e.name]="asc";if(t.definition?.doc?.query?.dimensions)for(const e of t.definition.doc.query.dimensions){const n=I(e,i,t.provider);n&&(n.sortOrder=r[e]||null,a.push(n))}const n=[];if(t.definition?.doc?.query?.metrics)for(const e of t.definition.doc.query.metrics){const a=q(e,i,t.provider);a&&n.push(a)}const l={dimensions:{},metrics:{},filters:{}};t.definition?.doc?.query?.titles&&(t.definition.doc.query.titles.dimensions&&(l.dimensions=t.definition.doc.query.titles.dimensions),t.definition.doc.query.titles.metrics&&(l.metrics=t.definition.doc.query.titles.metrics),t.definition.doc.query.titles.filters&&(l.filters=t.definition.doc.query.titles.filters));const o={};if(t.definition?.doc?.query?.filter){const e=t.definition.doc.query.filter;(e.and||e.or||[]).forEach(e=>{const[a,r]=Object.entries(e)[0],n=I(a,i,t.provider);n&&(o[a]={...n,values:r})})}g({dimensions:a,metrics:n,filters:o}),y(l),M(!0),console.log("Reconstructed report:",{dimensions:a,metrics:n,filters:o,titleOverrides:l})}catch(e){console.error("Error loading report definition:",e),l.error("Error loading report definition: "+(e.message||"Unknown error"))}},A=e=>{try{console.log("Loading cloned report:",e),c(e.provider),f(e.title||"");const t=[],a={};if(e.definition?.doc?.query?.order_by)for(const t of e.definition.doc.query.order_by)!0===t.desc?a[t.name]="desc":a[t.name]="asc";if(e.definition?.doc?.query?.dimensions)for(const r of e.definition.doc.query.dimensions){const n=I(r,i,e.provider);n&&(n.sortOrder=a[r]||null,t.push(n))}const r=[];if(e.definition?.doc?.query?.metrics)for(const t of e.definition.doc.query.metrics){const a=q(t,i,e.provider);a&&r.push(a)}const n={dimensions:{},metrics:{},filters:{}};e.definition?.doc?.query?.titles&&(e.definition.doc.query.titles.dimensions&&(n.dimensions=e.definition.doc.query.titles.dimensions),e.definition.doc.query.titles.metrics&&(n.metrics=e.definition.doc.query.titles.metrics),e.definition.doc.query.titles.filters&&(n.filters=e.definition.doc.query.titles.filters));const l={};if(e.definition?.doc?.query?.filter){const t=e.definition.doc.query.filter;(t.and||t.or||[]).forEach(t=>{const[a,r]=Object.entries(t)[0],n=I(a,i,e.provider);n&&(l[a]={...n,values:r})})}g({dimensions:t,metrics:r,filters:l}),y(n),console.log("Loaded cloned report:",{dimensions:t,metrics:r,filters:l,titleOverrides:n})}catch(e){console.error("Error loading cloned report:",e),l.error("Error loading cloned report: "+(e.message||"Unknown error"))}},O=(e=0,t=50)=>{const a=p.dimensions.map(e=>{const t={name:e.fullPath};return"desc"===e.sortOrder&&(t.desc=!0),t}),r=[];p.filters&&Object.keys(p.filters).length>0&&Object.entries(p.filters).forEach(([e,t])=>{t.values&&(Array.isArray(t.values)?t.values.length>0&&r.push({[e]:t.values}):"object"==typeof t.values&&r.push({[e]:t.values}))});const n=r.length>0?{and:r}:null,l={};Object.keys(h.dimensions).length>0&&(l.dimensions=h.dimensions),Object.keys(h.metrics).length>0&&(l.metrics=h.metrics),Object.keys(h.filters).length>0&&(l.filters=h.filters);const i={dimensions:p.dimensions.map(e=>e.fullPath),metrics:p.metrics.map(e=>e.fullPath),order_by:a,limit:t,offset:e*t};Object.keys(l).length>0&&(i.titles=l),n&&(i.filter=n);return{provider:d,doc:{query:i},parameters:o?.parameters||{base_currency:"EUR"}}},j=async(e,t)=>{try{v(!0);const a=O(e,t);console.log("Running report with:",a);const r=await Ye.runAdHocReport({report:a});console.log("Report result:",r),b(r),r&&r.length<t?S(e*t+r.length):S((e+2)*t)}catch(e){console.error("Error running report:",e),l.error("Error running report: "+(e.message||"Unknown error")),b(null)}finally{v(!1)}},_=async()=>{k(0),await j(0,T),B(3)},W=d,N=d&&u.trim()&&(p.dimensions.length>0||p.metrics.length>0);return X.default.createElement(m.Box,{sx:{p:3,fontFamily:"system-ui"}},X.default.createElement(m.Box,{sx:{display:"flex",justifyContent:"space-between",alignItems:"center",mb:2,backgroundColor:"transparent",fontFamily:"system-ui"}},X.default.createElement("h1",null,t?"Edit Report":"Create New Report"),n&&X.default.createElement(m.Button,{variant:"outlined",startIcon:X.default.createElement(Se.default,null),onClick:n},"Back to List")),X.default.createElement(m.Box,{sx:{mt:2,p:3,backgroundColor:"white",borderRadius:"12px",border:"1px solid #e0e0e0",fontFamily:"system-ui",display:"flex",flexDirection:"column",gap:3,boxShadow:"0px 2px 4px rgba(0,0,0,0.02)"}},X.default.createElement(m.Box,{sx:{display:"flex",gap:4,alignItems:"flex-start",flexWrap:"wrap"}},X.default.createElement("div",null,X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1,color:"rgb(37, 37, 37)"}},"Report Title"),X.default.createElement(m.TextField,{value:u,onChange:e=>f(e.target.value),placeholder:"Enter report title",sx:{width:"400px",fontFamily:"system-ui","& .MuiOutlinedInput-root":{backgroundColor:"white",borderRadius:"8px"}},size:"small"})),X.default.createElement("div",null,X.default.createElement(m.Typography,{sx:{fontSize:"14px",fontWeight:600,mb:1,color:"rgb(37, 37, 37)"}},"Select Root Provider"),X.default.createElement(tt,{items:i?Object.keys(i).filter(e=>!0===i[e].base).map(e=>({key:e,value:i[e].name||e})):[],value:d,onChange:e=>{c(e.target.value),g({dimensions:[],metrics:[],filters:{}}),y({dimensions:{},metrics:{},filters:{}}),console.log("Selected root provider:",e.target.value)},sx:{width:"300px",fontFamily:"system-ui"},disabled:!!t}))),X.default.createElement(m.Box,{sx:{display:"flex",gap:2,alignItems:"center"}},X.default.createElement(m.Button,{variant:"contained",onClick:_,disabled:!W,startIcon:X.default.createElement(ve.default,null),sx:{height:"40px",fontFamily:"system-ui",borderRadius:"8px",boxShadow:"none",textTransform:"none",backgroundColor:"rgb(70, 134, 128)",fontWeight:500,padding:"0 20px","&:hover":{backgroundColor:"rgb(46, 102, 98)",boxShadow:"none"}}},"Run Report"),X.default.createElement(m.Button,{variant:"outlined",startIcon:X.default.createElement(ke.default,null),onClick:async()=>{try{v(!0);const e=O();console.log("Downloading report with:",e);const t=(new Date).toISOString().split("T")[0],a=`${(u||"report").replace(/[^a-z0-9]/gi,"_").toLowerCase()}_${t}.csv`;await Ye.downloadAdHocReport({report:e,filename:a}),l.success("Report downloaded successfully!")}catch(e){console.error("Error downloading report:",e),l.error("Error downloading report: "+(e.message||"Unknown error"))}finally{v(!1)}},disabled:!W||E,sx:{height:"40px",fontFamily:"system-ui",borderRadius:"8px",boxShadow:"none",textTransform:"none",color:"#9c27b0",borderColor:"#e1bee7",fontWeight:500,padding:"0 20px","&:hover":{borderColor:"#9c27b0",backgroundColor:"rgba(156, 39, 176, 0.04)"}}},"Download CSV"),X.default.createElement(m.Button,{variant:"outlined",startIcon:X.default.createElement(Ce.default,null),onClick:async()=>{if(d)if(u.trim())if(0!==p.dimensions.length||0!==p.metrics.length)try{z(!0);const e=p.dimensions.map(e=>{const t={name:e.fullPath};return"desc"===e.sortOrder&&(t.desc=!0),t}),a={};Object.keys(h.dimensions).length>0&&(a.dimensions=h.dimensions),Object.keys(h.metrics).length>0&&(a.metrics=h.metrics),Object.keys(h.filters).length>0&&(a.filters=h.filters);const r={dimensions:p.dimensions.map(e=>e.fullPath),metrics:p.metrics.map(e=>e.fullPath),order_by:e};if(Object.keys(a).length>0&&(r.titles=a),Object.keys(p.filters).length>0){const e=[];Object.entries(p.filters).forEach(([t,a])=>{a.values&&(Array.isArray(a.values)?a.values.length>0&&e.push({[t]:a.values}):"object"==typeof a.values&&e.push({[t]:a.values}))}),e.length>0&&(r.filter={and:e})}const o={query:r},i={provider:d,title:u.trim(),definition:{provider:d,doc:o,parameters:{base_currency:"EUR"}}};console.log("Saving report definition:",i),t?(await Ye.updateReportDefinition({id:t,reportDefinition:i}),l.success("Report definition updated successfully!")):(await Ye.createReportDefinition({reportDefinition:i}),l.success("Report definition created successfully!")),n&&n()}catch(e){console.error("Error saving report definition:",e),l.error("Error saving report definition: "+(e.message||"Unknown error"))}finally{z(!1)}else l.warning("Please add at least one dimension or metric");else l.warning("Please enter a report title");else l.warning("Please select a provider first")},disabled:!N||P,sx:{height:"40px",fontFamily:"system-ui",borderRadius:"8px",boxShadow:"none",textTransform:"none",color:"#2e7d32",borderColor:"#a5d6a7",fontWeight:500,padding:"0 20px","&:hover":{borderColor:"#2e7d32",backgroundColor:"rgba(46, 125, 50, 0.04)"}}},P?"Saving...":t?"Update Report":"Save Report"))),d&&X.default.createElement(m.Box,{sx:{mt:2,fontFamily:"system-ui",backgroundColor:"white",px:3,py:2,borderRadius:"8px"}},X.default.createElement(m.Box,{sx:{borderBottom:1,borderColor:"rgba(70, 134, 127, 0.27)"}},X.default.createElement(m.Tabs,{value:D,onChange:(e,t)=>{B(t)},"aria-label":"report builder tabs",sx:{"& .MuiTabs-indicator":{display:"flex",justifyContent:"center",backgroundColor:"rgb(70, 134, 128)"},"& .MuiTabs-indicatorSpan":{backgroundColor:"rgb(70, 134, 128)"}}},X.default.createElement(m.Tab,{label:X.default.createElement(m.Badge,{badgeContent:p.dimensions.length,sx:{"& .MuiBadge-badge":{backgroundColor:"rgb(70, 134, 128)",color:"#fff"}}},X.default.createElement("span",{style:{marginRight:p.dimensions.length>0?"12px":"0"}},"Dimensions")),id:"report-tab-0","aria-controls":"report-tabpanel-0",sx:{height:"41px",fontFamily:"system-ui",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none",color:"rgb(37, 37, 37)","&.Mui-selected":{color:"rgb(70, 134, 128)"}}}),X.default.createElement(m.Tab,{label:X.default.createElement(m.Badge,{badgeContent:p.metrics.length,sx:{"& .MuiBadge-badge":{backgroundColor:"rgb(70, 134, 128)",color:"#fff"}}},X.default.createElement("span",{style:{marginRight:p.metrics.length>0?"12px":"0"}},"Metrics")),id:"report-tab-1","aria-controls":"report-tabpanel-1",sx:{height:"41px",fontFamily:"system-ui",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none",color:"rgb(37, 37, 37)","&.Mui-selected":{color:"rgb(70, 134, 128)"}}}),X.default.createElement(m.Tab,{label:X.default.createElement(m.Badge,{badgeContent:Object.keys(p.filters).length,sx:{"& .MuiBadge-badge":{backgroundColor:"rgb(70, 134, 128)",color:"#fff"}}},X.default.createElement("span",{style:{marginRight:Object.keys(p.filters).length>0?"12px":"0"}},"Filters")),id:"report-tab-2","aria-controls":"report-tabpanel-2",sx:{height:"41px",fontFamily:"system-ui",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none",color:"rgb(37, 37, 37)","&.Mui-selected":{color:"rgb(70, 134, 128)"}}}),X.default.createElement(m.Tab,{label:x?"Results":"Results (Run report first)",id:"report-tab-3","aria-controls":"report-tabpanel-3",disabled:!x,sx:{height:"41px",fontFamily:"system-ui",borderRadius:"0.5rem",boxShadow:"none",textTransform:"none",color:"rgb(37, 37, 37)","&.Mui-selected":{color:"rgb(70, 134, 128)"}}}))),X.default.createElement(wt,{value:D,index:0},X.default.createElement(yt,{providersData:i,rootProvider:d,savedDimensions:p.dimensions,onSaveDimension:e=>{g(t=>{const a={...t,dimensions:[...t.dimensions,e]};return console.log("Dimension saved:",e),console.log("Complete report:",a),a})},onRemoveDimension:e=>{g(t=>({...t,dimensions:t.dimensions.filter((t,a)=>a!==e)}))},onReorderDimensions:e=>{g(t=>({...t,dimensions:e}))},titleOverrides:h.dimensions,onUpdateTitle:(e,t)=>{y(a=>({...a,dimensions:{...a.dimensions,[e]:t}}))},onResetTitle:e=>{y(t=>{const a={...t.dimensions};return delete a[e],{...t,dimensions:a}})},existingMetrics:p.metrics,existingFilters:p.filters})),X.default.createElement(wt,{value:D,index:1},X.default.createElement(bt,{providersData:i,rootProvider:d,savedMetrics:p.metrics,onSaveMetric:e=>{g(t=>{const a={...t,metrics:[...t.metrics,e]};return console.log("Metric saved:",e),console.log("Complete report:",a),a})},onRemoveMetric:e=>{g(t=>({...t,metrics:t.metrics.filter((t,a)=>a!==e)}))},onReorderMetrics:e=>{g(t=>({...t,metrics:e}))},titleOverrides:h.metrics,onUpdateTitle:(e,t)=>{y(a=>({...a,metrics:{...a.metrics,[e]:t}}))},onResetTitle:e=>{y(t=>{const a={...t.metrics};return delete a[e],{...t,metrics:a}})},existingDimensions:p.dimensions,existingFilters:p.filters})),X.default.createElement(wt,{value:D,index:2},X.default.createElement(Et,{providersData:i,rootProvider:d,savedFilters:p.filters,existingDimensions:p.dimensions,existingMetrics:p.metrics,onSaveFilter:(e,t)=>{g(a=>{const r={...a,filters:{...a.filters,[e]:t}};return console.log("Filter saved:",{fullPath:e,filterData:t}),console.log("Complete report:",r),r})},onRemoveFilter:e=>{g(t=>{const a={...t.filters};return delete a[e],{...t,filters:a}})},titleOverrides:h.filters,dimensionTitleOverrides:h.dimensions,onUpdateTitle:(e,t)=>{y(a=>({...a,filters:{...a.filters,[e]:t}}))},onResetTitle:e=>{y(t=>{const a={...t.filters};return delete a[e],{...t,filters:a}})}})),X.default.createElement(wt,{value:D,index:3},x&&X.default.createElement(vt,{reportData:x,dimensions:p.dimensions,metrics:p.metrics,loading:E,onPageChange:async(e,t)=>{k(e),t!==T&&R(t),await j(e,t)},totalRows:w,titleOverrides:h}))))},Ct=()=>{const[t,a]=e.useState("list"),[r,n]=e.useState(null),[l,o]=e.useState(null),[i,s]=e.useState(!1),[d,c]=e.useState(0),u=e=>{n(e),o(null),s(!1),a("builder")},f=()=>{n(null),o(null),s(!1),a("builder")},m=e=>{n(e),o(null),s(!0),a("builder")},p=e=>{n(null),o(e),s(!1),a("builder")};return"list"===t?X.default.createElement(pt,{onSelectReport:u,onAddNew:f,onCloneReport:p,onRunReport:m,refreshTrigger:d}):X.default.createElement(St,{reportDefinitionId:r,cloneData:l,autoRun:i,onBackToList:()=>{n(null),o(null),s(!1),a("list"),c(e=>e+1)}})};var kt={Chart:ot,Dashboard:function({id:t="sample_dashboard",api:a,params:r}){const n=dt(),l=a||n?.api||{},o=r||n?.parameters||{},[i,s]=X.default.useState(),[d]=X.default.useState(),[c,u]=X.default.useState([]),f=X.default.useRef({}),m=nt();lt(m),console.log({rows:c},{dashboard:i},{schema:d},{params:o}),e.useEffect(()=>{Ye.setBaseUrl(l.base_url),Ye.setToken(l.token)},[l]);const p=async e=>{const t=e?.doc?.rows||[],a=[];for(let e=0;e<t.length;e++){const r=t[e];r.columns?.forEach(e=>{if(e.override?.filter?.length){const t={};e.override.filter.forEach(e=>{e.hasOwnProperty("value")&&(t[e.field]=[e.value])}),e.filter=t}}),a.push(r)}u(a)};return X.default.useEffect(()=>{t&&(async()=>{Ye.setBaseUrl(l.base_url),Ye.setToken(l.token),await Ye.loadDashboardMeta({dashboardId:t});const e=await Ye.getDashboard({id:t});f.current[e?.id]=e,s(e),await p(e)})().catch(e=>console.error(e.message))},[t]),X.default.createElement(he.default,{maxWidth:!1,disableGutters:!0},X.default.createElement(ge.default,{container:!0,spacing:3},c?.map((e,t)=>{const a=(e=>0===e?12:12/e)(e.columns.length);return X.default.createElement(X.default.Fragment,{key:t},1===t?X.default.createElement(ge.default,{item:!0,xs:12},X.default.createElement(ge.default,{container:!0,spacing:3},e.columns.map((e,t)=>X.default.createElement(ge.default,{key:t,item:!0,xs:12,md:a},X.default.createElement(ot,{api:l,cache:f.current,id:e.id,dashboard:i,schema:d,title:e.title,filter:e.filter,params:o}))))):e.columns.map((e,t)=>X.default.createElement(ge.default,{key:t,item:!0,xs:12,md:a},X.default.createElement(ot,{api:l,cache:f.current,id:e.id,dashboard:i,schema:d,title:e.title,filter:e.filter,params:o}))))})))},ReportApp:({params:t,api:a})=>(Ye._initialized||(Ye.setBaseUrl(a.base_url),Ye.setToken(a.token),Ye._initialized=!0),e.useEffect(()=>{Ye.setBaseUrl(a.base_url),Ye.setToken(a.token)},[a]),X.default.createElement(ut,null,X.default.createElement(st,{defaultParameters:t,defaultApi:a},X.default.createElement(Z.ThemeProvider,{theme:Z.createTheme({palette:{primary:{main:"rgb(70, 134, 128)"}},components:{MuiButton:{styleOverrides:{root:{borderRadius:8,textTransform:"none",boxShadow:"none","&:hover":{boxShadow:"none"}}}},MuiTooltip:{styleOverrides:{tooltip:{fontSize:"0.875rem",backgroundColor:"rgba(97, 97, 97, 0.95)",maxWidth:500},arrow:{color:"rgba(97, 97, 97, 0.95)"}},defaultProps:{arrow:!0,enterDelay:300,leaveDelay:200}},MuiPopper:{defaultProps:{style:{zIndex:1500}}}}})},X.default.createElement(Ct,null)))))};exports.default=kt;
|