@orderly.network/chart 2.5.3 → 2.6.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.mts CHANGED
@@ -10,7 +10,7 @@ type PnLChartProps = {
10
10
  profit: string;
11
11
  loss: string;
12
12
  };
13
- data: PnLChartDataItem[];
13
+ data: ReadonlyArray<PnLChartDataItem> | PnLChartDataItem[];
14
14
  invisible?: boolean;
15
15
  };
16
16
  declare const PnLBarChart: (props: PnLChartProps) => react_jsx_runtime.JSX.Element;
@@ -52,7 +52,7 @@ type VolChartProps = {
52
52
  colors?: {
53
53
  fill: string;
54
54
  };
55
- data: VolChartDataItem[];
55
+ data: ReadonlyArray<VolChartDataItem> | VolChartDataItem[];
56
56
  tooltip?: VolChartTooltip;
57
57
  className?: string;
58
58
  };
package/dist/index.d.ts CHANGED
@@ -10,7 +10,7 @@ type PnLChartProps = {
10
10
  profit: string;
11
11
  loss: string;
12
12
  };
13
- data: PnLChartDataItem[];
13
+ data: ReadonlyArray<PnLChartDataItem> | PnLChartDataItem[];
14
14
  invisible?: boolean;
15
15
  };
16
16
  declare const PnLBarChart: (props: PnLChartProps) => react_jsx_runtime.JSX.Element;
@@ -52,7 +52,7 @@ type VolChartProps = {
52
52
  colors?: {
53
53
  fill: string;
54
54
  };
55
- data: VolChartDataItem[];
55
+ data: ReadonlyArray<VolChartDataItem> | VolChartDataItem[];
56
56
  tooltip?: VolChartTooltip;
57
57
  className?: string;
58
58
  };
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- 'use strict';var react=require('react'),recharts=require('recharts'),ui=require('@orderly.network/ui'),jsxRuntime=require('react/jsx-runtime'),utils=require('@orderly.network/utils'),i18n=require('@orderly.network/i18n');var N=Object.create;var k=Object.defineProperty;var I=Object.getOwnPropertyDescriptor;var K=Object.getOwnPropertyNames;var $=Object.getPrototypeOf,M=Object.prototype.hasOwnProperty;var g=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var X=(t,e,r,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of K(e))!M.call(t,i)&&i!==r&&k(t,i,{get:()=>e[i],enumerable:!(o=I(e,i))||o.enumerable});return t};var G=(t,e,r)=>(r=t!=null?N($(t)):{},X(!t||!t.__esModule?k(r,"default",{value:t,enumerable:true}):r,t));var O=g(x=>{Object.defineProperty(x,"__esModule",{value:true});Object.defineProperty(x,"default",{enumerable:true,get:function(){return re}});function S(t,e){return {handler:t,config:e}}S.withOptions=function(t,e=()=>({})){let r=function(o){return {__options:o,handler:t(o),config:e(o)}};return r.__isOptionsFunction=true,r.__pluginFunction=t,r.__configFunction=e,r};var re=S;});var A=g(C=>{Object.defineProperty(C,"__esModule",{value:true});Object.defineProperty(C,"default",{enumerable:true,get:function(){return ae}});var oe=ie(O());function ie(t){return t&&t.__esModule?t:{default:t}}var ae=oe.default;});var V=g((rr,R)=>{var b=A();R.exports=(b.__esModule?b:{default:b}).default;});var v=()=>{let t=document.documentElement,e=getComputedStyle(t);return {primary:u(e.getPropertyValue("--oui-color-primary")),primaryLight:u(e.getPropertyValue("--oui-color-primary-light")),secondary:u(e.getPropertyValue("--oui-color-secondary")),success:u(e.getPropertyValue("--oui-color-success")),warning:u(e.getPropertyValue("--oui-color-warning")),danger:u(e.getPropertyValue("--oui-color-danger")),info:u(e.getPropertyValue("--oui-color-info")),loss:u(e.getPropertyValue("--oui-color-trading-loss")),profit:u(e.getPropertyValue("--oui-color-trading-profit"))}},u=t=>`rgb(${t.split(" ").join(",")})`;var f=t=>react.useMemo(()=>{let r=v();return {profit:t?.profit||r.profit,loss:t?.loss||r.loss,primary:r.primary,primaryLight:r.primaryLight}},[t]);var d=t=>{let{label:e,value:r,prefix:o,unit:i="USDC",coloring:a=false,dp:n,rm:c}=t;return jsxRuntime.jsxs(ui.Box,{intensity:600,p:3,r:"md",children:[jsxRuntime.jsxs(ui.Flex,{direction:"row",className:t.titleClassName,children:[o,jsxRuntime.jsx(ui.Text.numeral,{unit:i,as:"div",size:"sm",coloring:a,showIdentifier:a,unitClassName:"oui-text-base-contrast-54 oui-ml-1",weight:"semibold",rm:c,dp:n,children:r})]}),jsxRuntime.jsx(ui.Text,{size:"2xs",intensity:54,weight:"semibold",children:e})]})};var h=t=>{let e=Math.abs(t),r=e===0?0:e<=10?2:e<=100?1:0,o=utils.numberToHumanStyle(e,r);return t<0?`-${o}`:o};var at=t=>{let{fill:e,x:r,y:o,width:i,height:a}=t,n=Math.abs(a);return jsxRuntime.jsx("rect",{rx:2,x:r,y:a>0?o:o+a,width:i,height:n,stroke:"none",fill:e})},nt=t=>{let{x:e,y:r,stroke:o,payload:i,index:a,width:n,containerWidth:c}=t,{t:z}=i18n.useTranslation(),D=a===0?48:c>0?c-10:n+i.offset;return jsxRuntime.jsx("g",{transform:`translate(${D},${r-6})`,children:jsxRuntime.jsx("text",{x:0,y:0,dy:16,textAnchor:a===0?"start":"end",fontSize:10,fill:"rgba(255,255,255,0.54)",children:a===0?i.value:z("chart.now")})})},lt=t=>{let{width:e,height:r,stroke:o,fill:i}=t;return jsxRuntime.jsx(recharts.Cross,{x:t.x+t.width/2,top:t.top,height:r,width:1,stroke:"rgba(255,255,255,0.16)",strokeDasharray:"3 2",fill:"none"})},st=t=>{let{active:e,payload:r,label:o}=t,i=react.useRef(new Date().toISOString().split("T")[0]),{t:a}=i18n.useTranslation();return e&&r&&r.length?jsxRuntime.jsx(d,{label:o===i.current?a("chart.now"):o,value:r[0].value,coloring:true}):null},ct=t=>{let{invisible:e}=t,r=f(t.colors),o=react.useRef(0);return jsxRuntime.jsx(recharts.ResponsiveContainer,{className:ui.cn(e&&"chart-invisible"),onResize:(i,a)=>{o.current=i;},children:jsxRuntime.jsxs(recharts.BarChart,{data:t.data,margin:{left:-10,top:10,right:10,bottom:30},children:[!e&&jsxRuntime.jsx(recharts.Tooltip,{cursor:jsxRuntime.jsx(lt,{}),content:jsxRuntime.jsx(st,{})}),jsxRuntime.jsx(recharts.CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.ReferenceLine,{y:0,stroke:"rgba(0,0,0,0.04)"}),!e&&jsxRuntime.jsx(recharts.Bar,{dataKey:"pnl",shape:jsxRuntime.jsx(at,{}),children:t.data.map((i,a)=>jsxRuntime.jsx(recharts.Cell,{fill:i.pnl>0?r.profit:r.loss},`cell-${a}`))}),jsxRuntime.jsx(recharts.YAxis,{tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickFormatter:i=>h(i),tickLine:false,axisLine:false,dataKey:"pnl"}),jsxRuntime.jsx(recharts.XAxis,{dataKey:"date",tickLine:false,interval:t.data.length-2,height:1,tick:jsxRuntime.jsx(nt,{containerWidth:o.current}),stroke:"#FFFFFF",strokeOpacity:.04})]})})};var y=t=>{let{x:e,y:r,stroke:o,payload:i,index:a}=t,{t:n}=i18n.useTranslation();return jsxRuntime.jsx("g",{transform:`translate(${e},${r-6})`,children:jsxRuntime.jsx("text",{x:0,y:0,dy:16,textAnchor:"end",fontSize:10,fill:"rgba(255,255,255,0.54)",children:a===0?i.value:n("chart.now")})})};var vt=t=>{let{active:e,payload:r,label:o}=t,i=react.useRef(new Date().toISOString().split("T")[0]),{t:a}=i18n.useTranslation();return e&&r&&r.length?jsxRuntime.jsx(d,{label:o===i.current?a("chart.now"):o,value:r[0].value,coloring:true}):null},Ft=t=>{let e=f(t.colors),r=i=>{let a=[];return i?.reduce((n,c)=>(n+=c.pnl,a.push({...c,pnl:n,_pnl:c.pnl}),n),0),a},o=react.useMemo(()=>r(t.data),[t.data]);return jsxRuntime.jsx(recharts.ResponsiveContainer,{className:t.invisible?"chart-invisible":"",children:jsxRuntime.jsxs(recharts.LineChart,{data:o,margin:{top:20,right:10,left:-10,bottom:0},children:[jsxRuntime.jsx(recharts.CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.XAxis,{dataKey:"date",interval:t.data.length-2,tick:jsxRuntime.jsx(y,{}),stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.YAxis,{dataKey:"pnl",tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,tickFormatter:i=>h(i)}),!t.invisible&&jsxRuntime.jsx(recharts.Tooltip,{cursor:{strokeDasharray:"3 2",strokeOpacity:.16},content:jsxRuntime.jsx(vt,{})}),!t.invisible&&jsxRuntime.jsx(recharts.Line,{type:"natural",dataKey:"pnl",stroke:e.primary,strokeWidth:2,dot:false,isAnimationActive:false})]})})};var Bt=t=>{let{active:e,payload:r,label:o}=t,i=react.useRef(new Date().toISOString().split("T")[0]),{t:a}=i18n.useTranslation();return e&&r&&r.length?jsxRuntime.jsx(d,{label:o===i.current?a("chart.now"):o,value:r[0].value}):null},zt=t=>{let e=f(t.colors);return jsxRuntime.jsx(recharts.ResponsiveContainer,{className:t.invisible?"chart-invisible":"",children:jsxRuntime.jsxs(recharts.LineChart,{width:530,height:180,data:t.data,margin:{top:20,right:10,left:-20,bottom:-10},children:[jsxRuntime.jsx(recharts.CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.XAxis,{dataKey:"date",interval:t.data.length-2,tick:jsxRuntime.jsx(y,{}),stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.YAxis,{dataKey:"account_value",tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,tickFormatter:r=>h(r)}),!t.invisible&&jsxRuntime.jsx(recharts.Tooltip,{cursor:{strokeDasharray:"3 2",strokeOpacity:.16},content:jsxRuntime.jsx(Bt,{})}),!t.invisible&&jsxRuntime.jsx(recharts.Line,{type:"natural",dataKey:"account_value",stroke:e.profit,strokeWidth:2,dot:false,isAnimationActive:false})]})})};var Qt=t=>{let{fill:e,x:r,y:o,width:i,height:a,opacity:n}=t,c=Math.abs(a);return jsxRuntime.jsx("rect",{rx:2,x:r,y:a>0?o:o+a,width:i,height:c,stroke:"none",fill:e,opacity:n})},Ut=t=>{let{width:e,height:r,payload:o,stroke:i,fill:a}=t;return o?.[0]?.value===0?null:jsxRuntime.jsx(recharts.Cross,{x:t.x+t.width/2,top:t.top,height:r,width:1,stroke:"rgba(255,255,255,0.16)",strokeDasharray:"3 2",fill:"none"})},Jt=t=>{let{active:e,payload:r,label:o,tooltip:i}=t;return r?.[0]?.value===0?null:e&&r&&r.length?jsxRuntime.jsx(d,{label:o,value:r[0].value,titleClassName:"oui-gap-4",rm:i?.rm,dp:i?.dp}):null},Zt=t=>{let e=f(t.colors?.fill?{profit:t.colors?.fill,loss:t.colors?.fill}:void 0),r=t.data.reduce((a,n)=>a+n.volume,0)===0,o=t.data.reduce((a,n)=>a>n.volume?a:n.volume,0),i=o<=10?2:o<=100?1:0;return jsxRuntime.jsx(ui.Box,{className:ui.cn(t.className),children:jsxRuntime.jsx(recharts.ResponsiveContainer,{children:jsxRuntime.jsxs(recharts.BarChart,{data:t.data,margin:{left:-0,top:6,right:0,bottom:20},children:[jsxRuntime.jsx(recharts.Tooltip,{cursor:jsxRuntime.jsx(Ut,{}),content:jsxRuntime.jsx(Jt,{tooltip:t.tooltip})}),jsxRuntime.jsx(recharts.CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.08,repeatCount:6}),jsxRuntime.jsx(recharts.ReferenceLine,{y:0,stroke:"#000"}),jsxRuntime.jsx(recharts.Bar,{dataKey:"volume",shape:jsxRuntime.jsx(Qt,{}),minPointSize:1,children:t.data.map((a,n)=>jsxRuntime.jsx(recharts.Cell,{fill:a.volume>0?e.profit:e.loss,opacity:a.opacity},`cell-${n}`))}),jsxRuntime.jsx(recharts.YAxis,{tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,dataKey:"volume",tickFormatter:(a,n)=>r?`${n*100}`:jt(a,i),width:45}),jsxRuntime.jsx(recharts.XAxis,{dataKey:"date",tickLine:false,interval:t.data.length-2,height:1,tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},stroke:"rgb(229, 231, 235)",strokeOpacity:.2})]})})})};function jt(t,e=0){let r=["","K","M","B","T"],o=0;for(;t>=1e3&&o<r.length-1;)t/=1e3,o++;return `${te(t,e)}${r[o]}`}function te(t,e){let r=t.toString(),o=r.indexOf(".");if(o===-1||e===0)return r.split(".")[0];let i=o+e+1;return r.slice(0,i)}var B=G(V()),ne=()=>(0, B.default)(function({addComponents:t,addBase:e}){t({".xAxis":{".recharts-cartesian-axis-tick:first-child text":{"text-anchor":"start"},".recharts-cartesian-axis-tick:last-child text":{"text-anchor":"end"}}},{respectPrefix:false});});exports.AssetLineChart=zt;exports.PnLBarChart=ct;exports.PnlLineChart=Ft;exports.VolBarChart=Zt;exports.chartPlugin=ne;//# sourceMappingURL=index.js.map
1
+ 'use strict';var react=require('react'),recharts=require('recharts'),i18n=require('@orderly.network/i18n'),ui=require('@orderly.network/ui'),utils=require('@orderly.network/utils'),jsxRuntime=require('react/jsx-runtime');var I=Object.create;var k=Object.defineProperty;var N=Object.getOwnPropertyDescriptor;var K=Object.getOwnPropertyNames;var $=Object.getPrototypeOf,M=Object.prototype.hasOwnProperty;var g=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var X=(t,e,r,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of K(e))!M.call(t,a)&&a!==r&&k(t,a,{get:()=>e[a],enumerable:!(o=N(e,a))||o.enumerable});return t};var G=(t,e,r)=>(r=t!=null?I($(t)):{},X(!t||!t.__esModule?k(r,"default",{value:t,enumerable:true}):r,t));var A=g(x=>{Object.defineProperty(x,"__esModule",{value:true});Object.defineProperty(x,"default",{enumerable:true,get:function(){return re}});function S(t,e){return {handler:t,config:e}}S.withOptions=function(t,e=()=>({})){let r=function(o){return {__options:o,handler:t(o),config:e(o)}};return r.__isOptionsFunction=true,r.__pluginFunction=t,r.__configFunction=e,r};var re=S;});var O=g(C=>{Object.defineProperty(C,"__esModule",{value:true});Object.defineProperty(C,"default",{enumerable:true,get:function(){return ie}});var oe=ae(A());function ae(t){return t&&t.__esModule?t:{default:t}}var ie=oe.default;});var V=g((rr,R)=>{var b=O();R.exports=(b.__esModule?b:{default:b}).default;});var h=t=>{let e=Math.abs(t),r=e===0?0:e<=10?2:e<=100?1:0,o=utils.numberToHumanStyle(e,r);return t<0?`-${o}`:o};var f=t=>{let{label:e,value:r,prefix:o,unit:a="USDC",coloring:i=false,dp:n,rm:c}=t;return jsxRuntime.jsxs(ui.Box,{intensity:600,p:3,r:"md",children:[jsxRuntime.jsxs(ui.Flex,{direction:"row",className:t.titleClassName,children:[o,jsxRuntime.jsx(ui.Text.numeral,{unit:a,as:"div",size:"sm",coloring:i,showIdentifier:i,unitClassName:"oui-text-base-contrast-54 oui-ml-1",weight:"semibold",rm:c,dp:n,children:r})]}),jsxRuntime.jsx(ui.Text,{size:"2xs",intensity:54,weight:"semibold",children:e})]})};var T=()=>{let t=document.documentElement,e=getComputedStyle(t);return {primary:u(e.getPropertyValue("--oui-color-primary")),primaryLight:u(e.getPropertyValue("--oui-color-primary-light")),secondary:u(e.getPropertyValue("--oui-color-secondary")),success:u(e.getPropertyValue("--oui-color-success")),warning:u(e.getPropertyValue("--oui-color-warning")),danger:u(e.getPropertyValue("--oui-color-danger")),info:u(e.getPropertyValue("--oui-color-info")),loss:u(e.getPropertyValue("--oui-color-trading-loss")),profit:u(e.getPropertyValue("--oui-color-trading-profit"))}},u=t=>`rgb(${t.split(" ").join(",")})`;var d=t=>react.useMemo(()=>{let r=T();return {profit:t?.profit||r.profit,loss:t?.loss||r.loss,primary:r.primary,primaryLight:r.primaryLight}},[t]);var it=t=>{let{fill:e,x:r,y:o,width:a,height:i}=t,n=Math.abs(i);return jsxRuntime.jsx("rect",{rx:2,x:r,y:i>0?o:o+i,width:a,height:n,stroke:"none",fill:e})},nt=t=>{let{x:e,y:r,stroke:o,payload:a,index:i,width:n,containerWidth:c}=t,{t:D}=i18n.useTranslation(),z=i===0?48:c>0?c-10:n+a.offset;return jsxRuntime.jsx("g",{transform:`translate(${z},${r-6})`,children:jsxRuntime.jsx("text",{x:0,y:0,dy:16,textAnchor:i===0?"start":"end",fontSize:10,fill:"rgba(255,255,255,0.54)",children:i===0?a.value:D("chart.now")})})},lt=t=>{let{width:e,height:r,stroke:o,fill:a}=t;return jsxRuntime.jsx(recharts.Cross,{x:t.x+t.width/2,top:t.top,height:r,width:1,stroke:"rgba(255,255,255,0.16)",strokeDasharray:"3 2",fill:"none"})},st=t=>{let{active:e,payload:r,label:o}=t,a=react.useRef(new Date().toISOString().split("T")[0]),{t:i}=i18n.useTranslation();return e&&r&&r.length?jsxRuntime.jsx(f,{label:o===a.current?i("chart.now"):o,value:r[0].value,coloring:true}):null},ct=t=>{let{invisible:e}=t,r=d(t.colors),o=react.useRef(0);return jsxRuntime.jsx(recharts.ResponsiveContainer,{className:ui.cn(e&&"chart-invisible"),onResize:(a,i)=>{o.current=a;},children:jsxRuntime.jsxs(recharts.BarChart,{data:t.data,margin:{left:-10,top:10,right:10,bottom:30},children:[!e&&jsxRuntime.jsx(recharts.Tooltip,{cursor:jsxRuntime.jsx(lt,{}),content:jsxRuntime.jsx(st,{})}),jsxRuntime.jsx(recharts.CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.ReferenceLine,{y:0,stroke:"rgba(0,0,0,0.04)"}),!e&&jsxRuntime.jsx(recharts.Bar,{dataKey:"pnl",shape:jsxRuntime.jsx(it,{}),children:t.data.map((a,i)=>jsxRuntime.jsx(recharts.Cell,{fill:a.pnl>0?r.profit:r.loss},`cell-${i}`))}),jsxRuntime.jsx(recharts.YAxis,{tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickFormatter:a=>h(a),tickLine:false,axisLine:false,dataKey:"pnl"}),jsxRuntime.jsx(recharts.XAxis,{dataKey:"date",tickLine:false,interval:t.data.length-2,height:1,tick:jsxRuntime.jsx(nt,{containerWidth:o.current}),stroke:"#FFFFFF",strokeOpacity:.04})]})})};var y=t=>{let{x:e,y:r,stroke:o,payload:a,index:i}=t,{t:n}=i18n.useTranslation();return jsxRuntime.jsx("g",{transform:`translate(${e},${r-6})`,children:jsxRuntime.jsx("text",{x:0,y:0,dy:16,textAnchor:"end",fontSize:10,fill:"rgba(255,255,255,0.54)",children:i===0?a.value:n("chart.now")})})};var vt=t=>{let{active:e,payload:r,label:o}=t,a=react.useRef(new Date().toISOString().split("T")[0]),{t:i}=i18n.useTranslation();return e&&r&&r.length?jsxRuntime.jsx(f,{label:o===a.current?i("chart.now"):o,value:r[0].value,coloring:true}):null},Ft=t=>{let e=d(t.colors),r=a=>{let i=[];return a?.reduce((n,c)=>(n+=c.pnl,i.push({...c,pnl:n,_pnl:c.pnl}),n),0),i},o=react.useMemo(()=>r(t.data),[t.data]);return jsxRuntime.jsx(recharts.ResponsiveContainer,{className:t.invisible?"chart-invisible":"",children:jsxRuntime.jsxs(recharts.LineChart,{data:o,margin:{top:20,right:10,left:-10,bottom:0},children:[jsxRuntime.jsx(recharts.CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.XAxis,{dataKey:"date",interval:t.data.length-2,tick:jsxRuntime.jsx(y,{}),stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.YAxis,{dataKey:"pnl",tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,tickFormatter:a=>h(a)}),!t.invisible&&jsxRuntime.jsx(recharts.Tooltip,{cursor:{strokeDasharray:"3 2",strokeOpacity:.16},content:jsxRuntime.jsx(vt,{})}),!t.invisible&&jsxRuntime.jsx(recharts.Line,{type:"natural",dataKey:"pnl",stroke:e.primary,strokeWidth:2,dot:false,isAnimationActive:false})]})})};var Bt=t=>{let{active:e,payload:r,label:o}=t,a=react.useRef(new Date().toISOString().split("T")[0]),{t:i}=i18n.useTranslation();return e&&r&&r.length?jsxRuntime.jsx(f,{label:o===a.current?i("chart.now"):o,value:r[0].value}):null},Dt=t=>{let e=d(t.colors);return jsxRuntime.jsx(recharts.ResponsiveContainer,{className:t.invisible?"chart-invisible":"",children:jsxRuntime.jsxs(recharts.LineChart,{width:530,height:180,data:t.data,margin:{top:20,right:10,left:-20,bottom:-10},children:[jsxRuntime.jsx(recharts.CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.XAxis,{dataKey:"date",interval:t.data.length-2,tick:jsxRuntime.jsx(y,{}),stroke:"#FFFFFF",strokeOpacity:.04}),jsxRuntime.jsx(recharts.YAxis,{dataKey:"account_value",tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,tickFormatter:r=>h(r)}),!t.invisible&&jsxRuntime.jsx(recharts.Tooltip,{cursor:{strokeDasharray:"3 2",strokeOpacity:.16},content:jsxRuntime.jsx(Bt,{})}),!t.invisible&&jsxRuntime.jsx(recharts.Line,{type:"natural",dataKey:"account_value",stroke:e.profit,strokeWidth:2,dot:false,isAnimationActive:false})]})})};var Qt=t=>{let{fill:e,x:r,y:o,width:a,height:i,opacity:n}=t,c=Math.abs(i);return jsxRuntime.jsx("rect",{rx:2,x:r,y:i>0?o:o+i,width:a,height:c,stroke:"none",fill:e,opacity:n})},Ut=t=>{let{width:e,height:r,payload:o,stroke:a,fill:i}=t;return o?.[0]?.value===0?null:jsxRuntime.jsx(recharts.Cross,{x:t.x+t.width/2,top:t.top,height:r,width:1,stroke:"rgba(255,255,255,0.16)",strokeDasharray:"3 2",fill:"none"})},Jt=t=>{let{active:e,payload:r,label:o,tooltip:a}=t;return r?.[0]?.value===0?null:e&&r&&r.length?jsxRuntime.jsx(f,{label:o,value:r[0].value,titleClassName:"oui-gap-4",rm:a?.rm,dp:a?.dp}):null},Zt=t=>{let e=d(t.colors?.fill?{profit:t.colors?.fill,loss:t.colors?.fill}:void 0),r=t.data?.reduce((i,n)=>i+n.volume,0)===0,o=t.data?.reduce((i,n)=>i>n.volume?i:n.volume,0),a=o<=10?2:o<=100?1:0;return jsxRuntime.jsx(ui.Box,{className:ui.cn(t.className),children:jsxRuntime.jsx(recharts.ResponsiveContainer,{children:jsxRuntime.jsxs(recharts.BarChart,{data:t.data,margin:{left:-0,top:6,right:0,bottom:20},children:[jsxRuntime.jsx(recharts.Tooltip,{cursor:jsxRuntime.jsx(Ut,{}),content:jsxRuntime.jsx(Jt,{tooltip:t.tooltip})}),jsxRuntime.jsx(recharts.CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.08,repeatCount:6}),jsxRuntime.jsx(recharts.ReferenceLine,{y:0,stroke:"#000"}),jsxRuntime.jsx(recharts.Bar,{dataKey:"volume",shape:jsxRuntime.jsx(Qt,{}),minPointSize:1,children:t.data.map((i,n)=>jsxRuntime.jsx(recharts.Cell,{fill:i.volume>0?e.profit:e.loss,opacity:i.opacity},`cell-${n}`))}),jsxRuntime.jsx(recharts.YAxis,{tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,dataKey:"volume",tickFormatter:(i,n)=>r?`${n*100}`:jt(i,a),width:45}),jsxRuntime.jsx(recharts.XAxis,{dataKey:"date",tickLine:false,interval:t.data.length-2,height:1,tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},stroke:"rgb(229, 231, 235)",strokeOpacity:.2})]})})})};function jt(t,e=0){let r=["","K","M","B","T"],o=0;for(;t>=1e3&&o<r.length-1;)t/=1e3,o++;return `${te(t,e)}${r[o]}`}function te(t,e){let r=t.toString(),o=r.indexOf(".");if(o===-1||e===0)return r.split(".")[0];let a=o+e+1;return r.slice(0,a)}var B=G(V()),ne=()=>(0, B.default)(function({addComponents:t,addBase:e}){t({".xAxis":{".recharts-cartesian-axis-tick:first-child text":{"text-anchor":"start"},".recharts-cartesian-axis-tick:last-child text":{"text-anchor":"end"}}},{respectPrefix:false});});exports.AssetLineChart=Dt;exports.PnLBarChart=ct;exports.PnlLineChart=Ft;exports.VolBarChart=Zt;exports.chartPlugin=ne;//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2/node_modules/tailwindcss/lib/util/createPlugin.js","../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2/node_modules/tailwindcss/lib/public/create-plugin.js","../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2/node_modules/tailwindcss/plugin.js","../src/utils/theme.ts","../src/orderly/useColors.ts","../src/orderly/customTooltip.tsx","../src/utils/yTickFormatter.ts","../src/orderly/pnlBar.tsx","../src/orderly/xAxisLabel.tsx","../src/orderly/pnlLine.tsx","../src/orderly/assetLine.tsx","../src/orderly/volBar.tsx","../src/tailwindcss/theme.ts"],"names":["require_createPlugin","__commonJSMin","exports","_default","createPlugin","plugin","config","pluginFunction","configFunction","optionsFunction","options","require_create_plugin","_createPlugin","_interop_require_default","obj","require_plugin","module","getThemeColors","root","computedStyle","convertToRGB","color","useColors","colors","useMemo","themeColors","OrderlyChartTooltip","props","label","value","prefix","unit","coloring","dp","rm","jsxs","Box","Flex","jsx","Text","tickFormatter","absValue","formatted","numberToHumanStyle","RoundedRectangle","fill","x","y","width","height","absHeight","XAxisLabel","stroke","payload","index","containerWidth","t","useTranslation","_x","CustomizedCross","Cross","CustomTooltip","active","todayStr","useRef","PnLBarChart","invisible","widthRef","ResponsiveContainer","cn","BarChart","Tooltip","CartesianGrid","ReferenceLine","Bar","entry","Cell","YAxis","XAxis","PnlLineChart","dataTransfer","data","series","acc","item","LineChart","Line","AssetLineChart","opacity","tooltip","VolBarChart","isEmpty","b","maxVolume","decimal","number","decimalPlaces","abbreviations","toFixedWithoutRounding","num","fix","numStr","decimalIndex","cutoffIndex","import_plugin","chartPlugin","addComponents","addBase"],"mappings":"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","file":"index.js","sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function() {\n return _default;\n }\n});\nfunction createPlugin(plugin, config) {\n return {\n handler: plugin,\n config\n };\n}\ncreatePlugin.withOptions = function(pluginFunction, configFunction = ()=>({})) {\n const optionsFunction = function(options) {\n return {\n __options: options,\n handler: pluginFunction(options),\n config: configFunction(options)\n };\n };\n optionsFunction.__isOptionsFunction = true;\n // Expose plugin dependencies so that `object-hash` returns a different\n // value if anything here changes, to ensure a rebuild is triggered.\n optionsFunction.__pluginFunction = pluginFunction;\n optionsFunction.__configFunction = configFunction;\n return optionsFunction;\n};\nconst _default = createPlugin;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function() {\n return _default;\n }\n});\nconst _createPlugin = /*#__PURE__*/ _interop_require_default(require(\"../util/createPlugin\"));\nfunction _interop_require_default(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nconst _default = _createPlugin.default;\n","let createPlugin = require('./lib/public/create-plugin')\nmodule.exports = (createPlugin.__esModule ? createPlugin : { default: createPlugin }).default\n","export const getThemeColors = () => {\n const root = document.documentElement;\n const computedStyle = getComputedStyle(root);\n\n const colors = {\n primary: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-primary\")\n ),\n primaryLight: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-primary-light\")\n ),\n secondary: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-secondary\")\n ),\n success: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-success\")\n ),\n warning: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-warning\")\n ),\n danger: convertToRGB(computedStyle.getPropertyValue(\"--oui-color-danger\")),\n info: convertToRGB(computedStyle.getPropertyValue(\"--oui-color-info\")),\n loss: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-trading-loss\")\n ),\n profit: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-trading-profit\")\n ),\n };\n\n return colors;\n};\n\nconst convertToRGB = (color: string) => {\n return `rgb(${color.split(\" \").join(\",\")})`;\n};\n","import { useMemo } from \"react\";\nimport { getThemeColors } from \"../utils/theme\";\n\nexport const useColors = (colors?: { profit: string; loss: string }) => {\n const _colors = useMemo(() => {\n const themeColors = getThemeColors();\n return {\n profit: colors?.profit || themeColors.profit,\n loss: colors?.loss || themeColors.loss,\n primary: themeColors.primary,\n primaryLight: themeColors.primaryLight,\n };\n }, [colors]);\n\n return _colors;\n};\n","import { Box, Flex, Text } from \"@orderly.network/ui\";\n\nexport const OrderlyChartTooltip = (props: {\n label: string;\n value: string | number;\n unit?: string;\n prefix?: React.ReactNode;\n titleClassName?: string;\n coloring?: boolean;\n dp?: number;\n rm?: number;\n}) => {\n const {\n label,\n value,\n prefix,\n unit = \"USDC\",\n coloring = false,\n dp,\n rm,\n } = props;\n return (\n <Box intensity={600} p={3} r=\"md\">\n <Flex direction={\"row\"} className={props.titleClassName}>\n {prefix}\n <Text.numeral\n unit={unit}\n as=\"div\"\n size=\"sm\"\n coloring={coloring}\n showIdentifier={coloring}\n unitClassName=\"oui-text-base-contrast-54 oui-ml-1\"\n weight=\"semibold\"\n rm={rm}\n dp={dp}\n >\n {value}\n </Text.numeral>\n </Flex>\n <Text size=\"2xs\" intensity={54} weight=\"semibold\">\n {label}\n </Text>\n </Box>\n );\n};\n","import { numberToHumanStyle } from \"@orderly.network/utils\";\n\nexport const tickFormatter = (value: number) => {\n let absValue = Math.abs(value);\n const dp = absValue === 0 ? 0 : absValue <= 10 ? 2 : absValue <= 100 ? 1 : 0;\n\n const formatted = numberToHumanStyle(absValue, dp);\n return value < 0 ? `-${formatted}` : formatted;\n};\n","import { useColors } from \"./useColors\";\nimport {\n BarChart,\n XAxis,\n YAxis,\n ResponsiveContainer,\n Bar,\n Cell,\n Tooltip,\n CartesianGrid,\n ReferenceLine,\n Cross,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { cn } from \"@orderly.network/ui\";\nimport { useRef } from \"react\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type PnLChartDataItem = {\n date: string;\n pnl: number;\n};\n\nexport type PnLChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: PnLChartDataItem[];\n invisible?: boolean;\n};\n\nconst RoundedRectangle = (props: any) => {\n const { fill, x, y, width, height } = props;\n\n const absHeight = Math.abs(height);\n\n return (\n <rect\n rx={2}\n x={x}\n y={height > 0 ? y : y + height}\n width={width}\n height={absHeight}\n stroke=\"none\"\n fill={fill}\n />\n );\n};\n\nexport const XAxisLabel = (props: any) => {\n const { x, y, stroke, payload, index, width, containerWidth } = props;\n const { t } = useTranslation();\n const _x =\n index === 0\n ? 48\n : containerWidth > 0\n ? containerWidth - 10\n : width + payload.offset;\n\n return (\n <g transform={`translate(${_x},${y - 6})`}>\n <text\n x={0}\n y={0}\n dy={16}\n textAnchor={index === 0 ? \"start\" : \"end\"}\n // textAnchor={\"start\"}\n fontSize={10}\n fill={\"rgba(255,255,255,0.54)\"}\n >\n {index === 0 ? payload.value : t(\"chart.now\")}\n </text>\n </g>\n );\n};\n\nconst CustomizedCross = (props: any) => {\n const { width, height, stroke, fill } = props;\n\n return (\n // @ts-ignore\n <Cross\n // y={props.y + props.top}\n x={props.x + props.width / 2}\n top={props.top}\n height={height}\n width={1}\n stroke={\"rgba(255,255,255,0.16)\"}\n strokeDasharray={\"3 2\"}\n fill={\"none\"}\n />\n );\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n coloring\n />\n );\n }\n\n return null;\n};\n\nexport const PnLBarChart = (props: PnLChartProps) => {\n const { invisible } = props;\n const colors = useColors(props.colors);\n const widthRef = useRef(0);\n\n return (\n // @ts-ignore\n <ResponsiveContainer\n className={cn(invisible && \"chart-invisible\")}\n onResize={(width, height) => {\n // console.log(\"width\", width, height);\n widthRef.current = width;\n }}\n >\n {/* @ts-ignore */}\n <BarChart\n data={props.data}\n margin={{ left: -10, top: 10, right: 10, bottom: 30 }}\n >\n {!invisible && (\n // @ts-ignore\n <Tooltip\n // cursor={{ fillOpacity: 0.1 }}\n cursor={<CustomizedCross />}\n content={<CustomTooltip />}\n />\n )}\n\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <ReferenceLine y={0} stroke=\"rgba(0,0,0,0.04)\" />\n {/* @ts-ignore */}\n\n {!invisible && (\n // @ts-ignore\n <Bar dataKey=\"pnl\" shape={<RoundedRectangle />}>\n {props.data.map((entry, index) => {\n return (\n // @ts-ignore\n <Cell\n key={`cell-${index}`}\n fill={entry.pnl > 0 ? colors.profit : colors.loss}\n />\n );\n })}\n </Bar>\n )}\n {/* @ts-ignore */}\n <YAxis\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickFormatter={(value) => tickFormatter(value)}\n tickLine={false}\n axisLine={false}\n dataKey={\"pnl\"}\n />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n // axisLine={false}\n tickLine={false}\n interval={props.data.length - 2}\n // tick={renderQuarterTick}\n height={1}\n // scale=\"time\"\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel containerWidth={widthRef.current} />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n />\n </BarChart>\n </ResponsiveContainer>\n );\n};\n","import { useTranslation } from \"@orderly.network/i18n\";\n\nexport const XAxisLabel = (props: any) => {\n const { x, y, stroke, payload, index } = props;\n const { t } = useTranslation();\n return (\n <g transform={`translate(${x},${y - 6})`}>\n <text\n x={0}\n y={0}\n dy={16}\n textAnchor=\"end\"\n fontSize={10}\n fill={\"rgba(255,255,255,0.54)\"}\n >\n {index === 0 ? payload.value : t(\"chart.now\")}\n </text>\n </g>\n );\n};\n","import { useMemo, useRef } from \"react\";\nimport { getThemeColors } from \"../utils/theme\";\nimport { useColors } from \"./useColors\";\n// import { Line } from \"../line/line\";\nimport {\n LineChart,\n XAxis,\n YAxis,\n Line,\n CartesianGrid,\n ReferenceLine,\n Tooltip,\n ResponsiveContainer,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { XAxisLabel } from \"./xAxisLabel\";\nimport { numberToHumanStyle } from \"@orderly.network/utils\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type PnlLineChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: any;\n invisible?: boolean;\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n coloring\n />\n );\n }\n\n return null;\n};\n\nconst PnlLineChart = (props: PnlLineChartProps) => {\n const colors = useColors(props.colors);\n\n const dataTransfer = (data: any[]) => {\n const series: any[] = [];\n\n data?.reduce((acc, item) => {\n acc += item.pnl;\n series.push({\n ...item,\n pnl: acc,\n _pnl: item.pnl,\n // date: new Date(item.date).getTime(),\n });\n return acc;\n }, 0);\n\n return series;\n };\n\n const data = useMemo(() => dataTransfer(props.data), [props.data]);\n\n return (\n // @ts-ignore\n <ResponsiveContainer className={props.invisible ? \"chart-invisible\" : \"\"}>\n {/* @ts-ignore */}\n <LineChart\n data={data}\n margin={{ top: 20, right: 10, left: -10, bottom: 0 }}\n >\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n interval={props.data.length - 2}\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n // scale={\"time\"}\n // type=\"number\"\n // range={}\n />\n {/* @ts-ignore */}\n <YAxis\n dataKey=\"pnl\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n tickFormatter={(value) => tickFormatter(value)}\n />\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Tooltip\n cursor={{ strokeDasharray: \"3 2\", strokeOpacity: 0.16 }}\n content={<CustomTooltip />}\n />\n )}\n\n {/* <ReferenceLine y={0} stroke=\"#000\" /> */}\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Line\n type=\"natural\"\n dataKey=\"pnl\"\n stroke={colors.primary}\n strokeWidth={2}\n dot={false}\n isAnimationActive={false}\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n );\n};\n\nexport { PnlLineChart };\n","import { useColors } from \"./useColors\";\n// import { Line } from \"../line/line\";\nimport {\n LineChart,\n XAxis,\n YAxis,\n Line,\n CartesianGrid,\n Tooltip,\n ResponsiveContainer,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { XAxisLabel } from \"./xAxisLabel\";\nimport { useRef } from \"react\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type AssetChartDataItem = {\n date: string;\n account_value: number;\n};\n\nexport type PnlLineChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: AssetChartDataItem[];\n invisible?: boolean;\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n />\n );\n }\n\n return null;\n};\n\nconst AssetLineChart = (props: PnlLineChartProps) => {\n const colors = useColors(props.colors);\n\n // const dataTransfer = (data: any[]) => {\n // const series: any[] = [];\n\n // data.reduce((acc, item) => {\n // acc += item.pnl;\n // series.push({ ...item, pnl: acc, _pnl: item.pnl });\n // return acc;\n // }, 0);\n\n // return series;\n // };\n\n // const data = useMemo(() => dataTransfer(props.data), [props.data]);\n\n return (\n // @ts-ignore\n <ResponsiveContainer className={props.invisible ? \"chart-invisible\" : \"\"}>\n {/* @ts-ignore */}\n <LineChart\n width={530}\n height={180}\n data={props.data}\n margin={{ top: 20, right: 10, left: -20, bottom: -10 }}\n >\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n interval={props.data.length - 2}\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n ></XAxis>\n {/* @ts-ignore */}\n <YAxis\n dataKey=\"account_value\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n tickFormatter={(value) => tickFormatter(value)}\n />\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Tooltip\n cursor={{ strokeDasharray: \"3 2\", strokeOpacity: 0.16 }}\n content={<CustomTooltip />}\n />\n )}\n\n {/* <Legend /> */}\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Line\n type=\"natural\"\n dataKey=\"account_value\"\n stroke={colors.profit}\n strokeWidth={2}\n dot={false}\n isAnimationActive={false}\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n );\n};\n\nexport { AssetLineChart };\n","import { useColors } from \"./useColors\";\nimport {\n BarChart,\n XAxis,\n YAxis,\n ResponsiveContainer,\n Bar,\n Cell,\n Tooltip,\n CartesianGrid,\n ReferenceLine,\n Cross,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { Box, cn } from \"@orderly.network/ui\";\n\nexport type VolChartDataItem = {\n date: string;\n volume: number;\n opacity?: string | number;\n};\n\nexport type VolChartTooltip = {\n rm?: number;\n dp?: number;\n};\n\nexport type VolChartProps = {\n colors?: {\n fill: string;\n };\n data: VolChartDataItem[];\n tooltip?: VolChartTooltip;\n className?: string;\n};\n\nconst RoundedRectangle = (props: any) => {\n const { fill, x, y, width, height, opacity } = props;\n const absHeight = Math.abs(height);\n\n return (\n <rect\n rx={2}\n x={x}\n y={height > 0 ? y : y + height}\n width={width}\n height={absHeight}\n stroke=\"none\"\n fill={fill}\n opacity={opacity}\n />\n );\n};\n\nconst CustomizedCross = (props: any) => {\n const { width, height, payload, stroke, fill } = props;\n\n if (payload?.[0]?.value === 0) return null;\n\n return (\n // @ts-ignore\n <Cross\n // y={props.y + props.top}\n x={props.x + props.width / 2}\n top={props.top}\n height={height}\n width={1}\n stroke={\"rgba(255,255,255,0.16)\"}\n strokeDasharray={\"3 2\"}\n fill={\"none\"}\n />\n );\n};\n\nconst CustomTooltip = (\n props: TooltipProps<any, any> & { tooltip?: VolChartTooltip }\n) => {\n const { active, payload, label, tooltip } = props;\n\n if (payload?.[0]?.value === 0) return null;\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label}\n value={payload[0].value}\n // prefix=\"Commission\"\n titleClassName=\"oui-gap-4\"\n rm={tooltip?.rm}\n dp={tooltip?.dp}\n />\n );\n }\n\n return null;\n};\n\nexport const VolBarChart = (props: VolChartProps) => {\n const colors = useColors(\n props.colors?.fill\n ? { profit: props.colors?.fill, loss: props.colors?.fill }\n : undefined\n );\n\n const isEmpty = props.data.reduce((a, b) => a + b.volume, 0) === 0;\n const maxVolume = props.data.reduce((a,b) => (a > b.volume ? a : b.volume), 0);\n const decimal = maxVolume <= 10 ? 2 : (maxVolume <= 100 ? 1 : 0);\n\n return (\n // @ts-ignore\n <Box className={cn(props.className)}>\n {/* @ts-ignore */}\n <ResponsiveContainer>\n {/* @ts-ignore */}\n <BarChart\n data={props.data}\n margin={{ left: -0, top: 6, right: 0, bottom: 20 }}\n >\n {/* @ts-ignore */}\n <Tooltip\n // cursor={{ fillOpacity: 0.1 }}\n cursor={<CustomizedCross />}\n content={<CustomTooltip tooltip={props.tooltip} />}\n />\n <CartesianGrid\n vertical={false}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.08}\n repeatCount={6}\n />\n {/* @ts-ignore */}\n <ReferenceLine y={0} stroke=\"#000\" />\n {/* @ts-ignore */}\n <Bar dataKey=\"volume\" shape={<RoundedRectangle />} minPointSize={1}>\n {props.data.map((entry, index) => {\n return (\n // @ts-ignore\n <Cell\n key={`cell-${index}`}\n fill={entry.volume > 0 ? colors.profit : colors.loss}\n opacity={entry.opacity}\n />\n );\n })}\n </Bar>\n {/* @ts-ignore */}\n <YAxis\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n dataKey={\"volume\"}\n tickFormatter={(value, index) => {\n if (isEmpty) return `${index * 100}`;\n return numberToHumanStyle(value, decimal);\n }}\n width={45}\n />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n // axisLine={false}\n tickLine={false}\n interval={props.data.length - 2}\n // tick={renderQuarterTick}\n height={1}\n // scale=\"time\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n stroke=\"rgb(229, 231, 235)\"\n strokeOpacity={0.2}\n />\n </BarChart>\n </ResponsiveContainer>\n </Box>\n );\n};\nfunction numberToHumanStyle(number: number, decimalPlaces: number = 0): string {\n const abbreviations = [\"\", \"K\", \"M\", \"B\", \"T\"];\n\n let index = 0;\n while (number >= 1000 && index < abbreviations.length - 1) {\n number /= 1000;\n index++;\n }\n\n const roundedNumber = toFixedWithoutRounding(number, decimalPlaces);\n\n return `${roundedNumber}${abbreviations[index]}`;\n}\n\nfunction toFixedWithoutRounding(num: number, fix: number): string {\n const numStr = num.toString();\n const decimalIndex = numStr.indexOf(\".\");\n\n if (decimalIndex === -1 || fix === 0) {\n return numStr.split(\".\")[0];\n }\n\n const cutoffIndex = decimalIndex + fix + 1;\n\n return numStr.slice(0, cutoffIndex);\n}\n","import plugin from \"tailwindcss/plugin\";\n\nimport { PluginCreator } from \"tailwindcss/types/config\";\n\nexport const chartPlugin: PluginCreator = () =>\n plugin(function ({ addComponents, addBase }) {\n addComponents(\n {\n \".xAxis\": {\n \".recharts-cartesian-axis-tick:first-child text\": {\n \"text-anchor\": \"start\",\n },\n \".recharts-cartesian-axis-tick:last-child text\": {\n \"text-anchor\": \"end\",\n },\n },\n },\n {\n respectPrefix: false,\n }\n );\n });\n"]}
1
+ {"version":3,"sources":["../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2_@swc+core@1.13.2_@swc+helpers@0.5.17__@types+node@22.16.5_typescript@5.8.3_/node_modules/tailwindcss/lib/util/createPlugin.js","../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2_@swc+core@1.13.2_@swc+helpers@0.5.17__@types+node@22.16.5_typescript@5.8.3_/node_modules/tailwindcss/lib/public/create-plugin.js","../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2_@swc+core@1.13.2_@swc+helpers@0.5.17__@types+node@22.16.5_typescript@5.8.3_/node_modules/tailwindcss/plugin.js","../src/utils/yTickFormatter.ts","../src/orderly/customTooltip.tsx","../src/utils/theme.ts","../src/orderly/useColors.ts","../src/orderly/pnlBar.tsx","../src/orderly/xAxisLabel.tsx","../src/orderly/pnlLine.tsx","../src/orderly/assetLine.tsx","../src/orderly/volBar.tsx","../src/tailwindcss/theme.ts"],"names":["require_createPlugin","__commonJSMin","exports","_default","createPlugin","plugin","config","pluginFunction","configFunction","optionsFunction","options","require_create_plugin","_createPlugin","_interop_require_default","obj","require_plugin","module","tickFormatter","value","absValue","dp","formatted","numberToHumanStyle","OrderlyChartTooltip","props","label","prefix","unit","coloring","rm","jsxs","Box","Flex","jsx","Text","getThemeColors","root","computedStyle","convertToRGB","color","useColors","colors","useMemo","themeColors","RoundedRectangle","fill","x","y","width","height","absHeight","XAxisLabel","stroke","payload","index","containerWidth","t","useTranslation","_x","CustomizedCross","Cross","CustomTooltip","active","todayStr","useRef","PnLBarChart","invisible","widthRef","ResponsiveContainer","cn","BarChart","Tooltip","CartesianGrid","ReferenceLine","Bar","entry","Cell","YAxis","XAxis","PnlLineChart","dataTransfer","data","series","acc","item","LineChart","Line","AssetLineChart","opacity","tooltip","VolBarChart","isEmpty","pre","cur","maxVolume","decimal","number","decimalPlaces","abbreviations","toFixedWithoutRounding","num","fix","numStr","decimalIndex","cutoffIndex","import_plugin","chartPlugin","addComponents","addBase"],"mappings":"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","file":"index.js","sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function() {\n return _default;\n }\n});\nfunction createPlugin(plugin, config) {\n return {\n handler: plugin,\n config\n };\n}\ncreatePlugin.withOptions = function(pluginFunction, configFunction = ()=>({})) {\n const optionsFunction = function(options) {\n return {\n __options: options,\n handler: pluginFunction(options),\n config: configFunction(options)\n };\n };\n optionsFunction.__isOptionsFunction = true;\n // Expose plugin dependencies so that `object-hash` returns a different\n // value if anything here changes, to ensure a rebuild is triggered.\n optionsFunction.__pluginFunction = pluginFunction;\n optionsFunction.__configFunction = configFunction;\n return optionsFunction;\n};\nconst _default = createPlugin;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function() {\n return _default;\n }\n});\nconst _createPlugin = /*#__PURE__*/ _interop_require_default(require(\"../util/createPlugin\"));\nfunction _interop_require_default(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nconst _default = _createPlugin.default;\n","let createPlugin = require('./lib/public/create-plugin')\nmodule.exports = (createPlugin.__esModule ? createPlugin : { default: createPlugin }).default\n","import { numberToHumanStyle } from \"@orderly.network/utils\";\n\nexport const tickFormatter = (value: number) => {\n let absValue = Math.abs(value);\n const dp = absValue === 0 ? 0 : absValue <= 10 ? 2 : absValue <= 100 ? 1 : 0;\n\n const formatted = numberToHumanStyle(absValue, dp);\n return value < 0 ? `-${formatted}` : formatted;\n};\n","import { Box, Flex, Text } from \"@orderly.network/ui\";\n\nexport const OrderlyChartTooltip = (props: {\n label: string;\n value: string | number;\n unit?: string;\n prefix?: React.ReactNode;\n titleClassName?: string;\n coloring?: boolean;\n dp?: number;\n rm?: number;\n}) => {\n const {\n label,\n value,\n prefix,\n unit = \"USDC\",\n coloring = false,\n dp,\n rm,\n } = props;\n return (\n <Box intensity={600} p={3} r=\"md\">\n <Flex direction={\"row\"} className={props.titleClassName}>\n {prefix}\n <Text.numeral\n unit={unit}\n as=\"div\"\n size=\"sm\"\n coloring={coloring}\n showIdentifier={coloring}\n unitClassName=\"oui-text-base-contrast-54 oui-ml-1\"\n weight=\"semibold\"\n rm={rm}\n dp={dp}\n >\n {value}\n </Text.numeral>\n </Flex>\n <Text size=\"2xs\" intensity={54} weight=\"semibold\">\n {label}\n </Text>\n </Box>\n );\n};\n","export const getThemeColors = () => {\n const root = document.documentElement;\n const computedStyle = getComputedStyle(root);\n\n const colors = {\n primary: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-primary\")\n ),\n primaryLight: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-primary-light\")\n ),\n secondary: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-secondary\")\n ),\n success: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-success\")\n ),\n warning: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-warning\")\n ),\n danger: convertToRGB(computedStyle.getPropertyValue(\"--oui-color-danger\")),\n info: convertToRGB(computedStyle.getPropertyValue(\"--oui-color-info\")),\n loss: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-trading-loss\")\n ),\n profit: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-trading-profit\")\n ),\n };\n\n return colors;\n};\n\nconst convertToRGB = (color: string) => {\n return `rgb(${color.split(\" \").join(\",\")})`;\n};\n","import { useMemo } from \"react\";\nimport { getThemeColors } from \"../utils/theme\";\n\nexport const useColors = (colors?: { profit: string; loss: string }) => {\n const _colors = useMemo(() => {\n const themeColors = getThemeColors();\n return {\n profit: colors?.profit || themeColors.profit,\n loss: colors?.loss || themeColors.loss,\n primary: themeColors.primary,\n primaryLight: themeColors.primaryLight,\n };\n }, [colors]);\n\n return _colors;\n};\n","import { useRef } from \"react\";\nimport {\n BarChart,\n XAxis,\n YAxis,\n ResponsiveContainer,\n Bar,\n Cell,\n Tooltip,\n CartesianGrid,\n ReferenceLine,\n Cross,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { cn } from \"@orderly.network/ui\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { useColors } from \"./useColors\";\n\nexport type PnLChartDataItem = {\n date: string;\n pnl: number;\n};\n\nexport type PnLChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: ReadonlyArray<PnLChartDataItem> | PnLChartDataItem[];\n invisible?: boolean;\n};\n\nconst RoundedRectangle = (props: any) => {\n const { fill, x, y, width, height } = props;\n\n const absHeight = Math.abs(height);\n\n return (\n <rect\n rx={2}\n x={x}\n y={height > 0 ? y : y + height}\n width={width}\n height={absHeight}\n stroke=\"none\"\n fill={fill}\n />\n );\n};\n\nexport const XAxisLabel = (props: any) => {\n const { x, y, stroke, payload, index, width, containerWidth } = props;\n const { t } = useTranslation();\n const _x =\n index === 0\n ? 48\n : containerWidth > 0\n ? containerWidth - 10\n : width + payload.offset;\n\n return (\n <g transform={`translate(${_x},${y - 6})`}>\n <text\n x={0}\n y={0}\n dy={16}\n textAnchor={index === 0 ? \"start\" : \"end\"}\n // textAnchor={\"start\"}\n fontSize={10}\n fill={\"rgba(255,255,255,0.54)\"}\n >\n {index === 0 ? payload.value : t(\"chart.now\")}\n </text>\n </g>\n );\n};\n\nconst CustomizedCross = (props: any) => {\n const { width, height, stroke, fill } = props;\n\n return (\n // @ts-ignore\n <Cross\n // y={props.y + props.top}\n x={props.x + props.width / 2}\n top={props.top}\n height={height}\n width={1}\n stroke={\"rgba(255,255,255,0.16)\"}\n strokeDasharray={\"3 2\"}\n fill={\"none\"}\n />\n );\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n coloring\n />\n );\n }\n\n return null;\n};\n\nexport const PnLBarChart = (props: PnLChartProps) => {\n const { invisible } = props;\n const colors = useColors(props.colors);\n const widthRef = useRef(0);\n\n return (\n // @ts-ignore\n <ResponsiveContainer\n className={cn(invisible && \"chart-invisible\")}\n onResize={(width, height) => {\n // console.log(\"width\", width, height);\n widthRef.current = width;\n }}\n >\n {/* @ts-ignore */}\n <BarChart\n data={props.data as any[]}\n margin={{ left: -10, top: 10, right: 10, bottom: 30 }}\n >\n {!invisible && (\n // @ts-ignore\n <Tooltip\n // cursor={{ fillOpacity: 0.1 }}\n cursor={<CustomizedCross />}\n content={<CustomTooltip />}\n />\n )}\n\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <ReferenceLine y={0} stroke=\"rgba(0,0,0,0.04)\" />\n {/* @ts-ignore */}\n\n {!invisible && (\n // @ts-ignore\n <Bar dataKey=\"pnl\" shape={<RoundedRectangle />}>\n {props.data.map((entry, index) => {\n return (\n // @ts-ignore\n <Cell\n key={`cell-${index}`}\n fill={entry.pnl > 0 ? colors.profit : colors.loss}\n />\n );\n })}\n </Bar>\n )}\n {/* @ts-ignore */}\n <YAxis\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickFormatter={(value) => tickFormatter(value)}\n tickLine={false}\n axisLine={false}\n dataKey={\"pnl\"}\n />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n // axisLine={false}\n tickLine={false}\n interval={props.data.length - 2}\n // tick={renderQuarterTick}\n height={1}\n // scale=\"time\"\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel containerWidth={widthRef.current} />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n />\n </BarChart>\n </ResponsiveContainer>\n );\n};\n","import { useTranslation } from \"@orderly.network/i18n\";\n\nexport const XAxisLabel = (props: any) => {\n const { x, y, stroke, payload, index } = props;\n const { t } = useTranslation();\n return (\n <g transform={`translate(${x},${y - 6})`}>\n <text\n x={0}\n y={0}\n dy={16}\n textAnchor=\"end\"\n fontSize={10}\n fill={\"rgba(255,255,255,0.54)\"}\n >\n {index === 0 ? payload.value : t(\"chart.now\")}\n </text>\n </g>\n );\n};\n","import { useMemo, useRef } from \"react\";\nimport { getThemeColors } from \"../utils/theme\";\nimport { useColors } from \"./useColors\";\n// import { Line } from \"../line/line\";\nimport {\n LineChart,\n XAxis,\n YAxis,\n Line,\n CartesianGrid,\n ReferenceLine,\n Tooltip,\n ResponsiveContainer,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { XAxisLabel } from \"./xAxisLabel\";\nimport { numberToHumanStyle } from \"@orderly.network/utils\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type PnlLineChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: any;\n invisible?: boolean;\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n coloring\n />\n );\n }\n\n return null;\n};\n\nconst PnlLineChart = (props: PnlLineChartProps) => {\n const colors = useColors(props.colors);\n\n const dataTransfer = (data: any[]) => {\n const series: any[] = [];\n\n data?.reduce((acc, item) => {\n acc += item.pnl;\n series.push({\n ...item,\n pnl: acc,\n _pnl: item.pnl,\n // date: new Date(item.date).getTime(),\n });\n return acc;\n }, 0);\n\n return series;\n };\n\n const data = useMemo(() => dataTransfer(props.data), [props.data]);\n\n return (\n // @ts-ignore\n <ResponsiveContainer className={props.invisible ? \"chart-invisible\" : \"\"}>\n {/* @ts-ignore */}\n <LineChart\n data={data}\n margin={{ top: 20, right: 10, left: -10, bottom: 0 }}\n >\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n interval={props.data.length - 2}\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n // scale={\"time\"}\n // type=\"number\"\n // range={}\n />\n {/* @ts-ignore */}\n <YAxis\n dataKey=\"pnl\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n tickFormatter={(value) => tickFormatter(value)}\n />\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Tooltip\n cursor={{ strokeDasharray: \"3 2\", strokeOpacity: 0.16 }}\n content={<CustomTooltip />}\n />\n )}\n\n {/* <ReferenceLine y={0} stroke=\"#000\" /> */}\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Line\n type=\"natural\"\n dataKey=\"pnl\"\n stroke={colors.primary}\n strokeWidth={2}\n dot={false}\n isAnimationActive={false}\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n );\n};\n\nexport { PnlLineChart };\n","import { useColors } from \"./useColors\";\n// import { Line } from \"../line/line\";\nimport {\n LineChart,\n XAxis,\n YAxis,\n Line,\n CartesianGrid,\n Tooltip,\n ResponsiveContainer,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { XAxisLabel } from \"./xAxisLabel\";\nimport { useRef } from \"react\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type AssetChartDataItem = {\n date: string;\n account_value: number;\n};\n\nexport type PnlLineChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: AssetChartDataItem[];\n invisible?: boolean;\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n />\n );\n }\n\n return null;\n};\n\nconst AssetLineChart = (props: PnlLineChartProps) => {\n const colors = useColors(props.colors);\n\n // const dataTransfer = (data: any[]) => {\n // const series: any[] = [];\n\n // data.reduce((acc, item) => {\n // acc += item.pnl;\n // series.push({ ...item, pnl: acc, _pnl: item.pnl });\n // return acc;\n // }, 0);\n\n // return series;\n // };\n\n // const data = useMemo(() => dataTransfer(props.data), [props.data]);\n\n return (\n // @ts-ignore\n <ResponsiveContainer className={props.invisible ? \"chart-invisible\" : \"\"}>\n {/* @ts-ignore */}\n <LineChart\n width={530}\n height={180}\n data={props.data}\n margin={{ top: 20, right: 10, left: -20, bottom: -10 }}\n >\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n interval={props.data.length - 2}\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n ></XAxis>\n {/* @ts-ignore */}\n <YAxis\n dataKey=\"account_value\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n tickFormatter={(value) => tickFormatter(value)}\n />\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Tooltip\n cursor={{ strokeDasharray: \"3 2\", strokeOpacity: 0.16 }}\n content={<CustomTooltip />}\n />\n )}\n\n {/* <Legend /> */}\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Line\n type=\"natural\"\n dataKey=\"account_value\"\n stroke={colors.profit}\n strokeWidth={2}\n dot={false}\n isAnimationActive={false}\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n );\n};\n\nexport { AssetLineChart };\n","import {\n BarChart,\n XAxis,\n YAxis,\n ResponsiveContainer,\n Bar,\n Cell,\n Tooltip,\n CartesianGrid,\n ReferenceLine,\n Cross,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { Box, cn } from \"@orderly.network/ui\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { useColors } from \"./useColors\";\n\nexport type VolChartDataItem = {\n date: string;\n volume: number;\n opacity?: string | number;\n};\n\nexport type VolChartTooltip = {\n rm?: number;\n dp?: number;\n};\n\nexport type VolChartProps = {\n colors?: { fill: string };\n data: ReadonlyArray<VolChartDataItem> | VolChartDataItem[];\n tooltip?: VolChartTooltip;\n className?: string;\n};\n\nconst RoundedRectangle = (props: any) => {\n const { fill, x, y, width, height, opacity } = props;\n const absHeight = Math.abs(height);\n\n return (\n <rect\n rx={2}\n x={x}\n y={height > 0 ? y : y + height}\n width={width}\n height={absHeight}\n stroke=\"none\"\n fill={fill}\n opacity={opacity}\n />\n );\n};\n\nconst CustomizedCross = (props: any) => {\n const { width, height, payload, stroke, fill } = props;\n\n if (payload?.[0]?.value === 0) {\n return null;\n }\n\n return (\n // @ts-ignore\n <Cross\n // y={props.y + props.top}\n x={props.x + props.width / 2}\n top={props.top}\n height={height}\n width={1}\n stroke={\"rgba(255,255,255,0.16)\"}\n strokeDasharray={\"3 2\"}\n fill={\"none\"}\n />\n );\n};\n\nconst CustomTooltip = (\n props: TooltipProps<any, any> & { tooltip?: VolChartTooltip },\n) => {\n const { active, payload, label, tooltip } = props;\n\n if (payload?.[0]?.value === 0) {\n return null;\n }\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label}\n value={payload[0].value}\n // prefix=\"Commission\"\n titleClassName=\"oui-gap-4\"\n rm={tooltip?.rm}\n dp={tooltip?.dp}\n />\n );\n }\n\n return null;\n};\n\nexport const VolBarChart = (props: VolChartProps) => {\n const colors = useColors(\n props.colors?.fill\n ? { profit: props.colors?.fill, loss: props.colors?.fill }\n : undefined,\n );\n\n const isEmpty =\n (props.data as any)?.reduce((pre: any, cur: any) => pre + cur.volume, 0) ===\n 0;\n\n const maxVolume = (props.data as any)?.reduce(\n (pre: any, cur: any) => (pre > cur.volume ? pre : cur.volume),\n 0,\n );\n\n const decimal = maxVolume <= 10 ? 2 : maxVolume <= 100 ? 1 : 0;\n\n return (\n // @ts-ignore\n <Box className={cn(props.className)}>\n {/* @ts-ignore */}\n <ResponsiveContainer>\n {/* @ts-ignore */}\n <BarChart\n data={props.data as any[]}\n margin={{ left: -0, top: 6, right: 0, bottom: 20 }}\n >\n {/* @ts-ignore */}\n <Tooltip\n // cursor={{ fillOpacity: 0.1 }}\n cursor={<CustomizedCross />}\n content={<CustomTooltip tooltip={props.tooltip} />}\n />\n <CartesianGrid\n vertical={false}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.08}\n repeatCount={6}\n />\n {/* @ts-ignore */}\n <ReferenceLine y={0} stroke=\"#000\" />\n {/* @ts-ignore */}\n <Bar dataKey=\"volume\" shape={<RoundedRectangle />} minPointSize={1}>\n {props.data.map((entry, index) => {\n return (\n // @ts-ignore\n <Cell\n key={`cell-${index}`}\n fill={entry.volume > 0 ? colors.profit : colors.loss}\n opacity={entry.opacity}\n />\n );\n })}\n </Bar>\n {/* @ts-ignore */}\n <YAxis\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n dataKey={\"volume\"}\n tickFormatter={(value, index) => {\n if (isEmpty) return `${index * 100}`;\n return numberToHumanStyle(value, decimal);\n }}\n width={45}\n />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n // axisLine={false}\n tickLine={false}\n interval={props.data.length - 2}\n // tick={renderQuarterTick}\n height={1}\n // scale=\"time\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n stroke=\"rgb(229, 231, 235)\"\n strokeOpacity={0.2}\n />\n </BarChart>\n </ResponsiveContainer>\n </Box>\n );\n};\nfunction numberToHumanStyle(number: number, decimalPlaces: number = 0): string {\n const abbreviations = [\"\", \"K\", \"M\", \"B\", \"T\"];\n\n let index = 0;\n while (number >= 1000 && index < abbreviations.length - 1) {\n number /= 1000;\n index++;\n }\n\n const roundedNumber = toFixedWithoutRounding(number, decimalPlaces);\n\n return `${roundedNumber}${abbreviations[index]}`;\n}\n\nfunction toFixedWithoutRounding(num: number, fix: number): string {\n const numStr = num.toString();\n const decimalIndex = numStr.indexOf(\".\");\n\n if (decimalIndex === -1 || fix === 0) {\n return numStr.split(\".\")[0];\n }\n\n const cutoffIndex = decimalIndex + fix + 1;\n\n return numStr.slice(0, cutoffIndex);\n}\n","import plugin from \"tailwindcss/plugin\";\n\nimport { PluginCreator } from \"tailwindcss/types/config\";\n\nexport const chartPlugin: PluginCreator = () =>\n plugin(function ({ addComponents, addBase }) {\n addComponents(\n {\n \".xAxis\": {\n \".recharts-cartesian-axis-tick:first-child text\": {\n \"text-anchor\": \"start\",\n },\n \".recharts-cartesian-axis-tick:last-child text\": {\n \"text-anchor\": \"end\",\n },\n },\n },\n {\n respectPrefix: false,\n }\n );\n });\n"]}
package/dist/index.mjs CHANGED
@@ -1,2 +1,2 @@
1
- import {useMemo,useRef}from'react';import {ResponsiveContainer,BarChart,Tooltip,CartesianGrid,ReferenceLine,Bar,Cell,YAxis,XAxis,LineChart,Line,Cross}from'recharts';import {cn,Box,Flex,Text}from'@orderly.network/ui';import {jsx,jsxs}from'react/jsx-runtime';import {numberToHumanStyle}from'@orderly.network/utils';import {useTranslation}from'@orderly.network/i18n';var N=Object.create;var k=Object.defineProperty;var I=Object.getOwnPropertyDescriptor;var K=Object.getOwnPropertyNames;var $=Object.getPrototypeOf,M=Object.prototype.hasOwnProperty;var g=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var X=(t,e,r,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of K(e))!M.call(t,i)&&i!==r&&k(t,i,{get:()=>e[i],enumerable:!(o=I(e,i))||o.enumerable});return t};var G=(t,e,r)=>(r=t!=null?N($(t)):{},X(!t||!t.__esModule?k(r,"default",{value:t,enumerable:true}):r,t));var O=g(x=>{Object.defineProperty(x,"__esModule",{value:true});Object.defineProperty(x,"default",{enumerable:true,get:function(){return re}});function S(t,e){return {handler:t,config:e}}S.withOptions=function(t,e=()=>({})){let r=function(o){return {__options:o,handler:t(o),config:e(o)}};return r.__isOptionsFunction=true,r.__pluginFunction=t,r.__configFunction=e,r};var re=S;});var A=g(C=>{Object.defineProperty(C,"__esModule",{value:true});Object.defineProperty(C,"default",{enumerable:true,get:function(){return ae}});var oe=ie(O());function ie(t){return t&&t.__esModule?t:{default:t}}var ae=oe.default;});var V=g((rr,R)=>{var b=A();R.exports=(b.__esModule?b:{default:b}).default;});var v=()=>{let t=document.documentElement,e=getComputedStyle(t);return {primary:u(e.getPropertyValue("--oui-color-primary")),primaryLight:u(e.getPropertyValue("--oui-color-primary-light")),secondary:u(e.getPropertyValue("--oui-color-secondary")),success:u(e.getPropertyValue("--oui-color-success")),warning:u(e.getPropertyValue("--oui-color-warning")),danger:u(e.getPropertyValue("--oui-color-danger")),info:u(e.getPropertyValue("--oui-color-info")),loss:u(e.getPropertyValue("--oui-color-trading-loss")),profit:u(e.getPropertyValue("--oui-color-trading-profit"))}},u=t=>`rgb(${t.split(" ").join(",")})`;var f=t=>useMemo(()=>{let r=v();return {profit:t?.profit||r.profit,loss:t?.loss||r.loss,primary:r.primary,primaryLight:r.primaryLight}},[t]);var d=t=>{let{label:e,value:r,prefix:o,unit:i="USDC",coloring:a=false,dp:n,rm:c}=t;return jsxs(Box,{intensity:600,p:3,r:"md",children:[jsxs(Flex,{direction:"row",className:t.titleClassName,children:[o,jsx(Text.numeral,{unit:i,as:"div",size:"sm",coloring:a,showIdentifier:a,unitClassName:"oui-text-base-contrast-54 oui-ml-1",weight:"semibold",rm:c,dp:n,children:r})]}),jsx(Text,{size:"2xs",intensity:54,weight:"semibold",children:e})]})};var h=t=>{let e=Math.abs(t),r=e===0?0:e<=10?2:e<=100?1:0,o=numberToHumanStyle(e,r);return t<0?`-${o}`:o};var at=t=>{let{fill:e,x:r,y:o,width:i,height:a}=t,n=Math.abs(a);return jsx("rect",{rx:2,x:r,y:a>0?o:o+a,width:i,height:n,stroke:"none",fill:e})},nt=t=>{let{x:e,y:r,stroke:o,payload:i,index:a,width:n,containerWidth:c}=t,{t:z}=useTranslation(),D=a===0?48:c>0?c-10:n+i.offset;return jsx("g",{transform:`translate(${D},${r-6})`,children:jsx("text",{x:0,y:0,dy:16,textAnchor:a===0?"start":"end",fontSize:10,fill:"rgba(255,255,255,0.54)",children:a===0?i.value:z("chart.now")})})},lt=t=>{let{width:e,height:r,stroke:o,fill:i}=t;return jsx(Cross,{x:t.x+t.width/2,top:t.top,height:r,width:1,stroke:"rgba(255,255,255,0.16)",strokeDasharray:"3 2",fill:"none"})},st=t=>{let{active:e,payload:r,label:o}=t,i=useRef(new Date().toISOString().split("T")[0]),{t:a}=useTranslation();return e&&r&&r.length?jsx(d,{label:o===i.current?a("chart.now"):o,value:r[0].value,coloring:true}):null},ct=t=>{let{invisible:e}=t,r=f(t.colors),o=useRef(0);return jsx(ResponsiveContainer,{className:cn(e&&"chart-invisible"),onResize:(i,a)=>{o.current=i;},children:jsxs(BarChart,{data:t.data,margin:{left:-10,top:10,right:10,bottom:30},children:[!e&&jsx(Tooltip,{cursor:jsx(lt,{}),content:jsx(st,{})}),jsx(CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsx(ReferenceLine,{y:0,stroke:"rgba(0,0,0,0.04)"}),!e&&jsx(Bar,{dataKey:"pnl",shape:jsx(at,{}),children:t.data.map((i,a)=>jsx(Cell,{fill:i.pnl>0?r.profit:r.loss},`cell-${a}`))}),jsx(YAxis,{tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickFormatter:i=>h(i),tickLine:false,axisLine:false,dataKey:"pnl"}),jsx(XAxis,{dataKey:"date",tickLine:false,interval:t.data.length-2,height:1,tick:jsx(nt,{containerWidth:o.current}),stroke:"#FFFFFF",strokeOpacity:.04})]})})};var y=t=>{let{x:e,y:r,stroke:o,payload:i,index:a}=t,{t:n}=useTranslation();return jsx("g",{transform:`translate(${e},${r-6})`,children:jsx("text",{x:0,y:0,dy:16,textAnchor:"end",fontSize:10,fill:"rgba(255,255,255,0.54)",children:a===0?i.value:n("chart.now")})})};var vt=t=>{let{active:e,payload:r,label:o}=t,i=useRef(new Date().toISOString().split("T")[0]),{t:a}=useTranslation();return e&&r&&r.length?jsx(d,{label:o===i.current?a("chart.now"):o,value:r[0].value,coloring:true}):null},Ft=t=>{let e=f(t.colors),r=i=>{let a=[];return i?.reduce((n,c)=>(n+=c.pnl,a.push({...c,pnl:n,_pnl:c.pnl}),n),0),a},o=useMemo(()=>r(t.data),[t.data]);return jsx(ResponsiveContainer,{className:t.invisible?"chart-invisible":"",children:jsxs(LineChart,{data:o,margin:{top:20,right:10,left:-10,bottom:0},children:[jsx(CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsx(XAxis,{dataKey:"date",interval:t.data.length-2,tick:jsx(y,{}),stroke:"#FFFFFF",strokeOpacity:.04}),jsx(YAxis,{dataKey:"pnl",tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,tickFormatter:i=>h(i)}),!t.invisible&&jsx(Tooltip,{cursor:{strokeDasharray:"3 2",strokeOpacity:.16},content:jsx(vt,{})}),!t.invisible&&jsx(Line,{type:"natural",dataKey:"pnl",stroke:e.primary,strokeWidth:2,dot:false,isAnimationActive:false})]})})};var Bt=t=>{let{active:e,payload:r,label:o}=t,i=useRef(new Date().toISOString().split("T")[0]),{t:a}=useTranslation();return e&&r&&r.length?jsx(d,{label:o===i.current?a("chart.now"):o,value:r[0].value}):null},zt=t=>{let e=f(t.colors);return jsx(ResponsiveContainer,{className:t.invisible?"chart-invisible":"",children:jsxs(LineChart,{width:530,height:180,data:t.data,margin:{top:20,right:10,left:-20,bottom:-10},children:[jsx(CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsx(XAxis,{dataKey:"date",interval:t.data.length-2,tick:jsx(y,{}),stroke:"#FFFFFF",strokeOpacity:.04}),jsx(YAxis,{dataKey:"account_value",tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,tickFormatter:r=>h(r)}),!t.invisible&&jsx(Tooltip,{cursor:{strokeDasharray:"3 2",strokeOpacity:.16},content:jsx(Bt,{})}),!t.invisible&&jsx(Line,{type:"natural",dataKey:"account_value",stroke:e.profit,strokeWidth:2,dot:false,isAnimationActive:false})]})})};var Qt=t=>{let{fill:e,x:r,y:o,width:i,height:a,opacity:n}=t,c=Math.abs(a);return jsx("rect",{rx:2,x:r,y:a>0?o:o+a,width:i,height:c,stroke:"none",fill:e,opacity:n})},Ut=t=>{let{width:e,height:r,payload:o,stroke:i,fill:a}=t;return o?.[0]?.value===0?null:jsx(Cross,{x:t.x+t.width/2,top:t.top,height:r,width:1,stroke:"rgba(255,255,255,0.16)",strokeDasharray:"3 2",fill:"none"})},Jt=t=>{let{active:e,payload:r,label:o,tooltip:i}=t;return r?.[0]?.value===0?null:e&&r&&r.length?jsx(d,{label:o,value:r[0].value,titleClassName:"oui-gap-4",rm:i?.rm,dp:i?.dp}):null},Zt=t=>{let e=f(t.colors?.fill?{profit:t.colors?.fill,loss:t.colors?.fill}:void 0),r=t.data.reduce((a,n)=>a+n.volume,0)===0,o=t.data.reduce((a,n)=>a>n.volume?a:n.volume,0),i=o<=10?2:o<=100?1:0;return jsx(Box,{className:cn(t.className),children:jsx(ResponsiveContainer,{children:jsxs(BarChart,{data:t.data,margin:{left:-0,top:6,right:0,bottom:20},children:[jsx(Tooltip,{cursor:jsx(Ut,{}),content:jsx(Jt,{tooltip:t.tooltip})}),jsx(CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.08,repeatCount:6}),jsx(ReferenceLine,{y:0,stroke:"#000"}),jsx(Bar,{dataKey:"volume",shape:jsx(Qt,{}),minPointSize:1,children:t.data.map((a,n)=>jsx(Cell,{fill:a.volume>0?e.profit:e.loss,opacity:a.opacity},`cell-${n}`))}),jsx(YAxis,{tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,dataKey:"volume",tickFormatter:(a,n)=>r?`${n*100}`:jt(a,i),width:45}),jsx(XAxis,{dataKey:"date",tickLine:false,interval:t.data.length-2,height:1,tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},stroke:"rgb(229, 231, 235)",strokeOpacity:.2})]})})})};function jt(t,e=0){let r=["","K","M","B","T"],o=0;for(;t>=1e3&&o<r.length-1;)t/=1e3,o++;return `${te(t,e)}${r[o]}`}function te(t,e){let r=t.toString(),o=r.indexOf(".");if(o===-1||e===0)return r.split(".")[0];let i=o+e+1;return r.slice(0,i)}var B=G(V()),ne=()=>(0, B.default)(function({addComponents:t,addBase:e}){t({".xAxis":{".recharts-cartesian-axis-tick:first-child text":{"text-anchor":"start"},".recharts-cartesian-axis-tick:last-child text":{"text-anchor":"end"}}},{respectPrefix:false});});export{zt as AssetLineChart,ct as PnLBarChart,Ft as PnlLineChart,Zt as VolBarChart,ne as chartPlugin};//# sourceMappingURL=index.mjs.map
1
+ import {useMemo,useRef}from'react';import {ResponsiveContainer,BarChart,Tooltip,CartesianGrid,ReferenceLine,Bar,Cell,YAxis,XAxis,LineChart,Line,Cross}from'recharts';import {useTranslation}from'@orderly.network/i18n';import {cn,Box,Flex,Text}from'@orderly.network/ui';import {numberToHumanStyle}from'@orderly.network/utils';import {jsx,jsxs}from'react/jsx-runtime';var I=Object.create;var k=Object.defineProperty;var N=Object.getOwnPropertyDescriptor;var K=Object.getOwnPropertyNames;var $=Object.getPrototypeOf,M=Object.prototype.hasOwnProperty;var g=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var X=(t,e,r,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of K(e))!M.call(t,a)&&a!==r&&k(t,a,{get:()=>e[a],enumerable:!(o=N(e,a))||o.enumerable});return t};var G=(t,e,r)=>(r=t!=null?I($(t)):{},X(!t||!t.__esModule?k(r,"default",{value:t,enumerable:true}):r,t));var A=g(x=>{Object.defineProperty(x,"__esModule",{value:true});Object.defineProperty(x,"default",{enumerable:true,get:function(){return re}});function S(t,e){return {handler:t,config:e}}S.withOptions=function(t,e=()=>({})){let r=function(o){return {__options:o,handler:t(o),config:e(o)}};return r.__isOptionsFunction=true,r.__pluginFunction=t,r.__configFunction=e,r};var re=S;});var O=g(C=>{Object.defineProperty(C,"__esModule",{value:true});Object.defineProperty(C,"default",{enumerable:true,get:function(){return ie}});var oe=ae(A());function ae(t){return t&&t.__esModule?t:{default:t}}var ie=oe.default;});var V=g((rr,R)=>{var b=O();R.exports=(b.__esModule?b:{default:b}).default;});var h=t=>{let e=Math.abs(t),r=e===0?0:e<=10?2:e<=100?1:0,o=numberToHumanStyle(e,r);return t<0?`-${o}`:o};var f=t=>{let{label:e,value:r,prefix:o,unit:a="USDC",coloring:i=false,dp:n,rm:c}=t;return jsxs(Box,{intensity:600,p:3,r:"md",children:[jsxs(Flex,{direction:"row",className:t.titleClassName,children:[o,jsx(Text.numeral,{unit:a,as:"div",size:"sm",coloring:i,showIdentifier:i,unitClassName:"oui-text-base-contrast-54 oui-ml-1",weight:"semibold",rm:c,dp:n,children:r})]}),jsx(Text,{size:"2xs",intensity:54,weight:"semibold",children:e})]})};var T=()=>{let t=document.documentElement,e=getComputedStyle(t);return {primary:u(e.getPropertyValue("--oui-color-primary")),primaryLight:u(e.getPropertyValue("--oui-color-primary-light")),secondary:u(e.getPropertyValue("--oui-color-secondary")),success:u(e.getPropertyValue("--oui-color-success")),warning:u(e.getPropertyValue("--oui-color-warning")),danger:u(e.getPropertyValue("--oui-color-danger")),info:u(e.getPropertyValue("--oui-color-info")),loss:u(e.getPropertyValue("--oui-color-trading-loss")),profit:u(e.getPropertyValue("--oui-color-trading-profit"))}},u=t=>`rgb(${t.split(" ").join(",")})`;var d=t=>useMemo(()=>{let r=T();return {profit:t?.profit||r.profit,loss:t?.loss||r.loss,primary:r.primary,primaryLight:r.primaryLight}},[t]);var it=t=>{let{fill:e,x:r,y:o,width:a,height:i}=t,n=Math.abs(i);return jsx("rect",{rx:2,x:r,y:i>0?o:o+i,width:a,height:n,stroke:"none",fill:e})},nt=t=>{let{x:e,y:r,stroke:o,payload:a,index:i,width:n,containerWidth:c}=t,{t:D}=useTranslation(),z=i===0?48:c>0?c-10:n+a.offset;return jsx("g",{transform:`translate(${z},${r-6})`,children:jsx("text",{x:0,y:0,dy:16,textAnchor:i===0?"start":"end",fontSize:10,fill:"rgba(255,255,255,0.54)",children:i===0?a.value:D("chart.now")})})},lt=t=>{let{width:e,height:r,stroke:o,fill:a}=t;return jsx(Cross,{x:t.x+t.width/2,top:t.top,height:r,width:1,stroke:"rgba(255,255,255,0.16)",strokeDasharray:"3 2",fill:"none"})},st=t=>{let{active:e,payload:r,label:o}=t,a=useRef(new Date().toISOString().split("T")[0]),{t:i}=useTranslation();return e&&r&&r.length?jsx(f,{label:o===a.current?i("chart.now"):o,value:r[0].value,coloring:true}):null},ct=t=>{let{invisible:e}=t,r=d(t.colors),o=useRef(0);return jsx(ResponsiveContainer,{className:cn(e&&"chart-invisible"),onResize:(a,i)=>{o.current=a;},children:jsxs(BarChart,{data:t.data,margin:{left:-10,top:10,right:10,bottom:30},children:[!e&&jsx(Tooltip,{cursor:jsx(lt,{}),content:jsx(st,{})}),jsx(CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsx(ReferenceLine,{y:0,stroke:"rgba(0,0,0,0.04)"}),!e&&jsx(Bar,{dataKey:"pnl",shape:jsx(it,{}),children:t.data.map((a,i)=>jsx(Cell,{fill:a.pnl>0?r.profit:r.loss},`cell-${i}`))}),jsx(YAxis,{tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickFormatter:a=>h(a),tickLine:false,axisLine:false,dataKey:"pnl"}),jsx(XAxis,{dataKey:"date",tickLine:false,interval:t.data.length-2,height:1,tick:jsx(nt,{containerWidth:o.current}),stroke:"#FFFFFF",strokeOpacity:.04})]})})};var y=t=>{let{x:e,y:r,stroke:o,payload:a,index:i}=t,{t:n}=useTranslation();return jsx("g",{transform:`translate(${e},${r-6})`,children:jsx("text",{x:0,y:0,dy:16,textAnchor:"end",fontSize:10,fill:"rgba(255,255,255,0.54)",children:i===0?a.value:n("chart.now")})})};var vt=t=>{let{active:e,payload:r,label:o}=t,a=useRef(new Date().toISOString().split("T")[0]),{t:i}=useTranslation();return e&&r&&r.length?jsx(f,{label:o===a.current?i("chart.now"):o,value:r[0].value,coloring:true}):null},Ft=t=>{let e=d(t.colors),r=a=>{let i=[];return a?.reduce((n,c)=>(n+=c.pnl,i.push({...c,pnl:n,_pnl:c.pnl}),n),0),i},o=useMemo(()=>r(t.data),[t.data]);return jsx(ResponsiveContainer,{className:t.invisible?"chart-invisible":"",children:jsxs(LineChart,{data:o,margin:{top:20,right:10,left:-10,bottom:0},children:[jsx(CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsx(XAxis,{dataKey:"date",interval:t.data.length-2,tick:jsx(y,{}),stroke:"#FFFFFF",strokeOpacity:.04}),jsx(YAxis,{dataKey:"pnl",tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,tickFormatter:a=>h(a)}),!t.invisible&&jsx(Tooltip,{cursor:{strokeDasharray:"3 2",strokeOpacity:.16},content:jsx(vt,{})}),!t.invisible&&jsx(Line,{type:"natural",dataKey:"pnl",stroke:e.primary,strokeWidth:2,dot:false,isAnimationActive:false})]})})};var Bt=t=>{let{active:e,payload:r,label:o}=t,a=useRef(new Date().toISOString().split("T")[0]),{t:i}=useTranslation();return e&&r&&r.length?jsx(f,{label:o===a.current?i("chart.now"):o,value:r[0].value}):null},Dt=t=>{let e=d(t.colors);return jsx(ResponsiveContainer,{className:t.invisible?"chart-invisible":"",children:jsxs(LineChart,{width:530,height:180,data:t.data,margin:{top:20,right:10,left:-20,bottom:-10},children:[jsx(CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.04}),jsx(XAxis,{dataKey:"date",interval:t.data.length-2,tick:jsx(y,{}),stroke:"#FFFFFF",strokeOpacity:.04}),jsx(YAxis,{dataKey:"account_value",tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,tickFormatter:r=>h(r)}),!t.invisible&&jsx(Tooltip,{cursor:{strokeDasharray:"3 2",strokeOpacity:.16},content:jsx(Bt,{})}),!t.invisible&&jsx(Line,{type:"natural",dataKey:"account_value",stroke:e.profit,strokeWidth:2,dot:false,isAnimationActive:false})]})})};var Qt=t=>{let{fill:e,x:r,y:o,width:a,height:i,opacity:n}=t,c=Math.abs(i);return jsx("rect",{rx:2,x:r,y:i>0?o:o+i,width:a,height:c,stroke:"none",fill:e,opacity:n})},Ut=t=>{let{width:e,height:r,payload:o,stroke:a,fill:i}=t;return o?.[0]?.value===0?null:jsx(Cross,{x:t.x+t.width/2,top:t.top,height:r,width:1,stroke:"rgba(255,255,255,0.16)",strokeDasharray:"3 2",fill:"none"})},Jt=t=>{let{active:e,payload:r,label:o,tooltip:a}=t;return r?.[0]?.value===0?null:e&&r&&r.length?jsx(f,{label:o,value:r[0].value,titleClassName:"oui-gap-4",rm:a?.rm,dp:a?.dp}):null},Zt=t=>{let e=d(t.colors?.fill?{profit:t.colors?.fill,loss:t.colors?.fill}:void 0),r=t.data?.reduce((i,n)=>i+n.volume,0)===0,o=t.data?.reduce((i,n)=>i>n.volume?i:n.volume,0),a=o<=10?2:o<=100?1:0;return jsx(Box,{className:cn(t.className),children:jsx(ResponsiveContainer,{children:jsxs(BarChart,{data:t.data,margin:{left:-0,top:6,right:0,bottom:20},children:[jsx(Tooltip,{cursor:jsx(Ut,{}),content:jsx(Jt,{tooltip:t.tooltip})}),jsx(CartesianGrid,{vertical:false,stroke:"#FFFFFF",strokeOpacity:.08,repeatCount:6}),jsx(ReferenceLine,{y:0,stroke:"#000"}),jsx(Bar,{dataKey:"volume",shape:jsx(Qt,{}),minPointSize:1,children:t.data.map((i,n)=>jsx(Cell,{fill:i.volume>0?e.profit:e.loss,opacity:i.opacity},`cell-${n}`))}),jsx(YAxis,{tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},tickLine:false,axisLine:false,dataKey:"volume",tickFormatter:(i,n)=>r?`${n*100}`:jt(i,a),width:45}),jsx(XAxis,{dataKey:"date",tickLine:false,interval:t.data.length-2,height:1,tick:{fontSize:10,fill:"rgba(255,255,255,0.54)"},stroke:"rgb(229, 231, 235)",strokeOpacity:.2})]})})})};function jt(t,e=0){let r=["","K","M","B","T"],o=0;for(;t>=1e3&&o<r.length-1;)t/=1e3,o++;return `${te(t,e)}${r[o]}`}function te(t,e){let r=t.toString(),o=r.indexOf(".");if(o===-1||e===0)return r.split(".")[0];let a=o+e+1;return r.slice(0,a)}var B=G(V()),ne=()=>(0, B.default)(function({addComponents:t,addBase:e}){t({".xAxis":{".recharts-cartesian-axis-tick:first-child text":{"text-anchor":"start"},".recharts-cartesian-axis-tick:last-child text":{"text-anchor":"end"}}},{respectPrefix:false});});export{Dt as AssetLineChart,ct as PnLBarChart,Ft as PnlLineChart,Zt as VolBarChart,ne as chartPlugin};//# sourceMappingURL=index.mjs.map
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2/node_modules/tailwindcss/lib/util/createPlugin.js","../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2/node_modules/tailwindcss/lib/public/create-plugin.js","../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2/node_modules/tailwindcss/plugin.js","../src/utils/theme.ts","../src/orderly/useColors.ts","../src/orderly/customTooltip.tsx","../src/utils/yTickFormatter.ts","../src/orderly/pnlBar.tsx","../src/orderly/xAxisLabel.tsx","../src/orderly/pnlLine.tsx","../src/orderly/assetLine.tsx","../src/orderly/volBar.tsx","../src/tailwindcss/theme.ts"],"names":["require_createPlugin","__commonJSMin","exports","_default","createPlugin","plugin","config","pluginFunction","configFunction","optionsFunction","options","require_create_plugin","_createPlugin","_interop_require_default","obj","require_plugin","module","getThemeColors","root","computedStyle","convertToRGB","color","useColors","colors","useMemo","themeColors","OrderlyChartTooltip","props","label","value","prefix","unit","coloring","dp","rm","jsxs","Box","Flex","jsx","Text","tickFormatter","absValue","formatted","numberToHumanStyle","RoundedRectangle","fill","x","y","width","height","absHeight","XAxisLabel","stroke","payload","index","containerWidth","t","useTranslation","_x","CustomizedCross","Cross","CustomTooltip","active","todayStr","useRef","PnLBarChart","invisible","widthRef","ResponsiveContainer","cn","BarChart","Tooltip","CartesianGrid","ReferenceLine","Bar","entry","Cell","YAxis","XAxis","PnlLineChart","dataTransfer","data","series","acc","item","LineChart","Line","AssetLineChart","opacity","tooltip","VolBarChart","isEmpty","b","maxVolume","decimal","number","decimalPlaces","abbreviations","toFixedWithoutRounding","num","fix","numStr","decimalIndex","cutoffIndex","import_plugin","chartPlugin","addComponents","addBase"],"mappings":"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","file":"index.mjs","sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function() {\n return _default;\n }\n});\nfunction createPlugin(plugin, config) {\n return {\n handler: plugin,\n config\n };\n}\ncreatePlugin.withOptions = function(pluginFunction, configFunction = ()=>({})) {\n const optionsFunction = function(options) {\n return {\n __options: options,\n handler: pluginFunction(options),\n config: configFunction(options)\n };\n };\n optionsFunction.__isOptionsFunction = true;\n // Expose plugin dependencies so that `object-hash` returns a different\n // value if anything here changes, to ensure a rebuild is triggered.\n optionsFunction.__pluginFunction = pluginFunction;\n optionsFunction.__configFunction = configFunction;\n return optionsFunction;\n};\nconst _default = createPlugin;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function() {\n return _default;\n }\n});\nconst _createPlugin = /*#__PURE__*/ _interop_require_default(require(\"../util/createPlugin\"));\nfunction _interop_require_default(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nconst _default = _createPlugin.default;\n","let createPlugin = require('./lib/public/create-plugin')\nmodule.exports = (createPlugin.__esModule ? createPlugin : { default: createPlugin }).default\n","export const getThemeColors = () => {\n const root = document.documentElement;\n const computedStyle = getComputedStyle(root);\n\n const colors = {\n primary: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-primary\")\n ),\n primaryLight: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-primary-light\")\n ),\n secondary: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-secondary\")\n ),\n success: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-success\")\n ),\n warning: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-warning\")\n ),\n danger: convertToRGB(computedStyle.getPropertyValue(\"--oui-color-danger\")),\n info: convertToRGB(computedStyle.getPropertyValue(\"--oui-color-info\")),\n loss: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-trading-loss\")\n ),\n profit: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-trading-profit\")\n ),\n };\n\n return colors;\n};\n\nconst convertToRGB = (color: string) => {\n return `rgb(${color.split(\" \").join(\",\")})`;\n};\n","import { useMemo } from \"react\";\nimport { getThemeColors } from \"../utils/theme\";\n\nexport const useColors = (colors?: { profit: string; loss: string }) => {\n const _colors = useMemo(() => {\n const themeColors = getThemeColors();\n return {\n profit: colors?.profit || themeColors.profit,\n loss: colors?.loss || themeColors.loss,\n primary: themeColors.primary,\n primaryLight: themeColors.primaryLight,\n };\n }, [colors]);\n\n return _colors;\n};\n","import { Box, Flex, Text } from \"@orderly.network/ui\";\n\nexport const OrderlyChartTooltip = (props: {\n label: string;\n value: string | number;\n unit?: string;\n prefix?: React.ReactNode;\n titleClassName?: string;\n coloring?: boolean;\n dp?: number;\n rm?: number;\n}) => {\n const {\n label,\n value,\n prefix,\n unit = \"USDC\",\n coloring = false,\n dp,\n rm,\n } = props;\n return (\n <Box intensity={600} p={3} r=\"md\">\n <Flex direction={\"row\"} className={props.titleClassName}>\n {prefix}\n <Text.numeral\n unit={unit}\n as=\"div\"\n size=\"sm\"\n coloring={coloring}\n showIdentifier={coloring}\n unitClassName=\"oui-text-base-contrast-54 oui-ml-1\"\n weight=\"semibold\"\n rm={rm}\n dp={dp}\n >\n {value}\n </Text.numeral>\n </Flex>\n <Text size=\"2xs\" intensity={54} weight=\"semibold\">\n {label}\n </Text>\n </Box>\n );\n};\n","import { numberToHumanStyle } from \"@orderly.network/utils\";\n\nexport const tickFormatter = (value: number) => {\n let absValue = Math.abs(value);\n const dp = absValue === 0 ? 0 : absValue <= 10 ? 2 : absValue <= 100 ? 1 : 0;\n\n const formatted = numberToHumanStyle(absValue, dp);\n return value < 0 ? `-${formatted}` : formatted;\n};\n","import { useColors } from \"./useColors\";\nimport {\n BarChart,\n XAxis,\n YAxis,\n ResponsiveContainer,\n Bar,\n Cell,\n Tooltip,\n CartesianGrid,\n ReferenceLine,\n Cross,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { cn } from \"@orderly.network/ui\";\nimport { useRef } from \"react\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type PnLChartDataItem = {\n date: string;\n pnl: number;\n};\n\nexport type PnLChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: PnLChartDataItem[];\n invisible?: boolean;\n};\n\nconst RoundedRectangle = (props: any) => {\n const { fill, x, y, width, height } = props;\n\n const absHeight = Math.abs(height);\n\n return (\n <rect\n rx={2}\n x={x}\n y={height > 0 ? y : y + height}\n width={width}\n height={absHeight}\n stroke=\"none\"\n fill={fill}\n />\n );\n};\n\nexport const XAxisLabel = (props: any) => {\n const { x, y, stroke, payload, index, width, containerWidth } = props;\n const { t } = useTranslation();\n const _x =\n index === 0\n ? 48\n : containerWidth > 0\n ? containerWidth - 10\n : width + payload.offset;\n\n return (\n <g transform={`translate(${_x},${y - 6})`}>\n <text\n x={0}\n y={0}\n dy={16}\n textAnchor={index === 0 ? \"start\" : \"end\"}\n // textAnchor={\"start\"}\n fontSize={10}\n fill={\"rgba(255,255,255,0.54)\"}\n >\n {index === 0 ? payload.value : t(\"chart.now\")}\n </text>\n </g>\n );\n};\n\nconst CustomizedCross = (props: any) => {\n const { width, height, stroke, fill } = props;\n\n return (\n // @ts-ignore\n <Cross\n // y={props.y + props.top}\n x={props.x + props.width / 2}\n top={props.top}\n height={height}\n width={1}\n stroke={\"rgba(255,255,255,0.16)\"}\n strokeDasharray={\"3 2\"}\n fill={\"none\"}\n />\n );\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n coloring\n />\n );\n }\n\n return null;\n};\n\nexport const PnLBarChart = (props: PnLChartProps) => {\n const { invisible } = props;\n const colors = useColors(props.colors);\n const widthRef = useRef(0);\n\n return (\n // @ts-ignore\n <ResponsiveContainer\n className={cn(invisible && \"chart-invisible\")}\n onResize={(width, height) => {\n // console.log(\"width\", width, height);\n widthRef.current = width;\n }}\n >\n {/* @ts-ignore */}\n <BarChart\n data={props.data}\n margin={{ left: -10, top: 10, right: 10, bottom: 30 }}\n >\n {!invisible && (\n // @ts-ignore\n <Tooltip\n // cursor={{ fillOpacity: 0.1 }}\n cursor={<CustomizedCross />}\n content={<CustomTooltip />}\n />\n )}\n\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <ReferenceLine y={0} stroke=\"rgba(0,0,0,0.04)\" />\n {/* @ts-ignore */}\n\n {!invisible && (\n // @ts-ignore\n <Bar dataKey=\"pnl\" shape={<RoundedRectangle />}>\n {props.data.map((entry, index) => {\n return (\n // @ts-ignore\n <Cell\n key={`cell-${index}`}\n fill={entry.pnl > 0 ? colors.profit : colors.loss}\n />\n );\n })}\n </Bar>\n )}\n {/* @ts-ignore */}\n <YAxis\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickFormatter={(value) => tickFormatter(value)}\n tickLine={false}\n axisLine={false}\n dataKey={\"pnl\"}\n />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n // axisLine={false}\n tickLine={false}\n interval={props.data.length - 2}\n // tick={renderQuarterTick}\n height={1}\n // scale=\"time\"\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel containerWidth={widthRef.current} />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n />\n </BarChart>\n </ResponsiveContainer>\n );\n};\n","import { useTranslation } from \"@orderly.network/i18n\";\n\nexport const XAxisLabel = (props: any) => {\n const { x, y, stroke, payload, index } = props;\n const { t } = useTranslation();\n return (\n <g transform={`translate(${x},${y - 6})`}>\n <text\n x={0}\n y={0}\n dy={16}\n textAnchor=\"end\"\n fontSize={10}\n fill={\"rgba(255,255,255,0.54)\"}\n >\n {index === 0 ? payload.value : t(\"chart.now\")}\n </text>\n </g>\n );\n};\n","import { useMemo, useRef } from \"react\";\nimport { getThemeColors } from \"../utils/theme\";\nimport { useColors } from \"./useColors\";\n// import { Line } from \"../line/line\";\nimport {\n LineChart,\n XAxis,\n YAxis,\n Line,\n CartesianGrid,\n ReferenceLine,\n Tooltip,\n ResponsiveContainer,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { XAxisLabel } from \"./xAxisLabel\";\nimport { numberToHumanStyle } from \"@orderly.network/utils\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type PnlLineChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: any;\n invisible?: boolean;\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n coloring\n />\n );\n }\n\n return null;\n};\n\nconst PnlLineChart = (props: PnlLineChartProps) => {\n const colors = useColors(props.colors);\n\n const dataTransfer = (data: any[]) => {\n const series: any[] = [];\n\n data?.reduce((acc, item) => {\n acc += item.pnl;\n series.push({\n ...item,\n pnl: acc,\n _pnl: item.pnl,\n // date: new Date(item.date).getTime(),\n });\n return acc;\n }, 0);\n\n return series;\n };\n\n const data = useMemo(() => dataTransfer(props.data), [props.data]);\n\n return (\n // @ts-ignore\n <ResponsiveContainer className={props.invisible ? \"chart-invisible\" : \"\"}>\n {/* @ts-ignore */}\n <LineChart\n data={data}\n margin={{ top: 20, right: 10, left: -10, bottom: 0 }}\n >\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n interval={props.data.length - 2}\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n // scale={\"time\"}\n // type=\"number\"\n // range={}\n />\n {/* @ts-ignore */}\n <YAxis\n dataKey=\"pnl\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n tickFormatter={(value) => tickFormatter(value)}\n />\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Tooltip\n cursor={{ strokeDasharray: \"3 2\", strokeOpacity: 0.16 }}\n content={<CustomTooltip />}\n />\n )}\n\n {/* <ReferenceLine y={0} stroke=\"#000\" /> */}\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Line\n type=\"natural\"\n dataKey=\"pnl\"\n stroke={colors.primary}\n strokeWidth={2}\n dot={false}\n isAnimationActive={false}\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n );\n};\n\nexport { PnlLineChart };\n","import { useColors } from \"./useColors\";\n// import { Line } from \"../line/line\";\nimport {\n LineChart,\n XAxis,\n YAxis,\n Line,\n CartesianGrid,\n Tooltip,\n ResponsiveContainer,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { XAxisLabel } from \"./xAxisLabel\";\nimport { useRef } from \"react\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type AssetChartDataItem = {\n date: string;\n account_value: number;\n};\n\nexport type PnlLineChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: AssetChartDataItem[];\n invisible?: boolean;\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n />\n );\n }\n\n return null;\n};\n\nconst AssetLineChart = (props: PnlLineChartProps) => {\n const colors = useColors(props.colors);\n\n // const dataTransfer = (data: any[]) => {\n // const series: any[] = [];\n\n // data.reduce((acc, item) => {\n // acc += item.pnl;\n // series.push({ ...item, pnl: acc, _pnl: item.pnl });\n // return acc;\n // }, 0);\n\n // return series;\n // };\n\n // const data = useMemo(() => dataTransfer(props.data), [props.data]);\n\n return (\n // @ts-ignore\n <ResponsiveContainer className={props.invisible ? \"chart-invisible\" : \"\"}>\n {/* @ts-ignore */}\n <LineChart\n width={530}\n height={180}\n data={props.data}\n margin={{ top: 20, right: 10, left: -20, bottom: -10 }}\n >\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n interval={props.data.length - 2}\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n ></XAxis>\n {/* @ts-ignore */}\n <YAxis\n dataKey=\"account_value\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n tickFormatter={(value) => tickFormatter(value)}\n />\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Tooltip\n cursor={{ strokeDasharray: \"3 2\", strokeOpacity: 0.16 }}\n content={<CustomTooltip />}\n />\n )}\n\n {/* <Legend /> */}\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Line\n type=\"natural\"\n dataKey=\"account_value\"\n stroke={colors.profit}\n strokeWidth={2}\n dot={false}\n isAnimationActive={false}\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n );\n};\n\nexport { AssetLineChart };\n","import { useColors } from \"./useColors\";\nimport {\n BarChart,\n XAxis,\n YAxis,\n ResponsiveContainer,\n Bar,\n Cell,\n Tooltip,\n CartesianGrid,\n ReferenceLine,\n Cross,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { Box, cn } from \"@orderly.network/ui\";\n\nexport type VolChartDataItem = {\n date: string;\n volume: number;\n opacity?: string | number;\n};\n\nexport type VolChartTooltip = {\n rm?: number;\n dp?: number;\n};\n\nexport type VolChartProps = {\n colors?: {\n fill: string;\n };\n data: VolChartDataItem[];\n tooltip?: VolChartTooltip;\n className?: string;\n};\n\nconst RoundedRectangle = (props: any) => {\n const { fill, x, y, width, height, opacity } = props;\n const absHeight = Math.abs(height);\n\n return (\n <rect\n rx={2}\n x={x}\n y={height > 0 ? y : y + height}\n width={width}\n height={absHeight}\n stroke=\"none\"\n fill={fill}\n opacity={opacity}\n />\n );\n};\n\nconst CustomizedCross = (props: any) => {\n const { width, height, payload, stroke, fill } = props;\n\n if (payload?.[0]?.value === 0) return null;\n\n return (\n // @ts-ignore\n <Cross\n // y={props.y + props.top}\n x={props.x + props.width / 2}\n top={props.top}\n height={height}\n width={1}\n stroke={\"rgba(255,255,255,0.16)\"}\n strokeDasharray={\"3 2\"}\n fill={\"none\"}\n />\n );\n};\n\nconst CustomTooltip = (\n props: TooltipProps<any, any> & { tooltip?: VolChartTooltip }\n) => {\n const { active, payload, label, tooltip } = props;\n\n if (payload?.[0]?.value === 0) return null;\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label}\n value={payload[0].value}\n // prefix=\"Commission\"\n titleClassName=\"oui-gap-4\"\n rm={tooltip?.rm}\n dp={tooltip?.dp}\n />\n );\n }\n\n return null;\n};\n\nexport const VolBarChart = (props: VolChartProps) => {\n const colors = useColors(\n props.colors?.fill\n ? { profit: props.colors?.fill, loss: props.colors?.fill }\n : undefined\n );\n\n const isEmpty = props.data.reduce((a, b) => a + b.volume, 0) === 0;\n const maxVolume = props.data.reduce((a,b) => (a > b.volume ? a : b.volume), 0);\n const decimal = maxVolume <= 10 ? 2 : (maxVolume <= 100 ? 1 : 0);\n\n return (\n // @ts-ignore\n <Box className={cn(props.className)}>\n {/* @ts-ignore */}\n <ResponsiveContainer>\n {/* @ts-ignore */}\n <BarChart\n data={props.data}\n margin={{ left: -0, top: 6, right: 0, bottom: 20 }}\n >\n {/* @ts-ignore */}\n <Tooltip\n // cursor={{ fillOpacity: 0.1 }}\n cursor={<CustomizedCross />}\n content={<CustomTooltip tooltip={props.tooltip} />}\n />\n <CartesianGrid\n vertical={false}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.08}\n repeatCount={6}\n />\n {/* @ts-ignore */}\n <ReferenceLine y={0} stroke=\"#000\" />\n {/* @ts-ignore */}\n <Bar dataKey=\"volume\" shape={<RoundedRectangle />} minPointSize={1}>\n {props.data.map((entry, index) => {\n return (\n // @ts-ignore\n <Cell\n key={`cell-${index}`}\n fill={entry.volume > 0 ? colors.profit : colors.loss}\n opacity={entry.opacity}\n />\n );\n })}\n </Bar>\n {/* @ts-ignore */}\n <YAxis\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n dataKey={\"volume\"}\n tickFormatter={(value, index) => {\n if (isEmpty) return `${index * 100}`;\n return numberToHumanStyle(value, decimal);\n }}\n width={45}\n />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n // axisLine={false}\n tickLine={false}\n interval={props.data.length - 2}\n // tick={renderQuarterTick}\n height={1}\n // scale=\"time\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n stroke=\"rgb(229, 231, 235)\"\n strokeOpacity={0.2}\n />\n </BarChart>\n </ResponsiveContainer>\n </Box>\n );\n};\nfunction numberToHumanStyle(number: number, decimalPlaces: number = 0): string {\n const abbreviations = [\"\", \"K\", \"M\", \"B\", \"T\"];\n\n let index = 0;\n while (number >= 1000 && index < abbreviations.length - 1) {\n number /= 1000;\n index++;\n }\n\n const roundedNumber = toFixedWithoutRounding(number, decimalPlaces);\n\n return `${roundedNumber}${abbreviations[index]}`;\n}\n\nfunction toFixedWithoutRounding(num: number, fix: number): string {\n const numStr = num.toString();\n const decimalIndex = numStr.indexOf(\".\");\n\n if (decimalIndex === -1 || fix === 0) {\n return numStr.split(\".\")[0];\n }\n\n const cutoffIndex = decimalIndex + fix + 1;\n\n return numStr.slice(0, cutoffIndex);\n}\n","import plugin from \"tailwindcss/plugin\";\n\nimport { PluginCreator } from \"tailwindcss/types/config\";\n\nexport const chartPlugin: PluginCreator = () =>\n plugin(function ({ addComponents, addBase }) {\n addComponents(\n {\n \".xAxis\": {\n \".recharts-cartesian-axis-tick:first-child text\": {\n \"text-anchor\": \"start\",\n },\n \".recharts-cartesian-axis-tick:last-child text\": {\n \"text-anchor\": \"end\",\n },\n },\n },\n {\n respectPrefix: false,\n }\n );\n });\n"]}
1
+ {"version":3,"sources":["../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2_@swc+core@1.13.2_@swc+helpers@0.5.17__@types+node@22.16.5_typescript@5.8.3_/node_modules/tailwindcss/lib/util/createPlugin.js","../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2_@swc+core@1.13.2_@swc+helpers@0.5.17__@types+node@22.16.5_typescript@5.8.3_/node_modules/tailwindcss/lib/public/create-plugin.js","../../../node_modules/.pnpm/tailwindcss@3.4.17_ts-node@10.9.2_@swc+core@1.13.2_@swc+helpers@0.5.17__@types+node@22.16.5_typescript@5.8.3_/node_modules/tailwindcss/plugin.js","../src/utils/yTickFormatter.ts","../src/orderly/customTooltip.tsx","../src/utils/theme.ts","../src/orderly/useColors.ts","../src/orderly/pnlBar.tsx","../src/orderly/xAxisLabel.tsx","../src/orderly/pnlLine.tsx","../src/orderly/assetLine.tsx","../src/orderly/volBar.tsx","../src/tailwindcss/theme.ts"],"names":["require_createPlugin","__commonJSMin","exports","_default","createPlugin","plugin","config","pluginFunction","configFunction","optionsFunction","options","require_create_plugin","_createPlugin","_interop_require_default","obj","require_plugin","module","tickFormatter","value","absValue","dp","formatted","numberToHumanStyle","OrderlyChartTooltip","props","label","prefix","unit","coloring","rm","jsxs","Box","Flex","jsx","Text","getThemeColors","root","computedStyle","convertToRGB","color","useColors","colors","useMemo","themeColors","RoundedRectangle","fill","x","y","width","height","absHeight","XAxisLabel","stroke","payload","index","containerWidth","t","useTranslation","_x","CustomizedCross","Cross","CustomTooltip","active","todayStr","useRef","PnLBarChart","invisible","widthRef","ResponsiveContainer","cn","BarChart","Tooltip","CartesianGrid","ReferenceLine","Bar","entry","Cell","YAxis","XAxis","PnlLineChart","dataTransfer","data","series","acc","item","LineChart","Line","AssetLineChart","opacity","tooltip","VolBarChart","isEmpty","pre","cur","maxVolume","decimal","number","decimalPlaces","abbreviations","toFixedWithoutRounding","num","fix","numStr","decimalIndex","cutoffIndex","import_plugin","chartPlugin","addComponents","addBase"],"mappings":"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","file":"index.mjs","sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function() {\n return _default;\n }\n});\nfunction createPlugin(plugin, config) {\n return {\n handler: plugin,\n config\n };\n}\ncreatePlugin.withOptions = function(pluginFunction, configFunction = ()=>({})) {\n const optionsFunction = function(options) {\n return {\n __options: options,\n handler: pluginFunction(options),\n config: configFunction(options)\n };\n };\n optionsFunction.__isOptionsFunction = true;\n // Expose plugin dependencies so that `object-hash` returns a different\n // value if anything here changes, to ensure a rebuild is triggered.\n optionsFunction.__pluginFunction = pluginFunction;\n optionsFunction.__configFunction = configFunction;\n return optionsFunction;\n};\nconst _default = createPlugin;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"default\", {\n enumerable: true,\n get: function() {\n return _default;\n }\n});\nconst _createPlugin = /*#__PURE__*/ _interop_require_default(require(\"../util/createPlugin\"));\nfunction _interop_require_default(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nconst _default = _createPlugin.default;\n","let createPlugin = require('./lib/public/create-plugin')\nmodule.exports = (createPlugin.__esModule ? createPlugin : { default: createPlugin }).default\n","import { numberToHumanStyle } from \"@orderly.network/utils\";\n\nexport const tickFormatter = (value: number) => {\n let absValue = Math.abs(value);\n const dp = absValue === 0 ? 0 : absValue <= 10 ? 2 : absValue <= 100 ? 1 : 0;\n\n const formatted = numberToHumanStyle(absValue, dp);\n return value < 0 ? `-${formatted}` : formatted;\n};\n","import { Box, Flex, Text } from \"@orderly.network/ui\";\n\nexport const OrderlyChartTooltip = (props: {\n label: string;\n value: string | number;\n unit?: string;\n prefix?: React.ReactNode;\n titleClassName?: string;\n coloring?: boolean;\n dp?: number;\n rm?: number;\n}) => {\n const {\n label,\n value,\n prefix,\n unit = \"USDC\",\n coloring = false,\n dp,\n rm,\n } = props;\n return (\n <Box intensity={600} p={3} r=\"md\">\n <Flex direction={\"row\"} className={props.titleClassName}>\n {prefix}\n <Text.numeral\n unit={unit}\n as=\"div\"\n size=\"sm\"\n coloring={coloring}\n showIdentifier={coloring}\n unitClassName=\"oui-text-base-contrast-54 oui-ml-1\"\n weight=\"semibold\"\n rm={rm}\n dp={dp}\n >\n {value}\n </Text.numeral>\n </Flex>\n <Text size=\"2xs\" intensity={54} weight=\"semibold\">\n {label}\n </Text>\n </Box>\n );\n};\n","export const getThemeColors = () => {\n const root = document.documentElement;\n const computedStyle = getComputedStyle(root);\n\n const colors = {\n primary: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-primary\")\n ),\n primaryLight: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-primary-light\")\n ),\n secondary: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-secondary\")\n ),\n success: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-success\")\n ),\n warning: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-warning\")\n ),\n danger: convertToRGB(computedStyle.getPropertyValue(\"--oui-color-danger\")),\n info: convertToRGB(computedStyle.getPropertyValue(\"--oui-color-info\")),\n loss: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-trading-loss\")\n ),\n profit: convertToRGB(\n computedStyle.getPropertyValue(\"--oui-color-trading-profit\")\n ),\n };\n\n return colors;\n};\n\nconst convertToRGB = (color: string) => {\n return `rgb(${color.split(\" \").join(\",\")})`;\n};\n","import { useMemo } from \"react\";\nimport { getThemeColors } from \"../utils/theme\";\n\nexport const useColors = (colors?: { profit: string; loss: string }) => {\n const _colors = useMemo(() => {\n const themeColors = getThemeColors();\n return {\n profit: colors?.profit || themeColors.profit,\n loss: colors?.loss || themeColors.loss,\n primary: themeColors.primary,\n primaryLight: themeColors.primaryLight,\n };\n }, [colors]);\n\n return _colors;\n};\n","import { useRef } from \"react\";\nimport {\n BarChart,\n XAxis,\n YAxis,\n ResponsiveContainer,\n Bar,\n Cell,\n Tooltip,\n CartesianGrid,\n ReferenceLine,\n Cross,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { useTranslation } from \"@orderly.network/i18n\";\nimport { cn } from \"@orderly.network/ui\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { useColors } from \"./useColors\";\n\nexport type PnLChartDataItem = {\n date: string;\n pnl: number;\n};\n\nexport type PnLChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: ReadonlyArray<PnLChartDataItem> | PnLChartDataItem[];\n invisible?: boolean;\n};\n\nconst RoundedRectangle = (props: any) => {\n const { fill, x, y, width, height } = props;\n\n const absHeight = Math.abs(height);\n\n return (\n <rect\n rx={2}\n x={x}\n y={height > 0 ? y : y + height}\n width={width}\n height={absHeight}\n stroke=\"none\"\n fill={fill}\n />\n );\n};\n\nexport const XAxisLabel = (props: any) => {\n const { x, y, stroke, payload, index, width, containerWidth } = props;\n const { t } = useTranslation();\n const _x =\n index === 0\n ? 48\n : containerWidth > 0\n ? containerWidth - 10\n : width + payload.offset;\n\n return (\n <g transform={`translate(${_x},${y - 6})`}>\n <text\n x={0}\n y={0}\n dy={16}\n textAnchor={index === 0 ? \"start\" : \"end\"}\n // textAnchor={\"start\"}\n fontSize={10}\n fill={\"rgba(255,255,255,0.54)\"}\n >\n {index === 0 ? payload.value : t(\"chart.now\")}\n </text>\n </g>\n );\n};\n\nconst CustomizedCross = (props: any) => {\n const { width, height, stroke, fill } = props;\n\n return (\n // @ts-ignore\n <Cross\n // y={props.y + props.top}\n x={props.x + props.width / 2}\n top={props.top}\n height={height}\n width={1}\n stroke={\"rgba(255,255,255,0.16)\"}\n strokeDasharray={\"3 2\"}\n fill={\"none\"}\n />\n );\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n coloring\n />\n );\n }\n\n return null;\n};\n\nexport const PnLBarChart = (props: PnLChartProps) => {\n const { invisible } = props;\n const colors = useColors(props.colors);\n const widthRef = useRef(0);\n\n return (\n // @ts-ignore\n <ResponsiveContainer\n className={cn(invisible && \"chart-invisible\")}\n onResize={(width, height) => {\n // console.log(\"width\", width, height);\n widthRef.current = width;\n }}\n >\n {/* @ts-ignore */}\n <BarChart\n data={props.data as any[]}\n margin={{ left: -10, top: 10, right: 10, bottom: 30 }}\n >\n {!invisible && (\n // @ts-ignore\n <Tooltip\n // cursor={{ fillOpacity: 0.1 }}\n cursor={<CustomizedCross />}\n content={<CustomTooltip />}\n />\n )}\n\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <ReferenceLine y={0} stroke=\"rgba(0,0,0,0.04)\" />\n {/* @ts-ignore */}\n\n {!invisible && (\n // @ts-ignore\n <Bar dataKey=\"pnl\" shape={<RoundedRectangle />}>\n {props.data.map((entry, index) => {\n return (\n // @ts-ignore\n <Cell\n key={`cell-${index}`}\n fill={entry.pnl > 0 ? colors.profit : colors.loss}\n />\n );\n })}\n </Bar>\n )}\n {/* @ts-ignore */}\n <YAxis\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickFormatter={(value) => tickFormatter(value)}\n tickLine={false}\n axisLine={false}\n dataKey={\"pnl\"}\n />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n // axisLine={false}\n tickLine={false}\n interval={props.data.length - 2}\n // tick={renderQuarterTick}\n height={1}\n // scale=\"time\"\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel containerWidth={widthRef.current} />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n />\n </BarChart>\n </ResponsiveContainer>\n );\n};\n","import { useTranslation } from \"@orderly.network/i18n\";\n\nexport const XAxisLabel = (props: any) => {\n const { x, y, stroke, payload, index } = props;\n const { t } = useTranslation();\n return (\n <g transform={`translate(${x},${y - 6})`}>\n <text\n x={0}\n y={0}\n dy={16}\n textAnchor=\"end\"\n fontSize={10}\n fill={\"rgba(255,255,255,0.54)\"}\n >\n {index === 0 ? payload.value : t(\"chart.now\")}\n </text>\n </g>\n );\n};\n","import { useMemo, useRef } from \"react\";\nimport { getThemeColors } from \"../utils/theme\";\nimport { useColors } from \"./useColors\";\n// import { Line } from \"../line/line\";\nimport {\n LineChart,\n XAxis,\n YAxis,\n Line,\n CartesianGrid,\n ReferenceLine,\n Tooltip,\n ResponsiveContainer,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { XAxisLabel } from \"./xAxisLabel\";\nimport { numberToHumanStyle } from \"@orderly.network/utils\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type PnlLineChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: any;\n invisible?: boolean;\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n coloring\n />\n );\n }\n\n return null;\n};\n\nconst PnlLineChart = (props: PnlLineChartProps) => {\n const colors = useColors(props.colors);\n\n const dataTransfer = (data: any[]) => {\n const series: any[] = [];\n\n data?.reduce((acc, item) => {\n acc += item.pnl;\n series.push({\n ...item,\n pnl: acc,\n _pnl: item.pnl,\n // date: new Date(item.date).getTime(),\n });\n return acc;\n }, 0);\n\n return series;\n };\n\n const data = useMemo(() => dataTransfer(props.data), [props.data]);\n\n return (\n // @ts-ignore\n <ResponsiveContainer className={props.invisible ? \"chart-invisible\" : \"\"}>\n {/* @ts-ignore */}\n <LineChart\n data={data}\n margin={{ top: 20, right: 10, left: -10, bottom: 0 }}\n >\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n interval={props.data.length - 2}\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n // scale={\"time\"}\n // type=\"number\"\n // range={}\n />\n {/* @ts-ignore */}\n <YAxis\n dataKey=\"pnl\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n tickFormatter={(value) => tickFormatter(value)}\n />\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Tooltip\n cursor={{ strokeDasharray: \"3 2\", strokeOpacity: 0.16 }}\n content={<CustomTooltip />}\n />\n )}\n\n {/* <ReferenceLine y={0} stroke=\"#000\" /> */}\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Line\n type=\"natural\"\n dataKey=\"pnl\"\n stroke={colors.primary}\n strokeWidth={2}\n dot={false}\n isAnimationActive={false}\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n );\n};\n\nexport { PnlLineChart };\n","import { useColors } from \"./useColors\";\n// import { Line } from \"../line/line\";\nimport {\n LineChart,\n XAxis,\n YAxis,\n Line,\n CartesianGrid,\n Tooltip,\n ResponsiveContainer,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { XAxisLabel } from \"./xAxisLabel\";\nimport { useRef } from \"react\";\nimport { tickFormatter } from \"../utils/yTickFormatter\";\nimport { useTranslation } from \"@orderly.network/i18n\";\n\nexport type AssetChartDataItem = {\n date: string;\n account_value: number;\n};\n\nexport type PnlLineChartProps = {\n colors?: {\n profit: string;\n loss: string;\n };\n data: AssetChartDataItem[];\n invisible?: boolean;\n};\n\nconst CustomTooltip = (props: TooltipProps<any, any>) => {\n const { active, payload, label } = props;\n const todayStr = useRef(new Date().toISOString().split(\"T\")[0]);\n const { t } = useTranslation();\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label === todayStr.current ? t(\"chart.now\") : label}\n value={payload[0].value}\n />\n );\n }\n\n return null;\n};\n\nconst AssetLineChart = (props: PnlLineChartProps) => {\n const colors = useColors(props.colors);\n\n // const dataTransfer = (data: any[]) => {\n // const series: any[] = [];\n\n // data.reduce((acc, item) => {\n // acc += item.pnl;\n // series.push({ ...item, pnl: acc, _pnl: item.pnl });\n // return acc;\n // }, 0);\n\n // return series;\n // };\n\n // const data = useMemo(() => dataTransfer(props.data), [props.data]);\n\n return (\n // @ts-ignore\n <ResponsiveContainer className={props.invisible ? \"chart-invisible\" : \"\"}>\n {/* @ts-ignore */}\n <LineChart\n width={530}\n height={180}\n data={props.data}\n margin={{ top: 20, right: 10, left: -20, bottom: -10 }}\n >\n <CartesianGrid vertical={false} stroke=\"#FFFFFF\" strokeOpacity={0.04} />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n interval={props.data.length - 2}\n // tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tick={<XAxisLabel />}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.04}\n ></XAxis>\n {/* @ts-ignore */}\n <YAxis\n dataKey=\"account_value\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n tickFormatter={(value) => tickFormatter(value)}\n />\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Tooltip\n cursor={{ strokeDasharray: \"3 2\", strokeOpacity: 0.16 }}\n content={<CustomTooltip />}\n />\n )}\n\n {/* <Legend /> */}\n {/* @ts-ignore */}\n {!props.invisible && (\n // @ts-ignore\n <Line\n type=\"natural\"\n dataKey=\"account_value\"\n stroke={colors.profit}\n strokeWidth={2}\n dot={false}\n isAnimationActive={false}\n />\n )}\n </LineChart>\n </ResponsiveContainer>\n );\n};\n\nexport { AssetLineChart };\n","import {\n BarChart,\n XAxis,\n YAxis,\n ResponsiveContainer,\n Bar,\n Cell,\n Tooltip,\n CartesianGrid,\n ReferenceLine,\n Cross,\n} from \"recharts\";\nimport type { TooltipProps } from \"recharts\";\nimport { Box, cn } from \"@orderly.network/ui\";\nimport { OrderlyChartTooltip } from \"./customTooltip\";\nimport { useColors } from \"./useColors\";\n\nexport type VolChartDataItem = {\n date: string;\n volume: number;\n opacity?: string | number;\n};\n\nexport type VolChartTooltip = {\n rm?: number;\n dp?: number;\n};\n\nexport type VolChartProps = {\n colors?: { fill: string };\n data: ReadonlyArray<VolChartDataItem> | VolChartDataItem[];\n tooltip?: VolChartTooltip;\n className?: string;\n};\n\nconst RoundedRectangle = (props: any) => {\n const { fill, x, y, width, height, opacity } = props;\n const absHeight = Math.abs(height);\n\n return (\n <rect\n rx={2}\n x={x}\n y={height > 0 ? y : y + height}\n width={width}\n height={absHeight}\n stroke=\"none\"\n fill={fill}\n opacity={opacity}\n />\n );\n};\n\nconst CustomizedCross = (props: any) => {\n const { width, height, payload, stroke, fill } = props;\n\n if (payload?.[0]?.value === 0) {\n return null;\n }\n\n return (\n // @ts-ignore\n <Cross\n // y={props.y + props.top}\n x={props.x + props.width / 2}\n top={props.top}\n height={height}\n width={1}\n stroke={\"rgba(255,255,255,0.16)\"}\n strokeDasharray={\"3 2\"}\n fill={\"none\"}\n />\n );\n};\n\nconst CustomTooltip = (\n props: TooltipProps<any, any> & { tooltip?: VolChartTooltip },\n) => {\n const { active, payload, label, tooltip } = props;\n\n if (payload?.[0]?.value === 0) {\n return null;\n }\n\n if (active && payload && payload.length) {\n return (\n <OrderlyChartTooltip\n label={label}\n value={payload[0].value}\n // prefix=\"Commission\"\n titleClassName=\"oui-gap-4\"\n rm={tooltip?.rm}\n dp={tooltip?.dp}\n />\n );\n }\n\n return null;\n};\n\nexport const VolBarChart = (props: VolChartProps) => {\n const colors = useColors(\n props.colors?.fill\n ? { profit: props.colors?.fill, loss: props.colors?.fill }\n : undefined,\n );\n\n const isEmpty =\n (props.data as any)?.reduce((pre: any, cur: any) => pre + cur.volume, 0) ===\n 0;\n\n const maxVolume = (props.data as any)?.reduce(\n (pre: any, cur: any) => (pre > cur.volume ? pre : cur.volume),\n 0,\n );\n\n const decimal = maxVolume <= 10 ? 2 : maxVolume <= 100 ? 1 : 0;\n\n return (\n // @ts-ignore\n <Box className={cn(props.className)}>\n {/* @ts-ignore */}\n <ResponsiveContainer>\n {/* @ts-ignore */}\n <BarChart\n data={props.data as any[]}\n margin={{ left: -0, top: 6, right: 0, bottom: 20 }}\n >\n {/* @ts-ignore */}\n <Tooltip\n // cursor={{ fillOpacity: 0.1 }}\n cursor={<CustomizedCross />}\n content={<CustomTooltip tooltip={props.tooltip} />}\n />\n <CartesianGrid\n vertical={false}\n stroke=\"#FFFFFF\"\n strokeOpacity={0.08}\n repeatCount={6}\n />\n {/* @ts-ignore */}\n <ReferenceLine y={0} stroke=\"#000\" />\n {/* @ts-ignore */}\n <Bar dataKey=\"volume\" shape={<RoundedRectangle />} minPointSize={1}>\n {props.data.map((entry, index) => {\n return (\n // @ts-ignore\n <Cell\n key={`cell-${index}`}\n fill={entry.volume > 0 ? colors.profit : colors.loss}\n opacity={entry.opacity}\n />\n );\n })}\n </Bar>\n {/* @ts-ignore */}\n <YAxis\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n tickLine={false}\n axisLine={false}\n dataKey={\"volume\"}\n tickFormatter={(value, index) => {\n if (isEmpty) return `${index * 100}`;\n return numberToHumanStyle(value, decimal);\n }}\n width={45}\n />\n {/* @ts-ignore */}\n <XAxis\n dataKey=\"date\"\n // axisLine={false}\n tickLine={false}\n interval={props.data.length - 2}\n // tick={renderQuarterTick}\n height={1}\n // scale=\"time\"\n tick={{ fontSize: 10, fill: \"rgba(255,255,255,0.54)\" }}\n stroke=\"rgb(229, 231, 235)\"\n strokeOpacity={0.2}\n />\n </BarChart>\n </ResponsiveContainer>\n </Box>\n );\n};\nfunction numberToHumanStyle(number: number, decimalPlaces: number = 0): string {\n const abbreviations = [\"\", \"K\", \"M\", \"B\", \"T\"];\n\n let index = 0;\n while (number >= 1000 && index < abbreviations.length - 1) {\n number /= 1000;\n index++;\n }\n\n const roundedNumber = toFixedWithoutRounding(number, decimalPlaces);\n\n return `${roundedNumber}${abbreviations[index]}`;\n}\n\nfunction toFixedWithoutRounding(num: number, fix: number): string {\n const numStr = num.toString();\n const decimalIndex = numStr.indexOf(\".\");\n\n if (decimalIndex === -1 || fix === 0) {\n return numStr.split(\".\")[0];\n }\n\n const cutoffIndex = decimalIndex + fix + 1;\n\n return numStr.slice(0, cutoffIndex);\n}\n","import plugin from \"tailwindcss/plugin\";\n\nimport { PluginCreator } from \"tailwindcss/types/config\";\n\nexport const chartPlugin: PluginCreator = () =>\n plugin(function ({ addComponents, addBase }) {\n addComponents(\n {\n \".xAxis\": {\n \".recharts-cartesian-axis-tick:first-child text\": {\n \"text-anchor\": \"start\",\n },\n \".recharts-cartesian-axis-tick:last-child text\": {\n \"text-anchor\": \"end\",\n },\n },\n },\n {\n respectPrefix: false,\n }\n );\n });\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@orderly.network/chart",
3
- "version": "2.5.3",
3
+ "version": "2.6.0-alpha.0",
4
4
  "description": "Charting library for Orderly Network",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.mjs",
@@ -23,7 +23,7 @@
23
23
  "react-dom": "^18.2.0",
24
24
  "tailwindcss": "^3.4.4",
25
25
  "tsup": "^8.1.0",
26
- "tsconfig": "0.8.3"
26
+ "tsconfig": "0.9.0-alpha.0"
27
27
  },
28
28
  "peerDependencies": {
29
29
  "react": ">=18",
@@ -36,9 +36,9 @@
36
36
  "d3-selection": "^3.0.0",
37
37
  "d3-shape": "^3.2.0",
38
38
  "recharts": "^2.12.7",
39
- "@orderly.network/utils": "2.5.3",
40
- "@orderly.network/i18n": "2.5.3",
41
- "@orderly.network/ui": "2.5.3"
39
+ "@orderly.network/i18n": "2.6.0-alpha.0",
40
+ "@orderly.network/utils": "2.6.0-alpha.0",
41
+ "@orderly.network/ui": "2.6.0-alpha.0"
42
42
  },
43
43
  "scripts": {
44
44
  "build": "tsup",