Skip to content

Commit

Permalink
Apply format currency to tAxes
Browse files Browse the repository at this point in the history
  • Loading branch information
benguozakinci@gmail.com authored and benguozakinci@gmail.com committed Sep 2, 2021
1 parent bcc97e3 commit 68e7885
Showing 1 changed file with 93 additions and 57 deletions.
150 changes: 93 additions & 57 deletions app/Traits/Charts.php
Original file line number Diff line number Diff line change
Expand Up @@ -95,57 +95,6 @@ public function getDonutChartOptions($colors)
];
}

public function formatMoney($str){
return new Raw(
"
const moneySettings = {
decimal: '" . config('money.' . setting('default.currency') . '.decimal_mark') . "',
thousands: '". config('money.' . setting('default.currency') . '.thousands_separator') . "',
symbol: '" . config('money.' . setting('default.currency') . '.symbol') . "',
isPrefix: '" . config('money.' . setting('default.currency') . '.symbol_first') . "',
precision: '" . config('money.' . setting('default.currency') . '.precision') . "',
};
const $str = function (input, opt = moneySettings) {
function fixed (precision) {
return Math.max(0, Math.min(precision, 20));
};
function toStr(value) {
return value ? value.toString() : '';
};
function numbersToCurrency(numbers, precision) {
var exp = Math.pow(10, precision);
var float = parseFloat(numbers) / exp;
return float.toFixed(fixed(precision));
};
function joinIntegerAndDecimal (integer, decimal, separator) {
return decimal ? integer + separator + decimal : integer;
};
if (typeof input === 'number') {
input = input.toFixed(fixed(opt.precision));
};
var negative = input.indexOf('-') >= 0 ? '-' : '';
var numbers = toStr(input).replace(/\D+/g, '') || '0';
var currency = numbersToCurrency(numbers, opt.precision);
var parts = toStr(currency).split('.');
var integer = parts[0].replace(/(\d)(?=(?:\d{3})+\b)/gm, opt.thousands);;
var decimal = parts[1];
if(opt.isPrefix) {
return opt.symbol + negative + joinIntegerAndDecimal(integer, decimal, opt.decimal)
}
return negative + joinIntegerAndDecimal(integer, decimal, opt.decimal) + opt.suffix;
}"
);
}

public function getLineChartOptions()
{
return [
Expand All @@ -160,6 +109,52 @@ public function getLineChartOptions()
'position' => 'nearest',
'callbacks' => [
'label' => new Raw("function(tooltipItem, data) {
const moneySettings = {
decimal: '" . config('money.' . setting('default.currency') . '.decimal_mark') . "',
thousands: '". config('money.' . setting('default.currency') . '.thousands_separator') . "',
symbol: '" . config('money.' . setting('default.currency') . '.symbol') . "',
isPrefix: '" . config('money.' . setting('default.currency') . '.symbol_first') . "',
precision: '" . config('money.' . setting('default.currency') . '.precision') . "',
};
const formattedCurrency = function (input, opt = moneySettings) {
function fixed (precision) {
return Math.max(0, Math.min(precision, 20));
};
function toStr(value) {
return value ? value.toString() : '';
};
function numbersToCurrency(numbers, precision) {
var exp = Math.pow(10, precision);
var float = parseFloat(numbers) / exp;
return float.toFixed(fixed(precision));
};
function joinIntegerAndDecimal (integer, decimal, separator) {
return decimal ? integer + separator + decimal : integer;
};
if (typeof input === 'number') {
input = input.toFixed(fixed(opt.precision));
};
var negative = input.indexOf('-') >= 0 ? '-' : '';
var numbers = toStr(input).replace(/\D+/g, '') || '0';
var currency = numbersToCurrency(numbers, opt.precision);
var parts = toStr(currency).split('.');
var integer = parts[0].replace(/(\d)(?=(?:\d{3})+\b)/gm, opt.thousands);;
var decimal = parts[1];
if(opt.isPrefix == 1) {
return opt.symbol + negative + joinIntegerAndDecimal(integer, decimal, opt.decimal)
}
return negative + joinIntegerAndDecimal(integer, decimal, opt.decimal) + opt.symbol;
};
return formattedCurrency(tooltipItem.yLabel, moneySettings);
}")
],
Expand All @@ -169,8 +164,53 @@ public function getLineChartOptions()
'ticks' => [
'beginAtZero' => true,
'callback' => new Raw("function(value, index, values) {
return '" . config('money.' . setting('default.currency') . '.symbol') . "' + value;
const moneySettings = {
decimal: '" . config('money.' . setting('default.currency') . '.decimal_mark') . "',
thousands: '". config('money.' . setting('default.currency') . '.thousands_separator') . "',
symbol: '" . config('money.' . setting('default.currency') . '.symbol') . "',
isPrefix: '" . config('money.' . setting('default.currency') . '.symbol_first') . "',
precision: '" . config('money.' . setting('default.currency') . '.precision') . "',
};
const formattedCurrency = function (input, opt = moneySettings) {
function fixed (precision) {
return Math.max(0, Math.min(precision, 20));
};
function toStr(value) {
return value ? value.toString() : '';
};
function numbersToCurrency(numbers, precision) {
var exp = Math.pow(10, precision);
var float = parseFloat(numbers) / exp;
return float.toFixed(fixed(precision));
};
function joinIntegerAndDecimal (integer, decimal, separator) {
return decimal ? integer + separator + decimal : integer;
};
if (typeof input === 'number') {
input = input.toFixed(fixed(opt.precision));
};
var negative = input.indexOf('-') >= 0 ? '-' : '';
var numbers = toStr(input).replace(/\D+/g, '') || '0';
var currency = numbersToCurrency(numbers, opt.precision);
var parts = toStr(currency).split('.');
var integer = parts[0].replace(/(\d)(?=(?:\d{3})+\b)/gm, opt.thousands);;
var decimal = parts[1];
if(opt.isPrefix == 1) {
return opt.symbol + negative + joinIntegerAndDecimal(integer, decimal, opt.decimal)
} else {
return negative + joinIntegerAndDecimal(integer, decimal, opt.decimal) + opt.symbol;
}
};
return formattedCurrency(value, moneySettings);
}"),
],
]
Expand All @@ -182,9 +222,6 @@ public function getLineChartOptions()
'ticks' => [
'padding' => 10,
'fontColor' => '#9e9e9e',
'callback' => new Raw("function(value, index, values) {
return '" . config('money.' . setting('default.currency') . '.symbol') . "' + value;
}"),
]],
'gridLines' => [
'drawBorder' => false,
Expand Down Expand Up @@ -212,4 +249,3 @@ public function getLineChartOptions()
];
}
}

0 comments on commit 68e7885

Please sign in to comment.