@undp/data-viz 2.0.8 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (215) hide show
  1. package/dist/AreaChart.cjs +1 -1
  2. package/dist/AreaChart.d.ts +2 -0
  3. package/dist/AreaChart.js +1 -1
  4. package/dist/BarGraph.cjs +1 -1
  5. package/dist/BarGraph.cjs.map +1 -1
  6. package/dist/BarGraph.d.ts +2 -0
  7. package/dist/BarGraph.js +1188 -1213
  8. package/dist/BarGraph.js.map +1 -1
  9. package/dist/BasicStatCard.d.ts +2 -0
  10. package/dist/BeeSwarmChart.cjs +1 -1
  11. package/dist/BeeSwarmChart.cjs.map +1 -1
  12. package/dist/BeeSwarmChart.d.ts +2 -0
  13. package/dist/BeeSwarmChart.js +258 -267
  14. package/dist/BeeSwarmChart.js.map +1 -1
  15. package/dist/BiVariateChoroplethMap.cjs +1 -1
  16. package/dist/BiVariateChoroplethMap.cjs.map +1 -1
  17. package/dist/BiVariateChoroplethMap.d.ts +2 -0
  18. package/dist/BiVariateChoroplethMap.js +126 -131
  19. package/dist/BiVariateChoroplethMap.js.map +1 -1
  20. package/dist/BulletChart.cjs +1 -1
  21. package/dist/BulletChart.cjs.map +1 -1
  22. package/dist/BulletChart.d.ts +2 -0
  23. package/dist/BulletChart.js +404 -413
  24. package/dist/BulletChart.js.map +1 -1
  25. package/dist/ButterflyChart.cjs +1 -1
  26. package/dist/ButterflyChart.cjs.map +1 -1
  27. package/dist/ButterflyChart.d.ts +2 -0
  28. package/dist/ButterflyChart.js +179 -184
  29. package/dist/ButterflyChart.js.map +1 -1
  30. package/dist/ChoroplethMap.cjs +1 -1
  31. package/dist/ChoroplethMap.cjs.map +1 -1
  32. package/dist/ChoroplethMap.d.ts +2 -0
  33. package/dist/ChoroplethMap.js +268 -273
  34. package/dist/ChoroplethMap.js.map +1 -1
  35. package/dist/CirclePackingGraph.cjs +1 -1
  36. package/dist/CirclePackingGraph.d.ts +2 -0
  37. package/dist/CirclePackingGraph.js +1 -1
  38. package/dist/DataCards.cjs +1 -1
  39. package/dist/DataCards.d.ts +2 -0
  40. package/dist/DataCards.js +2 -2
  41. package/dist/DataTable.d.ts +2 -0
  42. package/dist/DetailsModal-0Ry5nXiC.js +32 -0
  43. package/dist/DetailsModal-0Ry5nXiC.js.map +1 -0
  44. package/dist/DetailsModal-BN0HDFlV.cjs +2 -0
  45. package/dist/DetailsModal-BN0HDFlV.cjs.map +1 -0
  46. package/dist/DifferenceLineChart.cjs +1 -1
  47. package/dist/DifferenceLineChart.d.ts +2 -0
  48. package/dist/DifferenceLineChart.js +1 -1
  49. package/dist/DonutChart.cjs +1 -1
  50. package/dist/DonutChart.cjs.map +1 -1
  51. package/dist/DonutChart.d.ts +2 -0
  52. package/dist/DonutChart.js +185 -190
  53. package/dist/DonutChart.js.map +1 -1
  54. package/dist/DotDensityMap.cjs +1 -1
  55. package/dist/DotDensityMap.cjs.map +1 -1
  56. package/dist/DotDensityMap.d.ts +2 -0
  57. package/dist/DotDensityMap.js +198 -203
  58. package/dist/DotDensityMap.js.map +1 -1
  59. package/dist/DualAxisLineChart.cjs +1 -1
  60. package/dist/DualAxisLineChart.d.ts +2 -0
  61. package/dist/DualAxisLineChart.js +1 -1
  62. package/dist/DumbbellChart.cjs +1 -1
  63. package/dist/DumbbellChart.cjs.map +1 -1
  64. package/dist/DumbbellChart.d.ts +2 -0
  65. package/dist/DumbbellChart.js +364 -373
  66. package/dist/DumbbellChart.js.map +1 -1
  67. package/dist/GeoHubCompareMaps.d.ts +2 -0
  68. package/dist/GeoHubMap.d.ts +2 -0
  69. package/dist/GeoHubMapWithLayerSelection.d.ts +2 -0
  70. package/dist/{GraphEl-BcKU0bG1.cjs → GraphEl-B16EYkko.cjs} +2 -2
  71. package/dist/{GraphEl-BcKU0bG1.cjs.map → GraphEl-B16EYkko.cjs.map} +1 -1
  72. package/dist/{GraphEl-CGq1EWRn.js → GraphEl-ebgfxefq.js} +3 -3
  73. package/dist/{GraphEl-CGq1EWRn.js.map → GraphEl-ebgfxefq.js.map} +1 -1
  74. package/dist/GriddedGraphs.cjs +1 -1
  75. package/dist/GriddedGraphs.cjs.map +1 -1
  76. package/dist/GriddedGraphs.d.ts +3 -0
  77. package/dist/GriddedGraphs.js +158 -146
  78. package/dist/GriddedGraphs.js.map +1 -1
  79. package/dist/GriddedGraphsFromConfig.d.ts +3 -0
  80. package/dist/HeatMap.cjs +1 -1
  81. package/dist/HeatMap.cjs.map +1 -1
  82. package/dist/HeatMap.d.ts +2 -0
  83. package/dist/HeatMap.js +111 -116
  84. package/dist/HeatMap.js.map +1 -1
  85. package/dist/Histogram.cjs +1 -1
  86. package/dist/Histogram.d.ts +2 -0
  87. package/dist/Histogram.js +1 -1
  88. package/dist/HybridMap.cjs +1 -1
  89. package/dist/HybridMap.cjs.map +1 -1
  90. package/dist/HybridMap.d.ts +2 -0
  91. package/dist/HybridMap.js +202 -207
  92. package/dist/HybridMap.js.map +1 -1
  93. package/dist/LineChartWithConfidenceInterval.cjs +1 -1
  94. package/dist/LineChartWithConfidenceInterval.d.ts +2 -0
  95. package/dist/LineChartWithConfidenceInterval.js +1 -1
  96. package/dist/{Modal-DGcuAHyK.js → Modal-bMQA6bL_.js} +5 -5
  97. package/dist/{Modal-DGcuAHyK.js.map → Modal-bMQA6bL_.js.map} +1 -1
  98. package/dist/MultiGraphDashboard.cjs +1 -1
  99. package/dist/MultiGraphDashboard.cjs.map +1 -1
  100. package/dist/MultiGraphDashboard.d.ts +3 -0
  101. package/dist/MultiGraphDashboard.js +90 -85
  102. package/dist/MultiGraphDashboard.js.map +1 -1
  103. package/dist/MultiGraphDashboardFromConfig.d.ts +3 -0
  104. package/dist/MultiGraphDashboardWideToLongFormat.d.ts +2 -0
  105. package/dist/MultiGraphDashboardWideToLongFormat.js +1 -1
  106. package/dist/MultiGraphDashboardWideToLongFormatFromConfig.d.ts +2 -0
  107. package/dist/MultiLineAltChart.cjs +1 -1
  108. package/dist/MultiLineAltChart.d.ts +2 -0
  109. package/dist/MultiLineAltChart.js +1 -1
  110. package/dist/MultiLineChart.cjs +1 -1
  111. package/dist/MultiLineChart.d.ts +2 -0
  112. package/dist/MultiLineChart.js +1 -1
  113. package/dist/ParetoChart.cjs +1 -1
  114. package/dist/ParetoChart.cjs.map +1 -1
  115. package/dist/ParetoChart.d.ts +2 -0
  116. package/dist/ParetoChart.js +187 -192
  117. package/dist/ParetoChart.js.map +1 -1
  118. package/dist/PerformanceIntensiveMultiGraphDashboard.cjs +1 -1
  119. package/dist/PerformanceIntensiveMultiGraphDashboard.cjs.map +1 -1
  120. package/dist/PerformanceIntensiveMultiGraphDashboard.d.ts +3 -0
  121. package/dist/PerformanceIntensiveMultiGraphDashboard.js +76 -72
  122. package/dist/PerformanceIntensiveMultiGraphDashboard.js.map +1 -1
  123. package/dist/PerformanceIntensiveMultiGraphDashboardFromConfig.d.ts +3 -0
  124. package/dist/PerformanceIntensiveScrollStory.d.ts +2 -0
  125. package/dist/RadarChart.cjs +1 -1
  126. package/dist/RadarChart.cjs.map +1 -1
  127. package/dist/RadarChart.d.ts +2 -0
  128. package/dist/RadarChart.js +158 -163
  129. package/dist/RadarChart.js.map +1 -1
  130. package/dist/SankeyChart.cjs +1 -1
  131. package/dist/SankeyChart.cjs.map +1 -1
  132. package/dist/SankeyChart.d.ts +2 -0
  133. package/dist/SankeyChart.js +172 -177
  134. package/dist/SankeyChart.js.map +1 -1
  135. package/dist/ScatterPlot.cjs +1 -1
  136. package/dist/ScatterPlot.cjs.map +1 -1
  137. package/dist/ScatterPlot.d.ts +2 -0
  138. package/dist/ScatterPlot.js +222 -227
  139. package/dist/ScatterPlot.js.map +1 -1
  140. package/dist/ScrollStory.d.ts +2 -0
  141. package/dist/SimpleLineChart.cjs +1 -1
  142. package/dist/SimpleLineChart.d.ts +2 -0
  143. package/dist/SimpleLineChart.js +1 -1
  144. package/dist/SingleGraphDashboard.cjs +1 -1
  145. package/dist/SingleGraphDashboard.cjs.map +1 -1
  146. package/dist/SingleGraphDashboard.d.ts +3 -0
  147. package/dist/SingleGraphDashboard.js +131 -128
  148. package/dist/SingleGraphDashboard.js.map +1 -1
  149. package/dist/SingleGraphDashboardFromConfig.d.ts +3 -0
  150. package/dist/SingleGraphDashboardGeoHubMaps.d.ts +2 -0
  151. package/dist/SingleGraphDashboardGeoHubMapsFromConfig.d.ts +2 -0
  152. package/dist/SingleGraphDashboardThreeDGraphs.cjs +1 -1
  153. package/dist/SingleGraphDashboardThreeDGraphs.cjs.map +1 -1
  154. package/dist/SingleGraphDashboardThreeDGraphs.d.ts +3 -0
  155. package/dist/SingleGraphDashboardThreeDGraphs.js +145 -141
  156. package/dist/SingleGraphDashboardThreeDGraphs.js.map +1 -1
  157. package/dist/SingleGraphDashboardThreeDGraphsFromConfig.d.ts +3 -0
  158. package/dist/SlopeChart.cjs +1 -1
  159. package/dist/SlopeChart.cjs.map +1 -1
  160. package/dist/SlopeChart.d.ts +2 -0
  161. package/dist/SlopeChart.js +182 -187
  162. package/dist/SlopeChart.js.map +1 -1
  163. package/dist/SparkLine.cjs +1 -1
  164. package/dist/SparkLine.d.ts +2 -0
  165. package/dist/SparkLine.js +1 -1
  166. package/dist/StatCardFromData.d.ts +2 -0
  167. package/dist/StripChart.cjs +1 -1
  168. package/dist/StripChart.cjs.map +1 -1
  169. package/dist/StripChart.d.ts +2 -0
  170. package/dist/StripChart.js +249 -258
  171. package/dist/StripChart.js.map +1 -1
  172. package/dist/ThreeDGlobe.cjs +1 -1
  173. package/dist/ThreeDGlobe.cjs.map +1 -1
  174. package/dist/ThreeDGlobe.d.ts +2 -0
  175. package/dist/ThreeDGlobe.js +142 -147
  176. package/dist/ThreeDGlobe.js.map +1 -1
  177. package/dist/Tooltip-Dj5eVppQ.js +45 -0
  178. package/dist/Tooltip-Dj5eVppQ.js.map +1 -0
  179. package/dist/Tooltip-uUdw6wJL.cjs +2 -0
  180. package/dist/Tooltip-uUdw6wJL.cjs.map +1 -0
  181. package/dist/TreeMapGraph.cjs +1 -1
  182. package/dist/TreeMapGraph.cjs.map +1 -1
  183. package/dist/TreeMapGraph.d.ts +2 -0
  184. package/dist/TreeMapGraph.js +159 -164
  185. package/dist/TreeMapGraph.js.map +1 -1
  186. package/dist/Types.d.ts +3 -0
  187. package/dist/UnitChart.d.ts +2 -0
  188. package/dist/{checkIfMultiple-Y9iKaV_u.js → checkIfMultiple-CIRtG0KE.js} +2 -2
  189. package/dist/{checkIfMultiple-Y9iKaV_u.js.map → checkIfMultiple-CIRtG0KE.js.map} +1 -1
  190. package/dist/getUniqValue-DsqSii6M.js +11 -0
  191. package/dist/getUniqValue-DsqSii6M.js.map +1 -0
  192. package/dist/getUniqValue-NX8DgwND.cjs +2 -0
  193. package/dist/getUniqValue-NX8DgwND.cjs.map +1 -0
  194. package/dist/index-BBV4tAeA.js +330 -0
  195. package/dist/index-BBV4tAeA.js.map +1 -0
  196. package/dist/index-CF5hnGvG.cjs +2 -0
  197. package/dist/index-CF5hnGvG.cjs.map +1 -0
  198. package/dist/index.cjs +1 -1
  199. package/dist/index.d.ts +3 -0
  200. package/dist/index.js +2 -2
  201. package/dist/utils.cjs +1 -1
  202. package/dist/utils.js +1 -1
  203. package/package.json +1 -1
  204. package/dist/Tooltip-4dJo4_AF.cjs +0 -2
  205. package/dist/Tooltip-4dJo4_AF.cjs.map +0 -1
  206. package/dist/Tooltip-CwWUegPB.js +0 -43
  207. package/dist/Tooltip-CwWUegPB.js.map +0 -1
  208. package/dist/getUniqValue-BKHCm3zE.js +0 -11
  209. package/dist/getUniqValue-BKHCm3zE.js.map +0 -1
  210. package/dist/getUniqValue-RViz8tTw.cjs +0 -2
  211. package/dist/getUniqValue-RViz8tTw.cjs.map +0 -1
  212. package/dist/index-B2LQV7Tk.js +0 -335
  213. package/dist/index-B2LQV7Tk.js.map +0 -1
  214. package/dist/index-xRHRLDIp.cjs +0 -2
  215. package/dist/index-xRHRLDIp.cjs.map +0 -1
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./index-CHPV5EwG-CTPQjnHt.cjs"),A=require("react"),O=require("./parse-hMnG_lRV.cjs"),xi=require("./index-Cno4Q0YE.cjs"),ei=require("./numberFormattingFunction-02t-wJta.cjs"),mi=require("./Tooltip-4dJo4_AF.cjs"),It=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),ii=require("./customArea-CMF5g-C3.cjs"),di=require("./AxisTitle-sS5bLLR7.cjs"),pi=require("./Axis-DxRV2yMi.cjs"),fi=require("./XTicksAndGridLines-B6CELS7q.cjs"),hi=require("./ReferenceLine-BH0qdf4R.cjs"),yi=require("./YTicksAndGridLines-4pxTRlRK.cjs"),gi=require("./index-B_sAFsEV.cjs"),ji=require("./time-CZd5YLSP.cjs"),vi=require("./linear-BwPAspcq.cjs"),ni=require("./line-DHV4JwCR.cjs"),Ge=require("./step-BZ3C8QFW.cjs"),oi=require("./area-D3Qx7k7K.cjs"),wi=require("./select-Bnfk0lJx.cjs"),Ri=require("./init-DU0ybBc_.cjs"),bi=require("./pointer-Dkq5NV1q.cjs"),Ei=require("./use-in-view-QcfiW0w3.cjs"),S=require("./proxy-BxvUI_9l.cjs"),Oi=require("./GraphFooter.cjs"),Ci=require("./GraphHeader.cjs"),Ai=require("./ColorLegend.cjs"),Pe=require("./Colors.cjs"),Vi=require("./generateRandomString-B5zBiJzS.cjs"),Li=require("./EmptyState-sAEZ_5rU.cjs"),si=require("./GraphContainer-d8A46BK2.cjs"),Si=require("./getNoOfTicks-C_1CFXv_.cjs");function ki(r){const t=s.compilerRuntimeExports.c(217),{data:k,width:ot,height:Nt,lineColors:c,suffix:E,prefix:v,dateFormat:x,showValues:w,noOfXTicks:Tt,rightMargin:qt,leftMargin:V,topMargin:$t,bottomMargin:gt,tooltip:H,highlightAreaSettings:Mt,onSeriesMouseOver:Ft,animate:i,rtl:W,showColorLegendAtTop:Gt,colorDomain:N,diffAreaColors:D,idSuffix:st,strokeWidth:T,showDots:q,refValues:jt,minValue:I,maxValue:vt,annotations:Pt,customHighlightAreaSettings:Ht,yAxisTitle:Y,noOfYTicks:xe,minDate:Wt,maxDate:wt,curveType:Rt,styles:f,classNames:d,precision:b,customLayers:$}=r,bt=A.useRef(null);let X;t[0]!==i.amount||t[1]!==i.once?(X={once:i.once,amount:i.amount},t[0]=i.amount,t[1]=i.once,t[2]=X):X=t[2];const u=Ei.useInView(bt,X),[p,ne]=A.useState(!1);let Et,at;t[3]!==i.duration||t[4]!==p||t[5]!==u?(Et=()=>{if(u&&!p){const o=setTimeout(()=>{ne(!0)},(i.duration+.5)*1e3);return()=>clearTimeout(o)}},at=[u,p,i.duration],t[3]=i.duration,t[4]=p,t[5]=u,t[6]=Et,t[7]=at):(Et=t[6],at=t[7]),A.useEffect(Et,at);const U=Rt==="linear"?ni.curveLinear:Rt==="step"?Ge.curveStep:Rt==="stepAfter"?Ge.stepAfter:Rt==="stepBefore"?Ge.stepBefore:Ge.monotoneX,[L,g]=A.useState(void 0),[h,oe]=A.useState(void 0),[B,Yt]=A.useState(void 0),Ot=Y?V+30:V;let rt;t[8]!==gt||t[9]!==qt||t[10]!==Ot||t[11]!==$t?(rt={top:$t,bottom:gt,left:Ot,right:qt},t[8]=gt,t[9]=qt,t[10]=Ot,t[11]=$t,t[12]=rt):rt=t[12];const y=rt,lt=A.useRef(null);let z;t[13]!==x?(z=o=>({...o,date:O.parse(`${o.date}`,x,new Date)}),t[13]=x,t[14]=z):z=t[14];const n=xi.orderBy(k.map(z),["date"],["asc"]);let ct;if(t[15]!==x||t[16]!==Mt){let o;t[18]!==x?(o=e=>({...e,coordinates:[e.coordinates[0]===null?null:O.parse(`${e.coordinates[0]}`,x,new Date),e.coordinates[1]===null?null:O.parse(`${e.coordinates[1]}`,x,new Date)]}),t[18]=x,t[19]=o):o=t[19],ct=Mt.map(o),t[15]=x,t[16]=Mt,t[17]=ct}else ct=t[17];const Ct=ct;let ut;if(t[20]!==Ht||t[21]!==x){let o;t[23]!==x?(o=e=>({...e,coordinates:e.coordinates.map((P,Dt)=>Dt%2===0?O.parse(`${P}`,x,new Date):P)}),t[23]=x,t[24]=o):o=t[24],ut=Ht.map(o),t[20]=Ht,t[21]=x,t[22]=ut}else ut=t[22];const se=ut,m=ot-y.left-y.right,j=Nt-y.top-y.bottom,ae=Wt?O.parse(`${Wt}`,x,new Date):n[0].date,Xt=wt?O.parse(`${wt}`,x,new Date):n[n.length-1].date,J=Math.min(...n.map(zi))!==1/0?Math.min(...n.map(Bi))>0?0:Math.min(...n.map(Ui)):0,K=Math.min(...n.map(Xi))!==1/0?Math.min(...n.map(Yi))>0?0:Math.min(...n.map(Wi)):0,M=Math.max(...n.map(Hi))!==1/0?Math.max(...n.map(Pi)):0,Ut=Math.max(...n.map(Gi))!==1/0?Math.max(...n.map(Fi)):0;let Q;t[25]!==J||t[26]!==K||t[27]!==I?(Q=It.checkIfNullOrUndefined(I)?J<K?J:K:I,t[25]=J,t[26]=K,t[27]=I,t[28]=Q):Q=t[28];const R=Q,Z=M>Ut?M:Ut,a=ji.time().domain([ae,Xt]).range([0,m]);let xt;t[29]!==R||t[30]!==I?(xt=It.checkIfNullOrUndefined(I)?R:I,t[29]=R,t[30]=I,t[31]=xt):xt=t[31];let _;t[32]!==Z||t[33]!==vt?(_=It.checkIfNullOrUndefined(vt)?Z>0?Z:0:vt,t[32]=Z,t[33]=vt,t[34]=_):_=t[34];const l=vi.linear().domain([xt,_]).range([j,0]).nice(),mt=ni.line().x(o=>a(o.date)).y(o=>l(o.y1)).curve(U),Bt=ni.line().x(o=>a(o.date)).y(o=>l(o.y2)).curve(U),At=oi.area().x(o=>a(o.date)).y1(o=>l(o.y1)).y0(o=>l(o.y2)).curve(U),re=oi.area().x(o=>a(o.date)).y1(o=>l(o.y1)).y0(0).curve(U),le=oi.area().x(o=>a(o.date)).y1(o=>l(o.y2)).y0(0).curve(U),zt=l.ticks(xe),Jt=a.ticks(Tt);A.useEffect(()=>{const o=P=>{const Dt=n[Ri.bisectCenter(n.map(Mi),a.invert(bi.pointer(P)[0]),0)];g(Dt||n[n.length-1]),Ft?.(Dt||n[n.length-1]),Yt(P.clientY),oe(P.clientX)},e=()=>{g(void 0),oe(void 0),Yt(void 0),Ft?.(void 0)};wi.select(lt.current).on("mousemove",o).on("mouseout",e)},[a,n,Ft]);let dt;t[35]===Symbol.for("react.memo_cache_sentinel")?(dt={fill:"none"},t[35]=dt):dt=t[35];let tt;t[36]===Symbol.for("react.memo_cache_sentinel")?(tt={fill:"none"},t[36]=tt):tt=t[36];let pt;t[37]!==i||t[38]!==j||t[39]!==m||t[40]!==Ct||t[41]!==u||t[42]!==a?(pt=s.jsxRuntimeExports.jsx(gi.HighlightArea,{areaSettings:Ct,width:m,height:j,scale:a,animate:i,isInView:u}),t[37]=i,t[38]=j,t[39]=m,t[40]=Ct,t[41]=u,t[42]=a,t[43]=pt):pt=t[43];const et=f?.yAxis?.gridLines,ce=f?.yAxis?.labels;let it;t[44]!==et||t[45]!==ce?(it={gridLines:et,labels:ce},t[44]=et,t[45]=ce,t[46]=it):it=t[46];const ue=d?.yAxis?.gridLines,Vt=d?.yAxis?.labels;let Lt;t[47]!==ue||t[48]!==Vt?(Lt={gridLines:ue,labels:Vt},t[47]=ue,t[48]=Vt,t[49]=Lt):Lt=t[49];const ft=l(R<0?0:R),ht=l(R<0?0:R),St=0-V,kt=m+y.right,F=R<0?0:R;let C;t[50]!==b||t[51]!==v||t[52]!==E||t[53]!==F?(C=ei.numberFormattingFunction(F,"NA",b,v,E),t[50]=b,t[51]=v,t[52]=E,t[53]=F,t[54]=C):C=t[54];const G=0-V,yt=l(R<0?0:R),Kt=Z<0?"1rem":-5;let nt;t[55]!==G||t[56]!==yt||t[57]!==Kt?(nt={x:G,y:yt,dx:0,dy:Kt},t[55]=G,t[56]=yt,t[57]=Kt,t[58]=nt):nt=t[58];const He=d?.xAxis?.axis,We=d?.yAxis?.labels;let Qt;t[59]!==He||t[60]!==We?(Qt={axis:He,label:We},t[59]=He,t[60]=We,t[61]=Qt):Qt=t[61];const Ye=f?.xAxis?.axis,Xe=f?.yAxis?.labels;let Zt;t[62]!==Ye||t[63]!==Xe?(Zt={axis:Ye,label:Xe},t[62]=Ye,t[63]=Xe,t[64]=Zt):Zt=t[64];let me;t[65]!==ft||t[66]!==ht||t[67]!==St||t[68]!==kt||t[69]!==C||t[70]!==nt||t[71]!==Qt||t[72]!==Zt?(me=s.jsxRuntimeExports.jsx(pi.Axis,{y1:ft,y2:ht,x1:St,x2:kt,label:C,labelPos:nt,classNames:Qt,styles:Zt}),t[65]=ft,t[66]=ht,t[67]=St,t[68]=kt,t[69]=C,t[70]=nt,t[71]=Qt,t[72]=Zt,t[73]=me):me=t[73];const Ue=0-V-15,Be=j/2,ze=f?.yAxis?.title,Je=d?.yAxis?.title;let de;t[74]!==Ue||t[75]!==Be||t[76]!==ze||t[77]!==Je||t[78]!==Y?(de=s.jsxRuntimeExports.jsx(di.AxisTitle,{x:Ue,y:Be,style:ze,className:Je,text:Y,rotate90:!0}),t[74]=Ue,t[75]=Be,t[76]=ze,t[77]=Je,t[78]=Y,t[79]=de):de=t[79];let pe;t[80]!==x?(pe=o=>O.format(o,x),t[80]=x,t[81]=pe):pe=t[81];const ai=Jt.map(pe),ri=Jt.map(o=>a(o)),Ke=f?.xAxis?.gridLines,Qe=f?.xAxis?.labels;let fe;t[82]!==Ke||t[83]!==Qe?(fe={gridLines:Ke,labels:Qe},t[82]=Ke,t[83]=Qe,t[84]=fe):fe=t[84];const Ze=d?.xAxis?.gridLines;let _t;t[85]!==Ze?(_t=s.mo("opacity-0",Ze),t[85]=Ze,t[86]=_t):_t=t[86];const _e=d?.xAxis?.labels;let te;t[87]!==_e?(te=s.mo("fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs",_e),t[87]=_e,t[88]=te):te=t[88];let he;t[89]!==_t||t[90]!==te?(he={gridLines:_t,labels:te},t[89]=_t,t[90]=te,t[91]=he):he=t[91];let ye;t[92]!==$?(ye=$.filter(Ti).map(Ni),t[92]=$,t[93]=ye):ye=t[93];let ge;t[94]!==D[1]?(ge={fill:D[1]},t[94]=D[1],t[95]=ge):ge=t[95];let je;t[96]!==i.duration?(je={opacity:0,transition:{duration:i.duration}},t[96]=i.duration,t[97]=je):je=t[97];let ve;t[98]===Symbol.for("react.memo_cache_sentinel")?(ve={opacity:1},t[98]=ve):ve=t[98];let we;t[99]!==i.duration?(we={initial:ve,whileInView:{opacity:1,transition:{duration:i.duration}}},t[99]=i.duration,t[100]=we):we=t[100];let Re;t[101]!==D[0]?(Re={fill:D[0]},t[101]=D[0],t[102]=Re):Re=t[102];let be;t[103]!==i.duration?(be={opacity:0,transition:{duration:i.duration}},t[103]=i.duration,t[104]=be):be=t[104];let Ee;t[105]===Symbol.for("react.memo_cache_sentinel")?(Ee={opacity:0},t[105]=Ee):Ee=t[105];let Oe;t[106]!==i.duration?(Oe={initial:Ee,whileInView:{opacity:1,transition:{duration:i.duration}}},t[106]=i.duration,t[107]=Oe):Oe=t[107];let Ce;t[108]!==c[0]||t[109]!==T?(Ce={fill:"none",stroke:c[0],strokeWidth:T},t[108]=c[0],t[109]=T,t[110]=Ce):Ce=t[110];let Ae;t[111]!==i.duration?(Ae={opacity:0,transition:{duration:i.duration}},t[111]=i.duration,t[112]=Ae):Ae=t[112];let Ve;t[113]!==c[1]||t[114]!==T?(Ve={fill:"none",stroke:c[1],strokeWidth:T},t[113]=c[1],t[114]=T,t[115]=Ve):Ve=t[115];let Le;t[116]!==i.duration?(Le={opacity:0,transition:{duration:i.duration}},t[116]=i.duration,t[117]=Le):Le=t[117];const li=1,ti=Bt(n)||"";let ee;t[118]!==i.duration?(ee={duration:i.duration},t[118]=i.duration,t[119]=ee):ee=t[119];let Se;t[120]!==ti||t[121]!==ee?(Se={pathLength:li,d:ti,opacity:1,transition:ee},t[120]=ti,t[121]=ee,t[122]=Se):Se=t[122];let ke;t[123]!==i.duration||t[124]!==N||t[125]!==n||t[126]!==p||t[127]!==u||t[128]!==c[0]||t[129]!==c[1]||t[130]!==Gt||t[131]!==a||t[132]!==l?(ke=Gt?null:s.jsxRuntimeExports.jsxs("g",{children:[s.jsxRuntimeExports.jsx(S.motion.text,{className:"text-xs",dx:5,dy:4,exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,x:a(n[n.length-1].date),y:l(n[n.length-1].y1),fill:c[0]},whileInView:{opacity:1,x:a(n[n.length-1].date),y:l(n[n.length-1].y1),fill:c[0],transition:{duration:p?i.duration:.5,delay:p?0:i.duration}}},initial:"initial",animate:u?"whileInView":"initial",children:N[0]},N[0]),s.jsxRuntimeExports.jsx(S.motion.text,{className:"text-xs",dx:5,dy:4,exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,x:a(n[n.length-1].date),y:l(n[n.length-1].y2),fill:c[1]},whileInView:{opacity:1,x:a(n[n.length-1].date),y:l(n[n.length-1].y2),fill:c[1],transition:{duration:p?i.duration:.5,delay:p?0:i.duration}}},initial:"initial",animate:u?"whileInView":"initial",children:N[1]},N[1])]}),t[123]=i.duration,t[124]=N,t[125]=n,t[126]=p,t[127]=u,t[128]=c[0],t[129]=c[1],t[130]=Gt,t[131]=a,t[132]=l,t[133]=ke):ke=t[133];let De;t[134]!==d?.mouseOverLine||t[135]!==j||t[136]!==L||t[137]!==f?.mouseOverLine||t[138]!==a?(De=L?s.jsxRuntimeExports.jsx("line",{y1:0,y2:j,x1:a(L.date),x2:a(L.date),className:s.mo("undp-tick-line stroke-primary-gray-700 dark:stroke-primary-gray-100",d?.mouseOverLine),style:f?.mouseOverLine}):null,t[134]=d?.mouseOverLine,t[135]=j,t[136]=L,t[137]=f?.mouseOverLine,t[138]=a,t[139]=De):De=t[139];let Ie;if(t[140]!==i.duration||t[141]!==d?.graphObjectValues||t[142]!==n||t[143]!==m||t[144]!==p||t[145]!==u||t[146]!==c[0]||t[147]!==c[1]||t[148]!==b||t[149]!==v||t[150]!==q||t[151]!==w||t[152]!==f?.graphObjectValues||t[153]!==E||t[154]!==a||t[155]!==l){let o;t[157]!==i.duration||t[158]!==d?.graphObjectValues||t[159]!==n.length||t[160]!==m||t[161]!==p||t[162]!==u||t[163]!==c[0]||t[164]!==c[1]||t[165]!==b||t[166]!==v||t[167]!==q||t[168]!==w||t[169]!==f?.graphObjectValues||t[170]!==E||t[171]!==a||t[172]!==l?(o=(e,P)=>s.jsxRuntimeExports.jsxs(S.motion.g,{children:[It.checkIfNullOrUndefined(e.y1)?null:s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[q?s.jsxRuntimeExports.jsx(S.motion.circle,{r:m/n.length<5?0:m/n.length<20?2:4,exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,cx:a(e.date),cy:l(e.y1),fill:c[0]},whileInView:{opacity:1,fill:c[0],transition:{duration:.5,delay:i.duration},cx:a(e.date),cy:l(e.y1)}},initial:"initial",animate:u?"whileInView":"initial"}):null,w?s.jsxRuntimeExports.jsx(S.motion.text,{dy:e.y2<e.y1?-8:"1em",style:{textAnchor:"middle",...f?.graphObjectValues||{}},className:s.mo("graph-value graph-value-line-1 text-xs font-bold",d?.graphObjectValues),exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,x:a(e.date),y:l(e.y1),fill:c[0]},whileInView:{opacity:1,fill:c[0],x:a(e.date),y:l(e.y1),transition:{duration:p?i.duration:.5,delay:p?0:i.duration}}},initial:"initial",animate:u?"whileInView":"initial",children:ei.numberFormattingFunction(e.y1,"NA",b,v,E)}):null]}),It.checkIfNullOrUndefined(e.y2)?null:s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[q?s.jsxRuntimeExports.jsx(S.motion.circle,{r:m/n.length<5?0:m/n.length<20?2:4,exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,cx:a(e.date),cy:l(e.y2),fill:c[1]},whileInView:{opacity:1,fill:c[1],transition:{duration:p?i.duration:.5,delay:p?0:i.duration},cx:a(e.date),cy:l(e.y2)}},initial:"initial",animate:u?"whileInView":"initial"}):null,w?s.jsxRuntimeExports.jsx(S.motion.text,{dy:e.y2>e.y1?-8:"1em",style:{textAnchor:"middle",...f?.graphObjectValues||{}},className:s.mo("graph-value graph-value-line-2 text-xs font-bold",d?.graphObjectValues),exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,x:a(e.date),y:l(e.y2),fill:c[1]},whileInView:{opacity:1,x:a(e.date),y:l(e.y2),fill:c[1],transition:{duration:p?i.duration:.5,delay:p?0:i.duration}}},initial:"initial",animate:u?"whileInView":"initial",children:ei.numberFormattingFunction(e.y2,"NA",b,v,E)}):null]})]},P),t[157]=i.duration,t[158]=d?.graphObjectValues,t[159]=n.length,t[160]=m,t[161]=p,t[162]=u,t[163]=c[0],t[164]=c[1],t[165]=b,t[166]=v,t[167]=q,t[168]=w,t[169]=f?.graphObjectValues,t[170]=E,t[171]=a,t[172]=l,t[173]=o):o=t[173],Ie=n.map(o),t[140]=i.duration,t[141]=d?.graphObjectValues,t[142]=n,t[143]=m,t[144]=p,t[145]=u,t[146]=c[0],t[147]=c[1],t[148]=b,t[149]=v,t[150]=q,t[151]=w,t[152]=f?.graphObjectValues,t[153]=E,t[154]=a,t[155]=l,t[156]=Ie}else Ie=t[156];let Ne;t[174]!==i||t[175]!==m||t[176]!==u||t[177]!==V||t[178]!==y.right||t[179]!==jt||t[180]!==l?(Ne=jt?s.jsxRuntimeExports.jsx(s.jsxRuntimeExports.Fragment,{children:jt.map((o,e)=>s.jsxRuntimeExports.jsx(hi.RefLineY,{text:o.text,color:o.color,y:l(o.value),x1:0-V,x2:m+y.right,classNames:o.classNames,styles:o.styles,animate:i,isInView:u},e))}):null,t[174]=i,t[175]=m,t[176]=u,t[177]=V,t[178]=y.right,t[179]=jt,t[180]=l,t[181]=Ne):Ne=t[181];let ie;if(t[182]!==i||t[183]!==Pt||t[184]!==x||t[185]!==m||t[186]!==u||t[187]!==y.right||t[188]!==W||t[189]!==a||t[190]!==l){let o;t[192]!==i||t[193]!==x||t[194]!==m||t[195]!==u||t[196]!==y.right||t[197]!==W||t[198]!==a||t[199]!==l?(o=(e,P)=>{const Dt=ii.getLineEndPoint({x:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0),y:e.yCoordinate?l(e.yCoordinate)+(e.yOffset||0)-8:0+(e.yOffset||0)-8},{x:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date)):0,y:e.yCoordinate?l(e.yCoordinate):0},It.checkIfNullOrUndefined(e.connectorRadius)?3.5:e.connectorRadius),ci=e.showConnector?{y1:Dt.y,x1:Dt.x,y2:e.yCoordinate?l(e.yCoordinate)+(e.yOffset||0):0+(e.yOffset||0),x2:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0),cy:e.yCoordinate?l(e.yCoordinate):0,cx:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date)):0,circleRadius:It.checkIfNullOrUndefined(e.connectorRadius)?3.5:e.connectorRadius,strokeWidth:e.showConnector===!0?2:Math.min(e.showConnector||0,1)}:void 0,ui={y:e.yCoordinate?l(e.yCoordinate)+(e.yOffset||0)-8:0+(e.yOffset||0)-8,x:W?0:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0),width:W?e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0):m+y.right-(e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0)),maxWidth:e.maxWidth,fontWeight:e.fontWeight,align:e.align};return s.jsxRuntimeExports.jsx(ii.Annotation,{color:e.color,connectorsSettings:ci,labelSettings:ui,text:e.text,classNames:e.classNames,styles:e.styles,animate:i,isInView:u},P)},t[192]=i,t[193]=x,t[194]=m,t[195]=u,t[196]=y.right,t[197]=W,t[198]=a,t[199]=l,t[200]=o):o=t[200],ie=Pt.map(o),t[182]=i,t[183]=Pt,t[184]=x,t[185]=m,t[186]=u,t[187]=y.right,t[188]=W,t[189]=a,t[190]=l,t[191]=ie}else ie=t[191];let Te;t[201]!==ie?(Te=s.jsxRuntimeExports.jsx("g",{children:ie}),t[201]=ie,t[202]=Te):Te=t[202];let qe;t[203]!==$?(qe=$.filter(Ii).map(Di),t[203]=$,t[204]=qe):qe=t[204];let $e;t[205]===Symbol.for("react.memo_cache_sentinel")?($e={fill:"none",pointerEvents:"all"},t[205]=$e):$e=t[205];let Me;t[206]!==lt||t[207]!==j||t[208]!==m?(Me=s.jsxRuntimeExports.jsx("rect",{ref:lt,style:$e,width:m,height:j}),t[206]=lt,t[207]=j,t[208]=m,t[209]=Me):Me=t[209];let Fe;return t[210]!==d?.tooltip||t[211]!==h||t[212]!==B||t[213]!==L||t[214]!==f?.tooltip||t[215]!==H?(Fe=L&&H&&h&&B?s.jsxRuntimeExports.jsx(mi.Tooltip,{data:L,body:H,xPos:h,yPos:B,backgroundStyle:f?.tooltip,className:d?.tooltip}):null,t[210]=d?.tooltip,t[211]=h,t[212]=B,t[213]=L,t[214]=f?.tooltip,t[215]=H,t[216]=Fe):Fe=t[216],s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[s.jsxRuntimeExports.jsx(S.motion.svg,{width:`${ot}px`,height:`${Nt}px`,viewBox:`0 0 ${ot} ${Nt}`,direction:"ltr",ref:bt,children:s.jsxRuntimeExports.jsxs("g",{transform:`translate(${y.left},${y.top})`,children:[s.jsxRuntimeExports.jsx("clipPath",{id:`above${st}`,children:s.jsxRuntimeExports.jsx("path",{d:le(n),style:dt})}),s.jsxRuntimeExports.jsx("clipPath",{id:`below${st}`,children:s.jsxRuntimeExports.jsx("path",{d:re(n),style:tt})}),pt,s.jsxRuntimeExports.jsx(ii.CustomArea,{areaSettings:se,scaleX:a,scaleY:l,animate:i,isInView:u}),s.jsxRuntimeExports.jsx("g",{children:s.jsxRuntimeExports.jsxs("g",{children:[s.jsxRuntimeExports.jsx(yi.YTicksAndGridLines,{values:zt.filter($i),y:zt.filter(qi).map(o=>l(o)),x1:0-V,x2:m+y.right,styles:it,classNames:Lt,suffix:E,prefix:v,labelType:"secondary",showGridLines:!0,labelPos:"vertical",precision:b}),me,de]})}),s.jsxRuntimeExports.jsx(fi.XTicksAndGridLines,{values:ai,x:ri,y1:0,y2:j,styles:fe,classNames:he,suffix:E,prefix:v,labelType:"primary",showGridLines:!0,precision:b}),ye,s.jsxRuntimeExports.jsxs("g",{children:[s.jsxRuntimeExports.jsx(S.motion.path,{clipPath:`url(#below${st})`,d:At(n)||"",style:ge,exit:je,variants:we,initial:"initial",animate:u?"whileInView":"initial"}),s.jsxRuntimeExports.jsx(S.motion.path,{clipPath:`url(#above${st})`,d:At(n)||"",style:Re,exit:be,variants:Oe,initial:"initial",animate:u?"whileInView":"initial"})]}),s.jsxRuntimeExports.jsxs("g",{children:[s.jsxRuntimeExports.jsx(S.motion.path,{d:mt(n)||"",style:Ce,exit:Ae,variants:{initial:{pathLength:0,d:mt(n)||"",opacity:1},whileInView:{pathLength:1,d:mt(n)||"",opacity:1,transition:{duration:i.duration}}},initial:"initial",animate:u?"whileInView":"initial"}),s.jsxRuntimeExports.jsx(S.motion.path,{style:Ve,exit:Le,variants:{initial:{pathLength:0,d:Bt(n)||"",opacity:1},whileInView:Se},initial:"initial",animate:u?"whileInView":"initial"}),ke,De,Ie]}),Ne,Te,qe,Me]})}),Fe]})}function Di(r){return r.layer}function Ii(r){return r.position==="after"}function Ni(r){return r.layer}function Ti(r){return r.position==="before"}function qi(r){return r!==0}function $i(r){return r!==0}function Mi(r){return r.date}function Fi(r){return r.y2}function Gi(r){return r.y2}function Pi(r){return r.y1}function Hi(r){return r.y1}function Wi(r){return r.y2}function Yi(r){return r.y2}function Xi(r){return r.y2}function Ui(r){return r.y1}function Bi(r){return r.y1}function zi(r){return r.y1}function Ji(r){const t=s.compilerRuntimeExports.c(90),{data:k,graphTitle:ot,suffix:Nt,sources:c,prefix:E,graphDescription:v,height:x,width:w,footNote:Tt,noOfXTicks:qt,dateFormat:V,showValues:$t,padding:gt,lineColors:H,backgroundColor:Mt,leftMargin:Ft,rightMargin:i,topMargin:W,bottomMargin:Gt,tooltip:N,highlightAreaSettings:D,relativeHeight:st,onSeriesMouseOver:T,graphID:q,graphDownload:jt,dataDownload:I,animate:vt,language:Pt,minHeight:Ht,labels:Y,showColorLegendAtTop:xe,colorLegendTitle:Wt,diffAreaColors:wt,strokeWidth:Rt,showDots:f,refValues:d,minValue:b,maxValue:$,annotations:bt,customHighlightAreaSettings:X,theme:u,ariaLabel:p,yAxisTitle:ne,noOfYTicks:Et,minDate:at,maxDate:U,curveType:L,styles:g,classNames:h,precision:oe,customLayers:B}=r,Yt=Nt===void 0?"":Nt,Ot=E===void 0?"":E,rt=qt===void 0?10:qt,y=V===void 0?"yyyy":V,lt=$t===void 0?!1:$t;let z;t[0]!==H?(z=H===void 0?[Pe.Colors.light.categoricalColors.colors[0],Pe.Colors.light.categoricalColors.colors[1]]:H,t[0]=H,t[1]=z):z=t[1];const n=z,ct=Mt===void 0?!1:Mt,Ct=Ft===void 0?30:Ft,ut=i===void 0?50:i,se=W===void 0?20:W,m=Gt===void 0?25:Gt;let j;t[2]!==D?(j=D===void 0?[]:D,t[2]=D,t[3]=j):j=t[3];const ae=j,Xt=jt===void 0?!1:jt,J=I===void 0?!1:I,K=vt===void 0?!1:vt,M=Pt===void 0?"en":Pt,Ut=Ht===void 0?0:Ht,Q=xe===void 0?!1:xe;let R;t[4]!==wt?(R=wt===void 0?[Pe.Colors.alerts.red,Pe.Colors.alerts.darkGreen]:wt,t[4]=wt,t[5]=R):R=t[5];const Z=R,a=Rt===void 0?2:Rt,xt=f===void 0?!0:f;let _;t[6]!==d?(_=d===void 0?[]:d,t[6]=d,t[7]=_):_=t[7];const l=_;let mt;t[8]!==bt?(mt=bt===void 0?[]:bt,t[8]=bt,t[9]=mt):mt=t[9];const Bt=mt;let At;t[10]!==X?(At=X===void 0?[]:X,t[10]=X,t[11]=At):At=t[11];const re=At,le=u===void 0?"light":u,zt=Et===void 0?5:Et,Jt=L===void 0?"curve":L,dt=oe===void 0?2:oe;let tt;t[12]!==B?(tt=B===void 0?[]:B,t[12]=B,t[13]=tt):tt=t[13];const pt=tt,[et,ce]=A.useState(0),[it,ue]=A.useState(0),Vt=A.useRef(null),Lt=A.useRef(null);let ft,ht;t[14]===Symbol.for("react.memo_cache_sentinel")?(ft=()=>{const Kt=new ResizeObserver(nt=>{ce(nt[0].target.clientWidth||620),ue(nt[0].target.clientHeight||480)});return Vt.current&&Kt.observe(Vt.current),()=>Kt.disconnect()},ht=[],t[14]=ft,t[15]=ht):(ft=t[14],ht=t[15]),A.useEffect(ft,ht);const St=h?.graphContainer,kt=g?.graphContainer;let F;t[16]!==h?.description||t[17]!==h?.title||t[18]!==k||t[19]!==J||t[20]!==v||t[21]!==Xt||t[22]!==ot||t[23]!==g?.description||t[24]!==g?.title||t[25]!==w?(F=ot||v||Xt||J?s.jsxRuntimeExports.jsx(Ci.GraphHeader,{styles:{title:g?.title,description:g?.description},classNames:{title:h?.title,description:h?.description},graphTitle:ot,graphDescription:v,width:w,graphDownload:Xt?Lt:void 0,dataDownload:J?k.map(tn).filter(_i).length>0?k.map(Zi).filter(Qi):k.filter(Ki):null}):null,t[16]=h?.description,t[17]=h?.title,t[18]=k,t[19]=J,t[20]=v,t[21]=Xt,t[22]=ot,t[23]=g?.description,t[24]=g?.title,t[25]=w,t[26]=F):F=t[26];let C;t[27]!==K||t[28]!==Bt||t[29]!==m||t[30]!==h||t[31]!==Wt||t[32]!==Jt||t[33]!==re||t[34]!==pt||t[35]!==k||t[36]!==y||t[37]!==Z||t[38]!==ae||t[39]!==Y||t[40]!==M||t[41]!==Ct||t[42]!==n||t[43]!==U||t[44]!==$||t[45]!==at||t[46]!==b||t[47]!==rt||t[48]!==zt||t[49]!==T||t[50]!==dt||t[51]!==Ot||t[52]!==l||t[53]!==ut||t[54]!==Q||t[55]!==xt||t[56]!==lt||t[57]!==a||t[58]!==g||t[59]!==Yt||t[60]!==it||t[61]!==et||t[62]!==N||t[63]!==se||t[64]!==ne?(C=k.length===0?s.jsxRuntimeExports.jsx(Li.EmptyState,{}):s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[Q?s.jsxRuntimeExports.jsx(Ai.ColorLegend,{colorDomain:Y,colorLegendTitle:Wt,colors:n,showNAColor:!1,className:h?.colorLegend}):null,s.jsxRuntimeExports.jsx(si.GraphArea,{ref:Vt,children:et&&it?s.jsxRuntimeExports.jsx(ki,{data:k,lineColors:n,colorDomain:Y,width:et,height:it,suffix:Yt,prefix:Ot,dateFormat:y,showValues:lt,noOfXTicks:rt??Si.getNoOfTicks(et),leftMargin:Ct,rightMargin:ut,topMargin:se,bottomMargin:m,highlightAreaSettings:ae,tooltip:N,onSeriesMouseOver:T,showColorLegendAtTop:Q,animate:K===!0?{duration:.5,once:!0,amount:.5}:K||{duration:0,once:!0,amount:0},rtl:M==="he"||M==="ar",diffAreaColors:Z,idSuffix:Vi.generateRandomString(8),strokeWidth:a,showDots:xt,refValues:l,minValue:b,maxValue:$,annotations:Bt,customHighlightAreaSettings:re,yAxisTitle:ne,noOfYTicks:zt,minDate:at,maxDate:U,curveType:Jt,styles:g,classNames:h,precision:dt,customLayers:pt}):null})]}),t[27]=K,t[28]=Bt,t[29]=m,t[30]=h,t[31]=Wt,t[32]=Jt,t[33]=re,t[34]=pt,t[35]=k,t[36]=y,t[37]=Z,t[38]=ae,t[39]=Y,t[40]=M,t[41]=Ct,t[42]=n,t[43]=U,t[44]=$,t[45]=at,t[46]=b,t[47]=rt,t[48]=zt,t[49]=T,t[50]=dt,t[51]=Ot,t[52]=l,t[53]=ut,t[54]=Q,t[55]=xt,t[56]=lt,t[57]=a,t[58]=g,t[59]=Yt,t[60]=it,t[61]=et,t[62]=N,t[63]=se,t[64]=ne,t[65]=C):C=t[65];let G;t[66]!==h?.footnote||t[67]!==h?.source||t[68]!==Tt||t[69]!==c||t[70]!==g?.footnote||t[71]!==g?.source||t[72]!==w?(G=c||Tt?s.jsxRuntimeExports.jsx(Oi.GraphFooter,{styles:{footnote:g?.footnote,source:g?.source},classNames:{footnote:h?.footnote,source:h?.source},sources:c,footNote:Tt,width:w}):null,t[66]=h?.footnote,t[67]=h?.source,t[68]=Tt,t[69]=c,t[70]=g?.footnote,t[71]=g?.source,t[72]=w,t[73]=G):G=t[73];let yt;return t[74]!==p||t[75]!==ct||t[76]!==q||t[77]!==x||t[78]!==M||t[79]!==Ut||t[80]!==gt||t[81]!==st||t[82]!==St||t[83]!==kt||t[84]!==F||t[85]!==C||t[86]!==G||t[87]!==le||t[88]!==w?(yt=s.jsxRuntimeExports.jsxs(si.GraphContainer,{className:St,style:kt,id:q,ref:Lt,"aria-label":p,backgroundColor:ct,theme:le,language:M,minHeight:Ut,width:w,height:x,relativeHeight:st,padding:gt,children:[F,C,G]}),t[74]=p,t[75]=ct,t[76]=q,t[77]=x,t[78]=M,t[79]=Ut,t[80]=gt,t[81]=st,t[82]=St,t[83]=kt,t[84]=F,t[85]=C,t[86]=G,t[87]=le,t[88]=w,t[89]=yt):yt=t[89],yt}function Ki(r){return r!==void 0}function Qi(r){return r!==void 0}function Zi(r){return r.data}function _i(r){return r!==void 0}function tn(r){return r.data}exports.DifferenceLineChart=Ji;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./index-CHPV5EwG-CTPQjnHt.cjs"),A=require("react"),O=require("./parse-hMnG_lRV.cjs"),xi=require("./index-Cno4Q0YE.cjs"),ei=require("./numberFormattingFunction-02t-wJta.cjs"),mi=require("./Tooltip-uUdw6wJL.cjs"),It=require("./checkIfNullOrUndefined-BCW3Y1ML.cjs"),ii=require("./customArea-CMF5g-C3.cjs"),di=require("./AxisTitle-sS5bLLR7.cjs"),pi=require("./Axis-DxRV2yMi.cjs"),fi=require("./XTicksAndGridLines-B6CELS7q.cjs"),hi=require("./ReferenceLine-BH0qdf4R.cjs"),yi=require("./YTicksAndGridLines-4pxTRlRK.cjs"),gi=require("./index-B_sAFsEV.cjs"),ji=require("./time-CZd5YLSP.cjs"),vi=require("./linear-BwPAspcq.cjs"),ni=require("./line-DHV4JwCR.cjs"),Ge=require("./step-BZ3C8QFW.cjs"),oi=require("./area-D3Qx7k7K.cjs"),wi=require("./select-Bnfk0lJx.cjs"),Ri=require("./init-DU0ybBc_.cjs"),bi=require("./pointer-Dkq5NV1q.cjs"),Ei=require("./use-in-view-QcfiW0w3.cjs"),S=require("./proxy-BxvUI_9l.cjs"),Oi=require("./GraphFooter.cjs"),Ci=require("./GraphHeader.cjs"),Ai=require("./ColorLegend.cjs"),Pe=require("./Colors.cjs"),Vi=require("./generateRandomString-B5zBiJzS.cjs"),Li=require("./EmptyState-sAEZ_5rU.cjs"),si=require("./GraphContainer-d8A46BK2.cjs"),Si=require("./getNoOfTicks-C_1CFXv_.cjs");function ki(r){const t=s.compilerRuntimeExports.c(217),{data:k,width:ot,height:Nt,lineColors:c,suffix:E,prefix:v,dateFormat:x,showValues:w,noOfXTicks:Tt,rightMargin:qt,leftMargin:V,topMargin:$t,bottomMargin:gt,tooltip:H,highlightAreaSettings:Mt,onSeriesMouseOver:Ft,animate:i,rtl:W,showColorLegendAtTop:Gt,colorDomain:N,diffAreaColors:D,idSuffix:st,strokeWidth:T,showDots:q,refValues:jt,minValue:I,maxValue:vt,annotations:Pt,customHighlightAreaSettings:Ht,yAxisTitle:Y,noOfYTicks:xe,minDate:Wt,maxDate:wt,curveType:Rt,styles:f,classNames:d,precision:b,customLayers:$}=r,bt=A.useRef(null);let X;t[0]!==i.amount||t[1]!==i.once?(X={once:i.once,amount:i.amount},t[0]=i.amount,t[1]=i.once,t[2]=X):X=t[2];const u=Ei.useInView(bt,X),[p,ne]=A.useState(!1);let Et,at;t[3]!==i.duration||t[4]!==p||t[5]!==u?(Et=()=>{if(u&&!p){const o=setTimeout(()=>{ne(!0)},(i.duration+.5)*1e3);return()=>clearTimeout(o)}},at=[u,p,i.duration],t[3]=i.duration,t[4]=p,t[5]=u,t[6]=Et,t[7]=at):(Et=t[6],at=t[7]),A.useEffect(Et,at);const U=Rt==="linear"?ni.curveLinear:Rt==="step"?Ge.curveStep:Rt==="stepAfter"?Ge.stepAfter:Rt==="stepBefore"?Ge.stepBefore:Ge.monotoneX,[L,g]=A.useState(void 0),[h,oe]=A.useState(void 0),[B,Yt]=A.useState(void 0),Ot=Y?V+30:V;let rt;t[8]!==gt||t[9]!==qt||t[10]!==Ot||t[11]!==$t?(rt={top:$t,bottom:gt,left:Ot,right:qt},t[8]=gt,t[9]=qt,t[10]=Ot,t[11]=$t,t[12]=rt):rt=t[12];const y=rt,lt=A.useRef(null);let z;t[13]!==x?(z=o=>({...o,date:O.parse(`${o.date}`,x,new Date)}),t[13]=x,t[14]=z):z=t[14];const n=xi.orderBy(k.map(z),["date"],["asc"]);let ct;if(t[15]!==x||t[16]!==Mt){let o;t[18]!==x?(o=e=>({...e,coordinates:[e.coordinates[0]===null?null:O.parse(`${e.coordinates[0]}`,x,new Date),e.coordinates[1]===null?null:O.parse(`${e.coordinates[1]}`,x,new Date)]}),t[18]=x,t[19]=o):o=t[19],ct=Mt.map(o),t[15]=x,t[16]=Mt,t[17]=ct}else ct=t[17];const Ct=ct;let ut;if(t[20]!==Ht||t[21]!==x){let o;t[23]!==x?(o=e=>({...e,coordinates:e.coordinates.map((P,Dt)=>Dt%2===0?O.parse(`${P}`,x,new Date):P)}),t[23]=x,t[24]=o):o=t[24],ut=Ht.map(o),t[20]=Ht,t[21]=x,t[22]=ut}else ut=t[22];const se=ut,m=ot-y.left-y.right,j=Nt-y.top-y.bottom,ae=Wt?O.parse(`${Wt}`,x,new Date):n[0].date,Xt=wt?O.parse(`${wt}`,x,new Date):n[n.length-1].date,J=Math.min(...n.map(zi))!==1/0?Math.min(...n.map(Bi))>0?0:Math.min(...n.map(Ui)):0,K=Math.min(...n.map(Xi))!==1/0?Math.min(...n.map(Yi))>0?0:Math.min(...n.map(Wi)):0,M=Math.max(...n.map(Hi))!==1/0?Math.max(...n.map(Pi)):0,Ut=Math.max(...n.map(Gi))!==1/0?Math.max(...n.map(Fi)):0;let Q;t[25]!==J||t[26]!==K||t[27]!==I?(Q=It.checkIfNullOrUndefined(I)?J<K?J:K:I,t[25]=J,t[26]=K,t[27]=I,t[28]=Q):Q=t[28];const R=Q,Z=M>Ut?M:Ut,a=ji.time().domain([ae,Xt]).range([0,m]);let xt;t[29]!==R||t[30]!==I?(xt=It.checkIfNullOrUndefined(I)?R:I,t[29]=R,t[30]=I,t[31]=xt):xt=t[31];let _;t[32]!==Z||t[33]!==vt?(_=It.checkIfNullOrUndefined(vt)?Z>0?Z:0:vt,t[32]=Z,t[33]=vt,t[34]=_):_=t[34];const l=vi.linear().domain([xt,_]).range([j,0]).nice(),mt=ni.line().x(o=>a(o.date)).y(o=>l(o.y1)).curve(U),Bt=ni.line().x(o=>a(o.date)).y(o=>l(o.y2)).curve(U),At=oi.area().x(o=>a(o.date)).y1(o=>l(o.y1)).y0(o=>l(o.y2)).curve(U),re=oi.area().x(o=>a(o.date)).y1(o=>l(o.y1)).y0(0).curve(U),le=oi.area().x(o=>a(o.date)).y1(o=>l(o.y2)).y0(0).curve(U),zt=l.ticks(xe),Jt=a.ticks(Tt);A.useEffect(()=>{const o=P=>{const Dt=n[Ri.bisectCenter(n.map(Mi),a.invert(bi.pointer(P)[0]),0)];g(Dt||n[n.length-1]),Ft?.(Dt||n[n.length-1]),Yt(P.clientY),oe(P.clientX)},e=()=>{g(void 0),oe(void 0),Yt(void 0),Ft?.(void 0)};wi.select(lt.current).on("mousemove",o).on("mouseout",e)},[a,n,Ft]);let dt;t[35]===Symbol.for("react.memo_cache_sentinel")?(dt={fill:"none"},t[35]=dt):dt=t[35];let tt;t[36]===Symbol.for("react.memo_cache_sentinel")?(tt={fill:"none"},t[36]=tt):tt=t[36];let pt;t[37]!==i||t[38]!==j||t[39]!==m||t[40]!==Ct||t[41]!==u||t[42]!==a?(pt=s.jsxRuntimeExports.jsx(gi.HighlightArea,{areaSettings:Ct,width:m,height:j,scale:a,animate:i,isInView:u}),t[37]=i,t[38]=j,t[39]=m,t[40]=Ct,t[41]=u,t[42]=a,t[43]=pt):pt=t[43];const et=f?.yAxis?.gridLines,ce=f?.yAxis?.labels;let it;t[44]!==et||t[45]!==ce?(it={gridLines:et,labels:ce},t[44]=et,t[45]=ce,t[46]=it):it=t[46];const ue=d?.yAxis?.gridLines,Vt=d?.yAxis?.labels;let Lt;t[47]!==ue||t[48]!==Vt?(Lt={gridLines:ue,labels:Vt},t[47]=ue,t[48]=Vt,t[49]=Lt):Lt=t[49];const ft=l(R<0?0:R),ht=l(R<0?0:R),St=0-V,kt=m+y.right,F=R<0?0:R;let C;t[50]!==b||t[51]!==v||t[52]!==E||t[53]!==F?(C=ei.numberFormattingFunction(F,"NA",b,v,E),t[50]=b,t[51]=v,t[52]=E,t[53]=F,t[54]=C):C=t[54];const G=0-V,yt=l(R<0?0:R),Kt=Z<0?"1rem":-5;let nt;t[55]!==G||t[56]!==yt||t[57]!==Kt?(nt={x:G,y:yt,dx:0,dy:Kt},t[55]=G,t[56]=yt,t[57]=Kt,t[58]=nt):nt=t[58];const He=d?.xAxis?.axis,We=d?.yAxis?.labels;let Qt;t[59]!==He||t[60]!==We?(Qt={axis:He,label:We},t[59]=He,t[60]=We,t[61]=Qt):Qt=t[61];const Ye=f?.xAxis?.axis,Xe=f?.yAxis?.labels;let Zt;t[62]!==Ye||t[63]!==Xe?(Zt={axis:Ye,label:Xe},t[62]=Ye,t[63]=Xe,t[64]=Zt):Zt=t[64];let me;t[65]!==ft||t[66]!==ht||t[67]!==St||t[68]!==kt||t[69]!==C||t[70]!==nt||t[71]!==Qt||t[72]!==Zt?(me=s.jsxRuntimeExports.jsx(pi.Axis,{y1:ft,y2:ht,x1:St,x2:kt,label:C,labelPos:nt,classNames:Qt,styles:Zt}),t[65]=ft,t[66]=ht,t[67]=St,t[68]=kt,t[69]=C,t[70]=nt,t[71]=Qt,t[72]=Zt,t[73]=me):me=t[73];const Ue=0-V-15,Be=j/2,ze=f?.yAxis?.title,Je=d?.yAxis?.title;let de;t[74]!==Ue||t[75]!==Be||t[76]!==ze||t[77]!==Je||t[78]!==Y?(de=s.jsxRuntimeExports.jsx(di.AxisTitle,{x:Ue,y:Be,style:ze,className:Je,text:Y,rotate90:!0}),t[74]=Ue,t[75]=Be,t[76]=ze,t[77]=Je,t[78]=Y,t[79]=de):de=t[79];let pe;t[80]!==x?(pe=o=>O.format(o,x),t[80]=x,t[81]=pe):pe=t[81];const ai=Jt.map(pe),ri=Jt.map(o=>a(o)),Ke=f?.xAxis?.gridLines,Qe=f?.xAxis?.labels;let fe;t[82]!==Ke||t[83]!==Qe?(fe={gridLines:Ke,labels:Qe},t[82]=Ke,t[83]=Qe,t[84]=fe):fe=t[84];const Ze=d?.xAxis?.gridLines;let _t;t[85]!==Ze?(_t=s.mo("opacity-0",Ze),t[85]=Ze,t[86]=_t):_t=t[86];const _e=d?.xAxis?.labels;let te;t[87]!==_e?(te=s.mo("fill-primary-gray-700 dark:fill-primary-gray-300 xs:max-[360px]:hidden text-[9px] md:text-[10px] lg:text-xs",_e),t[87]=_e,t[88]=te):te=t[88];let he;t[89]!==_t||t[90]!==te?(he={gridLines:_t,labels:te},t[89]=_t,t[90]=te,t[91]=he):he=t[91];let ye;t[92]!==$?(ye=$.filter(Ti).map(Ni),t[92]=$,t[93]=ye):ye=t[93];let ge;t[94]!==D[1]?(ge={fill:D[1]},t[94]=D[1],t[95]=ge):ge=t[95];let je;t[96]!==i.duration?(je={opacity:0,transition:{duration:i.duration}},t[96]=i.duration,t[97]=je):je=t[97];let ve;t[98]===Symbol.for("react.memo_cache_sentinel")?(ve={opacity:1},t[98]=ve):ve=t[98];let we;t[99]!==i.duration?(we={initial:ve,whileInView:{opacity:1,transition:{duration:i.duration}}},t[99]=i.duration,t[100]=we):we=t[100];let Re;t[101]!==D[0]?(Re={fill:D[0]},t[101]=D[0],t[102]=Re):Re=t[102];let be;t[103]!==i.duration?(be={opacity:0,transition:{duration:i.duration}},t[103]=i.duration,t[104]=be):be=t[104];let Ee;t[105]===Symbol.for("react.memo_cache_sentinel")?(Ee={opacity:0},t[105]=Ee):Ee=t[105];let Oe;t[106]!==i.duration?(Oe={initial:Ee,whileInView:{opacity:1,transition:{duration:i.duration}}},t[106]=i.duration,t[107]=Oe):Oe=t[107];let Ce;t[108]!==c[0]||t[109]!==T?(Ce={fill:"none",stroke:c[0],strokeWidth:T},t[108]=c[0],t[109]=T,t[110]=Ce):Ce=t[110];let Ae;t[111]!==i.duration?(Ae={opacity:0,transition:{duration:i.duration}},t[111]=i.duration,t[112]=Ae):Ae=t[112];let Ve;t[113]!==c[1]||t[114]!==T?(Ve={fill:"none",stroke:c[1],strokeWidth:T},t[113]=c[1],t[114]=T,t[115]=Ve):Ve=t[115];let Le;t[116]!==i.duration?(Le={opacity:0,transition:{duration:i.duration}},t[116]=i.duration,t[117]=Le):Le=t[117];const li=1,ti=Bt(n)||"";let ee;t[118]!==i.duration?(ee={duration:i.duration},t[118]=i.duration,t[119]=ee):ee=t[119];let Se;t[120]!==ti||t[121]!==ee?(Se={pathLength:li,d:ti,opacity:1,transition:ee},t[120]=ti,t[121]=ee,t[122]=Se):Se=t[122];let ke;t[123]!==i.duration||t[124]!==N||t[125]!==n||t[126]!==p||t[127]!==u||t[128]!==c[0]||t[129]!==c[1]||t[130]!==Gt||t[131]!==a||t[132]!==l?(ke=Gt?null:s.jsxRuntimeExports.jsxs("g",{children:[s.jsxRuntimeExports.jsx(S.motion.text,{className:"text-xs",dx:5,dy:4,exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,x:a(n[n.length-1].date),y:l(n[n.length-1].y1),fill:c[0]},whileInView:{opacity:1,x:a(n[n.length-1].date),y:l(n[n.length-1].y1),fill:c[0],transition:{duration:p?i.duration:.5,delay:p?0:i.duration}}},initial:"initial",animate:u?"whileInView":"initial",children:N[0]},N[0]),s.jsxRuntimeExports.jsx(S.motion.text,{className:"text-xs",dx:5,dy:4,exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,x:a(n[n.length-1].date),y:l(n[n.length-1].y2),fill:c[1]},whileInView:{opacity:1,x:a(n[n.length-1].date),y:l(n[n.length-1].y2),fill:c[1],transition:{duration:p?i.duration:.5,delay:p?0:i.duration}}},initial:"initial",animate:u?"whileInView":"initial",children:N[1]},N[1])]}),t[123]=i.duration,t[124]=N,t[125]=n,t[126]=p,t[127]=u,t[128]=c[0],t[129]=c[1],t[130]=Gt,t[131]=a,t[132]=l,t[133]=ke):ke=t[133];let De;t[134]!==d?.mouseOverLine||t[135]!==j||t[136]!==L||t[137]!==f?.mouseOverLine||t[138]!==a?(De=L?s.jsxRuntimeExports.jsx("line",{y1:0,y2:j,x1:a(L.date),x2:a(L.date),className:s.mo("undp-tick-line stroke-primary-gray-700 dark:stroke-primary-gray-100",d?.mouseOverLine),style:f?.mouseOverLine}):null,t[134]=d?.mouseOverLine,t[135]=j,t[136]=L,t[137]=f?.mouseOverLine,t[138]=a,t[139]=De):De=t[139];let Ie;if(t[140]!==i.duration||t[141]!==d?.graphObjectValues||t[142]!==n||t[143]!==m||t[144]!==p||t[145]!==u||t[146]!==c[0]||t[147]!==c[1]||t[148]!==b||t[149]!==v||t[150]!==q||t[151]!==w||t[152]!==f?.graphObjectValues||t[153]!==E||t[154]!==a||t[155]!==l){let o;t[157]!==i.duration||t[158]!==d?.graphObjectValues||t[159]!==n.length||t[160]!==m||t[161]!==p||t[162]!==u||t[163]!==c[0]||t[164]!==c[1]||t[165]!==b||t[166]!==v||t[167]!==q||t[168]!==w||t[169]!==f?.graphObjectValues||t[170]!==E||t[171]!==a||t[172]!==l?(o=(e,P)=>s.jsxRuntimeExports.jsxs(S.motion.g,{children:[It.checkIfNullOrUndefined(e.y1)?null:s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[q?s.jsxRuntimeExports.jsx(S.motion.circle,{r:m/n.length<5?0:m/n.length<20?2:4,exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,cx:a(e.date),cy:l(e.y1),fill:c[0]},whileInView:{opacity:1,fill:c[0],transition:{duration:.5,delay:i.duration},cx:a(e.date),cy:l(e.y1)}},initial:"initial",animate:u?"whileInView":"initial"}):null,w?s.jsxRuntimeExports.jsx(S.motion.text,{dy:e.y2<e.y1?-8:"1em",style:{textAnchor:"middle",...f?.graphObjectValues||{}},className:s.mo("graph-value graph-value-line-1 text-xs font-bold",d?.graphObjectValues),exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,x:a(e.date),y:l(e.y1),fill:c[0]},whileInView:{opacity:1,fill:c[0],x:a(e.date),y:l(e.y1),transition:{duration:p?i.duration:.5,delay:p?0:i.duration}}},initial:"initial",animate:u?"whileInView":"initial",children:ei.numberFormattingFunction(e.y1,"NA",b,v,E)}):null]}),It.checkIfNullOrUndefined(e.y2)?null:s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[q?s.jsxRuntimeExports.jsx(S.motion.circle,{r:m/n.length<5?0:m/n.length<20?2:4,exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,cx:a(e.date),cy:l(e.y2),fill:c[1]},whileInView:{opacity:1,fill:c[1],transition:{duration:p?i.duration:.5,delay:p?0:i.duration},cx:a(e.date),cy:l(e.y2)}},initial:"initial",animate:u?"whileInView":"initial"}):null,w?s.jsxRuntimeExports.jsx(S.motion.text,{dy:e.y2>e.y1?-8:"1em",style:{textAnchor:"middle",...f?.graphObjectValues||{}},className:s.mo("graph-value graph-value-line-2 text-xs font-bold",d?.graphObjectValues),exit:{opacity:0,transition:{duration:i.duration}},variants:{initial:{opacity:0,x:a(e.date),y:l(e.y2),fill:c[1]},whileInView:{opacity:1,x:a(e.date),y:l(e.y2),fill:c[1],transition:{duration:p?i.duration:.5,delay:p?0:i.duration}}},initial:"initial",animate:u?"whileInView":"initial",children:ei.numberFormattingFunction(e.y2,"NA",b,v,E)}):null]})]},P),t[157]=i.duration,t[158]=d?.graphObjectValues,t[159]=n.length,t[160]=m,t[161]=p,t[162]=u,t[163]=c[0],t[164]=c[1],t[165]=b,t[166]=v,t[167]=q,t[168]=w,t[169]=f?.graphObjectValues,t[170]=E,t[171]=a,t[172]=l,t[173]=o):o=t[173],Ie=n.map(o),t[140]=i.duration,t[141]=d?.graphObjectValues,t[142]=n,t[143]=m,t[144]=p,t[145]=u,t[146]=c[0],t[147]=c[1],t[148]=b,t[149]=v,t[150]=q,t[151]=w,t[152]=f?.graphObjectValues,t[153]=E,t[154]=a,t[155]=l,t[156]=Ie}else Ie=t[156];let Ne;t[174]!==i||t[175]!==m||t[176]!==u||t[177]!==V||t[178]!==y.right||t[179]!==jt||t[180]!==l?(Ne=jt?s.jsxRuntimeExports.jsx(s.jsxRuntimeExports.Fragment,{children:jt.map((o,e)=>s.jsxRuntimeExports.jsx(hi.RefLineY,{text:o.text,color:o.color,y:l(o.value),x1:0-V,x2:m+y.right,classNames:o.classNames,styles:o.styles,animate:i,isInView:u},e))}):null,t[174]=i,t[175]=m,t[176]=u,t[177]=V,t[178]=y.right,t[179]=jt,t[180]=l,t[181]=Ne):Ne=t[181];let ie;if(t[182]!==i||t[183]!==Pt||t[184]!==x||t[185]!==m||t[186]!==u||t[187]!==y.right||t[188]!==W||t[189]!==a||t[190]!==l){let o;t[192]!==i||t[193]!==x||t[194]!==m||t[195]!==u||t[196]!==y.right||t[197]!==W||t[198]!==a||t[199]!==l?(o=(e,P)=>{const Dt=ii.getLineEndPoint({x:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0),y:e.yCoordinate?l(e.yCoordinate)+(e.yOffset||0)-8:0+(e.yOffset||0)-8},{x:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date)):0,y:e.yCoordinate?l(e.yCoordinate):0},It.checkIfNullOrUndefined(e.connectorRadius)?3.5:e.connectorRadius),ci=e.showConnector?{y1:Dt.y,x1:Dt.x,y2:e.yCoordinate?l(e.yCoordinate)+(e.yOffset||0):0+(e.yOffset||0),x2:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0),cy:e.yCoordinate?l(e.yCoordinate):0,cx:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date)):0,circleRadius:It.checkIfNullOrUndefined(e.connectorRadius)?3.5:e.connectorRadius,strokeWidth:e.showConnector===!0?2:Math.min(e.showConnector||0,1)}:void 0,ui={y:e.yCoordinate?l(e.yCoordinate)+(e.yOffset||0)-8:0+(e.yOffset||0)-8,x:W?0:e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0),width:W?e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0):m+y.right-(e.xCoordinate?a(O.parse(`${e.xCoordinate}`,x,new Date))+(e.xOffset||0):0+(e.xOffset||0)),maxWidth:e.maxWidth,fontWeight:e.fontWeight,align:e.align};return s.jsxRuntimeExports.jsx(ii.Annotation,{color:e.color,connectorsSettings:ci,labelSettings:ui,text:e.text,classNames:e.classNames,styles:e.styles,animate:i,isInView:u},P)},t[192]=i,t[193]=x,t[194]=m,t[195]=u,t[196]=y.right,t[197]=W,t[198]=a,t[199]=l,t[200]=o):o=t[200],ie=Pt.map(o),t[182]=i,t[183]=Pt,t[184]=x,t[185]=m,t[186]=u,t[187]=y.right,t[188]=W,t[189]=a,t[190]=l,t[191]=ie}else ie=t[191];let Te;t[201]!==ie?(Te=s.jsxRuntimeExports.jsx("g",{children:ie}),t[201]=ie,t[202]=Te):Te=t[202];let qe;t[203]!==$?(qe=$.filter(Ii).map(Di),t[203]=$,t[204]=qe):qe=t[204];let $e;t[205]===Symbol.for("react.memo_cache_sentinel")?($e={fill:"none",pointerEvents:"all"},t[205]=$e):$e=t[205];let Me;t[206]!==lt||t[207]!==j||t[208]!==m?(Me=s.jsxRuntimeExports.jsx("rect",{ref:lt,style:$e,width:m,height:j}),t[206]=lt,t[207]=j,t[208]=m,t[209]=Me):Me=t[209];let Fe;return t[210]!==d?.tooltip||t[211]!==h||t[212]!==B||t[213]!==L||t[214]!==f?.tooltip||t[215]!==H?(Fe=L&&H&&h&&B?s.jsxRuntimeExports.jsx(mi.Tooltip,{data:L,body:H,xPos:h,yPos:B,backgroundStyle:f?.tooltip,className:d?.tooltip}):null,t[210]=d?.tooltip,t[211]=h,t[212]=B,t[213]=L,t[214]=f?.tooltip,t[215]=H,t[216]=Fe):Fe=t[216],s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[s.jsxRuntimeExports.jsx(S.motion.svg,{width:`${ot}px`,height:`${Nt}px`,viewBox:`0 0 ${ot} ${Nt}`,direction:"ltr",ref:bt,children:s.jsxRuntimeExports.jsxs("g",{transform:`translate(${y.left},${y.top})`,children:[s.jsxRuntimeExports.jsx("clipPath",{id:`above${st}`,children:s.jsxRuntimeExports.jsx("path",{d:le(n),style:dt})}),s.jsxRuntimeExports.jsx("clipPath",{id:`below${st}`,children:s.jsxRuntimeExports.jsx("path",{d:re(n),style:tt})}),pt,s.jsxRuntimeExports.jsx(ii.CustomArea,{areaSettings:se,scaleX:a,scaleY:l,animate:i,isInView:u}),s.jsxRuntimeExports.jsx("g",{children:s.jsxRuntimeExports.jsxs("g",{children:[s.jsxRuntimeExports.jsx(yi.YTicksAndGridLines,{values:zt.filter($i),y:zt.filter(qi).map(o=>l(o)),x1:0-V,x2:m+y.right,styles:it,classNames:Lt,suffix:E,prefix:v,labelType:"secondary",showGridLines:!0,labelPos:"vertical",precision:b}),me,de]})}),s.jsxRuntimeExports.jsx(fi.XTicksAndGridLines,{values:ai,x:ri,y1:0,y2:j,styles:fe,classNames:he,suffix:E,prefix:v,labelType:"primary",showGridLines:!0,precision:b}),ye,s.jsxRuntimeExports.jsxs("g",{children:[s.jsxRuntimeExports.jsx(S.motion.path,{clipPath:`url(#below${st})`,d:At(n)||"",style:ge,exit:je,variants:we,initial:"initial",animate:u?"whileInView":"initial"}),s.jsxRuntimeExports.jsx(S.motion.path,{clipPath:`url(#above${st})`,d:At(n)||"",style:Re,exit:be,variants:Oe,initial:"initial",animate:u?"whileInView":"initial"})]}),s.jsxRuntimeExports.jsxs("g",{children:[s.jsxRuntimeExports.jsx(S.motion.path,{d:mt(n)||"",style:Ce,exit:Ae,variants:{initial:{pathLength:0,d:mt(n)||"",opacity:1},whileInView:{pathLength:1,d:mt(n)||"",opacity:1,transition:{duration:i.duration}}},initial:"initial",animate:u?"whileInView":"initial"}),s.jsxRuntimeExports.jsx(S.motion.path,{style:Ve,exit:Le,variants:{initial:{pathLength:0,d:Bt(n)||"",opacity:1},whileInView:Se},initial:"initial",animate:u?"whileInView":"initial"}),ke,De,Ie]}),Ne,Te,qe,Me]})}),Fe]})}function Di(r){return r.layer}function Ii(r){return r.position==="after"}function Ni(r){return r.layer}function Ti(r){return r.position==="before"}function qi(r){return r!==0}function $i(r){return r!==0}function Mi(r){return r.date}function Fi(r){return r.y2}function Gi(r){return r.y2}function Pi(r){return r.y1}function Hi(r){return r.y1}function Wi(r){return r.y2}function Yi(r){return r.y2}function Xi(r){return r.y2}function Ui(r){return r.y1}function Bi(r){return r.y1}function zi(r){return r.y1}function Ji(r){const t=s.compilerRuntimeExports.c(90),{data:k,graphTitle:ot,suffix:Nt,sources:c,prefix:E,graphDescription:v,height:x,width:w,footNote:Tt,noOfXTicks:qt,dateFormat:V,showValues:$t,padding:gt,lineColors:H,backgroundColor:Mt,leftMargin:Ft,rightMargin:i,topMargin:W,bottomMargin:Gt,tooltip:N,highlightAreaSettings:D,relativeHeight:st,onSeriesMouseOver:T,graphID:q,graphDownload:jt,dataDownload:I,animate:vt,language:Pt,minHeight:Ht,labels:Y,showColorLegendAtTop:xe,colorLegendTitle:Wt,diffAreaColors:wt,strokeWidth:Rt,showDots:f,refValues:d,minValue:b,maxValue:$,annotations:bt,customHighlightAreaSettings:X,theme:u,ariaLabel:p,yAxisTitle:ne,noOfYTicks:Et,minDate:at,maxDate:U,curveType:L,styles:g,classNames:h,precision:oe,customLayers:B}=r,Yt=Nt===void 0?"":Nt,Ot=E===void 0?"":E,rt=qt===void 0?10:qt,y=V===void 0?"yyyy":V,lt=$t===void 0?!1:$t;let z;t[0]!==H?(z=H===void 0?[Pe.Colors.light.categoricalColors.colors[0],Pe.Colors.light.categoricalColors.colors[1]]:H,t[0]=H,t[1]=z):z=t[1];const n=z,ct=Mt===void 0?!1:Mt,Ct=Ft===void 0?30:Ft,ut=i===void 0?50:i,se=W===void 0?20:W,m=Gt===void 0?25:Gt;let j;t[2]!==D?(j=D===void 0?[]:D,t[2]=D,t[3]=j):j=t[3];const ae=j,Xt=jt===void 0?!1:jt,J=I===void 0?!1:I,K=vt===void 0?!1:vt,M=Pt===void 0?"en":Pt,Ut=Ht===void 0?0:Ht,Q=xe===void 0?!1:xe;let R;t[4]!==wt?(R=wt===void 0?[Pe.Colors.alerts.red,Pe.Colors.alerts.darkGreen]:wt,t[4]=wt,t[5]=R):R=t[5];const Z=R,a=Rt===void 0?2:Rt,xt=f===void 0?!0:f;let _;t[6]!==d?(_=d===void 0?[]:d,t[6]=d,t[7]=_):_=t[7];const l=_;let mt;t[8]!==bt?(mt=bt===void 0?[]:bt,t[8]=bt,t[9]=mt):mt=t[9];const Bt=mt;let At;t[10]!==X?(At=X===void 0?[]:X,t[10]=X,t[11]=At):At=t[11];const re=At,le=u===void 0?"light":u,zt=Et===void 0?5:Et,Jt=L===void 0?"curve":L,dt=oe===void 0?2:oe;let tt;t[12]!==B?(tt=B===void 0?[]:B,t[12]=B,t[13]=tt):tt=t[13];const pt=tt,[et,ce]=A.useState(0),[it,ue]=A.useState(0),Vt=A.useRef(null),Lt=A.useRef(null);let ft,ht;t[14]===Symbol.for("react.memo_cache_sentinel")?(ft=()=>{const Kt=new ResizeObserver(nt=>{ce(nt[0].target.clientWidth||620),ue(nt[0].target.clientHeight||480)});return Vt.current&&Kt.observe(Vt.current),()=>Kt.disconnect()},ht=[],t[14]=ft,t[15]=ht):(ft=t[14],ht=t[15]),A.useEffect(ft,ht);const St=h?.graphContainer,kt=g?.graphContainer;let F;t[16]!==h?.description||t[17]!==h?.title||t[18]!==k||t[19]!==J||t[20]!==v||t[21]!==Xt||t[22]!==ot||t[23]!==g?.description||t[24]!==g?.title||t[25]!==w?(F=ot||v||Xt||J?s.jsxRuntimeExports.jsx(Ci.GraphHeader,{styles:{title:g?.title,description:g?.description},classNames:{title:h?.title,description:h?.description},graphTitle:ot,graphDescription:v,width:w,graphDownload:Xt?Lt:void 0,dataDownload:J?k.map(tn).filter(_i).length>0?k.map(Zi).filter(Qi):k.filter(Ki):null}):null,t[16]=h?.description,t[17]=h?.title,t[18]=k,t[19]=J,t[20]=v,t[21]=Xt,t[22]=ot,t[23]=g?.description,t[24]=g?.title,t[25]=w,t[26]=F):F=t[26];let C;t[27]!==K||t[28]!==Bt||t[29]!==m||t[30]!==h||t[31]!==Wt||t[32]!==Jt||t[33]!==re||t[34]!==pt||t[35]!==k||t[36]!==y||t[37]!==Z||t[38]!==ae||t[39]!==Y||t[40]!==M||t[41]!==Ct||t[42]!==n||t[43]!==U||t[44]!==$||t[45]!==at||t[46]!==b||t[47]!==rt||t[48]!==zt||t[49]!==T||t[50]!==dt||t[51]!==Ot||t[52]!==l||t[53]!==ut||t[54]!==Q||t[55]!==xt||t[56]!==lt||t[57]!==a||t[58]!==g||t[59]!==Yt||t[60]!==it||t[61]!==et||t[62]!==N||t[63]!==se||t[64]!==ne?(C=k.length===0?s.jsxRuntimeExports.jsx(Li.EmptyState,{}):s.jsxRuntimeExports.jsxs(s.jsxRuntimeExports.Fragment,{children:[Q?s.jsxRuntimeExports.jsx(Ai.ColorLegend,{colorDomain:Y,colorLegendTitle:Wt,colors:n,showNAColor:!1,className:h?.colorLegend}):null,s.jsxRuntimeExports.jsx(si.GraphArea,{ref:Vt,children:et&&it?s.jsxRuntimeExports.jsx(ki,{data:k,lineColors:n,colorDomain:Y,width:et,height:it,suffix:Yt,prefix:Ot,dateFormat:y,showValues:lt,noOfXTicks:rt??Si.getNoOfTicks(et),leftMargin:Ct,rightMargin:ut,topMargin:se,bottomMargin:m,highlightAreaSettings:ae,tooltip:N,onSeriesMouseOver:T,showColorLegendAtTop:Q,animate:K===!0?{duration:.5,once:!0,amount:.5}:K||{duration:0,once:!0,amount:0},rtl:M==="he"||M==="ar",diffAreaColors:Z,idSuffix:Vi.generateRandomString(8),strokeWidth:a,showDots:xt,refValues:l,minValue:b,maxValue:$,annotations:Bt,customHighlightAreaSettings:re,yAxisTitle:ne,noOfYTicks:zt,minDate:at,maxDate:U,curveType:Jt,styles:g,classNames:h,precision:dt,customLayers:pt}):null})]}),t[27]=K,t[28]=Bt,t[29]=m,t[30]=h,t[31]=Wt,t[32]=Jt,t[33]=re,t[34]=pt,t[35]=k,t[36]=y,t[37]=Z,t[38]=ae,t[39]=Y,t[40]=M,t[41]=Ct,t[42]=n,t[43]=U,t[44]=$,t[45]=at,t[46]=b,t[47]=rt,t[48]=zt,t[49]=T,t[50]=dt,t[51]=Ot,t[52]=l,t[53]=ut,t[54]=Q,t[55]=xt,t[56]=lt,t[57]=a,t[58]=g,t[59]=Yt,t[60]=it,t[61]=et,t[62]=N,t[63]=se,t[64]=ne,t[65]=C):C=t[65];let G;t[66]!==h?.footnote||t[67]!==h?.source||t[68]!==Tt||t[69]!==c||t[70]!==g?.footnote||t[71]!==g?.source||t[72]!==w?(G=c||Tt?s.jsxRuntimeExports.jsx(Oi.GraphFooter,{styles:{footnote:g?.footnote,source:g?.source},classNames:{footnote:h?.footnote,source:h?.source},sources:c,footNote:Tt,width:w}):null,t[66]=h?.footnote,t[67]=h?.source,t[68]=Tt,t[69]=c,t[70]=g?.footnote,t[71]=g?.source,t[72]=w,t[73]=G):G=t[73];let yt;return t[74]!==p||t[75]!==ct||t[76]!==q||t[77]!==x||t[78]!==M||t[79]!==Ut||t[80]!==gt||t[81]!==st||t[82]!==St||t[83]!==kt||t[84]!==F||t[85]!==C||t[86]!==G||t[87]!==le||t[88]!==w?(yt=s.jsxRuntimeExports.jsxs(si.GraphContainer,{className:St,style:kt,id:q,ref:Lt,"aria-label":p,backgroundColor:ct,theme:le,language:M,minHeight:Ut,width:w,height:x,relativeHeight:st,padding:gt,children:[F,C,G]}),t[74]=p,t[75]=ct,t[76]=q,t[77]=x,t[78]=M,t[79]=Ut,t[80]=gt,t[81]=st,t[82]=St,t[83]=kt,t[84]=F,t[85]=C,t[86]=G,t[87]=le,t[88]=w,t[89]=yt):yt=t[89],yt}function Ki(r){return r!==void 0}function Qi(r){return r!==void 0}function Zi(r){return r.data}function _i(r){return r!==void 0}function tn(r){return r.data}exports.DifferenceLineChart=Ji;
2
2
  //# sourceMappingURL=DifferenceLineChart.cjs.map
@@ -58,6 +58,7 @@ declare interface ClassNameObject {
58
58
  regLine?: string;
59
59
  dataCards?: string;
60
60
  colorLegend?: string;
61
+ modal?: string;
61
62
  }
62
63
 
63
64
  declare type CurveTypes = 'linear' | 'curve' | 'step' | 'stepAfter' | 'stepBefore';
@@ -233,6 +234,7 @@ declare interface StyleObject {
233
234
  mouseOverLine?: React.CSSProperties;
234
235
  regLine?: React.CSSProperties;
235
236
  dataCards?: React.CSSProperties;
237
+ modal?: React.CSSProperties;
236
238
  }
237
239
 
238
240
  export { }
@@ -3,7 +3,7 @@ import { useRef as Ye, useState as ie, useEffect as ni } from "react";
3
3
  import { p as V, f as ui } from "./parse-DlCRUFh_.js";
4
4
  import { o as di } from "./index-BZQYSqar.js";
5
5
  import { n as ii } from "./numberFormattingFunction-14YCbkN2.js";
6
- import { T as hi } from "./Tooltip-CwWUegPB.js";
6
+ import { T as hi } from "./Tooltip-Dj5eVppQ.js";
7
7
  import { c as Tt } from "./checkIfNullOrUndefined-DmfiKkNw.js";
8
8
  import { C as pi, g as xi, A as yi } from "./customArea-BUhPiPT6.js";
9
9
  import { A as gi } from "./AxisTitle-jeI7am8o.js";
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const m=require("./index-CHPV5EwG-CTPQjnHt.cjs"),K=require("react"),ne=require("./Typography-DX7PlgQU.cjs"),xe=require("./index-Cno4Q0YE.cjs"),fe=require("./Source-DYMJRrsq.cjs"),ge=require("./index-DQA8q5sC.cjs"),me=require("./Modal-JW_IExO3.cjs"),he=require("./Tooltip-4dJo4_AF.cjs"),_=require("./Colors.cjs"),de=require("./numberFormattingFunction-02t-wJta.cjs"),ye=require("./string2HTML-CPGr_I5E.cjs"),O=require("./array-DKbXV8lR.cjs"),ve=require("./GraphFooter.cjs"),je=require("./GraphHeader.cjs"),Re=require("./EmptyState-sAEZ_5rU.cjs"),ue=require("./GraphContainer-d8A46BK2.cjs"),ce=Math.abs,F=Math.atan2,U=Math.cos,be=Math.max,ie=Math.min,V=Math.sin,Z=Math.sqrt,I=1e-12,ee=Math.PI,se=ee/2,re=2*ee;function Ee(s){return s>1?0:s<-1?ee:Math.acos(s)}function pe(s){return s>=1?se:s<=-1?-se:Math.asin(s)}function Ae(s){return s.innerRadius}function Me(s){return s.outerRadius}function Ce(s){return s.startAngle}function Ne(s){return s.endAngle}function De(s){return s&&s.padAngle}function Se(s,e,c,R,l,b,d,t){var x=c-s,a=R-e,n=d-l,E=t-b,r=E*x-n*a;if(!(r*r<I))return r=(n*(e-b)-E*(s-l))/r,[s+r*x,e+r*a]}function te(s,e,c,R,l,b,d){var t=s-c,x=e-R,a=(d?b:-b)/Z(t*t+x*x),n=a*x,E=-a*t,r=s+n,i=e+E,h=c+n,v=R+E,T=(r+h)/2,f=(i+v)/2,y=h-r,M=v-i,p=y*y+M*M,j=l-b,A=r*v-h*i,G=(M<0?-1:1)*Z(be(0,j*j*p-A*A)),P=(A*M-y*G)/p,z=(-A*y-M*G)/p,N=(A*M+y*G)/p,D=(-A*y+M*G)/p,S=P-T,o=z-f,u=N-T,B=D-f;return S*S+o*o>u*u+B*B&&(P=N,z=D),{cx:P,cy:z,x01:-n,y01:-E,x11:P*(l/j-1),y11:z*(l/j-1)}}function qe(){var s=Ae,e=Me,c=O.constant(0),R=null,l=Ce,b=Ne,d=De,t=null,x=O.withPath(a);function a(){var n,E,r=+s.apply(this,arguments),i=+e.apply(this,arguments),h=l.apply(this,arguments)-se,v=b.apply(this,arguments)-se,T=ce(v-h),f=v>h;if(t||(t=n=x()),i<r&&(E=i,i=r,r=E),!(i>I))t.moveTo(0,0);else if(T>re-I)t.moveTo(i*U(h),i*V(h)),t.arc(0,0,i,h,v,!f),r>I&&(t.moveTo(r*U(v),r*V(v)),t.arc(0,0,r,v,h,f));else{var y=h,M=v,p=h,j=v,A=T,G=T,P=d.apply(this,arguments)/2,z=P>I&&(R?+R.apply(this,arguments):Z(r*r+i*i)),N=ie(ce(i-r)/2,+c.apply(this,arguments)),D=N,S=N,o,u;if(z>I){var B=pe(z/r*V(P)),L=pe(z/i*V(P));(A-=B*2)>I?(B*=f?1:-1,p+=B,j-=B):(A=0,p=j=(h+v)/2),(G-=L*2)>I?(L*=f?1:-1,y+=L,M-=L):(G=0,y=M=(h+v)/2)}var W=i*U(y),k=i*V(y),q=r*U(j),H=r*V(j);if(N>I){var $=i*U(M),X=i*V(M),Y=r*U(p),C=r*V(p),w;if(T<ee)if(w=Se(W,k,Y,C,$,X,q,H)){var g=W-w[0],J=k-w[1],Q=$-w[0],oe=X-w[1],ae=1/V(Ee((g*Q+J*oe)/(Z(g*g+J*J)*Z(Q*Q+oe*oe)))/2),le=Z(w[0]*w[0]+w[1]*w[1]);D=ie(N,(r-le)/(ae-1)),S=ie(N,(i-le)/(ae+1))}else D=S=0}G>I?S>I?(o=te(Y,C,W,k,i,S,f),u=te($,X,q,H,i,S,f),t.moveTo(o.cx+o.x01,o.cy+o.y01),S<N?t.arc(o.cx,o.cy,S,F(o.y01,o.x01),F(u.y01,u.x01),!f):(t.arc(o.cx,o.cy,S,F(o.y01,o.x01),F(o.y11,o.x11),!f),t.arc(0,0,i,F(o.cy+o.y11,o.cx+o.x11),F(u.cy+u.y11,u.cx+u.x11),!f),t.arc(u.cx,u.cy,S,F(u.y11,u.x11),F(u.y01,u.x01),!f))):(t.moveTo(W,k),t.arc(0,0,i,y,M,!f)):t.moveTo(W,k),!(r>I)||!(A>I)?t.lineTo(q,H):D>I?(o=te(q,H,$,X,r,-D,f),u=te(W,k,Y,C,r,-D,f),t.lineTo(o.cx+o.x01,o.cy+o.y01),D<N?t.arc(o.cx,o.cy,D,F(o.y01,o.x01),F(u.y01,u.x01),!f):(t.arc(o.cx,o.cy,D,F(o.y01,o.x01),F(o.y11,o.x11),!f),t.arc(0,0,r,F(o.cy+o.y11,o.cx+o.x11),F(u.cy+u.y11,u.cx+u.x11),f),t.arc(u.cx,u.cy,D,F(u.y11,u.x11),F(u.y01,u.x01),!f))):t.arc(0,0,r,j,p,f)}if(t.closePath(),n)return t=null,n+""||null}return a.centroid=function(){var n=(+s.apply(this,arguments)+ +e.apply(this,arguments))/2,E=(+l.apply(this,arguments)+ +b.apply(this,arguments))/2-ee/2;return[U(E)*n,V(E)*n]},a.innerRadius=function(n){return arguments.length?(s=typeof n=="function"?n:O.constant(+n),a):s},a.outerRadius=function(n){return arguments.length?(e=typeof n=="function"?n:O.constant(+n),a):e},a.cornerRadius=function(n){return arguments.length?(c=typeof n=="function"?n:O.constant(+n),a):c},a.padRadius=function(n){return arguments.length?(R=n==null?null:typeof n=="function"?n:O.constant(+n),a):R},a.startAngle=function(n){return arguments.length?(l=typeof n=="function"?n:O.constant(+n),a):l},a.endAngle=function(n){return arguments.length?(b=typeof n=="function"?n:O.constant(+n),a):b},a.padAngle=function(n){return arguments.length?(d=typeof n=="function"?n:O.constant(+n),a):d},a.context=function(n){return arguments.length?(t=n??null,a):t},a}function Te(s,e){return e<s?-1:e>s?1:e>=s?0:NaN}function ke(s){return s}function we(){var s=ke,e=Te,c=null,R=O.constant(0),l=O.constant(re),b=O.constant(0);function d(t){var x,a=(t=O.array(t)).length,n,E,r=0,i=new Array(a),h=new Array(a),v=+R.apply(this,arguments),T=Math.min(re,Math.max(-re,l.apply(this,arguments)-v)),f,y=Math.min(Math.abs(T)/a,b.apply(this,arguments)),M=y*(T<0?-1:1),p;for(x=0;x<a;++x)(p=h[i[x]=x]=+s(t[x],x,t))>0&&(r+=p);for(e!=null?i.sort(function(j,A){return e(h[j],h[A])}):c!=null&&i.sort(function(j,A){return c(t[j],t[A])}),x=0,E=r?(T-a*M)/r:0;x<a;++x,v=f)n=i[x],p=h[n],f=v+(p>0?p*E:0)+M,h[n]={data:t[n],index:x,value:p,startAngle:v,endAngle:f,padAngle:y};return h}return d.value=function(t){return arguments.length?(s=typeof t=="function"?t:O.constant(+t),d):s},d.sortValues=function(t){return arguments.length?(e=t,c=null,d):e},d.sort=function(t){return arguments.length?(c=t,e=null,d):c},d.startAngle=function(t){return arguments.length?(R=typeof t=="function"?t:O.constant(+t),d):R},d.endAngle=function(t){return arguments.length?(l=typeof t=="function"?t:O.constant(+t),d):l},d.padAngle=function(t){return arguments.length?(b=typeof t=="function"?t:O.constant(+t),d):b},d}function Oe(s){const e=m.compilerRuntimeExports.c(43),{mainText:c,data:R,radius:l,colors:b,subNote:d,strokeWidth:t,tooltip:x,onSeriesMouseOver:a,onSeriesMouseClick:n,colorDomain:E,resetSelectionOnDoubleClick:r,detailsOnClick:i,styles:h,classNames:v,precision:T}=s,f=we().sort(null).startAngle(0).value(ze),[y,M]=K.useState(void 0),[p,j]=K.useState(void 0),[A,G]=K.useState(void 0),[P,z]=K.useState(void 0),N=`${l*2}px`,D=`${l*2}px`,S=`0 0 ${l*2} ${l*2}`,o="ltr",u="mx-auto",B=`translate(${l} ${l})`;let L;e[0]!==R||e[1]!==c||e[2]!==T||e[3]!==l||e[4]!==t||e[5]!==d?(L=c||d?m.jsxRuntimeExports.jsx("foreignObject",{y:0-(l-t),x:0-(l-t),width:2*(l-t),height:2*(l-t),children:m.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center items-center h-inherit py-0 px-4",children:[c?m.jsxRuntimeExports.jsx(ne.v,{marginBottom:"none",className:"donut-main-text text-primary-gray-700 dark:text-primary-gray-100 leading-none text-center",children:typeof c=="string"?c:R.findIndex(C=>C.label===c.label)!==-1?de.numberFormattingFunction(R[R.findIndex(C=>C.label===c.label)].size,"NA",T,c.prefix,c.suffix):"NA"}):null,d?m.jsxRuntimeExports.jsx(ne.j,{marginBottom:"none",size:"base",leading:"none",className:"donut-sub-note text-primary-gray-700 dark:text-primary-gray-100 text-center font-bold",children:d}):typeof c=="string"||!c?null:m.jsxRuntimeExports.jsx(ne.j,{size:"base",marginBottom:"none",leading:"none",className:"donut-label text-primary-gray-700 dark:text-primary-gray-100 text-center font-bold",children:c.label})]})}):null,e[0]=R,e[1]=c,e[2]=T,e[3]=l,e[4]=t,e[5]=d,e[6]=L):L=e[6];let W;e[7]!==E||e[8]!==b||e[9]!==i||e[10]!==p||e[11]!==y||e[12]!==n||e[13]!==a||e[14]!==l||e[15]!==r||e[16]!==j||e[17]!==t?(W=(C,w)=>m.jsxRuntimeExports.jsx("path",{d:qe()({innerRadius:l-t,outerRadius:l,startAngle:C.startAngle,endAngle:C.endAngle}),style:{fill:E.indexOf(C.data.label)!==-1?b[E.indexOf(C.data.label)%b.length]:_.Colors.gray,opacity:y?y.label===C.data.label?1:.3:1},onMouseEnter:g=>{M(C.data),z(g.clientY),G(g.clientX),a?.(C)},onClick:()=>{(n||i)&&(ge.isEqual(p,C.data)&&r?(j(void 0),n?.(void 0)):(j(C.data),n&&n(C.data)))},onMouseMove:g=>{M(C.data),z(g.clientY),G(g.clientX)},onMouseLeave:()=>{M(void 0),G(void 0),z(void 0),a?.(void 0)}},w),e[7]=E,e[8]=b,e[9]=i,e[10]=p,e[11]=y,e[12]=n,e[13]=a,e[14]=l,e[15]=r,e[16]=j,e[17]=t,e[18]=W):W=e[18];const k=f(R).map(W);let q;e[19]!==B||e[20]!==L||e[21]!==k?(q=m.jsxRuntimeExports.jsxs("g",{transform:B,children:[L,k]}),e[19]=B,e[20]=L,e[21]=k,e[22]=q):q=e[22];let H;e[23]!==N||e[24]!==D||e[25]!==S||e[26]!==q?(H=m.jsxRuntimeExports.jsx("svg",{width:N,height:D,viewBox:S,direction:o,className:u,children:q}),e[23]=N,e[24]=D,e[25]=S,e[26]=q,e[27]=H):H=e[27];let $;e[28]!==v?.tooltip||e[29]!==A||e[30]!==P||e[31]!==y||e[32]!==h?.tooltip||e[33]!==x?($=y&&x&&A&&P?m.jsxRuntimeExports.jsx(he.Tooltip,{data:y,body:x,xPos:A,yPos:P,backgroundStyle:h?.tooltip,className:v?.tooltip}):null,e[28]=v?.tooltip,e[29]=A,e[30]=P,e[31]=y,e[32]=h?.tooltip,e[33]=x,e[34]=$):$=e[34];let X;e[35]!==i||e[36]!==p||e[37]!==j?(X=i&&p!==void 0?m.jsxRuntimeExports.jsx(me.le,{open:p!==void 0,onClose:()=>{j(void 0)},children:m.jsxRuntimeExports.jsx("div",{className:"graph-modal-content m-0",dangerouslySetInnerHTML:typeof i=="string"?{__html:ye.string2HTML(i,p)}:void 0,children:typeof i=="function"?i(p):null})}):null,e[35]=i,e[36]=p,e[37]=j,e[38]=X):X=e[38];let Y;return e[39]!==H||e[40]!==$||e[41]!==X?(Y=m.jsxRuntimeExports.jsxs(m.jsxRuntimeExports.Fragment,{children:[H,$,X]}),e[39]=H,e[40]=$,e[41]=X,e[42]=Y):Y=e[42],Y}function ze(s){return s.size}function Fe(s){const{mainText:e,graphTitle:c,colors:R=_.Colors.light.categoricalColors.colors,suffix:l="",sources:b,prefix:d="",strokeWidth:t=50,graphDescription:x,subNote:a,footNote:n,radius:E,data:r,showColorScale:i=!0,padding:h,backgroundColor:v=!1,tooltip:T,onSeriesMouseOver:f,graphID:y,onSeriesMouseClick:M,graphDownload:p=!1,dataDownload:j=!1,colorDomain:A,sortData:G,language:P="en",theme:z="light",width:N,height:D,minHeight:S=0,relativeHeight:o,ariaLabel:u,resetSelectionOnDoubleClick:B=!0,colorScaleMaxWidth:L,detailsOnClick:W,styles:k,classNames:q,precision:H=2}=s,[$,X]=K.useState(0),Y=K.useRef(null),C=K.useRef(null);K.useEffect(()=>{const g=new ResizeObserver(J=>{X((Math.min(J[0].target.clientWidth||620,J[0].target.clientHeight||480,E||1/0)||420)/2)});return Y.current&&g.observe(Y.current),()=>g.disconnect()},[E]);const w=G?xe.orderBy(r,["size"],[G]):r;return m.jsxRuntimeExports.jsxs(ue.GraphContainer,{className:q?.graphContainer,style:k?.graphContainer,id:y,ref:C,"aria-label":u,backgroundColor:v,theme:z,language:P,minHeight:S,width:N,height:D,relativeHeight:o,padding:h,children:[c||x||p||j?m.jsxRuntimeExports.jsx(je.GraphHeader,{styles:{title:k?.title,description:k?.description},classNames:{title:q?.title,description:q?.description},graphTitle:c,graphDescription:x,width:N,graphDownload:p?C:void 0,dataDownload:j?r.map(g=>g.data).filter(g=>g!==void 0).length>0?r.map(g=>g.data).filter(g=>g!==void 0):r.filter(g=>g!==void 0):null}):null,r.length===0?m.jsxRuntimeExports.jsx(Re.EmptyState,{}):m.jsxRuntimeExports.jsxs(m.jsxRuntimeExports.Fragment,{children:[i?m.jsxRuntimeExports.jsx("div",{className:m.mo("leading-0 flex mb-0 ml-auto mr-auto justify-center gap-x-3 gap-y-0 flex-wrap",q?.colorLegend),style:{maxWidth:L},"aria-label":"Color legend",children:w.map((g,J)=>m.jsxRuntimeExports.jsxs("div",{className:"flex gap-2 items-center pb-3",children:[m.jsxRuntimeExports.jsx("div",{className:"w-3 h-3 rounded-full",style:{backgroundColor:(A||w.map(Q=>Q.label)).indexOf(g.label)!==-1?(R||_.Colors[z].categoricalColors.colors)[(A||w.map(Q=>Q.label)).indexOf(g.label)%(R||_.Colors[z].categoricalColors.colors).length]:_.Colors.gray}}),m.jsxRuntimeExports.jsxs(ne.j,{marginBottom:"none",size:"sm",className:"text-primary-gray-700 dark:text-primary-gray-100",children:[g.label,":"," ",m.jsxRuntimeExports.jsx("span",{className:"font-bold",style:{fontSize:"inherit"},children:de.numberFormattingFunction(g.size,"NA",H,d,l)})]})]},J))}):null,m.jsxRuntimeExports.jsx(fe.n,{size:"lg"}),m.jsxRuntimeExports.jsx(ue.GraphArea,{ref:Y,children:$?m.jsxRuntimeExports.jsx(Oe,{mainText:e,data:w,colors:R,radius:$,subNote:a,strokeWidth:t,tooltip:T,colorDomain:A||w.map(g=>g.label),onSeriesMouseOver:f,onSeriesMouseClick:M,resetSelectionOnDoubleClick:B,styles:k,detailsOnClick:W,precision:H}):null})]}),b||n?m.jsxRuntimeExports.jsx(ve.GraphFooter,{styles:{footnote:k?.footnote,source:k?.source},classNames:{footnote:q?.footnote,source:q?.source},sources:b,footNote:n,width:N}):null]})}exports.DonutChart=Fe;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const h=require("./index-CHPV5EwG-CTPQjnHt.cjs"),K=require("react"),ne=require("./Typography-DX7PlgQU.cjs"),me=require("./index-Cno4Q0YE.cjs"),xe=require("./Source-DYMJRrsq.cjs"),fe=require("./index-DQA8q5sC.cjs"),ge=require("./Tooltip-uUdw6wJL.cjs"),_=require("./Colors.cjs"),pe=require("./numberFormattingFunction-02t-wJta.cjs"),he=require("./DetailsModal-BN0HDFlV.cjs"),T=require("./array-DKbXV8lR.cjs"),ye=require("./GraphFooter.cjs"),ve=require("./GraphHeader.cjs"),je=require("./EmptyState-sAEZ_5rU.cjs"),ue=require("./GraphContainer-d8A46BK2.cjs"),ce=Math.abs,F=Math.atan2,U=Math.cos,Re=Math.max,ae=Math.min,V=Math.sin,Z=Math.sqrt,H=1e-12,ee=Math.PI,re=ee/2,se=2*ee;function be(r){return r>1?0:r<-1?ee:Math.acos(r)}function de(r){return r>=1?re:r<=-1?-re:Math.asin(r)}function Ee(r){return r.innerRadius}function Ae(r){return r.outerRadius}function Ce(r){return r.startAngle}function Me(r){return r.endAngle}function De(r){return r&&r.padAngle}function Ne(r,e,c,R,l,b,d,t){var p=c-r,a=R-e,n=d-l,E=t-b,s=E*p-n*a;if(!(s*s<H))return s=(n*(e-b)-E*(r-l))/s,[r+s*p,e+s*a]}function te(r,e,c,R,l,b,d){var t=r-c,p=e-R,a=(d?b:-b)/Z(t*t+p*p),n=a*p,E=-a*t,s=r+n,i=e+E,y=c+n,g=R+E,q=(s+y)/2,m=(i+g)/2,v=y-s,C=g-i,x=v*v+C*C,j=l-b,A=s*g-y*i,G=(C<0?-1:1)*Z(Re(0,j*j*x-A*A)),P=(A*C-v*G)/x,z=(-A*v-C*G)/x,D=(A*C+v*G)/x,N=(-A*v+C*G)/x,S=P-q,o=z-m,u=D-q,I=N-m;return S*S+o*o>u*u+I*I&&(P=D,z=N),{cx:P,cy:z,x01:-n,y01:-E,x11:P*(l/j-1),y11:z*(l/j-1)}}function Se(){var r=Ee,e=Ae,c=T.constant(0),R=null,l=Ce,b=Me,d=De,t=null,p=T.withPath(a);function a(){var n,E,s=+r.apply(this,arguments),i=+e.apply(this,arguments),y=l.apply(this,arguments)-re,g=b.apply(this,arguments)-re,q=ce(g-y),m=g>y;if(t||(t=n=p()),i<s&&(E=i,i=s,s=E),!(i>H))t.moveTo(0,0);else if(q>se-H)t.moveTo(i*U(y),i*V(y)),t.arc(0,0,i,y,g,!m),s>H&&(t.moveTo(s*U(g),s*V(g)),t.arc(0,0,s,g,y,m));else{var v=y,C=g,x=y,j=g,A=q,G=q,P=d.apply(this,arguments)/2,z=P>H&&(R?+R.apply(this,arguments):Z(s*s+i*i)),D=ae(ce(i-s)/2,+c.apply(this,arguments)),N=D,S=D,o,u;if(z>H){var I=de(z/s*V(P)),W=de(z/i*V(P));(A-=I*2)>H?(I*=m?1:-1,x+=I,j-=I):(A=0,x=j=(y+g)/2),(G-=W*2)>H?(W*=m?1:-1,v+=W,C-=W):(G=0,v=C=(y+g)/2)}var X=i*U(v),w=i*V(v),k=s*U(j),$=s*V(j);if(D>H){var B=i*U(C),Y=i*V(C),L=s*U(x),M=s*V(x),O;if(q<ee)if(O=Ne(X,w,L,M,B,Y,k,$)){var f=X-O[0],J=w-O[1],Q=B-O[0],oe=Y-O[1],ie=1/V(be((f*Q+J*oe)/(Z(f*f+J*J)*Z(Q*Q+oe*oe)))/2),le=Z(O[0]*O[0]+O[1]*O[1]);N=ae(D,(s-le)/(ie-1)),S=ae(D,(i-le)/(ie+1))}else N=S=0}G>H?S>H?(o=te(L,M,X,w,i,S,m),u=te(B,Y,k,$,i,S,m),t.moveTo(o.cx+o.x01,o.cy+o.y01),S<D?t.arc(o.cx,o.cy,S,F(o.y01,o.x01),F(u.y01,u.x01),!m):(t.arc(o.cx,o.cy,S,F(o.y01,o.x01),F(o.y11,o.x11),!m),t.arc(0,0,i,F(o.cy+o.y11,o.cx+o.x11),F(u.cy+u.y11,u.cx+u.x11),!m),t.arc(u.cx,u.cy,S,F(u.y11,u.x11),F(u.y01,u.x01),!m))):(t.moveTo(X,w),t.arc(0,0,i,v,C,!m)):t.moveTo(X,w),!(s>H)||!(A>H)?t.lineTo(k,$):N>H?(o=te(k,$,B,Y,s,-N,m),u=te(X,w,L,M,s,-N,m),t.lineTo(o.cx+o.x01,o.cy+o.y01),N<D?t.arc(o.cx,o.cy,N,F(o.y01,o.x01),F(u.y01,u.x01),!m):(t.arc(o.cx,o.cy,N,F(o.y01,o.x01),F(o.y11,o.x11),!m),t.arc(0,0,s,F(o.cy+o.y11,o.cx+o.x11),F(u.cy+u.y11,u.cx+u.x11),m),t.arc(u.cx,u.cy,N,F(u.y11,u.x11),F(u.y01,u.x01),!m))):t.arc(0,0,s,j,x,m)}if(t.closePath(),n)return t=null,n+""||null}return a.centroid=function(){var n=(+r.apply(this,arguments)+ +e.apply(this,arguments))/2,E=(+l.apply(this,arguments)+ +b.apply(this,arguments))/2-ee/2;return[U(E)*n,V(E)*n]},a.innerRadius=function(n){return arguments.length?(r=typeof n=="function"?n:T.constant(+n),a):r},a.outerRadius=function(n){return arguments.length?(e=typeof n=="function"?n:T.constant(+n),a):e},a.cornerRadius=function(n){return arguments.length?(c=typeof n=="function"?n:T.constant(+n),a):c},a.padRadius=function(n){return arguments.length?(R=n==null?null:typeof n=="function"?n:T.constant(+n),a):R},a.startAngle=function(n){return arguments.length?(l=typeof n=="function"?n:T.constant(+n),a):l},a.endAngle=function(n){return arguments.length?(b=typeof n=="function"?n:T.constant(+n),a):b},a.padAngle=function(n){return arguments.length?(d=typeof n=="function"?n:T.constant(+n),a):d},a.context=function(n){return arguments.length?(t=n??null,a):t},a}function ke(r,e){return e<r?-1:e>r?1:e>=r?0:NaN}function qe(r){return r}function we(){var r=qe,e=ke,c=null,R=T.constant(0),l=T.constant(se),b=T.constant(0);function d(t){var p,a=(t=T.array(t)).length,n,E,s=0,i=new Array(a),y=new Array(a),g=+R.apply(this,arguments),q=Math.min(se,Math.max(-se,l.apply(this,arguments)-g)),m,v=Math.min(Math.abs(q)/a,b.apply(this,arguments)),C=v*(q<0?-1:1),x;for(p=0;p<a;++p)(x=y[i[p]=p]=+r(t[p],p,t))>0&&(s+=x);for(e!=null?i.sort(function(j,A){return e(y[j],y[A])}):c!=null&&i.sort(function(j,A){return c(t[j],t[A])}),p=0,E=s?(q-a*C)/s:0;p<a;++p,g=m)n=i[p],x=y[n],m=g+(x>0?x*E:0)+C,y[n]={data:t[n],index:p,value:x,startAngle:g,endAngle:m,padAngle:v};return y}return d.value=function(t){return arguments.length?(r=typeof t=="function"?t:T.constant(+t),d):r},d.sortValues=function(t){return arguments.length?(e=t,c=null,d):e},d.sort=function(t){return arguments.length?(c=t,e=null,d):c},d.startAngle=function(t){return arguments.length?(R=typeof t=="function"?t:T.constant(+t),d):R},d.endAngle=function(t){return arguments.length?(l=typeof t=="function"?t:T.constant(+t),d):l},d.padAngle=function(t){return arguments.length?(b=typeof t=="function"?t:T.constant(+t),d):b},d}function Oe(r){const e=h.compilerRuntimeExports.c(44),{mainText:c,data:R,radius:l,colors:b,subNote:d,strokeWidth:t,tooltip:p,onSeriesMouseOver:a,onSeriesMouseClick:n,colorDomain:E,resetSelectionOnDoubleClick:s,detailsOnClick:i,styles:y,classNames:g,precision:q}=r,m=we().sort(null).startAngle(0).value(Te),[v,C]=K.useState(void 0),[x,j]=K.useState(void 0),[A,G]=K.useState(void 0),[P,z]=K.useState(void 0),D=`${l*2}px`,N=`${l*2}px`,S=`0 0 ${l*2} ${l*2}`,o="ltr",u="mx-auto",I=`translate(${l} ${l})`;let W;e[0]!==R||e[1]!==c||e[2]!==q||e[3]!==l||e[4]!==t||e[5]!==d?(W=c||d?h.jsxRuntimeExports.jsx("foreignObject",{y:0-(l-t),x:0-(l-t),width:2*(l-t),height:2*(l-t),children:h.jsxRuntimeExports.jsxs("div",{className:"flex flex-col gap-0.5 justify-center items-center h-inherit py-0 px-4",children:[c?h.jsxRuntimeExports.jsx(ne.v,{marginBottom:"none",className:"donut-main-text text-primary-gray-700 dark:text-primary-gray-100 leading-none text-center",children:typeof c=="string"?c:R.findIndex(M=>M.label===c.label)!==-1?pe.numberFormattingFunction(R[R.findIndex(M=>M.label===c.label)].size,"NA",q,c.prefix,c.suffix):"NA"}):null,d?h.jsxRuntimeExports.jsx(ne.j,{marginBottom:"none",size:"base",leading:"none",className:"donut-sub-note text-primary-gray-700 dark:text-primary-gray-100 text-center font-bold",children:d}):typeof c=="string"||!c?null:h.jsxRuntimeExports.jsx(ne.j,{size:"base",marginBottom:"none",leading:"none",className:"donut-label text-primary-gray-700 dark:text-primary-gray-100 text-center font-bold",children:c.label})]})}):null,e[0]=R,e[1]=c,e[2]=q,e[3]=l,e[4]=t,e[5]=d,e[6]=W):W=e[6];let X;e[7]!==E||e[8]!==b||e[9]!==i||e[10]!==x||e[11]!==v||e[12]!==n||e[13]!==a||e[14]!==l||e[15]!==s||e[16]!==j||e[17]!==t?(X=(M,O)=>h.jsxRuntimeExports.jsx("path",{d:Se()({innerRadius:l-t,outerRadius:l,startAngle:M.startAngle,endAngle:M.endAngle}),style:{fill:E.indexOf(M.data.label)!==-1?b[E.indexOf(M.data.label)%b.length]:_.Colors.gray,opacity:v?v.label===M.data.label?1:.3:1},onMouseEnter:f=>{C(M.data),z(f.clientY),G(f.clientX),a?.(M)},onClick:()=>{(n||i)&&(fe.isEqual(x,M.data)&&s?(j(void 0),n?.(void 0)):(j(M.data),n&&n(M.data)))},onMouseMove:f=>{C(M.data),z(f.clientY),G(f.clientX)},onMouseLeave:()=>{C(void 0),G(void 0),z(void 0),a?.(void 0)}},O),e[7]=E,e[8]=b,e[9]=i,e[10]=x,e[11]=v,e[12]=n,e[13]=a,e[14]=l,e[15]=s,e[16]=j,e[17]=t,e[18]=X):X=e[18];const w=m(R).map(X);let k;e[19]!==I||e[20]!==W||e[21]!==w?(k=h.jsxRuntimeExports.jsxs("g",{transform:I,children:[W,w]}),e[19]=I,e[20]=W,e[21]=w,e[22]=k):k=e[22];let $;e[23]!==D||e[24]!==N||e[25]!==S||e[26]!==k?($=h.jsxRuntimeExports.jsx("svg",{width:D,height:N,viewBox:S,direction:o,className:u,children:k}),e[23]=D,e[24]=N,e[25]=S,e[26]=k,e[27]=$):$=e[27];let B;e[28]!==g?.tooltip||e[29]!==A||e[30]!==P||e[31]!==v||e[32]!==y?.tooltip||e[33]!==p?(B=v&&p&&A&&P?h.jsxRuntimeExports.jsx(ge.Tooltip,{data:v,body:p,xPos:A,yPos:P,backgroundStyle:y?.tooltip,className:g?.tooltip}):null,e[28]=g?.tooltip,e[29]=A,e[30]=P,e[31]=v,e[32]=y?.tooltip,e[33]=p,e[34]=B):B=e[34];let Y;e[35]!==g?.modal||e[36]!==i||e[37]!==x||e[38]!==j?(Y=i&&x!==void 0?h.jsxRuntimeExports.jsx(he.DetailsModal,{body:i,data:x,setData:j,className:g?.modal}):null,e[35]=g?.modal,e[36]=i,e[37]=x,e[38]=j,e[39]=Y):Y=e[39];let L;return e[40]!==$||e[41]!==B||e[42]!==Y?(L=h.jsxRuntimeExports.jsxs(h.jsxRuntimeExports.Fragment,{children:[$,B,Y]}),e[40]=$,e[41]=B,e[42]=Y,e[43]=L):L=e[43],L}function Te(r){return r.size}function ze(r){const{mainText:e,graphTitle:c,colors:R=_.Colors.light.categoricalColors.colors,suffix:l="",sources:b,prefix:d="",strokeWidth:t=50,graphDescription:p,subNote:a,footNote:n,radius:E,data:s,showColorScale:i=!0,padding:y,backgroundColor:g=!1,tooltip:q,onSeriesMouseOver:m,graphID:v,onSeriesMouseClick:C,graphDownload:x=!1,dataDownload:j=!1,colorDomain:A,sortData:G,language:P="en",theme:z="light",width:D,height:N,minHeight:S=0,relativeHeight:o,ariaLabel:u,resetSelectionOnDoubleClick:I=!0,colorScaleMaxWidth:W,detailsOnClick:X,styles:w,classNames:k,precision:$=2}=r,[B,Y]=K.useState(0),L=K.useRef(null),M=K.useRef(null);K.useEffect(()=>{const f=new ResizeObserver(J=>{Y((Math.min(J[0].target.clientWidth||620,J[0].target.clientHeight||480,E||1/0)||420)/2)});return L.current&&f.observe(L.current),()=>f.disconnect()},[E]);const O=G?me.orderBy(s,["size"],[G]):s;return h.jsxRuntimeExports.jsxs(ue.GraphContainer,{className:k?.graphContainer,style:w?.graphContainer,id:v,ref:M,"aria-label":u,backgroundColor:g,theme:z,language:P,minHeight:S,width:D,height:N,relativeHeight:o,padding:y,children:[c||p||x||j?h.jsxRuntimeExports.jsx(ve.GraphHeader,{styles:{title:w?.title,description:w?.description},classNames:{title:k?.title,description:k?.description},graphTitle:c,graphDescription:p,width:D,graphDownload:x?M:void 0,dataDownload:j?s.map(f=>f.data).filter(f=>f!==void 0).length>0?s.map(f=>f.data).filter(f=>f!==void 0):s.filter(f=>f!==void 0):null}):null,s.length===0?h.jsxRuntimeExports.jsx(je.EmptyState,{}):h.jsxRuntimeExports.jsxs(h.jsxRuntimeExports.Fragment,{children:[i?h.jsxRuntimeExports.jsx("div",{className:h.mo("leading-0 flex mb-0 ml-auto mr-auto justify-center gap-x-3 gap-y-0 flex-wrap",k?.colorLegend),style:{maxWidth:W},"aria-label":"Color legend",children:O.map((f,J)=>h.jsxRuntimeExports.jsxs("div",{className:"flex gap-2 items-center pb-3",children:[h.jsxRuntimeExports.jsx("div",{className:"w-3 h-3 rounded-full",style:{backgroundColor:(A||O.map(Q=>Q.label)).indexOf(f.label)!==-1?(R||_.Colors[z].categoricalColors.colors)[(A||O.map(Q=>Q.label)).indexOf(f.label)%(R||_.Colors[z].categoricalColors.colors).length]:_.Colors.gray}}),h.jsxRuntimeExports.jsxs(ne.j,{marginBottom:"none",size:"sm",className:"text-primary-gray-700 dark:text-primary-gray-100",children:[f.label,":"," ",h.jsxRuntimeExports.jsx("span",{className:"font-bold",style:{fontSize:"inherit"},children:pe.numberFormattingFunction(f.size,"NA",$,d,l)})]})]},J))}):null,h.jsxRuntimeExports.jsx(xe.n,{size:"lg"}),h.jsxRuntimeExports.jsx(ue.GraphArea,{ref:L,children:B?h.jsxRuntimeExports.jsx(Oe,{mainText:e,data:O,colors:R,radius:B,subNote:a,strokeWidth:t,tooltip:q,colorDomain:A||O.map(f=>f.label),onSeriesMouseOver:m,onSeriesMouseClick:C,resetSelectionOnDoubleClick:I,styles:w,detailsOnClick:X,precision:$}):null})]}),b||n?h.jsxRuntimeExports.jsx(ye.GraphFooter,{styles:{footnote:w?.footnote,source:w?.source},classNames:{footnote:k?.footnote,source:k?.source},sources:b,footNote:n,width:D}):null]})}exports.DonutChart=ze;
2
2
  //# sourceMappingURL=DonutChart.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"DonutChart.cjs","sources":["../node_modules/d3-shape/src/math.js","../node_modules/d3-shape/src/arc.js","../node_modules/d3-shape/src/descending.js","../node_modules/d3-shape/src/identity.js","../node_modules/d3-shape/src/pie.js","../src/Components/Graphs/DonutChart/Graph.tsx","../src/Components/Graphs/DonutChart/index.tsx"],"sourcesContent":["export const abs = Math.abs;\nexport const atan2 = Math.atan2;\nexport const cos = Math.cos;\nexport const max = Math.max;\nexport const min = Math.min;\nexport const sin = Math.sin;\nexport const sqrt = Math.sqrt;\n\nexport const epsilon = 1e-12;\nexport const pi = Math.PI;\nexport const halfPi = pi / 2;\nexport const tau = 2 * pi;\n\nexport function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi : Math.acos(x);\n}\n\nexport function asin(x) {\n return x >= 1 ? halfPi : x <= -1 ? -halfPi : Math.asin(x);\n}\n","import constant from \"./constant.js\";\nimport {abs, acos, asin, atan2, cos, epsilon, halfPi, max, min, pi, sin, sqrt, tau} from \"./math.js\";\nimport {withPath} from \"./path.js\";\n\nfunction arcInnerRadius(d) {\n return d.innerRadius;\n}\n\nfunction arcOuterRadius(d) {\n return d.outerRadius;\n}\n\nfunction arcStartAngle(d) {\n return d.startAngle;\n}\n\nfunction arcEndAngle(d) {\n return d.endAngle;\n}\n\nfunction arcPadAngle(d) {\n return d && d.padAngle; // Note: optional!\n}\n\nfunction intersect(x0, y0, x1, y1, x2, y2, x3, y3) {\n var x10 = x1 - x0, y10 = y1 - y0,\n x32 = x3 - x2, y32 = y3 - y2,\n t = y32 * x10 - x32 * y10;\n if (t * t < epsilon) return;\n t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / t;\n return [x0 + t * x10, y0 + t * y10];\n}\n\n// Compute perpendicular offset line of length rc.\n// http://mathworld.wolfram.com/Circle-LineIntersection.html\nfunction cornerTangents(x0, y0, x1, y1, r1, rc, cw) {\n var x01 = x0 - x1,\n y01 = y0 - y1,\n lo = (cw ? rc : -rc) / sqrt(x01 * x01 + y01 * y01),\n ox = lo * y01,\n oy = -lo * x01,\n x11 = x0 + ox,\n y11 = y0 + oy,\n x10 = x1 + ox,\n y10 = y1 + oy,\n x00 = (x11 + x10) / 2,\n y00 = (y11 + y10) / 2,\n dx = x10 - x11,\n dy = y10 - y11,\n d2 = dx * dx + dy * dy,\n r = r1 - rc,\n D = x11 * y10 - x10 * y11,\n d = (dy < 0 ? -1 : 1) * sqrt(max(0, r * r * d2 - D * D)),\n cx0 = (D * dy - dx * d) / d2,\n cy0 = (-D * dx - dy * d) / d2,\n cx1 = (D * dy + dx * d) / d2,\n cy1 = (-D * dx + dy * d) / d2,\n dx0 = cx0 - x00,\n dy0 = cy0 - y00,\n dx1 = cx1 - x00,\n dy1 = cy1 - y00;\n\n // Pick the closer of the two intersection points.\n // TODO Is there a faster way to determine which intersection to use?\n if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) cx0 = cx1, cy0 = cy1;\n\n return {\n cx: cx0,\n cy: cy0,\n x01: -ox,\n y01: -oy,\n x11: cx0 * (r1 / r - 1),\n y11: cy0 * (r1 / r - 1)\n };\n}\n\nexport default function() {\n var innerRadius = arcInnerRadius,\n outerRadius = arcOuterRadius,\n cornerRadius = constant(0),\n padRadius = null,\n startAngle = arcStartAngle,\n endAngle = arcEndAngle,\n padAngle = arcPadAngle,\n context = null,\n path = withPath(arc);\n\n function arc() {\n var buffer,\n r,\n r0 = +innerRadius.apply(this, arguments),\n r1 = +outerRadius.apply(this, arguments),\n a0 = startAngle.apply(this, arguments) - halfPi,\n a1 = endAngle.apply(this, arguments) - halfPi,\n da = abs(a1 - a0),\n cw = a1 > a0;\n\n if (!context) context = buffer = path();\n\n // Ensure that the outer radius is always larger than the inner radius.\n if (r1 < r0) r = r1, r1 = r0, r0 = r;\n\n // Is it a point?\n if (!(r1 > epsilon)) context.moveTo(0, 0);\n\n // Or is it a circle or annulus?\n else if (da > tau - epsilon) {\n context.moveTo(r1 * cos(a0), r1 * sin(a0));\n context.arc(0, 0, r1, a0, a1, !cw);\n if (r0 > epsilon) {\n context.moveTo(r0 * cos(a1), r0 * sin(a1));\n context.arc(0, 0, r0, a1, a0, cw);\n }\n }\n\n // Or is it a circular or annular sector?\n else {\n var a01 = a0,\n a11 = a1,\n a00 = a0,\n a10 = a1,\n da0 = da,\n da1 = da,\n ap = padAngle.apply(this, arguments) / 2,\n rp = (ap > epsilon) && (padRadius ? +padRadius.apply(this, arguments) : sqrt(r0 * r0 + r1 * r1)),\n rc = min(abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments)),\n rc0 = rc,\n rc1 = rc,\n t0,\n t1;\n\n // Apply padding? Note that since r1 ≥ r0, da1 ≥ da0.\n if (rp > epsilon) {\n var p0 = asin(rp / r0 * sin(ap)),\n p1 = asin(rp / r1 * sin(ap));\n if ((da0 -= p0 * 2) > epsilon) p0 *= (cw ? 1 : -1), a00 += p0, a10 -= p0;\n else da0 = 0, a00 = a10 = (a0 + a1) / 2;\n if ((da1 -= p1 * 2) > epsilon) p1 *= (cw ? 1 : -1), a01 += p1, a11 -= p1;\n else da1 = 0, a01 = a11 = (a0 + a1) / 2;\n }\n\n var x01 = r1 * cos(a01),\n y01 = r1 * sin(a01),\n x10 = r0 * cos(a10),\n y10 = r0 * sin(a10);\n\n // Apply rounded corners?\n if (rc > epsilon) {\n var x11 = r1 * cos(a11),\n y11 = r1 * sin(a11),\n x00 = r0 * cos(a00),\n y00 = r0 * sin(a00),\n oc;\n\n // Restrict the corner radius according to the sector angle. If this\n // intersection fails, it’s probably because the arc is too small, so\n // disable the corner radius entirely.\n if (da < pi) {\n if (oc = intersect(x01, y01, x00, y00, x11, y11, x10, y10)) {\n var ax = x01 - oc[0],\n ay = y01 - oc[1],\n bx = x11 - oc[0],\n by = y11 - oc[1],\n kc = 1 / sin(acos((ax * bx + ay * by) / (sqrt(ax * ax + ay * ay) * sqrt(bx * bx + by * by))) / 2),\n lc = sqrt(oc[0] * oc[0] + oc[1] * oc[1]);\n rc0 = min(rc, (r0 - lc) / (kc - 1));\n rc1 = min(rc, (r1 - lc) / (kc + 1));\n } else {\n rc0 = rc1 = 0;\n }\n }\n }\n\n // Is the sector collapsed to a line?\n if (!(da1 > epsilon)) context.moveTo(x01, y01);\n\n // Does the sector’s outer ring have rounded corners?\n else if (rc1 > epsilon) {\n t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);\n t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);\n\n context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n // Have the corners merged?\n if (rc1 < rc) context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);\n\n // Otherwise, draw the two corners and the ring.\n else {\n context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);\n context.arc(0, 0, r1, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), !cw);\n context.arc(t1.cx, t1.cy, rc1, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);\n }\n }\n\n // Or is the outer ring just a circular arc?\n else context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);\n\n // Is there no inner ring, and it’s a circular sector?\n // Or perhaps it’s an annular sector collapsed due to padding?\n if (!(r0 > epsilon) || !(da0 > epsilon)) context.lineTo(x10, y10);\n\n // Does the sector’s inner ring (or point) have rounded corners?\n else if (rc0 > epsilon) {\n t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);\n t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);\n\n context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n // Have the corners merged?\n if (rc0 < rc) context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);\n\n // Otherwise, draw the two corners and the ring.\n else {\n context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);\n context.arc(0, 0, r0, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), cw);\n context.arc(t1.cx, t1.cy, rc0, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);\n }\n }\n\n // Or is the inner ring just a circular arc?\n else context.arc(0, 0, r0, a10, a00, cw);\n }\n\n context.closePath();\n\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n arc.centroid = function() {\n var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2,\n a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi / 2;\n return [cos(a) * r, sin(a) * r];\n };\n\n arc.innerRadius = function(_) {\n return arguments.length ? (innerRadius = typeof _ === \"function\" ? _ : constant(+_), arc) : innerRadius;\n };\n\n arc.outerRadius = function(_) {\n return arguments.length ? (outerRadius = typeof _ === \"function\" ? _ : constant(+_), arc) : outerRadius;\n };\n\n arc.cornerRadius = function(_) {\n return arguments.length ? (cornerRadius = typeof _ === \"function\" ? _ : constant(+_), arc) : cornerRadius;\n };\n\n arc.padRadius = function(_) {\n return arguments.length ? (padRadius = _ == null ? null : typeof _ === \"function\" ? _ : constant(+_), arc) : padRadius;\n };\n\n arc.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant(+_), arc) : startAngle;\n };\n\n arc.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant(+_), arc) : endAngle;\n };\n\n arc.padAngle = function(_) {\n return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant(+_), arc) : padAngle;\n };\n\n arc.context = function(_) {\n return arguments.length ? ((context = _ == null ? null : _), arc) : context;\n };\n\n return arc;\n}\n","export default function(a, b) {\n return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;\n}\n","export default function(d) {\n return d;\n}\n","import array from \"./array.js\";\nimport constant from \"./constant.js\";\nimport descending from \"./descending.js\";\nimport identity from \"./identity.js\";\nimport {tau} from \"./math.js\";\n\nexport default function() {\n var value = identity,\n sortValues = descending,\n sort = null,\n startAngle = constant(0),\n endAngle = constant(tau),\n padAngle = constant(0);\n\n function pie(data) {\n var i,\n n = (data = array(data)).length,\n j,\n k,\n sum = 0,\n index = new Array(n),\n arcs = new Array(n),\n a0 = +startAngle.apply(this, arguments),\n da = Math.min(tau, Math.max(-tau, endAngle.apply(this, arguments) - a0)),\n a1,\n p = Math.min(Math.abs(da) / n, padAngle.apply(this, arguments)),\n pa = p * (da < 0 ? -1 : 1),\n v;\n\n for (i = 0; i < n; ++i) {\n if ((v = arcs[index[i] = i] = +value(data[i], i, data)) > 0) {\n sum += v;\n }\n }\n\n // Optionally sort the arcs by previously-computed values or by data.\n if (sortValues != null) index.sort(function(i, j) { return sortValues(arcs[i], arcs[j]); });\n else if (sort != null) index.sort(function(i, j) { return sort(data[i], data[j]); });\n\n // Compute the arcs! They are stored in the original data's order.\n for (i = 0, k = sum ? (da - n * pa) / sum : 0; i < n; ++i, a0 = a1) {\n j = index[i], v = arcs[j], a1 = a0 + (v > 0 ? v * k : 0) + pa, arcs[j] = {\n data: data[j],\n index: i,\n value: v,\n startAngle: a0,\n endAngle: a1,\n padAngle: p\n };\n }\n\n return arcs;\n }\n\n pie.value = function(_) {\n return arguments.length ? (value = typeof _ === \"function\" ? _ : constant(+_), pie) : value;\n };\n\n pie.sortValues = function(_) {\n return arguments.length ? (sortValues = _, sort = null, pie) : sortValues;\n };\n\n pie.sort = function(_) {\n return arguments.length ? (sort = _, sortValues = null, pie) : sort;\n };\n\n pie.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant(+_), pie) : startAngle;\n };\n\n pie.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant(+_), pie) : endAngle;\n };\n\n pie.padAngle = function(_) {\n return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant(+_), pie) : padAngle;\n };\n\n return pie;\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport isEqual from 'fast-deep-equal';\r\nimport { pie, arc } from 'd3-shape';\r\nimport { useState } from 'react';\r\nimport { H2, P } from '@undp/design-system-react/Typography';\r\nimport { Modal } from '@undp/design-system-react/Modal';\r\n\r\nimport { ClassNameObject, DonutChartDataType, StyleObject } from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { string2HTML } from '@/Utils/string2HTML';\r\n\r\ninterface Props {\r\n mainText?: string | { label: string; suffix?: string; prefix?: string };\r\n radius: number;\r\n colors: string[];\r\n subNote?: string;\r\n strokeWidth: number;\r\n data: DonutChartDataType[];\r\n\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n\r\n onSeriesMouseOver?: (_d: any) => void;\r\n\r\n onSeriesMouseClick?: (_d: any) => void;\r\n colorDomain: string[];\r\n resetSelectionOnDoubleClick: boolean;\r\n\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n precision: number;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n mainText,\r\n data,\r\n radius,\r\n colors,\r\n subNote,\r\n strokeWidth,\r\n tooltip,\r\n onSeriesMouseOver,\r\n onSeriesMouseClick,\r\n colorDomain,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n precision,\r\n } = props;\r\n const pieData = pie()\r\n .sort(null)\r\n .startAngle(0)\r\n\r\n .value((d: any) => d.size);\r\n\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n return (\r\n <>\r\n <svg\r\n width={`${radius * 2}px`}\r\n height={`${radius * 2}px`}\r\n viewBox={`0 0 ${radius * 2} ${radius * 2}`}\r\n direction='ltr'\r\n className='mx-auto'\r\n >\r\n <g transform={`translate(${radius} ${radius})`}>\r\n {mainText || subNote ? (\r\n <foreignObject\r\n y={0 - (radius - strokeWidth)}\r\n x={0 - (radius - strokeWidth)}\r\n width={2 * (radius - strokeWidth)}\r\n height={2 * (radius - strokeWidth)}\r\n >\r\n <div className='flex flex-col gap-0.5 justify-center items-center h-inherit py-0 px-4'>\r\n {mainText ? (\r\n <H2\r\n marginBottom='none'\r\n className='donut-main-text text-primary-gray-700 dark:text-primary-gray-100 leading-none text-center'\r\n >\r\n {typeof mainText === 'string'\r\n ? mainText\r\n : data.findIndex(d => d.label === mainText.label) !== -1\r\n ? numberFormattingFunction(\r\n data[data.findIndex(d => d.label === mainText.label)].size,\r\n 'NA',\r\n precision,\r\n mainText.prefix,\r\n mainText.suffix,\r\n )\r\n : 'NA'}\r\n </H2>\r\n ) : null}\r\n {subNote ? (\r\n <P\r\n marginBottom='none'\r\n size='base'\r\n leading='none'\r\n className='donut-sub-note text-primary-gray-700 dark:text-primary-gray-100 text-center font-bold'\r\n >\r\n {subNote}\r\n </P>\r\n ) : typeof mainText === 'string' || !mainText ? null : (\r\n <P\r\n size='base'\r\n marginBottom='none'\r\n leading='none'\r\n className='donut-label text-primary-gray-700 dark:text-primary-gray-100 text-center font-bold'\r\n >\r\n {mainText.label}\r\n </P>\r\n )}\r\n </div>\r\n </foreignObject>\r\n ) : null}\r\n {pieData(data as any).map((d, i) => (\r\n <path\r\n key={i}\r\n d={\r\n arc()({\r\n innerRadius: radius - strokeWidth,\r\n outerRadius: radius,\r\n startAngle: d.startAngle,\r\n endAngle: d.endAngle,\r\n }) as string\r\n }\r\n style={{\r\n fill:\r\n colorDomain.indexOf((d.data as any).label) !== -1\r\n ? colors[colorDomain.indexOf((d.data as any).label) % colors.length]\r\n : Colors.gray,\r\n opacity: mouseOverData\r\n ? mouseOverData.label === (d.data as any).label\r\n ? 1\r\n : 0.3\r\n : 1,\r\n }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d.data);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d.data) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d.data);\r\n if (onSeriesMouseClick) onSeriesMouseClick(d.data);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d.data);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n />\r\n ))}\r\n </g>\r\n </svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <Modal\r\n open={mouseClickData !== undefined}\r\n onClose={() => {\r\n setMouseClickData(undefined);\r\n }}\r\n >\r\n <div\r\n className='graph-modal-content m-0'\r\n dangerouslySetInnerHTML={\r\n typeof detailsOnClick === 'string'\r\n ? { __html: string2HTML(detailsOnClick, mouseClickData) }\r\n : undefined\r\n }\r\n >\r\n {typeof detailsOnClick === 'function' ? detailsOnClick(mouseClickData) : null}\r\n </div>\r\n </Modal>\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\nimport { P } from '@undp/design-system-react/Typography';\r\nimport orderBy from 'lodash.orderby';\r\nimport { Spacer } from '@undp/design-system-react/Spacer';\r\nimport { cn } from '@undp/design-system-react/cn';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n DonutChartDataType,\r\n Languages,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: DonutChartDataType[];\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Array of colors for each segment */\r\n colors?: string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Radius of the donut chart */\r\n radius?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Max width of the color scale as a css property */\r\n colorScaleMaxWidth?: string;\r\n /** Stroke width of the arcs and circle of the donut */\r\n strokeWidth?: number;\r\n /** Sorting order for data. This is overwritten by labelOrder prop */\r\n sortData?: 'asc' | 'desc';\r\n /** Large text at the center of the donut chart. If the type is an object then the text is the value in the data for the label mentioned in the object */\r\n mainText?: string | { label: string; suffix?: string; prefix?: string };\r\n /** Small text at the center of the donut chart */\r\n subNote?: string;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function DonutChart(props: Props) {\r\n const {\r\n mainText,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n strokeWidth = 50,\r\n graphDescription,\r\n subNote,\r\n footNote,\r\n radius,\r\n data,\r\n showColorScale = true,\r\n padding,\r\n backgroundColor = false,\r\n tooltip,\r\n onSeriesMouseOver,\r\n graphID,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n colorDomain,\r\n sortData,\r\n language = 'en',\r\n theme = 'light',\r\n width,\r\n height,\r\n minHeight = 0,\r\n relativeHeight,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n colorScaleMaxWidth,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n precision = 2,\r\n } = props;\r\n\r\n const [graphRadius, setGraphRadius] = useState(0);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setGraphRadius(\r\n (Math.min(\r\n ...[\r\n entries[0].target.clientWidth || 620,\r\n entries[0].target.clientHeight || 480,\r\n radius || Infinity,\r\n ],\r\n ) || 420) / 2,\r\n );\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [radius]);\r\n\r\n const sortedData = sortData ? orderBy(data, ['size'], [sortData]) : data;\r\n\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <div\r\n className={cn(\r\n 'leading-0 flex mb-0 ml-auto mr-auto justify-center gap-x-3 gap-y-0 flex-wrap',\r\n classNames?.colorLegend,\r\n )}\r\n style={{ maxWidth: colorScaleMaxWidth }}\r\n aria-label='Color legend'\r\n >\r\n {sortedData.map((d, i) => (\r\n <div className='flex gap-2 items-center pb-3' key={i}>\r\n <div\r\n className='w-3 h-3 rounded-full'\r\n style={{\r\n backgroundColor:\r\n (colorDomain || sortedData.map(el => el.label)).indexOf(d.label) !== -1\r\n ? (colors || Colors[theme].categoricalColors.colors)[\r\n (colorDomain || sortedData.map(el => el.label)).indexOf(d.label) %\r\n (colors || Colors[theme].categoricalColors.colors).length\r\n ]\r\n : Colors.gray,\r\n }}\r\n />\r\n <P\r\n marginBottom='none'\r\n size='sm'\r\n className='text-primary-gray-700 dark:text-primary-gray-100'\r\n >\r\n {d.label}:{' '}\r\n <span className='font-bold' style={{ fontSize: 'inherit' }}>\r\n {numberFormattingFunction(d.size, 'NA', precision, prefix, suffix)}\r\n </span>\r\n </P>\r\n </div>\r\n ))}\r\n </div>\r\n ) : null}\r\n <Spacer size='lg' />\r\n <GraphArea ref={graphDiv}>\r\n {graphRadius ? (\r\n <Graph\r\n mainText={mainText}\r\n data={sortedData}\r\n colors={colors}\r\n radius={graphRadius}\r\n subNote={subNote}\r\n strokeWidth={strokeWidth}\r\n tooltip={tooltip}\r\n colorDomain={colorDomain || sortedData.map(d => d.label)}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n precision={precision}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n </>\r\n )}\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["abs","atan2","cos","max","min","sin","sqrt","epsilon","pi","halfPi","tau","acos","x","asin","arcInnerRadius","d","arcOuterRadius","arcStartAngle","arcEndAngle","arcPadAngle","intersect","x0","y0","x1","y1","x2","y2","x3","y3","x10","y10","x32","y32","t","cornerTangents","r1","rc","cw","x01","y01","lo","ox","oy","x11","y11","x00","y00","dx","dy","d2","r","D","cx0","cy0","cx1","cy1","dx0","dy0","dx1","dy1","arc","innerRadius","outerRadius","cornerRadius","constant","padRadius","startAngle","endAngle","padAngle","context","path","withPath","buffer","r0","a0","a1","da","a01","a11","a00","a10","da0","da1","ap","rp","rc0","rc1","t0","t1","p0","p1","oc","ax","ay","bx","by","kc","lc","a","_","descending","b","identity","pie","value","sortValues","sort","data","i","n","array","j","k","sum","index","arcs","p","pa","v","Graph","props","$","_c","mainText","radius","colors","subNote","strokeWidth","tooltip","onSeriesMouseOver","onSeriesMouseClick","colorDomain","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","precision","pieData","_temp","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","t2","t3","t4","t5","t6","jsx","jsxs","H2","findIndex","d_1","label","numberFormattingFunction","d_0","size","prefix","suffix","P","t7","d_2","fill","indexOf","length","Colors","gray","opacity","event","clientY","clientX","isEqual","event_0","t8","map","t9","t10","t11","Tooltip","t12","Modal","__html","string2HTML","t13","Fragment","DonutChart","graphTitle","light","categoricalColors","sources","graphDescription","footNote","showColorScale","padding","backgroundColor","graphID","graphDownload","dataDownload","sortData","language","theme","width","height","minHeight","relativeHeight","ariaLabel","colorScaleMaxWidth","graphRadius","setGraphRadius","graphDiv","useRef","graphParentDiv","useEffect","resizeObserver","ResizeObserver","entries","Math","target","clientWidth","clientHeight","Infinity","current","observe","disconnect","sortedData","orderBy","GraphContainer","graphContainer","GraphHeader","title","description","filter","EmptyState","cn","colorLegend","maxWidth","el","fontSize","Spacer","GraphArea","GraphFooter","footnote","source"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4]}
1
+ {"version":3,"file":"DonutChart.cjs","sources":["../node_modules/d3-shape/src/math.js","../node_modules/d3-shape/src/arc.js","../node_modules/d3-shape/src/descending.js","../node_modules/d3-shape/src/identity.js","../node_modules/d3-shape/src/pie.js","../src/Components/Graphs/DonutChart/Graph.tsx","../src/Components/Graphs/DonutChart/index.tsx"],"sourcesContent":["export const abs = Math.abs;\nexport const atan2 = Math.atan2;\nexport const cos = Math.cos;\nexport const max = Math.max;\nexport const min = Math.min;\nexport const sin = Math.sin;\nexport const sqrt = Math.sqrt;\n\nexport const epsilon = 1e-12;\nexport const pi = Math.PI;\nexport const halfPi = pi / 2;\nexport const tau = 2 * pi;\n\nexport function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi : Math.acos(x);\n}\n\nexport function asin(x) {\n return x >= 1 ? halfPi : x <= -1 ? -halfPi : Math.asin(x);\n}\n","import constant from \"./constant.js\";\nimport {abs, acos, asin, atan2, cos, epsilon, halfPi, max, min, pi, sin, sqrt, tau} from \"./math.js\";\nimport {withPath} from \"./path.js\";\n\nfunction arcInnerRadius(d) {\n return d.innerRadius;\n}\n\nfunction arcOuterRadius(d) {\n return d.outerRadius;\n}\n\nfunction arcStartAngle(d) {\n return d.startAngle;\n}\n\nfunction arcEndAngle(d) {\n return d.endAngle;\n}\n\nfunction arcPadAngle(d) {\n return d && d.padAngle; // Note: optional!\n}\n\nfunction intersect(x0, y0, x1, y1, x2, y2, x3, y3) {\n var x10 = x1 - x0, y10 = y1 - y0,\n x32 = x3 - x2, y32 = y3 - y2,\n t = y32 * x10 - x32 * y10;\n if (t * t < epsilon) return;\n t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / t;\n return [x0 + t * x10, y0 + t * y10];\n}\n\n// Compute perpendicular offset line of length rc.\n// http://mathworld.wolfram.com/Circle-LineIntersection.html\nfunction cornerTangents(x0, y0, x1, y1, r1, rc, cw) {\n var x01 = x0 - x1,\n y01 = y0 - y1,\n lo = (cw ? rc : -rc) / sqrt(x01 * x01 + y01 * y01),\n ox = lo * y01,\n oy = -lo * x01,\n x11 = x0 + ox,\n y11 = y0 + oy,\n x10 = x1 + ox,\n y10 = y1 + oy,\n x00 = (x11 + x10) / 2,\n y00 = (y11 + y10) / 2,\n dx = x10 - x11,\n dy = y10 - y11,\n d2 = dx * dx + dy * dy,\n r = r1 - rc,\n D = x11 * y10 - x10 * y11,\n d = (dy < 0 ? -1 : 1) * sqrt(max(0, r * r * d2 - D * D)),\n cx0 = (D * dy - dx * d) / d2,\n cy0 = (-D * dx - dy * d) / d2,\n cx1 = (D * dy + dx * d) / d2,\n cy1 = (-D * dx + dy * d) / d2,\n dx0 = cx0 - x00,\n dy0 = cy0 - y00,\n dx1 = cx1 - x00,\n dy1 = cy1 - y00;\n\n // Pick the closer of the two intersection points.\n // TODO Is there a faster way to determine which intersection to use?\n if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1) cx0 = cx1, cy0 = cy1;\n\n return {\n cx: cx0,\n cy: cy0,\n x01: -ox,\n y01: -oy,\n x11: cx0 * (r1 / r - 1),\n y11: cy0 * (r1 / r - 1)\n };\n}\n\nexport default function() {\n var innerRadius = arcInnerRadius,\n outerRadius = arcOuterRadius,\n cornerRadius = constant(0),\n padRadius = null,\n startAngle = arcStartAngle,\n endAngle = arcEndAngle,\n padAngle = arcPadAngle,\n context = null,\n path = withPath(arc);\n\n function arc() {\n var buffer,\n r,\n r0 = +innerRadius.apply(this, arguments),\n r1 = +outerRadius.apply(this, arguments),\n a0 = startAngle.apply(this, arguments) - halfPi,\n a1 = endAngle.apply(this, arguments) - halfPi,\n da = abs(a1 - a0),\n cw = a1 > a0;\n\n if (!context) context = buffer = path();\n\n // Ensure that the outer radius is always larger than the inner radius.\n if (r1 < r0) r = r1, r1 = r0, r0 = r;\n\n // Is it a point?\n if (!(r1 > epsilon)) context.moveTo(0, 0);\n\n // Or is it a circle or annulus?\n else if (da > tau - epsilon) {\n context.moveTo(r1 * cos(a0), r1 * sin(a0));\n context.arc(0, 0, r1, a0, a1, !cw);\n if (r0 > epsilon) {\n context.moveTo(r0 * cos(a1), r0 * sin(a1));\n context.arc(0, 0, r0, a1, a0, cw);\n }\n }\n\n // Or is it a circular or annular sector?\n else {\n var a01 = a0,\n a11 = a1,\n a00 = a0,\n a10 = a1,\n da0 = da,\n da1 = da,\n ap = padAngle.apply(this, arguments) / 2,\n rp = (ap > epsilon) && (padRadius ? +padRadius.apply(this, arguments) : sqrt(r0 * r0 + r1 * r1)),\n rc = min(abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments)),\n rc0 = rc,\n rc1 = rc,\n t0,\n t1;\n\n // Apply padding? Note that since r1 ≥ r0, da1 ≥ da0.\n if (rp > epsilon) {\n var p0 = asin(rp / r0 * sin(ap)),\n p1 = asin(rp / r1 * sin(ap));\n if ((da0 -= p0 * 2) > epsilon) p0 *= (cw ? 1 : -1), a00 += p0, a10 -= p0;\n else da0 = 0, a00 = a10 = (a0 + a1) / 2;\n if ((da1 -= p1 * 2) > epsilon) p1 *= (cw ? 1 : -1), a01 += p1, a11 -= p1;\n else da1 = 0, a01 = a11 = (a0 + a1) / 2;\n }\n\n var x01 = r1 * cos(a01),\n y01 = r1 * sin(a01),\n x10 = r0 * cos(a10),\n y10 = r0 * sin(a10);\n\n // Apply rounded corners?\n if (rc > epsilon) {\n var x11 = r1 * cos(a11),\n y11 = r1 * sin(a11),\n x00 = r0 * cos(a00),\n y00 = r0 * sin(a00),\n oc;\n\n // Restrict the corner radius according to the sector angle. If this\n // intersection fails, it’s probably because the arc is too small, so\n // disable the corner radius entirely.\n if (da < pi) {\n if (oc = intersect(x01, y01, x00, y00, x11, y11, x10, y10)) {\n var ax = x01 - oc[0],\n ay = y01 - oc[1],\n bx = x11 - oc[0],\n by = y11 - oc[1],\n kc = 1 / sin(acos((ax * bx + ay * by) / (sqrt(ax * ax + ay * ay) * sqrt(bx * bx + by * by))) / 2),\n lc = sqrt(oc[0] * oc[0] + oc[1] * oc[1]);\n rc0 = min(rc, (r0 - lc) / (kc - 1));\n rc1 = min(rc, (r1 - lc) / (kc + 1));\n } else {\n rc0 = rc1 = 0;\n }\n }\n }\n\n // Is the sector collapsed to a line?\n if (!(da1 > epsilon)) context.moveTo(x01, y01);\n\n // Does the sector’s outer ring have rounded corners?\n else if (rc1 > epsilon) {\n t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);\n t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);\n\n context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n // Have the corners merged?\n if (rc1 < rc) context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);\n\n // Otherwise, draw the two corners and the ring.\n else {\n context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);\n context.arc(0, 0, r1, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), !cw);\n context.arc(t1.cx, t1.cy, rc1, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);\n }\n }\n\n // Or is the outer ring just a circular arc?\n else context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);\n\n // Is there no inner ring, and it’s a circular sector?\n // Or perhaps it’s an annular sector collapsed due to padding?\n if (!(r0 > epsilon) || !(da0 > epsilon)) context.lineTo(x10, y10);\n\n // Does the sector’s inner ring (or point) have rounded corners?\n else if (rc0 > epsilon) {\n t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);\n t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);\n\n context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);\n\n // Have the corners merged?\n if (rc0 < rc) context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);\n\n // Otherwise, draw the two corners and the ring.\n else {\n context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);\n context.arc(0, 0, r0, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), cw);\n context.arc(t1.cx, t1.cy, rc0, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);\n }\n }\n\n // Or is the inner ring just a circular arc?\n else context.arc(0, 0, r0, a10, a00, cw);\n }\n\n context.closePath();\n\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n arc.centroid = function() {\n var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2,\n a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi / 2;\n return [cos(a) * r, sin(a) * r];\n };\n\n arc.innerRadius = function(_) {\n return arguments.length ? (innerRadius = typeof _ === \"function\" ? _ : constant(+_), arc) : innerRadius;\n };\n\n arc.outerRadius = function(_) {\n return arguments.length ? (outerRadius = typeof _ === \"function\" ? _ : constant(+_), arc) : outerRadius;\n };\n\n arc.cornerRadius = function(_) {\n return arguments.length ? (cornerRadius = typeof _ === \"function\" ? _ : constant(+_), arc) : cornerRadius;\n };\n\n arc.padRadius = function(_) {\n return arguments.length ? (padRadius = _ == null ? null : typeof _ === \"function\" ? _ : constant(+_), arc) : padRadius;\n };\n\n arc.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant(+_), arc) : startAngle;\n };\n\n arc.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant(+_), arc) : endAngle;\n };\n\n arc.padAngle = function(_) {\n return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant(+_), arc) : padAngle;\n };\n\n arc.context = function(_) {\n return arguments.length ? ((context = _ == null ? null : _), arc) : context;\n };\n\n return arc;\n}\n","export default function(a, b) {\n return b < a ? -1 : b > a ? 1 : b >= a ? 0 : NaN;\n}\n","export default function(d) {\n return d;\n}\n","import array from \"./array.js\";\nimport constant from \"./constant.js\";\nimport descending from \"./descending.js\";\nimport identity from \"./identity.js\";\nimport {tau} from \"./math.js\";\n\nexport default function() {\n var value = identity,\n sortValues = descending,\n sort = null,\n startAngle = constant(0),\n endAngle = constant(tau),\n padAngle = constant(0);\n\n function pie(data) {\n var i,\n n = (data = array(data)).length,\n j,\n k,\n sum = 0,\n index = new Array(n),\n arcs = new Array(n),\n a0 = +startAngle.apply(this, arguments),\n da = Math.min(tau, Math.max(-tau, endAngle.apply(this, arguments) - a0)),\n a1,\n p = Math.min(Math.abs(da) / n, padAngle.apply(this, arguments)),\n pa = p * (da < 0 ? -1 : 1),\n v;\n\n for (i = 0; i < n; ++i) {\n if ((v = arcs[index[i] = i] = +value(data[i], i, data)) > 0) {\n sum += v;\n }\n }\n\n // Optionally sort the arcs by previously-computed values or by data.\n if (sortValues != null) index.sort(function(i, j) { return sortValues(arcs[i], arcs[j]); });\n else if (sort != null) index.sort(function(i, j) { return sort(data[i], data[j]); });\n\n // Compute the arcs! They are stored in the original data's order.\n for (i = 0, k = sum ? (da - n * pa) / sum : 0; i < n; ++i, a0 = a1) {\n j = index[i], v = arcs[j], a1 = a0 + (v > 0 ? v * k : 0) + pa, arcs[j] = {\n data: data[j],\n index: i,\n value: v,\n startAngle: a0,\n endAngle: a1,\n padAngle: p\n };\n }\n\n return arcs;\n }\n\n pie.value = function(_) {\n return arguments.length ? (value = typeof _ === \"function\" ? _ : constant(+_), pie) : value;\n };\n\n pie.sortValues = function(_) {\n return arguments.length ? (sortValues = _, sort = null, pie) : sortValues;\n };\n\n pie.sort = function(_) {\n return arguments.length ? (sort = _, sortValues = null, pie) : sort;\n };\n\n pie.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant(+_), pie) : startAngle;\n };\n\n pie.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant(+_), pie) : endAngle;\n };\n\n pie.padAngle = function(_) {\n return arguments.length ? (padAngle = typeof _ === \"function\" ? _ : constant(+_), pie) : padAngle;\n };\n\n return pie;\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport isEqual from 'fast-deep-equal';\r\nimport { pie, arc } from 'd3-shape';\r\nimport { useState } from 'react';\r\nimport { H2, P } from '@undp/design-system-react/Typography';\r\n\r\nimport { ClassNameObject, DonutChartDataType, StyleObject } from '@/Types';\r\nimport { Tooltip } from '@/Components/Elements/Tooltip';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { DetailsModal } from '@/Components/Elements/DetailsModal';\r\n\r\ninterface Props {\r\n mainText?: string | { label: string; suffix?: string; prefix?: string };\r\n radius: number;\r\n colors: string[];\r\n subNote?: string;\r\n strokeWidth: number;\r\n data: DonutChartDataType[];\r\n\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n\r\n onSeriesMouseOver?: (_d: any) => void;\r\n\r\n onSeriesMouseClick?: (_d: any) => void;\r\n colorDomain: string[];\r\n resetSelectionOnDoubleClick: boolean;\r\n\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n styles?: StyleObject;\r\n classNames?: ClassNameObject;\r\n precision: number;\r\n}\r\n\r\nexport function Graph(props: Props) {\r\n const {\r\n mainText,\r\n data,\r\n radius,\r\n colors,\r\n subNote,\r\n strokeWidth,\r\n tooltip,\r\n onSeriesMouseOver,\r\n onSeriesMouseClick,\r\n colorDomain,\r\n resetSelectionOnDoubleClick,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n precision,\r\n } = props;\r\n const pieData = pie()\r\n .sort(null)\r\n .startAngle(0)\r\n\r\n .value((d: any) => d.size);\r\n\r\n const [mouseOverData, setMouseOverData] = useState<any>(undefined);\r\n\r\n const [mouseClickData, setMouseClickData] = useState<any>(undefined);\r\n const [eventX, setEventX] = useState<number | undefined>(undefined);\r\n const [eventY, setEventY] = useState<number | undefined>(undefined);\r\n return (\r\n <>\r\n <svg\r\n width={`${radius * 2}px`}\r\n height={`${radius * 2}px`}\r\n viewBox={`0 0 ${radius * 2} ${radius * 2}`}\r\n direction='ltr'\r\n className='mx-auto'\r\n >\r\n <g transform={`translate(${radius} ${radius})`}>\r\n {mainText || subNote ? (\r\n <foreignObject\r\n y={0 - (radius - strokeWidth)}\r\n x={0 - (radius - strokeWidth)}\r\n width={2 * (radius - strokeWidth)}\r\n height={2 * (radius - strokeWidth)}\r\n >\r\n <div className='flex flex-col gap-0.5 justify-center items-center h-inherit py-0 px-4'>\r\n {mainText ? (\r\n <H2\r\n marginBottom='none'\r\n className='donut-main-text text-primary-gray-700 dark:text-primary-gray-100 leading-none text-center'\r\n >\r\n {typeof mainText === 'string'\r\n ? mainText\r\n : data.findIndex(d => d.label === mainText.label) !== -1\r\n ? numberFormattingFunction(\r\n data[data.findIndex(d => d.label === mainText.label)].size,\r\n 'NA',\r\n precision,\r\n mainText.prefix,\r\n mainText.suffix,\r\n )\r\n : 'NA'}\r\n </H2>\r\n ) : null}\r\n {subNote ? (\r\n <P\r\n marginBottom='none'\r\n size='base'\r\n leading='none'\r\n className='donut-sub-note text-primary-gray-700 dark:text-primary-gray-100 text-center font-bold'\r\n >\r\n {subNote}\r\n </P>\r\n ) : typeof mainText === 'string' || !mainText ? null : (\r\n <P\r\n size='base'\r\n marginBottom='none'\r\n leading='none'\r\n className='donut-label text-primary-gray-700 dark:text-primary-gray-100 text-center font-bold'\r\n >\r\n {mainText.label}\r\n </P>\r\n )}\r\n </div>\r\n </foreignObject>\r\n ) : null}\r\n {pieData(data as any).map((d, i) => (\r\n <path\r\n key={i}\r\n d={\r\n arc()({\r\n innerRadius: radius - strokeWidth,\r\n outerRadius: radius,\r\n startAngle: d.startAngle,\r\n endAngle: d.endAngle,\r\n }) as string\r\n }\r\n style={{\r\n fill:\r\n colorDomain.indexOf((d.data as any).label) !== -1\r\n ? colors[colorDomain.indexOf((d.data as any).label) % colors.length]\r\n : Colors.gray,\r\n opacity: mouseOverData\r\n ? mouseOverData.label === (d.data as any).label\r\n ? 1\r\n : 0.3\r\n : 1,\r\n }}\r\n onMouseEnter={event => {\r\n setMouseOverData(d.data);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n onSeriesMouseOver?.(d);\r\n }}\r\n onClick={() => {\r\n if (onSeriesMouseClick || detailsOnClick) {\r\n if (isEqual(mouseClickData, d.data) && resetSelectionOnDoubleClick) {\r\n setMouseClickData(undefined);\r\n onSeriesMouseClick?.(undefined);\r\n } else {\r\n setMouseClickData(d.data);\r\n if (onSeriesMouseClick) onSeriesMouseClick(d.data);\r\n }\r\n }\r\n }}\r\n onMouseMove={event => {\r\n setMouseOverData(d.data);\r\n setEventY(event.clientY);\r\n setEventX(event.clientX);\r\n }}\r\n onMouseLeave={() => {\r\n setMouseOverData(undefined);\r\n setEventX(undefined);\r\n setEventY(undefined);\r\n onSeriesMouseOver?.(undefined);\r\n }}\r\n />\r\n ))}\r\n </g>\r\n </svg>\r\n {mouseOverData && tooltip && eventX && eventY ? (\r\n <Tooltip\r\n data={mouseOverData}\r\n body={tooltip}\r\n xPos={eventX}\r\n yPos={eventY}\r\n backgroundStyle={styles?.tooltip}\r\n className={classNames?.tooltip}\r\n />\r\n ) : null}\r\n {detailsOnClick && mouseClickData !== undefined ? (\r\n <DetailsModal\r\n body={detailsOnClick}\r\n data={mouseClickData}\r\n setData={setMouseClickData}\r\n className={classNames?.modal}\r\n />\r\n ) : null}\r\n </>\r\n );\r\n}\r\n","import { useEffect, useRef, useState } from 'react';\r\nimport { P } from '@undp/design-system-react/Typography';\r\nimport orderBy from 'lodash.orderby';\r\nimport { Spacer } from '@undp/design-system-react/Spacer';\r\nimport { cn } from '@undp/design-system-react/cn';\r\n\r\nimport { Graph } from './Graph';\r\n\r\nimport {\r\n DonutChartDataType,\r\n Languages,\r\n SourcesDataType,\r\n StyleObject,\r\n ClassNameObject,\r\n} from '@/Types';\r\nimport { numberFormattingFunction } from '@/Utils/numberFormattingFunction';\r\nimport { GraphFooter } from '@/Components/Elements/GraphFooter';\r\nimport { GraphHeader } from '@/Components/Elements/GraphHeader';\r\nimport { Colors } from '@/Components/ColorPalette';\r\nimport { EmptyState } from '@/Components/Elements/EmptyState';\r\nimport { GraphArea, GraphContainer } from '@/Components/Elements/GraphContainer';\r\n\r\ninterface Props {\r\n // Data\r\n /** Array of data objects */\r\n data: DonutChartDataType[];\r\n\r\n // Titles, Labels, and Sources\r\n /** Title of the graph */\r\n graphTitle?: string | React.ReactNode;\r\n /** Description of the graph */\r\n graphDescription?: string | React.ReactNode;\r\n /** Footnote for the graph */\r\n footNote?: string | React.ReactNode;\r\n /** Source data for the graph */\r\n sources?: SourcesDataType[];\r\n /** Accessibility label */\r\n ariaLabel?: string;\r\n\r\n // Colors and Styling\r\n /** Array of colors for each segment */\r\n colors?: string[];\r\n /** Domain of colors for the graph */\r\n colorDomain?: string[];\r\n /** Background color of the graph */\r\n backgroundColor?: string | boolean;\r\n /** Custom styles for the graph. Each object should be a valid React CSS style object. */\r\n styles?: StyleObject;\r\n /** Custom class names */\r\n classNames?: ClassNameObject;\r\n\r\n // Size and Spacing\r\n /** Width of the graph */\r\n width?: number;\r\n /** Height of the graph */\r\n height?: number;\r\n /** Minimum height of the graph */\r\n minHeight?: number;\r\n /** Relative height scaling factor. This overwrites the height props */\r\n relativeHeight?: number;\r\n /** Padding around the graph. Defaults to 0 if no backgroundColor is mentioned else defaults to 1rem */\r\n padding?: string;\r\n /** Radius of the donut chart */\r\n radius?: number;\r\n\r\n // Values and Ticks\r\n /** Prefix for values */\r\n prefix?: string;\r\n /** Suffix for values */\r\n suffix?: string;\r\n\r\n // Graph Parameters\r\n /** Toggle visibility of color scale. This is only applicable if the data props hae color parameter */\r\n showColorScale?: boolean;\r\n /** Max width of the color scale as a css property */\r\n colorScaleMaxWidth?: string;\r\n /** Stroke width of the arcs and circle of the donut */\r\n strokeWidth?: number;\r\n /** Sorting order for data. This is overwritten by labelOrder prop */\r\n sortData?: 'asc' | 'desc';\r\n /** Large text at the center of the donut chart. If the type is an object then the text is the value in the data for the label mentioned in the object */\r\n mainText?: string | { label: string; suffix?: string; prefix?: string };\r\n /** Small text at the center of the donut chart */\r\n subNote?: string;\r\n /** Specifies the number of decimal places to display in the value. */\r\n precision?: number;\r\n /** Enable graph download option as png */\r\n graphDownload?: boolean;\r\n /** Enable data download option as a csv */\r\n dataDownload?: boolean;\r\n /** Reset selection on double-click. Only applicable when used in a dashboard context with filters. */\r\n resetSelectionOnDoubleClick?: boolean;\r\n\r\n // Interactions and Callbacks\r\n /** Tooltip content. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n tooltip?: string | ((_d: any) => React.ReactNode);\r\n /** Details displayed on the modal when user clicks of a data point. If the type is string then this uses the [handlebar](../?path=/docs/misc-handlebars-templates-and-custom-helpers--docs) template to display the data */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n detailsOnClick?: string | ((_d: any) => React.ReactNode);\r\n /** Callback for mouse over event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseOver?: (_d: any) => void;\r\n /** Callback for mouse click event */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSeriesMouseClick?: (_d: any) => void;\r\n\r\n // Configuration and Options\r\n /** Language setting */\r\n language?: Languages;\r\n /** Color theme */\r\n theme?: 'light' | 'dark';\r\n /** Unique ID for the graph */\r\n graphID?: string;\r\n}\r\n\r\nexport function DonutChart(props: Props) {\r\n const {\r\n mainText,\r\n graphTitle,\r\n colors = Colors.light.categoricalColors.colors,\r\n suffix = '',\r\n sources,\r\n prefix = '',\r\n strokeWidth = 50,\r\n graphDescription,\r\n subNote,\r\n footNote,\r\n radius,\r\n data,\r\n showColorScale = true,\r\n padding,\r\n backgroundColor = false,\r\n tooltip,\r\n onSeriesMouseOver,\r\n graphID,\r\n onSeriesMouseClick,\r\n graphDownload = false,\r\n dataDownload = false,\r\n colorDomain,\r\n sortData,\r\n language = 'en',\r\n theme = 'light',\r\n width,\r\n height,\r\n minHeight = 0,\r\n relativeHeight,\r\n ariaLabel,\r\n resetSelectionOnDoubleClick = true,\r\n colorScaleMaxWidth,\r\n detailsOnClick,\r\n styles,\r\n classNames,\r\n precision = 2,\r\n } = props;\r\n\r\n const [graphRadius, setGraphRadius] = useState(0);\r\n\r\n const graphDiv = useRef<HTMLDivElement>(null);\r\n const graphParentDiv = useRef<HTMLDivElement>(null);\r\n\r\n useEffect(() => {\r\n const resizeObserver = new ResizeObserver(entries => {\r\n setGraphRadius(\r\n (Math.min(\r\n ...[\r\n entries[0].target.clientWidth || 620,\r\n entries[0].target.clientHeight || 480,\r\n radius || Infinity,\r\n ],\r\n ) || 420) / 2,\r\n );\r\n });\r\n if (graphDiv.current) {\r\n resizeObserver.observe(graphDiv.current);\r\n }\r\n return () => resizeObserver.disconnect();\r\n }, [radius]);\r\n\r\n const sortedData = sortData ? orderBy(data, ['size'], [sortData]) : data;\r\n\r\n return (\r\n <GraphContainer\r\n className={classNames?.graphContainer}\r\n style={styles?.graphContainer}\r\n id={graphID}\r\n ref={graphParentDiv}\r\n aria-label={ariaLabel}\r\n backgroundColor={backgroundColor}\r\n theme={theme}\r\n language={language}\r\n minHeight={minHeight}\r\n width={width}\r\n height={height}\r\n relativeHeight={relativeHeight}\r\n padding={padding}\r\n >\r\n {graphTitle || graphDescription || graphDownload || dataDownload ? (\r\n <GraphHeader\r\n styles={{\r\n title: styles?.title,\r\n description: styles?.description,\r\n }}\r\n classNames={{\r\n title: classNames?.title,\r\n description: classNames?.description,\r\n }}\r\n graphTitle={graphTitle}\r\n graphDescription={graphDescription}\r\n width={width}\r\n graphDownload={graphDownload ? graphParentDiv : undefined}\r\n dataDownload={\r\n dataDownload\r\n ? data.map(d => d.data).filter(d => d !== undefined).length > 0\r\n ? data.map(d => d.data).filter(d => d !== undefined)\r\n : data.filter(d => d !== undefined)\r\n : null\r\n }\r\n />\r\n ) : null}\r\n {data.length === 0 ? (\r\n <EmptyState />\r\n ) : (\r\n <>\r\n {showColorScale ? (\r\n <div\r\n className={cn(\r\n 'leading-0 flex mb-0 ml-auto mr-auto justify-center gap-x-3 gap-y-0 flex-wrap',\r\n classNames?.colorLegend,\r\n )}\r\n style={{ maxWidth: colorScaleMaxWidth }}\r\n aria-label='Color legend'\r\n >\r\n {sortedData.map((d, i) => (\r\n <div className='flex gap-2 items-center pb-3' key={i}>\r\n <div\r\n className='w-3 h-3 rounded-full'\r\n style={{\r\n backgroundColor:\r\n (colorDomain || sortedData.map(el => el.label)).indexOf(d.label) !== -1\r\n ? (colors || Colors[theme].categoricalColors.colors)[\r\n (colorDomain || sortedData.map(el => el.label)).indexOf(d.label) %\r\n (colors || Colors[theme].categoricalColors.colors).length\r\n ]\r\n : Colors.gray,\r\n }}\r\n />\r\n <P\r\n marginBottom='none'\r\n size='sm'\r\n className='text-primary-gray-700 dark:text-primary-gray-100'\r\n >\r\n {d.label}:{' '}\r\n <span className='font-bold' style={{ fontSize: 'inherit' }}>\r\n {numberFormattingFunction(d.size, 'NA', precision, prefix, suffix)}\r\n </span>\r\n </P>\r\n </div>\r\n ))}\r\n </div>\r\n ) : null}\r\n <Spacer size='lg' />\r\n <GraphArea ref={graphDiv}>\r\n {graphRadius ? (\r\n <Graph\r\n mainText={mainText}\r\n data={sortedData}\r\n colors={colors}\r\n radius={graphRadius}\r\n subNote={subNote}\r\n strokeWidth={strokeWidth}\r\n tooltip={tooltip}\r\n colorDomain={colorDomain || sortedData.map(d => d.label)}\r\n onSeriesMouseOver={onSeriesMouseOver}\r\n onSeriesMouseClick={onSeriesMouseClick}\r\n resetSelectionOnDoubleClick={resetSelectionOnDoubleClick}\r\n styles={styles}\r\n detailsOnClick={detailsOnClick}\r\n precision={precision}\r\n />\r\n ) : null}\r\n </GraphArea>\r\n </>\r\n )}\r\n {sources || footNote ? (\r\n <GraphFooter\r\n styles={{ footnote: styles?.footnote, source: styles?.source }}\r\n classNames={{\r\n footnote: classNames?.footnote,\r\n source: classNames?.source,\r\n }}\r\n sources={sources}\r\n footNote={footNote}\r\n width={width}\r\n />\r\n ) : null}\r\n </GraphContainer>\r\n );\r\n}\r\n"],"names":["abs","atan2","cos","max","min","sin","sqrt","epsilon","pi","halfPi","tau","acos","x","asin","arcInnerRadius","d","arcOuterRadius","arcStartAngle","arcEndAngle","arcPadAngle","intersect","x0","y0","x1","y1","x2","y2","x3","y3","x10","y10","x32","y32","t","cornerTangents","r1","rc","cw","x01","y01","lo","ox","oy","x11","y11","x00","y00","dx","dy","d2","r","D","cx0","cy0","cx1","cy1","dx0","dy0","dx1","dy1","arc","innerRadius","outerRadius","cornerRadius","constant","padRadius","startAngle","endAngle","padAngle","context","path","withPath","buffer","r0","a0","a1","da","a01","a11","a00","a10","da0","da1","ap","rp","rc0","rc1","t0","t1","p0","p1","oc","ax","ay","bx","by","kc","lc","a","_","descending","b","identity","pie","value","sortValues","sort","data","i","n","array","j","k","sum","index","arcs","p","pa","v","Graph","props","$","_c","mainText","radius","colors","subNote","strokeWidth","tooltip","onSeriesMouseOver","onSeriesMouseClick","colorDomain","resetSelectionOnDoubleClick","detailsOnClick","styles","classNames","precision","pieData","_temp","mouseOverData","setMouseOverData","useState","undefined","mouseClickData","setMouseClickData","eventX","setEventX","eventY","setEventY","t2","t3","t4","t5","t6","jsx","jsxs","H2","findIndex","d_1","label","numberFormattingFunction","d_0","size","prefix","suffix","P","t7","d_2","fill","indexOf","length","Colors","gray","opacity","event","clientY","clientX","isEqual","event_0","t8","map","t9","t10","t11","Tooltip","t12","modal","DetailsModal","t13","Fragment","DonutChart","graphTitle","light","categoricalColors","sources","graphDescription","footNote","showColorScale","padding","backgroundColor","graphID","graphDownload","dataDownload","sortData","language","theme","width","height","minHeight","relativeHeight","ariaLabel","colorScaleMaxWidth","graphRadius","setGraphRadius","graphDiv","useRef","graphParentDiv","useEffect","resizeObserver","ResizeObserver","entries","Math","target","clientWidth","clientHeight","Infinity","current","observe","disconnect","sortedData","orderBy","GraphContainer","graphContainer","GraphHeader","title","description","filter","EmptyState","cn","colorLegend","maxWidth","el","fontSize","Spacer","GraphArea","GraphFooter","footnote","source"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4]}
@@ -30,6 +30,7 @@ declare interface ClassNameObject {
30
30
  regLine?: string;
31
31
  dataCards?: string;
32
32
  colorLegend?: string;
33
+ modal?: string;
33
34
  }
34
35
 
35
36
  export declare function DonutChart(props: Props): JSX.Element;
@@ -140,6 +141,7 @@ declare interface StyleObject {
140
141
  mouseOverLine?: React.CSSProperties;
141
142
  regLine?: React.CSSProperties;
142
143
  dataCards?: React.CSSProperties;
144
+ modal?: React.CSSProperties;
143
145
  }
144
146
 
145
147
  export { }