unleash-server 7.4.2 → 7.4.3
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/lib/features/index.d.ts +1 -0
- package/dist/lib/features/index.d.ts.map +1 -1
- package/dist/lib/features/index.js +1 -0
- package/dist/lib/features/index.js.map +1 -1
- package/dist/lib/routes/admin-api/user/user.d.ts +1 -0
- package/dist/lib/routes/admin-api/user/user.d.ts.map +1 -1
- package/dist/lib/routes/admin-api/user/user.js +12 -1
- package/dist/lib/routes/admin-api/user/user.js.map +1 -1
- package/dist/lib/server-impl.d.ts +2 -2
- package/dist/lib/server-impl.d.ts.map +1 -1
- package/dist/lib/server-impl.js +2 -2
- package/dist/lib/server-impl.js.map +1 -1
- package/frontend/build/index.html +1 -1
- package/frontend/build/static/{AdvancedPlayground-DRpxJMnK.js → AdvancedPlayground-BVQjoHnr.js} +1 -1
- package/frontend/build/static/{BackendConnections-_n7OFNmD.js → BackendConnections-bRvUo06H.js} +1 -1
- package/frontend/build/static/{CreateProject-068uYB82.js → CreateProject-z7K5-k8g.js} +1 -1
- package/frontend/build/static/{EnterpriseEdge-D8BFcFOL.js → EnterpriseEdge-CAkbmuGs.js} +1 -1
- package/frontend/build/static/{FeatureMetricsChart-CmPDv0Qg.js → FeatureMetricsChart-TPw8l2qi.js} +1 -1
- package/frontend/build/static/{FeatureStaleDialog-p_WEko7Q.js → FeatureStaleDialog-DwV5Mzh6.js} +1 -1
- package/frontend/build/static/{FeatureViewLazyExport-CsvADBC_.js → FeatureViewLazyExport-CBpSqVMU.js} +2 -2
- package/frontend/build/static/{FlagMetricsChart-D0cnIXiN.js → FlagMetricsChart-DLcy8CzE.js} +1 -1
- package/frontend/build/static/{FrontendNetworkTrafficUsage-DF0QQUFI.js → FrontendNetworkTrafficUsage-CYJZFmkc.js} +1 -1
- package/frontend/build/static/{GridLayoutWrapper-CvaFKuMM.js → GridLayoutWrapper-CixVvIgD.js} +1 -1
- package/frontend/build/static/{ImpactMetricsPage-BQnbfPhs.js → ImpactMetricsPage-AS6DHn5C.js} +1 -1
- package/frontend/build/static/{LazyAdminExport-CaPIJWoT.js → LazyAdminExport-dyqU9IvB.js} +3 -3
- package/frontend/build/static/{LazyProjectExport-DxVvRHV2.js → LazyProjectExport-B1vRaljX.js} +2 -2
- package/frontend/build/static/{LifecycleChartComponent-7r5tp81g.js → LifecycleChartComponent-BGuUP9oF.js} +1 -1
- package/frontend/build/static/{LineChartComponent-p_JFdSdE.js → LineChartComponent-DA6kG8Ei.js} +1 -1
- package/frontend/build/static/{MarkCompletedDialogue-BHRKKIec.js → MarkCompletedDialogue-D2TM3HgS.js} +1 -1
- package/frontend/build/static/{NetworkOverview-Dr4-ROCD.js → NetworkOverview-aNdwr7xF.js} +1 -1
- package/frontend/build/static/{NetworkPrometheusAPIWarning-COfHXZmz.js → NetworkPrometheusAPIWarning-f1m-ZHgX.js} +1 -1
- package/frontend/build/static/{NetworkTraffic-Dm-2mi3M.js → NetworkTraffic-CzH9_YqS.js} +1 -1
- package/frontend/build/static/{NetworkTrafficUsage-fGr4QA8t.js → NetworkTrafficUsage-BqpcQ4JO.js} +1 -1
- package/frontend/build/static/{PercentageDonut-DystLTgb.js → PercentageDonut-cKg6eF-p.js} +1 -1
- package/frontend/build/static/{ReactJSONEditor-CdN66QkS.js → ReactJSONEditor-BH7GX57b.js} +1 -1
- package/frontend/build/static/{RoleCell-BjcvUPQZ.js → RoleCell-D01N1lHV.js} +1 -1
- package/frontend/build/static/{aggregateFeatureMetrics-60FrVlfS.js → aggregateFeatureMetrics-DJ_IwcyH.js} +1 -1
- package/frontend/build/static/{formatTickValue-CODpmZvr.js → formatTickValue-ClJtK_xN.js} +1 -1
- package/frontend/build/static/{index-B_EIW-7Y.js → index-Cz4lAJ3Y.js} +117 -117
- package/frontend/build/static/{networkTrafficUsageHighlightPlugin-COgb9_ZU.js → networkTrafficUsageHighlightPlugin-Ce-A3Xr6.js} +1 -1
- package/frontend/build/static/{useApiTokens-CdZATTgS.js → useApiTokens-Dx2wjhgw.js} +1 -1
- package/frontend/package.json +1 -1
- package/package.json +2 -2
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{dt as w,jj as F,bt as E,aP as S,r as p,j as r,B as k,jk as D,bs as A,s as g,jl as P,jm as I,jn as B,jo as T,jp as L,jq as N,jr as O,b as j,T as R,js as y,bq as $,G as H}from"./index-
|
|
1
|
+
import{dt as w,jj as F,bt as E,aP as S,r as p,j as r,B as k,jk as D,bs as A,s as g,jl as P,jm as I,jn as B,jo as T,jp as L,jq as N,jr as O,b as j,T as R,js as y,bq as $,G as H}from"./index-Cz4lAJ3Y.js";import{f as V,a as W}from"./formatTickValue-ClJtK_xN.js";import{F as U,c as _,u as G,b as Y}from"./aggregateFeatureMetrics-DJ_IwcyH.js";import{F as q,M as z}from"./MarkCompletedDialogue-D2TM3HgS.js";const J=e=>{const t={label:"Exposed",hoverBackgroundColor:"#A39EFF",backgroundColor:"#A39EFF",data:M(e,n=>n.yes)},a={label:"Not exposed",hoverBackgroundColor:"#D8D6FF",backgroundColor:"#D8D6FF",data:M(e,n=>n.no)};return{datasets:[t,a]}},M=(e,t)=>e.map(a=>({x:a.timestamp,y:t(a),variants:a.variants||{}})),K=(e,t)=>{if(t===0)return"";const[a,n]=e,s=Math.floor(Number(n)/t*100);return`${n} (${s}%) - ${a}`},C=e=>({plugins:{legend:{position:"top",labels:{color:e.palette.text.primary,usePointStyle:!0,pointStyle:"none",boxHeight:0,padding:15,boxPadding:5}},tooltip:{enabled:!1}},responsive:!0,maintainAspectRatio:!1,scales:{x:{stacked:!0,ticks:{display:!1},grid:{display:!1}},y:{stacked:!0,ticks:{maxTicksLimit:5,display:!1},grid:{drawBorder:!1,color:e.palette.divider}}},elements:{bar:{borderRadius:5}},interaction:{mode:"index",intersect:!1}}),Q=(e,t,a)=>{var m;const{responsive:n,elements:s,interaction:c,scales:o,maintainAspectRatio:i}=C(e);return{plugins:{legend:{position:"bottom",labels:{color:e.palette.text.primary,pointStyle:"circle",usePointStyle:!0,boxHeight:6,padding:15,boxPadding:5}},annotation:{clip:!1,annotations:{}},tooltip:{backgroundColor:e.palette.background.paper,titleColor:e.palette.text.primary,bodyColor:e.palette.text.primary,bodySpacing:6,padding:{top:20,bottom:20,left:30,right:30},borderColor:"rgba(0, 0, 0, 0.05)",borderWidth:3,usePointStyle:!0,caretSize:0,boxPadding:10,callbacks:{label:l=>`${l.formattedValue} - ${l.dataset.label}`,afterLabel:l=>{const d=l.dataset.data[l.dataIndex];if(l.dataset.label!=="Exposed"||d.variants===void 0)return"";const{disabled:f,...u}=d.variants;return Object.entries(u).map(b=>K(b,d.y)).join(`
|
|
2
2
|
`)},title:l=>`Time: ${t>48?w(l[0].label,a.locale,"UTC"):F(l[0].label,a.locale)}`}}},responsive:n,maintainAspectRatio:i,scales:{x:{...o?o.x:{},ticks:{color:e.palette.text.secondary,callback(l){const d=this.getLabelForValue(Number(l));return t>48?E(d,a.locale,"UTC"):F(d,a.locale)}}},y:{...(o==null?void 0:o.y)??{},ticks:{...((m=o==null?void 0:o.y)==null?void 0:m.ticks)??{},color:e.palette.text.secondary,callback:V,display:!0}}},elements:s,interaction:c}},X=({project:e,flagName:t,onArchive:a,className:n})=>{var f;const{feature:s,refetchFeature:c}=S(e,t),o=(f=s.environments)==null?void 0:f.map(u=>({name:u.name,lastSeenAt:u.lastSeenAt,enabled:u.enabled,yes:u.yes,no:u.no})),[i,m]=p.useState(!1),[l,d]=p.useState(!1);return r.jsxs(k,{sx:{display:"flex"},className:n,children:[r.jsx(D,{sx:{pt:0,pb:0},featureLastSeen:s.lastSeenAt,environments:o}),r.jsx(A,{feature:s,onArchive:()=>m(!0),onComplete:()=>d(!0),onUncomplete:c}),s.children.length>0?r.jsx(U,{features:s.children,project:e,isOpen:i,onClose:()=>m(!1)}):r.jsx(q,{isOpen:i,onConfirm:a,onClose:()=>m(!1),projectId:e,featureIds:[t]}),s.project?r.jsx(z,{isOpen:l,setIsOpen:d,projectId:s.project,featureId:s.name,onComplete:c}):null]})},Z=[0,14,28,21,33,31,31,22,26,37,31,14,21,14,0],ee=e=>({labels:Array.from({length:15},(t,a)=>a+1),datasets:[{data:Z,backgroundColor:e.palette.divider,hoverBackgroundColor:e.palette.divider,label:""}]}),v=g("div")({width:"100%",flexGrow:1}),x=({label:e})=>{const t=j(),a=p.useMemo(()=>C(t),[t]),n=p.useMemo(()=>ee(t),[t]),s="placeholder-chart-label";return r.jsxs(r.Fragment,{children:[r.jsx(R,{id:s,children:e}),r.jsx(v,{children:r.jsx(y,{data:n,options:a,"aria-describedby":s})})]})},te=()=>{const e=j(),t=p.useMemo(()=>C(e),[e]),a=p.useMemo(()=>({labels:[],datasets:[]}),[e]);return r.jsx(v,{children:r.jsx(y,{data:a,options:t,"aria-label":"A placeholder bar chart with a single feature flag exposure metrics"})})},ae=(e,t)=>{const[a,n]=p.useState(null),{feature:s}=S(e,t),c=((s==null?void 0:s.environments)??[]).map(i=>({name:i.name,type:i.type})),o=c.find(i=>i.type==="production");return p.useEffect(()=>{o?n(o.name):c.length>0&&n(c[0].name)},[t,JSON.stringify(c)]),{environment:a,setEnvironment:n,activeEnvironments:c}},re=(e,t,a)=>{const{featureMetrics:n=[],loading:s,error:c}=G(e,a),o=p.useMemo(()=>[...n].sort((u,b)=>u.timestamp.localeCompare(b.timestamp)),[n]),i=p.useMemo(()=>Y(o==null?void 0:o.filter(u=>t===u.environment)).map(u=>({...u,appName:"all selected"})),[o,t]),m=p.useMemo(()=>J(i),[i]),l=j(),{locationSettings:d}=$(),f=p.useMemo(()=>Q(l,a,d),[l,a,d]);return{data:m,options:f,loading:s,error:c}},se=({activeEnvironments:e,environment:t,setEnvironment:a})=>r.jsx(H,{name:"feature-environments",label:"Environment",id:"feature-environments",options:e.map(n=>({key:n.name,label:n.name})),value:String(t),onChange:a}),ne=g(k)(({theme:e})=>({display:"flex",justifyContent:"flex-start",flexFlow:"row wrap",gap:e.spacing(2)})),h=g("div")(({theme:e})=>({display:"flex",flexDirection:"column",gap:e.spacing(3),alignItems:"center",height:"100%",justifyContent:"space-between"})),oe=g(X)({alignItems:"center",justifySelf:"start"}),le=g("div")(({theme:e})=>({display:"flex",justifyContent:"space-between",flexFlow:"row wrap",width:"100%",gap:e.spacing(4)})),me=e=>r.jsx(h,{children:r.jsx(x,{...e})}),ie=({flag:e,onArchive:t})=>{const[a,n]=p.useState(48),{environment:s,setEnvironment:c,activeEnvironments:o}=ae(e.project,e.name),{data:i,options:m,loading:l,error:d}=re(e.name,s,a);if(d)return r.jsx(h,{children:r.jsx(x,{label:"Couldn't fetch metrics for the current flag right now. Please try again. Report this if it doesn't resolve itself."})});const f=i.datasets[0].data.length===0;return r.jsxs(h,{children:[r.jsxs(le,{children:[r.jsx(oe,{project:e.project,flagName:e.name,onArchive:t}),r.jsxs(ne,{children:[s?r.jsx(se,{environment:s,setEnvironment:c,activeEnvironments:o}):null,r.jsx(_,{hoursBack:a,setHoursBack:n})]})]}),l?r.jsx(te,{}):f?r.jsx(x,{label:"No metrics for this feature flag in the selected environment and time period"}):r.jsx(v,{children:r.jsx(y,{data:i,options:m,"aria-label":"A bar chart with a single feature flag exposure metrics"})})]})},fe=e=>[".",".."].includes(e.flag.name)?r.jsx(h,{children:r.jsx(x,{label:`The current flag name ('${e.flag.name}') is known to cause issues due how it affects URLs. We cannot show you a chart for it.`})}):r.jsx(ie,{...e});P.register(W,I,B,T,L,N,O);export{fe as FlagMetricsChart,me as PlaceholderFlagMetricsChartWithWrapper};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{cV as n,ba as l,j as e,C as c,R as a,B as d,js as g,jl as j,jm as h,jn as p,jo as f,jp as m,jq as u,jr as x}from"./index-
|
|
1
|
+
import{cV as n,ba as l,j as e,C as c,R as a,B as d,js as g,jl as j,jm as h,jn as p,jo as f,jp as m,jq as u,jr as x}from"./index-Cz4lAJ3Y.js";import{a as S}from"./formatTickValue-ClJtK_xN.js";import{u as C,c as w,S as P,T as y,P as T,n as b,g as B}from"./networkTrafficUsageHighlightPlugin-Ce-A3Xr6.js";import"./LazyAdminExport-dyqU9IvB.js";import"./RoleCell-D01N1lHV.js";import"./useApiTokens-Dx2wjhgw.js";import"./PercentageDonut-cKg6eF-p.js";const _=()=>{n("Network - Frontend Traffic Usage");const{isOss:s}=l(),{chartDataSelection:t,setChartDataSelection:r,options:o}=C(),{chartData:i}=w(t);return e.jsx(c,{condition:s(),show:e.jsx(a,{severity:"warning",children:"Not enabled."}),elseShow:e.jsx(e.Fragment,{children:e.jsxs(P,{children:[e.jsxs(y,{children:[e.jsx(d,{children:e.jsx(a,{severity:"info",icon:!1,children:"Frontend traffic is determined by the total SDK requests to the Frontend API"})}),e.jsx(T,{selectedPeriod:t,setPeriod:r})]}),e.jsx(g,{data:i,plugins:[b],options:o,"aria-label":B(t)})]})})})};j.register(S,h,p,f,m,u,x);export{_ as default};
|
package/frontend/build/static/{GridLayoutWrapper-CvaFKuMM.js → GridLayoutWrapper-CixVvIgD.js}
RENAMED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{j as g,B as X,T as ze,j6 as Rn,j7 as Dn,aZ as Ie,j8 as _n,j9 as Sr,d$ as On,n as Rr,r as L,ja as rr,jb as Pn,dE as En,dF as zn,b7 as nr,u as Cn,A as Mn,v as Dr,m as _r,R as jn,s as B,b as Or,aj as Pr,aq as Tn,cb as Ln,h_ as Hn,h$ as $n,jc as Er,E as Nn,bY as Wn,k as or,aC as kn,jd as qn,cG as ir,a$ as An,b1 as In,ep as Gn,je as Bn,jf as zr,jg as Fn,jh as he,ji as Ct,g as Yn}from"./index-B_EIW-7Y.js";const Xn=({formData:t,actions:e,metricSeries:r,loading:n})=>g.jsxs(X,{children:[g.jsxs(X,{sx:o=>({display:"flex",flexDirection:"column",gap:o.spacing(3)}),children:[g.jsx(ze,{variant:"body2",color:"text.secondary",children:"Select a custom metric to see its value over time. This can help you understand the impact of your feature rollout on key outcomes, such as system performance, usage patterns or error rates."}),g.jsx(Rn,{value:t.metricName,onChange:e.handleSeriesChange,options:r,loading:n}),t.metricName?g.jsxs(g.Fragment,{children:[g.jsxs(Dn,{value:t.timeRange,onChange:e.setTimeRange,children:[g.jsx(Ie,{value:"hour",children:"Last hour"}),g.jsx(Ie,{value:"day",children:"Last 24 hours"}),g.jsx(Ie,{value:"week",children:"Last 7 days"}),g.jsx(Ie,{value:"month",children:"Last 30 days"})]}),g.jsx(_n,{value:t.aggregationMode,onChange:e.setAggregationMode,metricType:Sr(t.metricName)})]}):null]}),t.metricName?g.jsx(On,{sx:o=>({margin:o.spacing(1.5,0)}),control:g.jsx(Rr,{checked:t.yAxisMin==="zero",onChange:o=>e.setYAxisMin(o.target.checked?"zero":"auto")}),label:"Begin at zero"}):null]}),Un=({open:t,initialConfig:e})=>{const[r,n]=L.useState((e==null?void 0:e.title)||""),[o,i]=L.useState((e==null?void 0:e.metricName)||""),[a,u]=L.useState((e==null?void 0:e.timeRange)||"day"),[s,l]=L.useState((e==null?void 0:e.yAxisMin)||"auto"),[c,d]=L.useState((e==null?void 0:e.labelSelectors)||{}),[f,p]=L.useState((e==null?void 0:e.aggregationMode)||rr(o)),{data:{labels:b}}=Pn(o?{series:o,range:a,aggregationMode:f}:void 0);L.useEffect(()=>{t&&e?(n(e.title||""),i(e.metricName),u(e.timeRange),l(e.yAxisMin),d(e.labelSelectors),p(e.aggregationMode||rr(e.metricName))):t&&!e&&(n(""),i(""),u("day"),l("auto"),d({}),p("count"))},[t,e]);const D=w=>{i(w),d({});const y=Sr(w);y==="counter"?p("count"):y==="gauge"?p("avg"):y==="histogram"&&p("p50")},S=()=>({title:r||void 0,metricName:o,timeRange:a,yAxisMin:s,labelSelectors:c,aggregationMode:f}),h=o.length>0;return{formData:{title:r,metricName:o,timeRange:a,yAxisMin:s,aggregationMode:f,labelSelectors:c},actions:{setTitle:n,setMetricName:i,setTimeRange:u,setYAxisMin:l,setAggregationMode:p,setLabelSelectors:d,handleSeriesChange:D,getConfigToSave:S},isValid:h,currentAvailableLabels:b}},Vn=()=>{const t="api/admin/impact-metrics/config",{data:e,refetch:r,loading:n,error:o}=En(nr(t),()=>zn(nr(t),"impactMetricsConfig"));return{configs:(e==null?void 0:e.configs)||[],refetch:r,loading:n,error:o}},Kn=t=>{const e=t?`api/admin/projects/${t.projectId}/features/${t.featureName}/impact-metrics/config`:"api/admin/impact-metrics/config",{makeRequest:r,createRequest:n,errors:o,loading:i}=Cn({propagateErrors:!0}),a=L.useCallback(async s=>{const l=n(e,{method:"POST",body:JSON.stringify(s)},"updateImpactMetric");return r(l.caller,l.id)},[r,n]),u=L.useCallback(async s=>{const l=n(`${e}/${s}`,{method:"DELETE"},"deleteImpactMetric");return r(l.caller,l.id)},[r,n,e]);return{createImpactMetric:a,deleteImpactMetric:u,errors:o,loading:i}},de="*",Ba=()=>{const{configs:t,loading:e,error:r,refetch:n}=Vn(),{layout:o,charts:i}=L.useMemo(()=>({layout:t.map((p,b)=>{const D=b%2,S=Math.floor(b/2);return{i:p.id,x:D*6,y:S*2,w:6,h:2,minW:4,minH:2,maxW:12,maxH:8}}),charts:t}),[t]),{createImpactMetric:a,deleteImpactMetric:u,loading:s,errors:l}=Kn(),c=L.useCallback(async p=>{await a(p),n()},[a,n]),d=L.useCallback(async(p,b)=>{await a({...b,id:p}),n()},[t,a,n]),f=L.useCallback(async p=>{await u(p),n()},[t,u,n]);return{charts:i,layout:o,loading:e||s,error:r||Object.keys(l).length>0?l:void 0,addChart:c,updateChart:d,deleteChart:f}},Zn=({labelKey:t,options:e,value:r,onChange:n})=>{const o=r.includes(de),i=`autocomplete-${t}`,a=e.length>=1e3,u=[de,...e];return g.jsx(Mn,{multiple:!0,disableCloseOnSelect:!0,id:i,options:u,value:o?e:r,getOptionLabel:s=>s===de?"(Select all)":s,onChange:(s,l,c,d)=>{if((d==null?void 0:d.option)===de){n(o?[]:[de]);return}n(l.filter(f=>f!==de))},renderOption:(s,l,{selected:c})=>{const{key:d,...f}=s;return g.jsxs("li",{...f,children:[g.jsx(Rr,{size:"small",checked:l===de?o:c,style:{marginRight:8}}),l===de?g.jsx(ze,{component:"span",sx:{color:"text.secondary"},children:"Select all"}):l]},d||l)},renderTags:(s,l)=>{const d=s.slice(-5),f=s.length-5;return g.jsxs(g.Fragment,{children:[d.map((p,b)=>{const{key:D,...S}=l({index:b});return L.createElement(Dr,{...S,key:D,label:p,size:"small"})}),f>0?g.jsxs(ze,{component:"span",sx:{color:"text.secondary"},children:[" ","(+",f,")"]}):null]})},renderInput:s=>g.jsxs(g.Fragment,{children:[g.jsx(_r,{...s,label:t,placeholder:o?void 0:"Select values…",variant:"outlined",size:"small",inputProps:{...s.inputProps}}),a&&g.jsx(jn,{severity:"warning",sx:l=>({padding:l.spacing(1,2),marginTop:l.spacing(1)}),children:"Maximum of 1000 values loaded due to performance."})]})})},Jn=B(X)(({theme:t})=>({display:"flex",flexDirection:"column",gap:t.spacing(1),width:"100%"})),Qn=B(X)(({theme:t})=>({width:"100%",display:"flex",alignItems:"center",gap:t.spacing(1)})),eo=B(X)(({theme:t})=>({display:"grid",gridTemplateColumns:"repeat(auto-fill, minmax(250px, 1fr))",gap:t.spacing(2),flexGrow:1})),to=B(X)({display:"flex",flexDirection:"column",flexGrow:1}),ro=B(ze)({lineHeight:1.5,height:"24px"}),no=B(Dr)(({theme:t})=>({position:"relative",height:"20px",margin:t.spacing(-1,0)})),ar=({title:t,labels:e,labelSelectors:r,onLabelChange:n,onAllToggle:o,onChange:i})=>{const a=e.map(([l])=>l),u=a.some(l=>r[l]),s=()=>{const l={};Object.entries(r).forEach(([c,d])=>{a.includes(c)||(l[c]=d)}),i(l)};return g.jsxs(Jn,{children:[g.jsxs(Qn,{children:[g.jsx(ro,{variant:"subtitle2",children:t}),u&&g.jsx(no,{label:"Clear all",size:"small",variant:"outlined",onClick:s})]}),g.jsx(eo,{children:e.map(([l,c])=>{const d=r[l]||[];return g.jsx(to,{children:g.jsx(Zn,{labelKey:l,options:c,value:d,onChange:f=>n(l,f),handleAllToggle:o})},l)})})]})},sr=["environment","appName","origin"],oo=({labelSelectors:t,onChange:e,availableLabels:r})=>{const n=(u,s)=>{const l={...t};s.length===0?delete l[u]:l[u]=s,e(l)},o=(u,s)=>{const l={...t};s?l[u]=["*"]:delete l[u],e(l)};if(!r||Object.keys(r).length===0)return null;const i=Object.entries(r).filter(([u])=>sr.includes(u)).sort(),a=Object.entries(r).filter(([u])=>!sr.includes(u)).sort();return g.jsxs(X,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[i.length>0&&g.jsx(ar,{title:"Filter by labels",labels:i,labelSelectors:t,onLabelChange:n,onAllToggle:o,onChange:e}),a.length>0&&g.jsx(ar,{title:"Flag specific filters",labels:a,labelSelectors:t,onLabelChange:n,onAllToggle:o,onChange:e})]})},io=B(X)(({theme:t})=>({display:"flex",flexDirection:"column",gap:t.spacing(3),[t.breakpoints.down("lg")]:{flex:"none"},[t.breakpoints.up("lg")]:{flex:"0 0 400px"}})),ao=B(X)(({theme:t})=>({flex:1,display:"flex",flexDirection:"column",gap:t.spacing(2),[t.breakpoints.down("lg")]:{minHeight:"300px"},[t.breakpoints.up("lg")]:{minHeight:"400px"}})),Fa=({open:t,onClose:e,onSave:r,initialConfig:n,metricSeries:o,loading:i=!1})=>{const{formData:a,actions:u,isValid:s,currentAvailableLabels:l}=Un({open:t,initialConfig:n}),c=Or(),d=Pr(c.breakpoints.down("lg")),{trackEvent:f}=Tn(),p=()=>{s&&(r(u.getConfigToSave()),f("impact-metrics",{props:{eventType:"chart added"}}),e())};return g.jsxs(Ln,{open:t,onClose:e,maxWidth:"lg",fullWidth:!0,sx:{"& .MuiDialog-paper":{minHeight:"600px",maxHeight:"90vh"}},children:[g.jsx(Hn,{children:n?"Edit Chart":"Add New Chart"}),g.jsxs($n,{children:[g.jsxs(X,{sx:b=>({display:"flex",flexDirection:{xs:"column",lg:"row"},gap:b.spacing(3),pt:b.spacing(1),height:"100%"}),children:[g.jsxs(io,{children:[g.jsx(_r,{label:"Chart Title (optional)",value:a.title,onChange:b=>u.setTitle(b.target.value),fullWidth:!0,variant:"outlined",size:"small"}),g.jsx(Xn,{formData:a,actions:u,metricSeries:o,loading:i})]}),g.jsx(ao,{children:g.jsx(X,{sx:b=>({padding:b.spacing(1)}),children:g.jsx(Er,{metricName:a.metricName,timeRange:a.timeRange,labelSelectors:a.labelSelectors,yAxisMin:a.yAxisMin,aggregationMode:a.aggregationMode,isPreview:!0},d?"small":"large")})})]}),l?g.jsx(oo,{labelSelectors:a.labelSelectors,onChange:u.setLabelSelectors,availableLabels:l}):null]}),g.jsx(Nn,{}),g.jsxs(Wn,{sx:b=>({margin:b.spacing(2,3,3)}),children:[g.jsx(or,{onClick:e,children:"Cancel"}),g.jsx(or,{onClick:p,variant:"contained",disabled:!s,children:n?"Update":"Add Chart"})]})]})},so=t=>{const e=[];t.displayName&&e.push(`${t.displayName}`),e.push(`last ${t.timeRange}`),e.push(t.aggregationMode);const r=Object.keys(t.labelSelectors).length;return r>0&&e.push(`${r} filter${r>1?"s":""}`),e.join(" • ")},lo=B(kn)(({theme:t})=>({borderRadius:`${t.shape.borderRadiusMedium}px`,boxShadow:"none",display:"flex",flexDirection:"column",height:"100%"})),uo=B(X)({flex:1,display:"flex",flexDirection:"column",minHeight:0}),co=B(X)(({theme:t})=>({position:"relative",minWidth:0,flexGrow:1,height:"100%",display:"flex",flexDirection:"column",margin:"auto 0",padding:t.spacing(3)})),fo=B(X)(({theme:t})=>({display:"flex",gap:t.spacing(1),alignItems:"center",padding:t.spacing(1.5,2),borderBottom:`1px solid ${t.palette.divider}`})),po=B(X)(({theme:t})=>({display:"flex",flexDirection:"column",justifyContent:"flex-end",flexGrow:1,overflow:"hidden",textOverflow:"ellipsis"})),ho=B(X)(({theme:t})=>({marginLeft:"auto",display:"flex",alignItems:"center",gap:t.spacing(.5)})),go=B(qn)(({theme:t})=>({alignSelf:"start",color:t.palette.primary.main,marginTop:t.spacing(.25)})),Ya=({config:t,onEdit:e,onDelete:r,permission:n=Gn,projectId:o,dragHandle:i,icon:a})=>g.jsxs(lo,{children:[g.jsxs(fo,{children:[i,t.mode==="read"?g.jsx(go,{}):null,g.jsxs(po,{children:[t.title&&g.jsx(ze,{variant:"h3",children:t.title}),g.jsx(ze,{variant:"body2",color:"text.secondary",children:so(t)})]}),a,t.mode!=="read"&&g.jsxs(ho,{children:[g.jsx(ir,{onClick:()=>e(t),permission:n,projectId:o,tooltipProps:{title:"Edit chart"},children:g.jsx(An,{})}),g.jsx(ir,{onClick:()=>r(t.id),permission:n,projectId:o,tooltipProps:{title:"Remove chart"},children:g.jsx(In,{})})]})]}),g.jsx(uo,{children:g.jsx(co,{children:g.jsx(Er,{metricName:t.metricName,timeRange:t.timeRange,labelSelectors:t.labelSelectors,yAxisMin:t.yAxisMin,aggregationMode:t.aggregationMode,aspectRatio:1.5,overrideOptions:{maintainAspectRatio:!1},emptyDataDescription:"Send impact metrics using Unleash SDK for this series to view the chart."})})})]});var Cr={exports:{}},We={},bt={exports:{}};(function(t,e){(function(r,n){n(e)})(Bn,function(r){function n(v){return function(T,M,j,W,I,te,k){return v(T,M,k)}}function o(v){return function(T,M,j,W){if(!T||!M||typeof T!="object"||typeof M!="object")return v(T,M,j,W);var I=W.get(T),te=W.get(M);if(I&&te)return I===M&&te===T;W.set(T,M),W.set(M,T);var k=v(T,M,j,W);return W.delete(T),W.delete(M),k}}function i(v,_){var T={};for(var M in v)T[M]=v[M];for(var M in _)T[M]=_[M];return T}function a(v){return v.constructor===Object||v.constructor==null}function u(v){return typeof v.then=="function"}function s(v,_){return v===_||v!==v&&_!==_}var l="[object Arguments]",c="[object Boolean]",d="[object Date]",f="[object RegExp]",p="[object Map]",b="[object Number]",D="[object Object]",S="[object Set]",h="[object String]",w=Object.prototype.toString;function y(v){var _=v.areArraysEqual,T=v.areDatesEqual,M=v.areMapsEqual,j=v.areObjectsEqual,W=v.areRegExpsEqual,I=v.areSetsEqual,te=v.createIsNestedEqual,k=te(ne);function ne(H,q,oe){if(H===q)return!0;if(!H||!q||typeof H!="object"||typeof q!="object")return H!==H&&q!==q;if(a(H)&&a(q))return j(H,q,k,oe);var er=Array.isArray(H),tr=Array.isArray(q);if(er||tr)return er===tr&&_(H,q,k,oe);var ie=w.call(H);return ie!==w.call(q)?!1:ie===d?T(H,q,k,oe):ie===f?W(H,q,k,oe):ie===p?M(H,q,k,oe):ie===S?I(H,q,k,oe):ie===D||ie===l?u(H)||u(q)?!1:j(H,q,k,oe):ie===c||ie===b||ie===h?s(H.valueOf(),q.valueOf()):!1}return ne}function x(v,_,T,M){var j=v.length;if(_.length!==j)return!1;for(;j-- >0;)if(!T(v[j],_[j],j,j,v,_,M))return!1;return!0}var m=o(x);function z(v,_){return s(v.valueOf(),_.valueOf())}function N(v,_,T,M){var j=v.size===_.size;if(!j)return!1;if(!v.size)return!0;var W={},I=0;return v.forEach(function(te,k){if(j){var ne=!1,H=0;_.forEach(function(q,oe){!ne&&!W[H]&&(ne=T(k,oe,I,H,v,_,M)&&T(te,q,k,oe,v,_,M))&&(W[H]=!0),H++}),I++,j=ne}}),j}var A=o(N),K="_owner",J=Object.prototype.hasOwnProperty;function Me(v,_,T,M){var j=Object.keys(v),W=j.length;if(Object.keys(_).length!==W)return!1;for(var I;W-- >0;){if(I=j[W],I===K){var te=!!v.$$typeof,k=!!_.$$typeof;if((te||k)&&te!==k)return!1}if(!J.call(_,I)||!T(v[I],_[I],I,I,v,_,M))return!1}return!0}var ct=o(Me);function je(v,_){return v.source===_.source&&v.flags===_.flags}function Te(v,_,T,M){var j=v.size===_.size;if(!j)return!1;if(!v.size)return!0;var W={};return v.forEach(function(I,te){if(j){var k=!1,ne=0;_.forEach(function(H,q){!k&&!W[ne]&&(k=T(I,H,te,q,v,_,M))&&(W[ne]=!0),ne++}),j=k}}),j}var Qt=o(Te),ge=Object.freeze({areArraysEqual:x,areDatesEqual:z,areMapsEqual:N,areObjectsEqual:Me,areRegExpsEqual:je,areSetsEqual:Te,createIsNestedEqual:n}),me=Object.freeze({areArraysEqual:m,areDatesEqual:z,areMapsEqual:A,areObjectsEqual:ct,areRegExpsEqual:je,areSetsEqual:Qt,createIsNestedEqual:n}),Ae=y(ge);function dt(v,_){return Ae(v,_,void 0)}var gn=y(i(ge,{createIsNestedEqual:function(){return s}}));function mn(v,_){return gn(v,_,void 0)}var yn=y(me);function vn(v,_){return yn(v,_,new WeakMap)}var bn=y(i(me,{createIsNestedEqual:function(){return s}}));function wn(v,_){return bn(v,_,new WeakMap)}function xn(v){return y(i(ge,v(ge)))}function Sn(v){var _=y(i(me,v(me)));return function(T,M,j){return j===void 0&&(j=new WeakMap),_(T,M,j)}}r.circularDeepEqual=vn,r.circularShallowEqual=wn,r.createCustomCircularEqual=Sn,r.createCustomEqual=xn,r.deepEqual=dt,r.sameValueZeroEqual=s,r.shallowEqual=mn,Object.defineProperty(r,"__esModule",{value:!0})})})(bt,bt.exports);var Mt=bt.exports;const Ze=zr(Fn);var E={},mo=function(e,r,n){return e===r?!0:e.className===r.className&&n(e.style,r.style)&&e.width===r.width&&e.autoSize===r.autoSize&&e.cols===r.cols&&e.draggableCancel===r.draggableCancel&&e.draggableHandle===r.draggableHandle&&n(e.verticalCompact,r.verticalCompact)&&n(e.compactType,r.compactType)&&n(e.layout,r.layout)&&n(e.margin,r.margin)&&n(e.containerPadding,r.containerPadding)&&e.rowHeight===r.rowHeight&&e.maxRows===r.maxRows&&e.isBounded===r.isBounded&&e.isDraggable===r.isDraggable&&e.isResizable===r.isResizable&&e.allowOverlap===r.allowOverlap&&e.preventCollision===r.preventCollision&&e.useCSSTransforms===r.useCSSTransforms&&e.transformScale===r.transformScale&&e.isDroppable===r.isDroppable&&n(e.resizeHandles,r.resizeHandles)&&n(e.resizeHandle,r.resizeHandle)&&e.onLayoutChange===r.onLayoutChange&&e.onDragStart===r.onDragStart&&e.onDrag===r.onDrag&&e.onDragStop===r.onDragStop&&e.onResizeStart===r.onResizeStart&&e.onResize===r.onResize&&e.onResizeStop===r.onResizeStop&&e.onDrop===r.onDrop&&n(e.droppingItem,r.droppingItem)&&n(e.innerRef,r.innerRef)};Object.defineProperty(E,"__esModule",{value:!0});E.bottom=jt;E.childrenEqual=bo;E.cloneLayout=Mr;E.cloneLayoutItem=xe;E.collides=Je;E.compact=Tr;E.compactItem=Lr;E.compactType=To;E.correctBounds=Hr;E.fastPositionEqual=wo;E.fastRGLPropsEqual=void 0;E.getAllCollisions=$r;E.getFirstCollision=be;E.getLayoutItem=Tt;E.getStatics=Lt;E.modifyLayout=jr;E.moveElement=Ne;E.moveElementAwayFromCollision=xt;E.noop=void 0;E.perc=So;E.resizeItemInDirection=Eo;E.setTopLeft=Co;E.setTransform=zo;E.sortLayoutItems=qt;E.sortLayoutItemsByColRow=Ar;E.sortLayoutItemsByRowCol=qr;E.synchronizeLayoutWithChildren=Mo;E.validateLayout=jo;E.withLayoutItem=vo;var lr=Mt,$e=yo(L);function yo(t){return t&&t.__esModule?t:{default:t}}function jt(t){let e=0,r;for(let n=0,o=t.length;n<o;n++)r=t[n].y+t[n].h,r>e&&(e=r);return e}function Mr(t){const e=Array(t.length);for(let r=0,n=t.length;r<n;r++)e[r]=xe(t[r]);return e}function jr(t,e){const r=Array(t.length);for(let n=0,o=t.length;n<o;n++)e.i===t[n].i?r[n]=e:r[n]=t[n];return r}function vo(t,e,r){let n=Tt(t,e);return n?(n=r(xe(n)),t=jr(t,n),[t,n]):[t,null]}function xe(t){return{w:t.w,h:t.h,x:t.x,y:t.y,i:t.i,minW:t.minW,maxW:t.maxW,minH:t.minH,maxH:t.maxH,moved:!!t.moved,static:!!t.static,isDraggable:t.isDraggable,isResizable:t.isResizable,resizeHandles:t.resizeHandles,isBounded:t.isBounded}}function bo(t,e){return(0,lr.deepEqual)($e.default.Children.map(t,r=>r==null?void 0:r.key),$e.default.Children.map(e,r=>r==null?void 0:r.key))&&(0,lr.deepEqual)($e.default.Children.map(t,r=>r==null?void 0:r.props["data-grid"]),$e.default.Children.map(e,r=>r==null?void 0:r.props["data-grid"]))}E.fastRGLPropsEqual=mo;function wo(t,e){return t.left===e.left&&t.top===e.top&&t.width===e.width&&t.height===e.height}function Je(t,e){return!(t.i===e.i||t.x+t.w<=e.x||t.x>=e.x+e.w||t.y+t.h<=e.y||t.y>=e.y+e.h)}function Tr(t,e,r,n){const o=Lt(t),i=qt(t,e),a=Array(t.length);for(let u=0,s=i.length;u<s;u++){let l=xe(i[u]);l.static||(l=Lr(o,l,e,r,i,n),o.push(l)),a[t.indexOf(i[u])]=l,l.moved=!1}return a}const xo={x:"w",y:"h"};function wt(t,e,r,n){const o=xo[n];e[n]+=1;const i=t.map(a=>a.i).indexOf(e.i);for(let a=i+1;a<t.length;a++){const u=t[a];if(!u.static){if(u.y>e.y+e.h)break;Je(e,u)&&wt(t,u,r+e[o],n)}}e[n]=r}function Lr(t,e,r,n,o,i){const a=r==="vertical",u=r==="horizontal";if(a)for(e.y=Math.min(jt(t),e.y);e.y>0&&!be(t,e);)e.y--;else if(u)for(;e.x>0&&!be(t,e);)e.x--;let s;for(;(s=be(t,e))&&!(r===null&&i);)if(u?wt(o,e,s.x+s.w,"x"):wt(o,e,s.y+s.h,"y"),u&&e.x+e.w>n)for(e.x=n-e.w,e.y++;e.x>0&&!be(t,e);)e.x--;return e.y=Math.max(e.y,0),e.x=Math.max(e.x,0),e}function Hr(t,e){const r=Lt(t);for(let n=0,o=t.length;n<o;n++){const i=t[n];if(i.x+i.w>e.cols&&(i.x=e.cols-i.w),i.x<0&&(i.x=0,i.w=e.cols),!i.static)r.push(i);else for(;be(r,i);)i.y++}return t}function Tt(t,e){for(let r=0,n=t.length;r<n;r++)if(t[r].i===e)return t[r]}function be(t,e){for(let r=0,n=t.length;r<n;r++)if(Je(t[r],e))return t[r]}function $r(t,e){return t.filter(r=>Je(r,e))}function Lt(t){return t.filter(e=>e.static)}function Ne(t,e,r,n,o,i,a,u,s){if(e.static&&e.isDraggable!==!0||e.y===n&&e.x===r)return t;`${e.i}${String(r)}${String(n)}${e.x}${e.y}`;const l=e.x,c=e.y;typeof r=="number"&&(e.x=r),typeof n=="number"&&(e.y=n),e.moved=!0;let d=qt(t,a);(a==="vertical"&&typeof n=="number"?c>=n:a==="horizontal"&&typeof r=="number"?l>=r:!1)&&(d=d.reverse());const p=$r(d,e),b=p.length>0;if(b&&s)return Mr(t);if(b&&i)return`${e.i}`,e.x=l,e.y=c,e.moved=!1,t;for(let D=0,S=p.length;D<S;D++){const h=p[D];`${e.i}${e.x}${e.y}${h.i}${h.x}${h.y}`,!h.moved&&(h.static?t=xt(t,h,e,o,a):t=xt(t,e,h,o,a))}return t}function xt(t,e,r,n,o,i){const a=o==="horizontal",u=o==="vertical",s=e.static;if(n){n=!1;const d={x:a?Math.max(e.x-r.w,0):r.x,y:u?Math.max(e.y-r.h,0):r.y,w:r.w,h:r.h,i:"-1"},f=be(t,d),p=f&&f.y+f.h>e.y,b=f&&e.x+e.w>f.x;if(f){if(p&&u)return Ne(t,r,void 0,e.y+1,n,s,o);if(p&&o==null)return e.y=r.y,r.y=r.y+r.h,t;if(b&&a)return Ne(t,e,r.x,void 0,n,s,o)}else return`${r.i}${d.x}${d.y}`,Ne(t,r,a?d.x:void 0,u?d.y:void 0,n,s,o)}const l=a?r.x+1:void 0,c=u?r.y+1:void 0;return l==null&&c==null?t:Ne(t,r,a?r.x+1:void 0,u?r.y+1:void 0,n,s,o)}function So(t){return t*100+"%"}const Nr=(t,e,r,n)=>t+r>n?e:r,Wr=(t,e,r)=>t<0?e:r,kr=t=>Math.max(0,t),Ht=t=>Math.max(0,t),$t=(t,e,r)=>{let{left:n,height:o,width:i}=e;const a=t.top-(o-t.height);return{left:n,width:i,height:Wr(a,t.height,o),top:Ht(a)}},Nt=(t,e,r)=>{let{top:n,left:o,height:i,width:a}=e;return{top:n,height:i,width:Nr(t.left,t.width,a,r),left:kr(o)}},Wt=(t,e,r)=>{let{top:n,height:o,width:i}=e;const a=t.left-(i-t.width);return{height:o,width:a<0?t.width:Nr(t.left,t.width,i,r),top:Ht(n),left:kr(a)}},kt=(t,e,r)=>{let{top:n,left:o,height:i,width:a}=e;return{width:a,left:o,height:Wr(n,t.height,i),top:Ht(n)}},Ro=function(){return $t(arguments.length<=0?void 0:arguments[0],Nt(...arguments))},Do=function(){return $t(arguments.length<=0?void 0:arguments[0],Wt(...arguments))},_o=function(){return kt(arguments.length<=0?void 0:arguments[0],Nt(...arguments))},Oo=function(){return kt(arguments.length<=0?void 0:arguments[0],Wt(...arguments))},Po={n:$t,ne:Ro,e:Nt,se:_o,s:kt,sw:Oo,w:Wt,nw:Do};function Eo(t,e,r,n){const o=Po[t];return o?o(e,{...e,...r},n):r}function zo(t){let{top:e,left:r,width:n,height:o}=t;const i=`translate(${r}px,${e}px)`;return{transform:i,WebkitTransform:i,MozTransform:i,msTransform:i,OTransform:i,width:`${n}px`,height:`${o}px`,position:"absolute"}}function Co(t){let{top:e,left:r,width:n,height:o}=t;return{top:`${e}px`,left:`${r}px`,width:`${n}px`,height:`${o}px`,position:"absolute"}}function qt(t,e){return e==="horizontal"?Ar(t):e==="vertical"?qr(t):t}function qr(t){return t.slice(0).sort(function(e,r){return e.y>r.y||e.y===r.y&&e.x>r.x?1:e.y===r.y&&e.x===r.x?0:-1})}function Ar(t){return t.slice(0).sort(function(e,r){return e.x>r.x||e.x===r.x&&e.y>r.y?1:-1})}function Mo(t,e,r,n,o){t=t||[];const i=[];$e.default.Children.forEach(e,u=>{if((u==null?void 0:u.key)==null)return;const s=Tt(t,String(u.key)),l=u.props["data-grid"];s&&l==null?i.push(xe(s)):l?i.push(xe({...l,i:u.key})):i.push(xe({w:1,h:1,x:0,y:jt(i),i:String(u.key)}))});const a=Hr(i,{cols:r});return o?a:Tr(a,n,r)}function jo(t){let e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:"Layout";const r=["x","y","w","h"];if(!Array.isArray(t))throw new Error(e+" must be an array!");for(let n=0,o=t.length;n<o;n++){const i=t[n];for(let a=0;a<r.length;a++){const u=r[a],s=i[u];if(typeof s!="number"||Number.isNaN(s))throw new Error(`ReactGridLayout: ${e}[${n}].${u} must be a number! Received: ${s} (${typeof s})`)}if(typeof i.i<"u"&&typeof i.i!="string")throw new Error(`ReactGridLayout: ${e}[${n}].i must be a string! Received: ${i.i} (${typeof i.i})`)}}function To(t){const{verticalCompact:e,compactType:r}=t||{};return e===!1?null:r}const Lo=()=>{};E.noop=Lo;var se={};Object.defineProperty(se,"__esModule",{value:!0});se.calcGridColWidth=Qe;se.calcGridItemPosition=Ho;se.calcGridItemWHPx=St;se.calcWH=No;se.calcXY=$o;se.clamp=we;function Qe(t){const{margin:e,containerPadding:r,containerWidth:n,cols:o}=t;return(n-e[0]*(o-1)-r[0]*2)/o}function St(t,e,r){return Number.isFinite(t)?Math.round(e*t+Math.max(0,t-1)*r):t}function Ho(t,e,r,n,o,i){const{margin:a,containerPadding:u,rowHeight:s}=t,l=Qe(t),c={};return i&&i.resizing?(c.width=Math.round(i.resizing.width),c.height=Math.round(i.resizing.height)):(c.width=St(n,l,a[0]),c.height=St(o,s,a[1])),i&&i.dragging?(c.top=Math.round(i.dragging.top),c.left=Math.round(i.dragging.left)):i&&i.resizing&&typeof i.resizing.top=="number"&&typeof i.resizing.left=="number"?(c.top=Math.round(i.resizing.top),c.left=Math.round(i.resizing.left)):(c.top=Math.round((s+a[1])*r+u[1]),c.left=Math.round((l+a[0])*e+u[0])),c}function $o(t,e,r,n,o){const{margin:i,containerPadding:a,cols:u,rowHeight:s,maxRows:l}=t,c=Qe(t);let d=Math.round((r-a[0])/(c+i[0])),f=Math.round((e-a[1])/(s+i[1]));return d=we(d,0,u-n),f=we(f,0,l-o),{x:d,y:f}}function No(t,e,r,n,o,i){const{margin:a,maxRows:u,cols:s,rowHeight:l}=t,c=Qe(t);let d=Math.round((e+a[0])/(c+a[0])),f=Math.round((r+a[1])/(l+a[1])),p=we(d,0,s-n),b=we(f,0,u-o);return["sw","w","nw"].indexOf(i)!==-1&&(p=we(d,0,s)),["nw","n","ne"].indexOf(i)!==-1&&(b=we(f,0,u)),{w:p,h:b}}function we(t,e,r){return Math.max(Math.min(t,r),e)}var et={},tt={exports:{}},Ir={},$={},le={};Object.defineProperty(le,"__esModule",{value:!0});le.dontSetMe=Io;le.findInArray=Wo;le.int=Ao;le.isFunction=ko;le.isNum=qo;function Wo(t,e){for(let r=0,n=t.length;r<n;r++)if(e.apply(e,[t[r],r,t]))return t[r]}function ko(t){return typeof t=="function"||Object.prototype.toString.call(t)==="[object Function]"}function qo(t){return typeof t=="number"&&!isNaN(t)}function Ao(t){return parseInt(t,10)}function Io(t,e,r){if(t[e])return new Error(`Invalid prop ${e} passed to ${r} - do not set this, set it on the child.`)}var Se={};Object.defineProperty(Se,"__esModule",{value:!0});Se.browserPrefixToKey=Br;Se.browserPrefixToStyle=Go;Se.default=void 0;Se.getPrefix=Gr;const ft=["Moz","Webkit","O","ms"];function Gr(){var r,n;let t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"transform";if(typeof window>"u")return"";const e=(n=(r=window.document)==null?void 0:r.documentElement)==null?void 0:n.style;if(!e||t in e)return"";for(let o=0;o<ft.length;o++)if(Br(t,ft[o])in e)return ft[o];return""}function Br(t,e){return e?`${e}${Bo(t)}`:t}function Go(t,e){return e?`-${e.toLowerCase()}-${t}`:t}function Bo(t){let e="",r=!0;for(let n=0;n<t.length;n++)r?(e+=t[n].toUpperCase(),r=!1):t[n]==="-"?r=!0:e+=t[n];return e}Se.default=Gr();Object.defineProperty($,"__esModule",{value:!0});$.addClassName=Xr;$.addEvent=Yo;$.addUserSelectStyles=ni;$.createCSSTransform=Qo;$.createSVGTransform=ei;$.getTouch=ti;$.getTouchIdentifier=ri;$.getTranslation=At;$.innerHeight=Ko;$.innerWidth=Zo;$.matchesSelector=Yr;$.matchesSelectorAndParentsTo=Fo;$.offsetXYFromParent=Jo;$.outerHeight=Uo;$.outerWidth=Vo;$.removeClassName=Ur;$.removeEvent=Xo;$.scheduleRemoveUserSelectStyles=oi;var ee=le,ur=Fr(Se);function Fr(t,e){if(typeof WeakMap=="function")var r=new WeakMap,n=new WeakMap;return(Fr=function(o,i){if(!i&&o&&o.__esModule)return o;var a,u,s={__proto__:null,default:o};if(o===null||typeof o!="object"&&typeof o!="function")return s;if(a=i?n:r){if(a.has(o))return a.get(o);a.set(o,s)}for(const l in o)l!=="default"&&{}.hasOwnProperty.call(o,l)&&((u=(a=Object.defineProperty)&&Object.getOwnPropertyDescriptor(o,l))&&(u.get||u.set)?a(s,l,u):s[l]=o[l]);return s})(t,e)}let Ge="";function Yr(t,e){return Ge||(Ge=(0,ee.findInArray)(["matches","webkitMatchesSelector","mozMatchesSelector","msMatchesSelector","oMatchesSelector"],function(r){return(0,ee.isFunction)(t[r])})),(0,ee.isFunction)(t[Ge])?t[Ge](e):!1}function Fo(t,e,r){let n=t;do{if(Yr(n,e))return!0;if(n===r)return!1;n=n.parentNode}while(n);return!1}function Yo(t,e,r,n){if(!t)return;const o={capture:!0,...n};t.addEventListener?t.addEventListener(e,r,o):t.attachEvent?t.attachEvent("on"+e,r):t["on"+e]=r}function Xo(t,e,r,n){if(!t)return;const o={capture:!0,...n};t.removeEventListener?t.removeEventListener(e,r,o):t.detachEvent?t.detachEvent("on"+e,r):t["on"+e]=null}function Uo(t){let e=t.clientHeight;const r=t.ownerDocument.defaultView.getComputedStyle(t);return e+=(0,ee.int)(r.borderTopWidth),e+=(0,ee.int)(r.borderBottomWidth),e}function Vo(t){let e=t.clientWidth;const r=t.ownerDocument.defaultView.getComputedStyle(t);return e+=(0,ee.int)(r.borderLeftWidth),e+=(0,ee.int)(r.borderRightWidth),e}function Ko(t){let e=t.clientHeight;const r=t.ownerDocument.defaultView.getComputedStyle(t);return e-=(0,ee.int)(r.paddingTop),e-=(0,ee.int)(r.paddingBottom),e}function Zo(t){let e=t.clientWidth;const r=t.ownerDocument.defaultView.getComputedStyle(t);return e-=(0,ee.int)(r.paddingLeft),e-=(0,ee.int)(r.paddingRight),e}function Jo(t,e,r){const o=e===e.ownerDocument.body?{left:0,top:0}:e.getBoundingClientRect(),i=(t.clientX+e.scrollLeft-o.left)/r,a=(t.clientY+e.scrollTop-o.top)/r;return{x:i,y:a}}function Qo(t,e){const r=At(t,e,"px");return{[(0,ur.browserPrefixToKey)("transform",ur.default)]:r}}function ei(t,e){return At(t,e,"")}function At(t,e,r){let{x:n,y:o}=t,i=`translate(${n}${r},${o}${r})`;if(e){const a=`${typeof e.x=="string"?e.x:e.x+r}`,u=`${typeof e.y=="string"?e.y:e.y+r}`;i=`translate(${a}, ${u})`+i}return i}function ti(t,e){return t.targetTouches&&(0,ee.findInArray)(t.targetTouches,r=>e===r.identifier)||t.changedTouches&&(0,ee.findInArray)(t.changedTouches,r=>e===r.identifier)}function ri(t){if(t.targetTouches&&t.targetTouches[0])return t.targetTouches[0].identifier;if(t.changedTouches&&t.changedTouches[0])return t.changedTouches[0].identifier}function ni(t){if(!t)return;let e=t.getElementById("react-draggable-style-el");e||(e=t.createElement("style"),e.type="text/css",e.id="react-draggable-style-el",e.innerHTML=`.react-draggable-transparent-selection *::-moz-selection {all: inherit;}
|
|
1
|
+
import{j as g,B as X,T as ze,j6 as Rn,j7 as Dn,aZ as Ie,j8 as _n,j9 as Sr,d$ as On,n as Rr,r as L,ja as rr,jb as Pn,dE as En,dF as zn,b7 as nr,u as Cn,A as Mn,v as Dr,m as _r,R as jn,s as B,b as Or,aj as Pr,aq as Tn,cb as Ln,h_ as Hn,h$ as $n,jc as Er,E as Nn,bY as Wn,k as or,aC as kn,jd as qn,cG as ir,a$ as An,b1 as In,ep as Gn,je as Bn,jf as zr,jg as Fn,jh as he,ji as Ct,g as Yn}from"./index-Cz4lAJ3Y.js";const Xn=({formData:t,actions:e,metricSeries:r,loading:n})=>g.jsxs(X,{children:[g.jsxs(X,{sx:o=>({display:"flex",flexDirection:"column",gap:o.spacing(3)}),children:[g.jsx(ze,{variant:"body2",color:"text.secondary",children:"Select a custom metric to see its value over time. This can help you understand the impact of your feature rollout on key outcomes, such as system performance, usage patterns or error rates."}),g.jsx(Rn,{value:t.metricName,onChange:e.handleSeriesChange,options:r,loading:n}),t.metricName?g.jsxs(g.Fragment,{children:[g.jsxs(Dn,{value:t.timeRange,onChange:e.setTimeRange,children:[g.jsx(Ie,{value:"hour",children:"Last hour"}),g.jsx(Ie,{value:"day",children:"Last 24 hours"}),g.jsx(Ie,{value:"week",children:"Last 7 days"}),g.jsx(Ie,{value:"month",children:"Last 30 days"})]}),g.jsx(_n,{value:t.aggregationMode,onChange:e.setAggregationMode,metricType:Sr(t.metricName)})]}):null]}),t.metricName?g.jsx(On,{sx:o=>({margin:o.spacing(1.5,0)}),control:g.jsx(Rr,{checked:t.yAxisMin==="zero",onChange:o=>e.setYAxisMin(o.target.checked?"zero":"auto")}),label:"Begin at zero"}):null]}),Un=({open:t,initialConfig:e})=>{const[r,n]=L.useState((e==null?void 0:e.title)||""),[o,i]=L.useState((e==null?void 0:e.metricName)||""),[a,u]=L.useState((e==null?void 0:e.timeRange)||"day"),[s,l]=L.useState((e==null?void 0:e.yAxisMin)||"auto"),[c,d]=L.useState((e==null?void 0:e.labelSelectors)||{}),[f,p]=L.useState((e==null?void 0:e.aggregationMode)||rr(o)),{data:{labels:b}}=Pn(o?{series:o,range:a,aggregationMode:f}:void 0);L.useEffect(()=>{t&&e?(n(e.title||""),i(e.metricName),u(e.timeRange),l(e.yAxisMin),d(e.labelSelectors),p(e.aggregationMode||rr(e.metricName))):t&&!e&&(n(""),i(""),u("day"),l("auto"),d({}),p("count"))},[t,e]);const D=w=>{i(w),d({});const y=Sr(w);y==="counter"?p("count"):y==="gauge"?p("avg"):y==="histogram"&&p("p50")},S=()=>({title:r||void 0,metricName:o,timeRange:a,yAxisMin:s,labelSelectors:c,aggregationMode:f}),h=o.length>0;return{formData:{title:r,metricName:o,timeRange:a,yAxisMin:s,aggregationMode:f,labelSelectors:c},actions:{setTitle:n,setMetricName:i,setTimeRange:u,setYAxisMin:l,setAggregationMode:p,setLabelSelectors:d,handleSeriesChange:D,getConfigToSave:S},isValid:h,currentAvailableLabels:b}},Vn=()=>{const t="api/admin/impact-metrics/config",{data:e,refetch:r,loading:n,error:o}=En(nr(t),()=>zn(nr(t),"impactMetricsConfig"));return{configs:(e==null?void 0:e.configs)||[],refetch:r,loading:n,error:o}},Kn=t=>{const e=t?`api/admin/projects/${t.projectId}/features/${t.featureName}/impact-metrics/config`:"api/admin/impact-metrics/config",{makeRequest:r,createRequest:n,errors:o,loading:i}=Cn({propagateErrors:!0}),a=L.useCallback(async s=>{const l=n(e,{method:"POST",body:JSON.stringify(s)},"updateImpactMetric");return r(l.caller,l.id)},[r,n]),u=L.useCallback(async s=>{const l=n(`${e}/${s}`,{method:"DELETE"},"deleteImpactMetric");return r(l.caller,l.id)},[r,n,e]);return{createImpactMetric:a,deleteImpactMetric:u,errors:o,loading:i}},de="*",Ba=()=>{const{configs:t,loading:e,error:r,refetch:n}=Vn(),{layout:o,charts:i}=L.useMemo(()=>({layout:t.map((p,b)=>{const D=b%2,S=Math.floor(b/2);return{i:p.id,x:D*6,y:S*2,w:6,h:2,minW:4,minH:2,maxW:12,maxH:8}}),charts:t}),[t]),{createImpactMetric:a,deleteImpactMetric:u,loading:s,errors:l}=Kn(),c=L.useCallback(async p=>{await a(p),n()},[a,n]),d=L.useCallback(async(p,b)=>{await a({...b,id:p}),n()},[t,a,n]),f=L.useCallback(async p=>{await u(p),n()},[t,u,n]);return{charts:i,layout:o,loading:e||s,error:r||Object.keys(l).length>0?l:void 0,addChart:c,updateChart:d,deleteChart:f}},Zn=({labelKey:t,options:e,value:r,onChange:n})=>{const o=r.includes(de),i=`autocomplete-${t}`,a=e.length>=1e3,u=[de,...e];return g.jsx(Mn,{multiple:!0,disableCloseOnSelect:!0,id:i,options:u,value:o?e:r,getOptionLabel:s=>s===de?"(Select all)":s,onChange:(s,l,c,d)=>{if((d==null?void 0:d.option)===de){n(o?[]:[de]);return}n(l.filter(f=>f!==de))},renderOption:(s,l,{selected:c})=>{const{key:d,...f}=s;return g.jsxs("li",{...f,children:[g.jsx(Rr,{size:"small",checked:l===de?o:c,style:{marginRight:8}}),l===de?g.jsx(ze,{component:"span",sx:{color:"text.secondary"},children:"Select all"}):l]},d||l)},renderTags:(s,l)=>{const d=s.slice(-5),f=s.length-5;return g.jsxs(g.Fragment,{children:[d.map((p,b)=>{const{key:D,...S}=l({index:b});return L.createElement(Dr,{...S,key:D,label:p,size:"small"})}),f>0?g.jsxs(ze,{component:"span",sx:{color:"text.secondary"},children:[" ","(+",f,")"]}):null]})},renderInput:s=>g.jsxs(g.Fragment,{children:[g.jsx(_r,{...s,label:t,placeholder:o?void 0:"Select values…",variant:"outlined",size:"small",inputProps:{...s.inputProps}}),a&&g.jsx(jn,{severity:"warning",sx:l=>({padding:l.spacing(1,2),marginTop:l.spacing(1)}),children:"Maximum of 1000 values loaded due to performance."})]})})},Jn=B(X)(({theme:t})=>({display:"flex",flexDirection:"column",gap:t.spacing(1),width:"100%"})),Qn=B(X)(({theme:t})=>({width:"100%",display:"flex",alignItems:"center",gap:t.spacing(1)})),eo=B(X)(({theme:t})=>({display:"grid",gridTemplateColumns:"repeat(auto-fill, minmax(250px, 1fr))",gap:t.spacing(2),flexGrow:1})),to=B(X)({display:"flex",flexDirection:"column",flexGrow:1}),ro=B(ze)({lineHeight:1.5,height:"24px"}),no=B(Dr)(({theme:t})=>({position:"relative",height:"20px",margin:t.spacing(-1,0)})),ar=({title:t,labels:e,labelSelectors:r,onLabelChange:n,onAllToggle:o,onChange:i})=>{const a=e.map(([l])=>l),u=a.some(l=>r[l]),s=()=>{const l={};Object.entries(r).forEach(([c,d])=>{a.includes(c)||(l[c]=d)}),i(l)};return g.jsxs(Jn,{children:[g.jsxs(Qn,{children:[g.jsx(ro,{variant:"subtitle2",children:t}),u&&g.jsx(no,{label:"Clear all",size:"small",variant:"outlined",onClick:s})]}),g.jsx(eo,{children:e.map(([l,c])=>{const d=r[l]||[];return g.jsx(to,{children:g.jsx(Zn,{labelKey:l,options:c,value:d,onChange:f=>n(l,f),handleAllToggle:o})},l)})})]})},sr=["environment","appName","origin"],oo=({labelSelectors:t,onChange:e,availableLabels:r})=>{const n=(u,s)=>{const l={...t};s.length===0?delete l[u]:l[u]=s,e(l)},o=(u,s)=>{const l={...t};s?l[u]=["*"]:delete l[u],e(l)};if(!r||Object.keys(r).length===0)return null;const i=Object.entries(r).filter(([u])=>sr.includes(u)).sort(),a=Object.entries(r).filter(([u])=>!sr.includes(u)).sort();return g.jsxs(X,{sx:{display:"flex",gap:2,flexWrap:"wrap"},children:[i.length>0&&g.jsx(ar,{title:"Filter by labels",labels:i,labelSelectors:t,onLabelChange:n,onAllToggle:o,onChange:e}),a.length>0&&g.jsx(ar,{title:"Flag specific filters",labels:a,labelSelectors:t,onLabelChange:n,onAllToggle:o,onChange:e})]})},io=B(X)(({theme:t})=>({display:"flex",flexDirection:"column",gap:t.spacing(3),[t.breakpoints.down("lg")]:{flex:"none"},[t.breakpoints.up("lg")]:{flex:"0 0 400px"}})),ao=B(X)(({theme:t})=>({flex:1,display:"flex",flexDirection:"column",gap:t.spacing(2),[t.breakpoints.down("lg")]:{minHeight:"300px"},[t.breakpoints.up("lg")]:{minHeight:"400px"}})),Fa=({open:t,onClose:e,onSave:r,initialConfig:n,metricSeries:o,loading:i=!1})=>{const{formData:a,actions:u,isValid:s,currentAvailableLabels:l}=Un({open:t,initialConfig:n}),c=Or(),d=Pr(c.breakpoints.down("lg")),{trackEvent:f}=Tn(),p=()=>{s&&(r(u.getConfigToSave()),f("impact-metrics",{props:{eventType:"chart added"}}),e())};return g.jsxs(Ln,{open:t,onClose:e,maxWidth:"lg",fullWidth:!0,sx:{"& .MuiDialog-paper":{minHeight:"600px",maxHeight:"90vh"}},children:[g.jsx(Hn,{children:n?"Edit Chart":"Add New Chart"}),g.jsxs($n,{children:[g.jsxs(X,{sx:b=>({display:"flex",flexDirection:{xs:"column",lg:"row"},gap:b.spacing(3),pt:b.spacing(1),height:"100%"}),children:[g.jsxs(io,{children:[g.jsx(_r,{label:"Chart Title (optional)",value:a.title,onChange:b=>u.setTitle(b.target.value),fullWidth:!0,variant:"outlined",size:"small"}),g.jsx(Xn,{formData:a,actions:u,metricSeries:o,loading:i})]}),g.jsx(ao,{children:g.jsx(X,{sx:b=>({padding:b.spacing(1)}),children:g.jsx(Er,{metricName:a.metricName,timeRange:a.timeRange,labelSelectors:a.labelSelectors,yAxisMin:a.yAxisMin,aggregationMode:a.aggregationMode,isPreview:!0},d?"small":"large")})})]}),l?g.jsx(oo,{labelSelectors:a.labelSelectors,onChange:u.setLabelSelectors,availableLabels:l}):null]}),g.jsx(Nn,{}),g.jsxs(Wn,{sx:b=>({margin:b.spacing(2,3,3)}),children:[g.jsx(or,{onClick:e,children:"Cancel"}),g.jsx(or,{onClick:p,variant:"contained",disabled:!s,children:n?"Update":"Add Chart"})]})]})},so=t=>{const e=[];t.displayName&&e.push(`${t.displayName}`),e.push(`last ${t.timeRange}`),e.push(t.aggregationMode);const r=Object.keys(t.labelSelectors).length;return r>0&&e.push(`${r} filter${r>1?"s":""}`),e.join(" • ")},lo=B(kn)(({theme:t})=>({borderRadius:`${t.shape.borderRadiusMedium}px`,boxShadow:"none",display:"flex",flexDirection:"column",height:"100%"})),uo=B(X)({flex:1,display:"flex",flexDirection:"column",minHeight:0}),co=B(X)(({theme:t})=>({position:"relative",minWidth:0,flexGrow:1,height:"100%",display:"flex",flexDirection:"column",margin:"auto 0",padding:t.spacing(3)})),fo=B(X)(({theme:t})=>({display:"flex",gap:t.spacing(1),alignItems:"center",padding:t.spacing(1.5,2),borderBottom:`1px solid ${t.palette.divider}`})),po=B(X)(({theme:t})=>({display:"flex",flexDirection:"column",justifyContent:"flex-end",flexGrow:1,overflow:"hidden",textOverflow:"ellipsis"})),ho=B(X)(({theme:t})=>({marginLeft:"auto",display:"flex",alignItems:"center",gap:t.spacing(.5)})),go=B(qn)(({theme:t})=>({alignSelf:"start",color:t.palette.primary.main,marginTop:t.spacing(.25)})),Ya=({config:t,onEdit:e,onDelete:r,permission:n=Gn,projectId:o,dragHandle:i,icon:a})=>g.jsxs(lo,{children:[g.jsxs(fo,{children:[i,t.mode==="read"?g.jsx(go,{}):null,g.jsxs(po,{children:[t.title&&g.jsx(ze,{variant:"h3",children:t.title}),g.jsx(ze,{variant:"body2",color:"text.secondary",children:so(t)})]}),a,t.mode!=="read"&&g.jsxs(ho,{children:[g.jsx(ir,{onClick:()=>e(t),permission:n,projectId:o,tooltipProps:{title:"Edit chart"},children:g.jsx(An,{})}),g.jsx(ir,{onClick:()=>r(t.id),permission:n,projectId:o,tooltipProps:{title:"Remove chart"},children:g.jsx(In,{})})]})]}),g.jsx(uo,{children:g.jsx(co,{children:g.jsx(Er,{metricName:t.metricName,timeRange:t.timeRange,labelSelectors:t.labelSelectors,yAxisMin:t.yAxisMin,aggregationMode:t.aggregationMode,aspectRatio:1.5,overrideOptions:{maintainAspectRatio:!1},emptyDataDescription:"Send impact metrics using Unleash SDK for this series to view the chart."})})})]});var Cr={exports:{}},We={},bt={exports:{}};(function(t,e){(function(r,n){n(e)})(Bn,function(r){function n(v){return function(T,M,j,W,I,te,k){return v(T,M,k)}}function o(v){return function(T,M,j,W){if(!T||!M||typeof T!="object"||typeof M!="object")return v(T,M,j,W);var I=W.get(T),te=W.get(M);if(I&&te)return I===M&&te===T;W.set(T,M),W.set(M,T);var k=v(T,M,j,W);return W.delete(T),W.delete(M),k}}function i(v,_){var T={};for(var M in v)T[M]=v[M];for(var M in _)T[M]=_[M];return T}function a(v){return v.constructor===Object||v.constructor==null}function u(v){return typeof v.then=="function"}function s(v,_){return v===_||v!==v&&_!==_}var l="[object Arguments]",c="[object Boolean]",d="[object Date]",f="[object RegExp]",p="[object Map]",b="[object Number]",D="[object Object]",S="[object Set]",h="[object String]",w=Object.prototype.toString;function y(v){var _=v.areArraysEqual,T=v.areDatesEqual,M=v.areMapsEqual,j=v.areObjectsEqual,W=v.areRegExpsEqual,I=v.areSetsEqual,te=v.createIsNestedEqual,k=te(ne);function ne(H,q,oe){if(H===q)return!0;if(!H||!q||typeof H!="object"||typeof q!="object")return H!==H&&q!==q;if(a(H)&&a(q))return j(H,q,k,oe);var er=Array.isArray(H),tr=Array.isArray(q);if(er||tr)return er===tr&&_(H,q,k,oe);var ie=w.call(H);return ie!==w.call(q)?!1:ie===d?T(H,q,k,oe):ie===f?W(H,q,k,oe):ie===p?M(H,q,k,oe):ie===S?I(H,q,k,oe):ie===D||ie===l?u(H)||u(q)?!1:j(H,q,k,oe):ie===c||ie===b||ie===h?s(H.valueOf(),q.valueOf()):!1}return ne}function x(v,_,T,M){var j=v.length;if(_.length!==j)return!1;for(;j-- >0;)if(!T(v[j],_[j],j,j,v,_,M))return!1;return!0}var m=o(x);function z(v,_){return s(v.valueOf(),_.valueOf())}function N(v,_,T,M){var j=v.size===_.size;if(!j)return!1;if(!v.size)return!0;var W={},I=0;return v.forEach(function(te,k){if(j){var ne=!1,H=0;_.forEach(function(q,oe){!ne&&!W[H]&&(ne=T(k,oe,I,H,v,_,M)&&T(te,q,k,oe,v,_,M))&&(W[H]=!0),H++}),I++,j=ne}}),j}var A=o(N),K="_owner",J=Object.prototype.hasOwnProperty;function Me(v,_,T,M){var j=Object.keys(v),W=j.length;if(Object.keys(_).length!==W)return!1;for(var I;W-- >0;){if(I=j[W],I===K){var te=!!v.$$typeof,k=!!_.$$typeof;if((te||k)&&te!==k)return!1}if(!J.call(_,I)||!T(v[I],_[I],I,I,v,_,M))return!1}return!0}var ct=o(Me);function je(v,_){return v.source===_.source&&v.flags===_.flags}function Te(v,_,T,M){var j=v.size===_.size;if(!j)return!1;if(!v.size)return!0;var W={};return v.forEach(function(I,te){if(j){var k=!1,ne=0;_.forEach(function(H,q){!k&&!W[ne]&&(k=T(I,H,te,q,v,_,M))&&(W[ne]=!0),ne++}),j=k}}),j}var Qt=o(Te),ge=Object.freeze({areArraysEqual:x,areDatesEqual:z,areMapsEqual:N,areObjectsEqual:Me,areRegExpsEqual:je,areSetsEqual:Te,createIsNestedEqual:n}),me=Object.freeze({areArraysEqual:m,areDatesEqual:z,areMapsEqual:A,areObjectsEqual:ct,areRegExpsEqual:je,areSetsEqual:Qt,createIsNestedEqual:n}),Ae=y(ge);function dt(v,_){return Ae(v,_,void 0)}var gn=y(i(ge,{createIsNestedEqual:function(){return s}}));function mn(v,_){return gn(v,_,void 0)}var yn=y(me);function vn(v,_){return yn(v,_,new WeakMap)}var bn=y(i(me,{createIsNestedEqual:function(){return s}}));function wn(v,_){return bn(v,_,new WeakMap)}function xn(v){return y(i(ge,v(ge)))}function Sn(v){var _=y(i(me,v(me)));return function(T,M,j){return j===void 0&&(j=new WeakMap),_(T,M,j)}}r.circularDeepEqual=vn,r.circularShallowEqual=wn,r.createCustomCircularEqual=Sn,r.createCustomEqual=xn,r.deepEqual=dt,r.sameValueZeroEqual=s,r.shallowEqual=mn,Object.defineProperty(r,"__esModule",{value:!0})})})(bt,bt.exports);var Mt=bt.exports;const Ze=zr(Fn);var E={},mo=function(e,r,n){return e===r?!0:e.className===r.className&&n(e.style,r.style)&&e.width===r.width&&e.autoSize===r.autoSize&&e.cols===r.cols&&e.draggableCancel===r.draggableCancel&&e.draggableHandle===r.draggableHandle&&n(e.verticalCompact,r.verticalCompact)&&n(e.compactType,r.compactType)&&n(e.layout,r.layout)&&n(e.margin,r.margin)&&n(e.containerPadding,r.containerPadding)&&e.rowHeight===r.rowHeight&&e.maxRows===r.maxRows&&e.isBounded===r.isBounded&&e.isDraggable===r.isDraggable&&e.isResizable===r.isResizable&&e.allowOverlap===r.allowOverlap&&e.preventCollision===r.preventCollision&&e.useCSSTransforms===r.useCSSTransforms&&e.transformScale===r.transformScale&&e.isDroppable===r.isDroppable&&n(e.resizeHandles,r.resizeHandles)&&n(e.resizeHandle,r.resizeHandle)&&e.onLayoutChange===r.onLayoutChange&&e.onDragStart===r.onDragStart&&e.onDrag===r.onDrag&&e.onDragStop===r.onDragStop&&e.onResizeStart===r.onResizeStart&&e.onResize===r.onResize&&e.onResizeStop===r.onResizeStop&&e.onDrop===r.onDrop&&n(e.droppingItem,r.droppingItem)&&n(e.innerRef,r.innerRef)};Object.defineProperty(E,"__esModule",{value:!0});E.bottom=jt;E.childrenEqual=bo;E.cloneLayout=Mr;E.cloneLayoutItem=xe;E.collides=Je;E.compact=Tr;E.compactItem=Lr;E.compactType=To;E.correctBounds=Hr;E.fastPositionEqual=wo;E.fastRGLPropsEqual=void 0;E.getAllCollisions=$r;E.getFirstCollision=be;E.getLayoutItem=Tt;E.getStatics=Lt;E.modifyLayout=jr;E.moveElement=Ne;E.moveElementAwayFromCollision=xt;E.noop=void 0;E.perc=So;E.resizeItemInDirection=Eo;E.setTopLeft=Co;E.setTransform=zo;E.sortLayoutItems=qt;E.sortLayoutItemsByColRow=Ar;E.sortLayoutItemsByRowCol=qr;E.synchronizeLayoutWithChildren=Mo;E.validateLayout=jo;E.withLayoutItem=vo;var lr=Mt,$e=yo(L);function yo(t){return t&&t.__esModule?t:{default:t}}function jt(t){let e=0,r;for(let n=0,o=t.length;n<o;n++)r=t[n].y+t[n].h,r>e&&(e=r);return e}function Mr(t){const e=Array(t.length);for(let r=0,n=t.length;r<n;r++)e[r]=xe(t[r]);return e}function jr(t,e){const r=Array(t.length);for(let n=0,o=t.length;n<o;n++)e.i===t[n].i?r[n]=e:r[n]=t[n];return r}function vo(t,e,r){let n=Tt(t,e);return n?(n=r(xe(n)),t=jr(t,n),[t,n]):[t,null]}function xe(t){return{w:t.w,h:t.h,x:t.x,y:t.y,i:t.i,minW:t.minW,maxW:t.maxW,minH:t.minH,maxH:t.maxH,moved:!!t.moved,static:!!t.static,isDraggable:t.isDraggable,isResizable:t.isResizable,resizeHandles:t.resizeHandles,isBounded:t.isBounded}}function bo(t,e){return(0,lr.deepEqual)($e.default.Children.map(t,r=>r==null?void 0:r.key),$e.default.Children.map(e,r=>r==null?void 0:r.key))&&(0,lr.deepEqual)($e.default.Children.map(t,r=>r==null?void 0:r.props["data-grid"]),$e.default.Children.map(e,r=>r==null?void 0:r.props["data-grid"]))}E.fastRGLPropsEqual=mo;function wo(t,e){return t.left===e.left&&t.top===e.top&&t.width===e.width&&t.height===e.height}function Je(t,e){return!(t.i===e.i||t.x+t.w<=e.x||t.x>=e.x+e.w||t.y+t.h<=e.y||t.y>=e.y+e.h)}function Tr(t,e,r,n){const o=Lt(t),i=qt(t,e),a=Array(t.length);for(let u=0,s=i.length;u<s;u++){let l=xe(i[u]);l.static||(l=Lr(o,l,e,r,i,n),o.push(l)),a[t.indexOf(i[u])]=l,l.moved=!1}return a}const xo={x:"w",y:"h"};function wt(t,e,r,n){const o=xo[n];e[n]+=1;const i=t.map(a=>a.i).indexOf(e.i);for(let a=i+1;a<t.length;a++){const u=t[a];if(!u.static){if(u.y>e.y+e.h)break;Je(e,u)&&wt(t,u,r+e[o],n)}}e[n]=r}function Lr(t,e,r,n,o,i){const a=r==="vertical",u=r==="horizontal";if(a)for(e.y=Math.min(jt(t),e.y);e.y>0&&!be(t,e);)e.y--;else if(u)for(;e.x>0&&!be(t,e);)e.x--;let s;for(;(s=be(t,e))&&!(r===null&&i);)if(u?wt(o,e,s.x+s.w,"x"):wt(o,e,s.y+s.h,"y"),u&&e.x+e.w>n)for(e.x=n-e.w,e.y++;e.x>0&&!be(t,e);)e.x--;return e.y=Math.max(e.y,0),e.x=Math.max(e.x,0),e}function Hr(t,e){const r=Lt(t);for(let n=0,o=t.length;n<o;n++){const i=t[n];if(i.x+i.w>e.cols&&(i.x=e.cols-i.w),i.x<0&&(i.x=0,i.w=e.cols),!i.static)r.push(i);else for(;be(r,i);)i.y++}return t}function Tt(t,e){for(let r=0,n=t.length;r<n;r++)if(t[r].i===e)return t[r]}function be(t,e){for(let r=0,n=t.length;r<n;r++)if(Je(t[r],e))return t[r]}function $r(t,e){return t.filter(r=>Je(r,e))}function Lt(t){return t.filter(e=>e.static)}function Ne(t,e,r,n,o,i,a,u,s){if(e.static&&e.isDraggable!==!0||e.y===n&&e.x===r)return t;`${e.i}${String(r)}${String(n)}${e.x}${e.y}`;const l=e.x,c=e.y;typeof r=="number"&&(e.x=r),typeof n=="number"&&(e.y=n),e.moved=!0;let d=qt(t,a);(a==="vertical"&&typeof n=="number"?c>=n:a==="horizontal"&&typeof r=="number"?l>=r:!1)&&(d=d.reverse());const p=$r(d,e),b=p.length>0;if(b&&s)return Mr(t);if(b&&i)return`${e.i}`,e.x=l,e.y=c,e.moved=!1,t;for(let D=0,S=p.length;D<S;D++){const h=p[D];`${e.i}${e.x}${e.y}${h.i}${h.x}${h.y}`,!h.moved&&(h.static?t=xt(t,h,e,o,a):t=xt(t,e,h,o,a))}return t}function xt(t,e,r,n,o,i){const a=o==="horizontal",u=o==="vertical",s=e.static;if(n){n=!1;const d={x:a?Math.max(e.x-r.w,0):r.x,y:u?Math.max(e.y-r.h,0):r.y,w:r.w,h:r.h,i:"-1"},f=be(t,d),p=f&&f.y+f.h>e.y,b=f&&e.x+e.w>f.x;if(f){if(p&&u)return Ne(t,r,void 0,e.y+1,n,s,o);if(p&&o==null)return e.y=r.y,r.y=r.y+r.h,t;if(b&&a)return Ne(t,e,r.x,void 0,n,s,o)}else return`${r.i}${d.x}${d.y}`,Ne(t,r,a?d.x:void 0,u?d.y:void 0,n,s,o)}const l=a?r.x+1:void 0,c=u?r.y+1:void 0;return l==null&&c==null?t:Ne(t,r,a?r.x+1:void 0,u?r.y+1:void 0,n,s,o)}function So(t){return t*100+"%"}const Nr=(t,e,r,n)=>t+r>n?e:r,Wr=(t,e,r)=>t<0?e:r,kr=t=>Math.max(0,t),Ht=t=>Math.max(0,t),$t=(t,e,r)=>{let{left:n,height:o,width:i}=e;const a=t.top-(o-t.height);return{left:n,width:i,height:Wr(a,t.height,o),top:Ht(a)}},Nt=(t,e,r)=>{let{top:n,left:o,height:i,width:a}=e;return{top:n,height:i,width:Nr(t.left,t.width,a,r),left:kr(o)}},Wt=(t,e,r)=>{let{top:n,height:o,width:i}=e;const a=t.left-(i-t.width);return{height:o,width:a<0?t.width:Nr(t.left,t.width,i,r),top:Ht(n),left:kr(a)}},kt=(t,e,r)=>{let{top:n,left:o,height:i,width:a}=e;return{width:a,left:o,height:Wr(n,t.height,i),top:Ht(n)}},Ro=function(){return $t(arguments.length<=0?void 0:arguments[0],Nt(...arguments))},Do=function(){return $t(arguments.length<=0?void 0:arguments[0],Wt(...arguments))},_o=function(){return kt(arguments.length<=0?void 0:arguments[0],Nt(...arguments))},Oo=function(){return kt(arguments.length<=0?void 0:arguments[0],Wt(...arguments))},Po={n:$t,ne:Ro,e:Nt,se:_o,s:kt,sw:Oo,w:Wt,nw:Do};function Eo(t,e,r,n){const o=Po[t];return o?o(e,{...e,...r},n):r}function zo(t){let{top:e,left:r,width:n,height:o}=t;const i=`translate(${r}px,${e}px)`;return{transform:i,WebkitTransform:i,MozTransform:i,msTransform:i,OTransform:i,width:`${n}px`,height:`${o}px`,position:"absolute"}}function Co(t){let{top:e,left:r,width:n,height:o}=t;return{top:`${e}px`,left:`${r}px`,width:`${n}px`,height:`${o}px`,position:"absolute"}}function qt(t,e){return e==="horizontal"?Ar(t):e==="vertical"?qr(t):t}function qr(t){return t.slice(0).sort(function(e,r){return e.y>r.y||e.y===r.y&&e.x>r.x?1:e.y===r.y&&e.x===r.x?0:-1})}function Ar(t){return t.slice(0).sort(function(e,r){return e.x>r.x||e.x===r.x&&e.y>r.y?1:-1})}function Mo(t,e,r,n,o){t=t||[];const i=[];$e.default.Children.forEach(e,u=>{if((u==null?void 0:u.key)==null)return;const s=Tt(t,String(u.key)),l=u.props["data-grid"];s&&l==null?i.push(xe(s)):l?i.push(xe({...l,i:u.key})):i.push(xe({w:1,h:1,x:0,y:jt(i),i:String(u.key)}))});const a=Hr(i,{cols:r});return o?a:Tr(a,n,r)}function jo(t){let e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:"Layout";const r=["x","y","w","h"];if(!Array.isArray(t))throw new Error(e+" must be an array!");for(let n=0,o=t.length;n<o;n++){const i=t[n];for(let a=0;a<r.length;a++){const u=r[a],s=i[u];if(typeof s!="number"||Number.isNaN(s))throw new Error(`ReactGridLayout: ${e}[${n}].${u} must be a number! Received: ${s} (${typeof s})`)}if(typeof i.i<"u"&&typeof i.i!="string")throw new Error(`ReactGridLayout: ${e}[${n}].i must be a string! Received: ${i.i} (${typeof i.i})`)}}function To(t){const{verticalCompact:e,compactType:r}=t||{};return e===!1?null:r}const Lo=()=>{};E.noop=Lo;var se={};Object.defineProperty(se,"__esModule",{value:!0});se.calcGridColWidth=Qe;se.calcGridItemPosition=Ho;se.calcGridItemWHPx=St;se.calcWH=No;se.calcXY=$o;se.clamp=we;function Qe(t){const{margin:e,containerPadding:r,containerWidth:n,cols:o}=t;return(n-e[0]*(o-1)-r[0]*2)/o}function St(t,e,r){return Number.isFinite(t)?Math.round(e*t+Math.max(0,t-1)*r):t}function Ho(t,e,r,n,o,i){const{margin:a,containerPadding:u,rowHeight:s}=t,l=Qe(t),c={};return i&&i.resizing?(c.width=Math.round(i.resizing.width),c.height=Math.round(i.resizing.height)):(c.width=St(n,l,a[0]),c.height=St(o,s,a[1])),i&&i.dragging?(c.top=Math.round(i.dragging.top),c.left=Math.round(i.dragging.left)):i&&i.resizing&&typeof i.resizing.top=="number"&&typeof i.resizing.left=="number"?(c.top=Math.round(i.resizing.top),c.left=Math.round(i.resizing.left)):(c.top=Math.round((s+a[1])*r+u[1]),c.left=Math.round((l+a[0])*e+u[0])),c}function $o(t,e,r,n,o){const{margin:i,containerPadding:a,cols:u,rowHeight:s,maxRows:l}=t,c=Qe(t);let d=Math.round((r-a[0])/(c+i[0])),f=Math.round((e-a[1])/(s+i[1]));return d=we(d,0,u-n),f=we(f,0,l-o),{x:d,y:f}}function No(t,e,r,n,o,i){const{margin:a,maxRows:u,cols:s,rowHeight:l}=t,c=Qe(t);let d=Math.round((e+a[0])/(c+a[0])),f=Math.round((r+a[1])/(l+a[1])),p=we(d,0,s-n),b=we(f,0,u-o);return["sw","w","nw"].indexOf(i)!==-1&&(p=we(d,0,s)),["nw","n","ne"].indexOf(i)!==-1&&(b=we(f,0,u)),{w:p,h:b}}function we(t,e,r){return Math.max(Math.min(t,r),e)}var et={},tt={exports:{}},Ir={},$={},le={};Object.defineProperty(le,"__esModule",{value:!0});le.dontSetMe=Io;le.findInArray=Wo;le.int=Ao;le.isFunction=ko;le.isNum=qo;function Wo(t,e){for(let r=0,n=t.length;r<n;r++)if(e.apply(e,[t[r],r,t]))return t[r]}function ko(t){return typeof t=="function"||Object.prototype.toString.call(t)==="[object Function]"}function qo(t){return typeof t=="number"&&!isNaN(t)}function Ao(t){return parseInt(t,10)}function Io(t,e,r){if(t[e])return new Error(`Invalid prop ${e} passed to ${r} - do not set this, set it on the child.`)}var Se={};Object.defineProperty(Se,"__esModule",{value:!0});Se.browserPrefixToKey=Br;Se.browserPrefixToStyle=Go;Se.default=void 0;Se.getPrefix=Gr;const ft=["Moz","Webkit","O","ms"];function Gr(){var r,n;let t=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"transform";if(typeof window>"u")return"";const e=(n=(r=window.document)==null?void 0:r.documentElement)==null?void 0:n.style;if(!e||t in e)return"";for(let o=0;o<ft.length;o++)if(Br(t,ft[o])in e)return ft[o];return""}function Br(t,e){return e?`${e}${Bo(t)}`:t}function Go(t,e){return e?`-${e.toLowerCase()}-${t}`:t}function Bo(t){let e="",r=!0;for(let n=0;n<t.length;n++)r?(e+=t[n].toUpperCase(),r=!1):t[n]==="-"?r=!0:e+=t[n];return e}Se.default=Gr();Object.defineProperty($,"__esModule",{value:!0});$.addClassName=Xr;$.addEvent=Yo;$.addUserSelectStyles=ni;$.createCSSTransform=Qo;$.createSVGTransform=ei;$.getTouch=ti;$.getTouchIdentifier=ri;$.getTranslation=At;$.innerHeight=Ko;$.innerWidth=Zo;$.matchesSelector=Yr;$.matchesSelectorAndParentsTo=Fo;$.offsetXYFromParent=Jo;$.outerHeight=Uo;$.outerWidth=Vo;$.removeClassName=Ur;$.removeEvent=Xo;$.scheduleRemoveUserSelectStyles=oi;var ee=le,ur=Fr(Se);function Fr(t,e){if(typeof WeakMap=="function")var r=new WeakMap,n=new WeakMap;return(Fr=function(o,i){if(!i&&o&&o.__esModule)return o;var a,u,s={__proto__:null,default:o};if(o===null||typeof o!="object"&&typeof o!="function")return s;if(a=i?n:r){if(a.has(o))return a.get(o);a.set(o,s)}for(const l in o)l!=="default"&&{}.hasOwnProperty.call(o,l)&&((u=(a=Object.defineProperty)&&Object.getOwnPropertyDescriptor(o,l))&&(u.get||u.set)?a(s,l,u):s[l]=o[l]);return s})(t,e)}let Ge="";function Yr(t,e){return Ge||(Ge=(0,ee.findInArray)(["matches","webkitMatchesSelector","mozMatchesSelector","msMatchesSelector","oMatchesSelector"],function(r){return(0,ee.isFunction)(t[r])})),(0,ee.isFunction)(t[Ge])?t[Ge](e):!1}function Fo(t,e,r){let n=t;do{if(Yr(n,e))return!0;if(n===r)return!1;n=n.parentNode}while(n);return!1}function Yo(t,e,r,n){if(!t)return;const o={capture:!0,...n};t.addEventListener?t.addEventListener(e,r,o):t.attachEvent?t.attachEvent("on"+e,r):t["on"+e]=r}function Xo(t,e,r,n){if(!t)return;const o={capture:!0,...n};t.removeEventListener?t.removeEventListener(e,r,o):t.detachEvent?t.detachEvent("on"+e,r):t["on"+e]=null}function Uo(t){let e=t.clientHeight;const r=t.ownerDocument.defaultView.getComputedStyle(t);return e+=(0,ee.int)(r.borderTopWidth),e+=(0,ee.int)(r.borderBottomWidth),e}function Vo(t){let e=t.clientWidth;const r=t.ownerDocument.defaultView.getComputedStyle(t);return e+=(0,ee.int)(r.borderLeftWidth),e+=(0,ee.int)(r.borderRightWidth),e}function Ko(t){let e=t.clientHeight;const r=t.ownerDocument.defaultView.getComputedStyle(t);return e-=(0,ee.int)(r.paddingTop),e-=(0,ee.int)(r.paddingBottom),e}function Zo(t){let e=t.clientWidth;const r=t.ownerDocument.defaultView.getComputedStyle(t);return e-=(0,ee.int)(r.paddingLeft),e-=(0,ee.int)(r.paddingRight),e}function Jo(t,e,r){const o=e===e.ownerDocument.body?{left:0,top:0}:e.getBoundingClientRect(),i=(t.clientX+e.scrollLeft-o.left)/r,a=(t.clientY+e.scrollTop-o.top)/r;return{x:i,y:a}}function Qo(t,e){const r=At(t,e,"px");return{[(0,ur.browserPrefixToKey)("transform",ur.default)]:r}}function ei(t,e){return At(t,e,"")}function At(t,e,r){let{x:n,y:o}=t,i=`translate(${n}${r},${o}${r})`;if(e){const a=`${typeof e.x=="string"?e.x:e.x+r}`,u=`${typeof e.y=="string"?e.y:e.y+r}`;i=`translate(${a}, ${u})`+i}return i}function ti(t,e){return t.targetTouches&&(0,ee.findInArray)(t.targetTouches,r=>e===r.identifier)||t.changedTouches&&(0,ee.findInArray)(t.changedTouches,r=>e===r.identifier)}function ri(t){if(t.targetTouches&&t.targetTouches[0])return t.targetTouches[0].identifier;if(t.changedTouches&&t.changedTouches[0])return t.changedTouches[0].identifier}function ni(t){if(!t)return;let e=t.getElementById("react-draggable-style-el");e||(e=t.createElement("style"),e.type="text/css",e.id="react-draggable-style-el",e.innerHTML=`.react-draggable-transparent-selection *::-moz-selection {all: inherit;}
|
|
2
2
|
`,e.innerHTML+=`.react-draggable-transparent-selection *::selection {all: inherit;}
|
|
3
3
|
`,t.getElementsByTagName("head")[0].appendChild(e)),t.body&&Xr(t.body,"react-draggable-transparent-selection")}function oi(t){window.requestAnimationFrame?window.requestAnimationFrame(()=>{cr(t)}):cr(t)}function cr(t){if(t)try{if(t.body&&Ur(t.body,"react-draggable-transparent-selection"),t.selection)t.selection.empty();else{const e=(t.defaultView||window).getSelection();e&&e.type!=="Caret"&&e.removeAllRanges()}}catch{}}function Xr(t,e){t.classList?t.classList.add(e):t.className.match(new RegExp(`(?:^|\\s)${e}(?!\\S)`))||(t.className+=` ${e}`)}function Ur(t,e){t.classList?t.classList.remove(e):t.className=t.className.replace(new RegExp(`(?:^|\\s)${e}(?!\\S)`,"g"),"")}var ue={};Object.defineProperty(ue,"__esModule",{value:!0});ue.canDragX=si;ue.canDragY=li;ue.createCoreData=ci;ue.createDraggableData=di;ue.getBoundPosition=ii;ue.getControlPosition=ui;ue.snapToGrid=ai;var Q=le,Pe=$;function ii(t,e,r){if(!t.props.bounds)return[e,r];let{bounds:n}=t.props;n=typeof n=="string"?n:fi(n);const o=It(t);if(typeof n=="string"){const{ownerDocument:i}=o,a=i.defaultView;let u;if(n==="parent"?u=o.parentNode:u=o.getRootNode().querySelector(n),!(u instanceof a.HTMLElement))throw new Error('Bounds selector "'+n+'" could not find an element.');const s=u,l=a.getComputedStyle(o),c=a.getComputedStyle(s);n={left:-o.offsetLeft+(0,Q.int)(c.paddingLeft)+(0,Q.int)(l.marginLeft),top:-o.offsetTop+(0,Q.int)(c.paddingTop)+(0,Q.int)(l.marginTop),right:(0,Pe.innerWidth)(s)-(0,Pe.outerWidth)(o)-o.offsetLeft+(0,Q.int)(c.paddingRight)-(0,Q.int)(l.marginRight),bottom:(0,Pe.innerHeight)(s)-(0,Pe.outerHeight)(o)-o.offsetTop+(0,Q.int)(c.paddingBottom)-(0,Q.int)(l.marginBottom)}}return(0,Q.isNum)(n.right)&&(e=Math.min(e,n.right)),(0,Q.isNum)(n.bottom)&&(r=Math.min(r,n.bottom)),(0,Q.isNum)(n.left)&&(e=Math.max(e,n.left)),(0,Q.isNum)(n.top)&&(r=Math.max(r,n.top)),[e,r]}function ai(t,e,r){const n=Math.round(e/t[0])*t[0],o=Math.round(r/t[1])*t[1];return[n,o]}function si(t){return t.props.axis==="both"||t.props.axis==="x"}function li(t){return t.props.axis==="both"||t.props.axis==="y"}function ui(t,e,r){const n=typeof e=="number"?(0,Pe.getTouch)(t,e):null;if(typeof e=="number"&&!n)return null;const o=It(r),i=r.props.offsetParent||o.offsetParent||o.ownerDocument.body;return(0,Pe.offsetXYFromParent)(n||t,i,r.props.scale)}function ci(t,e,r){const n=!(0,Q.isNum)(t.lastX),o=It(t);return n?{node:o,deltaX:0,deltaY:0,lastX:e,lastY:r,x:e,y:r}:{node:o,deltaX:e-t.lastX,deltaY:r-t.lastY,lastX:t.lastX,lastY:t.lastY,x:e,y:r}}function di(t,e){const r=t.props.scale;return{node:e.node,x:t.state.x+e.deltaX/r,y:t.state.y+e.deltaY/r,deltaX:e.deltaX/r,deltaY:e.deltaY/r,lastX:t.state.x,lastY:t.state.y}}function fi(t){return{left:t.left,top:t.top,right:t.right,bottom:t.bottom}}function It(t){const e=t.findDOMNode();if(!e)throw new Error("<DraggableCore>: Unmounted during event!");return e}var rt={},nt={};Object.defineProperty(nt,"__esModule",{value:!0});nt.default=pi;function pi(){}Object.defineProperty(rt,"__esModule",{value:!0});rt.default=void 0;var pt=Vr(L),U=Gt(he),hi=Gt(Ct),F=$,fe=ue,ht=le,Le=Gt(nt);function Gt(t){return t&&t.__esModule?t:{default:t}}function Vr(t,e){if(typeof WeakMap=="function")var r=new WeakMap,n=new WeakMap;return(Vr=function(o,i){if(!i&&o&&o.__esModule)return o;var a,u,s={__proto__:null,default:o};if(o===null||typeof o!="object"&&typeof o!="function")return s;if(a=i?n:r){if(a.has(o))return a.get(o);a.set(o,s)}for(const l in o)l!=="default"&&{}.hasOwnProperty.call(o,l)&&((u=(a=Object.defineProperty)&&Object.getOwnPropertyDescriptor(o,l))&&(u.get||u.set)?a(s,l,u):s[l]=o[l]);return s})(t,e)}function V(t,e,r){return(e=gi(e))in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function gi(t){var e=mi(t,"string");return typeof e=="symbol"?e:e+""}function mi(t,e){if(typeof t!="object"||!t)return t;var r=t[Symbol.toPrimitive];if(r!==void 0){var n=r.call(t,e||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(t)}const re={touch:{start:"touchstart",move:"touchmove",stop:"touchend"},mouse:{start:"mousedown",move:"mousemove",stop:"mouseup"}};let pe=re.mouse,ot=class extends pt.Component{constructor(){super(...arguments),V(this,"dragging",!1),V(this,"lastX",NaN),V(this,"lastY",NaN),V(this,"touchIdentifier",null),V(this,"mounted",!1),V(this,"handleDragStart",e=>{if(this.props.onMouseDown(e),!this.props.allowAnyClick&&typeof e.button=="number"&&e.button!==0)return!1;const r=this.findDOMNode();if(!r||!r.ownerDocument||!r.ownerDocument.body)throw new Error("<DraggableCore> not mounted on DragStart!");const{ownerDocument:n}=r;if(this.props.disabled||!(e.target instanceof n.defaultView.Node)||this.props.handle&&!(0,F.matchesSelectorAndParentsTo)(e.target,this.props.handle,r)||this.props.cancel&&(0,F.matchesSelectorAndParentsTo)(e.target,this.props.cancel,r))return;e.type==="touchstart"&&!this.props.allowMobileScroll&&e.preventDefault();const o=(0,F.getTouchIdentifier)(e);this.touchIdentifier=o;const i=(0,fe.getControlPosition)(e,o,this);if(i==null)return;const{x:a,y:u}=i,s=(0,fe.createCoreData)(this,a,u);(0,Le.default)("DraggableCore: handleDragStart: %j",s),(0,Le.default)("calling",this.props.onStart),!(this.props.onStart(e,s)===!1||this.mounted===!1)&&(this.props.enableUserSelectHack&&(0,F.addUserSelectStyles)(n),this.dragging=!0,this.lastX=a,this.lastY=u,(0,F.addEvent)(n,pe.move,this.handleDrag),(0,F.addEvent)(n,pe.stop,this.handleDragStop))}),V(this,"handleDrag",e=>{const r=(0,fe.getControlPosition)(e,this.touchIdentifier,this);if(r==null)return;let{x:n,y:o}=r;if(Array.isArray(this.props.grid)){let u=n-this.lastX,s=o-this.lastY;if([u,s]=(0,fe.snapToGrid)(this.props.grid,u,s),!u&&!s)return;n=this.lastX+u,o=this.lastY+s}const i=(0,fe.createCoreData)(this,n,o);if((0,Le.default)("DraggableCore: handleDrag: %j",i),this.props.onDrag(e,i)===!1||this.mounted===!1){try{this.handleDragStop(new MouseEvent("mouseup"))}catch{const s=document.createEvent("MouseEvents");s.initMouseEvent("mouseup",!0,!0,window,0,0,0,0,0,!1,!1,!1,!1,0,null),this.handleDragStop(s)}return}this.lastX=n,this.lastY=o}),V(this,"handleDragStop",e=>{if(!this.dragging)return;const r=(0,fe.getControlPosition)(e,this.touchIdentifier,this);if(r==null)return;let{x:n,y:o}=r;if(Array.isArray(this.props.grid)){let s=n-this.lastX||0,l=o-this.lastY||0;[s,l]=(0,fe.snapToGrid)(this.props.grid,s,l),n=this.lastX+s,o=this.lastY+l}const i=(0,fe.createCoreData)(this,n,o);if(this.props.onStop(e,i)===!1||this.mounted===!1)return!1;const u=this.findDOMNode();u&&this.props.enableUserSelectHack&&(0,F.scheduleRemoveUserSelectStyles)(u.ownerDocument),(0,Le.default)("DraggableCore: handleDragStop: %j",i),this.dragging=!1,this.lastX=NaN,this.lastY=NaN,u&&((0,Le.default)("DraggableCore: Removing handlers"),(0,F.removeEvent)(u.ownerDocument,pe.move,this.handleDrag),(0,F.removeEvent)(u.ownerDocument,pe.stop,this.handleDragStop))}),V(this,"onMouseDown",e=>(pe=re.mouse,this.handleDragStart(e))),V(this,"onMouseUp",e=>(pe=re.mouse,this.handleDragStop(e))),V(this,"onTouchStart",e=>(pe=re.touch,this.handleDragStart(e))),V(this,"onTouchEnd",e=>(pe=re.touch,this.handleDragStop(e)))}componentDidMount(){this.mounted=!0;const e=this.findDOMNode();e&&(0,F.addEvent)(e,re.touch.start,this.onTouchStart,{passive:!1})}componentWillUnmount(){this.mounted=!1;const e=this.findDOMNode();if(e){const{ownerDocument:r}=e;(0,F.removeEvent)(r,re.mouse.move,this.handleDrag),(0,F.removeEvent)(r,re.touch.move,this.handleDrag),(0,F.removeEvent)(r,re.mouse.stop,this.handleDragStop),(0,F.removeEvent)(r,re.touch.stop,this.handleDragStop),(0,F.removeEvent)(e,re.touch.start,this.onTouchStart,{passive:!1}),this.props.enableUserSelectHack&&(0,F.scheduleRemoveUserSelectStyles)(r)}}findDOMNode(){var e,r,n;return(e=this.props)!=null&&e.nodeRef?(n=(r=this.props)==null?void 0:r.nodeRef)==null?void 0:n.current:hi.default.findDOMNode(this)}render(){return pt.cloneElement(pt.Children.only(this.props.children),{onMouseDown:this.onMouseDown,onMouseUp:this.onMouseUp,onTouchEnd:this.onTouchEnd})}};rt.default=ot;V(ot,"displayName","DraggableCore");V(ot,"propTypes",{allowAnyClick:U.default.bool,allowMobileScroll:U.default.bool,children:U.default.node.isRequired,disabled:U.default.bool,enableUserSelectHack:U.default.bool,offsetParent:function(t,e){if(t[e]&&t[e].nodeType!==1)throw new Error("Draggable's offsetParent must be a DOM Node.")},grid:U.default.arrayOf(U.default.number),handle:U.default.string,cancel:U.default.string,nodeRef:U.default.object,onStart:U.default.func,onDrag:U.default.func,onStop:U.default.func,onMouseDown:U.default.func,scale:U.default.number,className:ht.dontSetMe,style:ht.dontSetMe,transform:ht.dontSetMe});V(ot,"defaultProps",{allowAnyClick:!1,allowMobileScroll:!1,disabled:!1,enableUserSelectHack:!0,onStart:function(){},onDrag:function(){},onStop:function(){},onMouseDown:function(){},scale:1});(function(t){Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"DraggableCore",{enumerable:!0,get:function(){return s.default}}),t.default=void 0;var e=d(L),r=c(he),n=c(Ct),o=Ze,i=$,a=ue,u=le,s=c(rt),l=c(nt);function c(h){return h&&h.__esModule?h:{default:h}}function d(h,w){if(typeof WeakMap=="function")var y=new WeakMap,x=new WeakMap;return(d=function(m,z){if(!z&&m&&m.__esModule)return m;var N,A,K={__proto__:null,default:m};if(m===null||typeof m!="object"&&typeof m!="function")return K;if(N=z?x:y){if(N.has(m))return N.get(m);N.set(m,K)}for(const J in m)J!=="default"&&{}.hasOwnProperty.call(m,J)&&((A=(N=Object.defineProperty)&&Object.getOwnPropertyDescriptor(m,J))&&(A.get||A.set)?N(K,J,A):K[J]=m[J]);return K})(h,w)}function f(){return f=Object.assign?Object.assign.bind():function(h){for(var w=1;w<arguments.length;w++){var y=arguments[w];for(var x in y)({}).hasOwnProperty.call(y,x)&&(h[x]=y[x])}return h},f.apply(null,arguments)}function p(h,w,y){return(w=b(w))in h?Object.defineProperty(h,w,{value:y,enumerable:!0,configurable:!0,writable:!0}):h[w]=y,h}function b(h){var w=D(h,"string");return typeof w=="symbol"?w:w+""}function D(h,w){if(typeof h!="object"||!h)return h;var y=h[Symbol.toPrimitive];if(y!==void 0){var x=y.call(h,w||"default");if(typeof x!="object")return x;throw new TypeError("@@toPrimitive must return a primitive value.")}return(w==="string"?String:Number)(h)}class S extends e.Component{static getDerivedStateFromProps(w,y){let{position:x}=w,{prevPropsPosition:m}=y;return x&&(!m||x.x!==m.x||x.y!==m.y)?((0,l.default)("Draggable: getDerivedStateFromProps %j",{position:x,prevPropsPosition:m}),{x:x.x,y:x.y,prevPropsPosition:{...x}}):null}constructor(w){super(w),p(this,"onDragStart",(y,x)=>{if((0,l.default)("Draggable: onDragStart: %j",x),this.props.onStart(y,(0,a.createDraggableData)(this,x))===!1)return!1;this.setState({dragging:!0,dragged:!0})}),p(this,"onDrag",(y,x)=>{if(!this.state.dragging)return!1;(0,l.default)("Draggable: onDrag: %j",x);const m=(0,a.createDraggableData)(this,x),z={x:m.x,y:m.y,slackX:0,slackY:0};if(this.props.bounds){const{x:A,y:K}=z;z.x+=this.state.slackX,z.y+=this.state.slackY;const[J,Me]=(0,a.getBoundPosition)(this,z.x,z.y);z.x=J,z.y=Me,z.slackX=this.state.slackX+(A-z.x),z.slackY=this.state.slackY+(K-z.y),m.x=z.x,m.y=z.y,m.deltaX=z.x-this.state.x,m.deltaY=z.y-this.state.y}if(this.props.onDrag(y,m)===!1)return!1;this.setState(z)}),p(this,"onDragStop",(y,x)=>{if(!this.state.dragging||this.props.onStop(y,(0,a.createDraggableData)(this,x))===!1)return!1;(0,l.default)("Draggable: onDragStop: %j",x);const z={dragging:!1,slackX:0,slackY:0};if(!!this.props.position){const{x:A,y:K}=this.props.position;z.x=A,z.y=K}this.setState(z)}),this.state={dragging:!1,dragged:!1,x:w.position?w.position.x:w.defaultPosition.x,y:w.position?w.position.y:w.defaultPosition.y,prevPropsPosition:{...w.position},slackX:0,slackY:0,isElementSVG:!1},w.position&&!(w.onDrag||w.onStop)&&console.warn("A `position` was applied to this <Draggable>, without drag handlers. This will make this component effectively undraggable. Please attach `onDrag` or `onStop` handlers so you can adjust the `position` of this element.")}componentDidMount(){typeof window.SVGElement<"u"&&this.findDOMNode()instanceof window.SVGElement&&this.setState({isElementSVG:!0})}componentWillUnmount(){this.state.dragging&&this.setState({dragging:!1})}findDOMNode(){var w,y;return((y=(w=this.props)==null?void 0:w.nodeRef)==null?void 0:y.current)??n.default.findDOMNode(this)}render(){const{axis:w,bounds:y,children:x,defaultPosition:m,defaultClassName:z,defaultClassNameDragging:N,defaultClassNameDragged:A,position:K,positionOffset:J,scale:Me,...ct}=this.props;let je={},Te=null;const ge=!!!K||this.state.dragging,me=K||m,Ae={x:(0,a.canDragX)(this)&&ge?this.state.x:me.x,y:(0,a.canDragY)(this)&&ge?this.state.y:me.y};this.state.isElementSVG?Te=(0,i.createSVGTransform)(Ae,J):je=(0,i.createCSSTransform)(Ae,J);const dt=(0,o.clsx)(x.props.className||"",z,{[N]:this.state.dragging,[A]:this.state.dragged});return e.createElement(s.default,f({},ct,{onStart:this.onDragStart,onDrag:this.onDrag,onStop:this.onDragStop}),e.cloneElement(e.Children.only(x),{className:dt,style:{...x.props.style,...je},transform:Te}))}}t.default=S,p(S,"displayName","Draggable"),p(S,"propTypes",{...s.default.propTypes,axis:r.default.oneOf(["both","x","y","none"]),bounds:r.default.oneOfType([r.default.shape({left:r.default.number,right:r.default.number,top:r.default.number,bottom:r.default.number}),r.default.string,r.default.oneOf([!1])]),defaultClassName:r.default.string,defaultClassNameDragging:r.default.string,defaultClassNameDragged:r.default.string,defaultPosition:r.default.shape({x:r.default.number,y:r.default.number}),positionOffset:r.default.shape({x:r.default.oneOfType([r.default.number,r.default.string]),y:r.default.oneOfType([r.default.number,r.default.string])}),position:r.default.shape({x:r.default.number,y:r.default.number}),className:u.dontSetMe,style:u.dontSetMe,transform:u.dontSetMe}),p(S,"defaultProps",{...s.default.defaultProps,axis:"both",bounds:!1,defaultClassName:"react-draggable",defaultClassNameDragging:"react-draggable-dragging",defaultClassNameDragged:"react-draggable-dragged",defaultPosition:{x:0,y:0},scale:1})})(Ir);const{default:Kr,DraggableCore:yi}=Ir;tt.exports=Kr;tt.exports.default=Kr;tt.exports.DraggableCore=yi;var Zr=tt.exports,it={exports:{}},ke={},Bt={};Bt.__esModule=!0;Bt.cloneElement=Ri;var vi=bi(L);function bi(t){return t&&t.__esModule?t:{default:t}}function dr(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter(function(o){return Object.getOwnPropertyDescriptor(t,o).enumerable})),r.push.apply(r,n)}return r}function fr(t){for(var e=1;e<arguments.length;e++){var r=arguments[e]!=null?arguments[e]:{};e%2?dr(Object(r),!0).forEach(function(n){wi(t,n,r[n])}):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(r)):dr(Object(r)).forEach(function(n){Object.defineProperty(t,n,Object.getOwnPropertyDescriptor(r,n))})}return t}function wi(t,e,r){return e=xi(e),e in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function xi(t){var e=Si(t,"string");return typeof e=="symbol"?e:String(e)}function Si(t,e){if(typeof t!="object"||t===null)return t;var r=t[Symbol.toPrimitive];if(r!==void 0){var n=r.call(t,e||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(t)}function Ri(t,e){return e.style&&t.props.style&&(e.style=fr(fr({},t.props.style),e.style)),e.className&&t.props.className&&(e.className=t.props.className+" "+e.className),vi.default.cloneElement(t,e)}var qe={};qe.__esModule=!0;qe.resizableProps=void 0;var O=Di(he);function Di(t){return t&&t.__esModule?t:{default:t}}var _i={axis:O.default.oneOf(["both","x","y","none"]),className:O.default.string,children:O.default.element.isRequired,draggableOpts:O.default.shape({allowAnyClick:O.default.bool,cancel:O.default.string,children:O.default.node,disabled:O.default.bool,enableUserSelectHack:O.default.bool,offsetParent:O.default.node,grid:O.default.arrayOf(O.default.number),handle:O.default.string,nodeRef:O.default.object,onStart:O.default.func,onDrag:O.default.func,onStop:O.default.func,onMouseDown:O.default.func,scale:O.default.number}),height:function(){for(var e=arguments.length,r=new Array(e),n=0;n<e;n++)r[n]=arguments[n];var o=r[0];if(o.axis==="both"||o.axis==="y"){var i;return(i=O.default.number).isRequired.apply(i,r)}return O.default.number.apply(O.default,r)},handle:O.default.oneOfType([O.default.node,O.default.func]),handleSize:O.default.arrayOf(O.default.number),lockAspectRatio:O.default.bool,maxConstraints:O.default.arrayOf(O.default.number),minConstraints:O.default.arrayOf(O.default.number),onResizeStop:O.default.func,onResizeStart:O.default.func,onResize:O.default.func,resizeHandles:O.default.arrayOf(O.default.oneOf(["s","w","e","n","sw","nw","se","ne"])),transformScale:O.default.number,width:function(){for(var e=arguments.length,r=new Array(e),n=0;n<e;n++)r[n]=arguments[n];var o=r[0];if(o.axis==="both"||o.axis==="x"){var i;return(i=O.default.number).isRequired.apply(i,r)}return O.default.number.apply(O.default,r)}};qe.resizableProps=_i;ke.__esModule=!0;ke.default=void 0;var He=Ci(L),Oi=Zr,Pi=Bt,Ei=qe,zi=["children","className","draggableOpts","width","height","handle","handleSize","lockAspectRatio","axis","minConstraints","maxConstraints","onResize","onResizeStop","onResizeStart","resizeHandles","transformScale"];function Jr(t){if(typeof WeakMap!="function")return null;var e=new WeakMap,r=new WeakMap;return(Jr=function(o){return o?r:e})(t)}function Ci(t,e){if(t&&t.__esModule)return t;if(t===null||typeof t!="object"&&typeof t!="function")return{default:t};var r=Jr(e);if(r&&r.has(t))return r.get(t);var n={},o=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var i in t)if(i!=="default"&&Object.prototype.hasOwnProperty.call(t,i)){var a=o?Object.getOwnPropertyDescriptor(t,i):null;a&&(a.get||a.set)?Object.defineProperty(n,i,a):n[i]=t[i]}return n.default=t,r&&r.set(t,n),n}function Rt(){return Rt=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(t[n]=r[n])}return t},Rt.apply(this,arguments)}function Mi(t,e){if(t==null)return{};var r={},n=Object.keys(t),o,i;for(i=0;i<n.length;i++)o=n[i],!(e.indexOf(o)>=0)&&(r[o]=t[o]);return r}function pr(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter(function(o){return Object.getOwnPropertyDescriptor(t,o).enumerable})),r.push.apply(r,n)}return r}function gt(t){for(var e=1;e<arguments.length;e++){var r=arguments[e]!=null?arguments[e]:{};e%2?pr(Object(r),!0).forEach(function(n){ji(t,n,r[n])}):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(r)):pr(Object(r)).forEach(function(n){Object.defineProperty(t,n,Object.getOwnPropertyDescriptor(r,n))})}return t}function ji(t,e,r){return e=Ti(e),e in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function Ti(t){var e=Li(t,"string");return typeof e=="symbol"?e:String(e)}function Li(t,e){if(typeof t!="object"||t===null)return t;var r=t[Symbol.toPrimitive];if(r!==void 0){var n=r.call(t,e||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(t)}function Hi(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,Dt(t,e)}function Dt(t,e){return Dt=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(n,o){return n.__proto__=o,n},Dt(t,e)}var Ft=function(t){Hi(e,t);function e(){for(var n,o=arguments.length,i=new Array(o),a=0;a<o;a++)i[a]=arguments[a];return n=t.call.apply(t,[this].concat(i))||this,n.handleRefs={},n.lastHandleRect=null,n.slack=null,n}var r=e.prototype;return r.componentWillUnmount=function(){this.resetData()},r.resetData=function(){this.lastHandleRect=this.slack=null},r.runConstraints=function(o,i){var a=this.props,u=a.minConstraints,s=a.maxConstraints,l=a.lockAspectRatio;if(!u&&!s&&!l)return[o,i];if(l){var c=this.props.width/this.props.height,d=o-this.props.width,f=i-this.props.height;Math.abs(d)>Math.abs(f*c)?i=o/c:o=i*c}var p=o,b=i,D=this.slack||[0,0],S=D[0],h=D[1];return o+=S,i+=h,u&&(o=Math.max(u[0],o),i=Math.max(u[1],i)),s&&(o=Math.min(s[0],o),i=Math.min(s[1],i)),this.slack=[S+(p-o),h+(b-i)],[o,i]},r.resizeHandler=function(o,i){var a=this;return function(u,s){var l=s.node,c=s.deltaX,d=s.deltaY;o==="onResizeStart"&&a.resetData();var f=(a.props.axis==="both"||a.props.axis==="x")&&i!=="n"&&i!=="s",p=(a.props.axis==="both"||a.props.axis==="y")&&i!=="e"&&i!=="w";if(!(!f&&!p)){var b=i[0],D=i[i.length-1],S=l.getBoundingClientRect();if(a.lastHandleRect!=null){if(D==="w"){var h=S.left-a.lastHandleRect.left;c+=h}if(b==="n"){var w=S.top-a.lastHandleRect.top;d+=w}}a.lastHandleRect=S,D==="w"&&(c=-c),b==="n"&&(d=-d);var y=a.props.width+(f?c/a.props.transformScale:0),x=a.props.height+(p?d/a.props.transformScale:0),m=a.runConstraints(y,x);y=m[0],x=m[1];var z=y!==a.props.width||x!==a.props.height,N=typeof a.props[o]=="function"?a.props[o]:null,A=o==="onResize"&&!z;N&&!A&&(u.persist==null||u.persist(),N(u,{node:l,size:{width:y,height:x},handle:i})),o==="onResizeStop"&&a.resetData()}}},r.renderResizeHandle=function(o,i){var a=this.props.handle;if(!a)return He.createElement("span",{className:"react-resizable-handle react-resizable-handle-"+o,ref:i});if(typeof a=="function")return a(o,i);var u=typeof a.type=="string",s=gt({ref:i},u?{}:{handleAxis:o});return He.cloneElement(a,s)},r.render=function(){var o=this,i=this.props,a=i.children,u=i.className,s=i.draggableOpts;i.width,i.height,i.handle,i.handleSize,i.lockAspectRatio,i.axis,i.minConstraints,i.maxConstraints,i.onResize,i.onResizeStop,i.onResizeStart;var l=i.resizeHandles;i.transformScale;var c=Mi(i,zi);return(0,Pi.cloneElement)(a,gt(gt({},c),{},{className:(u?u+" ":"")+"react-resizable",children:[].concat(a.props.children,l.map(function(d){var f,p=(f=o.handleRefs[d])!=null?f:o.handleRefs[d]=He.createRef();return He.createElement(Oi.DraggableCore,Rt({},s,{nodeRef:p,key:"resizableHandle-"+d,onStop:o.resizeHandler("onResizeStop",d),onStart:o.resizeHandler("onResizeStart",d),onDrag:o.resizeHandler("onResize",d)}),o.renderResizeHandle(d,p))}))}))},e}(He.Component);ke.default=Ft;Ft.propTypes=Ei.resizableProps;Ft.defaultProps={axis:"both",handleSize:[20,20],lockAspectRatio:!1,minConstraints:[20,20],maxConstraints:[1/0,1/0],resizeHandles:["se"],transformScale:1};var at={};at.__esModule=!0;at.default=void 0;var mt=qi(L),$i=Qr(he),Ni=Qr(ke),Wi=qe,ki=["handle","handleSize","onResize","onResizeStart","onResizeStop","draggableOpts","minConstraints","maxConstraints","lockAspectRatio","axis","width","height","resizeHandles","style","transformScale"];function Qr(t){return t&&t.__esModule?t:{default:t}}function en(t){if(typeof WeakMap!="function")return null;var e=new WeakMap,r=new WeakMap;return(en=function(o){return o?r:e})(t)}function qi(t,e){if(t&&t.__esModule)return t;if(t===null||typeof t!="object"&&typeof t!="function")return{default:t};var r=en(e);if(r&&r.has(t))return r.get(t);var n={},o=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var i in t)if(i!=="default"&&Object.prototype.hasOwnProperty.call(t,i)){var a=o?Object.getOwnPropertyDescriptor(t,i):null;a&&(a.get||a.set)?Object.defineProperty(n,i,a):n[i]=t[i]}return n.default=t,r&&r.set(t,n),n}function _t(){return _t=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(t[n]=r[n])}return t},_t.apply(this,arguments)}function hr(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter(function(o){return Object.getOwnPropertyDescriptor(t,o).enumerable})),r.push.apply(r,n)}return r}function Xe(t){for(var e=1;e<arguments.length;e++){var r=arguments[e]!=null?arguments[e]:{};e%2?hr(Object(r),!0).forEach(function(n){Ai(t,n,r[n])}):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(r)):hr(Object(r)).forEach(function(n){Object.defineProperty(t,n,Object.getOwnPropertyDescriptor(r,n))})}return t}function Ai(t,e,r){return e=Ii(e),e in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function Ii(t){var e=Gi(t,"string");return typeof e=="symbol"?e:String(e)}function Gi(t,e){if(typeof t!="object"||t===null)return t;var r=t[Symbol.toPrimitive];if(r!==void 0){var n=r.call(t,e||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(t)}function Bi(t,e){if(t==null)return{};var r={},n=Object.keys(t),o,i;for(i=0;i<n.length;i++)o=n[i],!(e.indexOf(o)>=0)&&(r[o]=t[o]);return r}function Fi(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,Ot(t,e)}function Ot(t,e){return Ot=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(n,o){return n.__proto__=o,n},Ot(t,e)}var tn=function(t){Fi(e,t);function e(){for(var n,o=arguments.length,i=new Array(o),a=0;a<o;a++)i[a]=arguments[a];return n=t.call.apply(t,[this].concat(i))||this,n.state={width:n.props.width,height:n.props.height,propsWidth:n.props.width,propsHeight:n.props.height},n.onResize=function(u,s){var l=s.size;n.props.onResize?(u.persist==null||u.persist(),n.setState(l,function(){return n.props.onResize&&n.props.onResize(u,s)})):n.setState(l)},n}e.getDerivedStateFromProps=function(o,i){return i.propsWidth!==o.width||i.propsHeight!==o.height?{width:o.width,height:o.height,propsWidth:o.width,propsHeight:o.height}:null};var r=e.prototype;return r.render=function(){var o=this.props,i=o.handle,a=o.handleSize;o.onResize;var u=o.onResizeStart,s=o.onResizeStop,l=o.draggableOpts,c=o.minConstraints,d=o.maxConstraints,f=o.lockAspectRatio,p=o.axis;o.width,o.height;var b=o.resizeHandles,D=o.style,S=o.transformScale,h=Bi(o,ki);return mt.createElement(Ni.default,{axis:p,draggableOpts:l,handle:i,handleSize:a,height:this.state.height,lockAspectRatio:f,maxConstraints:d,minConstraints:c,onResizeStart:u,onResize:this.onResize,onResizeStop:s,resizeHandles:b,transformScale:S,width:this.state.width},mt.createElement("div",_t({},h,{style:Xe(Xe({},D),{},{width:this.state.width+"px",height:this.state.height+"px"})})))},e}(mt.Component);at.default=tn;tn.propTypes=Xe(Xe({},Wi.resizableProps),{},{children:$i.default.element});it.exports=function(){throw new Error("Don't instantiate Resizable directly! Use require('react-resizable').Resizable")};it.exports.Resizable=ke.default;it.exports.ResizableBox=at.default;var Yi=it.exports,ce={};Object.defineProperty(ce,"__esModule",{value:!0});ce.resizeHandleType=ce.resizeHandleAxesType=ce.default=void 0;var P=rn(he),Xi=rn(L);function rn(t){return t&&t.__esModule?t:{default:t}}const Ui=ce.resizeHandleAxesType=P.default.arrayOf(P.default.oneOf(["s","w","e","n","sw","nw","se","ne"])),Vi=ce.resizeHandleType=P.default.oneOfType([P.default.node,P.default.func]);ce.default={className:P.default.string,style:P.default.object,width:P.default.number,autoSize:P.default.bool,cols:P.default.number,draggableCancel:P.default.string,draggableHandle:P.default.string,verticalCompact:function(t){t.verticalCompact},compactType:P.default.oneOf(["vertical","horizontal"]),layout:function(t){var e=t.layout;e!==void 0&&E.validateLayout(e,"layout")},margin:P.default.arrayOf(P.default.number),containerPadding:P.default.arrayOf(P.default.number),rowHeight:P.default.number,maxRows:P.default.number,isBounded:P.default.bool,isDraggable:P.default.bool,isResizable:P.default.bool,allowOverlap:P.default.bool,preventCollision:P.default.bool,useCSSTransforms:P.default.bool,transformScale:P.default.number,isDroppable:P.default.bool,resizeHandles:Ui,resizeHandle:Vi,onLayoutChange:P.default.func,onDragStart:P.default.func,onDrag:P.default.func,onDragStop:P.default.func,onResizeStart:P.default.func,onResize:P.default.func,onResizeStop:P.default.func,onDrop:P.default.func,droppingItem:P.default.shape({i:P.default.string.isRequired,w:P.default.number.isRequired,h:P.default.number.isRequired}),children:function(t,e){const r=t[e],n={};Xi.default.Children.forEach(r,function(o){if((o==null?void 0:o.key)!=null){if(n[o.key])throw new Error('Duplicate child key "'+o.key+'" found! This will cause problems in ReactGridLayout.');n[o.key]=!0}})},innerRef:P.default.any};Object.defineProperty(et,"__esModule",{value:!0});et.default=void 0;var De=Yt(L),gr=Ct,C=Yt(he),Ki=Zr,Zi=Yi,_e=E,G=se,mr=ce,Ji=Yt(Ze);function Yt(t){return t&&t.__esModule?t:{default:t}}function ae(t,e,r){return(e=Qi(e))in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function Qi(t){var e=ea(t,"string");return typeof e=="symbol"?e:e+""}function ea(t,e){if(typeof t!="object"||!t)return t;var r=t[Symbol.toPrimitive];if(r!==void 0){var n=r.call(t,e||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(t)}class Xt extends De.default.Component{constructor(){super(...arguments),ae(this,"state",{resizing:null,dragging:null,className:""}),ae(this,"elementRef",De.default.createRef()),ae(this,"onDragStart",(e,r)=>{let{node:n}=r;const{onDragStart:o,transformScale:i}=this.props;if(!o)return;const a={top:0,left:0},{offsetParent:u}=n;if(!u)return;const s=u.getBoundingClientRect(),l=n.getBoundingClientRect(),c=l.left/i,d=s.left/i,f=l.top/i,p=s.top/i;a.left=c-d+u.scrollLeft,a.top=f-p+u.scrollTop,this.setState({dragging:a});const{x:b,y:D}=(0,G.calcXY)(this.getPositionParams(),a.top,a.left,this.props.w,this.props.h);return o.call(this,this.props.i,b,D,{e,node:n,newPosition:a})}),ae(this,"onDrag",(e,r,n)=>{let{node:o,deltaX:i,deltaY:a}=r;const{onDrag:u}=this.props;if(!u)return;if(!this.state.dragging)throw new Error("onDrag called before onDragStart.");let s=this.state.dragging.top+a,l=this.state.dragging.left+i;const{isBounded:c,i:d,w:f,h:p,containerWidth:b}=this.props,D=this.getPositionParams();if(c){const{offsetParent:y}=o;if(y){const{margin:x,rowHeight:m}=this.props,z=y.clientHeight-(0,G.calcGridItemWHPx)(p,m,x[1]);s=(0,G.clamp)(s,0,z);const N=(0,G.calcGridColWidth)(D),A=b-(0,G.calcGridItemWHPx)(f,N,x[0]);l=(0,G.clamp)(l,0,A)}}const S={top:s,left:l};n?this.setState({dragging:S}):(0,gr.flushSync)(()=>{this.setState({dragging:S})});const{x:h,y:w}=(0,G.calcXY)(D,s,l,f,p);return u.call(this,d,h,w,{e,node:o,newPosition:S})}),ae(this,"onDragStop",(e,r)=>{let{node:n}=r;const{onDragStop:o}=this.props;if(!o)return;if(!this.state.dragging)throw new Error("onDragEnd called before onDragStart.");const{w:i,h:a,i:u}=this.props,{left:s,top:l}=this.state.dragging,c={top:l,left:s};this.setState({dragging:null});const{x:d,y:f}=(0,G.calcXY)(this.getPositionParams(),l,s,i,a);return o.call(this,u,d,f,{e,node:n,newPosition:c})}),ae(this,"onResizeStop",(e,r,n)=>this.onResizeHandler(e,r,n,"onResizeStop")),ae(this,"onResizeStart",(e,r,n)=>this.onResizeHandler(e,r,n,"onResizeStart")),ae(this,"onResize",(e,r,n)=>this.onResizeHandler(e,r,n,"onResize"))}shouldComponentUpdate(e,r){if(this.props.children!==e.children||this.props.droppingPosition!==e.droppingPosition)return!0;const n=(0,G.calcGridItemPosition)(this.getPositionParams(this.props),this.props.x,this.props.y,this.props.w,this.props.h,this.state),o=(0,G.calcGridItemPosition)(this.getPositionParams(e),e.x,e.y,e.w,e.h,r);return!(0,_e.fastPositionEqual)(n,o)||this.props.useCSSTransforms!==e.useCSSTransforms}componentDidMount(){this.moveDroppingItem({})}componentDidUpdate(e){this.moveDroppingItem(e)}moveDroppingItem(e){const{droppingPosition:r}=this.props;if(!r)return;const n=this.elementRef.current;if(!n)return;const o=e.droppingPosition||{left:0,top:0},{dragging:i}=this.state,a=i&&r.left!==o.left||r.top!==o.top;if(!i)this.onDragStart(r.e,{node:n,deltaX:r.left,deltaY:r.top});else if(a){const u=r.left-i.left,s=r.top-i.top;this.onDrag(r.e,{node:n,deltaX:u,deltaY:s},!0)}}getPositionParams(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:this.props;return{cols:e.cols,containerPadding:e.containerPadding,containerWidth:e.containerWidth,margin:e.margin,maxRows:e.maxRows,rowHeight:e.rowHeight}}createStyle(e){const{usePercentages:r,containerWidth:n,useCSSTransforms:o}=this.props;let i;return o?i=(0,_e.setTransform)(e):(i=(0,_e.setTopLeft)(e),r&&(i.left=(0,_e.perc)(e.left/n),i.width=(0,_e.perc)(e.width/n))),i}mixinDraggable(e,r){return De.default.createElement(Ki.DraggableCore,{disabled:!r,onStart:this.onDragStart,onDrag:this.onDrag,onStop:this.onDragStop,handle:this.props.handle,cancel:".react-resizable-handle"+(this.props.cancel?","+this.props.cancel:""),scale:this.props.transformScale,nodeRef:this.elementRef},e)}curryResizeHandler(e,r){return(n,o)=>r(n,o,e)}mixinResizable(e,r,n){const{cols:o,minW:i,minH:a,maxW:u,maxH:s,transformScale:l,resizeHandles:c,resizeHandle:d}=this.props,f=this.getPositionParams(),p=(0,G.calcGridItemPosition)(f,0,0,o,0).width,b=(0,G.calcGridItemPosition)(f,0,0,i,a),D=(0,G.calcGridItemPosition)(f,0,0,u,s),S=[b.width,b.height],h=[Math.min(D.width,p),Math.min(D.height,1/0)];return De.default.createElement(Zi.Resizable,{draggableOpts:{disabled:!n},className:n?void 0:"react-resizable-hide",width:r.width,height:r.height,minConstraints:S,maxConstraints:h,onResizeStop:this.curryResizeHandler(r,this.onResizeStop),onResizeStart:this.curryResizeHandler(r,this.onResizeStart),onResize:this.curryResizeHandler(r,this.onResize),transformScale:l,resizeHandles:c,handle:d},e)}onResizeHandler(e,r,n,o){let{node:i,size:a,handle:u}=r;const s=this.props[o];if(!s)return;const{x:l,y:c,i:d,maxH:f,minH:p,containerWidth:b}=this.props,{minW:D,maxW:S}=this.props;let h=a;i&&(h=(0,_e.resizeItemInDirection)(u,n,a,b),(0,gr.flushSync)(()=>{this.setState({resizing:o==="onResizeStop"?null:h})}));let{w,h:y}=(0,G.calcWH)(this.getPositionParams(),h.width,h.height,l,c,u);w=(0,G.clamp)(w,Math.max(D,1),S),y=(0,G.clamp)(y,p,f),s.call(this,d,w,y,{e,node:i,size:h,handle:u})}render(){const{x:e,y:r,w:n,h:o,isDraggable:i,isResizable:a,droppingPosition:u,useCSSTransforms:s}=this.props,l=(0,G.calcGridItemPosition)(this.getPositionParams(),e,r,n,o,this.state),c=De.default.Children.only(this.props.children);let d=De.default.cloneElement(c,{ref:this.elementRef,className:(0,Ji.default)("react-grid-item",c.props.className,this.props.className,{static:this.props.static,resizing:!!this.state.resizing,"react-draggable":i,"react-draggable-dragging":!!this.state.dragging,dropping:!!u,cssTransforms:s}),style:{...this.props.style,...c.props.style,...this.createStyle(l)}});return d=this.mixinResizable(d,l,a),d=this.mixinDraggable(d,i),d}}et.default=Xt;ae(Xt,"propTypes",{children:C.default.element,cols:C.default.number.isRequired,containerWidth:C.default.number.isRequired,rowHeight:C.default.number.isRequired,margin:C.default.array.isRequired,maxRows:C.default.number.isRequired,containerPadding:C.default.array.isRequired,x:C.default.number.isRequired,y:C.default.number.isRequired,w:C.default.number.isRequired,h:C.default.number.isRequired,minW:function(t,e){const r=t[e];if(typeof r!="number")return new Error("minWidth not Number");if(r>t.w||r>t.maxW)return new Error("minWidth larger than item width/maxWidth")},maxW:function(t,e){const r=t[e];if(typeof r!="number")return new Error("maxWidth not Number");if(r<t.w||r<t.minW)return new Error("maxWidth smaller than item width/minWidth")},minH:function(t,e){const r=t[e];if(typeof r!="number")return new Error("minHeight not Number");if(r>t.h||r>t.maxH)return new Error("minHeight larger than item height/maxHeight")},maxH:function(t,e){const r=t[e];if(typeof r!="number")return new Error("maxHeight not Number");if(r<t.h||r<t.minH)return new Error("maxHeight smaller than item height/minHeight")},i:C.default.string.isRequired,resizeHandles:mr.resizeHandleAxesType,resizeHandle:mr.resizeHandleType,onDragStop:C.default.func,onDragStart:C.default.func,onDrag:C.default.func,onResizeStop:C.default.func,onResizeStart:C.default.func,onResize:C.default.func,isDraggable:C.default.bool.isRequired,isResizable:C.default.bool.isRequired,isBounded:C.default.bool.isRequired,static:C.default.bool,useCSSTransforms:C.default.bool.isRequired,transformScale:C.default.number,className:C.default.string,handle:C.default.string,cancel:C.default.string,droppingPosition:C.default.shape({e:C.default.object.isRequired,left:C.default.number.isRequired,top:C.default.number.isRequired})});ae(Xt,"defaultProps",{className:"",cancel:"",handle:"",minH:1,minW:1,maxH:1/0,maxW:1/0,transformScale:1});Object.defineProperty(We,"__esModule",{value:!0});We.default=void 0;var ye=nn(L),yt=Mt,ta=Ut(Ze),R=E,ra=se,yr=Ut(et),na=Ut(ce);function Ut(t){return t&&t.__esModule?t:{default:t}}function nn(t,e){if(typeof WeakMap=="function")var r=new WeakMap,n=new WeakMap;return(nn=function(o,i){if(!i&&o&&o.__esModule)return o;var a,u,s={__proto__:null,default:o};if(o===null||typeof o!="object"&&typeof o!="function")return s;if(a=i?n:r){if(a.has(o))return a.get(o);a.set(o,s)}for(const l in o)l!=="default"&&{}.hasOwnProperty.call(o,l)&&((u=(a=Object.defineProperty)&&Object.getOwnPropertyDescriptor(o,l))&&(u.get||u.set)?a(s,l,u):s[l]=o[l]);return s})(t,e)}function Y(t,e,r){return(e=oa(e))in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function oa(t){var e=ia(t,"string");return typeof e=="symbol"?e:e+""}function ia(t,e){if(typeof t!="object"||!t)return t;var r=t[Symbol.toPrimitive];if(r!==void 0){var n=r.call(t,e||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(t)}const vr="react-grid-layout";let on=!1;try{on=/firefox/i.test(navigator.userAgent)}catch{}class st extends ye.Component{constructor(){super(...arguments),Y(this,"state",{activeDrag:null,layout:(0,R.synchronizeLayoutWithChildren)(this.props.layout,this.props.children,this.props.cols,(0,R.compactType)(this.props),this.props.allowOverlap),mounted:!1,oldDragItem:null,oldLayout:null,oldResizeItem:null,resizing:!1,droppingDOMNode:null,children:[]}),Y(this,"dragEnterCounter",0),Y(this,"onDragStart",(e,r,n,o)=>{let{e:i,node:a}=o;const{layout:u}=this.state,s=(0,R.getLayoutItem)(u,e);if(!s)return;const l={w:s.w,h:s.h,x:s.x,y:s.y,placeholder:!0,i:e};return this.setState({oldDragItem:(0,R.cloneLayoutItem)(s),oldLayout:u,activeDrag:l}),this.props.onDragStart(u,s,s,null,i,a)}),Y(this,"onDrag",(e,r,n,o)=>{let{e:i,node:a}=o;const{oldDragItem:u}=this.state;let{layout:s}=this.state;const{cols:l,allowOverlap:c,preventCollision:d}=this.props,f=(0,R.getLayoutItem)(s,e);if(!f)return;const p={w:f.w,h:f.h,x:f.x,y:f.y,placeholder:!0,i:e};s=(0,R.moveElement)(s,f,r,n,!0,d,(0,R.compactType)(this.props),l,c),this.props.onDrag(s,u,f,p,i,a),this.setState({layout:c?s:(0,R.compact)(s,(0,R.compactType)(this.props),l),activeDrag:p})}),Y(this,"onDragStop",(e,r,n,o)=>{let{e:i,node:a}=o;if(!this.state.activeDrag)return;const{oldDragItem:u}=this.state;let{layout:s}=this.state;const{cols:l,preventCollision:c,allowOverlap:d}=this.props,f=(0,R.getLayoutItem)(s,e);if(!f)return;s=(0,R.moveElement)(s,f,r,n,!0,c,(0,R.compactType)(this.props),l,d);const b=d?s:(0,R.compact)(s,(0,R.compactType)(this.props),l);this.props.onDragStop(b,u,f,null,i,a);const{oldLayout:D}=this.state;this.setState({activeDrag:null,layout:b,oldDragItem:null,oldLayout:null}),this.onLayoutMaybeChanged(b,D)}),Y(this,"onResizeStart",(e,r,n,o)=>{let{e:i,node:a}=o;const{layout:u}=this.state,s=(0,R.getLayoutItem)(u,e);s&&(this.setState({oldResizeItem:(0,R.cloneLayoutItem)(s),oldLayout:this.state.layout,resizing:!0}),this.props.onResizeStart(u,s,s,null,i,a))}),Y(this,"onResize",(e,r,n,o)=>{let{e:i,node:a,size:u,handle:s}=o;const{oldResizeItem:l}=this.state,{layout:c}=this.state,{cols:d,preventCollision:f,allowOverlap:p}=this.props;let b=!1,D,S,h;const[w,y]=(0,R.withLayoutItem)(c,e,m=>{let z;return S=m.x,h=m.y,["sw","w","nw","n","ne"].indexOf(s)!==-1&&(["sw","nw","w"].indexOf(s)!==-1&&(S=m.x+(m.w-r),r=m.x!==S&&S<0?m.w:r,S=S<0?0:S),["ne","n","nw"].indexOf(s)!==-1&&(h=m.y+(m.h-n),n=m.y!==h&&h<0?m.h:n,h=h<0?0:h),b=!0),f&&!p&&(z=(0,R.getAllCollisions)(c,{...m,w:r,h:n,x:S,y:h}).filter(A=>A.i!==m.i).length>0,z&&(h=m.y,n=m.h,S=m.x,r=m.w,b=!1)),m.w=r,m.h=n,m});if(!y)return;D=w,b&&(D=(0,R.moveElement)(w,y,S,h,!0,this.props.preventCollision,(0,R.compactType)(this.props),d,p));const x={w:y.w,h:y.h,x:y.x,y:y.y,static:!0,i:e};this.props.onResize(D,l,y,x,i,a),this.setState({layout:p?D:(0,R.compact)(D,(0,R.compactType)(this.props),d),activeDrag:x})}),Y(this,"onResizeStop",(e,r,n,o)=>{let{e:i,node:a}=o;const{layout:u,oldResizeItem:s}=this.state,{cols:l,allowOverlap:c}=this.props,d=(0,R.getLayoutItem)(u,e),f=c?u:(0,R.compact)(u,(0,R.compactType)(this.props),l);this.props.onResizeStop(f,s,d,null,i,a);const{oldLayout:p}=this.state;this.setState({activeDrag:null,layout:f,oldResizeItem:null,oldLayout:null,resizing:!1}),this.onLayoutMaybeChanged(f,p)}),Y(this,"onDragOver",e=>{var w;if(e.preventDefault(),e.stopPropagation(),on&&!((w=e.nativeEvent.target)!=null&&w.classList.contains(vr)))return!1;const{droppingItem:r,onDropDragOver:n,margin:o,cols:i,rowHeight:a,maxRows:u,width:s,containerPadding:l,transformScale:c}=this.props,d=n==null?void 0:n(e);if(d===!1)return this.state.droppingDOMNode&&this.removeDroppingPlaceholder(),!1;const f={...r,...d},{layout:p}=this.state,b=e.currentTarget.getBoundingClientRect(),D=e.clientX-b.left,S=e.clientY-b.top,h={left:D/c,top:S/c,e};if(this.state.droppingDOMNode){if(this.state.droppingPosition){const{left:y,top:x}=this.state.droppingPosition;(y!=D||x!=S)&&this.setState({droppingPosition:h})}}else{const y={cols:i,margin:o,maxRows:u,rowHeight:a,containerWidth:s,containerPadding:l||o},x=(0,ra.calcXY)(y,S,D,f.w,f.h);this.setState({droppingDOMNode:ye.createElement("div",{key:f.i}),droppingPosition:h,layout:[...p,{...f,x:x.x,y:x.y,static:!1,isDraggable:!0}]})}}),Y(this,"removeDroppingPlaceholder",()=>{const{droppingItem:e,cols:r}=this.props,{layout:n}=this.state,o=(0,R.compact)(n.filter(i=>i.i!==e.i),(0,R.compactType)(this.props),r,this.props.allowOverlap);this.setState({layout:o,droppingDOMNode:null,activeDrag:null,droppingPosition:void 0})}),Y(this,"onDragLeave",e=>{e.preventDefault(),e.stopPropagation(),this.dragEnterCounter--,this.dragEnterCounter===0&&this.removeDroppingPlaceholder()}),Y(this,"onDragEnter",e=>{e.preventDefault(),e.stopPropagation(),this.dragEnterCounter++}),Y(this,"onDrop",e=>{e.preventDefault(),e.stopPropagation();const{droppingItem:r}=this.props,{layout:n}=this.state,o=n.find(i=>i.i===r.i);this.dragEnterCounter=0,this.removeDroppingPlaceholder(),this.props.onDrop(n,o,e)})}componentDidMount(){this.setState({mounted:!0}),this.onLayoutMaybeChanged(this.state.layout,this.props.layout)}static getDerivedStateFromProps(e,r){let n;return r.activeDrag?null:(!(0,yt.deepEqual)(e.layout,r.propsLayout)||e.compactType!==r.compactType?n=e.layout:(0,R.childrenEqual)(e.children,r.children)||(n=r.layout),n?{layout:(0,R.synchronizeLayoutWithChildren)(n,e.children,e.cols,(0,R.compactType)(e),e.allowOverlap),compactType:e.compactType,children:e.children,propsLayout:e.layout}:null)}shouldComponentUpdate(e,r){return this.props.children!==e.children||!(0,R.fastRGLPropsEqual)(this.props,e,yt.deepEqual)||this.state.activeDrag!==r.activeDrag||this.state.mounted!==r.mounted||this.state.droppingPosition!==r.droppingPosition}componentDidUpdate(e,r){if(!this.state.activeDrag){const n=this.state.layout,o=r.layout;this.onLayoutMaybeChanged(n,o)}}containerHeight(){if(!this.props.autoSize)return;const e=(0,R.bottom)(this.state.layout),r=this.props.containerPadding?this.props.containerPadding[1]:this.props.margin[1];return e*this.props.rowHeight+(e-1)*this.props.margin[1]+r*2+"px"}onLayoutMaybeChanged(e,r){r||(r=this.state.layout),(0,yt.deepEqual)(r,e)||this.props.onLayoutChange(e)}placeholder(){const{activeDrag:e}=this.state;if(!e)return null;const{width:r,cols:n,margin:o,containerPadding:i,rowHeight:a,maxRows:u,useCSSTransforms:s,transformScale:l}=this.props;return ye.createElement(yr.default,{w:e.w,h:e.h,x:e.x,y:e.y,i:e.i,className:`react-grid-placeholder ${this.state.resizing?"placeholder-resizing":""}`,containerWidth:r,cols:n,margin:o,containerPadding:i||o,maxRows:u,rowHeight:a,isDraggable:!1,isResizable:!1,isBounded:!1,useCSSTransforms:s,transformScale:l},ye.createElement("div",null))}processGridItem(e,r){if(!e||!e.key)return;const n=(0,R.getLayoutItem)(this.state.layout,String(e.key));if(!n)return null;const{width:o,cols:i,margin:a,containerPadding:u,rowHeight:s,maxRows:l,isDraggable:c,isResizable:d,isBounded:f,useCSSTransforms:p,transformScale:b,draggableCancel:D,draggableHandle:S,resizeHandles:h,resizeHandle:w}=this.props,{mounted:y,droppingPosition:x}=this.state,m=typeof n.isDraggable=="boolean"?n.isDraggable:!n.static&&c,z=typeof n.isResizable=="boolean"?n.isResizable:!n.static&&d,N=n.resizeHandles||h,A=m&&f&&n.isBounded!==!1;return ye.createElement(yr.default,{containerWidth:o,cols:i,margin:a,containerPadding:u||a,maxRows:l,rowHeight:s,cancel:D,handle:S,onDragStop:this.onDragStop,onDragStart:this.onDragStart,onDrag:this.onDrag,onResizeStart:this.onResizeStart,onResize:this.onResize,onResizeStop:this.onResizeStop,isDraggable:m,isResizable:z,isBounded:A,useCSSTransforms:p&&y,usePercentages:!y,transformScale:b,w:n.w,h:n.h,x:n.x,y:n.y,i:n.i,minH:n.minH,minW:n.minW,maxH:n.maxH,maxW:n.maxW,static:n.static,droppingPosition:r?x:void 0,resizeHandles:N,resizeHandle:w},e)}render(){const{className:e,style:r,isDroppable:n,innerRef:o}=this.props,i=(0,ta.default)(vr,e),a={height:this.containerHeight(),...r};return ye.createElement("div",{ref:o,className:i,style:a,onDrop:n?this.onDrop:R.noop,onDragLeave:n?this.onDragLeave:R.noop,onDragEnter:n?this.onDragEnter:R.noop,onDragOver:n?this.onDragOver:R.noop},ye.Children.map(this.props.children,u=>this.processGridItem(u)),n&&this.state.droppingDOMNode&&this.processGridItem(this.state.droppingDOMNode,!0),this.placeholder())}}We.default=st;Y(st,"displayName","ReactGridLayout");Y(st,"propTypes",na.default);Y(st,"defaultProps",{autoSize:!0,cols:12,className:"",style:{},draggableHandle:"",draggableCancel:"",containerPadding:null,rowHeight:150,maxRows:1/0,layout:[],margin:[10,10],isBounded:!1,isDraggable:!0,isResizable:!0,allowOverlap:!1,isDroppable:!1,useCSSTransforms:!0,transformScale:1,verticalCompact:!0,compactType:"vertical",preventCollision:!1,droppingItem:{i:"__dropping-elem__",h:1,w:1},resizeHandles:["se"],onLayoutChange:R.noop,onDragStart:R.noop,onDrag:R.noop,onDragStop:R.noop,onResizeStart:R.noop,onResize:R.noop,onResizeStop:R.noop,onDrop:R.noop,onDropDragOver:R.noop});var lt={},Re={};Object.defineProperty(Re,"__esModule",{value:!0});Re.findOrGenerateResponsiveLayout=la;Re.getBreakpointFromWidth=aa;Re.getColsFromBreakpoint=sa;Re.sortBreakpoints=Vt;var Be=E;function aa(t,e){const r=Vt(t);let n=r[0];for(let o=1,i=r.length;o<i;o++){const a=r[o];e>t[a]&&(n=a)}return n}function sa(t,e){if(!e[t])throw new Error("ResponsiveReactGridLayout: `cols` entry for breakpoint "+t+" is missing!");return e[t]}function la(t,e,r,n,o,i){if(t[r])return(0,Be.cloneLayout)(t[r]);let a=t[n];const u=Vt(e),s=u.slice(u.indexOf(r));for(let l=0,c=s.length;l<c;l++){const d=s[l];if(t[d]){a=t[d];break}}return a=(0,Be.cloneLayout)(a||[]),(0,Be.compact)((0,Be.correctBounds)(a,{cols:o}),i,o)}function Vt(t){return Object.keys(t).sort(function(r,n){return t[r]-t[n]})}Object.defineProperty(lt,"__esModule",{value:!0});lt.default=void 0;var br=sn(L),Z=an(he),vt=Mt,Ee=E,ve=Re,ua=an(We);function an(t){return t&&t.__esModule?t:{default:t}}function sn(t,e){if(typeof WeakMap=="function")var r=new WeakMap,n=new WeakMap;return(sn=function(o,i){if(!i&&o&&o.__esModule)return o;var a,u,s={__proto__:null,default:o};if(o===null||typeof o!="object"&&typeof o!="function")return s;if(a=i?n:r){if(a.has(o))return a.get(o);a.set(o,s)}for(const l in o)l!=="default"&&{}.hasOwnProperty.call(o,l)&&((u=(a=Object.defineProperty)&&Object.getOwnPropertyDescriptor(o,l))&&(u.get||u.set)?a(s,l,u):s[l]=o[l]);return s})(t,e)}function Pt(){return Pt=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var n in r)({}).hasOwnProperty.call(r,n)&&(t[n]=r[n])}return t},Pt.apply(null,arguments)}function Ue(t,e,r){return(e=ca(e))in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function ca(t){var e=da(t,"string");return typeof e=="symbol"?e:e+""}function da(t,e){if(typeof t!="object"||!t)return t;var r=t[Symbol.toPrimitive];if(r!==void 0){var n=r.call(t,e||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(t)}const wr=t=>Object.prototype.toString.call(t);function Fe(t,e){return t==null?null:Array.isArray(t)?t:t[e]}class Kt extends br.Component{constructor(){super(...arguments),Ue(this,"state",this.generateInitialState()),Ue(this,"onLayoutChange",e=>{this.props.onLayoutChange(e,{...this.props.layouts,[this.state.breakpoint]:e})})}generateInitialState(){const{width:e,breakpoints:r,layouts:n,cols:o}=this.props,i=(0,ve.getBreakpointFromWidth)(r,e),a=(0,ve.getColsFromBreakpoint)(i,o),u=this.props.verticalCompact===!1?null:this.props.compactType;return{layout:(0,ve.findOrGenerateResponsiveLayout)(n,r,i,i,a,u),breakpoint:i,cols:a}}static getDerivedStateFromProps(e,r){if(!(0,vt.deepEqual)(e.layouts,r.layouts)){const{breakpoint:n,cols:o}=r;return{layout:(0,ve.findOrGenerateResponsiveLayout)(e.layouts,e.breakpoints,n,n,o,e.compactType),layouts:e.layouts}}return null}componentDidUpdate(e){(this.props.width!=e.width||this.props.breakpoint!==e.breakpoint||!(0,vt.deepEqual)(this.props.breakpoints,e.breakpoints)||!(0,vt.deepEqual)(this.props.cols,e.cols))&&this.onWidthChange(e)}onWidthChange(e){const{breakpoints:r,cols:n,layouts:o,compactType:i}=this.props,a=this.props.breakpoint||(0,ve.getBreakpointFromWidth)(this.props.breakpoints,this.props.width),u=this.state.breakpoint,s=(0,ve.getColsFromBreakpoint)(a,n),l={...o};if(u!==a||e.breakpoints!==r||e.cols!==n){u in l||(l[u]=(0,Ee.cloneLayout)(this.state.layout));let f=(0,ve.findOrGenerateResponsiveLayout)(l,r,a,u,s,i);f=(0,Ee.synchronizeLayoutWithChildren)(f,this.props.children,s,i,this.props.allowOverlap),l[a]=f,this.props.onBreakpointChange(a,s),this.props.onLayoutChange(f,l),this.setState({breakpoint:a,layout:f,cols:s})}const c=Fe(this.props.margin,a),d=Fe(this.props.containerPadding,a);this.props.onWidthChange(this.props.width,c,s,d)}render(){const{breakpoint:e,breakpoints:r,cols:n,layouts:o,margin:i,containerPadding:a,onBreakpointChange:u,onLayoutChange:s,onWidthChange:l,...c}=this.props;return br.createElement(ua.default,Pt({},c,{margin:Fe(i,this.state.breakpoint),containerPadding:Fe(a,this.state.breakpoint),onLayoutChange:this.onLayoutChange,layout:this.state.layout,cols:this.state.cols}))}}lt.default=Kt;Ue(Kt,"propTypes",{breakpoint:Z.default.string,breakpoints:Z.default.object,allowOverlap:Z.default.bool,cols:Z.default.object,margin:Z.default.oneOfType([Z.default.array,Z.default.object]),containerPadding:Z.default.oneOfType([Z.default.array,Z.default.object]),layouts(t,e){if(wr(t[e])!=="[object Object]")throw new Error("Layout property must be an object. Received: "+wr(t[e]));Object.keys(t[e]).forEach(r=>{if(!(r in t.breakpoints))throw new Error("Each key in layouts must align with a key in breakpoints.");(0,Ee.validateLayout)(t.layouts[r],"layouts."+r)})},width:Z.default.number.isRequired,onBreakpointChange:Z.default.func,onLayoutChange:Z.default.func,onWidthChange:Z.default.func});Ue(Kt,"defaultProps",{breakpoints:{lg:1200,md:996,sm:768,xs:480,xxs:0},cols:{lg:12,md:10,sm:6,xs:4,xxs:2},containerPadding:{lg:null,md:null,sm:null,xs:null,xxs:null},layouts:{},margin:[10,10],allowOverlap:!1,onBreakpointChange:Ee.noop,onLayoutChange:Ee.noop,onWidthChange:Ee.noop});var Zt={},ln=function(){if(typeof Map<"u")return Map;function t(e,r){var n=-1;return e.some(function(o,i){return o[0]===r?(n=i,!0):!1}),n}return function(){function e(){this.__entries__=[]}return Object.defineProperty(e.prototype,"size",{get:function(){return this.__entries__.length},enumerable:!0,configurable:!0}),e.prototype.get=function(r){var n=t(this.__entries__,r),o=this.__entries__[n];return o&&o[1]},e.prototype.set=function(r,n){var o=t(this.__entries__,r);~o?this.__entries__[o][1]=n:this.__entries__.push([r,n])},e.prototype.delete=function(r){var n=this.__entries__,o=t(n,r);~o&&n.splice(o,1)},e.prototype.has=function(r){return!!~t(this.__entries__,r)},e.prototype.clear=function(){this.__entries__.splice(0)},e.prototype.forEach=function(r,n){n===void 0&&(n=null);for(var o=0,i=this.__entries__;o<i.length;o++){var a=i[o];r.call(n,a[1],a[0])}},e}()}(),Et=typeof window<"u"&&typeof document<"u"&&window.document===document,Ve=function(){return typeof global<"u"&&global.Math===Math?global:typeof self<"u"&&self.Math===Math?self:typeof window<"u"&&window.Math===Math?window:Function("return this")()}(),fa=function(){return typeof requestAnimationFrame=="function"?requestAnimationFrame.bind(Ve):function(t){return setTimeout(function(){return t(Date.now())},1e3/60)}}(),pa=2;function ha(t,e){var r=!1,n=!1,o=0;function i(){r&&(r=!1,t()),n&&u()}function a(){fa(i)}function u(){var s=Date.now();if(r){if(s-o<pa)return;n=!0}else r=!0,n=!1,setTimeout(a,e);o=s}return u}var ga=20,ma=["top","right","bottom","left","width","height","size","weight"],ya=typeof MutationObserver<"u",va=function(){function t(){this.connected_=!1,this.mutationEventsAdded_=!1,this.mutationsObserver_=null,this.observers_=[],this.onTransitionEnd_=this.onTransitionEnd_.bind(this),this.refresh=ha(this.refresh.bind(this),ga)}return t.prototype.addObserver=function(e){~this.observers_.indexOf(e)||this.observers_.push(e),this.connected_||this.connect_()},t.prototype.removeObserver=function(e){var r=this.observers_,n=r.indexOf(e);~n&&r.splice(n,1),!r.length&&this.connected_&&this.disconnect_()},t.prototype.refresh=function(){var e=this.updateObservers_();e&&this.refresh()},t.prototype.updateObservers_=function(){var e=this.observers_.filter(function(r){return r.gatherActive(),r.hasActive()});return e.forEach(function(r){return r.broadcastActive()}),e.length>0},t.prototype.connect_=function(){!Et||this.connected_||(document.addEventListener("transitionend",this.onTransitionEnd_),window.addEventListener("resize",this.refresh),ya?(this.mutationsObserver_=new MutationObserver(this.refresh),this.mutationsObserver_.observe(document,{attributes:!0,childList:!0,characterData:!0,subtree:!0})):(document.addEventListener("DOMSubtreeModified",this.refresh),this.mutationEventsAdded_=!0),this.connected_=!0)},t.prototype.disconnect_=function(){!Et||!this.connected_||(document.removeEventListener("transitionend",this.onTransitionEnd_),window.removeEventListener("resize",this.refresh),this.mutationsObserver_&&this.mutationsObserver_.disconnect(),this.mutationEventsAdded_&&document.removeEventListener("DOMSubtreeModified",this.refresh),this.mutationsObserver_=null,this.mutationEventsAdded_=!1,this.connected_=!1)},t.prototype.onTransitionEnd_=function(e){var r=e.propertyName,n=r===void 0?"":r,o=ma.some(function(i){return!!~n.indexOf(i)});o&&this.refresh()},t.getInstance=function(){return this.instance_||(this.instance_=new t),this.instance_},t.instance_=null,t}(),un=function(t,e){for(var r=0,n=Object.keys(e);r<n.length;r++){var o=n[r];Object.defineProperty(t,o,{value:e[o],enumerable:!1,writable:!1,configurable:!0})}return t},Ce=function(t){var e=t&&t.ownerDocument&&t.ownerDocument.defaultView;return e||Ve},cn=ut(0,0,0,0);function Ke(t){return parseFloat(t)||0}function xr(t){for(var e=[],r=1;r<arguments.length;r++)e[r-1]=arguments[r];return e.reduce(function(n,o){var i=t["border-"+o+"-width"];return n+Ke(i)},0)}function ba(t){for(var e=["top","right","bottom","left"],r={},n=0,o=e;n<o.length;n++){var i=o[n],a=t["padding-"+i];r[i]=Ke(a)}return r}function wa(t){var e=t.getBBox();return ut(0,0,e.width,e.height)}function xa(t){var e=t.clientWidth,r=t.clientHeight;if(!e&&!r)return cn;var n=Ce(t).getComputedStyle(t),o=ba(n),i=o.left+o.right,a=o.top+o.bottom,u=Ke(n.width),s=Ke(n.height);if(n.boxSizing==="border-box"&&(Math.round(u+i)!==e&&(u-=xr(n,"left","right")+i),Math.round(s+a)!==r&&(s-=xr(n,"top","bottom")+a)),!Ra(t)){var l=Math.round(u+i)-e,c=Math.round(s+a)-r;Math.abs(l)!==1&&(u-=l),Math.abs(c)!==1&&(s-=c)}return ut(o.left,o.top,u,s)}var Sa=function(){return typeof SVGGraphicsElement<"u"?function(t){return t instanceof Ce(t).SVGGraphicsElement}:function(t){return t instanceof Ce(t).SVGElement&&typeof t.getBBox=="function"}}();function Ra(t){return t===Ce(t).document.documentElement}function Da(t){return Et?Sa(t)?wa(t):xa(t):cn}function _a(t){var e=t.x,r=t.y,n=t.width,o=t.height,i=typeof DOMRectReadOnly<"u"?DOMRectReadOnly:Object,a=Object.create(i.prototype);return un(a,{x:e,y:r,width:n,height:o,top:r,right:e+n,bottom:o+r,left:e}),a}function ut(t,e,r,n){return{x:t,y:e,width:r,height:n}}var Oa=function(){function t(e){this.broadcastWidth=0,this.broadcastHeight=0,this.contentRect_=ut(0,0,0,0),this.target=e}return t.prototype.isActive=function(){var e=Da(this.target);return this.contentRect_=e,e.width!==this.broadcastWidth||e.height!==this.broadcastHeight},t.prototype.broadcastRect=function(){var e=this.contentRect_;return this.broadcastWidth=e.width,this.broadcastHeight=e.height,e},t}(),Pa=function(){function t(e,r){var n=_a(r);un(this,{target:e,contentRect:n})}return t}(),Ea=function(){function t(e,r,n){if(this.activeObservations_=[],this.observations_=new ln,typeof e!="function")throw new TypeError("The callback provided as parameter 1 is not a function.");this.callback_=e,this.controller_=r,this.callbackCtx_=n}return t.prototype.observe=function(e){if(!arguments.length)throw new TypeError("1 argument required, but only 0 present.");if(!(typeof Element>"u"||!(Element instanceof Object))){if(!(e instanceof Ce(e).Element))throw new TypeError('parameter 1 is not of type "Element".');var r=this.observations_;r.has(e)||(r.set(e,new Oa(e)),this.controller_.addObserver(this),this.controller_.refresh())}},t.prototype.unobserve=function(e){if(!arguments.length)throw new TypeError("1 argument required, but only 0 present.");if(!(typeof Element>"u"||!(Element instanceof Object))){if(!(e instanceof Ce(e).Element))throw new TypeError('parameter 1 is not of type "Element".');var r=this.observations_;r.has(e)&&(r.delete(e),r.size||this.controller_.removeObserver(this))}},t.prototype.disconnect=function(){this.clearActive(),this.observations_.clear(),this.controller_.removeObserver(this)},t.prototype.gatherActive=function(){var e=this;this.clearActive(),this.observations_.forEach(function(r){r.isActive()&&e.activeObservations_.push(r)})},t.prototype.broadcastActive=function(){if(this.hasActive()){var e=this.callbackCtx_,r=this.activeObservations_.map(function(n){return new Pa(n.target,n.broadcastRect())});this.callback_.call(e,r,e),this.clearActive()}},t.prototype.clearActive=function(){this.activeObservations_.splice(0)},t.prototype.hasActive=function(){return this.activeObservations_.length>0},t}(),dn=typeof WeakMap<"u"?new WeakMap:new ln,fn=function(){function t(e){if(!(this instanceof t))throw new TypeError("Cannot call a class as a function.");if(!arguments.length)throw new TypeError("1 argument required, but only 0 present.");var r=va.getInstance(),n=new Ea(e,r,this);dn.set(this,n)}return t}();["observe","unobserve","disconnect"].forEach(function(t){fn.prototype[t]=function(){var e;return(e=dn.get(this))[t].apply(e,arguments)}});var za=function(){return typeof Ve.ResizeObserver<"u"?Ve.ResizeObserver:fn}();const Ca=Object.freeze(Object.defineProperty({__proto__:null,default:za},Symbol.toStringTag,{value:"Module"})),Ma=zr(Ca);Object.defineProperty(Zt,"__esModule",{value:!0});Zt.default=Wa;var Ye=pn(L),ja=Jt(he),Ta=Jt(Ma),La=Jt(Ze);function Jt(t){return t&&t.__esModule?t:{default:t}}function pn(t,e){if(typeof WeakMap=="function")var r=new WeakMap,n=new WeakMap;return(pn=function(o,i){if(!i&&o&&o.__esModule)return o;var a,u,s={__proto__:null,default:o};if(o===null||typeof o!="object"&&typeof o!="function")return s;if(a=i?n:r){if(a.has(o))return a.get(o);a.set(o,s)}for(const l in o)l!=="default"&&{}.hasOwnProperty.call(o,l)&&((u=(a=Object.defineProperty)&&Object.getOwnPropertyDescriptor(o,l))&&(u.get||u.set)?a(s,l,u):s[l]=o[l]);return s})(t,e)}function zt(){return zt=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var n in r)({}).hasOwnProperty.call(r,n)&&(t[n]=r[n])}return t},zt.apply(null,arguments)}function Oe(t,e,r){return(e=Ha(e))in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function Ha(t){var e=$a(t,"string");return typeof e=="symbol"?e:e+""}function $a(t,e){if(typeof t!="object"||!t)return t;var r=t[Symbol.toPrimitive];if(r!==void 0){var n=r.call(t,e||"default");if(typeof n!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(t)}const Na="react-grid-layout";function Wa(t){var e;return e=class extends Ye.Component{constructor(){super(...arguments),Oe(this,"state",{width:1280}),Oe(this,"elementRef",Ye.createRef()),Oe(this,"mounted",!1),Oe(this,"resizeObserver",void 0)}componentDidMount(){this.mounted=!0,this.resizeObserver=new Ta.default(o=>{if(this.elementRef.current instanceof HTMLElement){const a=o[0].contentRect.width;this.setState({width:a})}});const n=this.elementRef.current;n instanceof HTMLElement&&this.resizeObserver.observe(n)}componentWillUnmount(){this.mounted=!1;const n=this.elementRef.current;n instanceof HTMLElement&&this.resizeObserver.unobserve(n),this.resizeObserver.disconnect()}render(){const{measureBeforeMount:n,...o}=this.props;return n&&!this.mounted?Ye.createElement("div",{className:(0,La.default)(this.props.className,Na),style:this.props.style,ref:this.elementRef}):Ye.createElement(t,zt({innerRef:this.elementRef},o,this.state))}},Oe(e,"defaultProps",{measureBeforeMount:!1}),Oe(e,"propTypes",{measureBeforeMount:ja.default.bool}),e}(function(t){t.exports=We.default,t.exports.utils=E,t.exports.calculateUtils=se,t.exports.Responsive=lt.default,t.exports.Responsive.utils=Re,t.exports.WidthProvider=Zt.default})(Cr);var hn=Cr.exports;const ka=Yn(hn),qa=hn.WidthProvider(ka),Aa=B("div")(({theme:t})=>({"& .react-grid-item":{borderRadius:`${t.shape.borderRadiusMedium}px`},"& .grid-item-drag-handle":{[t.breakpoints.down("md")]:{display:"none"}}})),Ia=B("div")(({theme:t})=>({border:`1px solid ${t.palette.divider}`})),Va=({items:t,onLayoutChange:e,cols:r={lg:12,md:12,sm:6,xs:4,xxs:2},rowHeight:n=180})=>{const o=Or(),i=Pr(o.breakpoints.down("md")),a=L.useMemo(()=>{if(i){let l=0;return t.map(c=>{const d={i:c.id,x:0,y:l,w:r.xs,h:c.h??4,minW:r.xs,minH:c.minH??3,maxW:r.xs,maxH:c.maxH??8,static:!1};return l+=d.h,d})}return t.map((l,c)=>({i:l.id,x:l.x??c%Math.floor(r.lg/(l.w??4))*(l.w??4),y:l.y??Math.floor(c/Math.floor(r.lg/(l.w??4)))*(l.h??4),w:l.w??4,h:l.h??4,minW:l.minW??4,minH:l.minH??3,maxW:l.maxW??12,maxH:l.maxH??8,static:l.static??!1}))},[t,r,i]),u=L.useMemo(()=>t.map(l=>g.jsx(Ia,{children:l.component},l.id)),[t]),s=L.useCallback(l=>{i||e==null||e(l)},[e,i]);return g.jsx(Aa,{children:g.jsx(qa,{className:"impact-metrics-grid",layout:a,cols:i?r.xs:r.lg,rowHeight:n,margin:[Number.parseInt(o.spacing(2),10),Number.parseInt(o.spacing(2),10)],containerPadding:[0,0],isDraggable:!1,isResizable:!1,onLayoutChange:s,resizeHandles:["se"],draggableHandle:".grid-item-drag-handle",compactType:i?null:"vertical",preventCollision:!1,useCSSTransforms:!0,autoSize:!0,allowOverlap:!1,children:u})})};export{Ya as C,Va as G,Fa as a,Ba as b,Kn as u};
|