You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
662 lines
15 KiB
662 lines
15 KiB
/**
|
|
* Dashboard Analytics
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
(function () {
|
|
let cardColor, headingColor, axisColor, shadeColor, borderColor;
|
|
|
|
cardColor = config.colors.white;
|
|
headingColor = config.colors.headingColor;
|
|
axisColor = config.colors.axisColor;
|
|
borderColor = config.colors.borderColor;
|
|
|
|
// Total Revenue Report Chart - Bar Chart
|
|
// --------------------------------------------------------------------
|
|
const totalRevenueChartEl = document.querySelector('#totalRevenueChart'),
|
|
totalRevenueChartOptions = {
|
|
series: [
|
|
{
|
|
name: '2021',
|
|
data: [18, 7, 15, 29, 18, 12, 9]
|
|
},
|
|
{
|
|
name: '2020',
|
|
data: [-13, -18, -9, -14, -5, -17, -15]
|
|
}
|
|
],
|
|
chart: {
|
|
height: 300,
|
|
stacked: true,
|
|
type: 'bar',
|
|
toolbar: { show: false }
|
|
},
|
|
plotOptions: {
|
|
bar: {
|
|
horizontal: false,
|
|
columnWidth: '33%',
|
|
borderRadius: 12,
|
|
startingShape: 'rounded',
|
|
endingShape: 'rounded'
|
|
}
|
|
},
|
|
colors: [config.colors.primary, config.colors.info],
|
|
dataLabels: {
|
|
enabled: false
|
|
},
|
|
stroke: {
|
|
curve: 'smooth',
|
|
width: 6,
|
|
lineCap: 'round',
|
|
colors: [cardColor]
|
|
},
|
|
legend: {
|
|
show: true,
|
|
horizontalAlign: 'left',
|
|
position: 'top',
|
|
markers: {
|
|
height: 8,
|
|
width: 8,
|
|
radius: 12,
|
|
offsetX: -3
|
|
},
|
|
labels: {
|
|
colors: axisColor
|
|
},
|
|
itemMargin: {
|
|
horizontal: 10
|
|
}
|
|
},
|
|
grid: {
|
|
borderColor: borderColor,
|
|
padding: {
|
|
top: 0,
|
|
bottom: -8,
|
|
left: 20,
|
|
right: 20
|
|
}
|
|
},
|
|
xaxis: {
|
|
categories: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul'],
|
|
labels: {
|
|
style: {
|
|
fontSize: '13px',
|
|
colors: axisColor
|
|
}
|
|
},
|
|
axisTicks: {
|
|
show: false
|
|
},
|
|
axisBorder: {
|
|
show: false
|
|
}
|
|
},
|
|
yaxis: {
|
|
labels: {
|
|
style: {
|
|
fontSize: '13px',
|
|
colors: axisColor
|
|
}
|
|
}
|
|
},
|
|
responsive: [
|
|
{
|
|
breakpoint: 1700,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '32%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 1580,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '35%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 1440,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '42%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 1300,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '48%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 1200,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '40%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 1040,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 11,
|
|
columnWidth: '48%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 991,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '30%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 840,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '35%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 768,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '28%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 640,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '32%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 576,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '37%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 480,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '45%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 420,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '52%'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
breakpoint: 380,
|
|
options: {
|
|
plotOptions: {
|
|
bar: {
|
|
borderRadius: 10,
|
|
columnWidth: '60%'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
],
|
|
states: {
|
|
hover: {
|
|
filter: {
|
|
type: 'none'
|
|
}
|
|
},
|
|
active: {
|
|
filter: {
|
|
type: 'none'
|
|
}
|
|
}
|
|
}
|
|
};
|
|
if (typeof totalRevenueChartEl !== undefined && totalRevenueChartEl !== null) {
|
|
const totalRevenueChart = new ApexCharts(totalRevenueChartEl, totalRevenueChartOptions);
|
|
totalRevenueChart.render();
|
|
}
|
|
|
|
// Growth Chart - Radial Bar Chart
|
|
// --------------------------------------------------------------------
|
|
const growthChartEl = document.querySelector('#growthChart'),
|
|
growthChartOptions = {
|
|
series: [78],
|
|
labels: ['Growth'],
|
|
chart: {
|
|
height: 240,
|
|
type: 'radialBar'
|
|
},
|
|
plotOptions: {
|
|
radialBar: {
|
|
size: 150,
|
|
offsetY: 10,
|
|
startAngle: -150,
|
|
endAngle: 150,
|
|
hollow: {
|
|
size: '55%'
|
|
},
|
|
track: {
|
|
background: cardColor,
|
|
strokeWidth: '100%'
|
|
},
|
|
dataLabels: {
|
|
name: {
|
|
offsetY: 15,
|
|
color: headingColor,
|
|
fontSize: '15px',
|
|
fontWeight: '600',
|
|
fontFamily: 'Public Sans'
|
|
},
|
|
value: {
|
|
offsetY: -25,
|
|
color: headingColor,
|
|
fontSize: '22px',
|
|
fontWeight: '500',
|
|
fontFamily: 'Public Sans'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
colors: [config.colors.primary],
|
|
fill: {
|
|
type: 'gradient',
|
|
gradient: {
|
|
shade: 'dark',
|
|
shadeIntensity: 0.5,
|
|
gradientToColors: [config.colors.primary],
|
|
inverseColors: true,
|
|
opacityFrom: 1,
|
|
opacityTo: 0.6,
|
|
stops: [30, 70, 100]
|
|
}
|
|
},
|
|
stroke: {
|
|
dashArray: 5
|
|
},
|
|
grid: {
|
|
padding: {
|
|
top: -35,
|
|
bottom: -10
|
|
}
|
|
},
|
|
states: {
|
|
hover: {
|
|
filter: {
|
|
type: 'none'
|
|
}
|
|
},
|
|
active: {
|
|
filter: {
|
|
type: 'none'
|
|
}
|
|
}
|
|
}
|
|
};
|
|
if (typeof growthChartEl !== undefined && growthChartEl !== null) {
|
|
const growthChart = new ApexCharts(growthChartEl, growthChartOptions);
|
|
growthChart.render();
|
|
}
|
|
|
|
// Profit Report Line Chart
|
|
// --------------------------------------------------------------------
|
|
const profileReportChartEl = document.querySelector('#profileReportChart'),
|
|
profileReportChartConfig = {
|
|
chart: {
|
|
height: 80,
|
|
// width: 175,
|
|
type: 'line',
|
|
toolbar: {
|
|
show: false
|
|
},
|
|
dropShadow: {
|
|
enabled: true,
|
|
top: 10,
|
|
left: 5,
|
|
blur: 3,
|
|
color: config.colors.warning,
|
|
opacity: 0.15
|
|
},
|
|
sparkline: {
|
|
enabled: true
|
|
}
|
|
},
|
|
grid: {
|
|
show: false,
|
|
padding: {
|
|
right: 8
|
|
}
|
|
},
|
|
colors: [config.colors.warning],
|
|
dataLabels: {
|
|
enabled: false
|
|
},
|
|
stroke: {
|
|
width: 5,
|
|
curve: 'smooth'
|
|
},
|
|
series: [
|
|
{
|
|
data: [110, 270, 145, 245, 205, 285]
|
|
}
|
|
],
|
|
xaxis: {
|
|
show: false,
|
|
lines: {
|
|
show: false
|
|
},
|
|
labels: {
|
|
show: false
|
|
},
|
|
axisBorder: {
|
|
show: false
|
|
}
|
|
},
|
|
yaxis: {
|
|
show: false
|
|
}
|
|
};
|
|
if (typeof profileReportChartEl !== undefined && profileReportChartEl !== null) {
|
|
const profileReportChart = new ApexCharts(profileReportChartEl, profileReportChartConfig);
|
|
profileReportChart.render();
|
|
}
|
|
|
|
// Order Statistics Chart
|
|
// --------------------------------------------------------------------
|
|
const chartOrderStatistics = document.querySelector('#orderStatisticsChart'),
|
|
orderChartConfig = {
|
|
chart: {
|
|
height: 165,
|
|
width: 130,
|
|
type: 'donut'
|
|
},
|
|
labels: ['Electronic', 'Sports', 'Decor', 'Fashion'],
|
|
series: [85, 15, 50, 50],
|
|
colors: [config.colors.primary, config.colors.secondary, config.colors.info, config.colors.success],
|
|
stroke: {
|
|
width: 5,
|
|
colors: cardColor
|
|
},
|
|
dataLabels: {
|
|
enabled: false,
|
|
formatter: function (val, opt) {
|
|
return parseInt(val) + '%';
|
|
}
|
|
},
|
|
legend: {
|
|
show: false
|
|
},
|
|
grid: {
|
|
padding: {
|
|
top: 0,
|
|
bottom: 0,
|
|
right: 15
|
|
}
|
|
},
|
|
plotOptions: {
|
|
pie: {
|
|
donut: {
|
|
size: '75%',
|
|
labels: {
|
|
show: true,
|
|
value: {
|
|
fontSize: '1.5rem',
|
|
fontFamily: 'Public Sans',
|
|
color: headingColor,
|
|
offsetY: -15,
|
|
formatter: function (val) {
|
|
return parseInt(val) + '%';
|
|
}
|
|
},
|
|
name: {
|
|
offsetY: 20,
|
|
fontFamily: 'Public Sans'
|
|
},
|
|
total: {
|
|
show: true,
|
|
fontSize: '0.8125rem',
|
|
color: axisColor,
|
|
label: 'Weekly',
|
|
formatter: function (w) {
|
|
return '38%';
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
};
|
|
if (typeof chartOrderStatistics !== undefined && chartOrderStatistics !== null) {
|
|
const statisticsChart = new ApexCharts(chartOrderStatistics, orderChartConfig);
|
|
statisticsChart.render();
|
|
}
|
|
|
|
// Income Chart - Area chart
|
|
// --------------------------------------------------------------------
|
|
const incomeChartEl = document.querySelector('#incomeChart'),
|
|
incomeChartConfig = {
|
|
series: [
|
|
{
|
|
data: [24, 21, 30, 22, 42, 26, 35, 29]
|
|
}
|
|
],
|
|
chart: {
|
|
height: 215,
|
|
parentHeightOffset: 0,
|
|
parentWidthOffset: 0,
|
|
toolbar: {
|
|
show: false
|
|
},
|
|
type: 'area'
|
|
},
|
|
dataLabels: {
|
|
enabled: false
|
|
},
|
|
stroke: {
|
|
width: 2,
|
|
curve: 'smooth'
|
|
},
|
|
legend: {
|
|
show: false
|
|
},
|
|
markers: {
|
|
size: 6,
|
|
colors: 'transparent',
|
|
strokeColors: 'transparent',
|
|
strokeWidth: 4,
|
|
discrete: [
|
|
{
|
|
fillColor: config.colors.white,
|
|
seriesIndex: 0,
|
|
dataPointIndex: 7,
|
|
strokeColor: config.colors.primary,
|
|
strokeWidth: 2,
|
|
size: 6,
|
|
radius: 8
|
|
}
|
|
],
|
|
hover: {
|
|
size: 7
|
|
}
|
|
},
|
|
colors: [config.colors.primary],
|
|
fill: {
|
|
type: 'gradient',
|
|
gradient: {
|
|
shade: shadeColor,
|
|
shadeIntensity: 0.6,
|
|
opacityFrom: 0.5,
|
|
opacityTo: 0.25,
|
|
stops: [0, 95, 100]
|
|
}
|
|
},
|
|
grid: {
|
|
borderColor: borderColor,
|
|
strokeDashArray: 3,
|
|
padding: {
|
|
top: -20,
|
|
bottom: -8,
|
|
left: -10,
|
|
right: 8
|
|
}
|
|
},
|
|
xaxis: {
|
|
categories: ['', 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul'],
|
|
axisBorder: {
|
|
show: false
|
|
},
|
|
axisTicks: {
|
|
show: false
|
|
},
|
|
labels: {
|
|
show: true,
|
|
style: {
|
|
fontSize: '13px',
|
|
colors: axisColor
|
|
}
|
|
}
|
|
},
|
|
yaxis: {
|
|
labels: {
|
|
show: false
|
|
},
|
|
min: 10,
|
|
max: 50,
|
|
tickAmount: 4
|
|
}
|
|
};
|
|
if (typeof incomeChartEl !== undefined && incomeChartEl !== null) {
|
|
const incomeChart = new ApexCharts(incomeChartEl, incomeChartConfig);
|
|
incomeChart.render();
|
|
}
|
|
|
|
// Expenses Mini Chart - Radial Chart
|
|
// --------------------------------------------------------------------
|
|
const weeklyExpensesEl = document.querySelector('#expensesOfWeek'),
|
|
weeklyExpensesConfig = {
|
|
series: [65],
|
|
chart: {
|
|
width: 60,
|
|
height: 60,
|
|
type: 'radialBar'
|
|
},
|
|
plotOptions: {
|
|
radialBar: {
|
|
startAngle: 0,
|
|
endAngle: 360,
|
|
strokeWidth: '8',
|
|
hollow: {
|
|
margin: 2,
|
|
size: '45%'
|
|
},
|
|
track: {
|
|
strokeWidth: '50%',
|
|
background: borderColor
|
|
},
|
|
dataLabels: {
|
|
show: true,
|
|
name: {
|
|
show: false
|
|
},
|
|
value: {
|
|
formatter: function (val) {
|
|
return '$' + parseInt(val);
|
|
},
|
|
offsetY: 5,
|
|
color: '#697a8d',
|
|
fontSize: '13px',
|
|
show: true
|
|
}
|
|
}
|
|
}
|
|
},
|
|
fill: {
|
|
type: 'solid',
|
|
colors: config.colors.primary
|
|
},
|
|
stroke: {
|
|
lineCap: 'round'
|
|
},
|
|
grid: {
|
|
padding: {
|
|
top: -10,
|
|
bottom: -15,
|
|
left: -10,
|
|
right: -10
|
|
}
|
|
},
|
|
states: {
|
|
hover: {
|
|
filter: {
|
|
type: 'none'
|
|
}
|
|
},
|
|
active: {
|
|
filter: {
|
|
type: 'none'
|
|
}
|
|
}
|
|
}
|
|
};
|
|
if (typeof weeklyExpensesEl !== undefined && weeklyExpensesEl !== null) {
|
|
const weeklyExpenses = new ApexCharts(weeklyExpensesEl, weeklyExpensesConfig);
|
|
weeklyExpenses.render();
|
|
}
|
|
})();
|
|
|