using ApexCharts ;
using Biskilog_Accounting.Shared.CustomModels ;
using Microsoft.AspNetCore.Components ;
using Microsoft.Extensions.Options ;
namespace Biskilog_Accounting.Client.Pages.Dashboard.Elements
{
public partial class ChartElement
{
[Parameter]
public bool IsLoading { get ; set ; }
[Parameter]
public string Title { get ; set ; } = string . Empty ;
[Parameter]
public string SubTitle { get ; set ; } = string . Empty ;
[Parameter]
public List < WeeklySaleItem > Series { get ; set ; } = new List < WeeklySaleItem > ( ) ;
private ApexChartOptions < WeeklySaleItem > m_options ;
private ApexChartOptions < WeeklySaleItem > options = new ApexChartOptions < WeeklySaleItem > ( ) ;
private string m_bestDay { get ; set ; } = string . Empty ;
private string m_worstDay { get ; set ; } = string . Empty ;
private string m_bestSales { get ; set ; } = string . Empty ;
private string m_worstSales { get ; set ; } = string . Empty ;
protected override void OnParametersSet ( )
{
m_options = new ApexChartOptions < WeeklySaleItem >
{
PlotOptions = new PlotOptions
{
Bar = new PlotOptionsBar
{
ColumnWidth = "20" ,
}
} ,
Colors = new List < string > { "#11726d" } ,
Yaxis = new List < YAxis >
{
new YAxis
{
Labels = new YAxisLabels
{
Formatter = @ "function (value, index, w) {
return Number ( value ) . toLocaleString ( ) ; } "
}
}
} ,
} ;
options . Colors = new List < string > { "#11726d" } ;
options . Fill = new Fill
{
Type = new List < FillType > { FillType . Gradient , FillType . Gradient } ,
Gradient = new FillGradient
{
ShadeIntensity = 1 ,
OpacityFrom = 0.2 ,
OpacityTo = 0.9 ,
}
} ;
options . Yaxis = new List < YAxis >
{
new YAxis
{
Labels = new YAxisLabels
{
Formatter = @ "function (value, index, w) {
return Number ( value ) . toLocaleString ( ) ; } "
}
}
} ;
if ( Series . Count > 1 )
{
m_bestDay = Series . OrderByDescending ( t = > t . Total ) . First ( ) . Date . ToShortDateString ( ) ;
m_bestSales = m_calculator . FormatMoneyWithCurrencyKilo ( ( double ) Series . OrderByDescending ( t = > t . Total ) . First ( ) . Total ) ;
m_worstDay = Series . OrderByDescending ( t = > t . Total ) . Last ( ) . Date . ToShortDateString ( ) ;
m_worstSales = m_calculator . FormatMoneyWithCurrencyKilo ( ( double ) Series . OrderByDescending ( t = > t . Total ) . Last ( ) . Total ) ;
}
base . OnParametersSet ( ) ;
}
}
}